mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 9840cfcb97
			
		
	
	
		9840cfcb97
		
	
	
	
	
		
			
			- Optimise SVE switching for CPUs with 128-bit implementations.
 
  - Fix output format from SVE selftest.
 
  - Add support for versions v1.2 and 1.3 of the SMC calling convention.
 
  - Allow Pointer Authentication to be configured independently for
    kernel and userspace.
 
  - PMU driver cleanups for managing IRQ affinity and exposing event
    attributes via sysfs.
 
  - KASAN optimisations for both hardware tagging (MTE) and out-of-line
    software tagging implementations.
 
  - Relax frame record alignment requirements to facilitate 8-byte
    alignment with KASAN and Clang.
 
  - Cleanup of page-table definitions and removal of unused memory types.
 
  - Reduction of ARCH_DMA_MINALIGN back to 64 bytes.
 
  - Refactoring of our instruction decoding routines and addition of some
    missing encodings.
 
  - Move entry code moved into C and hardened against harmful compiler
    instrumentation.
 
  - Update booting requirements for the FEAT_HCX feature, added to v8.7
    of the architecture.
 
  - Fix resume from idle when pNMI is being used.
 
  - Additional CPU sanity checks for MTE and preparatory changes for
    systems where not all of the CPUs support 32-bit EL0.
 
  - Update our kernel string routines to the latest Cortex Strings
    implementation.
 
  - Big cleanup of our cache maintenance routines, which were confusingly
    named and inconsistent in their implementations.
 
  - Tweak linker flags so that GDB can understand vmlinux when using RELR
    relocations.
 
  - Boot path cleanups to enable early initialisation of per-cpu
    operations needed by KCSAN.
 
  - Non-critical fixes and miscellaneous cleanup.
 -----BEGIN PGP SIGNATURE-----
 
 iQFEBAABCgAuFiEEPxTL6PPUbjXGY88ct6xw3ITBYzQFAmDUh1YQHHdpbGxAa2Vy
 bmVsLm9yZwAKCRC3rHDchMFjNDaUCAC+2Jy2Yopd94uBPYajGybM0rqCUgE7b5n1
 A7UzmQ6fia2hwqCPmxGG+sRabovwN7C1bKrUCc03RIbErIa7wum1edeyqmF/Aw44
 DUDY1MAOSZaFmX8L62QCvxG1hfdLPtGmHMd1hdXvxYK7PCaigEFnzbLRWTtgE+Ok
 JhdvNfsoeITJObHnvYPF3rV3NAbyYni9aNJ5AC/qb3dlf6XigEraXaMj29XHKfwc
 +vmn+25oqFkLHyFeguqIoK+vUQAy/8TjFfjX83eN3LZknNhDJgWS1Iq1Nm+Vxt62
 RvDUUecWJjAooCWgmil6pt0enI+q6E8LcX3A3cWWrM6psbxnYzkU
 =I6KS
 -----END PGP SIGNATURE-----
Merge tag 'arm64-upstream' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux
Pull arm64 updates from Will Deacon:
 "There's a reasonable amount here and the juicy details are all below.
  It's worth noting that the MTE/KASAN changes strayed outside of our
  usual directories due to core mm changes and some associated changes
  to some other architectures; Andrew asked for us to carry these [1]
  rather that take them via the -mm tree.
  Summary:
   - Optimise SVE switching for CPUs with 128-bit implementations.
   - Fix output format from SVE selftest.
   - Add support for versions v1.2 and 1.3 of the SMC calling
     convention.
   - Allow Pointer Authentication to be configured independently for
     kernel and userspace.
   - PMU driver cleanups for managing IRQ affinity and exposing event
     attributes via sysfs.
   - KASAN optimisations for both hardware tagging (MTE) and out-of-line
     software tagging implementations.
   - Relax frame record alignment requirements to facilitate 8-byte
     alignment with KASAN and Clang.
   - Cleanup of page-table definitions and removal of unused memory
     types.
   - Reduction of ARCH_DMA_MINALIGN back to 64 bytes.
   - Refactoring of our instruction decoding routines and addition of
     some missing encodings.
   - Move entry code moved into C and hardened against harmful compiler
     instrumentation.
   - Update booting requirements for the FEAT_HCX feature, added to v8.7
     of the architecture.
   - Fix resume from idle when pNMI is being used.
   - Additional CPU sanity checks for MTE and preparatory changes for
     systems where not all of the CPUs support 32-bit EL0.
   - Update our kernel string routines to the latest Cortex Strings
     implementation.
   - Big cleanup of our cache maintenance routines, which were
     confusingly named and inconsistent in their implementations.
   - Tweak linker flags so that GDB can understand vmlinux when using
     RELR relocations.
   - Boot path cleanups to enable early initialisation of per-cpu
     operations needed by KCSAN.
   - Non-critical fixes and miscellaneous cleanup"
* tag 'arm64-upstream' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux: (150 commits)
  arm64: tlb: fix the TTL value of tlb_get_level
  arm64: Restrict undef hook for cpufeature registers
  arm64/mm: Rename ARM64_SWAPPER_USES_SECTION_MAPS
  arm64: insn: avoid circular include dependency
  arm64: smp: Bump debugging information print down to KERN_DEBUG
  drivers/perf: fix the missed ida_simple_remove() in ddr_perf_probe()
  perf/arm-cmn: Fix invalid pointer when access dtc object sharing the same IRQ number
  arm64: suspend: Use cpuidle context helpers in cpu_suspend()
  PSCI: Use cpuidle context helpers in psci_cpu_suspend_enter()
  arm64: Convert cpu_do_idle() to using cpuidle context helpers
  arm64: Add cpuidle context save/restore helpers
  arm64: head: fix code comments in set_cpu_boot_mode_flag
  arm64: mm: drop unused __pa(__idmap_text_start)
  arm64: mm: fix the count comments in compute_indices
  arm64/mm: Fix ttbr0 values stored in struct thread_info for software-pan
  arm64: mm: Pass original fault address to handle_mm_fault()
  arm64/mm: Drop SECTION_[SHIFT|SIZE|MASK]
  arm64/mm: Use CONT_PMD_SHIFT for ARM64_MEMSTART_SHIFT
  arm64/mm: Drop SWAPPER_INIT_MAP_SIZE
  arm64: Conditionally configure PTR_AUTH key of the kernel.
  ...
		
	
			
		
			
				
	
	
		
			59 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| #ifndef __ASM_ARM_CPUIDLE_H
 | |
| #define __ASM_ARM_CPUIDLE_H
 | |
| 
 | |
| #include <asm/proc-fns.h>
 | |
| 
 | |
| #ifdef CONFIG_CPU_IDLE
 | |
| extern int arm_cpuidle_simple_enter(struct cpuidle_device *dev,
 | |
| 		struct cpuidle_driver *drv, int index);
 | |
| #define __cpuidle_method_section __used __section("__cpuidle_method_of_table")
 | |
| #else
 | |
| static inline int arm_cpuidle_simple_enter(struct cpuidle_device *dev,
 | |
| 		struct cpuidle_driver *drv, int index) { return -ENODEV; }
 | |
| #define __cpuidle_method_section __maybe_unused /* drop silently */
 | |
| #endif
 | |
| 
 | |
| /* Common ARM WFI state */
 | |
| #define ARM_CPUIDLE_WFI_STATE_PWR(p) {\
 | |
| 	.enter                  = arm_cpuidle_simple_enter,\
 | |
| 	.exit_latency           = 1,\
 | |
| 	.target_residency       = 1,\
 | |
| 	.power_usage		= p,\
 | |
| 	.name                   = "WFI",\
 | |
| 	.desc                   = "ARM WFI",\
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * in case power_specified == 1, give a default WFI power value needed
 | |
|  * by some governors
 | |
|  */
 | |
| #define ARM_CPUIDLE_WFI_STATE ARM_CPUIDLE_WFI_STATE_PWR(UINT_MAX)
 | |
| 
 | |
| struct device_node;
 | |
| 
 | |
| struct cpuidle_ops {
 | |
| 	int (*suspend)(unsigned long arg);
 | |
| 	int (*init)(struct device_node *, int cpu);
 | |
| };
 | |
| 
 | |
| struct of_cpuidle_method {
 | |
| 	const char *method;
 | |
| 	const struct cpuidle_ops *ops;
 | |
| };
 | |
| 
 | |
| #define CPUIDLE_METHOD_OF_DECLARE(name, _method, _ops)			\
 | |
| 	static const struct of_cpuidle_method __cpuidle_method_of_table_##name \
 | |
| 	__cpuidle_method_section = { .method = _method, .ops = _ops }
 | |
| 
 | |
| extern int arm_cpuidle_suspend(int index);
 | |
| 
 | |
| extern int arm_cpuidle_init(int cpu);
 | |
| 
 | |
| struct arm_cpuidle_irq_context { };
 | |
| 
 | |
| #define arm_cpuidle_save_irq_context(c)		(void)c
 | |
| #define arm_cpuidle_restore_irq_context(c)	(void)c
 | |
| 
 | |
| #endif
 |