 ab5318788c
			
		
	
	
	ab5318788c
	
	
	
		
			
			Pull core debug changes from Ingo Molnar: "This contains mostly kernel debugging related updates: - make hung_task detection more configurable to distros - add final bits for x86 UV NMI debugging, with related KGDB changes - update the mailing-list of MAINTAINERS entries I'm involved with" * 'core-urgent-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: hung_task: Display every hung task warning sysctl: Add neg_one as a standard constraint x86/uv/nmi, kgdb/kdb: Fix UV NMI handler when KDB not configured x86/uv/nmi: Fix Sparse warnings kgdb/kdb: Fix no KDB config problem MAINTAINERS: Restore "L: linux-kernel@vger.kernel.org" entries
		
			
				
	
	
		
			106 lines
		
	
	
	
		
			3.2 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			106 lines
		
	
	
	
		
			3.2 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef _SCHED_SYSCTL_H
 | |
| #define _SCHED_SYSCTL_H
 | |
| 
 | |
| #ifdef CONFIG_DETECT_HUNG_TASK
 | |
| extern int	     sysctl_hung_task_check_count;
 | |
| extern unsigned int  sysctl_hung_task_panic;
 | |
| extern unsigned long sysctl_hung_task_timeout_secs;
 | |
| extern int sysctl_hung_task_warnings;
 | |
| extern int proc_dohung_task_timeout_secs(struct ctl_table *table, int write,
 | |
| 					 void __user *buffer,
 | |
| 					 size_t *lenp, loff_t *ppos);
 | |
| #else
 | |
| /* Avoid need for ifdefs elsewhere in the code */
 | |
| enum { sysctl_hung_task_timeout_secs = 0 };
 | |
| #endif
 | |
| 
 | |
| /*
 | |
|  * Default maximum number of active map areas, this limits the number of vmas
 | |
|  * per mm struct. Users can overwrite this number by sysctl but there is a
 | |
|  * problem.
 | |
|  *
 | |
|  * When a program's coredump is generated as ELF format, a section is created
 | |
|  * per a vma. In ELF, the number of sections is represented in unsigned short.
 | |
|  * This means the number of sections should be smaller than 65535 at coredump.
 | |
|  * Because the kernel adds some informative sections to a image of program at
 | |
|  * generating coredump, we need some margin. The number of extra sections is
 | |
|  * 1-3 now and depends on arch. We use "5" as safe margin, here.
 | |
|  */
 | |
| #define MAPCOUNT_ELF_CORE_MARGIN	(5)
 | |
| #define DEFAULT_MAX_MAP_COUNT	(USHRT_MAX - MAPCOUNT_ELF_CORE_MARGIN)
 | |
| 
 | |
| extern int sysctl_max_map_count;
 | |
| 
 | |
| extern unsigned int sysctl_sched_latency;
 | |
| extern unsigned int sysctl_sched_min_granularity;
 | |
| extern unsigned int sysctl_sched_wakeup_granularity;
 | |
| extern unsigned int sysctl_sched_child_runs_first;
 | |
| 
 | |
| enum sched_tunable_scaling {
 | |
| 	SCHED_TUNABLESCALING_NONE,
 | |
| 	SCHED_TUNABLESCALING_LOG,
 | |
| 	SCHED_TUNABLESCALING_LINEAR,
 | |
| 	SCHED_TUNABLESCALING_END,
 | |
| };
 | |
| extern enum sched_tunable_scaling sysctl_sched_tunable_scaling;
 | |
| 
 | |
| extern unsigned int sysctl_numa_balancing_scan_delay;
 | |
| extern unsigned int sysctl_numa_balancing_scan_period_min;
 | |
| extern unsigned int sysctl_numa_balancing_scan_period_max;
 | |
| extern unsigned int sysctl_numa_balancing_scan_size;
 | |
| 
 | |
| #ifdef CONFIG_SCHED_DEBUG
 | |
| extern unsigned int sysctl_sched_migration_cost;
 | |
| extern unsigned int sysctl_sched_nr_migrate;
 | |
| extern unsigned int sysctl_sched_time_avg;
 | |
| extern unsigned int sysctl_timer_migration;
 | |
| extern unsigned int sysctl_sched_shares_window;
 | |
| 
 | |
| int sched_proc_update_handler(struct ctl_table *table, int write,
 | |
| 		void __user *buffer, size_t *length,
 | |
| 		loff_t *ppos);
 | |
| #endif
 | |
| #ifdef CONFIG_SCHED_DEBUG
 | |
| static inline unsigned int get_sysctl_timer_migration(void)
 | |
| {
 | |
| 	return sysctl_timer_migration;
 | |
| }
 | |
| #else
 | |
| static inline unsigned int get_sysctl_timer_migration(void)
 | |
| {
 | |
| 	return 1;
 | |
| }
 | |
| #endif
 | |
| 
 | |
| /*
 | |
|  *  control realtime throttling:
 | |
|  *
 | |
|  *  /proc/sys/kernel/sched_rt_period_us
 | |
|  *  /proc/sys/kernel/sched_rt_runtime_us
 | |
|  */
 | |
| extern unsigned int sysctl_sched_rt_period;
 | |
| extern int sysctl_sched_rt_runtime;
 | |
| 
 | |
| #ifdef CONFIG_CFS_BANDWIDTH
 | |
| extern unsigned int sysctl_sched_cfs_bandwidth_slice;
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_SCHED_AUTOGROUP
 | |
| extern unsigned int sysctl_sched_autogroup_enabled;
 | |
| #endif
 | |
| 
 | |
| extern int sched_rr_timeslice;
 | |
| 
 | |
| extern int sched_rr_handler(struct ctl_table *table, int write,
 | |
| 		void __user *buffer, size_t *lenp,
 | |
| 		loff_t *ppos);
 | |
| 
 | |
| extern int sched_rt_handler(struct ctl_table *table, int write,
 | |
| 		void __user *buffer, size_t *lenp,
 | |
| 		loff_t *ppos);
 | |
| 
 | |
| extern int sysctl_numa_balancing(struct ctl_table *table, int write,
 | |
| 				 void __user *buffer, size_t *lenp,
 | |
| 				 loff_t *ppos);
 | |
| 
 | |
| #endif /* _SCHED_SYSCTL_H */
 |