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 #
  23 # Copyright (c) 2005, 2010, Oracle and/or its affiliates. All rights reserved.
  24 # Copyright (c) 2013 Andrew Stormont.  All rights reserved.
  25 # Copyright (c) 2015, 2017 by Delphix. All rights reserved.
  26 # Copyright (c) 2015, Joyent, Inc. All rights reserved.
  27 # Copyright 2016 Gary Mills
  28 # Copyright 2016 Nexenta Systems, Inc.
  29 #
  30 
  31 #
  32 #       This makefile contains the common definitions for all sparc
  33 #       implementation architecture independent modules.
  34 #
  35 
  36 #
  37 #       Define supported builds
  38 #
  39 DEF_BUILDS      = $(DEF_BUILDS64)
  40 ALL_BUILDS      = $(ALL_BUILDS64)
  41 
  42 #
  43 #       Everybody needs to know how to build modstubs.o and to locate unix.o.
  44 #       Note that unix.o must currently be selected from among the possible
  45 #       "implementation architectures". Note further, that unix.o is only
  46 #       used as an optional error check for undefines so (theoretically)
  47 #       any "implementation architectures" could be used. We choose sun4u
  48 #       because it is the reference port.
  49 #
  50 UNIX_DIR         = $(UTSBASE)/sun4u/unix
  51 GENLIB_DIR       = $(UTSBASE)/sun4u/genunix
  52 IPDRV_DIR        = $(UTSBASE)/sparc/ip
  53 MODSTUBS_DIR     = $(UNIX_DIR)
  54 DSF_DIR          = $(UNIX_DIR)
  55 LINTS_DIR        = $(OBJS_DIR)
  56 LINT_LIB_DIR     = $(UTSBASE)/sparc/lint-libs/$(OBJS_DIR)
  57 
  58 UNIX_O           = $(UNIX_DIR)/$(OBJS_DIR)/unix.o
  59 MODSTUBS_O       = $(MODSTUBS_DIR)/$(OBJS_DIR)/modstubs.o
  60 GENLIB           = $(UTSBASE)/sun4u/lint-libs/$(OBJS_DIR)/libgenunix.so
  61 
  62 LINT_LIB_32      = $(UTSBASE)/sun4u/lint-libs/$(OBJS_DIR)/llib-lunix.ln
  63 GEN_LINT_LIB_32  = $(UTSBASE)/sun4u/lint-libs/$(OBJS_DIR)/llib-lgenunix.ln
  64 
  65 LINT_LIB_64      = $(UTSBASE)/sun4u/lint-libs/$(OBJS_DIR)/llib-lunix.ln
  66 GEN_LINT_LIB_64  = $(UTSBASE)/sun4u/lint-libs/$(OBJS_DIR)/llib-lgenunix.ln
  67 
  68 LINT_LIB         = $(LINT_LIB_$(CLASS))
  69 GEN_LINT_LIB     = $(GEN_LINT_LIB_$(CLASS))
  70 
  71 LINT32_DIRS      = $(LINT32_BUILDS:%=$(UTSBASE)/sparc/lint-libs/%)
  72 LINT32_FILES     = $(LINT32_DIRS:%=%/llib-l$(MODULE).ln)
  73 
  74 LINT64_DIRS      = $(LINT64_BUILDS:%=$(UTSBASE)/sparc/lint-libs/%)
  75 LINT64_FILES     = $(LINT64_DIRS:%=%/llib-l$(MODULE).ln)
  76 
  77 #
  78 #       Include the makefiles which define build rule templates, the
  79 #       collection of files per module, and a few specific flags. Note
  80 #       that order is significant, just as with an include path. The
  81 #       first build rule template which matches the files name will be
  82 #       used. By including these in order from most machine dependent
  83 #       to most machine independent, we allow a machine dependent file
  84 #       to be used in preference over a machine independent version
  85 #       (Such as a machine specific optimization, which preserves the
  86 #       interfaces.)
  87 #
  88 include $(UTSBASE)/sparc/Makefile.files
  89 include $(UTSBASE)/sparc/v9/Makefile.files
  90 include $(UTSBASE)/sun/Makefile.files
  91 include $(UTSBASE)/common/Makefile.files
  92 
  93 #
  94 # ----- TRANSITIONAL SECTION --------------------------------------------------
  95 #
  96 
  97 #
  98 #       Not everything which *should* be a module is a module yet. The
  99 #       following is a list of such objects which are currently part of
 100 #       genunix but which might someday become kmods.   This must be
 101 #       defined before we include Makefile.uts, or else genunix's build
 102 #       won't be as parallel as we might like.
 103 #
 104 NOT_YET_KMODS    = $(OLDPTY_OBJS) $(PTY_OBJS) $(VCONS_CONF_OBJS) $(MOD_OBJS)
 105 
 106 #
 107 # ----- END OF TRANSITIONAL SECTION -------------------------------------------
 108 #
 109 #       Include machine independent rules. Note that this does not imply
 110 #       that the resulting module from rules in Makefile.uts is machine
 111 #       independent. Only that the build rules are machine independent.
 112 #
 113 include $(UTSBASE)/Makefile.uts
 114 
 115 #
 116 #       machine specific optimization, override default in Makefile.master
 117 #
 118 XARCH_32        = -xarch=v8
 119 XARCH_64        = -m64
 120 XARCH           = $(XARCH_$(CLASS))
 121 
 122 COPTIMIZE_32    = -xO3
 123 COPTIMIZE_64    = -xO3
 124 COPTIMIZE       = $(COPTIMIZE_$(CLASS))
 125 
 126 CCMODE          = -Xa
 127 
 128 CFLAGS_32       = -xcg92
 129 CFLAGS_64       = -xchip=ultra $(CCABS32) $(CCREGSYM)
 130 CFLAGS          = $(CFLAGS_$(CLASS))
 131 
 132 CFLAGS          += $(XARCH)
 133 CFLAGS          += $(COPTIMIZE)
 134 CFLAGS          += $(EXTRA_CFLAGS)
 135 CFLAGS          += $(XAOPT)
 136 CFLAGS          += $(INLINES) -D_ASM_INLINES
 137 CFLAGS          += $(CCMODE)
 138 CFLAGS          += $(SPACEFLAG)
 139 CFLAGS          += $(CERRWARN)
 140 CFLAGS          += $(CTF_FLAGS_$(CLASS))
 141 CFLAGS          += $(CSTD)
 142 CFLAGS          += $(CCUNBOUND)
 143 CFLAGS          += $(CCSTATICSYM)
 144 CFLAGS          += $(CC32BITCALLERS)
 145 CFLAGS          += $(CCNOAUTOINLINE)
 146 CFLAGS          += $(IROPTFLAG)
 147 CFLAGS          += $(CGLOBALSTATIC)
 148 CFLAGS          += -xregs=no%float
 149 CFLAGS          += -xstrconst
 150 CFLAGS          += $(CSOURCEDEBUGFLAGS)
 151 CFLAGS          += $(CUSERFLAGS)
 152 
 153 ASFLAGS         += $(XARCH)
 154 
 155 LINT_DEFS_32    =
 156 LINT_DEFS_64    = -m64
 157 LINT_DEFS       += $(LINT_DEFS_$(CLASS))
 158 
 159 #
 160 #       The following must be defined for all implementations:
 161 #
 162 #       MODSTUBS:       Module stubs source file.
 163 #
 164 MODSTUBS         = $(UTSBASE)/sparc/ml/modstubs.s
 165 
 166 #
 167 #       Define the actual specific platforms - obviously none.
 168 #
 169 MACHINE_DEFS     =
 170 
 171 #
 172 #       Debugging level
 173 #
 174 #       Special knowledge of which special debugging options effect which
 175 #       file is used to optimize the build if these flags are changed.
 176 #
 177 #       XXX: The above could possibly be done for more flags and files, but
 178 #            is left as an experiment to the interested reader. Be forewarned,
 179 #            that excessive use could lead to maintenance difficulties.
 180 #
 181 DEBUG_DEFS_OBJ32        =
 182 DEBUG_DEFS_DBG32        = -DDEBUG
 183 DEBUG_DEFS_OBJ64        =
 184 DEBUG_DEFS_DBG64        = -DDEBUG
 185 DEBUG_DEFS              = $(DEBUG_DEFS_$(BUILD_TYPE))
 186 
 187 DEBUG_COND_OBJ32        = $(POUND_SIGN)
 188 DEBUG_COND_DBG32        =
 189 DEBUG_COND_OBJ64        = $(POUND_SIGN)
 190 DEBUG_COND_DBG64        =
 191 IF_DEBUG_OBJ            = $(DEBUG_COND_$(BUILD_TYPE))$(OBJS_DIR)/
 192 
 193 $(IF_DEBUG_OBJ)syscall.o        :=      DEBUG_DEFS      += -DSYSCALLTRACE
 194 $(IF_DEBUG_OBJ)clock.o          :=      DEBUG_DEFS      += -DKSLICE=1
 195 
 196 # Comment these out if you don't want dispatcher lock statistics.
 197 
 198 # $(IF_DEBUG_OBJ)disp_lock.o    := DEBUG_DEFS   += -DDISP_LOCK_STATS
 199 
 200 #
 201 #       Collect the preprocessor definitions to be associated with *all*
 202 #       files.
 203 #
 204 ALL_DEFS         = $(MACHINE_DEFS) $(DEBUG_DEFS) $(OPTION_DEFS)
 205 
 206 #
 207 #       TCP congestion control modules (/kernel/cc)
 208 #
 209 CC_KMODS       += cc_newreno cc_cubic cc_sunreno
 210 
 211 #
 212 #
 213 #       The kernels modules which are "implementation architecture"
 214 #       specific for this machine are enumerated below. Note that most
 215 #       of these modules must exist (in one form or another) for each
 216 #       architecture.
 217 #
 218 #       Common Drivers (usually pseudo drivers) (/kernel/drv):
 219 #
 220 DRV_KMODS       += aggr arp audio bl blkdev bofi clone cn conskbd consms cpuid
 221 DRV_KMODS       += crypto cryptoadm devinfo dump
 222 DRV_KMODS       += dtrace fasttrap fbt lockstat profile sdt systrace dcpc
 223 DRV_KMODS       += fssnap icmp icmp6 ip ip6 ipnet ipsecah
 224 DRV_KMODS       += ipsecesp iptun iwscn keysock kmdb kstat ksyms llc1
 225 DRV_KMODS       += lofi
 226 DRV_KMODS       += log logindmux kssl mm nca physmem pm poll pool
 227 DRV_KMODS       += pseudo ptc ptm pts ptsl ramdisk random rsm rts sad
 228 DRV_KMODS       += simnet softmac sppp sppptun sy sysevent sysmsg
 229 DRV_KMODS       += spdsock
 230 DRV_KMODS       += tcp tcp6 timerfd tl tnf ttymux udp udp6 wc winlock zcons zfd
 231 DRV_KMODS       += ippctl
 232 DRV_KMODS       += dld
 233 DRV_KMODS       += ipd
 234 DRV_KMODS       += ipf
 235 DRV_KMODS       += rpcib
 236 DRV_KMODS       += dlpistub
 237 DRV_KMODS       += vnic
 238 DRV_KMODS       += xge
 239 DRV_KMODS       += rds
 240 DRV_KMODS       += rdsv3
 241 DRV_KMODS       += chxge
 242 DRV_KMODS       += smbsrv
 243 DRV_KMODS       += vscan
 244 DRV_KMODS       += nsmb
 245 DRV_KMODS       += fm
 246 DRV_KMODS       += nulldriver
 247 DRV_KMODS       += bridge trill
 248 DRV_KMODS       += bpf
 249 DRV_KMODS       += dca
 250 DRV_KMODS       += inotify
 251 DRV_KMODS       += eventfd
 252 DRV_KMODS       += signalfd
 253 DRV_KMODS       += timerfd
 254 
 255 #
 256 #       Hardware Drivers in common space
 257 #
 258 
 259 DRV_KMODS       += afe
 260 DRV_KMODS       += audio1575
 261 DRV_KMODS       += audioens
 262 DRV_KMODS       += audiols
 263 DRV_KMODS       += audiop16x
 264 DRV_KMODS       += audiopci
 265 DRV_KMODS       += audiots
 266 DRV_KMODS       += bnxe
 267 DRV_KMODS       += e1000g
 268 DRV_KMODS       += efe
 269 DRV_KMODS       += hxge
 270 DRV_KMODS       += mxfe
 271 DRV_KMODS       += rge
 272 DRV_KMODS       += rtls
 273 DRV_KMODS       += sfe
 274 DRV_KMODS       += aac
 275 DRV_KMODS       += igb
 276 DRV_KMODS       += ixgbe
 277 DRV_KMODS       += vr
 278 DRV_KMODS       += mr_sas
 279 DRV_KMODS       += yge
 280 
 281 #
 282 #       Machine Specific Driver Modules (/kernel/drv):
 283 #
 284 DRV_KMODS       += audiocs
 285 DRV_KMODS       += bge dmfe eri fas hme qfe
 286 DRV_KMODS       += openeepr options sd ses st
 287 DRV_KMODS       += ssd
 288 DRV_KMODS       += ecpp
 289 DRV_KMODS       += hid hubd ehci ohci uhci usb_mid usb_ia scsa2usb usbprn ugen
 290 DRV_KMODS       += usbser usbsacm usbsksp usbsprl
 291 DRV_KMODS       += usb_as usb_ac
 292 DRV_KMODS       += usbskel
 293 DRV_KMODS       += usbvc
 294 DRV_KMODS       += usbftdi
 295 DRV_KMODS       += usbecm
 296 DRV_KMODS       += hci1394 av1394 scsa1394 dcam1394
 297 DRV_KMODS       += sbp2
 298 DRV_KMODS       += ib ibp eibnx eoib rdsib sdp iser daplt hermon tavor sol_ucma sol_uverbs
 299 DRV_KMODS       += sol_umad
 300 DRV_KMODS       += pci_pci pcieb pcieb_bcm
 301 DRV_KMODS       += i8042 kb8042 mouse8042
 302 DRV_KMODS       += fcode
 303 DRV_KMODS       += mpt_sas
 304 DRV_KMODS       += socal
 305 DRV_KMODS       += sgen
 306 DRV_KMODS       += myri10ge
 307 DRV_KMODS       += smp
 308 DRV_KMODS       += dad
 309 DRV_KMODS       += scsi_vhci
 310 DRV_KMODS       += fcp
 311 DRV_KMODS       += fcip
 312 DRV_KMODS       += fcsm
 313 DRV_KMODS       += fp
 314 DRV_KMODS       += qlc
 315 DRV_KMODS       += qlge
 316 DRV_KMODS       += stmf
 317 DRV_KMODS       += stmf_sbd
 318 DRV_KMODS       += fct
 319 DRV_KMODS       += fcoe
 320 DRV_KMODS       += fcoet
 321 DRV_KMODS       += fcoei
 322 DRV_KMODS       += qlt
 323 DRV_KMODS       += iscsit
 324 DRV_KMODS       += pppt
 325 DRV_KMODS       += ncall nsctl sdbc nskern sv
 326 DRV_KMODS       += ii rdc rdcsrv rdcstub
 327 DRV_KMODS       += iscsi
 328 DRV_KMODS       += emlxs
 329 DRV_KMODS       += oce
 330 DRV_KMODS       += srpt
 331 DRV_KMODS       += pmcs
 332 DRV_KMODS       += pmcs8001fw
 333 
 334 #
 335 #       I/O framework test drivers
 336 #
 337 DRV_KMODS       += pshot
 338 DRV_KMODS       += gen_drv
 339 DRV_KMODS       += tvhci tphci tclient
 340 DRV_KMODS       += emul64
 341 
 342 #
 343 # PCMCIA specific module(s)
 344 #
 345 DRV_KMODS       += pcs
 346 MISC_KMODS      += busra cardbus dada pcmcia
 347 DRV_KMODS       += pcic
 348 
 349 #
 350 #       Exec Class Modules (/kernel/exec):
 351 #
 352 EXEC_KMODS      += aoutexec elfexec intpexec shbinexec javaexec
 353 
 354 #
 355 #       Scheduling Class Modules (/kernel/sched):
 356 #
 357 SCHED_KMODS     += RT TS RT_DPTBL TS_DPTBL IA FSS FX FX_DPTBL SDC
 358 
 359 #
 360 #       File System Modules (/kernel/fs):
 361 #
 362 FS_KMODS        += dev devfs fdfs fifofs hsfs lofs namefs nfs pcfs tmpfs zfs
 363 FS_KMODS        += zut specfs udfs ufs autofs procfs sockfs mntfs
 364 FS_KMODS        += ctfs objfs sharefs dcfs smbfs bootfs
 365 
 366 #
 367 #       Streams Modules (/kernel/strmod):
 368 #
 369 STRMOD_KMODS    += bufmod connld dedump ldterm ms pckt pfmod
 370 STRMOD_KMODS    += pipemod ptem redirmod rpcmod rlmod telmod timod
 371 STRMOD_KMODS    += spppasyn spppcomp
 372 STRMOD_KMODS    += tirdwr ttcompat
 373 STRMOD_KMODS    += usbkbm usbms usbwcm usb_ah
 374 STRMOD_KMODS    += drcompat
 375 STRMOD_KMODS    += cryptmod
 376 STRMOD_KMODS    += vuid3ps2
 377 
 378 #
 379 #       'System' Modules (/kernel/sys):
 380 #
 381 SYS_KMODS       += c2audit
 382 SYS_KMODS       += exacctsys
 383 SYS_KMODS       += inst_sync kaio msgsys semsys shmsys sysacct pipe
 384 SYS_KMODS       += doorfs pset acctctl portfs
 385 
 386 #
 387 #       'User' Modules (/kernel/misc):
 388 #
 389 MISC_KMODS      += ac97
 390 MISC_KMODS      += bignum
 391 MISC_KMODS      += consconfig gld ipc nfs_dlboot nfssrv scsi
 392 MISC_KMODS      += strplumb swapgeneric tlimod
 393 MISC_KMODS      += rpcsec rpcsec_gss kgssapi kmech_dummy
 394 MISC_KMODS      += kmech_krb5
 395 MISC_KMODS      += fssnap_if
 396 MISC_KMODS      += hidparser kbtrans usba usba10 usbs49_fw
 397 MISC_KMODS      += s1394
 398 MISC_KMODS      += hpcsvc pcihp
 399 MISC_KMODS      += rsmops
 400 MISC_KMODS      += kcf
 401 MISC_KMODS      += ksocket
 402 MISC_KMODS      += ibcm
 403 MISC_KMODS      += ibdm
 404 MISC_KMODS      += ibdma
 405 MISC_KMODS      += ibmf
 406 MISC_KMODS      += ibtl
 407 MISC_KMODS      += sol_ofs
 408 MISC_KMODS      += idm
 409 MISC_KMODS      += idmap
 410 MISC_KMODS      += hook
 411 MISC_KMODS      += neti
 412 MISC_KMODS      += ctf
 413 MISC_KMODS      += mac dls
 414 MISC_KMODS      += cmlb
 415 MISC_KMODS      += tem
 416 MISC_KMODS      += pcicfg fcodem fcpci
 417 MISC_KMODS      += scsi_vhci_f_sym scsi_vhci_f_tpgs scsi_vhci_f_asym_sun
 418 MISC_KMODS      += scsi_vhci_f_sym_hds
 419 MISC_KMODS      += scsi_vhci_f_tape scsi_vhci_f_tpgs_tape
 420 MISC_KMODS      += fctl
 421 MISC_KMODS      += emlxs_fw
 422 MISC_KMODS      += qlc_fw_2200
 423 MISC_KMODS      += qlc_fw_2300
 424 MISC_KMODS      += qlc_fw_2400
 425 MISC_KMODS      += qlc_fw_2500
 426 MISC_KMODS      += qlc_fw_6322
 427 MISC_KMODS      += qlc_fw_8100
 428 MISC_KMODS      += spuni
 429 MISC_KMODS      += mii
 430 
 431 MISC_KMODS      += klmmod klmops
 432 
 433 #
 434 #       Software Cryptographic Providers (/kernel/crypto):
 435 #
 436 CRYPTO_KMODS    += aes
 437 CRYPTO_KMODS    += arcfour
 438 CRYPTO_KMODS    += blowfish
 439 CRYPTO_KMODS    += des
 440 CRYPTO_KMODS    += ecc
 441 CRYPTO_KMODS    += edonr
 442 CRYPTO_KMODS    += md4
 443 CRYPTO_KMODS    += md5
 444 CRYPTO_KMODS    += rsa
 445 CRYPTO_KMODS    += sha1
 446 CRYPTO_KMODS    += sha2
 447 CRYPTO_KMODS    += skein
 448 CRYPTO_KMODS    += swrand
 449 
 450 #
 451 # IP Policy Modules (/kernel/ipp):
 452 #
 453 IPP_KMODS       += dlcosmk
 454 IPP_KMODS       += flowacct
 455 IPP_KMODS       += ipgpc
 456 IPP_KMODS       += dscpmk
 457 IPP_KMODS       += tokenmt
 458 IPP_KMODS       += tswtclmt
 459 
 460 #
 461 # 'Dacf' modules (/kernel/dacf)
 462 DACF_KMODS      += consconfig_dacf
 463 
 464 #
 465 #       SVVS Testing Modules (/kernel/strmod):
 466 #
 467 #       These are streams and driver modules which are not to be
 468 #       delivered with a released system. However, during development
 469 #       it is convenient to build and install the SVVS kernel modules.
 470 #
 471 SVVS_KMODS      += lmodb lmode lmodr lmodt svvslo tidg tivc tmux
 472 
 473 #
 474 #       Modules eXcluded from the product:
 475 #
 476 XMODS           +=
 477 
 478 #
 479 #       'Dacf' Modules (/kernel/dacf):
 480 #
 481 DACF_KMODS      += net_dacf
 482 
 483 #
 484 #       MAC-Type Plugin Modules (/kernel/mac)
 485 #
 486 MAC_KMODS       += mac_6to4
 487 MAC_KMODS       += mac_ether
 488 MAC_KMODS       += mac_ipv4
 489 MAC_KMODS       += mac_ipv6
 490 MAC_KMODS       += mac_wifi
 491 MAC_KMODS       += mac_ib
 492 
 493 #
 494 # socketmod (kernel/socketmod)
 495 #
 496 SOCKET_KMODS    += sockpfp
 497 SOCKET_KMODS    += socksctp
 498 SOCKET_KMODS    += socksdp
 499 SOCKET_KMODS    += sockrds
 500 SOCKET_KMODS    += ksslf
 501 SOCKET_KMODS    += datafilt
 502 
 503 #
 504 #       kiconv modules (/kernel/kiconv):
 505 #
 506 KICONV_KMODS    += kiconv_emea kiconv_ja kiconv_ko kiconv_sc kiconv_tc
 507 
 508 #
 509 # Ensure that the variable member of the cpu_t (cpu_m) is defined
 510 # for the lint builds so as not to cause lint errors during the
 511 # global cross check.
 512 #
 513 $(LINTFLAGSUPPRESS)LINTFLAGS    += -D_MACHDEP -I$(UTSBASE)/sun4 \
 514                                    -I$(UTSBASE)/sun4u -I$(UTSBASE)/sfmmu