1. 29 4月, 2020 1 次提交
  2. 27 3月, 2020 1 次提交
  3. 04 3月, 2020 1 次提交
  4. 28 2月, 2020 1 次提交
  5. 07 1月, 2020 2 次提交
  6. 23 12月, 2019 3 次提交
  7. 22 11月, 2019 1 次提交
  8. 16 10月, 2019 1 次提交
  9. 15 10月, 2019 2 次提交
  10. 11 9月, 2019 1 次提交
  11. 17 8月, 2019 1 次提交
  12. 07 6月, 2019 1 次提交
  13. 27 5月, 2019 2 次提交
  14. 21 5月, 2019 1 次提交
  15. 03 5月, 2019 1 次提交
    • J
      iommu/dma-iommu: Split iommu_dma_map_msi_msg() in two parts · ece6e6f0
      Julien Grall 提交于
      On RT, iommu_dma_map_msi_msg() may be called from non-preemptible
      context. This will lead to a splat with CONFIG_DEBUG_ATOMIC_SLEEP as
      the function is using spin_lock (they can sleep on RT).
      
      iommu_dma_map_msi_msg() is used to map the MSI page in the IOMMU PT
      and update the MSI message with the IOVA.
      
      Only the part to lookup for the MSI page requires to be called in
      preemptible context. As the MSI page cannot change over the lifecycle
      of the MSI interrupt, the lookup can be cached and re-used later on.
      
      iomma_dma_map_msi_msg() is now split in two functions:
          - iommu_dma_prepare_msi(): This function will prepare the mapping
          in the IOMMU and store the cookie in the structure msi_desc. This
          function should be called in preemptible context.
          - iommu_dma_compose_msi_msg(): This function will update the MSI
          message with the IOVA when the device is behind an IOMMU.
      Signed-off-by: NJulien Grall <julien.grall@arm.com>
      Reviewed-by: NRobin Murphy <robin.murphy@arm.com>
      Reviewed-by: NEric Auger <eric.auger@redhat.com>
      Acked-by: NJoerg Roedel <jroedel@suse.de>
      Signed-off-by: NMarc Zyngier <marc.zyngier@arm.com>
      ece6e6f0
  16. 05 4月, 2019 1 次提交
    • D
      iommu/arm-smmu: Break insecure users by disabling bypass by default · 954a03be
      Douglas Anderson 提交于
      If you're bisecting why your peripherals stopped working, it's
      probably this CL.  Specifically if you see this in your dmesg:
        Unexpected global fault, this could be serious
      ...then it's almost certainly this CL.
      
      Running your IOMMU-enabled peripherals with the IOMMU in bypass mode
      is insecure and effectively disables the protection they provide.
      There are few reasons to allow unmatched stream bypass, and even fewer
      good ones.
      
      This patch starts the transition over to make it much harder to run
      your system insecurely.  Expected steps:
      
      1. By default disable bypass (so anyone insecure will notice) but make
         it easy for someone to re-enable bypass with just a KConfig change.
         That's this patch.
      
      2. After people have had a little time to come to grips with the fact
         that they need to set their IOMMUs properly and have had time to
         dig into how to do this, the KConfig will be eliminated and bypass
         will simply be disabled.  Folks who are truly upset and still
         haven't fixed their system can either figure out how to add
         'arm-smmu.disable_bypass=n' to their command line or revert the
         patch in their own private kernel.  Of course these folks will be
         less secure.
      Suggested-by: NRobin Murphy <robin.murphy@arm.com>
      Reviewed-by: NMarc Gonzalez <marc.w.gonzalez@free.fr>
      Tested-by: NMarc Gonzalez <marc.w.gonzalez@free.fr>
      Signed-off-by: NDouglas Anderson <dianders@chromium.org>
      Signed-off-by: NWill Deacon <will.deacon@arm.com>
      954a03be
  17. 28 2月, 2019 1 次提交
    • L
      iommu/hyper-v: Add Hyper-V stub IOMMU driver · 29217a47
      Lan Tianyu 提交于
      On the bare metal, enabling X2APIC mode requires interrupt remapping
      function which helps to deliver irq to cpu with 32-bit APIC ID.
      Hyper-V doesn't provide interrupt remapping function so far and Hyper-V
      MSI protocol already supports to deliver interrupt to the CPU whose
      virtual processor index is more than 255. IO-APIC interrupt still has
      8-bit APIC ID limitation.
      
      This patch is to add Hyper-V stub IOMMU driver in order to enable
      X2APIC mode successfully in Hyper-V Linux guest. The driver returns X2APIC
      interrupt remapping capability when X2APIC mode is available. Otherwise,
      it creates a Hyper-V irq domain to limit IO-APIC interrupts' affinity
      and make sure cpus assigned with IO-APIC interrupt have 8-bit APIC ID.
      
      Define 24 IO-APIC remapping entries because Hyper-V only expose one
      single IO-APIC and one IO-APIC has 24 pins according IO-APIC spec(
      https://pdos.csail.mit.edu/6.828/2016/readings/ia32/ioapic.pdf).
      Reviewed-by: NMichael Kelley <mikelley@microsoft.com>
      Signed-off-by: NLan Tianyu <Tianyu.Lan@microsoft.com>
      Signed-off-by: NJoerg Roedel <jroedel@suse.de>
      29217a47
  18. 16 1月, 2019 1 次提交
  19. 11 1月, 2019 1 次提交
  20. 27 9月, 2018 1 次提交
    • T
      s390: vfio-ap: base implementation of VFIO AP device driver · 1fde5734
      Tony Krowiak 提交于
      Introduces a new AP device driver. This device driver
      is built on the VFIO mediated device framework. The framework
      provides sysfs interfaces that facilitate passthrough
      access by guests to devices installed on the linux host.
      
      The VFIO AP device driver will serve two purposes:
      
      1. Provide the interfaces to reserve AP devices for exclusive
         use by KVM guests. This is accomplished by unbinding the
         devices to be reserved for guest usage from the zcrypt
         device driver and binding them to the VFIO AP device driver.
      
      2. Implements the functions, callbacks and sysfs attribute
         interfaces required to create one or more VFIO mediated
         devices each of which will be used to configure the AP
         matrix for a guest and serve as a file descriptor
         for facilitating communication between QEMU and the
         VFIO AP device driver.
      
      When the VFIO AP device driver is initialized:
      
      * It registers with the AP bus for control of type 10 (CEX4
        and newer) AP queue devices. This limitation was imposed
        due to:
      
        1. A desire to keep the code as simple as possible;
      
        2. Some older models are no longer supported by the kernel
           and others are getting close to end of service.
      
        3. A lack of older systems on which to test older devices.
      
        The probe and remove callbacks will be provided to support
        the binding/unbinding of AP queue devices to/from the VFIO
        AP device driver.
      
      * Creates a matrix device, /sys/devices/vfio_ap/matrix,
        to serve as the parent of the mediated devices created, one
        for each guest, and to hold the APQNs of the AP devices bound to
        the VFIO AP device driver.
      Signed-off-by: NTony Krowiak <akrowiak@linux.ibm.com>
      Reviewed-by: NHalil Pasic <pasic@linux.ibm.com>
      Tested-by: NMichael Mueller <mimu@linux.ibm.com>
      Tested-by: NFarhan Ali <alifm@linux.ibm.com>
      Acked-by: NDavid Hildenbrand <david@redhat.com>
      Reviewed-by: NCornelia Huck <cohuck@redhat.com>
      Message-Id: <20180925231641.4954-5-akrowiak@linux.vnet.ibm.com>
      Signed-off-by: NChristian Borntraeger <borntraeger@de.ibm.com>
      1fde5734
  21. 25 9月, 2018 1 次提交
  22. 27 7月, 2018 2 次提交
  23. 06 7月, 2018 3 次提交
  24. 12 6月, 2018 1 次提交
    • L
      Revert "iommu/amd_iommu: Use CONFIG_DMA_DIRECT_OPS=y and dma_direct_{alloc,free}()" · e16c4790
      Linus Torvalds 提交于
      This reverts commit b468620f.
      
      It turns out that this broke drm on AMD platforms. Quoting Gabriel C:
       "I can confirm reverting b468620f fixes
        that issue for me.
      
        The GPU is working fine with SME enabled.
      
        Now with working GPU :) I can also confirm performance is back to
        normal without doing any other workarounds"
      
      Christan König analyzed it partially:
       "As far as I analyzed it we now get an -ENOMEM from dma_alloc_attrs()
        in drivers/gpu/drm/ttm/ttm_page_alloc_dma.c when IOMMU is enabled"
      
      and Christoph Hellwig responded:
       "I think the prime issue is that dma_direct_alloc respects the dma
        mask. Which we don't need if actually using the iommu. This would be
        mostly harmless exept for the the SEV bit high in the address that
        makes the checks fail.
      
        For now I'd say revert this commit for 4.17/4.18-rc and I'll look into
        addressing these issues properly"
      Reported-and-bisected-by: NGabriel C <nix.or.die@gmail.com>
      Acked-by: NChristoph Hellwig <hch@lst.de>
      Cc: Christian König <christian.koenig@amd.com>
      Cc: Michel Dänzer <michel.daenzer@amd.com>
      Cc: Joerg Roedel <jroedel@suse.de>
      Cc: Tom Lendacky <thomas.lendacky@amd.com>
      Cc: Andrew Morton <akpm@linux-foundation.org>
      Cc: stable@kernel.org		# v4.17
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      e16c4790
  25. 09 5月, 2018 1 次提交
  26. 03 5月, 2018 1 次提交
  27. 20 3月, 2018 2 次提交
  28. 19 9月, 2017 2 次提交
    • G
      iommu/qcom: Depend on HAS_DMA to fix compile error · 986a5f70
      Geert Uytterhoeven 提交于
      If NO_DMA=y:
      
          warning: (IPMMU_VMSA && ARM_SMMU && ARM_SMMU_V3 && QCOM_IOMMU) selects IOMMU_IO_PGTABLE_LPAE which has unmet direct dependencies (IOMMU_SUPPORT && HAS_DMA && (ARM || ARM64 || COMPILE_TEST && !GENERIC_ATOMIC64))
      
      and
      
          drivers/iommu/io-pgtable-arm.o: In function `__arm_lpae_sync_pte':
          io-pgtable-arm.c:(.text+0x206): undefined reference to `bad_dma_ops'
          drivers/iommu/io-pgtable-arm.o: In function `__arm_lpae_free_pages':
          io-pgtable-arm.c:(.text+0x6a6): undefined reference to `bad_dma_ops'
          drivers/iommu/io-pgtable-arm.o: In function `__arm_lpae_alloc_pages':
          io-pgtable-arm.c:(.text+0x812): undefined reference to `bad_dma_ops'
          io-pgtable-arm.c:(.text+0x81c): undefined reference to `bad_dma_ops'
          io-pgtable-arm.c:(.text+0x862): undefined reference to `bad_dma_ops'
          drivers/iommu/io-pgtable-arm.o: In function `arm_lpae_run_tests':
          io-pgtable-arm.c:(.init.text+0x86): undefined reference to `alloc_io_pgtable_ops'
          io-pgtable-arm.c:(.init.text+0x47c): undefined reference to `free_io_pgtable_ops'
          drivers/iommu/qcom_iommu.o: In function `qcom_iommu_init_domain':
          qcom_iommu.c:(.text+0x1ce): undefined reference to `alloc_io_pgtable_ops'
          drivers/iommu/qcom_iommu.o: In function `qcom_iommu_domain_free':
          qcom_iommu.c:(.text+0x754): undefined reference to `free_io_pgtable_ops'
      
      QCOM_IOMMU selects IOMMU_IO_PGTABLE_LPAE, which bypasses its dependency
      on HAS_DMA.  Make QCOM_IOMMU depend on HAS_DMA to fix this.
      
      Fixes: 0ae349a0 ("iommu/qcom: Add qcom_iommu")
      Signed-off-by: NGeert Uytterhoeven <geert@linux-m68k.org>
      Signed-off-by: NJoerg Roedel <jroedel@suse.de>
      986a5f70
    • G
      iommu: Add missing dependencies · a4aaeccc
      Guenter Roeck 提交于
      parisc:allmodconfig, xtensa:allmodconfig, and possibly others generate
      the following Kconfig warning.
      
      warning: (IPMMU_VMSA && ARM_SMMU && ARM_SMMU_V3 && QCOM_IOMMU) selects
      IOMMU_IO_PGTABLE_LPAE which has unmet direct dependencies (IOMMU_SUPPORT &&
      HAS_DMA && (ARM || ARM64 || COMPILE_TEST && !GENERIC_ATOMIC64))
      
      IOMMU_IO_PGTABLE_LPAE depends on (COMPILE_TEST && !GENERIC_ATOMIC64),
      so any configuration option selecting it needs to have the same dependencies.
      Signed-off-by: NGuenter Roeck <linux@roeck-us.net>
      Signed-off-by: NJoerg Roedel <jroedel@suse.de>
      a4aaeccc
  29. 15 8月, 2017 2 次提交