ocd.h 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. /*
  2. * AVR32 OCD Registers
  3. *
  4. * Copyright (C) 2004-2006 Atmel Corporation
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License version 2 as
  8. * published by the Free Software Foundation.
  9. */
  10. #ifndef __ASM_AVR32_OCD_H
  11. #define __ASM_AVR32_OCD_H
  12. /* Debug Registers */
  13. #define DBGREG_DID 0
  14. #define DBGREG_DC 8
  15. #define DBGREG_DS 16
  16. #define DBGREG_RWCS 28
  17. #define DBGREG_RWA 36
  18. #define DBGREG_RWD 40
  19. #define DBGREG_WT 44
  20. #define DBGREG_DTC 52
  21. #define DBGREG_DTSA0 56
  22. #define DBGREG_DTSA1 60
  23. #define DBGREG_DTEA0 72
  24. #define DBGREG_DTEA1 76
  25. #define DBGREG_BWC0A 88
  26. #define DBGREG_BWC0B 92
  27. #define DBGREG_BWC1A 96
  28. #define DBGREG_BWC1B 100
  29. #define DBGREG_BWC2A 104
  30. #define DBGREG_BWC2B 108
  31. #define DBGREG_BWC3A 112
  32. #define DBGREG_BWC3B 116
  33. #define DBGREG_BWA0A 120
  34. #define DBGREG_BWA0B 124
  35. #define DBGREG_BWA1A 128
  36. #define DBGREG_BWA1B 132
  37. #define DBGREG_BWA2A 136
  38. #define DBGREG_BWA2B 140
  39. #define DBGREG_BWA3A 144
  40. #define DBGREG_BWA3B 148
  41. #define DBGREG_BWD3A 153
  42. #define DBGREG_BWD3B 156
  43. #define DBGREG_PID 284
  44. #define SABAH_OCD 0x01
  45. #define SABAH_ICACHE 0x02
  46. #define SABAH_MEM_CACHED 0x04
  47. #define SABAH_MEM_UNCACHED 0x05
  48. /* Fields in the Development Control register */
  49. #define DC_SS_BIT 8
  50. #define DC_SS (1 << DC_SS_BIT)
  51. #define DC_DBE (1 << 13)
  52. #define DC_RID (1 << 27)
  53. #define DC_ORP (1 << 28)
  54. #define DC_MM (1 << 29)
  55. #define DC_RES (1 << 30)
  56. /* Fields in the Development Status register */
  57. #define DS_SSS (1 << 0)
  58. #define DS_SWB (1 << 1)
  59. #define DS_HWB (1 << 2)
  60. #define DS_BP_SHIFT 8
  61. #define DS_BP_MASK (0xff << DS_BP_SHIFT)
  62. #define __mfdr(addr) \
  63. ({ \
  64. register unsigned long value; \
  65. asm volatile("mfdr %0, %1" : "=r"(value) : "i"(addr)); \
  66. value; \
  67. })
  68. #define __mtdr(addr, value) \
  69. asm volatile("mtdr %0, %1" : : "i"(addr), "r"(value))
  70. #endif /* __ASM_AVR32_OCD_H */