asp.h 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  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. /*
  44. * Allowing this is more efficient and eliminates left and right swaps
  45. * caused by underruns, but will swap the left and right channels
  46. * when compared to previous behavior.
  47. */
  48. unsigned enable_channel_combine:1;
  49. unsigned sram_size_playback;
  50. unsigned sram_size_capture;
  51. /* McASP specific fields */
  52. int tdm_slots;
  53. u8 op_mode;
  54. u8 num_serializer;
  55. u8 *serial_dir;
  56. u8 version;
  57. u8 txnumevt;
  58. u8 rxnumevt;
  59. };
  60. enum {
  61. MCASP_VERSION_1 = 0, /* DM646x */
  62. MCASP_VERSION_2, /* DA8xx/OMAPL1x */
  63. };
  64. #define INACTIVE_MODE 0
  65. #define TX_MODE 1
  66. #define RX_MODE 2
  67. #define DAVINCI_MCASP_IIS_MODE 0
  68. #define DAVINCI_MCASP_DIT_MODE 1
  69. #endif /* __ASM_ARCH_DAVINCI_ASP_H */