Sven/Sarah Barth
5af16b3da3
* apply patch by Michael Ring to fix compilation for ARM THUMB
2025-01-09 07:39:18 +01:00
Sven/Sarah Barth
e94d02a067
* with all existing RTLs switched over to the atomic intrinsics, the define FPC_SYSTEM_INTERLOCKED_USE_INTRIN can be removed again
2024-12-12 22:05:20 +01:00
Sven/Sarah Barth
5d6c8130a0
* switch ARM RTL to provide atomic intrinsic helpers instead of Interlocked* functions
2024-12-12 22:05:16 +01:00
Rika Ichinose
ce5a632432
Remove the rest of the VER3_0 conditionals.
2024-09-01 17:13:39 +00:00
florian
13dfd1cafd
* get rid of a couple of more tabs
2024-07-30 22:31:24 +02:00
florian
a0cae50af6
* rtl part of #35433
2024-05-01 23:15:12 +02:00
Michael VAN CANNEYT
ccfa38c68e
* Dotted RTL compiles
2023-07-27 19:04:03 +02:00
Michael VAN CANNEYT
b849d92589
* Char -> AnsiChar
2023-07-14 17:26:10 +02:00
Pierre Muller
13368fbb8a
Add dummy version for symbian
2023-05-22 09:13:14 +00:00
Jonas Maebe
229d88c50f
Thumb(2): fix compilation after FPU control word changes
...
Resolves #39966
2022-10-20 22:25:29 +02:00
Jonas Maebe
0758aa1143
FPU exception mask: generlised system unit interface
2022-10-17 19:43:01 +00:00
Jeppe Johansen
d712c64236
* thumb2: Optimize fillchar a bit more with a wider inner loop chunk size
...
git-svn-id: trunk@49100 -
2021-04-01 20:55:21 +00:00
Jeppe Johansen
8b779975aa
* thumb2: Make fillchar smaller, faster and more reliable. Some gas versions remove the "mov r0,r0" making the calculated branch break
...
git-svn-id: trunk@49098 -
2021-04-01 12:36:06 +00:00
pierre
38ddf2e8c5
Fix spelling error of revision 48023
...
git-svn-id: trunk@48024 -
2021-01-04 08:35:36 +00:00
pierre
3362abb30c
* Set softfloat_rounding_mode indise SetRoundMode function for all CPUs.
...
* SetRoundMode returns previous rounding mode value for all CPUs.
git-svn-id: trunk@48018 -
2021-01-03 21:44:18 +00:00
svenbarth
0c316deab5
* readd SmallInt typecasts to SmallInt overload of SwapEndian
...
git-svn-id: trunk@46898 -
2020-09-19 17:42:04 +00:00
svenbarth
9d86fed95b
* avoid range check error when using SwapEndian with 16-bit constants
...
+ added test
git-svn-id: trunk@46897 -
2020-09-19 17:04:17 +00:00
florian
e332c17bbd
* some inconsistency regarding FPC_NONE usage fixed
...
git-svn-id: trunk@43770 -
2019-12-24 16:14:30 +00:00
florian
c189af0e3d
* improved software floating point exception handling in the rtl
...
git-svn-id: trunk@43163 -
2019-10-10 20:31:31 +00:00
florian
c418d63c16
+ create defines with FPU capabilites
...
+ make use of FPU capability defines in the rtl
git-svn-id: trunk@42681 -
2019-08-13 22:12:49 +00:00
florian
b3ed34592f
+ software handling of exceptions on arm
...
* reworked software handling of exceptions so they can be check lazily
git-svn-id: trunk@42525 -
2019-07-28 21:06:36 +00:00
pierre
beec828647
Fix cycling of arm compiler starting with release ppcarm 3.0.4
...
git-svn-id: trunk@41140 -
2019-01-30 10:48:21 +00:00
Jonas Maebe
96b27765f0
* replaced fstm/fldm with vstm/vldm for clang compatibility
...
git-svn-id: trunk@41136 -
2019-01-29 21:39:20 +00:00
florian
9f16c34329
+ initial work for tls-based threadvar support on arm-linux
...
git-svn-id: trunk@40267 -
2018-11-07 22:02:58 +00:00
florian
ff86c80176
* cpu specific header file for the system unit: cpuh.inc, moved several declarations into it
...
git-svn-id: trunk@37542 -
2017-11-01 16:33:30 +00:00
yury
2ae3ce79bb
* ARM: Never use the "BLX label" instruction. Use "BL label" instead.
...
The linker will always change BL to BLX if necessary, but not vice versa (linker version dependent).
"BLX label" ALWAYS changes the instruction set. It changes a processor in ARM state to Thumb state,
or a processor in Thumb state to ARM state.
git-svn-id: trunk@36086 -
2017-05-04 15:55:55 +00:00
florian
7213a13081
* split fpc_mul_<64 bit> into separate procedures with and without overflow checking
...
git-svn-id: trunk@35454 -
2017-02-19 19:15:14 +00:00
florian
84bb46a35d
+ cpu unit for arm (linux only so far)
...
git-svn-id: trunk@33184 -
2016-03-06 13:33:20 +00:00
florian
1c067e96bf
* fix VFPv4 support
...
git-svn-id: trunk@33182 -
2016-03-06 13:33:16 +00:00
Jeppe Johansen
03d4ada29e
Use a temporary variable to avoid potential problems of overwriting the argument.
...
git-svn-id: trunk@33119 -
2016-02-25 10:38:18 +00:00
florian
3f2057a2f2
* do not generate blx instructions, the generation of blx instead of bl was introduced some years ago but today it proves to be wrong: if necessary, the linker converts the bl into a blx, this is also how gcc and clang handle it
...
git-svn-id: trunk@32788 -
2015-12-29 13:32:21 +00:00
yury
2dafb8d674
* arm-android: Use kuser_memory_barrier by default.
...
git-svn-id: trunk@32077 -
2015-10-17 16:07:04 +00:00
yury
c9a0c5e7a6
* arm: Support for the kuser_memory_barrier kernel function for memory barriers.
...
git-svn-id: trunk@32075 -
2015-10-17 15:40:05 +00:00
yury
0d9d730efe
* arm-android: Use kuser_cmpxchg for Interlocked* functions when RTL is compiled for the ARMv5t CPU.
...
git-svn-id: trunk@32072 -
2015-10-17 14:38:17 +00:00
Károly Balogh
c81290bc94
fix InterlockedCompareExchange on ARM-Linux: kuser_cmpxchg destroys r3, which needs to be restored, if we have to loop
...
git-svn-id: trunk@32063 -
2015-10-16 18:53:35 +00:00
yury
e1a0b1204a
* Removed unused vars in RTL.
...
git-svn-id: trunk@31750 -
2015-09-17 16:48:53 +00:00
yury
9f2ef7c546
* ARM assembler routines are PIC compatible now.
...
git-svn-id: trunk@31703 -
2015-09-15 18:06:36 +00:00
Jeppe Johansen
53fd543440
Fix fillchar for >ARMv3
...
git-svn-id: trunk@31573 -
2015-09-07 20:25:03 +00:00
Jeppe Johansen
dac294c680
Fix ARMv3/ARMv2A support.
...
git-svn-id: trunk@31561 -
2015-09-06 20:33:26 +00:00
Jeppe Johansen
44ad5af04d
Fix some minor UMULL, and FPv4_S16 define problems
...
git-svn-id: trunk@31560 -
2015-09-06 20:14:16 +00:00
Jeppe Johansen
3ef4033e7d
Test the proper CPUARM capability when chosing between blx and bl.
...
git-svn-id: trunk@30273 -
2015-03-22 13:42:28 +00:00
Jeppe Johansen
9478099e5a
Undo recent VFP assembler changes to make bootstrapping from 3.0.1 possible.
...
git-svn-id: trunk@30183 -
2015-03-14 10:04:17 +00:00
Jeppe Johansen
914e9e7b49
Merged from trunk
...
git-svn-id: branches/laksen/armiw@30146 -
2015-03-08 12:33:46 +00:00
florian
9eab90d8c4
* always pass the architecture to the arm assembler
...
* encode pld/ldrd in arm.inc using .long, so it causes no errors with older architectures settings of the assembler
git-svn-id: trunk@29780 -
2015-02-21 21:58:30 +00:00
Jeppe Johansen
ff7af306df
Add FPA support.
...
git-svn-id: branches/laksen/armiw@29366 -
2015-01-01 11:18:04 +00:00
Jeppe Johansen
71cdedea82
Add missing NOP, and B instruction forms.
...
Move ThumbFunc flag from section to symbol.
Make .w forms optional the other way around. If .w is explicitly put on an instruction the assembler should always chose a wide form.
git-svn-id: branches/laksen/armiw@29341 -
2014-12-27 13:23:02 +00:00
Jeppe Johansen
9e5979e8be
Implemented UAL syntax support in the ARM assembler reader. Can be toggled with a field for now, but not implemented yet. Still using pre-UAL syntax for now.
...
Switched codegeneration of VFPv2 and VFPv3 to use UAL mnemonics and syntax.
Updated VFP code in RTL to use UAL syntax too.
Added preliminary ELF support for ARM.
Added support for linking of WinCE COFF files. Should work for with a standard ARMv4-I target.
git-svn-id: branches/laksen/armiw@29247 -
2014-12-10 20:44:34 +00:00
Jeppe Johansen
d4461efae3
Fix broken ldrd assembler syntax in RTL
...
git-svn-id: trunk@29187 -
2014-11-30 17:30:46 +00:00
florian
03c553606e
- unneeded spaces removed
...
git-svn-id: trunk@28740 -
2014-10-04 13:45:17 +00:00
Károly Balogh
1a4d6d79c5
new division helpers for ARM by Nico Erfurth. on our ARMv5 core hardware they're 22%-36% faster than the generic ones for the most common case.
...
git-svn-id: trunk@28273 -
2014-07-29 17:39:55 +00:00