|
@@ -33,6 +33,7 @@
|
|
|
#define SD8787_DEFAULT_FW_NAME "mrvl/sd8787_uapsta.bin"
|
|
|
#define SD8797_DEFAULT_FW_NAME "mrvl/sd8797_uapsta.bin"
|
|
|
#define SD8897_DEFAULT_FW_NAME "mrvl/sd8897_uapsta.bin"
|
|
|
+#define SD8887_DEFAULT_FW_NAME "mrvl/sd8887_uapsta.bin"
|
|
|
|
|
|
#define BLOCK_MODE 1
|
|
|
#define BYTE_MODE 0
|
|
@@ -334,6 +335,47 @@ static const struct mwifiex_sdio_card_reg mwifiex_reg_sd8897 = {
|
|
|
.fw_dump_end = 0xea,
|
|
|
};
|
|
|
|
|
|
+static const struct mwifiex_sdio_card_reg mwifiex_reg_sd8887 = {
|
|
|
+ .start_rd_port = 0,
|
|
|
+ .start_wr_port = 0,
|
|
|
+ .base_0_reg = 0x6C,
|
|
|
+ .base_1_reg = 0x6D,
|
|
|
+ .poll_reg = 0x5C,
|
|
|
+ .host_int_enable = UP_LD_HOST_INT_MASK | DN_LD_HOST_INT_MASK |
|
|
|
+ CMD_PORT_UPLD_INT_MASK | CMD_PORT_DNLD_INT_MASK,
|
|
|
+ .host_int_rsr_reg = 0x4,
|
|
|
+ .host_int_status_reg = 0x0C,
|
|
|
+ .host_int_mask_reg = 0x08,
|
|
|
+ .status_reg_0 = 0x90,
|
|
|
+ .status_reg_1 = 0x91,
|
|
|
+ .sdio_int_mask = 0xff,
|
|
|
+ .data_port_mask = 0xffffffff,
|
|
|
+ .io_port_0_reg = 0xE4,
|
|
|
+ .io_port_1_reg = 0xE5,
|
|
|
+ .io_port_2_reg = 0xE6,
|
|
|
+ .max_mp_regs = 196,
|
|
|
+ .rd_bitmap_l = 0x10,
|
|
|
+ .rd_bitmap_u = 0x11,
|
|
|
+ .rd_bitmap_1l = 0x12,
|
|
|
+ .rd_bitmap_1u = 0x13,
|
|
|
+ .wr_bitmap_l = 0x14,
|
|
|
+ .wr_bitmap_u = 0x15,
|
|
|
+ .wr_bitmap_1l = 0x16,
|
|
|
+ .wr_bitmap_1u = 0x17,
|
|
|
+ .rd_len_p0_l = 0x18,
|
|
|
+ .rd_len_p0_u = 0x19,
|
|
|
+ .card_misc_cfg_reg = 0xd8,
|
|
|
+ .card_cfg_2_1_reg = 0xd9,
|
|
|
+ .cmd_rd_len_0 = 0xc0,
|
|
|
+ .cmd_rd_len_1 = 0xc1,
|
|
|
+ .cmd_rd_len_2 = 0xc2,
|
|
|
+ .cmd_rd_len_3 = 0xc3,
|
|
|
+ .cmd_cfg_0 = 0xc4,
|
|
|
+ .cmd_cfg_1 = 0xc5,
|
|
|
+ .cmd_cfg_2 = 0xc6,
|
|
|
+ .cmd_cfg_3 = 0xc7,
|
|
|
+};
|
|
|
+
|
|
|
static const struct mwifiex_sdio_device mwifiex_sdio_sd8786 = {
|
|
|
.firmware = SD8786_DEFAULT_FW_NAME,
|
|
|
.reg = &mwifiex_reg_sd87xx,
|
|
@@ -386,6 +428,19 @@ static const struct mwifiex_sdio_device mwifiex_sdio_sd8897 = {
|
|
|
.supports_fw_dump = true,
|
|
|
};
|
|
|
|
|
|
+static const struct mwifiex_sdio_device mwifiex_sdio_sd8887 = {
|
|
|
+ .firmware = SD8887_DEFAULT_FW_NAME,
|
|
|
+ .reg = &mwifiex_reg_sd8887,
|
|
|
+ .max_ports = 32,
|
|
|
+ .mp_agg_pkt_limit = 16,
|
|
|
+ .supports_sdio_new_mode = true,
|
|
|
+ .has_control_mask = false,
|
|
|
+ .tx_buf_size = MWIFIEX_TX_DATA_BUF_SIZE_4K,
|
|
|
+ .mp_tx_agg_buf_size = MWIFIEX_MP_AGGR_BUF_SIZE_32K,
|
|
|
+ .mp_rx_agg_buf_size = MWIFIEX_MP_AGGR_BUF_SIZE_32K,
|
|
|
+ .supports_fw_dump = false,
|
|
|
+};
|
|
|
+
|
|
|
/*
|
|
|
* .cmdrsp_complete handler
|
|
|
*/
|