[PATCH] D64095: SVFS implementation according to RFC: Interface user provided vector functions with the vectorizer.

Sumedh Arani via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Wed Jul 31 14:41:39 PDT 2019


aranisumedh marked 3 inline comments as done.
aranisumedh added inline comments.


================
Comment at: llvm/include/llvm/Analysis/SearchVectorFunctionSystem.h:137
+                .Case("Us", ParameterKind::OMP_LinearUValPos)
+                .Case("u",  ParameterKind::OMP_Uniform);
+        }
----------------
jdoerfert wrote:
> aranisumedh wrote:
> > jdoerfert wrote:
> > > The default case is missing. `llvm_unreachable` I assume.
> > I don't think StringSwitch Default Case handles `llvm_unreachable`
> > 
> I guess you can do this: add a default case, if that value is chosen invoke llvm_unreachable.
Will update.


================
Comment at: llvm/include/llvm/Analysis/SearchVectorFunctionSystem.h:121
+struct SVFS {
+  Module *M;
+
----------------
jdoerfert wrote:
> aranisumedh wrote:
> > jdoerfert wrote:
> > > I found a single use of this exposed member and that use can be replaced by something like:
> > > `Call->getModule()`
> > > If there is no reason to have this member, get rid of it and all the `init` stuff.
> > I did make this change but however, as I'm building the CallInst programmatically in the test case, this leads to a segmentation fault. 
> > 
> > However, in the patch that is to follow(hooking to the loopVectorizer), Call->getModule() works perfectly. 
> > 
> > Do you have any suggestions as so as to get the getVectorizedFunction test working as specified in SearchVectorFunctionTest.cpp
> > 
> > Also, do I use AssertionSuccess() and AssertionFailure() for testing bad inputs?
> You lost me here.
I have added a new comment that points to the issue better. 


================
Comment at: llvm/unittests/Analysis/SearchVectorFunctionSystemTest.cpp:227
+                   ConstantInt::get(Type::getInt32Ty(Ctx), 20)};
+  std::unique_ptr<CallInst> Caller(CallInst::Create(F, Args));
+  CallInst *Call = Caller.get();
----------------
I create the CallInst programmatically here. The stack trace tells me the bug is in `getVectorizedFunction` in SearchVectorFunctionSystem.cpp. When it calls `Call->getModule()`, a segmentation fault occurs. As I understand, the CallInst is probably not getting inserted in the module.

I was wondering how do I modify the test case so as to suit this functionality?







================
Comment at: llvm/unittests/Analysis/SearchVectorFunctionSystemTest.cpp:273
+  outs() << Call->getModule() << "\n";
+  outs() << M.get() << "\n";
+
----------------
jdoerfert wrote:
> I doubt we want to output anything here.
Yes. Forgot to remove the comments. It was for debugging purpose.


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

https://reviews.llvm.org/D64095





More information about the llvm-commits mailing list