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 
  26 TOPDIR =        ../../../../..
  27 
  28 include $(TOPDIR)/uts/Makefile.uts
  29 
  30 all     :=      TARGET = all
  31 install :=      TARGET = install
  32 clean   :=      TARGET = clean
  33 
  34 TARG_MACH =     sparcv9
  35 TARG_MACH_DIR = sparcv9
  36 ARCHVERS =      v9
  37 PLATFORM =      sun4
  38 #ARCHMMU  =     sfmmu
  39 PROMVERS =      ieee1275
  40 ASFLAGS +=      $(sparcv9_XARCH)
  41 
  42 ARCH_C_SRC =    sun4u_memlist.c sun4x_standalloc.c sun4dep.c
  43 ARCH_S_SRC =    sparcv9_subr.s
  44 SRT0_S =        sun4u_srt0.s
  45 INLINES =
  46 
  47 LDFLAGS +=      -L$(TOPDIR)/psm/stand/lib/promif/$(TARG_MACH)/$(PROMVERS)/common
  48 
  49 #
  50 # The following libraries are build in LIBPLAT_DIR
  51 #
  52 LIBPLAT_DIR =   $(TOPDIR)/psm/stand/lib/promif/$(TARG_MACH)/$(PROMVERS)/$(PLATFORM)
  53 LIBPLAT_LIBS =  libplat.a
  54 LIBPLAT_L_LIBS= $(LIBPLAT_LIBS:lib%.a=llib-l%.ln)
  55 LIBPLAT_DEP =   $(LIBPLAT_DIR)/$(LIBPLAT_LIBS)
  56 LIBPLAT_DEP_L = $(LIBPLAT_DIR)/$(LIBPLAT_L_LIBS)
  57 
  58 #
  59 # Platform specific libraries
  60 #
  61 PSMLIBS +=      $(LIBPLAT_LIBS:lib%.a=-l%)
  62 PSMLIB_DIRS +=  $(LIBPLAT_DIR)
  63 
  64 include ../Makefile.com
  65 
  66 CPPINCS         += -I$(TOPDIR)/psm/stand/boot/sparc/sun4
  67 
  68 #
  69 # Set the choice of compiler. 
  70 
  71 include $(TOPDIR)/psm/Makefile.psm.64
  72 
  73 CFLAGS64        += -xchip=ultra $(CCABS32)
  74 
  75 #
  76 # XXX this totally sucks since it effectively turns off -errchk=longptr64,
  77 # which we really should be using.
  78 #
  79 LINTFLAGS64 = $(LINTFLAGS) -m64
  80 
  81 #
  82 # Cross-reference customization: include all boot-related source files.
  83 #
  84 STANDLIBDIR=    ../../../../../stand/lib
  85 STANDSYSDIR=    ../../../../../stand/sys
  86 PROMDIRS=       ../../../../promif
  87 NAMESDIRS=      ../../../lib/names/sparcv9 ../../../lib/names/sparc/common
  88 XRDIRS +=       ../../sparc/common ../../common $(STANDLIBDIR) \
  89                 $(STANDSYSDIR) $(PROMDIRS) $(NAMESDIRS)
  90 XRPRUNE =       i86pc i386
  91 
  92 
  93 #############################
  94 #
  95 #  WANboot booter
  96 #
  97 # Libraries used to build wanboot
  98 #
  99 LIBWAN_LIBS     = \
 100                 libwanboot.a \
 101                 libnvpair.a libufs.a libhsfs.a libnfs.a \
 102                 libxdr.a libnames.a libsock.a libinet.a libtcp.a \
 103                 libscrypt.a libssl.a libcrypto.a \
 104                 libmd5.a libsa.a libprom.a libssl.a \
 105                 $(LIBPLAT_LIBS)
 106 WAN_LIBS        = $(LIBWAN_LIBS:lib%.a=-l%)
 107 WAN_DIRS        = $(LIBNAME_DIR:%=-L%) $(LIBSYS_DIR:%=-L%)
 108 WAN_DIRS        += $(LIBPLAT_DIR:%=-L%) $(LIBPROM_DIR:%=-L%)
 109 
 110 #
 111 # Loader flags used to build wanboot
 112 #
 113 WAN_MAPFILE     = $(MACH_DIR)/mapfile
 114 WAN_LDFLAGS     = -dn -M $(WAN_MAPFILE) -e _start $(WAN_DIRS)
 115 WAN_L_LDFLAGS   = $(WAN_DIRS)
 116 
 117 #
 118 # Object files used to build wanboot
 119 #
 120 WAN_SRT0        = $(SRT0_OBJ)
 121 WAN_OBJS        = $(OBJS) wbfsconf.o wbcli.o wanboot.o ramdisk.o
 122 WAN_L_OBJS      = $(WAN_SRT0:%.o=%.ln) $(WAN_OBJS:%.o=%.ln)
 123 
 124 
 125 #############################
 126 #
 127 # NFS booter
 128 #
 129 # Libraries used to build nfsboot
 130 #
 131 LIBNFS_LIBS     = libnfs.a libxdr.a libnames.a \
 132                 libsock.a libinet.a libtcp.a libsa.a libprom.a \
 133                 $(LIBPLAT_LIBS)
 134 NFS_LIBS        = $(LIBNFS_LIBS:lib%.a=-l%)
 135 NFS_DIRS        = $(LIBNAME_DIR:%=-L%) $(LIBSYS_DIR:%=-L%)
 136 NFS_DIRS        += $(LIBPLAT_DIR:%=-L%) $(LIBPROM_DIR:%=-L%)
 137 
 138 #
 139 # Loader flags used to build inetboot
 140 #
 141 NFS_MAPFILE     = $(MACH_DIR)/mapfile
 142 NFS_LDFLAGS     = -dn -M $(NFS_MAPFILE) -e _start $(NFS_DIRS)
 143 NFS_L_LDFLAGS   = $(NFS_DIRS)
 144 
 145 #
 146 # Object files used to build inetboot
 147 #
 148 NFS_SRT0        = $(SRT0_OBJ)
 149 NFS_OBJS        = $(OBJS) nfsconf.o inetboot.o ramdisk.o
 150 NFS_L_OBJS      = $(NFS_SRT0:%.o=%.ln) $(NFS_OBJS:%.o=%.ln)
 151 
 152 
 153 #include $(BOOTSRCDIR)/Makefile.rules
 154 
 155 FRC:
 156 
 157 .KEEP_STATE:
 158 
 159 all: $(WANBOOT) $(NFSBOOT)
 160 
 161 install: all                                    \
 162         $(ROOT_PLAT_SUN4U_WANBOOT)              \
 163         $(ROOT_PLAT_SUN4V_WANBOOT)              \
 164         $(USR_PLAT_SUN4U_LIB_FS_NFS_NFSBOOT)    \
 165         $(USR_PLAT_SUN4V_LIB_FS_NFS_NFSBOOT)
 166 
 167 $(WANBOOT): $(WAN_MAPFILE) $(WAN_SRT0) $(WAN_OBJS) $(LIBDEPS)
 168         $(LD) $(WAN_LDFLAGS) -o $@ $(WAN_SRT0) $(WAN_OBJS) $(WAN_LIBS)
 169         $(MCS) -d $@
 170         $(POST_PROCESS)
 171         $(MCS) -c $@
 172         $(STRIP) $@
 173 
 174 $(NFSBOOT): $(NFS_MAPFILE) $(NFS_SRT0) $(NFS_OBJS) $(LIBDEPS)
 175         $(LD) $(NFS_LDFLAGS) -o $@ $(NFS_SRT0) $(NFS_OBJS) $(NFS_LIBS)
 176         $(MCS) -d $@
 177         $(POST_PROCESS)
 178         $(MCS) -c $@
 179         $(STRIP) $@
 180 
 181 $(WANBOOT)_lint: $(WAN_L_OBJS) $(L_LIBDEPS)
 182         @echo ""
 183         @echo wanboot lint: global crosschecks:
 184         $(LINT.c) $(WAN_L_LDFLAGS) $(WAN_L_OBJS) $(WAN_LIBS)
 185 
 186 $(NFSBOOT)_lint: $(NFS_L_OBJS) $(L_LIBDEPS)
 187         @echo ""
 188         @echo inetboot lint: global crosschecks:
 189         $(LINT.c) $(NFS_L_LDFLAGS) $(NFS_L_OBJS) $(NFS_LIBS)
 190 
 191 $(ROOT_PLAT_SUN4U_WANBOOT): $(WANBOOT)
 192         $(INS) -s -m $(FILEMODE) -f $(ROOT_PLAT_DIR)/sun4u $(WANBOOT)
 193 
 194 $(ROOT_PLAT_SUN4V_WANBOOT): $(WANBOOT)
 195         $(INS) -s -m $(FILEMODE) -f $(ROOT_PLAT_DIR)/sun4v $(WANBOOT)
 196 
 197 $(USR_PLAT_SUN4U_LIB_FS_NFS):
 198         $(INS.dir)
 199 
 200 $(USR_PLAT_SUN4V_LIB_FS_NFS):
 201         $(INS.dir)
 202 
 203 $(USR_PLAT_SUN4U_LIB_FS_NFS_NFSBOOT): $(USR_PLAT_SUN4U_LIB_FS_NFS) $(NFSBOOT)
 204         $(INS) -s -m $(FILEMODE) -f $(USR_PLAT_SUN4U_LIB_FS_NFS) $(NFSBOOT)
 205 
 206 $(USR_PLAT_SUN4V_LIB_FS_NFS_NFSBOOT): $(USR_PLAT_SUN4V_LIB_FS_NFS) $(NFSBOOT)
 207         $(INS) -s -m $(FILEMODE) -f $(USR_PLAT_SUN4V_LIB_FS_NFS) $(NFSBOOT)
 208 
 209 $(STRIPALIGN): $(CMN_DIR)/$$(@).c
 210         $(NATIVECC) -o $@ $(CMN_DIR)/$@.c
 211 
 212 clean:
 213         $(RM) make.out lint.out
 214         $(RM) $(OBJS) $(CONF_OBJS) $(MISC_OBJS) $(SRT0_OBJ)
 215         $(RM) $(WANBOOT_OBJS) $(NFSBOOT_OBJS)
 216         $(RM) $(L_OBJS) $(CONF_L_OBJS) $(MISC_L_OBJS) $(SRT0_L_OBJ)
 217         $(RM) $(WANBOOT_L_OBJS) $(NFSBOOT_L_OBJS)
 218 
 219 clobber: clean
 220         $(RM) $(WANBOOT) $(NFSBOOT) $(STRIPALIGN)
 221 
 222 lint: $(WANBOOT)_lint $(NFSBOOT)_lint