diff options
| author | Aleksandr Nogikh <nogikh@google.com> | 2024-05-03 18:49:35 +0200 |
|---|---|---|
| committer | Dmitry Vyukov <dvyukov@google.com> | 2024-05-16 15:38:27 +0000 |
| commit | 5b8f52cdd0b790158fdbe88d0fd902d24f8a996d (patch) | |
| tree | 2827ebd34598426f41ad4c1e43c0549f29e8446a /pkg/fuzzer/queue/queue.go | |
| parent | 03820adaef911ce08278d95f034f134c3c0c852e (diff) | |
pkg/fuzzer: introduce a request restarter layer
Make Result statuses more elaborate.
Instead of retrying inputs directly in rpc.go, extract this logic to a
separate entity in pkg/fuzzer/queue.
Diffstat (limited to 'pkg/fuzzer/queue/queue.go')
| -rw-r--r-- | pkg/fuzzer/queue/queue.go | 49 |
1 files changed, 37 insertions, 12 deletions
diff --git a/pkg/fuzzer/queue/queue.go b/pkg/fuzzer/queue/queue.go index 00e83a69e..cb5aa134b 100644 --- a/pkg/fuzzer/queue/queue.go +++ b/pkg/fuzzer/queue/queue.go @@ -72,7 +72,7 @@ func (r *Request) Wait(ctx context.Context) *Result { r.initChannel() select { case <-ctx.Done(): - return &Result{Stop: true} + return &Result{Status: ExecFailure} case <-r.done: return r.result } @@ -95,10 +95,23 @@ const ( ) type Result struct { - Info *ipc.ProgInfo - Stop bool + Info *ipc.ProgInfo + Status Status } +func (r *Result) Stop() bool { + return r.Status == ExecFailure || r.Status == Crashed +} + +type Status int + +const ( + Success Status = iota + ExecFailure // For e.g. serialization errors. + Crashed // The VM crashed holding the request. + Restarted // The VM was restarted holding the request. +) + // Executor describes the interface wanted by the producers of requests. // After a Request is submitted, it's expected that the consumer will eventually // take it and report the execution result via Done(). @@ -157,16 +170,28 @@ func (pq *PlainQueue) Submit(req *Request) { func (pq *PlainQueue) Next() *Request { pq.mu.Lock() defer pq.mu.Unlock() - if pq.pos < len(pq.queue) { - ret := pq.queue[pq.pos] - pq.queue[pq.pos] = nil - pq.pos++ - if pq.stat != nil { - pq.stat.Add(-1) - } - return ret + return pq.nextLocked() +} + +func (pq *PlainQueue) tryNext() *Request { + if !pq.mu.TryLock() { + return nil } - return nil + defer pq.mu.Unlock() + return pq.nextLocked() +} + +func (pq *PlainQueue) nextLocked() *Request { + if pq.pos == len(pq.queue) { + return nil + } + ret := pq.queue[pq.pos] + pq.queue[pq.pos] = nil + pq.pos++ + if pq.stat != nil { + pq.stat.Add(-1) + } + return ret } // Order combines several different sources in a particular order. |
