/Linux-v6.6/arch/x86/include/asm/ |
D | preempt.h | 27 return raw_cpu_read_4(pcpu_hot.preempt_count) & ~PREEMPT_NEED_RESCHED; in preempt_count() 35 old = raw_cpu_read_4(pcpu_hot.preempt_count); in preempt_count_set() 38 } while (raw_cpu_cmpxchg_4(pcpu_hot.preempt_count, old, new) != old); in preempt_count_set() 47 per_cpu(pcpu_hot.preempt_count, (cpu)) = PREEMPT_DISABLED; \ 61 raw_cpu_and_4(pcpu_hot.preempt_count, ~PREEMPT_NEED_RESCHED); in set_preempt_need_resched() 66 raw_cpu_or_4(pcpu_hot.preempt_count, PREEMPT_NEED_RESCHED); in clear_preempt_need_resched() 71 return !(raw_cpu_read_4(pcpu_hot.preempt_count) & PREEMPT_NEED_RESCHED); in test_preempt_need_resched() 80 raw_cpu_add_4(pcpu_hot.preempt_count, val); in __preempt_count_add() 85 raw_cpu_add_4(pcpu_hot.preempt_count, -val); in __preempt_count_sub() 95 return GEN_UNARY_RMWcc("decl", pcpu_hot.preempt_count, e, in __preempt_count_dec_and_test() [all …]
|
D | current.h | 14 struct pcpu_hot { struct 35 static_assert(sizeof(struct pcpu_hot) == 64); argument 37 DECLARE_PER_CPU_ALIGNED(struct pcpu_hot, pcpu_hot); 41 return this_cpu_read_stable(pcpu_hot.current_task); in get_current()
|
D | irq_stack.h | 119 call_on_stack(__this_cpu_read(pcpu_hot.hardirq_stack_ptr), \ 138 if (user_mode(regs) || __this_cpu_read(pcpu_hot.hardirq_stack_inuse)) { \ 149 __this_cpu_write(pcpu_hot.hardirq_stack_inuse, true); \ 151 __this_cpu_write(pcpu_hot.hardirq_stack_inuse, false); \ 215 __this_cpu_write(pcpu_hot.hardirq_stack_inuse, true); \ 217 __this_cpu_write(pcpu_hot.hardirq_stack_inuse, false); \
|
D | nospec-branch.h | 81 movq $-1, PER_CPU_VAR(pcpu_hot + X86_call_depth); 84 movq $-1, PER_CPU_VAR(pcpu_hot + X86_call_depth); 89 movq %rax, PER_CPU_VAR(pcpu_hot + X86_call_depth); 94 movq %rax, PER_CPU_VAR(pcpu_hot + X86_call_depth); \ 98 sarq $5, %gs:pcpu_hot + X86_call_depth; \ 102 sarq $5, PER_CPU_VAR(pcpu_hot + X86_call_depth); \
|
D | smp.h | 146 #define raw_smp_processor_id() this_cpu_read(pcpu_hot.cpu_number) 147 #define __smp_processor_id() __this_cpu_read(pcpu_hot.cpu_number)
|
D | hardirq.h | 63 #define local_softirq_pending_ref pcpu_hot.softirq_pending
|
D | processor.h | 521 return this_cpu_read_stable(pcpu_hot.top_of_stack); in current_top_of_stack()
|
/Linux-v6.6/arch/x86/kernel/ |
D | irq_32.c | 77 irqstk = __this_cpu_read(pcpu_hot.hardirq_stack_ptr); in execute_on_irq_stack() 115 if (per_cpu(pcpu_hot.hardirq_stack_ptr, cpu)) in irq_init_percpu_irqstack() 127 per_cpu(pcpu_hot.hardirq_stack_ptr, cpu) = page_address(ph); in irq_init_percpu_irqstack() 128 per_cpu(pcpu_hot.softirq_stack_ptr, cpu) = page_address(ps); in irq_init_percpu_irqstack() 138 irqstk = __this_cpu_read(pcpu_hot.softirq_stack_ptr); in do_softirq_own_stack()
|
D | irq_64.c | 53 per_cpu(pcpu_hot.hardirq_stack_ptr, cpu) = va + IRQ_STACK_SIZE - 8; in map_irq_stack() 66 per_cpu(pcpu_hot.hardirq_stack_ptr, cpu) = va + IRQ_STACK_SIZE - 8; in map_irq_stack() 73 if (per_cpu(pcpu_hot.hardirq_stack_ptr, cpu)) in irq_init_percpu_irqstack()
|
D | asm-offsets.c | 117 OFFSET(X86_top_of_stack, pcpu_hot, top_of_stack); in common() 118 OFFSET(X86_current_task, pcpu_hot, current_task); in common() 120 OFFSET(X86_call_depth, pcpu_hot, call_depth); in common()
|
D | dumpstack_32.c | 40 unsigned long *begin = (unsigned long *)this_cpu_read(pcpu_hot.hardirq_stack_ptr); in in_hardirq_stack() 65 unsigned long *begin = (unsigned long *)this_cpu_read(pcpu_hot.softirq_stack_ptr); in in_softirq_stack()
|
D | process_32.c | 200 this_cpu_write(pcpu_hot.top_of_stack, in __switch_to() 210 raw_cpu_write(pcpu_hot.current_task, next_p); in __switch_to()
|
D | process_64.c | 569 this_cpu_read(pcpu_hot.hardirq_stack_inuse)); in __switch_to() 623 raw_cpu_write(pcpu_hot.current_task, next_p); in __switch_to() 624 raw_cpu_write(pcpu_hot.top_of_stack, task_top_of_stack(next_p)); in __switch_to()
|
D | setup_percpu.c | 172 per_cpu(pcpu_hot.cpu_number, cpu) = cpu; in setup_per_cpu_areas()
|
D | dumpstack_64.c | 137 unsigned long *end = (unsigned long *)this_cpu_read(pcpu_hot.hardirq_stack_ptr); in in_irq_stack()
|
D | head_64.S | 307 movq pcpu_hot + X86_current_task(%rdx), %rax 452 movq PER_CPU_VAR(pcpu_hot) + X86_current_task, %rcx
|
D | traps.c | 775 struct pt_regs *regs = (struct pt_regs *)this_cpu_read(pcpu_hot.top_of_stack) - 1; in sync_regs() 793 sp = this_cpu_read(pcpu_hot.top_of_stack); in vc_switch_off_ist()
|
D | smpboot.c | 964 per_cpu(pcpu_hot.current_task, cpu) = idle; in common_cpu_up() 974 per_cpu(pcpu_hot.top_of_stack, cpu) = task_top_of_stack(idle); in common_cpu_up()
|
/Linux-v6.6/arch/x86/entry/ |
D | entry_64_compat.S | 61 movq PER_CPU_VAR(pcpu_hot + X86_top_of_stack), %rsp 193 movq PER_CPU_VAR(pcpu_hot + X86_top_of_stack), %rsp 334 movq PER_CPU_VAR(pcpu_hot + X86_top_of_stack), %rsp
|
D | entry_64.S | 95 movq PER_CPU_VAR(pcpu_hot + X86_top_of_stack), %rsp 1218 movq PER_CPU_VAR(pcpu_hot + X86_top_of_stack), %rsp 1534 movq PER_CPU_VAR(pcpu_hot + X86_top_of_stack), %rax
|
D | entry_32.S | 1157 movl PER_CPU_VAR(pcpu_hot + X86_top_of_stack), %esp 1219 movl PER_CPU_VAR(pcpu_hot + X86_top_of_stack), %esi
|
/Linux-v6.6/arch/x86/lib/ |
D | retpoline.S | 339 shlq $5, PER_CPU_VAR(pcpu_hot + X86_call_depth)
|
/Linux-v6.6/arch/x86/kernel/cpu/ |
D | common.c | 2048 DEFINE_PER_CPU_ALIGNED(struct pcpu_hot, pcpu_hot) = { 2053 EXPORT_PER_CPU_SYMBOL(pcpu_hot);
|