Makefile.target 16.6 KB
Newer Older
bellard's avatar
bellard committed
1
2
include config.mak

bellard's avatar
bellard committed
3
4
5
6
TARGET_BASE_ARCH:=$(TARGET_ARCH)
ifeq ($(TARGET_ARCH), x86_64)
TARGET_BASE_ARCH:=i386
endif
ths's avatar
ths committed
7
8
9
ifeq ($(TARGET_ARCH), mips64)
TARGET_BASE_ARCH:=mips
endif
bellard's avatar
bellard committed
10
11
12
ifeq ($(TARGET_ARCH), ppc64)
TARGET_BASE_ARCH:=ppc
endif
13
14
15
ifeq ($(TARGET_ARCH), ppcemb)
TARGET_BASE_ARCH:=ppc
endif
bellard's avatar
bellard committed
16
17
18
ifeq ($(TARGET_ARCH), sparc64)
TARGET_BASE_ARCH:=sparc
endif
bellard's avatar
bellard committed
19
TARGET_PATH=$(SRC_PATH)/target-$(TARGET_BASE_ARCH)
bellard's avatar
bellard committed
20
VPATH=$(SRC_PATH):$(TARGET_PATH):$(SRC_PATH)/hw:$(SRC_PATH)/audio
21
CPPFLAGS=-I. -I.. -I$(TARGET_PATH) -I$(SRC_PATH)
22
23
24
25
26
ifdef CONFIG_DARWIN_USER
VPATH+=:$(SRC_PATH)/darwin-user
CPPFLAGS+=-I$(SRC_PATH)/darwin-user -I$(SRC_PATH)/darwin-user/$(TARGET_ARCH)
endif
ifdef CONFIG_LINUX_USER
bellard's avatar
bellard committed
27
VPATH+=:$(SRC_PATH)/linux-user
28
CPPFLAGS+=-I$(SRC_PATH)/linux-user -I$(SRC_PATH)/linux-user/$(TARGET_ARCH)
bellard's avatar
bellard committed
29
endif
30
31
BASE_CFLAGS=
BASE_LDFLAGS=
bellard's avatar
bellard committed
32
#CFLAGS+=-Werror
bellard's avatar
bellard committed
33
34
LIBS=
HELPER_CFLAGS=$(CFLAGS)
bellard's avatar
bellard committed
35
DYNGEN=../dyngen$(EXESUF)
36
# user emulator name
bellard's avatar
bellard committed
37
TARGET_ARCH2=$(TARGET_ARCH)
38
39
ifeq ($(TARGET_ARCH),arm)
  ifeq ($(TARGET_WORDS_BIGENDIAN),yes)
bellard's avatar
bellard committed
40
    TARGET_ARCH2=armeb
41
  endif
bellard's avatar
bellard committed
42
endif
pbrook's avatar
pbrook committed
43
44
45
46
47
ifeq ($(TARGET_ARCH),sh4)
  ifeq ($(TARGET_WORDS_BIGENDIAN),yes)
    TARGET_ARCH2=sh4eb
  endif
endif
bellard's avatar
bellard committed
48
ifeq ($(TARGET_ARCH),mips)
bellard's avatar
bellard committed
49
50
  ifneq ($(TARGET_WORDS_BIGENDIAN),yes)
    TARGET_ARCH2=mipsel
bellard's avatar
bellard committed
51
52
  endif
endif
ths's avatar
ths committed
53
54
55
56
57
ifeq ($(TARGET_ARCH),mips64)
  ifneq ($(TARGET_WORDS_BIGENDIAN),yes)
    TARGET_ARCH2=mips64el
  endif
endif
bellard's avatar
bellard committed
58
QEMU_USER=qemu-$(TARGET_ARCH2)
59
60
# system emulator name
ifdef CONFIG_SOFTMMU
61
ifeq ($(TARGET_ARCH), i386)
bellard's avatar
bellard committed
62
QEMU_SYSTEM=qemu$(EXESUF)
63
else
bellard's avatar
bellard committed
64
QEMU_SYSTEM=qemu-system-$(TARGET_ARCH2)$(EXESUF)
65
66
endif
else
67
QEMU_SYSTEM=qemu-fast
68
69
endif

bellard's avatar
bellard committed
70
ifdef CONFIG_USER_ONLY
71
PROGS=$(QEMU_USER)
bellard's avatar
bellard committed
72
else
73
PROGS+=$(QEMU_SYSTEM)
bellard's avatar
bellard committed
74
75
76
ifndef CONFIG_SOFTMMU
CONFIG_STATIC=y
endif
bellard's avatar
update    
bellard committed
77
endif # !CONFIG_USER_ONLY
bellard's avatar
bellard committed
78
79

