Makefile revision bf56214c0556fa6864189c826d39dbe156bb22a0
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# CDDL HEADER START
4f6469885c3d66367e3f8fb94e1f3c66115990b0Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# The contents of this file are subject to the terms of the
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# Common Development and Distribution License (the "License").
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# You may not use this file except in compliance with the License.
4f6469885c3d66367e3f8fb94e1f3c66115990b0Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# or http://www.opensolaris.org/os/licensing.
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# See the License for the specific language governing permissions
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# and limitations under the License.
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# When distributing Covered Code, include this CDDL HEADER in each
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# If applicable, add the following below this CDDL HEADER, with the
4f6469885c3d66367e3f8fb94e1f3c66115990b0Mark Andrews# fields enclosed by brackets "[]" replaced with your own identifying
4f6469885c3d66367e3f8fb94e1f3c66115990b0Mark Andrews# information: Portions Copyright [yyyy] [name of copyright owner]
4f6469885c3d66367e3f8fb94e1f3c66115990b0Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# CDDL HEADER END
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# Copyright 2007 Sun Microsystems, Inc. All rights reserved.
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# Use is subject to license terms.
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#ident "%Z%%M% %I% %E% SMI"
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# This makefile drives the production of the ibdm kernel module.
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# sparc architecture dependent
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# Path to the base of the uts directory tree (usually /usr/src/uts).
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsUTSBASE = ../..
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# Define the module and object file sets.
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsMODULE = ibdm
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsOBJECTS = $(IBDM_OBJS:%=$(OBJS_DIR)/%)
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsLINTS = $(IBDM_OBJS:%.o=$(LINTS_DIR)/%.ln)
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsROOTMODULE = $(ROOT_MISC_DIR)/$(MODULE)
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsWARLOCK_OUT = $(IBDM_OBJS:%.o=%.ll)
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsWARLOCK_OK = $(MODULE).ok
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# Include common rules.
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrewsinclude $(UTSBASE)/sparc/Makefile.sparc
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# Define targets
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsALL_TARGET = $(BINARY)
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsLINT_TARGET = $(MODULE).lint
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsINSTALL_TARGET = $(BINARY) $(ROOTMODULE)
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# Overrides.
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsALL_BUILDS = $(ALL_BUILDSONLY64)
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsDEF_BUILDS = $(DEF_BUILDSONLY64)
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# lint pass one enforcement
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsCFLAGS += $(CCVERBOSE)
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# depends on misc/ibtl, and misc/ibmf
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsLDFLAGS += -dy -Nmisc/ibtl -Nmisc/ibmf
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# For now, disable these lint checks; maintainers should endeavor
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# to investigate and remove these for maximum lint coverage.
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# Please do not carry these forward to new Makefiles.
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsLINTTAGS += -erroff=E_BAD_PTR_CAST_ALIGN
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# Default build targets.
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews.KEEP_STATE:
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrewsdef: $(DEF_DEPS)
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrewsall: $(ALL_DEPS)
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrewsclean: $(CLEAN_DEPS)
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews $(RM) $(WARLOCK_OUT) $(WARLOCK_OK)
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrewsclobber: $(CLOBBER_DEPS)
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews $(RM) $(WARLOCK_OUT) $(WARLOCK_OK)
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrewslint: $(LINT_DEPS)
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrewsmodlintlib: $(MODLINTLIB_DEPS) lint32
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrewsclean.lint: $(CLEAN_LINT_DEPS)
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrewsinstall: $(INSTALL_DEPS)
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# Include common targets.
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrewsinclude $(UTSBASE)/sparc/Makefile.targ
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews# Defines for local commands.
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews#
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsWARLOCK = warlock
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsWLCC = wlcc
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsTOUCH = touch
3eb9ec750c9088869170dda63e8899b2ba462823Mark AndrewsTEST = test
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrewswarlock: $(WARLOCK_OK)
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews$(WARLOCK_OK): $(WARLOCK_OUT)
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews $(TOUCH) $@
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews%.ll: $(UTSBASE)/common/io/ib/mgt/ibdm/%.c \
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews $(UTSBASE)/common/sys/ib/mgt/ibdm/ibdm_impl.h \
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews $(UTSBASE)/common/sys/ib/mgt/ibdm/ibdm_ibnex.h
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews $(WLCC) $(CPPFLAGS) -DDEBUG -o $@ $<
3eb9ec750c9088869170dda63e8899b2ba462823Mark Andrews