Commit dc7db799 authored by Mattias Jonsson's avatar Mattias Jonsson

backport of Bug#17401628

revid:mattias.jonsson@oracle.com-20131119103616-u6t82s8cpgp0q3ex

Use of uninitialized memory in the priority queue used for returning records
in sorted order.

It happens if no previous partition have returned a row since the
beginning of index_init + an index_read* call returned
HA_ERR_KEY_NOT_FOUND for all partitions (otherwise the record
buffer/priority queue would be initialized) + an index_next/prev
call where all partitions returns HA_ERR_END_OF_FILE.
parent 020edb1c
...@@ -5398,7 +5398,7 @@ void ha_partition::return_top_record(uchar *buf) ...@@ -5398,7 +5398,7 @@ void ha_partition::return_top_record(uchar *buf)
int ha_partition::handle_ordered_index_scan_key_not_found() int ha_partition::handle_ordered_index_scan_key_not_found()
{ {
int error; int error;
uint i; uint i, old_elements= m_queue.elements;
uchar *part_buf= m_ordered_rec_buffer; uchar *part_buf= m_ordered_rec_buffer;
uchar *curr_rec_buf= NULL; uchar *curr_rec_buf= NULL;
DBUG_ENTER("ha_partition::handle_ordered_index_scan_key_not_found"); DBUG_ENTER("ha_partition::handle_ordered_index_scan_key_not_found");
...@@ -5433,9 +5433,12 @@ int ha_partition::handle_ordered_index_scan_key_not_found() ...@@ -5433,9 +5433,12 @@ int ha_partition::handle_ordered_index_scan_key_not_found()
bitmap_clear_all(&m_key_not_found_partitions); bitmap_clear_all(&m_key_not_found_partitions);
m_key_not_found= false; m_key_not_found= false;
if (m_queue.elements > old_elements)
{
/* Update m_top_entry, which may have changed. */ /* Update m_top_entry, which may have changed. */
uchar *key_buffer= queue_top(&m_queue); uchar *key_buffer= queue_top(&m_queue);
m_top_entry= uint2korr(key_buffer); m_top_entry= uint2korr(key_buffer);
}
DBUG_RETURN(0); DBUG_RETURN(0);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment