florian
|
b1151ef4ea
|
+ missing instruction
|
2025-03-30 20:07:00 +02:00 |
|
florian
|
548e91f104
|
* fix rol/ror instruction usage and spilling on RiscV
|
2025-03-28 22:26:59 +01:00 |
|
florian
|
065ddfd8d4
|
+ RiscV: ROL/ROR code generation support
|
2025-03-25 22:40:26 +01:00 |
|
florian
|
0785652b55
|
+ RiscV: handle ror(i)(w) in the assembler optimizer
|
2025-03-24 23:01:00 +01:00 |
|
florian
|
cafaa9f5b8
|
+ RiscV: handle rol(w) in the assembler optimizer
|
2025-03-23 23:04:17 +01:00 |
|
florian
|
310069221a
|
* comment fixed
|
2025-03-20 21:55:38 +01:00 |
|
florian
|
61bf79c0ac
|
+ RiscV: FcmpAndi2Fcmp optimization
|
2025-03-19 23:00:22 +01:00 |
|
florian
|
860a2d0145
|
- disable Slti0B2B as well
|
2025-03-12 22:56:48 +01:00 |
|
florian
|
ad50adf5f3
|
* some RiscV optimizer improvements and fixes
|
2025-03-11 22:56:03 +01:00 |
|
florian
|
c7290bfb78
|
* enclose {$define DEBUG_AOPTCPU} in {$ifdef EXTDEBUG}
|
2025-03-10 22:50:49 +01:00 |
|
florian
|
1f6ac0609e
|
+ SltiAndi2Slti optimization
|
2025-03-09 20:34:21 +01:00 |
|
florian
|
e6d140df80
|
* make TRVCpuAsmOptimizer.OptPass1SLTIU look further ahead
|
2025-03-08 23:08:10 +01:00 |
|
florian
|
d91be468da
|
* fix SltiuAndi2Sltiu optimization
|
2025-03-07 22:20:46 +01:00 |
|
florian
|
7a19bc012a
|
+ RiscV: SltiuAndi2Sltiu optimization
|
2025-03-06 22:59:53 +01:00 |
|
florian
|
783436f2a1
|
* factor out TRVCpuAsmOptimizer.OptPass1SxxI
|
2025-03-04 22:52:51 +01:00 |
|
florian
|
2679972f38
|
* factor out TRVCpuAsmOptimizer.OptPass1SLTIU
|
2025-03-01 22:24:13 +01:00 |
|
florian
|
70591f6449
|
* factor out TRVCpuAsmOptimizer.OptPass1Andi
|
2025-02-27 22:55:35 +01:00 |
|
florian
|
da6c0e919b
|
+ RiscV: rv32gcb
|
2025-02-22 21:57:52 +01:00 |
|
florian
|
fecd25bac1
|
* fix typo
* properly pass zba, zbb, zbs to march
|
2025-02-21 22:47:44 +01:00 |
|
florian
|
4664e510e6
|
* RiscV: handle more instructions in taicpu.spilling_get_operation_type
|
2025-02-20 23:05:52 +01:00 |
|
florian
|
8e45bb133d
|
+ RV64GCB CPU type
|
2025-02-20 22:41:35 +01:00 |
|
florian
|
4427392d56
|
* RiscV: fix AddiAddi2Addi optimization
|
2025-02-17 22:35:15 +01:00 |
|
florian
|
9432af9ec6
|
* RiscV: play safe in taicpu.spilling_get_operation_type
|
2025-02-16 14:46:39 +01:00 |
|
florian
|
5a07867d20
|
* RiscV: fixing spilling_get_operation_tpye for LI
|
2025-02-15 23:08:15 +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
|
e17c575123
|
* properly write RV32E/RV64E architecture tags
|
2025-01-28 22:38:59 +01:00 |
|
florian
|
95c2a5a2d7
|
+ RiscV: support ZMMUL extension
|
2025-01-26 14:43:57 +01:00 |
|
florian
|
bf41de879a
|
* factor out TRVCpuAsmOptimizer.OptPass1SLTI
|
2025-01-22 22:58:34 +01:00 |
|
florian
|
cfc5f17b0d
|
+ CPURV_HAS_ZICOND
|
2025-01-20 22:52:23 +01:00 |
|
florian
|
ea9e3e02bd
|
+ RiscV: write arch attribute
|
2025-01-17 23:16:38 +01:00 |
|
florian
|
5c6abd2e51
|
* factor out TRVCpuAsmOptimizer.OptPass1SLTx
|
2025-01-14 18:53:20 +01:00 |
|
florian
|
f417c87ec8
|
* RiscV: check for cpu capabilities before using fmv for loading zero
|
2025-01-12 18:30:32 +01:00 |
|
florian
|
5bb4049737
|
* remove accidently committed debug statement
|
2025-01-12 11:32:34 +01:00 |
|
florian
|
dc2c6c8996
|
* factor out TRVCpuAsmOptimizer.OptPass1Sub
|
2025-01-12 11:07:29 +01:00 |
|
florian
|
cfee7d07d8
|
* cleanup
|
2025-01-11 23:11:41 +01:00 |
|
florian
|
971d97c179
|
+ RiscV: make use of the fmv.w.x/fmv.d.x instruction to load 0.0
|
2025-01-11 21:03:54 +01:00 |
|
florian
|
1202b2612f
|
+ RiscV: make use of the fl* rd,symbol,rd pseudoinstruction
|
2025-01-11 14:22:01 +01:00 |
|
florian
|
c3110dfaa9
|
+ RiscV: make use of the fneg.* instruction
|
2025-01-09 22:25:26 +01:00 |
|
florian
|
a370b6ff1d
|
* set is_jmp
|
2025-01-07 22:51:16 +01:00 |
|
Pierre Muller
|
f2f39d4aaa
|
Avoid wrong typecast by checking explictly that hp1 is indeed an instruction
|
2025-01-07 14:40:13 +00:00 |
|
florian
|
e082fe9752
|
+ OptPass1FSGNJ optimization
|
2025-01-06 16:00:11 +01:00 |
|
florian
|
7aae7a8d51
|
+ min/max optimization support for RiscV
|
2025-01-06 15:21:18 +01:00 |
|
florian
|
b5eaa8555a
|
* apply OptPass1FOP to FMIN/FMAX as well
|
2025-01-06 15:21:18 +01:00 |
|
florian
|
2c5a070959
|
+ random bits for quad support on RiscV
|
2025-01-06 15:21:18 +01:00 |
|
florian
|
72daf3f556
|
* RiscV64: optimize 32 bit shift instructions as well
|
2025-01-04 14:59:00 +01:00 |
|
florian
|
5add799193
|
* fix trvinlinenode.second_fma
|
2025-01-01 18:00:15 +01:00 |
|
florian
|
40f9d006d6
|
* write basic attributes for riscvXX-linux
|
2024-12-30 15:56:24 +01:00 |
|
florian
|
e30ca27914
|
* RiscV: write also nopic directive
|
2024-12-29 18:38:27 +01:00 |
|
florian
|
64e87c87bc
|
* apply OptPass1OP to SLT/SLTU as well
|
2024-12-28 23:38:22 +01:00 |
|
florian
|
b7608b045b
|
* RiscV: push_addr_param unified
|
2024-12-26 16:49:43 +01:00 |
|