Commit 475a93e0 authored by Rich Prohaska's avatar Rich Prohaska Committed by Yoni Fogel

merge -r 20020:20023 tokudb.2578 to main. build the brtloader with cilk++. refs[t:2578]

git-svn-id: file:///svn/toku/tokudb@20024 c7de825b-a66e-492c-adef-691d508d4ae1
parent 813eaa05
...@@ -1668,7 +1668,7 @@ static int write_nonleaves (BRTLOADER bl, FIDX pivots_fidx, struct dbout *out, s ...@@ -1668,7 +1668,7 @@ static int write_nonleaves (BRTLOADER bl, FIDX pivots_fidx, struct dbout *out, s
CILK_END CILK_END
static void add_pair_to_leafnode (struct leaf_buf *lbuf, unsigned char *key, int keylen, unsigned char *val, int vallen); static void add_pair_to_leafnode (struct leaf_buf *lbuf, unsigned char *key, int keylen, unsigned char *val, int vallen);
static int write_translation_table (struct dbout *out, long long *off_of_translation_p); static int write_translation_table (struct dbout *out, long long *off_of_translation_p);
static void write_header (struct dbout *out, long long translation_location_on_disk, long long translation_size_on_disk, BLOCKNUM root_blocknum_on_disk, LSN load_lsn); static int write_header (struct dbout *out, long long translation_location_on_disk, long long translation_size_on_disk, BLOCKNUM root_blocknum_on_disk, LSN load_lsn);
CILK_BEGIN CILK_BEGIN
static int toku_loader_write_brt_from_q (BRTLOADER bl, static int toku_loader_write_brt_from_q (BRTLOADER bl,
...@@ -1696,7 +1696,9 @@ static int toku_loader_write_brt_from_q (BRTLOADER bl, ...@@ -1696,7 +1696,9 @@ static int toku_loader_write_brt_from_q (BRTLOADER bl,
sts.n_subtrees_limit = 1; sts.n_subtrees_limit = 1;
XMALLOC_N(sts.n_subtrees_limit, sts.subtrees); XMALLOC_N(sts.n_subtrees_limit, sts.subtrees);
if (sts.subtrees == NULL) { if (sts.subtrees == NULL) {
r = errno; goto error; r = errno;
subtrees_info_destroy(&sts);
return r;
} }
struct dbout out; struct dbout out;
...@@ -1707,7 +1709,10 @@ static int toku_loader_write_brt_from_q (BRTLOADER bl, ...@@ -1707,7 +1709,10 @@ static int toku_loader_write_brt_from_q (BRTLOADER bl,
out.n_translations_limit = 4; out.n_translations_limit = 4;
MALLOC_N(out.n_translations_limit, out.translation); MALLOC_N(out.n_translations_limit, out.translation);
if (out.translation == NULL) { if (out.translation == NULL) {
r = errno; goto error; r = errno;
subtrees_info_destroy(&sts);
dbout_destroy(&out);
return r;
} }
out.translation[0].off = -2LL; out.translation[0].size = 0; // block 0 is NULL out.translation[0].off = -2LL; out.translation[0].size = 0; // block 0 is NULL
...@@ -1818,8 +1823,9 @@ static int toku_loader_write_brt_from_q (BRTLOADER bl, ...@@ -1818,8 +1823,9 @@ static int toku_loader_write_brt_from_q (BRTLOADER bl,
long long off_of_translation; long long off_of_translation;
r = write_translation_table(&out, &off_of_translation); r = write_translation_table(&out, &off_of_translation);
assert(r==0); // RFP2578 assert(r == 0); // RFP2578
write_header(&out, off_of_translation, (out.n_translations+1)*16+4, root_block, bl->load_lsn); // RFP2578 r = write_header(&out, off_of_translation, (out.n_translations+1)*16+4, root_block, bl->load_lsn);
assert(r == 0); // RFP2578
r = update_progress(progress_allocation, bl, "wrote tdb file"); r = update_progress(progress_allocation, bl, "wrote tdb file");
} }
...@@ -2179,7 +2185,7 @@ static int write_translation_table (struct dbout *out, long long *off_of_transla ...@@ -2179,7 +2185,7 @@ static int write_translation_table (struct dbout *out, long long *off_of_transla
} }
static void write_header (struct dbout *out, long long translation_location_on_disk, long long translation_size_on_disk, BLOCKNUM root_blocknum_on_disk, LSN load_lsn) { static int write_header (struct dbout *out, long long translation_location_on_disk, long long translation_size_on_disk, BLOCKNUM root_blocknum_on_disk, LSN load_lsn) {
struct brt_header h; memset(&h, 0, sizeof h); struct brt_header h; memset(&h, 0, sizeof h);
h.layout_version = BRT_LAYOUT_VERSION; h.layout_version = BRT_LAYOUT_VERSION;
h.checkpoint_count = 1; h.checkpoint_count = 1;
...@@ -2197,6 +2203,7 @@ static void write_header (struct dbout *out, long long translation_location_on_d ...@@ -2197,6 +2203,7 @@ static void write_header (struct dbout *out, long long translation_location_on_d
assert(wbuf.ndone==size); assert(wbuf.ndone==size);
toku_os_full_pwrite(out->fd, wbuf.buf, wbuf.ndone, 0); // RFP2578 use the version that returns error codes? toku_os_full_pwrite(out->fd, wbuf.buf, wbuf.ndone, 0); // RFP2578 use the version that returns error codes?
toku_free(buf); toku_free(buf);
return 0;
} }
static int read_some_pivots (FIDX pivots_file, int n_to_read, BRTLOADER bl, static int read_some_pivots (FIDX pivots_file, int n_to_read, BRTLOADER bl,
......
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