From a5ef75b681ea65e71ea6f72abc3eaa39fb7f73df Mon Sep 17 00:00:00 2001 From: Michael Crosby Date: Mon, 3 Aug 2015 16:48:19 -0700 Subject: [PATCH] Add signal API to Container interface This adds a `Signal()` method to the container interface so that the initial process can be signaled after a Load or operation. It also implements signaling the init process from a nonChildProcess. Signed-off-by: Michael Crosby --- libcontainer/container.go | 8 ++++++++ libcontainer/container_linux.go | 7 +++++++ libcontainer/restored_process.go | 6 +++++- 3 files changed, 20 insertions(+), 1 deletion(-) diff --git a/libcontainer/container.go b/libcontainer/container.go index 567fc681..a24b71b8 100644 --- a/libcontainer/container.go +++ b/libcontainer/container.go @@ -5,6 +5,8 @@ package libcontainer import ( + "os" + "github.com/opencontainers/runc/libcontainer/configs" ) @@ -159,4 +161,10 @@ type Container interface { // errors: // Systemerror - System error. NotifyOOM() (<-chan struct{}, error) + + // Signal sends the provided signal code to the container's initial process. + // + // errors: + // Systemerror - System error. + Signal(s os.Signal) error } diff --git a/libcontainer/container_linux.go b/libcontainer/container_linux.go index 108c58f2..9a27eb43 100644 --- a/libcontainer/container_linux.go +++ b/libcontainer/container_linux.go @@ -118,6 +118,13 @@ func (c *linuxContainer) Start(process *Process) error { return nil } +func (c *linuxContainer) Signal(s os.Signal) error { + if err := c.initProcess.signal(s); err != nil { + return newSystemError(err) + } + return nil +} + func (c *linuxContainer) newParentProcess(p *Process, doInit bool) (parentProcess, error) { parentPipe, childPipe, err := newPipe() if err != nil { diff --git a/libcontainer/restored_process.go b/libcontainer/restored_process.go index 89dfa041..a96f4ca5 100644 --- a/libcontainer/restored_process.go +++ b/libcontainer/restored_process.go @@ -106,7 +106,11 @@ func (p *nonChildProcess) startTime() (string, error) { } func (p *nonChildProcess) signal(s os.Signal) error { - return newGenericError(fmt.Errorf("restored process cannot be signaled"), SystemError) + proc, err := os.FindProcess(p.processPid) + if err != nil { + return err + } + return proc.Signal(s) } func (p *nonChildProcess) externalDescriptors() []string {