From: Serge Aleynikov <serge@hq.idt.net>
To: "Serge E. Hallyn" <serue@us.ibm.com>
Cc: linux-kernel@vger.kernel.org, Linus Torvalds <torvalds@osdl.org>,
Alan Cox <alan@redhat.com>
Subject: Re: non-critical security bug fix
Date: Thu, 12 Oct 2006 15:25:57 -0400 [thread overview]
Message-ID: <452E96C5.8070307@hq.idt.net> (raw)
In-Reply-To: <20061012190647.GA6725@sergelap.austin.ibm.com>
Serge (what a nice name! ;-) ),
Let me give you an example where we found this patch very useful.
A 3rd party library that we bought implemented a user-level SCTP
protocol by opening raw sockets. This required our application to run
as root. However, we didn't want for it to run as root, and wanted to
set the CAP_NET_RAW option and have the interaction with the raw socket
survive after when we switch the effective user away from root.
When reading "man capabilities" we found:
"If a process that has a 0 value for one or more of its user IDs
wants to prevent its permitted capability set being cleared when it
resets all of its user IDs to non-zero values, it can do so using
the prctl() PR_SET_KEEPCAPS operation."
Correct me if I am wrong, but I believe that this sentence says just
what I described above. If so, the previously attached patch has the
behavior described in the man page.
Regards,
--
Serge Aleynikov
Routing R&D, IDT Telecom
Tel: +1 (973) 438-3436
Fax: +1 (973) 438-1464
Serge E. Hallyn wrote:
> Quoting Serge Aleynikov (serge@hq.idt.net):
>> To Maintainers of the linux/security/commoncap.c:
>>
>> Patch description:
>> ==================
>> This bug-fix ensures that if a process with root access sets
>> keep_capabilities flag, current capabilities get preserved when the
>> process switches from root to another effective user. It looks like
>> this was intended from the way capabilities are documented, but the
>> current->keep_capabilities flag is not being checked.
>
> Note that without your patch, the permitted set is maintained, so that
> you can regain the caps into your effective set after setuid if you
> need. i.e.
>
> prctl(PR_SET_KEEPCAPS, 1);
> setresuid(1000, 1000, 1000);
> caps = cap_from_text("cap_net_admin,cap_sys_admin,cap_dac_override=ep");
> ret = cap_set_proc(caps);
>
> So this patch will change the default behavior, but does not add
> features or change what is possible.
>
> Ordinarely I'd say changing default behavior wrt security is a bad
> thing, but given that this is "default behavior when doing prctl(PR_SET_KEEPCAPS)",
> I don't know how much it matters.
>
> Still, I like the current behavior, where setuid means drop effective
> caps no matter what.
>
> -serge
>
next prev parent reply other threads:[~2006-10-12 19:25 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-10-11 18:58 non-critical security bug fix Serge Aleynikov
2006-10-12 19:06 ` Serge E. Hallyn
2006-10-12 19:25 ` Serge Aleynikov [this message]
2006-10-12 20:29 ` Serge E. Hallyn
2006-10-12 21:11 ` Serge Aleynikov
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=452E96C5.8070307@hq.idt.net \
--to=serge@hq.idt.net \
--cc=alan@redhat.com \
--cc=linux-kernel@vger.kernel.org \
--cc=serue@us.ibm.com \
--cc=torvalds@osdl.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox