diff options
author | Philippe Mathieu-Daudé <philmd@linaro.org> | 2024-06-14 15:49:10 +0200 |
---|---|---|
committer | Philippe Mathieu-Daudé <philmd@linaro.org> | 2024-07-05 23:54:58 +0200 |
commit | 5241b759bcf1e9952a5a5503bc802d76409b4ac6 (patch) | |
tree | 089ccb7405578ef3d4deae58cace52e3bd7a41c6 | |
parent | f18a78de24244986ab37c017f5a56a83d93ec779 (diff) | |
download | qemu-5241b759bcf1e9952a5a5503bc802d76409b4ac6.zip qemu-5241b759bcf1e9952a5a5503bc802d76409b4ac6.tar.gz qemu-5241b759bcf1e9952a5a5503bc802d76409b4ac6.tar.bz2 |
hw/sd/sdcard: Introduce set_csd/set_cid handlers
In preparation of introducing eMMC support which have
different CSD/CID structures, introduce a pair of handlers
in SDCardClass.
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-82-philmd@linaro.org>
-rw-r--r-- | hw/sd/sd.c | 7 | ||||
-rw-r--r-- | include/hw/sd/sd.h | 2 |
2 files changed, 7 insertions, 2 deletions
@@ -680,6 +680,7 @@ static inline uint64_t sd_addr_to_wpnum(uint64_t addr) static void sd_reset(DeviceState *dev) { SDState *sd = SD_CARD(dev); + SDCardClass *sc = SD_CARD_GET_CLASS(sd); uint64_t size; uint64_t sect; @@ -700,8 +701,8 @@ static void sd_reset(DeviceState *dev) sd->size = size; sd_set_ocr(sd); sd_set_scr(sd); - sd_set_cid(sd); - sd_set_csd(sd, size); + sc->set_cid(sd); + sc->set_csd(sd, size); sd_set_cardstatus(sd); sd_set_sdstatus(sd); @@ -2475,6 +2476,8 @@ static void sd_class_init(ObjectClass *klass, void *data) sc->enable = sd_enable; sc->get_inserted = sd_get_inserted; sc->get_readonly = sd_get_readonly; + sc->set_cid = sd_set_cid; + sc->set_csd = sd_set_csd; sc->proto = &sd_proto_sd; } diff --git a/include/hw/sd/sd.h b/include/hw/sd/sd.h index c1a35ab..0d6d9e4 100644 --- a/include/hw/sd/sd.h +++ b/include/hw/sd/sd.h @@ -127,6 +127,8 @@ struct SDCardClass { void (*enable)(SDState *sd, bool enable); bool (*get_inserted)(SDState *sd); bool (*get_readonly)(SDState *sd); + void (*set_cid)(SDState *sd); + void (*set_csd)(SDState *sd, uint64_t size); const struct SDProto *proto; }; |