Makefile.target 10.7 KB
Newer Older
B
bellard 已提交
1 2
include config.mak

B
bellard 已提交
3 4 5 6
TARGET_BASE_ARCH:=$(TARGET_ARCH)
ifeq ($(TARGET_ARCH), x86_64)
TARGET_BASE_ARCH:=i386
endif
B
bellard 已提交
7 8 9
ifeq ($(TARGET_ARCH), ppc64)
TARGET_BASE_ARCH:=ppc
endif
B
bellard 已提交
10 11 12
ifeq ($(TARGET_ARCH), sparc64)
TARGET_BASE_ARCH:=sparc
endif
B
bellard 已提交
13
TARGET_PATH=$(SRC_PATH)/target-$(TARGET_BASE_ARCH)
B
bellard 已提交
14
VPATH=$(SRC_PATH):$(TARGET_PATH):$(SRC_PATH)/hw:$(SRC_PATH)/audio
B
bellard 已提交
15 16 17 18 19
DEFINES=-I. -I$(TARGET_PATH) -I$(SRC_PATH)
ifdef CONFIG_USER_ONLY
VPATH+=:$(SRC_PATH)/linux-user
DEFINES+=-I$(SRC_PATH)/linux-user -I$(SRC_PATH)/linux-user/$(TARGET_ARCH)
endif
B
bellard 已提交
20
CFLAGS=-Wall -O2 -g -fno-strict-aliasing
B
bellard 已提交
21
#CFLAGS+=-Werror
B
bellard 已提交
22 23 24
LDFLAGS=-g
LIBS=
HELPER_CFLAGS=$(CFLAGS)
B
bellard 已提交
25
DYNGEN=../dyngen$(EXESUF)
26
# user emulator name
27 28 29 30 31 32 33 34 35
ifeq ($(TARGET_ARCH),arm)
  ifeq ($(TARGET_WORDS_BIGENDIAN),yes)
    QEMU_USER=qemu-armeb
  else
    QEMU_USER=qemu-arm
  endif
else
  QEMU_USER=qemu-$(TARGET_ARCH)
endif
36 37
# system emulator name
ifdef CONFIG_SOFTMMU
38
ifeq ($(TARGET_ARCH), i386)
B
bellard 已提交
39
QEMU_SYSTEM=qemu$(EXESUF)
40
else
41 42 43
QEMU_SYSTEM=qemu-system-$(TARGET_ARCH)$(EXESUF)
endif
else
44
QEMU_SYSTEM=qemu-fast
45 46
endif

B
bellard 已提交
47
ifdef CONFIG_USER_ONLY
48
PROGS=$(QEMU_USER)
B
bellard 已提交
49
else
50
PROGS+=$(QEMU_SYSTEM)
B
bellard 已提交
51 52 53
ifndef CONFIG_SOFTMMU
CONFIG_STATIC=y
endif
B
update  
bellard 已提交
54
endif # !CONFIG_USER_ONLY
B
bellard 已提交
55 56 57 58 59 60 61 62 63

ifdef CONFIG_STATIC
LDFLAGS+=-static
endif

ifeq ($(ARCH),i386)
CFLAGS+=-fomit-frame-pointer
OP_CFLAGS=$(CFLAGS) -mpreferred-stack-boundary=2
ifeq ($(HAVE_GCC3_OPTIONS),yes)
64
OP_CFLAGS+= -falign-functions=0 -fno-gcse
B
bellard 已提交
65 66 67
else
OP_CFLAGS+= -malign-functions=0
endif
B
bellard 已提交
68

B
bellard 已提交
69
ifdef TARGET_GPROF
B
bellard 已提交
70 71 72 73 74 75
USE_I386_LD=y
endif
ifdef CONFIG_STATIC
USE_I386_LD=y
endif
ifdef USE_I386_LD
B
bellard 已提交
76 77 78 79 80 81 82 83 84
LDFLAGS+=-Wl,-T,$(SRC_PATH)/i386.ld
else
# WARNING: this LDFLAGS is _very_ tricky : qemu is an ELF shared object
# that the kernel ELF loader considers as an executable. I think this
# is the simplest way to make it self virtualizable!
LDFLAGS+=-Wl,-shared
endif
endif

