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 2014 Garrett D'Amore <garrett@damore.org>
  23  * Copyright 2017 RackTop Systems.
  24  *
  25  * Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
  26  * Use is subject to license terms.
  27  */
  28 
  29 /*      Copyright (c) 1984, 1986, 1987, 1988, 1989 AT&T     */
  30 /*        All Rights Reserved   */
  31 
  32 
  33 #ifndef _SYS_SYSTEMINFO_H
  34 #define _SYS_SYSTEMINFO_H
  35 
  36 #ifdef  __cplusplus
  37 extern "C" {
  38 #endif
  39 
  40 #if defined(_KERNEL) || defined(_FAKE_KERNEL)
  41 extern char architecture[];
  42 extern char architecture_32[];
  43 extern char hw_serial[];        /* machine's 32-bit hostid; a decimal string */
  44 extern char hw_provider[];
  45 extern char srpc_domain[];
  46 extern char platform[];
  47 #endif  /* _KERNEL || _FAKE_KERNEL */
  48 
  49 /*
  50  * Commands to sysinfo(2)
  51  *
  52  * Values for sysinfo(2) commands are to be assigned by the following
  53  * algorithm:
  54  *
  55  *    1 -  256  Unix International assigned numbers for `get' style commands.
  56  *  257 -  512  Unix International assigned numbers for `set' style commands
  57  *              where the value is selected to be the value for the
  58  *              corresponding `get' command plus 256.
  59  *  513 -  768  Solaris specific `get' style commands.
  60  *  769 - 1024  Solaris specific `set' style commands where the value is
  61  *              selected to be the value for the corresponding `get' command
  62  *              plus 256.
  63  *
  64  * These values have be registered
  65  * with Unix International can't be corrected now.  The status of a command
  66  * as published or unpublished does not alter the algorithm.
  67  */
  68 
  69 /* UI defined `get' commands (1-256) */
  70 #define SI_SYSNAME              1       /* return name of operating system */
  71 #define SI_HOSTNAME             2       /* return name of node */
  72 #define SI_RELEASE              3       /* return release of operating system */
  73 #define SI_VERSION              4       /* return version field of utsname */
  74 #define SI_MACHINE              5       /* return kind of machine */
  75 #define SI_ARCHITECTURE         6       /* return instruction set arch */
  76 #define SI_HW_SERIAL            7       /* return hardware serial number */
  77 #define SI_HW_PROVIDER          8       /* return hardware manufacturer */
  78 #define SI_SRPC_DOMAIN          9       /* return secure RPC domain */
  79 
  80 /* UI defined `set' commands (257-512) */
  81 #define SI_SET_HOSTNAME         258     /* set name of node */
  82 #define SI_SET_SRPC_DOMAIN      265     /* set secure RPC domain */
  83 
  84 /* Solaris defined `get' commands (513-768) */
  85 #define SI_PLATFORM             513     /* return platform identifier */
  86 #define SI_ISALIST              514     /* return supported isa list */
  87 #define SI_DHCP_CACHE           515     /* return kernel-cached DHCPACK */
  88 #define SI_ARCHITECTURE_32      516     /* basic 32-bit SI_ARCHITECTURE */
  89 #define SI_ARCHITECTURE_64      517     /* basic 64-bit SI_ARCHITECTURE */
  90 #define SI_ARCHITECTURE_K       518     /* kernel SI_ARCHITECTURE equivalent */
  91 #define SI_ARCHITECTURE_NATIVE  519     /* SI_ARCHITECTURE of the caller */
  92 
  93 /* Solaris defined `set' commands (769-1024) (none currently assigned) */
  94 
  95 
  96 #define HW_INVALID_HOSTID       0xFFFFFFFF      /* an invalid hostid */
  97 #define HW_HOSTID_LEN           11              /* minimum buffer size needed */
  98                                                 /* to hold a decimal or hex */
  99                                                 /* hostid string */
 100 #define DOM_NM_LN               64              /* maximum length of domain */
 101                                                 /* name */
 102 
 103 #if !defined(_KERNEL)
 104 int sysinfo(int, char *, long);
 105 #endif
 106 
 107 #ifdef  __cplusplus
 108 }
 109 #endif
 110 
 111 #endif /* _SYS_SYSTEMINFO_H */