1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
|
/*
This file is part of libdvbcsa.
libdvbcsa 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; either version 2 of the License, or
(at your option) any later version.
libdvbcsa 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 libdvbcsa; if not, write to the Free Software Foundation,
Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
(c) 2011 Erik Tews <e_tews at cdc.informatik.tu-darmstadt.de>
*/
#include <time.h>
#include <stdio.h>
#include <sys/time.h>
#include <dvbcsa/dvbcsa.h>
#include "dvbcsa_pv.h"
#ifdef __linux__
#include <sched.h>
#endif
#ifdef HAVE_ASSERT_H
#include <assert.h>
#endif
#define KEYS 5000000
int
main (void)
{
struct dvbcsa_bs_key_s *ffkey = dvbcsa_bs_key_alloc();
unsigned int i;
uint8_t cw[8] = {0, 0, 0, 0, 0, 0, 0, 0};
struct timeval t0, t1;
#ifdef HAVE_ASSERT_H
assert(ffkey != NULL);
#endif
#ifdef __linux__
struct sched_param sp = { .sched_priority = 1 };
sched_setscheduler (0, SCHED_FIFO, &sp);
#endif
printf("* DVBCSA keysetup benchmark *\n");
gettimeofday(&t0, NULL);
for (i = 0; i < KEYS; i++) {
cw[0] = i;
cw[1] = i>>8;
cw[2] = i>>16;
cw[3] = i>>24;
dvbcsa_bs_key_set (cw, ffkey);
}
gettimeofday(&t1, NULL);
printf(" - %u keys proceded, %.1f Mkeys/s\n\n", KEYS,
(float)(KEYS) / (float)((t1.tv_sec * 1000000 + t1.tv_usec) - (t0.tv_sec * 1000000 + t0.tv_usec))
);
dvbcsa_bs_key_free(ffkey);
return (0);
}
|