Lines Matching refs:card

20 int sdmmc_read_status(struct sd_card *card)  in sdmmc_read_status()  argument
27 if (!card->host_props.is_spi) { in sdmmc_read_status()
28 cmd.arg = (card->relative_addr << 16U); in sdmmc_read_status()
34 ret = sdhc_request(card->sdhc, &cmd, NULL); in sdmmc_read_status()
38 if (card->host_props.is_spi) { in sdmmc_read_status()
65 int sdmmc_wait_ready(struct sd_card *card) in sdmmc_wait_ready() argument
70 if (!sdhc_card_busy(card->sdhc)) { in sdmmc_wait_ready()
72 ret = sd_retry(sdmmc_read_status, card, CONFIG_SD_RETRY_COUNT); in sdmmc_wait_ready()
205 static int sdmmc_spi_read_cxd(struct sd_card *card, uint32_t opcode, uint32_t *cxd) in sdmmc_spi_read_cxd() argument
211 uint32_t *cxd_be = (uint32_t *)card->card_buffer; in sdmmc_spi_read_cxd()
226 ret = sdhc_request(card->sdhc, &cmd, &data); in sdmmc_spi_read_cxd()
238 static int sdmmc_read_cxd(struct sd_card *card, uint32_t opcode, uint32_t rca, uint32_t *cxd) in sdmmc_read_cxd() argument
249 ret = sdhc_request(card->sdhc, &cmd, NULL); in sdmmc_read_cxd()
260 int sdmmc_read_csd(struct sd_card *card) in sdmmc_read_csd() argument
267 if (card->host_props.is_spi && IS_ENABLED(CONFIG_SDHC_SUPPORTS_SPI_MODE)) { in sdmmc_read_csd()
268 ret = sdmmc_spi_read_cxd(card, SD_SEND_CSD, csd); in sdmmc_read_csd()
270 ret = sdmmc_read_cxd(card, SD_SEND_CSD, card->relative_addr, csd); in sdmmc_read_csd()
278 sdmmc_decode_csd(&card_csd, csd, &card->block_count, &card->block_size); in sdmmc_read_csd()
279 LOG_DBG("Card block count %d, block size %d", card->block_count, card->block_size); in sdmmc_read_csd()
284 int card_read_cid(struct sd_card *card) in card_read_cid() argument
293 if (card->host_props.is_spi && IS_ENABLED(CONFIG_SDHC_SUPPORTS_SPI_MODE)) { in card_read_cid()
294 ret = sdmmc_spi_read_cxd(card, SD_SEND_CID, cid); in card_read_cid()
296 ret = sdmmc_read_cxd(card, SD_ALL_SEND_CID, 0, cid); in card_read_cid()
306 if (card->type == CARD_MMC) { in card_read_cid()
325 int sdmmc_switch_voltage(struct sd_card *card) in sdmmc_switch_voltage() argument
331 if (!(card->flags & SD_1800MV_FLAG)) { in sdmmc_switch_voltage()
342 ret = sdhc_request(card->sdhc, &cmd, NULL); in sdmmc_switch_voltage()
358 if (!(sdhc_card_busy(card->sdhc))) { in sdmmc_switch_voltage()
361 if (!sdhc_card_busy(card->sdhc)) { in sdmmc_switch_voltage()
371 sd_clock = card->bus_io.clock; in sdmmc_switch_voltage()
372 card->bus_io.clock = 0; in sdmmc_switch_voltage()
373 ret = sdhc_set_io(card->sdhc, &card->bus_io); in sdmmc_switch_voltage()
379 card->bus_io.signal_voltage = SD_VOL_1_8_V; in sdmmc_switch_voltage()
380 ret = sdhc_set_io(card->sdhc, &card->bus_io); in sdmmc_switch_voltage()
387 card->bus_io.clock = sd_clock; in sdmmc_switch_voltage()
388 ret = sdhc_set_io(card->sdhc, &card->bus_io); in sdmmc_switch_voltage()
398 if (sdhc_card_busy(card->sdhc)) { in sdmmc_switch_voltage()
402 card->card_voltage = SD_VOL_1_8_V; in sdmmc_switch_voltage()
411 int sdmmc_request_rca(struct sd_card *card) in sdmmc_request_rca() argument
423 ret = sdhc_request(card->sdhc, &cmd, NULL); in sdmmc_request_rca()
429 card->relative_addr = ((cmd.response[0U] & 0xFFFF0000) >> 16U); in sdmmc_request_rca()
430 } while (card->relative_addr == 0U); in sdmmc_request_rca()
431 LOG_DBG("Card relative addr: %d", card->relative_addr); in sdmmc_request_rca()
438 int sdmmc_select_card(struct sd_card *card) in sdmmc_select_card() argument
444 cmd.arg = ((card->relative_addr) << 16U); in sdmmc_select_card()
449 ret = sdhc_request(card->sdhc, &cmd, NULL); in sdmmc_select_card()
463 int card_app_command(struct sd_card *card, int relative_card_address) in card_app_command() argument
473 ret = sdhc_request(card->sdhc, &cmd, NULL); in card_app_command()
484 if ((!card->host_props.is_spi) && !(cmd.response[0U] & SD_R1_APP_CMD)) { in card_app_command()
491 static int card_read(struct sd_card *card, uint8_t *rbuf, uint32_t start_block, uint32_t num_blocks) in card_read() argument
510 if (!(card->flags & SD_HIGH_CAPACITY_FLAG)) { in card_read()
512 cmd.arg = start_block * card->block_size; in card_read()
521 data.block_size = card->block_size; in card_read()
528 ret = sdhc_request(card->sdhc, &cmd, &data); in card_read()
535 ret = sdmmc_wait_ready(card); in card_read()
544 int card_read_blocks(struct sd_card *card, uint8_t *rbuf, uint32_t start_block, uint32_t num_blocks) in card_read_blocks() argument
551 if ((start_block + num_blocks) > card->block_count) { in card_read_blocks()
554 if (card->type == CARD_SDIO) { in card_read_blocks()
558 ret = k_mutex_lock(&card->lock, K_MSEC(CONFIG_SD_DATA_TIMEOUT)); in card_read_blocks()
572 if (sizeof(card->card_buffer) < card->block_size) { in card_read_blocks()
575 k_mutex_unlock(&card->lock); in card_read_blocks()
578 rlen = sizeof(card->card_buffer) / card->block_size; in card_read_blocks()
583 ret = card_read(card, card->card_buffer, sector + start_block, rlen); in card_read_blocks()
586 k_mutex_unlock(&card->lock); in card_read_blocks()
590 memcpy(buf_offset, card->card_buffer, rlen * card->block_size); in card_read_blocks()
593 buf_offset += rlen * card->block_size; in card_read_blocks()
597 ret = card_read(card, rbuf, start_block, num_blocks); in card_read_blocks()
600 k_mutex_unlock(&card->lock); in card_read_blocks()
604 k_mutex_unlock(&card->lock); in card_read_blocks()
612 static int card_query_written(struct sd_card *card, uint32_t *num_written) in card_query_written() argument
617 uint32_t *blocks = (uint32_t *)card->card_buffer; in card_query_written()
619 ret = card_app_command(card, card->relative_addr); in card_query_written()
637 ret = sdhc_request(card->sdhc, &cmd, &data); in card_query_written()
653 static int card_write(struct sd_card *card, const uint8_t *wbuf, uint32_t start_block, in card_write() argument
666 if (!(card->flags & SD_HIGH_CAPACITY_FLAG)) { in card_write()
668 cmd.arg = start_block * card->block_size; in card_write()
677 data.block_size = card->block_size; in card_write()
684 ret = sdhc_request(card->sdhc, &cmd, &data); in card_write()
687 ret = sdmmc_wait_ready(card); in card_write()
692 ret = card_query_written(card, &blocks); in card_write()
700 ret = sdmmc_wait_ready(card); in card_write()
709 int card_write_blocks(struct sd_card *card, const uint8_t *wbuf, uint32_t start_block, in card_write_blocks() argument
717 if ((start_block + num_blocks) > card->block_count) { in card_write_blocks()
720 if (card->type == CARD_SDIO) { in card_write_blocks()
724 ret = k_mutex_lock(&card->lock, K_MSEC(CONFIG_SD_DATA_TIMEOUT)); in card_write_blocks()
737 if (sizeof(card->card_buffer) < card->block_size) { in card_write_blocks()
740 k_mutex_unlock(&card->lock); in card_write_blocks()
743 wlen = sizeof(card->card_buffer) / card->block_size; in card_write_blocks()
748 memcpy(card->card_buffer, buf_offset, wlen * card->block_size); in card_write_blocks()
750 ret = card_write(card, card->card_buffer, sector + start_block, wlen); in card_write_blocks()
753 k_mutex_unlock(&card->lock); in card_write_blocks()
758 buf_offset += wlen * card->block_size; in card_write_blocks()
762 ret = card_write(card, wbuf, start_block, num_blocks); in card_write_blocks()
765 k_mutex_unlock(&card->lock); in card_write_blocks()
769 k_mutex_unlock(&card->lock); in card_write_blocks()
774 int card_ioctl(struct sd_card *card, uint8_t cmd, void *buf) in card_ioctl() argument
778 ret = k_mutex_lock(&card->lock, K_MSEC(CONFIG_SD_DATA_TIMEOUT)); in card_ioctl()
785 (*(uint32_t *)buf) = card->block_count; in card_ioctl()
789 (*(uint32_t *)buf) = card->block_size; in card_ioctl()
796 ret = sdmmc_wait_ready(card); in card_ioctl()
800 ret = sdmmc_wait_ready(card); in card_ioctl()
805 card->bus_io.power_mode = SDHC_POWER_OFF; in card_ioctl()
806 ret = sdhc_set_io(card->sdhc, &card->bus_io); in card_ioctl()
811 k_mutex_unlock(&card->lock); in card_ioctl()