aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAvinash Patil <patila@marvell.com>2014-10-01 13:55:26 -0400
committerJohn W. Linville <linville@tuxdriver.com>2014-10-02 14:23:15 -0400
commit030bb75a1db4030a5ce91e93b82e00966e8b6522 (patch)
tree46faf20bf4a78eeb0761b4926f35663aa5348642
parent554a0113ccb149e3d04ceb608114a3425c507f00 (diff)
mwifiex: add support for SD8887 chipset
This patch adds SD8887 support to mwifiex. SD8887 is Marvell's 1x1 11ac solution. The corresponding firmware image file is located at: "mrvl/sd8887_uapsta.bin" Signed-off-by: Avinash Patil <patila@marvell.com> Signed-off-by: Cathy Luo <cluo@marvell.com> Signed-off-by: Frank Huang <frankh@marvell.com> Signed-off-by: Nishant Sarmukadam <nishants@marvell.com> Signed-off-by: Amitkumar Karwar <akarwar@marvell.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
-rw-r--r--drivers/net/wireless/mwifiex/Kconfig4
-rw-r--r--drivers/net/wireless/mwifiex/sdio.c5
-rw-r--r--drivers/net/wireless/mwifiex/sdio.h55
3 files changed, 62 insertions, 2 deletions
diff --git a/drivers/net/wireless/mwifiex/Kconfig b/drivers/net/wireless/mwifiex/Kconfig
index ecdf34505b54..e70d0df9b0da 100644
--- a/drivers/net/wireless/mwifiex/Kconfig
+++ b/drivers/net/wireless/mwifiex/Kconfig
@@ -9,12 +9,12 @@ config MWIFIEX
9 mwifiex. 9 mwifiex.
10 10
11config MWIFIEX_SDIO 11config MWIFIEX_SDIO
12 tristate "Marvell WiFi-Ex Driver for SD8786/SD8787/SD8797/SD8897" 12 tristate "Marvell WiFi-Ex Driver for SD8786/SD8787/SD8797/SD8887/SD8897"
13 depends on MWIFIEX && MMC 13 depends on MWIFIEX && MMC
14 select FW_LOADER 14 select FW_LOADER
15 ---help--- 15 ---help---
16 This adds support for wireless adapters based on Marvell 16 This adds support for wireless adapters based on Marvell
17 8786/8787/8797 chipsets with SDIO interface. 17 8786/8787/8797/8887/8897 chipsets with SDIO interface.
18 18
19 If you choose to build it as a module, it will be called 19 If you choose to build it as a module, it will be called
20 mwifiex_sdio. 20 mwifiex_sdio.
diff --git a/drivers/net/wireless/mwifiex/sdio.c b/drivers/net/wireless/mwifiex/sdio.c
index a22e9a91f2f2..b25766b43b9f 100644
--- a/drivers/net/wireless/mwifiex/sdio.c
+++ b/drivers/net/wireless/mwifiex/sdio.c
@@ -279,6 +279,8 @@ static int mwifiex_sdio_suspend(struct device *dev)
279#define SDIO_DEVICE_ID_MARVELL_8797 (0x9129) 279#define SDIO_DEVICE_ID_MARVELL_8797 (0x9129)
280/* Device ID for SD8897 */ 280/* Device ID for SD8897 */
281#define SDIO_DEVICE_ID_MARVELL_8897 (0x912d) 281#define SDIO_DEVICE_ID_MARVELL_8897 (0x912d)
282/* Device ID for SD8887 */
283#define SDIO_DEVICE_ID_MARVELL_8887 (0x9135)
282 284
283/* WLAN IDs */ 285/* WLAN IDs */
284static const struct sdio_device_id mwifiex_ids[] = { 286static const struct sdio_device_id mwifiex_ids[] = {
@@ -290,6 +292,8 @@ static const struct sdio_device_id mwifiex_ids[] = {
290 .driver_data = (unsigned long) &mwifiex_sdio_sd8797}, 292 .driver_data = (unsigned long) &mwifiex_sdio_sd8797},
291 {SDIO_DEVICE(SDIO_VENDOR_ID_MARVELL, SDIO_DEVICE_ID_MARVELL_8897), 293 {SDIO_DEVICE(SDIO_VENDOR_ID_MARVELL, SDIO_DEVICE_ID_MARVELL_8897),
292 .driver_data = (unsigned long) &mwifiex_sdio_sd8897}, 294 .driver_data = (unsigned long) &mwifiex_sdio_sd8897},
295 {SDIO_DEVICE(SDIO_VENDOR_ID_MARVELL, SDIO_DEVICE_ID_MARVELL_8887),
296 .driver_data = (unsigned long)&mwifiex_sdio_sd8887},
293 {}, 297 {},
294}; 298};
295 299
@@ -2233,3 +2237,4 @@ MODULE_FIRMWARE(SD8786_DEFAULT_FW_NAME);
2233MODULE_FIRMWARE(SD8787_DEFAULT_FW_NAME); 2237MODULE_FIRMWARE(SD8787_DEFAULT_FW_NAME);
2234MODULE_FIRMWARE(SD8797_DEFAULT_FW_NAME); 2238MODULE_FIRMWARE(SD8797_DEFAULT_FW_NAME);
2235MODULE_FIRMWARE(SD8897_DEFAULT_FW_NAME); 2239MODULE_FIRMWARE(SD8897_DEFAULT_FW_NAME);
2240MODULE_FIRMWARE(SD8887_DEFAULT_FW_NAME);
diff --git a/drivers/net/wireless/mwifiex/sdio.h b/drivers/net/wireless/mwifiex/sdio.h
index 5a08ebc882e4..20cd9adc98d3 100644
--- a/drivers/net/wireless/mwifiex/sdio.h
+++ b/drivers/net/wireless/mwifiex/sdio.h
@@ -33,6 +33,7 @@
33#define SD8787_DEFAULT_FW_NAME "mrvl/sd8787_uapsta.bin" 33#define SD8787_DEFAULT_FW_NAME "mrvl/sd8787_uapsta.bin"
34#define SD8797_DEFAULT_FW_NAME "mrvl/sd8797_uapsta.bin" 34#define SD8797_DEFAULT_FW_NAME "mrvl/sd8797_uapsta.bin"
35#define SD8897_DEFAULT_FW_NAME "mrvl/sd8897_uapsta.bin" 35#define SD8897_DEFAULT_FW_NAME "mrvl/sd8897_uapsta.bin"
36#define SD8887_DEFAULT_FW_NAME "mrvl/sd8887_uapsta.bin"
36 37
37#define BLOCK_MODE 1 38#define BLOCK_MODE 1
38#define BYTE_MODE 0 39#define BYTE_MODE 0
@@ -334,6 +335,47 @@ static const struct mwifiex_sdio_card_reg mwifiex_reg_sd8897 = {
334 .fw_dump_end = 0xea, 335 .fw_dump_end = 0xea,
335}; 336};
336 337
338static const struct mwifiex_sdio_card_reg mwifiex_reg_sd8887 = {
339 .start_rd_port = 0,
340 .start_wr_port = 0,
341 .base_0_reg = 0x6C,
342 .base_1_reg = 0x6D,
343 .poll_reg = 0x5C,
344 .host_int_enable = UP_LD_HOST_INT_MASK | DN_LD_HOST_INT_MASK |
345 CMD_PORT_UPLD_INT_MASK | CMD_PORT_DNLD_INT_MASK,
346 .host_int_rsr_reg = 0x4,
347 .host_int_status_reg = 0x0C,
348 .host_int_mask_reg = 0x08,
349 .status_reg_0 = 0x90,
350 .status_reg_1 = 0x91,
351 .sdio_int_mask = 0xff,
352 .data_port_mask = 0xffffffff,
353 .io_port_0_reg = 0xE4,
354 .io_port_1_reg = 0xE5,
355 .io_port_2_reg = 0xE6,
356 .max_mp_regs = 196,
357 .rd_bitmap_l = 0x10,
358 .rd_bitmap_u = 0x11,
359 .rd_bitmap_1l = 0x12,
360 .rd_bitmap_1u = 0x13,
361 .wr_bitmap_l = 0x14,
362 .wr_bitmap_u = 0x15,
363 .wr_bitmap_1l = 0x16,
364 .wr_bitmap_1u = 0x17,
365 .rd_len_p0_l = 0x18,
366 .rd_len_p0_u = 0x19,
367 .card_misc_cfg_reg = 0xd8,
368 .card_cfg_2_1_reg = 0xd9,
369 .cmd_rd_len_0 = 0xc0,
370 .cmd_rd_len_1 = 0xc1,
371 .cmd_rd_len_2 = 0xc2,
372 .cmd_rd_len_3 = 0xc3,
373 .cmd_cfg_0 = 0xc4,
374 .cmd_cfg_1 = 0xc5,
375 .cmd_cfg_2 = 0xc6,
376 .cmd_cfg_3 = 0xc7,
377};
378
337static const struct mwifiex_sdio_device mwifiex_sdio_sd8786 = { 379static const struct mwifiex_sdio_device mwifiex_sdio_sd8786 = {
338 .firmware = SD8786_DEFAULT_FW_NAME, 380 .firmware = SD8786_DEFAULT_FW_NAME,
339 .reg = &mwifiex_reg_sd87xx, 381 .reg = &mwifiex_reg_sd87xx,
@@ -386,6 +428,19 @@ static const struct mwifiex_sdio_device mwifiex_sdio_sd8897 = {
386 .supports_fw_dump = true, 428 .supports_fw_dump = true,
387}; 429};
388 430
431static const struct mwifiex_sdio_device mwifiex_sdio_sd8887 = {
432 .firmware = SD8887_DEFAULT_FW_NAME,
433 .reg = &mwifiex_reg_sd8887,
434 .max_ports = 32,
435 .mp_agg_pkt_limit = 16,
436 .supports_sdio_new_mode = true,
437 .has_control_mask = false,
438 .tx_buf_size = MWIFIEX_TX_DATA_BUF_SIZE_4K,
439 .mp_tx_agg_buf_size = MWIFIEX_MP_AGGR_BUF_SIZE_32K,
440 .mp_rx_agg_buf_size = MWIFIEX_MP_AGGR_BUF_SIZE_32K,
441 .supports_fw_dump = false,
442};
443
389/* 444/*
390 * .cmdrsp_complete handler 445 * .cmdrsp_complete handler
391 */ 446 */