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

Start doing the I/O on the block allocator

git-svn-id: file:///svn/tokudb.1131b+1080a@6087 c7de825b-a66e-492c-adef-691d508d4ae1
parent 9e8e6004
...@@ -114,6 +114,11 @@ struct remembered_hash { ...@@ -114,6 +114,11 @@ struct remembered_hash {
u_int32_t fullhash; // fullhash is the hashed value of fnum and root. u_int32_t fullhash; // fullhash is the hashed value of fnum and root.
}; };
struct block_translation_pair {
DISKOFF diskoff;
DISKOFF size;
};
struct brt_header { struct brt_header {
int dirty; int dirty;
u_int32_t fullhash; u_int32_t fullhash;
...@@ -133,11 +138,13 @@ struct brt_header { ...@@ -133,11 +138,13 @@ struct brt_header {
BLOCKNUM free_blocks; // free list for blocks. Use -1 to indicate that there are no free blocks BLOCKNUM free_blocks; // free list for blocks. Use -1 to indicate that there are no free blocks
BLOCKNUM unused_blocks; // first unused block BLOCKNUM unused_blocks; // first unused block
// Where and how big is the block allocation vector? u_int64_t max_blocknum_translated;
// The block allocation vector translates block numbers to offsets (DISKOFF) in the file. struct block_translation_pair *block_translation;
// We use a DISKOFF for the vector location, because we cannot use block numbers to bootstrap the indirection table.
BLOCKNUM block_allocation_vector_length; // It's a blocknum because the block allocation vector is indexed by blocknums. // Where and how big is the block translation vector stored on disk.
DISKOFF block_allocation_vector_location; // Remember this so we can free the block before writing a new one. u_int64_t block_translation_size_on_disk;
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
BLOCK_ALLOCATOR block_allocator; BLOCK_ALLOCATOR block_allocator;
}; };
......
...@@ -586,18 +586,12 @@ int toku_serialize_brt_header_to_wbuf (struct wbuf *wbuf, struct brt_header *h) ...@@ -586,18 +586,12 @@ int toku_serialize_brt_header_to_wbuf (struct wbuf *wbuf, struct brt_header *h)
wbuf_BLOCKNUM(wbuf, h->free_blocks); wbuf_BLOCKNUM(wbuf, h->free_blocks);
wbuf_BLOCKNUM(wbuf, h->unused_blocks); wbuf_BLOCKNUM(wbuf, h->unused_blocks);
wbuf_int (wbuf, h->n_named_roots); wbuf_int (wbuf, h->n_named_roots);
if (h->block_allocation_vector_length.b != 0) { if (h->block_translation_address_on_disk !=0 ) {
block_allocator_free_block(h->block_allocator, h->block_allocation_vector_location); block_allocator_free_block(h->block_allocator, h->block_translation_address_on_disk);
} }
#if 0 block_allocator_alloc_block(h->block_allocator, 4 + 8*h->max_blocknum_translated, &h->block_translation_address_on_disk);
h->block_allocation_vector_length.b = block_allocator_get_vector_length(h->block_allocator); wbuf_ulonglong(wbuf, h->max_blocknum_translated);
{ wbuf_DISKOFF(wbuf, h->block_translation_address_on_disk);
int r = block_allocator_alloc_block(h->block_allocator, 0, h->block_allocation_vector_length.b, (u_int64_t*)&h->block_allocation_vector_location);
assert(r==0);
}
#endif
wbuf_BLOCKNUM(wbuf, h->block_allocation_vector_length);
wbuf_DISKOFF(wbuf, h->block_allocation_vector_location);
if (h->n_named_roots>=0) { if (h->n_named_roots>=0) {
int i; int i;
for (i=0; i<h->n_named_roots; i++) { for (i=0; i<h->n_named_roots; i++) {
...@@ -617,18 +611,33 @@ int toku_serialize_brt_header_to_wbuf (struct wbuf *wbuf, struct brt_header *h) ...@@ -617,18 +611,33 @@ int toku_serialize_brt_header_to_wbuf (struct wbuf *wbuf, struct brt_header *h)
} }
int toku_serialize_brt_header_to (int fd, struct brt_header *h) { int toku_serialize_brt_header_to (int fd, struct brt_header *h) {
{
struct wbuf w; struct wbuf w;
unsigned int size = toku_serialize_brt_header_size (h); unsigned int size = toku_serialize_brt_header_size (h);
wbuf_init(&w, toku_malloc(size), size); wbuf_init(&w, toku_malloc(size), size);
int r=toku_serialize_brt_header_to_wbuf(&w, h); int r=toku_serialize_brt_header_to_wbuf(&w, h);
assert(r==0);
assert(w.ndone==size); assert(w.ndone==size);
{
ssize_t nwrote = pwrite(fd, w.buf, w.ndone, 0); ssize_t nwrote = pwrite(fd, w.buf, w.ndone, 0);
if (nwrote<0) perror("pwrite"); if (nwrote<0) perror("pwrite");
assert((size_t)nwrote==w.ndone); assert((size_t)nwrote==w.ndone);
toku_free(w.buf);
} }
{
struct wbuf w;
u_int64_t size = 4 + h->max_blocknum_translated * 8; // 4 for the checksum
wbuf_init(&w, toku_malloc(size), size);
u_int64_t i;
for (i=0; i<h->max_blocknum_translated; i++) {
wbuf_ulonglong(&w, h->block_translation[i].diskoff);
wbuf_ulonglong(&w, h->block_translation[i].size);
}
wbuf_int(&w, x1764_finish(&w.checksum));
ssize_t nwrote = pwrite(fd, w.buf, size, h->block_translation_address_on_disk);
assert(nwrote==(ssize_t)size);
toku_free(w.buf); toku_free(w.buf);
return r; };
return 0;
} }
int deserialize_brtheader (u_int32_t size, int fd, DISKOFF off, struct brt_header **brth, u_int32_t fullhash) { int deserialize_brtheader (u_int32_t size, int fd, DISKOFF off, struct brt_header **brth, u_int32_t fullhash) {
...@@ -672,10 +681,8 @@ int deserialize_brtheader (u_int32_t size, int fd, DISKOFF off, struct brt_heade ...@@ -672,10 +681,8 @@ int deserialize_brtheader (u_int32_t size, int fd, DISKOFF off, struct brt_heade
block_locations_and_lengths[i] = ntohll(block_locations_and_lengths[i]); block_locations_and_lengths[i] = ntohll(block_locations_and_lengths[i]);
} }
} }
#if 0
int r = create_block_allocator(&h->block_allocator, h->block_allocation_vector_length.b, block_locations_and_lengths, h->nodesize); int r = create_block_allocator(&h->block_allocator, h->block_allocation_vector_length.b, block_locations_and_lengths, h->nodesize);
assert(r==0); assert(r==0);
#endif
if (block_locations_and_lengths) free(block_locations_and_lengths); if (block_locations_and_lengths) free(block_locations_and_lengths);
} }
if (h->n_named_roots>=0) { if (h->n_named_roots>=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