public inbox for gcc-bugs@sourceware.org help / color / mirror / Atom feed
From: "juzhe.zhong at rivai dot ai" <gcc-bugzilla@gcc.gnu.org> To: gcc-bugs@gcc.gnu.org Subject: [Bug tree-optimization/113583] Main loop in 519.lbm not vectorized. Date: Wed, 24 Jan 2024 14:42:31 +0000 [thread overview] Message-ID: <bug-113583-4-2mwbLiVAQY@http.gcc.gnu.org/bugzilla/> (raw) In-Reply-To: <bug-113583-4@http.gcc.gnu.org/bugzilla/> https://gcc.gnu.org/bugzilla/show_bug.cgi?id=113583 --- Comment #1 from JuzheZhong <juzhe.zhong at rivai dot ai> --- It's interesting, for Clang only RISC-V can vectorize it. I think there are 2 topics: 1. Support vectorization of this codes of in loop vectorizer. 2. Transform gather/scatter into strided load/store for RISC-V. For 2nd topic: LLVM does it by RISC-V target specific lowering pass: RISC-V gather/scatter lowering (riscv-gather-scatter-lowering) This is the RISC-V LLVM backend codes: if (II->getIntrinsicID() == Intrinsic::masked_gather) Call = Builder.CreateIntrinsic( Intrinsic::riscv_masked_strided_load, {DataType, BasePtr->getType(), Stride->getType()}, {II->getArgOperand(3), BasePtr, Stride, II->getArgOperand(2)}); else Call = Builder.CreateIntrinsic( Intrinsic::riscv_masked_strided_store, {DataType, BasePtr->getType(), Stride->getType()}, {II->getArgOperand(0), BasePtr, Stride, II->getArgOperand(3)}); I have ever tried to support strided load/store in GCC loop vectorizer, but it seems to be unacceptable. Maybe we can support strided load/stores by leveraging LLVM approach ??? Btw, LLVM risc-v gather/scatter didn't do a perfect job here: vid.v v8 vmul.vx v8, v8, a3 .... vsoxei64.v v10, (s2), v14 This is in-order indexed store which is very costly in hardware. It should be unorder indexed store or strided store. Anyway, I think we should investigate first how to support vectorization of lbm in loop vectorizer.
next prev parent reply other threads:[~2024-01-24 14:42 UTC|newest] Thread overview: 21+ messages / expand[flat|nested] mbox.gz Atom feed top 2024-01-24 14:21 [Bug tree-optimization/113583] New: " rdapp at gcc dot gnu.org 2024-01-24 14:42 ` juzhe.zhong at rivai dot ai [this message] 2024-01-24 14:44 ` [Bug tree-optimization/113583] " rdapp at gcc dot gnu.org 2024-01-24 15:00 ` juzhe.zhong at rivai dot ai 2024-01-25 3:06 ` juzhe.zhong at rivai dot ai 2024-01-25 3:13 ` juzhe.zhong at rivai dot ai 2024-01-25 5:41 ` pinskia at gcc dot gnu.org 2024-01-25 9:05 ` rguenther at suse dot de 2024-01-25 9:16 ` juzhe.zhong at rivai dot ai 2024-01-25 9:34 ` rguenth at gcc dot gnu.org 2024-01-26 9:50 ` rdapp at gcc dot gnu.org 2024-01-26 10:21 ` rguenther at suse dot de 2024-02-05 6:59 ` juzhe.zhong at rivai dot ai 2024-02-07 3:39 ` juzhe.zhong at rivai dot ai 2024-02-07 7:48 ` juzhe.zhong at rivai dot ai 2024-02-07 8:04 ` rguenther at suse dot de 2024-02-07 8:08 ` juzhe.zhong at rivai dot ai 2024-02-07 8:13 ` juzhe.zhong at rivai dot ai 2024-02-07 10:24 ` rguenther at suse dot de 2024-05-13 14:17 ` rdapp at gcc dot gnu.org 2024-05-16 12:41 ` rguenth at gcc dot gnu.org
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=bug-113583-4-2mwbLiVAQY@http.gcc.gnu.org/bugzilla/ \ --to=gcc-bugzilla@gcc.gnu.org \ --cc=gcc-bugs@gcc.gnu.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).