J. Gareth "Curious Kit" Moreton
|
6f24c8b4ef
* x86: Code generation fixes where FLAGS
|
vor 3 Jahren |
florian
|
637976e83f
* patch by Marģers to unify internal error numbers, resolves #37888
|
vor 5 Jahren |
florian
|
8c5606b41d
+ support mmx shifting
|
vor 7 Jahren |
florian
|
c1de51454c
ti386shlshrnode.second_64bit:
|
vor 7 Jahren |
nickysn
|
af235cae86
* use TEST CL,32 instead of TEST ECX,32 in the beginning of a 64-bit shl/shr
|
vor 8 Jahren |
nickysn
|
d7b8d8dd54
* don't emit the "SUB ECX,32" instruction on i386, when doing a 64-bit shift by
|
vor 8 Jahren |
nickysn
|
7e8c89435f
* avoid the AND instruction in the i386 shr64/shl64 code, by using TEST+JZ,
|
vor 8 Jahren |
nickysn
|
6580dfee39
* generate better i386 code for 64-bit shl/shr, by masking the shift count by
|
vor 8 Jahren |
sergei
|
5356f17fa5
* i386: switch the div/mod node to shared code, leaving in place the specific optimization for division by power of 2.
|
vor 11 Jahren |
sergei
|
ed46a07f62
* Using x86-specific capability of shifting with carry flag helps to reduce amount of instructions.
|
vor 11 Jahren |
sergei
|
92cf25b9a5
* Reworked i386 division by constant optimization to reuse code from powerpc64. The algorithm is slightly different, signed version is one instruction shorter, unsigned one is one instruction longer (typically). The new algorithm is easily scalable for x86_64 target, unlike the old one.
|
vor 11 Jahren |
Jonas Maebe
|
edd42aa42a
* moved subsetref/reg and bit_set/test support from cgobj to hlcgobj for
|
vor 13 Jahren |
Jonas Maebe
|
9ec3cc2022
* fixed sign of location.size for divmodn, 64 shlshrn and for muln
|
vor 18 Jahren |
daniel
|
9adb202a92
* Rework the constexprint to allow operations from low(int64) to high(qword).
|
vor 18 Jahren |
peter
|
658c46b903
* remove tdictionary and tindexarray
|
vor 19 Jahren |
florian
|
85d63d9fa9
* settings refactored
|
vor 19 Jahren |
peter
|
3078a1927f
* remove ttype
|
vor 19 Jahren |
peter
|
b7fe6797bf
Merged revisions 2921-2922,2925 via svnmerge from
|
vor 19 Jahren |
peter
|
588cccb3ca
* remove some obsolete i386 specific code
|
vor 19 Jahren |
peter
|
d8dc5679e3
* aktcputype and aktoptimizecputype was missing in the previous optimization commits
|
vor 19 Jahren |
peter
|
b6e35a200e
* rewrite of optimizer options
|
vor 19 Jahren |
peter
|
4bee83c736
* range check errors
|
vor 19 Jahren |
florian
|
bec0daebfa
+ optimized <dword> div <const dword>
|
vor 20 Jahren |
peter
|
5942d23b1b
* fix range error
|
vor 20 Jahren |
florian
|
3582108be1
* signed divisions with constants are always done without idiv
|
vor 20 Jahren |
peter
|
a3ab2053c9
* support multiple asmlabel types, renamed getlabel to
|
vor 20 Jahren |
fpc
|
790a4fe2d3
* log and id tags removed
|
vor 20 Jahren |
fpc
|
50778076c3
initial import
|
vor 20 Jahren |
peter
|
e417e34496
* truncate log
|
vor 20 Jahren |
peter
|
c95a859f0a
* generic tlocation
|
vor 21 Jahren |