2019-10-06 19:24:05 +08:00
|
|
|
const builtin = @import("builtin");
|
|
|
|
|
|
|
|
pub extern stdcallcc fn _alldiv(a: i64, b: i64) i64 {
|
|
|
|
@setRuntimeSafety(builtin.is_test);
|
|
|
|
const s_a = a >> (i64.bit_count - 1);
|
|
|
|
const s_b = b >> (i64.bit_count - 1);
|
|
|
|
|
|
|
|
const an = (a ^ s_a) -% s_a;
|
|
|
|
const bn = (b ^ s_b) -% s_b;
|
|
|
|
|
|
|
|
const r = @bitCast(u64, an) / @bitCast(u64, bn);
|
|
|
|
const s = s_a ^ s_b;
|
|
|
|
return (@bitCast(i64, r) ^ s) -% s;
|
|
|
|
}
|
|
|
|
|
2018-01-25 17:10:11 +08:00
|
|
|
pub nakedcc fn _aulldiv() void {
|
2018-01-25 14:46:12 +08:00
|
|
|
@setRuntimeSafety(false);
|
2019-10-06 19:24:05 +08:00
|
|
|
|
|
|
|
// The stack layout is:
|
|
|
|
// ESP+16 divisor (hi)
|
|
|
|
// ESP+12 divisor (low)
|
|
|
|
// ESP+8 dividend (hi)
|
|
|
|
// ESP+4 dividend (low)
|
|
|
|
// ESP return address
|
|
|
|
|
2017-12-18 22:59:57 +08:00
|
|
|
asm volatile (
|
2019-10-06 19:24:05 +08:00
|
|
|
\\ push %%ebx
|
|
|
|
\\ push %%esi
|
|
|
|
\\ mov 0x18(%%esp),%%eax
|
|
|
|
\\ or %%eax,%%eax
|
|
|
|
\\ jne 1f
|
|
|
|
\\ mov 0x14(%%esp),%%ecx
|
|
|
|
\\ mov 0x10(%%esp),%%eax
|
|
|
|
\\ xor %%edx,%%edx
|
|
|
|
\\ div %%ecx
|
|
|
|
\\ mov %%eax,%%ebx
|
|
|
|
\\ mov 0xc(%%esp),%%eax
|
|
|
|
\\ div %%ecx
|
|
|
|
\\ mov %%ebx,%%edx
|
|
|
|
\\ jmp 5f
|
|
|
|
\\ 1:
|
|
|
|
\\ mov %%eax,%%ecx
|
|
|
|
\\ mov 0x14(%%esp),%%ebx
|
|
|
|
\\ mov 0x10(%%esp),%%edx
|
|
|
|
\\ mov 0xc(%%esp),%%eax
|
|
|
|
\\ 2:
|
|
|
|
\\ shr %%ecx
|
|
|
|
\\ rcr %%ebx
|
|
|
|
\\ shr %%edx
|
|
|
|
\\ rcr %%eax
|
|
|
|
\\ or %%ecx,%%ecx
|
|
|
|
\\ jne 2b
|
|
|
|
\\ div %%ebx
|
|
|
|
\\ mov %%eax,%%esi
|
|
|
|
\\ mull 0x18(%%esp)
|
|
|
|
\\ mov %%eax,%%ecx
|
|
|
|
\\ mov 0x14(%%esp),%%eax
|
|
|
|
\\ mul %%esi
|
|
|
|
\\ add %%ecx,%%edx
|
|
|
|
\\ jb 3f
|
|
|
|
\\ cmp 0x10(%%esp),%%edx
|
|
|
|
\\ ja 3f
|
|
|
|
\\ jb 4f
|
|
|
|
\\ cmp 0xc(%%esp),%%eax
|
|
|
|
\\ jbe 4f
|
|
|
|
\\ 3:
|
|
|
|
\\ dec %%esi
|
|
|
|
\\ 4:
|
|
|
|
\\ xor %%edx,%%edx
|
|
|
|
\\ mov %%esi,%%eax
|
|
|
|
\\ 5:
|
|
|
|
\\ pop %%esi
|
|
|
|
\\ pop %%ebx
|
|
|
|
\\ ret $0x10
|
2017-12-18 22:59:57 +08:00
|
|
|
);
|
2017-10-01 01:58:05 +08:00
|
|
|
}
|