/* * Tutorial example #2 * Part of Comedilib * * Copyright (c) 1999,2000 David A. Schleef * Copyright (c) 2008 Frank Mori Hess * * This file may be freely modified, distributed, and combined with * other software, as long as proper attribution is given in the * source code. */ #include /* for printf() */ #include #include #include #include int subdev = 0; /* change this to your input subdevice */ int chan = 0; /* change this to your channel */ int range = 0; /* more on this later */ int aref = AREF_GROUND; /* more on this later */ const char filename[] = "/dev/comedi0"; int main(int argc, char *argv[]) { comedi_t *device; lsampl_t data; double physical_value; int retval; comedi_range *range_info; lsampl_t maxdata; device = comedi_open(filename); if (device == NULL) { comedi_perror(filename); return 1; } retval = comedi_data_read(device, subdev, chan, range, aref, &data); if (retval < 0) { comedi_perror(filename); return 1; } comedi_set_global_oor_behavior(COMEDI_OOR_NAN); range_info = comedi_get_range(device, subdev, chan, range); maxdata = comedi_get_maxdata(device, subdev, chan); printf("[0,%d] -> [%g,%g]\n", maxdata, range_info->min, range_info->max); physical_value = comedi_to_phys(data, range_info, maxdata); if (isnan(physical_value)) { printf("Out of range [%g,%g]", range_info->min, range_info->max); } else { printf("%g", physical_value); switch(range_info->unit) { case UNIT_volt: printf(" V"); break; case UNIT_mA: printf(" mA"); break; case UNIT_none: break; default: printf(" (unknown unit %d)", range_info->unit); } printf(" (%lu in raw units)\n", (unsigned long)data); } return 0; }