xref: /illumos-gate/usr/src/uts/intel/nxge/Makefile (revision 12042ab213b3af68474f48555504db816a449211)
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# uts/intel/nxge/Makefile
22#
23# Copyright (c) 2007, 2010, Oracle and/or its affiliates. All rights reserved.
24#
25# Copyright (c) 2018, Joyent, Inc.
26
27#
28#	Path to the base of the uts directory tree (usually /usr/src/uts).
29#
30UTSBASE	= ../..
31
32#
33#	Define the module and object file sets.
34#
35MODULE		= nxge
36NXGE_OBJECTS =	$(NXGE_OBJS) $(NXGE_NPI_OBJS)
37OBJECTS		=  $(NXGE_OBJECTS:%=$(OBJS_DIR)/%)
38LINTS		= $(NXGE_OBJECTS:%.o=$(LINTS_DIR)/%.ln)
39ROOTMODULE	= $(ROOT_DRV_DIR)/$(MODULE)
40CONF_SRCDIR	= $(UTSBASE)/common/io/nxge
41
42#
43#	Include common rules.
44#
45include $(UTSBASE)/intel/Makefile.intel
46
47#
48#	Override defaults to build a unique, local modstubs.o.
49#
50MODSTUBS_DIR	= $(OBJS_DIR)
51
52CLEANFILES	+= $(MODSTUBS_O)
53
54#
55#	Define targets
56#
57ALL_TARGET	= $(BINARY)
58LINT_TARGET	= $(MODULE).lint
59INSTALL_TARGET	= $(BINARY) $(ROOTMODULE) $(ROOT_CONFFILE)
60
61#
62# Include nxge specific header files
63#
64INC_PATH	+= -I$(UTSBASE)/common
65INC_PATH	+= -I$(UTSBASE)/common/io/nxge/npi
66INC_PATH	+= -I$(UTSBASE)/common/sys/nxge
67INC_PATH	+= -I$(UTSBASE)/sun4v
68#
69#
70# lint pass one enforcement
71#
72CFLAGS += -DSOLARIS
73#
74#ALL_BUILDS      = $(ALL_BUILDS64)
75#DEF_BUILDS      = $(DEF_BUILDS64)
76#CLEANLINTFILES  += $(LINT64_FILES)
77#
78LINTFLAGS += -DSOLARIS
79#
80# STREAMS, DDI API limitations and other ON header file definitions such as ethernet.h
81# force us to turn off these lint checks.
82#
83LINTTAGS	+= -erroff=E_BAD_PTR_CAST_ALIGN
84LINTTAGS	+= -erroff=E_PTRDIFF_OVERFLOW
85LINTTAGS	+= -erroff=E_FALSE_LOGICAL_EXPR
86
87CERRWARN	+= -_gcc=-Wno-unused-label
88CERRWARN	+= -_gcc=-Wno-parentheses
89CERRWARN	+= -_gcc=-Wno-switch
90CERRWARN	+= $(CNOWARN_UNINIT)
91CERRWARN	+= -_gcc=-Wno-type-limits
92
93# needs work
94SMATCH=off
95
96#
97#	Driver depends on mac & IP
98#
99LDFLAGS		+= -dy -N misc/mac -N drv/ip
100
101#
102#	Default build targets.
103#
104.KEEP_STATE:
105
106def:		$(DEF_DEPS)
107
108all:		$(ALL_DEPS)
109
110clean:		$(CLEAN_DEPS)
111
112clobber:	$(CLOBBER_DEPS)
113
114lint:		$(LINT_DEPS)
115
116modlintlib:	$(MODLINTLIB_DEPS)
117
118clean.lint:	$(CLEAN_LINT_DEPS)
119
120install:	$(INSTALL_DEPS)
121
122#
123#	Include common targets.
124#
125include $(UTSBASE)/intel/Makefile.targ
126