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# 22# Copyright 2008 Sun Microsystems, Inc. All rights reserved. 23# Use is subject to license terms. 24# 25# Copyright (c) 2018, Joyent, Inc. 26 27 28# 29# This makefile drives the production of NS/SiS 30# Fast Ethernet (SFE) driver module in intel systems 31# 32 33# 34# Path to the base of the uts directory tree (usually /usr/src/uts). 35# 36UTSBASE = ../.. 37 38# 39# Define the module and object file sets. 40# 41MODULE = sfe 42OBJECTS = $(SFE_OBJS:%=$(OBJS_DIR)/%) 43LINTS = $(SFE_OBJS:%.o=$(LINTS_DIR)/%.ln) 44ROOTMODULE = $(ROOT_DRV_DIR)/$(MODULE) 45 46# 47# Include common rules. 48# 49include $(UTSBASE)/intel/Makefile.intel 50 51# 52# Define targets 53# 54ALL_TARGET = $(BINARY) 55LINT_TARGET = $(MODULE).lint 56INSTALL_TARGET = $(BINARY) $(ROOTMODULE) 57 58# 59# GENERAL PURPOUSE GEM FLAGS: Tuning GEM for Solaris specific modes 60# 61VFLAGS = -DVERSION='"2.6.1"' 62AFLAGS = -Di86pc 63DFLAGS = -D"__INLINE__=" 64CFGFLAGS = -DGEM_CONFIG_POLLING -DGEM_CONFIG_GLDv3 -DGEM_CONFIG_VLAN \ 65 -DGEM_CONFIG_CKSUM_OFFLOAD -DGEM_CONFIG_ND \ 66 -DCONFIG_DP83815 -DCONFIG_SIS900 -DCONFIG_SIS7016 \ 67 -DCONFIG_MAC_ADDR_SIS630E -DCONFIG_OPT_IO -UCONFIG_OO \ 68 -DCONFIG_PATTERN_MATCH_DP83815 69# 70# FAST PATH SECTION: Will activate usage of inlines as a regular functions 71# on fast data path 72 73CPPFLAGS += $(VFLAGS) $(AFLAGS) $(DFLAGS) $(CFGFLAGS) $(CCVERBOSE) \ 74 -I$(UTSBASE)/common/io/sfe 75 76CFLAGS += $(CPPFLAGS) 77 78CERRWARN += -_gcc=-Wno-unused-label 79CERRWARN += -_gcc=-Wno-switch 80CERRWARN += -_gcc=-Wno-parentheses 81CERRWARN += -_gcc=-Wno-uninitialized 82 83# needs work 84SMOFF += all_func_returns 85 86# 87# Driver depends on MAC & IP 88# 89LDFLAGS += -dy -N misc/mac -N drv/ip 90 91# 92# Default build targets. 93# 94.KEEP_STATE: 95 96def: $(DEF_DEPS) 97 98all: $(ALL_DEPS) 99 100clean: $(CLEAN_DEPS) 101 102clobber: $(CLOBBER_DEPS) 103 104lint: $(LINT_DEPS) 105 106modlintlib: $(MODLINTLIB_DEPS) 107 108clean.lint: $(CLEAN_LINT_DEPS) 109 110install: $(INSTALL_DEPS) 111 112# 113# Include common targets. 114# 115include $(UTSBASE)/intel/Makefile.targ 116