diff options
Diffstat (limited to 'tools/iso/kernel.soso/devfs.c')
-rw-r--r-- | tools/iso/kernel.soso/devfs.c | 132 |
1 files changed, 0 insertions, 132 deletions
diff --git a/tools/iso/kernel.soso/devfs.c b/tools/iso/kernel.soso/devfs.c deleted file mode 100644 index bfff39cb..00000000 --- a/tools/iso/kernel.soso/devfs.c +++ /dev/null @@ -1,132 +0,0 @@ -#include "devfs.h" -#include "common.h" -#include "fs.h" -#include "alloc.h" -#include "device.h" -#include "screen.h" -#include "list.h" -#include "spinlock.h" - -static FileSystemNode* gDevRoot = NULL; - -static List* gDeviceList = NULL; -static Spinlock gDeviceListLock; - -static BOOL devfs_open(File *node, uint32 flags); -static FileSystemDirent *devfs_readdir(FileSystemNode *node, uint32 index); -static FileSystemNode *devfs_finddir(FileSystemNode *node, char *name); - -static FileSystemDirent gDirent; - -void initializeDevFS() { - gDevRoot = kmalloc(sizeof(FileSystemNode)); - memset((uint8*)gDevRoot, 0, sizeof(FileSystemNode)); - - gDevRoot->nodeType = FT_Directory; - - FileSystemNode* rootFs = getFileSystemRootNode(); - - FileSystemNode* devNode = finddir_fs(rootFs, "dev"); - - if (devNode) { - devNode->nodeType |= FT_MountPoint; - devNode->mountPoint = gDevRoot; - gDevRoot->parent = devNode->parent; - strcpy(gDevRoot->name, devNode->name); - } - else { - PANIC("/dev does not exist!"); - } - - gDevRoot->open = devfs_open; - gDevRoot->finddir = devfs_finddir; - gDevRoot->readdir = devfs_readdir; - - gDeviceList = List_Create(); - Spinlock_Init(&gDeviceListLock); -} - -static BOOL devfs_open(File *node, uint32 flags) { - return TRUE; -} - -static FileSystemDirent *devfs_readdir(FileSystemNode *node, uint32 index) { - FileSystemDirent * result = NULL; - - uint32 counter = 0; - - Spinlock_Lock(&gDeviceListLock); - - List_Foreach(n, gDeviceList) { - if (index == counter) { - FileSystemNode* deviceNode = (FileSystemNode*)n->data; - strcpy(gDirent.name, deviceNode->name); - gDirent.fileType = deviceNode->nodeType; - gDirent.inode = index; - result = &gDirent; - break; - } - - ++counter; - } - Spinlock_Unlock(&gDeviceListLock); - - return result; -} - -static FileSystemNode *devfs_finddir(FileSystemNode *node, char *name) { - FileSystemNode* result = NULL; - - - Spinlock_Lock(&gDeviceListLock); - - List_Foreach(n, gDeviceList) { - FileSystemNode* deviceNode = (FileSystemNode*)n->data; - - if (strcmp(name, deviceNode->name) == 0) { - result = deviceNode; - break; - } - } - - Spinlock_Unlock(&gDeviceListLock); - - return result; -} - -FileSystemNode* registerDevice(Device* device) { - Spinlock_Lock(&gDeviceListLock); - - List_Foreach(n, gDeviceList) { - FileSystemNode* deviceNode = (FileSystemNode*)n->data; - - if (strcmp(device->name, deviceNode->name) == 0) { - //There is already a device with the same name - Spinlock_Unlock(&gDeviceListLock); - return NULL; - } - } - - FileSystemNode* deviceNode = (FileSystemNode*)kmalloc(sizeof(FileSystemNode)); - memset((uint8*)deviceNode, 0, sizeof(FileSystemNode)); - strcpy(deviceNode->name, device->name); - deviceNode->nodeType = device->deviceType; - deviceNode->open = device->open; - deviceNode->close = device->close; - deviceNode->readBlock = device->readBlock; - deviceNode->writeBlock = device->writeBlock; - deviceNode->read = device->read; - deviceNode->write = device->write; - deviceNode->ioctl = device->ioctl; - deviceNode->ftruncate = device->ftruncate; - deviceNode->mmap = device->mmap; - deviceNode->munmap = device->munmap; - deviceNode->privateNodeData = device->privateData; - deviceNode->parent = gDevRoot; - - List_Append(gDeviceList, deviceNode); - - Spinlock_Unlock(&gDeviceListLock); - - return deviceNode; -} |