/* $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_ */