]> git.alsa-project.org Git - alsa-tools.git/commitdiff
Thomas Charbonnel <thomas@undata.org>:
authorTakashi Iwai <tiwai@suse.de>
Mon, 3 Nov 2003 19:09:32 +0000 (19:09 +0000)
committerTakashi Iwai <tiwai@suse.de>
Mon, 3 Nov 2003 19:09:32 +0000 (19:09 +0000)
updated to version 1.2.

39 files changed:
hdspconf/ChangeLog
hdspconf/README
hdspconf/configure.in
hdspconf/pixmaps/alsalogo.xpm
hdspconf/pixmaps/lad_banner.xpm
hdspconf/pixmaps/rme.xpm
hdspconf/src/HC_AboutText.cxx
hdspconf/src/HC_Aeb.cxx [new file with mode: 0644]
hdspconf/src/HC_Aeb.h [new file with mode: 0644]
hdspconf/src/HC_AutoSyncRef.cxx
hdspconf/src/HC_BreakoutCable.cxx [new file with mode: 0644]
hdspconf/src/HC_BreakoutCable.h [new file with mode: 0644]
hdspconf/src/HC_CardPane.cxx
hdspconf/src/HC_CardPane.h
hdspconf/src/HC_ClockSource.cxx
hdspconf/src/HC_ClockSource.h
hdspconf/src/HC_InputLevel.cxx [new file with mode: 0644]
hdspconf/src/HC_InputLevel.h [new file with mode: 0644]
hdspconf/src/HC_OutputLevel.cxx [new file with mode: 0644]
hdspconf/src/HC_OutputLevel.h [new file with mode: 0644]
hdspconf/src/HC_Phones.cxx [new file with mode: 0644]
hdspconf/src/HC_Phones.h [new file with mode: 0644]
hdspconf/src/HC_PrefSyncRef.cxx
hdspconf/src/HC_PrefSyncRef.h
hdspconf/src/HC_SpdifFreq.cxx
hdspconf/src/HC_SpdifIn.cxx
hdspconf/src/HC_SpdifIn.h
hdspconf/src/HC_SyncCheck.cxx
hdspconf/src/HC_SyncCheck.h
hdspconf/src/HC_SystemClock.cxx
hdspconf/src/HC_XpmRenderer.h
hdspconf/src/Makefile.am
hdspconf/src/defines.h
hdspconf/src/hdspconf.cxx
hdspconf/src/pixmaps.cxx [new file with mode: 0644]
hdspconf/src/pixmaps.h [new file with mode: 0644]
hdsploader/INSTALL
hdsploader/configure.in
hdsploader/hdsploader.c

index e69de29bb2d1d6434b8b29ae775ad8c2e48c5391..c396ad82dd0af4b231437cd52f6467906ee75bc7 100644 (file)
@@ -0,0 +1,2 @@
+Version 1.2 (01/11/2003) :
+    * added support for HDSP 9652 and HDSP 9632 specific features
index 0e006c139f82fbc41c0871c4216a09b2941e9d86..ab915dc262d4bf19dec14d15d3f629632d12659c 100644 (file)
@@ -1,2 +1,2 @@
-HDSPConfig is a GUI to control the Hammerfall HDSP Alsa Settings.
+HDSPConf is a GUI to control the Hammerfall HDSP Alsa Settings.
 Up to four hdsp cards are supported.
index 4ff0181bf0758825b58008cfbb9b9e12c8262947..fb5f7a44acb4c5b61d89571f342a36dfcafaacef 100644 (file)
@@ -1,5 +1,5 @@
 AC_INIT(src/hdspconf.cxx)
-AM_INIT_AUTOMAKE(hdspconf, 1.1)
+AM_INIT_AUTOMAKE(hdspconf, 1.2)
 
 AC_PROG_CXX
 AC_PROG_MAKE_SET
index 39c402372e85e26fde8b1c60d0f4066bfd63354c..b32c32dc5f3bc7772b943dd243603a2c1f0b7ee8 100644 (file)
@@ -1,5 +1,5 @@
 /* XPM */
