OSDN Git Service

android-x86/hardware-intel-intel-driver.git
8 years agoMake sure the pointer is valid before dereferencing it
Xiang, Haihao [Mon, 21 Sep 2015 00:54:11 +0000 (08:54 +0800)]
Make sure the pointer is valid before dereferencing it

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
Reviewed-by: Zhao, Yakui <yakui.zhao@intel.com>
8 years agoUpdate the NEWS
Xiang, Haihao [Fri, 18 Sep 2015 04:12:03 +0000 (12:12 +0800)]
Update the NEWS

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
8 years agoSilence compiler warning
Xiang, Haihao [Tue, 8 Sep 2015 01:18:14 +0000 (09:18 +0800)]
Silence compiler warning

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
8 years agoCheck pointer returned from calloc()
Xiang, Haihao [Mon, 7 Sep 2015 07:21:49 +0000 (15:21 +0800)]
Check pointer returned from calloc()

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
8 years agoCheck pointer against NULL first before dereferencing it
Xiang, Haihao [Mon, 7 Sep 2015 01:29:38 +0000 (09:29 +0800)]
Check pointer against NULL first before dereferencing it

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
Reviewed-by: Zhao, Yakui <yakui.zhao@intel.com>
8 years agoi965: Remove duplicate check on platform in hybrid codec proxy
Sean V Kelley [Fri, 11 Sep 2015 01:21:22 +0000 (18:21 -0700)]
i965: Remove duplicate check on platform in hybrid codec proxy

Check is made in hybrid driver for respectve platforms.

Signed-off-by: Sean V Kelley <seanvk@posteo.de>
8 years ago1.6.2.pre1 for development
Xiang, Haihao [Thu, 10 Sep 2015 02:57:32 +0000 (10:57 +0800)]
1.6.2.pre1 for development

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
8 years agoMerge branch 'v1.6-branch' into fdo--master
Xiang, Haihao [Thu, 10 Sep 2015 02:56:28 +0000 (10:56 +0800)]
Merge branch 'v1.6-branch' into fdo--master

Conflicts:
configure.ac

8 years agolibva-intel-driver 1.6.1
Xiang, Haihao [Wed, 9 Sep 2015 08:51:36 +0000 (16:51 +0800)]
libva-intel-driver 1.6.1

Signed-off-by: Xiang, Haihao <haihao.xiang@intel.com>
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>
(cherry picked from commit 2d42512bd6b7382c5effe21a5f9999742d98db88)

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 agoUpdate NEWS
Xiang, Haihao [Sun, 6 Sep 2015 07:49:46 +0000 (15:49 +0800)]
Update NEWS

Signed-off-by: Xiang, Haihao <haihao.xiang@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>
(cherry picked from commit b63c28904e2568c0c50b5047b5a90d32d02b9fca)

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>
(cherry picked from commit ad7b5a0233d8ead9a2ca141f3fa75f4bda1045c1)

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>
(cherry picked from commit 12a09a2efe213af350f29f342da6842d66dab63e)

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>
(cherry picked from commit f75ddc58b16cb93e85e737792c431415288cafb1)

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>
(cherry picked from commit 44e3ec2a98e99ccd839bd05cba45f0b8c9afe437)

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>
(cherry picked from commit 464ebff117df40b04c4f8da560c311e470d5a112)

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>
(cherry picked from commit 815d17f944b13ebc1eca62572dbec0c49ea01999)

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>
(cherry picked from commit 3bbaff8b4180d2510c8c77d9e4d19bf84853f31a)

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>
(cherry picked from commit 2f254ecd154d59553a1e3949f66161bade6ca2b7)

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>
(cherry picked from commit 020b341cf959c7ae10a233972fcbe29c47d86e68)

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>
(cherry picked from commit cec8f05596a4bf11070fffeec1b4c7e5b7d44323)

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>
(cherry picked from commit d7c2ba36a1bce5d4bd2e40fd161eae160946bd76)

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>
(cherry picked from commit eb06298ecadf53a752abbb99208a37bda3e90c30)

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>
(cherry picked from commit e12ddd354454a6491b24be202f0f56d401ab0a1b)

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>
(cherry picked from commit d69346b33e31efac0e7338bc24718eef76f329da)

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>
(cherry picked from commit d117b9d30a00c811eb7e636c772979de846d30c8)

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>
(cherry picked from commit 9170fed321780f394e8eae4a789c31120c4e957c)

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>
(cherry picked from commit 1c5a8431e581eb26240c765d28f89e06138ca879)

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
(cherry picked from commit c1f6411d3e0337226e157a51f8aab6a9c4e8b434)

8 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>
(cherry picked from commit 29f4234504fd99299997a3fc2f01393fb77030b7)

8 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>
(cherry picked from commit e751897e64d1d37d6c592b71a8cc7ea8bc8a0b7f)

8 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>
(cherry picked from commit 02a2d4cb26e9a651b33a6e35c665b287155bbb83)

8 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>
(cherry picked from commit 7c47a8f74878904e0d2fbb5da966552f783d74ab)

8 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>
(cherry picked from commit 67e122a4b100365d5d8bb6377c73e39f6c44abf9)

8 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>
(cherry picked from commit 611d8ea9d75dc026c203e3ebe53b434769d4587c)

8 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>
(cherry picked from commit 4bda4667fd635df5bd27ce01353a3b6d6bf85508)

8 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.
(cherry picked from commit 12b3d9ef379e6159e30c2aafc040f1137cd4141a)

8 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>
(cherry picked from commit d06c17e9c0d4a11a3efaead7da63765148bf938e)

8 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>
(cherry picked from commit fb5e1cd86047e2683f169cd52cc27861447321cf)

8 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>
(cherry picked from commit 7bb3658212f49a6f8d3d61b0b5d161aca73c2a11)

8 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>
(cherry picked from commit 8d11fd7dd7952551b2d57f900ce1f408a35616a1)

8 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>
(cherry picked from commit 6ff572fb94fce0b941d56eb7c0f45d82c1672ea3)

8 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
(cherry picked from commit e49960198a4c53ad96e36e0952db514764af06f6)

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

8 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>
8 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>
8 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>
8 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>
8 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>
8 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>
8 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>
8 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.

8 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>
8 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

8 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>
8 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>