#include <unistd.h>
#include <stdint.h>
-#include "usbtmc.h"
#include "scope.h"
+#include "usbtmc.h"
/* Just USB for now... */
int sendscpi(struct scope* sc, char* cmd, unsigned char *resp, int resplen)
{
- return usbtmc_sendscpi(sc->usbdev, cmd, resp, resplen);
+ return usbtmc_sendscpi(sc, cmd, resp, resplen);
}
void closescope(struct scope* sc)
{
- return usbtmc_close(sc->usbdev);
+ return usbtmc_close(sc);
}
void claimscope(struct scope* sc)
{
- return usbtmc_claim(sc->usbdev);
+ return usbtmc_claim(sc);
}
void releasescope(struct scope* sc)
{
//Disable keylock, so the user doesn't have to press the 'force'-button
sendscpi(sc, ":KEY:LOCK DISABLE",NULL,0);
- return usbtmc_release(sc->usbdev);
+ return usbtmc_release(sc);
}
struct scope* initscope(void)
{
- struct usb_dev_handle *usbdev;
struct scope *sc;
- usbdev = usbtmc_initscope();
+ sc = usbtmc_initscope();
- if (!usbdev) {
+ if (!sc) {
printf("No scope found.\n");
exit(EXIT_FAILURE);
}
- sc = calloc(1, sizeof(struct scope));
- if (sc == NULL) {
- perror("malloc");
- exit(EXIT_FAILURE);
- }
-
- sc->usbdev = usbdev;
-
claimscope(sc);
sendscpi(sc, "*IDN?", (unsigned char*)sc->idn, sizeof(sc->idn));
releasescope(sc);
#include <usb.h>
#include <arpa/inet.h>
+#include "scope.h"
#include "usbtmc.h"
#define USB_TIMEOUT 50000
//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 usbtmc_sendscpi(usb_dev_handle *dev, char* cmd,
+int usbtmc_sendscpi(struct scope *sc, char* cmd,
unsigned char *resp, int resplen) {
unsigned char *buff;
int len,r,i;
buff[11]=0x00;
//fprintf(stderr,"Writing header len=%d\n", cmdlen);
//printb(buff,12);
- r=usb_bulk_write(dev, 1, (char*)buff, 12, USB_TIMEOUT);
+ r=usb_bulk_write(sc->usb.dev, 1, (char*)buff, 12, USB_TIMEOUT);
//fprintf(stderr,"%i bytes written. Writing cmd\n",r);
//printb(cmd, cmdlen);
- r=usb_bulk_write(dev, 1, cmd, cmdlen, USB_TIMEOUT);
+ r=usb_bulk_write(sc->usb.dev, 1, cmd, cmdlen, USB_TIMEOUT);
//fprintf(stderr,"%i bytes written.\n",r);
if (resp != NULL && resplen != 0) {
//send read command
buff[11]=0;
//fprintf(stderr,"Writing resp req header\n");
//printb(buff,12);
- r=usb_bulk_write(dev, 1, (char*)buff, 12, USB_TIMEOUT);
+ r=usb_bulk_write(sc->usb.dev, 1, (char*)buff, 12, USB_TIMEOUT);
//fprintf(stderr,"%i bytes written. Reading response hdr\n",r);
- r=usb_bulk_read(dev, 2, (char*)buff, 0x40, USB_TIMEOUT);
+ r=usb_bulk_read(sc->usb.dev, 2, (char*)buff, 0x40, USB_TIMEOUT);
//printb(buff,r);
len=chars2int(buff+4);
//fprintf(stderr,"%i bytes read. Resplen=%i\n",r,len);
if (len > 0x40-12) {
//fprintf(stderr," Reading response:\n");
if (resplen<len) len=resplen;
- r=usb_bulk_read(dev, 2, (char*)resp+(0x40-12), len-(0x40-12), USB_TIMEOUT);
+ r=usb_bulk_read(sc->usb.dev, 2, (char*)resp+(0x40-12), len-(0x40-12), USB_TIMEOUT);
//fprintf(stderr,"%i bytes read, wanted %i.\n", r, len-(0x40-12));
return r+(0x40-12);
}
return 0;
}
-void usbtmc_claim(usb_dev_handle *sc)
+void usbtmc_claim(struct scope *sc)
{
- usb_claim_interface(sc, 0);
+ usb_claim_interface(sc->usb.dev, 0);
}
-void usbtmc_release(usb_dev_handle *sc)
+void usbtmc_release(struct scope *sc)
{
- usb_release_interface(sc, 0);
+ usb_release_interface(sc->usb.dev, 0);
}
//Initialize the scope.
-usb_dev_handle* usbtmc_initscope(void) {
+struct scope* usbtmc_initscope(void) {
int r;
unsigned char buff[10];
usb_dev_handle *dev;
+ struct scope *sc;
//Init libusb
usb_init();
if (!dev) {
return NULL;
}
- usbtmc_claim(dev);
+
+ sc = calloc(1, sizeof(struct scope));
+ if (sc == NULL) {
+ perror("calloc");
+ exit(EXIT_FAILURE);
+ }
+
+ sc->usb.dev = dev;
+
+ usbtmc_claim(sc);
//The following code isn't really necessary, the program works
//OK without it too.
- r=usb_control_msg(dev, 0xC8, 9, 0, 0, (char*)buff, 4, USB_TIMEOUT);
- usbtmc_release(dev);
+ r=usb_control_msg(sc->usb.dev, 0xC8, 9, 0, 0, (char*)buff, 4, USB_TIMEOUT);
+ usbtmc_release(sc);
if (r < 0) {
fprintf (stderr, "Error %d sending init message: %s\n",
r, strerror (-r));
if (chars2int(buff)!=0x40005dc) {
fprintf(stderr,"Init: buff[%i]=%x\n",r,chars2int(buff));
}
- return dev;
+ return sc;
}
-void usbtmc_close(usb_dev_handle *sc)
+void usbtmc_close(struct scope *sc)
{
//Free up and exit
- usb_close(sc);
+ usb_close(sc->usb.dev);
}