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
54 lines
989 B
C
54 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 */
|