summaryrefslogtreecommitdiff
path: root/simulation.scm
diff options
context:
space:
mode:
Diffstat (limited to 'simulation.scm')
-rw-r--r--simulation.scm58
1 files changed, 37 insertions, 21 deletions
diff --git a/simulation.scm b/simulation.scm
index ee71d10..4ce8fc0 100644
--- a/simulation.scm
+++ b/simulation.scm
@@ -158,7 +158,7 @@
(define (make-gateway id upstream downstream)
(define time-on-air 0.01) ;s (TODO)
- (define radio-interference-queue '())
+ (define pending-interferences '())
(define (forward-frame x)
(ll "forwarding ~a" x))
@@ -170,13 +170,13 @@
(match ev
(($ <radio-event> 'uplink-start channel-n frame) #f)
(($ <radio-event> 'interference channel-n frame)
- (set! radio-interference-queue (cons ev radio-interference-queue)))
+ (set! pending-interferences (cons ev pending-interferences)))
(($ <radio-event> 'uplink-end channel-n frame)
(let-values (((mine not-mine)
(partition (lambda (x) (eq? (radio-event-frame x)
(radio-event-frame ev)))
- radio-interference-queue)))
- (set! radio-interference-queue not-mine)
+ pending-interferences)))
+ (set! pending-interferences not-mine)
(when (null? mine) ;; TODO
(forward-frame frame)))))))))
@@ -186,8 +186,9 @@
;; We can access it only from one fiber! Careful!
(define lorawan-channels (make-hash-table))
- (define (interference? chn)
- (< 1 (length (hash-table-ref lorawan-channels chn))))
+ (define (interferences ev chn)
+ (let ((res (hash-table-ref/default lorawan-channels chn '())))
+ (if (equal? res (list ev)) '() res)))
(define (use-lorawan-channel! chn start-event)
(hash-table-update!/default lorawan-channels chn
(lambda (event-list)
@@ -201,6 +202,11 @@
(remove! (lambda (x) (eq? (radio-event-frame x)
(radio-event-frame end-event)))
event-list))))
+ (define (radio-event->interference ev)
+ "Make a new radio-event of type 'interference from another radio-event"
+ (match ev
+ (($ <radio-event> type channel-n frame)
+ (make-radio-event 'interference channel-n frame))))
(lambda ()
(forever
@@ -212,12 +218,18 @@
(frame-FCnt frame)
channel-n)
(use-lorawan-channel! channel-n ev)
- (hash-table-walk gateways
- (lambda (k gateway)
- (put-message (device-channel gateway) ev)))
- (when (interference? channel-n)
- ;; TODO: send an 'interference event to the device
- (ll "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA")))
+ (let ((ints (interferences ev channel-n)))
+ (hash-table-walk gateways
+ (lambda (k gateway)
+ (spawn-fiber
+ (lambda ()
+ (put-message (device-channel gateway) ev)
+ (for-each
+ (lambda (ev)
+ (ll "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA")
+ (put-message (device-channel gateway)
+ (radio-event->interference ev)))
+ ints)))))))
(($ <radio-event> 'downlink-start channel-n frame)
(ll "Device ~a started downlink-frame #~a on channel ~a"
@@ -225,13 +237,15 @@
(frame-FCnt frame)
channel-n)
(use-lorawan-channel! channel-n ev)
- (put-message
- (device-channel (hash-table-ref end-devices
- (frame-DeviceAddr frame)))
- ev)
- (when (interference? channel-n)
- ;; TODO: send an 'interference event to the device
- (ll "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA")))
+ (let ((chan (hash-table-ref end-devices
+ (frame-DeviceAddr frame)))
+ (ints (interferences ev channel-n)))
+ (put-message chan ev)
+ (for-each
+ (lambda (ev)
+ (ll "AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA")
+ (put-message chan (radio-event->interference ev)))
+ ints)))
(($ <radio-event> 'uplink-end channel-n frame)
(ll "Device ~a ended uplink-frame #~a on channel ~a"
@@ -240,8 +254,10 @@
channel-n)
(release-lorawan-channel! channel-n ev)
(hash-table-walk gateways
- (lambda (k gateway)
- (put-message (device-channel gateway) ev))))
+ (lambda (k gateway)
+ (spawn-fiber
+ (lambda ()
+ (put-message (device-channel gateway) ev))))))
(($ <radio-event> 'downlink-end channel-n frame)
(ll "Device ~a ended uplink-frame #~a on channel ~a"