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:
Robinson P. Tryon 2008-01-15 22:30:55 +00:00 committed by Uwe Hermann
parent 6211ae13c3
commit 552cfb7b74
9 changed files with 108 additions and 4 deletions

View file

@ -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);
}

View file

@ -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);
}

View file

@ -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);
}

View file

@ -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);
}

View file

@ -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);
}

View file

@ -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."

View file

@ -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;

View file

@ -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

View file

@ -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);
}