I am trying to fix a problem in Bugzilla which has been open for more
than a year, and which seems to be related to DBI, and I was hoping 
that you could give me some direction in trying to solve the problem. On
my site the problem is totally repeatable. I am using Perl 5.8.8,
DBI-1.613_71. 

In short: on one line a variable is a reference to an array, and,
directly after a return statement, the value is no longer an array, but
a scalar
having a reference to DBI. So it looks like something is
changing/corrupting the Perl stack. Since Driver.xst and Perl.xsi change
the stack it seems
that that are likely to be causing the problem.

The bug in Bugzilla is:

https://bugzilla.mozilla.org/show_bug.cgi?id=481459


The code that seems to be causing the problem is:

my $objects = $dbh->selectall_arrayref($sql, {Slice=>{}}, @untainted);

For a given $sql and a given @untainted, the $objects returned is not 
an array but a reference to DBI::db=HASH

When I step through the code, selectall_arrayref works correctly until 
the final return statement. Before the return statement, the type is an 
array, and directly afterwards, it is a DBI::db=HASH.

The sql statement is:

SELECT id,value,product_id FROM versions WHERE  id IN 
(?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,
?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?
,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,
?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,
?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,
?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?
,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,
?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?
,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?) 
   ORDER BY id

and the @untainted array is an equivalent number of small integers.

For a smaller or larger number of variables selectall_arrayref is working 
correctly. 

I changed the calling routine so that when an error was detected, the code was 
run again. On second and consecutive times the 
code worked correctly.

I am prepared to debug the problem if someone could help.

Peter

Reply via email to