mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-10-26 14:01:50 +01:00 
			
		
		
		
	With GCC 9.2.1 net/nfs.c leads to multiple errors of type
address-of-packed-member.
net/nfs.c: In function ‘rpc_req’:
net/nfs.c:199:18: error: taking address of packed member of
‘struct rpc_t’ may result in an unaligned pointer value
[-Werror=address-of-packed-member]
  199 |  p = (uint32_t *)&(rpc_pkt.u.call.data);
      |                  ^~~~~~~~~~~~~~~~~~~~~~
net/nfs.c: In function ‘nfs_readlink_reply’:
net/nfs.c:631:46: error: taking address of packed member of
‘struct rpc_t’ may result in an unaligned pointer value
[-Werror=address-of-packed-member]
  631 |    nfs3_get_attributes_offset(rpc_pkt.u.reply.data);
      |                               ~~~~~~~~~~~~~~~^~~~~
  LD      drivers/block/built-in.o
net/nfs.c: In function ‘nfs_read_reply’:
net/nfs.c:692:46: error: taking address of packed member of
‘struct rpc_t’ may result in an unaligned pointer value
[-Werror=address-of-packed-member]
  692 |    nfs3_get_attributes_offset(rpc_pkt.u.reply.data);
      |                               ~~~~~~~~~~~~~~~^~~~~
struct rpc_t is only used as local variable. It is naturally packed. So
there is no need for the attribute packed.
Signed-off-by: Heinrich Schuchardt <xypron.glpk@gmx.de>
Reviewed-by: Bin Meng <bmeng.cn@gmail.com>
Acked-by: Joe Hershberger <joe.hershberger@ni.com>
		
	
			
		
			
				
	
	
		
			88 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			2.1 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 */
 | |
| #define NFS_MAX_ATTRS	26
 | |
| 
 | |
| /* 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[NFS_READ_SIZE + (6 + NFS_MAX_ATTRS) *
 | |
| 			sizeof(uint32_t)];
 | |
| 		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 / sizeof(uint32_t) +
 | |
| 				NFS_MAX_ATTRS];
 | |
| 		} reply;
 | |
| 	} u;
 | |
| };
 | |
| void nfs_start(void);	/* Begin NFS */
 | |
| 
 | |
| 
 | |
| /**********************************************************************/
 | |
| 
 | |
| #endif /* __NFS_H__ */
 |