Merge branch 'BetterTerm' into cpu
This commit is contained in:
commit
cef3c37b89
|
@ -31,6 +31,7 @@
|
||||||
|
|
||||||
//----------------------------------------------------------------------------//
|
//----------------------------------------------------------------------------//
|
||||||
|
|
||||||
|
noreturn void PoShutdown(void);
|
||||||
noreturn void PoShutdownQemu(void);
|
noreturn void PoShutdownQemu(void);
|
||||||
noreturn void PoShutdownVirtualbox(void);
|
noreturn void PoShutdownVirtualbox(void);
|
||||||
noreturn void PoShutdownBochs(void);
|
noreturn void PoShutdownBochs(void);
|
||||||
|
|
|
@ -116,6 +116,6 @@ void BtDoSanityChecks(uint mbMagic) {
|
||||||
DebugLog("[Init] Kernel successfully loaded at %p with %x magic\n"
|
DebugLog("[Init] Kernel successfully loaded at %p with %x magic\n"
|
||||||
" and it uses %dKB\n\n",
|
" and it uses %dKB\n\n",
|
||||||
BtLoaderInfo.kernelAddr,
|
BtLoaderInfo.kernelAddr,
|
||||||
mbMagic,tmp);
|
mbMagic, tmp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -64,6 +64,5 @@ noreturn void BtStartKern(multiboot_info_t *mbInfo, uint mbMagic, void *codeSeg)
|
||||||
|
|
||||||
KeStartShell();
|
KeStartShell();
|
||||||
|
|
||||||
KernLog("End of input reached\n");
|
PoShutdown();
|
||||||
PoShutdownQemu();
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -151,7 +151,7 @@ void RtcHandler(ISRFrame_t *regs)
|
||||||
void IoPrintRtcTime(void)
|
void IoPrintRtcTime(void)
|
||||||
{
|
{
|
||||||
Time_t* RtcTime = IoGetRtcTime();
|
Time_t* RtcTime = IoGetRtcTime();
|
||||||
KernLog("[RTC Time] %02d/%02d/%04d ; %02d:%02d:%02d \n\n",
|
KernLog("[RTC Time] %02d/%02d/%04d ; %02d:%02d:%02d \n",
|
||||||
RtcTime->day,
|
RtcTime->day,
|
||||||
RtcTime->month,
|
RtcTime->month,
|
||||||
RtcTime->year + RtcTime->century*100,
|
RtcTime->year + RtcTime->century*100,
|
||||||
|
|
|
@ -195,7 +195,7 @@ void MmPrintMemoryMap(void) {
|
||||||
|
|
||||||
ulong len = memoryMap.entry[i].length;
|
ulong len = memoryMap.entry[i].length;
|
||||||
|
|
||||||
KernLog("Mem zone : %lp\t%s\twith length: %luMB + %luKB + %luB\n",
|
KernLog("mem zone: %lp\t%s\twith length: %04luMB + %04luKB + %04luB\n",
|
||||||
memoryMap.entry[i].addr, avStr,
|
memoryMap.entry[i].addr, avStr,
|
||||||
_ADDR_TO_MB(len), _ADDR_TO_KB(len), _ADDR_TO_B(len)
|
_ADDR_TO_MB(len), _ADDR_TO_KB(len), _ADDR_TO_B(len)
|
||||||
);
|
);
|
||||||
|
|
|
@ -59,3 +59,8 @@ noreturn void PoShutdownBochs(void)
|
||||||
__builtin_unreachable();
|
__builtin_unreachable();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
noreturn void PoShutdown(void)
|
||||||
|
{
|
||||||
|
PoShutdownQemu();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -390,7 +390,7 @@ void pstest(void)
|
||||||
|
|
||||||
while (tick < 100) {
|
while (tick < 100) {
|
||||||
//if (tick%25==0)ClearTerm(StdOut);
|
//if (tick%25==0)ClearTerm(StdOut);
|
||||||
if (tick > 0 && tick != 50 && tick % 10 == 0) {
|
if (tick > 0 && tick != 50 && tick % 10 == 0 && PsCurProc) {
|
||||||
KernLog("Blocking current process\n");
|
KernLog("Blocking current process\n");
|
||||||
PsBlockCurProc();
|
PsBlockCurProc();
|
||||||
}
|
}
|
||||||
|
|
|
@ -44,7 +44,7 @@ error_t CmdStarWars(int argc, char **argv, char *cmdline)
|
||||||
|
|
||||||
error_t CmdQuit(int argc, char **argv, char *cmdline)
|
error_t CmdQuit(int argc, char **argv, char *cmdline)
|
||||||
{
|
{
|
||||||
PoShutdownQemu();
|
PoShutdown();
|
||||||
return EOK;
|
return EOK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -80,42 +80,114 @@ error_t CmdMemMap(int argc, char **argv, char *cmdline)
|
||||||
return EOK;
|
return EOK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern ulong realKernelEnd;
|
||||||
|
|
||||||
error_t CmdMemUsage(int argc, char **argv, char *cmdline)
|
error_t CmdMemUsage(int argc, char **argv, char *cmdline)
|
||||||
{
|
{
|
||||||
size_t start, end;
|
size_t stack_cur;
|
||||||
size_t diff, max;
|
size_t img_diff, stack_diff;
|
||||||
|
size_t heap_start, heap_end;
|
||||||
|
size_t heap_diff, heap_max;
|
||||||
|
|
||||||
ulong flags = KePauseIRQs();
|
ulong flags = KePauseIRQs();
|
||||||
|
|
||||||
start = (size_t)_heap_start;
|
heap_start = (size_t)_heap_start;
|
||||||
end = (size_t)_heap_end;
|
heap_end = (size_t)_heap_end;
|
||||||
max = _heap_max;
|
heap_max = _heap_max;
|
||||||
|
|
||||||
KeRestoreIRQs(flags);
|
KeRestoreIRQs(flags);
|
||||||
|
|
||||||
diff = (size_t)end - (size_t)start;
|
img_diff = realKernelEnd - (size_t)BtLoaderInfo.kernelAddr;
|
||||||
|
stack_diff = (size_t)BtLoaderInfo.kernelEndAddr - (realKernelEnd + 1);
|
||||||
|
heap_diff = (size_t)heap_end - (size_t)heap_start;
|
||||||
|
|
||||||
KernLog("Heap start:\t\t%p (%luMB + %luKB + %luB)\n",
|
KernLog("Kernel image\n");
|
||||||
start, _ADDR_TO_MB(start),
|
|
||||||
_ADDR_TO_KB(start),
|
|
||||||
_ADDR_TO_B(start));
|
|
||||||
|
|
||||||
KernLog("Heap end:\t\t%p (%luMB + %luKB + %luB)\n",
|
KernLog("\tstarts at:\t\t%p (%04luMB + %04luKB + %04luB)\n",
|
||||||
end, _ADDR_TO_MB(end),
|
BtLoaderInfo.kernelAddr,
|
||||||
_ADDR_TO_KB(end),
|
_ADDR_TO_MB((size_t)BtLoaderInfo.kernelAddr),
|
||||||
_ADDR_TO_B(end));
|
_ADDR_TO_KB((size_t)BtLoaderInfo.kernelAddr),
|
||||||
|
_ADDR_TO_B((size_t)BtLoaderInfo.kernelAddr));
|
||||||
|
|
||||||
KernLog("Heap size:\t\t%luMB + %luKB + %luB (%#lx)\n",
|
KernLog("\tends at:\t\t%p (%04luMB + %04luKB + %04luB)\n",
|
||||||
_ADDR_TO_MB(diff),
|
realKernelEnd,
|
||||||
_ADDR_TO_KB(diff),
|
_ADDR_TO_MB(realKernelEnd),
|
||||||
_ADDR_TO_B(diff),
|
_ADDR_TO_KB(realKernelEnd),
|
||||||
diff);
|
_ADDR_TO_B(realKernelEnd));
|
||||||
|
|
||||||
KernLog("Max heap size:\t%luMB + %luKB + %luB (%#lx)\n",
|
KernLog("\tsize:\t\t\t%04luMB + %04luKB + %04luB (%p)\n",
|
||||||
_ADDR_TO_MB(max),
|
_ADDR_TO_MB(img_diff),
|
||||||
_ADDR_TO_KB(max),
|
_ADDR_TO_KB(img_diff),
|
||||||
_ADDR_TO_B(max),
|
_ADDR_TO_B(img_diff),
|
||||||
max);
|
img_diff);
|
||||||
|
|
||||||
|
KernLog("Kernel stack\n");
|
||||||
|
|
||||||
|
KernLog("\tstarts at:\t\t%p (%04luMB + %04luKB + %04luB)\n",
|
||||||
|
BtLoaderInfo.kernelEndAddr,
|
||||||
|
_ADDR_TO_MB((size_t)BtLoaderInfo.kernelEndAddr),
|
||||||
|
_ADDR_TO_KB((size_t)BtLoaderInfo.kernelEndAddr),
|
||||||
|
_ADDR_TO_B((size_t)BtLoaderInfo.kernelEndAddr));
|
||||||
|
|
||||||
|
BARRIER();
|
||||||
|
char var;
|
||||||
|
(void)var;
|
||||||
|
|
||||||
|
stack_cur = (size_t)BtLoaderInfo.kernelEndAddr - (size_t)&var;
|
||||||
|
|
||||||
|
KernLog("\tends at:\t\t%p (%04luMB + %04luKB + %04luB)\n",
|
||||||
|
stack_cur,
|
||||||
|
_ADDR_TO_MB(stack_cur),
|
||||||
|
_ADDR_TO_KB(stack_cur),
|
||||||
|
_ADDR_TO_B(stack_cur));
|
||||||
|
|
||||||
|
KernLog("\tmin addr:\t\t%p (%04luMB + %04luKB + %04luB)\n",
|
||||||
|
realKernelEnd+1,
|
||||||
|
_ADDR_TO_MB(realKernelEnd+1),
|
||||||
|
_ADDR_TO_KB(realKernelEnd+1),
|
||||||
|
_ADDR_TO_B(realKernelEnd+1));
|
||||||
|
|
||||||
|
KernLog("\tsize (cur):\t\t%04luMB + %04luKB + %04luB (%p)\n",
|
||||||
|
_ADDR_TO_MB(stack_cur),
|
||||||
|
_ADDR_TO_KB(stack_cur),
|
||||||
|
_ADDR_TO_B(stack_cur),
|
||||||
|
stack_cur);
|
||||||
|
|
||||||
|
KernLog("\tsize (max):\t\t%04luMB + %04luKB + %04luB (%p)\n",
|
||||||
|
_ADDR_TO_MB(stack_diff),
|
||||||
|
_ADDR_TO_KB(stack_diff),
|
||||||
|
_ADDR_TO_B(stack_diff),
|
||||||
|
stack_diff);
|
||||||
|
|
||||||
|
KernLog("Kernel heap\n");
|
||||||
|
|
||||||
|
KernLog("\tstarts at:\t\t%p (%04luMB + %04luKB + %04luB)\n",
|
||||||
|
heap_start, _ADDR_TO_MB(heap_start),
|
||||||
|
_ADDR_TO_KB(heap_start),
|
||||||
|
_ADDR_TO_B(heap_start));
|
||||||
|
|
||||||
|
KernLog("\tends at:\t\t%p (%04luMB + %04luKB + %04luB)\n",
|
||||||
|
heap_end, _ADDR_TO_MB(heap_end),
|
||||||
|
_ADDR_TO_KB(heap_end),
|
||||||
|
_ADDR_TO_B(heap_end));
|
||||||
|
|
||||||
|
KernLog("\tmax addr:\t\t%p (%04luMB + %04luKB + %04luB)\n",
|
||||||
|
heap_start + heap_max,
|
||||||
|
_ADDR_TO_MB(heap_start + heap_max),
|
||||||
|
_ADDR_TO_KB(heap_start + heap_max),
|
||||||
|
_ADDR_TO_B(heap_start + heap_max));
|
||||||
|
|
||||||
|
KernLog("\tsize (cur):\t\t%04luMB + %04luKB + %04luB (%p)\n",
|
||||||
|
_ADDR_TO_MB(heap_diff),
|
||||||
|
_ADDR_TO_KB(heap_diff),
|
||||||
|
_ADDR_TO_B(heap_diff),
|
||||||
|
heap_diff);
|
||||||
|
|
||||||
|
KernLog("\tsize (max):\t\t%04luMB + %04luKB + %04luB (%p)\n",
|
||||||
|
_ADDR_TO_MB(heap_max),
|
||||||
|
_ADDR_TO_KB(heap_max),
|
||||||
|
_ADDR_TO_B(heap_max),
|
||||||
|
heap_max);
|
||||||
|
|
||||||
return EOK;
|
return EOK;
|
||||||
}
|
}
|
||||||
|
|
|
@ -67,7 +67,7 @@ void KeStartShell(void)
|
||||||
memzero(argv0, ARG_MAX);
|
memzero(argv0, ARG_MAX);
|
||||||
shargv = &argv0;
|
shargv = &argv0;
|
||||||
|
|
||||||
KernLog("shell> ");
|
KernLog("\nshell> ");
|
||||||
BFlushBuf(BStdOut);
|
BFlushBuf(BStdOut);
|
||||||
|
|
||||||
while ((rc = BGetFromBuf(BStdIn, &ch)) == EOK || rc == EENDF) {
|
while ((rc = BGetFromBuf(BStdIn, &ch)) == EOK || rc == EENDF) {
|
||||||
|
@ -111,7 +111,7 @@ void KeStartShell(void)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case KEY_ESC:
|
case KEY_ESC:
|
||||||
PoShutdownQemu();
|
PoShutdown();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
|
|
@ -26,6 +26,7 @@
|
||||||
#include <extras/argv.h>
|
#include <extras/argv.h>
|
||||||
|
|
||||||
#include <kernel/mm.h>
|
#include <kernel/mm.h>
|
||||||
|
#include <kernel/boot.h>
|
||||||
#include <kernel/heap.h>
|
#include <kernel/heap.h>
|
||||||
#include <kernel/time.h>
|
#include <kernel/time.h>
|
||||||
#include <kernel/speaker.h>
|
#include <kernel/speaker.h>
|
||||||
|
|
Loading…
Reference in New Issue