405_mal.h 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. /* include/mal.h, openbios_walnut, walnut_bios 8/6/99 08:48:40 */
  2. /*----------------------------------------------------------------------------+
  3. |
  4. | This source code has been made available to you by IBM on an AS-IS
  5. | basis. Anyone receiving this source is licensed under IBM
  6. | copyrights to use it in any way he or she deems fit, including
  7. | copying it, modifying it, compiling it, and redistributing it either
  8. | with or without modifications. No license under IBM patents or
  9. | patent applications is to be implied by the copyright license.
  10. |
  11. | Any user of this software should understand that IBM cannot provide
  12. | technical support for this software and will not be responsible for
  13. | any consequences resulting from the use of this software.
  14. |
  15. | Any person who transfers this source code or any derivative work
  16. | must include the IBM copyright notice, this paragraph, and the
  17. | preceding two paragraphs in the transferred software.
  18. |
  19. | COPYRIGHT I B M CORPORATION 1999
  20. | LICENSED MATERIAL - PROGRAM PROPERTY OF I B M
  21. +----------------------------------------------------------------------------*/
  22. /*----------------------------------------------------------------------------+
  23. |
  24. | File Name: mal.h
  25. |
  26. | Function: Header file for the MAL (MADMAL) macro on the 405GP.
  27. |
  28. | Author: Mark Wisner
  29. |
  30. | Change Activity-
  31. |
  32. | Date Description of Change BY
  33. | --------- --------------------- ---
  34. | 29-Apr-99 Created MKW
  35. |
  36. +----------------------------------------------------------------------------*/
  37. /*----------------------------------------------------------------------------+
  38. | 17-Nov-03 Travis B. Sawyer, Sandburst Corporation, tsawyer@sandburst.com
  39. | Added register bit definitions to support multiple channels
  40. +----------------------------------------------------------------------------*/
  41. #ifndef _mal_h_
  42. #define _mal_h_
  43. /* MADMAL transmit and receive status/control bits */
  44. /* for COMMAC bits, refer to the COMMAC header file */
  45. #define MAL_TX_CTRL_READY 0x8000
  46. #define MAL_TX_CTRL_WRAP 0x4000
  47. #define MAL_TX_CTRL_CM 0x2000
  48. #define MAL_TX_CTRL_LAST 0x1000
  49. #define MAL_TX_CTRL_INTR 0x0400
  50. #define MAL_RX_CTRL_EMPTY 0x8000
  51. #define MAL_RX_CTRL_WRAP 0x4000
  52. #define MAL_RX_CTRL_CM 0x2000
  53. #define MAL_RX_CTRL_LAST 0x1000
  54. #define MAL_RX_CTRL_FIRST 0x0800
  55. #define MAL_RX_CTRL_INTR 0x0400
  56. /* Configuration Reg */
  57. #define MAL_CR_MMSR 0x80000000
  58. #define MAL_CR_PLBP_1 0x00400000 /* lowsest is 00 */
  59. #define MAL_CR_PLBP_2 0x00800000
  60. #define MAL_CR_PLBP_3 0x00C00000 /* highest */
  61. #define MAL_CR_GA 0x00200000
  62. #define MAL_CR_OA 0x00100000
  63. #define MAL_CR_PLBLE 0x00080000
  64. #define MAL_CR_PLBLT_1 0x00040000
  65. #define MAL_CR_PLBLT_2 0x00020000
  66. #define MAL_CR_PLBLT_3 0x00010000
  67. #define MAL_CR_PLBLT_4 0x00008000
  68. #define MAL_CR_PLBLT_DEFAULT 0x00078000 /* ????? */
  69. #define MAL_CR_PLBB 0x00004000
  70. #define MAL_CR_OPBBL 0x00000080
  71. #define MAL_CR_EOPIE 0x00000004
  72. #define MAL_CR_LEA 0x00000002
  73. #define MAL_CR_MSD 0x00000001
  74. /* Error Status Reg */
  75. #define MAL_ESR_EVB 0x80000000
  76. #define MAL_ESR_CID 0x40000000
  77. #define MAL_ESR_DE 0x00100000
  78. #define MAL_ESR_ONE 0x00080000
  79. #define MAL_ESR_OTE 0x00040000
  80. #define MAL_ESR_OSE 0x00020000
  81. #define MAL_ESR_PEIN 0x00010000
  82. /* same bit position as the IER */
  83. /* VV VV */
  84. #define MAL_ESR_DEI 0x00000010
  85. #define MAL_ESR_ONEI 0x00000008
  86. #define MAL_ESR_OTEI 0x00000004
  87. #define MAL_ESR_OSEI 0x00000002
  88. #define MAL_ESR_PBEI 0x00000001
  89. /* ^^ ^^ */
  90. /* Mal IER */
  91. #if defined(CONFIG_440SPE) || \
  92. defined(CONFIG_440EPX) || defined(CONFIG_440GRX) || \
  93. defined(CONFIG_405EX)
  94. #define MAL_IER_PT 0x00000080
  95. #define MAL_IER_PRE 0x00000040
  96. #define MAL_IER_PWE 0x00000020
  97. #define MAL_IER_DE 0x00000010
  98. #define MAL_IER_OTE 0x00000004
  99. #define MAL_IER_OE 0x00000002
  100. #define MAL_IER_PE 0x00000001
  101. #else
  102. #define MAL_IER_DE 0x00000010
  103. #define MAL_IER_NE 0x00000008
  104. #define MAL_IER_TE 0x00000004
  105. #define MAL_IER_OPBE 0x00000002
  106. #define MAL_IER_PLBE 0x00000001
  107. #endif
  108. /* MAL Channel Active Set and Reset Registers */
  109. #define MAL_TXRX_CASR (0x80000000)
  110. #define MAL_TXRX_CASR_V(__x) (__x) /* Channel 0 shifts 0, channel 1 shifts 1, etc */
  111. /* MAL Buffer Descriptor structure */
  112. typedef struct {
  113. short ctrl; /* MAL / Commac status control bits */
  114. short data_len; /* Max length is 4K-1 (12 bits) */
  115. char *data_ptr; /* pointer to actual data buffer */
  116. } mal_desc_t;
  117. #endif