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);
109427a06beSAllen 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