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 (the "License"). 6# You may not use this file except in compliance with the License. 7# 8# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 9# or http://www.opensolaris.org/os/licensing. 10# See the License for the specific language governing permissions 11# and limitations under the License. 12# 13# When distributing Covered Code, include this CDDL HEADER in each 14# file and include the License file at usr/src/OPENSOLARIS.LICENSE. 15# If applicable, add the following below this CDDL HEADER, with the 16# fields enclosed by brackets "[]" replaced with your own identifying 17# information: Portions Copyright [yyyy] [name of copyright owner] 18# 19# CDDL HEADER END 20# 21# 22# Copyright 2006 Sun Microsystems, Inc. All rights reserved. 23# Use is subject to license terms. 24# 25# uts/sparc/audiots/Makefile 26# 27#ident "%Z%%M% %I% %E% SMI" 28# 29# This makefile drives the production of the T2 audio driver 30# (audiots) kernel module. 31# 32# 33# Path to the base of the uts directory tree (usually /usr/src/uts). 34# 35UTSBASE = ../.. 36 37# 38# Define the module and object file sets. 39# 40MODULE = audiots 41OBJECTS = $(AUDIOTS_OBJS:%=$(OBJS_DIR)/%) 42LINTS = $(AUDIOTS_OBJS:%.o=$(LINTS_DIR)/%.ln) 43ROOTMODULE = $(ROOT_DRV_DIR)/$(MODULE) 44CONF_SRCDIR = $(UTSBASE)/common/io/audio/sada/drv/audiots 45WARLOCK_OUT = $(AUDIOTS_OBJS:%.o=%.ll) 46WARLOCK_OK = $(MODULE).ok 47WLCMD_DIR = $(UTSBASE)/common/io/warlock 48 49# 50# Include common rules. 51# 52include $(UTSBASE)/sparc/Makefile.sparc 53 54# 55# Overrides, lint pass one enforcement 56# 57CFLAGS += $(CCVERBOSE) 58 59# 60# Depends on misc/audiosup 61# 62LDFLAGS += -dy -Nmisc/amsrc2 -Nmisc/mixer -Nmisc/audiosup 63 64# 65# Define targets 66# 67ALL_TARGET = $(BINARY) $(SRC_CONFILE) 68LINT_TARGET = $(MODULE).lint 69INSTALL_TARGET = $(BINARY) $(ROOTMODULE) $(ROOT_CONFFILE_64) 70 71# 72# Overrides 73# 74ALL_BUILDS = $(ALL_BUILDSONLY64) 75DEF_BUILDS = $(DEF_BUILDSONLY64) 76CLEANLINTFILES += $(LINT32_FILES) 77 78# 79# For now, disable these lint checks; maintainers should endeavor 80# to investigate and remove these for maximum lint coverage. 81# Please do not carry these forward to new Makefiles. 82# 83LINTTAGS += -erroff=E_BAD_PTR_CAST_ALIGN 84LINTTAGS += -erroff=E_ASSIGN_NARROW_CONV 85 86# 87# Default build targets. 88# 89.KEEP_STATE: 90 91def: $(DEF_DEPS) 92 93all: $(ALL_DEPS) 94 95clean: $(CLEAN_DEPS) 96 $(RM) $(WARLOCK_OUT) $(WARLOCK_OK) 97 98clobber: $(CLOBBER_DEPS) 99 $(RM) $(WARLOCK_OUT) $(WARLOCK_OK) 100 101lint: $(LINT_DEPS) 102 103modlintlib: $(MODLINTLIB_DEPS) lint32 104 105clean.lint: $(CLEAN_LINT_DEPS) 106 107install: $(INSTALL_DEPS) 108 109# 110# Include common targets. 111# 112include $(UTSBASE)/sparc/Makefile.targ 113 114# 115# Defines for local commands. 116# 117SCCS = sccs 118TEST = test 119WLCC = wlcc 120TOUCH = touch 121WARLOCK = warlock 122 123# 124# Mapfile target 125# 126mapfile: 127 $(TEST) -f $@ || $(SCCS) get $@ 128 129# 130# Warlock targets 131# 132# NOTE: there will be warnings about q_lock which is the simulated 133# rwlock of the taskq framework 134# 135MIXER_FILES = $(MIXER_OBJS:%.o=$(UTSBASE)/sparc/mixer/%.ll) 136AUDIO_SUP_FILES = $(AUDIO_SUP_OBJS:%.o=$(UTSBASE)/sparc/audiosup/%.ll) 137AMSRC2_FILES = $(AMSRC2_OBJS:%.o=$(UTSBASE)/sparc/amsrc2/%.ll) 138 139 140%.wlcmd: 141 cd $(WLCMD_DIR); $(TEST) -f $@ || $(SCCS) get $@ 142 143warlock: $(WARLOCK_OK) 144 145$(WARLOCK_OK): $(WARLOCK_OUT) warlock_ddi.files warlock_standalone \ 146 warlock_audiosup.files warlock_mixer.files warlock_amsrc2.files \ 147 audiots_with_sada.wlcmd warlock_standalone 148 $(WARLOCK) -c $(WLCMD_DIR)/audiots_with_sada.wlcmd $(WARLOCK_OUT) \ 149 $(MIXER_FILES) $(AUDIO_SUP_FILES) $(AMSRC2_FILES) \ 150 -l ../warlock/ddi_dki_impl.ll 151 $(TOUCH) $(WARLOCK_OK) 152 153%.ll: $(UTSBASE)/common/io/audio/sada/drv/audiots/%.c 154 $(WLCC) $(CPPFLAGS) -DDEBUG -o $@ $< 155 156warlock_standalone: $(WARLOCK_OUT) warlock_ddi.files audiots.wlcmd 157 $(WARLOCK) -c $(WLCMD_DIR)/audiots.wlcmd $(WARLOCK_OUT) \ 158 -l ../warlock/ddi_dki_impl.ll 159 160warlock_ddi.files: 161 @cd ../warlock; pwd; $(MAKE) warlock 162 163warlock_audiosup.files: 164 @cd ../audiosup; pwd; $(MAKE) warlock 165 166warlock_amsrc2.files: 167 @cd ../amsrc2; pwd; $(MAKE) warlock 168 169warlock_mixer.files: 170 @cd ../mixer; pwd; $(MAKE) warlock 171