91b9b0d718
sparc, 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. Unlike most architectures, sparc actually succeeded in defining this right for big-endian CPUs, but as everyone else got it wrong, we just use the same hack everywhere. 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>
36 lines
1.2 KiB
C
36 lines
1.2 KiB
C
/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
|
|
#ifndef _SPARC_MSGBUF_H
|
|
#define _SPARC_MSGBUF_H
|
|
|
|
/*
|
|
* The msqid64_ds structure for sparc64 architecture.
|
|
* Note extra padding because this structure is passed back and forth
|
|
* between kernel and user space.
|
|
*
|
|
* Pad space is left for:
|
|
* - 2 miscellaneous 32-bit values
|
|
*/
|
|
struct msqid64_ds {
|
|
struct ipc64_perm msg_perm;
|
|
#if defined(__sparc__) && defined(__arch64__)
|
|
__kernel_time_t msg_stime; /* last msgsnd time */
|
|
__kernel_time_t msg_rtime; /* last msgrcv time */
|
|
__kernel_time_t msg_ctime; /* last change time */
|
|
#else
|
|
unsigned long msg_stime_high;
|
|
unsigned long msg_stime; /* last msgsnd time */
|
|
unsigned long msg_rtime_high;
|
|
unsigned long msg_rtime; /* last msgrcv time */
|
|
unsigned long msg_ctime_high;
|
|
unsigned long msg_ctime; /* last change time */
|
|
#endif
|
|
unsigned long msg_cbytes; /* current number of bytes on queue */
|
|
unsigned long msg_qnum; /* number of messages in queue */
|
|
unsigned long msg_qbytes; /* max number of bytes on queue */
|
|
__kernel_pid_t msg_lspid; /* pid of last msgsnd */
|
|
__kernel_pid_t msg_lrpid; /* last receive pid */
|
|
unsigned long __unused1;
|
|
unsigned long __unused2;
|
|
};
|
|
#endif /* _SPARC_MSGBUF_H */
|