• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Definitions for API from sdio common code (bcmsdh) to individual
3  * host controller drivers.
4  *
5  * Copyright (C) 1999-2017, Broadcom Corporation
6  *
7  *      Unless you and Broadcom execute a separate written software license
8  * agreement governing use of this software, this software is licensed to you
9  * under the terms of the GNU General Public License version 2 (the "GPL"),
10  * available at http://www.broadcom.com/licenses/GPLv2.php, with the
11  * following added to such license:
12  *
13  *      As a special exception, the copyright holders of this software give you
14  * permission to link this software with independent modules, and to copy and
15  * distribute the resulting executable under terms of your choice, provided that
16  * you also meet, for each linked independent module, the terms and conditions of
17  * the license of that module.  An independent module is a module which is not
18  * derived from this software.  The special exception does not apply to any
19  * modifications of the software.
20  *
21  *      Notwithstanding the above, under no circumstances may you combine this
22  * software in any way with any other Broadcom software provided under a license
23  * other than the GPL, without Broadcom's express prior written consent.
24  *
25  *
26  * <<Broadcom-WL-IPTag/Open:>>
27  *
28  * $Id: bcmsdbus.h 644725 2016-06-21 12:26:04Z $
29  */
30 
31 #ifndef    _sdio_api_h_
32 #define    _sdio_api_h_
33 
34 #if defined(BT_OVER_SDIO)
35 #include <linux/mmc/sdio_func.h>
36 #endif /* defined (BT_OVER_SDIO) */
37 
38 
39 #define SDIOH_API_RC_SUCCESS                          (0x00)
40 #define SDIOH_API_RC_FAIL                          (0x01)
41 #define SDIOH_API_SUCCESS(status) (status == 0)
42 
43 #define SDIOH_READ              0    /* Read request */
44 #define SDIOH_WRITE             1    /* Write request */
45 
46 #define SDIOH_DATA_FIX          0    /* Fixed addressing */
47 #define SDIOH_DATA_INC          1    /* Incremental addressing */
48 
49 #define SDIOH_CMD_TYPE_NORMAL   0       /* Normal command */
50 #define SDIOH_CMD_TYPE_APPEND   1       /* Append command */
51 #define SDIOH_CMD_TYPE_CUTTHRU  2       /* Cut-through command */
52 
53 #define SDIOH_DATA_PIO          0       /* PIO mode */
54 #define SDIOH_DATA_DMA          1       /* DMA mode */
55 
56 /* Max number of glommed pkts */
57 #ifdef CUSTOM_MAX_TXGLOM_SIZE
58 #define SDPCM_MAXGLOM_SIZE  CUSTOM_MAX_TXGLOM_SIZE
59 #else
60 #define SDPCM_MAXGLOM_SIZE    36
61 #endif /* CUSTOM_MAX_TXGLOM_SIZE */
62 
63 #define SDPCM_TXGLOM_CPY 0            /* SDIO 2.0 should use copy mode */
64 #define SDPCM_TXGLOM_MDESC    1        /* SDIO 3.0 should use multi-desc mode */
65 
66 #ifdef CUSTOM_DEF_TXGLOM_SIZE
67 #define SDPCM_DEFGLOM_SIZE  CUSTOM_DEF_TXGLOM_SIZE
68 #else
69 #define SDPCM_DEFGLOM_SIZE SDPCM_MAXGLOM_SIZE
70 #endif /* CUSTOM_DEF_TXGLOM_SIZE */
71 
72 #if SDPCM_DEFGLOM_SIZE > SDPCM_MAXGLOM_SIZE
73 #warning "SDPCM_DEFGLOM_SIZE cannot be higher than SDPCM_MAXGLOM_SIZE!!"
74 #undef SDPCM_DEFGLOM_SIZE
75 #define SDPCM_DEFGLOM_SIZE SDPCM_MAXGLOM_SIZE
76 #endif
77 
78 #ifdef PKT_STATICS
79 typedef struct pkt_statics {
80     uint16    event_count;
81     uint32    event_size;
82     uint16    ctrl_count;
83     uint32    ctrl_size;
84     uint32    data_count;
85     uint32    data_size;
86     uint32    glom_cnt[SDPCM_MAXGLOM_SIZE];
87     uint16    glom_max;
88     uint16    glom_count;
89     uint32    glom_size;
90     uint16    test_count;
91     uint32    test_size;
92 } pkt_statics_t;
93 #endif
94 
95 typedef int SDIOH_API_RC;
96 
97 /* SDio Host structure */
98 typedef struct sdioh_info sdioh_info_t;
99 
100 /* callback function, taking one arg */
101 typedef void (*sdioh_cb_fn_t)(void *);
102 #if defined(BT_OVER_SDIO)
103 extern
104 void sdioh_sdmmc_card_enable_func_f3(sdioh_info_t *sd, struct sdio_func *func);
105 #endif /* defined (BT_OVER_SDIO) */
106 
107 extern SDIOH_API_RC sdioh_interrupt_register(sdioh_info_t *si, sdioh_cb_fn_t fn, void *argh);
108 extern SDIOH_API_RC sdioh_interrupt_deregister(sdioh_info_t *si);
109 
110 /* query whether SD interrupt is enabled or not */
111 extern SDIOH_API_RC sdioh_interrupt_query(sdioh_info_t *si, bool *onoff);
112 
113 /* enable or disable SD interrupt */
114 extern SDIOH_API_RC sdioh_interrupt_set(sdioh_info_t *si, bool enable_disable);
115 
116 #if defined(DHD_DEBUG)
117 extern bool sdioh_interrupt_pending(sdioh_info_t *si);
118 #endif
119 
120 /* read or write one byte using cmd52 */
121 extern SDIOH_API_RC sdioh_request_byte(sdioh_info_t *si, uint rw, uint fnc, uint addr, uint8 *byte);
122 
123 /* read or write 2/4 bytes using cmd53 */
124 extern SDIOH_API_RC sdioh_request_word(sdioh_info_t *si, uint cmd_type, uint rw, uint fnc,
125     uint addr, uint32 *word, uint nbyte);
126 
127 /* read or write any buffer using cmd53 */
128 extern SDIOH_API_RC sdioh_request_buffer(sdioh_info_t *si, uint pio_dma, uint fix_inc,
129     uint rw, uint fnc_num, uint32 addr, uint regwidth, uint32 buflen, uint8 *buffer,
130     void *pkt);
131 
132 /* get cis data */
133 extern SDIOH_API_RC sdioh_cis_read(sdioh_info_t *si, uint fuc, uint8 *cis, uint32 length);
134 extern SDIOH_API_RC sdioh_cisaddr_read(sdioh_info_t *sd, uint func, uint8 *cisd, uint32 offset);
135 
136 extern SDIOH_API_RC sdioh_cfg_read(sdioh_info_t *si, uint fuc, uint32 addr, uint8 *data);
137 extern SDIOH_API_RC sdioh_cfg_write(sdioh_info_t *si, uint fuc, uint32 addr, uint8 *data);
138 
139 /* query number of io functions */
140 extern uint sdioh_query_iofnum(sdioh_info_t *si);
141 
142 /* handle iovars */
143 extern int sdioh_iovar_op(sdioh_info_t *si, const char *name,
144                           void *params, int plen, void *arg, int len, bool set);
145 
146 /* Issue abort to the specified function and clear controller as needed */
147 extern int sdioh_abort(sdioh_info_t *si, uint fnc);
148 
149 /* Start and Stop SDIO without re-enumerating the SD card. */
150 extern int sdioh_start(sdioh_info_t *si, int stage);
151 extern int sdioh_stop(sdioh_info_t *si);
152 
153 /* Wait system lock free */
154 extern int sdioh_waitlockfree(sdioh_info_t *si);
155 
156 /* Reset and re-initialize the device */
157 extern int sdioh_sdio_reset(sdioh_info_t *si);
158 
159 
160 
161 #if defined(BCMSDIOH_STD)
162     #define SDIOH_SLEEP_ENABLED
163 #endif
164 extern SDIOH_API_RC sdioh_sleep(sdioh_info_t *si, bool enab);
165 
166 /* GPIO support */
167 extern SDIOH_API_RC sdioh_gpio_init(sdioh_info_t *sd);
168 extern bool sdioh_gpioin(sdioh_info_t *sd, uint32 gpio);
169 extern SDIOH_API_RC sdioh_gpioouten(sdioh_info_t *sd, uint32 gpio);
170 extern SDIOH_API_RC sdioh_gpioout(sdioh_info_t *sd, uint32 gpio, bool enab);
171 extern uint sdioh_set_mode(sdioh_info_t *sd, uint mode);
172 
173 #endif /* _sdio_api_h_ */
174