Skip to content

Instantly share code, notes, and snippets.

@samdphillips
Created November 1, 2022 21:23
Show Gist options
  • Save samdphillips/dbf0bf73d3dcb173c8a5bb5cad31fb1a to your computer and use it in GitHub Desktop.
Save samdphillips/dbf0bf73d3dcb173c8a5bb5cad31fb1a to your computer and use it in GitHub Desktop.
#lang racket/base
(require syncvar/mvar)
(provide make-barrier
barrier-wait-evt
barrier-wait
log-barrier-info)
(define-logger barrier)
(struct barrier (count ready-sema))
(define (make-barrier count)
(barrier (make-mvar count) (make-semaphore 0)))
(define (barrier-wait-evt a-barrier)
(nack-guard-evt
(λ (nack-evt)
(define count (barrier-count a-barrier))
(mvar-update! count sub1)
(thread (λ ()
(sync nack-evt)
(mvar-update! count add1)))
(cond
[(<= (mvar-get count) 0)
(wrap-evt
always-evt
(λ (v) (semaphore-post (barrier-ready-sema a-barrier))))]
[else
(wrap-evt (semaphore-peek-evt (barrier-ready-sema a-barrier))
void)]))))
(define (barrier-wait a-barrier)
(sync (barrier-wait-evt a-barrier)))
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment