diff options
Diffstat (limited to 'sys')
-rw-r--r-- | sys/dev/ic/rl2cmd.h | 306 |
1 files changed, 142 insertions, 164 deletions
diff --git a/sys/dev/ic/rl2cmd.h b/sys/dev/ic/rl2cmd.h index 9c32dd63b24..0fe4f8365e4 100644 --- a/sys/dev/ic/rl2cmd.h +++ b/sys/dev/ic/rl2cmd.h @@ -1,269 +1,247 @@ -/* $OpenBSD: rl2cmd.h,v 1.1 1999/06/21 23:21:46 d Exp $ */ +/* $OpenBSD: rl2cmd.h,v 1.2 1999/07/14 03:52:27 d Exp $ */ /* * David Leonard <d@openbsd.org>, 1999. Public Domain. * * RangeLAN2 host-to-card message protocol. */ -/* - * Micro-message commands - */ - +/* Micro-message command header. */ struct rl2_mm_cmd { - u_int8_t cmd_letter; /* command letter */ - u_int8_t cmd_seq; /* must increment, <0x80 */ - u_int8_t cmd_fn; /* function number */ - u_int8_t cmd_error; /* reserved */ + u_int8_t cmd_letter; /* Command letter */ + u_int8_t cmd_seq; /* Incremented on each command */ +#define RL2_MAXSEQ 0x7c + u_int8_t cmd_fn; /* Function number */ + u_int8_t cmd_error; /* Reserved */ }; - #define RL2_MM_CMD(l,n) ((((unsigned int)l)<<8) | ((unsigned int)n)) #define RL2_MM_CMD_LETTER(cmd) ((unsigned char)(((cmd) & 0xff00)>>8)) #define RL2_MM_CMD_FUNCTION(cmd) ((unsigned char)((cmd) & 0xff)) - -#if 0 - /* A: Initialisation commands */ - RL2_MM_INITIALIZE = 0, /* A0 a0 */ /* [3]>0 */ - RL2_MM_SEARCH_AND_SYNC, /* A1 a1- */ - RL2_MM_SEARCH_CONTINUE, /* A2 a2. */ - RL2_MM_ABORT_SEARCH, /* A3 a3. */ - RL2_MM_SYNCHRONISED, /* a4 */ /*HandleInSync*/ - RL2_MM_UNSYNCHRONISED, /* A5 */ - RL2_MM_GOTO_STANDBY, /* A6 */ /* stop() */ - RL2_MM_ITO, /* A7 a7. */ - RL2_MM_KEEPALIVE, /* A8 a8. */ - RL2_MM_MULTICAST, /* A9 a9. */ - RL2_MM_RFNC_STATS, /* A11 a11.*/ - RL2_MM_SECURITY, /* A12 a12.*/ - RL2_MM_ROM_VERSION, /* A13 a13 */ - RL2_MM_GLOBAL_ADDR, /* A14 a14 */ - RL2_MM_CONFIGMAC, /* A16 a16.*/ - RL2_MM_ROAMPARAM, /* A17 a17.*/ - RL2_MM_ROAMING, /* a18 */ /* LLDRoam */ - RL2_MM_ROAM, /* A19 a19 */ - RL2_MM_FAULT, /* a20 */ /* beep,reset */ - RL2_MM_SNIFF_MODE, /* A22 */ - RL2_MM_DISABLE_EEPROM_WRITE, /* A23 a23.*/ - RL2_MM_ENABLE_EEPROMP_WRITE, /* A24 a24.*/ - RL2_MM_HOPSTATS, /* A35 a35 */ - /* B: Data commands */ - /* C: Diagnostic commands */ - RL2_MM_DISABLE_HOPPING, /* C9 */ -#endif - #define RL2_CMDCODE(letter, num) ((((letter) & 0xff) << 8) | ((num) & 0xff)) -#define u_int4_t u_int8_t - -struct rl2_mm_setparam { - struct rl2_mm_cmd mm_cmd; -#define RL2_MM_SETPARAM { 'A', 0, 0, 0 } -#define RL2_MM_SETPARAM_CODE RL2_CMDCODE('A',0) - u_int8_t enaddr[6]; - u_int8_t opmode; -#define RL2_MM_SETPARAM_OPMODE_NORMAL 0 -#define RL2_MM_SETPARAM_OPMODE_PROMISC 1 -#define RL2_MM_SETPARAM_OPMODE_PROTOCOL 2 - u_int8_t stationtype; -#define RL2_MM_SETPARAM_STATIONTYPE_SLAVE RL2_STATIONTYPE_SLAVE -#define RL2_MM_SETPARAM_STATIONTYPE_ALTMASTER RL2_STATIONTYPE_ALTMASTER -#define RL2_MM_SETPARAM_STATIONTYPE_MASTER RL2_STATIONTYPE_MASTER - u_int8_t hop_period; - u_int8_t bfreq; - u_int8_t sfreq; - u_int4_t channel : 4; /* lower bits */ - u_int4_t subchannel : 4; /* upper bits */ - char mastername[11]; - u_int4_t sec1 : 4; /* default 3 */ - u_int4_t domain : 4; /* default 0 */ - u_int8_t sec2; /* default 2 */ - u_int8_t sec3; /* default 1 */ - u_int8_t sync_to; /* 1 if roaming */ - u_int8_t xxx_pad; /* zero */ - char syncname[11]; -}; - -struct rl2_mm_paramset { - struct rl2_mm_cmd mm_cmd; -#define RL2_MM_PARAMSET { 'a', 0, 0, 0 } -#define RL2_MM_PARAMSET_CODE RL2_CMDCODE('a',0) - u_int8_t xxx; -}; - +/* Initialise card, and set operational parameters. */ +struct rl2_mm_init { + struct rl2_mm_cmd mm_cmd; +#define RL2_MM_INIT { 'A', 0, 0, 0 } + u_int8_t enaddr[6]; + u_int8_t opmode; +#define RL2_MM_INIT_OPMODE_NORMAL 0 +#define RL2_MM_INIT_OPMODE_PROMISC 1 +#define RL2_MM_INIT_OPMODE_PROTOCOL 2 + u_int8_t stationtype; /* RL2_STATIONTYPE_... */ + u_int8_t hop_period; + u_int8_t bfreq; + u_int8_t sfreq; + u_char channel : 4; /* lower bits */ + u_char subchannel : 4; /* upper bits */ + char mastername[11]; + u_char sec1 : 4; /* default 3 */ + u_char domain : 4; /* default 0 */ + u_int8_t sec2; /* default 2 */ + u_int8_t sec3; /* default 1 */ + u_int8_t sync_to; /* 1 if roaming */ + u_int8_t xxx_pad; /* zero */ + char syncname[11]; +}; + +/* Result of initialisation. */ +struct rl2_mm_initted { + struct rl2_mm_cmd mm_cmd; +#define RL2_MM_INITTED { 'a', 0, 0, 0 } + u_int8_t xxx; +}; + +/* Start searching for other masters. */ struct rl2_mm_search { - struct rl2_mm_cmd mm_cmd; + struct rl2_mm_cmd mm_cmd; #define RL2_MM_SEARCH { 'A', 0, 1, 0 } -#define RL2_MM_SEARCH_CODE RL2_CMDCODE('A',1) - u_int8_t xxx1[23]; - u_int4_t xxx2 : 4; - u_int4_t domain : 4; - u_int8_t roaming; - u_int8_t xxx3; /* default 0 */ - u_int8_t xxx4; /* default 1 */ - u_int8_t xxx5; /* default 0 */ - u_int8_t xxx6[11]; + u_int8_t xxx1[23]; + u_char xxx2 : 4; + u_char domain : 4; + u_int8_t roaming; + u_int8_t xxx3; /* default 0 */ + u_int8_t xxx4; /* default 1 */ + u_int8_t xxx5; /* default 0 */ + u_int8_t xxx6[11]; }; +/* Notification that searching has started. */ struct rl2_mm_searching { - struct rl2_mm_cmd mm_cmd; + struct rl2_mm_cmd mm_cmd; #define RL2_MM_SEARCHING { 'a', 0, 1, 0 } -#define RL2_MM_SEARCHING_CODE RL2_CMDCODE('a',1) - u_int8_t xxx; + u_int8_t xxx; }; +/* Terminate search. */ #define RL2_MM_ABORTSEARCH { 'A', 0, 3, 0 } -#define RL2_MM_ABORTSEARCH_CODE RL2_CMDCODE('A',3) +/* Station synchronised to a master. */ struct rl2_mm_synchronised { - struct rl2_mm_cmd mm_cmd; + struct rl2_mm_cmd mm_cmd; #define RL2_MM_SYNCHRONISED { 'a', 0, 4, 0 } -#define RL2_MM_SYNCHRONISED_CODE RL2_CMDCODE('a',4) - u_int4_t channel : 4; /* lower bits */ - u_int4_t subchannel : 4; /* upper bits */ - char mastername[11]; - u_int8_t enaddr[6]; + u_char channel : 4; /* lower bits */ + u_char subchannel : 4; /* upper bits */ + char mastername[11]; + u_int8_t enaddr[6]; }; +/* Station lost synchronisation with a master. */ #define RL2_MM_UNSYNCHRONISED { 'a', 0, 5, 0 } -#define RL2_MM_UNSYNCHRONISED_CODE RL2_CMDCODE('a',5) +/* Send card to sleep. (See rl2_wakeup().) */ struct rl2_mm_standby { - struct rl2_mm_cmd mm_cmd; + struct rl2_mm_cmd mm_cmd; #define RL2_MM_STANDBY { 'A', 0, 6, 0 } - u_int8_t xxx; /* default 0 */ + u_int8_t xxx; /* default 0 */ }; +/* Set ITO (inactivity timeout timer). */ struct rl2_mm_setito { - struct rl2_mm_cmd mm_cmd; + struct rl2_mm_cmd mm_cmd; #define RL2_MM_SETITO { 'A', 0, 7, 0 } - u_int8_t xxx; /* default 3 */ - u_int8_t timeout; - unsigned int bd_wakeup : 1; - unsigned int pm_sync : 7; - u_int8_t sniff_time; + u_int8_t xxx; /* default 3 */ + u_int8_t timeout; + u_char bd_wakeup : 1; + u_char pm_sync : 7; + u_int8_t sniff_time; }; +/* ITO acknowledgment */ #define RL2_MM_GOTITO { 'a', 0, 7, 0 } +/* Send keepalive protocol message (?). */ #define RL2_MM_SENDKEEPALIVE { 'A', 0, 8, 0 } +/* Set multicast mode. */ struct rl2_mm_multicast { - struct rl2_mm_cmd mm_cmd; + struct rl2_mm_cmd mm_cmd; #define RL2_MM_MULTICAST { 'A', 0, 9, 0 } - u_int8_t enable; + u_int8_t enable; }; +/* Ack multicast mode change. */ #define RL2_MM_MULTICASTING { 'a', 0, 9, 0 } +/* Request statistics. */ #define RL2_MM_GETSTATS { 'A', 0, 11, 0 } + +/* Statistics results. */ #define RL2_MM_GOTSTATS { 'a', 0, 11, 0 } +/* Set security ID used in channel. */ struct rl2_mm_setsecurity { - struct rl2_mm_cmd mm_cmd; + struct rl2_mm_cmd mm_cmd; #define RL2_MM_SETSECURITY { 'A', 0, 12, 0 } - u_int8_t sec1; - u_int8_t sec2; - u_int8_t sec3; + u_int8_t sec1; + u_int8_t sec2; + u_int8_t sec3; }; +/* Ack set security ID. */ #define RL2_MM_GOTSECURITY { 'a', 0, 12, 0 } +/* Request firmware version. */ #define RL2_MM_GETPROMVERSION { 'A', 0, 13, 0 } +/* Reply with firmware version. */ struct rl2_mm_gotpromversion { - struct rl2_mm_cmd mm_cmd; + struct rl2_mm_cmd mm_cmd; #define RL2_MM_GOTPROMVERSION { 'a', 0, 13, 0 } - u_int8_t xxx; - char version[7]; + u_int8_t xxx; /* sizeof version? */ + char version[7]; }; +/* Request station's MAC address (same as ethernet). */ #define RL2_MM_GETENADDR { 'A', 0, 14, 0 } +/* Reply with station's MAC address. */ struct rl2_mm_gotenaddr { - struct rl2_mm_cmd mm_cmd; + struct rl2_mm_cmd mm_cmd; #define RL2_MM_GOTENADDR { 'a', 0, 14, 0 } - u_int8_t xxx; - u_int8_t enaddr[6]; + u_int8_t xxx; + u_int8_t enaddr[6]; }; +/* Tune various channel parameters. */ struct rl2_mm_setmagic { - struct rl2_mm_cmd mm_cmd; + struct rl2_mm_cmd mm_cmd; #define RL2_MM_SETMAGIC { 'A', 0, 16, 0 } - u_char fairness_slot : 3; - u_char deferral_slot : 5; - u_int8_t regular_mac_retry; /* default 0x07 */ - u_int8_t frag_mac_retry; /* default 0x0a */ - u_int8_t regular_mac_qfsk; /* default 0x02 */ - u_int8_t frag_mac_qfsk; /* default 0x05 */ - u_int8_t xxx1; /* default 0xff */ - u_int8_t xxx2; /* default 0xff */ - u_int8_t xxx3; /* default 0xff */ - u_int8_t xxx4; /* zero */ -}; - + u_char fairness_slot : 3; + u_char deferral_slot : 5; + u_int8_t regular_mac_retry; /* default 0x07 */ + u_int8_t frag_mac_retry; /* default 0x0a */ + u_int8_t regular_mac_qfsk; /* default 0x02 */ + u_int8_t frag_mac_qfsk; /* default 0x05 */ + u_int8_t xxx1; /* default 0xff */ + u_int8_t xxx2; /* default 0xff */ + u_int8_t xxx3; /* default 0xff */ + u_int8_t xxx4; /* zero */ +}; + +/* Ack channel tuning. */ #define RL2_MM_GOTMAGIC { 'a', 0, 16, 0 } +/* Set roaming parameters - used when multiple masters available. */ struct rl2_mm_setroaming { - struct rl2_mm_cmd mm_cmd; + struct rl2_mm_cmd mm_cmd; #define RL2_MM_SETROAMING { 'A', 0, 17, 0 } - u_int8_t sync_alarm; - u_int8_t retry_thresh; - u_int8_t rssi_threshold; - u_int8_t xxx1; /* default 0x5a */ - u_int8_t sync_rssi_threshold; - u_int8_t xxx2; /* default 0xa5 */ - u_int8_t missed_sync; + u_int8_t sync_alarm; + u_int8_t retry_thresh; + u_int8_t rssi_threshold; + u_int8_t xxx1; /* default 0x5a */ + u_int8_t sync_rssi_threshold; + u_int8_t xxx2; /* default 0xa5 */ + u_int8_t missed_sync; }; +/* Ack roaming parameter change. */ #define RL2_MM_GOTROAMING { 'a', 0, 17, 0 } #define RL2_MM_ROAMING { 'a', 0, 18, 0 } #define RL2_MM_ROAM { 'A', 0, 19, 0 } + +/* Hardware fault notification. (Usually the antenna.) */ #define RL2_MM_FAULT { 'a', 0, 20, 0 } -#define RL2_MM_FAULT_CODE RL2_CMDCODE('a',20) + #define RL2_MM_EEPROM_PROTECT { 'A', 0, 23, 0 } #define RL2_MM_EEPROM_PROTECTED { 'a', 0, 23, 0 } #define RL2_MM_EEPROM_UNPROTECT { 'A', 0, 24, 0 } #define RL2_MM_EEPROM_UNPROTECTED { 'a', 0, 24, 0 } + +/* Receive hop statistics. */ #define RL2_MM_HOP_STATISTICS { 'a', 0, 35, 0 } +/* Transmit a frame on the channel. */ struct rl2_mm_sendpacket { - struct rl2_mm_cmd mm_cmd; + struct rl2_mm_cmd mm_cmd; #define RL2_MM_SENDPACKET { 'B', 0, 0, 0 } - u_int8_t mode; + u_int8_t mode; #define RL2_MM_SENDPACKET_MODE_BIT7 0x80 #define RL2_MM_SENDPACKET_MODE_ZFIRST 0x20 #define RL2_MM_SENDPACKET_MODE_QFSK 0x03 - u_int8_t power; /* default 0x70 */ - u_int8_t length_lo; - u_int8_t length_hi; - u_int8_t xxx1; /* default 0 */ - u_int8_t xxx2; /* default 0 */ - u_int8_t sequence; /* must increment */ - u_int8_t xxx3; /* default 0 */ + u_int8_t power; /* default 0x70 */ + u_int8_t length_lo; + u_int8_t length_hi; + u_int8_t xxx1; /* default 0 */ + u_int8_t xxx2; /* default 0 */ + u_int8_t sequence; /* must increment */ + u_int8_t xxx3; /* default 0 */ }; +/* Ack packet transmission. */ #define RL2_MM_SENTPACKET { 'b', 0, 0, 0 } +/* Notification of frame received from channel. */ struct rl2_mm_recvpacket { - struct rl2_mm_cmd mm_cmd; + struct rl2_mm_cmd mm_cmd; #define RL2_MM_RECVPACKET { 'b', 0, 1, 0 } - u_int8_t xxx[8]; + u_int8_t xxx[8]; }; +/* Disable hopping. (?) */ struct rl2_mm_disablehopping { - struct rl2_mm_cmd mm_cmd; + struct rl2_mm_cmd mm_cmd; #define RL2_MM_DISABLEHOPPING { 'C', 0, 9, 0 } - u_int8_t hopflag; + u_int8_t hopflag; #define RL2_MM_DISABLEHOPPING_HOPFLAG_DISABLE 0x52 }; -/* queue */ -struct rl2_rx { - SIMPLEQ_ENTRY(rl2_rx) rx_entry; - size_t rx_size; - struct rl2_mm_cmd rx_hdr; - u_int8_t rx_data[1]; -}; - -#define RL2_MAX_RX_QUEUE_LEN 16 - |