Kernel: kernel doesn't allocate large blocks of data on stack
We used to allocate 1 KiB blocks on multiple places on stack. This is a problem, since kernel stack shouldn't have to be too big
This commit is contained in:
parent
40f9a42c00
commit
6f7045ead2
|
@ -557,7 +557,10 @@ argument_done:
|
||||||
int fd = TRY(Process::current()->open(arguments[1], O_RDONLY));
|
int fd = TRY(Process::current()->open(arguments[1], O_RDONLY));
|
||||||
BAN::ScopeGuard _([fd] { MUST(Process::current()->close(fd)); });
|
BAN::ScopeGuard _([fd] { MUST(Process::current()->close(fd)); });
|
||||||
|
|
||||||
char buffer[1024] {};
|
char* buffer = new char[1024];
|
||||||
|
BAN::ScopeGuard buffer_guard([buffer] { delete[] buffer; });
|
||||||
|
ASSERT(buffer);
|
||||||
|
|
||||||
while (size_t n_read = TRY(Process::current()->read(fd, buffer, sizeof(buffer))))
|
while (size_t n_read = TRY(Process::current()->read(fd, buffer, sizeof(buffer))))
|
||||||
TTY_PRINT("{}", BAN::StringView(buffer, n_read));
|
TTY_PRINT("{}", BAN::StringView(buffer, n_read));
|
||||||
TTY_PRINTLN("");
|
TTY_PRINTLN("");
|
||||||
|
@ -621,7 +624,10 @@ argument_done:
|
||||||
return {};
|
return {};
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t buffer[1024];
|
uint8_t* buffer = new uint8_t[1024];
|
||||||
|
BAN::ScopeGuard buffer_guard([buffer] { delete[] buffer; });
|
||||||
|
ASSERT(buffer);
|
||||||
|
|
||||||
for (size_t i = 1; i < arguments.size(); i++)
|
for (size_t i = 1; i < arguments.size(); i++)
|
||||||
{
|
{
|
||||||
int fd = TRY(Process::current()->open(arguments[i], O_RDONLY));
|
int fd = TRY(Process::current()->open(arguments[i], O_RDONLY));
|
||||||
|
|
|
@ -58,6 +58,10 @@ namespace Kernel
|
||||||
{
|
{
|
||||||
register_bus_irq_handler(this, irq);
|
register_bus_irq_handler(this, irq);
|
||||||
|
|
||||||
|
uint16_t* identify_buffer = new uint16_t[256];
|
||||||
|
ASSERT(identify_buffer);
|
||||||
|
BAN::ScopeGuard _([identify_buffer] { delete[] identify_buffer; });
|
||||||
|
|
||||||
for (uint8_t i = 0; i < 2; i++)
|
for (uint8_t i = 0; i < 2; i++)
|
||||||
{
|
{
|
||||||
m_devices[i] = new ATADevice(this);
|
m_devices[i] = new ATADevice(this);
|
||||||
|
@ -66,7 +70,7 @@ namespace Kernel
|
||||||
|
|
||||||
BAN::ScopeGuard guard([this, i] { m_devices[i]->unref(); m_devices[i] = nullptr; });
|
BAN::ScopeGuard guard([this, i] { m_devices[i]->unref(); m_devices[i] = nullptr; });
|
||||||
|
|
||||||
uint16_t identify_buffer[256];
|
|
||||||
auto type = identify(device, identify_buffer);
|
auto type = identify(device, identify_buffer);
|
||||||
if (type == DeviceType::None)
|
if (type == DeviceType::None)
|
||||||
continue;
|
continue;
|
||||||
|
|
|
@ -38,8 +38,9 @@ namespace Kernel
|
||||||
{
|
{
|
||||||
m_width = m_terminal_driver->width();
|
m_width = m_terminal_driver->width();
|
||||||
m_height = m_terminal_driver->height();
|
m_height = m_terminal_driver->height();
|
||||||
|
|
||||||
m_buffer = new Cell[m_width * m_height];
|
m_buffer = new Cell[m_width * m_height];
|
||||||
|
ASSERT(m_buffer);
|
||||||
|
|
||||||
if (s_tty == nullptr)
|
if (s_tty == nullptr)
|
||||||
s_tty = this;
|
s_tty = this;
|
||||||
|
|
Loading…
Reference in New Issue