Debug memory

This commit is contained in:
Loic Guegan 2021-04-29 15:01:54 +02:00
parent fde8a1ab65
commit f37f5d86b7
12 changed files with 98 additions and 77 deletions

View file

@ -4,13 +4,12 @@
#include "libs/stdio.hpp" #include "libs/stdio.hpp"
u32* mb2_find_tag(u32 *mb2_info_addr, char type){ u32* mb2_find_tag(u32 *mb2_info_addr, char type){
PAGING_MAP(mb2_info_addr); PAGE_MAP(mb2_info_addr);
u32 size=(u32)mb2_info_addr[0]; // Todo: check for size u32 size=(u32)VIRT(mb2_info_addr)[0]; // Todo: check for size
for(u64 i=0;i<size/8;i++) PAGE_RMAP(mb2_info_addr, size);
PAGING_MAP(mb2_info_addr+i*4096);
char *location=((char*)mb2_info_addr)+8; // Goto first tag char *location=((char*)VIRT(mb2_info_addr))+8; // Goto first tag
char *start=(char*)mb2_info_addr; char *start=(char*)VIRT(mb2_info_addr);
while((location-start) < size){ while((location-start) < size){
// Goto next 64bit align address // Goto next 64bit align address
@ -23,6 +22,10 @@ u32* mb2_find_tag(u32 *mb2_info_addr, char type){
if(cur_type==type){ if(cur_type==type){
return (u32*)location; return (u32*)location;
} }
if(type > 30){
printk("Strange multiboot infos structure...\n");
return 0;
}
location+=cur_size; location+=cur_size;
} }

View file

@ -16,7 +16,7 @@ typedef struct FRAMEBUFFER {
u32 height; u32 height;
u8 bpp; u8 bpp;
u8 type; u8 type;
u64 color_info_addr; u8 reserved;
} __attribute__((packed)) FRAMEBUFFER; } __attribute__((packed)) FRAMEBUFFER;
u32* mb2_find_tag(u32 *mb2_info_addr, char type); u32* mb2_find_tag(u32 *mb2_info_addr, char type);

View file

@ -34,7 +34,7 @@ extern "C" void boucane(u64 mb_info){
paging_enable(); paging_enable();
memtext_init(); memtext_init();
idt_enable_interrupt(); idt_enable_interrupt();
// Looking for framebuffer // Looking for framebuffer
FRAMEBUFFER fb_info; FRAMEBUFFER fb_info;
if(mb2_find_framebuffer((u32*)mb_info, &fb_info)){ if(mb2_find_framebuffer((u32*)mb_info, &fb_info)){
@ -57,6 +57,7 @@ extern "C" void boucane(u64 mb_info){
// Booting! // Booting!
printk("Booting Boucane v%d.%d.%d\n",VERSION_MAJOR,VERSION_MINOR, VERSION_PATH); printk("Booting Boucane v%d.%d.%d\n",VERSION_MAJOR,VERSION_MINOR, VERSION_PATH);
while(1); while(1);
} }

View file

@ -11,11 +11,14 @@ u64* paging_allocate_table(){
u64 addr=(u64)kpages[kpages_next]; u64 addr=(u64)kpages[kpages_next];
u64* allocated=(u64*)(addr-kvar_kernel_vma); u64* allocated=(u64*)(addr-kvar_kernel_vma);
kpages_next++; kpages_next++;
if(kpages_next>=PAGING_MAX_PAGE){
printk("Could not allocate more page structures. Kernel Panic!");
while(1);
}
return allocated; return allocated;
} }
void paging_enable() { void paging_enable() {
// Init status // Init status
for (int i = 0; i < PAGING_MAX_PAGE / 8; i++) { for (int i = 0; i < PAGING_MAX_PAGE / 8; i++) {
paging_status[i] = 0; paging_status[i] = 0;
@ -33,10 +36,11 @@ void paging_enable() {
// Setting up new kernel address space // Setting up new kernel address space
for(u64 i=0;i<=0x10000000;i+=4096){ for(u64 i=0;i<=0x10000000;i+=4096){
paging_allocate_addr(kpages[0],kvar_kernel_vma+i,i, 0x3,0); // Identity map PAGE_MAP(i);
} }
// 4096 bytes stack // 4096 bytes stack
paging_allocate_addr(kpages[0],kvar_kernel_vma-4096,kvar_stack_pma,0x3,0); PAGE_MAP_PHY(-4096, kvar_stack_pma);
// Load new pml4 // Load new pml4
u64 kpage_phy=((u64)kpages[0]-kvar_kernel_vma); u64 kpage_phy=((u64)kpages[0]-kvar_kernel_vma);
@ -46,18 +50,6 @@ void paging_enable() {
:: "r" (kpage_phy)); :: "r" (kpage_phy));
} }
u64 paging_as_phy(u64* pml4_table, u64 virt){
u16 pml4=virt>>39&0x1FF;
u16 pdp=virt>>30&0x1FF;
u16 pd=virt>>21&0x1FF;
u16 pt=(virt>>12)&0x1FF;
u64* pdp_table=(u64*)PAGE(pml4_table[pml4]);
u64* pd_table=(u64*)PAGE(pdp_table[pdp]);
u64* pt_table=(u64*)PAGE(pd_table[pd]);
return((PAGE(pt_table[pt]))|(virt&0xFFF));
}
u64* paging_allocate_contiguous(int npages){ u64* paging_allocate_contiguous(int npages){
int n_contiguous=0; int n_contiguous=0;
for (int i = 0; i < PAGING_MAX_PAGE / 8; i++) { for (int i = 0; i < PAGING_MAX_PAGE / 8; i++) {
@ -94,6 +86,8 @@ void paging_deallocate(u64 addr){
paging_status[page_number/8]=byte&(~(1<<(page_number%8))); paging_status[page_number/8]=byte&(~(1<<(page_number%8)));
} }
/// TODO: Debug addess
void paging_deallocate_pml4(u64* pml4){ void paging_deallocate_pml4(u64* pml4){
for(int i=0;i<512;i++){ for(int i=0;i<512;i++){
u64* pdp=(u64*)PAGE(pml4[i]); u64* pdp=(u64*)PAGE(pml4[i]);
@ -142,7 +136,7 @@ void paging_deallocate_table(u64* table){
} }
} }
void paging_allocate_addr(u64* pml4_table, u64 virt, u64 phy, u16 options, u64 offset){ void paging_allocate_addr(u64* pml4_table, u64 virt, u64 phy, u16 options){
u16 pml4=virt>>39&0x1FF; u16 pml4=virt>>39&0x1FF;
u16 pdp=virt>>30&0x1FF; u16 pdp=virt>>30&0x1FF;
u16 pd=virt>>21&0x1FF; u16 pd=virt>>21&0x1FF;
@ -153,29 +147,29 @@ void paging_allocate_addr(u64* pml4_table, u64 virt, u64 phy, u16 options, u64 o
if(pml4_table[pml4] == 0){ if(pml4_table[pml4] == 0){
pml4_table[pml4]=(u64)paging_allocate_table(); pml4_table[pml4]=(u64)paging_allocate_table();
pml4_table[pml4]|=options; pml4_table[pml4]|=options;
paging_allocate_addr(pml4_table,virt,phy,options,offset); paging_allocate_addr(pml4_table,virt,phy,options);
return; return;
} }
// Solve pd // Solve pd
u64* pdp_table=(u64*)(PAGE(pml4_table[pml4])+offset); u64* pdp_table=(u64*)(VIRT(PAGE(pml4_table[pml4])));
if(pdp_table[pdp] == 0){ if(pdp_table[pdp] == 0){
pdp_table[pdp]=(u64)paging_allocate_table(); pdp_table[pdp]=(u64)paging_allocate_table();
pdp_table[pdp]|=options; pdp_table[pdp]|=options;
paging_allocate_addr(pml4_table,virt,phy,options,offset); paging_allocate_addr(pml4_table,virt,phy,options);
return; return;
} }
// Solve pt // Solve pt
u64* pd_table=(u64*)(PAGE(pdp_table[pdp])+offset); u64* pd_table=(u64*)(VIRT(PAGE(pdp_table[pdp])));
if(pd_table[pd] == 0){ if(pd_table[pd] == 0){
pd_table[pd]=(u64)paging_allocate_table(); pd_table[pd]=(u64)paging_allocate_table();
pd_table[pd]|=options; pd_table[pd]|=options;
paging_allocate_addr(pml4_table,virt,phy,options,offset); paging_allocate_addr(pml4_table,virt,phy,options);
return; return;
} }
// Solve address // Solve address
u64* pt_table=(u64*)(PAGE(pd_table[pd])+offset); u64* pt_table=(u64*)(VIRT(PAGE(pd_table[pd])));
if(pt_table[pt] == 0){ if(pt_table[pt] == 0){
pt_table[pt]=PAGE(phy); pt_table[pt]=PAGE(phy);
pt_table[pt]|=options; pt_table[pt]|=options;

View file

@ -2,34 +2,40 @@
#include "core/types.hpp" #include "core/types.hpp"
#define MAX_TABLES 280
#define PAGING_MAX_PAGE (20*512)
/** /**
* Current number of page (from the beginning of the ram) used by the kernel that * Current number of page (from the beginning of the ram) used by the kernel that
* should not be used by the paging allocation mechanism and should not be granted * should not be used by the paging allocation mechanism and should not be granted
* for allocation * for allocation
*/ */
#define PAGING_KERNEL_USED_PAGE (2*512)
/// @brief New number of page reachable at the end of the paging_enable() call /// @brief New number of page reachable at the end of the paging_enable() call
#define PAGING_KERNEL_SPACE_MAX_PAGE (20*512) #define MAX_TABLES 280
#define PAGING_ALLOCATE() paging_allocate_contiguous(1) #define PAGING_MAX_PAGE (20*512)
#define PAGE_ALLOCATE() paging_allocate_contiguous(1)
/// @brief Options
#define PAGING_OPT_P 1 #define PAGING_OPT_P 1
#define PAGING_OPT_RW (1<<1) #define PAGING_OPT_RW (1<<1)
#define PAGING_OPT_PCD (1<<3) #define PAGING_OPT_PCD (1<<3)
/// @brief Get page address that contain addr /// @brief Get page address that contain addr
#define PAGE(addr) (addr&(~(0xFFF))) #define PAGE(addr) (addr&(~(0xFFF)))
#define PAGING_MAP(addr) paging_allocate_addr(kpages[0],(u64)(addr),(u64)(addr),PAGING_OPT_P|PAGING_OPT_RW,kvar_kernel_vma) #define VIRT(addr) (addr+kvar_kernel_vma)
#define PAGING_MAP_RANGE(addr, n) { \
for(u64 i=0;i<(n);i++){ \ /// @brief Mapping facilities
paging_allocate_addr(kpages[0],((u64)(addr))+i,((u64)(addr))+i,PAGING_OPT_P|PAGING_OPT_RW,kvar_kernel_vma); \ #define PAGE_ID_MAP(addr) paging_allocate_addr(kpages[0],(u64)(addr),(u64)(addr),PAGING_OPT_P|PAGING_OPT_RW)
#define PAGE_ID_RMAP(addr, n) { \
for(u64 i=0;i<(n);i+=4096){ \
paging_allocate_addr(kpages[0],((u64)(addr))+i,((u64)(addr))+i,PAGING_OPT_P|PAGING_OPT_RW); \
}} }}
#define PAGE_MAP(addr) paging_allocate_addr(kpages[0],(u64)((addr)+kvar_kernel_vma),(u64)(addr),PAGING_OPT_P|PAGING_OPT_RW)
#define PAGE_RMAP(addr, n) { \
#define PAGING_MAP2(addr,phy) paging_allocate_addr(kpages[0],(u64)(addr),(u64)(phy),PAGING_OPT_P|PAGING_OPT_RW,kvar_kernel_vma) for(u64 i=0;i<(n);i+=4096){ \
#define PAGING_MAP2_RANGE(addr, phy, n) { \ paging_allocate_addr(kpages[0],(((u64)(addr))+kvar_kernel_vma)+i,((u64)(addr))+i,PAGING_OPT_P|PAGING_OPT_RW); \
for(u64 i=0;i<(n);i++){ \ }}
paging_allocate_addr(kpages[0],((u64)(addr))+i,((u64)(phy))+i,PAGING_OPT_P|PAGING_OPT_RW,kvar_kernel_vma); \ #define PAGE_MAP_PHY(addr,phy) paging_allocate_addr(kpages[0],(u64)((addr)+kvar_kernel_vma),(u64)(phy),PAGING_OPT_P|PAGING_OPT_RW)
#define PAGE_RMAP_PHY(addr,phy, n) { \
for(u64 i=0;i<(n);i+=4096){ \
paging_allocate_addr(kpages[0],(((u64)(addr))+kvar_kernel_vma)+i,((u64)(phy))+i,PAGING_OPT_P|PAGING_OPT_RW); \
}} }}
/// @brief All PAE table structures are allocated here /// @brief All PAE table structures are allocated here
@ -70,21 +76,8 @@ void paging_deallocate_pml4(u64* pml4);
*/ */
void paging_deallocate_table(u64* table); void paging_deallocate_table(u64* table);
/**
* Allocate table structure (pml4, pdp etc..)
*/
u64* paging_allocate_table_local();
/** /**
* Map virtual page associated to virt * Map virtual page associated to virt
* to the physical page associated with phy * to the physical page associated with phy
* Offset can be used to convert pml4_table address
* content to virtual addresses (since physical addresses from the pml4_table are not
* available after the trampoline into High-Half memory)
*/ */
void paging_allocate_addr(u64* pml4_table,u64 virt, u64 phy, u16 options, u64 offset); void paging_allocate_addr(u64* pml4_table,u64 virt, u64 phy, u16 options);
/**
* Get associated physical address
*/
u64 paging_as_phy(u64* pml4_table, u64 virt);

View file

@ -32,7 +32,7 @@ char acpi_init(void* rsdp_p){
} }
char acpi_load_rsdt(){ char acpi_load_rsdt(){
PAGING_MAP(rsdp.rsdt_addr); // Ensure page is accessible PAGE_ID_MAP(rsdp.rsdt_addr); // Ensure page is accessible
memcpy((void*)rsdp.rsdt_addr, &rsdt, sizeof(rsdt)); memcpy((void*)rsdp.rsdt_addr, &rsdt, sizeof(rsdt));
rsdt.first_entry_addr_ptr=rsdp.rsdt_addr+36; rsdt.first_entry_addr_ptr=rsdp.rsdt_addr+36;
if(rsdt.header.signature !=ACPI_RSDT_SIGNATURE){ if(rsdt.header.signature !=ACPI_RSDT_SIGNATURE){
@ -54,7 +54,7 @@ char acpi_load_madt(){
u32 *addr=(u32*)(rsdt.first_entry_addr_ptr+i*4); u32 *addr=(u32*)(rsdt.first_entry_addr_ptr+i*4);
// Load header // Load header
ACPI_TABLE_HEADER header; ACPI_TABLE_HEADER header;
PAGING_MAP(*addr); PAGE_ID_MAP(*addr);
memcpy((void*)*addr, &header, sizeof(header)); memcpy((void*)*addr, &header, sizeof(header));
// Check if it is MADT // Check if it is MADT
if(header.signature==ACPI_MADT_SIGNATURE){ if(header.signature==ACPI_MADT_SIGNATURE){

View file

@ -7,10 +7,25 @@ FB_CFG fb_cfg;
void framebuffer_init(FB_CFG config){ void framebuffer_init(FB_CFG config){
fb_cfg=config; fb_cfg=config;
PAGING_MAP_RANGE(fb_cfg.location, fb_cfg.pitch*fb_cfg.height); // Map buffer to the end of the memory
// indeed fb_cfg.location could be to big and
// thus leading to cross u64 size limit while summing it with
// kvar_kernel_vma in paging.cc/hpp
u64 start=0xFFFFFFFFFFFFFFFF - fb_cfg.pitch*fb_cfg.height;
// Ensure we start writing at the begining of the page since
// start is not necessarly 4096 bytes aligned
start=PAGE(start);
PAGE_RMAP_PHY(start-kvar_kernel_vma,fb_cfg.location, fb_cfg.pitch*fb_cfg.height);
fb_cfg.location=start;
} }
void framebuffer_draw(FB_PIXEL p){ void framebuffer_draw(FB_PIXEL p){
// Check overflow
p.x=p.x>(fb_cfg.width)?fb_cfg.width:p.x;
p.y=p.y>(fb_cfg.width)?fb_cfg.width:p.y;
p.x=p.x<0?0:p.x;
p.y=p.y<0?0:p.y;
u8 *pixel=(u8*)(fb_cfg.location+p.x*(fb_cfg.depth/8)+p.y*fb_cfg.pitch); u8 *pixel=(u8*)(fb_cfg.location+p.x*(fb_cfg.depth/8)+p.y*fb_cfg.pitch);
pixel[0]=p.r; pixel[0]=p.r;
pixel[1]=p.g; pixel[1]=p.g;
@ -20,11 +35,24 @@ void framebuffer_draw(FB_PIXEL p){
} }
void framebuffer_scrollup(u32 npixel){ void framebuffer_scrollup(u32 npixel){
u64 start=fb_cfg.location+npixel*fb_cfg.pitch; for(u32 y=0;y<fb_cfg.height;y++){
u64 amount=fb_cfg.pitch*(fb_cfg.height-npixel); if(npixel<fb_cfg.height){
memcpy((void*)start,(void*)fb_cfg.location,amount); // TODO change because page fault can occurs for(u32 x=0;x<fb_cfg.width;x++){
u32 *pixel_dst=(u32*)(fb_cfg.location+x*(fb_cfg.depth/8)+y*fb_cfg.pitch);
u32 *pixel_src=(u32*)(fb_cfg.location+x*(fb_cfg.depth/8)+npixel*fb_cfg.pitch);
*pixel_dst=*pixel_src; // Faster than writing pixel by pixel
}
}
else{
for(u32 x=0;x<fb_cfg.width;x++){
u8 *pixel_dst=(u8*)(fb_cfg.location+x*(fb_cfg.depth/8)+y*fb_cfg.pitch);
*pixel_dst=0;// Faster than writing pixel by pixel
}
}
npixel++;
}
} }
void framebuffer_clear(){ void framebuffer_clear(){
memset((void*)fb_cfg.location, 0, fb_cfg.pitch*fb_cfg.height); // memset((void*)fb_cfg.location, 0, fb_cfg.pitch*fb_cfg.height-1000);
} }

View file

@ -4,13 +4,12 @@
#include "libs/string.hpp" #include "libs/string.hpp"
char memtext_buffer[MEMTEXT_BUFFER_SIZE]; char memtext_buffer[MEMTEXT_BUFFER_SIZE];
u64 memtext_x=0; u64 memtext_x=0;
void memtext_init(){ void memtext_init(){
PAGING_MAP2_RANGE(MEMTEXT_ADDR_LOCATION,0x0,8); PAGE_RMAP(MEMTEXT_ADDR_LOCATION,8);
u64* p_addr=(u64*)MEMTEXT_ADDR_LOCATION; u64* p_addr=(u64*)VIRT(MEMTEXT_ADDR_LOCATION);
*p_addr=(u64)memtext_buffer; *p_addr=(u64)memtext_buffer;
// Cleaning buffer // Cleaning buffer

View file

@ -2,7 +2,7 @@
#include "boucane.hpp" #include "boucane.hpp"
#define MEMTEXT_BUFFER_SIZE 1024 #define MEMTEXT_BUFFER_SIZE 4096
#define MEMTEXT_ADDR_LOCATION 0x0 #define MEMTEXT_ADDR_LOCATION 0x0

View file

@ -30,8 +30,10 @@ void psftext_putchar(char c){
if(c=='\n'){ if(c=='\n'){
psf_status.y++; psf_status.y++;
psf_status.x=0; psf_status.x=0;
if(psf_status.y>psf_status.nline) if(psf_status.y>=psf_status.nline){
framebuffer_scrollup(psf_status.header.glyph_height); framebuffer_scrollup(psf_status.header.glyph_height);
psf_status.y--;
}
return; return;
} }
@ -60,7 +62,9 @@ void psftext_putchar(char c){
if(psf_status.x>psf_status.nchar){ if(psf_status.x>psf_status.nchar){
psf_status.y++; psf_status.y++;
psf_status.x=0; psf_status.x=0;
if(psf_status.y>psf_status.nline) if(psf_status.y>=psf_status.nline){
framebuffer_scrollup(psf_status.header.glyph_height); framebuffer_scrollup(psf_status.header.glyph_height);
psf_status.y--;
}
} }
} }

View file

@ -6,7 +6,7 @@
#define MAX_LINE 25 #define MAX_LINE 25
VIDEO_STATE VS={ VIDEO_STATE VS={
(u8 *)0xB8000, (u8 *)0,
0, 0,
0, 0,
BLACK, BLACK,
@ -14,8 +14,8 @@ VIDEO_STATE VS={
}; };
void vgatext_init(){ void vgatext_init(){
PAGING_MAP(0xB8000); PAGE_RMAP(0xB8000,4096*2);
PAGING_MAP(0xB8000+4096); VS.mem=(u8*)VIRT(0xB8000);
} }
void vgatext_putchar(char c){ void vgatext_putchar(char c){

View file

@ -1,4 +1,3 @@
romimage: file=$BXSHARE/BIOS-bochs-latest, options=fastboot romimage: file=$BXSHARE/BIOS-bochs-latest, options=fastboot
vgaromimage: file=$BXSHARE/VGABIOS-lgpl-latest vgaromimage: file=$BXSHARE/VGABIOS-lgpl-latest
cpu: count=1, ips=10000000, reset_on_triple_fault=0