asp.h 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  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 dm365 register banks */
  12. #define DAVINCI_DM365_ASP0_BASE 0x01D02000
  13. /* Bases of dm646x register banks */
  14. #define DAVINCI_DM646X_MCASP0_REG_BASE 0x01D01000
  15. #define DAVINCI_DM646X_MCASP1_REG_BASE 0x01D01800
  16. /* Bases of da850/da830 McASP0 register banks */
  17. #define DAVINCI_DA8XX_MCASP0_REG_BASE 0x01D00000
  18. /* Bases of da830 McASP1 register banks */
  19. #define DAVINCI_DA830_MCASP1_REG_BASE 0x01D04000
  20. /* EDMA channels of dm644x and dm355 */
  21. #define DAVINCI_DMA_ASP0_TX 2
  22. #define DAVINCI_DMA_ASP0_RX 3
  23. #define DAVINCI_DMA_ASP1_TX 8
  24. #define DAVINCI_DMA_ASP1_RX 9
  25. /* EDMA channels of dm646x */
  26. #define DAVINCI_DM646X_DMA_MCASP0_AXEVT0 6
  27. #define DAVINCI_DM646X_DMA_MCASP0_AREVT0 9
  28. #define DAVINCI_DM646X_DMA_MCASP1_AXEVT1 12
  29. /* EDMA channels of da850/da830 McASP0 */
  30. #define DAVINCI_DA8XX_DMA_MCASP0_AREVT 0
  31. #define DAVINCI_DA8XX_DMA_MCASP0_AXEVT 1
  32. /* EDMA channels of da830 McASP1 */
  33. #define DAVINCI_DA830_DMA_MCASP1_AREVT 2
  34. #define DAVINCI_DA830_DMA_MCASP1_AXEVT 3
  35. /* Interrupts */
  36. #define DAVINCI_ASP0_RX_INT IRQ_MBRINT
  37. #define DAVINCI_ASP0_TX_INT IRQ_MBXINT
  38. #define DAVINCI_ASP1_RX_INT IRQ_MBRINT
  39. #define DAVINCI_ASP1_TX_INT IRQ_MBXINT
  40. struct snd_platform_data {
  41. u32 tx_dma_offset;
  42. u32 rx_dma_offset;
  43. enum dma_event_q eventq_no; /* event queue number */
  44. unsigned int codec_fmt;
  45. /*
  46. * Allowing this is more efficient and eliminates left and right swaps
  47. * caused by underruns, but will swap the left and right channels
  48. * when compared to previous behavior.
  49. */
  50. unsigned enable_channel_combine:1;
  51. unsigned sram_size_playback;
  52. unsigned sram_size_capture;
  53. /* McASP specific fields */
  54. int tdm_slots;
  55. u8 op_mode;
  56. u8 num_serializer;
  57. u8 *serial_dir;
  58. u8 version;
  59. u8 txnumevt;
  60. u8 rxnumevt;
  61. };
  62. enum {
  63. MCASP_VERSION_1 = 0, /* DM646x */
  64. MCASP_VERSION_2, /* DA8xx/OMAPL1x */
  65. };
  66. #define INACTIVE_MODE 0
  67. #define TX_MODE 1
  68. #define RX_MODE 2
  69. #define DAVINCI_MCASP_IIS_MODE 0
  70. #define DAVINCI_MCASP_DIT_MODE 1
  71. #endif /* __ASM_ARCH_DAVINCI_ASP_H */