mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 10:40:15 +02:00 
			
		
		
		
	MIPS: Fix crash that occurs when function tracing is enabled
A recent patch changed some irq routines from inlines to functions. These routines are called by the tracer code. Now that they're functions, if they are compiled for function tracing they will call the tracer and crash the system due to infinite recursion. The fix disables tracing in these functions by using "notrace" in the function definition. Signed-off-by: Al Cooper <alcooperx@gmail.com> Reviewed-by: David Daney <david.daney@cavium.com> Pathchwork: https://patchwork.linux-mips.org/patch/4564/ Signed-off-by: Ralf Baechle <ralf@linux-mips.org>
This commit is contained in:
		
							parent
							
								
									0ec7ec75f6
								
							
						
					
					
						commit
						f93a1a00f2
					
				
					 1 changed files with 4 additions and 4 deletions
				
			
		| 
						 | 
				
			
			@ -56,7 +56,7 @@ __asm__(
 | 
			
		|||
	"	.set	pop						\n"
 | 
			
		||||
	"	.endm							\n");
 | 
			
		||||
 | 
			
		||||
void arch_local_irq_disable(void)
 | 
			
		||||
notrace void arch_local_irq_disable(void)
 | 
			
		||||
{
 | 
			
		||||
	preempt_disable();
 | 
			
		||||
	__asm__ __volatile__(
 | 
			
		||||
| 
						 | 
				
			
			@ -93,7 +93,7 @@ __asm__(
 | 
			
		|||
	"	.set	pop						\n"
 | 
			
		||||
	"	.endm							\n");
 | 
			
		||||
 | 
			
		||||
unsigned long arch_local_irq_save(void)
 | 
			
		||||
notrace unsigned long arch_local_irq_save(void)
 | 
			
		||||
{
 | 
			
		||||
	unsigned long flags;
 | 
			
		||||
	preempt_disable();
 | 
			
		||||
| 
						 | 
				
			
			@ -135,7 +135,7 @@ __asm__(
 | 
			
		|||
	"	.set	pop						\n"
 | 
			
		||||
	"	.endm							\n");
 | 
			
		||||
 | 
			
		||||
void arch_local_irq_restore(unsigned long flags)
 | 
			
		||||
notrace void arch_local_irq_restore(unsigned long flags)
 | 
			
		||||
{
 | 
			
		||||
	unsigned long __tmp1;
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -159,7 +159,7 @@ void arch_local_irq_restore(unsigned long flags)
 | 
			
		|||
EXPORT_SYMBOL(arch_local_irq_restore);
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
void __arch_local_irq_restore(unsigned long flags)
 | 
			
		||||
notrace void __arch_local_irq_restore(unsigned long flags)
 | 
			
		||||
{
 | 
			
		||||
	unsigned long __tmp1;
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in a new issue