Add new --list-supported switch for printing the list of Super I/Os
supported by superiotool (closes #91). Signed-off-by: Robinson P. Tryon <bishop.robinson@gmail.com> Acked-by: Uwe Hermann <uwe@hermann-uwe.de> git-svn-id: svn://svn.coreboot.org/coreboot/trunk@3050 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
This commit is contained in:
parent
6211ae13c3
commit
552cfb7b74
9 changed files with 108 additions and 4 deletions
|
@ -99,3 +99,8 @@ void probe_idregs_ali(uint16_t port)
|
||||||
|
|
||||||
exit_conf_mode_ali(port);
|
exit_conf_mode_ali(port);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void print_ali_chips(void)
|
||||||
|
{
|
||||||
|
print_vendor_chips("ALi", reg_table);
|
||||||
|
}
|
||||||
|
|
|
@ -99,3 +99,8 @@ void probe_idregs_fintek(uint16_t port)
|
||||||
|
|
||||||
exit_conf_mode_winbond_fintek_ite_8787(port);
|
exit_conf_mode_winbond_fintek_ite_8787(port);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void print_fintek_chips(void)
|
||||||
|
{
|
||||||
|
print_vendor_chips("Fintek", reg_table);
|
||||||
|
}
|
||||||
|
|
|
@ -380,3 +380,8 @@ void probe_idregs_ite(uint16_t port)
|
||||||
probe_idregs_ite_helper("(init=0x87,0x87) ", port);
|
probe_idregs_ite_helper("(init=0x87,0x87) ", port);
|
||||||
exit_conf_mode_winbond_fintek_ite_8787(port);
|
exit_conf_mode_winbond_fintek_ite_8787(port);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void print_ite_chips(void)
|
||||||
|
{
|
||||||
|
print_vendor_chips("ITE", reg_table);
|
||||||
|
}
|
||||||
|
|
|
@ -449,3 +449,8 @@ void probe_idregs_nsc(uint16_t port)
|
||||||
|
|
||||||
dump_superio("NSC", reg_table, port, id);
|
dump_superio("NSC", reg_table, port, id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void print_nsc_chips(void)
|
||||||
|
{
|
||||||
|
print_vendor_chips("NSC", reg_table);
|
||||||
|
}
|
||||||
|
|
|
@ -546,3 +546,8 @@ void probe_idregs_smsc(uint16_t port)
|
||||||
probe_idregs_smsc_helper(port, DEVICE_ID_REG, DEVICE_REV_REG);
|
probe_idregs_smsc_helper(port, DEVICE_ID_REG, DEVICE_REV_REG);
|
||||||
probe_idregs_smsc_helper(port, DEVICE_ID_REG_OLD, DEVICE_REV_REG_OLD);
|
probe_idregs_smsc_helper(port, DEVICE_ID_REG_OLD, DEVICE_REV_REG_OLD);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void print_smsc_chips(void)
|
||||||
|
{
|
||||||
|
print_vendor_chips("SMSC", reg_table);
|
||||||
|
}
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
.TH SUPERIOTOOL 8 "October 11, 2007"
|
.TH SUPERIOTOOL 8 "January 13, 2008"
|
||||||
.SH NAME
|
.SH NAME
|
||||||
superiotool \- Super I/O detection tool
|
superiotool \- Super I/O detection tool
|
||||||
.SH SYNOPSIS
|
.SH SYNOPSIS
|
||||||
.B superiotool \fR[\fB\-dVvh\fR]
|
.B superiotool \fR[\fB\-dlVvh\fR]
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
.B superiotool
|
.B superiotool
|
||||||
is a GPL'd user-space utility which can
|
is a GPL'd user-space utility which can
|
||||||
|
@ -72,6 +72,16 @@ which can mean several things. It's recommended to consult the datasheet for
|
||||||
detailed information about the
|
detailed information about the
|
||||||
.BR MM " fields."
|
.BR MM " fields."
|
||||||
.TP
|
.TP
|
||||||
|
.B "\-l, \-\-list-supported"
|
||||||
|
List all Super I/O chips recognized by
|
||||||
|
.BR superiotool ". The phrase"
|
||||||
|
.BR (dump available)
|
||||||
|
following a chip name indicates that
|
||||||
|
.B superiotool
|
||||||
|
supports the
|
||||||
|
.B --dump
|
||||||
|
option for this chip.
|
||||||
|
.TP
|
||||||
.B "\-V, \-\-verbose"
|
.B "\-V, \-\-verbose"
|
||||||
Enable verbose mode. This option can be used together with the
|
Enable verbose mode. This option can be used together with the
|
||||||
.BR "\-d" " option."
|
.BR "\-d" " option."
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
* Copyright (C) 2006 Ronald Minnich <rminnich@gmail.com>
|
* Copyright (C) 2006 Ronald Minnich <rminnich@gmail.com>
|
||||||
* Copyright (C) 2007 Uwe Hermann <uwe@hermann-uwe.de>
|
* Copyright (C) 2007 Uwe Hermann <uwe@hermann-uwe.de>
|
||||||
* Copyright (C) 2007 Carl-Daniel Hailfinger
|
* Copyright (C) 2007 Carl-Daniel Hailfinger
|
||||||
|
* Copyright (C) 2008 Robinson P. Tryon <bishop.robinson@gmail.com>
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
@ -161,6 +162,41 @@ void probing_for(const char *vendor, const char *info, uint16_t port)
|
||||||
vendor, info, port);
|
vendor, info, port);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Print a list of all supported chips from the given vendor. */
|
||||||
|
void print_vendor_chips(const char *vendor,
|
||||||
|
const struct superio_registers reg_table[])
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
for (i = 0; reg_table[i].superio_id != EOT; i++) {
|
||||||
|
printf("%s %s", vendor, reg_table[i].name);
|
||||||
|
|
||||||
|
/* Unless the ldn is empty, assume this chip has a dump. */
|
||||||
|
if (reg_table[i].ldn[0].ldn != EOT)
|
||||||
|
printf(" (dump available)");
|
||||||
|
|
||||||
|
printf("\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
/* If we printed any chips for this vendor, put in a blank line. */
|
||||||
|
if (i != 0)
|
||||||
|
printf("\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Print a list of all chips supported by superiotool. */
|
||||||
|
void print_list_of_supported_chips(void)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
printf("Supported Super I/O chips:\n\n");
|
||||||
|
|
||||||
|
for (i = 0; i < ARRAY_SIZE(vendor_print_functions); i++)
|
||||||
|
vendor_print_functions[i].print_list();
|
||||||
|
|
||||||
|
printf("See <http://coreboot.org/Superiotool#Supported_devices> "
|
||||||
|
"for more information.\n");
|
||||||
|
}
|
||||||
|
|
||||||
static void print_version(void)
|
static void print_version(void)
|
||||||
{
|
{
|
||||||
printf("superiotool r%s\n", SUPERIOTOOL_VERSION);
|
printf("superiotool r%s\n", SUPERIOTOOL_VERSION);
|
||||||
|
@ -172,18 +208,23 @@ int main(int argc, char *argv[])
|
||||||
|
|
||||||
static const struct option long_options[] = {
|
static const struct option long_options[] = {
|
||||||
{"dump", no_argument, NULL, 'd'},
|
{"dump", no_argument, NULL, 'd'},
|
||||||
|
{"list-supported", no_argument, NULL, 'l'},
|
||||||
{"verbose", no_argument, NULL, 'V'},
|
{"verbose", no_argument, NULL, 'V'},
|
||||||
{"version", no_argument, NULL, 'v'},
|
{"version", no_argument, NULL, 'v'},
|
||||||
{"help", no_argument, NULL, 'h'},
|
{"help", no_argument, NULL, 'h'},
|
||||||
{0, 0, 0, 0}
|
{0, 0, 0, 0}
|
||||||
};
|
};
|
||||||
|
|
||||||
while ((opt = getopt_long(argc, argv, "dVvh",
|
while ((opt = getopt_long(argc, argv, "dlVvh",
|
||||||
long_options, &option_index)) != EOF) {
|
long_options, &option_index)) != EOF) {
|
||||||
switch (opt) {
|
switch (opt) {
|
||||||
case 'd':
|
case 'd':
|
||||||
dump = 1;
|
dump = 1;
|
||||||
break;
|
break;
|
||||||
|
case 'l':
|
||||||
|
print_list_of_supported_chips();
|
||||||
|
exit(0);
|
||||||
|
break;
|
||||||
case 'V':
|
case 'V':
|
||||||
verbose = 1;
|
verbose = 1;
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -3,6 +3,7 @@
|
||||||
*
|
*
|
||||||
* Copyright (C) 2007 Carl-Daniel Hailfinger
|
* Copyright (C) 2007 Carl-Daniel Hailfinger
|
||||||
* Copyright (C) 2007 Uwe Hermann <uwe@hermann-uwe.de>
|
* Copyright (C) 2007 Uwe Hermann <uwe@hermann-uwe.de>
|
||||||
|
* Copyright (C) 2008 Robinson P. Tryon <bishop.robinson@gmail.com>
|
||||||
*
|
*
|
||||||
* This program is free software; you can redistribute it and/or modify
|
* 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
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
@ -29,8 +30,9 @@
|
||||||
#include <getopt.h>
|
#include <getopt.h>
|
||||||
#include <sys/io.h>
|
#include <sys/io.h>
|
||||||
|
|
||||||
#define USAGE "Usage: superiotool [-d] [-V] [-v] [-h]\n\n\
|
#define USAGE "Usage: superiotool [-d] [-l] [-V] [-v] [-h]\n\n\
|
||||||
-d | --dump Dump Super I/O register contents\n\
|
-d | --dump Dump Super I/O register contents\n\
|
||||||
|
-l | --list-supported Show the list of supported Super I/O chips\n\
|
||||||
-V | --verbose Verbose mode\n\
|
-V | --verbose Verbose mode\n\
|
||||||
-v | --version Show the superiotool version\n\
|
-v | --version Show the superiotool version\n\
|
||||||
-h | --help Show a short help text\n\n\
|
-h | --help Show a short help text\n\n\
|
||||||
|
@ -80,24 +82,32 @@ const char *get_superio_name(const struct superio_registers reg_table[],
|
||||||
void dump_superio(const char *name, const struct superio_registers reg_table[],
|
void dump_superio(const char *name, const struct superio_registers reg_table[],
|
||||||
uint16_t port, uint16_t id);
|
uint16_t port, uint16_t id);
|
||||||
void probing_for(const char *vendor, const char *info, uint16_t port);
|
void probing_for(const char *vendor, const char *info, uint16_t port);
|
||||||
|
void print_vendor_chips(const char *vendor,
|
||||||
|
const struct superio_registers reg_table[]);
|
||||||
|
|
||||||
/* ali.c */
|
/* ali.c */
|
||||||
void probe_idregs_ali(uint16_t port);
|
void probe_idregs_ali(uint16_t port);
|
||||||
|
void print_ali_chips(void);
|
||||||
|
|
||||||
/* fintek.c */
|
/* fintek.c */
|
||||||
void probe_idregs_fintek(uint16_t port);
|
void probe_idregs_fintek(uint16_t port);
|
||||||
|
void print_fintek_chips(void);
|
||||||
|
|
||||||
/* ite.c */
|
/* ite.c */
|
||||||
void probe_idregs_ite(uint16_t port);
|
void probe_idregs_ite(uint16_t port);
|
||||||
|
void print_ite_chips(void);
|
||||||
|
|
||||||
/* nsc.c */
|
/* nsc.c */
|
||||||
void probe_idregs_nsc(uint16_t port);
|
void probe_idregs_nsc(uint16_t port);
|
||||||
|
void print_nsc_chips(void);
|
||||||
|
|
||||||
/* smsc.c */
|
/* smsc.c */
|
||||||
void probe_idregs_smsc(uint16_t port);
|
void probe_idregs_smsc(uint16_t port);
|
||||||
|
void print_smsc_chips(void);
|
||||||
|
|
||||||
/* winbond.c */
|
/* winbond.c */
|
||||||
void probe_idregs_winbond(uint16_t port);
|
void probe_idregs_winbond(uint16_t port);
|
||||||
|
void print_winbond_chips(void);
|
||||||
|
|
||||||
/** Table of which config ports to probe for each Super I/O family. */
|
/** Table of which config ports to probe for each Super I/O family. */
|
||||||
static const struct {
|
static const struct {
|
||||||
|
@ -112,4 +122,17 @@ static const struct {
|
||||||
{probe_idregs_winbond, {0x2e, 0x4e, 0x3f0, 0x370, 0x250, EOT}},
|
{probe_idregs_winbond, {0x2e, 0x4e, 0x3f0, 0x370, 0x250, EOT}},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/** Table of functions to print out supported Super I/O chips. */
|
||||||
|
static const struct {
|
||||||
|
void (*print_list) (void);
|
||||||
|
} vendor_print_functions[] = {
|
||||||
|
{print_ali_chips},
|
||||||
|
{print_fintek_chips},
|
||||||
|
{print_ite_chips},
|
||||||
|
{print_nsc_chips},
|
||||||
|
{print_smsc_chips},
|
||||||
|
{print_winbond_chips},
|
||||||
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -445,3 +445,8 @@ void probe_idregs_winbond(uint16_t port)
|
||||||
probe_idregs_winbond_helper("(init=0x87,0x87) ", port);
|
probe_idregs_winbond_helper("(init=0x87,0x87) ", port);
|
||||||
exit_conf_mode_winbond_fintek_ite_8787(port);
|
exit_conf_mode_winbond_fintek_ite_8787(port);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void print_winbond_chips(void)
|
||||||
|
{
|
||||||
|
print_vendor_chips("Winbond", reg_table);
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue