root/fs/nfsd/nfs4xdr_gen.c
// SPDX-License-Identifier: GPL-2.0
// Generated by xdrgen. Manual edits will be lost.
// XDR specification file: ../../Documentation/sunrpc/xdr/nfs4_1.x
// XDR specification modification time: Thu Jan  8 23:12:07 2026

#include <linux/sunrpc/svc.h>

#include "nfs4xdr_gen.h"

static bool __maybe_unused
xdrgen_decode_int64_t(struct xdr_stream *xdr, int64_t *ptr)
{
        return xdrgen_decode_hyper(xdr, ptr);
}

static bool __maybe_unused
xdrgen_decode_uint32_t(struct xdr_stream *xdr, uint32_t *ptr)
{
        return xdrgen_decode_unsigned_int(xdr, ptr);
}

static bool __maybe_unused
xdrgen_decode_bitmap4(struct xdr_stream *xdr, bitmap4 *ptr)
{
        if (xdr_stream_decode_u32(xdr, &ptr->count) < 0)
                return false;
        for (u32 i = 0; i < ptr->count; i++)
                if (!xdrgen_decode_uint32_t(xdr, &ptr->element[i]))
                        return false;
        return true;
}

static bool __maybe_unused
xdrgen_decode_utf8string(struct xdr_stream *xdr, utf8string *ptr)
{
        return xdrgen_decode_opaque(xdr, ptr, 0);
}

static bool __maybe_unused
xdrgen_decode_utf8str_cis(struct xdr_stream *xdr, utf8str_cis *ptr)
{
        return xdrgen_decode_utf8string(xdr, ptr);
}

static bool __maybe_unused
xdrgen_decode_utf8str_cs(struct xdr_stream *xdr, utf8str_cs *ptr)
{
        return xdrgen_decode_utf8string(xdr, ptr);
}

static bool __maybe_unused
xdrgen_decode_utf8str_mixed(struct xdr_stream *xdr, utf8str_mixed *ptr)
{
        return xdrgen_decode_utf8string(xdr, ptr);
}

static bool __maybe_unused
xdrgen_decode_nfstime4(struct xdr_stream *xdr, struct nfstime4 *ptr)
{
        if (!xdrgen_decode_int64_t(xdr, &ptr->seconds))
                return false;
        if (!xdrgen_decode_uint32_t(xdr, &ptr->nseconds))
                return false;
        return true;
}

static bool __maybe_unused
xdrgen_decode_fattr4_offline(struct xdr_stream *xdr, fattr4_offline *ptr)
{
        return xdrgen_decode_bool(xdr, ptr);
}

static bool __maybe_unused
xdrgen_decode_open_arguments4(struct xdr_stream *xdr, struct open_arguments4 *ptr)
{
        if (!xdrgen_decode_bitmap4(xdr, &ptr->oa_share_access))
                return false;
        if (!xdrgen_decode_bitmap4(xdr, &ptr->oa_share_deny))
                return false;
        if (!xdrgen_decode_bitmap4(xdr, &ptr->oa_share_access_want))
                return false;
        if (!xdrgen_decode_bitmap4(xdr, &ptr->oa_open_claim))
                return false;
        if (!xdrgen_decode_bitmap4(xdr, &ptr->oa_create_mode))
                return false;
        return true;
}

static bool __maybe_unused
xdrgen_decode_open_args_share_access4(struct xdr_stream *xdr, open_args_share_access4 *ptr)
{
        u32 val;

        if (xdr_stream_decode_u32(xdr, &val) < 0)
                return false;
        /* Compiler may optimize to a range check for dense enums */
        switch (val) {
        case OPEN_ARGS_SHARE_ACCESS_READ:
        case OPEN_ARGS_SHARE_ACCESS_WRITE:
        case OPEN_ARGS_SHARE_ACCESS_BOTH:
                break;
        default:
                return false;
        }
        *ptr = val;
        return true;
}

