1. 12 Feb, 2021 1 commit
  2. 10 Feb, 2021 13 commits
  3. 05 Feb, 2021 2 commits
  4. 04 Feb, 2021 1 commit
    • Andy Lutomirski's avatar
      x86/ptrace: Clean up PTRACE_GETREGS/PTRACE_PUTREGS regset selection · f22fecaf
      Andy Lutomirski authored
      task_user_regset_view() has nonsensical semantics, but those semantics
      appear to be relied on by existing users of PTRACE_GETREGSET and
      PTRACE_SETREGSET.  (See added comments below for details.)
      
      It shouldn't be used for PTRACE_GETREGS or PTRACE_SETREGS, though. A
      native 64-bit ptrace() call and an x32 ptrace() call using GETREGS
      or SETREGS wants the 64-bit regset views, and a 32-bit ptrace() call
      (native or compat) should use the 32-bit regset.
      
      task_user_regset_view() almost does this except that it will
      malfunction if a ptracer is itself ptraced and the outer ptracer
      modifies CS on entry to a ptrace() syscall.  Hopefully that has never
      happened.  (The compat ptrace() code already hardcoded the 32-bit
      regset, so this change has no effect on that path.)
      
      Improve the situation and deobfuscate the code by hardcoding the
      64-bit view in the x32 ptrace() and selecting the view based on the
      kernel config in the native ptrace().
      
      I tried to figure out the history behind this API. I naïvely assumed
      that PTRAGE_GETREGSET and PTRACE_SETREGSET were ancient APIs that
      predated compat, but no. They were introduced by
      
        2225a122 ("ptrace: Add support for generic PTRACE_GETREGSET/PTRACE_SETREGSET")
      
      in 2010, and they are simply a poor design.  ELF core dumps have the
      ELF e_machine field and a bunch of register sets in ELF notes, and the
      pair (e_machine, NT_XXX) indicates the format of the regset blob.  But
      the new PTRACE_GET/SETREGSET API coopted the NT_XXX numbering without
      any way to specify which e_machine was in effect.  This is especially
      bad on x86, where a process can freely switch between 32-bit and
      64-bit mode, and, in fact, the PTRAGE_SETREGSET call itself can cause
      this switch to happen.  Oops.
      Signed-off-by: default avatarAndy Lutomirski <luto@kernel.org>
      Signed-off-by: default avatarBorislav Petkov <bp@suse.de>
      Link: https://lkml.kernel.org/r/9daa791d0c7eaebd59c5bc2b2af1b0e7bebe707d.1612375698.git.luto@kernel.org
      f22fecaf
  5. 21 Jan, 2021 1 commit
  6. 15 Jan, 2021 1 commit
  7. 12 Jan, 2021 1 commit
  8. 08 Jan, 2021 1 commit
  9. 05 Jan, 2021 1 commit
  10. 04 Jan, 2021 1 commit
    • Lorenzo Stoakes's avatar
      x86/mm: Increase pgt_buf size for 5-level page tables · 167dcfc0
      Lorenzo Stoakes authored
      pgt_buf is used to allocate page tables on initial direct page mapping
      which bootstraps the kernel into being able to allocate these before the
      direct mapping makes further pages available.
      
      INIT_PGD_PAGE_COUNT is set to 6 pages (doubled for KASLR) - 3 (PUD, PMD,
      PTE) for the 1 MiB ISA mapping and 3 more for the first direct mapping
      assignment in each case providing 2 MiB of address space.
      
      This has not been updated for 5-level page tables which has an
      additional P4D page table level above PUD.
      
      In most instances, this will not have a material impact as the first
      4 page levels allocated for the ISA mapping will provide sufficient
      address space to encompass all further address mappings.
      
      If the first direct mapping is within 512 GiB of the ISA mapping, only
      a PMD and PTE needs to be added in the instance the kernel is using 4
      KiB page tables (e.g. CONFIG_DEBUG_PAGEALLOC is enabled) and only a PMD
      if the kernel can use 2 MiB pages (the first allocation is limited to
      PMD_SIZE so a GiB page cannot be used there).
      
      However, if the machine has more than 512 GiB of RAM and the kernel is
      allocating 4 KiB page size, 3 further page tables are required.
      
      If the machine has more than 256 TiB of RAM at 4 KiB or 2 MiB page size,
      further 3 or 4 page tables are required respectively.
      
      Update INIT_PGD_PAGE_COUNT to reflect this.
      
       [ bp: Sanitize text into passive voice without ambiguous personal pronouns. ]
      Signed-off-by: default avatarLorenzo Stoakes <lstoakes@gmail.com>
      Signed-off-by: default avatarBorislav Petkov <bp@suse.de>
      Acked-by: default avatarKirill A. Shutemov <kirill.shutemov@linux.intel.com>
      Acked-by: default avatarDave Hansen <dave.hansen@intel.com>
      Link: https://lkml.kernel.org/r/20201215205641.34096-1-lstoakes@gmail.com
      167dcfc0
  11. 03 Jan, 2021 1 commit
  12. 02 Jan, 2021 3 commits
    • Linus Torvalds's avatar
      Merge tag 's390-5.11-3' of git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux · 3516bd72
      Linus Torvalds authored
      Pull s390 cleanups from Vasily Gorbik:
       "Update defconfigs and sort config select list"
      
      * tag 's390-5.11-3' of git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux:
        s390/Kconfig: sort config S390 select list once again
        s390: update defconfigs
      3516bd72
    • Linus Torvalds's avatar
      Merge tag 'pm-5.11-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm · d9296a7b
      Linus Torvalds authored
      Pull power management fixes from Rafael Wysocki:
       "These fix a crash in intel_pstate during resume from suspend-to-RAM
        that may occur after recent changes and two resource leaks in error
        paths in the operating performance points (OPP) framework, add a new
        C-states table to intel_idle and update the cpuidle MAINTAINERS entry
        to cover the governors too.
      
        Specifics:
      
         - Fix recently introduced crash in the intel_pstate driver that
           occurs if scale-invariance is disabled during resume from
           suspend-to-RAM due to inconsistent changes of APERF or MPERF MSR
           values made by the platform firmware (Rafael Wysocki).
      
         - Fix a memory leak and add a missing clk_put() in error paths in the
           OPP framework (Quanyang Wang, Viresh Kumar).
      
         - Add new C-states table for SnowRidge processors to the intel_idle
           driver (Artem Bityutskiy).
      
         - Update the MAINTAINERS entry for cpuidle to make it clear that the
           governors are covered by it too (Lukas Bulwahn)"
      
      * tag 'pm-5.11-rc2' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm:
        intel_idle: add SnowRidge C-state table
        cpufreq: intel_pstate: Fix fast-switch fallback path
        opp: Call the missing clk_put() on error
        opp: fix memory leak in _allocate_opp_table
        MAINTAINERS: include governors into CPU IDLE TIME MANAGEMENT FRAMEWORK
      d9296a7b
    • Rafael J. Wysocki's avatar
      Merge branches 'pm-cpufreq' and 'pm-cpuidle' · 89ecf09e
      Rafael J. Wysocki authored
      * pm-cpufreq:
        cpufreq: intel_pstate: Fix fast-switch fallback path
      
      * pm-cpuidle:
        intel_idle: add SnowRidge C-state table
        MAINTAINERS: include governors into CPU IDLE TIME MANAGEMENT FRAMEWORK
      89ecf09e
  13. 01 Jan, 2021 4 commits
    • Linus Torvalds's avatar
      Merge tag 'scsi-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi · eda809ae
      Linus Torvalds authored
      Pull SCSI fixes from James Bottomley:
       "This is a load of driver fixes (12 ufs, 1 mpt3sas, 1 cxgbi).
      
        The big core two fixes are for power management ("block: Do not accept
        any requests while suspended" and "block: Fix a race in the runtime
        power management code") which finally sorts out the resume problems
        we've occasionally been having.
      
        To make the resume fix, there are seven necessary precursors which
        effectively renames REQ_PREEMPT to REQ_PM, so every "special" request
        in block is automatically a power management exempt one.
      
        All of the non-PM preempt cases are removed except for the one in the
        SCSI Parallel Interface (spi) domain validation which is a genuine
        case where we have to run requests at high priority to validate the
        bus so this becomes an autopm get/put protected request"
      
      * tag 'scsi-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi: (22 commits)
        scsi: cxgb4i: Fix TLS dependency
        scsi: ufs: Un-inline ufshcd_vops_device_reset function
        scsi: ufs: Re-enable WriteBooster after device reset
        scsi: ufs-mediatek: Use correct path to fix compile error
        scsi: mpt3sas: Signedness bug in _base_get_diag_triggers()
        scsi: block: Do not accept any requests while suspended
        scsi: block: Remove RQF_PREEMPT and BLK_MQ_REQ_PREEMPT
        scsi: core: Only process PM requests if rpm_status != RPM_ACTIVE
        scsi: scsi_transport_spi: Set RQF_PM for domain validation commands
        scsi: ide: Mark power management requests with RQF_PM instead of RQF_PREEMPT
        scsi: ide: Do not set the RQF_PREEMPT flag for sense requests
        scsi: block: Introduce BLK_MQ_REQ_PM
        scsi: block: Fix a race in the runtime power management code
        scsi: ufs-pci: Enable UFSHCD_CAP_RPM_AUTOSUSPEND for Intel controllers
        scsi: ufs-pci: Fix recovery from hibernate exit errors for Intel controllers
        scsi: ufs-pci: Ensure UFS device is in PowerDown mode for suspend-to-disk ->poweroff()
        scsi: ufs-pci: Fix restore from S4 for Intel controllers
        scsi: ufs-mediatek: Keep VCC always-on for specific devices
        scsi: ufs: Allow regulators being always-on
        scsi: ufs: Clear UAC for RPMB after ufshcd resets
        ...
      eda809ae
    • Linus Torvalds's avatar
      Merge tag 'block-5.11-2021-01-01' of git://git.kernel.dk/linux-block · 8b4805c6
      Linus Torvalds authored
      Pull block fixes from Jens Axboe:
       "Two minor block fixes from this last week that should go into 5.11:
      
         - Add missing NOWAIT debugfs definition (Andres)
      
         - Fix kerneldoc warning introduced this merge window (Randy)"
      
      * tag 'block-5.11-2021-01-01' of git://git.kernel.dk/linux-block:
        block: add debugfs stanza for QUEUE_FLAG_NOWAIT
        fs: block_dev.c: fix kernel-doc warnings from struct block_device changes
      8b4805c6
    • Linus Torvalds's avatar
      Merge tag 'io_uring-5.11-2021-01-01' of git://git.kernel.dk/linux-block · dc3e24b2
      Linus Torvalds authored
      Pull io_uring fixes from Jens Axboe:
       "A few fixes that should go into 5.11, all marked for stable as well:
      
         - Fix issue around identity COW'ing and users that share a ring
           across processes
      
         - Fix a hang associated with unregistering fixed files (Pavel)
      
         - Move the 'process is exiting' cancelation a bit earlier, so
           task_works aren't affected by it (Pavel)"
      
      * tag 'io_uring-5.11-2021-01-01' of git://git.kernel.dk/linux-block:
        kernel/io_uring: cancel io_uring before task works
        io_uring: fix io_sqe_files_unregister() hangs
        io_uring: add a helper for setting a ref node
        io_uring: don't assume mm is constant across submits
      dc3e24b2
    • Linus Torvalds's avatar
      depmod: handle the case of /sbin/depmod without /sbin in PATH · cedd1862
      Linus Torvalds authored
      Commit 436e980e ("kbuild: don't hardcode depmod path") stopped
      hard-coding the path of depmod, but in the process caused trouble for
      distributions that had that /sbin location, but didn't have it in the
      PATH (generally because /sbin is limited to the super-user path).
      
      Work around it for now by just adding /sbin to the end of PATH in the
      depmod.sh script.
      Reported-and-tested-by: default avatarSedat Dilek <sedat.dilek@gmail.com>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      cedd1862
  14. 31 Dec, 2020 3 commits
  15. 30 Dec, 2020 6 commits