mirror of
https://git.savannah.gnu.org/git/guix.git
synced 2025-01-18 21:46:35 +01:00
system: Allow users to PTRACE_ATTACH to their own processes.
* gnu/build/activation.scm (activate-ptrace-attach): New procedure. * gnu/system.scm (operating-system-activation-script): Use it.
This commit is contained in:
parent
ce6fc7d6a5
commit
b158f1d751
2 changed files with 16 additions and 0 deletions
|
@ -30,6 +30,7 @@ (define-module (gnu build activation)
|
|||
activate-/bin/sh
|
||||
activate-modprobe
|
||||
activate-firmware
|
||||
activate-ptrace-attach
|
||||
activate-current-system))
|
||||
|
||||
;;; Commentary:
|
||||
|
@ -335,6 +336,18 @@ (define (activate-firmware directory)
|
|||
(lambda (port)
|
||||
(display directory port))))
|
||||
|
||||
(define (activate-ptrace-attach)
|
||||
"Allow users to PTRACE_ATTACH their own processes.
|
||||
|
||||
This works around a regression introduced in the default \"security\" policy
|
||||
found in Linux 3.4 onward that prevents users from attaching to their own
|
||||
processes--see Yama.txt in the Linux source tree for the rationale. This
|
||||
sounds like an unacceptable restriction for little or no security
|
||||
improvement."
|
||||
(call-with-output-file "/proc/sys/kernel/yama/ptrace_scope"
|
||||
(lambda (port)
|
||||
(display 0 port))))
|
||||
|
||||
|
||||
(define %current-system
|
||||
;; The system that is current (a symlink.) This is not necessarily the same
|
||||
|
|
|
@ -681,6 +681,9 @@ (define group-specs
|
|||
(activate-firmware
|
||||
(string-append #$firmware "/lib/firmware"))
|
||||
|
||||
;; Let users debug their own processes!
|
||||
(activate-ptrace-attach)
|
||||
|
||||
;; Run the services' activation snippets.
|
||||
;; TODO: Use 'load-compiled'.
|
||||
(for-each primitive-load '#$actions)
|
||||
|
|
Loading…
Reference in a new issue