asp.h 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677
  1. /*
  2. * <mach/asp.h> - DaVinci Audio Serial Port support
  3. */
  4. #ifndef __ASM_ARCH_DAVINCI_ASP_H
  5. #define __ASM_ARCH_DAVINCI_ASP_H
  6. #include <mach/irqs.h>
  7. #include <mach/edma.h>
  8. /* Bases of dm644x and dm355 register banks */
  9. #define DAVINCI_ASP0_BASE 0x01E02000
  10. #define DAVINCI_ASP1_BASE 0x01E04000
  11. /* Bases of dm646x register banks */
  12. #define DAVINCI_DM646X_MCASP0_REG_BASE 0x01D01000
  13. #define DAVINCI_DM646X_MCASP1_REG_BASE 0x01D01800
  14. /* Bases of da850/da830 McASP0 register banks */
  15. #define DAVINCI_DA8XX_MCASP0_REG_BASE 0x01D00000
  16. /* Bases of da830 McASP1 register banks */
  17. #define DAVINCI_DA830_MCASP1_REG_BASE 0x01D04000
  18. /* EDMA channels of dm644x and dm355 */
  19. #define DAVINCI_DMA_ASP0_TX 2
  20. #define DAVINCI_DMA_ASP0_RX 3
  21. #define DAVINCI_DMA_ASP1_TX 8
  22. #define DAVINCI_DMA_ASP1_RX 9
  23. /* EDMA channels of dm646x */
  24. #define DAVINCI_DM646X_DMA_MCASP0_AXEVT0 6
  25. #define DAVINCI_DM646X_DMA_MCASP0_AREVT0 9
  26. #define DAVINCI_DM646X_DMA_MCASP1_AXEVT1 12
  27. /* EDMA channels of da850/da830 McASP0 */
  28. #define DAVINCI_DA8XX_DMA_MCASP0_AREVT 0
  29. #define DAVINCI_DA8XX_DMA_MCASP0_AXEVT 1
  30. /* EDMA channels of da830 McASP1 */
  31. #define DAVINCI_DA830_DMA_MCASP1_AREVT 2
  32. #define DAVINCI_DA830_DMA_MCASP1_AXEVT 3
  33. /* Interrupts */
  34. #define DAVINCI_ASP0_RX_INT IRQ_MBRINT
  35. #define DAVINCI_ASP0_TX_INT IRQ_MBXINT
  36. #define DAVINCI_ASP1_RX_INT IRQ_MBRINT
  37. #define DAVINCI_ASP1_TX_INT IRQ_MBXINT
  38. struct snd_platform_data {
  39. u32 tx_dma_offset;
  40. u32 rx_dma_offset;
  41. enum dma_event_q eventq_no; /* event queue number */
  42. unsigned int codec_fmt;
  43. /* McASP specific fields */
  44. int tdm_slots;
  45. u8 op_mode;
  46. u8 num_serializer;
  47. u8 *serial_dir;
  48. u8 version;
  49. u8 txnumevt;
  50. u8 rxnumevt;
  51. };
  52. enum {
  53. MCASP_VERSION_1 = 0, /* DM646x */
  54. MCASP_VERSION_2, /* DA8xx/OMAPL1x */
  55. };
  56. #define INACTIVE_MODE 0
  57. #define TX_MODE 1
  58. #define RX_MODE 2
  59. #define DAVINCI_MCASP_IIS_MODE 0
  60. #define DAVINCI_MCASP_DIT_MODE 1
  61. #endif /* __ASM_ARCH_DAVINCI_ASP_H */