1843e1988Sjohnlev# 2843e1988Sjohnlev# CDDL HEADER START 3843e1988Sjohnlev# 4843e1988Sjohnlev# The contents of this file are subject to the terms of the 5843e1988Sjohnlev# Common Development and Distribution License (the "License"). 6843e1988Sjohnlev# You may not use this file except in compliance with the License. 7843e1988Sjohnlev# 8843e1988Sjohnlev# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9843e1988Sjohnlev# or http://www.opensolaris.org/os/licensing. 10843e1988Sjohnlev# See the License for the specific language governing permissions 11843e1988Sjohnlev# and limitations under the License. 12843e1988Sjohnlev# 13843e1988Sjohnlev# When distributing Covered Code, include this CDDL HEADER in each 14843e1988Sjohnlev# file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15843e1988Sjohnlev# If applicable, add the following below this CDDL HEADER, with the 16843e1988Sjohnlev# fields enclosed by brackets "[]" replaced with your own identifying 17843e1988Sjohnlev# information: Portions Copyright [yyyy] [name of copyright owner] 18843e1988Sjohnlev# 19843e1988Sjohnlev# CDDL HEADER END 20843e1988Sjohnlev# 21843e1988Sjohnlev 22843e1988Sjohnlev# 2398157a70Sakolb# Copyright 2008 Sun Microsystems, Inc. All rights reserved. 24843e1988Sjohnlev# Use is subject to license terms. 25843e1988Sjohnlev# 26*b6b206fcSJohn Levon# Copyright (c) 2018, Joyent, Inc. 27*b6b206fcSJohn Levon# 28843e1988Sjohnlev# This makefile drives the production of unix (and unix.o). 29843e1988Sjohnlev# 30843e1988Sjohnlev# i86xpv implementation architecture dependent 31843e1988Sjohnlev# 32843e1988Sjohnlev 33843e1988Sjohnlev# 34843e1988Sjohnlev# Path to the base of the uts directory tree (usually /usr/src/uts). 35843e1988Sjohnlev# 36843e1988SjohnlevUTSBASE = ../.. 37843e1988Sjohnlev 38843e1988Sjohnlev# 39843e1988Sjohnlev# Define the module and object file sets. 40843e1988Sjohnlev# 41843e1988SjohnlevUNIX = unix 42843e1988SjohnlevDBOOT = dboot 43843e1988Sjohnlev 44843e1988SjohnlevOBJECTS = $(SPECIAL_OBJS:%=$(OBJS_DIR)/%) \ 45843e1988Sjohnlev $(CORE_OBJS:%=$(OBJS_DIR)/%) \ 46843e1988Sjohnlev $(KRTLD_OBJS:%=$(OBJS_DIR)/%) \ 47843e1988Sjohnlev $(MACH_NOT_YET_KMODS:%=$(OBJS_DIR)/%) 48843e1988Sjohnlev 49843e1988SjohnlevLINTS = $(SPECIAL_OBJS:%.o=$(LINTS_DIR)/%.ln) \ 50843e1988Sjohnlev $(CORE_OBJS:%.o=$(LINTS_DIR)/%.ln) \ 51843e1988Sjohnlev $(KRTLD_OBJS:%.o=$(LINTS_DIR)/%.ln) \ 52843e1988Sjohnlev $(MACH_NOT_YET_KMODS:%.o=$(LINTS_DIR)/%.ln) \ 53843e1988Sjohnlev $(LINTS_DIR)/vers.ln \ 54843e1988Sjohnlev $(LINTS_DIR)/modstubs.ln 55843e1988Sjohnlev 56843e1988SjohnlevROOTMODULE = $(ROOT_PSM_KERN_DIR)/$(UNIX) 57843e1988Sjohnlev 58843e1988SjohnlevUNIX_BIN = $(OBJS_DIR)/$(UNIX) 59843e1988Sjohnlev 60843e1988SjohnlevLIBS = $(GENLIB) 61843e1988Sjohnlev 62843e1988SjohnlevGENUNIX = genunix 63843e1988SjohnlevGENUNIX_DIR = ../../intel/$(GENUNIX) 64843e1988Sjohnlev 65843e1988SjohnlevLIBOPTS = -L $(GENUNIX_DIR)/$(OBJS_DIR) -l $(GENUNIX) 66843e1988Sjohnlev 67843e1988SjohnlevCTFEXTRAOBJS = $(OBJS_DIR)/vers.o 68843e1988Sjohnlev 69843e1988SjohnlevDBOOT_OBJS_DIR = dboot/$(OBJS_DIR) 70843e1988SjohnlevDBOOT_OBJECTS = $(DBOOT_OBJS:%=$(DBOOT_OBJS_DIR)/%) 71843e1988SjohnlevDBOOT_BIN = $(DBOOT_OBJS_DIR)/$(DBOOT) 72843e1988SjohnlevDBOOT_O = $(OBJS_DIR)/$(DBOOT).o 73843e1988SjohnlevDBOOT_S = $(DBOOT_O:%.o=%.s) 74843e1988SjohnlevDBOOT_LINTS = $(DBOOT_OBJS:%.o=$(DBOOT_OBJS_DIR)/%.ln) 75843e1988SjohnlevDBOOT_LINT = $(LINT_$(MACH)_$(CLASS)) 76843e1988Sjohnlev 77843e1988Sjohnlev# 78843e1988Sjohnlev# Include common rules. 79843e1988Sjohnlev# 80843e1988Sjohnlevinclude $(UTSBASE)/i86xpv/Makefile.i86xpv 81843e1988Sjohnlev 82843e1988Sjohnlev# 83843e1988Sjohnlev# Define targets 84843e1988Sjohnlev# 85843e1988SjohnlevALL_TARGET = $(UNIX_BIN) 86843e1988SjohnlevLINT_TARGET = $(LINT_LIB) $(DBOOT_LINT_LIB) 87843e1988SjohnlevINSTALL_TARGET = $(UNIX_BIN) $(ROOTMODULE) 88843e1988Sjohnlev 89843e1988Sjohnlev# 90843e1988Sjohnlev# This is UNIX_DIR. Use a short path. 91843e1988Sjohnlev# 92843e1988SjohnlevUNIX_DIR = . 93843e1988Sjohnlev 94843e1988Sjohnlev# 95843e1988Sjohnlev# Overrides 96843e1988Sjohnlev# 97843e1988SjohnlevCLEANFILES += \ 98843e1988Sjohnlev $(UNIX_O) $(MODSTUBS_O) \ 99843e1988Sjohnlev $(OBJS_DIR)/vers.c $(OBJS_DIR)/vers.o \ 100b6805bf7SGordon Ross $(OBJS_DIR)/dtracestubs.s \ 101843e1988Sjohnlev $(DTRACESTUBS_O) $(DTRACESTUBS) 102843e1988Sjohnlev 103843e1988SjohnlevCLEANFILES += \ 104843e1988Sjohnlev $(DBOOT_O) $(DBOOT_S) \ 105843e1988Sjohnlev $(DBOOT_OBJECTS) \ 106843e1988Sjohnlev $(DBOOT_BIN) 107843e1988Sjohnlev 108b6805bf7SGordon RossCLEANFILES += \ 109898c3fecSToomas Soome $(DBOOT_OBJS_DIR)/$(VGATEXT_FONT).c \ 110898c3fecSToomas Soome $(OBJS_DIR)/$(VGATEXT_FONT).c 111898c3fecSToomas Soome 112898c3fecSToomas SoomeCLEANFILES += \ 113b6805bf7SGordon Ross $(OBJS_DIR)/fb_swtch_src.o \ 114b6805bf7SGordon Ross $(OBJS_DIR)/fb_swtch_src \ 115b6805bf7SGordon Ross $(OBJS_DIR)/fb_swtch.s 116b6805bf7SGordon Ross 117b6805bf7SGordon RossCLEANFILES += \ 118b6805bf7SGordon Ross $(ZLIB_OBJS:%.o=$(OBJS_DIR)/%.o) \ 119b6805bf7SGordon Ross $(ZLIB_OBJS:%.o=$(OBJS_DIR)/%.ln) 120b6805bf7SGordon Ross 121843e1988SjohnlevCLOBBERFILES = $(CLEANFILES) $(UNIX_BIN) 122843e1988SjohnlevCLEANLINTFILES += $(LINT_LIB) $(DBOOT_LINT_LIB) $(DBOOT_LINTS) 123843e1988Sjohnlev 124843e1988Sjohnlev# instr_size needs a special header 125843e1988Sjohnlev$(OBJS_DIR)/instr_size.o := EXTRA_OPTIONS = -I$(SRC)/common/dis/i386 126843e1988Sjohnlev$(OBJS_DIR)/instr_size.ln := EXTRA_OPTIONS = -I$(SRC)/common/dis/i386 127843e1988Sjohnlev 128843e1988SjohnlevCFLAGS += -DDIS_MEM 129843e1988Sjohnlev 130843e1988Sjohnlev# 131843e1988Sjohnlev# For now, disable these lint checks; maintainers should endeavor 132843e1988Sjohnlev# to investigate and remove these for maximum lint coverage. 133843e1988Sjohnlev# Please do not carry these forward to new Makefiles. 134843e1988Sjohnlev# 135843e1988SjohnlevLINTTAGS += -erroff=E_BAD_PTR_CAST_ALIGN 136843e1988SjohnlevLINTTAGS += -erroff=E_SUSPICIOUS_COMPARISON 137843e1988SjohnlevLINTTAGS += -erroff=E_SUPPRESSION_DIRECTIVE_UNUSED 138843e1988SjohnlevLINTTAGS += -erroff=E_STATIC_UNUSED 139843e1988SjohnlevLINTTAGS += -erroff=E_PTRDIFF_OVERFLOW 140843e1988SjohnlevLINTTAGS += -erroff=E_ASSIGN_NARROW_CONV 141843e1988Sjohnlev 1427014882cSRichard LoweCERRWARN += -_gcc=-Wno-parentheses 1437014882cSRichard LoweCERRWARN += -_gcc=-Wno-uninitialized 1447014882cSRichard LoweCERRWARN += -_gcc=-Wno-char-subscripts 1457014882cSRichard LoweCERRWARN += -_gcc=-Wno-unused-variable 1467014882cSRichard LoweCERRWARN += -_gcc=-Wno-unused-function 1477014882cSRichard LoweCERRWARN += -_gcc=-Wno-unused-label 1487014882cSRichard LoweCERRWARN += -_gcc=-Wno-type-limits 1497014882cSRichard LoweCERRWARN += -_gcc=-Wno-clobbered 1507014882cSRichard LoweCERRWARN += -_gcc=-Wno-unused-value 1517014882cSRichard LoweCERRWARN += -_gcc=-Wno-empty-body 1527014882cSRichard Lowe 153*b6b206fcSJohn Levon# needs work 154*b6b206fcSJohn LevonSMATCH=off 155*b6b206fcSJohn Levon 1568793b36bSNick Todd# Ensure that lint sees 'struct cpu' containing a fully declared 1578793b36bSNick Todd# embedded 'struct machcpu' 1588793b36bSNick Todd# 1598793b36bSNick ToddLINTFLAGS += -D_MACHDEP -I../../i86pc 1608793b36bSNick Todd 161843e1988Sjohnlev# 162843e1988Sjohnlev# Default build targets. 163843e1988Sjohnlev# 164843e1988Sjohnlev.KEEP_STATE: 165843e1988Sjohnlev 166843e1988Sjohnlevdef: $(DEF_DEPS) 167843e1988Sjohnlev 168843e1988Sjohnlevall: $(ALL_DEPS) 169843e1988Sjohnlev 170843e1988Sjohnlevclean: $(CLEAN_DEPS) 171843e1988Sjohnlev 172843e1988Sjohnlevclobber: $(CLOBBER_DEPS) 173843e1988Sjohnlev 174843e1988Sjohnlevlint: $(LINT_DEPS) 175843e1988Sjohnlev 176843e1988Sjohnlevclean.lint: $(CLEAN_LINT_DEPS) 177843e1988Sjohnlev 178843e1988Sjohnlevinstall: $(INSTALL_DEPS) 179843e1988Sjohnlev 180843e1988SjohnlevMAPFILE_32 = $(MAPFILE) 181843e1988SjohnlevMAPFILE_64 = $(MAPFILE).amd64 182843e1988Sjohnlev 183843e1988SjohnlevMAPFILE_NAME = $(MAPFILE_$(CLASS)) 184843e1988Sjohnlev 185843e1988Sjohnlev$(UNIX_BIN): $(UNIX_O) $(MODSTUBS_O) $(MAPFILE_NAME) \ 186843e1988Sjohnlev $(GENLIB) $(DTRACESTUBS) $(DBOOT_O) 187843e1988Sjohnlev $(LD) -dy -b -o $@ -e dboot_image -znointerp -M $(MAPFILE_NAME) \ 188843e1988Sjohnlev $(UNIX_O) $(DBOOT_O) $(MODSTUBS_O) $(LIBOPTS) \ 189843e1988Sjohnlev $(DTRACESTUBS) 190843e1988Sjohnlev $(CTFMERGE_UNIQUIFY_AGAINST_GENUNIX) 191843e1988Sjohnlev $(POST_PROCESS) 192843e1988Sjohnlev 193843e1988Sjohnlev$(UNIX_O): $(OBJECTS) $(OBJS_DIR)/vers.o 194843e1988Sjohnlev $(LD) -r -o $@ $(OBJECTS) $(OBJS_DIR)/vers.o 195843e1988Sjohnlev 196843e1988Sjohnlev$(DBOOT_BIN): $(DBOOT_OBJS_DIR) $(DBOOT_OBJECTS) dboot/Mapfile.dboot 197843e1988Sjohnlev $(LD) -dn -e _start -M dboot/Mapfile.dboot \ 198843e1988Sjohnlev -o $(DBOOT_BIN) $(DBOOT_OBJECTS) 199843e1988Sjohnlev 200843e1988Sjohnlev$(DBOOT_O): $(DBOOT_BIN) 201843e1988Sjohnlev @echo " .data" > $(DBOOT_S) 202843e1988Sjohnlev @echo " .globl dboot_image" >> $(DBOOT_S) 203843e1988Sjohnlev @echo "dboot_image:" >> $(DBOOT_S) 204843e1988Sjohnlev $(ELFEXTRACT) $(DBOOT_BIN) >> $(DBOOT_S) 205843e1988Sjohnlev $(COMPILE.s) -o $(DBOOT_O) $(DBOOT_S) 206843e1988Sjohnlev 207843e1988Sjohnlev$(DBOOT_OBJS_DIR): 208843e1988Sjohnlev -@mkdir -p $@ 2> /dev/null 209843e1988Sjohnlev 210843e1988Sjohnlev# 211843e1988Sjohnlev# Special rules for generating assym.h for inclusion in assembly files. 212843e1988Sjohnlev# 213843e1988Sjohnlev$(DSF_DIR)/$(OBJS_DIR)/assym.h $(DSF_DIR)/$(OBJS_DIR)/kdi_assym.h: FRC 214843e1988Sjohnlev @cd $(DSF_DIR); $(MAKE) all.targ 215843e1988Sjohnlev 216843e1988Sjohnlev# 217843e1988Sjohnlev# The global lint target builds the kernel lint library (llib-lunix.ln) 218843e1988Sjohnlev# which is equivalent to a lint of /unix.o. Then all kernel modules for 219843e1988Sjohnlev# this architecture are linted against the kernel lint library. 220843e1988Sjohnlev# 221843e1988Sjohnlev# Note: lint errors in the kernel lint library will be repeated for 222843e1988Sjohnlev# each module. It is important that the kernel lint library 223843e1988Sjohnlev# be clean to keep the textual output to a reasonable level. 224843e1988Sjohnlev# 225843e1988Sjohnlev 226843e1988Sjohnlev$(LINT_LIB): $(LINT_LIB_DIR) $(LINTS) 22798157a70Sakolb @pwd 228843e1988Sjohnlev @-$(ECHO) "\n$(UNIX): (library construction):" 229843e1988Sjohnlev @$(LINT) -o$(UNIX) $(LINTFLAGS) $(LINTS) 230843e1988Sjohnlev @$(MV) $(@F) $@ 231843e1988Sjohnlev 232843e1988Sjohnlev$(DBOOT_LINT_LIB): $(LINT_LIB_DIR) $(DBOOT_LINTS) 23398157a70Sakolb @pwd 234843e1988Sjohnlev @-$(ECHO) "\n$(DBOOT): (library construction):" 235843e1988Sjohnlev @$(LINT) -o$(DBOOT) $(DBOOT_LINTFLAGS) $(DBOOT_LINTS) 236843e1988Sjohnlev @$(MV) $(@F) $@ 237843e1988Sjohnlev 238843e1988Sjohnlevlintlib: $(LINT_DEPS) 239843e1988Sjohnlev 240843e1988Sjohnlev# 241843e1988Sjohnlev# Include common targets. 242843e1988Sjohnlev# 243843e1988Sjohnlevinclude $(UTSBASE)/i86xpv/Makefile.targ 244