Pierre Muller
e1b3c03daf
Add test for mips code generation bug
2022-10-29 21:34:00 +01:00
Pierre Muller
dce70b3b70
Short version of the mips code genration bug
2022-10-29 21:34:00 +01:00
marcoonthegit
f9a76aaa56
* Add AMPM to string, patch from closes #39973
2022-10-29 16:12:40 +02:00
Jonas Maebe
f18524f2fe
Darwin: fix mac0S 11.0 version string
...
Prevents LLVM warnings
2022-10-29 14:24:37 +02:00
Jonas Maebe
cd8ddffe42
AArch64: X18 is not a volatile register
...
It may be unused on some platforms, but in general it's reserved for OS library
usage (usually related to TLS)
2022-10-29 14:24:37 +02:00
Jonas Maebe
49fb1b4c29
RTTI: don't generate full RTTI for internal types
...
These are types created by the code generator for internal purposes, and hence
are never queried by user code
2022-10-29 14:24:37 +02:00
Sven/Sarah Barth
f0e31628ad
* ensure that hmodule is initialized correctly
2022-10-29 12:15:59 +02:00
Sven/Sarah Barth
e050a019a2
* fix #29859 : ensure that it's correctly passed down into generate_specialization whether a unit name was provided for the specialization and if so search the generic only in that unit
...
+ added tests
2022-10-28 17:40:53 +02:00
Sven/Sarah Barth
35a57bac94
* generate the generic name for a specialization of a generic interface alias in the same way as for specializations in general
2022-10-28 17:36:22 +02:00
Sven/Sarah Barth
399d82e1da
- remove unused consume_generic_interface; it has been superseded by handle_generic_interface in 17a0ac7fc0
2022-10-28 13:57:02 +02:00
florian
c75bb80b14
* more debug messages
...
* better exit codes for test
2022-10-26 23:20:18 +02:00
Pierre Muller
49ddf159b2
Fix internalerror generated with riscv32 compiler.
...
Fix
Compiling ./fcl-passrc/src/pscanner.pp
pscanner.pp(2512,40) Fatal: Internal error 2006010801
error generated for riscv32-linux target after commit #c83e6c34
by correcting expectloc for riscv32 for 64-bit comparisons.
Add a small test.
2022-10-25 18:42:14 +02:00
mattias
0f43c7b229
pas2js: use exename instead of paramstr 0, to search pas2js.cfg in exe location
2022-10-25 17:52:08 +02:00
mattias
6685e22ead
fcl-css: clearstyles
2022-10-25 10:49:18 +02:00
florian
be401422fd
* more warnings after last commit fixed
2022-10-24 22:52:52 +02:00
florian
3fa77a4f62
* fix life information propagation for while loops, resolves #39971
...
* warnings/errors fixed which are caused by the new life information propagation
+ test
2022-10-24 22:13:43 +02:00
Jonas Maebe
e63cc73cfa
Darwin/AArch64: future-proof version check
2022-10-23 22:25:29 +02:00
florian
86547d35d7
+ apply OpTest/Or2Op optimization to ANDN as well
...
+ DebugMsg for OpTest/Or2Op added
2022-10-23 22:10:35 +02:00
Jonas Maebe
ae4c8359aa
Darwin/AArch64: detect when SIGILL indicates an FPU exception
...
Parse the ESR (ESR_ELx, Exception Syndrome Register (ELx)), return run error
as in float_raise
2022-10-23 19:10:55 +02:00
J. Gareth "Curious Kit" Moreton
a1ea1dd98e
* x86: Changed BMI2 check to BMI1 for ordinal ANDN optimisation
2022-10-22 21:08:36 +00:00
Pierre Muller
afc9acda37
Change wrong "$macros off" into "$macro off"
2022-10-22 15:54:49 -05:00
Pierre Muller
f3179cb718
Add system_powerpc_wii to supported_targets of powerpc generic GNU assembler
2022-10-22 15:34:38 -05:00
J. Gareth "Curious Kit" Moreton
626e23d89f
* x86: The code generator will now attempt manipulate "x and (not y)" (where x and y are ordinals) to use ANDN.
2022-10-22 13:13:44 +00:00
J. Gareth "Curious Kit" Moreton
567244007e
* x86: Improvement to bug fix so an optimisation can still be made even if the other register is in use
2022-10-22 13:07:16 +00:00
J. Gareth "Curious Kit" Moreton
41b8f6a42e
* x86: Bug fix where improved AddMov2Mov optimisation didn't
...
check to see if the other register was modified in between
2022-10-22 13:07:16 +00:00
J. Gareth "Curious Kit" Moreton
fa76baa3d4
* New test to evaluate i39918
2022-10-22 13:07:16 +00:00
florian
8f269d4540
* check for proper exception type
2022-10-22 15:05:52 +02:00
florian
2b48afe151
* check if optinfo is assigned before using it, resolves #39913
2022-10-21 21:14:39 +02:00
florian
2c51abf40d
+ print optinfo pointer if set
2022-10-21 21:13:28 +02:00
Michaël Van Canneyt
0a2447a955
* Publish all available & needed properties
2022-10-21 13:36:10 +02:00
mattias
87a9214983
pastojs: FindDefaultConfig: search in symlinked compiler exe
2022-10-21 12:10:09 +01:00
Jonas Maebe
229d88c50f
Thumb(2): fix compilation after FPU control word changes
...
Resolves #39966
2022-10-20 22:25:29 +02:00
Martin
dd0711a27e
Fix incorrect dwarf entry count. Issue #39928 introduced in 1b6982107f
2022-10-20 20:03:23 +00:00
Michaël Van Canneyt
850685844b
* Fix handling of options file
2022-10-19 22:57:11 +02:00
Michaël Van Canneyt
9e60c686b4
* Add crossoriginisolation and debugcapture
2022-10-19 22:57:11 +02:00
florian
e142953c6d
* make the hidden high parameter for short strings a byte for 8 bit CPUs
2022-10-19 22:48:54 +02:00
ccrause
991460c4ee
Rewrite fpc_shortstr_concat_multi for AVR to not use a temporary shortstring to reduce RAM usage.
2022-10-19 20:18:56 +00:00
Michael VAN CANNEYT
fb7787b11e
* Added debugcapture route
2022-10-19 20:33:06 +02:00
mattias
2d94575fa8
fcl-css: added attribute value check
2022-10-19 16:44:33 +01:00
J. Gareth "Curious Kit" Moreton
45b1d592f5
* x86: Bug fix where "mov $0,%reg" was inserted on the wrong side of a SETcc instruction
2022-10-18 20:47:42 +00:00
J. Gareth "Curious Kit" Moreton
27aa4d4e34
* x86: ConvertJumpToRET now sets the condition to C_None
2022-10-18 20:47:42 +00:00
J. Gareth "Curious Kit" Moreton
6b77017cb9
* x86: Added two new tests for i39922
2022-10-18 20:47:42 +00:00
Jonas Maebe
c89848a00f
powerpc64le: fix reading FPU control word after 0758aa1143
...
Also, missing rest of the commit message for that change:
The default implementation of SysResetFPU now sets the FPU control word that
was last set from any thread (Delphi and FPC i386/x86-64-compatible). No longer
call SysInitFPU when starting a new thread, only SysResetFPU. Combined, this
means that new FPC-started threads will always start out with that control
word on all architectures.
Added generic fpc_cpuinit implementation that is used unless
FPC_SYSTEM_HAS_FPC_CPUINIT has been defined.
Ensure that the softfloat exception mask is initially set to the same
value as the hardware fpu exception mask on architectures that use both.
SafeLoadLibrary now saves/restores the FPU control word on all platforms.
Removed outdated fpc_mtfsb0_corrected define check in powerpc64.inc
Resolves #38230
2022-10-18 21:55:53 +02:00
Jonas Maebe
0758aa1143
FPU exception mask: generlised system unit interface
2022-10-17 19:43:01 +00:00
florian
e457cdad8a
* patch by avk959 to solve infinite loop in FindMatchesBoyerMoore*, resolves #39885 and #39709
...
+ tests
2022-10-17 21:14:32 +02:00
florian
5670a7543c
* properly reset nf_write/nf_modify flags for min/max inline nodes, needed by dead store optimization, resolves #39958
...
* factored out nutils.node_reset_pass1_write
2022-10-16 22:51:50 +02:00
Jeppe
c83e6c34a9
riscv32: Fix 64bit comparisons
...
- Code taken from MIPS backend
- Removed some unused code generated for RV32 64bit integer ops
2022-10-16 17:37:53 +02:00
mattias
73e5d6f70f
fcl-css: renamed TCSSNode to ICSSNode, resolver: list of style elements
2022-10-16 13:51:45 +02:00
florian
65ff03f30a
+ test for #39955
2022-10-15 13:59:35 +02:00
florian
1c86a4bbeb
* if a pointer_to_array type conversion is applied to a variable, it is not written, resolves #39957
2022-10-14 23:12:18 +02:00