summaryrefslogtreecommitdiffstats
path: root/sys/dev/ath/if_ath_tx.h
blob: d4775d0e97ec818114456e12b92313c0b3ac5456 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
/*-
 * Copyright (c) 2002-2009 Sam Leffler, Errno Consulting
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer,
 *    without modification.
 * 2. Redistributions in binary form must reproduce at minimum a disclaimer
 *    similar to the "NO WARRANTY" disclaimer below ("Disclaimer") and any
 *    redistribution must be conditioned upon including a substantially
 *    similar Disclaimer requirement for further binary redistribution.
 *
 * NO WARRANTY
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF NONINFRINGEMENT, MERCHANTIBILITY
 * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
 * THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY,
 * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER
 * IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
 * THE POSSIBILITY OF SUCH DAMAGES.
 *
 * $FreeBSD$
 */
#ifndef	__IF_ATH_TX_H__
#define	__IF_ATH_TX_H__

/*
 * some general macros
 */
#define	INCR(_l, _sz)		(_l) ++; (_l) &= ((_sz) - 1)
/*
 * return block-ack bitmap index given sequence and starting sequence
 */
#define	ATH_BA_INDEX(_st, _seq)	(((_seq) - (_st)) & (IEEE80211_SEQ_RANGE - 1))

#define	WME_BA_BMP_SIZE	64
#define	WME_MAX_BA	WME_BA_BMP_SIZE

/*
 * How 'busy' to try and keep the hardware txq
 */
#define	ATH_AGGR_MIN_QDEPTH		2

/*
 * Watermark for scheduling TIDs in order to maximise aggregation.
 *
 * If hwq_depth is greater than this, don't schedule the TID
 * for packet scheduling - the hardware is already busy servicing
 * this TID.
 *
 * If hwq_depth is less than this, schedule the TID for packet
 * scheduling in the completion handler.
 */
#define	ATH_AGGR_SCHED_HIGH		4
#define	ATH_AGGR_SCHED_LOW		2

/*
 * return whether a bit at index _n in bitmap _bm is set
 * _sz is the size of the bitmap
 */
#define	ATH_BA_ISSET(_bm, _n)	(((_n) < (WME_BA_BMP_SIZE)) &&		\
	    ((_bm)[(_n) >> 5] & (1 << ((_n) & 31))))


/* extracting the seqno from buffer seqno */
#define	SEQNO(_a)	((_a) >> IEEE80211_SEQ_SEQ_SHIFT)

/*
 * Whether the current sequence number is within the
 * BAW.
 */
#define	BAW_WITHIN(_start, _bawsz, _seqno)	\
	    ((((_seqno) - (_start)) & 4095) < (_bawsz))

/*
 * Maximum aggregate size
 */
#define	ATH_AGGR_MAXSIZE	65530

extern void ath_freetx(struct mbuf *m);
extern void ath_tx_node_flush(struct ath_softc *sc, struct ath_node *an);
extern void ath_tx_txq_drain(struct ath_softc *sc, struct ath_txq *txq);
extern void ath_txfrag_cleanup(struct ath_softc *sc, ath_bufhead *frags,
    struct ieee80211_node *ni);
extern int ath_txfrag_setup(struct ath_softc *sc, ath_bufhead *frags,
    struct mbuf *m0, struct ieee80211_node *ni);
extern int ath_tx_start(struct ath_softc *sc, struct ieee80211_node *ni,
    struct ath_buf *bf, struct mbuf *m0);
extern int ath_raw_xmit(struct ieee80211_node *ni, struct mbuf *m,
    const struct ieee80211_bpf_params *params);

/* software queue stuff */
extern void ath_tx_swq(struct ath_softc *sc, struct ieee80211_node *ni,
    struct ath_txq *txq, struct ath_buf *bf);
extern void ath_tx_tid_init(struct ath_softc *sc, struct ath_node *an);
extern void ath_tx_tid_hw_queue_aggr(struct ath_softc *sc, struct ath_node *an,
    struct ath_tid *tid);
extern void ath_tx_tid_hw_queue_norm(struct ath_softc *sc, struct ath_node *an,
    struct ath_tid *tid);
extern void ath_txq_sched(struct ath_softc *sc, struct ath_txq *txq);
extern void ath_tx_normal_comp(struct ath_softc *sc, struct ath_buf *bf,
    int fail);
extern void ath_tx_aggr_comp(struct ath_softc *sc, struct ath_buf *bf,
    int fail);
extern void ath_tx_addto_baw(struct ath_softc *sc, struct ath_node *an,
    struct ath_tid *tid, struct ath_buf *bf);
extern struct ieee80211_tx_ampdu * ath_tx_get_tx_tid(struct ath_node *an,
    int tid);

/* TX addba handling */
extern	int ath_addba_request(struct ieee80211_node *ni,
    struct ieee80211_tx_ampdu *tap, int dialogtoken,
    int baparamset, int batimeout);
extern	int ath_addba_response(struct ieee80211_node *ni,
    struct ieee80211_tx_ampdu *tap, int dialogtoken,
    int code, int batimeout);
extern	void ath_addba_stop(struct ieee80211_node *ni,
    struct ieee80211_tx_ampdu *tap);
extern	void ath_bar_response(struct ieee80211_node *ni,
     struct ieee80211_tx_ampdu *tap, int status);
extern	void ath_addba_response_timeout(struct ieee80211_node *ni,
    struct ieee80211_tx_ampdu *tap);

/*
 * AP mode power save handling (of stations)
 */
extern	void ath_tx_node_sleep(struct ath_softc *sc, struct ath_node *an);
extern	void ath_tx_node_wakeup(struct ath_softc *sc, struct ath_node *an);
extern	int ath_tx_node_is_asleep(struct ath_softc *sc, struct ath_node *an);
extern	void ath_tx_node_reassoc(struct ath_softc *sc, struct ath_node *an);

/*
 * Misc debugging stuff
 */
#ifdef	ATH_DEBUG_ALQ
extern	void ath_tx_alq_post(struct ath_softc *sc, struct ath_buf *bf_first);
#endif	/* ATH_DEBUG_ALQ */

/*
 * Setup path
 */
#define	ath_txdma_setup(_sc)			\
	(_sc)->sc_tx.xmit_setup(_sc)
#define	ath_txdma_teardown(_sc)			\
	(_sc)->sc_tx.xmit_teardown(_sc)
#define	ath_txq_restart_dma(_sc, _txq)		\
	(_sc)->sc_tx.xmit_dma_restart((_sc), (_txq))
#define	ath_tx_handoff(_sc, _txq, _bf)		\
	(_sc)->sc_tx.xmit_handoff((_sc), (_txq), (_bf))
#define	ath_draintxq(_sc, _rtype)		\
	(_sc)->sc_tx.xmit_drain((_sc), (_rtype))

extern	void ath_xmit_setup_legacy(struct ath_softc *sc);

#endif
OpenPOWER on IntegriCloud