123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 |
- /*
- * CSA functions
- * Copyright (C) 2011-2012 Unix Solutions Ltd.
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2
- * as published by the Free Software Foundation.
- *
- * 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.
- */
-
- #include <stdio.h>
- #include <stdlib.h>
- #include <string.h>
- #include <inttypes.h>
- #include <sys/time.h>
-
- #include "libfuncs/libfuncs.h"
-
- #include "csa.h"
-
- csakey_t *csa_key_alloc(void) {
- struct csakey *key = calloc(1, sizeof(struct csakey));
- key->s_csakey[0] = dvbcsa_key_alloc();
- key->s_csakey[1] = dvbcsa_key_alloc();
- key->bs_csakey[0] = dvbcsa_bs_key_alloc();
- key->bs_csakey[1] = dvbcsa_bs_key_alloc();
- return (csakey_t *)key;
- }
-
- void csa_key_free(csakey_t **pcsakey) {
- struct csakey *key = *((struct csakey **)pcsakey);
- if (key) {
- dvbcsa_key_free(key->s_csakey[0]);
- dvbcsa_key_free(key->s_csakey[1]);
- dvbcsa_bs_key_free(key->bs_csakey[0]);
- dvbcsa_bs_key_free(key->bs_csakey[1]);
- FREE(*pcsakey);
- }
- }
-
- inline unsigned int csa_get_batch_size(void) {
- if (use_dvbcsa) {
- return dvbcsa_bs_batch_size(); // 32?
- }
- return 0;
- }
-
- inline void csa_set_even_cw(csakey_t *csakey, uint8_t *even_cw) {
- struct csakey *key = (struct csakey *)csakey;
- dvbcsa_key_set(even_cw, key->s_csakey[0]);
- dvbcsa_bs_key_set(even_cw, key->bs_csakey[0]);
- }
-
- inline void csa_set_odd_cw(csakey_t *csakey, uint8_t *odd_cw) {
- struct csakey *key = (struct csakey *)csakey;
- dvbcsa_key_set(odd_cw, key->s_csakey[1]);
- dvbcsa_bs_key_set(odd_cw, key->bs_csakey[1]);
- }
-
- inline void csa_decrypt_single_packet(csakey_t *csakey, uint8_t *ts_packet) {
- struct csakey *key = (struct csakey *)csakey;
- if (use_dvbcsa) {
- unsigned int key_idx = ts_packet_get_scrambled(ts_packet) - 2;
- unsigned int payload_offset = ts_packet_get_payload_offset(ts_packet);
- ts_packet_set_not_scrambled(ts_packet);
- dvbcsa_decrypt(key->s_csakey[key_idx], ts_packet + payload_offset, 188 - payload_offset);
- }
- }
-
- inline void csa_decrypt_multiple_even(csakey_t *csakey, struct csa_batch *batch) {
- struct csakey *key = (struct csakey *)csakey;
- dvbcsa_bs_decrypt(key->bs_csakey[0], (struct dvbcsa_bs_batch_s *)batch, 184);
- }
-
- inline void csa_decrypt_multiple_odd(csakey_t *csakey, struct csa_batch *batch) {
- struct csakey *key = (struct csakey *)csakey;
- dvbcsa_bs_decrypt(key->bs_csakey[1], (struct dvbcsa_bs_batch_s *)batch, 184);
- }
-
- /* The following routine is taken from benchbitslice in libdvbcsa */
- void csa_benchmark(void) {
- struct timeval t0, t1;
- struct dvbcsa_bs_key_s *key = dvbcsa_bs_key_alloc();
- unsigned int n, i, npackets = 0;
- unsigned int batch_size = dvbcsa_bs_batch_size();
- uint8_t data[batch_size + 1][188];
- struct dvbcsa_bs_batch_s pcks[batch_size + 1];
- uint8_t cw[8] = { 0x12, 0x34, 0x56, 0x78, 0x89, 0xab, 0xcd, 0xef, };
-
- srand(time(0));
- puts("Single threaded CSA decoding benchmark");
-
- dvbcsa_bs_key_set (cw, key);
-
- printf("Batch size %d packets.\n\n", batch_size);
- for (i = 0; i < batch_size; i++) {
- pcks[i].data = data[i];
- pcks[i].len = 184;
- memset(data[i], rand(), pcks[i].len);
- }
- pcks[i].data = NULL;
-
- gettimeofday(&t0, NULL);
- for (n = (1 << 12) / batch_size; n < (1 << 19) / batch_size; n *= 2) {
- printf(" Decrypting %6u mpegts packets\r", n * batch_size);
- fflush(stdout);
- for (i = 0; i < n; i++) {
- dvbcsa_bs_decrypt(key, pcks, 184);
- }
- npackets += n * batch_size;
- }
- gettimeofday(&t1, NULL);
-
- unsigned long long usec = timeval_diff_usec(&t0, &t1);
- printf("DONE: %u packets (%u bytes) decrypted in %llu ms = %.1f Mbits/s\n\n",
- npackets,
- npackets * 188,
- usec / 1000,
- (double)(npackets * 188 * 8) / (double)usec
- );
-
- dvbcsa_bs_key_free(key);
- }
|