Skip to content

Commit

Permalink
Btrfs: write_buf is now callable outside send.c
Browse files Browse the repository at this point in the history
Developing service cmds needs it.

Signed-off-by: Anand Jain <anand.jain@oracle.com>
  • Loading branch information
Anand Jain authored and Chris Mason committed Oct 4, 2012
1 parent b4f359a commit 1bcea35
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 5 deletions.
11 changes: 6 additions & 5 deletions fs/btrfs/send.c
Original file line number Diff line number Diff line change
Expand Up @@ -386,7 +386,7 @@ static struct btrfs_path *alloc_path_for_send(void)
return path;
}

static int write_buf(struct send_ctx *sctx, const void *buf, u32 len)
int write_buf(struct file *filp, const void *buf, u32 len, loff_t *off)
{
int ret;
mm_segment_t old_fs;
Expand All @@ -396,8 +396,7 @@ static int write_buf(struct send_ctx *sctx, const void *buf, u32 len)
set_fs(KERNEL_DS);

while (pos < len) {
ret = vfs_write(sctx->send_filp, (char *)buf + pos, len - pos,
&sctx->send_off);
ret = vfs_write(filp, (char *)buf + pos, len - pos, off);
/* TODO handle that correctly */
/*if (ret == -ERESTARTSYS) {
continue;
Expand Down Expand Up @@ -553,7 +552,8 @@ static int send_header(struct send_ctx *sctx)
strcpy(hdr.magic, BTRFS_SEND_STREAM_MAGIC);
hdr.version = cpu_to_le32(BTRFS_SEND_STREAM_VERSION);

return write_buf(sctx, &hdr, sizeof(hdr));
return write_buf(sctx->send_filp, &hdr, sizeof(hdr),
&sctx->send_off);
}

/*
Expand Down Expand Up @@ -590,7 +590,8 @@ static int send_cmd(struct send_ctx *sctx)
crc = crc32c(0, (unsigned char *)sctx->send_buf, sctx->send_size);
hdr->crc = cpu_to_le32(crc);

ret = write_buf(sctx, sctx->send_buf, sctx->send_size);
ret = write_buf(sctx->send_filp, sctx->send_buf, sctx->send_size,
&sctx->send_off);

sctx->total_send_size += sctx->send_size;
sctx->cmd_send_size[le16_to_cpu(hdr->cmd)] += sctx->send_size;
Expand Down
1 change: 1 addition & 0 deletions fs/btrfs/send.h
Original file line number Diff line number Diff line change
Expand Up @@ -130,4 +130,5 @@ enum {

#ifdef __KERNEL__
long btrfs_ioctl_send(struct file *mnt_file, void __user *arg);
int write_buf(struct file *filp, const void *buf, u32 len, loff_t *off);
#endif

0 comments on commit 1bcea35

Please sign in to comment.