diff options
author | Jamie Liu <jamieliu@google.com> | 2021-09-02 15:48:04 -0700 |
---|---|---|
committer | gVisor bot <gvisor-bot@google.com> | 2021-09-02 15:50:49 -0700 |
commit | 2aeab259c4d24f87d7788fed338b64d99e0865ec (patch) | |
tree | 3f42007a3d7a7d810ca9e3c8a2705b93682fd3d3 /pkg/flipcall/ctrl_futex.go | |
parent | 9149b2cefdb5883e41416aecea16fba4c5cd3ac1 (diff) |
Internal change.
PiperOrigin-RevId: 394560866
Diffstat (limited to 'pkg/flipcall/ctrl_futex.go')
-rw-r--r-- | pkg/flipcall/ctrl_futex.go | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/pkg/flipcall/ctrl_futex.go b/pkg/flipcall/ctrl_futex.go index 5d2ee4018..99410628f 100644 --- a/pkg/flipcall/ctrl_futex.go +++ b/pkg/flipcall/ctrl_futex.go @@ -121,7 +121,7 @@ func (ep *Endpoint) ctrlWaitFirst() error { return ep.futexWaitUntilActive() } -func (ep *Endpoint) ctrlRoundTrip() error { +func (ep *Endpoint) ctrlRoundTrip(mayRetainP bool) error { if err := ep.enterFutexWait(); err != nil { return err } @@ -133,6 +133,9 @@ func (ep *Endpoint) ctrlRoundTrip() error { if err := ep.futexWakePeer(); err != nil { return err } + // Since we don't know if the peer Endpoint is in the same process as this + // one (in which case it may need our P to run), we allow our P to be + // retaken regardless of mayRetainP. return ep.futexWaitUntilActive() } |