parse header

This commit is contained in:
2026-02-17 16:00:11 +01:00
parent 3234447bbb
commit 3d1c8a2200
5 changed files with 44 additions and 32 deletions

View File

@@ -3,6 +3,7 @@
#include "./debug/output.h" #include "./debug/output.h"
#include "./types.h" // This is actually used #include "./types.h" // This is actually used
#include "arch/core_interrupt.h" #include "arch/core_interrupt.h"
#include "memory/page.h"
#include "memory/pageframealloc.h" #include "memory/pageframealloc.h"
#include "memory/pagetable.h" #include "memory/pagetable.h"
#include "object/outputstream.h" #include "object/outputstream.h"
@@ -82,12 +83,20 @@ extern "C" int main() {
// Enter Level 1/2 // Enter Level 1/2
Guarded g = Guard::enter(); Guarded g = Guard::enter();
uint32_t (*apps_header)[1024] = (uint32_t (*)[1024])Multiboot::getModule(0)->getStartAddress();
uint64_t offset = 1;
for(uint16_t i = 1; i <= (*apps_header)[0]; i++){
uint32_t appsize = (*apps_header)[i];
uintptr_t appstart = (0x4000+offset)<<12;
DBG << "app " << i << " size " << appsize << " at " << appstart << endl;
g.vault().scheduler.ready(new Thread(false, (void*)appstart));
offset += 1+(appsize/4096);
}
//for(void* p=Multiboot::getModule(0)->getStartAddress(); p<Multiboot::getModule(0)->getEndAddress(); p=(void*)((uintptr_t)p+4096)){ //for(void* p=Multiboot::getModule(0)->getStartAddress(); p<Multiboot::getModule(0)->getEndAddress(); p=(void*)((uintptr_t)p+4096)){
// DBG << "module at: " << hex << p << endl; // DBG << "module at: " << hex << p << endl;
// g.vault().scheduler.ready(new Thread(false, p)); // g.vault().scheduler.ready(new Thread(false, p));
//} //}
g.vault().scheduler.ready(new Thread(false, (void*)0x4001000)); //g.vault().scheduler.ready(new Thread(false, (void*)0x4001000));
load_cr3((void*)&paging_tree.l4);
//for (uint32_t i = 0; i < NUM_APPS; ++i) { //for (uint32_t i = 0; i < NUM_APPS; ++i) {
// g.vault().scheduler.ready(&(apps[i])); // g.vault().scheduler.ready(&(apps[i]));

View File

@@ -42,6 +42,7 @@ class Scheduler {
*/ */
alignas(16) IdleThread idleThread; alignas(16) IdleThread idleThread;
public: public:
Scheduler(); Scheduler();

View File

@@ -33,6 +33,7 @@ class Thread {
bool isKernel; bool isKernel;
void* start; void* start;
pagetable_t* subtable; pagetable_t* subtable;
friend class Queue<Thread>; friend class Queue<Thread>;

View File

@@ -13,12 +13,12 @@ extern "C" void main() {
for (unsigned i = 1;; ++i) { for (unsigned i = 1;; ++i) {
write(1, text, sizeof(text)); write(1, text, sizeof(text));
if(i==id){ //if(i==id){
//write(2, "kill", 4); // //write(2, "kill", 4);
//write(2, &text[4], 1); // //write(2, &text[4], 1);
//write(2, " ", 1); // //write(2, " ", 1);
sys_exit(); // sys_exit();
} //}
sleep(1000); sleep(1000);
} }
} }

View File

@@ -9,29 +9,30 @@ extern "C" void main() {
char cmd_buff[100]; char cmd_buff[100];
uint8_t bufferpos = 0; uint8_t bufferpos = 0;
while(1){ while(1){
char msg[11]; write(1, "kappl", 5);
int len; //char msg[11];
len = read(0, msg, 1); //int len;
if(len){ //len = read(0, msg, 1);
write(0, msg, len); //if(len){
memcpy(&cmd_buff[bufferpos], msg, len); // write(0, msg, len);
bufferpos+=len; // memcpy(&cmd_buff[bufferpos], msg, len);
for(uint8_t i=0; i<len; i++) // bufferpos+=len;
if(msg[i] == '\n'){ // for(uint8_t i=0; i<len; i++)
bufferpos = 0; // if(msg[i] == '\n'){
if(strncmp(cmd_buff, "kill ", 5) == 0){ // bufferpos = 0;
int pid = cmd_buff[5]-0x30; // if(strncmp(cmd_buff, "kill ", 5) == 0){
char r[] = "killing X\n"; // int pid = cmd_buff[5]-0x30;
r[8] = pid+0x30; // char r[] = "killing X\n";
write(0, r, 9); // r[8] = pid+0x30;
sys_kill(pid); // write(0, r, 9);
} // sys_kill(pid);
if(strncmp(cmd_buff, "killall", 7) == 0){ // }
for(uint8_t i = 0; i<10; i++){ // if(strncmp(cmd_buff, "killall", 7) == 0){
sys_kill(i); // for(uint8_t i = 0; i<10; i++){
} // sys_kill(i);
} // }
} // }
} // }
//}
} }
} }