Commit 7e5a0963 authored by Bradley C. Kuszmaul's avatar Bradley C. Kuszmaul Committed by Yoni Fogel

Compile with the block allocator. Addresses #1000, #1080, #1131.

git-svn-id: file:///svn/tokudb.1131b+1080a@6097 c7de825b-a66e-492c-adef-691d508d4ae1
parent d929e088
...@@ -142,7 +142,9 @@ struct brt_header { ...@@ -142,7 +142,9 @@ struct brt_header {
struct block_translation_pair *block_translation; struct block_translation_pair *block_translation;
// Where and how big is the block translation vector stored on disk. // Where and how big is the block translation vector stored on disk.
u_int64_t block_translation_size_on_disk; // The size of the on_disk buffer may no longer match the max_blocknum_translated field, since blocks may have been allocated or freed.
// We need to remember this old information so we can free it properly.
u_int64_t block_translation_size_on_disk; // the size of the block (i.e. 8 times the number of entries)
u_int64_t block_translation_address_on_disk; // 0 if there is no memory allocated u_int64_t block_translation_address_on_disk; // 0 if there is no memory allocated
// The in-memory data structure for block allocation // The in-memory data structure for block allocation
......
...@@ -16,6 +16,7 @@ ...@@ -16,6 +16,7 @@
#include <arpa/inet.h> #include <arpa/inet.h>
#include <zlib.h> #include <zlib.h>
#if 0
static u_int64_t ntohll(u_int64_t v) { static u_int64_t ntohll(u_int64_t v) {
union u { union u {
u_int32_t l[2]; u_int32_t l[2];
...@@ -24,7 +25,7 @@ static u_int64_t ntohll(u_int64_t v) { ...@@ -24,7 +25,7 @@ static u_int64_t ntohll(u_int64_t v) {
uv.ll = v; uv.ll = v;
return (((u_int64_t)uv.l[0])<<32) + uv.l[1]; return (((u_int64_t)uv.l[0])<<32) + uv.l[1];
} }
#endif
// Don't include the compressed data size or the uncompressed data size. // Don't include the compressed data size or the uncompressed data size.
...@@ -664,26 +665,41 @@ int deserialize_brtheader (u_int32_t size, int fd, DISKOFF off, struct brt_heade ...@@ -664,26 +665,41 @@ int deserialize_brtheader (u_int32_t size, int fd, DISKOFF off, struct brt_heade
h->free_blocks = rbuf_blocknum(&rc); h->free_blocks = rbuf_blocknum(&rc);
h->unused_blocks = rbuf_blocknum(&rc); h->unused_blocks = rbuf_blocknum(&rc);
h->n_named_roots = rbuf_int(&rc); h->n_named_roots = rbuf_int(&rc);
h->block_allocation_vector_length = rbuf_blocknum(&rc); h->max_blocknum_translated = rbuf_diskoff(&rc);
h->block_allocation_vector_location = rbuf_diskoff(&rc); h->block_translation_size_on_disk = 4 + 8 * h->max_blocknum_translated;
h->block_translation_address_on_disk = rbuf_diskoff(&rc);
// Set up the the block translation buffer.
create_block_allocator(&h->block_allocator, h->nodesize);
if (h->max_blocknum_translated == 0) {
h->block_translation = 0;
} else {
//
block_allocator_alloc_block_at(h->block_allocator, h->block_translation_address_on_disk, h->block_translation_size_on_disk);
XMALLOC_N(h->max_blocknum_translated, h->block_translation);
unsigned char *XMALLOC_N(h->block_translation_size_on_disk, tbuf);
{ {
u_int64_t *block_locations_and_lengths = 0; ssize_t r = pread(fd, tbuf, h->block_translation_size_on_disk, h->block_translation_address_on_disk);
if (h->block_allocation_vector_length.b > 0) { assert(r==(ssize_t)h->block_translation_size_on_disk);
MALLOC_N(h->block_allocation_vector_length.b * 2, block_locations_and_lengths);
assert(block_locations_and_lengths);
u_int64_t len = h->block_allocation_vector_length.b * 16 + 4;
ssize_t r = pread(fd, block_locations_and_lengths, len, h->block_allocation_vector_location);
assert(r==(ssize_t)len);
u_int32_t x1764 = x1764_memory(block_locations_and_lengths, len-4); // compute a checksum
assert(x1764 == *(u_int32_t*)(block_locations_and_lengths+h->block_allocation_vector_length.b*2));
int i;
for (i=0; i<h->block_allocation_vector_length.b * 2; i++) {
block_locations_and_lengths[i] = ntohll(block_locations_and_lengths[i]);
} }
{
// check the checksum
u_int32_t x1764 = x1764_memory(tbuf, h->block_translation_size_on_disk - 4);
u_int32_t stored_x1764 = ntohl(*(int*)(tbuf + h->block_translation_size_on_disk - 4));
assert(x1764 == stored_x1764);
} }
int r = create_block_allocator(&h->block_allocator, h->block_allocation_vector_length.b, block_locations_and_lengths, h->nodesize); // now read all that data.
assert(r==0); u_int64_t i;
if (block_locations_and_lengths) free(block_locations_and_lengths); struct rbuf rt;
rt.buf = tbuf;
rt.ndone = 0;
rt.size = h->block_translation_size_on_disk-4;
assert(rt.size>0);
for (i=0; i<h->max_blocknum_translated; i++) {
h->block_translation[i].diskoff = rbuf_diskoff(&rt);
h->block_translation[i].size = rbuf_diskoff(&rt);
block_allocator_alloc_block_at(h->block_allocator, h->block_translation[i].diskoff, h->block_translation[i].size);
}
toku_free(tbuf);
} }
if (h->n_named_roots>=0) { if (h->n_named_roots>=0) {
int i; int i;
......
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