B
bellard 已提交
85
ifeq ($(ARCH),x86_64)
86
OP_CFLAGS=$(CFLAGS) -falign-functions=0
B
bellard 已提交
87
LDFLAGS+=-Wl,-T,$(SRC_PATH)/x86_64.ld
88 89
endif

B
bellard 已提交
90
ifeq ($(ARCH),ppc)
91
CFLAGS+= -D__powerpc__
B
bellard 已提交
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 125
OP_CFLAGS=$(CFLAGS)
LDFLAGS+=-Wl,-T,$(SRC_PATH)/ppc.ld
endif

ifeq ($(ARCH),s390)
OP_CFLAGS=$(CFLAGS)
LDFLAGS+=-Wl,-T,$(SRC_PATH)/s390.ld
endif

ifeq ($(ARCH),sparc)
CFLAGS+=-m32 -ffixed-g1 -ffixed-g2 -ffixed-g3 -ffixed-g6
LDFLAGS+=-m32
OP_CFLAGS=$(CFLAGS) -fno-delayed-branch -ffixed-i0
HELPER_CFLAGS=$(CFLAGS) -ffixed-i0 -mflat
# -static is used to avoid g1/g3 usage by the dynamic linker
LDFLAGS+=-Wl,-T,$(SRC_PATH)/sparc.ld -static
endif

ifeq ($(ARCH),sparc64)
CFLAGS+=-m64 -ffixed-g1 -ffixed-g2 -ffixed-g3 -ffixed-g6
LDFLAGS+=-m64
OP_CFLAGS=$(CFLAGS) -fno-delayed-branch -ffixed-i0
endif

ifeq ($(ARCH),alpha)
# -msmall-data is not used because we want two-instruction relocations
# for the constant constructions
OP_CFLAGS=-Wall -O2 -g
# Ensure there's only a single GP
CFLAGS += -msmall-data
LDFLAGS+=-Wl,-T,$(SRC_PATH)/alpha.ld
endif

ifeq ($(ARCH),ia64)
B
bellard 已提交
126
CFLAGS += -mno-sdata
B
bellard 已提交
127
OP_CFLAGS=$(CFLAGS)
B
bellard 已提交
128
LDFLAGS+=-Wl,-G0 -Wl,-T,$(SRC_PATH)/ia64.ld
B
bellard 已提交
129 130 131
endif

ifeq ($(ARCH),arm)
B
bellard 已提交
132
OP_CFLAGS=$(CFLAGS) -mno-sched-prolog -fno-omit-frame-pointer
B
bellard 已提交
133 134 135
LDFLAGS+=-Wl,-T,$(SRC_PATH)/arm.ld
endif

B
bellard 已提交
136 137 138 139 140
ifeq ($(ARCH),m68k)
OP_CFLAGS=$(CFLAGS) -fomit-frame-pointer
LDFLAGS+=-Wl,-T,m68k.ld
endif

B
bellard 已提交
141 142 143 144 145
ifeq ($(HAVE_GCC3_OPTIONS),yes)
# very important to generate a return at the end of every operation
OP_CFLAGS+=-fno-reorder-blocks -fno-optimize-sibling-calls
endif

146 147
ifeq ($(CONFIG_DARWIN),yes)
OP_CFLAGS+= -mdynamic-no-pic
B
bellard 已提交
148
LIBS+=-lmx
149 150
endif

B
bellard 已提交
151 152
#########################################################

B
bellard 已提交
153
DEFINES+=-D_GNU_SOURCE -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE
B
bellard 已提交
154
LIBS+=-lm
B
bellard 已提交
155 156 157
ifndef CONFIG_USER_ONLY
LIBS+=-lz
endif
B
bellard 已提交
158
ifdef CONFIG_WIN32
159
LIBS+=-lwinmm -lws2_32 -liphlpapi
B
bellard 已提交
160
endif
B
bellard 已提交
161 162 163 164 165 166 167

# profiling code
ifdef TARGET_GPROF
LDFLAGS+=-p
main.o: CFLAGS+=-p
endif

