FreeBSD kernel usb device Code
if_usievar.h
Go to the documentation of this file.
1/* $FreeBSD$ */
3/*-
4 * Copyright (c) 2011 Anybots Inc
5 * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
6 *
7 * written by Akinori Furukoshi <moonlightakkiy@yahoo.ca>
8 * - ucom part is based on u3g.c
9 *
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
12 * are met:
13 * 1. Redistributions of source code must retain the above copyright
14 * notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in the
17 * documentation and/or other materials provided with the distribution.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
23 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29 * SUCH DAMAGE.
30 */
31
32#ifndef _IF_USEVAR_H_
33#define _IF_USEVAR_H_
34
35#define USIE_DCD 0x0001
36#define USIE_DSR 0x0002
37#define USIE_DTR 0x0004
38#define USIE_RI 0x0008
39#define USIE_CTS 0x0100
40#define USIE_RTS 0x0200
41
42#define USIE_HIP_FRM_CHR 0x7e
43#define USIE_HIP_ESC_CHR 0x7d
44#define USIE_HIP_IF 0
45
46#define USIE_HIPCNS_MIN 16 /* HIP + CnS + 2 framing char */
47#define USIE_HIPCNS_MAX 261 /* HIP + max CnS 255 + 2 framing char */
48
49#define USIE_CNFG_INDEX 0
50#define USIE_IFACE_INDEX 0
51#define USIE_IFACE_MAX 12
52#define USIE_BUFSIZE 2048
53#define USIE_MTU_MAX 1500
54#define USIE_RXSZ_MAX 4096
55
56/* USB control pipe request */
57#define USIE_POWER 0x00
58#define USIE_FW_ATTR 0x06
59#define USIE_NMEA 0x07
60#define USIE_LINK_STATE 0x22
61
62/* firmware attr flags */
63#define USIE_PM_AUTO (1 << 1)
64#define USIE_FW_DHCP (1 << 3) /* DHCP capable */
65
66/* line state flags */
67#define USIE_LS_DTR (1 << 0)
68#define USIE_LS_RTS (1 << 1)
69
70/* Host Interface Porotocol Header */
71struct usie_hip {
72 uint16_t len;
73#define USIE_HIP_LEN_MASK 0x3fff
74#define USIE_HIP_IP_LEN_MASK 0x07ff
75
76 uint8_t id;
77#define USIE_HIP_PAD (1 << 7)
78#define USIE_HIP_MASK 0x7f
79#define USIE_HIP_SYNC2M 0x20 /* host -> modem */
80#define USIE_HIP_DOWN 0x26
81#define USIE_HIP_CNS2M 0x2b /* h -> m */
82#define USIE_HIP_CTX 0x3f
83#define USIE_HIP_SYNC2H 0x60 /* h <- m */
84#define USIE_HIP_RESTR 0x62
85#define USIE_HIP_RCGI 0x64
86#define USIE_HIP_CNS2H 0x6b /* h <- m */
87#define USIE_HIP_UMTS 0x78
88#define USIE_HIP_IP 0x7f
89
90 uint8_t param;
92
93/* Control and Status Header */
94struct usie_cns {
95 uint16_t obj; /* object type */
96#define USIE_CNS_OB_RSSI 0x1001 /* read RSSI */
97#define USIE_CNS_OB_HW_DISABLE 0x1011 /* disable h/w */
98#define USIE_CNS_OB_PW_SW 0x1071 /* power on/off */
99#define USIE_CNS_OB_PROF_WRITE 0x7003 /* write profile */
100#define USIE_CNS_OB_LINK_UPDATE 0x7004 /* dis/connect */
101#define USIE_CNS_OB_PDP_READ 0x7006 /* read out IP addr */
102
103 uint8_t op; /* operation type */
104#define USIE_CNS_OP_ERR (1 << 7)/* | == error */
105#define USIE_CNS_OP_REQ 0x01 /* host -> modem */
106#define USIE_CNS_OP_RSP 0x02 /* h <- m */
107#define USIE_CNS_OP_SET 0x03 /* h -> m */
108#define USIE_CNS_OP_ACK 0x04 /* h <- m */
109#define USIE_CNS_OP_NOTIF_ON 0x05 /* h -> m */
110#define USIE_CNS_OP_RSP_ON 0x06 /* h <- m */
111#define USIE_CNS_OP_NOTIF 0x07 /* h <- m */
112#define USIE_CNS_OP_NOTIF_OFF 0x08 /* h -> m */
113#define USIE_CNS_OP_RSP_OFF 0x09 /* h <- m */
114#define USIE_CNS_OP_REQ_CHG 0x0a /* h -> m */
115#define USIE_CNS_OP_RSP_CHG 0x0b /* h <- m */
116
117 uint8_t rsv0; /* reserved, always '0' */
118 uint32_t id; /* caller ID */
119/*
120 * .id is to identify calling functions
121 * h/w responses with the same .id used in request. Only '0' is reserved
122 * for notification (asynchronous message generated by h/w without any
123 * request). All other values are user defineable.
124 */
125#define USIE_CNS_ID_NOTIF 0x00000000 /* reserved */
126#define USIE_CNS_ID_INIT 0x00000001
127#define USIE_CNS_ID_STOP 0x00000002
128#define USIE_CNS_ID_DNS 0x00000003
129#define USIE_CNS_ID_RSSI 0x00000004
130
131 uint8_t rsv1; /* reserved, always '0' */
132 uint8_t len; /* length of param */
134
135/*
136 * CnS param attached to struct usie_cns
137 * usie_cns.len is total size of this param
138 * max 255
139 */
140#define USIE_CNS_PM_UP 0x01
141#define USIE_CNS_PM_DOWN 0x00
142
143/* Link Sense Indication data structure */
144struct usie_lsi {
145 uint8_t proto;
146#define USIE_LSI_UMTS 0x01
147
148 uint8_t pad0;
149 uint16_t len;
150 uint8_t area;
151#define USIE_LSI_AREA_NO 0x00
152#define USIE_LSI_AREA_NODATA 0x01
153
154 uint8_t pad1[41];
155 uint8_t state;
156#define USIE_LSI_STATE_IDLE 0x00
157
158 uint8_t pad2[33];
159 uint8_t type;
160#define USIE_LSI_IP4 0x00
161
162 uint8_t pdp_addr_len; /* PDP addr */
163 uint8_t pdp_addr[16];
164 uint8_t pad3[23];
165 uint8_t dns1_addr_len; /* DNS addr */
166 uint8_t dns1_addr[16];
168 uint8_t dns2_addr[16];
169 uint8_t wins1_addr_len; /* Wins addr */
170 uint8_t wins1_addr[16];
172 uint8_t wins2_addr[16];
173 uint8_t pad4[4];
174 uint8_t gw_addr_len; /* GW addr */
175 uint8_t gw_addr[16];
176 uint8_t rsv[8];
177} __packed;
178
180 uint8_t addr_len;
181 uint8_t pdp_addr[16];
182 uint8_t dns1_addr[16];
183 uint8_t dns2_addr[16];
184 uint8_t gw_addr[16];
185} __packed;
186
187/* Tx/Rx IP packet descriptor */
188struct usie_desc {
189 struct usie_hip hip;
190 uint16_t desc_type;
191#define USIE_TYPE_MASK 0x03ff
192#define USIE_IP_TX 0x0002
193#define USIE_IP_RX 0x0202
194
195 struct ether_header ethhdr;
196} __packed;
197
198enum {
204
205enum {
211
214
215#define USIE_UCOM_MAX 6
218
219 struct mtx sc_mtx;
220
221 struct task sc_if_status_task;
222 struct task sc_if_sync_task;
224
226
228
231
232 struct ifnet *sc_ifp;
234 device_t sc_dev;
235
236 struct mbuf *sc_rxm;
237
238 uint16_t sc_if_ifnum;
239
240 int16_t sc_rssi;
241
242 uint8_t sc_msr;
243 uint8_t sc_lsr;
244 uint8_t sc_nucom;
245
246 uint8_t sc_resp_temp[USIE_BUFSIZE] __aligned(4);
247 uint8_t sc_status_temp[USIE_BUFSIZE] __aligned(4);
248};
249
250/* Some code assumptions */
251
252extern uint8_t usie_assert[((sizeof(struct usie_hip) +
253 sizeof(struct usie_lsi) + 1) <= USIE_BUFSIZE) ? 1 : -1];
254
255extern uint8_t ucdc_assert[(sizeof(struct usb_cdc_notification)
256 >= 16) ? 1 : -1];
257
258#endif /* _IF_USEVAR_H_ */
@ USIE_UC_STATUS
Definition: if_usievar.h:199
@ USIE_UC_TX
Definition: if_usievar.h:201
@ USIE_UC_N_XFER
Definition: if_usievar.h:202
@ USIE_UC_RX
Definition: if_usievar.h:200
@ USIE_IF_TX
Definition: if_usievar.h:208
@ USIE_IF_RX
Definition: if_usievar.h:207
@ USIE_IF_STATUS
Definition: if_usievar.h:206
@ USIE_IF_N_XFER
Definition: if_usievar.h:209
#define USIE_BUFSIZE
Definition: if_usievar.h:52
uint8_t ucdc_assert[(sizeof(struct usb_cdc_notification) >=16) ? 1 :-1]
struct usie_cns __packed
struct usie_hip __aligned(4)
uint8_t usie_assert[((sizeof(struct usie_hip)+sizeof(struct usie_lsi)+1)<=USIE_BUFSIZE) ? 1 :-1]
#define USIE_UCOM_MAX
Definition: if_usievar.h:215
uint8_t rsv0
Definition: if_usievar.h:117
uint8_t len
Definition: if_usievar.h:132
uint8_t rsv1
Definition: if_usievar.h:131
uint16_t obj
Definition: if_usievar.h:95
uint8_t op
Definition: if_usievar.h:103
uint32_t id
Definition: if_usievar.h:118
uint16_t desc_type
Definition: if_usievar.h:190
struct usie_hip hip
Definition: if_usievar.h:189
struct ether_header ethhdr
Definition: if_usievar.h:195
uint8_t param
Definition: if_usievar.h:90
uint16_t len
Definition: if_usievar.h:72
uint8_t id
Definition: if_usievar.h:76
uint8_t type
Definition: if_usievar.h:159
uint8_t pad2[33]
Definition: if_usievar.h:158
uint8_t pad3[23]
Definition: if_usievar.h:164
uint8_t pad0
Definition: if_usievar.h:148
uint16_t len
Definition: if_usievar.h:149
uint8_t pdp_addr_len
Definition: if_usievar.h:162
uint8_t pad1[41]
Definition: if_usievar.h:154
uint8_t proto
Definition: if_usievar.h:145
uint8_t gw_addr[16]
Definition: if_usievar.h:175
uint8_t wins2_addr[16]
Definition: if_usievar.h:172
uint8_t wins1_addr[16]
Definition: if_usievar.h:170
uint8_t pdp_addr[16]
Definition: if_usievar.h:163
uint8_t gw_addr_len
Definition: if_usievar.h:174
uint8_t wins2_addr_len
Definition: if_usievar.h:171
uint8_t area
Definition: if_usievar.h:150
uint8_t pad4[4]
Definition: if_usievar.h:173
uint8_t rsv[8]
Definition: if_usievar.h:176
uint8_t wins1_addr_len
Definition: if_usievar.h:169
uint8_t dns1_addr[16]
Definition: if_usievar.h:166
uint8_t dns1_addr_len
Definition: if_usievar.h:165
uint8_t dns2_addr[16]
Definition: if_usievar.h:168
uint8_t state
Definition: if_usievar.h:155
uint8_t dns2_addr_len
Definition: if_usievar.h:167
uint8_t dns1_addr[16]
Definition: if_usievar.h:182
uint8_t gw_addr[16]
Definition: if_usievar.h:184
uint8_t dns2_addr[16]
Definition: if_usievar.h:183
uint8_t addr_len
Definition: if_usievar.h:180
uint8_t pdp_addr[16]
Definition: if_usievar.h:181
uint16_t sc_if_ifnum
Definition: if_usievar.h:238
struct task sc_if_status_task
Definition: if_usievar.h:221
uint8_t sc_lsr
Definition: if_usievar.h:243
struct task sc_if_sync_task
Definition: if_usievar.h:222
struct ucom_softc sc_ucom[USIE_UCOM_MAX]
Definition: if_usievar.h:216
struct usie_net_info sc_net
Definition: if_usievar.h:225
uint8_t sc_msr
Definition: if_usievar.h:242
uint8_t sc_uc_ifnum[USIE_UCOM_MAX]
Definition: if_usievar.h:217
struct ucom_super_softc sc_super_ucom
Definition: if_usievar.h:213
struct mtx sc_mtx
Definition: if_usievar.h:219
struct usb_callout sc_if_sync_ch
Definition: if_usievar.h:223
struct mbuf * sc_rxm
Definition: if_usievar.h:236
uint8_t sc_nucom
Definition: if_usievar.h:244
struct usie_desc sc_txd
Definition: if_usievar.h:227
uint8_t sc_status_temp[USIE_BUFSIZE] __aligned(4)
struct usb_device * sc_udev
Definition: if_usievar.h:233
uint8_t sc_resp_temp[USIE_BUFSIZE] __aligned(4)
struct ifnet * sc_ifp
Definition: if_usievar.h:232
int16_t sc_rssi
Definition: if_usievar.h:240
struct usb_xfer * sc_if_xfer[USIE_IF_N_XFER]
Definition: if_usievar.h:230
struct usb_xfer * sc_uc_xfer[USIE_UCOM_MAX][USIE_UC_N_XFER]
Definition: if_usievar.h:229
device_t sc_dev
Definition: if_usievar.h:234