2024-07-23 15:31:36 +00:00
vcpkg_from_github (
O U T _ S O U R C E _ P A T H S O U R C E _ P A T H
R E P O f f m p e g / f f m p e g
fix qsv memory leak by updating ffmpeg (#9266)
* fix qsv memory leak by updating ffmpeg
* Memory leaks occur when destroying FFmpeg QSV VRAM encoders. This issue is resolved with FFmpeg version 7.
* FFmpeg requires ffnvcodec version 12.1.14.0 or higher, and an NVIDIA driver version greater than 530. For more details, https://github.com/FFmpeg/nv-codec-headers/tree/n12.1.14.0.
* The code of NVIDIA VRAM encoder is not changed, still use Video Codec SDK version 11, which is unaffected by FFmpeg. Drivers newer than 470 can support this, but we may consider an update later, as the support check by sdk code may not be accurate for FFmpeg RAM encoders.
* The issue is related to FFmpeg, not libmfx. FFmpeg version 7 recommends using libvpl, but vcpkg currently lacks ports for libvpl. We can add these in the future.
* D3D11 Texture Rendering: The "Shared GPU Memory" in the task manager continue increasing when using D3D11 texture render, which can exceed the GPU memory limit (e.g., reaching up to 100GB). I don't know what it is and will try to find it out.
* Roughly tests on Windows, Linux, macOS, and Android for quick fix. Further testing will be performed, and I will share the results in this pr.
Signed-off-by: 21pages <sunboeasy@gmail.com>
* update flutter_gpu_texture_render, fix shared gpu memory leak while
rendering
Signed-off-by: 21pages <sunboeasy@gmail.com>
---------
Signed-off-by: 21pages <sunboeasy@gmail.com>
2024-09-07 10:20:52 +08:00
R E F " n $ { V E R S I O N } "
S H A 5 1 2 3 b a 0 2 e 8 b 9 7 9 c 8 0 b f 6 1 d 5 5 f 4 1 4 b d a c 2 c 7 5 6 5 7 8 b b 3 6 4 9 8 e d 7 4 8 6 1 5 1 7 5 5 c 6 c c f 8 b d 8 f f 2 b 8 c 7 a f a 3 c 5 d 1 a c d 8 6 2 c e 4 8 3 1 4 8 8 6 a 8 6 a 1 0 5 6 1 3 c 0 5 e 3 6 6 0 1 9 8 4 c 3 3 4 f 8 f 6 b f
2024-07-23 15:31:36 +00:00
H E A D _ R E F m a s t e r
P A T C H E S
0 0 0 2 - f i x - m s v c - l i n k . p a t c h # upstreamed in future version
0 0 0 3 - f i x - w i n d o w s i n c l u d e . p a t c h
0 0 0 5 - f i x - n a s m . p a t c h # upstreamed in future version
0 0 1 2 - F i x - s s l - 1 1 0 - d e t e c t i o n . p a t c h
0 0 1 3 - d e f i n e - W I N V E R . p a t c h
fix qsv memory leak by updating ffmpeg (#9266)
* fix qsv memory leak by updating ffmpeg
* Memory leaks occur when destroying FFmpeg QSV VRAM encoders. This issue is resolved with FFmpeg version 7.
* FFmpeg requires ffnvcodec version 12.1.14.0 or higher, and an NVIDIA driver version greater than 530. For more details, https://github.com/FFmpeg/nv-codec-headers/tree/n12.1.14.0.
* The code of NVIDIA VRAM encoder is not changed, still use Video Codec SDK version 11, which is unaffected by FFmpeg. Drivers newer than 470 can support this, but we may consider an update later, as the support check by sdk code may not be accurate for FFmpeg RAM encoders.
* The issue is related to FFmpeg, not libmfx. FFmpeg version 7 recommends using libvpl, but vcpkg currently lacks ports for libvpl. We can add these in the future.
* D3D11 Texture Rendering: The "Shared GPU Memory" in the task manager continue increasing when using D3D11 texture render, which can exceed the GPU memory limit (e.g., reaching up to 100GB). I don't know what it is and will try to find it out.
* Roughly tests on Windows, Linux, macOS, and Android for quick fix. Further testing will be performed, and I will share the results in this pr.
Signed-off-by: 21pages <sunboeasy@gmail.com>
* update flutter_gpu_texture_render, fix shared gpu memory leak while
rendering
Signed-off-by: 21pages <sunboeasy@gmail.com>
---------
Signed-off-by: 21pages <sunboeasy@gmail.com>
2024-09-07 10:20:52 +08:00
p a t c h / 0 0 0 1 - a v c o d e c - a m f e n c - a d d - q u e r y _ t i m e o u t - o p t i o n - f o r - h 2 6 4 - h e v . p a t c h
p a t c h / 0 0 0 2 - l i b a v c o d e c - a m f e n c - r e c o n f i g - w h e n - b i t r a t e - c h a n g e . p a t c h
p a t c h / 0 0 0 3 - a m f - c o l o r s p a c e . p a t c h
2024-07-23 15:31:36 +00:00
)
if ( SOURCE_PATH MATCHES " " )
message ( FATAL_ERROR "Error: ffmpeg will not build with spaces in the path. Please use a directory with no spaces" )
endif ( )
if ( NOT VCPKG_TARGET_ARCHITECTURE STREQUAL "wasm32" )
vcpkg_find_acquire_program ( NASM )
get_filename_component ( NASM_EXE_PATH "${NASM}" DIRECTORY )
vcpkg_add_to_path ( "${NASM_EXE_PATH}" )
endif ( )
set ( OPTIONS " \
- - d i s a b l e - s h a r e d \
- - e n a b l e - s t a t i c \
- - e n a b l e - p i c \
- - d i s a b l e - e v e r y t h i n g \
- - d i s a b l e - p r o g r a m s \
- - d i s a b l e - d o c \
- - d i s a b l e - h t m l p a g e s \
- - d i s a b l e - m a n p a g e s \
- - d i s a b l e - p o d p a g e s \
- - d i s a b l e - t x t p a g e s \
- - d i s a b l e - n e t w o r k \
- - d i s a b l e - a p p k i t \
- - d i s a b l e - c o r e i m a g e \
- - d i s a b l e - m e t a l \
- - d i s a b l e - s d l 2 \
- - d i s a b l e - s e c u r e t r a n s p o r t \
- - d i s a b l e - v u l k a n \
- - d i s a b l e - a u d i o t o o l b o x \
- - d i s a b l e - v 4 l 2 - m 2 m \
- - d i s a b l e - d e b u g \
- - d i s a b l e - v a l g r i n d - b a c k t r a c e \
- - d i s a b l e - l a r g e - t e s t s \
- - d i s a b l e - a v d e v i c e \
- - e n a b l e - a v c o d e c \
- - e n a b l e - a v f o r m a t \
- - d i s a b l e - a v f i l t e r \
- - d i s a b l e - s w r e s a m p l e \
- - d i s a b l e - s w s c a l e \
- - d i s a b l e - p o s t p r o c \
- - e n a b l e - d e c o d e r = h 2 6 4 \
- - e n a b l e - d e c o d e r = h e v c \
- - e n a b l e - p a r s e r = h 2 6 4 \
- - e n a b l e - p a r s e r = h e v c \
- - e n a b l e - b s f = h 2 6 4 _ m p 4 t o a n n e x b \
- - e n a b l e - b s f = h e v c _ m p 4 t o a n n e x b \
- - e n a b l e - b s f = h 2 6 4 _ m e t a d a t a \
- - e n a b l e - b s f = h e v c _ m e t a d a t a \
- - e n a b l e - m u x e r = m p 4 \
- - e n a b l e - p r o t o c o l = f i l e \
" )
if ( VCPKG_HOST_IS_WINDOWS )
vcpkg_acquire_msys ( MSYS_ROOT PACKAGES automake1.16 )
set ( SHELL "${MSYS_ROOT}/usr/bin/bash.exe" )
vcpkg_add_to_path ( "${MSYS_ROOT}/usr/share/automake-1.16" )
string ( APPEND OPTIONS " --pkg-config=${CURRENT_HOST_INSTALLED_DIR}/tools/pkgconf/pkgconf${VCPKG_HOST_EXECUTABLE_SUFFIX}" )
else ( )
find_program ( SHELL bash )
endif ( )
if ( VCPKG_TARGET_IS_LINUX )
string ( APPEND OPTIONS " \
- - t a r g e t - o s = l i n u x \
- - e n a b l e - p t h r e a d s \
" )
if ( VCPKG_TARGET_ARCHITECTURE STREQUAL "arm" )
else ( )
string ( APPEND OPTIONS " \
- - e n a b l e - c u d a \
- - e n a b l e - f f n v c o d e c \
- - e n a b l e - e n c o d e r = h 2 6 4 _ n v e n c \
- - e n a b l e - e n c o d e r = h e v c _ n v e n c \
- - e n a b l e - h w a c c e l = h 2 6 4 _ n v d e c \
- - e n a b l e - h w a c c e l = h e v c _ n v d e c \
- - e n a b l e - a m f \
- - e n a b l e - e n c o d e r = h 2 6 4 _ a m f \
- - e n a b l e - e n c o d e r = h e v c _ a m f \
- - e n a b l e - h w a c c e l = h 2 6 4 _ v a a p i \
- - e n a b l e - h w a c c e l = h e v c _ v a a p i \
- - e n a b l e - e n c o d e r = h 2 6 4 _ v a a p i \
- - e n a b l e - e n c o d e r = h e v c _ v a a p i \
" )
if ( VCPKG_TARGET_ARCHITECTURE STREQUAL "x64" )
string ( APPEND OPTIONS " \
- - e n a b l e - c u d a _ l l v m \
" )
endif ( )
endif ( )
elseif ( VCPKG_TARGET_IS_WINDOWS )
string ( APPEND OPTIONS " \
- - t a r g e t - o s = w i n 3 2 \
- - t o o l c h a i n = m s v c \
fix qsv memory leak by updating ffmpeg (#9266)
* fix qsv memory leak by updating ffmpeg
* Memory leaks occur when destroying FFmpeg QSV VRAM encoders. This issue is resolved with FFmpeg version 7.
* FFmpeg requires ffnvcodec version 12.1.14.0 or higher, and an NVIDIA driver version greater than 530. For more details, https://github.com/FFmpeg/nv-codec-headers/tree/n12.1.14.0.
* The code of NVIDIA VRAM encoder is not changed, still use Video Codec SDK version 11, which is unaffected by FFmpeg. Drivers newer than 470 can support this, but we may consider an update later, as the support check by sdk code may not be accurate for FFmpeg RAM encoders.
* The issue is related to FFmpeg, not libmfx. FFmpeg version 7 recommends using libvpl, but vcpkg currently lacks ports for libvpl. We can add these in the future.
* D3D11 Texture Rendering: The "Shared GPU Memory" in the task manager continue increasing when using D3D11 texture render, which can exceed the GPU memory limit (e.g., reaching up to 100GB). I don't know what it is and will try to find it out.
* Roughly tests on Windows, Linux, macOS, and Android for quick fix. Further testing will be performed, and I will share the results in this pr.
Signed-off-by: 21pages <sunboeasy@gmail.com>
* update flutter_gpu_texture_render, fix shared gpu memory leak while
rendering
Signed-off-by: 21pages <sunboeasy@gmail.com>
---------
Signed-off-by: 21pages <sunboeasy@gmail.com>
2024-09-07 10:20:52 +08:00
- - c c = c l \
2024-07-23 15:31:36 +00:00
- - e n a b l e - g p l \
- - e n a b l e - d 3 d 1 1 v a \
- - e n a b l e - c u d a \
- - e n a b l e - f f n v c o d e c \
- - e n a b l e - h w a c c e l = h 2 6 4 _ n v d e c \
- - e n a b l e - h w a c c e l = h e v c _ n v d e c \
- - e n a b l e - h w a c c e l = h 2 6 4 _ d 3 d 1 1 v a \
- - e n a b l e - h w a c c e l = h e v c _ d 3 d 1 1 v a \
- - e n a b l e - h w a c c e l = h 2 6 4 _ d 3 d 1 1 v a 2 \
- - e n a b l e - h w a c c e l = h e v c _ d 3 d 1 1 v a 2 \
- - e n a b l e - a m f \
- - e n a b l e - e n c o d e r = h 2 6 4 _ a m f \
- - e n a b l e - e n c o d e r = h e v c _ a m f \
- - e n a b l e - e n c o d e r = h 2 6 4 _ n v e n c \
- - e n a b l e - e n c o d e r = h e v c _ n v e n c \
- - e n a b l e - l i b m f x \
- - e n a b l e - e n c o d e r = h 2 6 4 _ q s v \
- - e n a b l e - e n c o d e r = h e v c _ q s v \
" )
if ( VCPKG_TARGET_ARCHITECTURE STREQUAL "x86" )
set ( LIB_MACHINE_ARG /machine:x86 )
string ( APPEND OPTIONS " --arch=i686 --enable-cross-compile" )
elseif ( VCPKG_TARGET_ARCHITECTURE STREQUAL "x64" )
set ( LIB_MACHINE_ARG /machine:x64 )
string ( APPEND OPTIONS " --arch=x86_64" )
else ( )
message ( FATAL_ERROR "Unsupported target architecture" )
endif ( )
elseif ( VCPKG_TARGET_IS_OSX )
string ( APPEND OPTIONS " \
- - d i s a b l e - a u t o d e t e c t \
- - e n a b l e - v i d e o t o o l b o x \
- - e n a b l e - e n c o d e r = h 2 6 4 _ v i d e o t o o l b o x , h e v c _ v i d e o t o o l b o x \
- - e n a b l e - h w a c c e l = h 2 6 4 _ v i d e o t o o l b o x , h e v c _ v i d e o t o o l b o x \
" )
elseif ( VCPKG_TARGET_IS_IOS )
string ( APPEND OPTIONS " \
- - a r c h = a r m 6 4 \
- - d i s a b l e - a u t o d e t e c t \
- - d i s a b l e - h w a c c e l s \
- - d i s a b l e - e n c o d e r s \
- - d i s a b l e - v i d e o t o o l b o x \
- - e x t r a - c f l a g s = \ " - a r c h a r m 6 4 - m i o s - v e r s i o n - m i n = 8 . 0 - f e m b e d - b i t c o d e \ " \
- - e x t r a - l d f l a g s = \ " - a r c h a r m 6 4 - m i o s - v e r s i o n - m i n = 8 . 0 - f e m b e d - b i t c o d e \ " \
" )
elseif ( VCPKG_CMAKE_SYSTEM_NAME STREQUAL "Android" )
string ( APPEND OPTIONS " \
- - t a r g e t - o s = a n d r o i d \
- - d i s a b l e - a s m \
- - e n a b l e - j n i \
- - e n a b l e - m e d i a c o d e c \
- - d i s a b l e - h w a c c e l s \
- - e n a b l e - e n c o d e r = h 2 6 4 _ m e d i a c o d e c \
- - e n a b l e - e n c o d e r = h e v c _ m e d i a c o d e c \
- - e n a b l e - d e c o d e r = h 2 6 4 _ m e d i a c o d e c \
- - e n a b l e - d e c o d e r = h e v c _ m e d i a c o d e c \
" )
endif ( )
if ( VCPKG_TARGET_IS_OSX )
list ( JOIN VCPKG_OSX_ARCHITECTURES " " OSX_ARCHS )
list ( LENGTH VCPKG_OSX_ARCHITECTURES OSX_ARCH_COUNT )
endif ( )
vcpkg_cmake_get_vars ( cmake_vars_file )
include ( "${cmake_vars_file}" )
if ( VCPKG_DETECTED_MSVC )
string ( APPEND OPTIONS " --disable-inline-asm" ) # clang-cl has inline assembly but this leads to undefined symbols.
set ( OPTIONS "--toolchain=msvc ${OPTIONS}" )
# This is required because ffmpeg depends upon optimizations to link correctly
string ( APPEND VCPKG_COMBINED_C_FLAGS_DEBUG " -O2" )
string ( REGEX REPLACE "(^| )-RTC1( |$)" " " VCPKG_COMBINED_C_FLAGS_DEBUG "${VCPKG_COMBINED_C_FLAGS_DEBUG}" )
string ( REGEX REPLACE "(^| )-Od( |$)" " " VCPKG_COMBINED_C_FLAGS_DEBUG "${VCPKG_COMBINED_C_FLAGS_DEBUG}" )
string ( REGEX REPLACE "(^| )-Ob0( |$)" " " VCPKG_COMBINED_C_FLAGS_DEBUG "${VCPKG_COMBINED_C_FLAGS_DEBUG}" )
endif ( )
string ( APPEND VCPKG_COMBINED_C_FLAGS_DEBUG " -I \" ${ CURRENT_INSTALLED_DIR } /include\ "" )
string ( APPEND VCPKG_COMBINED_C_FLAGS_RELEASE " -I \" ${ CURRENT_INSTALLED_DIR } /include\ "" )
fix qsv memory leak by updating ffmpeg (#9266)
* fix qsv memory leak by updating ffmpeg
* Memory leaks occur when destroying FFmpeg QSV VRAM encoders. This issue is resolved with FFmpeg version 7.
* FFmpeg requires ffnvcodec version 12.1.14.0 or higher, and an NVIDIA driver version greater than 530. For more details, https://github.com/FFmpeg/nv-codec-headers/tree/n12.1.14.0.
* The code of NVIDIA VRAM encoder is not changed, still use Video Codec SDK version 11, which is unaffected by FFmpeg. Drivers newer than 470 can support this, but we may consider an update later, as the support check by sdk code may not be accurate for FFmpeg RAM encoders.
* The issue is related to FFmpeg, not libmfx. FFmpeg version 7 recommends using libvpl, but vcpkg currently lacks ports for libvpl. We can add these in the future.
* D3D11 Texture Rendering: The "Shared GPU Memory" in the task manager continue increasing when using D3D11 texture render, which can exceed the GPU memory limit (e.g., reaching up to 100GB). I don't know what it is and will try to find it out.
* Roughly tests on Windows, Linux, macOS, and Android for quick fix. Further testing will be performed, and I will share the results in this pr.
Signed-off-by: 21pages <sunboeasy@gmail.com>
* update flutter_gpu_texture_render, fix shared gpu memory leak while
rendering
Signed-off-by: 21pages <sunboeasy@gmail.com>
---------
Signed-off-by: 21pages <sunboeasy@gmail.com>
2024-09-07 10:20:52 +08:00
if ( VCPKG_TARGET_IS_WINDOWS )
string ( APPEND VCPKG_COMBINED_C_FLAGS_DEBUG " -I \" ${ CURRENT_INSTALLED_DIR } /include/mfx\ "" )
string ( APPEND VCPKG_COMBINED_C_FLAGS_RELEASE " -I \" ${ CURRENT_INSTALLED_DIR } /include/mfx\ "" )
endif ( )
2024-07-23 15:31:36 +00:00
# # Setup vcpkg toolchain
set ( prog_env "" )
if ( VCPKG_DETECTED_CMAKE_C_COMPILER )
get_filename_component ( CC_path "${VCPKG_DETECTED_CMAKE_C_COMPILER}" DIRECTORY )
get_filename_component ( CC_filename "${VCPKG_DETECTED_CMAKE_C_COMPILER}" NAME )
set ( ENV{CC} "${CC_filename}" )
string ( APPEND OPTIONS " --cc=${CC_filename}" )
fix qsv memory leak by updating ffmpeg (#9266)
* fix qsv memory leak by updating ffmpeg
* Memory leaks occur when destroying FFmpeg QSV VRAM encoders. This issue is resolved with FFmpeg version 7.
* FFmpeg requires ffnvcodec version 12.1.14.0 or higher, and an NVIDIA driver version greater than 530. For more details, https://github.com/FFmpeg/nv-codec-headers/tree/n12.1.14.0.
* The code of NVIDIA VRAM encoder is not changed, still use Video Codec SDK version 11, which is unaffected by FFmpeg. Drivers newer than 470 can support this, but we may consider an update later, as the support check by sdk code may not be accurate for FFmpeg RAM encoders.
* The issue is related to FFmpeg, not libmfx. FFmpeg version 7 recommends using libvpl, but vcpkg currently lacks ports for libvpl. We can add these in the future.
* D3D11 Texture Rendering: The "Shared GPU Memory" in the task manager continue increasing when using D3D11 texture render, which can exceed the GPU memory limit (e.g., reaching up to 100GB). I don't know what it is and will try to find it out.
* Roughly tests on Windows, Linux, macOS, and Android for quick fix. Further testing will be performed, and I will share the results in this pr.
Signed-off-by: 21pages <sunboeasy@gmail.com>
* update flutter_gpu_texture_render, fix shared gpu memory leak while
rendering
Signed-off-by: 21pages <sunboeasy@gmail.com>
---------
Signed-off-by: 21pages <sunboeasy@gmail.com>
2024-09-07 10:20:52 +08:00
if ( VCPKG_HOST_IS_WINDOWS )
string ( APPEND OPTIONS " --host_cc=${CC_filename}" )
endif ( )
2024-07-23 15:31:36 +00:00
list ( APPEND prog_env "${CC_path}" )
endif ( )
if ( VCPKG_DETECTED_CMAKE_CXX_COMPILER )
get_filename_component ( CXX_path "${VCPKG_DETECTED_CMAKE_CXX_COMPILER}" DIRECTORY )
get_filename_component ( CXX_filename "${VCPKG_DETECTED_CMAKE_CXX_COMPILER}" NAME )
set ( ENV{CXX} "${CXX_filename}" )
string ( APPEND OPTIONS " --cxx=${CXX_filename}" )
# string(APPEND OPTIONS " --host_cxx=${CC_filename}")
list ( APPEND prog_env "${CXX_path}" )
endif ( )
if ( VCPKG_DETECTED_CMAKE_RC_COMPILER )
get_filename_component ( RC_path "${VCPKG_DETECTED_CMAKE_RC_COMPILER}" DIRECTORY )
get_filename_component ( RC_filename "${VCPKG_DETECTED_CMAKE_RC_COMPILER}" NAME )
set ( ENV{WINDRES} "${RC_filename}" )
string ( APPEND OPTIONS " --windres=${RC_filename}" )
list ( APPEND prog_env "${RC_path}" )
endif ( )
if ( VCPKG_DETECTED_CMAKE_LINKER AND VCPKG_TARGET_IS_WINDOWS AND NOT VCPKG_TARGET_IS_MINGW )
get_filename_component ( LD_path "${VCPKG_DETECTED_CMAKE_LINKER}" DIRECTORY )
get_filename_component ( LD_filename "${VCPKG_DETECTED_CMAKE_LINKER}" NAME )
set ( ENV{LD} "${LD_filename}" )
string ( APPEND OPTIONS " --ld=${LD_filename}" )
# string(APPEND OPTIONS " --host_ld=${LD_filename}")
list ( APPEND prog_env "${LD_path}" )
endif ( )
if ( VCPKG_DETECTED_CMAKE_NM )
get_filename_component ( NM_path "${VCPKG_DETECTED_CMAKE_NM}" DIRECTORY )
get_filename_component ( NM_filename "${VCPKG_DETECTED_CMAKE_NM}" NAME )
set ( ENV{NM} "${NM_filename}" )
string ( APPEND OPTIONS " --nm=${NM_filename}" )
list ( APPEND prog_env "${NM_path}" )
endif ( )
if ( VCPKG_DETECTED_CMAKE_AR )
get_filename_component ( AR_path "${VCPKG_DETECTED_CMAKE_AR}" DIRECTORY )
get_filename_component ( AR_filename "${VCPKG_DETECTED_CMAKE_AR}" NAME )
if ( AR_filename MATCHES [[^(llvm- ) ? l i b \ . e x e $ ] ] )
set ( ENV{AR} "ar-lib ${AR_filename}" )
string ( APPEND OPTIONS " --ar='ar-lib ${AR_filename}'" )
else ( )
set ( ENV{AR} "${AR_filename}" )
string ( APPEND OPTIONS " --ar='${AR_filename}'" )
endif ( )
list ( APPEND prog_env "${AR_path}" )
endif ( )
if ( VCPKG_DETECTED_CMAKE_RANLIB )
get_filename_component ( RANLIB_path "${VCPKG_DETECTED_CMAKE_RANLIB}" DIRECTORY )
get_filename_component ( RANLIB_filename "${VCPKG_DETECTED_CMAKE_RANLIB}" NAME )
set ( ENV{RANLIB} "${RANLIB_filename}" )
string ( APPEND OPTIONS " --ranlib=${RANLIB_filename}" )
list ( APPEND prog_env "${RANLIB_path}" )
endif ( )
if ( VCPKG_DETECTED_CMAKE_STRIP )
get_filename_component ( STRIP_path "${VCPKG_DETECTED_CMAKE_STRIP}" DIRECTORY )
get_filename_component ( STRIP_filename "${VCPKG_DETECTED_CMAKE_STRIP}" NAME )
set ( ENV{STRIP} "${STRIP_filename}" )
string ( APPEND OPTIONS " --strip=${STRIP_filename}" )
list ( APPEND prog_env "${STRIP_path}" )
endif ( )
fix qsv memory leak by updating ffmpeg (#9266)
* fix qsv memory leak by updating ffmpeg
* Memory leaks occur when destroying FFmpeg QSV VRAM encoders. This issue is resolved with FFmpeg version 7.
* FFmpeg requires ffnvcodec version 12.1.14.0 or higher, and an NVIDIA driver version greater than 530. For more details, https://github.com/FFmpeg/nv-codec-headers/tree/n12.1.14.0.
* The code of NVIDIA VRAM encoder is not changed, still use Video Codec SDK version 11, which is unaffected by FFmpeg. Drivers newer than 470 can support this, but we may consider an update later, as the support check by sdk code may not be accurate for FFmpeg RAM encoders.
* The issue is related to FFmpeg, not libmfx. FFmpeg version 7 recommends using libvpl, but vcpkg currently lacks ports for libvpl. We can add these in the future.
* D3D11 Texture Rendering: The "Shared GPU Memory" in the task manager continue increasing when using D3D11 texture render, which can exceed the GPU memory limit (e.g., reaching up to 100GB). I don't know what it is and will try to find it out.
* Roughly tests on Windows, Linux, macOS, and Android for quick fix. Further testing will be performed, and I will share the results in this pr.
Signed-off-by: 21pages <sunboeasy@gmail.com>
* update flutter_gpu_texture_render, fix shared gpu memory leak while
rendering
Signed-off-by: 21pages <sunboeasy@gmail.com>
---------
Signed-off-by: 21pages <sunboeasy@gmail.com>
2024-09-07 10:20:52 +08:00
if ( VCPKG_HOST_IS_WINDOWS )
vcpkg_acquire_msys ( MSYS_ROOT PACKAGES automake1.16 )
set ( SHELL "${MSYS_ROOT}/usr/bin/bash.exe" )
list ( APPEND prog_env "${MSYS_ROOT}/usr/bin" "${MSYS_ROOT}/usr/share/automake-1.16" )
else ( )
# find_program(SHELL bash)
endif ( )
2024-07-23 15:31:36 +00:00
list ( REMOVE_DUPLICATES prog_env )
vcpkg_add_to_path ( PREPEND ${ prog_env } )
# More? OBJCC BIN2C
file ( REMOVE_RECURSE "${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-dbg" "${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-rel" )
set ( FFMPEG_PKGCONFIG_MODULES libavutil )
set ( OPTIONS_CROSS "--enable-cross-compile" )
# ffmpeg needs --cross-prefix option to use appropriate tools for cross-compiling.
if ( VCPKG_DETECTED_CMAKE_C_COMPILER MATCHES "([^\/]*-)gcc$" )
string ( APPEND OPTIONS_CROSS " --cross-prefix=${CMAKE_MATCH_1}" )
endif ( )
if ( VCPKG_TARGET_ARCHITECTURE STREQUAL "x64" )
set ( BUILD_ARCH "x86_64" )
else ( )
set ( BUILD_ARCH ${ VCPKG_TARGET_ARCHITECTURE } )
endif ( )
if ( VCPKG_TARGET_ARCHITECTURE STREQUAL "arm" OR VCPKG_TARGET_ARCHITECTURE STREQUAL "arm64" )
if ( VCPKG_TARGET_IS_WINDOWS )
vcpkg_find_acquire_program ( GASPREPROCESSOR )
foreach ( GAS_PATH ${ GASPREPROCESSOR } )
get_filename_component ( GAS_ITEM_PATH ${ GAS_PATH } DIRECTORY )
vcpkg_add_to_path ( "${GAS_ITEM_PATH}" )
endforeach ( GAS_PATH )
endif ( )
endif ( )
set ( OPTIONS_DEBUG "--disable-optimizations" )
set ( OPTIONS_RELEASE "--enable-optimizations" )
set ( OPTIONS "${OPTIONS} ${OPTIONS_CROSS}" )
if ( VCPKG_TARGET_IS_MINGW )
set ( OPTIONS "${OPTIONS} --extra_cflags=-D_WIN32_WINNT=0x0601" )
elseif ( VCPKG_TARGET_IS_WINDOWS )
set ( OPTIONS "${OPTIONS} --extra-cflags=-DHAVE_UNISTD_H=0" )
endif ( )
vcpkg_find_acquire_program ( PKGCONFIG )
set ( OPTIONS "${OPTIONS} --pkg-config=${PKGCONFIG}" )
if ( VCPKG_LIBRARY_LINKAGE STREQUAL "static" )
set ( OPTIONS "${OPTIONS} --pkg-config-flags=--static" )
endif ( )
message ( STATUS "Building Options: ${OPTIONS}" )
# Release build
if ( NOT VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "release" )
if ( VCPKG_DETECTED_MSVC )
set ( OPTIONS_RELEASE "${OPTIONS_RELEASE} --extra-ldflags=-libpath:\" ${ CURRENT_INSTALLED_DIR } /lib\ "" )
else ( )
set ( OPTIONS_RELEASE "${OPTIONS_RELEASE} --extra-ldflags=-L\" ${ CURRENT_INSTALLED_DIR } /lib\ "" )
endif ( )
message ( STATUS "Building Release Options: ${OPTIONS_RELEASE}" )
set ( ENV{PKG_CONFIG_PATH} "${CURRENT_INSTALLED_DIR}/lib/pkgconfig" )
message ( STATUS "Building ${PORT} for Release" )
file ( MAKE_DIRECTORY "${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-rel" )
# We use response files here as the only known way to handle spaces in paths
set ( crsp "${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-rel/cflags.rsp" )
string ( REGEX REPLACE "-arch [A-Za-z0-9_]+" "" VCPKG_COMBINED_C_FLAGS_RELEASE_SANITIZED "${VCPKG_COMBINED_C_FLAGS_RELEASE}" )
file ( WRITE "${crsp}" "${VCPKG_COMBINED_C_FLAGS_RELEASE_SANITIZED}" )
set ( ldrsp "${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-rel/ldflags.rsp" )
string ( REGEX REPLACE "-arch [A-Za-z0-9_]+" "" VCPKG_COMBINED_SHARED_LINKER_FLAGS_RELEASE_SANITIZED "${VCPKG_COMBINED_SHARED_LINKER_FLAGS_RELEASE}" )
file ( WRITE "${ldrsp}" "${VCPKG_COMBINED_SHARED_LINKER_FLAGS_RELEASE_SANITIZED}" )
set ( ENV{CFLAGS} "@${crsp}" )
# All tools except the msvc arm{,64} assembler accept @... as response file syntax.
# For that assembler, there is no known way to pass in flags. We must hope that not passing flags will work acceptably.
if ( NOT VCPKG_DETECTED_MSVC OR NOT VCPKG_TARGET_ARCHITECTURE MATCHES "^arm" )
set ( ENV{ASFLAGS} "@${crsp}" )
endif ( )
set ( ENV{LDFLAGS} "@${ldrsp}" )
set ( ENV{ARFLAGS} "${VCPKG_COMBINED_STATIC_LINKER_FLAGS_RELEASE}" )
set ( BUILD_DIR "${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-rel" )
set ( CONFIGURE_OPTIONS "${OPTIONS} ${OPTIONS_RELEASE}" )
set ( INST_PREFIX "${CURRENT_PACKAGES_DIR}" )
configure_file ( "${CMAKE_CURRENT_LIST_DIR}/build.sh.in" "${BUILD_DIR}/build.sh" @ONLY )
z_vcpkg_setup_pkgconfig_path ( CONFIG RELEASE )
vcpkg_execute_required_process (
C O M M A N D " $ { S H E L L } " . / b u i l d . s h
W O R K I N G _ D I R E C T O R Y " $ { B U I L D _ D I R } "
L O G N A M E " b u i l d - $ { T A R G E T _ T R I P L E T } - r e l "
S A V E _ L O G _ F I L E S f f b u i l d / c o n f i g . l o g
)
z_vcpkg_restore_pkgconfig_path ( )
endif ( )
# Debug build
if ( NOT VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "debug" )
if ( VCPKG_DETECTED_MSVC )
set ( OPTIONS_DEBUG "${OPTIONS_DEBUG} --extra-ldflags=-libpath:\" ${ CURRENT_INSTALLED_DIR } /debug/lib\ "" )
else ( )
set ( OPTIONS_DEBUG "${OPTIONS_DEBUG} --extra-ldflags=-L\" ${ CURRENT_INSTALLED_DIR } /debug/lib\ "" )
endif ( )
message ( STATUS "Building Debug Options: ${OPTIONS_DEBUG}" )
set ( ENV{LDFLAGS} "${VCPKG_COMBINED_SHARED_LINKER_FLAGS_DEBUG}" )
set ( ENV{PKG_CONFIG_PATH} "${CURRENT_INSTALLED_DIR}/debug/lib/pkgconfig" )
message ( STATUS "Building ${PORT} for Debug" )
file ( MAKE_DIRECTORY "${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-dbg" )
set ( crsp "${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-dbg/cflags.rsp" )
string ( REGEX REPLACE "-arch [A-Za-z0-9_]+" "" VCPKG_COMBINED_C_FLAGS_DEBUG_SANITIZED "${VCPKG_COMBINED_C_FLAGS_DEBUG}" )
file ( WRITE "${crsp}" "${VCPKG_COMBINED_C_FLAGS_DEBUG_SANITIZED}" )
set ( ldrsp "${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-dbg/ldflags.rsp" )
string ( REGEX REPLACE "-arch [A-Za-z0-9_]+" "" VCPKG_COMBINED_SHARED_LINKER_FLAGS_DEBUG_SANITIZED "${VCPKG_COMBINED_SHARED_LINKER_FLAGS_DEBUG}" )
file ( WRITE "${ldrsp}" "${VCPKG_COMBINED_SHARED_LINKER_FLAGS_DEBUG_SANITIZED}" )
set ( ENV{CFLAGS} "@${crsp}" )
if ( NOT VCPKG_DETECTED_MSVC OR NOT VCPKG_TARGET_ARCHITECTURE MATCHES "^arm" )
set ( ENV{ASFLAGS} "@${crsp}" )
endif ( )
set ( ENV{LDFLAGS} "@${ldrsp}" )
set ( ENV{ARFLAGS} "${VCPKG_COMBINED_STATIC_LINKER_FLAGS_DEBUG}" )
set ( BUILD_DIR "${CURRENT_BUILDTREES_DIR}/${TARGET_TRIPLET}-dbg" )
set ( CONFIGURE_OPTIONS "${OPTIONS} ${OPTIONS_DEBUG}" )
set ( INST_PREFIX "${CURRENT_PACKAGES_DIR}/debug" )
configure_file ( "${CMAKE_CURRENT_LIST_DIR}/build.sh.in" "${BUILD_DIR}/build.sh" @ONLY )
z_vcpkg_setup_pkgconfig_path ( CONFIG DEBUG )
vcpkg_execute_required_process (
C O M M A N D " $ { S H E L L } " . / b u i l d . s h
W O R K I N G _ D I R E C T O R Y " $ { B U I L D _ D I R } "
L O G N A M E " b u i l d - $ { T A R G E T _ T R I P L E T } - d b g "
S A V E _ L O G _ F I L E S f f b u i l d / c o n f i g . l o g
)
z_vcpkg_restore_pkgconfig_path ( )
endif ( )
if ( VCPKG_TARGET_IS_WINDOWS )
file ( GLOB DEF_FILES "${CURRENT_PACKAGES_DIR}/lib/*.def" "${CURRENT_PACKAGES_DIR}/debug/lib/*.def" )
if ( NOT VCPKG_TARGET_IS_MINGW )
if ( VCPKG_TARGET_ARCHITECTURE STREQUAL "arm" )
set ( LIB_MACHINE_ARG /machine:ARM )
elseif ( VCPKG_TARGET_ARCHITECTURE STREQUAL "arm64" )
set ( LIB_MACHINE_ARG /machine:ARM64 )
elseif ( VCPKG_TARGET_ARCHITECTURE STREQUAL "x86" )
set ( LIB_MACHINE_ARG /machine:x86 )
elseif ( VCPKG_TARGET_ARCHITECTURE STREQUAL "x64" )
set ( LIB_MACHINE_ARG /machine:x64 )
else ( )
message ( FATAL_ERROR "Unsupported target architecture" )
endif ( )
foreach ( DEF_FILE ${ DEF_FILES } )
get_filename_component ( DEF_FILE_DIR "${DEF_FILE}" DIRECTORY )
get_filename_component ( DEF_FILE_NAME "${DEF_FILE}" NAME )
string ( REGEX REPLACE "-[0-9]*\\.def" "${VCPKG_TARGET_STATIC_LIBRARY_SUFFIX}" OUT_FILE_NAME "${DEF_FILE_NAME}" )
file ( TO_NATIVE_PATH "${DEF_FILE}" DEF_FILE_NATIVE )
file ( TO_NATIVE_PATH "${DEF_FILE_DIR}/${OUT_FILE_NAME}" OUT_FILE_NATIVE )
message ( STATUS "Generating ${OUT_FILE_NATIVE}" )
vcpkg_execute_required_process (
C O M M A N D l i b . e x e " / d e f : $ { D E F _ F I L E _ N A T I V E } " " / o u t : $ { O U T _ F I L E _ N A T I V E } " $ { L I B _ M A C H I N E _ A R G }
W O R K I N G _ D I R E C T O R Y " $ { C U R R E N T _ P A C K A G E S _ D I R } "
L O G N A M E " l i b c o n v e r t - $ { T A R G E T _ T R I P L E T } "
)
endforeach ( )
endif ( )
file ( GLOB EXP_FILES "${CURRENT_PACKAGES_DIR}/lib/*.exp" "${CURRENT_PACKAGES_DIR}/debug/lib/*.exp" )
file ( GLOB LIB_FILES "${CURRENT_PACKAGES_DIR}/bin/*${VCPKG_TARGET_STATIC_LIBRARY_SUFFIX}" "${CURRENT_PACKAGES_DIR}/debug/bin/*${VCPKG_TARGET_STATIC_LIBRARY_SUFFIX}" )
if ( VCPKG_TARGET_IS_MINGW )
file ( GLOB LIB_FILES_2 "${CURRENT_PACKAGES_DIR}/bin/*.lib" "${CURRENT_PACKAGES_DIR}/debug/bin/*.lib" )
endif ( )
set ( files_to_remove ${ EXP_FILES } ${ LIB_FILES } ${ LIB_FILES_2 } ${ DEF_FILES } )
if ( files_to_remove )
file ( REMOVE ${ files_to_remove } )
endif ( )
endif ( )
file ( REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/debug/include" "${CURRENT_PACKAGES_DIR}/debug/share" )
if ( VCPKG_LIBRARY_LINKAGE STREQUAL "static" )
file ( REMOVE_RECURSE "${CURRENT_PACKAGES_DIR}/bin" "${CURRENT_PACKAGES_DIR}/debug/bin" )
endif ( )
vcpkg_copy_pdbs ( )
if ( VCPKG_TARGET_IS_WINDOWS )
set ( _dirs "/" )
if ( NOT VCPKG_BUILD_TYPE OR VCPKG_BUILD_TYPE STREQUAL "debug" )
list ( APPEND _dirs "/debug/" )
endif ( )
foreach ( _debug IN LISTS _dirs )
foreach ( PKGCONFIG_MODULE IN LISTS FFMPEG_PKGCONFIG_MODULES )
set ( PKGCONFIG_FILE "${CURRENT_PACKAGES_DIR}${_debug}lib/pkgconfig/${PKGCONFIG_MODULE}.pc" )
# remove redundant cygwin style -libpath entries
execute_process (
C O M M A N D " $ { M S Y S _ R O O T } / u s r / b i n / c y g p a t h . e x e " - u " $ { C U R R E N T _ I N S T A L L E D _ D I R } "
O U T P U T _ V A R I A B L E C Y G _ I N S T A L L E D _ D I R
O U T P U T _ S T R I P _ T R A I L I N G _ W H I T E S P A C E
)
vcpkg_replace_string ( "${PKGCONFIG_FILE}" "-libpath:${CYG_INSTALLED_DIR}${_debug}lib/pkgconfig/../../lib " "" )
# transform libdir, includedir, and prefix paths from cygwin style to windows style
file ( READ "${PKGCONFIG_FILE}" PKGCONFIG_CONTENT )
foreach ( PATH_NAME prefix libdir includedir )
string ( REGEX MATCH "${PATH_NAME}=[^\n]*" PATH_VALUE "${PKGCONFIG_CONTENT}" )
string ( REPLACE "${PATH_NAME}=" "" PATH_VALUE "${PATH_VALUE}" )
if ( NOT PATH_VALUE )
message ( FATAL_ERROR "failed to find pkgconfig variable ${PATH_NAME}" )
endif ( )
execute_process (
C O M M A N D " $ { M S Y S _ R O O T } / u s r / b i n / c y g p a t h . e x e " - w " $ { P A T H _ V A L U E } "
O U T P U T _ V A R I A B L E F I X E D _ P A T H
O U T P U T _ S T R I P _ T R A I L I N G _ W H I T E S P A C E
)
file ( TO_CMAKE_PATH "${FIXED_PATH}" FIXED_PATH )
vcpkg_replace_string ( "${PKGCONFIG_FILE}" "${PATH_NAME}=${PATH_VALUE}" "${PATH_NAME}=${FIXED_PATH}" )
endforeach ( )
# list libraries with -l flag (so pkgconf knows they are libraries and not just linker flags)
foreach ( LIBS_ENTRY Libs Libs.private )
string ( REGEX MATCH "${LIBS_ENTRY}: [^\n]*" LIBS_VALUE "${PKGCONFIG_CONTENT}" )
if ( NOT LIBS_VALUE )
message ( FATAL_ERROR "failed to find pkgconfig entry ${LIBS_ENTRY}" )
endif ( )
string ( REPLACE "${LIBS_ENTRY}: " "" LIBS_VALUE "${LIBS_VALUE}" )
if ( LIBS_VALUE )
set ( LIBS_VALUE_OLD "${LIBS_VALUE}" )
string ( REGEX REPLACE "([^ ]+)[.]lib" "-l\\1" LIBS_VALUE "${LIBS_VALUE}" )
set ( LIBS_VALUE_NEW "${LIBS_VALUE}" )
vcpkg_replace_string ( "${PKGCONFIG_FILE}" "${LIBS_ENTRY}: ${LIBS_VALUE_OLD}" "${LIBS_ENTRY}: ${LIBS_VALUE_NEW}" )
endif ( )
endforeach ( )
endforeach ( )
endforeach ( )
endif ( )
vcpkg_fixup_pkgconfig ( )
# Handle dependencies
x_vcpkg_pkgconfig_get_modules ( PREFIX FFMPEG_PKGCONFIG MODULES ${ FFMPEG_PKGCONFIG_MODULES } LIBS )
function ( append_dependencies_from_libs out )
cmake_parse_arguments ( PARSE_ARGV 1 "arg" "" "LIBS" "" )
string ( REGEX REPLACE "[ ]+" ";" contents "${arg_LIBS}" )
list ( FILTER contents EXCLUDE REGEX "^-F.+" )
list ( FILTER contents EXCLUDE REGEX "^-framework$" )
list ( FILTER contents EXCLUDE REGEX "^-L.+" )
list ( FILTER contents EXCLUDE REGEX "^-libpath:.+" )
list ( TRANSFORM contents REPLACE "^-Wl,-framework," "-l" )
list ( FILTER contents EXCLUDE REGEX "^-Wl,.+" )
list ( TRANSFORM contents REPLACE "^-l" "" )
list ( FILTER contents EXCLUDE REGEX "^avutil$" )
list ( FILTER contents EXCLUDE REGEX "^avcodec$" )
list ( FILTER contents EXCLUDE REGEX "^avdevice$" )
list ( FILTER contents EXCLUDE REGEX "^avfilter$" )
list ( FILTER contents EXCLUDE REGEX "^avformat$" )
list ( FILTER contents EXCLUDE REGEX "^postproc$" )
list ( FILTER contents EXCLUDE REGEX "^swresample$" )
list ( FILTER contents EXCLUDE REGEX "^swscale$" )
if ( VCPKG_TARGET_IS_WINDOWS )
list ( TRANSFORM contents TOLOWER )
endif ( )
if ( contents )
list ( APPEND "${out}" "${contents}" )
set ( "${out}" "${${out}}" PARENT_SCOPE )
endif ( )
endfunction ( )
append_dependencies_from_libs ( FFMPEG_DEPENDENCIES_RELEASE LIBS "${FFMPEG_PKGCONFIG_LIBS_RELEASE}" )
append_dependencies_from_libs ( FFMPEG_DEPENDENCIES_DEBUG LIBS "${FFMPEG_PKGCONFIG_LIBS_DEBUG}" )
# must remove duplicates from the front to respect link order so reverse first
list ( REVERSE FFMPEG_DEPENDENCIES_RELEASE )
list ( REVERSE FFMPEG_DEPENDENCIES_DEBUG )
list ( REMOVE_DUPLICATES FFMPEG_DEPENDENCIES_RELEASE )
list ( REMOVE_DUPLICATES FFMPEG_DEPENDENCIES_DEBUG )
list ( REVERSE FFMPEG_DEPENDENCIES_RELEASE )
list ( REVERSE FFMPEG_DEPENDENCIES_DEBUG )
message ( STATUS "Dependencies (release): ${FFMPEG_DEPENDENCIES_RELEASE}" )
message ( STATUS "Dependencies (debug): ${FFMPEG_DEPENDENCIES_DEBUG}" )
# Handle version strings
function ( extract_regex_from_file out )
cmake_parse_arguments ( PARSE_ARGV 1 "arg" "MAJOR" "FILE_WITHOUT_EXTENSION;REGEX" "" )
file ( READ "${arg_FILE_WITHOUT_EXTENSION}.h" contents )
if ( contents MATCHES "${arg_REGEX}" )
if ( NOT CMAKE_MATCH_COUNT EQUAL 1 )
message ( FATAL_ERROR "Could not identify match group in regular expression \" ${ arg_REGEX } \"")
endif ( )
else ( )
if ( arg_MAJOR )
file ( READ "${arg_FILE_WITHOUT_EXTENSION}_major.h" contents )
if ( contents MATCHES "${arg_REGEX}" )
if ( NOT CMAKE_MATCH_COUNT EQUAL 1 )
message ( FATAL_ERROR "Could not identify match group in regular expression \" ${ arg_REGEX } \"")
endif ( )
else ( )
message ( WARNING "Could not find line matching \" ${ arg_REGEX } \" in file \"${arg_FILE_WITHOUT_EXTENSION}_major.h\"")
endif ( )
else ( )
message ( WARNING "Could not find line matching \" ${ arg_REGEX } \" in file \"${arg_FILE_WITHOUT_EXTENSION}.h\"")
endif ( )
endif ( )
set ( "${out}" "${CMAKE_MATCH_1}" PARENT_SCOPE )
endfunction ( )
function ( extract_version_from_component out )
cmake_parse_arguments ( PARSE_ARGV 1 "arg" "" "COMPONENT" "" )
string ( TOLOWER "${arg_COMPONENT}" component_lower )
string ( TOUPPER "${arg_COMPONENT}" component_upper )
extract_regex_from_file ( major_version
F I L E _ W I T H O U T _ E X T E N S I O N " $ { S O U R C E _ P A T H } / $ { c o m p o n e n t _ l o w e r } / v e r s i o n "
M A J O R
R E G E X " #define ${component_upper}_VERSION_MAJOR[ ]+([0-9]+)"
)
extract_regex_from_file ( minor_version
F I L E _ W I T H O U T _ E X T E N S I O N " $ { S O U R C E _ P A T H } / $ { c o m p o n e n t _ l o w e r } / v e r s i o n "
R E G E X " #define ${component_upper}_VERSION_MINOR[ ]+([0-9]+)"
)
extract_regex_from_file ( micro_version
F I L E _ W I T H O U T _ E X T E N S I O N " $ { S O U R C E _ P A T H } / $ { c o m p o n e n t _ l o w e r } / v e r s i o n "
R E G E X " #define ${component_upper}_VERSION_MICRO[ ]+([0-9]+)"
)
set ( "${out}" "${major_version}.${minor_version}.${micro_version}" PARENT_SCOPE )
endfunction ( )
extract_regex_from_file ( FFMPEG_VERSION
F I L E _ W I T H O U T _ E X T E N S I O N " $ { C U R R E N T _ B U I L D T R E E S _ D I R } / $ { T A R G E T _ T R I P L E T } - r e l / l i b a v u t i l / f f v e r s i o n "
R E G E X " #define FFMPEG_VERSION[ ]+\"(.+)\""
)
extract_version_from_component ( LIBAVUTIL_VERSION
C O M P O N E N T l i b a v u t i l )
extract_version_from_component ( LIBAVCODEC_VERSION
C O M P O N E N T l i b a v c o d e c )
extract_version_from_component ( LIBAVDEVICE_VERSION
C O M P O N E N T l i b a v d e v i c e )
extract_version_from_component ( LIBAVFILTER_VERSION
C O M P O N E N T l i b a v f i l t e r )
extract_version_from_component ( LIBAVFORMAT_VERSION
C O M P O N E N T l i b a v f o r m a t )
extract_version_from_component ( LIBSWRESAMPLE_VERSION
C O M P O N E N T l i b s w r e s a m p l e )
extract_version_from_component ( LIBSWSCALE_VERSION
C O M P O N E N T l i b s w s c a l e )
# Handle copyright
file ( STRINGS "${CURRENT_BUILDTREES_DIR}/build-${TARGET_TRIPLET}-rel-out.log" LICENSE_STRING REGEX "License: .*" LIMIT_COUNT 1 )
if ( LICENSE_STRING STREQUAL "License: LGPL version 2.1 or later" )
set ( LICENSE_FILE "COPYING.LGPLv2.1" )
elseif ( LICENSE_STRING STREQUAL "License: LGPL version 3 or later" )
set ( LICENSE_FILE "COPYING.LGPLv3" )
elseif ( LICENSE_STRING STREQUAL "License: GPL version 2 or later" )
set ( LICENSE_FILE "COPYING.GPLv2" )
elseif ( LICENSE_STRING STREQUAL "License: GPL version 3 or later" )
set ( LICENSE_FILE "COPYING.GPLv3" )
elseif ( LICENSE_STRING STREQUAL "License: nonfree and unredistributable" )
set ( LICENSE_FILE "COPYING.NONFREE" )
file ( WRITE "${SOURCE_PATH}/${LICENSE_FILE}" "${LICENSE_STRING}" )
else ( )
message ( FATAL_ERROR "Failed to identify license (${LICENSE_STRING})" )
endif ( )
configure_file ( "${CMAKE_CURRENT_LIST_DIR}/vcpkg-cmake-wrapper.cmake" "${CURRENT_PACKAGES_DIR}/share/${PORT}/vcpkg-cmake-wrapper.cmake" @ONLY )
vcpkg_install_copyright ( FILE_LIST "${SOURCE_PATH}/${LICENSE_FILE}" )