@@ -507,28 +507,18 @@ done:
return zone;
}
-static int write_file(void *src_map, struct stat *src_st, const char *pathname)
+static int write_symlink(const char *target, const char *link)
{
struct stat st;
- int fd;
- ssize_t written;
- DBG("pathname %s", pathname);
+ DBG("pathname %s", link);
- if (lstat(pathname, &st) == 0) {
- if (S_ISLNK(st.st_mode))
- unlink(pathname);
+ if (lstat(link, &st) == 0) {
+ if (S_ISLNK(st.st_mode) || S_ISREG(st.st_mode))
+ unlink(link);
}
- fd = open(pathname, O_WRONLY | O_CREAT | O_TRUNC | O_CLOEXEC, 0644);
- if (fd < 0)
- return -EIO;
-
- written = write(fd, src_map, src_st->st_size);
-
- close(fd);
-
- if (written < 0)
+ if (symlink(target, link) < 0)
return -EIO;
return 0;
@@ -537,35 +527,17 @@ static int write_file(void *src_map, struct stat *src_st, const char *pathname)
int __connman_timezone_change(const char *zone)
{
struct stat st;
- char *map, pathname[PATH_MAX];
- int fd, err;
+ g_autofree char *pathname = NULL;
+ int err;
DBG("zone %s", zone);
- snprintf(pathname, PATH_MAX, "%s/%s", USR_SHARE_ZONEINFO, zone);
+ pathname = g_strdup_printf("%s/%s", USR_SHARE_ZONEINFO, zone);
- fd = open(pathname, O_RDONLY | O_CLOEXEC);
- if (fd < 0)
+ if (stat(pathname, &st) < 0 || !S_ISREG(st.st_mode))
return -EINVAL;
- if (fstat(fd, &st) < 0) {
- close(fd);
- return -EIO;
- }
-
- map = mmap(0, st.st_size, PROT_READ, MAP_SHARED, fd, 0);
- if (!map || map == MAP_FAILED) {
- close(fd);
- return -EIO;
- }
-
- err = write_file(map, &st, connman_setting_get_string("Localtime"));
-
- munmap(map, st.st_size);
-
- close(fd);
-
- return err;
+ return write_symlink(pathname, connman_setting_get_string("Localtime"));
}
static guint inotify_watch = 0;
--
2.34.1
---------------------------------------------------------------
andrea.ricchi@amarulasolutions.com
User - 05/06/2025 09:04
This reverts commit f20ccd19a62bd01aa117bfc8e7c388d2a16cde05.
`compare_file` is intended to work with symlinks, enabling
full and accurate matching between the requested timezone and the zoneinfo
database.
---
src/timezone.c | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
@@ -124,8 +124,8 @@ static int compare_file(void *src_map, struct stat *src_st,
DBG("real path %s path name %s", real_path, pathname);
- if (real_path && !g_strcmp0(real_path, pathname))
- return 0;
+ if (real_path && g_strcmp0(real_path, pathname))
+ return -1;
fd = open(pathname, O_RDONLY | O_CLOEXEC);
if (fd < 0)