OSDN Git Service

android-x86/hardware-intel-common-vaapi.git
8 years agoFix if issue of SLICE_TYPE_I statement in vme_pipeline_programing
Lim Siew Hoon [Wed, 9 Sep 2015 02:10:58 +0000 (10:10 +0800)]
Fix if issue of SLICE_TYPE_I statement in vme_pipeline_programing

Signed-off-by: Lim Siew Hoon <siew.hoon.lim@intel.com>
Reviewed-by: Zhao, Yakui <yakui.zhao@intel.com>
8 years agoReplace --enable-wrapper with --enable-hybrid-codec
Xiang, Haihao [Wed, 9 Sep 2015 04:19:21 +0000 (12:19 +0800)]
Replace --enable-wrapper with --enable-hybrid-codec

hybrid-codec is more meaningful.

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
Reviewed-by: Zhao Yakui <yakui.zhao@intel.com>
8 years agoRemove file access check in loading wrapper
Sameer Kibey [Sun, 6 Sep 2015 01:39:16 +0000 (09:39 +0800)]
Remove file access check in loading wrapper

Remove the check for file access in the wrapper.
Otherwise this call will fail on Chrome OS with sandboxing
enabled.

Signed-off-by: Sameer Kibey <sameer.kibey@intel.com>
Signed-off-by: Sean V Kelley <seanvk@posteo.de>
8 years agoExport the profile/entrypoints for the wrapped backend drivers
Zhao Yakui [Sun, 6 Sep 2015 01:39:15 +0000 (09:39 +0800)]
Export the profile/entrypoints for the wrapped backend drivers

Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
Signed-off-by: Sean V Kelley <seanvk@posteo.de>
8 years agoCall the wrapped backend driver for the given decoding
Zhao Yakui [Sun, 6 Sep 2015 01:39:14 +0000 (09:39 +0800)]
Call the wrapped backend driver for the given decoding

The wrapped vaBeginPicture/vaRenderPicture/vaEndPicture are called.
Currently the wrapper is for the VP9 decoding.

Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
Signed-off-by: Sean V Kelley <seanvk@posteo.de>
8 years agoAdd the support of wrapper the VA Buffer to the backend driver
Zhao Yakui [Sun, 6 Sep 2015 01:39:13 +0000 (09:39 +0800)]
Add the support of wrapper the VA Buffer to the backend driver

The obj_context is passed when calling vaCreateBuffer, which can be
used to check whether it belongs to the wrapped context. If one VA buffer
belongs to wrapped buffer, the callback function of backend driver will
be called for the corresponding VA buffer.

Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
Signed-off-by: Sean V Kelley <seanvk@posteo.de>
8 years agoAdd one function to wrapper VA surface into backend driver
Zhao Yakui [Sun, 6 Sep 2015 01:39:12 +0000 (09:39 +0800)]
Add one function to wrapper VA surface into backend driver

Currently only NV12 surface is supported as the decoding uses the NV12 format.

Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
Signed-off-by: Sameer Kibey <sameer.kibey@intel.com>
Signed-off-by: Sean V Kelley <seanvk@posteo.de>
8 years agoCall the wrapped function to free wrapped surface/buffer
Zhao Yakui [Sun, 6 Sep 2015 01:39:11 +0000 (09:39 +0800)]
Call the wrapped function to free wrapped surface/buffer

Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
Signed-off-by: Sean V Kelley <seanvk@posteo.de>
8 years agoCall wrapped driver to handle config/context related with VP9 decoding
Zhao Yakui [Sun, 6 Sep 2015 01:39:10 +0000 (09:39 +0800)]
Call wrapped driver to handle config/context related with VP9 decoding

Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
Signed-off-by: Sean V Kelley <seanvk@posteo.de>
8 years agoWrapper the DriverContextP of backend driver
Zhao Yakui [Sun, 6 Sep 2015 01:39:09 +0000 (09:39 +0800)]
Wrapper the DriverContextP of backend driver

The default directory of backend driver is used.(LIBVA_DRIVERS_PATH).
Only when the backend driver exists, the wrapper is initialized and added.
Otherwise it won't be initialized.

And the option of "enable-wrapper" is added, which is used to determine whether
the wrapper of backend driver is supported.

Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
Signed-off-by: Sean V Kelley <seanvk@posteo.de>
8 years agoAdd one field for Config/Context/Surface/Buffer to store the wrapper content
Zhao Yakui [Sun, 6 Sep 2015 01:39:08 +0000 (09:39 +0800)]
Add one field for Config/Context/Surface/Buffer to store the wrapper content

This is to do the preparation that the libva-intel-driver can be the user of
other backend driver.

Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
Signed-off-by: Sean V Kelley <seanvk@posteo.de>
8 years agoClean up unused local variable 'i965'
Lim Siew Hoon [Wed, 26 Aug 2015 11:43:34 +0000 (19:43 +0800)]
Clean up unused local variable 'i965'

Signed-off-by: Lim Siew Hoon <siew.hoon.lim@intel.com>
8 years agoClean up the duplicate extra two line of code
Lim Siew Hoon [Wed, 26 Aug 2015 09:20:34 +0000 (17:20 +0800)]
Clean up the duplicate extra two line of code

Signed-off-by: Lim Siew Hoon <siew.hoon.lim@intel.com>
8 years agoFix if statement checking sampling factor for YUV422V_4Y
Lim Siew Hoon [Wed, 26 Aug 2015 08:27:59 +0000 (16:27 +0800)]
Fix if statement checking sampling factor for YUV422V_4Y

Signed-off-by: Lim Siew Hoon <siew.hoon.lim@intel.com>
8 years agoFix suspiciously placed semicolon at if statement.
Lim Siew Hoon [Wed, 26 Aug 2015 04:31:21 +0000 (12:31 +0800)]
Fix suspiciously placed semicolon at if statement.

Signed-off-by: Lim Siew Hoon <siew.hoon.lim@intel.com>
8 years agoFix memset initialize for huff_co_table and huff_si_table array
Lim Siew Hoon [Wed, 26 Aug 2015 03:13:44 +0000 (11:13 +0800)]
Fix memset initialize for huff_co_table and huff_si_table array

Signed-off-by: Lim Siew Hoon <siew.hoon.lim@intel.com>
8 years agoFix memset initialize value for huff_size_table and huff_code_table
Lim Siew Hoon [Wed, 26 Aug 2015 02:55:18 +0000 (10:55 +0800)]
Fix memset initialize value for huff_size_table and huff_code_table

Signed-off-by: Lim Siew Hoon <siew.hoon.lim@intel.com>
8 years agoFix klockwork critical message hit on calloc function usage
Lim Siew Hoon [Thu, 20 Aug 2015 10:29:09 +0000 (18:29 +0800)]
Fix klockwork critical message hit on calloc function usage

The calloc function maybe return NULL, it will causing
memory access violation if continue using NULL C structure.
Add assert function to do checking on its.

bugzilla:
https://bugs.freedesktop.org/show_bug.cgi?id=91699

Signed-off-by: Lim Siew Hoon <siew.hoon.lim@intel.com>
8 years agoencode/hevc: Check slice type first in case user passes wrong parameters to driver
Xiang, Haihao [Mon, 3 Aug 2015 06:32:48 +0000 (14:32 +0800)]
encode/hevc: Check slice type first in case user passes wrong parameters to driver

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
8 years agoencode/hevc: Check the correct BO before unreferencing it
Xiang, Haihao [Mon, 3 Aug 2015 06:32:34 +0000 (14:32 +0800)]
encode/hevc: Check the correct BO before unreferencing it

v2: Change the log message per Emil's suggestion

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
8 years agoAdded LIBVA_DRIVERS_PATH configure argument
Joel Holdsworth [Wed, 26 Aug 2015 23:21:12 +0000 (00:21 +0100)]
Added LIBVA_DRIVERS_PATH configure argument

9 years agoDecoding: Export the attribute of slice mode for decoding
Zhao Yakui [Tue, 25 Aug 2015 05:35:21 +0000 (13:35 +0800)]
Decoding: Export the attribute of slice mode for decoding

Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
Reviewed-by: Xiang Haihao <haihao.xiang@intel.com>
9 years agoRemove the redundant check in vaBeginPicture call
Zhao Yakui [Tue, 25 Aug 2015 05:35:16 +0000 (13:35 +0800)]
Remove the redundant check in vaBeginPicture call

The corresponding check is already executed when calling vaCreateConfig.
So the redundant check is removed.

Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
Reviewed-by: Xiang Haihao <haihao.xiang@intel.com>
9 years agoAdd one field to store the expected VA_RT_FORMAT for surface
Zhao Yakui [Tue, 25 Aug 2015 05:35:08 +0000 (13:35 +0800)]
Add one field to store the expected VA_RT_FORMAT for surface

The VA_RT_FORMAT_XXX is also used to derive the corresponding layout of
VA SURFACE.For example: VA_RT_FORMAT_YUV420/422, RGB32 and so on.

Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
Reviewed-by: Xiang Haihao <haihao.xiang@intel.com>
9 years agoVPP: Initialize the uninitialed surface to avoid NULL GPU buffer
Zhao Yakui [Fri, 14 Aug 2015 04:13:13 +0000 (12:13 +0800)]
VPP: Initialize the uninitialed surface to avoid NULL GPU buffer

Sometimes the surface allocation is deferred. In such case it should be
checked correctly before it is using. Otherwise the corresponding
GPU buffer is NULL.
This is to fix the regression issue reported by XBMC.

Tested-by: Zaverel <zaverel@free.fr>
Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
9 years agoVPP: Flush batch buffer to assure that previous GPU operation is submitted
Zhao Yakui [Fri, 14 Aug 2015 04:13:08 +0000 (12:13 +0800)]
VPP: Flush batch buffer to assure that previous GPU operation is submitted

Tested-by: Zaverel <zaverel@free.fr>
Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
9 years agoencode/hevc: fix HEVC encode on SKL GT3
Xiang, Haihao [Thu, 23 Jul 2015 02:05:37 +0000 (10:05 +0800)]
encode/hevc: fix HEVC encode on SKL GT3