ifdef CONFIG_STATIC
80
BASE_LDFLAGS+=-static
bellard's avatar
bellard committed
81
82
endif

83
# We require -O2 to avoid the stack setup prologue in EXIT_TB
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
OP_CFLAGS := -Wall -O2 -g -fno-strict-aliasing

# cc-option
# Usage: OP_CFLAGS+=$(call cc-option, -falign-functions=0, -malign-functions=0)

cc-option = $(shell if $(CC) $(OP_CFLAGS) $(1) -S -o /dev/null -xc /dev/null \
              > /dev/null 2>&1; then echo "$(1)"; else echo "$(2)"; fi ;)

OP_CFLAGS+=$(call cc-option, -fno-reorder-blocks, "")
OP_CFLAGS+=$(call cc-option, -fno-gcse, "")
OP_CFLAGS+=$(call cc-option, -fno-tree-ch, "")
OP_CFLAGS+=$(call cc-option, -fno-optimize-sibling-calls, "")
OP_CFLAGS+=$(call cc-option, -fno-crossjumping, "")
OP_CFLAGS+=$(call cc-option, -fno-align-labels, "")
OP_CFLAGS+=$(call cc-option, -fno-align-jumps, "")
OP_CFLAGS+=$(call cc-option, -fno-align-functions, $(call cc-option, -malign-functions=0, ""))
100

bellard's avatar
bellard committed
101
ifeq ($(ARCH),i386)
102
103
HELPER_CFLAGS+=-fomit-frame-pointer
OP_CFLAGS+=-mpreferred-stack-boundary=2 -fomit-frame-pointer
bellard's avatar
bellard committed
104
ifdef TARGET_GPROF
bellard's avatar
bellard committed
105
106
107
108
109
110
USE_I386_LD=y
endif
ifdef CONFIG_STATIC
USE_I386_LD=y
endif
ifdef USE_I386_LD
111
BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
bellard's avatar
bellard committed
112
else
113
ifdef CONFIG_LINUX_USER
bellard's avatar
bellard committed
114
115
116
# 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!
117
BASE_LDFLAGS+=-Wl,-shared
bellard's avatar
bellard committed
118
119
endif
endif
120
endif
bellard's avatar
bellard committed
121

bellard's avatar
bellard committed
122
ifeq ($(ARCH),x86_64)
123
BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
124
125
endif

bellard's avatar
bellard committed
126
ifeq ($(ARCH),ppc)
127
CPPFLAGS+= -D__powerpc__
128
ifdef CONFIG_LINUX_USER
129
BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
bellard's avatar
bellard committed
130
endif
131
endif
bellard's avatar
bellard committed
132
133

ifeq ($(ARCH),s390)
134
BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
bellard's avatar
bellard committed
135
136
137
endif

ifeq ($(ARCH),sparc)
138
139
140
141
142
143
144
145
146
147
  BASE_CFLAGS+=-ffixed-g2 -ffixed-g3
  OP_CFLAGS+=-fno-delayed-branch -ffixed-i0
  ifeq ($(CONFIG_SOLARIS),yes)
    OP_CFLAGS+=-fno-omit-frame-pointer
  else
    BASE_CFLAGS+=-ffixed-g1 -ffixed-g6
    HELPER_CFLAGS=$(CFLAGS) -ffixed-i0 -mflat
    # -static is used to avoid g1/g3 usage by the dynamic linker
    BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld -static
  endif
bellard's avatar
bellard committed
148
endif
bellard's avatar
bellard committed
149
150

ifeq ($(ARCH),sparc64)
151
152
153
154
155
156
  BASE_CFLAGS+=-ffixed-g1 -ffixed-g4 -ffixed-g5 -ffixed-g7
  OP_CFLAGS+=-mcpu=ultrasparc -m64 -fno-delayed-branch -ffixed-i0
  ifneq ($(CONFIG_SOLARIS),yes)
    BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
    OP_CFLAGS+=-ffixed-g1 -ffixed-g4 -ffixed-g5 -ffixed-g7
  endif
bellard's avatar
bellard committed
157
158
159
endif

ifeq ($(ARCH),alpha)
160
161
# -msmall-data is not used for OP_CFLAGS because we want two-instruction
# relocations for the constant constructions
bellard's avatar
bellard committed
162
# Ensure there's only a single GP
163
164
BASE_CFLAGS+=-msmall-data
BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
bellard's avatar
bellard committed
165
166
167
endif

ifeq ($(ARCH),ia64)
168
169
170
BASE_CFLAGS+=-mno-sdata
OP_CFLAGS+=-mno-sdata
BASE_LDFLAGS+=-Wl,-G0 -Wl,-T,$(SRC_PATH)/$(ARCH).ld
bellard's avatar
bellard committed
171
172
173
endif

ifeq ($(ARCH),arm)
174
175
OP_CFLAGS+=-mno-sched-prolog -fno-omit-frame-pointer
BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
bellard's avatar
bellard committed
176
177
endif

bellard's avatar
bellard committed
178
ifeq ($(ARCH),m68k)
179
180
181
182
183
OP_CFLAGS+=-fomit-frame-pointer
BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
endif

ifeq ($(ARCH),mips)
ths's avatar
ths committed
184
OP_CFLAGS+=-mabi=32 -G0 -fno-PIC -mno-abicalls -fomit-frame-pointer -fno-delayed-branch -Wa,-O0
ths's avatar
ths committed
185
186
187
188
189
190
191
192
ifeq ($(WORDS_BIGENDIAN),yes)
BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
else
BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH)el.ld
endif
endif

ifeq ($(ARCH),mips64)
ths's avatar
ths committed
193
OP_CFLAGS+=-mabi=n32 -G0 -fno-PIC -mno-abicalls -fomit-frame-pointer -fno-delayed-branch -Wa,-O0
ths's avatar
ths committed
194
ifeq ($(WORDS_BIGENDIAN),yes)
195
BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
ths's avatar
ths committed
196
197
198
else
BASE_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH)el.ld
endif
bellard's avatar
bellard committed
199
200
endif

201
ifeq ($(CONFIG_DARWIN),yes)
bellard's avatar
bellard committed
202
LIBS+=-lmx
203
204
endif

205
206
207
208
209
ifdef CONFIG_DARWIN_USER
# Leave some space for the regular program loading zone
BASE_LDFLAGS+=-Wl,-segaddr,__STD_PROG_ZONE,0x1000 -image_base 0x0e000000
endif

210
211
212
213
BASE_CFLAGS+=$(OS_CFLAGS) $(ARCH_CFLAGS)
BASE_LDFLAGS+=$(OS_LDFLAGS) $(ARCH_LDFLAGS)
OP_CFLAGS+=$(OS_CFLAGS) $(ARCH_CFLAGS)
OP_LDFLAGS+=$(OS_LDFLAGS) $(ARCH_LDFLAGS)
214

bellard's avatar
bellard committed
215
216
#########################################################

217
CPPFLAGS+=-D_GNU_SOURCE -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE
bellard's avatar
bellard committed
218
LIBS+=-lm
bellard's avatar
bellard committed
219
220
221
ifndef CONFIG_USER_ONLY
LIBS+=-lz
endif
bellard's avatar
bellard committed
222
ifdef CONFIG_WIN32
223
LIBS+=-lwinmm -lws2_32 -liphlpapi
bellard's avatar
bellard committed
224
endif
bellard's avatar
bellard committed
225
226
ifdef CONFIG_SOLARIS
LIBS+=-lsocket -lnsl -lresolv
ths's avatar
ths committed
227
228
229
230
231
232
ifdef NEEDS_LIBSUNMATH
LIBS+=-lsunmath
LDFLAGS+=-L/opt/SUNWspro/prod/lib -R/opt/SUNWspro/prod/lib
OP_CFLAGS+=-I/opt/SUNWspro/prod/include/cc
BASE_CFLAGS+=-I/opt/SUNWspro/prod/include/cc
endif
bellard's avatar
bellard committed
233
endif
bellard's avatar
bellard committed
234
235
236

# profiling code
ifdef TARGET_GPROF
237
238
BASE_LDFLAGS+=-p
main.o: BASE_CFLAGS+=-p
bellard's avatar
bellard committed
239
240
endif

241
ifdef CONFIG_LINUX_USER
pbrook's avatar
pbrook committed
242
243
OBJS= main.o syscall.o mmap.o signal.o path.o osdep.o thunk.o \
      elfload.o linuxload.o
244
LIBS+= $(AIOLIBS)
pbrook's avatar
pbrook committed
245
246
247
248
ifdef TARGET_HAS_BFLT
OBJS+= flatload.o
endif

bellard's avatar
bellard committed
249
250
251
ifeq ($(TARGET_ARCH), i386)
OBJS+= vm86.o
endif
bellard's avatar
bellard committed
252
ifeq ($(TARGET_ARCH), arm)
bellard's avatar
bellard committed
253
OBJS+=nwfpe/fpa11.o nwfpe/fpa11_cpdo.o \
bellard's avatar
bellard committed
254
nwfpe/fpa11_cpdt.o nwfpe/fpa11_cprt.o nwfpe/fpopcode.o nwfpe/single_cpdo.o \
255
 nwfpe/double_cpdo.o nwfpe/extended_cpdo.o arm-semi.o
