Commit 4b0a66d5 authored by Kent Overstreet's avatar Kent Overstreet Committed by Kent Overstreet

bcachefs: Check alignment in write path

Also - fix alignment in bch2_set_page_dirty()
Signed-off-by: default avatarKent Overstreet <kent.overstreet@linux.dev>
parent 41fcd621
...@@ -684,8 +684,8 @@ static int bch2_page_reservation_get(struct bch_fs *c, ...@@ -684,8 +684,8 @@ static int bch2_page_reservation_get(struct bch_fs *c,
if (!s) if (!s)
return -ENOMEM; return -ENOMEM;
for (i = offset / 512; for (i = round_down(offset, block_bytes(c)) >> 9;
i < DIV_ROUND_UP(offset + len, 512); i < round_up(offset + len, block_bytes(c)) >> 9;
i++) { i++) {
disk_sectors += sectors_to_reserve(&s->s[i], disk_sectors += sectors_to_reserve(&s->s[i],
res->disk.nr_replicas); res->disk.nr_replicas);
...@@ -757,8 +757,8 @@ static void bch2_set_page_dirty(struct bch_fs *c, ...@@ -757,8 +757,8 @@ static void bch2_set_page_dirty(struct bch_fs *c,
struct bch_page_state *s = bch2_page_state(page); struct bch_page_state *s = bch2_page_state(page);
unsigned i, dirty_sectors = 0; unsigned i, dirty_sectors = 0;
for (i = offset / 512; for (i = round_down(offset, block_bytes(c)) >> 9;
i < DIV_ROUND_UP(offset + len, 512); i < round_up(offset + len, block_bytes(c)) >> 9;
i++) { i++) {
unsigned sectors = sectors_to_reserve(&s->s[i], unsigned sectors = sectors_to_reserve(&s->s[i],
res->disk.nr_replicas); res->disk.nr_replicas);
......
...@@ -920,30 +920,39 @@ static void __bch2_write(struct closure *cl) ...@@ -920,30 +920,39 @@ static void __bch2_write(struct closure *cl)
void bch2_write(struct closure *cl) void bch2_write(struct closure *cl)
{ {
struct bch_write_op *op = container_of(cl, struct bch_write_op, cl); struct bch_write_op *op = container_of(cl, struct bch_write_op, cl);
struct bio *bio = &op->wbio.bio;
struct bch_fs *c = op->c; struct bch_fs *c = op->c;
BUG_ON(!op->nr_replicas); BUG_ON(!op->nr_replicas);
BUG_ON(!op->write_point.v); BUG_ON(!op->write_point.v);
BUG_ON(!bkey_cmp(op->pos, POS_MAX)); BUG_ON(!bkey_cmp(op->pos, POS_MAX));
if (bio_sectors(bio) & (c->opts.block_size - 1)) {
__bcache_io_error(c, "misaligned write");
op->error = -EIO;
goto err;
}
op->start_time = local_clock(); op->start_time = local_clock();
bch2_keylist_init(&op->insert_keys, op->inline_keys); bch2_keylist_init(&op->insert_keys, op->inline_keys);
wbio_init(&op->wbio.bio)->put_bio = false; wbio_init(bio)->put_bio = false;
if (c->opts.nochanges || if (c->opts.nochanges ||
!percpu_ref_tryget(&c->writes)) { !percpu_ref_tryget(&c->writes)) {
__bcache_io_error(c, "read only"); __bcache_io_error(c, "read only");
op->error = -EROFS; op->error = -EROFS;
if (!(op->flags & BCH_WRITE_NOPUT_RESERVATION)) goto err;
bch2_disk_reservation_put(c, &op->res);
closure_return(cl);
return;
} }
bch2_increment_clock(c, bio_sectors(&op->wbio.bio), WRITE); bch2_increment_clock(c, bio_sectors(bio), WRITE);
continue_at_nobarrier(cl, __bch2_write, NULL); continue_at_nobarrier(cl, __bch2_write, NULL);
return;
err:
if (!(op->flags & BCH_WRITE_NOPUT_RESERVATION))
bch2_disk_reservation_put(c, &op->res);
closure_return(cl);
} }
/* Cache promotion on read */ /* Cache promotion on read */
......
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