|
@@ -25,6 +25,7 @@
|
|
#include "hw/block/flash.h"
|
|
#include "hw/block/flash.h"
|
|
#include "qemu/error-report.h"
|
|
#include "qemu/error-report.h"
|
|
#include "hw/char/pl011.h"
|
|
#include "hw/char/pl011.h"
|
|
|
|
+#include "hw/sd/sd.h"
|
|
|
|
|
|
#define VERSATILE_FLASH_ADDR 0x34000000
|
|
#define VERSATILE_FLASH_ADDR 0x34000000
|
|
#define VERSATILE_FLASH_SIZE (64 * 1024 * 1024)
|
|
#define VERSATILE_FLASH_SIZE (64 * 1024 * 1024)
|
|
@@ -309,8 +310,29 @@ static void versatile_init(MachineState *machine, int board_id)
|
|
/* Wire up the mux control signals from the SYS_CLCD register */
|
|
/* Wire up the mux control signals from the SYS_CLCD register */
|
|
qdev_connect_gpio_out(sysctl, 0, qdev_get_gpio_in(dev, 0));
|
|
qdev_connect_gpio_out(sysctl, 0, qdev_get_gpio_in(dev, 0));
|
|
|
|
|
|
- sysbus_create_varargs("pl181", 0x10005000, sic[22], sic[1], NULL);
|
|
|
|
- sysbus_create_varargs("pl181", 0x1000b000, sic[23], sic[2], NULL);
|
|
|
|
|
|
+ dev = sysbus_create_varargs("pl181", 0x10005000, sic[22], sic[1], NULL);
|
|
|
|
+ dinfo = drive_get_next(IF_SD);
|
|
|
|
+ if (dinfo) {
|
|
|
|
+ DeviceState *card;
|
|
|
|
+
|
|
|
|
+ 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(dev, "sd-bus"),
|
|
|
|
+ &error_fatal);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ dev = sysbus_create_varargs("pl181", 0x1000b000, sic[23], sic[2], NULL);
|
|
|
|
+ dinfo = drive_get_next(IF_SD);
|
|
|
|
+ if (dinfo) {
|
|
|
|
+ DeviceState *card;
|
|
|
|
+
|
|
|
|
+ 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(dev, "sd-bus"),
|
|
|
|
+ &error_fatal);
|
|
|
|
+ }
|
|
|
|
|
|
/* Add PL031 Real Time Clock. */
|
|
/* Add PL031 Real Time Clock. */
|
|
sysbus_create_simple("pl031", 0x101e8000, pic[10]);
|
|
sysbus_create_simple("pl031", 0x101e8000, pic[10]);
|