From 8ace5f95bf8bff8385ef82e9e8a45721100c32e9 Mon Sep 17 00:00:00 2001 From: Marcus Glocker Date: Sat, 16 Jun 2007 19:45:25 +0000 Subject: Add three new firmware commands to set authentication, set rate adaption, and tune several 802.11 parameters. --- sys/dev/pcmcia/if_malo.c | 152 +++++++++++++++++++++++++++++++++++++++++--- sys/dev/pcmcia/if_maloreg.h | 5 +- sys/dev/pcmcia/if_malovar.h | 31 ++++++++- 3 files changed, 177 insertions(+), 11 deletions(-) (limited to 'sys/dev') diff --git a/sys/dev/pcmcia/if_malo.c b/sys/dev/pcmcia/if_malo.c index 357828dbfd1..306ed78248c 100644 --- a/sys/dev/pcmcia/if_malo.c +++ b/sys/dev/pcmcia/if_malo.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_malo.c,v 1.15 2007/06/11 09:56:13 mglocker Exp $ */ +/* $OpenBSD: if_malo.c,v 1.16 2007/06/16 19:45:24 mglocker Exp $ */ /* * Copyright (c) 2007 Marcus Glocker @@ -91,12 +91,15 @@ void cmalo_hexdump(void *, int); int cmalo_cmd_get_hwspec(struct malo_softc *); int cmalo_cmd_rsp_hwspec(struct malo_softc *); int cmalo_cmd_set_reset(struct malo_softc *); +int cmalo_cmd_set_auth(struct malo_softc *); +int cmalo_cmd_set_snmp(struct malo_softc *, uint16_t); int cmalo_cmd_set_radio(struct malo_softc *, uint16_t); int cmalo_cmd_set_channel(struct malo_softc *, uint16_t); int cmalo_cmd_set_txpower(struct malo_softc *, int16_t); int cmalo_cmd_set_antenna(struct malo_softc *, uint16_t); int cmalo_cmd_set_macctrl(struct malo_softc *); int cmalo_cmd_set_assoc(struct malo_softc *); +int cmalo_cmd_set_rate(struct malo_softc *); int cmalo_cmd_request(struct malo_softc *, uint16_t, int); int cmalo_cmd_response(struct malo_softc *); @@ -241,6 +244,15 @@ malo_pcmcia_activate(struct device *dev, enum devact act) /* * Driver. */ + +/* XXX experimental */ +uint8_t ap[] = { 0x00, 0x17, 0x9a, 0x44, 0xda, 0x83 }; +uint8_t chan[] = { 0x01 }; +#if 0 +uint8_t ap[] = { 0x00, 0x15, 0xe9, 0xa4, 0x6e, 0xd1 }; +uint8_t chan[] = { 0x04 }; +#endif + void cmalo_attach(void *arg) { @@ -570,6 +582,12 @@ cmalo_init(struct ifnet *ifp) if (cmalo_cmd_set_channel(sc, sc->sc_curchan) != 0) return (EIO); + cmalo_cmd_set_rate(sc); + + cmalo_cmd_set_snmp(sc, MALO_OID_RTSTRESH); + cmalo_cmd_set_snmp(sc, MALO_OID_SHORTRETRY); + cmalo_cmd_set_snmp(sc, MALO_OID_FRAGTRESH); + cmalo_cmd_set_assoc(sc); /* device up */ @@ -977,6 +995,83 @@ cmalo_cmd_set_reset(struct malo_softc *sc) return (0); } +int +cmalo_cmd_set_auth(struct malo_softc *sc) +{ + struct malo_cmd_header *hdr = sc->sc_cmd; + struct malo_cmd_body_auth *body; + uint16_t psize; + + bzero(sc->sc_cmd, MALO_CMD_BUFFER_SIZE); + psize = sizeof(*hdr) + sizeof(*body); + + hdr->cmd = htole16(MALO_CMD_AUTH); + hdr->size = htole16(sizeof(*body)); + hdr->seqnum = htole16(1); + hdr->result = 0; + body = (struct malo_cmd_body_auth *)(hdr + 1); + + bcopy(ap, body->peermac, ETHER_ADDR_LEN); + body->authtype = 0; + + /* process command request */ + if (cmalo_cmd_request(sc, psize, 0) != 0) + return (EIO); + + /* process command repsonse */ + cmalo_cmd_response(sc); + + return (0); +} + +int +cmalo_cmd_set_snmp(struct malo_softc *sc, uint16_t oid) +{ + struct malo_cmd_header *hdr = sc->sc_cmd; + struct malo_cmd_body_snmp *body; + uint16_t psize; + + bzero(sc->sc_cmd, MALO_CMD_BUFFER_SIZE); + psize = sizeof(*hdr) + sizeof(*body); + + hdr->cmd = htole16(MALO_CMD_SNMP); + hdr->size = htole16(sizeof(*body)); + hdr->seqnum = htole16(1); + hdr->result = 0; + body = (struct malo_cmd_body_snmp *)(hdr + 1); + + body->action = htole16(1); + + switch (oid) { + case MALO_OID_RTSTRESH: + body->oid = htole16(MALO_OID_RTSTRESH); + body->size = htole16(2); + *(uint16_t *)body->data = htole16(2347); + break; + case MALO_OID_SHORTRETRY: + body->oid = htole16(MALO_OID_SHORTRETRY); + body->size = htole16(2); + *(uint16_t *)body->data = htole16(4); + break; + case MALO_OID_FRAGTRESH: + body->oid = htole16(MALO_OID_FRAGTRESH); + body->size = htole16(2); + *(uint16_t *)body->data = htole16(2346); + break; + default: + break; + } + + /* process command request */ + if (cmalo_cmd_request(sc, psize, 0) != 0) + return (EIO); + + /* process command repsonse */ + cmalo_cmd_response(sc); + + return (0); +} + int cmalo_cmd_set_radio(struct malo_softc *sc, uint16_t control) { @@ -1148,12 +1243,6 @@ cmalo_cmd_set_assoc(struct malo_softc *sc) struct malo_cmd_body_assoc_cf *body_cf; struct malo_cmd_body_assoc_rate *body_rate; uint16_t psize; - uint8_t ap[] = { 0x00, 0x17, 0x9a, 0x44, 0xda, 0x83 }; /* XXX */ - uint8_t chan[] = { 0x01 }; /* XXX */ -#if 0 - uint8_t ap[] = { 0x00, 0x15, 0xe9, 0xa4, 0x6e, 0xd1 }; /* XXX */ - uint8_t chan[] = { 0x02 }; /* XXX */ -#endif bzero(sc->sc_cmd, MALO_CMD_BUFFER_SIZE); psize = sizeof(*hdr) + sizeof(*body); @@ -1161,10 +1250,10 @@ cmalo_cmd_set_assoc(struct malo_softc *sc) hdr->cmd = htole16(MALO_CMD_ASSOC); hdr->seqnum = htole16(1); hdr->result = 0; - body = (struct malo_cmd_body_assoc *)(hdr + 1); + bcopy(ap, body->peermac, ETHER_ADDR_LEN); - body->capinfo = htole16(IEEE80211_CAPINFO_ESS); + body->capinfo = htole16(IEEE80211_CAPINFO_ESS); body->listenintrv = htole16(10); body_ssid = sc->sc_cmd + psize; @@ -1204,6 +1293,36 @@ cmalo_cmd_set_assoc(struct malo_softc *sc) return (0); } +int +cmalo_cmd_set_rate(struct malo_softc *sc) +{ + struct malo_cmd_header *hdr = sc->sc_cmd; + struct malo_cmd_body_rate *body; + uint16_t psize; + + bzero(sc->sc_cmd, MALO_CMD_BUFFER_SIZE); + psize = sizeof(*hdr) + sizeof(*body); + + hdr->cmd = htole16(MALO_CMD_RATE); + hdr->size = htole16(sizeof(*body)); + hdr->seqnum = htole16(1); + hdr->result = 0; + body = (struct malo_cmd_body_rate *)(hdr + 1); + + body->action = htole16(1); + body->hwauto = htole16(1); + body->ratebitmap = htole16(0x1fff); + + /* process command request */ + if (cmalo_cmd_request(sc, psize, 0) != 0) + return (EIO); + + /* process command repsonse */ + cmalo_cmd_response(sc); + + return (0); +} + int cmalo_cmd_request(struct malo_softc *sc, uint16_t psize, int no_response) { @@ -1288,6 +1407,16 @@ cmalo_cmd_response(struct malo_softc *sc) case MALO_CMD_RESET: /* reset will not send back a response */ break; + case MALO_CMD_AUTH: + /* do nothing */ + DPRINTF(1, "%s: got auth cmd response\n", + sc->sc_dev.dv_xname); + break; + case MALO_CMD_SNMP: + /* do nothing */ + DPRINTF(1, "%s: got snmp cmd response\n", + sc->sc_dev.dv_xname); + break; case MALO_CMD_RADIO: /* do nothing */ DPRINTF(1, "%s: got radio cmd response\n", @@ -1313,6 +1442,11 @@ cmalo_cmd_response(struct malo_softc *sc) DPRINTF(1, "%s: got macctrl cmd response\n", sc->sc_dev.dv_xname); break; + case MALO_CMD_RATE: + /* do nothing */ + DPRINTF(1, "%s: got rate cmd response\n", + sc->sc_dev.dv_xname); + break; default: printf("%s: got unknown cmd response (0x%04x)!\n", sc->sc_dev.dv_xname, hdr->cmd); diff --git a/sys/dev/pcmcia/if_maloreg.h b/sys/dev/pcmcia/if_maloreg.h index d2ac2e2654a..5dc69c510c9 100644 --- a/sys/dev/pcmcia/if_maloreg.h +++ b/sys/dev/pcmcia/if_maloreg.h @@ -1,4 +1,4 @@ -/* $OpenBSD: if_maloreg.h,v 1.6 2007/06/08 22:08:21 mglocker Exp $ */ +/* $OpenBSD: if_maloreg.h,v 1.7 2007/06/16 19:45:24 mglocker Exp $ */ /* * Copyright (c) 2007 Marcus Glocker @@ -51,12 +51,15 @@ #define MALO_CMD_RESP 0x8000 #define MALO_CMD_HWSPEC 0x0003 #define MALO_CMD_RESET 0x0005 +#define MALO_CMD_AUTH 0x0011 +#define MALO_CMD_SNMP 0x0016 #define MALO_CMD_RADIO 0x001c #define MALO_CMD_CHANNEL 0x001d #define MALO_CMD_TXPOWER 0x001e #define MALO_CMD_ANTENNA 0x0020 #define MALO_CMD_MACCTRL 0x0028 #define MALO_CMD_ASSOC 0x0050 +#define MALO_CMD_RATE 0x0076 /* FW command values */ #define MALO_CMD_RADIO_OFF 0x0000 diff --git a/sys/dev/pcmcia/if_malovar.h b/sys/dev/pcmcia/if_malovar.h index f54d5409b29..30b969e519c 100644 --- a/sys/dev/pcmcia/if_malovar.h +++ b/sys/dev/pcmcia/if_malovar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: if_malovar.h,v 1.9 2007/06/08 22:08:21 mglocker Exp $ */ +/* $OpenBSD: if_malovar.h,v 1.10 2007/06/16 19:45:24 mglocker Exp $ */ /* * Copyright (c) 2007 Marcus Glocker @@ -67,6 +67,29 @@ struct malo_cmd_body_spec { uint32_t fw_capinfo; } __packed; +struct malo_cmd_body_auth { + uint8_t peermac[ETHER_ADDR_LEN]; + uint8_t authtype; +} __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; @@ -131,6 +154,12 @@ struct malo_cmd_body_assoc_rate { uint8_t data[1]; } __packed; +struct malo_cmd_body_rate { + uint16_t action; + uint16_t hwauto; + uint16_t ratebitmap; +} __packed; + /* RX descriptor */ #define MALO_RX_STATUS_OK 0x0001 struct malo_rx_desc { -- cgit v1.2.3