asp.h 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  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. /* EDMA channels of dm644x and dm355 */
  15. #define DAVINCI_DMA_ASP0_TX 2
  16. #define DAVINCI_DMA_ASP0_RX 3
  17. #define DAVINCI_DMA_ASP1_TX 8
  18. #define DAVINCI_DMA_ASP1_RX 9
  19. /* EDMA channels of dm646x */
  20. #define DAVINCI_DM646X_DMA_MCASP0_AXEVT0 6
  21. #define DAVINCI_DM646X_DMA_MCASP0_AREVT0 9
  22. #define DAVINCI_DM646X_DMA_MCASP1_AXEVT1 12
  23. /* Interrupts */
  24. #define DAVINCI_ASP0_RX_INT IRQ_MBRINT
  25. #define DAVINCI_ASP0_TX_INT IRQ_MBXINT
  26. #define DAVINCI_ASP1_RX_INT IRQ_MBRINT
  27. #define DAVINCI_ASP1_TX_INT IRQ_MBXINT
  28. struct snd_platform_data {
  29. char *clk_name;
  30. u32 tx_dma_offset;
  31. u32 rx_dma_offset;
  32. enum dma_event_q eventq_no; /* event queue number */
  33. unsigned int codec_fmt;
  34. /* McASP specific fields */
  35. int tdm_slots;
  36. u8 op_mode;
  37. u8 num_serializer;
  38. u8 *serial_dir;
  39. };
  40. #define INACTIVE_MODE 0
  41. #define TX_MODE 1
  42. #define RX_MODE 2
  43. #define DAVINCI_MCASP_IIS_MODE 0
  44. #define DAVINCI_MCASP_DIT_MODE 1
  45. #endif /* __ASM_ARCH_DAVINCI_ASP_H */