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 2007 Sun Microsystems, Inc.  All rights reserved.
  23 # Use is subject to license terms.
  24 #
  25 #ident  "%Z%%M% %I%     %E% SMI"
  26 
  27 #
  28 #       Global definitions for sun4u implementation specific modules.
  29 #
  30 
  31 #
  32 #       Define the name of this implementation.
  33 #
  34 
  35 #
  36 #       Define directories.
  37 #
  38 ROOT_SERENGETI_DIR              = $(ROOT_PLAT_DIR)/SUNW,Sun-Fire
  39 ROOT_SERENGETI_MOD_DIR          = $(ROOT_SERENGETI_DIR)/kernel
  40 
  41 ROOT_SERENGETI_KERN_DIR_32      = $(ROOT_SERENGETI_MOD_DIR)
  42 ROOT_SERENGETI_KERN_DIR_64      = $(ROOT_SERENGETI_MOD_DIR)/$(SUBDIR64)
  43 ROOT_SERENGETI_KERN_DIR         = $(ROOT_SERENGETI_KERN_DIR_$(CLASS))
  44 
  45 ROOT_SERENGETI_CPU_DIR_32       = $(ROOT_SERENGETI_MOD_DIR)/cpu
  46 ROOT_SERENGETI_CPU_DIR_64       = $(ROOT_SERENGETI_MOD_DIR)/cpu/$(SUBDIR64)
  47 ROOT_SERENGETI_CPU_DIR          = $(ROOT_SERENGETI_CPU_DIR_$(CLASS))
  48 
  49 ROOT_SERENGETI_DRV_DIR_32       = $(ROOT_SERENGETI_MOD_DIR)/drv
  50 ROOT_SERENGETI_DRV_DIR_64       = $(ROOT_SERENGETI_MOD_DIR)/drv/$(SUBDIR64)
  51 ROOT_SERENGETI_DRV_DIR          = $(ROOT_SERENGETI_DRV_DIR_$(CLASS))
  52 
  53 ROOT_SERENGETI_MISC_DIR_32      = $(ROOT_SERENGETI_MOD_DIR)/misc
  54 ROOT_SERENGETI_MISC_DIR_64      = $(ROOT_SERENGETI_MOD_DIR)/misc/$(SUBDIR64)
  55 ROOT_SERENGETI_MISC_DIR         = $(ROOT_SERENGETI_MISC_DIR_$(CLASS))
  56 
  57 ROOT_SERENGETI_CRYPTO_DIR_32    = $(ROOT_SERENGETI_MOD_DIR)/crypto
  58 ROOT_SERENGETI_CRYPTO_DIR_64    = $(ROOT_SERENGETI_MOD_DIR)/crypto/$(SUBDIR64)
  59 ROOT_SERENGETI_CRYPTO_DIR       = $(ROOT_SERENGETI_CRYPTO_DIR_$(CLASS))
  60 
  61 ROOT_PLAT_MOD_DIRS              += $(ROOT_SERENGETI_MOD_DIR)
  62 ROOT_PLAT_MISC_DIRS_32          += $(ROOT_SERENGETI_MISC_DIR_32)
  63 
  64 USR_SERENGETI_DIR               = $(USR_PLAT_DIR)/SUNW,Sun-Fire
  65 USR_SERENGETI_INC_DIR           = $(USR_SERENGETI_DIR)/include
  66 USR_SERENGETI_ISYS_DIR          = $(USR_SERENGETI_INC_DIR)/sys
  67 USR_SERENGETI_SBIN_DIR          = $(USR_SERENGETI_DIR)/sbin
  68 USR_SERENGETI_LIB_DIR           = $(USR_SERENGETI_DIR)/lib
  69 
  70 SERENGETI_LINT_LIB_DIR          = $(UTSBASE)/$(PLATFORM)/serengeti/lint-libs/$(OBJS_DIR)
  71 
  72 #
  73 #       Include the makefiles which define build rule templates, the
  74 #       collection of files per module, and a few specific flags. Note
  75 #       that order is significant, just as with an include path. The
  76 #       first build rule template which matches the files name will be
  77 #       used. By including these in order from most machine dependent
  78 #       to most machine independent, we allow a machine dependent file
  79 #       to be used in preference over a machine independent version
  80 #       (Such as a machine specific optimization, which preserves the
  81 #       interfaces.)
  82 #
  83 
  84 #
  85 # Links to UltraSparc III crypto modules
  86 #
  87 SERENGETI_CRYPTO_LINKS  += aes
  88 
  89 include $(UTSTREE)/sun4u/serengeti/Makefile.files
  90 #
  91 #       Include common rules.
  92 #
  93 
  94 include $(UTSTREE)/sun4u/Makefile.sun4u
  95 
  96 #
  97 #       Define modules
  98 #
  99 SERENGETI_KMODS = cheetah cheetahplus  
 100 SERENGETI_KMODS += platmod sbdp sgcn sghsc sgsbbc ssm
 101 
 102 #
 103 #       Everybody needs to know how to build modstubs.o and to locate unix.o
 104 #
 105 UNIX_DIR        = $(UTSBASE)/$(PLATFORM)/serengeti/unix
 106 MODSTUBS_DIR    = $(UNIX_DIR)
 107 DSF_DIR         = $(UTSBASE)/$(PLATFORM)/serengeti/genassym
 108 LINTS_DIR       = $(OBJS_DIR)
 109 LINT_LIB_DIR    = $(UTSBASE)/$(PLATFORM)/serengeti/lint-libs/$(OBJS_DIR)
 110 
 111 UNIX_O          = $(UNIX_DIR)/$(OBJS_DIR)/unix.o
 112 
 113 LINT_LIB        = $(LINT_LIB_DIR)/llib-lunix.ln
 114 
 115 #
 116 #       Define the actual specific platforms
 117 #
 118 MACHINE_DEFS    = -D$(PLATFORM) -D_MACHDEP -DSFMMU -DMP -DMIXEDCPU_DR_SUPPORTED
 119 
 120 #
 121 #       Define platform specific values
 122 #
 123 MACHINE_DEFS    += -DNCPU=558
 124 MACHINE_DEFS    += -DMAX_CPU_CHIPID=554
 125 MACHINE_DEFS    += -DMAX_UPA=1024
 126 MACHINE_DEFS    += -DIGN_SIZE=10
 127 MACHINE_DEFS    += -DMAX_MEM_NODES=8
 128 MACHINE_DEFS    += -DLOCKED_DTLB_ENTRIES=6
 129 # Max IOSRAM TOC major version number supported
 130 MACHINE_DEFS    += -DMAX_IOSRAM_TOC_VER=0x1
 131 MACHINE_DEFS    += -DC_OBP
 132 
 133 #       Define for inline pre-processing since
 134 #       cpp is not smart about v9 yet.
 135 #       It's not smart about __sparc either since it only predefines sparc.
 136 CPP_DEFS_32     = -D__sparc
 137 CPP_DEFS_64     = -D__sparc -D__sparcv9
 138 CPP_DEFS        = $(CPP_DEFS_$(CLASS))
 139 
 140 #
 141 # For now, disable these lint checks; maintainers should endeavor
 142 # to investigate and remove these for maximum lint coverage.
 143 # Please do not carry these forward to new Makefiles.
 144 #
 145 LINTTAGS        += -erroff=E_SUSPICIOUS_COMPARISON
 146 LINTTAGS        += -erroff=E_BAD_PTR_CAST_ALIGN
 147 LINTTAGS        += -erroff=E_SUPPRESSION_DIRECTIVE_UNUSED
 148 LINTTAGS        += -erroff=E_STATIC_UNUSED
 149 LINTTAGS        += -erroff=E_PTRDIFF_OVERFLOW
 150 LINTTAGS        += -erroff=E_ASSIGN_NARROW_CONV