<p dir="ltr">Thank you Anna! Since sending this email I have reached this conclusion from the stack dump, and have been modifying calls to getIntrinsic in clang.</p>
<p dir="ltr">Many Thanks,<br>
David</p>
<div class="gmail_extra"><br><div class="gmail_quote">On Jul 28, 2016 6:18 PM, "Anna Thomas" <<a href="mailto:anna@azul.com">anna@azul.com</a>> wrote:<br type="attribution"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Hi David,<br>
<br>
The error shows that the clang source code uses this intrinsic as well, but in the old form. You need to modify the clang source code (where this intrinsic is used) to consider the overloaded operands.<br>
<br>
The assert would show the trace where clang uses this intrinsic.<br>
<br>
Hope this helps,<br>
Anna<br>
<br>
> On Jul 26, 2016, at 3:21 PM, David Noursi via llvm-dev <<a href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a>> wrote:<br>
><br>
> Hello All,<br>
><br>
> I have been modifying LLVM a project of mine, and have encountered issues with overloading an intrinsic function.<br>
><br>
> I have defined two types, abit (which is mapped, in Intrinsics.td, to i128) and qbit (accordingly mapped to i16). I would like my intrinsic function, CNOT(x,y), to accept either an abit or a qbit for each argument, so I overload with iAny and llvm_anyint_ty, as seemed to be the method for other intrinsics:<br>
><br>
> def int_CNOT: Intrinsic<[], [llvm_anyint_ty, llvm_anyint_ty],[],["llvm.CNOT"]>;<br>
><br>
> My llvm/clang directory builds successfully, but I get an error on getType from clang, which I believe is rooted in my llvm code. My question is simply, are there any additional steps to overloading an intrinsic? I stand to believe there is more to be done than what I did in the one line above, but I cannot find where to do this.<br>
><br>
> For what its worth, I get this error in generating the initial IR through clang:<br>
><br>
> clang: ../ArrayRef.h:129: const T &llvm::ArrayRef<llvm::Type *>::operator[](size_t) const [T = llvm::Type *]: Assertion `Index < Length && "Invalid index!"' failed.<br>
><br>
> Many Thanks,<br>
> David Noursi<br>
><br>
><br>
> _______________________________________________<br>
> LLVM Developers mailing list<br>
> <a href="mailto:llvm-dev@lists.llvm.org">llvm-dev@lists.llvm.org</a><br>
> <a href="http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev" rel="noreferrer" target="_blank">http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev</a><br>
<br>
</blockquote></div></div>