aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPhilippe Mathieu-Daudé <philmd@linaro.org>2024-06-17 12:05:21 +0200
committerPhilippe Mathieu-Daudé <philmd@linaro.org>2024-07-05 23:54:54 +0200
commitf18a78de24244986ab37c017f5a56a83d93ec779 (patch)
tree3f86b51440991c86d1d95697b9cd52c92ad175e7
parent2a97045b483e1844dedb81aaf3f4e01d2c3249f5 (diff)
downloadqemu-f18a78de24244986ab37c017f5a56a83d93ec779.zip
qemu-f18a78de24244986ab37c017f5a56a83d93ec779.tar.gz
qemu-f18a78de24244986ab37c017f5a56a83d93ec779.tar.bz2
hw/sd/sdcard: Cover more SDCardStates
So far eMMC will only use sd_sleep_state, but all all states specified for completeness. Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org> Reviewed-by: Cédric Le Goater <clg@redhat.com> Tested-by: Andrew Jeffery <andrew@codeconstruct.com.au> Tested-by: Cédric Le Goater <clg@redhat.com> Message-Id: <20240628070216.92609-81-philmd@linaro.org>
-rw-r--r--hw/sd/sd.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/hw/sd/sd.c b/hw/sd/sd.c
index 9e6b9c9..ecb1b2f 100644
--- a/hw/sd/sd.c
+++ b/hw/sd/sd.c
@@ -76,7 +76,9 @@ enum SDCardModes {
};
enum SDCardStates {
+ sd_waitirq_state = -2, /* emmc */
sd_inactive_state = -1,
+
sd_idle_state = 0,
sd_ready_state = 1,
sd_identification_state = 2,
@@ -86,6 +88,9 @@ enum SDCardStates {
sd_receivingdata_state = 6,
sd_programming_state = 7,
sd_disconnect_state = 8,
+ sd_bus_test_state = 9, /* emmc */
+ sd_sleep_state = 10, /* emmc */
+ sd_io_state = 15 /* sd */
};
#define SDMMC_CMD_MAX 64
@@ -203,13 +208,19 @@ static const char *sd_state_name(enum SDCardStates state)
[sd_standby_state] = "standby",
[sd_transfer_state] = "transfer",
[sd_sendingdata_state] = "sendingdata",
+ [sd_bus_test_state] = "bus-test",
[sd_receivingdata_state] = "receivingdata",
[sd_programming_state] = "programming",
[sd_disconnect_state] = "disconnect",
+ [sd_sleep_state] = "sleep",
+ [sd_io_state] = "i/o"
};
if (state == sd_inactive_state) {
return "inactive";
}
+ if (state == sd_waitirq_state) {
+ return "wait-irq";
+ }
assert(state < ARRAY_SIZE(state_name));
return state_name[state];
}