211 lines
4.1 KiB
C
211 lines
4.1 KiB
C
|
|
#include <stdio.h>
|
|
#include <comedilib.h>
|
|
#include <fcntl.h>
|
|
#include <unistd.h>
|
|
#include <sys/ioctl.h>
|
|
#include <errno.h>
|
|
#include <getopt.h>
|
|
#include <ctype.h>
|
|
#include <math.h>
|
|
#include <sys/time.h>
|
|
#include <string.h>
|
|
#include "comedi_test.h"
|
|
|
|
int comedi_get_cmd_src_mask(comedi_t *it,unsigned int s,comedi_cmd *cmd);
|
|
int comedi_get_cmd_fast_1chan(comedi_t *it,unsigned int s,comedi_cmd *cmd);
|
|
void probe_max_1chan(comedi_t *it,int s);
|
|
char *tobinary(char *s,int bits,int n);
|
|
char *cmd_src(int src,char *buf);
|
|
|
|
int test_cmd_probe_src_mask(void)
|
|
{
|
|
comedi_cmd cmd;
|
|
char buf[100];
|
|
int ret;
|
|
|
|
printf("rev 1\n");
|
|
|
|
ret = comedi_get_cmd_src_mask(device,subdevice,&cmd);
|
|
if(ret<0){
|
|
printf("not supported\n");
|
|
return 0;
|
|
}
|
|
printf("command source mask:\n");
|
|
printf(" start: %s\n",cmd_src(cmd.start_src,buf));
|
|
printf(" scan_begin: %s\n",cmd_src(cmd.scan_begin_src,buf));
|
|
printf(" convert: %s\n",cmd_src(cmd.convert_src,buf));
|
|
printf(" scan_end: %s\n",cmd_src(cmd.scan_end_src,buf));
|
|
printf(" stop: %s\n",cmd_src(cmd.stop_src,buf));
|
|
|
|
return 0;
|
|
}
|
|
|
|
int test_cmd_probe_fast_1chan(void)
|
|
{
|
|
comedi_cmd cmd;
|
|
char buf[100];
|
|
|
|
printf("command fast 1chan:\n");
|
|
if(comedi_get_cmd_fast_1chan(device,subdevice,&cmd)<0){
|
|
printf(" not supported\n");
|
|
return 0;
|
|
}
|
|
printf(" start: %s %d\n",
|
|
cmd_src(cmd.start_src,buf),cmd.start_arg);
|
|
printf(" scan_begin: %s %d\n",
|
|
cmd_src(cmd.scan_begin_src,buf),cmd.scan_begin_arg);
|
|
printf(" convert: %s %d\n",
|
|
cmd_src(cmd.convert_src,buf),cmd.convert_arg);
|
|
printf(" scan_end: %s %d\n",
|
|
cmd_src(cmd.scan_end_src,buf),cmd.scan_end_arg);
|
|
printf(" stop: %s %d\n",
|
|
cmd_src(cmd.stop_src,buf),cmd.stop_arg);
|
|
|
|
return 0;
|
|
}
|
|
|
|
#define BUFSZ 1000
|
|
|
|
int test_cmd_read_fast_1chan(void)
|
|
{
|
|
comedi_cmd cmd;
|
|
char buf[BUFSZ];
|
|
unsigned int chanlist[1];
|
|
int go;
|
|
int total=0;
|
|
int ret;
|
|
|
|
if(comedi_get_cmd_fast_1chan(device,subdevice,&cmd)<0){
|
|
printf(" not supported\n");
|
|
return 0;
|
|
}
|
|
|
|
cmd.chanlist = chanlist;
|
|
cmd.scan_end_arg = 1;
|
|
cmd.stop_arg = 10000;
|
|
cmd.chanlist_len = 1;
|
|
chanlist[0] = CR_PACK(0,0,0);
|
|
|
|
comedi_command(device,&cmd);
|
|
|
|
go=1;
|
|
while(go){
|
|
ret = read(comedi_fileno(device),buf,BUFSZ);
|
|
if(ret<0){
|
|
if(errno==EAGAIN){
|
|
usleep(10000);
|
|
}else{
|
|
go = 0;
|
|
perror("read");
|
|
}
|
|
}else if(ret==0){
|
|
go = 0;
|
|
}else{
|
|
total += ret;
|
|
printf("read %d %d\n",ret,total);
|
|
}
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
char *tobinary(char *s,int bits,int n)
|
|
{
|
|
int bit=1<<n;
|
|
char *t=s;
|
|
|
|
for(;bit;bit>>=1)
|
|
*t++=(bits&bit)?'1':'0';
|
|
*t=0;
|
|
|
|
return s;
|
|
}
|
|
|
|
char *cmd_src(int src,char *buf)
|
|
{
|
|
buf[0]=0;
|
|
|
|
if(src&TRIG_NONE)strcat(buf,"none|");
|
|
if(src&TRIG_NOW)strcat(buf,"now|");
|
|
if(src&TRIG_FOLLOW)strcat(buf,"follow|");
|
|
if(src&TRIG_TIME)strcat(buf,"time|");
|
|
if(src&TRIG_TIMER)strcat(buf,"timer|");
|
|
if(src&TRIG_COUNT)strcat(buf,"count|");
|
|
if(src&TRIG_EXT)strcat(buf,"ext|");
|
|
if(src&TRIG_INT)strcat(buf,"int|");
|
|
|
|
if(strlen(buf)==0){
|
|
sprintf(buf,"unknown(0x%02x)",src);
|
|
}else{
|
|
buf[strlen(buf)-1]=0;
|
|
}
|
|
|
|
return buf;
|
|
}
|
|
|
|
|
|
int comedi_get_cmd_src_mask(comedi_t *it,unsigned int s,comedi_cmd *cmd)
|
|
{
|
|
memset(cmd,0,sizeof(*cmd));
|
|
|
|
cmd->subdev = s;
|
|
|
|
cmd->flags = 0;
|
|
|
|
cmd->start_src = TRIG_ANY;
|
|
cmd->scan_begin_src = TRIG_ANY;
|
|
cmd->convert_src = TRIG_ANY;
|
|
cmd->scan_end_src = TRIG_ANY;
|
|
cmd->stop_src = TRIG_ANY;
|
|
|
|
return comedi_command_test(it,cmd);
|
|
}
|
|
|
|
|
|
int comedi_get_cmd_fast_1chan(comedi_t *it,unsigned int s,comedi_cmd *cmd)
|
|
{
|
|
int ret;
|
|
|
|
ret = comedi_get_cmd_src_mask(it,s,cmd);
|
|
if(ret<0)return ret;
|
|
|
|
cmd->chanlist_len = 1;
|
|
|
|
cmd->scan_end_src = TRIG_COUNT;
|
|
cmd->scan_end_arg = 1;
|
|
|
|
if(cmd->convert_src&TRIG_TIMER){
|
|
if(cmd->scan_begin_src&TRIG_FOLLOW){
|
|
cmd->convert_src = TRIG_TIMER;
|
|
cmd->scan_begin_src = TRIG_FOLLOW;
|
|
}else{
|
|
cmd->convert_src = TRIG_TIMER;
|
|
cmd->scan_begin_src = TRIG_TIMER;
|
|
}
|
|
}else{
|
|
printf("can't do timed?!?\n");
|
|
return -1;
|
|
}
|
|
if(cmd->stop_src&TRIG_COUNT){
|
|
cmd->stop_src=TRIG_COUNT;
|
|
cmd->stop_arg=2;
|
|
}else if(cmd->stop_src&TRIG_NONE){
|
|
cmd->stop_src=TRIG_NONE;
|
|
cmd->stop_arg=0;
|
|
}else{
|
|
printf("can't find a good stop_src\n");
|
|
return -1;
|
|
}
|
|
|
|
ret=comedi_command_test(it,cmd);
|
|
if(ret==3){
|
|
/* good */
|
|
ret=comedi_command_test(it,cmd);
|
|
}
|
|
if(ret==4 || ret==0){
|
|
return 0;
|
|
}
|
|
return -1;
|
|
}
|
|
|