..
aasmcpu.pas
* synchronized with trunk up to r27758
2014-05-12 16:12:34 +00:00
agx86att.pas
Separate out nasm assembler for i8086, i386 and x86_64 cpus, also separte based on target object format
2014-01-21 00:26:08 +00:00
agx86int.pas
* grouped all tai_real* types into a single tai_realconst type,
2014-07-01 16:29:58 +00:00
agx86nsm.pas
* grouped all tai_real* types into a single tai_realconst type,
2014-07-01 16:29:58 +00:00
cga.pas
+ support for FMA intrinsic: if there is no hardware support, the compiler throws an error.
2014-04-13 19:21:54 +00:00
cgx86.pas
* Tcgx86.g_concatcopy: optimization for the case where source.segment is
2014-05-02 13:07:54 +00:00
cpubase.pas
+ Implemented IEEE 754-compliant checking for unordered results of floating-point compares on x86 targets. Mantis #9362 .
2014-04-14 12:36:11 +00:00
hlcgx86.pas
itcpugas.pas
* command line compilation of i8086 fixed
2013-04-21 18:32:09 +00:00
itx86int.pas
* merge i8086 branch by Nikolay Nikolov
2013-04-25 20:23:51 +00:00
ni86mem.pas
* isolated segment-related functionality of tabsolutevarsym into i386/i8086-
2014-03-30 15:42:53 +00:00
nx86add.pas
* i386: For integer comparisons with zero, emit "test $-1,%reg" instead of "test %reg,%reg". It is more spilling-friendly, because it transforms into "test $-1,spilltemp" and does not require a register.
2014-04-20 19:16:58 +00:00
nx86cal.pas
* pass a list of (pointers to) the paralocs to hlcgobj.a_call/g_call*, as
2014-03-06 21:40:57 +00:00
nx86cnv.pas
* x86: improve x87 qword to float conversion, using single-precision constants saves space and removes need in separate load on FPU stack. No precision loss occurs because 2**64 is representable exactly even in single precision.
2014-03-03 20:41:42 +00:00
nx86con.pas
nx86inl.pas
+ make use of vfnmsub*/vfmsub*/vfnmadd* instructions if possible
2014-05-02 21:07:46 +00:00
nx86mat.pas
* create shorter code for -<single/double> when generating avx code
2014-03-29 19:35:41 +00:00
nx86mem.pas
* synchronized with trunk up to r27758
2014-05-12 16:12:34 +00:00
nx86set.pas
* Use GOT-relative constants for i386 PIC jump tables, they don't need runtime relocations. Now almost ABI-compliant on Linux/BSD (Darwin targets unchanged). Also clean up i8086-specific stuff: using tai_const.create_type_sym(aitconst_ptr,...) generates near pointers on i8086, which is the desired goal.
2014-03-03 21:06:49 +00:00
rax86.pas
* merged avx2 branch, developed by Torsten Grundke
2014-03-20 12:03:52 +00:00
rax86att.pas
* properly propagate PIC-related suffixes from the x86 assembler reader in
2013-05-30 12:20:48 +00:00
rax86int.pas
* Moved local label infrastructure into tasmreader, reduces number of global vars. Functionality is not changed.
2014-04-05 09:43:13 +00:00
rgx86.pas
* synchronised with trunk up till r26975
2014-03-06 21:36:58 +00:00
symi86.pas
* i8086 and i386-specific code from tabstractprocdef.is_pushleftright moved to
2014-04-12 15:34:08 +00:00
symx86.pas
+ symx86 unit, forgot to commit (part of r27397)
2014-03-30 22:03:55 +00:00
x86ins.dat
+ prove of concept how FMA4 could be supported in inline assembler
2014-03-20 21:25:38 +00:00
x86reg.dat
* x86 targets: Profiling shows that quite a bit of time is spent in findreg_by_number(), despite it uses binary search. Worse, it is repeated for every piece of register information. Trying to get rid of some of these calls: rearranged registers so that their "opcode" matches 3 LSBs of superregister number (with a few exceptions described at the beginning of x86reg.dat). This allows to lookup opcodes in regval() with O(1) complexity, and removes need in rXXXop.inc files.
2013-10-03 08:08:04 +00:00