Home | History | Annotate | Line # | Download | only in ic
cs4231reg.h revision 1.3
      1  1.3     jtc /* $NetBSD: cs4231reg.h,v 1.3 1996/02/05 02:18:48 jtc Exp $ */
      2  1.2     jtc 
      3  1.2     jtc /*-
      4  1.2     jtc  * Copyright (c) 1996 The NetBSD Foundation, Inc.
      5  1.2     jtc  * All rights reserved.
      6  1.1  brezak  *
      7  1.2     jtc  * This code is derived from software contributed to The NetBSD Foundation
      8  1.2     jtc  * by Ken Hornstein and John Kohl.
      9  1.1  brezak  *
     10  1.2     jtc  * Redistribution and use in source and binary forms, with or without
     11  1.2     jtc  * modification, are permitted provided that the following conditions
     12  1.2     jtc  * are met:
     13  1.2     jtc  * 1. Redistributions of source code must retain the above copyright
     14  1.2     jtc  *    notice, this list of conditions and the following disclaimer.
     15  1.2     jtc  * 2. Redistributions in binary form must reproduce the above copyright
     16  1.2     jtc  *    notice, this list of conditions and the following disclaimer in the
     17  1.2     jtc  *    documentation and/or other materials provided with the distribution.
     18  1.2     jtc  * 3. All advertising materials mentioning features or use of this software
     19  1.2     jtc  *    must display the following acknowledgement:
     20  1.2     jtc  *        This product includes software developed by the NetBSD
     21  1.2     jtc  *	  Foundation, Inc. and its contributors.
     22  1.2     jtc  * 4. Neither the name of The NetBSD Foundation nor the names of its
     23  1.2     jtc  *    contributors may be used to endorse or promote products derived
     24  1.2     jtc  *    from this software without specific prior written permission.
     25  1.1  brezak  *
     26  1.3     jtc  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     27  1.3     jtc  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     28  1.3     jtc  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     29  1.3     jtc  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE
     30  1.3     jtc  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     31  1.3     jtc  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     32  1.3     jtc  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     33  1.3     jtc  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     34  1.3     jtc  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     35  1.3     jtc  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     36  1.3     jtc  * POSSIBILITY OF SUCH DAMAGE.
     37  1.1  brezak  */
     38  1.1  brezak 
     39  1.1  brezak /*
     40  1.1  brezak  * Register defs for Crystal Semiconductor CS4231 Audio Codec/mixer
     41  1.1  brezak  * chip, used on Gravis UltraSound MAX cards.
     42  1.1  brezak  *
     43  1.1  brezak  * Block diagram:
     44  1.1  brezak  *             +----------------------------------------------------+
     45  1.1  brezak  *             |						    |
     46  1.1  brezak  *             |   +----------------------------------------------+ |
     47  1.1  brezak  *	       |   |mixed in       +-+  		          | |
     48  1.1  brezak  *	       |   +------------>--| |  		          | |
     49  1.1  brezak  *             | mic in            | |			          | |
     50  1.1  brezak  *   Mic --+-->| --------- GAIN ->-| |			          | |
     51  1.1  brezak  *         |   | AUX 1 in          |M|				  | |
     52  1.1  brezak  *   GF1 --)-->| -------------+-->-|U|				  | |
     53  1.1  brezak  *	   |   | Line in      |	   |X|---- GAIN ----------+	  | |
     54  1.1  brezak  *  Line --)-->| ---------+---)-->-| |			  |	  | |
     55  1.1  brezak  *	   |   |	  |   |    | |			  |	  | |
     56  1.1  brezak  *	   |   |	  |   |    +-+		         ADC 	  | |
     57  1.1  brezak  *	   |   |	  |   |      		          | 	  | |
     58  1.1  brezak  *	   |   |	  |   |				  |	  | |
     59  1.1  brezak  *	   |   |	  |   +--- L/M --\		  |	  | | AMP-->
     60  1.1  brezak  *	   |   |	  |   	   	  \		  |	  | |  |
     61  1.1  brezak  *	   |   |	  |   	   	   \	          |	  | |  |
     62  1.1  brezak  *	   |   |	  +---- L/M -------O-->--+--------)-------+-|--+-> line
     63  1.1  brezak  *	   |   |   mono in	       	  /|     |        |	    |
     64  1.1  brezak  *	   +---|-->------------ L/M -----/ |     |        |	    |
     65  1.1  brezak  *	       |   AUX 2 in		   |     |        |	    |
     66  1.1  brezak  *  CD --------|-->------------ L/M -------+    L/M       |	    |
     67  1.1  brezak  *	       |				 |        v	    |
     68  1.1  brezak  *	       |				 |        |	    |
     69  1.1  brezak  *	       |				DAC       |	    |
     70  1.1  brezak  *	       |				 |        |	    |
     71  1.1  brezak  *             +----------------------------------------------------+
     72  1.1  brezak  *	       					 |        |
     73  1.1  brezak  *						 |        |
     74  1.1  brezak  *						 v        v
     75  1.1  brezak  *     	       	       	       	       	       	  Pc BUS (DISK) ???
     76  1.1  brezak  *
     77  1.1  brezak  */
     78  1.1  brezak 
     79  1.1  brezak 
     80  1.1  brezak /*
     81  1.1  brezak  * The CS4231 mixer is write-only--it cannot be queried for current
     82  1.1  brezak  * settings.  Drivers must keep track of current values themselves.
     83  1.1  brezak  */
     84  1.1  brezak 
     85  1.1  brezak /* CS4231/AD1845 mode2 registers; added to AD1848 registers */
     86  1.1  brezak #define CS_ALT_FEATURE1		0x10
     87  1.1  brezak #define CS_ALT_FEATURE2		0x11
     88  1.1  brezak #define CS_LEFT_LINE_CONTROL	0x12
     89  1.1  brezak #define CS_RIGHT_LINE_CONTROL	0x13
     90  1.1  brezak #define CS_TIMER_LOW		0x14
     91  1.1  brezak #define CS_TIMER_HIGH		0x15
     92  1.1  brezak #define CS_UPPER_FREQUENCY_SEL	0x16
     93  1.1  brezak #define CS_LOWER_FREQUENCY_SEL	0x17
     94  1.1  brezak #define CS_IRQ_STATUS		0x18
     95  1.1  brezak #define CS_VERSION_ID		0x19
     96  1.1  brezak #define CS_MONO_IO_CONTROL	0x1A
     97  1.1  brezak #define CS_POWERDOWN_CONTROL	0x1B
     98  1.1  brezak #define CS_REC_FORMAT		0x1C
     99  1.1  brezak #define CS_XTAL_SELECT		0x1D
    100  1.1  brezak #define CS_UPPER_REC_CNT	0x1E
    101  1.1  brezak #define CS_LOWER_REC_CNT	0x1F
    102  1.1  brezak 
    103  1.1  brezak #define MONO_INPUT_ATTEN_BITS	0x0f
    104  1.1  brezak #define MONO_INPUT_ATTEN_MASK	0xf0
    105  1.1  brezak #define MONO_INPUT_MUTE		0x80
    106  1.1  brezak #define MONO_INPUT_MUTE_MASK	0x7f
    107  1.1  brezak 
    108  1.1  brezak #define LINE_INPUT_ATTEN_BITS	0x1f
    109  1.1  brezak #define LINE_INPUT_ATTEN_MASK	0xe0
    110  1.1  brezak #define LINE_INPUT_MUTE		0x80
    111  1.1  brezak #define LINE_INPUT_MUTE_MASK	0x7f
    112