Makefile revision 75d01c9ab5ef6f1bbac9f9d4eb379d5c38583d82
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# CDDL HEADER START
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# The contents of this file are subject to the terms of the
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# Common Development and Distribution License, Version 1.0 only
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# (the "License"). You may not use this file except in compliance
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# with the License.
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# or http://www.opensolaris.org/os/licensing.
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# See the License for the specific language governing permissions
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# and limitations under the License.
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# When distributing Covered Code, include this CDDL HEADER in each
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# If applicable, add the following below this CDDL HEADER, with the
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# fields enclosed by brackets "[]" replaced with your own identifying
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# information: Portions Copyright [yyyy] [name of copyright owner]
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# CDDL HEADER END
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
80e2ca8596e3435bc3b76f3c597833ea0a87f85e#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# Copyright 2005 Sun Microsystems, Inc. All rights reserved.
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# Use is subject to license terms.
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# uts/sparc/audio1575/Makefile
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#pragma ident "%Z%%M% %I% %E% SMI"
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# This makefile drives the production of the M1575 audio driver
628e3cbed6489fa1db545d8524a06cd6535af456Edward Pilatowicz# (audio1575) kernel module.
628e3cbed6489fa1db545d8524a06cd6535af456Edward Pilatowicz#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# Path to the base of the uts directory tree (usually /usr/src/uts).
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edpUTSBASE = ../..
628e3cbed6489fa1db545d8524a06cd6535af456Edward Pilatowicz
628e3cbed6489fa1db545d8524a06cd6535af456Edward Pilatowicz#
628e3cbed6489fa1db545d8524a06cd6535af456Edward Pilatowicz# Define the module and object file sets.
628e3cbed6489fa1db545d8524a06cd6535af456Edward Pilatowicz#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edpMODULE = audio1575
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edpOBJECTS = $(AUDIO1575_OBJS:%=$(OBJS_DIR)/%)
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edpLINTS = $(AUDIO1575_OBJS:%.o=$(LINTS_DIR)/%.ln)
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edpROOTMODULE = $(ROOT_DRV_DIR)/$(MODULE)
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edpCONF_SRCDIR = $(UTSBASE)/sun/io/audio/sada/drv/audio1575
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edpWARLOCK_OBJECTS = $(AUDIO1575_OBJS:%.o=%.ll)
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edpWARLOCK_OK = $(MODULE).ok
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp
80e2ca8596e3435bc3b76f3c597833ea0a87f85e#
628e3cbed6489fa1db545d8524a06cd6535af456Edward Pilatowicz# Include common rules.
80e2ca8596e3435bc3b76f3c597833ea0a87f85e#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edpinclude $(UTSBASE)/sparc/Makefile.sparc
628e3cbed6489fa1db545d8524a06cd6535af456Edward Pilatowicz
628e3cbed6489fa1db545d8524a06cd6535af456Edward Pilatowicz#
628e3cbed6489fa1db545d8524a06cd6535af456Edward Pilatowicz# Overrides, lint pass one enforcement
628e3cbed6489fa1db545d8524a06cd6535af456Edward Pilatowicz#
628e3cbed6489fa1db545d8524a06cd6535af456Edward PilatowiczCFLAGS += $(CCVERBOSE)
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# Depends on misc/audiosup
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edpLDFLAGS += -dy -Nmisc/amsrc2 -Nmisc/mixer -Nmisc/audiosup
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# Define targets
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edpALL_TARGET = $(BINARY) $(SRC_CONFILE)
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edpLINT_TARGET = $(MODULE).lint
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edpINSTALL_TARGET = $(BINARY) $(ROOTMODULE) $(ROOT_CONFFILE_64)
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# Overrides
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edpALL_BUILDS = $(ALL_BUILDSONLY64)
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edpDEF_BUILDS = $(DEF_BUILDSONLY64)
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edpCLEANLINTFILES += $(LINT32_FILES)
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp# Default build targets.
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp#
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp.KEEP_STATE:
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edp
4a75c0c1ad1b9f32a7a423e1f23a8d23ac800de0edpdef: $(DEF_DEPS)
all: $(ALL_DEPS)
clean: $(CLEAN_DEPS); \
$(RM) $(WARLOCK_OBJECTS) $(WARLOCK_OK)
clobber: $(CLOBBER_DEPS); \
$(RM) $(WARLOCK_OBJECTS) $(WARLOCK_OK)
lint: $(LINT_DEPS)
modlintlib: $(MODLINTLIB_DEPS) lint32
clean.lint: $(CLEAN_LINT_DEPS)
install: $(INSTALL_DEPS)
#
# Include common targets.
#
include $(UTSBASE)/sparc/Makefile.targ
#
# Defines for local commands.
#
SCCS = sccs
TEST = test
WLCC = wlcc
TOUCH = touch
WARLOCK = warlock
#
# Mapfile target
#
mapfile:
$(TEST) -f $@ || $(SCCS) get $@
#
# Warlock targets
#
# NOTE: there will be warnings about q_lock which is the simulated
# rwlock of the taskq framework
#
%.wlcmd:
$(TEST) -f $@ || $(SCCS) get $@
warlock: $(WARLOCK_OK)
$(WARLOCK_OK): $(WARLOCK_OBJECTS) warlock_ddi.files \
warlock_audiosup.files warlock_mixer.files warlock_amsrc2.files
$(WARLOCK) -c audio1575_with_sada.wlcmd $(WARLOCK_OBJECTS) \
../audiosup/audio_support.ll ../amsrc2/am_src2.ll \
../mixer/am_main.ll ../mixer/am_ad.ll ../mixer/am_ioctl.ll \
-l ../warlock/ddi_dki_impl.ll
$(TOUCH) $(WARLOCK_OK)
%.ll: $(UTSBASE)/sun/io/audio/sada/drv/audio1575/%.c
$(WLCC) $(CPPFLAGS) -DDEBUG -o $@ $<
warlock_standalone: $(WARLOCK_OBJECTS) warlock_ddi.files audio1575.wlcmd
$(WARLOCK) -c audio1575.wlcmd $(WARLOCK_OBJECTS) \
-l ../warlock/ddi_dki_impl.ll
warlock_ddi.files:
@cd ../warlock; pwd; $(MAKE) warlock
warlock_audiosup.files:
@cd ../audiosup; pwd; $(MAKE) warlock
warlock_amsrc2.files:
@cd ../amsrc2; pwd; $(MAKE) warlock
warlock_mixer.files:
@cd ../mixer; pwd; $(MAKE) warlock