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 # Copyright 2019 Peter Tribble. 25 # 26 # psm/stand/boot/sparcv9/ieee1275/sun4u/Makefile 27 # 28 # 29 TOPDIR = ../../../../../../.. 30 31 include $(TOPDIR)/Makefile.master 32 include $(TOPDIR)/lib/Makefile.lib 33 include $(TOPDIR)/psm/stand/lib/Makefile.lib 34 include $(TOPDIR)/psm/Makefile.psm.64 35 36 CFLAGS64 += -xchip=ultra $(CCABS32) 37 38 PLATDIR = $(TOPDIR)/psm/promif/ieee1275/sun4u 39 PLATSUN4DIR = $(TOPDIR)/psm/promif/ieee1275/sun4 40 SYSDIR = $(TOPDIR)/uts 41 42 LIBPLAT = libplat.a 43 LINTLIBPLAT = llib-lplat.ln 44 45 PLAT_PFILES = \ 46 prom_serengeti.c \ 47 prom_sunfire.c \ 48 prom_tlb.c 49 50 PLAT_PSUN4FILES = \ 51 prom_alloc.c \ 52 prom_cpuctl.c \ 53 prom_fio.c \ 54 prom_getunum.c \ 55 prom_heartbeat.c \ 56 prom_idprom.c \ 57 prom_init.c \ 58 prom_macaddr.c \ 59 prom_map.c \ 60 prom_mem.c \ 61 prom_mmu.c \ 62 prom_retain.c \ 63 prom_sparc.c \ 64 prom_vername.c 65 66 KARCH = sun4u 67 MMU = sfmmu 68 69 OBJSDIR = objs 70 71 PLAT_POBJ = $(PLAT_PFILES:%.c=$(OBJSDIR)/%.o) 72 PLAT_PSUN4OBJ = $(PLAT_PSUN4FILES:%.c=$(OBJSDIR)/%.o) 73 OBJS = $(PLAT_POBJ) $(PLAT_PSUN4OBJ) 74 L_OBJS = $(OBJS:%.o=%.ln) 75 L_SRCS = $(PLAT_PFILES:%=$(PLATDIR)/%) 76 L_SRCS += $(PLAT_PSUN4FILES:%=$(PLATSUN4DIR)/%) 77 78 ARCHOPTS= -Dsun4u 79 ASFLAGS = -P -D__STDC__ -D_BOOT -D_ASM 80 CPPDEFS = $(ARCHOPTS) -D$(KARCH) -D_BOOT -D_KERNEL -D_MACHDEP 81 CPPINCS = -I. -I$(SYSDIR)/sun4 -I$(SYSDIR)/$(KARCH) -I$(SYSDIR)/$(MMU) \ 82 -I$(SYSDIR)/sparc/v9 -I$(SYSDIR)/sparc \ 83 -I$(SYSDIR)/sun -I$(SYSDIR)/common 84 CPPFLAGS= $(CPPDEFS) $(CPPINCS) $(CPPFLAGS.master) 85 CFLAGS += $(CCVERBOSE) 86 87 .KEEP_STATE: 88 89 .PARALLEL: $(OBJS) $(L_OBJS) 90 91 all install: $(LIBPLAT) 92 93 lint: $(LINTLIBPLAT) 94 95 clean: 96 $(RM) $(OBJS) $(L_OBJS) 97 98 clobber: clean 99 $(RM) $(LIBPLAT) $(LINTLIBPLAT) 100 101 $(LIBPLAT): $(OBJSDIR) .WAIT $(OBJS) 102 $(BUILD.AR) $(OBJS) 103 104 $(LINTLIBPLAT): $(OBJSDIR) .WAIT $(L_OBJS) 105 @$(ECHO) "\nlint library construction:" $@ 106 @$(LINT.lib) -o plat $(L_SRCS) 107 108 $(OBJSDIR): 109 -@[ -d $@ ] || mkdir $@ 110 111 # 112 # build rules using standard library object subdirectory 113 # 114 $(OBJSDIR)/%.o: $(PLATDIR)/%.c 115 $(COMPILE.c) -o $@ $< 116 $(POST_PROCESS_O) 117 118 $(OBJSDIR)/%.o: $(PLATDIR)/%.s 119 $(COMPILE.s) -o $@ $< 120 $(POST_PROCESS_O) 121 122 $(OBJSDIR)/%.o: $(PLATSUN4DIR)/%.c 123 $(COMPILE.c) -o $@ $< 124 $(POST_PROCESS_O) 125 126 $(OBJSDIR)/%.o: $(PLATSUN4DIR)/%.s 127 $(COMPILE.s) -o $@ $< 128 $(POST_PROCESS_O) 129 130 $(OBJSDIR)/%.ln: $(PLATDIR)/%.c 131 @($(LHEAD) $(LINT.c) $< $(LTAIL)) 132 @$(MV) $(@F) $@ 133 134 $(OBJSDIR)/%.ln: $(PLATDIR)/%.s 135 @($(LHEAD) $(LINT.s) $< $(LTAIL)) 136 @$(MV) $(@F) $@ 137 138 $(OBJSDIR)/%.ln: $(PLATSUN4DIR)/%.c 139 @($(LHEAD) $(LINT.c) $< $(LTAIL)) 140 @$(MV) $(@F) $@ 141 142 $(OBJSDIR)/%.ln: $(PLATSUN4DIR)/%.s 143 @($(LHEAD) $(LINT.s) $< $(LTAIL)) 144 @$(MV) $(@F) $@