diff options
author | Mike Larkin <mlarkin@cvs.openbsd.org> | 2018-07-09 08:43:10 +0000 |
---|---|---|
committer | Mike Larkin <mlarkin@cvs.openbsd.org> | 2018-07-09 08:43:10 +0000 |
commit | ded0cc36256ed91eda5bbb71a6a6b446008689f3 (patch) | |
tree | 48a8cd86127b0f335b8ced10c182a787bf816e90 | |
parent | 4c35ce156c41e93e7570eb2e6aa08bde765a1a0d (diff) |
vmd(8): stash device IRQ in the device struct
ok kettenis
-rw-r--r-- | usr.sbin/vmd/virtio.c | 11 | ||||
-rw-r--r-- | usr.sbin/vmd/virtio.h | 10 | ||||
-rw-r--r-- | usr.sbin/vmd/vmd.h | 4 |
3 files changed, 18 insertions, 7 deletions
diff --git a/usr.sbin/vmd/virtio.c b/usr.sbin/vmd/virtio.c index 4452cfcbb53..599dda467bf 100644 --- a/usr.sbin/vmd/virtio.c +++ b/usr.sbin/vmd/virtio.c @@ -1,4 +1,4 @@ -/* $OpenBSD: virtio.c,v 1.61 2018/06/19 17:12:34 reyk Exp $ */ +/* $OpenBSD: virtio.c,v 1.62 2018/07/09 08:43:09 mlarkin Exp $ */ /* * Copyright (c) 2015 Mike Larkin <mlarkin@openbsd.org> @@ -1769,6 +1769,7 @@ virtio_init(struct vmd_vm *vm, int child_cdrom, int *child_disks, sizeof(struct vring_desc) * VIORND_QUEUE_SIZE + sizeof(uint16_t) * (2 + VIORND_QUEUE_SIZE)); viornd.pci_id = id; + viornd.irq = pci_get_dev_irq(id); if (vcp->vcp_ndisks > 0) { nr_vioblk = vcp->vcp_ndisks; @@ -1812,6 +1813,7 @@ virtio_init(struct vmd_vm *vm, int child_cdrom, int *child_disks, vioblk[i].cfg.device_feature = VIRTIO_BLK_F_SIZE_MAX; vioblk[i].max_xfer = 1048576; vioblk[i].pci_id = id; + vioblk[i].irq = pci_get_dev_irq(id); } } @@ -1942,6 +1944,7 @@ virtio_init(struct vmd_vm *vm, int child_cdrom, int *child_disks, vioscsi->n_blocks = sz >> 11; /* num of 2048 blocks in file */ vioscsi->max_xfer = VIOSCSI_BLOCK_SIZE_CDROM; vioscsi->pci_id = id; + vioscsi->irq = pci_get_dev_irq(id); } /* virtio control device */ @@ -1993,7 +1996,7 @@ vmmci_restore(int fd, uint32_t vm_id) } int -viornd_restore(int fd) +viornd_restore(int fd, struct vm_create_params *vcp) { log_debug("%s: receiving viornd", __func__); if (atomicio(read, fd, &viornd, sizeof(viornd)) != sizeof(viornd)) { @@ -2005,6 +2008,8 @@ viornd_restore(int fd) __progname); return (-1); } + viornd.vm_id = vcp->vcp_id; + return (0); } @@ -2146,7 +2151,7 @@ virtio_restore(int fd, struct vmd_vm *vm, int child_cdrom, int *child_disks, struct vm_create_params *vcp = &vmc->vmc_params; int ret; - if ((ret = viornd_restore(fd)) == -1) + if ((ret = viornd_restore(fd, vcp)) == -1) return ret; if ((ret = vioblk_restore(fd, vcp, child_disks)) == -1) diff --git a/usr.sbin/vmd/virtio.h b/usr.sbin/vmd/virtio.h index 502a619e582..20327f9915c 100644 --- a/usr.sbin/vmd/virtio.h +++ b/usr.sbin/vmd/virtio.h @@ -1,4 +1,4 @@ -/* $OpenBSD: virtio.h,v 1.25 2018/04/26 15:59:12 mlarkin Exp $ */ +/* $OpenBSD: virtio.h,v 1.26 2018/07/09 08:43:09 mlarkin Exp $ */ /* * Copyright (c) 2015 Mike Larkin <mlarkin@openbsd.org> @@ -139,6 +139,8 @@ struct viornd_dev { struct virtio_vq_info vq[VIRTIO_MAX_QUEUES]; uint8_t pci_id; + int irq; + uint32_t vm_id; }; struct vioblk_dev { @@ -151,6 +153,8 @@ struct vioblk_dev { uint32_t max_xfer; uint8_t pci_id; + int irq; + uint32_t vm_id; }; /* vioscsi will use at least 3 queues - 5.6.2 Virtqueues @@ -176,6 +180,8 @@ struct vioscsi_dev { uint32_t max_xfer; uint8_t pci_id; + uint32_t vm_id; + int irq; }; struct vionet_dev { @@ -250,7 +256,7 @@ uint32_t vring_size(uint32_t); int virtio_rnd_io(int, uint16_t, uint32_t *, uint8_t *, void *, uint8_t); int viornd_dump(int); -int viornd_restore(int); +int viornd_restore(int, struct vm_create_params *); void viornd_update_qs(void); void viornd_update_qa(void); int viornd_notifyq(void); diff --git a/usr.sbin/vmd/vmd.h b/usr.sbin/vmd/vmd.h index 27c17edb187..4daf3def8c7 100644 --- a/usr.sbin/vmd/vmd.h +++ b/usr.sbin/vmd/vmd.h @@ -1,4 +1,4 @@ -/* $OpenBSD: vmd.h,v 1.69 2018/06/26 10:00:08 reyk Exp $ */ +/* $OpenBSD: vmd.h,v 1.70 2018/07/09 08:43:09 mlarkin Exp $ */ /* * Copyright (c) 2015 Mike Larkin <mlarkin@openbsd.org> @@ -172,7 +172,7 @@ struct vm_dump_header { #define VM_DUMP_SIGNATURE VMM_HV_SIGNATURE uint8_t vmh_pad[3]; uint8_t vmh_version; -#define VM_DUMP_VERSION 3 +#define VM_DUMP_VERSION 4 struct vm_dump_header_cpuid vmh_cpuids[VM_DUMP_HEADER_CPUID_COUNT]; } __packed; |