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