libsent/src/adin/adin_mic_linux_alsa.c

マイク入力 (Linux/ALSA) [詳細]

#include <sent/stddefs.h>
#include <sent/adin.h>
#include <sys/ioctl.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <alsa/asoundlib.h>

ソースコードを見る。

関数

boolean adin_mic_standby (int sfreq, void *dummy)
 Device initialization: check device capability and open for recording.
static int xrun_recovery (snd_pcm_t *handle, int err)
 Error recovery when PCM buffer underrun or suspend.
boolean adin_mic_begin ()
 Start recording.
boolean adin_mic_end ()
 Stop recording.
int adin_mic_read (SP16 *buf, int sampnum)
 Read samples from device

変数

static snd_pcm_t * handle
 Audio handler
static snd_pcm_hw_params_t * hwparams
 Pointer to device hardware parameters
static char * pcm_name = "hw:0,0"
 Name of the PCM device
static boolean need_swap
 Whether samples need byte swap
static int latency = 32
 Lantency time in msec. You can override this value by specifying environment valuable "LATENCY_MSEC".
static struct pollfd * ufds
 Poll descriptor
static int count
 Poll descriptor count


説明

マイク入力 (Linux/ALSA)

ALSA API を使用する,マイク入力のための低レベル関数です. 使用には ALSA サウンドドライバーがインストールされていることが必要です. 使用するには configure 時に "--with-mictype=alsa" を指定して下さい.

サウンドカードが 16bit モノラル で録音できることが必須です.

JuliusはLinuxではミキサーデバイスの設定を一切行いません.録音デバイスの 選択(マイク/ライン)や録音ボリュームの調節は alsamixer など他のツールで 行なって下さい.

複数サウンドカードはサポートされていません.複数のサウンドカードが インストールされている場合,最初の1つが用いられます.

参照:
http://www.alsa-project.org/
作者:
Akinobu LEE
日付:
Sun Feb 13 16:18:26 2005
Revision
1.1.1.1

adin_mic_linux_alsa.c で定義されています。


関数

boolean adin_mic_standby ( int  sfreq,
void *  dummy 
)

Device initialization: check device capability and open for recording.

Connection initialization: check connectivity and open for recording.

引数:
sfreq [in] required sampling frequency.
dummy [in] a dummy data
戻り値:
TRUE on success, FALSE on failure.

adin_mic_linux_alsa.c81 行で定義されています。

static int xrun_recovery ( snd_pcm_t *  handle,
int  err 
) [static]

Error recovery when PCM buffer underrun or suspend.

引数:
handle [in] audio handler
err [in] error code
戻り値:
0 on success, otherwise the given errno.

adin_mic_linux_alsa.c287 行で定義されています。

boolean adin_mic_begin (  ) 

Start recording.

戻り値:
TRUE on success, FALSE on failure.

adin_mic_linux_alsa.c313 行で定義されています。

boolean adin_mic_end (  ) 

Stop recording.

戻り値:
TRUE on success, FALSE on failure.

adin_mic_linux_alsa.c359 行で定義されています。

int adin_mic_read ( SP16 buf,
int  sampnum 
)

Read samples from device

Read samples from the daemon.

Try to read sampnum samples and returns actual number of recorded samples currently available. This function will block until at least one sample can be obtained.

引数:
buf [out] samples obtained in this function
sampnum [in] wanted number of samples to be read
戻り値:
actural number of read samples, -2 if an error occured.

adin_mic_linux_alsa.c377 行で定義されています。


Juliusに対してTue Dec 18 16:05:03 2007に生成されました。  doxygen 1.5.4