summaryrefslogtreecommitdiff
path: root/Mkfiles/Makefile.bc3
blob: f58ae105aed283b758a4021c31cbf8930b89d501 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
# Makefile for the Netwide Assembler under 16-bit DOS (aimed at Borland C)
#
# The Netwide Assembler is copyright (C) 1996 Simon Tatham and
# Julian Hall. All rights reserved. The software is
# redistributable under the licence given in the file "Licence"
# distributed in the NASM archive.
#
# This Makefile compiles NASM and NDISASM for 16 bit DOS using Borland
# C++; tested with version 3.1.  It probably should work for any
# version of Turbo C++ or Borland C++ from version 3.0 upwards.
# For Turbo C++, replace "bcc" with "tcc", and replace "-O1" with "-O".
#
# Most everything is remarked, and explaned in full, it should be
# easy to convert it to another compiler. I tried to make the devision
# of information logical, and easy to follow.
#
# BEFORE YOU USE THIS MAKE FILE!!!
#
# Make sure the line below is set to the propper location of your standard
# Libaries, if not you'll get some errors. Make sure to keep the trailing
# backslash, as it's needed, and remeber to use \\ not \ as that will cause
# some errors.
#
# This Makefile was updated with NASM 0.98.31, and could compile that
# version correctly using Borland C++ 3.1 under DOS.
#

CC = bcc                #compiler

# opimizations
OPTFLAGS = -d -O1 -Ogmp -k-
  # -d  = merge duplicate strings
  # -O1 = optimize for size
  # -Og = enable global common subexpression elimination
  # -Om = enable loop invariant removal
  # -Op = enable constant propagation
  # ** WARNING: DO NOT ENABLE -Ov (strength reduction) ON BORLAND C++ 3.1 **
  # ** NASM IS KNOWN TO MISCOMPILE WITH -Ov **
  # -k- = omit stack frames where practical
#output formats
OUTFORMS = -DOF_ONLY -DOF_BIN -DOF_OBJ -DOF_WIN32 -DOF_AS86

#compiler flags
CFLAGS = $(OPTFLAGS) -mh -f- $(OUTFORMS)
  # -mh = model huge
  # -f- = no floating point

LINKFLAGS = -d -mh -M -f-
  # -d  = merge duplicate strings
  # -M  = generate map file (to find address space bottlenecks)

LIBS =                  #any libaries to add, out side of the standard libary
EXE = .exe              #executable file extention (keep the . as the start)
OBJ = obj               #OBJ file extention
LIB = lib               #LIB file extension

.c.$(OBJ):
	$(CC) $(CFLAGS) -c -o$@ $<

################################################################
# The OBJ files that NASM is dependent on

NASMOBJS = nasm.$(OBJ)   nasmlib.$(OBJ)  float.$(OBJ)  \
	   assemble.$(OBJ) labels.$(OBJ) \
	   parser.$(OBJ) outform.$(OBJ)  preproc.$(OBJ) \
	   listing.$(OBJ) eval.$(OBJ) insnsa.$(OBJ)

################################################################
# The OBJ files that NDISASM is dependent on

NDISASMOBJS = ndisasm.$(OBJ)  disasm.$(OBJ) sync.$(OBJ) \
	      nasmlib.$(OBJ) insnsd.$(OBJ)

################################################################
# The OBJ file for the output formats

OUTOBJ= output\\outbin.$(OBJ) output\\outaout.$(OBJ) output\\outcoff.$(OBJ) \
	output\\outelf32.$(OBJ) output\\outelf64.$(OBJ) \
	output\\outobj.$(OBJ)  output\\outas86.$(OBJ) \
	output\\outdbg.$(OBJ) output\\outrdf2.$(OBJ) output\\outieee.$(OBJ)

################################################################
# Build everything

all : nasm$(EXE) ndisasm$(EXE)

################################################################
# Rules to put the CFLAGS in a file
CFLAGS: Makefile
	echo $(CFLAGS) > CFLAGS
	$(MAKE) clean

################################################################
# NASM, NDISASM link.  The &&!...! construct in Borland Make
# creates a temporary file and inserts its name on the command
# line.  It works around the DOS 127-character command line
# limit.

nasm$(EXE): $(NASMOBJS) output\\out.$(LIB)
	$(CC) $(LINKFLAGS) -onasm$(EXE) @&&!
$(NASMOBJS)
output\\out.$(LIB)
!

ndisasm$(EXE): $(NDISASMOBJS)
	$(CC) $(LINKFLAGS) -ondisasm$(EXE) @&&!
$(NDISASMOBJS)
!

################################################################
# Build the output formats as a library
# The & ... $? construct tells Borland Make to repeat for all
# out of date dependencies
output\\out.$(LIB): $(OUTOBJ)
	-del output\\out.$(LIB)
	for %a in (output\\*.$(OBJ)) do tlib /C output\\out.$(LIB) +%a

