X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=Makefile;h=d0b16338e5c25ca99d70071304c8465e4d9fa4e1;hb=df51d8efa8ce9afcedda64acc69c1dba2648716d;hp=98378215374a771d65fc1c359bba1abcf7f7a700;hpb=81cada8effc3e91eec3f413772b3c1629e8beb4d;p=x264 diff --git a/Makefile b/Makefile index 98378215..d0b16338 100644 --- a/Makefile +++ b/Makefile @@ -2,82 +2,111 @@ include config.mak +vpath %.c $(SRCPATH) +vpath %.h $(SRCPATH) +vpath %.S $(SRCPATH) +vpath %.asm $(SRCPATH) +vpath %.rc $(SRCPATH) + +GENERATED = + all: default +default: SRCS = common/mc.c common/predict.c common/pixel.c common/macroblock.c \ common/frame.c common/dct.c common/cpu.c common/cabac.c \ - common/common.c common/mdate.c common/rectangle.c \ + common/common.c common/osdep.c common/rectangle.c \ common/set.c common/quant.c common/deblock.c common/vlc.c \ common/mvpred.c common/bitstream.c \ encoder/analyse.c encoder/me.c encoder/ratecontrol.c \ encoder/set.c encoder/macroblock.c encoder/cabac.c \ encoder/cavlc.c encoder/encoder.c encoder/lookahead.c -SRCCLI = x264.c input/timecode.c \ - input/yuv.c input/y4m.c output/raw.c \ - output/matroska.c output/matroska_ebml.c \ - output/flv.c output/flv_bytestream.c +SRCCLI = x264.c input/input.c input/timecode.c input/raw.c input/y4m.c \ + output/raw.c output/matroska.c output/matroska_ebml.c \ + output/flv.c output/flv_bytestream.c filters/filters.c \ + filters/video/video.c filters/video/source.c filters/video/internal.c \ + filters/video/resize.c filters/video/cache.c filters/video/fix_vfr_pts.c \ + filters/video/select_every.c filters/video/crop.c filters/video/depth.c SRCSO = +OBJS = +OBJSO = +OBJCLI = + +OBJCHK = tools/checkasm.o + +OBJEXAMPLE = example.o CONFIG := $(shell cat config.h) +# GPL-only files +ifneq ($(findstring HAVE_GPL 1, $(CONFIG)),) +SRCCLI += +endif + # Optional module sources -ifneq ($(findstring HAVE_AVS, $(CONFIG)),) +ifneq ($(findstring HAVE_AVS 1, $(CONFIG)),) SRCCLI += input/avs.c endif -ifneq ($(findstring HAVE_PTHREAD, $(CONFIG)),) +ifneq ($(findstring HAVE_THREAD 1, $(CONFIG)),) SRCCLI += input/thread.c SRCS += common/threadpool.c endif -ifneq ($(findstring HAVE_LAVF, $(CONFIG)),) +ifneq ($(findstring HAVE_WIN32THREAD 1, $(CONFIG)),) +SRCS += common/win32thread.c +endif + +ifneq ($(findstring HAVE_LAVF 1, $(CONFIG)),) SRCCLI += input/lavf.c endif -ifneq ($(findstring HAVE_FFMS, $(CONFIG)),) +ifneq ($(findstring HAVE_FFMS 1, $(CONFIG)),) SRCCLI += input/ffms.c endif -ifneq ($(findstring HAVE_GPAC, $(CONFIG)),) +ifneq ($(findstring HAVE_GPAC 1, $(CONFIG)),) SRCCLI += output/mp4.c endif -# Visualization sources -ifeq ($(VIS),yes) -SRCS += common/visualize.c common/display-x11.c +ifneq ($(findstring HAVE_LSMASH 1, $(CONFIG)),) +SRCCLI += output/mp4_lsmash.c endif # MMX/SSE optims ifneq ($(AS),) X86SRC0 = const-a.asm cabac-a.asm dct-a.asm deblock-a.asm mc-a.asm \ - mc-a2.asm pixel-a.asm predict-a.asm quant-a.asm sad-a.asm \ + mc-a2.asm pixel-a.asm predict-a.asm quant-a.asm \ cpu-a.asm dct-32.asm bitstream-a.asm +ifneq ($(findstring HIGH_BIT_DEPTH, $(CONFIG)),) +X86SRC0 += sad16-a.asm +else +X86SRC0 += sad-a.asm +endif X86SRC = $(X86SRC0:%=common/x86/%) -ifeq ($(ARCH),X86) +ifeq ($(SYS_ARCH),X86) ARCH_X86 = yes ASMSRC = $(X86SRC) common/x86/pixel-32.asm endif -ifeq ($(ARCH),X86_64) +ifeq ($(SYS_ARCH),X86_64) ARCH_X86 = yes -ASMSRC = $(X86SRC:-32.asm=-64.asm) -ASFLAGS += -DARCH_X86_64 +ASMSRC = $(X86SRC:-32.asm=-64.asm) common/x86/trellis-64.asm endif ifdef ARCH_X86 -ASFLAGS += -Icommon/x86/ SRCS += common/x86/mc-c.c common/x86/predict-c.c OBJASM = $(ASMSRC:%.asm=%.o) $(OBJASM): common/x86/x86inc.asm common/x86/x86util.asm -checkasm: tools/checkasm-a.o +OBJCHK += tools/checkasm-a.o endif endif # AltiVec optims -ifeq ($(ARCH),PPC) +ifeq ($(SYS_ARCH),PPC) ifneq ($(AS),) SRCS += common/ppc/mc.c common/ppc/pixel.c common/ppc/dct.c \ common/ppc/quant.c common/ppc/deblock.c \ @@ -86,65 +115,122 @@ endif endif # NEON optims -ifeq ($(ARCH),ARM) +ifeq ($(SYS_ARCH),ARM) ifneq ($(AS),) ASMSRC += common/arm/cpu-a.S common/arm/pixel-a.S common/arm/mc-a.S \ common/arm/dct-a.S common/arm/quant-a.S common/arm/deblock-a.S \ - common/arm/predict-a.S + common/arm/predict-a.S common/arm/bitstream-a.S SRCS += common/arm/mc-c.c common/arm/predict-c.c OBJASM = $(ASMSRC:%.S=%.o) +OBJCHK += tools/checkasm-arm.o endif endif -# VIS optims -ifeq ($(ARCH),UltraSparc) -ASMSRC += common/sparc/pixel.asm -OBJASM = $(ASMSRC:%.asm=%.o) +# AArch64 NEON optims +ifeq ($(SYS_ARCH),AARCH64) +ifneq ($(AS),) +ASMSRC += common/aarch64/bitstream-a.S \ + common/aarch64/cabac-a.S \ + common/aarch64/dct-a.S \ + common/aarch64/deblock-a.S \ + common/aarch64/mc-a.S \ + common/aarch64/pixel-a.S \ + common/aarch64/predict-a.S \ + common/aarch64/quant-a.S +SRCS += common/aarch64/asm-offsets.c \ + common/aarch64/mc-c.c \ + common/aarch64/predict-c.c +OBJASM = $(ASMSRC:%.S=%.o) +OBJCHK += tools/checkasm-aarch64.o +endif +endif + +# MSA optims +ifeq ($(SYS_ARCH),MIPS) +ifneq ($(findstring HAVE_MSA 1, $(CONFIG)),) +SRCS += common/mips/mc-c.c common/mips/dct-c.c \ + common/mips/deblock-c.c common/mips/pixel-c.c \ + common/mips/predict-c.c common/mips/quant-c.c +endif endif ifneq ($(HAVE_GETOPT_LONG),1) SRCCLI += extras/getopt.c endif +ifeq ($(SYS),WINDOWS) +OBJCLI += $(if $(RC), x264res.o) ifneq ($(SONAME),) -ifeq ($(SYS),MINGW) -SRCSO += x264dll.c +SRCSO += x264dll.c +OBJSO += $(if $(RC), x264res.dll.o) endif endif -OBJS = $(SRCS:%.c=%.o) -OBJCLI = $(SRCCLI:%.c=%.o) -OBJSO = $(SRCSO:%.c=%.o) -DEP = depend +ifeq ($(HAVE_OPENCL),yes) +common/oclobj.h: common/opencl/x264-cl.h $(wildcard $(SRCPATH)/common/opencl/*.cl) + cat $^ | $(SRCPATH)/tools/cltostr.sh $@ +GENERATED += common/oclobj.h +SRCS += common/opencl.c encoder/slicetype-cl.c +endif -.PHONY: all default fprofiled clean distclean install uninstall dox test testclean +OBJS += $(SRCS:%.c=%.o) +OBJCLI += $(SRCCLI:%.c=%.o) +OBJSO += $(SRCSO:%.c=%.o) -default: $(DEP) x264$(EXE) +.PHONY: all default fprofiled clean distclean install install-* uninstall cli lib-* etags -libx264.a: .depend $(OBJS) $(OBJASM) - $(AR) rc libx264.a $(OBJS) $(OBJASM) - $(RANLIB) libx264.a +cli: x264$(EXE) +lib-static: $(LIBX264) +lib-shared: $(SONAME) -$(SONAME): .depend $(OBJS) $(OBJASM) $(OBJSO) - $(CC) -shared -o $@ $(OBJS) $(OBJASM) $(OBJSO) $(SOFLAGS) $(LDFLAGS) +$(LIBX264): $(GENERATED) .depend $(OBJS) $(OBJASM) + rm -f $(LIBX264) + $(AR)$@ $(OBJS) $(OBJASM) + $(if $(RANLIB), $(RANLIB) $@) -x264$(EXE): $(OBJCLI) libx264.a - $(CC) -o $@ $+ $(LDFLAGS) $(LDFLAGSCLI) +$(SONAME): $(GENERATED) .depend $(OBJS) $(OBJASM) $(OBJSO) + $(LD)$@ $(OBJS) $(OBJASM) $(OBJSO) $(SOFLAGS) $(LDFLAGS) + +ifneq ($(EXE),) +.PHONY: x264 checkasm example +x264: x264$(EXE) +checkasm: checkasm$(EXE) +example: example$(EXE) +endif -checkasm: tools/checkasm.o libx264.a - $(CC) -o $@ $+ $(LDFLAGS) +x264$(EXE): $(GENERATED) .depend $(OBJCLI) $(CLI_LIBX264) + $(LD)$@ $(OBJCLI) $(CLI_LIBX264) $(LDFLAGSCLI) $(LDFLAGS) -%.o: %.asm +checkasm$(EXE): $(GENERATED) .depend $(OBJCHK) $(LIBX264) + $(LD)$@ $(OBJCHK) $(LIBX264) $(LDFLAGS) + +example$(EXE): $(GENERATED) .depend $(OBJEXAMPLE) $(LIBX264) + $(LD)$@ $(OBJEXAMPLE) $(LIBX264) $(LDFLAGS) + +$(OBJS) $(OBJASM) $(OBJSO) $(OBJCLI) $(OBJCHK) $(OBJEXAMPLE): .depend + +%.o: %.asm common/x86/x86inc.asm common/x86/x86util.asm $(AS) $(ASFLAGS) -o $@ $< - -@ $(STRIP) -x $@ # delete local/anonymous symbols, so they don't show up in oprofile + -@ $(if $(STRIP), $(STRIP) -x $@) # delete local/anonymous symbols, so they don't show up in oprofile %.o: %.S $(AS) $(ASFLAGS) -o $@ $< - -@ $(STRIP) -x $@ # delete local/anonymous symbols, so they don't show up in oprofile + -@ $(if $(STRIP), $(STRIP) -x $@) # delete local/anonymous symbols, so they don't show up in oprofile + +%.dll.o: %.rc x264.h + $(RC) $(RCFLAGS)$@ -DDLL $< + +%.o: %.rc x264.h + $(RC) $(RCFLAGS)$@ $< .depend: config.mak @rm -f .depend - @$(foreach SRC, $(SRCS) $(SRCCLI) $(SRCSO), $(CC) $(CFLAGS) $(SRC) -MT $(SRC:%.c=%.o) -MM -g0 1>> .depend;) + @echo 'dependency file generation...' +ifeq ($(COMPILER),CL) + @$(foreach SRC, $(addprefix $(SRCPATH)/, $(SRCS) $(SRCCLI) $(SRCSO)), $(SRCPATH)/tools/msvsdepend.sh "$(CC)" "$(CFLAGS)" "$(SRC)" "$(SRC:$(SRCPATH)/%.c=%.o)" 1>> .depend;) +else + @$(foreach SRC, $(addprefix $(SRCPATH)/, $(SRCS) $(SRCCLI) $(SRCSO)), $(CC) $(CFLAGS) $(SRC) $(DEPMT) $(SRC:$(SRCPATH)/%.c=%.o) $(DEPMM) 1>> .depend;) +endif config.mak: ./configure @@ -173,68 +259,63 @@ fprofiled: else fprofiled: $(MAKE) clean - mv config.mak config.mak2 - sed -e 's/CFLAGS.*/& -fprofile-generate/; s/LDFLAGS.*/& -fprofile-generate/' config.mak2 > config.mak - $(MAKE) x264$(EXE) + $(MAKE) x264$(EXE) CFLAGS="$(CFLAGS) $(PROF_GEN_CC)" LDFLAGS="$(LDFLAGS) $(PROF_GEN_LD)" $(foreach V, $(VIDS), $(foreach I, 0 1 2 3 4 5 6 7, ./x264$(EXE) $(OPT$I) --threads 1 $(V) -o $(DEVNULL) ;)) +ifeq ($(COMPILER),CL) +# Because Visual Studio timestamps the object files within the PGD, it fails to build if they change - only the executable should be deleted + rm -f x264$(EXE) +else rm -f $(SRC2:%.c=%.o) - sed -e 's/CFLAGS.*/& -fprofile-use/; s/LDFLAGS.*/& -fprofile-use/' config.mak2 > config.mak - $(MAKE) - rm -f $(SRC2:%.c=%.gcda) $(SRC2:%.c=%.gcno) - mv config.mak2 config.mak +endif + $(MAKE) CFLAGS="$(CFLAGS) $(PROF_USE_CC)" LDFLAGS="$(LDFLAGS) $(PROF_USE_LD)" + rm -f $(SRC2:%.c=%.gcda) $(SRC2:%.c=%.gcno) *.dyn pgopti.dpi pgopti.dpi.lock *.pgd *.pgc endif clean: - rm -f $(OBJS) $(OBJASM) $(OBJCLI) $(OBJSO) $(SONAME) *.a x264 x264.exe .depend TAGS - rm -f checkasm checkasm.exe tools/checkasm.o tools/checkasm-a.o - rm -f $(SRC2:%.c=%.gcda) $(SRC2:%.c=%.gcno) - - sed -e 's/ *-fprofile-\(generate\|use\)//g' config.mak > config.mak2 && mv config.mak2 config.mak + rm -f $(OBJS) $(OBJASM) $(OBJCLI) $(OBJSO) $(SONAME) *.a *.lib *.exp *.pdb x264 x264.exe .depend TAGS + rm -f checkasm checkasm.exe $(OBJCHK) $(GENERATED) x264_lookahead.clbin + rm -f example example.exe $(OBJEXAMPLE) + rm -f $(SRC2:%.c=%.gcda) $(SRC2:%.c=%.gcno) *.dyn pgopti.dpi pgopti.dpi.lock *.pgd *.pgc distclean: clean - rm -f config.mak config.h config.log x264.pc - rm -rf test/ - -install: x264$(EXE) $(SONAME) - install -d $(DESTDIR)$(bindir) - install -d $(DESTDIR)$(includedir) - install -d $(DESTDIR)$(libdir) - install -d $(DESTDIR)$(libdir)/pkgconfig - install -m 644 x264.h $(DESTDIR)$(includedir) - install -m 644 libx264.a $(DESTDIR)$(libdir) - install -m 644 x264.pc $(DESTDIR)$(libdir)/pkgconfig - install x264$(EXE) $(DESTDIR)$(bindir) - $(RANLIB) $(DESTDIR)$(libdir)/libx264.a -ifeq ($(SYS),MINGW) - $(if $(SONAME), install -m 755 $(SONAME) $(DESTDIR)$(bindir)) -else - $(if $(SONAME), ln -f -s $(SONAME) $(DESTDIR)$(libdir)/libx264.$(SOSUFFIX)) - $(if $(SONAME), install -m 755 $(SONAME) $(DESTDIR)$(libdir)) + rm -f config.mak x264_config.h config.h config.log x264.pc x264.def conftest* + +install-cli: cli + $(INSTALL) -d $(DESTDIR)$(bindir) + $(INSTALL) x264$(EXE) $(DESTDIR)$(bindir) + +install-lib-dev: + $(INSTALL) -d $(DESTDIR)$(includedir) + $(INSTALL) -d $(DESTDIR)$(libdir) + $(INSTALL) -d $(DESTDIR)$(libdir)/pkgconfig + $(INSTALL) -m 644 $(SRCPATH)/x264.h $(DESTDIR)$(includedir) + $(INSTALL) -m 644 x264_config.h $(DESTDIR)$(includedir) + $(INSTALL) -m 644 x264.pc $(DESTDIR)$(libdir)/pkgconfig + +install-lib-static: lib-static install-lib-dev + $(INSTALL) -m 644 $(LIBX264) $(DESTDIR)$(libdir) + $(if $(RANLIB), $(RANLIB) $(DESTDIR)$(libdir)/$(LIBX264)) + +install-lib-shared: lib-shared install-lib-dev +ifneq ($(IMPLIBNAME),) + $(INSTALL) -d $(DESTDIR)$(bindir) + $(INSTALL) -m 755 $(SONAME) $(DESTDIR)$(bindir) + $(INSTALL) -m 644 $(IMPLIBNAME) $(DESTDIR)$(libdir) +else ifneq ($(SONAME),) + ln -f -s $(SONAME) $(DESTDIR)$(libdir)/libx264.$(SOSUFFIX) + $(INSTALL) -m 755 $(SONAME) $(DESTDIR)$(libdir) endif - $(if $(IMPLIBNAME), install -m 644 $(IMPLIBNAME) $(DESTDIR)$(libdir)) uninstall: - rm -f $(DESTDIR)$(includedir)/x264.h $(DESTDIR)$(libdir)/libx264.a + rm -f $(DESTDIR)$(includedir)/x264.h $(DESTDIR)$(includedir)/x264_config.h $(DESTDIR)$(libdir)/libx264.a rm -f $(DESTDIR)$(bindir)/x264$(EXE) $(DESTDIR)$(libdir)/pkgconfig/x264.pc - $(if $(SONAME), rm -f $(DESTDIR)$(libdir)/$(SONAME) $(DESTDIR)$(libdir)/libx264.$(SOSUFFIX)) +ifneq ($(IMPLIBNAME),) + rm -f $(DESTDIR)$(bindir)/$(SONAME) $(DESTDIR)$(libdir)/$(IMPLIBNAME) +else ifneq ($(SONAME),) + rm -f $(DESTDIR)$(libdir)/$(SONAME) $(DESTDIR)$(libdir)/libx264.$(SOSUFFIX) +endif etags: TAGS TAGS: etags $(SRCS) - -dox: - doxygen Doxyfile - -ifeq (,$(VIDS)) -test: - @echo 'usage: make test VIDS="infile1 infile2 ..."' - @echo 'where infiles are anything that x264 understands,' - @echo 'i.e. YUV with resolution in the filename, y4m, or avisynth.' -else -test: - perl tools/regression-test.pl --version=head,current --options='$(OPT0)' --options='$(OPT1)' --options='$(OPT2)' $(VIDS:%=--input=%) -endif - -testclean: - rm -f test/*.log test/*.264 - $(foreach DIR, $(wildcard test/x264-r*/), cd $(DIR) ; make clean ; cd ../.. ;)