bellard's avatar
bellard committed
256
endif
pbrook's avatar
pbrook committed
257
258
259
ifeq ($(TARGET_ARCH), m68k)
OBJS+= m68k-sim.o m68k-semi.o
endif
260
261
262
263
264
265
endif #CONFIG_LINUX_USER

ifdef CONFIG_DARWIN_USER
OBJS= main.o commpage.o machload.o mmap.o osdep.o signal.o syscall.o thunk.o
endif

bellard's avatar
bellard committed
266
267
268
269
SRCS:= $(OBJS:.o=.c)
OBJS+= libqemu.a

# cpu emulator library
bellard's avatar
bellard committed
270
LIBOBJS=exec.o kqemu.o translate-op.o translate-all.o cpu-exec.o\
bellard's avatar
bellard committed
271
        translate.o op.o 
bellard's avatar
bellard committed
272
273
274
275
276
ifdef CONFIG_SOFTFLOAT
LIBOBJS+=fpu/softfloat.o
else
LIBOBJS+=fpu/softfloat-native.o
endif
277
CPPFLAGS+=-I$(SRC_PATH)/fpu
bellard's avatar
bellard committed
278
279

ifeq ($(TARGET_ARCH), i386)
280
LIBOBJS+=helper.o helper2.o
bellard's avatar
bellard committed
281
282
283
ifeq ($(ARCH), i386)
LIBOBJS+=translate-copy.o
endif
bellard's avatar
bellard committed
284
285
endif

bellard's avatar
bellard committed
286
287
288
289
ifeq ($(TARGET_ARCH), x86_64)
LIBOBJS+=helper.o helper2.o
endif

bellard's avatar
bellard committed
290
ifeq ($(TARGET_BASE_ARCH), ppc)
bellard's avatar
update    
bellard committed
291
LIBOBJS+= op_helper.o helper.o
292
293
endif

ths's avatar
ths committed
294
ifeq ($(TARGET_BASE_ARCH), mips)
bellard's avatar
bellard committed
295
296
297
LIBOBJS+= op_helper.o helper.o
endif

bellard's avatar
bellard committed
298
ifeq ($(TARGET_BASE_ARCH), sparc)
299
300
301
LIBOBJS+= op_helper.o helper.o
endif

bellard's avatar
bellard committed
302
ifeq ($(TARGET_BASE_ARCH), arm)
bellard's avatar
bellard committed
303
LIBOBJS+= op_helper.o helper.o
bellard's avatar
bellard committed
304
305
endif

bellard's avatar
bellard committed
306
307
308
309
ifeq ($(TARGET_BASE_ARCH), sh4)
LIBOBJS+= op_helper.o helper.o
endif

pbrook's avatar
pbrook committed
310
311
312
313
ifeq ($(TARGET_BASE_ARCH), m68k)
LIBOBJS+= helper.o
endif

314
315
316
317
ifeq ($(TARGET_BASE_ARCH), alpha)
LIBOBJS+= op_helper.o helper.o alpha_palcode.o
endif

bellard's avatar
bellard committed
318
319
320
# NOTE: the disassembler code is only needed for debugging
LIBOBJS+=disas.o 
ifeq ($(findstring i386, $(TARGET_ARCH) $(ARCH)),i386)
321
322
USE_I386_DIS=y
endif
bellard's avatar
bellard committed
323
ifeq ($(findstring x86_64, $(TARGET_ARCH) $(ARCH)),x86_64)
324
325
326
USE_I386_DIS=y
endif
ifdef USE_I386_DIS
bellard's avatar
bellard committed
327
328
329
330
331
LIBOBJS+=i386-dis.o
endif
ifeq ($(findstring alpha, $(TARGET_ARCH) $(ARCH)),alpha)
LIBOBJS+=alpha-dis.o
endif
bellard's avatar
bellard committed
332
ifeq ($(findstring ppc, $(TARGET_BASE_ARCH) $(ARCH)),ppc)
bellard's avatar
bellard committed
333
334
LIBOBJS+=ppc-dis.o
endif
ths's avatar
ths committed
335
ifeq ($(findstring mips, $(TARGET_BASE_ARCH) $(ARCH)),mips)
bellard's avatar
bellard committed
336
337
LIBOBJS+=mips-dis.o
endif
bellard's avatar
bellard committed
338
ifeq ($(findstring sparc, $(TARGET_BASE_ARCH) $(ARCH)),sparc)
bellard's avatar
bellard committed
339
340
341
342
343
LIBOBJS+=sparc-dis.o
endif
ifeq ($(findstring arm, $(TARGET_ARCH) $(ARCH)),arm)
LIBOBJS+=arm-dis.o
endif
bellard's avatar
bellard committed
344
345
346
ifeq ($(findstring m68k, $(TARGET_ARCH) $(ARCH)),m68k)
LIBOBJS+=m68k-dis.o
endif
bellard's avatar
bellard committed
347
348
349
ifeq ($(findstring sh4, $(TARGET_ARCH) $(ARCH)),sh4)
LIBOBJS+=sh4-dis.o
endif
bellard's avatar
bellard committed
350

