 7f254c5cb8
			
		
	
	
		7f254c5cb8
		
	
	
	
	
		
			
			Since commit 8efb2ed5ec ("linux-user: Correct signedness of
target_flock l_start and l_len fields"), flock64 structure uses
abi_llong for l_start and l_len in place of "unsigned long long"
this should force them to be aligned accordingly to the target
rules. So we can remove the padding field and the QEMU_PACKED
attribute.
I have compared the result of the following program before and
after the change:
    cat -> flock64_dump  <<EOF
    p/d sizeof(struct target_flock64)
    p/d &((struct target_flock64 *)0)->l_type
    p/d &((struct target_flock64 *)0)->l_whence
    p/d &((struct target_flock64 *)0)->l_start
    p/d &((struct target_flock64 *)0)->l_len
    p/d &((struct target_flock64 *)0)->l_pid
    quit
    EOF
    for file in build/all/*-linux-user/qemu-* ; do
    echo $file
    gdb -batch -nx -x flock64_dump $file 2> /dev/null
    done
The sizeof() changes because we remove the QEMU_PACKED.
The new size is 32 (except for i386 and m68k) and this is
the real size of "struct flock64" on the target architecture.
The following architectures differ:
aarch64_be, aarch64, alpha, armeb, arm, cris, hppa, nios2, or1k,
riscv32, riscv64, s390x.
For a subset of these architectures, I have checked with the following
program the new structure is the correct one:
  #include <stdio.h>
  #define __USE_LARGEFILE64
  #include <fcntl.h>
  int main(void)
  {
	  printf("struct flock64 %d\n", sizeof(struct flock64));
	  printf("l_type %d\n", &((struct flock64 *)0)->l_type);
	  printf("l_whence %d\n", &((struct flock64 *)0)->l_whence);
	  printf("l_start %d\n", &((struct flock64 *)0)->l_start);
	  printf("l_len %d\n", &((struct flock64 *)0)->l_len);
	  printf("l_pid %d\n", &((struct flock64 *)0)->l_pid);
  }
[I have checked aarch64, alpha, hppa, s390x]
For ARM, the target_flock64 becomes the EABI definition, so we need to
define the OABI one in place of the EABI one and use it when it is
needed.
I have also fixed the alignment value for sh4 (to align llong on 4 bytes)
(see c2e3dee6e0 "linux-user: Define target alignment size")
[We should check alignment properties for cris, nios2 and or1k]
Signed-off-by: Laurent Vivier <laurent@vivier.eu>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-Id: <20180502215730.28162-1-laurent@vivier.eu>
		
	
			
		
			
				
	
	
		
			60 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			60 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * ARM specific structures for linux-user
 | |
|  *
 | |
|  * Copyright (c) 2013 Fabrice Bellard
 | |
|  *
 | |
|  * This library is free software; you can redistribute it and/or
 | |
|  * modify it under the terms of the GNU Lesser General Public
 | |
|  * License as published by the Free Software Foundation; either
 | |
|  * version 2 of the License, or (at your option) any later version.
 | |
|  *
 | |
|  * This library is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
|  * Lesser General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Lesser General Public
 | |
|  * License along with this library; if not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| #ifndef ARM_TARGET_STRUCTS_H
 | |
| #define ARM_TARGET_STRUCTS_H
 | |
| 
 | |
| struct target_ipc_perm {
 | |
|     abi_int __key;                      /* Key.  */
 | |
|     abi_uint uid;                       /* Owner's user ID.  */
 | |
|     abi_uint gid;                       /* Owner's group ID.  */
 | |
|     abi_uint cuid;                      /* Creator's user ID.  */
 | |
|     abi_uint cgid;                      /* Creator's group ID.  */
 | |
|     abi_ushort mode;                    /* Read/write permission.  */
 | |
|     abi_ushort __pad1;
 | |
|     abi_ushort __seq;                   /* Sequence number.  */
 | |
|     abi_ushort __pad2;
 | |
|     abi_ulong __unused1;
 | |
|     abi_ulong __unused2;
 | |
| };
 | |
| 
 | |
| struct target_shmid_ds {
 | |
|     struct target_ipc_perm shm_perm;    /* operation permission struct */
 | |
|     abi_long shm_segsz;                 /* size of segment in bytes */
 | |
|     abi_ulong shm_atime;                /* time of last shmat() */
 | |
|     abi_ulong __unused1;
 | |
|     abi_ulong shm_dtime;                /* time of last shmdt() */
 | |
|     abi_ulong __unused2;
 | |
|     abi_ulong shm_ctime;                /* time of last change by shmctl() */
 | |
|     abi_ulong __unused3;
 | |
|     abi_int shm_cpid;                   /* pid of creator */
 | |
|     abi_int shm_lpid;                   /* pid of last shmop */
 | |
|     abi_ulong shm_nattch;               /* number of current attaches */
 | |
|     abi_ulong __unused4;
 | |
|     abi_ulong __unused5;
 | |
| };
 | |
| 
 | |
| struct target_oabi_flock64 {
 | |
|     abi_short l_type;
 | |
|     abi_short l_whence;
 | |
|     abi_llong l_start;
 | |
|     abi_llong l_len;
 | |
|     abi_int   l_pid;
 | |
| } QEMU_PACKED;
 | |
| #endif
 |