X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=Makefile;h=2def78fcb6fd20853c1477332e4e27411b241e8b;hb=b3daf517e2885a7caef8d6c3f78c9c7cef4d4fae;hp=f656b00c7c8e360aa728430a4f92e5a72cdcaf62;hpb=d5300df11f3cfe160b1a3c00187c041d4bdeb9a1;p=vlc diff --git a/Makefile b/Makefile index f656b00c7c..2def78fcb6 100644 --- a/Makefile +++ b/Makefile @@ -1,3 +1,5 @@ +# Generated automatically from Makefile.in by configure. +# Generated automatically from Makefile.in by configure. ################################################################################ # vlc (VideoLAN Client) main makefile # (c)1998 VideoLAN @@ -5,24 +7,65 @@ # This makefile is the main makefile for the VideoLAN client. ################################################################################ +CC = egcc + ################################################################################ # Configuration ################################################################################ -# Environment -#CC = gcc -#SHELL = /bin/sh +# Audio output settings +AOUT = dsp +#AOUT += esd +# Not yet supported +#AOUT += alsa +# Fallback method that should always work +AOUT += dummy # Video output settings -VIDEO=X11 -#VIDEO=DGA -#VIDEO=FB -#VIDEO=BEOS - -# Target architecture and optimization -#ARCH= -ARCH=MMX +VOUT = x11 +#VOUT += fb +#VOUT += ggi +#VOUT += glide +# Not yet supported +#VOUT = beos +#VOUT += dga +# Fallback method that should always work +VOUT += dummy + +# Interface settings +INTF = x11 +#INTF += fb +#INTF += ggi +#INTF += glide +# Not yet supported +#INTF = beos +#INTF += dga +# Fallback method that should always work +INTF += dummy + +# Target architecture +ARCH=X86 #ARCH=PPC +#ARCH=SPARC + +# Target operating system +SYS=LINUX +#SYS=GNU +#SYS=BSD +#SYS=BEOS + +# For x86 architecture, choose MMX support +ARCH += MMX +# For x86 architecture, optimize for Pentium Pro +# (choose NO if you get `Invalid instruction' errors) +ARCH += PPRO + +# Decoder choice - ?? old decoder will be removed soon +#DECODER=old +DECODER=new + +# Debugging mode on or off (set to 1 to activate) +DEBUG=0 #----------------- do not change anything below this line ---------------------- @@ -30,45 +73,64 @@ ARCH=MMX # Configuration pre-processing ################################################################################ -# DEFINE will contain all the constants definitions decided in Makefile -DEFINE = -DVIDEO_$(VIDEO) +# PROGRAM_OPTIONS is an identification string of the compilation options +PROGRAM_OPTIONS = $(SYS) $(ARCH) +ifeq ($(DEBUG),1) +PROGRAM_OPTIONS += DEBUG +endif -# video is a lowercase version of VIDEO used for filenames -video = $(shell echo $(VIDEO) | tr 'A-Z' 'a-z') +# PROGRAM_BUILD is a complete identification of the build +# ( we can't use fancy options with date since OSes like Solaris +# or FreeBSD have strange date implementations ) +PROGRAM_BUILD = `date` $(USER) +# XXX: beos does not support hostname +#PROGRAM_BUILD = `date` $(USER)@`hostname` + +# DEFINE will contain some of the constants definitions decided in Makefile, +# including ARCH_xx and SYS_xx. It will be passed to C compiler. +DEFINE += -DARCH_$(shell echo $(ARCH) | cut -f1 -d' ') +DEFINE += -DSYS_$(SYS) +DEFINE += -DPLUGIN_PATH="\"$(PREFIX)/lib/videolan/vlc\"" +DEFINE += -DPROGRAM_VERSION="\"0.1.99\"" +DEFINE += -DPROGRAM_CODENAME="\"Onatopp\"" +#DEFINE += -DPROGRAM_OPTIONS="\"$(shell echo $(PROGRAM_OPTIONS) | tr 'A-Z' 'a-z')\"" +#DEFINE += -DPROGRAM_BUILD="\"$(PROGRAM_BUILD)\"" +ifeq ($(DEBUG),1) +DEFINE += -DDEBUG +endif ################################################################################ -# Tunning and other variables +# Tuning and other variables - do not change anything except if you know +# exactly what you are doing ################################################################################ # -# Transformation for video decompression (Fourier or cosine) +# C headers directories # -TRANSFORM=vdec_idct -#TRANSFORM=vdec_idft +INCLUDE += -Iinclude -I/usr/local/include -I/usr/X11R6/include # -# C headers directories +# Libraries # -INCLUDE += -Iinclude -ifeq ($(VIDEO),X11) -INCLUDE += -I/usr/X11R6/include/X11 +ifeq ($(SYS),GNU) +LIB += -lthreads -ldl endif -# -# Libraries -# -LIB += -lpthread +ifeq ($(SYS),BSD) +LIB += -pthread -lgnugetopt +LIB += -L/usr/local/lib +endif + +ifeq ($(SYS),LINUX) +LIB += -lpthread -ldl +endif -ifeq ($(VIDEO),X11) -LIB += -L/usr/X11R6/lib -LIB += -lX11 -LIB += -lXext -LIB += -lXpm +ifeq ($SYS),BEOS) +LIB += -llibroot -llibgame -llibbe endif -# System dependant libraries -#??LIB += -lXxf86dga +LIB += -lm # # C compiler flags: compilation @@ -82,26 +144,33 @@ CCFLAGS += -D_GNU_SOURCE CCFLAGS += -O6 CCFLAGS += -ffast-math -funroll-loops -fargument-noalias-global CCFLAGS += -fomit-frame-pointer -#CCFLAGS += -fomit-frame-pointer -s -# Optimizations for x86 familiy, without MMX -ifeq ($(ARCH),) +# Optimizations for x86 familiy +ifneq (,$(findstring X86,$(ARCH))) CCFLAGS += -malign-double -CCFLAGS += -march=pentiumpro #CCFLAGS += -march=pentium -endif - -# Optimization for x86 with MMX support -ifeq ($(ARCH),MMX) -CCFLAGS += -malign-double +# Eventual Pentium Pro optimizations +ifneq (,$(findstring PPRO,$(ARCH))) +ifneq ($(SYS), BSD) CCFLAGS += -march=pentiumpro endif +endif +# Eventual MMX optimizations for x86 +ifneq (,$(findstring MMX,$(ARCH))) +CFLAGS += -DHAVE_MMX +endif +endif # Optimizations for PowerPC -ifeq ($(ARCH),PPC) +ifneq (,$(findstring PPC,$(ARCH))) CCFLAGS += -mcpu=604e -mmultiple -mhard-float -mstring endif +# Optimizations for Sparc +ifneq (,$(findstring SPARC,$(ARCH))) +CCFLAGS += -mhard-float +endif + # # C compiler flags: dependancies # @@ -116,41 +185,28 @@ LCFLAGS += -Wall #LCFLAGS += -s # -# C compiler flags: common flags +# Additionnal debugging flags # -# Optimizations for x86 with MMX support -ifeq ($(ARCH),MMX) -CFLAGS += -DHAVE_MMX +# Debugging support +ifeq ($(DEBUG),1) +CFLAGS += -g +#CFLAGS += -pg endif -# -# Additionnal debugging flags -# -# Debugging settings: electric fence, debuging symbols and profiling support. -# Note that electric fence and accurate profiling are quite uncompatible. -#CCFLAGS += -g -#CCFLAGS += -pg -#LCFLAGS += -g -#LCFLAGS += -pg -#LIB += -ldmalloc -#LIB += -lefence - ################################################################################# # Objects and files ################################################################################# # -# Objects +# C Objects # interface_obj = interface/main.o \ interface/interface.o \ interface/intf_msg.o \ interface/intf_cmd.o \ interface/intf_ctrl.o \ - interface/control.o \ - interface/intf_console.o \ - interface/intf_$(video).o + interface/intf_console.o input_obj = input/input_vlan.o \ input/input_file.o \ @@ -161,18 +217,33 @@ input_obj = input/input_vlan.o \ input/input_psi.o \ input/input.o -audio_output_obj = audio_output/audio_output.o \ - audio_output/audio_dsp.o +audio_output_obj = audio_output/audio_output.o video_output_obj = video_output/video_output.o \ - video_output/video_$(video).o - -audio_decoder_obj = audio_decoder/audio_decoder.o \ + video_output/video_text.o \ + video_output/video_yuv.o + +ac3_decoder_obj = ac3_decoder/ac3_decoder_thread.o \ + ac3_decoder/ac3_decoder.o \ + ac3_decoder/ac3_parse.o \ + ac3_decoder/ac3_exponent.o \ + ac3_decoder/ac3_bit_allocate.o \ + ac3_decoder/ac3_mantissa.o \ + ac3_decoder/ac3_rematrix.o \ + ac3_decoder/ac3_imdct.o \ + ac3_decoder/ac3_downmix.o + +audio_decoder_obj = audio_decoder/audio_decoder_thread.o \ + audio_decoder/audio_decoder.o \ audio_decoder/audio_math.o +spu_decoder_obj = spu_decoder/spu_decoder.o + #??generic_decoder_obj = generic_decoder/generic_decoder.o # remeber to add it to OBJ +ifeq ($(DECODER),old) +CFLAGS += -DOLD_DECODER video_decoder_obj = video_decoder_ref/video_decoder.o \ video_decoder_ref/display.o \ video_decoder_ref/getblk.o \ @@ -183,49 +254,70 @@ video_decoder_obj = video_decoder_ref/video_decoder.o \ video_decoder_ref/motion.o \ video_decoder_ref/mpeg2dec.o \ video_decoder_ref/recon.o \ - video_decoder_ref/spatscal.o -# video_decoder_ref/$(TRANSFORM).o - -#video_parser_obj = video_parser/video_parser.o \ -# video_parser/vpar_headers.o \ -# video_parser/vpar_blocks.o \ -# video_parser/vpar_motion.o \ -# video_parser/vpar_synchro.o \ -# video_parser/video_fifo.o - -#video_decoder_obj = video_decoder/video_decoder.o \ -# video_decoder/vdec_idct.o \ -# video_decoder/vdec_motion.o + video_decoder_ref/spatscal.o +else +video_parser_obj = video_parser/video_parser.o \ + video_parser/vpar_headers.o \ + video_parser/vpar_blocks.o \ + video_parser/vpar_synchro.o \ + video_parser/video_fifo.o + +video_decoder_obj = video_decoder/video_decoder.o \ + video_decoder/vdec_motion.o \ + video_decoder/vdec_motion_inner.o \ + video_decoder/vdec_idct.o +endif misc_obj = misc/mtime.o \ misc/rsc_files.o \ - misc/netutils.o - -ifeq ($(VIDEO),X11) -misc_obj+= misc/xutils.o -endif - -ifeq ($(ARCH),MMX) -ASM_OBJ = video_decoder_ref/idctmmx.o \ - video_decoder_ref/yuv12-rgb16.o -endif + misc/netutils.o \ + misc/plugins.o \ + misc/decoder_fifo.o C_OBJ = $(interface_obj) \ $(input_obj) \ $(audio_output_obj) \ $(video_output_obj) \ + $(ac3_decoder_obj) \ $(audio_decoder_obj) \ + $(spu_decoder_obj) \ $(generic_decoder_obj) \ $(video_parser_obj) \ $(video_decoder_obj) \ $(vlan_obj) \ $(misc_obj) +# +# Assembler Objects +# +ifneq (,$(findstring X86,$(ARCH))) +ifneq (,$(findstring MMX,$(ARCH))) +ifeq ($(DECODER),new) +ASM_OBJ = video_decoder/vdec_idctmmx.o \ + video_output/video_yuv_mmx.o +else +ASM_OBJ = video_decoder_ref/vdec_idctmmx.o \ + video_output/video_yuv_mmx.o +endif +endif +endif + +# +# Plugins +# +intf_plugin = $(INTF:%=plugins/intf/intf_%.so) +aout_plugin = $(AOUT:%=plugins/aout/aout_%.so) +vout_plugin = $(VOUT:%=plugins/vout/vout_%.so) + +PLUGIN_OBJ = $(intf_plugin) $(aout_plugin) $(vout_plugin) + # # Other lists of files # -sources := $(C_OBJ:%.o=%.c) -dependancies := $(sources:%.c=dep/%.d) +C_OBJ := $(C_OBJ:%.o=src/%.o) +ASM_OBJ := $(ASM_OBJ:%.o=src/%.o) +sources := $(C_OBJ:%.o=%.c) $(PLUGIN_OBJ:%.so=%.c) +dependancies := $(sources:%.c=.dep/%.d) # All symbols must be exported export @@ -240,48 +332,108 @@ export all: vlc clean: - rm -f $(C_OBJ) $(ASM_OBJ) + rm -f $(C_OBJ) $(ASM_OBJ) $(PLUGIN_OBJ) distclean: clean - rm -f **/*.o **/*~ *.log + rm -f **/*.o **/*.so **/*~ *.log + rm -f Makefile include/defs.h config.cache config.log rm -f vlc gmon.out core - rm -rf dep + rm -rf .dep + +install: + $(INSTALL) vlc $(PREFIX)/bin + mkdir -p $(PREFIX)/lib/videolan/vlc + $(INSTALL) $(PLUGIN_OBJ) $(PREFIX)/lib/videolan/vlc + +show: + @echo "Command line for C objects:" + @echo $(CC) $(CCFLAGS) $(CFLAGS) -c -o "" "" + @echo + @echo "Command line for assembler objects:" + @echo $(CC) $(CFLAGS) -c -o "" "" FORCE: # # Real targets # -vlc: $(C_OBJ) $(ASM_OBJ) - $(CC) $(LCFLAGS) $(CFLAGS) -o $@ $(C_OBJ) $(ASM_OBJ) +vlc: $(C_OBJ) $(ASM_OBJ) $(PLUGIN_OBJ) + $(CC) $(CCFLAGS) $(LCFLAGS) $(CFLAGS) --export-dynamic -rdynamic -o $@ $(C_OBJ) $(ASM_OBJ) # # Generic rules (see below) # $(dependancies): %.d: FORCE - @make -s --no-print-directory -f Makefile.dep $@ - -$(C_OBJ): %.o: dep/%.d + @$(MAKE) -s --no-print-directory -f Makefile.dep $@ +$(C_OBJ): %.o: Makefile.dep +$(C_OBJ): %.o: .dep/%.d $(C_OBJ): %.o: %.c - $(CC) $(CCFLAGS) $(CFLAGS) -c -o $@ $< + @echo "compiling $*.o from $*.c" + @$(CC) $(CCFLAGS) $(CFLAGS) -c -o $@ $< + +$(ASM_OBJ): %.o: Makefile.dep $(ASM_OBJ): %.o: %.S - $(CC) $(CFLAGS) -c -o $@ $< + @echo "assembling $*.o from $*.S" + @$(CC) $(CFLAGS) -c -o $@ $< + +$(PLUGIN_OBJ): %.so: Makefile.dep +$(PLUGIN_OBJ): %.so: .dep/%.d + +# audio plugins +plugins/aout/aout_dummy.so plugins/aout/aout_dsp.so: %.so: %.c + @echo "compiling $*.so from $*.c" +ifeq ($(SYS), BEOS) + @$(CC) $(CCFLAGS) $(CFLAGS) -nostart -o $@ $< +else + @$(CC) $(CCFLAGS) $(CFLAGS) -shared -o $@ $< +endif + +plugins/aout/aout_esd.so: %.so: %.c + @echo "compiling $*.so from $*.c" +ifeq ($(SYS), BSD) + @$(CC) $(CCFLAGS) $(CFLAGS) -lesd -shared -o $@ $< +else + @$(CC) $(CCFLAGS) $(CFLAGS) -laudiofile -lesd -shared -o $@ $< +endif + +# video plugins +plugins/intf/intf_dummy.so plugins/vout/vout_dummy.so \ + plugins/intf/intf_fb.so plugins/vout/vout_fb.so: %.so: %.c + @echo "compiling $*.so from $*.c" +ifeq ($(SYS), BEOS) + @$(CC) $(CCFLAGS) $(CFLAGS) -nostart -o $@ $< +else + @$(CC) $(CCFLAGS) $(CFLAGS) -shared -o $@ $< +endif + +plugins/intf/intf_x11.so plugins/vout/vout_x11.so: %.so: %.c + @echo "compiling $*.so from $*.c" + @$(CC) $(CCFLAGS) $(CFLAGS) -I/usr/X11R6/include -L/usr/X11R6/lib -lX11 -lXext -shared -o $@ $< + +plugins/intf/intf_glide.so plugins/vout/vout_glide.so: %.so: %.c + @echo "compiling $*.so from $*.c" + @$(CC) $(CCFLAGS) $(CFLAGS) -I/usr/include/glide -lglide2x -shared -o $@ $< + +plugins/intf/intf_ggi.so plugins/vout/vout_ggi.so: %.so: %.c + @echo "compiling $*.so from $*.c" + @$(CC) $(CCFLAGS) $(CFLAGS) -lggi -shared -o $@ $< + ################################################################################ # Note on generic rules and dependancies ################################################################################ # Note on dependancies: each .c file is associated with a .d file, which -# depends of it. The .o file associated with a .c file depends of the .d, of the -# .c itself, and of Makefile. The .d files are stored in a separate dep/ +# depends of it. The .o file associated with a .c file depends of the .d, of the +# .c itself, and of Makefile. The .d files are stored in a separate .dep/ # directory. # The dep directory should be ignored by CVS. -# Note on inclusions: depending of the target, the dependancies files must +# Note on inclusions: depending of the target, the dependancies files must # or must not be included. The problem is that if we ask make to include a file, -# and this file does not exist, it is made before it can be included. In a -# general way, a .d file should be included if and only if the corresponding .o +# and this file does not exist, it is made before it can be included. In a +# general way, a .d file should be included if and only if the corresponding .o # needs to be re-made. # Two makefiles are used: the main one (this one) has regular generic rules,