summaryrefslogtreecommitdiffstats
path: root/drivers/net/hyperv/netvsc.c
diff options
context:
space:
mode:
authorAlex Williamson <alex.williamson@redhat.com>2019-04-03 12:36:21 -0600
committerAlex Williamson <alex.williamson@redhat.com>2019-04-03 12:43:05 -0600
commit492855939bdb59c6f947b0b5b44af9ad82b7e38c (patch)
tree3e003ed3ff3042311258910a713a48b6aea9abe9 /drivers/net/hyperv/netvsc.c
parente39dd513d5f2ae2041c593d42fd0d8b24e7e950b (diff)
downloadblackbird-op-linux-492855939bdb59c6f947b0b5b44af9ad82b7e38c.tar.gz
blackbird-op-linux-492855939bdb59c6f947b0b5b44af9ad82b7e38c.zip
vfio/type1: Limit DMA mappings per container
Memory backed DMA mappings are accounted against a user's locked memory limit, including multiple mappings of the same memory. This accounting bounds the number of such mappings that a user can create. However, DMA mappings that are not backed by memory, such as DMA mappings of device MMIO via mmaps, do not make use of page pinning and therefore do not count against the user's locked memory limit. These mappings still consume memory, but the memory is not well associated to the process for the purpose of oom killing a task. To add bounding on this use case, we introduce a limit to the total number of concurrent DMA mappings that a user is allowed to create. This limit is exposed as a tunable module option where the default value of 64K is expected to be well in excess of any reasonable use case (a large virtual machine configuration would typically only make use of tens of concurrent mappings). This fixes CVE-2019-3882. Reviewed-by: Eric Auger <eric.auger@redhat.com> Tested-by: Eric Auger <eric.auger@redhat.com> Reviewed-by: Peter Xu <peterx@redhat.com> Reviewed-by: Cornelia Huck <cohuck@redhat.com> Signed-off-by: Alex Williamson <alex.williamson@redhat.com>
Diffstat (limited to 'drivers/net/hyperv/netvsc.c')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud