>-----Original Message-----
>From: Libva [mailto:[email protected]] On Behalf Of Lim
>Siew Hoon
>Sent: Monday, June 27, 2016 8:27 PM
>To: [email protected]
>Subject: [Libva] [PATCH 2/3] check memory allocation and initialize to zero
>value in save_recyuv
>
>Signed-off-by: Lim Siew Hoon <[email protected]>
>---
> test/encode/h264encode.c | 38
>++++++++++++++++++++++++++++++++++++++
> 1 file changed, 38 insertions(+)
>
>diff --git a/test/encode/h264encode.c b/test/encode/h264encode.c
>index ce96f92..d5bc3a6 100644
>--- a/test/encode/h264encode.c
>+++ b/test/encode/h264encode.c
>@@ -1940,13 +1940,51 @@ static int save_recyuv(VASurfaceID surface_id,
> if (srcyuv_fourcc == VA_FOURCC_NV12) {
> int uv_size = 2 * (frame_width/2) * (frame_height/2);
> dst_Y = malloc(2*uv_size);
>+ if(dst_Y == NULL) {
>+ printf("Failed to allocate memory for dst_Y\n");
>+ exit(1);
>+ }
>+
> dst_U = malloc(uv_size);
>+ if(dst_U == NULL) {
>+ printf("Failed to allocate memory for dst_U\n");
>+ if(dst_Y)
>+ free(dst_Y);
First dst_y is not NULL when getting here, second free(NULL) is safe, so it is
not necessary check dst_y against NULL.
>+ exit(1);
>+ }
>+
>+ memset(dst_Y, 0, 2*uv_size);
>+ memset(dst_U, 0, uv_size);
> } else if (srcyuv_fourcc == VA_FOURCC_IYUV ||
> srcyuv_fourcc == VA_FOURCC_YV12) {
> int uv_size = (frame_width/2) * (frame_height/2);
> dst_Y = malloc(4*uv_size);
>+ if(dst_Y == NULL) {
>+ printf("Failed to allocate memory for dst_Y\n");
>+ exit(1);
>+ }
>+
> dst_U = malloc(uv_size);
>+ if(dst_U == NULL) {
>+ printf("Failed to allocate memory for dst_U\n");
>+ if(dst_Y)
>+ free(dst_Y);
Same as above.
>+ exit(1);
>+ }
>+
> dst_V = malloc(uv_size);
>+ if(dst_V == NULL) {
>+ printf("Failed to allocate memory for dst_V\n");
>+ if(dst_Y)
>+ free(dst_Y);
>+ if(dst_U)
>+ free(dst_U);
Same as above.
>+ exit(1);
>+ }
>+
>+ memset(dst_Y, 0, 4*uv_size);
>+ memset(dst_U, 0, uv_size);
>+ memset(dst_V, 0, uv_size);
> } else {
> printf("Unsupported source YUV format\n");
> exit(1);
>--
>2.1.0
>
>_______________________________________________
>Libva mailing list
>[email protected]
>https://lists.freedesktop.org/mailman/listinfo/libva
_______________________________________________
Libva mailing list
[email protected]
https://lists.freedesktop.org/mailman/listinfo/libva