This change affects 'SemaOpenCLCXX/newdelete.cl' test,
thus the patch contains adjustments in types validation of
operators new and delete
Details
Diff Detail
- Repository
- rG LLVM Github Monorepo
Unit Tests
Event Timeline
@svenvh We haven't looked into address spaces in details when adding this. I wonder what behavior would make sense for new/delete? Do we plan to allow new/delete in named address spaces or only in generic? It might be more helpful to allow named address spaces since generic has not been intended for allocations, but however generic makes things easier because it avoids duplication and the concrete address space can always be cast to it. I think constant doesn't make sense at all since nothing can be done with a readonly chunk of memory?
Another aspect to consider - how will address spaces aligned with the concept of overloading i.e.
- Declaring multiple new operators with different address spaces in the same scope generates an error since overloading by the return type is not allowed.
- Declaring multiple delete operators differing by address spaces seems to fail because C++ doesn't allow to overload it yet.
While the test in the review works, if we start using other than generic address spaces it fails with various compile-time errors. For example, I get an error if I try to assign to local address space pointer even if the declaration of new has the address space too:
`class A {
public:
__local void* operator new(size_t);
};
__local A* a = new A;`
error: assigning 'A *' to '__local A *' changes address space of pointer
Perhaps this deserves a PR at least?
clang/lib/Sema/SemaDeclCXX.cpp | ||
---|---|---|
15287 | I think getAs returns a PointerType* that we could just use straight away without the need for CanQual? but actually, you could just change to auto* that would make things easier. The same below. | |
15289 | FYI I think ExpectedResultType is going to be in always in the canonical form here by the way it is constructed so getCanonicalType should be redundant. |
Thanks for review. Just to be clear: can I proceed with this? Or we should discuss it first? As I see possible this change can be abandoned after discussion.
Moreover, I see nothing about address space of void pointer in OpenCL C spec. For example (OpenCL C 2.2, Clause 6.3.2.3 - Pointers, replace the first two paragraphs with the following paragraphs):
A pointer to void in any address space may be converted to or from a pointer to any incomplete or
object type. A pointer to any incomplete or object type in some address space may be converted to a
pointer to void in an enclosing address space and back again; the result shall compare equal to the
original pointer.
Do I understand correctly that this means void pointer is not necessarily points to generic AS?
It seems the use of new/delete still needs a more thorough investigation indeed. I'd suggest we don't try to solve that in this patch (nor hold this back), so a PR sounds like a good option.
Do I understand correctly that this means void pointer is not necessarily points to generic AS?
This is an internal Clang pointer type that is used in very few places as a pointer to anything, so it makes sense to add generic.
I agree this change actually fixes a bug i.e. missing generic address space for C++ mode. We should go ahead and commit it.
clang/lib/Sema/SemaDeclCXX.cpp | ||
---|---|---|
15289 | Not sure if I understand this one, because QualType can't be cast to CanQualType so I think getCanonicalType() is needed. But I tried to unify existing logic and rewrote RemoveAddressSpaceFromPtr() to return CanQualType as it can be implicitly cast to QualType. |
FYI I have created PR49191 for the issues with address spaces I have highlighted earlier.
I think getAs returns a PointerType* that we could just use straight away without the need for CanQual? but actually, you could just change to auto* that would make things easier.
The same below.