mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-25 14:31:21 +02:00 
			
		
		
		
	When U-Boot started using SPDX tags we were among the early adopters and there weren't a lot of other examples to borrow from. So we picked the area of the file that usually had a full license text and replaced it with an appropriate SPDX-License-Identifier: entry. Since then, the Linux Kernel has adopted SPDX tags and they place it as the very first line in a file (except where shebangs are used, then it's second line) and with slightly different comment styles than us. In part due to community overlap, in part due to better tag visibility and in part for other minor reasons, switch over to that style. This commit changes all instances where we have a single declared license in the tag as both the before and after are identical in tag contents. There's also a few places where I found we did not have a tag and have introduced one. Signed-off-by: Tom Rini <trini@konsulko.com>
		
			
				
	
	
		
			85 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0+ */
 | |
| /*
 | |
|  * (C) Masami Komiya <mkomiya@sonare.it> 2004
 | |
|  */
 | |
| 
 | |
| #ifndef __NFS_H__
 | |
| #define __NFS_H__
 | |
| 
 | |
| #define SUNRPC_PORT     111
 | |
| 
 | |
| #define PROG_PORTMAP    100000
 | |
| #define PROG_NFS        100003
 | |
| #define PROG_MOUNT      100005
 | |
| 
 | |
| #define MSG_CALL        0
 | |
| #define MSG_REPLY       1
 | |
| 
 | |
| #define PORTMAP_GETPORT 3
 | |
| 
 | |
| #define MOUNT_ADDENTRY  1
 | |
| #define MOUNT_UMOUNTALL 4
 | |
| 
 | |
| #define NFS_LOOKUP      4
 | |
| #define NFS_READLINK    5
 | |
| #define NFS_READ        6
 | |
| 
 | |
| #define NFS3PROC_LOOKUP 3
 | |
| 
 | |
| #define NFS_FHSIZE      32
 | |
| #define NFS3_FHSIZE     64
 | |
| 
 | |
| #define NFSERR_PERM     1
 | |
| #define NFSERR_NOENT    2
 | |
| #define NFSERR_ACCES    13
 | |
| #define NFSERR_ISDIR    21
 | |
| #define NFSERR_INVAL    22
 | |
| 
 | |
| /*
 | |
|  * Block size used for NFS read accesses.  A RPC reply packet (including  all
 | |
|  * headers) must fit within a single Ethernet frame to avoid fragmentation.
 | |
|  * However, if CONFIG_IP_DEFRAG is set, a bigger value could be used.  In any
 | |
|  * case, most NFS servers are optimized for a power of 2.
 | |
|  */
 | |
| #define NFS_READ_SIZE	1024	/* biggest power of two that fits Ether frame */
 | |
| 
 | |
| /* Values for Accept State flag on RPC answers (See: rfc1831) */
 | |
| enum rpc_accept_stat {
 | |
| 	NFS_RPC_SUCCESS = 0,	/* RPC executed successfully */
 | |
| 	NFS_RPC_PROG_UNAVAIL = 1,	/* remote hasn't exported program */
 | |
| 	NFS_RPC_PROG_MISMATCH = 2,	/* remote can't support version # */
 | |
| 	NFS_RPC_PROC_UNAVAIL = 3,	/* program can't support procedure */
 | |
| 	NFS_RPC_GARBAGE_ARGS = 4,	/* procedure can't decode params */
 | |
| 	NFS_RPC_SYSTEM_ERR = 5	/* errors like memory allocation failure */
 | |
| };
 | |
| 
 | |
| struct rpc_t {
 | |
| 	union {
 | |
| 		uint8_t data[2048];
 | |
| 		struct {
 | |
| 			uint32_t id;
 | |
| 			uint32_t type;
 | |
| 			uint32_t rpcvers;
 | |
| 			uint32_t prog;
 | |
| 			uint32_t vers;
 | |
| 			uint32_t proc;
 | |
| 			uint32_t data[1];
 | |
| 		} call;
 | |
| 		struct {
 | |
| 			uint32_t id;
 | |
| 			uint32_t type;
 | |
| 			uint32_t rstatus;
 | |
| 			uint32_t verifier;
 | |
| 			uint32_t v2;
 | |
| 			uint32_t astatus;
 | |
| 			uint32_t data[NFS_READ_SIZE];
 | |
| 		} reply;
 | |
| 	} u;
 | |
| } __attribute__((packed));
 | |
| void nfs_start(void);	/* Begin NFS */
 | |
| 
 | |
| 
 | |
| /**********************************************************************/
 | |
| 
 | |
| #endif /* __NFS_H__ */
 |