crime.c
上传用户:lgb322
上传日期:2013-02-24
资源大小:30529k
文件大小:1k
源码类别:

嵌入式Linux

开发平台:

Unix_Linux

  1. /*
  2.  * This file is subject to the terms and conditions of the GNU General Public
  3.  * License.  See the file "COPYING" in the main directory of this archive
  4.  * for more details.
  5.  *
  6.  * Copyright (C) 2001 Keith M Wesolowski
  7.  */
  8. #include <linux/types.h>
  9. #include <linux/init.h>
  10. #include <linux/kernel.h>
  11. #include <asm/ip32/crime.h>
  12. #include <asm/ptrace.h>
  13. #include <asm/promlib.h>
  14. void __init crime_init (void)
  15. {
  16. u64 id = crime_read_64 (CRIME_ID);
  17. u64 rev = id & CRIME_ID_REV;
  18. id = (id & CRIME_ID_IDBITS) >> 4;
  19. printk ("CRIME id %1lx rev %ld detected at %016lxn", id, rev,
  20. (unsigned long) CRIME_BASE);
  21. }
  22. /* XXX Like on Sun, these give us various useful information to printk. */
  23. void crime_memerr_intr (unsigned int irq, void *dev_id, struct pt_regs *regs)
  24. {
  25. u64 memerr = crime_read_64 (CRIME_MEM_ERROR_STAT);
  26. u64 addr = crime_read_64 (CRIME_MEM_ERROR_ADDR);
  27. memerr &= CRIME_MEM_ERROR_STAT_MASK;
  28. printk ("CRIME memory error at physaddr 0x%08lx status %08lxn",
  29. addr << 2, memerr);
  30. crime_write_64 (CRIME_MEM_ERROR_STAT, 0);
  31. }
  32. void crime_cpuerr_intr (unsigned int irq, void *dev_id, struct pt_regs *regs)
  33. {
  34. u64 cpuerr = crime_read_64 (CRIME_CPU_ERROR_STAT);
  35. u64 addr = crime_read_64 (CRIME_CPU_ERROR_ADDR);
  36. cpuerr &= CRIME_CPU_ERROR_MASK;
  37. addr <<= 2UL;
  38. printk ("CRIME CPU interface error detected at %09lx status %08lxn",
  39. addr, cpuerr);
  40. crime_write_64 (CRIME_CPU_ERROR_STAT, 0);
  41. }