mirror of
https://github.com/genodelabs/genode.git
synced 2025-01-11 15:33:04 +00:00
libc: checks for initialization and user context
We check if the libc (kernel singleton, config) was initialized and also if suspend() is called from the valid user context. Issue #2332
This commit is contained in:
parent
88db3c0df7
commit
67ac0dde6e
@ -524,6 +524,13 @@ struct Libc::Kernel
|
|||||||
unsigned long _suspend_main(Suspend_functor &check,
|
unsigned long _suspend_main(Suspend_functor &check,
|
||||||
unsigned long timeout_ms)
|
unsigned long timeout_ms)
|
||||||
{
|
{
|
||||||
|
/* check if we're running on the user context */
|
||||||
|
if (Thread::myself()->mystack().top != (Genode::addr_t)_user_stack) {
|
||||||
|
error("libc suspend() called from non-user context (",
|
||||||
|
__builtin_return_address(0), ") - aborting");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
if (!check.suspend())
|
if (!check.suspend())
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
@ -774,9 +781,12 @@ static void resumed_callback() { kernel->entrypoint_resumed(); }
|
|||||||
void Libc::resume_all() { kernel->resume_all(); }
|
void Libc::resume_all() { kernel->resume_all(); }
|
||||||
|
|
||||||
|
|
||||||
unsigned long Libc::suspend(Suspend_functor &s,
|
unsigned long Libc::suspend(Suspend_functor &s, unsigned long timeout_ms)
|
||||||
unsigned long timeout_ms)
|
|
||||||
{
|
{
|
||||||
|
if (!kernel) {
|
||||||
|
error("libc kernel not initialized, needed for suspend()");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
return kernel->suspend(s, timeout_ms);
|
return kernel->suspend(s, timeout_ms);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -789,8 +799,8 @@ unsigned long Libc::current_time()
|
|||||||
void Libc::schedule_suspend(void (*suspended) ())
|
void Libc::schedule_suspend(void (*suspended) ())
|
||||||
{
|
{
|
||||||
if (!kernel) {
|
if (!kernel) {
|
||||||
error("libc kernel not initialized, needed for suspend()");
|
error("libc kernel not initialized, needed for fork()");
|
||||||
return;
|
exit(1);
|
||||||
}
|
}
|
||||||
kernel->schedule_suspend(suspended);
|
kernel->schedule_suspend(suspended);
|
||||||
}
|
}
|
||||||
@ -800,7 +810,7 @@ void Libc::schedule_select(Libc::Select_handler_base *h)
|
|||||||
{
|
{
|
||||||
if (!kernel) {
|
if (!kernel) {
|
||||||
error("libc kernel not initialized, needed for select()");
|
error("libc kernel not initialized, needed for select()");
|
||||||
return;
|
exit(1);
|
||||||
}
|
}
|
||||||
kernel->schedule_select(h);
|
kernel->schedule_select(h);
|
||||||
}
|
}
|
||||||
@ -813,6 +823,11 @@ void Libc::execute_in_application_context(Libc::Application_code &app_code)
|
|||||||
* don't use this code.
|
* don't use this code.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
if (!kernel) {
|
||||||
|
error("libc kernel not initialized, needed for with_libc()");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
static bool nested = false;
|
static bool nested = false;
|
||||||
|
|
||||||
if (nested) {
|
if (nested) {
|
||||||
@ -825,11 +840,6 @@ void Libc::execute_in_application_context(Libc::Application_code &app_code)
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!kernel) {
|
|
||||||
error("libc kernel not initialized, needed for with_libc()");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
nested = true;
|
nested = true;
|
||||||
kernel->run(app_code);
|
kernel->run(app_code);
|
||||||
nested = false;
|
nested = false;
|
||||||
|
@ -91,6 +91,10 @@ namespace Libc {
|
|||||||
Genode::Xml_node config() __attribute__((weak));
|
Genode::Xml_node config() __attribute__((weak));
|
||||||
Genode::Xml_node config()
|
Genode::Xml_node config()
|
||||||
{
|
{
|
||||||
|
if (!_config_node) {
|
||||||
|
error("libc config not initialized - aborting");
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
return *_config_node;
|
return *_config_node;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user