aboutsummaryrefslogtreecommitdiff
path: root/src/Specific/montgomery32_2e521m1_17limbs
diff options
context:
space:
mode:
authorGravatar Jason Gross <jgross@mit.edu>2017-11-14 14:51:47 -0500
committerGravatar Jason Gross <jgross@mit.edu>2017-11-14 14:51:47 -0500
commitbf033f502453f9ccceb4366289cf4ea4e4de5371 (patch)
treeb7506b4643582511e999c8e7ee272f895f438f78 /src/Specific/montgomery32_2e521m1_17limbs
parentf75f4b93de64cac020b75ec14dfaf0df6a24be15 (diff)
Update display logs and c files
Diffstat (limited to 'src/Specific/montgomery32_2e521m1_17limbs')
-rw-r--r--src/Specific/montgomery32_2e521m1_17limbs/feadd.c106
-rw-r--r--src/Specific/montgomery32_2e521m1_17limbs/feaddDisplay.log59
-rw-r--r--src/Specific/montgomery32_2e521m1_17limbs/fenz.c37
-rw-r--r--src/Specific/montgomery32_2e521m1_17limbs/fenzDisplay.log23
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