diff options
-rw-r--r-- | sys/dev/ic/bwi.c | 567 |
1 files changed, 296 insertions, 271 deletions
diff --git a/sys/dev/ic/bwi.c b/sys/dev/ic/bwi.c index 612960ede04..58ffcc6b21c 100644 --- a/sys/dev/ic/bwi.c +++ b/sys/dev/ic/bwi.c @@ -1,4 +1,4 @@ -/* $OpenBSD: bwi.c,v 1.1 2007/09/12 13:13:12 jsg Exp $ */ +/* $OpenBSD: bwi.c,v 1.2 2007/09/12 14:19:42 jsg Exp $ */ /* * Copyright (c) 2007 The DragonFly Project. All rights reserved. * @@ -115,49 +115,49 @@ struct bwi_retry_lim { uint16_t lgretry_fb; }; -static int bwi_mac_test(struct bwi_mac *); -static int bwi_mac_get_property(struct bwi_mac *); +int bwi_mac_test(struct bwi_mac *); +int bwi_mac_get_property(struct bwi_mac *); -static void bwi_mac_set_retry_lim(struct bwi_mac *, +void bwi_mac_set_retry_lim(struct bwi_mac *, const struct bwi_retry_lim *); -static void bwi_mac_set_ackrates(struct bwi_mac *, +void bwi_mac_set_ackrates(struct bwi_mac *, const struct ieee80211_rateset *); -static int bwi_mac_gpio_init(struct bwi_mac *); -static int bwi_mac_gpio_fini(struct bwi_mac *); -static void bwi_mac_opmode_init(struct bwi_mac *); -static void bwi_mac_hostflags_init(struct bwi_mac *); -static void bwi_mac_bss_param_init(struct bwi_mac *); +int bwi_mac_gpio_init(struct bwi_mac *); +int bwi_mac_gpio_fini(struct bwi_mac *); +void bwi_mac_opmode_init(struct bwi_mac *); +void bwi_mac_hostflags_init(struct bwi_mac *); +void bwi_mac_bss_param_init(struct bwi_mac *); -static int bwi_mac_fw_alloc(struct bwi_mac *); -static void bwi_mac_fw_free(struct bwi_mac *); -static int bwi_mac_fw_load(struct bwi_mac *); -static int bwi_mac_fw_init(struct bwi_mac *); -static int bwi_mac_fw_load_iv(struct bwi_mac *, const struct fw_image *); +int bwi_mac_fw_alloc(struct bwi_mac *); +void bwi_mac_fw_free(struct bwi_mac *); +int bwi_mac_fw_load(struct bwi_mac *); +int bwi_mac_fw_init(struct bwi_mac *); +int bwi_mac_fw_load_iv(struct bwi_mac *, const struct fw_image *); -static void bwi_mac_setup_tpctl(struct bwi_mac *); -static void bwi_mac_adjust_tpctl(struct bwi_mac *, int, int); +void bwi_mac_setup_tpctl(struct bwi_mac *); +void bwi_mac_adjust_tpctl(struct bwi_mac *, int, int); -static void bwi_mac_lock(struct bwi_mac *); -static void bwi_mac_unlock(struct bwi_mac *); +void bwi_mac_lock(struct bwi_mac *); +void bwi_mac_unlock(struct bwi_mac *); static const uint8_t bwi_sup_macrev[] = { 2, 4, 5, 6, 7, 9, 10 }; /* PHY */ -static void bwi_phy_init_11a(struct bwi_mac *); -static void bwi_phy_init_11g(struct bwi_mac *); -static void bwi_phy_init_11b_rev2(struct bwi_mac *); -static void bwi_phy_init_11b_rev4(struct bwi_mac *); -static void bwi_phy_init_11b_rev5(struct bwi_mac *); -static void bwi_phy_init_11b_rev6(struct bwi_mac *); +void bwi_phy_init_11a(struct bwi_mac *); +void bwi_phy_init_11g(struct bwi_mac *); +void bwi_phy_init_11b_rev2(struct bwi_mac *); +void bwi_phy_init_11b_rev4(struct bwi_mac *); +void bwi_phy_init_11b_rev5(struct bwi_mac *); +void bwi_phy_init_11b_rev6(struct bwi_mac *); -static void bwi_phy_config_11g(struct bwi_mac *); -static void bwi_phy_config_agc(struct bwi_mac *); +void bwi_phy_config_11g(struct bwi_mac *); +void bwi_phy_config_agc(struct bwi_mac *); -static void bwi_tbl_write_2(struct bwi_mac *mac, uint16_t, uint16_t); -static void bwi_tbl_write_4(struct bwi_mac *mac, uint16_t, uint32_t); +void bwi_tbl_write_2(struct bwi_mac *mac, uint16_t, uint16_t); +void bwi_tbl_write_4(struct bwi_mac *mac, uint16_t, uint32_t); -static void bwi_plcp_header(void *, int, uint8_t) __unused; +void bwi_plcp_header(void *, int, uint8_t) __unused; #define SUP_BPHY(num) { .rev = num, .init = bwi_phy_init_11b_rev##num } @@ -236,32 +236,31 @@ struct rf_saveregs { #define SAVE_PHY_REG(mac, regs, n) (regs)->phy_##n = PHY_READ((mac), 0x##n) #define RESTORE_PHY_REG(mac, regs, n) PHY_WRITE((mac), 0x##n, (regs)->phy_##n) -static int bwi_rf_calc_txpower(int8_t *, uint8_t, const int16_t[]); -static void bwi_rf_work_around(struct bwi_mac *, u_int); -static int bwi_rf_gain_max_reached(struct bwi_mac *, int); -static uint16_t bwi_rf_calibval(struct bwi_mac *); -static uint16_t bwi_rf_get_tp_ctrl2(struct bwi_mac *); -static uint32_t bwi_rf_lo_devi_measure(struct bwi_mac *, uint16_t); -static void bwi_rf_lo_measure(struct bwi_mac *, +int bwi_rf_calc_txpower(int8_t *, uint8_t, const int16_t[]); +void bwi_rf_work_around(struct bwi_mac *, u_int); +int bwi_rf_gain_max_reached(struct bwi_mac *, int); +uint16_t bwi_rf_calibval(struct bwi_mac *); +uint16_t bwi_rf_get_tp_ctrl2(struct bwi_mac *); +uint32_t bwi_rf_lo_devi_measure(struct bwi_mac *, uint16_t); +void bwi_rf_lo_measure(struct bwi_mac *, const struct bwi_rf_lo *, struct bwi_rf_lo *, uint8_t); -static uint8_t _bwi_rf_lo_update(struct bwi_mac *, uint16_t); -static void bwi_rf_lo_write(struct bwi_mac *, const struct bwi_rf_lo *); +void bwi_rf_lo_write(struct bwi_mac *, const struct bwi_rf_lo *); -static void bwi_rf_set_nrssi_ofs_11g(struct bwi_mac *); -static void bwi_rf_calc_nrssi_slope_11b(struct bwi_mac *); -static void bwi_rf_calc_nrssi_slope_11g(struct bwi_mac *); -static void bwi_rf_set_nrssi_thr_11b(struct bwi_mac *); -static void bwi_rf_set_nrssi_thr_11g(struct bwi_mac *); +void bwi_rf_set_nrssi_ofs_11g(struct bwi_mac *); +void bwi_rf_calc_nrssi_slope_11b(struct bwi_mac *); +void bwi_rf_calc_nrssi_slope_11g(struct bwi_mac *); +void bwi_rf_set_nrssi_thr_11b(struct bwi_mac *); +void bwi_rf_set_nrssi_thr_11g(struct bwi_mac *); -static void bwi_rf_init_sw_nrssi_table(struct bwi_mac *); +void bwi_rf_init_sw_nrssi_table(struct bwi_mac *); -static void bwi_rf_on_11a(struct bwi_mac *); -static void bwi_rf_on_11bg(struct bwi_mac *); +void bwi_rf_on_11a(struct bwi_mac *); +void bwi_rf_on_11bg(struct bwi_mac *); -static void bwi_rf_off_11a(struct bwi_mac *); -static void bwi_rf_off_11bg(struct bwi_mac *); -static void bwi_rf_off_11g_rev5(struct bwi_mac *); +void bwi_rf_off_11a(struct bwi_mac *); +void bwi_rf_off_11bg(struct bwi_mac *); +void bwi_rf_off_11g_rev5(struct bwi_mac *); static const int8_t bwi_txpower_map_11b[BWI_TSSI_MAX] = { BWI_TXPOWER_MAP_11B }; @@ -281,95 +280,135 @@ struct bwi_myaddr_bssid { uint8_t bssid[IEEE80211_ADDR_LEN]; } __packed; -static int bwi_init(struct ifnet *); -static int bwi_ioctl(struct ifnet *, u_long, caddr_t); -static void bwi_start(struct ifnet *); -static void bwi_watchdog(struct ifnet *); -static int bwi_newstate(struct ieee80211com *, enum ieee80211_state, int); -static void bwi_updateslot(struct ieee80211com *); -static int bwi_media_change(struct ifnet *); +/* XXX does not belong here */ +struct ieee80211_ds_plcp_hdr { + uint8_t i_signal; + uint8_t i_service; + uint16_t i_length; + uint16_t i_crc; +} __packed; -static void bwi_next_scan(void *); -static void bwi_calibrate(void *); +#define IEEE80211_DS_PLCP_SERVICE_LOCKED 0x04 +#define IEEE80211_DS_PLCL_SERVICE_PBCC 0x08 +#define IEEE80211_DS_PLCP_SERVICE_LENEXT5 0x20 +#define IEEE80211_DS_PLCP_SERVICE_LENEXT6 0x40 +#define IEEE80211_DS_PLCP_SERVICE_LENEXT7 0x80 + + +int bwi_init(struct ifnet *); +int bwi_ioctl(struct ifnet *, u_long, caddr_t); +void bwi_start(struct ifnet *); +void bwi_watchdog(struct ifnet *); +int bwi_newstate(struct ieee80211com *, enum ieee80211_state, int); +void bwi_updateslot(struct ieee80211com *); +int bwi_media_change(struct ifnet *); -static int bwi_stop(struct bwi_softc *); -static int bwi_newbuf(struct bwi_softc *, int, int) __unused; -static int bwi_encap(struct bwi_softc *, int, struct mbuf *, +void bwi_next_scan(void *); +void bwi_calibrate(void *); + +int bwi_stop(struct bwi_softc *); +int bwi_newbuf(struct bwi_softc *, int, int) __unused; +int bwi_encap(struct bwi_softc *, int, struct mbuf *, struct ieee80211_node *); -static void bwi_init_rxdesc_ring32(struct bwi_softc *, uint32_t, +void bwi_init_rxdesc_ring32(struct bwi_softc *, uint32_t, bus_addr_t, int, int) __unused; -static void bwi_reset_rx_ring32(struct bwi_softc *, uint32_t); - -static int bwi_init_tx_ring32(struct bwi_softc *, int) __unused; -static int bwi_init_rx_ring32(struct bwi_softc *) __unused; -static int bwi_init_txstats32(struct bwi_softc *) __unused; -static void bwi_free_tx_ring32(struct bwi_softc *, int) __unused; -static void bwi_free_rx_ring32(struct bwi_softc *) __unused; -static void bwi_free_txstats32(struct bwi_softc *) __unused; -static void bwi_setup_rx_desc32(struct bwi_softc *, int, bus_addr_t, int) __unused; -static void bwi_setup_tx_desc32(struct bwi_softc *, struct bwi_ring_data *, +void bwi_reset_rx_ring32(struct bwi_softc *, uint32_t); + +int bwi_init_tx_ring32(struct bwi_softc *, int) __unused; +int bwi_init_rx_ring32(struct bwi_softc *) __unused; +int bwi_init_txstats32(struct bwi_softc *) __unused; +void bwi_free_tx_ring32(struct bwi_softc *, int) __unused; +void bwi_free_rx_ring32(struct bwi_softc *) __unused; +void bwi_free_txstats32(struct bwi_softc *) __unused; +void bwi_setup_rx_desc32(struct bwi_softc *, int, bus_addr_t, int) __unused; +void bwi_setup_tx_desc32(struct bwi_softc *, struct bwi_ring_data *, int, bus_addr_t, int) __unused; -static void bwi_rxeof32(struct bwi_softc *) __unused; -static void bwi_start_tx32(struct bwi_softc *, uint32_t, int) __unused; -static void bwi_txeof_status32(struct bwi_softc *) __unused; - -static int bwi_init_tx_ring64(struct bwi_softc *, int) __unused; -static int bwi_init_rx_ring64(struct bwi_softc *) __unused; -static int bwi_init_txstats64(struct bwi_softc *) __unused; -static void bwi_free_tx_ring64(struct bwi_softc *, int) __unused; -static void bwi_free_rx_ring64(struct bwi_softc *) __unused; -static void bwi_free_txstats64(struct bwi_softc *) __unused; -static void bwi_setup_rx_desc64(struct bwi_softc *, int, bus_addr_t, int) __unused; -static void bwi_setup_tx_desc64(struct bwi_softc *, struct bwi_ring_data *, +void bwi_rxeof32(struct bwi_softc *) __unused; +void bwi_start_tx32(struct bwi_softc *, uint32_t, int) __unused; +void bwi_txeof_status32(struct bwi_softc *) __unused; + +int bwi_init_tx_ring64(struct bwi_softc *, int) __unused; +int bwi_init_rx_ring64(struct bwi_softc *) __unused; +int bwi_init_txstats64(struct bwi_softc *) __unused; +void bwi_free_tx_ring64(struct bwi_softc *, int) __unused; +void bwi_free_rx_ring64(struct bwi_softc *) __unused; +void bwi_free_txstats64(struct bwi_softc *) __unused; +void bwi_setup_rx_desc64(struct bwi_softc *, int, bus_addr_t, int) __unused; +void bwi_setup_tx_desc64(struct bwi_softc *, struct bwi_ring_data *, int, bus_addr_t, int) __unused; -static void bwi_rxeof64(struct bwi_softc *) __unused; -static void bwi_start_tx64(struct bwi_softc *, uint32_t, int) __unused; -static void bwi_txeof_status64(struct bwi_softc *) __unused; - -static void bwi_rxeof(struct bwi_softc *, int); -static void _bwi_txeof(struct bwi_softc *, uint16_t); -static void bwi_txeof(struct bwi_softc *); -static void bwi_txeof_status(struct bwi_softc *, int); -static void bwi_enable_intrs(struct bwi_softc *, uint32_t); -static void bwi_disable_intrs(struct bwi_softc *, uint32_t); - -static int bwi_dma_alloc(struct bwi_softc *); -static void bwi_dma_free(struct bwi_softc *); -static int bwi_dma_ring_alloc(struct bwi_softc *, bus_dma_tag_t, +void bwi_rxeof64(struct bwi_softc *) __unused; +void bwi_start_tx64(struct bwi_softc *, uint32_t, int) __unused; +void bwi_txeof_status64(struct bwi_softc *) __unused; + +void bwi_rxeof(struct bwi_softc *, int); +void _bwi_txeof(struct bwi_softc *, uint16_t); +void bwi_txeof(struct bwi_softc *); +void bwi_txeof_status(struct bwi_softc *, int); +void bwi_enable_intrs(struct bwi_softc *, uint32_t); +void bwi_disable_intrs(struct bwi_softc *, uint32_t); + +int bwi_dma_alloc(struct bwi_softc *); +void bwi_dma_free(struct bwi_softc *); +int bwi_dma_ring_alloc(struct bwi_softc *, bus_dma_tag_t, struct bwi_ring_data *, bus_size_t, uint32_t) __unused; -static int bwi_dma_mbuf_create(struct bwi_softc *) __unused; -static void bwi_dma_mbuf_destroy(struct bwi_softc *, int, int) __unused; -static int bwi_dma_txstats_alloc(struct bwi_softc *, uint32_t, bus_size_t) __unused; -static void bwi_dma_txstats_free(struct bwi_softc *) __unused; -static void bwi_dma_ring_addr(void *, bus_dma_segment_t *, int, int) __unused; -static void bwi_dma_buf_addr(void *, bus_dma_segment_t *, int, +int bwi_dma_mbuf_create(struct bwi_softc *) __unused; +void bwi_dma_mbuf_destroy(struct bwi_softc *, int, int) __unused; +int bwi_dma_txstats_alloc(struct bwi_softc *, uint32_t, bus_size_t) __unused; +void bwi_dma_txstats_free(struct bwi_softc *) __unused; +void bwi_dma_ring_addr(void *, bus_dma_segment_t *, int, int) __unused; +void bwi_dma_buf_addr(void *, bus_dma_segment_t *, int, bus_size_t, int) __unused; -static void bwi_power_on(struct bwi_softc *, int); -static int bwi_power_off(struct bwi_softc *, int); -static int bwi_set_clock_mode(struct bwi_softc *, enum bwi_clock_mode); -static int bwi_set_clock_delay(struct bwi_softc *); -static void bwi_get_clock_freq(struct bwi_softc *, struct bwi_clock_freq *); -static int bwi_get_pwron_delay(struct bwi_softc *sc); -static void bwi_set_addr_filter(struct bwi_softc *, uint16_t, +void bwi_power_on(struct bwi_softc *, int); +int bwi_power_off(struct bwi_softc *, int); +int bwi_set_clock_mode(struct bwi_softc *, enum bwi_clock_mode); +int bwi_set_clock_delay(struct bwi_softc *); +void bwi_get_clock_freq(struct bwi_softc *, struct bwi_clock_freq *); +int bwi_get_pwron_delay(struct bwi_softc *sc); +void bwi_set_addr_filter(struct bwi_softc *, uint16_t, const uint8_t *); -static void bwi_set_bssid(struct bwi_softc *, const uint8_t *); -static int bwi_set_chan(struct bwi_softc *, u_int8_t); +void bwi_set_bssid(struct bwi_softc *, const uint8_t *); +int bwi_set_chan(struct bwi_softc *, u_int8_t); + +void bwi_get_card_flags(struct bwi_softc *); +void bwi_get_eaddr(struct bwi_softc *, uint16_t, uint8_t *); + +int bwi_bus_attach(struct bwi_softc *); +int bwi_bbp_attach(struct bwi_softc *); +int bwi_bbp_power_on(struct bwi_softc *, enum bwi_clock_mode); +void bwi_bbp_power_off(struct bwi_softc *); + +const char *bwi_regwin_name(const struct bwi_regwin *) __unused; +uint32_t bwi_regwin_disable_bits(struct bwi_softc *); +void bwi_regwin_info(struct bwi_softc *, uint16_t *, uint8_t *); +int bwi_regwin_select(struct bwi_softc *, int); + +/* misc unsorted */ +int bwi_fwimage_is_valid(struct bwi_softc *, + const struct fw_image *, uint8_t); +void bwi_mac_balance_atten(int *, int *); +int16_t bwi_nrssi_11g(struct bwi_mac *); + +struct bwi_rf_lo * bwi_get_rf_lo(struct bwi_mac *, uint16_t, uint16_t); +struct bwi_rf_lo * bwi_rf_lo_find(struct bwi_mac *, + const struct bwi_tpctl *); +int bwi_rf_lo_isused(struct bwi_mac *, const struct bwi_rf_lo *); +uint8_t _bwi_rf_lo_update(struct bwi_mac *, uint16_t); + -static void bwi_get_card_flags(struct bwi_softc *); -static void bwi_get_eaddr(struct bwi_softc *, uint16_t, uint8_t *); +uint16_t bwi_bitswap4(uint16_t); +uint16_t bwi_phy812_value(struct bwi_mac *, uint16_t); +int32_t _bwi_adjust_devide(int32_t, int32_t); +int32_t _nrssi_threshold(const struct bwi_rf *, int32_t); -static int bwi_bus_attach(struct bwi_softc *); -static int bwi_bbp_attach(struct bwi_softc *); -static int bwi_bbp_power_on(struct bwi_softc *, enum bwi_clock_mode); -static void bwi_bbp_power_off(struct bwi_softc *); +void bwi_setup_desc32(struct bwi_softc *, struct bwi_desc32 *, + int, int, bus_addr_t, int, int); +void bwi_ofdm_plcp_header(uint32_t *, int, uint8_t); +void bwi_ds_plcp_header(struct ieee80211_ds_plcp_hdr *, int, + uint8_t); -static const char *bwi_regwin_name(const struct bwi_regwin *) __unused; -static uint32_t bwi_regwin_disable_bits(struct bwi_softc *); -static void bwi_regwin_info(struct bwi_softc *, uint16_t *, uint8_t *); -static int bwi_regwin_select(struct bwi_softc *, int); struct cfdriver bwi_cd = { NULL, "bwi", DV_IFNET @@ -852,7 +891,7 @@ bwi_mac_set_tpctl_11bg(struct bwi_mac *mac, const struct bwi_tpctl *new_tpctl) bwi_rf_lo_adjust(mac, tpctl); } -static int +int bwi_mac_test(struct bwi_mac *mac) { struct bwi_softc *sc = mac->mac_sc; @@ -903,7 +942,7 @@ bwi_mac_test(struct bwi_mac *mac) return 0; } -static void +void bwi_mac_setup_tpctl(struct bwi_mac *mac) { struct bwi_softc *sc = mac->mac_sc; @@ -1141,7 +1180,7 @@ bwi_mac_detach(struct bwi_mac *mac) bwi_mac_fw_free(mac); } -static __inline int +int bwi_fwimage_is_valid(struct bwi_softc *sc, const struct fw_image *fw, uint8_t fw_type) { @@ -1192,7 +1231,7 @@ bwi_fwimage_is_valid(struct bwi_softc *sc, const struct fw_image *fw, /* * XXX Error cleanup */ -static int +int bwi_mac_fw_alloc(struct bwi_mac *mac) { printf("%s\n", __func__); @@ -1287,7 +1326,7 @@ back: return (0); } -static void +void bwi_mac_fw_free(struct bwi_mac *mac) { printf("%s\n", __func__); @@ -1314,7 +1353,7 @@ bwi_mac_fw_free(struct bwi_mac *mac) #endif } -static int +int bwi_mac_fw_load(struct bwi_mac *mac) { printf("%s\n", __func__); @@ -1396,7 +1435,7 @@ bwi_mac_fw_load(struct bwi_mac *mac) return (0); } -static int +int bwi_mac_gpio_init(struct bwi_mac *mac) { struct bwi_softc *sc = mac->mac_sc; @@ -1431,7 +1470,7 @@ bwi_mac_gpio_init(struct bwi_mac *mac) return bwi_regwin_switch(sc, old, NULL); } -static int +int bwi_mac_gpio_fini(struct bwi_mac *mac) { struct bwi_softc *sc = mac->mac_sc; @@ -1448,7 +1487,7 @@ bwi_mac_gpio_fini(struct bwi_mac *mac) return bwi_regwin_switch(sc, old, NULL); } -static int +int bwi_mac_fw_load_iv(struct bwi_mac *mac, const struct fw_image *fw) { printf("%s\n", __func__); @@ -1529,7 +1568,7 @@ bwi_mac_fw_load_iv(struct bwi_mac *mac, const struct fw_image *fw) return (0); } -static int +int bwi_mac_fw_init(struct bwi_mac *mac) { int error; @@ -1548,7 +1587,7 @@ bwi_mac_fw_init(struct bwi_mac *mac) return error; } -static void +void bwi_mac_opmode_init(struct bwi_mac *mac) { struct bwi_softc *sc = mac->mac_sc; @@ -1618,7 +1657,7 @@ bwi_mac_opmode_init(struct bwi_mac *mac) CSR_WRITE_2(sc, BWI_MAC_PRE_TBTT, pre_tbtt); } -static void +void bwi_mac_hostflags_init(struct bwi_mac *mac) { struct bwi_softc *sc = mac->mac_sc; @@ -1647,7 +1686,7 @@ bwi_mac_hostflags_init(struct bwi_mac *mac) HFLAGS_WRITE(mac, host_flags); } -static void +void bwi_mac_bss_param_init(struct bwi_mac *mac) { struct bwi_softc *sc = mac->mac_sc; @@ -1697,7 +1736,7 @@ bwi_mac_bss_param_init(struct bwi_mac *mac) IEEE80211_CW_MAX); } -static void +void bwi_mac_set_retry_lim(struct bwi_mac *mac, const struct bwi_retry_lim *lim) { /* Short/Long retry limit */ @@ -1713,7 +1752,7 @@ bwi_mac_set_retry_lim(struct bwi_mac *mac, const struct bwi_retry_lim *lim) lim->lgretry_fb); } -static void +void bwi_mac_set_ackrates(struct bwi_mac *mac, const struct ieee80211_rateset *rs) { printf("%s\n", __func__); @@ -1858,7 +1897,7 @@ bwi_mac_shutdown(struct bwi_mac *mac) mac->mac_flags &= ~BWI_MAC_F_INITED; } -static int +int bwi_mac_get_property(struct bwi_mac *mac) { struct bwi_softc *sc = mac->mac_sc; @@ -1985,7 +2024,7 @@ bwi_mac_attach(struct bwi_softc *sc, int id, uint8_t rev) return 0; } -static __inline void +void bwi_mac_balance_atten(int *bbp_atten0, int *rf_atten0) { int bbp_atten, rf_atten, rf_atten_lim = -1; @@ -2043,7 +2082,7 @@ bwi_mac_balance_atten(int *bbp_atten0, int *rf_atten0) *bbp_atten0 = bbp_atten; } -static void +void bwi_mac_adjust_tpctl(struct bwi_mac *mac, int rf_atten_adj, int bbp_atten_adj) { struct bwi_softc *sc = mac->mac_sc; @@ -2185,7 +2224,7 @@ bwi_mac_calibrate_txpower(struct bwi_mac *mac) /* TODO: LO */ } -static void +void bwi_mac_lock(struct bwi_mac *mac) { struct bwi_softc *sc = mac->mac_sc; @@ -2207,7 +2246,7 @@ bwi_mac_lock(struct bwi_mac *mac) mac->mac_flags |= BWI_MAC_F_LOCKED; } -static void +void bwi_mac_unlock(struct bwi_mac *mac) { struct bwi_softc *sc = mac->mac_sc; @@ -2376,7 +2415,7 @@ bwi_phy_calibrate(struct bwi_mac *mac) return 0; } -static void +void bwi_tbl_write_2(struct bwi_mac *mac, uint16_t ofs, uint16_t data) { struct bwi_phy *phy = &mac->mac_phy; @@ -2386,7 +2425,7 @@ bwi_tbl_write_2(struct bwi_mac *mac, uint16_t ofs, uint16_t data) PHY_WRITE(mac, phy->phy_tbl_data_lo, data); } -static void +void bwi_tbl_write_4(struct bwi_mac *mac, uint16_t ofs, uint32_t data) { struct bwi_phy *phy = &mac->mac_phy; @@ -2413,13 +2452,13 @@ bwi_nrssi_read(struct bwi_mac *mac, uint16_t ofs) return (int16_t)PHY_READ(mac, BWI_PHYR_NRSSI_DATA); } -static void +void bwi_phy_init_11a(struct bwi_mac *mac) { /* TODO:11A */ } -static void +void bwi_phy_init_11g(struct bwi_mac *mac) { struct bwi_softc *sc = mac->mac_sc; @@ -2532,7 +2571,7 @@ bwi_phy_init_11g(struct bwi_mac *mac) } } -static void +void bwi_phy_init_11b_rev2(struct bwi_mac *mac) { /* TODO:11B */ @@ -2540,7 +2579,7 @@ bwi_phy_init_11b_rev2(struct bwi_mac *mac) "%s is not implemented yet\n", __func__); } -static void +void bwi_phy_init_11b_rev4(struct bwi_mac *mac) { /* TODO:11B */ @@ -2548,7 +2587,7 @@ bwi_phy_init_11b_rev4(struct bwi_mac *mac) "%s is not implemented yet\n", __func__); } -static void +void bwi_phy_init_11b_rev5(struct bwi_mac *mac) { struct bwi_softc *sc = mac->mac_sc; @@ -2650,7 +2689,7 @@ bwi_phy_init_11b_rev5(struct bwi_mac *mac) CSR_FILT_SETBITS_2(sc, BWI_PHY_MAGIC_REG1, 0xffc0, 0x4); } -static void +void bwi_phy_init_11b_rev6(struct bwi_mac *mac) { struct bwi_softc *sc = mac->mac_sc; @@ -2790,7 +2829,7 @@ bwi_phy_init_11b_rev6(struct bwi_mac *mac) #define N(arr) (int)(sizeof(arr) / sizeof(arr[0])) -static void +void bwi_phy_config_11g(struct bwi_mac *mac) { struct bwi_softc *sc = mac->mac_sc; @@ -2925,7 +2964,7 @@ bwi_phy_config_11g(struct bwi_mac *mac) /* * Configure Automatic Gain Controller */ -static void +void bwi_phy_config_agc(struct bwi_mac *mac) { struct bwi_phy *phy = &mac->mac_phy; @@ -3067,7 +3106,7 @@ bwi_phy_clear_state(struct bwi_phy *phy) /* BWIRF */ -static __inline int16_t +int16_t bwi_nrssi_11g(struct bwi_mac *mac) { int16_t val; @@ -3082,7 +3121,7 @@ bwi_nrssi_11g(struct bwi_mac *mac) #undef NRSSI_11G_MASK } -static __inline struct bwi_rf_lo * +struct bwi_rf_lo * bwi_get_rf_lo(struct bwi_mac *mac, uint16_t rf_atten, uint16_t bbp_atten) { int n; @@ -3093,7 +3132,7 @@ bwi_get_rf_lo(struct bwi_mac *mac, uint16_t rf_atten, uint16_t bbp_atten) return &mac->mac_rf.rf_lo[n]; } -static __inline int +int bwi_rf_lo_isused(struct bwi_mac *mac, const struct bwi_rf_lo *lo) { struct bwi_rf *rf = &mac->mac_rf; @@ -3433,7 +3472,7 @@ bwi_rf_init(struct bwi_mac *mac) } } -static void +void bwi_rf_off_11a(struct bwi_mac *mac) { RF_WRITE(mac, 0x4, 0xff); @@ -3445,20 +3484,20 @@ bwi_rf_off_11a(struct bwi_mac *mac) PHY_WRITE(mac, 0x15, 0xaa00); } -static void +void bwi_rf_off_11bg(struct bwi_mac *mac) { PHY_WRITE(mac, 0x15, 0xaa00); } -static void +void bwi_rf_off_11g_rev5(struct bwi_mac *mac) { PHY_SETBITS(mac, 0x811, 0x8c); PHY_CLRBITS(mac, 0x812, 0x8c); } -static void +void bwi_rf_work_around(struct bwi_mac *mac, u_int chan) { struct bwi_softc *sc = mac->mac_sc; @@ -3481,7 +3520,7 @@ bwi_rf_work_around(struct bwi_mac *mac, u_int chan) CSR_WRITE_2(sc, BWI_RF_CHAN, BWI_RF_2GHZ_CHAN(chan)); } -static __inline struct bwi_rf_lo * +struct bwi_rf_lo * bwi_rf_lo_find(struct bwi_mac *mac, const struct bwi_tpctl *tpctl) { uint16_t rf_atten, bbp_atten; @@ -3532,7 +3571,7 @@ bwi_rf_lo_adjust(struct bwi_mac *mac, const struct bwi_tpctl *tpctl) RF_LO_WRITE(mac, lo); } -static void +void bwi_rf_lo_write(struct bwi_mac *mac, const struct bwi_rf_lo *lo) { uint16_t val; @@ -3543,7 +3582,7 @@ bwi_rf_lo_write(struct bwi_mac *mac, const struct bwi_rf_lo *lo) PHY_WRITE(mac, BWI_PHYR_RF_LO, val); } -static int +int bwi_rf_gain_max_reached(struct bwi_mac *mac, int idx) { PHY_FILT_SETBITS(mac, 0x812, 0xf0ff, idx << 8); @@ -3556,8 +3595,8 @@ bwi_rf_gain_max_reached(struct bwi_mac *mac, int idx) } /* XXX use bitmap array */ -static __inline uint16_t -bitswap4(uint16_t val) +uint16_t +bwi_bitswap4(uint16_t val) { uint16_t ret; @@ -3568,7 +3607,7 @@ bitswap4(uint16_t val) return ret; } -static __inline uint16_t +uint16_t bwi_phy812_value(struct bwi_mac *mac, uint16_t lpd) { struct bwi_softc *sc = mac->mac_sc; @@ -3800,7 +3839,7 @@ bwi_rf_init_bcm2050(struct bwi_mac *mac) for (i = 0; i < 16; ++i) { int j; - rfr_78 = (bitswap4(i) << 1) | 0x20; + rfr_78 = (bwi_bitswap4(i) << 1) | 0x20; RF_WRITE(mac, 0x78, rfr_78); DELAY(10); @@ -3902,7 +3941,7 @@ bwi_rf_init_bcm2050(struct bwi_mac *mac) #undef SAVE_RF_MAX } -static uint16_t +uint16_t bwi_rf_calibval(struct bwi_mac *mac) { /* http://bcm-specs.sipsolutions.net/RCCTable */ @@ -3925,7 +3964,7 @@ bwi_rf_calibval(struct bwi_mac *mac) return calib; } -static __inline int32_t +int32_t _bwi_adjust_devide(int32_t num, int32_t den) { if (num < 0) @@ -3938,7 +3977,7 @@ _bwi_adjust_devide(int32_t num, int32_t den) * http://bcm-specs.sipsolutions.net/TSSI_to_DBM_Table * "calculating table entries" */ -static int +int bwi_rf_calc_txpower(int8_t *txpwr, uint8_t idx, const int16_t pa_params[]) { int32_t m1, m2, f, dbm; @@ -4271,7 +4310,7 @@ bwi_rf_lo_update(struct bwi_mac *mac) bwi_rf_set_chan(mac, orig_chan, 1); } -static uint32_t +uint32_t bwi_rf_lo_devi_measure(struct bwi_mac *mac, uint16_t ctrl) { struct bwi_phy *phy = &mac->mac_phy; @@ -4304,7 +4343,7 @@ bwi_rf_lo_devi_measure(struct bwi_mac *mac, uint16_t ctrl) return devi; } -static uint16_t +uint16_t bwi_rf_get_tp_ctrl2(struct bwi_mac *mac) { uint32_t devi_min; @@ -4330,7 +4369,7 @@ bwi_rf_get_tp_ctrl2(struct bwi_mac *mac) return tp_ctrl2; } -static uint8_t +uint8_t _bwi_rf_lo_update(struct bwi_mac *mac, uint16_t orig_rf7a) { #define RF_ATTEN_LISTSZ 14 @@ -4427,7 +4466,7 @@ _bwi_rf_lo_update(struct bwi_mac *mac, uint16_t orig_rf7a) #undef BBP_ATTEN_MAX } -static void +void bwi_rf_lo_measure(struct bwi_mac *mac, const struct bwi_rf_lo *src_lo, struct bwi_rf_lo *dst_lo, uint8_t devi_ctrl) { @@ -4516,7 +4555,7 @@ bwi_rf_lo_measure(struct bwi_mac *mac, const struct bwi_rf_lo *src_lo, #undef LO_ADJUST_MAX } -static void +void bwi_rf_calc_nrssi_slope_11b(struct bwi_mac *mac) { #define SAVE_RF_MAX 3 @@ -4629,7 +4668,7 @@ bwi_rf_calc_nrssi_slope_11b(struct bwi_mac *mac) #undef SAVE_PHY_MAX } -static void +void bwi_rf_set_nrssi_ofs_11g(struct bwi_mac *mac) { #define SAVE_RF_MAX 2 @@ -4784,7 +4823,7 @@ bwi_rf_set_nrssi_ofs_11g(struct bwi_mac *mac) #undef SAVE_PHY6_MAX } -static void +void bwi_rf_calc_nrssi_slope_11g(struct bwi_mac *mac) { #define SAVE_RF_MAX 3 @@ -4963,7 +5002,7 @@ bwi_rf_calc_nrssi_slope_11g(struct bwi_mac *mac) #undef SAVE_PHY3_MAX } -static void +void bwi_rf_init_sw_nrssi_table(struct bwi_mac *mac) { struct bwi_rf *rf = &mac->mac_rf; @@ -5003,7 +5042,7 @@ bwi_rf_init_hw_nrssi_table(struct bwi_mac *mac, uint16_t adjust) } } -static void +void bwi_rf_set_nrssi_thr_11b(struct bwi_mac *mac) { struct bwi_rf *rf = &mac->mac_rf; @@ -5043,7 +5082,7 @@ bwi_rf_set_nrssi_thr_11b(struct bwi_mac *mac) } } -static __inline int32_t +int32_t _nrssi_threshold(const struct bwi_rf *rf, int32_t val) { val *= (rf->rf_nrssi[1] - rf->rf_nrssi[0]); @@ -5060,7 +5099,7 @@ _nrssi_threshold(const struct bwi_rf *rf, int32_t val) return val; } -static void +void bwi_rf_set_nrssi_thr_11g(struct bwi_mac *mac) { int32_t thr1, thr2; @@ -5150,13 +5189,13 @@ bwi_rf_clear_state(struct bwi_rf *rf) rf->rf_idle_tssi = rf->rf_idle_tssi0; } -static void +void bwi_rf_on_11a(struct bwi_mac *mac) { /* TODO:11A */ } -static void +void bwi_rf_on_11bg(struct bwi_mac *mac) { struct bwi_phy *phy = &mac->mac_phy; @@ -5296,7 +5335,7 @@ bwi_read_sprom(struct bwi_softc *sc, uint16_t ofs) return CSR_READ_2(sc, ofs + BWI_SPROM_START); } -static __inline void +void bwi_setup_desc32(struct bwi_softc *sc, struct bwi_desc32 *desc_array, int ndesc, int desc_idx, bus_addr_t paddr, int buf_len, int tx) @@ -5508,7 +5547,7 @@ bwi_detach(void *arg) return 0; } -static void +void bwi_power_on(struct bwi_softc *sc, int with_pll) { printf("%s\n", __func__); @@ -5550,7 +5589,7 @@ back: #endif } -static int +int bwi_power_off(struct bwi_softc *sc, int with_pll) { printf("%s\n", __func__); @@ -5602,7 +5641,7 @@ bwi_regwin_switch(struct bwi_softc *sc, struct bwi_regwin *rw, return 0; } -static int +int bwi_regwin_select(struct bwi_softc *sc, int id) { uint32_t win = BWI_PCIM_REGWIN(id); @@ -5620,7 +5659,7 @@ bwi_regwin_select(struct bwi_softc *sc, int id) return ENXIO; } -static void +void bwi_regwin_info(struct bwi_softc *sc, uint16_t *type, uint8_t *rev) { uint32_t val; @@ -5634,7 +5673,7 @@ bwi_regwin_info(struct bwi_softc *sc, uint16_t *type, uint8_t *rev) *type, *rev, __SHIFTOUT(val, BWI_ID_HI_REGWIN_VENDOR_MASK)); } -static int +int bwi_bbp_attach(struct bwi_softc *sc) { #define N(arr) (int)(sizeof(arr) / sizeof(arr[0])) @@ -5877,7 +5916,7 @@ back: return bwi_regwin_switch(sc, old, NULL); } -static void +void bwi_get_card_flags(struct bwi_softc *sc) { sc->sc_card_flags = bwi_read_sprom(sc, BWI_SPROM_CARD_FLAGS); @@ -5893,7 +5932,7 @@ bwi_get_card_flags(struct bwi_softc *sc) sc->sc_card_flags); } -static void +void bwi_get_eaddr(struct bwi_softc *sc, uint16_t eaddr_ofs, uint8_t *eaddr) { int i; @@ -5904,7 +5943,7 @@ bwi_get_eaddr(struct bwi_softc *sc, uint16_t eaddr_ofs, uint8_t *eaddr) } } -static void +void bwi_get_clock_freq(struct bwi_softc *sc, struct bwi_clock_freq *freq) { struct bwi_regwin *com; @@ -5967,7 +6006,7 @@ bwi_get_clock_freq(struct bwi_softc *sc, struct bwi_clock_freq *freq) freq->clkfreq_min, freq->clkfreq_max); } -static int +int bwi_set_clock_mode(struct bwi_softc *sc, enum bwi_clock_mode clk_mode) { struct bwi_regwin *old, *com; @@ -6024,7 +6063,7 @@ bwi_set_clock_mode(struct bwi_softc *sc, enum bwi_clock_mode clk_mode) return bwi_regwin_switch(sc, old, NULL); } -static int +int bwi_set_clock_delay(struct bwi_softc *sc) { struct bwi_regwin *old, *com; @@ -6144,7 +6183,7 @@ back: return (0); } -static int +int bwi_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data) { struct bwi_softc *sc = ifp->if_softc; @@ -6216,7 +6255,7 @@ bwi_ioctl(struct ifnet *ifp, u_long cmd, caddr_t data) return (error); } -static void +void bwi_start(struct ifnet *ifp) { struct bwi_softc *sc = ifp->if_softc; @@ -6327,7 +6366,7 @@ bwi_start(struct ifnet *ifp) ifp->if_timer = 1; } -static void +void bwi_watchdog(struct ifnet *ifp) { struct bwi_softc *sc = ifp->if_softc; @@ -6349,7 +6388,7 @@ bwi_watchdog(struct ifnet *ifp) ieee80211_watchdog(ifp); } -static int +int bwi_stop(struct bwi_softc *sc) { struct ieee80211com *ic = &sc->sc_ic; @@ -6502,7 +6541,7 @@ bwi_intr(void *xsc) return (1); } -static int +int bwi_newstate(struct ieee80211com *ic, enum ieee80211_state nstate, int arg) { struct bwi_softc *sc = ic->ic_if.if_softc; @@ -6552,7 +6591,7 @@ back: return error; } -static int +int bwi_media_change(struct ifnet *ifp) { int error; @@ -6566,7 +6605,7 @@ bwi_media_change(struct ifnet *ifp) return 0; } -static int +int bwi_dma_alloc(struct bwi_softc *sc) { printf("%s\n", __func__); @@ -6714,7 +6753,7 @@ bwi_dma_alloc(struct bwi_softc *sc) return (0); } -static void +void bwi_dma_free(struct bwi_softc *sc) { printf("%s\n", __func__); @@ -6755,7 +6794,7 @@ bwi_dma_free(struct bwi_softc *sc) #endif } -static int +int bwi_dma_ring_alloc(struct bwi_softc *sc, bus_dma_tag_t dtag, struct bwi_ring_data *rd, bus_size_t size, uint32_t txrx_ctrl) @@ -6788,7 +6827,7 @@ bwi_dma_ring_alloc(struct bwi_softc *sc, bus_dma_tag_t dtag, return (0); } -static int +int bwi_dma_txstats_alloc(struct bwi_softc *sc, uint32_t ctrl_base, bus_size_t desc_sz) { @@ -6884,7 +6923,7 @@ bwi_dma_txstats_alloc(struct bwi_softc *sc, uint32_t ctrl_base, return (0); } -static void +void bwi_dma_txstats_free(struct bwi_softc *sc) { printf("%s\n", __func__); @@ -6912,14 +6951,14 @@ bwi_dma_txstats_free(struct bwi_softc *sc) #endif } -static void +void bwi_dma_ring_addr(void *arg, bus_dma_segment_t *seg, int nseg, int error) { KASSERT(nseg == 1, ("too many segments\n")); *((bus_addr_t *)arg) = seg->ds_addr; } -static int +int bwi_dma_mbuf_create(struct bwi_softc *sc) { printf("%s\n", __func__); @@ -7002,7 +7041,7 @@ fail: return (1); } -static void +void bwi_dma_mbuf_destroy(struct bwi_softc *sc, int ntx, int nrx) { printf("%s\n", __func__); @@ -7050,19 +7089,19 @@ bwi_dma_mbuf_destroy(struct bwi_softc *sc, int ntx, int nrx) #endif } -static void +void bwi_enable_intrs(struct bwi_softc *sc, uint32_t enable_intrs) { CSR_SETBITS_4(sc, BWI_MAC_INTR_MASK, enable_intrs); } -static void +void bwi_disable_intrs(struct bwi_softc *sc, uint32_t disable_intrs) { CSR_CLRBITS_4(sc, BWI_MAC_INTR_MASK, disable_intrs); } -static int +int bwi_init_tx_ring32(struct bwi_softc *sc, int ring_idx) { printf("%s\n", __func__); @@ -7099,7 +7138,7 @@ bwi_init_tx_ring32(struct bwi_softc *sc, int ring_idx) return (1); } -static void +void bwi_init_rxdesc_ring32(struct bwi_softc *sc, uint32_t ctrl_base, bus_addr_t paddr, int hdr_size, int ndesc) { @@ -7122,7 +7161,7 @@ bwi_init_rxdesc_ring32(struct bwi_softc *sc, uint32_t ctrl_base, (ndesc - 1) * sizeof(struct bwi_desc32)); } -static int +int bwi_init_rx_ring32(struct bwi_softc *sc) { printf("%s\n", __func__); @@ -7150,7 +7189,7 @@ bwi_init_rx_ring32(struct bwi_softc *sc) return (1); } -static int +int bwi_init_txstats32(struct bwi_softc *sc) { printf("%s\n", __func__); @@ -7180,7 +7219,7 @@ bwi_init_txstats32(struct bwi_softc *sc) return (1); } -static void +void bwi_setup_rx_desc32(struct bwi_softc *sc, int buf_idx, bus_addr_t paddr, int buf_len) { @@ -7191,7 +7230,7 @@ bwi_setup_rx_desc32(struct bwi_softc *sc, int buf_idx, bus_addr_t paddr, paddr, buf_len, 0); } -static void +void bwi_setup_tx_desc32(struct bwi_softc *sc, struct bwi_ring_data *rd, int buf_idx, bus_addr_t paddr, int buf_len) { @@ -7200,42 +7239,42 @@ bwi_setup_tx_desc32(struct bwi_softc *sc, struct bwi_ring_data *rd, paddr, buf_len, 1); } -static int +int bwi_init_tx_ring64(struct bwi_softc *sc, int ring_idx) { /* TODO:64 */ return EOPNOTSUPP; } -static int +int bwi_init_rx_ring64(struct bwi_softc *sc) { /* TODO:64 */ return EOPNOTSUPP; } -static int +int bwi_init_txstats64(struct bwi_softc *sc) { /* TODO:64 */ return EOPNOTSUPP; } -static void +void bwi_setup_rx_desc64(struct bwi_softc *sc, int buf_idx, bus_addr_t paddr, int buf_len) { /* TODO:64 */ } -static void +void bwi_setup_tx_desc64(struct bwi_softc *sc, struct bwi_ring_data *rd, int buf_idx, bus_addr_t paddr, int buf_len) { /* TODO:64 */ } -static void +void bwi_dma_buf_addr(void *arg, bus_dma_segment_t *seg, int nseg, bus_size_t mapsz, int error) { @@ -7245,7 +7284,7 @@ bwi_dma_buf_addr(void *arg, bus_dma_segment_t *seg, int nseg, } } -static int +int bwi_newbuf(struct bwi_softc *sc, int buf_idx, int init) { printf("%s\n", __func__); @@ -7324,7 +7363,7 @@ back: return (0); } -static void +void bwi_set_addr_filter(struct bwi_softc *sc, uint16_t addr_ofs, const uint8_t *addr) { @@ -7342,7 +7381,7 @@ bwi_set_addr_filter(struct bwi_softc *sc, uint16_t addr_ofs, } } -static int +int bwi_set_chan(struct bwi_softc *sc, u_int8_t chan) { struct bwi_mac *mac; @@ -7357,7 +7396,7 @@ bwi_set_chan(struct bwi_softc *sc, u_int8_t chan) return 0; } -static void +void bwi_next_scan(void *xsc) { struct bwi_softc *sc = xsc; @@ -7373,7 +7412,7 @@ bwi_next_scan(void *xsc) splx(s); } -static void +void bwi_rxeof(struct bwi_softc *sc, int end_idx) { printf("%s\n", __func__); @@ -7448,7 +7487,7 @@ next: #endif } -static void +void bwi_rxeof32(struct bwi_softc *sc) { uint32_t val, rx_ctrl; @@ -7466,13 +7505,13 @@ bwi_rxeof32(struct bwi_softc *sc) end_idx * sizeof(struct bwi_desc32)); } -static void +void bwi_rxeof64(struct bwi_softc *sc) { /* TODO:64 */ } -static void +void bwi_reset_rx_ring32(struct bwi_softc *sc, uint32_t rx_ctrl) { int i; @@ -7499,13 +7538,13 @@ bwi_reset_rx_ring32(struct bwi_softc *sc, uint32_t rx_ctrl) CSR_WRITE_4(sc, rx_ctrl + BWI_RX32_RINGINFO, 0); } -static void +void bwi_free_txstats32(struct bwi_softc *sc) { bwi_reset_rx_ring32(sc, sc->sc_txstats->stats_ctrl_base); } -static void +void bwi_free_rx_ring32(struct bwi_softc *sc) { struct bwi_ring_data *rd = &sc->sc_rx_rdata; @@ -7525,7 +7564,7 @@ bwi_free_rx_ring32(struct bwi_softc *sc) } } -static void +void bwi_free_tx_ring32(struct bwi_softc *sc, int ring_idx) { printf("%s\n", __func__); @@ -7590,19 +7629,19 @@ bwi_free_tx_ring32(struct bwi_softc *sc, int ring_idx) #endif } -static void +void bwi_free_txstats64(struct bwi_softc *sc) { /* TODO:64 */ } -static void +void bwi_free_rx_ring64(struct bwi_softc *sc) { /* TODO:64 */ } -static void +void bwi_free_tx_ring64(struct bwi_softc *sc, int ring_idx) { /* TODO:64 */ @@ -7635,7 +7674,7 @@ bwi_rate2plcp(uint8_t rate) } } -static __inline void +void bwi_ofdm_plcp_header(uint32_t *plcp0, int pkt_len, uint8_t rate) { /* XXX does not belong here */ @@ -7649,21 +7688,7 @@ bwi_ofdm_plcp_header(uint32_t *plcp0, int pkt_len, uint8_t rate) *plcp0 = htole32(plcp); } -/* XXX does not belong here */ -struct ieee80211_ds_plcp_hdr { - uint8_t i_signal; - uint8_t i_service; - uint16_t i_length; - uint16_t i_crc; -} __packed; - -#define IEEE80211_DS_PLCP_SERVICE_LOCKED 0x04 -#define IEEE80211_DS_PLCL_SERVICE_PBCC 0x08 -#define IEEE80211_DS_PLCP_SERVICE_LENEXT5 0x20 -#define IEEE80211_DS_PLCP_SERVICE_LENEXT6 0x40 -#define IEEE80211_DS_PLCP_SERVICE_LENEXT7 0x80 - -static __inline void +void bwi_ds_plcp_header(struct ieee80211_ds_plcp_hdr *plcp, int pkt_len, uint8_t rate) { @@ -7691,7 +7716,7 @@ bwi_ds_plcp_header(struct ieee80211_ds_plcp_hdr *plcp, int pkt_len, /* NOTE: do NOT touch i_crc */ } -static void +void bwi_plcp_header(void *plcp, int pkt_len, uint8_t rate) { printf("%s\n", __func__); @@ -7712,7 +7737,7 @@ bwi_plcp_header(void *plcp, int pkt_len, uint8_t rate) #endif } -static int +int bwi_encap(struct bwi_softc *sc, int idx, struct mbuf *m, struct ieee80211_node *ni) { @@ -7897,7 +7922,7 @@ back: return (1); } -static void +void bwi_start_tx32(struct bwi_softc *sc, uint32_t tx_ctrl, int idx) { idx = (idx + 1) % BWI_TX_NDESC; @@ -7905,13 +7930,13 @@ bwi_start_tx32(struct bwi_softc *sc, uint32_t tx_ctrl, int idx) idx * sizeof(struct bwi_desc32)); } -static void +void bwi_start_tx64(struct bwi_softc *sc, uint32_t tx_ctrl, int idx) { /* TODO:64 */ } -static void +void bwi_txeof_status32(struct bwi_softc *sc) { struct ifnet *ifp = &sc->sc_ic.ic_if; @@ -7933,13 +7958,13 @@ bwi_txeof_status32(struct bwi_softc *sc) ifp->if_start(ifp); } -static void +void bwi_txeof_status64(struct bwi_softc *sc) { /* TODO:64 */ } -static void +void _bwi_txeof(struct bwi_softc *sc, uint16_t tx_id) { struct ieee80211com *ic = &sc->sc_ic; @@ -7983,7 +8008,7 @@ _bwi_txeof(struct bwi_softc *sc, uint16_t tx_id) ifp->if_flags &= ~IFF_OACTIVE; } -static void +void bwi_txeof_status(struct bwi_softc *sc, int end_idx) { printf("%s\n", __func__); @@ -8002,7 +8027,7 @@ bwi_txeof_status(struct bwi_softc *sc, int end_idx) #endif } -static void +void bwi_txeof(struct bwi_softc *sc) { struct ifnet *ifp = &sc->sc_ic.ic_if; @@ -8029,21 +8054,21 @@ bwi_txeof(struct bwi_softc *sc) ifp->if_start(ifp); } -static int +int bwi_bbp_power_on(struct bwi_softc *sc, enum bwi_clock_mode clk_mode) { bwi_power_on(sc, 1); return bwi_set_clock_mode(sc, clk_mode); } -static void +void bwi_bbp_power_off(struct bwi_softc *sc) { bwi_set_clock_mode(sc, BWI_CLOCK_MODE_SLOW); bwi_power_off(sc, 1); } -static int +int bwi_get_pwron_delay(struct bwi_softc *sc) { struct bwi_regwin *com, *old; @@ -8071,7 +8096,7 @@ bwi_get_pwron_delay(struct bwi_softc *sc) return bwi_regwin_switch(sc, old, NULL); } -static int +int bwi_bus_attach(struct bwi_softc *sc) { struct bwi_regwin *bus, *old; @@ -8092,7 +8117,7 @@ bwi_bus_attach(struct bwi_softc *sc) return bwi_regwin_switch(sc, old, NULL); } -static const char * +const char * bwi_regwin_name(const struct bwi_regwin *rw) { switch (rw->rw_type) { @@ -8109,7 +8134,7 @@ bwi_regwin_name(const struct bwi_regwin *rw) return NULL; } -static uint32_t +uint32_t bwi_regwin_disable_bits(struct bwi_softc *sc) { uint32_t busrev; @@ -8271,7 +8296,7 @@ bwi_regwin_enable(struct bwi_softc *sc, struct bwi_regwin *rw, uint32_t flags) DELAY(1); } -static void +void bwi_set_bssid(struct bwi_softc *sc, const uint8_t *bssid) { struct ieee80211com *ic = &sc->sc_ic; @@ -8302,7 +8327,7 @@ bwi_set_bssid(struct bwi_softc *sc, const uint8_t *bssid) } } -static void +void bwi_updateslot(struct ieee80211com *ic) { struct bwi_softc *sc = ic->ic_if.if_softc; @@ -8320,7 +8345,7 @@ bwi_updateslot(struct ieee80211com *ic) bwi_mac_updateslot(mac, (ic->ic_flags & IEEE80211_F_SHSLOT)); } -static void +void bwi_calibrate(void *xsc) { struct bwi_softc *sc = xsc; |