git://scm.lunaixsky.com
/
lunaix-os.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
regression: mmap for fd
[lunaix-os.git]
/
lunaix-os
/
kernel
/
demos
/
dir_read.c
diff --git
a/lunaix-os/kernel/demos/dir_read.c
b/lunaix-os/kernel/demos/dir_read.c
index 8c4a34407fc9a0efc95f4af426e4802d3f8c951f..70070a1eafe3753413a5691e119d3f0f381b4689 100644
(file)
--- a/
lunaix-os/kernel/demos/dir_read.c
+++ b/
lunaix-os/kernel/demos/dir_read.c
@@
-1,22
+1,30
@@
#include <lunaix/dirent.h>
#include <lunaix/fctrl.h>
#include <lunaix/dirent.h>
#include <lunaix/fctrl.h>
-#include <lunaix/syslog.h>
-
-LOG_MODULE("RDDIR")
+#include <lunaix/lunaix.h>
+#include <lunaix/lunistd.h>
void
_readdir_main()
{
void
_readdir_main()
{
- int fd = open("/
bus/../.
.", 0);
+ int fd = open("/
dev/./../dev/
.", 0);
if (fd == -1) {
if (fd == -1) {
-
kprintf(KERROR "fail to open\n"
);
+
printf("fail to open (%d)\n", geterrno()
);
return;
}
return;
}
+ char path[129];
+ int len = realpathat(fd, path, 128);
+ if (len < 0) {
+ printf("fail to read (%d)\n", geterrno());
+ } else {
+ path[len] = 0;
+ printf("%s\n", path);
+ }
+
struct dirent ent = { .d_offset = 0 };
struct dirent ent = { .d_offset = 0 };
- while (
!readdir(fd, &ent)
) {
-
kprintf(KINFO
"%s\n", ent.d_name);
+ while (
sys_readdir(fd, &ent) == 1
) {
+
printf(
"%s\n", ent.d_name);
}
close(fd);
}
close(fd);