--- /dev/null
+/*
+ * Copyright (c) 2013 - Mauro Carvalho Chehab <m.chehab@samsung.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
+ *
+ * Based on ETSI EN 300 468 V1.11.1 (2010-04)
+ */
+
+#ifndef _T2_DELIVERY_H
+#define _T2_DELIVERY_H
+
+#include <stdint.h>
+#include <unistd.h> /* ssize_t */
+
+struct dvb_desc_t2_delivery_subcell {
+ uint8_t cell_id_extension;
+ uint16_t transposer_frequency;
+} __attribute__((packed));
+
+struct dvb_desc_t2_delivery {
+ uint8_t type;
+ uint8_t length;
+ struct dvb_desc *next;
+
+ uint32_t *centre_frequency;
+ uint8_t frequency_loop_length;
+ uint8_t subcel_info_loop_length;
+ struct dvb_desc_t2_delivery_subcell *subcell;
+
+ uint8_t descriptor_tag_extension;
+ uint8_t plp_id;
+ uint16_t system_id;
+ union {
+ uint16_t bitfield;
+ struct {
+ uint16_t tfs_flag:1;
+ uint16_t other_frequency_flag:1;
+ uint16_t transmission_mode:3;
+ uint16_t guard_interval:3;
+ uint16_t reserved:2;
+ uint16_t bandwidth:3;
+ uint16_t SISO_MISO:2;
+ };
+ };
+} __attribute__((packed));
+
+struct dvb_v5_fe_parms;
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+void dvb_desc_t2_delivery_init (struct dvb_v5_fe_parms *parms, const uint8_t *buf, struct dvb_desc *desc);
+void dvb_desc_t2_delivery_print(struct dvb_v5_fe_parms *parms, const struct dvb_desc *desc);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif
--- /dev/null
+/*
+ * Copyright (c) 2013 - Mauro Carvalho Chehab <m.chehab@samsung.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
+ *
+ * Based on ETSI EN 300 468 V1.11.1 (2010-04)
+ */
+
+#include "descriptors/desc_t2_delivery.h"
+#include "descriptors.h"
+#include "dvb-fe.h"
+
+void dvb_desc_t2_delivery_init(struct dvb_v5_fe_parms *parms, const uint8_t *buf, struct dvb_desc *desc)
+{
+ struct dvb_desc_t2_delivery *d = (struct dvb_desc_t2_delivery *) desc;
+ unsigned char *p = (unsigned char *) buf;
+ size_t len;
+ int i;
+
+ len = sizeof(*d) - offsetof(struct dvb_desc_t2_delivery, centre_frequency);
+ memcpy(&d->centre_frequency, p, len);
+ p += len;
+
+ bswap16(d->system_id);
+
+ if (d->length <= 4)
+ return;
+
+ bswap16(d->bitfield);
+
+ if (d->tfs_flag)
+ d->frequency_loop_length = 1;
+ else {
+ d->frequency_loop_length = *p;
+ p++;
+ }
+
+ d->centre_frequency = malloc(sizeof(*d->centre_frequency) * d->frequency_loop_length);
+ if (!d->centre_frequency)
+ dvb_perror("Out of memory");
+
+ memcpy(d->centre_frequency, p, sizeof(*d->centre_frequency) * d->frequency_loop_length);
+ p += sizeof(*d->centre_frequency) * d->frequency_loop_length;
+
+ for (i = 0; i < d->frequency_loop_length; i++)
+ bswap32(d->centre_frequency[i]);
+
+ d->subcel_info_loop_length = *p;
+ p++;
+
+ d->subcell = malloc(sizeof(*d->subcell) * d->subcel_info_loop_length);
+ if (!d->subcell)
+ dvb_perror("Out of memory");
+ memcpy(d->subcell, p, sizeof(*d->subcell) * d->subcel_info_loop_length);
+
+ for (i = 0; i < d->subcel_info_loop_length; i++)
+ bswap16(d->subcell[i].transposer_frequency);
+}
+
+void dvb_desc_t2_delivery_print(struct dvb_v5_fe_parms *parms, const struct dvb_desc *desc)
+{
+ const struct dvb_desc_t2_delivery *d = (const struct dvb_desc_t2_delivery *) desc;
+ int i;
+
+ dvb_log("| t2 delivery");
+ dvb_log("| descriptor_tag_extension %d", d->descriptor_tag_extension);
+ dvb_log("| plp_id %d", d->plp_id);
+ dvb_log("| system_id %d", d->system_id);
+
+ if (d->length <= 4)
+ return;
+
+ dvb_log("| tfs_flag %d", d->tfs_flag);
+ dvb_log("| other_frequency_flag %d", d->other_frequency_flag);
+ dvb_log("| transmission_mode %d", d->transmission_mode);
+ dvb_log("| guard_interval %d", d->guard_interval);
+ dvb_log("| reserved %d", d->reserved);
+ dvb_log("| bandwidth %d", d->bandwidth);
+ dvb_log("| SISO MISO %d", d->SISO_MISO);
+
+ for (i = 0; i < d->frequency_loop_length; i++)
+ dvb_log("| centre frequency[%d] %d", i, d->centre_frequency[i]);
+
+ for (i = 0; i < d->subcel_info_loop_length; i++) {
+ dvb_log("| cell_id_extension[%d] %d", i, d->subcell[i].cell_id_extension);
+ dvb_log("| transposer frequency %d", d->subcell[i].transposer_frequency);
+ }
+}