X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fmidi%2B%2B2%2Fmidi%2B%2B%2Fjack.h;h=6d3e3341bc16f8d1ae3c6cf3d1447fbf2eb5d73a;hb=54bec37b5a72e1fae18be44c85f405f6bd99ee90;hp=c20b2693f134f212dd6ab02f9f8f792066fd9f19;hpb=2f4392f043fe174f798f0d2ca60dc37b2dd8ec7b;p=ardour.git diff --git a/libs/midi++2/midi++/jack.h b/libs/midi++2/midi++/jack.h index c20b2693f1..6d3e3341bc 100644 --- a/libs/midi++2/midi++/jack.h +++ b/libs/midi++2/midi++/jack.h @@ -28,9 +28,13 @@ #include #include +#include + +#include #include #include #include +#include namespace MIDI { @@ -39,26 +43,45 @@ namespace MIDI class JACK_MidiPort : public Port { public: - JACK_MidiPort (PortRequest &req, jack_client_t* jack_client); + JACK_MidiPort (const XMLNode& node, jack_client_t* jack_client); virtual ~JACK_MidiPort (); + int write(byte *msg, size_t msglen, timestamp_t timestamp); + int read(byte *buf, size_t max); + /* No select(2)/poll(2)-based I/O */ virtual int selectable() const { return -1; } virtual void cycle_start(nframes_t nframes); -protected: - /* Direct I/O */ - int write(byte *msg, size_t msglen, timestamp_t timestamp); - int read(byte *buf, size_t max, timestamp_t timestamp); + static std::string typestring; + + virtual XMLNode& get_state () const; + virtual void set_state (const XMLNode&); + + static void set_process_thread (pthread_t); + + protected: + std::string get_typestring () const { + return typestring; + } private: - int create_ports(PortRequest &req); + int create_ports(const XMLNode&); jack_client_t* _jack_client; jack_port_t* _jack_input_port; jack_port_t* _jack_output_port; nframes_t _last_read_index; + timestamp_t _last_write_timestamp; + + void flush (void* jack_port_buffer); + + static pthread_t _process_thread; + static bool is_process_thread(); + + RingBuffer non_process_thread_fifo; + Glib::Mutex non_process_thread_fifo_lock; };