X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fmisc%2Frealpath.c;h=4cc7e7debe281c11b6979e3f3bbaec73a4803a59;hb=6739b13a172aad9c01572c04cadacc99c7041811;hp=5756817943c208c66723f375c606451e7fe400f1;hpb=400c5e5c8307a2ebe44ef1f203f5a15669f20347;p=musl diff --git a/src/misc/realpath.c b/src/misc/realpath.c index 57568179..4cc7e7de 100644 --- a/src/misc/realpath.c +++ b/src/misc/realpath.c @@ -1,10 +1,13 @@ #include -#include #include #include #include #include #include +#include +#include "syscall.h" + +void __procfdname(char *, unsigned); char *realpath(const char *restrict filename, char *restrict resolved) { @@ -12,38 +15,31 @@ char *realpath(const char *restrict filename, char *restrict resolved) ssize_t r; struct stat st1, st2; char buf[15+3*sizeof(int)]; - int alloc = 0; + char tmp[PATH_MAX]; if (!filename) { errno = EINVAL; return 0; } - fd = open(filename, O_RDONLY|O_NONBLOCK); + fd = syscall(SYS_open, filename, O_PATH|O_NONBLOCK|O_CLOEXEC|O_LARGEFILE); if (fd < 0) return 0; - snprintf(buf, sizeof buf, "/proc/self/fd/%d", fd); - - if (!resolved) { - alloc = 1; - resolved = malloc(PATH_MAX); - if (!resolved) return 0; - } + __procfdname(buf, fd); - r = readlink(buf, resolved, PATH_MAX-1); + r = readlink(buf, tmp, sizeof tmp - 1); if (r < 0) goto err; - resolved[r] = 0; + tmp[r] = 0; fstat(fd, &st1); - r = stat(resolved, &st2); + r = stat(tmp, &st2); if (r<0 || st1.st_dev != st2.st_dev || st1.st_ino != st2.st_ino) { if (!r) errno = ELOOP; goto err; } - close(fd); - return resolved; + __syscall(SYS_close, fd); + return resolved ? strcpy(resolved, tmp) : strdup(tmp); err: - if (alloc) free(resolved); - close(fd); + __syscall(SYS_close, fd); return 0; }