-
Notifications
You must be signed in to change notification settings - Fork 47
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for opaque pointers and structs #51
base: master
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Looks reasonable.
When I added support for LLVM 15 (with opaque pointer support) I didn't need this. I usually used all these helper methods like GlobalValueType
and the like to replace ElementType
calls, see: tinygo-org/tinygo@2fd669c. But if you're building a backend then I suppose this may be necessary.
I'm not sure what's up with the CI. I hope it's a temporary failure. |
Looks like this needs to be done to pass CI on macOS... |
This reverts commit 69314f8.
Seemed like python was failing to install in the CI.... I tried a fix to force python to install, but now it's saying that python is already installed. So it must have been updated in the base image. So I reverted my "fix" since it shouldn't be necessary. |
The fix for opaque structs seems necessary indeed (and is unrelated to opaque pointers: opaque structs are simply structs without a body and are part of LLVM for years). I'm not so sure about specific support for opaque pointers. They were last used by default in LLVM 14, and have been removed entirely in LLVM 17. So I'd say that new code should assume all pointers are opaque. Or do you still need to compile against LLVM 14 for some reason? This is what LLVMBool LLVMPointerTypeIsOpaque(LLVMTypeRef Ty) {
return true;
} |
If you call
ElementType()
on an opaque pointer, it causes a segfault. Unfortunately there was no way to know you had an opaque pointer on your hands before this change, so there was no way to know that callingElementType()
on the type that was aPointerTypeKind
would crash.This change introduces a
IsPointerOpaque()
method to check for opaque pointers. While I was at it, I noticed there was no way to check for opaque structs as well, so I added that. I also tried callingSubtypes()
and noticed it causes an index out of range panic when there is no subtypes, so I fixed that too.When I uploaded the fix, I noticed that LLVM 14 doesn't have the method to check for opaque pointers, which is odd because opaque pointers have been a thing since 2015.... at any rate, it was simple enough to add a back port for it, though it took a couple tries to get the CI to pass.