Skip to content

Commit

Permalink
sample: vfio-mdev: avoid deadlock in mdev_access()
Browse files Browse the repository at this point in the history
mdev_access() calls mbochs_get_page() with mdev_state->ops_lock held,
while mbochs_get_page() locks the mutex by itself.
It leads to unavoidable deadlock.

Found by Linux Driver Verification project (linuxtesting.org).

Signed-off-by: Alexey Khoroshilov <[email protected]>
Signed-off-by: Alex Williamson <[email protected]>
  • Loading branch information
khoroshilov authored and awilliam committed Jul 11, 2018
1 parent 1e4b044 commit 498e8bf
Showing 1 changed file with 3 additions and 1 deletion.
4 changes: 3 additions & 1 deletion samples/vfio-mdev/mbochs.c
Original file line number Diff line number Diff line change
Expand Up @@ -178,6 +178,8 @@ static const char *vbe_name(u32 index)
return "(invalid)";
}

static struct page *__mbochs_get_page(struct mdev_state *mdev_state,
pgoff_t pgoff);
static struct page *mbochs_get_page(struct mdev_state *mdev_state,
pgoff_t pgoff);

Expand Down Expand Up @@ -394,7 +396,7 @@ static ssize_t mdev_access(struct mdev_device *mdev, char *buf, size_t count,
MBOCHS_MEMORY_BAR_OFFSET + mdev_state->memsize) {
pos -= MBOCHS_MMIO_BAR_OFFSET;
poff = pos & ~PAGE_MASK;
pg = mbochs_get_page(mdev_state, pos >> PAGE_SHIFT);
pg = __mbochs_get_page(mdev_state, pos >> PAGE_SHIFT);
map = kmap(pg);
if (is_write)
memcpy(map + poff, buf, count);
Expand Down

0 comments on commit 498e8bf

Please sign in to comment.