codecparsers: jpeg: use U_READ_UINT*() wherever possible.

Use GstByteReader *_unchecked() variants as much as possible.

Signed-off-by: Gwenole Beauchesne <gwenole.beauchesne@intel.com>
This commit is contained in:
Wind Yuan 2012-06-05 10:10:22 +08:00 committed by Gwenole Beauchesne
parent 90e6532fd3
commit e61f4c4445

View file

@ -88,6 +88,15 @@ ensure_debug_category (void)
memcpy(buf, vals, length); \ memcpy(buf, vals, length); \
} G_STMT_END } G_STMT_END
#define U_READ_UINT8(reader, val) G_STMT_START { \
(val) = gst_byte_reader_get_uint8_unchecked(reader); \
} G_STMT_END
#define U_READ_UINT16(reader, val) G_STMT_START { \
(val) = gst_byte_reader_get_uint16_be_unchecked(reader); \
} G_STMT_END
static gboolean jpeg_parse_to_next_marker (GstByteReader * reader, static gboolean jpeg_parse_to_next_marker (GstByteReader * reader,
guint8 * marker); guint8 * marker);
@ -268,18 +277,23 @@ gst_jpeg_parse_frame_hdr (GstJpegFrameHdr * frame_hdr,
u_int i; u_int i;
g_assert (frame_hdr && data && size); g_assert (frame_hdr && data && size);
READ_UINT8 (&bytes_reader, frame_hdr->sample_precision);
READ_UINT16 (&bytes_reader, frame_hdr->height); CHECK_FAILED (gst_byte_reader_get_remaining (&bytes_reader) >= 6, GST_JPEG_PARSER_ERROR);
READ_UINT16 (&bytes_reader, frame_hdr->width); U_READ_UINT8 (&bytes_reader, frame_hdr->sample_precision);
READ_UINT8 (&bytes_reader, frame_hdr->num_components); U_READ_UINT16 (&bytes_reader, frame_hdr->height);
U_READ_UINT16 (&bytes_reader, frame_hdr->width);
U_READ_UINT8 (&bytes_reader, frame_hdr->num_components);
CHECK_FAILED (frame_hdr->num_components <= GST_JPEG_MAX_SCAN_COMPONENTS, CHECK_FAILED (frame_hdr->num_components <= GST_JPEG_MAX_SCAN_COMPONENTS,
GST_JPEG_PARSER_ERROR); GST_JPEG_PARSER_ERROR);
CHECK_FAILED (gst_byte_reader_get_remaining(&bytes_reader) >= 3*frame_hdr->num_components,
GST_JPEG_PARSER_ERROR);
for (i = 0; i < frame_hdr->num_components; i++) { for (i = 0; i < frame_hdr->num_components; i++) {
READ_UINT8 (&bytes_reader, frame_hdr->components[i].identifier); U_READ_UINT8 (&bytes_reader, frame_hdr->components[i].identifier);
READ_UINT8 (&bytes_reader, val); U_READ_UINT8 (&bytes_reader, val);
frame_hdr->components[i].horizontal_factor = (val >> 4) & 0x0F; frame_hdr->components[i].horizontal_factor = (val >> 4) & 0x0F;
frame_hdr->components[i].vertical_factor = (val & 0x0F); frame_hdr->components[i].vertical_factor = (val & 0x0F);
READ_UINT8 (&bytes_reader, frame_hdr->components[i].quant_table_selector); U_READ_UINT8 (&bytes_reader, frame_hdr->components[i].quant_table_selector);
CHECK_FAILED ((frame_hdr->components[i].horizontal_factor <= 4 && CHECK_FAILED ((frame_hdr->components[i].horizontal_factor <= 4 &&
frame_hdr->components[i].vertical_factor <= 4 && frame_hdr->components[i].vertical_factor <= 4 &&
frame_hdr->components[i].quant_table_selector < 4), frame_hdr->components[i].quant_table_selector < 4),
@ -287,9 +301,6 @@ gst_jpeg_parse_frame_hdr (GstJpegFrameHdr * frame_hdr,
} }
return GST_JPEG_PARSER_OK; return GST_JPEG_PARSER_OK;
failed:
return GST_JPEG_PARSER_ERROR;
wrong_state: wrong_state:
return result; return result;
} }
@ -307,10 +318,13 @@ gst_jpeg_parse_scan_hdr (GstJpegScanHdr * scan_hdr,
READ_UINT8 (&bytes_reader, scan_hdr->num_components); READ_UINT8 (&bytes_reader, scan_hdr->num_components);
CHECK_FAILED (scan_hdr->num_components <= GST_JPEG_MAX_SCAN_COMPONENTS, CHECK_FAILED (scan_hdr->num_components <= GST_JPEG_MAX_SCAN_COMPONENTS,
GST_JPEG_PARSER_BROKEN_DATA); GST_JPEG_PARSER_BROKEN_DATA);
CHECK_FAILED (gst_byte_reader_get_remaining (&bytes_reader) >= 2*scan_hdr->num_components,
GST_JPEG_PARSER_ERROR);
for (i = 0; i < scan_hdr->num_components; i++) { for (i = 0; i < scan_hdr->num_components; i++) {
READ_UINT8 (&bytes_reader, U_READ_UINT8 (&bytes_reader,
scan_hdr->components[i].component_selector); scan_hdr->components[i].component_selector);
READ_UINT8 (&bytes_reader, val); U_READ_UINT8 (&bytes_reader, val);
scan_hdr->components[i].dc_selector = (val >> 4) & 0x0F; scan_hdr->components[i].dc_selector = (val >> 4) & 0x0F;
scan_hdr->components[i].ac_selector = val & 0x0F; scan_hdr->components[i].ac_selector = val & 0x0F;
g_assert (scan_hdr->components[i].dc_selector < 4 && g_assert (scan_hdr->components[i].dc_selector < 4 &&
@ -344,7 +358,7 @@ gst_jpeg_parse_huffman_table (
g_assert (huf_tables && data && size); g_assert (huf_tables && data && size);
while (gst_byte_reader_get_remaining (&bytes_reader)) { while (gst_byte_reader_get_remaining (&bytes_reader)) {
READ_UINT8 (&bytes_reader, tmp_val); U_READ_UINT8 (&bytes_reader, tmp_val);
is_dc = !((tmp_val >> 4) & 0x0F); is_dc = !((tmp_val >> 4) & 0x0F);
table_index = (tmp_val & 0x0F); table_index = (tmp_val & 0x0F);
CHECK_FAILED (table_index < GST_JPEG_MAX_SCAN_COMPONENTS, CHECK_FAILED (table_index < GST_JPEG_MAX_SCAN_COMPONENTS,
@ -383,26 +397,26 @@ gst_jpeg_parse_quant_table (
g_assert (quant_tables && num_quant_tables && data && size); g_assert (quant_tables && num_quant_tables && data && size);
while (gst_byte_reader_get_remaining (&bytes_reader)) { while (gst_byte_reader_get_remaining (&bytes_reader)) {
READ_UINT8 (&bytes_reader, val); U_READ_UINT8 (&bytes_reader, val);
table_index = (val & 0x0f); table_index = (val & 0x0f);
CHECK_FAILED (table_index < GST_JPEG_MAX_SCAN_COMPONENTS && table_index < num_quant_tables, CHECK_FAILED (table_index < GST_JPEG_MAX_SCAN_COMPONENTS && table_index < num_quant_tables,
GST_JPEG_PARSER_BROKEN_DATA); GST_JPEG_PARSER_BROKEN_DATA);
quant_table = &quant_tables[table_index]; quant_table = &quant_tables[table_index];
quant_table->quant_precision = ((val >> 4) & 0x0f); quant_table->quant_precision = ((val >> 4) & 0x0f);
CHECK_FAILED (gst_byte_reader_get_remaining(&bytes_reader) >= GST_JPEG_MAX_QUANT_ELEMENTS * (1 + !!quant_table->quant_precision),
GST_JPEG_PARSER_BROKEN_DATA);
for (i = 0; i < GST_JPEG_MAX_QUANT_ELEMENTS; i++) { for (i = 0; i < GST_JPEG_MAX_QUANT_ELEMENTS; i++) {
if (!quant_table->quant_precision) { /* 8-bit values */ if (!quant_table->quant_precision) { /* 8-bit values */
READ_UINT8(&bytes_reader, val); U_READ_UINT8 (&bytes_reader, val);
quant_table->quant_table[i] = val; quant_table->quant_table[i] = val;
} else { /* 16-bit values */ } else { /* 16-bit values */
READ_UINT16(&bytes_reader, quant_table->quant_table[i]); U_READ_UINT16 (&bytes_reader, quant_table->quant_table[i]);
} }
} }
} }
return GST_JPEG_PARSER_OK; return GST_JPEG_PARSER_OK;
failed:
return GST_JPEG_PARSER_ERROR;
wrong_state: wrong_state:
return result; return result;
} }