################################################################
# A quick way to delete the OBJ files as well as the binaries.

clean :
	-del *.$(OBJ)
	-del output\\*.$(OBJ)
	-del output\\out.$(LIB)
	-del *.$(LIB)
	-del insnsa_?.c
	-del nasm$(EXE)
	-del ndisasm$(EXE)
	-del *.map
	-del CFLAGS

#-- Magic hints to mkdep.pl --#
# @object-ending: ".$(OBJ)"
# @path-separator: "\\"
#-- Everything below is generated by mkdep.pl - do not edit --#
assemble.$(OBJ): assemble.c preproc.h insns.h pptok.h regs.h regflags.c \
 config.h version.h nasmlib.h nasm.h regvals.c insnsi.h assemble.h
disasm.$(OBJ): disasm.c insns.h sync.h regdis.c regs.h config.h regs.c \
 version.h nasm.h insnsn.c names.c insnsi.h disasm.h
eval.$(OBJ): eval.c labels.h eval.h regs.h config.h version.h nasmlib.h \
 nasm.h
float.$(OBJ): float.c regs.h config.h version.h nasm.h
insnsa.$(OBJ): insnsa.c insns.h regs.h config.h version.h nasm.h insnsi.h
insnsd.$(OBJ): insnsd.c insns.h regs.h config.h version.h nasm.h insnsi.h
insnsn.$(OBJ): insnsn.c
labels.$(OBJ): labels.c regs.h config.h version.h nasmlib.h nasm.h
listing.$(OBJ): listing.c regs.h config.h version.h nasmlib.h nasm.h \
 listing.h
macros.$(OBJ): macros.c
names.$(OBJ): names.c regs.c insnsn.c
nasm.$(OBJ): nasm.c labels.h preproc.h insns.h parser.h eval.h pptok.h \
 regs.h outform.h config.h version.h nasmlib.h nasm.h stdscan.h assemble.h \
 insnsi.h listing.h
nasmlib.$(OBJ): nasmlib.c insns.h regs.h config.h version.h nasmlib.h nasm.h \
 insnsi.h
ndisasm.$(OBJ): ndisasm.c insns.h sync.h regs.h config.h version.h nasmlib.h \
 nasm.h insnsi.h disasm.h
outform.$(OBJ): outform.c regs.h config.h outform.h version.h nasm.h
output\\outaout.$(OBJ): output\\outaout.c regs.h outform.h config.h \
 version.h nasmlib.h nasm.h stdscan.h
output\\outas86.$(OBJ): output\\outas86.c regs.h outform.h config.h \
 version.h nasmlib.h nasm.h
output\\outbin.$(OBJ): output\\outbin.c labels.h eval.h regs.h outform.h \
 config.h version.h nasmlib.h nasm.h stdscan.h
output\\outcoff.$(OBJ): output\\outcoff.c regs.h outform.h config.h \
 version.h nasmlib.h nasm.h
output\\outdbg.$(OBJ): output\\outdbg.c regs.h outform.h config.h version.h \
 nasmlib.h nasm.h
output\\outelf32.$(OBJ): output\\outelf32.c regs.h outform.h config.h \
 version.h nasmlib.h nasm.h stdscan.h
output\\outelf64.$(OBJ): output\\outelf64.c regs.h outform.h config.h \
 version.h nasmlib.h nasm.h stdscan.h
output\\outieee.$(OBJ): output\\outieee.c regs.h outform.h config.h \
 version.h nasmlib.h nasm.h
output\\outmacho.$(OBJ): output\\outmacho.c compiler.h regs.h outform.h \
 config.h version.h nasmlib.h nasm.h
output\\outobj.$(OBJ): output\\outobj.c regs.h outform.h config.h version.h \
 nasmlib.h nasm.h stdscan.h
output\\outrdf.$(OBJ): output\\outrdf.c regs.h outform.h config.h version.h \
 nasmlib.h nasm.h
output\\outrdf2.$(OBJ): output\\outrdf2.c rdoff\\rdoff.h regs.h outform.h \
 config.h version.h nasmlib.h nasm.h
parser.$(OBJ): parser.c insns.h parser.h float.h regs.h regflags.c config.h \
 version.h nasmlib.h nasm.h stdscan.h insnsi.h
pptok.$(OBJ): pptok.c
preproc.$(OBJ): preproc.c preproc.h macros.c pptok.h regs.h config.h \
 version.h nasmlib.h nasm.h
regdis.$(OBJ): regdis.c
regflags.$(OBJ): regflags.c
regs.$(OBJ): regs.c
regvals.$(OBJ): regvals.c
stdscan.$(OBJ): stdscan.c insns.h regs.h config.h version.h nasmlib.h nasm.h \
 stdscan.h insnsi.h
sync.$(OBJ): sync.c sync.h
tokhash.$(OBJ): tokhash.c insns.h regs.h config.h version.h nasm.h insnsi.h