blob: 5a0e95edf4dfed55288acc59fb9ea88f49f0dcd6 [file] [log] [blame]
Takahiro Hirofuchi0945b4f2011-05-14 03:55:07 -07001/*
2 * Copyright (C) 2005-2007 Takahiro Hirofuchi
3 */
4
matt mooney4fd83e82011-06-19 22:44:34 -07005#ifndef __USBIP_COMMON_H
6#define __USBIP_COMMON_H
Takahiro Hirofuchi0945b4f2011-05-14 03:55:07 -07007
Valentina Manea021aed82014-03-08 14:53:26 +02008#include <libudev.h>
matt mooney4fd83e82011-06-19 22:44:34 -07009
10#include <stdint.h>
11#include <stdio.h>
12#include <stdlib.h>
13#include <string.h>
14
15#include <syslog.h>
16#include <unistd.h>
Shuah Khand1fd43d2014-01-24 11:34:13 -070017#include <linux/usb/ch9.h>
Shuah Khancec2e7b2014-03-03 16:38:45 -070018#include "../../uapi/usbip.h"
Takahiro Hirofuchi0945b4f2011-05-14 03:55:07 -070019
20#ifndef USBIDS_FILE
21#define USBIDS_FILE "/usr/share/hwdata/usb.ids"
22#endif
23
24#ifndef VHCI_STATE_PATH
25#define VHCI_STATE_PATH "/var/run/vhci_hcd"
26#endif
27
matt mooney5a285cf2011-05-26 06:17:08 -070028/* kernel module names */
29#define USBIP_CORE_MOD_NAME "usbip-core"
30#define USBIP_HOST_DRV_NAME "usbip-host"
31#define USBIP_VHCI_DRV_NAME "vhci_hcd"
32
Valentina Manea1e940312014-03-08 14:53:19 +020033/* sysfs constants */
34#define SYSFS_MNT_PATH "/sys"
35#define SYSFS_BUS_NAME "bus"
36#define SYSFS_BUS_TYPE "usb"
37#define SYSFS_DRIVERS_NAME "drivers"
38
39#define SYSFS_PATH_MAX 256
40#define SYSFS_BUS_ID_SIZE 32
41
Takahiro Hirofuchi0945b4f2011-05-14 03:55:07 -070042extern int usbip_use_syslog;
43extern int usbip_use_stderr;
44extern int usbip_use_debug ;
45
matt mooney213fd4a2011-06-19 22:44:32 -070046#define PROGNAME "usbip"
Takahiro Hirofuchi0945b4f2011-05-14 03:55:07 -070047
matt mooney213fd4a2011-06-19 22:44:32 -070048#define pr_fmt(fmt) "%s: %s: " fmt "\n", PROGNAME
49#define dbg_fmt(fmt) pr_fmt("%s:%d:[%s] " fmt), "debug", \
Joe Perchesf8628a42014-05-23 22:13:20 -070050 __FILE__, __LINE__, __func__
Takahiro Hirofuchi0945b4f2011-05-14 03:55:07 -070051
matt mooney213fd4a2011-06-19 22:44:32 -070052#define err(fmt, args...) \
53 do { \
54 if (usbip_use_syslog) { \
55 syslog(LOG_ERR, pr_fmt(fmt), "error", ##args); \
56 } \
57 if (usbip_use_stderr) { \
58 fprintf(stderr, pr_fmt(fmt), "error", ##args); \
59 } \
60 } while (0)
Takahiro Hirofuchi0945b4f2011-05-14 03:55:07 -070061
matt mooney213fd4a2011-06-19 22:44:32 -070062#define info(fmt, args...) \
63 do { \
64 if (usbip_use_syslog) { \
65 syslog(LOG_INFO, pr_fmt(fmt), "info", ##args); \
66 } \
67 if (usbip_use_stderr) { \
68 fprintf(stderr, pr_fmt(fmt), "info", ##args); \
69 } \
70 } while (0)
Takahiro Hirofuchi0945b4f2011-05-14 03:55:07 -070071
matt mooney213fd4a2011-06-19 22:44:32 -070072#define dbg(fmt, args...) \
73 do { \
74 if (usbip_use_debug) { \
75 if (usbip_use_syslog) { \
76 syslog(LOG_DEBUG, dbg_fmt(fmt), ##args); \
77 } \
78 if (usbip_use_stderr) { \
79 fprintf(stderr, dbg_fmt(fmt), ##args); \
80 } \
81 } \
82 } while (0)
Takahiro Hirofuchi0945b4f2011-05-14 03:55:07 -070083
matt mooney213fd4a2011-06-19 22:44:32 -070084#define BUG() \
85 do { \
86 err("sorry, it's a bug!"); \
87 abort(); \
88 } while (0)
Takahiro Hirofuchi0945b4f2011-05-14 03:55:07 -070089
matt mooney35dd0c22011-05-27 01:44:14 -070090struct usbip_usb_interface {
Takahiro Hirofuchi0945b4f2011-05-14 03:55:07 -070091 uint8_t bInterfaceClass;
92 uint8_t bInterfaceSubClass;
93 uint8_t bInterfaceProtocol;
94 uint8_t padding; /* alignment */
95} __attribute__((packed));
96
matt mooney35dd0c22011-05-27 01:44:14 -070097struct usbip_usb_device {
Takahiro Hirofuchi0945b4f2011-05-14 03:55:07 -070098 char path[SYSFS_PATH_MAX];
99 char busid[SYSFS_BUS_ID_SIZE];
100
101 uint32_t busnum;
102 uint32_t devnum;
103 uint32_t speed;
104
105 uint16_t idVendor;
106 uint16_t idProduct;
107 uint16_t bcdDevice;
108
109 uint8_t bDeviceClass;
110 uint8_t bDeviceSubClass;
111 uint8_t bDeviceProtocol;
112 uint8_t bConfigurationValue;
113 uint8_t bNumConfigurations;
114 uint8_t bNumInterfaces;
115} __attribute__((packed));
116
117#define to_string(s) #s
118
matt mooney35dd0c22011-05-27 01:44:14 -0700119void dump_usb_interface(struct usbip_usb_interface *);
120void dump_usb_device(struct usbip_usb_device *);
Valentina Manea021aed82014-03-08 14:53:26 +0200121int read_usb_device(struct udev_device *sdev, struct usbip_usb_device *udev);
122int read_attr_value(struct udev_device *dev, const char *name,
Kurt Kanzenbach9db91e12013-02-22 12:13:29 +0100123 const char *format);
matt mooney35dd0c22011-05-27 01:44:14 -0700124int read_usb_interface(struct usbip_usb_device *udev, int i,
125 struct usbip_usb_interface *uinf);
Takahiro Hirofuchi0945b4f2011-05-14 03:55:07 -0700126
127const char *usbip_speed_string(int num);
128const char *usbip_status_string(int32_t status);
129
130int usbip_names_init(char *);
131void usbip_names_free(void);
Kurt Kanzenbach9db91e12013-02-22 12:13:29 +0100132void usbip_names_get_product(char *buff, size_t size, uint16_t vendor,
133 uint16_t product);
134void usbip_names_get_class(char *buff, size_t size, uint8_t class,
135 uint8_t subclass, uint8_t protocol);
Takahiro Hirofuchi0945b4f2011-05-14 03:55:07 -0700136
matt mooney4fd83e82011-06-19 22:44:34 -0700137#endif /* __USBIP_COMMON_H */