1 /*
   2  * CDDL HEADER START
   3  *
   4  * The contents of this file are subject to the terms of the
   5  * Common Development and Distribution License (the "License").
   6  * You may not use this file except in compliance with the License.
   7  *
   8  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
   9  * or http://www.opensolaris.org/os/licensing.
  10  * See the License for the specific language governing permissions
  11  * and limitations under the License.
  12  *
  13  * When distributing Covered Code, include this CDDL HEADER in each
  14  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
  15  * If applicable, add the following below this CDDL HEADER, with the
  16  * fields enclosed by brackets "[]" replaced with your own identifying
  17  * information: Portions Copyright [yyyy] [name of copyright owner]
  18  *
  19  * CDDL HEADER END
  20  */
  21 /*
  22  * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
  23  * Use is subject to license terms.
  24  */
  25 
  26 /*      Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T     */
  27 /*        All Rights Reserved   */
  28 
  29 
  30 #ifndef _SYS_SYSTEMINFO_H
  31 #define _SYS_SYSTEMINFO_H
  32 
  33 #ifdef  __cplusplus
  34 extern "C" {
  35 #endif
  36 
  37 #ifdef  _KERNEL
  38 extern char architecture[];
  39 extern char architecture_32[];
  40 extern char hw_serial[];        /* machine's 32-bit hostid; a decimal string */
  41 extern char hw_provider[];
  42 extern char srpc_domain[];
  43 extern char platform[];
  44 #endif  /* _KERNEL */
  45 
  46 /*
  47  * Commands to sysinfo(2)
  48  *
  49  * Values for sysinfo(2) commands are to be assigned by the following
  50  * algorithm:
  51  *
  52  *    1 -  256  Unix International assigned numbers for `get' style commands.
  53  *  257 -  512  Unix International assigned numbers for `set' style commands
  54  *              where the value is selected to be the value for the
  55  *              corresponding `get' command plus 256.
  56  *  513 -  768  Solaris specific `get' style commands.
  57  *  769 - 1024  Solaris specific `set' style commands where the value is
  58  *              selected to be the value for the corresponding `get' command
  59  *              plus 256.
  60  *
  61  * These values have be registered
  62  * with Unix International can't be corrected now.  The status of a command
  63  * as published or unpublished does not alter the algorithm.
  64  */
  65 
  66 /* UI defined `get' commands (1-256) */
  67 #define SI_SYSNAME              1       /* return name of operating system */
  68 #define SI_HOSTNAME             2       /* return name of node */
  69 #define SI_RELEASE              3       /* return release of operating system */
  70 #define SI_VERSION              4       /* return version field of utsname */
  71 #define SI_MACHINE              5       /* return kind of machine */
  72 #define SI_ARCHITECTURE         6       /* return instruction set arch */
  73 #define SI_HW_SERIAL            7       /* return hardware serial number */
  74 #define SI_HW_PROVIDER          8       /* return hardware manufacturer */
  75 #define SI_SRPC_DOMAIN          9       /* return secure RPC domain */
  76 
  77 /* UI defined `set' commands (257-512) */
  78 #define SI_SET_HOSTNAME         258     /* set name of node */
  79 #define SI_SET_SRPC_DOMAIN      265     /* set secure RPC domain */
  80 
  81 /* Solaris defined `get' commands (513-768) */
  82 #define SI_PLATFORM             513     /* return platform identifier */
  83 #define SI_ISALIST              514     /* return supported isa list */
  84 #define SI_DHCP_CACHE           515     /* return kernel-cached DHCPACK */
  85 #define SI_ARCHITECTURE_32      516     /* basic 32-bit SI_ARCHITECTURE */
  86 #define SI_ARCHITECTURE_64      517     /* basic 64-bit SI_ARCHITECTURE */
  87 #define SI_ARCHITECTURE_K       518     /* kernel SI_ARCHITECTURE equivalent */
  88 #define SI_ARCHITECTURE_NATIVE  519     /* SI_ARCHITECTURE of the caller */
  89 
  90 /* Solaris defined `set' commands (769-1024) (none currently assigned) */
  91 
  92 
  93 #define HW_INVALID_HOSTID       0xFFFFFFFF      /* an invalid hostid */
  94 #define HW_HOSTID_LEN           11              /* minimum buffer size needed */
  95                                                 /* to hold a decimal or hex */
  96                                                 /* hostid string */
  97 #define DOM_NM_LN               64              /* maximum length of domain */
  98                                                 /* name */
  99 
 100 #if !defined(_KERNEL)
 101 #if defined(__STDC__)
 102 int sysinfo(int, char *, long);
 103 #else
 104 int sysinfo();
 105 #endif
 106 #endif
 107 
 108 #ifdef  __cplusplus
 109 }
 110 #endif
 111 
 112 #endif /* _SYS_SYSTEMINFO_H */