3acf31e4ea
Add command line option handling code. The following options are defined at the moment: -d|--dump Dump Super I/O registers. -V|--verbose Verbose mode. -v|--version Show the superiotool version. -h|--help Show a short help text. Per default (no options) we just probe for a Super I/O and print its vendor, name, ID, version, and config port. Example: $ ./superiotool Found SMSC FDC37N769 Super I/O (id=0x28, rev=0x01) at port=0x03f0 $ ./superiotool -d Found SMSC FDC37N769 Super I/O (id=0x28, rev=0x01) at port=0x03f0 idx 00 01 02 03 04 05 06 07 08 09 0a 0b 0c 0d 0e 0f 10 11 12 13 14 15 16 17 18 19 1a 1b 1c 1d 1e 1f 20 21 22 23 24 25 26 27 28 29 2a 2b 2c 2d 2e 2f val 20 90 80 f4 00 00 ff 00 00 00 40 00 0e 28 01 00 00 00 00 00 02 00 01 03 00 00 00 00 00 00 80 00 00 00 00 00 00 ba 00 00 03 00 00 23 03 03 00 00 def 28 9c 88 70 00 00 ff 00 00 00 00 00 02 28 NA 00 00 80 RR RR NA NA NA 03 RR RR RR RR RR RR 80 00 3c RR RR 00 00 00 00 00 00 00 RR 00 00 03 00 00 $ ./superiotool -s ./superiotool: invalid option -- s $ ./superiotool -h Usage: superiotool [-d] [-V] [-v] [-h] $ ./superiotool -v superiotool 0.1 Signed-off-by: Uwe Hermann <uwe@hermann-uwe.de> Acked-by: Uwe Hermann <uwe@hermann-uwe.de> git-svn-id: svn://svn.coreboot.org/coreboot/trunk@2788 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
156 lines
4.6 KiB
C
156 lines
4.6 KiB
C
/*
|
|
* This file is part of the LinuxBIOS project.
|
|
*
|
|
* Copyright (C) 2006 coresystems GmbH <info@coresystems.de>
|
|
*
|
|
* 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 program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* 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., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
#include "superiotool.h"
|
|
|
|
void dump_fintek(uint16_t port, uint16_t did)
|
|
{
|
|
switch (did) {
|
|
case 0x0604:
|
|
printf("Fintek F71805\n");
|
|
break;
|
|
case 0x4103:
|
|
printf("Fintek F71872\n");
|
|
break;
|
|
default:
|
|
printf("Unknown Fintek Super I/O: did=0x%04x\n", did);
|
|
return;
|
|
}
|
|
|
|
printf("Flash write is %s.\n",
|
|
regval(port, 0x28) & 0x80 ? "enabled" : "disabled");
|
|
printf("Flash control is 0x%04x.\n", regval(port, 0x28));
|
|
printf("27=%02x\n", regval(port, 0x27));
|
|
printf("29=%02x\n", regval(port, 0x29));
|
|
printf("2a=%02x\n", regval(port, 0x2a));
|
|
printf("2b=%02x\n", regval(port, 0x2b));
|
|
|
|
/* Select UART 1. */
|
|
regwrite(port, 0x07, 0x01);
|
|
printf("UART1 is %s\n",
|
|
regval(port, 0x30) & 1 ? "enabled" : "disabled");
|
|
printf("UART1 base=%02x%02x, irq=%02x, mode=%s\n", regval(port, 0x60),
|
|
regval(port, 0x61), regval(port, 0x70) & 0x0f,
|
|
regval(port, 0xf0) & 0x10 ? "RS485" : "RS232");
|
|
|
|
/* Select UART 2. */
|
|
regwrite(port, 0x07, 0x02);
|
|
printf("UART2 is %s\n",
|
|
regval(port, 0x30) & 1 ? "enabled" : "disabled");
|
|
printf("UART2 base=%02x%02x, irq=%02x, mode=%s\n", regval(port, 0x60),
|
|
regval(port, 0x61), regval(port, 0x70) & 0x0f,
|
|
regval(port, 0xf0) & 0x10 ? "RS485" : "RS232");
|
|
|
|
/* Select parallel port. */
|
|
regwrite(port, 0x07, 0x03);
|
|
printf("PARPORT is %s\n",
|
|
regval(port, 0x30) & 1 ? "enabled" : "disabled");
|
|
printf("PARPORT base=%02x%02x, irq=%02x\n", regval(port, 0x60),
|
|
regval(port, 0x61), regval(port, 0x70) & 0x0f);
|
|
|
|
/* Select HW monitor. */
|
|
regwrite(port, 0x07, 0x04);
|
|
printf("HW monitor is %s\n",
|
|
regval(port, 0x30) & 1 ? "enabled" : "disabled");
|
|
printf("HW monitor base=%02x%02x, irq=%02x\n", regval(port, 0x60),
|
|
regval(port, 0x61), regval(port, 0x70) & 0x0f);
|
|
|
|
/* Select GPIO. */
|
|
regwrite(port, 0x07, 0x05);
|
|
printf("GPIO is %s\n", regval(port, 0x30) & 1 ? "enabled" : "disabled");
|
|
printf
|
|
("GPIO 70=%02x, e0=%02x, e1=%02x, e2=%02x, e3=%02x, e4=%02x, e5=%02x\n",
|
|
regval(port, 0x70), regval(port, 0xe0), regval(port, 0xe1),
|
|
regval(port, 0xe2), regval(port, 0xe3), regval(port, 0xe4),
|
|
regval(port, 0xe5));
|
|
printf
|
|
("GPIO e6=%02x, e7=%02x, e8=%02x, e9=%02x, f0=%02x, f1=%02x, f3=%02x, f4=%02x\n",
|
|
regval(port, 0xe6), regval(port, 0xe7), regval(port, 0xe8),
|
|
regval(port, 0xe9), regval(port, 0xf0), regval(port, 0xf1),
|
|
regval(port, 0xf3), regval(port, 0xf4));
|
|
printf("GPIO f5=%02x, f6=%02x, f7=%02x, f8=%02x\n", regval(port, 0xf5),
|
|
regval(port, 0xf6), regval(port, 0xf7), regval(port, 0xf8));
|
|
}
|
|
|
|
static void enter_conf_mode_fintek(uint16_t port)
|
|
{
|
|
/* Enable configuration sequence (Fintek uses this for example)
|
|
* Older ITE chips have the same enable sequence.
|
|
*/
|
|
outb(0x87, port);
|
|
outb(0x87, port);
|
|
}
|
|
|
|
static void exit_conf_mode_fintek(uint16_t port)
|
|
{
|
|
/* Exit MB PnP mode (for Fintek, doesn't hurt ITE). */
|
|
outb(0xaa, port);
|
|
}
|
|
|
|
void probe_idregs_fintek(uint16_t port)
|
|
{
|
|
uint16_t vid, did, success = 0;
|
|
|
|
enter_conf_mode_fintek(port);
|
|
|
|
outb(0x20, port);
|
|
if (inb(port) != 0x20) {
|
|
no_superio_found(port);
|
|
return;
|
|
}
|
|
did = inb(port + 1);
|
|
did |= (regval(port, 0x21) << 8);
|
|
|
|
vid = regval(port, 0x23);
|
|
vid |= (regval(port, 0x24) << 8);
|
|
|
|
printf("Super I/O found at 0x%02x: vid=0x%04x/did=0x%04x\n",
|
|
port, vid, did);
|
|
|
|
if (vid == 0xff || vid == 0xffff)
|
|
return;
|
|
|
|
/* printf("%s\n", familyid[id]); */
|
|
switch (did) {
|
|
case 0x0887: /* Pseudoreversed for ITE8708 */
|
|
case 0x1087: /* Pseudoreversed for ITE8710 */
|
|
success = 1;
|
|
dump_ite(port, ((did & 0xff) << 8) | ((did & 0xff00) >> 8));
|
|
regwrite(port, 0x02, 0x02); /* Exit MB PnP mode. */
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
|
|
switch (vid) {
|
|
case 0x3419:
|
|
success = 1;
|
|
dump_fintek(port, did);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
|
|
if (!success)
|
|
printf("No dump for vid 0x%04x, did 0x%04x\n", vid, did);
|
|
|
|
exit_conf_mode_fintek(port);
|
|
}
|
|
|