diff spandsp-0.0.3/user/sample.c @ 5:f762bf195c4b

import spandsp-0.0.3
author Peter Meerwald <pmeerw@cosy.sbg.ac.at>
date Fri, 25 Jun 2010 16:00:21 +0200
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/spandsp-0.0.3/user/sample.c	Fri Jun 25 16:00:21 2010 +0200
@@ -0,0 +1,148 @@
+/*
+  sample.c
+  David Rowe 14 December 2006
+
+  User mode side of zaptel echo sampling system.
+
+  Compile:
+  
+    gcc sample.c -o sample -Wall
+*/
+
+/*
+  Copyright (C) 2007 David Rowe
+ 
+  All rights reserved.
+ 
+  This program is free software; you can redistribute it and/or modify
+  it under the terms of the GNU General Public License version 2, as
+  published by the Free Software Foundation.
+ 
+  This program is distributed in the hope that it will be useful,
+  but WITHOUT ANY WARRANTY; without even the implied warranty of
+  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+  GNU General Public License for more details.
+ 
+  You should have received a copy of the GNU General Public License
+  along with this program; if not, write to the Free Software
+  Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+*/
+
+#include <sys/types.h>
+#include <sys/stat.h>
+#include <fcntl.h>
+#include <sys/ioctl.h>
+#include <unistd.h>
+#include <stdio.h>
+#include <string.h>
+#include <stdlib.h>
+
+#define SAMPLE_BUF_SZ 1000
+#define FS            8000
+#define MAX_STR       256
+#define ZT_CHUNKSIZE  8
+
+/* ioctls for sample */
+
+#define SAMPLE_SET_CHANNEL 0
+#define SAMPLE_TX_IMPULSE  1
+
+int main(int argc, char *argv[]) {
+	int    fd, len, i, j, frames;
+	short  buf[3*SAMPLE_BUF_SZ];
+	short  txbuf[SAMPLE_BUF_SZ];
+	short  rxbuf[SAMPLE_BUF_SZ];
+	short  ecbuf[SAMPLE_BUF_SZ];
+	FILE  *ftx, *frx, *fec;
+	float  secs;
+        int    sample_ch;
+        char   filename[MAX_STR];
+	short  *pbuf, *ptxbuf, *prxbuf, *pecbuf;
+
+	if (argc < 4) {
+	  printf("usage: %s SampleName channel(1|2|.....) length(secs)\n"
+		 " [-i(impulse mode)]", 
+		 argv[0]);
+	  exit(0);
+	}
+
+	sprintf(filename, "%s_tx.raw", argv[1]);
+	ftx = fopen(filename,"wb");
+	if (ftx == NULL) {
+	  printf("Can't open tx sample file: %s\n", filename);
+	  exit(1);
+	}
+
+	sprintf(filename, "%s_rx.raw", argv[1]);
+	frx = fopen(filename,"wb");
+	if (frx == NULL) {
+	  printf("Can't open rx sample file: %s\n", filename);
+	  exit(1);
+	}
+
+	sprintf(filename, "%s_ec.raw", argv[1]);
+	fec = fopen(filename,"wb");
+	if (frx == NULL) {
+	  printf("Can't open ec sample file: %s\n", filename);
+	  exit(1);
+	}
+
+	sample_ch = atoi(argv[2]);
+	if (sample_ch < 1) {
+	  printf("Invalid channel: %d must be > 0\n", sample_ch);
+	  exit(1);
+	}
+
+	secs = atof(argv[3]);
+	if ((secs < 0.0) || (secs > 100.0)) {
+	  printf("Invalid secs %f, must be between 0 and 100\n", secs);
+	  exit(1);
+	}
+	frames = (secs*FS)/SAMPLE_BUF_SZ;
+
+	fd = open("/dev/sample", O_RDWR);
+	if( fd == -1) {
+		printf("open error...\n");
+		exit(0);
+	}
+	
+	ioctl(fd, SAMPLE_SET_CHANNEL, &sample_ch);
+
+	if (argc == 5) {
+	  if(!strcmp(argv[4], "-i")) {
+	    printf("Impulse mode enabled\n");
+	    ioctl(fd, SAMPLE_TX_IMPULSE, &sample_ch);
+	  }
+	}
+
+	printf("sampling Zap/%d...\n", sample_ch);
+	for(i=0; i<frames; i++) {
+	  len = read(fd, buf, 3*sizeof(short)*SAMPLE_BUF_SZ);
+	  if( len == -1 ) {
+	    printf("read error...\n");
+	    exit(1);
+	  }
+
+	  /* demultiplex and write to disk */
+
+	  pbuf = buf;
+	  ptxbuf = txbuf;
+	  prxbuf = rxbuf;
+	  pecbuf = ecbuf;
+	  for(j=0; j<SAMPLE_BUF_SZ; j++) {
+	      *ptxbuf++ = *pbuf++;
+	      *prxbuf++ = *pbuf++;
+	      *pecbuf++ = *pbuf++;
+	  }
+	  fwrite(txbuf, sizeof(short), SAMPLE_BUF_SZ, ftx);
+	  fwrite(rxbuf, sizeof(short), SAMPLE_BUF_SZ, frx);
+	  fwrite(ecbuf, sizeof(short), SAMPLE_BUF_SZ, fec);
+	}
+
+	close(fd);
+	fclose(ftx);
+	fclose(frx);
+	fclose(fec);
+
+	return 0;
+}

Repositories maintained by Peter Meerwald, pmeerw@pmeerw.net.