mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 02:30:34 +02:00 
			
		
		
		
	Only build the checks for R4k errata workarounds if we expect that the kernel might actually run on a system with an R4k CPU - ie. CONFIG_SYS_HAS_CPU_R4X00=y & we're targeting a pre-MIPSr1 ISA revision. Rename cpu-bugs64.c to r4k-bugs64.c to indicate the fact that the code is specific to R4k CPUs. Signed-off-by: Paul Burton <paul.burton@mips.com> Cc: linux-mips@vger.kernel.org
		
			
				
	
	
		
			53 lines
		
	
	
	
		
			989 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
	
		
			989 B
		
	
	
	
		
			C
		
	
	
	
	
	
/* SPDX-License-Identifier: GPL-2.0 */
 | 
						|
/*
 | 
						|
 * This is included by init/main.c to check for architecture-dependent bugs.
 | 
						|
 *
 | 
						|
 * Copyright (C) 2007  Maciej W. Rozycki
 | 
						|
 *
 | 
						|
 * Needs:
 | 
						|
 *	void check_bugs(void);
 | 
						|
 */
 | 
						|
#ifndef _ASM_BUGS_H
 | 
						|
#define _ASM_BUGS_H
 | 
						|
 | 
						|
#include <linux/bug.h>
 | 
						|
#include <linux/delay.h>
 | 
						|
#include <linux/smp.h>
 | 
						|
 | 
						|
#include <asm/cpu.h>
 | 
						|
#include <asm/cpu-info.h>
 | 
						|
 | 
						|
extern int daddiu_bug;
 | 
						|
 | 
						|
extern void check_bugs64_early(void);
 | 
						|
 | 
						|
extern void check_bugs32(void);
 | 
						|
extern void check_bugs64(void);
 | 
						|
 | 
						|
static inline void check_bugs_early(void)
 | 
						|
{
 | 
						|
	if (IS_ENABLED(CONFIG_CPU_R4X00_BUGS64))
 | 
						|
		check_bugs64_early();
 | 
						|
}
 | 
						|
 | 
						|
static inline void check_bugs(void)
 | 
						|
{
 | 
						|
	unsigned int cpu = smp_processor_id();
 | 
						|
 | 
						|
	cpu_data[cpu].udelay_val = loops_per_jiffy;
 | 
						|
	check_bugs32();
 | 
						|
 | 
						|
	if (IS_ENABLED(CONFIG_CPU_R4X00_BUGS64))
 | 
						|
		check_bugs64();
 | 
						|
}
 | 
						|
 | 
						|
static inline int r4k_daddiu_bug(void)
 | 
						|
{
 | 
						|
	if (!IS_ENABLED(CONFIG_CPU_R4X00_BUGS64))
 | 
						|
		return 0;
 | 
						|
 | 
						|
	WARN_ON(daddiu_bug < 0);
 | 
						|
	return daddiu_bug != 0;
 | 
						|
}
 | 
						|
 | 
						|
#endif /* _ASM_BUGS_H */
 |