Makefile revision b6805bf78d2bbbeeaea8909a05623587b42d58b3
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek#
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek# CDDL HEADER START
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek#
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek# The contents of this file are subject to the terms of the
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek# Common Development and Distribution License (the "License").
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek# You may not use this file except in compliance with the License.
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek#
8d00718b943ab8b326320feb50820f0663031817Stephen Gallagher# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek# or http://www.opensolaris.org/os/licensing.
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek# See the License for the specific language governing permissions
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek# and limitations under the License.
8d00718b943ab8b326320feb50820f0663031817Stephen Gallagher#
8d00718b943ab8b326320feb50820f0663031817Stephen Gallagher# When distributing Covered Code, include this CDDL HEADER in each
8d00718b943ab8b326320feb50820f0663031817Stephen Gallagher# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
8d00718b943ab8b326320feb50820f0663031817Stephen Gallagher# If applicable, add the following below this CDDL HEADER, with the
8d00718b943ab8b326320feb50820f0663031817Stephen Gallagher# fields enclosed by brackets "[]" replaced with your own identifying
8d00718b943ab8b326320feb50820f0663031817Stephen Gallagher# information: Portions Copyright [yyyy] [name of copyright owner]
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek#
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek# CDDL HEADER END
8d00718b943ab8b326320feb50820f0663031817Stephen Gallagher#
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek#
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek# uts/intel/hwa1480_fw/Makefile
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek# Copyright 2009 Sun Microsystems, Inc. All rights reserved.
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek# Use is subject to license terms.
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek#
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek#
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek# This makefile drives the production of the hwa1480_fw kernel module.
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek#
8d00718b943ab8b326320feb50820f0663031817Stephen Gallagher#
8d00718b943ab8b326320feb50820f0663031817Stephen Gallagher# Path to the base of the uts directory tree (usually /usr/src/uts).
8d00718b943ab8b326320feb50820f0663031817Stephen Gallagher#
8d00718b943ab8b326320feb50820f0663031817Stephen GallagherUTSBASE = ../..
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek#
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek# Define the module and object file sets.
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek#
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub HrozekMODULE = hwa1480_fw
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub HrozekOBJECTS = $(WUSB_FWMOD_OBJS:%=$(OBJS_DIR)/%)
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub HrozekLINTS = $(WUSB_FWMOD_OBJS:%.o=$(LINTS_DIR)/%.ln)
8d00718b943ab8b326320feb50820f0663031817Stephen GallagherROOTMODULE = $(ROOT_MISC_DIR)/$(MODULE)
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub HrozekWARLOCK_OUT = $(WUSB_FWMOD_OBJS:%.o=%.ll)
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub HrozekWARLOCK_OK = $(MODULE).ok
8d00718b943ab8b326320feb50820f0663031817Stephen Gallagher
8d00718b943ab8b326320feb50820f0663031817Stephen GallagherFWOBJ = $(OBJS_DIR)/$(MODULE).o
8d00718b943ab8b326320feb50820f0663031817Stephen Gallagher
8d00718b943ab8b326320feb50820f0663031817Stephen GallagherOBJECTS += $(FWOBJ)
8d00718b943ab8b326320feb50820f0663031817Stephen Gallagher
8d00718b943ab8b326320feb50820f0663031817Stephen Gallagher#
8d00718b943ab8b326320feb50820f0663031817Stephen Gallagher# Include common rules.
8d00718b943ab8b326320feb50820f0663031817Stephen Gallagher#
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozekinclude $(UTSBASE)/intel/Makefile.intel
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub HrozekLDFLAGS =
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek#
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek# Define targets
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek#
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub HrozekALL_TARGET = $(BINARY)
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub HrozekLINT_TARGET = $(MODULE).lint
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub HrozekINSTALL_TARGET = $(BINARY) $(ROOTMODULE)
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek#
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek# For now, disable these lint checks; maintainers should endeavor
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek# to investigate and remove these for maximum lint coverage.
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek# Please do not carry these forward to new Makefiles.
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek#
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub HrozekLINTTAGS += -erroff=E_BAD_PTR_CAST_ALIGN
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub HrozekLINTTAGS += -erroff=E_PTRDIFF_OVERFLOW
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub HrozekLINTTAGS += -erroff=E_ASSIGN_NARROW_CONV
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub HrozekLINTTAGS += -erroff=E_STATIC_UNUSED
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub HrozekCLEANFILES += $(WARLOCK_OUT) $(WARLOCK_OK)
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub HrozekCLOBBERFILES += $(BINSRC)/$(MODULE)
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek#
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek# Default build targets.
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek#
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek.KEEP_STATE:
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozekdef: $(DEF_DEPS) $(FWOBJ)
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozekall: $(ALL_DEPS)
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozekclean: $(CLEAN_DEPS)
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozekclobber: $(CLOBBER_DEPS)
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozeklint: $(LINT_DEPS)
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozekmodlintlib: $(MODLINTLIB_DEPS)
530ba03ecabb472f17d5d1ab546aec9390492de1Jakub Hrozek
clean.lint: $(CLEAN_LINT_DEPS)
install: $(INSTALL_DEPS)
# customized section for transforming firmware binary
ELFWRAP = elfwrap
BINSRC = $(UTSBASE)/common/io/usb/clients/hwa1480_fw/i1480
ORIGIN_SRC = i1480-usb-0.0.bin
#get build type, 32/64
WRAPTYPE = $(CLASS:%=-%)
#set elfwrap option
WRAPOPT = $(WRAPTYPE:-32=)
$(FWOBJ):
cp $(BINSRC)/$(ORIGIN_SRC) $(BINSRC)/$(MODULE)
$(ELFWRAP) $(WRAPOPT) -o $@ $(BINSRC)/$(MODULE)
#
# Include common targets.
#
include $(UTSBASE)/intel/Makefile.targ
#
# Defines for local commands.
#
WLCC = wlcc
TOUCH = touch
WARLOCK = warlock
#
# Warlock targets
#
warlock: $(WARLOCK_OK)
$(WARLOCK_OK): $(WARLOCK_OUT)
$(TOUCH) $@
%.ll: $(UTSBASE)/common/io/usb/clients/hwa1480_fw/%.c
$(WLCC) $(CPPFLAGS) -DDEBUG -o $@ $<