00001 // This file is part of MOS, the MANTIS Operating System 00002 // See http://mantis.cs.colorado.edu/ 00003 // 00004 // Copyright (c) 2002 - 2007 University of Colorado, Boulder 00005 // 00006 // All rights reserved. 00007 // 00008 // Redistribution and use in source and binary forms, with or without 00009 // modification, are permitted provided that the following conditions are 00010 // met: 00011 // 00012 // * Redistributions of source code must retain the above copyright 00013 // notice, this list of conditions and the following disclaimer. 00014 // * Redistributions in binary form must reproduce the above 00015 // copyright notice, this list of conditions and the following 00016 // disclaimer in the documentation and/or other materials provided 00017 // with the distribution. 00018 // * Neither the name of the MANTIS Project nor the names of its 00019 // contributors may be used to endorse or promote products derived 00020 // from this software without specific prior written permission. 00021 // 00022 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS 00023 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT 00024 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR 00025 // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT 00026 // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, 00027 // INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 00028 // BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; 00029 // LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER 00030 // CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 00031 // LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN 00032 // ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 00033 // POSSIBILITY OF SUCH DAMAGE. 00034 00035 #include <inttypes.h> 00036 00037 #define RC5_ROUNDS 12 00038 #define RC5_KEYSPACES ((2 * RC5_ROUNDS) + 2) 00039 00042 typedef struct _rc5key_info { 00044 int rounds; 00046 uint32_t vector[RC5_KEYSPACES]; 00047 } rc5key_info; 00048 00054 void rc5_key_setup(uint8_t *key, int dummy, rc5key_info *key_info); 00062 void rc5_encrypt(uint32_t *in, uint32_t *out, rc5key_info *key_info); 00070 void rc5_decrypt(const uint32_t *in, uint32_t *out, rc5key_info *key_info); 00078 void block_encrypt(const uint8_t *plt, uint8_t *enc, int size, 00079 uint8_t *iv, rc5key_info *key_info); 00087 void block_decrypt(const uint8_t *enc, uint8_t *dec, int size, 00088 uint8_t *iv, rc5key_info *key_info); 00097 void block_mac(const uint8_t *plt, int size, uint8_t *mac, int mac_size, 00098 uint8_t *iv, rc5key_info *key_info); 00099
1.4.6