hardware/intel/libva
Revision | cd08c78169c4b958f5c491fb409f09870f90ee5b (tree) |
---|---|
Time | 2013-06-19 15:24:12 |
Author | Elaine Wang <elaine.wang@inte...> |
Commiter | Xiang, Haihao |
vatrace: fix vatrace crash during video recording
Video recording crash when va trace is enabled. It's caused by
using wrong buffer type to trace slice buffer. This patch distinguish buffer
type VAEncSliceParameterBuffer from VAEncSliceParameterBufferH264 by
the buffer size.
Signed-off-by: Elaine Wang <elaine.wang@intel.com>
Change-Id: Ibc5c6a17b155e305151a25580b4e613702665ad1
(cherry picked from commit b5b1933f60dfec8cf2cff19082362accbe6fce1d)
@@ -1348,6 +1348,8 @@ static void va_TraceVAEncSliceParameterBufferH264( | ||
1348 | 1348 | DPY2INDEX(dpy); |
1349 | 1349 | int i; |
1350 | 1350 | |
1351 | + if (!p) | |
1352 | + return; | |
1351 | 1353 | va_TraceMsg(idx, "VAEncSliceParameterBufferH264\n"); |
1352 | 1354 | va_TraceMsg(idx, "\tmacroblock_address = %d\n", p->macroblock_address); |
1353 | 1355 | va_TraceMsg(idx, "\tnum_macroblocks = %d\n", p->num_macroblocks); |
@@ -1366,12 +1368,12 @@ static void va_TraceVAEncSliceParameterBufferH264( | ||
1366 | 1368 | |
1367 | 1369 | if (p->slice_type == 0 || p->slice_type == 1) { |
1368 | 1370 | va_TraceMsg(idx, "\tRefPicList0 ="); |
1369 | - for (i = 0; i < p->num_ref_idx_l0_active_minus1 + 1; i++) { | |
1371 | + for (i = 0; i < p->num_ref_idx_l0_active_minus1 + 1 && i < 32; i++) { | |
1370 | 1372 | va_TraceMsg(idx, "%d-%d-0x%08x-%d\n", p->RefPicList0[i].TopFieldOrderCnt, p->RefPicList0[i].BottomFieldOrderCnt, p->RefPicList0[i].picture_id, p->RefPicList0[i].frame_idx); |
1371 | 1373 | } |
1372 | 1374 | if (p->slice_type == 1) { |
1373 | 1375 | va_TraceMsg(idx, "\tRefPicList1 ="); |
1374 | - for (i = 0; i < p->num_ref_idx_l1_active_minus1 + 1; i++) | |
1376 | + for (i = 0; i < p->num_ref_idx_l1_active_minus1 + 1 && i < 32; i++) | |
1375 | 1377 | { |
1376 | 1378 | va_TraceMsg(idx, "%d-%d-0x%08x-%d\n", p->RefPicList1[i].TopFieldOrderCnt, p->RefPicList1[i].BottomFieldOrderCnt, p->RefPicList1[i].picture_id, p->RefPicList1[i].frame_idx); |
1377 | 1379 | } |
@@ -1381,7 +1383,7 @@ static void va_TraceVAEncSliceParameterBufferH264( | ||
1381 | 1383 | va_TraceMsg(idx, "\tluma_log2_weight_denom = %d\n", p->luma_log2_weight_denom); |
1382 | 1384 | va_TraceMsg(idx, "\tchroma_log2_weight_denom = %d\n", p->chroma_log2_weight_denom); |
1383 | 1385 | va_TraceMsg(idx, "\tluma_weight_l0_flag = %d\n", p->luma_weight_l0_flag); |
1384 | - if (p->luma_weight_l0_flag) { | |
1386 | + if (p->luma_weight_l0_flag && p->num_ref_idx_l0_active_minus1 < 32) { | |
1385 | 1387 | for (i = 0; i <= p->num_ref_idx_l0_active_minus1; i++) { |
1386 | 1388 | va_TraceMsg(idx, "\t%d ", p->luma_weight_l0[i]); |
1387 | 1389 | va_TraceMsg(idx, "\t%d ", p->luma_offset_l0[i]); |
@@ -1389,7 +1391,7 @@ static void va_TraceVAEncSliceParameterBufferH264( | ||
1389 | 1391 | } |
1390 | 1392 | |
1391 | 1393 | va_TraceMsg(idx, "\tchroma_weight_l0_flag = %d\n", p->chroma_weight_l0_flag); |
1392 | - if (p->chroma_weight_l0_flag) { | |
1394 | + if (p->chroma_weight_l0_flag && p->num_ref_idx_l0_active_minus1 < 32) { | |
1393 | 1395 | for (i = 0; i <= p->num_ref_idx_l0_active_minus1; i++) { |
1394 | 1396 | va_TraceMsg(idx, "\t\t%d ", p->chroma_weight_l0[i][0]); |
1395 | 1397 | va_TraceMsg(idx, "\t\t%d ", p->chroma_offset_l0[i][0]); |
@@ -1399,7 +1401,7 @@ static void va_TraceVAEncSliceParameterBufferH264( | ||
1399 | 1401 | } |
1400 | 1402 | |
1401 | 1403 | va_TraceMsg(idx, "\tluma_weight_l1_flag = %d\n", p->luma_weight_l1_flag); |
1402 | - if (p->luma_weight_l1_flag) { | |
1404 | + if (p->luma_weight_l1_flag && p->num_ref_idx_l1_active_minus1 < 32) { | |
1403 | 1405 | for (i = 0; i <= p->num_ref_idx_l1_active_minus1; i++) { |
1404 | 1406 | va_TraceMsg(idx, "\t\t%d ", p->luma_weight_l1[i]); |
1405 | 1407 | va_TraceMsg(idx, "\t\t%d ", p->luma_offset_l1[i]); |
@@ -1407,7 +1409,7 @@ static void va_TraceVAEncSliceParameterBufferH264( | ||
1407 | 1409 | } |
1408 | 1410 | |
1409 | 1411 | va_TraceMsg(idx, "\tchroma_weight_l1_flag = %d\n", p->chroma_weight_l1_flag); |
1410 | - if (p->chroma_weight_l1_flag) { | |
1412 | + if (p->chroma_weight_l1_flag && p->num_ref_idx_l1_active_minus1 < 32) { | |
1411 | 1413 | for (i = 0; i <= p->num_ref_idx_l1_active_minus1; i++) { |
1412 | 1414 | va_TraceMsg(idx, "\t\t%d ", p->chroma_weight_l1[i][0]); |
1413 | 1415 | va_TraceMsg(idx, "\t\t%d ", p->chroma_offset_l1[i][0]); |
@@ -2031,7 +2033,10 @@ static void va_TraceH264Buf( | ||
2031 | 2033 | va_TraceVAEncPictureParameterBufferH264(dpy, context, buffer, type, size, num_elements, pbuf); |
2032 | 2034 | break; |
2033 | 2035 | case VAEncSliceParameterBufferType: |
2034 | - va_TraceVAEncSliceParameterBufferH264(dpy, context, buffer, type, size, num_elements, pbuf); | |
2036 | + if (size == sizeof(VAEncSliceParameterBuffer)) | |
2037 | + va_TraceVAEncSliceParameterBuffer(dpy, context, buffer, type, size, num_elements, pbuf); | |
2038 | + else | |
2039 | + va_TraceVAEncSliceParameterBufferH264(dpy, context, buffer, type, size, num_elements, pbuf); | |
2035 | 2040 | break; |
2036 | 2041 | case VAEncMiscParameterBufferType: |
2037 | 2042 | va_TraceVAEncMiscParameterBuffer(dpy, context, buffer, type, size, num_elements, pbuf); |