Makefile.sun3 revision 1.109
1# $NetBSD: Makefile.sun3,v 1.109 2018/09/22 12:24:03 rin Exp $
2
3# Makefile for NetBSD
4#
5# This makefile is constructed from a machine description:
6#	config machineid
7# Most changes should be made in the machine description
8#	/sys/arch/sun3/conf/``machineid''
9# after which you should do
10#	config machineid
11# Machine generic makefile changes should be made in
12#	/sys/arch/sun3/conf/Makefile.sun3
13# after which config should be rerun for all machines of that type.
14#
15# To specify debugging, add the config line: makeoptions DEBUG="-g"
16# A better way is to specify -g only for a few files.
17#
18#	makeoptions DEBUGLIST="uvm* trap if_*"
19
20MACHINE_ARCH=m68k
21USETOOLS?=	no
22NEED_OWN_INSTALL_TARGET?=no
23.include <bsd.own.mk>
24
25##
26## (1) port identification
27##
28SUN3=		$S/arch/sun3
29GENASSYM_CONF=	${SUN3}/${MACHTYPE}/genassym.cf
30
31##
32## (2) compile settings
33##
34CPPFLAGS+=	-Dsun3
35CFLAGS+=	${CMACHFLAGS} -fno-defer-pop
36CFLAGS+=	-msoft-float
37AFLAGS+=	-x assembler-with-cpp
38
39##
40## (3) libkern and compat
41##
42OPT_MODULAR=   %MODULAR%
43
44##
45## (4) local objects, compile rules, and dependencies
46##
47MD_OBJS=	locore.o
48MD_CFILES=
49MD_SFILES=	${SUN3}/${MACHTYPE}/locore.s
50
51locore.o: ${SUN3}/${MACHTYPE}/locore.s
52	${NORMAL_S}
53
54.include "$S/arch/m68k/conf/Makefile.kern.m68k.inc"
55
56##
57## (5) link settings
58##
59.if ${MACHTYPE} == "sun3x"
60TEXTADDR?=	F8004000
61.else
62TEXTADDR?=	0E004000
63.endif
64LINKFORMAT=	-N
65
66##
67## (6) port specific target dependencies
68##
69
70# For cross-compilation, the "gcc -M" mkdep script is convenient,
71# but that does not correctly make rules from *.s files.  The
72# easiest work-around is to just list those dependencies here.
73locore.o:   assym.h m68k/asm.h m68k/trap.h
74copy.o:     assym.h m68k/asm.h $S/sys/errno.h
75bcopy.o:    assym.h m68k/asm.h
76copypage.o: assym.h m68k/asm.h
77lock_stubs.o: assym.h
78
79# depend on CPU configuration
80db_machdep.o dvma.o machdep.o pmap.o sun3_startup.o vm_machdep.o: Makefile
81
82# depends on DDB, etc.
83stub.o: Makefile
84
85##
86## (7) misc settings
87##
88
89##
90## (8) config(8) generated machinery
91##
92%INCLUDES
93
94%OBJS
95
96%CFILES
97
98%SFILES
99
100%LOAD
101
102%RULES
103
104##
105## (9) port independent kernel machinery
106##
107.include "$S/conf/Makefile.kern.inc"
108
109##
110## (10) Appending make options.
111##
112%MAKEOPTIONSAPPEND
113