diff options
Diffstat (limited to 'recipes-multimedia/libva/files')
12 files changed, 91 insertions, 960 deletions
| diff --git a/recipes-multimedia/libva/files/0001-Disable-vp9-padding-on-mtl.patch b/recipes-multimedia/libva/files/0001-Disable-vp9-padding-on-mtl.patch deleted file mode 100644 index 90dff8d1..00000000 --- a/recipes-multimedia/libva/files/0001-Disable-vp9-padding-on-mtl.patch +++ /dev/null | |||
| @@ -1,35 +0,0 @@ | |||
| 1 | From 1b303f417113ad1aa6b63fc024fbe4aa0c943f57 Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Lim Siew Hoon <siew.hoon.lim@intel.com> | ||
| 3 | Date: Tue, 5 Sep 2023 16:13:42 +0800 | ||
| 4 | Subject: [PATCH 01/12] Disable vp9 padding on mtl. | ||
| 5 | |||
| 6 | Upstream-Status: Submitted [https://github.com/intel/media-driver/pull/1720] | ||
| 7 | |||
| 8 | Signed-off-by: Lim Siew Hoon <siew.hoon.lim@intel.com> | ||
| 9 | --- | ||
| 10 | media_softlet/linux/Xe_M_plus/ddi/media_sku_wa_mtl.cpp | 4 ++-- | ||
| 11 | 1 file changed, 2 insertions(+), 2 deletions(-) | ||
| 12 | |||
| 13 | diff --git a/media_softlet/linux/Xe_M_plus/ddi/media_sku_wa_mtl.cpp b/media_softlet/linux/Xe_M_plus/ddi/media_sku_wa_mtl.cpp | ||
| 14 | index 844545a87..72265289c 100644 | ||
| 15 | --- a/media_softlet/linux/Xe_M_plus/ddi/media_sku_wa_mtl.cpp | ||
| 16 | +++ b/media_softlet/linux/Xe_M_plus/ddi/media_sku_wa_mtl.cpp | ||
| 17 | @@ -284,7 +284,7 @@ static bool InitMtlMediaWaExt(struct GfxDeviceInfo *devInfo, | ||
| 18 | |||
| 19 | MEDIA_WR_WA(waTable, WaDisableSetObjectCapture, 1); | ||
| 20 | |||
| 21 | - MEDIA_WR_WA(waTable, Wa_Vp9UnalignedHeight, 1); | ||
| 22 | + MEDIA_WR_WA(waTable, Wa_Vp9UnalignedHeight, 0); | ||
| 23 | |||
| 24 | MEDIA_WR_WA(waTable, Wa_15013355402, 1); | ||
| 25 | |||
| 26 | @@ -337,4 +337,4 @@ static struct LinuxDeviceInit arlDeviceInit = | ||
| 27 | }; | ||
| 28 | |||
| 29 | static bool arlDeviceRegister = DeviceInfoFactory<LinuxDeviceInit>:: | ||
| 30 | - RegisterDevice((uint32_t)IGFX_ARROWLAKE, &arlDeviceInit); | ||
| 31 | \ No newline at end of file | ||
| 32 | + RegisterDevice((uint32_t)IGFX_ARROWLAKE, &arlDeviceInit); | ||
| 33 | -- | ||
| 34 | 2.40.1 | ||
| 35 | |||
| diff --git a/recipes-multimedia/libva/files/0002-Force-ARGB-surface-to-tile4-for-ACM.patch b/recipes-multimedia/libva/files/0003-Force-ARGB-surface-to-tile4-for-ACM.patch index df3d9805..ffb5b747 100644 --- a/recipes-multimedia/libva/files/0002-Force-ARGB-surface-to-tile4-for-ACM.patch +++ b/recipes-multimedia/libva/files/0003-Force-ARGB-surface-to-tile4-for-ACM.patch | |||
| @@ -1,7 +1,7 @@ | |||
| 1 | From 1580f01ec5ad5afdad58c39dded999494275be10 Mon Sep 17 00:00:00 2001 | 1 | From 6132115dd2f1db55a6a5371618247dfaa334a035 Mon Sep 17 00:00:00 2001 | 
| 2 | From: Lim Siew Hoon <siew.hoon.lim@intel.com> | 2 | From: Lim Siew Hoon <siew.hoon.lim@intel.com> | 
| 3 | Date: Wed, 11 Oct 2023 15:36:21 +0800 | 3 | Date: Wed, 11 Oct 2023 15:36:21 +0800 | 
| 4 | Subject: [PATCH 02/12] Force ARGB surface to tile4 for ACM | 4 | Subject: [PATCH 3/7] Force ARGB surface to tile4 for ACM | 
| 5 | 5 | ||
| 6 | Upstream-Status: Submitted [https://github.com/intel/media-driver/pull/1728] | 6 | Upstream-Status: Submitted [https://github.com/intel/media-driver/pull/1728] | 
| 7 | 7 | ||
| @@ -12,10 +12,10 @@ Signed-off-by: Lim Siew Hoon <siew.hoon.lim@intel.com> | |||
| 12 | 1 file changed, 10 insertions(+) | 12 | 1 file changed, 10 insertions(+) | 
| 13 | 13 | ||
| 14 | diff --git a/media_driver/linux/common/ddi/media_libva_util.cpp b/media_driver/linux/common/ddi/media_libva_util.cpp | 14 | diff --git a/media_driver/linux/common/ddi/media_libva_util.cpp b/media_driver/linux/common/ddi/media_libva_util.cpp | 
| 15 | index 63c173419..73be76366 100755 | 15 | index a4e12edfa..11634f66e 100755 | 
| 16 | --- a/media_driver/linux/common/ddi/media_libva_util.cpp | 16 | --- a/media_driver/linux/common/ddi/media_libva_util.cpp | 
| 17 | +++ b/media_driver/linux/common/ddi/media_libva_util.cpp | 17 | +++ b/media_driver/linux/common/ddi/media_libva_util.cpp | 
| 18 | @@ -504,6 +504,7 @@ VAStatus DdiMediaUtil_AllocateSurface( | 18 | @@ -521,6 +521,7 @@ VAStatus DdiMediaUtil_AllocateSurface( | 
| 19 | gmmCustomParams.Flags.Gpu.UnifiedAuxSurface = 0; | 19 | gmmCustomParams.Flags.Gpu.UnifiedAuxSurface = 0; | 
| 20 | } | 20 | } | 
| 21 | } | 21 | } | 
| @@ -23,7 +23,7 @@ index 63c173419..73be76366 100755 | |||
| 23 | break; | 23 | break; | 
| 24 | case TILING_X: | 24 | case TILING_X: | 
| 25 | gmmCustomParams.Flags.Info.TiledX = true; | 25 | gmmCustomParams.Flags.Info.TiledX = true; | 
| 26 | @@ -685,6 +686,15 @@ VAStatus DdiMediaUtil_AllocateSurface( | 26 | @@ -702,6 +703,15 @@ VAStatus DdiMediaUtil_AllocateSurface( | 
| 27 | } | 27 | } | 
| 28 | } | 28 | } | 
| 29 | } | 29 | } | 
| @@ -40,5 +40,5 @@ index 63c173419..73be76366 100755 | |||
| 40 | case TILING_X: | 40 | case TILING_X: | 
| 41 | gmmParams.Flags.Info.TiledX = true; | 41 | gmmParams.Flags.Info.TiledX = true; | 
| 42 | -- | 42 | -- | 
| 43 | 2.40.1 | 43 | 2.43.0 | 
| 44 | 44 | ||
| diff --git a/recipes-multimedia/libva/files/0004-Add-device-ID-for-ARL.patch b/recipes-multimedia/libva/files/0004-Add-device-ID-for-ARL.patch deleted file mode 100644 index 59fff127..00000000 --- a/recipes-multimedia/libva/files/0004-Add-device-ID-for-ARL.patch +++ /dev/null | |||
| @@ -1,45 +0,0 @@ | |||
| 1 | From bb860c0bfe53060925b1dce50da4e6e94cfc8cae Mon Sep 17 00:00:00 2001 | ||
| 2 | From: huangli2018 <li.h.huang@intel.com> | ||
| 3 | Date: Wed, 20 Dec 2023 15:47:43 +0800 | ||
| 4 | Subject: [PATCH 04/13] Add device ID for ARL | ||
| 5 | |||
| 6 | Add device ID for ARL | ||
| 7 | |||
| 8 | Upstream-Status: Backport [https://github.com/intel/media-driver/commit/95cbfce81cafa3c24d9d4601d41a855093bc51fb] | ||
| 9 | Signed-off-by: Lim Siew Hoon <siew.hoon.lim@intel.com> | ||
| 10 | --- | ||
| 11 | .../linux/Xe_M_plus/ddi/media_sysinfo_mtl.cpp | 13 +++++++++++-- | ||
| 12 | 1 file changed, 11 insertions(+), 2 deletions(-) | ||
| 13 | |||
| 14 | diff --git a/media_softlet/linux/Xe_M_plus/ddi/media_sysinfo_mtl.cpp b/media_softlet/linux/Xe_M_plus/ddi/media_sysinfo_mtl.cpp | ||
| 15 | index 426bd795f..7b73dfaff 100644 | ||
| 16 | --- a/media_softlet/linux/Xe_M_plus/ddi/media_sysinfo_mtl.cpp | ||
| 17 | +++ b/media_softlet/linux/Xe_M_plus/ddi/media_sysinfo_mtl.cpp | ||
| 18 | @@ -1,6 +1,6 @@ | ||
| 19 | /*===================== begin_copyright_notice ================================== | ||
| 20 | |||
| 21 | -Copyright (c) 2022, Intel Corporation | ||
| 22 | +Copyright (c) 2023, Intel Corporation | ||
| 23 | |||
| 24 | Permission is hereby granted, free of charge, to any person obtaining a | ||
| 25 | copy of this software and associated documentation files (the "Software"), | ||
| 26 | @@ -218,4 +218,13 @@ static struct GfxDeviceInfo arlInfo = { | ||
| 27 | }; | ||
| 28 | |||
| 29 | static bool arlsDevice7d67 = DeviceInfoFactory<GfxDeviceInfo>:: | ||
| 30 | - RegisterDevice(0x7D67, &arlInfo); | ||
| 31 | \ No newline at end of file | ||
| 32 | + RegisterDevice(0x7D67, &arlInfo); | ||
| 33 | + | ||
| 34 | +static bool arlhDevice7d51 = DeviceInfoFactory<GfxDeviceInfo>:: | ||
| 35 | + RegisterDevice(0x7D51, &arlInfo); | ||
| 36 | + | ||
| 37 | +static bool arlhDevice7dd1 = DeviceInfoFactory<GfxDeviceInfo>:: | ||
| 38 | + RegisterDevice(0x7DD1, &arlInfo); | ||
| 39 | + | ||
| 40 | +static bool arlhDevice7d41 = DeviceInfoFactory<GfxDeviceInfo>:: | ||
| 41 | + RegisterDevice(0x7D41, &arlInfo); | ||
| 42 | \ No newline at end of file | ||
| 43 | -- | ||
| 44 | 2.40.1 | ||
| 45 | |||
| diff --git a/recipes-multimedia/libva/files/0004-Fix-failed-4k-videowalll-test-case-and-color-corrupt.patch b/recipes-multimedia/libva/files/0004-Fix-failed-4k-videowalll-test-case-and-color-corrupt.patch new file mode 100644 index 00000000..49e3ff13 --- /dev/null +++ b/recipes-multimedia/libva/files/0004-Fix-failed-4k-videowalll-test-case-and-color-corrupt.patch | |||
| @@ -0,0 +1,85 @@ | |||
| 1 | From a32b95e58fd3e34847e799b909e08dbe5c9dc692 Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Lim Siew Hoon <siew.hoon.lim@intel.com> | ||
| 3 | Date: Fri, 2 Aug 2024 13:25:13 +0800 | ||
| 4 | Subject: [PATCH 4/7] Fix failed 4k videowalll test case and color corruption | ||
| 5 | of video composition in Gen12 platform | ||
| 6 | |||
| 7 | Fix failed 4k video wall test case from 16CH video only show | ||
| 8 | 1CH output and corruption observed on certain number of video | ||
| 9 | composition when doing sample_multi_transcode in legacy path. | ||
| 10 | |||
| 11 | platform: TGL/ADL/RPL | ||
| 12 | |||
| 13 | Upstream-Status: Submitted [https://github.com/intel/media-driver/pull/1839] | ||
| 14 | |||
| 15 | Signed-off-by: xupianch <xu.pian.chan@intel.com> | ||
| 16 | Signed-off-by: Lim Siew Hoon <siew.hoon.lim@intel.com> | ||
| 17 | --- | ||
| 18 | .../common/vp/hal/vphal_render_composite.cpp | 9 ++++++++- | ||
| 19 | .../linux/common/vp/ddi/media_libva_vp.c | 18 +++++------------- | ||
| 20 | 2 files changed, 13 insertions(+), 14 deletions(-) | ||
| 21 | |||
| 22 | diff --git a/media_driver/agnostic/common/vp/hal/vphal_render_composite.cpp b/media_driver/agnostic/common/vp/hal/vphal_render_composite.cpp | ||
| 23 | index 169030209..cc7c241c1 100644 | ||
| 24 | --- a/media_driver/agnostic/common/vp/hal/vphal_render_composite.cpp | ||
| 25 | +++ b/media_driver/agnostic/common/vp/hal/vphal_render_composite.cpp | ||
| 26 | @@ -6784,6 +6784,13 @@ bool CompositeState::BuildFilter( | ||
| 27 | |||
| 28 | for (i = 0; (i < (int)pCompParams->uSourceCount) && (iMaxFilterSize > 0); i++) | ||
| 29 | { | ||
| 30 | + if (i > 0) | ||
| 31 | + { | ||
| 32 | + if (!RECT1_CONTAINS_RECT2(pCompParams->pSource[0]->rcDst, pCompParams->pSource[i]->rcDst)) | ||
| 33 | + { | ||
| 34 | + pFilter->forceToTargetColorSpace = true; | ||
| 35 | + } | ||
| 36 | + } | ||
| 37 | pSrc = pCompParams->pSource[i]; | ||
| 38 | |||
| 39 | //-------------------------------- | ||
| 40 | @@ -8154,4 +8161,4 @@ bool CompositeState::IsSamplerIDForY( | ||
| 41 | return true; | ||
| 42 | } | ||
| 43 | return false; | ||
| 44 | - } | ||
| 45 | \ No newline at end of file | ||
| 46 | + } | ||
| 47 | diff --git a/media_driver/linux/common/vp/ddi/media_libva_vp.c b/media_driver/linux/common/vp/ddi/media_libva_vp.c | ||
| 48 | index 48a452315..4f0fc2c48 100644 | ||
| 49 | --- a/media_driver/linux/common/vp/ddi/media_libva_vp.c | ||
| 50 | +++ b/media_driver/linux/common/vp/ddi/media_libva_vp.c | ||
| 51 | @@ -1148,7 +1148,7 @@ DdiVp_SetProcPipelineParams( | ||
| 52 | |||
| 53 | // Background Colorfill | ||
| 54 | // According to libva definition, if alpha in output background color is zero, then colorfill is not needed | ||
| 55 | - if ((pPipelineParam->output_background_color >> 24) != 0 || pVpHalTgtSurf->ColorSpace == CSpace_sRGB) | ||
| 56 | + if ((pPipelineParam->output_background_color >> 24) != 0) | ||
| 57 | { | ||
| 58 | if (pVpHalRenderParams->pColorFillParams == nullptr) | ||
| 59 | { | ||
| 60 | @@ -1157,18 +1157,10 @@ DdiVp_SetProcPipelineParams( | ||
| 61 | |||
| 62 | DDI_CHK_NULL(pVpHalRenderParams->pColorFillParams, "Null pColorFillParams.", VA_STATUS_ERROR_UNKNOWN); | ||
| 63 | |||
| 64 | - if (pVpHalTgtSurf->ColorSpace == CSpace_sRGB && (pPipelineParam->output_background_color >> 24) == 0) | ||
| 65 | - { | ||
| 66 | - // set color space for sRGB output | ||
| 67 | - pVpHalRenderParams->pColorFillParams->CSpace = CSpace_sRGB; | ||
| 68 | - } | ||
| 69 | - else | ||
| 70 | - { | ||
| 71 | - // set background colorfill option | ||
| 72 | - pVpHalRenderParams->pColorFillParams->Color = pPipelineParam->output_background_color; | ||
| 73 | - pVpHalRenderParams->pColorFillParams->bYCbCr = false; | ||
| 74 | - pVpHalRenderParams->pColorFillParams->CSpace = CSpace_sRGB; | ||
| 75 | - } | ||
| 76 | + // set background colorfill option | ||
| 77 | + pVpHalRenderParams->pColorFillParams->Color = pPipelineParam->output_background_color; | ||
| 78 | + pVpHalRenderParams->pColorFillParams->bYCbCr = false; | ||
| 79 | + pVpHalRenderParams->pColorFillParams->CSpace = CSpace_sRGB; | ||
| 80 | }else | ||
| 81 | { | ||
| 82 | MOS_FreeMemAndSetNull(pVpHalRenderParams->pColorFillParams); | ||
| 83 | -- | ||
| 84 | 2.43.0 | ||
| 85 | |||
| diff --git a/recipes-multimedia/libva/files/0005-Add-XR24-support-to-DMABuf.patch b/recipes-multimedia/libva/files/0005-Add-XR24-support-to-DMABuf.patch deleted file mode 100644 index a9cd2317..00000000 --- a/recipes-multimedia/libva/files/0005-Add-XR24-support-to-DMABuf.patch +++ /dev/null | |||
| @@ -1,34 +0,0 @@ | |||
| 1 | From bbd3af94a6146d702909ff7e25b0c0547ecbb895 Mon Sep 17 00:00:00 2001 | ||
| 2 | From: jlui <jonathan.ming.jun.lui@intel.com> | ||
| 3 | Date: Wed, 15 Nov 2023 10:48:34 +0800 | ||
| 4 | Subject: [PATCH 05/13] Add XR24 support to DMABuf | ||
| 5 | |||
| 6 | This is to enable XR24/BGRX support for DMABuf | ||
| 7 | |||
| 8 | Signed-off-by: Lui, Jonathan Ming Jun <jonathan.ming.jun.lui@intel.com> | ||
| 9 | |||
| 10 | Upstream-Status: Backport [https://github.com/intel/media-driver/commit/3910b7029f5416fd0b5972f940c65d0a82c48c7b] | ||
| 11 | |||
| 12 | Signed-off-by: Lim, Siew Hoon <siew.hoon.lim@intel.com> | ||
| 13 | --- | ||
| 14 | .../vp/ddi/capstable_data_vp_xe_lpm_plus_r0_specific.h | 3 ++- | ||
| 15 | 1 file changed, 2 insertions(+), 1 deletion(-) | ||
| 16 | |||
| 17 | diff --git a/media_softlet/linux/xe_lpm_plus_r0/vp/ddi/capstable_data_vp_xe_lpm_plus_r0_specific.h b/media_softlet/linux/xe_lpm_plus_r0/vp/ddi/capstable_data_vp_xe_lpm_plus_r0_specific.h | ||
| 18 | index fdcca8873..2dcf440a4 100644 | ||
| 19 | --- a/media_softlet/linux/xe_lpm_plus_r0/vp/ddi/capstable_data_vp_xe_lpm_plus_r0_specific.h | ||
| 20 | +++ b/media_softlet/linux/xe_lpm_plus_r0/vp/ddi/capstable_data_vp_xe_lpm_plus_r0_specific.h | ||
| 21 | @@ -55,8 +55,9 @@ static ProfileSurfaceAttribInfo surfaceAttribInfo_VAEntrypointVideoProc_VAProfil | ||
| 22 | {VASurfaceAttribPixelFormat, VA_SURFACE_ATTRIB_GETTABLE | VA_SURFACE_ATTRIB_SETTABLE, {VAGenericValueTypeInteger, {VA_FOURCC('4', '2', '2', 'V')}}}, | ||
| 23 | {VASurfaceAttribPixelFormat, VA_SURFACE_ATTRIB_GETTABLE | VA_SURFACE_ATTRIB_SETTABLE, {VAGenericValueTypeInteger, {VA_FOURCC('R', 'G', 'B', 'A')}}}, | ||
| 24 | {VASurfaceAttribPixelFormat, VA_SURFACE_ATTRIB_GETTABLE | VA_SURFACE_ATTRIB_SETTABLE, {VAGenericValueTypeInteger, {VA_FOURCC('B', 'G', 'R', 'A')}}}, | ||
| 25 | - {VASurfaceAttribPixelFormat, VA_SURFACE_ATTRIB_GETTABLE | VA_SURFACE_ATTRIB_SETTABLE, {VAGenericValueTypeInteger, { VA_FOURCC('R', 'G', 'B', 'P')}}}, | ||
| 26 | + {VASurfaceAttribPixelFormat, VA_SURFACE_ATTRIB_GETTABLE | VA_SURFACE_ATTRIB_SETTABLE, {VAGenericValueTypeInteger, {VA_FOURCC('R', 'G', 'B', 'P')}}}, | ||
| 27 | {VASurfaceAttribPixelFormat, VA_SURFACE_ATTRIB_GETTABLE | VA_SURFACE_ATTRIB_SETTABLE, {VAGenericValueTypeInteger, {VA_FOURCC('R', 'G', 'B', 'X')}}}, | ||
| 28 | + {VASurfaceAttribPixelFormat, VA_SURFACE_ATTRIB_GETTABLE | VA_SURFACE_ATTRIB_SETTABLE, {VAGenericValueTypeInteger, {VA_FOURCC('X', 'R', 'G', 'B')}}}, | ||
| 29 | {VASurfaceAttribPixelFormat, VA_SURFACE_ATTRIB_GETTABLE | VA_SURFACE_ATTRIB_SETTABLE, {VAGenericValueTypeInteger, {VA_FOURCC('P', '0', '1', '0')}}}, | ||
| 30 | {VASurfaceAttribPixelFormat, VA_SURFACE_ATTRIB_GETTABLE | VA_SURFACE_ATTRIB_SETTABLE, {VAGenericValueTypeInteger, {VA_FOURCC('R', 'G', '2', '4')}}}, | ||
| 31 | {VASurfaceAttribPixelFormat, VA_SURFACE_ATTRIB_GETTABLE | VA_SURFACE_ATTRIB_SETTABLE, {VAGenericValueTypeInteger, {VA_FOURCC_ARGB}}}, | ||
| 32 | -- | ||
| 33 | 2.40.1 | ||
| 34 | |||
| diff --git a/recipes-multimedia/libva/files/0006-add-INTEL-MEDIA-ALLOC-refineE-to-specify-the-memory-.patch b/recipes-multimedia/libva/files/0006-add-INTEL-MEDIA-ALLOC-refineE-to-specify-the-memory-.patch deleted file mode 100644 index 5b04201a..00000000 --- a/recipes-multimedia/libva/files/0006-add-INTEL-MEDIA-ALLOC-refineE-to-specify-the-memory-.patch +++ /dev/null | |||
| @@ -1,214 +0,0 @@ | |||
| 1 | From 67fb6128adf8fc03d429393e98f0982b42a40e64 Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Zhang_Xinfeng <carl.zhang@intel.com> | ||
| 3 | Date: Wed, 27 Dec 2023 09:59:29 +0800 | ||
| 4 | Subject: [PATCH 06/12] add INTEL MEDIA ALLOC refineE to specify the memory | ||
| 5 | alignment | ||
| 6 | |||
| 7 | this key is used to allocate bigger pages | ||
| 8 | env variable INTEL_MEDIA_ALLOC_refineE also could be used | ||
| 9 | and was not enabled by default | ||
| 10 | mode 0 is default mode | ||
| 11 | mode 1 is < 64 align to 64 | ||
| 12 | mode 2 is > 1M && <= 3M align to 1M, >3M align to 2M | ||
| 13 | mode 3 is mode 1 & mode 2 | ||
| 14 | |||
| 15 | Upstream-Status: Backport [https://github.com/intel/media-driver/commit/765dd939dcc5562d18cca18e5eda505bda952797] | ||
| 16 | Signed-off-by: Lim, Siew Hoon <siew.hoon.lim@intel.com> | ||
| 17 | --- | ||
| 18 | .../linux/common/os/i915/mos_bufmgr.c | 75 +++++++++++++++---- | ||
| 19 | .../common/os/i915_production/mos_bufmgr.c | 1 + | ||
| 20 | .../common/os/mos_context_specific_next.cpp | 21 +++++- | ||
| 21 | .../common/os/mos_user_setting_specific.cpp | 7 ++ | ||
| 22 | 4 files changed, 90 insertions(+), 14 deletions(-) | ||
| 23 | |||
| 24 | diff --git a/media_softlet/linux/common/os/i915/mos_bufmgr.c b/media_softlet/linux/common/os/i915/mos_bufmgr.c | ||
| 25 | index c0b3ba027..b623d0129 100644 | ||
| 26 | --- a/media_softlet/linux/common/os/i915/mos_bufmgr.c | ||
| 27 | +++ b/media_softlet/linux/common/os/i915/mos_bufmgr.c | ||
| 28 | @@ -138,7 +138,7 @@ struct mos_bufmgr_gem { | ||
| 29 | int exec_count; | ||
| 30 | |||
| 31 | /** Array of lists of cached gem objects of power-of-two sizes */ | ||
| 32 | - struct mos_gem_bo_bucket cache_bucket[14 * 4]; | ||
| 33 | + struct mos_gem_bo_bucket cache_bucket[64]; | ||
| 34 | int num_buckets; | ||
| 35 | time_t time; | ||
| 36 | |||
| 37 | @@ -3852,9 +3852,9 @@ add_bucket(struct mos_bufmgr_gem *bufmgr_gem, int size) | ||
| 38 | } | ||
| 39 | |||
| 40 | static void | ||
| 41 | -init_cache_buckets(struct mos_bufmgr_gem *bufmgr_gem) | ||
| 42 | +init_cache_buckets(struct mos_bufmgr_gem *bufmgr_gem, uint8_t alloc_mode) | ||
| 43 | { | ||
| 44 | - unsigned long size, cache_max_size = 64 * 1024 * 1024; | ||
| 45 | + unsigned long size, cache_max_size = 64 * 1024 * 1024, unit_size; | ||
| 46 | |||
| 47 | /* OK, so power of two buckets was too wasteful of memory. | ||
| 48 | * Give 3 other sizes between each power of two, to hopefully | ||
| 49 | @@ -3864,17 +3864,63 @@ init_cache_buckets(struct mos_bufmgr_gem *bufmgr_gem) | ||
| 50 | * width/height alignment and rounding of sizes to pages will | ||
| 51 | * get us useful cache hit rates anyway) | ||
| 52 | */ | ||
| 53 | - add_bucket(bufmgr_gem, 4096); | ||
| 54 | - add_bucket(bufmgr_gem, 4096 * 2); | ||
| 55 | - add_bucket(bufmgr_gem, 4096 * 3); | ||
| 56 | + /* alloc_mode 0 is default alloc_mode | ||
| 57 | + * alloc_mode 1 rounding up to 64K for all < 1M | ||
| 58 | + * alloc_mode 2 rounding up to 2M for size> 1M | ||
| 59 | + * alloc_mode 3 rounding up to 2M for size > 1M and 64K for size <= 1M */ | ||
| 60 | + if( alloc_mode > 3 ) | ||
| 61 | + alloc_mode = 0; | ||
| 62 | + | ||
| 63 | + if ( 0 == alloc_mode || 2 == alloc_mode) | ||
| 64 | + { | ||
| 65 | + // < 1M normal alloc_mode | ||
| 66 | + add_bucket(bufmgr_gem, 4096); | ||
| 67 | + add_bucket(bufmgr_gem, 4096 * 2); | ||
| 68 | + add_bucket(bufmgr_gem, 4096 * 3); | ||
| 69 | + /* Initialize the linked lists for BO reuse cache. */ | ||
| 70 | + for (size = 4 * 4096; size < 1024 * 1024; size *= 2) { | ||
| 71 | + add_bucket(bufmgr_gem, size); | ||
| 72 | + add_bucket(bufmgr_gem, size + size * 1 / 4); | ||
| 73 | + add_bucket(bufmgr_gem, size + size * 2 / 4); | ||
| 74 | + add_bucket(bufmgr_gem, size + size * 3 / 4); | ||
| 75 | + } | ||
| 76 | |||
| 77 | - /* Initialize the linked lists for BO reuse cache. */ | ||
| 78 | - for (size = 4 * 4096; size <= cache_max_size; size *= 2) { | ||
| 79 | - add_bucket(bufmgr_gem, size); | ||
| 80 | + add_bucket(bufmgr_gem, 1024 * 1024); | ||
| 81 | + } | ||
| 82 | + if (1 == alloc_mode || 3 == alloc_mode) | ||
| 83 | + { | ||
| 84 | + // < 1M 64k alignment | ||
| 85 | + unit_size = 64 * 1024; | ||
| 86 | + for (size = unit_size; size <= 1024 * 1024; size += unit_size) | ||
| 87 | + { | ||
| 88 | + add_bucket(bufmgr_gem, size); | ||
| 89 | + } | ||
| 90 | + } | ||
| 91 | + if( 0 == alloc_mode || 1 == alloc_mode) | ||
| 92 | + { | ||
| 93 | + //> 1M is normal alloc_mode | ||
| 94 | + add_bucket(bufmgr_gem, 1280 * 1024); | ||
| 95 | + add_bucket(bufmgr_gem, 1536 * 1024); | ||
| 96 | + add_bucket(bufmgr_gem, 1792 * 1024); | ||
| 97 | + | ||
| 98 | + for (size = 2 * 1024 * 1024; size < cache_max_size; size *= 2) { | ||
| 99 | + add_bucket(bufmgr_gem, size); | ||
| 100 | + add_bucket(bufmgr_gem, size + size * 1 / 4); | ||
| 101 | + add_bucket(bufmgr_gem, size + size * 2 / 4); | ||
| 102 | + add_bucket(bufmgr_gem, size + size * 3 / 4); | ||
| 103 | + } | ||
| 104 | + } | ||
| 105 | + if( 2 == alloc_mode || 3 == alloc_mode) | ||
| 106 | + { | ||
| 107 | + //> 1M rolling to 2M | ||
| 108 | + unit_size = 2 * 1024 * 1024; | ||
| 109 | + add_bucket(bufmgr_gem, unit_size); | ||
| 110 | + add_bucket(bufmgr_gem, 3 * 1024 * 1024); | ||
| 111 | |||
| 112 | - add_bucket(bufmgr_gem, size + size * 1 / 4); | ||
| 113 | - add_bucket(bufmgr_gem, size + size * 2 / 4); | ||
| 114 | - add_bucket(bufmgr_gem, size + size * 3 / 4); | ||
| 115 | + for (size = 4 * 1024 * 1024; size <= cache_max_size; size += unit_size) | ||
| 116 | + { | ||
| 117 | + add_bucket(bufmgr_gem, size); | ||
| 118 | + } | ||
| 119 | } | ||
| 120 | } | ||
| 121 | |||
| 122 | @@ -5100,6 +5146,7 @@ mos_bufmgr_gem_init_i915(int fd, int batch_size) | ||
| 123 | struct drm_i915_gem_get_aperture aperture; | ||
| 124 | drm_i915_getparam_t gp; | ||
| 125 | int ret, tmp; | ||
| 126 | + uint8_t alloc_mode; | ||
| 127 | bool exec2 = false; | ||
| 128 | |||
| 129 | pthread_mutex_lock(&bufmgr_list_mutex); | ||
| 130 | @@ -5352,10 +5399,12 @@ mos_bufmgr_gem_init_i915(int fd, int batch_size) | ||
| 131 | * | ||
| 132 | * Every 4 was too few for the blender benchmark. | ||
| 133 | */ | ||
| 134 | + alloc_mode = (uint8_t)(batch_size & 0xff); | ||
| 135 | + batch_size &= 0xffffff00; | ||
| 136 | bufmgr_gem->max_relocs = batch_size / sizeof(uint32_t) / 2 - 2; | ||
| 137 | |||
| 138 | DRMINITLISTHEAD(&bufmgr_gem->named); | ||
| 139 | - init_cache_buckets(bufmgr_gem); | ||
| 140 | + init_cache_buckets(bufmgr_gem,alloc_mode); | ||
| 141 | |||
| 142 | DRMLISTADD(&bufmgr_gem->managers, &bufmgr_list); | ||
| 143 | |||
| 144 | diff --git a/media_softlet/linux/common/os/i915_production/mos_bufmgr.c b/media_softlet/linux/common/os/i915_production/mos_bufmgr.c | ||
| 145 | index 90b5685b1..b3574f7d3 100644 | ||
| 146 | --- a/media_softlet/linux/common/os/i915_production/mos_bufmgr.c | ||
| 147 | +++ b/media_softlet/linux/common/os/i915_production/mos_bufmgr.c | ||
| 148 | @@ -5403,6 +5403,7 @@ mos_bufmgr_gem_init_i915(int fd, int batch_size) | ||
| 149 | * | ||
| 150 | * Every 4 was too few for the blender benchmark. | ||
| 151 | */ | ||
| 152 | + batch_size &= 0xffffff00; | ||
| 153 | bufmgr_gem->max_relocs = batch_size / sizeof(uint32_t) / 2 - 2; | ||
| 154 | |||
| 155 | DRMINITLISTHEAD(&bufmgr_gem->named); | ||
| 156 | diff --git a/media_softlet/linux/common/os/mos_context_specific_next.cpp b/media_softlet/linux/common/os/mos_context_specific_next.cpp | ||
| 157 | index 9e9e3ff7e..543e262d1 100644 | ||
| 158 | --- a/media_softlet/linux/common/os/mos_context_specific_next.cpp | ||
| 159 | +++ b/media_softlet/linux/common/os/mos_context_specific_next.cpp | ||
| 160 | @@ -64,6 +64,7 @@ MOS_STATUS OsContextSpecificNext::Init(DDI_DEVICE_CONTEXT ddiDriverContext) | ||
| 161 | uint32_t iDeviceId = 0; | ||
| 162 | MOS_STATUS eStatus = MOS_STATUS_SUCCESS; | ||
| 163 | uint32_t value = 0; | ||
| 164 | + uint32_t mode = 0; | ||
| 165 | MediaUserSettingSharedPtr userSettingPtr = nullptr; | ||
| 166 | |||
| 167 | MOS_OS_FUNCTION_ENTER; | ||
| 168 | @@ -89,7 +90,25 @@ MOS_STATUS OsContextSpecificNext::Init(DDI_DEVICE_CONTEXT ddiDriverContext) | ||
| 169 | |||
| 170 | userSettingPtr = MosInterface::MosGetUserSettingInstance(osDriverContext); | ||
| 171 | |||
| 172 | - m_bufmgr = mos_bufmgr_gem_init(m_fd, BATCH_BUFFER_SIZE, &m_deviceType); | ||
| 173 | + mode = BATCH_BUFFER_SIZE; | ||
| 174 | + ReadUserSetting( | ||
| 175 | + userSettingPtr, | ||
| 176 | + value, | ||
| 177 | + "INTEL MEDIA ALLOC MODE", | ||
| 178 | + MediaUserSetting::Group::Device); | ||
| 179 | + | ||
| 180 | + if (value) | ||
| 181 | + { | ||
| 182 | + mode |= (value & 0x000000ff); | ||
| 183 | + } | ||
| 184 | + value = 0; | ||
| 185 | + /* no need to set batch buffer size after switch to softpin | ||
| 186 | + * keep it, just for test during relocation to softpin transition | ||
| 187 | + * now , it could be a debug method , but is actually useless | ||
| 188 | + * so it is safe to reuse the lowest 8bit to convey addtional information | ||
| 189 | + * more suitable solution is deleting it , or add additional parameter*/ | ||
| 190 | + | ||
| 191 | + m_bufmgr = mos_bufmgr_gem_init(m_fd, (int)mode, &m_deviceType); | ||
| 192 | if (nullptr == m_bufmgr) | ||
| 193 | { | ||
| 194 | MOS_OS_ASSERTMESSAGE("Not able to allocate buffer manager, fd=0x%d", m_fd); | ||
| 195 | diff --git a/media_softlet/linux/common/os/mos_user_setting_specific.cpp b/media_softlet/linux/common/os/mos_user_setting_specific.cpp | ||
| 196 | index 6be8b4298..caed584f4 100644 | ||
| 197 | --- a/media_softlet/linux/common/os/mos_user_setting_specific.cpp | ||
| 198 | +++ b/media_softlet/linux/common/os/mos_user_setting_specific.cpp | ||
| 199 | @@ -52,5 +52,12 @@ MOS_STATUS MosUserSetting::InitMosUserSettingSpecific(MediaUserSettingSharedPtr | ||
| 200 | 0, | ||
| 201 | true); //"Enable VM Bind." | ||
| 202 | |||
| 203 | + DeclareUserSettingKey( | ||
| 204 | + userSettingPtr, | ||
| 205 | + "INTEL MEDIA ALLOC MODE", | ||
| 206 | + MediaUserSetting::Group::Device, | ||
| 207 | + 0, | ||
| 208 | + false); // | ||
| 209 | + | ||
| 210 | return MOS_STATUS_SUCCESS; | ||
| 211 | } | ||
| 212 | -- | ||
| 213 | 2.40.1 | ||
| 214 | |||
| diff --git a/recipes-multimedia/libva/files/0007-Skip-report-keys.patch b/recipes-multimedia/libva/files/0007-Skip-report-keys.patch deleted file mode 100644 index 459ff490..00000000 --- a/recipes-multimedia/libva/files/0007-Skip-report-keys.patch +++ /dev/null | |||
| @@ -1,78 +0,0 @@ | |||
| 1 | From b1aebef4d342c77fc2b9c5efbf20aeb2aa9d634e Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Wang_Pingli <pingli.wang@intel.com> | ||
| 3 | Date: Thu, 28 Dec 2023 16:44:40 +0800 | ||
| 4 | Subject: [PATCH 07/12] Skip report keys | ||
| 5 | |||
| 6 | Skip to report keys | ||
| 7 | |||
| 8 | Upstream-Status: Backport [https://github.com/intel/media-driver/commit/68ce25b0a6fa90614eb4734c8680aa4e149e8323] | ||
| 9 | Signed-off-by: Lim, Siew Hoon <siew.hoon.lim@intel.com> | ||
| 10 | --- | ||
| 11 | .../os/osservice/mos_utilities_specific.cpp | 30 +++++++++++++++++-- | ||
| 12 | 1 file changed, 28 insertions(+), 2 deletions(-) | ||
| 13 | |||
| 14 | diff --git a/media_softlet/linux/common/os/osservice/mos_utilities_specific.cpp b/media_softlet/linux/common/os/osservice/mos_utilities_specific.cpp | ||
| 15 | index b5df29f06..96785e21e 100644 | ||
| 16 | --- a/media_softlet/linux/common/os/osservice/mos_utilities_specific.cpp | ||
| 17 | +++ b/media_softlet/linux/common/os/osservice/mos_utilities_specific.cpp | ||
| 18 | @@ -67,6 +67,8 @@ int32_t g_mosMemoryFailSimulateAllocCounter = 0; | ||
| 19 | int32_t *MosUtilities::m_mosAllocMemoryFailSimulateAllocCounter = &g_mosMemoryFailSimulateAllocCounter; | ||
| 20 | #endif | ||
| 21 | |||
| 22 | +static bool s_skipToReportReg = false; | ||
| 23 | + | ||
| 24 | double MosUtilities::MosGetTime() | ||
| 25 | { | ||
| 26 | struct timespec ts = {}; | ||
| 27 | @@ -1551,6 +1553,10 @@ MOS_STATUS MosUtilities::MosInitializeReg(RegBufferMap ®BufferMap) | ||
| 28 | { | ||
| 29 | std::string id = ""; | ||
| 30 | |||
| 31 | + static const char *disableReportRegKeyList[] = { | ||
| 32 | + "INTEL MEDIA ALLOC MODE" | ||
| 33 | + }; | ||
| 34 | + static const uint32_t disableReportRegKeyListCount = sizeof(disableReportRegKeyList) / sizeof(disableReportRegKeyList[0]); | ||
| 35 | while(!regStream.eof()) | ||
| 36 | { | ||
| 37 | std::string line = ""; | ||
| 38 | @@ -1585,8 +1591,22 @@ MOS_STATUS MosUtilities::MosInitializeReg(RegBufferMap ®BufferMap) | ||
| 39 | { | ||
| 40 | std::string name = line.substr(0,pos); | ||
| 41 | std::string value = line.substr(pos+1); | ||
| 42 | - auto &keys = regBufferMap[id]; | ||
| 43 | - keys[name] = value; | ||
| 44 | + if (name.size() > 0 && value.size() > 0) | ||
| 45 | + { | ||
| 46 | + auto &keys = regBufferMap[id]; | ||
| 47 | + keys[name] = value; | ||
| 48 | + if (s_skipToReportReg == false && id == USER_SETTING_CONFIG_PATH) | ||
| 49 | + { | ||
| 50 | + for (uint32_t i = 0; i < disableReportRegKeyListCount; i++) | ||
| 51 | + { | ||
| 52 | + if (strcmp(name.c_str(), disableReportRegKeyList[i]) == 0) | ||
| 53 | + { | ||
| 54 | + s_skipToReportReg = true; | ||
| 55 | + break; | ||
| 56 | + } | ||
| 57 | + } | ||
| 58 | + } | ||
| 59 | + } | ||
| 60 | } | ||
| 61 | } | ||
| 62 | } | ||
| 63 | @@ -1606,6 +1626,12 @@ MOS_STATUS MosUtilities::MosInitializeReg(RegBufferMap ®BufferMap) | ||
| 64 | MOS_STATUS MosUtilities::MosUninitializeReg(RegBufferMap ®BufferMap) | ||
| 65 | { | ||
| 66 | MOS_STATUS status = MOS_STATUS_SUCCESS; | ||
| 67 | + | ||
| 68 | + if (s_skipToReportReg) | ||
| 69 | + { | ||
| 70 | + return MOS_STATUS_SUCCESS; | ||
| 71 | + } | ||
| 72 | + | ||
| 73 | if (regBufferMap.size() == 0) | ||
| 74 | { | ||
| 75 | return MOS_STATUS_SUCCESS; | ||
| 76 | -- | ||
| 77 | 2.40.1 | ||
| 78 | |||
| diff --git a/recipes-multimedia/libva/files/0008-Limit-INTEL-MEDIA-ALLOC-MODE-to-MTL-and-ARL-only.patch b/recipes-multimedia/libva/files/0008-Limit-INTEL-MEDIA-ALLOC-MODE-to-MTL-and-ARL-only.patch deleted file mode 100644 index ece5e00b..00000000 --- a/recipes-multimedia/libva/files/0008-Limit-INTEL-MEDIA-ALLOC-MODE-to-MTL-and-ARL-only.patch +++ /dev/null | |||
| @@ -1,255 +0,0 @@ | |||
| 1 | From ac2ffac8d4aade216cc361c6c7120c13a8780719 Mon Sep 17 00:00:00 2001 | ||
| 2 | From: "Soon, Thean Siew" <thean.siew.soon@intel.com> | ||
| 3 | Date: Thu, 28 Dec 2023 18:42:59 +0000 | ||
| 4 | Subject: [PATCH 08/12] Limit INTEL MEDIA ALLOC MODE to MTL and ARL only | ||
| 5 | |||
| 6 | Upstream-Status: Submitted [https://github.com/intel/media-driver/pull/1754] | ||
| 7 | |||
| 8 | Signed-off-by: Soon, Thean Siew <thean.siew.soon@intel.com> | ||
| 9 | --- | ||
| 10 | .../common/os/i915/include/mos_bufmgr_api.h | 1 + | ||
| 11 | .../common/os/i915/include/mos_bufmgr_priv.h | 2 +- | ||
| 12 | .../linux/common/os/i915/mos_bufmgr.c | 69 +++++++++++++++---- | ||
| 13 | .../linux/common/os/i915/mos_bufmgr_api.c | 19 +++++ | ||
| 14 | .../os/i915_production/mos_bufmgr_priv.h | 1 + | ||
| 15 | .../common/os/mos_context_specific_next.cpp | 36 +++++----- | ||
| 16 | 6 files changed, 94 insertions(+), 34 deletions(-) | ||
| 17 | |||
| 18 | diff --git a/media_softlet/linux/common/os/i915/include/mos_bufmgr_api.h b/media_softlet/linux/common/os/i915/include/mos_bufmgr_api.h | ||
| 19 | index 71cc01099..ab4f1ba89 100644 | ||
| 20 | --- a/media_softlet/linux/common/os/i915/include/mos_bufmgr_api.h | ||
| 21 | +++ b/media_softlet/linux/common/os/i915/include/mos_bufmgr_api.h | ||
| 22 | @@ -299,6 +299,7 @@ void mos_bufmgr_enable_vmbind(struct mos_bufmgr *bufmgr); | ||
| 23 | void mos_bufmgr_disable_object_capture(struct mos_bufmgr *bufmgr); | ||
| 24 | int mos_bufmgr_get_memory_info(struct mos_bufmgr *bufmgr, char *info, uint32_t length); | ||
| 25 | int mos_bufmgr_get_devid(struct mos_bufmgr *bufmgr); | ||
| 26 | +void mos_bufmgr_realloc_cache(struct mos_bufmgr *bufmgr, uint8_t alloc_mode); | ||
| 27 | |||
| 28 | int mos_bo_map_unsynchronized(struct mos_linux_bo *bo); | ||
| 29 | int mos_bo_map_gtt(struct mos_linux_bo *bo); | ||
| 30 | diff --git a/media_softlet/linux/common/os/i915/include/mos_bufmgr_priv.h b/media_softlet/linux/common/os/i915/include/mos_bufmgr_priv.h | ||
| 31 | index 63f69f985..6fd58f827 100644 | ||
| 32 | --- a/media_softlet/linux/common/os/i915/include/mos_bufmgr_priv.h | ||
| 33 | +++ b/media_softlet/linux/common/os/i915/include/mos_bufmgr_priv.h | ||
| 34 | @@ -358,9 +358,9 @@ struct mos_bufmgr { | ||
| 35 | void (*disable_object_capture)(struct mos_bufmgr *bufmgr) = nullptr; | ||
| 36 | int (*get_memory_info)(struct mos_bufmgr *bufmgr, char *info, uint32_t length) = nullptr; | ||
| 37 | int (*get_devid)(struct mos_bufmgr *bufmgr) = nullptr; | ||
| 38 | + void (*realloc_cache)(struct mos_bufmgr *bufmgr, uint8_t alloc_mode) = nullptr; | ||
| 39 | int (*query_engines_count)(struct mos_bufmgr *bufmgr, | ||
| 40 | unsigned int *nengine) = nullptr; | ||
| 41 | - | ||
| 42 | int (*query_engines)(struct mos_bufmgr *bufmgr, | ||
| 43 | __u16 engine_class, | ||
| 44 | __u64 caps, | ||
| 45 | diff --git a/media_softlet/linux/common/os/i915/mos_bufmgr.c b/media_softlet/linux/common/os/i915/mos_bufmgr.c | ||
| 46 | index b623d0129..2814ddbb7 100644 | ||
| 47 | --- a/media_softlet/linux/common/os/i915/mos_bufmgr.c | ||
| 48 | +++ b/media_softlet/linux/common/os/i915/mos_bufmgr.c | ||
| 49 | @@ -2426,19 +2426,9 @@ mos_gem_bo_start_gtt_access(struct mos_linux_bo *bo, int write_enable) | ||
| 50 | } | ||
| 51 | |||
| 52 | static void | ||
| 53 | -mos_bufmgr_gem_destroy(struct mos_bufmgr *bufmgr) | ||
| 54 | +mos_bufmgr_cleanup_cache(struct mos_bufmgr_gem *bufmgr_gem) | ||
| 55 | { | ||
| 56 | - struct mos_bufmgr_gem *bufmgr_gem = (struct mos_bufmgr_gem *) bufmgr; | ||
| 57 | - struct drm_gem_close close_bo; | ||
| 58 | - int i, ret; | ||
| 59 | - | ||
| 60 | - free(bufmgr_gem->exec2_objects); | ||
| 61 | - free(bufmgr_gem->exec_objects); | ||
| 62 | - free(bufmgr_gem->exec_bos); | ||
| 63 | - pthread_mutex_destroy(&bufmgr_gem->lock); | ||
| 64 | - | ||
| 65 | - /* Free any cached buffer objects we were going to reuse */ | ||
| 66 | - for (i = 0; i < bufmgr_gem->num_buckets; i++) { | ||
| 67 | + for (int i = 0; i < bufmgr_gem->num_buckets; i++) { | ||
| 68 | struct mos_gem_bo_bucket *bucket = | ||
| 69 | &bufmgr_gem->cache_bucket[i]; | ||
| 70 | struct mos_bo_gem *bo_gem; | ||
| 71 | @@ -2450,7 +2440,25 @@ mos_bufmgr_gem_destroy(struct mos_bufmgr *bufmgr) | ||
| 72 | |||
| 73 | mos_gem_bo_free(&bo_gem->bo); | ||
| 74 | } | ||
| 75 | + bufmgr_gem->cache_bucket[i].size = 0; | ||
| 76 | } | ||
| 77 | + bufmgr_gem->num_buckets = 0; | ||
| 78 | +} | ||
| 79 | + | ||
| 80 | +static void | ||
| 81 | +mos_bufmgr_gem_destroy(struct mos_bufmgr *bufmgr) | ||
| 82 | +{ | ||
| 83 | + struct mos_bufmgr_gem *bufmgr_gem = (struct mos_bufmgr_gem *)bufmgr; | ||
| 84 | + struct drm_gem_close close_bo; | ||
| 85 | + int ret; | ||
| 86 | + | ||
| 87 | + free(bufmgr_gem->exec2_objects); | ||
| 88 | + free(bufmgr_gem->exec_objects); | ||
| 89 | + free(bufmgr_gem->exec_bos); | ||
| 90 | + pthread_mutex_destroy(&bufmgr_gem->lock); | ||
| 91 | + | ||
| 92 | + /* Free any cached buffer objects we were going to reuse */ | ||
| 93 | + mos_bufmgr_cleanup_cache(bufmgr_gem); | ||
| 94 | |||
| 95 | /* Release userptr bo kept hanging around for optimisation. */ | ||
| 96 | if (bufmgr_gem->userptr_active.ptr) { | ||
| 97 | @@ -3852,9 +3860,41 @@ add_bucket(struct mos_bufmgr_gem *bufmgr_gem, int size) | ||
| 98 | } | ||
| 99 | |||
| 100 | static void | ||
| 101 | -init_cache_buckets(struct mos_bufmgr_gem *bufmgr_gem, uint8_t alloc_mode) | ||
| 102 | +init_cache_buckets(struct mos_bufmgr_gem *bufmgr_gem) | ||
| 103 | +{ | ||
| 104 | + unsigned long size, cache_max_size = 64 * 1024 * 1024; | ||
| 105 | + | ||
| 106 | + /* OK, so power of two buckets was too wasteful of memory. | ||
| 107 | + * Give 3 other sizes between each power of two, to hopefully | ||
| 108 | + * cover things accurately enough. (The alternative is | ||
| 109 | + * probably to just go for exact matching of sizes, and assume | ||
| 110 | + * that for things like composited window resize the tiled | ||
| 111 | + * width/height alignment and rounding of sizes to pages will | ||
| 112 | + * get us useful cache hit rates anyway) | ||
| 113 | + */ | ||
| 114 | + add_bucket(bufmgr_gem, 4096); | ||
| 115 | + add_bucket(bufmgr_gem, 4096 * 2); | ||
| 116 | + add_bucket(bufmgr_gem, 4096 * 3); | ||
| 117 | + | ||
| 118 | + /* Initialize the linked lists for BO reuse cache. */ | ||
| 119 | + for (size = 4 * 4096; size <= cache_max_size; size *= 2) { | ||
| 120 | + add_bucket(bufmgr_gem, size); | ||
| 121 | + | ||
| 122 | + add_bucket(bufmgr_gem, size + size * 1 / 4); | ||
| 123 | + add_bucket(bufmgr_gem, size + size * 2 / 4); | ||
| 124 | + add_bucket(bufmgr_gem, size + size * 3 / 4); | ||
| 125 | + } | ||
| 126 | +} | ||
| 127 | + | ||
| 128 | +static void | ||
| 129 | +mos_gem_realloc_cache(struct mos_bufmgr *bufmgr, uint8_t alloc_mode) | ||
| 130 | { | ||
| 131 | unsigned long size, cache_max_size = 64 * 1024 * 1024, unit_size; | ||
| 132 | + struct mos_bufmgr_gem *bufmgr_gem = (struct mos_bufmgr_gem *)bufmgr; | ||
| 133 | + | ||
| 134 | + // Clean up the pre-allocated cache before re-allocating according | ||
| 135 | + // to alloc_mode | ||
| 136 | + mos_bufmgr_cleanup_cache(bufmgr_gem); | ||
| 137 | |||
| 138 | /* OK, so power of two buckets was too wasteful of memory. | ||
| 139 | * Give 3 other sizes between each power of two, to hopefully | ||
| 140 | @@ -5218,6 +5258,7 @@ mos_bufmgr_gem_init_i915(int fd, int batch_size) | ||
| 141 | bufmgr_gem->bufmgr.disable_object_capture = mos_gem_disable_object_capture; | ||
| 142 | bufmgr_gem->bufmgr.get_memory_info = mos_gem_get_memory_info; | ||
| 143 | bufmgr_gem->bufmgr.get_devid = mos_gem_get_devid; | ||
| 144 | + bufmgr_gem->bufmgr.realloc_cache = mos_gem_realloc_cache; | ||
| 145 | bufmgr_gem->bufmgr.set_context_param = mos_gem_set_context_param; | ||
| 146 | bufmgr_gem->bufmgr.set_context_param_parallel = mos_gem_set_context_param_parallel; | ||
| 147 | bufmgr_gem->bufmgr.set_context_param_load_balance = mos_gem_set_context_param_load_balance; | ||
| 148 | @@ -5404,7 +5445,7 @@ mos_bufmgr_gem_init_i915(int fd, int batch_size) | ||
| 149 | bufmgr_gem->max_relocs = batch_size / sizeof(uint32_t) / 2 - 2; | ||
| 150 | |||
| 151 | DRMINITLISTHEAD(&bufmgr_gem->named); | ||
| 152 | - init_cache_buckets(bufmgr_gem,alloc_mode); | ||
| 153 | + init_cache_buckets(bufmgr_gem); | ||
| 154 | |||
| 155 | DRMLISTADD(&bufmgr_gem->managers, &bufmgr_list); | ||
| 156 | |||
| 157 | diff --git a/media_softlet/linux/common/os/i915/mos_bufmgr_api.c b/media_softlet/linux/common/os/i915/mos_bufmgr_api.c | ||
| 158 | index abe8ef96a..d0e02c267 100644 | ||
| 159 | --- a/media_softlet/linux/common/os/i915/mos_bufmgr_api.c | ||
| 160 | +++ b/media_softlet/linux/common/os/i915/mos_bufmgr_api.c | ||
| 161 | @@ -1204,6 +1204,25 @@ mos_bufmgr_get_devid(struct mos_bufmgr *bufmgr) | ||
| 162 | } | ||
| 163 | } | ||
| 164 | |||
| 165 | +void | ||
| 166 | +mos_bufmgr_realloc_cache(struct mos_bufmgr *bufmgr, uint8_t alloc_mode) | ||
| 167 | +{ | ||
| 168 | + if(!bufmgr) | ||
| 169 | + { | ||
| 170 | + MOS_OS_CRITICALMESSAGE("Input null ptr\n"); | ||
| 171 | + return; | ||
| 172 | + } | ||
| 173 | + | ||
| 174 | + if (bufmgr->realloc_cache) | ||
| 175 | + { | ||
| 176 | + return bufmgr->realloc_cache(bufmgr, alloc_mode); | ||
| 177 | + } | ||
| 178 | + else | ||
| 179 | + { | ||
| 180 | + MOS_OS_CRITICALMESSAGE("Unsupported\n"); | ||
| 181 | + } | ||
| 182 | +} | ||
| 183 | + | ||
| 184 | int | ||
| 185 | mos_query_engines_count(struct mos_bufmgr *bufmgr, | ||
| 186 | unsigned int *nengine) | ||
| 187 | diff --git a/media_softlet/linux/common/os/i915_production/mos_bufmgr_priv.h b/media_softlet/linux/common/os/i915_production/mos_bufmgr_priv.h | ||
| 188 | index c3b765a4c..1d7f7edb0 100644 | ||
| 189 | --- a/media_softlet/linux/common/os/i915_production/mos_bufmgr_priv.h | ||
| 190 | +++ b/media_softlet/linux/common/os/i915_production/mos_bufmgr_priv.h | ||
| 191 | @@ -358,6 +358,7 @@ struct mos_bufmgr { | ||
| 192 | void (*disable_object_capture)(struct mos_bufmgr *bufmgr) = nullptr; | ||
| 193 | int (*get_memory_info)(struct mos_bufmgr *bufmgr, char *info, uint32_t length) = nullptr; | ||
| 194 | int (*get_devid)(struct mos_bufmgr *bufmgr) = nullptr; | ||
| 195 | + void (*realloc_cache)(struct mos_bufmgr *bufmgr, uint8_t alloc_mode) = nullptr; | ||
| 196 | int (*query_engines_count)(struct mos_bufmgr *bufmgr, | ||
| 197 | unsigned int *nengine) = nullptr; | ||
| 198 | |||
| 199 | diff --git a/media_softlet/linux/common/os/mos_context_specific_next.cpp b/media_softlet/linux/common/os/mos_context_specific_next.cpp | ||
| 200 | index 543e262d1..87059f538 100644 | ||
| 201 | --- a/media_softlet/linux/common/os/mos_context_specific_next.cpp | ||
| 202 | +++ b/media_softlet/linux/common/os/mos_context_specific_next.cpp | ||
| 203 | @@ -90,25 +90,7 @@ MOS_STATUS OsContextSpecificNext::Init(DDI_DEVICE_CONTEXT ddiDriverContext) | ||
| 204 | |||
| 205 | userSettingPtr = MosInterface::MosGetUserSettingInstance(osDriverContext); | ||
| 206 | |||
| 207 | - mode = BATCH_BUFFER_SIZE; | ||
| 208 | - ReadUserSetting( | ||
| 209 | - userSettingPtr, | ||
| 210 | - value, | ||
| 211 | - "INTEL MEDIA ALLOC MODE", | ||
| 212 | - MediaUserSetting::Group::Device); | ||
| 213 | - | ||
| 214 | - if (value) | ||
| 215 | - { | ||
| 216 | - mode |= (value & 0x000000ff); | ||
| 217 | - } | ||
| 218 | - value = 0; | ||
| 219 | - /* no need to set batch buffer size after switch to softpin | ||
| 220 | - * keep it, just for test during relocation to softpin transition | ||
| 221 | - * now , it could be a debug method , but is actually useless | ||
| 222 | - * so it is safe to reuse the lowest 8bit to convey addtional information | ||
| 223 | - * more suitable solution is deleting it , or add additional parameter*/ | ||
| 224 | - | ||
| 225 | - m_bufmgr = mos_bufmgr_gem_init(m_fd, (int)mode, &m_deviceType); | ||
| 226 | + m_bufmgr = mos_bufmgr_gem_init(m_fd, BATCH_BUFFER_SIZE, &m_deviceType); | ||
| 227 | if (nullptr == m_bufmgr) | ||
| 228 | { | ||
| 229 | MOS_OS_ASSERTMESSAGE("Not able to allocate buffer manager, fd=0x%d", m_fd); | ||
| 230 | @@ -151,6 +133,22 @@ MOS_STATUS OsContextSpecificNext::Init(DDI_DEVICE_CONTEXT ddiDriverContext) | ||
| 231 | return eStatus; | ||
| 232 | } | ||
| 233 | |||
| 234 | + if (m_platformInfo.eProductFamily == IGFX_METEORLAKE || | ||
| 235 | + m_platformInfo.eProductFamily == IGFX_ARROWLAKE) | ||
| 236 | + { | ||
| 237 | + ReadUserSetting( | ||
| 238 | + userSettingPtr, | ||
| 239 | + value, | ||
| 240 | + "INTEL MEDIA ALLOC MODE", | ||
| 241 | + MediaUserSetting::Group::Device); | ||
| 242 | + | ||
| 243 | + if (value) | ||
| 244 | + { | ||
| 245 | + mode = (value & 0x000000ff); | ||
| 246 | + } | ||
| 247 | + mos_bufmgr_realloc_cache(m_bufmgr, mode); | ||
| 248 | + } | ||
| 249 | + | ||
| 250 | ReadUserSetting( | ||
| 251 | userSettingPtr, | ||
| 252 | value, | ||
| 253 | -- | ||
| 254 | 2.40.1 | ||
| 255 | |||
| diff --git a/recipes-multimedia/libva/files/0009-Skip-cache-bucket-realloc-for-default-mode-0.patch b/recipes-multimedia/libva/files/0009-Skip-cache-bucket-realloc-for-default-mode-0.patch deleted file mode 100644 index 8ee7ef14..00000000 --- a/recipes-multimedia/libva/files/0009-Skip-cache-bucket-realloc-for-default-mode-0.patch +++ /dev/null | |||
| @@ -1,33 +0,0 @@ | |||
| 1 | From 18c32247cbc0e9fabff7a847add099496af9e53f Mon Sep 17 00:00:00 2001 | ||
| 2 | From: "Soon, Thean Siew" <thean.siew.soon@intel.com> | ||
| 3 | Date: Mon, 8 Jan 2024 18:12:30 +0000 | ||
| 4 | Subject: [PATCH 09/12] Skip cache bucket realloc for default mode 0 | ||
| 5 | |||
| 6 | Upstream-Status: Submitted [https://github.com/intel/media-driver/pull/1754] | ||
| 7 | |||
| 8 | Signed-off-by: Soon, Thean Siew <thean.siew.soon@intel.com> | ||
| 9 | --- | ||
| 10 | .../linux/common/os/mos_context_specific_next.cpp | 7 ++++++- | ||
| 11 | 1 file changed, 6 insertions(+), 1 deletion(-) | ||
| 12 | |||
| 13 | diff --git a/media_softlet/linux/common/os/mos_context_specific_next.cpp b/media_softlet/linux/common/os/mos_context_specific_next.cpp | ||
| 14 | index 87059f538..9dbd5da79 100644 | ||
| 15 | --- a/media_softlet/linux/common/os/mos_context_specific_next.cpp | ||
| 16 | +++ b/media_softlet/linux/common/os/mos_context_specific_next.cpp | ||
| 17 | @@ -146,7 +146,12 @@ MOS_STATUS OsContextSpecificNext::Init(DDI_DEVICE_CONTEXT ddiDriverContext) | ||
| 18 | { | ||
| 19 | mode = (value & 0x000000ff); | ||
| 20 | } | ||
| 21 | - mos_bufmgr_realloc_cache(m_bufmgr, mode); | ||
| 22 | + | ||
| 23 | + // Realloc cache only if it's not mode 0 | ||
| 24 | + if (mode) | ||
| 25 | + { | ||
| 26 | + mos_bufmgr_realloc_cache(m_bufmgr, mode); | ||
| 27 | + } | ||
| 28 | } | ||
| 29 | |||
| 30 | ReadUserSetting( | ||
| 31 | -- | ||
| 32 | 2.40.1 | ||
| 33 | |||
| diff --git a/recipes-multimedia/libva/files/0010-Fix-failed-4k-video-wall-test-case-and-color-corrupt.patch b/recipes-multimedia/libva/files/0010-Fix-failed-4k-video-wall-test-case-and-color-corrupt.patch deleted file mode 100644 index 0100df77..00000000 --- a/recipes-multimedia/libva/files/0010-Fix-failed-4k-video-wall-test-case-and-color-corrupt.patch +++ /dev/null | |||
| @@ -1,195 +0,0 @@ | |||
| 1 | From 7291ab5206c5e172c6c94dcfbe4f1bc258f3b7a5 Mon Sep 17 00:00:00 2001 | ||
| 2 | From: WenshengZhang <wensheng.zhang@intel.com> | ||
| 3 | Date: Wed, 10 Jan 2024 14:08:37 +0800 | ||
| 4 | Subject: [PATCH 10/12] Fix failed 4k video wall test case and color corruption | ||
| 5 | of video composition | ||
| 6 | |||
| 7 | Fix failed 4k video wall test case from 16CH video only show 1CH output and | ||
| 8 | corruption observed on certain number of video composition when doing | ||
| 9 | sample_multi_transcode. | ||
| 10 | |||
| 11 | Upstream-Status: Backport [https://github.com/intel/media-driver/commit/38e14b1b97170b51586d00d1fa607e496b0c5825] | ||
| 12 | Signed-off-by: Lim, Siew Hoon <siew.hoon.lim@intel.com> | ||
| 13 | --- | ||
| 14 | .../common/vp/kdll/hal_kerneldll_next.h | 1 + | ||
| 15 | .../vp/hal/packet/vp_render_fc_kernel.cpp | 7 ++ | ||
| 16 | .../common/vp/kdll/hal_kerneldll_next.c | 70 +++++++++++-------- | ||
| 17 | .../linux/common/vp/ddi/ddi_vp_functions.cpp | 20 ++---- | ||
| 18 | 4 files changed, 55 insertions(+), 43 deletions(-) | ||
| 19 | |||
| 20 | diff --git a/media_common/agnostic/common/vp/kdll/hal_kerneldll_next.h b/media_common/agnostic/common/vp/kdll/hal_kerneldll_next.h | ||
| 21 | index 6447999b7..8e2ab371e 100644 | ||
| 22 | --- a/media_common/agnostic/common/vp/kdll/hal_kerneldll_next.h | ||
| 23 | +++ b/media_common/agnostic/common/vp/kdll/hal_kerneldll_next.h | ||
| 24 | @@ -588,6 +588,7 @@ typedef struct tagKdll_FilterEntry | ||
| 25 | Kdll_Scalingratio ScalingRatio; | ||
| 26 | Kdll_RenderMethod RenderMethod; | ||
| 27 | Kdll_SetCSCCoeffMethod SetCSCCoeffMode; | ||
| 28 | + bool forceToTargetColorSpace; | ||
| 29 | } Kdll_FilterEntry, *PKdll_FilterEntry; | ||
| 30 | |||
| 31 | // Structure that defines a compositing filter | ||
| 32 | diff --git a/media_softlet/agnostic/common/vp/hal/packet/vp_render_fc_kernel.cpp b/media_softlet/agnostic/common/vp/hal/packet/vp_render_fc_kernel.cpp | ||
| 33 | index 8e982f67e..f8308fed1 100644 | ||
| 34 | --- a/media_softlet/agnostic/common/vp/hal/packet/vp_render_fc_kernel.cpp | ||
| 35 | +++ b/media_softlet/agnostic/common/vp/hal/packet/vp_render_fc_kernel.cpp | ||
| 36 | @@ -775,6 +775,13 @@ MOS_STATUS VpRenderFcKernel::BuildFilter( | ||
| 37 | |||
| 38 | for (i = 0; (i < (int)compParams->sourceCount) && (iMaxFilterSize > 0); i++) | ||
| 39 | { | ||
| 40 | + if (i > 0) | ||
| 41 | + { | ||
| 42 | + if (!RECT1_CONTAINS_RECT2(compParams->source[0].surf->rcDst, compParams->source[i].surf->rcDst)) | ||
| 43 | + { | ||
| 44 | + pFilter->forceToTargetColorSpace = true; | ||
| 45 | + } | ||
| 46 | + } | ||
| 47 | src = &compParams->source[i]; | ||
| 48 | |||
| 49 | //-------------------------------- | ||
| 50 | diff --git a/media_softlet/agnostic/common/vp/kdll/hal_kerneldll_next.c b/media_softlet/agnostic/common/vp/kdll/hal_kerneldll_next.c | ||
| 51 | index d8f7d429a..151f3b039 100644 | ||
| 52 | --- a/media_softlet/agnostic/common/vp/kdll/hal_kerneldll_next.c | ||
| 53 | +++ b/media_softlet/agnostic/common/vp/kdll/hal_kerneldll_next.c | ||
| 54 | @@ -2378,6 +2378,7 @@ bool KernelDll_SetupCSC( | ||
| 55 | Kdll_CSC_Matrix curr_matrix; | ||
| 56 | Kdll_CSC_Matrix *matrix = pCSC->Matrix; // Color Space conversion matrix | ||
| 57 | uint8_t * matrixID = pCSC->MatrixID; // CSC coefficient allocation table | ||
| 58 | + bool forceToTargetColorSpace = false; | ||
| 59 | |||
| 60 | // Clear all CSC matrices | ||
| 61 | MOS_ZeroMemory(matrix, sizeof(pCSC->Matrix)); | ||
| 62 | @@ -2395,6 +2396,10 @@ bool KernelDll_SetupCSC( | ||
| 63 | //---------------------------------------------------------------// | ||
| 64 | for (i = iFilterSize, pFilter = pSearchState->Filter; i > 0; i--, pFilter++) | ||
| 65 | { | ||
| 66 | + if (pFilter->forceToTargetColorSpace) | ||
| 67 | + { | ||
| 68 | + forceToTargetColorSpace = true; | ||
| 69 | + } | ||
| 70 | // Disable Procamp for all layers except Main Video | ||
| 71 | // Disable Procamp if source is RGB | ||
| 72 | if (pFilter->layer != Layer_MainVideo || | ||
| 73 | @@ -2456,44 +2461,51 @@ bool KernelDll_SetupCSC( | ||
| 74 | //---------------------------------------------------------------// | ||
| 75 | if (sel_cspace == CSpace_Any) | ||
| 76 | { | ||
| 77 | - int cs; | ||
| 78 | - for (cs = (CSpace_Any + 1); cs < CSpace_Count; cs++) | ||
| 79 | + if (forceToTargetColorSpace) | ||
| 80 | { | ||
| 81 | - // Skip color spaces not in use | ||
| 82 | - cspace = (VPHAL_CSPACE)cs; | ||
| 83 | - if (!cspace_in_use[cspace]) | ||
| 84 | - { | ||
| 85 | - continue; | ||
| 86 | - } | ||
| 87 | - | ||
| 88 | - // xvYCC and BT are treated as same for CSC considerations (BT.x to xvYCC.x matrix is I) | ||
| 89 | - cspace = KernelDll_TranslateCspace(cspace); | ||
| 90 | - | ||
| 91 | - // Count # of CS conversions and matrices | ||
| 92 | - csc_count = 0; | ||
| 93 | - for (i = iFilterSize, pFilter = pSearchState->Filter; i > 0; i--, pFilter++) | ||
| 94 | + sel_cspace = out_cspace; | ||
| 95 | + } | ||
| 96 | + else | ||
| 97 | + { | ||
| 98 | + int cs; | ||
| 99 | + for (cs = (CSpace_Any + 1); cs < CSpace_Count; cs++) | ||
| 100 | { | ||
| 101 | - // Ignore layers where the Color Space may be set in software (colorfill, palletized) | ||
| 102 | - if (pFilter->cspace == CSpace_Any) | ||
| 103 | + // Skip color spaces not in use | ||
| 104 | + cspace = (VPHAL_CSPACE)cs; | ||
| 105 | + if (!cspace_in_use[cspace]) | ||
| 106 | { | ||
| 107 | continue; | ||
| 108 | } | ||
| 109 | |||
| 110 | - // Check if CSC/PA is required | ||
| 111 | - if (KernelDll_TranslateCspace(pFilter->cspace) != cspace || | ||
| 112 | - pFilter->procamp != DL_PROCAMP_DISABLED) | ||
| 113 | + // xvYCC and BT are treated as same for CSC considerations (BT.x to xvYCC.x matrix is I) | ||
| 114 | + cspace = KernelDll_TranslateCspace(cspace); | ||
| 115 | + | ||
| 116 | + // Count # of CS conversions and matrices | ||
| 117 | + csc_count = 0; | ||
| 118 | + for (i = iFilterSize, pFilter = pSearchState->Filter; i > 0; i--, pFilter++) | ||
| 119 | { | ||
| 120 | - csc_count++; | ||
| 121 | + // Ignore layers where the Color Space may be set in software (colorfill, palletized) | ||
| 122 | + if (pFilter->cspace == CSpace_Any) | ||
| 123 | + { | ||
| 124 | + continue; | ||
| 125 | + } | ||
| 126 | + | ||
| 127 | + // Check if CSC/PA is required | ||
| 128 | + if (KernelDll_TranslateCspace(pFilter->cspace) != cspace || | ||
| 129 | + pFilter->procamp != DL_PROCAMP_DISABLED) | ||
| 130 | + { | ||
| 131 | + csc_count++; | ||
| 132 | + } | ||
| 133 | } | ||
| 134 | - } | ||
| 135 | |||
| 136 | - // Save best choice as requiring minimum number of CSC operations | ||
| 137 | - if ((sel_csc_count < 0) || // Initial value | ||
| 138 | - (csc_count < sel_csc_count) || // Minimum number of CSC operations | ||
| 139 | - (csc_count == sel_csc_count && cs == main_cspace)) // Use main cspace as default if same CSC count | ||
| 140 | - { | ||
| 141 | - sel_cspace = cspace; | ||
| 142 | - sel_csc_count = csc_count; | ||
| 143 | + // Save best choice as requiring minimum number of CSC operations | ||
| 144 | + if ((sel_csc_count < 0) || // Initial value | ||
| 145 | + (csc_count < sel_csc_count) || // Minimum number of CSC operations | ||
| 146 | + (csc_count == sel_csc_count && cs == main_cspace)) // Use main cspace as default if same CSC count | ||
| 147 | + { | ||
| 148 | + sel_cspace = cspace; | ||
| 149 | + sel_csc_count = csc_count; | ||
| 150 | + } | ||
| 151 | } | ||
| 152 | } | ||
| 153 | } | ||
| 154 | diff --git a/media_softlet/linux/common/vp/ddi/ddi_vp_functions.cpp b/media_softlet/linux/common/vp/ddi/ddi_vp_functions.cpp | ||
| 155 | index 40d0b3fad..e60a6c69c 100644 | ||
| 156 | --- a/media_softlet/linux/common/vp/ddi/ddi_vp_functions.cpp | ||
| 157 | +++ b/media_softlet/linux/common/vp/ddi/ddi_vp_functions.cpp | ||
| 158 | @@ -2115,9 +2115,8 @@ VAStatus DdiVpFunctions::SetBackgroundColorfill( | ||
| 159 | { | ||
| 160 | DDI_VP_FUNC_ENTER; | ||
| 161 | DDI_VP_CHK_NULL(vpHalRenderParams, "nullptr vpHalRenderParams.", VA_STATUS_ERROR_INVALID_PARAMETER); | ||
| 162 | - DDI_VP_CHK_NULL(vpHalRenderParams->pTarget[0],"nullptr pTarget[0].", VA_STATUS_ERROR_INVALID_PARAMETER); | ||
| 163 | |||
| 164 | - if ((outBackGroundcolor >> 24) != 0 || vpHalRenderParams->pTarget[0]->ColorSpace == CSpace_sRGB) | ||
| 165 | + if ((outBackGroundcolor >> 24) != 0) | ||
| 166 | { | ||
| 167 | if (vpHalRenderParams->pColorFillParams == nullptr) | ||
| 168 | { | ||
| 169 | @@ -2126,18 +2125,11 @@ VAStatus DdiVpFunctions::SetBackgroundColorfill( | ||
| 170 | |||
| 171 | DDI_VP_CHK_NULL(vpHalRenderParams->pColorFillParams, "nullptr pColorFillParams.", VA_STATUS_ERROR_UNKNOWN); | ||
| 172 | |||
| 173 | - if (vpHalRenderParams->pTarget[0]->ColorSpace == CSpace_sRGB && (outBackGroundcolor >> 24) == 0) | ||
| 174 | - { | ||
| 175 | - // set color space for sRGB output | ||
| 176 | - vpHalRenderParams->pColorFillParams->CSpace = CSpace_sRGB; | ||
| 177 | - } | ||
| 178 | - else | ||
| 179 | - { | ||
| 180 | - // set background colorfill option | ||
| 181 | - vpHalRenderParams->pColorFillParams->Color = outBackGroundcolor; | ||
| 182 | - vpHalRenderParams->pColorFillParams->bYCbCr = false; | ||
| 183 | - vpHalRenderParams->pColorFillParams->CSpace = CSpace_sRGB; | ||
| 184 | - } | ||
| 185 | + // set background colorfill option | ||
| 186 | + vpHalRenderParams->pColorFillParams->Color = outBackGroundcolor; | ||
| 187 | + vpHalRenderParams->pColorFillParams->bYCbCr = false; | ||
| 188 | + vpHalRenderParams->pColorFillParams->CSpace = CSpace_sRGB; | ||
| 189 | + | ||
| 190 | } | ||
| 191 | else | ||
| 192 | { | ||
| 193 | -- | ||
| 194 | 2.40.1 | ||
| 195 | |||
| diff --git a/recipes-multimedia/libva/files/0011-Disable-422H-format-output.patch b/recipes-multimedia/libva/files/0011-Disable-422H-format-output.patch deleted file mode 100644 index 2f4aec1e..00000000 --- a/recipes-multimedia/libva/files/0011-Disable-422H-format-output.patch +++ /dev/null | |||
| @@ -1,33 +0,0 @@ | |||
| 1 | From f8b4d982232d4c1330e1e5f5dcd7cd8ca94decba Mon Sep 17 00:00:00 2001 | ||
| 2 | From: WenshengZhang <wensheng.zhang@intel.com> | ||
| 3 | Date: Thu, 25 Jan 2024 16:35:10 +0800 | ||
| 4 | Subject: [PATCH 11/12] Disable 422H format output | ||
| 5 | |||
| 6 | Disable 422H format output. | ||
| 7 | |||
| 8 | Upstream-Status: Backport [https://github.com/intel/media-driver/commit/eab411768e61a46e096793291f5f992eecf76cd8] | ||
| 9 | Signed-off-by: Lim, Siew Hoon <siew.hoon.lim@intel.com> | ||
| 10 | --- | ||
| 11 | .../agnostic/common/vp/hal/feature_manager/policy.cpp | 6 ++++++ | ||
| 12 | 1 file changed, 6 insertions(+) | ||
| 13 | |||
| 14 | diff --git a/media_softlet/agnostic/common/vp/hal/feature_manager/policy.cpp b/media_softlet/agnostic/common/vp/hal/feature_manager/policy.cpp | ||
| 15 | index 317cec25a..12f1124fa 100644 | ||
| 16 | --- a/media_softlet/agnostic/common/vp/hal/feature_manager/policy.cpp | ||
| 17 | +++ b/media_softlet/agnostic/common/vp/hal/feature_manager/policy.cpp | ||
| 18 | @@ -1140,6 +1140,12 @@ MOS_STATUS Policy::GetScalingExecutionCaps(SwFilter *feature, bool isHdrEnabled) | ||
| 19 | bool isAlphaSettingSupportedByVebox = | ||
| 20 | IsAlphaSettingSupportedByVebox(scalingParams->formatInput, scalingParams->formatOutput, scalingParams->pCompAlpha); | ||
| 21 | |||
| 22 | + if (scalingParams->formatOutput == Format_422H) | ||
| 23 | + { | ||
| 24 | + VP_PUBLIC_ASSERTMESSAGE("Scaling not support 422H format output."); | ||
| 25 | + return MOS_STATUS_UNIMPLEMENTED; | ||
| 26 | + } | ||
| 27 | + | ||
| 28 | // Clean usedForNextPass flag. | ||
| 29 | if (scalingEngine->usedForNextPass) | ||
| 30 | { | ||
| 31 | -- | ||
| 32 | 2.40.1 | ||
| 33 | |||
| diff --git a/recipes-multimedia/libva/files/0012-Decode-Fix-AVC-decode-SFC-4K-hang-issue.patch b/recipes-multimedia/libva/files/0012-Decode-Fix-AVC-decode-SFC-4K-hang-issue.patch deleted file mode 100644 index 1be9139d..00000000 --- a/recipes-multimedia/libva/files/0012-Decode-Fix-AVC-decode-SFC-4K-hang-issue.patch +++ /dev/null | |||
| @@ -1,32 +0,0 @@ | |||
| 1 | From b93904533d3ee66c7919fa8e23d26b852a37a917 Mon Sep 17 00:00:00 2001 | ||
| 2 | From: Lim Siew Hoon <siew.hoon.lim@intel.com> | ||
| 3 | Date: Tue, 30 Jan 2024 13:27:52 +0800 | ||
| 4 | Subject: [PATCH 12/12] [Decode] Fix AVC decode SFC 4K hang issue | ||
| 5 | |||
| 6 | Updated VDSFC input width and height for AVC decode | ||
| 7 | |||
| 8 | Upstream-Status: Submitted [https://github.com/intel-innersource/drivers.gpu.unified/pull/151401] | ||
| 9 | |||
| 10 | Signed-off-by: Lim Siew Hoon <siew.hoon.lim@intel.com> | ||
| 11 | --- | ||
| 12 | .../hal/dec/avc/packet/decode_avc_downsampling_packet.cpp | 4 ++++ | ||
| 13 | 1 file changed, 4 insertions(+) | ||
| 14 | |||
| 15 | diff --git a/media_softlet/agnostic/common/codec/hal/dec/avc/packet/decode_avc_downsampling_packet.cpp b/media_softlet/agnostic/common/codec/hal/dec/avc/packet/decode_avc_downsampling_packet.cpp | ||
| 16 | index e75fd8137..9cc236bd7 100644 | ||
| 17 | --- a/media_softlet/agnostic/common/codec/hal/dec/avc/packet/decode_avc_downsampling_packet.cpp | ||
| 18 | +++ b/media_softlet/agnostic/common/codec/hal/dec/avc/packet/decode_avc_downsampling_packet.cpp | ||
| 19 | @@ -59,6 +59,10 @@ MOS_STATUS AvcDownSamplingPkt::InitSfcParams(VDBOX_SFC_PARAMS &sfcParams) | ||
| 20 | |||
| 21 | AvcBasicFeature *avcBasicFeature = dynamic_cast<AvcBasicFeature*>(m_basicFeature); | ||
| 22 | DECODE_CHK_NULL(avcBasicFeature); | ||
| 23 | + | ||
| 24 | + sfcParams.input.width = avcBasicFeature->m_width; | ||
| 25 | + sfcParams.input.height = avcBasicFeature->m_height; | ||
| 26 | + | ||
| 27 | CODEC_PICTURE curPic = avcBasicFeature->m_avcPicParams->CurrPic; | ||
| 28 | |||
| 29 | if (avcBasicFeature->m_avcPicParams->seq_fields.mb_adaptive_frame_field_flag == true) | ||
| 30 | -- | ||
| 31 | 2.40.1 | ||
| 32 | |||
