SUNRPC: introduce xdr_init_decode_pages
Initialize xdr_stream and xdr_buf using an array of page pointers and length of buffer. Signed-off-by: Benny Halevy <bhalevy@panasas.com>
This commit is contained in:
committed by
Boaz Harrosh
parent
35c8bb543c
commit
f7da7a129d
@@ -512,12 +512,7 @@ int nfs_readdir_page_filler(nfs_readdir_descriptor_t *desc, struct nfs_entry *en
|
|||||||
struct page **xdr_pages, struct page *page, unsigned int buflen)
|
struct page **xdr_pages, struct page *page, unsigned int buflen)
|
||||||
{
|
{
|
||||||
struct xdr_stream stream;
|
struct xdr_stream stream;
|
||||||
struct xdr_buf buf = {
|
struct xdr_buf buf;
|
||||||
.pages = xdr_pages,
|
|
||||||
.page_len = buflen,
|
|
||||||
.buflen = buflen,
|
|
||||||
.len = buflen,
|
|
||||||
};
|
|
||||||
struct page *scratch;
|
struct page *scratch;
|
||||||
struct nfs_cache_array *array;
|
struct nfs_cache_array *array;
|
||||||
unsigned int count = 0;
|
unsigned int count = 0;
|
||||||
@@ -527,7 +522,7 @@ int nfs_readdir_page_filler(nfs_readdir_descriptor_t *desc, struct nfs_entry *en
|
|||||||
if (scratch == NULL)
|
if (scratch == NULL)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
xdr_init_decode(&stream, &buf, NULL);
|
xdr_init_decode_pages(&stream, &buf, xdr_pages, buflen);
|
||||||
xdr_set_scratch_buffer(&stream, page_address(scratch), PAGE_SIZE);
|
xdr_set_scratch_buffer(&stream, page_address(scratch), PAGE_SIZE);
|
||||||
|
|
||||||
do {
|
do {
|
||||||
|
@@ -510,12 +510,7 @@ filelayout_decode_layout(struct pnfs_layout_hdr *flo,
|
|||||||
gfp_t gfp_flags)
|
gfp_t gfp_flags)
|
||||||
{
|
{
|
||||||
struct xdr_stream stream;
|
struct xdr_stream stream;
|
||||||
struct xdr_buf buf = {
|
struct xdr_buf buf;
|
||||||
.pages = lgr->layoutp->pages,
|
|
||||||
.page_len = lgr->layoutp->len,
|
|
||||||
.buflen = lgr->layoutp->len,
|
|
||||||
.len = lgr->layoutp->len,
|
|
||||||
};
|
|
||||||
struct page *scratch;
|
struct page *scratch;
|
||||||
__be32 *p;
|
__be32 *p;
|
||||||
uint32_t nfl_util;
|
uint32_t nfl_util;
|
||||||
@@ -527,7 +522,7 @@ filelayout_decode_layout(struct pnfs_layout_hdr *flo,
|
|||||||
if (!scratch)
|
if (!scratch)
|
||||||
return -ENOMEM;
|
return -ENOMEM;
|
||||||
|
|
||||||
xdr_init_decode(&stream, &buf, NULL);
|
xdr_init_decode_pages(&stream, &buf, lgr->layoutp->pages, lgr->layoutp->len);
|
||||||
xdr_set_scratch_buffer(&stream, page_address(scratch), PAGE_SIZE);
|
xdr_set_scratch_buffer(&stream, page_address(scratch), PAGE_SIZE);
|
||||||
|
|
||||||
/* 20 = ufl_util (4), first_stripe_index (4), pattern_offset (8),
|
/* 20 = ufl_util (4), first_stripe_index (4), pattern_offset (8),
|
||||||
|
@@ -308,12 +308,7 @@ decode_device(struct inode *ino, struct pnfs_device *pdev, gfp_t gfp_flags)
|
|||||||
u8 max_stripe_index;
|
u8 max_stripe_index;
|
||||||
struct nfs4_file_layout_dsaddr *dsaddr = NULL;
|
struct nfs4_file_layout_dsaddr *dsaddr = NULL;
|
||||||
struct xdr_stream stream;
|
struct xdr_stream stream;
|
||||||
struct xdr_buf buf = {
|
struct xdr_buf buf;
|
||||||
.pages = pdev->pages,
|
|
||||||
.page_len = pdev->pglen,
|
|
||||||
.buflen = pdev->pglen,
|
|
||||||
.len = pdev->pglen,
|
|
||||||
};
|
|
||||||
struct page *scratch;
|
struct page *scratch;
|
||||||
|
|
||||||
/* set up xdr stream */
|
/* set up xdr stream */
|
||||||
@@ -321,7 +316,7 @@ decode_device(struct inode *ino, struct pnfs_device *pdev, gfp_t gfp_flags)
|
|||||||
if (!scratch)
|
if (!scratch)
|
||||||
goto out_err;
|
goto out_err;
|
||||||
|
|
||||||
xdr_init_decode(&stream, &buf, NULL);
|
xdr_init_decode_pages(&stream, &buf, pdev->pages, pdev->pglen);
|
||||||
xdr_set_scratch_buffer(&stream, page_address(scratch), PAGE_SIZE);
|
xdr_set_scratch_buffer(&stream, page_address(scratch), PAGE_SIZE);
|
||||||
|
|
||||||
/* Get the stripe count (number of stripe index) */
|
/* Get the stripe count (number of stripe index) */
|
||||||
|
@@ -216,6 +216,8 @@ extern __be32 *xdr_reserve_space(struct xdr_stream *xdr, size_t nbytes);
|
|||||||
extern void xdr_write_pages(struct xdr_stream *xdr, struct page **pages,
|
extern void xdr_write_pages(struct xdr_stream *xdr, struct page **pages,
|
||||||
unsigned int base, unsigned int len);
|
unsigned int base, unsigned int len);
|
||||||
extern void xdr_init_decode(struct xdr_stream *xdr, struct xdr_buf *buf, __be32 *p);
|
extern void xdr_init_decode(struct xdr_stream *xdr, struct xdr_buf *buf, __be32 *p);
|
||||||
|
extern void xdr_init_decode_pages(struct xdr_stream *xdr, struct xdr_buf *buf,
|
||||||
|
struct page **pages, unsigned int len);
|
||||||
extern void xdr_set_scratch_buffer(struct xdr_stream *xdr, void *buf, size_t buflen);
|
extern void xdr_set_scratch_buffer(struct xdr_stream *xdr, void *buf, size_t buflen);
|
||||||
extern __be32 *xdr_inline_decode(struct xdr_stream *xdr, size_t nbytes);
|
extern __be32 *xdr_inline_decode(struct xdr_stream *xdr, size_t nbytes);
|
||||||
extern void xdr_read_pages(struct xdr_stream *xdr, unsigned int len);
|
extern void xdr_read_pages(struct xdr_stream *xdr, unsigned int len);
|
||||||
|
@@ -638,6 +638,25 @@ void xdr_init_decode(struct xdr_stream *xdr, struct xdr_buf *buf, __be32 *p)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(xdr_init_decode);
|
EXPORT_SYMBOL_GPL(xdr_init_decode);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* xdr_init_decode - Initialize an xdr_stream for decoding data.
|
||||||
|
* @xdr: pointer to xdr_stream struct
|
||||||
|
* @buf: pointer to XDR buffer from which to decode data
|
||||||
|
* @pages: list of pages to decode into
|
||||||
|
* @len: length in bytes of buffer in pages
|
||||||
|
*/
|
||||||
|
void xdr_init_decode_pages(struct xdr_stream *xdr, struct xdr_buf *buf,
|
||||||
|
struct page **pages, unsigned int len)
|
||||||
|
{
|
||||||
|
memset(buf, 0, sizeof(*buf));
|
||||||
|
buf->pages = pages;
|
||||||
|
buf->page_len = len;
|
||||||
|
buf->buflen = len;
|
||||||
|
buf->len = len;
|
||||||
|
xdr_init_decode(xdr, buf, NULL);
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(xdr_init_decode_pages);
|
||||||
|
|
||||||
static __be32 * __xdr_inline_decode(struct xdr_stream *xdr, size_t nbytes)
|
static __be32 * __xdr_inline_decode(struct xdr_stream *xdr, size_t nbytes)
|
||||||
{
|
{
|
||||||
__be32 *p = xdr->p;
|
__be32 *p = xdr->p;
|
||||||
|
Reference in New Issue
Block a user