mirror of https://github.com/hashcat/hashcat.git
parent
07e1a15c63
commit
f3626fa082
@ -0,0 +1,13 @@
|
||||
/**
|
||||
* Author......: See docs/credits.txt
|
||||
* License.....: MIT
|
||||
*/
|
||||
|
||||
#ifndef _CPU_MD4_H
|
||||
#define _CPU_MD4_H
|
||||
|
||||
#include <string.h>
|
||||
|
||||
void md4_64 (u32 block[16], u32 digest[4]);
|
||||
|
||||
#endif // _CPU_MD4_H
|
@ -0,0 +1,99 @@
|
||||
/**
|
||||
* Author......: See docs/credits.txt
|
||||
* License.....: MIT
|
||||
*/
|
||||
|
||||
#define IS_GENERIC
|
||||
|
||||
#include "common.h"
|
||||
#include "types.h"
|
||||
#include "bitops.h"
|
||||
#include "inc_hash_constants.h"
|
||||
#include "inc_hash_functions.cl"
|
||||
#include "cpu_md4.h"
|
||||
|
||||
void md4_64 (u32 block[16], u32 digest[4])
|
||||
{
|
||||
u32 w0[4];
|
||||
u32 w1[4];
|
||||
u32 w2[4];
|
||||
u32 w3[4];
|
||||
|
||||
w0[0] = block[ 0];
|
||||
w0[1] = block[ 1];
|
||||
w0[2] = block[ 2];
|
||||
w0[3] = block[ 3];
|
||||
w1[0] = block[ 4];
|
||||
w1[1] = block[ 5];
|
||||
w1[2] = block[ 6];
|
||||
w1[3] = block[ 7];
|
||||
w2[0] = block[ 8];
|
||||
w2[1] = block[ 9];
|
||||
w2[2] = block[10];
|
||||
w2[3] = block[11];
|
||||
w3[0] = block[12];
|
||||
w3[1] = block[13];
|
||||
w3[2] = block[14];
|
||||
w3[3] = block[15];
|
||||
|
||||
u32 a = digest[0];
|
||||
u32 b = digest[1];
|
||||
u32 c = digest[2];
|
||||
u32 d = digest[3];
|
||||
|
||||
MD4_STEP (MD4_Fo, a, b, c, d, w0[0], MD4C00, MD4S00);
|
||||
MD4_STEP (MD4_Fo, d, a, b, c, w0[1], MD4C00, MD4S01);
|
||||
MD4_STEP (MD4_Fo, c, d, a, b, w0[2], MD4C00, MD4S02);
|
||||
MD4_STEP (MD4_Fo, b, c, d, a, w0[3], MD4C00, MD4S03);
|
||||
MD4_STEP (MD4_Fo, a, b, c, d, w1[0], MD4C00, MD4S00);
|
||||
MD4_STEP (MD4_Fo, d, a, b, c, w1[1], MD4C00, MD4S01);
|
||||
MD4_STEP (MD4_Fo, c, d, a, b, w1[2], MD4C00, MD4S02);
|
||||
MD4_STEP (MD4_Fo, b, c, d, a, w1[3], MD4C00, MD4S03);
|
||||
MD4_STEP (MD4_Fo, a, b, c, d, w2[0], MD4C00, MD4S00);
|
||||
MD4_STEP (MD4_Fo, d, a, b, c, w2[1], MD4C00, MD4S01);
|
||||
MD4_STEP (MD4_Fo, c, d, a, b, w2[2], MD4C00, MD4S02);
|
||||
MD4_STEP (MD4_Fo, b, c, d, a, w2[3], MD4C00, MD4S03);
|
||||
MD4_STEP (MD4_Fo, a, b, c, d, w3[0], MD4C00, MD4S00);
|
||||
MD4_STEP (MD4_Fo, d, a, b, c, w3[1], MD4C00, MD4S01);
|
||||
MD4_STEP (MD4_Fo, c, d, a, b, w3[2], MD4C00, MD4S02);
|
||||
MD4_STEP (MD4_Fo, b, c, d, a, w3[3], MD4C00, MD4S03);
|
||||
|
||||
MD4_STEP (MD4_Go, a, b, c, d, w0[0], MD4C01, MD4S10);
|
||||
MD4_STEP (MD4_Go, d, a, b, c, w1[0], MD4C01, MD4S11);
|
||||
MD4_STEP (MD4_Go, c, d, a, b, w2[0], MD4C01, MD4S12);
|
||||
MD4_STEP (MD4_Go, b, c, d, a, w3[0], MD4C01, MD4S13);
|
||||
MD4_STEP (MD4_Go, a, b, c, d, w0[1], MD4C01, MD4S10);
|
||||
MD4_STEP (MD4_Go, d, a, b, c, w1[1], MD4C01, MD4S11);
|
||||
MD4_STEP (MD4_Go, c, d, a, b, w2[1], MD4C01, MD4S12);
|
||||
MD4_STEP (MD4_Go, b, c, d, a, w3[1], MD4C01, MD4S13);
|
||||
MD4_STEP (MD4_Go, a, b, c, d, w0[2], MD4C01, MD4S10);
|
||||
MD4_STEP (MD4_Go, d, a, b, c, w1[2], MD4C01, MD4S11);
|
||||
MD4_STEP (MD4_Go, c, d, a, b, w2[2], MD4C01, MD4S12);
|
||||
MD4_STEP (MD4_Go, b, c, d, a, w3[2], MD4C01, MD4S13);
|
||||
MD4_STEP (MD4_Go, a, b, c, d, w0[3], MD4C01, MD4S10);
|
||||
MD4_STEP (MD4_Go, d, a, b, c, w1[3], MD4C01, MD4S11);
|
||||
MD4_STEP (MD4_Go, c, d, a, b, w2[3], MD4C01, MD4S12);
|
||||
MD4_STEP (MD4_Go, b, c, d, a, w3[3], MD4C01, MD4S13);
|
||||
|
||||
MD4_STEP (MD4_H , a, b, c, d, w0[0], MD4C02, MD4S20);
|
||||
MD4_STEP (MD4_H , d, a, b, c, w2[0], MD4C02, MD4S21);
|
||||
MD4_STEP (MD4_H , c, d, a, b, w1[0], MD4C02, MD4S22);
|
||||
MD4_STEP (MD4_H , b, c, d, a, w3[0], MD4C02, MD4S23);
|
||||
MD4_STEP (MD4_H , a, b, c, d, w0[2], MD4C02, MD4S20);
|
||||
MD4_STEP (MD4_H , d, a, b, c, w2[2], MD4C02, MD4S21);
|
||||
MD4_STEP (MD4_H , c, d, a, b, w1[2], MD4C02, MD4S22);
|
||||
MD4_STEP (MD4_H , b, c, d, a, w3[2], MD4C02, MD4S23);
|
||||
MD4_STEP (MD4_H , a, b, c, d, w0[1], MD4C02, MD4S20);
|
||||
MD4_STEP (MD4_H , d, a, b, c, w2[1], MD4C02, MD4S21);
|
||||
MD4_STEP (MD4_H , c, d, a, b, w1[1], MD4C02, MD4S22);
|
||||
MD4_STEP (MD4_H , b, c, d, a, w3[1], MD4C02, MD4S23);
|
||||
MD4_STEP (MD4_H , a, b, c, d, w0[3], MD4C02, MD4S20);
|
||||
MD4_STEP (MD4_H , d, a, b, c, w2[3], MD4C02, MD4S21);
|
||||
MD4_STEP (MD4_H , c, d, a, b, w1[3], MD4C02, MD4S22);
|
||||
MD4_STEP (MD4_H , b, c, d, a, w3[3], MD4C02, MD4S23);
|
||||
|
||||
digest[0] += a;
|
||||
digest[1] += b;
|
||||
digest[2] += c;
|
||||
digest[3] += d;
|
||||
}
|
Loading…
Reference in new issue