| #ifndef _PARISC_SHMBUF_H |
| #define _PARISC_SHMBUF_H |
| |
| /* |
| * The shmid64_ds structure for parisc architecture. |
| * Note extra padding because this structure is passed back and forth |
| * between kernel and user space. |
| * |
| * Pad space is left for: |
| * - 64-bit time_t to solve y2038 problem |
| * - 2 miscellaneous 32-bit values |
| */ |
| |
| struct shmid64_ds { |
| struct ipc64_perm shm_perm; /* operation perms */ |
| #ifndef CONFIG_64BIT |
| unsigned int __pad1; |
| #endif |
| __kernel_time_t shm_atime; /* last attach time */ |
| #ifndef CONFIG_64BIT |
| unsigned int __pad2; |
| #endif |
| __kernel_time_t shm_dtime; /* last detach time */ |
| #ifndef CONFIG_64BIT |
| unsigned int __pad3; |
| #endif |
| __kernel_time_t shm_ctime; /* last change time */ |
| #ifndef CONFIG_64BIT |
| unsigned int __pad4; |
| #endif |
| size_t shm_segsz; /* size of segment (bytes) */ |
| __kernel_pid_t shm_cpid; /* pid of creator */ |
| __kernel_pid_t shm_lpid; /* pid of last operator */ |
| unsigned int shm_nattch; /* no. of current attaches */ |
| unsigned int __unused1; |
| unsigned int __unused2; |
| }; |
| |
| #ifdef CONFIG_64BIT |
| /* The 'unsigned int' (formerly 'unsigned long') data types below will |
| * ensure that a 32-bit app calling shmctl(*,IPC_INFO,*) will work on |
| * a wide kernel, but if some of these values are meant to contain pointers |
| * they may need to be 'long long' instead. -PB XXX FIXME |
| */ |
| #endif |
| struct shminfo64 { |
| unsigned int shmmax; |
| unsigned int shmmin; |
| unsigned int shmmni; |
| unsigned int shmseg; |
| unsigned int shmall; |
| unsigned int __unused1; |
| unsigned int __unused2; |
| unsigned int __unused3; |
| unsigned int __unused4; |
| }; |
| |
| #endif /* _PARISC_SHMBUF_H */ |