diff options
author | gVisor bot <gvisor-bot@google.com> | 2020-10-22 02:20:01 +0000 |
---|---|---|
committer | gVisor bot <gvisor-bot@google.com> | 2020-10-22 02:20:01 +0000 |
commit | 5e18bb6c3270315dda1ccbd2c3530f05c353120f (patch) | |
tree | c1b02a60714b134db729a1408af05930dc9af2b2 /pkg | |
parent | d29c1e0f6fb872fb7661ba9a3642d137885794e6 (diff) | |
parent | 4e389c785779114620b47e005d08ca469cc1ed68 (diff) |
Merge release-20201019.0-28-g4e389c785 (automated)
Diffstat (limited to 'pkg')
-rw-r--r-- | pkg/sentry/kernel/fs_context.go | 20 |
1 files changed, 13 insertions, 7 deletions
diff --git a/pkg/sentry/kernel/fs_context.go b/pkg/sentry/kernel/fs_context.go index d46d1e1c1..08ea2e09c 100644 --- a/pkg/sentry/kernel/fs_context.go +++ b/pkg/sentry/kernel/fs_context.go @@ -147,19 +147,23 @@ func (f *FSContext) WorkingDirectory() *fs.Dirent { f.mu.Lock() defer f.mu.Unlock() - f.cwd.IncRef() + if f.cwd != nil { + f.cwd.IncRef() + } return f.cwd } // WorkingDirectoryVFS2 returns the current working directory. // -// This will return nil if called after f is destroyed, otherwise it will return -// a Dirent with a reference taken. +// This will return an empty vfs.VirtualDentry if called after f is +// destroyed, otherwise it will return a Dirent with a reference taken. func (f *FSContext) WorkingDirectoryVFS2() vfs.VirtualDentry { f.mu.Lock() defer f.mu.Unlock() - f.cwdVFS2.IncRef() + if f.cwdVFS2.Ok() { + f.cwdVFS2.IncRef() + } return f.cwdVFS2 } @@ -218,13 +222,15 @@ func (f *FSContext) RootDirectory() *fs.Dirent { // RootDirectoryVFS2 returns the current filesystem root. // -// This will return nil if called after f is destroyed, otherwise it will return -// a Dirent with a reference taken. +// This will return an empty vfs.VirtualDentry if called after f is +// destroyed, otherwise it will return a Dirent with a reference taken. func (f *FSContext) RootDirectoryVFS2() vfs.VirtualDentry { f.mu.Lock() defer f.mu.Unlock() - f.rootVFS2.IncRef() + if f.rootVFS2.Ok() { + f.rootVFS2.IncRef() + } return f.rootVFS2 } |