summaryrefslogtreecommitdiffstats
path: root/gst/mxf/mxftypes.c
diff options
context:
space:
mode:
authorSebastian Dröge <sebastian.droege@collabora.co.uk>2009-03-26 13:11:07 +0100
committerSebastian Dröge <sebastian.droege@collabora.co.uk>2009-03-26 13:11:07 +0100
commitc1c8b40d4201a4b6657b644bbe4a89e63b54bd0c (patch)
treedf8339df815d97db4b0327ce1ea2ae58ac9dcf86 /gst/mxf/mxftypes.c
parentce01236e328ba6863740361c81f1da98d37b687c (diff)
downloadgst-plugins-bad-c1c8b40d4201a4b6657b644bbe4a89e63b54bd0c.tar.gz
gst-plugins-bad-c1c8b40d4201a4b6657b644bbe4a89e63b54bd0c.tar.bz2
gst-plugins-bad-c1c8b40d4201a4b6657b644bbe4a89e63b54bd0c.zip
mxf: Differentiate between UL and UUID
Diffstat (limited to 'gst/mxf/mxftypes.c')
-rw-r--r--gst/mxf/mxftypes.c227
1 files changed, 187 insertions, 40 deletions
diff --git a/gst/mxf/mxftypes.c b/gst/mxf/mxftypes.c
index 5660ec7f..989203ef 100644
--- a/gst/mxf/mxftypes.c
+++ b/gst/mxf/mxftypes.c
@@ -188,7 +188,7 @@ mxf_ber_encode_size (guint size, guint8 ber[9])
}
GstBuffer *
-mxf_fill_new (guint size)
+mxf_fill_to_buffer (guint size)
{
GstBuffer *ret;
guint slen;
@@ -205,16 +205,162 @@ mxf_fill_new (guint size)
}
void
-mxf_ul_set (MXFUL * ul, GHashTable * hashtable)
+mxf_uuid_init (MXFUUID * uuid, GHashTable * hashtable)
{
guint i;
do {
for (i = 0; i < 4; i++)
- GST_WRITE_UINT32_BE (&ul->u[i * 4], g_random_int ());
+ GST_WRITE_UINT32_BE (&uuid->u[i * 4], g_random_int ());
- } while (hashtable
- && g_hash_table_lookup_extended (hashtable, ul, NULL, NULL));
+ } while (hashtable && (mxf_uuid_is_zero (uuid) ||
+ g_hash_table_lookup_extended (hashtable, uuid, NULL, NULL)));
+}
+
+gboolean
+mxf_uuid_is_equal (const MXFUUID * a, const MXFUUID * b)
+{
+ g_return_val_if_fail (a != NULL, FALSE);
+ g_return_val_if_fail (b != NULL, FALSE);
+
+ return (memcmp (a, b, 16) == 0);
+}
+
+gboolean
+mxf_uuid_is_zero (const MXFUUID * a)
+{
+ static const guint8 zero[16] = { 0x00, };
+
+ g_return_val_if_fail (a != NULL, FALSE);
+
+ return (memcmp (a, zero, 16) == 0);
+}
+
+guint
+mxf_uuid_hash (const MXFUUID * uuid)
+{
+ guint32 ret = 0;
+ guint i;
+
+ g_return_val_if_fail (uuid != NULL, 0);
+
+ for (i = 0; i < 4; i++)
+ ret ^= (uuid->u[i * 4 + 0] << 24) |
+ (uuid->u[i * 4 + 1] << 16) |
+ (uuid->u[i * 4 + 2] << 8) | (uuid->u[i * 4 + 3] << 0);
+
+ return ret;
+}
+
+gchar *
+mxf_uuid_to_string (const MXFUUID * uuid, gchar str[48])
+{
+ gchar *ret = str;
+
+ g_return_val_if_fail (uuid != NULL, NULL);
+
+ if (ret == NULL)
+ ret = g_malloc (48);
+
+ g_snprintf (ret, 48,
+ "%02x.%02x.%02x.%02x."
+ "%02x.%02x.%02x.%02x."
+ "%02x.%02x.%02x.%02x."
+ "%02x.%02x.%02x.%02x",
+ uuid->u[0], uuid->u[1], uuid->u[2], uuid->u[3],
+ uuid->u[4], uuid->u[5], uuid->u[6], uuid->u[7],
+ uuid->u[8], uuid->u[9], uuid->u[10], uuid->u[11],
+ uuid->u[12], uuid->u[13], uuid->u[14], uuid->u[15]);
+
+ return ret;
+}
+
+MXFUUID *
+mxf_uuid_from_string (const gchar * str, MXFUUID * uuid)
+{
+ MXFUUID *ret = uuid;
+ gint len;
+ guint i, j;
+
+ g_return_val_if_fail (str != NULL, NULL);
+
+ len = strlen (str);
+ if (len != 47) {
+ GST_ERROR ("Invalid UUID string length %d, should be 47", len);
+ return NULL;
+ }
+
+ if (ret == NULL)
+ ret = g_new0 (MXFUUID, 1);
+
+ memset (ret, 0, 16);
+
+ for (i = 0, j = 0; i < 16; i++) {
+ if (!g_ascii_isxdigit (str[j]) ||
+ !g_ascii_isxdigit (str[j + 1]) ||
+ (str[j + 2] != '.' && str[j + 2] != '\0')) {
+ GST_ERROR ("Invalid UL string '%s'", str);
+ if (uuid == NULL)
+ g_free (ret);
+ return NULL;
+ }
+
+ ret->u[i] = (g_ascii_xdigit_value (str[j]) << 4) |
+ (g_ascii_xdigit_value (str[j + 1]));
+ j += 3;
+ }
+ return ret;
+}
+
+gboolean
+mxf_uuid_array_parse (MXFUUID ** array, guint32 * count, const guint8 * data,
+ guint size)
+{
+ guint32 element_count, element_size;
+ guint i;
+
+ g_return_val_if_fail (array != NULL, FALSE);
+ g_return_val_if_fail (count != NULL, FALSE);
+ g_return_val_if_fail (data != NULL, FALSE);
+
+ if (size < 8)
+ return FALSE;
+
+ element_count = GST_READ_UINT32_BE (data);
+ data += 4;
+ size -= 4;
+
+ if (element_count == 0) {
+ *array = NULL;
+ *count = 0;
+ return TRUE;
+ }
+
+ element_size = GST_READ_UINT32_BE (data);
+ data += 4;
+ size -= 4;
+
+ if (element_size != 16) {
+ *array = NULL;
+ *count = 0;
+ return FALSE;
+ }
+
+ if (16 * element_count < size) {
+ *array = NULL;
+ *count = 0;
+ return FALSE;
+ }
+
+ *array = g_new (MXFUUID, element_count);
+ *count = element_count;
+
+ for (i = 0; i < element_count; i++) {
+ memcpy (&((*array)[i]), data, 16);
+ data += 16;
+ }
+
+ return TRUE;
}
gboolean
@@ -232,28 +378,29 @@ mxf_umid_is_zero (const MXFUMID * umid)
}
gchar *
-mxf_umid_to_string (const MXFUMID * key, gchar str[96])
+mxf_umid_to_string (const MXFUMID * umid, gchar str[96])
{
- g_return_val_if_fail (key != NULL, NULL);
+ g_return_val_if_fail (umid != NULL, NULL);
g_return_val_if_fail (str != NULL, NULL);
g_snprintf (str, 96,
"%02x.%02x.%02x.%02x.%02x.%02x.%02x.%02x.%02x.%02x.%02x.%02x.%02x.%02x.%02x.%02x."
"%02x.%02x.%02x.%02x.%02x.%02x.%02x.%02x.%02x.%02x.%02x.%02x.%02x.%02x.%02x.%02x",
- key->u[0], key->u[1], key->u[2], key->u[3], key->u[4], key->u[5],
- key->u[6], key->u[7], key->u[8], key->u[9], key->u[10], key->u[11],
- key->u[12], key->u[13], key->u[14], key->u[15],
- key->u[16],
- key->u[17],
- key->u[18],
- key->u[19],
- key->u[20],
- key->u[21],
- key->u[22],
- key->u[23],
- key->u[24],
- key->u[25],
- key->u[26], key->u[27], key->u[28], key->u[29], key->u[30], key->u[31]
+ umid->u[0], umid->u[1], umid->u[2], umid->u[3], umid->u[4], umid->u[5],
+ umid->u[6], umid->u[7], umid->u[8], umid->u[9], umid->u[10], umid->u[11],
+ umid->u[12], umid->u[13], umid->u[14], umid->u[15],
+ umid->u[16],
+ umid->u[17],
+ umid->u[18],
+ umid->u[19],
+ umid->u[20],
+ umid->u[21],
+ umid->u[22],
+ umid->u[23],
+ umid->u[24],
+ umid->u[25],
+ umid->u[26], umid->u[27], umid->u[28], umid->u[29], umid->u[30],
+ umid->u[31]
);
return str;
@@ -609,7 +756,7 @@ mxf_op_set_generalized (MXFUL * ul, MXFOperationalPattern pattern,
/* SMPTE 377M 6.1, Table 2 */
gboolean
-mxf_partition_pack_parse (const MXFUL * key, MXFPartitionPack * pack,
+mxf_partition_pack_parse (const MXFUL * ul, MXFPartitionPack * pack,
const guint8 * data, guint size)
{
#ifndef GST_DISABLE_GST_DEBUG
@@ -624,19 +771,19 @@ mxf_partition_pack_parse (const MXFUL * key, MXFPartitionPack * pack,
GST_DEBUG ("Parsing partition pack:");
- if (key->u[13] == 0x02)
+ if (ul->u[13] == 0x02)
pack->type = MXF_PARTITION_PACK_HEADER;
- else if (key->u[13] == 0x03)
+ else if (ul->u[13] == 0x03)
pack->type = MXF_PARTITION_PACK_BODY;
- else if (key->u[13] == 0x04)
+ else if (ul->u[13] == 0x04)
pack->type = MXF_PARTITION_PACK_FOOTER;
GST_DEBUG (" type = %s",
(pack->type == MXF_PARTITION_PACK_HEADER) ? "header" : (pack->type ==
MXF_PARTITION_PACK_BODY) ? "body" : "footer");
- pack->closed = (key->u[14] == 0x02 || key->u[14] == 0x04);
- pack->complete = (key->u[14] == 0x03 || key->u[14] == 0x04);
+ pack->closed = (ul->u[14] == 0x02 || ul->u[14] == 0x04);
+ pack->complete = (ul->u[14] == 0x03 || ul->u[14] == 0x04);
GST_DEBUG (" closed = %s, complete = %s", (pack->closed) ? "yes" : "no",
(pack->complete) ? "yes" : "no");
@@ -828,7 +975,7 @@ mxf_partition_pack_to_buffer (const MXFPartitionPack * pack)
/* SMPTE 377M 11.1 */
gboolean
-mxf_random_index_pack_parse (const MXFUL * key, const guint8 * data, guint size,
+mxf_random_index_pack_parse (const MXFUL * ul, const guint8 * data, guint size,
GArray ** array)
{
guint len, i;
@@ -900,7 +1047,7 @@ mxf_random_index_pack_to_buffer (const GArray * array)
/* SMPTE 377M 10.2.3 */
gboolean
-mxf_index_table_segment_parse (const MXFUL * key,
+mxf_index_table_segment_parse (const MXFUL * ul,
MXFIndexTableSegment * segment, const MXFPrimerPack * primer,
const guint8 * data, guint size)
{
@@ -910,7 +1057,7 @@ mxf_index_table_segment_parse (const MXFUL * key,
guint16 tag, tag_size;
const guint8 *tag_data;
- g_return_val_if_fail (key != NULL, FALSE);
+ g_return_val_if_fail (ul != NULL, FALSE);
g_return_val_if_fail (data != NULL, FALSE);
g_return_val_if_fail (primer != NULL, FALSE);
@@ -931,7 +1078,7 @@ mxf_index_table_segment_parse (const MXFUL * key,
goto error;
memcpy (&segment->instance_id, tag_data, 16);
GST_DEBUG (" instance id = %s",
- mxf_ul_to_string (&segment->instance_id, str));
+ mxf_uuid_to_string (&segment->instance_id, str));
break;
case 0x3f0b:
if (!mxf_fraction_parse (&segment->index_edit_rate, tag_data, tag_size))
@@ -1154,7 +1301,7 @@ _mxf_mapping_ul_free (MXFUL * ul)
}
gboolean
-mxf_primer_pack_parse (const MXFUL * key, MXFPrimerPack * pack,
+mxf_primer_pack_parse (const MXFUL * ul, MXFPrimerPack * pack,
const guint8 * data, guint size)
{
guint i;
@@ -1379,7 +1526,7 @@ mxf_local_tag_add_to_hash_table (const MXFPrimerPack * primer,
GHashTable ** hash_table)
{
MXFLocalTag *local_tag;
- MXFUL *key;
+ MXFUL *ul;
g_return_val_if_fail (primer != NULL, FALSE);
g_return_val_if_fail (tag_data != NULL, FALSE);
@@ -1394,23 +1541,23 @@ mxf_local_tag_add_to_hash_table (const MXFPrimerPack * primer,
g_return_val_if_fail (*hash_table != NULL, FALSE);
- key = (MXFUL *) g_hash_table_lookup (primer->mappings,
+ ul = (MXFUL *) g_hash_table_lookup (primer->mappings,
GUINT_TO_POINTER (((guint) tag)));
- if (key) {
+ if (ul) {
#ifndef GST_DISABLE_GST_DEBUG
gchar str[48];
#endif
GST_DEBUG ("Adding local tag 0x%04x with UL %s and size %u", tag,
- mxf_ul_to_string (key, str), tag_size);
+ mxf_ul_to_string (ul, str), tag_size);
local_tag = g_slice_new (MXFLocalTag);
- memcpy (&local_tag->key, key, sizeof (MXFUL));
+ memcpy (&local_tag->ul, ul, sizeof (MXFUL));
local_tag->size = tag_size;
local_tag->data = g_memdup (tag_data, tag_size);
- g_hash_table_insert (*hash_table, &local_tag->key, local_tag);
+ g_hash_table_insert (*hash_table, &local_tag->ul, local_tag);
} else {
GST_WARNING ("Local tag with no entry in primer pack: 0x%04x", tag);
}
@@ -1437,9 +1584,9 @@ mxf_local_tag_insert (MXFLocalTag * tag, GHashTable ** hash_table)
g_return_val_if_fail (*hash_table != NULL, FALSE);
GST_DEBUG ("Adding local tag 0x%04x with UL %s and size %u", tag,
- mxf_ul_to_string (&tag->key, str), tag->size);
+ mxf_ul_to_string (&tag->ul, str), tag->size);
- g_hash_table_insert (*hash_table, &tag->key, tag);
+ g_hash_table_insert (*hash_table, &tag->ul, tag);
return TRUE;
}