florian
d5d9716916
* fix thlcgxtensa.g_intf_wrapper as proposed by Anton in #39326 , resolves #39326
2022-01-27 22:37:31 +01:00
florian
46507f9565
* Xtensa: optimize constant multiplications
...
git-svn-id: trunk@49618 -
2021-07-18 21:40:43 +00:00
florian
db8c723b9d
* Xtensa: unified DataMov2Data optimization
...
git-svn-id: trunk@49616 -
2021-07-17 21:07:02 +00:00
pierre
da3eb5c178
Try to fix handle of large stack size in xtensa gen_proc_entry/gen_proc_exit
...
git-svn-id: trunk@49352 -
2021-05-12 22:54:59 +00: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
florian
9a39124118
* Xtensa: fix crash in TCpuAsmOptimizer.RegLoadedWithNewValue
...
git-svn-id: trunk@49132 -
2021-04-07 13:54:58 +00:00
florian
bc4a22e24d
+ Xtensa: tcpuinlinenode.second_prefetch
...
git-svn-id: trunk@49090 -
2021-03-30 21:43:20 +00:00
florian
053c42da33
+ Xtensa: support large stack frames for the call0 abi
...
git-svn-id: trunk@47848 -
2020-12-25 18:18:09 +00:00
florian
4f3271500a
* (modified) patch by Christo Crause: ESP8266 doesn't support min/max instructions, resolves #38175
...
git-svn-id: trunk@47699 -
2020-12-06 16:37:54 +00:00
florian
57dc416d96
+ replace appropriate if statements by min/max intrinsics
...
+ support min/max intrinsic on xtensa
git-svn-id: trunk@47693 -
2020-12-05 22:00:59 +00:00
florian
6ac2957187
* Xtensa: cleanup of getreferencestring
...
git-svn-id: trunk@47565 -
2020-11-24 22:04:28 +00:00
florian
4a05053650
+ Xtensa: make use of the LSX/SSX instructions
...
git-svn-id: trunk@47564 -
2020-11-24 21:22:20 +00:00
florian
9dcf85a8ef
+ Xtensa: FMA support
...
git-svn-id: trunk@47563 -
2020-11-24 20:59:47 +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
7f53d04ffd
+ xtensa: make use of nsau to implement Bsr*
...
git-svn-id: trunk@46963 -
2020-09-26 22:03:13 +00:00
florian
1c370ccde1
+ xtensa: make use of float.s instruction
...
git-svn-id: trunk@46962 -
2020-09-26 20:12:29 +00:00
florian
112f8a41ad
* Xtensa: set is_jmp flag so branch optimization works
...
git-svn-id: trunk@46960 -
2020-09-26 20:12:27 +00:00
pierre
a4e520180f
Avoid range check error in a_op_const_reg_reg method when compiled with -CriotR
...
git-svn-id: trunk@46945 -
2020-09-24 16:06:49 +00:00
florian
d7fe9914a7
+ introduce tcgobj.a_loadfpu_reg_intreg
...
+ make use of it in tcgtypeconvnode.second_nothing
+ Xtensa: implementation of a_tcgcpu.a_loadfpu_intreg_reg and tcgcpu.a_loadfpu_reg_intreg
git-svn-id: trunk@46858 -
2020-09-12 21:23:57 +00:00
florian
f8b17c410b
+ Xtensa: make use of ABS.S
...
+ extended test for abs(...) with single tests
git-svn-id: trunk@46852 -
2020-09-11 21:51:48 +00:00
florian
8e74a04dc5
* Xtensa: stack size calculation for the call0 abi fixed
...
git-svn-id: trunk@46833 -
2020-09-10 20:53:11 +00:00
florian
ddf26cb3d2
* Xtensa: trgcpu.do_spill_op fixed
...
* cleanup
git-svn-id: trunk@46820 -
2020-09-09 21:08:04 +00:00
florian
27b4f3df60
* Xtensa: taicpu.spilling_get_operation_type improved
...
git-svn-id: trunk@46819 -
2020-09-09 21:08:03 +00:00
florian
93eef547ae
* improve call0 calling conventions
...
git-svn-id: trunk@46797 -
2020-09-07 20:28:38 +00:00
florian
9337b2a3ac
* Xtensa: handle references with offset only properly
...
git-svn-id: trunk@46784 -
2020-09-05 20:25:32 +00:00
florian
243300c85f
* more ABI compliant parameter passing
...
git-svn-id: trunk@46783 -
2020-09-05 20:25:31 +00:00
florian
8ef6372340
* Xtensa: tcgcpu.g_concatcopy makes use of loop extensions if available
...
git-svn-id: trunk@46781 -
2020-09-05 20:25:29 +00:00
florian
451bb09e8f
* Xtensa: tcgcpu.g_concatcopy uses OC_NE so the branch requires one instruction less
...
git-svn-id: trunk@46780 -
2020-09-05 20:25:28 +00:00
florian
1edf99c324
* Xtensa: tcpuunaryminusnode.second_float fixed for double
...
git-svn-id: trunk@46779 -
2020-09-05 20:25:28 +00:00
florian
965f759c0d
* Xtensa: arrays are always passed as by reference but still returned in up to 4 registers
...
git-svn-id: trunk@46770 -
2020-09-04 20:58:14 +00:00
florian
1e38369d06
* Xtensa: set expectloc of not nodes correctly
...
git-svn-id: trunk@46752 -
2020-09-02 20:47:53 +00:00
florian
d5ce344b67
* stack size estimation again improved
...
git-svn-id: trunk@46739 -
2020-08-31 21:01:26 +00:00
florian
4407670d15
* Xtensa: fix operand size and location handling in TCPUAddNode.second_cmp
...
git-svn-id: trunk@46735 -
2020-08-30 21:32:45 +00:00
florian
6879a16cc3
* Xtensa: rewrote parameter handling
...
* Xtensa: aggregate types up to 16 bytes are returned in registers
git-svn-id: trunk@46734 -
2020-08-30 20:54:00 +00:00
florian
b36597c76a
* better calculation of estimated stack frame size
...
git-svn-id: trunk@46733 -
2020-08-30 20:53:59 +00:00
florian
867ed59459
* Xtensa: various stack handling fixes
...
git-svn-id: trunk@46732 -
2020-08-29 20:24:32 +00:00
florian
2c00016fdd
+ Xtensa: reused constant pool entries if possible
...
git-svn-id: trunk@46731 -
2020-08-29 20:24:31 +00:00
florian
3eb7a13088
+ Xtensa: implemented tcpuparamanager.ret_in_param according to API
...
* fixed passing of variant parameters
git-svn-id: trunk@46728 -
2020-08-28 20:18:36 +00:00
florian
292574f3fc
* Xtensa: fix single<>single
...
git-svn-id: trunk@46726 -
2020-08-28 20:18:35 +00:00
florian
47d6699a2e
* Xtensa: some issues with large parameters fixed
...
git-svn-id: trunk@46720 -
2020-08-27 21:31:31 +00:00
florian
250c0750a2
* Xtensa: several issues with parameter passing of the windowed api fixed
...
git-svn-id: trunk@46708 -
2020-08-26 21:03:42 +00:00
florian
f4ded560cc
* Xtensa: OP_NOT fixed
...
git-svn-id: trunk@46706 -
2020-08-26 21:01:00 +00:00
florian
f30f62231f
* reverted 46417: if a assembler subroutine needs an entry instruction, it should be added explicitly
...
git-svn-id: trunk@46696 -
2020-08-25 21:39:40 +00:00
florian
6e25a014e6
* Xtensa: force correct location into a register in tcpunotnode.second_boolean
...
git-svn-id: trunk@46695 -
2020-08-25 21:39:39 +00:00
florian
03a0e6e82f
* Xtensa: fixed TCPUAddNode.second_cmpsmallset
...
git-svn-id: trunk@46678 -
2020-08-24 21:02:08 +00:00
florian
27fbf8c91e
* Xtensa: tcpunotnode.second_boolean fixed
...
git-svn-id: trunk@46672 -
2020-08-23 19:13:19 +00:00
florian
ea2ae3b8f0
+ Xtensa: use extui for and with constants
...
git-svn-id: trunk@46664 -
2020-08-23 14:17:01 +00:00
florian
a45f71d0dc
* Xtensa: optimize some shifts by constants
...
git-svn-id: trunk@46556 -
2020-08-22 21:28:08 +00:00
florian
04846345b2
* Xtensa: more fixes to tcg64fxtensa.a_op64_const_reg_reg and tcg64fxtensa.a_op64_reg_reg_reg
...
git-svn-id: trunk@46551 -
2020-08-22 20:33:30 +00:00
florian
26e2759c27
* Xtensa: fixed tcg64fxtensa.a_op64_reg_reg_reg for unsigned operations
...
git-svn-id: trunk@46549 -
2020-08-22 19:38:10 +00:00