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 2010 Sun Microsystems, Inc. All rights reserved. 23# Use is subject to license terms. 24# 25# Copyright (c) 2018, Joyent, Inc. 26 27# 28# This file makes the atheros driver for an intel system 29# 30# intel architecture dependent 31# 32 33# 34# Path to the base of the uts directory tree (usually /usr/src/uts). 35# 36UTSBASE = ../.. 37# 38# Define the module and object file sets. 39# 40MODULE = ath 41OBJECTS = $(ATH_OBJS:%=$(OBJS_DIR)/%) $(OBJS_DIR)/hal.o 42 43ROOTMODULE = $(ROOT_DRV_DIR)/$(MODULE) 44 45# 46# Include common rules. 47# 48include $(UTSBASE)/intel/Makefile.intel 49 50# 51# Define targets 52# 53ALL_TARGET = $(BINARY) 54INSTALL_TARGET = $(BINARY) $(ROOTMODULE) 55 56# 57# Driver depends on GLDv3 & wifi kernel support module. 58# 59LDFLAGS += -Nmisc/mac -Nmisc/net80211 60 61CERRWARN += -_gcc=-Wno-type-limits 62CERRWARN += -_gcc=-Wno-unused-variable 63CERRWARN += -_gcc=-Wno-empty-body 64 65# needs work 66$(OBJS_DIR)/ath_rate.o := SMOFF += index_overflow 67 68# 69# Default build targets. 70# 71.KEEP_STATE: 72 73def: $(DEF_DEPS) 74 75all: $(ALL_DEPS) 76 77clean: $(CLEAN_DEPS) 78 79clobber: $(CLOBBER_DEPS) 80 81install: $(INSTALL_DEPS) 82 83# 84# Include common targets. 85# 86include $(UTSBASE)/intel/Makefile.targ 87 88# 89# If you have any special case that general 90# Makefile rules don't serve for you, just do 91# it yourself. 92# 93# The amd64 version of this object has the .eh_frame section tagged 94# as SHT_PROGBITS, while the ABI requires SHT_AMD64_UNWIND. The Solaris 95# ld enforces this, so use elfedit to bring the object in line with 96# this requirement. 97# 98ATHEROS_HAL=$(UTSBASE)/common/io/ath/hal_x86_$(CLASS).o.uu 99$(OBJS_DIR)/hal.o: $(ATHEROS_HAL) 100 uudecode -o $@ $(ATHEROS_HAL) 101 if [ `elfedit -r -e 'ehdr:e_machine' $@` = EM_AMD64 ]; \ 102 then elfedit -e 'shdr:sh_type .eh_frame SHT_AMD64_UNWIND' $@; fi 103