#
# CDDL HEADER START
#
# The contents of this file are subject to the terms of the
# Common Development and Distribution License (the "License").
# You may not use this file except in compliance with the License.
#
# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
# or http://www.opensolaris.org/os/licensing.
# See the License for the specific language governing permissions
# and limitations under the License.
#
# When distributing Covered Code, include this CDDL HEADER in each
# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
# If applicable, add the following below this CDDL HEADER, with the
# fields enclosed by brackets "[]" replaced with your own identifying
# information: Portions Copyright [yyyy] [name of copyright owner]
#
# CDDL HEADER END
#
#
# Copyright 2007 Sun Microsystems, Inc.  All rights reserved.
# Use is subject to license terms.
#
# ident	"%Z%%M%	%I%	%E% SMI"
#
#	This makefile drives the production of the sun4u opl platform
#	module.
#
#	sun4u opl implementation architecture dependent
#
# uts/sun4u/opl/Makefile

#
#	Path to the base of the uts directory tree (usually /usr/src/uts).
#
UTSBASE	= ../..

#
#       Include common rules.
#
include $(UTSBASE)/sun4u/opl/Makefile.opl

def		:=	TARGET= def
all		:=	TARGET= all
install		:=	TARGET= install
install_h	:=	TARGET= install_h
clean		:=	TARGET= clean
clobber		:=	TARGET= clobber
lint		:=	TARGET= lint
lintlib		:=	TARGET= lintlib
modlist		:=	TARGET= modlist
modlist		:=	NO_STATE= -K $$MODSTATE$$$$
modlintlib	:=	TARGET= modlintlib
clean.lint	:=	TARGET= clean.lint
check		:=	TARGET= check

#
#	Default build targets.
#
.KEEP_STATE:

def all clean clobber clean.lint: genassym unix .WAIT \
		$(OPL_CPU_KMODS) $(OPL_KMODS) $(CLOSED_OPL_KMODS)

modlist:	unix $(OPL_CPU_KMODS) $(OPL_KMODS) $(CLOSED_OPL_KMODS)

lintlib:	unix

modlintlib:	$(OPL_KMODS) $(CLOSED_OPL_KMODS)

IMPLEMENTED_PLATFORM	= SUNW,SPARC-Enterprise

# EXPORT DELETE START
#
# aes256 is delivered in the SUNWcryr package which is removed from
# the EXPORT_SRC build.
#
OPL_CRYPTO_LINKS	+= aes256
# EXPORT DELETE END

install: $(ROOT_OPL_DIR) $(USR_OPL_DIR) \
	$(USR_OPL_INC_DIR) \
	$(USR_OPL_SBIN_DIR) \
	$(USR_OPL_SBIN_PRTDIAG) \
	$(USR_OPL_SBIN_TRAPSTAT) \
	$(USR_OPL_SBIN_FRUADM) \
	$(USR_OPL_LIB_DIR) \
	$(OPL_CRYPTO_LINKS) \
	genassym unix .WAIT $(OPL_CPU_KMODS) $(OPL_KMODS) \
	$(CLOSED_OPL_KMODS) $(OPLMSU_OPTION)

genassym unix $(OPL_KMODS) $(OPL_CPU_KMODS): FRC
	@cd $@; pwd; $(MAKE) $(TARGET)

$(CLOSED_OPL_KMODS): FRC
	cd $(CLOSED)/uts/sun4u/opl/$@; pwd; $(MAKE) $(NO_STATE) $(TARGET)

$(OPL_CRYPTO_LINKS): $(ROOT_OPL_CRYPTO_DIR_64)
	-$(RM) $(ROOT_OPL_CRYPTO_DIR_64)/$@
	$(SYMLINK) $(ROOT_US3_CRYPTO_LINK)/$@ $(ROOT_OPL_CRYPTO_DIR_64)/$@

$(OPLMSU_OPTION):	FRC
	@cd $@; pwd; $(MAKE) $(TARGET)

install_h check:	FRC
	@cd sys; pwd; $(MAKE) $(TARGET)

lint:	modlintlib


#
# The 'lint.platmod' target lints the opl platform module against
# the sun4u kernel.  This ends up doing all the kernel cross-checks,
# so it takes a couple of minutes.
# Due to the low ROI, it's not run by default, but it's a good
# idea to run this if you change os/opl.c.
#

LINT_LIBS	= $(LINT_LIB) \
		  -L$(OPL_LINT_LIB_DIR) \
		  -L$(LINT_LIB_DIR) $(LINT_KMODS:%=-l%) \
		      $(CLOSED_LINT_KMODS:%=-l%) \
		  -L$(SPARC_LIB_DIR) $(SPARC_LINTS:%=-l%)

lint.platmod:   modlintlib
	@-$(ECHO) "\nOpl Platform-dependent module: global crosschecks:"
	@-$(LINT) $(LINTFLAGS) $(LINT_LIBS) 2>&1 | $(LGREP.2)

# EXPORT DELETE START

EXPORT_SRC:
	$(RM) Makefile+
	$(SED) -e "/^# EXPORT DELETE START/,/^# EXPORT DELETE END/d" \
	    < Makefile > Makefile+
	$(MV) Makefile+ Makefile
	$(CHMOD) 444 Makefile

# EXPORT DELETE END

#
#
#	Include common targets.
#
include $(UTSBASE)/sun4u/opl/Makefile.targ