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