xref: /OK3568_Linux_fs/kernel/include/uapi/linux/usb/tmc.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
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