Commit Graph

157 Commits

Author SHA1 Message Date
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