2009-07-10 17:07:44 -04:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
2010-07-08 17:27:49 -04:00
|
|
|
#ifndef __USE_ISOC99
|
2009-07-10 17:07:44 -04:00
|
|
|
#define __USE_ISOC99
|
2010-07-08 17:27:49 -04:00
|
|
|
#endif
|
2009-07-10 17:07:44 -04:00
|
|
|
#include <math.h>
|
|
|
|
#include "zoom.h"
|
|
|
|
#include "serial-util.h"
|
|
|
|
|
2013-06-14 20:54:37 -04:00
|
|
|
#define zputs(s) do { if (safewrite(fd, s, strlen(s)) != strlen(s)) \
|
|
|
|
return -1; } while(0)
|
|
|
|
#define zputc(ch) do { const char ____c = ch; \
|
|
|
|
if (safewrite(fd, &____c, 1) != 1) return -1; } while(0)
|
2009-07-10 17:07:44 -04:00
|
|
|
|
2009-07-10 17:28:12 -04:00
|
|
|
static int last_dac, last_adc;
|
|
|
|
|
2009-07-10 17:07:44 -04:00
|
|
|
static int verify_prompt(int fd)
|
|
|
|
{
|
|
|
|
char s[128];
|
|
|
|
int dac1, dac2, adc1, adc2;
|
|
|
|
if (fdgets(s, 128, fd, 1000) == NULL)
|
|
|
|
return -1;
|
|
|
|
chomp(s);
|
2009-07-10 17:40:13 -04:00
|
|
|
if (sscanf(s, "%x %d %x %d", &dac1, &dac2, &adc1, &adc2) != 4)
|
2009-07-10 17:07:44 -04:00
|
|
|
return -1;
|
2010-07-08 17:51:10 -04:00
|
|
|
// if (dac1 != dac2 || adc1 != adc2)
|
|
|
|
if (adc1 != adc2)
|
|
|
|
return -1;
|
2009-07-10 17:28:12 -04:00
|
|
|
last_dac = dac1;
|
|
|
|
last_adc = adc1;
|
2009-07-10 17:07:44 -04:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2009-10-06 16:03:25 -04:00
|
|
|
int zoom_init_real(int fd, int dozero)
|
2009-07-10 17:07:44 -04:00
|
|
|
{
|
2009-10-06 16:03:25 -04:00
|
|
|
zputs(dozero ? "00000000" : " ");
|
2009-07-10 17:07:44 -04:00
|
|
|
drain(fd);
|
2009-10-06 16:03:25 -04:00
|
|
|
zputc(dozero ? '0' : ' ');
|
2009-07-10 17:07:44 -04:00
|
|
|
if (verify_prompt(fd) < 0)
|
|
|
|
return -1;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int zoom_zero_start(int fd)
|
|
|
|
{
|
|
|
|
char s[128];
|
|
|
|
zputc('z');
|
|
|
|
if (fdgets(s, 128, fd, 1000) == NULL)
|
|
|
|
return -1;
|
|
|
|
chomp(s);
|
|
|
|
if (strcmp(s, "zeroing input...") != 0)
|
|
|
|
return -1;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int zoom_zero_stop(int fd)
|
|
|
|
{
|
|
|
|
zputc(' ');
|
|
|
|
if (verify_prompt(fd) < 0)
|
|
|
|
return -1;
|
2009-07-10 17:28:12 -04:00
|
|
|
return last_dac;
|
2009-07-10 17:07:44 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
int zoom_sweep(int fd, int dac[ZOOM_SWEEP_COUNT], int adc[ZOOM_SWEEP_COUNT])
|
|
|
|
{
|
|
|
|
char s[128];
|
|
|
|
int i;
|
|
|
|
char c;
|
|
|
|
zputc('s');
|
|
|
|
if (fdgets(s, 128, fd, 1000) == NULL)
|
|
|
|
return -1;
|
|
|
|
if (strncmp(s, "sweep around", 12) != 0)
|
|
|
|
return -1;
|
|
|
|
for (i = 0; i < ZOOM_SWEEP_COUNT; i++) {
|
|
|
|
if (fdgets(s, 128, fd, 1000) == NULL)
|
|
|
|
return -1;
|
|
|
|
chomp(s);
|
|
|
|
if (sscanf(s, "%d %d%c", &dac[i], &adc[i], &c) != 2)
|
|
|
|
return -2;
|
|
|
|
}
|
|
|
|
if (verify_prompt(fd) < 0)
|
|
|
|
return -3;
|
|
|
|
return 0;
|
|
|
|
}
|
2009-10-14 15:30:36 -04:00
|
|
|
|
2010-07-08 17:27:49 -04:00
|
|
|
int zoom_write_dac(int fd, int dac)
|
|
|
|
{
|
|
|
|
char s[128];
|
2013-06-14 20:54:37 -04:00
|
|
|
|
2010-07-08 17:27:49 -04:00
|
|
|
sprintf(s, "v%04x", dac);
|
|
|
|
zputs(s);
|
|
|
|
if (verify_prompt(fd) < 0)
|
|
|
|
return -1;
|
|
|
|
return last_dac;
|
|
|
|
}
|
|
|
|
|
2009-10-14 15:30:36 -04:00
|
|
|
/* Run mode: */
|
|
|
|
|
|
|
|
void zoomrun_trigger_calibrate(int fd)
|
|
|
|
{
|
|
|
|
char c = 'c';
|
|
|
|
write(fd, &c, 1);
|
2009-10-14 17:35:50 -04:00
|
|
|
drain_timeout(fd, 0);
|
2009-10-14 15:30:36 -04:00
|
|
|
}
|