mirror of
git://git.yoctoproject.org/linux-yocto.git
synced 2025-08-22 00:42:01 +02:00

Add a Python-based tool for translating XDR specifications into XDR encoder and decoder functions written in the Linux kernel's C coding style. The generator attempts to match the usual C coding style of the Linux kernel's SunRPC consumers. This approach is similar to the netlink code generator in tools/net/ynl . The maintainability benefits of machine-generated XDR code include: - Stronger type checking - Reduces the number of bugs introduced by human error - Makes the XDR code easier to audit and analyze - Enables rapid prototyping of new RPC-based protocols - Hardens the layering between protocol logic and marshaling - Makes it easier to add observability on demand - Unit tests might be built for both the tool and (automatically) for the generated code In addition, converting the XDR layer to use memory-safe languages such as Rust will be easier if much of the code can be converted automatically. Tested-by: Jeff Layton <jlayton@kernel.org> Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
22 lines
572 B
Django/Jinja
22 lines
572 B
Django/Jinja
{# SPDX-License-Identifier: GPL-2.0 #}
|
|
|
|
/**
|
|
* {{ program }}_svc_decode_{{ argument }} - Decode a {{ argument }} argument
|
|
* @rqstp: RPC transaction context
|
|
* @xdr: source XDR data stream
|
|
*
|
|
* Return values:
|
|
* %true: procedure arguments decoded successfully
|
|
* %false: decode failed
|
|
*/
|
|
bool {{ program }}_svc_decode_{{ argument }}(struct svc_rqst *rqstp, struct xdr_stream *xdr)
|
|
{
|
|
{% if argument == 'void' %}
|
|
return xdrgen_decode_void(xdr);
|
|
{% else %}
|
|
struct {{ argument }} *argp = rqstp->rq_argp;
|
|
|
|
return xdrgen_decode_{{ argument }}(xdr, argp);
|
|
{% endif %}
|
|
}
|