NetBSD/sys/dev/pcmcia/if_malo_pcmciavar.h
nonaka 5ffb0503f3 wlan interfaces make interrupt routine running on softint context.
see http://mail-index.netbsd.org/tech-kern/2016/12/06/msg021281.html

tested device:
 * ath at pci: AR5212, AR5424
 * athn at pci: AR9287
 * ipw at pci: 2100BG
 * iwi at pci: 2915ABG
 * iwm at pci: 3165, 7260, 8260
 * iwn at pci: 4945, 6235
 * ral at pci: RT2560
 * rtwn at pci: RTL8192CE
2017-02-02 10:05:35 +00:00

396 lines
9.2 KiB
C

/* $NetBSD: if_malo_pcmciavar.h,v 1.3 2017/02/02 10:05:35 nonaka Exp $ */
/* $OpenBSD: if_malovar.h,v 1.27 2007/10/09 20:37:32 mglocker Exp $ */
/*
* Copyright (c) 2007 Marcus Glocker <mglocker@openbsd.org>
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*/
/* simplify bus space access */
#define MALO_READ_1(sc, reg) \
bus_space_read_1((sc)->sc_iot, (sc)->sc_ioh, (reg))
#define MALO_READ_2(sc, reg) \
bus_space_read_2((sc)->sc_iot, (sc)->sc_ioh, (reg))
#ifdef __BUS_SPACE_HAS_STREAM_METHODS
#define MALO_READ_MULTI_2(sc, reg, off, size) \
bus_space_read_multi_stream_2((sc)->sc_iot, (sc)->sc_ioh, (reg), (off), (size))
#else
#if _BYTE_ORDER == _LITTLE_ENDIAN
#define MALO_READ_MULTI_2(sc, reg, off, size) \
bus_space_read_multi_2((sc)->sc_iot, (sc)->sc_ioh, (reg), (off), (size))
#else
#error not support bus_space_write_multi_stream_2()
#endif
#endif
#define MALO_WRITE_1(sc, reg, val) \
bus_space_write_1((sc)->sc_iot, (sc)->sc_ioh, (reg), (val))
#define MALO_WRITE_2(sc, reg, val) \
bus_space_write_2((sc)->sc_iot, (sc)->sc_ioh, (reg), (val))
#ifdef __BUS_SPACE_HAS_STREAM_METHODS
#define MALO_WRITE_MULTI_2(sc, reg, off, size) \
bus_space_write_multi_stream_2((sc)->sc_iot, (sc)->sc_ioh, (reg), (off), (size))
#else
#if _BYTE_ORDER == _LITTLE_ENDIAN
#define MALO_WRITE_MULTI_2(sc, reg, off, size) \
bus_space_write_multi_2((sc)->sc_iot, (sc)->sc_ioh, (reg), (off), (size))
#else
#error not support bus_space_write_multi_stream_2()
#endif
#endif
/* miscellaneous */
#define MALO_FW_HELPER_BSIZE 256 /* helper FW block size */
#define MALO_FW_HELPER_LOADED 0x10 /* helper FW loaded */
#define MALO_FW_MAIN_MAXRETRY 20 /* main FW block resend max retry */
#define MALO_CMD_BUFFER_SIZE 4096 /* cmd buffer */
#define MALO_DATA_BUFFER_SIZE 4096 /* data buffer */
/* device flags */
#define MALO_DEVICE_ATTACHED (1 << 0)
#define MALO_DEVICE_ENABLED (1 << 1)
#define MALO_FW_LOADED (1 << 2)
#define MALO_ASSOC_FAILED (1 << 3)
/*
* FW command structures
*/
struct malo_cmd_header {
uint16_t cmd;
uint16_t size;
uint16_t seqnum;
uint16_t result;
/* malo_cmd_body */
};
struct malo_cmd_body_spec {
uint16_t hw_if_version;
uint16_t hw_version;
uint16_t num_of_wcb;
uint16_t num_of_mcast;
uint8_t macaddr[ETHER_ADDR_LEN];
uint16_t regioncode;
uint16_t num_of_antenna;
uint32_t fw_version;
uint32_t wcbbase;
uint32_t rxpdrdptr;
uint32_t rxpdwrptr;
uint32_t fw_capinfo;
} __packed;
struct malo_cmd_body_scan {
uint8_t bsstype;
uint8_t bssid[ETHER_ADDR_LEN];
/* malo_cmd_tlv_ssid */
/* malo_cmd_tlv_chanlist */
/* malo_cmd_tlv_rates */
/* malo_cmd_tlv_numprobes */
} __packed;
struct malo_cmd_body_rsp_scan {
uint16_t bufsize;
uint8_t numofset;
} __packed;
struct malo_cmd_body_rsp_scan_set {
uint16_t size;
uint8_t bssid[ETHER_ADDR_LEN];
uint8_t rssi;
uint8_t timestamp[8];
uint16_t beaconintvl;
uint16_t capinfo;
uint8_t data[0];
} __packed;
struct malo_cmd_body_auth {
uint8_t peermac[ETHER_ADDR_LEN];
uint8_t authtype;
} __packed;
#define MALO_WEP_ACTION_TYPE_ADD 0x02
#define MALO_WEP_ACTION_TYPE_REMOVE 0x04
#define MALO_WEP_ACTION_TYPE_DEFAULT 0x08
#define MALO_WEP_KEY_TYPE_40BIT 0x01
#define MALO_WEP_KEY_TYPE_104BIT 0x02
struct malo_cmd_body_wep {
uint16_t action;
uint16_t key_index;
uint8_t key_type_1;
uint8_t key_type_2;
uint8_t key_type_3;
uint8_t key_type_4;
uint8_t key_value_1[16];
uint8_t key_value_2[16];
uint8_t key_value_3[16];
uint8_t key_value_4[16];
} __packed;
#define MALO_OID_BSS 0x00
#define MALO_OID_RATE 0x01
#define MALO_OID_BCNPERIOD 0x02
#define MALO_OID_DTIMPERIOD 0x03
#define MALO_OID_ASSOCTIMEOUT 0x04
#define MALO_OID_RTSTRESH 0x05
#define MALO_OID_SHORTRETRY 0x06
#define MALO_OID_LONGRETRY 0x07
#define MALO_OID_FRAGTRESH 0x08
#define MALO_OID_80211D 0x09
#define MALO_OID_80211H 0x0a
struct malo_cmd_body_snmp {
uint16_t action;
uint16_t oid;
uint16_t size;
uint8_t data[128];
} __packed;
struct malo_cmd_body_radio {
uint16_t action;
uint16_t control;
} __packed;
struct malo_cmd_body_channel {
uint16_t action;
uint16_t channel;
uint16_t rftype;
uint16_t reserved;
uint8_t channel_list[32];
} __packed;
struct malo_cmd_body_txpower {
uint16_t action;
int16_t txpower;
} __packed;
struct malo_cmd_body_antenna {
uint16_t action;
uint16_t antenna_mode;
} __packed;
struct malo_cmd_body_macctrl {
uint16_t action;
uint16_t reserved;
} __packed;
struct malo_cmd_body_macaddr {
uint16_t action;
uint8_t macaddr[ETHER_ADDR_LEN];
} __packed;
struct malo_cmd_body_assoc {
uint8_t peermac[ETHER_ADDR_LEN];
uint16_t capinfo;
uint16_t listenintrv;
uint16_t bcnperiod;
uint8_t dtimperiod;
/* malo_cmd_tlv_ssid */
/* malo_cmd_tlv_phy */
/* malo_cmd_tlv_cf */
/* malo_cmd_tlv_rate */
} __packed;
struct malo_cmd_body_rsp_assoc {
uint16_t capinfo;
uint16_t status;
uint16_t assoc_id;
uint16_t info_len;
/* uint8_t info[270] */
} __packed;
struct malo_cmd_body_80211d {
uint16_t action;
/* malo_cmd_tlv_80211d */
} __packed;
struct malo_cmd_body_bgscan_config {
uint16_t action;
uint8_t enable;
uint8_t bsstype;
uint8_t chperscan;
uint8_t discard;
uint16_t reserved;
uint32_t scanintvl;
uint32_t storecond;
uint32_t reportcond;
uint16_t maxscanres;
} __packed;
struct malo_cmd_body_bgscan_query {
uint8_t flush;
} __packed;
#define MALO_RATE_BITMAP_DS1 (1 << 0)
#define MALO_RATE_BITMAP_DS2 (1 << 1)
#define MALO_RATE_BITMAP_DS5 (1 << 2)
#define MALO_RATE_BITMAP_DS11 (1 << 3)
#define MALO_RATE_BITMAP_OFDM6 (1 << 5)
#define MALO_RATE_BITMAP_OFDM9 (1 << 6)
#define MALO_RATE_BITMAP_OFDM12 (1 << 7)
#define MALO_RATE_BITMAP_OFDM18 (1 << 8)
#define MALO_RATE_BITMAP_OFDM24 (1 << 9)
#define MALO_RATE_BITMAP_OFDM36 (1 << 10)
#define MALO_RATE_BITMAP_OFDM48 (1 << 11)
#define MALO_RATE_BITMAP_OFDM54 (1 << 12)
#define MALO_RATE_BITMAP_AUTO 0x1fef
struct malo_cmd_body_rate {
uint16_t action;
uint16_t hwauto;
uint16_t ratebitmap;
} __packed;
/*
* FW command TLV structures
*/
#define MALO_TLV_TYPE_SSID 0x0000
#define MALO_TLV_TYPE_RATES 0x0001
#define MALO_TLV_TYPE_PHY 0x0003
#define MALO_TLV_TYPE_CF 0x0004
#define MALO_TLV_TYPE_80211D 0x0007
#define MALO_TLV_TYPE_CHANLIST 0x0101
#define MALO_TLV_TYPE_NUMPROBES 0x0102
#define MALO_TLV_TYPE_PASSEID 0x010a
struct malo_cmd_tlv_ssid {
uint16_t type;
uint16_t size;
uint8_t data[0];
} __packed;
struct malo_cmd_tlv_rates {
uint16_t type;
uint16_t size;
uint8_t data[0];
} __packed;
struct malo_cmd_tlv_phy {
uint16_t type;
uint16_t size;
uint8_t data[0];
} __packed;
struct malo_cmd_tlv_cf {
uint16_t type;
uint16_t size;
uint8_t data[0];
} __packed;
struct malo_cmd_tlv_80211d_param {
uint8_t firstchannel;
uint8_t numchannels;
uint8_t maxtxpower;
} __packed;
struct malo_cmd_tlv_80211d {
uint16_t type;
uint16_t size;
uint8_t countrycode[3];
struct malo_cmd_tlv_80211d_param data[12];
} __packed;
struct malo_cmd_tlv_chanlist_param {
uint8_t radiotype;
uint8_t channumber;
uint8_t scantype;
uint16_t minscantime;
uint16_t maxscantime;
} __packed;
#define CHANNELS 12
struct malo_cmd_tlv_chanlist {
uint16_t type;
uint16_t size;
struct malo_cmd_tlv_chanlist_param data[CHANNELS];
} __packed;
struct malo_cmd_tlv_numprobes {
uint16_t type;
uint16_t size;
uint16_t numprobes;
} __packed;
struct malo_cmd_tlv_passeid {
uint16_t type;
uint16_t size;
uint8_t data[0];
} __packed;
/* RX descriptor */
#define MALO_RX_STATUS_OK 0x0001
struct malo_rx_desc {
uint16_t status;
uint8_t snr;
uint8_t control;
uint16_t pkglen;
uint8_t nf;
uint8_t rate;
uint32_t pkgoffset;
uint32_t reserved1;
uint8_t priority;
uint8_t reserved2[3];
} __packed;
/* TX descriptor */
struct malo_tx_desc {
uint32_t status;
uint32_t control;
uint32_t pkgoffset;
uint16_t pkglen;
uint8_t dstaddr[ETHER_ADDR_LEN];
uint8_t priority;
uint8_t flags;
uint8_t reserved[2];
} __packed;
/* scanned network */
struct malo_networks {
uint8_t bssid[ETHER_ADDR_LEN];
uint8_t rssi;
uint8_t timestamp[8];
uint16_t beaconintvl;
uint16_t capinfo;
uint8_t ssid[32];
uint8_t rates[14];
uint8_t channel;
} __packed;
/*
* Softc
*/
struct malo_softc {
device_t sc_dev;
struct ethercom sc_ec;
#define sc_if sc_ec.ec_if
struct ieee80211com sc_ic;
void *sc_soft_ih;
bus_space_tag_t sc_iot;
bus_space_handle_t sc_ioh;
int (*sc_newstate)
(struct ieee80211com *, enum ieee80211_state,
int);
int sc_flags;
uint8_t *sc_fw_h;
uint8_t *sc_fw_m;
size_t sc_fw_h_size;
size_t sc_fw_m_size;
int sc_cmd_ctxsave;
uint8_t *sc_cmd;
uint8_t *sc_data;
uint8_t sc_curchan;
int sc_net_num;
int sc_net_cur;
struct malo_networks sc_net[12];
callout_t sc_scan_ch;
#if NBPFILTER > 0
void *sc_drvbpf;
#endif
kcondvar_t sc_cv;
kmutex_t sc_mtx;
};