Cornelia Huck | a5cf2bb | 2013-01-24 06:08:55 +0000 | [diff] [blame] | 1 | /* |
| 2 | * virtio ccw target definitions |
| 3 | * |
Pierre Morel | de6a921 | 2015-05-27 13:11:59 +0200 | [diff] [blame] | 4 | * Copyright 2012,2015 IBM Corp. |
Cornelia Huck | a5cf2bb | 2013-01-24 06:08:55 +0000 | [diff] [blame] | 5 | * Author(s): Cornelia Huck <cornelia.huck@de.ibm.com> |
Pierre Morel | de6a921 | 2015-05-27 13:11:59 +0200 | [diff] [blame] | 6 | * Pierre Morel <pmorel@linux.vnet.ibm.com> |
Cornelia Huck | a5cf2bb | 2013-01-24 06:08:55 +0000 | [diff] [blame] | 7 | * |
| 8 | * This work is licensed under the terms of the GNU GPL, version 2 or (at |
| 9 | * your option) any later version. See the COPYING file in the top-level |
| 10 | * directory. |
| 11 | */ |
| 12 | |
| 13 | #ifndef HW_S390X_VIRTIO_CCW_H |
| 14 | #define HW_S390X_VIRTIO_CCW_H |
| 15 | |
Paolo Bonzini | 0d09e41 | 2013-02-05 17:06:20 +0100 | [diff] [blame] | 16 | #include <hw/virtio/virtio-blk.h> |
| 17 | #include <hw/virtio/virtio-net.h> |
| 18 | #include <hw/virtio/virtio-serial.h> |
| 19 | #include <hw/virtio/virtio-scsi.h> |
Paolo Bonzini | ccf6916 | 2013-04-19 16:16:50 +0200 | [diff] [blame] | 20 | #ifdef CONFIG_VHOST_SCSI |
| 21 | #include <hw/virtio/vhost-scsi.h> |
| 22 | #endif |
Paolo Bonzini | 0d09e41 | 2013-02-05 17:06:20 +0100 | [diff] [blame] | 23 | #include <hw/virtio/virtio-balloon.h> |
| 24 | #include <hw/virtio/virtio-rng.h> |
| 25 | #include <hw/virtio/virtio-bus.h> |
Cornelia Huck | d426d9f | 2013-07-15 17:45:03 +0200 | [diff] [blame] | 26 | #include <hw/s390x/s390_flic.h> |
Cornelia Huck | a5cf2bb | 2013-01-24 06:08:55 +0000 | [diff] [blame] | 27 | |
| 28 | #define VIRTUAL_CSSID 0xfe |
| 29 | |
| 30 | #define VIRTIO_CCW_CU_TYPE 0x3832 |
| 31 | #define VIRTIO_CCW_CHPID_TYPE 0x32 |
| 32 | |
| 33 | #define CCW_CMD_SET_VQ 0x13 |
| 34 | #define CCW_CMD_VDEV_RESET 0x33 |
| 35 | #define CCW_CMD_READ_FEAT 0x12 |
| 36 | #define CCW_CMD_WRITE_FEAT 0x11 |
| 37 | #define CCW_CMD_READ_CONF 0x22 |
| 38 | #define CCW_CMD_WRITE_CONF 0x21 |
| 39 | #define CCW_CMD_WRITE_STATUS 0x31 |
| 40 | #define CCW_CMD_SET_IND 0x43 |
| 41 | #define CCW_CMD_SET_CONF_IND 0x53 |
| 42 | #define CCW_CMD_READ_VQ_CONF 0x32 |
Cornelia Huck | 7e74946 | 2013-02-06 10:31:37 +0100 | [diff] [blame] | 43 | #define CCW_CMD_SET_IND_ADAPTER 0x73 |
Thomas Huth | c42767f | 2014-12-11 14:25:12 +0100 | [diff] [blame] | 44 | #define CCW_CMD_SET_VIRTIO_REV 0x83 |
Cornelia Huck | a5cf2bb | 2013-01-24 06:08:55 +0000 | [diff] [blame] | 45 | |
| 46 | #define TYPE_VIRTIO_CCW_DEVICE "virtio-ccw-device" |
| 47 | #define VIRTIO_CCW_DEVICE(obj) \ |
| 48 | OBJECT_CHECK(VirtioCcwDevice, (obj), TYPE_VIRTIO_CCW_DEVICE) |
| 49 | #define VIRTIO_CCW_DEVICE_CLASS(klass) \ |
| 50 | OBJECT_CLASS_CHECK(VirtIOCCWDeviceClass, (klass), TYPE_VIRTIO_CCW_DEVICE) |
| 51 | #define VIRTIO_CCW_DEVICE_GET_CLASS(obj) \ |
| 52 | OBJECT_GET_CLASS(VirtIOCCWDeviceClass, (obj), TYPE_VIRTIO_CCW_DEVICE) |
| 53 | |
| 54 | typedef struct VirtioBusState VirtioCcwBusState; |
| 55 | typedef struct VirtioBusClass VirtioCcwBusClass; |
| 56 | |
| 57 | #define TYPE_VIRTIO_CCW_BUS "virtio-ccw-bus" |
| 58 | #define VIRTIO_CCW_BUS(obj) \ |
| 59 | OBJECT_CHECK(VirtioCcwBus, (obj), TYPE_VIRTIO_CCW_BUS) |
| 60 | #define VIRTIO_CCW_BUS_GET_CLASS(obj) \ |
| 61 | OBJECT_CHECK(VirtioCcwBusState, (obj), TYPE_VIRTIO_CCW_BUS) |
| 62 | #define VIRTIO_CCW_BUS_CLASS(klass) \ |
| 63 | OBJECT_CLASS_CHECK(VirtioCcwBusClass, klass, TYPE_VIRTIO_CCW_BUS) |
| 64 | |
| 65 | typedef struct VirtioCcwDevice VirtioCcwDevice; |
| 66 | |
Cornelia Huck | a5cf2bb | 2013-01-24 06:08:55 +0000 | [diff] [blame] | 67 | typedef struct VirtIOCCWDeviceClass { |
| 68 | DeviceClass parent_class; |
Markus Armbruster | 5e5ced3 | 2015-02-27 14:53:39 +0100 | [diff] [blame] | 69 | void (*realize)(VirtioCcwDevice *dev, Error **errp); |
Cornelia Huck | a5cf2bb | 2013-01-24 06:08:55 +0000 | [diff] [blame] | 70 | int (*exit)(VirtioCcwDevice *dev); |
| 71 | } VirtIOCCWDeviceClass; |
| 72 | |
Cornelia Huck | b4436a0 | 2013-02-15 10:18:43 +0100 | [diff] [blame] | 73 | /* Performance improves when virtqueue kick processing is decoupled from the |
| 74 | * vcpu thread using ioeventfd for some devices. */ |
| 75 | #define VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT 1 |
| 76 | #define VIRTIO_CCW_FLAG_USE_IOEVENTFD (1 << VIRTIO_CCW_FLAG_USE_IOEVENTFD_BIT) |
| 77 | |
Cornelia Huck | 7bca389 | 2013-08-01 17:27:00 +0200 | [diff] [blame] | 78 | typedef struct IndAddr { |
| 79 | hwaddr addr; |
Cornelia Huck | d426d9f | 2013-07-15 17:45:03 +0200 | [diff] [blame] | 80 | uint64_t map; |
Cornelia Huck | 7bca389 | 2013-08-01 17:27:00 +0200 | [diff] [blame] | 81 | unsigned long refcnt; |
| 82 | int len; |
| 83 | QTAILQ_ENTRY(IndAddr) sibling; |
| 84 | } IndAddr; |
| 85 | |
Cornelia Huck | a5cf2bb | 2013-01-24 06:08:55 +0000 | [diff] [blame] | 86 | struct VirtioCcwDevice { |
| 87 | DeviceState parent_obj; |
| 88 | SubchDev *sch; |
Cornelia Huck | a5cf2bb | 2013-01-24 06:08:55 +0000 | [diff] [blame] | 89 | char *bus_id; |
Thomas Huth | c42767f | 2014-12-11 14:25:12 +0100 | [diff] [blame] | 90 | int revision; |
Cornelia Huck | a5cf2bb | 2013-01-24 06:08:55 +0000 | [diff] [blame] | 91 | VirtioBusState bus; |
Cornelia Huck | b4436a0 | 2013-02-15 10:18:43 +0100 | [diff] [blame] | 92 | bool ioeventfd_started; |
Cornelia Huck | 320ce85 | 2013-02-19 13:48:17 +0100 | [diff] [blame] | 93 | bool ioeventfd_disabled; |
Cornelia Huck | b4436a0 | 2013-02-15 10:18:43 +0100 | [diff] [blame] | 94 | uint32_t flags; |
Cornelia Huck | 7e74946 | 2013-02-06 10:31:37 +0100 | [diff] [blame] | 95 | uint8_t thinint_isc; |
Cornelia Huck | d426d9f | 2013-07-15 17:45:03 +0200 | [diff] [blame] | 96 | AdapterRoutes routes; |
Cornelia Huck | a5cf2bb | 2013-01-24 06:08:55 +0000 | [diff] [blame] | 97 | /* Guest provided values: */ |
Cornelia Huck | 7bca389 | 2013-08-01 17:27:00 +0200 | [diff] [blame] | 98 | IndAddr *indicators; |
| 99 | IndAddr *indicators2; |
| 100 | IndAddr *summary_indicator; |
Cornelia Huck | 7e74946 | 2013-02-06 10:31:37 +0100 | [diff] [blame] | 101 | uint64_t ind_bit; |
Cornelia Huck | a5cf2bb | 2013-01-24 06:08:55 +0000 | [diff] [blame] | 102 | }; |
| 103 | |
Thomas Huth | c42767f | 2014-12-11 14:25:12 +0100 | [diff] [blame] | 104 | /* The maximum virtio revision we support. */ |
| 105 | static inline int virtio_ccw_rev_max(VirtIODevice *vdev) |
| 106 | { |
| 107 | return 0; |
| 108 | } |
| 109 | |
Cornelia Huck | a5cf2bb | 2013-01-24 06:08:55 +0000 | [diff] [blame] | 110 | /* virtual css bus type */ |
| 111 | typedef struct VirtualCssBus { |
| 112 | BusState parent_obj; |
| 113 | } VirtualCssBus; |
| 114 | |
| 115 | #define TYPE_VIRTUAL_CSS_BUS "virtual-css-bus" |
| 116 | #define VIRTUAL_CSS_BUS(obj) \ |
| 117 | OBJECT_CHECK(VirtualCssBus, (obj), TYPE_VIRTUAL_CSS_BUS) |
| 118 | |
KONRAD Frederic | c908ea1 | 2013-03-21 15:15:17 +0100 | [diff] [blame] | 119 | /* virtio-scsi-ccw */ |
| 120 | |
| 121 | #define TYPE_VIRTIO_SCSI_CCW "virtio-scsi-ccw" |
| 122 | #define VIRTIO_SCSI_CCW(obj) \ |
| 123 | OBJECT_CHECK(VirtIOSCSICcw, (obj), TYPE_VIRTIO_SCSI_CCW) |
| 124 | |
| 125 | typedef struct VirtIOSCSICcw { |
| 126 | VirtioCcwDevice parent_obj; |
| 127 | VirtIOSCSI vdev; |
| 128 | } VirtIOSCSICcw; |
| 129 | |
Ed Maste | b702d2a | 2013-04-25 13:38:28 -0400 | [diff] [blame] | 130 | #ifdef CONFIG_VHOST_SCSI |
Paolo Bonzini | ccf6916 | 2013-04-19 16:16:50 +0200 | [diff] [blame] | 131 | /* vhost-scsi-ccw */ |
| 132 | |
| 133 | #define TYPE_VHOST_SCSI_CCW "vhost-scsi-ccw" |
| 134 | #define VHOST_SCSI_CCW(obj) \ |
| 135 | OBJECT_CHECK(VHostSCSICcw, (obj), TYPE_VHOST_SCSI_CCW) |
| 136 | |
| 137 | typedef struct VHostSCSICcw { |
| 138 | VirtioCcwDevice parent_obj; |
| 139 | VHostSCSI vdev; |
| 140 | } VHostSCSICcw; |
Ed Maste | b702d2a | 2013-04-25 13:38:28 -0400 | [diff] [blame] | 141 | #endif |
Paolo Bonzini | ccf6916 | 2013-04-19 16:16:50 +0200 | [diff] [blame] | 142 | |
KONRAD Frederic | 3400c45 | 2013-03-18 17:37:25 +0100 | [diff] [blame] | 143 | /* virtio-blk-ccw */ |
| 144 | |
| 145 | #define TYPE_VIRTIO_BLK_CCW "virtio-blk-ccw" |
| 146 | #define VIRTIO_BLK_CCW(obj) \ |
| 147 | OBJECT_CHECK(VirtIOBlkCcw, (obj), TYPE_VIRTIO_BLK_CCW) |
| 148 | |
| 149 | typedef struct VirtIOBlkCcw { |
| 150 | VirtioCcwDevice parent_obj; |
| 151 | VirtIOBlock vdev; |
KONRAD Frederic | 3400c45 | 2013-03-18 17:37:25 +0100 | [diff] [blame] | 152 | } VirtIOBlkCcw; |
| 153 | |
KONRAD Frederic | 30bff6a | 2013-03-27 10:49:12 +0100 | [diff] [blame] | 154 | /* virtio-balloon-ccw */ |
| 155 | |
| 156 | #define TYPE_VIRTIO_BALLOON_CCW "virtio-balloon-ccw" |
| 157 | #define VIRTIO_BALLOON_CCW(obj) \ |
| 158 | OBJECT_CHECK(VirtIOBalloonCcw, (obj), TYPE_VIRTIO_BALLOON_CCW) |
| 159 | |
| 160 | typedef struct VirtIOBalloonCcw { |
| 161 | VirtioCcwDevice parent_obj; |
| 162 | VirtIOBalloon vdev; |
| 163 | } VirtIOBalloonCcw; |
KONRAD Frederic | 3400c45 | 2013-03-18 17:37:25 +0100 | [diff] [blame] | 164 | |
KONRAD Frederic | 6acf69c | 2013-04-09 14:53:33 +0200 | [diff] [blame] | 165 | /* virtio-serial-ccw */ |
| 166 | |
| 167 | #define TYPE_VIRTIO_SERIAL_CCW "virtio-serial-ccw" |
| 168 | #define VIRTIO_SERIAL_CCW(obj) \ |
| 169 | OBJECT_CHECK(VirtioSerialCcw, (obj), TYPE_VIRTIO_SERIAL_CCW) |
| 170 | |
| 171 | typedef struct VirtioSerialCcw { |
| 172 | VirtioCcwDevice parent_obj; |
| 173 | VirtIOSerial vdev; |
| 174 | } VirtioSerialCcw; |
| 175 | |
KONRAD Frederic | 89334c8 | 2013-04-11 16:30:00 +0200 | [diff] [blame] | 176 | /* virtio-net-ccw */ |
| 177 | |
| 178 | #define TYPE_VIRTIO_NET_CCW "virtio-net-ccw" |
| 179 | #define VIRTIO_NET_CCW(obj) \ |
| 180 | OBJECT_CHECK(VirtIONetCcw, (obj), TYPE_VIRTIO_NET_CCW) |
| 181 | |
| 182 | typedef struct VirtIONetCcw { |
| 183 | VirtioCcwDevice parent_obj; |
| 184 | VirtIONet vdev; |
| 185 | } VirtIONetCcw; |
| 186 | |
KONRAD Frederic | 2db26d4 | 2013-04-24 10:07:58 +0200 | [diff] [blame] | 187 | /* virtio-rng-ccw */ |
| 188 | |
| 189 | #define TYPE_VIRTIO_RNG_CCW "virtio-rng-ccw" |
| 190 | #define VIRTIO_RNG_CCW(obj) \ |
| 191 | OBJECT_CHECK(VirtIORNGCcw, (obj), TYPE_VIRTIO_RNG_CCW) |
| 192 | |
| 193 | typedef struct VirtIORNGCcw { |
| 194 | VirtioCcwDevice parent_obj; |
| 195 | VirtIORNG vdev; |
| 196 | } VirtIORNGCcw; |
| 197 | |
Cornelia Huck | a5cf2bb | 2013-01-24 06:08:55 +0000 | [diff] [blame] | 198 | VirtualCssBus *virtual_css_bus_init(void); |
| 199 | void virtio_ccw_device_update_status(SubchDev *sch); |
| 200 | VirtIODevice *virtio_ccw_get_vdev(SubchDev *sch); |
Pierre Morel | de6a921 | 2015-05-27 13:11:59 +0200 | [diff] [blame] | 201 | |
| 202 | #ifdef CONFIG_VIRTFS |
| 203 | #include "hw/9pfs/virtio-9p.h" |
| 204 | |
| 205 | #define TYPE_VIRTIO_9P_CCW "virtio-9p-ccw" |
| 206 | #define VIRTIO_9P_CCW(obj) \ |
| 207 | OBJECT_CHECK(V9fsCCWState, (obj), TYPE_VIRTIO_9P_CCW) |
| 208 | |
| 209 | typedef struct V9fsCCWState { |
| 210 | VirtioCcwDevice parent_obj; |
| 211 | V9fsState vdev; |
| 212 | } V9fsCCWState; |
| 213 | |
| 214 | #endif /* CONFIG_VIRTFS */ |
| 215 | |
Cornelia Huck | a5cf2bb | 2013-01-24 06:08:55 +0000 | [diff] [blame] | 216 | #endif |