diff options
author | Avinash Patil <patila@marvell.com> | 2014-10-01 13:55:26 -0400 |
---|---|---|
committer | John W. Linville <linville@tuxdriver.com> | 2014-10-02 14:23:15 -0400 |
commit | 030bb75a1db4030a5ce91e93b82e00966e8b6522 (patch) | |
tree | 46faf20bf4a78eeb0761b4926f35663aa5348642 | |
parent | 554a0113ccb149e3d04ceb608114a3425c507f00 (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/Kconfig | 4 | ||||
-rw-r--r-- | drivers/net/wireless/mwifiex/sdio.c | 5 | ||||
-rw-r--r-- | drivers/net/wireless/mwifiex/sdio.h | 55 |
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 | ||
11 | config MWIFIEX_SDIO | 11 | config 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 */ |
284 | static const struct sdio_device_id mwifiex_ids[] = { | 286 | static 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); | |||
2233 | MODULE_FIRMWARE(SD8787_DEFAULT_FW_NAME); | 2237 | MODULE_FIRMWARE(SD8787_DEFAULT_FW_NAME); |
2234 | MODULE_FIRMWARE(SD8797_DEFAULT_FW_NAME); | 2238 | MODULE_FIRMWARE(SD8797_DEFAULT_FW_NAME); |
2235 | MODULE_FIRMWARE(SD8897_DEFAULT_FW_NAME); | 2239 | MODULE_FIRMWARE(SD8897_DEFAULT_FW_NAME); |
2240 | MODULE_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 | ||
338 | static 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 | |||
337 | static const struct mwifiex_sdio_device mwifiex_sdio_sd8786 = { | 379 | static 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 | ||
431 | static 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 | */ |