2022-06-07 17:11:35 +03:00
/* SPDX-License-Identifier: GPL-2.0-only */
2009-06-03 01:29:36 +04:00
/**
* Marvell BT - over - SDIO driver : SDIO interface related definitions
*
* Copyright ( C ) 2009 , Marvell International Ltd .
* */
# define SDIO_HEADER_LEN 4
/* SD block size can not bigger than 64 due to buf size limit in firmware */
/* define SD block size for data Tx/Rx */
# define SDIO_BLOCK_SIZE 64
/* Number of blocks for firmware transfer */
# define FIRMWARE_TRANSFER_NBLOCK 2
/* This is for firmware specific length */
# define FW_EXTRA_LEN 36
# define MRVDRV_SIZE_OF_CMD_BUFFER (2 * 1024)
# define MRVDRV_BT_RX_PACKET_BUFFER_SIZE \
( HCI_MAX_FRAME_SIZE + FW_EXTRA_LEN )
# define ALLOC_BUF_SIZE (((max_t (int, MRVDRV_BT_RX_PACKET_BUFFER_SIZE, \
MRVDRV_SIZE_OF_CMD_BUFFER ) + SDIO_HEADER_LEN \
+ SDIO_BLOCK_SIZE - 1 ) / SDIO_BLOCK_SIZE ) \
* SDIO_BLOCK_SIZE )
/* The number of times to try when polling for status */
# define MAX_POLL_TRIES 100
/* Max retry number of CMD53 write */
# define MAX_WRITE_IOMEM_RETRY 2
2011-04-09 05:19:33 +04:00
/* register bitmasks */
# define HOST_POWER_UP BIT(1)
# define HOST_CMD53_FIN BIT(2)
# define HIM_DISABLE 0xff
# define HIM_ENABLE (BIT(0) | BIT(1))
# define UP_LD_HOST_INT_STATUS BIT(0)
# define DN_LD_HOST_INT_STATUS BIT(1)
# define DN_LD_CARD_RDY BIT(0)
# define CARD_IO_READY BIT(3)
# define FIRMWARE_READY 0xfedc
2016-04-26 16:57:27 +03:00
struct btmrvl_plt_wake_cfg {
int irq_bt ;
bool wake_by_bt ;
} ;
2011-04-09 05:19:33 +04:00
struct btmrvl_sdio_card_reg {
u8 cfg ;
u8 host_int_mask ;
u8 host_intstatus ;
u8 card_status ;
u8 sq_read_base_addr_a0 ;
u8 sq_read_base_addr_a1 ;
u8 card_revision ;
u8 card_fw_status0 ;
u8 card_fw_status1 ;
u8 card_rx_len ;
u8 card_rx_unit ;
u8 io_port_0 ;
u8 io_port_1 ;
u8 io_port_2 ;
2014-03-29 01:54:39 +04:00
bool int_read_to_clear ;
u8 host_int_rsr ;
u8 card_misc_cfg ;
2014-11-24 13:40:53 +03:00
u8 fw_dump_ctrl ;
u8 fw_dump_start ;
u8 fw_dump_end ;
2011-04-09 05:19:33 +04:00
} ;
2009-06-03 01:29:36 +04:00
struct btmrvl_sdio_card {
struct sdio_func * func ;
u32 ioport ;
const char * helper ;
const char * firmware ;
2011-04-09 05:19:33 +04:00
const struct btmrvl_sdio_card_reg * reg ;
2014-04-01 01:41:44 +04:00
bool support_pscan_win_report ;
2014-11-24 13:40:53 +03:00
bool supports_fw_dump ;
2011-04-09 05:19:33 +04:00
u16 sd_blksz_fw_dl ;
2009-06-03 01:29:36 +04:00
u8 rx_unit ;
struct btmrvl_private * priv ;
2016-04-26 16:57:27 +03:00
struct device_node * plt_of_node ;
struct btmrvl_plt_wake_cfg * plt_wake_cfg ;
2009-06-03 01:29:36 +04:00
} ;
struct btmrvl_sdio_device {
const char * helper ;
const char * firmware ;
2011-04-09 05:19:33 +04:00
const struct btmrvl_sdio_card_reg * reg ;
2014-04-01 01:41:44 +04:00
const bool support_pscan_win_report ;
2011-04-09 05:19:33 +04:00
u16 sd_blksz_fw_dl ;
2014-11-24 13:40:53 +03:00
bool supports_fw_dump ;
2009-06-03 01:29:36 +04:00
} ;
/* Platform specific DMA alignment */
# define BTSDIO_DMA_ALIGN 8
/* Macros for Data Alignment : size */
# define ALIGN_SZ(p, a) \
( ( ( p ) + ( ( a ) - 1 ) ) & ~ ( ( a ) - 1 ) )
/* Macros for Data Alignment : address */
# define ALIGN_ADDR(p, a) \
2009-07-08 22:44:14 +04:00
( ( ( ( unsigned long ) ( p ) ) + ( ( ( unsigned long ) ( a ) ) - 1 ) ) & \
~ ( ( ( unsigned long ) ( a ) ) - 1 ) )