1 From 7007ef32a959ac4717c19339a24fd90a68638a19 Mon Sep 17 00:00:00 2001
2 From: Andrei Gherzan <andrei@gherzan.ro>
3 Date: Tue, 17 Jul 2012 16:07:17 +0300
4 Subject: [PATCH V3 2/2] storage.c: If there is no d_type support use
7 This is useful for filesystems where d_type is always DT_UNKNOWN.
8 In this case use fstatat() function.
10 Signed-off-by: Andrei Gherzan <andrei.gherzan@windriver.com>
11 Signed-off-by: Constantin Musca <constantinx.musca@intel.com>
12 Upstream-Status: Submitted
15 src/storage.c | 19 +++++++++++++++++++
16 1 file changed, 19 insertions(+)
18 Index: git/src/storage.c
19 ===================================================================
20 --- git.orig/src/storage.c
22 @@ -193,7 +193,6 @@ gchar **connman_storage_get_services()
28 * If the settings file is not found, then
29 * assume this directory is not a services dir.
30 @@ -203,6 +202,25 @@ gchar **connman_storage_get_services()
31 ret = stat(str, &buf);
36 + g_string_append_printf(result, "%s/", d->d_name);
40 + * If there is no d_type support use fstatat()
41 + * to check if directory
43 + ret = fstatat(dirfd(dir), d->d_name, &buf, 0);
46 + if (!(buf.st_mode & S_IFDIR))
48 + str = g_strdup_printf("%s/%s/settings", STORAGEDIR,
50 + ret = stat(str, &buf);
55 g_string_append_printf(result, "%s/", d->d_name);