1. 07 Jul, 2022 13 commits
  2. 16 May, 2022 6 commits
    • Reinette Chatre's avatar
      x86/sgx: Ensure no data in PCMD page after truncate · e3a3bbe3
      Reinette Chatre authored
      A PCMD (Paging Crypto MetaData) page contains the PCMD
      structures of enclave pages that have been encrypted and
      moved to the shmem backing store. When all enclave pages
      sharing a PCMD page are loaded in the enclave, there is no
      need for the PCMD page and it can be truncated from the
      backing store.
      
      A few issues appeared around the truncation of PCMD pages. The
      known issues have been addressed but the PCMD handling code could
      be made more robust by loudly complaining if any new issue appears
      in this area.
      
      Add a check that will complain with a warning if the PCMD page is not
      actually empty after it has been truncated. There should never be data
      in the PCMD page at this point since it is was just checked to be empty
      and truncated with enclave mutex held and is updated with the
      enclave mutex held.
      Suggested-by: default avatarDave Hansen <dave.hansen@linux.intel.com>
      Signed-off-by: default avatarReinette Chatre <reinette.chatre@intel.com>
      Signed-off-by: default avatarDave Hansen <dave.hansen@linux.intel.com>
      Reviewed-by: default avatarJarkko Sakkinen <jarkko@kernel.org>
      Tested-by: default avatarHaitao Huang <haitao.huang@intel.com>
      Link: https://lkml.kernel.org/r/6495120fed43fafc1496d09dd23df922b9a32709.1652389823.git.reinette.chatre@intel.com
      e3a3bbe3
    • Reinette Chatre's avatar
      x86/sgx: Fix race between reclaimer and page fault handler · af117837
      Reinette Chatre authored
      Haitao reported encountering a WARN triggered by the ENCLS[ELDU]
      instruction faulting with a #GP.
      
      The WARN is encountered when the reclaimer evicts a range of
      pages from the enclave when the same pages are faulted back right away.
      
      Consider two enclave pages (ENCLAVE_A and ENCLAVE_B)
      sharing a PCMD page (PCMD_AB). ENCLAVE_A is in the
      enclave memory and ENCLAVE_B is in the backing store. PCMD_AB contains
      just one entry, that of ENCLAVE_B.
      
      Scenario proceeds where ENCLAVE_A is being evicted from the enclave
      while ENCLAVE_B is faulted in.
      
      sgx_reclaim_pages() {
      
        ...
      
        /*
         * Reclaim ENCLAVE_A
         */
        mutex_lock(&encl->lock);
        /*
         * Get a reference to ENCLAVE_A's
         * shmem page where enclave page
         * encrypted data will be stored
         * as well as a reference to the
         * enclave page's PCMD data page,
         * PCMD_AB.
         * Release mutex before writing
         * any data to the shmem pages.
         */
        sgx_encl_get_backing(...);
        encl_page->desc |= SGX_ENCL_PAGE_BEING_RECLAIMED;
        mutex_unlock(&encl->lock);
      
                                          /*
                                           * Fault ENCLAVE_B
                                           */
      
                                          sgx_vma_fault() {
      
                                            mutex_lock(&encl->lock);
                                            /*
                                             * Get reference to
                                             * ENCLAVE_B's shmem page
                                             * as well as PCMD_AB.
                                             */
                                            sgx_encl_get_backing(...)
                                           /*
                                            * Load page back into
                                            * enclave via ELDU.
                                            */
                                           /*
                                            * Release reference to
                                            * ENCLAVE_B' shmem page and
                                            * PCMD_AB.
                                            */
                                           sgx_encl_put_backing(...);
                                           /*
                                            * PCMD_AB is found empty so
                                            * it and ENCLAVE_B's shmem page
                                            * are truncated.
                                            */
                                           /* Truncate ENCLAVE_B backing page */
                                           sgx_encl_truncate_backing_page();
                                           /* Truncate PCMD_AB */
                                           sgx_encl_truncate_backing_page();
      
                                           mutex_unlock(&encl->lock);
      
                                           ...
                                           }
        mutex_lock(&encl->lock);
        encl_page->desc &=
             ~SGX_ENCL_PAGE_BEING_RECLAIMED;
        /*
        * Write encrypted contents of
        * ENCLAVE_A to ENCLAVE_A shmem
        * page and its PCMD data to
        * PCMD_AB.
        */
        sgx_encl_put_backing(...)
      
        /*
         * Reference to PCMD_AB is
         * dropped and it is truncated.
         * ENCLAVE_A's PCMD data is lost.
         */
        mutex_unlock(&encl->lock);
      }
      
      What happens next depends on whether it is ENCLAVE_A being faulted
      in or ENCLAVE_B being evicted - but both end up with ENCLS[ELDU] faulting
      with a #GP.
      
      If ENCLAVE_A is faulted then at the time sgx_encl_get_backing() is called
      a new PCMD page is allocated and providing the empty PCMD data for
      ENCLAVE_A would cause ENCLS[ELDU] to #GP
      
      If ENCLAVE_B is evicted first then a new PCMD_AB would be allocated by the
      reclaimer but later when ENCLAVE_A is faulted the ENCLS[ELDU] instruction
      would #GP during its checks of the PCMD value and the WARN would be
      encountered.
      
      Noting that the reclaimer sets SGX_ENCL_PAGE_BEING_RECLAIMED at the time
      it obtains a reference to the backing store pages of an enclave page it
      is in the process of reclaiming, fix the race by only truncating the PCMD
      page after ensuring that no page sharing the PCMD page is in the process
      of being reclaimed.
      
      Cc: stable@vger.kernel.org
      Fixes: 08999b24 ("x86/sgx: Free backing memory after faulting the enclave page")
      Reported-by: default avatarHaitao Huang <haitao.huang@intel.com>
      Signed-off-by: default avatarReinette Chatre <reinette.chatre@intel.com>
      Signed-off-by: default avatarDave Hansen <dave.hansen@linux.intel.com>
      Reviewed-by: default avatarJarkko Sakkinen <jarkko@kernel.org>
      Tested-by: default avatarHaitao Huang <haitao.huang@intel.com>
      Link: https://lkml.kernel.org/r/ed20a5db516aa813873268e125680041ae11dfcf.1652389823.git.reinette.chatre@intel.com
      af117837
    • Reinette Chatre's avatar
      x86/sgx: Obtain backing storage page with enclave mutex held · 0e4e729a
      Reinette Chatre authored
      Haitao reported encountering a WARN triggered by the ENCLS[ELDU]
      instruction faulting with a #GP.
      
      The WARN is encountered when the reclaimer evicts a range of
      pages from the enclave when the same pages are faulted back
      right away.
      
      The SGX backing storage is accessed on two paths: when there
      are insufficient free pages in the EPC the reclaimer works
      to move enclave pages to the backing storage and as enclaves
      access pages that have been moved to the backing storage
      they are retrieved from there as part of page fault handling.
      
      An oversubscribed SGX system will often run the reclaimer and
      page fault handler concurrently and needs to ensure that the
      backing store is accessed safely between the reclaimer and
      the page fault handler. This is not the case because the
      reclaimer accesses the backing store without the enclave mutex
      while the page fault handler accesses the backing store with
      the enclave mutex.
      
      Consider the scenario where a page is faulted while a page sharing
      a PCMD page with the faulted page is being reclaimed. The
      consequence is a race between the reclaimer and page fault
      handler, the reclaimer attempting to access a PCMD at the
      same time it is truncated by the page fault handler. This
      could result in lost PCMD data. Data may still be
      lost if the reclaimer wins the race, this is addressed in
      the following patch.
      
      The reclaimer accesses pages from the backing storage without
      holding the enclave mutex and runs the risk of concurrently
      accessing the backing storage with the page fault handler that
      does access the backing storage with the enclave mutex held.
      
      In the scenario below a PCMD page is truncated from the backing
      store after all its pages have been loaded in to the enclave
      at the same time the PCMD page is loaded from the backing store
      when one of its pages are reclaimed:
      
      sgx_reclaim_pages() {              sgx_vma_fault() {
                                           ...
                                           mutex_lock(&encl->lock);
                                           ...
                                           __sgx_encl_eldu() {
                                             ...
                                             if (pcmd_page_empty) {
      /*
       * EPC page being reclaimed              /*
       * shares a PCMD page with an             * PCMD page truncated
       * enclave page that is being             * while requested from
       * faulted in.                            * reclaimer.
       */                                       */
      sgx_encl_get_backing()  <---------->      sgx_encl_truncate_backing_page()
                                              }
                                             mutex_unlock(&encl->lock);
      }                                    }
      
      In this scenario there is a race between the reclaimer and the page fault
      handler when the reclaimer attempts to get access to the same PCMD page
      that is being truncated. This could result in the reclaimer writing to
      the PCMD page that is then truncated, causing the PCMD data to be lost,
      or in a new PCMD page being allocated. The lost PCMD data may still occur
      after protecting the backing store access with the mutex - this is fixed
      in the next patch. By ensuring the backing store is accessed with the mutex
      held the enclave page state can be made accurate with the
      SGX_ENCL_PAGE_BEING_RECLAIMED flag accurately reflecting that a page
      is in the process of being reclaimed.
      
      Consistently protect the reclaimer's backing store access with the
      enclave's mutex to ensure that it can safely run concurrently with the
      page fault handler.
      
      Cc: stable@vger.kernel.org
      Fixes: 1728ab54 ("x86/sgx: Add a page reclaimer")
      Reported-by: default avatarHaitao Huang <haitao.huang@intel.com>
      Signed-off-by: default avatarReinette Chatre <reinette.chatre@intel.com>
      Signed-off-by: default avatarDave Hansen <dave.hansen@linux.intel.com>
      Reviewed-by: default avatarJarkko Sakkinen <jarkko@kernel.org>
      Tested-by: default avatarJarkko Sakkinen <jarkko@kernel.org>
      Tested-by: default avatarHaitao Huang <haitao.huang@intel.com>
      Link: https://lkml.kernel.org/r/fa2e04c561a8555bfe1f4e7adc37d60efc77387b.1652389823.git.reinette.chatre@intel.com
      0e4e729a
    • Reinette Chatre's avatar
      x86/sgx: Mark PCMD page as dirty when modifying contents · 2154e1c1
      Reinette Chatre authored
      Recent commit 08999b24 ("x86/sgx: Free backing memory
      after faulting the enclave page") expanded __sgx_encl_eldu()
      to clear an enclave page's PCMD (Paging Crypto MetaData)
      from the PCMD page in the backing store after the enclave
      page is restored to the enclave.
      
      Since the PCMD page in the backing store is modified the page
      should be marked as dirty to ensure the modified data is retained.
      
      Cc: stable@vger.kernel.org
      Fixes: 08999b24 ("x86/sgx: Free backing memory after faulting the enclave page")
      Signed-off-by: default avatarReinette Chatre <reinette.chatre@intel.com>
      Signed-off-by: default avatarDave Hansen <dave.hansen@linux.intel.com>
      Reviewed-by: default avatarJarkko Sakkinen <jarkko@kernel.org>
      Tested-by: default avatarHaitao Huang <haitao.huang@intel.com>
      Link: https://lkml.kernel.org/r/00cd2ac480db01058d112e347b32599c1a806bc4.1652389823.git.reinette.chatre@intel.com
      2154e1c1
    • Reinette Chatre's avatar
      x86/sgx: Disconnect backing page references from dirty status · 6bd42964
      Reinette Chatre authored
      SGX uses shmem backing storage to store encrypted enclave pages
      and their crypto metadata when enclave pages are moved out of
      enclave memory. Two shmem backing storage pages are associated with
      each enclave page - one backing page to contain the encrypted
      enclave page data and one backing page (shared by a few
      enclave pages) to contain the crypto metadata used by the
      processor to verify the enclave page when it is loaded back into
      the enclave.
      
      sgx_encl_put_backing() is used to release references to the
      backing storage and, optionally, mark both backing store pages
      as dirty.
      
      Managing references and dirty status together in this way results
      in both backing store pages marked as dirty, even if only one of
      the backing store pages are changed.
      
      Additionally, waiting until the page reference is dropped to set
      the page dirty risks a race with the page fault handler that
      may load outdated data into the enclave when a page is faulted
      right after it is reclaimed.
      
      Consider what happens if the reclaimer writes a page to the backing
      store and the page is immediately faulted back, before the reclaimer
      is able to set the dirty bit of the page:
      
      sgx_reclaim_pages() {                    sgx_vma_fault() {
        ...
        sgx_encl_get_backing();
        ...                                      ...
        sgx_reclaimer_write() {
          mutex_lock(&encl->lock);
          /* Write data to backing store */
          mutex_unlock(&encl->lock);
        }
                                                 mutex_lock(&encl->lock);
                                                 __sgx_encl_eldu() {
                                                   ...
                                                   /*
                                                    * Enclave backing store
                                                    * page not released
                                                    * nor marked dirty -
                                                    * contents may not be
                                                    * up to date.
                                                    */
                                                    sgx_encl_get_backing();
                                                    ...
                                                    /*
                                                     * Enclave data restored
                                                     * from backing store
                                                     * and PCMD pages that
                                                     * are not up to date.
                                                     * ENCLS[ELDU] faults
                                                     * because of MAC or PCMD
                                                     * checking failure.
                                                     */
                                                     sgx_encl_put_backing();
                                                  }
                                                  ...
        /* set page dirty */
        sgx_encl_put_backing();
        ...
                                                  mutex_unlock(&encl->lock);
      }                                        }
      
      Remove the option to sgx_encl_put_backing() to set the backing
      pages as dirty and set the needed pages as dirty right after
      receiving important data while enclave mutex is held. This ensures that
      the page fault handler can get up to date data from a page and prepares
      the code for a following change where only one of the backing pages
      need to be marked as dirty.
      
      Cc: stable@vger.kernel.org
      Fixes: 1728ab54 ("x86/sgx: Add a page reclaimer")
      Suggested-by: default avatarDave Hansen <dave.hansen@linux.intel.com>
      Signed-off-by: default avatarReinette Chatre <reinette.chatre@intel.com>
      Signed-off-by: default avatarDave Hansen <dave.hansen@linux.intel.com>
      Reviewed-by: default avatarJarkko Sakkinen <jarkko@kernel.org>
      Tested-by: default avatarHaitao Huang <haitao.huang@intel.com>
      Link: https://lore.kernel.org/linux-sgx/8922e48f-6646-c7cc-6393-7c78dcf23d23@intel.com/
      Link: https://lkml.kernel.org/r/fa9f98986923f43e72ef4c6702a50b2a0b3c42e3.1652389823.git.reinette.chatre@intel.com
      6bd42964
    • Linus Torvalds's avatar
      Linux 5.18-rc7 · 42226c98
      Linus Torvalds authored
      42226c98
  3. 15 May, 2022 8 commits
    • Linus Torvalds's avatar
      Merge tag 'driver-core-5.18-rc7' of... · 0cdd776e
      Linus Torvalds authored
      Merge tag 'driver-core-5.18-rc7' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/driver-core
      
      Pull driver core fixes from Greg KH:
       "Here is one fix, and three documentation updates for 5.18-rc7.
      
        The fix is for the firmware loader which resolves a long-reported
        problem where the credentials of the firmware loader could be set to a
        userspace process without enough permissions to actually load the
        firmware image. Many Android vendors have been reporting this for
        quite some time.
      
        The documentation updates are for the embargoed-hardware-issues.rst
        file to add a new entry, change an existing one, and sort the list to
        make changes easier in the future.
      
        All of these have been in linux-next for a while with no reported
        issues"
      
      * tag 'driver-core-5.18-rc7' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/driver-core:
        Documentation/process: Update ARM contact for embargoed hardware issues
        Documentation/process: Add embargoed HW contact for Ampere Computing
        Documentation/process: Make groups alphabetical and use tabs consistently
        firmware_loader: use kernel credentials when reading firmware
      0cdd776e
    • Linus Torvalds's avatar
      Merge tag 'char-misc-5.18-rc7' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc · 5becde60
      Linus Torvalds authored
      Pull char/misc driver fixes from Greg KH:
       "Here are two small driver fixes for 5.18-rc7 that resolve reported
        problems:
      
         - slimbus driver irq bugfix
      
         - interconnect sync state bugfix
      
        Both of these have been in linux-next with no reported problems"
      
      * tag 'char-misc-5.18-rc7' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc:
        slimbus: qcom: Fix IRQ check in qcom_slim_probe
        interconnect: Restore sync state by ignoring ipa-virt in provider count
      5becde60
    • Linus Torvalds's avatar
      Merge tag 'tty-5.18-rc7' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/tty · 6811a466
      Linus Torvalds authored
      Pull tty/serial driver fixes from Greg KH:
       "Here are some small tty n_gsm and serial driver fixes for 5.18-rc7
        that resolve reported problems. They include:
      
         - n_gsm fixes for reported issues
      
         - 8250_mtk driver fixes for some platforms
      
         - fsl_lpuart driver fix for reported problem.
      
         - digicolor driver fix for reported problem.
      
        All have been in linux-next for a while with no reported problems"
      
      * tag 'tty-5.18-rc7' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/tty:
        fsl_lpuart: Don't enable interrupts too early
        tty: n_gsm: fix invalid gsmtty_write_room() result
        tty: n_gsm: fix mux activation issues in gsm_config()
        tty: n_gsm: fix buffer over-read in gsm_dlci_data()
        serial: 8250_mtk: Fix register address for XON/XOFF character
        serial: 8250_mtk: Make sure to select the right FEATURE_SEL
        serial: 8250_mtk: Fix UART_EFR register address
        tty/serial: digicolor: fix possible null-ptr-deref in digicolor_uart_probe()
      6811a466
    • Linus Torvalds's avatar
      Merge tag 'usb-5.18-rc7' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb · fc49583c
      Linus Torvalds authored
      Pull USB fixes from Greg KH:
       "Here are some small fixes for reported issues with some USB drivers.
        They include:
      
         - xhci fixes for xhci-mtk platform driver
      
         - typec driver fixes for reported problems.
      
         - cdc-wdm read-stuck fix
      
         - gadget driver fix for reported race condition
      
         - new usb-serial driver ids
      
        All of these have been in linux-next with no reported problems"
      
      * tag 'usb-5.18-rc7' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb:
        usb: xhci-mtk: remove bandwidth budget table
        usb: xhci-mtk: fix fs isoc's transfer error
        usb: gadget: fix race when gadget driver register via ioctl
        usb: typec: tcpci_mt6360: Update for BMC PHY setting
        usb: gadget: uvc: allow for application to cleanly shutdown
        usb: typec: tcpci: Don't skip cleanup in .remove() on error
        usb: cdc-wdm: fix reading stuck on device close
        USB: serial: qcserial: add support for Sierra Wireless EM7590
        USB: serial: option: add Fibocom MA510 modem
        USB: serial: option: add Fibocom L610 modem
        USB: serial: pl2303: add device id for HP LM930 Display
      fc49583c
    • Linus Torvalds's avatar
      Merge tag 'powerpc-5.18-5' of git://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux · bc403203
      Linus Torvalds authored
      Pull powerpc fix from Michael Ellerman:
      
       - Fix KVM PR on 32-bit, which was broken by some MMU code refactoring.
      
      Thanks to: Alexander Graf, and Matt Evans.
      
      * tag 'powerpc-5.18-5' of git://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux:
        KVM: PPC: Book3S PR: Enable MSR_DR for switch_mmu_context()
      bc403203
    • Linus Torvalds's avatar
      Merge tag 'x86-urgent-2022-05-15' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 79dc4fc2
      Linus Torvalds authored
      Pull x86 fix from Thomas Gleixner:
       "A single fix for the handling of unpopulated sub-pmd spaces.
      
        The copy & pasta from the corresponding s390 code screwed up the
        address calculation for marking the sub-pmd ranges via memset by
        omitting the ALIGN_DOWN() to calculate the proper start address.
      
        It's a mystery why this code is not generic and shared because there
        is nothing architecture specific in there, but that's too intrusive
        for a backportable fix"
      
      * tag 'x86-urgent-2022-05-15' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/mm: Fix marking of unused sub-pmd ranges
      79dc4fc2
    • Linus Torvalds's avatar
      Merge tag 'sched-urgent-2022-05-15' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 990e798d
      Linus Torvalds authored
      Pull scheduler fix from Thomas Gleixner:
       "The recent expansion of the sched switch tracepoint inserted a new
        argument in the middle of the arguments. This reordering broke BPF
        programs which relied on the old argument list.
      
        While tracepoints are not considered stable ABI, it's not trivial to
        make BPF cope with such a change, but it's being worked on. For now
        restore the original argument order and move the new argument to the
        end of the argument list"
      
      * tag 'sched-urgent-2022-05-15' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        sched/tracing: Append prev_state to tp args instead
      990e798d
    • Linus Torvalds's avatar
      Merge tag 'irq-urgent-2022-05-15' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · fb756280
      Linus Torvalds authored
      Pull irq fix from Thomas Gleixner:
       "A single fix for a recent (introduced in 5.16) regression in the core
        interrupt code.
      
        The consolidation of the interrupt handler invocation code added an
        unconditional warning when generic_handle_domain_irq() is invoked from
        outside hard interrupt context. That's overbroad as the requirement
        for invoking these handlers in hard interrupt context is only required
        for certain interrupt types. The subsequently called code already
        contains a warning which triggers conditionally for interrupt chips
        which indicate this requirement in their properties.
      
        Remove the overbroad one"
      
      * tag 'irq-urgent-2022-05-15' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        genirq: Remove WARN_ON_ONCE() in generic_handle_domain_irq()
      fb756280
  4. 14 May, 2022 1 commit
  5. 13 May, 2022 12 commits
    • Linus Torvalds's avatar
      Merge tag 'drm-fixes-2022-05-14' of git://anongit.freedesktop.org/drm/drm · ec7f4961
      Linus Torvalds authored
      Pull more drm fixes from Dave Airlie:
       "Turns out I was right, some fixes hadn't made it to me yet. The vmwgfx
        ones also popped up later, but all seem like bad enough things to fix.
        The dma-buf, vc4 and nouveau ones are all pretty small.
      
        The fbdev fixes are a bit more complicated: a fix to cleanup fbdev
        devices properly, uncovered some use-after-free bugs in existing
        drivers. Then the fix for those bugs wasn't correct. This reverts that
        fix, and puts the proper fixes in place in the drivers to avoid the
        use-after-frees.
      
        This has had a fair number of eyes on it at this stage, and I'm
        confident enough that it puts things in the right place, and is less
        dangerous than reverting our way out of the initial change at this
        stage.
      
        fbdev:
         - revert NULL deref fix that turned into a use-after-free
         - prevent use-after-free in fbdev
         - efifb/simplefb/vesafb: fix cleanup paths to avoid use-after-frees
      
        dma-buf:
         - fix panic in stats setup
      
        vc4:
         - fix hdmi build
      
        nouveau:
         - tegra iommu present fix
         - fix leak in backlight name
      
        vmwgfx:
         - Black screen due to fences using FIFO checks on SVGA3
         - Random black screens on boot due to uninitialized drm_mode_fb_cmd2
         - Hangs on SVGA3 due to command buffers being used with gbobjects"
      
      * tag 'drm-fixes-2022-05-14' of git://anongit.freedesktop.org/drm/drm:
        drm/vmwgfx: Disable command buffers on svga3 without gbobjects
        drm/vmwgfx: Initialize drm_mode_fb_cmd2
        drm/vmwgfx: Fix fencing on SVGAv3
        drm/vc4: hdmi: Fix build error for implicit function declaration
        dma-buf: call dma_buf_stats_setup after dmabuf is in valid list
        fbdev: efifb: Fix a use-after-free due early fb_info cleanup
        drm/nouveau: Fix a potential theorical leak in nouveau_get_backlight_name()
        drm/nouveau/tegra: Stop using iommu_present()
        fbdev: vesafb: Cleanup fb_info in .fb_destroy rather than .remove
        fbdev: efifb: Cleanup fb_info in .fb_destroy rather than .remove
        fbdev: simplefb: Cleanup fb_info in .fb_destroy rather than .remove
        fbdev: Prevent possible use-after-free in fb_release()
        Revert "fbdev: Make fb_release() return -ENODEV if fbdev was unregistered"
      ec7f4961
    • Dave Airlie's avatar
      Merge tag 'drm-misc-fixes-2022-05-13' of git://anongit.freedesktop.org/drm/drm-misc into drm-fixes · eb7bac39
      Dave Airlie authored
      Multiple fixes to fbdev to address a regression at unregistration, an
      iommu detection improvement for nouveau, a memory leak fix for nouveau,
      pointer dereference fix for dma_buf_file_release(), and a build breakage
      fix for vc4
      Signed-off-by: default avatarDave Airlie <airlied@redhat.com>
      
      From: Maxime Ripard <maxime@cerno.tech>
      Link: https://patchwork.freedesktop.org/patch/msgid/20220513073044.ymayac7x7bzatrt7@houat
      eb7bac39
    • Dave Airlie's avatar
      Merge tag 'vmwgfx-drm-fixes-5.18-2022-05-13' of... · 30c60ba3
      Dave Airlie authored
      Merge tag 'vmwgfx-drm-fixes-5.18-2022-05-13' of https://gitlab.freedesktop.org/zack/vmwgfx into drm-fixes
      
      vmwgfx fixes for:
      - Black screen due to fences using FIFO checks on SVGA3
      - Random black screens on boot due to uninitialized drm_mode_fb_cmd2
      - Hangs on SVGA3 due to command buffers being used with gbobjects
      Signed-off-by: default avatarDave Airlie <airlied@redhat.com>
      From: Zack Rusin <zackr@vmware.com>
      Link: https://patchwork.freedesktop.org/patch/msgid/a1d32799e4c74b8540216376d7576bb783ca07ba.camel@vmware.com
      30c60ba3
    • Linus Torvalds's avatar
      Merge tag 'gfs2-v5.18-rc4-fix3' of git://git.kernel.org/pub/scm/linux/kernel/git/gfs2/linux-gfs2 · d928e8f3
      Linus Torvalds authored
      Pull gfs2 fixes from Andreas Gruenbacher:
       "We've finally identified commit dc732906 ("gfs2: Introduce flag
        for glock holder auto-demotion") to be the other cause of the
        filesystem corruption we've been seeing. This feature isn't strictly
        necessary anymore, so we've decided to stop using it for now.
      
        With this and the gfs_iomap_end rounding fix you've already seen
        ("gfs2: Fix filesystem block deallocation for short writes" in this
        pull request), we're corruption free again now.
      
         - Fix filesystem block deallocation for short writes.
      
         - Stop using glock holder auto-demotion for now.
      
         - Get rid of buffered writes inefficiencies due to page faults being
           disabled.
      
         - Minor other cleanups"
      
      * tag 'gfs2-v5.18-rc4-fix3' of git://git.kernel.org/pub/scm/linux/kernel/git/gfs2/linux-gfs2:
        gfs2: Stop using glock holder auto-demotion for now
        gfs2: buffered write prefaulting
        gfs2: Align read and write chunks to the page cache
        gfs2: Pull return value test out of should_fault_in_pages
        gfs2: Clean up use of fault_in_iov_iter_{read,write}able
        gfs2: Variable rename
        gfs2: Fix filesystem block deallocation for short writes
      d928e8f3
    • Andreas Gruenbacher's avatar
      gfs2: Stop using glock holder auto-demotion for now · e1fa9ea8
      Andreas Gruenbacher authored
      We're having unresolved issues with the glock holder auto-demotion mechanism
      introduced in commit dc732906.  This mechanism was assumed to be essential
      for avoiding frequent short reads and writes until commit 296abc0d
      ("gfs2: No short reads or writes upon glock contention").  Since then,
      when the inode glock is lost, it is simply re-acquired and the operation
      is resumed.  This means that apart from the performance penalty, we
      might as well drop the inode glock before faulting in pages, and
      re-acquire it afterwards.
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      e1fa9ea8
    • Andreas Gruenbacher's avatar
      gfs2: buffered write prefaulting · fa5dfa64
      Andreas Gruenbacher authored
      In gfs2_file_buffered_write, to increase the likelihood that all the
      user memory we're trying to write will be resident in memory, carry out
      the write in chunks and fault in each chunk of user memory before trying
      to write it.  Otherwise, some workloads will trigger frequent short
      "internal" writes, causing filesystem blocks to be allocated and then
      partially deallocated again when writing into holes, which is wasteful
      and breaks reservations.
      
      Neither the chunked writes nor any of the short "internal" writes are
      user visible.
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      fa5dfa64
    • Linus Torvalds's avatar
      Merge tag 'scsi-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi · f2dd0074
      Linus Torvalds authored
      Pull SCSI fixes from James Bottomley:
       "Four fixes, all in drivers.
      
        These patches mosly fix error legs and exceptional conditions
        (scsi_dh_alua, qla2xxx). The lpfc fixes are for coding issues with
        lpfc features"
      
      * tag 'scsi-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi:
        scsi: lpfc: Correct BDE DMA address assignment for GEN_REQ_WQE
        scsi: lpfc: Fix split code for FLOGI on FCoE
        scsi: qla2xxx: Fix missed DMA unmap for aborted commands
        scsi: scsi_dh_alua: Properly handle the ALUA transitioning state
      f2dd0074
    • Andreas Gruenbacher's avatar
      gfs2: Align read and write chunks to the page cache · 324d116c
      Andreas Gruenbacher authored
      Align the chunks that reads and writes are carried out in to the page
      cache rather than the user buffers.  This will be more efficient in
      general, especially for allocating writes.  Optimizing the case that the
      user buffer is gfs2 backed isn't very useful; we only need to make sure
      we won't deadlock.
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      324d116c
    • Andreas Gruenbacher's avatar
      gfs2: Pull return value test out of should_fault_in_pages · 72382264
      Andreas Gruenbacher authored
      Pull the return value test of the previous read or write operation out
      of should_fault_in_pages().  In a following patch, we'll fault in pages
      before the I/O and there will be no return value to check.
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      72382264
    • Andreas Gruenbacher's avatar
      gfs2: Clean up use of fault_in_iov_iter_{read,write}able · 6d22ff47
      Andreas Gruenbacher authored
      No need to store the return value of the fault_in functions in separate
      variables.
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      6d22ff47
    • Andreas Gruenbacher's avatar
      gfs2: Variable rename · 42e4c3bd
      Andreas Gruenbacher authored
      Instead of counting the number of bytes read from the filesystem,
      functions gfs2_file_direct_read and gfs2_file_read_iter count the number
      of bytes written into the user buffer.  Conversely, functions
      gfs2_file_direct_write and gfs2_file_buffered_write count the number of
      bytes read from the user buffer.  This is nothing but confusing, so
      change the read functions to count how many bytes they have read, and
      the write functions to count how many bytes they have written.
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      42e4c3bd
    • Andreas Gruenbacher's avatar
      gfs2: Fix filesystem block deallocation for short writes · d031a886
      Andreas Gruenbacher authored
      When a write cannot be carried out in full, gfs2_iomap_end() releases
      blocks that have been allocated for this write but haven't been used.
      
      To compute the end of the allocation, gfs2_iomap_end() incorrectly
      rounded the end of the attempted write down to the next block boundary
      to arrive at the end of the allocation.  It would have to round up, but
      the end of the allocation is also available as iomap->offset +
      iomap->length, so just use that instead.
      
      In addition, use round_up() for computing the start of the unused range.
      
      Fixes: 64bc06bb ("gfs2: iomap buffered write support")
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      d031a886