rjmccall added inline comments.
================ Comment at: lib/CodeGen/CGCall.cpp:80 + // used with the same version of generated operators. + RecTy = Context.getAddrSpaceQualType(RecTy, LangAS::opencl_generic); + ---------------- Anastasia wrote: > rjmccall wrote: > > I would suggest taking this opportunity to set up the AST to support > > declaring methods in an arbitrary address space, so that you can just ask a > > `CXXMethodDecl` what address space it's in. You don't have to actually add > > language support for that — OpenCL C++ would simply change the it to the > > generic address space instead of the default — but I think that's the right > > technical approach for implementing this, as opposed to adding a bunch of > > OpenCL C++ -specific logic all over the compiler that just hardcodes a > > different address space. > I quite like this idea. Apart from providing more clean implementation, it > opens opportunities for solving several problems that I am trying to > understand how to address. Specifically I am trying to find a way to > 'overload' methods based on the address space of the object. > > For example, if an object is created in the address space 1 then programmers > should be able to provide a method to be used for objects in such address > space for efficiency or even correctness issue. > > The reasons I am looking at it is that currently C++ doesn't make much sense > for address spaces, because we are removing them to generate just one > implementation with generic/default address space. However, > - Not all address spaces can be converted to generic/default address space. > Example in OpenCL is constant AS that can't be converted to any other. > - Higher performance can be achieved on some HW when using specific address > spaces instead of default. > > I was wondering if a method qualifier is a good language solution for this? > For example in OpenCL we could write something like: > > class foo > { > public: > void bar() __private; // implies bar(__private foo*) > void bar() __constant; // implies bar(__constant foo*) > }; > > I guess in C++ it can be done similarly: > > class foo > { > public: > void bar() __attribute__((address_space(1))); > void bar() __attribute__((address_space(2))); > }; > > I would quite like to solve this generically, not just for OpenCL. I think a > lot of implementation can be unified/reused then. > > Without this address spaces seem pretty useless with C++ because they are > just cast away to generic/default and no specific address space ends up at > the AST level at all. This means implementation will have to rely on the > optimizers to recover/deduce address spaces. But I would quite like to > provide a way for the developers to manually tune the code for address > spaces, just as it was done for OpenCL C. > > Let me know if you have any thought/suggestions. > I was wondering if a method qualifier is a good language solution for this? > For example in OpenCL we could write something like: Yes, I think that's a very natural extension of C++'s method-qualification rules for `const` and `volatile`. Overloads would then be resolved based on which address space was the best match. Now, to briefly take a holistic perspective on the language design, this feature would *strongly* benefit from a way to make a method templated over the address space of `this`. Unfortunately, I don't think that's reasonable to solve in a language extension; it's really something that needs core language work. That would be a pretty big leap in scope; that said, if you're interested in pursuing it, I'd be happy to share some thoughts on how it'd look, and I think there are several people in the Clang community who could help you with putting a proposal before the committee. Repository: rC Clang CHANGES SINCE LAST ACTION https://reviews.llvm.org/D54862/new/ https://reviews.llvm.org/D54862 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits