Kernel: Fix pledge syscall applying new pledges when it fails (#2076)

If the exec promises fail to apply, then the normal promises should
not apply either. Add a test for this fixed functionality.
This commit is contained in:
Michael Lelli 2020-05-02 17:41:18 -05:00 committed by GitHub
parent 37d1b0c875
commit 58a34fbe09
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
Notes: sideshowbarker 2024-07-19 07:01:57 +09:00
2 changed files with 37 additions and 4 deletions

View file

@ -4826,24 +4826,32 @@ int Process::sys$pledge(const Syscall::SC_pledge_params* user_params)
return true;
};
u32 new_promises;
u32 new_execpromises;
if (!promises.is_null()) {
u32 new_promises = 0;
new_promises = 0;
if (!parse_pledge(promises, new_promises))
return -EINVAL;
if (m_promises && (!new_promises || new_promises & ~m_promises))
return -EPERM;
m_promises = new_promises;
} else {
new_promises = m_promises;
}
if (!execpromises.is_null()) {
u32 new_execpromises = 0;
new_execpromises = 0;
if (!parse_pledge(execpromises, new_execpromises))
return -EINVAL;
if (m_execpromises && (!new_execpromises || new_execpromises & ~m_execpromises))
return -EPERM;
m_execpromises = new_execpromises;
} else {
new_execpromises = m_execpromises;
}
m_promises = new_promises;
m_execpromises = new_execpromises;
return 0;
}

View file

@ -0,0 +1,25 @@
#include <stdio.h>
#include <unistd.h>
int main(int argc, char** argv)
{
int res = pledge("stdio unix rpath", "stdio");
if (res < 0) {
perror("pledge");
return 1;
}
res = pledge("stdio unix", "stdio unix");
if (res >= 0) {
fprintf(stderr, "second pledge should have failed\n");
return 1;
}
res = pledge("stdio rpath", "stdio");
if (res < 0) {
perror("pledge");
return 1;
}
return 0;
}