7a880ea190
which is enabled by default (use `-c' to get the old format). The new format looks like this (only the values are correct; this was taken on my machine with a slightly old kernel): Device St Parent Description ---------- -- ---------- -------------------------------------------------- isa0 NC - sc0 NC isa0 Parallel printer adapter ed0 NC isa0 SMC8216/SMC8216C sio0 NC isa0 RS-232 serial port sio1 NC isa0 RS-232 serial port fdc0 NC isa0 floppy disk/tape controller fd0 NC fdc0 floppy disk wdc0 NC isa0 ST506/ESDI/IDE disk controller wd0 NC wdc0 ST506/ESDI/IDE disk npx0 NC isa0 Floating-point unit Note that many of these fields could be made more informative; I tried to make my changes as unintrusive as possible. See the `mcd' driver for an example of one which actually does something with the `state' field.
198 lines
3.8 KiB
C
198 lines
3.8 KiB
C
#include "lsdev.h"
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#include <machine/vmparam.h>
|
|
|
|
static void print_isa(struct devconf *);
|
|
static void print_eisa(struct devconf *);
|
|
static void print_pci(struct devconf *);
|
|
static void print_scsi(struct devconf *);
|
|
static void print_disk(struct devconf *);
|
|
|
|
void
|
|
hprint_config(void)
|
|
{
|
|
printf("# This listing automatically generated by lsdev(1)\n");
|
|
}
|
|
|
|
void
|
|
print_config(struct devconf *dc)
|
|
{
|
|
if(vflag)
|
|
printf("%d: ", dc->dc_number);
|
|
|
|
switch(dc->dc_devtype) {
|
|
case MDDT_CPU:
|
|
printf("# CPU %s%d", dc->dc_name, dc->dc_unit);
|
|
break;
|
|
case MDDT_BUS:
|
|
printf("controller %s%d", dc->dc_name, dc->dc_unit);
|
|
break;
|
|
case MDDT_ISA:
|
|
if(dc->dc_datalen >= ISA_EXTERNALLEN) {
|
|
print_isa(dc);
|
|
} else {
|
|
printit:
|
|
printf("%s%d at %s%d",
|
|
dc->dc_name, dc->dc_unit, dc->dc_pname,
|
|
dc->dc_punit);
|
|
}
|
|
break;
|
|
case MDDT_EISA:
|
|
if(dc->dc_datalen >= EISA_EXTERNALLEN) {
|
|
print_eisa(dc);
|
|
} else {
|
|
goto printit;
|
|
}
|
|
break;
|
|
case MDDT_PCI:
|
|
if(dc->dc_datalen >= PCI_EXTERNALLEN) {
|
|
print_pci(dc);
|
|
} else {
|
|
goto printit;
|
|
}
|
|
break;
|
|
case MDDT_SCSI:
|
|
if(dc->dc_datalen >= SCSI_EXTERNALLEN) {
|
|
print_scsi(dc);
|
|
} else {
|
|
goto printit;
|
|
}
|
|
break;
|
|
case MDDT_DISK:
|
|
if(dc->dc_datalen >= DISK_EXTERNALLEN) {
|
|
print_disk(dc);
|
|
} else {
|
|
goto printit;
|
|
}
|
|
break;
|
|
|
|
default:
|
|
if(dc->dc_devtype >= NDEVTYPES) {
|
|
printf("%s%d (#%d) at %s%d",
|
|
dc->dc_name, dc->dc_unit, dc->dc_devtype,
|
|
dc->dc_pname, dc->dc_punit);
|
|
} else {
|
|
printf("%s%d (%s) at %s%d",
|
|
dc->dc_name, dc->dc_unit,
|
|
devtypes[dc->dc_devtype], dc->dc_pname,
|
|
dc->dc_punit);
|
|
}
|
|
break;
|
|
}
|
|
fputc('\n', stdout);
|
|
}
|
|
|
|
static void
|
|
print_isa(struct devconf *dc)
|
|
{
|
|
struct isa_device *id = (struct isa_device *)dc->dc_data;
|
|
|
|
printf("%s%d\tat isa?", dc->dc_name, dc->dc_unit);
|
|
|
|
if(dc->dc_md.mddc_imask[0]) {
|
|
printf(" %3.3s", dc->dc_md.mddc_imask);
|
|
}
|
|
|
|
if(vflag) {
|
|
printf(" (id %d)", id->id_id);
|
|
}
|
|
|
|
if(id->id_iobase) {
|
|
if(id->id_iobase < 0) {
|
|
printf(" port ?");
|
|
} else {
|
|
printf(" port 0x%x", id->id_iobase);
|
|
}
|
|
}
|
|
|
|
if(id->id_irq) {
|
|
int bit = ffs(id->id_irq) - 1;
|
|
|
|
if(id->id_irq & ~(1 << bit)) {
|
|
printf(" irq ?");
|
|
} else {
|
|
printf(" irq %d", bit);
|
|
}
|
|
}
|
|
|
|
if(id->id_drq >= 0) {
|
|
printf(" drq %d", id->id_drq);
|
|
}
|
|
|
|
if(id->id_maddr) {
|
|
if((unsigned long)id->id_maddr == ~0UL) {
|
|
printf(" iomem ?");
|
|
} else {
|
|
printf(" iomem 0x%lx",
|
|
(unsigned long)id->id_maddr & ~KERNBASE);
|
|
}
|
|
}
|
|
|
|
if(id->id_msize) {
|
|
if(id->id_msize < 0) {
|
|
printf(" iosiz ?", id->id_msize);
|
|
} else {
|
|
printf(" iosiz %d", id->id_msize);
|
|
}
|
|
}
|
|
|
|
if(id->id_flags) {
|
|
printf(" flags 0x%x", id->id_flags);
|
|
}
|
|
}
|
|
|
|
static void
|
|
print_eisa(struct devconf *dc)
|
|
{
|
|
int *slotp = (int *)&dc->dc_data[ISA_EXTERNALLEN];
|
|
print_isa(dc);
|
|
if(vflag) {
|
|
printf(" (slot %d)", *slotp);
|
|
}
|
|
}
|
|
|
|
static void
|
|
print_pci(struct devconf *dc)
|
|
{
|
|
struct pci_device *pd = (struct pci_device *)dc->dc_data;
|
|
|
|
/*
|
|
* Unfortunately, the `pci_device' struct is completely
|
|
* useless. We will have to develop a unique structure
|
|
* for this task eventually, unless the existing one can
|
|
* be made to serve.
|
|
*/
|
|
|
|
printf("%s%d at %s%d", dc->dc_name, dc->dc_unit, dc->dc_pname,
|
|
dc->dc_punit);
|
|
}
|
|
|
|
static void
|
|
print_scsi(struct devconf *dc)
|
|
{
|
|
struct scsi_link *sl = (struct scsi_link *)dc->dc_data;
|
|
|
|
printf("%s%d at SCSI bus %d:%d:%d",
|
|
dc->dc_name, dc->dc_unit, sl->scsibus, sl->target,
|
|
sl->lun);
|
|
if(vflag) {
|
|
if(sl->flags & SDEV_MEDIA_LOADED)
|
|
printf(" (ready)");
|
|
if(sl->flags & SDEV_OPEN)
|
|
printf(" (open)");
|
|
if(sl->flags & SDEV_BOUNCE)
|
|
printf(" (bounce)");
|
|
}
|
|
}
|
|
|
|
static void
|
|
print_disk(struct devconf *dc)
|
|
{
|
|
int *slavep = (int *)dc->dc_data;
|
|
|
|
printf("%s%d at %s%d drive %d",
|
|
dc->dc_name, dc->dc_unit, dc->dc_pname, dc->dc_punit, *slavep);
|
|
}
|
|
|