2005-04-16 16:20:36 -06:00
|
|
|
/*
|
|
|
|
* This file is subject to the terms and conditions of the GNU General Public
|
|
|
|
* License. See the file "COPYING" in the main directory of this archive
|
|
|
|
* for more details.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2003 Ralf Baechle
|
|
|
|
*/
|
|
|
|
#ifndef _ASM_ASMMACRO_H
|
|
|
|
#define _ASM_ASMMACRO_H
|
2005-09-03 16:56:17 -06:00
|
|
|
|
2005-04-16 16:20:36 -06:00
|
|
|
#include <linux/config.h>
|
|
|
|
#include <asm/hazards.h>
|
2005-09-03 16:56:17 -06:00
|
|
|
|
2005-09-03 16:56:16 -06:00
|
|
|
#ifdef CONFIG_32BIT
|
2005-04-16 16:20:36 -06:00
|
|
|
#include <asm/asmmacro-32.h>
|
|
|
|
#endif
|
2005-09-03 16:56:16 -06:00
|
|
|
#ifdef CONFIG_64BIT
|
2005-04-16 16:20:36 -06:00
|
|
|
#include <asm/asmmacro-64.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
.macro local_irq_enable reg=t0
|
|
|
|
mfc0 \reg, CP0_STATUS
|
|
|
|
ori \reg, \reg, 1
|
|
|
|
mtc0 \reg, CP0_STATUS
|
|
|
|
irq_enable_hazard
|
|
|
|
.endm
|
|
|
|
|
|
|
|
.macro local_irq_disable reg=t0
|
|
|
|
mfc0 \reg, CP0_STATUS
|
|
|
|
ori \reg, \reg, 1
|
|
|
|
xori \reg, \reg, 1
|
|
|
|
mtc0 \reg, CP0_STATUS
|
|
|
|
irq_disable_hazard
|
|
|
|
.endm
|
|
|
|
|
|
|
|
#ifdef CONFIG_CPU_SB1
|
|
|
|
.macro fpu_enable_hazard
|
|
|
|
.set push
|
|
|
|
.set noreorder
|
|
|
|
.set mips2
|
|
|
|
SSNOP
|
|
|
|
bnezl $0, .+4
|
|
|
|
SSNOP
|
|
|
|
.set pop
|
|
|
|
.endm
|
|
|
|
#else
|
|
|
|
.macro fpu_enable_hazard
|
|
|
|
.endm
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* _ASM_ASMMACRO_H */
|