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:
riccardom 2009-07-11 14:21:09 +00:00
parent b6c16bdb0c
commit f63909b1d9
6 changed files with 139 additions and 2 deletions

View File

@ -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"])

View File

@ -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

View File

@ -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;

View File

@ -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)
{ {

View File

@ -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

111
desmume/src/mic_alsa.cpp Normal file
View File

@ -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;
}