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/hxge/Makefile 22# 23# Copyright 2008 Sun Microsystems, Inc. All rights reserved. 24# Use is subject to license terms. 25# 26# 27# ident "%Z%%M% %I% %E% SMI" 28# 29# This makefile drives the production of the Sun 30# 10G hxge Ethernet leaf driver 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 = hxge 41HXGE_OBJECTS = $(HXGE_OBJS) $(HXGE_HPI_OBJS) 42OBJECTS = $(HXGE_OBJECTS:%=$(OBJS_DIR)/%) 43LINTS = $(HXGE_OBJECTS:%.o=$(LINTS_DIR)/%.ln) 44ROOTMODULE = $(ROOT_DRV_DIR)/$(MODULE) 45CONF_SRCDIR = $(UTSBASE)/common/io/hxge 46 47# 48# Include common rules. 49# 50include $(UTSBASE)/intel/Makefile.intel 51 52# 53# Override defaults to build a unique, local modstubs.o. 54# 55MODSTUBS_DIR = $(OBJS_DIR) 56 57CLEANFILES += $(MODSTUBS_O) 58 59# 60# Define targets 61# 62ALL_TARGET = $(BINARY) 63LINT_TARGET = $(MODULE).lint 64INSTALL_TARGET = $(BINARY) $(ROOTMODULE) $(ROOT_CONFFILE) 65 66# 67# 68# Turn on doubleword alignment for 64 bit registers 69# 70CFLAGS += -dalign 71# 72# Include hxge specific header files 73# 74INC_PATH += -I$(UTSBASE)/common 75INC_PATH += -I$(UTSBASE)/common/io/hxge 76# 77# 78# lint pass one enforcement 79# 80CFLAGS += -DSOLARIS 81# 82# Debug flags 83# 84# CFLAGS += -DHXGE_DEBUG -DHPI_DEBUG 85# 86# 64 bit only 87# 88ALL_BUILDS = $(ALL_BUILDS64) 89DEF_BUILDS = $(DEF_BUILDS64) 90CLEANLINTFILES += $(LINT64_FILES) 91# 92LINTFLAGS += -DSOLARIS 93# 94# STREAMS, DDI API limitations and other ON header file definitions such as ethernet.h 95# force us to turn off these lint checks. 96# 97LINTTAGS += -erroff=E_BAD_PTR_CAST_ALIGN 98LINTTAGS += -erroff=E_PTRDIFF_OVERFLOW 99LINTTAGS += -erroff=E_FALSE_LOGICAL_EXPR 100# 101# Driver depends on mac & IP 102# 103LDFLAGS += -dy -N misc/mac -N drv/ip 104 105# 106# Default build targets. 107# 108.KEEP_STATE: 109 110def: $(DEF_DEPS) 111 112all: $(ALL_DEPS) 113 114clean: $(CLEAN_DEPS) 115 116clobber: $(CLOBBER_DEPS) 117 118lint: $(LINT_DEPS) 119 120modlintlib: $(MODLINTLIB_DEPS) lint32 121 122clean.lint: $(CLEAN_LINT_DEPS) 123 124install: $(INSTALL_DEPS) 125 126# 127# Include common targets. 128# 129include $(UTSBASE)/intel/Makefile.targ 130 131# 132# This is a hack to avoid a lint warning in the nightly build due to 133# lack of a 32 bit version of the hxge driver. This will be removed 134# when the 32 bit driver is available. 135# 136LINT32_DIRS=$(LINT32_BUILDS:%=$(UTSBASE)/intel/lint-libs/%) 137LINT32_FILES=$(LINT32_DIRS:%=%/llib-l$(MODULE).ln) 138