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