blob: 9346c2936655a57cb07fd7ce6398794d9216bd24 [file] [log] [blame]
H. Peter Anvindc467ba2007-09-24 12:30:54 -07001# -*- makefile -*-
2#
H. Peter Anvine8bfecf2007-09-16 22:16:24 -07003# Makefile for building NASM using Microsoft Visual C++ and NMAKE.
4# Tested on Microsoft Visual C++ 2005 Express Edition.
5#
6# Make sure to put the appropriate directories in your PATH, in
7# the case of MSVC++ 2005, they are ...\VC\bin and ...\Common7\IDE.
H. Peter Anvin4bef68a2016-03-08 00:50:13 -08008#
9# This is typically done by opening the Visual Studio Command Prompt.
10#
H. Peter Anvine8bfecf2007-09-16 22:16:24 -070011
12top_srcdir = .
13srcdir = .
H. Peter Anvind7642a42017-04-06 18:18:11 -070014objdir = .
H. Peter Anvine8bfecf2007-09-16 22:16:24 -070015VPATH = .
H. Peter Anvin675e7b72017-04-05 21:19:03 -070016prefix = "C:\Program Files\NASM"
H. Peter Anvine8bfecf2007-09-16 22:16:24 -070017exec_prefix = $(prefix)
18bindir = $(prefix)/bin
19mandir = $(prefix)/man
20
Jim Kukunas46d606e2014-11-20 16:39:16 -080021!IF "$(DEBUG)" == "1"
22CFLAGS = /Od /Zi
23LDFLAGS = /DEBUG
24!ELSE
Knut St. Osmundsen6fd29842016-04-21 09:13:19 +030025CFLAGS = /O2 /Zi
26LDFLAGS = /DEBUG /OPT:REF /OPT:ICF # (latter two undoes /DEBUG harm)
Jim Kukunas46d606e2014-11-20 16:39:16 -080027!ENDIF
28
H. Peter Anvine8bfecf2007-09-16 22:16:24 -070029CC = cl
Knut St. Osmundsen6fd29842016-04-21 09:13:19 +030030AR = lib
Jim Kukunas46d606e2014-11-20 16:39:16 -080031CFLAGS = $(CFLAGS) /W2
H. Peter Anvin397c1692016-10-04 17:01:59 -070032BUILD_CFLAGS = $(CFLAGS)
H. Peter Anvin4627e692016-01-26 12:01:34 -080033INTERNAL_CFLAGS = /I$(srcdir) /I. \
H. Peter Anvin397c1692016-10-04 17:01:59 -070034 /I$(srcdir)/include /I./include \
35 /I$(srcdir)/x86 /I./x86 \
36 /I$(srcdir)/asm /I./asm \
37 /I$(srcdir)/disasm /I./disasm \
Nikolai Saoukh95465072017-04-05 11:10:44 -040038 /I$(srcdir)/output /I./output
H. Peter Anvine8bfecf2007-09-16 22:16:24 -070039ALL_CFLAGS = $(BUILD_CFLAGS) $(INTERNAL_CFLAGS)
H. Peter Anvind7642a42017-04-06 18:18:11 -070040LDFLAGS = /link $(LINKFLAGS) /SUBSYSTEM:CONSOLE /RELEASE
H. Peter Anvin3720f7b2008-05-12 11:00:50 -070041LIBS =
H. Peter Anvin6c48b422017-04-03 11:23:31 -070042
H. Peter Anvin14858d72017-04-03 11:13:29 -070043PERL = perl
H. Peter Anvin6c48b422017-04-03 11:23:31 -070044PERLFLAGS = -I$(srcdir)/perllib -I$(srcdir)
45RUNPERL = $(PERL) $(PERLFLAGS)
46
47MAKENSIS = makensis
H. Peter Anvine8bfecf2007-09-16 22:16:24 -070048
H. Peter Anvin5d819332018-06-18 13:50:25 -070049RM_F = -del /f
H. Peter Anvin9a714c92017-04-06 17:24:03 -070050LN_S = copy
51
H. Peter Anvine8bfecf2007-09-16 22:16:24 -070052# Binary suffixes
53O = obj
H. Peter Anvin6a83cb92016-04-21 18:10:10 -070054A = lib
H. Peter Anvine8bfecf2007-09-16 22:16:24 -070055X = .exe
H. Peter Anvind685bd22017-11-08 10:57:16 -080056.SUFFIXES:
H. Peter Anvin5d819332018-06-18 13:50:25 -070057.SUFFIXES: $(X) .$(A) .$(O) .c .i .s .1 .man
H. Peter Anvine8bfecf2007-09-16 22:16:24 -070058
59.c.obj:
60 $(CC) /c $(ALL_CFLAGS) /Fo$@ $<
61
H. Peter Anvinc0d60662008-06-15 23:50:50 -070062#-- Begin File Lists --#
H. Peter Anvin7806e962008-06-15 16:54:29 -070063# Edit in Makefile.in, not here!
H. Peter Anvin9a714c92017-04-06 17:24:03 -070064NASM = asm\nasm.$(O)
65NDISASM = disasm\ndisasm.$(O)
H. Peter Anvin4d58a8f2017-02-28 18:08:21 -080066
H. Peter Anvin9a714c92017-04-06 17:24:03 -070067LIBOBJ = stdlib\snprintf.$(O) stdlib\vsnprintf.$(O) stdlib\strlcpy.$(O) \
H. Peter Anvin81b62b92017-12-20 13:33:49 -080068 stdlib\strnlen.$(O) stdlib\strrchrnul.$(O) \
69 \
H. Peter Anvin9a714c92017-04-06 17:24:03 -070070 nasmlib\ver.$(O) \
H. Peter Anvin (Intel)df2195b2018-12-13 16:43:43 -080071 nasmlib\alloc.$(O) nasmlib\asprintf.$(O) nasmlib\errfile.$(O) \
72 nasmlib\crc64.$(O) nasmlib\md5c.$(O) \
73 nasmlib\string.$(O) nasmlib\nctype.$(O) \
H. Peter Anvin9a714c92017-04-06 17:24:03 -070074 nasmlib\file.$(O) nasmlib\mmap.$(O) nasmlib\ilog2.$(O) \
H. Peter Anvin09799572017-04-23 22:39:53 -070075 nasmlib\realpath.$(O) nasmlib\path.$(O) \
H. Peter Anvin (Intel)d2320052020-06-04 18:30:35 -070076 nasmlib\filename.$(O) nasmlib\rlimit.$(O) \
H. Peter Anvin9a714c92017-04-06 17:24:03 -070077 nasmlib\zerobuf.$(O) nasmlib\readnum.$(O) nasmlib\bsi.$(O) \
78 nasmlib\rbtree.$(O) nasmlib\hashtbl.$(O) \
79 nasmlib\raa.$(O) nasmlib\saa.$(O) \
80 nasmlib\strlist.$(O) \
81 nasmlib\perfhash.$(O) nasmlib\badenum.$(O) \
H. Peter Anvin81b62b92017-12-20 13:33:49 -080082 \
H. Peter Anvin9a714c92017-04-06 17:24:03 -070083 common\common.$(O) \
H. Peter Anvin81b62b92017-12-20 13:33:49 -080084 \
H. Peter Anvin9a714c92017-04-06 17:24:03 -070085 x86\insnsa.$(O) x86\insnsb.$(O) x86\insnsd.$(O) x86\insnsn.$(O) \
86 x86\regs.$(O) x86\regvals.$(O) x86\regflags.$(O) x86\regdis.$(O) \
87 x86\disp8.$(O) x86\iflag.$(O) \
H. Peter Anvin4d58a8f2017-02-28 18:08:21 -080088 \
H. Peter Anvin0a2b1c32018-12-26 06:31:54 -080089 asm\error.$(O) asm\warnings.$(O) \
H. Peter Anvin (Intel)6e9554f2020-06-14 23:21:44 -070090 asm\floats.$(O) \
H. Peter Anvin9a714c92017-04-06 17:24:03 -070091 asm\directiv.$(O) asm\directbl.$(O) \
92 asm\pragma.$(O) \
93 asm\assemble.$(O) asm\labels.$(O) asm\parser.$(O) \
94 asm\preproc.$(O) asm\quote.$(O) asm\pptok.$(O) \
95 asm\listing.$(O) asm\eval.$(O) asm\exprlib.$(O) asm\exprdump.$(O) \
96 asm\stdscan.$(O) \
97 asm\strfunc.$(O) asm\tokhash.$(O) \
98 asm\segalloc.$(O) \
99 asm\preproc-nop.$(O) \
100 asm\rdstrnum.$(O) \
H. Peter Anvin (Intel)eb5b3ae2018-12-12 14:34:34 -0800101 asm\srcfile.$(O) \
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700102 macros\macros.$(O) \
H. Peter Anvine1f985c2016-05-25 12:06:29 -0700103 \
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700104 output\outform.$(O) output\outlib.$(O) output\legacy.$(O) \
105 output\nulldbg.$(O) output\nullout.$(O) \
106 output\outbin.$(O) output\outaout.$(O) output\outcoff.$(O) \
107 output\outelf.$(O) \
108 output\outobj.$(O) output\outas86.$(O) output\outrdf2.$(O) \
109 output\outdbg.$(O) output\outieee.$(O) output\outmacho.$(O) \
110 output\codeview.$(O) \
H. Peter Anvin4d58a8f2017-02-28 18:08:21 -0800111 \
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700112 disasm\disasm.$(O) disasm\sync.$(O)
H. Peter Anvin69809852017-03-01 01:23:00 -0800113
114SUBDIRS = stdlib nasmlib output asm disasm x86 common macros
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700115XSUBDIRS = test doc nsis rdoff
H. Peter Anvinad401692017-11-01 13:48:17 -0700116DEPDIRS = . include config x86 rdoff $(SUBDIRS)
H. Peter Anvinc0d60662008-06-15 23:50:50 -0700117#-- End File Lists --#
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700118
H. Peter Anvind7642a42017-04-06 18:18:11 -0700119NASMLIB = libnasm.$(A)
120
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700121all: nasm$(X) ndisasm$(X) rdf
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700122
H. Peter Anvind7642a42017-04-06 18:18:11 -0700123nasm$(X): $(NASM) $(NASMLIB)
124 $(CC) /Fe$@ $(NASM) $(LDFLAGS) $(NASMLIB) $(LIBS)
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700125
H. Peter Anvind7642a42017-04-06 18:18:11 -0700126ndisasm$(X): $(NDISASM) $(NASMLIB)
127 $(CC) /Fe$@ $(NDISASM) $(LDFLAGS) $(NASMLIB) $(LIBS)
Knut St. Osmundsen6fd29842016-04-21 09:13:19 +0300128
H. Peter Anvind7642a42017-04-06 18:18:11 -0700129$(NASMLIB): $(LIBOBJ)
Knut St. Osmundsen6fd29842016-04-21 09:13:19 +0300130 $(AR) $(ARFLAGS) /OUT:$@ $**
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700131
H. Peter Anvin14858d72017-04-03 11:13:29 -0700132#-- Begin Generated File Rules --#
133# Edit in Makefile.in, not here!
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700134
H. Peter Anvin14858d72017-04-03 11:13:29 -0700135# These source files are automagically generated from data files using
136# Perl scripts. They're distributed, though, so it isn't necessary to
137# have Perl just to recompile NASM from the distribution.
Cyrill Gorcunov08359152013-11-09 22:16:11 +0400138
H. Peter Anvin14858d72017-04-03 11:13:29 -0700139# Perl-generated source files
H. Peter Anvin (Intel)e2040292020-07-06 11:10:30 -0700140PERLREQ = config\unconfig.h \
141 x86\insnsb.c x86\insnsa.c x86\insnsd.c x86\insnsi.h x86\insnsn.c \
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700142 x86\regs.c x86\regs.h x86\regflags.c x86\regdis.c x86\regdis.h \
143 x86\regvals.c asm\tokhash.c asm\tokens.h asm\pptok.h asm\pptok.c \
144 x86\iflag.c x86\iflaggen.h \
145 macros\macros.c \
146 asm\pptok.ph asm\directbl.c asm\directiv.h \
H. Peter Anvin (Intel)57c37532020-06-27 16:04:38 -0700147 asm\warnings.c include\warnings.h doc\warnings.src \
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700148 version.h version.mac version.mak nsis\version.nsh
Jim Kukunas2bedd242014-08-07 09:06:51 -0700149
H. Peter Anvin (Intel)418138c2019-08-06 22:05:49 -0700150INSDEP = x86\insns.dat x86\insns.pl x86\insns-iflags.ph x86\iflags.ph
H. Peter Anvin14858d72017-04-03 11:13:29 -0700151
H. Peter Anvin (Intel)e2040292020-07-06 11:10:30 -0700152config\unconfig.h: config\config.h.in
153 $(RUNPERL) $(srcdir)\tools\unconfig.pl \
154 '$(srcdir)' config\config.h.in config\unconfig.h
155
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700156x86\iflag.c: $(INSDEP)
157 $(RUNPERL) $(srcdir)\x86\insns.pl -fc \
158 $(srcdir)\x86\insns.dat x86\iflag.c
159x86\iflaggen.h: $(INSDEP)
160 $(RUNPERL) $(srcdir)\x86\insns.pl -fh \
161 $(srcdir)\x86\insns.dat x86\iflaggen.h
162x86\insnsb.c: $(INSDEP)
163 $(RUNPERL) $(srcdir)\x86\insns.pl -b \
164 $(srcdir)\x86\insns.dat x86\insnsb.c
165x86\insnsa.c: $(INSDEP)
166 $(RUNPERL) $(srcdir)\x86\insns.pl -a \
167 $(srcdir)\x86\insns.dat x86\insnsa.c
168x86\insnsd.c: $(INSDEP)
169 $(RUNPERL) $(srcdir)\x86\insns.pl -d \
170 $(srcdir)\x86\insns.dat x86\insnsd.c
171x86\insnsi.h: $(INSDEP)
172 $(RUNPERL) $(srcdir)\x86\insns.pl -i \
173 $(srcdir)\x86\insns.dat x86\insnsi.h
174x86\insnsn.c: $(INSDEP)
175 $(RUNPERL) $(srcdir)\x86\insns.pl -n \
176 $(srcdir)\x86\insns.dat x86\insnsn.c
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700177
178# These files contains all the standard macros that are derived from
179# the version number.
180version.h: version version.pl
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700181 $(RUNPERL) $(srcdir)\version.pl h < $(srcdir)\version > version.h
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700182version.mac: version version.pl
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700183 $(RUNPERL) $(srcdir)\version.pl mac < $(srcdir)\version > version.mac
H. Peter Anvin14858d72017-04-03 11:13:29 -0700184version.sed: version version.pl
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700185 $(RUNPERL) $(srcdir)\version.pl sed < $(srcdir)\version > version.sed
H. Peter Anvin14858d72017-04-03 11:13:29 -0700186version.mak: version version.pl
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700187 $(RUNPERL) $(srcdir)\version.pl make < $(srcdir)\version > version.mak
188nsis\version.nsh: version version.pl
189 $(RUNPERL) $(srcdir)\version.pl nsis < $(srcdir)\version > nsis\version.nsh
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700190
191# This source file is generated from the standard macros file
192# `standard.mac' by another Perl script. Again, it's part of the
193# standard distribution.
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700194macros\macros.c: macros\macros.pl asm\pptok.ph version.mac \
195 $(srcdir)\macros\*.mac $(srcdir)\output\*.mac
196 $(RUNPERL) $(srcdir)\macros\macros.pl version.mac \
197 $(srcdir)\macros\*.mac $(srcdir)\output\*.mac
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700198
199# These source files are generated from regs.dat by yet another
200# perl script.
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700201x86\regs.c: x86\regs.dat x86\regs.pl
202 $(RUNPERL) $(srcdir)\x86\regs.pl c \
203 $(srcdir)\x86\regs.dat > x86\regs.c
204x86\regflags.c: x86\regs.dat x86\regs.pl
205 $(RUNPERL) $(srcdir)\x86\regs.pl fc \
206 $(srcdir)\x86\regs.dat > x86\regflags.c
207x86\regdis.c: x86\regs.dat x86\regs.pl
208 $(RUNPERL) $(srcdir)\x86\regs.pl dc \
209 $(srcdir)\x86\regs.dat > x86\regdis.c
210x86\regdis.h: x86\regs.dat x86\regs.pl
211 $(RUNPERL) $(srcdir)\x86\regs.pl dh \
212 $(srcdir)\x86\regs.dat > x86\regdis.h
213x86\regvals.c: x86\regs.dat x86\regs.pl
214 $(RUNPERL) $(srcdir)\x86\regs.pl vc \
215 $(srcdir)\x86\regs.dat > x86\regvals.c
216x86\regs.h: x86\regs.dat x86\regs.pl
217 $(RUNPERL) $(srcdir)\x86\regs.pl h \
218 $(srcdir)\x86\regs.dat > x86\regs.h
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700219
H. Peter Anvin0a2b1c32018-12-26 06:31:54 -0800220# Extract warnings from source code. Since this depends on
221# ALL the source files, this is only done on demand.
222WARNFILES = asm\warnings.c include\warnings.h doc\warnings.src
223
224warnings:
H. Peter Anvin (Intel)d2320052020-06-04 18:30:35 -0700225 $(RM_F) $(WARNFILES)
H. Peter Anvin0a2b1c32018-12-26 06:31:54 -0800226 $(MAKE) $(WARNFILES)
227
228asm\warnings.c: asm\warnings.pl
229 $(RUNPERL) $(srcdir)\asm\warnings.pl c asm\warnings.c $(srcdir)
230
231include\warnings.h: asm\warnings.pl
232 $(RUNPERL) $(srcdir)\asm\warnings.pl h include\warnings.h $(srcdir)
233
234doc\warnings.src: asm\warnings.pl
235 $(RUNPERL) $(srcdir)\asm\warnings.pl doc doc\warnings.src $(srcdir)
236
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700237# Assembler token hash
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700238asm\tokhash.c: x86\insns.dat x86\regs.dat asm\tokens.dat asm\tokhash.pl \
239 perllib\phash.ph
240 $(RUNPERL) $(srcdir)\asm\tokhash.pl c \
241 $(srcdir)\x86\insns.dat $(srcdir)\x86\regs.dat \
242 $(srcdir)\asm\tokens.dat > asm\tokhash.c
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700243
H. Peter Anvindc467ba2007-09-24 12:30:54 -0700244# Assembler token metadata
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700245asm\tokens.h: x86\insns.dat x86\regs.dat asm\tokens.dat asm\tokhash.pl \
246 perllib\phash.ph
247 $(RUNPERL) $(srcdir)\asm\tokhash.pl h \
248 $(srcdir)\x86\insns.dat $(srcdir)\x86\regs.dat \
249 $(srcdir)\asm\tokens.dat > asm\tokens.h
H. Peter Anvindc467ba2007-09-24 12:30:54 -0700250
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700251# Preprocessor token hash
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700252asm\pptok.h: asm\pptok.dat asm\pptok.pl perllib\phash.ph
253 $(RUNPERL) $(srcdir)\asm\pptok.pl h \
254 $(srcdir)\asm\pptok.dat asm\pptok.h
255asm\pptok.c: asm\pptok.dat asm\pptok.pl perllib\phash.ph
256 $(RUNPERL) $(srcdir)\asm\pptok.pl c \
257 $(srcdir)\asm\pptok.dat asm\pptok.c
258asm\pptok.ph: asm\pptok.dat asm\pptok.pl perllib\phash.ph
259 $(RUNPERL) $(srcdir)\asm\pptok.pl ph \
260 $(srcdir)\asm\pptok.dat asm\pptok.ph
Marat Dukhan10523942013-06-30 01:30:44 +0400261
262# Directives hash
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700263asm\directiv.h: asm\directiv.dat nasmlib\perfhash.pl perllib\phash.ph
264 $(RUNPERL) $(srcdir)\nasmlib\perfhash.pl h \
265 $(srcdir)\asm\directiv.dat asm\directiv.h
266asm\directbl.c: asm\directiv.dat nasmlib\perfhash.pl perllib\phash.ph
267 $(RUNPERL) $(srcdir)\nasmlib\perfhash.pl c \
268 $(srcdir)\asm\directiv.dat asm\directbl.c
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700269
H. Peter Anvin14858d72017-04-03 11:13:29 -0700270#-- End Generated File Rules --#
271
H. Peter Anvin90cc4152017-04-05 21:24:55 -0700272perlreq: $(PERLREQ)
273
H. Peter Anvin5d819332018-06-18 13:50:25 -0700274# This rule is only used for RDOFF
275.obj.exe:
276 $(CC) /Fe$@ $< $(LDFLAGS) $(RDFLIB) $(NASMLIB) $(LIBS)
277
278RDFLN = copy
279RDFLNPFX = rdoff^\
280
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700281#-- Begin RDOFF Shared Rules --#
282# Edit in Makefile.in, not here!
283
284RDFLIBOBJ = rdoff\rdoff.$(O) rdoff\rdfload.$(O) rdoff\symtab.$(O) \
285 rdoff\collectn.$(O) rdoff\rdlib.$(O) rdoff\segtab.$(O) \
286 rdoff\hash.$(O)
287
288RDFPROGS = rdoff\rdfdump$(X) rdoff\ldrdf$(X) rdoff\rdx$(X) rdoff\rdflib$(X) \
289 rdoff\rdf2bin$(X)
290RDF2BINLINKS = rdoff\rdf2com$(X) rdoff\rdf2ith$(X) \
291 rdoff\rdf2ihx$(X) rdoff\rdf2srec$(X)
292
293RDFLIB = rdoff\librdoff.$(A)
294RDFLIBS = $(RDFLIB) $(NASMLIB)
295
296rdoff\rdfdump$(X): rdoff\rdfdump.$(O) $(RDFLIBS)
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700297rdoff\ldrdf$(X): rdoff\ldrdf.$(O) $(RDFLIBS)
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700298rdoff\rdx$(X): rdoff\rdx.$(O) $(RDFLIBS)
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700299rdoff\rdflib$(X): rdoff\rdflib.$(O) $(RDFLIBS)
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700300rdoff\rdf2bin$(X): rdoff\rdf2bin.$(O) $(RDFLIBS)
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700301rdoff\rdf2com$(X): rdoff\rdf2bin$(X)
302 $(RM_F) rdoff\rdf2com$(X)
H. Peter Anvin5d819332018-06-18 13:50:25 -0700303 $(RDFLN) $(RDFLNPFX)rdf2bin$(X) $(RDFLNPFX)rdf2com$(X)
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700304rdoff\rdf2ith$(X): rdoff\rdf2bin$(X)
305 $(RM_F) rdoff\rdf2ith$(X)
H. Peter Anvin5d819332018-06-18 13:50:25 -0700306 $(RDFLN) $(RDFLNPFX)rdf2bin$(X) $(RDFLNPFX)rdf2ith$(X)
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700307rdoff\rdf2ihx$(X): rdoff\rdf2bin$(X)
H. Peter Anvin910ae642017-04-06 23:18:36 -0700308 $(RM_F) rdoff\rdf2ihx$(X)
H. Peter Anvin5d819332018-06-18 13:50:25 -0700309 $(RDFLN) $(RDFLNPFX)rdf2bin$(X) $(RDFLNPFX)rdf2ihx$(X)
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700310rdoff\rdf2srec$(X): rdoff\rdf2bin$(X)
H. Peter Anvin910ae642017-04-06 23:18:36 -0700311 $(RM_F) rdoff\rdf2srec$(X)
H. Peter Anvin5d819332018-06-18 13:50:25 -0700312 $(RDFLN) $(RDFLNPFX)rdf2bin$(X) $(RDFLNPFX)rdf2srec$(X)
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700313
314#-- End RDOFF Shared Rules --#
315
316rdf: $(RDFPROGS) $(RDF2BINLINKS)
317
H. Peter Anvind7642a42017-04-06 18:18:11 -0700318$(RDFLIB): $(RDFLIBOBJ)
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700319 $(AR) $(ARFLAGS) /OUT:$@ $**
320
H. Peter Anvin14858d72017-04-03 11:13:29 -0700321#-- Begin NSIS Rules --#
322# Edit in Makefile.in, not here!
323
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700324nsis\arch.nsh: nsis\getpearch.pl nasm$(X)
325 $(PERL) $(srcdir)\nsis\getpearch.pl nasm$(X) > nsis\arch.nsh
H. Peter Anvin14858d72017-04-03 11:13:29 -0700326
327# Should only be done after "make everything".
328# The use of redirection here keeps makensis from moving the cwd to the
329# source directory.
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700330nsis: nsis\nasm.nsi nsis\arch.nsh nsis\version.nsh
331 $(MAKENSIS) -Dsrcdir="$(srcdir)" -Dobjdir="$(objdir)" - < nsis\nasm.nsi
H. Peter Anvin14858d72017-04-03 11:13:29 -0700332
333#-- End NSIS Rules --#
334
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700335clean:
H. Peter Anvind7642a42017-04-06 18:18:11 -0700336 -del /f /s *.$(O)
337 -del /f /s *.pdb
338 -del /f /s *.s
339 -del /f /s *.i
340 -del /f $(NASMLIB) $(RDFLIB)
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700341 -del /f nasm$(X)
342 -del /f ndisasm$(X)
H. Peter Anvind7642a42017-04-06 18:18:11 -0700343 -del /f rdoff\*$(X)
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700344
345distclean: clean
346 -del /f config.h
347 -del /f config.log
348 -del /f config.status
349 -del /f Makefile
H. Peter Anvind7642a42017-04-06 18:18:11 -0700350 -del /f /s *~
351 -del /f /s *.bak
352 -del /f /s *.lst
353 -del /f /s *.bin
H. Peter Anvinad401692017-11-01 13:48:17 -0700354 -del /f /s *.dep
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700355 -del /f output\*~
356 -del /f output\*.bak
357 -del /f test\*.lst
358 -del /f test\*.bin
359 -del /f test\*.$(O)
360 -del /f test\*.bin
361 -del /f/s autom4te*.cache
362 rem cd rdoff && $(MAKE) distclean
363
364cleaner: clean
365 -del /f $(PERLREQ)
366 -del /f *.man
367 -del /f nasm.spec
368 rem cd doc && $(MAKE) clean
369
370spotless: distclean cleaner
371 -del /f doc\Makefile
372 -del doc\*~
373 -del doc\*.bak
374
375strip:
376
H. Peter Anvin77f43952017-04-06 20:20:04 -0700377# Abuse doc/Makefile.in to build nasmdoc.pdf only
378docs:
H. Peter Anvinf13effe2017-04-10 16:10:28 -0700379 cd doc && $(MAKE) /f Makefile.in srcdir=. top_srcdir=.. \
380 PERL=$(PERL) PDFOPT= nasmdoc.pdf
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700381
H. Peter Anvin77f43952017-04-06 20:20:04 -0700382everything: all docs nsis
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700383
H. Peter Anvind685bd22017-11-08 10:57:16 -0800384#
385# Does this version of this file have external dependencies? This definition
386# will be automatically updated by mkdep.pl as needed.
387#
388EXTERNAL_DEPENDENCIES = 1
389
390#
391# Generate dependency information for this Makefile only.
392# If this Makefile has external dependency information, then
393# the dependency information will remain external, so it doesn't
394# pollute the git logs.
395#
396msvc.dep: $(PERLREQ) tools\mkdep.pl
397 $(RUNPERL) tools\mkdep.pl -M Mkfiles\msvc.mak -- $(DEPDIRS)
398
399dep: msvc.dep
400
401# Include and/or generate msvc.dep as needed. This is too complex to
402# use the include-command feature, but we can open-code it here.
H. Peter Anvin5d819332018-06-18 13:50:25 -0700403MKDEP=0
404!IF $(EXTERNAL_DEPENDENCIES) == 1 && $(MKDEP) == 0
H. Peter Anvin53d8f222017-11-08 11:08:37 -0800405!IF EXISTS(msvc.dep)
H. Peter Anvind685bd22017-11-08 10:57:16 -0800406!INCLUDE msvc.dep
H. Peter Anvin53d8f222017-11-08 11:08:37 -0800407!ELSEIF [$(MAKE) /c MKDEP=1 /f Mkfiles\msvc.mak msvc.dep] == 0
408!INCLUDE msvc.dep
409!ELSE
410!ERROR Unable to rebuild dependencies file msvc.dep
H. Peter Anvind685bd22017-11-08 10:57:16 -0800411!ENDIF
H. Peter Anvin5d819332018-06-18 13:50:25 -0700412!ENDIF
H. Peter Anvind685bd22017-11-08 10:57:16 -0800413
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700414#-- Magic hints to mkdep.pl --#
415# @object-ending: ".$(O)"
H. Peter Anvin9a714c92017-04-06 17:24:03 -0700416# @path-separator: "\"
H. Peter Anvin (Intel)147f32a2020-07-01 21:13:27 -0700417# @exclude: "config/config.h"
H. Peter Anvind685bd22017-11-08 10:57:16 -0800418# @external: "msvc.dep"
419# @selfrule: "1"
H. Peter Anvine8bfecf2007-09-16 22:16:24 -0700420#-- Everything below is generated by mkdep.pl - do not edit --#