summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2019-12-22 12:37:16 -0500
committerRich Felker <dalias@aerifal.cx>2019-12-22 12:37:16 -0500
commit1e7f0fcd7ff2096904fd93a2ee6d12a2392be392 (patch)
tree71bcdc753853d22268ca7472ab7dabcbde4abeb0
parent3f959f6f76f16b7d954a6d8a134f3c30228d3be0 (diff)
downloadmusl-1e7f0fcd7ff2096904fd93a2ee6d12a2392be392.tar.gz
musl-1e7f0fcd7ff2096904fd93a2ee6d12a2392be392.tar.bz2
musl-1e7f0fcd7ff2096904fd93a2ee6d12a2392be392.tar.xz
musl-1e7f0fcd7ff2096904fd93a2ee6d12a2392be392.zip
adjust utmpx struct layout for time64, 32-/64-bit arch compat
since time64 switchover has changed the size and layout of the struct anyway, take the opportunity to fix it up so that it can be shared between 32- and 64-bit ABIs on the same system as long as byte order matches. the ut_type member is explicitly padded to make up for m68k having only 2-byte alignment; explicit padding has no effect on other archs. ut_session is changed from long to int, with endian-matched padding. this affects 64-bit archs as well, but brings the type into alignment with glibc's x86_64 struct, so it should not break software, and does not break on-disk format. the semantic type is int (pid-like) anyway. the padding produces correct alignment for the ut_tv member on 32-bit archs that don't naturally align it, so that ABI matches 64-bit. this type is presently not used anywhere in the ABI between libc and libc consumers; it's only used between pairs of consumers if a third-party utmp library using the system utmpx.h is in use.
-rw-r--r--include/utmpx.h7
1 files changed, 6 insertions, 1 deletions
diff --git a/include/utmpx.h b/include/utmpx.h
index 0429014d..b293f427 100644
--- a/include/utmpx.h
+++ b/include/utmpx.h
@@ -16,6 +16,7 @@ extern "C" {
struct utmpx {
short ut_type;
+ short __ut_pad1;
pid_t ut_pid;
char ut_line[32];
char ut_id[4];
@@ -25,7 +26,11 @@ struct utmpx {
short __e_termination;
short __e_exit;
} ut_exit;
- long ut_session;
+#if __BYTE_ORDER == 1234
+ int ut_session, __ut_pad2;
+#else
+ int __ut_pad2, ut_session;
+#endif
struct timeval ut_tv;
unsigned ut_addr_v6[4];
char __unused[20];