diff options
author | dmlb <dmlb@FreeBSD.org> | 2000-04-15 19:44:05 +0000 |
---|---|---|
committer | dmlb <dmlb@FreeBSD.org> | 2000-04-15 19:44:05 +0000 |
commit | 3405727a9b7c961c7c130f0f28fcbed0e42e3350 (patch) | |
tree | 467cb0ab146105d1c984422698db29c95d3af19f /sys/dev/ray/if_raymib.h | |
parent | 65c331110e278f71a84c98a4aa63798218ea71e5 (diff) | |
download | FreeBSD-src-3405727a9b7c961c7c130f0f28fcbed0e42e3350.zip FreeBSD-src-3405727a9b7c961c7c130f0f28fcbed0e42e3350.tar.gz |
Merged in a load of information from the card documentation - not finished yet.
Diffstat (limited to 'sys/dev/ray/if_raymib.h')
-rw-r--r-- | sys/dev/ray/if_raymib.h | 459 |
1 files changed, 338 insertions, 121 deletions
diff --git a/sys/dev/ray/if_raymib.h b/sys/dev/ray/if_raymib.h index 8643315..59212ba 100644 --- a/sys/dev/ray/if_raymib.h +++ b/sys/dev/ray/if_raymib.h @@ -28,7 +28,7 @@ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * - * $Id: if_raymib.h,v 1.3 2000/03/21 14:27:46 dmlb Exp $ + * $Id: if_raymib.h,v 1.4 2000/03/31 20:13:03 dmlb Exp $ * */ @@ -142,48 +142,6 @@ struct ray_mib_5 { #define mib_test_max_chan mib_tail.mib_test_max_chan /* - * IOCTL support - */ -struct ray_param_req { - int r_failcause; - u_int8_t r_paramid; - u_int8_t r_len; - u_int8_t r_data[256]; -}; -struct ray_stats_req { - u_int64_t rxoverflow; /* Number of rx overflows */ - u_int64_t rxcksum; /* Number of checksum errors */ - u_int64_t rxhcksum; /* Number of header checksum errors */ - u_int8_t rxnoise; /* Average receiver level */ -}; -#define RAY_FAILCAUSE_EIDRANGE 1 -#define RAY_FAILCAUSE_ELENGTH 2 -/* device can possibly return up to 255 */ -#define RAY_FAILCAUSE_EDEVSTOP 256 - -#ifdef KERNEL -#define RAY_FAILCAUSE_WAITING 257 -#endif - -/* Get a param the data is a ray_param_req structure */ -#define SIOCSRAYPARAM SIOCSIFGENERIC -#define SIOCGRAYPARAM SIOCGIFGENERIC -/* Get the error counters the data is a ray_stats_req structure */ -#define SIOCGRAYSTATS _IOWR('i', 201, struct ifreq) -#define SIOCGRAYSIGLEV _IOWR('i', 202, struct ifreq) - -#define RAY_NSIGLEVRECS 8 -#define RAY_NSIGLEV 8 -#define RAY_NANTENNA 8 - -struct ray_siglev { - u_int8_t rsl_host[ETHER_ADDR_LEN]; /* MAC address */ - u_int8_t rsl_siglevs[RAY_NSIGLEV]; /* levels, newest in [0] */ - u_int8_t rsl_antennas[RAY_NANTENNA]; /* best antenna */ - struct timeval rsl_time; /* time of last packet */ -}; - -/* * MIB IDs for the update/report param commands */ #define RAY_MIB_NET_TYPE 0 @@ -470,58 +428,117 @@ struct ray_siglev { * driver. * * Symb refers to numbers cleaned from the 802.11 specification, - * discussion with 802.11 knowledgable people at Symbionics (i.e. me, - * aps, ifo, hjl). + * discussion with 802.11 knowledgable people at Symbionics or + * stuff needed by me (i.e. me, * aps, ifo, hjl). * * V4 and V5 refer to settings for version 4 and version 5 of * the firmware. * + * DOC refers to the + * Combined Interface Requirements Specification + * and Interface Design Document (IRS/IDD) + * for the + * WLAN System Interfaces Between the + * HOST COMPUTER and the + * PCMCIA WLAN INTERFACE CARD + * Revision ECF 5.00 + * 17 June, 1998 */ /* - * ADHOC - I've not got an access point + * mib_net_type + * + * DOC 0x01 - Defines network type for Start and Join + * - Network commands. + * + * Symb 0x00 - Adhoc is safer and I ain't got an AP */ #define RAY_MIB_NET_TYPE_ADHOC 0x00 #define RAY_MIB_NET_TYPE_INFRA 0x01 #define RAY_MIB_NET_TYPE_DEFAULT RAY_MIB_NET_TYPE_ADHOC /* - * TERMINAL - but we might play with using the card as an AP + * mib_ap_status + * + * DOC 0x00 - Applicable only when Network Type is + * - Infrastructure. */ #define RAY_MIB_AP_STATUS_TERMINAL 0x00 #define RAY_MIB_AP_STATUS_AP 0x01 #define RAY_MIB_AP_STATUS_DEFAULT RAY_MIB_AP_STATUS_TERMINAL /* - * - windows setting comes from the Aviator software v1.1 + * mib_ssid + * + * DOC ESSID1 - Service Set ID. Can be any ASCII string + * - up to 32 bytes in length. If the string is + * - less than 32 bytes long, it must be + * - followed by a byte of 00h. + * + * Symb - windows setting comes from the Aviator software v1.1 */ #define RAY_MIB_SSID_WINDOWS "NETWORK_NAME" #define RAY_MIB_SSID_NOT_WINDOWS "WIRELESS_NETWORK" #define RAY_MIB_SSID_DEFAULT RAY_MIB_SSID_WINDOWS +/* + * mib_scan_mode + * + * DOC 0x01 - Defines acquisition approach for + * - terminals operating in either Ad Hoc or + * - Infrastructure Networks. N/A for APs. + */ #define RAY_MIB_SCAN_MODE_PASSIVE 0x00 #define RAY_MIB_SCAN_MODE_ACTIVE 0x01 #define RAY_MIB_SCAN_MODE_DEFAULT RAY_MIB_SCAN_MODE_ACTIVE /* - * NONE - power saving only works with access points + * mib_apm_mode + * + * DOC 0x00 - Defines power management mode for + * - stations operating in either Ad Hoc or + * - Infrastructure Networks. Must always + * - be 0 for APs. */ #define RAY_MIB_APM_MODE_NONE 0x00 #define RAY_MIB_APM_MODE_POWERSAVE 0x01 #define RAY_MIB_APM_MODE_DEFAULT RAY_MIB_APM_MODE_NONE /* - * Linux.h 0x0200 - * Linux.c-V4 0x7fff - * Linux.c-V5 0x7fff - * NetBSD.c 0x7fff - disabled - * Symb 0xXXXX - you really should fragment but getting it wrong + * mib_mac_addr + * + * DOC - MAC Address to be used by WIC (For + * - format see Figure 3.2.4.1.2-1, MAC + * - Address Format). Host may echo card + * - supplied address or use locally + * - administered address. + */ + +/* + * mib_frag_thresh + * + * DOC 0x7fff - Maximum over-the-air packet size (in + * - bytes) + * + * Symb 0xXXXX - you really should fragment when in low signal + * - conditions but getting it wrong * crucifies the performance */ +#define RAY_MIB_FRAG_THRESH_MINIMUM 0 +#define RAY_MIB_FRAG_THRESH_MAXIMUM 2346 #define RAY_MIB_FRAG_THRESH_DISABLE 0x7fff #define RAY_MIB_FRAG_THRESH_DEFAULT RAY_MIB_FRAG_THRESH_DISABLE /* + * mib_dwell_time + * + * DOC 0x0080 - Defines hop dwell time in Kusec. + * - Required only of stations which intend + * - to issue a Start Network command. + * - Forward Compatible Firmware (Build + * - 5) requires that the dwell time be one of + * - the set 16, 32, 64, 128, and 256. + * * Linux.h - 16k * 2**n, n=0-4 in Kus * Linux.c-V4 0x0200 * Linux.c-V5 0x0080 - 128 Kus @@ -530,12 +547,27 @@ struct ray_siglev { * NetBSD-V5 0x0080 * Symb-V4 0xXXXX - 802.11 dwell time is XXX Kus * Symb-V5 0xXXXX - 802.11 dwell time is XXX Kus - * XXX - see init_startup_params in Linux.c + * + * XXX confirm that 1024Kus is okay for windows driver - how? and see + * XXX how it is over the maximum */ +#define RAY_MIB_DWELL_TIME_MINIMUM 1 +#define RAY_MIB_DWELL_TIME_MAXIMUM 390 #define RAY_MIB_DWELL_TIME_V4 0x0400 #define RAY_MIB_DWELL_TIME_V5 0x0080 /* + * mib_beacon_period + * + * DOC 0x0100 - Defines time between target beacon + * - transmit times (TBTT) in Kusec. + * - Forward Compatible Firmware (Build + * - 5) requires that the Beacon Period be an + * - integral multiple of the Dwell Time (not + * - exceeding 255 hops). + * - Required only of stations which intend + * - to issue a Start Network command. + * * Linux.h - n * a_hop_time in Kus * Linux.c-V4 0x0001 * Linux.c-V5 0x0100 - 256 Kus @@ -544,141 +576,225 @@ struct ray_siglev { * NetBSD-V5 0x0100 * Symb-V4 0x0001 - best performance is one beacon each dwell XXX * Symb-V5 0x0080 - best performance is one beacon each dwell XXX - * XXX - see init_startup_params in Linux.c + * + * XXX V4 should probably set this to dwell_time */ -#define RAY_MIB_BEACON_PERIOD_V4 0x01 +#define RAY_MIB_BEACON_PERIOD_MINIMUM 1 +#define RAY_MIB_BEACON_PERIOD_MAXIMUM 0xffff +#define RAY_MIB_BEACON_PERIOD_V4 0x0001 #define RAY_MIB_BEACON_PERIOD_V5 RAY_MIB_DWELL_TIME_V5 /* + * mib_dtim_interval + * + * DOC 0x01 - Number of beacons per DTIM period. + * - Only APs will use this parameter, to set + * - the DTIM period. + * * Linux.h - in beacons * Linux.c 0x01 * NetBSD 0x01 * Symb 0xXX - need to find out what DTIM is */ +#define RAY_MIB_DTIM_INTERVAL_MINIMUM 1 +#define RAY_MIB_DTIM_INTERVAL_MAXIMUM 255 #define RAY_MIB_DTIM_INTERVAL_DEFAULT 0x01 /* + * mib_max_retry + * + * DOC 31 - Number of times WIC will attempt to + * - retransmit a failed packet. + * * Linux.c 0x07 - * NetBSD 0x01 - documented default for 5/6 + * NetBSD 0x01 - "documented default for 5/6" * NetBSD 0x07 - from Linux * NetBSD 0x03 - "divined" * Symb 0xXX - 7 retries seems okay but check with APS */ +#define RAY_MIB_MAX_RETRY_MINIMUM 0 +#define RAY_MIB_MAX_RETRY_MAXIMUM 255 #define RAY_MIB_MAX_RETRY_DEFAULT 0x07 /* + * mib_ack_timo + * + * DOC 0x86 - Time WIC will wait after completion of + * - a transmit before timing out anticipated + * - ACK (2 usec steps). Should equal + * - SIFS + constant. + * * Linux.c 0xa3 * NetBSD 0x86 - documented default for 5/6 * NetBSD 0xa3 - from Linux * NetBSD 0xa3 - "divined" * Symb 0xXX - this must be a 802.11 defined setting? */ +#define RAY_MIB_ACK_TIMO_MINIMUM 0 +#define RAY_MIB_ACK_TIMO_MAXIMUM 255 #define RAY_MIB_ACK_TIMO_DEFAULT 0xa3 /* + * mib_sifs + * + * DOC 0x1c - SIFS time in usec. + * * Linux.c 0x1d * NetBSD 0x1c - documented default for 5/6 * NetBSD 0x1d - from Linux * NetBSD 0x1d - "divined" * Symb 0xXX - default SIFS for 802.11 */ +#define RAY_MIB_SIFS_MINIMUM 28 +#define RAY_MIB_SIFS_MAXIMUM 62 #define RAY_MIB_SIFS_DEFAULT 0x1d /* - * Linux.c 0x82 - * NetBSD 0x82 - documented default for 5/6 - * NetBSD 0x82 - from Linux - * Symb 0xXX - default DIFS for 802.11 + * mib_difs + * + * DOC 0x82 - DIFS time in usec. */ +#define RAY_MIB_DIFS_MINIMUM 130 +#define RAY_MIB_DIFS_MAXIMUM 255 #define RAY_MIB_DIFS_DEFAULT 0x82 /* - * Linux.c-V4 0xce - * Linux.c-V5 0x4e - * NetBSD 0x00 - documented default for 5/6 - * NetBSD-V4 0xce - from Linux - * NetBSD-V5 0x4e - from Linux - * Symb 0xXX - default PIFS for 802.11 + * mib_pifs + * + * DOC 78 - PIFS time in usec. (Not currently + * - implemented. */ +#define RAY_MIB_PIFS_MINIMUM 78 +#define RAY_MIB_PIFS_MAXIMUM 255 #define RAY_MIB_PIFS_V4 0xce #define RAY_MIB_PIFS_V5 0x4e /* + * mib_rts_thresh + * + * DOC 0x7ffff - Threshold size in bytes below which + * - messages will not require use of RTS + * - Protocol. + * * Linux.c 0x7fff * NetBSD 0x7fff - disabled * Symb 0xXXXX - need to set this realistically to get CTS/RTS mode * working right */ +#define RAY_MIB_RTS_THRESH_MINIMUM 0 +#define RAY_MIB_RTS_THRESH_MAXIMUM 2346 #define RAY_MIB_RTS_THRESH_DISABLE 0x7fff #define RAY_MIB_RTS_THRESH_DEFAULT RAY_MIB_RTS_THRESH_DISABLE /* - * Linux.c-V4 0xfb1e - * Linix.c-V5 0x04e2 + * mib_scan_dwell + * + * DOC 0x04e2 - Time channel remains clear after probe + * - transmission prior to hopping to next + * - channel. (in 2 msec steps). + * + * Linux.c-V4 0xfb1e - 128572us + * Linix.c-V5 0x04e2 - 2500us * NetBSD-V4 0xfb1e * NetBSD-V5 0x04e2 - * Symb 0xXXXX - this might be the time to dwell on a channel - * whilst scanning for the n/w. In that case it should - * be tied to the dwell time above. - * V5 numbers could be Kus, - * 0x04e2Kus = 1250*1024us = 1.28 seconds + * Symb 0xXXXX - Check that v4 h/w can do 2.5ms and default it */ +#define RAY_MIB_SCAN_DWELL_MINIMUM 1 +#define RAY_MIB_SCAN_DWELL_MAXIMUM 65535 #define RAY_MIB_SCAN_DWELL_V4 0xfb1e #define RAY_MIB_SCAN_DWELL_V5 0x04e2 /* - * Linux.c-V4 0xc75c - * Linix.c-V5 0x38a4 + * mib_scan_max_dwell + * + * DOC 0x38a4 - Time to remain on a frequency channel + * - if CCA is detected after probe + * - transmission. (in 2 usec steps). + * + * Linux.c-V4 0xc75c - 102072us + * Linix.c-V5 0x38a4 - 29000us * NetBSD-V4 0xc75c * NetBSD-V5 0x38a4 * Symb 0xXXXX - see above - this may be total time before giving up - * but 0x38a4 Kus is about 14 seconds - * i.e. not 79*SCAN_DWELL */ +#define RAY_MIB_SCAN_MAX_DWELL_MINIMUM 1 +#define RAY_MIB_SCAN_MAX_DWELL_MAXIMUM 65535 #define RAY_MIB_SCAN_MAX_DWELL_V4 0xc75c #define RAY_MIB_SCAN_MAX_DWELL_V5 0x38a4 /* - * Linix.c 0x05 - * NetBSD 0x05 - * Symb 0xXX - can't be in Kus too short - */ + * mib_assoc_timo + * + * DOC 0x05 - Time (in hops) a station waits after + * - transmitting an Association Request + * - Message before association attempt is + * - considered failed. N/A for Ad Hoc + * - Networks and for APs in Infrastructure + */ +#define RAY_MIB_ASSOC_TIMO_MINIMUM 0 +#define RAY_MIB_ASSOC_TIMO_MAXIMUM 255 #define RAY_MIB_ASSOC_TIMO_DEFAULT 0x05 /* - * Linix.c-V4 0x04 - * Linux.c-V5 0x08 - * NetBSD-V4 0x04 - Linux - * NetBSD-V4 0x08 - "divined" - * NetBSD-V5 0x08 - * Symb 0xXX - hmm maybe this ties in with the DWELL_SCAN above? + * mib_adhoc_scan_cycle + * + * DOC 0x08 - Maximum number of times to cycle + * - through frequency hopping pattern as + * - part of scanning during Ad Hoc + * - Acquisition. */ +#define RAY_MIB_ADHOC_SCAN_CYCLE_MINIMUM 1 +#define RAY_MIB_ADHOC_SCAN_CYCLE_MAXIMUM 255 #define RAY_MIB_ADHOC_SCAN_CYCLE_DEFAULT 0x08 /* - * Linix.c 0x02 - * NetBSD-V4 0x02 - Linux - * NetBSD-V4 0x01 - "divined" - * NetBSD-V5 0x02 - * Symb 0xXX - hmm maybe this ties in with the DWELL_SCAN above? + * mib_infra_scan_cycle + * + * DOC 0x02 - Number of times to cycle through + * - frequency hopping pattern as part of + * - scanning during Infrastructure Network + * - Acquisition. */ +#define RAY_MIB_INFRA_SCAN_CYCLE_MINIMUM 1 +#define RAY_MIB_INFRA_SCAN_CYCLE_MAXIMUM 255 #define RAY_MIB_INFRA_SCAN_CYCLE_DEFAULT 0x02 /* - * Linix.c-V4 0x04 - * Linux.c-V5 0x08 - * NetBSD-V4 0x04 - Linux - * NetBSD-V4 0x18 - "divined" - * NetBSD-V5 0x08 - * Symb 0xXX - hmm maybe this ties in with the DWELL_SCAN above? + * mib_infra_super_scan_cycle + * + * DOC 0x08 - Number of times to repeat an + * - Infrastructure scan cycle if no APs are + * - found before indicating a failure. */ +#define RAY_MIB_INFRA_SUPER_SCAN_CYCLE_MINIMUM 1 +#define RAY_MIB_INFRA_SUPER_SCAN_CYCLE_MAXIMUM 255 #define RAY_MIB_INFRA_SUPER_SCAN_CYCLE_DEFAULT 0x08 +/* + * mib_promisc + * + * DOC 0x00 - Controls operation of WIC in + * - promiscuous mode. + */ +#define RAY_MIB_PROMISC_DISABLED 0 +#define RAY_MIB_PROMISC_ENABLED 1 #define RAY_MIB_PROMISC_DEFAULT 0x00 +/* + * mib_uniq_word + * + * DOC 0x0cdb - Unique word pattern (Transmitted as + * - 0CBDh per 802.11) + */ +#define RAY_MIB_UNIQ_WORD_MINIMUM 0 +#define RAY_MIB_UNIQ_WORD_MAXIMUM 0xffff #define RAY_MIB_UNIQ_WORD_DEFAULT 0x0cbd /* + * mib_slot_time + * + * DOC 0x32 - Slot time in usec + * * Linux.c-V4 0x4e * Linix.c-V5 0x32 * NetBSD-V4 0x4e - Linux @@ -686,10 +802,20 @@ struct ray_siglev { * NetBSD-V5 0x32 - mentions spec. is 50us i.e. 0x32 * Symb 0xXX - wtf 0x4e = 78 */ +#define RAY_MIB_SLOT_TIME_MINIMUM 1 +#define RAY_MIB_SLOT_TIME_MAXIMUM 128 #define RAY_MIB_SLOT_TIME_V4 0x4e #define RAY_MIB_SLOT_TIME_V5 0x32 /* + * mib_roam_low_snr_thresh + * + * DOC 0xff - SNR Threshold for use by roaming + * - algorithm. [Low power count is + * - incremented when Beacon is received at + * - SNR lower than Roaming Low SNR + * - Threshold.] To disable, set to FFh. + * * Linux.c 0xff * NetBSD-V4 0xff - Linux * NetBSD-V4 0x30 - "divined" @@ -697,64 +823,112 @@ struct ray_siglev { * NetBSD.h - if below this inc count * Symb 0xXX - hmm is 0xff really disabled? need this to work */ +#define RAY_MIB_ROAM_LOW_SNR_THRESH_MINIMUM 0 +#define RAY_MIB_ROAM_LOW_SNR_THRESH_MAXIMUM 255 #define RAY_MIB_ROAM_LOW_SNR_THRESH_DISABLED 0xff #define RAY_MIB_ROAM_LOW_SNR_THRESH_DEFAULT RAY_MIB_ROAM_LOW_SNR_THRESH_DISABLED /* + * mib_low_snr_count + * + * DOC 0xff - Threshold that number of consecutive + * - beacons received at SNR < Roaming + * - Low SNR Threshold must exceed + * - before roaming processing begins. To + * - disable, set to FFh. + * * Linux.c 0xff * NetBSD 0x07 - "divined - check" and marked as disabled * NetBSD 0xff - disabled * NetBSD.h - roam after cnt below thrsh - * Symb 0xXX - hmm is 0xff really disabled? need this to work + * Symb 0xXX - hmm is 0xff really disabled? need + * - this to work in infrastructure mode with mutliple APs */ +#define RAY_MIB_LOW_SNR_COUNT_MINIMUM 0 +#define RAY_MIB_LOW_SNR_COUNT_MAXIMUM 255 #define RAY_MIB_LOW_SNR_COUNT_DISABLED 0xff #define RAY_MIB_LOW_SNR_COUNT_DEFAULT RAY_MIB_LOW_SNR_COUNT_DISABLED /* + * mib_infra_missed_beacon_count + * + * DOC 0x02 - Threshold that number of consecutive + * - beacons not received must exceed + * - before roaming processing begins in an + * - infrastructure network. To disable, set + * - to FFh. * Linux.c 0x05 * NetBSD 0x02 - documented default for 5/6 * NetBSD 0x05 - Linux * NetBSD 0x07 - "divined - check, looks fishy" * Symb 0xXX - 5 missed beacons is probably okay */ +#define RAY_MIB_INFRA_MISSED_BEACON_COUNT_MINIMUM 0 +#define RAY_MIB_INFRA_MISSED_BEACON_COUNT_MAXIMUM 255 #define RAY_MIB_INFRA_MISSED_BEACON_COUNT_DEFAULT 0x05 /* - * Linux.c 0xff - * NetBSD 0xff - * Symb 0xXX - so what happens in adhoc if the beacon is missed? - * do we create our own beacon + * mib_adhoc_missed_beacon_count + * + * DOC 0xff - Threshold that number of consecutive + * - beacons transmitted by a terminal must + * - exceed before reacquisition processing + * - begins in Ad Hoc Network. */ +#define RAY_MIB_ADHOC_MISSED_BEACON_COUNT_MINIMUM 0 +#define RAY_MIB_ADHOC_MISSED_BEACON_COUNT_MAXIMUM 255 #define RAY_MIB_ADHOC_MISSED_BEACON_COUNT_DISABLED 0xff #define RAY_MIB_ADHOC_MISSED_BEACON_COUNT_DEFAULT RAY_MIB_ADHOC_MISSED_BEACON_COUNT_DISABLED -#define RAY_MIB_COUNTRY_CODE_USA 0x1 -#define RAY_MIB_COUNTRY_CODE_EUROPE 0x2 -#define RAY_MIB_COUNTRY_CODE_JAPAN 0x3 -#define RAY_MIB_COUNTRY_CODE_KOREA 0x4 -#define RAY_MIB_COUNTRY_CODE_SPAIN 0x5 -#define RAY_MIB_COUNTRY_CODE_FRANCE 0x6 -#define RAY_MIB_COUNTRY_CODE_ISRAEL 0x7 -#define RAY_MIB_COUNTRY_CODE_AUSTRALIA 0x8 -#define RAY_MIB_COUNTRY_CODE_JAPAN_TEST 0x9 -#define RAY_MIB_COUNTRY_CODE_MAX 0xa +/* + * mib_country_code + * + * DOC 0x01 - Country set of hopping patterns + * - (element value in beacon) + * - Note: Japan Test is for a special test + * - mode required by the Japanese + * - regulatory authorities. + */ +#define RAY_MIB_COUNTRY_CODE_MIMIMUM 0x01 +#define RAY_MIB_COUNTRY_CODE_MAXIMUM 0x09 +#define RAY_MIB_COUNTRY_CODE_USA 0x01 +#define RAY_MIB_COUNTRY_CODE_EUROPE 0x02 +#define RAY_MIB_COUNTRY_CODE_JAPAN 0x03 +#define RAY_MIB_COUNTRY_CODE_KOREA 0x04 +#define RAY_MIB_COUNTRY_CODE_SPAIN 0x05 +#define RAY_MIB_COUNTRY_CODE_FRANCE 0x06 +#define RAY_MIB_COUNTRY_CODE_ISRAEL 0x07 +#define RAY_MIB_COUNTRY_CODE_AUSTRALIA 0x08 +#define RAY_MIB_COUNTRY_CODE_JAPAN_TEST 0x09 #define RAY_MIB_COUNTRY_CODE_DEFAULT RAY_MIB_COUNTRY_CODE_USA /* + * mib_hop_seq + * + * DOC 0x0b - Hop Pattern to use. (Currently 66 + * - US/Europe plus 12 Japanese). + * * NetBSD.h - no longer supported */ +#define RAY_MIB_HOP_SEQ_MINIMUM 6 +#define RAY_MIB_HOP_SEQ_MAXIMUM 72 #define RAY_MIB_HOP_SEQ_DEFAULT 0x0b /* - * Linux.c-V4 0x4e - * Linix.c-V5 0x4f - * NetBSD-V4 0x4e - * NetBSD-V5 0x4f - * Symb 0xXX - 0x4e = 78 so is it a cock up? + * mib_hop_seq_len + * + * DOC 0x4f - Number of frequency channels in + * - hopping pattern is now set to the value + * - defined in IEEE802.11 for the selected + * - Current Country Code. */ +#define RAY_MIB_HOP_SEQ_LEN_MINIMUM 1 +#define RAY_MIB_HOP_SEQ_LEN_MAXIMUM 79 #define RAY_MIB_HOP_SEQ_LEN_V4 0x4e #define RAY_MIB_HOP_SEQ_LEN_V5 0x4f +/* XXX need to update these to the spec. XXX */ + /* * All from here down are the same in Linux/NetBSD and seem to be sane. */ @@ -797,9 +971,52 @@ struct ray_siglev { #define RAY_MIB_PRIVACY_CAN_JOIN_DONT_CARE 0x2 #define RAY_MIB_PRIVACY_CAN_JOIN_DEFAULT RAY_MIB_PRIVACY_CAN_JOIN_NOWEP +#define RAY_MIB_BASIC_RATE_SET_MINIMUM 1 +#define RAY_MIB_BASIC_RATE_SET_MAXIMUM 4 #define RAY_MIB_BASIC_RATE_SET_500K 1 #define RAY_MIB_BASIC_RATE_SET_1000K 2 #define RAY_MIB_BASIC_RATE_SET_1500K 3 #define RAY_MIB_BASIC_RATE_SET_2000K 4 -#define RAY_MIB_BASIC_RATE_SET_MAX 5 #define RAY_MIB_BASIC_RATE_SET_DEFAULT RAY_MIB_BASIC_RATE_SET_2000K + +/* + * IOCTL support + */ +struct ray_param_req { + int r_failcause; + u_int8_t r_paramid; + u_int8_t r_len; + u_int8_t r_data[256]; +}; +struct ray_stats_req { + u_int64_t rxoverflow; /* Number of rx overflows */ + u_int64_t rxcksum; /* Number of checksum errors */ + u_int64_t rxhcksum; /* Number of header checksum errors */ + u_int8_t rxnoise; /* Average receiver level */ +}; +#define RAY_FAILCAUSE_EIDRANGE 1 +#define RAY_FAILCAUSE_ELENGTH 2 +/* device can possibly return up to 255 */ +#define RAY_FAILCAUSE_EDEVSTOP 256 + +#ifdef KERNEL +#define RAY_FAILCAUSE_WAITING 257 +#endif + +/* Get a param the data is a ray_param_req structure */ +#define SIOCSRAYPARAM SIOCSIFGENERIC +#define SIOCGRAYPARAM SIOCGIFGENERIC +/* Get the error counters the data is a ray_stats_req structure */ +#define SIOCGRAYSTATS _IOWR('i', 201, struct ifreq) +#define SIOCGRAYSIGLEV _IOWR('i', 202, struct ifreq) + +#define RAY_NSIGLEVRECS 8 +#define RAY_NSIGLEV 8 +#define RAY_NANTENNA 8 + +struct ray_siglev { + u_int8_t rsl_host[ETHER_ADDR_LEN]; /* MAC address */ + u_int8_t rsl_siglevs[RAY_NSIGLEV]; /* levels, newest in [0] */ + u_int8_t rsl_antennas[RAY_NANTENNA]; /* best antenna */ + struct timeval rsl_time; /* time of last packet */ +}; |