]> git.proxmox.com Git - qemu.git/blame - Makefile.target
use constants for TLB handling (Thiemo Seufer)
[qemu.git] / Makefile.target
CommitLineData
626df76a
FB
1include config.mak
2
0b0babc6
FB
3TARGET_BASE_ARCH:=$(TARGET_ARCH)
4ifeq ($(TARGET_ARCH), x86_64)
5TARGET_BASE_ARCH:=i386
6endif
a2458627
FB
7ifeq ($(TARGET_ARCH), ppc64)
8TARGET_BASE_ARCH:=ppc
9endif
64b3ab24
FB
10ifeq ($(TARGET_ARCH), sparc64)
11TARGET_BASE_ARCH:=sparc
12endif
0b0babc6 13TARGET_PATH=$(SRC_PATH)/target-$(TARGET_BASE_ARCH)
85571bc7 14VPATH=$(SRC_PATH):$(TARGET_PATH):$(SRC_PATH)/hw:$(SRC_PATH)/audio
ad064840 15DEFINES=-I. -I.. -I$(TARGET_PATH) -I$(SRC_PATH)
3035f7ff
FB
16ifdef CONFIG_USER_ONLY
17VPATH+=:$(SRC_PATH)/linux-user
18DEFINES+=-I$(SRC_PATH)/linux-user -I$(SRC_PATH)/linux-user/$(TARGET_ARCH)
19endif
ab2572d7 20CFLAGS=-Wall -O2 -g -fno-strict-aliasing
0b0babc6 21#CFLAGS+=-Werror
626df76a
FB
22LDFLAGS=-g
23LIBS=
626df76a 24HELPER_CFLAGS=$(CFLAGS)
67b915a5 25DYNGEN=../dyngen$(EXESUF)
1e43adfc 26# user emulator name
c91fde65 27TARGET_ARCH2=$(TARGET_ARCH)
808c4954
FB
28ifeq ($(TARGET_ARCH),arm)
29 ifeq ($(TARGET_WORDS_BIGENDIAN),yes)
c91fde65 30 TARGET_ARCH2=armeb
808c4954 31 endif
c91fde65 32endif
01f5e596 33ifeq ($(TARGET_ARCH),mips)
c91fde65
FB
34 ifneq ($(TARGET_WORDS_BIGENDIAN),yes)
35 TARGET_ARCH2=mipsel
01f5e596 36 endif
01f5e596 37endif
c91fde65 38QEMU_USER=qemu-$(TARGET_ARCH2)
1e43adfc
FB
39# system emulator name
40ifdef CONFIG_SOFTMMU
a541f297 41ifeq ($(TARGET_ARCH), i386)
67b915a5 42QEMU_SYSTEM=qemu$(EXESUF)
0db63474 43else
c91fde65 44QEMU_SYSTEM=qemu-system-$(TARGET_ARCH2)$(EXESUF)
a541f297
FB
45endif
46else
0db63474 47QEMU_SYSTEM=qemu-fast
1e43adfc
FB
48endif
49
16e9b7de 50ifdef CONFIG_USER_ONLY
1e43adfc 51PROGS=$(QEMU_USER)
16e9b7de 52else
c321f673 53PROGS+=$(QEMU_SYSTEM)
de5eaa64
FB
54ifndef CONFIG_SOFTMMU
55CONFIG_STATIC=y
56endif
728c9fd5 57endif # !CONFIG_USER_ONLY
626df76a
FB
58
59ifdef CONFIG_STATIC
60LDFLAGS+=-static
61endif
62
63ifeq ($(ARCH),i386)
64CFLAGS+=-fomit-frame-pointer
65OP_CFLAGS=$(CFLAGS) -mpreferred-stack-boundary=2
66ifeq ($(HAVE_GCC3_OPTIONS),yes)
3611a29c 67OP_CFLAGS+= -falign-functions=0 -fno-gcse
626df76a
FB
68else
69OP_CFLAGS+= -malign-functions=0
70endif
3a4739d6 71
626df76a 72ifdef TARGET_GPROF
3a4739d6
FB
73USE_I386_LD=y
74endif
75ifdef CONFIG_STATIC
76USE_I386_LD=y
77endif
78ifdef USE_I386_LD
626df76a
FB
79LDFLAGS+=-Wl,-T,$(SRC_PATH)/i386.ld
80else
81# WARNING: this LDFLAGS is _very_ tricky : qemu is an ELF shared object
82# that the kernel ELF loader considers as an executable. I think this
83# is the simplest way to make it self virtualizable!
84LDFLAGS+=-Wl,-shared
85endif
626df76a
FB
86endif
87
0b0babc6 88ifeq ($(ARCH),x86_64)
bc51c5c9 89OP_CFLAGS=$(CFLAGS) -falign-functions=0
0b0babc6 90LDFLAGS+=-Wl,-T,$(SRC_PATH)/x86_64.ld
bc51c5c9
FB
91endif
92
626df76a 93ifeq ($(ARCH),ppc)
83fb7adf 94CFLAGS+= -D__powerpc__
626df76a
FB
95OP_CFLAGS=$(CFLAGS)
96LDFLAGS+=-Wl,-T,$(SRC_PATH)/ppc.ld
97endif
98
99ifeq ($(ARCH),s390)
100OP_CFLAGS=$(CFLAGS)
101LDFLAGS+=-Wl,-T,$(SRC_PATH)/s390.ld
102endif
103
104ifeq ($(ARCH),sparc)
105CFLAGS+=-m32 -ffixed-g1 -ffixed-g2 -ffixed-g3 -ffixed-g6
106LDFLAGS+=-m32
107OP_CFLAGS=$(CFLAGS) -fno-delayed-branch -ffixed-i0
108HELPER_CFLAGS=$(CFLAGS) -ffixed-i0 -mflat
109# -static is used to avoid g1/g3 usage by the dynamic linker
110LDFLAGS+=-Wl,-T,$(SRC_PATH)/sparc.ld -static
111endif
112
113ifeq ($(ARCH),sparc64)
114CFLAGS+=-m64 -ffixed-g1 -ffixed-g2 -ffixed-g3 -ffixed-g6
115LDFLAGS+=-m64
116OP_CFLAGS=$(CFLAGS) -fno-delayed-branch -ffixed-i0
117endif
118
119ifeq ($(ARCH),alpha)
120# -msmall-data is not used because we want two-instruction relocations
121# for the constant constructions
122OP_CFLAGS=-Wall -O2 -g
123# Ensure there's only a single GP
124CFLAGS += -msmall-data
125LDFLAGS+=-Wl,-T,$(SRC_PATH)/alpha.ld
126endif
127
128ifeq ($(ARCH),ia64)
b8076a74 129CFLAGS += -mno-sdata
626df76a 130OP_CFLAGS=$(CFLAGS)
b8076a74 131LDFLAGS+=-Wl,-G0 -Wl,-T,$(SRC_PATH)/ia64.ld
626df76a
FB
132endif
133
134ifeq ($(ARCH),arm)
ba68055e 135OP_CFLAGS=$(CFLAGS) -mno-sched-prolog -fno-omit-frame-pointer
626df76a
FB
136LDFLAGS+=-Wl,-T,$(SRC_PATH)/arm.ld
137endif
138
38e584a0
FB
139ifeq ($(ARCH),m68k)
140OP_CFLAGS=$(CFLAGS) -fomit-frame-pointer
141LDFLAGS+=-Wl,-T,m68k.ld
142endif
143
626df76a
FB
144ifeq ($(HAVE_GCC3_OPTIONS),yes)
145# very important to generate a return at the end of every operation
146OP_CFLAGS+=-fno-reorder-blocks -fno-optimize-sibling-calls
147endif
148
83fb7adf
FB
149ifeq ($(CONFIG_DARWIN),yes)
150OP_CFLAGS+= -mdynamic-no-pic
e80cfcfc 151LIBS+=-lmx
83fb7adf
FB
152endif
153
626df76a
FB
154#########################################################
155
d5249393 156DEFINES+=-D_GNU_SOURCE -D_FILE_OFFSET_BITS=64 -D_LARGEFILE_SOURCE
626df76a 157LIBS+=-lm
b932caba
FB
158ifndef CONFIG_USER_ONLY
159LIBS+=-lz
160endif
67b915a5 161ifdef CONFIG_WIN32
3db38e87 162LIBS+=-lwinmm -lws2_32 -liphlpapi
67b915a5 163endif
ec530c81
FB
164ifdef CONFIG_SOLARIS
165LIBS+=-lsocket -lnsl -lresolv
166endif
626df76a
FB
167
168# profiling code
169ifdef TARGET_GPROF
170LDFLAGS+=-p
171main.o: CFLAGS+=-p
172endif
173
e5fe0c52
PB
174OBJS= main.o syscall.o mmap.o signal.o path.o osdep.o thunk.o \
175 elfload.o linuxload.o
176ifdef TARGET_HAS_BFLT
177OBJS+= flatload.o
178endif
179
626df76a
FB
180ifeq ($(TARGET_ARCH), i386)
181OBJS+= vm86.o
182endif
f72b519c 183ifeq ($(TARGET_ARCH), arm)
158142c2 184OBJS+=nwfpe/fpa11.o nwfpe/fpa11_cpdo.o \
f72b519c 185nwfpe/fpa11_cpdt.o nwfpe/fpa11_cprt.o nwfpe/fpopcode.o nwfpe/single_cpdo.o \
a4f81979 186 nwfpe/double_cpdo.o nwfpe/extended_cpdo.o arm-semi.o
f72b519c 187endif
626df76a
FB
188SRCS:= $(OBJS:.o=.c)
189OBJS+= libqemu.a
190
191# cpu emulator library
158142c2 192LIBOBJS=exec.o kqemu.o translate-op.o translate-all.o cpu-exec.o\
e3086fbf 193 translate.o op.o
158142c2
FB
194ifdef CONFIG_SOFTFLOAT
195LIBOBJS+=fpu/softfloat.o
196else
197LIBOBJS+=fpu/softfloat-native.o
198endif
199DEFINES+=-I$(SRC_PATH)/fpu
626df76a
FB
200
201ifeq ($(TARGET_ARCH), i386)
1e43adfc 202LIBOBJS+=helper.o helper2.o
f72b519c
FB
203ifeq ($(ARCH), i386)
204LIBOBJS+=translate-copy.o
205endif
626df76a
FB
206endif
207
0b0babc6
FB
208ifeq ($(TARGET_ARCH), x86_64)
209LIBOBJS+=helper.o helper2.o
210endif
211
a2458627 212ifeq ($(TARGET_BASE_ARCH), ppc)
728c9fd5 213LIBOBJS+= op_helper.o helper.o
67867308
FB
214endif
215
6af0bf9c
FB
216ifeq ($(TARGET_ARCH), mips)
217LIBOBJS+= op_helper.o helper.o
218endif
219
64b3ab24 220ifeq ($(TARGET_BASE_ARCH), sparc)
e95c8d51
FB
221LIBOBJS+= op_helper.o helper.o
222endif
223
b7bcbe95 224ifeq ($(TARGET_BASE_ARCH), arm)
b5ff1b31 225LIBOBJS+= op_helper.o helper.o
b7bcbe95
FB
226endif
227
fdf9b3e8
FB
228ifeq ($(TARGET_BASE_ARCH), sh4)
229LIBOBJS+= op_helper.o helper.o
230endif
231
626df76a
FB
232# NOTE: the disassembler code is only needed for debugging
233LIBOBJS+=disas.o
234ifeq ($(findstring i386, $(TARGET_ARCH) $(ARCH)),i386)
bc51c5c9
FB
235USE_I386_DIS=y
236endif
0b0babc6 237ifeq ($(findstring x86_64, $(TARGET_ARCH) $(ARCH)),x86_64)
bc51c5c9
FB
238USE_I386_DIS=y
239endif
240ifdef USE_I386_DIS
626df76a
FB
241LIBOBJS+=i386-dis.o
242endif
243ifeq ($(findstring alpha, $(TARGET_ARCH) $(ARCH)),alpha)
244LIBOBJS+=alpha-dis.o
245endif
a2458627 246ifeq ($(findstring ppc, $(TARGET_BASE_ARCH) $(ARCH)),ppc)
626df76a
FB
247LIBOBJS+=ppc-dis.o
248endif
6af0bf9c
FB
249ifeq ($(findstring mips, $(TARGET_ARCH) $(ARCH)),mips)
250LIBOBJS+=mips-dis.o
251endif
64b3ab24 252ifeq ($(findstring sparc, $(TARGET_BASE_ARCH) $(ARCH)),sparc)
626df76a
FB
253LIBOBJS+=sparc-dis.o
254endif
255ifeq ($(findstring arm, $(TARGET_ARCH) $(ARCH)),arm)
256LIBOBJS+=arm-dis.o
257endif
48024e4a
FB
258ifeq ($(findstring m68k, $(TARGET_ARCH) $(ARCH)),m68k)
259LIBOBJS+=m68k-dis.o
260endif
fdf9b3e8
FB
261ifeq ($(findstring sh4, $(TARGET_ARCH) $(ARCH)),sh4)
262LIBOBJS+=sh4-dis.o
263endif
626df76a 264
1fddef4b
FB
265ifdef CONFIG_GDBSTUB
266OBJS+=gdbstub.o
267endif
626df76a 268
1e43adfc 269all: $(PROGS)
626df76a 270
1e43adfc 271$(QEMU_USER): $(OBJS)
626df76a
FB
272 $(CC) $(LDFLAGS) -o $@ $^ $(LIBS)
273ifeq ($(ARCH),alpha)
274# Mark as 32 bit binary, i. e. it will be mapped into the low 31 bit of
275# the address space (31 bit so sign extending doesn't matter)
276 echo -ne '\001\000\000\000' | dd of=qemu bs=1 seek=48 count=4 conv=notrunc
277endif
278
279# must use static linking to avoid leaving stuff in virtual address space
5fe141fd 280VL_OBJS=vl.o osdep.o block.o readline.o monitor.o pci.o console.o loader.o
de167e41 281VL_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
7fb843f8
FB
282ifdef CONFIG_WIN32
283VL_OBJS+=tap-win32.o
284endif
a541f297 285
1d14ffa9 286SOUND_HW = sb16.o es1370.o
7372f88d 287AUDIODRV = audio.o noaudio.o wavaudio.o
fb065187
FB
288ifdef CONFIG_SDL
289AUDIODRV += sdlaudio.o
290endif
291ifdef CONFIG_OSS
292AUDIODRV += ossaudio.o
293endif
1d14ffa9
FB
294ifdef CONFIG_COREAUDIO
295AUDIODRV += coreaudio.o
296endif
297ifdef CONFIG_ALSA
298AUDIODRV += alsaaudio.o
299LIBS += -lasound
300endif
301ifdef CONFIG_DSOUND
302AUDIODRV += dsoundaudio.o
303LIBS += -lole32 -ldxguid
85571bc7 304endif
102a52e4 305ifdef CONFIG_FMOD
85571bc7 306AUDIODRV += fmodaudio.o
102a52e4
FB
307audio.o fmodaudio.o: DEFINES := -I$(CONFIG_FMOD_INC) $(DEFINES)
308LIBS += $(CONFIG_FMOD_LIB)
85571bc7 309endif
1d14ffa9
FB
310ifdef CONFIG_ADLIB
311SOUND_HW += fmopl.o adlib.o
312endif
85571bc7 313
2e5d83bb 314# SCSI layer
7d8406be 315VL_OBJS+= scsi-disk.o cdrom.o lsi53c895a.o
2e5d83bb 316
a594cfbf 317# USB layer
2e5d83bb 318VL_OBJS+= usb.o usb-hub.o usb-linux.o usb-hid.o usb-ohci.o usb-msd.o
a594cfbf 319
a41b2ff2
PB
320# PCI network cards
321VL_OBJS+= ne2000.o rtl8139.o
322
0b0babc6 323ifeq ($(TARGET_BASE_ARCH), i386)
a541f297 324# Hardware support
a41b2ff2 325VL_OBJS+= ide.o pckbd.o ps2.o vga.o $(SOUND_HW) dma.o $(AUDIODRV)
fd06c375 326VL_OBJS+= fdc.o mc146818rtc.o serial.o i8259.o i8254.o pcspk.o pc.o
502a5395
PB
327VL_OBJS+= cirrus_vga.o mixeng.o apic.o parallel.o acpi.o piix_pci.o
328VL_OBJS+= usb-uhci.o
1d14ffa9 329DEFINES += -DHAS_AUDIO
67b915a5 330endif
a2458627 331ifeq ($(TARGET_BASE_ARCH), ppc)
a41b2ff2 332VL_OBJS+= ppc.o ide.o pckbd.o ps2.o vga.o $(SOUND_HW) dma.o $(AUDIODRV)
64201201 333VL_OBJS+= mc146818rtc.o serial.o i8259.o i8254.o fdc.o m48t59.o
e68b9b2b 334VL_OBJS+= ppc_prep.o ppc_chrp.o cuda.o adb.o openpic.o heathrow_pic.o mixeng.o
502a5395 335VL_OBJS+= grackle_pci.o prep_pci.o unin_pci.o
1d14ffa9 336DEFINES += -DHAS_AUDIO
a541f297 337endif
6af0bf9c 338ifeq ($(TARGET_ARCH), mips)
a41b2ff2 339VL_OBJS+= mips_r4k.o dma.o vga.o serial.o i8254.o i8259.o
697584ab 340#VL_OBJS+= #ide.o pckbd.o fdc.o m48t59.o
6af0bf9c 341endif
64b3ab24 342ifeq ($(TARGET_BASE_ARCH), sparc)
3475187d 343ifeq ($(TARGET_ARCH), sparc64)
502a5395 344VL_OBJS+= sun4u.o ide.o pckbd.o ps2.o vga.o apb_pci.o
83469015
FB
345VL_OBJS+= fdc.o mc146818rtc.o serial.o m48t59.o
346VL_OBJS+= cirrus_vga.o parallel.o
3475187d 347else
5fe141fd 348VL_OBJS+= sun4m.o tcx.o lance.o iommu.o m48t59.o slavio_intctl.o
819385c5 349VL_OBJS+= slavio_timer.o slavio_serial.o slavio_misc.o fdc.o esp.o
3475187d 350endif
e95c8d51 351endif
b5ff1b31 352ifeq ($(TARGET_BASE_ARCH), arm)
cdbdb648 353VL_OBJS+= integratorcp.o versatilepb.o ps2.o smc91c111.o arm_pic.o arm_timer.o
16406950 354VL_OBJS+= arm_boot.o pl011.o pl050.o pl080.o pl110.o pl190.o
502a5395 355VL_OBJS+= versatile_pci.o
b5ff1b31 356endif
fdf9b3e8
FB
357ifeq ($(TARGET_BASE_ARCH), sh4)
358VL_OBJS+= shix.o sh7750.o sh7750_regnames.o tc58128.o
359endif
a541f297
FB
360ifdef CONFIG_GDBSTUB
361VL_OBJS+=gdbstub.o
728c9fd5 362endif
626df76a
FB
363ifdef CONFIG_SDL
364VL_OBJS+=sdl.o
de5eaa64 365endif
24236869 366VL_OBJS+=vnc.o
5b0753e0
FB
367ifdef CONFIG_COCOA
368VL_OBJS+=cocoa.o
1d14ffa9
FB
369COCOA_LIBS=-F/System/Library/Frameworks -framework Cocoa -framework IOKit
370ifdef CONFIG_COREAUDIO
371COCOA_LIBS+=-framework CoreAudio
372endif
5b0753e0 373endif
7c1f25b4
FB
374ifdef CONFIG_SLIRP
375DEFINES+=-I$(SRC_PATH)/slirp
376SLIRP_OBJS=cksum.o if.o ip_icmp.o ip_input.o ip_output.o \
377slirp.o mbuf.o misc.o sbuf.o socket.o tcp_input.o tcp_output.o \
c7f74643 378tcp_subr.o tcp_timer.o udp.o bootp.o debug.o tftp.o
7c1f25b4 379VL_OBJS+=$(addprefix slirp/, $(SLIRP_OBJS))
626df76a
FB
380endif
381
c321f673
FB
382VL_LDFLAGS=
383# specific flags are needed for non soft mmu emulator
c321f673
FB
384ifdef CONFIG_STATIC
385VL_LDFLAGS+=-static
386endif
de5eaa64
FB
387ifndef CONFIG_SOFTMMU
388VL_LDFLAGS+=-Wl,-T,$(SRC_PATH)/i386-vl.ld
389endif
83fb7adf 390ifndef CONFIG_DARWIN
11d9f695 391ifndef CONFIG_WIN32
ec530c81 392ifndef CONFIG_SOLARIS
11d9f695
FB
393VL_LIBS=-lutil
394endif
83fb7adf 395endif
ec530c81 396endif
e3086fbf
FB
397ifdef TARGET_GPROF
398vl.o: CFLAGS+=-p
399VL_LDFLAGS+=-p
400endif
c321f673 401
b8076a74
FB
402ifeq ($(ARCH),ia64)
403VL_LDFLAGS+=-Wl,-G0 -Wl,-T,$(SRC_PATH)/ia64.ld
404endif
405
1d14ffa9
FB
406ifdef CONFIG_WIN32
407SDL_LIBS := $(filter-out -mwindows, $(SDL_LIBS)) -mconsole
408endif
409
1e43adfc 410$(QEMU_SYSTEM): $(VL_OBJS) libqemu.a
5b0753e0
FB
411 $(CC) $(VL_LDFLAGS) -o $@ $^ $(LIBS) $(SDL_LIBS) $(COCOA_LIBS) $(VL_LIBS)
412
413cocoa.o: cocoa.m
414 $(CC) $(CFLAGS) $(DEFINES) -c -o $@ $<
626df76a 415
3d11d0eb 416sdl.o: sdl.c keymaps.c sdl_keysym.h
626df76a
FB
417 $(CC) $(CFLAGS) $(DEFINES) $(SDL_CFLAGS) -c -o $@ $<
418
24236869
FB
419vnc.o: vnc.c keymaps.c sdl_keysym.h vnchextile.h
420 $(CC) $(CFLAGS) $(DEFINES) -c -o $@ $<
421
9f059eca
FB
422sdlaudio.o: sdlaudio.c
423 $(CC) $(CFLAGS) $(DEFINES) $(SDL_CFLAGS) -c -o $@ $<
424
626df76a 425depend: $(SRCS)
16e9b7de 426 $(CC) -MM $(CFLAGS) $(DEFINES) $^ 1>.depend
626df76a 427
1d14ffa9
FB
428vldepend: $(VL_OBJS:.o=.c)
429 $(CC) -MM $(CFLAGS) $(DEFINES) $^ 1>.depend
430
626df76a
FB
431# libqemu
432
433libqemu.a: $(LIBOBJS)
434 rm -f $@
435 $(AR) rcs $@ $(LIBOBJS)
436
1e43adfc 437translate.o: translate.c gen-op.h opc.h cpu.h
626df76a 438
158142c2
FB
439translate-all.o: translate-all.c opc.h cpu.h
440
441translate-op.o: translate-all.c op.h opc.h cpu.h
626df76a 442
1e43adfc 443op.h: op.o $(DYNGEN)
626df76a
FB
444 $(DYNGEN) -o $@ $<
445
1e43adfc 446opc.h: op.o $(DYNGEN)
626df76a
FB
447 $(DYNGEN) -c -o $@ $<
448
1e43adfc 449gen-op.h: op.o $(DYNGEN)
626df76a
FB
450 $(DYNGEN) -g -o $@ $<
451
1e43adfc 452op.o: op.c
626df76a
FB
453 $(CC) $(OP_CFLAGS) $(DEFINES) -c -o $@ $<
454
1e43adfc 455helper.o: helper.c
626df76a
FB
456 $(CC) $(HELPER_CFLAGS) $(DEFINES) -c -o $@ $<
457
0b0babc6 458ifeq ($(TARGET_BASE_ARCH), i386)
664e0f19 459op.o: op.c opreg_template.h ops_template.h ops_template_mem.h ops_mem.h ops_sse.h
1e43adfc
FB
460endif
461
462ifeq ($(TARGET_ARCH), arm)
463op.o: op.c op_template.h
bdd5003a 464pl110.o: pl110_template.h
1e43adfc 465endif
626df76a 466
64b3ab24 467ifeq ($(TARGET_BASE_ARCH), sparc)
3475187d
FB
468op.o: op.c op_template.h op_mem.h fop_template.h fbranch_template.h
469magic_load.o: elf_op.h
1e43adfc 470endif
626df76a 471
a2458627 472ifeq ($(TARGET_BASE_ARCH), ppc)
728c9fd5
FB
473op.o: op.c op_template.h op_mem.h
474op_helper.o: op_helper_mem.h
3fc6c082 475translate.o: translate.c translate_init.c
728c9fd5
FB
476endif
477
6af0bf9c
FB
478ifeq ($(TARGET_ARCH), mips)
479op.o: op.c op_template.c op_mem.c
480op_helper.o: op_helper_mem.c
481endif
482
5fe141fd
FB
483loader.o: loader.c elf_ops.h
484
6515b203
FB
485acpi.o: acpi.c acpi-dsdt.hex
486
487#$(SRC_PATH)/hw/acpi-dsdt.hex: acpi-dsdt.dsl
488# iasl -tc -p $@ $<
489
fdf9b3e8
FB
490ifeq ($(TARGET_ARCH), sh4)
491op.o: op.c op_mem.c cpu.h
492op_helper.o: op_helper.c exec.h cpu.h
493helper.o: helper.c exec.h cpu.h
27c7ca7e
FB
494sh7750.o: sh7750.c sh7750_regs.h sh7750_regnames.h cpu.h
495shix.o: shix.c sh7750_regs.h sh7750_regnames.h
fdf9b3e8 496sh7750_regnames.o: sh7750_regnames.c sh7750_regnames.h sh7750_regs.h
27c7ca7e 497tc58128.o: tc58128.c
fdf9b3e8
FB
498endif
499
214feb51
PB
500$(OBJS) $(LIBOBJS) $(VL_OBJS): config.h ../config-host.h
501
626df76a
FB
502%.o: %.c
503 $(CC) $(CFLAGS) $(DEFINES) -c -o $@ $<
504
f72b519c
FB
505%.o: %.S
506 $(CC) $(DEFINES) -c -o $@ $<
507
626df76a 508clean:
e362b55a 509 rm -f *.o *.a *~ $(PROGS) gen-op.h opc.h op.h nwfpe/*.o slirp/*.o fpu/*.o
1e43adfc
FB
510
511install: all
9b14bb04 512ifneq ($(PROGS),)
6a882643 513 $(INSTALL) -m 755 -s $(PROGS) "$(DESTDIR)$(bindir)"
9b14bb04 514endif
626df76a
FB
515
516ifneq ($(wildcard .depend),)
517include .depend
518endif
1d14ffa9 519
c0fe3827 520ifeq (1, 0)
1d14ffa9 521audio.o sdlaudio.o dsoundaudio.o ossaudio.o wavaudio.o noaudio.o \
c0fe3827 522fmodaudio.o alsaaudio.o mixeng.o sb16.o es1370.o gus.o adlib.o: \
1d14ffa9
FB
523CFLAGS := $(CFLAGS) -Wall -Werror -W -Wsign-compare
524endif