projects
/
oweals
/
musl.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
x32: remove arch-specific syscall remapping
[oweals/musl.git]
/
src
/
dirent
/
readdir.c
diff --git
a/src/dirent/readdir.c
b/src/dirent/readdir.c
index 98ec029e6b983bb9de2d3a86d2cf296dac5dd325..2cf0632c207ef2547d6dfe8b67ed23783cf151d4 100644
(file)
--- a/
src/dirent/readdir.c
+++ b/
src/dirent/readdir.c
@@
-1,5
+1,7
@@
#include <dirent.h>
#include <dirent.h>
+#include <errno.h>
#include "__dirent.h"
#include "__dirent.h"
+#include "syscall.h"
#include "libc.h"
int __getdents(int, struct dirent *, size_t);
#include "libc.h"
int __getdents(int, struct dirent *, size_t);
@@
-9,8
+11,11
@@
struct dirent *readdir(DIR *dir)
struct dirent *de;
if (dir->buf_pos >= dir->buf_end) {
struct dirent *de;
if (dir->buf_pos >= dir->buf_end) {
- int len = __getdents(dir->fd, (void *)dir->buf, sizeof dir->buf);
- if (len <= 0) return 0;
+ int len = __syscall(SYS_getdents, dir->fd, dir->buf, sizeof dir->buf);
+ if (len <= 0) {
+ if (len < 0 && len != -ENOENT) errno = -len;
+ return 0;
+ }
dir->buf_end = len;
dir->buf_pos = 0;
}
dir->buf_end = len;
dir->buf_pos = 0;
}