summaryrefslogtreecommitdiff
path: root/make-bcache.c
diff options
context:
space:
mode:
authorKent Overstreet <koverstreet@google.com>2012-01-18 16:05:32 -0800
committerKent Overstreet <koverstreet@google.com>2012-01-18 16:05:32 -0800
commit7f023533a8ee93126ff86097aca3630a9390c904 (patch)
treea9dc87fc6d12d82f3d3f261c995042b8213c4b37 /make-bcache.c
parent58f79db74b6d825d5d63eaa1d164139ed0778d7f (diff)
Add --discard and --cache_replacement_policy
Diffstat (limited to 'make-bcache.c')
-rw-r--r--make-bcache.c109
1 files changed, 95 insertions, 14 deletions
diff --git a/make-bcache.c b/make-bcache.c
index 2c31147..70174ed 100644
--- a/make-bcache.c
+++ b/make-bcache.c
@@ -58,6 +58,52 @@ uint64_t hatoi(const char *s)
return i;
}
+char *skip_spaces(const char *str)
+{
+ while (isspace(*str))
+ ++str;
+ return (char *)str;
+}
+
+char *strim(char *s)
+{
+ size_t size;
+ char *end;
+
+ s = skip_spaces(s);
+ size = strlen(s);
+ if (!size)
+ return s;
+
+ end = s + size - 1;
+ while (end >= s && isspace(*end))
+ end--;
+ *(end + 1) = '\0';
+
+ return s;
+}
+
+ssize_t read_string_list(const char *buf, const char * const list[])
+{
+ size_t i;
+ char *s, *d = strdup(buf);
+ if (!d)
+ return -ENOMEM;
+
+ s = strim(d);
+
+ for (i = 0; list[i]; i++)
+ if (!strcmp(list[i], s))
+ break;
+
+ free(d);
+
+ if (!list[i])
+ return -EINVAL;
+
+ return i;
+}
+
void usage()
{
printf("Usage: make-bcache [options] device\n"
@@ -67,20 +113,35 @@ void usage()
" -w, --block block size (hard sector size of SSD, often 2k)\n"
" -U UUID\n"
" --writeback enable writeback\n"
+ " --discard enable discards\n"
+ " --cache_replacement_policy=(lru|fifo)\n"
" -h, --help display this help and exit\n");
exit(EXIT_FAILURE);
}
+const char * const cache_replacement_policies[] = {
+ "lru",
+ "fifo",
+ "random",
+ NULL
+};
+
int writeback;
+int discard;
+unsigned cache_replacement_policy;
+uint64_t data_offset = 16;
struct option opts[] = {
- { "cache", 0, NULL, 'C' },
- { "bdev", 0, NULL, 'B' },
- { "bucket", 1, NULL, 'b' },
- { "block", 1, NULL, 'w' },
- { "writeback", 0, &writeback, 1 },
- { "help", 0, NULL, 'h' },
- { NULL, 0, NULL, 0 },
+ { "cache", 0, NULL, 'C' },
+ { "bdev", 0, NULL, 'B' },
+ { "bucket", 1, NULL, 'b' },
+ { "block", 1, NULL, 'w' },
+ { "writeback", 0, &writeback, 1 },
+ { "discard", 0, &discard, 1 },
+ { "cache_replacement_policy", 1, NULL, 'p' },
+// { "data_offset", 1, NULL, 'o' },
+ { "help", 0, NULL, 'h' },
+ { NULL, 0, NULL, 0 },
};
void write_sb(char *dev, struct cache_sb *sb)
@@ -88,7 +149,7 @@ void write_sb(char *dev, struct cache_sb *sb)
int fd;
char uuid[40], set_uuid[40];
- if (sb->version > 1) {
+ if (sb->version > BCACHE_SB_MAX_VERSION) {
printf("Must specify one of -C or -B\n");
usage();
}
@@ -109,11 +170,20 @@ void write_sb(char *dev, struct cache_sb *sb)
exit(EXIT_FAILURE);
}
- if (sb->version == CACHE_BACKING_DEV &&
- writeback)
- SET_BDEV_WRITEBACK(sb, 1);
- else
- SET_BDEV_WRITEBACK(sb, 0);
+ sb->flags = 0;
+
+ if (SB_BDEV(sb)) {
+ SET_BDEV_WRITEBACK(sb, writeback);
+
+ if (data_offset != 16) {
+ sb->version = BCACHE_SB_BDEV_VERSION;
+ sb->keys = 1;
+ sb->d[0] = data_offset;
+ }
+ } else {
+ SET_CACHE_DISCARD(sb, discard);
+ SET_CACHE_REPLACEMENT(sb, cache_replacement_policy);
+ }
sb->offset = SB_SECTOR;
memcpy(sb->magic, bcache_magic, 16);
@@ -164,7 +234,7 @@ int main(int argc, char **argv)
struct cache_sb sb;
memset(&sb, 0, sizeof(struct cache_sb));
- sb.version = 2;
+ sb.version = -1;
sb.block_size = 8;
sb.bucket_size = 1024;
@@ -193,6 +263,17 @@ int main(int argc, char **argv)
exit(EXIT_FAILURE);
}
break;
+ case 'p':
+ cache_replacement_policy = read_string_list(optarg,
+ cache_replacement_policies);
+ break;
+ case 'o':
+ data_offset = atoll(optarg);
+ if (sb.d[0] < 16) {
+ printf("Bad data offset; minimum 16 sectors\n");
+ exit(EXIT_FAILURE);
+ }
+ break;
case 'h':
usage();
break;