1*4882a593Smuzhiyun /* 2*4882a593Smuzhiyun * CDC network driver ioctl/indication encoding 3*4882a593Smuzhiyun * Broadcom 802.11abg Networking Device Driver 4*4882a593Smuzhiyun * 5*4882a593Smuzhiyun * Definitions subject to change without notice. 6*4882a593Smuzhiyun * 7*4882a593Smuzhiyun * Copyright (C) 2020, Broadcom. 8*4882a593Smuzhiyun * 9*4882a593Smuzhiyun * Unless you and Broadcom execute a separate written software license 10*4882a593Smuzhiyun * agreement governing use of this software, this software is licensed to you 11*4882a593Smuzhiyun * under the terms of the GNU General Public License version 2 (the "GPL"), 12*4882a593Smuzhiyun * available at http://www.broadcom.com/licenses/GPLv2.php, with the 13*4882a593Smuzhiyun * following added to such license: 14*4882a593Smuzhiyun * 15*4882a593Smuzhiyun * As a special exception, the copyright holders of this software give you 16*4882a593Smuzhiyun * permission to link this software with independent modules, and to copy and 17*4882a593Smuzhiyun * distribute the resulting executable under terms of your choice, provided that 18*4882a593Smuzhiyun * you also meet, for each linked independent module, the terms and conditions of 19*4882a593Smuzhiyun * the license of that module. An independent module is a module which is not 20*4882a593Smuzhiyun * derived from this software. The special exception does not apply to any 21*4882a593Smuzhiyun * modifications of the software. 22*4882a593Smuzhiyun * 23*4882a593Smuzhiyun * 24*4882a593Smuzhiyun * <<Broadcom-WL-IPTag/Dual:>> 25*4882a593Smuzhiyun */ 26*4882a593Smuzhiyun #ifndef _bcmcdc_h_ 27*4882a593Smuzhiyun #define _bcmcdc_h_ 28*4882a593Smuzhiyun #include <ethernet.h> 29*4882a593Smuzhiyun 30*4882a593Smuzhiyun typedef struct cdc_ioctl { 31*4882a593Smuzhiyun uint32 cmd; /* ioctl command value */ 32*4882a593Smuzhiyun uint32 len; /* lower 16: output buflen; upper 16: input buflen (excludes header) */ 33*4882a593Smuzhiyun uint32 flags; /* flag defns given below */ 34*4882a593Smuzhiyun uint32 status; /* status code returned from the device */ 35*4882a593Smuzhiyun } cdc_ioctl_t; 36*4882a593Smuzhiyun 37*4882a593Smuzhiyun /* Max valid buffer size that can be sent to the dongle */ 38*4882a593Smuzhiyun #define CDC_MAX_MSG_SIZE ETHER_MAX_LEN 39*4882a593Smuzhiyun 40*4882a593Smuzhiyun /* len field is divided into input and output buffer lengths */ 41*4882a593Smuzhiyun #define CDCL_IOC_OUTLEN_MASK 0x0000FFFF /* maximum or expected response length, */ 42*4882a593Smuzhiyun /* excluding IOCTL header */ 43*4882a593Smuzhiyun #define CDCL_IOC_OUTLEN_SHIFT 0 44*4882a593Smuzhiyun #define CDCL_IOC_INLEN_MASK 0xFFFF0000 /* input buffer length, excluding IOCTL header */ 45*4882a593Smuzhiyun #define CDCL_IOC_INLEN_SHIFT 16 46*4882a593Smuzhiyun 47*4882a593Smuzhiyun /* CDC flag definitions */ 48*4882a593Smuzhiyun #define CDCF_IOC_ERROR 0x01 /* 0=success, 1=ioctl cmd failed */ 49*4882a593Smuzhiyun #define CDCF_IOC_SET 0x02 /* 0=get, 1=set cmd */ 50*4882a593Smuzhiyun #define CDCF_IOC_OVL_IDX_MASK 0x3c /* overlay region index mask */ 51*4882a593Smuzhiyun #define CDCF_IOC_OVL_RSV 0x40 /* 1=reserve this overlay region */ 52*4882a593Smuzhiyun #define CDCF_IOC_OVL 0x80 /* 1=this ioctl corresponds to an overlay */ 53*4882a593Smuzhiyun #define CDCF_IOC_ACTION_MASK 0xfe /* SET/GET, OVL_IDX, OVL_RSV, OVL mask */ 54*4882a593Smuzhiyun #define CDCF_IOC_ACTION_SHIFT 1 /* SET/GET, OVL_IDX, OVL_RSV, OVL shift */ 55*4882a593Smuzhiyun #define CDCF_IOC_IF_MASK 0xF000 /* I/F index */ 56*4882a593Smuzhiyun #define CDCF_IOC_IF_SHIFT 12 57*4882a593Smuzhiyun #define CDCF_IOC_ID_MASK 0xFFFF0000 /* used to uniquely id an ioctl req/resp pairing */ 58*4882a593Smuzhiyun #define CDCF_IOC_ID_SHIFT 16 /* # of bits of shift for ID Mask */ 59*4882a593Smuzhiyun 60*4882a593Smuzhiyun #define CDC_IOC_IF_IDX(flags) (((flags) & CDCF_IOC_IF_MASK) >> CDCF_IOC_IF_SHIFT) 61*4882a593Smuzhiyun #define CDC_IOC_ID(flags) (((flags) & CDCF_IOC_ID_MASK) >> CDCF_IOC_ID_SHIFT) 62*4882a593Smuzhiyun 63*4882a593Smuzhiyun #define CDC_GET_IF_IDX(hdr) \ 64*4882a593Smuzhiyun ((int)((((hdr)->flags) & CDCF_IOC_IF_MASK) >> CDCF_IOC_IF_SHIFT)) 65*4882a593Smuzhiyun #define CDC_SET_IF_IDX(hdr, idx) \ 66*4882a593Smuzhiyun ((hdr)->flags = (((hdr)->flags & ~CDCF_IOC_IF_MASK) | ((idx) << CDCF_IOC_IF_SHIFT))) 67*4882a593Smuzhiyun 68*4882a593Smuzhiyun /* 69*4882a593Smuzhiyun * BDC header 70*4882a593Smuzhiyun * 71*4882a593Smuzhiyun * The BDC header is used on data packets to convey priority across USB. 72*4882a593Smuzhiyun */ 73*4882a593Smuzhiyun 74*4882a593Smuzhiyun struct bdc_header { 75*4882a593Smuzhiyun uint8 flags; /* Flags */ 76*4882a593Smuzhiyun uint8 priority; /* 802.1d Priority 0:2 bits, 4:7 USB flow control info */ 77*4882a593Smuzhiyun uint8 flags2; 78*4882a593Smuzhiyun uint8 dataOffset; /* Offset from end of BDC header to packet data, in 79*4882a593Smuzhiyun * 4-byte words. Leaves room for optional headers. 80*4882a593Smuzhiyun */ 81*4882a593Smuzhiyun }; 82*4882a593Smuzhiyun 83*4882a593Smuzhiyun #define BDC_HEADER_LEN 4 84*4882a593Smuzhiyun 85*4882a593Smuzhiyun /* flags field bitmap */ 86*4882a593Smuzhiyun #define BDC_FLAG_EXEMPT 0x03 /* EXT_STA: encryption exemption (host -> dongle?) */ 87*4882a593Smuzhiyun #define BDC_FLAG_80211_PKT 0x01 /* Packet is in 802.11 format (dongle -> host) */ 88*4882a593Smuzhiyun #define BDC_FLAG_SUM_GOOD 0x04 /* Dongle has verified good RX checksums */ 89*4882a593Smuzhiyun #define BDC_FLAG_SUM_NEEDED 0x08 /* Dongle needs to do TX checksums: host->device */ 90*4882a593Smuzhiyun #define BDC_FLAG_EVENT_MSG 0x08 /* Payload contains an event msg: device->host */ 91*4882a593Smuzhiyun #define BDC_FLAG_VER_MASK 0xf0 /* Protocol version mask */ 92*4882a593Smuzhiyun #define BDC_FLAG_VER_SHIFT 4 /* Protocol version shift */ 93*4882a593Smuzhiyun 94*4882a593Smuzhiyun /* priority field bitmap */ 95*4882a593Smuzhiyun #define BDC_PRIORITY_MASK 0x07 96*4882a593Smuzhiyun #define BDC_PRIORITY_FC_MASK 0xf0 /* flow control info mask */ 97*4882a593Smuzhiyun #define BDC_PRIORITY_FC_SHIFT 4 /* flow control info shift */ 98*4882a593Smuzhiyun 99*4882a593Smuzhiyun /* flags2 field bitmap */ 100*4882a593Smuzhiyun #define BDC_FLAG2_IF_MASK 0x0f /* interface index (host <-> dongle) */ 101*4882a593Smuzhiyun #define BDC_FLAG2_IF_SHIFT 0 102*4882a593Smuzhiyun #define BDC_FLAG2_FC_FLAG 0x10 /* flag to indicate if pkt contains */ 103*4882a593Smuzhiyun /* FLOW CONTROL info only */ 104*4882a593Smuzhiyun 105*4882a593Smuzhiyun /* version numbers */ 106*4882a593Smuzhiyun #define BDC_PROTO_VER_1 1 /* Old Protocol version */ 107*4882a593Smuzhiyun #define BDC_PROTO_VER 2 /* Protocol version */ 108*4882a593Smuzhiyun 109*4882a593Smuzhiyun /* flags2.if field access macros */ 110*4882a593Smuzhiyun #define BDC_GET_IF_IDX(hdr) \ 111*4882a593Smuzhiyun ((int)((((hdr)->flags2) & BDC_FLAG2_IF_MASK) >> BDC_FLAG2_IF_SHIFT)) 112*4882a593Smuzhiyun #define BDC_SET_IF_IDX(hdr, idx) \ 113*4882a593Smuzhiyun ((hdr)->flags2 = (((hdr)->flags2 & ~BDC_FLAG2_IF_MASK) | ((idx) << BDC_FLAG2_IF_SHIFT))) 114*4882a593Smuzhiyun 115*4882a593Smuzhiyun #endif /* _bcmcdc_h_ */ 116