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