Skip to content

Commit

Permalink
device: Do not allow container access to the nvdimm rootfs
Browse files Browse the repository at this point in the history
With this change, a container is not longer given access to
the underlying nvdimm root partition.
This is done by explicitly adding the nvdimm root partition
to the device cgroup of the container.

Fixes kata-containers#791

Signed-off-by: Archana Shinde <archana.m.shinde@intel.com>
  • Loading branch information
amshinde committed Jun 3, 2020
1 parent 906f7e2 commit a88af32
Show file tree
Hide file tree
Showing 3 changed files with 52 additions and 0 deletions.
26 changes: 26 additions & 0 deletions device.go
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@ const (
driverNvdimmType = "nvdimm"
driverEphemeralType = "ephemeral"
driverLocalType = "local"
vmRootfs = "/"
)

const (
Expand Down Expand Up @@ -472,3 +473,28 @@ func addDevice(ctx context.Context, device *pb.Device, spec *pb.Spec, s *sandbox

return devHandler(ctx, *device, spec, s)
}

// updateDeviceCgroupForGuestRootfs updates the device cgroup for container
// to not allow access to the nvdim root partition. This prevents the container
// from being able to access the VM rootfs.
func updateDeviceCgroupForGuestRootfs(spec *pb.Spec) {
var devStat unix.Stat_t

err := unix.Stat(vmRootfs, &devStat)
if err != nil {
return
}

devMajor := int64(unix.Major(devStat.Dev))
devMinor := int64(unix.Minor(devStat.Dev))

nvdimmCg := pb.LinuxDeviceCgroup{
Allow: false,
Major: devMajor,
Minor: devMinor,
Type: "b",
Access: "rwm",
}

spec.Linux.Resources.Devices = append(spec.Linux.Resources.Devices, nvdimmCg)
}
23 changes: 23 additions & 0 deletions device_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ import (

pb "github.com/kata-containers/agent/protocols/grpc"
"github.com/stretchr/testify/assert"
"golang.org/x/sys/unix"
)

var (
Expand Down Expand Up @@ -728,3 +729,25 @@ func TestGetDeviceName(t *testing.T) {
assert.Nil(err)
assert.Equal(name, path.Join(devRootPath, devName))
}

func TestUpdateDeviceCgroupForGuestRootfs(t *testing.T) {
skipUnlessRoot(t)
assert := assert.New(t)

spec := &pb.Spec{}

spec.Linux = &pb.Linux{}
spec.Linux.Resources = &pb.LinuxResources{}

updateDeviceCgroupForGuestRootfs(spec)
assert.Equal(1, len(spec.Linux.Resources.Devices))

var devStat unix.Stat_t
err := unix.Stat(vmRootfs, &devStat)
if err != nil {
return
}

assert.Equal(spec.Linux.Resources.Devices[0].Major, int64(unix.Major(devStat.Dev)))
assert.Equal(spec.Linux.Resources.Devices[0].Minor, int64(unix.Minor(devStat.Dev)))
}
3 changes: 3 additions & 0 deletions grpc.go
Original file line number Diff line number Diff line change
Expand Up @@ -654,6 +654,9 @@ func (a *agentGRPC) CreateContainer(ctx context.Context, req *pb.CreateContainer
}
}()

// Add the nvdimm root partition to the device cgroup to prevent access
updateDeviceCgroupForGuestRootfs(req.OCI)

// Convert the spec to an actual OCI specification structure.
ociSpec, err := pb.GRPCtoOCI(req.OCI)
if err != nil {
Expand Down

0 comments on commit a88af32

Please # to comment.