1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/netwerk/srtp/src/crypto/test/kernel_driver.c Wed Dec 31 06:09:35 2014 +0100 1.3 @@ -0,0 +1,126 @@ 1.4 +/* 1.5 + * kernel_driver.c 1.6 + * 1.7 + * a test driver for the crypto_kernel 1.8 + * 1.9 + * David A. McGrew 1.10 + * Cisco Systems, Inc. 1.11 + */ 1.12 +/* 1.13 + * 1.14 + * Copyright(c) 2001-2006 Cisco Systems, Inc. 1.15 + * All rights reserved. 1.16 + * 1.17 + * Redistribution and use in source and binary forms, with or without 1.18 + * modification, are permitted provided that the following conditions 1.19 + * are met: 1.20 + * 1.21 + * Redistributions of source code must retain the above copyright 1.22 + * notice, this list of conditions and the following disclaimer. 1.23 + * 1.24 + * Redistributions in binary form must reproduce the above 1.25 + * copyright notice, this list of conditions and the following 1.26 + * disclaimer in the documentation and/or other materials provided 1.27 + * with the distribution. 1.28 + * 1.29 + * Neither the name of the Cisco Systems, Inc. nor the names of its 1.30 + * contributors may be used to endorse or promote products derived 1.31 + * from this software without specific prior written permission. 1.32 + * 1.33 + * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 1.34 + * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 1.35 + * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS 1.36 + * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE 1.37 + * COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, 1.38 + * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES 1.39 + * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR 1.40 + * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 1.41 + * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, 1.42 + * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 1.43 + * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED 1.44 + * OF THE POSSIBILITY OF SUCH DAMAGE. 1.45 + * 1.46 + */ 1.47 + 1.48 + 1.49 +#include <stdio.h> /* for printf() */ 1.50 +#include <unistd.h> /* for getopt() */ 1.51 +#include "crypto_kernel.h" 1.52 + 1.53 +void 1.54 +usage(char *prog_name) { 1.55 + printf("usage: %s [ -v ][ -d debug_module ]*\n", prog_name); 1.56 + exit(255); 1.57 +} 1.58 + 1.59 +int 1.60 +main (int argc, char *argv[]) { 1.61 + extern char *optarg; 1.62 + int q; 1.63 + int do_validation = 0; 1.64 + err_status_t status; 1.65 + 1.66 + if (argc == 1) 1.67 + usage(argv[0]); 1.68 + 1.69 + /* initialize kernel - we need to do this before anything else */ 1.70 + status = crypto_kernel_init(); 1.71 + if (status) { 1.72 + printf("error: crypto_kernel init failed\n"); 1.73 + exit(1); 1.74 + } 1.75 + printf("crypto_kernel successfully initalized\n"); 1.76 + 1.77 + /* process input arguments */ 1.78 + while (1) { 1.79 + q = getopt(argc, argv, "vd:"); 1.80 + if (q == -1) 1.81 + break; 1.82 + switch (q) { 1.83 + case 'v': 1.84 + do_validation = 1; 1.85 + break; 1.86 + case 'd': 1.87 + status = crypto_kernel_set_debug_module(optarg, 1); 1.88 + if (status) { 1.89 + printf("error: set debug module (%s) failed\n", optarg); 1.90 + exit(1); 1.91 + } 1.92 + break; 1.93 + default: 1.94 + usage(argv[0]); 1.95 + } 1.96 + } 1.97 + 1.98 + if (do_validation) { 1.99 + printf("checking crypto_kernel status...\n"); 1.100 + status = crypto_kernel_status(); 1.101 + if (status) { 1.102 + printf("failed\n"); 1.103 + exit(1); 1.104 + } 1.105 + printf("crypto_kernel passed self-tests\n"); 1.106 + } 1.107 + 1.108 + status = crypto_kernel_shutdown(); 1.109 + if (status) { 1.110 + printf("error: crypto_kernel shutdown failed\n"); 1.111 + exit(1); 1.112 + } 1.113 + printf("crypto_kernel successfully shut down\n"); 1.114 + 1.115 + return 0; 1.116 +} 1.117 + 1.118 +/* 1.119 + * crypto_kernel_cipher_test() is a test of the cipher interface 1.120 + * of the crypto_kernel 1.121 + */ 1.122 + 1.123 +err_status_t 1.124 +crypto_kernel_cipher_test(void) { 1.125 + 1.126 + /* not implemented yet! */ 1.127 + 1.128 + return err_status_ok; 1.129 +}