LCOV - code coverage report
Current view: top level - common/utils - rmd160.c (source / functions) Hit Total Coverage
Test: coverage.info Lines: 191 193 99.0 %
Date: 2024-04-26 00:35:57 Functions: 3 3 100.0 %

          Line data    Source code
       1             : /********************************************************************\
       2             :  *
       3             :  *      FILE:     rmd160.c
       4             :  *
       5             :  *      CONTENTS: A sample C-implementation of the RIPEMD-160
       6             :  *                hash-function.
       7             :  *      TARGET:   any computer with an ANSI C compiler
       8             :  *
       9             :  *      AUTHOR:   Antoon Bosselaers, ESAT-COSIC
      10             :  *      DATE:     1 March 1996
      11             :  *      VERSION:  1.0
      12             :  *
      13             :  *      Copyright (c) 1996 Katholieke Universiteit Leuven
      14             :  *
      15             :  *      Permission is hereby granted, free of charge, to any person
      16             :  *      obtaining a copy of this software and associated documentation
      17             :  *      files (the "Software"), to deal in the Software without restriction,
      18             :  *      including without limitation the rights to use, copy, modify, merge,
      19             :  *      publish, distribute, sublicense, and/or sell copies of the Software,
      20             :  *      and to permit persons to whom the Software is furnished to do so,
      21             :  *      subject to the following conditions:
      22             :  *
      23             :  *      The above copyright notice and this permission notice shall be
      24             :  *      included in all copies or substantial portions of the Software.
      25             :  *
      26             :  *      THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
      27             :  *      EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
      28             :  *      MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
      29             :  *      IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
      30             :  *      CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
      31             :  *      TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
      32             :  *      SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
      33             :  *
      34             : \********************************************************************/
      35             : 
      36             : /*  header files */
      37             : #include "monetdb_config.h"
      38             : #include "rmd160.h"
      39             : 
      40             : /********************************************************************/
      41             : 
      42       38845 : void MDinit(dword *MDbuf)
      43             : {
      44       38845 :    MDbuf[0] = 0x67452301UL;
      45       38845 :    MDbuf[1] = 0xefcdab89UL;
      46       38845 :    MDbuf[2] = 0x98badcfeUL;
      47       38845 :    MDbuf[3] = 0x10325476UL;
      48       38845 :    MDbuf[4] = 0xc3d2e1f0UL;
      49             : 
      50       38845 :    return;
      51             : }
      52             : 
      53             : /********************************************************************/
      54             : 
      55      116546 : void MDcompress(dword *MDbuf, dword *X)
      56             : {
      57      116546 :    dword aa = MDbuf[0],  bb = MDbuf[1],  cc = MDbuf[2],
      58      116546 :          dd = MDbuf[3],  ee = MDbuf[4];
      59      116546 :    dword aaa = MDbuf[0], bbb = MDbuf[1], ccc = MDbuf[2],
      60      116546 :          ddd = MDbuf[3], eee = MDbuf[4];
      61             : 
      62             :    /* round 1 */
      63      116546 :    FF(aa, bb, cc, dd, ee, X[ 0], 11);
      64      116546 :    FF(ee, aa, bb, cc, dd, X[ 1], 14);
      65      116546 :    FF(dd, ee, aa, bb, cc, X[ 2], 15);
      66      116546 :    FF(cc, dd, ee, aa, bb, X[ 3], 12);
      67      116546 :    FF(bb, cc, dd, ee, aa, X[ 4],  5);
      68      116546 :    FF(aa, bb, cc, dd, ee, X[ 5],  8);
      69      116546 :    FF(ee, aa, bb, cc, dd, X[ 6],  7);
      70      116546 :    FF(dd, ee, aa, bb, cc, X[ 7],  9);
      71      116546 :    FF(cc, dd, ee, aa, bb, X[ 8], 11);
      72      116546 :    FF(bb, cc, dd, ee, aa, X[ 9], 13);
      73      116546 :    FF(aa, bb, cc, dd, ee, X[10], 14);
      74      116546 :    FF(ee, aa, bb, cc, dd, X[11], 15);
      75      116546 :    FF(dd, ee, aa, bb, cc, X[12],  6);
      76      116546 :    FF(cc, dd, ee, aa, bb, X[13],  7);
      77      116546 :    FF(bb, cc, dd, ee, aa, X[14],  9);
      78      116546 :    FF(aa, bb, cc, dd, ee, X[15],  8);
      79             : 
      80             :    /* round 2 */
      81      116546 :    GG(ee, aa, bb, cc, dd, X[ 7],  7);
      82      116546 :    GG(dd, ee, aa, bb, cc, X[ 4],  6);
      83      116546 :    GG(cc, dd, ee, aa, bb, X[13],  8);
      84      116546 :    GG(bb, cc, dd, ee, aa, X[ 1], 13);
      85      116546 :    GG(aa, bb, cc, dd, ee, X[10], 11);
      86      116546 :    GG(ee, aa, bb, cc, dd, X[ 6],  9);
      87      116546 :    GG(dd, ee, aa, bb, cc, X[15],  7);
      88      116546 :    GG(cc, dd, ee, aa, bb, X[ 3], 15);
      89      116546 :    GG(bb, cc, dd, ee, aa, X[12],  7);
      90      116546 :    GG(aa, bb, cc, dd, ee, X[ 0], 12);
      91      116546 :    GG(ee, aa, bb, cc, dd, X[ 9], 15);
      92      116546 :    GG(dd, ee, aa, bb, cc, X[ 5],  9);
      93      116546 :    GG(cc, dd, ee, aa, bb, X[ 2], 11);
      94      116546 :    GG(bb, cc, dd, ee, aa, X[14],  7);
      95      116546 :    GG(aa, bb, cc, dd, ee, X[11], 13);
      96      116546 :    GG(ee, aa, bb, cc, dd, X[ 8], 12);
      97             : 
      98             :    /* round 3 */
      99      116546 :    HH(dd, ee, aa, bb, cc, X[ 3], 11);
     100      116546 :    HH(cc, dd, ee, aa, bb, X[10], 13);
     101      116546 :    HH(bb, cc, dd, ee, aa, X[14],  6);
     102      116546 :    HH(aa, bb, cc, dd, ee, X[ 4],  7);
     103      116546 :    HH(ee, aa, bb, cc, dd, X[ 9], 14);
     104      116546 :    HH(dd, ee, aa, bb, cc, X[15],  9);
     105      116546 :    HH(cc, dd, ee, aa, bb, X[ 8], 13);
     106      116546 :    HH(bb, cc, dd, ee, aa, X[ 1], 15);
     107      116546 :    HH(aa, bb, cc, dd, ee, X[ 2], 14);
     108      116546 :    HH(ee, aa, bb, cc, dd, X[ 7],  8);
     109      116546 :    HH(dd, ee, aa, bb, cc, X[ 0], 13);
     110      116546 :    HH(cc, dd, ee, aa, bb, X[ 6],  6);
     111      116546 :    HH(bb, cc, dd, ee, aa, X[13],  5);
     112      116546 :    HH(aa, bb, cc, dd, ee, X[11], 12);
     113      116546 :    HH(ee, aa, bb, cc, dd, X[ 5],  7);
     114      116546 :    HH(dd, ee, aa, bb, cc, X[12],  5);
     115             : 
     116             :    /* round 4 */
     117      116546 :    II(cc, dd, ee, aa, bb, X[ 1], 11);
     118      116546 :    II(bb, cc, dd, ee, aa, X[ 9], 12);
     119      116546 :    II(aa, bb, cc, dd, ee, X[11], 14);
     120      116546 :    II(ee, aa, bb, cc, dd, X[10], 15);
     121      116546 :    II(dd, ee, aa, bb, cc, X[ 0], 14);
     122      116546 :    II(cc, dd, ee, aa, bb, X[ 8], 15);
     123      116546 :    II(bb, cc, dd, ee, aa, X[12],  9);
     124      116546 :    II(aa, bb, cc, dd, ee, X[ 4],  8);
     125      116546 :    II(ee, aa, bb, cc, dd, X[13],  9);
     126      116546 :    II(dd, ee, aa, bb, cc, X[ 3], 14);
     127      116546 :    II(cc, dd, ee, aa, bb, X[ 7],  5);
     128      116546 :    II(bb, cc, dd, ee, aa, X[15],  6);
     129      116546 :    II(aa, bb, cc, dd, ee, X[14],  8);
     130      116546 :    II(ee, aa, bb, cc, dd, X[ 5],  6);
     131      116546 :    II(dd, ee, aa, bb, cc, X[ 6],  5);
     132      116546 :    II(cc, dd, ee, aa, bb, X[ 2], 12);
     133             : 
     134             :    /* round 5 */
     135      116546 :    JJ(bb, cc, dd, ee, aa, X[ 4],  9);
     136      116546 :    JJ(aa, bb, cc, dd, ee, X[ 0], 15);
     137      116546 :    JJ(ee, aa, bb, cc, dd, X[ 5],  5);
     138      116546 :    JJ(dd, ee, aa, bb, cc, X[ 9], 11);
     139      116546 :    JJ(cc, dd, ee, aa, bb, X[ 7],  6);
     140      116546 :    JJ(bb, cc, dd, ee, aa, X[12],  8);
     141      116546 :    JJ(aa, bb, cc, dd, ee, X[ 2], 13);
     142      116546 :    JJ(ee, aa, bb, cc, dd, X[10], 12);
     143      116546 :    JJ(dd, ee, aa, bb, cc, X[14],  5);
     144      116546 :    JJ(cc, dd, ee, aa, bb, X[ 1], 12);
     145      116546 :    JJ(bb, cc, dd, ee, aa, X[ 3], 13);
     146      116546 :    JJ(aa, bb, cc, dd, ee, X[ 8], 14);
     147      116546 :    JJ(ee, aa, bb, cc, dd, X[11], 11);
     148      116546 :    JJ(dd, ee, aa, bb, cc, X[ 6],  8);
     149      116546 :    JJ(cc, dd, ee, aa, bb, X[15],  5);
     150      116546 :    JJ(bb, cc, dd, ee, aa, X[13],  6);
     151             : 
     152             :    /* parallel round 1 */
     153      116546 :    JJJ(aaa, bbb, ccc, ddd, eee, X[ 5],  8);
     154      116546 :    JJJ(eee, aaa, bbb, ccc, ddd, X[14],  9);
     155      116546 :    JJJ(ddd, eee, aaa, bbb, ccc, X[ 7],  9);
     156      116546 :    JJJ(ccc, ddd, eee, aaa, bbb, X[ 0], 11);
     157      116546 :    JJJ(bbb, ccc, ddd, eee, aaa, X[ 9], 13);
     158      116546 :    JJJ(aaa, bbb, ccc, ddd, eee, X[ 2], 15);
     159      116546 :    JJJ(eee, aaa, bbb, ccc, ddd, X[11], 15);
     160      116546 :    JJJ(ddd, eee, aaa, bbb, ccc, X[ 4],  5);
     161      116546 :    JJJ(ccc, ddd, eee, aaa, bbb, X[13],  7);
     162      116546 :    JJJ(bbb, ccc, ddd, eee, aaa, X[ 6],  7);
     163      116546 :    JJJ(aaa, bbb, ccc, ddd, eee, X[15],  8);
     164      116546 :    JJJ(eee, aaa, bbb, ccc, ddd, X[ 8], 11);
     165      116546 :    JJJ(ddd, eee, aaa, bbb, ccc, X[ 1], 14);
     166      116546 :    JJJ(ccc, ddd, eee, aaa, bbb, X[10], 14);
     167      116546 :    JJJ(bbb, ccc, ddd, eee, aaa, X[ 3], 12);
     168      116546 :    JJJ(aaa, bbb, ccc, ddd, eee, X[12],  6);
     169             : 
     170             :    /* parallel round 2 */
     171      116546 :    III(eee, aaa, bbb, ccc, ddd, X[ 6],  9);
     172      116546 :    III(ddd, eee, aaa, bbb, ccc, X[11], 13);
     173      116546 :    III(ccc, ddd, eee, aaa, bbb, X[ 3], 15);
     174      116546 :    III(bbb, ccc, ddd, eee, aaa, X[ 7],  7);
     175      116546 :    III(aaa, bbb, ccc, ddd, eee, X[ 0], 12);
     176      116546 :    III(eee, aaa, bbb, ccc, ddd, X[13],  8);
     177      116546 :    III(ddd, eee, aaa, bbb, ccc, X[ 5],  9);
     178      116546 :    III(ccc, ddd, eee, aaa, bbb, X[10], 11);
     179      116546 :    III(bbb, ccc, ddd, eee, aaa, X[14],  7);
     180      116546 :    III(aaa, bbb, ccc, ddd, eee, X[15],  7);
     181      116546 :    III(eee, aaa, bbb, ccc, ddd, X[ 8], 12);
     182      116546 :    III(ddd, eee, aaa, bbb, ccc, X[12],  7);
     183      116546 :    III(ccc, ddd, eee, aaa, bbb, X[ 4],  6);
     184      116546 :    III(bbb, ccc, ddd, eee, aaa, X[ 9], 15);
     185      116546 :    III(aaa, bbb, ccc, ddd, eee, X[ 1], 13);
     186      116546 :    III(eee, aaa, bbb, ccc, ddd, X[ 2], 11);
     187             : 
     188             :    /* parallel round 3 */
     189      116546 :    HHH(ddd, eee, aaa, bbb, ccc, X[15],  9);
     190      116546 :    HHH(ccc, ddd, eee, aaa, bbb, X[ 5],  7);
     191      116546 :    HHH(bbb, ccc, ddd, eee, aaa, X[ 1], 15);
     192      116546 :    HHH(aaa, bbb, ccc, ddd, eee, X[ 3], 11);
     193      116546 :    HHH(eee, aaa, bbb, ccc, ddd, X[ 7],  8);
     194      116546 :    HHH(ddd, eee, aaa, bbb, ccc, X[14],  6);
     195      116546 :    HHH(ccc, ddd, eee, aaa, bbb, X[ 6],  6);
     196      116546 :    HHH(bbb, ccc, ddd, eee, aaa, X[ 9], 14);
     197      116546 :    HHH(aaa, bbb, ccc, ddd, eee, X[11], 12);
     198      116546 :    HHH(eee, aaa, bbb, ccc, ddd, X[ 8], 13);
     199      116546 :    HHH(ddd, eee, aaa, bbb, ccc, X[12],  5);
     200      116546 :    HHH(ccc, ddd, eee, aaa, bbb, X[ 2], 14);
     201      116546 :    HHH(bbb, ccc, ddd, eee, aaa, X[10], 13);
     202      116546 :    HHH(aaa, bbb, ccc, ddd, eee, X[ 0], 13);
     203      116546 :    HHH(eee, aaa, bbb, ccc, ddd, X[ 4],  7);
     204      116546 :    HHH(ddd, eee, aaa, bbb, ccc, X[13],  5);
     205             : 
     206             :    /* parallel round 4 */
     207      116546 :    GGG(ccc, ddd, eee, aaa, bbb, X[ 8], 15);
     208      116546 :    GGG(bbb, ccc, ddd, eee, aaa, X[ 6],  5);
     209      116546 :    GGG(aaa, bbb, ccc, ddd, eee, X[ 4],  8);
     210      116546 :    GGG(eee, aaa, bbb, ccc, ddd, X[ 1], 11);
     211      116546 :    GGG(ddd, eee, aaa, bbb, ccc, X[ 3], 14);
     212      116546 :    GGG(ccc, ddd, eee, aaa, bbb, X[11], 14);
     213      116546 :    GGG(bbb, ccc, ddd, eee, aaa, X[15],  6);
     214      116546 :    GGG(aaa, bbb, ccc, ddd, eee, X[ 0], 14);
     215      116546 :    GGG(eee, aaa, bbb, ccc, ddd, X[ 5],  6);
     216      116546 :    GGG(ddd, eee, aaa, bbb, ccc, X[12],  9);
     217      116546 :    GGG(ccc, ddd, eee, aaa, bbb, X[ 2], 12);
     218      116546 :    GGG(bbb, ccc, ddd, eee, aaa, X[13],  9);
     219      116546 :    GGG(aaa, bbb, ccc, ddd, eee, X[ 9], 12);
     220      116546 :    GGG(eee, aaa, bbb, ccc, ddd, X[ 7],  5);
     221      116546 :    GGG(ddd, eee, aaa, bbb, ccc, X[10], 15);
     222      116546 :    GGG(ccc, ddd, eee, aaa, bbb, X[14],  8);
     223             : 
     224             :    /* parallel round 5 */
     225      116546 :    FFF(bbb, ccc, ddd, eee, aaa, X[12] ,  8);
     226      116546 :    FFF(aaa, bbb, ccc, ddd, eee, X[15] ,  5);
     227      116546 :    FFF(eee, aaa, bbb, ccc, ddd, X[10] , 12);
     228      116546 :    FFF(ddd, eee, aaa, bbb, ccc, X[ 4] ,  9);
     229      116546 :    FFF(ccc, ddd, eee, aaa, bbb, X[ 1] , 12);
     230      116546 :    FFF(bbb, ccc, ddd, eee, aaa, X[ 5] ,  5);
     231      116546 :    FFF(aaa, bbb, ccc, ddd, eee, X[ 8] , 14);
     232      116546 :    FFF(eee, aaa, bbb, ccc, ddd, X[ 7] ,  6);
     233      116546 :    FFF(ddd, eee, aaa, bbb, ccc, X[ 6] ,  8);
     234      116546 :    FFF(ccc, ddd, eee, aaa, bbb, X[ 2] , 13);
     235      116546 :    FFF(bbb, ccc, ddd, eee, aaa, X[13] ,  6);
     236      116546 :    FFF(aaa, bbb, ccc, ddd, eee, X[14] ,  5);
     237      116546 :    FFF(eee, aaa, bbb, ccc, ddd, X[ 0] , 15);
     238      116546 :    FFF(ddd, eee, aaa, bbb, ccc, X[ 3] , 13);
     239      116546 :    FFF(ccc, ddd, eee, aaa, bbb, X[ 9] , 11);
     240      116546 :    FFF(bbb, ccc, ddd, eee, aaa, X[11] , 11);
     241             : 
     242             :    /* combine results */
     243      116546 :    ddd += cc + MDbuf[1];               /* final result for MDbuf[0] */
     244      116546 :    MDbuf[1] = MDbuf[2] + dd + eee;
     245      116546 :    MDbuf[2] = MDbuf[3] + ee + aaa;
     246      116546 :    MDbuf[3] = MDbuf[4] + aa + bbb;
     247      116546 :    MDbuf[4] = MDbuf[0] + bb + ccc;
     248      116546 :    MDbuf[0] = ddd;
     249             : 
     250      116546 :    return;
     251             : }
     252             : 
     253             : /********************************************************************/
     254             : 
     255       38850 : void MDfinish(dword *MDbuf, byte *strptr, dword lswlen, dword mswlen)
     256             : {
     257       38850 :    unsigned int i;                                 /* counter       */
     258       38850 :    dword        X[16];                             /* message words */
     259             : 
     260       38850 :    memset(X, 0, 16*sizeof(dword));
     261             : 
     262             :    /* put bytes from strptr into X */
     263      408250 :    for (i=0; i<(lswlen&63); i++) {
     264             :       /* byte i goes into word X[i div 4] at pos.  8*(i mod 4)  */
     265      369400 :       X[i>>2] ^= (dword) *strptr++ << (8 * (i&3));
     266             :    }
     267             : 
     268             :    /* append the bit m_n == 1 */
     269       38850 :    X[(lswlen>>2)&15] ^= (dword)1 << (8*(lswlen&3) + 7);
     270             : 
     271       38850 :    if ((lswlen & 63) > 55) {
     272             :       /* length goes to next block */
     273           0 :       MDcompress(MDbuf, X);
     274           0 :       memset(X, 0, 16*sizeof(dword));
     275             :    }
     276             : 
     277             :    /* append length in bits*/
     278       38850 :    X[14] = lswlen << 3;
     279       38850 :    X[15] = (lswlen >> 29) | (mswlen << 3);
     280       38850 :    MDcompress(MDbuf, X);
     281             : 
     282       38853 :    return;
     283             : }
     284             : 
     285             : /************************ end of file rmd160.c **********************/

Generated by: LCOV version 1.14