B
bellard 已提交
168
OBJS= elfload.o main.o syscall.o mmap.o signal.o path.o osdep.o thunk.o 
B
bellard 已提交
169 170 171
ifeq ($(TARGET_ARCH), i386)
OBJS+= vm86.o
endif
B
bellard 已提交
172
ifeq ($(TARGET_ARCH), arm)
B
bellard 已提交
173
OBJS+=nwfpe/fpa11.o nwfpe/fpa11_cpdo.o \
B
bellard 已提交
174
nwfpe/fpa11_cpdt.o nwfpe/fpa11_cprt.o nwfpe/fpopcode.o nwfpe/single_cpdo.o \
175
 nwfpe/double_cpdo.o nwfpe/extended_cpdo.o arm-semi.o
B
bellard 已提交
176
endif
B
bellard 已提交
177 178 179 180
SRCS:= $(OBJS:.o=.c)
OBJS+= libqemu.a

# cpu emulator library
B
bellard 已提交
181
LIBOBJS=exec.o kqemu.o translate-op.o translate-all.o cpu-exec.o\
B
bellard 已提交
182
        translate.o op.o 
B
bellard 已提交
183 184 185 186 187 188
ifdef CONFIG_SOFTFLOAT
LIBOBJS+=fpu/softfloat.o
else
LIBOBJS+=fpu/softfloat-native.o
endif
DEFINES+=-I$(SRC_PATH)/fpu
B
bellard 已提交
189 190

ifeq ($(TARGET_ARCH), i386)
191
LIBOBJS+=helper.o helper2.o
B
bellard 已提交
192 193 194
ifeq ($(ARCH), i386)
LIBOBJS+=translate-copy.o
endif
B
bellard 已提交
195 196
endif

B
bellard 已提交
197 198 199 200
ifeq ($(TARGET_ARCH), x86_64)
LIBOBJS+=helper.o helper2.o
endif

B
bellard 已提交
201
ifeq ($(TARGET_BASE_ARCH), ppc)
B
update  
bellard 已提交
202
LIBOBJS+= op_helper.o helper.o
203 204
endif

B
bellard 已提交
205 206 207 208
ifeq ($(TARGET_ARCH), mips)
LIBOBJS+= op_helper.o helper.o
endif

B
bellard 已提交
209
ifeq ($(TARGET_BASE_ARCH), sparc)
210 211 212
LIBOBJS+= op_helper.o helper.o
endif

B
bellard 已提交
213
ifeq ($(TARGET_BASE_ARCH), arm)
B
bellard 已提交
214
LIBOBJS+= op_helper.o helper.o
B
bellard 已提交
215 216
endif

B
bellard 已提交
217 218 219
# NOTE: the disassembler code is only needed for debugging
LIBOBJS+=disas.o 
ifeq ($(findstring i386, $(TARGET_ARCH) $(ARCH)),i386)
220 221
USE_I386_DIS=y
endif
B
bellard 已提交
222
ifeq ($(findstring x86_64, $(TARGET_ARCH) $(ARCH)),x86_64)
223 224 225
USE_I386_DIS=y
endif
ifdef USE_I386_DIS
B
bellard 已提交
226 227 228 229 230
LIBOBJS+=i386-dis.o
endif
ifeq ($(findstring alpha, $(TARGET_ARCH) $(ARCH)),alpha)
LIBOBJS+=alpha-dis.o
endif
B
bellard 已提交
231
ifeq ($(findstring ppc, $(TARGET_BASE_ARCH) $(ARCH)),ppc)
B
bellard 已提交
232 233
LIBOBJS+=ppc-dis.o
endif
B
bellard 已提交
234 235 236
ifeq ($(findstring mips, $(TARGET_ARCH) $(ARCH)),mips)
LIBOBJS+=mips-dis.o
endif
B
bellard 已提交
237
ifeq ($(findstring sparc, $(TARGET_BASE_ARCH) $(ARCH)),sparc)
B
bellard 已提交
238 239 240 241 242
LIBOBJS+=sparc-dis.o
endif
ifeq ($(findstring arm, $(TARGET_ARCH) $(ARCH)),arm)
LIBOBJS+=arm-dis.o
endif
B
bellard 已提交
243 244 245
ifeq ($(findstring m68k, $(TARGET_ARCH) $(ARCH)),m68k)
LIBOBJS+=m68k-dis.o
endif
B
bellard 已提交
246 247 248 249

ifeq ($(ARCH),ia64)
OBJS += ia64-syscall.o
endif
B
bellard 已提交
250 251 252
ifdef CONFIG_GDBSTUB
OBJS+=gdbstub.o
endif
B
bellard 已提交
253

254
all: $(PROGS)
B
bellard 已提交
255

256
$(QEMU_USER): $(OBJS)
B
bellard 已提交
257 258 259 260 261 262 263 264
	$(CC) $(LDFLAGS) -o $@ $^  $(LIBS)
ifeq ($(ARCH),alpha)
# Mark as 32 bit binary, i. e. it will be mapped into the low 31 bit of
# the address space (31 bit so sign extending doesn't matter)
	echo -ne '\001\000\000\000' | dd of=qemu bs=1 seek=48 count=4 conv=notrunc
endif

# must use static linking to avoid leaving stuff in virtual address space
265
VL_OBJS=vl.o osdep.o block.o readline.o monitor.o pci.o console.o
266
VL_OBJS+=block-cow.o block-qcow.o aes.o block-vmdk.o block-cloop.o block-dmg.o block-bochs.o block-vpc.o block-vvfat.o
267

268
SOUND_HW = sb16.o es1370.o
B
bellard 已提交
269
AUDIODRV = audio.o noaudio.o wavaudio.o
B
bellard 已提交
270 271 272 273 274 275
ifdef CONFIG_SDL
AUDIODRV += sdlaudio.o
endif
ifdef CONFIG_OSS
AUDIODRV += ossaudio.o
endif
276 277 278 279 280 281 282 283 284 285
ifdef CONFIG_COREAUDIO
AUDIODRV += coreaudio.o
endif
ifdef CONFIG_ALSA
AUDIODRV += alsaaudio.o
LIBS += -lasound
endif
ifdef CONFIG_DSOUND
AUDIODRV += dsoundaudio.o
LIBS += -lole32 -ldxguid
B
bellard 已提交
286
endif
B
bellard 已提交
287
ifdef CONFIG_FMOD
B
bellard 已提交
288
AUDIODRV += fmodaudio.o
B
bellard 已提交
289 290
audio.o fmodaudio.o: DEFINES := -I$(CONFIG_FMOD_INC) $(DEFINES)
LIBS += $(CONFIG_FMOD_LIB)
B
bellard 已提交
291
endif
292 293 294
ifdef CONFIG_ADLIB
SOUND_HW += fmopl.o adlib.o
endif
B
bellard 已提交
295

B
bellard 已提交
296 297 298
# USB layer
VL_OBJS+= usb.o usb-uhci.o usb-linux.o usb-hid.o

