[PATCH] D99565: [X86] Support replacing aligned vector moves with unaligned moves when avx is enabled.

Craig Topper via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Tue Apr 13 01:00:13 PDT 2021


craig.topper added inline comments.


================
Comment at: clang/include/clang/Driver/Options.td:1649
+    Group<f_Group>,  Flags<[CoreOption, HelpHidden]>,
+    HelpText<"Do not emit unaligned move instructions unless users explicitly uses.">;
 def fassociative_math : Flag<["-"], "fassociative-math">, Group<f_Group>;
----------------
This makes it sound like unaligned moves would never be used even if it unaligned.


================
Comment at: llvm/lib/Target/X86/X86InstrFragmentsSIMD.td:834
+  if (EnableX86UnalignedVecMove)
+    return !Subtarget->hasAVX();
   auto *St = cast<StoreSDNode>(N);
----------------
Won’t this make this return true for any load when only SSE is enabled. So SSE will use an aligned load instruction for an unaligned address.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D99565/new/

https://reviews.llvm.org/D99565



More information about the llvm-commits mailing list