// This small util discovers your audio driver's behaviour #include #include #include #include #include #include #include #define OUTBURST 256 // Returns current time in microseconds unsigned int GetTimer(){ struct timeval tv; struct timezone tz; // float s; gettimeofday(&tv,&tz); // s=tv.tv_usec;s*=0.000001;s+=tv.tv_sec; return (tv.tv_sec*1000000+tv.tv_usec); } static unsigned char a_buffer[OUTBURST]; int main(){ int audio_buffer_size=0; int r; int xxx=1024*2; int audio_fd; char *dsp="/dev/dsp"; unsigned int t1,t2; audio_fd=open(dsp, O_WRONLY); if(audio_fd<0){ printf("Can't open audio device %s\n",dsp); return 1; } r=AFMT_S16_LE;ioctl (audio_fd, SNDCTL_DSP_SETFMT, &r); r=1; ioctl (audio_fd, SNDCTL_DSP_STEREO, &r); r=44100; if(ioctl (audio_fd, SNDCTL_DSP_SPEED, &r)==-1) printf("audio_setup: your card doesn't support %d Hz samplerate\n",r); t1=GetTimer(); while(xxx-->0){ r=write(audio_fd,a_buffer,OUTBURST); t2=GetTimer(); if(r<0) printf("Error writting to device\n"); else if(r==0) printf("EOF writting to device???\n"); else { printf("[%6d] writting %3d of %3d bytes in %7d us\n",audio_buffer_size,r,OUTBURST,t2-t1); audio_buffer_size+=r; } t1=t2; } close(audio_fd); return 0; }