Skip to content

Commit

Permalink
Fix humongous bug with fdopendir on mac
Browse files Browse the repository at this point in the history
https://opensource.apple.com/source/Libc/Libc-1244.1.7/include/dirent.h.auto.html

ccall picks the wrong one, causes crashes and truncated d_name
entries. Wrapping the function in a small C shim, as well as
using the CAPI, fixes this.
  • Loading branch information
hasufell committed Apr 14, 2020
1 parent 06b5a46 commit 74d6865
Show file tree
Hide file tree
Showing 3 changed files with 11 additions and 4 deletions.
2 changes: 1 addition & 1 deletion hpath-posix/cbits/dirutils.c
@@ -1,7 +1,7 @@
#include "dirutils.h"

unsigned int
__posixdir_d_type(struct dirent* d)
{
return(d -> d_type);
}

2 changes: 2 additions & 0 deletions hpath-posix/cbits/dirutils.h
Expand Up @@ -7,7 +7,9 @@
#include <sys/stat.h>
#include <fcntl.h>


extern unsigned int
__posixdir_d_type(struct dirent* d)
;

#endif
11 changes: 8 additions & 3 deletions hpath-posix/src/System/Posix/RawFilePath/Directory/Traversals.hs
Expand Up @@ -10,6 +10,7 @@
-- Traversal and read operations on directories.


{-# LANGUAGE CApiFFI #-}
{-# LANGUAGE CPP #-}
{-# LANGUAGE ForeignFunctionInterface #-}
{-# LANGUAGE OverloadedStrings #-}
Expand Down Expand Up @@ -173,11 +174,15 @@ foreign import ccall unsafe "__hscore_d_name"
foreign import ccall unsafe "__posixdir_d_type"
c_type :: Ptr CDirent -> IO DirType

foreign import ccall "realpath"
foreign import capi "stdlib.h realpath"
c_realpath :: CString -> CString -> IO CString

foreign import ccall unsafe "fdopendir"
c_fdopendir :: Posix.Fd -> IO (Ptr ())
-- Using normal 'ccall' here lead to memory bugs, crashes
-- and corrupted d_name entries. It appears there are two fdopendirs:
-- https://opensource.apple.com/source/Libc/Libc-1244.1.7/include/dirent.h.auto.html
-- The capi call picks the correct one.
foreign import capi unsafe "dirent.h fdopendir"
c_fdopendir :: Posix.Fd -> IO (Ptr CDir)

----------------------------------------------------------
-- less dodgy but still lower-level
Expand Down

0 comments on commit 74d6865

Please sign in to comment.