amd7930.h
上传用户:jlfgdled
上传日期:2013-04-10
资源大小:33168k
文件大小:8k
源码类别:

Linux/Unix编程

开发平台:

Unix_Linux

  1. /* $Id: amd7930.h,v 1.8 1999/09/21 14:37:10 davem Exp $
  2.  * drivers/sbus/audio/amd7930.h
  3.  *
  4.  * Copyright (C) 1996 Thomas K. Dyas (tdyas@noc.rutgers.edu)
  5.  *
  6.  * Definitions for the AMD79C30 Digital Subscriber Controller which is
  7.  * used as an audio chip in sun4c architecture machines. The
  8.  * information in this file is based on Advanced Micro Devices
  9.  * Publication 09893, Rev G, Amendment /0, Final (a.k.a. the data
  10.  * sheet).
  11.  */
  12. #ifndef _AMD7930_H_
  13. #define _AMD7930_H_
  14. #include <linux/types.h>
  15. #include <linux/version.h>
  16. /* Register interface presented to the CPU by the amd7930. */
  17. #define CR 0x00UL /* Command Register (W) */
  18. #define IR CR /* Interrupt Register (R) */
  19. #define DR 0x01UL /* Data Register (R/W) */
  20. #define DSR1 0x02UL /* D-channel Status Register 1 (R) */
  21. #define DER 0x03UL /* D-channel Error Register (R) */
  22. #define DCTB 0x04UL /* D-channel Transmit Buffer (W) */
  23. #define DCRB DCTB /* D-channel Receive Buffer (R) */
  24. #define BBTB 0x05UL /* Bb-channel Transmit Buffer (W) */
  25. #define BBRB BBTB /* Bb-channel Receive Buffer (R) */
  26. #define BCTB 0x06UL /* Bc-channel Transmit Buffer (W) */
  27. #define BCRB BCTB /* Bc-channel Receive Buffer (R) */
  28. #define DSR2 0x07UL /* D-channel Status Register 2 (R) */
  29. /* Indirect registers in the Main Audio Processor. */
  30. struct amd7930_map {
  31. __u16 x[8];
  32. __u16 r[8];
  33. __u16 gx;
  34. __u16 gr;
  35. __u16 ger;
  36. __u16 stgr;
  37. __u16 ftgr;
  38. __u16 atgr;
  39. __u8 mmr1;
  40. __u8 mmr2;
  41. };
  42. /* After an amd7930 interrupt, reading the Interrupt Register (ir)
  43.  * clears the interrupt and returns a bitmask indicated which
  44.  * interrupt source(s) require service
  45.  */
  46. #define AMR_IR_DTTHRSH 0x01 /* D-channel xmit threshold */
  47. #define AMR_IR_DRTHRSH 0x02 /* D-channel recv threshold */
  48. #define AMR_IR_DSRI 0x04 /* D-channel packet status */
  49. #define AMR_IR_DERI 0x08 /* D-channel error */
  50. #define AMR_IR_BBUF 0x10 /* B-channel data xfer */
  51. #define AMR_IR_LSRI 0x20 /* LIU status */
  52. #define AMR_IR_DSR2I 0x40 /* D-channel buffer status */
  53. #define AMR_IR_MLTFRMI 0x80 /* multiframe or PP */
  54. /* The amd7930 has "indirect registers" which are accessed by writing
  55.  * the register number into the Command Register and then reading or
  56.  * writing values from the Data Register as appropriate. We define the
  57.  * AMR_* macros to be the indirect register numbers and AM_* macros to
  58.  * be bits in whatever register is referred to.
  59.  */
  60. /* Initialization */
  61. #define AMR_INIT 0x21
  62. #define AM_INIT_ACTIVE 0x01
  63. #define AM_INIT_DATAONLY 0x02
  64. #define AM_INIT_POWERDOWN 0x03
  65. #define AM_INIT_DISABLE_INTS 0x04
  66. #define AMR_INIT2 0x20
  67. #define AM_INIT2_ENABLE_POWERDOWN 0x20
  68. #define AM_INIT2_ENABLE_MULTIFRAME 0x10
  69. /* Line Interface Unit */
  70. #define AMR_LIU_LSR 0xA1
  71. #define AM_LIU_LSR_STATE 0x07
  72. #define AM_LIU_LSR_F3 0x08
  73. #define AM_LIU_LSR_F7 0x10
  74. #define AM_LIU_LSR_F8 0x20
  75. #define AM_LIU_LSR_HSW 0x40
  76. #define AM_LIU_LSR_HSW_CHG 0x80
  77. #define AMR_LIU_LPR 0xA2
  78. #define AMR_LIU_LMR1 0xA3
  79. #define AM_LIU_LMR1_B1_ENABL 0x01
  80. #define AM_LIU_LMR1_B2_ENABL 0x02
  81. #define AM_LIU_LMR1_F_DISABL 0x04
  82. #define AM_LIU_LMR1_FA_DISABL 0x08
  83. #define AM_LIU_LMR1_REQ_ACTIV 0x10
  84. #define AM_LIU_LMR1_F8_F3 0x20
  85. #define AM_LIU_LMR1_LIU_ENABL 0x40
  86. #define AMR_LIU_LMR2 0xA4
  87. #define AM_LIU_LMR2_DECHO 0x01
  88. #define AM_LIU_LMR2_DLOOP 0x02
  89. #define AM_LIU_LMR2_DBACKOFF 0x04
  90. #define AM_LIU_LMR2_EN_F3_INT 0x08
  91. #define AM_LIU_LMR2_EN_F8_INT 0x10
  92. #define AM_LIU_LMR2_EN_HSW_INT 0x20
  93. #define AM_LIU_LMR2_EN_F7_INT 0x40
  94. #define AMR_LIU_2_4 0xA5
  95. #define AMR_LIU_MF 0xA6
  96. #define AMR_LIU_MFSB 0xA7
  97. #define AMR_LIU_MFQB 0xA8
  98. /* Multiplexor */
  99. #define AMR_MUX_MCR1 0x41
  100. #define AMR_MUX_MCR2 0x42
  101. #define AMR_MUX_MCR3 0x43
  102. #define AM_MUX_CHANNEL_B1 0x01
  103. #define AM_MUX_CHANNEL_B2 0x02
  104. #define AM_MUX_CHANNEL_Ba 0x03
  105. #define AM_MUX_CHANNEL_Bb 0x04
  106. #define AM_MUX_CHANNEL_Bc 0x05
  107. #define AM_MUX_CHANNEL_Bd 0x06
  108. #define AM_MUX_CHANNEL_Be 0x07
  109. #define AM_MUX_CHANNEL_Bf 0x08
  110. #define AMR_MUX_MCR4 0x44
  111. #define AM_MUX_MCR4_ENABLE_INTS 0x08
  112. #define AM_MUX_MCR4_REVERSE_Bb 0x10
  113. #define AM_MUX_MCR4_REVERSE_Bc 0x20
  114. #define AMR_MUX_1_4 0x45
  115. /* Main Audio Processor */
  116. #define AMR_MAP_X 0x61
  117. #define AMR_MAP_R 0x62
  118. #define AMR_MAP_GX 0x63
  119. #define AMR_MAP_GR 0x64
  120. #define AMR_MAP_GER 0x65
  121. #define AMR_MAP_STGR 0x66
  122. #define AMR_MAP_FTGR_1_2 0x67
  123. #define AMR_MAP_ATGR_1_2 0x68
  124. #define AMR_MAP_MMR1 0x69
  125. #define AM_MAP_MMR1_ALAW 0x01
  126. #define AM_MAP_MMR1_GX 0x02
  127. #define AM_MAP_MMR1_GR 0x04
  128. #define AM_MAP_MMR1_GER 0x08
  129. #define AM_MAP_MMR1_X 0x10
  130. #define AM_MAP_MMR1_R 0x20
  131. #define AM_MAP_MMR1_STG 0x40
  132. #define AM_MAP_MMR1_LOOPBACK 0x80
  133. #define AMR_MAP_MMR2 0x6A
  134. #define AM_MAP_MMR2_AINB 0x01
  135. #define AM_MAP_MMR2_LS 0x02
  136. #define AM_MAP_MMR2_ENABLE_DTMF 0x04
  137. #define AM_MAP_MMR2_ENABLE_TONEGEN 0x08
  138. #define AM_MAP_MMR2_ENABLE_TONERING 0x10
  139. #define AM_MAP_MMR2_DISABLE_HIGHPASS 0x20
  140. #define AM_MAP_MMR2_DISABLE_AUTOZERO 0x40
  141. #define AMR_MAP_1_10 0x6B
  142. #define AMR_MAP_MMR3 0x6C
  143. #define AMR_MAP_STRA 0x6D
  144. #define AMR_MAP_STRF 0x6E
  145. #define AMR_MAP_PEAKX 0x70
  146. #define AMR_MAP_PEAKR 0x71
  147. #define AMR_MAP_15_16 0x72
  148. /* Data Link Controller */
  149. #define AMR_DLC_FRAR_1_2_3 0x81
  150. #define AMR_DLC_SRAR_1_2_3 0x82
  151. #define AMR_DLC_TAR 0x83
  152. #define AMR_DLC_DRLR 0x84
  153. #define AMR_DLC_DTCR 0x85
  154. #define AMR_DLC_DMR1 0x86
  155. #define AMR_DLC_DMR1_DTTHRSH_INT 0x01
  156. #define AMR_DLC_DMR1_DRTHRSH_INT 0x02
  157. #define AMR_DLC_DMR1_TAR_ENABL 0x04
  158. #define AMR_DLC_DMR1_EORP_INT 0x08
  159. #define AMR_DLC_DMR1_EN_ADDR1 0x10
  160. #define AMR_DLC_DMR1_EN_ADDR2 0x20
  161. #define AMR_DLC_DMR1_EN_ADDR3 0x40
  162. #define AMR_DLC_DMR1_EN_ADDR4 0x80
  163. #define AMR_DLC_DMR1_EN_ADDRS 0xf0
  164. #define AMR_DLC_DMR2 0x87
  165. #define AMR_DLC_DMR2_RABRT_INT 0x01
  166. #define AMR_DLC_DMR2_RESID_INT 0x02
  167. #define AMR_DLC_DMR2_COLL_INT 0x04
  168. #define AMR_DLC_DMR2_FCS_INT 0x08
  169. #define AMR_DLC_DMR2_OVFL_INT 0x10
  170. #define AMR_DLC_DMR2_UNFL_INT 0x20
  171. #define AMR_DLC_DMR2_OVRN_INT 0x40
  172. #define AMR_DLC_DMR2_UNRN_INT 0x80
  173. #define AMR_DLC_1_7 0x88
  174. #define AMR_DLC_DRCR 0x89
  175. #define AMR_DLC_RNGR1 0x8A
  176. #define AMR_DLC_RNGR2 0x8B
  177. #define AMR_DLC_FRAR4 0x8C
  178. #define AMR_DLC_SRAR4 0x8D
  179. #define AMR_DLC_DMR3 0x8E
  180. #define AMR_DLC_DMR3_VA_INT 0x01
  181. #define AMR_DLC_DMR3_EOTP_INT 0x02
  182. #define AMR_DLC_DMR3_LBRP_INT 0x04
  183. #define AMR_DLC_DMR3_RBA_INT 0x08
  184. #define AMR_DLC_DMR3_LBT_INT 0x10
  185. #define AMR_DLC_DMR3_TBE_INT 0x20
  186. #define AMR_DLC_DMR3_RPLOST_INT 0x40
  187. #define AMR_DLC_DMR3_KEEP_FCS 0x80
  188. #define AMR_DLC_DMR4 0x8F
  189. #define AMR_DLC_DMR4_RCV_1 0x00
  190. #define AMR_DLC_DMR4_RCV_2 0x01
  191. #define AMR_DLC_DMR4_RCV_4 0x02
  192. #define AMR_DLC_DMR4_RCV_8 0x03
  193. #define AMR_DLC_DMR4_RCV_16 0x01
  194. #define AMR_DLC_DMR4_RCV_24 0x02
  195. #define AMR_DLC_DMR4_RCV_30 0x03
  196. #define AMR_DLC_DMR4_XMT_1 0x00
  197. #define AMR_DLC_DMR4_XMT_2 0x04
  198. #define AMR_DLC_DMR4_XMT_4 0x08
  199. #define AMR_DLC_DMR4_XMT_8 0x0c
  200. #define AMR_DLC_DMR4_XMT_10 0x08
  201. #define AMR_DLC_DMR4_XMT_14 0x0c
  202. #define AMR_DLC_DMR4_IDLE_MARK 0x00
  203. #define AMR_DLC_DMR4_IDLE_FLAG 0x10
  204. #define AMR_DLC_DMR4_ADDR_BOTH 0x00
  205. #define AMR_DLC_DMR4_ADDR_1ST 0x20
  206. #define AMR_DLC_DMR4_ADDR_2ND 0xa0
  207. #define AMR_DLC_DMR4_CR_ENABLE 0x40
  208. #define AMR_DLC_12_15 0x90
  209. #define AMR_DLC_ASR 0x91
  210. #define AMR_DLC_EFCR 0x92
  211. #define AMR_DLC_EFCR_EXTEND_FIFO 0x01
  212. #define AMR_DLC_EFCR_SEC_PKT_INT 0x02
  213. #define AMR_DSR1_VADDR 0x01
  214. #define AMR_DSR1_EORP 0x02
  215. #define AMR_DSR1_PKT_IP 0x04
  216. #define AMR_DSR1_DECHO_ON 0x08
  217. #define AMR_DSR1_DLOOP_ON 0x10
  218. #define AMR_DSR1_DBACK_OFF 0x20
  219. #define AMR_DSR1_EOTP 0x40
  220. #define AMR_DSR1_CXMT_ABRT 0x80
  221. #define AMR_DSR2_LBRP 0x01
  222. #define AMR_DSR2_RBA 0x02
  223. #define AMR_DSR2_RPLOST 0x04
  224. #define AMR_DSR2_LAST_BYTE 0x08
  225. #define AMR_DSR2_TBE 0x10
  226. #define AMR_DSR2_MARK_IDLE 0x20
  227. #define AMR_DSR2_FLAG_IDLE 0x40
  228. #define AMR_DSR2_SECOND_PKT 0x80
  229. #define AMR_DER_RABRT 0x01
  230. #define AMR_DER_RFRAME 0x02
  231. #define AMR_DER_COLLISION 0x04
  232. #define AMR_DER_FCS 0x08
  233. #define AMR_DER_OVFL 0x10
  234. #define AMR_DER_UNFL 0x20
  235. #define AMR_DER_OVRN 0x40
  236. #define AMR_DER_UNRN 0x80
  237. /* Peripheral Port */
  238. #define AMR_PP_PPCR1 0xC0
  239. #define AMR_PP_PPSR 0xC1
  240. #define AMR_PP_PPIER 0xC2
  241. #define AMR_PP_MTDR 0xC3
  242. #define AMR_PP_MRDR 0xC3
  243. #define AMR_PP_CITDR0 0xC4
  244. #define AMR_PP_CIRDR0 0xC4
  245. #define AMR_PP_CITDR1 0xC5
  246. #define AMR_PP_CIRDR1 0xC5
  247. #define AMR_PP_PPCR2 0xC8
  248. #define AMR_PP_PPCR3 0xC9
  249. /* Give this chip a "default" sample rate */
  250. #define AMD7930_RATE                    (8000)
  251. #endif /* _AMD7930_H_ */