Fork of CyaSSL for my specific settings

Dependents:   CyaSSL_Example

Fork of CyaSSL by wolf SSL

Committer:
wolfSSL
Date:
Sat Jul 12 07:18:23 2014 +0000
Revision:
0:1239e9b70ca2
CyaSSL 3.0.0;

Who changed what in which revision?

UserRevisionLine numberNew contents of line
wolfSSL 0:1239e9b70ca2 1 /* misc.c
wolfSSL 0:1239e9b70ca2 2 *
wolfSSL 0:1239e9b70ca2 3 * Copyright (C) 2006-2014 wolfSSL Inc.
wolfSSL 0:1239e9b70ca2 4 *
wolfSSL 0:1239e9b70ca2 5 * This file is part of CyaSSL.
wolfSSL 0:1239e9b70ca2 6 *
wolfSSL 0:1239e9b70ca2 7 * CyaSSL is free software; you can redistribute it and/or modify
wolfSSL 0:1239e9b70ca2 8 * it under the terms of the GNU General Public License as published by
wolfSSL 0:1239e9b70ca2 9 * the Free Software Foundation; either version 2 of the License, or
wolfSSL 0:1239e9b70ca2 10 * (at your option) any later version.
wolfSSL 0:1239e9b70ca2 11 *
wolfSSL 0:1239e9b70ca2 12 * CyaSSL is distributed in the hope that it will be useful,
wolfSSL 0:1239e9b70ca2 13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
wolfSSL 0:1239e9b70ca2 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
wolfSSL 0:1239e9b70ca2 15 * GNU General Public License for more details.
wolfSSL 0:1239e9b70ca2 16 *
wolfSSL 0:1239e9b70ca2 17 * You should have received a copy of the GNU General Public License
wolfSSL 0:1239e9b70ca2 18 * along with this program; if not, write to the Free Software
wolfSSL 0:1239e9b70ca2 19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
wolfSSL 0:1239e9b70ca2 20 */
wolfSSL 0:1239e9b70ca2 21
wolfSSL 0:1239e9b70ca2 22 #ifdef HAVE_CONFIG_H
wolfSSL 0:1239e9b70ca2 23 #include <config.h>
wolfSSL 0:1239e9b70ca2 24 #endif
wolfSSL 0:1239e9b70ca2 25
wolfSSL 0:1239e9b70ca2 26 #include <cyassl/ctaocrypt/settings.h>
wolfSSL 0:1239e9b70ca2 27
wolfSSL 0:1239e9b70ca2 28 #include <cyassl/ctaocrypt/misc.h>
wolfSSL 0:1239e9b70ca2 29
wolfSSL 0:1239e9b70ca2 30 /* inlining these functions is a huge speed increase and a small size decrease,
wolfSSL 0:1239e9b70ca2 31 because the functions are smaller than function call setup/cleanup, e.g.,
wolfSSL 0:1239e9b70ca2 32 md5 benchmark is twice as fast with inline. If you don't want it, then
wolfSSL 0:1239e9b70ca2 33 define NO_INLINE and compile this file into cyassl, otherwise it's used as
wolfSSL 0:1239e9b70ca2 34 a source header
wolfSSL 0:1239e9b70ca2 35 */
wolfSSL 0:1239e9b70ca2 36
wolfSSL 0:1239e9b70ca2 37 #ifdef NO_INLINE
wolfSSL 0:1239e9b70ca2 38 #define STATIC
wolfSSL 0:1239e9b70ca2 39 #else
wolfSSL 0:1239e9b70ca2 40 #define STATIC static
wolfSSL 0:1239e9b70ca2 41 #endif
wolfSSL 0:1239e9b70ca2 42
wolfSSL 0:1239e9b70ca2 43
wolfSSL 0:1239e9b70ca2 44 #ifdef INTEL_INTRINSICS
wolfSSL 0:1239e9b70ca2 45
wolfSSL 0:1239e9b70ca2 46 #include <stdlib.h> /* get intrinsic definitions */
wolfSSL 0:1239e9b70ca2 47
wolfSSL 0:1239e9b70ca2 48 #pragma intrinsic(_lrotl, _lrotr)
wolfSSL 0:1239e9b70ca2 49
wolfSSL 0:1239e9b70ca2 50 STATIC INLINE word32 rotlFixed(word32 x, word32 y)
wolfSSL 0:1239e9b70ca2 51 {
wolfSSL 0:1239e9b70ca2 52 return y ? _lrotl(x, y) : x;
wolfSSL 0:1239e9b70ca2 53 }
wolfSSL 0:1239e9b70ca2 54
wolfSSL 0:1239e9b70ca2 55 STATIC INLINE word32 rotrFixed(word32 x, word32 y)
wolfSSL 0:1239e9b70ca2 56 {
wolfSSL 0:1239e9b70ca2 57 return y ? _lrotr(x, y) : x;
wolfSSL 0:1239e9b70ca2 58 }
wolfSSL 0:1239e9b70ca2 59
wolfSSL 0:1239e9b70ca2 60 #else /* generic */
wolfSSL 0:1239e9b70ca2 61
wolfSSL 0:1239e9b70ca2 62 STATIC INLINE word32 rotlFixed(word32 x, word32 y)
wolfSSL 0:1239e9b70ca2 63 {
wolfSSL 0:1239e9b70ca2 64 return (x << y) | (x >> (sizeof(y) * 8 - y));
wolfSSL 0:1239e9b70ca2 65 }
wolfSSL 0:1239e9b70ca2 66
wolfSSL 0:1239e9b70ca2 67
wolfSSL 0:1239e9b70ca2 68 STATIC INLINE word32 rotrFixed(word32 x, word32 y)
wolfSSL 0:1239e9b70ca2 69 {
wolfSSL 0:1239e9b70ca2 70 return (x >> y) | (x << (sizeof(y) * 8 - y));
wolfSSL 0:1239e9b70ca2 71 }
wolfSSL 0:1239e9b70ca2 72
wolfSSL 0:1239e9b70ca2 73 #endif
wolfSSL 0:1239e9b70ca2 74
wolfSSL 0:1239e9b70ca2 75
wolfSSL 0:1239e9b70ca2 76 STATIC INLINE word32 ByteReverseWord32(word32 value)
wolfSSL 0:1239e9b70ca2 77 {
wolfSSL 0:1239e9b70ca2 78 #ifdef PPC_INTRINSICS
wolfSSL 0:1239e9b70ca2 79 /* PPC: load reverse indexed instruction */
wolfSSL 0:1239e9b70ca2 80 return (word32)__lwbrx(&value,0);
wolfSSL 0:1239e9b70ca2 81 #elif defined(KEIL_INTRINSICS)
wolfSSL 0:1239e9b70ca2 82 return (word32)__rev(value);
wolfSSL 0:1239e9b70ca2 83 #elif defined(FAST_ROTATE)
wolfSSL 0:1239e9b70ca2 84 /* 5 instructions with rotate instruction, 9 without */
wolfSSL 0:1239e9b70ca2 85 return (rotrFixed(value, 8U) & 0xff00ff00) |
wolfSSL 0:1239e9b70ca2 86 (rotlFixed(value, 8U) & 0x00ff00ff);
wolfSSL 0:1239e9b70ca2 87 #else
wolfSSL 0:1239e9b70ca2 88 /* 6 instructions with rotate instruction, 8 without */
wolfSSL 0:1239e9b70ca2 89 value = ((value & 0xFF00FF00) >> 8) | ((value & 0x00FF00FF) << 8);
wolfSSL 0:1239e9b70ca2 90 return rotlFixed(value, 16U);
wolfSSL 0:1239e9b70ca2 91 #endif
wolfSSL 0:1239e9b70ca2 92 }
wolfSSL 0:1239e9b70ca2 93
wolfSSL 0:1239e9b70ca2 94
wolfSSL 0:1239e9b70ca2 95 STATIC INLINE void ByteReverseWords(word32* out, const word32* in,
wolfSSL 0:1239e9b70ca2 96 word32 byteCount)
wolfSSL 0:1239e9b70ca2 97 {
wolfSSL 0:1239e9b70ca2 98 word32 count = byteCount/(word32)sizeof(word32), i;
wolfSSL 0:1239e9b70ca2 99
wolfSSL 0:1239e9b70ca2 100 for (i = 0; i < count; i++)
wolfSSL 0:1239e9b70ca2 101 out[i] = ByteReverseWord32(in[i]);
wolfSSL 0:1239e9b70ca2 102
wolfSSL 0:1239e9b70ca2 103 }
wolfSSL 0:1239e9b70ca2 104
wolfSSL 0:1239e9b70ca2 105
wolfSSL 0:1239e9b70ca2 106 #ifdef WORD64_AVAILABLE
wolfSSL 0:1239e9b70ca2 107
wolfSSL 0:1239e9b70ca2 108
wolfSSL 0:1239e9b70ca2 109 STATIC INLINE word64 rotlFixed64(word64 x, word64 y)
wolfSSL 0:1239e9b70ca2 110 {
wolfSSL 0:1239e9b70ca2 111 return (x << y) | (x >> (sizeof(y) * 8 - y));
wolfSSL 0:1239e9b70ca2 112 }
wolfSSL 0:1239e9b70ca2 113
wolfSSL 0:1239e9b70ca2 114
wolfSSL 0:1239e9b70ca2 115 STATIC INLINE word64 rotrFixed64(word64 x, word64 y)
wolfSSL 0:1239e9b70ca2 116 {
wolfSSL 0:1239e9b70ca2 117 return (x >> y) | (x << (sizeof(y) * 8 - y));
wolfSSL 0:1239e9b70ca2 118 }
wolfSSL 0:1239e9b70ca2 119
wolfSSL 0:1239e9b70ca2 120
wolfSSL 0:1239e9b70ca2 121 STATIC INLINE word64 ByteReverseWord64(word64 value)
wolfSSL 0:1239e9b70ca2 122 {
wolfSSL 0:1239e9b70ca2 123 #ifdef CTAOCRYPT_SLOW_WORD64
wolfSSL 0:1239e9b70ca2 124 return (word64)(ByteReverseWord32((word32)value)) << 32 |
wolfSSL 0:1239e9b70ca2 125 ByteReverseWord32((word32)(value>>32));
wolfSSL 0:1239e9b70ca2 126 #else
wolfSSL 0:1239e9b70ca2 127 value = ((value & W64LIT(0xFF00FF00FF00FF00)) >> 8) |
wolfSSL 0:1239e9b70ca2 128 ((value & W64LIT(0x00FF00FF00FF00FF)) << 8);
wolfSSL 0:1239e9b70ca2 129 value = ((value & W64LIT(0xFFFF0000FFFF0000)) >> 16) |
wolfSSL 0:1239e9b70ca2 130 ((value & W64LIT(0x0000FFFF0000FFFF)) << 16);
wolfSSL 0:1239e9b70ca2 131 return rotlFixed64(value, 32U);
wolfSSL 0:1239e9b70ca2 132 #endif
wolfSSL 0:1239e9b70ca2 133 }
wolfSSL 0:1239e9b70ca2 134
wolfSSL 0:1239e9b70ca2 135
wolfSSL 0:1239e9b70ca2 136 STATIC INLINE void ByteReverseWords64(word64* out, const word64* in,
wolfSSL 0:1239e9b70ca2 137 word32 byteCount)
wolfSSL 0:1239e9b70ca2 138 {
wolfSSL 0:1239e9b70ca2 139 word32 count = byteCount/(word32)sizeof(word64), i;
wolfSSL 0:1239e9b70ca2 140
wolfSSL 0:1239e9b70ca2 141 for (i = 0; i < count; i++)
wolfSSL 0:1239e9b70ca2 142 out[i] = ByteReverseWord64(in[i]);
wolfSSL 0:1239e9b70ca2 143
wolfSSL 0:1239e9b70ca2 144 }
wolfSSL 0:1239e9b70ca2 145
wolfSSL 0:1239e9b70ca2 146 #endif /* WORD64_AVAILABLE */
wolfSSL 0:1239e9b70ca2 147
wolfSSL 0:1239e9b70ca2 148
wolfSSL 0:1239e9b70ca2 149 STATIC INLINE void XorWords(word* r, const word* a, word32 n)
wolfSSL 0:1239e9b70ca2 150 {
wolfSSL 0:1239e9b70ca2 151 word32 i;
wolfSSL 0:1239e9b70ca2 152
wolfSSL 0:1239e9b70ca2 153 for (i = 0; i < n; i++) r[i] ^= a[i];
wolfSSL 0:1239e9b70ca2 154 }
wolfSSL 0:1239e9b70ca2 155
wolfSSL 0:1239e9b70ca2 156
wolfSSL 0:1239e9b70ca2 157 STATIC INLINE void xorbuf(void* buf, const void* mask, word32 count)
wolfSSL 0:1239e9b70ca2 158 {
wolfSSL 0:1239e9b70ca2 159 if (((word)buf | (word)mask | count) % CYASSL_WORD_SIZE == 0)
wolfSSL 0:1239e9b70ca2 160 XorWords( (word*)buf, (const word*)mask, count / CYASSL_WORD_SIZE);
wolfSSL 0:1239e9b70ca2 161 else {
wolfSSL 0:1239e9b70ca2 162 word32 i;
wolfSSL 0:1239e9b70ca2 163 byte* b = (byte*)buf;
wolfSSL 0:1239e9b70ca2 164 const byte* m = (const byte*)mask;
wolfSSL 0:1239e9b70ca2 165
wolfSSL 0:1239e9b70ca2 166 for (i = 0; i < count; i++) b[i] ^= m[i];
wolfSSL 0:1239e9b70ca2 167 }
wolfSSL 0:1239e9b70ca2 168 }
wolfSSL 0:1239e9b70ca2 169 #undef STATIC
wolfSSL 0:1239e9b70ca2 170
wolfSSL 0:1239e9b70ca2 171