This is an archive of the discontinued LLVM Phabricator instance.

[OpenCL] Improve diagnostic of argument in address space conversion builtins
ClosedPublic

Authored by AlistairD on Aug 29 2018, 4:01 AM.

Details

Summary

This change adds a warning if a parameter is passed with named address space to parameter that is in generic address space.

For example:

int i;
to_private(&i); //generate warning as conversion from private to private is redundant.

Diff Detail

Event Timeline

AlistairD created this revision.Aug 29 2018, 4:01 AM

Is this a feature requested by users?

I can understand that this may be useful to pinpoint some conversions which are potentially harmful to performance. However such conversions can often be eliminated by optimization, which makes this warning less useful.

On the other hand, too many warnings is a nuance to users, therefore I am wondering whether this warning should be off by default.

Do you have any chance to have any feedback from users about how useful or intrusive this warning is.

yaxunl added inline comments.Aug 29 2018, 6:55 AM
include/clang/Basic/DiagnosticSemaKinds.td
8584

How about change this to:

may cause dynamic conversion affecting performance

Is this a feature requested by users?

I can understand that this may be useful to pinpoint some conversions which are potentially harmful to performance. However such conversions can often be eliminated by optimization, which makes this warning less useful.

On the other hand, too many warnings is a nuance to users, therefore I am wondering whether this warning should be off by default.

Do you have any chance to have any feedback from users about how useful or intrusive this warning is.

Hi Sam, no feedback from the user. If you think this is not that useful we won't commit or make is off by default as you suggested. Let us know what you think makes more sense.

yaxunl added a comment.Sep 5 2018, 7:06 AM

Is this a feature requested by users?

I can understand that this may be useful to pinpoint some conversions which are potentially harmful to performance. However such conversions can often be eliminated by optimization, which makes this warning less useful.

On the other hand, too many warnings is a nuance to users, therefore I am wondering whether this warning should be off by default.

Do you have any chance to have any feedback from users about how useful or intrusive this warning is.

Hi Sam, no feedback from the user. If you think this is not that useful we won't commit or make is off by default as you suggested. Let us know what you think makes more sense.

I suggest to make it off by default. Since implicit casting to generic pointer is allowed by spec, we only want to see this warning when we want to debug performance issues.

AlistairD updated this revision to Diff 164162.Sep 6 2018, 1:33 AM
This comment was removed by AlistairD.
AlistairD marked an inline comment as done.Sep 6 2018, 1:36 AM
AlistairD updated this revision to Diff 164835.Sep 11 2018, 3:29 AM

Reworded warning message, switched warning off by default, and added it to -Wconversion group

Anastasia accepted this revision.Sep 14 2018, 10:03 AM
Anastasia added a reviewer: Anastasia.
Anastasia removed a subscriber: Anastasia.

LGTM!

This revision is now accepted and ready to land.Sep 14 2018, 10:03 AM
This revision was automatically updated to reflect the committed changes.