Commit Graph

453 Commits

Author SHA1 Message Date
florian
c7290bfb78 * enclose {$define DEBUG_AOPTCPU} in {$ifdef EXTDEBUG} 2025-03-10 22:50:49 +01:00
florian
46dcffed42 * MIPS64: make use of DMTC1 instruction 2024-10-18 21:53:26 +02:00
Pierre Muller
e8c6274915 Add -msoft-float or -mhard-float option to GNU assembler calls 2024-10-01 22:27:32 +01:00
Nikolay Nikolov
b077d17cdd * MIPS: don't generate FPU code for int to real conversion when FPU emulation is enabled 2024-09-29 20:56:43 +03:00
Nikolay Nikolov
bf7bf44727 * MIPS: don't generate FPU code for abs(real), sqr(real) and sqrt(real) in case
FPU emulation is enabled
2024-09-29 20:48:38 +03:00
Nikolay Nikolov
7b02331168 + added fpu_libgcc to MIPS 2024-09-29 20:24:31 +03:00
Nikolay Nikolov
180c23b395 * MIPS code gen: don't use FPU registers for function parameters in case SoftFPU
is enabled
2024-09-29 20:14:55 +03:00
Nikolay Nikolov
00d86d24be * MIPS code generator: don't put floating point results in FPU registers for
function results, if the SoftFPU is enabled
2024-09-29 20:11:47 +03:00
Kirill Kranz
be9bfbecc5 typo fixed 2024-09-29 16:59:02 +03:00
Kirill Kranz
8e6a8a36cd case statiment insteed of ifs 2024-09-29 16:58:12 +03:00
Kirill Kranz
d1438e0d39 check if next instruction exists 2024-09-29 16:58:12 +03:00
Kirill Kranz
e9d8bcf484 hlcgcpu.pas: uses unit systems + t_ps1.pas: correct Message3 2024-09-29 16:58:12 +03:00
Kirill Kranz
530a962dfc thx god You seen it! (reverse) 2024-09-29 16:58:12 +03:00
Kirill Kranz
14ad18a82b leave PIC code unchanged 2024-09-29 16:58:12 +03:00
Kirill Kranz
b47687852e if taicpu(p).opcode in [....] beautiy fix 2024-09-29 16:58:12 +03:00
Kirill Kranz
034c361804 resolveReadAfterWrite moved to aasmcpu.pas 2024-09-29 16:58:12 +03:00
Kirill Kranz
17c0765655 Indentation 2024-09-29 16:58:12 +03:00
Kirill Kranz
2f5cbbacb7 DynArrays works
because of InitHeap3, malloc3 and free3 functions from the psy-q-sdk
2024-09-29 16:58:12 +03:00
Kirill Kranz
ec2f18f8be compiles cube.pas example 2024-09-29 16:56:18 +03:00
Kirill Kranz
52651a7ede First compiler Build 2024-09-29 16:56:18 +03:00
Sven/Sarah Barth
f584c559fd * fold the MIPS tabitype into tabi as the former wasn't really used or hooked up anyway; this way the ABI can be set using -Ca<abi> 2024-06-04 23:45:46 +02:00
florian
f49da05633 * unified g_concatcopy_move 2024-05-15 22:52:24 +02:00
Pierre Muller
dc04a8a677 Fix storing of unaligned 64-bit to memory 2023-04-21 10:32:13 +01:00
Pierre Muller
d18ff64ed7 Fix a_load64_reg_ref and a_load64_ref_reg mips methods 2022-11-07 22:24:34 +00:00
Pierre Muller
c96bb0f416 Handle unaligned references in 64-bit a_load_ref_reg and a_load_reg_ref methods 2022-11-06 22:14:38 +00:00
Pierre Muller
b8920670f4 Change is_macro to return true for A_JAL if in pic mode 2022-09-20 22:33:14 +01:00
florian
85c7368759 * handle also simulated flags in tmipselnotnode.second_boolean, resolves #39877 2022-08-24 21:16:23 +02:00
florian
9c72ab651d * use g_concatcopy_unaligned on MIPS if needed 2022-08-06 15:04:35 +02:00
florian
d153c75e84 * small MIPS64 fix 2022-06-13 23:07:43 +02:00
florian
9201047f31 * a few more MISP64 fixes 2022-06-11 23:09:15 +02:00
florian
4149562787 * more MIPS64 fixes 2022-06-10 23:20:38 +02:00
florian
8bd1f19639 * few MIPS64 fixes 2022-06-09 22:55:24 +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
Pierre Muller
b048ae37b2 Fix loading of 64-bit constant into register for 64-bit mips CPU 2022-02-15 19:51:26 +00:00
florian
ba51494bd7 * more MIPS64 fixes 2022-02-09 22:59:46 +01:00
florian
bbece3e668 * MIPS64 can
* MIPS64 does not need separate 64 bit code path for ordinals
2022-02-08 23:08:32 +01:00
Florian Klämpfl
9348f58e70 * cosmetics 2022-02-06 20:13:51 +01:00
Pierre Muller
a9c67f22fd Add use of SD instruction in tcgmips.a_load_reg_ref method 2022-02-04 22:54:58 +00:00
Pierre Muller
c2ffd51c63 Fix compilation from 32-bit CPU by avoiding use of aint variable in for loop 2022-02-04 18:32:49 +00:00
florian
b2e553d3c4 * mips64el compiler can be compiled 2022-02-03 23:15:34 +01:00
florian
03f4685455 + sanity checks in mips and sparc register allocator 2021-12-17 21:25:17 +01:00
florian
6404478ea4 * cleanup of VER3_0 defines 2021-11-17 22:19:57 +01:00
florian
ff3acfb8cd * cleanup of 2.7.0 defines 2021-10-31 13:20:28 +01:00
pierre
75a9c5b500 Also avoid invalid typecast for RegLoadedWithNewValue method for mips, sparcgen and xtensa
git-svn-id: trunk@49186 -
2021-04-12 08:57:23 +00:00
pierre
01a351f804 Fix for bug report 38549 about wrong code generation
for mips/mipsel and riscv32/riscv64 CPUs for 
  set operators '<=' and '>='.
  New tests for this bug report.
  tw38549.pp, main source, also included 
  by tw38549a.pp, tw38549b.pp, tw38459c.pp and tw38459d.pp
  with explicit {$packset X}, with X=1,2,4, or 8 added.

git-svn-id: trunk@48874 -
2021-03-03 22:15:20 +00:00
florian
637976e83f * patch by Marģers to unify internal error numbers, resolves #37888
git-svn-id: trunk@47103 -
2020-10-13 19:59:01 +00:00
florian
28f25b2df0 * reworked usage of tcgnotnode.handle_locjump
git-svn-id: trunk@46275 -
2020-08-05 21:15:32 +00:00
yury
cc936710a0 * mips: Added support for unaligned load/store. It greatly improves performance and prevents bus errors on systems which do not emulate unaligned memory access.
git-svn-id: trunk@45871 -
2020-07-28 20:08:41 +00:00
yury
6478a727d7 * Fixed the peephole optimization of conditional movs for mips.
git-svn-id: trunk@45826 -
2020-07-22 11:40:21 +00:00
pierre
0c6998bb11 Try to fix mipsel-android by making sure P does not point to a freed instruction
git-svn-id: trunk@45812 -
2020-07-19 21:21:18 +00:00