351
352
353
ifdef CONFIG_GDBSTUB
OBJS+=gdbstub.o
endif
bellard's avatar
bellard committed
354

355
all: $(PROGS)
bellard's avatar
bellard committed
356

357
$(QEMU_USER): $(OBJS)
358
	$(CC) $(LDFLAGS) $(BASE_LDFLAGS) -o $@ $^  $(LIBS)
bellard's avatar
bellard committed
359
360
361
362
363
364
365
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
pbrook's avatar
pbrook committed
366
VL_OBJS=vl.o osdep.o readline.o monitor.o pci.o console.o loader.o isa_mmio.o
bellard's avatar
bellard committed
367
VL_OBJS+=cutils.o
368
VL_OBJS+=host-utils.o
bellard's avatar
bellard committed
369
VL_OBJS+=block.o block-raw.o
bellard's avatar
bellard committed
370
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 block-qcow2.o
pbrook's avatar
pbrook committed
371
VL_OBJS+=irq.o
bellard's avatar
bellard committed
372
373
374
ifdef CONFIG_WIN32
VL_OBJS+=tap-win32.o
endif
375

376
SOUND_HW = sb16.o es1370.o
377
AUDIODRV = audio.o noaudio.o wavaudio.o mixeng.o
378
379
380
381
382
383
ifdef CONFIG_SDL
AUDIODRV += sdlaudio.o
endif
ifdef CONFIG_OSS
AUDIODRV += ossaudio.o
endif
384
385
386
387
388
389
390
391
392
393
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
bellard's avatar
bellard committed
394
endif
bellard's avatar
bellard committed
395
ifdef CONFIG_FMOD
bellard's avatar
bellard committed
396
AUDIODRV += fmodaudio.o
397
audio.o fmodaudio.o: CPPFLAGS := -I$(CONFIG_FMOD_INC) $(CPPFLAGS)
bellard's avatar
bellard committed
398
LIBS += $(CONFIG_FMOD_LIB)
bellard's avatar
bellard committed
399
endif
400
401
402
ifdef CONFIG_ADLIB
SOUND_HW += fmopl.o adlib.o
endif
bellard's avatar
bellard committed
403
AUDIODRV+= wavcapture.o
bellard's avatar
bellard committed
404

pbrook's avatar
pbrook committed
405
406
VL_OBJS += i2c.o smbus.o

pbrook's avatar
pbrook committed
407
# SCSI layer
pbrook's avatar
pbrook committed
408
VL_OBJS+= scsi-disk.o cdrom.o lsi53c895a.o
pbrook's avatar
pbrook committed
409

bellard's avatar
bellard committed
410
# USB layer
pbrook's avatar
pbrook committed
411
VL_OBJS+= usb.o usb-hub.o usb-linux.o usb-hid.o usb-ohci.o usb-msd.o
bellard's avatar
bellard committed
412

ths's avatar
ths committed
413
414
415
# EEPROM emulation
VL_OBJS += eeprom93xx.o

416
# PCI network cards
ths's avatar
ths committed
417
418
419
420
VL_OBJS += eepro100.o
VL_OBJS += ne2000.o
VL_OBJS += pcnet.o
VL_OBJS += rtl8139.o
421

