84 lines
1.7 KiB
NASM
Raw Normal View History

2022-10-07 15:41:46 -07:00
/// F = f + f'z
/// G = g + g'z
///
/// h + h'z = FG
///
/// h = fg + sh(f'g')
/// h' = (f+f')(g+g') - fg - f'g'
2022-10-13 20:06:19 -04:00
///
2022-10-17 14:57:32 -04:00
/// Note: each symbol in the stack comments consists of six words
global test_mul_Fp6:
%mul_fp6
%jump(0xdeadbeef)
2022-10-13 20:06:19 -04:00
2022-10-17 11:02:24 -04:00
global test_mul_Fp12:
// stack: f, f', g, g'
%store_fp6(0)
%store_fp6(6)
%store_fp6(12)
%store_fp6(18)
PUSH return_on_stack
// stack: return_on_stack
%jump(mul_Fp12)
return_on_stack:
// stack:
%load_fp6(24)
%load_fp6(30)
// stack: h, h'
%jump(0xdeadbeef)
2022-10-13 20:06:19 -04:00
2022-10-07 15:41:46 -07:00
2022-10-17 11:02:24 -04:00
global mul_Fp12:
2022-10-07 15:41:46 -07:00
%load_fp6(6)
%load_fp6(18)
%dup2_fp6
%dup2_fp6
// stack: g', f', g', f'
%mul_fp6
%dup1_fp6
// stack: g'f', g'f', g', f'
%store_fp6_sh(36)
%store_fp6(42)
// stack: g', f'
%load_fp6(12)
// stack: g , g', f'
%swap_fp6
// stack: g', g , f'
%dup2_fp6
// stack: g , g', g , f'
%add_fp6
// stack: g + g', g , f'
2022-10-17 14:57:32 -04:00
%jump(0xdeadbeef)
2022-10-07 15:41:46 -07:00
%swap_fp6
// stack: g , g + g', f'
%load_fp6(0)
// stack: f, g , g'+ g , f'
%mul_fp6
%store_fp6(48)
// stack: g'+ g , f'
%swap_fp6
%load_fp6(0)
%add_fp6
// stack: f'+ f, g'+ g
%mul_fp6
// stack: (f+f')(g+g')
%load_fp6(42)
2022-10-17 11:02:24 -04:00
%bus_fp6
2022-10-07 15:41:46 -07:00
// stack: (f+f')(g+g') - f'g'
%load_fp6(48)
%swap_fp6
// stack: (f+f')(g+g') - f'g' , fg
%dup2_fp6
%bus_fp6
// stack: (f+f')(g+g') - f'g' - fg, fg
%store_fp6(30)
// stack: fg
%load_fp6(36)
// stack: sh(f'g') , fg
%add_fp6
// stack: sh(f'g') + fg
%store_fp6(24)
2022-10-17 11:02:24 -04:00
JUMP