| 
									
										
										
										
											2009-08-13 11:59:32 +08:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2011-06-15 15:29:23 -04:00
										 |  |  |  * Audio Codec driver supporting: | 
					
						
							|  |  |  |  *  AD1835A, AD1836, AD1837A, AD1838A, AD1839A | 
					
						
							| 
									
										
										
										
											2009-08-13 11:59:32 +08:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2011-06-15 15:29:23 -04:00
										 |  |  |  * Copyright 2009-2011 Analog Devices Inc. | 
					
						
							| 
									
										
										
										
											2009-08-13 11:59:32 +08:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2011-06-15 15:29:23 -04:00
										 |  |  |  * Licensed under the GPL-2 or later. | 
					
						
							| 
									
										
										
										
											2009-08-13 11:59:32 +08:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef __AD1836_H__
 | 
					
						
							|  |  |  | #define __AD1836_H__
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define AD1836_DAC_CTRL1               0
 | 
					
						
							|  |  |  | #define AD1836_DAC_POWERDOWN           2
 | 
					
						
							| 
									
										
										
										
											2011-06-15 15:29:20 -04:00
										 |  |  | #define AD1836_DAC_SERFMT_MASK         0xE0
 | 
					
						
							| 
									
										
										
										
											2009-08-13 11:59:32 +08:00
										 |  |  | #define AD1836_DAC_SERFMT_PCK256       (0x4 << 5)
 | 
					
						
							|  |  |  | #define AD1836_DAC_SERFMT_PCK128       (0x5 << 5)
 | 
					
						
							|  |  |  | #define AD1836_DAC_WORD_LEN_MASK       0x18
 | 
					
						
							| 
									
										
										
										
											2011-06-06 13:38:35 +02:00
										 |  |  | #define AD1836_DAC_WORD_LEN_OFFSET     3
 | 
					
						
							| 
									
										
										
										
											2009-08-13 11:59:32 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define AD1836_DAC_CTRL2               1
 | 
					
						
							| 
									
										
										
										
											2011-06-06 13:38:36 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* These macros are one-based. So AD183X_MUTE_LEFT(1) will return the mute bit
 | 
					
						
							|  |  |  |  * for the first ADC/DAC */ | 
					
						
							|  |  |  | #define AD1836_MUTE_LEFT(x) (((x) * 2) - 2)
 | 
					
						
							|  |  |  | #define AD1836_MUTE_RIGHT(x) (((x) * 2) - 1)
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define AD1836_DAC_L_VOL(x) ((x) * 2)
 | 
					
						
							|  |  |  | #define AD1836_DAC_R_VOL(x) (1 + ((x) * 2))
 | 
					
						
							| 
									
										
										
										
											2009-08-13 11:59:32 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define AD1836_ADC_CTRL1               12
 | 
					
						
							|  |  |  | #define AD1836_ADC_POWERDOWN           7
 | 
					
						
							|  |  |  | #define AD1836_ADC_HIGHPASS_FILTER     8
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define AD1836_ADC_CTRL2               13
 | 
					
						
							|  |  |  | #define AD1836_ADC_WORD_LEN_MASK       0x30
 | 
					
						
							| 
									
										
										
										
											2011-11-22 09:46:51 +08:00
										 |  |  | #define AD1836_ADC_WORD_OFFSET         4
 | 
					
						
							| 
									
										
										
										
											2011-06-15 15:29:20 -04:00
										 |  |  | #define AD1836_ADC_SERFMT_MASK         (7 << 6)
 | 
					
						
							| 
									
										
										
										
											2009-08-13 11:59:32 +08:00
										 |  |  | #define AD1836_ADC_SERFMT_PCK256       (0x4 << 6)
 | 
					
						
							|  |  |  | #define AD1836_ADC_SERFMT_PCK128       (0x5 << 6)
 | 
					
						
							| 
									
										
										
										
											2010-01-25 16:42:25 +08:00
										 |  |  | #define AD1836_ADC_AUX                 (0x6 << 6)
 | 
					
						
							| 
									
										
										
										
											2009-08-13 11:59:32 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define AD1836_ADC_CTRL3               14
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define AD1836_NUM_REGS                16
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2011-06-06 13:38:35 +02:00
										 |  |  | #define AD1836_WORD_LEN_24 0x0
 | 
					
						
							|  |  |  | #define AD1836_WORD_LEN_20 0x1
 | 
					
						
							|  |  |  | #define AD1836_WORD_LEN_16 0x2
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-13 11:59:32 +08:00
										 |  |  | #endif
 |