diff options
author | Asias He <asias@redhat.com> | 2013-04-25 03:35:22 -0400 |
---|---|---|
committer | Nicholas Bellinger <nab@linux-iscsi.org> | 2013-04-25 04:07:45 -0400 |
commit | 11c634183961c1f22a44167a676d0610cee3edaa (patch) | |
tree | 6859bbb05a027e080e16389f9ea2c039021466ad | |
parent | a6c9af87363c5e964d981fe0ec4aa73061a0c793 (diff) |
tcm_vhost: Add ioctl to get and set events missed flag
Signed-off-by: Asias He <asias@redhat.com>
Acked-by: Michael S. Tsirkin <mst@redhat.com>
Signed-off-by: Nicholas Bellinger <nab@linux-iscsi.org>
-rw-r--r-- | drivers/vhost/tcm_vhost.c | 17 | ||||
-rw-r--r-- | drivers/vhost/tcm_vhost.h | 3 |
2 files changed, 20 insertions, 0 deletions
diff --git a/drivers/vhost/tcm_vhost.c b/drivers/vhost/tcm_vhost.c index 5340fd759c6e..07217d818ad7 100644 --- a/drivers/vhost/tcm_vhost.c +++ b/drivers/vhost/tcm_vhost.c | |||
@@ -1200,8 +1200,11 @@ static long vhost_scsi_ioctl(struct file *f, unsigned int ioctl, | |||
1200 | struct vhost_scsi_target backend; | 1200 | struct vhost_scsi_target backend; |
1201 | void __user *argp = (void __user *)arg; | 1201 | void __user *argp = (void __user *)arg; |
1202 | u64 __user *featurep = argp; | 1202 | u64 __user *featurep = argp; |
1203 | u32 __user *eventsp = argp; | ||
1204 | u32 events_missed; | ||
1203 | u64 features; | 1205 | u64 features; |
1204 | int r, abi_version = VHOST_SCSI_ABI_VERSION; | 1206 | int r, abi_version = VHOST_SCSI_ABI_VERSION; |
1207 | struct vhost_virtqueue *vq = &vs->vqs[VHOST_SCSI_VQ_EVT]; | ||
1205 | 1208 | ||
1206 | switch (ioctl) { | 1209 | switch (ioctl) { |
1207 | case VHOST_SCSI_SET_ENDPOINT: | 1210 | case VHOST_SCSI_SET_ENDPOINT: |
@@ -1222,6 +1225,20 @@ static long vhost_scsi_ioctl(struct file *f, unsigned int ioctl, | |||
1222 | if (copy_to_user(argp, &abi_version, sizeof abi_version)) | 1225 | if (copy_to_user(argp, &abi_version, sizeof abi_version)) |
1223 | return -EFAULT; | 1226 | return -EFAULT; |
1224 | return 0; | 1227 | return 0; |
1228 | case VHOST_SCSI_SET_EVENTS_MISSED: | ||
1229 | if (get_user(events_missed, eventsp)) | ||
1230 | return -EFAULT; | ||
1231 | mutex_lock(&vq->mutex); | ||
1232 | vs->vs_events_missed = events_missed; | ||
1233 | mutex_unlock(&vq->mutex); | ||
1234 | return 0; | ||
1235 | case VHOST_SCSI_GET_EVENTS_MISSED: | ||
1236 | mutex_lock(&vq->mutex); | ||
1237 | events_missed = vs->vs_events_missed; | ||
1238 | mutex_unlock(&vq->mutex); | ||
1239 | if (put_user(events_missed, eventsp)) | ||
1240 | return -EFAULT; | ||
1241 | return 0; | ||
1225 | case VHOST_GET_FEATURES: | 1242 | case VHOST_GET_FEATURES: |
1226 | features = VHOST_SCSI_FEATURES; | 1243 | features = VHOST_SCSI_FEATURES; |
1227 | if (copy_to_user(featurep, &features, sizeof features)) | 1244 | if (copy_to_user(featurep, &features, sizeof features)) |
diff --git a/drivers/vhost/tcm_vhost.h b/drivers/vhost/tcm_vhost.h index a545a5b766a3..514b9fda230e 100644 --- a/drivers/vhost/tcm_vhost.h +++ b/drivers/vhost/tcm_vhost.h | |||
@@ -123,3 +123,6 @@ struct vhost_scsi_target { | |||
123 | #define VHOST_SCSI_CLEAR_ENDPOINT _IOW(VHOST_VIRTIO, 0x41, struct vhost_scsi_target) | 123 | #define VHOST_SCSI_CLEAR_ENDPOINT _IOW(VHOST_VIRTIO, 0x41, struct vhost_scsi_target) |
124 | /* Changing this breaks userspace. */ | 124 | /* Changing this breaks userspace. */ |
125 | #define VHOST_SCSI_GET_ABI_VERSION _IOW(VHOST_VIRTIO, 0x42, int) | 125 | #define VHOST_SCSI_GET_ABI_VERSION _IOW(VHOST_VIRTIO, 0x42, int) |
126 | /* Set and get the events missed flag */ | ||
127 | #define VHOST_SCSI_SET_EVENTS_MISSED _IOW(VHOST_VIRTIO, 0x43, __u32) | ||
128 | #define VHOST_SCSI_GET_EVENTS_MISSED _IOW(VHOST_VIRTIO, 0x44, __u32) | ||