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