diff options
Diffstat (limited to 'vere/ext/gmp/gen/x86_64-windows/mpn/sqr_diag_addlsh1.s')
-rw-r--r-- | vere/ext/gmp/gen/x86_64-windows/mpn/sqr_diag_addlsh1.s | 140 |
1 files changed, 140 insertions, 0 deletions
diff --git a/vere/ext/gmp/gen/x86_64-windows/mpn/sqr_diag_addlsh1.s b/vere/ext/gmp/gen/x86_64-windows/mpn/sqr_diag_addlsh1.s new file mode 100644 index 0000000..77831dd --- /dev/null +++ b/vere/ext/gmp/gen/x86_64-windows/mpn/sqr_diag_addlsh1.s @@ -0,0 +1,140 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + .text + .align 32, 0x90 + .globl __gmpn_sqr_diag_addlsh1 + + .def __gmpn_sqr_diag_addlsh1 + .scl 2 + .type 32 + .endef +__gmpn_sqr_diag_addlsh1: + + push %rdi + push %rsi + mov %rcx, %rdi + mov %rdx, %rsi + mov %r8, %rdx + mov %r9, %rcx + + push %rbx + + dec %rcx + shl %rcx + + mov (%rdx), %rax + + lea (%rdi,%rcx,8), %rdi + lea (%rsi,%rcx,8), %rsi + lea (%rdx,%rcx,4), %r11 + neg %rcx + + mul %rax + mov %rax, (%rdi,%rcx,8) + + xor %ebx, %ebx + jmp Lmid + + .align 16, 0x90 +Ltop: add %r10, %r8 + adc %rax, %r9 + mov %r8, -8(%rdi,%rcx,8) + mov %r9, (%rdi,%rcx,8) +Lmid: mov 8(%r11,%rcx,4), %rax + mov (%rsi,%rcx,8), %r8 + mov 8(%rsi,%rcx,8), %r9 + adc %r8, %r8 + adc %r9, %r9 + lea (%rdx,%rbx), %r10 + setc %bl + mul %rax + add $2, %rcx + js Ltop + +Lend: add %r10, %r8 + adc %rax, %r9 + mov %r8, -8(%rdi) + mov %r9, (%rdi) + adc %rbx, %rdx + mov %rdx, 8(%rdi) + + pop %rbx + pop %rsi + pop %rdi + ret + |