1. 24 10月, 2018 14 次提交
    • R
      cifs: change mkdir to use a compound · f733e393
      Ronnie Sahlberg 提交于
      This with the previous patch changes mkdir() from needing 6 roundtrips to
      just 3.
      Signed-off-by: NRonnie Sahlberg <lsahlber@redhat.com>
      Signed-off-by: NSteve French <stfrench@microsoft.com>
      f733e393
    • R
      cifs: add a smb2_compound_op and change QUERY_INFO to use it · c5a5f38f
      Ronnie Sahlberg 提交于
      This turns most open/query-info/close patterns in cifs.ko
      to become compounds.
      
      This changes stat from using 3 roundtrips to just a single one.
      Signed-off-by: NRonnie Sahlberg <lsahlber@redhat.com>
      Signed-off-by: NSteve French <stfrench@microsoft.com>
      c5a5f38f
    • R
      cifs: fix a credits leak for compund commands · cb5c2e63
      Ronnie Sahlberg 提交于
      When processing the mids for compounds we would only add credits based on
      the last successful mid in the compound which would leak credits and
      eventually triggering a re-connect.
      
      Fix this by splitting the mid processing part into two loops instead of one
      where the first loop just waits for all mids and then counts how many
      credits we were granted for the whole compound.
      Signed-off-by: NRonnie Sahlberg <lsahlber@redhat.com>
      Signed-off-by: NSteve French <stfrench@microsoft.com>
      cb5c2e63
    • S
      smb3: add tracepoint to catch cases where credit refund of failed op overlaps reconnect · b340a4d4
      Steve French 提交于
      Add tracepoint to catch potential cases where a pending operation overlapping a
      reconnect could fail and incorrectly refund its credits causing the client
      to think it has more credits available than the server thinks it does.
      Signed-off-by: NSteve French <stfrench@microsoft.com>
      Reviewed-by: NRonnie Sahlberg <lsahlber@redhat.com>
      b340a4d4
    • Y
      cifs: remove set but not used variable 'cifs_sb' · ce7fb50f
      YueHaibing 提交于
      Fixes gcc '-Wunused-but-set-variable' warning:
      
      fs/cifs/ioctl.c: In function 'cifs_ioctl':
      fs/cifs/ioctl.c:164:23: warning:
       variable 'cifs_sb' set but not used [-Wunused-but-set-variable]
      Signed-off-by: NYueHaibing <yuehaibing@huawei.com>
      Signed-off-by: NSteve French <stfrench@microsoft.com>
      ce7fb50f
    • Y
      cifs: Use kmemdup rather than duplicating its implementation in smb311_posix_mkdir() · d034feeb
      YueHaibing 提交于
      Use kmemdup rather than duplicating its implementation
      Signed-off-by: NYueHaibing <yuehaibing@huawei.com>
      Signed-off-by: NSteve French <stfrench@microsoft.com>
      d034feeb
    • S
      smb3: do not display confusing message on mount to Azure servers · d42c8a87
      Steve French 提交于
      Some servers (e.g. Azure) return "STATUS_NOT_IMPLEMENTED" rather
      than "STATUS_INVALID_DEVICE_REQUEST" on query network interface
      info at mount.  This shouldn't cause us to log a warning message
      automatically.  Don't log this unless noisier cifsFYI is enabled.
      Signed-off-by: NSteve French <stfrench@microsoft.com>
      Reviewed-by: NRonnie Sahlberg <lsahlber@redhat.com>
      d42c8a87
    • L
      Merge branch 'parisc-4.20-1' of git://git.kernel.org/pub/scm/linux/kernel/git/deller/parisc-linux · 44786880
      Linus Torvalds 提交于
      Pull parisc updates from Helge Deller:
       "Lots of small fixes and enhancements, most noteably:
      
         - Many TLB and cache flush optimizations (Dave)
      
         - Fixed HPMC/crash handler on 64-bit kernel (Dave and myself)
      
         - Added alternative infrastructre. The kernel now live-patches itself
           for various situations, e.g. replace SMP code when running on one
           CPU only or drop cache flushes when system has no cache installed.
      
         - vmlinuz now contains a full copy of the compressed vmlinux file.
           This simplifies debugging the currently booted kernel.
      
         - Unused driver removal (Christoph)
      
         - Reduced warnings of Dino PCI bridge when running in qemu
      
         - Removed gcc version check (Masahiro)"
      
      * 'parisc-4.20-1' of git://git.kernel.org/pub/scm/linux/kernel/git/deller/parisc-linux: (23 commits)
        parisc: Retrieve and display the PDC PAT capabilities
        parisc: Optimze cache flush algorithms
        parisc: Remove pte_inserted define
        parisc: Add PDC PAT cell_info() and pd_get_pdc_revisions() functions
        parisc: Drop two instructions from pte lookup code
        parisc: Use zdep for shlw macro on PA1.1 and PA2.0
        parisc: Add alternative coding infrastructure
        parisc: Include compressed vmlinux file in vmlinuz boot kernel
        extract-vmlinux: Check for uncompressed image as fallback
        parisc: Fix address in HPMC IVA
        parisc: Fix exported address of os_hpmc handler
        parisc: Fix map_pages() to not overwrite existing pte entries
        parisc: Purge TLB entries after updating page table entry and set page accessed flag in TLB handler
        parisc: Release spinlocks using ordered store
        parisc: Ratelimit dino stuck interrupt warnings
        parisc: dino: Utilize DINO_MASK_IRQ() macro
        parisc: Clean up crash header output
        parisc: Add SYSTEM_INFO and REGISTER TOC PAT functions
        parisc: Remove PTE load and fault check from L2_ptep macro
        parisc: Reorder TLB flush timing calculation
        ...
      44786880
    • L
      Merge branch 'for-linus' of git://git.armlinux.org.uk/~rmk/linux-arm · 07171da2
      Linus Torvalds 提交于
      Pull ARM updates from Russell King:
       "The main item in this pull request are the Spectre variant 1.1 fixes
        from Julien Thierry.
      
        A few other patches to improve various areas, and removal of some
        obsolete mcount bits and a redundant kbuild conditional"
      
      * 'for-linus' of git://git.armlinux.org.uk/~rmk/linux-arm:
        ARM: 8802/1: Call syscall_trace_exit even when system call skipped
        ARM: 8797/1: spectre-v1.1: harden __copy_to_user
        ARM: 8796/1: spectre-v1,v1.1: provide helpers for address sanitization
        ARM: 8795/1: spectre-v1.1: use put_user() for __put_user()
        ARM: 8794/1: uaccess: Prevent speculative use of the current addr_limit
        ARM: 8793/1: signal: replace __put_user_error with __put_user
        ARM: 8792/1: oabi-compat: copy oabi events using __copy_to_user()
        ARM: 8791/1: vfp: use __copy_to_user() when saving VFP state
        ARM: 8790/1: signal: always use __copy_to_user to save iwmmxt context
        ARM: 8789/1: signal: copy registers using __copy_to_user()
        ARM: 8801/1: makefile: use ARMv3M mode for RiscPC
        ARM: 8800/1: use choice for kernel unwinders
        ARM: 8798/1: remove unnecessary KBUILD_SRC ifeq conditional
        ARM: 8788/1: ftrace: remove old mcount support
        ARM: 8786/1: Debug kernel copy by printing
      07171da2
    • L
      Merge branch 'x86-vdso-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 034bda1c
      Linus Torvalds 提交于
      Pull x86 vdso updates from Ingo Molnar:
       "Two main changes:
      
         - Cleanups, simplifications and CLOCK_TAI support (Thomas Gleixner)
      
         - Improve code generation (Andy Lutomirski)"
      
      * 'x86-vdso-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/vdso: Rearrange do_hres() to improve code generation
        x86/vdso: Document vgtod_ts better
        x86/vdso: Remove "memory" clobbers in the vDSO syscall fallbacks
        x66/vdso: Add CLOCK_TAI support
        x86/vdso: Move cycle_last handling into the caller
        x86/vdso: Simplify the invalid vclock case
        x86/vdso: Replace the clockid switch case
        x86/vdso: Collapse coarse functions
        x86/vdso: Collapse high resolution functions
        x86/vdso: Introduce and use vgtod_ts
        x86/vdso: Use unsigned int consistently for vsyscall_gtod_data:: Seq
        x86/vdso: Enforce 64bit clocksource
        x86/time: Implement clocksource_arch_init()
        clocksource: Provide clocksource_arch_init()
      034bda1c
    • L
      Merge branch 'x86-pti-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · d82924c3
      Linus Torvalds 提交于
      Pull x86 pti updates from Ingo Molnar:
       "The main changes:
      
         - Make the IBPB barrier more strict and add STIBP support (Jiri
           Kosina)
      
         - Micro-optimize and clean up the entry code (Andy Lutomirski)
      
         - ... plus misc other fixes"
      
      * 'x86-pti-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/speculation: Propagate information about RSB filling mitigation to sysfs
        x86/speculation: Enable cross-hyperthread spectre v2 STIBP mitigation
        x86/speculation: Apply IBPB more strictly to avoid cross-process data leak
        x86/speculation: Add RETPOLINE_AMD support to the inline asm CALL_NOSPEC variant
        x86/CPU: Fix unused variable warning when !CONFIG_IA32_EMULATION
        x86/pti/64: Remove the SYSCALL64 entry trampoline
        x86/entry/64: Use the TSS sp2 slot for SYSCALL/SYSRET scratch space
        x86/entry/64: Document idtentry
      d82924c3
    • L
      Merge branch 'x86-platform-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · d7197a5a
      Linus Torvalds 提交于
      Pull x86 platform updates from Ingo Molnar:
       "Two minor OLPC changes: a build fix and a new quirk"
      
      * 'x86-platform-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/olpc: Fix build error with CONFIG_MFD_CS5535=m
        x86/olpc: Indicate that legacy PC XO-1 platform should not register RTC
      d7197a5a
    • L
      Merge branch 'x86-paravirt-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · f682a792
      Linus Torvalds 提交于
      Pull x86 paravirt updates from Ingo Molnar:
       "Two main changes:
      
         - Remove no longer used parts of the paravirt infrastructure and put
           large quantities of paravirt ops under a new config option
           PARAVIRT_XXL=y, which is selected by XEN_PV only. (Joergen Gross)
      
         - Enable PV spinlocks on Hyperv (Yi Sun)"
      
      * 'x86-paravirt-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/hyperv: Enable PV qspinlock for Hyper-V
        x86/hyperv: Add GUEST_IDLE_MSR support
        x86/paravirt: Clean up native_patch()
        x86/paravirt: Prevent redefinition of SAVE_FLAGS macro
        x86/xen: Make xen_reservation_lock static
        x86/paravirt: Remove unneeded mmu related paravirt ops bits
        x86/paravirt: Move the Xen-only pv_mmu_ops under the PARAVIRT_XXL umbrella
        x86/paravirt: Move the pv_irq_ops under the PARAVIRT_XXL umbrella
        x86/paravirt: Move the Xen-only pv_cpu_ops under the PARAVIRT_XXL umbrella
        x86/paravirt: Move items in pv_info under PARAVIRT_XXL umbrella
        x86/paravirt: Introduce new config option PARAVIRT_XXL
        x86/paravirt: Remove unused paravirt bits
        x86/paravirt: Use a single ops structure
        x86/paravirt: Remove clobbers from struct paravirt_patch_site
        x86/paravirt: Remove clobbers parameter from paravirt patch functions
        x86/paravirt: Make paravirt_patch_call() and paravirt_patch_jmp() static
        x86/xen: Add SPDX identifier in arch/x86/xen files
        x86/xen: Link platform-pci-unplug.o only if CONFIG_XEN_PVHVM
        x86/xen: Move pv specific parts of arch/x86/xen/mmu.c to mmu_pv.c
        x86/xen: Move pv irq related functions under CONFIG_XEN_PV umbrella
      f682a792
    • L
      Merge branch 'x86-mm-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 99792e0c
      Linus Torvalds 提交于
      Pull x86 mm updates from Ingo Molnar:
       "Lots of changes in this cycle:
      
         - Lots of CPA (change page attribute) optimizations and related
           cleanups (Thomas Gleixner, Peter Zijstra)
      
         - Make lazy TLB mode even lazier (Rik van Riel)
      
         - Fault handler cleanups and improvements (Dave Hansen)
      
         - kdump, vmcore: Enable kdumping encrypted memory with AMD SME
           enabled (Lianbo Jiang)
      
         - Clean up VM layout documentation (Baoquan He, Ingo Molnar)
      
         - ... plus misc other fixes and enhancements"
      
      * 'x86-mm-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (51 commits)
        x86/stackprotector: Remove the call to boot_init_stack_canary() from cpu_startup_entry()
        x86/mm: Kill stray kernel fault handling comment
        x86/mm: Do not warn about PCI BIOS W+X mappings
        resource: Clean it up a bit
        resource: Fix find_next_iomem_res() iteration issue
        resource: Include resource end in walk_*() interfaces
        x86/kexec: Correct KEXEC_BACKUP_SRC_END off-by-one error
        x86/mm: Remove spurious fault pkey check
        x86/mm/vsyscall: Consider vsyscall page part of user address space
        x86/mm: Add vsyscall address helper
        x86/mm: Fix exception table comments
        x86/mm: Add clarifying comments for user addr space
        x86/mm: Break out user address space handling
        x86/mm: Break out kernel address space handling
        x86/mm: Clarify hardware vs. software "error_code"
        x86/mm/tlb: Make lazy TLB mode lazier
        x86/mm/tlb: Add freed_tables element to flush_tlb_info
        x86/mm/tlb: Add freed_tables argument to flush_tlb_mm_range
        smp,cpumask: introduce on_each_cpu_cond_mask
        smp: use __cpumask_set_cpu in on_each_cpu_cond
        ...
      99792e0c
  2. 23 10月, 2018 26 次提交
    • L
      Merge branch 'x86-hyperv-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 382d72a9
      Linus Torvalds 提交于
      Pull x86 hyperv updates from Ingo Molnar:
       "Two small changes: a boot warning removal and a minor cleanup"
      
      * 'x86-hyperv-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/hyperv: Remove unused include
        x86/hyperv: Suppress "PCI: Fatal: No config space access function found"
      382d72a9
    • L
      Merge branch 'x86-grub2-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · ac73e08e
      Linus Torvalds 提交于
      Pull x86 grub2 updates from Ingo Molnar:
       "This extends the x86 boot protocol to include an address for the RSDP
        table - utilized by Xen currently.
      
        Matching Grub2 patches are pending as well. (Juergen Gross)"
      
      * 'x86-grub2-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/acpi, x86/boot: Take RSDP address for boot params if available
        x86/boot: Add ACPI RSDP address to setup_header
        x86/xen: Fix boot loader version reported for PVH guests
      ac73e08e
    • L
      Merge branch 'x86-cpu-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · fec98069
      Linus Torvalds 提交于
      Pull x86 cpu updates from Ingo Molnar:
       "The main changes in this cycle were:
      
         - Add support for the "Dhyana" x86 CPUs by Hygon: these are licensed
           based on the AMD Zen architecture, and are built and sold in China,
           for domestic datacenter use. The code is pretty close to AMD
           support, mostly with a few quirks and enumeration differences. (Pu
           Wen)
      
         - Enable CPUID support on Cyrix 6x86/6x86L processors"
      
      * 'x86-cpu-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        tools/cpupower: Add Hygon Dhyana support
        cpufreq: Add Hygon Dhyana support
        ACPI: Add Hygon Dhyana support
        x86/xen: Add Hygon Dhyana support to Xen
        x86/kvm: Add Hygon Dhyana support to KVM
        x86/mce: Add Hygon Dhyana support to the MCA infrastructure
        x86/bugs: Add Hygon Dhyana to the respective mitigation machinery
        x86/apic: Add Hygon Dhyana support
        x86/pci, x86/amd_nb: Add Hygon Dhyana support to PCI and northbridge
        x86/amd_nb: Check vendor in AMD-only functions
        x86/alternative: Init ideal_nops for Hygon Dhyana
        x86/events: Add Hygon Dhyana support to PMU infrastructure
        x86/smpboot: Do not use BSP INIT delay and MWAIT to idle on Dhyana
        x86/cpu/mtrr: Support TOP_MEM2 and get MTRR number
        x86/cpu: Get cache info and setup cache cpumap for Hygon Dhyana
        x86/cpu: Create Hygon Dhyana architecture support file
        x86/CPU: Change query logic so CPUID is enabled before testing
        x86/CPU: Use correct macros for Cyrix calls
      fec98069
    • L
      Merge branch 'x86-build-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 04ce7fae
      Linus Torvalds 提交于
      Pull x86 build update from Ingo Molnar:
       "A small cleanup to x86 Kconfigs"
      
      * 'x86-build-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/kconfig: Remove redundant 'default n' lines from all x86 Kconfig's
      04ce7fae
    • L
      Merge branch 'x86-boot-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 642116d4
      Linus Torvalds 提交于
      Pull x86 boot updates from Ingo Molnar:
       "Two cleanups and a bugfix for a rare boot option combination"
      
      * 'x86-boot-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/boot/KASLR: Remove return value from handle_mem_options()
        x86/corruption-check: Use pr_*() instead of printk()
        x86/corruption-check: Fix panic in memory_corruption_check() when boot option without value is provided
      642116d4
    • L
      Merge branch 'x86-asm-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · e1d20bea
      Linus Torvalds 提交于
      Pull x86 asm updates from Ingo Molnar:
       "The main changes in this cycle were the fsgsbase related preparatory
        patches from Chang S. Bae - but there's also an optimized
        memcpy_flushcache() and a cleanup for the __cmpxchg_double() assembly
        glue"
      
      * 'x86-asm-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/fsgsbase/64: Clean up various details
        x86/segments: Introduce the 'CPUNODE' naming to better document the segment limit CPU/node NR trick
        x86/vdso: Initialize the CPU/node NR segment descriptor earlier
        x86/vdso: Introduce helper functions for CPU and node number
        x86/segments/64: Rename the GDT PER_CPU entry to CPU_NUMBER
        x86/fsgsbase/64: Factor out FS/GS segment loading from __switch_to()
        x86/fsgsbase/64: Convert the ELF core dump code to the new FSGSBASE helpers
        x86/fsgsbase/64: Make ptrace use the new FS/GS base helpers
        x86/fsgsbase/64: Introduce FS/GS base helper functions
        x86/fsgsbase/64: Fix ptrace() to read the FS/GS base accurately
        x86/asm: Use CC_SET()/CC_OUT() in __cmpxchg_double()
        x86/asm: Optimize memcpy_flushcache()
      e1d20bea
    • L
      Merge branch 'x86-apic-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · cbbfb0ae
      Linus Torvalds 提交于
      Pull x86 apic updates from Ingo Molnar:
       "Improve the spreading of managed IRQs at allocation time"
      
      * 'x86-apic-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        irq/matrix: Spread managed interrupts on allocation
        irq/matrix: Split out the CPU selection code into a helper
      cbbfb0ae
    • L
      Merge branch 'sched-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 42f52e1c
      Linus Torvalds 提交于
      Pull scheduler updates from Ingo Molnar:
       "The main changes are:
      
         - Migrate CPU-intense 'misfit' tasks on asymmetric capacity systems,
           to better utilize (much) faster 'big core' CPUs. (Morten Rasmussen,
           Valentin Schneider)
      
         - Topology handling improvements, in particular when CPU capacity
           changes and related load-balancing fixes/improvements (Morten
           Rasmussen)
      
         - ... plus misc other improvements, fixes and updates"
      
      * 'sched-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (28 commits)
        sched/completions/Documentation: Add recommendation for dynamic and ONSTACK completions
        sched/completions/Documentation: Clean up the document some more
        sched/completions/Documentation: Fix a couple of punctuation nits
        cpu/SMT: State SMT is disabled even with nosmt and without "=force"
        sched/core: Fix comment regarding nr_iowait_cpu() and get_iowait_load()
        sched/fair: Remove setting task's se->runnable_weight during PELT update
        sched/fair: Disable LB_BIAS by default
        sched/pelt: Fix warning and clean up IRQ PELT config
        sched/topology: Make local variables static
        sched/debug: Use symbolic names for task state constants
        sched/numa: Remove unused numa_stats::nr_running field
        sched/numa: Remove unused code from update_numa_stats()
        sched/debug: Explicitly cast sched_feat() to bool
        sched/core: Disable SD_PREFER_SIBLING on asymmetric CPU capacity domains
        sched/fair: Don't move tasks to lower capacity CPUs unless necessary
        sched/fair: Set rq->rd->overload when misfit
        sched/fair: Wrap rq->rd->overload accesses with READ/WRITE_ONCE()
        sched/core: Change root_domain->overload type to int
        sched/fair: Change 'prefer_sibling' type to bool
        sched/fair: Kick nohz balance if rq->misfit_task_load
        ...
      42f52e1c
    • L
      Merge branch 'ras-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 0d1b82cd
      Linus Torvalds 提交于
      Pull RAS updates from Ingo Molnar:
       "Misc smaller fixes and cleanups"
      
      * 'ras-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/mcelog: Remove one mce_helper definition
        x86/mce: Add macros for the corrected error count bit field
        x86/mce: Use BIT_ULL(x) for bit mask definitions
        x86/mce-inject: Reset injection struct after injection
      0d1b82cd
    • L
      Merge branch 'perf-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · c05f3642
      Linus Torvalds 提交于
      Pull perf updates from Ingo Molnar:
       "The main updates in this cycle were:
      
         - Lots of perf tooling changes too voluminous to list (big perf trace
           and perf stat improvements, lots of libtraceevent reorganization,
           etc.), so I'll list the authors and refer to the changelog for
           details:
      
             Benjamin Peterson, Jérémie Galarneau, Kim Phillips, Peter
             Zijlstra, Ravi Bangoria, Sangwon Hong, Sean V Kelley, Steven
             Rostedt, Thomas Gleixner, Ding Xiang, Eduardo Habkost, Thomas
             Richter, Andi Kleen, Sanskriti Sharma, Adrian Hunter, Tzvetomir
             Stoyanov, Arnaldo Carvalho de Melo, Jiri Olsa.
      
           ... with the bulk of the changes written by Jiri Olsa, Tzvetomir
           Stoyanov and Arnaldo Carvalho de Melo.
      
         - Continued intel_rdt work with a focus on playing well with perf
           events. This also imported some non-perf RDT work due to
           dependencies. (Reinette Chatre)
      
         - Implement counter freezing for Arch Perfmon v4 (Skylake and newer).
           This allows to speed up the PMI handler by avoiding unnecessary MSR
           writes and make it more accurate. (Andi Kleen)
      
         - kprobes cleanups and simplification (Masami Hiramatsu)
      
         - Intel Goldmont PMU updates (Kan Liang)
      
         - ... plus misc other fixes and updates"
      
      * 'perf-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (155 commits)
        kprobes/x86: Use preempt_enable() in optimized_callback()
        x86/intel_rdt: Prevent pseudo-locking from using stale pointers
        kprobes, x86/ptrace.h: Make regs_get_kernel_stack_nth() not fault on bad stack
        perf/x86/intel: Export mem events only if there's PEBS support
        x86/cpu: Drop pointless static qualifier in punit_dev_state_show()
        x86/intel_rdt: Fix initial allocation to consider CDP
        x86/intel_rdt: CBM overlap should also check for overlap with CDP peer
        x86/intel_rdt: Introduce utility to obtain CDP peer
        tools lib traceevent, perf tools: Move struct tep_handler definition in a local header file
        tools lib traceevent: Separate out tep_strerror() for strerror_r() issues
        perf python: More portable way to make CFLAGS work with clang
        perf python: Make clang_has_option() work on Python 3
        perf tools: Free temporary 'sys' string in read_event_files()
        perf tools: Avoid double free in read_event_file()
        perf tools: Free 'printk' string in parse_ftrace_printk()
        perf tools: Cleanup trace-event-info 'tdata' leak
        perf strbuf: Match va_{add,copy} with va_end
        perf test: S390 does not support watchpoints in test 22
        perf auxtrace: Include missing asm/bitsperlong.h to get BITS_PER_LONG
        tools include: Adopt linux/bits.h
        ...
      c05f3642
    • L
      Merge branch 'locking-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 0200fbdd
      Linus Torvalds 提交于
      Pull locking and misc x86 updates from Ingo Molnar:
       "Lots of changes in this cycle - in part because locking/core attracted
        a number of related x86 low level work which was easier to handle in a
        single tree:
      
         - Linux Kernel Memory Consistency Model updates (Alan Stern, Paul E.
           McKenney, Andrea Parri)
      
         - lockdep scalability improvements and micro-optimizations (Waiman
           Long)
      
         - rwsem improvements (Waiman Long)
      
         - spinlock micro-optimization (Matthew Wilcox)
      
         - qspinlocks: Provide a liveness guarantee (more fairness) on x86.
           (Peter Zijlstra)
      
         - Add support for relative references in jump tables on arm64, x86
           and s390 to optimize jump labels (Ard Biesheuvel, Heiko Carstens)
      
         - Be a lot less permissive on weird (kernel address) uaccess faults
           on x86: BUG() when uaccess helpers fault on kernel addresses (Jann
           Horn)
      
         - macrofy x86 asm statements to un-confuse the GCC inliner. (Nadav
           Amit)
      
         - ... and a handful of other smaller changes as well"
      
      * 'locking-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (57 commits)
        locking/lockdep: Make global debug_locks* variables read-mostly
        locking/lockdep: Fix debug_locks off performance problem
        locking/pvqspinlock: Extend node size when pvqspinlock is configured
        locking/qspinlock_stat: Count instances of nested lock slowpaths
        locking/qspinlock, x86: Provide liveness guarantee
        x86/asm: 'Simplify' GEN_*_RMWcc() macros
        locking/qspinlock: Rework some comments
        locking/qspinlock: Re-order code
        locking/lockdep: Remove duplicated 'lock_class_ops' percpu array
        x86/defconfig: Enable CONFIG_USB_XHCI_HCD=y
        futex: Replace spin_is_locked() with lockdep
        locking/lockdep: Make class->ops a percpu counter and move it under CONFIG_DEBUG_LOCKDEP=y
        x86/jump-labels: Macrofy inline assembly code to work around GCC inlining bugs
        x86/cpufeature: Macrofy inline assembly code to work around GCC inlining bugs
        x86/extable: Macrofy inline assembly code to work around GCC inlining bugs
        x86/paravirt: Work around GCC inlining bugs when compiling paravirt ops
        x86/bug: Macrofy the BUG table section handling, to work around GCC inlining bugs
        x86/alternatives: Macrofy lock prefixes to work around GCC inlining bugs
        x86/refcount: Work around GCC inlining bug
        x86/objtool: Use asm macros to work around GCC inlining bugs
        ...
      0200fbdd
    • L
      Merge branch 'efi-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · de3fbb2a
      Linus Torvalds 提交于
      Pull EFI updates from Ingo Molnar:
       "The main changes are:
      
         - Add support for enlisting the help of the EFI firmware to create
           memory reservations that persist across kexec.
      
         - Add page fault handling to the runtime services support code on x86
           so we can more gracefully recover from buggy EFI firmware.
      
         - Fix command line handling on x86 for the boot path that omits the
           stub's PE/COFF entry point.
      
         - Other assorted fixes and updates"
      
      * 'efi-core-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86: boot: Fix EFI stub alignment
        efi/x86: Call efi_parse_options() from efi_main()
        efi/x86: earlyprintk - Add 64bit efi fb address support
        efi/x86: drop task_lock() from efi_switch_mm()
        efi/x86: Handle page faults occurring while running EFI runtime services
        efi: Make efi_rts_work accessible to efi page fault handler
        efi/efi_test: add exporting ResetSystem runtime service
        efi/libstub: arm: support building with clang
        efi: add API to reserve memory persistently across kexec reboot
        efi/arm: libstub: add a root memreserve config table
        efi: honour memory reservations passed via a linux specific config table
      de3fbb2a
    • L
      Merge branch 'core-rcu-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · cee1352f
      Linus Torvalds 提交于
      Pull RCU updates from Ingo Molnar:
       "The biggest change in this cycle is the conclusion of the big
        'simplify RCU to two primary flavors' consolidation work - i.e.
        there's a single RCU flavor for any kernel variant (PREEMPT and
        !PREEMPT):
      
          - Consolidate the RCU-bh, RCU-preempt, and RCU-sched flavors into a
            single flavor similar to RCU-sched in !PREEMPT kernels and into a
            single flavor similar to RCU-preempt (but also waiting on
            preempt-disabled sequences of code) in PREEMPT kernels.
      
            This branch also includes a refactoring of
            rcu_{nmi,irq}_{enter,exit}() from Byungchul Park.
      
          - Now that there is only one RCU flavor in any given running kernel,
            the many "rsp" pointers are no longer required, and this cleanup
            series removes them.
      
          - This branch carries out additional cleanups made possible by the
            RCU flavor consolidation, including inlining now-trivial
            functions, updating comments and definitions, and removing
            now-unneeded rcutorture scenarios.
      
          - Now that there is only one flavor of RCU in any running kernel,
            there is also only on rcu_data structure per CPU. This means that
            the rcu_dynticks structure can be merged into the rcu_data
            structure, a task taken on by this branch. This branch also
            contains a -rt-related fix from Mike Galbraith.
      
        There were also other updates:
      
          - Documentation updates, including some good-eye catches from Joel
            Fernandes.
      
          - SRCU updates, most notably changes enabling call_srcu() to be
            invoked very early in the boot sequence.
      
          - Torture-test updates, including some preliminary work towards
            making rcutorture better able to find problems that result in
            insufficient grace-period forward progress.
      
          - Initial changes to RCU to better promote forward progress of grace
            periods, including fixing a bug found by Marius Hillenbrand and
            David Woodhouse, with the fix suggested by Peter Zijlstra"
      
      * 'core-rcu-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (140 commits)
        srcu: Make early-boot call_srcu() reuse workqueue lists
        rcutorture: Test early boot call_srcu()
        srcu: Make call_srcu() available during very early boot
        rcu: Convert rcu_state.ofl_lock to raw_spinlock_t
        rcu: Remove obsolete ->dynticks_fqs and ->cond_resched_completed
        rcu: Switch ->dynticks to rcu_data structure, remove rcu_dynticks
        rcu: Switch dyntick nesting counters to rcu_data structure
        rcu: Switch urgent quiescent-state requests to rcu_data structure
        rcu: Switch lazy counts to rcu_data structure
        rcu: Switch last accelerate/advance to rcu_data structure
        rcu: Switch ->tick_nohz_enabled_snap to rcu_data structure
        rcu: Merge rcu_dynticks structure into rcu_data structure
        rcu: Remove unused rcu_dynticks_snap() from Tiny RCU
        rcu: Convert "1UL << x" to "BIT(x)"
        rcu: Avoid resched_cpu() when rescheduling the current CPU
        rcu: More aggressively enlist scheduler aid for nohz_full CPUs
        rcu: Compute jiffies_till_sched_qs from other kernel parameters
        rcu: Provide functions for determining if call_rcu() has been invoked
        rcu: Eliminate ->rcu_qs_ctr from the rcu_dynticks structure
        rcu: Motivate Tiny RCU forward progress
        ...
      cee1352f
    • I
      dda93b45
    • L
      Merge tag 's390-4.20-1' of git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux · e2b623fb
      Linus Torvalds 提交于
      Pull s390 updates from Martin Schwidefsky:
      
       - Improved access control for the zcrypt driver, multiple device nodes
         can now be created with different access control lists
      
       - Extend the pkey API to provide random protected keys, this is useful
         for encrypted swap device with ephemeral protected keys
      
       - Add support for virtually mapped kernel stacks
      
       - Rework the early boot code, this moves the memory detection into the
         boot code that runs prior to decompression.
      
       - Add KASAN support
      
       - Bug fixes and cleanups
      
      * tag 's390-4.20-1' of git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux: (83 commits)
        s390/pkey: move pckmo subfunction available checks away from module init
        s390/kasan: support preemptible kernel build
        s390/pkey: Load pkey kernel module automatically
        s390/perf: Return error when debug_register fails
        s390/sthyi: Fix machine name validity indication
        s390/zcrypt: fix broken zcrypt_send_cprb in-kernel api function
        s390/vmalloc: fix VMALLOC_START calculation
        s390/mem_detect: add missing include
        s390/dumpstack: print psw mask and address again
        s390/crypto: Enhance paes cipher to accept variable length key material
        s390/pkey: Introduce new API for transforming key blobs
        s390/pkey: Introduce new API for random protected key verification
        s390/pkey: Add sysfs attributes to emit secure key blobs
        s390/pkey: Add sysfs attributes to emit protected key blobs
        s390/pkey: Define protected key blob format
        s390/pkey: Introduce new API for random protected key generation
        s390/zcrypt: add ap_adapter_mask sysfs attribute
        s390/zcrypt: provide apfs failure code on type 86 error reply
        s390/zcrypt: zcrypt device driver cleanup
        s390/kasan: add support for mem= kernel parameter
        ...
      e2b623fb
    • L
      Merge tag 'please-pull-next' of git://git.kernel.org/pub/scm/linux/kernel/git/aegl/linux · 70408a99
      Linus Torvalds 提交于
      Pull ia64 updates from Tony Luck:
       "Miscellaneous ia64 fixes from Christoph"
      
      * tag 'please-pull-next' of git://git.kernel.org/pub/scm/linux/kernel/git/aegl/linux:
        intel-iommu: mark intel_dma_ops static
        ia64: remove machvec_dma_sync_{single,sg}
        ia64/sn2: remove no-ops dma sync methods
        ia64: remove the unused iommu_dma_init function
        ia64: remove the unused pci_iommu_shutdown function
        ia64: remove the unused bad_dma_address symbol
        ia64: remove iommu_dma_supported
        ia64: remove the dead iommu_sac_force variable
        ia64: remove the kern_mem_attribute export
      70408a99
    • L
      Merge branch 'stable/for-linus-4.20' of... · a4648c75
      Linus Torvalds 提交于
      Merge branch 'stable/for-linus-4.20' of git://git.kernel.org/pub/scm/linux/kernel/git/konrad/swiotlb
      
      Pull xen swiotlb fix from Konrad Rzeszutek Wilk:
       "One tiny fix for the Xen SWIOTLB mechanism that occasionally happened
        with devices that didn't allocate size in power of two but rather some
        odd sizes.
      
        We neglected to make the memory coherent leading to all kinds of fun
        crashes"
      
      * 'stable/for-linus-4.20' of git://git.kernel.org/pub/scm/linux/kernel/git/konrad/swiotlb:
        xen-swiotlb: use actually allocated size on check physical continuous
      a4648c75
    • L
      Merge tag 'acpi-4.20-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm · 58a02287
      Linus Torvalds 提交于
      Pull ACPI updates from Rafael Wysocki:
       "These fix ACPICA issues related to the handling of module-level AML,
        fix an ordering issue during ACPI initialization, update ACPICA to
        upstream revision 20181003 (including fixes mostly), fix issues with
        system-wide suspend/resume related to the ACPI driver for Intel SoCs
        (LPSS), fix device enumeration issues on boards with Dollar Cove or
        Whiskey Cove Intel PMICs, prevent ACPICA from calling ktime_get() in
        unsuitable conditions, update a few drivers and clean up some code in
        several places.
      
        Specifics:
      
         - Fix ACPICA issues related to the handling of module-level AML and
           make the ACPI initialization code parse ECDT before loading the
           definition block tables (Erik Schmauss).
      
         - Update ACPICA to upstream revision 20181003 including fixes related
           to the ill-defined "generic serial bus" and the handling of the
           _REG object (Bob Moore).
      
         - Fix some issues with system-wide suspend/resume on Intel BYT/CHT
           related to the handling of I2C controllers in the ACPI LPSS driver
           for Intel SoCs (Hans de Goede).
      
         - Modify the ACPI namespace scanning code to enumerate INT33FE HID
           devices as platform devices with I2C resources to avoid device
           enumeration problems on boards with Dollar Cove or Whiskey Cove
           Intel PMICs (Hans de Goede).
      
         - Prevent ACPICA from using ktime_get() during early resume from
           system-wide suspend before resuming the timekeeping which generally
           is unsafe and triggers a warning from the timekeeping code (Bart
           Van Assche).
      
         - Add low-level real time clock support to the ACPI Time and Aalarm
           Device (TAD) driver (Rafael Wysocki).
      
         - Fix the ACPI SBS driver to avoid GPE storms on MacBook Pro and
           Oopses when removing modules (Ronald Tschalär).
      
         - Fix the ACPI PPTT parsing code to handle architecturally unknown
           cache types properly (Jeffrey Hugo).
      
         - Fix initialization issue in the ACPI processor driver (Dou Liyang).
      
         - Clean up the code in several places (Andy Shevchenko, Bartlomiej
           Zolnierkiewicz, David Arcari, zhong jiang)"
      
      * tag 'acpi-4.20-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: (33 commits)
        ACPI / scan: Create platform device for INT33FE ACPI nodes
        ACPI / OSL: Use 'jiffies' as the time bassis for acpi_os_get_timer()
        ACPI: probe ECDT before loading AML tables regardless of module-level code flag
        ACPICA: Remove acpi_gbl_group_module_level_code and only use acpi_gbl_execute_tables_as_methods instead
        ACPICA: AML Parser: fix parse loop to correctly skip erroneous extended opcodes
        ACPICA: AML interpreter: add region addresses in global list during initialization
        ACPI: TAD: Add low-level support for real time capability
        ACPI: remove redundant 'default n' from Kconfig
        ACPI / SBS: Fix rare oops when removing modules
        ACPI / SBS: Fix GPE storm on recent MacBookPro's
        ACPI/PPTT: Handle architecturally unknown cache types
        drivers: base: cacheinfo: Do not populate sysfs for unknown cache types
        ACPICA: Update version to 20181003
        ACPICA: Never run _REG on system_memory and system_IO
        ACPICA: Split large interpreter file
        ACPICA: Update for field unit access
        ACPICA: Rename some of the Field Attribute defines
        ACPICA: Update for generic_serial_bus and attrib_raw_process_bytes protocol
        ACPI / processor: Fix the return value of acpi_processor_ids_walk()
        ACPI / LPSS: Resume BYT/CHT I2C controllers from resume_noirq
        ...
      58a02287
    • L
      Merge tag 'pm-4.20-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm · 12dd08fa
      Linus Torvalds 提交于
      Pull power management updates from Rafael Wysocki:
       "These make hibernation on 32-bit x86 systems work in all of the cases
        in which it works on 64-bit x86 ones, update the menu cpuidle governor
        and the "polling" state to make them more efficient, add more hardware
        support to cpufreq drivers and fix issues with some of them, fix a bug
        in the conservative cpufreq governor, fix the operating performance
        points (OPP) framework and make it more stable, update the devfreq
        subsystem to take changes in the APIs used by into account and clean
        up some things all over.
      
        Specifics:
      
         - Backport hibernation bug fixes from x86-64 to x86-32 and
           consolidate hibernation handling on x86 to allow 32-bit systems to
           work in all of the cases in which 64-bit ones work (Zhimin Gu, Chen
           Yu).
      
         - Fix hibernation documentation (Vladimir D. Seleznev).
      
         - Update the menu cpuidle governor to fix a couple of issues with it,
           make it more efficient in some cases and clean it up (Rafael
           Wysocki).
      
         - Rework the cpuidle polling state implementation to make it more
           efficient (Rafael Wysocki).
      
         - Clean up the cpuidle core somewhat (Fieah Lim).
      
         - Fix the cpufreq conservative governor to take policy limits into
           account properly in some cases (Rafael Wysocki).
      
         - Add support for retrieving guaranteed performance information to
           the ACPI CPPC library and make the intel_pstate driver use it to
           expose the CPU base frequency via sysfs on systems with the
           hardware-managed P-states (HWP) feature enabled (Srinivas
           Pandruvada).
      
         - Fix clang warning in the CPPC cpufreq driver (Nathan Chancellor).
      
         - Get rid of device_node.name printing from cpufreq (Rob Herring).
      
         - Remove unnecessary unlikely() from the cpufreq core (Igor Stoppa).
      
         - Add support for the r8a7744 SoC to the cpufreq-dt driver (Biju
           Das).
      
         - Update the dt-platdev cpufreq driver to allow RK3399 to have
           separate tunables per cluster (Dmitry Torokhov).
      
         - Fix the dma_alloc_coherent() usage in the tegra186 cpufreq driver
           (Christoph Hellwig).
      
         - Make the imx6q cpufreq driver read OCOTP through nvmem for
           imx6ul/imx6ull (Anson Huang).
      
         - Fix several bugs in the operating performance points (OPP)
           framework and make it more stable (Viresh Kumar, Dave Gerlach).
      
         - Update the devfreq subsystem to take changes in the APIs used by
           into account, fix some issues with it and make it stop print
           device_node.name directly (Bjorn Andersson, Enric Balletbo i Serra,
           Matthias Kaehlcke, Rob Herring, Vincent Donnefort, zhong jiang).
      
         - Prepare the generic power domains (genpd) framework for dealing
           with domains containing CPUs (Ulf Hansson).
      
         - Prevent sysfs attributes representing low-power S0 residency
           counters from being exposed if low-power S0 support is not
           indicated in ACPI FADT (Rajneesh Bhardwaj).
      
         - Get rid of custom CPU features macros for Intel CPUs from the
           intel_idle and RAPL drivers (Andy Shevchenko).
      
         - Update the tasks freezer to list tasks that refused to freeze and
           caused a system transition to a sleep state to be aborted (Todd
           Brandt).
      
         - Update the pm-graph set of tools to v5.2 (Todd Brandt).
      
         - Fix some issues in the cpupower utility (Anders Roxell, Prarit
           Bhargava)"
      
      * tag 'pm-4.20-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: (73 commits)
        PM / Domains: Document flags for genpd
        PM / Domains: Deal with multiple states but no governor in genpd
        PM / Domains: Don't treat zero found compatible idle states as an error
        cpuidle: menu: Avoid computations when result will be discarded
        cpuidle: menu: Drop redundant comparison
        cpufreq: tegra186: don't pass GFP_DMA32 to dma_alloc_coherent()
        cpufreq: conservative: Take limits changes into account properly
        Documentation: intel_pstate: Add base_frequency information
        cpufreq: intel_pstate: Add base_frequency attribute
        ACPI / CPPC: Add support for guaranteed performance
        cpuidle: menu: Simplify checks related to the polling state
        PM / tools: sleepgraph and bootgraph: upgrade to v5.2
        PM / tools: sleepgraph: first batch of v5.2 changes
        cpupower: Fix coredump on VMWare
        cpupower: Fix AMD Family 0x17 msr_pstate size
        cpufreq: imx6q: read OCOTP through nvmem for imx6ul/imx6ull
        cpufreq: dt-platdev: allow RK3399 to have separate tunables per cluster
        cpuidle: poll_state: Revise loop termination condition
        cpuidle: menu: Move the latency_req == 0 special case check
        cpuidle: menu: Avoid computations for very close timers
        ...
      12dd08fa
    • L
      Merge branch 'pcmcia-next' of git://git.kernel.org/pub/scm/linux/kernel/git/brodo/linux · 72f86d08
      Linus Torvalds 提交于
      Pull pcmcia fixes from Dominik Brodowski:
       "These are just a few odd fixes and improvements to the PCMCIA core and
        to a few PCMCIA device drivers"
      
      * 'pcmcia-next' of git://git.kernel.org/pub/scm/linux/kernel/git/brodo/linux:
        pcmcia: Implement CLKRUN protocol disabling for Ricoh bridges
        pcmcia: pcmcia_resource: Replace mdelay() with msleep()
        pcmcia: add error handling for pcmcia_enable_device in qlogic_stub
        char: pcmcia: cm4000_cs: Replace mdelay with usleep_range in set_protocol
        pcmcia: Use module_pcmcia_driver for scsi drivers
        pcmcia: remove KERN_INFO level from debug message
      72f86d08
    • L
      Merge tag 'for-linus-4.20' of https://github.com/cminyard/linux-ipmi · c403993a
      Linus Torvalds 提交于
      Pull IPMI updates from Corey Minyard:
       "Lots of small changes to the IPMI driver. Most of the changes are
        logging cleanup and style fixes. There are a few smaller bug fixes"
      
      * tag 'for-linus-4.20' of https://github.com/cminyard/linux-ipmi: (21 commits)
        ipmi: Fix timer race with module unload
        ipmi:ssif: Add support for multi-part transmit messages > 2 parts
        MAINTAINERS: Add file patterns for ipmi device tree bindings
        ipmi: Remove platform driver overrides and use the id_table
        ipmi: Free the address list on module cleanup
        ipmi: Don't leave holes in the I2C address list in the ssif driver
        ipmi: fix return value of ipmi_set_my_LUN
        ipmi: Convert pr_xxx() to dev_xxx() in the BT code
        ipmi:dmi: Ignore IPMI SMBIOS entries with a zero base address
        ipmi:dmi: Use pr_fmt in the IPMI DMI code
        ipmi: Change to ktime_get_ts64()
        ipmi_si: fix potential integer overflow on large shift
        ipmi_si_pci: fix NULL device in ipmi_si error message
        ipmi: Convert printk(KERN_<level> to pr_<level>(
        ipmi: Use more common logging styles
        ipmi: msghandler: Add and use pr_fmt and dev_fmt, remove PFX
        pci:ipmi: Move IPMI PCI class id defines to pci_ids.h
        ipmi: Finally get rid of ipmi_user_t and ipmi_smi_t
        ipmi:powernv: Convert ipmi_smi_t to struct ipmi_smi
        hwmon:ibm: Change ipmi_user_t to struct ipmi_user *
        ...
      c403993a
    • L
      Merge tag 'leds-for-4.20-rc1' of... · 6fd577cd
      Linus Torvalds 提交于
      Merge tag 'leds-for-4.20-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/j.anaszewski/linux-leds
      
      Pull LED updates from Jacek Anaszewski:
      "We introduce LED pattern trigger - the idea that was proposed three
       years ago now received enough attention and determination to drive it
       to the successful end.
      
        There is also one new LED class driver and couple of improvements to
        the existing ones.
      
        New LED class driver:
         - add support for Panasonic AN30259A with related DT bindings
      
        New LED trigger:
         - introduce LED pattern trigger
      
        leds-sc27xx-bltc:
         - implement pattern_set/clear ops to enable support for pattern
           trigger's hw_pattern sysfs file
      
        Improvements to existing LED class drivers:
         - leds-pwm: don't print error message on -EPROBE_DEFER
         - leds-gpio: try to lookup gpiod from device
         - leds-as3645a: convert to using %pOFn instead of device_node.name"
      
      * tag 'leds-for-4.20-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/j.anaszewski/linux-leds:
        leds: sc27xx: Add pattern_set/clear interfaces for LED controller
        leds: core: Introduce LED pattern trigger
        leds: add Panasonic AN30259A support
        dt-bindings: leds: document Panasonic AN30259A bindings
        leds: gpio: Try to lookup gpiod from device
        leds: pwm: silently error out on EPROBE_DEFER
        leds: Convert to using %pOFn instead of device_node.name
      6fd577cd
    • L
      Merge tag 'gpio-v4.20-1' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-gpio · 114b5f8f
      Linus Torvalds 提交于
      Pull GPIO updates from Linus Walleij:
       "This is the bulk of GPIO changes for the v4.20 series:
      
        Core changes:
      
         - A patch series from Hans Verkuil to make it possible to
           enable/disable IRQs on a GPIO line at runtime and drive GPIO lines
           as output without having to put/get them from scratch.
      
           The irqchip callbacks have been improved so that they can use only
           the fastpatch callbacks to enable/disable irqs like any normal
           irqchip, especially the gpiod_lock_as_irq() has been improved to be
           callable in fastpath context.
      
           A bunch of rework had to be done to achieve this but it is a big
           win since I never liked to restrict this to slowpath. The only call
           requireing slowpath was try_module_get() and this is kept at the
           .request_resources() slowpath callback. In the GPIO CEC driver this
           is a big win sine a single line is used for both outgoing and
           incoming traffic, and this needs to use IRQs for incoming traffic
           while actively driving the line for outgoing traffic.
      
         - Janusz Krzysztofik improved the GPIO array API to pass a "cookie"
           (struct gpio_array) and a bitmap for setting or getting multiple
           GPIO lines at once.
      
           This improvement orginated in a specific need to speed up an OMAP1
           driver and has led to a much better API and real performance gains
           when the state of the array can be used to bypass a lot of checks
           and code when we want things to go really fast.
      
           The previous code would minimize the number of calls down to the
           driver callbacks assuming the CPU speed was orders of magnitude
           faster than the I/O latency, but this assumption was wrong on
           several platforms: what we needed to do was to profile and improve
           the speed on the hot path of the array functions and this change is
           now completed.
      
         - Clean out the painful and hard to grasp BNF experiments from the
           device tree bindings. Future approaches are looking into using JSON
           schema for this purpose. (Rob Herring is floating a patch series.)
      
        New drivers:
      
         - The RCAR driver now supports r8a774a1 (RZ/G2M).
      
         - Synopsys GPIO via CREGs driver.
      
        Major improvements:
      
         - Modernization of the EP93xx driver to use irqdomain and other
           contemporary concepts.
      
         - The ingenic driver has been merged into the Ingenic pin control
           driver and removed from the GPIO subsystem.
      
         - Debounce support in the ftgpio010 driver"
      
      * tag 'gpio-v4.20-1' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-gpio: (116 commits)
        gpio: Clarify kerneldoc on gpiochip_set_chained_irqchip()
        gpio: Remove unused 'irqchip' argument to gpiochip_set_cascaded_irqchip()
        gpio: Drop parent irq assignment during cascade setup
        mmc: pwrseq_simple: Fix incorrect handling of GPIO bitmap
        gpio: fix SNPS_CREG kconfig dependency warning
        gpiolib: Initialize gdev field before is used
        gpio: fix kernel-doc after devres.c file rename
        gpio: fix doc string for devm_gpiochip_add_data() to not talk about irq_chip
        gpio: syscon: Fix possible NULL ptr usage
        gpiolib: Show correct direction from the beginning
        pinctrl: msm: Use init_valid_mask exported function
        gpiolib: Add init_valid_mask exported function
        GPIO: add single-register GPIO via CREG driver
        dt-bindings: Document the Synopsys GPIO via CREG bindings
        gpio: mockup: use device properties instead of platform_data
        gpio: Slightly more helpful debugfs
        gpio: omap: Remove set but not used variable 'dev'
        gpio: omap: drop omap_gpio_list
        Accept partial 'gpio-line-names' property.
        gpio: omap: get rid of the conditional PM runtime calls
        ...
      114b5f8f
    • L
      Merge tag 'pinctrl-v4.20-1' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl · b0b6a28b
      Linus Torvalds 提交于
      Pull pin control updates from Linus Walleij:
       "This is the bulk of pin control changes for the v4.20 series:
      
        There were no significant changes to the core this time! Bur the new
        Qualcomm, Mediatek and Broadcom drivers are quite interesting as they
        will be used in a few million embedded devices the coming years as it
        seems.
      
        New drivers:
      
         - Broadcom Northstar pin control driver.
      
         - Mediatek MT8183 subdriver.
      
         - Mediatek MT7623 subdriver.
      
         - Mediatek MT6765 subdriver.
      
         - Meson g12a subdriver.
      
         - Nuvoton NPCM7xx pin control and GPIO driver.
      
         - Qualcomm QCS404 pin control and GPIO subdriver.
      
         - Qualcomm SDM660 pin control and GPIO subdriver.
      
         - Renesas R8A7744 PFC subdriver.
      
         - Renesas R8A774C0 PFC subdriver.
      
         - Renesas RZ/N1 pinctrl driver
      
        Major improvements:
      
         - Pulled the GPIO support for Ingenic over from the GPIO subsystem
           and consolidated it all in the Ingenic pin control driver.
      
         - Major cleanups and consolidation work in all Intel drivers.
      
         - Major cleanups and consolidation work in all Mediatek drivers.
      
         - Lots of incremental improvements to the Renesas PFC pin controller
           family.
      
         - All drivers doing GPIO now include <linux/gpio/driver.h> and
           nothing else"
      
      * tag 'pinctrl-v4.20-1' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl: (153 commits)
        pinctrl: sunxi: Fix a memory leak in 'sunxi_pinctrl_build_state()'
        gpio: uniphier: include <linux/bits.h> instead of <linux/bitops.h>
        pinctrl: uniphier: include <linux/bits.h> instead of <linux/bitops.h>
        dt-bindings: pinctrl: bcm4708-pinmux: improve example binding
        pinctrl: geminilake: Sort register offsets by value
        pinctrl: geminilake: Get rid of unneeded ->probe() stub
        pinctrl: geminilake: Update pin list for B0 stepping
        pinctrl: renesas: Fix platform_no_drv_owner.cocci warnings
        pinctrl: mediatek: Make eint_m u16
        pinctrl: bcm: ns: Use uintptr_t for casting data
        pinctrl: madera: Fix uninitialized variable bug in madera_mux_set_mux
        pinctrl: gemini: Fix up TVC clock group
        pinctrl: gemini: Drop noisy debug prints
        pinctrl: gemini: Mask and set properly
        pinctrl: mediatek: select GPIOLIB
        pinctrl: rza1: don't manually release devm managed resources
        MAINTAINERS: update entry for Mediatek pin controller
        pinctrl: bcm: add Northstar driver
        dt-bindings: pinctrl: document Broadcom Northstar pin mux controller
        pinctrl: qcom: fix 'const' pointer handling
        ...
      b0b6a28b
    • L
      Merge tag 'mmc-v4.20' of git://git.kernel.org/pub/scm/linux/kernel/git/ulfh/mmc · 1650ac53
      Linus Torvalds 提交于
      Pull MMC updates from Ulf Hansson:
       "MMC core:
         - Introduce a host helper function to share re-tuning progress
      
        MMC host:
         - sdhci: Add support for v4 host mode
         - sdhci-of-arasan: Add Support for AM654 MMC and PHY
         - sdhci-sprd: Add support for Spreadtrum's host controller
         - sdhci-tegra: Add support for HS400 enhanced strobe
         - sdhci-tegra: Enable UHS/HS200 modes for Tegra186/210
         - sdhci-tegra: Add support for HS400 delay line calibration
         - sdhci-tegra: Add support for pad calibration
         - sdhci-of-dwcmshc: Address 128MB DMA boundary limitation
         - sdhci-of-esdhc: Add support for tuning erratum A008171
         - sdhci-iproc: Add ACPI support
         - mediatek: Add support for MT8183
         - mediatek: Improve the support for tuning
         - mediatek: Add bus clock control for MT2712
         - jz4740: Add support for the JZ4725B
         - mmci: Add support for the stm32 sdmmc variant
         - mmci: Add support for an optional reset control
         - mmci: Add some new variant specific properties/callbacks
         - mmci: Re-structure DMA code to prepare for new variants
         - renesas_sdhi: Add support for r8a77470, r8a7744 and r8a774a1
         - renesas_sdhi_internal_dmac: Whitelist r8a77970 and r8a774a1
         - tmio/uniphier-sd: Add new UniPhier SD/eMMC controller driver
         - tmio/renesas_sdhi: Deal properly with SCC detection during re-tune
         - tmio/renesas_sdhi: Refactor/consolidate clock management
         - omap_hsmmc: Drop cover detection and some unused platform data
         - dw_mmc-exynos: Enable tuning for more speed modes
         - sunxi: Clarify the new timing mode and enable it for the A64 controller
         - various: Convert to slot GPIO descriptors"
      
      * tag 'mmc-v4.20' of git://git.kernel.org/pub/scm/linux/kernel/git/ulfh/mmc: (129 commits)
        mmc: mediatek: drop too much code of tuning method
        mmc: mediatek: add MT8183 MMC driver support
        mmc: mediatek: tune CMD/DATA together
        mmc: mediatek: fix cannot receive new request when msdc_cmd_is_ready fail
        mmc: mediatek: fill the actual clock for mmc debugfs
        mmc: dt-bindings: add support for MT8183 SoC
        mmc: uniphier-sd: avoid using broken DMA RX channel
        mmc: uniphier-sd: fix DMA disabling
        mmc: tmio: simplify the DMA mode test
        mmc: tmio: remove TMIO_MMC_HAVE_HIGH_REG flag
        mmc: tmio: move MFD variant reset to a platform hook
        mmc: renesas_sdhi: Add r8a77470 SDHI1 support
        dt-bindings: mmc: renesas_sdhi: Add r8a77470 support
        mmc: mmci: add stm32 sdmmc variant
        dt-bindings: mmci: add stm32 sdmmc variant
        mmc: mmci: add stm32 sdmmc registers
        mmc: mmci: add clock divider for stm32 sdmmc
        mmc: mmci: add optional reset property
        dt-bindings: mmci: add optional reset property
        mmc: mmci: add variant property to not read datacnt
        ...
      1650ac53
    • L
      Merge tag 'regulator-v5.0' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/regulator · ca9eb48f
      Linus Torvalds 提交于
      Pull regulator updates from Mark Brown:
       "The biggest chunk of the regulator changes for this release outside of
        the new drivers is the conversion of the fixed regulator to use the
        GPIO descriptor API, there's a small addition to the GPIO API plus a
        bunch of updates to board files to implement it. This is some really
        welcome work from Linus Walleij that's had a bunch of review and has
        been sitting in -next for a while so I'm fairly happy there's no major
        issues.
      
         - Helpers for overlapping linear ranges.
      
         - Display opmode and consumer requested load in the regualtor_summary
           file in debugfs, plus a fix there.
      
         - Support for the fun and entertaining power off mechanism that the
           pfuze100 hardware implements.
      
         - Conversion of the fixed regulator API to use GPIO descriptors,
           including pulling in a bunch of patches to a bunch of board files.
      
         - New drivers for Cirrus Logic Lochnagar, Qualcomm PMS405, Rohm
           BD71847, ST PMIC1, and TI LM363x devices"
      
      * tag 'regulator-v5.0' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/regulator: (36 commits)
        regulator: lochnagar: Use a consisent comment style for SPDX header
        regulator: bd718x7: Remove struct bd718xx_pmic
        regulator: Fetch enable gpiods nonexclusive
        regulator/gpio: Allow nonexclusive GPIO access
        regulator: lochnagar: Add support for the Cirrus Logic Lochnagar
        regulator: stpmic1: Return REGULATOR_MODE_INVALID for invalid mode
        regulator: stpmic1: add stpmic1 regulator driver
        dt-bindings: regulator: document stpmic1 pmic regulators
        regulator: axp20x: Mark expected switch fall-throughs
        regulator: bd718xx: fix build warning on x86_64
        regulator: fixed: Default enable high on DT regulators
        regulator: bd718xx: rename bd71837 to 718xx
        regulator: bd718XX use pickable ranges
        regulator/mfd: bd718xx: rename bd71837/bd71847 common instances
        regulator: Support regulators where voltage ranges are selectable
        mfd: dt bindings: add BD71847 device-tree binding documentation
        regulator: dt bindings: add BD71847 device-tree binding documentation
        regulator/mfd: Support ROHM BD71847 power management IC
        regulator: da905{2,5}: Remove unnecessary array check
        regulator: qcom: Add PMS405 regulators
        ...
      ca9eb48f