Home
last modified time | relevance | path

Searched refs:stack (Results 1 – 25 of 822) sorted by relevance

12345678910>>...33

/linux/tools/testing/selftests/bpf/progs/
H A Dtest_global_func_ctx_args.c11 static long stack[256]; variable
19 return bpf_get_stack(ctx, &stack, sizeof(stack), 0); in kprobe_typedef_ctx_subprog()
50 return bpf_get_stack((void *)ctx, &stack, sizeof(stack), 0); in kprobe_struct_ctx_subprog()
67 return bpf_get_stack(ctx, &stack, sizeof(stack), 0); in kprobe_workaround_ctx_subprog()
83 return bpf_get_stack(ctx, &stack, sizeof(stack), 0); in raw_tp_ctx_subprog()
99 return bpf_get_stack(ctx, &stack, sizeof(stack), 0); in raw_tp_writable_ctx_subprog()
115 return bpf_get_stack(ctx, &stack, sizeof(stack), 0); in perf_event_ctx_subprog()
130 return bpf_get_stack(ctx, stack, sizeof(stack), 0); in subprog_ctx_tag()
142 return bpf_get_stack(ctx1, stack, sizeof(stack), 0) + in subprog_multi_ctx_tags()
144 bpf_get_stack(ctx2, stack, sizeof(stack), 0); in subprog_multi_ctx_tags()
/linux/lib/
H A Dstackdepot.c361 struct stack_record *stack; in depot_pop_free_pool() local
379 stack = current_pool + pool_offset; in depot_pop_free_pool()
382 stack->handle.pool_index_plus_1 = pool_index + 1; in depot_pop_free_pool()
383 stack->handle.offset = pool_offset >> DEPOT_STACK_ALIGN; in depot_pop_free_pool()
384 stack->handle.extra = 0; in depot_pop_free_pool()
385 INIT_LIST_HEAD(&stack->hash_list); in depot_pop_free_pool()
389 return stack; in depot_pop_free_pool()
395 struct stack_record *stack; in depot_pop_free() local
408 stack = list_first_entry(&free_stacks, struct stack_record, free_list); in depot_pop_free()
409 if (!poll_state_synchronize_rcu(stack->rcu_state)) in depot_pop_free()
[all …]
/linux/arch/x86/kernel/
H A Ddumpstack_32.c38 static bool in_hardirq_stack(unsigned long *stack, struct stack_info *info) in in_hardirq_stack() argument
47 if (stack < begin || stack > end) in in_hardirq_stack()
63 static bool in_softirq_stack(unsigned long *stack, struct stack_info *info) in in_softirq_stack() argument
72 if (stack < begin || stack > end) in in_softirq_stack()
88 static bool in_doublefault_stack(unsigned long *stack, struct stack_info *info) in in_doublefault_stack() argument
93 void *begin = ss->stack; in in_doublefault_stack()
94 void *end = begin + sizeof(ss->stack); in in_doublefault_stack()
96 if ((void *)stack < begin || (void *)stack >= end) in in_doublefault_stack()
108 int get_stack_info(unsigned long *stack, struct task_struct *task, in get_stack_info() argument
111 if (!stack) in get_stack_info()
[all …]
H A Ddumpstack.c30 bool noinstr in_task_stack(unsigned long *stack, struct task_struct *task, in in_task_stack() argument
36 if (stack < begin || stack >= end) in in_task_stack()
48 bool noinstr in_entry_stack(unsigned long *stack, struct stack_info *info) in in_entry_stack() argument
55 if ((void *)stack < begin || (void *)stack >= end) in in_entry_stack()
185 unsigned long *stack, const char *log_lvl) in show_trace_log_lvl() argument
195 unwind_start(&state, task, regs, stack); in show_trace_log_lvl()
196 stack = stack ?: get_stack_pointer(task, regs); in show_trace_log_lvl()
215 for (; stack; stack = stack_info.next_sp) { in show_trace_log_lvl()
218 stack = PTR_ALIGN(stack, sizeof(long)); in show_trace_log_lvl()
220 if (get_stack_info(stack, task, &stack_info, &visit_mask)) { in show_trace_log_lvl()
[all …]
H A Ddumpstack_64.c94 static __always_inline bool in_exception_stack(unsigned long *stack, struct stack_info *info) in in_exception_stack() argument
96 unsigned long begin, end, stk = (unsigned long)stack; in in_exception_stack()
135 static __always_inline bool in_irq_stack(unsigned long *stack, struct stack_info *info) in in_irq_stack() argument
153 if (stack < begin || stack >= end) in in_irq_stack()
170 bool noinstr get_stack_info_noinstr(unsigned long *stack, struct task_struct *task, in get_stack_info_noinstr() argument
173 if (in_task_stack(stack, task, info)) in get_stack_info_noinstr()
179 if (in_exception_stack(stack, info)) in get_stack_info_noinstr()
182 if (in_irq_stack(stack, info)) in get_stack_info_noinstr()
185 if (in_entry_stack(stack, info)) in get_stack_info_noinstr()
191 int get_stack_info(unsigned long *stack, struct task_struct *task, in get_stack_info() argument
[all …]
/linux/tools/testing/selftests/bpf/prog_tests/
H A Dbuild_id.c10 static void print_stack(struct bpf_stack_build_id *stack, int frame_cnt) in print_stack() argument
16 switch (stack[i].status) { in print_stack()
23 printf("%02hhx", (unsigned)stack[i].build_id[j]); in print_stack()
24 printf(" OFFSET = %llx", (unsigned long long)stack[i].offset); in print_stack()
27 printf("IP = %llx", (unsigned long long)stack[i].ip); in print_stack()
30 printf("UNEXPECTED STATUS %d ", stack[i].status); in print_stack()
40 struct bpf_stack_build_id *stack; in subtest_nofault() local
59 stack = skel->bss->stack_nofault; in subtest_nofault()
62 print_stack(stack, frame_cnt); in subtest_nofault()
65 ASSERT_EQ(stack[0].status, BPF_STACK_BUILD_ID_VALID, "build_id_status"); in subtest_nofault()
[all …]
/linux/Documentation/arch/x86/
H A Dshstk.rst14 CET introduces shadow stack and indirect branch tracking (IBT). A shadow stack
15 is a secondary stack allocated from memory which cannot be directly modified by
17 return address to both the normal stack and the shadow stack. Upon
18 function return, the processor pops the shadow stack copy and compares it
19 to the normal stack copy. If the two differ, the processor raises a
23 shadow stack and kernel IBT are supported.
28 To use userspace shadow stack you need HW that supports it, a kernel
34 To build a user shadow stack enabled kernel, Binutils v2.29 or LLVM v6 or later
38 CET. "user_shstk" means that userspace shadow stack is supported on the current
98 ARCH_SHSTK_SHSTK - Shadow stack
[all …]
H A Dkernel-stacks.rst14 Like all other architectures, x86_64 has a kernel stack for every
17 zombie. While the thread is in user space the kernel stack is empty
25 * Interrupt stack. IRQ_STACK_SIZE
29 kernel switches from the current task to the interrupt stack. Like
32 of every per thread stack.
34 The interrupt stack is also used when processing a softirq.
36 Switching to the kernel interrupt stack is done by software based on a
41 to automatically switch to a new stack for designated events such as
46 point to dedicated stacks; each stack can be a different size.
50 loads such a descriptor, the hardware automatically sets the new stack
[all …]
/linux/tools/testing/selftests/arm64/gcs/
H A Dlibc-gcs.c303 unsigned long *stack; in FIXTURE() local
434 self->stack = (void *)syscall(__NR_map_shadow_stack, 0, in FIXTURE_SETUP()
437 ASSERT_FALSE(self->stack == MAP_FAILED); in FIXTURE_SETUP()
438 ksft_print_msg("Allocated stack from %p-%p\n", self->stack, in FIXTURE_SETUP()
439 self->stack + variant->stack_size); in FIXTURE_SETUP()
446 if (self->stack != MAP_FAILED) { in FIXTURE_TEARDOWN()
447 ret = munmap(self->stack, variant->stack_size); in FIXTURE_TEARDOWN()
455 unsigned long *stack = self->stack; in TEST_F() local
473 ASSERT_EQ(stack[cap_index], GCS_CAP(&stack[cap_index])); in TEST_F()
479 unsigned long *stack = self->stack; in TEST_F() local
[all …]
/linux/Documentation/mm/
H A Dvmalloced-kernel-stacks.rst21 Kernel stack overflows are often hard to debug and make the kernel
25 Virtually mapped kernel stacks with guard pages cause kernel stack
31 causes reliable faults when the stack overflows. The usability of
32 the stack trace after overflow and response to the overflow itself
49 needs to work while the stack points to a virtual address with
51 most likely) needs to ensure that the stack's page table entries
52 are populated before running on a possibly unpopulated stack.
53 - If the stack overflows into a guard page, something reasonable
64 with guard pages. This causes kernel stack overflows to be caught
75 VMAP_STACK is enabled, it is not possible to run DMA on stack
[all …]
/linux/arch/nios2/kernel/
H A Dtraps.c60 void show_stack(struct task_struct *task, unsigned long *stack, in show_stack() argument
66 if (!stack) { in show_stack()
68 stack = (unsigned long *)task->thread.ksp; in show_stack()
70 stack = (unsigned long *)&stack; in show_stack()
73 addr = (unsigned long) stack; in show_stack()
76 printk("%sStack from %08lx:", loglvl, (unsigned long)stack); in show_stack()
78 if (stack + 1 > endstack) in show_stack()
82 printk("%s %08lx", loglvl, *stack++); in show_stack()
87 while (stack + 1 <= endstack) { in show_stack()
88 addr = *stack++; in show_stack()
/linux/arch/openrisc/kernel/
H A Dunwinder.c60 void unwind_stack(void *data, unsigned long *stack, in unwind_stack() argument
67 while (!kstack_end(stack)) { in unwind_stack()
68 frameinfo = container_of(stack, in unwind_stack()
83 stack++; in unwind_stack()
93 void unwind_stack(void *data, unsigned long *stack, in unwind_stack() argument
98 while (!kstack_end(stack)) { in unwind_stack()
99 addr = *stack++; in unwind_stack()
/linux/mm/kmsan/
H A Dinit.c149 static void smallstack_push(struct smallstack *stack, struct page *pages) in smallstack_push() argument
151 KMSAN_WARN_ON(stack->index == MAX_BLOCKS); in smallstack_push()
152 stack->items[stack->index] = pages; in smallstack_push()
153 stack->index++; in smallstack_push()
157 static struct page *smallstack_pop(struct smallstack *stack) in smallstack_pop() argument
161 KMSAN_WARN_ON(stack->index == 0); in smallstack_pop()
162 stack->index--; in smallstack_pop()
163 ret = stack->items[stack->index]; in smallstack_pop()
164 stack->items[stack->index] = NULL; in smallstack_pop()
/linux/arch/um/kernel/
H A Dsysrq.c29 void show_stack(struct task_struct *task, unsigned long *stack, in show_stack() argument
35 if (!stack) in show_stack()
36 stack = get_stack_pointer(task, segv_regs); in show_stack()
40 if (kstack_end(stack)) in show_stack()
44 pr_cont(" %08lx", READ_ONCE_NOCHECK(*stack)); in show_stack()
45 stack++; in show_stack()
/linux/include/linux/sched/
H A Dtask_stack.h23 return task->stack; in task_stack_page()
31 return (unsigned long *)((unsigned long)task->stack + THREAD_SIZE) - 1; in end_of_stack()
33 return task->stack; in end_of_stack()
39 #define task_stack_page(task) ((void *)(task)->stack)
91 void *stack = task_stack_page(current); in object_is_on_stack() local
94 return (obj >= stack) && (obj < (stack + THREAD_SIZE)); in object_is_on_stack()
/linux/arch/um/kernel/skas/
H A Dmmu.c29 unsigned long stack = 0; in init_new_context() local
32 stack = __get_free_pages(GFP_KERNEL | __GFP_ZERO, ilog2(STUB_DATA_PAGES)); in init_new_context()
33 if (stack == 0) in init_new_context()
36 new_id->stack = stack; in init_new_context()
53 free_pages(new_id->stack, ilog2(STUB_DATA_PAGES)); in init_new_context()
84 free_pages(mmu->id.stack, ilog2(STUB_DATA_PAGES)); in destroy_context()
117 stub_data = (void *)mm_context->id.stack; in mm_sigchld_irq()
/linux/tools/perf/scripts/python/
H A Dstackcollapse.py97 stack = list()
103 stack.append(tidy_function_name(entry['sym']['name'],
108 stack.append(tidy_function_name(param_dict['symbol'],
119 stack.append(comm)
121 stack_string = ';'.join(reversed(stack))
126 for stack in list:
127 print("%s %d" % (stack, lines[stack]))
/linux/arch/x86/include/asm/
H A Dstacktrace.h31 bool in_task_stack(unsigned long *stack, struct task_struct *task,
34 bool in_entry_stack(unsigned long *stack, struct stack_info *info);
36 int get_stack_info(unsigned long *stack, struct task_struct *task,
38 bool get_stack_info_noinstr(unsigned long *stack, struct task_struct *task,
42 bool get_stack_guard_info(unsigned long *stack, struct stack_info *info) in get_stack_guard_info() argument
45 if (get_stack_info_noinstr(stack, current, info)) in get_stack_guard_info()
48 return get_stack_info_noinstr((void *)stack + PAGE_SIZE, current, info); in get_stack_guard_info()
/linux/tools/testing/selftests/mm/
H A Dpkey_sighandler_tests.c80 static inline long clone_raw(unsigned long flags, void *stack, in clone_raw() argument
84 long a2 = (long)stack; in clone_raw()
179 stack_t *stack = ptr; in thread_segv_maperr_ptr() local
187 syscall_raw(SYS_sigaltstack, (long)stack, 0, 0, 0, 0, 0); in thread_segv_maperr_ptr()
286 void *stack; in test_sigsegv_handler_with_different_pkey_for_stack() local
302 stack = mmap(0, STACK_SIZE, PROT_READ | PROT_WRITE, in test_sigsegv_handler_with_different_pkey_for_stack()
305 assert(stack != MAP_FAILED); in test_sigsegv_handler_with_different_pkey_for_stack()
315 sys_mprotect_pkey(stack, STACK_SIZE, PROT_READ | PROT_WRITE, pkey); in test_sigsegv_handler_with_different_pkey_for_stack()
330 stack + STACK_SIZE, in test_sigsegv_handler_with_different_pkey_for_stack()
405 stack_t *stack = ptr; in thread_sigusr2_self() local
[all …]
/linux/arch/um/os-Linux/
H A Dhelper.c47 unsigned long stack, sp; in run_helper() local
50 stack = alloc_stack(0, __uml_cant_sleep()); in run_helper()
51 if (stack == 0) in run_helper()
69 sp = stack + UM_KERN_PAGE_SIZE; in run_helper()
115 free_stack(stack, 0); in run_helper()
122 unsigned long stack, sp; in run_helper_thread() local
129 stack = alloc_stack(0, __uml_cant_sleep()); in run_helper_thread()
130 if (stack == 0) in run_helper_thread()
133 sp = stack + UM_KERN_PAGE_SIZE; in run_helper_thread()
152 free_stack(stack, 0); in run_helper_thread()
[all …]
/linux/arch/powerpc/kernel/
H A Dstacktrace.c44 unsigned long *stack = (unsigned long *) sp; in arch_stack_walk() local
50 newsp = stack[0]; in arch_stack_walk()
51 ip = stack[STACK_FRAME_LR_SAVE]; in arch_stack_walk()
96 unsigned long *stack = (unsigned long *) sp; in arch_stack_walk_reliable() local
103 newsp = stack[0]; in arch_stack_walk_reliable()
123 stack[STACK_INT_FRAME_MARKER_LONGS] == STACK_FRAME_REGS_MARKER) { in arch_stack_walk_reliable()
128 ip = stack[STACK_FRAME_LR_SAVE]; in arch_stack_walk_reliable()
136 ip = ftrace_graph_ret_addr(task, &graph_idx, ip, stack); in arch_stack_walk_reliable()
/linux/arch/um/os-Linux/skas/
H A Dmem.c27 struct stub_data *proc_data = (void *)mm_idp->stack; in syscall_stub_dump_error()
59 unsigned long *stack) in check_init_stack() argument
61 if (stack == NULL) { in check_init_stack()
62 stack = (unsigned long *) mm_idp->stack + 2; in check_init_stack()
63 *stack = 0; in check_init_stack()
65 return stack; in check_init_stack()
89 struct stub_data *proc_data = (void *)mm_idp->stack; in do_syscall_stub()
160 struct stub_data *proc_data = (struct stub_data *) mm_idp->stack; in syscall_stub_alloc()
183 struct stub_data *proc_data = (void *) mm_idp->stack; in syscall_stub_get_previous()
/linux/Documentation/ABI/testing/
H A Dsysfs-ocfs238 * 'o2cb' - The classic o2cb cluster stack that ocfs2 has
62 the cluster stack in use. The contents may change
63 when all filesystems are unmounted and the cluster stack
71 of current ocfs2 cluster stack. This value is set by
72 userspace tools when bringing the cluster stack online.
74 Cluster stack names are 4 characters in length.
76 When the 'o2cb' cluster stack is used, the 'o2cb' cluster
81 cluster stack on a single line.
83 Writing a new stack name to this file changes the current
84 cluster stack unless there are mounted ocfs2 filesystems.
[all …]
/linux/arch/loongarch/
H A DKconfig.debug5 This determines which method will be used for unwinding kernel stack
6 traces for panics, oopses, bugs, warnings, perf, /proc/<pid>/stack,
12 This option enables the "guess" unwinder for unwinding kernel stack
13 traces. It scans the stack and reports every kernel text address it
23 This option enables the "prologue" unwinder for unwinding kernel stack
24 traces. It unwind the stack frame based on prologue code analyze. Symbol
35 unwinding kernel stack traces. It uses a custom data format which is
/linux/fs/jfs/
H A Djfs_btree.h108 struct btframe stack[MAXTREEHEIGHT]; member
112 (btstack)->top = (btstack)->stack
115 ( (btstack)->top == &((btstack)->stack[MAXTREEHEIGHT-1]))
126 ( (btstack)->top == (btstack)->stack ? NULL : --(btstack)->top )
129 ( (btstack)->top == (btstack)->stack ? NULL : (btstack)->top )
137 (long long)btstack->stack[i].bn, in BT_STACK_DUMP()
138 btstack->stack[i].index); in BT_STACK_DUMP()

12345678910>>...33