diff options
author | Jason Gross <jgross@mit.edu> | 2017-11-14 14:51:47 -0500 |
---|---|---|
committer | Jason Gross <jgross@mit.edu> | 2017-11-14 14:51:47 -0500 |
commit | bf033f502453f9ccceb4366289cf4ea4e4de5371 (patch) | |
tree | b7506b4643582511e999c8e7ee272f895f438f78 /src/Specific/montgomery32_2e521m1_17limbs | |
parent | f75f4b93de64cac020b75ec14dfaf0df6a24be15 (diff) |
Update display logs and c files
Diffstat (limited to 'src/Specific/montgomery32_2e521m1_17limbs')
4 files changed, 225 insertions, 0 deletions
diff --git a/src/Specific/montgomery32_2e521m1_17limbs/feadd.c b/src/Specific/montgomery32_2e521m1_17limbs/feadd.c new file mode 100644 index 000000000..7019270b1 --- /dev/null +++ b/src/Specific/montgomery32_2e521m1_17limbs/feadd.c @@ -0,0 +1,106 @@ +static void feadd(uint32_t out[17], const uint32_t in1[17], const uint32_t in2[17]) { + { const uint32_t x34 = in1[16]; + { const uint32_t x35 = in1[15]; + { const uint32_t x33 = in1[14]; + { const uint32_t x31 = in1[13]; + { const uint32_t x29 = in1[12]; + { const uint32_t x27 = in1[11]; + { const uint32_t x25 = in1[10]; + { const uint32_t x23 = in1[9]; + { const uint32_t x21 = in1[8]; + { const uint32_t x19 = in1[7]; + { const uint32_t x17 = in1[6]; + { const uint32_t x15 = in1[5]; + { const uint32_t x13 = in1[4]; + { const uint32_t x11 = in1[3]; + { const uint32_t x9 = in1[2]; + { const uint32_t x7 = in1[1]; + { const uint32_t x5 = in1[0]; + { const uint32_t x66 = in2[16]; + { const uint32_t x67 = in2[15]; + { const uint32_t x65 = in2[14]; + { const uint32_t x63 = in2[13]; + { const uint32_t x61 = in2[12]; + { const uint32_t x59 = in2[11]; + { const uint32_t x57 = in2[10]; + { const uint32_t x55 = in2[9]; + { const uint32_t x53 = in2[8]; + { const uint32_t x51 = in2[7]; + { const uint32_t x49 = in2[6]; + { const uint32_t x47 = in2[5]; + { const uint32_t x45 = in2[4]; + { const uint32_t x43 = in2[3]; + { const uint32_t x41 = in2[2]; + { const uint32_t x39 = in2[1]; + { const uint32_t x37 = in2[0]; + { uint32_t x69; uint8_t x70 = _addcarryx_u32(0x0, x5, x37, &x69); + { uint32_t x72; uint8_t x73 = _addcarryx_u32(x70, x7, x39, &x72); + { uint32_t x75; uint8_t x76 = _addcarryx_u32(x73, x9, x41, &x75); + { uint32_t x78; uint8_t x79 = _addcarryx_u32(x76, x11, x43, &x78); + { uint32_t x81; uint8_t x82 = _addcarryx_u32(x79, x13, x45, &x81); + { uint32_t x84; uint8_t x85 = _addcarryx_u32(x82, x15, x47, &x84); + { uint32_t x87; uint8_t x88 = _addcarryx_u32(x85, x17, x49, &x87); + { uint32_t x90; uint8_t x91 = _addcarryx_u32(x88, x19, x51, &x90); + { uint32_t x93; uint8_t x94 = _addcarryx_u32(x91, x21, x53, &x93); + { uint32_t x96; uint8_t x97 = _addcarryx_u32(x94, x23, x55, &x96); + { uint32_t x99; uint8_t x100 = _addcarryx_u32(x97, x25, x57, &x99); + { uint32_t x102; uint8_t x103 = _addcarryx_u32(x100, x27, x59, &x102); + { uint32_t x105; uint8_t x106 = _addcarryx_u32(x103, x29, x61, &x105); + { uint32_t x108; uint8_t x109 = _addcarryx_u32(x106, x31, x63, &x108); + { uint32_t x111; uint8_t x112 = _addcarryx_u32(x109, x33, x65, &x111); + { uint32_t x114; uint8_t x115 = _addcarryx_u32(x112, x35, x67, &x114); + { uint32_t x117; uint8_t x118 = _addcarryx_u32(x115, x34, x66, &x117); + { uint32_t x120; uint8_t x121 = _subborrow_u32(0x0, x69, 0xffffffff, &x120); + { uint32_t x123; uint8_t x124 = _subborrow_u32(x121, x72, 0xffffffff, &x123); + { uint32_t x126; uint8_t x127 = _subborrow_u32(x124, x75, 0xffffffff, &x126); + { uint32_t x129; uint8_t x130 = _subborrow_u32(x127, x78, 0xffffffff, &x129); + { uint32_t x132; uint8_t x133 = _subborrow_u32(x130, x81, 0xffffffff, &x132); + { uint32_t x135; uint8_t x136 = _subborrow_u32(x133, x84, 0xffffffff, &x135); + { uint32_t x138; uint8_t x139 = _subborrow_u32(x136, x87, 0xffffffff, &x138); + { uint32_t x141; uint8_t x142 = _subborrow_u32(x139, x90, 0xffffffff, &x141); + { uint32_t x144; uint8_t x145 = _subborrow_u32(x142, x93, 0xffffffff, &x144); + { uint32_t x147; uint8_t x148 = _subborrow_u32(x145, x96, 0xffffffff, &x147); + { uint32_t x150; uint8_t x151 = _subborrow_u32(x148, x99, 0xffffffff, &x150); + { uint32_t x153; uint8_t x154 = _subborrow_u32(x151, x102, 0xffffffff, &x153); + { uint32_t x156; uint8_t x157 = _subborrow_u32(x154, x105, 0xffffffff, &x156); + { uint32_t x159; uint8_t x160 = _subborrow_u32(x157, x108, 0xffffffff, &x159); + { uint32_t x162; uint8_t x163 = _subborrow_u32(x160, x111, 0xffffffff, &x162); + { uint32_t x165; uint8_t x166 = _subborrow_u32(x163, x114, 0xffffffff, &x165); + { uint32_t x168; uint8_t x169 = _subborrow_u32(x166, x117, 0x1ff, &x168); + { uint32_t _; uint8_t x172 = _subborrow_u32(x169, x118, 0x0, &_); + { uint32_t x173 = cmovznz32(x172, x168, x117); + { uint32_t x174 = cmovznz32(x172, x165, x114); + { uint32_t x175 = cmovznz32(x172, x162, x111); + { uint32_t x176 = cmovznz32(x172, x159, x108); + { uint32_t x177 = cmovznz32(x172, x156, x105); + { uint32_t x178 = cmovznz32(x172, x153, x102); + { uint32_t x179 = cmovznz32(x172, x150, x99); + { uint32_t x180 = cmovznz32(x172, x147, x96); + { uint32_t x181 = cmovznz32(x172, x144, x93); + { uint32_t x182 = cmovznz32(x172, x141, x90); + { uint32_t x183 = cmovznz32(x172, x138, x87); + { uint32_t x184 = cmovznz32(x172, x135, x84); + { uint32_t x185 = cmovznz32(x172, x132, x81); + { uint32_t x186 = cmovznz32(x172, x129, x78); + { uint32_t x187 = cmovznz32(x172, x126, x75); + { uint32_t x188 = cmovznz32(x172, x123, x72); + { uint32_t x189 = cmovznz32(x172, x120, x69); + out[0] = x189; + out[1] = x188; + out[2] = x187; + out[3] = x186; + out[4] = x185; + out[5] = x184; + out[6] = x183; + out[7] = x182; + out[8] = x181; + out[9] = x180; + out[10] = x179; + out[11] = x178; + out[12] = x177; + out[13] = x176; + out[14] = x175; + out[15] = x174; + out[16] = x173; + }}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}} +} diff --git a/src/Specific/montgomery32_2e521m1_17limbs/feaddDisplay.log b/src/Specific/montgomery32_2e521m1_17limbs/feaddDisplay.log new file mode 100644 index 000000000..0dbd5526d --- /dev/null +++ b/src/Specific/montgomery32_2e521m1_17limbs/feaddDisplay.log @@ -0,0 +1,59 @@ +λ x x0 : word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32, +Interp-η +(λ var : Syntax.base_type → Type, + λ '(x34, x35, x33, x31, x29, x27, x25, x23, x21, x19, x17, x15, x13, x11, x9, x7, x5, (x66, x67, x65, x63, x61, x59, x57, x55, x53, x51, x49, x47, x45, x43, x41, x39, x37))%core, + uint32_t x69, uint8_t x70 = addcarryx_u32(0x0, x5, x37); + uint32_t x72, uint8_t x73 = addcarryx_u32(x70, x7, x39); + uint32_t x75, uint8_t x76 = addcarryx_u32(x73, x9, x41); + uint32_t x78, uint8_t x79 = addcarryx_u32(x76, x11, x43); + uint32_t x81, uint8_t x82 = addcarryx_u32(x79, x13, x45); + uint32_t x84, uint8_t x85 = addcarryx_u32(x82, x15, x47); + uint32_t x87, uint8_t x88 = addcarryx_u32(x85, x17, x49); + uint32_t x90, uint8_t x91 = addcarryx_u32(x88, x19, x51); + uint32_t x93, uint8_t x94 = addcarryx_u32(x91, x21, x53); + uint32_t x96, uint8_t x97 = addcarryx_u32(x94, x23, x55); + uint32_t x99, uint8_t x100 = addcarryx_u32(x97, x25, x57); + uint32_t x102, uint8_t x103 = addcarryx_u32(x100, x27, x59); + uint32_t x105, uint8_t x106 = addcarryx_u32(x103, x29, x61); + uint32_t x108, uint8_t x109 = addcarryx_u32(x106, x31, x63); + uint32_t x111, uint8_t x112 = addcarryx_u32(x109, x33, x65); + uint32_t x114, uint8_t x115 = addcarryx_u32(x112, x35, x67); + uint32_t x117, uint8_t x118 = addcarryx_u32(x115, x34, x66); + uint32_t x120, uint8_t x121 = subborrow_u32(0x0, x69, 0xffffffff); + uint32_t x123, uint8_t x124 = subborrow_u32(x121, x72, 0xffffffff); + uint32_t x126, uint8_t x127 = subborrow_u32(x124, x75, 0xffffffff); + uint32_t x129, uint8_t x130 = subborrow_u32(x127, x78, 0xffffffff); + uint32_t x132, uint8_t x133 = subborrow_u32(x130, x81, 0xffffffff); + uint32_t x135, uint8_t x136 = subborrow_u32(x133, x84, 0xffffffff); + uint32_t x138, uint8_t x139 = subborrow_u32(x136, x87, 0xffffffff); + uint32_t x141, uint8_t x142 = subborrow_u32(x139, x90, 0xffffffff); + uint32_t x144, uint8_t x145 = subborrow_u32(x142, x93, 0xffffffff); + uint32_t x147, uint8_t x148 = subborrow_u32(x145, x96, 0xffffffff); + uint32_t x150, uint8_t x151 = subborrow_u32(x148, x99, 0xffffffff); + uint32_t x153, uint8_t x154 = subborrow_u32(x151, x102, 0xffffffff); + uint32_t x156, uint8_t x157 = subborrow_u32(x154, x105, 0xffffffff); + uint32_t x159, uint8_t x160 = subborrow_u32(x157, x108, 0xffffffff); + uint32_t x162, uint8_t x163 = subborrow_u32(x160, x111, 0xffffffff); + uint32_t x165, uint8_t x166 = subborrow_u32(x163, x114, 0xffffffff); + uint32_t x168, uint8_t x169 = subborrow_u32(x166, x117, 0x1ff); + uint32_t _, uint8_t x172 = subborrow_u32(x169, x118, 0x0); + uint32_t x173 = cmovznz32(x172, x168, x117); + uint32_t x174 = cmovznz32(x172, x165, x114); + uint32_t x175 = cmovznz32(x172, x162, x111); + uint32_t x176 = cmovznz32(x172, x159, x108); + uint32_t x177 = cmovznz32(x172, x156, x105); + uint32_t x178 = cmovznz32(x172, x153, x102); + uint32_t x179 = cmovznz32(x172, x150, x99); + uint32_t x180 = cmovznz32(x172, x147, x96); + uint32_t x181 = cmovznz32(x172, x144, x93); + uint32_t x182 = cmovznz32(x172, x141, x90); + uint32_t x183 = cmovznz32(x172, x138, x87); + uint32_t x184 = cmovznz32(x172, x135, x84); + uint32_t x185 = cmovznz32(x172, x132, x81); + uint32_t x186 = cmovznz32(x172, x129, x78); + uint32_t x187 = cmovznz32(x172, x126, x75); + uint32_t x188 = cmovznz32(x172, x123, x72); + uint32_t x189 = cmovznz32(x172, x120, x69); + return (x173, x174, x175, x176, x177, x178, x179, x180, x181, x182, x183, x184, x185, x186, x187, x188, x189)) +(x, x0)%core + : word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 → word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 → ReturnType (uint32_t * uint32_t * uint32_t * uint32_t * uint32_t * uint32_t * uint32_t * uint32_t * uint32_t * uint32_t * uint32_t * uint32_t * uint32_t * uint32_t * uint32_t * uint32_t * uint32_t) diff --git a/src/Specific/montgomery32_2e521m1_17limbs/fenz.c b/src/Specific/montgomery32_2e521m1_17limbs/fenz.c new file mode 100644 index 000000000..fdbe458c3 --- /dev/null +++ b/src/Specific/montgomery32_2e521m1_17limbs/fenz.c @@ -0,0 +1,37 @@ +static void fenz(ReturnType uint32_t out[1], const uint32_t in1[17]) { + { const uint32_t x31 = in1[16]; + { const uint32_t x32 = in1[15]; + { const uint32_t x30 = in1[14]; + { const uint32_t x28 = in1[13]; + { const uint32_t x26 = in1[12]; + { const uint32_t x24 = in1[11]; + { const uint32_t x22 = in1[10]; + { const uint32_t x20 = in1[9]; + { const uint32_t x18 = in1[8]; + { const uint32_t x16 = in1[7]; + { const uint32_t x14 = in1[6]; + { const uint32_t x12 = in1[5]; + { const uint32_t x10 = in1[4]; + { const uint32_t x8 = in1[3]; + { const uint32_t x6 = in1[2]; + { const uint32_t x4 = in1[1]; + { const uint32_t x2 = in1[0]; + { uint32_t x33 = (x32 | x31); + { uint32_t x34 = (x30 | x33); + { uint32_t x35 = (x28 | x34); + { uint32_t x36 = (x26 | x35); + { uint32_t x37 = (x24 | x36); + { uint32_t x38 = (x22 | x37); + { uint32_t x39 = (x20 | x38); + { uint32_t x40 = (x18 | x39); + { uint32_t x41 = (x16 | x40); + { uint32_t x42 = (x14 | x41); + { uint32_t x43 = (x12 | x42); + { uint32_t x44 = (x10 | x43); + { uint32_t x45 = (x8 | x44); + { uint32_t x46 = (x6 | x45); + { uint32_t x47 = (x4 | x46); + { uint32_t x48 = (x2 | x47); + out[0] = x48; + }}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}} +} diff --git a/src/Specific/montgomery32_2e521m1_17limbs/fenzDisplay.log b/src/Specific/montgomery32_2e521m1_17limbs/fenzDisplay.log new file mode 100644 index 000000000..47cc8d6b2 --- /dev/null +++ b/src/Specific/montgomery32_2e521m1_17limbs/fenzDisplay.log @@ -0,0 +1,23 @@ +λ x : word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32, +Interp-η +(λ var : Syntax.base_type → Type, + λ '(x31, x32, x30, x28, x26, x24, x22, x20, x18, x16, x14, x12, x10, x8, x6, x4, x2)%core, + uint32_t x33 = (x32 | x31); + uint32_t x34 = (x30 | x33); + uint32_t x35 = (x28 | x34); + uint32_t x36 = (x26 | x35); + uint32_t x37 = (x24 | x36); + uint32_t x38 = (x22 | x37); + uint32_t x39 = (x20 | x38); + uint32_t x40 = (x18 | x39); + uint32_t x41 = (x16 | x40); + uint32_t x42 = (x14 | x41); + uint32_t x43 = (x12 | x42); + uint32_t x44 = (x10 | x43); + uint32_t x45 = (x8 | x44); + uint32_t x46 = (x6 | x45); + uint32_t x47 = (x4 | x46); + uint32_t x48 = (x2 | x47); + return x48) +x + : word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 * word32 → ReturnType uint32_t |