Re: linux-next: manual merge of the cel tree with the nfs tree

From: Stephen Rothwell
Date: Wed Dec 16 2020 - 20:53:08 EST


Hi all,

On Tue, 15 Dec 2020 11:41:50 +1100 Stephen Rothwell <sfr@xxxxxxxxxxxxxxxx> wrote:
>
> 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.
>
>
> 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

This is now a conflict between the nfs tree and Linus' tree.

--
Cheers,
Stephen Rothwell

Attachment: pgpZQ8tUORwtu.pgp
Description: OpenPGP digital signature