forked from luck/tmp_suning_uos_patched
y2038: xtensa: Extend sysvipc data structures
xtensa, uses a nonstandard variation of the generic sysvipc data structures, intended to have the padding moved around so it can deal with big-endian 32-bit user space that has 64-bit time_t. xtensa tries hard to define the structures so they work in both big-endian and little-endian systems with padding on the right side. However, they only succeeded for for two of the three structures, and their struct shmid64_ds ended up being defined in two identical copies, and the big-endian one is wrong. This takes just take the same approach here that we have for the asm-generic headers and adds separate 32-bit fields for the upper halves of the timestamps, to let libc deal with the mess in user space. Signed-off-by: Arnd Bergmann <arnd@arndb.de>
This commit is contained in:
parent
d0b67de998
commit
b497ef570e
|
@ -7,7 +7,6 @@
|
||||||
* between kernel and user space.
|
* between kernel and user space.
|
||||||
*
|
*
|
||||||
* Pad space is left for:
|
* Pad space is left for:
|
||||||
* - 64-bit time_t to solve y2038 problem
|
|
||||||
* - 2 miscellaneous 32-bit values
|
* - 2 miscellaneous 32-bit values
|
||||||
*
|
*
|
||||||
* This file is subject to the terms and conditions of the GNU General
|
* This file is subject to the terms and conditions of the GNU General
|
||||||
|
@ -21,19 +20,19 @@
|
||||||
struct msqid64_ds {
|
struct msqid64_ds {
|
||||||
struct ipc64_perm msg_perm;
|
struct ipc64_perm msg_perm;
|
||||||
#ifdef __XTENSA_EB__
|
#ifdef __XTENSA_EB__
|
||||||
unsigned int __unused1;
|
unsigned long msg_stime_high;
|
||||||
__kernel_time_t msg_stime; /* last msgsnd time */
|
unsigned long msg_stime; /* last msgsnd time */
|
||||||
unsigned int __unused2;
|
unsigned long msg_rtime_high;
|
||||||
__kernel_time_t msg_rtime; /* last msgrcv time */
|
unsigned long msg_rtime; /* last msgrcv time */
|
||||||
unsigned int __unused3;
|
unsigned long msg_ctime_high;
|
||||||
__kernel_time_t msg_ctime; /* last change time */
|
unsigned long msg_ctime; /* last change time */
|
||||||
#elif defined(__XTENSA_EL__)
|
#elif defined(__XTENSA_EL__)
|
||||||
__kernel_time_t msg_stime; /* last msgsnd time */
|
unsigned long msg_stime; /* last msgsnd time */
|
||||||
unsigned int __unused1;
|
unsigned long msg_stime_high;
|
||||||
__kernel_time_t msg_rtime; /* last msgrcv time */
|
unsigned long msg_rtime; /* last msgrcv time */
|
||||||
unsigned int __unused2;
|
unsigned long msg_rtime_high;
|
||||||
__kernel_time_t msg_ctime; /* last change time */
|
unsigned long msg_ctime; /* last change time */
|
||||||
unsigned int __unused3;
|
unsigned long msg_ctime_high;
|
||||||
#else
|
#else
|
||||||
# error processor byte order undefined!
|
# error processor byte order undefined!
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -14,7 +14,6 @@
|
||||||
* between kernel and user space.
|
* between kernel and user space.
|
||||||
*
|
*
|
||||||
* Pad space is left for:
|
* Pad space is left for:
|
||||||
* - 64-bit time_t to solve y2038 problem
|
|
||||||
* - 2 miscellaneous 32-bit values
|
* - 2 miscellaneous 32-bit values
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
@ -27,15 +26,15 @@
|
||||||
struct semid64_ds {
|
struct semid64_ds {
|
||||||
struct ipc64_perm sem_perm; /* permissions .. see ipc.h */
|
struct ipc64_perm sem_perm; /* permissions .. see ipc.h */
|
||||||
#ifdef __XTENSA_EL__
|
#ifdef __XTENSA_EL__
|
||||||
__kernel_time_t sem_otime; /* last semop time */
|
unsigned long sem_otime; /* last semop time */
|
||||||
unsigned long __unused1;
|
unsigned long sem_otime_high;
|
||||||
__kernel_time_t sem_ctime; /* last change time */
|
unsigned long sem_ctime; /* last change time */
|
||||||
unsigned long __unused2;
|
unsigned long sem_ctime_high;
|
||||||
#else
|
#else
|
||||||
unsigned long __unused1;
|
unsigned long sem_otime_high;
|
||||||
__kernel_time_t sem_otime; /* last semop time */
|
unsigned long sem_otime; /* last semop time */
|
||||||
unsigned long __unused2;
|
unsigned long sem_ctime_high;
|
||||||
__kernel_time_t sem_ctime; /* last change time */
|
unsigned long sem_ctime; /* last change time */
|
||||||
#endif
|
#endif
|
||||||
unsigned long sem_nsems; /* no. of semaphores in array */
|
unsigned long sem_nsems; /* no. of semaphores in array */
|
||||||
unsigned long __unused3;
|
unsigned long __unused3;
|
||||||
|
|
|
@ -4,10 +4,10 @@
|
||||||
*
|
*
|
||||||
* The shmid64_ds structure for Xtensa architecture.
|
* The shmid64_ds structure for Xtensa architecture.
|
||||||
* Note extra padding because this structure is passed back and forth
|
* Note extra padding because this structure is passed back and forth
|
||||||
* between kernel and user space.
|
* between kernel and user space, but the padding is on the wrong
|
||||||
|
* side for big-endian xtensa, for historic reasons.
|
||||||
*
|
*
|
||||||
* Pad space is left for:
|
* Pad space is left for:
|
||||||
* - 64-bit time_t to solve y2038 problem
|
|
||||||
* - 2 miscellaneous 32-bit values
|
* - 2 miscellaneous 32-bit values
|
||||||
*
|
*
|
||||||
* This file is subject to the terms and conditions of the GNU General Public
|
* This file is subject to the terms and conditions of the GNU General Public
|
||||||
|
@ -20,42 +20,21 @@
|
||||||
#ifndef _XTENSA_SHMBUF_H
|
#ifndef _XTENSA_SHMBUF_H
|
||||||
#define _XTENSA_SHMBUF_H
|
#define _XTENSA_SHMBUF_H
|
||||||
|
|
||||||
#if defined (__XTENSA_EL__)
|
|
||||||
struct shmid64_ds {
|
struct shmid64_ds {
|
||||||
struct ipc64_perm shm_perm; /* operation perms */
|
struct ipc64_perm shm_perm; /* operation perms */
|
||||||
size_t shm_segsz; /* size of segment (bytes) */
|
size_t shm_segsz; /* size of segment (bytes) */
|
||||||
__kernel_time_t shm_atime; /* last attach time */
|
unsigned long shm_atime; /* last attach time */
|
||||||
unsigned long __unused1;
|
unsigned long shm_atime_high;
|
||||||
__kernel_time_t shm_dtime; /* last detach time */
|
unsigned long shm_dtime; /* last detach time */
|
||||||
unsigned long __unused2;
|
unsigned long shm_dtime_high;
|
||||||
__kernel_time_t shm_ctime; /* last change time */
|
unsigned long shm_ctime; /* last change time */
|
||||||
unsigned long __unused3;
|
unsigned long shm_ctime_high;
|
||||||
__kernel_pid_t shm_cpid; /* pid of creator */
|
__kernel_pid_t shm_cpid; /* pid of creator */
|
||||||
__kernel_pid_t shm_lpid; /* pid of last operator */
|
__kernel_pid_t shm_lpid; /* pid of last operator */
|
||||||
unsigned long shm_nattch; /* no. of current attaches */
|
unsigned long shm_nattch; /* no. of current attaches */
|
||||||
unsigned long __unused4;
|
unsigned long __unused4;
|
||||||
unsigned long __unused5;
|
unsigned long __unused5;
|
||||||
};
|
};
|
||||||
#elif defined (__XTENSA_EB__)
|
|
||||||
struct shmid64_ds {
|
|
||||||
struct ipc64_perm shm_perm; /* operation perms */
|
|
||||||
size_t shm_segsz; /* size of segment (bytes) */
|
|
||||||
__kernel_time_t shm_atime; /* last attach time */
|
|
||||||
unsigned long __unused1;
|
|
||||||
__kernel_time_t shm_dtime; /* last detach time */
|
|
||||||
unsigned long __unused2;
|
|
||||||
__kernel_time_t shm_ctime; /* last change time */
|
|
||||||
unsigned long __unused3;
|
|
||||||
__kernel_pid_t shm_cpid; /* pid of creator */
|
|
||||||
__kernel_pid_t shm_lpid; /* pid of last operator */
|
|
||||||
unsigned long shm_nattch; /* no. of current attaches */
|
|
||||||
unsigned long __unused4;
|
|
||||||
unsigned long __unused5;
|
|
||||||
};
|
|
||||||
#else
|
|
||||||
# error endian order not defined
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
struct shminfo64 {
|
struct shminfo64 {
|
||||||
unsigned long shmmax;
|
unsigned long shmmax;
|
||||||
|
|
Loading…
Reference in New Issue
Block a user