Re: Why can setuid programs regain root after dropping it when usingcapabilities?

From: Jan Engelhardt
Date: Sun Jan 01 2006 - 10:25:24 EST



>>While debugging some code, I found that a setuid program could regain
>>root after dropping root if the program used capabilities. (I tested
>>this on 2.6.14 and 2.6.9.) Is this the expected behavior? Here's a
>>short test case:
>>
>>/* chown root this program, suid it, and run it as non-root */
>>#include <sys/types.h>
>>#include <sys/capability.h>
>>#include <unistd.h>
>>#include <stdio.h>
>>int main() {
>> cap_set_proc(cap_from_text("all-eip")); /* drop all caps */
>> setuid(getuid()); /* drop root. this call succeeds */
>> setuid(0); /* this should fail! but doesn't */

uid != euid. You would probably have to use

seteuid(getuid());

Plus there is also the feature of saved ids, see sys_setresuid().



Jan Engelhardt
--
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/