mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-03-21 03:32:29 +00:00
Optimize 96-bit division a little bit.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@136222 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
636a02b57c
commit
ffcc2a542c
@ -46,8 +46,9 @@ void mult96bit(uint64_t freq, uint32_t N, uint64_t W[2]) {
|
||||
uint64_t div96bit(uint64_t W[2], uint32_t D) {
|
||||
uint64_t y = W[0];
|
||||
uint64_t x = W[1];
|
||||
int i;
|
||||
|
||||
for (int i = 1; i <= 64; ++i) {
|
||||
for (i = 1; i <= 64 && x; ++i) {
|
||||
uint32_t t = (int)x >> 31;
|
||||
x = (x << 1) | (y >> 63);
|
||||
y = y << 1;
|
||||
@ -57,7 +58,7 @@ uint64_t div96bit(uint64_t W[2], uint32_t D) {
|
||||
}
|
||||
}
|
||||
|
||||
return y;
|
||||
return y << (64 - i + 1);
|
||||
}
|
||||
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user