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_NETWORK_H 7*4882a593Smuzhiyun #define __USBIP_NETWORK_H 8*4882a593Smuzhiyun 9*4882a593Smuzhiyun #ifdef HAVE_CONFIG_H 10*4882a593Smuzhiyun #include "../config.h" 11*4882a593Smuzhiyun #endif 12*4882a593Smuzhiyun 13*4882a593Smuzhiyun #include <sys/types.h> 14*4882a593Smuzhiyun 15*4882a593Smuzhiyun #include <stdint.h> 16*4882a593Smuzhiyun 17*4882a593Smuzhiyun extern int usbip_port; 18*4882a593Smuzhiyun extern char *usbip_port_string; 19*4882a593Smuzhiyun void usbip_setup_port_number(char *arg); 20*4882a593Smuzhiyun 21*4882a593Smuzhiyun /* ---------------------------------------------------------------------- */ 22*4882a593Smuzhiyun /* Common header for all the kinds of PDUs. */ 23*4882a593Smuzhiyun struct op_common { 24*4882a593Smuzhiyun uint16_t version; 25*4882a593Smuzhiyun 26*4882a593Smuzhiyun #define OP_REQUEST (0x80 << 8) 27*4882a593Smuzhiyun #define OP_REPLY (0x00 << 8) 28*4882a593Smuzhiyun uint16_t code; 29*4882a593Smuzhiyun 30*4882a593Smuzhiyun /* status codes defined in usbip_common.h */ 31*4882a593Smuzhiyun uint32_t status; /* op_code status (for reply) */ 32*4882a593Smuzhiyun 33*4882a593Smuzhiyun } __attribute__((packed)); 34*4882a593Smuzhiyun 35*4882a593Smuzhiyun /* ---------------------------------------------------------------------- */ 36*4882a593Smuzhiyun /* Dummy Code */ 37*4882a593Smuzhiyun #define OP_UNSPEC 0x00 38*4882a593Smuzhiyun #define OP_REQ_UNSPEC OP_UNSPEC 39*4882a593Smuzhiyun #define OP_REP_UNSPEC OP_UNSPEC 40*4882a593Smuzhiyun 41*4882a593Smuzhiyun /* ---------------------------------------------------------------------- */ 42*4882a593Smuzhiyun /* Retrieve USB device information. (still not used) */ 43*4882a593Smuzhiyun #define OP_DEVINFO 0x02 44*4882a593Smuzhiyun #define OP_REQ_DEVINFO (OP_REQUEST | OP_DEVINFO) 45*4882a593Smuzhiyun #define OP_REP_DEVINFO (OP_REPLY | OP_DEVINFO) 46*4882a593Smuzhiyun 47*4882a593Smuzhiyun struct op_devinfo_request { 48*4882a593Smuzhiyun char busid[SYSFS_BUS_ID_SIZE]; 49*4882a593Smuzhiyun } __attribute__((packed)); 50*4882a593Smuzhiyun 51*4882a593Smuzhiyun struct op_devinfo_reply { 52*4882a593Smuzhiyun struct usbip_usb_device udev; 53*4882a593Smuzhiyun struct usbip_usb_interface uinf[]; 54*4882a593Smuzhiyun } __attribute__((packed)); 55*4882a593Smuzhiyun 56*4882a593Smuzhiyun /* ---------------------------------------------------------------------- */ 57*4882a593Smuzhiyun /* Import a remote USB device. */ 58*4882a593Smuzhiyun #define OP_IMPORT 0x03 59*4882a593Smuzhiyun #define OP_REQ_IMPORT (OP_REQUEST | OP_IMPORT) 60*4882a593Smuzhiyun #define OP_REP_IMPORT (OP_REPLY | OP_IMPORT) 61*4882a593Smuzhiyun 62*4882a593Smuzhiyun struct op_import_request { 63*4882a593Smuzhiyun char busid[SYSFS_BUS_ID_SIZE]; 64*4882a593Smuzhiyun } __attribute__((packed)); 65*4882a593Smuzhiyun 66*4882a593Smuzhiyun struct op_import_reply { 67*4882a593Smuzhiyun struct usbip_usb_device udev; 68*4882a593Smuzhiyun // struct usbip_usb_interface uinf[]; 69*4882a593Smuzhiyun } __attribute__((packed)); 70*4882a593Smuzhiyun 71*4882a593Smuzhiyun #define PACK_OP_IMPORT_REQUEST(pack, request) do {\ 72*4882a593Smuzhiyun } while (0) 73*4882a593Smuzhiyun 74*4882a593Smuzhiyun #define PACK_OP_IMPORT_REPLY(pack, reply) do {\ 75*4882a593Smuzhiyun usbip_net_pack_usb_device(pack, &(reply)->udev);\ 76*4882a593Smuzhiyun } while (0) 77*4882a593Smuzhiyun 78*4882a593Smuzhiyun /* ---------------------------------------------------------------------- */ 79*4882a593Smuzhiyun /* Export a USB device to a remote host. */ 80*4882a593Smuzhiyun #define OP_EXPORT 0x06 81*4882a593Smuzhiyun #define OP_REQ_EXPORT (OP_REQUEST | OP_EXPORT) 82*4882a593Smuzhiyun #define OP_REP_EXPORT (OP_REPLY | OP_EXPORT) 83*4882a593Smuzhiyun 84*4882a593Smuzhiyun struct op_export_request { 85*4882a593Smuzhiyun struct usbip_usb_device udev; 86*4882a593Smuzhiyun } __attribute__((packed)); 87*4882a593Smuzhiyun 88*4882a593Smuzhiyun struct op_export_reply { 89*4882a593Smuzhiyun int returncode; 90*4882a593Smuzhiyun } __attribute__((packed)); 91*4882a593Smuzhiyun 92*4882a593Smuzhiyun 93*4882a593Smuzhiyun #define PACK_OP_EXPORT_REQUEST(pack, request) do {\ 94*4882a593Smuzhiyun usbip_net_pack_usb_device(pack, &(request)->udev);\ 95*4882a593Smuzhiyun } while (0) 96*4882a593Smuzhiyun 97*4882a593Smuzhiyun #define PACK_OP_EXPORT_REPLY(pack, reply) do {\ 98*4882a593Smuzhiyun } while (0) 99*4882a593Smuzhiyun 100*4882a593Smuzhiyun /* ---------------------------------------------------------------------- */ 101*4882a593Smuzhiyun /* un-Export a USB device from a remote host. */ 102*4882a593Smuzhiyun #define OP_UNEXPORT 0x07 103*4882a593Smuzhiyun #define OP_REQ_UNEXPORT (OP_REQUEST | OP_UNEXPORT) 104*4882a593Smuzhiyun #define OP_REP_UNEXPORT (OP_REPLY | OP_UNEXPORT) 105*4882a593Smuzhiyun 106*4882a593Smuzhiyun struct op_unexport_request { 107*4882a593Smuzhiyun struct usbip_usb_device udev; 108*4882a593Smuzhiyun } __attribute__((packed)); 109*4882a593Smuzhiyun 110*4882a593Smuzhiyun struct op_unexport_reply { 111*4882a593Smuzhiyun int returncode; 112*4882a593Smuzhiyun } __attribute__((packed)); 113*4882a593Smuzhiyun 114*4882a593Smuzhiyun #define PACK_OP_UNEXPORT_REQUEST(pack, request) do {\ 115*4882a593Smuzhiyun usbip_net_pack_usb_device(pack, &(request)->udev);\ 116*4882a593Smuzhiyun } while (0) 117*4882a593Smuzhiyun 118*4882a593Smuzhiyun #define PACK_OP_UNEXPORT_REPLY(pack, reply) do {\ 119*4882a593Smuzhiyun } while (0) 120*4882a593Smuzhiyun 121*4882a593Smuzhiyun /* ---------------------------------------------------------------------- */ 122*4882a593Smuzhiyun /* Negotiate IPSec encryption key. (still not used) */ 123*4882a593Smuzhiyun #define OP_CRYPKEY 0x04 124*4882a593Smuzhiyun #define OP_REQ_CRYPKEY (OP_REQUEST | OP_CRYPKEY) 125*4882a593Smuzhiyun #define OP_REP_CRYPKEY (OP_REPLY | OP_CRYPKEY) 126*4882a593Smuzhiyun 127*4882a593Smuzhiyun struct op_crypkey_request { 128*4882a593Smuzhiyun /* 128bit key */ 129*4882a593Smuzhiyun uint32_t key[4]; 130*4882a593Smuzhiyun } __attribute__((packed)); 131*4882a593Smuzhiyun 132*4882a593Smuzhiyun struct op_crypkey_reply { 133*4882a593Smuzhiyun uint32_t __reserved; 134*4882a593Smuzhiyun } __attribute__((packed)); 135*4882a593Smuzhiyun 136*4882a593Smuzhiyun 137*4882a593Smuzhiyun /* ---------------------------------------------------------------------- */ 138*4882a593Smuzhiyun /* Retrieve the list of exported USB devices. */ 139*4882a593Smuzhiyun #define OP_DEVLIST 0x05 140*4882a593Smuzhiyun #define OP_REQ_DEVLIST (OP_REQUEST | OP_DEVLIST) 141*4882a593Smuzhiyun #define OP_REP_DEVLIST (OP_REPLY | OP_DEVLIST) 142*4882a593Smuzhiyun 143*4882a593Smuzhiyun struct op_devlist_request { 144*4882a593Smuzhiyun } __attribute__((packed)); 145*4882a593Smuzhiyun 146*4882a593Smuzhiyun struct op_devlist_reply { 147*4882a593Smuzhiyun uint32_t ndev; 148*4882a593Smuzhiyun /* followed by reply_extra[] */ 149*4882a593Smuzhiyun } __attribute__((packed)); 150*4882a593Smuzhiyun 151*4882a593Smuzhiyun struct op_devlist_reply_extra { 152*4882a593Smuzhiyun struct usbip_usb_device udev; 153*4882a593Smuzhiyun struct usbip_usb_interface uinf[]; 154*4882a593Smuzhiyun } __attribute__((packed)); 155*4882a593Smuzhiyun 156*4882a593Smuzhiyun #define PACK_OP_DEVLIST_REQUEST(pack, request) do {\ 157*4882a593Smuzhiyun } while (0) 158*4882a593Smuzhiyun 159*4882a593Smuzhiyun #define PACK_OP_DEVLIST_REPLY(pack, reply) do {\ 160*4882a593Smuzhiyun (reply)->ndev = usbip_net_pack_uint32_t(pack, (reply)->ndev);\ 161*4882a593Smuzhiyun } while (0) 162*4882a593Smuzhiyun 163*4882a593Smuzhiyun uint32_t usbip_net_pack_uint32_t(int pack, uint32_t num); 164*4882a593Smuzhiyun uint16_t usbip_net_pack_uint16_t(int pack, uint16_t num); 165*4882a593Smuzhiyun void usbip_net_pack_usb_device(int pack, struct usbip_usb_device *udev); 166*4882a593Smuzhiyun void usbip_net_pack_usb_interface(int pack, struct usbip_usb_interface *uinf); 167*4882a593Smuzhiyun 168*4882a593Smuzhiyun ssize_t usbip_net_recv(int sockfd, void *buff, size_t bufflen); 169*4882a593Smuzhiyun ssize_t usbip_net_send(int sockfd, void *buff, size_t bufflen); 170*4882a593Smuzhiyun int usbip_net_send_op_common(int sockfd, uint32_t code, uint32_t status); 171*4882a593Smuzhiyun int usbip_net_recv_op_common(int sockfd, uint16_t *code, int *status); 172*4882a593Smuzhiyun int usbip_net_set_reuseaddr(int sockfd); 173*4882a593Smuzhiyun int usbip_net_set_nodelay(int sockfd); 174*4882a593Smuzhiyun int usbip_net_set_keepalive(int sockfd); 175*4882a593Smuzhiyun int usbip_net_set_v6only(int sockfd); 176*4882a593Smuzhiyun int usbip_net_tcp_connect(char *hostname, char *port); 177*4882a593Smuzhiyun 178*4882a593Smuzhiyun #endif /* __USBIP_NETWORK_H */ 179