]> git.alsa-project.org Git - alsa-tools.git/commitdiff
Changed codes to adapt for the latest control interface.
authorTakashi Iwai <tiwai@suse.de>
Wed, 6 Jun 2001 13:58:01 +0000 (13:58 +0000)
committerTakashi Iwai <tiwai@suse.de>
Wed, 6 Jun 2001 13:58:01 +0000 (13:58 +0000)
Seems working now..

envy24control/driverevents.c
envy24control/envy24control.c
envy24control/envy24control.h
envy24control/hardware.c
envy24control/levelmeters.c
envy24control/mixer.c
envy24control/patchbay.c

index 5016060d9d496cc13830f9914ef1cb395e4bceef..b41b4408544d93b4c2543fc9bc55765960a61dfd 100644 (file)
 
 #include "envy24control.h"
 
-static void control_value(snd_ctl_t *handle, void *private_data, snd_ctl_elem_id_t *id)
+void control_input_callback(gpointer data, gint source, GdkInputCondition condition)
 {
-       if (id->iface == SND_CTL_ELEM_IFACE_PCM) {
-               if (!strcmp(id->name, "Multi Track Route")) {
+       snd_ctl_t *ctl = (snd_ctl_t *)data;
+       snd_ctl_event_t *ev;
+       const char *name;
+       int index;
+
+       snd_ctl_event_alloca(&ev);
+       if (snd_ctl_read(ctl, ev) < 0)
+               return;
+       name = snd_ctl_event_elem_get_name(ev);
+       index = snd_ctl_event_elem_get_index(ev);
+       switch (snd_ctl_event_elem_get_interface(ev)) {
+       case SND_CTL_ELEM_IFACE_PCM:
+               if (!strcmp(name, "Multi Track Route"))
                        patchbay_update();
-                       return;
-               }
-               if (!strcmp(id->name, "Multi Track S/PDIF Master")) {
+               else if (!strcmp(name, "Multi Track S/PDIF Master"))
                        master_clock_update();
-                       return;
-               }
-               if (!strcmp(id->name, "Word Clock Sync")) {
+               else if (!strcmp(name, "Word Clock Sync"))
                        master_clock_update();
-                       return;
-               }
-               if (!strcmp(id->name, "Multi Track Volume Rate")) {
+               else if (!strcmp(name, "Multi Track Volume Rate"))
                        volume_change_rate_update();
-                       return;
-               }
-               if (!strcmp(id->name, "S/PDIF Input Optical")) {
+               else if (!strcmp(name, "S/PDIF Input Optical"))
                        spdif_input_update();
-                       return;
-               }
-               if (!strcmp(id->name, "Delta S/PDIF Output Defaults")) {
+               else if (!strcmp(name, "Delta S/PDIF Output Defaults"))
                        spdif_output_update();
-                       return;
-               }
-       }
-       if (id->iface == SND_CTL_ELEM_IFACE_MIXER) {
-               if (!strcmp(id->name, "Multi Playback Volume")) {
-                       mixer_update_stream(id->index + 1, 1, 0);
-                       return;
-               }
-               if (!strcmp(id->name, "Multi Capture Volume")) {
-                       mixer_update_stream(id->index + 11, 1, 0);
-                       return;
-               }       
-               if (!strcmp(id->name, "Multi Playback Switch")) {
-                       mixer_update_stream(id->index + 1, 0, 1);
-                       return;
-               }
-               if (!strcmp(id->name, "Multi Capture Switch")) {
-                       mixer_update_stream(id->index + 11, 0, 1);
-                       return;
-               }
+               break;
+       case SND_CTL_ELEM_IFACE_MIXER:
+               if (!strcmp(name, "Multi Playback Volume"))
+                       mixer_update_stream(index + 1, 1, 0);
+               else if (!strcmp(name, "Multi Capture Volume"))
+                       mixer_update_stream(index + 11, 1, 0);
+               else if (!strcmp(name, "Multi Playback Switch"))
+                       mixer_update_stream(index + 1, 0, 1);
+               else if (!strcmp(name, "Multi Capture Switch"))
+                       mixer_update_stream(index + 11, 0, 1);
+               break;
+       default:
+               break;
        }
 }
 
-static snd_ctl_callbacks_t control_callbacks = {
-       private_data: NULL,
-       rebuild: NULL,          /* FIXME!! */
-       value: control_value,
-       change: NULL,
-       add: NULL,
-       remove: NULL,
-       reserved: { NULL, }
-};
-
-void control_input_callback(gpointer data, gint source, GdkInputCondition condition)
-{
-       snd_ctl_read(card_ctl, &control_callbacks);
-}
index d0dbd779e4851d0c28c9e1d62562f4ac44d64142..f278908eebfac0be12a86aaf0fd18236e0c11ec3 100644 (file)
 ******************************************************************************/
 
 #include "envy24control.h"
+#define _GNU_SOURCE
+#include <getopt.h>
 
-int card = 0;
-snd_ctl_t *card_ctl = NULL;
-snd_ctl_card_info_t hw_info;
 ice1712_eeprom_t card_eeprom;
+snd_ctl_t *ctl;
 
 GtkWidget *window;
 
@@ -1023,64 +1023,65 @@ static void create_about(GtkWidget *main, GtkWidget *notebook, int page)
        gtk_widget_set_usize(label, 736, 16);
 }
 
