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 |
|
florian
|
c7290bfb78
|
* enclose {$define DEBUG_AOPTCPU} in {$ifdef EXTDEBUG}
|
2025-03-10 22:50:49 +01:00 |
|
florian
|
490c431bf9
|
* make use of not_zero in tbasecgarm.a_bit_scan_reg_reg
|
2025-02-12 23:02:03 +01:00 |
|
florian
|
b2f6214b33
|
+ a_bit_scan_reg_reg gets a flag if src cannot be zero: this simplifies the generated code
|
2025-02-08 14:27:48 +01:00 |
|
florian
|
a16f2ae35d
|
* tai_eabi_attribute -> tai_attribute so it can be used by other architectures
|
2024-12-30 15:56:24 +01:00 |
|
J. Gareth "Curious Kit" Moreton
|
2a50d5abf8
|
* ARMv7A / A64: Constant writes to memory merged to larger forms where possible
|
2024-11-03 15:02:51 +00:00 |
|
florian
|
bea36238e7
|
* generate fmrx instruction only if the cpu has the vfp extension, resolves #40985
|
2024-11-01 22:29:11 +01:00 |
|
florian
|
90cc6db5cb
|
* armv7 should a synonyme for arm7a
|
2024-08-28 20:27:09 +01:00 |
|
Pierre Muller
|
ce702df526
|
Take care about endianess in arm instruction binary code generator
|
2024-06-11 01:05:51 +02:00 |
|
J. Gareth "Curious Kit" Moreton
|
bf970b29f4
|
* arm / a64: TAsmNode debugging info is now output for ARM and AArch64
|
2024-05-30 20:04:11 +00:00 |
|
florian
|
f49da05633
|
* unified g_concatcopy_move
|
2024-05-15 22:52:24 +02:00 |
|
florian
|
9b1861a104
|
+ enable cs_opt_consts on arm as well
|
2024-05-07 22:40:13 +02:00 |
|
J. Gareth "Curious Kit" Moreton
|
9ee1821622
|
* arm / a64: Extended the AND; CMP -> ANDS family of optimisations to catch BIC as well as AND
|
2024-04-20 12:55:47 +00:00 |
|
florian
|
c87213085f
|
* overflow checking for generic abs(<int64>)
* fix overflow checking on arm for 64 bit signed numbers
* arm uses generic abs(<int64>)
|
2024-03-29 20:06:23 +01:00 |
|
florian
|
56d84c9283
|
* compilation fixed
|
2024-03-28 18:31:38 +01:00 |
|
florian
|
0efd3afb8c
|
+ arm: internal abs(<int64>)
+ arm: overflow checking for abs(...)
|
2024-03-28 15:56:52 +01:00 |
|
Michaël Van Canneyt
|
4e8b1cb97a
|
* Fixed signature of insert_init_final_table
|
2024-03-05 07:56:14 +00:00 |
|
florian
|
8146443336
|
+ set pi_do_call on ARM as well if we check for fpu exceptions
|
2024-02-17 21:03:55 +01:00 |
|
florian
|
a71cc71585
|
+ function needs_check_for_fpu_exceptions to unify fpu exception handling
|
2024-02-13 17:42:21 +01:00 |
|
Pierre Muller
|
53bf5dc6ef
|
Avoid wrong typecast by adding check that p1 is an instuction before casting it to taicpu
|
2024-02-12 10:39:18 +00:00 |
|
J. Gareth "Curious Kit" Moreton
|
271f69db12
|
* arm/a64: "OptPass2AND" and "OptPass2CMP" adapted to remove vestigial CMP and TST instructions
|
2024-02-11 21:39:19 +00:00 |
|
J. Gareth "Curious Kit" Moreton
|
6b2e4fa413
|
* arm: "OpCmp2OpS" moved to Pass 2 so it doesn't conflict with AND; CMP -> TST optimisation
|
2024-02-11 21:39:19 +00:00 |
|
J. Gareth "Curious Kit" Moreton
|
b18c10d0d8
|
* arm/a64: New "OptPass2TST" routine to catch "TST; B.c; AND -> ANDS; B.c" optimisation
|
2024-02-11 21:39:19 +00:00 |
|
J. Gareth "Curious Kit" Moreton
|
9f19f582c4
|
* arm/a64: New AND/CMP -> TST or ANDS optimisation
|
2024-02-11 21:39:19 +00:00 |
|
J. Gareth "Curious Kit" Moreton
|
29916bc6f6
|
* arm: Fixed "RegInInstruction" and "RegModifiedByInstruction" not handling the flags properly
|
2024-02-11 21:39:19 +00:00 |
|
florian
|
f7bfa0e426
|
* range checking is already performed in pass_typecheck
|
2024-01-07 17:51:35 +01:00 |
|
Pierre Muller
|
6e9521d99a
|
Fix for trunk arm STM optimize bug
|
2023-11-12 18:22:19 +00:00 |
|
ccrause
|
652f21b656
|
RP2040 support based on modification by Michael Ring (https://github.com/michael-ring/freepascal).
|
2023-11-11 17:45:23 +00:00 |
|
J. Gareth "Curious Kit" Moreton
|
c4061e49e6
|
* ARM: Fixed issue where some offsets of ADR assembly instructions
were incorrectly encoded by the internal assembler
|
2023-10-22 12:04:05 +00:00 |
|
florian
|
be401422fd
|
* more warnings after last commit fixed
|
2022-10-24 22:52:52 +02:00 |
|
J. Gareth "Curious Kit" Moreton
|
d6ff4ed967
|
* arm/a64: New sbfx/ubfx -> mov optimisation
|
2022-07-30 18:36:16 +00:00 |
|
Jonas Maebe
|
2ed4071c1e
|
ARM: fixed compiler compilation after 75c16b6126
|
2022-07-24 15:00:49 +02:00 |
|
Jonas Maebe
|
75c16b6126
|
llvm: support for getting the llvm rtl (rt) architecture name
This is the name used as part of the llvm rt libraries, like
asan (address sanitizer)
|
2022-07-24 14:36:13 +02:00 |
|
J. Gareth "Curious Kit" Moreton
|
d1f035f456
|
* arm: Labels to constants are now data labels and not jump labels
|
2022-07-15 17:03:10 +00:00 |
|
J. Gareth "Curious Kit" Moreton
|
be39828fca
|
* arm: Symbol reference counts are corrected when PC-relative data is inserted
|
2022-07-15 17:03:10 +00:00 |
|
florian
|
83ce54b815
|
set Tag_ABI_VFP_args to 1 only if the hard float abi is used, should resolve #39817
|
2022-06-30 22:02:11 +02:00 |
|
Jonas Maebe
|
03a961709b
|
arm paramanager: always create at least one paraloc
Even for parameters of 0 bytes. Matches behaviour on other targets.
|
2022-06-13 22:52:27 +02:00 |
|
Pierre Muller
|
2cdbdcd5c5
|
Manually increase refs of newly created labelsymbol in insertpcrelativedata
|
2022-05-31 14:26:00 +00:00 |
|
Sven/Sarah Barth
|
7f3a5eb9ab
|
* extend tabstractprocdef.getcopyas by a parameter to control whether the copy should be registered or not
|
2022-05-26 21:42:59 +02:00 |
|
florian
|
27fb9086aa
|
* cleanup: cs_opt_loopunroll is a generic optimization for a long time already
|
2022-03-08 23:03:18 +01:00 |
|
florian
|
2a93e65511
|
* seperator => separator
|
2022-01-02 13:12:33 +01:00 |
|
florian
|
6404478ea4
|
* cleanup of VER3_0 defines
|
2021-11-17 22:19:57 +01:00 |
|
florian
|
9423d5e390
|
+ fp-armv8 fpu type added
|
2021-11-06 11:00:53 +01:00 |
|
florian
|
9feafc7bd7
|
+ ARM: started on vfpv5 support
|
2021-11-05 23:05:38 +01:00 |
|
florian
|
ff3acfb8cd
|
* cleanup of 2.7.0 defines
|
2021-10-31 13:20:28 +01:00 |
|
florian
|
bbcc396644
|
* ARM: fix for Merge Add/Sub optimization
git-svn-id: trunk@49520 -
|
2021-06-21 21:36:32 +00:00 |
|
florian
|
356afdd25b
|
* ARM (thumb): do not save registers in routines marked as noreturn
git-svn-id: trunk@49519 -
|
2021-06-20 18:14:30 +00:00 |
|
florian
|
50648f2a60
|
+ ARM: PushPop optimziation
git-svn-id: trunk@49510 -
|
2021-06-17 21:12:08 +00:00 |
|
florian
|
e1d9d1be0a
|
+ Merge Add/Sub optimization
git-svn-id: trunk@49508 -
|
2021-06-16 19:53:56 +00:00 |
|
florian
|
3f8aeadb91
|
* do not generate exit code for arm (thumb and thumb-2) if a routine is marked as noreturn
git-svn-id: trunk@49506 -
|
2021-06-15 20:09:46 +00:00 |
|