145 lines
3.7 KiB
C
145 lines
3.7 KiB
C
|
/*
|
||
|
*
|
||
|
* BRIEF MODULE DESCRIPTION
|
||
|
* ITE Semi IT8712 Super I/O functions.
|
||
|
*
|
||
|
* Copyright 2001 MontaVista Software Inc.
|
||
|
* Author: MontaVista Software, Inc.
|
||
|
* ppopov@mvista.com or source@mvista.com
|
||
|
*
|
||
|
* This program is free software; you can redistribute it and/or modify it
|
||
|
* under the terms of the GNU General Public License as published by the
|
||
|
* Free Software Foundation; either version 2 of the License, or (at your
|
||
|
* option) any later version.
|
||
|
*
|
||
|
* THIS SOFTWARE IS PROVIDED ``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.
|
||
|
*
|
||
|
* You should have received a copy of the GNU General Public License along
|
||
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
||
|
* 675 Mass Ave, Cambridge, MA 02139, USA.
|
||
|
*/
|
||
|
|
||
|
#include <asm/io.h>
|
||
|
#include <asm/types.h>
|
||
|
#include <asm/it8712.h>
|
||
|
#include <asm/it8172/it8172.h>
|
||
|
|
||
|
#ifndef TRUE
|
||
|
#define TRUE 1
|
||
|
#endif
|
||
|
|
||
|
#ifndef FALSE
|
||
|
#define FALSE 0
|
||
|
#endif
|
||
|
|
||
|
void LPCEnterMBPnP(void)
|
||
|
{
|
||
|
int i;
|
||
|
unsigned char key[4] = {0x87, 0x01, 0x55, 0x55};
|
||
|
|
||
|
for (i = 0; i<4; i++)
|
||
|
outb(key[i], LPC_KEY_ADDR);
|
||
|
|
||
|
}
|
||
|
|
||
|
void LPCExitMBPnP(void)
|
||
|
{
|
||
|
outb(0x02, LPC_KEY_ADDR);
|
||
|
outb(0x02, LPC_DATA_ADDR);
|
||
|
}
|
||
|
|
||
|
void LPCSetConfig(char LdnNumber, char Index, char data)
|
||
|
{
|
||
|
LPCEnterMBPnP(); // Enter IT8712 MB PnP mode
|
||
|
outb(0x07, LPC_KEY_ADDR);
|
||
|
outb(LdnNumber, LPC_DATA_ADDR);
|
||
|
outb(Index, LPC_KEY_ADDR);
|
||
|
outb(data, LPC_DATA_ADDR);
|
||
|
LPCExitMBPnP();
|
||
|
}
|
||
|
|
||
|
char LPCGetConfig(char LdnNumber, char Index)
|
||
|
{
|
||
|
char rtn;
|
||
|
|
||
|
LPCEnterMBPnP(); // Enter IT8712 MB PnP mode
|
||
|
outb(0x07, LPC_KEY_ADDR);
|
||
|
outb(LdnNumber, LPC_DATA_ADDR);
|
||
|
outb(Index, LPC_KEY_ADDR);
|
||
|
rtn = inb(LPC_DATA_ADDR);
|
||
|
LPCExitMBPnP();
|
||
|
return rtn;
|
||
|
}
|
||
|
|
||
|
int SearchIT8712(void)
|
||
|
{
|
||
|
unsigned char Id1, Id2;
|
||
|
unsigned short Id;
|
||
|
|
||
|
LPCEnterMBPnP();
|
||
|
outb(0x20, LPC_KEY_ADDR); /* chip id byte 1 */
|
||
|
Id1 = inb(LPC_DATA_ADDR);
|
||
|
outb(0x21, LPC_KEY_ADDR); /* chip id byte 2 */
|
||
|
Id2 = inb(LPC_DATA_ADDR);
|
||
|
Id = (Id1 << 8) | Id2;
|
||
|
LPCExitMBPnP();
|
||
|
if (Id == 0x8712)
|
||
|
return TRUE;
|
||
|
else
|
||
|
return FALSE;
|
||
|
}
|
||
|
|
||
|
void InitLPCInterface(void)
|
||
|
{
|
||
|
unsigned char bus, dev_fn;
|
||
|
unsigned long data;
|
||
|
|
||
|
bus = 0;
|
||
|
dev_fn = 1<<3 | 4;
|
||
|
|
||
|
|
||
|
/* pci cmd, SERR# Enable */
|
||
|
IT_WRITE(IT_CONFADDR,
|
||
|
(bus << IT_BUSNUM_SHF) |
|
||
|
(dev_fn << IT_FUNCNUM_SHF) |
|
||
|
((0x4 / 4) << IT_REGNUM_SHF));
|
||
|
IT_READ(IT_CONFDATA, data);
|
||
|
data |= 0x0100;
|
||
|
IT_WRITE(IT_CONFADDR,
|
||
|
(bus << IT_BUSNUM_SHF) |
|
||
|
(dev_fn << IT_FUNCNUM_SHF) |
|
||
|
((0x4 / 4) << IT_REGNUM_SHF));
|
||
|
IT_WRITE(IT_CONFDATA, data);
|
||
|
|
||
|
/* setup serial irq control register */
|
||
|
IT_WRITE(IT_CONFADDR,
|
||
|
(bus << IT_BUSNUM_SHF) |
|
||
|
(dev_fn << IT_FUNCNUM_SHF) |
|
||
|
((0x48 / 4) << IT_REGNUM_SHF));
|
||
|
IT_READ(IT_CONFDATA, data);
|
||
|
data = (data & 0xffff00ff) | 0xc400;
|
||
|
IT_WRITE(IT_CONFADDR,
|
||
|
(bus << IT_BUSNUM_SHF) |
|
||
|
(dev_fn << IT_FUNCNUM_SHF) |
|
||
|
((0x48 / 4) << IT_REGNUM_SHF));
|
||
|
IT_WRITE(IT_CONFDATA, data);
|
||
|
|
||
|
|
||
|
/* Enable I/O Space Subtractive Decode */
|
||
|
/* default 0x4C is 0x3f220000 */
|
||
|
IT_WRITE(IT_CONFADDR,
|
||
|
(bus << IT_BUSNUM_SHF) |
|
||
|
(dev_fn << IT_FUNCNUM_SHF) |
|
||
|
((0x4C / 4) << IT_REGNUM_SHF));
|
||
|
IT_WRITE(IT_CONFDATA, 0x3f2200f3);
|
||
|
}
|