diff options
author | Farhan Ali <alifm@linux.ibm.com> | 2019-01-21 17:54:08 +0300 |
---|---|---|
committer | Cornelia Huck <cohuck@redhat.com> | 2019-02-04 18:41:04 +0300 |
commit | 405d566f98ae19ccf624b31b6eccd6039d9cbc39 (patch) | |
tree | 19808a2a066326cebd9d7224105bbb78f5e76206 /drivers/s390/cio/vfio_ccw_cp.c | |
parent | 7dd541a3fb34b34f0f25154dd0d24d0d9b1ca0f3 (diff) | |
download | linux-405d566f98ae19ccf624b31b6eccd6039d9cbc39.tar.xz |
vfio-ccw: Don't assume there are more ccws after a TIC
When trying to calculate the length of a ccw chain, we assume
there are ccws after a TIC. This can lead to overcounting and
copying garbage data from guest memory.
Signed-off-by: Farhan Ali <alifm@linux.ibm.com>
Message-Id: <d63748c1f1b03147bcbf401596638627a5e35ef7.1548082107.git.alifm@linux.ibm.com>
Reviewed-by: Halil Pasic <pasic@linux.ibm.com>
Signed-off-by: Cornelia Huck <cohuck@redhat.com>
Diffstat (limited to 'drivers/s390/cio/vfio_ccw_cp.c')
-rw-r--r-- | drivers/s390/cio/vfio_ccw_cp.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/s390/cio/vfio_ccw_cp.c b/drivers/s390/cio/vfio_ccw_cp.c index 70a006ba4d05..ba08fe137c2e 100644 --- a/drivers/s390/cio/vfio_ccw_cp.c +++ b/drivers/s390/cio/vfio_ccw_cp.c @@ -392,7 +392,7 @@ static int ccwchain_calc_length(u64 iova, struct channel_program *cp) return -EOPNOTSUPP; } - if ((!ccw_is_chain(ccw)) && (!ccw_is_tic(ccw))) + if (!ccw_is_chain(ccw)) break; ccw++; |