static bool __maybe_unused
xdrgen_decode_open_args_share_deny4(struct xdr_stream *xdr, open_args_share_deny4 *ptr)
{
        u32 val;

        if (xdr_stream_decode_u32(xdr, &val) < 0)
                return false;
        /* Compiler may optimize to a range check for dense enums */
        switch (val) {
        case OPEN_ARGS_SHARE_DENY_NONE:
        case OPEN_ARGS_SHARE_DENY_READ:
        case OPEN_ARGS_SHARE_DENY_WRITE:
        case OPEN_ARGS_SHARE_DENY_BOTH:
                break;
        default:
                return false;
        }
        *ptr = val;
        return true;
}

static bool __maybe_unused
xdrgen_decode_open_args_share_access_want4(struct xdr_stream *xdr, open_args_share_access_want4 *ptr)
{
        u32 val;

        if (xdr_stream_decode_u32(xdr, &val) < 0)
                return false;
        /* Compiler may optimize to a range check for dense enums */
        switch (val) {
        case OPEN_ARGS_SHARE_ACCESS_WANT_ANY_DELEG:
        case OPEN_ARGS_SHARE_ACCESS_WANT_NO_DELEG:
        case OPEN_ARGS_SHARE_ACCESS_WANT_CANCEL:
        case OPEN_ARGS_SHARE_ACCESS_WANT_SIGNAL_DELEG_WHEN_RESRC_AVAIL:
        case OPEN_ARGS_SHARE_ACCESS_WANT_PUSH_DELEG_WHEN_UNCONTENDED:
        case OPEN_ARGS_SHARE_ACCESS_WANT_DELEG_TIMESTAMPS:
        case OPEN_ARGS_SHARE_ACCESS_WANT_OPEN_XOR_DELEGATION:
                break;
        default:
                return false;
        }
        *ptr = val;
        return true;
}

static bool __maybe_unused
xdrgen_decode_open_args_open_claim4(struct xdr_stream *xdr, open_args_open_claim4 *ptr)
{
        u32 val;

        if (xdr_stream_decode_u32(xdr, &val) < 0)
                return false;
        /* Compiler may optimize to a range check for dense enums */
        switch (val) {
        case OPEN_ARGS_OPEN_CLAIM_NULL:
        case OPEN_ARGS_OPEN_CLAIM_PREVIOUS:
        case OPEN_ARGS_OPEN_CLAIM_DELEGATE_CUR:
        case OPEN_ARGS_OPEN_CLAIM_DELEGATE_PREV:
        case OPEN_ARGS_OPEN_CLAIM_FH:
        case OPEN_ARGS_OPEN_CLAIM_DELEG_CUR_FH:
        case OPEN_ARGS_OPEN_CLAIM_DELEG_PREV_FH:
                break;
        default:
                return false;
        }
        *ptr = val;
        return true;
}

static bool __maybe_unused
xdrgen_decode_open_args_createmode4(struct xdr_stream *xdr, open_args_createmode4 *ptr)
{
        u32 val;

        if (xdr_stream_decode_u32(xdr, &val) < 0)
                return false;
        /* Compiler may optimize to a range check for dense enums */
        switch (val) {
        case OPEN_ARGS_CREATEMODE_UNCHECKED4:
        case OPEN_ARGS_CREATE_MODE_GUARDED:
        case OPEN_ARGS_CREATEMODE_EXCLUSIVE4:
        case OPEN_ARGS_CREATE_MODE_EXCLUSIVE4_1:
                break;
        default:
                return false;
        }
        *ptr = val;
        return true;
}

bool
xdrgen_decode_fattr4_open_arguments(struct xdr_stream *xdr, fattr4_open_arguments *ptr)
{
        return xdrgen_decode_open_arguments4(xdr, ptr);
}

/*
 * Determine what OPEN supports.
 */

bool
xdrgen_decode_fattr4_time_deleg_access(struct xdr_stream *xdr, fattr4_time_deleg_access *ptr)
{
        return xdrgen_decode_nfstime4(xdr, ptr);
}

