Commit ab92287b authored by Georgi Chorbadzhiyski's avatar Georgi Chorbadzhiyski

dvb/si: Complete support for descriptor 0x5f (Private data specifier).

Add missing desc5f_set_specifier() function and also print the specifier
as hex.
parent f7c66da1
...@@ -4,6 +4,7 @@ ...@@ -4,6 +4,7 @@
* Copyright (C) 2009-2010 VideoLAN * Copyright (C) 2009-2010 VideoLAN
* *
* Authors: Christophe Massiot <massiot@via.ecp.fr> * Authors: Christophe Massiot <massiot@via.ecp.fr>
* Georgi Chorbadzhiyski <georgi@unixsol.org>
* *
* Permission is hereby granted, free of charge, to any person obtaining * Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the * a copy of this software and associated documentation files (the
...@@ -49,6 +50,7 @@ extern "C" ...@@ -49,6 +50,7 @@ extern "C"
static inline void desc5f_init(uint8_t *p_desc) static inline void desc5f_init(uint8_t *p_desc)
{ {
desc_set_tag(p_desc, 0x5f); desc_set_tag(p_desc, 0x5f);
desc_set_length(p_desc, DESC5F_HEADER_SIZE - DESC_HEADER_SIZE);
} }
static inline uint32_t desc5f_get_specifier(const uint8_t *p_desc) static inline uint32_t desc5f_get_specifier(const uint8_t *p_desc)
...@@ -57,6 +59,14 @@ static inline uint32_t desc5f_get_specifier(const uint8_t *p_desc) ...@@ -57,6 +59,14 @@ static inline uint32_t desc5f_get_specifier(const uint8_t *p_desc)
(p_desc[4] << 8) | p_desc[5]; (p_desc[4] << 8) | p_desc[5];
} }
static inline void desc5f_set_specifier(uint8_t *p_desc, uint32_t i_specifier)
{
p_desc[2] = (i_specifier >> 24) & 0xff;
p_desc[3] = (i_specifier >> 16) & 0xff;
p_desc[4] = (i_specifier >> 8) & 0xff;
p_desc[5] = i_specifier & 0xff;
}
static inline bool desc5f_validate(const uint8_t *p_desc) static inline bool desc5f_validate(const uint8_t *p_desc)
{ {
return desc_get_length(p_desc) >= DESC5F_HEADER_SIZE - DESC_HEADER_SIZE; return desc_get_length(p_desc) >= DESC5F_HEADER_SIZE - DESC_HEADER_SIZE;
...@@ -67,11 +77,11 @@ static inline void desc5f_print(const uint8_t *p_desc, f_print pf_print, ...@@ -67,11 +77,11 @@ static inline void desc5f_print(const uint8_t *p_desc, f_print pf_print,
{ {
switch (i_print_type) { switch (i_print_type) {
case PRINT_XML: case PRINT_XML:
pf_print(opaque, "<PRIVATE_DATA_SPECIFIER_DESC specifier=\"%u\" />", pf_print(opaque, "<PRIVATE_DATA_SPECIFIER_DESC specifier=\"0x%08x\" />",
desc5f_get_specifier(p_desc)); desc5f_get_specifier(p_desc));
break; break;
default: default:
pf_print(opaque, " - desc 5f private data specifier=%u", pf_print(opaque, " - desc 5f private_data specifier=0x%08x",
desc5f_get_specifier(p_desc)); desc5f_get_specifier(p_desc));
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment