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 (c) 1992, 2010, Oracle and/or its affiliates. All rights reserved. 23 * 24 * Copyright 2018 Joyent, Inc. 25 */ 26 27 #ifndef _GENASSYM 28 #define _GENASSYM 29 #endif 30 31 #define exit kern_exit 32 33 #include <sys/types.h> 34 #include <sys/param.h> 35 #include <sys/systm.h> 36 #include <sys/elf_notes.h> 37 #include <sys/thread.h> 38 #include <sys/rwlock.h> 39 #include <sys/proc.h> 40 #include <sys/cpuvar.h> 41 #include <sys/clock.h> 42 #include <sys/trap.h> 43 #include <sys/modctl.h> 44 #include <sys/traptrace.h> 45 #include <vm/seg.h> 46 #include <sys/avintr.h> 47 #include <sys/pic.h> 48 #include <sys/pit.h> 49 #include <sys/fp.h> 50 #include <sys/disp.h> 51 #include <sys/archsystm.h> 52 #include <sys/x86_archext.h> 53 #include <sys/sunddi.h> 54 #include <sys/mach_mmu.h> 55 56 #if defined(__xpv) 57 #include <sys/hypervisor.h> 58 #endif 59 60 #undef exit /* unhide exit, see comment above */ 61 extern void exit(int); 62 63 /* 64 * Proactively discourage anyone from referring to structures or 65 * member offsets in this program. 66 */ 67 #define struct struct... 68 #define OFFSET OFFSET... 69 70 int 71 main(int argc, char *argv[]) 72 { 73 printf("#define\tLOCK_LEVEL 0x%x\n", LOCK_LEVEL); 74 printf("#define\tCLOCK_LEVEL 0x%x\n", CLOCK_LEVEL); 75 printf("#define\tDISP_LEVEL 0x%x\n", DISP_LEVEL); 76 printf("#define\tPIL_MAX 0x%x\n", PIL_MAX); 77 printf("#define\tHIGH_LEVELS 0x%x\n", HIGH_LEVELS); 78 printf("#define\tCPU_INTR_ACTV_HIGH_LEVEL_MASK 0x%x\n", 79 CPU_INTR_ACTV_HIGH_LEVEL_MASK); 80 81 printf("#define\tPIC_NSEOI 0x%x\n", PIC_NSEOI); 82 printf("#define\tPIC_SEOI_LVL7 0x%x\n", PIC_SEOI_LVL7); 83 84 printf("#define\tNANOSEC 0x%llx\n", NANOSEC); 85 printf("#define\tADJ_SHIFT 0x%x\n", ADJ_SHIFT); 86 87 printf("#define\tSSLEEP 0x%x\n", SSLEEP); 88 printf("#define\tSRUN 0x%x\n", SRUN); 89 printf("#define\tSONPROC 0x%x\n", SONPROC); 90 91 printf("#define\tT_INTR_THREAD 0x%x\n", T_INTR_THREAD); 92 printf("#define\tFREE_THREAD 0x%x\n", TS_FREE); 93 printf("#define\tTS_FREE 0x%x\n", TS_FREE); 94 printf("#define\tTS_ZOMB 0x%x\n", TS_ZOMB); 95 printf("#define\tTP_MSACCT 0x%x\n", TP_MSACCT); 96 printf("#define\tTP_WATCHPT 0x%x\n", TP_WATCHPT); 97 printf("#define\tONPROC_THREAD 0x%x\n", TS_ONPROC); 98 99 printf("#define\tS_READ 0x%x\n", (int)S_READ); 100 printf("#define\tS_WRITE 0x%x\n", (int)S_WRITE); 101 printf("#define\tS_EXEC 0x%x\n", (int)S_EXEC); 102 printf("#define\tS_OTHER 0x%x\n", (int)S_OTHER); 103 104 printf("#define\tNORMALRETURN 0x%x\n", (int)NORMALRETURN); 105 printf("#define\tLWP_USER 0x%x\n", LWP_USER); 106 printf("#define\tLWP_SYS 0x%x\n", LWP_SYS); 107 printf("#define\tLMS_USER 0x%x\n", LMS_USER); 108 printf("#define\tLMS_SYSTEM 0x%x\n", LMS_SYSTEM); 109 110 printf("#define\tSSE_MXCSR_EFLAGS 0x%x\n", SSE_MXCSR_EFLAGS); 111 112 printf("#define\tFP_FXSAVE 0x%x\n", FP_FXSAVE); 113 printf("#define\tFP_XSAVE 0x%x\n", FP_XSAVE); 114 115 printf("#define\tAV_INT_SPURIOUS 0x%x\n", AV_INT_SPURIOUS); 116 117 printf("#define\tCPU_READY 0x%x\n", CPU_READY); 118 printf("#define\tCPU_QUIESCED 0x%x\n", CPU_QUIESCED); 119 120 printf("#define\tMCMD_PORT 0x%x\n", MCMD_PORT); 121 printf("#define\tSCMD_PORT 0x%x\n", SCMD_PORT); 122 printf("#define\tMIMR_PORT 0x%x\n", MIMR_PORT); 123 printf("#define\tSIMR_PORT 0x%x\n", SIMR_PORT); 124 125 printf("#define\tDMP_NOSYNC 0x%x\n", DMP_NOSYNC); 126 127 printf("#define\tRW_WRITER\t0x%x\n", RW_WRITER); 128 printf("#define\tRW_READER\t0x%x\n", RW_READER); 129 130 printf("#define\tNSYSCALL 0x%x\n", NSYSCALL); 131 132 printf("#define\tSE_32RVAL1 0x%x\n", SE_32RVAL1); 133 printf("#define\tSE_32RVAL2 0x%x\n", SE_32RVAL2); 134 printf("#define\tSE_64RVAL 0x%x\n", SE_64RVAL); 135 136 printf("#define\tMAXSYSARGS 0x%x\n", MAXSYSARGS); 137 138 /* Hack value just to allow clock to be kicked */ 139 printf("#define\tNSEC_PER_CLOCK_TICK 0x%llx\n", NANOSEC / 100); 140 141 printf("#define\tNSEC_PER_COUNTER_TICK 0x%llx\n", NANOSEC / PIT_HZ); 142 143 printf("#define\tNBPW 0x%x\n", NBPW); 144 145 printf("#define\tDDI_ACCATTR_IO_SPACE 0x%x\n", DDI_ACCATTR_IO_SPACE); 146 printf("#define\tDDI_ACCATTR_DIRECT 0x%x\n", DDI_ACCATTR_DIRECT); 147 printf("#define\tDDI_ACCATTR_CPU_VADDR 0x%x\n", DDI_ACCATTR_CPU_VADDR); 148 printf("#define\tDDI_DEV_AUTOINCR 0x%x\n", DDI_DEV_AUTOINCR); 149 150 printf("#define\tMMU_STD_PAGESIZE 0x%x\n", (uint_t)MMU_STD_PAGESIZE); 151 printf("#define\tMMU_STD_PAGEMASK 0x%x\n", (uint_t)MMU_STD_PAGEMASK); 152 printf("#define\tFOUR_MEG 0x%x\n", (uint_t)FOUR_MEG); 153 154 printf("#define\tTRAPTR_NENT 0x%x\n", TRAPTR_NENT); 155 156 printf("#define\tCPU_DTRACE_NOFAULT 0x%x\n", CPU_DTRACE_NOFAULT); 157 printf("#define\tCPU_DTRACE_BADADDR 0x%x\n", CPU_DTRACE_BADADDR); 158 printf("#define\tCPU_DTRACE_DIVZERO 0x%x\n", CPU_DTRACE_DIVZERO); 159 printf("#define\tCPU_DTRACE_ILLOP 0x%x\n", CPU_DTRACE_ILLOP); 160 161 printf("#define\tMODS_NOUNLOAD 0x%x\n", MODS_NOUNLOAD); 162 printf("#define\tMODS_WEAK 0x%x\n", MODS_WEAK); 163 printf("#define\tMODS_INSTALLED 0x%x\n", MODS_INSTALLED); 164 165 printf("#define\tKPREEMPT_SYNC 0x%x\n", KPREEMPT_SYNC); 166 167 #if defined(__xpv) 168 printf("#define\tSHUTDOWN_reboot 0x%x\n", SHUTDOWN_reboot); 169 printf("#define\tSCHEDOP_block 0x%x\n", SCHEDOP_block); 170 printf("#define\tVGCF_IN_KERNEL 0x%x\n", VGCF_IN_KERNEL); 171 #endif 172 return (0); 173 }