bellard's avatar
bellard committed
422
ifeq ($(TARGET_BASE_ARCH), i386)
423
# Hardware support
424
VL_OBJS+= ide.o pckbd.o ps2.o vga.o $(SOUND_HW) dma.o $(AUDIODRV)
bellard's avatar
bellard committed
425
VL_OBJS+= fdc.o mc146818rtc.o serial.o i8259.o i8254.o pcspk.o pc.o
426
VL_OBJS+= cirrus_vga.o apic.o parallel.o acpi.o piix_pci.o
427
VL_OBJS+= usb-uhci.o smbus_eeprom.o vmmouse.o vmware_vga.o
428
CPPFLAGS += -DHAS_AUDIO -DHAS_AUDIO_CHOICE
bellard's avatar
bellard committed
429
endif
bellard's avatar
bellard committed
430
ifeq ($(TARGET_BASE_ARCH), ppc)
431
VL_OBJS+= ppc.o ide.o pckbd.o ps2.o vga.o $(SOUND_HW) dma.o $(AUDIODRV)
432
VL_OBJS+= mc146818rtc.o serial.o i8259.o i8254.o fdc.o m48t59.o pflash_cfi02.o
433
VL_OBJS+= ppc_prep.o ppc_chrp.o cuda.o adb.o openpic.o heathrow_pic.o
j_mayer's avatar
j_mayer committed
434
VL_OBJS+= grackle_pci.o prep_pci.o unin_pci.o ppc405_uc.o ppc405_boards.o
435
CPPFLAGS += -DHAS_AUDIO -DHAS_AUDIO_CHOICE
436
endif
ths's avatar
ths committed
437
ifeq ($(TARGET_BASE_ARCH), mips)
438
439
VL_OBJS+= mips_r4k.o mips_malta.o mips_pica61.o
VL_OBJS+= mips_timer.o mips_int.o dma.o vga.o serial.o i8254.o i8259.o
440
VL_OBJS+= ide.o gt64xxx.o pckbd.o ps2.o fdc.o mc146818rtc.o usb-uhci.o acpi.o ds1225y.o
441
VL_OBJS+= piix_pci.o parallel.o mixeng.o cirrus_vga.o $(SOUND_HW) $(AUDIODRV)
ths's avatar
ths committed
442
CPPFLAGS += -DHAS_AUDIO
bellard's avatar
bellard committed
443
endif
bellard's avatar
bellard committed
444
ifeq ($(TARGET_BASE_ARCH), sparc)
bellard's avatar
bellard committed
445
ifeq ($(TARGET_ARCH), sparc64)
pbrook's avatar
pbrook committed
446
VL_OBJS+= sun4u.o ide.o pckbd.o ps2.o vga.o apb_pci.o
bellard's avatar
bellard committed
447
448
VL_OBJS+= fdc.o mc146818rtc.o serial.o m48t59.o
VL_OBJS+= cirrus_vga.o parallel.o
bellard's avatar
bellard committed
449
else
450
451
VL_OBJS+= sun4m.o tcx.o pcnet.o iommu.o m48t59.o slavio_intctl.o
VL_OBJS+= slavio_timer.o slavio_serial.o slavio_misc.o fdc.o esp.o sparc32_dma.o
452
VL_OBJS+= cs4231.o
bellard's avatar
bellard committed
453
endif
454
endif
bellard's avatar
bellard committed
455
ifeq ($(TARGET_BASE_ARCH), arm)
456
VL_OBJS+= integratorcp.o versatilepb.o ps2.o smc91c111.o arm_pic.o arm_timer.o
457
VL_OBJS+= arm_boot.o pl011.o pl050.o pl080.o pl110.o pl181.o pl190.o
458
VL_OBJS+= versatile_pci.o sd.o ptimer.o
pbrook's avatar
pbrook committed
459
VL_OBJS+= arm_gic.o realview.o arm_sysctl.o
460
VL_OBJS+= arm-semi.o
461
462
463
VL_OBJS+= pxa2xx.o pxa2xx_pic.o pxa2xx_gpio.o pxa2xx_timer.o pxa2xx_dma.o
VL_OBJS+= pxa2xx_lcd.o pxa2xx_mmci.o pxa2xx_pcmcia.o max111x.o
VL_OBJS+= spitz.o ads7846.o ide.o serial.o nand.o $(AUDIODRV)
464
CPPFLAGS += -DHAS_AUDIO
bellard's avatar
bellard committed
465
endif
bellard's avatar
bellard committed
466
467
468
ifeq ($(TARGET_BASE_ARCH), sh4)
VL_OBJS+= shix.o sh7750.o sh7750_regnames.o tc58128.o
endif
469
470
ifdef CONFIG_GDBSTUB
VL_OBJS+=gdbstub.o 
bellard's avatar
update    
bellard committed
471
endif
bellard's avatar
bellard committed
472
ifdef CONFIG_SDL
473
VL_OBJS+=sdl.o x_keymap.o
bellard's avatar
bellard committed
474
endif
bellard's avatar
bellard committed
475
VL_OBJS+=vnc.o
476
477
ifdef CONFIG_COCOA
VL_OBJS+=cocoa.o
478
479
480
481
COCOA_LIBS=-F/System/Library/Frameworks -framework Cocoa -framework IOKit
ifdef CONFIG_COREAUDIO
COCOA_LIBS+=-framework CoreAudio
endif
482
endif
bellard's avatar
bellard committed
483
ifdef CONFIG_SLIRP
484
CPPFLAGS+=-I$(SRC_PATH)/slirp
bellard's avatar
bellard committed
485
486
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 \
bellard's avatar
bellard committed
487
tcp_subr.o tcp_timer.o udp.o bootp.o debug.o tftp.o
bellard's avatar
bellard committed
488
VL_OBJS+=$(addprefix slirp/, $(SLIRP_OBJS))
bellard's avatar
bellard committed
489
490
endif

