+static struct usbtmc_capabilities* usbtmc_get_capabilities(struct scope *sc)
+{
+ int r;
+ static struct usbtmc_capabilities res;
+
+ r = usb_control_msg(sc->usb.dev, 0xA1,
+ USBTMC_CTL_GET_CAPABILITIES,
+ 0, 0, (char*)&res, sizeof(struct usbtmc_capabilities),
+ USB_TIMEOUT);
+ if (r != sizeof(struct usbtmc_capabilities)) {
+ printf("GET_CAPABILITIES failed: %s\n", usb_strerror());
+ return NULL;
+ }
+
+ printf("USBTMC Version %x.%x Capabilities:\n", res.bcdUSBTMC[0], res.bcdUSBTMC[1]);
+ if (res.USBTMCIFcapabilities & USBTMC_CAP_IF_INDICATOR_PULSE)
+ printf("\tInterface supports indicator pulse\n");
+
+ if (res.USBTMCIFcapabilities & USBTMC_CAP_IF_TALKONLY)
+ printf("\tInterface is talk only\n");
+
+ if (res.USBTMCIFcapabilities & USBTMC_CAP_IF_LISTENONLY)
+ printf("\tInterface is listen only\n");
+
+ if (res.USBTMCDEVcapabilities & USBTMC_CAP_DEV_TERMCHAR_SUPP)
+ printf("\tDevice supports Termchar\n");
+
+ printf("USB488 Version %x.%x Capabilities:\n", res.bcdUSB488[0], res.bcdUSB488[1]);
+
+ if (res.USB488IFcapabilities & USB488_CAP_IF_4882)
+ printf("\tInterface is 488.2 compliant\n");
+
+ if (res.USB488IFcapabilities & USB488_CAP_IF_LOCKOUT)
+ printf("\tInterface supports local lockout\n");
+
+ if (res.USB488IFcapabilities & USB488_CAP_IF_TRIGGER)
+ printf("\tInterface supports TRIGGER\n");
+
+ if (res.USB488DEVcapabilities & USB488_CAP_DEV_SCPI)
+ printf("\tDevice is SCPI compliant\n");
+
+ if (res.USB488DEVcapabilities & USB488_CAP_DEV_SR1)
+ printf("\tDevice is SR1 capable\n");
+
+ if (res.USB488DEVcapabilities & USB488_CAP_DEV_RL1)
+ printf("\tDevice is RL1 capable\n");
+
+ if (res.USB488DEVcapabilities & USB488_CAP_DEV_DT1)
+ printf("\tDevice is DT1 capable\n");
+
+ return &res;
+}
+