52 lines
1.6 KiB
C
Executable File
52 lines
1.6 KiB
C
Executable File
/* MN10300/AM33v2 Microcontroller SMP registers
|
|
*
|
|
* Copyright (C) 2006 Matsushita Electric Industrial Co., Ltd.
|
|
* All Rights Reserved.
|
|
* Created:
|
|
* 13-Nov-2006 MEI Add extended cache and atomic operation register
|
|
* for SMP support.
|
|
* 23-Feb-2007 MEI Add define for gdbstub SMP.
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; either version
|
|
* 2 of the License, or (at your option) any later version.
|
|
*/
|
|
|
|
#ifndef _ASM_PROC_SMP_REGS_H
|
|
#define _ASM_PROC_SMP_REGS_H
|
|
|
|
#ifdef __KERNEL__
|
|
|
|
#ifndef __ASSEMBLY__
|
|
#include <linux/types.h>
|
|
#endif
|
|
#include <asm/cpu-regs.h>
|
|
|
|
/*
|
|
* Reference to the interrupt controllers of other CPUs
|
|
*/
|
|
#define CROSS_ICR_CPU_SHIFT 16
|
|
|
|
#define CROSS_GxICR(X, CPU) __SYSREG(0xc4000000 + (X) * 4 + \
|
|
((X) >= 64 && (X) < 192) * 0xf00 + ((CPU) << CROSS_ICR_CPU_SHIFT), u16)
|
|
#define CROSS_GxICR_u8(X, CPU) __SYSREG(0xc4000000 + (X) * 4 + \
|
|
(((X) >= 64) && ((X) < 192)) * 0xf00 + ((CPU) << CROSS_ICR_CPU_SHIFT), u8)
|
|
|
|
/* CPU ID register */
|
|
#define CPUID __SYSREGC(0xc0000054, u32)
|
|
#define CPUID_MASK 0x00000007 /* CPU ID mask */
|
|
|
|
/* extended cache control register */
|
|
#define ECHCTR __SYSREG(0xc0000c20, u32)
|
|
#define ECHCTR_IBCM 0x00000001 /* instruction cache broad cast mask */
|
|
#define ECHCTR_DBCM 0x00000002 /* data cache broad cast mask */
|
|
#define ECHCTR_ISPM 0x00000004 /* instruction cache snoop mask */
|
|
#define ECHCTR_DSPM 0x00000008 /* data cache snoop mask */
|
|
|
|
#define NMIAGR __SYSREG(0xd400013c, u16)
|
|
#define NMIAGR_GN 0x03fc
|
|
|
|
#endif /* __KERNEL__ */
|
|
#endif /* _ASM_PROC_SMP_REGS_H */
|