This is an archive of the discontinued LLVM Phabricator instance.

[UBsan] Skip -fsanitize=vptr instrumentations when the pointer value is null
ClosedPublic

Authored by byoungyoung on Jul 7 2014, 1:59 PM.

Details

Summary

Skip Vptr checks when the pointer value is null.

In general static_cast on null pointers causes undefined behaviors, it may not depending on the contexts. This patch enforces to skip null pointers just like it was done in -fsanitize=null.

Diff Detail

Event Timeline

byoungyoung updated this revision to Diff 11128.Jul 7 2014, 1:59 PM
byoungyoung retitled this revision from to [UBsan] Skip -fsanitize=vptr instrumentations when the pointer value is null.
byoungyoung updated this object.
byoungyoung edited the test plan for this revision. (Show Details)
byoungyoung added a subscriber: Unknown Object (MLST).
byoungyoung updated this object.
rsmith edited edge metadata.Jul 14 2014, 6:25 PM

Please provide a test.

lib/CodeGen/CGExpr.cpp
553–554

Nit: lowercase 'v'.

It'd be nice to expand on this a bit: a null pointer here is undefined behavior, but if -fsanitize=null is not enabled, we don't want to change the behavior of code in that case, so that the user doesn't have to fix all their null pointer bugs before they can find their type mismatch bugs (which are likely to be more serious).

byoungyoung edited edge metadata.

Expanded a comment, and added a testcase. I'm not sure whether the checks in the testcase would be enough, so please let me know if it doesn't.

rsmith added inline comments.Jul 15 2014, 9:30 PM
lib/CodeGen/CGExpr.cpp
464

Instead of the below fix, please instead fix this by changing this line to

if (SanOpts->Null || TCK == TCK_DowncastPointer)
test/CodeGen/ubsan-vptr-null.cpp
1 ↗(On Diff #11458)

Can you fold this into an existing test file?

13 ↗(On Diff #11458)

Please don't check the label names here: this test will fail in non-debug builds where we don't name blocks.

15 ↗(On Diff #11458)

Likewise here.

Update the patch as commented except the test cast folding. Richard, could you please point which file should I fold into for the testcase? As far as I checked, all existing ubsan tests are written in C (except type-blacklist one), but this case has to be done in C++.

Ah... thanks again Richard to point where the test file is :(, and merged the test.

rsmith accepted this revision.Jul 17 2014, 10:18 AM
rsmith edited edge metadata.

LGTM

This revision is now accepted and ready to land.Jul 17 2014, 10:18 AM

rsmith@ - could you please land this patch as I don't have a commit permission?

lib/CodeGen/CGExpr.cpp
553–554

Thanks Richard for the comments! Let me change the patch as you suggested.

I was confused on your comment in -fsanitize=null, which says "When performing a pointer downcast, it's OK if the value is null. Skip the remaining checks in that case". Is this mean that the down-casted null pointer is a result of "defined behavior", or did you mean something else? From my shallow understanding and your review comments, it seems "undefined" though.

samsonov edited edge metadata.Jul 18 2014, 11:24 AM

Landed in r213393. Thanks!

samsonov closed this revision.Jul 18 2014, 11:24 AM