diff options
author | gVisor bot <gvisor-bot@google.com> | 2020-02-26 03:16:03 +0000 |
---|---|---|
committer | gVisor bot <gvisor-bot@google.com> | 2020-02-26 03:16:03 +0000 |
commit | c065c5f9eeec194fe40dadb5f2396fd078474299 (patch) | |
tree | 070bd17cc0ef22fcd8d2834f2d4c95cff7c58295 /pkg/sentry/vfs/vfs.go | |
parent | 834ceb8b0d7550793610ed0173c3fa669f53b46c (diff) | |
parent | a92087f0f8fe82ce99414ec99ffe33e514cb21f6 (diff) |
Merge release-20200219.0-46-ga92087f (automated)
Diffstat (limited to 'pkg/sentry/vfs/vfs.go')
-rwxr-xr-x | pkg/sentry/vfs/vfs.go | 16 |
1 files changed, 11 insertions, 5 deletions
diff --git a/pkg/sentry/vfs/vfs.go b/pkg/sentry/vfs/vfs.go index 73f8043be..bde81e1ef 100755 --- a/pkg/sentry/vfs/vfs.go +++ b/pkg/sentry/vfs/vfs.go @@ -126,17 +126,23 @@ func (vfs *VirtualFilesystem) Init() error { // Construct vfs.anonMount. anonfsDevMinor, err := vfs.GetAnonBlockDevMinor() if err != nil { - return err + // This shouldn't be possible since anonBlockDevMinorNext was + // initialized to 1 above (no device numbers have been allocated yet). + panic(fmt.Sprintf("VirtualFilesystem.Init: device number allocation for anonfs failed: %v", err)) } anonfs := anonFilesystem{ devMinor: anonfsDevMinor, } anonfs.vfsfs.Init(vfs, &anonfs) - vfs.anonMount = &Mount{ - vfs: vfs, - fs: &anonfs.vfsfs, - refs: 1, + defer anonfs.vfsfs.DecRef() + anonMount, err := vfs.NewDisconnectedMount(&anonfs.vfsfs, nil, &MountOptions{}) + if err != nil { + // We should not be passing any MountOptions that would cause + // construction of this mount to fail. + panic(fmt.Sprintf("VirtualFilesystem.Init: anonfs mount failed: %v", err)) } + vfs.anonMount = anonMount + return nil } |