t03: send memory stats.
This commit is contained in:
@@ -25,7 +25,7 @@
|
||||
.equ clock=8000000 ; Define the clock frequency
|
||||
|
||||
;.equ SEND_DEVICE_EVERY = 3000
|
||||
.equ SEND_DEVICE_EVERY = 350 ; every 30s
|
||||
.equ SEND_DEVICE_EVERY = 100 ; every 10s
|
||||
.equ SEND_STATS_EVERY = 600 ; every minute
|
||||
|
||||
.nolist
|
||||
@@ -206,6 +206,7 @@ onSystemTimerTick:
|
||||
rcall maybeSendDeviceMsg
|
||||
rcall maybeSendTStatsMsg
|
||||
rcall maybeSendRStatsMsg
|
||||
rcall maybeSendMStatsMsg
|
||||
rcall TtyOnUart1_Periodically
|
||||
ret
|
||||
|
||||
@@ -250,11 +251,16 @@ initModules:
|
||||
ldi r16, HIGH(SEND_STATS_EVERY)
|
||||
sts sendTStatsCounter+1, r16
|
||||
|
||||
ldi r16, LOW(SEND_STATS_EVERY)
|
||||
ldi r16, LOW(SEND_STATS_EVERY+10)
|
||||
sts sendRStatsCounter, r16
|
||||
ldi r16, HIGH(SEND_STATS_EVERY)
|
||||
ldi r16, HIGH(SEND_STATS_EVERY+10)
|
||||
sts sendRStatsCounter+1, r16
|
||||
|
||||
ldi r16, LOW(SEND_STATS_EVERY+20)
|
||||
sts sendMStatsCounter, r16
|
||||
ldi r16, HIGH(SEND_STATS_EVERY+20)
|
||||
sts sendMStatsCounter+1, r16
|
||||
|
||||
ret
|
||||
; @end
|
||||
|
||||
@@ -285,6 +291,7 @@ initModules:
|
||||
.include "modules/network/msg/device-w.asm"
|
||||
.include "modules/network/msg/sendstats-w.asm"
|
||||
.include "modules/network/msg/recvstats-w.asm"
|
||||
.include "modules/network/msg/memstats-w.asm"
|
||||
|
||||
.include "modules/uart_hw/defs.asm"
|
||||
.include "modules/uart_hw/lowlevel.asm"
|
||||
@@ -348,12 +355,8 @@ maybeSendTStatsMsg:
|
||||
rcall NETMSG_SendStats_Write ; (R16, R17, R18, R19, R20, R21, Z)
|
||||
sbiw xh:xl, 1
|
||||
pop r16
|
||||
push r16
|
||||
rcall NET_Interface_AddOutgoingMsgNum ; (R17, R18, X)
|
||||
pop r16
|
||||
brcs maybeSendTStatsMsg_resetCounter
|
||||
rcall NET_Buffer_ReleaseByNum ; (R16, X)
|
||||
rjmp maybeSendTStatsMsg_end
|
||||
rcall NET_Interface_AddOrReleaseOutMsg ; (R16, R17, R18, X)
|
||||
brcc maybeSendTStatsMsg_end
|
||||
; reset counter
|
||||
maybeSendTStatsMsg_resetCounter:
|
||||
ldi r24, LOW(SEND_STATS_EVERY)
|
||||
@@ -383,12 +386,8 @@ maybeSendRStatsMsg:
|
||||
rcall NETMSG_RecvStats_Write ; (R16, R17, R18, R19, R20, R21, Z)
|
||||
sbiw xh:xl, 1
|
||||
pop r16
|
||||
push r16
|
||||
rcall NET_Interface_AddOutgoingMsgNum ; (R17, R18, X)
|
||||
pop r16
|
||||
brcs maybeSendRStatsMsg_resetCounter
|
||||
rcall NET_Buffer_ReleaseByNum ; (R16, X)
|
||||
rjmp maybeSendRStatsMsg_end
|
||||
rcall NET_Interface_AddOrReleaseOutMsg ; (R16, R17, R18, X)
|
||||
brcc maybeSendRStatsMsg_end
|
||||
; reset counter
|
||||
maybeSendRStatsMsg_resetCounter:
|
||||
ldi r24, LOW(SEND_STATS_EVERY)
|
||||
@@ -401,6 +400,37 @@ maybeSendRStatsMsg_end:
|
||||
|
||||
|
||||
|
||||
maybeSendMStatsMsg:
|
||||
ldi yl, LOW(ttyOnUart1_iface)
|
||||
ldi yh, HIGH(ttyOnUart1_iface)
|
||||
|
||||
lds r24, sendMStatsCounter
|
||||
lds r25, sendMStatsCounter+1
|
||||
sbiw r25:r24, 1
|
||||
brne maybeSendMStatsMsg_storeCounter
|
||||
; send device msg
|
||||
rcall NET_Buffer_Alloc ; (R16, R17, X)
|
||||
; brcc maybeSendTStatsMsg_resetCounter
|
||||
brcc maybeSendMStatsMsg_end
|
||||
push r16
|
||||
adiw xh:xl, 1
|
||||
rcall NETMSG_MemStats_Write ; (R16, R17, R18, R19, R20, R21)
|
||||
sbiw xh:xl, 1
|
||||
pop r16
|
||||
rcall NET_Interface_AddOrReleaseOutMsg ; (R16, R17, R18, X)
|
||||
brcc maybeSendMStatsMsg_end
|
||||
; reset counter
|
||||
maybeSendMStatsMsg_resetCounter:
|
||||
ldi r24, LOW(SEND_STATS_EVERY)
|
||||
ldi r25, HIGH(SEND_STATS_EVERY)
|
||||
maybeSendMStatsMsg_storeCounter:
|
||||
sts sendMStatsCounter, r24
|
||||
sts sendMStatsCounter+1, r25
|
||||
maybeSendMStatsMsg_end:
|
||||
ret
|
||||
|
||||
|
||||
|
||||
checkRecvdMsg:
|
||||
ldi yl, LOW(ttyOnUart1_iface)
|
||||
ldi yh, HIGH(ttyOnUart1_iface)
|
||||
@@ -503,6 +533,7 @@ programRamBegin:
|
||||
deviceCounter: .byte 2
|
||||
sendTStatsCounter: .byte 2
|
||||
sendRStatsCounter: .byte 2
|
||||
sendMStatsCounter: .byte 2
|
||||
programRamEnd:
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user