msvc.mak 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400
  1. # -*- makefile -*-
  2. #
  3. # 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.
  8. #
  9. # This is typically done by opening the Visual Studio Command Prompt.
  10. #
  11. top_srcdir = .
  12. srcdir = .
  13. objdir = .
  14. VPATH = .
  15. prefix = "C:\Program Files\NASM"
  16. exec_prefix = $(prefix)
  17. bindir = $(prefix)/bin
  18. mandir = $(prefix)/man
  19. !IF "$(DEBUG)" == "1"
  20. CFLAGS = /Od /Zi
  21. LDFLAGS = /DEBUG
  22. !ELSE
  23. CFLAGS = /O2 /Zi
  24. LDFLAGS = /DEBUG /OPT:REF /OPT:ICF # (latter two undoes /DEBUG harm)
  25. !ENDIF
  26. CC = cl
  27. AR = lib
  28. CFLAGS = $(CFLAGS) /W2
  29. BUILD_CFLAGS = $(CFLAGS)
  30. INTERNAL_CFLAGS = /I$(srcdir) /I. \
  31. /I$(srcdir)/include /I./include \
  32. /I$(srcdir)/x86 /I./x86 \
  33. /I$(srcdir)/asm /I./asm \
  34. /I$(srcdir)/disasm /I./disasm \
  35. /I$(srcdir)/output /I./output
  36. ALL_CFLAGS = $(BUILD_CFLAGS) $(INTERNAL_CFLAGS)
  37. LDFLAGS = /link $(LINKFLAGS) /SUBSYSTEM:CONSOLE /RELEASE
  38. LIBS =
  39. PERL = perl
  40. PERLFLAGS = -I$(srcdir)/perllib -I$(srcdir)
  41. RUNPERL = $(PERL) $(PERLFLAGS)
  42. MAKENSIS = makensis
  43. RM_F = -del /f
  44. LN_S = copy
  45. # Binary suffixes
  46. O = obj
  47. A = lib
  48. X = .exe
  49. .SUFFIXES:
  50. .SUFFIXES: $(X) .$(A) .$(O) .c .i .s .1 .man
  51. .c.obj:
  52. $(CC) /c $(ALL_CFLAGS) /Fo$@ $<
  53. #-- Begin File Lists --#
  54. # Edit in Makefile.in, not here!
  55. NASM = asm\nasm.$(O)
  56. NDISASM = disasm\ndisasm.$(O)
  57. LIBOBJ = stdlib\snprintf.$(O) stdlib\vsnprintf.$(O) stdlib\strlcpy.$(O) \
  58. stdlib\strnlen.$(O) stdlib\strrchrnul.$(O) \
  59. \
  60. nasmlib\ver.$(O) \
  61. nasmlib\crc64.$(O) nasmlib\malloc.$(O) nasmlib\errfile.$(O) \
  62. nasmlib\md5c.$(O) nasmlib\string.$(O) \
  63. nasmlib\file.$(O) nasmlib\mmap.$(O) nasmlib\ilog2.$(O) \
  64. nasmlib\realpath.$(O) nasmlib\path.$(O) \
  65. nasmlib\filename.$(O) nasmlib\srcfile.$(O) \
  66. nasmlib\zerobuf.$(O) nasmlib\readnum.$(O) nasmlib\bsi.$(O) \
  67. nasmlib\rbtree.$(O) nasmlib\hashtbl.$(O) \
  68. nasmlib\raa.$(O) nasmlib\saa.$(O) \
  69. nasmlib\strlist.$(O) \
  70. nasmlib\perfhash.$(O) nasmlib\badenum.$(O) \
  71. \
  72. common\common.$(O) \
  73. \
  74. x86\insnsa.$(O) x86\insnsb.$(O) x86\insnsd.$(O) x86\insnsn.$(O) \
  75. x86\regs.$(O) x86\regvals.$(O) x86\regflags.$(O) x86\regdis.$(O) \
  76. x86\disp8.$(O) x86\iflag.$(O) \
  77. \
  78. asm\error.$(O) \
  79. asm\float.$(O) \
  80. asm\directiv.$(O) asm\directbl.$(O) \
  81. asm\pragma.$(O) \
  82. asm\assemble.$(O) asm\labels.$(O) asm\parser.$(O) \
  83. asm\preproc.$(O) asm\quote.$(O) asm\pptok.$(O) \
  84. asm\listing.$(O) asm\eval.$(O) asm\exprlib.$(O) asm\exprdump.$(O) \
  85. asm\stdscan.$(O) \
  86. asm\strfunc.$(O) asm\tokhash.$(O) \
  87. asm\segalloc.$(O) \
  88. asm\preproc-nop.$(O) \
  89. asm\rdstrnum.$(O) \
  90. \
  91. macros\macros.$(O) \
  92. \
  93. output\outform.$(O) output\outlib.$(O) output\legacy.$(O) \
  94. output\strtbl.$(O) \
  95. output\nulldbg.$(O) output\nullout.$(O) \
  96. output\outbin.$(O) output\outaout.$(O) output\outcoff.$(O) \
  97. output\outelf.$(O) \
  98. output\outobj.$(O) output\outas86.$(O) output\outrdf2.$(O) \
  99. output\outdbg.$(O) output\outieee.$(O) output\outmacho.$(O) \
  100. output\codeview.$(O) \
  101. \
  102. disasm\disasm.$(O) disasm\sync.$(O)
  103. SUBDIRS = stdlib nasmlib output asm disasm x86 common macros
  104. XSUBDIRS = test doc nsis rdoff
  105. DEPDIRS = . include config x86 rdoff $(SUBDIRS)
  106. #-- End File Lists --#
  107. NASMLIB = libnasm.$(A)
  108. all: nasm$(X) ndisasm$(X) rdf
  109. nasm$(X): $(NASM) $(NASMLIB)
  110. $(CC) /Fe$@ $(NASM) $(LDFLAGS) $(NASMLIB) $(LIBS)
  111. ndisasm$(X): $(NDISASM) $(NASMLIB)
  112. $(CC) /Fe$@ $(NDISASM) $(LDFLAGS) $(NASMLIB) $(LIBS)
  113. $(NASMLIB): $(LIBOBJ)
  114. $(AR) $(ARFLAGS) /OUT:$@ $**
  115. #-- Begin Generated File Rules --#
  116. # Edit in Makefile.in, not here!
  117. # These source files are automagically generated from data files using
  118. # Perl scripts. They're distributed, though, so it isn't necessary to
  119. # have Perl just to recompile NASM from the distribution.
  120. # Perl-generated source files
  121. PERLREQ = x86\insnsb.c x86\insnsa.c x86\insnsd.c x86\insnsi.h x86\insnsn.c \
  122. x86\regs.c x86\regs.h x86\regflags.c x86\regdis.c x86\regdis.h \
  123. x86\regvals.c asm\tokhash.c asm\tokens.h asm\pptok.h asm\pptok.c \
  124. x86\iflag.c x86\iflaggen.h \
  125. macros\macros.c \
  126. asm\pptok.ph asm\directbl.c asm\directiv.h \
  127. version.h version.mac version.mak nsis\version.nsh
  128. INSDEP = x86\insns.dat x86\insns.pl x86\insns-iflags.ph
  129. x86\iflag.c: $(INSDEP)
  130. $(RUNPERL) $(srcdir)\x86\insns.pl -fc \
  131. $(srcdir)\x86\insns.dat x86\iflag.c
  132. x86\iflaggen.h: $(INSDEP)
  133. $(RUNPERL) $(srcdir)\x86\insns.pl -fh \
  134. $(srcdir)\x86\insns.dat x86\iflaggen.h
  135. x86\insnsb.c: $(INSDEP)
  136. $(RUNPERL) $(srcdir)\x86\insns.pl -b \
  137. $(srcdir)\x86\insns.dat x86\insnsb.c
  138. x86\insnsa.c: $(INSDEP)
  139. $(RUNPERL) $(srcdir)\x86\insns.pl -a \
  140. $(srcdir)\x86\insns.dat x86\insnsa.c
  141. x86\insnsd.c: $(INSDEP)
  142. $(RUNPERL) $(srcdir)\x86\insns.pl -d \
  143. $(srcdir)\x86\insns.dat x86\insnsd.c
  144. x86\insnsi.h: $(INSDEP)
  145. $(RUNPERL) $(srcdir)\x86\insns.pl -i \
  146. $(srcdir)\x86\insns.dat x86\insnsi.h
  147. x86\insnsn.c: $(INSDEP)
  148. $(RUNPERL) $(srcdir)\x86\insns.pl -n \
  149. $(srcdir)\x86\insns.dat x86\insnsn.c
  150. # These files contains all the standard macros that are derived from
  151. # the version number.
  152. version.h: version version.pl
  153. $(RUNPERL) $(srcdir)\version.pl h < $(srcdir)\version > version.h
  154. version.mac: version version.pl
  155. $(RUNPERL) $(srcdir)\version.pl mac < $(srcdir)\version > version.mac
  156. version.sed: version version.pl
  157. $(RUNPERL) $(srcdir)\version.pl sed < $(srcdir)\version > version.sed
  158. version.mak: version version.pl
  159. $(RUNPERL) $(srcdir)\version.pl make < $(srcdir)\version > version.mak
  160. nsis\version.nsh: version version.pl
  161. $(RUNPERL) $(srcdir)\version.pl nsis < $(srcdir)\version > nsis\version.nsh
  162. # This source file is generated from the standard macros file
  163. # `standard.mac' by another Perl script. Again, it's part of the
  164. # standard distribution.
  165. macros\macros.c: macros\macros.pl asm\pptok.ph version.mac \
  166. $(srcdir)\macros\*.mac $(srcdir)\output\*.mac
  167. $(RUNPERL) $(srcdir)\macros\macros.pl version.mac \
  168. $(srcdir)\macros\*.mac $(srcdir)\output\*.mac
  169. # These source files are generated from regs.dat by yet another
  170. # perl script.
  171. x86\regs.c: x86\regs.dat x86\regs.pl
  172. $(RUNPERL) $(srcdir)\x86\regs.pl c \
  173. $(srcdir)\x86\regs.dat > x86\regs.c
  174. x86\regflags.c: x86\regs.dat x86\regs.pl
  175. $(RUNPERL) $(srcdir)\x86\regs.pl fc \
  176. $(srcdir)\x86\regs.dat > x86\regflags.c
  177. x86\regdis.c: x86\regs.dat x86\regs.pl
  178. $(RUNPERL) $(srcdir)\x86\regs.pl dc \
  179. $(srcdir)\x86\regs.dat > x86\regdis.c
  180. x86\regdis.h: x86\regs.dat x86\regs.pl
  181. $(RUNPERL) $(srcdir)\x86\regs.pl dh \
  182. $(srcdir)\x86\regs.dat > x86\regdis.h
  183. x86\regvals.c: x86\regs.dat x86\regs.pl
  184. $(RUNPERL) $(srcdir)\x86\regs.pl vc \
  185. $(srcdir)\x86\regs.dat > x86\regvals.c
  186. x86\regs.h: x86\regs.dat x86\regs.pl
  187. $(RUNPERL) $(srcdir)\x86\regs.pl h \
  188. $(srcdir)\x86\regs.dat > x86\regs.h
  189. # Assembler token hash
  190. asm\tokhash.c: x86\insns.dat x86\regs.dat asm\tokens.dat asm\tokhash.pl \
  191. perllib\phash.ph
  192. $(RUNPERL) $(srcdir)\asm\tokhash.pl c \
  193. $(srcdir)\x86\insns.dat $(srcdir)\x86\regs.dat \
  194. $(srcdir)\asm\tokens.dat > asm\tokhash.c
  195. # Assembler token metadata
  196. asm\tokens.h: x86\insns.dat x86\regs.dat asm\tokens.dat asm\tokhash.pl \
  197. perllib\phash.ph
  198. $(RUNPERL) $(srcdir)\asm\tokhash.pl h \
  199. $(srcdir)\x86\insns.dat $(srcdir)\x86\regs.dat \
  200. $(srcdir)\asm\tokens.dat > asm\tokens.h
  201. # Preprocessor token hash
  202. asm\pptok.h: asm\pptok.dat asm\pptok.pl perllib\phash.ph
  203. $(RUNPERL) $(srcdir)\asm\pptok.pl h \
  204. $(srcdir)\asm\pptok.dat asm\pptok.h
  205. asm\pptok.c: asm\pptok.dat asm\pptok.pl perllib\phash.ph
  206. $(RUNPERL) $(srcdir)\asm\pptok.pl c \
  207. $(srcdir)\asm\pptok.dat asm\pptok.c
  208. asm\pptok.ph: asm\pptok.dat asm\pptok.pl perllib\phash.ph
  209. $(RUNPERL) $(srcdir)\asm\pptok.pl ph \
  210. $(srcdir)\asm\pptok.dat asm\pptok.ph
  211. # Directives hash
  212. asm\directiv.h: asm\directiv.dat nasmlib\perfhash.pl perllib\phash.ph
  213. $(RUNPERL) $(srcdir)\nasmlib\perfhash.pl h \
  214. $(srcdir)\asm\directiv.dat asm\directiv.h
  215. asm\directbl.c: asm\directiv.dat nasmlib\perfhash.pl perllib\phash.ph
  216. $(RUNPERL) $(srcdir)\nasmlib\perfhash.pl c \
  217. $(srcdir)\asm\directiv.dat asm\directbl.c
  218. #-- End Generated File Rules --#
  219. perlreq: $(PERLREQ)
  220. # This rule is only used for RDOFF
  221. .obj.exe:
  222. $(CC) /Fe$@ $< $(LDFLAGS) $(RDFLIB) $(NASMLIB) $(LIBS)
  223. RDFLN = copy
  224. RDFLNPFX = rdoff^\
  225. #-- Begin RDOFF Shared Rules --#
  226. # Edit in Makefile.in, not here!
  227. RDFLIBOBJ = rdoff\rdoff.$(O) rdoff\rdfload.$(O) rdoff\symtab.$(O) \
  228. rdoff\collectn.$(O) rdoff\rdlib.$(O) rdoff\segtab.$(O) \
  229. rdoff\hash.$(O)
  230. RDFPROGS = rdoff\rdfdump$(X) rdoff\ldrdf$(X) rdoff\rdx$(X) rdoff\rdflib$(X) \
  231. rdoff\rdf2bin$(X)
  232. RDF2BINLINKS = rdoff\rdf2com$(X) rdoff\rdf2ith$(X) \
  233. rdoff\rdf2ihx$(X) rdoff\rdf2srec$(X)
  234. RDFLIB = rdoff\librdoff.$(A)
  235. RDFLIBS = $(RDFLIB) $(NASMLIB)
  236. rdoff\rdfdump$(X): rdoff\rdfdump.$(O) $(RDFLIBS)
  237. rdoff\ldrdf$(X): rdoff\ldrdf.$(O) $(RDFLIBS)
  238. rdoff\rdx$(X): rdoff\rdx.$(O) $(RDFLIBS)
  239. rdoff\rdflib$(X): rdoff\rdflib.$(O) $(RDFLIBS)
  240. rdoff\rdf2bin$(X): rdoff\rdf2bin.$(O) $(RDFLIBS)
  241. rdoff\rdf2com$(X): rdoff\rdf2bin$(X)
  242. $(RM_F) rdoff\rdf2com$(X)
  243. $(RDFLN) $(RDFLNPFX)rdf2bin$(X) $(RDFLNPFX)rdf2com$(X)
  244. rdoff\rdf2ith$(X): rdoff\rdf2bin$(X)
  245. $(RM_F) rdoff\rdf2ith$(X)
  246. $(RDFLN) $(RDFLNPFX)rdf2bin$(X) $(RDFLNPFX)rdf2ith$(X)
  247. rdoff\rdf2ihx$(X): rdoff\rdf2bin$(X)
  248. $(RM_F) rdoff\rdf2ihx$(X)
  249. $(RDFLN) $(RDFLNPFX)rdf2bin$(X) $(RDFLNPFX)rdf2ihx$(X)
  250. rdoff\rdf2srec$(X): rdoff\rdf2bin$(X)
  251. $(RM_F) rdoff\rdf2srec$(X)
  252. $(RDFLN) $(RDFLNPFX)rdf2bin$(X) $(RDFLNPFX)rdf2srec$(X)
  253. #-- End RDOFF Shared Rules --#
  254. rdf: $(RDFPROGS) $(RDF2BINLINKS)
  255. $(RDFLIB): $(RDFLIBOBJ)
  256. $(AR) $(ARFLAGS) /OUT:$@ $**
  257. #-- Begin NSIS Rules --#
  258. # Edit in Makefile.in, not here!
  259. # NSIS is not built except by explicit request, as it only applies to
  260. # Windows platforms
  261. nsis\arch.nsh: nsis\getpearch.pl nasm$(X)
  262. $(PERL) $(srcdir)\nsis\getpearch.pl nasm$(X) > nsis\arch.nsh
  263. # Should only be done after "make everything".
  264. # The use of redirection here keeps makensis from moving the cwd to the
  265. # source directory.
  266. nsis: nsis\nasm.nsi nsis\arch.nsh nsis\version.nsh
  267. $(MAKENSIS) -Dsrcdir="$(srcdir)" -Dobjdir="$(objdir)" - < nsis\nasm.nsi
  268. #-- End NSIS Rules --#
  269. clean:
  270. -del /f /s *.$(O)
  271. -del /f /s *.pdb
  272. -del /f /s *.s
  273. -del /f /s *.i
  274. -del /f $(NASMLIB) $(RDFLIB)
  275. -del /f nasm$(X)
  276. -del /f ndisasm$(X)
  277. -del /f rdoff\*$(X)
  278. distclean: clean
  279. -del /f config.h
  280. -del /f config.log
  281. -del /f config.status
  282. -del /f Makefile
  283. -del /f /s *~
  284. -del /f /s *.bak
  285. -del /f /s *.lst
  286. -del /f /s *.bin
  287. -del /f /s *.dep
  288. -del /f output\*~
  289. -del /f output\*.bak
  290. -del /f test\*.lst
  291. -del /f test\*.bin
  292. -del /f test\*.$(O)
  293. -del /f test\*.bin
  294. -del /f/s autom4te*.cache
  295. rem cd rdoff && $(MAKE) distclean
  296. cleaner: clean
  297. -del /f $(PERLREQ)
  298. -del /f *.man
  299. -del /f nasm.spec
  300. rem cd doc && $(MAKE) clean
  301. spotless: distclean cleaner
  302. -del /f doc\Makefile
  303. -del doc\*~
  304. -del doc\*.bak
  305. strip:
  306. # Abuse doc/Makefile.in to build nasmdoc.pdf only
  307. docs:
  308. cd doc && $(MAKE) /f Makefile.in srcdir=. top_srcdir=.. \
  309. PERL=$(PERL) PDFOPT= nasmdoc.pdf
  310. everything: all docs nsis
  311. #
  312. # Does this version of this file have external dependencies? This definition
  313. # will be automatically updated by mkdep.pl as needed.
  314. #
  315. EXTERNAL_DEPENDENCIES = 1
  316. #
  317. # Generate dependency information for this Makefile only.
  318. # If this Makefile has external dependency information, then
  319. # the dependency information will remain external, so it doesn't
  320. # pollute the git logs.
  321. #
  322. msvc.dep: $(PERLREQ) tools\mkdep.pl
  323. $(RUNPERL) tools\mkdep.pl -M Mkfiles\msvc.mak -- $(DEPDIRS)
  324. dep: msvc.dep
  325. # Include and/or generate msvc.dep as needed. This is too complex to
  326. # use the include-command feature, but we can open-code it here.
  327. MKDEP=0
  328. !IF $(EXTERNAL_DEPENDENCIES) == 1 && $(MKDEP) == 0
  329. !IF EXISTS(msvc.dep)
  330. !INCLUDE msvc.dep
  331. !ELSEIF [$(MAKE) /c MKDEP=1 /f Mkfiles\msvc.mak msvc.dep] == 0
  332. !INCLUDE msvc.dep
  333. !ELSE
  334. !ERROR Unable to rebuild dependencies file msvc.dep
  335. !ENDIF
  336. !ENDIF
  337. #-- Magic hints to mkdep.pl --#
  338. # @object-ending: ".$(O)"
  339. # @path-separator: "\"
  340. # @exclude: "config\config.h"
  341. # @external: "msvc.dep"
  342. # @selfrule: "1"
  343. #-- Everything below is generated by mkdep.pl - do not edit --#