Cannot output from stack
Posted: Tue Aug 11, 2009 7:51 am
I've already implemented multitasking and a simple form of IPC in my kernel. I'm trying to set up a simple system under it with a shell and console driver. The way it works is that the shell sends a signal (sort of like *nix signals, but more like a small message) to the console driver. The console driver then asks the kernel to map a page of memory from the shell's address space (where the buffer to be printed is) to a location into the driver's own address space. The proper memory location is then read directly from this remapping and printed to the screen.
So far, this has been working fine, as long as the buffer is a global variable (i.e. in the data section). However, if I allocate the buffer on the stack as a local variable, the driver prints out either nothing or garbage. I have compensated for the buffer not being page aligned, and that is not the problem. I also tried enabling write-through caching and disabling caching, both on the pages in the stack and on the system as a whole (by setting flags on CR3). I checked the addresses being passed to the driver, and they are also correct. There are no compiler optimizations - optimizing breaks both cases. Any idea what the problem could be?
So far, this has been working fine, as long as the buffer is a global variable (i.e. in the data section). However, if I allocate the buffer on the stack as a local variable, the driver prints out either nothing or garbage. I have compensated for the buffer not being page aligned, and that is not the problem. I also tried enabling write-through caching and disabling caching, both on the pages in the stack and on the system as a whole (by setting flags on CR3). I checked the addresses being passed to the driver, and they are also correct. There are no compiler optimizations - optimizing breaks both cases. Any idea what the problem could be?