1. 05 7月, 2021 17 次提交
    • H
      s390/lib,string: fix strcat() inline asm constraint modifier · a0ae5cd2
      Heiko Carstens 提交于
      "dummy" is not only used as output but also as input. Therefore use
      the correct "+" constraint modifier.
      
      Fixes: 8cf23c8e ("s390/lib,string: get rid of register asm")
      Reported-by: NSven Schnelle <svens@linux.ibm.com>
      Signed-off-by: NHeiko Carstens <hca@linux.ibm.com>
      Signed-off-by: NVasily Gorbik <gor@linux.ibm.com>
      a0ae5cd2
    • T
      s390/cpumf: Allow concurrent access for CPU Measurement Counter Facility · a029a4ea
      Thomas Richter 提交于
      Commit cf6acb8b ("s390/cpumf: Add support for complete counter set extraction")
      allows access to the CPU Measurement Counter Facility via character
      device /dev/hwctr. The access was exclusive via this device or
      via perf_event_open() system call. Only one path at a time was
      permitted. The CPU Measurement Counter Facility device driver blocked
      access to other processes.
      
      This patch removes this restriction and allows concurrent access to
      the CPU Measurement Counter Facility from multiple processes at the same
      time via perf_event_open() SVC and via /dev/hwctr device. The access
      via /dev/hwctr device is still exclusive, only one process is allowed to
      access this device.
      
      This patch
      - moves the /dev/hwctr device access from file perf_cpum_cf_diag.c.
        to file perf_cpum_cf.c.
      - use only one trace buffer .../s390dbf/cpum_cf.
      - remove cfset_csd structure and includes its members it into the
        structure cpu_cf_events. This results in one data structure and
        simplifies the access.
      - rework function familiy ctr_set_enable, ctr_set_disable, ctr_set_start
        and ctr_set_stop which operate on a counter set number.
        Now they operate on a counter set bit mask.
      - move CF_DIAG event functionality to file perf_cpum_cf.c. It now
        contains the complete functionality of the CPU Measurement Counter
        Facility:
        - Performance measurement support for counters using perf stat.
        - Support for complete counter set extraction with device /dev/hwctr.
        - Support for counter set extraction event CF_DIAG attached to
          samples using perf record.
      - removes file perf_cpum_cf_diag.c
      Signed-off-by: NThomas Richter <tmricht@linux.ibm.com>
      Reviewed-by: NSumanth Korikkar <sumanthk@linux.ibm.com>
      Signed-off-by: NVasily Gorbik <gor@linux.ibm.com>
      a029a4ea
    • A
      s390/mcck: move register validation to C code · 5fa2ea07
      Alexander Gordeev 提交于
      This update partially reverts commit 3037a52f ("s390/nmi:
      do register validation as early as possible").
      
      Storage error checks and control registers validation are left
      in the assembler code, since correct ASCEs and page tables are
      required to enable DAT - which is done before the C handler is
      entered.
      
      System damage, kernel instruction address and PSW MWP checks
      are left in the assembler code as well, since there is no way
      to proceed if one of these checks is failed.
      
      The getcpu vdso syscall reads CPU number from the programmable
      field of the TOD clock. Disregard the TOD programmable register
      validity bit and load the CPU number into the TOD programmable
      field unconditionally.
      Signed-off-by: NAlexander Gordeev <agordeev@linux.ibm.com>
      Reviewed-by: NHeiko Carstens <hca@linux.ibm.com>
      Signed-off-by: NHeiko Carstens <hca@linux.ibm.com>
      Signed-off-by: NVasily Gorbik <gor@linux.ibm.com>
      5fa2ea07
    • A
      s390/boot: replace magic string check with a bootdata flag · 9f744abb
      Alexander Egorenkov 提交于
      The magic string "S390EP" at offset 0x10008 indicated to the decompressed
      kernel that it was booted by the decompressor. Introduce a new bootdata
      flag instead which conveys the same information in an explicit and
      a cleaner way. But keep the magic string because it is a kernel ABI.
      Signed-off-by: NAlexander Egorenkov <egorenar@linux.ibm.com>
      Reviewed-by: NVasily Gorbik <gor@linux.ibm.com>
      Signed-off-by: NVasily Gorbik <gor@linux.ibm.com>
      9f744abb
    • A
      s390/mcck: keep machine check interruption codes sorted · 549abb7f
      Alexander Gordeev 提交于
      This update puts in order MCCK_CODE_CPU_TIMER_VALID code definition.
      Signed-off-by: NAlexander Gordeev <agordeev@linux.ibm.com>
      Reviewed-by: NHeiko Carstens <hca@linux.ibm.com>
      Signed-off-by: NHeiko Carstens <hca@linux.ibm.com>
      Signed-off-by: NVasily Gorbik <gor@linux.ibm.com>
      549abb7f
    • A
      s390/mcck: move storage error checks to assembler · d35925b3
      Alexander Gordeev 提交于
      The current storage errors tackling is wrong - the DAT is
      enabled in assembler code before the actual storage checks
      in C half are executed. In case the page tables themselves
      are damaged such approach is not going to work.
      
      With this update unrecoverable storage errors are not
      passed to C code for handling, but rather the machine
      is stopped right away. The only exception to this flow
      is when a machine check occurred in KVM guest - in this
      case the errors are reinjected by the handler.
      Signed-off-by: NAlexander Gordeev <agordeev@linux.ibm.com>
      Reviewed-by: NHeiko Carstens <hca@linux.ibm.com>
      Signed-off-by: NHeiko Carstens <hca@linux.ibm.com>
      Signed-off-by: NVasily Gorbik <gor@linux.ibm.com>
      d35925b3
    • A
      s390/mcck: always enter C handler with DAT enabled · 7f6dc8d4
      Alexander Gordeev 提交于
      The machine check handler must be entered with DAT disabled
      in case control registers are corrupted or a storage error
      happened and we can not tell if such error corresponds to a
      page table.
      
      Both of described conditions end up in stopping all CPUs and
      entering the disabled wait in C half of the handler. However,
      the storage errors are still checked after the DAT is enabled
      and C code is entered. In case a page table is damaged such
      flow is not expected to work.
      
      This update paves the way for moving the storage error checks
      from C to assembler half. All fatal errors that can only be
      handled with DAT disabled are handled in assembler half also.
      As result, the C half is only entered if the DAT is secured.
      Signed-off-by: NAlexander Gordeev <agordeev@linux.ibm.com>
      Reviewed-by: NHeiko Carstens <hca@linux.ibm.com>
      Signed-off-by: NHeiko Carstens <hca@linux.ibm.com>
      Signed-off-by: NVasily Gorbik <gor@linux.ibm.com>
      7f6dc8d4
    • A
      s390/mcck: optimize user mode check in case of !CONFIG_KVM · e2c13d64
      Alexander Gordeev 提交于
      In case of the !CONFIG_KVM use "jz" instead of "jnz" when
      detecting user mode and get rid of unnecessary jump as result.
      Signed-off-by: NAlexander Gordeev <agordeev@linux.ibm.com>
      Reviewed-by: NChristia Borntraeger <borntraeger@de.ibm.com>
      Signed-off-by: NHeiko Carstens <hca@linux.ibm.com>
      Signed-off-by: NVasily Gorbik <gor@linux.ibm.com>
      e2c13d64
    • A
      s390/entry.S: factor out SIEEXIT macro · fbbdfca5
      Alexander Gordeev 提交于
      Factor out SIEEXIT macro and use it instead of cleanup_sie
      routine. As a side effect %r13 and %r14 are spared.
      Signed-off-by: NAlexander Gordeev <agordeev@linux.ibm.com>
      Reviewed-by: NChristia Borntraeger <borntraeger@de.ibm.com>
      Signed-off-by: NHeiko Carstens <hca@linux.ibm.com>
      Signed-off-by: NVasily Gorbik <gor@linux.ibm.com>
      fbbdfca5
    • H
      s390/lib,uaccess: fix copy_in_user_mvcos() inline asm clobber list · 07f3a35d
      Heiko Carstens 提交于
      General register 0 is clobbered within the inline assembly and
      therefore must be listed in the clobber list.
      
      Fixes:  d1e18efa ("s390/lib,uaccess: get rid of register asm")
      Signed-off-by: NHeiko Carstens <hca@linux.ibm.com>
      Signed-off-by: NVasily Gorbik <gor@linux.ibm.com>
      07f3a35d
    • J
      s390: mm: Fix secure storage access exception handling · 85b18d7b
      Janosch Frank 提交于
      Turns out that the bit 61 in the TEID is not always 1 and if that's
      the case the address space ID and the address are
      unpredictable. Without an address and its address space ID we can't
      export memory and hence we can only send a SIGSEGV to the process or
      panic the kernel depending on who caused the exception.
      
      Unfortunately bit 61 is only reliable if we have the "misc" UV feature
      bit.
      Signed-off-by: NJanosch Frank <frankja@linux.ibm.com>
      Reviewed-by: NChristian Borntraeger <borntraeger@de.ibm.com>
      Fixes: 084ea4d6 ("s390/mm: add (non)secure page access exceptions handlers")
      Cc: stable@vger.kernel.org
      Signed-off-by: NVasily Gorbik <gor@linux.ibm.com>
      85b18d7b
    • K
      s390/kprobes: use is_kernel() helper · 47f7c6cf
      Kefeng Wang 提交于
      Use is_kernel() helper instead of is_kernel_addr().
      
      [hca@linux.ibm.com: add missing unsigned long cast]
      Cc: Vasily Gorbik <gor@linux.ibm.com>
      Cc: Christian Borntraeger <borntraeger@de.ibm.com>
      Signed-off-by: NKefeng Wang <wangkefeng.wang@huawei.com>
      Signed-off-by: NHeiko Carstens <hca@linux.ibm.com>
      Signed-off-by: NVasily Gorbik <gor@linux.ibm.com>
      47f7c6cf
    • L
      Merge tag 's390-5.14-1' of git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux · 2bb919b6
      Linus Torvalds 提交于
      Pull s390 updates from Vasily Gorbik:
      
       - Rework inline asm to get rid of error prone "register asm"
         constructs, which are problematic especially when code
         instrumentation is enabled.
      
         In particular introduce and use register pair union to allocate
         even/odd register pairs. Unfortunately this breaks compatibility with
         older clang compilers and minimum clang version for s390 has been
         raised to 13.
      
           https://lore.kernel.org/linux-next/CAK7LNARuSmPCEy-ak0erPrPTgZdGVypBROFhtw+=3spoGoYsyw@mail.gmail.com/
      
       - Fix gcc 11 warnings, which triggered various minor reworks all over
         the code.
      
       - Add zstd kernel image compression support.
      
       - Rework boot CPU lowcore handling.
      
       - De-duplicate and move kernel memory layout setup logic earlier.
      
       - Few fixes in preparation for FORTIFY_SOURCE performing compile-time
         and run-time field bounds checking for mem functions.
      
       - Remove broken and unused power management support leftovers in s390
         drivers.
      
       - Disable stack-protector for decompressor and purgatory to fix
         buildroot build.
      
       - Fix vt220 sclp console name to match the char device name.
      
       - Enable HAVE_IOREMAP_PROT and add zpci_set_irq()/zpci_clear_irq() in
         zPCI code.
      
       - Remove some implausible WARN_ON_ONCEs and remove arch specific
         counter transaction call backs in favour of default transaction
         handling in perf code.
      
       - Extend/add new uevents for online/config/mode state changes of AP
         card / queue device in zcrypt.
      
       - Minor entry and ccwgroup code improvements.
      
       - Other small various fixes and improvements all over the code.
      
      * tag 's390-5.14-1' of git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux: (91 commits)
        s390/dasd: use register pair instead of register asm
        s390/qdio: get rid of register asm
        s390/ioasm: use symbolic names for asm operands
        s390/ioasm: get rid of register asm
        s390/cmf: get rid of register asm
        s390/lib,string: get rid of register asm
        s390/lib,uaccess: get rid of register asm
        s390/string: get rid of register asm
        s390/cmpxchg: use register pair instead of register asm
        s390/mm,pages-states: get rid of register asm
        s390/lib,xor: get rid of register asm
        s390/timex: get rid of register asm
        s390/hypfs: use register pair instead of register asm
        s390/zcrypt: Switch to flexible array member
        s390/speculation: Use statically initialized const for instructions
        virtio/s390: get rid of open-coded kvm hypercall
        s390/pci: add zpci_set_irq()/zpci_clear_irq()
        scripts/min-tool-version.sh: Raise minimum clang version to 13.0.0 for s390
        s390/ipl: use register pair instead of register asm
        s390/mem_detect: fix tprot() program check new psw handling
        ...
      2bb919b6
    • L
      Merge tag 'csky-for-linus-5.14-rc1' of git://github.com/c-sky/csky-linux · 0d4d4c6f
      Linus Torvalds 提交于
      Pull arch/csky updates from Guo Ren:
       "A small cleanup and a fixup"
      
      * tag 'csky-for-linus-5.14-rc1' of git://github.com/c-sky/csky-linux:
        csky: Kconfig: Remove unused selects
        csky: syscache: Fixup duplicate cache flush
      0d4d4c6f
    • L
      Merge tag 'cxl-for-5.14' of git://git.kernel.org/pub/scm/linux/kernel/git/cxl/cxl · 0c66a95c
      Linus Torvalds 提交于
      Pull CXL (Compute Express Link) updates from Dan Williams:
       "This subsystem is still in the build-out phase as the bulk of the
        update is improvements to enumeration and fleshing out the device
        model. In terms of new features, more mailbox commands have been added
        to the allowed-list in support of persistent memory provisioning
        support targeting v5.15.
      
        The critical update from an enumeration perspective is support for the
        CXL Fixed Memory Window Structure that indicates to Linux which system
        physical address ranges decode to the CXL Host Bridges in the system.
        This allows the driver to detect which address ranges have been mapped
        by firmware and what address ranges are available for future hotplug.
      
        So, again, mostly skeleton this round, with more meat targeting v5.15.
      
        Summary:
      
         - Add support for the CXL Fixed Memory Window Structure, a recent
           extension of the ACPI CEDT (CXL Early Discovery Table)
      
         - Add infrastructure for component registers
      
         - Add HDM (Host-managed device memory) decoder definitions
      
         - Define a device model for an HDM decoder tree
      
         - Bridge CXL persistent memory capabilities to an NVDIMM bus /
           device-model
      
         - Switch to fine grained mapping of CXL MMIO registers to allow
           different drivers / system software to own individual register
           blocks
      
         - Enable media provisioning commands, and publish the label storage
           area size in sysfs
      
         - Miscellaneous cleanups and fixes"
      
      * tag 'cxl-for-5.14' of git://git.kernel.org/pub/scm/linux/kernel/git/cxl/cxl: (34 commits)
        cxl/pci: Rename CXL REGLOC ID
        cxl/acpi: Use the ACPI CFMWS to create static decoder objects
        cxl/acpi: Add the Host Bridge base address to CXL port objects
        cxl/pmem: Register 'pmem' / cxl_nvdimm devices
        libnvdimm: Drop unused device power management support
        libnvdimm: Export nvdimm shutdown helper, nvdimm_delete()
        cxl/pmem: Add initial infrastructure for pmem support
        cxl/core: Add cxl-bus driver infrastructure
        cxl/pci: Add media provisioning required commands
        cxl/component_regs: Fix offset
        cxl/hdm: Fix decoder count calculation
        cxl/acpi: Introduce cxl_decoder objects
        cxl/acpi: Enumerate host bridge root ports
        cxl/acpi: Add downstream port data to cxl_port instances
        cxl/Kconfig: Default drivers to CONFIG_CXL_BUS
        cxl/acpi: Introduce the root of a cxl_port topology
        cxl/pci: Fixup devm_cxl_iomap_block() to take a 'struct device *'
        cxl/pci: Add HDM decoder capabilities
        cxl/pci: Reserve individual register block regions
        cxl/pci: Map registers based on capabilities
        ...
      0c66a95c
    • L
      Merge branch 'i2c/for-mergewindow' of git://git.kernel.org/pub/scm/linux/kernel/git/wsa/linux · 855ff900
      Linus Torvalds 提交于
      Pull i2c updates from Wolfram Sang:
      
       - core supports now bus regulators controlling power for SCL/SDA
      
       - quite some DT binding conversions to YAML
      
       - added a seperate DT binding for the optional SMBus Alert feature
      
       - documentation with examples how to deal with I2C sysfs files
      
       - some bigger rework for the i801 driver
      
       - and a few usual driver updates
      
      * 'i2c/for-mergewindow' of git://git.kernel.org/pub/scm/linux/kernel/git/wsa/linux: (42 commits)
        i2c: ali1535: mention that the device should not be disabled
        i2c: mpc: Restore reread of I2C status register
        i2c: core-smbus: Expose PEC calculate function for generic use
        Documentation: i2c: Add doc for I2C sysfs
        i2c: core: Disable client irq on reboot/shutdown
        dt-bindings: i2c: update bindings for MT8195 SoC
        i2c: imx: Fix some checkpatch warnings
        i2c: davinci: Simplify with dev_err_probe()
        i2c: cadence: Simplify with dev_err_probe()
        i2c: xiic: Simplify with dev_err_probe()
        i2c: cadence: Clear HOLD bit before xfer_size register rolls over
        dt-bindings: i2c: ce4100: Replace "ti,pcf8575" by "nxp,pcf8575"
        i2c: i801: Improve i801_setup_hstcfg
        i2c: i801: Use driver name constant instead of function dev_driver_string
        i2c: i801: Simplify initialization of i2c_board_info in i801_probe_optional_slaves
        i2c: i801: Improve status polling
        i2c: cht-wc: Replace of_node by NULL
        i2c: riic: Add RZ/G2L support
        dt-bindings: i2c: renesas,riic: Document RZ/G2L I2C controller
        dt-bindings: i2c: renesas,iic: Convert to json-schema
        ...
      855ff900
    • M
      scsi: blkcg: Fix application ID config options · d2500a0c
      Martin K. Petersen 提交于
      Commit d2bcbeab ("scsi: blkcg: Add app identifier support for
      blkcg") introduced an FC_APPID config option under SCSI. However, the
      added config option is not used anywhere. Simply remove it.
      
      The block layer BLK_CGROUP_FC_APPID config option is what actually
      controls whether the application ID code should be built or not. Make
      this option dependent on NVMe over FC since that is currently the only
      transport which supports the capability.
      
      Fixes: d2bcbeab ("scsi: blkcg: Add app identifier support for blkcg")
      Reported-by: NLinus Torvalds <torvalds@linux-foundation.org>
      Signed-off-by: NMartin K. Petersen <martin.petersen@oracle.com>
      Reviewed-by: NChristoph Hellwig <hch@lst.de>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      d2500a0c
  2. 04 7月, 2021 9 次提交
    • G
      csky: Kconfig: Remove unused selects · 90dc8c0e
      Guo Ren 提交于
       - GENERIC_ALLOCATOR is duplicated
       - Remove USB_ARCH_HAS_OHCI & USB_ARCH_HAS_EHCI, because they
         have been removed from linux.
      Signed-off-by: NGuo Ren <guoren@linux.alibaba.com>
      Cc: Arnd Bergmann <arnd@arndb.de>
      90dc8c0e
    • G
      csky: syscache: Fixup duplicate cache flush · 6ea42c84
      Guo Ren 提交于
      The current csky logic of sys_cacheflush is wrong, it'll cause
      icache flush call dcache flush again. Now fixup it with a
      conditional "break & fallthrough".
      
      Fixes: 997153b9 ("csky: Add flush_icache_mm to defer flush icache all")
      Fixes: 0679d29d ("csky: fix syscache.c fallthrough warning")
      Acked-by: NRandy Dunlap <rdunlap@infradead.org>
      Co-Developed-by: NRandy Dunlap <rdunlap@infradead.org>
      Signed-off-by: NGuo Ren <guoren@linux.alibaba.com>
      Cc: Arnd Bergmann <arnd@arndb.de>
      6ea42c84
    • L
      Merge tag 'leds-5.14-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/pavel/linux-leds · 303392fd
      Linus Torvalds 提交于
      Pull LED updates from Pavel Machek:
       "This contains quite a lot of fixes, with more fixes in my inbox that
        did not make it (sorry)"
      
      * tag 'leds-5.14-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/pavel/linux-leds: (36 commits)
        leds: lgm: Fix up includes
        leds: ktd2692: Fix an error handling path
        leds: as3645a: Fix error return code in as3645a_parse_node()
        leds: turris-omnia: add missing MODULE_DEVICE_TABLE
        leds: lp55xx: Initialize enable GPIO direction to output
        leds: lm36274: Add missed property.h
        leds: el15203000: Make error handling more robust
        leds: pwm: Make error handling more robust
        leds: lt3593: Make use of device properties
        leds: lp50xx: Put fwnode in error case during ->probe()
        leds: lm3697: Don't spam logs when probe is deferred
        leds: lm3692x: Put fwnode in any case during ->probe()
        leds: lm36274: Correct headers (of*.h -> mod_devicetable.h)
        leds: lm36274: Put fwnode in error case during ->probe()
        leds: lm3532: Make error handling more robust
        leds: lm3532: select regmap I2C API
        leds: lgm-sso: Drop duplicate NULL check for GPIO operations
        leds: lgm-sso: Remove unneeded of_match_ptr()
        leds: lgm-sso: Fix clock handling
        leds: el15203000: Introduce to_el15203000_led() helper
        ...
      303392fd
    • L
      Merge tag 'vfio-v5.14-rc1' of git://github.com/awilliam/linux-vfio · 8e8d9442
      Linus Torvalds 提交于
      Pull VFIO updates from Alex Williamson:
      
       - Module reference fixes, structure renaming (Max Gurtovoy)
      
       - Export and use common pci_dev_trylock() (Luis Chamberlain)
      
       - Enable direct mdev device creation and probing by parent (Christoph
         Hellwig & Jason Gunthorpe)
      
       - Fix mdpy error path leak (Colin Ian King)
      
       - Fix mtty list entry leak (Jason Gunthorpe)
      
       - Enforce mtty device limit (Alex Williamson)
      
       - Resolve concurrent vfio-pci mmap faults (Alex Williamson)
      
      * tag 'vfio-v5.14-rc1' of git://github.com/awilliam/linux-vfio:
        vfio/pci: Handle concurrent vma faults
        vfio/mtty: Enforce available_instances
        vfio/mtty: Delete mdev_devices_list
        vfio: use the new pci_dev_trylock() helper to simplify try lock
        PCI: Export pci_dev_trylock() and pci_dev_unlock()
        vfio/mdpy: Fix memory leak of object mdev_state->vconfig
        vfio/iommu_type1: rename vfio_group struck to vfio_iommu_group
        vfio/mbochs: Convert to use vfio_register_group_dev()
        vfio/mdpy: Convert to use vfio_register_group_dev()
        vfio/mtty: Convert to use vfio_register_group_dev()
        vfio/mdev: Allow the mdev_parent_ops to specify the device driver to bind
        vfio/mdev: Remove CONFIG_VFIO_MDEV_DEVICE
        driver core: Export device_driver_attach()
        driver core: Don't return EPROBE_DEFER to userspace during sysfs bind
        driver core: Flow the return code from ->probe() through to sysfs bind
        driver core: Better distinguish probe errors in really_probe
        driver core: Pull required checks into driver_probe_device()
        vfio/platform: remove unneeded parent_module attribute
        vfio: centralize module refcount in subsystem layer
      8e8d9442
    • L
      Merge branch 'work.namei' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs · 58ec9059
      Linus Torvalds 提交于
      Pull vfs name lookup updates from Al Viro:
       "Small namei.c patch series, mostly to simplify the rules for nameidata
        state. It's actually from the previous cycle - but I didn't post it
        for review in time...
      
        Changes visible outside of fs/namei.c: file_open_root() calling
        conventions change, some freed bits in LOOKUP_... space"
      
      * 'work.namei' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs:
        namei: make sure nd->depth is always valid
        teach set_nameidata() to handle setting the root as well
        take LOOKUP_{ROOT,ROOT_GRABBED,JUMPED} out of LOOKUP_... space
        switch file_open_root() to struct path
      58ec9059
    • L
      Merge branch 'work.iov_iter' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs · d3acb15a
      Linus Torvalds 提交于
      Pull iov_iter updates from Al Viro:
       "iov_iter cleanups and fixes.
      
        There are followups, but this is what had sat in -next this cycle. IMO
        the macro forest in there became much thinner and easier to follow..."
      
      * 'work.iov_iter' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs: (37 commits)
        csum_and_copy_to_pipe_iter(): leave handling of csum_state to caller
        clean up copy_mc_pipe_to_iter()
        pipe_zero(): we don't need no stinkin' kmap_atomic()...
        iov_iter: clean csum_and_copy_...() primitives up a bit
        copy_page_from_iter(): don't need kmap_atomic() for kvec/bvec cases
        copy_page_to_iter(): don't bother with kmap_atomic() for bvec/kvec cases
        iterate_xarray(): only of the first iteration we might get offset != 0
        pull handling of ->iov_offset into iterate_{iovec,bvec,xarray}
        iov_iter: make iterator callbacks use base and len instead of iovec
        iov_iter: make the amount already copied available to iterator callbacks
        iov_iter: get rid of separate bvec and xarray callbacks
        iov_iter: teach iterate_{bvec,xarray}() about possible short copies
        iterate_bvec(): expand bvec.h macro forest, massage a bit
        iov_iter: unify iterate_iovec and iterate_kvec
        iov_iter: massage iterate_iovec and iterate_kvec to logics similar to iterate_bvec
        iterate_and_advance(): get rid of magic in case when n is 0
        csum_and_copy_to_iter(): massage into form closer to csum_and_copy_from_iter()
        iov_iter: replace iov_iter_copy_from_user_atomic() with iterator-advancing variant
        [xarray] iov_iter_npages(): just use DIV_ROUND_UP()
        iov_iter_npages(): don't bother with iterate_all_kinds()
        ...
      d3acb15a
    • L
      Merge branch 'work.d_path' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs · f92a322a
      Linus Torvalds 提交于
      Pull vfs d_path() updates from Al Viro:
       "d_path.c refactoring"
      
      * 'work.d_path' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs:
        getcwd(2): clean up error handling
        d_path: prepend_path() is unlikely to return non-zero
        d_path: prepend_path(): lift the inner loop into a new helper
        d_path: prepend_path(): lift resetting b in case when we'd return 3 out of loop
        d_path: prepend_path(): get rid of vfsmnt
        d_path: introduce struct prepend_buffer
        d_path: make prepend_name() boolean
        d_path: lift -ENAMETOOLONG handling into callers of prepend_path()
        d_path: don't bother with return value of prepend()
        getcwd(2): saner logics around prepend_path() call
        d_path: get rid of path_with_deleted()
        d_path: regularize handling of root dentry in __dentry_path()
        d_path: saner calling conventions for __dentry_path()
        d_path: "\0" is {0,0}, not {0}
      f92a322a
    • L
      Merge tag 'trace-v5.14' of git://git.kernel.org/pub/scm/linux/kernel/git/rostedt/linux-trace · 757fa80f
      Linus Torvalds 提交于
      Pull tracing updates from Steven Rostedt:
      
       - Added option for per CPU threads to the hwlat tracer
      
       - Have hwlat tracer handle hotplug CPUs
      
       - New tracer: osnoise, that detects latency caused by interrupts,
         softirqs and scheduling of other tasks.
      
       - Added timerlat tracer that creates a thread and measures in detail
         what sources of latency it has for wake ups.
      
       - Removed the "success" field of the sched_wakeup trace event. This has
         been hardcoded as "1" since 2015, no tooling should be looking at it
         now. If one exists, we can revert this commit, fix that tool and try
         to remove it again in the future.
      
       - tgid mapping fixed to handle more than PID_MAX_DEFAULT pids/tgids.
      
       - New boot command line option "tp_printk_stop", as tp_printk causes
         trace events to write to console. When user space starts, this can
         easily live lock the system. Having a boot option to stop just after
         boot up is useful to prevent that from happening.
      
       - Have ftrace_dump_on_oops boot command line option take numbers that
         match the numbers shown in /proc/sys/kernel/ftrace_dump_on_oops.
      
       - Bootconfig clean ups, fixes and enhancements.
      
       - New ktest script that tests bootconfig options.
      
       - Add tracepoint_probe_register_may_exist() to register a tracepoint
         without triggering a WARN*() if it already exists. BPF has a path
         from user space that can do this. All other paths are considered a
         bug.
      
       - Small clean ups and fixes
      
      * tag 'trace-v5.14' of git://git.kernel.org/pub/scm/linux/kernel/git/rostedt/linux-trace: (49 commits)
        tracing: Resize tgid_map to pid_max, not PID_MAX_DEFAULT
        tracing: Simplify & fix saved_tgids logic
        treewide: Add missing semicolons to __assign_str uses
        tracing: Change variable type as bool for clean-up
        trace/timerlat: Fix indentation on timerlat_main()
        trace/osnoise: Make 'noise' variable s64 in run_osnoise()
        tracepoint: Add tracepoint_probe_register_may_exist() for BPF tracing
        tracing: Fix spelling in osnoise tracer "interferences" -> "interference"
        Documentation: Fix a typo on trace/osnoise-tracer
        trace/osnoise: Fix return value on osnoise_init_hotplug_support
        trace/osnoise: Make interval u64 on osnoise_main
        trace/osnoise: Fix 'no previous prototype' warnings
        tracing: Have osnoise_main() add a quiescent state for task rcu
        seq_buf: Make trace_seq_putmem_hex() support data longer than 8
        seq_buf: Fix overflow in seq_buf_putmem_hex()
        trace/osnoise: Support hotplug operations
        trace/hwlat: Support hotplug operations
        trace/hwlat: Protect kdata->kthread with get/put_online_cpus
        trace: Add timerlat tracer
        trace: Add osnoise tracer
        ...
      757fa80f
    • L
      Merge tag 'devicetree-for-5.14' of git://git.kernel.org/pub/scm/linux/kernel/git/robh/linux · a70bb580
      Linus Torvalds 提交于
      Pull devicetree updates from Rob Herring:
      
       - Refine reserved memory nomap handling
      
       - Merge some PCI and non-PCI address handling implementations
      
       - Simplify of_address.h header ifdefs
      
       - Improve printk handling of some 64-bit types
      
       - Convert adi,adv7511, Arm ccree, Arm SCMI, Arm SCU, Arm TWD timer, Arm
         VIC, arm,sbsa-gwdt, Arm/Amlogic SCPI, Aspeed I2C, Broadcom iProc PWM,
         linaro,optee-tz, MDIO GPIO, Mediatek RNG, MTD physmap, NXP
         pcf8563/pcf85263/pcf85363, Renesas TPU, renesas,emev2-smu,
         renesas,r9a06g032-sysctrl, sysc-rmobile, Tegra20 EMC, TI AM56 PCI, TI
         OMAP mailbox, TI SCI bindings, virtio-mmio, Zynq FPGA, and ZynqMP RTC
         to DT schema
      
       - Convert mux and mux controller bindings to schema. This includes MDIO
         IIO, and I2C muxes.
      
       - Add Arm PL031 RTC binding schema
      
       - Add vendor prefixes for StarFive Technology Co. Ltd. and Insignal Ltd
      
       - Fix some stale doc references
      
       - Remove stale property-units.txt. Superseded by schema in dt-schema
         repo.
      
       - Fixes for 'unevaluatedProperties' handling (enabled with experimental
         json-schema support)
      
       - Drop redundant usage of minItems and maxItems across the tree
      
       - Update some examples to use bindings with a schema
      
      * tag 'devicetree-for-5.14' of git://git.kernel.org/pub/scm/linux/kernel/git/robh/linux: (83 commits)
        dt-bindings: Fix 'unevaluatedProperties' errors in DT graph users
        dt-bindings: display: renesas,du: Fix 'ports' reference
        dt-bindings: media: adv7180: Add missing video-interfaces.yaml reference
        dt-bindings: crypto: ccree: Convert to json-schema
        dt-bindings: fpga: zynq: convert bindings to YAML
        dt-bindings: rtc: zynqmp: convert bindings to YAML
        dt-bindings: interrupt-controller: Convert ARM VIC to json-schema
        of: of_reserved_mem: mark nomap memory instead of removing
        of: of_reserved_mem: only call memblock_free for normal reserved memory
        dt-bindings: Drop redundant minItems/maxItems
        dt-bindings: spmi: Correct 'reg' schema
        of: reserved-memory: Add stub for RESERVEDMEM_OF_DECLARE()
        dt-bindings: clk: vc5: Fix example
        dt-bindings: timer: renesas,tmu: add r8a779a0 TMU support
        dt-bindings: drm: bridge: adi,adv7511.txt: convert to yaml
        dt-bindings: PCI: ti,am65: Convert PCIe host/endpoint mode dt-bindings to YAML
        of: Remove superfluous casts when printing u64 values
        of: Fix truncation of memory sizes on 32-bit platforms
        dt-bindings: rtc: nxp,pcf8563: Absorb pcf85263/pcf85363 bindings
        dt-bindings: pwm: Use examples with documented/matching schema
        ...
      a70bb580
  3. 03 7月, 2021 14 次提交
    • L
      Revert "ALSA: usb-audio: Reduce latency at playback start" · 4b820e16
      Linus Torvalds 提交于
      This reverts commit 9ce650a7.
      
      This commit causes watchdog lockups on my machine, and while I have no
      idea what the cause is, it bisected right to this commit, and reverting
      the change promptly fixes it.
      
      At least occasionally one of the watchdog call traces was
      
        Call Trace:
          _raw_spin_lock_irqsave+0x35/0x40
          snd_pcm_period_elapsed+0x1b/0xa0 [snd_pcm]
          snd_usb_endpoint_start+0x1a0/0x3c0 [snd_usb_audio]
          start_endpoints+0x23/0x90 [snd_usb_audio]
          snd_usb_substream_playback_trigger+0x7b/0x1a0 [snd_usb_audio]
          snd_pcm_common_ioctl+0x1c44/0x2360 [snd_pcm]
          snd_pcm_ioctl+0x2e/0x40 [snd_pcm]
          __se_sys_ioctl+0x72/0xc0
          do_syscall_64+0x4c/0xa0
          entry_SYSCALL_64_after_hwframe+0x44/0xae
      
      so presumably it's a locking error on that substream spinlock that
      snd_pcm_period_elapsed() takes.  But at this point I just want to have a
      working system so that I can continue the merge window work tomorrow.
      
      Cc: Takashi Iwai <tiwai@suse.de>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      4b820e16
    • L
      Merge tag 'sound-5.14-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound · d6b63b5b
      Linus Torvalds 提交于
      Pull sound updates from Takashi Iwai:
       "As the diffstat scatters over the tree, we've got many tree-wide small
        changes, but also got quite a few intrusive changes in the core side.
        The only ABI-visible core change is the new rawmidi framing mode
        support while others are kernel-internal, mostly code refactoring
        and/or nice improvements.
      
        Here are some highlights:
      
        Core:
         - A new framing access mode for rawmidi to get timestamps
         - Cleanup / refactoring of buffer memory management helper code
         - Support for automatic negotiation of ASoC DAI formats
         - Revival of software suspend for PCM and control core, as a
           preliminary work for PCI BAR rescan support
      
        ASoC:
         - Accessory detection support for several Qualcomm parts
         - Support for IEC958 control with hdmi-codec
         - Merging of Tegra machine drivers into a single driver
         - Support for AmLogic SM1 TOACODEC, Intel AlderLake-M, several NXP
           i.MX8 variants, NXP TFA1 and TDF9897, Rockchip RK817, Qualcomm
           Quinary MI2S, Texas Instruments TAS2505
      
        USB-audio:
         - Reduction of latency at playback start
         - Code cleanup / fixes of usx2y driver
         - Scarlett2 mixer code fixes and enhancements
         - Quirks for Ozone and Denon devices
      
        HD-audio:
         - A few quirks for HP and ASUS machines
         - Display power management fixes
      
        Others:
         - FireWire code refactoring and enhancements
         - Tree-wide trivial coding-style fixes"
      
      * tag 'sound-5.14-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound: (594 commits)
        ALSA: usb-audio: scarlett2: Fix for loop increment in scarlett2_usb_get_config
        ALSA: hda/realtek: fix mute/micmute LEDs for HP ProBook 630 G8
        ALSA: hda/realtek: fix mute/micmute LEDs for HP ProBook 445 G8
        ALSA: hda/realtek: fix mute/micmute LEDs for HP ProBook 450 G8
        ALSA: hda/realtek - Add ALC285 HP init procedure
        ALSA: hda/realtek - Add type for ALC287
        ALSA: scarlett2: Fix scarlett2_*_ctl_put() return values again
        ALSA: scarlett2: Fix pad count for 18i8 Gen 3
        ALSA: hda/realtek: fix mute/micmute LEDs for HP EliteBook 830 G8 Notebook PC
        ALSA: firewire-lib: Fix 'amdtp_domain_start()' when no AMDTP_OUT_STREAM stream is found
        ASoC: qcom: lpass-cpu: mark IRQ_CLEAR register as volatile and readable
        ALSA: hda: Release codec display power during shutdown/reboot
        ALSA: hda: Release controller display power during shutdown/reboot
        ALSA: hda/realtek: Apply LED fixup for HP Dragonfly G1, too
        ASoC: fsl: remove unnecessary oom message
        ASoC: tlv320aic32x4: dt-bindings: add TAS2505 to compatible
        ASoC: tlv320aic32x4: add support for TAS2505
        ASoC: tlv320aic32x4: add type to device private data struct
        ASoC: tegra30: ahub: Use devm_platform_get_and_ioremap_resource()
        ASoC: tegra: tegra210_admaif: Use devm_platform_get_and_ioremap_resource()
        ...
      d6b63b5b
    • L
      Merge tag 'scsi-misc' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi · bd31b9ef
      Linus Torvalds 提交于
      Pull SCSI updates from James Bottomley:
       "This series consists of the usual driver updates (ufs, ibmvfc,
        megaraid_sas, lpfc, elx, mpi3mr, qedi, iscsi, storvsc, mpt3sas) with
        elx and mpi3mr being new drivers.
      
        The major core change is a rework to drop the status byte handling
        macros and the old bit shifted definitions and the rest of the updates
        are minor fixes"
      
      * tag 'scsi-misc' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi: (287 commits)
        scsi: aha1740: Avoid over-read of sense buffer
        scsi: arcmsr: Avoid over-read of sense buffer
        scsi: ips: Avoid over-read of sense buffer
        scsi: ufs: ufs-mediatek: Add missing of_node_put() in ufs_mtk_probe()
        scsi: elx: libefc: Fix IRQ restore in efc_domain_dispatch_frame()
        scsi: elx: libefc: Fix less than zero comparison of a unsigned int
        scsi: elx: efct: Fix pointer error checking in debugfs init
        scsi: elx: efct: Fix is_originator return code type
        scsi: elx: efct: Fix link error for _bad_cmpxchg
        scsi: elx: efct: Eliminate unnecessary boolean check in efct_hw_command_cancel()
        scsi: elx: efct: Do not use id uninitialized in efct_lio_setup_session()
        scsi: elx: efct: Fix error handling in efct_hw_init()
        scsi: elx: efct: Remove redundant initialization of variable lun
        scsi: elx: efct: Fix spelling mistake "Unexected" -> "Unexpected"
        scsi: lpfc: Fix build error in lpfc_scsi.c
        scsi: target: iscsi: Remove redundant continue statement
        scsi: qla4xxx: Remove redundant continue statement
        scsi: ppa: Switch to use module_parport_driver()
        scsi: imm: Switch to use module_parport_driver()
        scsi: mpt3sas: Fix error return value in _scsih_expander_add()
        ...
      bd31b9ef
    • L
      Merge tag 'xfs-5.14-merge-6' of git://git.kernel.org/pub/scm/fs/xfs/xfs-linux · 9f7b640f
      Linus Torvalds 提交于
      Pull xfs updates from Darrick Wong:
       "Most of the work this cycle has been on refactoring various parts of
        the codebase. The biggest non-cleanup changes are (1) reducing the
        number of cache flushes sent when writing the log; (2) a substantial
        number of log recovery fixes; and (3) I started accepting pull
        requests from contributors if the commits in their branches match
        what's been sent to the list.
      
        For a week or so I /had/ staged a major cleanup of the logging code
        from Dave Chinner, but it exposed so many lurking bugs in other parts
        of the logging and log recovery code that I decided to defer that
        patchset until we can address those latent bugs.
      
        Larger cleanups this time include walking the incore inode cache (me)
        and rework of the extended attribute code (Allison) to prepare it for
        adding logged xattr updates (and directory tree parent pointers) in
        future releases.
      
        Summary:
      
         - Refactor the buffer cache to use bulk page allocation
      
         - Convert agnumber-based AG iteration to walk per-AG structures
      
         - Clean up some unit conversions and other code warts
      
         - Reduce spinlock contention in the directio fastpath
      
         - Collapse all the inode cache walks into a single function
      
         - Remove indirect function calls from the inode cache walk code
      
         - Dramatically reduce the number of cache flushes sent when writing
           log buffers
      
         - Preserve inode sickness reports for longer
      
         - Rename xfs_eofblocks since it controls inode cache walks
      
         - Refactor the extended attribute code to prepare it for the addition
           of log intent items to make xattrs fully transactional
      
         - A few fixes to earlier large patchsets
      
         - Log recovery fixes so that we don't accidentally mark the log clean
           when log intent recovery fails
      
         - Fix some latent SOB errors
      
         - Clean up shutdown messages that get logged to dmesg
      
         - Fix a regression in the online shrink code
      
         - Fix a UAF in the buffer logging code if the fs goes offline
      
         - Fix uninitialized error variables
      
         - Fix a UAF in the CIL when commited log item callbacks race with a
           shutdown
      
         - Fix a bug where the CIL could hang trying to push part of the log
           ring buffer that hasn't been filled yet"
      
      * tag 'xfs-5.14-merge-6' of git://git.kernel.org/pub/scm/fs/xfs/xfs-linux: (102 commits)
        xfs: don't wait on future iclogs when pushing the CIL
        xfs: Fix a CIL UAF by getting get rid of the iclog callback lock
        xfs: remove callback dequeue loop from xlog_state_do_iclog_callbacks
        xfs: don't nest icloglock inside ic_callback_lock
        xfs: Initialize error in xfs_attr_remove_iter
        xfs: fix endianness issue in xfs_ag_shrink_space
        xfs: remove dead stale buf unpin handling code
        xfs: hold buffer across unpin and potential shutdown processing
        xfs: force the log offline when log intent item recovery fails
        xfs: fix log intent recovery ENOSPC shutdowns when inactivating inodes
        xfs: shorten the shutdown messages to a single line
        xfs: print name of function causing fs shutdown instead of hex pointer
        xfs: fix type mismatches in the inode reclaim functions
        xfs: separate primary inode selection criteria in xfs_iget_cache_hit
        xfs: refactor the inode recycling code
        xfs: add iclog state trace events
        xfs: xfs_log_force_lsn isn't passed a LSN
        xfs: Fix CIL throttle hang when CIL space used going backwards
        xfs: journal IO cache flush reductions
        xfs: remove need_start_rec parameter from xlog_write()
        ...
      9f7b640f
    • L
      Merge tag 'jfs-5.14' of git://github.com/kleikamp/linux-shaggy · e4aa67b0
      Linus Torvalds 提交于
      Pull jfs updates from David Kleikamp:
       "JFS fixes for 5.14"
      
      * tag 'jfs-5.14' of git://github.com/kleikamp/linux-shaggy:
        jfs: Avoid field-overflowing memcpy()
        jfs: remove unnecessary oom message
        jfs: fix GPF in diFree
        fs/jfs: Fix missing error code in lmLogInit()
        jfs: Remove trailing semicolon in macros
        fs: Fix typo issue
      e4aa67b0
    • L
      Merge tag 'configfs-5.13' of git://git.infradead.org/users/hch/configfs · ced4cca7
      Linus Torvalds 提交于
      Pull configfs updates from Christoph Hellwig:
      
       - fix a memleak in configfs_release_bin_file (Chung-Chiang Cheng)
      
       - implement the .read_iter and .write_iter (Bart Van Assche)
      
       - minor cleanups (Bart Van Assche, me)
      
      * tag 'configfs-5.13' of git://git.infradead.org/users/hch/configfs:
        configfs: simplify configfs_release_bin_file
        configfs: fix memleak in configfs_release_bin_file
        configfs: implement the .read_iter and .write_iter methods
        configfs: drop pointless kerneldoc comments
        configfs: fix the kerneldoc comment for configfs_create_bin_file
      ced4cca7
    • L
      Merge tag 'dma-mapping-5.14' of git://git.infradead.org/users/hch/dma-mapping · e72b0696
      Linus Torvalds 提交于
      Pull dma-mapping updates from Christoph Hellwig:
      
       - a trivivial whitespace fix (Zhen Lei)
      
       - report -EEXIST errors in add_dma_entry (Hamza Mahfooz)
      
      * tag 'dma-mapping-5.14' of git://git.infradead.org/users/hch/dma-mapping:
        dma-debug: report -EEXIST errors in add_dma_entry
        dma-mapping: remove a trailing space
      e72b0696
    • L
      Merge tag 'iommu-updates-v5.14' of git://git.kernel.org/pub/scm/linux/kernel/git/joro/iommu · cd3eb7ef
      Linus Torvalds 提交于
      Pull iommu updates from Joerg Roedel:
      
       - SMMU Updates from Will Deacon:
      
           - SMMUv3:
              - Support stalling faults for platform devices
              - Decrease defaults sizes for the event and PRI queues
           - SMMUv2:
              - Support for a new '->probe_finalize' hook, needed by Nvidia
              - Even more Qualcomm compatible strings
              - Avoid Adreno TTBR1 quirk for DB820C platform
      
       - Intel VT-d updates from Lu Baolu:
      
           - Convert Intel IOMMU to use sva_lib helpers in iommu core
           - ftrace and debugfs supports for page fault handling
           - Support asynchronous nested capabilities
           - Various misc cleanups
      
       - Support for new VIOT ACPI table to make the VirtIO IOMMU
         available on x86
      
       - Add the amd_iommu=force_enable command line option to enable
         the IOMMU on platforms where they are known to cause problems
      
       - Support for version 2 of the Rockchip IOMMU
      
       - Various smaller fixes, cleanups and refactorings
      
      * tag 'iommu-updates-v5.14' of git://git.kernel.org/pub/scm/linux/kernel/git/joro/iommu: (66 commits)
        iommu/virtio: Enable x86 support
        iommu/dma: Pass address limit rather than size to iommu_setup_dma_ops()
        ACPI: Add driver for the VIOT table
        ACPI: Move IOMMU setup code out of IORT
        ACPI: arm64: Move DMA setup operations out of IORT
        iommu/vt-d: Fix dereference of pointer info before it is null checked
        iommu: Update "iommu.strict" documentation
        iommu/arm-smmu: Check smmu->impl pointer before dereferencing
        iommu/arm-smmu-v3: Remove unnecessary oom message
        iommu/arm-smmu: Fix arm_smmu_device refcount leak in address translation
        iommu/arm-smmu: Fix arm_smmu_device refcount leak when arm_smmu_rpm_get fails
        iommu/vt-d: Fix linker error on 32-bit
        iommu/vt-d: No need to typecast
        iommu/vt-d: Define counter explicitly as unsigned int
        iommu/vt-d: Remove unnecessary braces
        iommu/vt-d: Removed unused iommu_count in dmar domain
        iommu/vt-d: Use bitfields for DMAR capabilities
        iommu/vt-d: Use DEVICE_ATTR_RO macro
        iommu/vt-d: Fix out-bounds-warning in intel/svm.c
        iommu/vt-d: Add PRQ handling latency sampling
        ...
      cd3eb7ef
    • L
      Merge tag 'linux-kselftest-next-5.14-rc1' of... · 35e43538
      Linus Torvalds 提交于
      Merge tag 'linux-kselftest-next-5.14-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest
      
      Pull Kselftest update from Shuah Khan:
       "Fixes to existing tests and framework:
      
         - migrate sgx test to kselftest harness
      
         - add new test cases to sgx test
      
         - ftrace test fix event-no-pid on 1-core machine
      
         - splice test adjust for handler fallback removal"
      
      * tag 'linux-kselftest-next-5.14-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest:
        selftests/sgx: remove checks for file execute permissions
        selftests/ftrace: fix event-no-pid on 1-core machine
        selftests/sgx: Refine the test enclave to have storage
        selftests/sgx: Add EXPECT_EEXIT() macro
        selftests/sgx: Dump enclave memory map
        selftests/sgx: Migrate to kselftest harness
        selftests/sgx: Rename 'eenter' and 'sgx_call_vdso'
        selftests: timers: rtcpie: skip test if default RTC device does not exist
        selftests: lib.mk: Also install "config" and "settings"
        selftests: splice: Adjust for handler fallback removal
        selftests/tls: Add {} to avoid static checker warning
        selftests/resctrl: Fix incorrect parsing of option "-t"
      35e43538
    • L
      Merge tag 'linux-kselftest-kunit-fixes-5.14-rc1' of... · a48ad6e7
      Linus Torvalds 提交于
      Merge tag 'linux-kselftest-kunit-fixes-5.14-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest
      
      Pull KUnit update from Shuah Khan:
       "Fixes and features:
      
         - add support for skipped tests
      
         - introduce kunit_kmalloc_array/kunit_kcalloc() helpers
      
         - add gnu_printf specifiers
      
         - add kunit_shutdown
      
         - add unit test for filtering suites by names
      
         - convert lib/test_list_sort.c to use KUnit
      
         - code organization moving default config to tools/testing/kunit
      
         - refactor of internal parser input handling
      
         - cleanups and updates to documentation
      
         - code cleanup related to casts"
      
      * tag 'linux-kselftest-kunit-fixes-5.14-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/shuah/linux-kselftest: (29 commits)
        kunit: add unit test for filtering suites by names
        kasan: test: make use of kunit_skip()
        kunit: test: Add example tests which are always skipped
        kunit: tool: Support skipped tests in kunit_tool
        kunit: Support skipped tests
        thunderbolt: test: Reinstate a few casts of bitfields
        kunit: tool: internal refactor of parser input handling
        lib/test: convert lib/test_list_sort.c to use KUnit
        kunit: introduce kunit_kmalloc_array/kunit_kcalloc() helpers
        kunit: Remove the unused all_tests.config
        kunit: Move default config from arch/um -> tools/testing/kunit
        kunit: arch/um/configs: Enable KUNIT_ALL_TESTS by default
        kunit: Add gnu_printf specifiers
        lib/cmdline_kunit: Remove a cast which are no-longer required
        kernel/sysctl-test: Remove some casts which are no-longer required
        thunderbolt: test: Remove some casts which are no longer required
        mmc: sdhci-of-aspeed: Remove some unnecessary casts from KUnit tests
        iio: Remove a cast in iio-test-format which is no longer required
        device property: Remove some casts in property-entry-test
        Documentation: kunit: Clean up some string casts in examples
        ...
      a48ad6e7
    • L
      Merge tag 'powerpc-5.14-1' of git://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux · 019b3fd9
      Linus Torvalds 提交于
      Pull powerpc updates from Michael Ellerman:
      
       - A big series refactoring parts of our KVM code, and converting some
         to C.
      
       - Support for ARCH_HAS_SET_MEMORY, and ARCH_HAS_STRICT_MODULE_RWX on
         some CPUs.
      
       - Support for the Microwatt soft-core.
      
       - Optimisations to our interrupt return path on 64-bit.
      
       - Support for userspace access to the NX GZIP accelerator on PowerVM on
         Power10.
      
       - Enable KUAP and KUEP by default on 32-bit Book3S CPUs.
      
       - Other smaller features, fixes & cleanups.
      
      Thanks to: Andy Shevchenko, Aneesh Kumar K.V, Arnd Bergmann, Athira
      Rajeev, Baokun Li, Benjamin Herrenschmidt, Bharata B Rao, Christophe
      Leroy, Daniel Axtens, Daniel Henrique Barboza, Finn Thain, Geoff Levand,
      Haren Myneni, Jason Wang, Jiapeng Chong, Joel Stanley, Jordan Niethe,
      Kajol Jain, Nathan Chancellor, Nathan Lynch, Naveen N. Rao, Nicholas
      Piggin, Nick Desaulniers, Paul Mackerras, Russell Currey, Sathvika
      Vasireddy, Shaokun Zhang, Stephen Rothwell, Sudeep Holla, Suraj Jitindar
      Singh, Tom Rix, Vaibhav Jain, YueHaibing, Zhang Jianhua, and Zhen Lei.
      
      * tag 'powerpc-5.14-1' of git://git.kernel.org/pub/scm/linux/kernel/git/powerpc/linux: (218 commits)
        powerpc: Only build restart_table.c for 64s
        powerpc/64s: move ret_from_fork etc above __end_soft_masked
        powerpc/64s/interrupt: clean up interrupt return labels
        powerpc/64/interrupt: add missing kprobe annotations on interrupt exit symbols
        powerpc/64: enable MSR[EE] in irq replay pt_regs
        powerpc/64s/interrupt: preserve regs->softe for NMI interrupts
        powerpc/64s: add a table of implicit soft-masked addresses
        powerpc/64e: remove implicit soft-masking and interrupt exit restart logic
        powerpc/64e: fix CONFIG_RELOCATABLE build warnings
        powerpc/64s: fix hash page fault interrupt handler
        powerpc/4xx: Fix setup_kuep() on SMP
        powerpc/32s: Fix setup_{kuap/kuep}() on SMP
        powerpc/interrupt: Use names in check_return_regs_valid()
        powerpc/interrupt: Also use exit_must_hard_disable() on PPC32
        powerpc/sysfs: Replace sizeof(arr)/sizeof(arr[0]) with ARRAY_SIZE
        powerpc/ptrace: Refactor regs_set_return_{msr/ip}
        powerpc/ptrace: Move set_return_regs_changed() before regs_set_return_{msr/ip}
        powerpc/stacktrace: Fix spurious "stale" traces in raise_backtrace_ipi()
        powerpc/pseries/vas: Include irqdomain.h
        powerpc: mark local variables around longjmp as volatile
        ...
      019b3fd9
    • L
      Merge tag 'asm-generic-unaligned-5.14' of... · 4cad6719
      Linus Torvalds 提交于
      Merge tag 'asm-generic-unaligned-5.14' of git://git.kernel.org/pub/scm/linux/kernel/git/arnd/asm-generic
      
      Pull asm/unaligned.h unification from Arnd Bergmann:
       "Unify asm/unaligned.h around struct helper
      
        The get_unaligned()/put_unaligned() helpers are traditionally
        architecture specific, with the two main variants being the
        "access-ok.h" version that assumes unaligned pointer accesses always
        work on a particular architecture, and the "le-struct.h" version that
        casts the data to a byte aligned type before dereferencing, for
        architectures that cannot always do unaligned accesses in hardware.
      
        Based on the discussion linked below, it appears that the access-ok
        version is not realiable on any architecture, but the struct version
        probably has no downsides. This series changes the code to use the
        same implementation on all architectures, addressing the few
        exceptions separately"
      
      Link: https://lore.kernel.org/lkml/75d07691-1e4f-741f-9852-38c0b4f520bc@synopsys.com/
      Link: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=100363
      Link: https://lore.kernel.org/lkml/20210507220813.365382-14-arnd@kernel.org/
      Link: git://git.kernel.org/pub/scm/linux/kernel/git/arnd/asm-generic.git unaligned-rework-v2
      Link: https://lore.kernel.org/lkml/CAHk-=whGObOKruA_bU3aPGZfoDqZM1_9wBkwREp0H0FgR-90uQ@mail.gmail.com/
      
      * tag 'asm-generic-unaligned-5.14' of git://git.kernel.org/pub/scm/linux/kernel/git/arnd/asm-generic:
        asm-generic: simplify asm/unaligned.h
        asm-generic: uaccess: 1-byte access is always aligned
        netpoll: avoid put_unaligned() on single character
        mwifiex: re-fix for unaligned accesses
        apparmor: use get_unaligned() only for multi-byte words
        partitions: msdos: fix one-byte get_unaligned()
        asm-generic: unaligned always use struct helpers
        asm-generic: unaligned: remove byteshift helpers
        powerpc: use linux/unaligned/le_struct.h on LE power7
        m68k: select CONFIG_HAVE_EFFICIENT_UNALIGNED_ACCESS
        sh: remove unaligned access for sh4a
        openrisc: always use unaligned-struct header
        asm-generic: use asm-generic/unaligned.h for most architectures
      4cad6719
    • L
      Merge tag 'perf-tools-for-v5.14-2021-07-01' of... · 40625491
      Linus Torvalds 提交于
      Merge tag 'perf-tools-for-v5.14-2021-07-01' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux
      
      Pull perf tool updates from Arnaldo Carvalho de Melo:
       "Tools:
      
         - Add cgroup support for 'perf top' (-G).
      
         - Add support for KVM MSRs in 'perf kvm stat'
      
         - Support probes on init functions in 'perf probe', to support the
           bootconfig format.
      
         - Improve error reporting in 'perf probe'.
      
         - No need to synthesize BUILD_ID records in 'perf inject' if the
           MMAP2 records have build ids already.
      
         - Allow toggling source code ('s' hotkey) in 'perf annotate' in all
           lines.
      
         - Add itrace options support to 'perf annotate'.
      
         - Support to custom DSO filters for 'perf script'.
      
        Hardware enablement:
      
         - Support the HYBRID_TOPOLOGY and HYBRID_CPU_PMU_CAPS features in the
           perf.data file header.
      
         - Support PMU prefix for mem-load and mem-store events, to support
           hybrid (BIG little) CPUs such as Intel's Alderlake.
      
         - Support hybrid CPUs in 'perf mem' and 'perf c2c'.
      
        Hardware tracing:
      
         - Intel PT now supports tracing KVM guests.
      
         - Timestamp improvements for ARM's Coresight.
      
        Build:
      
         - Add 'make -C tools/perf build-test' entries for
           libopencsd/CORESIGHT=1 and libbpf/LIBBPF_DYNAMIC=1.
      
         - Use bison's --file-prefix-map option to avoid storing full paths
           when using O= in the perf build.
      
        Tests:
      
         - Improve the 'perf test' entries for libpfm4 and BPF counters.
      
        Misc:
      
         - Sync msr-index.h, mount.h, kvm headers with the kernel originals.
      
         - Add vendor events and metrics for Intel's Icelake Server & Client"
      
      * tag 'perf-tools-for-v5.14-2021-07-01' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux: (123 commits)
        perf session: Add missing evlist__delete when deleting a session
        perf annotate: Allow 's' on source code lines
        perf dlfilter: Add object_code() to perf_dlfilter_fns
        perf dlfilter: Add attr() to perf_dlfilter_fns
        perf dlfilter: Add srcline() to perf_dlfilter_fns
        perf dlfilter: Add insn() to perf_dlfilter_fns
        perf dlfilter: Add resolve_address() to perf_dlfilter_fns
        perf build: Install perf_dlfilter.h
        perf script: Add option to pass arguments to dlfilters
        perf script: Add option to list dlfilters
        perf script: Add dlfilter__filter_event_early()
        perf script: Add API for filtering via dynamically loaded shared object
        perf llvm: Return -ENOMEM when asprintf() fails
        perf cs-etm: Delay decode of non-timeless data until cs_etm__flush_events()
        tools headers UAPI: Synch KVM's svm.h header with the kernel
        tools kvm headers arm64: Update KVM headers from the kernel sources
        tools headers UAPI: Sync linux/kvm.h with the kernel sources
        tools headers cpufeatures: Sync with the kernel sources
        tools include UAPI: Update linux/mount.h copy
        tools arch x86: Sync the msr-index.h copy with the kernel sources
        ...
      40625491
    • L
      Merge branch 'akpm' (patches from Andrew) · 71bd9341
      Linus Torvalds 提交于
      Merge more updates from Andrew Morton:
       "190 patches.
      
        Subsystems affected by this patch series: mm (hugetlb, userfaultfd,
        vmscan, kconfig, proc, z3fold, zbud, ras, mempolicy, memblock,
        migration, thp, nommu, kconfig, madvise, memory-hotplug, zswap,
        zsmalloc, zram, cleanups, kfence, and hmm), procfs, sysctl, misc,
        core-kernel, lib, lz4, checkpatch, init, kprobes, nilfs2, hfs,
        signals, exec, kcov, selftests, compress/decompress, and ipc"
      
      * emailed patches from Andrew Morton <akpm@linux-foundation.org>: (190 commits)
        ipc/util.c: use binary search for max_idx
        ipc/sem.c: use READ_ONCE()/WRITE_ONCE() for use_global_lock
        ipc: use kmalloc for msg_queue and shmid_kernel
        ipc sem: use kvmalloc for sem_undo allocation
        lib/decompressors: remove set but not used variabled 'level'
        selftests/vm/pkeys: exercise x86 XSAVE init state
        selftests/vm/pkeys: refill shadow register after implicit kernel write
        selftests/vm/pkeys: handle negative sys_pkey_alloc() return code
        selftests/vm/pkeys: fix alloc_random_pkey() to make it really, really random
        kcov: add __no_sanitize_coverage to fix noinstr for all architectures
        exec: remove checks in __register_bimfmt()
        x86: signal: don't do sas_ss_reset() until we are certain that sigframe won't be abandoned
        hfsplus: report create_date to kstat.btime
        hfsplus: remove unnecessary oom message
        nilfs2: remove redundant continue statement in a while-loop
        kprobes: remove duplicated strong free_insn_page in x86 and s390
        init: print out unknown kernel parameters
        checkpatch: do not complain about positive return values starting with EPOLL
        checkpatch: improve the indented label test
        checkpatch: scripts/spdxcheck.py now requires python3
        ...
      71bd9341