mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-07-27 04:13:53 -06:00
hw/sd/omap_mmc: Convert to SDBus API
Convert the OMAP MMC controller to the new SDBus API: * the controller creates an SDBus bus * instead of sd_foo functions on the SDState object, call sdbus_foo functions on the SDBus * the board code creates a proper TYPE_SD_CARD object and attaches it to the controller's SDBus, instead of the controller creating a card directly via sd_init() that never gets attached to any bus * because the SD card object is on a bus, it gets reset automatically by the "traverse the qbus tree resetting things" code, and we don't need to manually reset the card from the controller reset function Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org> Message-ID: <20250128104519.3981448-5-peter.maydell@linaro.org> [PMD: Include "hw/sd/sd.h" instead of "hw/sd/sdcard_legacy.h", create bus in omap_mmc_initfn() instead of omap_mmc_realize()] Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org>
This commit is contained in:
parent
68b4885764
commit
0c90811231
3 changed files with 19 additions and 23 deletions
|
@ -29,6 +29,7 @@
|
|||
#include "hw/qdev-properties.h"
|
||||
#include "hw/arm/boot.h"
|
||||
#include "hw/arm/omap.h"
|
||||
#include "hw/sd/sd.h"
|
||||
#include "system/blockdev.h"
|
||||
#include "system/system.h"
|
||||
#include "hw/arm/soc_dma.h"
|
||||
|
@ -3981,11 +3982,18 @@ struct omap_mpu_state_s *omap310_mpu_init(MemoryRegion *dram,
|
|||
warn_report("missing SecureDigital device");
|
||||
}
|
||||
s->mmc = omap_mmc_init(0xfffb7800, system_memory,
|
||||
dinfo ? blk_by_legacy_dinfo(dinfo) : NULL,
|
||||
qdev_get_gpio_in(s->ih[1], OMAP_INT_OQN),
|
||||
&s->drq[OMAP_DMA_MMC_TX],
|
||||
omap_findclk(s, "mmc_ck"));
|
||||
|
||||
if (dinfo) {
|
||||
DeviceState *card = qdev_new(TYPE_SD_CARD);
|
||||
qdev_prop_set_drive_err(card, "drive", blk_by_legacy_dinfo(dinfo),
|
||||
&error_fatal);
|
||||
qdev_realize_and_unref(card, qdev_get_child_bus(s->mmc, "sd-bus"),
|
||||
&error_fatal);
|
||||
}
|
||||
|
||||
s->mpuio = omap_mpuio_init(system_memory, 0xfffb5000,
|
||||
qdev_get_gpio_in(s->ih[1], OMAP_INT_KEYBOARD),
|
||||
qdev_get_gpio_in(s->ih[1], OMAP_INT_MPUIO),
|
||||
|
|
|
@ -25,18 +25,19 @@
|
|||
#include "hw/irq.h"
|
||||
#include "hw/sysbus.h"
|
||||
#include "hw/arm/omap.h"
|
||||
#include "hw/sd/sdcard_legacy.h"
|
||||
#include "hw/sd/sd.h"
|
||||
|
||||
typedef struct OMAPMMCState {
|
||||
SysBusDevice parent_obj;
|
||||
|
||||
SDBus sdbus;
|
||||
|
||||
qemu_irq irq;
|
||||
qemu_irq dma_tx_gpio;
|
||||
qemu_irq dma_rx_gpio;
|
||||
qemu_irq coverswitch;
|
||||
MemoryRegion iomem;
|
||||
omap_clk clk;
|
||||
SDState *card;
|
||||
uint16_t last_cmd;
|
||||
uint16_t sdio;
|
||||
uint16_t rsp[8];
|
||||
|
@ -158,7 +159,7 @@ static void omap_mmc_command(OMAPMMCState *host, int cmd, int dir,
|
|||
request.arg = host->arg;
|
||||
request.crc = 0; /* FIXME */
|
||||
|
||||
rsplen = sd_do_command(host->card, &request, response);
|
||||
rsplen = sdbus_do_command(&host->sdbus, &request, response);
|
||||
|
||||
/* TODO: validate CRCs */
|
||||
switch (resptype) {
|
||||
|
@ -247,10 +248,10 @@ static void omap_mmc_transfer(OMAPMMCState *host)
|
|||
if (host->fifo_len > host->af_level)
|
||||
break;
|
||||
|
||||
value = sd_read_byte(host->card);
|
||||
value = sdbus_read_byte(&host->sdbus);
|
||||
host->fifo[(host->fifo_start + host->fifo_len) & 31] = value;
|
||||
if (-- host->blen_counter) {
|
||||
value = sd_read_byte(host->card);
|
||||
value = sdbus_read_byte(&host->sdbus);
|
||||
host->fifo[(host->fifo_start + host->fifo_len) & 31] |=
|
||||
value << 8;
|
||||
host->blen_counter --;
|
||||
|
@ -262,10 +263,10 @@ static void omap_mmc_transfer(OMAPMMCState *host)
|
|||
break;
|
||||
|
||||
value = host->fifo[host->fifo_start] & 0xff;
|
||||
sd_write_byte(host->card, value);
|
||||
sdbus_write_byte(&host->sdbus, value);
|
||||
if (-- host->blen_counter) {
|
||||
value = host->fifo[host->fifo_start] >> 8;
|
||||
sd_write_byte(host->card, value);
|
||||
sdbus_write_byte(&host->sdbus, value);
|
||||
host->blen_counter --;
|
||||
}
|
||||
|
||||
|
@ -328,14 +329,6 @@ static void omap_mmc_reset(OMAPMMCState *host)
|
|||
host->clkdiv = 0;
|
||||
|
||||
omap_mmc_pseudo_reset(host);
|
||||
|
||||
/* Since we're still using the legacy SD API the card is not plugged
|
||||
* into any bus, and we must reset it manually. When omap_mmc is
|
||||
* QOMified this must move into the QOM reset function.
|
||||
*/
|
||||
if (host->card) {
|
||||
device_cold_reset(DEVICE(host->card));
|
||||
}
|
||||
}
|
||||
|
||||
static uint64_t omap_mmc_read(void *opaque, hwaddr offset, unsigned size)
|
||||
|
@ -592,7 +585,6 @@ static const MemoryRegionOps omap_mmc_ops = {
|
|||
|
||||
DeviceState *omap_mmc_init(hwaddr base,
|
||||
MemoryRegion *sysmem,
|
||||
BlockBackend *blk,
|
||||
qemu_irq irq, qemu_irq dma[], omap_clk clk)
|
||||
{
|
||||
DeviceState *dev;
|
||||
|
@ -610,11 +602,6 @@ DeviceState *omap_mmc_init(hwaddr base,
|
|||
qdev_connect_gpio_out_named(dev, "dma-rx", 0, dma[1]);
|
||||
sysbus_connect_irq(SYS_BUS_DEVICE(dev), 0, irq);
|
||||
|
||||
/* Instantiate the storage */
|
||||
s->card = sd_init(blk, false);
|
||||
if (s->card == NULL) {
|
||||
exit(1);
|
||||
}
|
||||
return dev;
|
||||
}
|
||||
|
||||
|
@ -639,6 +626,8 @@ static void omap_mmc_initfn(Object *obj)
|
|||
sysbus_init_irq(SYS_BUS_DEVICE(obj), &s->irq);
|
||||
qdev_init_gpio_out_named(DEVICE(obj), &s->dma_tx_gpio, "dma-tx", 1);
|
||||
qdev_init_gpio_out_named(DEVICE(obj), &s->dma_rx_gpio, "dma-rx", 1);
|
||||
|
||||
qbus_init(&s->sdbus, sizeof(s->sdbus), TYPE_SD_BUS, DEVICE(obj), "sd-bus");
|
||||
}
|
||||
|
||||
static void omap_mmc_class_init(ObjectClass *oc, void *data)
|
||||
|
|
|
@ -534,7 +534,6 @@ OBJECT_DECLARE_SIMPLE_TYPE(OMAPMMCState, OMAP_MMC)
|
|||
|
||||
DeviceState *omap_mmc_init(hwaddr base,
|
||||
MemoryRegion *sysmem,
|
||||
BlockBackend *blk,
|
||||
qemu_irq irq, qemu_irq dma[], omap_clk clk);
|
||||
|
||||
/* omap_i2c.c */
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue