mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 02:30:34 +02:00 
			
		
		
		
	- Support for kernel address space layout randomization
 
  - Add support for kernel image signature verification
 
  - Convert s390 to the generic get_user_pages_fast code
 
  - Convert s390 to the stack unwind API analog to x86
 
  - Add support for CPU directed interrupts for PCI devices
 
  - Provide support for MIO instructions to the PCI base layer, this
    will allow the use of direct PCI mappings in user space code
 
  - Add the basic KVM guest ultravisor interface for protected VMs
 
  - Add AT_HWCAP bits for several new hardware capabilities
 
  - Update the CPU measurement facility counter definitions to SVN 6
 
  - Arnds cleanup patches for his quest to get LLVM compiles working
 
  - A vfio-ccw update with bug fixes and support for halt and clear
 
  - Improvements for the hardware TRNG code
 
  - Another round of cleanup for the QDIO layer
 
  - Numerous cleanups and bug fixes
 -----BEGIN PGP SIGNATURE-----
 Version: GnuPG v2
 
 iQEcBAABCAAGBQJc0CCEAAoJEDjwexyKj9rgjmkH/A3e2drvuP/hSF3xfCKTQFdx
 /PoLHQVCqENB3HU3FA/ljoXuG6jMgwj61looqlxBNumXFpIfTg0E1JC5S4wRGJ+K
 cOVhIKV53gcuZkRcCJQp0WMnGzpk1Daf7iYXYmAl+7e+mREUPxOuJ0Ei6vXvRGZS
 8cQrUCGrtPgkAeLlndypHI2M2TDDGJIMczOGbOZau8+8Lo7Wq9zt5y0h/v0ew37g
 ogA0eGh6koU1435dt2pclZRiZ1XOcar3Uin9ioT+RnSgJ4pr1Pza/F6IGO0RdQa+
 rva990lqGFp5r9lE4rMCwK9LWb/rfHdVPd35t9XPwphnQ/ORoWUwLk3uc5XOHow=
 =dbuy
 -----END PGP SIGNATURE-----
Merge tag 's390-5.2-1' of git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux
Pull s390 updates from Martin Schwidefsky:
 - Support for kernel address space layout randomization
 - Add support for kernel image signature verification
 - Convert s390 to the generic get_user_pages_fast code
 - Convert s390 to the stack unwind API analog to x86
 - Add support for CPU directed interrupts for PCI devices
 - Provide support for MIO instructions to the PCI base layer, this will
   allow the use of direct PCI mappings in user space code
 - Add the basic KVM guest ultravisor interface for protected VMs
 - Add AT_HWCAP bits for several new hardware capabilities
 - Update the CPU measurement facility counter definitions to SVN 6
 - Arnds cleanup patches for his quest to get LLVM compiles working
 - A vfio-ccw update with bug fixes and support for halt and clear
 - Improvements for the hardware TRNG code
 - Another round of cleanup for the QDIO layer
 - Numerous cleanups and bug fixes
* tag 's390-5.2-1' of git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux: (98 commits)
  s390/vdso: drop unnecessary cc-ldoption
  s390: fix clang -Wpointer-sign warnigns in boot code
  s390: drop CONFIG_VIRT_TO_BUS
  s390: boot, purgatory: pass $(CLANG_FLAGS) where needed
  s390: only build for new CPUs with clang
  s390: simplify disabled_wait
  s390/ftrace: use HAVE_FUNCTION_GRAPH_RET_ADDR_PTR
  s390/unwind: introduce stack unwind API
  s390/opcodes: add missing instructions to the disassembler
  s390/bug: add entry size to the __bug_table section
  s390: use proper expoline sections for .dma code
  s390/nospec: rename assembler generated expoline thunks
  s390: add missing ENDPROC statements to assembler functions
  locking/lockdep: check for freed initmem in static_obj()
  s390/kernel: add support for kernel address space layout randomization (KASLR)
  s390/kernel: introduce .dma sections
  s390/sclp: do not use static sccbs
  s390/kprobes: use static buffer for insn_page
  s390/kernel: convert SYSCALL and PGM_CHECK handlers to .quad
  s390/kernel: build a relocatable kernel
  ...
		
	
			
		
			
				
	
	
		
			62 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			62 lines
		
	
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
// SPDX-License-Identifier: GPL-2.0
 | 
						|
/*
 | 
						|
 * Stack trace management functions
 | 
						|
 *
 | 
						|
 *  Copyright IBM Corp. 2006
 | 
						|
 *  Author(s): Heiko Carstens <heiko.carstens@de.ibm.com>
 | 
						|
 */
 | 
						|
 | 
						|
#include <linux/sched.h>
 | 
						|
#include <linux/sched/debug.h>
 | 
						|
#include <linux/stacktrace.h>
 | 
						|
#include <linux/kallsyms.h>
 | 
						|
#include <linux/export.h>
 | 
						|
#include <asm/stacktrace.h>
 | 
						|
#include <asm/unwind.h>
 | 
						|
 | 
						|
void save_stack_trace(struct stack_trace *trace)
 | 
						|
{
 | 
						|
	struct unwind_state state;
 | 
						|
 | 
						|
	unwind_for_each_frame(&state, current, NULL, 0) {
 | 
						|
		if (trace->nr_entries >= trace->max_entries)
 | 
						|
			break;
 | 
						|
		if (trace->skip > 0)
 | 
						|
			trace->skip--;
 | 
						|
		else
 | 
						|
			trace->entries[trace->nr_entries++] = state.ip;
 | 
						|
	}
 | 
						|
}
 | 
						|
EXPORT_SYMBOL_GPL(save_stack_trace);
 | 
						|
 | 
						|
void save_stack_trace_tsk(struct task_struct *tsk, struct stack_trace *trace)
 | 
						|
{
 | 
						|
	struct unwind_state state;
 | 
						|
 | 
						|
	unwind_for_each_frame(&state, tsk, NULL, 0) {
 | 
						|
		if (trace->nr_entries >= trace->max_entries)
 | 
						|
			break;
 | 
						|
		if (in_sched_functions(state.ip))
 | 
						|
			continue;
 | 
						|
		if (trace->skip > 0)
 | 
						|
			trace->skip--;
 | 
						|
		else
 | 
						|
			trace->entries[trace->nr_entries++] = state.ip;
 | 
						|
	}
 | 
						|
}
 | 
						|
EXPORT_SYMBOL_GPL(save_stack_trace_tsk);
 | 
						|
 | 
						|
void save_stack_trace_regs(struct pt_regs *regs, struct stack_trace *trace)
 | 
						|
{
 | 
						|
	struct unwind_state state;
 | 
						|
 | 
						|
	unwind_for_each_frame(&state, current, regs, 0) {
 | 
						|
		if (trace->nr_entries >= trace->max_entries)
 | 
						|
			break;
 | 
						|
		if (trace->skip > 0)
 | 
						|
			trace->skip--;
 | 
						|
		else
 | 
						|
			trace->entries[trace->nr_entries++] = state.ip;
 | 
						|
	}
 | 
						|
}
 | 
						|
EXPORT_SYMBOL_GPL(save_stack_trace_regs);
 |