bool
xdrgen_decode_fattr4_time_deleg_modify(struct xdr_stream *xdr, fattr4_time_deleg_modify *ptr)
{
        return xdrgen_decode_nfstime4(xdr, ptr);
}

/*
 * New RECOMMENDED Attribute for
 * delegation caching of times
 */

static bool __maybe_unused
xdrgen_decode_open_delegation_type4(struct xdr_stream *xdr, open_delegation_type4 *ptr)
{
        u32 val;

        if (xdr_stream_decode_u32(xdr, &val) < 0)
                return false;
        /* Compiler may optimize to a range check for dense enums */
        switch (val) {
        case OPEN_DELEGATE_NONE:
        case OPEN_DELEGATE_READ:
        case OPEN_DELEGATE_WRITE:
        case OPEN_DELEGATE_NONE_EXT:
        case OPEN_DELEGATE_READ_ATTRS_DELEG:
        case OPEN_DELEGATE_WRITE_ATTRS_DELEG:
                break;
        default:
                return false;
        }
        *ptr = val;
        return true;
}

bool
xdrgen_decode_aclmodel4(struct xdr_stream *xdr, aclmodel4 *ptr)
{
        u32 val;

        if (xdr_stream_decode_u32(xdr, &val) < 0)
                return false;
        /* Compiler may optimize to a range check for dense enums */
        switch (val) {
        case ACL_MODEL_NFS4:
        case ACL_MODEL_POSIX_DRAFT:
        case ACL_MODEL_NONE:
                break;
        default:
                return false;
        }
        *ptr = val;
        return true;
}

bool
xdrgen_decode_aclscope4(struct xdr_stream *xdr, aclscope4 *ptr)
{
        u32 val;

        if (xdr_stream_decode_u32(xdr, &val) < 0)
                return false;
        /* Compiler may optimize to a range check for dense enums */
        switch (val) {
        case ACL_SCOPE_FILE_OBJECT:
        case ACL_SCOPE_FILE_SYSTEM:
        case ACL_SCOPE_SERVER:
                break;
        default:
                return false;
        }
        *ptr = val;
        return true;
}

bool
xdrgen_decode_posixacetag4(struct xdr_stream *xdr, posixacetag4 *ptr)
{
        u32 val;

        if (xdr_stream_decode_u32(xdr, &val) < 0)
                return false;
        /* Compiler may optimize to a range check for dense enums */
        switch (val) {
        case POSIXACE4_TAG_USER_OBJ:
        case POSIXACE4_TAG_USER:
        case POSIXACE4_TAG_GROUP_OBJ:
        case POSIXACE4_TAG_GROUP:
        case POSIXACE4_TAG_MASK:
        case POSIXACE4_TAG_OTHER:
                break;
        default:
                return false;
        }
        *ptr = val;
        return true;
}

bool
xdrgen_decode_posixaceperm4(struct xdr_stream *xdr, posixaceperm4 *ptr)
{
        return xdrgen_decode_uint32_t(xdr, ptr);
}

static bool __maybe_unused
xdrgen_decode_posixace4(struct xdr_stream *xdr, struct posixace4 *ptr)
{
        if (!xdrgen_decode_posixacetag4(xdr, &ptr->tag))
                return false;
        if (!xdrgen_decode_posixaceperm4(xdr, &ptr->perm))
                return false;
        if (!xdrgen_decode_utf8str_mixed(xdr, &ptr->who))
                return false;
        return true;
}

static bool __maybe_unused
xdrgen_decode_fattr4_acl_trueform(struct xdr_stream *xdr, fattr4_acl_trueform *ptr)
{
        return xdrgen_decode_aclmodel4(xdr, ptr);
}

static bool __maybe_unused
xdrgen_decode_fattr4_acl_trueform_scope(struct xdr_stream *xdr, fattr4_acl_trueform_scope *ptr)
{
        return xdrgen_decode_aclscope4(xdr, ptr);
}

