diff options
-rw-r--r-- | libstore/Makefile | 5 | ||||
-rw-r--r-- | libstore/create.c | 21 | ||||
-rw-r--r-- | libstore/stripe.c | 97 |
3 files changed, 63 insertions, 60 deletions
diff --git a/libstore/Makefile b/libstore/Makefile index be01ae76..8d88d212 100644 --- a/libstore/Makefile +++ b/libstore/Makefile @@ -24,11 +24,12 @@ makemode := library libname = libstore SRCS = create.c derive.c make.c rdwr.c set.c device.c file.c stripe.c \ - storeread.c storecat.c + storeread.c storecat.c enc.c encode.c decode.c clone.c LCLHDRS=store.h installhdrs=store.h -OBJS = $(SRCS:.c=.o) +UTIL_OBJS = storeread.o storecat.o +OBJS = $(filter-out $(UTIL_OBJS), $(SRCS:.c=.o)) storeread: storeread.o libstore.so ../libshouldbeinlibc/libshouldbeinlibc.so storecat: storecat.o libstore.so ../libshouldbeinlibc/libshouldbeinlibc.so diff --git a/libstore/create.c b/libstore/create.c index 89e6c221..ad23a7e7 100644 --- a/libstore/create.c +++ b/libstore/create.c @@ -24,6 +24,16 @@ #include "store.h" +static error_t +fgsi (file_t source, + mach_port_t **ports, mach_msg_type_number_t *num_ports, + int **ints, mach_msg_type_number_t *num_ints, + off_t **offsets, mach_msg_type_number_t *num_offsets, + char **data, mach_msg_type_number_t *num_data) +{ + return EOPNOTSUPP; +} + /* Return a new store in STORE, which refers to the storage underlying SOURCE. A reference to SOURCE is created (but may be destroyed with store_close_source). */ @@ -31,7 +41,7 @@ error_t store_create (file_t source, struct store **store) { error_t err; struct store_enc enc; - mach_port_t inline_ports[10] + mach_port_t inline_ports[10]; int inline_ints[60]; off_t inline_offsets[60]; char inline_data[100]; @@ -39,11 +49,12 @@ error_t store_create (file_t source, struct store **store) store_enc_init (&enc, inline_ports, 10, inline_ints, 60, inline_offsets, 60, inline_data, 100); +#define file_get_storage_info fgsi /* XXX */ err = file_get_storage_info (source, - &enc->ports, &enc->ports_len, - &enc->ints, &enc->ints_len, - &enc->offsets, &enc->offsets_len, - &enc->data, &enc->data_len); + &enc.ports, &enc.ports_len, + &enc.ints, &enc.ints_len, + &enc.offsets, &enc.offsets_len, + &enc.data, &enc.data_len); if (err) return err; diff --git a/libstore/stripe.c b/libstore/stripe.c index 0032060d..794ef381 100644 --- a/libstore/stripe.c +++ b/libstore/stripe.c @@ -21,22 +21,19 @@ Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include <stdlib.h> +#include <string.h> #include "store.h" -struct stripe_info -{ - struct store **stripes; - int dealloc : 1; -}; - +extern long lcm (long p, long q); + /* Return ADDR adjust for any block size difference between STORE and STRIPE. We assume that STORE's block size is no less than STRIPE's. */ static inline off_t addr_adj (off_t addr, struct store *store, struct store *stripe) { - unsigned common_bs = store->block_shift; - unsigned stripe_bs = stripe->block_shift; + unsigned common_bs = store->log2_block_size; + unsigned stripe_bs = stripe->log2_block_size; if (common_bs == stripe_bs) return addr; else @@ -48,8 +45,8 @@ stripe_read (struct store *store, off_t addr, size_t index, mach_msg_type_number_t amount, char **buf, mach_msg_type_number_t *len) { - struct stripe_info *info = store->hook; - struct store *stripe = info->stripes[index]; + struct store **stripes = store->hook; + struct store *stripe = stripes[index]; return store_read (stripe, addr_adj (addr, store, stripe), amount, buf, len); } @@ -58,42 +55,47 @@ stripe_write (struct store *store, off_t addr, size_t index, char *buf, mach_msg_type_number_t len, mach_msg_type_number_t *amount) { - struct stripe_info *info = store->hook; - struct store *stripe = info->stripes[index]; + struct store **stripes = store->hook; + struct store *stripe = stripes[index]; return store_write (stripe, addr_adj (addr, store, stripe), buf, len, amount); } +static error_t +stripe_clone (const struct store *from, struct store *to) +{ + size_t num_stripes = from->runs_len / 2; + + to->hook = malloc (sizeof (struct store *) * num_stripes); + if (to->hook == 0) + return ENOMEM; + + bcopy (from->hook, to->hook, num_stripes * sizeof (struct store *)); + + return 0; +} + static struct store_meths -stripe_meths = {stripe_read, stripe_write}; +stripe_meths = {stripe_read, stripe_write, 0, 0, 0, stripe_clone}; /* Return a new store in STORE that interleaves all the stores in STRIPES (NUM_STRIPES of them) every INTERLEAVE bytes; INTERLEAVE must be an - integer multiple of each stripe's block size. If DEALLOC is true, then - the striped stores are freed when this store is (in any case, the array - STRIPES is copied, and so should be freed by the caller). */ + integer multiple of each stripe's block size. The stores in STRIPES are + consumed -- that is, will be freed when this store is (however, the + *array* STRIPES is copied, and so should be freed by the caller). */ error_t -store_ileave_create (struct store **stripes, size_t num_stripes, int dealloc, +store_ileave_create (struct store * const *stripes, size_t num_stripes, off_t interleave, struct store **store) { size_t i; error_t err = EINVAL; /* default error */ off_t block_size = 1, min_end = 0; off_t runs[num_stripes * 2]; - struct stripe_info *info = malloc (sizeof (struct stripe_info)); + struct store *cstripes = malloc (sizeof (struct store *) * num_stripes); - if (info == 0) + if (cstripes == 0) return ENOMEM; - info->stripes = malloc (sizeof (struct store *) * num_stripes); - info->dealloc = dealloc; - - if (info->stripes == 0) - { - free (info); - return ENOMEM; - } - /* Find a common block size. */ for (i = 0; i < num_stripes; i++) block_size = lcm (block_size, stripes[i]->block_size); @@ -130,46 +132,36 @@ store_ileave_create (struct store **stripes, size_t num_stripes, int dealloc, } (*store)->wrap_dst = interleave; - (*store)->hook = info; - bcopy (stripes, info->stripes, num_stripes * sizeof *stripes); + (*store)->hook = cstripes; + bcopy (stripes, cstripes, num_stripes * sizeof *stripes); return 0; barf: - free (info->stripes); - free (info); + free (cstripes); return err; } /* Return a new store in STORE that concatenates all the stores in STORES - (NUM_STORES of them). If DEALLOC is true, then the sub-stores are freed - when this store is (in any case, the array STORES is copied, and so should - be freed by the caller). */ + (NUM_STORES of them). The stores in STRIPES are consumed -- that is, will + be freed when this store is (however, the *array* STRIPES is copied, and + so should be freed by the caller). */ error_t -store_concat_create (struct store **stores, size_t num_stores, int dealloc, +store_concat_create (struct store * const *stores, size_t num_stores, struct store **store) { size_t i; error_t err = EINVAL; /* default error */ off_t block_size = 1; off_t runs[num_stores * 2]; - struct stripe_info *info = malloc (sizeof (struct stripe_info)); + struct store *cstripes = malloc (sizeof (struct store *) * num_stores); - if (info == 0) + if (cstripes == 0) return ENOMEM; - info->stripes = malloc (sizeof (struct store *) * num_stores); - info->dealloc = dealloc; - - if (info->stripes == 0) - { - free (info); - return ENOMEM; - } - /* Find a common block size. */ - for (i = 0; i < num_stripes; i++) - block_size = lcm (block_size, stripes[i]->block_size); + for (i = 0; i < num_stores; i++) + block_size = lcm (block_size, stores[i]->block_size); for (i = 0; i < num_stores; i++) { @@ -185,13 +177,12 @@ store_concat_create (struct store **stores, size_t num_stores, int dealloc, goto barf; } - (*store)->hook = info; - bcopy (stores, info->stripes, num_stores * sizeof *stores); + (*store)->hook = cstripes; + bcopy (stores, cstripes, num_stores * sizeof *stores); return 0; barf: - free (info->stripes); - free (info); + free (cstripes); return err; } |