Kernel: Clearing promises with pledge("") should fail

Thanks Sergey for catching this brain-fart. :^)
This commit is contained in:
Andreas Kling 2020-01-12 12:14:08 +01:00
commit d1839ae0c9
Notes: sideshowbarker 2024-07-19 10:08:33 +09:00

View file

@ -4417,7 +4417,7 @@ int Process::sys$pledge(const Syscall::SC_pledge_params* user_params)
u32 new_promises = 0;
if (!parse_pledge(promises, new_promises))
return -EINVAL;
if (m_promises && new_promises & ~m_promises)
if (m_promises && (!new_promises || new_promises & ~m_promises))
return -EPERM;
m_promises = new_promises;
}
@ -4426,7 +4426,7 @@ int Process::sys$pledge(const Syscall::SC_pledge_params* user_params)
u32 new_execpromises = 0;
if (!parse_pledge(execpromises, new_execpromises))
return -EINVAL;
if (m_execpromises && new_execpromises & ~m_execpromises)
if (m_execpromises && (!new_execpromises || new_execpromises & ~m_execpromises))
return -EPERM;
m_execpromises = new_execpromises;
}