1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */ 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun * Copyright (C) 2007 Stefan Kopp, Gechingen, Germany 4*4882a593Smuzhiyun * Copyright (C) 2008 Novell, Inc. 5*4882a593Smuzhiyun * Copyright (C) 2008 Greg Kroah-Hartman <gregkh@suse.de> 6*4882a593Smuzhiyun * Copyright (C) 2015 Dave Penkler <dpenkler@gmail.com> 7*4882a593Smuzhiyun * Copyright (C) 2018 IVI Foundation, Inc. 8*4882a593Smuzhiyun * 9*4882a593Smuzhiyun * This file holds USB constants defined by the USB Device Class 10*4882a593Smuzhiyun * and USB488 Subclass Definitions for Test and Measurement devices 11*4882a593Smuzhiyun * published by the USB-IF. 12*4882a593Smuzhiyun * 13*4882a593Smuzhiyun * It also has the ioctl and capability definitions for the 14*4882a593Smuzhiyun * usbtmc kernel driver that userspace needs to know about. 15*4882a593Smuzhiyun */ 16*4882a593Smuzhiyun 17*4882a593Smuzhiyun #ifndef __LINUX_USB_TMC_H 18*4882a593Smuzhiyun #define __LINUX_USB_TMC_H 19*4882a593Smuzhiyun 20*4882a593Smuzhiyun #include <linux/types.h> /* __u8 etc */ 21*4882a593Smuzhiyun 22*4882a593Smuzhiyun /* USB TMC status values */ 23*4882a593Smuzhiyun #define USBTMC_STATUS_SUCCESS 0x01 24*4882a593Smuzhiyun #define USBTMC_STATUS_PENDING 0x02 25*4882a593Smuzhiyun #define USBTMC_STATUS_FAILED 0x80 26*4882a593Smuzhiyun #define USBTMC_STATUS_TRANSFER_NOT_IN_PROGRESS 0x81 27*4882a593Smuzhiyun #define USBTMC_STATUS_SPLIT_NOT_IN_PROGRESS 0x82 28*4882a593Smuzhiyun #define USBTMC_STATUS_SPLIT_IN_PROGRESS 0x83 29*4882a593Smuzhiyun 30*4882a593Smuzhiyun /* USB TMC requests values */ 31*4882a593Smuzhiyun #define USBTMC_REQUEST_INITIATE_ABORT_BULK_OUT 1 32*4882a593Smuzhiyun #define USBTMC_REQUEST_CHECK_ABORT_BULK_OUT_STATUS 2 33*4882a593Smuzhiyun #define USBTMC_REQUEST_INITIATE_ABORT_BULK_IN 3 34*4882a593Smuzhiyun #define USBTMC_REQUEST_CHECK_ABORT_BULK_IN_STATUS 4 35*4882a593Smuzhiyun #define USBTMC_REQUEST_INITIATE_CLEAR 5 36*4882a593Smuzhiyun #define USBTMC_REQUEST_CHECK_CLEAR_STATUS 6 37*4882a593Smuzhiyun #define USBTMC_REQUEST_GET_CAPABILITIES 7 38*4882a593Smuzhiyun #define USBTMC_REQUEST_INDICATOR_PULSE 64 39*4882a593Smuzhiyun #define USBTMC488_REQUEST_READ_STATUS_BYTE 128 40*4882a593Smuzhiyun #define USBTMC488_REQUEST_REN_CONTROL 160 41*4882a593Smuzhiyun #define USBTMC488_REQUEST_GOTO_LOCAL 161 42*4882a593Smuzhiyun #define USBTMC488_REQUEST_LOCAL_LOCKOUT 162 43*4882a593Smuzhiyun 44*4882a593Smuzhiyun struct usbtmc_request { 45*4882a593Smuzhiyun __u8 bRequestType; 46*4882a593Smuzhiyun __u8 bRequest; 47*4882a593Smuzhiyun __u16 wValue; 48*4882a593Smuzhiyun __u16 wIndex; 49*4882a593Smuzhiyun __u16 wLength; 50*4882a593Smuzhiyun } __attribute__ ((packed)); 51*4882a593Smuzhiyun 52*4882a593Smuzhiyun struct usbtmc_ctrlrequest { 53*4882a593Smuzhiyun struct usbtmc_request req; 54*4882a593Smuzhiyun void __user *data; /* pointer to user space */ 55*4882a593Smuzhiyun } __attribute__ ((packed)); 56*4882a593Smuzhiyun 57*4882a593Smuzhiyun struct usbtmc_termchar { 58*4882a593Smuzhiyun __u8 term_char; 59*4882a593Smuzhiyun __u8 term_char_enabled; 60*4882a593Smuzhiyun } __attribute__ ((packed)); 61*4882a593Smuzhiyun 62*4882a593Smuzhiyun /* 63*4882a593Smuzhiyun * usbtmc_message->flags: 64*4882a593Smuzhiyun */ 65*4882a593Smuzhiyun #define USBTMC_FLAG_ASYNC 0x0001 66*4882a593Smuzhiyun #define USBTMC_FLAG_APPEND 0x0002 67*4882a593Smuzhiyun #define USBTMC_FLAG_IGNORE_TRAILER 0x0004 68*4882a593Smuzhiyun 69*4882a593Smuzhiyun struct usbtmc_message { 70*4882a593Smuzhiyun __u32 transfer_size; /* size of bytes to transfer */ 71*4882a593Smuzhiyun __u32 transferred; /* size of received/written bytes */ 72*4882a593Smuzhiyun __u32 flags; /* bit 0: 0 = synchronous; 1 = asynchronous */ 73*4882a593Smuzhiyun void __user *message; /* pointer to header and data in user space */ 74*4882a593Smuzhiyun } __attribute__ ((packed)); 75*4882a593Smuzhiyun 76*4882a593Smuzhiyun /* Request values for USBTMC driver's ioctl entry point */ 77*4882a593Smuzhiyun #define USBTMC_IOC_NR 91 78*4882a593Smuzhiyun #define USBTMC_IOCTL_INDICATOR_PULSE _IO(USBTMC_IOC_NR, 1) 79*4882a593Smuzhiyun #define USBTMC_IOCTL_CLEAR _IO(USBTMC_IOC_NR, 2) 80*4882a593Smuzhiyun #define USBTMC_IOCTL_ABORT_BULK_OUT _IO(USBTMC_IOC_NR, 3) 81*4882a593Smuzhiyun #define USBTMC_IOCTL_ABORT_BULK_IN _IO(USBTMC_IOC_NR, 4) 82*4882a593Smuzhiyun #define USBTMC_IOCTL_CLEAR_OUT_HALT _IO(USBTMC_IOC_NR, 6) 83*4882a593Smuzhiyun #define USBTMC_IOCTL_CLEAR_IN_HALT _IO(USBTMC_IOC_NR, 7) 84*4882a593Smuzhiyun #define USBTMC_IOCTL_CTRL_REQUEST _IOWR(USBTMC_IOC_NR, 8, struct usbtmc_ctrlrequest) 85*4882a593Smuzhiyun #define USBTMC_IOCTL_GET_TIMEOUT _IOR(USBTMC_IOC_NR, 9, __u32) 86*4882a593Smuzhiyun #define USBTMC_IOCTL_SET_TIMEOUT _IOW(USBTMC_IOC_NR, 10, __u32) 87*4882a593Smuzhiyun #define USBTMC_IOCTL_EOM_ENABLE _IOW(USBTMC_IOC_NR, 11, __u8) 88*4882a593Smuzhiyun #define USBTMC_IOCTL_CONFIG_TERMCHAR _IOW(USBTMC_IOC_NR, 12, struct usbtmc_termchar) 89*4882a593Smuzhiyun #define USBTMC_IOCTL_WRITE _IOWR(USBTMC_IOC_NR, 13, struct usbtmc_message) 90*4882a593Smuzhiyun #define USBTMC_IOCTL_READ _IOWR(USBTMC_IOC_NR, 14, struct usbtmc_message) 91*4882a593Smuzhiyun #define USBTMC_IOCTL_WRITE_RESULT _IOWR(USBTMC_IOC_NR, 15, __u32) 92*4882a593Smuzhiyun #define USBTMC_IOCTL_API_VERSION _IOR(USBTMC_IOC_NR, 16, __u32) 93*4882a593Smuzhiyun 94*4882a593Smuzhiyun #define USBTMC488_IOCTL_GET_CAPS _IOR(USBTMC_IOC_NR, 17, unsigned char) 95*4882a593Smuzhiyun #define USBTMC488_IOCTL_READ_STB _IOR(USBTMC_IOC_NR, 18, unsigned char) 96*4882a593Smuzhiyun #define USBTMC488_IOCTL_REN_CONTROL _IOW(USBTMC_IOC_NR, 19, unsigned char) 97*4882a593Smuzhiyun #define USBTMC488_IOCTL_GOTO_LOCAL _IO(USBTMC_IOC_NR, 20) 98*4882a593Smuzhiyun #define USBTMC488_IOCTL_LOCAL_LOCKOUT _IO(USBTMC_IOC_NR, 21) 99*4882a593Smuzhiyun #define USBTMC488_IOCTL_TRIGGER _IO(USBTMC_IOC_NR, 22) 100*4882a593Smuzhiyun #define USBTMC488_IOCTL_WAIT_SRQ _IOW(USBTMC_IOC_NR, 23, __u32) 101*4882a593Smuzhiyun 102*4882a593Smuzhiyun #define USBTMC_IOCTL_MSG_IN_ATTR _IOR(USBTMC_IOC_NR, 24, __u8) 103*4882a593Smuzhiyun #define USBTMC_IOCTL_AUTO_ABORT _IOW(USBTMC_IOC_NR, 25, __u8) 104*4882a593Smuzhiyun 105*4882a593Smuzhiyun /* Cancel and cleanup asynchronous calls */ 106*4882a593Smuzhiyun #define USBTMC_IOCTL_CANCEL_IO _IO(USBTMC_IOC_NR, 35) 107*4882a593Smuzhiyun #define USBTMC_IOCTL_CLEANUP_IO _IO(USBTMC_IOC_NR, 36) 108*4882a593Smuzhiyun 109*4882a593Smuzhiyun /* Driver encoded usb488 capabilities */ 110*4882a593Smuzhiyun #define USBTMC488_CAPABILITY_TRIGGER 1 111*4882a593Smuzhiyun #define USBTMC488_CAPABILITY_SIMPLE 2 112*4882a593Smuzhiyun #define USBTMC488_CAPABILITY_REN_CONTROL 2 113*4882a593Smuzhiyun #define USBTMC488_CAPABILITY_GOTO_LOCAL 2 114*4882a593Smuzhiyun #define USBTMC488_CAPABILITY_LOCAL_LOCKOUT 2 115*4882a593Smuzhiyun #define USBTMC488_CAPABILITY_488_DOT_2 4 116*4882a593Smuzhiyun #define USBTMC488_CAPABILITY_DT1 16 117*4882a593Smuzhiyun #define USBTMC488_CAPABILITY_RL1 32 118*4882a593Smuzhiyun #define USBTMC488_CAPABILITY_SR1 64 119*4882a593Smuzhiyun #define USBTMC488_CAPABILITY_FULL_SCPI 128 120*4882a593Smuzhiyun 121*4882a593Smuzhiyun #endif 122