mirror of
https://github.com/gbowne1/ClassicOS.git
synced 2026-01-21 12:35:19 -08:00
Compare commits
5 Commits
86608ef48c
...
19f7c7b213
| Author | SHA1 | Date | |
|---|---|---|---|
| 19f7c7b213 | |||
| bc9d84a93e | |||
| 9066ceaddb | |||
|
|
3b67e81ed0 | ||
|
|
841892398a |
@@ -3,6 +3,14 @@
|
|||||||
#include "terminal.h"
|
#include "terminal.h"
|
||||||
#include "utils.h"
|
#include "utils.h"
|
||||||
|
|
||||||
|
void cpuid(uint32_t leaf, uint32_t *eax, uint32_t *ebx, uint32_t *ecx, uint32_t *edx) {
|
||||||
|
__asm__(
|
||||||
|
"cpuid"
|
||||||
|
: "=a"(*eax), "=b"(*ebx), "=c"(*ecx), "=d"(*edx)
|
||||||
|
: "a"(leaf)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
// Helper to print a labeled decimal value
|
// Helper to print a labeled decimal value
|
||||||
void print_val(const char* label, uint32_t val) {
|
void print_val(const char* label, uint32_t val) {
|
||||||
char buf[12];
|
char buf[12];
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
#ifndef IRQ_H
|
#ifndef IRQ_H
|
||||||
#define IRQ_H
|
#define IRQ_H
|
||||||
|
|
||||||
#include "types.h"
|
#include <stdint.h>
|
||||||
|
|
||||||
void irq_remap(void);
|
void irq_remap(void);
|
||||||
void irq_install(void);
|
void irq_install(void);
|
||||||
|
|||||||
@@ -1,3 +1,4 @@
|
|||||||
|
#include <stdbool.h>
|
||||||
#include "terminal.h"
|
#include "terminal.h"
|
||||||
#include "serial.h"
|
#include "serial.h"
|
||||||
#include "isr.h"
|
#include "isr.h"
|
||||||
|
|||||||
@@ -1,21 +1,17 @@
|
|||||||
#include "paging.h"
|
|
||||||
#include "io.h"
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <stddef.h>
|
#include <string.h>
|
||||||
|
#include "io.h"
|
||||||
|
#include "paging.h"
|
||||||
|
|
||||||
page_directory_entry_t *page_directory = (page_directory_entry_t *)0x200000;
|
page_directory_entry_t *page_directory = (page_directory_entry_t *)0x200000;
|
||||||
page_table_entry_t *page_table = (page_table_entry_t *)0x201000;
|
page_table_entry_t *page_table = (page_table_entry_t *)0x201000;
|
||||||
page_table_entry_t *heap_page_table = (page_table_entry_t *)0x202000;
|
|
||||||
|
|
||||||
// Helper function to set up the page directory entry
|
// Helper function to set up the page directory entry
|
||||||
void set_page_directory(page_directory_entry_t *dir) {
|
void set_page_directory(page_directory_entry_t *dir) {
|
||||||
for (int i = 0; i < PAGE_DIRECTORY_SIZE; i++) {
|
// Set first PDE
|
||||||
dir[i].present = 0;
|
|
||||||
}
|
|
||||||
dir[0].present = 1;
|
dir[0].present = 1;
|
||||||
dir[0].rw = 1;
|
dir[0].rw = 1;
|
||||||
dir[0].user = 0;
|
dir[0].addr = (uint32_t)page_table >> 12;
|
||||||
dir[0].frame = (uint32_t)page_table >> 12;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Helper function to set up the page table entry
|
// Helper function to set up the page table entry
|
||||||
@@ -24,11 +20,7 @@ void set_page_table(page_table_entry_t *table) {
|
|||||||
// Set up page table entries with identity mapping
|
// Set up page table entries with identity mapping
|
||||||
table[i].present = 1;
|
table[i].present = 1;
|
||||||
table[i].rw = 1; // Read/Write
|
table[i].rw = 1; // Read/Write
|
||||||
table[i].user = 0; // Kernel mode
|
table[i].addr = i; // Identity mapping
|
||||||
table[i].write_through = 0;
|
|
||||||
table[i].cache_disabled = 0;
|
|
||||||
table[i].accessed = 0;
|
|
||||||
table[i].frame = i; // Identity mapping
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -47,26 +39,13 @@ void enable_paging() {
|
|||||||
|
|
||||||
// Initialize paging: set up the page directory and enable paging
|
// Initialize paging: set up the page directory and enable paging
|
||||||
void paging_init() {
|
void paging_init() {
|
||||||
|
// Zero out the tables
|
||||||
|
memset(page_directory, 0x00, PAGE_DIRECTORY_SIZE * sizeof *page_directory);
|
||||||
|
memset(page_table, 0x00, PAGE_TABLE_SIZE * sizeof *page_table);
|
||||||
|
|
||||||
// Set up identity-mapped page directory + table
|
// Set up identity-mapped page directory + table
|
||||||
set_page_directory(page_directory);
|
set_page_directory(page_directory);
|
||||||
set_page_table(page_table);
|
set_page_table(page_table);
|
||||||
|
|
||||||
// === Set up heap mapping at 0xC0100000 ===
|
|
||||||
for (int i = 0; i < PAGE_TABLE_SIZE; i++) {
|
|
||||||
heap_page_table[i].present = 1;
|
|
||||||
heap_page_table[i].rw = 1;
|
|
||||||
heap_page_table[i].user = 0;
|
|
||||||
heap_page_table[i].write_through = 0;
|
|
||||||
heap_page_table[i].cache_disabled = 0;
|
|
||||||
heap_page_table[i].accessed = 0;
|
|
||||||
heap_page_table[i].frame = (256 + i); // Start physical heap at 1MB (256*4KB = 1MB)
|
|
||||||
}
|
|
||||||
|
|
||||||
// Index 772 = 0xC0100000 / 4MB
|
|
||||||
page_directory[772].present = 1;
|
|
||||||
page_directory[772].rw = 1;
|
|
||||||
page_directory[772].user = 0;
|
|
||||||
page_directory[772].frame = (uint32_t)heap_page_table >> 12;
|
|
||||||
|
|
||||||
enable_paging();
|
enable_paging();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -16,25 +16,25 @@ typedef struct {
|
|||||||
uint32_t write_through : 1; // Write-through cache
|
uint32_t write_through : 1; // Write-through cache
|
||||||
uint32_t cache_disabled : 1; // Cache disabled
|
uint32_t cache_disabled : 1; // Cache disabled
|
||||||
uint32_t accessed : 1; // Accessed bit
|
uint32_t accessed : 1; // Accessed bit
|
||||||
uint32_t reserved : 1; // Reserved bit
|
uint32_t dirty : 1; // Dirty bit
|
||||||
uint32_t page_size : 1; // Page size (0: 4KB, 1: 4MB)
|
uint32_t attribute : 1; // Page size (0: 4KB, 1: 4MB)
|
||||||
uint32_t global : 1; // Global page (can be used across different processes)
|
uint32_t global : 1; // Global page (can be used across different processes)
|
||||||
uint32_t available : 3; // Available bits for the system
|
uint32_t reserved : 3; // Unused
|
||||||
uint32_t frame : 20; // Frame address (physical address)
|
uint32_t addr : 20; // Page frame address (physical address)
|
||||||
} __attribute__((packed)) page_table_entry_t;
|
} __attribute__((packed)) page_table_entry_t;
|
||||||
|
|
||||||
// Define page directory entry
|
// Define page directory entry
|
||||||
typedef struct {
|
typedef struct {
|
||||||
uint32_t present : 1;
|
uint32_t present : 1; // Present bit (1: PTE is present in memory)
|
||||||
uint32_t rw : 1;
|
uint32_t rw : 1; // Read-Write bit (1: pages are read-write)
|
||||||
uint32_t user : 1;
|
uint32_t user : 1; // User-supervisor bit (1: user mode access)
|
||||||
uint32_t write_through : 1;
|
uint32_t write_through : 1; // Write-through cache
|
||||||
uint32_t cache_disabled : 1;
|
uint32_t cache_disabled : 1; // Cache disabled
|
||||||
uint32_t accessed : 1;
|
uint32_t accessed : 1; // Accessed bit
|
||||||
uint32_t reserved : 1;
|
uint32_t available : 1; // Unused
|
||||||
uint32_t zero : 5; // Must be zero for page directory
|
uint32_t page_size : 1; // Page size (0: 4KB, 1: 4MB)
|
||||||
uint32_t reserved_2 : 7; // Reserved bits
|
uint32_t available_2 : 4; // Unused
|
||||||
uint32_t frame : 20; // Frame address of the page table
|
uint32_t addr : 20; // Page table address
|
||||||
} __attribute__((packed)) page_directory_entry_t;
|
} __attribute__((packed)) page_directory_entry_t;
|
||||||
|
|
||||||
extern page_directory_entry_t *page_directory;
|
extern page_directory_entry_t *page_directory;
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
#ifndef PRINT_H
|
#ifndef PRINT_H
|
||||||
#define PRINT_H
|
#define PRINT_H
|
||||||
|
|
||||||
#include "types.h"
|
#include <stdint.h>
|
||||||
|
|
||||||
void print_string(const char *str);
|
void print_string(const char *str);
|
||||||
void my_printf(const char *format, ...);
|
void my_printf(const char *format, ...);
|
||||||
|
|||||||
@@ -1,9 +1,8 @@
|
|||||||
|
#include <stdbool.h>
|
||||||
|
#include <string.h>
|
||||||
#include "malloc.h"
|
#include "malloc.h"
|
||||||
#include "print.h"
|
#include "print.h"
|
||||||
#include "threading.h"
|
#include "threading.h"
|
||||||
#include "types.h"
|
|
||||||
#include "utils.h"
|
|
||||||
#include <stdint.h>
|
|
||||||
|
|
||||||
#define MAX_THREADS 16 // Maximum number of threads
|
#define MAX_THREADS 16 // Maximum number of threads
|
||||||
#define THREAD_STACK_SIZE 8192 // Stack size for each thread
|
#define THREAD_STACK_SIZE 8192 // Stack size for each thread
|
||||||
|
|||||||
@@ -1 +0,0 @@
|
|||||||
#include "types.h"
|
|
||||||
@@ -1,61 +0,0 @@
|
|||||||
#ifndef TYPES_H
|
|
||||||
#define TYPES_H
|
|
||||||
|
|
||||||
// ----------------------------
|
|
||||||
// Fixed-width integer types
|
|
||||||
// ----------------------------
|
|
||||||
typedef unsigned char uint8_t;
|
|
||||||
typedef signed char int8_t;
|
|
||||||
typedef unsigned short uint16_t;
|
|
||||||
typedef signed short int16_t;
|
|
||||||
typedef unsigned int uint32_t;
|
|
||||||
typedef signed int int32_t;
|
|
||||||
typedef unsigned long long uint64_t;
|
|
||||||
typedef signed long long int64_t;
|
|
||||||
|
|
||||||
// ----------------------------
|
|
||||||
// Boolean & NULL definitions
|
|
||||||
// ----------------------------
|
|
||||||
#ifndef __cplusplus
|
|
||||||
typedef enum { false = 0, true = 1 } bool;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef NULL
|
|
||||||
#define NULL ((void*)0)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// ----------------------------
|
|
||||||
// OS subsystem types
|
|
||||||
// ----------------------------
|
|
||||||
typedef int32_t ssize_t;
|
|
||||||
|
|
||||||
typedef uint32_t phys_addr_t; // Physical address
|
|
||||||
typedef uint32_t virt_addr_t; // Virtual address
|
|
||||||
|
|
||||||
typedef uint32_t pid_t; // Process ID
|
|
||||||
typedef uint32_t tid_t; // Thread ID
|
|
||||||
|
|
||||||
// ----------------------------
|
|
||||||
// Bitfield & utility macros
|
|
||||||
// ----------------------------
|
|
||||||
#define BIT(n) (1U << (n))
|
|
||||||
#define BITS(m, n) (((1U << ((n) - (m) + 1)) - 1) << (m))
|
|
||||||
|
|
||||||
// Align value to next multiple of alignment
|
|
||||||
#define ALIGN_UP(val, align) (((val) + ((align)-1)) & ~((align)-1))
|
|
||||||
#define ALIGN_DOWN(val, align) ((val) & ~((align)-1))
|
|
||||||
|
|
||||||
// ----------------------------
|
|
||||||
// Attributes for structures
|
|
||||||
// ----------------------------
|
|
||||||
#define PACKED __attribute__((packed))
|
|
||||||
#define ALIGN(x) __attribute__((aligned(x)))
|
|
||||||
|
|
||||||
// ----------------------------
|
|
||||||
// Likely/unlikely branch hints
|
|
||||||
// (for future optimization use)
|
|
||||||
// ----------------------------
|
|
||||||
#define likely(x) __builtin_expect(!!(x), 1)
|
|
||||||
#define unlikely(x) __builtin_expect(!!(x), 0)
|
|
||||||
|
|
||||||
#endif // TYPES_H
|
|
||||||
@@ -3,14 +3,10 @@
|
|||||||
|
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
|
|
||||||
#include "types.h"
|
|
||||||
|
|
||||||
// Convert integer to string (base is typically 10, 16, etc.)
|
// Convert integer to string (base is typically 10, 16, etc.)
|
||||||
char* itoa(int value, char* str, int base);
|
char* itoa(int value, char* str, int base);
|
||||||
|
|
||||||
// Convert unsigned integer to string (base is typically 10, 16, etc.)
|
// Convert unsigned integer to string (base is typically 10, 16, etc.)
|
||||||
char* utoa(unsigned int value, char* str, int base);
|
char* utoa(unsigned int value, char* str, int base);
|
||||||
|
|
||||||
void *memset(void *dest, int value, size_t len);
|
|
||||||
|
|
||||||
#endif // UTILS_H
|
#endif // UTILS_H
|
||||||
|
|||||||
@@ -1,6 +1,12 @@
|
|||||||
#ifndef CLASSICOS_KLIBC_STDBOOL_H
|
#ifndef CLASSICOS_KLIBC_STDBOOL_H
|
||||||
#define CLASSICOS_KLIBC_STDBOOL_H
|
#define CLASSICOS_KLIBC_STDBOOL_H
|
||||||
|
|
||||||
typedef enum { false = 0, true = 1 } bool;
|
#ifndef __cplusplus
|
||||||
|
#define bool _Bool
|
||||||
|
#define true 1
|
||||||
|
#define false 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define __bool_true_false_are_defined 1
|
||||||
|
|
||||||
#endif // CLASSICOS_KLIBC_STDBOOL_H
|
#endif // CLASSICOS_KLIBC_STDBOOL_H
|
||||||
|
|||||||
Reference in New Issue
Block a user