B
bellard 已提交
299
ifeq ($(TARGET_BASE_ARCH), i386)
300
# Hardware support
301
VL_OBJS+= ide.o ne2000.o pckbd.o ps2.o vga.o $(SOUND_HW) dma.o $(AUDIODRV)
B
bellard 已提交
302
VL_OBJS+= fdc.o mc146818rtc.o serial.o i8259.o i8254.o pc.o
B
bellard 已提交
303
VL_OBJS+= cirrus_vga.o mixeng.o apic.o parallel.o
304
DEFINES += -DHAS_AUDIO
B
bellard 已提交
305
endif
B
bellard 已提交
306
ifeq ($(TARGET_BASE_ARCH), ppc)
307
VL_OBJS+= ppc.o ide.o ne2000.o pckbd.o ps2.o vga.o $(SOUND_HW) dma.o $(AUDIODRV)
B
bellard 已提交
308
VL_OBJS+= mc146818rtc.o serial.o i8259.o i8254.o fdc.o m48t59.o
B
bellard 已提交
309
VL_OBJS+= ppc_prep.o ppc_chrp.o cuda.o adb.o openpic.o heathrow_pic.o mixeng.o
310
DEFINES += -DHAS_AUDIO
311
endif
B
bellard 已提交
312
ifeq ($(TARGET_ARCH), mips)
B
bellard 已提交
313 314
VL_OBJS+= mips_r4k.o dma.o vga.o serial.o ne2000.o i8254.o i8259.o
#VL_OBJS+= #ide.o pckbd.o fdc.o m48t59.o
B
bellard 已提交
315
endif
B
bellard 已提交
316
ifeq ($(TARGET_BASE_ARCH), sparc)
B
bellard 已提交
317
ifeq ($(TARGET_ARCH), sparc64)
318
VL_OBJS+= sun4u.o ide.o ne2000.o pckbd.o ps2.o vga.o
B
bellard 已提交
319 320 321
VL_OBJS+= fdc.o mc146818rtc.o serial.o m48t59.o
VL_OBJS+= cirrus_vga.o parallel.o
VL_OBJS+= magic-load.o
B
bellard 已提交
322
else
323 324
VL_OBJS+= sun4m.o tcx.o lance.o iommu.o m48t59.o magic-load.o slavio_intctl.o
VL_OBJS+= slavio_timer.o slavio_serial.o slavio_misc.o fdc.o esp.o
B
bellard 已提交
325
endif
326
endif
B
bellard 已提交
327
ifeq ($(TARGET_BASE_ARCH), arm)
328
VL_OBJS+= integratorcp.o ps2.o smc91c111.o
B
bellard 已提交
329
endif
330 331
ifdef CONFIG_GDBSTUB
VL_OBJS+=gdbstub.o 
B
update  
bellard 已提交
332
endif
B
bellard 已提交
333 334
ifdef CONFIG_SDL
VL_OBJS+=sdl.o
B
bellard 已提交
335
endif
336 337
ifdef CONFIG_COCOA
VL_OBJS+=cocoa.o
338 339 340 341
COCOA_LIBS=-F/System/Library/Frameworks -framework Cocoa -framework IOKit
ifdef CONFIG_COREAUDIO
COCOA_LIBS+=-framework CoreAudio
endif
342
endif
B
bellard 已提交
343 344 345 346
ifdef CONFIG_SLIRP
DEFINES+=-I$(SRC_PATH)/slirp
SLIRP_OBJS=cksum.o if.o ip_icmp.o ip_input.o ip_output.o \
slirp.o mbuf.o misc.o sbuf.o socket.o tcp_input.o tcp_output.o \
B
bellard 已提交
347
tcp_subr.o tcp_timer.o udp.o bootp.o debug.o tftp.o
B
bellard 已提交
348
VL_OBJS+=$(addprefix slirp/, $(SLIRP_OBJS))
B
bellard 已提交
349 350
endif

351 352 353 354 355
VL_LDFLAGS=
# specific flags are needed for non soft mmu emulator
ifdef CONFIG_STATIC
VL_LDFLAGS+=-static
endif
B
bellard 已提交
356 357 358
ifndef CONFIG_SOFTMMU
VL_LDFLAGS+=-Wl,-T,$(SRC_PATH)/i386-vl.ld 
endif
359
ifndef CONFIG_DARWIN
B
bellard 已提交
360 361 362
ifndef CONFIG_WIN32
VL_LIBS=-lutil
endif
363
endif
B
bellard 已提交
364 365 366 367
ifdef TARGET_GPROF
vl.o: CFLAGS+=-p
VL_LDFLAGS+=-p
endif
368

B
bellard 已提交
369 370 371 372
ifeq ($(ARCH),ia64)
VL_LDFLAGS+=-Wl,-G0 -Wl,-T,$(SRC_PATH)/ia64.ld
endif

373 374 375 376
ifdef CONFIG_WIN32
SDL_LIBS := $(filter-out -mwindows, $(SDL_LIBS)) -mconsole
endif

377
$(QEMU_SYSTEM): $(VL_OBJS) libqemu.a
378 379 380 381
	$(CC) $(VL_LDFLAGS) -o $@ $^ $(LIBS) $(SDL_LIBS) $(COCOA_LIBS) $(VL_LIBS)

cocoa.o: cocoa.m
	$(CC) $(CFLAGS) $(DEFINES) -c -o $@ $<
B
bellard 已提交
382

383
sdl.o: sdl.c keymaps.c sdl_keysym.h
B
bellard 已提交
384 385
	$(CC) $(CFLAGS) $(DEFINES) $(SDL_CFLAGS) -c -o $@ $<

B
bellard 已提交
386 387 388
sdlaudio.o: sdlaudio.c
	$(CC) $(CFLAGS) $(DEFINES) $(SDL_CFLAGS) -c -o $@ $<

B
bellard 已提交
389
depend: $(SRCS)
B
bellard 已提交
390
	$(CC) -MM $(CFLAGS) $(DEFINES) $^ 1>.depend
B
bellard 已提交
391

392 393 394
vldepend: $(VL_OBJS:.o=.c)
	$(CC) -MM $(CFLAGS) $(DEFINES) $^ 1>.depend

B
bellard 已提交
395 396 397 398 399 400
# libqemu 

libqemu.a: $(LIBOBJS)
	rm -f $@
	$(AR) rcs $@ $(LIBOBJS)

401
translate.o: translate.c gen-op.h opc.h cpu.h
B
bellard 已提交
402

B
bellard 已提交
403 404 405
translate-all.o: translate-all.c opc.h cpu.h

translate-op.o: translate-all.c op.h opc.h cpu.h
B
bellard 已提交
406

407
op.h: op.o $(DYNGEN)
B
bellard 已提交
408 409
	$(DYNGEN) -o $@ $<

410
opc.h: op.o $(DYNGEN)
B
bellard 已提交
411 412
	$(DYNGEN) -c -o $@ $<

413
gen-op.h: op.o $(DYNGEN)
B
bellard 已提交
414 415
	$(DYNGEN) -g -o $@ $<

416
op.o: op.c
B
bellard 已提交
417 418
	$(CC) $(OP_CFLAGS) $(DEFINES) -c -o $@ $<

419
helper.o: helper.c
B
bellard 已提交
420 421
	$(CC) $(HELPER_CFLAGS) $(DEFINES) -c -o $@ $<

B
bellard 已提交
422
ifeq ($(TARGET_BASE_ARCH), i386)
B
bellard 已提交
423
op.o: op.c opreg_template.h ops_template.h ops_template_mem.h ops_mem.h ops_sse.h
424 425 426 427 428
endif

ifeq ($(TARGET_ARCH), arm)
op.o: op.c op_template.h
endif
B
bellard 已提交
429

B
bellard 已提交
430
ifeq ($(TARGET_BASE_ARCH), sparc)
B
bellard 已提交
431 432
op.o: op.c op_template.h op_mem.h fop_template.h fbranch_template.h
magic_load.o: elf_op.h
433
endif
B
bellard 已提交
434

B
bellard 已提交
435
ifeq ($(TARGET_BASE_ARCH), ppc)
B
update  
bellard 已提交
436 437
op.o: op.c op_template.h op_mem.h
op_helper.o: op_helper_mem.h
438
translate.o: translate.c translate_init.c
B
update  
bellard 已提交
439 440
endif

B
bellard 已提交
441 442 443 444 445
ifeq ($(TARGET_ARCH), mips)
op.o: op.c op_template.c op_mem.c
op_helper.o: op_helper_mem.c
endif

B
bellard 已提交
446 447 448
%.o: %.c
	$(CC) $(CFLAGS) $(DEFINES) -c -o $@ $<

B
bellard 已提交
449 450 451
%.o: %.S
	$(CC) $(DEFINES) -c -o $@ $<

B
bellard 已提交
452
clean:
B
bellard 已提交
453
	rm -f *.o  *.a *~ $(PROGS) gen-op.h opc.h op.h nwfpe/*.o slirp/*.o fpu/*.o
454 455

install: all 
B
bellard 已提交
456
ifneq ($(PROGS),)
B
bellard 已提交
457
	install -m 755 -s $(PROGS) "$(bindir)"
B
bellard 已提交
458
endif
B
bellard 已提交
459 460 461 462

ifneq ($(wildcard .depend),)
include .depend
endif
463

B
bellard 已提交
464
ifeq (1, 0)
465
audio.o sdlaudio.o dsoundaudio.o ossaudio.o wavaudio.o noaudio.o \
B
bellard 已提交
466
fmodaudio.o alsaaudio.o mixeng.o sb16.o es1370.o gus.o adlib.o: \
467 468
CFLAGS := $(CFLAGS) -Wall -Werror -W -Wsign-compare
endif