Home | History | Annotate | Line # | Download | only in ic
      1  1.1  nisimura /*-
      2  1.1  nisimura  * Copyright (c) 2012 The NetBSD Foundation, Inc.
      3  1.1  nisimura  * All rights reserved.
      4  1.1  nisimura  *
      5  1.1  nisimura  * This code is derived from software contributed to The NetBSD Foundation
      6  1.1  nisimura  * by Paul Fleischer <paul (at) xpg.dk>
      7  1.1  nisimura  *
      8  1.1  nisimura  * Redistribution and use in source and binary forms, with or without
      9  1.1  nisimura  * modification, are permitted provided that the following conditions
     10  1.1  nisimura  * are met:
     11  1.1  nisimura  * 1. Redistributions of source code must retain the above copyright
     12  1.1  nisimura  *    notice, this list of conditions and the following disclaimer.
     13  1.1  nisimura  * 2. Redistributions in binary form must reproduce the above copyright
     14  1.1  nisimura  *    notice, this list of conditions and the following disclaimer in the
     15  1.1  nisimura  *    documentation and/or other materials provided with the distribution.
     16  1.1  nisimura  *
     17  1.1  nisimura  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     18  1.1  nisimura  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     19  1.1  nisimura  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     20  1.1  nisimura  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     21  1.1  nisimura  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     22  1.1  nisimura  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     23  1.1  nisimura  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     24  1.1  nisimura  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     25  1.1  nisimura  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     26  1.1  nisimura  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     27  1.1  nisimura  * POSSIBILITY OF SUCH DAMAGE.
     28  1.1  nisimura  */
     29  1.1  nisimura #ifndef _DEV_IC_UDA1341REG_H_
     30  1.1  nisimura #define _DEV_IC_UDA1341REG_H_
     31  1.1  nisimura 
     32  1.1  nisimura #define UDA1341_L3_ADDR_DEVICE	0x14 /* Address of the UDA1341 on the L3 bus */
     33  1.1  nisimura #define UDA1341_L3_ADDR_DATA0	0x00
     34  1.1  nisimura #define UDA1341_L3_ADDR_DATA1	0x01
     35  1.1  nisimura #define UDA1341_L3_ADDR_STATUS	0x02
     36  1.1  nisimura 
     37  1.1  nisimura /* Status address has two "banks", 0 and 1.
     38  1.1  nisimura    The bank is selected as bit 7 of the data written.
     39  1.1  nisimura  */
     40  1.1  nisimura #define UDA1341_L3_STATUS0	(0<<7)
     41  1.1  nisimura #define UDA1341_L3_STATUS1	(1<<7)
     42  1.1  nisimura 
     43  1.1  nisimura /** Status bank 0 **/
     44  1.1  nisimura #define UDA1341_L3_STATUS0_RST		(1<<6)
     45  1.1  nisimura 
     46  1.1  nisimura /* System clock selection (bit 4 and 5) */
     47  1.1  nisimura #define UDA1341_L3_STATUS0_SC_512	(0<<4)
     48  1.1  nisimura #define	UDA1341_L3_STATUS0_SC_384	(1<<4)
     49  1.1  nisimura #define	UDA1341_L3_STATUS0_SC_256	(2<<4)
     50  1.1  nisimura #define UDA1341_L3_STATUS0_SC_NA	(3<<4)
     51  1.1  nisimura #define UDA1341_L3_STATUS0_SC_SHIFT	4
     52  1.1  nisimura 
     53  1.1  nisimura /* Interface format (bit 1, 2, 3)*/
     54  1.1  nisimura #define UDA1341_L3_STATUS0_IF_I2S	(0<<1)
     55  1.1  nisimura #define UDA1341_L3_STATUS0_IF_LSB16	(1<<1)
     56  1.1  nisimura #define UDA1341_L3_STATUS0_IF_LSB18	(2<<1)
     57  1.1  nisimura #define UDA1341_L3_STATUS0_IF_LSB20	(3<<1)
     58  1.1  nisimura #define UDA1341_L3_STATUS0_IF_MSB	(4<<1)
     59  1.1  nisimura #define UDA1341_L3_STATUS0_IF_LSB16_MSB	(5<<1)
     60  1.1  nisimura #define UDA1341_L3_STATUS0_IF_LSB18_MSB	(6<<1)
     61  1.1  nisimura #define UDA1341_L3_STATUS0_IF_LSB20_MSB (7<<1)
     62  1.1  nisimura #define UDA1341_L3_STATUS0_IF_SHIFT	1
     63  1.1  nisimura 
     64  1.1  nisimura /* DC-Filtering */
     65  1.1  nisimura #define UDA1341_L3_STATUS0_DC_FILTERING (1<<0)
     66  1.1  nisimura 
     67  1.1  nisimura /** Status bank 1**/
     68  1.1  nisimura 
     69  1.1  nisimura /* Output and Input Gain*/
     70  1.1  nisimura #define UDA1341_L3_STATUS1_OGS_6DB	(1<<6)
     71  1.1  nisimura #define UDA1341_L3_STATUS1_IGS_6DB	(1<<5)
     72  1.1  nisimura 
     73  1.1  nisimura /* DAC and ADC polarity inversion */
     74  1.1  nisimura #define UDA1341_L3_STATUS1_PAD_INV	(1<<4)
     75  1.1  nisimura #define UDA1341_L3_STATUS1_PDA_INV	(1<<3)
     76  1.1  nisimura 
     77  1.1  nisimura /* Double speed playback */
     78  1.1  nisimura #define UDA1341_L3_STATUS1_DS		(1<<2)
     79  1.1  nisimura 
     80  1.1  nisimura /* Power Control */
     81  1.1  nisimura #define UDA1341_L3_STATUS1_PC_ADC	(1<<1)
     82  1.1  nisimura #define UDA1341_L3_STATUS1_PC_DAC	(1<<0)
     83  1.1  nisimura 
     84  1.1  nisimura /*** DATA0 ***/
     85  1.1  nisimura /*
     86  1.1  nisimura  * Data0 has five banks: three for direct control, and two for extended access.
     87  1.1  nisimura  */
     88  1.1  nisimura #define UDA1341_L3_DATA0_VOLUME		(0<<6)
     89  1.1  nisimura #define UDA1341_L3_DATA0_VOLUME_MASK	(0x3F)
     90  1.1  nisimura 
     91  1.1  nisimura #define UDA1341_L3_DATA0_BASS_TREBLE	(1<<6)
     92  1.1  nisimura #define UDA1341_L3_DATA0_BASS_SHIFT	2
     93  1.1  nisimura #define UDA1341_L3_DATA0_BASS_MASK	0x3C
     94  1.1  nisimura #define UDA1341_L3_DATA0_TREBLE_SHIFT	0
     95  1.1  nisimura #define UDA1341_L3_DATA0_TREBLE_MASK	0x03
     96  1.1  nisimura 
     97  1.1  nisimura #define UDA1341_L3_DATA0_SOUNDC		(2<<6)
     98  1.1  nisimura #define UDA1341_L3_DATA0_SOUNDC_DE_MASK (0x18)
     99  1.1  nisimura #define UDA1341_L3_DATA0_SOUNDC_DE_SHIFT 3
    100  1.1  nisimura #define UDA1341_L3_DATA0_SOUNDC_MUTE	(1<<2)
    101  1.1  nisimura #define UDA1341_L3_DATA0_SOUNDC_MODE_MASK (0x03)
    102  1.1  nisimura 
    103  1.1  nisimura #define UDA1341_L3_DATA0_EA		((3<<6)|0<<5)
    104  1.1  nisimura #define UDA1341_L3_DATA0_ED		((3<<6)|1<<5)
    105  1.1  nisimura 
    106  1.1  nisimura #define UDA1341_L3_DATA0_MA_MASK	(0x1F)
    107  1.1  nisimura #define UDA1341_L3_DATA0_MB_MASK	(0x1F)
    108  1.1  nisimura 
    109  1.1  nisimura #define UDA1341_L3_DATA0_MS_MASK	(0x1C)
    110  1.1  nisimura #define UDA1341_L3_DATA0_MS_SHIFT	2
    111  1.1  nisimura 
    112  1.1  nisimura #define UDA1341_L3_DATA0_MM_MASK	(0x03)
    113  1.1  nisimura 
    114  1.1  nisimura #define UDA1341_L3_DATA0_AGC_SHIFT	4
    115  1.1  nisimura #define UDA1341_L3_DATA0_AGC_MASK	(0x10)
    116  1.1  nisimura 
    117  1.1  nisimura #define UDA1341_L3_DATA0_IG_LOW_MASK	(0x03)
    118  1.1  nisimura #define UDA1341_L3_DATA0_IG_HIGH_MASK	(0x1F)
    119  1.1  nisimura 
    120  1.1  nisimura #define UDA1341_L3_DATA0_AL_MASK	(0x03)
    121  1.1  nisimura #endif
    122