improve stats reporting
now again use three messages to transmit stats (much more efficient than sending single values, also more acurate).
This commit is contained in:
@@ -25,7 +25,13 @@ AppNetwork_SendTxdStats:
|
||||
bigcall NETMSG_SendStats_Write ; (R16, R17, R18, R19, R20, R21, Z)
|
||||
sbiw xh:xl, 1
|
||||
pop r16
|
||||
bigcall NET_Interface_AddOrReleaseOutMsg ; (R16, R17, R18, X)
|
||||
push yl
|
||||
push yh
|
||||
ldi yl, LOW(netInterfaceData)
|
||||
ldi yh, HIGH(netInterfaceData)
|
||||
bigcall NET_Interface_AddOrReleaseOutMsg ; (R16, R17, R18, X)
|
||||
pop yh
|
||||
pop yl
|
||||
AppNetwork_SendTxdStats_end:
|
||||
ret
|
||||
; @end
|
||||
@@ -35,7 +41,7 @@ AppNetwork_SendTxdStats_end:
|
||||
; ---------------------------------------------------------------------------
|
||||
; @routine AppNetwork_SendRxdStats
|
||||
|
||||
; @param Y network interface to work with
|
||||
; @param Y network interface whose stats to send
|
||||
; @clobbers R16, X (R17, R18, R19, R20, R21, Z)
|
||||
|
||||
AppNetwork_SendRxdStats:
|
||||
@@ -46,7 +52,13 @@ AppNetwork_SendRxdStats:
|
||||
bigcall NETMSG_RecvStats_Write ; (R16, R17, R18, R19, R20, R21, Z)
|
||||
sbiw xh:xl, 1
|
||||
pop r16
|
||||
bigcall NET_Interface_AddOrReleaseOutMsg ; (R16, R17, R18, X)
|
||||
push yl
|
||||
push yh
|
||||
ldi yl, LOW(netInterfaceData)
|
||||
ldi yh, HIGH(netInterfaceData)
|
||||
bigcall NET_Interface_AddOrReleaseOutMsg ; (R16, R17, R18, X)
|
||||
pop yh
|
||||
pop yl
|
||||
AppNetwork_SendRxdStats_end:
|
||||
ret
|
||||
; @end
|
||||
@@ -54,9 +66,8 @@ AppNetwork_SendRxdStats_end:
|
||||
|
||||
|
||||
; ---------------------------------------------------------------------------
|
||||
; @routine AppNetwork_SendRxdStats
|
||||
; @routine AppNetwork_SendMemStats
|
||||
|
||||
; @param Y network interface to work with
|
||||
; @clobbers R16, X (R17, R18, R19, R20, R21, Z)
|
||||
|
||||
AppNetwork_SendMemStats:
|
||||
@@ -67,7 +78,13 @@ AppNetwork_SendMemStats:
|
||||
bigcall NETMSG_MemStats_Write ; (R16, R17, R18, R19, R20, R21)
|
||||
sbiw xh:xl, 1
|
||||
pop r16
|
||||
bigcall NET_Interface_AddOrReleaseOutMsg ; (R16, R17, R18, X)
|
||||
push yl
|
||||
push yh
|
||||
ldi yl, LOW(netInterfaceData)
|
||||
ldi yh, HIGH(netInterfaceData)
|
||||
bigcall NET_Interface_AddOrReleaseOutMsg ; (R16, R17, R18, X)
|
||||
pop yh
|
||||
pop yl
|
||||
AppNetwork_SendMemStats_end:
|
||||
ret
|
||||
; @end
|
||||
|
||||
@@ -11,7 +11,7 @@
|
||||
; ***************************************************************************
|
||||
; defines
|
||||
|
||||
.equ APP_STATS_INTERVAL_MINS = 31
|
||||
.equ APP_STATS_INTERVAL_MINS = 10
|
||||
|
||||
|
||||
|
||||
@@ -62,10 +62,6 @@ AppStats_OnEveryMinute:
|
||||
ret
|
||||
|
||||
AppStats_OnEveryMinute_noIrq:
|
||||
; ldi yl, LOW(netInterfaceData)
|
||||
; ldi yh, HIGH(netInterfaceData)
|
||||
; rcall AppNetwork_SendRxdStats ; debug
|
||||
|
||||
lds r16, appStatsTimer
|
||||
inc r16
|
||||
cpi r16, APP_STATS_INTERVAL_MINS
|
||||
@@ -73,71 +69,28 @@ AppStats_OnEveryMinute_noIrq:
|
||||
clr r16
|
||||
AppStats_OnEveryMinute_store:
|
||||
sts appStatsTimer, r16
|
||||
ldi yl, LOW(netInterfaceData)
|
||||
ldi yh, HIGH(netInterfaceData)
|
||||
|
||||
ldi r17, AQHOME_VALUEID_STATS_PACKETS_IN
|
||||
ldi xl, LOW(netInterfaceData)
|
||||
ldi xh, HIGH(netInterfaceData)
|
||||
|
||||
cpi r16, 1
|
||||
breq AppStats_OnEveryMinute_sendDevice
|
||||
|
||||
cpi r16, 2
|
||||
breq AppStats_OnEveryMinute_sendMemStats
|
||||
|
||||
cpi r16, 3
|
||||
breq AppStats_OnEveryMinute_sendPacketsIn
|
||||
cpi r16, 5
|
||||
breq AppStats_OnEveryMinute_sendPacketsOut
|
||||
cpi r16, 6
|
||||
breq AppStats_OnEveryMinute_sendDevice
|
||||
cpi r16, 7
|
||||
breq AppStats_OnEveryMinute_sendContentErrs
|
||||
cpi r16, 9
|
||||
breq AppStats_OnEveryMinute_sendIoErrs
|
||||
cpi r16, 10
|
||||
breq AppStats_OnEveryMinute_sendDevice
|
||||
cpi r16, 11
|
||||
breq AppStats_OnEveryMinute_sendNoBufErrs
|
||||
cpi r16, 13
|
||||
breq AppStats_OnEveryMinute_sendCollisionErrs
|
||||
cpi r16, 14
|
||||
breq AppStats_OnEveryMinute_sendDevice
|
||||
cpi r16, 15
|
||||
breq AppStats_OnEveryMinute_sendBusyErrs
|
||||
breq AppStats_OnEveryMinute_sendRecvStats1
|
||||
|
||||
cpi r16, 4
|
||||
breq AppStats_OnEveryMinute_sendSendStats1
|
||||
|
||||
#ifdef APP_STATS_NETDEV2
|
||||
ldi r17, AQHOME_VALUEID_STATS_PACKETS_IN2
|
||||
ldi xl, LOW(netInterfaceData2)
|
||||
ldi xh, HIGH(netInterfaceData2)
|
||||
cpi r16, 16
|
||||
breq AppStats_OnEveryMinute_sendPacketsIn
|
||||
cpi r16, 17
|
||||
breq AppStats_OnEveryMinute_sendPacketsOut
|
||||
cpi r16, 18
|
||||
breq AppStats_OnEveryMinute_sendDevice
|
||||
cpi r16, 19
|
||||
breq AppStats_OnEveryMinute_sendContentErrs
|
||||
cpi r16, 20
|
||||
breq AppStats_OnEveryMinute_sendIoErrs
|
||||
cpi r16, 21
|
||||
breq AppStats_OnEveryMinute_sendDevice
|
||||
cpi r16, 22
|
||||
breq AppStats_OnEveryMinute_sendNoBufErrs
|
||||
cpi r16, 23
|
||||
breq AppStats_OnEveryMinute_sendDevice
|
||||
cpi r16, 24
|
||||
breq AppStats_OnEveryMinute_sendCollisionErrs
|
||||
cpi r16, 25
|
||||
breq AppStats_OnEveryMinute_sendBusyErrs
|
||||
#endif
|
||||
cpi r16, 5
|
||||
breq AppStats_OnEveryMinute_sendRecvStats2
|
||||
|
||||
#ifdef MODULES_HEAP
|
||||
cpi r16, 26
|
||||
breq AppStats_OnEveryMinute_sendHeapUsed
|
||||
cpi r16, 27
|
||||
breq AppStats_OnEveryMinute_sendHeapfree
|
||||
cpi r16, 6
|
||||
breq AppStats_OnEveryMinute_sendSendStats2
|
||||
#endif
|
||||
cpi r16, 28
|
||||
breq AppStats_OnEveryMinute_sendDevice
|
||||
; add more here
|
||||
ret
|
||||
|
||||
AppStats_OnEveryMinute_sendDevice:
|
||||
push yl
|
||||
push yh
|
||||
@@ -152,68 +105,35 @@ AppStats_OnEveryMinute_sendDevice:
|
||||
pop yh
|
||||
pop yl
|
||||
ret
|
||||
AppStats_OnEveryMinute_sendPacketsIn:
|
||||
ldi r16, 0
|
||||
rjmp appStatsSendDeviceStat
|
||||
AppStats_OnEveryMinute_sendPacketsOut:
|
||||
ldi r16, 1
|
||||
rjmp appStatsSendDeviceStat
|
||||
AppStats_OnEveryMinute_sendContentErrs:
|
||||
ldi r16, 2
|
||||
rjmp appStatsSendDeviceStat
|
||||
AppStats_OnEveryMinute_sendIoErrs:
|
||||
ldi r16, 3
|
||||
rjmp appStatsSendDeviceStat
|
||||
AppStats_OnEveryMinute_sendNoBufErrs:
|
||||
ldi r16, 4
|
||||
rjmp appStatsSendDeviceStat
|
||||
AppStats_OnEveryMinute_sendCollisionErrs:
|
||||
ldi r16, 5
|
||||
rjmp appStatsSendDeviceStat
|
||||
AppStats_OnEveryMinute_sendBusyErrs:
|
||||
ldi r16, 6
|
||||
rjmp appStatsSendDeviceStat
|
||||
AppStats_OnEveryMinute_sendMemStats:
|
||||
rjmp AppNetwork_SendMemStats
|
||||
|
||||
#ifdef MODULES_HEAP
|
||||
AppStats_OnEveryMinute_sendHeapUsed:
|
||||
ldi r17, AQHOME_VALUEID_STATS_HEAP_USED
|
||||
lds r18, heapUsed
|
||||
lds r19, heapUsed+1
|
||||
rjmp appStatsSend16BitValue
|
||||
AppStats_OnEveryMinute_sendHeapfree:
|
||||
ldi r17, AQHOME_VALUEID_STATS_HEAP_FREE
|
||||
lds r18, heapFree
|
||||
lds r19, heapFree+1
|
||||
rjmp appStatsSend16BitValue
|
||||
AppStats_OnEveryMinute_sendRecvStats1:
|
||||
ldi yl, LOW(netInterfaceData)
|
||||
ldi yh, HIGH(netInterfaceData)
|
||||
rjmp AppNetwork_SendRxdStats
|
||||
|
||||
AppStats_OnEveryMinute_sendSendStats1:
|
||||
ldi yl, LOW(netInterfaceData)
|
||||
ldi yh, HIGH(netInterfaceData)
|
||||
rjmp AppNetwork_SendTxdStats
|
||||
|
||||
#ifdef APP_STATS_NETDEV2
|
||||
AppStats_OnEveryMinute_sendRecvStats2:
|
||||
ldi yl, LOW(netInterfaceData2)
|
||||
ldi yh, HIGH(netInterfaceData2)
|
||||
rjmp AppNetwork_SendRxdStats
|
||||
|
||||
AppStats_OnEveryMinute_sendSendStats2:
|
||||
ldi yl, LOW(netInterfaceData2)
|
||||
ldi yh, HIGH(netInterfaceData2)
|
||||
rjmp AppNetwork_SendTxdStats
|
||||
#endif
|
||||
; @end
|
||||
|
||||
|
||||
|
||||
|
||||
; ---------------------------------------------------------------------------
|
||||
; @routine AppStats_OnEveryMinute @global
|
||||
;
|
||||
; @param r16 index into device table (e.g. 0 for NET_IFACE_OFFS_PACKETSIN_LOW)
|
||||
; @param r17 offset to first value id (e.g. AQHOME_VALUEID_STATS_PACKETS_IN for device 0,
|
||||
; AQHOME_VALUEID_STATS_PACKETS_IN2 for device 1)
|
||||
; @param Y pointer to device to send data to
|
||||
; @param X pointer to device to inspect
|
||||
|
||||
appStatsSendDeviceStat:
|
||||
add r17, r16
|
||||
lsl r16
|
||||
adiw xh:xl, NET_IFACE_OFFS_PACKETSIN_LOW
|
||||
add xl, r16
|
||||
adc xh, r16
|
||||
sub xh, r16
|
||||
ld r18, X+
|
||||
ld r19, X
|
||||
rjmp appStatsSend16BitValue
|
||||
; @end
|
||||
|
||||
|
||||
|
||||
; ---------------------------------------------------------------------------
|
||||
; @routine AppStats_OnEveryMinute @global
|
||||
;
|
||||
|
||||
Reference in New Issue
Block a user