* dirent.c: Fix `struct dirent' overflow on Solaris. See #82678.
[mono.git] / support / dirent.c
index ae13bf2ea529bd4a9dfbe053221d5c2712b5a75b..50d2f64a8443bd31700edf70fa912262969549ef 100644 (file)
@@ -11,6 +11,7 @@
 #include <errno.h>
 #include <string.h>
 #include <stdlib.h>
+#include <limits.h>
 #include <unistd.h>
 
 #include "map.h"
@@ -23,11 +24,9 @@ Mono_Posix_Syscall_seekdir (void *dir, mph_off_t offset)
 {
        mph_return_if_off_t_overflow (offset);
 
-       errno = 0;
-
        seekdir ((DIR*) dir, (off_t) offset);
 
-       return errno != 0;
+       return 0;
 }
 
 mph_off_t
@@ -79,24 +78,26 @@ Mono_Posix_Syscall_readdir (void *dirp, struct Mono_Posix_Syscall__Dirent *entry
 gint32
 Mono_Posix_Syscall_readdir_r (void *dirp, struct Mono_Posix_Syscall__Dirent *entry, void **result)
 {
-       struct dirent _entry;
+       struct dirent *_entry = malloc(sizeof(struct dirent) + 
+                       MAX(PATH_MAX, NAME_MAX) + 1);
        int r;
 
-       r = readdir_r (dirp, &_entry, (struct dirent**) result);
+       r = readdir_r (dirp, _entry, (struct dirent**) result);
 
-       if (r == 0 && result != NULL) {
-               copy_dirent (entry, &_entry);
+       if (r == 0 && *result != NULL) {
+               copy_dirent (entry, _entry);
        }
 
+       free (_entry);
+
        return r;
 }
 
 int
 Mono_Posix_Syscall_rewinddir (void* dir)
 {
-       errno = 0;
        rewinddir (dir);
-       return errno == 0 ? 0 : -1;
+       return 0;
 }
 
 G_END_DECLS