summaryrefslogtreecommitdiffhomepage
path: root/pkg/sentry/fsimpl/gofer/regular_file.go
diff options
context:
space:
mode:
authorAyush Ranjan <ayushranjan@google.com>2021-10-19 16:45:09 -0700
committergVisor bot <gvisor-bot@google.com>2021-10-19 16:47:44 -0700
commit1b494b80f02774ee109ccb7e20d9c2fe59b8cf72 (patch)
treebac01f38e8c152ace1533cb1c206213cdac83b66 /pkg/sentry/fsimpl/gofer/regular_file.go
parent64aee33ed0e1a422c3e2954de8f1d3f219ed14b8 (diff)
Do not return non-nil *lisafs.Inode to doCreateAt on error.
lisafs.ClientFile.MkdirAt is allowed to return a non-nil Inode and a non-nil error on an RPC error. The caller must not use the returned (invalid) Inode on error. But a code path in the gofer client does end up using it. More specifically, when the Mkdir RPC fails and we end up creating a synthetic dentry for a mountpoint, we end up returning the (invalid) non-nil Inode to filesystem.doCreateAt implementation which thinks that a remote file was created. But that non-nil Inode is actually invalid because the RPC failed. Things go downhill from there. Update client to not use childDirInode if RPC failed. PiperOrigin-RevId: 404396573
Diffstat (limited to 'pkg/sentry/fsimpl/gofer/regular_file.go')
0 files changed, 0 insertions, 0 deletions