From: David Malcolm Date: Wed, 19 Jan 2022 17:09:09 +0000 (-0500) Subject: analyzer: add regression test [PR103685] X-Git-Tag: basepoints/gcc-13~1532 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=f5a9d76be849b4cf20b1b687febc34a937381dc3;p=thirdparty%2Fgcc.git analyzer: add regression test [PR103685] PR analyzer/103685 reports a false positive from -Wanalyzer-null-dereference seen at -O2 with GCC 11. I can reproduce it with GCC 11, but not with trunk; this patch adds a reduced test case that reproduces it with GCC 11 as a regression test for GCC 12 onwards. gcc/testsuite/ChangeLog: PR analyzer/103685 * gcc.dg/analyzer/torture/pr103685.c: New test. Signed-off-by: David Malcolm --- diff --git a/gcc/testsuite/gcc.dg/analyzer/torture/pr103685.c b/gcc/testsuite/gcc.dg/analyzer/torture/pr103685.c new file mode 100644 index 000000000000..1b2224874178 --- /dev/null +++ b/gcc/testsuite/gcc.dg/analyzer/torture/pr103685.c @@ -0,0 +1,33 @@ +typedef struct ec_key_st EC_KEY; +typedef struct ec_group_st EC_GROUP; +typedef struct R3410_ec { + int nid; + EC_GROUP *group; +} R3410_ec_params; +extern R3410_ec_params R3410_2012_512_paramset[]; + +static R3410_ec_params *gost_nid2params(int nid) { + R3410_ec_params *params; + + params = R3410_2012_512_paramset; + while (params->nid != 0) { + if (params->nid == nid) + return params; + params++; + } + + return ((void *)0); +} + +int fill_GOST_EC_params(EC_KEY *eckey, int nid) { + R3410_ec_params *params = gost_nid2params(nid); + if (!eckey || !params) { + return 0; + } + + if (params->group) { + return 1; + } + + return 0; +}