aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/jalv.c31
-rw-r--r--src/jalv_console.c2
-rw-r--r--src/jalv_gtk2.c2
-rw-r--r--src/jalv_internal.h7
-rw-r--r--src/state.c2
-rw-r--r--wscript6
6 files changed, 28 insertions, 22 deletions
diff --git a/src/jalv.c b/src/jalv.c
index 6ee017e..e4cb0f6 100644
--- a/src/jalv.c
+++ b/src/jalv.c
@@ -15,7 +15,7 @@
*/
#define _POSIX_C_SOURCE 200809L /* for mkdtemp */
-
+#define _DARWIN_C_SOURCE /* for mkdtemp on OSX */
#include <assert.h>
#include <math.h>
#include <signal.h>
@@ -53,7 +53,7 @@
#define NS_MIDI "http://lv2plug.in/ns/ext/midi#"
#define NS_PSET "http://lv2plug.in/ns/ext/presets#"
-sem_t exit_sem; /**< Exit semaphore */
+ZixSem exit_sem; /**< Exit semaphore */
LV2_URID
map_uri(LV2_URID_Map_Handle handle,
@@ -197,6 +197,7 @@ void
jalv_create_ports(Jalv* jalv)
{
jalv->num_ports = lilv_plugin_get_num_ports(jalv->plugin);
+ fprintf(stderr, "CREATE PORTS %d\n", jalv->num_ports);
jalv->ports = calloc((size_t)jalv->num_ports, sizeof(struct Port));
float* default_values = calloc(lilv_plugin_get_num_ports(jalv->plugin),
sizeof(float));
@@ -215,11 +216,14 @@ jalv_create_ports(Jalv* jalv)
void
jalv_allocate_port_buffers(Jalv* jalv)
{
+ fprintf(stderr, "ALLOCATE PORT BUFFERS %d\n", jalv->num_ports);
for (uint32_t i = 0; i < jalv->num_ports; ++i) {
struct Port* const port = &jalv->ports[i];
+ fprintf(stderr, "PORT %d TYPE %d\n", i, port->type);
switch (port->type) {
case TYPE_EVENT:
lv2_evbuf_free(port->evbuf);
+ fprintf(stderr, "ALLOCATE PORT BUFFERS %d\n", i);
port->evbuf = lv2_evbuf_new(
jalv->midi_buf_size,
port->old_api ? LV2_EVBUF_EVENT : LV2_EVBUF_ATOM);
@@ -322,7 +326,7 @@ jack_process_cb(jack_nframes_t nframes, void* data)
switch (host->play_state) {
case JALV_PAUSE_REQUESTED:
host->play_state = JALV_PAUSED;
- sem_post(&host->paused);
+ zix_sem_post(&host->paused);
break;
case JALV_PAUSED:
for (uint32_t p = 0; p < host->num_ports; ++p) {
@@ -467,7 +471,7 @@ jack_session_cb(jack_session_event_t* event, void* arg)
break;
case JackSessionSaveAndQuit:
jalv_save(host, event->session_dir);
- sem_post(&exit_sem);
+ zix_sem_post(&exit_sem);
break;
}
@@ -538,7 +542,7 @@ jalv_emit_ui_events(Jalv* host)
static void
signal_handler(int ignored)
{
- sem_post(&exit_sem);
+ zix_sem_post(&exit_sem);
}
int
@@ -587,10 +591,10 @@ main(int argc, char** argv)
host.ui_width = -1;
host.ui_height = -1;
- sem_init(&exit_sem, 0, 0);
+ zix_sem_init(&exit_sem, 0);
host.done = &exit_sem;
- sem_init(&host.paused, 0, 0);
+ zix_sem_init(&host.paused, 0);
signal(SIGINT, signal_handler);
signal(SIGTERM, signal_handler);
@@ -681,6 +685,9 @@ main(int argc, char** argv)
fprintf(stderr, "No appropriate UI found\n");
}
+ /* Create port structures (host.ports) */
+ jalv_create_ports(&host);
+
/* Get the plugin's name */
LilvNode* name = lilv_plugin_get_name(host.plugin);
const char* name_str = lilv_node_as_string(name);
@@ -726,16 +733,14 @@ main(int argc, char** argv)
/* Instantiate the plugin */
host.instance = lilv_plugin_instantiate(
host.plugin, jack_get_sample_rate(host.jack_client), features);
- if (!host.instance)
+ if (!host.instance) {
die("Failed to instantiate plugin.\n");
+ }
if (!host.buf_size_set) {
jalv_allocate_port_buffers(&host);
}
- /* Create port structures (host.ports) */
- jalv_create_ports(&host);
-
/* Apply loaded state to plugin instance if necessary */
if (state) {
jalv_apply_state(&host, state);
@@ -801,7 +806,7 @@ main(int argc, char** argv)
jalv_open_ui(&host, host.ui_instance);
/* Wait for finish signal from UI or signal handler */
- sem_wait(&exit_sem);
+ zix_sem_wait(&exit_sem);
fprintf(stderr, "Exiting...\n");
@@ -839,7 +844,7 @@ main(int argc, char** argv)
suil_host_free(ui_host);
lilv_world_free(world);
- sem_destroy(&exit_sem);
+ zix_sem_destroy(&exit_sem);
remove(host.temp_dir);
free(host.temp_dir);
diff --git a/src/jalv_console.c b/src/jalv_console.c
index 04d7c78..80be5cd 100644
--- a/src/jalv_console.c
+++ b/src/jalv_console.c
@@ -84,7 +84,7 @@ jalv_open_ui(Jalv* jalv,
printf("\nPress enter to quit: ");
fflush(stdout);
getc(stdin);
- sem_post(jalv->done);
+ zix_sem_post(jalv->done);
#endif
printf("\n");
diff --git a/src/jalv_gtk2.c b/src/jalv_gtk2.c
index 7c0fed7..fad7609 100644
--- a/src/jalv_gtk2.c
+++ b/src/jalv_gtk2.c
@@ -280,6 +280,6 @@ jalv_open_ui(Jalv* jalv,
gtk_widget_show_all(window);
gtk_main();
- sem_post(jalv->done);
+ zix_sem_post(jalv->done);
return 0;
}
diff --git a/src/jalv_internal.h b/src/jalv_internal.h
index 4dc4310..25da829 100644
--- a/src/jalv_internal.h
+++ b/src/jalv_internal.h
@@ -17,7 +17,6 @@
#ifndef JALV_INTERNAL_H
#define JALV_INTERNAL_H
-#include <semaphore.h>
#include <stdlib.h>
#include <string.h>
@@ -31,6 +30,8 @@
#include "lv2/lv2plug.in/ns/ext/urid/urid.h"
#include "lv2/lv2plug.in/ns/ext/state/state.h"
+#include "zix/sem.h"
+
#include "lv2_evbuf.h"
#include "symap.h"
@@ -97,8 +98,8 @@ typedef struct {
jack_client_t* jack_client; ///< Jack client
jack_ringbuffer_t* ui_events; ///< Port events from UI
jack_ringbuffer_t* plugin_events; ///< Port events from plugin
- sem_t* done; ///< Exit semaphore
- sem_t paused; ///< Paused signal from process thread
+ ZixSem* done; ///< Exit semaphore
+ ZixSem paused; ///< Paused signal from process thread
JalvPlayState play_state; ///< Current play state
char* temp_dir; ///< Temporary plugin state directory
char* save_dir; ///< Plugin save directory
diff --git a/src/state.c b/src/state.c
index 00c86a0..c052c9c 100644
--- a/src/state.c
+++ b/src/state.c
@@ -159,7 +159,7 @@ jalv_apply_state(Jalv* jalv, LilvState* state)
const bool must_pause = (jalv->play_state == JALV_RUNNING);
if (must_pause) {
jalv->play_state = JALV_PAUSE_REQUESTED;
- sem_wait(&jalv->paused);
+ zix_sem_wait(&jalv->paused);
}
lilv_state_restore(
diff --git a/wscript b/wscript
index af9934a..9006a43 100644
--- a/wscript
+++ b/wscript
@@ -85,7 +85,7 @@ def build(bld):
obj = bld(features = 'c cprogram',
source = source + ' src/jalv_console.c',
target = 'jalv',
- includes = ['.'],
+ includes = ['.', 'src'],
lib = ['pthread'],
install_path = '${BINDIR}')
autowaf.use_lib(bld, obj, libs)
@@ -95,7 +95,7 @@ def build(bld):
obj = bld(features = 'c cprogram',
source = source + ' src/jalv_gtk2.c',
target = 'jalv.gtk',
- includes = ['.'],
+ includes = ['.', 'src'],
lib = ['pthread'],
install_path = '${BINDIR}')
autowaf.use_lib(bld, obj, libs + ' GTK2')
@@ -105,7 +105,7 @@ def build(bld):
obj = bld(features = 'c cxx cxxprogram',
source = source + ' src/jalv_qt4.cpp',
target = 'jalv.qt',
- includes = ['.'],
+ includes = ['.', 'src'],
lib = ['pthread'],
install_path = '${BINDIR}')
autowaf.use_lib(bld, obj, libs + ' QT4')