X-Git-Url: http://cvs.zerfleddert.de/cgi-bin/gitweb.cgi/rigol/blobdiff_plain/e8e713c3a536c59f94d6402d852f353e34fac2de..713be7a43ed11947c358fc67c11b9df7b0be204c:/rigol.c?ds=sidebyside diff --git a/rigol.c b/rigol.c index 818b7ea..06ebacb 100644 --- a/rigol.c +++ b/rigol.c @@ -8,7 +8,6 @@ rmmod uhci_hcd; modprobe uhci_hcd (or alternately: use ohci_hcd) if that happens and you should be fine. */ -#include #include #include #include @@ -23,43 +22,8 @@ rmmod uhci_hcd; modprobe uhci_hcd #include #include -#include "png.h" - - -//This routine locates a scope by VID/PID and returns an opened handle to it. -usb_dev_handle *find_scope() { - struct usb_bus *bus; - struct usb_device *dev=NULL; - usb_find_busses(); - usb_find_devices(); - for (bus=usb_busses; bus; bus=bus->next) { - for (dev=bus->devices; dev; dev=dev->next) { - //fprintf(stderr,"Prod/dev: %04X:%04X\n",dev->descriptor.idVendor,dev->descriptor.idProduct); - if (dev->descriptor.idVendor==0x400 && dev->descriptor.idProduct==0x5dc) { - return usb_open(dev); - } - } - } - return NULL; -} - -//Helper-routine: Convert a little-endian 4-byte word to an int -void int2chars(unsigned char *buff,unsigned int a) { - buff[3]=(a>>24)&0xff; - buff[2]=(a>>16)&0xff; - buff[1]=(a>>8)&0xff; - buff[0]=(a)&0xff; -} - -//Helper-routine: Convert an int to little-endian 4-byte word -unsigned int chars2int(unsigned char *buff) { - unsigned int a; - a=buff[3]<<24; - a+=buff[2]<<16; - a+=buff[1]<<8; - a+=buff[0]; - return a; -} +#include "scope.h" +#include "commands.h" #define MIN(a,b) (((a)<(b))?(a):(b)) @@ -92,88 +56,6 @@ void printb (unsigned char *pkt, int len) } } -//Send a scpi-command to the scope. The response goes into the buffer -//called resp, with a size of resplen. If resp==NULL, no response -//is requested. -int sendscpi(usb_dev_handle *dev, char* cmd, - unsigned char *resp, int resplen) { - unsigned char *buff; - int len,r,i; - int cmdlen = strlen(cmd); - static unsigned char seq=0; - - - buff=malloc(0x40); - seq++; - buff[0]=1; //func - buff[1]=seq; buff[2]=~seq; //nseq - buff[3]=0; - int2chars(buff+4, cmdlen); - buff[8]=1; - buff[9]=0x37; - buff[10]=0x39; - buff[11]=0x39; - //fprintf(stderr,"Writing header len=%d\n", cmdlen); - //printb(buff,12); - r=usb_bulk_write(dev, 1, (char*)buff, 12, 1000); - //fprintf(stderr,"%i bytes written. Writing cmd\n",r); - //printb(cmd, cmdlen); - r=usb_bulk_write(dev, 1, cmd, cmdlen, 1000); - //fprintf(stderr,"%i bytes written.\n",r); - if (resp != NULL && resplen != 0) { - //send read command - buff[0]=2; //func - seq++; - buff[1]=seq; buff[2]=~seq; //nseq - int2chars(buff+4,0x40); - buff[8]=1; - buff[9]=0xA; - buff[10]=0; - buff[11]=0; - //fprintf(stderr,"Writing resp req header\n"); - //printb(buff,12); - r=usb_bulk_write(dev, 1, (char*)buff, 12, 1000); - //fprintf(stderr,"%i bytes written. Reading response hdr\n",r); - r=usb_bulk_read(dev, 2, (char*)buff, 0x40, 1000); - //printb(buff,r); - len=chars2int(buff+4); - //fprintf(stderr,"%i bytes read. Resplen=%i\n",r,len); - for (i=0; i<(r-12); i++) { - if (i 0x40-12) { - //fprintf(stderr," Reading response:\n"); - if (resplen 0) { - sscanf ((char*)buf, "%lf", &temp); - return temp; - } - return ERROR; -} - - -void do_get_buf (struct usb_dev_handle *sc) -{ - FILE *fp; - int i, j, l, bp; - char buf[1024]; - unsigned char ch1[1024]; - unsigned char data[512*1024]; - double sampfreq; - - sendscpi (sc, ":STOP", NULL, 0); - - sampfreq = get_float_from_scope (sc, ":ACQ:SAMP?"); - - printf ("Got sampling freq: %g\n", sampfreq); - - sprintf (buf, ":TIM:SCAL %.15f", 50 / sampfreq); - printf ("sending scale cmd: %s\n", buf); - sendscpi (sc, buf, NULL, 0); - - sleep (1); - - bp=0; - for (i=-254*1024;i< 254*1024;i += 600) { - sprintf (buf, ":TIM:OFFSET %.15f", i / sampfreq); - printf ("Sending offset cmd: %s\n", buf); - sendscpi (sc, buf, NULL, 0); - - l = sendscpi(sc, ":WAV:DATA? CHANEL1", ch1, 1024); - - if (l != 1024) { - printf ("hmm. didnt' get 1024 bytes. \n"); - } - - for (j=0;j<600;j++) - data[bp++] = ch1[j+0xd4]; - } - printf ("Got %d bytes of data. \n", bp); - - fp = fopen ("ch1.dump", "w"); - fwrite (data, bp, 1, fp); - fclose (fp); - - sendscpi (sc, ":TIM:OFFSET 0", NULL, 0); -} - -void do_get_screen(struct usb_dev_handle *sc) -{ - unsigned char screen[320*234]; - time_t lt; - char filename[256]; - unsigned char *png; - int imglen; - int l; - int fd; - pid_t display; - - /* Hide "RMT" from screen */ - l = sendscpi(sc, ":KEY:LOCK DISABLE", NULL, 0); - usleep(20000); - - l = sendscpi(sc, ":LCD:DATA?", screen, sizeof(screen)); - - if (l != sizeof(screen)) { - printf ("hmm. didnt' get %d bytes, but %d\n\n", sizeof(screen), l); - } - - strftime(filename, sizeof(filename), "screen_%Y%m%d-%H%M%S.png", localtime(<)); - fd=open(filename, O_CREAT|O_WRONLY, 0644); - png = lcd2png(screen, &imglen); - write(fd, png, imglen); - close(fd); - - printf("Waveform saved as %s\n", filename); - - display = fork(); - switch(display) { - case 0: - execlp("display", "display", filename, NULL); - exit(0); - break; - case -1: - perror("fork"); - break; - default: - break; - } -} - void child_reaper(int sig) { pid_t child; @@ -354,24 +95,15 @@ void child_reaper(int sig) int main(int argc, char **argv) { - struct usb_dev_handle *sc; + struct scope *sc; char *scpi; unsigned char *buff; int l; struct sigaction act; - //Init libusb - usb_init(); - //Locate and open the scope - sc=find_scope(); - if (!sc) { - printf("No scope found.\n"); - exit(1); - } else { - printf("Scope found.\n"); - } //Initialize scope - initscope(sc); + sc = initscope(); + claimscope(sc); buff = malloc (1024*1024); if (buff == NULL) { perror("malloc"); @@ -403,11 +135,15 @@ int main(int argc, char **argv) continue; } if (strncmp (scpi, "databuf", 7) == 0) { - do_get_buf (sc); + do_get_buf(sc); continue; } if (strncmp (scpi, "screen", 6) == 0) { - do_get_screen (sc); + do_get_screen(sc); + continue; + } + if (strncmp (scpi, "display", 7) == 0) { + do_display_screen(sc); continue; } @@ -426,11 +162,7 @@ int main(int argc, char **argv) } free (scpi); } - //Disable keylock, so the user doesn't have to press the 'force'-button - l=sendscpi(sc, ":KEY:LOCK DISABLE",NULL,0); - - //Free up and exit - usb_release_interface(sc,0); - usb_close(sc); + releasescope(sc); + closescope(sc); return 0; }