mirror of
https://github.com/alsa-project/alsa-lib.git
synced 2025-12-16 08:56:42 -05:00
PCM changes (record->capture)...
This commit is contained in:
parent
fd672765f4
commit
dc126564c7
8 changed files with 57 additions and 57 deletions
|
|
@ -14,14 +14,14 @@ static char *xitoa(int aaa)
|
|||
|
||||
/*
|
||||
* This small demo program can be used for measuring latency between
|
||||
* record and playback. This latency is measured from driver (diff when
|
||||
* playback and record was started). Scheduler is set to SCHED_RR.
|
||||
* capture and playback. This latency is measured from driver (diff when
|
||||
* playback and capture was started). Scheduler is set to SCHED_RR.
|
||||
*
|
||||
* Used format is 44100Hz, Signed Little Endian 16-bit, Stereo.
|
||||
*
|
||||
* Program begins with 128-byte fragment (about 726us) and step is 32-byte
|
||||
* until playback without underruns is reached. This program starts playback
|
||||
* after two fragments are recorded (teoretical latency is 1452us by 128-byte
|
||||
* after two fragments are captureed (teoretical latency is 1452us by 128-byte
|
||||
* fragment).
|
||||
*/
|
||||
|
||||
|
|
@ -38,7 +38,7 @@ void setformat(void *phandle, void *rhandle)
|
|||
printf("Playback format error: %s\n", snd_strerror(err));
|
||||
exit(0);
|
||||
}
|
||||
if ((err = snd_pcm_record_format(rhandle, &format)) < 0) {
|
||||
if ((err = snd_pcm_capture_format(rhandle, &format)) < 0) {
|
||||
printf("Record format error: %s\n", snd_strerror(err));
|
||||
exit(0);
|
||||
}
|
||||
|
|
@ -46,7 +46,7 @@ void setformat(void *phandle, void *rhandle)
|
|||
printf("Playback time error: %s\n", snd_strerror(err));
|
||||
exit(0);
|
||||
}
|
||||
if ((err = snd_pcm_record_time(rhandle, 1)) < 0) {
|
||||
if ((err = snd_pcm_capture_time(rhandle, 1)) < 0) {
|
||||
printf("Record time error: %s\n", snd_strerror(err));
|
||||
exit(0);
|
||||
}
|
||||
|
|
@ -56,15 +56,15 @@ int setparams(void *phandle, void *rhandle, int *fragmentsize)
|
|||
{
|
||||
int err, step = 4;
|
||||
snd_pcm_playback_info_t pinfo;
|
||||
snd_pcm_record_info_t rinfo;
|
||||
snd_pcm_capture_info_t rinfo;
|
||||
snd_pcm_playback_params_t pparams;
|
||||
snd_pcm_record_params_t rparams;
|
||||
snd_pcm_capture_params_t rparams;
|
||||
|
||||
if ((err = snd_pcm_playback_info(phandle, &pinfo)) < 0) {
|
||||
printf("Playback info error: %s\n", snd_strerror(err));
|
||||
exit(0);
|
||||
}
|
||||
if ((err = snd_pcm_record_info(rhandle, &rinfo)) < 0) {
|
||||
if ((err = snd_pcm_capture_info(rhandle, &rinfo)) < 0) {
|
||||
printf("Record info error: %s\n", snd_strerror(err));
|
||||
exit(0);
|
||||
}
|
||||
|
|
@ -96,7 +96,7 @@ int setparams(void *phandle, void *rhandle, int *fragmentsize)
|
|||
bzero(&rparams, sizeof(rparams));
|
||||
rparams.fragment_size = *fragmentsize;
|
||||
rparams.fragments_min = 1; /* wakeup if at least one fragment is ready */
|
||||
if ((err = snd_pcm_record_params(rhandle, &rparams)) < 0) {
|
||||
if ((err = snd_pcm_capture_params(rhandle, &rparams)) < 0) {
|
||||
*fragmentsize += step;
|
||||
continue;
|
||||
}
|
||||
|
|
@ -122,7 +122,7 @@ int playbackunderrun(void *phandle)
|
|||
return pstatus.underrun;
|
||||
}
|
||||
|
||||
void recordfragment(void *rhandle, char *buffer, int index, int fragmentsize)
|
||||
void capturefragment(void *rhandle, char *buffer, int index, int fragmentsize)
|
||||
{
|
||||
int err;
|
||||
|
||||
|
|
@ -184,14 +184,14 @@ int main(void)
|
|||
int err, fragmentsize = 0;
|
||||
int ridx, pidx, size, ok;
|
||||
snd_pcm_playback_status_t pstatus;
|
||||
snd_pcm_record_status_t rstatus;
|
||||
snd_pcm_capture_status_t rstatus;
|
||||
|
||||
setscheduler();
|
||||
if ((err = snd_pcm_open(&phandle, pcard, pdevice, SND_PCM_OPEN_PLAYBACK)) < 0) {
|
||||
printf("Playback open error: %s\n", snd_strerror(err));
|
||||
return 0;
|
||||
}
|
||||
if ((err = snd_pcm_open(&rhandle, rcard, rdevice, SND_PCM_OPEN_RECORD)) < 0) {
|
||||
if ((err = snd_pcm_open(&rhandle, rcard, rdevice, SND_PCM_OPEN_CAPTURE)) < 0) {
|
||||
printf("Record open error: %s\n", snd_strerror(err));
|
||||
return 0;
|
||||
}
|
||||
|
|
@ -201,9 +201,9 @@ int main(void)
|
|||
break;
|
||||
ok = 1;
|
||||
ridx = pidx = size = 0;
|
||||
recordfragment(rhandle, buffer, ridx++, fragmentsize);
|
||||
recordfragment(rhandle, buffer, ridx++, fragmentsize);
|
||||
if ((err = snd_pcm_record_status(rhandle, &rstatus)) < 0) {
|
||||
capturefragment(rhandle, buffer, ridx++, fragmentsize);
|
||||
capturefragment(rhandle, buffer, ridx++, fragmentsize);
|
||||
if ((err = snd_pcm_capture_status(rhandle, &rstatus)) < 0) {
|
||||
printf("Record status error: %s\n", snd_strerror(err));
|
||||
exit(0);
|
||||
}
|
||||
|
|
@ -213,7 +213,7 @@ int main(void)
|
|||
pidx += 2;
|
||||
pidx %= 2;
|
||||
while (ok && size < 3 * 176400) { /* 30 seconds */
|
||||
recordfragment(rhandle, buffer, ridx++, fragmentsize);
|
||||
capturefragment(rhandle, buffer, ridx++, fragmentsize);
|
||||
ridx %= 2;
|
||||
playfragment(phandle, buffer, pidx++, fragmentsize);
|
||||
size += fragmentsize;
|
||||
|
|
@ -225,7 +225,7 @@ int main(void)
|
|||
printf("Playback status error: %s\n", snd_strerror(err));
|
||||
exit(0);
|
||||
}
|
||||
snd_pcm_flush_record(rhandle);
|
||||
snd_pcm_flush_capture(rhandle);
|
||||
snd_pcm_flush_playback(phandle);
|
||||
if (ok && !playbackunderrun(phandle) > 0) {
|
||||
printf("Playback OK!!!\n");
|
||||
|
|
|
|||
10
test/pcm.c
10
test/pcm.c
|
|
@ -24,7 +24,7 @@ void setformat(void *phandle, void *rhandle)
|
|||
if ((err = snd_pcm_playback_format(phandle, &format)) < 0) {
|
||||
printf("Playback format error: %s\n", snd_strerror(err));
|
||||
}
|
||||
if ((err = snd_pcm_record_format(rhandle, &format)) < 0) {
|
||||
if ((err = snd_pcm_capture_format(rhandle, &format)) < 0) {
|
||||
printf("Record format error: %s\n", snd_strerror(err));
|
||||
}
|
||||
}
|
||||
|
|
@ -39,7 +39,7 @@ void method1(void)
|
|||
printf("Playback open error: %s\n", snd_strerror(err));
|
||||
return;
|
||||
}
|
||||
if ((err = snd_pcm_open(&rhandle, 0, 0, SND_PCM_OPEN_RECORD)) < 0) {
|
||||
if ((err = snd_pcm_open(&rhandle, 0, 0, SND_PCM_OPEN_CAPTURE)) < 0) {
|
||||
printf("Record open error: %s\n", snd_strerror(err));
|
||||
return;
|
||||
}
|
||||
|
|
@ -74,7 +74,7 @@ void method2(void)
|
|||
printf("Playback open error: %s\n", snd_strerror(err));
|
||||
return;
|
||||
}
|
||||
if ((err = snd_pcm_open(&rhandle, 0, 0, SND_PCM_OPEN_RECORD)) < 0) {
|
||||
if ((err = snd_pcm_open(&rhandle, 0, 0, SND_PCM_OPEN_CAPTURE)) < 0) {
|
||||
printf("Record open error: %s\n", snd_strerror(err));
|
||||
return;
|
||||
}
|
||||
|
|
@ -86,7 +86,7 @@ void method2(void)
|
|||
return;
|
||||
}
|
||||
printf("done...\n");
|
||||
if ((err = snd_pcm_flush_record(rhandle)) < 0) {
|
||||
if ((err = snd_pcm_flush_capture(rhandle)) < 0) {
|
||||
printf("Record flush error: %s\n", snd_strerror(err));
|
||||
return;
|
||||
}
|
||||
|
|
@ -127,7 +127,7 @@ void method3(void)
|
|||
return;
|
||||
}
|
||||
printf("done...\n");
|
||||
if ((err = snd_pcm_flush_record(handle)) < 0) {
|
||||
if ((err = snd_pcm_flush_capture(handle)) < 0) {
|
||||
printf("Record flush error: %s\n", snd_strerror(err));
|
||||
return;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -40,7 +40,7 @@ const char *get_interface(void)
|
|||
case 2:
|
||||
return "PCM playback";
|
||||
case 3:
|
||||
return "PCM record";
|
||||
return "PCM capture";
|
||||
case 4:
|
||||
return "rawmidi output";
|
||||
case 5:
|
||||
|
|
@ -60,7 +60,7 @@ int switch_list(snd_switch_list_t *list)
|
|||
case 2:
|
||||
return snd_ctl_pcm_playback_switch_list(ctl_handle, sw_device, list);
|
||||
case 3:
|
||||
return snd_ctl_pcm_record_switch_list(ctl_handle, sw_device, list);
|
||||
return snd_ctl_pcm_capture_switch_list(ctl_handle, sw_device, list);
|
||||
case 4:
|
||||
return snd_ctl_rawmidi_output_switch_list(ctl_handle, sw_device, list);
|
||||
case 5:
|
||||
|
|
@ -80,7 +80,7 @@ int switch_read(snd_switch_t *sw)
|
|||
case 2:
|
||||
return snd_ctl_pcm_playback_switch_read(ctl_handle, sw_device, sw);
|
||||
case 3:
|
||||
return snd_ctl_pcm_record_switch_write(ctl_handle, sw_device, sw);
|
||||
return snd_ctl_pcm_capture_switch_write(ctl_handle, sw_device, sw);
|
||||
case 4:
|
||||
return snd_ctl_rawmidi_output_switch_read(ctl_handle, sw_device, sw);
|
||||
case 5:
|
||||
|
|
@ -100,7 +100,7 @@ int switch_write(snd_switch_t *sw)
|
|||
case 2:
|
||||
return snd_ctl_pcm_playback_switch_write(ctl_handle, sw_device, sw);
|
||||
case 3:
|
||||
return snd_ctl_pcm_record_switch_write(ctl_handle, sw_device, sw);
|
||||
return snd_ctl_pcm_capture_switch_write(ctl_handle, sw_device, sw);
|
||||
case 4:
|
||||
return snd_ctl_rawmidi_output_switch_write(ctl_handle, sw_device, sw);
|
||||
case 5:
|
||||
|
|
@ -195,7 +195,7 @@ int main(void)
|
|||
process(" ", "Mixer", 1, idx);
|
||||
for (idx = 0; idx < info.pcmdevs; idx++) {
|
||||
process(" ", "PCM playback", 2, idx);
|
||||
process(" ", "PCM record", 3, idx);
|
||||
process(" ", "PCM capture", 3, idx);
|
||||
}
|
||||
snd_ctl_close(ctl_handle);
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue