xref: /freebsd/sys/dev/rtsx/rtsx.c (revision c0bed9bd0bda2ca9239f5913cd2d5c1bd5d29bfa)
1  /*-
2   * SPDX-License-Identifier: BSD-2-Clause
3   *
4   * Copyright (c) 2006 Uwe Stuehler <uwe@openbsd.org>
5   * Copyright (c) 2012 Stefan Sperling <stsp@openbsd.org>
6   * Copyright (c) 2020 Henri Hennebert <hlh@restart.be>
7   * Copyright (c) 2020 Gary Jennejohn <gj@freebsd.org>
8   * Copyright (c) 2020 Jesper Schmitz Mouridsen <jsm@FreeBSD.org>
9   * All rights reserved.
10   *
11   * Patch from:
12   * - Lutz Bichler <Lutz.Bichler@gmail.com>
13   *
14   * Base on OpenBSD /sys/dev/pci/rtsx_pci.c & /dev/ic/rtsx.c
15   *      on Linux   /drivers/mmc/host/rtsx_pci_sdmmc.c,
16   *                 /include/linux/rtsx_pci.h &
17   *                 /drivers/misc/cardreader/rtsx_pcr.c
18   *      on NetBSD  /sys/dev/ic/rtsx.c
19   *
20   * Permission to use, copy, modify, and distribute this software for any
21   * purpose with or without fee is hereby granted, provided that the above
22   * copyright notice and this permission notice appear in all copies.
23   *
24   * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
25   * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26   * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27   * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
28   * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
29   * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
30   * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
31   * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
32   * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
33   * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
34   * SUCH DAMAGE.
35   */
36  
37  #include <sys/param.h>
38  #include <sys/module.h>
39  #include <sys/systm.h> /* For FreeBSD 11 */
40  #include <sys/types.h> /* For FreeBSD 11 */
41  #include <sys/errno.h>
42  #include <sys/kernel.h>
43  #include <sys/bus.h>
44  #include <sys/endian.h>
45  #include <machine/bus.h>
46  #include <sys/mutex.h>
47  #include <sys/malloc.h>
48  #include <sys/rman.h>
49  #include <sys/queue.h>
50  #include <sys/taskqueue.h>
51  #include <sys/sysctl.h>
52  #include <dev/pci/pcivar.h>
53  #include <dev/pci/pcireg.h>
54  #include <dev/mmc/bridge.h>
55  #include <dev/mmc/mmcreg.h>
56  #include <dev/mmc/mmcbrvar.h>
57  #include <machine/_inttypes.h>
58  
59  #include "opt_mmccam.h"
60  
61  #ifdef MMCCAM
62  #include <cam/cam.h>
63  #include <cam/cam_ccb.h>
64  #include <cam/cam_debug.h>
65  #include <cam/cam_sim.h>
66  #include <cam/cam_xpt_sim.h>
67  #include <cam/mmc/mmc_sim.h>
68  #include "mmc_sim_if.h"
69  #endif /* MMCCAM */
70  
71  #include "rtsxreg.h"
72  
73  /* The softc holds our per-instance data. */
74  struct rtsx_softc {
75  	struct mtx	rtsx_mtx;		/* device mutex */
76  	device_t	rtsx_dev;		/* device */
77  	uint16_t	rtsx_flags;		/* device flags */
78  	uint16_t	rtsx_device_id;		/* device ID */
79  	device_t	rtsx_mmc_dev;		/* device of mmc bus */
80  	uint32_t	rtsx_intr_enabled;	/* enabled interrupts */
81  	uint32_t 	rtsx_intr_status;	/* soft interrupt status */
82  	int		rtsx_irq_res_id;	/* bus IRQ resource id */
83  	struct resource *rtsx_irq_res;		/* bus IRQ resource */
84  	void		*rtsx_irq_cookie;	/* bus IRQ resource cookie */
85  	struct callout	rtsx_timeout_callout;	/* callout for timeout */
86  	int		rtsx_timeout_cmd;	/* interrupt timeout for setup commands */
87  	int		rtsx_timeout_io;	/* interrupt timeout for I/O commands */
88  	void		(*rtsx_intr_trans_ok)(struct rtsx_softc *sc);
89  						/* function to call if transfer succeed */
90  	void		(*rtsx_intr_trans_ko)(struct rtsx_softc *sc);
91  						/* function to call if transfer fail */
92  
93  	struct timeout_task
94  			rtsx_card_insert_task;	/* card insert delayed task */
95  	struct task	rtsx_card_remove_task;	/* card remove task */
96  
97  	int		rtsx_mem_res_id;	/* bus memory resource id */
98  	struct resource *rtsx_mem_res;		/* bus memory resource */
99  	bus_space_tag_t	   rtsx_mem_btag;	/* host register set tag */
100  	bus_space_handle_t rtsx_mem_bhandle;	/* host register set handle */
101  
102  	bus_dma_tag_t	rtsx_cmd_dma_tag;	/* DMA tag for command transfer */
103  	bus_dmamap_t	rtsx_cmd_dmamap;	/* DMA map for command transfer */
104  	void		*rtsx_cmd_dmamem;	/* DMA mem for command transfer */
105  	bus_addr_t	rtsx_cmd_buffer;	/* device visible address of the DMA segment */
106  	int		rtsx_cmd_index;		/* index in rtsx_cmd_buffer */
107  
108  	bus_dma_tag_t	rtsx_data_dma_tag;	/* DMA tag for data transfer */
109  	bus_dmamap_t	rtsx_data_dmamap;	/* DMA map for data transfer */
110  	void		*rtsx_data_dmamem;	/* DMA mem for data transfer */
111  	bus_addr_t	rtsx_data_buffer;	/* device visible address of the DMA segment */
112  
113  #ifdef MMCCAM
114  	union ccb		*rtsx_ccb;	/* CAM control block */
115  	struct mmc_sim		rtsx_mmc_sim;	/* CAM generic sim */
116  	struct mmc_request	rtsx_cam_req;	/* CAM MMC request */
117  #endif /* MMCCAM */
118  
119  	struct mmc_request *rtsx_req;		/* MMC request */
120  	struct mmc_host rtsx_host;		/* host parameters */
121  	int		rtsx_pcie_cap;		/* PCIe capability offset */
122  	int8_t		rtsx_bus_busy;		/* bus busy status */
123  	int8_t		rtsx_ios_bus_width;	/* current host.ios.bus_width */
124  	int32_t		rtsx_ios_clock;		/* current host.ios.clock */
125  	int8_t		rtsx_ios_power_mode;	/* current host.ios.power mode */
126  	int8_t		rtsx_ios_timing;	/* current host.ios.timing */
127  	int8_t		rtsx_ios_vccq;		/* current host.ios.vccq */
128  	uint8_t		rtsx_read_only;		/* card read only status */
129  	uint8_t		rtsx_inversion;		/* inversion of card detection and read only status */
130  	uint8_t		rtsx_force_timing;	/* force bus_timing_uhs_sdr50 */
131  	uint8_t		rtsx_debug_mask;	/* debugging mask */
132  #define 	RTSX_DEBUG_BASIC	0x01	/* debug basic flow */
133  #define 	RTSX_TRACE_SD_CMD	0x02	/* trace SD commands */
134  #define 	RTSX_DEBUG_TUNING	0x04	/* debug tuning */
135  #ifdef MMCCAM
136  	uint8_t		rtsx_cam_status;	/* CAM status - 1 if card in use */
137  #endif /* MMCCAM */
138  	uint64_t	rtsx_read_count;	/* count of read operations */
139  	uint64_t	rtsx_write_count;	/* count of write operations */
140  	bool		rtsx_discovery_mode;	/* are we in discovery mode? */
141  	bool		rtsx_tuning_mode;	/* are we tuning */
142  	bool		rtsx_double_clk;	/* double clock freqency */
143  	bool		rtsx_vpclk;		/* voltage at Pulse-width Modulation(PWM) clock? */
144  	uint8_t		rtsx_ssc_depth;		/* Spread spectrum clocking depth */
145  	uint8_t		rtsx_card_drive_sel;	/* value for RTSX_CARD_DRIVE_SEL */
146  	uint8_t		rtsx_sd30_drive_sel_3v3;/* value for RTSX_SD30_DRIVE_SEL */
147  };
148  
149  /* rtsx_flags values */
150  #define	RTSX_F_DEFAULT		0x0000
151  #define	RTSX_F_CARD_PRESENT	0x0001
152  #define	RTSX_F_SDIO_SUPPORT	0x0002
153  #define	RTSX_F_VERSION_A	0x0004
154  #define	RTSX_F_VERSION_B	0x0008
155  #define	RTSX_F_VERSION_C	0x0010
156  #define	RTSX_F_VERSION_D	0x0020
157  #define	RTSX_F_8411B_QFN48	0x0040
158  #define	RTSX_F_REVERSE_SOCKET	0x0080
159  
160  #define	RTSX_REALTEK		0x10ec
161  #define	RTSX_RTS5209		0x5209
162  #define	RTSX_RTS5227		0x5227
163  #define	RTSX_RTS5229		0x5229
164  #define	RTSX_RTS522A		0x522a
165  #define	RTSX_RTS525A		0x525a
166  #define	RTSX_RTS5249		0x5249
167  #define	RTSX_RTS5260		0x5260
168  #define	RTSX_RTL8402		0x5286
169  #define	RTSX_RTL8411		0x5289
170  #define	RTSX_RTL8411B		0x5287
171  
172  #define	RTSX_VERSION		"2.1g"
173  
174  static const struct rtsx_pciids {
175  	uint16_t	device_id;
176  	const char	*desc;
177  } rtsx_ids[] = {
178  	{ RTSX_RTS5209, RTSX_VERSION " Realtek RTS5209 PCIe SD Card Reader" },
179  	{ RTSX_RTS5227, RTSX_VERSION " Realtek RTS5227 PCIe SD Card Reader" },
180  	{ RTSX_RTS5229, RTSX_VERSION " Realtek RTS5229 PCIe SD Card Reader" },
181  	{ RTSX_RTS522A, RTSX_VERSION " Realtek RTS522A PCIe SD Card Reader" },
182  	{ RTSX_RTS525A, RTSX_VERSION " Realtek RTS525A PCIe SD Card Reader" },
183  	{ RTSX_RTS5249, RTSX_VERSION " Realtek RTS5249 PCIe SD Card Reader" },
184  	{ RTSX_RTS5260, RTSX_VERSION " Realtek RTS5260 PCIe SD Card Reader" },
185  	{ RTSX_RTL8402, RTSX_VERSION " Realtek RTL8402 PCIe SD Card Reader" },
186  	{ RTSX_RTL8411, RTSX_VERSION " Realtek RTL8411 PCIe SD Card Reader" },
187  	{ RTSX_RTL8411B, RTSX_VERSION " Realtek RTL8411B PCIe SD Card Reader" },
188  };
189  
190  /* See `kenv | grep smbios.system` */
191  static const struct rtsx_inversion_model {
192  	char	*maker;
193  	char	*family;
194  	char	*product;
195  } rtsx_inversion_models[] = {
196  	{ "LENOVO",		"ThinkPad T470p",	"20J7S0PM00"},
197  	{ "LENOVO",		"ThinkPad X13 Gen 1",	"20UF000QRT"},
198  	{ NULL,			NULL,			NULL}
199  };
200  
201  static int	rtsx_dma_alloc(struct rtsx_softc *sc);
202  static void	rtsx_dmamap_cb(void *arg, bus_dma_segment_t *segs, int nsegs, int error);
203  static void	rtsx_dma_free(struct rtsx_softc *sc);
204  static void	rtsx_intr(void *arg);
205  static void	rtsx_handle_card_present(struct rtsx_softc *sc);
206  static void	rtsx_card_task(void *arg, int pending __unused);
207  static bool	rtsx_is_card_present(struct rtsx_softc *sc);
208  static int	rtsx_init(struct rtsx_softc *sc);
209  static int	rtsx_map_sd_drive(int index);
210  static int	rtsx_rts5227_fill_driving(struct rtsx_softc *sc);
211  static int	rtsx_rts5249_fill_driving(struct rtsx_softc *sc);
212  static int	rtsx_rts5260_fill_driving(struct rtsx_softc *sc);
213  static int	rtsx_read(struct rtsx_softc *, uint16_t, uint8_t *);
214  static int	rtsx_read_cfg(struct rtsx_softc *sc, uint8_t func, uint16_t addr, uint32_t *val);
215  static int	rtsx_write(struct rtsx_softc *sc, uint16_t addr, uint8_t mask, uint8_t val);
216  static int	rtsx_read_phy(struct rtsx_softc *sc, uint8_t addr, uint16_t *val);
217  static int	rtsx_write_phy(struct rtsx_softc *sc, uint8_t addr, uint16_t val);
218  static int	rtsx_bus_power_off(struct rtsx_softc *sc);
219  static int	rtsx_bus_power_on(struct rtsx_softc *sc);
220  static int	rtsx_set_bus_width(struct rtsx_softc *sc, enum mmc_bus_width width);
221  static int	rtsx_set_sd_timing(struct rtsx_softc *sc, enum mmc_bus_timing timing);
222  static int	rtsx_set_sd_clock(struct rtsx_softc *sc, uint32_t freq);
223  static int	rtsx_stop_sd_clock(struct rtsx_softc *sc);
224  static int	rtsx_switch_sd_clock(struct rtsx_softc *sc, uint8_t clk, uint8_t n, uint8_t div, uint8_t mcu);
225  #ifndef MMCCAM
226  static void	rtsx_sd_change_tx_phase(struct rtsx_softc *sc, uint8_t sample_point);
227  static void	rtsx_sd_change_rx_phase(struct rtsx_softc *sc, uint8_t sample_point);
228  static void	rtsx_sd_tuning_rx_phase(struct rtsx_softc *sc, uint32_t *phase_map);
229  static int	rtsx_sd_tuning_rx_cmd(struct rtsx_softc *sc, uint8_t sample_point);
230  static int	rtsx_sd_tuning_rx_cmd_wait(struct rtsx_softc *sc, struct mmc_command *cmd);
231  static void	rtsx_sd_tuning_rx_cmd_wakeup(struct rtsx_softc *sc);
232  static void	rtsx_sd_wait_data_idle(struct rtsx_softc *sc);
233  static uint8_t	rtsx_sd_search_final_rx_phase(struct rtsx_softc *sc, uint32_t phase_map);
234  static int	rtsx_sd_get_rx_phase_len(uint32_t phase_map, int start_bit);
235  #endif /* !MMCCAM */
236  #if 0	/* For led */
237  static int	rtsx_led_enable(struct rtsx_softc *sc);
238  static int	rtsx_led_disable(struct rtsx_softc *sc);
239  #endif	/* For led */
240  static uint8_t	rtsx_response_type(uint16_t mmc_rsp);
241  static void	rtsx_init_cmd(struct rtsx_softc *sc, struct mmc_command *cmd);
242  static void	rtsx_push_cmd(struct rtsx_softc *sc, uint8_t cmd, uint16_t reg,
243  			      uint8_t mask, uint8_t data);
244  static void	rtsx_set_cmd_data_len(struct rtsx_softc *sc, uint16_t block_cnt, uint16_t byte_cnt);
245  static void	rtsx_send_cmd(struct rtsx_softc *sc);
246  static void	rtsx_ret_resp(struct rtsx_softc *sc);
247  static void	rtsx_set_resp(struct rtsx_softc *sc, struct mmc_command *cmd);
248  static void	rtsx_stop_cmd(struct rtsx_softc *sc);
249  static void	rtsx_clear_error(struct rtsx_softc *sc);
250  static void	rtsx_req_done(struct rtsx_softc *sc);
251  static int	rtsx_send_req(struct rtsx_softc *sc, struct mmc_command *cmd);
252  static int	rtsx_xfer_short(struct rtsx_softc *sc, struct mmc_command *cmd);
253  static void	rtsx_ask_ppbuf_part1(struct rtsx_softc *sc);
254  static void	rtsx_get_ppbuf_part1(struct rtsx_softc *sc);
255  static void	rtsx_get_ppbuf_part2(struct rtsx_softc *sc);
256  static void	rtsx_put_ppbuf_part1(struct rtsx_softc *sc);
257  static void	rtsx_put_ppbuf_part2(struct rtsx_softc *sc);
258  static void	rtsx_write_ppbuf(struct rtsx_softc *sc);
259  static int	rtsx_xfer(struct rtsx_softc *sc, struct mmc_command *cmd);
260  static void	rtsx_xfer_begin(struct rtsx_softc *sc);
261  static void	rtsx_xfer_start(struct rtsx_softc *sc);
262  static void	rtsx_xfer_finish(struct rtsx_softc *sc);
263  static void	rtsx_timeout(void *arg);
264  
265  #ifdef MMCCAM
266  static int	rtsx_get_tran_settings(device_t dev, struct ccb_trans_settings_mmc *cts);
267  static int	rtsx_set_tran_settings(device_t dev, struct ccb_trans_settings_mmc *cts);
268  static int	rtsx_cam_request(device_t dev, union ccb *ccb);
269  #endif /* MMCCAM */
270  
271  static int	rtsx_read_ivar(device_t bus, device_t child, int which, uintptr_t *result);
272  static int	rtsx_write_ivar(device_t bus, device_t child, int which, uintptr_t value);
273  
274  static int	rtsx_mmcbr_update_ios(device_t bus, device_t child __unused);
275  static int	rtsx_mmcbr_switch_vccq(device_t bus, device_t child __unused);
276  static int	rtsx_mmcbr_request(device_t bus, device_t child __unused, struct mmc_request *req);
277  #ifndef MMCCAM
278  static int	rtsx_mmcbr_tune(device_t bus, device_t child __unused, bool hs400 __unused);
279  static int	rtsx_mmcbr_retune(device_t bus, device_t child __unused, bool reset __unused);
280  static int	rtsx_mmcbr_get_ro(device_t bus, device_t child __unused);
281  static int	rtsx_mmcbr_acquire_host(device_t bus, device_t child __unused);
282  static int	rtsx_mmcbr_release_host(device_t bus, device_t child __unused);
283  #endif /* !MMCCAM */
284  
285  static int	rtsx_probe(device_t dev);
286  static int	rtsx_attach(device_t dev);
287  static int	rtsx_detach(device_t dev);
288  static int	rtsx_shutdown(device_t dev);
289  static int	rtsx_suspend(device_t dev);
290  static int	rtsx_resume(device_t dev);
291  
292  #define	RTSX_LOCK_INIT(_sc)	mtx_init(&(_sc)->rtsx_mtx,	\
293  					 device_get_nameunit(sc->rtsx_dev), "rtsx", MTX_DEF)
294  #define	RTSX_LOCK(_sc)		mtx_lock(&(_sc)->rtsx_mtx)
295  #define	RTSX_UNLOCK(_sc)	mtx_unlock(&(_sc)->rtsx_mtx)
296  #define	RTSX_LOCK_DESTROY(_sc)	mtx_destroy(&(_sc)->rtsx_mtx)
297  
298  #define	RTSX_SDCLK_OFF			0
299  #define	RTSX_SDCLK_250KHZ	   250000
300  #define	RTSX_SDCLK_400KHZ	   400000
301  #define	RTSX_SDCLK_25MHZ	 25000000
302  #define	RTSX_SDCLK_50MHZ	 50000000
303  #define	RTSX_SDCLK_100MHZ	100000000
304  #define	RTSX_SDCLK_208MHZ	208000000
305  
306  #define	RTSX_MIN_DIV_N		80
307  #define	RTSX_MAX_DIV_N		208
308  
309  #define	RTSX_MAX_DATA_BLKLEN	512
310  
311  #define	RTSX_DMA_ALIGN		4
312  #define	RTSX_HOSTCMD_MAX	256
313  #define	RTSX_DMA_CMD_BIFSIZE	(sizeof(uint32_t) * RTSX_HOSTCMD_MAX)
314  #define	RTSX_DMA_DATA_BUFSIZE	maxphys
315  
316  #define	ISSET(t, f) ((t) & (f))
317  
318  #define	READ4(sc, reg)						\
319  	(bus_space_read_4((sc)->rtsx_mem_btag, (sc)->rtsx_mem_bhandle, (reg)))
320  #define	WRITE4(sc, reg, val)					\
321  	(bus_space_write_4((sc)->rtsx_mem_btag, (sc)->rtsx_mem_bhandle, (reg), (val)))
322  
323  #define	RTSX_READ(sc, reg, val) 				\
324  	do { 							\
325  		int err = rtsx_read((sc), (reg), (val)); 	\
326  		if (err) 					\
327  			return (err);				\
328  	} while (0)
329  
330  #define	RTSX_WRITE(sc, reg, val) 				\
331  	do { 							\
332  		int err = rtsx_write((sc), (reg), 0xff, (val));	\
333  		if (err) 					\
334  			return (err);				\
335  	} while (0)
336  #define	RTSX_CLR(sc, reg, bits)					\
337  	do { 							\
338  		int err = rtsx_write((sc), (reg), (bits), 0); 	\
339  		if (err) 					\
340  			return (err);				\
341  	} while (0)
342  
343  #define	RTSX_SET(sc, reg, bits)					\
344  	do { 							\
345  		int err = rtsx_write((sc), (reg), (bits), 0xff);\
346  		if (err) 					\
347  			return (err);				\
348  	} while (0)
349  
350  #define	RTSX_BITOP(sc, reg, mask, bits)				\
351  	do {							\
352  		int err = rtsx_write((sc), (reg), (mask), (bits));	\
353  		if (err)					\
354  			return (err);				\
355  	} while (0)
356  
357  /*
358   * We use two DMA buffers: a command buffer and a data buffer.
359   *
360   * The command buffer contains a command queue for the host controller,
361   * which describes SD/MMC commands to run, and other parameters. The chip
362   * runs the command queue when a special bit in the RTSX_HCBAR register is
363   * set and signals completion with the RTSX_TRANS_OK_INT interrupt.
364   * Each command is encoded as a 4 byte sequence containing command number
365   * (read, write, or check a host controller register), a register address,
366   * and a data bit-mask and value.
367   * SD/MMC commands which do not transfer any data from/to the card only use
368   * the command buffer.
369   *
370   * The data buffer is used for transfer longer than 512. Data transfer is
371   * controlled via the RTSX_HDBAR register and completion is signalled by
372   * the RTSX_TRANS_OK_INT interrupt.
373   *
374   * The chip is unable to perform DMA above 4GB.
375   */
376  
377  /*
378   * Main commands in the usual seqence used:
379   *
380   * CMD0		Go idle state
381   * CMD8		Send interface condition
382   * CMD55	Application Command for next ACMD
383   * ACMD41	Send Operation Conditions Register (OCR: voltage profile of the card)
384   * CMD2		Send Card Identification (CID) Register
385   * CMD3		Send relative address
386   * CMD9		Send Card Specific Data (CSD)
387   * CMD13	Send status (32 bits -  bit 25: card password protected)
388   * CMD7		Select card (before Get card SCR)
389   * ACMD51	Send SCR (SD CARD Configuration Register - [51:48]: Bus widths supported)
390   * CMD6		SD switch function
391   * ACMD13	Send SD status (512 bits)
392   * ACMD42	Set/Clear card detect
393   * ACMD6	Set bus width
394   * CMD19	Send tuning block
395   * CMD12	Stop transmission
396   *
397   * CMD17	Read single block (<=512)
398   * CMD18	Read multiple blocks (>512)
399   * CMD24	Write single block (<=512)
400   * CMD25	Write multiple blocks (>512)
401   *
402   * CMD52	IO R/W direct
403   * CMD5		Send Operation Conditions
404   */
405  
406  static int
rtsx_dma_alloc(struct rtsx_softc * sc)407  rtsx_dma_alloc(struct rtsx_softc *sc)
408  {
409  	int	error = 0;
410  
411  	error = bus_dma_tag_create(bus_get_dma_tag(sc->rtsx_dev), /* inherit from parent */
412  	    RTSX_DMA_ALIGN, 0,		/* alignment, boundary */
413  	    BUS_SPACE_MAXADDR_32BIT,	/* lowaddr */
414  	    BUS_SPACE_MAXADDR,		/* highaddr */
415  	    NULL, NULL,			/* filter, filterarg */
416  	    RTSX_DMA_CMD_BIFSIZE, 1,	/* maxsize, nsegments */
417  	    RTSX_DMA_CMD_BIFSIZE,	/* maxsegsize */
418  	    0,				/* flags */
419  	    NULL, NULL,			/* lockfunc, lockarg */
420  	    &sc->rtsx_cmd_dma_tag);
421  	if (error) {
422  		device_printf(sc->rtsx_dev,
423  			      "Can't create cmd parent DMA tag\n");
424  		return (error);
425  	}
426  	error = bus_dmamem_alloc(sc->rtsx_cmd_dma_tag,		/* DMA tag */
427  	    &sc->rtsx_cmd_dmamem,				/* will hold the KVA pointer */
428  	    BUS_DMA_COHERENT | BUS_DMA_WAITOK | BUS_DMA_ZERO,	/* flags */
429  	    &sc->rtsx_cmd_dmamap); 				/* DMA map */
430  	if (error) {
431  		device_printf(sc->rtsx_dev,
432  			      "Can't create DMA map for command transfer\n");
433  		goto destroy_cmd_dma_tag;
434  
435  	}
436  	error = bus_dmamap_load(sc->rtsx_cmd_dma_tag,	/* DMA tag */
437  	    sc->rtsx_cmd_dmamap,	/* DMA map */
438  	    sc->rtsx_cmd_dmamem,	/* KVA pointer to be mapped */
439  	    RTSX_DMA_CMD_BIFSIZE,	/* size of buffer */
440  	    rtsx_dmamap_cb,		/* callback */
441  	    &sc->rtsx_cmd_buffer,	/* first arg of callback */
442  	    0);				/* flags */
443  	if (error || sc->rtsx_cmd_buffer == 0) {
444  		device_printf(sc->rtsx_dev,
445  			      "Can't load DMA memory for command transfer\n");
446  		error = (error) ? error : EFAULT;
447  		goto destroy_cmd_dmamem_alloc;
448  	}
449  
450  	error = bus_dma_tag_create(bus_get_dma_tag(sc->rtsx_dev),	/* inherit from parent */
451  	    RTSX_DMA_DATA_BUFSIZE, 0,	/* alignment, boundary */
452  	    BUS_SPACE_MAXADDR_32BIT,	/* lowaddr */
453  	    BUS_SPACE_MAXADDR,		/* highaddr */
454  	    NULL, NULL,			/* filter, filterarg */
455  	    RTSX_DMA_DATA_BUFSIZE, 1,	/* maxsize, nsegments */
456  	    RTSX_DMA_DATA_BUFSIZE,	/* maxsegsize */
457  	    0,				/* flags */
458  	    NULL, NULL,			/* lockfunc, lockarg */
459  	    &sc->rtsx_data_dma_tag);
460  	if (error) {
461  		device_printf(sc->rtsx_dev,
462  			      "Can't create data parent DMA tag\n");
463  		goto destroy_cmd_dmamap_load;
464  	}
465  	error = bus_dmamem_alloc(sc->rtsx_data_dma_tag,		/* DMA tag */
466  	    &sc->rtsx_data_dmamem,				/* will hold the KVA pointer */
467  	    BUS_DMA_WAITOK | BUS_DMA_ZERO,			/* flags */
468  	    &sc->rtsx_data_dmamap); 				/* DMA map */
469  	if (error) {
470  		device_printf(sc->rtsx_dev,
471  			      "Can't create DMA map for data transfer\n");
472  		goto destroy_data_dma_tag;
473  	}
474  	error = bus_dmamap_load(sc->rtsx_data_dma_tag,	/* DMA tag */
475  	    sc->rtsx_data_dmamap,	/* DMA map */
476  	    sc->rtsx_data_dmamem,	/* KVA pointer to be mapped */
477  	    RTSX_DMA_DATA_BUFSIZE,	/* size of buffer */
478  	    rtsx_dmamap_cb,		/* callback */
479  	    &sc->rtsx_data_buffer,	/* first arg of callback */
480  	    0);				/* flags */
481  	if (error || sc->rtsx_data_buffer == 0) {
482  		device_printf(sc->rtsx_dev,
483  			      "Can't load DMA memory for data transfer\n");
484  		error = (error) ? error : EFAULT;
485  		goto destroy_data_dmamem_alloc;
486  	}
487  	return (error);
488  
489   destroy_data_dmamem_alloc:
490  	bus_dmamem_free(sc->rtsx_data_dma_tag, sc->rtsx_data_dmamem, sc->rtsx_data_dmamap);
491   destroy_data_dma_tag:
492  	bus_dma_tag_destroy(sc->rtsx_data_dma_tag);
493   destroy_cmd_dmamap_load:
494  	bus_dmamap_unload(sc->rtsx_cmd_dma_tag, sc->rtsx_cmd_dmamap);
495   destroy_cmd_dmamem_alloc:
496  	bus_dmamem_free(sc->rtsx_cmd_dma_tag, sc->rtsx_cmd_dmamem, sc->rtsx_cmd_dmamap);
497   destroy_cmd_dma_tag:
498  	bus_dma_tag_destroy(sc->rtsx_cmd_dma_tag);
499  
500  	return (error);
501  }
502  
503  static void
rtsx_dmamap_cb(void * arg,bus_dma_segment_t * segs,int nsegs,int error)504  rtsx_dmamap_cb(void *arg, bus_dma_segment_t *segs, int nsegs, int error)
505  {
506  	if (error) {
507  		printf("rtsx_dmamap_cb: error %d\n", error);
508  		return;
509  	}
510  	*(bus_addr_t *)arg = segs[0].ds_addr;
511  }
512  
513  static void
rtsx_dma_free(struct rtsx_softc * sc)514  rtsx_dma_free(struct rtsx_softc *sc)
515  {
516  	if (sc->rtsx_cmd_dma_tag != NULL) {
517  		if (sc->rtsx_cmd_dmamap != NULL)
518  			bus_dmamap_unload(sc->rtsx_cmd_dma_tag,
519  					  sc->rtsx_cmd_dmamap);
520  		if (sc->rtsx_cmd_dmamem != NULL)
521  			bus_dmamem_free(sc->rtsx_cmd_dma_tag,
522  					sc->rtsx_cmd_dmamem,
523  					sc->rtsx_cmd_dmamap);
524  		sc->rtsx_cmd_dmamap = NULL;
525  		sc->rtsx_cmd_dmamem = NULL;
526  		sc->rtsx_cmd_buffer = 0;
527  		bus_dma_tag_destroy(sc->rtsx_cmd_dma_tag);
528  		sc->rtsx_cmd_dma_tag = NULL;
529  	}
530  	if (sc->rtsx_data_dma_tag != NULL) {
531  		if (sc->rtsx_data_dmamap != NULL)
532  			bus_dmamap_unload(sc->rtsx_data_dma_tag,
533  					  sc->rtsx_data_dmamap);
534  		if (sc->rtsx_data_dmamem != NULL)
535  			bus_dmamem_free(sc->rtsx_data_dma_tag,
536  					sc->rtsx_data_dmamem,
537  					sc->rtsx_data_dmamap);
538  		sc->rtsx_data_dmamap = NULL;
539  		sc->rtsx_data_dmamem = NULL;
540  		sc->rtsx_data_buffer = 0;
541  		bus_dma_tag_destroy(sc->rtsx_data_dma_tag);
542  		sc->rtsx_data_dma_tag = NULL;
543  	}
544  }
545  
546  static void
rtsx_intr(void * arg)547  rtsx_intr(void *arg)
548  {
549  	struct rtsx_softc *sc = arg;
550  	uint32_t	enabled;
551  	uint32_t	status;
552  
553  	RTSX_LOCK(sc);
554  
555  	enabled = sc->rtsx_intr_enabled;
556  	status = READ4(sc, RTSX_BIPR);	/* read Bus Interrupt Pending Register */
557  	sc->rtsx_intr_status = status;
558  
559  	if (sc->rtsx_debug_mask & RTSX_TRACE_SD_CMD)
560  		device_printf(sc->rtsx_dev, "Interrupt handler - enabled: 0x%08x, status: 0x%08x\n", enabled, status);
561  
562  	/* Ack interrupts. */
563  	WRITE4(sc, RTSX_BIPR, status);
564  
565  	if (((enabled & status) == 0) || status == 0xffffffff) {
566  		device_printf(sc->rtsx_dev, "Spurious interrupt - enabled: 0x%08x, status: 0x%08x\n", enabled, status);
567  		RTSX_UNLOCK(sc);
568  		return;
569  	}
570  
571  	/* Detect write protect. */
572  	if (status & RTSX_SD_WRITE_PROTECT)
573  		sc->rtsx_read_only = 1;
574  	else
575  		sc->rtsx_read_only = 0;
576  
577  	/* Start task to handle SD card status change (from dwmmc.c). */
578  	if (status & RTSX_SD_INT) {
579  		device_printf(sc->rtsx_dev, "Interrupt card inserted/removed\n");
580  		rtsx_handle_card_present(sc);
581  	}
582  
583  	if (sc->rtsx_req == NULL) {
584  		RTSX_UNLOCK(sc);
585  		return;
586  	}
587  
588  	if (status & RTSX_TRANS_OK_INT) {
589  		sc->rtsx_req->cmd->error = MMC_ERR_NONE;
590  		if (sc->rtsx_intr_trans_ok != NULL)
591  			sc->rtsx_intr_trans_ok(sc);
592  	} else if (status & RTSX_TRANS_FAIL_INT) {
593  		uint8_t stat1;
594  		sc->rtsx_req->cmd->error = MMC_ERR_FAILED;
595  		if (rtsx_read(sc, RTSX_SD_STAT1, &stat1) == 0 &&
596  		    (stat1 & RTSX_SD_CRC_ERR)) {
597  			device_printf(sc->rtsx_dev, "CRC error\n");
598  			sc->rtsx_req->cmd->error = MMC_ERR_BADCRC;
599  		}
600  		if (!sc->rtsx_tuning_mode)
601  			device_printf(sc->rtsx_dev, "Transfer fail - status: 0x%08x\n", status);
602  		rtsx_stop_cmd(sc);
603  		if (sc->rtsx_intr_trans_ko != NULL)
604  			sc->rtsx_intr_trans_ko(sc);
605  	}
606  
607  	RTSX_UNLOCK(sc);
608  }
609  
610  /*
611   * Function called from the IRQ handler (from dwmmc.c).
612   */
613  static void
rtsx_handle_card_present(struct rtsx_softc * sc)614  rtsx_handle_card_present(struct rtsx_softc *sc)
615  {
616  	bool	was_present;
617  	bool	is_present;
618  
619  #ifdef MMCCAM
620  	was_present = sc->rtsx_cam_status;
621  #else  /* !MMCCAM */
622  	was_present = sc->rtsx_mmc_dev != NULL;
623  #endif /* MMCCAM */
624  	is_present = rtsx_is_card_present(sc);
625  	if (is_present)
626  		device_printf(sc->rtsx_dev, "Card present\n");
627  	else
628  		device_printf(sc->rtsx_dev, "Card absent\n");
629  
630  	if (!was_present && is_present) {
631  		/*
632  		 * The delay is to debounce the card insert
633  		 * (sometimes the card detect pin stabilizes
634  		 * before the other pins have made good contact).
635  		 */
636  		taskqueue_enqueue_timeout(taskqueue_bus,
637  					  &sc->rtsx_card_insert_task, -hz);
638  	} else if (was_present && !is_present) {
639  		taskqueue_enqueue(taskqueue_bus, &sc->rtsx_card_remove_task);
640  	}
641  }
642  
643  /*
644   * This function is called at startup.
645   */
646  static void
rtsx_card_task(void * arg,int pending __unused)647  rtsx_card_task(void *arg, int pending __unused)
648  {
649  	struct rtsx_softc *sc = arg;
650  
651  #ifndef MMCCAM
652  	bus_topo_lock();
653  #endif
654  	if (rtsx_is_card_present(sc)) {
655  		sc->rtsx_flags |= RTSX_F_CARD_PRESENT;
656  		/* Card is present, attach if necessary. */
657  #ifdef MMCCAM
658  		if (sc->rtsx_cam_status == 0) {
659  #else  /* !MMCCAM */
660  		if (sc->rtsx_mmc_dev == NULL) {
661  #endif /* MMCCAM */
662  			if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
663  				device_printf(sc->rtsx_dev, "Card inserted\n");
664  
665  			sc->rtsx_read_count = sc->rtsx_write_count = 0;
666  #ifdef MMCCAM
667  			sc->rtsx_cam_status = 1;
668  			mmc_cam_sim_discover(&sc->rtsx_mmc_sim);
669  #else  /* !MMCCAM */
670  			sc->rtsx_mmc_dev = device_add_child(sc->rtsx_dev, "mmc", DEVICE_UNIT_ANY);
671  			if (sc->rtsx_mmc_dev == NULL) {
672  				device_printf(sc->rtsx_dev, "Adding MMC bus failed\n");
673  			} else {
674  				device_set_ivars(sc->rtsx_mmc_dev, sc);
675  				device_probe_and_attach(sc->rtsx_mmc_dev);
676  			}
677  #endif /* MMCCAM */
678  		}
679  	} else {
680  		sc->rtsx_flags &= ~RTSX_F_CARD_PRESENT;
681  		/* Card isn't present, detach if necessary. */
682  #ifdef MMCCAM
683  		if (sc->rtsx_cam_status != 0) {
684  #else  /* !MMCCAM */
685  		if (sc->rtsx_mmc_dev != NULL) {
686  #endif /* MMCCAM */
687  			if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
688  				device_printf(sc->rtsx_dev, "Card removed\n");
689  
690  			if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
691  				device_printf(sc->rtsx_dev, "Read count: %" PRIu64 ", write count: %" PRIu64 "\n",
692  					      sc->rtsx_read_count, sc->rtsx_write_count);
693  #ifdef MMCCAM
694  			sc->rtsx_cam_status = 0;
695  			mmc_cam_sim_discover(&sc->rtsx_mmc_sim);
696  #else  /* !MMCCAM */
697  			if (device_delete_child(sc->rtsx_dev, sc->rtsx_mmc_dev))
698  				device_printf(sc->rtsx_dev, "Detaching MMC bus failed\n");
699  			sc->rtsx_mmc_dev = NULL;
700  #endif /* MMCCAM */
701  		}
702  	}
703  #ifndef MMCCAM
704  	bus_topo_unlock();
705  #endif
706  }
707  
708  static bool
709  rtsx_is_card_present(struct rtsx_softc *sc)
710  {
711  	uint32_t status;
712  
713  	status = READ4(sc, RTSX_BIPR);
714  	if (sc->rtsx_inversion == 0)
715  		return (status & RTSX_SD_EXIST);
716  	else
717  		return !(status & RTSX_SD_EXIST);
718  }
719  
720  static int
721  rtsx_init(struct rtsx_softc *sc)
722  {
723  	uint8_t	version;
724  	uint8_t	val;
725  	int	error;
726  
727  	sc->rtsx_host.host_ocr = RTSX_SUPPORTED_VOLTAGE;
728  	sc->rtsx_host.f_min = RTSX_SDCLK_250KHZ;
729  	sc->rtsx_host.f_max = RTSX_SDCLK_208MHZ;
730  	sc->rtsx_host.caps = MMC_CAP_4_BIT_DATA | MMC_CAP_HSPEED |
731  		MMC_CAP_UHS_SDR12 | MMC_CAP_UHS_SDR25;
732  
733  	sc->rtsx_host.caps |= MMC_CAP_UHS_SDR50 | MMC_CAP_UHS_SDR104;
734  	if (sc->rtsx_device_id == RTSX_RTS5209)
735  		sc->rtsx_host.caps |= MMC_CAP_8_BIT_DATA;
736  	pci_find_cap(sc->rtsx_dev, PCIY_EXPRESS, &(sc->rtsx_pcie_cap));
737  
738  	/*
739  	 * Check IC version.
740  	 */
741  	switch (sc->rtsx_device_id) {
742  	case RTSX_RTS5229:
743  		/* Read IC version from dummy register. */
744  		RTSX_READ(sc, RTSX_DUMMY_REG, &version);
745  		if ((version & 0x0F) == RTSX_IC_VERSION_C)
746  			sc->rtsx_flags |= RTSX_F_VERSION_C;
747  		break;
748  	case RTSX_RTS522A:
749  		/* Read IC version from dummy register. */
750  		RTSX_READ(sc, RTSX_DUMMY_REG, &version);
751  		if ((version & 0x0F) == RTSX_IC_VERSION_A)
752  			sc->rtsx_flags |= RTSX_F_VERSION_A;
753  		break;
754  	case RTSX_RTS525A:
755  		/* Read IC version from dummy register. */
756  		RTSX_READ(sc, RTSX_DUMMY_REG, &version);
757  		if ((version & 0x0F) == RTSX_IC_VERSION_A)
758  			sc->rtsx_flags |= RTSX_F_VERSION_A;
759  		break;
760  	case RTSX_RTL8411B:
761  		RTSX_READ(sc, RTSX_RTL8411B_PACKAGE, &version);
762  		if (version & RTSX_RTL8411B_QFN48)
763  			sc->rtsx_flags |= RTSX_F_8411B_QFN48;
764  		break;
765  	}
766  
767  	/*
768  	 * Fetch vendor settings.
769  	 */
770  	/*
771  	 * Normally OEMs will set vendor setting to the config space
772  	 * of Realtek card reader in BIOS stage. This statement reads
773  	 * the setting and configure the internal registers according
774  	 * to it, to improve card reader's compatibility condition.
775  	 */
776  	sc->rtsx_card_drive_sel = RTSX_CARD_DRIVE_DEFAULT;
777  	switch (sc->rtsx_device_id) {
778  		uint32_t reg;
779  		uint32_t reg1;
780  		uint8_t  reg3;
781  	case RTSX_RTS5209:
782  		sc->rtsx_card_drive_sel = RTSX_RTS5209_CARD_DRIVE_DEFAULT;
783  		sc->rtsx_sd30_drive_sel_3v3 = RTSX_DRIVER_TYPE_D;
784  		reg = pci_read_config(sc->rtsx_dev, RTSX_PCR_SETTING_REG2, 4);
785  		if (!(reg & 0x80)) {
786  			sc->rtsx_card_drive_sel = (reg >> 8) & 0x3F;
787  			sc->rtsx_sd30_drive_sel_3v3 = reg & 0x07;
788  		} else if (bootverbose || sc->rtsx_debug_mask & RTSX_DEBUG_BASIC) {
789  			device_printf(sc->rtsx_dev, "pci_read_config() error - reg: 0x%08x\n", reg);
790  		}
791  		if (bootverbose || sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
792  			device_printf(sc->rtsx_dev, "card_drive_sel: 0x%02x, sd30_drive_sel_3v3: 0x%02x\n",
793  				      sc->rtsx_card_drive_sel, sc->rtsx_sd30_drive_sel_3v3);
794  		break;
795  	case RTSX_RTS5227:
796  	case RTSX_RTS522A:
797  		sc->rtsx_sd30_drive_sel_3v3 = RTSX_CFG_DRIVER_TYPE_B;
798  		reg = pci_read_config(sc->rtsx_dev, RTSX_PCR_SETTING_REG1, 4);
799  		if (!(reg & 0x1000000)) {
800  			sc->rtsx_card_drive_sel &= 0x3F;
801  			sc->rtsx_card_drive_sel |= ((reg >> 25) & 0x01) << 6;
802  			reg = pci_read_config(sc->rtsx_dev, RTSX_PCR_SETTING_REG2, 4);
803  			sc->rtsx_sd30_drive_sel_3v3 = (reg >> 5) & 0x03;
804  			if (reg & 0x4000)
805  				sc->rtsx_flags |= RTSX_F_REVERSE_SOCKET;
806  		} else if (bootverbose || sc->rtsx_debug_mask & RTSX_DEBUG_BASIC) {
807  			device_printf(sc->rtsx_dev, "pci_read_config() error - reg: 0x%08x\n", reg);
808  		}
809  		if (bootverbose || sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
810  			device_printf(sc->rtsx_dev,
811  				      "card_drive_sel: 0x%02x, sd30_drive_sel_3v3: 0x%02x, reverse_socket is %s\n",
812  				      sc->rtsx_card_drive_sel, sc->rtsx_sd30_drive_sel_3v3,
813  				      (sc->rtsx_flags & RTSX_F_REVERSE_SOCKET) ? "true" : "false");
814  		break;
815  	case RTSX_RTS5229:
816  		sc->rtsx_sd30_drive_sel_3v3 = RTSX_DRIVER_TYPE_D;
817  		reg = pci_read_config(sc->rtsx_dev, RTSX_PCR_SETTING_REG1, 4);
818  		if (!(reg & 0x1000000)) {
819  			sc->rtsx_card_drive_sel &= 0x3F;
820  			sc->rtsx_card_drive_sel |= ((reg >> 25) & 0x01) << 6;
821  			reg = pci_read_config(sc->rtsx_dev, RTSX_PCR_SETTING_REG2, 4);
822  			sc->rtsx_sd30_drive_sel_3v3 = rtsx_map_sd_drive((reg >> 5) & 0x03);
823  		} else if (bootverbose || sc->rtsx_debug_mask & RTSX_DEBUG_BASIC) {
824  			device_printf(sc->rtsx_dev, "pci_read_config() error - reg: 0x%08x\n", reg);
825  		}
826  		if (bootverbose || sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
827  			device_printf(sc->rtsx_dev, "card_drive_sel: 0x%02x, sd30_drive_sel_3v3: 0x%02x\n",
828  				      sc->rtsx_card_drive_sel, sc->rtsx_sd30_drive_sel_3v3);
829  		break;
830  	case RTSX_RTS525A:
831  	case RTSX_RTS5249:
832  	case RTSX_RTS5260:
833  		sc->rtsx_sd30_drive_sel_3v3 = RTSX_CFG_DRIVER_TYPE_B;
834  		reg = pci_read_config(sc->rtsx_dev, RTSX_PCR_SETTING_REG1, 4);
835  		if ((reg & 0x1000000)) {
836  			sc->rtsx_card_drive_sel &= 0x3F;
837  			sc->rtsx_card_drive_sel |= ((reg >> 25) & 0x01) << 6;
838  			reg = pci_read_config(sc->rtsx_dev, RTSX_PCR_SETTING_REG2, 4);
839  			sc->rtsx_sd30_drive_sel_3v3 = (reg >> 5) & 0x03;
840  			if (reg & 0x4000)
841  				sc->rtsx_flags |= RTSX_F_REVERSE_SOCKET;
842  		} else if (bootverbose || sc->rtsx_debug_mask & RTSX_DEBUG_BASIC) {
843  			device_printf(sc->rtsx_dev, "pci_read_config() error - reg: 0x%08x\n", reg);
844  		}
845  		if (bootverbose || sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
846  			device_printf(sc->rtsx_dev,
847  				      "card_drive_sel = 0x%02x, sd30_drive_sel_3v3: 0x%02x, reverse_socket is %s\n",
848  				      sc->rtsx_card_drive_sel, sc->rtsx_sd30_drive_sel_3v3,
849  				      (sc->rtsx_flags & RTSX_F_REVERSE_SOCKET) ? "true" : "false");
850  		break;
851  	case RTSX_RTL8402:
852  	case RTSX_RTL8411:
853  		sc->rtsx_card_drive_sel = RTSX_RTL8411_CARD_DRIVE_DEFAULT;
854  		sc->rtsx_sd30_drive_sel_3v3 = RTSX_DRIVER_TYPE_D;
855  		reg1 = pci_read_config(sc->rtsx_dev, RTSX_PCR_SETTING_REG1, 4);
856  		if (reg1 & 0x1000000) {
857  			sc->rtsx_card_drive_sel &= 0x3F;
858  			sc->rtsx_card_drive_sel |= ((reg1 >> 25) & 0x01) << 6;
859  			reg3 = pci_read_config(sc->rtsx_dev, RTSX_PCR_SETTING_REG3, 1);
860  			sc->rtsx_sd30_drive_sel_3v3 = (reg3 >> 5) & 0x07;
861  		} else if (bootverbose || sc->rtsx_debug_mask & RTSX_DEBUG_BASIC) {
862  			device_printf(sc->rtsx_dev, "pci_read_config() error - reg1: 0x%08x\n", reg1);
863  		}
864  		if (bootverbose || sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
865  			device_printf(sc->rtsx_dev,
866  				      "card_drive_sel: 0x%02x, sd30_drive_sel_3v3: 0x%02x\n",
867  				      sc->rtsx_card_drive_sel, sc->rtsx_sd30_drive_sel_3v3);
868  		break;
869  	case RTSX_RTL8411B:
870  		sc->rtsx_card_drive_sel = RTSX_RTL8411_CARD_DRIVE_DEFAULT;
871  		sc->rtsx_sd30_drive_sel_3v3 = RTSX_DRIVER_TYPE_D;
872  		reg = pci_read_config(sc->rtsx_dev, RTSX_PCR_SETTING_REG1, 4);
873  		if (!(reg & 0x1000000)) {
874  			sc->rtsx_sd30_drive_sel_3v3 = rtsx_map_sd_drive(reg & 0x03);
875  		} else if (bootverbose || sc->rtsx_debug_mask & RTSX_DEBUG_BASIC) {
876  			device_printf(sc->rtsx_dev, "pci_read_config() error - reg: 0x%08x\n", reg);
877  		}
878  		if (bootverbose || sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
879  			device_printf(sc->rtsx_dev,
880  				      "card_drive_sel: 0x%02x, sd30_drive_sel_3v3: 0x%02x\n",
881  				      sc->rtsx_card_drive_sel, sc->rtsx_sd30_drive_sel_3v3);
882  		break;
883  	}
884  
885  	if (bootverbose || sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
886  		device_printf(sc->rtsx_dev, "rtsx_init() rtsx_flags: 0x%04x\n", sc->rtsx_flags);
887  
888  	/* Enable interrupts. */
889  	sc->rtsx_intr_enabled = RTSX_TRANS_OK_INT_EN | RTSX_TRANS_FAIL_INT_EN | RTSX_SD_INT_EN;
890  	WRITE4(sc, RTSX_BIER, sc->rtsx_intr_enabled);
891  
892  	/* Power on SSC clock. */
893  	RTSX_CLR(sc, RTSX_FPDCTL, RTSX_SSC_POWER_DOWN);
894  	/* Wait SSC power stable. */
895  	DELAY(200);
896  
897  	/* Disable ASPM */
898  	val = pci_read_config(sc->rtsx_dev, sc->rtsx_pcie_cap + PCIER_LINK_CTL, 1);
899  	pci_write_config(sc->rtsx_dev, sc->rtsx_pcie_cap + PCIER_LINK_CTL, val & 0xfc, 1);
900  
901  	/*
902  	 * Optimize phy.
903  	 */
904  	switch (sc->rtsx_device_id) {
905  	case RTSX_RTS5209:
906  		/* Some magic numbers from Linux driver. */
907  		if ((error = rtsx_write_phy(sc, 0x00, 0xB966)))
908  			return (error);
909  		break;
910  	case RTSX_RTS5227:
911  		RTSX_CLR(sc, RTSX_PM_CTRL3, RTSX_D3_DELINK_MODE_EN);
912  
913  		/* Optimize RX sensitivity. */
914  		if ((error = rtsx_write_phy(sc, 0x00, 0xBA42)))
915  			return (error);
916  		break;
917  	case RTSX_RTS5229:
918  		/* Optimize RX sensitivity. */
919  		if ((error = rtsx_write_phy(sc, 0x00, 0xBA42)))
920  			return (error);
921  		break;
922  	case RTSX_RTS522A:
923  		RTSX_CLR(sc, RTSX_RTS522A_PM_CTRL3, RTSX_D3_DELINK_MODE_EN);
924  		if (sc->rtsx_flags & RTSX_F_VERSION_A) {
925  			if ((error = rtsx_write_phy(sc, RTSX_PHY_RCR2, RTSX_PHY_RCR2_INIT_27S)))
926  				return (error);
927  		}
928  		if ((error = rtsx_write_phy(sc, RTSX_PHY_RCR1, RTSX_PHY_RCR1_INIT_27S)))
929  			return (error);
930  		if ((error = rtsx_write_phy(sc, RTSX_PHY_FLD0, RTSX_PHY_FLD0_INIT_27S)))
931  			return (error);
932  		if ((error = rtsx_write_phy(sc, RTSX_PHY_FLD3, RTSX_PHY_FLD3_INIT_27S)))
933  			return (error);
934  		if ((error = rtsx_write_phy(sc, RTSX_PHY_FLD4, RTSX_PHY_FLD4_INIT_27S)))
935  			return (error);
936  		break;
937  	case RTSX_RTS525A:
938  		if ((error = rtsx_write_phy(sc, RTSX__PHY_FLD0,
939  					    RTSX__PHY_FLD0_CLK_REQ_20C | RTSX__PHY_FLD0_RX_IDLE_EN |
940  					    RTSX__PHY_FLD0_BIT_ERR_RSTN | RTSX__PHY_FLD0_BER_COUNT |
941  					    RTSX__PHY_FLD0_BER_TIMER | RTSX__PHY_FLD0_CHECK_EN)))
942  			return (error);
943  		if ((error = rtsx_write_phy(sc, RTSX__PHY_ANA03,
944  					    RTSX__PHY_ANA03_TIMER_MAX | RTSX__PHY_ANA03_OOBS_DEB_EN |
945  					    RTSX__PHY_CMU_DEBUG_EN)))
946  			return (error);
947  		if (sc->rtsx_flags & RTSX_F_VERSION_A)
948  			if ((error = rtsx_write_phy(sc, RTSX__PHY_REV0,
949  						    RTSX__PHY_REV0_FILTER_OUT | RTSX__PHY_REV0_CDR_BYPASS_PFD |
950  						    RTSX__PHY_REV0_CDR_RX_IDLE_BYPASS)))
951  				return (error);
952  		break;
953  	case RTSX_RTS5249:
954  		RTSX_CLR(sc, RTSX_PM_CTRL3, RTSX_D3_DELINK_MODE_EN);
955  		if ((error = rtsx_write_phy(sc, RTSX_PHY_REV,
956  					    RTSX_PHY_REV_RESV | RTSX_PHY_REV_RXIDLE_LATCHED |
957  					    RTSX_PHY_REV_P1_EN | RTSX_PHY_REV_RXIDLE_EN |
958  					    RTSX_PHY_REV_CLKREQ_TX_EN | RTSX_PHY_REV_RX_PWST |
959  					    RTSX_PHY_REV_CLKREQ_DT_1_0 | RTSX_PHY_REV_STOP_CLKRD |
960  					    RTSX_PHY_REV_STOP_CLKWR)))
961  			return (error);
962  		DELAY(1000);
963  		if ((error = rtsx_write_phy(sc, RTSX_PHY_BPCR,
964  					    RTSX_PHY_BPCR_IBRXSEL | RTSX_PHY_BPCR_IBTXSEL |
965  					    RTSX_PHY_BPCR_IB_FILTER | RTSX_PHY_BPCR_CMIRROR_EN)))
966  			return (error);
967  		if ((error = rtsx_write_phy(sc, RTSX_PHY_PCR,
968  					    RTSX_PHY_PCR_FORCE_CODE | RTSX_PHY_PCR_OOBS_CALI_50 |
969  					    RTSX_PHY_PCR_OOBS_VCM_08 | RTSX_PHY_PCR_OOBS_SEN_90 |
970  					    RTSX_PHY_PCR_RSSI_EN | RTSX_PHY_PCR_RX10K)))
971  			return (error);
972  		if ((error = rtsx_write_phy(sc, RTSX_PHY_RCR2,
973  					    RTSX_PHY_RCR2_EMPHASE_EN | RTSX_PHY_RCR2_NADJR |
974  					    RTSX_PHY_RCR2_CDR_SR_2 | RTSX_PHY_RCR2_FREQSEL_12 |
975  					    RTSX_PHY_RCR2_CDR_SC_12P | RTSX_PHY_RCR2_CALIB_LATE)))
976  			return (error);
977  		if ((error = rtsx_write_phy(sc, RTSX_PHY_FLD4,
978  					    RTSX_PHY_FLD4_FLDEN_SEL | RTSX_PHY_FLD4_REQ_REF |
979  					    RTSX_PHY_FLD4_RXAMP_OFF | RTSX_PHY_FLD4_REQ_ADDA |
980  					    RTSX_PHY_FLD4_BER_COUNT | RTSX_PHY_FLD4_BER_TIMER |
981  					    RTSX_PHY_FLD4_BER_CHK_EN)))
982  			return (error);
983  		if ((error = rtsx_write_phy(sc, RTSX_PHY_RDR,
984  					    RTSX_PHY_RDR_RXDSEL_1_9 | RTSX_PHY_SSC_AUTO_PWD)))
985  			return (error);
986  		if ((error = rtsx_write_phy(sc, RTSX_PHY_RCR1,
987  					    RTSX_PHY_RCR1_ADP_TIME_4 | RTSX_PHY_RCR1_VCO_COARSE)))
988  			return (error);
989  		if ((error = rtsx_write_phy(sc, RTSX_PHY_FLD3,
990  					    RTSX_PHY_FLD3_TIMER_4 | RTSX_PHY_FLD3_TIMER_6 |
991  					    RTSX_PHY_FLD3_RXDELINK)))
992  			return (error);
993  		if ((error = rtsx_write_phy(sc, RTSX_PHY_TUNE,
994  					    RTSX_PHY_TUNE_TUNEREF_1_0 | RTSX_PHY_TUNE_VBGSEL_1252 |
995  					    RTSX_PHY_TUNE_SDBUS_33 | RTSX_PHY_TUNE_TUNED18 |
996  					    RTSX_PHY_TUNE_TUNED12 | RTSX_PHY_TUNE_TUNEA12)))
997  			return (error);
998  		break;
999  	}
1000  
1001  	/* Set mcu_cnt to 7 to ensure data can be sampled properly. */
1002  	RTSX_BITOP(sc, RTSX_CLK_DIV, 0x07, 0x07);
1003  
1004  	/* Disable sleep mode. */
1005  	RTSX_CLR(sc, RTSX_HOST_SLEEP_STATE,
1006  		 RTSX_HOST_ENTER_S1 | RTSX_HOST_ENTER_S3);
1007  
1008  	/* Disable card clock. */
1009  	RTSX_CLR(sc, RTSX_CARD_CLK_EN, RTSX_CARD_CLK_EN_ALL);
1010  
1011  	/* Reset delink mode. */
1012  	RTSX_CLR(sc, RTSX_CHANGE_LINK_STATE,
1013  		 RTSX_FORCE_RST_CORE_EN | RTSX_NON_STICKY_RST_N_DBG);
1014  
1015  	/* Card driving select. */
1016  	RTSX_WRITE(sc, RTSX_CARD_DRIVE_SEL, sc->rtsx_card_drive_sel);
1017  
1018  	/* Enable SSC clock. */
1019  	RTSX_WRITE(sc, RTSX_SSC_CTL1, RTSX_SSC_8X_EN | RTSX_SSC_SEL_4M);
1020  	RTSX_WRITE(sc, RTSX_SSC_CTL2, 0x12);
1021  
1022  	/* Disable cd_pwr_save. */
1023  	RTSX_BITOP(sc, RTSX_CHANGE_LINK_STATE, 0x16, RTSX_MAC_PHY_RST_N_DBG);
1024  
1025  	/* Clear Link Ready Interrupt. */
1026  	RTSX_BITOP(sc, RTSX_IRQSTAT0, RTSX_LINK_READY_INT, RTSX_LINK_READY_INT);
1027  
1028  	/* Enlarge the estimation window of PERST# glitch
1029  	 * to reduce the chance of invalid card interrupt. */
1030  	RTSX_WRITE(sc, RTSX_PERST_GLITCH_WIDTH, 0x80);
1031  
1032  	/* Set RC oscillator to 400K. */
1033  	RTSX_CLR(sc, RTSX_RCCTL, RTSX_RCCTL_F_2M);
1034  
1035  	/* Enable interrupt write-clear (default is read-clear). */
1036  	RTSX_CLR(sc, RTSX_NFTS_TX_CTRL, RTSX_INT_READ_CLR);
1037  
1038  	switch (sc->rtsx_device_id) {
1039  	case RTSX_RTS525A:
1040  	case RTSX_RTS5260:
1041  		RTSX_BITOP(sc, RTSX_PM_CLK_FORCE_CTL, 1, 1);
1042  		break;
1043  	}
1044  
1045  	/* OC power down. */
1046  	RTSX_BITOP(sc, RTSX_FPDCTL, RTSX_SD_OC_POWER_DOWN, RTSX_SD_OC_POWER_DOWN);
1047  
1048  	/* Enable clk_request_n to enable clock power management */
1049  	pci_write_config(sc->rtsx_dev, sc->rtsx_pcie_cap + PCIER_LINK_CTL + 1, 1, 1);
1050  
1051  	/* Enter L1 when host tx idle */
1052  	pci_write_config(sc->rtsx_dev, 0x70F, 0x5B, 1);
1053  
1054  	/*
1055  	 * Specific extra init.
1056  	 */
1057  	switch (sc->rtsx_device_id) {
1058  		uint16_t cap;
1059  	case RTSX_RTS5209:
1060  		/* Turn off LED. */
1061  		RTSX_WRITE(sc, RTSX_CARD_GPIO, 0x03);
1062  		/* Reset ASPM state to default value. */
1063  		RTSX_CLR(sc, RTSX_ASPM_FORCE_CTL, RTSX_ASPM_FORCE_MASK);
1064  		/* Force CLKREQ# PIN to drive 0 to request clock. */
1065  		RTSX_BITOP(sc, RTSX_PETXCFG, 0x08, 0x08);
1066  		/* Configure GPIO as output. */
1067  		RTSX_WRITE(sc, RTSX_CARD_GPIO_DIR, 0x03);
1068  		/* Configure driving. */
1069  		RTSX_WRITE(sc, RTSX_SD30_CMD_DRIVE_SEL, sc->rtsx_sd30_drive_sel_3v3);
1070  		break;
1071  	case RTSX_RTS5227:
1072  		/* Configure GPIO as output. */
1073  		RTSX_BITOP(sc, RTSX_GPIO_CTL, RTSX_GPIO_LED_ON, RTSX_GPIO_LED_ON);
1074  		/* Reset ASPM state to default value. */
1075  		RTSX_BITOP(sc, RTSX_ASPM_FORCE_CTL, RTSX_ASPM_FORCE_MASK, RTSX_FORCE_ASPM_NO_ASPM);
1076  		/* Switch LDO3318 source from DV33 to 3V3. */
1077  		RTSX_CLR(sc, RTSX_LDO_PWR_SEL, RTSX_LDO_PWR_SEL_DV33);
1078  		RTSX_BITOP(sc, RTSX_LDO_PWR_SEL, RTSX_LDO_PWR_SEL_DV33, RTSX_LDO_PWR_SEL_3V3);
1079  		/* Set default OLT blink period. */
1080  		RTSX_BITOP(sc, RTSX_OLT_LED_CTL, 0x0F, RTSX_OLT_LED_PERIOD);
1081  		/* Configure LTR. */
1082  		cap = pci_read_config(sc->rtsx_dev, sc->rtsx_pcie_cap + PCIER_DEVICE_CTL2, 2);
1083  		if (cap & PCIEM_CTL2_LTR_ENABLE)
1084  			RTSX_WRITE(sc, RTSX_LTR_CTL, 0xa3);
1085  		/* Configure OBFF. */
1086  		RTSX_BITOP(sc, RTSX_OBFF_CFG, RTSX_OBFF_EN_MASK, RTSX_OBFF_ENABLE);
1087  		/* Configure driving. */
1088  		if ((error = rtsx_rts5227_fill_driving(sc)))
1089  			return (error);
1090  		/* Configure force_clock_req. */
1091  		if (sc->rtsx_flags & RTSX_F_REVERSE_SOCKET)
1092  			RTSX_BITOP(sc, RTSX_PETXCFG, 0xB8, 0xB8);
1093  		else
1094  			RTSX_BITOP(sc, RTSX_PETXCFG, 0xB8, 0x88);
1095  		RTSX_CLR(sc, RTSX_PM_CTRL3, RTSX_D3_DELINK_MODE_EN);
1096  		/*!!! Added for reboot after Windows. */
1097  		RTSX_BITOP(sc, RTSX_PM_CTRL3, RTSX_PM_WAKE_EN, RTSX_PM_WAKE_EN);
1098  		break;
1099  	case RTSX_RTS5229:
1100  		/* Configure GPIO as output. */
1101  		RTSX_BITOP(sc, RTSX_GPIO_CTL, RTSX_GPIO_LED_ON, RTSX_GPIO_LED_ON);
1102  		/* Reset ASPM state to default value. */
1103  		/*  With this reset: dd if=/dev/random of=/dev/mmcsd0 encounter a timeout. */
1104  //!!!		RTSX_BITOP(sc, RTSX_ASPM_FORCE_CTL, RTSX_ASPM_FORCE_MASK, RTSX_FORCE_ASPM_NO_ASPM);
1105  		/* Force CLKREQ# PIN to drive 0 to request clock. */
1106  		RTSX_BITOP(sc, RTSX_PETXCFG, 0x08, 0x08);
1107  		/* Switch LDO3318 source from DV33 to card_3v3. */
1108  		RTSX_CLR(sc, RTSX_LDO_PWR_SEL, RTSX_LDO_PWR_SEL_DV33);
1109  		RTSX_BITOP(sc, RTSX_LDO_PWR_SEL, RTSX_LDO_PWR_SEL_DV33, RTSX_LDO_PWR_SEL_3V3);
1110  		/* Set default OLT blink period. */
1111  		RTSX_BITOP(sc, RTSX_OLT_LED_CTL, 0x0F, RTSX_OLT_LED_PERIOD);
1112  		/* Configure driving. */
1113  		RTSX_WRITE(sc, RTSX_SD30_CMD_DRIVE_SEL, sc->rtsx_sd30_drive_sel_3v3);
1114  		break;
1115  	case RTSX_RTS522A:
1116  		/* Add specific init from RTS5227. */
1117  		/* Configure GPIO as output. */
1118  		RTSX_BITOP(sc, RTSX_GPIO_CTL, RTSX_GPIO_LED_ON, RTSX_GPIO_LED_ON);
1119  		/* Reset ASPM state to default value. */
1120  		RTSX_BITOP(sc, RTSX_ASPM_FORCE_CTL, RTSX_ASPM_FORCE_MASK, RTSX_FORCE_ASPM_NO_ASPM);
1121  		/* Switch LDO3318 source from DV33 to 3V3. */
1122  		RTSX_CLR(sc, RTSX_LDO_PWR_SEL, RTSX_LDO_PWR_SEL_DV33);
1123  		RTSX_BITOP(sc, RTSX_LDO_PWR_SEL, RTSX_LDO_PWR_SEL_DV33, RTSX_LDO_PWR_SEL_3V3);
1124  		/* Set default OLT blink period. */
1125  		RTSX_BITOP(sc, RTSX_OLT_LED_CTL, 0x0F, RTSX_OLT_LED_PERIOD);
1126  		/* Configure LTR. */
1127  		cap = pci_read_config(sc->rtsx_dev, sc->rtsx_pcie_cap + PCIER_DEVICE_CTL2, 2);
1128  		if (cap & PCIEM_CTL2_LTR_ENABLE)
1129  			RTSX_WRITE(sc, RTSX_LTR_CTL, 0xa3);
1130  		/* Configure OBFF. */
1131  		RTSX_BITOP(sc, RTSX_OBFF_CFG, RTSX_OBFF_EN_MASK, RTSX_OBFF_ENABLE);
1132  		/* Configure driving. */
1133  		if ((error = rtsx_rts5227_fill_driving(sc)))
1134  			return (error);
1135  		/* Configure force_clock_req. */
1136  		if (sc->rtsx_flags & RTSX_F_REVERSE_SOCKET)
1137  			RTSX_BITOP(sc, RTSX_PETXCFG, 0xB8, 0xB8);
1138  		else
1139  			RTSX_BITOP(sc, RTSX_PETXCFG, 0xB8, 0x88);
1140  		RTSX_CLR(sc, RTSX_RTS522A_PM_CTRL3,  0x10);
1141  
1142  		/* specific for RTS522A. */
1143  		RTSX_BITOP(sc, RTSX_FUNC_FORCE_CTL,
1144  			   RTSX_FUNC_FORCE_UPME_XMT_DBG, RTSX_FUNC_FORCE_UPME_XMT_DBG);
1145  		RTSX_BITOP(sc, RTSX_PCLK_CTL, 0x04, 0x04);
1146  		RTSX_BITOP(sc, RTSX_PM_EVENT_DEBUG,
1147  			   RTSX_PME_DEBUG_0, RTSX_PME_DEBUG_0);
1148  		RTSX_WRITE(sc, RTSX_PM_CLK_FORCE_CTL, 0x11);
1149  		break;
1150  	case RTSX_RTS525A:
1151  		/* Add specific init from RTS5249. */
1152  		/* Rest L1SUB Config. */
1153  		RTSX_CLR(sc, RTSX_L1SUB_CONFIG3, 0xff);
1154  		/* Configure GPIO as output. */
1155  		RTSX_BITOP(sc, RTSX_GPIO_CTL, RTSX_GPIO_LED_ON, RTSX_GPIO_LED_ON);
1156  		/* Reset ASPM state to default value. */
1157  		RTSX_BITOP(sc, RTSX_ASPM_FORCE_CTL, RTSX_ASPM_FORCE_MASK, RTSX_FORCE_ASPM_NO_ASPM);
1158  		/* Switch LDO3318 source from DV33 to 3V3. */
1159  		RTSX_CLR(sc, RTSX_LDO_PWR_SEL, RTSX_LDO_PWR_SEL_DV33);
1160  		RTSX_BITOP(sc, RTSX_LDO_PWR_SEL, RTSX_LDO_PWR_SEL_DV33, RTSX_LDO_PWR_SEL_3V3);
1161  		/* Set default OLT blink period. */
1162  		RTSX_BITOP(sc, RTSX_OLT_LED_CTL, 0x0F, RTSX_OLT_LED_PERIOD);
1163  		/* Configure driving. */
1164  		if ((error = rtsx_rts5249_fill_driving(sc)))
1165  			return (error);
1166  		/* Configure force_clock_req. */
1167  		if (sc->rtsx_flags & RTSX_F_REVERSE_SOCKET)
1168  			RTSX_BITOP(sc, RTSX_PETXCFG, 0xB0, 0xB0);
1169  		else
1170  			RTSX_BITOP(sc, RTSX_PETXCFG, 0xB0, 0x80);
1171  
1172  		/* Specifc for RTS525A. */
1173  		RTSX_BITOP(sc, RTSX_PCLK_CTL, RTSX_PCLK_MODE_SEL, RTSX_PCLK_MODE_SEL);
1174  		if (sc->rtsx_flags & RTSX_F_VERSION_A) {
1175  			RTSX_WRITE(sc, RTSX_L1SUB_CONFIG2, RTSX_L1SUB_AUTO_CFG);
1176  			RTSX_BITOP(sc, RTSX_RREF_CFG,
1177  				   RTSX_RREF_VBGSEL_MASK, RTSX_RREF_VBGSEL_1V25);
1178  			RTSX_BITOP(sc, RTSX_LDO_VIO_CFG,
1179  				   RTSX_LDO_VIO_TUNE_MASK, RTSX_LDO_VIO_1V7);
1180  			RTSX_BITOP(sc, RTSX_LDO_DV12S_CFG,
1181  				   RTSX_LDO_D12_TUNE_MASK, RTSX_LDO_D12_TUNE_DF);
1182  			RTSX_BITOP(sc, RTSX_LDO_AV12S_CFG,
1183  				   RTSX_LDO_AV12S_TUNE_MASK, RTSX_LDO_AV12S_TUNE_DF);
1184  			RTSX_BITOP(sc, RTSX_LDO_VCC_CFG0,
1185  				   RTSX_LDO_VCC_LMTVTH_MASK, RTSX_LDO_VCC_LMTVTH_2A);
1186  			RTSX_BITOP(sc, RTSX_OOBS_CONFIG,
1187  				   RTSX_OOBS_AUTOK_DIS | RTSX_OOBS_VAL_MASK, 0x89);
1188  		}
1189  		break;
1190  	case RTSX_RTS5249:
1191  		/* Rest L1SUB Config. */
1192  		RTSX_CLR(sc, RTSX_L1SUB_CONFIG3, 0xff);
1193  		/* Configure GPIO as output. */
1194  		RTSX_BITOP(sc, RTSX_GPIO_CTL, RTSX_GPIO_LED_ON, RTSX_GPIO_LED_ON);
1195  		/* Reset ASPM state to default value. */
1196  		RTSX_BITOP(sc, RTSX_ASPM_FORCE_CTL, RTSX_ASPM_FORCE_MASK, RTSX_FORCE_ASPM_NO_ASPM);
1197  		/* Switch LDO3318 source from DV33 to 3V3. */
1198  		RTSX_CLR(sc, RTSX_LDO_PWR_SEL, RTSX_LDO_PWR_SEL_DV33);
1199  		RTSX_BITOP(sc, RTSX_LDO_PWR_SEL, RTSX_LDO_PWR_SEL_DV33, RTSX_LDO_PWR_SEL_3V3);
1200  		/* Set default OLT blink period. */
1201  		RTSX_BITOP(sc, RTSX_OLT_LED_CTL, 0x0F, RTSX_OLT_LED_PERIOD);
1202  		/* Configure driving. */
1203  		if ((error = rtsx_rts5249_fill_driving(sc)))
1204  			return (error);
1205  		/* Configure force_clock_req. */
1206  		if (sc->rtsx_flags & RTSX_F_REVERSE_SOCKET)
1207  			RTSX_BITOP(sc, RTSX_PETXCFG, 0xB0, 0xB0);
1208  		else
1209  			RTSX_BITOP(sc, RTSX_PETXCFG, 0xB0, 0x80);
1210  		break;
1211  	case RTSX_RTS5260:
1212  		/* Set mcu_cnt to 7 to ensure data can be sampled properly. */
1213  		RTSX_BITOP(sc, RTSX_CLK_DIV, 0x07, 0x07);
1214  		RTSX_WRITE(sc, RTSX_SSC_DIV_N_0, 0x5D);
1215  		/* Force no MDIO */
1216  		RTSX_WRITE(sc, RTSX_RTS5260_AUTOLOAD_CFG4, RTSX_RTS5260_MIMO_DISABLE);
1217  		/* Modify SDVCC Tune Default Parameters! */
1218  		RTSX_BITOP(sc, RTSX_LDO_VCC_CFG0, RTSX_RTS5260_DVCC_TUNE_MASK, RTSX_RTS5260_DVCC_33);
1219  
1220  		RTSX_BITOP(sc, RTSX_PCLK_CTL, RTSX_PCLK_MODE_SEL, RTSX_PCLK_MODE_SEL);
1221  
1222  		RTSX_BITOP(sc, RTSX_L1SUB_CONFIG1, RTSX_AUX_CLK_ACTIVE_SEL_MASK, RTSX_MAC_CKSW_DONE);
1223  		/* Rest L1SUB Config */
1224  		RTSX_CLR(sc, RTSX_L1SUB_CONFIG3, 0xFF);
1225  		RTSX_BITOP(sc, RTSX_PM_CLK_FORCE_CTL, RTSX_CLK_PM_EN, RTSX_CLK_PM_EN);
1226  		RTSX_WRITE(sc, RTSX_PWD_SUSPEND_EN, 0xFF);
1227  		RTSX_BITOP(sc, RTSX_PWR_GATE_CTRL, RTSX_PWR_GATE_EN, RTSX_PWR_GATE_EN);
1228  		RTSX_BITOP(sc, RTSX_REG_VREF, RTSX_PWD_SUSPND_EN, RTSX_PWD_SUSPND_EN);
1229  		RTSX_BITOP(sc, RTSX_RBCTL, RTSX_U_AUTO_DMA_EN_MASK, RTSX_U_AUTO_DMA_DISABLE);
1230  		if (sc->rtsx_flags & RTSX_F_REVERSE_SOCKET)
1231  			RTSX_BITOP(sc, RTSX_PETXCFG, 0xB0, 0xB0);
1232  		else
1233  			RTSX_BITOP(sc, RTSX_PETXCFG, 0xB0, 0x80);
1234  		RTSX_BITOP(sc, RTSX_OBFF_CFG, RTSX_OBFF_EN_MASK, RTSX_OBFF_DISABLE);
1235  
1236  		RTSX_CLR(sc, RTSX_RTS5260_DVCC_CTRL, RTSX_RTS5260_DVCC_OCP_EN | RTSX_RTS5260_DVCC_OCP_CL_EN);
1237  
1238  		/* CLKREQ# PIN will be forced to drive low. */
1239  		RTSX_BITOP(sc, RTSX_PETXCFG, RTSX_FORCE_CLKREQ_DELINK_MASK, RTSX_FORCE_CLKREQ_LOW);
1240  
1241  		RTSX_CLR(sc, RTSX_RTS522A_PM_CTRL3,  0x10);
1242  		break;
1243  	case RTSX_RTL8402:
1244  	case RTSX_RTL8411:
1245  		RTSX_WRITE(sc, RTSX_SD30_CMD_DRIVE_SEL, sc->rtsx_sd30_drive_sel_3v3);
1246  		RTSX_BITOP(sc, RTSX_CARD_PAD_CTL, RTSX_CD_DISABLE_MASK | RTSX_CD_AUTO_DISABLE,
1247  			   RTSX_CD_ENABLE);
1248  		break;
1249  	case RTSX_RTL8411B:
1250  		if (sc->rtsx_flags & RTSX_F_8411B_QFN48)
1251  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL3, 0xf5);
1252  		RTSX_WRITE(sc, RTSX_SD30_CMD_DRIVE_SEL, sc->rtsx_sd30_drive_sel_3v3);
1253  		/* Enable SD interrupt. */
1254  		RTSX_BITOP(sc, RTSX_CARD_PAD_CTL, RTSX_CD_DISABLE_MASK | RTSX_CD_AUTO_DISABLE,
1255  			   RTSX_CD_ENABLE);
1256  		/* Clear hw_pfm_en to disable hardware PFM mode. */
1257  		RTSX_BITOP(sc, RTSX_FUNC_FORCE_CTL, 0x06, 0x00);
1258  		break;
1259  	}
1260  
1261  	/*!!! Added for reboot after Windows. */
1262  	rtsx_bus_power_off(sc);
1263  	rtsx_set_sd_timing(sc, bus_timing_normal);
1264  	rtsx_set_sd_clock(sc, 0);
1265  	/*!!! Added for reboot after Windows. */
1266  
1267  	return (0);
1268  }
1269  
1270  static int
1271  rtsx_map_sd_drive(int index)
1272  {
1273  	uint8_t	sd_drive[4] =
1274  		{
1275  		 0x01,	/* Type D */
1276  		 0x02,	/* Type C */
1277  		 0x05,	/* Type A */
1278  		 0x03	/* Type B */
1279  		};
1280  	return (sd_drive[index]);
1281  }
1282  
1283  /* For voltage 3v3. */
1284  static int
1285  rtsx_rts5227_fill_driving(struct rtsx_softc *sc)
1286  {
1287  	u_char	driving_3v3[4][3] = {
1288  				     {0x13, 0x13, 0x13},
1289  				     {0x96, 0x96, 0x96},
1290  				     {0x7F, 0x7F, 0x7F},
1291  				     {0x96, 0x96, 0x96},
1292  	};
1293  	RTSX_WRITE(sc, RTSX_SD30_CLK_DRIVE_SEL, driving_3v3[sc->rtsx_sd30_drive_sel_3v3][0]);
1294  	RTSX_WRITE(sc, RTSX_SD30_CMD_DRIVE_SEL, driving_3v3[sc->rtsx_sd30_drive_sel_3v3][1]);
1295  	RTSX_WRITE(sc, RTSX_SD30_DAT_DRIVE_SEL, driving_3v3[sc->rtsx_sd30_drive_sel_3v3][2]);
1296  
1297  	return (0);
1298  }
1299  
1300  /* For voltage 3v3. */
1301  static int
1302  rtsx_rts5249_fill_driving(struct rtsx_softc *sc)
1303  {
1304  	u_char	driving_3v3[4][3] = {
1305  				     {0x11, 0x11, 0x18},
1306  				     {0x55, 0x55, 0x5C},
1307  				     {0xFF, 0xFF, 0xFF},
1308  				     {0x96, 0x96, 0x96},
1309  	};
1310  	RTSX_WRITE(sc, RTSX_SD30_CLK_DRIVE_SEL, driving_3v3[sc->rtsx_sd30_drive_sel_3v3][0]);
1311  	RTSX_WRITE(sc, RTSX_SD30_CMD_DRIVE_SEL, driving_3v3[sc->rtsx_sd30_drive_sel_3v3][1]);
1312  	RTSX_WRITE(sc, RTSX_SD30_DAT_DRIVE_SEL, driving_3v3[sc->rtsx_sd30_drive_sel_3v3][2]);
1313  
1314  	return (0);
1315  }
1316  
1317  static int
1318  rtsx_rts5260_fill_driving(struct rtsx_softc *sc)
1319  {
1320  	u_char	driving_3v3[4][3] = {
1321  				     {0x11, 0x11, 0x11},
1322  				     {0x22, 0x22, 0x22},
1323  				     {0x55, 0x55, 0x55},
1324  				     {0x33, 0x33, 0x33},
1325  	};
1326  	RTSX_WRITE(sc, RTSX_SD30_CLK_DRIVE_SEL, driving_3v3[sc->rtsx_sd30_drive_sel_3v3][0]);
1327  	RTSX_WRITE(sc, RTSX_SD30_CMD_DRIVE_SEL, driving_3v3[sc->rtsx_sd30_drive_sel_3v3][1]);
1328  	RTSX_WRITE(sc, RTSX_SD30_DAT_DRIVE_SEL, driving_3v3[sc->rtsx_sd30_drive_sel_3v3][2]);
1329  
1330  	return (0);
1331  }
1332  
1333  static int
1334  rtsx_read(struct rtsx_softc *sc, uint16_t addr, uint8_t *val)
1335  {
1336  	int	 tries = 1024;
1337  	uint32_t arg;
1338  	uint32_t reg;
1339  
1340  	arg = RTSX_HAIMR_BUSY | (uint32_t)((addr & 0x3FFF) << 16);
1341  	WRITE4(sc, RTSX_HAIMR, arg);
1342  
1343  	while (tries--) {
1344  		reg = READ4(sc, RTSX_HAIMR);
1345  		if (!(reg & RTSX_HAIMR_BUSY))
1346  			break;
1347  	}
1348  	*val = (reg & 0xff);
1349  
1350  	if (tries > 0) {
1351  		return (0);
1352  	} else {
1353  		device_printf(sc->rtsx_dev, "rtsx_read(0x%x) timeout\n", arg);
1354  		return (ETIMEDOUT);
1355  	}
1356  }
1357  
1358  static int
1359  rtsx_read_cfg(struct rtsx_softc *sc, uint8_t func, uint16_t addr, uint32_t *val)
1360  {
1361  	int	tries = 1024;
1362  	uint8_t	data0, data1, data2, data3, rwctl;
1363  
1364  	RTSX_WRITE(sc, RTSX_CFGADDR0, addr);
1365  	RTSX_WRITE(sc, RTSX_CFGADDR1, addr >> 8);
1366  	RTSX_WRITE(sc, RTSX_CFGRWCTL, RTSX_CFG_BUSY | (func & 0x03 << 4));
1367  
1368  	while (tries--) {
1369  		RTSX_READ(sc, RTSX_CFGRWCTL, &rwctl);
1370  		if (!(rwctl & RTSX_CFG_BUSY))
1371  			break;
1372  	}
1373  
1374  	if (tries == 0)
1375  		return (ETIMEDOUT);
1376  
1377  	RTSX_READ(sc, RTSX_CFGDATA0, &data0);
1378  	RTSX_READ(sc, RTSX_CFGDATA1, &data1);
1379  	RTSX_READ(sc, RTSX_CFGDATA2, &data2);
1380  	RTSX_READ(sc, RTSX_CFGDATA3, &data3);
1381  
1382  	*val = (data3 << 24) | (data2 << 16) | (data1 << 8) | data0;
1383  
1384  	return (0);
1385  }
1386  
1387  static int
1388  rtsx_write(struct rtsx_softc *sc, uint16_t addr, uint8_t mask, uint8_t val)
1389  {
1390  	int 	 tries = 1024;
1391  	uint32_t arg;
1392  	uint32_t reg;
1393  
1394  	arg = RTSX_HAIMR_BUSY | RTSX_HAIMR_WRITE |
1395  		(uint32_t)(((addr & 0x3FFF) << 16) |
1396  			   (mask << 8) | val);
1397  	WRITE4(sc, RTSX_HAIMR, arg);
1398  
1399  	while (tries--) {
1400  		reg = READ4(sc, RTSX_HAIMR);
1401  		if (!(reg & RTSX_HAIMR_BUSY)) {
1402  			if (val != (reg & 0xff)) {
1403  				device_printf(sc->rtsx_dev, "rtsx_write(0x%x) error reg=0x%x\n", arg, reg);
1404  				return (EIO);
1405  			}
1406  			return (0);
1407  		}
1408  	}
1409  	device_printf(sc->rtsx_dev, "rtsx_write(0x%x) timeout\n", arg);
1410  
1411  	return (ETIMEDOUT);
1412  }
1413  
1414  static int
1415  rtsx_read_phy(struct rtsx_softc *sc, uint8_t addr, uint16_t *val)
1416  {
1417  	int	tries = 100000;
1418  	uint8_t	data0, data1, rwctl;
1419  
1420  	RTSX_WRITE(sc, RTSX_PHY_ADDR, addr);
1421  	RTSX_WRITE(sc, RTSX_PHY_RWCTL, RTSX_PHY_BUSY | RTSX_PHY_READ);
1422  
1423  	while (tries--) {
1424  		RTSX_READ(sc, RTSX_PHY_RWCTL, &rwctl);
1425  		if (!(rwctl & RTSX_PHY_BUSY))
1426  			break;
1427  	}
1428  	if (tries == 0)
1429  		return (ETIMEDOUT);
1430  
1431  	RTSX_READ(sc, RTSX_PHY_DATA0, &data0);
1432  	RTSX_READ(sc, RTSX_PHY_DATA1, &data1);
1433  	*val = data1 << 8 | data0;
1434  
1435  	return (0);
1436  }
1437  
1438  static int
1439  rtsx_write_phy(struct rtsx_softc *sc, uint8_t addr, uint16_t val)
1440  {
1441  	int	tries = 100000;
1442  	uint8_t	rwctl;
1443  
1444  	RTSX_WRITE(sc, RTSX_PHY_DATA0, val);
1445  	RTSX_WRITE(sc, RTSX_PHY_DATA1, val >> 8);
1446  	RTSX_WRITE(sc, RTSX_PHY_ADDR, addr);
1447  	RTSX_WRITE(sc, RTSX_PHY_RWCTL, RTSX_PHY_BUSY | RTSX_PHY_WRITE);
1448  
1449  	while (tries--) {
1450  		RTSX_READ(sc, RTSX_PHY_RWCTL, &rwctl);
1451  		if (!(rwctl & RTSX_PHY_BUSY))
1452  			break;
1453  	}
1454  
1455  	return ((tries == 0) ? ETIMEDOUT : 0);
1456  }
1457  
1458  /*
1459   * Notice that the meaning of RTSX_PWR_GATE_CTRL changes between RTS5209 and
1460   * RTS5229. In RTS5209 it is a mask of disabled power gates, while in RTS5229
1461   * it is a mask of *enabled* gates.
1462   */
1463  static int
1464  rtsx_bus_power_off(struct rtsx_softc *sc)
1465  {
1466  	if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
1467  		device_printf(sc->rtsx_dev, "rtsx_bus_power_off()\n");
1468  
1469  	/* Disable SD clock. */
1470  	RTSX_CLR(sc, RTSX_CARD_CLK_EN, RTSX_SD_CLK_EN);
1471  
1472  	/* Disable SD output. */
1473  	RTSX_CLR(sc, RTSX_CARD_OE, RTSX_SD_OUTPUT_EN);
1474  
1475  	/* Turn off power. */
1476  	switch (sc->rtsx_device_id) {
1477  	case RTSX_RTS5209:
1478  		RTSX_BITOP(sc, RTSX_CARD_PWR_CTL, RTSX_SD_PWR_MASK | RTSX_PMOS_STRG_MASK,
1479  			   RTSX_SD_PWR_OFF | RTSX_PMOS_STRG_400mA);
1480  		RTSX_SET(sc, RTSX_PWR_GATE_CTRL, RTSX_LDO3318_OFF);
1481  		break;
1482  	case RTSX_RTS5227:
1483  	case RTSX_RTS5229:
1484  	case RTSX_RTS522A:
1485  		RTSX_BITOP(sc, RTSX_CARD_PWR_CTL, RTSX_SD_PWR_MASK | RTSX_PMOS_STRG_MASK,
1486  			   RTSX_SD_PWR_OFF | RTSX_PMOS_STRG_400mA);
1487  		RTSX_CLR(sc, RTSX_PWR_GATE_CTRL, RTSX_LDO3318_PWR_MASK);
1488  		break;
1489  	case RTSX_RTS5260:
1490  		rtsx_stop_cmd(sc);
1491  		/* Switch vccq to 330 */
1492  		RTSX_BITOP(sc, RTSX_LDO_CONFIG2, RTSX_DV331812_VDD1, RTSX_DV331812_VDD1);
1493  		RTSX_BITOP(sc, RTSX_LDO_DV18_CFG, RTSX_DV331812_MASK, RTSX_DV331812_33);
1494  		RTSX_CLR(sc, RTSX_SD_PAD_CTL, RTSX_SD_IO_USING_1V8);
1495  		rtsx_rts5260_fill_driving(sc);
1496  
1497  		RTSX_BITOP(sc, RTSX_LDO_VCC_CFG1, RTSX_LDO_POW_SDVDD1_MASK, RTSX_LDO_POW_SDVDD1_OFF);
1498  		RTSX_BITOP(sc, RTSX_LDO_CONFIG2, RTSX_DV331812_POWERON, RTSX_DV331812_POWEROFF);
1499  		break;
1500  	case RTSX_RTL8402:
1501  	case RTSX_RTL8411:
1502  	case RTSX_RTL8411B:
1503  		RTSX_BITOP(sc, RTSX_CARD_PWR_CTL, RTSX_BPP_POWER_MASK,
1504  			   RTSX_BPP_POWER_OFF);
1505  		RTSX_BITOP(sc, RTSX_LDO_CTL, RTSX_BPP_LDO_POWB,
1506  			   RTSX_BPP_LDO_SUSPEND);
1507  		break;
1508  	default:
1509  		RTSX_CLR(sc, RTSX_PWR_GATE_CTRL, RTSX_LDO3318_PWR_MASK);
1510  		RTSX_SET(sc, RTSX_CARD_PWR_CTL, RTSX_SD_PWR_OFF);
1511  		RTSX_CLR(sc, RTSX_CARD_PWR_CTL, RTSX_PMOS_STRG_800mA);
1512  		break;
1513  	}
1514  
1515  	/* Disable pull control. */
1516  	switch (sc->rtsx_device_id) {
1517  	case RTSX_RTS5209:
1518  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL1, RTSX_PULL_CTL_DISABLE12);
1519  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL2, RTSX_PULL_CTL_DISABLE12);
1520  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL3, RTSX_PULL_CTL_DISABLE3);
1521  		break;
1522  	case RTSX_RTS5227:
1523  	case RTSX_RTS522A:
1524  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL2, RTSX_PULL_CTL_DISABLE12);
1525  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL3, RTSX_PULL_CTL_DISABLE3);
1526  		break;
1527  	case RTSX_RTS5229:
1528  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL2, RTSX_PULL_CTL_DISABLE12);
1529  		if (sc->rtsx_flags & RTSX_F_VERSION_C)
1530  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL3, RTSX_PULL_CTL_DISABLE3_TYPE_C);
1531  		else
1532  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL3, RTSX_PULL_CTL_DISABLE3);
1533  		break;
1534  	case RTSX_RTS525A:
1535  	case RTSX_RTS5249:
1536  	case RTSX_RTS5260:
1537  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL1, 0x66);
1538  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL2, RTSX_PULL_CTL_DISABLE12);
1539  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL3, RTSX_PULL_CTL_DISABLE3);
1540  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL4, 0x55);
1541  		break;
1542  	case RTSX_RTL8402:
1543  	case RTSX_RTL8411:
1544  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL1, 0x65);
1545  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL2, 0x55);
1546  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL3, 0x95);
1547  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL4, 0x09);
1548  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL5, 0x05);
1549  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL6, 0x04);
1550  		break;
1551  	case RTSX_RTL8411B:
1552  		if (sc->rtsx_flags & RTSX_F_8411B_QFN48) {
1553  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL2, 0x55);
1554  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL3, 0xf5);
1555  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL6, 0x15);
1556  		} else {
1557  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL1, 0x65);
1558  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL2, 0x55);
1559  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL3, 0xd5);
1560  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL4, 0x59);
1561  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL5, 0x55);
1562  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL6, 0x15);
1563  		}
1564  		break;
1565  	}
1566  
1567  	return (0);
1568  }
1569  
1570  static int
1571  rtsx_bus_power_on(struct rtsx_softc *sc)
1572  {
1573  	if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
1574  		device_printf(sc->rtsx_dev, "rtsx_bus_power_on()\n");
1575  
1576  	/* Select SD card. */
1577  	RTSX_BITOP(sc, RTSX_CARD_SELECT, 0x07, RTSX_SD_MOD_SEL);
1578  	RTSX_BITOP(sc, RTSX_CARD_SHARE_MODE, RTSX_CARD_SHARE_MASK, RTSX_CARD_SHARE_48_SD);
1579  
1580  	/* Enable SD clock. */
1581  	RTSX_BITOP(sc, RTSX_CARD_CLK_EN, RTSX_SD_CLK_EN,  RTSX_SD_CLK_EN);
1582  
1583  	/* Enable pull control. */
1584  	switch (sc->rtsx_device_id) {
1585  	case RTSX_RTS5209:
1586  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL1, RTSX_PULL_CTL_ENABLE12);
1587  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL2, RTSX_PULL_CTL_ENABLE12);
1588  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL3, RTSX_PULL_CTL_ENABLE3);
1589  		break;
1590  	case RTSX_RTS5227:
1591  	case RTSX_RTS522A:
1592  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL2, RTSX_PULL_CTL_ENABLE12);
1593  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL3, RTSX_PULL_CTL_ENABLE3);
1594  		break;
1595  	case RTSX_RTS5229:
1596  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL2, RTSX_PULL_CTL_ENABLE12);
1597  		if (sc->rtsx_flags & RTSX_F_VERSION_C)
1598  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL3, RTSX_PULL_CTL_ENABLE3_TYPE_C);
1599  		else
1600  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL3, RTSX_PULL_CTL_ENABLE3);
1601  		break;
1602  	case RTSX_RTS525A:
1603  	case RTSX_RTS5249:
1604  	case RTSX_RTS5260:
1605  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL1, 0x66);
1606  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL2, RTSX_PULL_CTL_ENABLE12);
1607  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL3, RTSX_PULL_CTL_ENABLE3);
1608  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL4, 0xaa);
1609  		break;
1610  	case RTSX_RTL8402:
1611  	case RTSX_RTL8411:
1612  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL1, 0xaa);
1613  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL2, 0xaa);
1614  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL3, 0xa9);
1615  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL4, 0x09);
1616  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL5, 0x09);
1617  		RTSX_WRITE(sc, RTSX_CARD_PULL_CTL6, 0x04);
1618  		break;
1619  	case RTSX_RTL8411B:
1620  		if (sc->rtsx_flags & RTSX_F_8411B_QFN48) {
1621  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL2, 0xaa);
1622  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL3, 0xf9);
1623  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL6, 0x19);
1624  		} else {
1625  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL1, 0xaa);
1626  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL2, 0xaa);
1627  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL3, 0xd9);
1628  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL4, 0x59);
1629  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL5, 0x55);
1630  			RTSX_WRITE(sc, RTSX_CARD_PULL_CTL6, 0x15);
1631  		}
1632  		break;
1633  	}
1634  
1635  	/*
1636  	 * To avoid a current peak, enable card power in two phases
1637  	 * with a delay in between.
1638  	 */
1639  	switch (sc->rtsx_device_id) {
1640  	case RTSX_RTS5209:
1641  		/* Partial power. */
1642  		RTSX_BITOP(sc, RTSX_CARD_PWR_CTL, RTSX_SD_PWR_MASK, RTSX_SD_PARTIAL_PWR_ON);
1643  		RTSX_BITOP(sc, RTSX_PWR_GATE_CTRL, RTSX_LDO3318_PWR_MASK, RTSX_LDO3318_VCC2);
1644  
1645  		DELAY(200);
1646  
1647  		/* Full power. */
1648  		RTSX_BITOP(sc, RTSX_CARD_PWR_CTL, RTSX_SD_PWR_MASK, RTSX_SD_PWR_ON);
1649  		RTSX_BITOP(sc, RTSX_PWR_GATE_CTRL, RTSX_LDO3318_PWR_MASK, RTSX_LDO3318_ON);
1650  		break;
1651  	case RTSX_RTS5227:
1652  	case RTSX_RTS522A:
1653  		/* Partial power. */
1654  		RTSX_BITOP(sc, RTSX_CARD_PWR_CTL, RTSX_SD_PWR_MASK, RTSX_SD_PARTIAL_PWR_ON);
1655  		RTSX_BITOP(sc, RTSX_PWR_GATE_CTRL, RTSX_LDO3318_PWR_MASK, RTSX_LDO3318_VCC1);
1656  
1657  		DELAY(20000);
1658  
1659  		/* Full power. */
1660  		RTSX_BITOP(sc, RTSX_CARD_PWR_CTL, RTSX_SD_PWR_MASK, RTSX_SD_PWR_ON);
1661  		RTSX_BITOP(sc, RTSX_PWR_GATE_CTRL, RTSX_LDO3318_PWR_MASK,
1662  			   RTSX_LDO3318_VCC1 | RTSX_LDO3318_VCC2);
1663  		RTSX_BITOP(sc, RTSX_CARD_OE, RTSX_SD_OUTPUT_EN, RTSX_SD_OUTPUT_EN);
1664  		RTSX_BITOP(sc, RTSX_CARD_OE, RTSX_MS_OUTPUT_EN, RTSX_MS_OUTPUT_EN);
1665  		break;
1666  	case RTSX_RTS5229:
1667  		/* Partial power. */
1668  		RTSX_BITOP(sc, RTSX_CARD_PWR_CTL, RTSX_SD_PWR_MASK, RTSX_SD_PARTIAL_PWR_ON);
1669  		RTSX_BITOP(sc, RTSX_PWR_GATE_CTRL, RTSX_LDO3318_PWR_MASK, RTSX_LDO3318_VCC1);
1670  
1671  		DELAY(200);
1672  
1673  		/* Full power. */
1674  		RTSX_BITOP(sc, RTSX_CARD_PWR_CTL, RTSX_SD_PWR_MASK, RTSX_SD_PWR_ON);
1675  		RTSX_BITOP(sc, RTSX_PWR_GATE_CTRL, RTSX_LDO3318_PWR_MASK,
1676  			   RTSX_LDO3318_VCC1 | RTSX_LDO3318_VCC2);
1677  		break;
1678  	case RTSX_RTS525A:
1679  		RTSX_BITOP(sc, RTSX_LDO_VCC_CFG1, RTSX_LDO_VCC_TUNE_MASK, RTSX_LDO_VCC_3V3);
1680  	case RTSX_RTS5249:
1681  		/* Partial power. */
1682  		RTSX_BITOP(sc, RTSX_CARD_PWR_CTL, RTSX_SD_PWR_MASK, RTSX_SD_PARTIAL_PWR_ON);
1683  		RTSX_BITOP(sc, RTSX_PWR_GATE_CTRL, RTSX_LDO3318_PWR_MASK, RTSX_LDO3318_VCC1);
1684  
1685  		DELAY(5000);
1686  
1687  		/* Full power. */
1688  		RTSX_BITOP(sc, RTSX_CARD_PWR_CTL, RTSX_SD_PWR_MASK, RTSX_SD_PWR_ON);
1689  		RTSX_BITOP(sc, RTSX_PWR_GATE_CTRL, RTSX_LDO3318_PWR_MASK,
1690  			   RTSX_LDO3318_VCC1 | RTSX_LDO3318_VCC2);
1691  		break;
1692  	case RTSX_RTS5260:
1693  		RTSX_BITOP(sc, RTSX_LDO_CONFIG2, RTSX_DV331812_VDD1, RTSX_DV331812_VDD1);
1694  		RTSX_BITOP(sc, RTSX_LDO_VCC_CFG0, RTSX_RTS5260_DVCC_TUNE_MASK, RTSX_RTS5260_DVCC_33);
1695  		RTSX_BITOP(sc, RTSX_LDO_VCC_CFG1, RTSX_LDO_POW_SDVDD1_MASK, RTSX_LDO_POW_SDVDD1_ON);
1696  		RTSX_BITOP(sc, RTSX_LDO_CONFIG2, RTSX_DV331812_POWERON, RTSX_DV331812_POWERON);
1697  
1698  		DELAY(20000);
1699  
1700  		RTSX_BITOP(sc, RTSX_SD_CFG1, RTSX_SD_MODE_MASK | RTSX_SD_ASYNC_FIFO_NOT_RST,
1701  			   RTSX_SD30_MODE | RTSX_SD_ASYNC_FIFO_NOT_RST);
1702  		RTSX_BITOP(sc, RTSX_CLK_CTL, RTSX_CHANGE_CLK, RTSX_CLK_LOW_FREQ);
1703  		RTSX_WRITE(sc, RTSX_CARD_CLK_SOURCE,
1704  			   RTSX_CRC_VAR_CLK0 | RTSX_SD30_FIX_CLK | RTSX_SAMPLE_VAR_CLK1);
1705  		RTSX_CLR(sc, RTSX_CLK_CTL, RTSX_CLK_LOW_FREQ);
1706  
1707  		/* Initialize SD_CFG1 register */
1708  		RTSX_WRITE(sc, RTSX_SD_CFG1, RTSX_CLK_DIVIDE_128 | RTSX_SD20_MODE);
1709  		RTSX_WRITE(sc, RTSX_SD_SAMPLE_POINT_CTL, RTSX_SD20_RX_POS_EDGE);
1710  		RTSX_CLR(sc, RTSX_SD_PUSH_POINT_CTL, 0xff);
1711  		RTSX_BITOP(sc, RTSX_CARD_STOP, RTSX_SD_STOP | RTSX_SD_CLR_ERR,
1712  			   RTSX_SD_STOP | RTSX_SD_CLR_ERR);
1713  		/* Reset SD_CFG3 register */
1714  		RTSX_CLR(sc, RTSX_SD_CFG3, RTSX_SD30_CLK_END_EN);
1715  		RTSX_CLR(sc, RTSX_REG_SD_STOP_SDCLK_CFG,
1716  			 RTSX_SD30_CLK_STOP_CFG_EN | RTSX_SD30_CLK_STOP_CFG0 | RTSX_SD30_CLK_STOP_CFG1);
1717  		RTSX_CLR(sc, RTSX_REG_PRE_RW_MODE, RTSX_EN_INFINITE_MODE);
1718  		break;
1719  	case RTSX_RTL8402:
1720  	case RTSX_RTL8411:
1721  	case RTSX_RTL8411B:
1722  		RTSX_BITOP(sc, RTSX_CARD_PWR_CTL, RTSX_BPP_POWER_MASK,
1723  			   RTSX_BPP_POWER_5_PERCENT_ON);
1724  		RTSX_BITOP(sc, RTSX_LDO_CTL, RTSX_BPP_LDO_POWB,
1725  			   RTSX_BPP_LDO_SUSPEND);
1726  		DELAY(150);
1727  		RTSX_BITOP(sc, RTSX_CARD_PWR_CTL, RTSX_BPP_POWER_MASK,
1728  			   RTSX_BPP_POWER_10_PERCENT_ON);
1729  		DELAY(150);
1730  		RTSX_BITOP(sc, RTSX_CARD_PWR_CTL, RTSX_BPP_POWER_MASK,
1731  			   RTSX_BPP_POWER_15_PERCENT_ON);
1732  		DELAY(150);
1733  		RTSX_BITOP(sc, RTSX_CARD_PWR_CTL, RTSX_BPP_POWER_MASK,
1734  			   RTSX_BPP_POWER_ON);
1735  		RTSX_BITOP(sc, RTSX_LDO_CTL, RTSX_BPP_LDO_POWB,
1736  			   RTSX_BPP_LDO_ON);
1737  		break;
1738  	}
1739  
1740  	/* Enable SD card output. */
1741  	RTSX_WRITE(sc, RTSX_CARD_OE, RTSX_SD_OUTPUT_EN);
1742  
1743  	DELAY(200);
1744  
1745  	return (0);
1746  }
1747  
1748  /*
1749   * Set but width.
1750   */
1751  static int
1752  rtsx_set_bus_width(struct rtsx_softc *sc, enum mmc_bus_width width)
1753  {
1754  	uint32_t bus_width;
1755  
1756  	switch (width) {
1757  	case bus_width_1:
1758  		bus_width = RTSX_BUS_WIDTH_1;
1759  		break;
1760  	case bus_width_4:
1761  		bus_width = RTSX_BUS_WIDTH_4;
1762  		break;
1763  	case bus_width_8:
1764  		bus_width = RTSX_BUS_WIDTH_8;
1765  		break;
1766  	default:
1767  		return (MMC_ERR_INVALID);
1768  	}
1769  	RTSX_BITOP(sc, RTSX_SD_CFG1, RTSX_BUS_WIDTH_MASK, bus_width);
1770  
1771  	if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC) {
1772  		char *busw[] = {
1773  				"1 bit",
1774  				"4 bits",
1775  				"8 bits"
1776  		};
1777  		device_printf(sc->rtsx_dev, "Setting bus width to %s\n", busw[bus_width]);
1778  	}
1779  	return (0);
1780  }
1781  
1782  static int
1783  rtsx_set_sd_timing(struct rtsx_softc *sc, enum mmc_bus_timing timing)
1784  {
1785  	if (timing == bus_timing_hs && sc->rtsx_force_timing) {
1786  		timing = bus_timing_uhs_sdr50;
1787  		sc->rtsx_ios_timing = timing;
1788  	}
1789  
1790  	if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
1791  		device_printf(sc->rtsx_dev, "rtsx_set_sd_timing(%u)\n", timing);
1792  
1793  	switch (timing) {
1794  	case bus_timing_uhs_sdr50:
1795  	case bus_timing_uhs_sdr104:
1796  		sc->rtsx_double_clk = false;
1797  		sc->rtsx_vpclk = true;
1798  		RTSX_BITOP(sc, RTSX_SD_CFG1, 0x0c | RTSX_SD_ASYNC_FIFO_NOT_RST,
1799  			   RTSX_SD30_MODE | RTSX_SD_ASYNC_FIFO_NOT_RST);
1800  		RTSX_BITOP(sc, RTSX_CLK_CTL, RTSX_CLK_LOW_FREQ, RTSX_CLK_LOW_FREQ);
1801  		RTSX_WRITE(sc, RTSX_CARD_CLK_SOURCE,
1802  			   RTSX_CRC_VAR_CLK0 | RTSX_SD30_FIX_CLK | RTSX_SAMPLE_VAR_CLK1);
1803  		RTSX_CLR(sc, RTSX_CLK_CTL, RTSX_CLK_LOW_FREQ);
1804  		break;
1805  	case bus_timing_hs:
1806  		RTSX_BITOP(sc, RTSX_SD_CFG1, RTSX_SD_MODE_MASK, RTSX_SD20_MODE);
1807  		RTSX_BITOP(sc, RTSX_CLK_CTL, RTSX_CLK_LOW_FREQ, RTSX_CLK_LOW_FREQ);
1808  		RTSX_WRITE(sc, RTSX_CARD_CLK_SOURCE,
1809  			   RTSX_CRC_FIX_CLK | RTSX_SD30_VAR_CLK0 | RTSX_SAMPLE_VAR_CLK1);
1810  		RTSX_CLR(sc, RTSX_CLK_CTL, RTSX_CLK_LOW_FREQ);
1811  
1812  		RTSX_BITOP(sc, RTSX_SD_PUSH_POINT_CTL,
1813  			   RTSX_SD20_TX_SEL_MASK, RTSX_SD20_TX_14_AHEAD);
1814  		RTSX_BITOP(sc, RTSX_SD_SAMPLE_POINT_CTL,
1815  			   RTSX_SD20_RX_SEL_MASK, RTSX_SD20_RX_14_DELAY);
1816  		break;
1817  	default:
1818  		RTSX_BITOP(sc, RTSX_SD_CFG1, RTSX_SD_MODE_MASK, RTSX_SD20_MODE);
1819  		RTSX_BITOP(sc, RTSX_CLK_CTL, RTSX_CLK_LOW_FREQ, RTSX_CLK_LOW_FREQ);
1820  		RTSX_WRITE(sc, RTSX_CARD_CLK_SOURCE,
1821  			   RTSX_CRC_FIX_CLK | RTSX_SD30_VAR_CLK0 | RTSX_SAMPLE_VAR_CLK1);
1822  		RTSX_CLR(sc, RTSX_CLK_CTL, RTSX_CLK_LOW_FREQ);
1823  
1824  		RTSX_WRITE(sc, RTSX_SD_PUSH_POINT_CTL, RTSX_SD20_TX_NEG_EDGE);
1825  		RTSX_BITOP(sc, RTSX_SD_SAMPLE_POINT_CTL,
1826  			   RTSX_SD20_RX_SEL_MASK, RTSX_SD20_RX_POS_EDGE);
1827  		break;
1828  	}
1829  
1830  	return (0);
1831  }
1832  
1833  /*
1834   * Set or change SDCLK frequency or disable the SD clock.
1835   * Return zero on success.
1836   */
1837  static int
1838  rtsx_set_sd_clock(struct rtsx_softc *sc, uint32_t freq)
1839  {
1840  	uint8_t	clk;
1841  	uint8_t	clk_divider, n, div, mcu;
1842  	int	error = 0;
1843  
1844  	if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
1845  		device_printf(sc->rtsx_dev, "rtsx_set_sd_clock(%u)\n", freq);
1846  
1847  	if (freq == RTSX_SDCLK_OFF) {
1848  		error = rtsx_stop_sd_clock(sc);
1849  		return error;
1850  	}
1851  
1852  	sc->rtsx_ssc_depth = RTSX_SSC_DEPTH_500K;
1853  	sc->rtsx_discovery_mode = (freq <= 1000000) ? true : false;
1854  
1855  	if (sc->rtsx_discovery_mode) {
1856  		/* We use 250k(around) here, in discovery stage. */
1857  		clk_divider = RTSX_CLK_DIVIDE_128;
1858  		freq = 30000000;
1859  	} else {
1860  		clk_divider = RTSX_CLK_DIVIDE_0;
1861  	}
1862  	RTSX_BITOP(sc, RTSX_SD_CFG1, RTSX_CLK_DIVIDE_MASK, clk_divider);
1863  
1864  	freq /= 1000000;
1865  	if (sc->rtsx_discovery_mode || !sc->rtsx_double_clk)
1866  		clk = freq;
1867  	else
1868  		clk = freq * 2;
1869  
1870  	switch (sc->rtsx_device_id) {
1871  	case RTSX_RTL8402:
1872  	case RTSX_RTL8411:
1873  	case RTSX_RTL8411B:
1874  		n = clk * 4 / 5 - 2;
1875  		break;
1876  	default:
1877  		n = clk - 2;
1878  		break;
1879  	}
1880  	if ((clk <= 2) || (n > RTSX_MAX_DIV_N))
1881  		return (MMC_ERR_INVALID);
1882  
1883  	mcu = 125 / clk + 3;
1884  	if (mcu > 15)
1885  		mcu = 15;
1886  
1887  	/* Make sure that the SSC clock div_n is not less than RTSX_MIN_DIV_N. */
1888  	div = RTSX_CLK_DIV_1;
1889  	while ((n < RTSX_MIN_DIV_N) && (div < RTSX_CLK_DIV_8)) {
1890  		switch (sc->rtsx_device_id) {
1891  		case RTSX_RTL8402:
1892  		case RTSX_RTL8411:
1893  		case RTSX_RTL8411B:
1894  			n = (((n + 2) * 5 / 4) * 2) * 4 / 5 - 2;
1895  			break;
1896  		default:
1897  			n = (n + 2) * 2 - 2;
1898  			break;
1899  		}
1900  		div++;
1901  	}
1902  
1903  	if (sc->rtsx_double_clk && sc->rtsx_ssc_depth > 1)
1904  		sc->rtsx_ssc_depth -= 1;
1905  
1906  	if (div > RTSX_CLK_DIV_1) {
1907  		if (sc->rtsx_ssc_depth > (div - 1))
1908  			sc->rtsx_ssc_depth -= (div - 1);
1909  		else
1910  			sc->rtsx_ssc_depth = RTSX_SSC_DEPTH_4M;
1911  	}
1912  
1913  	/* Enable SD clock. */
1914  	error = rtsx_switch_sd_clock(sc, clk, n, div, mcu);
1915  
1916  	return (error);
1917  }
1918  
1919  static int
1920  rtsx_stop_sd_clock(struct rtsx_softc *sc)
1921  {
1922  	RTSX_CLR(sc, RTSX_CARD_CLK_EN, RTSX_CARD_CLK_EN_ALL);
1923  	RTSX_SET(sc, RTSX_SD_BUS_STAT, RTSX_SD_CLK_FORCE_STOP);
1924  
1925  	return (0);
1926  }
1927  
1928  static int
1929  rtsx_switch_sd_clock(struct rtsx_softc *sc, uint8_t clk, uint8_t n, uint8_t div, uint8_t mcu)
1930  {
1931  	if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC) {
1932  		device_printf(sc->rtsx_dev, "rtsx_switch_sd_clock() - discovery-mode is %s, ssc_depth: %d\n",
1933  			      (sc->rtsx_discovery_mode) ? "true" : "false", sc->rtsx_ssc_depth);
1934  		device_printf(sc->rtsx_dev, "rtsx_switch_sd_clock() - clk: %d, n: %d, div: %d, mcu: %d\n",
1935  			      clk, n, div, mcu);
1936  	}
1937  
1938  	RTSX_BITOP(sc, RTSX_CLK_CTL, RTSX_CLK_LOW_FREQ, RTSX_CLK_LOW_FREQ);
1939  	RTSX_WRITE(sc, RTSX_CLK_DIV, (div << 4) | mcu);
1940  	RTSX_CLR(sc, RTSX_SSC_CTL1, RTSX_RSTB);
1941  	RTSX_BITOP(sc, RTSX_SSC_CTL2, RTSX_SSC_DEPTH_MASK, sc->rtsx_ssc_depth);
1942  	RTSX_WRITE(sc, RTSX_SSC_DIV_N_0, n);
1943  	RTSX_BITOP(sc, RTSX_SSC_CTL1, RTSX_RSTB, RTSX_RSTB);
1944  	if (sc->rtsx_vpclk) {
1945  		RTSX_CLR(sc, RTSX_SD_VPCLK0_CTL, RTSX_PHASE_NOT_RESET);
1946  		RTSX_BITOP(sc, RTSX_SD_VPCLK0_CTL, RTSX_PHASE_NOT_RESET, RTSX_PHASE_NOT_RESET);
1947  	}
1948  
1949  	/* Wait SSC clock stable. */
1950  	DELAY(200);
1951  
1952  	RTSX_CLR(sc, RTSX_CLK_CTL, RTSX_CLK_LOW_FREQ);
1953  
1954  	return (0);
1955  }
1956  
1957  #ifndef MMCCAM
1958  static void
1959  rtsx_sd_change_tx_phase(struct rtsx_softc *sc, uint8_t sample_point)
1960  {
1961  	if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
1962  		device_printf(sc->rtsx_dev, "rtsx_sd_change_tx_phase() - sample_point: %d\n", sample_point);
1963  
1964  	rtsx_write(sc, RTSX_CLK_CTL, RTSX_CHANGE_CLK, RTSX_CHANGE_CLK);
1965  	rtsx_write(sc, RTSX_SD_VPCLK0_CTL, RTSX_PHASE_SELECT_MASK, sample_point);
1966  	rtsx_write(sc, RTSX_SD_VPCLK0_CTL, RTSX_PHASE_NOT_RESET, 0);
1967  	rtsx_write(sc, RTSX_SD_VPCLK0_CTL, RTSX_PHASE_NOT_RESET, RTSX_PHASE_NOT_RESET);
1968  	rtsx_write(sc, RTSX_CLK_CTL, RTSX_CHANGE_CLK, 0);
1969  	rtsx_write(sc, RTSX_SD_CFG1, RTSX_SD_ASYNC_FIFO_NOT_RST, 0);
1970  }
1971  
1972  static void
1973  rtsx_sd_change_rx_phase(struct rtsx_softc *sc, uint8_t sample_point)
1974  {
1975  	if (sc->rtsx_debug_mask & RTSX_DEBUG_TUNING)
1976  		device_printf(sc->rtsx_dev, "rtsx_sd_change_rx_phase() - sample_point: %d\n", sample_point);
1977  
1978  	rtsx_write(sc, RTSX_CLK_CTL, RTSX_CHANGE_CLK, RTSX_CHANGE_CLK);
1979  	rtsx_write(sc, RTSX_SD_VPCLK1_CTL, RTSX_PHASE_SELECT_MASK, sample_point);
1980  	rtsx_write(sc, RTSX_SD_VPCLK1_CTL, RTSX_PHASE_NOT_RESET, 0);
1981  	rtsx_write(sc, RTSX_SD_VPCLK1_CTL, RTSX_PHASE_NOT_RESET, RTSX_PHASE_NOT_RESET);
1982  	rtsx_write(sc, RTSX_CLK_CTL, RTSX_CHANGE_CLK, 0);
1983  	rtsx_write(sc, RTSX_SD_CFG1, RTSX_SD_ASYNC_FIFO_NOT_RST, 0);
1984  }
1985  
1986  static void
1987  rtsx_sd_tuning_rx_phase(struct rtsx_softc *sc, uint32_t *phase_map)
1988  {
1989  	uint32_t raw_phase_map = 0;
1990  	int	 i;
1991  	int	 error;
1992  
1993  	for (i = 0; i < RTSX_RX_PHASE_MAX; i++) {
1994  		error = rtsx_sd_tuning_rx_cmd(sc, (uint8_t)i);
1995  		if (error == 0)
1996  			raw_phase_map |= 1 << i;
1997  	}
1998  	if (phase_map != NULL)
1999  		*phase_map = raw_phase_map;
2000  }
2001  
2002  static int
2003  rtsx_sd_tuning_rx_cmd(struct rtsx_softc *sc, uint8_t sample_point)
2004  {
2005  	struct mmc_request req = {};
2006  	struct mmc_command cmd = {};
2007  	int	error = 0;
2008  
2009  	cmd.opcode = MMC_SEND_TUNING_BLOCK;
2010  	cmd.arg = 0;
2011  	req.cmd = &cmd;
2012  
2013  	RTSX_LOCK(sc);
2014  
2015  	sc->rtsx_req = &req;
2016  
2017  	rtsx_sd_change_rx_phase(sc, sample_point);
2018  
2019  	rtsx_write(sc, RTSX_SD_CFG3, RTSX_SD_RSP_80CLK_TIMEOUT_EN,
2020  		   RTSX_SD_RSP_80CLK_TIMEOUT_EN);
2021  
2022  	rtsx_init_cmd(sc, &cmd);
2023  	rtsx_set_cmd_data_len(sc, 1, 0x40);
2024  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_CFG2, 0xff,
2025  		      RTSX_SD_CALCULATE_CRC7 | RTSX_SD_CHECK_CRC16 |
2026  		      RTSX_SD_NO_WAIT_BUSY_END | RTSX_SD_CHECK_CRC7 | RTSX_SD_RSP_LEN_6);
2027  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_TRANSFER,
2028  		      0xff, RTSX_TM_AUTO_TUNING | RTSX_SD_TRANSFER_START);
2029  	rtsx_push_cmd(sc, RTSX_CHECK_REG_CMD, RTSX_SD_TRANSFER,
2030  		      RTSX_SD_TRANSFER_END, RTSX_SD_TRANSFER_END);
2031  
2032  	/* Set interrupt post processing */
2033  	sc->rtsx_intr_trans_ok = rtsx_sd_tuning_rx_cmd_wakeup;
2034  	sc->rtsx_intr_trans_ko = rtsx_sd_tuning_rx_cmd_wakeup;
2035  
2036  	/* Run the command queue. */
2037  	rtsx_send_cmd(sc);
2038  
2039  	error = rtsx_sd_tuning_rx_cmd_wait(sc, &cmd);
2040  
2041  	if (error) {
2042  		if (sc->rtsx_debug_mask & RTSX_DEBUG_TUNING)
2043  			device_printf(sc->rtsx_dev, "rtsx_sd_tuning_rx_cmd() - error: %d\n", error);
2044  		rtsx_sd_wait_data_idle(sc);
2045  		rtsx_clear_error(sc);
2046  	}
2047  	rtsx_write(sc, RTSX_SD_CFG3, RTSX_SD_RSP_80CLK_TIMEOUT_EN, 0);
2048  
2049  	sc->rtsx_req = NULL;
2050  
2051  	RTSX_UNLOCK(sc);
2052  
2053  	return (error);
2054  }
2055  
2056  static int
2057  rtsx_sd_tuning_rx_cmd_wait(struct rtsx_softc *sc, struct mmc_command *cmd)
2058  {
2059  	int	status;
2060  	int	mask = RTSX_TRANS_OK_INT | RTSX_TRANS_FAIL_INT;
2061  
2062  	status = sc->rtsx_intr_status & mask;
2063  	while (status == 0) {
2064  		if (msleep(&sc->rtsx_intr_status, &sc->rtsx_mtx, 0, "rtsxintr", sc->rtsx_timeout_cmd) == EWOULDBLOCK) {
2065  			cmd->error = MMC_ERR_TIMEOUT;
2066  			return (MMC_ERR_TIMEOUT);
2067  		}
2068  		status = sc->rtsx_intr_status & mask;
2069  	}
2070  	return (cmd->error);
2071  }
2072  
2073  static void
2074  rtsx_sd_tuning_rx_cmd_wakeup(struct rtsx_softc *sc)
2075  {
2076  	wakeup(&sc->rtsx_intr_status);
2077  }
2078  
2079  static void
2080  rtsx_sd_wait_data_idle(struct rtsx_softc *sc)
2081  {
2082  	int	i;
2083  	uint8_t	val;
2084  
2085  	for (i = 0; i < 100; i++) {
2086  		rtsx_read(sc, RTSX_SD_DATA_STATE, &val);
2087  		if (val & RTSX_SD_DATA_IDLE)
2088  			return;
2089  		DELAY(100);
2090  	}
2091  }
2092  
2093  static uint8_t
2094  rtsx_sd_search_final_rx_phase(struct rtsx_softc *sc, uint32_t phase_map)
2095  {
2096  	int	start = 0, len = 0;
2097  	int	start_final = 0, len_final = 0;
2098  	uint8_t	final_phase = 0xff;
2099  
2100  	while (start < RTSX_RX_PHASE_MAX) {
2101  		len = rtsx_sd_get_rx_phase_len(phase_map, start);
2102  		if (len_final < len) {
2103  			start_final = start;
2104  			len_final = len;
2105  		}
2106  		start += len ? len : 1;
2107  	}
2108  
2109  	final_phase = (start_final + len_final / 2) % RTSX_RX_PHASE_MAX;
2110  
2111  	if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
2112  		device_printf(sc->rtsx_dev,
2113  			      "rtsx_sd_search_final_rx_phase() - phase_map: %x, start_final: %d, len_final: %d, final_phase: %d\n",
2114  			      phase_map, start_final, len_final, final_phase);
2115  
2116  	return final_phase;
2117  }
2118  
2119  static int
2120  rtsx_sd_get_rx_phase_len(uint32_t phase_map, int start_bit)
2121  {
2122  	int	i;
2123  
2124  	for (i = 0; i < RTSX_RX_PHASE_MAX; i++) {
2125  		if ((phase_map & (1 << (start_bit + i) % RTSX_RX_PHASE_MAX)) == 0)
2126  			return i;
2127  	}
2128  	return RTSX_RX_PHASE_MAX;
2129  }
2130  #endif /* !MMCCAM */
2131  
2132  #if 0	/* For led */
2133  static int
2134  rtsx_led_enable(struct rtsx_softc *sc)
2135  {
2136  	switch (sc->rtsx_device_id) {
2137  	case RTSX_RTS5209:
2138  		RTSX_CLR(sc, RTSX_CARD_GPIO, RTSX_CARD_GPIO_LED_OFF);
2139  		RTSX_WRITE(sc, RTSX_CARD_AUTO_BLINK,
2140  			   RTSX_LED_BLINK_EN | RTSX_LED_BLINK_SPEED);
2141  		break;
2142  	case RTSX_RTL8411B:
2143  		RTSX_CLR(sc, RTSX_GPIO_CTL, 0x01);
2144  		RTSX_WRITE(sc, RTSX_CARD_AUTO_BLINK,
2145  			   RTSX_LED_BLINK_EN | RTSX_LED_BLINK_SPEED);
2146  		break;
2147  	default:
2148  		RTSX_SET(sc, RTSX_GPIO_CTL, RTSX_GPIO_LED_ON);
2149  		RTSX_SET(sc, RTSX_OLT_LED_CTL, RTSX_OLT_LED_AUTOBLINK);
2150  		break;
2151  	}
2152  
2153  	return (0);
2154  }
2155  
2156  static int
2157  rtsx_led_disable(struct rtsx_softc *sc)
2158  {
2159  	switch (sc->rtsx_device_id) {
2160  	case RTSX_RTS5209:
2161  		RTSX_CLR(sc, RTSX_CARD_AUTO_BLINK, RTSX_LED_BLINK_EN);
2162  		RTSX_WRITE(sc, RTSX_CARD_GPIO, RTSX_CARD_GPIO_LED_OFF);
2163  		break;
2164  	case RTSX_RTL8411B:
2165  		RTSX_CLR(sc, RTSX_CARD_AUTO_BLINK, RTSX_LED_BLINK_EN);
2166  		RTSX_SET(sc, RTSX_GPIO_CTL, 0x01);
2167  		break;
2168  	default:
2169  		RTSX_CLR(sc, RTSX_OLT_LED_CTL, RTSX_OLT_LED_AUTOBLINK);
2170  		RTSX_CLR(sc, RTSX_GPIO_CTL, RTSX_GPIO_LED_ON);
2171  		break;
2172  	}
2173  
2174  	return (0);
2175  }
2176  #endif	/* For led */
2177  
2178  static uint8_t
2179  rtsx_response_type(uint16_t mmc_rsp)
2180  {
2181  	int	i;
2182  	struct rsp_type {
2183  		uint16_t mmc_rsp;
2184  		uint8_t  rtsx_rsp;
2185  	} rsp_types[] = {
2186  		{ MMC_RSP_NONE,	RTSX_SD_RSP_TYPE_R0 },
2187  		{ MMC_RSP_R1,	RTSX_SD_RSP_TYPE_R1 },
2188  		{ MMC_RSP_R1B,	RTSX_SD_RSP_TYPE_R1B },
2189  		{ MMC_RSP_R2,	RTSX_SD_RSP_TYPE_R2 },
2190  		{ MMC_RSP_R3,	RTSX_SD_RSP_TYPE_R3 },
2191  		{ MMC_RSP_R4,	RTSX_SD_RSP_TYPE_R4 },
2192  		{ MMC_RSP_R5,	RTSX_SD_RSP_TYPE_R5 },
2193  		{ MMC_RSP_R6,	RTSX_SD_RSP_TYPE_R6 },
2194  		{ MMC_RSP_R7,	RTSX_SD_RSP_TYPE_R7 }
2195  	};
2196  
2197  	for (i = 0; i < nitems(rsp_types); i++) {
2198  		if (mmc_rsp == rsp_types[i].mmc_rsp)
2199  			return (rsp_types[i].rtsx_rsp);
2200  	}
2201  
2202  	return (0);
2203  }
2204  
2205  /*
2206   * Init command buffer with SD command index and argument.
2207   */
2208  static void
2209  rtsx_init_cmd(struct rtsx_softc *sc, struct mmc_command *cmd)
2210  {
2211  	sc->rtsx_cmd_index = 0;
2212  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_CMD0,
2213  		      0xff, RTSX_SD_CMD_START  | cmd->opcode);
2214  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_CMD1,
2215  		     0xff, cmd->arg >> 24);
2216  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_CMD2,
2217  		      0xff, cmd->arg >> 16);
2218  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_CMD3,
2219  		     0xff, cmd->arg >> 8);
2220  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_CMD4,
2221  		     0xff, cmd->arg);
2222  }
2223  
2224  /*
2225   * Append a properly encoded host command to the host command buffer.
2226   */
2227  static void
2228  rtsx_push_cmd(struct rtsx_softc *sc, uint8_t cmd, uint16_t reg,
2229  	      uint8_t mask, uint8_t data)
2230  {
2231  	KASSERT(sc->rtsx_cmd_index < RTSX_HOSTCMD_MAX,
2232  		("rtsx: Too many host commands (%d)\n", sc->rtsx_cmd_index));
2233  
2234  	uint32_t *cmd_buffer = (uint32_t *)(sc->rtsx_cmd_dmamem);
2235  	cmd_buffer[sc->rtsx_cmd_index++] =
2236  		htole32((uint32_t)(cmd & 0x3) << 30) |
2237  		((uint32_t)(reg & 0x3fff) << 16) |
2238  		((uint32_t)(mask) << 8) |
2239  		((uint32_t)data);
2240  }
2241  
2242  /*
2243   * Queue commands to configure data transfer size.
2244   */
2245  static void
2246  rtsx_set_cmd_data_len(struct rtsx_softc *sc, uint16_t block_cnt, uint16_t byte_cnt)
2247  {
2248  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_BLOCK_CNT_L,
2249  		      0xff, block_cnt & 0xff);
2250  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_BLOCK_CNT_H,
2251  		      0xff, block_cnt >> 8);
2252  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_BYTE_CNT_L,
2253  		      0xff, byte_cnt & 0xff);
2254  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_BYTE_CNT_H,
2255  		      0xff, byte_cnt >> 8);
2256  }
2257  
2258  /*
2259   * Run the command queue.
2260   */
2261  static void
2262  rtsx_send_cmd(struct rtsx_softc *sc)
2263  {
2264  	if (sc->rtsx_debug_mask & RTSX_TRACE_SD_CMD)
2265  		device_printf(sc->rtsx_dev, "rtsx_send_cmd()\n");
2266  
2267  	sc->rtsx_intr_status = 0;
2268  
2269  	/* Sync command DMA buffer. */
2270  	bus_dmamap_sync(sc->rtsx_cmd_dma_tag, sc->rtsx_cmd_dmamap, BUS_DMASYNC_PREREAD);
2271  	bus_dmamap_sync(sc->rtsx_cmd_dma_tag, sc->rtsx_cmd_dmamap, BUS_DMASYNC_PREWRITE);
2272  
2273  	/* Tell the chip where the command buffer is and run the commands. */
2274  	WRITE4(sc, RTSX_HCBAR, (uint32_t)sc->rtsx_cmd_buffer);
2275  	WRITE4(sc, RTSX_HCBCTLR,
2276  	       ((sc->rtsx_cmd_index * 4) & 0x00ffffff) | RTSX_START_CMD | RTSX_HW_AUTO_RSP);
2277  }
2278  
2279  /*
2280   * Stop previous command.
2281   */
2282  static void
2283  rtsx_stop_cmd(struct rtsx_softc *sc)
2284  {
2285  	/* Stop command transfer. */
2286  	WRITE4(sc, RTSX_HCBCTLR, RTSX_STOP_CMD);
2287  
2288  	/* Stop DMA transfer. */
2289  	WRITE4(sc, RTSX_HDBCTLR, RTSX_STOP_DMA);
2290  
2291  	switch (sc->rtsx_device_id) {
2292  	case RTSX_RTS5260:
2293  		rtsx_write(sc, RTSX_RTS5260_DMA_RST_CTL_0,
2294  			   RTSX_RTS5260_DMA_RST | RTSX_RTS5260_ADMA3_RST,
2295  			   RTSX_RTS5260_DMA_RST | RTSX_RTS5260_ADMA3_RST);
2296  		rtsx_write(sc, RTSX_RBCTL, RTSX_RB_FLUSH, RTSX_RB_FLUSH);
2297  		break;
2298  	default:
2299  		rtsx_write(sc, RTSX_DMACTL, RTSX_DMA_RST, RTSX_DMA_RST);
2300  
2301  		rtsx_write(sc, RTSX_RBCTL, RTSX_RB_FLUSH, RTSX_RB_FLUSH);
2302  		break;
2303  	}
2304  }
2305  
2306  /*
2307   * Clear error.
2308   */
2309  static void
2310  rtsx_clear_error(struct rtsx_softc *sc)
2311  {
2312  	/* Clear error. */
2313  	rtsx_write(sc, RTSX_CARD_STOP, RTSX_SD_STOP | RTSX_SD_CLR_ERR,
2314  		   RTSX_SD_STOP | RTSX_SD_CLR_ERR);
2315  }
2316  
2317  /*
2318   * Signal end of request to mmc/mmcsd.
2319   */
2320  static void
2321  rtsx_req_done(struct rtsx_softc *sc)
2322  {
2323  #ifdef MMCCAM
2324  	union ccb *ccb;
2325  #endif /* MMCCAM */
2326  	struct mmc_request *req;
2327  
2328  	req = sc->rtsx_req;
2329  	if (req->cmd->error == MMC_ERR_NONE) {
2330  		if (req->cmd->opcode == MMC_READ_SINGLE_BLOCK ||
2331  		    req->cmd->opcode == MMC_READ_MULTIPLE_BLOCK)
2332  			sc->rtsx_read_count++;
2333  		else if (req->cmd->opcode == MMC_WRITE_BLOCK ||
2334  			 req->cmd->opcode == MMC_WRITE_MULTIPLE_BLOCK)
2335  			sc->rtsx_write_count++;
2336  	} else {
2337  		rtsx_clear_error(sc);
2338  	}
2339  	callout_stop(&sc->rtsx_timeout_callout);
2340  	sc->rtsx_req = NULL;
2341  #ifdef MMCCAM
2342  	ccb = sc->rtsx_ccb;
2343  	sc->rtsx_ccb = NULL;
2344  	ccb->ccb_h.status = (req->cmd->error == 0 ? CAM_REQ_CMP : CAM_REQ_CMP_ERR);
2345  	xpt_done(ccb);
2346  #else  /* !MMCCAM */
2347  	req->done(req);
2348  #endif /* MMCCAM */
2349  }
2350  
2351  /*
2352   * Send request.
2353   */
2354  static int
2355  rtsx_send_req(struct rtsx_softc *sc, struct mmc_command *cmd)
2356  {
2357  	uint8_t	 rsp_type;
2358  	uint16_t reg;
2359  
2360  	if (sc->rtsx_debug_mask & RTSX_TRACE_SD_CMD)
2361  		device_printf(sc->rtsx_dev, "rtsx_send_req() - CMD%d\n", cmd->opcode);
2362  
2363  	/* Convert response type. */
2364  	rsp_type = rtsx_response_type(cmd->flags & MMC_RSP_MASK);
2365  	if (rsp_type == 0) {
2366  		device_printf(sc->rtsx_dev, "Unknown rsp_type: 0x%lx\n", (cmd->flags & MMC_RSP_MASK));
2367  		cmd->error = MMC_ERR_INVALID;
2368  		return (MMC_ERR_INVALID);
2369  	}
2370  
2371  	rtsx_init_cmd(sc, cmd);
2372  
2373  	/* Queue command to set response type. */
2374  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_CFG2, 0xff, rsp_type);
2375  
2376  	/* Use the ping-pong buffer (cmd buffer) for commands which do not transfer data. */
2377  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_CARD_DATA_SOURCE,
2378  		      0x01, RTSX_PINGPONG_BUFFER);
2379  
2380  	/* Queue commands to perform SD transfer. */
2381  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_TRANSFER,
2382  		      0xff, RTSX_TM_CMD_RSP | RTSX_SD_TRANSFER_START);
2383  	rtsx_push_cmd(sc, RTSX_CHECK_REG_CMD, RTSX_SD_TRANSFER,
2384  		      RTSX_SD_TRANSFER_END|RTSX_SD_STAT_IDLE,
2385  		      RTSX_SD_TRANSFER_END|RTSX_SD_STAT_IDLE);
2386  
2387  	/* If needed queue commands to read back card status response. */
2388  	if (rsp_type == RTSX_SD_RSP_TYPE_R2) {
2389  		/* Read data from ping-pong buffer. */
2390  		for (reg = RTSX_PPBUF_BASE2; reg < RTSX_PPBUF_BASE2 + 16; reg++)
2391  			rtsx_push_cmd(sc, RTSX_READ_REG_CMD, reg, 0, 0);
2392  	} else if (rsp_type != RTSX_SD_RSP_TYPE_R0) {
2393  		/* Read data from SD_CMDx registers. */
2394  		for (reg = RTSX_SD_CMD0; reg <= RTSX_SD_CMD4; reg++)
2395  			rtsx_push_cmd(sc, RTSX_READ_REG_CMD, reg, 0, 0);
2396  	}
2397  	rtsx_push_cmd(sc, RTSX_READ_REG_CMD, RTSX_SD_STAT1, 0, 0);
2398  
2399  	/* Set transfer OK function. */
2400  	if (sc->rtsx_intr_trans_ok == NULL)
2401  		sc->rtsx_intr_trans_ok = rtsx_ret_resp;
2402  
2403  	/* Run the command queue. */
2404  	rtsx_send_cmd(sc);
2405  
2406  	return (0);
2407  }
2408  
2409  /*
2410   * Return response of previous command (case cmd->data == NULL) and complete resquest.
2411   * This Function is called by the interrupt handler via sc->rtsx_intr_trans_ok.
2412   */
2413  static void
2414  rtsx_ret_resp(struct rtsx_softc *sc)
2415  {
2416  	struct mmc_command *cmd;
2417  
2418  	cmd = sc->rtsx_req->cmd;
2419  	rtsx_set_resp(sc, cmd);
2420  	rtsx_req_done(sc);
2421  }
2422  
2423  /*
2424   * Set response of previous command.
2425   */
2426  static void
2427  rtsx_set_resp(struct rtsx_softc *sc, struct mmc_command *cmd)
2428  {
2429  	uint8_t	 rsp_type;
2430  
2431  	rsp_type = rtsx_response_type(cmd->flags & MMC_RSP_MASK);
2432  
2433  	/* Sync command DMA buffer. */
2434  	bus_dmamap_sync(sc->rtsx_cmd_dma_tag, sc->rtsx_cmd_dmamap, BUS_DMASYNC_POSTREAD);
2435  	bus_dmamap_sync(sc->rtsx_cmd_dma_tag, sc->rtsx_cmd_dmamap, BUS_DMASYNC_POSTWRITE);
2436  
2437  	/* Copy card response into mmc response buffer. */
2438  	if (ISSET(cmd->flags, MMC_RSP_PRESENT)) {
2439  		uint32_t *cmd_buffer = (uint32_t *)(sc->rtsx_cmd_dmamem);
2440  
2441  		if (sc->rtsx_debug_mask & RTSX_TRACE_SD_CMD) {
2442  			device_printf(sc->rtsx_dev, "cmd_buffer: 0x%08x 0x%08x 0x%08x 0x%08x 0x%08x\n",
2443  				      cmd_buffer[0], cmd_buffer[1], cmd_buffer[2], cmd_buffer[3], cmd_buffer[4]);
2444  		}
2445  
2446  		if (rsp_type == RTSX_SD_RSP_TYPE_R2) {
2447  			/* First byte is CHECK_REG_CMD return value, skip it. */
2448  			unsigned char *ptr = (unsigned char *)cmd_buffer + 1;
2449  			int i;
2450  
2451  			/*
2452  			 * The controller offloads the last byte {CRC-7, end bit 1}
2453  			 * of response type R2. Assign dummy CRC, 0, and end bit to this
2454  			 * byte (ptr[16], goes into the LSB of resp[3] later).
2455  			 */
2456  			ptr[16] = 0x01;
2457  			/* The second byte is the status of response, skip it. */
2458  			for (i = 0; i < 4; i++)
2459  				cmd->resp[i] = be32dec(ptr + 1 + i * 4);
2460  		} else {
2461  			/*
2462  			 * First byte is CHECK_REG_CMD return value, second
2463  			 * one is the command op code -- we skip those.
2464  			 */
2465  			cmd->resp[0] =
2466  				((be32toh(cmd_buffer[0]) & 0x0000ffff) << 16) |
2467  				((be32toh(cmd_buffer[1]) & 0xffff0000) >> 16);
2468  		}
2469  
2470  		if (sc->rtsx_debug_mask & RTSX_TRACE_SD_CMD)
2471  			device_printf(sc->rtsx_dev, "cmd->resp: 0x%08x 0x%08x 0x%08x 0x%08x\n",
2472  				      cmd->resp[0], cmd->resp[1], cmd->resp[2], cmd->resp[3]);
2473  	}
2474  }
2475  
2476  /*
2477   * Use the ping-pong buffer (cmd buffer) for transfer <= 512 bytes.
2478   */
2479  static int
2480  rtsx_xfer_short(struct rtsx_softc *sc, struct mmc_command *cmd)
2481  {
2482  	int	read;
2483  
2484  	if (cmd->data == NULL || cmd->data->len == 0) {
2485  		cmd->error = MMC_ERR_INVALID;
2486  		return (MMC_ERR_INVALID);
2487  	}
2488  	cmd->data->xfer_len = (cmd->data->len > RTSX_MAX_DATA_BLKLEN) ?
2489  		RTSX_MAX_DATA_BLKLEN : cmd->data->len;
2490  
2491  	read = ISSET(cmd->data->flags, MMC_DATA_READ);
2492  
2493  	if (sc->rtsx_debug_mask & RTSX_TRACE_SD_CMD)
2494  		device_printf(sc->rtsx_dev, "rtsx_xfer_short() - %s xfer: %ld bytes with block size %ld\n",
2495  			      read ? "Read" : "Write",
2496  			      (unsigned long)cmd->data->len, (unsigned long)cmd->data->xfer_len);
2497  
2498  	if (cmd->data->len > 512) {
2499  		device_printf(sc->rtsx_dev, "rtsx_xfer_short() - length too large: %ld > 512\n",
2500  			      (unsigned long)cmd->data->len);
2501  		cmd->error = MMC_ERR_INVALID;
2502  		return (MMC_ERR_INVALID);
2503  	}
2504  
2505  	if (read) {
2506  		if (sc->rtsx_discovery_mode)
2507  			rtsx_write(sc, RTSX_SD_CFG1, RTSX_CLK_DIVIDE_MASK, RTSX_CLK_DIVIDE_0);
2508  
2509  		rtsx_init_cmd(sc, cmd);
2510  
2511  		/* Queue commands to configure data transfer size. */
2512  		rtsx_set_cmd_data_len(sc, cmd->data->len / cmd->data->xfer_len, cmd->data->xfer_len);
2513  
2514  		/* From Linux: rtsx_pci_sdmmc.c sd_read_data(). */
2515  		rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_CFG2, 0xff,
2516  			      RTSX_SD_CALCULATE_CRC7 | RTSX_SD_CHECK_CRC16 |
2517  			      RTSX_SD_NO_WAIT_BUSY_END | RTSX_SD_CHECK_CRC7 | RTSX_SD_RSP_LEN_6);
2518  
2519  		/* Use the ping-pong buffer (cmd buffer). */
2520  		rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_CARD_DATA_SOURCE,
2521  			      0x01, RTSX_PINGPONG_BUFFER);
2522  
2523  		/* Queue commands to perform SD transfer. */
2524  		rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_TRANSFER,
2525  			      0xff, RTSX_TM_NORMAL_READ | RTSX_SD_TRANSFER_START);
2526  		rtsx_push_cmd(sc, RTSX_CHECK_REG_CMD, RTSX_SD_TRANSFER,
2527  			      RTSX_SD_TRANSFER_END, RTSX_SD_TRANSFER_END);
2528  
2529  		/* Set transfer OK function. */
2530  		sc->rtsx_intr_trans_ok = rtsx_ask_ppbuf_part1;
2531  
2532  		/* Run the command queue. */
2533  		rtsx_send_cmd(sc);
2534  	} else {
2535  		/* Set transfer OK function. */
2536  		sc->rtsx_intr_trans_ok = rtsx_put_ppbuf_part1;
2537  
2538  		/* Run the command queue. */
2539  		rtsx_send_req(sc, cmd);
2540  	}
2541  
2542  	return (0);
2543  }
2544  
2545  /*
2546   * Use the ping-pong buffer (cmd buffer) for the transfer - first part <= 256 bytes.
2547   * This Function is called by the interrupt handler via sc->rtsx_intr_trans_ok.
2548   */
2549  static void
2550  rtsx_ask_ppbuf_part1(struct rtsx_softc *sc)
2551  {
2552  	struct mmc_command *cmd;
2553  	uint16_t reg = RTSX_PPBUF_BASE2;
2554  	int	 len;
2555  	int	 i;
2556  
2557  	cmd = sc->rtsx_req->cmd;
2558  	len = (cmd->data->len > RTSX_HOSTCMD_MAX) ? RTSX_HOSTCMD_MAX : cmd->data->len;
2559  
2560  	sc->rtsx_cmd_index = 0;
2561  	for (i = 0; i < len; i++) {
2562  		rtsx_push_cmd(sc, RTSX_READ_REG_CMD, reg++, 0, 0);
2563  	}
2564  
2565  	/* Set transfer OK function. */
2566  	sc->rtsx_intr_trans_ok = rtsx_get_ppbuf_part1;
2567  
2568  	/* Run the command queue. */
2569  	rtsx_send_cmd(sc);
2570  }
2571  
2572  /*
2573   * Get the data from the ping-pong buffer (cmd buffer) - first part <= 256 bytes.
2574   * This Function is called by the interrupt handler via sc->rtsx_intr_trans_ok.
2575   */
2576  static void
2577  rtsx_get_ppbuf_part1(struct rtsx_softc *sc)
2578  {
2579  	struct mmc_command *cmd;
2580  	uint8_t	 *ptr;
2581  	int	 len;
2582  
2583  	cmd = sc->rtsx_req->cmd;
2584  	ptr = cmd->data->data;
2585  	len = (cmd->data->len > RTSX_HOSTCMD_MAX) ? RTSX_HOSTCMD_MAX : cmd->data->len;
2586  
2587  	/* Sync command DMA buffer. */
2588  	bus_dmamap_sync(sc->rtsx_cmd_dma_tag, sc->rtsx_cmd_dmamap, BUS_DMASYNC_POSTREAD);
2589  	bus_dmamap_sync(sc->rtsx_cmd_dma_tag, sc->rtsx_cmd_dmamap, BUS_DMASYNC_POSTWRITE);
2590  
2591  	memcpy(ptr, sc->rtsx_cmd_dmamem, len);
2592  
2593  	len = (cmd->data->len > RTSX_HOSTCMD_MAX) ? cmd->data->len - RTSX_HOSTCMD_MAX : 0;
2594  
2595  	/* Use the ping-pong buffer (cmd buffer) for the transfer - second part > 256 bytes. */
2596  	if (len > 0) {
2597  		uint16_t reg = RTSX_PPBUF_BASE2 + RTSX_HOSTCMD_MAX;
2598  		int	 i;
2599  
2600  		sc->rtsx_cmd_index = 0;
2601  		for (i = 0; i < len; i++) {
2602  			rtsx_push_cmd(sc, RTSX_READ_REG_CMD, reg++, 0, 0);
2603  		}
2604  
2605  		/* Set transfer OK function. */
2606  		sc->rtsx_intr_trans_ok = rtsx_get_ppbuf_part2;
2607  
2608  		/* Run the command queue. */
2609  		rtsx_send_cmd(sc);
2610  	} else {
2611  		if (sc->rtsx_debug_mask & RTSX_TRACE_SD_CMD && cmd->opcode == ACMD_SEND_SCR) {
2612  			uint8_t *ptr = cmd->data->data;
2613  			device_printf(sc->rtsx_dev, "SCR: 0x%02x%02x%02x%02x%02x%02x%02x%02x\n",
2614  				      ptr[0], ptr[1], ptr[2], ptr[3],
2615  				      ptr[4], ptr[5], ptr[6], ptr[7]);
2616  		}
2617  
2618  		if (sc->rtsx_discovery_mode)
2619  			rtsx_write(sc, RTSX_SD_CFG1, RTSX_CLK_DIVIDE_MASK, RTSX_CLK_DIVIDE_128);
2620  
2621  		rtsx_req_done(sc);
2622  	}
2623  }
2624  
2625  /*
2626   * Get the data from the ping-pong buffer (cmd buffer) - second part > 256 bytes.
2627   * This Function is called by the interrupt handler via sc->rtsx_intr_trans_ok.
2628   */
2629  static void
2630  rtsx_get_ppbuf_part2(struct rtsx_softc *sc)
2631  {
2632  	struct mmc_command *cmd;
2633  	uint8_t	*ptr;
2634  	int	len;
2635  
2636  	cmd = sc->rtsx_req->cmd;
2637  	ptr = cmd->data->data;
2638  	ptr += RTSX_HOSTCMD_MAX;
2639  	len = cmd->data->len - RTSX_HOSTCMD_MAX;
2640  
2641  	/* Sync command DMA buffer. */
2642  	bus_dmamap_sync(sc->rtsx_cmd_dma_tag, sc->rtsx_cmd_dmamap, BUS_DMASYNC_POSTREAD);
2643  	bus_dmamap_sync(sc->rtsx_cmd_dma_tag, sc->rtsx_cmd_dmamap, BUS_DMASYNC_POSTWRITE);
2644  
2645  	memcpy(ptr, sc->rtsx_cmd_dmamem, len);
2646  
2647  	if (sc->rtsx_discovery_mode)
2648  		rtsx_write(sc, RTSX_SD_CFG1, RTSX_CLK_DIVIDE_MASK, RTSX_CLK_DIVIDE_128);
2649  
2650  	rtsx_req_done(sc);
2651  }
2652  
2653  /*
2654   * Use the ping-pong buffer (cmd buffer) for transfer - first part <= 256 bytes.
2655   * This Function is called by the interrupt handler via sc->rtsx_intr_trans_ok.
2656   */
2657  static void
2658  rtsx_put_ppbuf_part1(struct rtsx_softc *sc)
2659  {
2660  	struct mmc_command *cmd;
2661  	uint16_t reg = RTSX_PPBUF_BASE2;
2662  	uint8_t	 *ptr;
2663  	int	 len;
2664  	int	 i;
2665  
2666  	cmd = sc->rtsx_req->cmd;
2667  	ptr = cmd->data->data;
2668  	len = (cmd->data->len > RTSX_HOSTCMD_MAX) ? RTSX_HOSTCMD_MAX : cmd->data->len;
2669  
2670  	rtsx_set_resp(sc, cmd);
2671  
2672  	sc->rtsx_cmd_index = 0;
2673  	for (i = 0; i < len; i++) {
2674  		rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, reg++, 0xff, *ptr);
2675  		ptr++;
2676  	}
2677  
2678  	/* Set transfer OK function. */
2679  	if (cmd->data->len > RTSX_HOSTCMD_MAX)
2680  		sc->rtsx_intr_trans_ok = rtsx_put_ppbuf_part2;
2681  	else
2682  		sc->rtsx_intr_trans_ok = rtsx_write_ppbuf;
2683  
2684  	/* Run the command queue. */
2685  	rtsx_send_cmd(sc);
2686  }
2687  
2688  /*
2689   * Use the ping-pong buffer (cmd buffer) for transfer - second part > 256 bytes.
2690   * This Function is called by the interrupt handler via sc->rtsx_intr_trans_ok.
2691   */
2692  static void
2693  rtsx_put_ppbuf_part2(struct rtsx_softc *sc)
2694  {
2695  	struct mmc_command *cmd;
2696  	uint16_t reg = RTSX_PPBUF_BASE2 + RTSX_HOSTCMD_MAX;
2697  	uint8_t	 *ptr;
2698  	int	 len;
2699  	int	 i;
2700  
2701  	cmd = sc->rtsx_req->cmd;
2702  	ptr = cmd->data->data;
2703  	ptr += RTSX_HOSTCMD_MAX;
2704  	len = cmd->data->len - RTSX_HOSTCMD_MAX;
2705  
2706  	sc->rtsx_cmd_index = 0;
2707  	for (i = 0; i < len; i++) {
2708  		rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, reg++, 0xff, *ptr);
2709  		ptr++;
2710  	}
2711  
2712  	/* Set transfer OK function. */
2713  	sc->rtsx_intr_trans_ok = rtsx_write_ppbuf;
2714  
2715  	/* Run the command queue. */
2716  	rtsx_send_cmd(sc);
2717  }
2718  
2719  /*
2720   * Write the data previously given via the ping-pong buffer on the card.
2721   * This Function is called by the interrupt handler via sc->rtsx_intr_trans_ok.
2722   */
2723  static void
2724  rtsx_write_ppbuf(struct rtsx_softc *sc)
2725  {
2726  	struct mmc_command *cmd;
2727  
2728  	cmd = sc->rtsx_req->cmd;
2729  
2730  	sc->rtsx_cmd_index = 0;
2731  
2732  	/* Queue commands to configure data transfer size. */
2733  	rtsx_set_cmd_data_len(sc, cmd->data->len / cmd->data->xfer_len, cmd->data->xfer_len);
2734  
2735  	/* From Linux: rtsx_pci_sdmmc.c sd_write_data(). */
2736  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_CFG2, 0xff,
2737  		      RTSX_SD_CALCULATE_CRC7 | RTSX_SD_CHECK_CRC16 |
2738  		      RTSX_SD_NO_WAIT_BUSY_END | RTSX_SD_CHECK_CRC7 | RTSX_SD_RSP_LEN_0);
2739  
2740  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_TRANSFER, 0xff,
2741  		      RTSX_TM_AUTO_WRITE3 | RTSX_SD_TRANSFER_START);
2742  	rtsx_push_cmd(sc, RTSX_CHECK_REG_CMD, RTSX_SD_TRANSFER,
2743  		      RTSX_SD_TRANSFER_END, RTSX_SD_TRANSFER_END);
2744  
2745  	/* Set transfer OK function. */
2746  	sc->rtsx_intr_trans_ok = rtsx_req_done;
2747  
2748  	/* Run the command queue. */
2749  	rtsx_send_cmd(sc);
2750  }
2751  
2752  /*
2753   * Use the data buffer for transfer > 512 bytes.
2754   */
2755  static int
2756  rtsx_xfer(struct rtsx_softc *sc, struct mmc_command *cmd)
2757  {
2758  	int	read = ISSET(cmd->data->flags, MMC_DATA_READ);
2759  
2760  	cmd->data->xfer_len = (cmd->data->len > RTSX_MAX_DATA_BLKLEN) ?
2761  		RTSX_MAX_DATA_BLKLEN : cmd->data->len;
2762  
2763  	if (sc->rtsx_debug_mask & RTSX_TRACE_SD_CMD)
2764  		device_printf(sc->rtsx_dev, "rtsx_xfer() - %s xfer: %ld bytes with block size %ld\n",
2765  			      read ? "Read" : "Write",
2766  			      (unsigned long)cmd->data->len, (unsigned long)cmd->data->xfer_len);
2767  
2768  	if (cmd->data->len > RTSX_DMA_DATA_BUFSIZE) {
2769  		device_printf(sc->rtsx_dev, "rtsx_xfer() length too large: %ld > %ld\n",
2770  			      (unsigned long)cmd->data->len, RTSX_DMA_DATA_BUFSIZE);
2771  		cmd->error = MMC_ERR_INVALID;
2772  		return (MMC_ERR_INVALID);
2773  	}
2774  
2775  	if (!read) {
2776  		/* Set transfer OK function. */
2777  		sc->rtsx_intr_trans_ok = rtsx_xfer_begin;
2778  
2779  		/* Run the command queue. */
2780  		rtsx_send_req(sc, cmd);
2781  	} else {
2782  		rtsx_xfer_start(sc);
2783  	}
2784  
2785  	return (0);
2786  }
2787  
2788  /*
2789   * Get request response and start dma data transfer (write command).
2790   * This Function is called by the interrupt handler via sc->rtsx_intr_trans_ok.
2791   */
2792  static void
2793  rtsx_xfer_begin(struct rtsx_softc *sc)
2794  {
2795  	struct mmc_command *cmd;
2796  
2797  	cmd = sc->rtsx_req->cmd;
2798  
2799  	if (sc->rtsx_debug_mask & RTSX_TRACE_SD_CMD)
2800  		device_printf(sc->rtsx_dev, "rtsx_xfer_begin() - CMD%d\n", cmd->opcode);
2801  
2802  	rtsx_set_resp(sc, cmd);
2803  	rtsx_xfer_start(sc);
2804  }
2805  
2806  /*
2807   * Start dma data transfer.
2808   */
2809  static void
2810  rtsx_xfer_start(struct rtsx_softc *sc)
2811  {
2812  	struct mmc_command *cmd;
2813  	int	read;
2814  	uint8_t	cfg2;
2815  	int	dma_dir;
2816  	int	tmode;
2817  
2818  	cmd = sc->rtsx_req->cmd;
2819  	read = ISSET(cmd->data->flags, MMC_DATA_READ);
2820  
2821  	/* Configure DMA transfer mode parameters. */
2822  	if (cmd->opcode == MMC_READ_MULTIPLE_BLOCK)
2823  		cfg2 = RTSX_SD_CHECK_CRC16 | RTSX_SD_NO_WAIT_BUSY_END | RTSX_SD_RSP_LEN_6;
2824  	else
2825  		cfg2 = RTSX_SD_CHECK_CRC16 | RTSX_SD_NO_WAIT_BUSY_END | RTSX_SD_RSP_LEN_0;
2826  	if (read) {
2827  		dma_dir = RTSX_DMA_DIR_FROM_CARD;
2828  		/*
2829  		 * Use transfer mode AUTO_READ1, which assume we not
2830  		 * already send the read command and don't need to send
2831  		 * CMD 12 manually after read.
2832  		 */
2833  		tmode = RTSX_TM_AUTO_READ1;
2834  		cfg2 |= RTSX_SD_CALCULATE_CRC7 | RTSX_SD_CHECK_CRC7;
2835  
2836  		rtsx_init_cmd(sc, cmd);
2837  	} else {
2838  		dma_dir = RTSX_DMA_DIR_TO_CARD;
2839  		/*
2840  		 * Use transfer mode AUTO_WRITE3, wich assumes we've already
2841  		 * sent the write command and gotten the response, and will
2842  		 * send CMD 12 manually after writing.
2843  		 */
2844  		tmode = RTSX_TM_AUTO_WRITE3;
2845  		cfg2 |= RTSX_SD_NO_CALCULATE_CRC7 | RTSX_SD_NO_CHECK_CRC7;
2846  
2847  		sc->rtsx_cmd_index = 0;
2848  	}
2849  
2850  	/* Queue commands to configure data transfer size. */
2851  	rtsx_set_cmd_data_len(sc, cmd->data->len / cmd->data->xfer_len, cmd->data->xfer_len);
2852  
2853  	/* Configure DMA controller. */
2854  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_IRQSTAT0,
2855  		     RTSX_DMA_DONE_INT, RTSX_DMA_DONE_INT);
2856  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_DMATC3,
2857  		     0xff, cmd->data->len >> 24);
2858  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_DMATC2,
2859  		     0xff, cmd->data->len >> 16);
2860  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_DMATC1,
2861  		     0xff, cmd->data->len >> 8);
2862  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_DMATC0,
2863  		     0xff, cmd->data->len);
2864  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_DMACTL,
2865  		     RTSX_DMA_EN | RTSX_DMA_DIR | RTSX_DMA_PACK_SIZE_MASK,
2866  		     RTSX_DMA_EN | dma_dir | RTSX_DMA_512);
2867  
2868  	/* Use the DMA ring buffer for commands which transfer data. */
2869  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_CARD_DATA_SOURCE,
2870  		      0x01, RTSX_RING_BUFFER);
2871  
2872  	/* Queue command to set response type. */
2873  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_CFG2, 0xff, cfg2);
2874  
2875  	/* Queue commands to perform SD transfer. */
2876  	rtsx_push_cmd(sc, RTSX_WRITE_REG_CMD, RTSX_SD_TRANSFER,
2877  		      0xff, tmode | RTSX_SD_TRANSFER_START);
2878  	rtsx_push_cmd(sc, RTSX_CHECK_REG_CMD, RTSX_SD_TRANSFER,
2879  		      RTSX_SD_TRANSFER_END, RTSX_SD_TRANSFER_END);
2880  
2881  	/* Run the command queue. */
2882  	rtsx_send_cmd(sc);
2883  
2884  	if (!read)
2885  		memcpy(sc->rtsx_data_dmamem, cmd->data->data, cmd->data->len);
2886  
2887  	/* Sync data DMA buffer. */
2888  	bus_dmamap_sync(sc->rtsx_data_dma_tag, sc->rtsx_data_dmamap, BUS_DMASYNC_PREREAD);
2889  	bus_dmamap_sync(sc->rtsx_data_dma_tag, sc->rtsx_data_dmamap, BUS_DMASYNC_PREWRITE);
2890  
2891  	/* Set transfer OK function. */
2892  	sc->rtsx_intr_trans_ok = rtsx_xfer_finish;
2893  
2894  	/* Tell the chip where the data buffer is and run the transfer. */
2895  	WRITE4(sc, RTSX_HDBAR, sc->rtsx_data_buffer);
2896  	WRITE4(sc, RTSX_HDBCTLR, RTSX_TRIG_DMA | (read ? RTSX_DMA_READ : 0) |
2897  	       (cmd->data->len & 0x00ffffff));
2898  }
2899  
2900  /*
2901   * Finish dma data transfer.
2902   * This Function is called by the interrupt handler via sc->rtsx_intr_trans_ok.
2903   */
2904  static void
2905  rtsx_xfer_finish(struct rtsx_softc *sc)
2906  {
2907  	struct mmc_command *cmd;
2908  	int	read;
2909  
2910  	cmd = sc->rtsx_req->cmd;
2911  
2912  	if (sc->rtsx_debug_mask & RTSX_TRACE_SD_CMD)
2913  		device_printf(sc->rtsx_dev, "rtsx_xfer_finish() - CMD%d\n", cmd->opcode);
2914  
2915  	read = ISSET(cmd->data->flags, MMC_DATA_READ);
2916  
2917  	/* Sync data DMA buffer. */
2918  	bus_dmamap_sync(sc->rtsx_data_dma_tag, sc->rtsx_data_dmamap, BUS_DMASYNC_POSTREAD);
2919  	bus_dmamap_sync(sc->rtsx_data_dma_tag, sc->rtsx_data_dmamap, BUS_DMASYNC_POSTWRITE);
2920  
2921  	if (read) {
2922  		memcpy(cmd->data->data, sc->rtsx_data_dmamem, cmd->data->len);
2923  		rtsx_req_done(sc);
2924  	} else {
2925  		/* Send CMD12 after AUTO_WRITE3 (see mmcsd_rw() in mmcsd.c) */
2926  		/* and complete request. */
2927  		sc->rtsx_intr_trans_ok = NULL;
2928  		rtsx_send_req(sc, sc->rtsx_req->stop);
2929  	}
2930  }
2931  
2932  /*
2933   * Manage request timeout.
2934   */
2935  static void
2936  rtsx_timeout(void *arg)
2937  {
2938  	struct rtsx_softc *sc;
2939  
2940  	sc = (struct rtsx_softc *)arg;
2941  	if (sc->rtsx_req != NULL) {
2942  		device_printf(sc->rtsx_dev, "Controller timeout for CMD%u\n",
2943  			      sc->rtsx_req->cmd->opcode);
2944  		sc->rtsx_req->cmd->error = MMC_ERR_TIMEOUT;
2945  		rtsx_stop_cmd(sc);
2946  		rtsx_req_done(sc);
2947  	} else {
2948  		device_printf(sc->rtsx_dev, "Controller timeout!\n");
2949  	}
2950  }
2951  
2952  #ifdef MMCCAM
2953  static int
2954  rtsx_get_tran_settings(device_t dev, struct ccb_trans_settings_mmc *cts)
2955  {
2956  	struct rtsx_softc *sc;
2957  
2958  	sc = device_get_softc(dev);
2959  
2960  	cts->host_ocr = sc->rtsx_host.host_ocr;
2961  	cts->host_f_min = sc->rtsx_host.f_min;
2962  	cts->host_f_max = sc->rtsx_host.f_max;
2963  	cts->host_caps = sc->rtsx_host.caps;
2964  	cts->host_max_data = RTSX_DMA_DATA_BUFSIZE / MMC_SECTOR_SIZE;
2965  	memcpy(&cts->ios, &sc->rtsx_host.ios, sizeof(struct mmc_ios));
2966  
2967  	return (0);
2968  }
2969  
2970  /*
2971   *  Apply settings and return status accordingly.
2972  */
2973  static int
2974  rtsx_set_tran_settings(device_t dev, struct ccb_trans_settings_mmc *cts)
2975  {
2976  	struct rtsx_softc *sc;
2977  	struct mmc_ios *ios;
2978  	struct mmc_ios *new_ios;
2979  
2980  	sc = device_get_softc(dev);
2981  
2982  	ios = &sc->rtsx_host.ios;
2983  	new_ios = &cts->ios;
2984  
2985  	/* Update only requested fields */
2986  	if (cts->ios_valid & MMC_CLK) {
2987  		ios->clock = new_ios->clock;
2988  		sc->rtsx_ios_clock = -1;	/* To be updated by rtsx_mmcbr_update_ios(). */
2989  		if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
2990  			device_printf(sc->rtsx_dev, "rtsx_set_tran_settings() - clock: %u\n", ios->clock);
2991  	}
2992  	if (cts->ios_valid & MMC_VDD) {
2993  		ios->vdd = new_ios->vdd;
2994  		if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
2995  			device_printf(sc->rtsx_dev, "rtsx_set_tran_settings() - vdd: %d\n", ios->vdd);
2996  	}
2997  	if (cts->ios_valid & MMC_CS) {
2998  		ios->chip_select = new_ios->chip_select;
2999  		if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
3000  			device_printf(sc->rtsx_dev, "rtsx_set_tran_settings() - chip_select: %d\n", ios->chip_select);
3001  	}
3002  	if (cts->ios_valid & MMC_BW) {
3003  		ios->bus_width = new_ios->bus_width;
3004  		sc->rtsx_ios_bus_width = -1;	/* To be updated by rtsx_mmcbr_update_ios(). */
3005  		if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
3006  			device_printf(sc->rtsx_dev, "rtsx_set_tran_settings() - bus width: %d\n", ios->bus_width);
3007  	}
3008  	if (cts->ios_valid & MMC_PM) {
3009  		ios->power_mode = new_ios->power_mode;
3010  		sc->rtsx_ios_power_mode = -1;	/* To be updated by rtsx_mmcbr_update_ios(). */
3011  		if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
3012  			device_printf(sc->rtsx_dev, "rtsx_set_tran_settings() - power mode: %d\n", ios->power_mode);
3013  	}
3014  	if (cts->ios_valid & MMC_BT) {
3015  		ios->timing = new_ios->timing;
3016  		sc->rtsx_ios_timing = -1;	/* To be updated by rtsx_mmcbr_update_ios(). */
3017  		if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
3018  			device_printf(sc->rtsx_dev, "rtsx_set_tran_settings() - timing: %d\n", ios->timing);
3019  	}
3020  	if (cts->ios_valid & MMC_BM) {
3021  		ios->bus_mode = new_ios->bus_mode;
3022  		if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
3023  			device_printf(sc->rtsx_dev, "rtsx_set_tran_settings() - bus mode: %d\n", ios->bus_mode);
3024  	}
3025  #if  __FreeBSD_version >= 1300000
3026  	if (cts->ios_valid & MMC_VCCQ) {
3027  		ios->vccq = new_ios->vccq;
3028  		sc->rtsx_ios_vccq = -1;		/* To be updated by rtsx_mmcbr_update_ios(). */
3029  		if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
3030  			device_printf(sc->rtsx_dev, "rtsx_set_tran_settings() - vccq: %d\n", ios->vccq);
3031  	}
3032  #endif /* __FreeBSD_version >= 1300000 */
3033  	if (rtsx_mmcbr_update_ios(sc->rtsx_dev, NULL) == 0)
3034  		return (CAM_REQ_CMP);
3035  	else
3036  		return (CAM_REQ_CMP_ERR);
3037  }
3038  
3039  /*
3040   * Build a request and run it.
3041   */
3042  static int
3043  rtsx_cam_request(device_t dev, union ccb *ccb)
3044  {
3045  	struct rtsx_softc *sc;
3046  
3047  	sc = device_get_softc(dev);
3048  
3049  	RTSX_LOCK(sc);
3050  	if (sc->rtsx_ccb != NULL) {
3051  		RTSX_UNLOCK(sc);
3052  		return (CAM_BUSY);
3053  	}
3054  	sc->rtsx_ccb = ccb;
3055  	sc->rtsx_cam_req.cmd = &ccb->mmcio.cmd;
3056  	sc->rtsx_cam_req.stop = &ccb->mmcio.stop;
3057  	RTSX_UNLOCK(sc);
3058  
3059  	rtsx_mmcbr_request(sc->rtsx_dev, NULL, &sc->rtsx_cam_req);
3060  	return (0);
3061  }
3062  #endif /* MMCCAM */
3063  
3064  static int
3065  rtsx_read_ivar(device_t bus, device_t child, int which, uintptr_t *result)
3066  {
3067  	struct rtsx_softc *sc;
3068  
3069  	sc = device_get_softc(bus);
3070  	switch (which) {
3071  	case MMCBR_IVAR_BUS_MODE:		/* ivar  0 - 1 = opendrain, 2 = pushpull */
3072  		*result = sc->rtsx_host.ios.bus_mode;
3073  		break;
3074  	case MMCBR_IVAR_BUS_WIDTH:		/* ivar  1 - 0 = 1b   2 = 4b, 3 = 8b */
3075  		*result = sc->rtsx_host.ios.bus_width;
3076  		break;
3077  	case MMCBR_IVAR_CHIP_SELECT:		/* ivar  2 - O = dontcare, 1 = cs_high, 2 = cs_low */
3078  		*result = sc->rtsx_host.ios.chip_select;
3079  		break;
3080  	case MMCBR_IVAR_CLOCK:			/* ivar  3 - clock in Hz */
3081  		*result = sc->rtsx_host.ios.clock;
3082  		break;
3083  	case MMCBR_IVAR_F_MIN:			/* ivar  4 */
3084  		*result = sc->rtsx_host.f_min;
3085  		break;
3086  	case MMCBR_IVAR_F_MAX:			/* ivar  5 */
3087  		*result = sc->rtsx_host.f_max;
3088  		break;
3089  	case MMCBR_IVAR_HOST_OCR: 		/* ivar  6 - host operation conditions register */
3090  		*result = sc->rtsx_host.host_ocr;
3091  		break;
3092  	case MMCBR_IVAR_MODE:			/* ivar  7 - 0 = mode_mmc, 1 = mode_sd */
3093  		*result = sc->rtsx_host.mode;
3094  		break;
3095  	case MMCBR_IVAR_OCR:			/* ivar  8 - operation conditions register */
3096  		*result = sc->rtsx_host.ocr;
3097  		break;
3098  	case MMCBR_IVAR_POWER_MODE:		/* ivar  9 - 0 = off, 1 = up, 2 = on */
3099  		*result = sc->rtsx_host.ios.power_mode;
3100  		break;
3101  	case MMCBR_IVAR_VDD:			/* ivar 11 - voltage power pin */
3102  		*result = sc->rtsx_host.ios.vdd;
3103  		break;
3104  	case MMCBR_IVAR_VCCQ:			/* ivar 12 - signaling: 0 = 1.20V, 1 = 1.80V, 2 = 3.30V */
3105  		*result = sc->rtsx_host.ios.vccq;
3106  		break;
3107  	case MMCBR_IVAR_CAPS:			/* ivar 13 */
3108  		*result = sc->rtsx_host.caps;
3109  		break;
3110  	case MMCBR_IVAR_TIMING:			/* ivar 14 - 0 = normal, 1 = timing_hs, ... */
3111  		*result = sc->rtsx_host.ios.timing;
3112  		break;
3113  	case MMCBR_IVAR_MAX_DATA:		/* ivar 15 */
3114  		*result = RTSX_DMA_DATA_BUFSIZE / MMC_SECTOR_SIZE;
3115  		break;
3116  	case MMCBR_IVAR_RETUNE_REQ:		/* ivar 10 */
3117  	case MMCBR_IVAR_MAX_BUSY_TIMEOUT:	/* ivar 16 */
3118  	default:
3119  		return (EINVAL);
3120  	}
3121  
3122  	if (sc->rtsx_debug_mask & RTSX_TRACE_SD_CMD)
3123  		device_printf(bus, "Read ivar #%d, value %#x / #%d\n",
3124  			      which, *(int *)result, *(int *)result);
3125  
3126  	return (0);
3127  }
3128  
3129  static int
3130  rtsx_write_ivar(device_t bus, device_t child, int which, uintptr_t value)
3131  {
3132  	struct rtsx_softc *sc;
3133  
3134  	sc = device_get_softc(bus);
3135  	if (sc->rtsx_debug_mask & RTSX_TRACE_SD_CMD)
3136  		device_printf(bus, "Write ivar #%d, value %#x / #%d\n",
3137  			      which, (int)value, (int)value);
3138  
3139  	switch (which) {
3140  	case MMCBR_IVAR_BUS_MODE:		/* ivar  0 - 1 = opendrain, 2 = pushpull */
3141  		sc->rtsx_host.ios.bus_mode = value;
3142  		break;
3143  	case MMCBR_IVAR_BUS_WIDTH:		/* ivar  1 - 0 = 1b   2 = 4b, 3 = 8b */
3144  		sc->rtsx_host.ios.bus_width = value;
3145  		sc->rtsx_ios_bus_width = -1;	/* To be updated on next rtsx_mmcbr_update_ios(). */
3146  		break;
3147  	case MMCBR_IVAR_CHIP_SELECT:		/* ivar  2 - O = dontcare, 1 = cs_high, 2 = cs_low */
3148  		sc->rtsx_host.ios.chip_select = value;
3149  		break;
3150  	case MMCBR_IVAR_CLOCK:			/* ivar  3 - clock in Hz */
3151  		sc->rtsx_host.ios.clock = value;
3152  		sc->rtsx_ios_clock = -1;	/* To be updated on next rtsx_mmcbr_update_ios(). */
3153  		break;
3154  	case MMCBR_IVAR_MODE:			/* ivar  7 - 0 = mode_mmc, 1 = mode_sd */
3155  		sc->rtsx_host.mode = value;
3156  		break;
3157  	case MMCBR_IVAR_OCR:			/* ivar  8 - operation conditions register */
3158  		sc->rtsx_host.ocr = value;
3159  		break;
3160  	case MMCBR_IVAR_POWER_MODE:		/* ivar  9 - 0 = off, 1 = up, 2 = on */
3161  		sc->rtsx_host.ios.power_mode = value;
3162  		sc->rtsx_ios_power_mode = -1;	/* To be updated on next rtsx_mmcbr_update_ios(). */
3163  		break;
3164  	case MMCBR_IVAR_VDD:			/* ivar 11 - voltage power pin */
3165  		sc->rtsx_host.ios.vdd = value;
3166  		break;
3167  	case MMCBR_IVAR_VCCQ:			/* ivar 12 - signaling: 0 = 1.20V, 1 = 1.80V, 2 = 3.30V */
3168  		sc->rtsx_host.ios.vccq = value;
3169  		sc->rtsx_ios_vccq = value;	/* rtsx_mmcbr_switch_vccq() will be called by mmc.c (MMCCAM undef). */
3170  		break;
3171  	case MMCBR_IVAR_TIMING:			/* ivar 14 - 0 = normal, 1 = timing_hs, ... */
3172  		sc->rtsx_host.ios.timing = value;
3173  		sc->rtsx_ios_timing = -1;	/* To be updated on next rtsx_mmcbr_update_ios(). */
3174  		break;
3175  	/* These are read-only. */
3176  	case MMCBR_IVAR_F_MIN:			/* ivar  4 */
3177  	case MMCBR_IVAR_F_MAX:			/* ivar  5 */
3178  	case MMCBR_IVAR_HOST_OCR: 		/* ivar  6 - host operation conditions register */
3179  	case MMCBR_IVAR_RETUNE_REQ:		/* ivar 10 */
3180  	case MMCBR_IVAR_CAPS:			/* ivar 13 */
3181  	case MMCBR_IVAR_MAX_DATA:		/* ivar 15 */
3182  	case MMCBR_IVAR_MAX_BUSY_TIMEOUT:	/* ivar 16 */
3183  	default:
3184  		return (EINVAL);
3185  	}
3186  
3187  	return (0);
3188  }
3189  
3190  static int
3191  rtsx_mmcbr_update_ios(device_t bus, device_t child__unused)
3192  {
3193  	struct rtsx_softc *sc;
3194  	struct mmc_ios	  *ios;
3195  	int	error;
3196  
3197  	sc = device_get_softc(bus);
3198  	ios = &sc->rtsx_host.ios;
3199  
3200  	if (sc->rtsx_debug_mask & RTSX_TRACE_SD_CMD)
3201  		device_printf(bus, "rtsx_mmcbr_update_ios()\n");
3202  
3203  	/* if MMCBR_IVAR_BUS_WIDTH updated. */
3204  	if (sc->rtsx_ios_bus_width < 0) {
3205  		sc->rtsx_ios_bus_width = ios->bus_width;
3206  		if ((error = rtsx_set_bus_width(sc, ios->bus_width)))
3207  			return (error);
3208  	}
3209  
3210  	/* if MMCBR_IVAR_POWER_MODE updated. */
3211  	if (sc->rtsx_ios_power_mode < 0) {
3212  		sc->rtsx_ios_power_mode = ios->power_mode;
3213  		switch (ios->power_mode) {
3214  		case power_off:
3215  			if ((error = rtsx_bus_power_off(sc)))
3216  				return (error);
3217  			break;
3218  		case power_up:
3219  			if ((error = rtsx_bus_power_on(sc)))
3220  				return (error);
3221  			break;
3222  		case power_on:
3223  			if ((error = rtsx_bus_power_on(sc)))
3224  				return (error);
3225  			break;
3226  		}
3227  	}
3228  
3229  	sc->rtsx_double_clk = true;
3230  	sc->rtsx_vpclk = false;
3231  
3232  	/* if MMCBR_IVAR_TIMING updated. */
3233  	if (sc->rtsx_ios_timing < 0) {
3234  		sc->rtsx_ios_timing = ios->timing;
3235  		if ((error = rtsx_set_sd_timing(sc, ios->timing)))
3236  			return (error);
3237  	}
3238  
3239  	/* if MMCBR_IVAR_CLOCK updated, must be after rtsx_set_sd_timing() */
3240  	if (sc->rtsx_ios_clock < 0) {
3241  		sc->rtsx_ios_clock = ios->clock;
3242  		if ((error = rtsx_set_sd_clock(sc, ios->clock)))
3243  			return (error);
3244  	}
3245  
3246  	/* if MMCCAM and vccq updated */
3247  	if (sc->rtsx_ios_vccq < 0) {
3248  		sc->rtsx_ios_vccq = ios->vccq;
3249  		if ((error = rtsx_mmcbr_switch_vccq(sc->rtsx_dev, NULL)))
3250  			return (error);
3251  	}
3252  
3253  	return (0);
3254  }
3255  
3256  /*
3257   * Set output stage logic power voltage.
3258   */
3259  static int
3260  rtsx_mmcbr_switch_vccq(device_t bus, device_t child __unused)
3261  {
3262  	struct rtsx_softc *sc;
3263  	int	vccq = 0;
3264  	int	error;
3265  
3266  	sc = device_get_softc(bus);
3267  
3268  	switch (sc->rtsx_host.ios.vccq) {
3269  	case vccq_120:
3270  		vccq = 120;
3271  		break;
3272  	case vccq_180:
3273  		vccq = 180;
3274  		break;
3275  	case vccq_330:
3276  		vccq = 330;
3277  		break;
3278  	};
3279  	/* It seems it is always vccq_330. */
3280  	if (vccq == 330) {
3281  		switch (sc->rtsx_device_id) {
3282  			uint16_t val;
3283  		case RTSX_RTS5227:
3284  			if ((error = rtsx_write_phy(sc, 0x08, 0x4FE4)))
3285  				return (error);
3286  			if ((error = rtsx_rts5227_fill_driving(sc)))
3287  				return (error);
3288  			break;
3289  		case RTSX_RTS5209:
3290  		case RTSX_RTS5229:
3291  			RTSX_BITOP(sc, RTSX_SD30_CMD_DRIVE_SEL, RTSX_SD30_DRIVE_SEL_MASK, sc->rtsx_sd30_drive_sel_3v3);
3292  			if ((error = rtsx_write_phy(sc, 0x08, 0x4FE4)))
3293  				return (error);
3294  			break;
3295  		case RTSX_RTS522A:
3296  			if ((error = rtsx_write_phy(sc, 0x08, 0x57E4)))
3297  				return (error);
3298  			if ((error = rtsx_rts5227_fill_driving(sc)))
3299  				return (error);
3300  			break;
3301  		case RTSX_RTS525A:
3302  			RTSX_BITOP(sc, RTSX_LDO_CONFIG2, RTSX_LDO_D3318_MASK, RTSX_LDO_D3318_33V);
3303  			RTSX_BITOP(sc, RTSX_SD_PAD_CTL, RTSX_SD_IO_USING_1V8, 0);
3304  			if ((error = rtsx_rts5249_fill_driving(sc)))
3305  				return (error);
3306  			break;
3307  		case RTSX_RTS5249:
3308  			if ((error = rtsx_read_phy(sc, RTSX_PHY_TUNE, &val)))
3309  				return (error);
3310  			if ((error = rtsx_write_phy(sc, RTSX_PHY_TUNE,
3311  						    (val & RTSX_PHY_TUNE_VOLTAGE_MASK) | RTSX_PHY_TUNE_VOLTAGE_3V3)))
3312  				return (error);
3313  			if ((error = rtsx_rts5249_fill_driving(sc)))
3314  				return (error);
3315  			break;
3316  		case RTSX_RTS5260:
3317  			RTSX_BITOP(sc, RTSX_LDO_CONFIG2, RTSX_DV331812_VDD1, RTSX_DV331812_VDD1);
3318  			RTSX_BITOP(sc, RTSX_LDO_DV18_CFG, RTSX_DV331812_MASK, RTSX_DV331812_33);
3319  			RTSX_CLR(sc, RTSX_SD_PAD_CTL, RTSX_SD_IO_USING_1V8);
3320  			if ((error = rtsx_rts5260_fill_driving(sc)))
3321  				return (error);
3322  			break;
3323  		case RTSX_RTL8402:
3324  			RTSX_BITOP(sc, RTSX_SD30_CMD_DRIVE_SEL, RTSX_SD30_DRIVE_SEL_MASK, sc->rtsx_sd30_drive_sel_3v3);
3325  			RTSX_BITOP(sc, RTSX_LDO_CTL,
3326  				   (RTSX_BPP_ASIC_MASK << RTSX_BPP_SHIFT_8402) | RTSX_BPP_PAD_MASK,
3327  				   (RTSX_BPP_ASIC_3V3 << RTSX_BPP_SHIFT_8402) | RTSX_BPP_PAD_3V3);
3328  			break;
3329  		case RTSX_RTL8411:
3330  		case RTSX_RTL8411B:
3331  			RTSX_BITOP(sc, RTSX_SD30_CMD_DRIVE_SEL, RTSX_SD30_DRIVE_SEL_MASK, sc->rtsx_sd30_drive_sel_3v3);
3332  			RTSX_BITOP(sc, RTSX_LDO_CTL,
3333  				   (RTSX_BPP_ASIC_MASK << RTSX_BPP_SHIFT_8411) | RTSX_BPP_PAD_MASK,
3334  				   (RTSX_BPP_ASIC_3V3 << RTSX_BPP_SHIFT_8411) | RTSX_BPP_PAD_3V3);
3335  			break;
3336  		}
3337  		DELAY(300);
3338  	}
3339  
3340  	if (sc->rtsx_debug_mask & (RTSX_DEBUG_BASIC | RTSX_TRACE_SD_CMD))
3341  		device_printf(sc->rtsx_dev, "rtsx_mmcbr_switch_vccq(%d)\n", vccq);
3342  
3343  	return (0);
3344  }
3345  
3346  #ifndef MMCCAM
3347  /*
3348   * Tune card if bus_timing_uhs_sdr50.
3349   */
3350  static int
3351  rtsx_mmcbr_tune(device_t bus, device_t child __unused, bool hs400)
3352  {
3353  	struct rtsx_softc *sc;
3354  	uint32_t raw_phase_map[RTSX_RX_TUNING_CNT] = {0};
3355  	uint32_t phase_map;
3356  	uint8_t	 final_phase;
3357  	int	 i;
3358  
3359  	sc = device_get_softc(bus);
3360  
3361  	if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
3362  		device_printf(sc->rtsx_dev, "rtsx_mmcbr_tune() - hs400 is %s\n",
3363  			      (hs400) ? "true" : "false");
3364  
3365  	if (sc->rtsx_ios_timing != bus_timing_uhs_sdr50)
3366  		return (0);
3367  
3368  	sc->rtsx_tuning_mode = true;
3369  
3370  	switch (sc->rtsx_device_id) {
3371  	case RTSX_RTS5209:
3372  	case RTSX_RTS5227:
3373  		rtsx_sd_change_tx_phase(sc, 27);
3374  		break;
3375  	case RTSX_RTS522A:
3376  		rtsx_sd_change_tx_phase(sc, 20);
3377  		break;
3378  	case RTSX_RTS5229:
3379  		rtsx_sd_change_tx_phase(sc, 27);
3380  		break;
3381  	case RTSX_RTS525A:
3382  	case RTSX_RTS5249:
3383  		rtsx_sd_change_tx_phase(sc, 29);
3384  		break;
3385  	case RTSX_RTL8402:
3386  	case RTSX_RTL8411:
3387  	case RTSX_RTL8411B:
3388  		rtsx_sd_change_tx_phase(sc, 7);
3389  		break;
3390  	}
3391  
3392  	/* trying rx tuning for bus_timing_uhs_sdr50. */
3393  	for (i = 0; i < RTSX_RX_TUNING_CNT; i++) {
3394  		rtsx_sd_tuning_rx_phase(sc, &(raw_phase_map[i]));
3395  		if (raw_phase_map[i] == 0)
3396  			break;
3397  	}
3398  
3399  	phase_map = 0xffffffff;
3400  	for (i = 0; i < RTSX_RX_TUNING_CNT; i++) {
3401  		if (sc->rtsx_debug_mask & (RTSX_DEBUG_BASIC | RTSX_DEBUG_TUNING))
3402  			device_printf(sc->rtsx_dev, "rtsx_mmcbr_tune() - RX raw_phase_map[%d]: 0x%08x\n",
3403  				      i, raw_phase_map[i]);
3404  		phase_map &= raw_phase_map[i];
3405  	}
3406  	if (sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
3407  		device_printf(sc->rtsx_dev, "rtsx_mmcbr_tune() - RX phase_map: 0x%08x\n", phase_map);
3408  
3409  	if (phase_map) {
3410  		final_phase = rtsx_sd_search_final_rx_phase(sc, phase_map);
3411  		if (final_phase != 0xff) {
3412  			rtsx_sd_change_rx_phase(sc, final_phase);
3413  		}
3414  	}
3415  
3416  	sc->rtsx_tuning_mode = false;
3417  
3418  	return (0);
3419  }
3420  
3421  static int
3422  rtsx_mmcbr_retune(device_t bus, device_t child __unused, bool reset __unused)
3423  {
3424  	struct rtsx_softc *sc;
3425  
3426  	sc = device_get_softc(bus);
3427  
3428  	if (sc->rtsx_debug_mask & RTSX_TRACE_SD_CMD)
3429  		device_printf(sc->rtsx_dev, "rtsx_mmcbr_retune()\n");
3430  
3431  	return (0);
3432  }
3433  #endif /* !MMCCAM */
3434  
3435  static int
3436  rtsx_mmcbr_request(device_t bus, device_t child __unused, struct mmc_request *req)
3437  {
3438  	struct rtsx_softc  *sc;
3439  	struct mmc_command *cmd;
3440  	int	timeout;
3441  	int	error;
3442  
3443  	sc = device_get_softc(bus);
3444  
3445  	RTSX_LOCK(sc);
3446  	if (sc->rtsx_req != NULL) {
3447  		RTSX_UNLOCK(sc);
3448  		return (EBUSY);
3449  	}
3450  	sc->rtsx_req = req;
3451  	cmd = req->cmd;
3452  	cmd->error = error = MMC_ERR_NONE;
3453  	sc->rtsx_intr_status = 0;
3454  	sc->rtsx_intr_trans_ok = NULL;
3455  	sc->rtsx_intr_trans_ko = rtsx_req_done;
3456  
3457  	if (sc->rtsx_debug_mask & RTSX_TRACE_SD_CMD)
3458  		device_printf(sc->rtsx_dev, "rtsx_mmcbr_request(CMD%u arg %#x, flags %#x, dlen %u, dflags %#x)\n",
3459  			      cmd->opcode, cmd->arg, cmd->flags,
3460  			      cmd->data != NULL ? (unsigned int)cmd->data->len : 0,
3461  			      cmd->data != NULL ? cmd->data->flags : 0);
3462  
3463  	/* Check if card present. */
3464  	if (!ISSET(sc->rtsx_flags, RTSX_F_CARD_PRESENT)) {
3465  		cmd->error = error = MMC_ERR_FAILED;
3466  		goto end;
3467  	}
3468  
3469  	/* Refuse SDIO probe if the chip doesn't support SDIO. */
3470  	if (cmd->opcode == IO_SEND_OP_COND &&
3471  	    !ISSET(sc->rtsx_flags, RTSX_F_SDIO_SUPPORT)) {
3472  		cmd->error = error = MMC_ERR_INVALID;
3473  		goto end;
3474  	}
3475  
3476  	/* Return MMC_ERR_TIMEOUT for SD_IO_RW_DIRECT and IO_SEND_OP_COND. */
3477  	if (cmd->opcode == SD_IO_RW_DIRECT || cmd->opcode == IO_SEND_OP_COND) {
3478  		cmd->error = error = MMC_ERR_TIMEOUT;
3479  		goto end;
3480  	}
3481  
3482  	/* Select SD card. */
3483  	RTSX_BITOP(sc, RTSX_CARD_SELECT, 0x07, RTSX_SD_MOD_SEL);
3484  	RTSX_BITOP(sc, RTSX_CARD_SHARE_MODE, RTSX_CARD_SHARE_MASK, RTSX_CARD_SHARE_48_SD);
3485  
3486  	if (cmd->data == NULL) {
3487  		DELAY(200);
3488  		timeout = sc->rtsx_timeout_cmd;
3489  		error = rtsx_send_req(sc, cmd);
3490  	} else if (cmd->data->len <= 512) {
3491  		timeout = sc->rtsx_timeout_io;
3492  		error = rtsx_xfer_short(sc, cmd);
3493  	} else {
3494  		timeout = sc->rtsx_timeout_io;
3495  		error = rtsx_xfer(sc, cmd);
3496  	}
3497   end:
3498  	if (error == MMC_ERR_NONE) {
3499  		callout_reset(&sc->rtsx_timeout_callout, timeout * hz, rtsx_timeout, sc);
3500  	} else {
3501  		rtsx_req_done(sc);
3502  	}
3503  	RTSX_UNLOCK(sc);
3504  
3505  	return (error);
3506  }
3507  
3508  #ifndef MMCCAM
3509  static int
3510  rtsx_mmcbr_get_ro(device_t bus, device_t child __unused)
3511  {
3512  	struct rtsx_softc *sc;
3513  
3514  	sc = device_get_softc(bus);
3515  
3516  	if (sc->rtsx_inversion == 0)
3517  		return (sc->rtsx_read_only);
3518  	else
3519  		return !(sc->rtsx_read_only);
3520  }
3521  
3522  static int
3523  rtsx_mmcbr_acquire_host(device_t bus, device_t child __unused)
3524  {
3525  	struct rtsx_softc *sc;
3526  
3527  	sc = device_get_softc(bus);
3528  	if (sc->rtsx_debug_mask & RTSX_TRACE_SD_CMD)
3529  		device_printf(bus, "rtsx_mmcbr_acquire_host()\n");
3530  
3531  	RTSX_LOCK(sc);
3532  	while (sc->rtsx_bus_busy)
3533  		msleep(&sc->rtsx_bus_busy, &sc->rtsx_mtx, 0, "rtsxah", 0);
3534  	sc->rtsx_bus_busy++;
3535  	RTSX_UNLOCK(sc);
3536  
3537  	return (0);
3538  }
3539  
3540  static int
3541  rtsx_mmcbr_release_host(device_t bus, device_t child __unused)
3542  {
3543  	struct rtsx_softc *sc;
3544  
3545  	sc = device_get_softc(bus);
3546  	if (sc->rtsx_debug_mask & RTSX_TRACE_SD_CMD)
3547  		device_printf(bus, "rtsx_mmcbr_release_host()\n");
3548  
3549  	RTSX_LOCK(sc);
3550  	sc->rtsx_bus_busy--;
3551  	wakeup(&sc->rtsx_bus_busy);
3552  	RTSX_UNLOCK(sc);
3553  
3554  	return (0);
3555  }
3556  #endif /* !MMCCAM */
3557  
3558  /*
3559   *
3560   * PCI Support Functions
3561   *
3562   */
3563  
3564  /*
3565   * Compare the device ID (chip) of this device against the IDs that this driver
3566   * supports. If there is a match, set the description and return success.
3567   */
3568  static int
3569  rtsx_probe(device_t dev)
3570  {
3571  	uint16_t vendor_id;
3572  	uint16_t device_id;
3573  	int	 i;
3574  
3575  	vendor_id = pci_get_vendor(dev);
3576  	device_id = pci_get_device(dev);
3577  
3578  	if (vendor_id != RTSX_REALTEK)
3579  		return (ENXIO);
3580  	for (i = 0; i < nitems(rtsx_ids); i++) {
3581  		if (rtsx_ids[i].device_id == device_id) {
3582  			device_set_desc(dev, rtsx_ids[i].desc);
3583  			return (BUS_PROBE_DEFAULT);
3584  		}
3585  	}
3586  	return (ENXIO);
3587  }
3588  
3589  /*
3590   * Attach function is only called if the probe is successful.
3591   */
3592  static int
3593  rtsx_attach(device_t dev)
3594  {
3595  	struct rtsx_softc 	*sc = device_get_softc(dev);
3596  	uint16_t 		vendor_id;
3597  	uint16_t 		device_id;
3598  	struct sysctl_ctx_list	*ctx;
3599  	struct sysctl_oid_list	*tree;
3600  	int			msi_count = 1;
3601  	uint32_t		sdio_cfg;
3602  	int			error;
3603  	char			*maker;
3604  	char			*family;
3605  	char			*product;
3606  	int			i;
3607  
3608  	vendor_id = pci_get_vendor(dev);
3609  	device_id = pci_get_device(dev);
3610  	if (bootverbose)
3611  		device_printf(dev, "Attach - Vendor ID: 0x%x - Device ID: 0x%x\n",
3612  			      vendor_id, device_id);
3613  
3614  	sc->rtsx_dev = dev;
3615  	sc->rtsx_device_id = device_id;
3616  	sc->rtsx_req = NULL;
3617  	sc->rtsx_timeout_cmd = 1;
3618  	sc->rtsx_timeout_io = 10;
3619  	sc->rtsx_read_only = 0;
3620  	sc->rtsx_inversion = 0;
3621  	sc->rtsx_force_timing = 0;
3622  	sc->rtsx_debug_mask = 0;
3623  	sc->rtsx_read_count = 0;
3624  	sc->rtsx_write_count = 0;
3625  
3626  	maker = kern_getenv("smbios.system.maker");
3627  	family = kern_getenv("smbios.system.family");
3628  	product = kern_getenv("smbios.system.product");
3629  	for (i = 0; rtsx_inversion_models[i].maker != NULL; i++) {
3630  		if (strcmp(rtsx_inversion_models[i].maker, maker) == 0 &&
3631  		    strcmp(rtsx_inversion_models[i].family, family) == 0 &&
3632  		    strcmp(rtsx_inversion_models[i].product, product) == 0) {
3633  			device_printf(dev, "Inversion activated for %s/%s/%s, see BUG in rtsx(4)\n", maker, family, product);
3634  			device_printf(dev, "If a card is detected without an SD card present,"
3635  				      " add dev.rtsx.0.inversion=0 in loader.conf(5)\n");
3636  			sc->rtsx_inversion = 1;
3637  			break;
3638  		}
3639  	}
3640  
3641  	RTSX_LOCK_INIT(sc);
3642  
3643  	ctx = device_get_sysctl_ctx(dev);
3644  	tree = SYSCTL_CHILDREN(device_get_sysctl_tree(dev));
3645  	SYSCTL_ADD_INT(ctx, tree, OID_AUTO, "timeout_io", CTLFLAG_RW,
3646  		       &sc->rtsx_timeout_io, 0, "Request timeout for I/O commands in seconds");
3647  	SYSCTL_ADD_INT(ctx, tree, OID_AUTO, "timeout_cmd", CTLFLAG_RW,
3648  		       &sc->rtsx_timeout_cmd, 0, "Request timeout for setup commands in seconds");
3649  	SYSCTL_ADD_U8(ctx, tree, OID_AUTO, "read_only", CTLFLAG_RD,
3650  		      &sc->rtsx_read_only, 0, "Card is write protected");
3651  	SYSCTL_ADD_U8(ctx, tree, OID_AUTO, "inversion", CTLFLAG_RWTUN,
3652  		      &sc->rtsx_inversion, 0, "Inversion of card detection and read only status");
3653  	SYSCTL_ADD_U8(ctx, tree, OID_AUTO, "force_timing", CTLFLAG_RW,
3654  		      &sc->rtsx_force_timing, 0, "Force bus_timing_uhs_sdr50");
3655  	SYSCTL_ADD_U8(ctx, tree, OID_AUTO, "debug_mask", CTLFLAG_RWTUN,
3656  		      &sc->rtsx_debug_mask, 0, "debugging mask, see rtsx(4)");
3657  	SYSCTL_ADD_U64(ctx, tree, OID_AUTO, "read_count", CTLFLAG_RD | CTLFLAG_STATS,
3658  		       &sc->rtsx_read_count, 0, "Count of read operations");
3659  	SYSCTL_ADD_U64(ctx, tree, OID_AUTO, "write_count", CTLFLAG_RD | CTLFLAG_STATS,
3660  		       &sc->rtsx_write_count, 0, "Count of write operations");
3661  
3662  	if (bootverbose || sc->rtsx_debug_mask & RTSX_DEBUG_BASIC)
3663  		device_printf(dev, "We are running with inversion: %d\n", sc->rtsx_inversion);
3664  
3665  	/* Allocate IRQ. */
3666  	sc->rtsx_irq_res_id = 0;
3667  	if (pci_alloc_msi(dev, &msi_count) == 0)
3668  		sc->rtsx_irq_res_id = 1;
3669  	sc->rtsx_irq_res = bus_alloc_resource_any(dev, SYS_RES_IRQ, &sc->rtsx_irq_res_id,
3670  						  RF_ACTIVE | (sc->rtsx_irq_res_id != 0 ? 0 : RF_SHAREABLE));
3671  	if (sc->rtsx_irq_res == NULL) {
3672  		device_printf(dev, "Can't allocate IRQ resources for %d\n", sc->rtsx_irq_res_id);
3673  		pci_release_msi(dev);
3674  		return (ENXIO);
3675  	}
3676  
3677  	callout_init_mtx(&sc->rtsx_timeout_callout, &sc->rtsx_mtx, 0);
3678  
3679  	/* Allocate memory resource. */
3680  	if (sc->rtsx_device_id == RTSX_RTS525A)
3681  		sc->rtsx_mem_res_id = PCIR_BAR(1);
3682  	else
3683  		sc->rtsx_mem_res_id = PCIR_BAR(0);
3684  	sc->rtsx_mem_res = bus_alloc_resource_any(dev, SYS_RES_MEMORY, &sc->rtsx_mem_res_id, RF_ACTIVE);
3685  	if (sc->rtsx_mem_res == NULL) {
3686  		device_printf(dev, "Can't allocate memory resource for %d\n", sc->rtsx_mem_res_id);
3687  		goto destroy_rtsx_irq_res;
3688  	}
3689  
3690  	if (bootverbose)
3691  		device_printf(dev, "rtsx_irq_res_id: %d, rtsx_mem_res_id: %d\n",
3692  			      sc->rtsx_irq_res_id, sc->rtsx_mem_res_id);
3693  
3694  	sc->rtsx_mem_btag = rman_get_bustag(sc->rtsx_mem_res);
3695  	sc->rtsx_mem_bhandle = rman_get_bushandle(sc->rtsx_mem_res);
3696  
3697  	TIMEOUT_TASK_INIT(taskqueue_bus, &sc->rtsx_card_insert_task, 0,
3698  			  rtsx_card_task, sc);
3699  	TASK_INIT(&sc->rtsx_card_remove_task, 0, rtsx_card_task, sc);
3700  
3701  	/* Allocate two DMA buffers: a command buffer and a data buffer. */
3702  	error = rtsx_dma_alloc(sc);
3703  	if (error)
3704  		goto destroy_rtsx_irq_res;
3705  
3706  	/* Activate the interrupt. */
3707  	error = bus_setup_intr(dev, sc->rtsx_irq_res, INTR_TYPE_MISC | INTR_MPSAFE,
3708  			       NULL, rtsx_intr, sc, &sc->rtsx_irq_cookie);
3709  	if (error) {
3710  		device_printf(dev, "Can't set up irq [0x%x]!\n", error);
3711  		goto destroy_rtsx_mem_res;
3712  	}
3713  	pci_enable_busmaster(dev);
3714  
3715  	if (rtsx_read_cfg(sc, 0, RTSX_SDIOCFG_REG, &sdio_cfg) == 0) {
3716  		if ((sdio_cfg & RTSX_SDIOCFG_SDIO_ONLY) ||
3717  		    (sdio_cfg & RTSX_SDIOCFG_HAVE_SDIO))
3718  			sc->rtsx_flags |= RTSX_F_SDIO_SUPPORT;
3719  	}
3720  
3721  #ifdef MMCCAM
3722  	sc->rtsx_ccb = NULL;
3723  	sc->rtsx_cam_status = 0;
3724  
3725  	SYSCTL_ADD_U8(ctx, tree, OID_AUTO, "cam_status", CTLFLAG_RD,
3726  		      &sc->rtsx_cam_status, 0, "driver cam card present");
3727  
3728  	if (mmc_cam_sim_alloc(dev, "rtsx_mmc", &sc->rtsx_mmc_sim) != 0) {
3729  		device_printf(dev, "Can't allocate CAM SIM\n");
3730  		goto destroy_rtsx_irq;
3731  	}
3732  #endif /* MMCCAM */
3733  
3734  	/* Initialize device. */
3735  	error = rtsx_init(sc);
3736  	if (error) {
3737  		device_printf(dev, "Error %d during rtsx_init()\n", error);
3738  		goto destroy_rtsx_irq;
3739  	}
3740  
3741  	/*
3742  	 * Schedule a card detection as we won't get an interrupt
3743  	 * if the card is inserted when we attach. We wait a quarter
3744  	 * of a second to allow for a "spontaneous" interrupt which may
3745  	 * change the card presence state. This delay avoid a panic
3746  	 * on some configuration (e.g. Lenovo T540p).
3747  	 */
3748  	DELAY(250000);
3749  	if (rtsx_is_card_present(sc))
3750  		device_printf(sc->rtsx_dev, "A card is detected\n");
3751  	else
3752  		device_printf(sc->rtsx_dev, "No card is detected\n");
3753  	rtsx_card_task(sc, 0);
3754  
3755  	if (bootverbose)
3756  		device_printf(dev, "Device attached\n");
3757  
3758  	return (0);
3759  
3760   destroy_rtsx_irq:
3761  	bus_teardown_intr(dev, sc->rtsx_irq_res, sc->rtsx_irq_cookie);
3762   destroy_rtsx_mem_res:
3763  	bus_release_resource(dev, SYS_RES_MEMORY, sc->rtsx_mem_res_id,
3764  			     sc->rtsx_mem_res);
3765  	rtsx_dma_free(sc);
3766   destroy_rtsx_irq_res:
3767  	callout_drain(&sc->rtsx_timeout_callout);
3768  	bus_release_resource(dev, SYS_RES_IRQ, sc->rtsx_irq_res_id,
3769  			     sc->rtsx_irq_res);
3770  	pci_release_msi(dev);
3771  	RTSX_LOCK_DESTROY(sc);
3772  
3773  	return (ENXIO);
3774  }
3775  
3776  static int
3777  rtsx_detach(device_t dev)
3778  {
3779  	struct rtsx_softc *sc = device_get_softc(dev);
3780  	int	error;
3781  
3782  	if (bootverbose)
3783  		device_printf(dev, "Detach - Vendor ID: 0x%x - Device ID: 0x%x\n",
3784  			      pci_get_vendor(dev), sc->rtsx_device_id);
3785  
3786  	/* Disable interrupts. */
3787  	sc->rtsx_intr_enabled = 0;
3788  	WRITE4(sc, RTSX_BIER, sc->rtsx_intr_enabled);
3789  
3790  	/* Stop device. */
3791  	error = bus_generic_detach(sc->rtsx_dev);
3792  	if (error)
3793  		return (error);
3794  	sc->rtsx_mmc_dev = NULL;
3795  
3796  	taskqueue_drain_timeout(taskqueue_bus, &sc->rtsx_card_insert_task);
3797  	taskqueue_drain(taskqueue_bus, &sc->rtsx_card_remove_task);
3798  
3799  	/* Teardown the state in our softc created in our attach routine. */
3800  	rtsx_dma_free(sc);
3801  	if (sc->rtsx_mem_res != NULL)
3802  		bus_release_resource(dev, SYS_RES_MEMORY, sc->rtsx_mem_res_id,
3803  				     sc->rtsx_mem_res);
3804  	if (sc->rtsx_irq_cookie != NULL)
3805  		bus_teardown_intr(dev, sc->rtsx_irq_res, sc->rtsx_irq_cookie);
3806  	if (sc->rtsx_irq_res != NULL) {
3807  		callout_drain(&sc->rtsx_timeout_callout);
3808  		bus_release_resource(dev, SYS_RES_IRQ, sc->rtsx_irq_res_id,
3809  				     sc->rtsx_irq_res);
3810  		pci_release_msi(dev);
3811  	}
3812  	RTSX_LOCK_DESTROY(sc);
3813  #ifdef MMCCAM
3814  	mmc_cam_sim_free(&sc->rtsx_mmc_sim);
3815  #endif /* MMCCAM */
3816  
3817  	return (0);
3818  }
3819  
3820  static int
3821  rtsx_shutdown(device_t dev)
3822  {
3823  	if (bootverbose)
3824  		device_printf(dev, "Shutdown\n");
3825  
3826  	return (0);
3827  }
3828  
3829  /*
3830   * Device suspend routine.
3831   */
3832  static int
3833  rtsx_suspend(device_t dev)
3834  {
3835  	struct rtsx_softc *sc = device_get_softc(dev);
3836  
3837  	device_printf(dev, "Suspend\n");
3838  
3839  #ifdef MMCCAM
3840  	if (sc->rtsx_ccb != NULL) {
3841  		device_printf(dev, "Request in progress: CMD%u, rtsr_intr_status: 0x%08x\n",
3842  			      sc->rtsx_ccb->mmcio.cmd.opcode, sc->rtsx_intr_status);
3843  	}
3844  #else  /* !MMCCAM */
3845  	if (sc->rtsx_req != NULL) {
3846  		device_printf(dev, "Request in progress: CMD%u, rtsr_intr_status: 0x%08x\n",
3847  			      sc->rtsx_req->cmd->opcode, sc->rtsx_intr_status);
3848  	}
3849  #endif /* MMCCAM */
3850  
3851  	bus_generic_suspend(dev);
3852  
3853  	return (0);
3854  }
3855  
3856  /*
3857   * Device resume routine.
3858   */
3859  static int
3860  rtsx_resume(device_t dev)
3861  {
3862  	device_printf(dev, "Resume\n");
3863  
3864  	rtsx_init(device_get_softc(dev));
3865  
3866  	bus_generic_resume(dev);
3867  
3868  	return (0);
3869  }
3870  
3871  static device_method_t rtsx_methods[] = {
3872  	/* Device interface */
3873  	DEVMETHOD(device_probe,		rtsx_probe),
3874  	DEVMETHOD(device_attach,	rtsx_attach),
3875  	DEVMETHOD(device_detach,	rtsx_detach),
3876  	DEVMETHOD(device_shutdown,	rtsx_shutdown),
3877  	DEVMETHOD(device_suspend,	rtsx_suspend),
3878  	DEVMETHOD(device_resume,	rtsx_resume),
3879  
3880  	/* Bus interface */
3881  	DEVMETHOD(bus_read_ivar,	rtsx_read_ivar),
3882  	DEVMETHOD(bus_write_ivar,	rtsx_write_ivar),
3883  
3884  #ifndef MMCCAM
3885  	/* MMC bridge interface */
3886  	DEVMETHOD(mmcbr_update_ios,	rtsx_mmcbr_update_ios),
3887  	DEVMETHOD(mmcbr_switch_vccq,	rtsx_mmcbr_switch_vccq),
3888  	DEVMETHOD(mmcbr_tune,		rtsx_mmcbr_tune),
3889  	DEVMETHOD(mmcbr_retune,		rtsx_mmcbr_retune),
3890  	DEVMETHOD(mmcbr_request,	rtsx_mmcbr_request),
3891  	DEVMETHOD(mmcbr_get_ro,		rtsx_mmcbr_get_ro),
3892  	DEVMETHOD(mmcbr_acquire_host,	rtsx_mmcbr_acquire_host),
3893  	DEVMETHOD(mmcbr_release_host,	rtsx_mmcbr_release_host),
3894  #endif /* !MMCCAM */
3895  
3896  #ifdef MMCCAM
3897  	/* MMCCAM interface */
3898  	DEVMETHOD(mmc_sim_get_tran_settings,	rtsx_get_tran_settings),
3899  	DEVMETHOD(mmc_sim_set_tran_settings,	rtsx_set_tran_settings),
3900  	DEVMETHOD(mmc_sim_cam_request,		rtsx_cam_request),
3901  #endif /* MMCCAM */
3902  
3903  	DEVMETHOD_END
3904  };
3905  
3906  DEFINE_CLASS_0(rtsx, rtsx_driver, rtsx_methods, sizeof(struct rtsx_softc));
3907  DRIVER_MODULE(rtsx, pci, rtsx_driver, NULL, NULL);
3908  
3909  /* For Plug and Play */
3910  MODULE_PNP_INFO("U16:device;D:#;T:vendor=0x10ec", pci, rtsx,
3911  		rtsx_ids, nitems(rtsx_ids));
3912  
3913  #ifndef MMCCAM
3914  MMC_DECLARE_BRIDGE(rtsx);
3915  #endif /* !MMCCAM */
3916