Accepting request 534218 from Base:System
- Modify patch 0001-Use-mountinfo-to-be-able-to-use-the-mount-identity.patch to run even on older kernels missing mnt_id tag in fdinfo OBS-URL: https://build.opensuse.org/request/show/534218 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/psmisc?expand=0&rev=66
This commit is contained in:
commit
60f2054793
@ -1,4 +1,4 @@
|
|||||||
From 60bbf03a076374e20aa62e1f3297be170403fcb7 Mon Sep 17 00:00:00 2001
|
From c0652a4686d259dabdb3e96498d8dda7cdc9da03 Mon Sep 17 00:00:00 2001
|
||||||
From: Werner Fink <werner@suse.de>
|
From: Werner Fink <werner@suse.de>
|
||||||
Date: Thu, 29 Jun 2017 15:18:28 +0200
|
Date: Thu, 29 Jun 2017 15:18:28 +0200
|
||||||
Subject: [PATCH] Use mountinfo to be able to use the mount identity
|
Subject: [PATCH] Use mountinfo to be able to use the mount identity
|
||||||
@ -14,11 +14,11 @@ get the real mount ID for each file
|
|||||||
Signed-off-by: Werner Fink <werner@suse.de>
|
Signed-off-by: Werner Fink <werner@suse.de>
|
||||||
---
|
---
|
||||||
configure.ac | 18 +-
|
configure.ac | 18 +-
|
||||||
src/fuser.c | 525 +++++++++++++++++++++++++++----------
|
src/fuser.c | 528 +++++++++++++++++++++++++++----------
|
||||||
src/fuser.h | 19 +-
|
src/fuser.h | 19 +-
|
||||||
testsuite/Makefile.am | 3 +-
|
testsuite/Makefile.am | 3 +-
|
||||||
testsuite/killall.test/killall.exp | 4 +
|
testsuite/killall.test/killall.exp | 4 +
|
||||||
5 files changed, 421 insertions(+), 148 deletions(-)
|
5 files changed, 424 insertions(+), 148 deletions(-)
|
||||||
|
|
||||||
diff --git configure.ac configure.ac
|
diff --git configure.ac configure.ac
|
||||||
index 176a2fc..d8d3366 100644
|
index 176a2fc..d8d3366 100644
|
||||||
@ -64,7 +64,7 @@ index 176a2fc..d8d3366 100644
|
|||||||
dnl Checks for typedefs, structures, and compiler characteristics.
|
dnl Checks for typedefs, structures, and compiler characteristics.
|
||||||
AC_C_CONST
|
AC_C_CONST
|
||||||
diff --git src/fuser.c src/fuser.c
|
diff --git src/fuser.c src/fuser.c
|
||||||
index 31ef30c..4ef7cfd 100644
|
index 31ef30c..1c7c496 100644
|
||||||
--- src/fuser.c
|
--- src/fuser.c
|
||||||
+++ src/fuser.c
|
+++ src/fuser.c
|
||||||
@@ -32,6 +32,10 @@
|
@@ -32,6 +32,10 @@
|
||||||
@ -588,7 +588,7 @@ index 31ef30c..4ef7cfd 100644
|
|||||||
{
|
{
|
||||||
list_t *ptr, *tmp;
|
list_t *ptr, *tmp;
|
||||||
|
|
||||||
@@ -2005,72 +2095,229 @@ static void clear_mntinfo(void)
|
@@ -2005,72 +2095,232 @@ static void clear_mntinfo(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -661,12 +661,13 @@ index 31ef30c..4ef7cfd 100644
|
|||||||
+static int
|
+static int
|
||||||
+get_fdinfo(const pid_t pid, const char *fd, struct fdinfo *info)
|
+get_fdinfo(const pid_t pid, const char *fd, struct fdinfo *info)
|
||||||
+{
|
+{
|
||||||
|
+ int ret = 0;
|
||||||
|
+ char pathname[256];
|
||||||
+#if defined(HAS_FDINFO)
|
+#if defined(HAS_FDINFO)
|
||||||
+ const static char delimiters[] = ": \t\n";
|
+ const static char delimiters[] = ": \t\n";
|
||||||
+ char pathname[256];
|
|
||||||
+ char line[BUFSIZ];
|
+ char line[BUFSIZ];
|
||||||
+ FILE *fp;
|
+ FILE *fp;
|
||||||
+ int ret = 0;
|
+ int mnt_id = 0, flags = 0;
|
||||||
+
|
+
|
||||||
+ snprintf(pathname, 256, "/proc/%d/fdinfo/%s", pid, fd);
|
+ snprintf(pathname, 256, "/proc/%d/fdinfo/%s", pid, fd);
|
||||||
+ if ((fp = fopen(pathname, "r")) == NULL)
|
+ if ((fp = fopen(pathname, "r")) == NULL)
|
||||||
@ -682,37 +683,39 @@ index 31ef30c..4ef7cfd 100644
|
|||||||
+ continue;
|
+ continue;
|
||||||
+ if (strcmp(fp, "flags") == 0 && (ul = strtoul(vp, &ep, 0)) != ULONG_MAX && ep && *ep == 0) {
|
+ if (strcmp(fp, "flags") == 0 && (ul = strtoul(vp, &ep, 0)) != ULONG_MAX && ep && *ep == 0) {
|
||||||
+ info->flags = (mode_t)ul;
|
+ info->flags = (mode_t)ul;
|
||||||
|
+ flags++;
|
||||||
+ ret++;
|
+ ret++;
|
||||||
+ }
|
+ }
|
||||||
+ if (strcmp(fp, "mnt_id") == 0 && (ul = strtoul(vp, &ep, 0)) != ULONG_MAX && ep && *ep == 0) {
|
+ if (strcmp(fp, "mnt_id") == 0 && (ul = strtoul(vp, &ep, 0)) != ULONG_MAX && ep && *ep == 0) {
|
||||||
+ info->mnt_id = (int)ul;
|
+ info->mnt_id = (int)ul;
|
||||||
|
+ mnt_id++;
|
||||||
+ ret++;
|
+ ret++;
|
||||||
+ }
|
+ }
|
||||||
+
|
|
||||||
+ }
|
+ }
|
||||||
+ fclose(fp);
|
+ fclose(fp);
|
||||||
+out:
|
+out:
|
||||||
+#else
|
+#endif
|
||||||
+ char pathname[256], *realname;
|
+ if (!flags || !mnt_id) {
|
||||||
+ struct stat lst;
|
+ struct stat lst;
|
||||||
+ int ret = 0;
|
|
||||||
+
|
+
|
||||||
+ snprintf(pathname, 256, "/proc/%d/fd/%s", pid, fd);
|
+ snprintf(pathname, 256, "/proc/%d/fd/%s", pid, fd);
|
||||||
+ if (lstat(pathname, &lst) == 0) {
|
+ if (!flags && lstat(pathname, &lst) == 0) {
|
||||||
+ if (lst.st_mode & S_IWUSR)
|
+ if (lst.st_mode & S_IWUSR)
|
||||||
+ info->flags |= O_WRONLY;
|
+ info->flags |= O_WRONLY;
|
||||||
+ ret++;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ realname = expandpath(pathname);
|
|
||||||
+ if (realname) {
|
|
||||||
+ mntinfo_t *mountinfo;
|
|
||||||
+ if (find_mountpoint(realname, &mountinfo) == 0) {
|
|
||||||
+ info->mnt_id = mountinfo->id;
|
|
||||||
+ ret++;
|
+ ret++;
|
||||||
+ }
|
+ }
|
||||||
|
+
|
||||||
|
+ if (!mnt_id) {
|
||||||
|
+ char *realname = expandpath(pathname);
|
||||||
|
+ if (realname) {
|
||||||
|
+ mntinfo_t *mountinfo;
|
||||||
|
+ if (find_mountpoint(realname, &mountinfo) == 0) {
|
||||||
|
+ info->mnt_id = mountinfo->id;
|
||||||
|
+ ret++;
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
|
+ }
|
||||||
+ }
|
+ }
|
||||||
+#endif
|
|
||||||
+ return ret == 2 ? 0 : -1;
|
+ return ret == 2 ? 0 : -1;
|
||||||
+}
|
+}
|
||||||
+
|
+
|
||||||
@ -742,14 +745,14 @@ index 31ef30c..4ef7cfd 100644
|
|||||||
+ int mnt_id = get_mountid(path);
|
+ int mnt_id = get_mountid(path);
|
||||||
+#endif
|
+#endif
|
||||||
+ int ret = -1;
|
+ int ret = -1;
|
||||||
|
+
|
||||||
|
+ *mountinfo = NULL;
|
||||||
|
|
||||||
- /* Sort mount points accordingly to the reverse mount order */
|
- /* Sort mount points accordingly to the reverse mount order */
|
||||||
- initial(&sort);
|
- initial(&sort);
|
||||||
- for (mid = 1; mid <= max; mid++) {
|
- for (mid = 1; mid <= max; mid++) {
|
||||||
- list_t *ptr, *tmp;
|
- list_t *ptr, *tmp;
|
||||||
- list_for_each_safe(ptr, tmp, &mntinfo) {
|
- list_for_each_safe(ptr, tmp, &mntinfo) {
|
||||||
+ *mountinfo = NULL;
|
|
||||||
+
|
|
||||||
+#if defined(HAS_NAME_TO_HANDLE_AT)
|
+#if defined(HAS_NAME_TO_HANDLE_AT)
|
||||||
+ if (mnt_id >= 0) {
|
+ if (mnt_id >= 0) {
|
||||||
+ list_t *ptr;
|
+ list_t *ptr;
|
||||||
@ -831,12 +834,12 @@ index 31ef30c..4ef7cfd 100644
|
|||||||
- if (mid != mnt->parid)
|
- if (mid != mnt->parid)
|
||||||
+
|
+
|
||||||
+ if (nlen != mnt->nlen)
|
+ if (nlen != mnt->nlen)
|
||||||
+ continue;
|
|
||||||
+
|
|
||||||
+ if (strcmp(use, mnt->mpoint))
|
|
||||||
continue;
|
continue;
|
||||||
- move_head(ptr, &sort);
|
- move_head(ptr, &sort);
|
||||||
+
|
+
|
||||||
|
+ if (strcmp(use, mnt->mpoint))
|
||||||
|
+ continue;
|
||||||
|
+
|
||||||
+ ret = 0;
|
+ ret = 0;
|
||||||
+ errno = 0;
|
+ errno = 0;
|
||||||
+ *mountinfo = mnt;
|
+ *mountinfo = mnt;
|
||||||
@ -862,7 +865,7 @@ index 31ef30c..4ef7cfd 100644
|
|||||||
/*
|
/*
|
||||||
* Determine device of links below /proc/
|
* Determine device of links below /proc/
|
||||||
*/
|
*/
|
||||||
@@ -2078,8 +2325,7 @@ static int mntstat(const char *path, struct stat *buf)
|
@@ -2078,8 +2328,7 @@ static int mntstat(const char *path, struct stat *buf)
|
||||||
{
|
{
|
||||||
char name[PATH_MAX + 1];
|
char name[PATH_MAX + 1];
|
||||||
const char *use;
|
const char *use;
|
||||||
@ -872,7 +875,7 @@ index 31ef30c..4ef7cfd 100644
|
|||||||
|
|
||||||
if ((use = realpath(path, name)) == NULL || *use != '/')
|
if ((use = realpath(path, name)) == NULL || *use != '/')
|
||||||
{
|
{
|
||||||
@@ -2091,27 +2337,26 @@ static int mntstat(const char *path, struct stat *buf)
|
@@ -2091,27 +2340,26 @@ static int mntstat(const char *path, struct stat *buf)
|
||||||
errno = 0;
|
errno = 0;
|
||||||
return stat(path, buf);
|
return stat(path, buf);
|
||||||
}
|
}
|
||||||
|
@ -1,3 +1,9 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Fri Oct 13 07:10:39 UTC 2017 - werner@suse.de
|
||||||
|
|
||||||
|
- Modify patch 0001-Use-mountinfo-to-be-able-to-use-the-mount-identity.patch
|
||||||
|
to run even on older kernels missing mnt_id tag in fdinfo
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Mon Sep 18 10:17:52 UTC 2017 - werner@suse.de
|
Mon Sep 18 10:17:52 UTC 2017 - werner@suse.de
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user