zero.c 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. /* vim: tabstop=4 shiftwidth=4 noexpandtab
  2. * This file is part of ToaruOS and is released under the terms
  3. * of the NCSA / University of Illinois License - see LICENSE.md
  4. * Copyright (C) 2014-2018 K. Lange
  5. *
  6. * Null Device
  7. *
  8. */
  9. #include <kernel/system.h>
  10. #include <kernel/fs.h>
  11. #include <kernel/module.h>
  12. static uint32_t read_null(fs_node_t *node, uint32_t offset, uint32_t size, uint8_t *buffer);
  13. static uint32_t write_null(fs_node_t *node, uint32_t offset, uint32_t size, uint8_t *buffer);
  14. static void open_null(fs_node_t *node, unsigned int flags);
  15. static void close_null(fs_node_t *node);
  16. static uint32_t read_zero(fs_node_t *node, uint32_t offset, uint32_t size, uint8_t *buffer);
  17. static uint32_t write_zero(fs_node_t *node, uint32_t offset, uint32_t size, uint8_t *buffer);
  18. static void open_zero(fs_node_t *node, unsigned int flags);
  19. static void close_zero(fs_node_t *node);
  20. static uint32_t read_null(fs_node_t *node, uint32_t offset, uint32_t size, uint8_t *buffer) {
  21. return 0;
  22. }
  23. static uint32_t write_null(fs_node_t *node, uint32_t offset, uint32_t size, uint8_t *buffer) {
  24. return 0;
  25. }
  26. static void open_null(fs_node_t * node, unsigned int flags) {
  27. return;
  28. }
  29. static void close_null(fs_node_t * node) {
  30. return;
  31. }
  32. static uint32_t read_zero(fs_node_t *node, uint32_t offset, uint32_t size, uint8_t *buffer) {
  33. memset(buffer, 0x00, size);
  34. return 1;
  35. }
  36. static uint32_t write_zero(fs_node_t *node, uint32_t offset, uint32_t size, uint8_t *buffer) {
  37. return 0;
  38. }
  39. static void open_zero(fs_node_t * node, unsigned int flags) {
  40. return;
  41. }
  42. static void close_zero(fs_node_t * node) {
  43. return;
  44. }
  45. static fs_node_t * null_device_create(void) {
  46. fs_node_t * fnode = malloc(sizeof(fs_node_t));
  47. memset(fnode, 0x00, sizeof(fs_node_t));
  48. fnode->inode = 0;
  49. strcpy(fnode->name, "null");
  50. fnode->uid = 0;
  51. fnode->gid = 0;
  52. fnode->mask = 0666;
  53. fnode->flags = FS_CHARDEVICE;
  54. fnode->read = read_null;
  55. fnode->write = write_null;
  56. fnode->open = open_null;
  57. fnode->close = close_null;
  58. fnode->readdir = NULL;
  59. fnode->finddir = NULL;
  60. fnode->ioctl = NULL;
  61. return fnode;
  62. }
  63. static fs_node_t * zero_device_create(void) {
  64. fs_node_t * fnode = malloc(sizeof(fs_node_t));
  65. memset(fnode, 0x00, sizeof(fs_node_t));
  66. fnode->inode = 0;
  67. strcpy(fnode->name, "zero");
  68. fnode->uid = 0;
  69. fnode->gid = 0;
  70. fnode->mask = 0666;
  71. fnode->flags = FS_CHARDEVICE;
  72. fnode->read = read_zero;
  73. fnode->write = write_zero;
  74. fnode->open = open_zero;
  75. fnode->close = close_zero;
  76. fnode->readdir = NULL;
  77. fnode->finddir = NULL;
  78. fnode->ioctl = NULL;
  79. return fnode;
  80. }
  81. static int zero_initialize(void) {
  82. vfs_mount("/dev/null", null_device_create());
  83. vfs_mount("/dev/zero", zero_device_create());
  84. return 0;
  85. }
  86. static int zero_finalize(void) {
  87. return 0;
  88. }
  89. MODULE_DEF(zero, zero_initialize, zero_finalize);