diff options
author | Jo-Philipp Wich <jow@openwrt.org> | 2012-10-19 10:22:11 +0000 |
---|---|---|
committer | Jo-Philipp Wich <jow@openwrt.org> | 2012-10-19 10:22:11 +0000 |
commit | 53c2c3f84dcb19056c8a5c145b56f50b3eef7eab (patch) | |
tree | 00ef3f73d06b48a4ac566838efad875473833f33 /package/libs/sysfsutils/patches | |
parent | 325b9323ae1cfa99b963776c663087c3e35f761f (diff) | |
download | upstream-53c2c3f84dcb19056c8a5c145b56f50b3eef7eab.tar.gz upstream-53c2c3f84dcb19056c8a5c145b56f50b3eef7eab.tar.bz2 upstream-53c2c3f84dcb19056c8a5c145b56f50b3eef7eab.zip |
sysfsutils: move to the correct directory
SVN-Revision: 33856
Diffstat (limited to 'package/libs/sysfsutils/patches')
-rw-r--r-- | package/libs/sysfsutils/patches/200-mnt_path_check.patch | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/package/libs/sysfsutils/patches/200-mnt_path_check.patch b/package/libs/sysfsutils/patches/200-mnt_path_check.patch new file mode 100644 index 0000000000..8710578c5b --- /dev/null +++ b/package/libs/sysfsutils/patches/200-mnt_path_check.patch @@ -0,0 +1,55 @@ +--- a/lib/sysfs_utils.c ++++ b/lib/sysfs_utils.c +@@ -22,6 +22,7 @@ + */ + #include "libsysfs.h" + #include "sysfs.h" ++#include <mntent.h> + + /** + * sysfs_remove_trailing_slash: Removes any trailing '/' in the given path +@@ -53,6 +54,9 @@ int sysfs_get_mnt_path(char *mnt_path, s + { + static char sysfs_path[SYSFS_PATH_MAX] = ""; + const char *sysfs_path_env; ++ FILE *mnt; ++ struct mntent *mntent; ++ int ret; + + if (len == 0 || mnt_path == NULL) + return -1; +@@ -64,12 +68,31 @@ int sysfs_get_mnt_path(char *mnt_path, s + if (sysfs_path_env != NULL) { + safestrcpymax(mnt_path, sysfs_path_env, len); + sysfs_remove_trailing_slash(mnt_path); +- return 0; ++ } else { ++ safestrcpymax(mnt_path, SYSFS_MNT_PATH, len); + } +- safestrcpymax(mnt_path, SYSFS_MNT_PATH, len); + } + +- return 0; ++ /* check that mount point is indeed mounted */ ++ ret = -1; ++ if ((mnt = setmntent(SYSFS_PROC_MNTS, "r")) == NULL) { ++ dprintf("Error getting mount information\n"); ++ return -1; ++ } ++ while ((mntent = getmntent(mnt)) != NULL) { ++ if (strcmp(mntent->mnt_type, SYSFS_FSTYPE_NAME) == 0 && ++ strcmp(mntent->mnt_dir, mnt_path) == 0) { ++ ret = 0; ++ break; ++ } ++ } ++ ++ endmntent(mnt); ++ ++ if (ret < 0) ++ errno = ENOENT; ++ ++ return ret; + } + + /** |