mirror of https://gitee.com/openkylin/linux.git
rt2x00: Remove ieee80211_tx_control argument from write_tx_desc()
Move the last remaining information details read from ieee80211_tx_control in the drivers to the txentry_desc structure. After this we can remove ieee80211_tx_control from the argument list for the callback function, which makes it easier when the control information is moved into skb->cb Signed-off-by: Ivo van Doorn <IvDoorn@gmail.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
parent
fb55f4d1fa
commit
61486e0f68
|
@ -1001,8 +1001,7 @@ static int rt2400pci_set_device_state(struct rt2x00_dev *rt2x00dev,
|
||||||
*/
|
*/
|
||||||
static void rt2400pci_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
static void rt2400pci_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
||||||
struct sk_buff *skb,
|
struct sk_buff *skb,
|
||||||
struct txentry_desc *txdesc,
|
struct txentry_desc *txdesc)
|
||||||
struct ieee80211_tx_control *control)
|
|
||||||
{
|
{
|
||||||
struct skb_frame_desc *skbdesc = get_skb_frame_desc(skb);
|
struct skb_frame_desc *skbdesc = get_skb_frame_desc(skb);
|
||||||
__le32 *txd = skbdesc->desc;
|
__le32 *txd = skbdesc->desc;
|
||||||
|
@ -1046,8 +1045,7 @@ static void rt2400pci_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
||||||
test_bit(ENTRY_TXD_RTS_FRAME, &txdesc->flags));
|
test_bit(ENTRY_TXD_RTS_FRAME, &txdesc->flags));
|
||||||
rt2x00_set_field32(&word, TXD_W0_IFS, txdesc->ifs);
|
rt2x00_set_field32(&word, TXD_W0_IFS, txdesc->ifs);
|
||||||
rt2x00_set_field32(&word, TXD_W0_RETRY_MODE,
|
rt2x00_set_field32(&word, TXD_W0_RETRY_MODE,
|
||||||
!!(control->flags &
|
+ test_bit(ENTRY_TXD_RETRY_MODE, &txdesc->flags));
|
||||||
IEEE80211_TXCTL_LONG_RETRY_LIMIT));
|
|
||||||
rt2x00_desc_write(txd, 0, word);
|
rt2x00_desc_write(txd, 0, word);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1155,8 +1155,7 @@ static int rt2500pci_set_device_state(struct rt2x00_dev *rt2x00dev,
|
||||||
*/
|
*/
|
||||||
static void rt2500pci_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
static void rt2500pci_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
||||||
struct sk_buff *skb,
|
struct sk_buff *skb,
|
||||||
struct txentry_desc *txdesc,
|
struct txentry_desc *txdesc)
|
||||||
struct ieee80211_tx_control *control)
|
|
||||||
{
|
{
|
||||||
struct skb_frame_desc *skbdesc = get_skb_frame_desc(skb);
|
struct skb_frame_desc *skbdesc = get_skb_frame_desc(skb);
|
||||||
__le32 *txd = skbdesc->desc;
|
__le32 *txd = skbdesc->desc;
|
||||||
|
@ -1198,9 +1197,7 @@ static void rt2500pci_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
||||||
rt2x00_set_field32(&word, TXD_W0_CIPHER_OWNER, 1);
|
rt2x00_set_field32(&word, TXD_W0_CIPHER_OWNER, 1);
|
||||||
rt2x00_set_field32(&word, TXD_W0_IFS, txdesc->ifs);
|
rt2x00_set_field32(&word, TXD_W0_IFS, txdesc->ifs);
|
||||||
rt2x00_set_field32(&word, TXD_W0_RETRY_MODE,
|
rt2x00_set_field32(&word, TXD_W0_RETRY_MODE,
|
||||||
!!(control->flags &
|
test_bit(ENTRY_TXD_RETRY_MODE, &txdesc->flags));
|
||||||
IEEE80211_TXCTL_LONG_RETRY_LIMIT));
|
|
||||||
rt2x00_set_field32(&word, TXD_W0_DATABYTE_COUNT, skbdesc->data_len);
|
|
||||||
rt2x00_set_field32(&word, TXD_W0_CIPHER_ALG, CIPHER_NONE);
|
rt2x00_set_field32(&word, TXD_W0_CIPHER_ALG, CIPHER_NONE);
|
||||||
rt2x00_desc_write(txd, 0, word);
|
rt2x00_desc_write(txd, 0, word);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1033,8 +1033,7 @@ static int rt2500usb_set_device_state(struct rt2x00_dev *rt2x00dev,
|
||||||
*/
|
*/
|
||||||
static void rt2500usb_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
static void rt2500usb_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
||||||
struct sk_buff *skb,
|
struct sk_buff *skb,
|
||||||
struct txentry_desc *txdesc,
|
struct txentry_desc *txdesc)
|
||||||
struct ieee80211_tx_control *control)
|
|
||||||
{
|
{
|
||||||
struct skb_frame_desc *skbdesc = get_skb_frame_desc(skb);
|
struct skb_frame_desc *skbdesc = get_skb_frame_desc(skb);
|
||||||
__le32 *txd = skbdesc->desc;
|
__le32 *txd = skbdesc->desc;
|
||||||
|
@ -1058,7 +1057,7 @@ static void rt2500usb_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
||||||
rt2x00_desc_write(txd, 2, word);
|
rt2x00_desc_write(txd, 2, word);
|
||||||
|
|
||||||
rt2x00_desc_read(txd, 0, &word);
|
rt2x00_desc_read(txd, 0, &word);
|
||||||
rt2x00_set_field32(&word, TXD_W0_RETRY_LIMIT, control->retry_limit);
|
rt2x00_set_field32(&word, TXD_W0_RETRY_LIMIT, txdesc->retry_limit);
|
||||||
rt2x00_set_field32(&word, TXD_W0_MORE_FRAG,
|
rt2x00_set_field32(&word, TXD_W0_MORE_FRAG,
|
||||||
test_bit(ENTRY_TXD_MORE_FRAG, &txdesc->flags));
|
test_bit(ENTRY_TXD_MORE_FRAG, &txdesc->flags));
|
||||||
rt2x00_set_field32(&word, TXD_W0_ACK,
|
rt2x00_set_field32(&word, TXD_W0_ACK,
|
||||||
|
@ -1068,7 +1067,7 @@ static void rt2500usb_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
||||||
rt2x00_set_field32(&word, TXD_W0_OFDM,
|
rt2x00_set_field32(&word, TXD_W0_OFDM,
|
||||||
test_bit(ENTRY_TXD_OFDM_RATE, &txdesc->flags));
|
test_bit(ENTRY_TXD_OFDM_RATE, &txdesc->flags));
|
||||||
rt2x00_set_field32(&word, TXD_W0_NEW_SEQ,
|
rt2x00_set_field32(&word, TXD_W0_NEW_SEQ,
|
||||||
!!(control->flags & IEEE80211_TXCTL_FIRST_FRAGMENT));
|
test_bit(ENTRY_TXD_FIRST_FRAGMENT, &txdesc->flags));
|
||||||
rt2x00_set_field32(&word, TXD_W0_IFS, txdesc->ifs);
|
rt2x00_set_field32(&word, TXD_W0_IFS, txdesc->ifs);
|
||||||
rt2x00_set_field32(&word, TXD_W0_DATABYTE_COUNT, skbdesc->data_len);
|
rt2x00_set_field32(&word, TXD_W0_DATABYTE_COUNT, skbdesc->data_len);
|
||||||
rt2x00_set_field32(&word, TXD_W0_CIPHER, CIPHER_NONE);
|
rt2x00_set_field32(&word, TXD_W0_CIPHER, CIPHER_NONE);
|
||||||
|
|
|
@ -540,8 +540,7 @@ struct rt2x00lib_ops {
|
||||||
*/
|
*/
|
||||||
void (*write_tx_desc) (struct rt2x00_dev *rt2x00dev,
|
void (*write_tx_desc) (struct rt2x00_dev *rt2x00dev,
|
||||||
struct sk_buff *skb,
|
struct sk_buff *skb,
|
||||||
struct txentry_desc *txdesc,
|
struct txentry_desc *txdesc);
|
||||||
struct ieee80211_tx_control *control);
|
|
||||||
int (*write_tx_data) (struct rt2x00_dev *rt2x00dev,
|
int (*write_tx_data) (struct rt2x00_dev *rt2x00dev,
|
||||||
struct data_queue *queue, struct sk_buff *skb,
|
struct data_queue *queue, struct sk_buff *skb,
|
||||||
struct ieee80211_tx_control *control);
|
struct ieee80211_tx_control *control);
|
||||||
|
|
|
@ -664,7 +664,12 @@ void rt2x00lib_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
||||||
tx_rate = control->rts_cts_rate->hw_value;
|
tx_rate = control->rts_cts_rate->hw_value;
|
||||||
}
|
}
|
||||||
|
|
||||||
rate = rt2x00_get_rate(tx_rate);
|
/*
|
||||||
|
* Determine retry information.
|
||||||
|
*/
|
||||||
|
txdesc.retry_limit = control->retry_limit;
|
||||||
|
if (control->flags & IEEE80211_TXCTL_LONG_RETRY_LIMIT)
|
||||||
|
__set_bit(ENTRY_TXD_RETRY_MODE, &txdesc.flags);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Check if more fragments are pending
|
* Check if more fragments are pending
|
||||||
|
@ -686,16 +691,20 @@ void rt2x00lib_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
||||||
* Set ifs to IFS_SIFS when the this is not the first fragment,
|
* Set ifs to IFS_SIFS when the this is not the first fragment,
|
||||||
* or this fragment came after RTS/CTS.
|
* or this fragment came after RTS/CTS.
|
||||||
*/
|
*/
|
||||||
if ((seq_ctrl & IEEE80211_SCTL_FRAG) > 0 ||
|
if (test_bit(ENTRY_TXD_RTS_FRAME, &txdesc.flags)) {
|
||||||
test_bit(ENTRY_TXD_RTS_FRAME, &txdesc.flags))
|
|
||||||
txdesc.ifs = IFS_SIFS;
|
txdesc.ifs = IFS_SIFS;
|
||||||
else
|
} else if (control->flags & IEEE80211_TXCTL_FIRST_FRAGMENT) {
|
||||||
|
__set_bit(ENTRY_TXD_FIRST_FRAGMENT, &txdesc.flags);
|
||||||
txdesc.ifs = IFS_BACKOFF;
|
txdesc.ifs = IFS_BACKOFF;
|
||||||
|
} else {
|
||||||
|
txdesc.ifs = IFS_SIFS;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* PLCP setup
|
* PLCP setup
|
||||||
* Length calculation depends on OFDM/CCK rate.
|
* Length calculation depends on OFDM/CCK rate.
|
||||||
*/
|
*/
|
||||||
|
rate = rt2x00_get_rate(tx_rate);
|
||||||
txdesc.signal = rate->plcp;
|
txdesc.signal = rate->plcp;
|
||||||
txdesc.service = 0x04;
|
txdesc.service = 0x04;
|
||||||
|
|
||||||
|
@ -733,7 +742,7 @@ void rt2x00lib_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
||||||
txdesc.signal |= 0x08;
|
txdesc.signal |= 0x08;
|
||||||
}
|
}
|
||||||
|
|
||||||
rt2x00dev->ops->lib->write_tx_desc(rt2x00dev, skb, &txdesc, control);
|
rt2x00dev->ops->lib->write_tx_desc(rt2x00dev, skb, &txdesc);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Update queue entry.
|
* Update queue entry.
|
||||||
|
|
|
@ -204,18 +204,22 @@ struct txdone_entry_desc {
|
||||||
*
|
*
|
||||||
* @ENTRY_TXD_RTS_FRAME: This frame is a RTS frame.
|
* @ENTRY_TXD_RTS_FRAME: This frame is a RTS frame.
|
||||||
* @ENTRY_TXD_OFDM_RATE: This frame is send out with an OFDM rate.
|
* @ENTRY_TXD_OFDM_RATE: This frame is send out with an OFDM rate.
|
||||||
|
* @ENTRY_TXD_FIRST_FRAGMENT: This is the first frame.
|
||||||
* @ENTRY_TXD_MORE_FRAG: This frame is followed by another fragment.
|
* @ENTRY_TXD_MORE_FRAG: This frame is followed by another fragment.
|
||||||
* @ENTRY_TXD_REQ_TIMESTAMP: Require timestamp to be inserted.
|
* @ENTRY_TXD_REQ_TIMESTAMP: Require timestamp to be inserted.
|
||||||
* @ENTRY_TXD_BURST: This frame belongs to the same burst event.
|
* @ENTRY_TXD_BURST: This frame belongs to the same burst event.
|
||||||
* @ENTRY_TXD_ACK: An ACK is required for this frame.
|
* @ENTRY_TXD_ACK: An ACK is required for this frame.
|
||||||
|
* @ENTRY_TXD_RETRY_MODE: When set, the long retry count is used.
|
||||||
*/
|
*/
|
||||||
enum txentry_desc_flags {
|
enum txentry_desc_flags {
|
||||||
ENTRY_TXD_RTS_FRAME,
|
ENTRY_TXD_RTS_FRAME,
|
||||||
ENTRY_TXD_OFDM_RATE,
|
ENTRY_TXD_OFDM_RATE,
|
||||||
|
ENTRY_TXD_FIRST_FRAGMENT,
|
||||||
ENTRY_TXD_MORE_FRAG,
|
ENTRY_TXD_MORE_FRAG,
|
||||||
ENTRY_TXD_REQ_TIMESTAMP,
|
ENTRY_TXD_REQ_TIMESTAMP,
|
||||||
ENTRY_TXD_BURST,
|
ENTRY_TXD_BURST,
|
||||||
ENTRY_TXD_ACK,
|
ENTRY_TXD_ACK,
|
||||||
|
ENTRY_TXD_RETRY_MODE,
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -229,6 +233,7 @@ enum txentry_desc_flags {
|
||||||
* @length_low: PLCP length low word.
|
* @length_low: PLCP length low word.
|
||||||
* @signal: PLCP signal.
|
* @signal: PLCP signal.
|
||||||
* @service: PLCP service.
|
* @service: PLCP service.
|
||||||
|
* @retry_limit: Max number of retries.
|
||||||
* @aifs: AIFS value.
|
* @aifs: AIFS value.
|
||||||
* @ifs: IFS value.
|
* @ifs: IFS value.
|
||||||
* @cw_min: cwmin value.
|
* @cw_min: cwmin value.
|
||||||
|
@ -244,10 +249,11 @@ struct txentry_desc {
|
||||||
u16 signal;
|
u16 signal;
|
||||||
u16 service;
|
u16 service;
|
||||||
|
|
||||||
int aifs;
|
short retry_limit;
|
||||||
int ifs;
|
short aifs;
|
||||||
int cw_min;
|
short ifs;
|
||||||
int cw_max;
|
short cw_min;
|
||||||
|
short cw_max;
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -1526,8 +1526,7 @@ static int rt61pci_set_device_state(struct rt2x00_dev *rt2x00dev,
|
||||||
*/
|
*/
|
||||||
static void rt61pci_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
static void rt61pci_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
||||||
struct sk_buff *skb,
|
struct sk_buff *skb,
|
||||||
struct txentry_desc *txdesc,
|
struct txentry_desc *txdesc)
|
||||||
struct ieee80211_tx_control *control)
|
|
||||||
{
|
{
|
||||||
struct skb_frame_desc *skbdesc = get_skb_frame_desc(skb);
|
struct skb_frame_desc *skbdesc = get_skb_frame_desc(skb);
|
||||||
__le32 *txd = skbdesc->desc;
|
__le32 *txd = skbdesc->desc;
|
||||||
|
@ -1577,8 +1576,7 @@ static void rt61pci_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
||||||
test_bit(ENTRY_TXD_OFDM_RATE, &txdesc->flags));
|
test_bit(ENTRY_TXD_OFDM_RATE, &txdesc->flags));
|
||||||
rt2x00_set_field32(&word, TXD_W0_IFS, txdesc->ifs);
|
rt2x00_set_field32(&word, TXD_W0_IFS, txdesc->ifs);
|
||||||
rt2x00_set_field32(&word, TXD_W0_RETRY_MODE,
|
rt2x00_set_field32(&word, TXD_W0_RETRY_MODE,
|
||||||
!!(control->flags &
|
test_bit(ENTRY_TXD_RETRY_MODE, &txdesc->flags));
|
||||||
IEEE80211_TXCTL_LONG_RETRY_LIMIT));
|
|
||||||
rt2x00_set_field32(&word, TXD_W0_TKIP_MIC, 0);
|
rt2x00_set_field32(&word, TXD_W0_TKIP_MIC, 0);
|
||||||
rt2x00_set_field32(&word, TXD_W0_DATABYTE_COUNT, skbdesc->data_len);
|
rt2x00_set_field32(&word, TXD_W0_DATABYTE_COUNT, skbdesc->data_len);
|
||||||
rt2x00_set_field32(&word, TXD_W0_BURST,
|
rt2x00_set_field32(&word, TXD_W0_BURST,
|
||||||
|
|
|
@ -1255,8 +1255,7 @@ static int rt73usb_set_device_state(struct rt2x00_dev *rt2x00dev,
|
||||||
*/
|
*/
|
||||||
static void rt73usb_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
static void rt73usb_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
||||||
struct sk_buff *skb,
|
struct sk_buff *skb,
|
||||||
struct txentry_desc *txdesc,
|
struct txentry_desc *txdesc)
|
||||||
struct ieee80211_tx_control *control)
|
|
||||||
{
|
{
|
||||||
struct skb_frame_desc *skbdesc = get_skb_frame_desc(skb);
|
struct skb_frame_desc *skbdesc = get_skb_frame_desc(skb);
|
||||||
__le32 *txd = skbdesc->desc;
|
__le32 *txd = skbdesc->desc;
|
||||||
|
@ -1301,8 +1300,7 @@ static void rt73usb_write_tx_desc(struct rt2x00_dev *rt2x00dev,
|
||||||
test_bit(ENTRY_TXD_OFDM_RATE, &txdesc->flags));
|
test_bit(ENTRY_TXD_OFDM_RATE, &txdesc->flags));
|
||||||
rt2x00_set_field32(&word, TXD_W0_IFS, txdesc->ifs);
|
rt2x00_set_field32(&word, TXD_W0_IFS, txdesc->ifs);
|
||||||
rt2x00_set_field32(&word, TXD_W0_RETRY_MODE,
|
rt2x00_set_field32(&word, TXD_W0_RETRY_MODE,
|
||||||
!!(control->flags &
|
test_bit(ENTRY_TXD_RETRY_MODE, &txdesc->flags));
|
||||||
IEEE80211_TXCTL_LONG_RETRY_LIMIT));
|
|
||||||
rt2x00_set_field32(&word, TXD_W0_TKIP_MIC, 0);
|
rt2x00_set_field32(&word, TXD_W0_TKIP_MIC, 0);
|
||||||
rt2x00_set_field32(&word, TXD_W0_DATABYTE_COUNT, skbdesc->data_len);
|
rt2x00_set_field32(&word, TXD_W0_DATABYTE_COUNT, skbdesc->data_len);
|
||||||
rt2x00_set_field32(&word, TXD_W0_BURST2,
|
rt2x00_set_field32(&word, TXD_W0_BURST2,
|
||||||
|
|
Loading…
Reference in New Issue