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 */