-static char * alsalogo_xpm[] = {
+char * alsalogo_xpm[] = {
 "50 50 398 2",
 "      c None",
 ".     c #C0C0C0",
index bdd9f8a9401b56f8a24ec42b8ff948a6dbd3d15f..8bb8545cd1915f938474bf82d65c72d26edb313c 100644 (file)
@@ -1,5 +1,5 @@
 /* XPM */
-static char * lad_banner_xpm[] = {
+char * lad_banner_xpm[] = {
 "113 39 1833 2",
 "      c None",
 ".     c #C0C0C0",
index 345f4f8a6f89b6fb617379e0aa581a5cdbbdc0ae..a892603c466ef0f11c074b34dd3eefc1b4f4a584 100644 (file)
@@ -1,5 +1,5 @@
 /* XPM */
-static char * rme_xpm[] = {
+char * rme_xpm[] = {
 "113 35 2300 2",
 "      c None",
 ".     c #030505",
index 1d0140a66387a841261a65ec29acb0eb272be032..4014bf189c5fb45c7e63e6453ff589f03745cbb8 100644 (file)
@@ -23,7 +23,7 @@
 
 HC_AboutText::HC_AboutText(int x, int y, int w, int h):Fl_Widget(x, y, w, h, "About Text")
 {
-       text = "HDSPConf (C) 2003 Thomas Charbonnel <thomas@@undata.org>\n\n"
+       text = "HDSPConf " VERSION " (C) 2003 Thomas Charbonnel <thomas@@undata.org>\n\n"
               "This Program is free software; you can redistribute it and/or modify\n"
               "it under the terms of the GNU General Public License as published by\n"
               "the Free Software Foundation; either version 2 of the License, or\n"
diff --git a/hdspconf/src/HC_Aeb.cxx b/hdspconf/src/HC_Aeb.cxx
new file mode 100644 (file)
index 0000000..571ad4d
--- /dev/null
@@ -0,0 +1,94 @@
+/*
+ *   HDSPConf
+ *    
+ *   Copyright (C) 2003 Thomas Charbonnel (thomas@undata.org)
+ *    
+ *   This program is free software; you can redistribute it and/or modify
+ *   it under the terms of the GNU General Public License as published by
+ *   the Free Software Foundation; either version 2 of the License, or
+ *   (at your option) any later version.
+ *
+ *   This program is distributed in the hope that it will be useful,
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *   GNU General Public License for more details.
+ *
+ *   You should have received a copy of the GNU General Public License
+ *   along with this program; if not, write to the Free Software
+ *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#pragma implementation
+#include "HC_Aeb.h"
+
+static void setAebStatus(char *ctl_name, int val, int card_index)
+{
+    int err;
+    char card_name[6];
+    snd_ctl_elem_value_t *ctl;
+    snd_ctl_elem_id_t *id;
+    snd_ctl_t *handle;
+    snprintf(card_name, 6, "hw:%i", card_index);
+    snd_ctl_elem_value_alloca(&ctl);
+    snd_ctl_elem_id_alloca(&id);
+    snd_ctl_elem_id_set_name(id, ctl_name);
+    snd_ctl_elem_id_set_numid(id, 0);
+    snd_ctl_elem_id_set_interface(id, SND_CTL_ELEM_IFACE_HWDEP);
+    snd_ctl_elem_id_set_device(id, 0);
+    snd_ctl_elem_id_set_subdevice(id, 0);
+    snd_ctl_elem_id_set_index(id, 0);
+    snd_ctl_elem_value_set_id(ctl, id);
+    snd_ctl_elem_value_set_integer(ctl, 0, val);
+    if ((err = snd_ctl_open(&handle, card_name, SND_CTL_NONBLOCK)) < 0) {
+       fprintf(stderr, "Error opening ctl interface on card %s\n", card_name);
+       return;
+    }
+    if ((err = snd_ctl_elem_write(handle, ctl)) < 0) {
+       fprintf(stderr, "Error accessing ctl interface on card %s\n", card_name);
+       return;
+    }
+    snd_ctl_close(handle);
+}
+
+void adat_internal_cb(Fl_Widget *w, void *arg)
+{
+    setAebStatus("Analog Extension Board", ((Fl_Check_Button *)w)->value(), ((HC_CardPane *)arg)->alsa_index);
+}
+
+HC_Aeb::HC_Aeb(int x, int y, int w, int h):Fl_Group(x, y, w, h, "AEB")
+{
+       int i = 0;
+       lock = 0;
+       box(FL_ENGRAVED_FRAME);
+       label("AEB");
+       labelsize(10);
+       align(FL_ALIGN_TOP|FL_ALIGN_LEFT);
+       adat_internal = new Fl_Check_Button(x+15, y, w-30, 20, "Adat1 Int.");
+       adat_internal->labelsize(10);
+       adat_internal->callback(adat_internal_cb, (void *)parent());
+       end();  
+}
+
+void HC_Aeb::setAdatInternal(unsigned char val)
+{
+    if (val != adat_internal->value()) {
+       adat_internal->value(val);
+    }
+}
+
+
+int HC_Aeb::handle(int e)
+{
+    switch (e) {
+       case FL_PUSH:
+           lock = 1;
+           break;
+       case FL_RELEASE:
+           lock = 0;
+           break;
+       default:
+           return Fl_Group::handle(e);
+    }
+    return Fl_Group::handle(e);
+}
+
diff --git a/hdspconf/src/HC_Aeb.h b/hdspconf/src/HC_Aeb.h
new file mode 100644 (file)
index 0000000..8933579
--- /dev/null
@@ -0,0 +1,43 @@
+/*
+ *   HDSPConf
+ *    
+ *   Copyright (C) 2003 Thomas Charbonnel (thomas@undata.org)
+ *    
+ *   This program is free software; you can redistribute it and/or modify
+ *   it under the terms of the GNU General Public License as published by
+ *   the Free Software Foundation; either version 2 of the License, or
+ *   (at your option) any later version.
+ *
+ *   This program is distributed in the hope that it will be useful,
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *   GNU General Public License for more details.
+ *
+ *   You should have received a copy of the GNU General Public License
+ *   along with this program; if not, write to the Free Software
+ *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#pragma interface
+#ifndef HC_AEB_H
+#define HC_AEB_H
+
+#include <FL/Fl_Group.H>
+#include <FL/Fl_Check_Button.H>
+#include <alsa/asoundlib.h>
+#include "HC_CardPane.h"
+
+class HC_CardPane;
+
+class HC_Aeb:public Fl_Group
+{
+public:
+    HC_Aeb(int x, int y, int w, int h);
+    Fl_Check_Button *adat_internal;
+    void setAdatInternal(unsigned char val);
+    int handle(int e);
+    int lock;
+};
+
+#endif
+
index 8cc5484d04b2f593c3032214ecc8b824b45fe2bd..ff4f29ca4ca4e94324abea7a82cc569539a402f8 100644 (file)
@@ -21,8 +21,8 @@
 #pragma implementation
 #include "HC_AutoSyncRef.h"
 
-extern char *freqs[7];
-extern char *ref[6];
+extern char *freqs[10];
+extern char *ref[7];
 
 HC_AutoSyncRef::HC_AutoSyncRef(int x, int y, int w, int h):Fl_Widget(x, y, w, h, "AutoSync Ref.")
 {
@@ -69,6 +69,15 @@ void HC_AutoSyncRef::setFreq(int f)
        case 96000:
            freq = 5;
            break;
+       case 128000:
+           freq = 7;
+           break;
+       case 176400:
+           freq = 8;
+           break;
+       case 192000:
+           freq = 9;
+           break;
        default:
            freq = 6;
        }           
@@ -81,7 +90,7 @@ void HC_AutoSyncRef::setFreq(int f)
 void HC_AutoSyncRef::setRef(unsigned char r)
 {
        if (r == external_ref) return;
-       if (r > 6) external_ref = 6;
+       if (r > 6) external_ref = 3;
        else external_ref = r;
        redraw();
 }
diff --git a/hdspconf/src/HC_BreakoutCable.cxx b/hdspconf/src/HC_BreakoutCable.cxx
new file mode 100644 (file)
index 0000000..e0baa92
--- /dev/null
@@ -0,0 +1,93 @@
+/*
+ *   HDSPConf
+ *    
+ *   Copyright (C) 2003 Thomas Charbonnel (thomas@undata.org)
+ *    
+ *   This program is free software; you can redistribute it and/or modify
+ *   it under the terms of the GNU General Public License as published by
+ *   the Free Software Foundation; either version 2 of the License, or
+ *   (at your option) any later version.
+ *
+ *   This program is distributed in the hope that it will be useful,
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *   GNU General Public License for more details.
+ *
+ *   You should have received a copy of the GNU General Public License
+ *   along with this program; if not, write to the Free Software
+ *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#pragma implementation
+#include "HC_BreakoutCable.h"
+
+static void setXlrStatus(char *ctl_name, int val, int card_index)
+{
+    int err;
+    char card_name[6];
+    snd_ctl_elem_value_t *ctl;
+    snd_ctl_elem_id_t *id;
+    snd_ctl_t *handle;
+    snprintf(card_name, 6, "hw:%i", card_index);
+    snd_ctl_elem_value_alloca(&ctl);
+    snd_ctl_elem_id_alloca(&id);
+    snd_ctl_elem_id_set_name(id, ctl_name);
+    snd_ctl_elem_id_set_numid(id, 0);
+    snd_ctl_elem_id_set_interface(id, SND_CTL_ELEM_IFACE_HWDEP);
+    snd_ctl_elem_id_set_device(id, 0);
+    snd_ctl_elem_id_set_subdevice(id, 0);
+    snd_ctl_elem_id_set_index(id, 0);
+    snd_ctl_elem_value_set_id(ctl, id);
+    snd_ctl_elem_value_set_integer(ctl, 0, val);
+    if ((err = snd_ctl_open(&handle, card_name, SND_CTL_NONBLOCK)) < 0) {
+       fprintf(stderr, "Error opening ctl interface on card %s\n", card_name);
+       return;
+    }
+    if ((err = snd_ctl_elem_write(handle, ctl)) < 0) {
+       fprintf(stderr, "Error accessing ctl interface on card %s\n", card_name);
+       return;
+    }
+    snd_ctl_close(handle);
+}
+
+void xlr_cb(Fl_Widget *w, void *arg)
+{
+    setXlrStatus("XLR Breakout Cable", ((Fl_Check_Button *)w)->value(), ((HC_CardPane *)arg)->alsa_index);
+}
+
+HC_BreakoutCable::HC_BreakoutCable(int x, int y, int w, int h):Fl_Group(x, y, w, h, "Breakout Cable")
+{
+       int i = 0;
+       lock = 0;
+       box(FL_ENGRAVED_FRAME);
+       label("Breakout Cable");
+       labelsize(10);
+       align(FL_ALIGN_TOP|FL_ALIGN_LEFT);
+       xlr = new Fl_Check_Button(x+15, y, w-30, 20, "XLR");
+       xlr->labelsize(10);
+       xlr->callback(xlr_cb, (void *)parent());
+       end();  
+}
+
+void HC_BreakoutCable::setXlr(unsigned char val)
+{
+    if (val != xlr->value()) {
+       xlr->value(val);
+    }
+}
+
+int HC_BreakoutCable::handle(int e)
+{
+    switch (e) {
+       case FL_PUSH:
+           lock = 1;
+           break;
+       case FL_RELEASE:
+           lock = 0;
+           break;
+       default:
+           return Fl_Group::handle(e);
+    }
+    return Fl_Group::handle(e);
+}
+
diff --git a/hdspconf/src/HC_BreakoutCable.h b/hdspconf/src/HC_BreakoutCable.h
new file mode 100644 (file)
index 0000000..ebb4491
--- /dev/null
@@ -0,0 +1,43 @@
+/*
+ *   HDSPConf
+ *    
+ *   Copyright (C) 2003 Thomas Charbonnel (thomas@undata.org)
+ *    
+ *   This program is free software; you can redistribute it and/or modify
+ *   it under the terms of the GNU General Public License as published by
+ *   the Free Software Foundation; either version 2 of the License, or
+ *   (at your option) any later version.
+ *
+ *   This program is distributed in the hope that it will be useful,
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *   GNU General Public License for more details.
+ *
+ *   You should have received a copy of the GNU General Public License
+ *   along with this program; if not, write to the Free Software
+ *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#pragma interface
+#ifndef HC_BREAKOUTCABLE_H
+#define HC_BREAKOUTCABLE_H
+
+#include <FL/Fl_Group.H>
+#include <FL/Fl_Check_Button.H>
+#include <alsa/asoundlib.h>
+#include "HC_CardPane.h"
+
+class HC_CardPane;
+
+class HC_BreakoutCable:public Fl_Group
+{
+public:
+    HC_BreakoutCable(int x, int y, int w, int h);
+    Fl_Check_Button *xlr;
+    void setXlr(unsigned char val);
+    int handle(int e);
+    int lock;
+};
+
+#endif
+
index ddd57966c5f111551c2bb7c43c3ec4b40bf3f994..8371dbc14cef66b0f499330c23e63c03c3bfd708 100644 (file)
 #pragma implementation
 #include "HC_CardPane.h"
 
-HC_CardPane::HC_CardPane(int alsa_idx, int idx, int t):Fl_Group(PANE_X, PANE_Y, PANE_W, PANE_H)
+extern char *card_names[5];
+
+HC_CardPane::HC_CardPane(int alsa_idx, int idx, HDSP_IO_Type t):Fl_Group(PANE_X, PANE_Y, PANE_W, PANE_H)
 {
     alsa_index = alsa_idx;
     index = idx;
     type = t;
-    snprintf(name, 7, "Card %d", index+1);
+    snprintf(name, 19, "Card %d (%s)", index+1, card_names[t]);
     label(name);
     labelsize(10);
 
-    sync_ref = new HC_PrefSyncRef(x()+6, y()+20, 112, 120);
-    sync_check = new HC_SyncCheck(x()+6, y()+156, 112, 100);
+    if (type == Multiface) {
+       clock_source = new HC_ClockSource(x()+9, y()+20, 148, V_STEP*7);
+       sync_check = new HC_SyncCheck(x()+9, y()+40+V_STEP*7, 148, V_STEP*4);
+
+       spdif_in = new HC_SpdifIn(x()+166, y()+20, 148, V_STEP*3);
+       spdif_out = new HC_SpdifOut(x()+166, y()+40+V_STEP*3, 148, V_STEP*4);
+       spdif_freq = new HC_SpdifFreq(x()+166, y()+60+V_STEP*7, 148, V_STEP);
+           
+       sync_ref = new HC_PrefSyncRef(x()+323, y()+20, 148, V_STEP*4);
+       autosync_ref = new HC_AutoSyncRef(x()+323, y()+40+V_STEP*4, 148, V_STEP*2);
+       system_clock = new HC_SystemClock(x()+323, y()+60+V_STEP*6, 148, V_STEP*2);
+
+    } else if (type == Digiface) {
+    
+       clock_source = new HC_ClockSource(x()+9, y()+20, 148, V_STEP*7);
+       sync_check = new HC_SyncCheck(x()+9, y()+40+V_STEP*7, 148, V_STEP*6);
+
+       spdif_in = new HC_SpdifIn(x()+166, y()+20, 148, V_STEP*3);
+       spdif_out = new HC_SpdifOut(x()+166, y()+40+V_STEP*3, 148, V_STEP*4);
+       spdif_freq = new HC_SpdifFreq(x()+166, y()+60+V_STEP*7, 148, V_STEP);
+           
+       sync_ref = new HC_PrefSyncRef(x()+323, y()+20, 148, V_STEP*6);
+       autosync_ref = new HC_AutoSyncRef(x()+323, y()+40+V_STEP*6, 148, V_STEP*2);
+       system_clock = new HC_SystemClock(x()+323, y()+60+V_STEP*8, 148, V_STEP*2);
+
+    } else if (type == H9652) {
+
+       clock_source = new HC_ClockSource(x()+9, y()+20, 148, V_STEP*7);
+       sync_check = new HC_SyncCheck(x()+9, y()+40+V_STEP*7, 148, V_STEP*6);
 
-    spdif_in = new HC_SpdifIn(x()+124, y()+20, 112, 60);
-    spdif_out = new HC_SpdifOut(x()+124, y()+96, 112, 80);
-    spdif_freq = new HC_SpdifFreq(x()+124, y()+192, 112, 20);
+       spdif_in = new HC_SpdifIn(x()+166, y()+20, 148, V_STEP*3);
+       spdif_out = new HC_SpdifOut(x()+166, y()+40+V_STEP*3, 148, V_STEP*4);
+       spdif_freq = new HC_SpdifFreq(x()+166, y()+60+V_STEP*7, 148, V_STEP);
+           
+       aeb = new HC_Aeb(x()+323, y()+20, 148, V_STEP);
+       sync_ref = new HC_PrefSyncRef(x()+323, y()+40+V_STEP, 148, V_STEP*6);
+       autosync_ref = new HC_AutoSyncRef(x()+323, y()+60+V_STEP*7, 148, V_STEP*2);
+       system_clock = new HC_SystemClock(x()+323, y()+80+V_STEP*9, 148, V_STEP*2);
 
-    clock_source = new HC_ClockSource(x()+242, y()+20, 112, 140);
-    autosync_ref = new HC_AutoSyncRef(x()+242, y()+176, 112, 40);
-    system_clock = new HC_SystemClock(x()+242, y()+232, 112, 40);
+    } else if (type == H9632) {
+       clock_source = new HC_ClockSource(x()+8, y()+20, 110, V_STEP*10);
+       sync_check = new HC_SyncCheck(x()+8, y()+40+V_STEP*10, 110, V_STEP*3);
 
+       spdif_in = new HC_SpdifIn(x()+126, y()+20, 110, V_STEP*4);
+       spdif_out = new HC_SpdifOut(x()+126, y()+40+V_STEP*4, 110, V_STEP*4);
+       spdif_freq = new HC_SpdifFreq(x()+126, y()+60+V_STEP*8, 110, V_STEP);
+           
+       aeb = new HC_Aeb(x()+244, y()+20, 110, V_STEP);
+       sync_ref = new HC_PrefSyncRef(x()+244, y()+40+V_STEP, 110, V_STEP*3);
+       autosync_ref = new HC_AutoSyncRef(x()+244, y()+60+V_STEP*4, 110, V_STEP*2);
+       system_clock = new HC_SystemClock(x()+244, y()+80+V_STEP*6, 110, V_STEP*2);
+    
+       breakout_cable = new HC_BreakoutCable(x()+362, y()+20, 110, V_STEP);
+       input_level = new HC_InputLevel(x()+362, y()+40+V_STEP, 110, V_STEP*3);
+       output_level = new HC_OutputLevel(x()+362, y()+60+V_STEP*4, 110, V_STEP*3);
+       phones = new HC_Phones(x()+362, y()+80+V_STEP*7, 110, V_STEP*3);
+       
+    }
     end();
 }
 
index 3b5eb92e8f57d89c0b755e4420eb39b1309d6aea..b7cf32644f5127bb2efb5b9c12af0ff25e0cf9dc 100644 (file)
@@ -23,6 +23,7 @@
 #define HC_CardPane_H
 
 #include <stdio.h>
+#include <sound/hdsp.h>
 #include <FL/Fl_Group.H>
 #include "HC_SyncCheck.h"
 #include "HC_SpdifFreq.h"
 #include "HC_SpdifIn.h"
 #include "HC_SpdifOut.h"
 #include "HC_PrefSyncRef.h"
+#include "HC_Aeb.h"
+#include "HC_BreakoutCable.h"
+#include "HC_InputLevel.h"
+#include "HC_OutputLevel.h"
+#include "HC_Phones.h"
 #include "defines.h"
 
 class HC_SyncCheck;
@@ -42,11 +48,16 @@ class HC_ClockSource;
 class HC_SpdifIn;
 class HC_SpdifOut;
 class HC_PrefSyncRef;
+class HC_Aeb;
+class HC_BreakoutCable;
+class HC_InputLevel;
+class HC_OutputLevel;
+class HC_Phones;
 
 class HC_CardPane:public Fl_Group
 {
 public:
-    HC_CardPane(int alsa_idx, int idx, int t);    
+    HC_CardPane(int alsa_idx, int idx, HDSP_IO_Type t);    
     HC_SyncCheck *sync_check;
     HC_SpdifFreq *spdif_freq;
     HC_AutoSyncRef *autosync_ref;
@@ -55,11 +66,16 @@ public:
     HC_SpdifIn *spdif_in;
     HC_SpdifOut *spdif_out;
     HC_PrefSyncRef *sync_ref;
+    HC_Aeb *aeb;
+    HC_BreakoutCable *breakout_cable;
+    HC_InputLevel *input_level;
+    HC_OutputLevel *output_level;
+    HC_Phones *phones;
     int index;
     int alsa_index;
-    int type;
+    HDSP_IO_Type type;
 private:
-    char name[7];
+    char name[19];
 };
 
 #endif
index 564160ad066dcdb5965d45834bb58c8323f68dc4..ac99800bb3f07b818e5fb7e2c9914d4864ef34a8 100644 (file)
@@ -21,7 +21,7 @@
 #pragma implementation
 #include "HC_ClockSource.h"
 
-extern char *freqs[7];
+extern char *freqs[10];
 
 void clock_source_cb(Fl_Widget *w, void *arg)
 {
@@ -47,7 +47,14 @@ void clock_source_cb(Fl_Widget *w, void *arg)
                src = 5;
        } else if (source == cs->khz96) {
                src = 6;
+       } else if (source == cs->khz128) {
+               src = 7;
+       } else if (source == cs->khz176_4) {
+               src = 8;
+       } else if (source == cs->khz192) {
+               src = 9;
        }
+       
        snprintf(card_name, 6, "hw:%i", pane->alsa_index);
        snd_ctl_elem_value_alloca(&ctl);
        snd_ctl_elem_id_alloca(&id);
@@ -73,25 +80,38 @@ void clock_source_cb(Fl_Widget *w, void *arg)
 HC_ClockSource::HC_ClockSource(int x, int y, int w, int h):Fl_Group(x, y, w, h, "Sample Clock Source")
 {
        int i = 0;
-       int v_step = (int)(h/7.0f);
        box(FL_ENGRAVED_FRAME);
        label("Sample Clock Source");
        labelsize(10);
        align(FL_ALIGN_TOP|FL_ALIGN_LEFT);
-       autosync = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "AutoSync");
+       autosync = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, "AutoSync");
        autosync->callback(clock_source_cb, (void *)this);
-       khz32 = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, freqs[0]);
+       khz32 = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, freqs[0]);
        khz32->callback(clock_source_cb, (void *)this);
-       khz44_1 = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, freqs[1]);
+       khz44_1 = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, freqs[1]);
        khz44_1->callback(clock_source_cb, (void *)this);
-       khz48 = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, freqs[2]);
+       khz48 = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, freqs[2]);
        khz48->callback(clock_source_cb, (void *)this);
-       khz64 = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, freqs[3]);
+       khz64 = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, freqs[3]);
        khz64->callback(clock_source_cb, (void *)this);
-       khz88_2 = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, freqs[4]);
+       khz88_2 = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, freqs[4]);
        khz88_2->callback(clock_source_cb, (void *)this);
-       khz96 = new Fl_Round_Button(x+15, y+v_step*i, w-30, v_step, freqs[5]);
+       khz96 = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, freqs[5]);
        khz96->callback(clock_source_cb, (void *)this);
+       if (((HC_CardPane *)parent())->type == H9632) {
+           khz128 = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, freqs[7]);
+           khz128->callback(clock_source_cb, (void *)this);
+           khz128->labelsize(10);
+           khz128->type(FL_RADIO_BUTTON);
+           khz176_4 = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, freqs[8]);
+           khz176_4->callback(clock_source_cb, (void *)this);
+           khz176_4->labelsize(10);
+           khz176_4->type(FL_RADIO_BUTTON);
+           khz192 = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, freqs[9]);
+           khz192->callback(clock_source_cb, (void *)this);    
+           khz192->labelsize(10);
+           khz192->type(FL_RADIO_BUTTON);
+       }
        autosync->labelsize(10);
        autosync->type(FL_RADIO_BUTTON);
        khz32->labelsize(10);
index ae44dc6ca191c2e715ed720fe866396b76ac2c71..27b3619e270553ffb8be1b5b381204fa532e9a76 100644 (file)
@@ -33,7 +33,6 @@ class HC_ClockSource:public Fl_Group
 {
 public:
     HC_ClockSource(int x, int y, int w, int h);
-    int source;
     Fl_Round_Button *autosync;
     Fl_Round_Button *khz32;
     Fl_Round_Button *khz44_1;
@@ -41,6 +40,9 @@ public:
     Fl_Round_Button *khz64;
     Fl_Round_Button *khz88_2;
     Fl_Round_Button *khz96;
+    Fl_Round_Button *khz128;
+    Fl_Round_Button *khz176_4;
+    Fl_Round_Button *khz192;
     void setSource(unsigned char s);
 };
 
diff --git a/hdspconf/src/HC_InputLevel.cxx b/hdspconf/src/HC_InputLevel.cxx
new file mode 100644 (file)
index 0000000..157cd13
--- /dev/null
@@ -0,0 +1,103 @@
+/*
+ *   HDSPConf
+ *    
+ *   Copyright (C) 2003 Thomas Charbonnel (thomas@undata.org)
+ *    
+ *   This program is free software; you can redistribute it and/or modify
+ *   it under the terms of the GNU General Public License as published by
+ *   the Free Software Foundation; either version 2 of the License, or
+ *   (at your option) any later version.
+ *
+ *   This program is distributed in the hope that it will be useful,
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *   GNU General Public License for more details.
+ *
+ *   You should have received a copy of the GNU General Public License
+ *   along with this program; if not, write to the Free Software
+ *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#pragma implementation
+#include "HC_InputLevel.h"
+
+void input_level_cb(Fl_Widget *w, void *arg)
+{
+    int gain, err;
+    char card_name[6];
+    snd_ctl_elem_value_t *ctl;
+    snd_ctl_elem_id_t *id;
+    snd_ctl_t *handle;
+    Fl_Round_Button *source = (Fl_Round_Button *)w;
+    HC_InputLevel *il = (HC_InputLevel *)arg;
+    HC_CardPane *pane = (HC_CardPane *)il->parent();
+    if (source == il->lo_gain) {
+       gain = 2;
+    } else if (source == il->plus_four_dbu) {
+       gain = 1;
+    } else if (source == il->minus_ten_dbv) {
+       gain = 0;
+    }
+    snprintf(card_name, 6, "hw:%i", pane->alsa_index);
+    snd_ctl_elem_value_alloca(&ctl);
+    snd_ctl_elem_id_alloca(&id);
+    snd_ctl_elem_id_set_name(id, "AD Gain");
+    snd_ctl_elem_id_set_numid(id, 0);
+    snd_ctl_elem_id_set_interface(id, SND_CTL_ELEM_IFACE_HWDEP);
+    snd_ctl_elem_id_set_device(id, 0);
+    snd_ctl_elem_id_set_subdevice(id, 0);
+    snd_ctl_elem_id_set_index(id, 0);
+    snd_ctl_elem_value_set_id(ctl, id);
+    snd_ctl_elem_value_set_enumerated(ctl, 0, gain);
+    if ((err = snd_ctl_open(&handle, card_name, SND_CTL_NONBLOCK)) < 0) {
+       fprintf(stderr, "Error opening ctl interface on card %s\n", card_name);
+       return;
+    }
+    if ((err = snd_ctl_elem_write(handle, ctl)) < 0) {
+       fprintf(stderr, "Error accessing ctl interface on card %s\n", card_name);
+       return;
+    }
+    snd_ctl_close(handle);
+}
+
+HC_InputLevel::HC_InputLevel(int x, int y, int w, int h):Fl_Group(x, y, w, h, "Input Level")
+{
+       int i = 0;
+       int v_step = (int)(h/3.0f);
+       box(FL_ENGRAVED_FRAME);;
+       label("Input Level");
+       labelsize(10);
+       align(FL_ALIGN_TOP|FL_ALIGN_LEFT);
+       lo_gain = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "Lo Gain");
+       plus_four_dbu = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "+4 dBu");
+       minus_ten_dbv = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "-10 dBV");
+       lo_gain->labelsize(10);
+       lo_gain->type(FL_RADIO_BUTTON);
+       lo_gain->callback(input_level_cb, (void *)this);
+       plus_four_dbu->labelsize(10);
+       plus_four_dbu->type(FL_RADIO_BUTTON);
+       plus_four_dbu->callback(input_level_cb, (void *)this);
+       minus_ten_dbv->labelsize(10);
+       minus_ten_dbv->type(FL_RADIO_BUTTON);
+       minus_ten_dbv->callback(input_level_cb, (void *)this);
+       end();  
+}
+
+void HC_InputLevel::setInputLevel(unsigned char i)
+{
+       switch (i) {
+       case 0:
+           if (minus_ten_dbv->value() != 1)
+               minus_ten_dbv->setonly();
+           break;
+       case 1:
+           if (plus_four_dbu->value() != 1)
+               plus_four_dbu->setonly();
+           break;
+       case 2:
+           if (lo_gain->value() != 1)
+               lo_gain->setonly();
+           break;
+       }
+}
+
diff --git a/hdspconf/src/HC_InputLevel.h b/hdspconf/src/HC_InputLevel.h
new file mode 100644 (file)
index 0000000..a7691ca
--- /dev/null
@@ -0,0 +1,44 @@
+/*
+ *   HDSPConf
+ *    
+ *   Copyright (C) 2003 Thomas Charbonnel (thomas@undata.org)
+ *    
+ *   This program is free software; you can redistribute it and/or modify
+ *   it under the terms of the GNU General Public License as published by
+ *   the Free Software Foundation; either version 2 of the License, or
+ *   (at your option) any later version.
+ *
+ *   This program is distributed in the hope that it will be useful,
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *   GNU General Public License for more details.
+ *
+ *   You should have received a copy of the GNU General Public License
+ *   along with this program; if not, write to the Free Software
+ *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#pragma interface
+#ifndef HC_INPUTLEVEL_H
+#define HC_INPUTLEVEL_H
+
+#include <FL/Fl_Group.H>
+#include <FL/Fl_Round_Button.H>
+#include <alsa/asoundlib.h>
+#include "HC_CardPane.h"
+
+class HC_CardPane;
+
+class HC_InputLevel:public Fl_Group
+{
+public:
+    HC_InputLevel(int x, int y, int w, int h);
+    int source;
+    Fl_Round_Button *lo_gain;
+    Fl_Round_Button *plus_four_dbu;
+    Fl_Round_Button *minus_ten_dbv;
+    void setInputLevel(unsigned char i);
+};
+
+#endif
+
diff --git a/hdspconf/src/HC_OutputLevel.cxx b/hdspconf/src/HC_OutputLevel.cxx
new file mode 100644 (file)
index 0000000..9523ab6
--- /dev/null
@@ -0,0 +1,93 @@
+/*
+ *   HDSPConf
+ *    
+ *   Copyright (C) 2003 Thomas Charbonnel (thomas@undata.org)
+ *    
+ *   This program is free software; you can redistribute it and/or modify
+ *   it under the terms of the GNU General Public License as published by
+ *   the Free Software Foundation; either version 2 of the License, or
+ *   (at your option) any later version.
+ *
+ *   This program is distributed in the hope that it will be useful,
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *   GNU General Public License for more details.
+ *
+ *   You should have received a copy of the GNU General Public License
+ *   along with this program; if not, write to the Free Software
+ *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#pragma implementation
+#include "HC_OutputLevel.h"
+
+void output_level_cb(Fl_Widget *w, void *arg)
+{
+    int gain, err;
+    char card_name[6];
+    snd_ctl_elem_value_t *ctl;
+    snd_ctl_elem_id_t *id;
+    snd_ctl_t *handle;
+    Fl_Round_Button *source = (Fl_Round_Button *)w;
+    HC_OutputLevel *ol = (HC_OutputLevel *)arg;
+    HC_CardPane *pane = (HC_CardPane *)ol->parent();
+    if (source == ol->hi_gain) {
+       gain = 0;
+    } else if (source == ol->plus_four_dbu) {
+       gain = 1;
+    } else if (source == ol->minus_ten_dbv) {
+       gain = 2;
+    }
+    snprintf(card_name, 6, "hw:%i", pane->alsa_index);
+    snd_ctl_elem_value_alloca(&ctl);
+    snd_ctl_elem_id_alloca(&id);
+    snd_ctl_elem_id_set_name(id, "DA Gain");
+    snd_ctl_elem_id_set_numid(id, 0);
+    snd_ctl_elem_id_set_interface(id, SND_CTL_ELEM_IFACE_HWDEP);
+    snd_ctl_elem_id_set_device(id, 0);
+    snd_ctl_elem_id_set_subdevice(id, 0);
+    snd_ctl_elem_id_set_index(id, 0);
+    snd_ctl_elem_value_set_id(ctl, id);
+    snd_ctl_elem_value_set_enumerated(ctl, 0, gain);
+    if ((err = snd_ctl_open(&handle, card_name, SND_CTL_NONBLOCK)) < 0) {
+       fprintf(stderr, "Error opening ctl interface on card %s\n", card_name);
+       return;
+    }
+    if ((err = snd_ctl_elem_write(handle, ctl)) < 0) {
+       fprintf(stderr, "Error accessing ctl interface on card %s\n", card_name);
+       return;
+    }
+    snd_ctl_close(handle);
+}
+
+HC_OutputLevel::HC_OutputLevel(int x, int y, int w, int h):Fl_Group(x, y, w, h, "Output Level")
+{
+       int i = 0;
+       int v_step = (int)(h/3.0f);
+       box(FL_ENGRAVED_FRAME);;
+       label("Output Level");
+       labelsize(10);
+       align(FL_ALIGN_TOP|FL_ALIGN_LEFT);
+       hi_gain = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "Hi Gain");
+       plus_four_dbu = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "+4 dBu");
+       minus_ten_dbv = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "-10 dBV");
+       hi_gain->labelsize(10);
+       hi_gain->type(FL_RADIO_BUTTON);
+       hi_gain->callback(output_level_cb, (void *)this);
+       plus_four_dbu->labelsize(10);
+       plus_four_dbu->type(FL_RADIO_BUTTON);
+       plus_four_dbu->callback(output_level_cb, (void *)this);
+       minus_ten_dbv->labelsize(10);
+       minus_ten_dbv->type(FL_RADIO_BUTTON);
+       minus_ten_dbv->callback(output_level_cb, (void *)this);
+       end();  
+}
+
+void HC_OutputLevel::setOutputLevel(unsigned char i)
+{
+       if (i < children()) {
+           if (((Fl_Round_Button *)child(i))->value() !=1)
+               ((Fl_Round_Button *)child(i))->setonly();
+       }
+}
+
diff --git a/hdspconf/src/HC_OutputLevel.h b/hdspconf/src/HC_OutputLevel.h
new file mode 100644 (file)
index 0000000..3067ce1
--- /dev/null
@@ -0,0 +1,43 @@
+/*
+ *   HDSPConf
+ *    
+ *   Copyright (C) 2003 Thomas Charbonnel (thomas@undata.org)
+ *    
+ *   This program is free software; you can redistribute it and/or modify
+ *   it under the terms of the GNU General Public License as published by
+ *   the Free Software Foundation; either version 2 of the License, or
+ *   (at your option) any later version.
+ *
+ *   This program is distributed in the hope that it will be useful,
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *   GNU General Public License for more details.
+ *
+ *   You should have received a copy of the GNU General Public License
+ *   along with this program; if not, write to the Free Software
+ *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#pragma interface
+#ifndef HC_OUTPUTLEVEL_H
+#define HC_OUTPUTLEVEL_H
+
+#include <FL/Fl_Group.H>
+#include <FL/Fl_Round_Button.H>
+#include <alsa/asoundlib.h>
+#include "HC_CardPane.h"
+
+class HC_CardPane;
+
+class HC_OutputLevel:public Fl_Group
+{
+public:
+    HC_OutputLevel(int x, int y, int w, int h);
+    Fl_Round_Button *hi_gain;
+    Fl_Round_Button *plus_four_dbu;
+    Fl_Round_Button *minus_ten_dbv;
+    void setOutputLevel(unsigned char i);
+};
+
+#endif
+
diff --git a/hdspconf/src/HC_Phones.cxx b/hdspconf/src/HC_Phones.cxx
new file mode 100644 (file)
index 0000000..7c5f30a
--- /dev/null
@@ -0,0 +1,93 @@
+/*
+ *   HDSPConf
+ *    
+ *   Copyright (C) 2003 Thomas Charbonnel (thomas@undata.org)
+ *    
+ *   This program is free software; you can redistribute it and/or modify
+ *   it under the terms of the GNU General Public License as published by
+ *   the Free Software Foundation; either version 2 of the License, or
+ *   (at your option) any later version.
+ *
+ *   This program is distributed in the hope that it will be useful,
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *   GNU General Public License for more details.
+ *
+ *   You should have received a copy of the GNU General Public License
+ *   along with this program; if not, write to the Free Software
+ *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#pragma implementation
+#include "HC_Phones.h"
+
+void phones_cb(Fl_Widget *w, void *arg)
+{
+    int gain, err;
+    char card_name[6];
+    snd_ctl_elem_value_t *ctl;
+    snd_ctl_elem_id_t *id;
+    snd_ctl_t *handle;
+    Fl_Round_Button *source = (Fl_Round_Button *)w;
+    HC_Phones *ph = (HC_Phones *)arg;
+    HC_CardPane *pane = (HC_CardPane *)ph->parent();
+    if (source == ph->zero_db) {
+       gain = 0;
+    } else if (source == ph->minus_six_db) {
+       gain = 1;
+    } else if (source == ph->minus_twelve_db) {
+       gain = 2;
+    }
+    snprintf(card_name, 6, "hw:%i", pane->alsa_index);
+    snd_ctl_elem_value_alloca(&ctl);
+    snd_ctl_elem_id_alloca(&id);
+    snd_ctl_elem_id_set_name(id, "Phones Gain");
+    snd_ctl_elem_id_set_numid(id, 0);
+    snd_ctl_elem_id_set_interface(id, SND_CTL_ELEM_IFACE_HWDEP);
+    snd_ctl_elem_id_set_device(id, 0);
+    snd_ctl_elem_id_set_subdevice(id, 0);
+    snd_ctl_elem_id_set_index(id, 0);
+    snd_ctl_elem_value_set_id(ctl, id);
+    snd_ctl_elem_value_set_enumerated(ctl, 0, gain);
+    if ((err = snd_ctl_open(&handle, card_name, SND_CTL_NONBLOCK)) < 0) {
+       fprintf(stderr, "Error opening ctl interface on card %s\n", card_name);
+       return;
+    }
+    if ((err = snd_ctl_elem_write(handle, ctl)) < 0) {
+       fprintf(stderr, "Error accessing ctl interface on card %s\n", card_name);
+       return;
+    }
+    snd_ctl_close(handle);
+}
+
+HC_Phones::HC_Phones(int x, int y, int w, int h):Fl_Group(x, y, w, h, "Phones")
+{
+       int i = 0;
+       int v_step = (int)(h/3.0f);
+       box(FL_ENGRAVED_FRAME);;
+       label("Phones");
+       labelsize(10);
+       align(FL_ALIGN_TOP|FL_ALIGN_LEFT);
+       zero_db = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "Hi Gain");
+       minus_six_db = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "+4 dBu");
+       minus_twelve_db = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "-10 dBV");
+       zero_db->labelsize(10);
+       zero_db->type(FL_RADIO_BUTTON);
+       zero_db->callback(phones_cb, (void *)this);
+       minus_six_db->labelsize(10);
+       minus_six_db->type(FL_RADIO_BUTTON);
+       minus_six_db->callback(phones_cb, (void *)this);
+       minus_twelve_db->labelsize(10);
+       minus_twelve_db->type(FL_RADIO_BUTTON);
+       minus_twelve_db->callback(phones_cb, (void *)this);
+       end();  
+}
+
+void HC_Phones::setPhones(unsigned char i)
+{
+       if (i < children()) {
+           if (((Fl_Round_Button *)child(i))->value() != 1)
+               ((Fl_Round_Button *)child(i))->setonly();
+       }
+}
+
diff --git a/hdspconf/src/HC_Phones.h b/hdspconf/src/HC_Phones.h
new file mode 100644 (file)
index 0000000..f7a513b
--- /dev/null
@@ -0,0 +1,43 @@
+/*
+ *   HDSPConf
+ *    
+ *   Copyright (C) 2003 Thomas Charbonnel (thomas@undata.org)
+ *    
+ *   This program is free software; you can redistribute it and/or modify
+ *   it under the terms of the GNU General Public License as published by
+ *   the Free Software Foundation; either version 2 of the License, or
+ *   (at your option) any later version.
+ *
+ *   This program is distributed in the hope that it will be useful,
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *   GNU General Public License for more details.
+ *
+ *   You should have received a copy of the GNU General Public License
+ *   along with this program; if not, write to the Free Software
+ *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#pragma interface
+#ifndef HC_PHONES_H
+#define HC_PHONES_H
+
+#include <FL/Fl_Group.H>
+#include <FL/Fl_Round_Button.H>
+#include <alsa/asoundlib.h>
+#include "HC_CardPane.h"
+
+class HC_CardPane;
+
+class HC_Phones:public Fl_Group
+{
+public:
+    HC_Phones(int x, int y, int w, int h);
+    Fl_Round_Button *zero_db;
+    Fl_Round_Button *minus_six_db;
+    Fl_Round_Button *minus_twelve_db;
+    void setPhones(unsigned char i);
+};
+
+#endif
+
index c1bdd014d59750c405e6543536035f988ea0b373..bfd3096001f8446efafdd4c5afa5d87616492ff0 100644 (file)
@@ -33,11 +33,11 @@ void pref_sync_ref_cb(Fl_Widget *w, void *arg)
     Fl_Round_Button *source = (Fl_Round_Button *)w;
     if (source == psr->word_clock) {
        ref = 0;
-    } else if (source == psr->adat_sync) {
-       ref = 1;
     } else if (source == psr->spdif) {
-       ref = 2;
+       ref = 1;
     } else if (source == psr->adat1) {
+       ref = 2;
+    } else if (source == psr->adat_sync) {
        ref = 3;
     } else if (source == psr->adat2) {
        ref = 4;
@@ -70,31 +70,33 @@ void pref_sync_ref_cb(Fl_Widget *w, void *arg)
 HC_PrefSyncRef::HC_PrefSyncRef(int x, int y, int w, int h):Fl_Group(x, y, w, h, "Pref. Sync Ref")
 {
        int i = 0;
-       int v_step;
-       if (((HC_CardPane *)parent())->type == MULTIFACE) {
-           v_step = (int)(h/4.0f);
+       if (((HC_CardPane *)parent())->type == Multiface || ((HC_CardPane *)parent())->type == H9632) {
+           adat_name = "ADAT In";
        } else {
-           v_step = (int)(h/6.0f);
+           adat_name = "ADAT1 In";
        }
-       source = 0;
        box(FL_ENGRAVED_FRAME);;
        label("Pref. Sync Ref");
        labelsize(10);
        align(FL_ALIGN_TOP|FL_ALIGN_LEFT);
-       word_clock = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "Word Clock");
+       word_clock = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, "Word Clock");
        word_clock->callback(pref_sync_ref_cb, (void *)this);
-       adat_sync = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "ADAT Sync");
-       adat_sync->callback(pref_sync_ref_cb, (void *)this);
-       spdif = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "SPDIF In");
+       if (((HC_CardPane *)parent())->type != H9632) {
+           adat_sync = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, "ADAT Sync");
+           adat_sync->callback(pref_sync_ref_cb, (void *)this);
+           adat_sync->labelsize(10);
+           adat_sync->type(FL_RADIO_BUTTON);
+       }
+       spdif = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, "SPDIF In");
        spdif->callback(pref_sync_ref_cb, (void *)this);
-       adat1 = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "ADAT1 In");
+       adat1 = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, adat_name);
        adat1->callback(pref_sync_ref_cb, (void *)this);
-       if (((HC_CardPane *)parent())->type != MULTIFACE) {
-           adat2 = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "ADAT2 In");
+       if (((HC_CardPane *)parent())->type != Multiface && ((HC_CardPane *)parent())->type != H9632) {
+           adat2 = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, "ADAT2 In");
            adat2->labelsize(10);
            adat2->type(FL_RADIO_BUTTON);
            adat2->callback(pref_sync_ref_cb, (void *)this);
-           adat3 = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "ADAT3 In");
+           adat3 = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, "ADAT3 In");
            adat3->labelsize(10);
            adat3->type(FL_RADIO_BUTTON);
            adat3->callback(pref_sync_ref_cb, (void *)this);
@@ -105,16 +107,39 @@ HC_PrefSyncRef::HC_PrefSyncRef(int x, int y, int w, int h):Fl_Group(x, y, w, h,
        spdif->type(FL_RADIO_BUTTON);
        word_clock->labelsize(10);
        word_clock->type(FL_RADIO_BUTTON);
-       adat_sync->labelsize(10);
-       adat_sync->type(FL_RADIO_BUTTON);
        end();  
 }
 
 void HC_PrefSyncRef::setRef(int r)
 {
-       if (r >= 0 && r < children()) {
-           if (((Fl_Round_Button *)child(r))->value() != 1)
-               ((Fl_Round_Button *)child(r))->setonly();
+       switch (r) {
+       case 0:
+           if (word_clock->value() != 1)
+               word_clock->setonly();
+           break;
+       case 1:
+           if (spdif->value() != 1)
+               spdif->setonly();
+           break;
+       case 2:
+           if (adat1->value() != 1)
+               adat1->setonly();
+           break;
+       case 3:
+           if (((HC_CardPane *)parent())->type != H9632)
+               if (adat_sync->value() != 1)
+                   adat_sync->setonly();
+           break;
+       case 4:
+           if (((HC_CardPane *)parent())->type == H9652 || ((HC_CardPane *)parent())->type == Digiface)
+               if (adat2->value() != 1)
+                   adat2->setonly();
+           break;                          
+       case 5:
+           if (((HC_CardPane *)parent())->type == H9652 || ((HC_CardPane *)parent())->type == Digiface)
+               if (adat3->value() != 1)
+                   adat3->setonly();
+           break;                          
        }
 }
 
index e9cfc88613cbcb9501e9e805f28ad89a1a248346..5ef8875b7088b27d9481a36b8a6ad79b87748139 100644 (file)
@@ -41,6 +41,8 @@ public:
     Fl_Round_Button *word_clock;
     Fl_Round_Button *adat_sync;
     void setRef(int r);
+private:
+    char *adat_name;
 };
 
 #endif
index c38630dfcdebb666f1b925396ed907ca0a60ba50..0fed38f413a5b3bb55cbf01de74135ce19962a5a 100644 (file)
@@ -21,7 +21,7 @@
 #pragma implementation
 #include "HC_SpdifFreq.h"
 
-extern char *freqs[7];
+extern char *freqs[10];
 
 HC_SpdifFreq::HC_SpdifFreq(int x, int y, int w, int h):Fl_Widget(x, y, w, h, "SPDIF Freq.")
 {
@@ -64,6 +64,15 @@ void HC_SpdifFreq::setFreq(int f)
        case 96000:
            freq = 5;
            break;
+       case 128000:
+           freq = 7;
+           break;
+       case 176400:
+           freq = 8;
+           break;
+       case 192000:
+           freq = 9;
+           break;
        default:
            freq = 6;
        }
index 6a8c1485169ed3b0ca281c77a7267f2ed671cffe..343479f8675bda6fb66d3c299ed19e90201a1afa 100644 (file)
@@ -37,6 +37,8 @@ void spdif_in_cb(Fl_Widget *w, void *arg)
        in = 1;
     } else if (source == si->internal) {
        in = 2;
+    } else if (source == si->aes) {
+       in = 3;
     }
     snprintf(card_name, 6, "hw:%i", pane->alsa_index);
     snd_ctl_elem_value_alloca(&ctl);
@@ -63,15 +65,19 @@ void spdif_in_cb(Fl_Widget *w, void *arg)
 HC_SpdifIn::HC_SpdifIn(int x, int y, int w, int h):Fl_Group(x, y, w, h, "SPDIF In")
 {
        int i = 0;
-       int v_step = (int)(h/3.0f);
-       source = 0;
        box(FL_ENGRAVED_FRAME);;
        label("SPDIF In");
        labelsize(10);
        align(FL_ALIGN_TOP|FL_ALIGN_LEFT);
-       adat1 = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "ADAT1");
-       coaxial = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "Coaxial");
-       internal = new Fl_Round_Button(x+15, y+v_step*i++, w-30, v_step, "Internal");
+       adat1 = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, "Optical");
+       coaxial = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, "Coaxial");
+       internal = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, "Internal");
+       if (((HC_CardPane *)parent())->type == H9632) {
+           aes = new Fl_Round_Button(x+10, y+V_STEP*i++, w-20, V_STEP, "AES");
+           aes->labelsize(10);
+           aes->type(FL_RADIO_BUTTON);
+           aes->callback(spdif_in_cb, (void *)this);
+       }
        adat1->labelsize(10);
        adat1->type(FL_RADIO_BUTTON);
        adat1->callback(spdif_in_cb, (void *)this);
index e84088c4f451f90a617b2466761d444f5e224a83..498660e46c406bc1f0b978411a9c7abc4a2b6b36 100644 (file)
@@ -37,6 +37,7 @@ public:
     Fl_Round_Button *adat1;
     Fl_Round_Button *coaxial;
     Fl_Round_Button *internal;
+    Fl_Round_Button *aes;
     void setInput(unsigned char i);
 };
 
index 0ac426d7bc74969b404da448497d4b6425f846c6..4a088ba7344d7bd7fb1da8fd74c26a7659d90088 100644 (file)
@@ -31,10 +31,10 @@ HC_SyncCheck::HC_SyncCheck(int x, int y, int w, int h):Fl_Widget(x, y, w, h, "Sy
        wordclock_lock_status = -1;
        adatsync_lock_status = -1;
        spdif_lock_status = -1;
-       if (((HC_CardPane *)parent())->type == MULTIFACE) {
-               v_step = (int)(h/4.0f);    
+       if (((HC_CardPane *)parent())->type == Multiface || ((HC_CardPane *)parent())->type == H9632) {
+               adat_name = "ADAT In";
        } else {
-               v_step = (int)(h/6.0f);
+               adat_name = "ADAT1 In";
        } 
        h_step = (int)(w/2.0f);
        draw_box = Fl::get_boxtype(FL_ENGRAVED_FRAME);
@@ -45,7 +45,6 @@ HC_SyncCheck::HC_SyncCheck(int x, int y, int w, int h):Fl_Widget(x, y, w, h, "Sy
 
 void HC_SyncCheck::draw()
 {
-       int v_pos = v_step;
        int h_pos = 4;
        int i = 0;
        fl_color(FL_BACKGROUND_COLOR);
@@ -53,20 +52,22 @@ void HC_SyncCheck::draw()
        draw_box(x(), y(), w(), h(), FL_WHITE);
        fl_color(FL_BLACK);
        fl_font(FL_HELVETICA, 10);
-       fl_draw("ADAT1 In", x()+h_pos, y()+v_pos*i, h_step, v_step, FL_ALIGN_LEFT);
-       fl_draw(lock_status[adat1_lock_status], x()+h_pos+h_step, y()+v_pos*i++, h_step-h_pos, v_step, FL_ALIGN_CENTER);
-       if (((HC_CardPane *)parent())->type != MULTIFACE) {
-               fl_draw("ADAT2 In", x()+h_pos, y()+v_pos*i, h_step, v_step, FL_ALIGN_LEFT);
-               fl_draw(lock_status[adat2_lock_status], x()+h_pos+h_step, y()+v_pos*i++, h_step-h_pos, v_step, FL_ALIGN_CENTER);
-               fl_draw("ADAT3 In", x()+h_pos, y()+v_pos*i, h_step, v_step, FL_ALIGN_LEFT);
-               fl_draw(lock_status[adat3_lock_status], x()+h_pos+h_step, y()+v_pos*i++, h_step-h_pos, v_step, FL_ALIGN_CENTER);
+       fl_draw(adat_name, x()+h_pos, y()+V_STEP*i, h_step, V_STEP, FL_ALIGN_LEFT);
+       fl_draw(lock_status[adat1_lock_status], x()+h_pos+h_step, y()+V_STEP*i++, h_step-h_pos, V_STEP, FL_ALIGN_CENTER);
+       if (((HC_CardPane *)parent())->type == Digiface || ((HC_CardPane *)parent())->type == H9652) {
+               fl_draw("ADAT2 In", x()+h_pos, y()+V_STEP*i, h_step, V_STEP, FL_ALIGN_LEFT);
+               fl_draw(lock_status[adat2_lock_status], x()+h_pos+h_step, y()+V_STEP*i++, h_step-h_pos, V_STEP, FL_ALIGN_CENTER);
+               fl_draw("ADAT3 In", x()+h_pos, y()+V_STEP*i, h_step, V_STEP, FL_ALIGN_LEFT);
+               fl_draw(lock_status[adat3_lock_status], x()+h_pos+h_step, y()+V_STEP*i++, h_step-h_pos, V_STEP, FL_ALIGN_CENTER);
+       }
+       fl_draw("SPDIF In", x()+h_pos, y()+V_STEP*i, h_step, V_STEP, FL_ALIGN_LEFT);
+       fl_draw(lock_status[spdif_lock_status], x()+h_pos+h_step, y()+V_STEP*i++, h_step-h_pos, V_STEP, FL_ALIGN_CENTER);
+       fl_draw("WordClock", x()+h_pos, y()+V_STEP*i, h_step, V_STEP, FL_ALIGN_LEFT);
+       fl_draw(lock_status[wordclock_lock_status], x()+h_pos+h_step, y()+V_STEP*i++, h_step-h_pos, V_STEP, FL_ALIGN_CENTER);
+       if (((HC_CardPane *)parent())->type != H9632) {
+           fl_draw("ADAT Sync", x()+h_pos, y()+V_STEP*i, h_step, V_STEP, FL_ALIGN_LEFT);
+           fl_draw(lock_status[adatsync_lock_status], x()+h_pos+h_step, y()+V_STEP*i, h_step-h_pos, V_STEP, FL_ALIGN_CENTER);
        }
-       fl_draw("SPDIF In", x()+h_pos, y()+v_pos*i, h_step, v_step, FL_ALIGN_LEFT);
-       fl_draw(lock_status[spdif_lock_status], x()+h_pos+h_step, y()+v_pos*i++, h_step-h_pos, v_step, FL_ALIGN_CENTER);
-       fl_draw("WordClock", x()+h_pos, y()+v_pos*i, h_step, v_step, FL_ALIGN_LEFT);
-       fl_draw(lock_status[wordclock_lock_status], x()+h_pos+h_step, y()+v_pos*i++, h_step-h_pos, v_step, FL_ALIGN_CENTER);
-       fl_draw("ADAT Sync", x()+h_pos, y()+v_pos*i, h_step, v_step, FL_ALIGN_LEFT);
-       fl_draw(lock_status[adatsync_lock_status], x()+h_pos+h_step, y()+v_pos*i, h_step-h_pos, v_step, FL_ALIGN_CENTER);
 }
 
 void HC_SyncCheck::setSpdifStatus(unsigned char s)
index 64e8b00509c947e4f2ffc8eb2095e005b47f0f35..6aa6d13439a5310e8a531f130c5680695e2e3149 100644 (file)
@@ -51,7 +51,8 @@ public:
     void setAdatSyncStatus(unsigned char s);
     void setWCStatus(unsigned char s);
 private:
-    int v_step, h_step;
+    char *adat_name;
+    int h_step;
     Fl_Box_Draw_F *draw_box;
 };
 
index 947dc50781fb82f9177d9ca617998023a4a11650..f1f88bb07c352c2c499a54a3cb1472e0a5fd3ddf 100644 (file)
@@ -21,7 +21,7 @@
 #pragma implementation
 #include "HC_SystemClock.h"
 
-extern char *freqs[7];
+extern char *freqs[10];
 
 HC_SystemClock::HC_SystemClock(int x, int y, int w, int h):Fl_Widget(x, y, w, h, "System Clock")
 {
@@ -77,6 +77,15 @@ void HC_SystemClock::setFreq(int f)
     case 96000:
        freq = 5;
        break;
+    case 128000:
+       freq = 7;
+       break;
+    case 176400:
+       freq = 8;
+       break;
+    case 192000:
+       freq = 9;
+       break;
     default:
        freq = 6;
     }
index c3d1268dfa29e5ba4853a59b7ea8ce4c96a3e1db..3c6f768c42c0dac6c98422e92d45b9fa646583d4 100644 (file)
@@ -25,6 +25,7 @@
 #include <FL/Fl_Widget.H>
 #include <FL/fl_draw.H>
 #include <FL/Fl.H>
+#include "pixmaps.h"
 
 class HC_XpmRenderer:public Fl_Widget
 {
index 2d82236fbd6f7cb90a11c86c31967662179d921a..907fadd947df695993c049de3073ec8ee7f81550 100644 (file)
@@ -20,7 +20,19 @@ hdspconf_SOURCES = \
        HC_SpdifOut.h \
        HC_PrefSyncRef.cxx \
        HC_PrefSyncRef.h \
+       HC_Aeb.cxx \
+       HC_Aeb.h \
+       HC_BreakoutCable.cxx \
+       HC_BreakoutCable.h \
+       HC_InputLevel.cxx \
+       HC_InputLevel.h \
+       HC_OutputLevel.cxx \
+       HC_OutputLevel.h \
+       HC_Phones.cxx \
+       HC_Phones.h \
        HC_XpmRenderer.cxx \
        HC_XpmRenderer.h \
        HC_AboutText.cxx \
-       HC_AboutText.h
+       HC_AboutText.h \
+       pixmaps.cxx \
+       pixmaps.h
index 64339283dc37970b65cf059b9622e8905076bf53..531d411413f57ea4b04178b778392afc5f4bd642 100644 (file)
 #ifndef DEFINES_H
 #define DEFINES_H
 
-#define MULTIFACE 0
-#define DIGIFACE  1
-#define HDSP9652  2
-
-#define WINDOW_WIDTH  380
-#define WINDOW_HEIGHT 330
+#define WINDOW_WIDTH  500
+#define WINDOW_HEIGHT 400
 
 #define TABS_X 10
 #define TABS_Y 10
-#define TABS_W 360
-#define TABS_H 310
+#define TABS_W 480
+#define TABS_H 380
 
 #define PANE_X 10
 #define PANE_Y 30
-#define PANE_H 290
-#define PANE_W 360
+#define PANE_W 480
+#define PANE_H 360
+
+#define V_STEP 24
 
 #endif
 
index e5c31d21a473026a01d63733c575f67efa6e601e..22e4fa25c354bfeee223144ada2346a91a7fdeaf 100644 (file)
 #include <FL/Fl_Tabs.H>
 #include "HC_CardPane.h"
 #include "HC_XpmRenderer.h"
+#include "pixmaps.h"
 #include "HC_AboutText.h"
 #include "defines.h"
 
-#include "../pixmaps/rme.xpm"
-#include "../pixmaps/alsalogo.xpm"
-#include "../pixmaps/lad_banner.xpm"
+//#define GUI_TEST
 
 class HC_CardPane;
 class HC_XpmRenderer;
 class HC_AboutText;
 
-char *freqs[7] = {
+char *card_names[5] = {
+    "Digiface",
+    "Multiface",
+    "HDSP9652",
+    "HDSP9632",
+    "Undefined",
+};
+
+char *freqs[10] = {
     "32.0 kHz",
     "44.1 kHz",
     "48.0 kHz",
     "64.0 kHz",
     "88.2 kHz",
     "96.0 kHz",
-    "-----"
+    "-----",
+    "128.0 kHz",
+    "176.4 kHz",
+    "192.0 kHz",
 };
 
 char *ref[7] = {
@@ -101,8 +111,10 @@ static void refresh_cb(void *arg)
        pane->sync_check->setAdat1Status(config_info.adat_sync_check[0]);
        pane->sync_check->setSpdifStatus(config_info.spdif_sync_check);
        pane->sync_check->setWCStatus(config_info.wordclock_sync_check);
-       pane->sync_check->setAdatSyncStatus(config_info.adatsync_sync_check);
-       if (pane->type != MULTIFACE) {
+       if (pane->type != H9632) {
+           pane->sync_check->setAdatSyncStatus(config_info.adatsync_sync_check);
+       }
+       if (pane->type == Digiface || pane->type == H9652) {
            pane->sync_check->setAdat2Status(config_info.adat_sync_check[1]);
            pane->sync_check->setAdat3Status(config_info.adat_sync_check[2]);
        }
@@ -118,6 +130,15 @@ static void refresh_cb(void *arg)
        pane->autosync_ref->setFreq(config_info.autosync_sample_rate);
        pane->system_clock->setMode(config_info.system_clock_mode);
        pane->system_clock->setFreq(config_info.system_sample_rate);
+       if (pane->type == H9632) {
+           pane->input_level->setInputLevel(config_info.ad_gain);
+           pane->output_level->setOutputLevel(config_info.da_gain);
+           pane->phones->setPhones(config_info.phone_gain);
+           pane->breakout_cable->setXlr(config_info.xlr_breakout_cable);
+       }
+       if (pane->type == H9632 || pane->type == H9652) {
+           pane->aeb->setAdatInternal(config_info.analog_extension_board);
+       }
     }
 
     Fl::add_timeout(0.3, refresh_cb, arg);
@@ -136,7 +157,7 @@ int main(int argc, char **argv)
     Fl_Group  *about_pane;
     char *name;
     int card;
-    int hdsp_cards[4];
+    HDSP_IO_Type hdsp_cards[4];
     int alsa_index[4];
     snd_ctl_t *handle;
     snd_ctl_card_info_t *info;
@@ -146,8 +167,22 @@ int main(int argc, char **argv)
     snd_ctl_card_info_alloca(&info);
     snd_pcm_info_alloca(&pcminfo);    
     card = -1;
-    printf("HDSPConf %s\n", VERSION);
+    printf("\nHDSPConf %s - Copyright (C) 2003 Thomas Charbonnel <thomas@undata.org>\n", VERSION);
+    printf("This program comes WITH ABSOLUTELY NO WARRANTY\n");
+    printf("HDSPConf is free software, see the file copying for details\n\n");
     printf("Looking for HDSP cards :\n");
+
+#ifdef GUI_TEST
+    hdsp_cards[0] = Digiface;
+    alsa_index[0] = 0;
+    hdsp_cards[1] = H9652;
+    alsa_index[1] = 1;
+    hdsp_cards[2] = Multiface;
+    alsa_index[2] = 2;
+    hdsp_cards[3] = H9632;
+    alsa_index[3] = 3;
+    cards = 4;
+#else
     while (snd_card_next(&card) >= 0 && cards < 4) {
        if (card < 0) {
            break;
@@ -156,24 +191,30 @@ int main(int argc, char **argv)
            printf("Card %d : %s\n", card, name);
            if (!strncmp(name, "RME Hammerfall DSP + Multiface", 30)) {
                printf("Multiface found !\n");
-               hdsp_cards[cards] = MULTIFACE;
+               hdsp_cards[cards] = Multiface;
                alsa_index[cards] = card;
                cards++;
            } else if (!strncmp(name, "RME Hammerfall DSP + Digiface", 29)) {
                printf("Digiface found !\n");
-               hdsp_cards[cards] = DIGIFACE;
+               hdsp_cards[cards] = Digiface;
                alsa_index[cards] = card;
                cards++;
            } else if (!strncmp(name, "RME Hammerfall HDSP 9652", 24)) {
                printf("HDSP 9652 found !\n");
-               hdsp_cards[cards] = HDSP9652;
+               hdsp_cards[cards] = H9652;
                alsa_index[cards] = card;
                cards++;
+           } else if (!strncmp(name, "RME Hammerfall HDSP 9632", 24)) {
+               printf("HDSP 9632 found !\n");
+               hdsp_cards[cards] = H9632;
+               alsa_index[cards] = card;
+               cards++;        
            } else if (!strncmp(name, "RME Hammerfall DSP", 18)) {
-               printf("Uninitialized HDSP card found. Use hdsploader to upload firmware.\n");
+               printf("Uninitialized HDSP card found.\nUse hdsploader to upload configuration data to the card.\n");
            }
        }
     }
+#endif
     if (!cards) {
        printf("No Hammerfall DSP card found.\n");
        exit(1);
@@ -187,15 +228,17 @@ int main(int argc, char **argv)
            card_panes[i] = new HC_CardPane(alsa_index[i], i, hdsp_cards[i]);
            tabs->add((Fl_Group *)card_panes[i]);
     }
-    about_pane = new Fl_Group(10, 30, 360, 360, "About");
+    about_pane = new Fl_Group(10, 30, 480, 360, "About");
     about_pane->labelsize(10);
-    about_text = new HC_AboutText(20, 40, 340, 210); 
-    rme_logo = new HC_XpmRenderer(20, 263, 113, 35, rme_xpm);
-    alsa_logo = new HC_XpmRenderer(170, 255, 50, 50, alsalogo_xpm);
-    lad_banner = new HC_XpmRenderer(245, 260, 113, 39, lad_banner_xpm);
+    about_text = new HC_AboutText(80, 70, 440, 210); 
+    rme_logo = new HC_XpmRenderer(60, 328, 113, 35, rme_xpm);
+    alsa_logo = new HC_XpmRenderer(230, 320, 50, 50, alsalogo_xpm);
+    lad_banner = new HC_XpmRenderer(325, 325, 113, 39, lad_banner_xpm);
     about_pane->end();
     tabs->add(about_pane);
+#ifndef GUI_TEST
     refresh_cb((void *)tabs);
+#endif
     window->show(argc, argv);
     return Fl::run();    
 }
diff --git a/hdspconf/src/pixmaps.cxx b/hdspconf/src/pixmaps.cxx
new file mode 100644 (file)
index 0000000..f0d0000
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ *   HDSPConf
+ *    
+ *   Copyright (C) 2003 Thomas Charbonnel (thomas@undata.org)
+ *    
+ *   This program is free software; you can redistribute it and/or modify
+ *   it under the terms of the GNU General Public License as published by
+ *   the Free Software Foundation; either version 2 of the License, or
+ *   (at your option) any later version.
+ *
+ *   This program is distributed in the hope that it will be useful,
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *   GNU General Public License for more details.
+ *
+ *   You should have received a copy of the GNU General Public License
+ *   along with this program; if not, write to the Free Software
+ *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#include "pixmaps.h"
+
+#include "../pixmaps/alsalogo.xpm"
+#include "../pixmaps/lad_banner.xpm"
+#include "../pixmaps/rme.xpm"
+
diff --git a/hdspconf/src/pixmaps.h b/hdspconf/src/pixmaps.h
new file mode 100644 (file)
index 0000000..c193ed2
--- /dev/null
@@ -0,0 +1,29 @@
+/*
+ *   HDSPConf
+ *    
+ *   Copyright (C) 2003 Thomas Charbonnel (thomas@undata.org)
+ *    
+ *   This program is free software; you can redistribute it and/or modify
+ *   it under the terms of the GNU General Public License as published by
+ *   the Free Software Foundation; either version 2 of the License, or
+ *   (at your option) any later version.
+ *
+ *   This program is distributed in the hope that it will be useful,
+ *   but WITHOUT ANY WARRANTY; without even the implied warranty of
+ *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ *   GNU General Public License for more details.
+ *
+ *   You should have received a copy of the GNU General Public License
+ *   along with this program; if not, write to the Free Software
+ *   Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#ifndef pixmaps_H
+#define pixmaps_H
+
+extern char * rme_xpm[];
+extern char * alsalogo_xpm[];
+extern char * lad_banner_xpm[];
+
+#endif
+
index b42a17ac4640e9a2bfe5e480e44d0eef3f365928..54caf7c190f28df0279ade5fee3d43b108480a14 100644 (file)
@@ -1,3 +1,9 @@
+Copyright (C) 1994, 1995, 1996, 1999, 2000, 2001, 2002 Free Software
+Foundation, Inc.
+
+   This file is free documentation; the Free Software Foundation gives
+unlimited permission to copy, distribute and modify it.
+
 Basic Installation
 ==================
 
@@ -8,20 +14,27 @@ various system-dependent variables used during compilation.  It uses
 those values to create a `Makefile' in each directory of the package.
 It may also create one or more `.h' files containing system-dependent
 definitions.  Finally, it creates a shell script `config.status' that
-you can run in the future to recreate the current configuration, a file
-`config.cache' that saves the results of its tests to speed up
-reconfiguring, and a file `config.log' containing compiler output
-(useful mainly for debugging `configure').
+you can run in the future to recreate the current configuration, and a
+file `config.log' containing compiler output (useful mainly for
+debugging `configure').
+
+   It can also use an optional file (typically called `config.cache'
+and enabled with `--cache-file=config.cache' or simply `-C') that saves
+the results of its tests to speed up reconfiguring.  (Caching is
+disabled by default to prevent problems with accidental use of stale
+cache files.)
 
    If you need to do unusual things to compile the package, please try
 to figure out how `configure' could check whether to do them, and mail
 diffs or instructions to the address given in the `README' so they can
-be considered for the next release.  If at some point `config.cache'
-contains results you don't want to keep, you may remove or edit it.
+be considered for the next release.  If you are using the cache, and at
+some point `config.cache' contains results you don't want to keep, you
+may remove or edit it.
 
-   The file `configure.in' is used to create `configure' by a program
-called `autoconf'.  You only need `configure.in' if you want to change
-it or regenerate `configure' using a newer version of `autoconf'.
+   The file `configure.ac' (or `configure.in') is used to create
+`configure' by a program called `autoconf'.  You only need
+`configure.ac' if you want to change it or regenerate `configure' using
+a newer version of `autoconf'.
 
 The simplest way to compile this package is:
 
@@ -55,14 +68,16 @@ Compilers and Options
 =====================
 
    Some systems require unusual options for compilation or linking that
-the `configure' script does not know about.  You can give `configure'
-initial values for variables by setting them in the environment.  Using
-a Bourne-compatible shell, you can do that on the command line like
-this:
-     CC=c89 CFLAGS=-O2 LIBS=-lposix ./configure
+the `configure' script does not know about.  Run `./configure --help'
+for details on some of the pertinent environment variables.
+
+   You can give `configure' initial values for configuration parameters
+by setting variables in the command line or in the environment.  Here
+is an example:
 
-Or on systems that have the `env' program, you can do it like this:
-     env CPPFLAGS=-I/usr/local/include LDFLAGS=-s ./configure
+     ./configure CC=c89 CFLAGS=-O2 LIBS=-lposix
+
+   *Note Defining Variables::, for more details.
 
 Compiling For Multiple Architectures
 ====================================
@@ -75,11 +90,11 @@ directory where you want the object files and executables to go and run
 the `configure' script.  `configure' automatically checks for the
 source code in the directory that `configure' is in and in `..'.
 
-   If you have to use a `make' that does not supports the `VPATH'
-variable, you have to compile the package for one architecture at a time
-in the source code directory.  After you have installed the package for
-one architecture, use `make distclean' before reconfiguring for another
-architecture.
+   If you have to use a `make' that does not support the `VPATH'
+variable, you have to compile the package for one architecture at a
+time in the source code directory.  After you have installed the
+package for one architecture, use `make distclean' before reconfiguring
+for another architecture.
 
 Installation Names
 ==================
@@ -122,22 +137,32 @@ you can use the `configure' options `--x-includes=DIR' and
 Specifying the System Type
 ==========================
 
-   There may be some features `configure' can not figure out
-automatically, but needs to determine by the type of host the package
-will run on.  Usually `configure' can figure that out, but if it prints
-a message saying it can not guess the host type, give it the
-`--host=TYPE' option.  TYPE can either be a short name for the system
-type, such as `sun4', or a canonical name with three fields:
+   There may be some features `configure' cannot figure out
+automatically, but needs to determine by the type of machine the package
+will run on.  Usually, assuming the package is built to be run on the
+_same_ architectures, `configure' can figure that out, but if it prints
+a message saying it cannot guess the machine type, give it the
+`--build=TYPE' option.  TYPE can either be a short name for the system
+type, such as `sun4', or a canonical name which has the form:
+
      CPU-COMPANY-SYSTEM
 
-See the file `config.sub' for the possible values of each field.  If
+where SYSTEM can have one of these forms:
+
+     OS KERNEL-OS
+
+   See the file `config.sub' for the possible values of each field.  If
 `config.sub' isn't included in this package, then this package doesn't
-need to know the host type.
+need to know the machine type.
 
-   If you are building compiler tools for cross-compiling, you can also
+   If you are _building_ compiler tools for cross-compiling, you should
 use the `--target=TYPE' option to select the type of system they will
-produce code for and the `--build=TYPE' option to select the type of
-system on which you are compiling the package.
+produce code for.
+
+   If you want to _use_ a cross compiler, that generates code for a
+platform different from the build platform, you should specify the
+"host" platform (i.e., that on which the generated programs will
+eventually be run) with `--host=TYPE'.
 
 Sharing Defaults
 ================
@@ -150,20 +175,44 @@ default values for variables like `CC', `cache_file', and `prefix'.
 `CONFIG_SITE' environment variable to the location of the site script.
 A warning: not all `configure' scripts look for a site script.
 
-Operation Controls
+Defining Variables
 ==================
 
+   Variables not defined in a site shell script can be set in the
+environment passed to `configure'.  However, some packages may run
+configure again during the build, and the customized values of these
+variables may be lost.  In order to avoid this problem, you should set
+them in the `configure' command line, using `VAR=value'.  For example:
+
+     ./configure CC=/usr/local2/bin/gcc
+
+will cause the specified gcc to be used as the C compiler (unless it is
+overridden in the site shell script).
+
+`configure' Invocation
+======================
+
    `configure' recognizes the following options to control how it
 operates.
 
-`--cache-file=FILE'
-     Use and save the results of the tests in FILE instead of
-     `./config.cache'.  Set FILE to `/dev/null' to disable caching, for
-     debugging `configure'.
-
 `--help'
+`-h'
      Print a summary of the options to `configure', and exit.
 
+`--version'
+`-V'
+     Print the version of Autoconf used to generate the `configure'
+     script, and exit.
+
+`--cache-file=FILE'
+     Enable the cache: use and save the results of the tests in FILE,
+     traditionally `config.cache'.  FILE defaults to `/dev/null' to
+     disable caching.
+
+`--config-cache'
+`-C'
+     Alias for `--cache-file=config.cache'.
+
 `--quiet'
 `--silent'
 `-q'
@@ -175,8 +224,6 @@ operates.
      Look for the package's source code in directory DIR.  Usually
      `configure' can determine that directory automatically.
 
-`--version'
-     Print the version of Autoconf used to generate the `configure'
-     script, and exit.
+`configure' also accepts some other, not widely useful, options.  Run
+`configure --help' for more details.
 
-`configure' also accepts some other, not widely useful, options.
index f7f0a03d5f7e738023ed92b282e7a22fe2b78c47..79add1e1a773070e3db1dcb000ddecda9f817507 100644 (file)
@@ -1,5 +1,5 @@
 AC_INIT(hdsploader.c)
-AM_INIT_AUTOMAKE(hdsploader, 1.1)
+AM_INIT_AUTOMAKE(hdsploader, 1.2)
 AC_PROG_CC
 AC_PROG_INSTALL
 AC_HEADER_STDC
index 49e06878f9ba42622ac1ee1afc21efdb12c89d99..27556ab50a34c262897484250fb709aba5e72489 100644 (file)
@@ -36,7 +36,6 @@ void upload_firmware(int card)
     snd_hwdep_info_t *info;
     char card_name[6];
     hdsp_version_t version;
-    unsigned long *fw;
     
     hdsp_firmware_t firmware;
     hdsp_config_info_t config_info;
@@ -60,16 +59,16 @@ void upload_firmware(int card)
     switch (version.io_type) {
     case Multiface:
        if (version.firmware_rev == 0xa) {
-           fw = multiface_firmware;
+           firmware.firmware_data = multiface_firmware;
        } else {
-           fw = multiface_firmware_rev11;
+           firmware.firmware_data = multiface_firmware_rev11;
        }
        break;
     case Digiface:
        if (version.firmware_rev == 0xa) {
-           fw = digiface_firmware;
+           firmware.firmware_data = digiface_firmware;
        } else {
-           fw = digiface_firmware_rev11;
+           firmware.firmware_data = digiface_firmware_rev11;
        }
        break;
     default:
@@ -78,8 +77,6 @@ void upload_firmware(int card)
        return;
     }  
     
-    firmware.firmware_data = fw;
-    
     if ((err = snd_hwdep_ioctl(hw, SNDRV_HDSP_IOCTL_UPLOAD_FIRMWARE, &firmware)) < 0) {
        fprintf(stderr, "Hwdep ioctl error on card %s : %s.\n", card_name, snd_strerror(err));
        snd_hwdep_close(hw);