Skip to content

Commit

Permalink
Storable 3.05_11: croak on sizes read > I32_MAX
Browse files Browse the repository at this point in the history
detected by coverity:
CID 165606 (#2 of 2): Untrusted value as argument (TAINTED_SCALAR)
146. tainted_data: Passing tainted variable size to a tainted sink.

(cherry picked from commit 735d922)

Conflicts:
	dist/Storable/Storable.pm
  • Loading branch information
rurban authored and tonycoz committed Jan 10, 2018
1 parent ef28734 commit 0dab22a
Showing 1 changed file with 3 additions and 2 deletions.
5 changes: 3 additions & 2 deletions dist/Storable/Storable.xs
Original file line number Diff line number Diff line change
Expand Up @@ -566,6 +566,8 @@ static stcxt_t *Context_ptr = NULL;
#define KBUFCHK(x) \
STMT_START { \
if (x >= ksiz) { \
if (x >= I32_MAX) \
CROAK(("Too large size > I32_MAX")); \
TRACEME(("** extending kbuf to %d bytes (had %d)", \
(int)(x+1), (int)ksiz)); \
Renew(kbuf, x+1, char); \
Expand Down Expand Up @@ -5863,8 +5865,7 @@ static SV *retrieve_svundef_elem(pTHX_ stcxt_t *cxt, const char *cname)
*/
static SV *retrieve_array(pTHX_ stcxt_t *cxt, const char *cname)
{
I32 len;
I32 i;
I32 len, i;
AV *av;
SV *sv;
HV *stash;
Expand Down

0 comments on commit 0dab22a

Please sign in to comment.