<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/63681>63681</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
The clang static analyzer cannot generate path-sensitive error reports after enabling the ipa-always-inline-size parameter
</td>
</tr>
<tr>
<th>Labels</th>
<td>
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
yinluming13579
</td>
</tr>
</table>
<pre>
Hi, I've been checking my code for bugs recently using the clang static analyzer's null pointer dereference checker.During the detection process, I encountered such a problem: Now there is a global variable named pointer, and the pointer variable is assigned a value of NULL in a function, and then there is a function call of other translation units, but the function call does not Modify the value of pointer. After this function call, I dereference this variable, thus forming a null pointer dereference bug.When I checked the bug with the clang static analyzer, I found that when the clang static analyzer checked the bug, the cross-translation unit module of the clang static analyzer would not inline the function call by default, so the constraint solver thought that the pointer was Where dereferenced this pointer may or may not be null! I guess the reason for this problem is because clang static analyzer doesn't inline the function call, so it can't analyze the function call, so it can't determine whether the function call modifies the global variable pointer.So I used the parameter ipa-always-inline-size, which allows function calls across translation units to be checked inline, by checking std::tie(notNullState, nullState) = state->assume(location); The value of notNullState and nullState in the code, I found that after using this parameter, only nullState exists but notNullState does not exist, and the solver gives a correct judgment!
But the ensuing problem is that when I use this parameter, DereferenceChecker can detect the null pointer dereferencing bug, but cannot generate the corresponding path-sensitive inspection report. If I do not use this parameter, the constraint solver cannot get the correct the result of. I think since the constraint solver can check that this is a null pointer dereference bug after using the parameter and the clang static analyzer cannot generate an error report, it should be a bug of the clang static analyzer.
Here are the clang arguments I use:
`/project/coreutils-8.31# /usr/local/bin/clang-17 --analyze -Qunused-arguments -Xclang -analyzer-opt-analyze-headers -Xclang -analyzer-output=plist-multi-file -o /project/coreutils-8.31/reports/comm.c_clangsa_609b90dbff1573250e9ad7cef4b8d72c.plist -Xclang -analyzer-config -Xclang expand-macros=true -Xclang -analyzer-checker=alpha.security.cert.env.InvalidPtr,alpha.security.cert.pos.34c,core.CallAndMessage,core.DivideZero,core.NonNullParamChecker,core.NullDereference,core.StackAddressEscape,core.UndefinedBinaryOperatorResult,core.VLASize,core.uninitialized.ArraySubscript,core.uninitialized.Assign,core.uninitialized.Branch,core.uninitialized.CapturedBlockVariable,core.uninitialized.NewArraySize,core.uninitialized.UndefReturn,cplusplus.InnerPointer,cplusplus.Move,cplusplus.NewDelete,cplusplus.NewDeleteLeaks,cplusplus.PlacementNew,cplusplus.PureVirtualCall,cplusplus.StringChecker,deadcode.DeadStores,nullability.NullPassedToNonnull,nullability.NullReturnedFromNonnull,optin.cplusplus.UninitializedObject,optin.cplusplus.VirtualCall,optin.portability.UnixAPI,security.FloatLoopCounter,security.insecureAPI.UncheckedReturn,security.insecureAPI.getpw,security.insecureAPI.gets,security.insecureAPI.mkstemp,security.insecureAPI.mktemp,security.insecureAPI.rand,security.insecureAPI.vfork,unix.API,unix.MismatchedDeallocator,unix.Vfork,unix.cstring.BadSizeArg,unix.cstring.NullArg,valist.CopyToSelf,valist.Uninitialized,valist.Unterminated -Xclang -analyzer-disable-checker=unix.Malloc,unix.MallocSizeof,optin.portability.UnixAPI -Xclang -analyzer-config -Xclang aggressive-binary-operation-simplification=true -Xclang -analyzer-config -Xclang crosscheck-with-z3=true -Xclang -analyzer-config -Xclang experimental-enable-naive-ctu-analysis=true -Xclang -analyzer-config -Xclang ctu-dir=/project/coreutils-8.31/reports/ctu-dir/x86_64 -Xclang -analyzer-config -Xclang display-ctu-progress=true -x c --target=x86_64-linux-gnu -std=gnu11 -Xclang -analyzer-config -Xclang core.NullDereference=true -Xclang -analyzer-max-loop -Xclang 10 -Xclang -analyzer-config -Xclang max-inlinable-size=500 -Xclang -analyzer-config -Xclang max-nodes=2250000 -Xclang -analyzer-config -Xclang ipa-always-inline-size=80 -Xclang -analyzer-config -Xclang max-times-inline-large=80000 -I/project/coreutils-8.31 -I/project/coreutils-8.31/lib -I/project/coreutils-8.31/lib -I/project/coreutils-8.31/lib -I/project/coreutils-8.31/src -I/project/coreutils-8.31/src -O2 -isystem /usr/local/include -isystem /usr/include/x86_64-linux-gnu -isystem /usr/include /project/coreutils-8.31/src/comm.c`
The project I detected is the comm.c file of coreutils8.31
Below is the test code I used:
pointer = NULL;
thisline[i] = readlinebuffer_delim (all_line[i][alt[i][0]],
streams[i], delim);
printf("%d", *pointer);
readlinebuffer_delim is a function that needs to be checked across translation units, and pointer is a global variable pointer. If the ipa-always-inline-size parameter is not added, the clang static analyzer will not analyze the readlinebuffer_delim function call, so the constraint solver will think that printf ("%d", *pointer); Whether the pointer variable of the position is empty is uncertain. If the ipa-always-inline-size parameter is used, the constraint solver can judge that the pointer variable is null, but this clang static analyzer Unable to generate path-sensitive bug reports.
Thank you for taking the time to read my question, thank you for your help, I really tried many ways, but none of them can solve this problem, looking forward to your reply!
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJy8OUtz2zjSv4a-oMiSSMuSDz7I0rjGVY4n3zhOvtpLCgSaFMYgwMVDMvPrtxogJdqWFO9lDymZ6Af6je4OtVbUCuAmmd0ms_UF9W6jzU0nlPSNUPW0mM2vL0rNu5s_RZKvyH2Sz7dASgBF2AbYi1A1aTrCNAdSaUNKX1tigIFysiPeItxtgDBJVU2so04wQhWV3S8wST63RHkpSauFcmAIBwMVGFAMIn8w2dqbgQsHB8wJrUhrNANrg0wEFNMe6YET69mGUISXEpqkWJJHvUNiA0RYQkktdUkl2VIjaCmBKNoAHwRAflTxcNkg0x4TyaPBOKFkS6UHoivy-PzwQIQilFReBelGXNT46gFOGJUSSTUCiTNUWUkDxCvhglald0GKtzRcgyVKO_JFc1F1AWMvSC9wRpYVyu02wr4lj9Ya2zjgDAoi2G28RUei9wk97ZzS19kPVO--91O0WelrshNuc87nKEOlfbAPdWTXG-k4-nvuUUYgzGhr0_eWI43mXgZjnOa4017yYEShpFBwxMxlRzhU1EuH91kduWllnaFCOWK13AYLa19vXNRjHDI7asmP4PeRzXi09oDT0I7o-IOylBCMneRTck9qD9YGjgao1SqkVqSOcY3xVAKj3p7SEiNFJfn8tJa9asIRRiNmT_wZVMxEDBJA_8Uo_mDFBmNUQFTkfdoNwfqkyT3xtvdwSw1tkDURLU2p3NHOplGB1IpfIUR3G4EpLqXevYtvS2iIi48ZRZxGCw_BFDmGNOsOdcw6nhTLpFg6AUm-UNo9eimfHHUBVR0-rklSrIPJIU2KP6i1vkESqRmNBeA6KW7Jt3F2jtmF6rDnh8UjBhiHD-lBQy4PhRQjYDARomoluxEjeBXW2VA73ly3LxsBYVzk-kiuxRawQjFtDDBH_vG8bkC5JJ8mk3UyWd725QiU9SjKKA4PWRwceUTK9SEJVrGoYxz11TywPVFn8KY-6VEnRhUqUYMCg2pFoxkDttWKB7Go26QWlBVObNGwtu0fDAOtNi4j9xWWQB2scVza47m-v9sdru2FN2C9dERXGblHfuqFWBGr6wlOMeaGuiFsfB7OFdt3cTDOlMGVJ-rnO5tRRcAYbXqDoMLCEbsJRbEEQsNt5wpoFiPiTyxv1MAIkZraY9TYGAmYTAE1uZok-V1r9D_AXJLfMW3AOyFtusiKaZIXJMnvvDVJfocZJJP8rhQKEZFtOp2TNB1qU_p_XmG5SA-Xpf8frx9wTKpbN3ykG6AczFEs71rvkmLdSmFd2njpRFoJCSTV5KzAd9F4NoCaJmM_A29Lf15NrsvrCS-rajqbF_lsAteUzxlUl-WCz3OWhbuOCMO0qkS9B8BrSxVPm1DQkmLtjIdjVDGdkmJNZbuhmQXmjXBdxsC4DNQ2u1dbKgX_6jC2jyG12mbFJUvyFWqZraiUS8W_gLW0huF0LbaCw7_A6OHkUSusL18xDPuk3oO8lKOUH46fHGUvS84NWPuHZbTdQ54Vh0oo4LdCUdP91WKoavN3yKsB6fvD8im-AOHTK6GEE1SKX8CzpTG0e_KlZUa07gRO6N2Ow24NVWxzHLairfMG-K3U7OX7oVc6gvoIuyjJSUGDqn-D8yZI0kpv8V92rxSYr_sm9AD4orfw5uARdmuQ4E6cPgB9sW9AXyVlgJnyCLu3AG_guzDOU7mKj_wB9uSw6T44lgPl-D5la6D8yWkDeAlWLFoKicEUo8Fa4N_0o1axmfmAEVUHfmd0c8DSrRMqO9z-PLbZX2XMwg9Yb2WPUEzL4b5nJV6XX--TfLWP-DupqXvQul3FgWEMEyr8Ccuv99mz6luFvauOotXg2t0ZoD0Fa16sg6Y9DT4HNVTxU7Btpc1Lkq-8Eq9ZVD78-UXYhjq2Ab4GbJ0YJtgA_D4mYja4PrulHMN4aer3EPRjPMbSYl220m33TT-BrA5nb1w4Po59I3XAj9QzLixm16iuRemDyHtdwhcKp6tzjv99laV1jdVIbCEtQ-lJdag9QqvUiqaVohJ9R3e6BL9lGRrQIH6Kg1D6q_g0Kby2YARmKpUpqGAIRVE45nyksuLcY_BOEudTLtCGn37Leor87nVx9fPq8vd3cGFbSbsgYGt0sOZewFfCSJo6amrAVzbyTKVQ_jWtlSdpaLjXtfLT6SfUOfa0nLRFQ19TqXW7B00nv78CicJoEEwf5o1iPZt8klJpDqh8ns8mk88QnRhxivXikzc60cCeVqKdA3G4_P6M089DsQsT5f8Mxxr2OZy_cpIK22Hh_NgvCsWk53AEo4fsg3ocgKeQf9P9WcP2nR_2tqHJxWGvpwlLFpxtcNS0_RiAyCR0l7oie5aBY5ywQOrdgO7AurhUi8PxvpUexgOcPx-fHx6S4jYCcIwIQ-3sViSzdUAwQDmelb6qwPzkIAXquqBS_hzhJrNbKt3hYxJ-1km-iqyJdQZoYweMfEUCqzjl9nIZoVyV5Iskz5N8xsPPiiT5cr9ZOyAflevthiyMRgqAvx_dT034w1A7GOjorm-_IbuP883xDBxvIeLYTDkPj9i5rZKQMuKOlihHFT22WTk-KQaecaAM9ohGJr-1Mvkx2sl8WGP2s12rcUjWCnWEpnUd_uEVzgRUqP_KRCFCz03OYZ8AH_dk49Vq3wr2i09hT9j5ORRnDIr9SPtu6Mf5tX_TsiE1qXohnfZxj0ZfhiEaCyiyQj-RpiP_9mCHBa57Q9Rpb8gGZBsXNAabqI44I4CThqqOoIUG8ZVWg5mboH6wxJsFHqJKrYMklTY7ajgKEq4x0MouyacX_Kbg18U1vYCb6dViMbucXxeTi83NJeOLxXU5h6vZfFZcLi4ZY_NFTvm8YtOqpBfiJp_kxWQ-mU2uJ7NikrHZhM3Y9YIuKmCXC5ZcTqChQmZSbptMm_pCWOvh5qq4WkwvJC1B2uE_BcwNIqWlr21yOcEuzh7InHASbr59ev3wzlfjVYTtdxyh8xk89Lvwu_BG3mycay2WyPwuye9q4Ta-zJhu8H2Q2-EnPVT0oCx2PEHf_wQAAP__Y2HnQQ">