1. 17 Jun, 2021 17 commits
    • Zhen Lei's avatar
      um: fix error return code in winch_tramp() · ccf1236e
      Zhen Lei authored
      Fix to return a negative error code from the error handling case instead
      of 0, as done elsewhere in this function.
      
      Fixes: 89df6bfc ("uml: DEBUG_SHIRQ fixes")
      Reported-by: default avatarHulk Robot <hulkci@huawei.com>
      Signed-off-by: default avatarZhen Lei <thunder.leizhen@huawei.com>
      Acked-By: anton.ivanov@cambridgegreys.com
      Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
      ccf1236e
    • Zhen Lei's avatar
      um: fix error return code in slip_open() · b77e81fb
      Zhen Lei authored
      Fix to return a negative error code from the error handling case instead
      of 0, as done elsewhere in this function.
      
      Fixes: a3c77c67 ("[PATCH] uml: slirp and slip driver cleanups and fixes")
      Reported-by: default avatarHulk Robot <hulkci@huawei.com>
      Signed-off-by: default avatarZhen Lei <thunder.leizhen@huawei.com>
      Acked-By: anton.ivanov@cambridgegreys.com
      Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
      b77e81fb
    • YiFei Zhu's avatar
      um: Fix stack pointer alignment · 558f9b2f
      YiFei Zhu authored
      GCC assumes that stack is aligned to 16-byte on call sites [1].
      Since GCC 8, GCC began using 16-byte aligned SSE instructions to
      implement assignments to structs on stack. When
      CC_OPTIMIZE_FOR_PERFORMANCE is enabled, this affects
      os-Linux/sigio.c, write_sigio_thread:
      
        struct pollfds *fds, tmp;
        tmp = current_poll;
      
      Note that struct pollfds is exactly 16 bytes in size.
      GCC 8+ generates assembly similar to:
      
        movdqa (%rdi),%xmm0
        movaps %xmm0,-0x50(%rbp)
      
      This is an issue, because movaps will #GP if -0x50(%rbp) is not
      aligned to 16 bytes [2], and how rbp gets assigned to is via glibc
      clone thread_start, then function prologue, going though execution
      trace similar to (showing only relevant instructions):
      
        sub    $0x10,%rsi
        mov    %rcx,0x8(%rsi)
        mov    %rdi,(%rsi)
        syscall
        pop    %rax
        pop    %rdi
        callq  *%rax
        push   %rbp
        mov    %rsp,%rbp
      
      The stack pointer always points to the topmost element on stack,
      rather then the space right above the topmost. On push, the
      pointer decrements first before writing to the memory pointed to
      by it. Therefore, there is no need to have the stack pointer
      pointer always point to valid memory unless the stack is poped;
      so the `- sizeof(void *)` in the code is unnecessary.
      
      On the other hand, glibc reserves the 16 bytes it needs on stack
      and pops itself, so by the call instruction the stack pointer
      is exactly the caller-supplied sp. It then push the 16 bytes of
      the return address and the saved stack pointer, so the base
      pointer will be 16-byte aligned if and only if the caller
      supplied sp is 16-byte aligned. Therefore, the caller must supply
      a 16-byte aligned pointer, which `stack + UM_KERN_PAGE_SIZE`
      already satisfies.
      
      On a side note, musl is unaffected by this issue because it forces
      16 byte alignment via `and $-16,%rsi` in its clone wrapper.
      Similarly, glibc i386 is also unaffected because it has
      `andl $0xfffffff0, %ecx`.
      
      To reproduce this bug, enable CONFIG_UML_RTC and
      CC_OPTIMIZE_FOR_PERFORMANCE. uml_rtc will call
      add_sigio_fd which will then cause write_sigio_thread to either go
      into segfault loop or panic with "Segfault with no mm".
      
      Similarly, signal stacks will be aligned by the host kernel upon
      signal delivery. `- sizeof(void *)` to sigaltstack is
      unconventional and extraneous.
      
      On a related note, initialization of longjmp buffers do require
      `- sizeof(void *)`. This is to account for the return address
      that would have been pushed to the stack at the call site.
      
      The reason for uml to respect 16-byte alignment, rather than
      telling GCC to assume 8-byte alignment like the host kernel since
      commit d9b0cde9 ("x86-64, gcc: Use
      -mpreferred-stack-boundary=3 if supported"), is because uml links
      against libc. There is no reason to assume libc is also compiled
      with that flag and assumes 8-byte alignment rather than 16-byte.
      
      [1] https://gcc.gnu.org/bugzilla/show_bug.cgi?id=40838
      [2] https://c9x.me/x86/html/file_module_x86_id_180.htmlSigned-off-by: default avatarYiFei Zhu <zhuyifei1999@gmail.com>
      Fixes: 1da177e4 ("Linux-2.6.12-rc2")
      Reviewed-by: default avatarJohannes Berg <johannes@sipsolutions.net>
      Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
      558f9b2f
    • Johannes Berg's avatar
      um: implement flush_cache_vmap/flush_cache_vunmap · 80f849bf
      Johannes Berg authored
      vmalloc() heavy workloads in UML are extremely slow, due to
      flushing the entire kernel VM space (flush_tlb_kernel_vm())
      on the first segfault.
      
      Implement flush_cache_vmap() to avoid that, and while at it
      also add flush_cache_vunmap() since it's trivial.
      
      This speeds up my vmalloc() heavy test of copying files out
      from /sys/kernel/debug/gcov/ by 30x (from 30s to 1s.)
      Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
      Acked-By: default avatarAnton Ivanov <anton.ivanov@cambridgegreys.com>
      Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
      80f849bf
    • Anton Ivanov's avatar
      um: add a UML specific futex implementation · dd3035a2
      Anton Ivanov authored
      The generic asm futex implementation emulates atomic access to
      memory by doing a get_user followed by put_user. These translate
      to two mapping operations on UML with paging enabled in the
      meantime. This, in turn may end up changing interrupts,
      invoking the signal loop, etc.
      
      This replaces the generic implementation by a mapping followed
      by an operation on the mapped segment.
      Signed-off-by: default avatarAnton Ivanov <anton.ivanov@cambridgegreys.com>
      Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
      dd3035a2
    • Anton Ivanov's avatar
      um: enable the use of optimized xor routines in UML · c0ecca66
      Anton Ivanov authored
      This patch enables the use of optimized xor routines from the x86
      tree as well as the necessary fpu api shims so they can work on
      UML.
      Signed-off-by: default avatarAnton Ivanov <anton.ivanov@cambridgegreys.com>
      Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
      c0ecca66
    • Anton Ivanov's avatar
      um: Add support for host CPU flags and alignment · d8fb32f4
      Anton Ivanov authored
      1. Reflect host cpu flags into the UML instance so they can
      be used to select the correct implementations for xor, crypto, etc.
      
      2. Reflect host cache alignment into UML instance. This is
      important when running 32 bit on a 64 bit host as 32 bit by
      default aligns to 32 while the actual alignment should be 64.
      Ditto for some Xeons which align at 128.
      Signed-off-by: default avatarAnton Ivanov <anton.ivanov@cambridgegreys.com>
      Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
      d8fb32f4
    • Johannes Berg's avatar
      um: allow not setting extra rpaths in the linux binary · 386093c6
      Johannes Berg authored
      There doesn't seem to be any reason for the rpath being set in
      the binaries, at on systems that I tested on. On the other hand,
      setting rpath is actually harming binaries in some cases, e.g.
      if using nix-based compilation environments where /lib & /lib64
      are not part of the actual environment.
      
      Add a new Kconfig option (under EXPERT, for less user confusion)
      that allows disabling the rpath additions.
      Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
      Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
      386093c6
    • Johannes Berg's avatar
      um: virtio/pci: enable suspend/resume · 43c590cb
      Johannes Berg authored
      The UM virtual PCI devices currently cannot be suspended properly
      since the virtio driver already disables VQs well before the PCI
      bus's suspend_noirq wants to complete the transition by writing to
      PCI config space.
      
      After trying around for a long time with moving the devices on the
      DPM list, trying to create dependencies between them, etc. I gave
      up and instead added UML specific cross-driver API that lets the
      virt-pci code enable not suspending/resuming VQs for its devices.
      
      This then allows the PCI bus suspend_noirq to still talk to the
      device, and suspend/resume works properly.
      Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
      Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
      43c590cb
    • Johannes Berg's avatar
      um: add PCI over virtio emulation driver · 68f5d3f3
      Johannes Berg authored
      To support testing of PCI/PCIe drivers in UML, add a PCI bus
      support driver. This driver uses virtio, which in UML is really
      just vhost-user, to talk to devices, and adds the devices to
      the virtual PCI bus in the system.
      
      Since virtio already allows DMA/bus mastering this really isn't
      all that hard, of course we need the logic_iomem infrastructure
      that was added by a previous patch.
      
      The protocol to talk to the device is has a few fairly simple
      messages for reading to/writing from config and IO spaces, and
      messages for the device to send the various interrupts (INT#,
      MSI/MSI-X and while suspended PME#).
      
      Note that currently no offical virtio device ID is assigned for
      this protocol, as a consequence this patch requires defining it
      in the Kconfig, with a default that makes the driver refuse to
      work at all.
      
      Finally, in order to add support for MSI/MSI-X interrupts, some
      small changes are needed in the UML IRQ code, it needs to have
      more interrupts, changing NR_IRQS from 64 to 128 if this driver
      is enabled, but not actually use them for anything so that the
      generic IRQ domain/MSI infrastructure can allocate IRQ numbers.
      Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
      Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
      68f5d3f3
    • Johannes Berg's avatar
      um: irqs: allow invoking time-travel handler multiple times · a5ab7c84
      Johannes Berg authored
      If we happen to get multiple messages while IRQS are already
      suspended, we still need to handle them, since otherwise the
      simulation blocks.
      
      Remove the "prevent nesting" part, time_travel_add_irq_event()
      will deal with being called multiple times just fine.
      Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
      Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
      a5ab7c84
    • Johannes Berg's avatar
      um: time-travel/signals: fix ndelay() in interrupt · d6b399a0
      Johannes Berg authored
      We should be able to ndelay() from any context, even from an
      interrupt context! However, this is broken (not functionally,
      but locking-wise) in time-travel because we'll get into the
      time-travel code and enable interrupts to handle messages on
      other time-travel aware subsystems (only virtio for now).
      
      Luckily, I've already reworked the time-travel aware signal
      (interrupt) delivery for suspend/resume to have a time travel
      handler, which runs directly in the context of the signal and
      not from the Linux interrupt.
      
      In order to fix this time-travel issue then, we need to do a
      few things:
      
       1) rework the signal handling code to call time-travel handlers
          (only) if interrupts are disabled but signals aren't blocked,
          instead of marking it only pending there. This is needed to
          not deadlock other communication.
       2) rework time-travel to not enable interrupts while it's
          waiting for a message;
       3) rework time-travel to not (just) disable interrupts but
          rather block signals at a lower level while it needs them
          disabled for communicating with the controller.
      
      Finally, since now we can actually spend even virtual time
      in interrupts-disabled sections, the delay warning when we
      deliver a time-travel delayed interrupt is no longer valid,
      things can (and should) now get delayed.
      Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
      Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
      d6b399a0
    • Johannes Berg's avatar
      um: expose time-travel mode to userspace side · 33c7d061
      Johannes Berg authored
      This will be necessary in the userspace side to fix the
      signal/interrupt handling in time-travel=ext mode, which
      is the next patch.
      Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
      Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
      33c7d061
    • Johannes Berg's avatar
      um: export signals_enabled directly · fbb42e7f
      Johannes Berg authored
      Use signals_enabled instead of always jumping through
      a function call to read it, there's not much point in
      that.
      Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
      Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
      fbb42e7f
    • Johannes Berg's avatar
      um: remove unused smp_sigio_handler() declaration · 2efea7df
      Johannes Berg authored
      This function doesn't exist, remove its declaration.
      Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
      Acked-By: default avatarAnton Ivanov <anton.ivanov@cambridgegreys.com>
      Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
      2efea7df
    • Johannes Berg's avatar
      lib: add iomem emulation (logic_iomem) · ca2e3342
      Johannes Berg authored
      Add IO memory emulation that uses callbacks for read/write to
      the allocated regions. The callbacks can be registered by the
      users using logic_iomem_alloc().
      
      To use, an architecture must 'select LOGIC_IOMEM' in Kconfig
      and then include <asm-generic/logic_io.h> into asm/io.h to get
      the __raw_read*/__raw_write* functions.
      
      Optionally, an architecture may 'select LOGIC_IOMEM_FALLBACK'
      in which case non-emulated regions will 'fall back' to the
      various real_* functions that must then be provided.
      
      Cc: Arnd Bergmann <arnd@kernel.org>
      Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
      Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
      ca2e3342
    • Johannes Berg's avatar
      um: allow disabling NO_IOMEM · 0bbadafd
      Johannes Berg authored
      Adjust the kconfig a little to allow disabling NO_IOMEM in UML. To
      make an "allyesconfig" with CONFIG_NO_IOMEM=n build, adjust a few
      Kconfig things elsewhere and add dummy asm/fb.h and asm/vga.h files.
      Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
      Signed-off-by: default avatarRichard Weinberger <richard@nod.at>
      0bbadafd
  2. 13 Jun, 2021 4 commits
    • Linus Torvalds's avatar
      Linux 5.13-rc6 · 009c9aa5
      Linus Torvalds authored
      009c9aa5
    • Linus Torvalds's avatar
      Merge tag 'perf-tools-fixes-for-v5.13-2021-06-13' of... · e4e45343
      Linus Torvalds authored
      Merge tag 'perf-tools-fixes-for-v5.13-2021-06-13' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux
      
      Pull perf tools fixes from Arnaldo Carvalho de Melo:
      
       - Correct buffer copying when peeking events
      
       - Sync cpufeatures/disabled-features.h header with the kernel sources
      
      * tag 'perf-tools-fixes-for-v5.13-2021-06-13' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux:
        tools headers cpufeatures: Sync with the kernel sources
        perf session: Correct buffer copying when peeking events
      e4e45343
    • Linus Torvalds's avatar
      Merge tag 'nfs-for-5.13-3' of git://git.linux-nfs.org/projects/trondmy/linux-nfs · 960f0716
      Linus Torvalds authored
      Pull NFS client bugfixes from Trond Myklebust:
       "Highlights include:
      
        Stable fixes:
      
         - Fix use-after-free in nfs4_init_client()
      
        Bugfixes:
      
         - Fix deadlock between nfs4_evict_inode() and nfs4_opendata_get_inode()
      
         - Fix second deadlock in nfs4_evict_inode()
      
         - nfs4_proc_set_acl should not change the value of NFS_CAP_UIDGID_NOMAP
      
         - Fix setting of the NFS_CAP_SECURITY_LABEL capability"
      
      * tag 'nfs-for-5.13-3' of git://git.linux-nfs.org/projects/trondmy/linux-nfs:
        NFSv4: Fix second deadlock in nfs4_evict_inode()
        NFSv4: Fix deadlock between nfs4_evict_inode() and nfs4_opendata_get_inode()
        NFS: FMODE_READ and friends are C macros, not enum types
        NFS: Fix a potential NULL dereference in nfs_get_client()
        NFS: Fix use-after-free in nfs4_init_client()
        NFS: Ensure the NFS_CAP_SECURITY_LABEL capability is set when appropriate
        NFSv4: nfs4_proc_set_acl needs to restore NFS_CAP_UIDGID_NOMAP on error.
      960f0716
    • Linus Torvalds's avatar
      Merge tag 'scsi-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi · 331a6edb
      Linus Torvalds authored
      Pull SCSI fixes from James Bottomley:
       "Four reasonably small fixes to the core for scsi host allocation
        failure paths.
      
        The root problem is that we're not freeing the memory allocated by
        dev_set_name(), which involves a rejig of may of the free on error
        paths to do put_device() instead of kfree which, in turn, has several
        other knock on ramifications and inspection turned up a few other
        lurking bugs"
      
      * tag 'scsi-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi:
        scsi: core: Only put parent device if host state differs from SHOST_CREATED
        scsi: core: Put .shost_dev in failure path if host state changes to RUNNING
        scsi: core: Fix failure handling of scsi_add_host_with_dma()
        scsi: core: Fix error handling of scsi_host_alloc()
      331a6edb
  3. 12 Jun, 2021 15 commits
    • Linus Torvalds's avatar
      Merge tag 'riscv-for-linus-5.13-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/riscv/linux · 8ecfa36c
      Linus Torvalds authored
      Pull RISC-V fixes from Palmer Dabbelt:
      
       - A pair of XIP fixes: one to fix alternatives, and one to turn off the
         rest of the features that require code modification
      
       - A fix to a type that was causing some alternatives to break
      
       - A build fix for BUILTIN_DTB
      
      * tag 'riscv-for-linus-5.13-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/riscv/linux:
        riscv: Fix BUILTIN_DTB for sifive and microchip soc
        riscv: alternative: fix typo in macro name
        riscv: code patching only works on !XIP_KERNEL
        riscv: xip: support runtime trap patching
      8ecfa36c
    • Feng Tang's avatar
      mm: relocate 'write_protect_seq' in struct mm_struct · 2e302543
      Feng Tang authored
      0day robot reported a 9.2% regression for will-it-scale mmap1 test
      case[1], caused by commit 57efa1fe ("mm/gup: prevent gup_fast from
      racing with COW during fork").
      
      Further debug shows the regression is due to that commit changes the
      offset of hot fields 'mmap_lock' inside structure 'mm_struct', thus some
      cache alignment changes.
      
      From the perf data, the contention for 'mmap_lock' is very severe and
      takes around 95% cpu cycles, and it is a rw_semaphore
      
              struct rw_semaphore {
                      atomic_long_t count;	/* 8 bytes */
                      atomic_long_t owner;	/* 8 bytes */
                      struct optimistic_spin_queue osq; /* spinner MCS lock */
                      ...
      
      Before commit 57efa1fe adds the 'write_protect_seq', it happens to
      have a very optimal cache alignment layout, as Linus explained:
      
       "and before the addition of the 'write_protect_seq' field, the
        mmap_sem was at offset 120 in 'struct mm_struct'.
      
        Which meant that count and owner were in two different cachelines,
        and then when you have contention and spend time in
        rwsem_down_write_slowpath(), this is probably *exactly* the kind
        of layout you want.
      
        Because first the rwsem_write_trylock() will do a cmpxchg on the
        first cacheline (for the optimistic fast-path), and then in the
        case of contention, rwsem_down_write_slowpath() will just access
        the second cacheline.
      
        Which is probably just optimal for a load that spends a lot of
        time contended - new waiters touch that first cacheline, and then
        they queue themselves up on the second cacheline."
      
      After the commit, the rw_semaphore is at offset 128, which means the
      'count' and 'owner' fields are now in the same cacheline, and causes
      more cache bouncing.
      
      Currently there are 3 "#ifdef CONFIG_XXX" before 'mmap_lock' which will
      affect its offset:
      
        CONFIG_MMU
        CONFIG_MEMBARRIER
        CONFIG_HAVE_ARCH_COMPAT_MMAP_BASES
      
      The layout above is on 64 bits system with 0day's default kernel config
      (similar to RHEL-8.3's config), in which all these 3 options are 'y'.
      And the layout can vary with different kernel configs.
      
      Relayouting a structure is usually a double-edged sword, as sometimes it
      can helps one case, but hurt other cases.  For this case, one solution
      is, as the newly added 'write_protect_seq' is a 4 bytes long seqcount_t
      (when CONFIG_DEBUG_LOCK_ALLOC=n), placing it into an existing 4 bytes
      hole in 'mm_struct' will not change other fields' alignment, while
      restoring the regression.
      
      Link: https://lore.kernel.org/lkml/20210525031636.GB7744@xsang-OptiPlex-9020/ [1]
      Reported-by: default avatarkernel test robot <oliver.sang@intel.com>
      Signed-off-by: default avatarFeng Tang <feng.tang@intel.com>
      Reviewed-by: default avatarJohn Hubbard <jhubbard@nvidia.com>
      Reviewed-by: default avatarJason Gunthorpe <jgg@nvidia.com>
      Cc: Peter Xu <peterx@redhat.com>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      2e302543
    • Linus Torvalds's avatar
      Merge tag 'usb-5.13-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb · 43cb5d49
      Linus Torvalds authored
      Pull USB fixes from Greg KH:
       "Here are a number of tiny USB fixes for 5.13-rc6.
      
        There are more than I would normally like, but there's been a bunch of
        people banging on the gadget and dwc3 and typec code recently for I
        think an Android release, which has resulted in a number of small
        fixes. It's nice to see companies send fixes upstream for this type of
        work, a notable change from years ago.
      
        Anyway, fixes in here are:
      
         - usb-serial device id updates
      
         - usb-serial cp210x driver fixes for broken firmware versions
      
         - typec fixes for crazy charging devices and other reported problems
      
         - dwc3 fixes for reported problems found
      
         - gadget fixes for reported problems
      
         - tiny xhci fixes
      
         - other small fixes for reported issues.
      
         - revert of a problem fix found by linux-next testing
      
        All of these have passed 0-day and linux-next testing with no reported
        problems (the revert for the found linux-next build problem included)"
      
      * tag 'usb-5.13-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb: (44 commits)
        Revert "usb: gadget: fsl: Re-enable driver for ARM SoCs"
        usb: typec: mux: Fix copy-paste mistake in typec_mux_match
        usb: typec: ucsi: Clear PPM capability data in ucsi_init() error path
        usb: gadget: fsl: Re-enable driver for ARM SoCs
        usb: typec: wcove: Use LE to CPU conversion when accessing msg->header
        USB: serial: cp210x: fix CP2102N-A01 modem control
        USB: serial: cp210x: fix alternate function for CP2102N QFN20
        usb: misc: brcmstb-usb-pinmap: check return value after calling platform_get_resource()
        usb: dwc3: ep0: fix NULL pointer exception
        usb: gadget: eem: fix wrong eem header operation
        usb: typec: intel_pmc_mux: Put ACPI device using acpi_dev_put()
        usb: typec: intel_pmc_mux: Add missed error check for devm_ioremap_resource()
        usb: typec: intel_pmc_mux: Put fwnode in error case during ->probe()
        usb: typec: tcpm: Do not finish VDM AMS for retrying Responses
        usb: fix various gadget panics on 10gbps cabling
        usb: fix various gadgets null ptr deref on 10gbps cabling.
        usb: pci-quirks: disable D3cold on xhci suspend for s2idle on AMD Renoir
        usb: f_ncm: only first packet of aggregate needs to start timer
        USB: f_ncm: ncm_bitrate (speed) is unsigned
        MAINTAINERS: usb: add entry for isp1760
        ...
      43cb5d49
    • Linus Torvalds's avatar
      Merge tag 'tty-5.13-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/tty · c46fe4aa
      Linus Torvalds authored
      Pull serial driver fix from Greg KH:
       "A single 8250_exar serial driver fix for a reported problem with a
        change that happened in 5.13-rc1.
      
        It has been in linux-next with no reported problems"
      
      * tag 'tty-5.13-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/tty:
        serial: 8250_exar: Avoid NULL pointer dereference at ->exit()
      c46fe4aa
    • Linus Torvalds's avatar
      Merge tag 'staging-5.13-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging · 0d506588
      Linus Torvalds authored
      Pull staging driver fixes from Greg KH:
       "Two tiny staging driver fixes:
      
         - ralink-gdma driver authorship information fixed up
      
         - rtl8723bs driver fix for reported regression
      
        Both have been in linux-next for a while with no reported problems"
      
      * tag 'staging-5.13-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging:
        staging: ralink-gdma: Remove incorrect author information
        staging: rtl8723bs: Fix uninitialized variables
      0d506588
    • Linus Torvalds's avatar
      Merge tag 'driver-core-5.13-rc6' of... · 87a7f736
      Linus Torvalds authored
      Merge tag 'driver-core-5.13-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/driver-core
      
      Pull driver core fix from Greg KH:
       "A single debugfs fix for 5.13-rc6, fixing a bug in
        debugfs_read_file_str() that showed up in 5.13-rc1.
      
        It has been in linux-next for a full week with no
        reported problems"
      
      * tag 'driver-core-5.13-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/driver-core:
        debugfs: Fix debugfs_read_file_str()
      87a7f736
    • Linus Torvalds's avatar
      Merge tag 'char-misc-5.13-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc · 1dfa2e77
      Linus Torvalds authored
      Pull char/misc driver fixes from Greg KH:
       "Here are some small misc driver fixes for 5.13-rc6 that fix some
        reported problems:
      
         - Tiny phy driver fixes for reported issues
      
         - rtsx regression for when the device suspended
      
         - mhi driver fix for a use-after-free
      
        All of these have been in linux-next for a few days with no reported
        issues"
      
      * tag 'char-misc-5.13-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc:
        misc: rtsx: separate aspm mode into MODE_REG and MODE_CFG
        bus: mhi: pci-generic: Fix hibernation
        bus: mhi: pci_generic: Fix possible use-after-free in mhi_pci_remove()
        bus: mhi: pci_generic: T99W175: update channel name from AT to DUN
        phy: Sparx5 Eth SerDes: check return value after calling platform_get_resource()
        phy: ralink: phy-mt7621-pci: drop 'of_match_ptr' to fix -Wunused-const-variable
        phy: ti: Fix an error code in wiz_probe()
        phy: phy-mtk-tphy: Fix some resource leaks in mtk_phy_init()
        phy: cadence: Sierra: Fix error return code in cdns_sierra_phy_probe()
        phy: usb: Fix misuse of IS_ENABLED
      1dfa2e77
    • Linus Torvalds's avatar
      Merge tag 'pinctrl-v5.13-2' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl · 141415d7
      Linus Torvalds authored
      Pull pin control fixes from Linus Walleij:
      
       - Fix some documentation warnings for Allwinner
      
       - Fix duplicated GPIO groups on Qualcomm SDX55
      
       - Fix a double enablement bug in the Ralink driver
      
       - Fix the Qualcomm SC8180x Kconfig so the driver can be selected.
      
      * tag 'pinctrl-v5.13-2' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl:
        pinctrl: qcom: Make it possible to select SC8180x TLMM
        pinctrl: ralink: rt2880: avoid to error in calls is pin is already enabled
        pinctrl: qcom: Fix duplication in gpio_groups
        pinctrl: aspeed: Fix minor documentation error
      141415d7
    • Linus Torvalds's avatar
      Merge tag 'block-5.13-2021-06-12' of git://git.kernel.dk/linux-block · efc1fd60
      Linus Torvalds authored
      Pull block fixes from Jens Axboe:
       "A few fixes that should go into 5.13:
      
         - Fix a regression deadlock introduced in this release between open
           and remove of a bdev (Christoph)
      
         - Fix an async_xor md regression in this release (Xiao)
      
         - Fix bcache oversized read issue (Coly)"
      
      * tag 'block-5.13-2021-06-12' of git://git.kernel.dk/linux-block:
        block: loop: fix deadlock between open and remove
        async_xor: check src_offs is not NULL before updating it
        bcache: avoid oversized read request in cache missing code path
        bcache: remove bcache device self-defined readahead
      efc1fd60
    • Linus Torvalds's avatar
      Merge tag 'io_uring-5.13-2021-06-12' of git://git.kernel.dk/linux-block · b2568eeb
      Linus Torvalds authored
      Pull io_uring fixes from Jens Axboe:
       "Just an API change for the registration changes that went into this
        release. Better to get it sorted out now than before it's too late"
      
      * tag 'io_uring-5.13-2021-06-12' of git://git.kernel.dk/linux-block:
        io_uring: add feature flag for rsrc tags
        io_uring: change registration/upd/rsrc tagging ABI
      b2568eeb
    • Linus Torvalds's avatar
      Merge tag 'sched-urgent-2021-06-12' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 99f92594
      Linus Torvalds authored
      Pull scheduler fixes from Ingo Molnar:
       "Misc fixes:
      
         - Fix performance regression caused by lack of intended batching of
           RCU callbacks by over-eager NOHZ-full code.
      
         - Fix cgroups related corruption of load_avg and load_sum metrics.
      
         - Three fixes to fix blocked load, util_sum/runnable_sum and util_est
           tracking bugs"
      
      * tag 'sched-urgent-2021-06-12' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        sched/fair: Fix util_est UTIL_AVG_UNCHANGED handling
        sched/pelt: Ensure that *_sum is always synced with *_avg
        tick/nohz: Only check for RCU deferred wakeup on user/guest entry when needed
        sched/fair: Make sure to update tg contrib for blocked load
        sched/fair: Keep load_avg and load_sum synced
      99f92594
    • Linus Torvalds's avatar
      Merge tag 'perf-urgent-2021-06-12' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 191aaf6c
      Linus Torvalds authored
      Pull perf fixes from Ingo Molnar:
       "Misc fixes:
      
         - Fix the NMI watchdog on ancient Intel CPUs
      
         - Remove a misguided, NMI-unsafe KASAN callback from the NMI-safe
           irq_work path used by perf.
      
         - Fix uncore events on Ice Lake servers.
      
         - Someone booted maxcpus=1 on an SNB-EP, and the uncore driver
           emitted warnings and was probably buggy. Fix it.
      
         - KCSAN found a genuine data race in the core perf code. Somewhat
           ironically the bug was introduced through a recent race fix. :-/
           In our defense, the new race window was much more narrow. Fix it"
      
      * tag 'perf-urgent-2021-06-12' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/nmi_watchdog: Fix old-style NMI watchdog regression on old Intel CPUs
        irq_work: Make irq_work_queue() NMI-safe again
        perf/x86/intel/uncore: Fix M2M event umask for Ice Lake server
        perf/x86/intel/uncore: Fix a kernel WARNING triggered by maxcpus=1
        perf: Fix data race between pin_count increment/decrement
      191aaf6c
    • Linus Torvalds's avatar
      Merge tag 'objtool-urgent-2021-06-12' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 768895fb
      Linus Torvalds authored
      Pull objtool fixes from Ingo Molnar:
       "Two objtool fixes:
      
         - fix a bug that corrupts the code by mistakenly rewriting
           conditional jumps
      
         - fix another bug generating an incorrect ELF symbol table
           during retpoline rewriting"
      
      * tag 'objtool-urgent-2021-06-12' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        objtool: Only rewrite unconditional retpoline thunk calls
        objtool: Fix .symtab_shndx handling for elf_create_undef_symbol()
      768895fb
    • Alexandre Ghiti's avatar
      riscv: Fix BUILTIN_DTB for sifive and microchip soc · 0ddd7eaf
      Alexandre Ghiti authored
      Fix BUILTIN_DTB config which resulted in a dtb that was actually not
      built into the Linux image: in the same manner as Canaan soc does,
      create an object file from the dtb file that will get linked into the
      Linux image.
      Signed-off-by: default avatarAlexandre Ghiti <alex@ghiti.fr>
      Signed-off-by: default avatarPalmer Dabbelt <palmerdabbelt@google.com>
      0ddd7eaf
    • Linus Torvalds's avatar
      Merge tag 'trace-v5.13-rc5-2' of git://git.kernel.org/pub/scm/linux/kernel/git/rostedt/linux-trace · ad347abe
      Linus Torvalds authored
      Pull tracing fixes from Steven Rostedt:
      
       - Fix the length check in the temp buffer filter
      
       - Fix build failure in bootconfig tools for "fallthrough" macro
      
       - Fix error return of bootconfig apply_xbc() routine
      
      * tag 'trace-v5.13-rc5-2' of git://git.kernel.org/pub/scm/linux/kernel/git/rostedt/linux-trace:
        tracing: Correct the length check which causes memory corruption
        ftrace: Do not blindly read the ip address in ftrace_bug()
        tools/bootconfig: Fix a build error accroding to undefined fallthrough
        tools/bootconfig: Fix error return code in apply_xbc()
      ad347abe
  4. 11 Jun, 2021 4 commits
    • Linus Torvalds's avatar
      Merge tag 'clang-features-v5.13-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux · 548843c0
      Linus Torvalds authored
      Pull clang LTO fix from Kees Cook:
       "Clang 13 fixed some IR behavior for LTO, but this broke work-arounds
        used in the kernel.
      
        Handle changes to needed LTO flags in Clang 13 (Tor Vic)"
      
      * tag 'clang-features-v5.13-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux:
        x86, lto: Pass -stack-alignment only on LLD < 13.0.0
      548843c0
    • Linus Torvalds's avatar
      Merge tag 'gpio-fixes-for-v5.13-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/brgl/linux · e65b7914
      Linus Torvalds authored
      Pull gpio fix from Bartosz Golaszewski:
       "Fix a shift-out-of-bounds error in gpio-wcd934x"
      
      * tag 'gpio-fixes-for-v5.13-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/brgl/linux:
        gpio: wcd934x: Fix shift-out-of-bounds error
      e65b7914
    • Linus Torvalds's avatar
      Merge tag 'drm-fixes-2021-06-11' of git://anongit.freedesktop.org/drm/drm · f21b807c
      Linus Torvalds authored
      Pull drm fixes from Dave Airlie:
       "Another week of fixes, nothing too crazy, but a few all over the
        place.
      
        Two locking fixes in the core/ttm area, a couple of small driver fixes
        (radeon, sun4i, mcde, vc4). Then msm and amdgpu have a set of fixes
        each, mostly for smaller things, though the msm has a DSI fix for a
        black screen.
      
        I haven't seen any intel fixes this week so they may have a few that
        may or may not wait for next week.
      
        drm:
         - auth locking fix
      
        ttm:
         - locking fix
      
        amdgpu:
         - Use kvzmalloc in amdgu_bo_create
         - Use drm_dbg_kms for reporting failure to get a GEM FB
         - Fix some register offsets for Sienna Cichlid
         - Fix fall-through warning
      
        radeon:
         - memcpy_to/from_io fixes
      
        msm:
         - NULL ptr deref fix
         - CP_PROTECT reg programming fix
         - incorrect register shift fix
         - DSI blank screen fix
      
        sun4i:
         - hdmi output probing fix
      
        mcde:
         - DSI pipeline calc fix
      
        vc4:
         - out of bounds fix"
      
      * tag 'drm-fixes-2021-06-11' of git://anongit.freedesktop.org/drm/drm:
        drm/msm/dsi: Stash away calculated vco frequency on recalc
        drm: Lock pointer access in drm_master_release()
        drm/mcde: Fix off by 10^3 in calculation
        drm/msm/a6xx: avoid shadow NULL reference in failure path
        drm/msm/a6xx: fix incorrectly set uavflagprd_inv field for A650
        drm/msm/a6xx: update/fix CP_PROTECT initialization
        radeon: use memcpy_to/fromio for UVD fw upload
        drm/amd/pm: Fix fall-through warning for Clang
        drm/amdgpu: Fix incorrect register offsets for Sienna Cichlid
        drm/amdgpu: Use drm_dbg_kms for reporting failure to get a GEM FB
        drm/amdgpu: switch kzalloc to kvzalloc in amdgpu_bo_create
        drm/msm: Init mm_list before accessing it for use_vram path
        drm: Fix use-after-free read in drm_getunique()
        drm/vc4: fix vc4_atomic_commit_tail() logic
        drm/ttm: fix deref of bo->ttm without holding the lock v2
        drm/sun4i: dw-hdmi: Make HDMI PHY into a platform device
      f21b807c
    • Linus Torvalds's avatar
      Merge tag 'devicetree-fixes-for-5.13-3' of git://git.kernel.org/pub/scm/linux/kernel/git/robh/linux · 929d931f
      Linus Torvalds authored
      Pull devicetree fix from Rob Herring:
       "A single fix for broken media/renesas,drif.yaml binding schema"
      
      * tag 'devicetree-fixes-for-5.13-3' of git://git.kernel.org/pub/scm/linux/kernel/git/robh/linux:
        media: dt-bindings: media: renesas,drif: Fix fck definition
      929d931f