summaryrefslogtreecommitdiffstats
path: root/src/basic/selinux-util.c
diff options
context:
space:
mode:
authorZbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>2020-10-09 16:48:03 +0200
committerLennart Poettering <lennart@poettering.net>2020-10-12 15:51:39 +0200
commit4b6f74f5a0943e0abfa8e6997811f8f7b7f00a15 (patch)
treec0d7486eb957a2e22137e7794b83568152a38947 /src/basic/selinux-util.c
parentupdate TODO (diff)
downloadsystemd-4b6f74f5a0943e0abfa8e6997811f8f7b7f00a15.tar.xz
systemd-4b6f74f5a0943e0abfa8e6997811f8f7b7f00a15.zip
basic/selinux: work around mallinfo deprecation
Latest glibc has deprecated mallinfo(), so it might become unavailable at some point in the future. There is malloc_info(), but it returns XML, ffs. I think the information that we get from mallinfo() is quite useful, so let's use mallinfo() if available, and not otherwise.
Diffstat (limited to '')
-rw-r--r--src/basic/selinux-util.c30
1 files changed, 22 insertions, 8 deletions
diff --git a/src/basic/selinux-util.c b/src/basic/selinux-util.c
index 41913fc655..1791aeecde 100644
--- a/src/basic/selinux-util.c
+++ b/src/basic/selinux-util.c
@@ -84,14 +84,25 @@ void mac_selinux_retest(void) {
}
#if HAVE_SELINUX
+# if HAVE_MALLINFO
+static struct mallinfo mallinfo_nowarn(void) {
+ /* glibc has deprecated mallinfo(), but the replacement malloc_info() returns an XML blob ;=[ */
+DISABLE_WARNING_DEPRECATED_DECLARATIONS
+ return mallinfo();
+REENABLE_WARNING
+}
+# else
+# warning "mallinfo() is missing, add mallinfo2() supported instead."
+# endif
+
static int open_label_db(void) {
struct selabel_handle *hnd;
usec_t before_timestamp, after_timestamp;
- struct mallinfo before_mallinfo, after_mallinfo;
char timespan[FORMAT_TIMESPAN_MAX];
- int l;
- before_mallinfo = mallinfo();
+# if HAVE_MALLINFO
+ struct mallinfo before_mallinfo = mallinfo_nowarn();
+# endif
before_timestamp = now(CLOCK_MONOTONIC);
hnd = selabel_open(SELABEL_CTX_FILE, NULL, 0);
@@ -99,13 +110,16 @@ static int open_label_db(void) {
return log_enforcing_errno(errno, "Failed to initialize SELinux labeling handle: %m");
after_timestamp = now(CLOCK_MONOTONIC);
- after_mallinfo = mallinfo();
-
- l = after_mallinfo.uordblks > before_mallinfo.uordblks ? after_mallinfo.uordblks - before_mallinfo.uordblks : 0;
-
+# if HAVE_MALLINFO
+ struct mallinfo after_mallinfo = mallinfo_nowarn();
+ int l = after_mallinfo.uordblks > before_mallinfo.uordblks ? after_mallinfo.uordblks - before_mallinfo.uordblks : 0;
log_debug("Successfully loaded SELinux database in %s, size on heap is %iK.",
format_timespan(timespan, sizeof(timespan), after_timestamp - before_timestamp, 0),
- (l+1023)/1024);
+ DIV_ROUND_UP(l, 1024));
+# else
+ log_debug("Successfully loaded SELinux database in %s.",
+ format_timespan(timespan, sizeof(timespan), after_timestamp - before_timestamp, 0));
+# endif
/* release memory after measurement */
if (label_hnd)