xref: /titanic_41/usr/src/uts/sparc/ibcm/Makefile (revision 9512fe850e98fdd448c638ca63fdd92a8a510255)
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# Copyright 2004 Sun Microsystems, Inc.  All rights reserved.
24# Use is subject to license terms.
25#
26# uts/sparc/ibcm/Makefile
27#
28#	This makefile drives the production of the ibcm kernel
29#	module. SPARC architecture dependent
30#
31
32# ident	"%Z%%M%	%I%	%E% SMI"
33
34#
35#	Path to the base of the uts directory tree (usually /usr/src/uts).
36#
37UTSBASE	= ../..
38
39#
40#	Define the module and object file sets.
41#
42MODULE		= ibcm
43OBJECTS		= $(IBCM_OBJS:%=$(OBJS_DIR)/%)
44LINTS		= $(IBCM_OBJS:%.o=$(LINTS_DIR)/%.ln)
45ROOTMODULE	= $(ROOT_MISC_DIR)/$(MODULE)
46WARLOCK_OBJS    = $(IBCM_OBJS:%.o=%.ll)
47WARLOCK_OK      = $(MODULE).ok
48
49#
50#	Include common rules.
51#
52include $(UTSBASE)/sparc/Makefile.sparc
53
54#
55#	Define targets
56#
57ALL_TARGET	= $(BINARY)
58LINT_TARGET	= $(MODULE).lint
59INSTALL_TARGET	= $(BINARY) $(ROOTMODULE)
60
61#
62#	Overrides.
63#
64ALL_BUILDS	= $(ALL_BUILDSONLY64)
65DEF_BUILDS	= $(DEF_BUILDSONLY64)
66
67#
68# lint pass one enforcement
69#
70CFLAGS += $(CCVERBOSE)
71
72#
73#	depends on misc/ibtl and misc/ibmf
74#
75LDFLAGS	+= -dy -Nmisc/ibtl -Nmisc/ibmf
76
77#
78#	Default build targets.
79#
80.KEEP_STATE:
81
82def:		$(DEF_DEPS)
83
84all:		$(ALL_DEPS)
85
86clean:		$(CLEAN_DEPS); \
87		$(RM) $(WARLOCK_OBJS) $(WARLOCK_OK)
88
89clobber:	$(CLOBBER_DEPS); \
90		$(RM) $(WARLOCK_OBJS) $(WARLOCK_OK)
91
92lint:		$(LINT_DEPS)
93
94modlintlib:	$(MODLINTLIB_DEPS) lint32
95
96clean.lint:	$(CLEAN_LINT_DEPS)
97
98install:	$(INSTALL_DEPS)
99
100#
101#	Include common targets.
102#
103include $(UTSBASE)/sparc/Makefile.targ
104
105#
106#       Defines for local commands.
107#
108WARLOCK         = warlock
109WLCC            = wlcc
110TOUCH           = touch
111SCCS            = sccs
112TEST            = test
113
114warlock: $(MODULE).ok
115
116%.wlcmd:
117	$(TEST) -f $@ || $(SCCS) get $@
118
119$(MODULE).ok: $(WARLOCK_OBJS) ibcm.wlcmd
120	$(WARLOCK) -c ./ibcm.wlcmd $(WARLOCK_OBJS)
121	$(TOUCH) $@
122
123%.ll: $(UTSBASE)/common/io/ib/mgt/ibcm/%.c \
124	$(UTSBASE)/common/sys/ib/mgt/ibcm/ibcm_impl.h
125	$(WLCC)  $(CPPFLAGS) -DDEBUG -o $@ $<
126
127warlock_ddi.files:
128	@cd ../warlock; pwd; $(MAKE) warlock
129