[openssl-project] coverity defect release criteria (Fwd: New Defects reported by Coverity Scan for openssl/openssl)

Dr. Matthias St. Pierre Matthias.St.Pierre at ncp-e.com
Sun Sep 9 22:38:50 UTC 2018


preliminary status report:

*** CID 1439138:  Integer handling issues  (NEGATIVE_RETURNS)
	see https://github.com/openssl/openssl/pull/7156
	
*** CID 1439137:  Integer handling issues  (NEGATIVE_RETURNS)
	work in progress...               

*** CID 1439136:  Resource leaks  (RESOURCE_LEAK)
	see https://github.com/openssl/openssl/pull/7155

*** CID 1439135:  Memory - illegal accesses  (INCOMPATIBLE_CAST)
	todo

*** CID 1423323:  Null pointer dereferences  (FORWARD_NULL)
	see https://github.com/openssl/openssl/pull/7158

*** CID 1201571:  Error handling issues  (CHECKED_RETURN)
	todo

if anybody wants to fix one of the CIDs marked 'todo', no problem. Just drop a note on the openssl-project list.

Matthias


> -----Ursprüngliche Nachricht-----
> Von: openssl-project <openssl-project-bounces at openssl.org> Im Auftrag von Benjamin Kaduk
> Gesendet: Sonntag, 9. September 2018 18:04
> An: openssl-project at openssl.org
> Betreff: [openssl-project] coverity defect release criteria (Fwd: New Defects reported by Coverity Scan for openssl/openssl)
> 
> I see that Matthias has opened pull requests for a couple of these already;
> are you planning to work through the rest of them as well?
> 
> -Ben
> 
> On Sun, Sep 09, 2018 at 09:28:12AM +0000, scan-admin at coverity.com wrote:
> > Hi,
> >
> > Please find the latest report on new defect(s) introduced to openssl/openssl found with Coverity Scan.
> >
> > 6 new defect(s) introduced to openssl/openssl found with Coverity Scan.
> >
> >
> > New defect(s) Reported-by: Coverity Scan
> > Showing 6 of 6 defect(s)
> >
> >
> > ** CID 1439138:  Integer handling issues  (NEGATIVE_RETURNS)
> >
> >
> > ________________________________________________________________________________________________________
> > *** CID 1439138:  Integer handling issues  (NEGATIVE_RETURNS)
> > /crypto/rsa/rsa_pss.c: 247 in RSA_padding_add_PKCS1_PSS_mgf1()
> > 241         EM[emLen - 1] = 0xbc;
> > 242
> > 243         ret = 1;
> > 244
> > 245      err:
> > 246         EVP_MD_CTX_free(ctx);
> > >>>     CID 1439138:  Integer handling issues  (NEGATIVE_RETURNS)
> > >>>     "sLen" is passed to a parameter that cannot be negative.
> > 247         OPENSSL_clear_free(salt, sLen);
> > 248
> > 249         return ret;
> > 250
> > 251     }
> > 252
> > 253     #if defined(_MSC_VER)
> > 254     # pragma optimize("",on)
> >
> > ** CID 1439137:  Integer handling issues  (NEGATIVE_RETURNS)
> >
> >
> > ________________________________________________________________________________________________________
> > *** CID 1439137:  Integer handling issues  (NEGATIVE_RETURNS)
> > /crypto/sm2/sm2_pmeth.c: 277 in pkey_sm2_digest_custom()
> > 271         }
> > 272
> > 273         /* get hashed prefix 'z' of tbs message */
> > 274         if (!sm2_compute_z_digest(z, md, smctx->id, smctx->id_len, ec))
> > 275             return 0;
> > 276
> > >>>     CID 1439137:  Integer handling issues  (NEGATIVE_RETURNS)
> > >>>     "EVP_MD_size(md)" is passed to a parameter that cannot be negative.
> > 277         return EVP_DigestUpdate(mctx, z, EVP_MD_size(md));
> > 278     }
> > 279
> > 280     const EVP_PKEY_METHOD sm2_pkey_meth = {
> > 281         EVP_PKEY_SM2,
> > 282         0,
> >
> > ** CID 1439136:  Resource leaks  (RESOURCE_LEAK)
> > /test/dhtest.c: 202 in dh_test()
> >
> >
> > ________________________________________________________________________________________________________
> > *** CID 1439136:  Resource leaks  (RESOURCE_LEAK)
> > /test/dhtest.c: 202 in dh_test()
> > 196         BN_free(bp);
> > 197         BN_free(bg);
> > 198         BN_free(cpriv_key);
> > 199         BN_GENCB_free(_cb);
> > 200         DH_free(dh);
> > 201
> > >>>     CID 1439136:  Resource leaks  (RESOURCE_LEAK)
> > >>>     Variable "priv_key" going out of scope leaks the storage it points to.
> > 202         return ret;
> > 203     }
> > 204
> > 205     static int cb(int p, int n, BN_GENCB *arg)
> > 206     {
> > 207         return 1;
> >
> > ** CID 1439135:  Memory - illegal accesses  (INCOMPATIBLE_CAST)
> >
> >
> > ________________________________________________________________________________________________________
> > *** CID 1439135:  Memory - illegal accesses  (INCOMPATIBLE_CAST)
> > /apps/speed.c: 3105 in speed_main()
> > 3099                 ERR_print_errors(bio_err);
> > 3100                 rsa_count = 1;
> > 3101             } else {
> > 3102                 for (i = 0; i < loopargs_len; i++) {
> > 3103                     /* Perform EdDSA signature test */
> > 3104                     loopargs[i].siglen = test_ed_curves[testnum].siglen;
> > >>>     CID 1439135:  Memory - illegal accesses  (INCOMPATIBLE_CAST)
> > >>>     Pointer "&loopargs[i].siglen" points to an object whose effective type is "unsigned int" (32 bits, unsigned) but is dereferenced as a
> wider "unsigned long" (64 bits, unsigned).  This may lead to memory corruption.
> > 3105                     st = EVP_DigestSign(loopargs[i].eddsa_ctx[testnum],
> > 3106                                         loopargs[i].buf2, (size_t *)&loopargs[i].siglen,
> > 3107                                         loopargs[i].buf, 20);
> > 3108                     if (st == 0)
> > 3109                         break;
> > 3110                 }
> >
> > ** CID 1423323:  Null pointer dereferences  (FORWARD_NULL)
> >
> >
> > ________________________________________________________________________________________________________
> > *** CID 1423323:  Null pointer dereferences  (FORWARD_NULL)
> > /test/evp_extra_test.c: 894 in test_EVP_PKEY_check()
> > 888
> > 889         if (!TEST_int_eq(EVP_PKEY_param_check(ctx), expected_param_check))
> > 890             goto done;
> > 891
> > 892         ctx2 = EVP_PKEY_CTX_new_id(0xdefaced, NULL);
> > 893         /* assign the pkey directly, as an internal test */
> > >>>     CID 1423323:  Null pointer dereferences  (FORWARD_NULL)
> > >>>     Passing null pointer "pkey" to "EVP_PKEY_up_ref", which dereferences it.
> > 894         EVP_PKEY_up_ref(pkey);
> > 895         ctx2->pkey = pkey;
> > 896
> > 897         if (!TEST_int_eq(EVP_PKEY_check(ctx2), 0xbeef))
> > 898             goto done;
> > 899
> >
> > ** CID 1201571:  Error handling issues  (CHECKED_RETURN)
> > /crypto/pkcs12/p12_init.c: 25 in PKCS12_init()
> >
> >
> > ________________________________________________________________________________________________________
> > *** CID 1201571:  Error handling issues  (CHECKED_RETURN)
> > /crypto/pkcs12/p12_init.c: 25 in PKCS12_init()
> > 19         PKCS12 *pkcs12;
> > 20
> > 21         if ((pkcs12 = PKCS12_new()) == NULL) {
> > 22             PKCS12err(PKCS12_F_PKCS12_INIT, ERR_R_MALLOC_FAILURE);
> > 23             return NULL;
> > 24         }
> > >>>     CID 1201571:  Error handling issues  (CHECKED_RETURN)
> > >>>     Calling "ASN1_INTEGER_set" without checking return value (as is done elsewhere 30 out of 37 times).
> > 25         ASN1_INTEGER_set(pkcs12->version, 3);
> > 26         pkcs12->authsafes->type = OBJ_nid2obj(mode);
> > 27         switch (mode) {
> > 28         case NID_pkcs7_data:
> > 29             if ((pkcs12->authsafes->d.data = ASN1_OCTET_STRING_new()) == NULL) {
> > 30                 PKCS12err(PKCS12_F_PKCS12_INIT, ERR_R_MALLOC_FAILURE);
> >
> >
> > ________________________________________________________________________________________________________
> > To view the defects in Coverity Scan visit, https://u2389337.ct.sendgrid.net/wf/click?upn=08onrYu34A-2BWcWUl-2F-
> 2BfV0V05UPxvVjWch-2Bd2MGckcRakUl6QyjujEohY7rPpoYUE4H-2Fm-2BeoDOl8jw7bf4Z78hw-3D-3D_bpOft2V4l9NXEcTx5CnNFJqpP-
> 2F8a09dz6vsuNilvAJgBy9hWgnGhTAFGZnkvhcJuSQocoiCV36Dw66FwvViDOF-2BGQbzbMH8LM1tsnputryXt7SEgZZ-
> 2FmpoWsuVr91UzOFBmmlL0bipzCjL7WfoT7QvLLnFuGxTjboshY44ftCBEhW8TAZR-2B1c1y7JdbYkdSXw-2B7Vmts-2F-
> 2BitkvIjISgebBlgXuThX1DnzutpYSf00XD0-3D
> >
> >   To manage Coverity Scan email notifications for "kaduk-github at mit.edu", click
> https://u2389337.ct.sendgrid.net/wf/click?upn=08onrYu34A-2BWcWUl-2F-2BfV0V05UPxvVjWch-2Bd2MGckcRbVDbis712qZDP-
> 2FA8y06Nq414hC6p-2BsqBEViFMJYotwSt4SYNeSzd6tPCdCHgDzpHIBW-2Fr0I0sQJCop-2Fx5Lu2ueYFxYqLmFh7APZbTTED-
> 2B53KXZ2qVo0Y2q2bUC-2BpL2TzE-3D_bpOft2V4l9NXEcTx5CnNFJqpP-2F8a09dz6vsuNilvAJgBy9hWgnGhTAFGZnkvhcJu7xxYKPr1HkiPh-
> 2BL3MaUbhQMZae3MPjv9c6bU6U4uhOZEhiS1P-2BwpukQ4-2BcSzk5FouA75ij0odEEgZcWTB05BKimz0wg0Y8JsC1Izz20-
> 2FpfRp2kjWD47vvs4NmxuDPkNqvS3qoLRQ0vIXW8CFF339G-2B7jGolZ214Wxo3Gh6Hc0HY-3D
> >
> _______________________________________________
> openssl-project mailing list
> openssl-project at openssl.org
> https://mta.openssl.org/mailman/listinfo/openssl-project


More information about the openssl-project mailing list