mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-01 17:32:36 +00:00
add a note
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@45766 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
07649d9265
commit
f61b63ec5b
@ -524,3 +524,24 @@ Investigate lowering of sparse switch statements into perfect hash tables:
|
||||
http://burtleburtle.net/bob/hash/perfect.html
|
||||
|
||||
//===---------------------------------------------------------------------===//
|
||||
|
||||
We should turn things like "load+fabs+store" and "load+fneg+store" into the
|
||||
corresponding integer operations. On a yonah, this loop:
|
||||
|
||||
double a[256];
|
||||
for (b = 0; b < 10000000; b++)
|
||||
for (i = 0; i < 256; i++)
|
||||
a[i] = -a[i];
|
||||
|
||||
is twice as slow as this loop:
|
||||
|
||||
long long a[256];
|
||||
for (b = 0; b < 10000000; b++)
|
||||
for (i = 0; i < 256; i++)
|
||||
a[i] ^= (1ULL << 63);
|
||||
|
||||
and I suspect other processors are similar. On X86 in particular this is a
|
||||
big win because doing this with integers allows the use of read/modify/write
|
||||
instructions.
|
||||
|
||||
//===---------------------------------------------------------------------===//
|
||||
|
Loading…
x
Reference in New Issue
Block a user