105491d2cSKalle Valo /* 205491d2cSKalle Valo * Copyright (c) 2010 Broadcom Corporation 305491d2cSKalle Valo * 405491d2cSKalle Valo * Permission to use, copy, modify, and/or distribute this software for any 505491d2cSKalle Valo * purpose with or without fee is hereby granted, provided that the above 605491d2cSKalle Valo * copyright notice and this permission notice appear in all copies. 705491d2cSKalle Valo * 805491d2cSKalle Valo * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES 905491d2cSKalle Valo * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 1005491d2cSKalle Valo * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY 1105491d2cSKalle Valo * SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 1205491d2cSKalle Valo * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION 1305491d2cSKalle Valo * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN 1405491d2cSKalle Valo * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 1505491d2cSKalle Valo */ 1605491d2cSKalle Valo 1705491d2cSKalle Valo #ifndef _BRCM_MAC80211_IF_H_ 1805491d2cSKalle Valo #define _BRCM_MAC80211_IF_H_ 1905491d2cSKalle Valo 2005491d2cSKalle Valo #include <linux/timer.h> 2105491d2cSKalle Valo #include <linux/interrupt.h> 2205491d2cSKalle Valo #include <linux/workqueue.h> 2305491d2cSKalle Valo #include <linux/leds.h> 2405491d2cSKalle Valo 2505491d2cSKalle Valo #include "ucode_loader.h" 2605491d2cSKalle Valo #include "led.h" 2705491d2cSKalle Valo /* 2805491d2cSKalle Valo * Starting index for 5G rates in the 2905491d2cSKalle Valo * legacy rate table. 3005491d2cSKalle Valo */ 3105491d2cSKalle Valo #define BRCMS_LEGACY_5G_RATE_OFFSET 4 3205491d2cSKalle Valo 3305491d2cSKalle Valo /* softmac ioctl definitions */ 3405491d2cSKalle Valo #define BRCMS_SET_SHORTSLOT_OVERRIDE 146 3505491d2cSKalle Valo 3605491d2cSKalle Valo struct brcms_timer { 3705491d2cSKalle Valo struct delayed_work dly_wrk; 3805491d2cSKalle Valo struct brcms_info *wl; 3905491d2cSKalle Valo void (*fn) (void *); /* function called upon expiration */ 4005491d2cSKalle Valo void *arg; /* fixed argument provided to called function */ 4105491d2cSKalle Valo uint ms; 4205491d2cSKalle Valo bool periodic; 4305491d2cSKalle Valo bool set; /* indicates if timer is active */ 4405491d2cSKalle Valo struct brcms_timer *next; /* for freeing on unload */ 4505491d2cSKalle Valo #ifdef DEBUG 4605491d2cSKalle Valo char *name; /* Description of the timer */ 4705491d2cSKalle Valo #endif 4805491d2cSKalle Valo }; 4905491d2cSKalle Valo 5005491d2cSKalle Valo struct brcms_if { 5105491d2cSKalle Valo uint subunit; /* WDS/BSS unit */ 5205491d2cSKalle Valo struct pci_dev *pci_dev; 5305491d2cSKalle Valo }; 5405491d2cSKalle Valo 5505491d2cSKalle Valo #define MAX_FW_IMAGES 4 5605491d2cSKalle Valo struct brcms_firmware { 5705491d2cSKalle Valo u32 fw_cnt; 5805491d2cSKalle Valo const struct firmware *fw_bin[MAX_FW_IMAGES]; 5905491d2cSKalle Valo const struct firmware *fw_hdr[MAX_FW_IMAGES]; 6005491d2cSKalle Valo u32 hdr_num_entries[MAX_FW_IMAGES]; 6105491d2cSKalle Valo }; 6205491d2cSKalle Valo 6305491d2cSKalle Valo struct brcms_info { 6405491d2cSKalle Valo struct brcms_pub *pub; /* pointer to public wlc state */ 6505491d2cSKalle Valo struct brcms_c_info *wlc; /* pointer to private common data */ 6605491d2cSKalle Valo u32 magic; 6705491d2cSKalle Valo 6805491d2cSKalle Valo int irq; 6905491d2cSKalle Valo 7005491d2cSKalle Valo spinlock_t lock; /* per-device perimeter lock */ 7105491d2cSKalle Valo spinlock_t isr_lock; /* per-device ISR synchronization lock */ 7205491d2cSKalle Valo 7305491d2cSKalle Valo /* tx flush */ 7405491d2cSKalle Valo wait_queue_head_t tx_flush_wq; 7505491d2cSKalle Valo 7605491d2cSKalle Valo /* timer related fields */ 7705491d2cSKalle Valo atomic_t callbacks; /* # outstanding callback functions */ 7805491d2cSKalle Valo struct brcms_timer *timers; /* timer cleanup queue */ 7905491d2cSKalle Valo 8005491d2cSKalle Valo struct tasklet_struct tasklet; /* dpc tasklet */ 8105491d2cSKalle Valo bool resched; /* dpc needs to be and is rescheduled */ 8205491d2cSKalle Valo struct brcms_firmware fw; 8305491d2cSKalle Valo struct wiphy *wiphy; 8405491d2cSKalle Valo struct brcms_ucode ucode; 8505491d2cSKalle Valo bool mute_tx; 8605491d2cSKalle Valo struct brcms_led radio_led; 8705491d2cSKalle Valo struct led_classdev led_dev; 8805491d2cSKalle Valo }; 8905491d2cSKalle Valo 9005491d2cSKalle Valo /* misc callbacks */ 9105491d2cSKalle Valo void brcms_init(struct brcms_info *wl); 9205491d2cSKalle Valo uint brcms_reset(struct brcms_info *wl); 9305491d2cSKalle Valo void brcms_intrson(struct brcms_info *wl); 9405491d2cSKalle Valo u32 brcms_intrsoff(struct brcms_info *wl); 9505491d2cSKalle Valo void brcms_intrsrestore(struct brcms_info *wl, u32 macintmask); 9605491d2cSKalle Valo int brcms_up(struct brcms_info *wl); 9705491d2cSKalle Valo void brcms_down(struct brcms_info *wl); 9805491d2cSKalle Valo void brcms_txflowcontrol(struct brcms_info *wl, struct brcms_if *wlif, 9905491d2cSKalle Valo bool state, int prio); 10005491d2cSKalle Valo bool brcms_rfkill_set_hw_state(struct brcms_info *wl); 10105491d2cSKalle Valo 10205491d2cSKalle Valo /* timer functions */ 10305491d2cSKalle Valo struct brcms_timer *brcms_init_timer(struct brcms_info *wl, 10405491d2cSKalle Valo void (*fn) (void *arg), void *arg, 10505491d2cSKalle Valo const char *name); 10605491d2cSKalle Valo void brcms_free_timer(struct brcms_timer *timer); 10705491d2cSKalle Valo void brcms_add_timer(struct brcms_timer *timer, uint ms, int periodic); 10805491d2cSKalle Valo bool brcms_del_timer(struct brcms_timer *timer); 109*427a06beSAllen Pais void brcms_dpc(struct tasklet_struct *t); 11005491d2cSKalle Valo void brcms_timer(struct brcms_timer *t); 11105491d2cSKalle Valo void brcms_fatal_error(struct brcms_info *wl); 11205491d2cSKalle Valo 11305491d2cSKalle Valo #endif /* _BRCM_MAC80211_IF_H_ */ 114