[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