2010-05-18 09:41:46 +04:00
/*
* Copyright ( c ) 2010 Nuvoton technology corporation .
*
* Wan ZongShun < mcuos . com @ gmail . com >
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; version 2 of the License .
*
*/
# ifndef _NUC900_AUDIO_H
# define _NUC900_AUDIO_H
# include <linux/io.h>
/* Audio Control Registers */
# define ACTL_CON 0x00
# define ACTL_RESET 0x04
# define ACTL_RDSTB 0x08
# define ACTL_RDST_LENGTH 0x0C
# define ACTL_RDSTC 0x10
# define ACTL_RSR 0x14
# define ACTL_PDSTB 0x18
# define ACTL_PDST_LENGTH 0x1C
# define ACTL_PDSTC 0x20
# define ACTL_PSR 0x24
# define ACTL_IISCON 0x28
# define ACTL_ACCON 0x2C
# define ACTL_ACOS0 0x30
# define ACTL_ACOS1 0x34
# define ACTL_ACOS2 0x38
# define ACTL_ACIS0 0x3C
# define ACTL_ACIS1 0x40
# define ACTL_ACIS2 0x44
# define ACTL_COUNTER 0x48
/* bit definition of REG_ACTL_CON register */
# define R_DMA_IRQ 0x1000
# define T_DMA_IRQ 0x0800
# define IIS_AC_PIN_SEL 0x0100
# define FIFO_TH 0x0080
# define ADC_EN 0x0010
# define M80_EN 0x0008
# define ACLINK_EN 0x0004
# define IIS_EN 0x0002
/* bit definition of REG_ACTL_RESET register */
# define W5691_PLAY 0x20000
# define ACTL_RESET_BIT 0x10000
# define RECORD_RIGHT_CHNNEL 0x08000
# define RECORD_LEFT_CHNNEL 0x04000
# define PLAY_RIGHT_CHNNEL 0x02000
# define PLAY_LEFT_CHNNEL 0x01000
# define DAC_PLAY 0x00800
# define ADC_RECORD 0x00400
# define M80_PLAY 0x00200
# define AC_RECORD 0x00100
# define AC_PLAY 0x00080
# define IIS_RECORD 0x00040
# define IIS_PLAY 0x00020
# define DAC_RESET 0x00010
# define ADC_RESET 0x00008
# define M80_RESET 0x00004
# define AC_RESET 0x00002
# define IIS_RESET 0x00001
/* bit definition of REG_ACTL_ACCON register */
# define AC_BCLK_PU_EN 0x20
# define AC_R_FINISH 0x10
# define AC_W_FINISH 0x08
# define AC_W_RES 0x04
# define AC_C_RES 0x02
/* bit definition of ACTL_RSR register */
# define R_FIFO_EMPTY 0x04
# define R_DMA_END_IRQ 0x02
# define R_DMA_MIDDLE_IRQ 0x01
/* bit definition of ACTL_PSR register */
# define P_FIFO_EMPTY 0x04
# define P_DMA_END_IRQ 0x02
# define P_DMA_MIDDLE_IRQ 0x01
/* bit definition of ACTL_ACOS0 register */
# define SLOT1_VALID 0x01
# define SLOT2_VALID 0x02
# define SLOT3_VALID 0x04
# define SLOT4_VALID 0x08
# define VALID_FRAME 0x10
/* bit definition of ACTL_ACOS1 register */
# define R_WB 0x80
# define CODEC_READY 0x10
# define RESET_PRSR 0x00
# define AUDIO_WRITE(addr, val) __raw_writel(val, addr)
# define AUDIO_READ(addr) __raw_readl(addr)
struct nuc900_audio {
void __iomem * mmio ;
spinlock_t lock ;
dma_addr_t dma_addr [ 2 ] ;
unsigned long buffersize [ 2 ] ;
unsigned long irq_num ;
struct snd_pcm_substream * substream ;
struct resource * res ;
struct clk * clk ;
struct device * dev ;
} ;
2010-11-29 12:40:53 +03:00
extern struct nuc900_audio * nuc900_ac97_data ;
2010-05-18 09:41:46 +04:00
# endif /*end _NUC900_AUDIO_H */