From 1667bbac8600e5b65fd9775f40e92f2faffc4ec1 Mon Sep 17 00:00:00 2001 From: Ekaitz Zarraga Date: Wed, 18 Dec 2024 17:08:28 +0100 Subject: simulation: start with network server --- simulation.scm | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/simulation.scm b/simulation.scm index 417bde2..4087d78 100644 --- a/simulation.scm +++ b/simulation.scm @@ -156,17 +156,18 @@ (spawn-fiber upstream) (spawn-fiber downstream))) -(define (make-gateway id upstream downstream) +(define (make-gateway id in radio network) (define time-on-air 0.01) ;s (TODO) (define pending-interferences '()) (define (forward-frame x) - (ll "forwarding ~a" x)) + (ll "Gateway ~a forwarding ~a" id x) + (put-message network (make-network-event id x))) ;; Upstream: listen, and answer in new fibers (lambda () (forever - (let* ((ev (get-message upstream))) + (let* ((ev (get-message in))) (match ev (($ 'uplink-start channel-n frame) #f) (($ 'interference channel-n frame) @@ -275,8 +276,9 @@ (lambda () (forever - (match (ev (get-message upstream)) - (($ gateway-id frame) #f))))) + (match (get-message upstream) + (($ gateway-id frame) + (ll "Network event happend!")))))) @@ -286,7 +288,8 @@ (let* ((radio-chn (make-channel)) (end-devices (make-hash-table)) - (gateways (make-hash-table))) + (gateways (make-hash-table)) + (network-chn (make-channel))) (for-each (lambda (id) @@ -301,9 +304,11 @@ (let ((chn (make-channel))) (hash-table-set! gateways id - (make-device chn (make-gateway id chn radio-chn))))) + (make-device chn (make-gateway id chn radio-chn network-chn))))) (iota 1 2)) + (spawn-fiber (make-network-server network-chn gateways end-devices)) + (spawn-fiber (make-radio radio-chn end-devices gateways)) (hash-table-walk end-devices (lambda (_ device) (spawn-fiber (device-thunk device)))) -- cgit v1.2.3