Commit 4c3b59ab authored by Robert Haas's avatar Robert Haas

Fix failure when a shared tidbitmap has only one page.

Commit 98e6e890 made inadequate
provision for the case of a single-page shared tidbitmap.  It
allocate space for a shared PagetableEntry, but failed to
initialize it.

Report by Thomas Munro.  Patch by Dilip Kumar, with some comment
changes by me.

Discussion: http://postgr.es/m/CAEepm=19Cmnfbi-j2Bw-a6yGPeHE1OVhKvvKz9bRBTJGKfGHMA@mail.gmail.com
parent 28b04787
...@@ -866,12 +866,14 @@ tbm_prepare_shared_iterate(TIDBitmap *tbm) ...@@ -866,12 +866,14 @@ tbm_prepare_shared_iterate(TIDBitmap *tbm)
else if (tbm->status == TBM_ONE_PAGE) else if (tbm->status == TBM_ONE_PAGE)
{ {
/* /*
* In one page mode allocate the space for one pagetable entry and * In one page mode allocate the space for one pagetable entry,
* directly store its index i.e. 0 in page array * initialize it, and directly store its index (i.e. 0) in the
* page array.
*/ */
tbm->dsapagetable = dsa_allocate(tbm->dsa, sizeof(PTEntryArray) + tbm->dsapagetable = dsa_allocate(tbm->dsa, sizeof(PTEntryArray) +
sizeof(PagetableEntry)); sizeof(PagetableEntry));
ptbase = dsa_get_address(tbm->dsa, tbm->dsapagetable); ptbase = dsa_get_address(tbm->dsa, tbm->dsapagetable);
memcpy(ptbase->ptentry, &tbm->entry1, sizeof(PagetableEntry));
ptpages->index[0] = 0; ptpages->index[0] = 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