Commit Graph

66123 Commits

Author SHA1 Message Date
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