summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--libstore/file.c70
1 files changed, 58 insertions, 12 deletions
diff --git a/libstore/file.c b/libstore/file.c
index 3e091986..d64f8a6a 100644
--- a/libstore/file.c
+++ b/libstore/file.c
@@ -20,40 +20,84 @@
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */
+#include <stdio.h>
+#include <string.h>
+
#include <hurd/io.h>
#include "store.h"
static error_t
-file_read (struct store *store, off_t addr, mach_msg_type_number_t amount,
- char **buf, mach_msg_type_number_t *len)
+file_read (struct store *store,
+ off_t addr, size_t index, mach_msg_type_number_t amount,
+ char **buf, mach_msg_type_number_t *len)
{
- return io_read (store->port, buf, len, addr * store->block_size, amount);
+ size_t bsize = store->block_size;
+ error_t err = io_read (store->port, buf, len, addr * bsize, amount);
+ char rep_buf[20];
+ if (err)
+ strcpy (rep_buf, "-");
+ else if (*len > sizeof rep_buf - 3)
+ sprintf (rep_buf, "\"%.*s\"...", (int)(sizeof rep_buf - 6), *buf);
+ else
+ sprintf (rep_buf, "\"%.*s\"", (int)(sizeof rep_buf - 3), *buf);
+ fprintf (stderr, "; file_read (%ld, %d, %d) [%d] => %s, %s, %d\n",
+ addr, index, amount, store->block_size, err ? strerror (err) : "-",
+ rep_buf, err ? 0 : *len);
+ return err;
}
static error_t
file_write (struct store *store,
- off_t addr, char *buf, mach_msg_type_number_t len,
+ off_t addr, size_t index, char *buf, mach_msg_type_number_t len,
mach_msg_type_number_t *amount)
{
- return io_write (store->port, buf, len, addr * store->block_size, amount);
+ size_t bsize = store->block_size;
+ char rep_buf[20];
+ if (len > sizeof rep_buf - 3)
+ sprintf (rep_buf, "\"%.*s\"...", (int)(sizeof rep_buf - 6), buf);
+ else
+ sprintf (rep_buf, "\"%.*s\"", (int)(sizeof rep_buf - 3), buf);
+ fprintf (stderr, "; file_write (%ld, %d, %s, %d)\n",
+ addr, index, rep_buf, len);
+ return io_write (store->port, buf, len, addr * bsize, amount);
}
static struct store_meths
file_meths = {file_read, file_write};
static error_t
-file_byte_read (struct store *store, off_t addr, mach_msg_type_number_t amount,
+file_byte_read (struct store *store,
+ off_t addr, size_t index, mach_msg_type_number_t amount,
char **buf, mach_msg_type_number_t *len)
{
- return io_read (store->port, buf, len, addr, amount);
+ error_t err = io_read (store->port, buf, len, addr, amount);
+ char rep_buf[20];
+ if (err)
+ strcpy (rep_buf, "-");
+ else if (*len > sizeof rep_buf - 3)
+ sprintf (rep_buf, "\"%.*s\"...", (int)(sizeof rep_buf - 6), *buf);
+ else
+ sprintf (rep_buf, "\"%.*s\"", (int)(sizeof rep_buf - 3), *buf);
+ fprintf (stderr, "; file_byte_read (%ld, %d, %d) => %s, %s, %d\n",
+ addr, index, amount, err ? strerror (err) : "-",
+ rep_buf, err ? 0 : *len);
+ return err;
}
static error_t
file_byte_write (struct store *store,
- off_t addr, char *buf, mach_msg_type_number_t len,
- mach_msg_type_number_t *amount)
+ off_t addr, size_t index,
+ char *buf, mach_msg_type_number_t len,
+ mach_msg_type_number_t *amount)
{
+ char rep_buf[20];
+ if (len > sizeof rep_buf - 3)
+ sprintf (rep_buf, "\"%.*s\"...", (int)(sizeof rep_buf - 6), buf);
+ else
+ sprintf (rep_buf, "\"%.*s\"", (int)(sizeof rep_buf - 3), buf);
+ fprintf (stderr, "; file_byte_write (%ld, %d, %s, %d)\n",
+ addr, index, rep_buf, len);
return io_write (store->port, buf, len, addr, amount);
}
@@ -86,9 +130,11 @@ _store_file_create (file_t file, size_t block_size,
{
if (block_size == 1)
*store = _make_store (STORAGE_HURD_FILE, &file_byte_meths, file, 1,
- runs, runs_len);
- else
+ runs, runs_len, 0);
+ else if ((block_size & (block_size - 1)) == 0)
*store = _make_store (STORAGE_HURD_FILE, &file_meths, file, block_size,
- runs, runs_len);
+ runs, runs_len, 0);
+ else
+ return EINVAL; /* block size not a power of two */
return *store ? 0 : ENOMEM;
}