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

View file

@ -16,7 +16,7 @@ typedef struct FRAMEBUFFER {
u32 height;
u8 bpp;
u8 type;
u64 color_info_addr;
u8 reserved;
} __attribute__((packed)) FRAMEBUFFER;
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();
memtext_init();
idt_enable_interrupt();
// Looking for framebuffer
FRAMEBUFFER fb_info;
if(mb2_find_framebuffer((u32*)mb_info, &fb_info)){
@ -57,6 +57,7 @@ extern "C" void boucane(u64 mb_info){
// Booting!
printk("Booting Boucane v%d.%d.%d\n",VERSION_MAJOR,VERSION_MINOR, VERSION_PATH);
while(1);
}

View file

@ -11,11 +11,14 @@ u64* paging_allocate_table(){
u64 addr=(u64)kpages[kpages_next];
u64* allocated=(u64*)(addr-kvar_kernel_vma);
kpages_next++;
if(kpages_next>=PAGING_MAX_PAGE){
printk("Could not allocate more page structures. Kernel Panic!");
while(1);
}
return allocated;
}
void paging_enable() {
// Init status
for (int i = 0; i < PAGING_MAX_PAGE / 8; i++) {
paging_status[i] = 0;
@ -33,10 +36,11 @@ void paging_enable() {
// Setting up new kernel address space
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
paging_allocate_addr(kpages[0],kvar_kernel_vma-4096,kvar_stack_pma,0x3,0);
PAGE_MAP_PHY(-4096, kvar_stack_pma);
// Load new pml4
u64 kpage_phy=((u64)kpages[0]-kvar_kernel_vma);
@ -46,18 +50,6 @@ void paging_enable() {
:: "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){
int n_contiguous=0;
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)));
}
/// TODO: Debug addess
void paging_deallocate_pml4(u64* pml4){
for(int i=0;i<512;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 pdp=virt>>30&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){
pml4_table[pml4]=(u64)paging_allocate_table();
pml4_table[pml4]|=options;
paging_allocate_addr(pml4_table,virt,phy,options,offset);
paging_allocate_addr(pml4_table,virt,phy,options);
return;
}
// 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){
pdp_table[pdp]=(u64)paging_allocate_table();
pdp_table[pdp]|=options;
paging_allocate_addr(pml4_table,virt,phy,options,offset);
paging_allocate_addr(pml4_table,virt,phy,options);
return;
}
// 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){
pd_table[pd]=(u64)paging_allocate_table();
pd_table[pd]|=options;
paging_allocate_addr(pml4_table,virt,phy,options,offset);
paging_allocate_addr(pml4_table,virt,phy,options);
return;
}
// 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){
pt_table[pt]=PAGE(phy);
pt_table[pt]|=options;

View file

@ -2,34 +2,40 @@
#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
* should not be used by the paging allocation mechanism and should not be granted
* for allocation
*/
#define PAGING_KERNEL_USED_PAGE (2*512)
/// @brief New number of page reachable at the end of the paging_enable() call
#define PAGING_KERNEL_SPACE_MAX_PAGE (20*512)
#define PAGING_ALLOCATE() paging_allocate_contiguous(1)
#define MAX_TABLES 280
#define PAGING_MAX_PAGE (20*512)
#define PAGE_ALLOCATE() paging_allocate_contiguous(1)
/// @brief Options
#define PAGING_OPT_P 1
#define PAGING_OPT_RW (1<<1)
#define PAGING_OPT_PCD (1<<3)
/// @brief Get page address that contain addr
#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 PAGING_MAP_RANGE(addr, n) { \
for(u64 i=0;i<(n);i++){ \
paging_allocate_addr(kpages[0],((u64)(addr))+i,((u64)(addr))+i,PAGING_OPT_P|PAGING_OPT_RW,kvar_kernel_vma); \
#define VIRT(addr) (addr+kvar_kernel_vma)
/// @brief Mapping facilities
#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 PAGING_MAP2(addr,phy) paging_allocate_addr(kpages[0],(u64)(addr),(u64)(phy),PAGING_OPT_P|PAGING_OPT_RW,kvar_kernel_vma)
#define PAGING_MAP2_RANGE(addr, phy, n) { \
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(addr) paging_allocate_addr(kpages[0],(u64)((addr)+kvar_kernel_vma),(u64)(addr),PAGING_OPT_P|PAGING_OPT_RW)
#define PAGE_RMAP(addr, n) { \
for(u64 i=0;i<(n);i+=4096){ \
paging_allocate_addr(kpages[0],(((u64)(addr))+kvar_kernel_vma)+i,((u64)(addr))+i,PAGING_OPT_P|PAGING_OPT_RW); \
}}
#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
@ -70,21 +76,8 @@ void paging_deallocate_pml4(u64* pml4);
*/
void paging_deallocate_table(u64* table);
/**
* Allocate table structure (pml4, pdp etc..)
*/
u64* paging_allocate_table_local();
/**
* Map virtual page associated to virt
* 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);
/**
* Get associated physical address
*/
u64 paging_as_phy(u64* pml4_table, u64 virt);
void paging_allocate_addr(u64* pml4_table,u64 virt, u64 phy, u16 options);

View file

@ -32,7 +32,7 @@ char acpi_init(void* rsdp_p){
}
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));
rsdt.first_entry_addr_ptr=rsdp.rsdt_addr+36;
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);
// Load header
ACPI_TABLE_HEADER header;
PAGING_MAP(*addr);
PAGE_ID_MAP(*addr);
memcpy((void*)*addr, &header, sizeof(header));
// Check if it is MADT
if(header.signature==ACPI_MADT_SIGNATURE){

View file

@ -7,10 +7,25 @@ FB_CFG fb_cfg;
void framebuffer_init(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){
// 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);
pixel[0]=p.r;
pixel[1]=p.g;
@ -20,11 +35,24 @@ void framebuffer_draw(FB_PIXEL p){
}
void framebuffer_scrollup(u32 npixel){
u64 start=fb_cfg.location+npixel*fb_cfg.pitch;
u64 amount=fb_cfg.pitch*(fb_cfg.height-npixel);
memcpy((void*)start,(void*)fb_cfg.location,amount); // TODO change because page fault can occurs
for(u32 y=0;y<fb_cfg.height;y++){
if(npixel<fb_cfg.height){
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(){
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"
char memtext_buffer[MEMTEXT_BUFFER_SIZE];
u64 memtext_x=0;
void memtext_init(){
PAGING_MAP2_RANGE(MEMTEXT_ADDR_LOCATION,0x0,8);
u64* p_addr=(u64*)MEMTEXT_ADDR_LOCATION;
PAGE_RMAP(MEMTEXT_ADDR_LOCATION,8);
u64* p_addr=(u64*)VIRT(MEMTEXT_ADDR_LOCATION);
*p_addr=(u64)memtext_buffer;
// Cleaning buffer

View file

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

View file

@ -30,8 +30,10 @@ void psftext_putchar(char c){
if(c=='\n'){
psf_status.y++;
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);
psf_status.y--;
}
return;
}
@ -60,7 +62,9 @@ void psftext_putchar(char c){
if(psf_status.x>psf_status.nchar){
psf_status.y++;
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);
psf_status.y--;
}
}
}

View file

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

View file

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