FK20 CUDA
fp_x4.cuh
Go to the documentation of this file.
1 // bls12_381: Arithmetic for BLS12-381
2 // Copyright 2022-2023 Dag Arne Osvik
3 // Copyright 2022-2023 Luan Cardoso dos Santos
4 
5 #ifndef FP_X4
6 
11 #define FP_X4(Z, X) \
12  /* z = x + x */ \
13  \
14  "\n\tadd.u64.cc "#Z"0, "#X"0, "#X"0;" \
15  "\n\taddc.u64.cc "#Z"1, "#X"1, "#X"1;" \
16  "\n\taddc.u64.cc "#Z"2, "#X"2, "#X"2;" \
17  "\n\taddc.u64.cc "#Z"3, "#X"3, "#X"3;" \
18  "\n\taddc.u64.cc "#Z"4, "#X"4, "#X"4;" \
19  "\n\taddc.u64.cc "#Z"5, "#X"5, "#X"5;" \
20  "\n\taddc.u32 z6, 0, 0;" \
21  \
22  /* z = z + z */ \
23  \
24  "\n\tadd.u64.cc "#Z"0, "#Z"0, "#Z"0;" \
25  "\n\taddc.u64.cc "#Z"1, "#Z"1, "#Z"1;" \
26  "\n\taddc.u64.cc "#Z"2, "#Z"2, "#Z"2;" \
27  "\n\taddc.u64.cc "#Z"3, "#Z"3, "#Z"3;" \
28  "\n\taddc.u64.cc "#Z"4, "#Z"4, "#Z"4;" \
29  "\n\taddc.u64.cc "#Z"5, "#Z"5, "#Z"5;" \
30  "\n\taddc.u32 z6, z6, z6;" \
31  \
32  /* if z >= 2^385 then z -= 19m */ \
33  \
34  "\n\tsetp.gt.u32 gt, z6, 1;" \
35  "\n@gt\tsub.u64.cc "#Z"0, "#Z"0, 0xCDECFFFFFFF9AAB1U;" \
36  "\n@gt\tsubc.u64.cc "#Z"1, "#Z"1, 0x46C3FFE7293BFFFAU;" \
37  "\n@gt\tsubc.u64.cc "#Z"2, "#Z"2, 0xA89FA1F24F2244AEU;" \
38  "\n@gt\tsubc.u64.cc "#Z"3, "#Z"3, 0x74DA9ADE12E06434U;" \
39  "\n@gt\tsubc.u64.cc "#Z"4, "#Z"4, 0x930D7286FE9DD3FCU;" \
40  "\n@gt\tsubc.u64.cc "#Z"5, "#Z"5, 0xEE145462447E1D73U;" \
41  "\n@gt\tsubc.u32 z6, z6, 1;" \
42  \
43  /* if z >= 2^384 then z -= 9m */ \
44  \
45  "\n\tsetp.gt.u32 gt, z6, 0;" \
46  "\n@gt\tsub.u64.cc "#Z"0, "#Z"0, 0x89F6FFFFFFFD0003U;" \
47  "\n@gt\tsubc.u64.cc "#Z"1, "#Z"1, 0x140BFFF43BF3FFFDU;" \
48  "\n@gt\tsubc.u64.cc "#Z"2, "#Z"2, 0xA0B767A8AC38A745U;" \
49  "\n@gt\tsubc.u64.cc "#Z"3, "#Z"3, 0x8831A7AC8FADA8BAU;" \
50  "\n@gt\tsubc.u64.cc "#Z"4, "#Z"4, 0xA3F8E5685DA91392U;" \
51  "\n@gt\tsubc.u64.cc "#Z"5, "#Z"5, 0xEA09A13C057F1B6CU;" \
52  "\n@gt\tsubc.u32 z6, z6, 0;" \
53  \
54  /* if z >= 2^384 then z -= 9m */ \
55  \
56  "\n\tsetp.gt.u32 gt, z6, 0;" \
57  "\n@gt\tsub.u64.cc "#Z"0, "#Z"0, 0x89F6FFFFFFFD0003U;" \
58  "\n@gt\tsubc.u64.cc "#Z"1, "#Z"1, 0x140BFFF43BF3FFFDU;" \
59  "\n@gt\tsubc.u64.cc "#Z"2, "#Z"2, 0xA0B767A8AC38A745U;" \
60  "\n@gt\tsubc.u64.cc "#Z"3, "#Z"3, 0x8831A7AC8FADA8BAU;" \
61  "\n@gt\tsubc.u64.cc "#Z"4, "#Z"4, 0xA3F8E5685DA91392U;" \
62  "\n@gt\tsubc.u64.cc "#Z"5, "#Z"5, 0xEA09A13C057F1B6CU;"
63 
64 #endif