491
VL_LDFLAGS=
492
VL_LIBS=$(AIOLIBS)
493
494
495
496
# specific flags are needed for non soft mmu emulator
ifdef CONFIG_STATIC
VL_LDFLAGS+=-static
endif
bellard's avatar
bellard committed
497
498
499
ifndef CONFIG_SOFTMMU
VL_LDFLAGS+=-Wl,-T,$(SRC_PATH)/i386-vl.ld 
endif
500
ifndef CONFIG_DARWIN
bellard's avatar
bellard committed
501
ifndef CONFIG_WIN32
bellard's avatar
bellard committed
502
ifndef CONFIG_SOLARIS
503
VL_LIBS+=-lutil
bellard's avatar
bellard committed
504
endif
505
endif
bellard's avatar
bellard committed
506
endif
bellard's avatar
bellard committed
507
ifdef TARGET_GPROF
508
vl.o: BASE_CFLAGS+=-p
bellard's avatar
bellard committed
509
510
VL_LDFLAGS+=-p
endif
511

bellard's avatar
bellard committed
512
513
514
515
ifeq ($(ARCH),ia64)
VL_LDFLAGS+=-Wl,-G0 -Wl,-T,$(SRC_PATH)/ia64.ld
endif

bellard's avatar
bellard committed
516
ifeq ($(ARCH),sparc64)
517
518
519
520
  VL_LDFLAGS+=-m64
  ifneq ($(CONFIG_SOLARIS),yes)
    VL_LDFLAGS+=-Wl,-T,$(SRC_PATH)/$(ARCH).ld
  endif
bellard's avatar
bellard committed
521
522
endif

523
524
525
526
ifdef CONFIG_WIN32
SDL_LIBS := $(filter-out -mwindows, $(SDL_LIBS)) -mconsole
endif

527
$(QEMU_SYSTEM): $(VL_OBJS) libqemu.a
528
	$(CC) $(VL_LDFLAGS) $(LDFLAGS) -o $@ $^ $(LIBS) $(SDL_LIBS) $(COCOA_LIBS) $(VL_LIBS)
529
530

cocoa.o: cocoa.m
531
	$(CC) $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
bellard's avatar
bellard committed
532

533
sdl.o: sdl.c keymaps.c sdl_keysym.h
534
	$(CC) $(CFLAGS) $(CPPFLAGS) $(SDL_CFLAGS) $(BASE_CFLAGS) -c -o $@ $<
bellard's avatar
bellard committed
535

bellard's avatar
bellard committed
536
vnc.o: vnc.c keymaps.c sdl_keysym.h vnchextile.h
537
	$(CC) $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
bellard's avatar
bellard committed
538

bellard's avatar
bellard committed
539
sdlaudio.o: sdlaudio.c
540
	$(CC) $(CFLAGS) $(CPPFLAGS) $(SDL_CFLAGS) $(BASE_CFLAGS) -c -o $@ $<
bellard's avatar
bellard committed
541

bellard's avatar
bellard committed
542
depend: $(SRCS)
543
	$(CC) -MM $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) $^ 1>.depend
bellard's avatar
bellard committed
544

545
vldepend: $(VL_OBJS:.o=.c)
546
	$(CC) -MM $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) $^ 1>.depend
547

bellard's avatar
bellard committed
548
549
550
551
552
553
# libqemu 

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

554
translate.o: translate.c gen-op.h opc.h cpu.h
bellard's avatar
bellard committed
555

bellard's avatar
bellard committed
556
557
558
translate-all.o: translate-all.c opc.h cpu.h

translate-op.o: translate-all.c op.h opc.h cpu.h
bellard's avatar
bellard committed
559

560
op.h: op.o $(DYNGEN)
bellard's avatar
bellard committed
561
562
	$(DYNGEN) -o $@ $<

563
opc.h: op.o $(DYNGEN)
bellard's avatar
bellard committed
564
565
	$(DYNGEN) -c -o $@ $<

566
gen-op.h: op.o $(DYNGEN)
bellard's avatar
bellard committed
567
568
	$(DYNGEN) -g -o $@ $<

569
op.o: op.c
570
	$(CC) $(OP_CFLAGS) $(CPPFLAGS) -c -o $@ $<
bellard's avatar
bellard committed
571

