/* $NetBSD: aupscreg.h,v 1.3 2006/10/02 07:32:16 gdamore Exp $ */ /*- * Copyright (c) 2006 Shigeyuki Fukushima. * All rights reserved. * * Written by Shigeyuki Fukushima. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above * copyright notice, this list of conditions and the following * disclaimer in the documentation and/or other materials provided * with the distribution. * 3. The name of the author may not be used to endorse or promote * products derived from this software without specific prior * written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #ifndef _MIPS_ALCHEMY_DEV_AUPSCREG_H_ #define _MIPS_ALCHEMY_DEV_AUPSCREG_H_ /* * PSC registers (offset from PSCn_BASE). */ /* psc_sel: PSC clock and protocol select * CLK [5:4] * 00 = pscn_intclk (for SPI, SMBus, I2S Master[PSC3 Only]) * 01 = PSCn_EXTCLK (for SPI, SMBus, I2S Master) * 10 = PSCn_CLK (for AC97, I2S Slave) * 11 = Reserved * PS [2:0] * 000 = Protocol disable * 001 = Reserved * 010 = SPI mode * 011 = I2S mode * 100 = AC97 mode * 101 = SMBus mode * 11x = Reserved */ #define AUPSC_SEL 0x00 /* R/W */ # define AUPSC_SEL_CLK(x) ((x & 0x03) << 4) /* CLK */ # define AUPSC_SEL_PS(x) (x & 0x07) # define AUPSC_SEL_DISABLE 0 # define AUPSC_SEL_SPI 2 # define AUPSC_SEL_I2S 3 # define AUPSC_SEL_AC97 4 # define AUPSC_SEL_SMBUS 5 /* psc_ctrl: PSC control * ENA [1:0] * 00 = Disable/Reset * 01 = Reserved * 10 = Suspend * 11 = Enable */ #define AUPSC_CTRL 0x04 /* R/W */ # define AUPSC_CTRL_ENA(x) (x & 0x03) # define AUPSC_CTRL_DISABLE 0 # define AUPSC_CTRL_SUSPEND 2 # define AUPSC_CTRL_ENABLE 3 /* 0x0008 - 0x002F: Protocol-specific registers */ /* psc_stat: PSC status * DI [1] * 1 = Device interrupt * DR [1] * 1 = Device ready * SR [0] * 1 = PSC ready * all other bits a are protocol specific */ #define AUPSC_STAT 0x14 # define AUPSC_STAT_SR 1 # define AUPSC_STAT_DR 2 # define AUPSC_STAT_DI 4 /* PSC registers size */ #define AUPSC_SIZE 0x2f /* * SPI Protocol registers */ #define AUPSC_SPICFG 0x08 /* R/W */ #define AUPSC_SPIMSK 0x0c /* R/W */ #define AUPSC_SPIPCR 0x10 /* R/W */ #define AUPSC_SPISTAT 0x14 /* Read only */ #define AUPSC_SPIEVNT 0x18 /* R/W */ #define AUPSC_SPITXRX 0x1c /* R/W */ /* * I2S Protocol registers */ #define AUPSC_I2SCFG 0x08 /* R/W */ #define AUPSC_I2SMSK 0x0c /* R/W */ #define AUPSC_I2SPCR 0x10 /* R/W */ #define AUPSC_I2SSTAT 0x14 /* Read only */ #define AUPSC_I2SEVNT 0x18 /* R/W */ #define AUPSC_I2STXRX 0x1c /* R/W */ #define AUPSC_I2SUDF 0x20 /* R/W */ /* * AC97 Protocol registers */ #define AUPSC_AC97CFG 0x08 /* R/W */ #define AUPSC_AC97MSK 0x0c /* R/W */ #define AUPSC_AC97PCR 0x10 /* R/W */ #define AUPSC_AC97STAT 0x14 /* Read only */ #define AUPSC_AC97EVNT 0x18 /* R/W */ #define AUPSC_AC97TXRX 0x1c /* R/W */ #define AUPSC_AC97CDC 0x20 /* R/W */ #define AUPSC_AC97RST 0x24 /* R/W */ #define AUPSC_AC97GPO 0x28 /* R/W */ #define AUPSC_AC97GPI 0x2c /* Read only */ /* * SMBus Protocol registers */ #define AUPSC_SMBCFG 0x08 /* R/W */ #define AUPSC_SMBMSK 0x0c /* R/W */ #define AUPSC_SMBPCR 0x10 /* R/W */ #define AUPSC_SMBSTAT 0x14 /* Read only */ #define AUPSC_SMBEVNT 0x18 /* R/W */ #define AUPSC_SMBTXRX 0x1c /* R/W */ #define AUPSC_SMBTMR 0x20 /* R/W */ #endif /* _MIPS_ALCHEMY_DEV_AUPSCREG_H_ */