GT3 has 2 BSD rings, but HEVC commands can be only dispatched to BSD ring 0.

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
Reviewed-by: Zhao Yakui <yakui.zhao@intel.com>
9 years agoVPP: Combine the CSC/Scaling together to optimize the performance
Zhao Yakui [Wed, 15 Jul 2015 21:16:41 +0000 (17:16 -0400)]
VPP: Combine the CSC/Scaling together to optimize the performance

Currently it is divided into two steps when the video format is invovled.
In such case it is not efficient.

V1->V2: Follow Haihao's comment to call back the missing operation of
handle background color

Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
9 years agoCreateSurfaces2: forward function return to caller
Xu Guangxin [Wed, 1 Jul 2015 01:49:11 +0000 (09:49 +0800)]
CreateSurfaces2: forward function return to caller

we did not check following function's return:
i965_surface_native_memory
i965_suface_external_memory
i965_check_alloc_surface_bo
It will be in trouble if underlay buffer allocation is failed.

9 years ago1.6.1.pre1 for development
Xiang, Haihao [Wed, 8 Jul 2015 01:33:22 +0000 (09:33 +0800)]
1.6.1.pre1 for development

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
9 years agoMerge branch 'v1.6-branch' into master
Xiang, Haihao [Wed, 8 Jul 2015 00:31:04 +0000 (08:31 +0800)]
Merge branch 'v1.6-branch' into master

9 years agovpp/avs: fix license terms (MIT).
Gwenole Beauchesne [Tue, 7 Jul 2015 08:04:37 +0000 (10:04 +0200)]
vpp/avs: fix license terms (MIT).

Signed-off-by: Gwenole Beauchesne <gwenole.beauchesne@intel.com>
9 years agoH264: Use macroblock pair to calculate H264 decoding parameter under MBAFF flag
Zhao Yakui [Mon, 6 Jul 2015 17:45:47 +0000 (01:45 +0800)]
H264: Use macroblock pair to calculate H264 decoding parameter under MBAFF flag

Based on the H264 spec the macroblock pair should be used to calculate
the corresponding parameters under MBAFF.(mb-adaptive frame-field).
Otherwise the wrong parameter is sent to GPU HW.

Fix the GPU hang issue in https://bugs.freedesktop.org/show_bug.cgi?id=91207

Tested-by: Lim, Siew Hoon <siew.hoon.lim@intel.com>
Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
9 years agolibva-intel-driver 1.6.0
Xiang, Haihao [Wed, 1 Jul 2015 08:26:03 +0000 (16:26 +0800)]
libva-intel-driver 1.6.0

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
9 years agodec/hevc: Use a different equation for metadata tile column buffer on BSW
Xiang, Haihao [Mon, 29 Jun 2015 05:05:51 +0000 (13:05 +0800)]
dec/hevc: Use a different equation for metadata tile column buffer on BSW

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
Reviewed-by: Zhao Yakui <yakui.zhao@intel.com>
9 years agodec/hevc: Use the same equation for each metadata buffer no matter slice type
Xiang, Haihao [Mon, 29 Jun 2015 05:00:57 +0000 (13:00 +0800)]
dec/hevc: Use the same equation for each metadata buffer no matter slice type

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
Reviewed-by: Zhao Yakui <yakui.zhao@intel.com>
9 years agoGen75_vpp: Don't assert on BGRA input and output
fritsch [Wed, 24 Jun 2015 08:18:11 +0000 (10:18 +0200)]
Gen75_vpp: Don't assert on BGRA input and output

9 years agoversion 1.6.0.pre2
Xiang, Haihao [Wed, 24 Jun 2015 05:37:04 +0000 (13:37 +0800)]
version 1.6.0.pre2

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
9 years agoFIX:HEVC enc cause GPU hang when lcu_size=32 with 720x480 and 176x144
Qu,Pengfei [Thu, 18 Jun 2015 01:42:51 +0000 (09:42 +0800)]
FIX:HEVC enc cause GPU hang when lcu_size=32 with 720x480 and 176x144

Signed-off-by: Qu,Pengfei <Pengfei.Qu@intel.com>
(cherry picked from commit 0f6143e2e4bd70217887e1ad86a76200ad8b38a8)

9 years agoVP8 HWEnc: Modify qp threshold value for mode cost calculatation
Zhong Li [Mon, 8 Jun 2015 04:42:21 +0000 (12:42 +0800)]
VP8 HWEnc: Modify qp threshold value for mode cost calculatation

The patch is helpful to improve quality when qp is lower than the
threshold value.

Signed-off-by: Zhong Li <zhong.li@intel.com>
(cherry picked from commit e797089446c1f5b71b239b9046d76e054dfcba59)

9 years agoVPP: Configure SURFACE_STATE based on HW requirement to fix out-of-bound access issue
Zhao Yakui [Tue, 23 Jun 2015 01:38:32 +0000 (09:38 +0800)]
VPP: Configure SURFACE_STATE based on HW requirement to fix out-of-bound access issue

Otherwise some pixles will be regarded as out-of-bound and the
access will be dropped.

Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
Acked-by: Xiang haihao <haihao.xiang@intel.com>
(cherry picked from commit d5cd551887c8f4e5408327aba993e9927dd7d297)

9 years agoBDW/CHV/SKL: Follow the HW alignment requirement to access GPU buffer correctly
Zhao Yakui [Tue, 23 Jun 2015 01:38:25 +0000 (09:38 +0800)]
BDW/CHV/SKL: Follow the HW alignment requirement to access GPU buffer correctly

Otherwise the buffer access is incorrect.

Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
Acked-by: Xiang haihao <haihao.xiang@intel.com>
(cherry picked from commit fbab204929326567c876a48c0552430dd67a9852)

9 years agoVPP: Configure SURFACE_STATE based on HW requirement to fix out-of-bound access issue
Zhao Yakui [Tue, 23 Jun 2015 01:38:32 +0000 (09:38 +0800)]
VPP: Configure SURFACE_STATE based on HW requirement to fix out-of-bound access issue

Otherwise some pixles will be regarded as out-of-bound and the
access will be dropped.

Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
Acked-by: Xiang haihao <haihao.xiang@intel.com>
9 years agoBDW/CHV/SKL: Follow the HW alignment requirement to access GPU buffer correctly
Zhao Yakui [Tue, 23 Jun 2015 01:38:25 +0000 (09:38 +0800)]
BDW/CHV/SKL: Follow the HW alignment requirement to access GPU buffer correctly

Otherwise the buffer access is incorrect.

Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
Acked-by: Xiang haihao <haihao.xiang@intel.com>
9 years agoFIX:HEVC enc cause GPU hang when lcu_size=32 with 720x480 and 176x144
Qu,Pengfei [Thu, 18 Jun 2015 01:42:51 +0000 (09:42 +0800)]
FIX:HEVC enc cause GPU hang when lcu_size=32 with 720x480 and 176x144

Signed-off-by: Qu,Pengfei <Pengfei.Qu@intel.com>
9 years agoVP8 HWEnc: Modify qp threshold value for mode cost calculatation
Zhong Li [Mon, 8 Jun 2015 04:42:21 +0000 (12:42 +0800)]
VP8 HWEnc: Modify qp threshold value for mode cost calculatation

The patch is helpful to improve quality when qp is lower than the
threshold value.

Signed-off-by: Zhong Li <zhong.li@intel.com>
9 years agoUpdate NEWS
Xiang, Haihao [Thu, 4 Jun 2015 01:41:02 +0000 (09:41 +0800)]
Update NEWS

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
9 years agoUpdate the dependency on VA API
Xiang, Haihao [Thu, 4 Jun 2015 02:05:36 +0000 (10:05 +0800)]
Update the dependency on VA API

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
9 years agoAdd vp8_inter_frame_gen8.asm and vp8_intra_frame_gen8.asm to the core file list
Xiang, Haihao [Thu, 4 Jun 2015 05:54:18 +0000 (13:54 +0800)]
Add vp8_inter_frame_gen8.asm and vp8_intra_frame_gen8.asm to the core file list

Otherwise the packakge created by 'make dist' isn't buildable.

Remove vp8_inter_frame_gen9.asm and vp8_intra_frame_gen9.asm as they are the same
of vp8_inter_frame_gen8.asm and vp8_intra_frame_gen8.asm.

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
9 years agoAdd Android.mk to the corresponding EXTRA_DIST
Xiang, Haihao [Thu, 4 Jun 2015 02:17:48 +0000 (10:17 +0800)]
Add Android.mk to the corresponding EXTRA_DIST

'make dist' can include all Android.mk files in the release package

Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=90541
Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
9 years agoFix 'make dist'
Xiang, Haihao [Fri, 20 Mar 2015 04:01:07 +0000 (12:01 +0800)]
Fix 'make dist'

Otherwise the tar package created by 'make dist' is not buildable

(cherry picked from commit 2d0ce24c66c14c3f77bef54bdc4605241e0527bd)

9 years agoUpdate NEWS
Xiang, Haihao [Mon, 16 Mar 2015 07:12:44 +0000 (15:12 +0800)]
Update NEWS

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
(cherry picked from commit 3c66aa58ccb0fcb393472eeaa6a9188216683a79)

9 years agodec/vp8: fix segmentation update
Xiang, Haihao [Wed, 3 Jun 2015 01:42:03 +0000 (09:42 +0800)]
dec/vp8: fix segmentation update

Segment-based adjustments only occur if segmentation is enabled ($9.3).

Cc: Zhao Yakui <yakui.zhao@intel.com>
Tested-by: Charles, Daniel <daniel.charles@intel.com>
Acked-by: Zhao, Yakui <yakui.zhao@intel.com>
Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
Signed-off-by: Sean V Kelley <seanvk@posteo.de>
9 years agoHEVC/enc: Fix Multi Slice Encoding.
Sreerenj Balachandran [Wed, 27 May 2015 09:35:35 +0000 (12:35 +0300)]
HEVC/enc: Fix Multi Slice Encoding.

Fix the calculation of horizontal and vertical CTU position for next slice.

Signed-off-by: Sreerenj Balachandran <sreerenj.balachandran@intel.com>
9 years agoHEVC: encoder_utils: Fixes for packed slice header generation.
Sreerenj Balachandran [Fri, 22 May 2015 01:46:05 +0000 (04:46 +0300)]
HEVC: encoder_utils: Fixes for packed slice header generation.

-- Write no_output_of_prior_pics_flag to bitstream header for IRAP pictures
-- The slice_temporal_mvp_enabled_flag should only presnt in non-IDR frames.
-- Write collocated_from_l0_flag to bitstream header for B slice.
-- The max_num_merge_cand should be 5 - MaxNumMergeCand

Signed-off-by: Sreerenj Balachandran <sreerenj.balachandran@intel.com>
Reviewed-by: Zhao Yakui <yakui.zhao@intel.com>
9 years agoHEVC: Fix the nal unit type generation in packed slice header.
Sreerenj Balachandran [Fri, 22 May 2015 01:46:04 +0000 (04:46 +0300)]
HEVC: Fix the nal unit type generation in packed slice header.

Generate the Nal unit type for packed slice headers based
on idr_pic_flag and reference_pic_flag.

Signed-off-by: Sreerenj Balachandran <sreerenj.balachandran@intel.com>
Reviewed-by: Zhao Yakui <yakui.zhao@intel.com>
9 years agoHEVC: Fix the Wrong slice type usage
Sreerenj Balachandran [Fri, 22 May 2015 01:46:03 +0000 (04:46 +0300)]
HEVC: Fix the Wrong slice type usage

Don't mix the slice_type values of h264 and h265.

The SLICE_TYPE values of H264 and HEVC are different.
H264: Bslice_type = 1, Pslice_type = 0
HEVC: Bslice_type = 0, Pslice_type = 1

Signed-off-by: Sreerenj Balachandran <sreerenj.balachandran@intel.com>
Reviewed-by: Zhao Yakui <yakui.zhao@intel.com>
9 years agoVPP: Enable field rate madi/mcdi. Only second hunk is tested
Andy Furniss [Thu, 26 Mar 2015 14:34:48 +0000 (14:34 +0000)]
VPP: Enable field rate madi/mcdi. Only second hunk is tested

Signed-off-by: Andy Furniss <adf.lists@gmail.com>
9 years agoVPP: Make sure the store buffer is allocated
Xiang, Haihao [Mon, 23 Mar 2015 01:41:52 +0000 (09:41 +0800)]
VPP: Make sure the store buffer is allocated

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
9 years agoVPP: Adjust the parameter settings to DI on GEN6/GEN7
Xiang, Haihao [Thu, 19 Mar 2015 06:02:57 +0000 (07:02 +0100)]
VPP: Adjust the parameter settings to DI on GEN6/GEN7

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
9 years agovpp: add support for Motion-Compensated deinterlacing on Ivybridge.
Gwenole Beauchesne [Thu, 19 Mar 2015 06:02:56 +0000 (07:02 +0100)]
vpp: add support for Motion-Compensated deinterlacing on Ivybridge.

Signed-off-by: Gwenole Beauchesne <gwenole.beauchesne@intel.com>
9 years agovpp: fix advanced deinterlacing on Sandybridge and Ivybridge.
Gwenole Beauchesne [Thu, 19 Mar 2015 06:02:55 +0000 (07:02 +0100)]
vpp: fix advanced deinterlacing on Sandybridge and Ivybridge.

This fixes support for Motion Adaptive deinterlacing mode on both
Sandybridge and Ivybridge platforms. In particular, correct field
ordering is now supported, and STMM ping-pong buffering is added.

v2: changed STMM surface format to Y800 for a single plane.

Signed-off-by: Gwenole Beauchesne <gwenole.beauchesne@intel.com>
9 years agovpp: fix memory leak in DNDI code path.
Gwenole Beauchesne [Thu, 19 Mar 2015 06:02:54 +0000 (07:02 +0100)]
vpp: fix memory leak in DNDI code path.

The original current_out_surface was never released on exit. Main
reason for that is the legacy VPP framework that did not allow the
VADriverContextP handle to be passed down to the desired .finalize()
hook. Improved that to bring it on par with the VEBOX code path.

Signed-off-by: Gwenole Beauchesne <gwenole.beauchesne@intel.com>
9 years agoBump version to 1.6.0.pre1
Xiang, Haihao [Fri, 22 May 2015 08:47:19 +0000 (16:47 +0800)]
Bump version to 1.6.0.pre1

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
9 years agoVP8 HWEnc: Init CBR QP at begining of gen8_mfc_vp8_init
Zhong Li [Fri, 22 May 2015 08:33:53 +0000 (16:33 +0800)]
VP8 HWEnc: Init CBR QP at begining of gen8_mfc_vp8_init

Initialize CBR QP at begining of gen8_mfc_vp8_init(), because this
funtion will use qp to init prob_skip_false.

Signed-off-by: Zhong Li <zhong.li@intel.com>
9 years agoVP8 HWEnc: Fix CBR qp setting for vme cost
Zhong Li [Fri, 22 May 2015 06:06:04 +0000 (14:06 +0800)]
VP8 HWEnc: Fix CBR qp setting for vme cost

1. The q_index range of vp8 is different from h264, it's need to be
mapped to avc qp range.
2. For CBR case, qp should be set to CBR calculated value.

Signed-off-by: Zhong Li <zhong.li@intel.com>
Reviewed-by: Zhao Yakui <yakui.zhao@intel.com>
9 years agogen8_mfd: free surface used by JPEG decode
U. Artie Eoff [Tue, 19 May 2015 21:59:26 +0000 (14:59 -0700)]
gen8_mfd: free surface used by JPEG decode

This is a follow up to previous commit:

commit 8dda0650b55c467200c34ada127b5d9b54edea5c
Author: Zhao Yakui <yakui.zhao@intel.com>
Date:   Tue May 5 17:56:38 2015 +0800

    Decode: Free the allocated internal surface used by JPEG to avoid memory leak

For GEN8, this code path is normally disabled by default.
However, one can enable this code path by defining JPEG_WA
during compilation.  In that case, we would enable the
same memory leak.  Thus, apply the same fix in gen8_mfd to
fix it.

Signed-off-by: U. Artie Eoff <ullysses.a.eoff@intel.com>
Signed-off-by: Sean V Kelley <seanvk@posteo.de>
Tested-by: Sean V Kelley <seanvk@posteo.de>
9 years agoDecode: Free the allocated internal surface used by JPEG to avoid memory leak
Zhao Yakui [Tue, 5 May 2015 09:56:38 +0000 (17:56 +0800)]
Decode: Free the allocated internal surface used by JPEG to avoid memory leak

Signed-off-by: Zhao Yakui <yakui.zhao@intel.com>
Signed-off-by: Sean V Kelley <seanvk@posteo.de>
Tested-by: Sean V Kelley <seanvk@posteo.de>
9 years agoVP8 HWEnc: Fix vp8 mv incorrectly stored issue
Zhong Li [Mon, 4 May 2015 05:12:25 +0000 (13:12 +0800)]
VP8 HWEnc: Fix vp8 mv incorrectly stored issue

As vp8 spec, all luma motion vectors are doubled stored.
This patch has much benefit to P frame qualtity.

Signed-off-by: Zhong Li <zhong.li@intel.com>
9 years agoFix the build on Android
Xiang, Haihao [Thu, 30 Apr 2015 07:55:40 +0000 (15:55 +0800)]
Fix the build on Android

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
9 years agoVP8 HWEnc: Alloc larger memory for internal buffer
Zhong Li [Fri, 24 Apr 2015 08:51:00 +0000 (16:51 +0800)]
VP8 HWEnc: Alloc larger memory for internal buffer

It is to prevent the internal bitstream buffer overflow when qp is low.

Signed-off-by: Zhong Li <zhong.li@intel.com>
9 years agoVP8 HWEnc: Add CBR Support
Zhong Li [Fri, 24 Apr 2015 06:57:50 +0000 (14:57 +0800)]
VP8 HWEnc: Add CBR Support

Add bit rate control (CBR) for vp8 hw encoding

v1->v2: follow haihao's comment to update this patch

Signed-off-by: Zhong Li <zhong.li@intel.com>
9 years agoHEVC/dec: correct the frame store index
Xiang, Haihao [Wed, 22 Apr 2015 07:33:51 +0000 (15:33 +0800)]
HEVC/dec: correct the frame store index

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
9 years agoHEVC/dec: Fix collocated_ref_idx and collocated_from_l0_flag
Xiang, Haihao [Wed, 22 Apr 2015 07:33:50 +0000 (15:33 +0800)]
HEVC/dec: Fix collocated_ref_idx and collocated_from_l0_flag

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
9 years agoHEVC/dec: Make sure the derived value for ChromaLog2WeightDenom is in the the range...
Xiang, Haihao [Wed, 22 Apr 2015 07:33:49 +0000 (15:33 +0800)]
HEVC/dec: Make sure the derived value for ChromaLog2WeightDenom is in the the range of 0 to 7

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
9 years agoHEVC/dec: Fix weight/offset in HCP_WEIGHTOFFSET
Xiang, Haihao [Wed, 22 Apr 2015 07:33:48 +0000 (15:33 +0800)]
HEVC/dec: Fix weight/offset in HCP_WEIGHTOFFSET

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
9 years agoFix segmentation fault
Xiang, Haihao [Fri, 17 Apr 2015 08:41:24 +0000 (16:41 +0800)]
Fix segmentation fault

The segmentation fault occurs when CBR is selected without HRD parameter

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
9 years agoHEVC enc:Added 4K&2K support; Added Profile&Level 5.1 above
Qu,Pengfei [Wed, 15 Apr 2015 05:56:44 +0000 (13:56 +0800)]
HEVC enc:Added 4K&2K support; Added Profile&Level 5.1 above