bellard's avatar
bellard committed
572
573
574
575
# HELPER_CFLAGS is used for all the code compiled with static register
# variables
ifeq ($(TARGET_BASE_ARCH), i386)
# XXX: rename helper.c to op_helper.c
576
helper.o: helper.c
577
	$(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
bellard's avatar
bellard committed
578
579
else
op_helper.o: op_helper.c
580
	$(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
bellard's avatar
bellard committed
581
582
583
endif

cpu-exec.o: cpu-exec.c
584
	$(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
bellard's avatar
bellard committed
585

586
587
588
# Note: this is a workaround. The real fix is to avoid compiling
# cpu_signal_handler() in cpu-exec.c.
signal.o: signal.c
589
	$(CC) $(HELPER_CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
590

bellard's avatar
bellard committed
591
ifeq ($(TARGET_BASE_ARCH), i386)
bellard's avatar
bellard committed
592
op.o: op.c opreg_template.h ops_template.h ops_template_mem.h ops_mem.h ops_sse.h
593
594
595
596
endif

ifeq ($(TARGET_ARCH), arm)
op.o: op.c op_template.h
pbrook's avatar
pbrook committed
597
pl110.o: pl110_template.h
598
endif
bellard's avatar
bellard committed
599

bellard's avatar
bellard committed
600
ifeq ($(TARGET_BASE_ARCH), sparc)
bellard's avatar
bellard committed
601
602
op.o: op.c op_template.h op_mem.h fop_template.h fbranch_template.h
magic_load.o: elf_op.h
603
endif
bellard's avatar
bellard committed
604

bellard's avatar
bellard committed
605
ifeq ($(TARGET_BASE_ARCH), ppc)
bellard's avatar
update    
bellard committed
606
607
op.o: op.c op_template.h op_mem.h
op_helper.o: op_helper_mem.h
608
translate.o: translate.c translate_init.c
bellard's avatar
update    
bellard committed
609
610
endif

ths's avatar
ths committed
611
612
ifeq ($(TARGET_BASE_ARCH), mips)
helper.o: cpu.h exec-all.h
ths's avatar
ths committed
613
614
op.o: op_template.c fop_template.c op_mem.c exec.h cpu.h
op_helper.o: op_helper_mem.c exec.h softmmu_template.h cpu.h
ths's avatar
ths committed
615
translate.o: translate_init.c exec-all.h disas.h
bellard's avatar
bellard committed
616
617
endif

bellard's avatar
bellard committed
618
619
loader.o: loader.c elf_ops.h

bellard's avatar
bellard committed
620
621
622
623
ifeq ($(TARGET_ARCH), sh4)
op.o: op.c op_mem.c cpu.h
op_helper.o: op_helper.c exec.h cpu.h
helper.o: helper.c exec.h cpu.h
624
625
sh7750.o: sh7750.c sh7750_regs.h sh7750_regnames.h cpu.h
shix.o: shix.c sh7750_regs.h sh7750_regnames.h
bellard's avatar
bellard committed
626
sh7750_regnames.o: sh7750_regnames.c sh7750_regnames.h sh7750_regs.h
627
tc58128.o: tc58128.c
bellard's avatar
bellard committed
628
629
endif

630
631
632
633
634
ifeq ($(TARGET_BASE_ARCH), alpha)
op.o: op.c op_template.h op_mem.h
op_helper.o: op_helper_mem.h
endif

635
636
$(OBJS) $(LIBOBJS) $(VL_OBJS): config.h ../config-host.h

bellard's avatar
bellard committed
637
%.o: %.c
638
	$(CC) $(CFLAGS) $(CPPFLAGS) $(BASE_CFLAGS) -c -o $@ $<
bellard's avatar
bellard committed
639

bellard's avatar
bellard committed
640
%.o: %.S
641
	$(CC) $(CPPFLAGS) -c -o $@ $<
bellard's avatar
bellard committed
642

bellard's avatar
bellard committed
643
clean:
bellard's avatar
bellard committed
644
	rm -f *.o  *.a *~ $(PROGS) gen-op.h opc.h op.h nwfpe/*.o slirp/*.o fpu/*.o
645
646

install: all 
bellard's avatar
bellard committed
647
ifneq ($(PROGS),)
648
	$(INSTALL) -m 755 -s $(PROGS) "$(DESTDIR)$(bindir)"
bellard's avatar
bellard committed
649
endif
bellard's avatar
bellard committed
650
651
652
653

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

bellard's avatar
bellard committed
655
ifeq (1, 0)
656
audio.o sdlaudio.o dsoundaudio.o ossaudio.o wavaudio.o noaudio.o \
bellard's avatar
bellard committed
657
fmodaudio.o alsaaudio.o mixeng.o sb16.o es1370.o gus.o adlib.o: \
658
659
CFLAGS := $(CFLAGS) -Wall -Werror -W -Wsign-compare
endif