/* * MMC Host Controller Commands * * Copyright (c) 2021 Google LLC * * This program is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License as published by the * Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, but WITHOUT * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License * for more details. */ #include "../libqtest.h" /* more details at hw/sd/sdhci-internal.h */ #define SDHC_BLKSIZE 0x04 #define SDHC_BLKCNT 0x06 #define SDHC_ARGUMENT 0x08 #define SDHC_TRNMOD 0x0C #define SDHC_CMDREG 0x0E #define SDHC_BDATA 0x20 #define SDHC_PRNSTS 0x24 #define SDHC_BLKGAP 0x2A #define SDHC_CLKCON 0x2C #define SDHC_SWRST 0x2F #define SDHC_CAPAB 0x40 #define SDHC_MAXCURR 0x48 #define SDHC_HCVER 0xFE /* TRNSMOD Reg */ #define SDHC_TRNS_BLK_CNT_EN 0x0002 #define SDHC_TRNS_READ 0x0010 #define SDHC_TRNS_WRITE 0x0000 #define SDHC_TRNS_MULTI 0x0020 /* CMD Reg */ #define SDHC_CMD_DATA_PRESENT (1 << 5) #define SDHC_ALL_SEND_CID (2 << 8) #define SDHC_SEND_RELATIVE_ADDR (3 << 8) #define SDHC_SELECT_DESELECT_CARD (7 << 8) #define SDHC_SEND_CSD (9 << 8) #define SDHC_STOP_TRANSMISSION (12 << 8) #define SDHC_READ_MULTIPLE_BLOCK (18 << 8) #define SDHC_WRITE_MULTIPLE_BLOCK (25 << 8) #define SDHC_APP_CMD (55 << 8) /* SWRST Reg */ #define SDHC_RESET_ALL 0x01 /* CLKCTRL Reg */ #define SDHC_CLOCK_INT_EN 0x0001 #define SDHC_CLOCK_INT_STABLE 0x0002 #define SDHC_CLOCK_SDCLK_EN (1 << 2) /* Set registers needed to send commands to SD */ void sdhci_cmd_regs(QTestState *qts, uint64_t base_addr, uint16_t blksize, uint16_t blkcnt, uint32_t argument, uint16_t trnmod, uint16_t cmdreg); /* Read at most 1 block of SD using non-DMA */ ssize_t sdhci_read_cmd(QTestState *qts, uint64_t base_addr, char *msg, size_t count); /* Write at most 1 block of SD using non-DMA */ void sdhci_write_cmd(QTestState *qts, uint64_t base_addr, const char *msg, size_t count, size_t blksize);