xref: /OK3568_Linux_fs/kernel/tools/usb/usbip/libsrc/usbip_common.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun  * Copyright (C) 2005-2007 Takahiro Hirofuchi
4*4882a593Smuzhiyun  */
5*4882a593Smuzhiyun 
6*4882a593Smuzhiyun #ifndef __USBIP_COMMON_H
7*4882a593Smuzhiyun #define __USBIP_COMMON_H
8*4882a593Smuzhiyun 
9*4882a593Smuzhiyun #include <libudev.h>
10*4882a593Smuzhiyun 
11*4882a593Smuzhiyun #include <stdint.h>
12*4882a593Smuzhiyun #include <stdio.h>
13*4882a593Smuzhiyun #include <stdlib.h>
14*4882a593Smuzhiyun #include <string.h>
15*4882a593Smuzhiyun 
16*4882a593Smuzhiyun #include <syslog.h>
17*4882a593Smuzhiyun #include <unistd.h>
18*4882a593Smuzhiyun #include <linux/usb/ch9.h>
19*4882a593Smuzhiyun #include <linux/usbip.h>
20*4882a593Smuzhiyun 
21*4882a593Smuzhiyun #ifndef USBIDS_FILE
22*4882a593Smuzhiyun #define USBIDS_FILE "/usr/share/hwdata/usb.ids"
23*4882a593Smuzhiyun #endif
24*4882a593Smuzhiyun 
25*4882a593Smuzhiyun #ifndef VHCI_STATE_PATH
26*4882a593Smuzhiyun #define VHCI_STATE_PATH "/var/run/vhci_hcd"
27*4882a593Smuzhiyun #endif
28*4882a593Smuzhiyun 
29*4882a593Smuzhiyun #define VUDC_DEVICE_DESCR_FILE "dev_desc"
30*4882a593Smuzhiyun 
31*4882a593Smuzhiyun /* kernel module names */
32*4882a593Smuzhiyun #define USBIP_CORE_MOD_NAME	"usbip-core"
33*4882a593Smuzhiyun #define USBIP_HOST_DRV_NAME	"usbip-host"
34*4882a593Smuzhiyun #define USBIP_DEVICE_DRV_NAME	"usbip-vudc"
35*4882a593Smuzhiyun #define USBIP_VHCI_DRV_NAME	"vhci_hcd"
36*4882a593Smuzhiyun 
37*4882a593Smuzhiyun /* sysfs constants */
38*4882a593Smuzhiyun #define SYSFS_MNT_PATH         "/sys"
39*4882a593Smuzhiyun #define SYSFS_BUS_NAME         "bus"
40*4882a593Smuzhiyun #define SYSFS_BUS_TYPE         "usb"
41*4882a593Smuzhiyun #define SYSFS_DRIVERS_NAME     "drivers"
42*4882a593Smuzhiyun 
43*4882a593Smuzhiyun #define SYSFS_PATH_MAX		256
44*4882a593Smuzhiyun #define SYSFS_BUS_ID_SIZE	32
45*4882a593Smuzhiyun 
46*4882a593Smuzhiyun /* Defines for op_code status in server/client op_common PDUs */
47*4882a593Smuzhiyun #define ST_OK	0x00
48*4882a593Smuzhiyun #define ST_NA	0x01
49*4882a593Smuzhiyun 	/* Device requested for import is not available */
50*4882a593Smuzhiyun #define ST_DEV_BUSY	0x02
51*4882a593Smuzhiyun 	/* Device requested for import is in error state */
52*4882a593Smuzhiyun #define ST_DEV_ERR	0x03
53*4882a593Smuzhiyun #define ST_NODEV	0x04
54*4882a593Smuzhiyun #define ST_ERROR	0x05
55*4882a593Smuzhiyun 
56*4882a593Smuzhiyun extern int usbip_use_syslog;
57*4882a593Smuzhiyun extern int usbip_use_stderr;
58*4882a593Smuzhiyun extern int usbip_use_debug ;
59*4882a593Smuzhiyun 
60*4882a593Smuzhiyun #define PROGNAME "usbip"
61*4882a593Smuzhiyun 
62*4882a593Smuzhiyun #define pr_fmt(fmt)	"%s: %s: " fmt "\n", PROGNAME
63*4882a593Smuzhiyun #define dbg_fmt(fmt)	pr_fmt("%s:%d:[%s] " fmt), "debug",	\
64*4882a593Smuzhiyun 		        __FILE__, __LINE__, __func__
65*4882a593Smuzhiyun 
66*4882a593Smuzhiyun #define err(fmt, args...)						\
67*4882a593Smuzhiyun 	do {								\
68*4882a593Smuzhiyun 		if (usbip_use_syslog) {					\
69*4882a593Smuzhiyun 			syslog(LOG_ERR, pr_fmt(fmt), "error", ##args);	\
70*4882a593Smuzhiyun 		}							\
71*4882a593Smuzhiyun 		if (usbip_use_stderr) {					\
72*4882a593Smuzhiyun 			fprintf(stderr, pr_fmt(fmt), "error", ##args);	\
73*4882a593Smuzhiyun 		}							\
74*4882a593Smuzhiyun 	} while (0)
75*4882a593Smuzhiyun 
76*4882a593Smuzhiyun #define info(fmt, args...)						\
77*4882a593Smuzhiyun 	do {								\
78*4882a593Smuzhiyun 		if (usbip_use_syslog) {					\
79*4882a593Smuzhiyun 			syslog(LOG_INFO, pr_fmt(fmt), "info", ##args);	\
80*4882a593Smuzhiyun 		}							\
81*4882a593Smuzhiyun 		if (usbip_use_stderr) {					\
82*4882a593Smuzhiyun 			fprintf(stderr, pr_fmt(fmt), "info", ##args);	\
83*4882a593Smuzhiyun 		}							\
84*4882a593Smuzhiyun 	} while (0)
85*4882a593Smuzhiyun 
86*4882a593Smuzhiyun #define dbg(fmt, args...)						\
87*4882a593Smuzhiyun 	do {								\
88*4882a593Smuzhiyun 	if (usbip_use_debug) {						\
89*4882a593Smuzhiyun 		if (usbip_use_syslog) {					\
90*4882a593Smuzhiyun 			syslog(LOG_DEBUG, dbg_fmt(fmt), ##args);	\
91*4882a593Smuzhiyun 		}							\
92*4882a593Smuzhiyun 		if (usbip_use_stderr) {					\
93*4882a593Smuzhiyun 			fprintf(stderr, dbg_fmt(fmt), ##args);		\
94*4882a593Smuzhiyun 		}							\
95*4882a593Smuzhiyun 	}								\
96*4882a593Smuzhiyun 	} while (0)
97*4882a593Smuzhiyun 
98*4882a593Smuzhiyun #define BUG()						\
99*4882a593Smuzhiyun 	do {						\
100*4882a593Smuzhiyun 		err("sorry, it's a bug!");		\
101*4882a593Smuzhiyun 		abort();				\
102*4882a593Smuzhiyun 	} while (0)
103*4882a593Smuzhiyun 
104*4882a593Smuzhiyun struct usbip_usb_interface {
105*4882a593Smuzhiyun 	uint8_t bInterfaceClass;
106*4882a593Smuzhiyun 	uint8_t bInterfaceSubClass;
107*4882a593Smuzhiyun 	uint8_t bInterfaceProtocol;
108*4882a593Smuzhiyun 	uint8_t padding;	/* alignment */
109*4882a593Smuzhiyun } __attribute__((packed));
110*4882a593Smuzhiyun 
111*4882a593Smuzhiyun struct usbip_usb_device {
112*4882a593Smuzhiyun 	char path[SYSFS_PATH_MAX];
113*4882a593Smuzhiyun 	char busid[SYSFS_BUS_ID_SIZE];
114*4882a593Smuzhiyun 
115*4882a593Smuzhiyun 	uint32_t busnum;
116*4882a593Smuzhiyun 	uint32_t devnum;
117*4882a593Smuzhiyun 	uint32_t speed;
118*4882a593Smuzhiyun 
119*4882a593Smuzhiyun 	uint16_t idVendor;
120*4882a593Smuzhiyun 	uint16_t idProduct;
121*4882a593Smuzhiyun 	uint16_t bcdDevice;
122*4882a593Smuzhiyun 
123*4882a593Smuzhiyun 	uint8_t bDeviceClass;
124*4882a593Smuzhiyun 	uint8_t bDeviceSubClass;
125*4882a593Smuzhiyun 	uint8_t bDeviceProtocol;
126*4882a593Smuzhiyun 	uint8_t bConfigurationValue;
127*4882a593Smuzhiyun 	uint8_t bNumConfigurations;
128*4882a593Smuzhiyun 	uint8_t bNumInterfaces;
129*4882a593Smuzhiyun } __attribute__((packed));
130*4882a593Smuzhiyun 
131*4882a593Smuzhiyun #define to_string(s)	#s
132*4882a593Smuzhiyun 
133*4882a593Smuzhiyun void dump_usb_interface(struct usbip_usb_interface *);
134*4882a593Smuzhiyun void dump_usb_device(struct usbip_usb_device *);
135*4882a593Smuzhiyun int read_usb_device(struct udev_device *sdev, struct usbip_usb_device *udev);
136*4882a593Smuzhiyun int read_attr_value(struct udev_device *dev, const char *name,
137*4882a593Smuzhiyun 		    const char *format);
138*4882a593Smuzhiyun int read_usb_interface(struct usbip_usb_device *udev, int i,
139*4882a593Smuzhiyun 		       struct usbip_usb_interface *uinf);
140*4882a593Smuzhiyun 
141*4882a593Smuzhiyun const char *usbip_speed_string(int num);
142*4882a593Smuzhiyun const char *usbip_status_string(int32_t status);
143*4882a593Smuzhiyun const char *usbip_op_common_status_string(int status);
144*4882a593Smuzhiyun 
145*4882a593Smuzhiyun int usbip_names_init(char *);
146*4882a593Smuzhiyun void usbip_names_free(void);
147*4882a593Smuzhiyun void usbip_names_get_product(char *buff, size_t size, uint16_t vendor,
148*4882a593Smuzhiyun 			     uint16_t product);
149*4882a593Smuzhiyun void usbip_names_get_class(char *buff, size_t size, uint8_t class,
150*4882a593Smuzhiyun 			   uint8_t subclass, uint8_t protocol);
151*4882a593Smuzhiyun 
152*4882a593Smuzhiyun #endif /* __USBIP_COMMON_H */
153