Commit Graph

71837 Commits

Author SHA1 Message Date
florian
6c4d218b8d * use for threadvars on RiscV always the size optimization code path as loading addresses is expensive 2025-04-03 23:14:43 +02:00
Michaël Van Canneyt
fc43e66f05 * Wake main thread when a thread is auto freed 2025-04-03 17:12:20 +02:00
Michaël Van Canneyt
1a21ea41b8 * Correctly set current thread 2025-04-03 16:26:31 +02:00
Pierre Muller
3bf5c67485 Revert "Add missing dependency on types unit for math unit"
This reverts commit 1f01ba4bc0.
2025-04-03 12:07:18 +00:00
Pierre Muller
1f01ba4bc0 Add missing dependency on types unit for math unit 2025-04-03 11:58:59 +00:00
Pierre Muller
43538416e3 Handle ADR LDM and STM arm instructions
in taicpu.spilling_get_operation_type method
2025-04-03 11:58:59 +00:00
Michaël Van Canneyt
a797828619 * Some additional thread debugging statements 2025-04-03 11:59:51 +02:00
florian
fb126e32f9 * RtlUnwind destroys register, so save and restore them afterwards 2025-04-02 22:34:21 +02:00
Michaël Van Canneyt
9e9153b2d3 * forgot to commit 2025-04-02 16:27:34 +02:00
Michaël Van Canneyt
736fc12e55 * Allow wasm guest & host to be notified of wasm memory growth 2025-04-02 11:21:03 +02:00
florian
62236ec2bb * proper naming 2025-04-01 22:53:56 +02:00
florian
425ef662cc * patch by Pierre to fix spilling and jump handling of pseudo-instructions 2025-03-31 22:53:40 +02:00
Pierre Muller
282f4aa060 Add definitions of ALUSInt and ALUUInt types in java/jsystemh_types.inc 2025-03-31 13:36:13 +00:00
florian
b1151ef4ea + missing instruction 2025-03-30 20:07:00 +02:00
Rika Ichinose
6ab6be4793 Faster Val(). 2025-03-30 19:36:42 +02:00
J. Gareth "Curious Kit" Moreton
de51e6a32a * x86_64: Extension to MovMov2Mov optimisations to allow more MOVL to MOVQ zero-extensions 2025-03-30 17:04:56 +02:00
Ondrej Pokorny
ec5b4d458e decrease restarts_to_go only if restart is enabled (solves runtime error if compiled with range checks) 2025-03-30 08:16:41 +00:00
Ondrej Pokorny
0d988f2c96 JPEG: support custom CMYK conversions and reading custom APPn headers 2025-03-30 08:16:41 +00:00
florian
84a852bc13 * more aggressive cse on thread vars 2025-03-29 22:31:13 +01:00
Rika Ichinose
ce6db34224 Shortcut Compare*(a, a) before entering the aligned loop. 2025-03-29 22:07:03 +01:00
Rika Ichinose
8093b1ba0c Unbias 32-bit random. 2025-03-29 21:55:08 +01:00
florian
c07da2a654 * typo 2025-03-29 18:52:16 +01:00
florian
548e91f104 * fix rol/ror instruction usage and spilling on RiscV 2025-03-28 22:26:59 +01:00
Pierre Muller
6debe90b07 Disable libjack package for beos OS 2025-03-28 15:40:23 +00:00
Pierre Muller
a093c6e59a Add dependencies for units of utils/fpcres package 2025-03-28 05:46:00 +00:00
florian
f8f54dcbcf + RiscV has internal rol/r support 2025-03-27 22:33:30 +01:00
florian
f65994ddcb + RiscV: flags for crypotography extensions 2025-03-26 22:44:26 +01:00
Michaël Van Canneyt
1ef1481488 * Print unit name, flush output in status messages 2025-03-26 11:43:20 +01:00
florian
065ddfd8d4 + RiscV: ROL/ROR code generation support 2025-03-25 22:40:26 +01:00
Pierre Muller
a74a4aca03 Avoid range check error in TObjData.writebytes overloads using dynamic arrays 2025-03-25 12:09:06 +01:00
Jonas Maebe
754c40cdb0 tai_string: remove useless #0 terminators
The string data in the array alrady includes any necessary #0 terminators
and the length of the array contains the length of the data, so there is
no need to add an additional #0 terminator
2025-03-24 23:02:10 +01:00
Jonas Maebe
547fa426c7 Fix emit_ansistr_const: its input is not guaranteed to be #0-terminated
Also cleaned up all memory leaks where pchars were allocated, but never freed.
Before the change to dynamic arrays, these pchars were kept in the tai_string,
but now they got copied. Changed the tai_string constructor to support adding
a terminating #0, so we don't need to create intermediates just for that.
2025-03-24 23:02:10 +01:00
Jonas Maebe
dc5c99be6d LLVM: fix compilation after rgobj dynarray changes 2025-03-24 23:02:10 +01:00
Jonas Maebe
f0cecf5367 tai_aggregatetypedconst.add_to_string: fix off-by-one errors 2025-03-24 23:02:10 +01:00
Jonas Maebe
91667644f4 fpc_cpuinit: add destroyed register lists to assembler blocks
Otherwise the compiler assumes no registers are overwritten. And while the
regular code generator won't use register variables if assembler blocks are
present, LLVM is not restricted like that (and it could still cause issues
even with the default code generator in case PIC-rebased addresses are
accessed).
2025-03-24 23:02:10 +01:00
florian
0785652b55 + RiscV: handle ror(i)(w) in the assembler optimizer 2025-03-24 23:01:00 +01:00
Pierre Muller
bfc1172844 Remove tstunits/go32v2/Package.fpc file introduced by error in commit a3dd6acae4 2025-03-24 20:21:18 +00:00
Pierre Muller
8bd781aa4a Avoid long wait on this Windows OS specific test 2025-03-24 17:08:30 +00:00
Michaël Van Canneyt
6314d69c40 * Correct allocation size for IsHandled, index is 1-based 2025-03-24 16:47:02 +01:00
florian
cafaa9f5b8 + RiscV: handle rol(w) in the assembler optimizer 2025-03-23 23:04:17 +01:00
Rika Ichinose
0d5dddfcb5 Inline polyevl&ldexp in sin&cos. 2025-03-23 09:27:48 +01:00
florian
eb5c61281c + take care of asmmode in $push/$pop, resolves #41190 2025-03-22 21:16:03 +01:00
Michaël Van Canneyt
1a57a65c5f * Fix tw13628b 2025-03-22 12:28:07 +01:00
Michaël Van Canneyt
4b5c6ba3fc * Fix tgenconst13 2025-03-22 11:22:22 +01:00
florian
b20f968454 * simple clean ups after dyn. array conversion 2025-03-21 21:35:39 +01:00
Michaël Van Canneyt
6ba102ee57 * Do not set strval for unicode strings in tc_emit_stringdef 2025-03-21 14:38:37 +01:00
Michaël Van Canneyt
d3a0a2dddf * Call free instead of destroy 2025-03-21 14:25:19 +01:00
Michaël Van Canneyt
36e65b3464 * Correct check 2025-03-21 14:10:53 +01:00
Pierre Muller
04a31f8be2 Avoid range error in tbitset.clear method 2025-03-21 09:26:57 +00:00
Pierre Muller
e1478e27b3 Fix range check error inside tsuperregisterworklist.addnodup method 2025-03-21 09:11:08 +00:00