summaryrefslogtreecommitdiff
path: root/lkm/union
diff options
context:
space:
mode:
authorArtur Grabowski <art@cvs.openbsd.org>2001-06-15 11:10:19 +0000
committerArtur Grabowski <art@cvs.openbsd.org>2001-06-15 11:10:19 +0000
commit9680a34c3c5c28dbaeb36067ad52529b14e36654 (patch)
tree3f66011329aba3904b72ecef05b4ccdc2c02d821 /lkm/union
parentc22afdde6f8ae460fef0316c2a3587f9d9edc687 (diff)
Avoid a dangerous race.
To avoid having a ptrace(2)d process from doing an exec of a suid binary we strip off the suid bits from the executable if the process is traced. Later we P_SUGID{,EXEC} in the process flags that stops further ptrace attempts. The problem is that between the stripping of suid bits and setting P_SUGID{,EXEC} there is a pretty large window where the process can sleep and other processes can attach to it with ptrace. This is a quick fix for that. We set P_SUGID{,EXEC} early and take care to remove them (we don't want the process to become tainted unnecessarily) if exec fails. XXX - exec needs a lot more work, but people are asking for a solution now.
Diffstat (limited to 'lkm/union')
0 files changed, 0 insertions, 0 deletions