[BACK]Return to rmd160.c CVS log [TXT][DIR] Up to [local] / sys / crypto

Annotation of sys/crypto/rmd160.c, Revision 1.1

1.1     ! nbrk        1: /*     $OpenBSD: rmd160.c,v 1.4 2003/12/14 11:22:35 markus Exp $       */
        !             2: /*
        !             3:  * Copyright (c) 2001 Markus Friedl.  All rights reserved.
        !             4:  *
        !             5:  * Redistribution and use in source and binary forms, with or without
        !             6:  * modification, are permitted provided that the following conditions
        !             7:  * are met:
        !             8:  * 1. Redistributions of source code must retain the above copyright
        !             9:  *    notice, this list of conditions and the following disclaimer.
        !            10:  * 2. Redistributions in binary form must reproduce the above copyright
        !            11:  *    notice, this list of conditions and the following disclaimer in the
        !            12:  *    documentation and/or other materials provided with the distribution.
        !            13:  *
        !            14:  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
        !            15:  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
        !            16:  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
        !            17:  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
        !            18:  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
        !            19:  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
        !            20:  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
        !            21:  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
        !            22:  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
        !            23:  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
        !            24:  */
        !            25: /*
        !            26:  * Preneel, Bosselaers, Dobbertin, "The Cryptographic Hash Function RIPEMD-160",
        !            27:  * RSA Laboratories, CryptoBytes, Volume 3, Number 2, Autumn 1997,
        !            28:  * ftp://ftp.rsasecurity.com/pub/cryptobytes/crypto3n2.pdf
        !            29:  */
        !            30: #include <sys/param.h>
        !            31: #include <sys/systm.h>
        !            32: #include <sys/endian.h>
        !            33: #include <crypto/rmd160.h>
        !            34:
        !            35: #define PUT_64BIT_LE(cp, value) do { \
        !            36:        (cp)[7] = (value) >> 56; \
        !            37:        (cp)[6] = (value) >> 48; \
        !            38:        (cp)[5] = (value) >> 40; \
        !            39:        (cp)[4] = (value) >> 32; \
        !            40:        (cp)[3] = (value) >> 24; \
        !            41:        (cp)[2] = (value) >> 16; \
        !            42:        (cp)[1] = (value) >> 8; \
        !            43:        (cp)[0] = (value); } while (0)
        !            44:
        !            45: #define PUT_32BIT_LE(cp, value) do { \
        !            46:        (cp)[3] = (value) >> 24; \
        !            47:        (cp)[2] = (value) >> 16; \
        !            48:        (cp)[1] = (value) >> 8; \
        !            49:        (cp)[0] = (value); } while (0)
        !            50:
        !            51: #define        H0      0x67452301U
        !            52: #define        H1      0xEFCDAB89U
        !            53: #define        H2      0x98BADCFEU
        !            54: #define        H3      0x10325476U
        !            55: #define        H4      0xC3D2E1F0U
        !            56:
        !            57: #define        K0      0x00000000U
        !            58: #define        K1      0x5A827999U
        !            59: #define        K2      0x6ED9EBA1U
        !            60: #define        K3      0x8F1BBCDCU
        !            61: #define        K4      0xA953FD4EU
        !            62:
        !            63: #define        KK0     0x50A28BE6U
        !            64: #define        KK1     0x5C4DD124U
        !            65: #define        KK2     0x6D703EF3U
        !            66: #define        KK3     0x7A6D76E9U
        !            67: #define        KK4     0x00000000U
        !            68:
        !            69: /* rotate x left n bits.  */
        !            70: #define ROL(n, x) (((x) << (n)) | ((x) >> (32-(n))))
        !            71:
        !            72: #define F0(x, y, z) ((x) ^ (y) ^ (z))
        !            73: #define F1(x, y, z) (((x) & (y)) | ((~x) & (z)))
        !            74: #define F2(x, y, z) (((x) | (~y)) ^ (z))
        !            75: #define F3(x, y, z) (((x) & (z)) | ((y) & (~z)))
        !            76: #define F4(x, y, z) ((x) ^ ((y) | (~z)))
        !            77:
        !            78: #define R(a, b, c, d, e, Fj, Kj, sj, rj) \
        !            79:        do { \
        !            80:                a = ROL(sj, a + Fj(b,c,d) + X(rj) + Kj) + e; \
        !            81:                c = ROL(10, c); \
        !            82:        } while(0)
        !            83:
        !            84: #define X(i)   x[i]
        !            85:
        !            86: static u_char PADDING[64] = {
        !            87:        0x80, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
        !            88:        0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
        !            89:        0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
        !            90: };
        !            91:
        !            92: void
        !            93: RMD160Init(RMD160_CTX *ctx)
        !            94: {
        !            95:        ctx->count = 0;
        !            96:        ctx->state[0] = H0;
        !            97:        ctx->state[1] = H1;
        !            98:        ctx->state[2] = H2;
        !            99:        ctx->state[3] = H3;
        !           100:        ctx->state[4] = H4;
        !           101: }
        !           102:
        !           103: void
        !           104: RMD160Update(RMD160_CTX *ctx, const u_char *input, u_int32_t len)
        !           105: {
        !           106:        u_int32_t have, off, need;
        !           107:
        !           108:        have = (ctx->count/8) % 64;
        !           109:        need = 64 - have;
        !           110:        ctx->count += 8 * len;
        !           111:        off = 0;
        !           112:
        !           113:        if (len >= need) {
        !           114:                if (have) {
        !           115:                        memcpy(ctx->buffer + have, input, need);
        !           116:                        RMD160Transform(ctx->state, ctx->buffer);
        !           117:                        off = need;
        !           118:                        have = 0;
        !           119:                }
        !           120:                /* now the buffer is empty */
        !           121:                while (off + 64 <= len) {
        !           122:                        RMD160Transform(ctx->state, input+off);
        !           123:                        off += 64;
        !           124:                }
        !           125:        }
        !           126:        if (off < len)
        !           127:                memcpy(ctx->buffer + have, input+off, len-off);
        !           128: }
        !           129:
        !           130: void
        !           131: RMD160Final(u_char digest[20], RMD160_CTX *ctx)
        !           132: {
        !           133:        int i;
        !           134:        u_char size[8];
        !           135:        u_int32_t padlen;
        !           136:
        !           137:        PUT_64BIT_LE(size, ctx->count);
        !           138:
        !           139:        /*
        !           140:         * pad to 64 byte blocks, at least one byte from PADDING plus 8 bytes
        !           141:         * for the size
        !           142:         */
        !           143:        padlen = 64 - ((ctx->count/8) % 64);
        !           144:        if (padlen < 1 + 8)
        !           145:                padlen += 64;
        !           146:        RMD160Update(ctx, PADDING, padlen - 8);         /* padlen - 8 <= 64 */
        !           147:        RMD160Update(ctx, size, 8);
        !           148:
        !           149:        if (digest != NULL)
        !           150:                for (i = 0; i < 5; i++)
        !           151:                        PUT_32BIT_LE(digest + i*4, ctx->state[i]);
        !           152:
        !           153:        memset(ctx, 0, sizeof (*ctx));
        !           154: }
        !           155:
        !           156: void
        !           157: RMD160Transform(u_int32_t state[5], const u_char block[64])
        !           158: {
        !           159:        u_int32_t a, b, c, d, e, aa, bb, cc, dd, ee, t, x[16];
        !           160:
        !           161: #if BYTE_ORDER == LITTLE_ENDIAN
        !           162:        memcpy(x, block, 64);
        !           163: #else
        !           164:        int i;
        !           165:
        !           166:        for (i = 0; i < 16; i++)
        !           167:                x[i] = (u_int32_t)(
        !           168:                    (u_int32_t)(block[i*4 + 0]) |
        !           169:                    (u_int32_t)(block[i*4 + 1]) <<  8 |
        !           170:                    (u_int32_t)(block[i*4 + 2]) << 16 |
        !           171:                    (u_int32_t)(block[i*4 + 3]) << 24);
        !           172: #endif
        !           173:
        !           174:        a = state[0];
        !           175:        b = state[1];
        !           176:        c = state[2];
        !           177:        d = state[3];
        !           178:        e = state[4];
        !           179:
        !           180:        /* Round 1 */
        !           181:        R(a, b, c, d, e, F0, K0, 11,  0);
        !           182:        R(e, a, b, c, d, F0, K0, 14,  1);
        !           183:        R(d, e, a, b, c, F0, K0, 15,  2);
        !           184:        R(c, d, e, a, b, F0, K0, 12,  3);
        !           185:        R(b, c, d, e, a, F0, K0,  5,  4);
        !           186:        R(a, b, c, d, e, F0, K0,  8,  5);
        !           187:        R(e, a, b, c, d, F0, K0,  7,  6);
        !           188:        R(d, e, a, b, c, F0, K0,  9,  7);
        !           189:        R(c, d, e, a, b, F0, K0, 11,  8);
        !           190:        R(b, c, d, e, a, F0, K0, 13,  9);
        !           191:        R(a, b, c, d, e, F0, K0, 14, 10);
        !           192:        R(e, a, b, c, d, F0, K0, 15, 11);
        !           193:        R(d, e, a, b, c, F0, K0,  6, 12);
        !           194:        R(c, d, e, a, b, F0, K0,  7, 13);
        !           195:        R(b, c, d, e, a, F0, K0,  9, 14);
        !           196:        R(a, b, c, d, e, F0, K0,  8, 15); /* #15 */
        !           197:        /* Round 2 */
        !           198:        R(e, a, b, c, d, F1, K1,  7,  7);
        !           199:        R(d, e, a, b, c, F1, K1,  6,  4);
        !           200:        R(c, d, e, a, b, F1, K1,  8, 13);
        !           201:        R(b, c, d, e, a, F1, K1, 13,  1);
        !           202:        R(a, b, c, d, e, F1, K1, 11, 10);
        !           203:        R(e, a, b, c, d, F1, K1,  9,  6);
        !           204:        R(d, e, a, b, c, F1, K1,  7, 15);
        !           205:        R(c, d, e, a, b, F1, K1, 15,  3);
        !           206:        R(b, c, d, e, a, F1, K1,  7, 12);
        !           207:        R(a, b, c, d, e, F1, K1, 12,  0);
        !           208:        R(e, a, b, c, d, F1, K1, 15,  9);
        !           209:        R(d, e, a, b, c, F1, K1,  9,  5);
        !           210:        R(c, d, e, a, b, F1, K1, 11,  2);
        !           211:        R(b, c, d, e, a, F1, K1,  7, 14);
        !           212:        R(a, b, c, d, e, F1, K1, 13, 11);
        !           213:        R(e, a, b, c, d, F1, K1, 12,  8); /* #31 */
        !           214:        /* Round 3 */
        !           215:        R(d, e, a, b, c, F2, K2, 11,  3);
        !           216:        R(c, d, e, a, b, F2, K2, 13, 10);
        !           217:        R(b, c, d, e, a, F2, K2,  6, 14);
        !           218:        R(a, b, c, d, e, F2, K2,  7,  4);
        !           219:        R(e, a, b, c, d, F2, K2, 14,  9);
        !           220:        R(d, e, a, b, c, F2, K2,  9, 15);
        !           221:        R(c, d, e, a, b, F2, K2, 13,  8);
        !           222:        R(b, c, d, e, a, F2, K2, 15,  1);
        !           223:        R(a, b, c, d, e, F2, K2, 14,  2);
        !           224:        R(e, a, b, c, d, F2, K2,  8,  7);
        !           225:        R(d, e, a, b, c, F2, K2, 13,  0);
        !           226:        R(c, d, e, a, b, F2, K2,  6,  6);
        !           227:        R(b, c, d, e, a, F2, K2,  5, 13);
        !           228:        R(a, b, c, d, e, F2, K2, 12, 11);
        !           229:        R(e, a, b, c, d, F2, K2,  7,  5);
        !           230:        R(d, e, a, b, c, F2, K2,  5, 12); /* #47 */
        !           231:        /* Round 4 */
        !           232:        R(c, d, e, a, b, F3, K3, 11,  1);
        !           233:        R(b, c, d, e, a, F3, K3, 12,  9);
        !           234:        R(a, b, c, d, e, F3, K3, 14, 11);
        !           235:        R(e, a, b, c, d, F3, K3, 15, 10);
        !           236:        R(d, e, a, b, c, F3, K3, 14,  0);
        !           237:        R(c, d, e, a, b, F3, K3, 15,  8);
        !           238:        R(b, c, d, e, a, F3, K3,  9, 12);
        !           239:        R(a, b, c, d, e, F3, K3,  8,  4);
        !           240:        R(e, a, b, c, d, F3, K3,  9, 13);
        !           241:        R(d, e, a, b, c, F3, K3, 14,  3);
        !           242:        R(c, d, e, a, b, F3, K3,  5,  7);
        !           243:        R(b, c, d, e, a, F3, K3,  6, 15);
        !           244:        R(a, b, c, d, e, F3, K3,  8, 14);
        !           245:        R(e, a, b, c, d, F3, K3,  6,  5);
        !           246:        R(d, e, a, b, c, F3, K3,  5,  6);
        !           247:        R(c, d, e, a, b, F3, K3, 12,  2); /* #63 */
        !           248:        /* Round 5 */
        !           249:        R(b, c, d, e, a, F4, K4,  9,  4);
        !           250:        R(a, b, c, d, e, F4, K4, 15,  0);
        !           251:        R(e, a, b, c, d, F4, K4,  5,  5);
        !           252:        R(d, e, a, b, c, F4, K4, 11,  9);
        !           253:        R(c, d, e, a, b, F4, K4,  6,  7);
        !           254:        R(b, c, d, e, a, F4, K4,  8, 12);
        !           255:        R(a, b, c, d, e, F4, K4, 13,  2);
        !           256:        R(e, a, b, c, d, F4, K4, 12, 10);
        !           257:        R(d, e, a, b, c, F4, K4,  5, 14);
        !           258:        R(c, d, e, a, b, F4, K4, 12,  1);
        !           259:        R(b, c, d, e, a, F4, K4, 13,  3);
        !           260:        R(a, b, c, d, e, F4, K4, 14,  8);
        !           261:        R(e, a, b, c, d, F4, K4, 11, 11);
        !           262:        R(d, e, a, b, c, F4, K4,  8,  6);
        !           263:        R(c, d, e, a, b, F4, K4,  5, 15);
        !           264:        R(b, c, d, e, a, F4, K4,  6, 13); /* #79 */
        !           265:
        !           266:        aa = a ; bb = b; cc = c; dd = d; ee = e;
        !           267:
        !           268:        a = state[0];
        !           269:        b = state[1];
        !           270:        c = state[2];
        !           271:        d = state[3];
        !           272:        e = state[4];
        !           273:
        !           274:        /* Parallel round 1 */
        !           275:        R(a, b, c, d, e, F4, KK0,  8,  5);
        !           276:        R(e, a, b, c, d, F4, KK0,  9, 14);
        !           277:        R(d, e, a, b, c, F4, KK0,  9,  7);
        !           278:        R(c, d, e, a, b, F4, KK0, 11,  0);
        !           279:        R(b, c, d, e, a, F4, KK0, 13,  9);
        !           280:        R(a, b, c, d, e, F4, KK0, 15,  2);
        !           281:        R(e, a, b, c, d, F4, KK0, 15, 11);
        !           282:        R(d, e, a, b, c, F4, KK0,  5,  4);
        !           283:        R(c, d, e, a, b, F4, KK0,  7, 13);
        !           284:        R(b, c, d, e, a, F4, KK0,  7,  6);
        !           285:        R(a, b, c, d, e, F4, KK0,  8, 15);
        !           286:        R(e, a, b, c, d, F4, KK0, 11,  8);
        !           287:        R(d, e, a, b, c, F4, KK0, 14,  1);
        !           288:        R(c, d, e, a, b, F4, KK0, 14, 10);
        !           289:        R(b, c, d, e, a, F4, KK0, 12,  3);
        !           290:        R(a, b, c, d, e, F4, KK0,  6, 12); /* #15 */
        !           291:        /* Parallel round 2 */
        !           292:        R(e, a, b, c, d, F3, KK1,  9,  6);
        !           293:        R(d, e, a, b, c, F3, KK1, 13, 11);
        !           294:        R(c, d, e, a, b, F3, KK1, 15,  3);
        !           295:        R(b, c, d, e, a, F3, KK1,  7,  7);
        !           296:        R(a, b, c, d, e, F3, KK1, 12,  0);
        !           297:        R(e, a, b, c, d, F3, KK1,  8, 13);
        !           298:        R(d, e, a, b, c, F3, KK1,  9,  5);
        !           299:        R(c, d, e, a, b, F3, KK1, 11, 10);
        !           300:        R(b, c, d, e, a, F3, KK1,  7, 14);
        !           301:        R(a, b, c, d, e, F3, KK1,  7, 15);
        !           302:        R(e, a, b, c, d, F3, KK1, 12,  8);
        !           303:        R(d, e, a, b, c, F3, KK1,  7, 12);
        !           304:        R(c, d, e, a, b, F3, KK1,  6,  4);
        !           305:        R(b, c, d, e, a, F3, KK1, 15,  9);
        !           306:        R(a, b, c, d, e, F3, KK1, 13,  1);
        !           307:        R(e, a, b, c, d, F3, KK1, 11,  2); /* #31 */
        !           308:        /* Parallel round 3 */
        !           309:        R(d, e, a, b, c, F2, KK2,  9, 15);
        !           310:        R(c, d, e, a, b, F2, KK2,  7,  5);
        !           311:        R(b, c, d, e, a, F2, KK2, 15,  1);
        !           312:        R(a, b, c, d, e, F2, KK2, 11,  3);
        !           313:        R(e, a, b, c, d, F2, KK2,  8,  7);
        !           314:        R(d, e, a, b, c, F2, KK2,  6, 14);
        !           315:        R(c, d, e, a, b, F2, KK2,  6,  6);
        !           316:        R(b, c, d, e, a, F2, KK2, 14,  9);
        !           317:        R(a, b, c, d, e, F2, KK2, 12, 11);
        !           318:        R(e, a, b, c, d, F2, KK2, 13,  8);
        !           319:        R(d, e, a, b, c, F2, KK2,  5, 12);
        !           320:        R(c, d, e, a, b, F2, KK2, 14,  2);
        !           321:        R(b, c, d, e, a, F2, KK2, 13, 10);
        !           322:        R(a, b, c, d, e, F2, KK2, 13,  0);
        !           323:        R(e, a, b, c, d, F2, KK2,  7,  4);
        !           324:        R(d, e, a, b, c, F2, KK2,  5, 13); /* #47 */
        !           325:        /* Parallel round 4 */
        !           326:        R(c, d, e, a, b, F1, KK3, 15,  8);
        !           327:        R(b, c, d, e, a, F1, KK3,  5,  6);
        !           328:        R(a, b, c, d, e, F1, KK3,  8,  4);
        !           329:        R(e, a, b, c, d, F1, KK3, 11,  1);
        !           330:        R(d, e, a, b, c, F1, KK3, 14,  3);
        !           331:        R(c, d, e, a, b, F1, KK3, 14, 11);
        !           332:        R(b, c, d, e, a, F1, KK3,  6, 15);
        !           333:        R(a, b, c, d, e, F1, KK3, 14,  0);
        !           334:        R(e, a, b, c, d, F1, KK3,  6,  5);
        !           335:        R(d, e, a, b, c, F1, KK3,  9, 12);
        !           336:        R(c, d, e, a, b, F1, KK3, 12,  2);
        !           337:        R(b, c, d, e, a, F1, KK3,  9, 13);
        !           338:        R(a, b, c, d, e, F1, KK3, 12,  9);
        !           339:        R(e, a, b, c, d, F1, KK3,  5,  7);
        !           340:        R(d, e, a, b, c, F1, KK3, 15, 10);
        !           341:        R(c, d, e, a, b, F1, KK3,  8, 14); /* #63 */
        !           342:        /* Parallel round 5 */
        !           343:        R(b, c, d, e, a, F0, KK4,  8, 12);
        !           344:        R(a, b, c, d, e, F0, KK4,  5, 15);
        !           345:        R(e, a, b, c, d, F0, KK4, 12, 10);
        !           346:        R(d, e, a, b, c, F0, KK4,  9,  4);
        !           347:        R(c, d, e, a, b, F0, KK4, 12,  1);
        !           348:        R(b, c, d, e, a, F0, KK4,  5,  5);
        !           349:        R(a, b, c, d, e, F0, KK4, 14,  8);
        !           350:        R(e, a, b, c, d, F0, KK4,  6,  7);
        !           351:        R(d, e, a, b, c, F0, KK4,  8,  6);
        !           352:        R(c, d, e, a, b, F0, KK4, 13,  2);
        !           353:        R(b, c, d, e, a, F0, KK4,  6, 13);
        !           354:        R(a, b, c, d, e, F0, KK4,  5, 14);
        !           355:        R(e, a, b, c, d, F0, KK4, 15,  0);
        !           356:        R(d, e, a, b, c, F0, KK4, 13,  3);
        !           357:        R(c, d, e, a, b, F0, KK4, 11,  9);
        !           358:        R(b, c, d, e, a, F0, KK4, 11, 11); /* #79 */
        !           359:
        !           360:        t =        state[1] + cc + d;
        !           361:        state[1] = state[2] + dd + e;
        !           362:        state[2] = state[3] + ee + a;
        !           363:        state[3] = state[4] + aa + b;
        !           364:        state[4] = state[0] + bb + c;
        !           365:        state[0] = t;
        !           366: }

CVSweb