X-Git-Url: https://git.ucc.asn.au/?a=blobdiff_plain;f=Modules%2FFilesystems%2FInitRD%2Fmain.c;h=e578191550ec35d00dbfd5b1b1166e2a6590ee82;hb=ad2ec62655e1d6eb8f2b4a4684eb5d7952aea0fb;hp=08835bf72d19317e288d6bd07e125f7a3f4b1882;hpb=775bf8013abe9fe4ef3d4883ea2e43bba2a84da1;p=tpg%2Facess2.git diff --git a/Modules/Filesystems/InitRD/main.c b/Modules/Filesystems/InitRD/main.c index 08835bf7..e5781915 100644 --- a/Modules/Filesystems/InitRD/main.c +++ b/Modules/Filesystems/InitRD/main.c @@ -5,16 +5,19 @@ #include "initrd.h" #include +#define DUMP_ON_MOUNT 1 + // === IMPORTS == extern tVFS_Node gInitRD_RootNode; // === PROTOTYPES === int InitRD_Install(char **Arguments); -tVFS_Node *InitRD_InitDevice(char *Device, char **Arguments); +tVFS_Node *InitRD_InitDevice(const char *Device, const char **Arguments); void InitRD_Unmount(tVFS_Node *Node); Uint64 InitRD_ReadFile(tVFS_Node *Node, Uint64 Offset, Uint64 Size, void *Buffer); char *InitRD_ReadDir(tVFS_Node *Node, int ID); -tVFS_Node *InitRD_FindDir(tVFS_Node *Node, char *Name); +tVFS_Node *InitRD_FindDir(tVFS_Node *Node, const char *Name); +void InitRD_DumpDir(tVFS_Node *Node, int Indent); // === GLOBALS === MODULE_DEFINE(0, 0x0A, FS_InitRD, InitRD_Install, NULL); @@ -28,14 +31,18 @@ tVFS_Driver gInitRD_FSInfo = { int InitRD_Install(char **Arguments) { VFS_AddDriver( &gInitRD_FSInfo ); + return MODULE_ERR_OK; } /** * \brief Mount the InitRD */ -tVFS_Node *InitRD_InitDevice(char *Device, char **Arguments) +tVFS_Node *InitRD_InitDevice(const char *Device, const char **Arguments) { + #if DUMP_ON_MOUNT + InitRD_DumpDir( &gInitRD_RootNode, 0 ); + #endif return &gInitRD_RootNode; } @@ -77,7 +84,7 @@ char *InitRD_ReadDir(tVFS_Node *Node, int ID) /** * \brief Find an element in a directory */ -tVFS_Node *InitRD_FindDir(tVFS_Node *Node, char *Name) +tVFS_Node *InitRD_FindDir(tVFS_Node *Node, const char *Name) { int i; tInitRD_File *dir = Node->ImplPtr; @@ -92,3 +99,20 @@ tVFS_Node *InitRD_FindDir(tVFS_Node *Node, char *Name) return NULL; } + +void InitRD_DumpDir(tVFS_Node *Node, int Indent) +{ + int i; + char indent[Indent+1]; + tInitRD_File *dir = Node->ImplPtr; + + for( i = 0; i < Indent; i++ ) indent[i] = ' '; + indent[i] = '\0'; + + for( i = 0; i < Node->Size; i++ ) + { + //Log("%s- %p %s", indent, dir[i].Node, dir[i].Name); + if(dir[i].Node->Flags & VFS_FFLAG_DIRECTORY) + InitRD_DumpDir(dir[i].Node, Indent+1); + } +}