xref: /titanic_44/usr/src/uts/sun4u/montecarlo/Makefile (revision 28167c24ba5be8b7c1d05e02d053f4a55cd21cc9)
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, Version 1.0 only
6# (the "License").  You may not use this file except in compliance
7# with the License.
8#
9# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
10# or http://www.opensolaris.org/os/licensing.
11# See the License for the specific language governing permissions
12# and limitations under the License.
13#
14# When distributing Covered Code, include this CDDL HEADER in each
15# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
16# If applicable, add the following below this CDDL HEADER, with the
17# fields enclosed by brackets "[]" replaced with your own identifying
18# information: Portions Copyright [yyyy] [name of copyright owner]
19#
20# CDDL HEADER END
21#
22#
23# uts/sun4u/montecarlo/Makefile
24# Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
25# Use is subject to license terms.
26#
27#ident	"%Z%%M%	%I%	%E% SMI"
28#
29#     This makefile drives the production of all MonteCarlo system
30#     dependent modules for the sun4u architecture.
31#
32
33#
34#	Path to the base of the uts directory tree (usually /usr/src/uts).
35#
36UTSBASE		= ../..
37GROUP		= sys
38CHGRP		= /usr/bin/chgrp -h
39
40#
41#	Include common rules.
42#
43include $(UTSBASE)/sun4u/montecarlo/Makefile.montecarlo
44
45def		:=	TARGET= def
46all		:=	TARGET= all
47install		:=	TARGET= install
48install_h	:=	TARGET= install_h
49clean		:=	TARGET= clean
50clobber		:=	TARGET= clobber
51lint		:=	TARGET= lint
52#lintlib	:=	TARGET= lintlib
53modlintlib	:=	TARGET= modlintlib
54modlist		:=	TARGET= modlist
55modlist		:=	NO_STATE= -K $$MODSTATE$$$$
56clean.lint	:=	TARGET= clean.lint
57check		:=	TARGET= check
58
59#
60#	Default build targets.
61#
62.KEEP_STATE:
63
64def all clean.lint clean clobber modlist: $(MONTECARLO_KMODS) \
65	$(CLOSED_MONTECARLO_KMODS)
66
67modlintlib:	$(MONTECARLO_KMODS) $(CLOSED_MONTECARLO_KMODS)
68
69install:        $(ROOT_MONTECARLO_DIR) $(USR_MONTECARLO_DIR) \
70                $(USR_MONTECARLO_INC_DIR) \
71                $(USR_MONTECARLO_SBIN_DIR) \
72                $(USR_MONTECARLO_LIB_DIR) \
73                .WAIT $(MONTECARLO_KMODS) $(CLOSED_MONTECARLO_KMODS) \
74		pcicfg se.conf ttymux.conf
75
76pcicfg:		$(ROOT_MONTECARLO_MISC_DIR_64)
77		-@$(RM) $(ROOT_MONTECARLO_MISC_DIR_64)/$@
78		$(SYMLINK) ../../../../sun4u/kernel/misc/sparcv9/pcicfg.e \
79		$(ROOT_MONTECARLO_MISC_DIR_64)/$@
80
81se.conf:	$(ROOT_MONTECARLO_DRV_DIR)
82		-@$(RM) $(ROOT_MONTECARLO_DRV_DIR)/$@
83		$(CP) $(UTSBASE)/sun4u/montecarlo/io/$@ \
84		$(ROOT_MONTECARLO_DRV_DIR)/$@
85		$(CHMOD) $(CFILEMODE) $(ROOT_MONTECARLO_DRV_DIR)/$@
86		$(CHGRP) $(GROUP) $(ROOT_MONTECARLO_DRV_DIR)/$@
87
88ttymux.conf:	$(ROOT_MONTECARLO_DRV_DIR)
89		-@$(RM) $(ROOT_MONTECARLO_DRV_DIR)/$@
90		$(CP) $(UTSBASE)/sun4u/montecarlo/io/$@ \
91		$(ROOT_MONTECARLO_DRV_DIR)/$@
92		$(CHMOD) $(CFILEMODE) $(ROOT_MONTECARLO_DRV_DIR)/$@
93		$(CHGRP) $(GROUP) $(ROOT_MONTECARLO_DRV_DIR)/$@
94
95install_h check:	FRC
96	@cd sys; pwd; $(MAKE) $(TARGET)
97
98lint:		modlintlib
99
100#
101# The 'lint.platmod' target lints the montecarlo platform module against
102# the sun4u kernel.  This ends up doing all the kernel cross-checks,
103# so it takes a couple of minutes.
104# Due to the low ROI, it's not run by default, but it's a good
105# idea to run this if you change os/montecarlo.c.
106#
107LINT_LIBS	 = $(LINT_LIB) \
108		   -L$(MONTECARLO_LINT_LIB_DIR) \
109		   -L$(LINT_LIB_DIR) $(LINT_KMODS:%=-l%) \
110		       $(CLOSED_LINT_KMODS:%=-l%) \
111		   -L$(SPARC_LIB_DIR) $(SPARC_LINTS:%=-l%)
112
113lint.platmod:   modlintlib
114	@-$(ECHO) "\nMonteCarlo Platform-dependent module: global crosschecks:"
115	@-$(LINT) $(LINTFLAGS) $(LINT_LIBS) 2>&1 | $(LGREP.2)
116
117$(MONTECARLO_KMODS): FRC
118	@cd $@; pwd; $(MAKE) $(NO_STATE) $(TARGET)
119
120$(CLOSED_MONTECARLO_KMODS): FRC
121	cd $(CLOSED)/uts/sun4u/montecarlo/$@; pwd; \
122	    $(MAKE) $(NO_STATE) $(TARGET)
123
124#
125#	Include common targets.
126#
127include $(UTSBASE)/sun4u/montecarlo/Makefile.targ
128