Audio plugin host https://kx.studio/carla
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

1410 lines
49KB

  1. /*
  2. * Carla LADSPA Plugin
  3. * Copyright (C) 2011-2013 Filipe Coelho <falktx@falktx.com>
  4. *
  5. * This program is free software; you can redistribute it and/or
  6. * modify it under the terms of the GNU General Public License as
  7. * published by the Free Software Foundation; either version 2 of
  8. * the License, or any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * For a full copy of the GNU General Public License see the GPL.txt file
  16. */
  17. #include "CarlaPluginInternal.hpp"
  18. #ifdef WANT_LADSPA
  19. #include "CarlaLadspaUtils.hpp"
  20. CARLA_BACKEND_START_NAMESPACE
  21. class LadspaPlugin : public CarlaPlugin
  22. {
  23. public:
  24. LadspaPlugin(CarlaEngine* const engine, const unsigned int id)
  25. : CarlaPlugin(engine, id),
  26. fHandle(nullptr),
  27. fHandle2(nullptr),
  28. fDescriptor(nullptr),
  29. fRdfDescriptor(nullptr),
  30. fAudioInBuffers(nullptr),
  31. fAudioOutBuffers(nullptr),
  32. fParamBuffers(nullptr)
  33. {
  34. carla_debug("LadspaPlugin::LadspaPlugin(%p, %i)", engine, id);
  35. }
  36. ~LadspaPlugin()
  37. {
  38. carla_debug("LadspaPlugin::~LadspaPlugin()");
  39. if (fDescriptor != nullptr)
  40. {
  41. if (fDescriptor->deactivate != nullptr && kData->activeBefore)
  42. {
  43. if (fHandle != nullptr)
  44. fDescriptor->deactivate(fHandle);
  45. if (fHandle2 != nullptr)
  46. fDescriptor->deactivate(fHandle2);
  47. }
  48. if (fDescriptor->cleanup != nullptr)
  49. {
  50. if (fHandle != nullptr)
  51. fDescriptor->cleanup(fHandle);
  52. if (fHandle2 != nullptr)
  53. fDescriptor->cleanup(fHandle2);
  54. }
  55. fHandle = nullptr;
  56. fHandle2 = nullptr;
  57. fDescriptor = nullptr;
  58. }
  59. if (fRdfDescriptor != nullptr)
  60. {
  61. delete fRdfDescriptor;
  62. fRdfDescriptor = nullptr;
  63. }
  64. deleteBuffers();
  65. }
  66. // -------------------------------------------------------------------
  67. // Information (base)
  68. PluginType type() const
  69. {
  70. return PLUGIN_LADSPA;
  71. }
  72. PluginCategory category() const
  73. {
  74. if (fRdfDescriptor != nullptr)
  75. {
  76. const LADSPA_PluginType category = fRdfDescriptor->Type;
  77. // Specific Types
  78. if (category & (LADSPA_PLUGIN_DELAY|LADSPA_PLUGIN_REVERB))
  79. return PLUGIN_CATEGORY_DELAY;
  80. if (category & (LADSPA_PLUGIN_PHASER|LADSPA_PLUGIN_FLANGER|LADSPA_PLUGIN_CHORUS))
  81. return PLUGIN_CATEGORY_MODULATOR;
  82. if (category & (LADSPA_PLUGIN_AMPLIFIER))
  83. return PLUGIN_CATEGORY_DYNAMICS;
  84. if (category & (LADSPA_PLUGIN_UTILITY|LADSPA_PLUGIN_SPECTRAL|LADSPA_PLUGIN_FREQUENCY_METER))
  85. return PLUGIN_CATEGORY_UTILITY;
  86. // Pre-set LADSPA Types
  87. if (LADSPA_IS_PLUGIN_DYNAMICS(category))
  88. return PLUGIN_CATEGORY_DYNAMICS;
  89. if (LADSPA_IS_PLUGIN_AMPLITUDE(category))
  90. return PLUGIN_CATEGORY_MODULATOR;
  91. if (LADSPA_IS_PLUGIN_EQ(category))
  92. return PLUGIN_CATEGORY_EQ;
  93. if (LADSPA_IS_PLUGIN_FILTER(category))
  94. return PLUGIN_CATEGORY_FILTER;
  95. if (LADSPA_IS_PLUGIN_FREQUENCY(category))
  96. return PLUGIN_CATEGORY_UTILITY;
  97. if (LADSPA_IS_PLUGIN_SIMULATOR(category))
  98. return PLUGIN_CATEGORY_OTHER;
  99. if (LADSPA_IS_PLUGIN_TIME(category))
  100. return PLUGIN_CATEGORY_DELAY;
  101. if (LADSPA_IS_PLUGIN_GENERATOR(category))
  102. return PLUGIN_CATEGORY_SYNTH;
  103. }
  104. return getPluginCategoryFromName(fName);
  105. }
  106. long uniqueId() const
  107. {
  108. CARLA_ASSERT(fDescriptor != nullptr);
  109. return (fDescriptor != nullptr) ? static_cast<long>(fDescriptor->UniqueID) : 0;
  110. }
  111. // -------------------------------------------------------------------
  112. // Information (count)
  113. uint32_t parameterScalePointCount(const uint32_t parameterId) const
  114. {
  115. CARLA_ASSERT(parameterId < kData->param.count);
  116. const int32_t rindex = kData->param.data[parameterId].rindex;
  117. if (fRdfDescriptor != nullptr && rindex < static_cast<int32_t>(fRdfDescriptor->PortCount))
  118. {
  119. const LADSPA_RDF_Port& port = fRdfDescriptor->Ports[rindex];
  120. return static_cast<uint32_t>(port.ScalePointCount);
  121. }
  122. return 0;
  123. }
  124. // -------------------------------------------------------------------
  125. // Information (per-plugin data)
  126. float getParameterValue(const uint32_t parameterId)
  127. {
  128. CARLA_ASSERT(parameterId < kData->param.count);
  129. return fParamBuffers[parameterId];
  130. }
  131. float getParameterScalePointValue(const uint32_t parameterId, const uint32_t scalePointId)
  132. {
  133. CARLA_ASSERT(fRdfDescriptor != nullptr);
  134. CARLA_ASSERT(parameterId < kData->param.count);
  135. CARLA_ASSERT(scalePointId < parameterScalePointCount(parameterId));
  136. const int32_t rindex = kData->param.data[parameterId].rindex;
  137. if (fRdfDescriptor != nullptr && rindex < static_cast<int32_t>(fRdfDescriptor->PortCount))
  138. {
  139. const LADSPA_RDF_Port& port = fRdfDescriptor->Ports[rindex];
  140. if (scalePointId < port.ScalePointCount)
  141. {
  142. const LADSPA_RDF_ScalePoint& scalePoint = port.ScalePoints[scalePointId];
  143. return scalePoint.Value;
  144. }
  145. }
  146. return 0.0f;
  147. }
  148. void getLabel(char* const strBuf)
  149. {
  150. CARLA_ASSERT(fDescriptor != nullptr);
  151. if (fDescriptor != nullptr && fDescriptor->Label != nullptr)
  152. std::strncpy(strBuf, fDescriptor->Label, STR_MAX);
  153. else
  154. CarlaPlugin::getLabel(strBuf);
  155. }
  156. void getMaker(char* const strBuf)
  157. {
  158. CARLA_ASSERT(fDescriptor != nullptr);
  159. if (fRdfDescriptor != nullptr && fRdfDescriptor->Creator != nullptr)
  160. std::strncpy(strBuf, fRdfDescriptor->Creator, STR_MAX);
  161. else if (fDescriptor != nullptr && fDescriptor->Maker != nullptr)
  162. std::strncpy(strBuf, fDescriptor->Maker, STR_MAX);
  163. else
  164. CarlaPlugin::getMaker(strBuf);
  165. }
  166. void getCopyright(char* const strBuf)
  167. {
  168. CARLA_ASSERT(fDescriptor != nullptr);
  169. if (fDescriptor != nullptr && fDescriptor->Copyright != nullptr)
  170. std::strncpy(strBuf, fDescriptor->Copyright, STR_MAX);
  171. else
  172. CarlaPlugin::getCopyright(strBuf);
  173. }
  174. void getRealName(char* const strBuf)
  175. {
  176. CARLA_ASSERT(fDescriptor != nullptr);
  177. if (fRdfDescriptor != nullptr && fRdfDescriptor->Title != nullptr)
  178. std::strncpy(strBuf, fRdfDescriptor->Title, STR_MAX);
  179. else if (fDescriptor != nullptr && fDescriptor->Name != nullptr)
  180. std::strncpy(strBuf, fDescriptor->Name, STR_MAX);
  181. else
  182. CarlaPlugin::getRealName(strBuf);
  183. }
  184. void getParameterName(const uint32_t parameterId, char* const strBuf)
  185. {
  186. CARLA_ASSERT(fDescriptor != nullptr);
  187. CARLA_ASSERT(parameterId < kData->param.count);
  188. const int32_t rindex = kData->param.data[parameterId].rindex;
  189. if (fDescriptor != nullptr && rindex < static_cast<int32_t>(fDescriptor->PortCount))
  190. std::strncpy(strBuf, fDescriptor->PortNames[rindex], STR_MAX);
  191. else
  192. CarlaPlugin::getParameterName(parameterId, strBuf);
  193. }
  194. void getParameterSymbol(const uint32_t parameterId, char* const strBuf)
  195. {
  196. CARLA_ASSERT(parameterId < kData->param.count);
  197. const int32_t rindex = kData->param.data[parameterId].rindex;
  198. if (fRdfDescriptor != nullptr && rindex < static_cast<int32_t>(fRdfDescriptor->PortCount))
  199. {
  200. const LADSPA_RDF_Port& port = fRdfDescriptor->Ports[rindex];
  201. if (LADSPA_PORT_HAS_LABEL(port.Hints) && port.Label != nullptr)
  202. {
  203. std::strncpy(strBuf, port.Label, STR_MAX);
  204. return;
  205. }
  206. }
  207. CarlaPlugin::getParameterSymbol(parameterId, strBuf);
  208. }
  209. void getParameterUnit(const uint32_t parameterId, char* const strBuf)
  210. {
  211. CARLA_ASSERT(parameterId < kData->param.count);
  212. const int32_t rindex = kData->param.data[parameterId].rindex;
  213. if (fRdfDescriptor != nullptr && rindex < static_cast<int32_t>(fRdfDescriptor->PortCount))
  214. {
  215. const LADSPA_RDF_Port& port = fRdfDescriptor->Ports[rindex];
  216. if (LADSPA_PORT_HAS_UNIT(port.Hints))
  217. {
  218. switch (port.Unit)
  219. {
  220. case LADSPA_UNIT_DB:
  221. std::strncpy(strBuf, "dB", STR_MAX);
  222. return;
  223. case LADSPA_UNIT_COEF:
  224. std::strncpy(strBuf, "(coef)", STR_MAX);
  225. return;
  226. case LADSPA_UNIT_HZ:
  227. std::strncpy(strBuf, "Hz", STR_MAX);
  228. return;
  229. case LADSPA_UNIT_S:
  230. std::strncpy(strBuf, "s", STR_MAX);
  231. return;
  232. case LADSPA_UNIT_MS:
  233. std::strncpy(strBuf, "ms", STR_MAX);
  234. return;
  235. case LADSPA_UNIT_MIN:
  236. std::strncpy(strBuf, "min", STR_MAX);
  237. return;
  238. }
  239. }
  240. }
  241. CarlaPlugin::getParameterUnit(parameterId, strBuf);
  242. }
  243. void getParameterScalePointLabel(const uint32_t parameterId, const uint32_t scalePointId, char* const strBuf)
  244. {
  245. CARLA_ASSERT(fRdfDescriptor != nullptr);
  246. CARLA_ASSERT(parameterId < kData->param.count);
  247. CARLA_ASSERT(scalePointId < parameterScalePointCount(parameterId));
  248. const int32_t rindex = kData->param.data[parameterId].rindex;
  249. if (fRdfDescriptor != nullptr && rindex < static_cast<int32_t>(fRdfDescriptor->PortCount))
  250. {
  251. const LADSPA_RDF_Port& port = fRdfDescriptor->Ports[rindex];
  252. if (scalePointId < port.ScalePointCount)
  253. {
  254. const LADSPA_RDF_ScalePoint& scalePoint = port.ScalePoints[scalePointId];
  255. if (scalePoint.Label != nullptr)
  256. {
  257. std::strncpy(strBuf, scalePoint.Label, STR_MAX);
  258. return;
  259. }
  260. }
  261. }
  262. CarlaPlugin::getParameterScalePointLabel(parameterId, scalePointId, strBuf);
  263. }
  264. // -------------------------------------------------------------------
  265. // Set data (plugin-specific stuff)
  266. void setParameterValue(const uint32_t parameterId, const float value, const bool sendGui, const bool sendOsc, const bool sendCallback)
  267. {
  268. CARLA_ASSERT(parameterId < kData->param.count);
  269. const float fixedValue = kData->param.fixValue(parameterId, value);
  270. fParamBuffers[parameterId] = fixedValue;
  271. CarlaPlugin::setParameterValue(parameterId, fixedValue, sendGui, sendOsc, sendCallback);
  272. }
  273. // -------------------------------------------------------------------
  274. // Plugin state
  275. void reload()
  276. {
  277. carla_debug("LadspaPlugin::reload() - start");
  278. CARLA_ASSERT(kData->engine != nullptr);
  279. CARLA_ASSERT(fDescriptor != nullptr);
  280. CARLA_ASSERT(fHandle != nullptr);
  281. const ProcessMode processMode(kData->engine->getProccessMode());
  282. // Safely disable plugin for reload
  283. const ScopedDisabler sd(this);
  284. deleteBuffers();
  285. const float sampleRate = (float)kData->engine->getSampleRate();
  286. const uint32_t portCount = static_cast<uint32_t>(fDescriptor->PortCount);
  287. uint32_t aIns, aOuts, params, j;
  288. aIns = aOuts = params = 0;
  289. bool forcedStereoIn, forcedStereoOut;
  290. forcedStereoIn = forcedStereoOut = false;
  291. bool needsCtrlIn, needsCtrlOut;
  292. needsCtrlIn = needsCtrlOut = false;
  293. if (portCount > 0)
  294. {
  295. CARLA_ASSERT(fDescriptor->PortDescriptors != nullptr);
  296. CARLA_ASSERT(fDescriptor->PortRangeHints != nullptr);
  297. CARLA_ASSERT(fDescriptor->PortNames != nullptr);
  298. for (uint32_t i=0; i < portCount; i++)
  299. {
  300. const LADSPA_PortDescriptor portType = fDescriptor->PortDescriptors[i];
  301. if (LADSPA_IS_PORT_AUDIO(portType))
  302. {
  303. if (LADSPA_IS_PORT_INPUT(portType))
  304. aIns += 1;
  305. else if (LADSPA_IS_PORT_OUTPUT(portType))
  306. aOuts += 1;
  307. }
  308. else if (LADSPA_IS_PORT_CONTROL(portType))
  309. params += 1;
  310. }
  311. }
  312. if ((fOptions & PLUGIN_OPTION_FORCE_STEREO) != 0 && (aIns == 1 || aOuts == 1))
  313. {
  314. if (fHandle2 == nullptr)
  315. fHandle2 = fDescriptor->instantiate(fDescriptor, (unsigned long)sampleRate);
  316. if (aIns == 1)
  317. {
  318. aIns = 2;
  319. forcedStereoIn = true;
  320. }
  321. if (aOuts == 1)
  322. {
  323. aOuts = 2;
  324. forcedStereoOut = true;
  325. }
  326. }
  327. if (aIns > 0)
  328. {
  329. kData->audioIn.createNew(aIns);
  330. fAudioInBuffers = new float*[aIns];
  331. for (uint32_t i=0; i < aIns; i++)
  332. fAudioInBuffers[i] = nullptr;
  333. }
  334. if (aOuts > 0)
  335. {
  336. kData->audioOut.createNew(aOuts);
  337. fAudioOutBuffers = new float*[aOuts];
  338. needsCtrlIn = true;
  339. for (uint32_t i=0; i < aOuts; i++)
  340. fAudioOutBuffers[i] = nullptr;
  341. }
  342. if (params > 0)
  343. {
  344. kData->param.createNew(params);
  345. fParamBuffers = new float[params];
  346. for (uint32_t i=0; i < params; i++)
  347. fParamBuffers[i] = 0.0f;
  348. }
  349. const uint portNameSize = kData->engine->maxPortNameSize();
  350. CarlaString portName;
  351. for (uint32_t i=0, iAudioIn=0, iAudioOut=0, iCtrl=0; i < portCount; i++)
  352. {
  353. const LADSPA_PortDescriptor portType = fDescriptor->PortDescriptors[i];
  354. const LADSPA_PortRangeHint portRangeHints = fDescriptor->PortRangeHints[i];
  355. const bool hasPortRDF = (fRdfDescriptor != nullptr && i < fRdfDescriptor->PortCount);
  356. CARLA_ASSERT(fDescriptor->PortNames[i] != nullptr);
  357. if (LADSPA_IS_PORT_AUDIO(portType))
  358. {
  359. portName.clear();
  360. if (processMode == PROCESS_MODE_SINGLE_CLIENT)
  361. {
  362. portName = fName;
  363. portName += ":";
  364. }
  365. portName += fDescriptor->PortNames[i];
  366. portName.truncate(portNameSize);
  367. if (LADSPA_IS_PORT_INPUT(portType))
  368. {
  369. j = iAudioIn++;
  370. kData->audioIn.ports[j].port = (CarlaEngineAudioPort*)kData->client->addPort(kEnginePortTypeAudio, portName, true);
  371. kData->audioIn.ports[j].rindex = i;
  372. if (forcedStereoIn)
  373. {
  374. portName += "_2";
  375. kData->audioIn.ports[1].port = (CarlaEngineAudioPort*)kData->client->addPort(kEnginePortTypeAudio, portName, true);
  376. kData->audioIn.ports[1].rindex = i;
  377. }
  378. }
  379. else if (LADSPA_IS_PORT_OUTPUT(portType))
  380. {
  381. j = iAudioOut++;
  382. kData->audioOut.ports[j].port = (CarlaEngineAudioPort*)kData->client->addPort(kEnginePortTypeAudio, portName, false);
  383. kData->audioOut.ports[j].rindex = i;
  384. if (forcedStereoOut)
  385. {
  386. portName += "_2";
  387. kData->audioOut.ports[1].port = (CarlaEngineAudioPort*)kData->client->addPort(kEnginePortTypeAudio, portName, false);
  388. kData->audioOut.ports[1].rindex = i;
  389. }
  390. }
  391. else
  392. carla_stderr2("WARNING - Got a broken Port (Audio, but not input or output)");
  393. }
  394. else if (LADSPA_IS_PORT_CONTROL(portType))
  395. {
  396. j = iCtrl++;
  397. kData->param.data[j].index = j;
  398. kData->param.data[j].rindex = i;
  399. kData->param.data[j].hints = 0x0;
  400. kData->param.data[j].midiChannel = 0;
  401. kData->param.data[j].midiCC = -1;
  402. float min, max, def, step, stepSmall, stepLarge;
  403. // min value
  404. if (LADSPA_IS_HINT_BOUNDED_BELOW(portRangeHints.HintDescriptor))
  405. min = portRangeHints.LowerBound;
  406. else
  407. min = 0.0f;
  408. // max value
  409. if (LADSPA_IS_HINT_BOUNDED_ABOVE(portRangeHints.HintDescriptor))
  410. max = portRangeHints.UpperBound;
  411. else
  412. max = 1.0f;
  413. if (min > max)
  414. max = min;
  415. else if (max < min)
  416. min = max;
  417. if (max - min == 0.0f)
  418. {
  419. carla_stderr2("WARNING - Broken plugin parameter '%s': max - min == 0.0f", fDescriptor->PortNames[i]);
  420. max = min + 0.1f;
  421. }
  422. // default value
  423. if (hasPortRDF && LADSPA_PORT_HAS_DEFAULT(fRdfDescriptor->Ports[i].Hints))
  424. def = fRdfDescriptor->Ports[i].Default;
  425. else
  426. def = get_default_ladspa_port_value(portRangeHints.HintDescriptor, min, max);
  427. if (def < min)
  428. def = min;
  429. else if (def > max)
  430. def = max;
  431. if (LADSPA_IS_HINT_SAMPLE_RATE(portRangeHints.HintDescriptor))
  432. {
  433. min *= sampleRate;
  434. max *= sampleRate;
  435. def *= sampleRate;
  436. kData->param.data[j].hints |= PARAMETER_USES_SAMPLERATE;
  437. }
  438. if (LADSPA_IS_HINT_TOGGLED(portRangeHints.HintDescriptor))
  439. {
  440. step = max - min;
  441. stepSmall = step;
  442. stepLarge = step;
  443. kData->param.data[j].hints |= PARAMETER_IS_BOOLEAN;
  444. }
  445. else if (LADSPA_IS_HINT_INTEGER(portRangeHints.HintDescriptor))
  446. {
  447. step = 1.0f;
  448. stepSmall = 1.0f;
  449. stepLarge = 10.0f;
  450. kData->param.data[j].hints |= PARAMETER_IS_INTEGER;
  451. }
  452. else
  453. {
  454. float range = max - min;
  455. step = range/100.0f;
  456. stepSmall = range/1000.0f;
  457. stepLarge = range/10.0f;
  458. }
  459. if (LADSPA_IS_PORT_INPUT(portType))
  460. {
  461. kData->param.data[j].type = PARAMETER_INPUT;
  462. kData->param.data[j].hints |= PARAMETER_IS_ENABLED;
  463. kData->param.data[j].hints |= PARAMETER_IS_AUTOMABLE;
  464. needsCtrlIn = true;
  465. }
  466. else if (LADSPA_IS_PORT_OUTPUT(portType))
  467. {
  468. if (std::strcmp(fDescriptor->PortNames[i], "latency") == 0 || std::strcmp(fDescriptor->PortNames[i], "_latency") == 0)
  469. {
  470. min = 0.0f;
  471. max = sampleRate;
  472. def = 0.0f;
  473. step = 1.0f;
  474. stepSmall = 1.0f;
  475. stepLarge = 1.0f;
  476. kData->param.data[j].type = PARAMETER_LATENCY;
  477. kData->param.data[j].hints = 0;
  478. }
  479. else if (std::strcmp(fDescriptor->PortNames[i], "_sample-rate") == 0)
  480. {
  481. def = sampleRate;
  482. step = 1.0f;
  483. stepSmall = 1.0f;
  484. stepLarge = 1.0f;
  485. kData->param.data[j].type = PARAMETER_SAMPLE_RATE;
  486. kData->param.data[j].hints = 0;
  487. }
  488. else
  489. {
  490. kData->param.data[j].type = PARAMETER_OUTPUT;
  491. kData->param.data[j].hints |= PARAMETER_IS_ENABLED;
  492. kData->param.data[j].hints |= PARAMETER_IS_AUTOMABLE;
  493. needsCtrlOut = true;
  494. }
  495. }
  496. else
  497. {
  498. kData->param.data[j].type = PARAMETER_UNKNOWN;
  499. carla_stderr2("WARNING - Got a broken Port (Control, but not input or output)");
  500. }
  501. // extra parameter hints
  502. if (LADSPA_IS_HINT_LOGARITHMIC(portRangeHints.HintDescriptor))
  503. kData->param.data[j].hints |= PARAMETER_IS_LOGARITHMIC;
  504. // check for scalepoints, require at least 2 to make it useful
  505. if (hasPortRDF && fRdfDescriptor->Ports[i].ScalePointCount > 1)
  506. kData->param.data[j].hints |= PARAMETER_USES_SCALEPOINTS;
  507. kData->param.ranges[j].min = min;
  508. kData->param.ranges[j].max = max;
  509. kData->param.ranges[j].def = def;
  510. kData->param.ranges[j].step = step;
  511. kData->param.ranges[j].stepSmall = stepSmall;
  512. kData->param.ranges[j].stepLarge = stepLarge;
  513. // Start parameters in their default values
  514. fParamBuffers[j] = def;
  515. fDescriptor->connect_port(fHandle, i, &fParamBuffers[j]);
  516. if (fHandle2 != nullptr)
  517. fDescriptor->connect_port(fHandle2, i, &fParamBuffers[j]);
  518. }
  519. else
  520. {
  521. // Not Audio or Control
  522. carla_stderr2("ERROR - Got a broken Port (neither Audio or Control)");
  523. fDescriptor->connect_port(fHandle, i, nullptr);
  524. if (fHandle2 != nullptr)
  525. fDescriptor->connect_port(fHandle2, i, nullptr);
  526. }
  527. }
  528. if (needsCtrlIn)
  529. {
  530. portName.clear();
  531. if (processMode == PROCESS_MODE_SINGLE_CLIENT)
  532. {
  533. portName = fName;
  534. portName += ":";
  535. }
  536. portName += "event-in";
  537. portName.truncate(portNameSize);
  538. kData->event.portIn = (CarlaEngineEventPort*)kData->client->addPort(kEnginePortTypeEvent, portName, true);
  539. }
  540. if (needsCtrlOut)
  541. {
  542. portName.clear();
  543. if (processMode == PROCESS_MODE_SINGLE_CLIENT)
  544. {
  545. portName = fName;
  546. portName += ":";
  547. }
  548. portName += "event-out";
  549. portName.truncate(portNameSize);
  550. kData->event.portOut = (CarlaEngineEventPort*)kData->client->addPort(kEnginePortTypeEvent, portName, false);
  551. }
  552. // plugin checks
  553. fHints &= ~(PLUGIN_IS_SYNTH | PLUGIN_USES_CHUNKS | PLUGIN_CAN_DRYWET | PLUGIN_CAN_VOLUME | PLUGIN_CAN_BALANCE | PLUGIN_CAN_FORCE_STEREO);
  554. if (aOuts > 0 && (aIns == aOuts || aIns == 1))
  555. fHints |= PLUGIN_CAN_DRYWET;
  556. if (aOuts > 0)
  557. fHints |= PLUGIN_CAN_VOLUME;
  558. if (aOuts >= 2 && aOuts % 2 == 0)
  559. fHints |= PLUGIN_CAN_BALANCE;
  560. if (aIns <= 2 && aOuts <= 2 && (aIns == aOuts || aIns == 0 || aOuts == 0))
  561. fHints |= PLUGIN_CAN_FORCE_STEREO;
  562. // plugin options
  563. kData->availOptions &= ~(PLUGIN_OPTION_FIXED_BUFFER | PLUGIN_OPTION_SELF_AUTOMATION | PLUGIN_OPTION_SEND_ALL_SOUND_OFF | PLUGIN_OPTION_SEND_NOTE_AFTERTOUCH | PLUGIN_OPTION_SEND_PITCHBEND);
  564. // always available if needed
  565. kData->availOptions |= PLUGIN_OPTION_FIXED_BUFFER;
  566. // check latency
  567. if (fHints & PLUGIN_CAN_DRYWET)
  568. {
  569. for (uint32_t i=0; i < kData->param.count; i++)
  570. {
  571. if (kData->param.data[i].type != PARAMETER_LATENCY)
  572. continue;
  573. // we need to pre-run the plugin so it can update its latency control-port
  574. float tmpIn[aIns][2];
  575. float tmpOut[aOuts][2];
  576. for (j=0; j < aIns; j++)
  577. {
  578. tmpIn[j][0] = 0.0f;
  579. tmpIn[j][1] = 0.0f;
  580. fDescriptor->connect_port(fHandle, kData->audioIn.ports[j].rindex, tmpIn[j]);
  581. }
  582. for (j=0; j < aOuts; j++)
  583. {
  584. tmpOut[j][0] = 0.0f;
  585. tmpOut[j][1] = 0.0f;
  586. fDescriptor->connect_port(fHandle, kData->audioOut.ports[j].rindex, tmpOut[j]);
  587. }
  588. if (fDescriptor->activate != nullptr)
  589. fDescriptor->activate(fHandle);
  590. fDescriptor->run(fHandle, 2);
  591. if (fDescriptor->deactivate != nullptr)
  592. fDescriptor->deactivate(fHandle);
  593. const uint32_t latency = (uint32_t)fParamBuffers[i];
  594. if (kData->latency != latency)
  595. {
  596. kData->latency = latency;
  597. kData->client->setLatency(latency);
  598. recreateLatencyBuffers();
  599. }
  600. break;
  601. }
  602. }
  603. bufferSizeChanged(kData->engine->getBufferSize());
  604. carla_debug("LadspaPlugin::reload() - end");
  605. }
  606. // -------------------------------------------------------------------
  607. // Plugin processing
  608. void process(float** const inBuffer, float** const outBuffer, const uint32_t frames)
  609. {
  610. uint32_t i, k;
  611. // --------------------------------------------------------------------------------------------------------
  612. // Check if active
  613. if (! kData->active)
  614. {
  615. // disable any output sound
  616. for (i=0; i < kData->audioOut.count; i++)
  617. carla_zeroFloat(outBuffer[i], frames);
  618. if (kData->activeBefore)
  619. {
  620. if (fDescriptor->deactivate != nullptr)
  621. {
  622. fDescriptor->deactivate(fHandle);
  623. if (fHandle2 != nullptr)
  624. fDescriptor->deactivate(fHandle2);
  625. }
  626. }
  627. kData->activeBefore = kData->active;
  628. return;
  629. }
  630. // --------------------------------------------------------------------------------------------------------
  631. // Check if not active before
  632. if (kData->needsReset || ! kData->activeBefore)
  633. {
  634. if (kData->latency > 0)
  635. {
  636. for (i=0; i < kData->audioIn.count; i++)
  637. carla_zeroFloat(kData->latencyBuffers[i], kData->latency);
  638. }
  639. if (kData->activeBefore)
  640. {
  641. if (fDescriptor->deactivate != nullptr)
  642. {
  643. fDescriptor->deactivate(fHandle);
  644. if (fHandle2 != nullptr)
  645. fDescriptor->deactivate(fHandle2);
  646. }
  647. }
  648. if (fDescriptor->activate != nullptr)
  649. {
  650. fDescriptor->activate(fHandle);
  651. if (fHandle2 != nullptr)
  652. fDescriptor->activate(fHandle2);
  653. }
  654. kData->needsReset = false;
  655. }
  656. // --------------------------------------------------------------------------------------------------------
  657. // Event Input and Processing
  658. if (kData->event.portIn != nullptr && kData->activeBefore)
  659. {
  660. // ----------------------------------------------------------------------------------------------------
  661. // Event Input (System)
  662. bool sampleAccurate = (fOptions & PLUGIN_OPTION_FIXED_BUFFER) == 0;
  663. uint32_t time, nEvents = kData->event.portIn->getEventCount();
  664. uint32_t timeOffset = 0;
  665. for (i=0; i < nEvents; i++)
  666. {
  667. const EngineEvent& event = kData->event.portIn->getEvent(i);
  668. time = event.time;
  669. if (time >= frames)
  670. continue;
  671. CARLA_ASSERT_INT2(time >= timeOffset, time, timeOffset);
  672. if (time > timeOffset && sampleAccurate)
  673. {
  674. if (processSingle(inBuffer, outBuffer, time - timeOffset, timeOffset))
  675. timeOffset = time;
  676. }
  677. // Control change
  678. switch (event.type)
  679. {
  680. case kEngineEventTypeNull:
  681. break;
  682. case kEngineEventTypeControl:
  683. {
  684. const EngineControlEvent& ctrlEvent = event.ctrl;
  685. switch (ctrlEvent.type)
  686. {
  687. case kEngineControlEventTypeNull:
  688. break;
  689. case kEngineControlEventTypeParameter:
  690. {
  691. // Control backend stuff
  692. if (event.channel == kData->ctrlChannel)
  693. {
  694. float value;
  695. if (MIDI_IS_CONTROL_BREATH_CONTROLLER(ctrlEvent.param) && (fHints & PLUGIN_CAN_DRYWET) > 0)
  696. {
  697. value = ctrlEvent.value;
  698. setDryWet(value, false, false);
  699. postponeRtEvent(kPluginPostRtEventParameterChange, PARAMETER_DRYWET, 0, value);
  700. continue;
  701. }
  702. if (MIDI_IS_CONTROL_CHANNEL_VOLUME(ctrlEvent.param) && (fHints & PLUGIN_CAN_VOLUME) > 0)
  703. {
  704. value = ctrlEvent.value*127.0f/100.0f;
  705. setVolume(value, false, false);
  706. postponeRtEvent(kPluginPostRtEventParameterChange, PARAMETER_VOLUME, 0, value);
  707. continue;
  708. }
  709. if (MIDI_IS_CONTROL_BALANCE(ctrlEvent.param) && (fHints & PLUGIN_CAN_BALANCE) > 0)
  710. {
  711. float left, right;
  712. value = ctrlEvent.value/0.5f - 1.0f;
  713. if (value < 0.0f)
  714. {
  715. left = -1.0f;
  716. right = (value*2.0f)+1.0f;
  717. }
  718. else if (value > 0.0f)
  719. {
  720. left = (value*2.0f)-1.0f;
  721. right = 1.0f;
  722. }
  723. else
  724. {
  725. left = -1.0f;
  726. right = 1.0f;
  727. }
  728. setBalanceLeft(left, false, false);
  729. setBalanceRight(right, false, false);
  730. postponeRtEvent(kPluginPostRtEventParameterChange, PARAMETER_BALANCE_LEFT, 0, left);
  731. postponeRtEvent(kPluginPostRtEventParameterChange, PARAMETER_BALANCE_RIGHT, 0, right);
  732. continue;
  733. }
  734. }
  735. // Control plugin parameters
  736. for (k=0; k < kData->param.count; k++)
  737. {
  738. if (kData->param.data[k].midiChannel != event.channel)
  739. continue;
  740. if (kData->param.data[k].midiCC != ctrlEvent.param)
  741. continue;
  742. if (kData->param.data[k].type != PARAMETER_INPUT)
  743. continue;
  744. if ((kData->param.data[k].hints & PARAMETER_IS_AUTOMABLE) == 0)
  745. continue;
  746. float value;
  747. if (kData->param.data[k].hints & PARAMETER_IS_BOOLEAN)
  748. {
  749. value = (ctrlEvent.value < 0.5f) ? kData->param.ranges[k].min : kData->param.ranges[k].max;
  750. }
  751. else
  752. {
  753. value = kData->param.ranges[i].unnormalizeValue(ctrlEvent.value);
  754. if (kData->param.data[k].hints & PARAMETER_IS_INTEGER)
  755. value = std::rint(value);
  756. }
  757. setParameterValue(k, value, false, false, false);
  758. postponeRtEvent(kPluginPostRtEventParameterChange, static_cast<int32_t>(k), 0, value);
  759. }
  760. break;
  761. }
  762. case kEngineControlEventTypeMidiBank:
  763. case kEngineControlEventTypeMidiProgram:
  764. break;
  765. case kEngineControlEventTypeAllSoundOff:
  766. if (event.channel == kData->ctrlChannel)
  767. {
  768. if (fDescriptor->deactivate != nullptr)
  769. {
  770. fDescriptor->deactivate(fHandle);
  771. if (fHandle2 != nullptr)
  772. fDescriptor->deactivate(fHandle2);
  773. }
  774. if (fDescriptor->activate != nullptr)
  775. {
  776. fDescriptor->activate(fHandle);
  777. if (fHandle2 != nullptr)
  778. fDescriptor->activate(fHandle2);
  779. }
  780. postponeRtEvent(kPluginPostRtEventParameterChange, PARAMETER_ACTIVE, 0, 0.0);
  781. postponeRtEvent(kPluginPostRtEventParameterChange, PARAMETER_ACTIVE, 0, 1.0);
  782. }
  783. break;
  784. case kEngineControlEventTypeAllNotesOff:
  785. break;
  786. }
  787. break;
  788. }
  789. case kEngineEventTypeMidi:
  790. // ignored in LADSPA
  791. break;
  792. }
  793. }
  794. kData->postRtEvents.trySplice();
  795. if (frames > timeOffset)
  796. processSingle(inBuffer, outBuffer, frames - timeOffset, timeOffset);
  797. } // End of Event Input and Processing
  798. // --------------------------------------------------------------------------------------------------------
  799. // Plugin processing (no events)
  800. else
  801. {
  802. processSingle(inBuffer, outBuffer, frames, 0);
  803. } // End of Plugin processing (no events)
  804. // --------------------------------------------------------------------------------------------------------
  805. // Special Parameters
  806. #if 0
  807. CARLA_PROCESS_CONTINUE_CHECK;
  808. for (k=0; k < param.count; k++)
  809. {
  810. if (param.data[k].type == PARAMETER_LATENCY)
  811. {
  812. // TODO
  813. }
  814. }
  815. CARLA_PROCESS_CONTINUE_CHECK;
  816. #endif
  817. CARLA_PROCESS_CONTINUE_CHECK;
  818. // --------------------------------------------------------------------------------------------------------
  819. // Control Output
  820. if (kData->event.portOut != nullptr)
  821. {
  822. uint8_t channel;
  823. uint16_t param;
  824. float value;
  825. for (k=0; k < kData->param.count; k++)
  826. {
  827. if (kData->param.data[k].type != PARAMETER_OUTPUT)
  828. continue;
  829. kData->param.ranges[k].fixValue(fParamBuffers[k]);
  830. if (kData->param.data[k].midiCC > 0)
  831. {
  832. channel = kData->param.data[k].midiChannel;
  833. param = static_cast<uint16_t>(kData->param.data[k].midiCC);
  834. value = kData->param.ranges[k].normalizeValue(fParamBuffers[k]);
  835. kData->event.portOut->writeControlEvent(0, channel, kEngineControlEventTypeParameter, param, value);
  836. }
  837. }
  838. } // End of Control Output
  839. // --------------------------------------------------------------------------------------------------------
  840. kData->activeBefore = kData->active;
  841. }
  842. bool processSingle(float** const inBuffer, float** const outBuffer, const uint32_t frames, const uint32_t timeOffset)
  843. {
  844. uint32_t i, k;
  845. // --------------------------------------------------------------------------------------------------------
  846. // Try lock, silence otherwise
  847. if (kData->engine->isOffline())
  848. {
  849. kData->mutex.lock();
  850. }
  851. else if (! kData->mutex.tryLock())
  852. {
  853. for (i=0; i < kData->audioOut.count; i++)
  854. {
  855. for (k=0; k < frames; k++)
  856. outBuffer[i][k+timeOffset] = 0.0f;
  857. }
  858. return false;
  859. }
  860. // --------------------------------------------------------------------------------------------------------
  861. // Fill plugin buffers
  862. for (i=0; i < kData->audioIn.count; i++)
  863. carla_copyFloat(fAudioInBuffers[i], inBuffer[i]+timeOffset, frames);
  864. for (i=0; i < kData->audioOut.count; i++)
  865. carla_zeroFloat(fAudioOutBuffers[i], frames);
  866. // --------------------------------------------------------------------------------------------------------
  867. // Run plugin
  868. fDescriptor->run(fHandle, frames);
  869. if (fHandle2 != nullptr)
  870. fDescriptor->run(fHandle2, frames);
  871. // --------------------------------------------------------------------------------------------------------
  872. // Post-processing (dry/wet, volume and balance)
  873. {
  874. const bool doDryWet = (fHints & PLUGIN_CAN_DRYWET) > 0 && kData->postProc.dryWet != 1.0f;
  875. const bool doBalance = (fHints & PLUGIN_CAN_BALANCE) > 0 && (kData->postProc.balanceLeft != -1.0f || kData->postProc.balanceRight != 1.0f);
  876. float bufValue, oldBufLeft[doBalance ? frames : 1];
  877. for (i=0; i < kData->audioOut.count; i++)
  878. {
  879. // Dry/Wet
  880. if (doDryWet)
  881. {
  882. for (k=0; k < frames; k++)
  883. {
  884. // TODO
  885. //if (k < kData->latency && kData->latency < frames)
  886. // bufValue = (kData->audioIn.count == 1) ? kData->latencyBuffers[0][k] : kData->latencyBuffers[i][k];
  887. //else
  888. // bufValue = (kData->audioIn.count == 1) ? inBuffer[0][k-m_latency] : inBuffer[i][k-m_latency];
  889. bufValue = fAudioInBuffers[(kData->audioIn.count == 1) ? 0 : i][k];
  890. fAudioOutBuffers[i][k] = (fAudioOutBuffers[i][k] * kData->postProc.dryWet) + (bufValue * (1.0f - kData->postProc.dryWet));
  891. }
  892. }
  893. // Balance
  894. if (doBalance)
  895. {
  896. if (i % 2 == 0)
  897. carla_copyFloat(oldBufLeft, fAudioOutBuffers[i], frames);
  898. float balRangeL = (kData->postProc.balanceLeft + 1.0f)/2.0f;
  899. float balRangeR = (kData->postProc.balanceRight + 1.0f)/2.0f;
  900. for (k=0; k < frames; k++)
  901. {
  902. if (i % 2 == 0)
  903. {
  904. // left
  905. fAudioOutBuffers[i][k] = oldBufLeft[k] * (1.0f - balRangeL);
  906. fAudioOutBuffers[i][k] += fAudioOutBuffers[i+1][k] * (1.0f - balRangeR);
  907. }
  908. else
  909. {
  910. // right
  911. fAudioOutBuffers[i][k] = fAudioOutBuffers[i][k] * balRangeR;
  912. fAudioOutBuffers[i][k] += oldBufLeft[k] * balRangeL;
  913. }
  914. }
  915. }
  916. // Volume (and buffer copy)
  917. {
  918. for (k=0; k < frames; k++)
  919. outBuffer[i][k+timeOffset] = fAudioOutBuffers[i][k] * kData->postProc.volume;
  920. }
  921. }
  922. #if 0
  923. // Latency, save values for next callback, TODO
  924. if (kData->latency > 0 && kData->latency < frames)
  925. {
  926. for (i=0; i < kData->audioIn.count; i++)
  927. carla_copyFloat(kData->latencyBuffers[i], inBuffer[i] + (frames - kData->latency), kData->latency);
  928. }
  929. #endif
  930. } // End of Post-processing
  931. // --------------------------------------------------------------------------------------------------------
  932. kData->mutex.unlock();
  933. return true;
  934. }
  935. void bufferSizeChanged(const uint32_t newBufferSize)
  936. {
  937. carla_debug("LadspaPlugin::bufferSizeChanged(%i) - start", newBufferSize);
  938. for (uint32_t i=0; i < kData->audioIn.count; i++)
  939. {
  940. if (fAudioInBuffers[i] != nullptr)
  941. delete[] fAudioInBuffers[i];
  942. fAudioInBuffers[i] = new float[newBufferSize];
  943. }
  944. for (uint32_t i=0; i < kData->audioOut.count; i++)
  945. {
  946. if (fAudioOutBuffers[i] != nullptr)
  947. delete[] fAudioOutBuffers[i];
  948. fAudioOutBuffers[i] = new float[newBufferSize];
  949. }
  950. if (fHandle2 == nullptr)
  951. {
  952. for (uint32_t i=0; i < kData->audioIn.count; i++)
  953. {
  954. CARLA_ASSERT(fAudioInBuffers[i] != nullptr);
  955. fDescriptor->connect_port(fHandle, kData->audioIn.ports[i].rindex, fAudioInBuffers[i]);
  956. }
  957. for (uint32_t i=0; i < kData->audioOut.count; i++)
  958. {
  959. CARLA_ASSERT(fAudioOutBuffers[i] != nullptr);
  960. fDescriptor->connect_port(fHandle, kData->audioOut.ports[i].rindex, fAudioOutBuffers[i]);
  961. }
  962. }
  963. else
  964. {
  965. if (kData->audioIn.count > 0)
  966. {
  967. CARLA_ASSERT(kData->audioIn.count == 2);
  968. CARLA_ASSERT(fAudioInBuffers[0] != nullptr);
  969. CARLA_ASSERT(fAudioInBuffers[1] != nullptr);
  970. fDescriptor->connect_port(fHandle, kData->audioIn.ports[0].rindex, fAudioInBuffers[0]);
  971. fDescriptor->connect_port(fHandle2, kData->audioIn.ports[1].rindex, fAudioInBuffers[1]);
  972. }
  973. if (kData->audioOut.count > 0)
  974. {
  975. CARLA_ASSERT(kData->audioOut.count == 2);
  976. CARLA_ASSERT(fAudioOutBuffers[0] != nullptr);
  977. CARLA_ASSERT(fAudioOutBuffers[1] != nullptr);
  978. fDescriptor->connect_port(fHandle, kData->audioOut.ports[0].rindex, fAudioOutBuffers[0]);
  979. fDescriptor->connect_port(fHandle2, kData->audioOut.ports[1].rindex, fAudioOutBuffers[1]);
  980. }
  981. }
  982. carla_debug("LadspaPlugin::bufferSizeChanged(%i) - end", newBufferSize);
  983. }
  984. // -------------------------------------------------------------------
  985. // Cleanup
  986. void deleteBuffers()
  987. {
  988. carla_debug("LadspaPlugin::deleteBuffers() - start");
  989. if (fAudioInBuffers != nullptr)
  990. {
  991. for (uint32_t i=0; i < kData->audioIn.count; i++)
  992. {
  993. if (fAudioInBuffers[i] != nullptr)
  994. {
  995. delete[] fAudioInBuffers[i];
  996. fAudioInBuffers[i] = nullptr;
  997. }
  998. }
  999. delete[] fAudioInBuffers;
  1000. fAudioInBuffers = nullptr;
  1001. }
  1002. if (fAudioOutBuffers != nullptr)
  1003. {
  1004. for (uint32_t i=0; i < kData->audioOut.count; i++)
  1005. {
  1006. if (fAudioOutBuffers[i] != nullptr)
  1007. {
  1008. delete[] fAudioOutBuffers[i];
  1009. fAudioOutBuffers[i] = nullptr;
  1010. }
  1011. }
  1012. delete[] fAudioOutBuffers;
  1013. fAudioOutBuffers = nullptr;
  1014. }
  1015. if (fParamBuffers != nullptr)
  1016. {
  1017. delete[] fParamBuffers;
  1018. fParamBuffers = nullptr;
  1019. }
  1020. CarlaPlugin::deleteBuffers();
  1021. carla_debug("LadspaPlugin::deleteBuffers() - end");
  1022. }
  1023. // -------------------------------------------------------------------
  1024. bool init(const char* const filename, const char* const name, const char* const label, const LADSPA_RDF_Descriptor* const rdfDescriptor)
  1025. {
  1026. CARLA_ASSERT(kData->engine != nullptr);
  1027. CARLA_ASSERT(kData->client == nullptr);
  1028. CARLA_ASSERT(filename != nullptr);
  1029. CARLA_ASSERT(label != nullptr);
  1030. // ---------------------------------------------------------------
  1031. // open DLL
  1032. if (! libOpen(filename))
  1033. {
  1034. kData->engine->setLastError(libError(filename));
  1035. return false;
  1036. }
  1037. // ---------------------------------------------------------------
  1038. // get DLL main entry
  1039. const LADSPA_Descriptor_Function descFn = (LADSPA_Descriptor_Function)libSymbol("ladspa_descriptor");
  1040. if (descFn == nullptr)
  1041. {
  1042. kData->engine->setLastError("Could not find the LASDPA Descriptor in the plugin library");
  1043. return false;
  1044. }
  1045. // ---------------------------------------------------------------
  1046. // get descriptor that matches label
  1047. unsigned long i = 0;
  1048. while ((fDescriptor = descFn(i++)) != nullptr)
  1049. {
  1050. if (fDescriptor->Label != nullptr && std::strcmp(fDescriptor->Label, label) == 0)
  1051. break;
  1052. }
  1053. if (fDescriptor == nullptr)
  1054. {
  1055. kData->engine->setLastError("Could not find the requested plugin label in the plugin library");
  1056. return false;
  1057. }
  1058. // ---------------------------------------------------------------
  1059. // get info
  1060. if (is_ladspa_rdf_descriptor_valid(rdfDescriptor, fDescriptor))
  1061. fRdfDescriptor = ladspa_rdf_dup(rdfDescriptor);
  1062. if (name != nullptr)
  1063. fName = kData->engine->getNewUniquePluginName(name);
  1064. else if (fRdfDescriptor != nullptr && fRdfDescriptor->Title != nullptr)
  1065. fName = kData->engine->getNewUniquePluginName(fRdfDescriptor->Title);
  1066. else if (fDescriptor->Name != nullptr)
  1067. fName = kData->engine->getNewUniquePluginName(fDescriptor->Name);
  1068. else
  1069. fName = kData->engine->getNewUniquePluginName(fDescriptor->Label);
  1070. fFilename = filename;
  1071. // ---------------------------------------------------------------
  1072. // register client
  1073. kData->client = kData->engine->addClient(this);
  1074. if (kData->client == nullptr || ! kData->client->isOk())
  1075. {
  1076. kData->engine->setLastError("Failed to register plugin client");
  1077. return false;
  1078. }
  1079. // ---------------------------------------------------------------
  1080. // initialize plugin
  1081. fHandle = fDescriptor->instantiate(fDescriptor, (unsigned long)kData->engine->getSampleRate());
  1082. if (fHandle == nullptr)
  1083. {
  1084. kData->engine->setLastError("Plugin failed to initialize");
  1085. return false;
  1086. }
  1087. return true;
  1088. }
  1089. private:
  1090. LADSPA_Handle fHandle;
  1091. LADSPA_Handle fHandle2;
  1092. const LADSPA_Descriptor* fDescriptor;
  1093. const LADSPA_RDF_Descriptor* fRdfDescriptor;
  1094. float** fAudioInBuffers;
  1095. float** fAudioOutBuffers;
  1096. float* fParamBuffers;
  1097. };
  1098. CARLA_BACKEND_END_NAMESPACE
  1099. #else // WANT_LADSPA
  1100. # warning Building without LADSPA support
  1101. #endif
  1102. CARLA_BACKEND_START_NAMESPACE
  1103. CarlaPlugin* CarlaPlugin::newLADSPA(const Initializer& init, const LADSPA_RDF_Descriptor* const rdfDescriptor)
  1104. {
  1105. carla_debug("CarlaPlugin::newLADSPA({%p, \"%s\", \"%s\", \"%s\"}, %p)", init.engine, init.filename, init.name, init.label, rdfDescriptor);
  1106. #ifdef WANT_LADSPA
  1107. LadspaPlugin* const plugin = new LadspaPlugin(init.engine, init.id);
  1108. if (! plugin->init(init.filename, init.name, init.label, rdfDescriptor))
  1109. {
  1110. delete plugin;
  1111. return nullptr;
  1112. }
  1113. plugin->reload();
  1114. if (init.engine->getProccessMode() == PROCESS_MODE_CONTINUOUS_RACK && (plugin->hints() & PLUGIN_CAN_FORCE_STEREO) == 0)
  1115. {
  1116. init.engine->setLastError("Carla's rack mode can only work with Mono or Stereo LADSPA plugins, sorry!");
  1117. delete plugin;
  1118. return nullptr;
  1119. }
  1120. return plugin;
  1121. #else
  1122. init.engine->setLastError("LADSPA support not available");
  1123. return nullptr;
  1124. #endif
  1125. }
  1126. CARLA_BACKEND_END_NAMESPACE