diff options
| author | mws <none@none> | 2005-08-27 15:17:06 -0700 | 
|---|---|---|
| committer | mws <none@none> | 2005-08-27 15:17:06 -0700 | 
| commit | 84ab085a13f931bc78e7415e7ce921dbaa14fcb3 (patch) | |
| tree | 7e11d8ecfa91e3947c8c99dbe116ae10a8e8076f /usr/src/uts/common | |
| parent | 89518a1cfe5021ecf5ad8d04c40f53cf947e95d9 (diff) | |
| download | illumos-joyent-84ab085a13f931bc78e7415e7ce921dbaa14fcb3.tar.gz | |
PSARC 2005/483 SMBIOS Support for Solaris
6313638 SMBIOS Support for Solaris
6230033 prtdiag should be implemented for Solaris x86
6313668 bmc driver should not have its own private smbios reader
6313670 post_startup_mmu_initialization() is useless and can be deleted
Diffstat (limited to 'usr/src/uts/common')
| -rw-r--r-- | usr/src/uts/common/Makefile.files | 2 | ||||
| -rw-r--r-- | usr/src/uts/common/Makefile.rules | 7 | ||||
| -rw-r--r-- | usr/src/uts/common/io/smbios.c | 331 | ||||
| -rw-r--r-- | usr/src/uts/common/io/smbios.conf | 29 | ||||
| -rw-r--r-- | usr/src/uts/common/os/smb_subr.c | 73 | ||||
| -rw-r--r-- | usr/src/uts/common/sys/Makefile | 2 | ||||
| -rw-r--r-- | usr/src/uts/common/sys/smbios.h | 1183 | ||||
| -rw-r--r-- | usr/src/uts/common/sys/smbios_impl.h | 440 | 
8 files changed, 2067 insertions, 0 deletions
| diff --git a/usr/src/uts/common/Makefile.files b/usr/src/uts/common/Makefile.files index 18603b6b5f..550b7b2ab0 100644 --- a/usr/src/uts/common/Makefile.files +++ b/usr/src/uts/common/Makefile.files @@ -1186,6 +1186,8 @@ CTF_OBJS += ctf_create.o ctf_decl.o ctf_error.o ctf_hash.o ctf_labels.o \  ZMOD_OBJS += adler32.o infblock.o infcodes.o inffast.o inflate.o inftrees.o \  		infutil.o zutil.o zmod.o +SMBIOS_OBJS += smb_error.o smb_info.o smb_open.o smb_subr.o smb_dev.o +  RPCIB_OBJS += rpcib.o  KMDB_OBJS += kdrv.o diff --git a/usr/src/uts/common/Makefile.rules b/usr/src/uts/common/Makefile.rules index 989e199b15..41090da940 100644 --- a/usr/src/uts/common/Makefile.rules +++ b/usr/src/uts/common/Makefile.rules @@ -94,6 +94,10 @@ $(OBJS_DIR)/%.o:		$(COMMONBASE)/crypto/des/%.c  	$(COMPILE.c) -o $@ $<  	$(CTFCONVERT_O) +$(OBJS_DIR)/%.o:		$(COMMONBASE)/smbios/%.c +	$(COMPILE.c) -o $@ $< +	$(CTFCONVERT_O) +  $(OBJS_DIR)/%.o:		$(UTSBASE)/common/des/%.c  	$(COMPILE.c) -o $@ $<  	$(CTFCONVERT_O) @@ -926,6 +930,9 @@ $(LINTS_DIR)/%.ln:		$(COMMONBASE)/devid/%.c  $(LINTS_DIR)/%.ln:		$(COMMONBASE)/crypto/des/%.c  	@($(LHEAD) $(LINT.c) $< $(LTAIL)) +$(LINTS_DIR)/%.ln:		$(COMMONBASE)/smbios/%.c +	@($(LHEAD) $(LINT.c) $< $(LTAIL)) +  $(LINTS_DIR)/%.ln:		$(UTSBASE)/common/des/%.c  	@($(LHEAD) $(LINT.c) $< $(LTAIL)) diff --git a/usr/src/uts/common/io/smbios.c b/usr/src/uts/common/io/smbios.c new file mode 100644 index 0000000000..533975e418 --- /dev/null +++ b/usr/src/uts/common/io/smbios.c @@ -0,0 +1,331 @@ +/* + * CDDL HEADER START + * + * The contents of this file are subject to the terms of the + * Common Development and Distribution License, Version 1.0 only + * (the "License").  You may not use this file except in compliance + * with the License. + * + * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE + * or http://www.opensolaris.org/os/licensing. + * See the License for the specific language governing permissions + * and limitations under the License. + * + * When distributing Covered Code, include this CDDL HEADER in each + * file and include the License file at usr/src/OPENSOLARIS.LICENSE. + * If applicable, add the following below this CDDL HEADER, with the + * fields enclosed by brackets "[]" replaced with your own identifying + * information: Portions Copyright [yyyy] [name of copyright owner] + * + * CDDL HEADER END + */ + +/* + * Copyright 2005 Sun Microsystems, Inc.  All rights reserved. + * Use is subject to license terms. + */ + +#pragma ident	"%Z%%M%	%I%	%E% SMI" + +/* + * smbios(7D) driver + * + * This pseudo-driver makes available a snapshot of the system's SMBIOS image + * that can be accessed using libsmbios.  Clients may access a snapshot using + * either read(2) or mmap(2).  The driver returns the SMBIOS entry point data + * followed by the SMBIOS structure table.  The entry point has its 'staddr' + * field set to indicate the byte offset of the structure table.  The driver + * uses the common SMBIOS API defined in <sys/smbios.h> to access the image. + * + * At present, the kernel takes a single snapshot of SMBIOS at boot time and + * stores a handle for this snapshot in 'ksmbios'.  To keep track of driver + * opens, we simply compare-and-swap this handle into an 'smb_clones' array. + * Future x86 systems may need to support dynamic SMBIOS updates: when that + * happens the SMBIOS API can be extended to support reference counting and + * handles for different snapshots can be stored in smb_clones[]. + */ + +#include <sys/smbios.h> +#include <sys/sysmacros.h> +#include <sys/cmn_err.h> +#include <sys/vmsystm.h> +#include <vm/seg_vn.h> +#include <sys/ddi.h> +#include <sys/sunddi.h> +#include <sys/modctl.h> +#include <sys/conf.h> +#include <sys/stat.h> + +typedef struct smb_clone { +	smbios_hdl_t *c_hdl; +	size_t c_eplen; +	size_t c_stlen; +} smb_clone_t; + +static dev_info_t *smb_devi; +static smb_clone_t *smb_clones; +static int smb_nclones; + +/*ARGSUSED*/ +static int +smb_open(dev_t *dp, int flag, int otyp, cred_t *cred) +{ +	minor_t c; + +	if (ksmbios == NULL) +		return (ENXIO); + +	/* +	 * Locate and reserve a clone structure.  We skip clone 0 as that is +	 * the real minor number, and we assign a new minor to each clone. +	 */ +	for (c = 1; c < smb_nclones; c++) { +		if (casptr(&smb_clones[c].c_hdl, NULL, ksmbios) == NULL) +			break; +	} + +	if (c >= smb_nclones) +		return (EAGAIN); + +	smb_clones[c].c_eplen = P2ROUNDUP(sizeof (smbios_entry_t), 16); +	smb_clones[c].c_stlen = smbios_buflen(smb_clones[c].c_hdl); + +	*dp = makedevice(getemajor(*dp), c); + +	(void) ddi_prop_update_int(*dp, smb_devi, "size", +	    smb_clones[c].c_eplen + smb_clones[c].c_stlen); + +	return (0); +} + +/*ARGSUSED*/ +static int +smb_close(dev_t dev, int flag, int otyp, cred_t *cred) +{ +	(void) ddi_prop_remove(dev, smb_devi, "size"); +	smb_clones[getminor(dev)].c_hdl = NULL; +	return (0); +} + +/* + * Common code to copy out the SMBIOS snapshot used for both read and mmap. + * The caller must validate uio_offset for us since semantics differ there. + * The copy is done in two stages, either of which can be skipped based on the + * offset and length: first we copy the entry point, with 'staddr' recalculated + * to indicate the offset of the data buffer, and second we copy the table. + */ +static int +smb_uiomove(smb_clone_t *cp, uio_t *uio) +{ +	off_t off = uio->uio_offset; +	size_t len = uio->uio_resid; +	int err = 0; + +	if (off + len > cp->c_eplen + cp->c_stlen) +		len = cp->c_eplen + cp->c_stlen - off; + +	if (off < cp->c_eplen) { +		smbios_entry_t *ep = kmem_zalloc(cp->c_eplen, KM_SLEEP); +		size_t eprlen = MIN(len, cp->c_eplen - off); + +		smbios_info_smbios(cp->c_hdl, ep); +		ep->smbe_staddr = (uint32_t)cp->c_eplen; +		smbios_checksum(cp->c_hdl, ep); + +		err = uiomove((char *)ep + off, eprlen, UIO_READ, uio); +		kmem_free(ep, cp->c_eplen); + +		off += eprlen; +		len -= eprlen; +	} + +	if (err == 0 && off >= cp->c_eplen) { +		char *buf = (char *)smbios_buf(cp->c_hdl); +		size_t bufoff = off - cp->c_eplen; + +		err = uiomove(buf + bufoff, +		    MIN(len, cp->c_stlen - bufoff), UIO_READ, uio); +	} + +	return (err); +} + +/*ARGSUSED*/ +static int +smb_read(dev_t dev, uio_t *uio, cred_t *cred) +{ +	smb_clone_t *cp = &smb_clones[getminor(dev)]; + +	if (uio->uio_offset < 0 || +	    uio->uio_offset >= cp->c_eplen + cp->c_stlen) +		return (0); + +	return (smb_uiomove(cp, uio)); +} + +/*ARGSUSED*/ +static int +smb_segmap(dev_t dev, off_t off, struct as *as, caddr_t *addrp, off_t len, +    uint_t prot, uint_t maxprot, uint_t flags, cred_t *cred) +{ +	smb_clone_t *cp = &smb_clones[getminor(dev)]; + +	size_t alen = P2ROUNDUP(len, PAGESIZE); +	caddr_t addr; + +	iovec_t iov; +	uio_t uio; +	int err; + +	if (len <= 0 || (flags & MAP_FIXED)) +		return (EINVAL); + +	if ((prot & PROT_WRITE) && (flags & MAP_SHARED)) +		return (EACCES); + +	if (off < 0 || off + len < off || off + len > cp->c_eplen + cp->c_stlen) +		return (ENXIO); + +	as_rangelock(as); +	map_addr(&addr, alen, 0, 1, 0); + +	if (addr != NULL) +		err = as_map(as, addr, alen, segvn_create, zfod_argsp); +	else +		err = ENOMEM; + +	as_rangeunlock(as); +	*addrp = addr; + +	if (err != 0) +		return (err); + +	iov.iov_base = addr; +	iov.iov_len = len; + +	bzero(&uio, sizeof (uio_t)); +	uio.uio_iov = &iov; +	uio.uio_iovcnt = 1; +	uio.uio_offset = off; +	uio.uio_segflg = UIO_USERSPACE; +	uio.uio_extflg = UIO_COPY_DEFAULT; +	uio.uio_resid = len; + +	if ((err = smb_uiomove(cp, &uio)) != 0) +		(void) as_unmap(as, addr, alen); + +	return (err); +} + +/*ARGSUSED*/ +static int +smb_info(dev_info_t *dip, ddi_info_cmd_t infocmd, void *arg, void **result) +{ +	switch (infocmd) { +	case DDI_INFO_DEVT2DEVINFO: +		*result = smb_devi; +		return (DDI_SUCCESS); +	case DDI_INFO_DEVT2INSTANCE: +		*result = 0; +		return (DDI_SUCCESS); +	} +	return (DDI_FAILURE); +} + +static int +smb_attach(dev_info_t *devi, ddi_attach_cmd_t cmd) +{ +	if (cmd != DDI_ATTACH) +		return (DDI_FAILURE); + +	if (ddi_create_minor_node(devi, "smbios", +	    S_IFCHR, 0, DDI_PSEUDO, 0) == DDI_FAILURE) { +		ddi_remove_minor_node(devi, NULL); +		return (DDI_FAILURE); +	} + +	smb_devi = devi; +	return (DDI_SUCCESS); +} + +static int +smb_detach(dev_info_t *devi, ddi_detach_cmd_t cmd) +{ +	if (cmd != DDI_DETACH) +		return (DDI_FAILURE); + +	ddi_remove_minor_node(devi, NULL); +	return (DDI_SUCCESS); +} + +static struct cb_ops smb_cb_ops = { +	smb_open,		/* open */ +	smb_close,		/* close */ +	nodev,			/* strategy */ +	nodev,			/* print */ +	nodev,			/* dump */ +	smb_read,		/* read */ +	nodev,			/* write */ +	nodev,			/* ioctl */ +	nodev,			/* devmap */ +	nodev,			/* mmap */ +	smb_segmap,		/* segmap */ +	nochpoll,		/* poll */ +	ddi_prop_op,		/* prop_op */ +	NULL,			/* streamtab */ +	D_NEW | D_MP		/* flags */ +}; + +static struct dev_ops smb_ops = { +	DEVO_REV,		/* rev */ +	0,			/* refcnt */ +	smb_info,		/* info */ +	nulldev,		/* identify */ +	nulldev,		/* probe */ +	smb_attach,		/* attach */ +	smb_detach,		/* detach */ +	nodev,			/* reset */ +	&smb_cb_ops,		/* cb ops */ +	NULL			/* bus ops */ +}; + +static struct modldrv modldrv = { +	&mod_driverops, "System Management BIOS driver", &smb_ops, +}; + +static struct modlinkage modlinkage = { +	MODREV_1, { (void *)&modldrv } +}; + +int +_init(void) +{ +	int err; + +	if (smb_nclones <= 0) +		smb_nclones = maxusers; + +	smb_clones = kmem_zalloc(sizeof (smb_clone_t) * smb_nclones, KM_SLEEP); + +	if ((err = mod_install(&modlinkage)) != 0) +		kmem_free(smb_clones, sizeof (smb_clone_t) * smb_nclones); + +	return (err); +} + +int +_fini(void) +{ +	int err; + +	if ((err = mod_remove(&modlinkage)) == 0) +		kmem_free(smb_clones, sizeof (smb_clone_t) * smb_nclones); + +	return (err); +} + +int +_info(struct modinfo *mip) +{ +	return (mod_info(&modlinkage, mip)); +} diff --git a/usr/src/uts/common/io/smbios.conf b/usr/src/uts/common/io/smbios.conf new file mode 100644 index 0000000000..9f6f84271a --- /dev/null +++ b/usr/src/uts/common/io/smbios.conf @@ -0,0 +1,29 @@ +# +# CDDL HEADER START +#  +# The contents of this file are subject to the terms of the +# Common Development and Distribution License, Version 1.0 only +# (the "License").  You may not use this file except in compliance +# with the License. +#  +# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE +# or http://www.opensolaris.org/os/licensing. +# See the License for the specific language governing permissions +# and limitations under the License. +#  +# When distributing Covered Code, include this CDDL HEADER in each +# file and include the License file at usr/src/OPENSOLARIS.LICENSE. +# If applicable, add the following below this CDDL HEADER, with the +# fields enclosed by brackets "[]" replaced with your own identifying +# information: Portions Copyright [yyyy] [name of copyright owner] +#  +# CDDL HEADER END +# + +# +# Copyright 2005 Sun Microsystems, Inc.  All rights reserved. +# Use is subject to license terms. +# +#ident	"%Z%%M%	%I%	%E% SMI" + +name="smbios" parent="pseudo" instance=0; diff --git a/usr/src/uts/common/os/smb_subr.c b/usr/src/uts/common/os/smb_subr.c new file mode 100644 index 0000000000..6084676b17 --- /dev/null +++ b/usr/src/uts/common/os/smb_subr.c @@ -0,0 +1,73 @@ +/* + * CDDL HEADER START + * + * The contents of this file are subject to the terms of the + * Common Development and Distribution License, Version 1.0 only + * (the "License").  You may not use this file except in compliance + * with the License. + * + * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE + * or http://www.opensolaris.org/os/licensing. + * See the License for the specific language governing permissions + * and limitations under the License. + * + * When distributing Covered Code, include this CDDL HEADER in each + * file and include the License file at usr/src/OPENSOLARIS.LICENSE. + * If applicable, add the following below this CDDL HEADER, with the + * fields enclosed by brackets "[]" replaced with your own identifying + * information: Portions Copyright [yyyy] [name of copyright owner] + * + * CDDL HEADER END + */ + +/* + * Copyright 2005 Sun Microsystems, Inc.  All rights reserved. + * Use is subject to license terms. + */ + +#pragma ident	"%Z%%M%	%I%	%E% SMI" + +#include <sys/smbios_impl.h> +#include <sys/cmn_err.h> +#include <sys/varargs.h> +#include <sys/systm.h> +#include <sys/kmem.h> + +/*ARGSUSED*/ +const char * +smb_strerror(int err) +{ +	return (NULL); +} + +void * +smb_alloc(size_t len) +{ +	return (kmem_alloc(len, KM_SLEEP)); +} + +void * +smb_zalloc(size_t len) +{ +	return (kmem_zalloc(len, KM_SLEEP)); +} + +void +smb_free(void *buf, size_t len) +{ +	kmem_free(buf, len); +} + +/*PRINTFLIKE2*/ +void +smb_dprintf(smbios_hdl_t *shp, const char *format, ...) +{ +	va_list ap; + +	if (!(shp->sh_flags & SMB_FL_DEBUG)) +		return; + +	va_start(ap, format); +	vcmn_err(CE_CONT, format, ap); +	va_end(ap); +} diff --git a/usr/src/uts/common/sys/Makefile b/usr/src/uts/common/sys/Makefile index 259ceadd6d..e0b6d579b0 100644 --- a/usr/src/uts/common/sys/Makefile +++ b/usr/src/uts/common/sys/Makefile @@ -418,6 +418,8 @@ CHKHDRS=			\  	siginfo.h		\  	signal.h		\  	sleepq.h		\ +	smbios.h		\ +	smbios_impl.h		\  	sobject.h		\  	socket.h		\  	socket_impl.h		\ diff --git a/usr/src/uts/common/sys/smbios.h b/usr/src/uts/common/sys/smbios.h new file mode 100644 index 0000000000..7333c906ea --- /dev/null +++ b/usr/src/uts/common/sys/smbios.h @@ -0,0 +1,1183 @@ +/* + * CDDL HEADER START + * + * The contents of this file are subject to the terms of the + * Common Development and Distribution License, Version 1.0 only + * (the "License").  You may not use this file except in compliance + * with the License. + * + * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE + * or http://www.opensolaris.org/os/licensing. + * See the License for the specific language governing permissions + * and limitations under the License. + * + * When distributing Covered Code, include this CDDL HEADER in each + * file and include the License file at usr/src/OPENSOLARIS.LICENSE. + * If applicable, add the following below this CDDL HEADER, with the + * fields enclosed by brackets "[]" replaced with your own identifying + * information: Portions Copyright [yyyy] [name of copyright owner] + * + * CDDL HEADER END + */ + +/* + * Copyright 2005 Sun Microsystems, Inc.  All rights reserved. + * Use is subject to license terms. + */ + +/* + * This header file defines the interfaces available from the SMBIOS access + * library, libsmbios, and an equivalent kernel module.  This API can be used + * to access DMTF SMBIOS data from a device, file, or raw memory buffer. + * This is NOT yet a public interface, although it may eventually become one in + * the fullness of time after we gain more experience with the interfaces. + * + * In the meantime, be aware that any program linked with this API in this + * release of Solaris is almost guaranteed to break in the next release. + * + * In short, do not user this header file or these routines for any purpose. + */ + +#ifndef	_SYS_SMBIOS_H +#define	_SYS_SMBIOS_H + +#pragma ident	"%Z%%M%	%I%	%E% SMI" + +#include <sys/types.h> + +#ifdef	__cplusplus +extern "C" { +#endif + +/* + * SMBIOS Structure Table Entry Point.  See DSP0134 2.1.1 for more information. + * The structure table entry point is located by searching for the anchor. + */ +typedef struct smbios_entry { +	char smbe_eanchor[4];		/* anchor tag (SMB_ENTRY_EANCHOR) */ +	uint8_t smbe_ecksum;		/* checksum of entry point structure */ +	uint8_t smbe_elen;		/* length in bytes of entry point */ +	uint8_t smbe_major;		/* major version of the SMBIOS spec */ +	uint8_t smbe_minor;		/* minor version of the SMBIOS spec */ +	uint16_t smbe_maxssize;		/* maximum size in bytes of a struct */ +	uint8_t smbe_revision;		/* entry point structure revision */ +	uint8_t smbe_format[5];		/* entry point revision-specific data */ +	char smbe_ianchor[5];		/* intermed. tag (SMB_ENTRY_IANCHOR) */ +	uint8_t smbe_icksum;		/* intermed. checksum */ +	uint16_t smbe_stlen;		/* length in bytes of structure table */ +	uint32_t smbe_staddr;		/* physical addr of structure table */ +	uint16_t smbe_stnum;		/* number of structure table entries */ +	uint8_t smbe_bcdrev;		/* BCD value representing DMI version */ +} smbios_entry_t; + +#define	SMB_ENTRY_EANCHOR	"_SM_"	/* structure table entry point anchor */ +#define	SMB_ENTRY_EANCHORLEN	4	/* length of entry point anchor */ +#define	SMB_ENTRY_IANCHOR	"_DMI_"	/* intermediate anchor string */ +#define	SMB_ENTRY_IANCHORLEN	5	/* length of intermediate anchor */ + +/* + * Structure type codes.  The comments next to each type include an (R) note to + * indicate a structure that is required as of SMBIOS v2.3 and an (O) note to + * indicate a structure that is obsolete as of SMBIOS v2.3. + */ +#define	SMB_TYPE_BIOS		0	/* BIOS information (R) */ +#define	SMB_TYPE_SYSTEM		1	/* system information (R) */ +#define	SMB_TYPE_BASEBOARD	2	/* base board */ +#define	SMB_TYPE_CHASSIS	3	/* system enclosure or chassis (R) */ +#define	SMB_TYPE_PROCESSOR	4	/* processor (R) */ +#define	SMB_TYPE_MEMCTL		5	/* memory controller (O) */ +#define	SMB_TYPE_MEMMOD		6	/* memory module (O) */ +#define	SMB_TYPE_CACHE		7	/* processor cache (R) */ +#define	SMB_TYPE_PORT		8	/* port connector */ +#define	SMB_TYPE_SLOT		9	/* upgradeable system slot (R) */ +#define	SMB_TYPE_OBDEVS		10	/* on-board devices */ +#define	SMB_TYPE_OEMSTR		11	/* OEM string table */ +#define	SMB_TYPE_SYSCONFSTR	12	/* system configuration string table */ +#define	SMB_TYPE_LANG		13	/* BIOS language information */ +#define	SMB_TYPE_GROUP		14	/* group associations */ +#define	SMB_TYPE_EVENTLOG	15	/* system event log */ +#define	SMB_TYPE_MEMARRAY	16	/* physical memory array (R) */ +#define	SMB_TYPE_MEMDEVICE	17	/* memory device (R) */ +#define	SMB_TYPE_MEMERR32	18	/* 32-bit memory error information */ +#define	SMB_TYPE_MEMARRAYMAP	19	/* memory array mapped address (R) */ +#define	SMB_TYPE_MEMDEVICEMAP	20	/* memory device mapped address (R) */ +#define	SMB_TYPE_POINTDEV	21	/* built-in pointing device */ +#define	SMB_TYPE_BATTERY	22	/* portable battery */ +#define	SMB_TYPE_RESET		23	/* system reset settings */ +#define	SMB_TYPE_SECURITY	24	/* hardware security settings */ +#define	SMB_TYPE_POWERCTL	25	/* system power controls */ +#define	SMB_TYPE_VPROBE		26	/* voltage probe */ +#define	SMB_TYPE_COOLDEV	27	/* cooling device */ +#define	SMB_TYPE_TPROBE		28	/* temperature probe */ +#define	SMB_TYPE_IPROBE		29	/* current probe */ +#define	SMB_TYPE_OOBRA		30	/* out-of-band remote access facility */ +#define	SMB_TYPE_BIS		31	/* boot integrity services */ +#define	SMB_TYPE_BOOT		32	/* system boot status (R) */ +#define	SMB_TYPE_MEMERR64	33	/* 64-bit memory error information */ +#define	SMB_TYPE_MGMTDEV	34	/* management device */ +#define	SMB_TYPE_MGMTDEVCP	35	/* management device component */ +#define	SMB_TYPE_MGMTDEVDATA	36	/* management device threshold data */ +#define	SMB_TYPE_MEMCHAN	37	/* memory channel */ +#define	SMB_TYPE_IPMIDEV	38	/* IPMI device information */ +#define	SMB_TYPE_POWERSUP	39	/* system power supply */ +#define	SMB_TYPE_INACTIVE	126	/* inactive table entry */ +#define	SMB_TYPE_EOT		127	/* end of table */ + +#define	SMB_TYPE_OEM_LO		128	/* start of OEM-specific type range */ +#define	SMB_TYPE_OEM_HI		256	/* end of OEM-specific type range */ + +/* + * SMBIOS Common Information.  These structures do not correspond to anything + * in the SMBIOS specification, but allow library clients to more easily read + * information that is frequently encoded into the various SMBIOS structures. + */ +typedef struct smbios_info { +	const char *smbi_manufacturer;	/* manufacturer */ +	const char *smbi_product;	/* product name */ +	const char *smbi_version;	/* version */ +	const char *smbi_serial;	/* serial number */ +	const char *smbi_asset;		/* asset tag */ +	const char *smbi_location;	/* location tag */ +	const char *smbi_part;		/* part number */ +} smbios_info_t; + +typedef struct smbios_version { +	uint8_t smbv_major;		/* version major number */ +	uint8_t smbv_minor;		/* version minor number */ +} smbios_version_t; + +/* + * SMBIOS Bios Information.  See DSP0134 Section 3.3.1 for more information. + * smbb_romsize is converted from the implementation format into bytes. + */ +typedef struct smbios_bios { +	const char *smbb_vendor;	/* bios vendor string */ +	const char *smbb_version;	/* bios version string */ +	const char *smbb_reldate;	/* bios release date */ +	uint32_t smbb_segment;		/* bios address segment location */ +	uint32_t smbb_romsize;		/* bios rom size in bytes */ +	uint32_t smbb_runsize;		/* bios image size in bytes */ +	uint64_t smbb_cflags;		/* bios characteristics */ +	const uint8_t *smbb_xcflags;	/* bios characteristics extensions */ +	size_t smbb_nxcflags;		/* number of smbb_xcflags[] bytes */ +	smbios_version_t smbb_biosv;	/* bios version */ +	smbios_version_t smbb_ecfwv;	/* bios embedded ctrl f/w version */ +} smbios_bios_t; + +#define	SMB_BIOSFL_RSV0		0x00000001	/* reserved bit zero */ +#define	SMB_BIOSFL_RSV1		0x00000002	/* reserved bit one */ +#define	SMB_BIOSFL_UNKNOWN	0x00000004	/* unknown */ +#define	SMB_BIOSFL_BCNOTSUP	0x00000008	/* BIOS chars not supported */ +#define	SMB_BIOSFL_ISA		0x00000010	/* ISA is supported */ +#define	SMB_BIOSFL_MCA		0x00000020	/* MCA is supported */ +#define	SMB_BIOSFL_EISA		0x00000040	/* EISA is supported */ +#define	SMB_BIOSFL_PCI		0x00000080	/* PCI is supported */ +#define	SMB_BIOSFL_PCMCIA	0x00000100	/* PCMCIA is supported */ +#define	SMB_BIOSFL_PLUGNPLAY	0x00000200	/* Plug and Play is supported */ +#define	SMB_BIOSFL_APM		0x00000400	/* APM is supported */ +#define	SMB_BIOSFL_FLASH	0x00000800	/* BIOS is Flash Upgradeable */ +#define	SMB_BIOSFL_SHADOW	0x00001000	/* BIOS shadowing is allowed */ +#define	SMB_BIOSFL_VLVESA	0x00002000	/* VL-VESA is supported */ +#define	SMB_BIOSFL_ESCD		0x00004000	/* ESCD support is available */ +#define	SMB_BIOSFL_CDBOOT	0x00008000	/* Boot from CD is supported */ +#define	SMB_BIOSFL_SELBOOT	0x00010000	/* Selectable Boot supported */ +#define	SMB_BIOSFL_ROMSOCK	0x00020000	/* BIOS ROM is socketed */ +#define	SMB_BIOSFL_PCMBOOT	0x00040000	/* Boot from PCMCIA supported */ +#define	SMB_BIOSFL_EDD		0x00080000	/* EDD Spec is supported */ +#define	SMB_BIOSFL_NEC9800	0x00100000	/* int 0x13 NEC 9800 floppy */ +#define	SMB_BIOSFL_TOSHIBA	0x00200000	/* int 0x13 Toshiba floppy */ +#define	SMB_BIOSFL_525_360K	0x00400000	/* int 0x13 5.25" 360K floppy */ +#define	SMB_BIOSFL_525_12M	0x00800000	/* int 0x13 5.25" 1.2M floppy */ +#define	SMB_BIOSFL_35_720K	0x01000000	/* int 0x13 3.5" 720K floppy */ +#define	SMB_BIOSFL_35_288M	0x02000000	/* int 0x13 3.5" 2.88M floppy */ +#define	SMB_BIOSFL_I5_PRINT	0x04000000	/* int 0x5 print screen svcs */ +#define	SMB_BIOSFL_I9_KBD	0x08000000	/* int 0x9 8042 keyboard svcs */ +#define	SMB_BIOSFL_I14_SER	0x10000000	/* int 0x14 serial svcs */ +#define	SMB_BIOSFL_I17_PRINTER	0x20000000	/* int 0x17 printer svcs */ +#define	SMB_BIOSFL_I10_CGA	0x40000000	/* int 0x10 CGA svcs */ +#define	SMB_BIOSFL_NEC_PC98	0x80000000	/* NEC PC-98 */ + +#define	SMB_BIOSXB_1		0	/* bios extension byte 1 (3.3.1.2.1) */ +#define	SMB_BIOSXB_2		1	/* bios extension byte 2 (3.3.1.2.2) */ +#define	SMB_BIOSXB_BIOS_MAJ	2	/* bios major version */ +#define	SMB_BIOSXB_BIOS_MIN	3	/* bios minor version */ +#define	SMB_BIOSXB_ECFW_MAJ	4	/* extended ctlr f/w major version */ +#define	SMB_BIOSXB_ECFW_MIN	5	/* extended ctlr f/w minor version */ + +#define	SMB_BIOSXB1_ACPI	0x01	/* ACPI is supported */ +#define	SMB_BIOSXB1_USBL	0x02	/* USB legacy is supported */ +#define	SMB_BIOSXB1_AGP		0x04	/* AGP is supported */ +#define	SMB_BIOSXB1_I20		0x08	/* I2O boot is supported */ +#define	SMB_BIOSXB1_LS120	0x10	/* LS-120 boot is supported */ +#define	SMB_BIOSXB1_ATZIP	0x20	/* ATAPI ZIP drive boot is supported */ +#define	SMB_BIOSXB1_1394	0x40	/* 1394 boot is supported */ +#define	SMB_BIOSXB1_SMBAT	0x80	/* Smart Battery is supported */ + +#define	SMB_BIOSXB2_BBOOT	0x01	/* BIOS Boot Specification supported */ +#define	SMB_BIOSXB2_FKNETSVC	0x02	/* F-key Network Svc boot supported */ +#define	SMB_BIOSXB2_ETCDIST	0x04	/* Enable Targeted Content Distrib. */ + +/* + * SMBIOS Bios Information.  See DSP0134 Section 3.3.2 for more information. + * The current set of smbs_wakeup values is defined after the structure. + */ +typedef struct smbios_system { +	const uint8_t *smbs_uuid;	/* UUID byte array */ +	uint8_t smbs_uuidlen;		/* UUID byte array length */ +	uint8_t smbs_wakeup;		/* wake-up event */ +	const char *smbs_sku;		/* SKU number */ +	const char *smbs_family;	/* family */ +} smbios_system_t; + +#define	SMB_WAKEUP_RSV0		0x00	/* reserved */ +#define	SMB_WAKEUP_OTHER	0x01	/* other */ +#define	SMB_WAKEUP_UNKNOWN	0x02	/* unknown */ +#define	SMB_WAKEUP_APM		0x03	/* APM timer */ +#define	SMB_WAKEUP_MODEM	0x04	/* modem ring */ +#define	SMB_WAKEUP_LAN		0x05	/* LAN remote */ +#define	SMB_WAKEUP_SWITCH	0x06	/* power switch */ +#define	SMB_WAKEUP_PCIPME	0x07	/* PCI PME# */ +#define	SMB_WAKEUP_AC		0x08	/* AC power restored */ + +/* + * SMBIOS Base Board description.  See DSP0134 Section 3.3.3 for more + * information.  smbb_flags and smbb_type definitions are below. + */ +typedef struct smbios_bboard { +	id_t smbb_chassis;		/* chassis containing this board */ +	uint8_t smbb_flags;		/* flags (see below) */ +	uint8_t smbb_type;		/* board type (see below) */ +} smbios_bboard_t; + +#define	SMB_BBFL_MOTHERBOARD	0x01	/* board is a motherboard */ +#define	SMB_BBFL_NEEDAUX	0x02	/* auxiliary card or daughter req'd */ +#define	SMB_BBFL_REMOVABLE	0x04	/* board is removable */ +#define	SMB_BBFL_REPLACABLE	0x08	/* board is field-replacable */ +#define	SMB_BBFL_HOTSWAP	0x10	/* board is hot-swappable */ + +#define	SMB_BBT_UNKNOWN		0x1	/* unknown */ +#define	SMB_BBT_OTHER		0x2	/* other */ +#define	SMB_BBT_SBLADE		0x3	/* server blade */ +#define	SMB_BBT_CSWITCH		0x4	/* connectivity switch */ +#define	SMB_BBT_SMM		0x5	/* system management module */ +#define	SMB_BBT_PROC		0x6	/* processor module */ +#define	SMB_BBT_IO		0x7	/* i/o module */ +#define	SMB_BBT_MEM		0x8	/* memory module */ +#define	SMB_BBT_DAUGHTER	0x9	/* daughterboard */ +#define	SMB_BBT_MOTHER		0xA	/* motherboard */ +#define	SMB_BBT_PROCMEM		0xB	/* processor/memory module */ +#define	SMB_BBT_PROCIO		0xC	/* processor/i/o module */ +#define	SMB_BBT_INTER		0xD	/* interconnect board */ + +/* + * SMBIOS Chassis description.  See DSP0134 Section 3.3.4 for more information. + * We move the lock bit of the type field into smbc_lock for easier processing. + * NOTE: We do not currently export the contained element data for each chassis + * as this seems useless: see DSP0134 3.3.4.4.  It can be added if necessary. + */ +typedef struct smbios_chassis { +	uint32_t smbc_oemdata;		/* OEM-specific data */ +	uint8_t smbc_lock;		/* lock present? */ +	uint8_t smbc_type;		/* type */ +	uint8_t smbc_bustate;		/* boot-up state */ +	uint8_t smbc_psstate;		/* power supply state */ +	uint8_t smbc_thstate;		/* thermal state */ +	uint8_t smbc_security;		/* security status */ +	uint8_t smbc_uheight;		/* enclosure height in U's */ +	uint8_t smbc_cords;		/* number of power cords */ +	uint8_t smbc_elems;		/* number of element records */ +} smbios_chassis_t; + +#define	SMB_CHT_OTHER		0x01	/* other */ +#define	SMB_CHT_UNKNOWN		0x02	/* unknown */ +#define	SMB_CHT_DESKTOP		0x03	/* desktop */ +#define	SMB_CHT_LPDESKTOP	0x04	/* low-profile desktop */ +#define	SMB_CHT_PIZZA		0x05	/* pizza box */ +#define	SMB_CHT_MINITOWER	0x06	/* mini-tower */ +#define	SMB_CHT_TOWER		0x07	/* tower */ +#define	SMB_CHT_PORTABLE	0x08	/* portable */ +#define	SMB_CHT_LAPTOP		0x09	/* laptop */ +#define	SMB_CHT_NOTEBOOK	0x0A	/* notebook */ +#define	SMB_CHT_HANDHELD	0x0B	/* hand-held */ +#define	SMB_CHT_DOCK		0x0C	/* docking station */ +#define	SMB_CHT_ALLIN1		0x0D	/* all-in-one */ +#define	SMB_CHT_SUBNOTE		0x0E	/* sub-notebook */ +#define	SMB_CHT_SPACESAVE	0x0F	/* space-saving */ +#define	SMB_CHT_LUNCHBOX	0x10	/* lunchbox */ +#define	SMB_CHT_MAIN		0x11	/* main server chassis */ +#define	SMB_CHT_EXPANSION	0x12	/* expansion chassis */ +#define	SMB_CHT_SUB		0x13	/* sub-chassis */ +#define	SMB_CHT_BUS		0x14	/* bus expansion chassis */ +#define	SMB_CHT_PERIPHERAL	0x15	/* peripheral chassis */ +#define	SMB_CHT_RAID		0x16	/* raid chassis */ +#define	SMB_CHT_RACK		0x17	/* rack mount chassis */ +#define	SMB_CHT_SEALED		0x18	/* sealed case pc */ +#define	SMB_CHT_MULTI		0x19	/* multi-system chassis */ + +#define	SMB_CHST_OTHER		0x01	/* other */ +#define	SMB_CHST_UNKNOWN	0x02	/* unknown */ +#define	SMB_CHST_SAFE		0x03	/* safe */ +#define	SMB_CHST_WARNING	0x04	/* warning */ +#define	SMB_CHST_CRITICAL	0x05	/* critical */ +#define	SMB_CHST_NONREC		0x06	/* non-recoverable */ + +#define	SMB_CHSC_OTHER		0x01	/* other */ +#define	SMB_CHSC_UNKNOWN	0x02	/* unknown */ +#define	SMB_CHSC_NONE		0x03	/* none */ +#define	SMB_CHSC_EILOCK		0x04	/* external interface locked out */ +#define	SMB_CHSC_EIENAB		0x05	/* external interface enabled */ + +/* + * SMBIOS Processor description.  See DSP0134 Section 3.3.5 for more details. + * If the L1, L2, or L3 cache handle is -1, the cache information is unknown. + * If the handle refers to something of size 0, that type of cache is absent. + * + * NOTE: Although SMBIOS exports a 64-bit CPUID result, this value should not + * be used for any purpose other than BIOS debugging.  Solaris itself computes + * its own CPUID value and applies knowledge of additional errata and processor + * specific CPUID variations, so this value should not be used for anything. + */ +typedef struct smbios_processor { +	uint64_t smbp_cpuid;		/* processor cpuid information */ +	uint32_t smbp_family;		/* processor family */ +	uint8_t smbp_type;		/* processor type (SMB_PRT_*) */ +	uint8_t smbp_voltage;		/* voltage (SMB_PRV_*) */ +	uint8_t smbp_status;		/* status (SMB_PRS_*) */ +	uint8_t smbp_upgrade;		/* upgrade (SMB_PRU_*) */ +	uint32_t smbp_clkspeed;		/* external clock speed in MHz */ +	uint32_t smbp_maxspeed;		/* maximum speed in MHz */ +	uint32_t smbp_curspeed;		/* current speed in MHz */ +	id_t smbp_l1cache;		/* L1 cache handle */ +	id_t smbp_l2cache;		/* L2 cache handle */ +	id_t smbp_l3cache;		/* L3 cache handle */ +} smbios_processor_t; + +#define	SMB_PRT_OTHER		0x01	/* other */ +#define	SMB_PRT_UNKNOWN		0x02	/* unknown */ +#define	SMB_PRT_CENTRAL		0x03	/* central processor */ +#define	SMB_PRT_MATH		0x04	/* math processor */ +#define	SMB_PRT_DSP		0x05	/* DSP processor */ +#define	SMB_PRT_VIDEO		0x06	/* video processor */ + +#define	SMB_PRV_LEGACY(v)	(!((v) & 0x80))	/* legacy voltage mode */ +#define	SMB_PRV_FIXED(v)	((v) & 0x80)	/* fixed voltage mode */ + +#define	SMB_PRV_5V		0x01	/* 5V is supported */ +#define	SMB_PRV_33V		0x02	/* 3.3V is supported */ +#define	SMB_PRV_29V		0x04	/* 2.9V is supported */ + +#define	SMB_PRV_VOLTAGE(v)	((v) & 0x7f) + +#define	SMB_PRSTATUS_PRESENT(s)	((s) & 0x40)	/* socket is populated */ +#define	SMB_PRSTATUS_STATUS(s)	((s) & 0x07)	/* status (see below) */ + +#define	SMB_PRS_UNKNOWN		0x0	/* unknown */ +#define	SMB_PRS_ENABLED		0x1	/* enabled */ +#define	SMB_PRS_BDISABLED	0x2	/* disabled in bios user setup */ +#define	SMB_PRS_PDISABLED	0x3	/* disabled in bios from post error */ +#define	SMB_PRS_IDLE		0x4	/* waiting to be enabled */ +#define	SMB_PRS_OTHER		0x7	/* other */ + +#define	SMB_PRU_OTHER		0x01	/* other */ +#define	SMB_PRU_UNKNOWN		0x02	/* unknown */ +#define	SMB_PRU_DAUGHTER	0x03	/* daughter board */ +#define	SMB_PRU_ZIF		0x04	/* ZIF socket */ +#define	SMB_PRU_PIGGY		0x05	/* replaceable piggy back */ +#define	SMB_PRU_NONE		0x06	/* none */ +#define	SMB_PRU_LIF		0x07	/* LIF socket */ +#define	SMB_PRU_SLOT1		0x08	/* slot 1 */ +#define	SMB_PRU_SLOT2		0x09	/* slot 2 */ +#define	SMB_PRU_370PIN		0x0A	/* 370-pin socket */ +#define	SMB_PRU_SLOTA		0x0B	/* slot A */ +#define	SMB_PRU_SLOTM		0x0C	/* slot M */ +#define	SMB_PRU_423		0x0D	/* socket 423 */ +#define	SMB_PRU_A		0x0E	/* socket A (socket 462) */ +#define	SMB_PRU_478		0x0F	/* socket 478 */ +#define	SMB_PRU_754		0x10	/* socket 754 */ +#define	SMB_PRU_940		0x11	/* socket 940 */ + +#define	SMB_PRF_OTHER		0x01	/* other */ +#define	SMB_PRF_UNKNOWN		0x02	/* unknown */ +#define	SMB_PRF_8086		0x03	/* 8086 */ +#define	SMB_PRF_80286		0x04	/* 80286 */ +#define	SMB_PRF_I386		0x05	/* Intel 386 */ +#define	SMB_PRF_I486		0x06	/* Intel 486 */ +#define	SMB_PRF_8087		0x07	/* 8087 */ +#define	SMB_PRF_80287		0x08	/* 80287 */ +#define	SMB_PRF_80387		0x09	/* 80387 */ +#define	SMB_PRF_80487		0x0A	/* 80487 */ +#define	SMB_PRF_PENTIUM		0x0B	/* Pentium Family */ +#define	SMB_PRF_PENTIUMPRO	0x0C	/* Pentium Pro */ +#define	SMB_PRF_PENTIUMII	0x0D	/* Pentium II */ +#define	SMB_PRF_PENTIUM_MMX	0x0E	/* Pentium w/ MMX */ +#define	SMB_PRF_CELERON		0x0F	/* Celeron */ +#define	SMB_PRF_PENTIUMII_XEON	0x10	/* Pentium II Xeon */ +#define	SMB_PRF_PENTIUMIII	0x11	/* Pentium III */ +#define	SMB_PRF_M1		0x12	/* M1 */ +#define	SMB_PRF_M2		0x13	/* M2 */ +#define	SMB_PRF_DURON		0x18	/* AMD Duron */ +#define	SMB_PRF_K5		0x19	/* K5 */ +#define	SMB_PRF_K6		0x1A	/* K6 */ +#define	SMB_PRF_K6_2		0x1B	/* K6-2 */ +#define	SMB_PRF_K6_3		0x1C	/* K6-3 */ +#define	SMB_PRF_ATHLON		0x1D	/* Athlon */ +#define	SMB_PRF_2900		0x1E	/* AMD 2900 */ +#define	SMB_PRF_K6_2PLUS	0x1F	/* K6-2+ */ +#define	SMB_PRF_PPC		0x20	/* PowerPC */ +#define	SMB_PRF_PPC_601		0x21	/* PowerPC 601 */ +#define	SMB_PRF_PPC_603		0x22	/* PowerPC 603 */ +#define	SMB_PRF_PPC_603PLUS	0x23	/* PowerPC 603+ */ +#define	SMB_PRF_PPC_604		0x24	/* PowerPC 604 */ +#define	SMB_PRF_PPC_620		0x25	/* PowerPC 620 */ +#define	SMB_PRF_PPC_704		0x26	/* PowerPC x704 */ +#define	SMB_PRF_PPC_750		0x27	/* PowerPC 750 */ +#define	SMB_PRF_ALPHA		0x30	/* Alpha */ +#define	SMB_PRF_ALPHA_21064	0x31	/* Alpha 21064 */ +#define	SMB_PRF_ALPHA_21066	0x32	/* Alpha 21066 */ +#define	SMB_PRF_ALPHA_21164	0x33	/* Alpha 21164 */ +#define	SMB_PRF_ALPHA_21164PC	0x34	/* Alpha 21164PC */ +#define	SMB_PRF_ALPHA_21164A	0x35	/* Alpha 21164a */ +#define	SMB_PRF_ALPHA_21264	0x36	/* Alpha 21264 */ +#define	SMB_PRF_ALPHA_21364	0x37	/* Alpha 21364 */ +#define	SMB_PRF_MIPS		0x40	/* MIPS */ +#define	SMB_PRF_MIPS_R4000	0x41	/* MIPS R4000 */ +#define	SMB_PRF_MIPS_R4200	0x42	/* MIPS R4200 */ +#define	SMB_PRF_MIPS_R4400	0x43	/* MIPS R4400 */ +#define	SMB_PRF_MIPS_R4600	0x44	/* MIPS R4600 */ +#define	SMB_PRF_MIPS_R10000	0x45	/* MIPS R10000 */ +#define	SMB_PRF_SPARC		0x50	/* SPARC */ +#define	SMB_PRF_SUPERSPARC	0x51	/* SuperSPARC */ +#define	SMB_PRF_MICROSPARCII	0x52	/* microSPARC II */ +#define	SMB_PRF_MICROSPARCIIep	0x53	/* microSPARC IIep */ +#define	SMB_PRF_ULTRASPARC	0x54	/* UltraSPARC */ +#define	SMB_PRF_USII		0x55	/* UltraSPARC II */ +#define	SMB_PRF_USIIi		0x56	/* UltraSPARC IIi */ +#define	SMB_PRF_USIII		0x57	/* UltraSPARC III */ +#define	SMB_PRF_USIIIi		0x58	/* UltraSPARC IIIi */ +#define	SMB_PRF_68040		0x60	/* 68040 */ +#define	SMB_PRF_68XXX		0x61	/* 68XXX */ +#define	SMB_PRF_68000		0x62	/* 68000 */ +#define	SMB_PRF_68010		0x63	/* 68010 */ +#define	SMB_PRF_68020		0x64	/* 68020 */ +#define	SMB_PRF_68030		0x65	/* 68030 */ +#define	SMB_PRF_HOBBIT		0x70	/* Hobbit */ +#define	SMB_PRF_TM5000		0x78	/* Crusoe TM5000 */ +#define	SMB_PRF_TM3000		0x79	/* Crusoe TM3000 */ +#define	SMB_PRF_TM8000		0x7A	/* Efficeon TM8000 */ +#define	SMB_PRF_WEITEK		0x80	/* Weitek */ +#define	SMB_PRF_ITANIC		0x82	/* Itanium */ +#define	SMB_PRF_ATHLON64	0x83	/* Athlon64 */ +#define	SMB_PRF_OPTERON		0x84	/* Opteron */ +#define	SMB_PRF_PA		0x90	/* PA-RISC */ +#define	SMB_PRF_PA8500		0x91	/* PA-RISC 8500 */ +#define	SMB_PRF_PA8000		0x92	/* PA-RISC 8000 */ +#define	SMB_PRF_PA7300LC	0x93	/* PA-RISC 7300LC */ +#define	SMB_PRF_PA7200		0x94	/* PA-RISC 7200 */ +#define	SMB_PRF_PA7100LC	0x95	/* PA-RISC 7100LC */ +#define	SMB_PRF_PA7100		0x96	/* PA-RISC 7100 */ +#define	SMB_PRF_V30		0xA0	/* V30 */ +#define	SMB_PRF_PENTIUMIII_XEON	0xB0	/* Pentium III Xeon */ +#define	SMB_PRF_PENTIUMIII_SS	0xB1	/* Pentium III with SpeedStep */ +#define	SMB_PRF_P4		0xB2	/* Pentium 4 */ +#define	SMB_PRF_XEON		0xB3	/* Intel Xeon */ +#define	SMB_PRF_AS400		0xB4	/* AS400 */ +#define	SMB_PRF_XEON_MP		0xB5	/* Intel Xeon MP */ +#define	SMB_PRF_ATHLON_XP	0xB6	/* AMD Athlon XP */ +#define	SMB_PRF_ATHLON_MP	0xB7	/* AMB Athlon MP */ +#define	SMB_PRF_ITANIC2		0xB8	/* Itanium 2 */ +#define	SMB_PRF_PENTIUM_M	0xB9	/* Pentium M */ +#define	SMB_PRF_IBM390		0xC8	/* IBM 390 */ +#define	SMB_PRF_G4		0xC9	/* G4 */ +#define	SMB_PRF_G5		0xCA	/* G5 */ +#define	SMB_PRF_I860		0xFA	/* i860 */ +#define	SMB_PRF_I960		0xFB	/* i960 */ + +/* + * SMBIOS Cache Information.  See DSP0134 Section 3.3.8 for more information. + * If smba_size is zero, this indicates the specified cache is not present. + */ +typedef struct smbios_cache { +	uint32_t smba_maxsize;		/* maximum installed size in bytes */ +	uint32_t smba_size;		/* installed size in bytes */ +	uint16_t smba_stype;		/* supported SRAM types (SMB_CAT_*) */ +	uint16_t smba_ctype;		/* current SRAM type (SMB_CAT_*) */ +	uint8_t smba_speed;		/* speed in nanoseconds */ +	uint8_t smba_etype;		/* error correction type (SMB_CAE_*) */ +	uint8_t smba_ltype;		/* logical cache type (SMB_CAG_*) */ +	uint8_t smba_assoc;		/* associativity (SMB_CAA_*) */ +	uint8_t smba_level;		/* cache level */ +	uint8_t smba_mode;		/* cache mode (SMB_CAM_*) */ +	uint8_t smba_location;		/* cache location (SMB_CAL_*) */ +	uint8_t smba_flags;		/* cache flags (SMB_CAF_*) */ +} smbios_cache_t; + +#define	SMB_CAT_OTHER		0x0001		/* other */ +#define	SMB_CAT_UNKNOWN		0x0002		/* unknown */ +#define	SMB_CAT_NONBURST	0x0004		/* non-burst */ +#define	SMB_CAT_BURST		0x0008		/* burst */ +#define	SMB_CAT_PBURST		0x0010		/* pipeline burst */ +#define	SMB_CAT_SYNC		0x0020		/* synchronous */ +#define	SMB_CAT_ASYNC		0x0040		/* asynchronous */ + +#define	SMB_CAE_OTHER		0x01		/* other */ +#define	SMB_CAE_UNKNOWN		0x02		/* unknown */ +#define	SMB_CAE_NONE		0x03		/* none */ +#define	SMB_CAE_PARITY		0x04		/* parity */ +#define	SMB_CAE_SBECC		0x05		/* single-bit ECC */ +#define	SMB_CAE_MBECC		0x06		/* multi-bit ECC */ + +#define	SMB_CAG_OTHER		0x01		/* other */ +#define	SMB_CAG_UNKNOWN		0x02		/* unknown */ +#define	SMB_CAG_INSTR		0x03		/* instruction */ +#define	SMB_CAG_DATA		0x04		/* data */ +#define	SMB_CAG_UNIFIED		0x05		/* unified */ + +#define	SMB_CAA_OTHER		0x01		/* other */ +#define	SMB_CAA_UNKNOWN		0x02		/* unknown */ +#define	SMB_CAA_DIRECT		0x03		/* direct mapped */ +#define	SMB_CAA_2WAY		0x04		/* 2-way set associative */ +#define	SMB_CAA_4WAY		0x05		/* 4-way set associative */ +#define	SMB_CAA_FULL		0x06		/* fully associative */ +#define	SMB_CAA_8WAY		0x07		/* 8-way set associative */ +#define	SMB_CAA_16WAY		0x08		/* 16-way set associative */ + +#define	SMB_CAM_WT		0x00		/* write-through */ +#define	SMB_CAM_WB		0x01		/* write-back */ +#define	SMB_CAM_VARY		0x02		/* varies by address */ +#define	SMB_CAM_UNKNOWN		0x03		/* unknown */ + +#define	SMB_CAL_INTERNAL	0x00		/* internal */ +#define	SMB_CAL_EXTERNAL	0x01		/* external */ +#define	SMB_CAL_RESERVED	0x02		/* reserved */ +#define	SMB_CAL_UNKNOWN		0x03		/* unknown */ + +#define	SMB_CAF_ENABLED		0x01		/* enabled at boot time */ +#define	SMB_CAF_SOCKETED	0x02		/* cache is socketed */ + +/* + * SMBIOS Port Information.  See DSP0134 Section 3.3.9 for more information. + * The internal reference designator string is also mapped to the location. + */ +typedef struct smbios_port { +	const char *smbo_iref;	/* internal reference designator */ +	const char *smbo_eref;	/* external reference designator */ +	uint8_t smbo_itype;	/* internal connector type (SMB_POC_*) */ +	uint8_t smbo_etype;	/* external connector type (SMB_POC_*) */ +	uint8_t smbo_ptype;	/* port type (SMB_POT_*) */ +	uint8_t smbo_pad;	/* padding */ +} smbios_port_t; + +#define	SMB_POC_NONE		0x00		/* none */ +#define	SMB_POC_CENT		0x01		/* Centronics */ +#define	SMB_POC_MINICENT	0x02		/* Mini-Centronics */ +#define	SMB_POC_PROPRIETARY	0x03		/* proprietary */ +#define	SMB_POC_DB25M		0x04		/* DB-25 pin male */ +#define	SMB_POC_DB25F		0x05		/* DB-25 pin female */ +#define	SMB_POC_DB15M		0x06		/* DB-15 pin male */ +#define	SMB_POC_DB15F		0x07		/* DB-15 pin female */ +#define	SMB_POC_DB9M		0x08		/* DB-9 pin male */ +#define	SMB_POC_DB9F		0x09		/* DB-9 pin female */ +#define	SMB_POC_RJ11		0x0A		/* RJ-11 */ +#define	SMB_POC_RJ45		0x0B		/* RJ-45 */ +#define	SMB_POC_MINISCSI	0x0C		/* 50-pin MiniSCSI */ +#define	SMB_POC_MINIDIN		0x0D		/* Mini-DIN */ +#define	SMB_POC_MICRODIN	0x0E		/* Micro-DIN */ +#define	SMB_POC_PS2		0x0F		/* PS/2 */ +#define	SMB_POC_IR		0x10		/* Infrared */ +#define	SMB_POC_HPHIL		0x11		/* HP-HIL */ +#define	SMB_POC_USB		0x12		/* USB */ +#define	SMB_POC_SSA		0x13		/* SSA SCSI */ +#define	SMB_POC_DIN8M		0x14		/* Circular DIN-8 male */ +#define	SMB_POC_DIN8F		0x15		/* Circular DIN-8 female */ +#define	SMB_POC_OBIDE		0x16		/* on-board IDE */ +#define	SMB_POC_OBFLOPPY	0x17		/* on-board floppy */ +#define	SMB_POC_DI9		0x18		/* 9p dual inline (p10 cut) */ +#define	SMB_POC_DI25		0x19		/* 25p dual inline (p26 cut) */ +#define	SMB_POC_DI50		0x1A		/* 50p dual inline */ +#define	SMB_POC_DI68		0x1B		/* 68p dual inline */ +#define	SMB_POC_CDROM		0x1C		/* on-board sound from CDROM */ +#define	SMB_POC_MINI14		0x1D		/* Mini-Centronics Type 14 */ +#define	SMB_POC_MINI26		0x1E		/* Mini-Centronics Type 26 */ +#define	SMB_POC_MINIJACK	0x1F		/* Mini-jack (headphones) */ +#define	SMB_POC_BNC		0x20		/* BNC */ +#define	SMB_POC_1394		0x21		/* 1394 */ +#define	SMB_POC_PC98		0xA0		/* PC-98 */ +#define	SMB_POC_PC98HR		0xA1		/* PC-98Hireso */ +#define	SMB_POC_PCH98		0xA2		/* PC-H98 */ +#define	SMB_POC_PC98NOTE	0xA3		/* PC-98Note */ +#define	SMB_POC_PC98FULL	0xA4		/* PC-98Full */ +#define	SMB_POC_OTHER		0xFF		/* other */ + +#define	SMB_POT_NONE		0x00		/* none */ +#define	SMB_POT_PP_XTAT		0x01		/* Parallel Port XT/AT compat */ +#define	SMB_POT_PP_PS2		0x02		/* Parallel Port PS/2 */ +#define	SMB_POT_PP_ECP		0x03		/* Parallel Port ECP */ +#define	SMB_POT_PP_EPP		0x04		/* Parallel Port EPP */ +#define	SMB_POT_PP_ECPEPP	0x05		/* Parallel Port ECP/EPP */ +#define	SMB_POT_SP_XTAT		0x06		/* Serial Port XT/AT compat */ +#define	SMB_POT_SP_16450	0x07		/* Serial Port 16450 compat */ +#define	SMB_POT_SP_16550	0x08		/* Serial Port 16550 compat */ +#define	SMB_POT_SP_16550A	0x09		/* Serial Port 16550A compat */ +#define	SMB_POT_SCSI		0x0A		/* SCSI port */ +#define	SMB_POT_MIDI		0x0B		/* MIDI port */ +#define	SMB_POT_JOYSTICK	0x0C		/* Joystick port */ +#define	SMB_POT_KEYBOARD	0x0D		/* Keyboard port */ +#define	SMB_POT_MOUSE		0x0E		/* Mouse port */ +#define	SMB_POT_SSA		0x0F		/* SSA SCSI */ +#define	SMB_POT_USB		0x10		/* USB */ +#define	SMB_POT_FIREWIRE	0x11		/* FireWrite (IEEE P1394) */ +#define	SMB_POT_PCMII		0x12		/* PCMCIA Type II */ +#define	SMB_POT_PCMIIa		0x13		/* PCMCIA Type II (alternate) */ +#define	SMB_POT_PCMIII		0x14		/* PCMCIA Type III */ +#define	SMB_POT_CARDBUS		0x15		/* Cardbus */ +#define	SMB_POT_ACCESS		0x16		/* Access Bus Port */ +#define	SMB_POT_SCSI2		0x17		/* SCSI II */ +#define	SMB_POT_SCSIW		0x18		/* SCSI Wide */ +#define	SMB_POT_PC98		0x19		/* PC-98 */ +#define	SMB_POT_PC98HR		0x1A		/* PC-98Hireso */ +#define	SMB_POT_PCH98		0x1B		/* PC-H98 */ +#define	SMB_POT_VIDEO		0x1C		/* Video port */ +#define	SMB_POT_AUDIO		0x1D		/* Audio port */ +#define	SMB_POT_MODEM		0x1E		/* Modem port */ +#define	SMB_POT_NETWORK		0x1F		/* Network port */ +#define	SMB_POT_8251		0xA0		/* 8251 compatible */ +#define	SMB_POT_8251F		0xA1		/* 8251 FIFO compatible */ +#define	SMB_POT_OTHER		0xFF		/* other */ + +/* + * SMBIOS Slot Information.  See DSP0134 Section 3.3.10 for more information. + * See DSP0134 3.3.10.5 for how to interpret the value of smbl_id. + */ +typedef struct smbios_slot { +	const char *smbl_name;		/* reference designation */ +	uint8_t smbl_type;		/* slot type */ +	uint8_t smbl_width;		/* slot data bus width */ +	uint8_t smbl_usage;		/* current usage */ +	uint8_t smbl_length;		/* slot length */ +	uint16_t smbl_id;		/* slot ID */ +	uint8_t smbl_ch1;		/* slot characteristics 1 */ +	uint8_t smbl_ch2;		/* slot characteristics 2 */ +} smbios_slot_t; + +#define	SMB_SLT_OTHER		0x01	/* other */ +#define	SMB_SLT_UNKNOWN		0x02	/* unknown */ +#define	SMB_SLT_ISA		0x03	/* ISA */ +#define	SMB_SLT_MCA		0x04	/* MCA */ +#define	SMB_SLT_EISA		0x05	/* EISA */ +#define	SMB_SLT_PCI		0x06	/* PCI */ +#define	SMB_SLT_PCMCIA		0x07	/* PCMCIA */ +#define	SMB_SLT_VLVESA		0x08	/* VL-VESA */ +#define	SMB_SLT_PROPRIETARY	0x09	/* proprietary */ +#define	SMB_SLT_PROC		0x0A	/* processor card slot */ +#define	SMB_SLT_MEM		0x0B	/* proprietary memory card slot */ +#define	SMB_SLT_IOR		0x0C	/* I/O riser card slot */ +#define	SMB_SLT_NUBUS		0x0D	/* NuBus */ +#define	SMB_SLT_PCI66		0x0E	/* PCI (66MHz capable) */ +#define	SMB_SLT_AGP		0x0F	/* AGP */ +#define	SMB_SLT_AGP2X		0x10	/* AGP 2X */ +#define	SMB_SLT_AGP4X		0x11	/* AGP 4X */ +#define	SMB_SLT_PCIX		0x12	/* PCI-X */ +#define	SMB_SLT_AGP8X		0x13	/* AGP 8X */ +#define	SMB_SLT_PC98_C20	0xA0	/* PC-98/C20 */ +#define	SMB_SLT_PC98_C24	0xA1	/* PC-98/C24 */ +#define	SMB_SLT_PC98_E		0xA2	/* PC-98/E */ +#define	SMB_SLT_PC98_LB		0xA3	/* PC-98/Local Bus */ +#define	SMB_SLT_PC98_C		0xA4	/* PC-98/Card */ +#define	SMB_SLT_PCIE		0xA5	/* PCI Express */ + +#define	SMB_SLW_OTHER		0x01	/* other */ +#define	SMB_SLW_UNKNOWN		0x02	/* unknown */ +#define	SMB_SLW_8		0x03	/* 8 bit */ +#define	SMB_SLW_16		0x04	/* 16 bit */ +#define	SMB_SLW_32		0x05	/* 32 bit */ +#define	SMB_SLW_64		0x06	/* 64 bit */ +#define	SMB_SLW_128		0x07	/* 128 bit */ +#define	SMB_SLW_1X		0x08	/* 1x or x1 */ +#define	SMB_SLW_2X		0x09	/* 2x or x2 */ +#define	SMB_SLW_4X		0x0A	/* 4x or x4 */ +#define	SMB_SLW_8X		0x0B	/* 8x or x8 */ +#define	SMB_SLW_12X		0x0C	/* 12x or x12 */ +#define	SMB_SLW_16X		0x0D	/* 16x or x16 */ +#define	SMB_SLW_32X		0x0E	/* 32x or x32 */ + +#define	SMB_SLU_OTHER		0x01	/* other */ +#define	SMB_SLU_UNKNOWN		0x02	/* unknown */ +#define	SMB_SLU_AVAIL		0x03	/* available */ +#define	SMB_SLU_INUSE		0x04	/* in use */ + +#define	SMB_SLL_OTHER		0x01	/* other */ +#define	SMB_SLL_UNKNOWN		0x02	/* unknown */ +#define	SMB_SLL_SHORT		0x03	/* short length */ +#define	SMB_SLL_LONG		0x04	/* long length */ + +#define	SMB_SLCH1_UNKNOWN	0x01	/* characteristics unknown */ +#define	SMB_SLCH1_5V		0x02	/* provides 5.0V */ +#define	SMB_SLCH1_33V		0x04	/* provides 3.3V */ +#define	SMB_SLCH1_SHARED	0x08	/* opening shared with other slot */ +#define	SMB_SLCH1_PC16		0x10	/* slot supports PC Card-16 */ +#define	SMB_SLCH1_PCCB		0x20	/* slot supports CardBus */ +#define	SMB_SLCH1_PCZV		0x40	/* slot supports Zoom Video */ +#define	SMB_SLCH1_PCMRR		0x80	/* slot supports Modem Ring Resume */ + +#define	SMB_SLCH2_PME		0x01	/* slot supports PME# signal */ +#define	SMB_SLCH2_HOTPLUG	0x02	/* slot supports hot-plug devices */ +#define	SMB_SLCH2_SMBUS		0x04	/* slot supports SMBus signal */ + +/* + * SMBIOS On-Board Device Information.  See DSP0134 Section 3.3.11 for more + * information.  Any number of on-board device sections may be present, each + * containing one or more records.  The smbios_info_obdevs() function permits + * the caller to retrieve one or more of the records from a given section. + */ +typedef struct smbios_obdev { +	const char *smbd_name;		/* description string for this device */ +	uint8_t smbd_type;		/* type code (SMB_OBT_*) */ +	uint8_t smbd_enabled;		/* boolean (device is enabled) */ +} smbios_obdev_t; + +#define	SMB_OBT_OTHER		0x01	/* other */ +#define	SMB_OBT_UNKNOWN		0x02	/* unknown */ +#define	SMB_OBT_VIDEO		0x03	/* video */ +#define	SMB_OBT_SCSI		0x04	/* scsi */ +#define	SMB_OBT_ETHERNET	0x05	/* ethernet */ +#define	SMB_OBT_TOKEN		0x06	/* token ring */ +#define	SMB_OBT_SOUND		0x07	/* sound */ + +/* + * SMBIOS BIOS Language Information.  See DSP0134 Section 3.3.14 for more + * information.  The smbios_info_strtab() function can be applied using a + * count of smbla_num to retrieve the other possible language settings. + */ +typedef struct smbios_lang { +	const char *smbla_cur;		/* current language setting */ +	uint_t smbla_fmt;		/* language name format (see below) */ +	uint_t smbla_num;		/* number of installed languages */ +} smbios_lang_t; + +#define	SMB_LFMT_LONG	0		/* <ISO639>|<ISO3166>|Encoding Method */ +#define	SMB_LFMT_SHORT	1		/* <ISO930><ISO3166> */ + +/* + * SMBIOS System Event Log Information.  See DSP0134 Section 3.3.16 for more + * information.  Accessing the event log itself requires additional interfaces. + */ +typedef struct smbios_evtype { +	uint8_t smbevt_ltype;		/* log type */ +	uint8_t smbevt_dtype;		/* variable data format type */ +} smbios_evtype_t; + +typedef struct smbios_evlog { +	size_t smbev_size;		/* size in bytes of log area */ +	size_t smbev_hdr;		/* offset or index of header */ +	size_t smbev_data;		/* offset or index of data */ +	uint8_t smbev_method;		/* data access method (see below) */ +	uint8_t smbev_flags;		/* flags (see below) */ +	uint8_t smbev_format;		/* log header format (see below) */ +	uint8_t smbev_pad;		/* padding */ +	uint32_t smbev_token;		/* data update change token */ +	union { +		struct { +			uint16_t evi_iaddr; /* index address */ +			uint16_t evi_daddr; /* data address */ +		} eva_io;		/* i/o address for SMB_EVM_XxY */ +		uint32_t eva_addr;	/* address for SMB_EVM_MEM32 */ +		uint16_t eva_gpnv;	/* handle for SMB_EVM_GPNV */ +	} smbev_addr; +	uint32_t smbev_typec;		/* number of type descriptors */ +	const smbios_evtype_t *smbev_typev; /* type descriptor array */ +} smbios_evlog_t; + +#define	SMB_EVM_1x1i_1x1d	0	/* I/O: 1 1b idx port, 1 1b data port */ +#define	SMB_EVM_2x1i_1x1d	1	/* I/O: 2 1b idx port, 1 1b data port */ +#define	SMB_EVM_1x2i_1x1d	2	/* I/O: 1 2b idx port, 1 1b data port */ +#define	SMB_EVM_MEM32		3	/* Memory-Mapped 32-bit Physical Addr */ +#define	SMB_EVM_GPNV		4	/* GP Non-Volatile API Access */ + +#define	SMB_EVFL_VALID		0x1	/* log area valid */ +#define	SMB_EVFL_FULL		0x2	/* log area full */ + +#define	SMB_EVHF_NONE		0	/* no log headers used */ +#define	SMB_EVHF_F1		1	/* DMTF log header type 1 */ + +/* + * SMBIOS Physical Memory Array Information.  See DSP0134 Section 3.3.17 for + * more information.  This describes a collection of physical memory devices. + */ +typedef struct smbios_memarray { +	uint8_t smbma_location;		/* physical device location */ +	uint8_t smbma_use;		/* physical device functional purpose */ +	uint8_t smbma_ecc;		/* error detect/correct mechanism */ +	uint8_t smbma_pad0;		/* padding */ +	uint32_t smbma_pad1;		/* padding */ +	uint32_t smbma_ndevs;		/* number of slots or sockets */ +	id_t smbma_err;			/* handle of error (if any) */ +	uint64_t smbma_size;		/* maximum capacity in bytes */ +} smbios_memarray_t; + +#define	SMB_MAL_OTHER		0x01	/* other */ +#define	SMB_MAL_UNKNOWN		0x02	/* unknown */ +#define	SMB_MAL_SYSMB		0x03	/* system board or motherboard */ +#define	SMB_MAL_ISA		0x04	/* ISA add-on card */ +#define	SMB_MAL_EISA		0x05	/* EISA add-on card */ +#define	SMB_MAL_PCI		0x06	/* PCI add-on card */ +#define	SMB_MAL_MCA		0x07	/* MCA add-on card */ +#define	SMB_MAL_PCMCIA		0x08	/* PCMCIA add-on card */ +#define	SMB_MAL_PROP		0x09	/* proprietary add-on card */ +#define	SMB_MAL_NUBUS		0x0A	/* NuBus */ +#define	SMB_MAL_PC98C20		0xA0	/* PC-98/C20 add-on card */ +#define	SMB_MAL_PC98C24		0xA1	/* PC-98/C24 add-on card */ +#define	SMB_MAL_PC98E		0xA2	/* PC-98/E add-on card */ +#define	SMB_MAL_PC98LB		0xA3	/* PC-98/Local bus add-on card */ + +#define	SMB_MAU_OTHER		0x01	/* other */ +#define	SMB_MAU_UNKNOWN		0x02	/* unknown */ +#define	SMB_MAU_SYSTEM		0x03	/* system memory */ +#define	SMB_MAU_VIDEO		0x04	/* video memory */ +#define	SMB_MAU_FLASH		0x05	/* flash memory */ +#define	SMB_MAU_NVRAM		0x06	/* non-volatile RAM */ +#define	SMB_MAU_CACHE		0x07	/* cache memory */ + +#define	SMB_MAE_OTHER		0x01	/* other */ +#define	SMB_MAE_UNKNOWN		0x02	/* unknown */ +#define	SMB_MAE_NONE		0x03	/* none */ +#define	SMB_MAE_PARITY		0x04	/* parity */ +#define	SMB_MAE_SECC		0x05	/* single-bit ECC */ +#define	SMB_MAE_MECC		0x06	/* multi-bit ECC */ +#define	SMB_MAE_CRC		0x07	/* CRC */ + +/* + * SMBIOS Memory Device Information.  See DSP0134 Section 3.3.18 for more + * information.  One or more of these structures are associated with each + * smbios_memarray_t.  A structure is present even for unpopulated sockets. + * Unknown values are set to -1.  A smbmd_size of 0 indicates unpopulated. + * WARNING: Some BIOSes appear to export the *maximum* size of the device + * that can appear in the corresponding socket as opposed to the current one. + */ +typedef struct smbios_memdevice { +	id_t smbmd_array;		/* handle of physical memory array */ +	id_t smbmd_error;		/* handle of memory error data */ +	uint32_t smbmd_twidth;		/* total width in bits including ecc */ +	uint32_t smbmd_dwidth;		/* data width in bits */ +	uint64_t smbmd_size;		/* size in bytes (see note above) */ +	uint8_t smbmd_form;		/* form factor */ +	uint8_t smbmd_set;		/* set (0x00=none, 0xFF=unknown) */ +	uint8_t smbmd_type;		/* memory type */ +	uint8_t smbmd_pad;		/* padding */ +	uint32_t smbmd_flags;		/* flags (see below) */ +	uint32_t smbmd_speed;		/* speed in nanoseconds */ +	const char *smbmd_dloc;		/* physical device locator string */ +	const char *smbmd_bloc;		/* physical bank locator string */ +} smbios_memdevice_t; + +#define	SMB_MDFF_OTHER		0x01	/* other */ +#define	SMB_MDFF_UNKNOWN	0x02	/* unknown */ +#define	SMB_MDFF_SIMM		0x03	/* SIMM */ +#define	SMB_MDFF_SIP		0x04	/* SIP */ +#define	SMB_MDFF_CHIP		0x05	/* chip */ +#define	SMB_MDFF_DIP		0x06	/* DIP */ +#define	SMB_MDFF_ZIP		0x07	/* ZIP */ +#define	SMB_MDFF_PROP		0x08	/* proprietary card */ +#define	SMB_MDFF_DIMM		0x09	/* DIMM */ +#define	SMB_MDFF_TSOP		0x0A	/* TSOP */ +#define	SMB_MDFF_CHIPROW	0x0B	/* row of chips */ +#define	SMB_MDFF_RIMM		0x0C	/* RIMM */ +#define	SMB_MDFF_SODIMM		0x0D	/* SODIMM */ +#define	SMB_MDFF_SRIMM		0x0E	/* SRIMM */ + +#define	SMB_MDT_OTHER		0x01	/* other */ +#define	SMB_MDT_UNKNOWN		0x02	/* unknown */ +#define	SMB_MDT_DRAM		0x03	/* DRAM */ +#define	SMB_MDT_EDRAM		0x04	/* EDRAM */ +#define	SMB_MDT_VRAM		0x05	/* VRAM */ +#define	SMB_MDT_SRAM		0x06	/* SRAM */ +#define	SMB_MDT_RAM		0x07	/* RAM */ +#define	SMB_MDT_ROM		0x08	/* ROM */ +#define	SMB_MDT_FLASH		0x09	/* FLASH */ +#define	SMB_MDT_EEPROM		0x0A	/* EEPROM */ +#define	SMB_MDT_FEPROM		0x0B	/* FEPROM */ +#define	SMB_MDT_EPROM		0x0C	/* EPROM */ +#define	SMB_MDT_CDRAM		0x0D	/* CDRAM */ +#define	SMB_MDT_3DRAM		0x0E	/* 3DRAM */ +#define	SMB_MDT_SDRAM		0x0F	/* SDRAM */ +#define	SMB_MDT_SGRAM		0x10	/* SGRAM */ +#define	SMB_MDT_RDRAM		0x11	/* RDRAM */ +#define	SMB_MDT_DDR		0x12	/* DDR */ +#define	SMB_MDT_DDR2		0x13	/* DDR2 */ + +#define	SMB_MDF_OTHER		0x0002	/* other */ +#define	SMB_MDF_UNKNOWN		0x0004	/* unknown */ +#define	SMB_MDF_FASTPG		0x0008	/* fast-paged */ +#define	SMB_MDF_STATIC		0x0010	/* static column */ +#define	SMB_MDF_PSTATIC		0x0020	/* pseudo-static */ +#define	SMB_MDF_RAMBUS		0x0040	/* RAMBUS */ +#define	SMB_MDF_SYNC		0x0080	/* synchronous */ +#define	SMB_MDF_CMOS		0x0100	/* CMOS */ +#define	SMB_MDF_EDO		0x0200	/* EDO */ +#define	SMB_MDF_WDRAM		0x0400	/* Window DRAM */ +#define	SMB_MDF_CDRAM		0x0800	/* Cache DRAM */ +#define	SMB_MDF_NV		0x1000	/* non-volatile */ + +/* + * SMBIOS Memory Array Mapped Address.  See DSP0134 Section 3.3.20 for more + * information.  We convert start/end addresses into addr/size for convenience. + */ +typedef struct smbios_memarrmap { +	id_t smbmam_array;		/* physical memory array handle */ +	uint32_t smbmam_width;		/* number of devices that form a row */ +	uint64_t smbmam_addr;		/* physical address of mapping */ +	uint64_t smbmam_size;		/* size in bytes of address range */ +} smbios_memarrmap_t; + +/* + * SMBIOS Memory Device Mapped Address.  See DSP0134 Section 3.3.21 for more + * information.  We convert start/end addresses into addr/size for convenience. + */ +typedef struct smbios_memdevmap { +	id_t smbmdm_device;		/* memory device handle */ +	id_t smbmdm_arrmap;		/* memory array mapped address handle */ +	uint64_t smbmdm_addr;		/* physical address of mapping */ +	uint64_t smbmdm_size;		/* size in bytes of address range */ +	uint8_t smbmdm_rpos;		/* partition row position */ +	uint8_t smbmdm_ipos;		/* interleave position */ +	uint8_t smbmdm_idepth;		/* interleave data depth */ +} smbios_memdevmap_t; + +/* + * SMBIOS Hardware Security Settings.  See DSP0134 Section 3.3.25 for more + * information.  Only one such record will be present in the SMBIOS. + */ +typedef struct smbios_hwsec { +	uint8_t smbh_pwr_ps;		/* power-on password status */ +	uint8_t smbh_kbd_ps;		/* keyboard password status */ +	uint8_t smbh_adm_ps;		/* administrator password status */ +	uint8_t smbh_pan_ps;		/* front panel reset status */ +} smbios_hwsec_t; + +#define	SMB_HWSEC_PS_DISABLED	0x00	/* password disabled */ +#define	SMB_HWSEC_PS_ENABLED	0x01	/* password enabled */ +#define	SMB_HWSEC_PS_NOTIMPL	0x02	/* password not implemented */ +#define	SMB_HWSEC_PS_UNKNOWN	0x03	/* password status unknown */ + +/* + * SMBIOS System Boot Information.  See DSP0134 Section 3.3.33 for more + * information.  The contents of the data varies by type and is undocumented + * from the perspective of DSP0134 -- it seems to be left as vendor-specific. + * The (D) annotation next to SMB_BOOT_* below indicates possible data payload. + */ +typedef struct smbios_boot { +	uint8_t smbt_status;		/* boot status code (see below) */ +	const void *smbt_data;		/* data buffer specific to status */ +	size_t smbt_size;		/* size of smbt_data buffer in bytes */ +} smbios_boot_t; + +#define	SMB_BOOT_NORMAL		0	/* no errors detected */ +#define	SMB_BOOT_NOMEDIA	1	/* no bootable media */ +#define	SMB_BOOT_OSFAIL		2	/* normal o/s failed to load */ +#define	SMB_BOOT_FWHWFAIL	3	/* firmware-detected hardware failure */ +#define	SMB_BOOT_OSHWFAIL	4	/* o/s-detected hardware failure */ +#define	SMB_BOOT_USERREQ	5	/* user-requested boot (keystroke) */ +#define	SMB_BOOT_SECURITY	6	/* system security violation */ +#define	SMB_BOOT_PREVREQ	7	/* previously requested image (D) */ +#define	SMB_BOOT_WATCHDOG	8	/* watchdog initiated reboot */ +#define	SMB_BOOT_RESV_LO	9	/* low end of reserved range */ +#define	SMB_BOOT_RESV_HI	127	/* high end of reserved range */ +#define	SMB_BOOT_OEM_LO		128	/* low end of OEM-specific range */ +#define	SMB_BOOT_OEM_HI		191	/* high end of OEM-specific range */ +#define	SMB_BOOT_PROD_LO	192	/* low end of product-specific range */ +#define	SMB_BOOT_PROD_HI	255	/* high end of product-specific range */ + +/* + * SMBIOS IPMI Device Information.  See DSP0134 Section 3.3.39 and also + * Appendix C1 of the IPMI specification for more information on this record. + */ +typedef struct smbios_ipmi { +	uint_t smbip_type;		/* BMC interface type */ +	smbios_version_t smbip_vers;	/* BMC's IPMI specification version */ +	uint32_t smbip_i2c;		/* BMC I2C bus slave address */ +	uint32_t smbip_bus;		/* bus ID of NV storage device, or -1 */ +	uint64_t smbip_addr;		/* BMC base address */ +	uint32_t smbip_flags;		/* flags (see below) */ +	uint16_t smbip_intr;		/* interrupt number (or zero if none) */ +	uint16_t smbip_regspacing;	/* i/o space register spacing (bytes) */ +} smbios_ipmi_t; + +#define	SMB_IPMI_T_UNKNOWN	0x00	/* unknown */ +#define	SMB_IPMI_T_KCS		0x01	/* KCS: Keyboard Controller Style */ +#define	SMB_IPMI_T_SMIC		0x02	/* SMIC: Server Mgmt Interface Chip */ +#define	SMB_IPMI_T_BT		0x03	/* BT: Block Transfer */ +#define	SMB_IPMI_T_SSIF		0x04	/* SSIF: SMBus System Interface */ + +#define	SMB_IPMI_F_IOADDR	0x01	/* base address is in i/o space */ +#define	SMB_IPMI_F_INTRSPEC	0x02	/* intr information is specified */ +#define	SMB_IPMI_F_INTRHIGH	0x04	/* intr active high (else low) */ +#define	SMB_IPMI_F_INTREDGE	0x08	/* intr is edge triggered (else lvl) */ + +/* + * SMBIOS Interfaces.  An SMBIOS image can be opened by either providing a file + * pathname, device pathname, file descriptor, or raw memory buffer.  Once an + * image is opened the functions below can be used to iterate over the various + * structures and convert the underlying data representation into the simpler + * data structures described earlier in this header file.  The SMB_VERSION + * constant specified when opening an image indicates the version of the ABI + * the caller expects and the DMTF SMBIOS version the client can understand. + * The library will then map older or newer data structures to that as needed. + */ + +#define	SMB_VERSION_23	0x0203		/* SMBIOS encoding for DMTF spec 2.3 */ +#define	SMB_VERSION_24	0x0204		/* SMBIOS encoding for DMTF spec 2.4 */ +#define	SMB_VERSION	SMB_VERSION_24	/* SMBIOS latest version definitions */ + +#define	SMB_O_NOCKSUM	0x1		/* do not verify header checksums */ +#define	SMB_O_NOVERS	0x2		/* do not verify header versions */ +#define	SMB_O_ZIDS	0x4		/* strip out identification numbers */ +#define	SMB_O_MASK	0x7		/* mask of valid smbios_*open flags */ + +#define	SMB_ID_NOTSUP	0xFFFE		/* structure is not supported by BIOS */ +#define	SMB_ID_NONE	0xFFFF		/* structure is a null reference */ + +#define	SMB_ERR		(-1)		/* id_t value indicating error */ + +typedef struct smbios_hdl smbios_hdl_t; + +typedef struct smbios_struct { +	id_t smbstr_id;			/* structure ID handle */ +	uint_t smbstr_type;		/* structure type */ +	const void *smbstr_data;	/* structure data */ +	size_t smbstr_size;		/* structure size */ +} smbios_struct_t; + +typedef int smbios_struct_f(smbios_hdl_t *, +    const smbios_struct_t *, void *); + +extern smbios_hdl_t *smbios_open(const char *, int, int, int *); +extern smbios_hdl_t *smbios_fdopen(int, int, int, int *); +extern smbios_hdl_t *smbios_bufopen(const smbios_entry_t *, +    const void *, size_t, int, int, int *); + +extern const void *smbios_buf(smbios_hdl_t *); +extern size_t smbios_buflen(smbios_hdl_t *); + +extern void smbios_checksum(smbios_hdl_t *, smbios_entry_t *); +extern int smbios_write(smbios_hdl_t *, int); +extern void smbios_close(smbios_hdl_t *); + +extern int smbios_errno(smbios_hdl_t *); +extern const char *smbios_errmsg(int); + +extern int smbios_lookup_id(smbios_hdl_t *, id_t, smbios_struct_t *); +extern int smbios_iter(smbios_hdl_t *, smbios_struct_f *, void *); + +extern void smbios_info_smbios(smbios_hdl_t *, smbios_entry_t *); +extern int smbios_info_common(smbios_hdl_t *, id_t, smbios_info_t *); +extern id_t smbios_info_bios(smbios_hdl_t *, smbios_bios_t *); +extern id_t smbios_info_system(smbios_hdl_t *, smbios_system_t *); +extern int smbios_info_bboard(smbios_hdl_t *, id_t, smbios_bboard_t *); +extern int smbios_info_chassis(smbios_hdl_t *, id_t, smbios_chassis_t *); +extern int smbios_info_processor(smbios_hdl_t *, id_t, smbios_processor_t *); +extern int smbios_info_cache(smbios_hdl_t *, id_t, smbios_cache_t *); +extern int smbios_info_port(smbios_hdl_t *, id_t, smbios_port_t *); +extern int smbios_info_slot(smbios_hdl_t *, id_t, smbios_slot_t *); +extern int smbios_info_obdevs(smbios_hdl_t *, id_t, int, smbios_obdev_t *); +extern int smbios_info_strtab(smbios_hdl_t *, id_t, int, const char *[]); +extern id_t smbios_info_lang(smbios_hdl_t *, smbios_lang_t *); +extern id_t smbios_info_eventlog(smbios_hdl_t *, smbios_evlog_t *); +extern int smbios_info_memarray(smbios_hdl_t *, id_t, smbios_memarray_t *); +extern int smbios_info_memarrmap(smbios_hdl_t *, id_t, smbios_memarrmap_t *); +extern int smbios_info_memdevice(smbios_hdl_t *, id_t, smbios_memdevice_t *); +extern int smbios_info_memdevmap(smbios_hdl_t *, id_t, smbios_memdevmap_t *); +extern id_t smbios_info_hwsec(smbios_hdl_t *, smbios_hwsec_t *); +extern id_t smbios_info_boot(smbios_hdl_t *, smbios_boot_t *); +extern id_t smbios_info_ipmi(smbios_hdl_t *, smbios_ipmi_t *); + +#ifndef _KERNEL +/* + * The smbios_*_desc() and smbios_*_name() interfaces can be used for utilities + * such as smbios(1M) that wish to decode SMBIOS fields for humans.  The _desc + * functions return the comment string next to the #defines listed above, and + * the _name functions return the appropriate #define identifier itself. + */ +extern const char *smbios_bboard_flag_desc(uint_t); +extern const char *smbios_bboard_flag_name(uint_t); +extern const char *smbios_bboard_type_desc(uint_t); + +extern const char *smbios_bios_flag_desc(uint64_t); +extern const char *smbios_bios_flag_name(uint64_t); + +extern const char *smbios_bios_xb1_desc(uint_t); +extern const char *smbios_bios_xb1_name(uint_t); +extern const char *smbios_bios_xb2_desc(uint_t); +extern const char *smbios_bios_xb2_name(uint_t); + +extern const char *smbios_boot_desc(uint_t); + +extern const char *smbios_cache_assoc_desc(uint_t); +extern const char *smbios_cache_ctype_desc(uint_t); +extern const char *smbios_cache_ctype_name(uint_t); +extern const char *smbios_cache_ecc_desc(uint_t); +extern const char *smbios_cache_flag_desc(uint_t); +extern const char *smbios_cache_flag_name(uint_t); +extern const char *smbios_cache_loc_desc(uint_t); +extern const char *smbios_cache_logical_desc(uint_t); +extern const char *smbios_cache_mode_desc(uint_t); + +extern const char *smbios_chassis_state_desc(uint_t); +extern const char *smbios_chassis_type_desc(uint_t); + +extern const char *smbios_evlog_flag_desc(uint_t); +extern const char *smbios_evlog_flag_name(uint_t); +extern const char *smbios_evlog_format_desc(uint_t); +extern const char *smbios_evlog_method_desc(uint_t); + +extern const char *smbios_ipmi_flag_name(uint_t); +extern const char *smbios_ipmi_flag_desc(uint_t); +extern const char *smbios_ipmi_type_desc(uint_t); + +extern const char *smbios_hwsec_desc(uint_t); + +extern const char *smbios_memarray_loc_desc(uint_t); +extern const char *smbios_memarray_use_desc(uint_t); +extern const char *smbios_memarray_ecc_desc(uint_t); + +extern const char *smbios_memdevice_form_desc(uint_t); +extern const char *smbios_memdevice_type_desc(uint_t); +extern const char *smbios_memdevice_flag_name(uint_t); +extern const char *smbios_memdevice_flag_desc(uint_t); + +extern const char *smbios_port_conn_desc(uint_t); +extern const char *smbios_port_type_desc(uint_t); + +extern const char *smbios_processor_family_desc(uint_t); +extern const char *smbios_processor_status_desc(uint_t); +extern const char *smbios_processor_type_desc(uint_t); +extern const char *smbios_processor_upgrade_desc(uint_t); + +extern const char *smbios_slot_type_desc(uint_t); +extern const char *smbios_slot_width_desc(uint_t); +extern const char *smbios_slot_usage_desc(uint_t); +extern const char *smbios_slot_length_desc(uint_t); +extern const char *smbios_slot_ch1_desc(uint_t); +extern const char *smbios_slot_ch1_name(uint_t); +extern const char *smbios_slot_ch2_desc(uint_t); +extern const char *smbios_slot_ch2_name(uint_t); + +extern const char *smbios_type_desc(uint_t); +extern const char *smbios_type_name(uint_t); + +extern const char *smbios_system_wakeup_desc(uint_t); +#endif /* !_KERNEL */ + +#ifdef _KERNEL +/* + * For SMBIOS clients within the kernel itself, ksmbios is used to refer to + * the kernel's current snapshot of the SMBIOS, if one exists, and the + * ksmbios_flags tunable is the set of flags for use with smbios_open(). + */ +extern smbios_hdl_t *ksmbios; +extern int ksmbios_flags; +#endif /* _KERNEL */ + +#ifdef	__cplusplus +} +#endif + +#endif	/* _SYS_SMBIOS_H */ diff --git a/usr/src/uts/common/sys/smbios_impl.h b/usr/src/uts/common/sys/smbios_impl.h new file mode 100644 index 0000000000..2db36fd51d --- /dev/null +++ b/usr/src/uts/common/sys/smbios_impl.h @@ -0,0 +1,440 @@ +/* + * CDDL HEADER START + * + * The contents of this file are subject to the terms of the + * Common Development and Distribution License, Version 1.0 only + * (the "License").  You may not use this file except in compliance + * with the License. + * + * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE + * or http://www.opensolaris.org/os/licensing. + * See the License for the specific language governing permissions + * and limitations under the License. + * + * When distributing Covered Code, include this CDDL HEADER in each + * file and include the License file at usr/src/OPENSOLARIS.LICENSE. + * If applicable, add the following below this CDDL HEADER, with the + * fields enclosed by brackets "[]" replaced with your own identifying + * information: Portions Copyright [yyyy] [name of copyright owner] + * + * CDDL HEADER END + */ + +/* + * Copyright 2005 Sun Microsystems, Inc.  All rights reserved. + * Use is subject to license terms. + */ + +/* + * This header file defines the implementation structures for the SMBIOS access + * library, libsmbios, and an equivalent kernel module.  Clients should use + * the <smbios.h> or <sys/smbios.h> header files to access DMTF SMBIOS + * information, NOT these underlying implementation structures from the spec. + * In short, do not user this header file or these routines for any purpose. + */ + +#ifndef	_SYS_SMBIOS_IMPL_H +#define	_SYS_SMBIOS_IMPL_H + +#pragma ident	"%Z%%M%	%I%	%E% SMI" + +#include <sys/smbios.h> +#include <sys/sysmacros.h> + +#ifdef _KERNEL +#include <sys/systm.h> +#else +#include <strings.h> +#include <stddef.h> +#endif + +#ifdef	__cplusplus +extern "C" { +#endif + +#pragma pack(1) + +typedef struct smb_header { +	uint8_t smbh_type;		/* structure type (SMB_TYPE_* value) */ +	uint8_t smbh_len;		/* length in bytes of formatted area */ +	uint16_t smbh_hdl;		/* structure handle */ +} smb_header_t; + +typedef struct smb_bios { +	smb_header_t smbbi_hdr;		/* structure header */ +	uint8_t smbbi_vendor;		/* bios vendor string */ +	uint8_t smbbi_version;		/* bios version string */ +	uint16_t smbbi_segment;		/* segment location of bios address */ +	uint8_t smbbi_reldate;		/* bios release date */ +	uint8_t smbbi_romsize;		/* bios rom size (64k * (n + 1)) */ +	uint64_t smbbi_cflags;		/* bios characteristics */ +	uint8_t smbbi_xcflags[1];	/* bios characteristics extensions */ +} smb_bios_t; + +typedef struct smb_system { +	smb_header_t smbsi_hdr;		/* structure header */ +	uint8_t smbsi_manufacturer;	/* manufacturer */ +	uint8_t smbsi_product;		/* product name */ +	uint8_t smbsi_version;		/* version */ +	uint8_t smbsi_serial;		/* serial number */ +	uint8_t smbsi_uuid[16];		/* UUID */ +	uint8_t smbsi_wakeup;		/* wake-up type */ +	uint8_t smbsi_sku;		/* SKU number */ +	uint8_t smbsi_family;		/* family */ +} smb_system_t; + +typedef struct smb_bboard { +	smb_header_t smbbb_hdr;		/* structure header */ +	uint8_t smbbb_manufacturer;	/* manufacturer */ +	uint8_t smbbb_product;		/* product name */ +	uint8_t smbbb_version;		/* version */ +	uint8_t smbbb_serial;		/* serial number */ +	uint8_t smbbb_asset;		/* asset tag */ +	uint8_t smbbb_flags;		/* feature flags */ +	uint8_t smbbb_location;		/* location in chassis */ +	uint16_t smbbb_chassis;		/* chassis handle */ +	uint8_t smbbb_type;		/* board type */ +	uint8_t smbbb_cn;		/* number of contained handles */ +	uint16_t smbbb_cv[1];		/* array of contained handles */ +} smb_bboard_t; + +typedef struct smb_chassis { +	smb_header_t smbch_hdr;		/* structure header */ +	uint8_t smbch_manufacturer;	/* manufacturer */ +	uint8_t smbch_type;		/* type */ +	uint8_t smbch_version;		/* version */ +	uint8_t smbch_serial;		/* serial number */ +	uint8_t smbch_asset;		/* asset tag */ +	uint8_t smbch_bustate;		/* boot-up state */ +	uint8_t smbch_psstate;		/* power supply state */ +	uint8_t smbch_thstate;		/* thermal state */ +	uint8_t smbch_security;		/* security state */ +	uint32_t smbch_oemdata;		/* OEM-specific data */ +	uint8_t smbch_uheight;		/* enclosure height */ +	uint8_t smbch_cords;		/* number of power cords */ +	uint8_t smbch_cn;		/* number of contained records */ +	uint8_t smbch_cm;		/* size of contained records */ +	uint8_t smbch_cv[1];		/* array of contained records */ +} smb_chassis_t; + +#define	SMB_CHT_LOCK	0x80		/* lock bit within smbch_type */ + +typedef struct smb_processor { +	smb_header_t smbpr_hdr;		/* structure header */ +	uint8_t smbpr_socket;		/* socket designation */ +	uint8_t smbpr_type;		/* processor type (see <smbios.h>) */ +	uint8_t smbpr_family;		/* processor family (see <smbios.h>) */ +	uint8_t smbpr_manufacturer;	/* manufacturer */ +	uint64_t smbpr_cpuid;		/* processor cpuid information */ +	uint8_t smbpr_version;		/* version */ +	uint8_t smbpr_voltage;		/* voltage */ +	uint16_t smbpr_clkspeed;	/* external clock speed in MHz */ +	uint16_t smbpr_maxspeed;	/* maximum speed in MHz */ +	uint16_t smbpr_curspeed;	/* current speed in MHz */ +	uint8_t smbpr_status;		/* status (see <smbios.h>) */ +	uint8_t smbpr_upgrade;		/* upgrade */ +	uint16_t smbpr_l1cache;		/* L1 cache handle (if any) */ +	uint16_t smbpr_l2cache;		/* L2 cache handle (if any) */ +	uint16_t smbpr_l3cache;		/* L3 cache handle (if any) */ +	uint8_t smbpr_serial;		/* serial number */ +	uint8_t smbpr_asset;		/* asset tag */ +	uint8_t smbpr_part;		/* part number */ +} smb_processor_t; + +typedef struct smb_cache { +	smb_header_t smbca_hdr;		/* structure header */ +	uint8_t smbca_socket;		/* socket designation */ +	uint16_t smbca_config;		/* cache configuration */ +	uint16_t smbca_maxsize;		/* maximum installed size */ +	uint16_t smbca_size;		/* installed size */ +	uint16_t smbca_stype;		/* supported SRAM type */ +	uint16_t smbca_ctype;		/* current SRAM type */ +	uint8_t smbca_speed;		/* speed in nanoseconds */ +	uint8_t smbca_etype;		/* error correction type */ +	uint8_t smbca_ltype;		/* logical cache type */ +	uint8_t smbca_assoc;		/* associativity */ +} smb_cache_t; + +#define	SMB_CACHE_SIZE(s)	\ +	(((s) & 0x8000) ? (((s) & 0x7FFF) << 1) : (s)) + +#define	SMB_CACHE_CFG_MODE(c)		(((c) >> 8) & 3) +#define	SMB_CACHE_CFG_ENABLED(c)	(((c) >> 7) & 1) +#define	SMB_CACHE_CFG_LOCATION(c)	(((c) >> 5) & 3) +#define	SMB_CACHE_CFG_SOCKETED(c)	(((c) >> 3) & 1) +#define	SMB_CACHE_CFG_LEVEL(c)		(((c) & 7) + 1) + +typedef struct smb_port { +	smb_header_t smbpo_hdr;		/* structure header */ +	uint8_t smbpo_iref;		/* internal reference designator */ +	uint8_t smbpo_itype;		/* internal connector type */ +	uint8_t smbpo_eref;		/* external reference designator */ +	uint8_t smbpo_etype;		/* external connector type */ +	uint8_t smbpo_ptype;		/* port type */ +} smb_port_t; + +typedef struct smb_slot { +	smb_header_t smbsl_hdr;		/* structure header */ +	uint8_t smbsl_name;		/* reference designation */ +	uint8_t smbsl_type;		/* slot type */ +	uint8_t smbsl_width;		/* slot data bus width */ +	uint8_t smbsl_usage;		/* current usage */ +	uint8_t smbsl_length;		/* slot length */ +	uint16_t smbsl_id;		/* slot ID */ +	uint8_t smbsl_ch1;		/* slot characteristics 1 */ +	uint8_t smbsl_ch2;		/* slot characteristics 2 */ +} smb_slot_t; + +typedef struct smb_obdev { +	uint8_t smbob_type;		/* encoded type and enable bit */ +	uint8_t smbob_name;		/* descriptiong string */ +} smb_obdev_t; + +#define	SMB_OBT_ENABLED		0x80	/* enable bit within smbob_type */ + +typedef struct smb_strtab { +	smb_header_t smbtb_hdr;		/* structure header */ +	uint8_t smbtb_count;		/* number of strings */ +} smb_strtab_t; + +typedef struct smb_lang { +	smb_header_t smblang_hdr;	/* structure header */ +	uint8_t smblang_num;		/* number of installed languages */ +	uint8_t smblang_flags;		/* flags */ +	uint8_t smblang_resv[15];	/* reserved for future use */ +	uint8_t smblang_cur;		/* current language string */ +} smb_lang_t; + +typedef struct smb_sel { +	smb_header_t smbsel_hdr;	/* structure header */ +	uint16_t smbsel_len;		/* log area length */ +	uint16_t smbsel_hdroff;		/* header offset */ +	uint16_t smbsel_dataoff;	/* data offset */ +	uint8_t smbsel_method;		/* access method */ +	uint8_t smbsel_status;		/* status flags */ +	uint32_t smbsel_token;		/* change token */ +	uint32_t smbsel_addr;		/* access method address */ +	uint8_t smbsel_format;		/* header format */ +	uint8_t smbsel_typec;		/* number of type descriptors */ +	uint8_t smbsel_typesz;		/* size of each type descriptor */ +	uint8_t smbsel_typev[1];	/* array of type descriptors */ +} smb_sel_t; + +typedef struct smb_memarray { +	smb_header_t smbmarr_hdr;	/* structure header */ +	uint8_t smbmarr_loc;		/* location */ +	uint8_t smbmarr_use;		/* use */ +	uint8_t smbmarr_ecc;		/* error detect/correct mechanism */ +	uint32_t smbmarr_cap;		/* maximum capacity */ +	uint16_t smbmarr_err;		/* error handle */ +	uint16_t smbmarr_ndevs;		/* number of slots or sockets */ +} smb_memarray_t; + +typedef struct smb_memarrmap { +	smb_header_t smbamap_hdr;	/* structure header */ +	uint32_t smbamap_start;		/* starting address in kilobytes */ +	uint32_t smbamap_end;		/* ending address in kilobytes */ +	uint16_t smbamap_array;		/* physical memory array handle */ +	uint8_t smbamap_width;		/* partition width */ +} smb_memarrmap_t; + +typedef struct smb_memdevice { +	smb_header_t smbmdev_hdr;	/* structure header */ +	uint16_t smbmdev_array;		/* array handle */ +	uint16_t smbmdev_error;		/* error handle */ +	uint16_t smbmdev_twidth;	/* total width */ +	uint16_t smbmdev_dwidth;	/* data width */ +	uint16_t smbmdev_size;		/* size in either K or MB */ +	uint8_t smbmdev_form;		/* form factor */ +	uint8_t smbmdev_set;		/* device set */ +	uint8_t smbmdev_dloc;		/* device locator */ +	uint8_t smbmdev_bloc;		/* bank locator */ +	uint8_t smbmdev_type;		/* memory type */ +	uint16_t smbmdev_flags;		/* detail flags */ +	uint16_t smbmdev_speed;		/* speed in MHz */ +	uint8_t smbmdev_manufacturer;	/* manufacturer */ +	uint8_t smbmdev_serial;		/* serial number */ +	uint8_t smbmdev_asset;		/* asset tag */ +	uint8_t smbmdev_part;		/* part number */ +} smb_memdevice_t; + +#define	SMB_MDS_KBYTES		0x8000	/* size in specified in kilobytes */ + +typedef struct smb_memdevmap { +	smb_header_t smbdmap_hdr;	/* structure header */ +	uint32_t smbdmap_start;		/* starting address in kilobytes */ +	uint32_t smbdmap_end;		/* ending address in kilobytes */ +	uint16_t smbdmap_device;	/* memory device handle */ +	uint16_t smbdmap_array;		/* memory array mapped address handle */ +	uint8_t smbdmap_rpos;		/* row position */ +	uint8_t smbdmap_ipos;		/* interleave position */ +	uint8_t smbdmap_idepth;		/* interleave depth */ +} smb_memdevmap_t; + +typedef struct smb_battery { +	smb_header_t smbbat_hdr;	/* structure header */ +	uint8_t smbbat_loc;		/* location */ +	uint8_t smbbat_manufacturer;	/* manufacturer */ +	uint8_t smbbat_date;		/* manufacture date */ +	uint8_t smbbat_serial;		/* serial number */ +	uint8_t smbbat_devname;		/* device name */ +	uint8_t smbbat_chem;		/* device chemistry */ +	uint16_t smbbat_cap;		/* design capacity in mW hours */ +	uint16_t smbbat_volt;		/* design voltage in mV */ +	uint8_t smbbat_version;		/* SBDS version string */ +	uint8_t smbbat_err;		/* error percentage */ +	uint16_t smbbat_ssn;		/* SBDS serial number */ +	uint16_t smbbat_sdate;		/* SBDS manufacture date */ +	uint8_t smbbat_schem;		/* SBDS chemistry string */ +	uint8_t smbbat_mult;		/* design capacity multiplier */ +	uint32_t smbbat_oemdata;	/* OEM-specific data */ +} smb_battery_t; + +typedef struct smb_hwsec { +	smb_header_t smbhs_hdr;		/* structure header */ +	uint8_t smbhs_settings;		/* settings byte */ +} smb_hwsec_t; + +#define	SMB_HWS_PWR_PS(x)	(((x) & 0xC0) >> 6) +#define	SMB_HWS_KBD_PS(x)	(((x) & 0x30) >> 4) +#define	SMB_HWS_ADM_PS(x)	(((x) & 0x0C) >> 2) +#define	SMB_HWS_PAN_PS(x)	(((x) & 0x03) >> 0) + +typedef struct smb_boot { +	smb_header_t smbbo_hdr;		/* structure header */ +	uint8_t smbbo_pad[6];		/* reserved for future use */ +	uint8_t smbbo_status[1];	/* variable-length status buffer */ +} smb_boot_t; + +typedef struct smb_ipmi { +	smb_header_t smbipm_hdr;	/* structure header */ +	uint8_t smbipm_type;		/* interface type */ +	uint8_t smbipm_spec;		/* specification revision */ +	uint8_t smbipm_i2c;		/* i2C slave address */ +	uint8_t smbipm_bus;		/* NV storage device bus ID */ +	uint64_t smbipm_addr;		/* base address */ +	uint8_t smbipm_info;		/* base address modifier/intr info */ +	uint8_t smbipm_intr;		/* interrupt number */ +} smb_ipmi_t; + +#define	SMB_IPM_SPEC_MAJOR(x)	(((x) & 0xF0) >> 4) +#define	SMB_IPM_SPEC_MINOR(x)	((x) & 0x0F) + +#define	SMB_IPM_ADDR_IO		1ULL + +#define	SMB_IPM_INFO_REGS(x)	(((x) & 0xC0) >> 6) +#define	SMB_IPM_INFO_LSB(x)	(((x) & 0x10) >> 4) +#define	SMB_IPM_INFO_ISPEC(x)	(((x) & 0x08) >> 3) +#define	SMB_IPM_INFO_IPOL(x)	(((x) & 0x02) >> 1) +#define	SMB_IPM_INFO_IMODE(x)	(((x) & 0x01) >> 0) + +#define	SMB_IPM_REGS_1B		0 +#define	SMB_IPM_REGS_4B		1 +#define	SMB_IPM_REGS_16B	2 + +#define	SMB_IPM_IPOL_LO		0 +#define	SMB_IPM_IPOL_HI		1 + +#define	SMB_IPM_IMODE_EDGE	0 +#define	SMB_IPM_IMODE_LEVEL	1 + +typedef struct smb_powersup { +	smb_header_t smbpsup_hdr;	/* structure header */ +	uint8_t smbpsup_group;		/* group id */ +	uint8_t smbpsup_loc;		/* location tag */ +	uint8_t smbpsup_devname;	/* device name */ +	uint8_t smbpsup_manufacturer;	/* manufacturer */ +	uint8_t smbpsup_serial;		/* serial number */ +	uint8_t smbpsup_asset;		/* asset tag */ +	uint8_t smbpsup_part;		/* part number */ +	uint8_t smbpsup_rev;		/* revision string */ +	uint16_t smbpsup_max;		/* max output in milliwatts */ +	uint16_t smbpsup_char;		/* characteristics */ +	uint16_t smbpsup_vprobe;	/* voltage probe handle */ +	uint16_t smbpsup_cooldev;	/* cooling device handle */ +	uint16_t smbpsup_iprobe;	/* current probe handle */ +} smb_powersup_t; + +#pragma pack() + +typedef struct smb_struct { +	const smb_header_t *smbst_hdr;	/* address of raw structure data */ +	const uchar_t *smbst_str;	/* address of string data (if any) */ +	const uchar_t *smbst_end;	/* address of 0x0000 ending tag */ +	struct smb_struct *smbst_next; 	/* next structure in hash chain */ +	uint16_t *smbst_strtab;		/* string index -> offset table */ +	uint_t smbst_strtablen;		/* length of smbst_strtab */ +} smb_struct_t; + +struct smbios_hdl { +	smbios_entry_t sh_ent;		/* structure table entry point */ +	const void *sh_buf;		/* structure table buffer */ +	size_t sh_buflen;		/* size of structure table buffer */ +	smb_struct_t *sh_structs;	/* array of structure descriptors */ +	uint_t sh_nstructs;		/* number of active structures */ +	smb_struct_t **sh_hash;		/* hash bucket array for descriptors */ +	uint_t sh_hashlen;		/* hash bucket array length */ +	int sh_err;			/* error code for smbios_errno() */ +	int sh_libvers;			/* library client abi version */ +	int sh_smbvers;			/* derived underlying format version */ +	uint_t sh_flags;		/* miscellaneous flags (see below) */ +}; + +#define	SMB_FL_DEBUG	0x1		/* print debug messages for this hdl */ +#define	SMB_FL_BUFALLOC	0x2		/* sh_buf was allocated by library */ + +#define	SMB_BIOS_DEVICE		"/dev/xsvc"	/* device w/ BIOS physmem */ +#define	SMB_SMBIOS_DEVICE	"/dev/smbios"	/* device w/ SMBIOS image */ + +#define	SMB_RANGE_START	0xF0000		/* start of physical address range */ +#define	SMB_RANGE_LIMIT	0xFFFFF		/* limit of physical address range */ + +#define	SMB_MAJMIN(M, m)	((((M) & 0xFF) << 16) | ((m) & 0xFF)) +#define	SMB_MAJOR(v)		(((v) & 0xFF00) >> 8) +#define	SMB_MINOR(v)		(((v) & 0x00FF)) + +#define	ESMB_BASE	1000		/* base value for libsmbios errnos */ + +enum { +	ESMB_NOTFOUND = ESMB_BASE,	/* SMBIOS table not found on system */ +	ESMB_MAPDEV,			/* failed to map SMBIOS table */ +	ESMB_NOENT,			/* failed to locate structure */ +	ESMB_NOMEM,			/* failed to allocate memory */ +	ESMB_NOHDR,			/* failed to read SMBIOS header */ +	ESMB_NOSTAB,			/* failed to read SMBIOS struct table */ +	ESMB_NOINFO,			/* no common info for structure */ +	ESMB_SHORT,			/* buffer length doesn't match header */ +	ESMB_CORRUPT,			/* buffer struct or len is corrupt */ +	ESMB_VERSION,			/* version not supported by library */ +	ESMB_NOTSUP,			/* feature not supported by provider */ +	ESMB_HEADER,			/* SMBIOS header corrupt or invalid */ +	ESMB_OLD,			/* SMBIOS version is too old for us */ +	ESMB_NEW,			/* SMBIOS version is too new for us */ +	ESMB_CKSUM,			/* SMBIOS header checksum mismatch */ +	ESMB_INVAL,			/* invalid function call argument */ +	ESMB_TYPE,			/* structure type mismatch */ +	ESMB_UNKNOWN			/* unknown error (maximum value tag) */ +}; + +extern const smb_struct_t *smb_lookup_type(smbios_hdl_t *, uint_t); +extern const smb_struct_t *smb_lookup_id(smbios_hdl_t *, uint_t); +extern const char *smb_strptr(const smb_struct_t *, uint_t); +extern int smb_gteq(smbios_hdl_t *, int); + +extern int smb_set_errno(smbios_hdl_t *, int); +extern smbios_hdl_t *smb_open_error(smbios_hdl_t *, int *, int); +extern const char *smb_strerror(int); + +extern void *smb_alloc(size_t); +extern void *smb_zalloc(size_t); +extern void smb_free(void *, size_t); + +extern void smb_dprintf(smbios_hdl_t *, const char *, ...); + +extern int _smb_debug; + +#ifdef	__cplusplus +} +#endif + +#endif	/* _SYS_SMBIOS_IMPL_H */ | 
