summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--simulation.scm19
1 files 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
(($ <radio-event> 'uplink-start channel-n frame) #f)
(($ <radio-event> 'interference channel-n frame)
@@ -275,8 +276,9 @@
(lambda ()
(forever
- (match (ev (get-message upstream))
- (($ <network-event> gateway-id frame) #f)))))
+ (match (get-message upstream)
+ (($ <network-event> 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))))