static bool __maybe_unused
xdrgen_decode_fattr4_posix_default_acl(struct xdr_stream *xdr, fattr4_posix_default_acl *ptr)
{
        if (xdr_stream_decode_u32(xdr, &ptr->count) < 0)
                return false;
        for (u32 i = 0; i < ptr->count; i++)
                if (!xdrgen_decode_posixace4(xdr, &ptr->element[i]))
                        return false;
        return true;
}

static bool __maybe_unused
xdrgen_decode_fattr4_posix_access_acl(struct xdr_stream *xdr, fattr4_posix_access_acl *ptr)
{
        if (xdr_stream_decode_u32(xdr, &ptr->count) < 0)
                return false;
        for (u32 i = 0; i < ptr->count; i++)
                if (!xdrgen_decode_posixace4(xdr, &ptr->element[i]))
                        return false;
        return true;
}

/*
 * New for POSIX ACL extension
 */

static bool __maybe_unused
xdrgen_encode_int64_t(struct xdr_stream *xdr, const int64_t value)
{
        return xdrgen_encode_hyper(xdr, value);
}

static bool __maybe_unused
xdrgen_encode_uint32_t(struct xdr_stream *xdr, const uint32_t value)
{
        return xdrgen_encode_unsigned_int(xdr, value);
}

static bool __maybe_unused
xdrgen_encode_bitmap4(struct xdr_stream *xdr, const bitmap4 value)
{
        if (xdr_stream_encode_u32(xdr, value.count) != XDR_UNIT)
                return false;
        for (u32 i = 0; i < value.count; i++)
                if (!xdrgen_encode_uint32_t(xdr, value.element[i]))
                        return false;
        return true;
}

static bool __maybe_unused
xdrgen_encode_utf8string(struct xdr_stream *xdr, const utf8string value)
{
        return xdr_stream_encode_opaque(xdr, value.data, value.len) >= 0;
}

static bool __maybe_unused
xdrgen_encode_utf8str_cis(struct xdr_stream *xdr, const utf8str_cis value)
{
        return xdrgen_encode_utf8string(xdr, value);
}

static bool __maybe_unused
xdrgen_encode_utf8str_cs(struct xdr_stream *xdr, const utf8str_cs value)
{
        return xdrgen_encode_utf8string(xdr, value);
}

static bool __maybe_unused
xdrgen_encode_utf8str_mixed(struct xdr_stream *xdr, const utf8str_mixed value)
{
        return xdrgen_encode_utf8string(xdr, value);
}

static bool __maybe_unused
xdrgen_encode_nfstime4(struct xdr_stream *xdr, const struct nfstime4 *value)
{
        if (!xdrgen_encode_int64_t(xdr, value->seconds))
                return false;
        if (!xdrgen_encode_uint32_t(xdr, value->nseconds))
                return false;
        return true;
}

static bool __maybe_unused
xdrgen_encode_fattr4_offline(struct xdr_stream *xdr, const fattr4_offline value)
{
        return xdrgen_encode_bool(xdr, value);
}

static bool __maybe_unused
xdrgen_encode_open_arguments4(struct xdr_stream *xdr, const struct open_arguments4 *value)
{
        if (!xdrgen_encode_bitmap4(xdr, value->oa_share_access))
                return false;
        if (!xdrgen_encode_bitmap4(xdr, value->oa_share_deny))
                return false;
        if (!xdrgen_encode_bitmap4(xdr, value->oa_share_access_want))
                return false;
        if (!xdrgen_encode_bitmap4(xdr, value->oa_open_claim))
                return false;
        if (!xdrgen_encode_bitmap4(xdr, value->oa_create_mode))
                return false;
        return true;
}

static bool __maybe_unused
xdrgen_encode_open_args_share_access4(struct xdr_stream *xdr, open_args_share_access4 value)
{
        return xdr_stream_encode_u32(xdr, value) == XDR_UNIT;
}

static bool __maybe_unused
xdrgen_encode_open_args_share_deny4(struct xdr_stream *xdr, open_args_share_deny4 value)
{
        return xdr_stream_encode_u32(xdr, value) == XDR_UNIT;
}

