From 301909fbcb5314e7968824f69635387c50e53dbc Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Fri, 9 Jun 2000 17:34:27 +0000 Subject: Update. 2000-06-09 Ulrich Drepper * sysdeps/unix/sysv/linux/shm_open.c (where_is_shmfs): Try harder to find correct mount point despite wrong information from the kernel. --- sysdeps/unix/sysv/linux/shm_open.c | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) (limited to 'sysdeps/unix/sysv') diff --git a/sysdeps/unix/sysv/linux/shm_open.c b/sysdeps/unix/sysv/linux/shm_open.c index 0cf7f5e0b3..271b92db61 100644 --- a/sysdeps/unix/sysv/linux/shm_open.c +++ b/sysdeps/unix/sysv/linux/shm_open.c @@ -38,7 +38,7 @@ static struct } mountpoint; /* This is the default directory. */ -const char defaultdir[] = "/dev/shm/"; +static const char defaultdir[] = "/dev/shm/"; /* Protect the `mountpoint' variable above. */ __libc_once_define (static, once); @@ -82,7 +82,15 @@ where_is_shmfs (void) { /* Found it. There might be more than one place where the filesystem is mounted but one is enough for us. */ - size_t namelen = strlen (mp->mnt_dir); + size_t namelen; + + /* First make sure this really is the correct entry. At least + some versions of the kernel give wrong information because + of the implicit mount of the shmfs for SysV IPC. */ + if (__statfs (mp->mnt_dir, &f) != 0 || f.f_type != SHMFS_SUPER_MAGIC) + continue; + + namelen = strlen (mp->mnt_dir); if (namelen == 0) /* Hum, maybe some crippled entry. Keep on searching. */ -- cgit 1.4.1