147
147
} mv88w8618_rx_desc;
149
#define TYPE_MV88W8618_ETH "mv88w8618_eth"
150
#define MV88W8618_ETH(obj) \
151
OBJECT_CHECK(mv88w8618_eth_state, (obj), TYPE_MV88W8618_ETH)
149
153
typedef struct mv88w8618_eth_state {
155
SysBusDevice parent_obj;
151
158
MemoryRegion iomem;
382
389
.cleanup = eth_cleanup,
385
static int mv88w8618_eth_init(SysBusDevice *dev)
392
static int mv88w8618_eth_init(SysBusDevice *sbd)
387
mv88w8618_eth_state *s = FROM_SYSBUS(mv88w8618_eth_state, dev);
394
DeviceState *dev = DEVICE(sbd);
395
mv88w8618_eth_state *s = MV88W8618_ETH(dev);
389
sysbus_init_irq(dev, &s->irq);
397
sysbus_init_irq(sbd, &s->irq);
390
398
s->nic = qemu_new_nic(&net_mv88w8618_info, &s->conf,
391
object_get_typename(OBJECT(dev)), dev->qdev.id, s);
392
memory_region_init_io(&s->iomem, &mv88w8618_eth_ops, s, "mv88w8618-eth",
394
sysbus_init_mmio(dev, &s->iomem);
399
object_get_typename(OBJECT(dev)), dev->id, s);
400
memory_region_init_io(&s->iomem, OBJECT(s), &mv88w8618_eth_ops, s,
401
"mv88w8618-eth", MP_ETH_SIZE);
402
sysbus_init_mmio(sbd, &s->iomem);
431
439
static const TypeInfo mv88w8618_eth_info = {
432
.name = "mv88w8618_eth",
440
.name = TYPE_MV88W8618_ETH,
433
441
.parent = TYPE_SYS_BUS_DEVICE,
434
442
.instance_size = sizeof(mv88w8618_eth_state),
435
443
.class_init = mv88w8618_eth_class_init,
455
463
#define MP_LCD_TEXTCOLOR 0xe0e0ff /* RRGGBB */
465
#define TYPE_MUSICPAL_LCD "musicpal_lcd"
466
#define MUSICPAL_LCD(obj) \
467
OBJECT_CHECK(musicpal_lcd_state, (obj), TYPE_MUSICPAL_LCD)
457
469
typedef struct musicpal_lcd_state {
471
SysBusDevice parent_obj;
459
474
MemoryRegion iomem;
460
475
uint32_t brightness;
537
static void musicpal_lcd_gpio_brigthness_in(void *opaque, int irq, int level)
552
static void musicpal_lcd_gpio_brightness_in(void *opaque, int irq, int level)
539
554
musicpal_lcd_state *s = opaque;
540
555
s->brightness &= ~(1 << irq);
606
621
.gfx_update = lcd_refresh,
609
static int musicpal_lcd_init(SysBusDevice *dev)
624
static int musicpal_lcd_init(SysBusDevice *sbd)
611
musicpal_lcd_state *s = FROM_SYSBUS(musicpal_lcd_state, dev);
626
DeviceState *dev = DEVICE(sbd);
627
musicpal_lcd_state *s = MUSICPAL_LCD(dev);
613
629
s->brightness = 7;
615
memory_region_init_io(&s->iomem, &musicpal_lcd_ops, s,
631
memory_region_init_io(&s->iomem, OBJECT(s), &musicpal_lcd_ops, s,
616
632
"musicpal-lcd", MP_LCD_SIZE);
617
sysbus_init_mmio(dev, &s->iomem);
633
sysbus_init_mmio(sbd, &s->iomem);
619
s->con = graphic_console_init(DEVICE(dev), &musicpal_gfx_ops, s);
635
s->con = graphic_console_init(dev, &musicpal_gfx_ops, s);
620
636
qemu_console_resize(s->con, 128*3, 64*3);
622
qdev_init_gpio_in(&dev->qdev, musicpal_lcd_gpio_brigthness_in, 3);
638
qdev_init_gpio_in(dev, musicpal_lcd_gpio_brightness_in, 3);
652
668
static const TypeInfo musicpal_lcd_info = {
653
.name = "musicpal_lcd",
669
.name = TYPE_MUSICPAL_LCD,
654
670
.parent = TYPE_SYS_BUS_DEVICE,
655
671
.instance_size = sizeof(musicpal_lcd_state),
656
672
.class_init = musicpal_lcd_class_init,
661
677
#define MP_PIC_ENABLE_SET 0x08
662
678
#define MP_PIC_ENABLE_CLR 0x0C
664
typedef struct mv88w8618_pic_state
680
#define TYPE_MV88W8618_PIC "mv88w8618_pic"
681
#define MV88W8618_PIC(obj) \
682
OBJECT_CHECK(mv88w8618_pic_state, (obj), TYPE_MV88W8618_PIC)
684
typedef struct mv88w8618_pic_state {
686
SysBusDevice parent_obj;
667
689
MemoryRegion iomem;
669
691
uint32_t enabled;
737
758
static int mv88w8618_pic_init(SysBusDevice *dev)
739
mv88w8618_pic_state *s = FROM_SYSBUS(mv88w8618_pic_state, dev);
760
mv88w8618_pic_state *s = MV88W8618_PIC(dev);
741
qdev_init_gpio_in(&dev->qdev, mv88w8618_pic_set_irq, 32);
762
qdev_init_gpio_in(DEVICE(dev), mv88w8618_pic_set_irq, 32);
742
763
sysbus_init_irq(dev, &s->parent_irq);
743
memory_region_init_io(&s->iomem, &mv88w8618_pic_ops, s,
764
memory_region_init_io(&s->iomem, OBJECT(s), &mv88w8618_pic_ops, s,
744
765
"musicpal-pic", MP_PIC_SIZE);
745
766
sysbus_init_mmio(dev, &s->iomem);
771
792
static const TypeInfo mv88w8618_pic_info = {
772
.name = "mv88w8618_pic",
793
.name = TYPE_MV88W8618_PIC,
773
794
.parent = TYPE_SYS_BUS_DEVICE,
774
795
.instance_size = sizeof(mv88w8618_pic_state),
775
796
.class_init = mv88w8618_pic_class_init,
796
817
} mv88w8618_timer_state;
819
#define TYPE_MV88W8618_PIT "mv88w8618_pit"
820
#define MV88W8618_PIT(obj) \
821
OBJECT_CHECK(mv88w8618_pit_state, (obj), TYPE_MV88W8618_PIT)
798
823
typedef struct mv88w8618_pit_state {
825
SysBusDevice parent_obj;
800
828
MemoryRegion iomem;
801
829
mv88w8618_timer_state timer[4];
802
830
} mv88w8618_pit_state;
879
907
static void mv88w8618_pit_reset(DeviceState *d)
881
mv88w8618_pit_state *s = FROM_SYSBUS(mv88w8618_pit_state,
909
mv88w8618_pit_state *s = MV88W8618_PIT(d);
885
912
for (i = 0; i < 4; i++) {
897
924
static int mv88w8618_pit_init(SysBusDevice *dev)
899
mv88w8618_pit_state *s = FROM_SYSBUS(mv88w8618_pit_state, dev);
926
mv88w8618_pit_state *s = MV88W8618_PIT(dev);
902
929
/* Letting them all run at 1 MHz is likely just a pragmatic
905
932
mv88w8618_timer_init(dev, &s->timer[i], 1000000);
908
memory_region_init_io(&s->iomem, &mv88w8618_pit_ops, s,
935
memory_region_init_io(&s->iomem, OBJECT(s), &mv88w8618_pit_ops, s,
909
936
"musicpal-pit", MP_PIT_SIZE);
910
937
sysbus_init_mmio(dev, &s->iomem);
948
975
static const TypeInfo mv88w8618_pit_info = {
949
.name = "mv88w8618_pit",
976
.name = TYPE_MV88W8618_PIT,
950
977
.parent = TYPE_SYS_BUS_DEVICE,
951
978
.instance_size = sizeof(mv88w8618_pit_state),
952
979
.class_init = mv88w8618_pit_class_init,
955
982
/* Flash config register offsets */
956
983
#define MP_FLASHCFG_CFGR0 0x04
985
#define TYPE_MV88W8618_FLASHCFG "mv88w8618_flashcfg"
986
#define MV88W8618_FLASHCFG(obj) \
987
OBJECT_CHECK(mv88w8618_flashcfg_state, (obj), TYPE_MV88W8618_FLASHCFG)
958
989
typedef struct mv88w8618_flashcfg_state {
991
SysBusDevice parent_obj;
960
994
MemoryRegion iomem;
962
996
} mv88w8618_flashcfg_state;
997
1031
static int mv88w8618_flashcfg_init(SysBusDevice *dev)
999
mv88w8618_flashcfg_state *s = FROM_SYSBUS(mv88w8618_flashcfg_state, dev);
1033
mv88w8618_flashcfg_state *s = MV88W8618_FLASHCFG(dev);
1001
1035
s->cfgr0 = 0xfffe4285; /* Default as set by U-Boot for 8 MB flash */
1002
memory_region_init_io(&s->iomem, &mv88w8618_flashcfg_ops, s,
1036
memory_region_init_io(&s->iomem, OBJECT(s), &mv88w8618_flashcfg_ops, s,
1003
1037
"musicpal-flashcfg", MP_FLASHCFG_SIZE);
1004
1038
sysbus_init_mmio(dev, &s->iomem);
1028
1062
static const TypeInfo mv88w8618_flashcfg_info = {
1029
.name = "mv88w8618_flashcfg",
1063
.name = TYPE_MV88W8618_FLASHCFG,
1030
1064
.parent = TYPE_SYS_BUS_DEVICE,
1031
1065
.instance_size = sizeof(mv88w8618_flashcfg_state),
1032
1066
.class_init = mv88w8618_flashcfg_class_init,
1074
1108
SysBusDevice *sd = SYS_BUS_DEVICE(obj);
1075
1109
MusicPalMiscState *s = MUSICPAL_MISC(obj);
1077
memory_region_init_io(&s->iomem, &musicpal_misc_ops, NULL,
1111
memory_region_init_io(&s->iomem, OBJECT(s), &musicpal_misc_ops, NULL,
1078
1112
"musicpal-misc", MP_MISC_SIZE);
1079
1113
sysbus_init_mmio(sd, &s->iomem);
1122
1156
MemoryRegion *iomem = g_new(MemoryRegion, 1);
1124
memory_region_init_io(iomem, &mv88w8618_wlan_ops, NULL,
1158
memory_region_init_io(iomem, OBJECT(dev), &mv88w8618_wlan_ops, NULL,
1125
1159
"musicpal-wlan", MP_WLAN_SIZE);
1126
1160
sysbus_init_mmio(dev, iomem);
1149
1183
/* LCD brightness bits in GPIO_OE_HI */
1150
1184
#define MP_OE_LCD_BRIGHTNESS 0x0007
1186
#define TYPE_MUSICPAL_GPIO "musicpal_gpio"
1187
#define MUSICPAL_GPIO(obj) \
1188
OBJECT_CHECK(musicpal_gpio_state, (obj), TYPE_MUSICPAL_GPIO)
1152
1190
typedef struct musicpal_gpio_state {
1153
SysBusDevice busdev;
1192
SysBusDevice parent_obj;
1154
1195
MemoryRegion iomem;
1155
1196
uint32_t lcd_brightness;
1156
1197
uint32_t out_state;
1324
static int musicpal_gpio_init(SysBusDevice *dev)
1364
static int musicpal_gpio_init(SysBusDevice *sbd)
1326
musicpal_gpio_state *s = FROM_SYSBUS(musicpal_gpio_state, dev);
1328
sysbus_init_irq(dev, &s->irq);
1330
memory_region_init_io(&s->iomem, &musicpal_gpio_ops, s,
1366
DeviceState *dev = DEVICE(sbd);
1367
musicpal_gpio_state *s = MUSICPAL_GPIO(dev);
1369
sysbus_init_irq(sbd, &s->irq);
1371
memory_region_init_io(&s->iomem, OBJECT(s), &musicpal_gpio_ops, s,
1331
1372
"musicpal-gpio", MP_GPIO_SIZE);
1332
sysbus_init_mmio(dev, &s->iomem);
1334
qdev_init_gpio_out(&dev->qdev, s->out, ARRAY_SIZE(s->out));
1336
qdev_init_gpio_in(&dev->qdev, musicpal_gpio_pin_event, 32);
1373
sysbus_init_mmio(sbd, &s->iomem);
1375
qdev_init_gpio_out(dev, s->out, ARRAY_SIZE(s->out));
1377
qdev_init_gpio_in(dev, musicpal_gpio_pin_event, 32);
1367
1408
static const TypeInfo musicpal_gpio_info = {
1368
.name = "musicpal_gpio",
1409
.name = TYPE_MUSICPAL_GPIO,
1369
1410
.parent = TYPE_SYS_BUS_DEVICE,
1370
1411
.instance_size = sizeof(musicpal_gpio_state),
1371
1412
.class_init = musicpal_gpio_class_init,
1395
1436
#define MP_KEY_BTN_VOLUME (1 << 6)
1396
1437
#define MP_KEY_BTN_NAVIGATION (1 << 7)
1439
#define TYPE_MUSICPAL_KEY "musicpal_key"
1440
#define MUSICPAL_KEY(obj) \
1441
OBJECT_CHECK(musicpal_key_state, (obj), TYPE_MUSICPAL_KEY)
1398
1443
typedef struct musicpal_key_state {
1399
SysBusDevice busdev;
1445
SysBusDevice parent_obj;
1400
1448
MemoryRegion iomem;
1401
1449
uint32_t kbd_extended;
1402
1450
uint32_t pressed_keys;
1480
1528
s->kbd_extended = 0;
1483
static int musicpal_key_init(SysBusDevice *dev)
1531
static int musicpal_key_init(SysBusDevice *sbd)
1485
musicpal_key_state *s = FROM_SYSBUS(musicpal_key_state, dev);
1533
DeviceState *dev = DEVICE(sbd);
1534
musicpal_key_state *s = MUSICPAL_KEY(dev);
1487
memory_region_init(&s->iomem, "dummy", 0);
1488
sysbus_init_mmio(dev, &s->iomem);
1536
memory_region_init(&s->iomem, OBJECT(s), "dummy", 0);
1537
sysbus_init_mmio(sbd, &s->iomem);
1490
1539
s->kbd_extended = 0;
1491
1540
s->pressed_keys = 0;
1493
qdev_init_gpio_out(&dev->qdev, s->out, ARRAY_SIZE(s->out));
1542
qdev_init_gpio_out(dev, s->out, ARRAY_SIZE(s->out));
1495
1544
qemu_add_kbd_event_handler(musicpal_key_event, s);
1521
1570
static const TypeInfo musicpal_key_info = {
1522
.name = "musicpal_key",
1571
.name = TYPE_MUSICPAL_KEY,
1523
1572
.parent = TYPE_SYS_BUS_DEVICE,
1524
1573
.instance_size = sizeof(musicpal_key_state),
1525
1574
.class_init = musicpal_key_class_init,
1564
1613
cpu_pic = arm_pic_init_cpu(cpu);
1566
1615
/* For now we use a fixed - the original - RAM size */
1567
memory_region_init_ram(ram, "musicpal.ram", MP_RAM_DEFAULT_SIZE);
1616
memory_region_init_ram(ram, NULL, "musicpal.ram", MP_RAM_DEFAULT_SIZE);
1568
1617
vmstate_register_ram_global(ram);
1569
1618
memory_region_add_subregion(address_space_mem, 0, ram);
1571
memory_region_init_ram(sram, "musicpal.sram", MP_SRAM_SIZE);
1620
memory_region_init_ram(sram, NULL, "musicpal.sram", MP_SRAM_SIZE);
1572
1621
vmstate_register_ram_global(sram);
1573
1622
memory_region_add_subregion(address_space_mem, MP_SRAM_BASE, sram);
1575
dev = sysbus_create_simple("mv88w8618_pic", MP_PIC_BASE,
1624
dev = sysbus_create_simple(TYPE_MV88W8618_PIC, MP_PIC_BASE,
1576
1625
cpu_pic[ARM_PIC_CPU_IRQ]);
1577
1626
for (i = 0; i < 32; i++) {
1578
1627
pic[i] = qdev_get_gpio_in(dev, i);
1580
sysbus_create_varargs("mv88w8618_pit", MP_PIT_BASE, pic[MP_TIMER1_IRQ],
1629
sysbus_create_varargs(TYPE_MV88W8618_PIT, MP_PIT_BASE, pic[MP_TIMER1_IRQ],
1581
1630
pic[MP_TIMER2_IRQ], pic[MP_TIMER3_IRQ],
1582
1631
pic[MP_TIMER4_IRQ], NULL);
1627
sysbus_create_simple("mv88w8618_flashcfg", MP_FLASHCFG_BASE, NULL);
1676
sysbus_create_simple(TYPE_MV88W8618_FLASHCFG, MP_FLASHCFG_BASE, NULL);
1629
1678
qemu_check_nic_model(&nd_table[0], "mv88w8618");
1630
dev = qdev_create(NULL, "mv88w8618_eth");
1679
dev = qdev_create(NULL, TYPE_MV88W8618_ETH);
1631
1680
qdev_set_nic_properties(dev, &nd_table[0]);
1632
1681
qdev_init_nofail(dev);
1633
1682
sysbus_mmio_map(SYS_BUS_DEVICE(dev), 0, MP_ETH_BASE);
1638
1687
sysbus_create_simple(TYPE_MUSICPAL_MISC, MP_MISC_BASE, NULL);
1640
dev = sysbus_create_simple("musicpal_gpio", MP_GPIO_BASE, pic[MP_GPIO_IRQ]);
1689
dev = sysbus_create_simple(TYPE_MUSICPAL_GPIO, MP_GPIO_BASE,
1641
1691
i2c_dev = sysbus_create_simple("gpio_i2c", -1, NULL);
1642
1692
i2c = (i2c_bus *)qdev_get_child_bus(i2c_dev, "i2c");
1644
lcd_dev = sysbus_create_simple("musicpal_lcd", MP_LCD_BASE, NULL);
1645
key_dev = sysbus_create_simple("musicpal_key", -1, NULL);
1694
lcd_dev = sysbus_create_simple(TYPE_MUSICPAL_LCD, MP_LCD_BASE, NULL);
1695
key_dev = sysbus_create_simple(TYPE_MUSICPAL_KEY, -1, NULL);
1647
1697
/* I2C read data */
1648
1698
qdev_connect_gpio_out(i2c_dev, 0,