2 * (C) Masami Komiya <mkomiya@sonare.it> 2004
4 * SPDX-License-Identifier: GPL-2.0+
10 #define SUNRPC_PORT 111
12 #define PROG_PORTMAP 100000
13 #define PROG_NFS 100003
14 #define PROG_MOUNT 100005
19 #define PORTMAP_GETPORT 3
21 #define MOUNT_ADDENTRY 1
22 #define MOUNT_UMOUNTALL 4
25 #define NFS_READLINK 5
28 #define NFS3PROC_LOOKUP 3
31 #define NFS3_FHSIZE 64
34 #define NFSERR_NOENT 2
35 #define NFSERR_ACCES 13
36 #define NFSERR_ISDIR 21
37 #define NFSERR_INVAL 22
40 * Block size used for NFS read accesses. A RPC reply packet (including all
41 * headers) must fit within a single Ethernet frame to avoid fragmentation.
42 * However, if CONFIG_IP_DEFRAG is set, a bigger value could be used. In any
43 * case, most NFS servers are optimized for a power of 2.
45 #define NFS_READ_SIZE 1024 /* biggest power of two that fits Ether frame */
47 /* Values for Accept State flag on RPC answers (See: rfc1831) */
48 enum rpc_accept_stat {
49 NFS_RPC_SUCCESS = 0, /* RPC executed successfully */
50 NFS_RPC_PROG_UNAVAIL = 1, /* remote hasn't exported program */
51 NFS_RPC_PROG_MISMATCH = 2, /* remote can't support version # */
52 NFS_RPC_PROC_UNAVAIL = 3, /* program can't support procedure */
53 NFS_RPC_GARBAGE_ARGS = 4, /* procedure can't decode params */
54 NFS_RPC_SYSTEM_ERR = 5 /* errors like memory allocation failure */
76 uint32_t data[NFS_READ_SIZE];
79 } __attribute__((packed));
80 void nfs_start(void); /* Begin NFS */
83 /**********************************************************************/
85 #endif /* __NFS_H__ */