Skip to content

Commit

Permalink
Merge pull request #109 from Galfurian/develop
Browse files Browse the repository at this point in the history
Develop
  • Loading branch information
Galfurian authored Oct 4, 2024
2 parents be63f2a + 2afbe60 commit e24709d
Show file tree
Hide file tree
Showing 37 changed files with 1,742 additions and 718 deletions.
12 changes: 8 additions & 4 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -78,20 +78,24 @@ Follows the list of implemented features:
**Filesystem**
- [x] Virtual Filesystem (VFS);
- [x] Initramfs;
- [x] EXT2;
- [x] Second Extended File System (EXT2);
- [x] Procfs;

**Input/Output**
- [x] Programmable Interrupt Controller (PIC) drivers;
- [x] PS/2 drivers;
- [x] Advanced Technology Attachment (ATA) drivers;
- [x] Real Time Clock (RTC) drivers;
- [x] Keyboard drivers (IT/ENG layouts);
- [x] Video drivers;
- [ ] VGA drivers;

**Inter-Process Communication (IPC)**
- [X] Semaphore
- [ ] Message queue
- [ ] Shared memory
- [ ] Named pipe
- [X] Message queue
- [X] Shared memory
- [ ] PIPE
- [ ] Named PIPE

I will try to keep it updated...

Expand Down
3 changes: 3 additions & 0 deletions doc/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -105,6 +105,7 @@ if (DOXYGEN_FOUND)
${CMAKE_SOURCE_DIR}/mentos/inc/version.h

${CMAKE_SOURCE_DIR}/mentos/src/boot.c
${CMAKE_SOURCE_DIR}/mentos/src/crypt/sha256.c
${CMAKE_SOURCE_DIR}/mentos/src/descriptor_tables/exception.c
${CMAKE_SOURCE_DIR}/mentos/src/descriptor_tables/gdt.c
${CMAKE_SOURCE_DIR}/mentos/src/descriptor_tables/idt.c
Expand Down Expand Up @@ -193,6 +194,7 @@ if (DOXYGEN_FOUND)
${CMAKE_SOURCE_DIR}/libc/inc/bits/ioctls.h
${CMAKE_SOURCE_DIR}/libc/inc/bits/stat.h
${CMAKE_SOURCE_DIR}/libc/inc/bits/termios-struct.h
${CMAKE_SOURCE_DIR}/libc/inc/crypt/sha256.h
${CMAKE_SOURCE_DIR}/libc/inc/ctype.h
${CMAKE_SOURCE_DIR}/libc/inc/fcntl.h
${CMAKE_SOURCE_DIR}/libc/inc/fcvt.h
Expand Down Expand Up @@ -259,6 +261,7 @@ if (DOXYGEN_FOUND)
${CMAKE_SOURCE_DIR}/libc/src/sys/utsname.c
${CMAKE_SOURCE_DIR}/libc/src/termios.c
${CMAKE_SOURCE_DIR}/libc/src/time.c
${CMAKE_SOURCE_DIR}/libc/src/crypt/sha256.c
${CMAKE_SOURCE_DIR}/libc/src/unistd/chdir.c
${CMAKE_SOURCE_DIR}/libc/src/unistd/close.c
${CMAKE_SOURCE_DIR}/libc/src/unistd/creat.c
Expand Down
32 changes: 25 additions & 7 deletions libc/inc/crypt/sha256.h
Original file line number Diff line number Diff line change
@@ -1,9 +1,8 @@
/// @file sha256.c
/// @author Enrico Fraccaroli ([email protected])
/// @file sha256.h
/// @brief Implementation of the SHA-256 hashing algorithm.
/// @details The original code was written by Brad Conte, and is available at:
/// https://github.com/B-Con/crypto-algorithms
///
///
/// SHA-256 is one of the three algorithms in the SHA2
/// specification. The others, SHA-384 and SHA-512, are not
/// offered in this implementation.
Expand All @@ -19,14 +18,33 @@
/// @brief SHA256 outputs a 32 byte digest.
#define SHA256_BLOCK_SIZE 32

/// @brief Structure that holds context information for SHA-256 operations.
typedef struct {
uint8_t data[64];
uint32_t datalen;
unsigned long long bitlen;
uint32_t state[8];
uint8_t data[64]; ///< Input data block being processed (512 bits / 64 bytes).
uint32_t datalen; ///< Length of the current data in the buffer (in bytes).
unsigned long long bitlen; ///< Total length of the input in bits (for padding).
uint32_t state[8]; ///< Current hash state (256 bits / 8 * 32-bit words).
} SHA256_ctx_t;

/// @brief Initializes the SHA-256 context.
/// @param ctx Pointer to the SHA-256 context to initialize.
void sha256_init(SHA256_ctx_t *ctx);

/// @brief Adds data to the SHA-256 context for hashing.
/// @param ctx Pointer to the SHA-256 context.
/// @param data Pointer to the data to be hashed.
/// @param len Length of the data to hash, in bytes.
void sha256_update(SHA256_ctx_t *ctx, const uint8_t data[], size_t len);

/// @brief Finalizes the hashing and produces the final SHA-256 digest.
/// @param ctx Pointer to the SHA-256 context.
/// @param hash Pointer to a buffer where the final hash will be stored (must be at least 32 bytes long).
void sha256_final(SHA256_ctx_t *ctx, uint8_t hash[]);

