#ifndef _MIPS64_LOONGSON3_H_
#define _MIPS64_LOONGSON3_H_
#define LS3_CFG_BASE(node) (0x100000004000ull*(node) + 0x3ff00000)
#define LS3_MEM_BASE(node) (0x100000000000ull*(node))
#define LS3_IPI_BASE(n, c) (LS3_CFG_BASE(n) + 0x1000 + 0x100*(c))
#define LS3_IPI_ISR 0x00
#define LS3_IPI_IMR 0x04
#define LS3_IPI_SET 0x08
#define LS3_IPI_CLEAR 0x0c
#define LS3_IPI_MBOX0 0x20
#define LS3_IPI_MBOX1 0x28
#define LS3_IPI_MBOX2 0x30
#define LS3_IPI_MBOX3 0x38
static inline uint32_t
loongson3_get_cpuid(void)
{
uint32_t tmp;
asm volatile (
" .set push\n"
" .set mips64\n"
" mfc0 %0, $15, 1\n"
" .set pop\n"
: "=r" (tmp));
return tmp & 0xf;
}
#define LS3_COREID(cpuid) ((cpuid) & 3)
#define LS3_NODEID(cpuid) ((cpuid) >> 2)
#define LS3_IRT_ENTRY(node, irq) (LS3_CFG_BASE(node) + 0x1400 + (irq))
#define LS3_IRT_INTISR(node) (LS3_CFG_BASE(node) + 0x1420)
#define LS3_IRT_INTEN(node) (LS3_CFG_BASE(node) + 0x1424)
#define LS3_IRT_INTENSET(node) (LS3_CFG_BASE(node) + 0x1428)
#define LS3_IRT_INTENCLR(node) (LS3_CFG_BASE(node) + 0x142c)
#define LS3_IRT_INTISR_CORE(node, cpu) (LS3_CFG_BASE(node) + 0x1440 + (cpu)*8)
#define LS3_IRT_ENTRY_INT(node, x) LS3_IRT_ENTRY((node), (x))
#define LS3_IRT_ENTRY_PCI(node, x) LS3_IRT_ENTRY((node), 0x04+(x))
#define LS3_IRT_ENTRY_LPC(node) LS3_IRT_ENTRY((node), 0x0a)
#define LS3_IRT_ENTRY_HT0(node, x) LS3_IRT_ENTRY((node), 0x10+(x))
#define LS3_IRT_ENTRY_HT1(node, x) LS3_IRT_ENTRY((node), 0x18+(x))
#define LS3_IRT_ROUTE(core, intr) ((0x01 << (core)) | (0x10 << (intr)))
#define LS3_IRQ_INT(x) (x)
#define LS3_IRQ_PCI(x) ((x) + 0x04)
#define LS3_IRQ_LPC 0x0a
#define LS3_IRQ_HT0(x) ((x) + 0x10)
#define LS3_IRQ_HT1(x) ((x) + 0x18)
#define LS3_IRQ_NUM 32
#define LS3_IRQ_IS_HT(irq) ((irq) >= 0x10)
#define LS3_IRQ_HT_MASK 0xffff0000u
#define LS3_HT_IRQ_NUM 32
#define LS3_HT1_MEM_BASE(n) (LS3_MEM_BASE(n)+0x00000e0000000000ull)
#define LS3_HT1_CFG_BASE(n) (LS3_MEM_BASE(n)+0x00000efdfb000000ull)
#define LS3_HT_ISR_OFFSET(x) (0x80 + (x) * 4)
#define LS3_HT_IMR_OFFSET(x) (0xa0 + (x) * 4)
#endif