xref: /titanic_44/usr/src/uts/i86xpv/npe/Makefile (revision cb56572868bfc488bbd3ab847b09db2a25554d44)
1843e1988Sjohnlev#
2843e1988Sjohnlev# CDDL HEADER START
3843e1988Sjohnlev#
4843e1988Sjohnlev# The contents of this file are subject to the terms of the
5843e1988Sjohnlev# Common Development and Distribution License (the "License").
6843e1988Sjohnlev# You may not use this file except in compliance with the License.
7843e1988Sjohnlev#
8843e1988Sjohnlev# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9843e1988Sjohnlev# or http://www.opensolaris.org/os/licensing.
10843e1988Sjohnlev# See the License for the specific language governing permissions
11843e1988Sjohnlev# and limitations under the License.
12843e1988Sjohnlev#
13843e1988Sjohnlev# When distributing Covered Code, include this CDDL HEADER in each
14843e1988Sjohnlev# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15843e1988Sjohnlev# If applicable, add the following below this CDDL HEADER, with the
16843e1988Sjohnlev# fields enclosed by brackets "[]" replaced with your own identifying
17843e1988Sjohnlev# information: Portions Copyright [yyyy] [name of copyright owner]
18843e1988Sjohnlev#
19843e1988Sjohnlev# CDDL HEADER END
20843e1988Sjohnlev#
21843e1988Sjohnlev
22843e1988Sjohnlev#
2326947304SEvan Yan# Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
24843e1988Sjohnlev# Use is subject to license terms.
25843e1988Sjohnlev#
26*cb565728SJerry Jelinek# Copyright 2016 Joyent, Inc.
27*cb565728SJerry Jelinek#
28843e1988Sjohnlev#	This makefile drives the production of the PCI-E nexus driver
29843e1988Sjohnlev#
30843e1988Sjohnlev#	i86xpv implementation architecture dependent
31843e1988Sjohnlev#
32843e1988Sjohnlev
33843e1988Sjohnlev#
34843e1988Sjohnlev#	Path to the base of the uts directory tree (usually /usr/src/uts).
35843e1988Sjohnlev#
36843e1988SjohnlevUTSBASE	= ../..
37843e1988Sjohnlev
38843e1988Sjohnlev#
39843e1988Sjohnlev#	Define the module and object file sets.
40843e1988Sjohnlev#
41843e1988SjohnlevMODULE		= npe
42843e1988SjohnlevOBJECTS		= $(PCI_E_NEXUS_OBJS:%=$(OBJS_DIR)/%)
43843e1988SjohnlevLINTS		= $(PCI_E_NEXUS_OBJS:%.o=$(LINTS_DIR)/%.ln)
44843e1988SjohnlevROOTMODULE	= $(ROOT_PSM_DRV_DIR)/$(MODULE)
45843e1988Sjohnlev
46843e1988Sjohnlev#
47843e1988Sjohnlev#	Include common rules.
48843e1988Sjohnlev#
49843e1988Sjohnlevinclude $(UTSBASE)/i86xpv/Makefile.i86xpv
50843e1988Sjohnlev
51843e1988Sjohnlev#
52843e1988Sjohnlev#	Define targets
53843e1988Sjohnlev#
54843e1988SjohnlevALL_TARGET	= $(BINARY)
55843e1988SjohnlevLINT_TARGET	= $(MODULE).lint
56843e1988SjohnlevINSTALL_TARGET	= $(BINARY) $(ROOTMODULE)
57843e1988Sjohnlev
58843e1988Sjohnlev#
5926947304SEvan Yan# depends on misc/acpica and misc/pcie
60843e1988Sjohnlev#
61843e1988Sjohnlev# acpica supplies ACPI access routines
62843e1988Sjohnlev#
6326947304SEvan Yan# pcie supplies PCI Express fabric error support
6426947304SEvan Yan#
6526947304SEvan YanLDFLAGS	+= -dy -Nmisc/acpica -Nmisc/pcie
66843e1988Sjohnlev
67843e1988Sjohnlev#
68843e1988Sjohnlev# Name of the module is needed by the source, to distinguish from other
69843e1988Sjohnlev# PCI/PCI-express nexi
70843e1988Sjohnlev#
71843e1988SjohnlevCFLAGS		+= -D_MODULE_NAME="\"$(MODULE)\""
72843e1988SjohnlevLINTFLAGS	+= -D_MODULE_NAME="\"$(MODULE)\""
73843e1988Sjohnlev
74843e1988SjohnlevLINTTAGS	+= -erroff=E_ASSIGN_NARROW_CONV
75843e1988SjohnlevLINTTAGS	+= -erroff=E_SUSPICIOUS_COMPARISON
76843e1988Sjohnlev
777014882cSRichard LoweCERRWARN	+= -_gcc=-Wno-uninitialized
787014882cSRichard LoweCERRWARN	+= -_gcc=-Wno-parentheses
79*cb565728SJerry JelinekCERRWARN	+= -_gcc=-Wno-unused-function
807014882cSRichard Lowe
81843e1988Sjohnlev#
82843e1988Sjohnlev#	Default build targets.
83843e1988Sjohnlev#
84843e1988Sjohnlev.KEEP_STATE:
85843e1988Sjohnlev
86843e1988Sjohnlevdef:		$(DEF_DEPS)
87843e1988Sjohnlev
88843e1988Sjohnlevall:		$(ALL_DEPS)
89843e1988Sjohnlev
90843e1988Sjohnlevclean:		$(CLEAN_DEPS)
91843e1988Sjohnlev
92843e1988Sjohnlevclobber:	$(CLOBBER_DEPS)
93843e1988Sjohnlev
94843e1988Sjohnlevlint:		$(LINT_DEPS)
95843e1988Sjohnlev
96843e1988Sjohnlevmodlintlib:	$(MODLINTLIB_DEPS)
97843e1988Sjohnlev
98843e1988Sjohnlevclean.lint:	$(CLEAN_LINT_DEPS)
99843e1988Sjohnlev
100843e1988Sjohnlevinstall:	$(INSTALL_DEPS)
101843e1988Sjohnlev
102843e1988Sjohnlev#
103843e1988Sjohnlev#	Include common targets.
104843e1988Sjohnlev#
105843e1988Sjohnlevinclude $(UTSBASE)/i86xpv/Makefile.targ
106