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

« back to all changes in this revision

Viewing changes to hw/ssi/xilinx_spi.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:
73
73
 
74
74
#define FIFO_CAPACITY 256
75
75
 
 
76
#define TYPE_XILINX_SPI "xlnx.xps-spi"
 
77
#define XILINX_SPI(obj) OBJECT_CHECK(XilinxSPI, (obj), TYPE_XILINX_SPI)
 
78
 
76
79
typedef struct XilinxSPI {
77
 
    SysBusDevice busdev;
 
80
    SysBusDevice parent_obj;
 
81
 
78
82
    MemoryRegion mmio;
79
83
 
80
84
    qemu_irq irq;
109
113
 
110
114
static void xlx_spi_update_cs(XilinxSPI *s)
111
115
{
112
 
   int i;
 
116
    int i;
113
117
 
114
118
    for (i = 0; i < s->num_cs; ++i) {
115
119
        qemu_set_irq(s->cs_lines[i], !(~s->regs[R_SPISSR] & 1 << i));
154
158
 
155
159
static void xlx_spi_reset(DeviceState *d)
156
160
{
157
 
    xlx_spi_do_reset(DO_UPCAST(XilinxSPI, busdev.qdev, d));
 
161
    xlx_spi_do_reset(XILINX_SPI(d));
158
162
}
159
163
 
160
164
static inline int spi_master_enabled(XilinxSPI *s)
314
318
    }
315
319
};
316
320
 
317
 
static int xilinx_spi_init(SysBusDevice *dev)
 
321
static int xilinx_spi_init(SysBusDevice *sbd)
318
322
{
 
323
    DeviceState *dev = DEVICE(sbd);
 
324
    XilinxSPI *s = XILINX_SPI(dev);
319
325
    int i;
320
 
    XilinxSPI *s = FROM_SYSBUS(typeof(*s), dev);
321
326
 
322
327
    DB_PRINT("\n");
323
328
 
324
 
    s->spi = ssi_create_bus(&dev->qdev, "spi");
 
329
    s->spi = ssi_create_bus(dev, "spi");
325
330
 
326
 
    sysbus_init_irq(dev, &s->irq);
 
331
    sysbus_init_irq(sbd, &s->irq);
327
332
    s->cs_lines = g_new(qemu_irq, s->num_cs);
328
 
    ssi_auto_connect_slaves(DEVICE(s), s->cs_lines, s->spi);
 
333
    ssi_auto_connect_slaves(dev, s->cs_lines, s->spi);
329
334
    for (i = 0; i < s->num_cs; ++i) {
330
 
        sysbus_init_irq(dev, &s->cs_lines[i]);
 
335
        sysbus_init_irq(sbd, &s->cs_lines[i]);
331
336
    }
332
337
 
333
 
    memory_region_init_io(&s->mmio, &spi_ops, s, "xilinx-spi", R_MAX * 4);
334
 
    sysbus_init_mmio(dev, &s->mmio);
 
338
    memory_region_init_io(&s->mmio, OBJECT(s), &spi_ops, s,
 
339
                          "xilinx-spi", R_MAX * 4);
 
340
    sysbus_init_mmio(sbd, &s->mmio);
335
341
 
336
342
    s->irqline = -1;
337
343
 
371
377
}
372
378
 
373
379
static const TypeInfo xilinx_spi_info = {
374
 
    .name           = "xlnx.xps-spi",
 
380
    .name           = TYPE_XILINX_SPI,
375
381
    .parent         = TYPE_SYS_BUS_DEVICE,
376
382
    .instance_size  = sizeof(XilinxSPI),
377
383
    .class_init     = xilinx_spi_class_init,