From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: by sourceware.org (Postfix, from userid 48) id 802683858002; Mon, 4 Dec 2023 13:36:10 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org 802683858002 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gcc.gnu.org; s=default; t=1701696970; bh=X0W+10b/YhEcaIZvOAKC/envbwlJlBFc+6potuV7pT4=; h=From:To:Subject:Date:In-Reply-To:References:From; b=pLvaSC5ZtRbapUn3NFmw2PdMhXXkr8e5X/3cp2zMG8Y3/Baqe58Q2U1jmRfnZyziC sUIVza+8SeuhVSqdwvB/HPQrA4ZPhVN5LzYYjEZqFEs2p69ygJ3OD66xQZEaHMUo68 Q9U+ffP76e4liDJscclOiOZixUgruV0TCZ46tgM4= From: "cvs-commit at gcc dot gnu.org" To: gcc-bugs@gcc.gnu.org Subject: [Bug target/112431] RISC-V GCC-15 feature: Support register overlap on widen RVV instructions Date: Mon, 04 Dec 2023 13:36:10 +0000 X-Bugzilla-Reason: CC X-Bugzilla-Type: changed X-Bugzilla-Watch-Reason: None X-Bugzilla-Product: gcc X-Bugzilla-Component: target X-Bugzilla-Version: 14.0 X-Bugzilla-Keywords: missed-optimization X-Bugzilla-Severity: enhancement X-Bugzilla-Who: cvs-commit at gcc dot gnu.org X-Bugzilla-Status: UNCONFIRMED X-Bugzilla-Resolution: X-Bugzilla-Priority: P3 X-Bugzilla-Assigned-To: unassigned at gcc dot gnu.org X-Bugzilla-Target-Milestone: --- X-Bugzilla-Flags: X-Bugzilla-Changed-Fields: Message-ID: In-Reply-To: References: Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable X-Bugzilla-URL: http://gcc.gnu.org/bugzilla/ Auto-Submitted: auto-generated MIME-Version: 1.0 List-Id: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=3D112431 --- Comment #13 from GCC Commits --- The master branch has been updated by Pan Li : https://gcc.gnu.org/g:27fde325d64447a3a0d5d550c5976e5f3fb6dc16 commit r14-6117-g27fde325d64447a3a0d5d550c5976e5f3fb6dc16 Author: Juzhe-Zhong Date: Mon Dec 4 21:32:06 2023 +0800 RISC-V: Support highest-number regno overlap for widen ternary Consider this example: #include "riscv_vector.h" void foo6 (void *in, void *out) { vfloat64m8_t accum =3D __riscv_vle64_v_f64m8 (in, 4); vfloat64m4_t high_eew64 =3D __riscv_vget_v_f64m8_f64m4 (accum, 1); vint64m4_t high_eew64_i =3D __riscv_vreinterpret_v_f64m4_i64m4 (high_eew64); vint32m4_t high_eew32_i =3D __riscv_vreinterpret_v_i64m4_i32m4 (high_eew64_i); vfloat32m4_t high_eew32 =3D __riscv_vreinterpret_v_i32m4_f32m4 (high_eew32_i); vfloat64m8_t result =3D __riscv_vfwnmsac_vf_f64m8 (accum, 64, high_ee= w32, 4); __riscv_vse64_v_f64m8 (out, result, 4); } Before this patch: foo6: # @foo6 vsetivli zero, 4, e32, m4, ta, ma vle64.v v8, (a0) lui a0, 272384 fmv.w.x fa5, a0 vmv8r.v v16, v8 vfwnmsac.vf v16, fa5, v12 vse64.v v16, (a1) ret After this patch: foo6: .LFB5: .cfi_startproc lui a5,%hi(.LC0) flw fa5,%lo(.LC0)(a5) vsetivli zero,4,e32,m4,ta,ma vle64.v v8,0(a0) vfwnmsac.vf v8,fa5,v12 vse64.v v8,0(a1) ret PR target/112431 gcc/ChangeLog: * config/riscv/vector.md: Add highest-number overlap support. gcc/testsuite/ChangeLog: * gcc.target/riscv/rvv/base/pr112431-37.c: New test. * gcc.target/riscv/rvv/base/pr112431-38.c: New test.=