Commit 2cb69fe5 authored by Bradley C. Kuszmaul's avatar Bradley C. Kuszmaul

Log the distribute for a split in the other order. Addresses #27.

git-svn-id: file:///svn/tokudb@1799 c7de825b-a66e-492c-adef-691d508d4ae1
parent 71d13dad
...@@ -1291,24 +1291,16 @@ int toku_pma_split(TOKUTXN txn, FILENUM filenum, ...@@ -1291,24 +1291,16 @@ int toku_pma_split(TOKUTXN txn, FILENUM filenum,
splitk->flags = 0; splitk->flags = 0;
} }
/* put the first half of pairs into the left pma */
n = spliti;
error = pma_resize_array(txn, filenum, diskoff, pma, n + n/4, 0); // zeros the elements
assert(error == 0);
distribute_data(pma->pairs, toku_pma_index_limit(pma), &pairs[0], n, pma);
int r = pma_log_distribute(txn, filenum, diskoff, diskoff, spliti, &pairs[0]);
if (r!=0) { toku_free(pairs); return r; }
// Don't have to relocate kvpairs, because these ones are still there.
__pma_update_cursors(pma, &cursors, &pairs[0], n);
pma->n_pairs_present = spliti;
/* put the second half of pairs into the right pma */ /* put the second half of pairs into the right pma */
/* Do this first, so that the logging will move the stuff out of the left pma first, and then later when we redistribute in the left PMA, we won't overwrite something. */
n = npairs - spliti; n = npairs - spliti;
error = pma_resize_array(txn, filenum, newdiskoff, newpma, n + n/4, 0); error = pma_resize_array(txn, filenum, newdiskoff, newpma, n + n/4, 0);
assert(error == 0); assert(error == 0);
distribute_data(newpma->pairs, toku_pma_index_limit(newpma), &pairs[spliti], n, newpma); distribute_data(newpma->pairs, toku_pma_index_limit(newpma), &pairs[spliti], n, newpma);
r = pma_log_distribute(txn, filenum, diskoff, newdiskoff, n, &pairs[spliti]); {
int r = pma_log_distribute(txn, filenum, diskoff, newdiskoff, n, &pairs[spliti]);
if (r!=0) { toku_free(pairs); return r; } if (r!=0) { toku_free(pairs); return r; }
}
#if PMA_USE_MEMPOOL #if PMA_USE_MEMPOOL
__pma_relocate_kvpairs(newpma); __pma_relocate_kvpairs(newpma);
// If it's in an mpool, we must free those pairs. // If it's in an mpool, we must free those pairs.
...@@ -1319,6 +1311,19 @@ int toku_pma_split(TOKUTXN txn, FILENUM filenum, ...@@ -1319,6 +1311,19 @@ int toku_pma_split(TOKUTXN txn, FILENUM filenum,
__pma_update_cursors(newpma, &cursors, &pairs[spliti], n); __pma_update_cursors(newpma, &cursors, &pairs[spliti], n);
newpma->n_pairs_present = n; newpma->n_pairs_present = n;
/* put the first half of pairs into the left pma */
n = spliti;
error = pma_resize_array(txn, filenum, diskoff, pma, n + n/4, 0); // zeros the elements
assert(error == 0);
distribute_data(pma->pairs, toku_pma_index_limit(pma), &pairs[0], n, pma);
{
int r = pma_log_distribute(txn, filenum, diskoff, diskoff, spliti, &pairs[0]);
if (r!=0) { toku_free(pairs); return r; }
}
// Don't have to relocate kvpairs, because these ones are still there.
__pma_update_cursors(pma, &cursors, &pairs[0], n);
pma->n_pairs_present = spliti;
toku_free(pairs); toku_free(pairs);
/* The remaining cursors are in the left pma */ /* The remaining cursors are in the left pma */
......
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