Message ID | 1388245561-8751-2-git-send-email-neolynx@gmail.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Em Sat, 28 Dec 2013 16:45:50 +0100 André Roth <neolynx@gmail.com> escreveu: > Signed-off-by: André Roth <neolynx@gmail.com> > --- > lib/include/descriptors.h | 4 +- > lib/include/descriptors/desc_service_location.h | 70 +++++++++++++++++++++++ > lib/include/descriptors/vct.h | 5 +- > lib/libdvbv5/Makefile.am | 3 +- > lib/libdvbv5/descriptors.c | 2 +- > lib/libdvbv5/descriptors/desc_service_location.c | 71 ++++++++++++++++++++++++ > lib/libdvbv5/descriptors/vct.c | 1 + > lib/libdvbv5/dvb-scan.c | 12 +++- > 8 files changed, 162 insertions(+), 6 deletions(-) > create mode 100644 lib/include/descriptors/desc_service_location.h > create mode 100644 lib/libdvbv5/descriptors/desc_service_location.c > > diff --git a/lib/include/descriptors.h b/lib/include/descriptors.h > index 2e614f0..5ab29a0 100644 > --- a/lib/include/descriptors.h > +++ b/lib/include/descriptors.h > @@ -1,4 +1,4 @@ > - /* > +/* > * Copyright (c) 2011-2012 - Mauro Carvalho Chehab <mchehab@redhat.com> > * > * This program is free software; you can redistribute it and/or > @@ -216,6 +216,8 @@ enum descriptors { > /* SCTE 35 2004 */ > CUE_identifier_descriptor = 0x8a, > > + extended_channel_name = 0xa0, > + service_location = 0xa1, > /* From http://www.etherguidesystems.com/Help/SDOs/ATSC/Semantics/Descriptors/Default.aspx */ > component_name_descriptor = 0xa3, > > diff --git a/lib/include/descriptors/desc_service_location.h b/lib/include/descriptors/desc_service_location.h > new file mode 100644 > index 0000000..2e11cff > --- /dev/null > +++ b/lib/include/descriptors/desc_service_location.h > @@ -0,0 +1,70 @@ > +/* > + * Copyright (c) 2011-2012 - Mauro Carvalho Chehab <mchehab@redhat.com> I didn't wrote this code... > + * Copyright (c) 2012 - Andre Roth <neolynx@gmail.com> > + * > + * This program is free software; you can redistribute it and/or > + * modify it under the terms of the GNU General Public License > + * as published by the Free Software Foundation version 2 > + * of the License. > + * > + * This program is distributed in the hope that it will be useful, > + * but WITHOUT ANY WARRANTY; without even the implied warranty of > + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the > + * GNU General Public License for more details. > + * > + * You should have received a copy of the GNU General Public License > + * along with this program; if not, write to the Free Software > + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA > + * Or, point your browser to http://www.gnu.org/licenses/old-licenses/gpl-2.0.html > + * > + */ > + > +#ifndef _SERVICE_LOCATION_H > +#define _SERVICE_LOCATION_H > + > +#include <stdint.h> > +#include <unistd.h> /* ssize_t */ > + > +struct dvb_desc_service_location_element { > + uint8_t stream_type; > + union { > + uint16_t bitfield; > + struct { > + uint16_t elementary_pid:13; > + uint16_t reserved:3; > + }; > + }; > + uint8_t language[4]; > +} __attribute__((packed)); > + > +struct dvb_desc_service_location { > + uint8_t type; > + uint8_t length; > + struct dvb_desc *next; > + > + union { > + uint16_t bitfield; > + struct { > + uint16_t pcr_pid:13; > + uint16_t reserved:3; > + }; > + }; > + uint8_t elements; > + struct dvb_desc_service_location_element *element; > +} __attribute__((packed)); > + > +struct dvb_v5_fe_parms; > + > +#ifdef __cplusplus > +extern "C" { > +#endif > + > +void dvb_desc_service_location_init (struct dvb_v5_fe_parms *parms, const uint8_t *buf, struct dvb_desc *desc); > +void dvb_desc_service_location_print(struct dvb_v5_fe_parms *parms, const struct dvb_desc *desc); > +void dvb_desc_service_location_free (struct dvb_desc *desc); > + > +#ifdef __cplusplus > +} > +#endif > + > +#endif > diff --git a/lib/include/descriptors/vct.h b/lib/include/descriptors/vct.h > index 6272b43..505a407 100644 > --- a/lib/include/descriptors/vct.h > +++ b/lib/include/descriptors/vct.h > @@ -1,5 +1,6 @@ > /* > - * Copyright (c) 2013 - Mauro Carvalho Chehab <m.chehab@samsung.com> ...but I wrote this one. Please don't remove my copyright here. > + * Copyright (c) 2012 - Andre Roth <neolynx@gmail.com> > + * Copyright (c) 2013 - Andre Roth <neolynx@gmail.com> > * > * This program is free software; you can redistribute it and/or > * modify it under the terms of the GNU General Public License > @@ -35,7 +36,7 @@ struct dvb_table_vct_channel { > uint16_t __short_name[7]; > > union { > - uint16_t bitfield1; > + uint32_t bitfield; > struct { > uint32_t modulation_mode:8; > uint32_t minor_channel_number:10; Huh? You're adding your copyright just due to this one line trival change? > diff --git a/lib/libdvbv5/Makefile.am b/lib/libdvbv5/Makefile.am > index 2ad5902..400af39 100644 > --- a/lib/libdvbv5/Makefile.am > +++ b/lib/libdvbv5/Makefile.am > @@ -48,7 +48,8 @@ libdvbv5_la_SOURCES = \ > descriptors/nit.c ../include/descriptors/nit.h \ > descriptors/sdt.c ../include/descriptors/sdt.h \ > descriptors/vct.c ../include/descriptors/vct.h \ > - descriptors/eit.c ../include/descriptors/eit.h > + descriptors/vct.c ../include/descriptors/vct.h \ > + descriptors/desc_service_location.c ../include/descriptors/desc_service_location.h > > libdvbv5_la_CPPFLAGS = $(ENFORCE_LIBDVBV5_STATIC) > libdvbv5_la_LDFLAGS = $(LIBDVBV5_VERSION) $(ENFORCE_LIBDVBV5_STATIC) -lm > diff --git a/lib/libdvbv5/descriptors.c b/lib/libdvbv5/descriptors.c > index 5ce9241..437b2f4 100644 > --- a/lib/libdvbv5/descriptors.c > +++ b/lib/libdvbv5/descriptors.c > @@ -69,7 +69,7 @@ void dvb_desc_default_init(struct dvb_v5_fe_parms *parms, const uint8_t *buf, st > > void dvb_desc_default_print(struct dvb_v5_fe_parms *parms, const struct dvb_desc *desc) > { > - dvb_log("| %s (0x%02x)", dvb_descriptors[desc->type].name, desc->type); > + dvb_log("| %s (%#02x)", dvb_descriptors[desc->type].name, desc->type); > hexdump(parms, "| ", desc->data, desc->length); > } > > diff --git a/lib/libdvbv5/descriptors/desc_service_location.c b/lib/libdvbv5/descriptors/desc_service_location.c > new file mode 100644 > index 0000000..94c34fa > --- /dev/null > +++ b/lib/libdvbv5/descriptors/desc_service_location.c > @@ -0,0 +1,71 @@ > +/* > + * Copyright (c) 2011-2012 - Mauro Carvalho Chehab <mchehab@redhat.com> Again, I didn't write this parser. No need to add my copyright to it. > + * Copyright (c) 2012 - Andre Roth <neolynx@gmail.com> > + * > + * This program is free software; you can redistribute it and/or > + * modify it under the terms of the GNU General Public License > + * as published by the Free Software Foundation version 2 > + * of the License. > + * > + * This program is distributed in the hope that it will be useful, > + * but WITHOUT ANY WARRANTY; without even the implied warranty of > + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the > + * GNU General Public License for more details. > + * > + * You should have received a copy of the GNU General Public License > + * along with this program; if not, write to the Free Software > + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA > + * Or, point your browser to http://www.gnu.org/licenses/old-licenses/gpl-2.0.html > + * > + */ > + > +#include "descriptors/desc_service_location.h" > +#include "descriptors.h" > +#include "dvb-fe.h" > + > +void dvb_desc_service_location_init(struct dvb_v5_fe_parms *parms, const uint8_t *buf, struct dvb_desc *desc) > +{ > + struct dvb_desc_service_location *service_location = (struct dvb_desc_service_location *) desc; Please add a space here, to split data declaration from code. > + /* copy from .next */ > + memcpy(((uint8_t *) service_location ) > + + sizeof(service_location->type) > + + sizeof(service_location->length) > + + sizeof(service_location->next), > + buf, > + sizeof(service_location->bitfield) + sizeof(service_location->elements)); Before copying any data, please verify if are there enough data at the TS stream. Take a look on the patches I wrote, since I fixed several such issues already. > + buf += sizeof(service_location->bitfield) + sizeof(service_location->elements); > + > + bswap16(service_location->bitfield); > + > + // FIXME: handle elements == 0 Don't use CC99 comments. > + service_location->element = malloc(service_location->elements * sizeof(struct dvb_desc_service_location_element)); > + int i; > + struct dvb_desc_service_location_element *element = service_location->element; Please don't mix data initialization with code. Move the above to the beginning of the function. > + for(i = 0; i < service_location->elements; i++) { > + memcpy(element, buf, sizeof(struct dvb_desc_service_location_element) - 1); /* no \0 in lang */ Again, please check before copy. > + buf += sizeof(struct dvb_desc_service_location_element) - 1; > + element->language[3] = '\0'; > + bswap16(element->bitfield); > + element++; > + } > +} > + > +void dvb_desc_service_location_print(struct dvb_v5_fe_parms *parms, const struct dvb_desc *desc) > +{ > + const struct dvb_desc_service_location *service_location = (const struct dvb_desc_service_location *) desc; > + dvb_log("| pcr pid %d", service_location->pcr_pid); > + dvb_log("| streams:"); > + int i; > + struct dvb_desc_service_location_element *element = service_location->element; Don't mix code with data. > + for(i = 0; i < service_location->elements; i++) { > + dvb_log("| pid %d, type %d: %s", element[i].elementary_pid, element[i].stream_type, element[i].language); > + } > + dvb_log("| %d elements", service_location->elements); > +} > + > +void dvb_desc_service_location_free(struct dvb_desc *desc) > +{ > + const struct dvb_desc_service_location *service_location = (const struct dvb_desc_service_location *) desc; Add a blank line to split data declarations from code. > + free(service_location->element); > +} > + > diff --git a/lib/libdvbv5/descriptors/vct.c b/lib/libdvbv5/descriptors/vct.c > index e703c52..e567f7a 100644 > --- a/lib/libdvbv5/descriptors/vct.c > +++ b/lib/libdvbv5/descriptors/vct.c > @@ -1,5 +1,6 @@ > /* > * Copyright (c) 2013 - Mauro Carvalho Chehab <m.chehab@samsung.com> > + * Copyright (c) 2013 - Andre Roth <neolynx@gmail.com> > * > * This program is free software; you can redistribute it and/or > * modify it under the terms of the GNU General Public License > diff --git a/lib/libdvbv5/dvb-scan.c b/lib/libdvbv5/dvb-scan.c > index af3a052..76712d4 100644 > --- a/lib/libdvbv5/dvb-scan.c > +++ b/lib/libdvbv5/dvb-scan.c > @@ -185,6 +185,15 @@ int dvb_read_section_with_id(struct dvb_v5_fe_parms *parms, int dmx_fd, > > h = (struct dvb_table_header *)buf; > dvb_table_header_init(h); > + > + /* dvb_logdbg( "dvb_read_section: id %d, section %d/%d, current: %d", h->id, h->section_id, h->last_section, h->current_next ); */ Why to add a commented line? > + if (start_id == h->id && start_section == h->section_id) { > + dvb_logdbg( "dvb_read_section: section repeated, reading done" ); > + break; > + } > + if (start_id == -1) start_id = h->id; > + if (start_section == -1) start_section = h->section_id; > + > if (id != -1 && h->id != id) { /* search for a specific table id */ > continue; > } Hmm... you're re-adding the code you've removed on patch 01? Please don't mix ATSC VCT descriptors with this changeset. > @@ -232,7 +241,8 @@ int dvb_read_section_with_id(struct dvb_v5_fe_parms *parms, int dmx_fd, > else > dvb_logerr("dvb_read_section: no initializer for table %d", tid); > > - if (++sections == last_section + 1) > + if (id != -1 && ++sections == last_section + 1) { > + dvb_logerr("dvb_read_section: ++sections == last_section + 1"); Same here: don't mix duplicate section fixups with the ATSC VCT descriptor patch. > break; > } > free(buf);
diff --git a/lib/include/descriptors.h b/lib/include/descriptors.h index 2e614f0..5ab29a0 100644 --- a/lib/include/descriptors.h +++ b/lib/include/descriptors.h @@ -1,4 +1,4 @@ - /* +/* * Copyright (c) 2011-2012 - Mauro Carvalho Chehab <mchehab@redhat.com> * * This program is free software; you can redistribute it and/or @@ -216,6 +216,8 @@ enum descriptors { /* SCTE 35 2004 */ CUE_identifier_descriptor = 0x8a, + extended_channel_name = 0xa0, + service_location = 0xa1, /* From http://www.etherguidesystems.com/Help/SDOs/ATSC/Semantics/Descriptors/Default.aspx */ component_name_descriptor = 0xa3, diff --git a/lib/include/descriptors/desc_service_location.h b/lib/include/descriptors/desc_service_location.h new file mode 100644 index 0000000..2e11cff --- /dev/null +++ b/lib/include/descriptors/desc_service_location.h @@ -0,0 +1,70 @@ +/* + * Copyright (c) 2011-2012 - Mauro Carvalho Chehab <mchehab@redhat.com> + * Copyright (c) 2012 - Andre Roth <neolynx@gmail.com> + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation version 2 + * of the License. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + * Or, point your browser to http://www.gnu.org/licenses/old-licenses/gpl-2.0.html + * + */ + +#ifndef _SERVICE_LOCATION_H +#define _SERVICE_LOCATION_H + +#include <stdint.h> +#include <unistd.h> /* ssize_t */ + +struct dvb_desc_service_location_element { + uint8_t stream_type; + union { + uint16_t bitfield; + struct { + uint16_t elementary_pid:13; + uint16_t reserved:3; + }; + }; + uint8_t language[4]; +} __attribute__((packed)); + +struct dvb_desc_service_location { + uint8_t type; + uint8_t length; + struct dvb_desc *next; + + union { + uint16_t bitfield; + struct { + uint16_t pcr_pid:13; + uint16_t reserved:3; + }; + }; + uint8_t elements; + struct dvb_desc_service_location_element *element; +} __attribute__((packed)); + +struct dvb_v5_fe_parms; + +#ifdef __cplusplus +extern "C" { +#endif + +void dvb_desc_service_location_init (struct dvb_v5_fe_parms *parms, const uint8_t *buf, struct dvb_desc *desc); +void dvb_desc_service_location_print(struct dvb_v5_fe_parms *parms, const struct dvb_desc *desc); +void dvb_desc_service_location_free (struct dvb_desc *desc); + +#ifdef __cplusplus +} +#endif + +#endif diff --git a/lib/include/descriptors/vct.h b/lib/include/descriptors/vct.h index 6272b43..505a407 100644 --- a/lib/include/descriptors/vct.h +++ b/lib/include/descriptors/vct.h @@ -1,5 +1,6 @@ /* - * Copyright (c) 2013 - Mauro Carvalho Chehab <m.chehab@samsung.com> + * Copyright (c) 2012 - Andre Roth <neolynx@gmail.com> + * Copyright (c) 2013 - Andre Roth <neolynx@gmail.com> * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License @@ -35,7 +36,7 @@ struct dvb_table_vct_channel { uint16_t __short_name[7]; union { - uint16_t bitfield1; + uint32_t bitfield; struct { uint32_t modulation_mode:8; uint32_t minor_channel_number:10; diff --git a/lib/libdvbv5/Makefile.am b/lib/libdvbv5/Makefile.am index 2ad5902..400af39 100644 --- a/lib/libdvbv5/Makefile.am +++ b/lib/libdvbv5/Makefile.am @@ -48,7 +48,8 @@ libdvbv5_la_SOURCES = \ descriptors/nit.c ../include/descriptors/nit.h \ descriptors/sdt.c ../include/descriptors/sdt.h \ descriptors/vct.c ../include/descriptors/vct.h \ - descriptors/eit.c ../include/descriptors/eit.h + descriptors/vct.c ../include/descriptors/vct.h \ + descriptors/desc_service_location.c ../include/descriptors/desc_service_location.h libdvbv5_la_CPPFLAGS = $(ENFORCE_LIBDVBV5_STATIC) libdvbv5_la_LDFLAGS = $(LIBDVBV5_VERSION) $(ENFORCE_LIBDVBV5_STATIC) -lm diff --git a/lib/libdvbv5/descriptors.c b/lib/libdvbv5/descriptors.c index 5ce9241..437b2f4 100644 --- a/lib/libdvbv5/descriptors.c +++ b/lib/libdvbv5/descriptors.c @@ -69,7 +69,7 @@ void dvb_desc_default_init(struct dvb_v5_fe_parms *parms, const uint8_t *buf, st void dvb_desc_default_print(struct dvb_v5_fe_parms *parms, const struct dvb_desc *desc) { - dvb_log("| %s (0x%02x)", dvb_descriptors[desc->type].name, desc->type); + dvb_log("| %s (%#02x)", dvb_descriptors[desc->type].name, desc->type); hexdump(parms, "| ", desc->data, desc->length); } diff --git a/lib/libdvbv5/descriptors/desc_service_location.c b/lib/libdvbv5/descriptors/desc_service_location.c new file mode 100644 index 0000000..94c34fa --- /dev/null +++ b/lib/libdvbv5/descriptors/desc_service_location.c @@ -0,0 +1,71 @@ +/* + * Copyright (c) 2011-2012 - Mauro Carvalho Chehab <mchehab@redhat.com> + * Copyright (c) 2012 - Andre Roth <neolynx@gmail.com> + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation version 2 + * of the License. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + * Or, point your browser to http://www.gnu.org/licenses/old-licenses/gpl-2.0.html + * + */ + +#include "descriptors/desc_service_location.h" +#include "descriptors.h" +#include "dvb-fe.h" + +void dvb_desc_service_location_init(struct dvb_v5_fe_parms *parms, const uint8_t *buf, struct dvb_desc *desc) +{ + struct dvb_desc_service_location *service_location = (struct dvb_desc_service_location *) desc; + /* copy from .next */ + memcpy(((uint8_t *) service_location ) + + sizeof(service_location->type) + + sizeof(service_location->length) + + sizeof(service_location->next), + buf, + sizeof(service_location->bitfield) + sizeof(service_location->elements)); + buf += sizeof(service_location->bitfield) + sizeof(service_location->elements); + + bswap16(service_location->bitfield); + + // FIXME: handle elements == 0 + service_location->element = malloc(service_location->elements * sizeof(struct dvb_desc_service_location_element)); + int i; + struct dvb_desc_service_location_element *element = service_location->element; + for(i = 0; i < service_location->elements; i++) { + memcpy(element, buf, sizeof(struct dvb_desc_service_location_element) - 1); /* no \0 in lang */ + buf += sizeof(struct dvb_desc_service_location_element) - 1; + element->language[3] = '\0'; + bswap16(element->bitfield); + element++; + } +} + +void dvb_desc_service_location_print(struct dvb_v5_fe_parms *parms, const struct dvb_desc *desc) +{ + const struct dvb_desc_service_location *service_location = (const struct dvb_desc_service_location *) desc; + dvb_log("| pcr pid %d", service_location->pcr_pid); + dvb_log("| streams:"); + int i; + struct dvb_desc_service_location_element *element = service_location->element; + for(i = 0; i < service_location->elements; i++) { + dvb_log("| pid %d, type %d: %s", element[i].elementary_pid, element[i].stream_type, element[i].language); + } + dvb_log("| %d elements", service_location->elements); +} + +void dvb_desc_service_location_free(struct dvb_desc *desc) +{ + const struct dvb_desc_service_location *service_location = (const struct dvb_desc_service_location *) desc; + free(service_location->element); +} + diff --git a/lib/libdvbv5/descriptors/vct.c b/lib/libdvbv5/descriptors/vct.c index e703c52..e567f7a 100644 --- a/lib/libdvbv5/descriptors/vct.c +++ b/lib/libdvbv5/descriptors/vct.c @@ -1,5 +1,6 @@ /* * Copyright (c) 2013 - Mauro Carvalho Chehab <m.chehab@samsung.com> + * Copyright (c) 2013 - Andre Roth <neolynx@gmail.com> * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License diff --git a/lib/libdvbv5/dvb-scan.c b/lib/libdvbv5/dvb-scan.c index af3a052..76712d4 100644 --- a/lib/libdvbv5/dvb-scan.c +++ b/lib/libdvbv5/dvb-scan.c @@ -185,6 +185,15 @@ int dvb_read_section_with_id(struct dvb_v5_fe_parms *parms, int dmx_fd, h = (struct dvb_table_header *)buf; dvb_table_header_init(h); + + /* dvb_logdbg( "dvb_read_section: id %d, section %d/%d, current: %d", h->id, h->section_id, h->last_section, h->current_next ); */ + if (start_id == h->id && start_section == h->section_id) { + dvb_logdbg( "dvb_read_section: section repeated, reading done" ); + break; + } + if (start_id == -1) start_id = h->id; + if (start_section == -1) start_section = h->section_id; + if (id != -1 && h->id != id) { /* search for a specific table id */ continue; } @@ -232,7 +241,8 @@ int dvb_read_section_with_id(struct dvb_v5_fe_parms *parms, int dmx_fd, else dvb_logerr("dvb_read_section: no initializer for table %d", tid); - if (++sections == last_section + 1) + if (id != -1 && ++sections == last_section + 1) { + dvb_logerr("dvb_read_section: ++sections == last_section + 1"); break; } free(buf);
Signed-off-by: André Roth <neolynx@gmail.com> --- lib/include/descriptors.h | 4 +- lib/include/descriptors/desc_service_location.h | 70 +++++++++++++++++++++++ lib/include/descriptors/vct.h | 5 +- lib/libdvbv5/Makefile.am | 3 +- lib/libdvbv5/descriptors.c | 2 +- lib/libdvbv5/descriptors/desc_service_location.c | 71 ++++++++++++++++++++++++ lib/libdvbv5/descriptors/vct.c | 1 + lib/libdvbv5/dvb-scan.c | 12 +++- 8 files changed, 162 insertions(+), 6 deletions(-) create mode 100644 lib/include/descriptors/desc_service_location.h create mode 100644 lib/libdvbv5/descriptors/desc_service_location.c