{
size_t i;
- for (i = 0; i < count; i++)
- collect_file_symlink(pc, proc, names[assocs[i]], assocs[i] * -1,
- sockets_only);
+ for (i = 0; i < count; i++) {
+ struct file *f __attribute__((unused))
+ = collect_file_symlink(pc, proc, names[assocs[i]], assocs[i] * -1,
+ sockets_only);
+#if defined(HAVE_STATX) && defined(HAVE_STRUCT_STATX_STX_MNT_ID)
+ if (f && has_mnt_id(f)) {
+ struct statx stx;
+ if (ul_path_statx(pc, &stx, AT_NO_AUTOMOUNT|AT_STATX_DONT_SYNC,
+ STATX_MNT_ID, names[assocs[i]]) == 0)
+ f->mnt_id = stx.stx_mnt_id;
+ }
+#endif /* #if defined(HAVE_STATX) && defined(HAVE_STRUCT_STATX_STX_MNT_ID) */
+ }
}
static void collect_execve_file(struct path_cxt *pc, struct proc *proc,
#define is_opened_file(_f) ((_f)->association >= 0)
#define is_mapped_file(_f) (is_association((_f), SHM) || is_association((_f), MEM))
#define is_association(_f, a) ((_f)->association < 0 && (_f)->association == -ASSOC_ ## a)
-#define has_mnt_id(_f) (is_opened_file(_f) || is_mapped_file(_f))
+#define has_mnt_id(_f) (is_opened_file(_f) || is_mapped_file(_f) \
+ || is_association(_f, EXE) || is_association(_f, CWD) || is_association(_f, ROOT))
struct file_class {
const struct file_class *super;
--- /dev/null
+#!/bin/bash
+#
+# Copyright (C) 2025 Masatake YAMATO <yamato@redhat.com>
+#
+# This file is part of util-linux.
+#
+# This file is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 2 of the License, or
+# (at your option) any later version.
+#
+# This file is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+TS_TOPDIR="${0%/*}/../.."
+TS_DESC="MNTID column"
+
+. "$TS_TOPDIR"/functions.sh
+ts_init "$*"
+ts_skip_docker
+ts_skip_config HAVE_STRUCT_STATX_STX_MNT_ID "cannot get mnt_id via statx(2)"
+
+. "$TS_SELF/lsfd-functions.bash"
+ts_check_test_command "$TS_CMD_LSFD"
+ts_check_test_command "$TS_HELPER_MKFDS"
+ts_check_test_command "$TS_CMD_FINDMNT"
+
+ts_cd "$TS_OUTDIR"
+
+ID_EXE=$("$TS_CMD_FINDMNT" -n -o ID --target "$TS_HELPER_MKFDS" 2>> "$TS_OUTPUT" )
+ID_CWD=$("$TS_CMD_FINDMNT" -n -o ID --target . 2>> "$TS_OUTPUT" )
+ID_RTD=$("$TS_CMD_FINDMNT" -n -o ID --target / 2>> "$TS_OUTPUT" )
+
+{
+ coproc MKFDS { "$TS_HELPER_MKFDS" ro-regular-file 5; }
+
+ if read -u ${MKFDS[0]} PID; then
+ MNTID_EXE=$("$TS_CMD_LSFD" -n -o MNTID -Q 'ASSOC == "exe"' -p "$PID")
+ if [[ "$MNTID_EXE" == "$ID_EXE" ]]; then
+ echo exe:OK
+ else
+ echo exe:ERROR: "MNTID:$MNTID_EXE" != "ID:$ID_EXE"
+ fi
+ MNTID_CWD=$("$TS_CMD_LSFD" -n -o MNTID -Q 'ASSOC == "cwd"' -p "$PID")
+ if [[ "$MNTID_CWD" == "$ID_CWD" ]]; then
+ echo cwd:OK
+ else
+ echo cwd:ERROR: "MNTID:$MNTID_CWD" != "ID:$ID_CWD"
+ fi
+ MNTID_RTD=$("$TS_CMD_LSFD" -n -o MNTID -Q 'ASSOC == "rtd"' -p "$PID")
+ if [[ "$MNTID_RTD" == "$ID_RTD" ]]; then
+ echo rtd:OK
+ else
+ echo rtd:ERROR: "MNTID:$MNTID_RTD" != "ID:$ID_RTD"
+ fi
+ fi
+
+} >> "$TS_OUTPUT" 2>&1
+
+echo DONE >&"${MKFDS[1]}"
+wait "${MKFDS_PID}"
+
+ts_finalize