~ubuntu-branches/ubuntu/trusty/qemu/trusty

« back to all changes in this revision

Viewing changes to hw/arm/spitz.c

  • Committer: Package Import Robot
  • Author(s): Serge Hallyn
  • Date: 2013-10-22 22:47:07 UTC
  • mfrom: (1.8.3) (10.1.42 sid)
  • Revision ID: package-import@ubuntu.com-20131022224707-1lya34fw3k3f24tv
Tags: 1.6.0+dfsg-2ubuntu1
* Merge 1.6.0~rc0+dfsg-2exp from debian experimental.  Remaining changes:
  - debian/control
    * update maintainer
    * remove libiscsi, usb-redir, vde, vnc-jpeg, and libssh2-1-dev
      from build-deps
    * enable rbd
    * add qemu-system and qemu-common B/R to qemu-keymaps
    * add D:udev, R:qemu, R:qemu-common and B:qemu-common to
      qemu-system-common
    * qemu-system-arm, qemu-system-ppc, qemu-system-sparc:
      - add qemu-kvm to Provides
      - add qemu-common, qemu-kvm, kvm to B/R
      - remove openbios-sparc from qemu-system-sparc D
      - drop openbios-ppc and openhackware Depends to Suggests (for now)
    * qemu-system-x86:
      - add qemu-common to Breaks/Replaces.
      - add cpu-checker to Recommends.
    * qemu-user: add B/R:qemu-kvm
    * qemu-kvm:
      - add armhf armel powerpc sparc to Architecture
      - C/R/P: qemu-kvm-spice
    * add qemu-common package
    * drop qemu-slof which is not packaged in ubuntu
  - add qemu-system-common.links for tap ifup/down scripts and OVMF link.
  - qemu-system-x86.links:
    * remove pxe rom links which are in kvm-ipxe
    * add symlink for kvm.1 manpage
  - debian/rules
    * add kvm-spice symlink to qemu-kvm
    * call dh_installmodules for qemu-system-x86
    * update dh_installinit to install upstart script
    * run dh_installman (Closes: #709241) (cherrypicked from 1.5.0+dfsg-2)
  - Add qemu-utils.links for kvm-* symlinks.
  - Add qemu-system-x86.qemu-kvm.upstart and .default
  - Add qemu-system-x86.modprobe to set nesting=1
  - Add qemu-system-common.preinst to add kvm group
  - qemu-system-common.postinst: remove bad group acl if there, then have
    udev relabel /dev/kvm.
  - New linaro patches from qemu-linaro rebasing branch
  - Dropped patches:
    * xen-simplify-xen_enabled.patch
    * sparc-linux-user-fix-missing-symbols-in-.rel-.rela.plt-sections.patch
    * main_loop-do-not-set-nonblocking-if-xen_enabled.patch
    * xen_machine_pv-do-not-create-a-dummy-CPU-in-machine-.patch
    * virtio-rng-fix-crash
  - Kept patches:
    * expose_vms_qemu64cpu.patch - updated
    * linaro arm patches from qemu-linaro rebasing branch
  - New patches:
    * fix-pci-add: change CONFIG variable in ifdef to make sure that
      pci_add is defined.
* Add linaro patches
* Add experimental mach-virt patches for arm virtualization.
* qemu-system-common.install: add debian/tmp/usr/lib to install the
  qemu-bridge-helper

Show diffs side-by-side

added added

removed removed

Lines of Context:
50
50
#define FLASHCTL_RYBY           (1 << 5)
51
51
#define FLASHCTL_NCE            (FLASHCTL_CE0 | FLASHCTL_CE1)
52
52
 
 
53
#define TYPE_SL_NAND "sl-nand"
 
54
#define SL_NAND(obj) OBJECT_CHECK(SLNANDState, (obj), TYPE_SL_NAND)
 
55
 
53
56
typedef struct {
54
 
    SysBusDevice busdev;
 
57
    SysBusDevice parent_obj;
 
58
 
55
59
    MemoryRegion iomem;
56
60
    DeviceState *nand;
57
61
    uint8_t ctl;
147
151
{
148
152
    DeviceState *dev;
149
153
 
150
 
    dev = qdev_create(NULL, "sl-nand");
 
154
    dev = qdev_create(NULL, TYPE_SL_NAND);
151
155
 
152
156
    qdev_prop_set_uint8(dev, "manf_id", NAND_MFR_SAMSUNG);
153
157
    if (size == FLASH_128M)
159
163
    sysbus_mmio_map(SYS_BUS_DEVICE(dev), 0, FLASH_BASE);
160
164
}
161
165
 
162
 
static int sl_nand_init(SysBusDevice *dev) {
163
 
    SLNANDState *s;
 
166
static int sl_nand_init(SysBusDevice *dev)
 
167
{
 
168
    SLNANDState *s = SL_NAND(dev);
164
169
    DriveInfo *nand;
165
170
 
166
 
    s = FROM_SYSBUS(SLNANDState, dev);
167
 
 
168
171
    s->ctl = 0;
169
172
    nand = drive_get(IF_MTD, 0, 0);
170
173
    s->nand = nand_init(nand ? nand->bdrv : NULL, s->manf_id, s->chip_id);
171
174
 
172
 
    memory_region_init_io(&s->iomem, &sl_ops, s, "sl", 0x40);
 
175
    memory_region_init_io(&s->iomem, OBJECT(s), &sl_ops, s, "sl", 0x40);
173
176
    sysbus_init_mmio(dev, &s->iomem);
174
177
 
175
178
    return 0;
212
215
    SPITZ_GPIO_SWA, SPITZ_GPIO_SWB,
213
216
};
214
217
 
 
218
#define TYPE_SPITZ_KEYBOARD "spitz-keyboard"
 
219
#define SPITZ_KEYBOARD(obj) \
 
220
    OBJECT_CHECK(SpitzKeyboardState, (obj), TYPE_SPITZ_KEYBOARD)
 
221
 
215
222
typedef struct {
216
 
    SysBusDevice busdev;
 
223
    SysBusDevice parent_obj;
 
224
 
217
225
    qemu_irq sense[SPITZ_KEY_SENSE_NUM];
218
226
    qemu_irq gpiomap[5];
219
227
    int keymap[0x80];
458
466
    DeviceState *dev;
459
467
    SpitzKeyboardState *s;
460
468
 
461
 
    dev = sysbus_create_simple("spitz-keyboard", -1, NULL);
462
 
    s = FROM_SYSBUS(SpitzKeyboardState, SYS_BUS_DEVICE(dev));
 
469
    dev = sysbus_create_simple(TYPE_SPITZ_KEYBOARD, -1, NULL);
 
470
    s = SPITZ_KEYBOARD(dev);
463
471
 
464
472
    for (i = 0; i < SPITZ_KEY_SENSE_NUM; i ++)
465
473
        qdev_connect_gpio_out(dev, i, qdev_get_gpio_in(cpu->gpio, spitz_gpio_key_sense[i]));
482
490
    qemu_add_kbd_event_handler(spitz_keyboard_handler, s);
483
491
}
484
492
 
485
 
static int spitz_keyboard_init(SysBusDevice *dev)
 
493
static int spitz_keyboard_init(SysBusDevice *sbd)
486
494
{
487
 
    SpitzKeyboardState *s;
 
495
    DeviceState *dev = DEVICE(sbd);
 
496
    SpitzKeyboardState *s = SPITZ_KEYBOARD(dev);
488
497
    int i, j;
489
498
 
490
 
    s = FROM_SYSBUS(SpitzKeyboardState, dev);
491
 
 
492
499
    for (i = 0; i < 0x80; i ++)
493
500
        s->keymap[i] = -1;
494
501
    for (i = 0; i < SPITZ_KEY_SENSE_NUM + 1; i ++)
499
506
    spitz_keyboard_pre_map(s);
500
507
 
501
508
    s->kbdtimer = qemu_new_timer_ns(vm_clock, spitz_keyboard_tick, s);
502
 
    qdev_init_gpio_in(&dev->qdev, spitz_keyboard_strobe, SPITZ_KEY_STROBE_NUM);
503
 
    qdev_init_gpio_out(&dev->qdev, s->sense, SPITZ_KEY_SENSE_NUM);
 
509
    qdev_init_gpio_in(dev, spitz_keyboard_strobe, SPITZ_KEY_STROBE_NUM);
 
510
    qdev_init_gpio_out(dev, s->sense, SPITZ_KEY_SENSE_NUM);
504
511
 
505
512
    return 0;
506
513
}
896
903
 
897
904
    sl_flash_register(mpu, (model == spitz) ? FLASH_128M : FLASH_1024M);
898
905
 
899
 
    memory_region_init_ram(rom, "spitz.rom", SPITZ_ROM);
 
906
    memory_region_init_ram(rom, NULL, "spitz.rom", SPITZ_ROM);
900
907
    vmstate_register_ram_global(rom);
901
908
    memory_region_set_readonly(rom, true);
902
909
    memory_region_add_subregion(address_space_mem, 0, rom);
1027
1034
}
1028
1035
 
1029
1036
static const TypeInfo sl_nand_info = {
1030
 
    .name          = "sl-nand",
 
1037
    .name          = TYPE_SL_NAND,
1031
1038
    .parent        = TYPE_SYS_BUS_DEVICE,
1032
1039
    .instance_size = sizeof(SLNANDState),
1033
1040
    .class_init    = sl_nand_class_init,
1062
1069
}
1063
1070
 
1064
1071
static const TypeInfo spitz_keyboard_info = {
1065
 
    .name          = "spitz-keyboard",
 
1072
    .name          = TYPE_SPITZ_KEYBOARD,
1066
1073
    .parent        = TYPE_SYS_BUS_DEVICE,
1067
1074
    .instance_size = sizeof(SpitzKeyboardState),
1068
1075
    .class_init    = spitz_keyboard_class_init,