| # -*- makefile -*- |
| # |
| # Makefile for building NASM using OpenWatcom |
| # cross-compile on a DOS/Win32/OS2 platform host |
| # |
| |
| top_srcdir = . |
| srcdir = . |
| VPATH = $(srcdir)\asm;$(srcdir)\x86;asm;x86;$(srcdir)\macros;macros;$(srcdir)\output;$(srcdir)\lib;$(srcdir)\common;$(srcdir)\stdlib;$(srcdir)\nasmlib;$(srcdir)\disasm |
| prefix = C:\Program Files\NASM |
| exec_prefix = $(prefix) |
| bindir = $(prefix)\bin |
| mandir = $(prefix)\man |
| |
| CC = *wcl386 |
| DEBUG = |
| CFLAGS = -zq -6 -ox -wx -wcd=124 -ze -fpi $(DEBUG) |
| BUILD_CFLAGS = $(CFLAGS) $(%TARGET_CFLAGS) |
| INTERNAL_CFLAGS = -I$(srcdir) -I. -I$(srcdir)\include -I$(srcdir)\x86 -Ix86 -I$(srcdir)\asm -Iasm -I$(srcdir)\disasm -I$(srcdir)\output |
| ALL_CFLAGS = $(BUILD_CFLAGS) $(INTERNAL_CFLAGS) |
| LD = *wlink |
| LDEBUG = |
| LDFLAGS = op q $(%TARGET_LFLAGS) $(LDEBUG) |
| LIBS = |
| STRIP = wstrip |
| |
| PERL = perl |
| PERLFLAGS = -I$(srcdir)\perllib -I$(srcdir) |
| RUNPERL = $(PERL) $(PERLFLAGS) |
| |
| EMPTY = $(RUNPERL) -e "" |
| |
| MAKENSIS = makensis |
| |
| # Binary suffixes |
| O = obj |
| X = .exe |
| |
| # WMAKE errors out if a suffix is declared more than once, including |
| # its own built-in declarations. Thus, we need to explicitly clear the list |
| # first. Also, WMAKE only allows implicit rules that point "to the left" |
| # in this list! |
| .SUFFIXES: |
| .SUFFIXES: .man .1 .obj .i .c |
| |
| # Needed to find C files anywhere but in the current directory |
| .c : $(VPATH) |
| |
| .c.obj: |
| @set INCLUDE= |
| $(CC) -c $(ALL_CFLAGS) -fo=$^@ $[@ |
| |
| MANIFEST = |
| |
| #-- Begin File Lists --# |
| # Edit in Makefile.in, not here! |
| NASM = asm\nasm.obj |
| NDISASM = disasm\ndisasm.obj |
| |
| PROGOBJ = $(NASM) $(NDISASM) |
| PROGS = nasm$(X) ndisasm$(X) |
| |
| LIBOBJ_NW = stdlib\snprintf.obj stdlib\vsnprintf.obj stdlib\strlcpy.obj & |
| stdlib\strnlen.obj stdlib\strrchrnul.obj & |
| & |
| nasmlib\ver.obj & |
| nasmlib\alloc.obj nasmlib\asprintf.obj nasmlib\errfile.obj & |
| nasmlib\crc32.obj nasmlib\crc64.obj nasmlib\md5c.obj & |
| nasmlib\string.obj nasmlib\nctype.obj & |
| nasmlib\file.obj nasmlib\mmap.obj nasmlib\ilog2.obj & |
| nasmlib\realpath.obj nasmlib\path.obj & |
| nasmlib\filename.obj nasmlib\rlimit.obj & |
| nasmlib\readnum.obj nasmlib\numstr.obj & |
| nasmlib\zerobuf.obj nasmlib\bsi.obj & |
| nasmlib\rbtree.obj nasmlib\hashtbl.obj & |
| nasmlib\raa.obj nasmlib\saa.obj & |
| nasmlib\strlist.obj & |
| nasmlib\perfhash.obj nasmlib\badenum.obj & |
| & |
| common\common.obj & |
| & |
| x86\insnsa.obj x86\insnsb.obj x86\insnsd.obj x86\insnsn.obj & |
| x86\regs.obj x86\regvals.obj x86\regflags.obj x86\regdis.obj & |
| x86\disp8.obj x86\iflag.obj & |
| & |
| asm\error.obj & |
| asm\floats.obj & |
| asm\directiv.obj asm\directbl.obj & |
| asm\pragma.obj & |
| asm\assemble.obj asm\labels.obj asm\parser.obj & |
| asm\preproc.obj asm\quote.obj asm\pptok.obj & |
| asm\listing.obj asm\eval.obj asm\exprlib.obj asm\exprdump.obj & |
| asm\stdscan.obj & |
| asm\strfunc.obj asm\tokhash.obj & |
| asm\segalloc.obj & |
| asm\rdstrnum.obj & |
| asm\srcfile.obj & |
| macros\macros.obj & |
| & |
| output\outform.obj output\outlib.obj output\legacy.obj & |
| output\nulldbg.obj output\nullout.obj & |
| output\outbin.obj output\outaout.obj output\outcoff.obj & |
| output\outelf.obj & |
| output\outobj.obj output\outas86.obj & |
| output\outdbg.obj output\outieee.obj output\outmacho.obj & |
| output\codeview.obj & |
| & |
| disasm\disasm.obj disasm\sync.obj |
| |
| # Warnings depend on all source files, so handle them separately |
| WARNOBJ = asm\warnings.obj |
| WARNFILES = asm\warnings_c.h include\warnings.h doc\warnings.src |
| |
| LIBOBJ = $(LIBOBJ_NW) $(WARNOBJ) |
| ALLOBJ_NW = $(PROGOBJ) $(LIBOBJ_NW) |
| ALLOBJ = $(PROGOBJ) $(LIBOBJ) |
| |
| SUBDIRS = stdlib nasmlib output asm disasm x86 common macros win |
| XSUBDIRS = test doc nsis |
| DEPDIRS = . include config x86 $(SUBDIRS) |
| #-- End File Lists --# |
| |
| what: .SYMBOLIC |
| @echo Please build "dos", "win32", "os2" or "linux386" |
| |
| dos: .SYMBOLIC |
| @set TARGET_CFLAGS=-bt=DOS -I"$(%WATCOM)\h" |
| @set TARGET_LFLAGS=sys causeway |
| @%make all |
| |
| win32: .SYMBOLIC |
| @set TARGET_CFLAGS=-bt=NT -I"$(%WATCOM)\h" -I"$(%WATCOM)\h\nt" |
| @set TARGET_LFLAGS=sys nt |
| @%make all |
| |
| os2: .SYMBOLIC |
| @set TARGET_CFLAGS=-bt=OS2 -I"$(%WATCOM)\h" -I"$(%WATCOM)\h\os2" |
| @set TARGET_LFLAGS=sys os2v2 |
| @%make all |
| |
| linux386: .SYMBOLIC |
| @set TARGET_CFLAGS=-bt=LINUX -I"$(%WATCOM)\lh" |
| @set TARGET_LFLAGS=sys linux |
| @%make all |
| |
| all: perlreq nasm$(X) ndisasm$(X) .SYMBOLIC |
| # cd rdoff && $(MAKE) all |
| |
| NASMLIB = nasm.lib |
| |
| nasm$(X): $(NASM) $(NASMLIB) |
| $(LD) $(LDFLAGS) name nasm$(X) libr {$(NASMLIB) $(LIBS)} file {$(NASM)} |
| |
| ndisasm$(X): $(NDISASM) $(LIBOBJ) |
| $(LD) $(LDFLAGS) name ndisasm$(X) libr {$(NASMLIB) $(LIBS)} file {$(NDISASM)} |
| |
| nasm.lib: $(LIBOBJ) |
| wlib -q -b -n $@ $(LIBOBJ) |
| |
| # These are specific to certain Makefile syntaxes (what are they |
| # actually supposed to look like for wmake?) |
| WARNTIMES = $(WARNFILES:=.time) |
| WARNSRCS = $(LIBOBJ_NW:.obj=.c) |
| |
| #-- 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 = config\unconfig.h & |
| 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 & |
| $(WARNFILES) & |
| misc\nasmtok.el & |
| version.h version.mac version.mak nsis\version.nsh |
| |
| INSDEP = x86\insns.dat x86\insns.pl x86\insns-iflags.ph x86\iflags.ph |
| |
| config\unconfig.h: config\config.h.in |
| $(RUNPERL) $(tools)\unconfig.pl & |
| '$(srcdir)' config\config.h.in config\unconfig.h |
| |
| 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 |
| |
| # Extract warnings from source code. This is done automatically if any |
| # C files have changed; the script is fast enough that that is |
| # reasonable, but doesn't update the time stamp if the files aren't |
| # changed, to avoid rebuilding everything every time. Track the actual |
| # dependency by the empty file asm\warnings.time. |
| warnings: |
| $(RM_F) $(WARNFILES) $(WARNTIMES) |
| $(MAKE) asm\warnings.time |
| |
| asm\warnings.time: $(ALLOBJ_NW:.$(O)=.c) |
| $(EMPTY) asm\warnings.time |
| $(MAKE) $(WARNTIMES) |
| |
| asm\warnings_c.h.time: asm\warnings.pl asm\warnings.time |
| $(RUNPERL) $(srcdir)\asm\warnings.pl c asm\warnings_c.h $(srcdir) |
| $(EMPTY) asm\warnings_c.h.time |
| |
| asm\warnings_c.h: asm\warnings_c.h.time |
| @: Side effect |
| |
| include\warnings.h.time: asm\warnings.pl asm\warnings.time |
| $(RUNPERL) $(srcdir)\asm\warnings.pl h include\warnings.h $(srcdir) |
| $(EMPTY) include\warnings.h.time |
| |
| include\warnings.h: include\warnings.h.time |
| @: Side effect |
| |
| doc\warnings.src.time: asm\warnings.pl asm\warnings.time |
| $(RUNPERL) $(srcdir)\asm\warnings.pl doc doc\warnings.src $(srcdir) |
| $(EMPTY) doc\warnings.src.time |
| |
| doc\warnings.src : doc\warnings.src.time |
| @: Side effect |
| |
| # Assembler token hash |
| asm\tokhash.c: x86\insns.dat x86\insnsn.c asm\tokens.dat asm\tokhash.pl & |
| perllib\phash.ph |
| $(RUNPERL) $(srcdir)\asm\tokhash.pl c & |
| x86\insnsn.c $(srcdir)\x86\regs.dat & |
| $(srcdir)\asm\tokens.dat > asm\tokhash.c |
| |
| # Assembler token metadata |
| asm\tokens.h: x86\insns.dat x86\insnsn.c asm\tokens.dat asm\tokhash.pl & |
| perllib\phash.ph |
| $(RUNPERL) $(srcdir)\asm\tokhash.pl h & |
| x86\insnsn.c $(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 |
| |
| # Emacs token files |
| misc\nasmtok.el: misc\emacstbl.pl asm\tokhash.c asm\pptok.c & |
| asm\directiv.dat version |
| $(RUNPERL) $< $@ "$(srcdir)" "$(objdir)" |
| |
| #-- End Generated File Rules --# |
| |
| perlreq: $(PERLREQ) .SYMBOLIC |
| |
| #-- Begin NSIS Rules --# |
| # Edit in Makefile.in, not here! |
| |
| 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: .SYMBOLIC |
| rm -f *.obj *.s *.i |
| rm -f asm\*.obj asm\*.s asm\*.i |
| rm -f x86\*.obj x86\*.s x86\*.i |
| rm -f lib\*.obj lib\*.s lib\*.i |
| rm -f macros\*.obj macros\*.s macros\*.i |
| rm -f output\*.obj output\*.s output\*.i |
| rm -f common\*.obj common\*.s common\*.i |
| rm -f stdlib\*.obj stdlib\*.s stdlib\*.i |
| rm -f nasmlib\*.obj nasmlib\*.s nasmlib\*.i |
| rm -f disasm\*.obj disasm\*.s disasm\*.i |
| rm -f config.h config.log config.status |
| rm -f nasm$(X) ndisasm$(X) $(NASMLIB) |
| |
| distclean: clean .SYMBOLIC |
| rm -f config.h config.log config.status |
| rm -f Makefile *~ *.bak *.lst *.bin |
| rm -f output\*~ output\*.bak |
| rm -f test\*.lst test\*.bin test\*.obj test\*.bin |
| |
| cleaner: clean .SYMBOLIC |
| rm -f $(PERLREQ) |
| rm -f *.man |
| rm -f nasm.spec |
| # cd doc && $(MAKE) clean |
| |
| spotless: distclean cleaner .SYMBOLIC |
| rm -f doc\Makefile doc\*~ doc\*.bak |
| |
| strip: .SYMBOLIC |
| $(STRIP) *.exe |
| |
| doc: |
| # cd doc && $(MAKE) all |
| |
| everything: all doc |
| |
| # |
| # This build dependencies in *ALL* makefiles. Partially for that reason, |
| # it's expected to be invoked manually. |
| # |
| alldeps: perlreq .SYMBOLIC |
| $(PERL) syncfiles.pl Makefile.in Mkfiles\openwcom.mak |
| $(PERL) mkdep.pl -M Makefile.in Mkfiles\openwcom.mak -- . output lib |
| |
| #-- Magic hints to mkdep.pl --# |
| # @object-ending: ".obj" |
| # @path-separator: "\" |
| # @exclude: "config/config.h" |
| # @continuation: "&" |
| #-- Everything below is generated by mkdep.pl - do not edit --# |