wl1271: Corrections to TX path
Corrections to the TX path - use correct number of maximum descriptors (32 instead of 16) and correct checking and setting of excessive retries on completion. Signed-off-by: Juuso Oikarinen <juuso.oikarinen@nokia.com> Reviewed-by: Luciano Coelho <luciano.coelho@nokia.com> Signed-off-by: Luciano Coelho <luciano.coelho@nokia.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
This commit is contained in:
Родитель
d94cd297e5
Коммит
be7078c21d
|
@ -123,6 +123,8 @@ enum {
|
||||||
#define WL1271_DEFAULT_BEACON_INT 100
|
#define WL1271_DEFAULT_BEACON_INT 100
|
||||||
#define WL1271_DEFAULT_DTIM_PERIOD 1
|
#define WL1271_DEFAULT_DTIM_PERIOD 1
|
||||||
|
|
||||||
|
#define ACX_TX_DESCRIPTORS 32
|
||||||
|
|
||||||
enum wl1271_state {
|
enum wl1271_state {
|
||||||
WL1271_STATE_OFF,
|
WL1271_STATE_OFF,
|
||||||
WL1271_STATE_ON,
|
WL1271_STATE_ON,
|
||||||
|
@ -346,7 +348,7 @@ struct wl1271 {
|
||||||
struct work_struct filter_work;
|
struct work_struct filter_work;
|
||||||
|
|
||||||
/* Pending TX frames */
|
/* Pending TX frames */
|
||||||
struct sk_buff *tx_frames[16];
|
struct sk_buff *tx_frames[ACX_TX_DESCRIPTORS];
|
||||||
|
|
||||||
/* Security sequence number counters */
|
/* Security sequence number counters */
|
||||||
u8 tx_security_last_seq;
|
u8 tx_security_last_seq;
|
||||||
|
|
|
@ -170,7 +170,6 @@ enum {
|
||||||
#define DP_RX_PACKET_RING_CHUNK_NUM 2
|
#define DP_RX_PACKET_RING_CHUNK_NUM 2
|
||||||
#define DP_TX_PACKET_RING_CHUNK_NUM 2
|
#define DP_TX_PACKET_RING_CHUNK_NUM 2
|
||||||
#define DP_TX_COMPLETE_TIME_OUT 20
|
#define DP_TX_COMPLETE_TIME_OUT 20
|
||||||
#define FW_TX_CMPLT_BLOCK_SIZE 16
|
|
||||||
|
|
||||||
#define TX_MSDU_LIFETIME_MIN 0
|
#define TX_MSDU_LIFETIME_MIN 0
|
||||||
#define TX_MSDU_LIFETIME_MAX 3000
|
#define TX_MSDU_LIFETIME_MAX 3000
|
||||||
|
|
|
@ -1293,9 +1293,7 @@ static int __devinit wl1271_probe(struct spi_device *spi)
|
||||||
wl->basic_rate_set = WL1271_DEFAULT_BASIC_RATE_SET;
|
wl->basic_rate_set = WL1271_DEFAULT_BASIC_RATE_SET;
|
||||||
wl->band = IEEE80211_BAND_2GHZ;
|
wl->band = IEEE80211_BAND_2GHZ;
|
||||||
|
|
||||||
/* We use the default power on sleep time until we know which chip
|
for (i = 0; i < ACX_TX_DESCRIPTORS; i++)
|
||||||
* we're using */
|
|
||||||
for (i = 0; i < FW_TX_CMPLT_BLOCK_SIZE; i++)
|
|
||||||
wl->tx_frames[i] = NULL;
|
wl->tx_frames[i] = NULL;
|
||||||
|
|
||||||
spin_lock_init(&wl->wl_lock);
|
spin_lock_init(&wl->wl_lock);
|
||||||
|
|
|
@ -33,8 +33,7 @@
|
||||||
static int wl1271_tx_id(struct wl1271 *wl, struct sk_buff *skb)
|
static int wl1271_tx_id(struct wl1271 *wl, struct sk_buff *skb)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
for (i = 0; i < ACX_TX_DESCRIPTORS; i++)
|
||||||
for (i = 0; i < FW_TX_CMPLT_BLOCK_SIZE; i++)
|
|
||||||
if (wl->tx_frames[i] == NULL) {
|
if (wl->tx_frames[i] == NULL) {
|
||||||
wl->tx_frames[i] = skb;
|
wl->tx_frames[i] = skb;
|
||||||
return i;
|
return i;
|
||||||
|
@ -262,14 +261,13 @@ out:
|
||||||
static void wl1271_tx_complete_packet(struct wl1271 *wl,
|
static void wl1271_tx_complete_packet(struct wl1271 *wl,
|
||||||
struct wl1271_tx_hw_res_descr *result)
|
struct wl1271_tx_hw_res_descr *result)
|
||||||
{
|
{
|
||||||
|
|
||||||
struct ieee80211_tx_info *info;
|
struct ieee80211_tx_info *info;
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
u16 seq;
|
u16 seq;
|
||||||
int id = result->id;
|
int id = result->id;
|
||||||
|
|
||||||
/* check for id legality */
|
/* check for id legality */
|
||||||
if (id >= TX_HW_RESULT_QUEUE_LEN || wl->tx_frames[id] == NULL) {
|
if (id >= ACX_TX_DESCRIPTORS || wl->tx_frames[id] == NULL) {
|
||||||
wl1271_warning("TX result illegal id: %d", id);
|
wl1271_warning("TX result illegal id: %d", id);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -382,7 +380,7 @@ void wl1271_tx_flush(struct wl1271 *wl)
|
||||||
ieee80211_tx_status(wl->hw, skb);
|
ieee80211_tx_status(wl->hw, skb);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i < FW_TX_CMPLT_BLOCK_SIZE; i++)
|
for (i = 0; i < ACX_TX_DESCRIPTORS; i++)
|
||||||
if (wl->tx_frames[i] != NULL) {
|
if (wl->tx_frames[i] != NULL) {
|
||||||
skb = wl->tx_frames[i];
|
skb = wl->tx_frames[i];
|
||||||
info = IEEE80211_SKB_CB(skb);
|
info = IEEE80211_SKB_CB(skb);
|
||||||
|
|
Загрузка…
Ссылка в новой задаче