mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 0cd39f4600
			
		
	
	
		0cd39f4600
		
	
	
	
	
		
			
			By using lockdep_assert_*() from seqlock.h, the spaghetti monster
attacked.
Attack back by reducing seqlock.h dependencies from two key high level headers:
 - <linux/seqlock.h>:               -Remove <linux/ww_mutex.h>
 - <linux/time.h>:                  -Remove <linux/seqlock.h>
 - <linux/sched.h>:                 +Add    <linux/seqlock.h>
The price was to add it to sched.h ...
Core header fallout, we add direct header dependencies instead of gaining them
parasitically from higher level headers:
 - <linux/dynamic_queue_limits.h>:  +Add <asm/bug.h>
 - <linux/hrtimer.h>:               +Add <linux/seqlock.h>
 - <linux/ktime.h>:                 +Add <asm/bug.h>
 - <linux/lockdep.h>:               +Add <linux/smp.h>
 - <linux/sched.h>:                 +Add <linux/seqlock.h>
 - <linux/videodev2.h>:             +Add <linux/kernel.h>
Arch headers fallout:
 - PARISC: <asm/timex.h>:           +Add <asm/special_insns.h>
 - SH:     <asm/io.h>:              +Add <asm/page.h>
 - SPARC:  <asm/timer_64.h>:        +Add <uapi/asm/asi.h>
 - SPARC:  <asm/vvar.h>:            +Add <asm/processor.h>, <asm/barrier.h>
                                    -Remove <linux/seqlock.h>
 - X86:    <asm/fixmap.h>:          +Add <asm/pgtable_types.h>
                                    -Remove <asm/acpi.h>
There's also a bunch of parasitic header dependency fallout in .c files, not listed
separately.
[ mingo: Extended the changelog, split up & fixed the original patch. ]
Co-developed-by: Ingo Molnar <mingo@kernel.org>
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Link: https://lore.kernel.org/r/20200804133438.GK2674@hirez.programming.kicks-ass.net
		
	
			
		
			
				
	
	
		
			60 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0
 | |
| /*
 | |
|  *  HW NMI watchdog support
 | |
|  *
 | |
|  *  started by Don Zickus, Copyright (C) 2010 Red Hat, Inc.
 | |
|  *
 | |
|  *  Arch specific calls to support NMI watchdog
 | |
|  *
 | |
|  *  Bits copied from original nmi.c file
 | |
|  *
 | |
|  */
 | |
| #include <linux/thread_info.h>
 | |
| #include <asm/apic.h>
 | |
| #include <asm/nmi.h>
 | |
| 
 | |
| #include <linux/cpumask.h>
 | |
| #include <linux/kdebug.h>
 | |
| #include <linux/notifier.h>
 | |
| #include <linux/kprobes.h>
 | |
| #include <linux/nmi.h>
 | |
| #include <linux/init.h>
 | |
| #include <linux/delay.h>
 | |
| 
 | |
| #ifdef CONFIG_HARDLOCKUP_DETECTOR_PERF
 | |
| u64 hw_nmi_get_sample_period(int watchdog_thresh)
 | |
| {
 | |
| 	return (u64)(cpu_khz) * 1000 * watchdog_thresh;
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #ifdef arch_trigger_cpumask_backtrace
 | |
| static void nmi_raise_cpu_backtrace(cpumask_t *mask)
 | |
| {
 | |
| 	apic->send_IPI_mask(mask, NMI_VECTOR);
 | |
| }
 | |
| 
 | |
| void arch_trigger_cpumask_backtrace(const cpumask_t *mask, bool exclude_self)
 | |
| {
 | |
| 	nmi_trigger_cpumask_backtrace(mask, exclude_self,
 | |
| 				      nmi_raise_cpu_backtrace);
 | |
| }
 | |
| 
 | |
| static int nmi_cpu_backtrace_handler(unsigned int cmd, struct pt_regs *regs)
 | |
| {
 | |
| 	if (nmi_cpu_backtrace(regs))
 | |
| 		return NMI_HANDLED;
 | |
| 
 | |
| 	return NMI_DONE;
 | |
| }
 | |
| NOKPROBE_SYMBOL(nmi_cpu_backtrace_handler);
 | |
| 
 | |
| static int __init register_nmi_cpu_backtrace_handler(void)
 | |
| {
 | |
| 	register_nmi_handler(NMI_LOCAL, nmi_cpu_backtrace_handler,
 | |
| 				0, "arch_bt");
 | |
| 	return 0;
 | |
| }
 | |
| early_initcall(register_nmi_cpu_backtrace_handler);
 | |
| #endif
 |