/// @brief Converts a byte array to its hexadecimal string representation.
/// @param src Pointer to the source byte array.
/// @param src_length Length of the source byte array.
/// @param out Pointer to the output buffer for the hexadecimal string.
/// @param out_length Length of the output buffer (must be at least 2 * src_length + 1).
/// @details The output string will be null-terminated if the buffer is large enough.
void sha256_bytes_to_hex(uint8_t *src, size_t src_length, char *out, size_t out_length);
14 changes: 8 additions & 6 deletions libc/inc/readline.h
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,12 @@

#include "stddef.h"

/// @brief Reads a line from the file.
/// @param fd the file descriptor.
/// @param buffer the buffer where we place the line.
/// @param buflen the length of the buffer.
/// @param readlen the amount we read, if negative, we did not encounter a newline.
/// @return 0 if we are done reading, 1 if we encountered a newline, -1 if otherwise.
/// @brief Reads a line from the given file descriptor into the buffer.
/// @param fd The file descriptor to read from.
/// @param buffer The buffer where the read line will be stored. Must not be NULL.
/// @param buflen The size of the buffer.
/// @param read_len A pointer to store the length of the read line. Can be NULL if not needed.
/// @return 1 if a newline was found and the line was read successfully,
/// 0 if the end of the file was reached,
/// -1 if no newline was found and partial data was read.
int readline(int fd, char *buffer, size_t buflen, ssize_t *read_len);
1 change: 0 additions & 1 deletion libc/inc/sys/list_head_algorithm.h
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
/// @file list_head_algorithm.h
/// @author Enrico Fraccaroli ([email protected])
/// @brief Some general algorithm that might come in handy while using list_head.
/// @copyright (c) 2014-2024 This file is distributed under the MIT License.
/// See LICENSE.md for details.
Expand Down
1 change: 0 additions & 1 deletion libc/inc/sys/mman.h
Original file line number Diff line number Diff line change
@@ -1,5 +1,4 @@
/// @file mman.h
/// @author Enrico Fraccaroli ([email protected])
/// @brief Functions for managing mappings in virtual address space.
/// @copyright (c) 2014-2024 This file is distributed under the MIT License.
/// See LICENSE.md for details.
Expand Down
18 changes: 10 additions & 8 deletions libc/inc/sys/stat.h
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@
/// See LICENSE.md for details.

#pragma once

/// Prevents the error when inlcuding <bits/stat.h>.
#define __SYS_STAT_H

#include "bits/stat.h"
Expand All @@ -26,14 +28,14 @@
/// @defgroup FileTypeTest File Type Test Macros
/// @brief These macros allows to easily identify file types.
/// @{
#define S_ISTYPE(mode, mask) (((mode) & S_IFMT) == (mask))
#define S_ISSOCK(mode) (S_ISTYPE(mode, S_IFSOCK)) ///< Check if a socket.
#define S_ISLNK(mode) (S_ISTYPE(mode, S_IFLNK)) ///< Check if a symbolic link.
#define S_ISREG(mode) (S_ISTYPE(mode, S_IFREG)) ///< Check if a regular file.
#define S_ISBLK(mode) (S_ISTYPE(mode, S_IFBLK)) ///< Check if a block special.
#define S_ISDIR(mode) (S_ISTYPE(mode, S_IFDIR)) ///< Check if a directory.
#define S_ISCHR(mode) (S_ISTYPE(mode, S_IFCHR)) ///< Check if a char special.
#define S_ISFIFO(mode) (S_ISTYPE(mode, S_IFIFO)) ///< Check if a fifo.
#define S_ISTYPE(mode, mask) (((mode) & S_IFMT) == (mask)) ///< Easy macro for checking the type.
#define S_ISSOCK(mode) (S_ISTYPE(mode, S_IFSOCK)) ///< Check if a socket.
#define S_ISLNK(mode) (S_ISTYPE(mode, S_IFLNK)) ///< Check if a symbolic link.
#define S_ISREG(mode) (S_ISTYPE(mode, S_IFREG)) ///< Check if a regular file.
#define S_ISBLK(mode) (S_ISTYPE(mode, S_IFBLK)) ///< Check if a block special.
#define S_ISDIR(mode) (S_ISTYPE(mode, S_IFDIR)) ///< Check if a directory.
#define S_ISCHR(mode) (S_ISTYPE(mode, S_IFCHR)) ///< Check if a char special.
#define S_ISFIFO(mode) (S_ISTYPE(mode, S_IFIFO)) ///< Check if a fifo.
/// @}

/// @defgroup ModeBitsAccessPermission Mode Bits for Access Permission
Expand Down
12 changes: 6 additions & 6 deletions libc/inc/sys/unistd.h
Original file line number Diff line number Diff line change
Expand Up @@ -9,13 +9,13 @@
#include "stddef.h"
#include "sys/dirent.h"

#define STDIN_FILENO 0 ///< Standard input.
#define STDOUT_FILENO 1 ///< Standard output.
#define STDERR_FILENO 2 ///< Standard error output.
#define STDIN_FILENO 0 ///< Standard input file descriptor.
#define STDOUT_FILENO 1 ///< Standard output file descriptor.
#define STDERR_FILENO 2 ///< Standard error file descriptor.

#define stdin STDIN_FILENO ///< Standard input.
#define stdout STDOUT_FILENO ///< Standard output.
#define stderr STDERR_FILENO ///< Standard error output.
#define stdin STDIN_FILENO ///< Standard input file descriptor.
#define stdout STDOUT_FILENO ///< Standard output file descriptor.
#define stderr STDERR_FILENO ///< Standard error file descriptor.

/// @brief Read data from a file descriptor.
/// @param fd The file descriptor.
Expand Down
Loading

0 comments on commit e24709d

Please sign in to comment.