aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/wireless
diff options
context:
space:
mode:
authorArik Nemtsov <arik@wizery.com>2011-03-18 08:49:57 -0400
committerLuciano Coelho <coelho@ti.com>2011-04-19 09:49:07 -0400
commit1d732e8cf3dcc09d7c862b6c12f876533529073d (patch)
tree96f0eaecc8d44dbab04a81ab1a931889b21db3d4 /drivers/net/wireless
parent958b20e068be2c6267c2b5764babf15b0d4f5c69 (diff)
wl12xx: Clamp byte mode transfers for 128x chips
On wl128x based devices, when TX packets are aggregated, each packet size must be aligned to the SDIO block size, and sent using block mode transfers. The block size is set to 256 bytes, which is less than the maximum possible byte transfer. Thus, if two small packets (< 256 bytes) are aggregated, the aggregation buffer size would be 512, and will be sent using byte mode transfers. This can have undesired side effects. Fix this by setting the MMC_QUIRK_BLKSZ_FOR_BYTE_MODE mmc card quirk. For 127x chips this has no effect, as the block size is set to 512 bytes. Signed-off-by: Arik Nemtsov <arik@wizery.com> Signed-off-by: Ido Yariv <ido@wizery.com> Signed-off-by: Luciano Coelho <coelho@ti.com>
Diffstat (limited to 'drivers/net/wireless')
-rw-r--r--drivers/net/wireless/wl12xx/sdio.c3
-rw-r--r--drivers/net/wireless/wl12xx/sdio_test.c3
2 files changed, 6 insertions, 0 deletions
diff --git a/drivers/net/wireless/wl12xx/sdio.c b/drivers/net/wireless/wl12xx/sdio.c
index 5a2951ed6eda..2ade222f7cbb 100644
--- a/drivers/net/wireless/wl12xx/sdio.c
+++ b/drivers/net/wireless/wl12xx/sdio.c
@@ -246,6 +246,9 @@ static int __devinit wl1271_probe(struct sdio_func *func,
246 /* Grab access to FN0 for ELP reg. */ 246 /* Grab access to FN0 for ELP reg. */
247 func->card->quirks |= MMC_QUIRK_LENIENT_FN0; 247 func->card->quirks |= MMC_QUIRK_LENIENT_FN0;
248 248
249 /* Use block mode for transferring over one block size of data */
250 func->card->quirks |= MMC_QUIRK_BLKSZ_FOR_BYTE_MODE;
251
249 wlan_data = wl12xx_get_platform_data(); 252 wlan_data = wl12xx_get_platform_data();
250 if (IS_ERR(wlan_data)) { 253 if (IS_ERR(wlan_data)) {
251 ret = PTR_ERR(wlan_data); 254 ret = PTR_ERR(wlan_data);
diff --git a/drivers/net/wireless/wl12xx/sdio_test.c b/drivers/net/wireless/wl12xx/sdio_test.c
index 968249a4da39..f28915392877 100644
--- a/drivers/net/wireless/wl12xx/sdio_test.c
+++ b/drivers/net/wireless/wl12xx/sdio_test.c
@@ -417,6 +417,9 @@ static int __devinit wl1271_probe(struct sdio_func *func,
417 /* Grab access to FN0 for ELP reg. */ 417 /* Grab access to FN0 for ELP reg. */
418 func->card->quirks |= MMC_QUIRK_LENIENT_FN0; 418 func->card->quirks |= MMC_QUIRK_LENIENT_FN0;
419 419
420 /* Use block mode for transferring over one block size of data */
421 func->card->quirks |= MMC_QUIRK_BLKSZ_FOR_BYTE_MODE;
422
420 wlan_data = wl12xx_get_platform_data(); 423 wlan_data = wl12xx_get_platform_data();
421 if (IS_ERR(wlan_data)) { 424 if (IS_ERR(wlan_data)) {
422 ret = PTR_ERR(wlan_data); 425 ret = PTR_ERR(wlan_data);