Hi all, Today's linux-next merge of the cel tree got a conflict in: include/linux/sunrpc/xdr.h between commits: 9a20f6f4e6ba ("SUNRPC: Fixes for xdr_align_data()") c4f2f591f02c ("SUNRPC: Fix xdr_expand_hole()") f8d0e60f1056 ("SUNRPC: Cleanup - constify a number of xdr_buf helpers") from the nfs tree and commits: 5a7e702670ad ("SUNRPC: Adjust synopsis of xdr_buf_subsegment()") c1346a1216ab ("NFSD: Replace the internals of the READ_BUF() macro") from the cel tree. I fixed it up (see below) and can carry the fix as necessary. This is now fixed as far as linux-next is concerned, but any non trivial conflicts should be mentioned to your upstream maintainer when your tree is submitted for merging. You may also want to consider cooperating with the maintainer of the conflicting tree to minimise any particularly complex conflicts. -- Cheers, Stephen Rothwell diff --cc include/linux/sunrpc/xdr.h index 68d49fdc4ee9,9b35ce50cf2b..000000000000 --- a/include/linux/sunrpc/xdr.h +++ b/include/linux/sunrpc/xdr.h @@@ -182,14 -182,15 +182,15 @@@ xdr_adjust_iovec(struct kvec *iov, __be * XDR buffer helper functions */ extern void xdr_shift_buf(struct xdr_buf *, size_t); -extern void xdr_buf_from_iov(struct kvec *, struct xdr_buf *); +extern void xdr_buf_from_iov(const struct kvec *, struct xdr_buf *); - extern int xdr_buf_subsegment(const struct xdr_buf *, struct xdr_buf *, unsigned int, unsigned int); + extern int xdr_buf_subsegment(const struct xdr_buf *buf, struct xdr_buf *subbuf, + unsigned int base, unsigned int len); extern void xdr_buf_trim(struct xdr_buf *, unsigned int); -extern int read_bytes_from_xdr_buf(struct xdr_buf *, unsigned int, void *, unsigned int); -extern int write_bytes_to_xdr_buf(struct xdr_buf *, unsigned int, void *, unsigned int); +extern int read_bytes_from_xdr_buf(const struct xdr_buf *, unsigned int, void *, unsigned int); +extern int write_bytes_to_xdr_buf(const struct xdr_buf *, unsigned int, void *, unsigned int); -extern int xdr_encode_word(struct xdr_buf *, unsigned int, u32); -extern int xdr_decode_word(struct xdr_buf *, unsigned int, u32 *); +extern int xdr_encode_word(const struct xdr_buf *, unsigned int, u32); +extern int xdr_decode_word(const struct xdr_buf *, unsigned int, u32 *); struct xdr_array2_desc; typedef int (*xdr_xcode_elem_t)(struct xdr_array2_desc *desc, void *elem); @@@ -250,10 -251,54 +251,54 @@@ extern void xdr_init_decode_pages(struc extern __be32 *xdr_inline_decode(struct xdr_stream *xdr, size_t nbytes); extern unsigned int xdr_read_pages(struct xdr_stream *xdr, unsigned int len); extern void xdr_enter_page(struct xdr_stream *xdr, unsigned int len); -extern int xdr_process_buf(struct xdr_buf *buf, unsigned int offset, unsigned int len, int (*actor)(struct scatterlist *, void *), void *data); -extern uint64_t xdr_align_data(struct xdr_stream *, uint64_t, uint32_t); -extern uint64_t xdr_expand_hole(struct xdr_stream *, uint64_t, uint64_t); +extern int xdr_process_buf(const struct xdr_buf *buf, unsigned int offset, unsigned int len, int (*actor)(struct scatterlist *, void *), void *data); +extern unsigned int xdr_align_data(struct xdr_stream *, unsigned int offset, unsigned int length); +extern unsigned int xdr_expand_hole(struct xdr_stream *, unsigned int offset, unsigned int length); + extern bool xdr_stream_subsegment(struct xdr_stream *xdr, struct xdr_buf *subbuf, + unsigned int len); + + /** + * xdr_set_scratch_buffer - Attach a scratch buffer for decoding data. + * @xdr: pointer to xdr_stream struct + * @buf: pointer to an empty buffer + * @buflen: size of 'buf' + * + * The scratch buffer is used when decoding from an array of pages. + * If an xdr_inline_decode() call spans across page boundaries, then + * we copy the data into the scratch buffer in order to allow linear + * access. + */ + static inline void + xdr_set_scratch_buffer(struct xdr_stream *xdr, void *buf, size_t buflen) + { + xdr->scratch.iov_base = buf; + xdr->scratch.iov_len = buflen; + } + + /** + * xdr_set_scratch_page - Attach a scratch buffer for decoding data + * @xdr: pointer to xdr_stream struct + * @page: an anonymous page + * + * See xdr_set_scratch_buffer(). + */ + static inline void + xdr_set_scratch_page(struct xdr_stream *xdr, struct page *page) + { + xdr_set_scratch_buffer(xdr, page_address(page), PAGE_SIZE); + } + + /** + * xdr_reset_scratch_buffer - Clear scratch buffer information + * @xdr: pointer to xdr_stream struct + * + * See xdr_set_scratch_buffer(). + */ + static inline void + xdr_reset_scratch_buffer(struct xdr_stream *xdr) + { + xdr_set_scratch_buffer(xdr, NULL, 0); + } /** * xdr_stream_remaining - Return the number of bytes remaining in the stream
Attachment:
pgpmnFydJr28l.pgp
Description: OpenPGP digital signature