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.

2212 lines
73KB

  1. /*
  2. * Carla JACK Engine
  3. * Copyright (C) 2012-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 "CarlaEngineInternal.hpp"
  18. #include "CarlaBackendUtils.hpp"
  19. #include "CarlaMIDI.h"
  20. #ifdef JACKBRIDGE_EXPORT
  21. # include "jackbridge/JackBridge.hpp"
  22. #else
  23. # include "jackbridge/JackBridge1.cpp"
  24. # include "jackbridge/JackBridge2.cpp"
  25. #endif
  26. #include <cmath>
  27. #include <QtCore/QStringList>
  28. #define URI_CANVAS_ICON "http://kxstudio.sf.net/ns/canvas/icon"
  29. CARLA_BACKEND_START_NAMESPACE
  30. #if 0
  31. } // Fix editor indentation
  32. #endif
  33. // -------------------------------------------------------------------------------------------------------------------
  34. // Fallback data
  35. static const EngineEvent kFallbackJackEngineEvent;
  36. // -------------------------------------------------------------------------------------------------------------------
  37. // Plugin Helpers, defined in CarlaPlugin.cpp
  38. extern CarlaEngine* CarlaPluginGetEngine(CarlaPlugin* const plugin);
  39. extern CarlaEngineClient* CarlaPluginGetEngineClient(CarlaPlugin* const plugin);
  40. extern CarlaEngineAudioPort* CarlaPluginGetAudioInPort(CarlaPlugin* const plugin, uint32_t index);
  41. extern CarlaEngineAudioPort* CarlaPluginGetAudioOutPort(CarlaPlugin* const plugin, uint32_t index);
  42. // -------------------------------------------------------------------------------------------------------------------
  43. // Carla Engine JACK-Audio port
  44. class CarlaEngineJackAudioPort : public CarlaEngineAudioPort
  45. {
  46. public:
  47. CarlaEngineJackAudioPort(const bool isInput, const ProcessMode processMode, jack_client_t* const client, jack_port_t* const port)
  48. : CarlaEngineAudioPort(isInput, processMode),
  49. kClient(client),
  50. kPort(port)
  51. {
  52. carla_debug("CarlaEngineJackAudioPort::CarlaEngineJackAudioPort(%s, %s, %p, %p)", bool2str(isInput), ProcessMode2Str(processMode), client, port);
  53. if (processMode == PROCESS_MODE_SINGLE_CLIENT || processMode == PROCESS_MODE_MULTIPLE_CLIENTS)
  54. {
  55. CARLA_ASSERT(client != nullptr && port != nullptr);
  56. }
  57. else
  58. {
  59. CARLA_ASSERT(client == nullptr && port == nullptr);
  60. }
  61. }
  62. ~CarlaEngineJackAudioPort() override
  63. {
  64. carla_debug("CarlaEngineJackAudioPort::~CarlaEngineJackAudioPort()");
  65. if (kClient != nullptr && kPort != nullptr)
  66. jackbridge_port_unregister(kClient, kPort);
  67. }
  68. void initBuffer(CarlaEngine* const engine) override
  69. {
  70. CARLA_ASSERT(engine != nullptr);
  71. if (engine == nullptr)
  72. return;
  73. if (kPort == nullptr)
  74. return CarlaEngineAudioPort::initBuffer(engine);
  75. const uint32_t bufferSize(engine->getBufferSize());
  76. fBuffer = (float*)jackbridge_port_get_buffer(kPort, bufferSize);
  77. if (! kIsInput)
  78. carla_zeroFloat(fBuffer, bufferSize);
  79. }
  80. private:
  81. jack_client_t* const kClient;
  82. jack_port_t* const kPort;
  83. friend class CarlaEngineJack;
  84. CARLA_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(CarlaEngineJackAudioPort)
  85. };
  86. // -------------------------------------------------------------------------------------------------------------------
  87. // Carla Engine JACK-CV port
  88. class CarlaEngineJackCVPort : public CarlaEngineCVPort
  89. {
  90. public:
  91. CarlaEngineJackCVPort(const bool isInput, const ProcessMode processMode, const uint32_t bufferSize, jack_client_t* const client, jack_port_t* const port)
  92. : CarlaEngineCVPort(isInput, processMode, bufferSize),
  93. kClient(client),
  94. kPort(port)
  95. {
  96. carla_debug("CarlaEngineJackCVPort::CarlaEngineJackCVPort(%s, %s, %p, %p)", bool2str(isInput), ProcessMode2Str(processMode), client, port);
  97. if (processMode == PROCESS_MODE_SINGLE_CLIENT || processMode == PROCESS_MODE_MULTIPLE_CLIENTS)
  98. {
  99. CARLA_ASSERT(client != nullptr && port != nullptr);
  100. }
  101. else
  102. {
  103. CARLA_ASSERT(client == nullptr && port == nullptr);
  104. }
  105. }
  106. ~CarlaEngineJackCVPort() override
  107. {
  108. carla_debug("CarlaEngineJackCVPort::~CarlaEngineJackCVPort()");
  109. if (kClient != nullptr && kPort != nullptr)
  110. jackbridge_port_unregister(kClient, kPort);
  111. }
  112. void initBuffer(CarlaEngine* const engine) override
  113. {
  114. CARLA_ASSERT(engine != nullptr);
  115. if (engine == nullptr)
  116. return;
  117. if (kPort == nullptr)
  118. return CarlaEngineCVPort::initBuffer(engine);
  119. CARLA_ASSERT(engine->getBufferSize() == fBufferSize);
  120. if (kIsInput)
  121. {
  122. float* const jackBuffer = (float*)jackbridge_port_get_buffer(kPort, fBufferSize);
  123. carla_copyFloat(fBuffer, jackBuffer, fBufferSize);
  124. }
  125. else
  126. {
  127. carla_zeroFloat(fBuffer, fBufferSize);
  128. }
  129. }
  130. void writeBuffer(CarlaEngine* const engine) override
  131. {
  132. CARLA_ASSERT(! kIsInput);
  133. CARLA_ASSERT(engine != nullptr);
  134. if (kIsInput)
  135. return;
  136. if (engine == nullptr)
  137. return;
  138. CARLA_ASSERT(engine->getBufferSize() == fBufferSize);
  139. float* const jackBuffer = (float*)jackbridge_port_get_buffer(kPort, fBufferSize);
  140. carla_copyFloat(jackBuffer, fBuffer, fBufferSize);
  141. }
  142. private:
  143. jack_client_t* const kClient;
  144. jack_port_t* const kPort;
  145. friend class CarlaEngineJack;
  146. CARLA_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(CarlaEngineJackCVPort)
  147. };
  148. // -------------------------------------------------------------------------------------------------------------------
  149. // Carla Engine JACK-Event port
  150. class CarlaEngineJackEventPort : public CarlaEngineEventPort
  151. {
  152. public:
  153. CarlaEngineJackEventPort(const bool isInput, const ProcessMode processMode, jack_client_t* const client, jack_port_t* const port)
  154. : CarlaEngineEventPort(isInput, processMode),
  155. kClient(client),
  156. kPort(port),
  157. fJackBuffer(nullptr)
  158. {
  159. carla_debug("CarlaEngineJackEventPort::CarlaEngineJackEventPort(%s, %s, %p, %p)", bool2str(isInput), ProcessMode2Str(processMode), client, port);
  160. if (processMode == PROCESS_MODE_SINGLE_CLIENT || processMode == PROCESS_MODE_MULTIPLE_CLIENTS)
  161. {
  162. CARLA_ASSERT(client != nullptr && port != nullptr);
  163. }
  164. else
  165. {
  166. CARLA_ASSERT(client == nullptr && port == nullptr);
  167. }
  168. }
  169. ~CarlaEngineJackEventPort() override
  170. {
  171. carla_debug("CarlaEngineJackEventPort::~CarlaEngineJackEventPort()");
  172. if (kClient != nullptr && kPort != nullptr)
  173. jackbridge_port_unregister(kClient, kPort);
  174. }
  175. void initBuffer(CarlaEngine* const engine) override
  176. {
  177. CARLA_ASSERT(engine != nullptr);
  178. if (engine == nullptr)
  179. return;
  180. if (kPort == nullptr)
  181. return CarlaEngineEventPort::initBuffer(engine);
  182. fJackBuffer = jackbridge_port_get_buffer(kPort, engine->getBufferSize());
  183. if (! kIsInput)
  184. jackbridge_midi_clear_buffer(fJackBuffer);
  185. }
  186. uint32_t getEventCount() const override
  187. {
  188. if (kPort == nullptr)
  189. return CarlaEngineEventPort::getEventCount();
  190. CARLA_ASSERT(kIsInput);
  191. CARLA_ASSERT(fJackBuffer != nullptr);
  192. if (! kIsInput)
  193. return 0;
  194. if (fJackBuffer == nullptr)
  195. return 0;
  196. return jackbridge_midi_get_event_count(fJackBuffer);
  197. }
  198. const EngineEvent& getEvent(const uint32_t index) override
  199. {
  200. if (kPort == nullptr)
  201. return CarlaEngineEventPort::getEvent(index);
  202. CARLA_ASSERT(kIsInput);
  203. CARLA_ASSERT(fJackBuffer != nullptr);
  204. if (! kIsInput)
  205. return kFallbackJackEngineEvent;
  206. if (fJackBuffer == nullptr)
  207. return kFallbackJackEngineEvent;
  208. jack_midi_event_t jackEvent;
  209. carla_zeroStruct<jack_midi_event_t>(jackEvent);
  210. if (! jackbridge_midi_event_get(&jackEvent, fJackBuffer, index))
  211. return kFallbackJackEngineEvent;
  212. if (jackEvent.size == 0 || jackEvent.size > 4)
  213. return kFallbackJackEngineEvent;
  214. fRetEvent.clear();
  215. const uint8_t midiStatus = MIDI_GET_STATUS_FROM_DATA(jackEvent.buffer);
  216. const uint8_t midiChannel = MIDI_GET_CHANNEL_FROM_DATA(jackEvent.buffer);
  217. fRetEvent.time = jackEvent.time;
  218. fRetEvent.channel = midiChannel;
  219. if (MIDI_IS_STATUS_CONTROL_CHANGE(midiStatus))
  220. {
  221. CARLA_ASSERT(jackEvent.size == 2 || jackEvent.size == 3);
  222. const uint8_t midiControl = jackEvent.buffer[1];
  223. fRetEvent.type = kEngineEventTypeControl;
  224. if (MIDI_IS_CONTROL_BANK_SELECT(midiControl))
  225. {
  226. const uint8_t midiBank = jackEvent.buffer[2];
  227. fRetEvent.ctrl.type = kEngineControlEventTypeMidiBank;
  228. fRetEvent.ctrl.param = midiBank;
  229. fRetEvent.ctrl.value = 0.0f;
  230. }
  231. else if (midiControl == MIDI_CONTROL_ALL_SOUND_OFF)
  232. {
  233. fRetEvent.ctrl.type = kEngineControlEventTypeAllSoundOff;
  234. fRetEvent.ctrl.param = 0;
  235. fRetEvent.ctrl.value = 0.0f;
  236. }
  237. else if (midiControl == MIDI_CONTROL_ALL_NOTES_OFF)
  238. {
  239. fRetEvent.ctrl.type = kEngineControlEventTypeAllNotesOff;
  240. fRetEvent.ctrl.param = 0;
  241. fRetEvent.ctrl.value = 0.0f;
  242. }
  243. else
  244. {
  245. CARLA_ASSERT(jackEvent.size == 3);
  246. const uint8_t midiValue = jackEvent.buffer[2];
  247. fRetEvent.ctrl.type = kEngineControlEventTypeParameter;
  248. fRetEvent.ctrl.param = midiControl;
  249. fRetEvent.ctrl.value = float(midiValue)/127.0f;
  250. }
  251. }
  252. else if (MIDI_IS_STATUS_PROGRAM_CHANGE(midiStatus))
  253. {
  254. CARLA_ASSERT(jackEvent.size == 2);
  255. const uint8_t midiProgram = jackEvent.buffer[1];
  256. fRetEvent.type = kEngineEventTypeControl;
  257. fRetEvent.ctrl.type = kEngineControlEventTypeMidiProgram;
  258. fRetEvent.ctrl.param = midiProgram;
  259. fRetEvent.ctrl.value = 0.0f;
  260. }
  261. else
  262. {
  263. fRetEvent.type = kEngineEventTypeMidi;
  264. fRetEvent.midi.data[0] = midiStatus;
  265. fRetEvent.midi.size = static_cast<uint8_t>(jackEvent.size);
  266. if (jackEvent.size > 1)
  267. carla_copy<uint8_t>(fRetEvent.midi.data+1, jackEvent.buffer+1, jackEvent.size-1);
  268. }
  269. return fRetEvent;
  270. }
  271. void writeControlEvent(const uint32_t time, const uint8_t channel, const EngineControlEventType type, const uint16_t param, const float value) override
  272. {
  273. if (kPort == nullptr)
  274. return CarlaEngineEventPort::writeControlEvent(time, channel, type, param, value);
  275. CARLA_ASSERT(! kIsInput);
  276. CARLA_ASSERT(fJackBuffer != nullptr);
  277. CARLA_ASSERT(type != kEngineControlEventTypeNull);
  278. CARLA_ASSERT(channel < MAX_MIDI_CHANNELS);
  279. CARLA_ASSERT(param < MAX_MIDI_VALUE);
  280. CARLA_SAFE_ASSERT(value >= 0.0f && value <= 1.0f);
  281. if (kIsInput)
  282. return;
  283. if (fJackBuffer == nullptr)
  284. return;
  285. if (type == kEngineControlEventTypeNull)
  286. return;
  287. if (channel >= MAX_MIDI_CHANNELS)
  288. return;
  289. if (param >= MAX_MIDI_VALUE)
  290. return;
  291. if (type == kEngineControlEventTypeParameter)
  292. {
  293. CARLA_ASSERT(! MIDI_IS_CONTROL_BANK_SELECT(param));
  294. }
  295. const float fixedValue(carla_fixValue<float>(0.0f, 1.0f, value));
  296. size_t size = 0;
  297. jack_midi_data_t data[4] = { 0 };
  298. switch (type)
  299. {
  300. case kEngineControlEventTypeNull:
  301. break;
  302. case kEngineControlEventTypeParameter:
  303. data[0] = MIDI_STATUS_CONTROL_CHANGE + channel;
  304. data[1] = param;
  305. data[2] = fixedValue * 127.0f;
  306. size = 3;
  307. break;
  308. case kEngineControlEventTypeMidiBank:
  309. data[0] = MIDI_STATUS_CONTROL_CHANGE + channel;
  310. data[1] = MIDI_CONTROL_BANK_SELECT;
  311. data[2] = param;
  312. size = 3;
  313. break;
  314. case kEngineControlEventTypeMidiProgram:
  315. data[0] = MIDI_STATUS_PROGRAM_CHANGE + channel;
  316. data[1] = param;
  317. size = 2;
  318. break;
  319. case kEngineControlEventTypeAllSoundOff:
  320. data[0] = MIDI_STATUS_CONTROL_CHANGE + channel;
  321. data[1] = MIDI_CONTROL_ALL_SOUND_OFF;
  322. data[2] = 0;
  323. size = 3;
  324. break;
  325. case kEngineControlEventTypeAllNotesOff:
  326. data[0] = MIDI_STATUS_CONTROL_CHANGE + channel;
  327. data[1] = MIDI_CONTROL_ALL_NOTES_OFF;
  328. data[2] = 0;
  329. size = 3;
  330. break;
  331. }
  332. if (size > 0)
  333. jackbridge_midi_event_write(fJackBuffer, time, data, size);
  334. }
  335. void writeMidiEvent(const uint32_t time, const uint8_t channel, const uint8_t port, const uint8_t* const data, const uint8_t size) override
  336. {
  337. if (kPort == nullptr)
  338. return CarlaEngineEventPort::writeMidiEvent(time, channel, port, data, size);
  339. CARLA_ASSERT(! kIsInput);
  340. CARLA_ASSERT(fJackBuffer != nullptr);
  341. CARLA_ASSERT(channel < MAX_MIDI_CHANNELS);
  342. CARLA_ASSERT(data != nullptr);
  343. CARLA_ASSERT(size != 0);
  344. if (kIsInput)
  345. return;
  346. if (fJackBuffer == nullptr)
  347. return;
  348. if (channel >= MAX_MIDI_CHANNELS)
  349. return;
  350. if (data == nullptr)
  351. return;
  352. if (size == 0)
  353. return;
  354. uint8_t jdata[size];
  355. carla_copy<uint8_t>(jdata, data, size);
  356. jdata[0] = MIDI_GET_STATUS_FROM_DATA(data) + channel;
  357. jackbridge_midi_event_write(fJackBuffer, time, jdata, size);
  358. }
  359. private:
  360. jack_client_t* const kClient;
  361. jack_port_t* const kPort;
  362. void* fJackBuffer;
  363. EngineEvent fRetEvent;
  364. CARLA_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(CarlaEngineJackEventPort)
  365. };
  366. // -------------------------------------------------------------------------------------------------------------------
  367. // Jack Engine client
  368. class CarlaEngineJackClient : public CarlaEngineClient
  369. {
  370. public:
  371. CarlaEngineJackClient(const CarlaEngine& engine, jack_client_t* const client)
  372. : CarlaEngineClient(engine),
  373. kClient(client),
  374. kUseClient(engine.getProccessMode() == PROCESS_MODE_SINGLE_CLIENT || engine.getProccessMode() == PROCESS_MODE_MULTIPLE_CLIENTS)
  375. {
  376. carla_debug("CarlaEngineJackClient::CarlaEngineJackClient(name:\"%s\", %p)", engine.getName(), client);
  377. if (kUseClient)
  378. {
  379. CARLA_ASSERT(kClient != nullptr);
  380. }
  381. else
  382. {
  383. CARLA_ASSERT(kClient == nullptr);
  384. }
  385. }
  386. ~CarlaEngineJackClient() override
  387. {
  388. carla_debug("CarlaEngineClient::~CarlaEngineClient()");
  389. if (kEngine.getProccessMode() == PROCESS_MODE_MULTIPLE_CLIENTS && kClient != nullptr)
  390. jackbridge_client_close(kClient);
  391. }
  392. void activate() override
  393. {
  394. carla_debug("CarlaEngineJackClient::activate()");
  395. if (kEngine.getProccessMode() == PROCESS_MODE_MULTIPLE_CLIENTS)
  396. {
  397. CARLA_ASSERT(kClient != nullptr && ! fActive);
  398. if (kClient != nullptr && ! fActive)
  399. jackbridge_activate(kClient);
  400. }
  401. CarlaEngineClient::activate();
  402. }
  403. void deactivate() override
  404. {
  405. carla_debug("CarlaEngineJackClient::deactivate()");
  406. if (kEngine.getProccessMode() == PROCESS_MODE_MULTIPLE_CLIENTS)
  407. {
  408. CARLA_ASSERT(kClient != nullptr && fActive);
  409. if (kClient != nullptr && fActive)
  410. jackbridge_deactivate(kClient);
  411. }
  412. CarlaEngineClient::deactivate();
  413. }
  414. bool isOk() const override
  415. {
  416. carla_debug("CarlaEngineJackClient::isOk()");
  417. if (kUseClient)
  418. return (kClient != nullptr);
  419. return CarlaEngineClient::isOk();
  420. }
  421. #if 0
  422. void setLatency(const uint32_t samples) override
  423. {
  424. CarlaEngineClient::setLatency(samples);
  425. if (kUseClient)
  426. jackbridge_recompute_total_latencies(kClient);
  427. }
  428. #endif
  429. CarlaEnginePort* addPort(const EnginePortType portType, const char* const name, const bool isInput) override
  430. {
  431. carla_debug("CarlaEngineJackClient::addPort(%s, \"%s\", %s)", EnginePortType2Str(portType), name, bool2str(isInput));
  432. jack_port_t* port = nullptr;
  433. // Create JACK port first, if needed
  434. if (kUseClient)
  435. {
  436. switch (portType)
  437. {
  438. case kEnginePortTypeNull:
  439. break;
  440. case kEnginePortTypeAudio:
  441. port = jackbridge_port_register(kClient, name, JACK_DEFAULT_AUDIO_TYPE, isInput ? JackPortIsInput : JackPortIsOutput, 0);
  442. break;
  443. case kEnginePortTypeCV:
  444. port = jackbridge_port_register(kClient, name, JACK_DEFAULT_AUDIO_TYPE, JackPortIsControlVoltage | (isInput ? JackPortIsInput : JackPortIsOutput), 0);
  445. break;
  446. case kEnginePortTypeEvent:
  447. port = jackbridge_port_register(kClient, name, JACK_DEFAULT_MIDI_TYPE, isInput ? JackPortIsInput : JackPortIsOutput, 0);
  448. break;
  449. }
  450. }
  451. // Create Engine port
  452. switch (portType)
  453. {
  454. case kEnginePortTypeNull:
  455. break;
  456. case kEnginePortTypeAudio:
  457. return new CarlaEngineJackAudioPort(isInput, kEngine.getProccessMode(), kClient, port);
  458. case kEnginePortTypeCV:
  459. return new CarlaEngineJackCVPort(isInput, kEngine.getProccessMode(), kEngine.getBufferSize(), kClient, port);
  460. case kEnginePortTypeEvent:
  461. return new CarlaEngineJackEventPort(isInput, kEngine.getProccessMode(), kClient, port);
  462. }
  463. carla_stderr("CarlaEngineJackClient::addPort(%s, \"%s\", %s) - invalid type", EnginePortType2Str(portType), name, bool2str(isInput));
  464. return nullptr;
  465. }
  466. private:
  467. jack_client_t* const kClient;
  468. const bool kUseClient;
  469. friend class CarlaEngineJack;
  470. CARLA_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(CarlaEngineJackClient)
  471. };
  472. // -------------------------------------------------------------------------------------------------------------------
  473. // Jack Engine
  474. class CarlaEngineJack : public CarlaEngine
  475. {
  476. public:
  477. CarlaEngineJack()
  478. : CarlaEngine(),
  479. fClient(nullptr),
  480. fTransportState(JackTransportStopped),
  481. fFreewheel(false),
  482. #ifdef BUILD_BRIDGE
  483. fHasQuit(false)
  484. #else
  485. # ifdef CARLA_PROPER_CPP11_SUPPORT
  486. fRackPorts{nullptr},
  487. # endif
  488. fLastGroupId(0),
  489. fLastPortId(0),
  490. fLastConnectionId(0)
  491. #endif
  492. {
  493. carla_debug("CarlaEngineJack::CarlaEngineJack()");
  494. #ifdef BUILD_BRIDGE
  495. fOptions.processMode = PROCESS_MODE_MULTIPLE_CLIENTS;
  496. #else
  497. # ifndef CARLA_PROPER_CPP11_SUPPORT
  498. carla_fill<jack_port_t*>(fRackPorts, kRackPortCount, nullptr);
  499. # endif
  500. #endif
  501. // FIXME: Always enable JACK transport for now
  502. fOptions.transportMode = TRANSPORT_MODE_JACK;
  503. carla_zeroStruct<jack_position_t>(fTransportPos);
  504. }
  505. ~CarlaEngineJack() override
  506. {
  507. carla_debug("CarlaEngineJack::~CarlaEngineJack()");
  508. CARLA_ASSERT(fClient == nullptr);
  509. #ifndef BUILD_BRIDGE
  510. fUsedGroupNames.clear();
  511. fUsedPortNames.clear();
  512. fUsedConnections.clear();
  513. fGroupIconsChanged.clear();
  514. #endif
  515. }
  516. // -------------------------------------------------------------------
  517. // Maximum values
  518. unsigned int maxClientNameSize() const override
  519. {
  520. if (fOptions.processMode == PROCESS_MODE_SINGLE_CLIENT || fOptions.processMode == PROCESS_MODE_MULTIPLE_CLIENTS)
  521. return static_cast<unsigned int>(jackbridge_client_name_size());
  522. return CarlaEngine::maxClientNameSize();
  523. }
  524. unsigned int maxPortNameSize() const override
  525. {
  526. if (fOptions.processMode == PROCESS_MODE_SINGLE_CLIENT || fOptions.processMode == PROCESS_MODE_MULTIPLE_CLIENTS)
  527. return static_cast<unsigned int>(jackbridge_port_name_size());
  528. return CarlaEngine::maxPortNameSize();
  529. }
  530. // -------------------------------------------------------------------
  531. // Virtual, per-engine type calls
  532. bool init(const char* const clientName) override
  533. {
  534. carla_debug("CarlaEngineJack::init(\"%s\")", clientName);
  535. fFreewheel = false;
  536. fTransportState = JackTransportStopped;
  537. carla_zeroStruct<jack_position_t>(fTransportPos);
  538. #ifndef BUILD_BRIDGE
  539. fLastGroupId = 0;
  540. fLastPortId = 0;
  541. fLastConnectionId = 0;
  542. fUsedGroupNames.clear();
  543. fUsedPortNames.clear();
  544. fUsedConnections.clear();
  545. fGroupIconsChanged.clear();
  546. fClient = jackbridge_client_open(clientName, JackNullOption, nullptr);
  547. if (fClient != nullptr)
  548. {
  549. fBufferSize = jackbridge_get_buffer_size(fClient);
  550. fSampleRate = jackbridge_get_sample_rate(fClient);
  551. jackbridge_custom_publish_data(fClient, URI_CANVAS_ICON, "carla", 6);
  552. jackbridge_custom_set_data_appearance_callback(fClient, carla_jack_custom_appearance_callback, this);
  553. jackbridge_set_buffer_size_callback(fClient, carla_jack_bufsize_callback, this);
  554. jackbridge_set_sample_rate_callback(fClient, carla_jack_srate_callback, this);
  555. jackbridge_set_freewheel_callback(fClient, carla_jack_freewheel_callback, this);
  556. jackbridge_set_process_callback(fClient, carla_jack_process_callback, this);
  557. jackbridge_on_shutdown(fClient, carla_jack_shutdown_callback, this);
  558. # if 0
  559. jackbridge_set_latency_callback(fClient, carla_jack_latency_callback, this);
  560. # endif
  561. const char* const jackClientName(jackbridge_get_client_name(fClient));
  562. initJackPatchbay(jackClientName);
  563. jackbridge_set_client_registration_callback(fClient, carla_jack_client_registration_callback, this);
  564. jackbridge_set_port_registration_callback(fClient, carla_jack_port_registration_callback, this);
  565. jackbridge_set_port_connect_callback(fClient, carla_jack_port_connect_callback, this);
  566. jackbridge_set_port_rename_callback(fClient, carla_jack_port_rename_callback, this);
  567. if (fOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  568. {
  569. fRackPorts[kRackPortAudioIn1] = jackbridge_port_register(fClient, "audio-in1", JACK_DEFAULT_AUDIO_TYPE, JackPortIsInput, 0);
  570. fRackPorts[kRackPortAudioIn2] = jackbridge_port_register(fClient, "audio-in2", JACK_DEFAULT_AUDIO_TYPE, JackPortIsInput, 0);
  571. fRackPorts[kRackPortAudioOut1] = jackbridge_port_register(fClient, "audio-out1", JACK_DEFAULT_AUDIO_TYPE, JackPortIsOutput, 0);
  572. fRackPorts[kRackPortAudioOut2] = jackbridge_port_register(fClient, "audio-out2", JACK_DEFAULT_AUDIO_TYPE, JackPortIsOutput, 0);
  573. fRackPorts[kRackPortEventIn] = jackbridge_port_register(fClient, "events-in", JACK_DEFAULT_MIDI_TYPE, JackPortIsInput, 0);
  574. fRackPorts[kRackPortEventOut] = jackbridge_port_register(fClient, "events-out", JACK_DEFAULT_MIDI_TYPE, JackPortIsOutput, 0);
  575. }
  576. if (jackbridge_activate(fClient))
  577. {
  578. CarlaEngine::init(jackClientName);
  579. return true;
  580. }
  581. else
  582. {
  583. setLastError("Failed to activate the JACK client");
  584. jackbridge_client_close(fClient);
  585. fClient = nullptr;
  586. }
  587. }
  588. else
  589. setLastError("Failed to create new JACK client");
  590. return false;
  591. #else
  592. if (fBufferSize == 0 || fSampleRate == 0.0)
  593. {
  594. // open temp client to get initial buffer-size and sample-rate values
  595. if (jack_client_t* tmpClient = jackbridge_client_open(clientName, JackNullOption, nullptr))
  596. {
  597. fBufferSize = jackbridge_get_buffer_size(tmpClient);
  598. fSampleRate = jackbridge_get_sample_rate(tmpClient);
  599. jackbridge_client_close(tmpClient);
  600. }
  601. }
  602. return CarlaEngine::init(clientName);
  603. #endif
  604. }
  605. bool close() override
  606. {
  607. carla_debug("CarlaEngineJack::close()");
  608. CarlaEngine::close();
  609. #ifdef BUILD_BRIDGE
  610. fClient = nullptr;
  611. fHasQuit = true;
  612. return true;
  613. #else
  614. if (jackbridge_deactivate(fClient))
  615. {
  616. if (fOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  617. {
  618. jackbridge_port_unregister(fClient, fRackPorts[kRackPortAudioIn1]);
  619. jackbridge_port_unregister(fClient, fRackPorts[kRackPortAudioIn2]);
  620. jackbridge_port_unregister(fClient, fRackPorts[kRackPortAudioOut1]);
  621. jackbridge_port_unregister(fClient, fRackPorts[kRackPortAudioOut2]);
  622. jackbridge_port_unregister(fClient, fRackPorts[kRackPortEventIn]);
  623. jackbridge_port_unregister(fClient, fRackPorts[kRackPortEventOut]);
  624. }
  625. if (jackbridge_client_close(fClient))
  626. {
  627. fClient = nullptr;
  628. return true;
  629. }
  630. else
  631. setLastError("Failed to close the JACK client");
  632. }
  633. else
  634. setLastError("Failed to deactivate the JACK client");
  635. fClient = nullptr;
  636. fUsedGroupNames.clear();
  637. fUsedPortNames.clear();
  638. fUsedConnections.clear();
  639. fGroupIconsChanged.clear();
  640. #endif
  641. return false;
  642. }
  643. void idle() override
  644. {
  645. CarlaEngine::idle();
  646. if (fGroupIconsChanged.count() == 0)
  647. return;
  648. static bool checkIcons = false;
  649. if (! checkIcons)
  650. {
  651. checkIcons = true; // check them next time
  652. return;
  653. }
  654. checkIcons = false;
  655. void* data;
  656. size_t dataSize;
  657. QList<int> groupIconsCopy(fGroupIconsChanged);
  658. fGroupIconsChanged.clear();
  659. foreach (const int& groupId, groupIconsCopy)
  660. {
  661. const char* const groupName(getGroupName(groupId));
  662. data = nullptr;
  663. dataSize = 0;
  664. if (jackbridge_custom_get_data(fClient, groupName, URI_CANVAS_ICON, &data, &dataSize) && data != nullptr && dataSize != 0)
  665. {
  666. const char* const icon((const char*)data);
  667. CARLA_ASSERT(std::strlen(icon)+1 == dataSize);
  668. PatchbayIconType groupIcon;
  669. if (std::strcmp(icon, "app") == 0 || std::strcmp(icon, "application") == 0)
  670. groupIcon = PATCHBAY_ICON_APPLICATION;
  671. else if (std::strcmp(icon, "hardware") == 0)
  672. groupIcon = PATCHBAY_ICON_HARDWARE;
  673. else if (std::strcmp(icon, "carla") == 0)
  674. groupIcon = PATCHBAY_ICON_CARLA;
  675. else if (std::strcmp(icon, "distrho") == 0)
  676. groupIcon = PATCHBAY_ICON_DISTRHO;
  677. else if (std::strcmp(icon, "file") == 0)
  678. groupIcon = PATCHBAY_ICON_FILE;
  679. else if (std::strcmp(icon, "plugin") == 0)
  680. groupIcon = PATCHBAY_ICON_PLUGIN;
  681. else
  682. groupIcon = PATCHBAY_ICON_APPLICATION;
  683. callback(CALLBACK_PATCHBAY_ICON_CHANGED, 0, groupId, groupIcon, 0.0f, nullptr);
  684. }
  685. }
  686. }
  687. bool isRunning() const override
  688. {
  689. #ifdef BUILD_BRIDGE
  690. return (fClient != nullptr || ! fHasQuit);
  691. #else
  692. return (fClient != nullptr);
  693. #endif
  694. }
  695. bool isOffline() const override
  696. {
  697. return fFreewheel;
  698. }
  699. EngineType type() const override
  700. {
  701. return kEngineTypeJack;
  702. }
  703. CarlaEngineClient* addClient(CarlaPlugin* const plugin) override
  704. {
  705. const char* const iconName(plugin->iconName());
  706. jack_client_t* client = nullptr;
  707. #ifdef BUILD_BRIDGE
  708. client = fClient = jackbridge_client_open(plugin->name(), JackNullOption, nullptr);
  709. fBufferSize = jackbridge_get_buffer_size(client);
  710. fSampleRate = jackbridge_get_sample_rate(client);
  711. jackbridge_custom_publish_data(client, URI_CANVAS_ICON, iconName, std::strlen(iconName)+1);
  712. jackbridge_custom_set_data_appearance_callback(fClient, carla_jack_custom_appearance_callback, this);
  713. jackbridge_set_buffer_size_callback(client, carla_jack_bufsize_callback, this);
  714. jackbridge_set_sample_rate_callback(client, carla_jack_srate_callback, this);
  715. jackbridge_set_freewheel_callback(client, carla_jack_freewheel_callback, this);
  716. jackbridge_set_process_callback(client, carla_jack_process_callback, this);
  717. jackbridge_on_shutdown(client, carla_jack_shutdown_callback, this);
  718. # if 0
  719. jackbridge_set_latency_callback(client, carla_jack_latency_callback, this);
  720. # endif
  721. #else
  722. if (fOptions.processMode == PROCESS_MODE_SINGLE_CLIENT)
  723. {
  724. client = fClient;
  725. }
  726. else if (fOptions.processMode == PROCESS_MODE_MULTIPLE_CLIENTS)
  727. {
  728. client = jackbridge_client_open(plugin->name(), JackNullOption, nullptr);
  729. CARLA_ASSERT(client != nullptr);
  730. if (client == nullptr)
  731. return nullptr;
  732. jackbridge_custom_publish_data(client, URI_CANVAS_ICON, iconName, std::strlen(iconName)+1);
  733. jackbridge_set_process_callback(client, carla_jack_process_callback_plugin, plugin);
  734. # if 0
  735. jackbridge_set_latency_callback(client, carla_jack_latency_callback_plugin, plugin);
  736. # endif
  737. }
  738. #endif
  739. return new CarlaEngineJackClient(*this, client);
  740. }
  741. #ifndef BUILD_BRIDGE
  742. const char* renamePlugin(const unsigned int id, const char* const newName) override
  743. {
  744. CARLA_ASSERT(kData->curPluginCount > 0);
  745. CARLA_ASSERT(id < kData->curPluginCount);
  746. CARLA_ASSERT(kData->plugins != nullptr);
  747. CARLA_ASSERT(newName != nullptr);
  748. if (kData->plugins == nullptr)
  749. {
  750. setLastError("Critical error: no plugins are currently loaded!");
  751. return nullptr;
  752. }
  753. CarlaPlugin* const plugin(kData->plugins[id].plugin);
  754. if (plugin == nullptr)
  755. {
  756. carla_stderr("CarlaEngine::clonePlugin(%i) - could not find plugin", id);
  757. return nullptr;
  758. }
  759. CARLA_ASSERT(plugin->id() == id);
  760. bool needsReinit = (fOptions.processMode == PROCESS_MODE_SINGLE_CLIENT);
  761. const char* name = getUniquePluginName(newName);
  762. // TODO - use rename port if single-client
  763. // JACK client rename
  764. if (fOptions.processMode == PROCESS_MODE_MULTIPLE_CLIENTS)
  765. {
  766. CarlaEngineJackClient* const client((CarlaEngineJackClient*)CarlaPluginGetEngineClient(plugin));
  767. if (bridge.client_rename_ptr != nullptr)
  768. {
  769. name = bridge.client_rename_ptr(client->kClient, name);
  770. }
  771. else
  772. {
  773. // we should not be able to do this, jack really needs to allow client rename
  774. needsReinit = true;
  775. if (jack_client_t* jclient = jackbridge_client_open(name, JackNullOption, nullptr))
  776. {
  777. const char* const iconName(plugin->iconName());
  778. jackbridge_custom_publish_data(jclient, URI_CANVAS_ICON, iconName, std::strlen(iconName)+1);
  779. // close old client
  780. plugin->setEnabled(false);
  781. if (client->isActive())
  782. client->deactivate();
  783. plugin->clearBuffers();
  784. jackbridge_client_close(client->kClient);
  785. // set new client data
  786. name = jackbridge_get_client_name(jclient);
  787. jackbridge_set_process_callback(jclient, carla_jack_process_callback_plugin, plugin);
  788. # if 0
  789. jackbridge_set_latency_callback(jclient, carla_jack_latency_callback_plugin, plugin);
  790. # endif
  791. // this is supposed to be constant...
  792. std::memcpy((jack_client_t**)&client->kClient, &jclient, sizeof(jack_client_t**));
  793. }
  794. }
  795. }
  796. if (name == nullptr)
  797. return nullptr;
  798. // Rename
  799. plugin->setName(name);
  800. if (needsReinit)
  801. {
  802. // reload plugin to recreate its ports
  803. const SaveState& saveState(plugin->getSaveState());
  804. plugin->reload();
  805. plugin->loadSaveState(saveState);
  806. }
  807. return name;
  808. }
  809. // -------------------------------------------------------------------
  810. // Patchbay
  811. bool patchbayConnect(int portA, int portB) override
  812. {
  813. CARLA_ASSERT(fClient != nullptr);
  814. if (fClient == nullptr)
  815. {
  816. setLastError("Invalid JACK client");
  817. return false;
  818. }
  819. char portNameA[STR_MAX+1];
  820. char portNameB[STR_MAX+1];
  821. getFullPortName(portA, portNameA);
  822. getFullPortName(portB, portNameB);
  823. if (! jackbridge_connect(fClient, portNameA, portNameB))
  824. {
  825. setLastError("JACK operation failed");
  826. return false;
  827. }
  828. return true;
  829. }
  830. bool patchbayDisconnect(int connectionId) override
  831. {
  832. CARLA_ASSERT(fClient != nullptr);
  833. if (fClient == nullptr)
  834. {
  835. setLastError("Invalid JACK client");
  836. return false;
  837. }
  838. foreach (const ConnectionToId& connectionToId, fUsedConnections)
  839. {
  840. if (connectionToId.id == connectionId)
  841. {
  842. char portNameOut[STR_MAX+1];
  843. char portNameIn[STR_MAX+1];
  844. getFullPortName(connectionToId.portOut, portNameOut);
  845. getFullPortName(connectionToId.portIn, portNameIn);
  846. if (! jackbridge_disconnect(fClient, portNameOut, portNameIn))
  847. {
  848. setLastError("JACK operation failed");
  849. return false;
  850. }
  851. return true;
  852. }
  853. }
  854. setLastError("Failed to find the requested connection");
  855. return false;
  856. }
  857. void patchbayRefresh() override
  858. {
  859. CARLA_ASSERT(fClient != nullptr);
  860. if (fClient == nullptr)
  861. return;
  862. fLastGroupId = 0;
  863. fLastPortId = 0;
  864. fLastConnectionId = 0;
  865. fUsedGroupNames.clear();
  866. fUsedPortNames.clear();
  867. fUsedConnections.clear();
  868. fGroupIconsChanged.clear();
  869. initJackPatchbay(jackbridge_get_client_name(fClient));
  870. }
  871. #endif
  872. // -------------------------------------------------------------------
  873. // Transport
  874. void transportPlay() override
  875. {
  876. if (fOptions.transportMode == TRANSPORT_MODE_INTERNAL)
  877. CarlaEngine::transportPlay();
  878. else if (fClient != nullptr)
  879. jackbridge_transport_start(fClient);
  880. }
  881. void transportPause() override
  882. {
  883. if (fOptions.transportMode == TRANSPORT_MODE_INTERNAL)
  884. CarlaEngine::transportPause();
  885. else if (fClient != nullptr)
  886. jackbridge_transport_stop(fClient);
  887. }
  888. void transportRelocate(const uint32_t frame) override
  889. {
  890. if (fOptions.transportMode == TRANSPORT_MODE_INTERNAL)
  891. CarlaEngine::transportRelocate(frame);
  892. else if (fClient != nullptr)
  893. jackbridge_transport_locate(fClient, frame);
  894. }
  895. // -------------------------------------
  896. protected:
  897. void handleCustomAppearanceCallback(const char* client_name, const char* key, jack_custom_change_t change)
  898. {
  899. if ((change == JackCustomAdded || change == JackCustomReplaced) && std::strcmp(key, URI_CANVAS_ICON) == 0)
  900. {
  901. const int groupId (getGroupId(client_name));
  902. if (groupId == -1)
  903. return;
  904. fGroupIconsChanged.append(groupId);
  905. }
  906. }
  907. void handleJackBufferSizeCallback(const uint32_t newBufferSize)
  908. {
  909. if (fBufferSize == newBufferSize)
  910. return;
  911. fBufferSize = newBufferSize;
  912. bufferSizeChanged(newBufferSize);
  913. }
  914. void handleJackSampleRateCallback(const double newSampleRate)
  915. {
  916. if (fSampleRate == newSampleRate)
  917. return;
  918. fSampleRate = newSampleRate;
  919. sampleRateChanged(newSampleRate);
  920. }
  921. void handleJackFreewheelCallback(const bool isFreewheel)
  922. {
  923. fFreewheel = isFreewheel;
  924. }
  925. void saveTransportInfo()
  926. {
  927. if (fOptions.transportMode != TRANSPORT_MODE_JACK)
  928. return;
  929. fTransportPos.unique_1 = fTransportPos.unique_2 + 1; // invalidate
  930. fTransportState = jackbridge_transport_query(fClient, &fTransportPos);
  931. fTimeInfo.playing = (fTransportState == JackTransportRolling);
  932. if (fTransportPos.unique_1 == fTransportPos.unique_2)
  933. {
  934. fTimeInfo.frame = fTransportPos.frame;
  935. fTimeInfo.usecs = fTransportPos.usecs;
  936. if (fTransportPos.valid & JackPositionBBT)
  937. {
  938. fTimeInfo.valid = EngineTimeInfo::ValidBBT;
  939. fTimeInfo.bbt.bar = fTransportPos.bar;
  940. fTimeInfo.bbt.beat = fTransportPos.beat;
  941. fTimeInfo.bbt.tick = fTransportPos.tick;
  942. fTimeInfo.bbt.barStartTick = fTransportPos.bar_start_tick;
  943. fTimeInfo.bbt.beatsPerBar = fTransportPos.beats_per_bar;
  944. fTimeInfo.bbt.beatType = fTransportPos.beat_type;
  945. fTimeInfo.bbt.ticksPerBeat = fTransportPos.ticks_per_beat;
  946. fTimeInfo.bbt.beatsPerMinute = fTransportPos.beats_per_minute;
  947. }
  948. else
  949. fTimeInfo.valid = 0x0;
  950. }
  951. else
  952. {
  953. fTimeInfo.frame = 0;
  954. fTimeInfo.valid = 0x0;
  955. }
  956. }
  957. void handleJackProcessCallback(const uint32_t nframes)
  958. {
  959. saveTransportInfo();
  960. #ifndef BUILD_BRIDGE
  961. if (kData->curPluginCount == 0)
  962. {
  963. // pass-through
  964. if (fOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  965. {
  966. float* const audioIn1 = (float*)jackbridge_port_get_buffer(fRackPorts[kRackPortAudioIn1], nframes);
  967. float* const audioIn2 = (float*)jackbridge_port_get_buffer(fRackPorts[kRackPortAudioIn2], nframes);
  968. float* const audioOut1 = (float*)jackbridge_port_get_buffer(fRackPorts[kRackPortAudioOut1], nframes);
  969. float* const audioOut2 = (float*)jackbridge_port_get_buffer(fRackPorts[kRackPortAudioOut2], nframes);
  970. void* const eventOut = jackbridge_port_get_buffer(fRackPorts[kRackPortEventOut], nframes);
  971. CARLA_ASSERT(audioIn1 != nullptr);
  972. CARLA_ASSERT(audioIn2 != nullptr);
  973. CARLA_ASSERT(audioOut1 != nullptr);
  974. CARLA_ASSERT(audioOut2 != nullptr);
  975. CARLA_ASSERT(eventOut != nullptr);
  976. carla_copyFloat(audioOut1, audioIn1, nframes);
  977. carla_copyFloat(audioOut2, audioIn2, nframes);
  978. jackbridge_midi_clear_buffer(eventOut);
  979. }
  980. return proccessPendingEvents();
  981. }
  982. #endif
  983. #ifdef BUILD_BRIDGE
  984. CarlaPlugin* const plugin(getPluginUnchecked(0));
  985. if (plugin != nullptr && plugin->enabled() && plugin->tryLock())
  986. {
  987. plugin->initBuffers();
  988. processPlugin(plugin, nframes);
  989. plugin->unlock();
  990. }
  991. #else
  992. if (fOptions.processMode == PROCESS_MODE_SINGLE_CLIENT)
  993. {
  994. for (unsigned int i=0; i < kData->curPluginCount; ++i)
  995. {
  996. CarlaPlugin* const plugin(getPluginUnchecked(i));
  997. if (plugin != nullptr && plugin->enabled() && plugin->tryLock())
  998. {
  999. plugin->initBuffers();
  1000. processPlugin(plugin, nframes);
  1001. plugin->unlock();
  1002. }
  1003. }
  1004. }
  1005. else if (fOptions.processMode == PROCESS_MODE_CONTINUOUS_RACK)
  1006. {
  1007. // get buffers from jack
  1008. float* const audioIn1 = (float*)jackbridge_port_get_buffer(fRackPorts[kRackPortAudioIn1], nframes);
  1009. float* const audioIn2 = (float*)jackbridge_port_get_buffer(fRackPorts[kRackPortAudioIn2], nframes);
  1010. float* const audioOut1 = (float*)jackbridge_port_get_buffer(fRackPorts[kRackPortAudioOut1], nframes);
  1011. float* const audioOut2 = (float*)jackbridge_port_get_buffer(fRackPorts[kRackPortAudioOut2], nframes);
  1012. void* const eventIn = jackbridge_port_get_buffer(fRackPorts[kRackPortEventIn], nframes);
  1013. void* const eventOut = jackbridge_port_get_buffer(fRackPorts[kRackPortEventOut], nframes);
  1014. // assert buffers
  1015. CARLA_ASSERT(audioIn1 != nullptr);
  1016. CARLA_ASSERT(audioIn2 != nullptr);
  1017. CARLA_ASSERT(audioOut1 != nullptr);
  1018. CARLA_ASSERT(audioOut2 != nullptr);
  1019. CARLA_ASSERT(eventIn != nullptr);
  1020. CARLA_ASSERT(eventOut != nullptr);
  1021. // create audio buffers
  1022. float* inBuf[2] = { audioIn1, audioIn2 };
  1023. float* outBuf[2] = { audioOut1, audioOut2 };
  1024. // initialize input events
  1025. carla_zeroStruct<EngineEvent>(kData->bufEvents.in, INTERNAL_EVENT_COUNT);
  1026. {
  1027. uint32_t engineEventIndex = 0;
  1028. jack_midi_event_t jackEvent;
  1029. const uint32_t jackEventCount(jackbridge_midi_get_event_count(eventIn));
  1030. for (uint32_t jackEventIndex=0; jackEventIndex < jackEventCount; ++jackEventIndex)
  1031. {
  1032. if (jackbridge_midi_event_get(&jackEvent, eventIn, jackEventIndex) != 0)
  1033. continue;
  1034. EngineEvent* const engineEvent(&kData->bufEvents.in[engineEventIndex++]);
  1035. engineEvent->clear();
  1036. const uint8_t midiStatus = MIDI_GET_STATUS_FROM_DATA(jackEvent.buffer);
  1037. const uint8_t midiChannel = MIDI_GET_CHANNEL_FROM_DATA(jackEvent.buffer);
  1038. engineEvent->time = jackEvent.time;
  1039. engineEvent->channel = midiChannel;
  1040. if (MIDI_IS_STATUS_CONTROL_CHANGE(midiStatus))
  1041. {
  1042. const uint8_t midiControl = jackEvent.buffer[1];
  1043. engineEvent->type = kEngineEventTypeControl;
  1044. if (MIDI_IS_CONTROL_BANK_SELECT(midiControl))
  1045. {
  1046. const uint8_t midiBank = jackEvent.buffer[2];
  1047. engineEvent->ctrl.type = kEngineControlEventTypeMidiBank;
  1048. engineEvent->ctrl.param = midiBank;
  1049. engineEvent->ctrl.value = 0.0f;
  1050. }
  1051. else if (midiControl == MIDI_CONTROL_ALL_SOUND_OFF)
  1052. {
  1053. engineEvent->ctrl.type = kEngineControlEventTypeAllSoundOff;
  1054. engineEvent->ctrl.param = 0;
  1055. engineEvent->ctrl.value = 0.0f;
  1056. }
  1057. else if (midiControl == MIDI_CONTROL_ALL_NOTES_OFF)
  1058. {
  1059. engineEvent->ctrl.type = kEngineControlEventTypeAllNotesOff;
  1060. engineEvent->ctrl.param = 0;
  1061. engineEvent->ctrl.value = 0.0f;
  1062. }
  1063. else
  1064. {
  1065. const uint8_t midiValue = jackEvent.buffer[2];
  1066. engineEvent->ctrl.type = kEngineControlEventTypeParameter;
  1067. engineEvent->ctrl.param = midiControl;
  1068. engineEvent->ctrl.value = float(midiValue)/127.0f;
  1069. }
  1070. }
  1071. else if (MIDI_IS_STATUS_PROGRAM_CHANGE(midiStatus))
  1072. {
  1073. const uint8_t midiProgram = jackEvent.buffer[1];
  1074. engineEvent->type = kEngineEventTypeControl;
  1075. engineEvent->ctrl.type = kEngineControlEventTypeMidiProgram;
  1076. engineEvent->ctrl.param = midiProgram;
  1077. engineEvent->ctrl.value = 0.0f;
  1078. }
  1079. else if (jackEvent.size <= 4)
  1080. {
  1081. engineEvent->type = kEngineEventTypeMidi;
  1082. carla_copy<uint8_t>(engineEvent->midi.data, jackEvent.buffer, jackEvent.size);
  1083. engineEvent->midi.data[0] = midiStatus;
  1084. engineEvent->midi.size = static_cast<uint8_t>(jackEvent.size);
  1085. }
  1086. if (engineEventIndex >= INTERNAL_EVENT_COUNT)
  1087. break;
  1088. }
  1089. }
  1090. // process rack
  1091. processRack(inBuf, outBuf, nframes);
  1092. // output control
  1093. {
  1094. jackbridge_midi_clear_buffer(eventOut);
  1095. for (unsigned short i=0; i < INTERNAL_EVENT_COUNT; ++i)
  1096. {
  1097. EngineEvent* const engineEvent = &kData->bufEvents.out[i];
  1098. uint8_t data[3] = { 0 };
  1099. uint8_t size = 0;
  1100. switch (engineEvent->type)
  1101. {
  1102. case kEngineEventTypeNull:
  1103. break;
  1104. case kEngineEventTypeControl:
  1105. {
  1106. EngineControlEvent* const ctrlEvent = &engineEvent->ctrl;
  1107. if (ctrlEvent->type == kEngineControlEventTypeParameter && MIDI_IS_CONTROL_BANK_SELECT(ctrlEvent->param))
  1108. {
  1109. // FIXME?
  1110. ctrlEvent->type = kEngineControlEventTypeMidiBank;
  1111. ctrlEvent->param = ctrlEvent->value;
  1112. ctrlEvent->value = 0.0f;
  1113. }
  1114. switch (ctrlEvent->type)
  1115. {
  1116. case kEngineControlEventTypeNull:
  1117. break;
  1118. case kEngineControlEventTypeParameter:
  1119. data[0] = MIDI_STATUS_CONTROL_CHANGE + engineEvent->channel;
  1120. data[1] = static_cast<uint8_t>(ctrlEvent->param);
  1121. data[2] = uint8_t(ctrlEvent->value * 127.0f);
  1122. size = 3;
  1123. break;
  1124. case kEngineControlEventTypeMidiBank:
  1125. data[0] = MIDI_STATUS_CONTROL_CHANGE + engineEvent->channel;
  1126. data[1] = MIDI_CONTROL_BANK_SELECT;
  1127. data[2] = static_cast<uint8_t>(ctrlEvent->param);
  1128. size = 3;
  1129. break;
  1130. case kEngineControlEventTypeMidiProgram:
  1131. data[0] = MIDI_STATUS_PROGRAM_CHANGE + engineEvent->channel;
  1132. data[1] = static_cast<uint8_t>(ctrlEvent->param);
  1133. size = 2;
  1134. break;
  1135. case kEngineControlEventTypeAllSoundOff:
  1136. data[0] = MIDI_STATUS_CONTROL_CHANGE + engineEvent->channel;
  1137. data[1] = MIDI_CONTROL_ALL_SOUND_OFF;
  1138. size = 2;
  1139. break;
  1140. case kEngineControlEventTypeAllNotesOff:
  1141. data[0] = MIDI_STATUS_CONTROL_CHANGE + engineEvent->channel;
  1142. data[1] = MIDI_CONTROL_ALL_NOTES_OFF;
  1143. size = 2;
  1144. break;
  1145. }
  1146. break;
  1147. }
  1148. case kEngineEventTypeMidi:
  1149. {
  1150. EngineMidiEvent* const midiEvent = &engineEvent->midi;
  1151. data[0] = midiEvent->data[0];
  1152. data[1] = midiEvent->data[1];
  1153. data[2] = midiEvent->data[2];
  1154. size = midiEvent->size;
  1155. break;
  1156. }
  1157. }
  1158. if (size > 0)
  1159. jackbridge_midi_event_write(eventOut, engineEvent->time, data, size);
  1160. }
  1161. }
  1162. }
  1163. #endif // ! BUILD_BRIDGE
  1164. proccessPendingEvents();
  1165. }
  1166. #if 0
  1167. void handleJackLatencyCallback(const jack_latency_callback_mode_t mode)
  1168. {
  1169. if (fOptions.processMode != PROCESS_MODE_SINGLE_CLIENT)
  1170. return;
  1171. for (unsigned int i=0; i < kData->curPluginCount; ++i)
  1172. {
  1173. CarlaPlugin* const plugin = getPluginUnchecked(i);
  1174. if (plugin && plugin->enabled())
  1175. latencyPlugin(plugin, mode);
  1176. }
  1177. }
  1178. #endif
  1179. #ifndef BUILD_BRIDGE
  1180. void handleJackClientRegistrationCallback(const char* name, bool reg)
  1181. {
  1182. // do nothing on client registration, wait for first port
  1183. if (reg) return;
  1184. const int id(getGroupId(name)); // also checks name nullness
  1185. if (id == -1)
  1186. return;
  1187. GroupNameToId groupNameId(id, name);
  1188. fUsedGroupNames.removeAll(groupNameId);
  1189. callback(CALLBACK_PATCHBAY_CLIENT_REMOVED, 0, id, 0, 0.0f, nullptr);
  1190. }
  1191. void handleJackPortRegistrationCallback(jack_port_id_t port, bool reg)
  1192. {
  1193. jack_port_t* const jackPort(jackbridge_port_by_id(fClient, port));
  1194. const char* const portName(jackbridge_port_short_name(jackPort));
  1195. const char* const fullPortName(jackbridge_port_name(jackPort));
  1196. CARLA_ASSERT(jackPort != nullptr);
  1197. CARLA_ASSERT(portName != nullptr);
  1198. CARLA_ASSERT(fullPortName != nullptr);
  1199. if (jackPort == nullptr)
  1200. return;
  1201. if (portName == nullptr)
  1202. return;
  1203. if (fullPortName == nullptr)
  1204. return;
  1205. const size_t groupNameSize(std::strstr(fullPortName, portName) - fullPortName - 1);
  1206. char groupName[groupNameSize+1];
  1207. carla_copy<char>(groupName, fullPortName, groupNameSize);
  1208. groupName[groupNameSize] = '\0';
  1209. int groupId = getGroupId(groupName);
  1210. if (reg)
  1211. {
  1212. const int jackPortFlags(jackbridge_port_flags(jackPort));
  1213. if (groupId == -1)
  1214. {
  1215. groupId = fLastGroupId++;
  1216. GroupNameToId groupNameToId(groupId, groupName);
  1217. fUsedGroupNames.append(groupNameToId);
  1218. callback(CALLBACK_PATCHBAY_CLIENT_ADDED, 0, groupId, PATCHBAY_ICON_APPLICATION, 0.0f, groupName);
  1219. fGroupIconsChanged.append(groupId);
  1220. }
  1221. bool portIsInput = (jackPortFlags & JackPortIsInput);
  1222. bool portIsAudio = (std::strcmp(jackbridge_port_type(jackPort), JACK_DEFAULT_AUDIO_TYPE) == 0);
  1223. bool portIsCV = (jackPortFlags & JackPortIsControlVoltage);
  1224. unsigned int canvasPortFlags = 0x0;
  1225. canvasPortFlags |= portIsInput ? PATCHBAY_PORT_IS_INPUT : PATCHBAY_PORT_IS_OUTPUT;
  1226. canvasPortFlags |= portIsAudio ? PATCHBAY_PORT_IS_AUDIO : PATCHBAY_PORT_IS_MIDI;
  1227. if (portIsAudio && portIsCV)
  1228. canvasPortFlags |= PATCHBAY_PORT_IS_CV;
  1229. PortNameToId portNameToId(groupId, fLastPortId++, portName, fullPortName);
  1230. fUsedPortNames.append(portNameToId);
  1231. callback(CALLBACK_PATCHBAY_PORT_ADDED, 0, groupId, portNameToId.portId, canvasPortFlags, portName);
  1232. }
  1233. else
  1234. {
  1235. const int portId(getPortId(fullPortName));
  1236. CARLA_ASSERT(groupId != -1);
  1237. CARLA_ASSERT(portId != -1);
  1238. if (groupId == -1 || portId == -1)
  1239. return;
  1240. PortNameToId portNameId(groupId, portId, portName, fullPortName);
  1241. fUsedPortNames.removeOne(portNameId);
  1242. callback(CALLBACK_PATCHBAY_PORT_REMOVED, 0, portId, 0, 0.0f, nullptr);
  1243. }
  1244. }
  1245. void handleJackPortConnectCallback(jack_port_id_t a, jack_port_id_t b, bool connect)
  1246. {
  1247. jack_port_t* const jackPortA(jackbridge_port_by_id(fClient, a));
  1248. jack_port_t* const jackPortB(jackbridge_port_by_id(fClient, b));
  1249. const char* const fullPortNameA(jackbridge_port_name(jackPortA));
  1250. const char* const fullPortNameB(jackbridge_port_name(jackPortB));
  1251. CARLA_ASSERT(jackPortA != nullptr);
  1252. CARLA_ASSERT(jackPortB != nullptr);
  1253. CARLA_ASSERT(fullPortNameA != nullptr);
  1254. CARLA_ASSERT(fullPortNameB != nullptr);
  1255. if (jackPortA == nullptr)
  1256. return;
  1257. if (jackPortB == nullptr)
  1258. return;
  1259. if (fullPortNameA == nullptr)
  1260. return;
  1261. if (fullPortNameB == nullptr)
  1262. return;
  1263. const int portIdA(getPortId(fullPortNameA));
  1264. const int portIdB(getPortId(fullPortNameB));
  1265. if (portIdA == -1 || portIdB == -1)
  1266. return;
  1267. if (connect)
  1268. {
  1269. ConnectionToId connectionToId(fLastConnectionId++, portIdA, portIdB);
  1270. fUsedConnections.append(connectionToId);
  1271. callback(CALLBACK_PATCHBAY_CONNECTION_ADDED, 0, connectionToId.id, portIdA, portIdB, nullptr);
  1272. }
  1273. else
  1274. {
  1275. for (int i=0, count=fUsedConnections.count(); i < count; ++i)
  1276. {
  1277. const ConnectionToId& connectionToId(fUsedConnections[i]);
  1278. if (connectionToId.portOut == portIdA && connectionToId.portIn == portIdB)
  1279. {
  1280. callback(CALLBACK_PATCHBAY_CONNECTION_REMOVED, 0, connectionToId.id, 0, 0.0f, nullptr);
  1281. fUsedConnections.takeAt(i);
  1282. break;
  1283. }
  1284. }
  1285. }
  1286. }
  1287. void handleJackPortRenameCallback(jack_port_id_t port, const char* oldName, const char* newName)
  1288. {
  1289. jack_port_t* const jackPort(jackbridge_port_by_id(fClient, port));
  1290. const char* const portName(jackbridge_port_short_name(jackPort));
  1291. CARLA_ASSERT(jackPort != nullptr);
  1292. CARLA_ASSERT(portName != nullptr);
  1293. if (jackPort == nullptr)
  1294. return;
  1295. if (portName == nullptr)
  1296. return;
  1297. const size_t groupNameSize(std::strstr(newName, portName) - newName - 1);
  1298. char groupName[groupNameSize+1];
  1299. carla_copy<char>(groupName, newName, groupNameSize);
  1300. groupName[groupNameSize] = '\0';
  1301. const int groupId(getGroupId(groupName));
  1302. CARLA_ASSERT(groupId != -1);
  1303. if (groupId == -1)
  1304. return;
  1305. for (int i=0, count=fUsedPortNames.count(); i < count; ++i)
  1306. {
  1307. PortNameToId& portNameId(fUsedPortNames[i]);
  1308. if (/*portNameId.groupId == groupId &&*/ std::strcmp(portNameId.fullName, oldName) == 0)
  1309. {
  1310. CARLA_ASSERT(portNameId.groupId == groupId);
  1311. portNameId.rename(portName, newName);
  1312. callback(CALLBACK_PATCHBAY_PORT_RENAMED, 0, portNameId.portId, 0, 0.0f, newName);
  1313. break;
  1314. }
  1315. }
  1316. }
  1317. #endif
  1318. void handleJackShutdownCallback()
  1319. {
  1320. for (unsigned int i=0; i < kData->curPluginCount; ++i)
  1321. {
  1322. //CarlaPlugin* const plugin = getPluginUnchecked(i);
  1323. //if (plugin)
  1324. // plugin->x_client = nullptr;
  1325. }
  1326. fClient = nullptr;
  1327. callback(CALLBACK_QUIT, 0, 0, 0, 0.0f, nullptr);
  1328. }
  1329. // -------------------------------------
  1330. private:
  1331. jack_client_t* fClient;
  1332. jack_position_t fTransportPos;
  1333. jack_transport_state_t fTransportState;
  1334. bool fFreewheel;
  1335. // -------------------------------------
  1336. #ifdef BUILD_BRIDGE
  1337. bool fHasQuit;
  1338. #else
  1339. enum RackPorts {
  1340. kRackPortAudioIn1 = 0,
  1341. kRackPortAudioIn2 = 1,
  1342. kRackPortAudioOut1 = 2,
  1343. kRackPortAudioOut2 = 3,
  1344. kRackPortEventIn = 4,
  1345. kRackPortEventOut = 5,
  1346. kRackPortCount = 6
  1347. };
  1348. jack_port_t* fRackPorts[kRackPortCount];
  1349. struct GroupNameToId {
  1350. int id;
  1351. char name[STR_MAX+1];
  1352. GroupNameToId()
  1353. {
  1354. id = -1;
  1355. name[0] = '\0';
  1356. }
  1357. GroupNameToId(const int id, const char name[])
  1358. {
  1359. this->id = id;
  1360. std::strncpy(this->name, name, STR_MAX);
  1361. this->name[STR_MAX] = '\0';
  1362. }
  1363. bool operator==(const GroupNameToId& groupNameId)
  1364. {
  1365. if (groupNameId.id != id)
  1366. return false;
  1367. if (std::strcmp(groupNameId.name, name) != 0)
  1368. return false;
  1369. return true;
  1370. }
  1371. };
  1372. struct PortNameToId {
  1373. int groupId;
  1374. int portId;
  1375. char name[STR_MAX+1];
  1376. char fullName[STR_MAX+1]; // unique
  1377. PortNameToId()
  1378. {
  1379. groupId = -1;
  1380. portId = -1;
  1381. name[0] = '\0';
  1382. fullName[0] = '\0';
  1383. }
  1384. PortNameToId(const int groupId, const int portId, const char name[], const char fullName[])
  1385. {
  1386. this->groupId = groupId;
  1387. this->portId = portId;
  1388. std::strncpy(this->name, name, STR_MAX);
  1389. this->name[STR_MAX] = '\0';
  1390. std::strncpy(this->fullName, fullName, STR_MAX);
  1391. this->fullName[STR_MAX] = '\0';
  1392. }
  1393. void rename(const char name[], const char fullName[])
  1394. {
  1395. std::strncpy(this->name, name, STR_MAX);
  1396. this->name[STR_MAX] = '\0';
  1397. std::strncpy(this->fullName, fullName, STR_MAX);
  1398. this->fullName[STR_MAX] = '\0';
  1399. }
  1400. bool operator==(const PortNameToId& portNameId)
  1401. {
  1402. if (portNameId.groupId != groupId)
  1403. return false;
  1404. if (portNameId.portId != portId)
  1405. return false;
  1406. if (std::strcmp(portNameId.name, name) != 0)
  1407. return false;
  1408. if (std::strcmp(portNameId.fullName, fullName) != 0)
  1409. return false;
  1410. return true;
  1411. }
  1412. };
  1413. struct ConnectionToId {
  1414. int id;
  1415. int portOut;
  1416. int portIn;
  1417. ConnectionToId()
  1418. {
  1419. id = -1;
  1420. portOut = -1;
  1421. portIn = -1;
  1422. }
  1423. ConnectionToId(const int id, const int portOut, const int portIn)
  1424. {
  1425. this->id = id;
  1426. this->portOut = portOut;
  1427. this->portIn = portIn;
  1428. }
  1429. bool operator==(const ConnectionToId& connectionId)
  1430. {
  1431. if (connectionId.id != id)
  1432. return false;
  1433. if (connectionId.portOut != portOut)
  1434. return false;
  1435. if (connectionId.portIn != portIn)
  1436. return false;
  1437. return true;
  1438. }
  1439. };
  1440. int fLastGroupId;
  1441. int fLastPortId;
  1442. int fLastConnectionId;
  1443. QList<GroupNameToId> fUsedGroupNames;
  1444. QList<PortNameToId> fUsedPortNames;
  1445. QList<ConnectionToId> fUsedConnections;
  1446. QList<int> fGroupIconsChanged;
  1447. int getGroupId(const char* const name)
  1448. {
  1449. CARLA_ASSERT(name != nullptr);
  1450. if (name == nullptr)
  1451. return -1;
  1452. foreach (const GroupNameToId& groupNameId, fUsedGroupNames)
  1453. {
  1454. if (std::strcmp(groupNameId.name, name) == 0)
  1455. return groupNameId.id;
  1456. }
  1457. return -1;
  1458. }
  1459. const char* getGroupName(const int groupId)
  1460. {
  1461. CARLA_ASSERT(groupId >= 0);
  1462. static const char fallback[1] = { '\0' };
  1463. if (groupId < 0)
  1464. return fallback;
  1465. foreach (const GroupNameToId& groupNameId, fUsedGroupNames)
  1466. {
  1467. if (groupNameId.id == groupId)
  1468. return groupNameId.name;
  1469. }
  1470. return fallback;
  1471. }
  1472. int getPortId(const char* const fullName)
  1473. {
  1474. CARLA_ASSERT(fullName != nullptr);
  1475. if (fullName == nullptr)
  1476. return -1;
  1477. foreach (const PortNameToId& portNameId, fUsedPortNames)
  1478. {
  1479. if (std::strcmp(portNameId.fullName, fullName) == 0)
  1480. return portNameId.portId;
  1481. }
  1482. return -1;
  1483. }
  1484. void getFullPortName(const int portId, char nameBuf[STR_MAX+1])
  1485. {
  1486. foreach (const PortNameToId& portNameId, fUsedPortNames)
  1487. {
  1488. if (portNameId.portId == portId)
  1489. {
  1490. std::strncpy(nameBuf, portNameId.fullName, STR_MAX);
  1491. nameBuf[STR_MAX] = '\0';
  1492. return;
  1493. }
  1494. }
  1495. nameBuf[0] = '\0';
  1496. }
  1497. void initJackPatchbay(const char* const ourName)
  1498. {
  1499. CARLA_ASSERT(fLastGroupId == 0);
  1500. CARLA_ASSERT(fLastPortId == 0);
  1501. CARLA_ASSERT(fLastConnectionId == 0);
  1502. CARLA_ASSERT(ourName != nullptr);
  1503. // query initial jack ports
  1504. QStringList parsedGroups;
  1505. // our client
  1506. if (ourName != nullptr)
  1507. {
  1508. parsedGroups.append(QString(ourName));
  1509. GroupNameToId groupNameToId(fLastGroupId++, ourName);
  1510. fUsedGroupNames.append(groupNameToId);
  1511. callback(CALLBACK_PATCHBAY_CLIENT_ADDED, 0, groupNameToId.id, PATCHBAY_ICON_CARLA, 0.0f, ourName);
  1512. }
  1513. if (const char** ports = jackbridge_get_ports(fClient, nullptr, nullptr, 0))
  1514. {
  1515. for (int i=0; ports[i] != nullptr; ++i)
  1516. {
  1517. jack_port_t* const jackPort(jackbridge_port_by_name(fClient, ports[i]));
  1518. const char* const portName(jackbridge_port_short_name(jackPort));
  1519. const char* const fullPortName(ports[i]);
  1520. CARLA_ASSERT(jackPort != nullptr);
  1521. CARLA_ASSERT(portName != nullptr);
  1522. if (jackPort == nullptr)
  1523. continue;
  1524. if (portName == nullptr)
  1525. continue;
  1526. const int jackPortFlags(jackbridge_port_flags(jackPort));
  1527. const size_t groupNameSize(std::strstr(fullPortName, portName) - fullPortName - 1);
  1528. char groupName[groupNameSize+1];
  1529. int groupId = -1;
  1530. carla_copy<char>(groupName, fullPortName, groupNameSize);
  1531. groupName[groupNameSize] = '\0';
  1532. if (parsedGroups.contains(QString(groupName)))
  1533. {
  1534. groupId = getGroupId(groupName);
  1535. CARLA_ASSERT(groupId != -1);
  1536. }
  1537. else
  1538. {
  1539. groupId = fLastGroupId++;
  1540. parsedGroups.append(groupName);
  1541. GroupNameToId groupNameToId(groupId, groupName);
  1542. fUsedGroupNames.append(groupNameToId);
  1543. PatchbayIconType groupIcon = PATCHBAY_ICON_APPLICATION;
  1544. void* data = nullptr;
  1545. size_t dataSize = 0;
  1546. if (jackbridge_custom_get_data(fClient, groupName, URI_CANVAS_ICON, &data, &dataSize) && data != nullptr && dataSize != 0)
  1547. {
  1548. const char* const icon((const char*)data);
  1549. CARLA_ASSERT(std::strlen(icon)+1 == dataSize);
  1550. if (std::strcmp(icon, "app") == 0 || std::strcmp(icon, "application") == 0)
  1551. groupIcon = PATCHBAY_ICON_APPLICATION;
  1552. else if (std::strcmp(icon, "hardware") == 0)
  1553. groupIcon = PATCHBAY_ICON_HARDWARE;
  1554. else if (std::strcmp(icon, "carla") == 0)
  1555. groupIcon = PATCHBAY_ICON_CARLA;
  1556. else if (std::strcmp(icon, "distrho") == 0)
  1557. groupIcon = PATCHBAY_ICON_DISTRHO;
  1558. else if (std::strcmp(icon, "file") == 0)
  1559. groupIcon = PATCHBAY_ICON_FILE;
  1560. else if (std::strcmp(icon, "plugin") == 0)
  1561. groupIcon = PATCHBAY_ICON_PLUGIN;
  1562. }
  1563. else if (jackPortFlags & JackPortIsPhysical)
  1564. groupIcon = PATCHBAY_ICON_HARDWARE;
  1565. callback(CALLBACK_PATCHBAY_CLIENT_ADDED, 0, groupId, groupIcon, 0.0f, groupName);
  1566. }
  1567. bool portIsInput = (jackPortFlags & JackPortIsInput);
  1568. bool portIsAudio = (std::strcmp(jackbridge_port_type(jackPort), JACK_DEFAULT_AUDIO_TYPE) == 0);
  1569. bool portIsCV = (jackPortFlags & JackPortIsControlVoltage);
  1570. unsigned int canvasPortFlags = 0x0;
  1571. canvasPortFlags |= portIsInput ? PATCHBAY_PORT_IS_INPUT : PATCHBAY_PORT_IS_OUTPUT;
  1572. canvasPortFlags |= portIsAudio ? PATCHBAY_PORT_IS_AUDIO : PATCHBAY_PORT_IS_MIDI;
  1573. if (portIsAudio && portIsCV)
  1574. canvasPortFlags |= PATCHBAY_PORT_IS_CV;
  1575. PortNameToId portNameToId(groupId, fLastPortId++, portName, fullPortName);
  1576. fUsedPortNames.append(portNameToId);
  1577. callback(CALLBACK_PATCHBAY_PORT_ADDED, 0, groupId, portNameToId.portId, canvasPortFlags, portName);
  1578. }
  1579. jackbridge_free(ports);
  1580. }
  1581. // query connections, after all ports are in place
  1582. if (const char** ports = jackbridge_get_ports(fClient, nullptr, nullptr, JackPortIsOutput))
  1583. {
  1584. for (int i=0; ports[i] != nullptr; ++i)
  1585. {
  1586. jack_port_t* const jackPort(jackbridge_port_by_name(fClient, ports[i]));
  1587. const char* const fullPortName(ports[i]);
  1588. CARLA_ASSERT(jackPort != nullptr);
  1589. if (jackPort == nullptr)
  1590. continue;
  1591. const int thisPortId(getPortId(fullPortName));
  1592. if (thisPortId == -1)
  1593. continue;
  1594. if (const char** connections = jackbridge_port_get_connections(jackPort))
  1595. {
  1596. for (int j=0; connections[j] != nullptr; ++j)
  1597. {
  1598. const int targetPortId(getPortId(connections[j]));
  1599. ConnectionToId connectionToId(fLastConnectionId++, thisPortId, targetPortId);
  1600. fUsedConnections.append(connectionToId);
  1601. callback(CALLBACK_PATCHBAY_CONNECTION_ADDED, 0, connectionToId.id, thisPortId, targetPortId, nullptr);
  1602. }
  1603. jackbridge_free(connections);
  1604. }
  1605. }
  1606. jackbridge_free(ports);
  1607. }
  1608. }
  1609. #endif
  1610. // -------------------------------------
  1611. void processPlugin(CarlaPlugin* const plugin, const uint32_t nframes)
  1612. {
  1613. const uint32_t inCount(plugin->audioInCount());
  1614. const uint32_t outCount(plugin->audioOutCount());
  1615. float* inBuffer[inCount];
  1616. float* outBuffer[outCount];
  1617. float inPeaks[2] = { 0.0f };
  1618. float outPeaks[2] = { 0.0f };
  1619. for (uint32_t i=0; i < inCount; ++i)
  1620. {
  1621. CarlaEngineAudioPort* const port(CarlaPluginGetAudioInPort(plugin, i));
  1622. inBuffer[i] = port->getBuffer();
  1623. }
  1624. for (uint32_t i=0; i < outCount; ++i)
  1625. {
  1626. CarlaEngineAudioPort* const port(CarlaPluginGetAudioOutPort(plugin, i));
  1627. outBuffer[i] = port->getBuffer();
  1628. }
  1629. for (uint32_t i=0; i < inCount && i < 2; ++i)
  1630. {
  1631. for (uint32_t j=0; j < nframes; ++j)
  1632. {
  1633. const float absV(std::abs(inBuffer[i][j]));
  1634. if (absV > inPeaks[i])
  1635. inPeaks[i] = absV;
  1636. }
  1637. }
  1638. plugin->process(inBuffer, outBuffer, nframes);
  1639. for (uint32_t i=0; i < outCount && i < 2; ++i)
  1640. {
  1641. for (uint32_t j=0; j < nframes; ++j)
  1642. {
  1643. const float absV(std::abs(outBuffer[i][j]));
  1644. if (absV > outPeaks[i])
  1645. outPeaks[i] = absV;
  1646. }
  1647. }
  1648. setPeaks(plugin->id(), inPeaks, outPeaks);
  1649. }
  1650. #if 0
  1651. void latencyPlugin(CarlaPlugin* const plugin, jack_latency_callback_mode_t mode)
  1652. {
  1653. const uint32_t inCount = plugin->audioInCount();
  1654. const uint32_t outCount = plugin->audioOutCount();
  1655. jack_latency_range_t range;
  1656. uint32_t pluginLatency = plugin->latency();
  1657. if (pluginLatency == 0)
  1658. return;
  1659. if (mode == JackCaptureLatency)
  1660. {
  1661. for (uint32_t i=0; i < inCount; ++i)
  1662. {
  1663. uint32_t aOutI = (i >= outCount) ? outCount : i;
  1664. jack_port_t* const portIn = ((CarlaEngineJackAudioPort*)CarlaPluginGetAudioInPort(plugin, i))->kPort;
  1665. jack_port_t* const portOut = ((CarlaEngineJackAudioPort*)CarlaPluginGetAudioOutPort(plugin, aOutI))->kPort;
  1666. jackbridge_port_get_latency_range(portIn, mode, &range);
  1667. range.min += pluginLatency;
  1668. range.max += pluginLatency;
  1669. jackbridge_port_set_latency_range(portOut, mode, &range);
  1670. }
  1671. }
  1672. else
  1673. {
  1674. for (uint32_t i=0; i < outCount; ++i)
  1675. {
  1676. uint32_t aInI = (i >= inCount) ? inCount : i;
  1677. jack_port_t* const portIn = ((CarlaEngineJackAudioPort*)CarlaPluginGetAudioInPort(plugin, aInI))->kPort;
  1678. jack_port_t* const portOut = ((CarlaEngineJackAudioPort*)CarlaPluginGetAudioOutPort(plugin, i))->kPort;
  1679. jackbridge_port_get_latency_range(portOut, mode, &range);
  1680. range.min += pluginLatency;
  1681. range.max += pluginLatency;
  1682. jackbridge_port_set_latency_range(portIn, mode, &range);
  1683. }
  1684. }
  1685. }
  1686. #endif
  1687. // -------------------------------------
  1688. #define handlePtr ((CarlaEngineJack*)arg)
  1689. static void carla_jack_custom_appearance_callback(const char* client_name, const char* key, jack_custom_change_t change, void* arg)
  1690. {
  1691. handlePtr->handleCustomAppearanceCallback(client_name, key, change);
  1692. }
  1693. static int carla_jack_bufsize_callback(jack_nframes_t newBufferSize, void* arg)
  1694. {
  1695. handlePtr->handleJackBufferSizeCallback(newBufferSize);
  1696. return 0;
  1697. }
  1698. static int carla_jack_srate_callback(jack_nframes_t newSampleRate, void* arg)
  1699. {
  1700. handlePtr->handleJackSampleRateCallback(newSampleRate);
  1701. return 0;
  1702. }
  1703. static void carla_jack_freewheel_callback(int starting, void* arg)
  1704. {
  1705. handlePtr->handleJackFreewheelCallback(bool(starting));
  1706. }
  1707. static int carla_jack_process_callback(jack_nframes_t nframes, void* arg)
  1708. {
  1709. handlePtr->handleJackProcessCallback(nframes);
  1710. return 0;
  1711. }
  1712. #if 0
  1713. static void carla_jack_latency_callback(jack_latency_callback_mode_t mode, void* arg)
  1714. {
  1715. handlePtr->handleJackLatencyCallback(mode);
  1716. }
  1717. #endif
  1718. #ifndef BUILD_BRIDGE
  1719. static void carla_jack_client_registration_callback(const char* name, int reg, void* arg)
  1720. {
  1721. handlePtr->handleJackClientRegistrationCallback(name, (reg != 0));
  1722. }
  1723. static void carla_jack_port_registration_callback(jack_port_id_t port, int reg, void* arg)
  1724. {
  1725. handlePtr->handleJackPortRegistrationCallback(port, (reg != 0));
  1726. }
  1727. static void carla_jack_port_connect_callback(jack_port_id_t a, jack_port_id_t b, int connect, void* arg)
  1728. {
  1729. handlePtr->handleJackPortConnectCallback(a, b, (connect != 0));
  1730. }
  1731. static int carla_jack_port_rename_callback(jack_port_id_t port, const char* oldName, const char* newName, void* arg)
  1732. {
  1733. handlePtr->handleJackPortRenameCallback(port, oldName, newName);
  1734. return 0;
  1735. }
  1736. #endif
  1737. static void carla_jack_shutdown_callback(void* arg)
  1738. {
  1739. handlePtr->handleJackShutdownCallback();
  1740. }
  1741. #undef handlePtr
  1742. // -------------------------------------
  1743. #ifndef BUILD_BRIDGE
  1744. static int carla_jack_process_callback_plugin(jack_nframes_t nframes, void* arg)
  1745. {
  1746. CarlaPlugin* const plugin = (CarlaPlugin*)arg;
  1747. if (plugin != nullptr && plugin->enabled() && plugin->tryLock())
  1748. {
  1749. CarlaEngineJack* const engine = (CarlaEngineJack*)CarlaPluginGetEngine(plugin);
  1750. plugin->initBuffers();
  1751. engine->saveTransportInfo();
  1752. engine->processPlugin(plugin, nframes);
  1753. plugin->unlock();
  1754. }
  1755. else
  1756. carla_stdout("Plugin not enabled or locked");
  1757. return 0;
  1758. }
  1759. # if 0
  1760. static void carla_jack_latency_callback_plugin(jack_latency_callback_mode_t mode, void* arg)
  1761. {
  1762. CarlaPlugin* const plugin = (CarlaPlugin*)arg;
  1763. if (plugin != nullptr && plugin->enabled())
  1764. {
  1765. CarlaEngineJack* const engine = (CarlaEngineJack*)CarlaPluginGetEngine(plugin);
  1766. engine->latencyPlugin(plugin, mode);
  1767. }
  1768. }
  1769. # endif
  1770. #endif
  1771. CARLA_DECLARE_NON_COPYABLE_WITH_LEAK_DETECTOR(CarlaEngineJack)
  1772. };
  1773. // -----------------------------------------
  1774. CarlaEngine* CarlaEngine::newJack()
  1775. {
  1776. return new CarlaEngineJack();
  1777. }
  1778. // -----------------------------------------
  1779. CARLA_BACKEND_END_NAMESPACE