Signed-off-by: Qu,Pengfei <Pengfei.Qu@intel.com>
9 years agoAllow va{Get,Put}Image() to use derived image
Xiang, Haihao [Tue, 31 Mar 2015 04:48:41 +0000 (12:48 +0800)]
Allow va{Get,Put}Image() to use derived image

The surface can't be the same surface from which the image has
been derived.

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
Reviewed-by: Sean V Kelley <seanvk@posteo.de>
Tested-by: Sean V Kelley <seanvk@posteo.de>
9 years agoFix the quality factor.
Sirisha Muppavarapu [Mon, 23 Mar 2015 21:16:02 +0000 (14:16 -0700)]
Fix the quality factor.

The following are added in this commit:
    1) Added lower bound to the quality factor.
    2) Added extensive comments on scaling and normalization of the quality factor.

9 years agocheck that intel-gen4asm tool is actually present
Daniel Charles [Thu, 3 Jul 2014 21:28:50 +0000 (14:28 -0700)]
check that intel-gen4asm tool is actually present

intel-gen4asm tool has to be present on the host tools so that
it can actually be used. Cross compiling shows problems when the
gpu-tools version is met but the tool is not available on the PATH

So, first check that the tool is available and later check for version
before defining HAVE_GEN4ASM.

Signed-off-by: Daniel Charles <daniel.charles@intel.com>
(cherry picked from commit 038097c00ad7b4f2e0fd572ee20f255dd378b5cb)

Conflicts:

configure.ac

9 years agovpp: add support for "low-power" mode.
Gwenole Beauchesne [Fri, 20 Mar 2015 15:09:42 +0000 (16:09 +0100)]
vpp: add support for "low-power" mode.

Add support for "low-power" mode expressed with VA_PROC_PIPELINE_FAST
flag set to VAProcPipelineParameterBuffer.pipeline_flags. The purpose
is to discard any complex operation that would consume too many HW
resources.

While doing so, also try to optimize for cases where we only want to
perform format conversion, scaling and basic bob-deinterlacing.

Signed-off-by: Gwenole Beauchesne <gwenole.beauchesne@intel.com>
9 years agogen7_mfd: Optimise start code search
Olivier Crete [Mon, 9 Mar 2015 22:20:34 +0000 (18:20 -0400)]
gen7_mfd: Optimise start code search

Code inspired from GStreamer

See https://bugs.freedesktop.org/show_bug.cgi?id=89507

Signed-off-by: Olivier Crete <olivier.crete@collabora.com>
9 years agoAdd support for HEVC decoding on CHV
Sean V Kelley [Wed, 18 Feb 2015 16:29:55 +0000 (08:29 -0800)]
Add support for HEVC decoding on CHV

We can re-use SKL HEVC decode pipeline

Signed-off-by: Sean V Kelley <seanvk@posteo.de>
Cc: haihao.xiang@intel.com
Cc: focus.luo@intel.com
(cherry picked from commit 78171ec3b8e73071405d9ff6ecbddc05a6787001)

9 years agoMPEG2 ENC: Remove gen9 pak pipeline code
Zhong Li [Fri, 6 Feb 2015 08:56:07 +0000 (16:56 +0800)]
MPEG2 ENC: Remove gen9 pak pipeline code

SKL pak pipeline of mpeg2 encoding is same as gen8,
so remove the redundant code

Signed-off-by: Zhong Li <zhong.li@intel.com>
(cherry picked from commit ac46de469dd5eeaed34be0510631228a07748ec3)

9 years agoVP8 DEC: Change error concealment method
Zhong Li [Fri, 6 Feb 2015 08:29:50 +0000 (16:29 +0800)]
VP8 DEC: Change error concealment method

Use intra prediciton as error concealment method, instead of inter P
copy.

Signed-off-by: Zhong Li <zhong.li@intel.com>
(cherry picked from commit 8d8b4a577fbaa8d278fbc5fe213023cfeea5d57a)

9 years agoDisable the context check to avoid JPEG ENC failed
Qu,Pengfei [Mon, 26 Jan 2015 05:01:23 +0000 (13:01 +0800)]
Disable the context check to avoid JPEG ENC failed

https://bugs.freedesktop.org/show_bug.cgi?id=88728
Signed-off-by: Qu,Pengfei <Pengfei.Qu@intel.com>
(cherry picked from commit a8ca5f911c7c19b5ede3f96ac6113606b9dd4d95)

9 years agoJust Style alignment
Qu,Pengfei [Thu, 8 Jan 2015 08:41:26 +0000 (16:41 +0800)]
Just Style alignment

Signed-off-by: Qu,Pengfei <Pengfei.Qu@intel.com>
(cherry picked from commit 22439f1fcebbd2c1d563503720b1123a4bb97160)

9 years agoHEVC ENC:Added HEVC support in API function
Qu,Pengfei [Thu, 8 Jan 2015 08:40:07 +0000 (16:40 +0800)]
HEVC ENC:Added HEVC support in API function

Signed-off-by: Qu,Pengfei <Pengfei.Qu@intel.com>
(cherry picked from commit d4f1087a0606c7c8d2d5fd65d9f46990f41ce93a)

9 years agoHEVC ENC:Added pipeline init
Qu,Pengfei [Thu, 8 Jan 2015 08:39:38 +0000 (16:39 +0800)]
HEVC ENC:Added pipeline init

Signed-off-by: Qu,Pengfei <Pengfei.Qu@intel.com>
(cherry picked from commit 2759cabfa57c6e78ab2033cad4e7c2cbf2b9d4e2)

9 years agoHEVC ENC:Added VME pipeline
Qu,Pengfei [Thu, 8 Jan 2015 08:39:18 +0000 (16:39 +0800)]
HEVC ENC:Added VME pipeline

Signed-off-by: Qu,Pengfei <Pengfei.Qu@intel.com>
(cherry picked from commit 2a85633e34a4e66b18634e7b53cc91aa44ad2c2b)

Conflicts:
src/gen6_mfc_common.c

9 years agoHEVC ENC:Added PAK pipeline
Qu,Pengfei [Thu, 8 Jan 2015 08:38:52 +0000 (16:38 +0800)]
HEVC ENC:Added PAK pipeline

Signed-off-by: Qu,Pengfei <Pengfei.Qu@intel.com>
[Fix PAK-BSE data start offset in HCP_SLICE_STATE]
Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
(cherry picked from commit 3f47222004c6c2e575b170c7c7c3be00f61df302)

9 years agoHEVC ENC:Added slice header generated internally
Qu,Pengfei [Thu, 8 Jan 2015 08:38:25 +0000 (16:38 +0800)]
HEVC ENC:Added slice header generated internally

Signed-off-by: Qu,Pengfei <Pengfei.Qu@intel.com>
(cherry picked from commit 2c54b96fe89aa0839f8c34935a84b79c41fde55d)

Conflicts:
src/i965_encoder_utils.h

9 years agoHEVC ENC:Added PAK context for HEVC
Qu,Pengfei [Thu, 8 Jan 2015 08:23:43 +0000 (16:23 +0800)]
HEVC ENC:Added PAK context for HEVC

Signed-off-by: Qu,Pengfei <Pengfei.Qu@intel.com>
(cherry picked from commit 41f23f3dcfe24ca9493b36cb00bab5317584b099)

9 years agoVP8 HWEnc: Add BSW VP8 HWEnc support
Zhong Li [Thu, 15 Jan 2015 14:04:59 +0000 (22:04 +0800)]
VP8 HWEnc: Add BSW VP8 HWEnc support

Add BSW vp8 encoding support, and let SKL and BDW use the same PAK pipeline.

Signed-off-by: Zhong Li <zhong.li@intel.com>
(cherry picked from commit c2be56ae6f3628ea246a1dd02e5cac18da84df56)

9 years agoVP8 HWEnc: declare copyright and license of vp8_probs.h
Zhong Li [Thu, 15 Jan 2015 14:04:58 +0000 (22:04 +0800)]
VP8 HWEnc: declare copyright and license of vp8_probs.h

Signed-off-by: Zhong Li <zhong.li@intel.com>
(cherry picked from commit a52a5ffe1dc62ff12989e329860ae81ced247f00)

9 years agoVP8 HWEnc: vp8 encode quality optimization
Zhong Li [Thu, 15 Jan 2015 14:04:57 +0000 (22:04 +0800)]
VP8 HWEnc: vp8 encode quality optimization

1. Add mv and mode cost calc
2. Support 16x16 and 4x4 intra prediction
3. Support multi-mode intar prediction
4. Support 16x16 New_MV mode inter prediction

Signed-off-by: Zhong Li <zhong.li@intel.com>
(cherry picked from commit a25bda914d4041a96252bd24a597558af3237b15)

9 years agoVP8 HWEnc: Calc vp8 coded size by internal buffer
Zhong Li [Thu, 15 Jan 2015 14:04:56 +0000 (22:04 +0800)]
VP8 HWEnc: Calc vp8 coded size by internal buffer

Signed-off-by: Zhong Li <zhong.li@intel.com>
(cherry picked from commit 379282cbc79b65c994c22009412472bdeddbb4cc)

9 years agoVP8 HWEnc: Add P frame encoding support
Zhong Li [Thu, 15 Jan 2015 14:04:55 +0000 (22:04 +0800)]
VP8 HWEnc: Add P frame encoding support

Signed-off-by: Zhong Li <zhong.li@intel.com>
(cherry picked from commit e4737bb3b29c5ac9fb01f4efccd743d260673e27)

Conflicts:
src/shaders/vme/Makefile.am

9 years agoVP8 HWEnc: Build VP8 PAK pipeline and enabling I frame
Zhong Li [Thu, 15 Jan 2015 14:04:54 +0000 (22:04 +0800)]
VP8 HWEnc: Build VP8 PAK pipeline and enabling I frame

Signed-off-by: Zhong Li <zhong.li@intel.com>
(cherry picked from commit a18ce4664113d5b1a9b29ed45bf137df6b7a7898)

Conflicts:
src/i965_encoder_utils.c