mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 b62818e5ff
			
		
	
	
		b62818e5ff
		
	
	
	
	
		
			
			Doing NMI startup as an early initcall doesn't work because we need to have SMP started up by then. So we'd only NMI startup one cpu, which causes perf PMU grab to BUG because the nmi_active count isn't what it's supposed to be. This also points out that we don't have proper CPU up/down notifiers for the NMI code which will need to be fixed at some point. Signed-off-by: David S. Miller <davem@davemloft.net>
		
			
				
	
	
		
			49 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			49 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef __PCR_H
 | |
| #define __PCR_H
 | |
| 
 | |
| struct pcr_ops {
 | |
| 	u64 (*read)(void);
 | |
| 	void (*write)(u64);
 | |
| };
 | |
| extern const struct pcr_ops *pcr_ops;
 | |
| 
 | |
| extern void deferred_pcr_work_irq(int irq, struct pt_regs *regs);
 | |
| extern void schedule_deferred_pcr_work(void);
 | |
| 
 | |
| #define PCR_PIC_PRIV		0x00000001 /* PIC access is privileged */
 | |
| #define PCR_STRACE		0x00000002 /* Trace supervisor events  */
 | |
| #define PCR_UTRACE		0x00000004 /* Trace user events        */
 | |
| #define PCR_N2_HTRACE		0x00000008 /* Trace hypervisor events  */
 | |
| #define PCR_N2_TOE_OV0		0x00000010 /* Trap if PIC 0 overflows  */
 | |
| #define PCR_N2_TOE_OV1		0x00000020 /* Trap if PIC 1 overflows  */
 | |
| #define PCR_N2_MASK0		0x00003fc0
 | |
| #define PCR_N2_MASK0_SHIFT	6
 | |
| #define PCR_N2_SL0		0x0003c000
 | |
| #define PCR_N2_SL0_SHIFT	14
 | |
| #define PCR_N2_OV0		0x00040000
 | |
| #define PCR_N2_MASK1		0x07f80000
 | |
| #define PCR_N2_MASK1_SHIFT	19
 | |
| #define PCR_N2_SL1		0x78000000
 | |
| #define PCR_N2_SL1_SHIFT	27
 | |
| #define PCR_N2_OV1		0x80000000
 | |
| 
 | |
| extern unsigned int picl_shift;
 | |
| 
 | |
| /* In order to commonize as much of the implementation as
 | |
|  * possible, we use PICH as our counter.  Mostly this is
 | |
|  * to accomodate Niagara-1 which can only count insn cycles
 | |
|  * in PICH.
 | |
|  */
 | |
| static inline u64 picl_value(unsigned int nmi_hz)
 | |
| {
 | |
| 	u32 delta = local_cpu_data().clock_tick / (nmi_hz << picl_shift);
 | |
| 
 | |
| 	return ((u64)((0 - delta) & 0xffffffff)) << 32;
 | |
| }
 | |
| 
 | |
| extern u64 pcr_enable;
 | |
| 
 | |
| extern int pcr_arch_init(void);
 | |
| 
 | |
| #endif /* __PCR_H */
 |