50 lines
1.1 KiB
C
50 lines
1.1 KiB
C
/*
|
|
* linux/arch/parisc/kernel/pa7300lc.c
|
|
* - PA7300LC-specific functions
|
|
*
|
|
* Copyright (C) 2000 Philipp Rumpf */
|
|
|
|
#include <linux/sched.h>
|
|
#include <linux/smp.h>
|
|
#include <linux/kernel.h>
|
|
#include <asm/io.h>
|
|
#include <asm/ptrace.h>
|
|
#include <asm/machdep.h>
|
|
|
|
/* CPU register indices */
|
|
|
|
#define MIOC_STATUS 0xf040
|
|
#define MIOC_CONTROL 0xf080
|
|
#define MDERRADD 0xf0e0
|
|
#define DMAERR 0xf0e8
|
|
#define DIOERR 0xf0ec
|
|
#define HIDMAMEM 0xf0f4
|
|
|
|
/* this returns the HPA of the CPU it was called on */
|
|
static u32 cpu_hpa(void)
|
|
{
|
|
return 0xfffb0000;
|
|
}
|
|
|
|
static void pa7300lc_lpmc(int code, struct pt_regs *regs)
|
|
{
|
|
u32 hpa;
|
|
printk(KERN_WARNING "LPMC on CPU %d\n", smp_processor_id());
|
|
|
|
show_regs(regs);
|
|
|
|
hpa = cpu_hpa();
|
|
printk(KERN_WARNING
|
|
"MIOC_CONTROL %08x\n" "MIOC_STATUS %08x\n"
|
|
"MDERRADD %08x\n" "DMAERR %08x\n"
|
|
"DIOERR %08x\n" "HIDMAMEM %08x\n",
|
|
gsc_readl(hpa+MIOC_CONTROL), gsc_readl(hpa+MIOC_STATUS),
|
|
gsc_readl(hpa+MDERRADD), gsc_readl(hpa+DMAERR),
|
|
gsc_readl(hpa+DIOERR), gsc_readl(hpa+HIDMAMEM));
|
|
}
|
|
|
|
void pa7300lc_init(void)
|
|
{
|
|
cpu_lpmc = pa7300lc_lpmc;
|
|
}
|