Add the alsa microphone implementation done by Heptaeon and posted in the
forum. Dear contributors please don't do that, write to the list, come on irc, post a patch in sf.net instead. Anyway this is made the default if you have alsa, tested a bit and haven't managed to get it working. Since I don't know if it is our bad or common code issue please test and maybe report back on irc.
This commit is contained in:
parent
b6c16bdb0c
commit
f63909b1d9
|
@ -89,6 +89,7 @@ fi
|
||||||
|
|
||||||
dnl - Check for GTK and/or libglade
|
dnl - Check for GTK and/or libglade
|
||||||
FOUND_GLIB=no
|
FOUND_GLIB=no
|
||||||
|
HAVE_ALSA=no
|
||||||
GLIB_VER=2.8
|
GLIB_VER=2.8
|
||||||
GTK_VER=2.6
|
GTK_VER=2.6
|
||||||
AC_CHECK_TOOL(HAVE_PKG, pkg-config)
|
AC_CHECK_TOOL(HAVE_PKG, pkg-config)
|
||||||
|
@ -142,6 +143,10 @@ AC_PROVIDE_IFELSE([PKG_PROG_PKG_CONFIG], [
|
||||||
HAVE_LUA=no)
|
HAVE_LUA=no)
|
||||||
AC_SUBST(LUA_CFLAGS)
|
AC_SUBST(LUA_CFLAGS)
|
||||||
AC_SUBST(LUA_LIBS)
|
AC_SUBST(LUA_LIBS)
|
||||||
|
|
||||||
|
PKG_CHECK_MODULES(ALSA, alsa >= 1.0, HAVE_ALSA=yes, HAVE_ALSA=no)
|
||||||
|
AC_SUBST(ALSA_CFLAGS)
|
||||||
|
AC_SUBST(ALSA_LIBS)
|
||||||
fi
|
fi
|
||||||
],[
|
],[
|
||||||
echo "WARNING: pkg-config is not available therefore gtk, gtk-glade UIs and lua scripting are not available either."
|
echo "WARNING: pkg-config is not available therefore gtk, gtk-glade UIs and lua scripting are not available either."
|
||||||
|
@ -150,6 +155,11 @@ AC_PROVIDE_IFELSE([PKG_PROG_PKG_CONFIG], [
|
||||||
dnl -- force lua disabled
|
dnl -- force lua disabled
|
||||||
AM_CONDITIONAL([HAVE_LUA], [test "${HAVE_LUA}x" = "yes"])
|
AM_CONDITIONAL([HAVE_LUA], [test "${HAVE_LUA}x" = "yes"])
|
||||||
|
|
||||||
|
AM_CONDITIONAL([HAVE_ALSA], [test "${HAVE_ALSA}" = "yes"])
|
||||||
|
if test "x$HAVE_ALSA" = "xno"; then
|
||||||
|
AC_DEFINE([FAKE_MIC])
|
||||||
|
fi
|
||||||
|
|
||||||
dnl - set conditional for glib, needed to avoid commandline.cpp compilation for cli frontend since it depends on glib
|
dnl - set conditional for glib, needed to avoid commandline.cpp compilation for cli frontend since it depends on glib
|
||||||
AM_CONDITIONAL([HAVE_GLIB], [test "${FOUND_GLIB}" = "yes"])
|
AM_CONDITIONAL([HAVE_GLIB], [test "${FOUND_GLIB}" = "yes"])
|
||||||
|
|
||||||
|
|
|
@ -55,13 +55,17 @@ libdesmume_a_SOURCES = \
|
||||||
agg/src/agg_trans_affine.cpp agg/src/agg_trans_double_path.cpp agg/src/agg_trans_single_path.cpp agg/src/agg_trans_warp_magnifier.cpp \
|
agg/src/agg_trans_affine.cpp agg/src/agg_trans_double_path.cpp agg/src/agg_trans_single_path.cpp agg/src/agg_trans_warp_magnifier.cpp \
|
||||||
agg/src/agg_vcgen_bspline.cpp agg/src/agg_vcgen_contour.cpp agg/src/agg_vcgen_dash.cpp agg/src/agg_vcgen_markers_term.cpp agg/src/agg_vcgen_smooth_poly1.cpp agg/src/agg_vcgen_stroke.cpp \
|
agg/src/agg_vcgen_bspline.cpp agg/src/agg_vcgen_contour.cpp agg/src/agg_vcgen_dash.cpp agg/src/agg_vcgen_markers_term.cpp agg/src/agg_vcgen_smooth_poly1.cpp agg/src/agg_vcgen_stroke.cpp \
|
||||||
agg/src/agg_vpgen_clip_polygon.cpp agg/src/agg_vpgen_clip_polyline.cpp agg/src/agg_vpgen_segmentator \
|
agg/src/agg_vpgen_clip_polygon.cpp agg/src/agg_vpgen_clip_polyline.cpp agg/src/agg_vpgen_segmentator \
|
||||||
mic.cpp mic.h \
|
|
||||||
cheatSystem.cpp cheatSystem.h \
|
cheatSystem.cpp cheatSystem.h \
|
||||||
texcache.cpp texcache.h rasterize.cpp rasterize.h \
|
texcache.cpp texcache.h rasterize.cpp rasterize.h \
|
||||||
version.h
|
version.h
|
||||||
if HAVE_GLIB
|
if HAVE_GLIB
|
||||||
libdesmume_a_SOURCES += commandline.h commandline.cpp
|
libdesmume_a_SOURCES += commandline.h commandline.cpp
|
||||||
endif
|
endif
|
||||||
|
if HAVE_ALSA
|
||||||
|
libdesmume_a_SOURCES += mic_alsa.cpp
|
||||||
|
else
|
||||||
|
libdesmume_a_SOURCES += mic.cpp
|
||||||
|
endif
|
||||||
if HAVE_LUA
|
if HAVE_LUA
|
||||||
libdesmume_a_SOURCES += lua-engine.cpp
|
libdesmume_a_SOURCES += lua-engine.cpp
|
||||||
endif
|
endif
|
||||||
|
|
|
@ -684,10 +684,12 @@ static void desmume_cycle(int *sdl_quit, int *boost, struct my_config * my_confi
|
||||||
case SDLK_ESCAPE:
|
case SDLK_ESCAPE:
|
||||||
*sdl_quit = 1;
|
*sdl_quit = 1;
|
||||||
break;
|
break;
|
||||||
|
#ifdef FAKE_MIC
|
||||||
case SDLK_m:
|
case SDLK_m:
|
||||||
enable_fake_mic = !enable_fake_mic;
|
enable_fake_mic = !enable_fake_mic;
|
||||||
Mic_DoNoise(enable_fake_mic);
|
Mic_DoNoise(enable_fake_mic);
|
||||||
break;
|
break;
|
||||||
|
#endif
|
||||||
case SDLK_o:
|
case SDLK_o:
|
||||||
*boost = !(*boost);
|
*boost = !(*boost);
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -111,7 +111,9 @@ static void ToggleMenuVisible(GtkToggleAction *action);
|
||||||
static void ToggleStatusbarVisible(GtkToggleAction *action);
|
static void ToggleStatusbarVisible(GtkToggleAction *action);
|
||||||
static void ToggleToolbarVisible(GtkToggleAction *action);
|
static void ToggleToolbarVisible(GtkToggleAction *action);
|
||||||
static void ToggleAudio (GtkToggleAction *action);
|
static void ToggleAudio (GtkToggleAction *action);
|
||||||
|
#ifdef FAKE_MIC
|
||||||
static void ToggleMicNoise (GtkToggleAction *action);
|
static void ToggleMicNoise (GtkToggleAction *action);
|
||||||
|
#endif
|
||||||
static void ToggleGap (GtkToggleAction *action);
|
static void ToggleGap (GtkToggleAction *action);
|
||||||
static void SetRotation (GtkAction *action);
|
static void SetRotation (GtkAction *action);
|
||||||
static void ToggleLayerVisibility(GtkToggleAction* action, gpointer data);
|
static void ToggleLayerVisibility(GtkToggleAction* action, gpointer data);
|
||||||
|
@ -167,7 +169,9 @@ static const char *ui_description =
|
||||||
" <menuitem action='pause'/>"
|
" <menuitem action='pause'/>"
|
||||||
" <menuitem action='reset'/>"
|
" <menuitem action='reset'/>"
|
||||||
" <menuitem action='enableaudio'/>"
|
" <menuitem action='enableaudio'/>"
|
||||||
|
#ifdef FAKE_MIC
|
||||||
" <menuitem action='micnoise'/>"
|
" <menuitem action='micnoise'/>"
|
||||||
|
#endif
|
||||||
" <menu action='FrameskipMenu'>"
|
" <menu action='FrameskipMenu'>"
|
||||||
" <menuitem action='frameskip0'/>"
|
" <menuitem action='frameskip0'/>"
|
||||||
" <menuitem action='frameskip1'/>"
|
" <menuitem action='frameskip1'/>"
|
||||||
|
@ -285,7 +289,9 @@ static const GtkActionEntry action_entries[] = {
|
||||||
|
|
||||||
static const GtkToggleActionEntry toggle_entries[] = {
|
static const GtkToggleActionEntry toggle_entries[] = {
|
||||||
{ "enableaudio", NULL, "_Enable audio", NULL, NULL, G_CALLBACK(ToggleAudio), TRUE},
|
{ "enableaudio", NULL, "_Enable audio", NULL, NULL, G_CALLBACK(ToggleAudio), TRUE},
|
||||||
|
#ifdef FAKE_MIC
|
||||||
{ "micnoise", NULL, "Fake mic _noise", NULL, NULL, G_CALLBACK(ToggleMicNoise), FALSE},
|
{ "micnoise", NULL, "Fake mic _noise", NULL, NULL, G_CALLBACK(ToggleMicNoise), FALSE},
|
||||||
|
#endif
|
||||||
{ "gap", NULL, "_Gap", NULL, NULL, G_CALLBACK(ToggleGap), FALSE},
|
{ "gap", NULL, "_Gap", NULL, NULL, G_CALLBACK(ToggleGap), FALSE},
|
||||||
{ "view_menu", NULL, "View _menu", NULL, NULL, G_CALLBACK(ToggleMenuVisible), TRUE},
|
{ "view_menu", NULL, "View _menu", NULL, NULL, G_CALLBACK(ToggleMenuVisible), TRUE},
|
||||||
{ "view_toolbar", NULL, "View _toolbar", NULL, NULL, G_CALLBACK(ToggleToolbarVisible), TRUE},
|
{ "view_toolbar", NULL, "View _toolbar", NULL, NULL, G_CALLBACK(ToggleToolbarVisible), TRUE},
|
||||||
|
@ -1672,10 +1678,12 @@ static void ToggleAudio (GtkToggleAction *action)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef FAKE_MIC
|
||||||
static void ToggleMicNoise (GtkToggleAction *action)
|
static void ToggleMicNoise (GtkToggleAction *action)
|
||||||
{
|
{
|
||||||
Mic_DoNoise((BOOL)gtk_toggle_action_get_active(action));
|
Mic_DoNoise((BOOL)gtk_toggle_action_get_active(action));
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
static void desmume_gtk_menu_tools (GtkActionGroup *ag)
|
static void desmume_gtk_menu_tools (GtkActionGroup *ag)
|
||||||
{
|
{
|
||||||
|
|
|
@ -7,7 +7,9 @@ extern int MicButtonPressed;
|
||||||
static char MicSampleName[256];
|
static char MicSampleName[256];
|
||||||
char* LoadSample(const char *name);
|
char* LoadSample(const char *name);
|
||||||
extern int MicDisplay;
|
extern int MicDisplay;
|
||||||
#else
|
#endif
|
||||||
|
|
||||||
|
#ifdef FAKE_MIC
|
||||||
void Mic_DoNoise(BOOL);
|
void Mic_DoNoise(BOOL);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,111 @@
|
||||||
|
#include <alsa/asoundlib.h>
|
||||||
|
#include "types.h"
|
||||||
|
#include "mic.h"
|
||||||
|
|
||||||
|
#define MIC_BUFSIZE 4096
|
||||||
|
|
||||||
|
BOOL Mic_Inited = FALSE;
|
||||||
|
u8 Mic_Buffer[2][MIC_BUFSIZE];
|
||||||
|
u16 Mic_BufPos;
|
||||||
|
u8 Mic_PlayBuf;
|
||||||
|
|
||||||
|
int MicButtonPressed;
|
||||||
|
|
||||||
|
// Handle for the PCM device
|
||||||
|
static snd_pcm_t *pcm_handle;
|
||||||
|
|
||||||
|
BOOL Mic_Init()
|
||||||
|
{
|
||||||
|
snd_pcm_hw_params_t *hwparams;
|
||||||
|
|
||||||
|
if (Mic_Inited)
|
||||||
|
return TRUE;
|
||||||
|
|
||||||
|
// Open the default sound card in capture
|
||||||
|
if (snd_pcm_open(&pcm_handle, "default", SND_PCM_STREAM_CAPTURE, 0) < 0)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
// Allocate the snd_pcm_hw_params_t structure and fill it.
|
||||||
|
snd_pcm_hw_params_alloca(&hwparams);
|
||||||
|
if (snd_pcm_hw_params_any(pcm_handle, hwparams) < 0)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
//Set the access
|
||||||
|
if (snd_pcm_hw_params_set_access(pcm_handle, hwparams, SND_PCM_ACCESS_RW_INTERLEAVED) < 0)
|
||||||
|
return FALSE ;
|
||||||
|
|
||||||
|
//dir 0 == exacte (Rate = 16K exacte)
|
||||||
|
if (snd_pcm_hw_params_set_rate(pcm_handle, hwparams, 16000, 0) < 0)
|
||||||
|
return FALSE;
|
||||||
|
/* Set sample format */
|
||||||
|
if (snd_pcm_hw_params_set_format(pcm_handle, hwparams, SND_PCM_FORMAT_S8) < 0)
|
||||||
|
return FALSE;
|
||||||
|
// Set one channel (mono)
|
||||||
|
if (snd_pcm_hw_params_set_channels(pcm_handle, hwparams, 1) < 0)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
// Set 2 periods
|
||||||
|
if (snd_pcm_hw_params_set_periods(pcm_handle, hwparams, 2, 0) < 0)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
// Set the buffer sise
|
||||||
|
if (snd_pcm_hw_params_set_buffer_size(pcm_handle, hwparams, MIC_BUFSIZE) < 0)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
//Set the params
|
||||||
|
if (snd_pcm_hw_params(pcm_handle, hwparams) < 0)
|
||||||
|
return FALSE;
|
||||||
|
|
||||||
|
Mic_Inited = TRUE;
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Mic_Reset()
|
||||||
|
{
|
||||||
|
if (!Mic_Inited)
|
||||||
|
return;
|
||||||
|
|
||||||
|
memset(Mic_Buffer[0], 0, MIC_BUFSIZE);
|
||||||
|
memset(Mic_Buffer[1], 0, MIC_BUFSIZE);
|
||||||
|
Mic_BufPos = 0;
|
||||||
|
|
||||||
|
Mic_PlayBuf = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Mic_DeInit()
|
||||||
|
{
|
||||||
|
if (!Mic_Inited)
|
||||||
|
return;
|
||||||
|
|
||||||
|
Mic_Inited = FALSE;
|
||||||
|
|
||||||
|
snd_pcm_drop(pcm_handle);
|
||||||
|
snd_pcm_close(pcm_handle);
|
||||||
|
}
|
||||||
|
|
||||||
|
u8 Mic_ReadSample()
|
||||||
|
{
|
||||||
|
u8 tmp;
|
||||||
|
u8 ret;
|
||||||
|
|
||||||
|
if (!Mic_Inited)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
tmp = Mic_Buffer[Mic_PlayBuf][Mic_BufPos >> 1];
|
||||||
|
|
||||||
|
if (Mic_BufPos & 0x1) {
|
||||||
|
ret = ((tmp & 0x1) << 7);
|
||||||
|
} else {
|
||||||
|
ret = ((tmp & 0xFE) >> 1);
|
||||||
|
}
|
||||||
|
|
||||||
|
Mic_BufPos++;
|
||||||
|
if (Mic_BufPos >= (MIC_BUFSIZE << 1)) {
|
||||||
|
Mic_BufPos = 0;
|
||||||
|
snd_pcm_readi(pcm_handle, Mic_Buffer[Mic_PlayBuf], MIC_BUFSIZE);
|
||||||
|
Mic_PlayBuf ^= 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
Loading…
Reference in New Issue