pkgsrc-Changes archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
CVS commit: pkgsrc/multimedia/ffmpeg7
Module Name: pkgsrc
Committed By: ryoon
Date: Sun Apr 7 17:50:24 UTC 2024
Added Files:
pkgsrc/multimedia/ffmpeg7: ALTERNATIVES DESCR Makefile Makefile.common
PLIST buildlink3.mk distinfo options.mk
pkgsrc/multimedia/ffmpeg7/patches: patch-Makefile patch-configure
patch-doc_Makefile patch-doc_general__contents.texi
patch-doc_indevs.texi patch-doc_outdevs.texi
patch-libavdevice_Makefile patch-libavdevice_sunau.c
patch-libavdevice_sunau.h patch-libavdevice_sunau__dec.c
patch-libavdevice_sunau__enc.c patch-libavformat_avformat.h
patch-libavformat_mux__utils.c patch-libavutil_macros.h
patch-libavutil_ppc_cpu.c patch-libavutil_x86_asm.h
patch-libavutil_x86_cpu.c
Log Message:
multimedia/ffmpeg7: import ffmpeg7-7.0
FFmpeg is a complete, cross-platform solution to record, convert
and stream audio and video. It includes libavcodec - the leading
audio/video codec library.
This package contains major version 7.
To generate a diff of this commit:
cvs rdiff -u -r0 -r1.1 pkgsrc/multimedia/ffmpeg7/ALTERNATIVES \
pkgsrc/multimedia/ffmpeg7/DESCR pkgsrc/multimedia/ffmpeg7/Makefile \
pkgsrc/multimedia/ffmpeg7/Makefile.common pkgsrc/multimedia/ffmpeg7/PLIST \
pkgsrc/multimedia/ffmpeg7/buildlink3.mk \
pkgsrc/multimedia/ffmpeg7/distinfo pkgsrc/multimedia/ffmpeg7/options.mk
cvs rdiff -u -r0 -r1.1 pkgsrc/multimedia/ffmpeg7/patches/patch-Makefile \
pkgsrc/multimedia/ffmpeg7/patches/patch-configure \
pkgsrc/multimedia/ffmpeg7/patches/patch-doc_Makefile \
pkgsrc/multimedia/ffmpeg7/patches/patch-doc_general__contents.texi \
pkgsrc/multimedia/ffmpeg7/patches/patch-doc_indevs.texi \
pkgsrc/multimedia/ffmpeg7/patches/patch-doc_outdevs.texi \
pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_Makefile \
pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_sunau.c \
pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_sunau.h \
pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_sunau__dec.c \
pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_sunau__enc.c \
pkgsrc/multimedia/ffmpeg7/patches/patch-libavformat_avformat.h \
pkgsrc/multimedia/ffmpeg7/patches/patch-libavformat_mux__utils.c \
pkgsrc/multimedia/ffmpeg7/patches/patch-libavutil_macros.h \
pkgsrc/multimedia/ffmpeg7/patches/patch-libavutil_ppc_cpu.c \
pkgsrc/multimedia/ffmpeg7/patches/patch-libavutil_x86_asm.h \
pkgsrc/multimedia/ffmpeg7/patches/patch-libavutil_x86_cpu.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Added files:
Index: pkgsrc/multimedia/ffmpeg7/ALTERNATIVES
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/ALTERNATIVES:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/ALTERNATIVES Sun Apr 7 17:50:23 2024
@@ -0,0 +1,2 @@
+bin/ffmpeg @PREFIX@/bin/ffmpeg7
+bin/ffprobe @PREFIX@/bin/ffprobe7
Index: pkgsrc/multimedia/ffmpeg7/DESCR
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/DESCR:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/DESCR Sun Apr 7 17:50:23 2024
@@ -0,0 +1,5 @@
+FFmpeg is a complete, cross-platform solution to record, convert
+and stream audio and video. It includes libavcodec - the leading
+audio/video codec library.
+
+This package contains major version 7.
Index: pkgsrc/multimedia/ffmpeg7/Makefile
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/Makefile:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/Makefile Sun Apr 7 17:50:23 2024
@@ -0,0 +1,41 @@
+# $NetBSD: Makefile,v 1.1 2024/04/07 17:50:23 ryoon Exp $
+
+PKGNAME= ${DISTNAME:S/ffmpeg/ffmpeg7/}
+MAINTAINER= pkgsrc-users%NetBSD.org@localhost
+HOMEPAGE= https://ffmpeg.org/
+COMMENT= Decoding, encoding and streaming software (v6.x)
+
+CONFIGURE_ARGS+= --enable-avfilter
+CONFIGURE_ARGS+= --enable-postproc
+CONFIGURE_ARGS+= --disable-ffplay
+
+INSTALLATION_DIRS= lib/ffmpeg7 share/doc/ffmpeg7
+
+.include "../../mk/bsd.prefs.mk"
+
+.if ${_USE_RPATH:tl} != "no"
+CONFIGURE_ARGS+= --enable-rpath
+.endif
+
+PRINT_PLIST_AWK+= /html/ { $$0 = "$${PLIST.doc}" $$0 }
+PRINT_PLIST_AWK+= /css/ { $$0 = "$${PLIST.doc}" $$0 }
+
+TEST_TARGET= check
+
+post-install:
+ ${INSTALL_DATA} ${WRKSRC}/doc/*.txt \
+ ${DESTDIR}${PREFIX}/share/doc/ffmpeg7
+
+.include "options.mk"
+
+# disable asm on i386 to avoid text relocations
+.if ${MACHINE_ARCH} == "i386"
+CONFIGURE_ARGS+= --disable-asm
+.endif
+
+# configure script uses uname -m to detect arch, as opposed to uname -p in
+# GNU/configure. Unable to detect NetBSD/macppc hosts correctly.
+CONFIGURE_ARGS+= --arch=${MACHINE_ARCH}
+
+.include "../../multimedia/ffmpeg7/Makefile.common"
+.include "../../mk/bsd.pkg.mk"
Index: pkgsrc/multimedia/ffmpeg7/Makefile.common
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/Makefile.common:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/Makefile.common Sun Apr 7 17:50:23 2024
@@ -0,0 +1,110 @@
+# $NetBSD: Makefile.common,v 1.1 2024/04/07 17:50:23 ryoon Exp $
+# used by multimedia/ffmpeg7/Makefile
+# used by multimedia/ffplay7/Makefile
+
+DISTNAME= ffmpeg-7.0
+CATEGORIES= multimedia
+MASTER_SITES= http://www.ffmpeg.org/releases/
+EXTRACT_SUFX= .tar.xz
+
+LICENSE= gnu-lgpl-v2.1 AND gnu-gpl-v2 ${ADDITIONAL_LICENSE}
+
+PATCHDIR= ${.CURDIR}/../../multimedia/ffmpeg7/patches
+
+USE_LIBTOOL= yes
+USE_TOOLS+= gmake pod2man perl pkg-config
+HAS_CONFIGURE= yes
+CONFIGURE_ARGS+= --cc=${CC:Q}
+CONFIGURE_ARGS+= --disable-debug
+CONFIGURE_ARGS+= --disable-optimizations
+CONFIGURE_ARGS+= --disable-stripping
+CONFIGURE_ARGS+= --enable-gpl
+CONFIGURE_ARGS+= --enable-libxml2
+CONFIGURE_ARGS+= --enable-pthreads
+CONFIGURE_ARGS+= --enable-shared
+CONFIGURE_ARGS+= --mandir=${PREFIX}/${PKGMANDIR}
+CONFIGURE_ARGS+= --prefix=${PREFIX}
+CONFIGURE_ARGS+= --progs-suffix=7
+
+CONFIGURE_ARGS+= --enable-runtime-cpudetect
+CONFIGURE_ARGS+= --datadir=${PREFIX}/share/ffmpeg7
+CONFIGURE_ARGS+= --docdir=${PREFIX}/share/doc/ffmpeg7
+CONFIGURE_ARGS+= --incdir=${PREFIX}/include/ffmpeg7
+CONFIGURE_ARGS+= --libdir=${PREFIX}/lib/ffmpeg7
+CONFIGURE_ARGS+= --shlibdir=${PREFIX}/lib/ffmpeg7
+LDFLAGS+= ${COMPILER_RPATH_FLAG}${PREFIX}/lib/ffmpeg7
+# https://github.com/homebrew-ffmpeg/homebrew-ffmpeg/issues/140
+LDFLAGS.Darwin+= -Wl,-ld_classic
+
+.if ${USE_CROSS_COMPILE:tl} == yes
+CONFIGURE_ARGS+= --enable-cross-compile
+CONFIGURE_ARGS+= --host-cc=${NATIVE_CC:Q}
+CONFIGURE_ARGS+= --host-ld=${NATIVE_CC:Q}
+CONFIGURE_ARGS+= --target-os=${LOWER_OPSYS:Q}
+. include "../../mk/endian.mk"
+. if ${MACHINE_ENDIAN} == "big"
+CONFIGURE_ENV+= bigendian=yes
+. endif
+.endif
+
+# altivec support is detected at runtime, and only code that is gated
+# on the runtime detection can use it. The code in ffmpeg that is
+# gated on the runtime detection doesn't need -maltivec -mabi=altivec.
+# But passing -maltivec -mabi=altivec tells the compiler that _any_
+# code, whether or not gated on runtime detection, can be done with
+# altivec -- and the compiler will quietly take advantage of this,
+# e.g. to zero-initialize objects on the stack. This doesn't work too
+# well on powerpc CPUs without altivec, so nix the arguments.
+.if !empty(MACHINE_ARCH:Mpowerpc*)
+BUILDLINK_TRANSFORM+= rm:-maltivec
+BUILDLINK_TRANSFORM+= rm:-mabi=altivec
+.endif
+
+.if !empty(MACHINE_PLATFORM:MDarwin-1[2-9].*-*) || !empty(MACHINE_PLATFORM:MDarwin-2*)
+CONFIGURE_ARGS+= --enable-opencl
+.endif
+
+.if ${OPSYS} == "SunOS"
+USE_TOOLS+= bash:build
+CONFIG_SHELL= ${TOOLS_PATH.bash}
+.endif
+
+# Let's not put garbage into /tmp
+CONFIGURE_ENV+= TMPDIR=${WRKSRC}/tmp
+
+.include "../../mk/compiler.mk"
+
+.if !empty(PKGSRC_COMPILER:Msunpro)
+SUBST_CLASSES+= sunwspro
+SUBST_MESSAGE.sunwspro= Fixing compiler options for SunStudio C compiler.
+SUBST_STAGE.sunwspro= post-configure
+SUBST_FILES.sunwspro= config.mak
+SUBST_SED.sunwspro= -e "s/-O /-KPIC -DPIC /"
+SUBST_SED.sunwspro+= -e "s/-O3/-xO2/g"
+SUBST_SED.sunwspro+= -e "s/-std=c99/-xc99=all/"
+SUBST_SED.sunwspro+= -e "s/-Wl,-rpath-link,/-L /g"
+.endif
+
+.if ${MACHINE_ARCH} == x86_64 || ${MACHINE_ARCH} == i386
+TOOL_DEPENDS+= nasm>=2.13:../../devel/nasm
+.endif
+
+REPLACE_PERL+= doc/texi2pod.pl
+REPLACE_SH+= configure
+REPLACE_SH+= ffbuild/pkgconfig_generate.sh
+REPLACE_SH+= ffbuild/version.sh
+
+PLIST_SRC+= ${PKGDIR}/PLIST
+
+MAKE_ENV+= EXTRA_LIBS=${LIBGETOPT:Q}
+
+pre-configure:
+ ${MKDIR} ${WRKSRC}/tmp
+
+.include "../../archivers/bzip2/buildlink3.mk"
+.include "../../archivers/xz/buildlink3.mk"
+.include "../../devel/libgetopt/buildlink3.mk"
+.include "../../devel/zlib/buildlink3.mk"
+.include "../../textproc/libxml2/buildlink3.mk"
+.include "../../mk/atomic64.mk"
+.include "../../mk/pthread.buildlink3.mk"
Index: pkgsrc/multimedia/ffmpeg7/PLIST
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/PLIST:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/PLIST Sun Apr 7 17:50:23 2024
@@ -0,0 +1,285 @@
+@comment $NetBSD: PLIST,v 1.1 2024/04/07 17:50:23 ryoon Exp $
+bin/ffmpeg7
+bin/ffprobe7
+include/ffmpeg7/libavcodec/ac3_parser.h
+include/ffmpeg7/libavcodec/adts_parser.h
+include/ffmpeg7/libavcodec/avcodec.h
+include/ffmpeg7/libavcodec/avdct.h
+include/ffmpeg7/libavcodec/avfft.h
+include/ffmpeg7/libavcodec/bsf.h
+include/ffmpeg7/libavcodec/codec.h
+include/ffmpeg7/libavcodec/codec_desc.h
+include/ffmpeg7/libavcodec/codec_id.h
+include/ffmpeg7/libavcodec/codec_par.h
+include/ffmpeg7/libavcodec/d3d11va.h
+include/ffmpeg7/libavcodec/defs.h
+include/ffmpeg7/libavcodec/dirac.h
+include/ffmpeg7/libavcodec/dv_profile.h
+include/ffmpeg7/libavcodec/dxva2.h
+include/ffmpeg7/libavcodec/jni.h
+include/ffmpeg7/libavcodec/mediacodec.h
+include/ffmpeg7/libavcodec/packet.h
+include/ffmpeg7/libavcodec/qsv.h
+include/ffmpeg7/libavcodec/vdpau.h
+include/ffmpeg7/libavcodec/version.h
+include/ffmpeg7/libavcodec/version_major.h
+include/ffmpeg7/libavcodec/videotoolbox.h
+include/ffmpeg7/libavcodec/vorbis_parser.h
+include/ffmpeg7/libavdevice/avdevice.h
+include/ffmpeg7/libavdevice/version.h
+include/ffmpeg7/libavdevice/version_major.h
+include/ffmpeg7/libavfilter/avfilter.h
+include/ffmpeg7/libavfilter/buffersink.h
+include/ffmpeg7/libavfilter/buffersrc.h
+include/ffmpeg7/libavfilter/version.h
+include/ffmpeg7/libavfilter/version_major.h
+include/ffmpeg7/libavformat/avformat.h
+include/ffmpeg7/libavformat/avio.h
+include/ffmpeg7/libavformat/version.h
+include/ffmpeg7/libavformat/version_major.h
+include/ffmpeg7/libavutil/adler32.h
+include/ffmpeg7/libavutil/aes.h
+include/ffmpeg7/libavutil/aes_ctr.h
+include/ffmpeg7/libavutil/ambient_viewing_environment.h
+include/ffmpeg7/libavutil/attributes.h
+include/ffmpeg7/libavutil/audio_fifo.h
+include/ffmpeg7/libavutil/avassert.h
+include/ffmpeg7/libavutil/avconfig.h
+include/ffmpeg7/libavutil/avstring.h
+include/ffmpeg7/libavutil/avutil.h
+include/ffmpeg7/libavutil/base64.h
+include/ffmpeg7/libavutil/blowfish.h
+include/ffmpeg7/libavutil/bprint.h
+include/ffmpeg7/libavutil/bswap.h
+include/ffmpeg7/libavutil/buffer.h
+include/ffmpeg7/libavutil/camellia.h
+include/ffmpeg7/libavutil/cast5.h
+include/ffmpeg7/libavutil/channel_layout.h
+include/ffmpeg7/libavutil/common.h
+include/ffmpeg7/libavutil/cpu.h
+include/ffmpeg7/libavutil/crc.h
+include/ffmpeg7/libavutil/csp.h
+include/ffmpeg7/libavutil/des.h
+include/ffmpeg7/libavutil/detection_bbox.h
+include/ffmpeg7/libavutil/dict.h
+include/ffmpeg7/libavutil/display.h
+include/ffmpeg7/libavutil/dovi_meta.h
+include/ffmpeg7/libavutil/downmix_info.h
+include/ffmpeg7/libavutil/encryption_info.h
+include/ffmpeg7/libavutil/error.h
+include/ffmpeg7/libavutil/eval.h
+include/ffmpeg7/libavutil/executor.h
+include/ffmpeg7/libavutil/ffversion.h
+include/ffmpeg7/libavutil/fifo.h
+include/ffmpeg7/libavutil/file.h
+include/ffmpeg7/libavutil/film_grain_params.h
+include/ffmpeg7/libavutil/frame.h
+include/ffmpeg7/libavutil/hash.h
+include/ffmpeg7/libavutil/hdr_dynamic_metadata.h
+include/ffmpeg7/libavutil/hdr_dynamic_vivid_metadata.h
+include/ffmpeg7/libavutil/hmac.h
+include/ffmpeg7/libavutil/hwcontext.h
+include/ffmpeg7/libavutil/hwcontext_cuda.h
+include/ffmpeg7/libavutil/hwcontext_d3d11va.h
+include/ffmpeg7/libavutil/hwcontext_d3d12va.h
+include/ffmpeg7/libavutil/hwcontext_drm.h
+include/ffmpeg7/libavutil/hwcontext_dxva2.h
+include/ffmpeg7/libavutil/hwcontext_mediacodec.h
+include/ffmpeg7/libavutil/hwcontext_opencl.h
+include/ffmpeg7/libavutil/hwcontext_qsv.h
+include/ffmpeg7/libavutil/hwcontext_vaapi.h
+include/ffmpeg7/libavutil/hwcontext_vdpau.h
+include/ffmpeg7/libavutil/hwcontext_videotoolbox.h
+include/ffmpeg7/libavutil/hwcontext_vulkan.h
+include/ffmpeg7/libavutil/iamf.h
+include/ffmpeg7/libavutil/imgutils.h
+include/ffmpeg7/libavutil/intfloat.h
+include/ffmpeg7/libavutil/intreadwrite.h
+include/ffmpeg7/libavutil/lfg.h
+include/ffmpeg7/libavutil/log.h
+include/ffmpeg7/libavutil/lzo.h
+include/ffmpeg7/libavutil/macros.h
+include/ffmpeg7/libavutil/mastering_display_metadata.h
+include/ffmpeg7/libavutil/mathematics.h
+include/ffmpeg7/libavutil/md5.h
+include/ffmpeg7/libavutil/mem.h
+include/ffmpeg7/libavutil/motion_vector.h
+include/ffmpeg7/libavutil/murmur3.h
+include/ffmpeg7/libavutil/opt.h
+include/ffmpeg7/libavutil/parseutils.h
+include/ffmpeg7/libavutil/pixdesc.h
+include/ffmpeg7/libavutil/pixelutils.h
+include/ffmpeg7/libavutil/pixfmt.h
+include/ffmpeg7/libavutil/random_seed.h
+include/ffmpeg7/libavutil/rational.h
+include/ffmpeg7/libavutil/rc4.h
+include/ffmpeg7/libavutil/replaygain.h
+include/ffmpeg7/libavutil/ripemd.h
+include/ffmpeg7/libavutil/samplefmt.h
+include/ffmpeg7/libavutil/sha.h
+include/ffmpeg7/libavutil/sha512.h
+include/ffmpeg7/libavutil/spherical.h
+include/ffmpeg7/libavutil/stereo3d.h
+include/ffmpeg7/libavutil/tea.h
+include/ffmpeg7/libavutil/threadmessage.h
+include/ffmpeg7/libavutil/time.h
+include/ffmpeg7/libavutil/timecode.h
+include/ffmpeg7/libavutil/timestamp.h
+include/ffmpeg7/libavutil/tree.h
+include/ffmpeg7/libavutil/twofish.h
+include/ffmpeg7/libavutil/tx.h
+include/ffmpeg7/libavutil/uuid.h
+include/ffmpeg7/libavutil/version.h
+include/ffmpeg7/libavutil/video_enc_params.h
+include/ffmpeg7/libavutil/video_hint.h
+include/ffmpeg7/libavutil/xtea.h
+include/ffmpeg7/libpostproc/postprocess.h
+include/ffmpeg7/libpostproc/version.h
+include/ffmpeg7/libpostproc/version_major.h
+include/ffmpeg7/libswresample/swresample.h
+include/ffmpeg7/libswresample/version.h
+include/ffmpeg7/libswresample/version_major.h
+include/ffmpeg7/libswscale/swscale.h
+include/ffmpeg7/libswscale/version.h
+include/ffmpeg7/libswscale/version_major.h
+lib/ffmpeg7/libavcodec.a
+lib/ffmpeg7/libavcodec.so
+lib/ffmpeg7/libavcodec.so.61
+lib/ffmpeg7/libavcodec.so.61.3.100
+lib/ffmpeg7/libavdevice.a
+lib/ffmpeg7/libavdevice.so
+lib/ffmpeg7/libavdevice.so.61
+lib/ffmpeg7/libavdevice.so.61.1.100
+lib/ffmpeg7/libavfilter.a
+lib/ffmpeg7/libavfilter.so
+lib/ffmpeg7/libavfilter.so.10
+lib/ffmpeg7/libavfilter.so.10.1.100
+lib/ffmpeg7/libavformat.a
+lib/ffmpeg7/libavformat.so
+lib/ffmpeg7/libavformat.so.61
+lib/ffmpeg7/libavformat.so.61.1.100
+lib/ffmpeg7/libavutil.a
+lib/ffmpeg7/libavutil.so
+lib/ffmpeg7/libavutil.so.59
+lib/ffmpeg7/libavutil.so.59.8.100
+lib/ffmpeg7/libpostproc.a
+lib/ffmpeg7/libpostproc.so
+lib/ffmpeg7/libpostproc.so.58
+lib/ffmpeg7/libpostproc.so.58.1.100
+lib/ffmpeg7/libswresample.a
+lib/ffmpeg7/libswresample.so
+lib/ffmpeg7/libswresample.so.5
+lib/ffmpeg7/libswresample.so.5.1.100
+lib/ffmpeg7/libswscale.a
+lib/ffmpeg7/libswscale.so
+lib/ffmpeg7/libswscale.so.8
+lib/ffmpeg7/libswscale.so.8.1.100
+lib/ffmpeg7/pkgconfig/libavcodec.pc
+lib/ffmpeg7/pkgconfig/libavdevice.pc
+lib/ffmpeg7/pkgconfig/libavfilter.pc
+lib/ffmpeg7/pkgconfig/libavformat.pc
+lib/ffmpeg7/pkgconfig/libavutil.pc
+lib/ffmpeg7/pkgconfig/libpostproc.pc
+lib/ffmpeg7/pkgconfig/libswresample.pc
+lib/ffmpeg7/pkgconfig/libswscale.pc
+man/man1/ffmpeg-all7.1
+man/man1/ffmpeg-bitstream-filters7.1
+man/man1/ffmpeg-codecs7.1
+man/man1/ffmpeg-devices7.1
+man/man1/ffmpeg-filters7.1
+man/man1/ffmpeg-formats7.1
+man/man1/ffmpeg-protocols7.1
+man/man1/ffmpeg-resampler7.1
+man/man1/ffmpeg-scaler7.1
+man/man1/ffmpeg-utils7.1
+man/man1/ffmpeg7.1
+man/man1/ffprobe-all7.1
+man/man1/ffprobe7.1
+man/man3/libavcodec7.3
+man/man3/libavdevice7.3
+man/man3/libavfilter7.3
+man/man3/libavformat7.3
+man/man3/libavutil7.3
+man/man3/libswresample7.3
+man/man3/libswscale7.3
+${PLIST.doc}share/doc/ffmpeg7/bootstrap.min.css
+share/doc/ffmpeg7/build_system.txt
+${PLIST.doc}share/doc/ffmpeg7/community.html
+${PLIST.doc}share/doc/ffmpeg7/default.css
+${PLIST.doc}share/doc/ffmpeg7/developer.html
+share/doc/ffmpeg7/errno.txt
+${PLIST.doc}share/doc/ffmpeg7/faq.html
+${PLIST.doc}share/doc/ffmpeg7/fate.html
+${PLIST.doc}share/doc/ffmpeg7/ffmpeg-all.html
+${PLIST.doc}share/doc/ffmpeg7/ffmpeg-bitstream-filters.html
+${PLIST.doc}share/doc/ffmpeg7/ffmpeg-codecs.html
+${PLIST.doc}share/doc/ffmpeg7/ffmpeg-devices.html
+${PLIST.doc}share/doc/ffmpeg7/ffmpeg-filters.html
+${PLIST.doc}share/doc/ffmpeg7/ffmpeg-formats.html
+${PLIST.doc}share/doc/ffmpeg7/ffmpeg-protocols.html
+${PLIST.doc}share/doc/ffmpeg7/ffmpeg-resampler.html
+${PLIST.doc}share/doc/ffmpeg7/ffmpeg-scaler.html
+${PLIST.doc}share/doc/ffmpeg7/ffmpeg-utils.html
+${PLIST.doc}share/doc/ffmpeg7/ffmpeg.html
+share/doc/ffmpeg7/ffmpeg.txt
+${PLIST.doc}share/doc/ffmpeg7/ffprobe-all.html
+${PLIST.doc}share/doc/ffmpeg7/ffprobe.html
+share/doc/ffmpeg7/filter_design.txt
+${PLIST.doc}share/doc/ffmpeg7/general.html
+${PLIST.doc}share/doc/ffmpeg7/git-howto.html
+share/doc/ffmpeg7/infra.txt
+share/doc/ffmpeg7/issue_tracker.txt
+share/doc/ffmpeg7/libav-merge.txt
+${PLIST.doc}share/doc/ffmpeg7/libavcodec.html
+${PLIST.doc}share/doc/ffmpeg7/libavdevice.html
+${PLIST.doc}share/doc/ffmpeg7/libavfilter.html
+${PLIST.doc}share/doc/ffmpeg7/libavformat.html
+${PLIST.doc}share/doc/ffmpeg7/libavutil.html
+${PLIST.doc}share/doc/ffmpeg7/libswresample.html
+${PLIST.doc}share/doc/ffmpeg7/libswscale.html
+${PLIST.doc}share/doc/ffmpeg7/mailing-list-faq.html
+share/doc/ffmpeg7/mips.txt
+share/doc/ffmpeg7/multithreading.txt
+${PLIST.doc}share/doc/ffmpeg7/nut.html
+share/doc/ffmpeg7/optimization.txt
+${PLIST.doc}share/doc/ffmpeg7/platform.html
+share/doc/ffmpeg7/rate_distortion.txt
+share/doc/ffmpeg7/snow.txt
+${PLIST.doc}share/doc/ffmpeg7/style.min.css
+share/doc/ffmpeg7/swresample.txt
+share/doc/ffmpeg7/swscale.txt
+share/doc/ffmpeg7/tablegen.txt
+share/doc/ffmpeg7/undefined.txt
+share/doc/ffmpeg7/writing_filters.txt
+share/ffmpeg7/examples/Makefile
+share/ffmpeg7/examples/README
+share/ffmpeg7/examples/avio_http_serve_files.c
+share/ffmpeg7/examples/avio_list_dir.c
+share/ffmpeg7/examples/avio_read_callback.c
+share/ffmpeg7/examples/decode_audio.c
+share/ffmpeg7/examples/decode_filter_audio.c
+share/ffmpeg7/examples/decode_filter_video.c
+share/ffmpeg7/examples/decode_video.c
+share/ffmpeg7/examples/demux_decode.c
+share/ffmpeg7/examples/encode_audio.c
+share/ffmpeg7/examples/encode_video.c
+share/ffmpeg7/examples/extract_mvs.c
+share/ffmpeg7/examples/filter_audio.c
+share/ffmpeg7/examples/hw_decode.c
+share/ffmpeg7/examples/mux.c
+share/ffmpeg7/examples/qsv_decode.c
+share/ffmpeg7/examples/qsv_transcode.c
+share/ffmpeg7/examples/remux.c
+share/ffmpeg7/examples/resample_audio.c
+share/ffmpeg7/examples/scale_video.c
+share/ffmpeg7/examples/show_metadata.c
+share/ffmpeg7/examples/transcode.c
+share/ffmpeg7/examples/transcode_aac.c
+share/ffmpeg7/examples/vaapi_encode.c
+share/ffmpeg7/examples/vaapi_transcode.c
+share/ffmpeg7/ffprobe.xsd
+share/ffmpeg7/libvpx-1080p.ffpreset
+share/ffmpeg7/libvpx-1080p50_60.ffpreset
+share/ffmpeg7/libvpx-360p.ffpreset
+share/ffmpeg7/libvpx-720p.ffpreset
+share/ffmpeg7/libvpx-720p50_60.ffpreset
Index: pkgsrc/multimedia/ffmpeg7/buildlink3.mk
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/buildlink3.mk:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/buildlink3.mk Sun Apr 7 17:50:23 2024
@@ -0,0 +1,62 @@
+# $NetBSD: buildlink3.mk,v 1.1 2024/04/07 17:50:23 ryoon Exp $
+
+BUILDLINK_TREE+= ffmpeg7
+
+.if !defined(FFMPEG7_BUILDLINK3_MK)
+FFMPEG7_BUILDLINK3_MK:=
+
+BUILDLINK_API_DEPENDS.ffmpeg7+= ffmpeg7>=7.0
+BUILDLINK_PKGSRCDIR.ffmpeg7?= ../../multimedia/ffmpeg7
+
+pkgbase := ffmpeg7
+.include "../../mk/pkg-build-options.mk"
+
+.include "../../mk/bsd.fast.prefs.mk"
+
+.if ${PKG_BUILD_OPTIONS.ffmpeg7:Mav1}
+. include "../../multimedia/libaom/buildlink3.mk"
+.endif
+
+.if ${PKG_BUILD_OPTIONS.ffmpeg7:Mfreetype}
+. include "../../graphics/freetype2/buildlink3.mk"
+.endif
+
+.if ${PKG_BUILD_OPTIONS.ffmpeg7:Mfontconfig}
+. include "../../fonts/fontconfig/buildlink3.mk"
+.endif
+
+.if ${PKG_BUILD_OPTIONS.ffmpeg7:Mtheora}
+. include "../../multimedia/libtheora/buildlink3.mk"
+.endif
+
+.if ${PKG_BUILD_OPTIONS.ffmpeg7:Mxvid}
+. include "../../multimedia/xvidcore/buildlink3.mk"
+.endif
+
+.if ${PKG_BUILD_OPTIONS.ffmpeg7:Mx264}
+. include "../../multimedia/x264/buildlink3.mk"
+.endif
+
+.if ${PKG_BUILD_OPTIONS.ffmpeg7:Mlibvpx}
+. include "../../multimedia/libvpx/buildlink3.mk"
+.endif
+
+.if ${PKG_BUILD_OPTIONS.ffmpeg7:Mvaapi}
+. include "../../multimedia/libva/buildlink3.mk"
+.endif
+
+.if ${PKG_BUILD_OPTIONS.ffmpeg7:Mvdpau}
+. include "../../multimedia/libvdpau/buildlink3.mk"
+.endif
+
+BUILDLINK_INCDIRS.ffmpeg7+= include/ffmpeg7
+BUILDLINK_LIBDIRS.ffmpeg7+= lib/ffmpeg7
+BUILDLINK_FNAME_TRANSFORM.ffmpeg7+= -e 's|lib/ffmpeg7/pkgconfig/|lib/pkgconfig/|'
+
+.include "../../archivers/bzip2/buildlink3.mk"
+.include "../../archivers/xz/buildlink3.mk"
+.include "../../devel/libgetopt/buildlink3.mk"
+.include "../../devel/zlib/buildlink3.mk"
+.endif # FFMPEG7_BUILDLINK3_MK
+
+BUILDLINK_TREE+= -ffmpeg7
Index: pkgsrc/multimedia/ffmpeg7/distinfo
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/distinfo:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/distinfo Sun Apr 7 17:50:23 2024
@@ -0,0 +1,22 @@
+$NetBSD: distinfo,v 1.1 2024/04/07 17:50:23 ryoon Exp $
+
+BLAKE2s (ffmpeg-7.0.tar.xz) = 9712a6ec9d3cbbc3c8a92712a30982c12005abcdefb6f0c56a13fa8f4f0137e5
+SHA512 (ffmpeg-7.0.tar.xz) = f693027b9c142c3757b76b2fe1c09bdafa4bf2580e691b20306bc6621080005173d068122668e80f52bd46dba3ab04a32f0608d709c8e6fd1c73387b4d4881f7
+Size (ffmpeg-7.0.tar.xz) = 10791240 bytes
+SHA1 (patch-Makefile) = 2d27f218ee49179fdea14bb5c86c506dfb64dbd6
+SHA1 (patch-configure) = bdb43e6d014e0cdfa57b44ee30a2283c75871831
+SHA1 (patch-doc_Makefile) = 35a23c09f3f735131647888cdc1ba725ff0f33ac
+SHA1 (patch-doc_general__contents.texi) = 13704795d2688dc0377a512dc6e65025ad674724
+SHA1 (patch-doc_indevs.texi) = 8cd421a67f34ebbe6099102bf1de7c6cdb13dcb7
+SHA1 (patch-doc_outdevs.texi) = 0aec04682b516016abe9b81f6efcbbef97b1c3b2
+SHA1 (patch-libavdevice_Makefile) = 526efd20021068245d8904c0d55508a540ae4054
+SHA1 (patch-libavdevice_sunau.c) = 554a5fc77c0e94828e9eadc7f1f9d4067a76d4ae
+SHA1 (patch-libavdevice_sunau.h) = 2678d87f81e7b3faa42b5cc9814e373c4ad812f6
+SHA1 (patch-libavdevice_sunau__dec.c) = d2fc01e941c68ab8b6f5e0b98ee536a32cc56bdc
+SHA1 (patch-libavdevice_sunau__enc.c) = efe765b99ad6379d0237c619ac0dce41306431be
+SHA1 (patch-libavformat_avformat.h) = fd10d2646728d8340ac4b654e06db8deb9cf8522
+SHA1 (patch-libavformat_mux__utils.c) = a46cdcc8e32251773362406adad06efb367349ca
+SHA1 (patch-libavutil_macros.h) = 7d9770f018a2207d2dcb1fe057564e30be51fd42
+SHA1 (patch-libavutil_ppc_cpu.c) = 0c77fecf2b92fa7b8f786987b216fe70a0d45904
+SHA1 (patch-libavutil_x86_asm.h) = 8f48f9e8ec08b5176bb40fc0021f3bb913dbef22
+SHA1 (patch-libavutil_x86_cpu.c) = 9c97e68fde0fcb19741e034a803d509040ea4487
Index: pkgsrc/multimedia/ffmpeg7/options.mk
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/options.mk:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/options.mk Sun Apr 7 17:50:23 2024
@@ -0,0 +1,290 @@
+# $NetBSD: options.mk,v 1.1 2024/04/07 17:50:23 ryoon Exp $
+
+PKG_OPTIONS_VAR= PKG_OPTIONS.ffmpeg7
+PKG_OPTIONS_OPTIONAL_GROUPS= ssl
+PKG_OPTIONS_GROUP.ssl= gnutls mbedtls openssl
+
+PKG_SUPPORTED_OPTIONS= ass aom bluray doc fdk-aac fontconfig freetype jack \
+ lame libvpx libwebp opencore-amr opus pulseaudio rav1e rpi rtmp \
+ speex tesseract theora vorbis x11 x264 x265 xvid
+PKG_SUGGESTED_OPTIONS= ass aom bluray freetype fontconfig gnutls lame \
+ libvpx libwebp opus speex theora vorbis x264 x265 xvid
+
+PLIST_VARS+= doc
+
+# Add VDPAU if it is available
+.include "../../multimedia/libvdpau/available.mk"
+.if ${VDPAU_AVAILABLE} == "yes"
+PKG_SUPPORTED_OPTIONS+= vdpau
+PKG_SUGGESTED_OPTIONS+= vdpau
+.endif
+
+# Add VAAPI if it is available
+.include "../../multimedia/libva/available.mk"
+.if ${VAAPI_AVAILABLE} == "yes"
+PKG_SUPPORTED_OPTIONS+= vaapi
+PKG_SUGGESTED_OPTIONS+= vaapi
+.endif
+
+.if ${OPSYS} != "Darwin"
+PKG_SUGGESTED_OPTIONS+= x11
+.endif
+
+.include "../../mk/bsd.options.mk"
+
+# Fontconfig
+.if !empty(PKG_OPTIONS:Mfontconfig)
+CONFIGURE_ARGS+= --enable-fontconfig
+.include "../../fonts/fontconfig/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-fontconfig
+.endif
+
+# freetype option
+.if !empty(PKG_OPTIONS:Mfreetype)
+CONFIGURE_ARGS+= --enable-libfreetype
+.include "../../graphics/freetype2/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-libfreetype
+.endif
+
+# ass option
+.if !empty(PKG_OPTIONS:Mass)
+CONFIGURE_ARGS+= --enable-libass
+.include "../../multimedia/libass/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-libass
+.endif
+
+# av1 option with libaom
+.if !empty(PKG_OPTIONS:Maom)
+CONFIGURE_ARGS+= --enable-libaom
+BUILDLINK_API_DEPENDS.libaom+= libaom>=1.0.0nb1
+.include "../../multimedia/libaom/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-libaom
+.endif
+
+# av1 option with rav1e
+.if !empty(PKG_OPTIONS:Mrav1e)
+CONFIGURE_ARGS+= --enable-librav1e
+.include "../../multimedia/rav1e/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-librav1e
+.endif
+
+.if !empty(PKG_OPTIONS:Maom) || !empty(PKG_OPTIONS:Mrav1e)
+CONFIGURE_ARGS+= --enable-libdav1d
+.include "../../multimedia/dav1d/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-libdav1d
+.endif
+
+# doc option
+.if !empty(PKG_OPTIONS:Mdoc)
+PLIST.doc= yes
+USE_TOOLS+= texi2html
+CONFIGURE_ARGS+= --enable-htmlpages
+.else
+CONFIGURE_ARGS+= --disable-htmlpages
+.endif
+
+# Fraunhofer FDK AAC codec support
+.if !empty(PKG_OPTIONS:Mfdk-aac)
+RESTRICTED= ffmpeg built with fdk-aac combines GPL and GPL-incompatible code
+NO_BIN_ON_CDROM= ${RESTRICTED}
+NO_BIN_ON_FTP= ${RESTRICTED}
+CONFIGURE_ARGS+= --enable-libfdk_aac
+CONFIGURE_ARGS+= --enable-nonfree
+.include "../../audio/fdk-aac/buildlink3.mk"
+.endif
+
+# GnuTLS support
+.if !empty(PKG_OPTIONS:Mgnutls)
+CONFIGURE_ARGS+= --enable-gnutls
+.include "../../security/gnutls/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-gnutls
+.endif
+
+# mbedTLS support
+.if !empty(PKG_OPTIONS:Mmbedtls)
+CONFIGURE_ARGS+= --enable-mbedtls
+# Apache License 2.0 is incompatible with (L)GPL versions before 3
+CONFIGURE_ARGS+= --enable-version3
+ADDITIONAL_LICENSE+= AND gnu-lgpl-v3
+.include "../../security/mbedtls/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-mbedtls
+.endif
+
+# opencore-amr option
+.if !empty(PKG_OPTIONS:Mopencore-amr)
+CONFIGURE_ARGS+= --enable-libopencore-amrnb
+CONFIGURE_ARGS+= --enable-libopencore-amrwb
+# Apache License 2.0 is incompatible with (L)GPL versions before 3
+CONFIGURE_ARGS+= --enable-version3
+ADDITIONAL_LICENSE+= AND gnu-lgpl-v3
+.include "../../audio/opencore-amr/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-libopencore-amrnb
+CONFIGURE_ARGS+= --disable-libopencore-amrwb
+.endif
+
+# OpenSSL support
+.if !empty(PKG_OPTIONS:Mopenssl)
+CONFIGURE_ARGS+= --enable-nonfree
+CONFIGURE_ARGS+= --enable-openssl
+.include "../../security/openssl/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-openssl
+.endif
+
+# jack option
+.if !empty(PKG_OPTIONS:Mjack)
+CONFIGURE_ARGS+= --enable-libjack
+.include "../../audio/jack/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-libjack
+.endif
+
+# pulseaudio option
+.if !empty(PKG_OPTIONS:Mpulseaudio)
+CONFIGURE_ARGS+= --enable-libpulse
+.include "../../audio/pulseaudio/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-libpulse
+.endif
+
+# RTMP support via librtmp
+.if !empty(PKG_OPTIONS:Mrtmp)
+CONFIGURE_ARGS+= --enable-librtmp
+.include "../../net/rtmpdump/buildlink3.mk"
+.endif
+
+# OCR filter using Tesseract
+.if !empty(PKG_OPTIONS:Mtesseract)
+CONFIGURE_ARGS+= --enable-libtesseract
+.include "../../graphics/tesseract/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-libtesseract
+.endif
+
+# OGG Theora support
+.if !empty(PKG_OPTIONS:Mtheora)
+CONFIGURE_ARGS+= --enable-libtheora
+.include "../../multimedia/libtheora/buildlink3.mk"
+.endif
+
+# OGG Vorbis support
+.if !empty(PKG_OPTIONS:Mvorbis)
+CONFIGURE_ARGS+= --enable-libvorbis
+.include "../../audio/libvorbis/buildlink3.mk"
+.endif
+
+# LAME MP3 encoder
+.if !empty(PKG_OPTIONS:Mlame)
+# "lame-3.98" isn't compatible with "ffmpeg" which breaks audio encoding.
+BUILDLINK_API_DEPENDS.lame+= lame>=3.98.2nb1
+CONFIGURE_ARGS+= --enable-libmp3lame
+.include "../../audio/lame/buildlink3.mk"
+.endif
+
+# OPUS support
+.if !empty(PKG_OPTIONS:Mopus)
+CONFIGURE_ARGS+= --enable-libopus
+.include "../../audio/libopus/buildlink3.mk"
+.endif
+
+# Speex support
+.if !empty(PKG_OPTIONS:Mspeex)
+CONFIGURE_ARGS+= --enable-libspeex
+.include "../../audio/speex/buildlink3.mk"
+.endif
+
+# Raspberry Pi support
+.if !empty(PKG_OPTIONS:Mrpi)
+CONFIGURE_ARGS+= --enable-omx-rpi
+CONFIGURE_ARGS+= --enable-mmal
+SUBST_CLASSES+= vc
+SUBST_STAGE.vc= pre-configure
+SUBST_MESSAGE.vc= Fixing path to VideoCore libraries.
+SUBST_FILES.vc= configure
+SUBST_SED.vc+= -e 's;-isystem/opt/vc;-I${PREFIX};g'
+SUBST_SED.vc+= -e 's;/opt/vc;${PREFIX};g'
+.include "../../misc/raspberrypi-userland/buildlink3.mk"
+.endif
+
+# XviD support
+.if !empty(PKG_OPTIONS:Mxvid)
+CONFIGURE_ARGS+= --enable-libxvid
+.include "../../multimedia/xvidcore/buildlink3.mk"
+.endif
+
+# x264 support
+.if !empty(PKG_OPTIONS:Mx264)
+BUILDLINK_API_DEPENDS.x264+= x264>=20220601
+CONFIGURE_ARGS+= --enable-libx264
+.include "../../multimedia/x264/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-libx264
+.endif
+
+# x265 support
+.if !empty(PKG_OPTIONS:Mx265)
+CONFIGURE_ARGS+= --enable-libx265
+.include "../../multimedia/x265/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-libx265
+.endif
+
+# VDPAU support
+.if !empty(PKG_OPTIONS:Mvdpau) && !empty(PKG_OPTIONS:Mx11)
+CONFIGURE_ARGS+= --enable-vdpau
+.include "../../multimedia/libvdpau/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-vdpau
+.endif
+
+# VAAPI support
+.if !empty(PKG_OPTIONS:Mvaapi) && !empty(PKG_OPTIONS:Mx11)
+CONFIGURE_ARGS+= --enable-vaapi
+.include "../../multimedia/libva/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-vaapi
+.endif
+
+# VPX support
+.if !empty(PKG_OPTIONS:Mlibvpx)
+CONFIGURE_ARGS+= --enable-libvpx
+.include "../../multimedia/libvpx/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-libvpx
+.endif
+
+# WEBP support
+.if !empty(PKG_OPTIONS:Mlibwebp)
+CONFIGURE_ARGS+= --enable-libwebp
+.include "../../graphics/libwebp/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-libwebp
+.endif
+
+# X11 screen capture support using libxcb
+.if !empty(PKG_OPTIONS:Mx11)
+CONFIGURE_ARGS+= --enable-libxcb
+CONFIGURE_ARGS+= --enable-libxcb-shape
+CONFIGURE_ARGS+= --enable-libxcb-shm
+CONFIGURE_ARGS+= --enable-libxcb-xfixes
+.include "../../x11/libxcb/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-libxcb
+.endif
+
+# Bluray support
+.if !empty(PKG_OPTIONS:Mbluray)
+CONFIGURE_ARGS+= --enable-libbluray
+.include "../../multimedia/libbluray/buildlink3.mk"
+.else
+CONFIGURE_ARGS+= --disable-libbluray
+.endif
Index: pkgsrc/multimedia/ffmpeg7/patches/patch-Makefile
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/patches/patch-Makefile:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/patches/patch-Makefile Sun Apr 7 17:50:23 2024
@@ -0,0 +1,15 @@
+$NetBSD: patch-Makefile,v 1.1 2024/04/07 17:50:23 ryoon Exp $
+
+Do "install -c".
+
+--- Makefile.orig 2018-04-20 10:02:55.000000000 +0000
++++ Makefile
+@@ -125,7 +125,7 @@ install-libs: install-libs-yes
+
+ install-data: $(DATA_FILES)
+ $(Q)mkdir -p "$(DATADIR)"
+- $(INSTALL) -m 644 $(DATA_FILES) "$(DATADIR)"
++ $(INSTALL) -c -m 644 $(DATA_FILES) "$(DATADIR)"
+
+ uninstall: uninstall-data uninstall-headers uninstall-libs uninstall-pkgconfig
+
Index: pkgsrc/multimedia/ffmpeg7/patches/patch-configure
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/patches/patch-configure:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/patches/patch-configure Sun Apr 7 17:50:23 2024
@@ -0,0 +1,87 @@
+$NetBSD: patch-configure,v 1.1 2024/04/07 17:50:23 ryoon Exp $
+
+Sun audio support.
+
+Enable PIC on NetBSD, even on i386, to avoid text relocations.
+
+Fix install_name_dir on Darwin.
+
+Do not use 'rsync'.
+
+--- configure.orig 2024-04-04 23:22:59.000000000 +0000
++++ configure
+@@ -2298,6 +2298,7 @@ HEADERS_LIST="
+ sys_resource_h
+ sys_select_h
+ sys_soundcard_h
++ sys_audioio_h
+ sys_time_h
+ sys_un_h
+ sys_videoio_h
+@@ -2443,7 +2444,6 @@ TOOLCHAIN_FEATURES="
+ inline_asm_labels
+ inline_asm_nonlocal_labels
+ pragma_deprecated
+- rsync_contimeout
+ symver_asm_label
+ symver_gnu_asm
+ vfp_args
+@@ -3695,6 +3695,8 @@ opengl_outdev_deps="opengl"
+ opengl_outdev_suggest="sdl2"
+ oss_indev_deps_any="sys_soundcard_h"
+ oss_outdev_deps_any="sys_soundcard_h"
++sunau_indev_deps_any="sys_audioio_h"
++sunau_outdev_deps_any="sys_audioio_h"
+ pulse_indev_deps="libpulse"
+ pulse_outdev_deps="libpulse"
+ sdl2_outdev_deps="sdl2"
+@@ -5711,6 +5713,7 @@ case $target_os in
+ netbsd)
+ disable symver
+ enable section_data_rel_ro
++ enable pic
+ oss_indev_extralibs="-lossaudio"
+ oss_outdev_extralibs="-lossaudio"
+ enabled gcc || check_ldflags -Wl,-zmuldefs
+@@ -5737,7 +5740,7 @@ case $target_os in
+ ;;
+ darwin)
+ enabled ppc && add_asflags -force_cpusubtype_ALL
+- install_name_dir_default='$(SHLIBDIR)'
++ install_name_dir_default=$shlibdir
+ SHFLAGS='-dynamiclib -Wl,-single_module -Wl,-install_name,$(INSTALL_NAME_DIR)/$(SLIBNAME_WITH_MAJOR),-current_version,$(LIBVERSION),-compatibility_version,$(LIBMAJOR)'
+ enabled x86_32 && append SHFLAGS -Wl,-read_only_relocs,suppress
+ strip="${strip} -x"
+@@ -6110,10 +6113,13 @@ extern_prefix=${sym%%ff_extern*}
+ check_cc pragma_deprecated "" '_Pragma("GCC diagnostic push") _Pragma("GCC diagnostic ignored \"-Wdeprecated-declarations\"")'
+
+ # The global variable ensures the bits appear unchanged in the object file.
+-test_cc <<EOF || die "endian test failed"
+-unsigned int endian = 'B' << 24 | 'I' << 16 | 'G' << 8 | 'E';
++test_exec <<EOF || enable bigendian
++int main()
++{
++ long one = 1;
++ return !(*((char *)(&one)));
++}
+ EOF
+-od -t x1 $TMPO | grep -q '42 *49 *47 *45' && enable bigendian
+
+ check_cc const_nan math.h "struct { double d; } static const bar[] = { { NAN } }"
+
+@@ -6598,6 +6604,7 @@ check_headers malloc.h
+ check_headers mftransform.h
+ check_headers net/udplite.h
+ check_headers poll.h
++check_headers sys/audioio.h
+ check_headers pthread_np.h
+ check_headers sys/param.h
+ check_headers sys/resource.h
+@@ -7129,7 +7136,6 @@ enabled makeinfo \
+ disabled makeinfo_html && texi2html --help 2> /dev/null | grep -q 'init-file' && enable texi2html || disable texi2html
+ perl -v > /dev/null 2>&1 && enable perl || disable perl
+ pod2man --help > /dev/null 2>&1 && enable pod2man || disable pod2man
+-rsync --help 2> /dev/null | grep -q 'contimeout' && enable rsync_contimeout || disable rsync_contimeout
+ xmllint --version > /dev/null 2>&1 && enable xmllint || disable xmllint
+
+ # check V4L2 codecs available in the API
Index: pkgsrc/multimedia/ffmpeg7/patches/patch-doc_Makefile
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/patches/patch-doc_Makefile:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/patches/patch-doc_Makefile Sun Apr 7 17:50:23 2024
@@ -0,0 +1,31 @@
+$NetBSD: patch-doc_Makefile,v 1.1 2024/04/07 17:50:23 ryoon Exp $
+
+Make man pages and html docs versioned.
+
+--- doc/Makefile.orig 2016-02-15 02:29:37.000000000 +0000
++++ doc/Makefile
+@@ -14,8 +14,8 @@ COMPONENTS-$(CONFIG_AVFORMAT) += ffmpe
+ COMPONENTS-$(CONFIG_AVDEVICE) += ffmpeg-devices
+ COMPONENTS-$(CONFIG_AVFILTER) += ffmpeg-filters
+
+-MANPAGES1 = $(AVPROGS-yes:%=doc/%.1) $(AVPROGS-yes:%=doc/%-all.1) $(COMPONENTS-yes:%=doc/%.1)
+-MANPAGES3 = $(LIBRARIES-yes:%=doc/%.3)
++MANPAGES1 = $(AVPROGS-yes:%=doc/%7.1) $(AVPROGS-yes:%=doc/%-all7.1) $(COMPONENTS-yes:%=doc/%7.1)
++MANPAGES3 = $(LIBRARIES-yes:%=doc/%7.3)
+ MANPAGES = $(MANPAGES1) $(MANPAGES3)
+ PODPAGES = $(AVPROGS-yes:%=doc/%.pod) $(AVPROGS-yes:%=doc/%-all.pod) $(COMPONENTS-yes:%=doc/%.pod) $(LIBRARIES-yes:%=doc/%.pod)
+ HTMLPAGES = $(AVPROGS-yes:%=doc/%.html) $(AVPROGS-yes:%=doc/%-all.html) $(COMPONENTS-yes:%=doc/%.html) $(LIBRARIES-yes:%=doc/%.html) \
+@@ -114,10 +114,10 @@ doc/%-all.pod: doc/%.texi $(SRC_PATH)/do
+ $(Q)$(TEXIDEP)
+ $(M)perl $(SRC_PATH)/doc/texi2pod.pl -Dconfig-all=yes -Idoc $< $@
+
+-doc/%.1 doc/%.3: TAG = MAN
+-doc/%.1: doc/%.pod $(GENTEXI)
++doc/%7.1 doc/%7.3: TAG = MAN
++doc/%7.1: doc/%.pod $(GENTEXI)
+ $(M)pod2man --section=1 --center=" " --release=" " --date=" " $< > $@
+-doc/%.3: doc/%.pod $(GENTEXI)
++doc/%7.3: doc/%.pod $(GENTEXI)
+ $(M)pod2man --section=3 --center=" " --release=" " --date=" " $< > $@
+
+ $(DOCS) doc/doxy/html: | doc/
Index: pkgsrc/multimedia/ffmpeg7/patches/patch-doc_general__contents.texi
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/patches/patch-doc_general__contents.texi:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/patches/patch-doc_general__contents.texi Sun Apr 7 17:50:23 2024
@@ -0,0 +1,14 @@
+$NetBSD: patch-doc_general__contents.texi,v 1.1 2024/04/07 17:50:23 ryoon Exp $
+
+Add Sun Audio.
+
+--- doc/general_contents.texi.orig 2021-04-10 06:55:24.000000000 +0000
++++ doc/general_contents.texi
+@@ -1419,6 +1419,7 @@ performance on systems without hardware
+ @item OSS @tab X @tab X
+ @item PulseAudio @tab X @tab X
+ @item SDL @tab @tab X
++@item Sun Audio @tab @tab X
+ @item Video4Linux2 @tab X @tab X
+ @item VfW capture @tab X @tab
+ @item X11 grabbing @tab X @tab
Index: pkgsrc/multimedia/ffmpeg7/patches/patch-doc_indevs.texi
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/patches/patch-doc_indevs.texi:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/patches/patch-doc_indevs.texi Sun Apr 7 17:50:23 2024
@@ -0,0 +1,42 @@
+$NetBSD: patch-doc_indevs.texi,v 1.1 2024/04/07 17:50:23 ryoon Exp $
+
+* Add sunau documentation.
+
+--- doc/indevs.texi.orig 2019-12-31 21:35:22.000000000 +0000
++++ doc/indevs.texi
+@@ -1282,6 +1282,35 @@ Set the number of channels. Default is 2
+
+ @end table
+
++@section sunau
++
++Solaris/NetBSD audio input device.
++
++The filename to provide to the input device is the device node
++representing the Sun input device, and is usually set to
++@file{/dev/audio0}.
++
++For example to grab from @file{/dev/audio0} using @command{ffmpeg} use the
++command:
++@example
++ffmpeg -f sunau -i /dev/audio0 /tmp/oss.wav
++@end example
++
++@subsection Options
++
++@table @option
++
++@item buffer_samples
++Set the size of the audio buffer in samples. Default is 32.
++
++@item sample_rate
++Set the sample rate in Hz. Default is 48000.
++
++@item channels
++Set the number of channels. Default is 2.
++
++@end table
++
+ @section video4linux2, v4l2
+
+ Video4Linux2 input video device.
Index: pkgsrc/multimedia/ffmpeg7/patches/patch-doc_outdevs.texi
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/patches/patch-doc_outdevs.texi:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/patches/patch-doc_outdevs.texi Sun Apr 7 17:50:23 2024
@@ -0,0 +1,24 @@
+$NetBSD: patch-doc_outdevs.texi,v 1.1 2024/04/07 17:50:23 ryoon Exp $
+
+* Add sunau documentation.
+
+--- doc/outdevs.texi.orig 2019-12-31 21:35:22.000000000 +0000
++++ doc/outdevs.texi
+@@ -393,6 +393,17 @@ ffmpeg -i INPUT -c:v rawvideo -pix_fmt y
+
+ sndio audio output device.
+
++@section sunau
++
++Solaris/NetBSD audio output device.
++
++@subsection Options
++@table @option
++
++@item buffer_samples
++Set the size of the audio buffer in samples. Default is 32.
++@end table
++
+ @section v4l2
+
+ Video4Linux2 output device.
Index: pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_Makefile
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_Makefile:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_Makefile Sun Apr 7 17:50:23 2024
@@ -0,0 +1,15 @@
+$NetBSD: patch-libavdevice_Makefile,v 1.1 2024/04/07 17:50:23 ryoon Exp $
+
+Sun audio support.
+
+--- libavdevice/Makefile.orig 2019-12-31 21:35:24.000000000 +0000
++++ libavdevice/Makefile
+@@ -43,6 +43,8 @@ OBJS-$(CONFIG_PULSE_OUTDEV)
+ OBJS-$(CONFIG_SDL2_OUTDEV) += sdl2.o
+ OBJS-$(CONFIG_SNDIO_INDEV) += sndio_dec.o sndio.o
+ OBJS-$(CONFIG_SNDIO_OUTDEV) += sndio_enc.o sndio.o
++OBJS-$(CONFIG_SUNAU_INDEV) += sunau_dec.o sunau.o
++OBJS-$(CONFIG_SUNAU_OUTDEV) += sunau_enc.o sunau.o
+ OBJS-$(CONFIG_V4L2_INDEV) += v4l2.o v4l2-common.o timefilter.o
+ OBJS-$(CONFIG_V4L2_OUTDEV) += v4l2enc.o v4l2-common.o
+ OBJS-$(CONFIG_VFWCAP_INDEV) += vfwcap.o
Index: pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_sunau.c
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_sunau.c:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_sunau.c Sun Apr 7 17:50:23 2024
@@ -0,0 +1,110 @@
+$NetBSD: patch-libavdevice_sunau.c,v 1.1 2024/04/07 17:50:23 ryoon Exp $
+
+Sun audio support.
+
+--- libavdevice/sunau.c.orig 2023-06-02 16:15:11.549198344 +0000
++++ libavdevice/sunau.c
+@@ -0,0 +1,103 @@
++/*
++ * Solaris/NetBSD play and grab interface
++ * Copyright (c) 2020 Yorick Hardy
++ * Copyright (c) 2020 Nia Alarie <nia%NetBSD.org@localhost>
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#include "config.h"
++
++#include <string.h>
++
++#include <unistd.h>
++#include <fcntl.h>
++#include <sys/audioio.h>
++#include <sys/ioctl.h>
++
++#include "libavutil/file_open.h"
++#include "libavutil/log.h"
++
++#include "libavcodec/avcodec.h"
++#include "avdevice.h"
++
++#include "sunau.h"
++
++int ff_sunau_audio_open(AVFormatContext *s1, int is_output,
++ const char *audio_device)
++{
++ SunAudioData *s = s1->priv_data;
++ struct audio_info info;
++ struct audio_prinfo *prinfo;
++ int audio_fd, err;
++
++ audio_fd = avpriv_open(audio_device, is_output ? O_WRONLY : O_RDONLY);
++ if (audio_fd < 0) {
++ av_log(s1, AV_LOG_ERROR, "%s: %s\n", audio_device, av_err2str(AVERROR(errno)));
++ return AVERROR(EIO);
++ }
++
++ AUDIO_INITINFO(&info);
++
++#ifdef AUMODE_PLAY /* BSD extension */
++ info.mode = is_output ? AUMODE_PLAY : AUMODE_RECORD;
++#endif
++
++ prinfo = is_output ? &info.play : &info.record;
++
++ prinfo->encoding = AUDIO_ENCODING_LINEAR;
++ prinfo->precision = 16;
++ prinfo->sample_rate = s->sample_rate;
++ prinfo->channels = s->channels;
++
++ if ((err = ioctl(audio_fd, AUDIO_SETINFO, &info)) < 0) {
++ av_log(s1, AV_LOG_ERROR, "AUDIO_SETINFO: %s\n", av_err2str(AVERROR(errno)));
++ goto fail;
++ }
++
++ if ((err = ioctl(audio_fd, AUDIO_GETINFO, &info)) < 0) {
++ av_log(s1, AV_LOG_ERROR, "AUDIO_GETINFO: %s\n", av_err2str(AVERROR(errno)));
++ goto fail;
++ }
++
++ s->fd = audio_fd;
++#if HAVE_BIGENDIAN
++ s->codec_id = AV_CODEC_ID_PCM_S16BE;
++#else
++ s->codec_id = AV_CODEC_ID_PCM_S16LE;
++#endif
++ s->precision = prinfo->precision;
++ s->sample_rate = prinfo->sample_rate;
++ s->channels = prinfo->channels;
++ s->blocksize = s->buffer_samples * prinfo->precision * prinfo->channels;
++
++ if ((s->buffer = malloc(s->blocksize)) == NULL) {
++ av_log(s1, AV_LOG_ERROR, "malloc: %s\n", av_err2str(AVERROR(errno)));
++ goto fail;
++ }
++
++ return 0;
++ fail:
++ close(audio_fd);
++ return AVERROR(EIO);
++}
++
++int ff_sunau_audio_close(SunAudioData *s)
++{
++ close(s->fd);
++ return 0;
++}
Index: pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_sunau.h
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_sunau.h:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_sunau.h Sun Apr 7 17:50:24 2024
@@ -0,0 +1,55 @@
+$NetBSD: patch-libavdevice_sunau.h,v 1.1 2024/04/07 17:50:24 ryoon Exp $
+
+Sun audio support.
+
+--- libavdevice/sunau.h.orig 2020-03-20 20:53:01.579839153 +0000
++++ libavdevice/sunau.h
+@@ -0,0 +1,48 @@
++/*
++ * Solaris/NetBSD play and grab interface
++ * Copyright (c) 2020 Yorick Hardy
++ * Copyright (c) 2020 Nia Alarie <nia%NetBSD.org@localhost>
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#ifndef AVDEVICE_SUNAU_H
++#define AVDEVICE_SUNAU_H
++
++#include "libavcodec/avcodec.h"
++
++#include "libavformat/avformat.h"
++
++typedef struct SunAudioData {
++ AVClass *class;
++ int fd;
++ int buffer_samples;
++ unsigned int sample_rate;
++ unsigned int channels;
++ unsigned int precision;
++ size_t blocksize;
++ enum AVCodecID codec_id;
++ uint8_t *buffer;
++ size_t buffer_ptr;
++} SunAudioData;
++
++int ff_sunau_audio_open(AVFormatContext *s1, int is_output,
++ const char *audio_device);
++
++int ff_sunau_audio_close(SunAudioData *s);
++
++#endif /* AVDEVICE_SUNAU_H */
Index: pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_sunau__dec.c
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_sunau__dec.c:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_sunau__dec.c Sun Apr 7 17:50:24 2024
@@ -0,0 +1,145 @@
+$NetBSD: patch-libavdevice_sunau__dec.c,v 1.1 2024/04/07 17:50:24 ryoon Exp $
+
+Sun audio support.
+
+--- libavdevice/sunau_dec.c.orig 2020-03-20 20:53:01.607986932 +0000
++++ libavdevice/sunau_dec.c
+@@ -0,0 +1,138 @@
++/*
++ * Solaris/NetBSD play and grab interface
++ * Copyright (c) 2020 Yorick Hardy
++ * Copyright (c) 2020 Nia Alarie <nia%NetBSD.org@localhost>
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#include "config.h"
++
++#include <stdint.h>
++
++#include <unistd.h>
++#include <fcntl.h>
++#include <poll.h>
++#include <sys/audioio.h>
++#include <sys/ioctl.h>
++
++#include "libavutil/internal.h"
++#include "libavutil/opt.h"
++#include "libavutil/time.h"
++
++#include "libavcodec/avcodec.h"
++
++#include "avdevice.h"
++#include "libavformat/internal.h"
++
++#include "sunau.h"
++
++static int audio_read_header(AVFormatContext *s1)
++{
++ SunAudioData *s = s1->priv_data;
++ AVStream *st;
++
++ st = avformat_new_stream(s1, NULL);
++ if (!st) {
++ return AVERROR(ENOMEM);
++ }
++
++ if (ff_sunau_audio_open(s1, 0, s1->url) < 0) {
++ return AVERROR(EIO);
++ }
++
++ /* take real parameters */
++ st->codecpar->codec_type = AVMEDIA_TYPE_AUDIO;
++ st->codecpar->codec_id = s->codec_id;
++ st->codecpar->sample_rate = s->sample_rate;
++ st->codecpar->channels = s->channels;
++
++ avpriv_set_pts_info(st, 64, 1, 1000000); /* 64 bits pts in us */
++
++ return 0;
++}
++
++static int audio_read_packet(AVFormatContext *s1, AVPacket *pkt)
++{
++ SunAudioData *s = s1->priv_data;
++ struct audio_info info;
++ int ret;
++ long bdelay;
++ int64_t cur_time;
++
++ if ((ret = av_new_packet(pkt, s->blocksize)) < 0)
++ return ret;
++
++ ret = read(s->fd, pkt->data, pkt->size);
++ if (ret <= 0) {
++ av_packet_unref(pkt);
++ pkt->size = 0;
++ return ret < 0 ? AVERROR(errno) : AVERROR_EOF;
++ }
++
++ /* compute pts of the start of the packet */
++ cur_time = av_gettime();
++ bdelay = ret;
++
++#ifdef AUDIO_GETBUFINFO /* BSD extension */
++ if (ioctl(s->fd, AUDIO_GETBUFINFO, &info) == 0) {
++ bdelay += info.record.seek;
++ }
++#endif
++
++ /* subtract time represented by the number of bytes in the audio fifo */
++ cur_time -= (bdelay * 1000000LL) / (s->sample_rate * s->channels * s->precision);
++
++ /* convert to wanted units */
++ pkt->pts = cur_time;
++
++ return 0;
++}
++
++static int audio_read_close(AVFormatContext *s1)
++{
++ SunAudioData *s = s1->priv_data;
++
++ ff_sunau_audio_close(s);
++ return 0;
++}
++
++static const AVOption options[] = {
++ { "buffer_samples", "", offsetof(SunAudioData, buffer_samples), AV_OPT_TYPE_INT, {.i64 = 32}, 1, INT_MAX, AV_OPT_FLAG_DECODING_PARAM },
++ { "sample_rate", "", offsetof(SunAudioData, sample_rate), AV_OPT_TYPE_INT, {.i64 = 48000}, 1000, 192000, AV_OPT_FLAG_DECODING_PARAM },
++ { "channels", "", offsetof(SunAudioData, channels), AV_OPT_TYPE_INT, {.i64 = 2}, 1, 12, AV_OPT_FLAG_DECODING_PARAM },
++ { NULL },
++};
++
++static const AVClass sunau_demuxer_class = {
++ .class_name = "Sun/NetBSD audio demuxer",
++ .item_name = av_default_item_name,
++ .option = options,
++ .version = LIBAVUTIL_VERSION_INT,
++ .category = AV_CLASS_CATEGORY_DEVICE_AUDIO_INPUT,
++};
++
++AVInputFormat ff_sunau_demuxer = {
++ .name = "sunau",
++ .long_name = NULL_IF_CONFIG_SMALL("Sun/NetBSD audio capture"),
++ .priv_data_size = sizeof(SunAudioData),
++ .read_header = audio_read_header,
++ .read_packet = audio_read_packet,
++ .read_close = audio_read_close,
++ .flags = AVFMT_NOFILE,
++ .priv_class = &sunau_demuxer_class,
++};
Index: pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_sunau__enc.c
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_sunau__enc.c:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/patches/patch-libavdevice_sunau__enc.c Sun Apr 7 17:50:24 2024
@@ -0,0 +1,121 @@
+$NetBSD: patch-libavdevice_sunau__enc.c,v 1.1 2024/04/07 17:50:24 ryoon Exp $
+
+Sun audio support.
+
+--- libavdevice/sunau_enc.c.orig 2020-03-20 20:53:01.636938971 +0000
++++ libavdevice/sunau_enc.c
+@@ -0,0 +1,114 @@
++/*
++ * Solaris/NetBSD play and grab interface
++ * Copyright (c) 2020 Yorick Hardy
++ * Copyright (c) 2020 Nia Alarie <nia%NetBSD.org@localhost>
++ *
++ * This file is part of FFmpeg.
++ *
++ * FFmpeg is free software; you can redistribute it and/or
++ * modify it under the terms of the GNU Lesser General Public
++ * License as published by the Free Software Foundation; either
++ * version 2.1 of the License, or (at your option) any later version.
++ *
++ * FFmpeg is distributed in the hope that it will be useful,
++ * but WITHOUT ANY WARRANTY; without even the implied warranty of
++ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
++ * Lesser General Public License for more details.
++ *
++ * You should have received a copy of the GNU Lesser General Public
++ * License along with FFmpeg; if not, write to the Free Software
++ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
++ */
++
++#include "config.h"
++
++#include <unistd.h>
++#include <fcntl.h>
++#include <sys/audioio.h>
++#include <sys/ioctl.h>
++
++#include "libavutil/internal.h"
++
++#include "libavcodec/avcodec.h"
++
++#include "avdevice.h"
++#include "libavformat/internal.h"
++
++#include "sunau.h"
++
++static int audio_write_header(AVFormatContext *s1)
++{
++ SunAudioData *s = s1->priv_data;
++ AVStream *st;
++
++ st = s1->streams[0];
++ s->sample_rate = st->codecpar->sample_rate;
++ s->channels = st->codecpar->channels;
++ s->codec_id = st->codecpar->codec_id;
++ return ff_sunau_audio_open(s1, 1, s1->url) < 0 ? AVERROR(EIO) : 0;
++}
++
++static int audio_write_packet(AVFormatContext *s1, AVPacket *pkt)
++{
++ SunAudioData *s = s1->priv_data;
++ unsigned int len, size = pkt->size;
++ uint8_t *buf = pkt->data;
++ int ret;
++
++ while (size > 0) {
++ len = FFMIN(s->blocksize - s->buffer_ptr, size);
++ memcpy(s->buffer + s->buffer_ptr, buf, len);
++ s->buffer_ptr += len;
++ if (s->buffer_ptr >= s->blocksize) {
++ for (;;) {
++ ret = write(s->fd, s->buffer, s->blocksize);
++ if (ret > 0)
++ break;
++ if (ret < 0 && (errno != EAGAIN && errno != EINTR))
++ return AVERROR(EIO);
++ }
++ s->buffer_ptr = 0;
++ }
++ buf += len;
++ size -= len;
++ }
++ return 0;
++}
++
++static int audio_write_trailer(AVFormatContext *s1)
++{
++ SunAudioData *s = s1->priv_data;
++
++ ff_sunau_audio_close(s);
++ return 0;
++}
++
++static const AVOption options[] = {
++ { "buffer_samples", "", offsetof(SunAudioData, buffer_samples), AV_OPT_TYPE_INT, {.i64 = 32}, 1, 192000, AV_OPT_FLAG_DECODING_PARAM },
++ { NULL },
++};
++
++static const AVClass sunau_muxer_class = {
++ .class_name = "Sun/NetBSD audio muxer",
++ .item_name = av_default_item_name,
++ .option = options,
++ .version = LIBAVUTIL_VERSION_INT,
++ .category = AV_CLASS_CATEGORY_DEVICE_AUDIO_OUTPUT,
++};
++
++AVOutputFormat ff_sunau_muxer = {
++ .name = "sunau",
++ .long_name = NULL_IF_CONFIG_SMALL("Sun/NetBSD audio playback"),
++ .priv_data_size = sizeof(SunAudioData),
++ /* XXX: we may need to support higher precisions in the future, but
++ right now this is what the kernel can handle natively */
++ /* XXX: find better solution with "preinit" method, needed also in
++ other formats */
++ .audio_codec = AV_NE(AV_CODEC_ID_PCM_S16BE, AV_CODEC_ID_PCM_S16LE),
++ .video_codec = AV_CODEC_ID_NONE,
++ .write_header = audio_write_header,
++ .write_packet = audio_write_packet,
++ .write_trailer = audio_write_trailer,
++ .flags = AVFMT_NOFILE,
++ .priv_class = &sunau_muxer_class,
++};
Index: pkgsrc/multimedia/ffmpeg7/patches/patch-libavformat_avformat.h
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/patches/patch-libavformat_avformat.h:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/patches/patch-libavformat_avformat.h Sun Apr 7 17:50:24 2024
@@ -0,0 +1,17 @@
+$NetBSD: patch-libavformat_avformat.h,v 1.1 2024/04/07 17:50:24 ryoon Exp $
+
+expose av_stream_get_first_dts() for chromium - from ArchLinux
+
+--- libavformat/avformat.h.orig 2024-04-04 23:23:00.000000000 +0000
++++ libavformat/avformat.h
+@@ -1170,6 +1170,10 @@ typedef struct AVStreamGroup {
+
+ struct AVCodecParserContext *av_stream_get_parser(const AVStream *s);
+
++// Chromium: We use the internal field first_dts vvv
++int64_t av_stream_get_first_dts(const AVStream *st);
++// Chromium: We use the internal field first_dts ^^^
++
+ #define AV_PROGRAM_RUNNING 1
+
+ /**
Index: pkgsrc/multimedia/ffmpeg7/patches/patch-libavformat_mux__utils.c
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/patches/patch-libavformat_mux__utils.c:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/patches/patch-libavformat_mux__utils.c Sun Apr 7 17:50:24 2024
@@ -0,0 +1,20 @@
+$NetBSD: patch-libavformat_mux__utils.c,v 1.1 2024/04/07 17:50:24 ryoon Exp $
+
+expose av_stream_get_first_dts() for chromium - from ArchLinux
+
+--- libavformat/mux_utils.c.orig 2024-04-04 23:23:00.000000000 +0000
++++ libavformat/mux_utils.c
+@@ -30,6 +30,13 @@
+ #include "internal.h"
+ #include "mux.h"
+
++// Chromium: We use the internal field first_dts vvv
++int64_t av_stream_get_first_dts(const AVStream *st)
++{
++ return cffstream(st)->first_dts;
++}
++// Chromium: We use the internal field first_dts ^^^
++
+ int avformat_query_codec(const AVOutputFormat *ofmt, enum AVCodecID codec_id,
+ int std_compliance)
+ {
Index: pkgsrc/multimedia/ffmpeg7/patches/patch-libavutil_macros.h
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/patches/patch-libavutil_macros.h:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/patches/patch-libavutil_macros.h Sun Apr 7 17:50:24 2024
@@ -0,0 +1,29 @@
+$NetBSD: patch-libavutil_macros.h,v 1.1 2024/04/07 17:50:24 ryoon Exp $
+
+Add required int includes on various opensource platforms.
+
+--- libavutil/macros.h.orig 2022-01-14 18:45:40.000000000 +0000
++++ libavutil/macros.h
+@@ -27,6 +27,22 @@
+
+ #include "libavutil/avconfig.h"
+
++#if defined(__cplusplus)
++#if defined(__FreeBSD__) || defined(__OpenBSD__) || defined(__linux__)
++#undef _STDINT_H_
++#undef _SYS_STDINT_H_
++#undef _STDINT_H
++#undef _GCC_WRAP_STDINT_H
++#ifndef __STDC_CONSTANT_MACROS
++#define __STDC_CONSTANT_MACROS
++#endif
++#include <stdint.h>
++#endif /* FreeBSD | OpenBSD | linux */
++#if defined(__DragonFly__) || defined(__NetBSD__)
++#include <machine/int_const.h>
++#endif /* DragonFly | NetBSD */
++#endif /* __cplusplus */
++
+ #if AV_HAVE_BIGENDIAN
+ # define AV_NE(be, le) (be)
+ #else
Index: pkgsrc/multimedia/ffmpeg7/patches/patch-libavutil_ppc_cpu.c
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/patches/patch-libavutil_ppc_cpu.c:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/patches/patch-libavutil_ppc_cpu.c Sun Apr 7 17:50:24 2024
@@ -0,0 +1,26 @@
+$NetBSD: patch-libavutil_ppc_cpu.c,v 1.1 2024/04/07 17:50:24 ryoon Exp $
+
+Handle machdep.altivec on NetBSD like on OpenBSD.
+
+--- libavutil/ppc/cpu.c.orig 2023-11-09 23:38:54.000000000 +0000
++++ libavutil/ppc/cpu.c
+@@ -27,7 +27,7 @@
+ #if HAVE_UNISTD_H
+ #include <unistd.h>
+ #endif
+-#elif defined(__OpenBSD__)
++#elif defined(__NetBSD__) || defined(__OpenBSD__)
+ #include <sys/types.h>
+ #include <sys/sysctl.h>
+ #include <machine/cpu.h>
+@@ -56,8 +56,8 @@ int ff_get_cpu_flags_ppc(void)
+ if (result == VECTORTYPE_ALTIVEC)
+ return AV_CPU_FLAG_ALTIVEC;
+ return 0;
+-#elif defined(__APPLE__) || defined(__OpenBSD__)
+-#ifdef __OpenBSD__
++#elif defined(__APPLE__) || defined(__NetBSD__) || defined(__OpenBSD__)
++#if defined(__NetBSD__) || defined(__OpenBSD__)
+ int sels[2] = {CTL_MACHDEP, CPU_ALTIVEC};
+ #else
+ int sels[2] = {CTL_HW, HW_VECTORUNIT};
Index: pkgsrc/multimedia/ffmpeg7/patches/patch-libavutil_x86_asm.h
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/patches/patch-libavutil_x86_asm.h:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/patches/patch-libavutil_x86_asm.h Sun Apr 7 17:50:24 2024
@@ -0,0 +1,18 @@
+$NetBSD: patch-libavutil_x86_asm.h,v 1.1 2024/04/07 17:50:24 ryoon Exp $
+
+Avoid SunOS regset.h definition for REG_SP
+
+--- libavutil/x86/asm.h.orig 2016-10-28 18:31:25.000000000 +0000
++++ libavutil/x86/asm.h
+@@ -27,6 +27,11 @@
+ typedef struct xmm_reg { uint64_t a, b; } xmm_reg;
+ typedef struct ymm_reg { uint64_t a, b, c, d; } ymm_reg;
+
++/* avoid SunOS regset.h definition for REG_SP */
++#if defined (__sun) && defined (REG_SP)
++#undef REG_SP
++#endif
++
+ #if ARCH_X86_64
+ # define FF_OPSIZE "q"
+ # define FF_REG_a "rax"
Index: pkgsrc/multimedia/ffmpeg7/patches/patch-libavutil_x86_cpu.c
diff -u /dev/null pkgsrc/multimedia/ffmpeg7/patches/patch-libavutil_x86_cpu.c:1.1
--- /dev/null Sun Apr 7 17:50:24 2024
+++ pkgsrc/multimedia/ffmpeg7/patches/patch-libavutil_x86_cpu.c Sun Apr 7 17:50:24 2024
@@ -0,0 +1,22 @@
+$NetBSD: patch-libavutil_x86_cpu.c,v 1.1 2024/04/07 17:50:24 ryoon Exp $
+
+Make a part of the code depend on GCC >= 4.2.
+
+--- libavutil/x86/cpu.c.orig 2016-01-15 16:58:37.000000000 +0000
++++ libavutil/x86/cpu.c
+@@ -116,6 +116,7 @@ int ff_get_cpu_flags_x86(void)
+ #if HAVE_SSE
+ if (std_caps & (1 << 25))
+ rval |= AV_CPU_FLAG_SSE;
++#if !defined(__GNUC__) || (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 2))
+ if (std_caps & (1 << 26))
+ rval |= AV_CPU_FLAG_SSE2;
+ if (ecx & 1)
+@@ -138,6 +139,7 @@ int ff_get_cpu_flags_x86(void)
+ }
+ }
+ #endif /* HAVE_AVX */
++#endif /* gcc >= 4.2 */
+ #endif /* HAVE_SSE */
+ }
+ if (max_std_level >= 7) {
Home |
Main Index |
Thread Index |
Old Index