This is an archive of the discontinued LLVM Phabricator instance.

[OpenMP] Fix assert fail after target implicit map checks
AbandonedPublic

Authored by jdenny on Dec 1 2017, 1:35 PM.

Details

Reviewers
ABataev
sfantao
Summary

An error like err_omp_union_type_not_allowed for an implicit mapping
on a target directive produced an assert failure.

Diff Detail

Event Timeline

jdenny created this revision.Dec 1 2017, 1:35 PM
jdenny added a subscriber: cfe-commits.
ABataev edited edge metadata.Dec 5 2017, 7:23 AM

Fixed in a bit different way in r319774

jdenny added a comment.Dec 5 2017, 9:30 AM

r319774 works for my current use cases. Thanks.

While we're on this topic, do you happen to know the rationale behind the OpenMP restriction for which err_omp_union_type_not_allowed diagnoses violations? I googled but couldn't find the rationale. If you would prefer that I ask this in a different forum, would you please suggest one? Thanks.

r319774 works for my current use cases. Thanks.

While we're on this topic, do you happen to know the rationale behind the OpenMP restriction for which err_omp_union_type_not_allowed diagnoses violations? I googled but couldn't find the rationale. If you would prefer that I ask this in a different forum, would you please suggest one? Thanks.

You cannot map the member of the union, but you can map the whole union. Mapping of separate members is not allowed because you will definitely have troubles with overlapping memory for union members.

r319774 works for my current use cases. Thanks.

While we're on this topic, do you happen to know the rationale behind the OpenMP restriction for which err_omp_union_type_not_allowed diagnoses violations? I googled but couldn't find the rationale. If you would prefer that I ask this in a different forum, would you please suggest one? Thanks.

Ahh, and in your example, there is a problem in the compiler. We should map the whole union implicitly. I'll fix this

r319774 works for my current use cases. Thanks.

While we're on this topic, do you happen to know the rationale behind the OpenMP restriction for which err_omp_union_type_not_allowed diagnoses violations? I googled but couldn't find the rationale. If you would prefer that I ask this in a different forum, would you please suggest one? Thanks.

You can try it now, there should no more error messages

jdenny added a comment.Dec 5 2017, 1:20 PM

r319774 works for my current use cases. Thanks.

While we're on this topic, do you happen to know the rationale behind the OpenMP restriction for which err_omp_union_type_not_allowed diagnoses violations? I googled but couldn't find the rationale. If you would prefer that I ask this in a different forum, would you please suggest one? Thanks.

You cannot map the member of the union, but you can map the whole union. Mapping of separate members is not allowed because you will definitely have troubles with overlapping memory for union members.

Thanks for that clarification. Is there any way to word the error message "mapped storage cannot be derived from a union" to make this point clearer? I'm thinking "an individual member of" instead of "derived from" would help. Does that work ok?

You can try it now, there should no more error messages

Yes. Thanks.

r319774 works for my current use cases. Thanks.

While we're on this topic, do you happen to know the rationale behind the OpenMP restriction for which err_omp_union_type_not_allowed diagnoses violations? I googled but couldn't find the rationale. If you would prefer that I ask this in a different forum, would you please suggest one? Thanks.

You cannot map the member of the union, but you can map the whole union. Mapping of separate members is not allowed because you will definitely have troubles with overlapping memory for union members.

Thanks for that clarification. Is there any way to word the error message "mapped storage cannot be derived from a union" to make this point clearer? I'm thinking "an individual member of" instead of "derived from" would help. Does that work ok?

You can try it now, there should no more error messages

Yes. Thanks.

I agree, that error message does not sound quite good. Maybe, mapping of union members is not allowed?

jdenny added a comment.Dec 5 2017, 1:45 PM

r319774 works for my current use cases. Thanks.

While we're on this topic, do you happen to know the rationale behind the OpenMP restriction for which err_omp_union_type_not_allowed diagnoses violations? I googled but couldn't find the rationale. If you would prefer that I ask this in a different forum, would you please suggest one? Thanks.

You cannot map the member of the union, but you can map the whole union. Mapping of separate members is not allowed because you will definitely have troubles with overlapping memory for union members.

Thanks for that clarification. Is there any way to word the error message "mapped storage cannot be derived from a union" to make this point clearer? I'm thinking "an individual member of" instead of "derived from" would help. Does that work ok?

You can try it now, there should no more error messages

Yes. Thanks.

I agree, that error message does not sound quite good. Maybe, mapping of union members is not allowed?

I like that.

jdenny added a comment.Dec 7 2017, 9:40 AM

Alexey: I see that you committed the error message change, so I think this issue is done. Is Abandon Revision correct in this scenario? Sorry, I'm new here.

Alexey: I see that you committed the error message change, so I think this issue is done. Is Abandon Revision correct in this scenario? Sorry, I'm new here.

Yes, it is correct

jdenny abandoned this revision.Dec 7 2017, 9:53 AM