+static void usage(void)
+{
+       fprintf(stderr, "usage: envy24control [-D control-name]\n");
+}
+
 int main(int argc, char **argv)
 {
         GtkWidget *notebook;
-        char name[32], title[128];
-       int err;
-       unsigned int cards_mask;
-       snd_ctl_elem_value_t ctl;
+        char *name, title[128];
+       int i, c, err;
+       //snd_ctl_t *ctl; // global
+       snd_ctl_card_info_t *hw_info;
+       snd_ctl_elem_value_t *val;
+       int npfds;
+       struct pollfd *pfds;
        // snd_mixer_filter_t filter;
+       static struct option long_options[] = {
+               {"device", 1, 0, 'D'},
+       };
+
+       snd_ctl_card_info_alloca(&hw_info);
+       snd_ctl_elem_value_alloca(&val);
 
        /* Go through gtk initialization */
         gtk_init(&argc, &argv);
 
-       card = snd_defaults_card();
-       cards_mask = snd_cards_mask();
-       
-       while (1) {
-               sprintf(name, "envy24control%d", card);
-               if ((err = snd_ctl_hw_open(&card_ctl, name, card)) < 0) {
-                       fprintf(stderr, "snd_ctl_open: %s\n", snd_strerror(err));
-                       exit(EXIT_FAILURE);
-               }
-               if ((err = snd_ctl_card_info(card_ctl, &hw_info)) < 0) {
-                       fprintf(stderr, "snd_ctl_card_info: %s\n", snd_strerror(err));
-                       exit(EXIT_FAILURE);
-               }
-               if (hw_info.type == SND_CARD_TYPE_ICE1712)
+       name = "hw:0";
+       while ((c = getopt_long(argc, argv, "D:", long_options, NULL)) != -1) {
+               switch (c) {
+               case 'D':
+                       name = optarg;
                        break;
-               snd_ctl_close(card_ctl);
-               card_ctl = NULL;
-               cards_mask &= ~(1 << card);
-               for (card = 0; card < 32; card++)
-                       if ((1 << card) & cards_mask)
-                               break;
-               if (card >= 32)
+               default:
+                       usage();
+                       exit(1);
                        break;
+               }
        }
-       if (card_ctl == NULL) {
-               fprintf(stderr, "Unable to find ICE1712 soundcard...\n");
+
+       if ((err = snd_ctl_open(&ctl, name, 0)) < 0) {
+               fprintf(stderr, "snd_ctl_open: %s\n", snd_strerror(err));
                exit(EXIT_FAILURE);
        }
-
-#if 0
-       memset(&filter, 0, sizeof(filter));
-       snd_mixer_set_bit(filter.read_cmds, SND_MIXER_READ_ELEM_VALUE, 1);
-       if ((err = snd_mixer_put_filter(card_mixer, &filter)) < 0) {
-               fprintf(stderr, "snd_mixer_set_filter: %s\n", snd_strerror(err));
+       if ((err = snd_ctl_card_info(ctl, hw_info)) < 0) {
+               fprintf(stderr, "snd_ctl_card_info: %s\n", snd_strerror(err));
+               exit(EXIT_FAILURE);
+       }
+       if (snd_ctl_card_info_get_type(hw_info) != SND_CARD_TYPE_ICE1712) {
+               fprintf(stderr, "invalid card type %d\n", snd_ctl_card_info_get_type(hw_info));
                exit(EXIT_FAILURE);
        }
-#endif
 
-       memset(&ctl, 0, sizeof(ctl));
-       ctl.id.iface = SND_CTL_ELEM_IFACE_CARD;
-       strcpy(ctl.id.name, "ICE1712 EEPROM");
-       if ((err = snd_ctl_elem_read(card_ctl, &ctl)) < 0) {
+       snd_ctl_elem_value_set_interface(val, SND_CTL_ELEM_IFACE_CARD);
+       snd_ctl_elem_value_set_name(val, "ICE1712 EEPROM");
+       if ((err = snd_ctl_elem_read(ctl, val)) < 0) {
                fprintf(stderr, "Unable to read EEPROM contents: %s\n", snd_strerror(err));
                exit(EXIT_FAILURE);
        }
-       memcpy(&card_eeprom, ctl.value.bytes.data, 32);
+       memcpy(&card_eeprom, snd_ctl_elem_value_get_bytes(val), 32);
 
        /* Initialize code */
        level_meters_init();
@@ -1088,7 +1089,7 @@ int main(int argc, char **argv)
        hardware_init();
 
         /* Make the title */
-        sprintf(title, "Envy24 Control Utility %s (%s)", VERSION, hw_info.longname);
+        sprintf(title, "Envy24 Control Utility %s (%s)", VERSION, snd_ctl_card_info_get_longname(hw_info));
 
         /* Create the main window */
         window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
@@ -1111,10 +1112,16 @@ int main(int argc, char **argv)
        create_hardware(window, notebook, 2);
        create_about(window, notebook, 3);
 
-       gdk_input_add(snd_ctl_poll_descriptor(card_ctl),
-                     GDK_INPUT_READ,
-                     control_input_callback,
-                     NULL);
+       npfds = snd_ctl_poll_descriptors_count(ctl);
+       if (npfds > 0) {
+               pfds = alloca(sizeof(*pfds) * npfds);
+               npfds = snd_ctl_poll_descriptors(ctl, pfds, npfds);
+               for (i = 0; i < npfds; i++)
+                       gdk_input_add(pfds[i].fd,
+                                     GDK_INPUT_READ,
+                                     control_input_callback,
+                                     ctl);
+       }
        gtk_timeout_add(40, level_meters_timeout_callback, NULL);
        gtk_timeout_add(100, master_clock_status_timeout_callback, NULL);
 
@@ -1126,7 +1133,7 @@ int main(int argc, char **argv)
        gtk_widget_show(window);
        gtk_main();
 
-       snd_ctl_close(card_ctl);
+       snd_ctl_close(ctl);
 
        return EXIT_SUCCESS;
 }
index 03c8b4971491d67866a13bdca69aa621c7ae3c54..6ba37979003d9310ca219e794397a3913d7c6d63 100644 (file)
@@ -31,7 +31,7 @@ typedef struct {
        unsigned char extra[4];
 } ice1712_eeprom_t;
 
-extern snd_ctl_t *card_ctl;
+extern snd_ctl_t *ctl;
 extern ice1712_eeprom_t card_eeprom;
 
 extern GtkWidget *mixer_mix_drawing;
index f1089399cf267cb5a6b971d06350b4f311b242e8..fd94746bb0781db4c0c49dd77d7278f39f5a847a 100644 (file)
 
 #include "envy24control.h"
 
-static snd_ctl_elem_value_t spdif_master;
-static snd_ctl_elem_value_t word_clock_sync;
-static snd_ctl_elem_value_t volume_rate;
-static snd_ctl_elem_value_t spdif_input;
-static snd_ctl_elem_value_t spdif_output;
+static snd_ctl_elem_value_t *spdif_master;
+static snd_ctl_elem_value_t *word_clock_sync;
+static snd_ctl_elem_value_t *volume_rate;
+static snd_ctl_elem_value_t *spdif_input;
+static snd_ctl_elem_value_t *spdif_output;
 
 #define toggle_set(widget, state) \
        gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(widget), state);
@@ -37,14 +37,14 @@ void master_clock_update(void)
 {
        int err;
        
-       if ((err = snd_ctl_elem_read(card_ctl, &spdif_master)) < 0)
+       if ((err = snd_ctl_elem_read(ctl, spdif_master)) < 0)
                g_print("Unable to read S/PDIF master state: %s\n", snd_strerror(err));
        if (card_eeprom.subvendor == ICE1712_SUBDEVICE_DELTA1010) {
-               if ((err = snd_ctl_elem_read(card_ctl, &word_clock_sync)) < 0)
+               if ((err = snd_ctl_elem_read(ctl, word_clock_sync)) < 0)
                        g_print("Unable to read word clock sync selection: %s\n", snd_strerror(err));
        }
-       if (spdif_master.value.integer.value[0]) {
-               if (word_clock_sync.value.integer.value[0]) {
+       if (snd_ctl_elem_value_get_boolean(spdif_master, 0)) {
+               if (snd_ctl_elem_value_get_boolean(word_clock_sync, 0)) {
                        toggle_set(hw_master_clock_word_radio, TRUE);
                } else {
                        toggle_set(hw_master_clock_spdif_radio, TRUE);
@@ -59,8 +59,8 @@ static void master_clock_spdif_master(int on)
 {
        int err;
 
-       spdif_master.value.integer.value[0] = on ? 1 : 0;
-       if ((err = snd_ctl_elem_write(card_ctl, &spdif_master)) < 0)
+       snd_ctl_elem_value_set_boolean(spdif_master, 0, on ? 1 : 0);
+       if ((err = snd_ctl_elem_write(ctl, spdif_master)) < 0)
                g_print("Unable to write S/PDIF master state: %s\n", snd_strerror(err));
 }
 
@@ -70,8 +70,8 @@ static void master_clock_word_select(int on)
 
        if (card_eeprom.subvendor != ICE1712_SUBDEVICE_DELTA1010)
                return;
-       word_clock_sync.value.integer.value[0] = on ? 1 : 0;
-       if ((err = snd_ctl_elem_write(card_ctl, &word_clock_sync)) < 0)
+       snd_ctl_elem_value_set_boolean(word_clock_sync, 0, on ? 1 : 0);
+       if ((err = snd_ctl_elem_write(ctl, word_clock_sync)) < 0)
                g_print("Unable to write word clock sync selection: %s\n", snd_strerror(err));
 }
 
@@ -96,18 +96,18 @@ void master_clock_toggled(GtkWidget *togglebutton, gpointer data)
 
 gint master_clock_status_timeout_callback(gpointer data)
 {
-       snd_ctl_elem_value_t sw;
+       snd_ctl_elem_value_t *sw;
        int err;
        
        if (card_eeprom.subvendor != ICE1712_SUBDEVICE_DELTA1010)
                return FALSE;
-       memset(&sw, 0, sizeof(sw));
-       sw.id.iface = SND_CTL_ELEM_IFACE_PCM;
-       strcpy(sw.id.name, "Word Clock Status");
-       if ((err = snd_ctl_elem_read(card_ctl, &sw)) < 0)
+       snd_ctl_elem_value_alloca(&sw);
+       snd_ctl_elem_value_set_interface(sw, SND_CTL_ELEM_IFACE_PCM);
+       snd_ctl_elem_value_set_name(sw, "Word Clock Status");
+       if ((err = snd_ctl_elem_read(ctl, sw)) < 0)
                g_print("Unable to determine word clock status: %s\n", snd_strerror(err));
        gtk_label_set_text(GTK_LABEL(hw_master_clock_status_label),
-                          sw.value.integer.value[0] ? "Locked" : "No signal");
+                          snd_ctl_elem_value_get_boolean(sw, 0) ? "Locked" : "No signal");
        return TRUE;
 }
 
@@ -115,17 +115,18 @@ void volume_change_rate_update(void)
 {
        int err;
        
-       if ((err = snd_ctl_elem_read(card_ctl, &volume_rate)) < 0)
+       if ((err = snd_ctl_elem_read(ctl, volume_rate)) < 0)
                g_print("Unable to read volume change rate: %s\n", snd_strerror(err));
-       gtk_adjustment_set_value(GTK_ADJUSTMENT(hw_volume_change_adj), volume_rate.value.integer.value[0]);
+       gtk_adjustment_set_value(GTK_ADJUSTMENT(hw_volume_change_adj),
+                                snd_ctl_elem_value_get_integer(volume_rate, 0));
 }
 
 void volume_change_rate_adj(GtkAdjustment *adj, gpointer data)
 {
        int err;
        
-       volume_rate.value.integer.value[0] = adj->value;
-       if ((err = snd_ctl_elem_write(card_ctl, &volume_rate)) < 0)
+       snd_ctl_elem_value_set_integer(volume_rate, 0, adj->value);
+       if ((err = snd_ctl_elem_write(ctl, volume_rate)) < 0)
                g_print("Unable to write volume change rate: %s\n", snd_strerror(err));
 }
 
@@ -135,9 +136,9 @@ void spdif_output_update(void)
        
        if (card_eeprom.subvendor == ICE1712_SUBDEVICE_DELTA44)
                return;
-       if ((err = snd_ctl_elem_read(card_ctl, &spdif_output)) < 0)
+       if ((err = snd_ctl_elem_read(ctl, spdif_output)) < 0)
                g_print("Unable to read Delta S/PDIF output state: %s\n", snd_strerror(err));
-       val = spdif_output.value.integer.value[0];
+       val = snd_ctl_elem_value_get_integer(spdif_output, 0);
        if (val & 1) {          /* consumer */
                toggle_set(hw_spdif_consumer_radio, TRUE);
                if (val & 8) {
@@ -186,14 +187,14 @@ static void spdif_output_write(void)
 {
        int err;
 
-       if ((err = snd_ctl_elem_write(card_ctl, &spdif_output)) < 0)
+       if ((err = snd_ctl_elem_write(ctl, spdif_output)) < 0)
                g_print("Unable to write Delta S/PDIF Output Defaults: %s\n", snd_strerror(err));
 }
 
 void profi_data_toggled(GtkWidget *togglebutton, gpointer data)
 {
        char *str = (char *)data;
-       int val = spdif_output.value.integer.value[0];
+       int val = snd_ctl_elem_value_get_integer(spdif_output, 0);
        
        if (!is_active(togglebutton))
                return;
@@ -204,14 +205,14 @@ void profi_data_toggled(GtkWidget *togglebutton, gpointer data)
        } else if (!strcmp(str, "Non-audio")) {
                val &= ~0x02;
        }
-       spdif_output.value.integer.value[0] = val;
+       snd_ctl_elem_value_set_integer(spdif_output, 0, val);
        spdif_output_write();
 }
 
 void profi_stream_toggled(GtkWidget *togglebutton, gpointer data)
 {
        char *str = (char *)data;
-       int val = spdif_output.value.integer.value[0];
+       int val = snd_ctl_elem_value_get_integer(spdif_output, 0);
        
        if (!is_active(togglebutton))
                return;
@@ -222,14 +223,14 @@ void profi_stream_toggled(GtkWidget *togglebutton, gpointer data)
        } else if (!strcmp(str, "Stereo")) {
                val &= ~0x80;
        }
-       spdif_output.value.integer.value[0] = val;
+       snd_ctl_elem_value_set_integer(spdif_output, 0, val);
        spdif_output_write();
 }
 
 void profi_emphasis_toggled(GtkWidget *togglebutton, gpointer data)
 {
        char *str = (char *)data;
-       int val = spdif_output.value.integer.value[0];
+       int val = snd_ctl_elem_value_get_integer(spdif_output, 0);
        
        if (!is_active(togglebutton))
                return;
@@ -246,14 +247,14 @@ void profi_emphasis_toggled(GtkWidget *togglebutton, gpointer data)
        } else if (!strcmp(str, "NOTID")) {
                val |= 0x60;
        }
-       spdif_output.value.integer.value[0] = val;
+       snd_ctl_elem_value_set_integer(spdif_output, 0, val);
        spdif_output_write();
 }
 
 void consumer_copyright_toggled(GtkWidget *togglebutton, gpointer data)
 {
        char *str = (char *)data;
-       int val = spdif_output.value.integer.value[0];
+       int val = snd_ctl_elem_value_get_integer(spdif_output, 0);
        
        if (!is_active(togglebutton))
                return;
@@ -264,14 +265,14 @@ void consumer_copyright_toggled(GtkWidget *togglebutton, gpointer data)
        } else if (!strcmp(str, "Permitted")) {
                val &= ~0x08;
        }
-       spdif_output.value.integer.value[0] = val;
+       snd_ctl_elem_value_set_integer(spdif_output, 0, val);
        spdif_output_write();
 }
 
 void consumer_copy_toggled(GtkWidget *togglebutton, gpointer data)
 {
        char *str = (char *)data;
-       int val = spdif_output.value.integer.value[0];
+       int val = snd_ctl_elem_value_get_integer(spdif_output, 0);
        
        if (!is_active(togglebutton))
                return;
@@ -282,14 +283,14 @@ void consumer_copy_toggled(GtkWidget *togglebutton, gpointer data)
        } else if (!strcmp(str, "Original")) {
                val &= ~0x80;
        }
-       spdif_output.value.integer.value[0] = val;
+       snd_ctl_elem_value_set_integer(spdif_output, 0, val);
        spdif_output_write();
 }
 
 void consumer_emphasis_toggled(GtkWidget *togglebutton, gpointer data)
 {
        char *str = (char *)data;
-       int val = spdif_output.value.integer.value[0];
+       int val = snd_ctl_elem_value_get_integer(spdif_output, 0);
        
        if (!is_active(togglebutton))
                return;
@@ -300,14 +301,14 @@ void consumer_emphasis_toggled(GtkWidget *togglebutton, gpointer data)
        } else if (!strcmp(str, "5015")) {
                val &= ~0x10;
        }
-       spdif_output.value.integer.value[0] = val;
+       snd_ctl_elem_value_set_integer(spdif_output, 0, val);
        spdif_output_write();
 }
 
 void consumer_category_toggled(GtkWidget *togglebutton, gpointer data)
 {
        char *str = (char *)data;
-       int val = spdif_output.value.integer.value[0];
+       int val = snd_ctl_elem_value_get_integer(spdif_output, 0);
        
        if (!is_active(togglebutton))
                return;
@@ -324,7 +325,7 @@ void consumer_category_toggled(GtkWidget *togglebutton, gpointer data)
        } else if (!strcmp(str, "General")) {
                val |= 0x60;
        }
-       spdif_output.value.integer.value[0] = val;
+       snd_ctl_elem_value_set_integer(spdif_output, 0, val);
        spdif_output_write();
 }
 
@@ -335,15 +336,15 @@ void spdif_output_toggled(GtkWidget *togglebutton, gpointer data)
 
        if (is_active(togglebutton)) {
                if (!strcmp(str, "Professional")) {
-                       if (spdif_output.value.integer.value[0] & 0x01) {
+                       if (snd_ctl_elem_value_get_integer(spdif_output, 0) & 0x01) {
                                /* default setup: audio, no emphasis */
-                               spdif_output.value.integer.value[0] = 0x22;
+                               snd_ctl_elem_value_set_integer(spdif_output, 0, 0x22);
                        }
                        page = 0;
                } else {
-                       if (!(spdif_output.value.integer.value[0] & 0x01)) {
+                       if (!(snd_ctl_elem_value_get_integer(spdif_output, 0) & 0x01)) {
                                /* default setup: no emphasis, PCM encoder */
-                               spdif_output.value.integer.value[0] = 0x31;
+                               snd_ctl_elem_value_set_integer(spdif_output, 0, 0x31);
                        }
                        page = 1;
                }
@@ -359,9 +360,9 @@ void spdif_input_update(void)
        
        if (card_eeprom.subvendor != ICE1712_SUBDEVICE_DELTADIO2496)
                return;
-       if ((err = snd_ctl_elem_read(card_ctl, &spdif_input)) < 0)
+       if ((err = snd_ctl_elem_read(ctl, spdif_input)) < 0)
                g_print("Unable to read S/PDIF input switch: %s\n", snd_strerror(err));
-       if (spdif_input.value.integer.value[0]) {
+       if (snd_ctl_elem_value_get_boolean(spdif_input, 0)) {
                toggle_set(hw_spdif_input_optical_radio, TRUE);
        } else {
                toggle_set(hw_spdif_input_coaxial_radio, TRUE);
@@ -376,34 +377,38 @@ void spdif_input_toggled(GtkWidget *togglebutton, gpointer data)
        if (!is_active(togglebutton))
                return;
        if (!strcmp(str, "Optical"))
-               spdif_input.value.integer.value[0] = 1;
+               snd_ctl_elem_value_set_boolean(spdif_input, 0, 1);
        else
-               spdif_input.value.integer.value[0] = 0;
-       if ((err = snd_ctl_elem_write(card_ctl, &spdif_input)) < 0)
+               snd_ctl_elem_value_set_boolean(spdif_input, 0, 0);
+       if ((err = snd_ctl_elem_write(ctl, spdif_input)) < 0)
                g_print("Unable to write S/PDIF input switch: %s\n", snd_strerror(err));
 }
 
 void hardware_init(void)
 {
-       memset(&spdif_master, 0, sizeof(spdif_master));
-       spdif_master.id.iface = SND_CTL_ELEM_IFACE_PCM;
-       strcpy(spdif_master.id.name, "Multi Track S/PDIF Master");
+       if (snd_ctl_elem_value_malloc(&spdif_master) < 0 ||
+           snd_ctl_elem_value_malloc(&word_clock_sync) < 0 ||
+           snd_ctl_elem_value_malloc(&volume_rate) < 0 ||
+           snd_ctl_elem_value_malloc(&spdif_input) < 0 ||
+           snd_ctl_elem_value_malloc(&spdif_output) < 0) {
+               g_print("Cannot allocate memory\n");
+               exit(1);
+       }
+
+       snd_ctl_elem_value_set_interface(spdif_master, SND_CTL_ELEM_IFACE_PCM);
+       snd_ctl_elem_value_set_name(spdif_master, "Multi Track IEC958 Master");
 
-       memset(&word_clock_sync, 0, sizeof(spdif_master));
-       word_clock_sync.id.iface = SND_CTL_ELEM_IFACE_PCM;
-       strcpy(word_clock_sync.id.name, "Word Clock Sync");
+       snd_ctl_elem_value_set_interface(word_clock_sync, SND_CTL_ELEM_IFACE_PCM);
+       snd_ctl_elem_value_set_name(word_clock_sync, "Word Clock Sync");
 
-       memset(&volume_rate, 0, sizeof(volume_rate));
-       spdif_master.id.iface = SND_CTL_ELEM_IFACE_PCM;
-       strcpy(volume_rate.id.name, "Multi Track Volume Rate");
+       snd_ctl_elem_value_set_interface(volume_rate, SND_CTL_ELEM_IFACE_PCM);
+       snd_ctl_elem_value_set_name(volume_rate, "Multi Track Volume Rate");
 
-       memset(&spdif_input, 0, sizeof(spdif_input));
-       spdif_master.id.iface = SND_CTL_ELEM_IFACE_PCM;
-       strcpy(spdif_input.id.name, "S/PDIF Input Optical");
+       snd_ctl_elem_value_set_interface(spdif_input, SND_CTL_ELEM_IFACE_PCM);
+       snd_ctl_elem_value_set_name(spdif_input, "IEC958 Input Optical");
 
-       memset(&spdif_output, 0, sizeof(spdif_output));
-       spdif_master.id.iface = SND_CTL_ELEM_IFACE_PCM;
-       strcpy(spdif_output.id.name, "Delta S/PDIF Output Defaults");
+       snd_ctl_elem_value_set_interface(spdif_output, SND_CTL_ELEM_IFACE_PCM);
+       snd_ctl_elem_value_set_name(spdif_output, "IEC958 Playback Default");
 }
 
 void hardware_postinit(void)
index e68ed711a6ff99819bb212f28ca4fe6f9ad46e5b..98a08c8eaf46f62fc01b7c4e98ecbac67aea3cc9 100644 (file)
@@ -26,16 +26,13 @@ static GdkGC *penOrangeLight[21] = { NULL, };
 static GdkGC *penRedShadow[21] = { NULL, };
 static GdkGC *penRedLight[21] = { NULL, };
 static GdkPixmap *pixmap[21] = { NULL, };
-static snd_ctl_elem_value_t peaks;
+static snd_ctl_elem_value_t *peaks;
 
 static void update_peak_switch(void)
 {
        int err;
 
-       memset(&peaks, 0, sizeof(peaks));
-       peaks.id.iface = SND_CTL_ELEM_IFACE_MIXER;
-       strcpy(peaks.id.name, "Multi Track Peak");
-       if ((err = snd_ctl_elem_read(card_ctl, &peaks)) < 0)
+       if ((err = snd_ctl_elem_read(ctl, peaks)) < 0)
                g_print("Unable to read peaks: %s\n", snd_strerror(err));
 }
 
@@ -44,10 +41,10 @@ static void get_levels(int idx, int *l1, int *l2)
        *l1 = *l2 = 0;
        
        if (idx == 0) {
-               *l1 = peaks.value.integer.value[4 + 20];
-               *l2 = peaks.value.integer.value[4 + 21];
+               *l1 = snd_ctl_elem_value_get_integer(peaks, 20);
+               *l2 = snd_ctl_elem_value_get_integer(peaks, 21);
        } else {
-               *l1 = *l2 = peaks.value.integer.value[4 + idx - 1];
+               *l1 = *l2 = snd_ctl_elem_value_get_integer(peaks, idx - 1);
        }
 }
 
@@ -220,7 +217,9 @@ void level_meters_reset_peaks(GtkButton *button, gpointer data)
 
 void level_meters_init(void)
 {
-       memset(&peaks, 0, sizeof(peaks));
+       snd_ctl_elem_value_malloc(&peaks);
+       snd_ctl_elem_value_set_interface(peaks, SND_CTL_ELEM_IFACE_MIXER);
+       snd_ctl_elem_value_set_name(peaks, "Multi Track Peak");
 }
 
 void level_meters_postinit(void)
index ad74039cb9160fcda3335349c774a9fa563feb76..9172ed39c6ac1c0837a75f16f0ab2bb728bf639d 100644 (file)
@@ -29,53 +29,60 @@ static int is_active(GtkWidget *widget)
 
 void mixer_update_stream(int stream, int vol_flag, int sw_flag)
 {
-       snd_ctl_elem_value_t vol, sw;
        int err;
        
        if (vol_flag) {
-               memset(&vol, 0, sizeof(vol));
-               vol.id.iface = SND_CTL_ELEM_IFACE_MIXER;
-               strcpy(vol.id.name, stream <= 10 ? "Multi Playback Volume" : "Multi Capture Volume");
-               vol.id.index = (stream - 1) % 10;
-               if ((err = snd_ctl_elem_read(card_ctl, &vol)) < 0)
+               snd_ctl_elem_value_t *vol;
+               int v[2];
+               snd_ctl_elem_value_alloca(&vol);
+               snd_ctl_elem_value_set_interface(vol, SND_CTL_ELEM_IFACE_MIXER);
+               snd_ctl_elem_value_set_name(vol, stream <= 10 ? "Multi Playback Volume" : "Multi Capture Volume");
+               snd_ctl_elem_value_set_index(vol, (stream - 1) % 10);
+               if ((err = snd_ctl_elem_read(ctl, vol)) < 0)
                        g_print("Unable to read multi playback volume: %s\n", snd_strerror(err));
-               gtk_adjustment_set_value(GTK_ADJUSTMENT(mixer_adj[stream-1][0]), 96 - vol.value.integer.value[0]);
-               gtk_adjustment_set_value(GTK_ADJUSTMENT(mixer_adj[stream-1][1]), 96 - vol.value.integer.value[1]);
-               if (vol.value.integer.value[0] != vol.value.integer.value[1])
+               v[0] = snd_ctl_elem_value_get_integer(vol, 0);
+               v[1] = snd_ctl_elem_value_get_integer(vol, 1);
+               gtk_adjustment_set_value(GTK_ADJUSTMENT(mixer_adj[stream-1][0]), 96 - v[0]);
+               gtk_adjustment_set_value(GTK_ADJUSTMENT(mixer_adj[stream-1][1]), 96 - v[1]);
+               if (v[0] != v[1])
                        toggle_set(mixer_stereo_toggle[stream-1], FALSE);
        }
        if (sw_flag) {
-               memset(&sw, 0, sizeof(sw));
-               sw.id.iface = SND_CTL_ELEM_IFACE_MIXER;
-               strcpy(sw.id.name, stream <= 10 ? "Multi Playback Switch" : "Multi Capture Switch");
-               sw.id.index = (stream - 1) % 10;
-               if ((err = snd_ctl_elem_read(card_ctl, &sw)) < 0)
+               snd_ctl_elem_value_t *sw;
+               int v[2];
+               snd_ctl_elem_value_alloca(&sw);
+               snd_ctl_elem_value_set_interface(sw, SND_CTL_ELEM_IFACE_MIXER);
+               snd_ctl_elem_value_set_name(sw, stream <= 10 ? "Multi Playback Switch" : "Multi Capture Switch");
+               snd_ctl_elem_value_set_index(sw, (stream - 1) % 10);
+               if ((err = snd_ctl_elem_read(ctl, sw)) < 0)
                        g_print("Unable to read multi playback switch: %s\n", snd_strerror(err));
-               toggle_set(mixer_solo_toggle[stream-1][0], sw.value.integer.value[0] ? TRUE : FALSE);
-               toggle_set(mixer_solo_toggle[stream-1][1], sw.value.integer.value[1] ? TRUE : FALSE);
-               toggle_set(mixer_mute_toggle[stream-1][0], !sw.value.integer.value[0] ? TRUE : FALSE);
-               toggle_set(mixer_mute_toggle[stream-1][1], !sw.value.integer.value[1] ? TRUE : FALSE);
-               if (sw.value.integer.value[0] != sw.value.integer.value[1])
+               v[0] = snd_ctl_elem_value_get_boolean(sw, 0);
+               v[1] = snd_ctl_elem_value_get_boolean(sw, 1);
+               toggle_set(mixer_solo_toggle[stream-1][0], v[0] ? TRUE : FALSE);
+               toggle_set(mixer_solo_toggle[stream-1][1], v[1] ? TRUE : FALSE);
+               toggle_set(mixer_mute_toggle[stream-1][0], !v[0] ? TRUE : FALSE);
+               toggle_set(mixer_mute_toggle[stream-1][1], !v[1] ? TRUE : FALSE);
+               if (v[0] != v[1])
                        toggle_set(mixer_stereo_toggle[stream-1], FALSE);
        }
 }
 
 static void set_switch1(int stream, int left, int right)
 {
-       snd_ctl_elem_value_t sw;
+       snd_ctl_elem_value_t *sw;
        int err;
        
-       memset(&sw, 0, sizeof(sw));
-       sw.id.iface = SND_CTL_ELEM_IFACE_MIXER;
-       strcpy(sw.id.name, stream <= 10 ? "Multi Playback Switch" : "Multi Capture Switch");
-       sw.id.index = (stream - 1) % 10;
-       if ((err = snd_ctl_elem_read(card_ctl, &sw)) < 0)
+       snd_ctl_elem_value_alloca(&sw);
+       snd_ctl_elem_value_set_interface(sw, SND_CTL_ELEM_IFACE_MIXER);
+       snd_ctl_elem_value_set_name(sw, stream <= 10 ? "Multi Playback Switch" : "Multi Capture Switch");
+       snd_ctl_elem_value_set_index(sw, (stream - 1) % 10);
+       if ((err = snd_ctl_elem_read(ctl, sw)) < 0)
                g_print("Unable to read multi switch: %s\n", snd_strerror(err));
        if (left >= 0)
-               sw.value.integer.value[0] = left != 0;
+               snd_ctl_elem_value_set_boolean(sw, 0, left != 0);
        if (right >= 0)
-               sw.value.integer.value[1] = right != 0;
-       if ((err = snd_ctl_elem_write(card_ctl, &sw)) < 0 && err != -EBUSY)
+               snd_ctl_elem_value_set_boolean(sw, 1, right != 0);
+       if ((err = snd_ctl_elem_write(ctl, sw)) < 0 && err != -EBUSY)
                g_print("Unable to write multi switch: %s\n", snd_strerror(err));
 }
 
@@ -147,20 +154,20 @@ void mixer_toggled_mute(GtkWidget *togglebutton, gpointer data)
 
 static void set_volume1(int stream, int left, int right)
 {
-       snd_ctl_elem_value_t vol;
+       snd_ctl_elem_value_t *vol;
        int err;
        
-       memset(&vol, 0, sizeof(vol));
-       vol.id.iface = SND_CTL_ELEM_IFACE_MIXER;
-       strcpy(vol.id.name, stream <= 10 ? "Multi Playback Volume" : "Multi Capture Volume");
-       vol.id.index = (stream - 1) % 10;
-       if ((err = snd_ctl_elem_read(card_ctl, &vol)) < 0)
+       snd_ctl_elem_value_alloca(&vol);
+       snd_ctl_elem_value_set_interface(vol, SND_CTL_ELEM_IFACE_MIXER);
+       snd_ctl_elem_value_set_name(vol, stream <= 10 ? "Multi Playback Volume" : "Multi Capture Volume");
+       snd_ctl_elem_value_set_index(vol, (stream - 1) % 10);
+       if ((err = snd_ctl_elem_read(ctl, vol)) < 0)
                g_print("Unable to read multi volume: %s\n", snd_strerror(err));
        if (left >= 0)
-               vol.value.integer.value[0] = left;
+               snd_ctl_elem_value_set_integer(vol, 0, left);
        if (right >= 0)
-               vol.value.integer.value[1] = right;
-       if ((err = snd_ctl_elem_write(card_ctl, &vol)) < 0 && err != -EBUSY)
+               snd_ctl_elem_value_set_integer(vol, 1, right);
+       if ((err = snd_ctl_elem_write(ctl, vol)) < 0 && err != -EBUSY)
                g_print("Unable to write multi volume: %s\n", snd_strerror(err));
 }
 
index f95ff94dfc8b2b5d055d9639b0e227c3277c331d..c91d8fa897ed2c9fb9d1dd87bbc248dccad021b6 100644 (file)
@@ -19,7 +19,7 @@
 
 #include "envy24control.h"
 
-static snd_ctl_elem_value_t routes;
+static snd_ctl_elem_value_t *routes;
 
 #define toggle_set(widget, state) \
        gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(widget), state);
@@ -31,14 +31,14 @@ static int is_active(GtkWidget *widget)
 
 static int get_toggle_index(int stream)
 {
-       unsigned short psdout = routes.value.bytes.data[0] |
-                               (routes.value.bytes.data[1] << 8);
-       unsigned short spdout = routes.value.bytes.data[2] |
-                               (routes.value.bytes.data[3] << 8);
-       unsigned int capture = routes.value.bytes.data[4] |
-                              (routes.value.bytes.data[5] << 8) |
-                              (routes.value.bytes.data[6] << 16) |
-                              (routes.value.bytes.data[7] << 24);
+       unsigned short psdout = snd_ctl_elem_value_get_byte(routes, 0) |
+                               (snd_ctl_elem_value_get_byte(routes, 1) << 8);
+       unsigned short spdout = snd_ctl_elem_value_get_byte(routes, 2) |
+                               (snd_ctl_elem_value_get_byte(routes, 3) << 8);
+       unsigned int capture = snd_ctl_elem_value_get_byte(routes, 4) |
+                              (snd_ctl_elem_value_get_byte(routes, 5) << 8) |
+                              (snd_ctl_elem_value_get_byte(routes, 6) << 16) |
+                              (snd_ctl_elem_value_get_byte(routes, 7) << 24);
        int right = (stream - 1) & 1;
        int source = (stream - 1) >> 1;
 
@@ -95,7 +95,7 @@ void patchbay_update(void)
 {
        int stream, tidx, err;
 
-       if ((err = snd_ctl_elem_read(card_ctl, &routes)) < 0) {
+       if ((err = snd_ctl_elem_read(ctl, routes)) < 0) {
                g_print("Multi track routes read error: %s\n", snd_strerror(err));
                return;
        }
@@ -107,14 +107,14 @@ void patchbay_update(void)
 
 static void set_routes(int stream, int idx)
 {
-       unsigned short psdout = routes.value.bytes.data[0] |
-                               (routes.value.bytes.data[1] << 8);
-       unsigned short spdout = routes.value.bytes.data[2] |
-                               (routes.value.bytes.data[3] << 8);
-       unsigned int capture = routes.value.bytes.data[4] |
-                              (routes.value.bytes.data[5] << 8) |
-                              (routes.value.bytes.data[6] << 16) |
-                              (routes.value.bytes.data[7] << 24);
+       unsigned short psdout = snd_ctl_elem_value_get_byte(routes, 0) |
+                               (snd_ctl_elem_value_get_byte(routes, 1) << 8);
+       unsigned short spdout = snd_ctl_elem_value_get_byte(routes, 2) |
+                               (snd_ctl_elem_value_get_byte(routes, 3) << 8);
+       unsigned int capture = snd_ctl_elem_value_get_byte(routes, 4) |
+                              (snd_ctl_elem_value_get_byte(routes, 5) << 8) |
+                              (snd_ctl_elem_value_get_byte(routes, 6) << 16) |
+                              (snd_ctl_elem_value_get_byte(routes, 7) << 24);
        int right = (stream - 1) & 1;
        int source = (stream - 1) >> 1;
        int err;
@@ -160,16 +160,17 @@ static void set_routes(int stream, int idx)
                        spdout |= ((idx - 4) & 7) << spdout_shift1;
                }
        }
-       routes.value.bytes.data[0] = psdout & 0xff;
-       routes.value.bytes.data[1] = (psdout >> 8) & 0xff;
-       routes.value.bytes.data[2] = spdout & 0xff;
-       routes.value.bytes.data[3] = (spdout >> 8) & 0xff;
-       routes.value.bytes.data[4] = capture & 0xff;
-       routes.value.bytes.data[5] = (capture >> 8) & 0xff;
-       routes.value.bytes.data[6] = (capture >> 16) & 0xff;
-       routes.value.bytes.data[7] = (capture >> 24) & 0xff;
+       snd_ctl_elem_value_set_byte(routes, 0, psdout & 0xff);
+       snd_ctl_elem_value_set_byte(routes, 1, (psdout >> 8) & 0xff);
+       snd_ctl_elem_value_set_byte(routes, 2, spdout & 0xff);
+       snd_ctl_elem_value_set_byte(routes, 3, (spdout >> 8) & 0xff);
+       snd_ctl_elem_value_set_byte(routes, 4, capture & 0xff);
+       snd_ctl_elem_value_set_byte(routes, 5, (capture >> 8) & 0xff);
+       snd_ctl_elem_value_set_byte(routes, 6, (capture >> 16) & 0xff);
+       snd_ctl_elem_value_set_byte(routes, 7, (capture >> 24) & 0xff);
        // g_print("psdout = 0x%x, spdout = 0x%x, capture = 0x%x\n", psdout, spdout, capture);
-       if ((err = snd_ctl_elem_write(card_ctl, &routes)) < 0)
+
+       if ((err = snd_ctl_elem_write(ctl, routes)) < 0)
                g_print("Multi track route write error: %s\n", snd_strerror(err));
 }
 
@@ -184,9 +185,9 @@ void patchbay_toggled(GtkWidget *togglebutton, gpointer data)
 
 void patchbay_init(void)
 {
-       memset(&routes, 0, sizeof(routes));
-       routes.id.iface = SND_CTL_ELEM_IFACE_MIXER;
-       strcpy(routes.id.name, "Multi Track Route");
+       snd_ctl_elem_value_malloc(&routes);
+       snd_ctl_elem_value_set_interface(routes, SND_CTL_ELEM_IFACE_MIXER);
+       snd_ctl_elem_value_set_name(routes, "Multi Track Route");
 }
 
 void patchbay_postinit(void)