Makefile revision bb25c06cca41ca78e5fb87fbb8e81d55beb18c95
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# CDDL HEADER START
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# The contents of this file are subject to the terms of the
bb25c06cca41ca78e5fb87fbb8e81d55beb18c95jg# Common Development and Distribution License (the "License").
bb25c06cca41ca78e5fb87fbb8e81d55beb18c95jg# You may not use this file except in compliance with the License.
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# or http://www.opensolaris.org/os/licensing.
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# See the License for the specific language governing permissions
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# and limitations under the License.
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# When distributing Covered Code, include this CDDL HEADER in each
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# If applicable, add the following below this CDDL HEADER, with the
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# fields enclosed by brackets "[]" replaced with your own identifying
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# information: Portions Copyright [yyyy] [name of copyright owner]
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# CDDL HEADER END
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
bb25c06cca41ca78e5fb87fbb8e81d55beb18c95jg# Copyright 2006 Sun Microsystems, Inc. All rights reserved.
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# Use is subject to license terms.
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# uts/sparc/audio1575/Makefile
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
bb25c06cca41ca78e5fb87fbb8e81d55beb18c95jg#ident "%Z%%M% %I% %E% SMI"
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# This makefile drives the production of the M1575 audio driver
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# (audio1575) kernel module.
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# Path to the base of the uts directory tree (usually /usr/src/uts).
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smUTSBASE = ../..
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# Define the module and object file sets.
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smMODULE = audio1575
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smOBJECTS = $(AUDIO1575_OBJS:%=$(OBJS_DIR)/%)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smLINTS = $(AUDIO1575_OBJS:%.o=$(LINTS_DIR)/%.ln)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smROOTMODULE = $(ROOT_DRV_DIR)/$(MODULE)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smCONF_SRCDIR = $(UTSBASE)/sun/io/audio/sada/drv/audio1575
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smWARLOCK_OBJECTS = $(AUDIO1575_OBJS:%.o=%.ll)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smWARLOCK_OK = $(MODULE).ok
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# Include common rules.
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sminclude $(UTSBASE)/sparc/Makefile.sparc
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# Overrides, lint pass one enforcement
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smCFLAGS += $(CCVERBOSE)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# Depends on misc/audiosup
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smLDFLAGS += -dy -Nmisc/amsrc2 -Nmisc/mixer -Nmisc/audiosup
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# Define targets
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smALL_TARGET = $(BINARY) $(SRC_CONFILE)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smLINT_TARGET = $(MODULE).lint
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smINSTALL_TARGET = $(BINARY) $(ROOTMODULE) $(ROOT_CONFFILE_64)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# Overrides
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smALL_BUILDS = $(ALL_BUILDSONLY64)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smDEF_BUILDS = $(DEF_BUILDSONLY64)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smCLEANLINTFILES += $(LINT32_FILES)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
bb25c06cca41ca78e5fb87fbb8e81d55beb18c95jg#
bb25c06cca41ca78e5fb87fbb8e81d55beb18c95jg# For now, disable these lint checks; maintainers should endeavor
bb25c06cca41ca78e5fb87fbb8e81d55beb18c95jg# to investigate and remove these for maximum lint coverage.
bb25c06cca41ca78e5fb87fbb8e81d55beb18c95jg# Please do not carry these forward to new Makefiles.
bb25c06cca41ca78e5fb87fbb8e81d55beb18c95jg#
bb25c06cca41ca78e5fb87fbb8e81d55beb18c95jgLINTTAGS += -erroff=E_BAD_PTR_CAST_ALIGN
bb25c06cca41ca78e5fb87fbb8e81d55beb18c95jg
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# Default build targets.
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm.KEEP_STATE:
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smdef: $(DEF_DEPS)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82small: $(ALL_DEPS)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smclean: $(CLEAN_DEPS); \
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm $(RM) $(WARLOCK_OBJECTS) $(WARLOCK_OK)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smclobber: $(CLOBBER_DEPS); \
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm $(RM) $(WARLOCK_OBJECTS) $(WARLOCK_OK)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smlint: $(LINT_DEPS)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smmodlintlib: $(MODLINTLIB_DEPS) lint32
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smclean.lint: $(CLEAN_LINT_DEPS)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sminstall: $(INSTALL_DEPS)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# Include common targets.
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sminclude $(UTSBASE)/sparc/Makefile.targ
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# Defines for local commands.
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smSCCS = sccs
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smTEST = test
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smWLCC = wlcc
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smTOUCH = touch
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smWARLOCK = warlock
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# Mapfile target
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smmapfile:
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm $(TEST) -f $@ || $(SCCS) get $@
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# Warlock targets
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# NOTE: there will be warnings about q_lock which is the simulated
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm# rwlock of the taskq framework
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm#
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm%.wlcmd:
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm $(TEST) -f $@ || $(SCCS) get $@
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smwarlock: $(WARLOCK_OK)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm$(WARLOCK_OK): $(WARLOCK_OBJECTS) warlock_ddi.files \
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm warlock_audiosup.files warlock_mixer.files warlock_amsrc2.files
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm $(WARLOCK) -c audio1575_with_sada.wlcmd $(WARLOCK_OBJECTS) \
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm ../audiosup/audio_support.ll ../amsrc2/am_src2.ll \
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm ../mixer/am_main.ll ../mixer/am_ad.ll ../mixer/am_ioctl.ll \
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm -l ../warlock/ddi_dki_impl.ll
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm $(TOUCH) $(WARLOCK_OK)
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm%.ll: $(UTSBASE)/sun/io/audio/sada/drv/audio1575/%.c
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm $(WLCC) $(CPPFLAGS) -DDEBUG -o $@ $<
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smwarlock_standalone: $(WARLOCK_OBJECTS) warlock_ddi.files audio1575.wlcmd
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm $(WARLOCK) -c audio1575.wlcmd $(WARLOCK_OBJECTS) \
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm -l ../warlock/ddi_dki_impl.ll
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smwarlock_ddi.files:
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm @cd ../warlock; pwd; $(MAKE) warlock
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smwarlock_audiosup.files:
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm @cd ../audiosup; pwd; $(MAKE) warlock
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smwarlock_amsrc2.files:
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm @cd ../amsrc2; pwd; $(MAKE) warlock
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82smwarlock_mixer.files:
75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82sm @cd ../mixer; pwd; $(MAKE) warlock