-
Notifications
You must be signed in to change notification settings - Fork 0
/
IntelC64.mak
124 lines (99 loc) · 3.62 KB
/
IntelC64.mak
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
# this makefile (NMake) creates the JWasm Win64 binary with the Intel C++
# compiler. It has been tested with:
# - Intel C++ on IA-32, v11.1
# the Intel compiler needs external includes and libraries, compatible with
# MS Visual C. MS VC 2008 has been used here.
# directory paths to adjust:
# CDIR - root directory of the Intel C compiler
# VCDIR - root directory for Visual C includes and libraries
# W64LIB - directory for Win64 import library files (kernel32.lib).
# Default is WinInc ( may be changed to the MS Platform SDK ).
name = jwasm
CDIR = g:\intelcpp
VCDIR = \msvc9
W64LIB = \WinInc\Lib64
# use the MS linker or jwlink (jwlink is experimental!)
!ifndef MSLINK
MSLINK=1
!endif
!ifndef DEBUG
DEBUG=0
!endif
!ifndef OUTD
!if $(DEBUG)
OUTD=IC64D
!else
OUTD=IC64R
!endif
!endif
inc_dirs = -IH -I"$(CDIR)\include" -I"$(VCDIR)\include"
TRMEM=0
linker = $(CDIR)\bin64\xilink.exe
lib = $(CDIR)\bin64\xilib.exe
!if $(DEBUG)
!if $(TRMEM)
extra_c_flags = -Zd -Od -DDEBUG_OUT -DTRMEM
!else
extra_c_flags = -Zd -Od -DDEBUG_OUT
!endif
!else
extra_c_flags = -O2 -Gs -DNDEBUG
#extra_c_flags = -Ox -DNDEBUG
!endif
c_flags =-D_WIN64 $(extra_c_flags) $(c_flags64)
#lflags stuff
#########
LOPT = /NOLOGO
!if $(DEBUG)
#LOPTD = /debug
!endif
lflagsw = $(LOPTD) /SUBSYSTEM:CONSOLE $(LOPT) /map:$^*.map
CC=$(CDIR)\bin64\icl.exe -c -nologo $(inc_dirs) $(c_flags)
.c{$(OUTD)}.obj:
@$(CC) -Fo$* $<
proj_obj = $(OUTD)/main.obj $(OUTD)/assemble.obj $(OUTD)/assume.obj \
$(OUTD)/directiv.obj $(OUTD)/posndir.obj $(OUTD)/segment.obj \
$(OUTD)/expreval.obj $(OUTD)/memalloc.obj $(OUTD)/errmsg.obj \
$(OUTD)/macro.obj $(OUTD)/string.obj $(OUTD)/condasm.obj \
$(OUTD)/types.obj $(OUTD)/fpfixup.obj $(OUTD)/invoke.obj \
$(OUTD)/equate.obj $(OUTD)/mangle.obj $(OUTD)/loop.obj \
$(OUTD)/parser.obj $(OUTD)/tokenize.obj $(OUTD)/input.obj \
$(OUTD)/expans.obj $(OUTD)/symbols.obj $(OUTD)/labels.obj \
$(OUTD)/fixup.obj $(OUTD)/codegen.obj $(OUTD)/data.obj \
$(OUTD)/reswords.obj $(OUTD)/branch.obj $(OUTD)/queue.obj \
$(OUTD)/hll.obj $(OUTD)/proc.obj $(OUTD)/option.obj \
$(OUTD)/omf.obj $(OUTD)/omfint.obj $(OUTD)/omffixup.obj\
$(OUTD)/coff.obj $(OUTD)/elf.obj $(OUTD)/bin.obj \
$(OUTD)/listing.obj $(OUTD)/safeseh.obj \
$(OUTD)/context.obj $(OUTD)/extern.obj $(OUTD)/simsegm.obj \
$(OUTD)/cmdline.obj $(OUTD)/linnum.obj $(OUTD)/fastpass.obj\
!if $(TRMEM)
$(OUTD)/trmem.obj \
!endif
$(OUTD)/backptch.obj $(OUTD)/msgtext.obj $(OUTD)/tbyte.obj \
$(OUTD)/dbgcv.obj $(OUTD)/end.obj $(OUTD)/cpumodel.obj
######
TARGET1=$(OUTD)\$(name).exe
ALL: $(OUTD) $(TARGET1)
$(OUTD):
@mkdir $(OUTD)
$(OUTD)\$(name).exe : $(OUTD)/main.obj $(OUTD)/$(name).lib
!if $(MSLINK)
@$(linker) @<<
$(lflagsw) $(OUTD)/main.obj $(OUTD)/$(name).lib
/LIBPATH:"$(CDIR)\Lib\Intel64" /LIBPATH:"$(VCDIR)\Lib64" /LIBPATH:"$(W64LIB)" /OUT:$@
<<
!else
@jwlink format windows pe file $(OUTD)/main.obj name $@ lib $(OUTD)/$(name).lib libpath "$(CDIR)\Lib\Ia32" libpath "$(VCDIR)\Lib64" libpath "$(W64LIB)" op start=_mainCRTStartup, norelocs, eliminate, map=$(OUTD)/$(name).map
!endif
$(OUTD)\$(name).lib : $(proj_obj)
@$(lib) /nologo /out:$(OUTD)\$(name).lib $(proj_obj)
$(OUTD)/msgtext.obj: msgtext.c H/msgdef.h H/usage.h H/globals.h
@$(CC) -Fo$* msgtext.c
$(OUTD)/reswords.obj: reswords.c H/instruct.h H/special.h H/directve.h
@$(CC) -Fo$* reswords.c
######
clean:
@erase $(OUTD)\*.exe
@erase $(OUTD)\*.obj
@erase $(OUTD)\*.map