Advertisement
Guest User

xform

a guest
May 16th, 2014
257
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C 3.76 KB | None | 0 0
  1. void f(uint64_t x[8])
  2. {
  3.     uint64_t a, b, c, d, e, f, g, h;
  4.     a = 0x243F6A8885A308D3 + x[0]; a=rotl(a, 3);
  5.     b = 0x13198A2E03707344 + x[1]; b=rotl(b, 5);
  6.     c = 0xA4093822299F31D0 + x[2]; c=rotl(c, 7);
  7.     d = 0x082EFA98EC4E6C89 + x[3]; d=rotl(d,11);
  8.     e = 0x452821E638D01377 + x[4]; e=rotl(e,13);
  9.     f = 0xBE5466CF34E90C6C + x[5]; f=rotl(f,17);
  10.     g = 0xC0AC29B7C97C50DD + x[6]; g=rotl(g,19);
  11.     h = 0x3F84D5B5B5470917 + x[7]; h=rotl(h,23);
  12.  
  13.     r(e,a,b,c,d,41,21,17,29);
  14.     r(f,b,c,d,a,33,49, 1,17);
  15.     r(g,c,d,a,b,41,11,17, 3);
  16.     r(h,d,a,b,c,17, 7,33,55);
  17.  
  18.     r(a,e,f,g,h, 9,27,17,51);
  19.     r(b,f,g,h,e,25,61,49,53);
  20.     r(c,g,h,e,f,49,23,33,39);
  21.     r(d,h,e,f,g,57,51,49,27);
  22.  
  23.     e += 0x9216D5D98979FB1B; e=rotl(e,47);
  24.     f += 0xD1310BA698DFB5AC; f=rotl(f,53);
  25.     g += 0x2FFD72DBD01ADFB7; g=rotl(g,59);
  26.     h += 0xB8E1AFED6A267E96; h=rotl(h,61);
  27.  
  28.     r(e,a,b,c,d,33,15, 1,47);
  29.     r(f,b,c,d,a,57,13,49,37);
  30.     r(g,c,d,a,b,25, 3,49,11);
  31.     r(h,d,a,b,c, 9,37,17,13);
  32.    
  33.     a += 0xBA7C9045F12C7F99; a=rotl(a,29);
  34.     b += 0x24A19947B3916CF7; b=rotl(b,37);
  35.     c += 0x0801F2E2858EFC16; c=rotl(c,41);
  36.     d += 0x636920D871574E69; d=rotl(d,43);
  37.  
  38.     r(a,e,f,g,h, 9, 5,17,45);
  39.     r(b,f,g,h,e,25,29,49,21);
  40.     r(c,g,h,e,f,17,57,33, 9);
  41.     r(d,h,e,f,g,57,19,49,59);
  42.  
  43.     e += 0xA458FEA3F4933D7E; e=rotl(e, 3);
  44.     f += 0x0D95748F728EB658; f=rotl(f, 5);
  45.     g += 0x718BCD5882154AEE; g=rotl(g, 7);
  46.     h += 0x7B54A41DC25A59B5; h=rotl(h,11);
  47.  
  48.     r(e,a,b,c,d, 9,27,17,51);
  49.     r(f,b,c,d,a,25,61,49,53);
  50.     r(g,c,d,a,b,49,23,33,39);
  51.     r(h,d,a,b,c,57,51,49,28);
  52.    
  53.     a += 0x9C30D5392AF26013; a=rotl(a,13);
  54.     b += 0xC5D1B023286085F0; b=rotl(b,17);
  55.     c += 0xCA417918B8DB38EF; c=rotl(c,19);
  56.     d += 0x8E79DCB0603A180E; d=rotl(d,23);
  57.  
  58.     r(a,e,f,g,h,41,21,17,29);
  59.     r(b,f,g,h,e,33,49, 1,17);
  60.     r(c,g,h,e,f,41,11,17, 3);
  61.     r(d,h,e,f,g,17, 7,33,55);
  62.  
  63.     x[0] = a;
  64.     x[1] = b;
  65.     x[2] = c;
  66.     x[3] = d;
  67.     x[4] = e;
  68.     x[5] = f;
  69.     x[6] = g;
  70.     x[7] = h;
  71. }
  72.  
  73.  
  74. void finv(uint64_t x[8])
  75. {
  76.     uint64_t a, b, c, d, e, f, g, h;
  77.  
  78.     a = x[0];
  79.     b = x[1];
  80.     c = x[2];
  81.     d = x[3];
  82.     e = x[4];
  83.     f = x[5];
  84.     g = x[6];
  85.     h = x[7];
  86.  
  87.     rinv(a,e,f,g,h,41,21,17,29);
  88.     rinv(b,f,g,h,e,33,49, 1,17);
  89.     rinv(c,g,h,e,f,41,11,17, 3);
  90.     rinv(d,h,e,f,g,17, 7,33,55);
  91.  
  92.     a=rotr(a,13);a -= 0x9C30D5392AF26013;
  93.     b=rotr(b,17);b -= 0xC5D1B023286085F0;
  94.     c=rotr(c,19);c -= 0xCA417918B8DB38EF;
  95.     d=rotr(d,23);d -= 0x8E79DCB0603A180E;
  96.    
  97.     rinv(e,a,b,c,d, 9,27,17,51);
  98.     rinv(f,b,c,d,a,25,61,49,53);
  99.     rinv(g,c,d,a,b,49,23,33,39);
  100.     rinv(h,d,a,b,c,57,51,49,28);
  101.  
  102.     e=rotr(e, 3); e -= 0xA458FEA3F4933D7E;
  103.     f=rotr(f, 5); f -= 0x0D95748F728EB658;
  104.     g=rotr(g, 7); g -= 0x718BCD5882154AEE;
  105.     h=rotr(h,11); h -= 0x7B54A41DC25A59B5;
  106.  
  107.     rinv(a,e,f,g,h, 9, 5,17,45);
  108.     rinv(b,f,g,h,e,25,29,49,21);
  109.     rinv(c,g,h,e,f,17,57,33, 9);
  110.     rinv(d,h,e,f,g,57,19,49,59);
  111.    
  112.     a=rotr(a,29); a -= 0xBA7C9045F12C7F99;
  113.     b=rotr(b,37); b -= 0x24A19947B3916CF7;
  114.     c=rotr(c,41); c -= 0x0801F2E2858EFC16;
  115.     d=rotr(d,43); d -= 0x636920D871574E69;
  116.  
  117.     rinv(e,a,b,c,d,33,15, 1,47);
  118.     rinv(f,b,c,d,a,57,13,49,37);
  119.     rinv(g,c,d,a,b,25, 3,49,11);
  120.     rinv(h,d,a,b,c, 9,37,17,13);
  121.  
  122.     e=rotr(e,47); e -= 0x9216D5D98979FB1B;
  123.     f=rotr(f,53); f -= 0xD1310BA698DFB5AC;
  124.     g=rotr(g,59); g -= 0x2FFD72DBD01ADFB7;
  125.     h=rotr(h,61); h -= 0xB8E1AFED6A267E96;
  126.  
  127.     rinv(a,e,f,g,h, 9,27,17,51);
  128.     rinv(b,f,g,h,e,25,61,49,53);
  129.     rinv(c,g,h,e,f,49,23,33,39);
  130.     rinv(d,h,e,f,g,57,51,49,27);
  131.  
  132.     rinv(e,a,b,c,d,41,21,17,29);
  133.     rinv(f,b,c,d,a,33,49, 1,17);
  134.     rinv(g,c,d,a,b,41,11,17, 3);
  135.     rinv(h,d,a,b,c,17, 7,33,55);
  136.  
  137.     a=rotr(a, 3); x[0] = a - 0x243F6A8885A308D3;
  138.     b=rotr(b, 5); x[1] = b - 0x13198A2E03707344;
  139.     c=rotr(c, 7); x[2] = c - 0xA4093822299F31D0;
  140.     d=rotr(d,11); x[3] = d - 0x082EFA98EC4E6C89;
  141.     e=rotr(e,13); x[4] = e - 0x452821E638D01377;
  142.     f=rotr(f,17); x[5] = f - 0xBE5466CF34E90C6C;
  143.     g=rotr(g,19); x[6] = g - 0xC0AC29B7C97C50DD;
  144.     h=rotr(h,23); x[7] = h - 0x3F84D5B5B5470917;
  145. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement