mirror of
https://github.com/netwide-assembler/nasm.git
synced 2025-01-06 16:04:43 +08:00
5d8193367e
1. The mkdep.pl program didn't handle excluded dependencies correctly, causing it to error out due to config/config.h not existing. 2. NMAKE is sensitive to the order suffixes appear in .SUFFIXES, causing it to try to use the builtin rule .c.exe instead of .c.obj -> .obj.exe. 3. NMAKE doesn't handle the && operator between commands. 4. The !ifdef jungle around dependency generation was wrong. Signed-off-by: H. Peter Anvin <hpa@linux.intel.com>
400 lines
12 KiB
Makefile
400 lines
12 KiB
Makefile
# -*- makefile -*-
|
|
#
|
|
# Makefile for building NASM using Microsoft Visual C++ and NMAKE.
|
|
# Tested on Microsoft Visual C++ 2005 Express Edition.
|
|
#
|
|
# Make sure to put the appropriate directories in your PATH, in
|
|
# the case of MSVC++ 2005, they are ...\VC\bin and ...\Common7\IDE.
|
|
#
|
|
# This is typically done by opening the Visual Studio Command Prompt.
|
|
#
|
|
|
|
top_srcdir = .
|
|
srcdir = .
|
|
objdir = .
|
|
VPATH = .
|
|
prefix = "C:\Program Files\NASM"
|
|
exec_prefix = $(prefix)
|
|
bindir = $(prefix)/bin
|
|
mandir = $(prefix)/man
|
|
|
|
!IF "$(DEBUG)" == "1"
|
|
CFLAGS = /Od /Zi
|
|
LDFLAGS = /DEBUG
|
|
!ELSE
|
|
CFLAGS = /O2 /Zi
|
|
LDFLAGS = /DEBUG /OPT:REF /OPT:ICF # (latter two undoes /DEBUG harm)
|
|
!ENDIF
|
|
|
|
CC = cl
|
|
AR = lib
|
|
CFLAGS = $(CFLAGS) /W2
|
|
BUILD_CFLAGS = $(CFLAGS)
|
|
INTERNAL_CFLAGS = /I$(srcdir) /I. \
|
|
/I$(srcdir)/include /I./include \
|
|
/I$(srcdir)/x86 /I./x86 \
|
|
/I$(srcdir)/asm /I./asm \
|
|
/I$(srcdir)/disasm /I./disasm \
|
|
/I$(srcdir)/output /I./output
|
|
ALL_CFLAGS = $(BUILD_CFLAGS) $(INTERNAL_CFLAGS)
|
|
LDFLAGS = /link $(LINKFLAGS) /SUBSYSTEM:CONSOLE /RELEASE
|
|
LIBS =
|
|
|
|
PERL = perl
|
|
PERLFLAGS = -I$(srcdir)/perllib -I$(srcdir)
|
|
RUNPERL = $(PERL) $(PERLFLAGS)
|
|
|
|
MAKENSIS = makensis
|
|
|
|
RM_F = -del /f
|
|
LN_S = copy
|
|
|
|
# Binary suffixes
|
|
O = obj
|
|
A = lib
|
|
X = .exe
|
|
.SUFFIXES:
|
|
.SUFFIXES: $(X) .$(A) .$(O) .c .i .s .1 .man
|
|
|
|
.c.obj:
|
|
$(CC) /c $(ALL_CFLAGS) /Fo$@ $<
|
|
|
|
#-- Begin File Lists --#
|
|
# Edit in Makefile.in, not here!
|
|
NASM = asm\nasm.$(O)
|
|
NDISASM = disasm\ndisasm.$(O)
|
|
|
|
LIBOBJ = stdlib\snprintf.$(O) stdlib\vsnprintf.$(O) stdlib\strlcpy.$(O) \
|
|
stdlib\strnlen.$(O) stdlib\strrchrnul.$(O) \
|
|
\
|
|
nasmlib\ver.$(O) \
|
|
nasmlib\crc64.$(O) nasmlib\malloc.$(O) \
|
|
nasmlib\md5c.$(O) nasmlib\string.$(O) \
|
|
nasmlib\file.$(O) nasmlib\mmap.$(O) nasmlib\ilog2.$(O) \
|
|
nasmlib\realpath.$(O) nasmlib\path.$(O) \
|
|
nasmlib\filename.$(O) nasmlib\srcfile.$(O) \
|
|
nasmlib\zerobuf.$(O) nasmlib\readnum.$(O) nasmlib\bsi.$(O) \
|
|
nasmlib\rbtree.$(O) nasmlib\hashtbl.$(O) \
|
|
nasmlib\raa.$(O) nasmlib\saa.$(O) \
|
|
nasmlib\strlist.$(O) \
|
|
nasmlib\perfhash.$(O) nasmlib\badenum.$(O) \
|
|
\
|
|
common\common.$(O) \
|
|
\
|
|
x86\insnsa.$(O) x86\insnsb.$(O) x86\insnsd.$(O) x86\insnsn.$(O) \
|
|
x86\regs.$(O) x86\regvals.$(O) x86\regflags.$(O) x86\regdis.$(O) \
|
|
x86\disp8.$(O) x86\iflag.$(O) \
|
|
\
|
|
asm\error.$(O) \
|
|
asm\float.$(O) \
|
|
asm\directiv.$(O) asm\directbl.$(O) \
|
|
asm\pragma.$(O) \
|
|
asm\assemble.$(O) asm\labels.$(O) asm\parser.$(O) \
|
|
asm\preproc.$(O) asm\quote.$(O) asm\pptok.$(O) \
|
|
asm\listing.$(O) asm\eval.$(O) asm\exprlib.$(O) asm\exprdump.$(O) \
|
|
asm\stdscan.$(O) \
|
|
asm\strfunc.$(O) asm\tokhash.$(O) \
|
|
asm\segalloc.$(O) \
|
|
asm\preproc-nop.$(O) \
|
|
asm\rdstrnum.$(O) \
|
|
\
|
|
macros\macros.$(O) \
|
|
\
|
|
output\outform.$(O) output\outlib.$(O) output\legacy.$(O) \
|
|
output\strtbl.$(O) \
|
|
output\nulldbg.$(O) output\nullout.$(O) \
|
|
output\outbin.$(O) output\outaout.$(O) output\outcoff.$(O) \
|
|
output\outelf.$(O) \
|
|
output\outobj.$(O) output\outas86.$(O) output\outrdf2.$(O) \
|
|
output\outdbg.$(O) output\outieee.$(O) output\outmacho.$(O) \
|
|
output\codeview.$(O) \
|
|
\
|
|
disasm\disasm.$(O) disasm\sync.$(O)
|
|
|
|
SUBDIRS = stdlib nasmlib output asm disasm x86 common macros
|
|
XSUBDIRS = test doc nsis rdoff
|
|
DEPDIRS = . include config x86 rdoff $(SUBDIRS)
|
|
#-- End File Lists --#
|
|
|
|
NASMLIB = libnasm.$(A)
|
|
|
|
all: nasm$(X) ndisasm$(X) rdf
|
|
|
|
nasm$(X): $(NASM) $(NASMLIB)
|
|
$(CC) /Fe$@ $(NASM) $(LDFLAGS) $(NASMLIB) $(LIBS)
|
|
|
|
ndisasm$(X): $(NDISASM) $(NASMLIB)
|
|
$(CC) /Fe$@ $(NDISASM) $(LDFLAGS) $(NASMLIB) $(LIBS)
|
|
|
|
$(NASMLIB): $(LIBOBJ)
|
|
$(AR) $(ARFLAGS) /OUT:$@ $**
|
|
|
|
#-- Begin Generated File Rules --#
|
|
# Edit in Makefile.in, not here!
|
|
|
|
# These source files are automagically generated from data files using
|
|
# Perl scripts. They're distributed, though, so it isn't necessary to
|
|
# have Perl just to recompile NASM from the distribution.
|
|
|
|
# Perl-generated source files
|
|
PERLREQ = x86\insnsb.c x86\insnsa.c x86\insnsd.c x86\insnsi.h x86\insnsn.c \
|
|
x86\regs.c x86\regs.h x86\regflags.c x86\regdis.c x86\regdis.h \
|
|
x86\regvals.c asm\tokhash.c asm\tokens.h asm\pptok.h asm\pptok.c \
|
|
x86\iflag.c x86\iflaggen.h \
|
|
macros\macros.c \
|
|
asm\pptok.ph asm\directbl.c asm\directiv.h \
|
|
version.h version.mac version.mak nsis\version.nsh
|
|
|
|
INSDEP = x86\insns.dat x86\insns.pl x86\insns-iflags.ph
|
|
|
|
x86\iflag.c: $(INSDEP)
|
|
$(RUNPERL) $(srcdir)\x86\insns.pl -fc \
|
|
$(srcdir)\x86\insns.dat x86\iflag.c
|
|
x86\iflaggen.h: $(INSDEP)
|
|
$(RUNPERL) $(srcdir)\x86\insns.pl -fh \
|
|
$(srcdir)\x86\insns.dat x86\iflaggen.h
|
|
x86\insnsb.c: $(INSDEP)
|
|
$(RUNPERL) $(srcdir)\x86\insns.pl -b \
|
|
$(srcdir)\x86\insns.dat x86\insnsb.c
|
|
x86\insnsa.c: $(INSDEP)
|
|
$(RUNPERL) $(srcdir)\x86\insns.pl -a \
|
|
$(srcdir)\x86\insns.dat x86\insnsa.c
|
|
x86\insnsd.c: $(INSDEP)
|
|
$(RUNPERL) $(srcdir)\x86\insns.pl -d \
|
|
$(srcdir)\x86\insns.dat x86\insnsd.c
|
|
x86\insnsi.h: $(INSDEP)
|
|
$(RUNPERL) $(srcdir)\x86\insns.pl -i \
|
|
$(srcdir)\x86\insns.dat x86\insnsi.h
|
|
x86\insnsn.c: $(INSDEP)
|
|
$(RUNPERL) $(srcdir)\x86\insns.pl -n \
|
|
$(srcdir)\x86\insns.dat x86\insnsn.c
|
|
|
|
# These files contains all the standard macros that are derived from
|
|
# the version number.
|
|
version.h: version version.pl
|
|
$(RUNPERL) $(srcdir)\version.pl h < $(srcdir)\version > version.h
|
|
version.mac: version version.pl
|
|
$(RUNPERL) $(srcdir)\version.pl mac < $(srcdir)\version > version.mac
|
|
version.sed: version version.pl
|
|
$(RUNPERL) $(srcdir)\version.pl sed < $(srcdir)\version > version.sed
|
|
version.mak: version version.pl
|
|
$(RUNPERL) $(srcdir)\version.pl make < $(srcdir)\version > version.mak
|
|
nsis\version.nsh: version version.pl
|
|
$(RUNPERL) $(srcdir)\version.pl nsis < $(srcdir)\version > nsis\version.nsh
|
|
|
|
# This source file is generated from the standard macros file
|
|
# `standard.mac' by another Perl script. Again, it's part of the
|
|
# standard distribution.
|
|
macros\macros.c: macros\macros.pl asm\pptok.ph version.mac \
|
|
$(srcdir)\macros\*.mac $(srcdir)\output\*.mac
|
|
$(RUNPERL) $(srcdir)\macros\macros.pl version.mac \
|
|
$(srcdir)\macros\*.mac $(srcdir)\output\*.mac
|
|
|
|
# These source files are generated from regs.dat by yet another
|
|
# perl script.
|
|
x86\regs.c: x86\regs.dat x86\regs.pl
|
|
$(RUNPERL) $(srcdir)\x86\regs.pl c \
|
|
$(srcdir)\x86\regs.dat > x86\regs.c
|
|
x86\regflags.c: x86\regs.dat x86\regs.pl
|
|
$(RUNPERL) $(srcdir)\x86\regs.pl fc \
|
|
$(srcdir)\x86\regs.dat > x86\regflags.c
|
|
x86\regdis.c: x86\regs.dat x86\regs.pl
|
|
$(RUNPERL) $(srcdir)\x86\regs.pl dc \
|
|
$(srcdir)\x86\regs.dat > x86\regdis.c
|
|
x86\regdis.h: x86\regs.dat x86\regs.pl
|
|
$(RUNPERL) $(srcdir)\x86\regs.pl dh \
|
|
$(srcdir)\x86\regs.dat > x86\regdis.h
|
|
x86\regvals.c: x86\regs.dat x86\regs.pl
|
|
$(RUNPERL) $(srcdir)\x86\regs.pl vc \
|
|
$(srcdir)\x86\regs.dat > x86\regvals.c
|
|
x86\regs.h: x86\regs.dat x86\regs.pl
|
|
$(RUNPERL) $(srcdir)\x86\regs.pl h \
|
|
$(srcdir)\x86\regs.dat > x86\regs.h
|
|
|
|
# Assembler token hash
|
|
asm\tokhash.c: x86\insns.dat x86\regs.dat asm\tokens.dat asm\tokhash.pl \
|
|
perllib\phash.ph
|
|
$(RUNPERL) $(srcdir)\asm\tokhash.pl c \
|
|
$(srcdir)\x86\insns.dat $(srcdir)\x86\regs.dat \
|
|
$(srcdir)\asm\tokens.dat > asm\tokhash.c
|
|
|
|
# Assembler token metadata
|
|
asm\tokens.h: x86\insns.dat x86\regs.dat asm\tokens.dat asm\tokhash.pl \
|
|
perllib\phash.ph
|
|
$(RUNPERL) $(srcdir)\asm\tokhash.pl h \
|
|
$(srcdir)\x86\insns.dat $(srcdir)\x86\regs.dat \
|
|
$(srcdir)\asm\tokens.dat > asm\tokens.h
|
|
|
|
# Preprocessor token hash
|
|
asm\pptok.h: asm\pptok.dat asm\pptok.pl perllib\phash.ph
|
|
$(RUNPERL) $(srcdir)\asm\pptok.pl h \
|
|
$(srcdir)\asm\pptok.dat asm\pptok.h
|
|
asm\pptok.c: asm\pptok.dat asm\pptok.pl perllib\phash.ph
|
|
$(RUNPERL) $(srcdir)\asm\pptok.pl c \
|
|
$(srcdir)\asm\pptok.dat asm\pptok.c
|
|
asm\pptok.ph: asm\pptok.dat asm\pptok.pl perllib\phash.ph
|
|
$(RUNPERL) $(srcdir)\asm\pptok.pl ph \
|
|
$(srcdir)\asm\pptok.dat asm\pptok.ph
|
|
|
|
# Directives hash
|
|
asm\directiv.h: asm\directiv.dat nasmlib\perfhash.pl perllib\phash.ph
|
|
$(RUNPERL) $(srcdir)\nasmlib\perfhash.pl h \
|
|
$(srcdir)\asm\directiv.dat asm\directiv.h
|
|
asm\directbl.c: asm\directiv.dat nasmlib\perfhash.pl perllib\phash.ph
|
|
$(RUNPERL) $(srcdir)\nasmlib\perfhash.pl c \
|
|
$(srcdir)\asm\directiv.dat asm\directbl.c
|
|
|
|
#-- End Generated File Rules --#
|
|
|
|
perlreq: $(PERLREQ)
|
|
|
|
# This rule is only used for RDOFF
|
|
.obj.exe:
|
|
$(CC) /Fe$@ $< $(LDFLAGS) $(RDFLIB) $(NASMLIB) $(LIBS)
|
|
|
|
RDFLN = copy
|
|
RDFLNPFX = rdoff^\
|
|
|
|
#-- Begin RDOFF Shared Rules --#
|
|
# Edit in Makefile.in, not here!
|
|
|
|
RDFLIBOBJ = rdoff\rdoff.$(O) rdoff\rdfload.$(O) rdoff\symtab.$(O) \
|
|
rdoff\collectn.$(O) rdoff\rdlib.$(O) rdoff\segtab.$(O) \
|
|
rdoff\hash.$(O)
|
|
|
|
RDFPROGS = rdoff\rdfdump$(X) rdoff\ldrdf$(X) rdoff\rdx$(X) rdoff\rdflib$(X) \
|
|
rdoff\rdf2bin$(X)
|
|
RDF2BINLINKS = rdoff\rdf2com$(X) rdoff\rdf2ith$(X) \
|
|
rdoff\rdf2ihx$(X) rdoff\rdf2srec$(X)
|
|
|
|
RDFLIB = rdoff\librdoff.$(A)
|
|
RDFLIBS = $(RDFLIB) $(NASMLIB)
|
|
|
|
rdoff\rdfdump$(X): rdoff\rdfdump.$(O) $(RDFLIBS)
|
|
rdoff\ldrdf$(X): rdoff\ldrdf.$(O) $(RDFLIBS)
|
|
rdoff\rdx$(X): rdoff\rdx.$(O) $(RDFLIBS)
|
|
rdoff\rdflib$(X): rdoff\rdflib.$(O) $(RDFLIBS)
|
|
rdoff\rdf2bin$(X): rdoff\rdf2bin.$(O) $(RDFLIBS)
|
|
rdoff\rdf2com$(X): rdoff\rdf2bin$(X)
|
|
$(RM_F) rdoff\rdf2com$(X)
|
|
$(RDFLN) $(RDFLNPFX)rdf2bin$(X) $(RDFLNPFX)rdf2com$(X)
|
|
rdoff\rdf2ith$(X): rdoff\rdf2bin$(X)
|
|
$(RM_F) rdoff\rdf2ith$(X)
|
|
$(RDFLN) $(RDFLNPFX)rdf2bin$(X) $(RDFLNPFX)rdf2ith$(X)
|
|
rdoff\rdf2ihx$(X): rdoff\rdf2bin$(X)
|
|
$(RM_F) rdoff\rdf2ihx$(X)
|
|
$(RDFLN) $(RDFLNPFX)rdf2bin$(X) $(RDFLNPFX)rdf2ihx$(X)
|
|
rdoff\rdf2srec$(X): rdoff\rdf2bin$(X)
|
|
$(RM_F) rdoff\rdf2srec$(X)
|
|
$(RDFLN) $(RDFLNPFX)rdf2bin$(X) $(RDFLNPFX)rdf2srec$(X)
|
|
|
|
#-- End RDOFF Shared Rules --#
|
|
|
|
rdf: $(RDFPROGS) $(RDF2BINLINKS)
|
|
|
|
$(RDFLIB): $(RDFLIBOBJ)
|
|
$(AR) $(ARFLAGS) /OUT:$@ $**
|
|
|
|
#-- Begin NSIS Rules --#
|
|
# Edit in Makefile.in, not here!
|
|
|
|
# NSIS is not built except by explicit request, as it only applies to
|
|
# Windows platforms
|
|
nsis\arch.nsh: nsis\getpearch.pl nasm$(X)
|
|
$(PERL) $(srcdir)\nsis\getpearch.pl nasm$(X) > nsis\arch.nsh
|
|
|
|
# Should only be done after "make everything".
|
|
# The use of redirection here keeps makensis from moving the cwd to the
|
|
# source directory.
|
|
nsis: nsis\nasm.nsi nsis\arch.nsh nsis\version.nsh
|
|
$(MAKENSIS) -Dsrcdir="$(srcdir)" -Dobjdir="$(objdir)" - < nsis\nasm.nsi
|
|
|
|
#-- End NSIS Rules --#
|
|
|
|
clean:
|
|
-del /f /s *.$(O)
|
|
-del /f /s *.pdb
|
|
-del /f /s *.s
|
|
-del /f /s *.i
|
|
-del /f $(NASMLIB) $(RDFLIB)
|
|
-del /f nasm$(X)
|
|
-del /f ndisasm$(X)
|
|
-del /f rdoff\*$(X)
|
|
|
|
distclean: clean
|
|
-del /f config.h
|
|
-del /f config.log
|
|
-del /f config.status
|
|
-del /f Makefile
|
|
-del /f /s *~
|
|
-del /f /s *.bak
|
|
-del /f /s *.lst
|
|
-del /f /s *.bin
|
|
-del /f /s *.dep
|
|
-del /f output\*~
|
|
-del /f output\*.bak
|
|
-del /f test\*.lst
|
|
-del /f test\*.bin
|
|
-del /f test\*.$(O)
|
|
-del /f test\*.bin
|
|
-del /f/s autom4te*.cache
|
|
rem cd rdoff && $(MAKE) distclean
|
|
|
|
cleaner: clean
|
|
-del /f $(PERLREQ)
|
|
-del /f *.man
|
|
-del /f nasm.spec
|
|
rem cd doc && $(MAKE) clean
|
|
|
|
spotless: distclean cleaner
|
|
-del /f doc\Makefile
|
|
-del doc\*~
|
|
-del doc\*.bak
|
|
|
|
strip:
|
|
|
|
# Abuse doc/Makefile.in to build nasmdoc.pdf only
|
|
docs:
|
|
cd doc && $(MAKE) /f Makefile.in srcdir=. top_srcdir=.. \
|
|
PERL=$(PERL) PDFOPT= nasmdoc.pdf
|
|
|
|
everything: all docs nsis
|
|
|
|
#
|
|
# Does this version of this file have external dependencies? This definition
|
|
# will be automatically updated by mkdep.pl as needed.
|
|
#
|
|
EXTERNAL_DEPENDENCIES = 1
|
|
|
|
#
|
|
# Generate dependency information for this Makefile only.
|
|
# If this Makefile has external dependency information, then
|
|
# the dependency information will remain external, so it doesn't
|
|
# pollute the git logs.
|
|
#
|
|
msvc.dep: $(PERLREQ) tools\mkdep.pl
|
|
$(RUNPERL) tools\mkdep.pl -M Mkfiles\msvc.mak -- $(DEPDIRS)
|
|
|
|
dep: msvc.dep
|
|
|
|
# Include and/or generate msvc.dep as needed. This is too complex to
|
|
# use the include-command feature, but we can open-code it here.
|
|
MKDEP=0
|
|
!IF $(EXTERNAL_DEPENDENCIES) == 1 && $(MKDEP) == 0
|
|
!IF EXISTS(msvc.dep)
|
|
!INCLUDE msvc.dep
|
|
!ELSEIF [$(MAKE) /c MKDEP=1 /f Mkfiles\msvc.mak msvc.dep] == 0
|
|
!INCLUDE msvc.dep
|
|
!ELSE
|
|
!ERROR Unable to rebuild dependencies file msvc.dep
|
|
!ENDIF
|
|
!ENDIF
|
|
|
|
#-- Magic hints to mkdep.pl --#
|
|
# @object-ending: ".$(O)"
|
|
# @path-separator: "\"
|
|
# @exclude: "config\config.h"
|
|
# @external: "msvc.dep"
|
|
# @selfrule: "1"
|
|
#-- Everything below is generated by mkdep.pl - do not edit --#
|