static bool __maybe_unused
xdrgen_encode_open_args_share_access_want4(struct xdr_stream *xdr, open_args_share_access_want4 value)
{
        return xdr_stream_encode_u32(xdr, value) == XDR_UNIT;
}

static bool __maybe_unused
xdrgen_encode_open_args_open_claim4(struct xdr_stream *xdr, open_args_open_claim4 value)
{
        return xdr_stream_encode_u32(xdr, value) == XDR_UNIT;
}

static bool __maybe_unused
xdrgen_encode_open_args_createmode4(struct xdr_stream *xdr, open_args_createmode4 value)
{
        return xdr_stream_encode_u32(xdr, value) == XDR_UNIT;
}

bool
xdrgen_encode_fattr4_open_arguments(struct xdr_stream *xdr, const fattr4_open_arguments *value)
{
        return xdrgen_encode_open_arguments4(xdr, value);
}

bool
xdrgen_encode_fattr4_time_deleg_access(struct xdr_stream *xdr, const fattr4_time_deleg_access *value)
{
        return xdrgen_encode_nfstime4(xdr, value);
}

bool
xdrgen_encode_fattr4_time_deleg_modify(struct xdr_stream *xdr, const fattr4_time_deleg_modify *value)
{
        return xdrgen_encode_nfstime4(xdr, value);
}

static bool __maybe_unused
xdrgen_encode_open_delegation_type4(struct xdr_stream *xdr, open_delegation_type4 value)
{
        return xdr_stream_encode_u32(xdr, value) == XDR_UNIT;
}

bool
xdrgen_encode_aclmodel4(struct xdr_stream *xdr, aclmodel4 value)
{
        return xdr_stream_encode_u32(xdr, value) == XDR_UNIT;
}

bool
xdrgen_encode_aclscope4(struct xdr_stream *xdr, aclscope4 value)
{
        return xdr_stream_encode_u32(xdr, value) == XDR_UNIT;
}

bool
xdrgen_encode_posixacetag4(struct xdr_stream *xdr, posixacetag4 value)
{
        return xdr_stream_encode_u32(xdr, value) == XDR_UNIT;
}

bool
xdrgen_encode_posixaceperm4(struct xdr_stream *xdr, const posixaceperm4 value)
{
        return xdrgen_encode_uint32_t(xdr, value);
}

static bool __maybe_unused
xdrgen_encode_posixace4(struct xdr_stream *xdr, const struct posixace4 *value)
{
        if (!xdrgen_encode_posixacetag4(xdr, value->tag))
                return false;
        if (!xdrgen_encode_posixaceperm4(xdr, value->perm))
                return false;
        if (!xdrgen_encode_utf8str_mixed(xdr, value->who))
                return false;
        return true;
}

static bool __maybe_unused
xdrgen_encode_fattr4_acl_trueform(struct xdr_stream *xdr, const fattr4_acl_trueform value)
{
        return xdrgen_encode_aclmodel4(xdr, value);
}

static bool __maybe_unused
xdrgen_encode_fattr4_acl_trueform_scope(struct xdr_stream *xdr, const fattr4_acl_trueform_scope value)
{
        return xdrgen_encode_aclscope4(xdr, value);
}

static bool __maybe_unused
xdrgen_encode_fattr4_posix_default_acl(struct xdr_stream *xdr, const fattr4_posix_default_acl value)
{
        if (xdr_stream_encode_u32(xdr, value.count) != XDR_UNIT)
                return false;
        for (u32 i = 0; i < value.count; i++)
                if (!xdrgen_encode_posixace4(xdr, &value.element[i]))
                        return false;
        return true;
}

static bool __maybe_unused
xdrgen_encode_fattr4_posix_access_acl(struct xdr_stream *xdr, const fattr4_posix_access_acl value)
{
        if (xdr_stream_encode_u32(xdr, value.count) != XDR_UNIT)
                return false;
        for (u32 i = 0; i < value.count; i++)
                if (!xdrgen_encode_posixace4(xdr, &value.element[i]))
                        return false;
        return true;
}