diff --git a/avr/devices/0BUILD b/avr/devices/0BUILD
index 9662863..67b5e1f 100644
--- a/avr/devices/0BUILD
+++ b/avr/devices/0BUILD
@@ -37,6 +37,8 @@
n25
n26
n27
+ r04
+ r05
t03
diff --git a/avr/devices/r05/.gitignore b/avr/devices/r05/.gitignore
new file mode 100644
index 0000000..8e0618c
--- /dev/null
+++ b/avr/devices/r05/.gitignore
@@ -0,0 +1,2 @@
+*.eep.hex
+*.obj
diff --git a/avr/devices/r05/0BUILD b/avr/devices/r05/0BUILD
new file mode 100644
index 0000000..9e83ec2
--- /dev/null
+++ b/avr/devices/r05/0BUILD
@@ -0,0 +1,23 @@
+
+
+
+
+
+ boot
+ main
+ test
+
+
+
+ defs.asm
+ README
+
+
+
+ aqua_r05.xml
+
+
+
+
+
+
diff --git a/avr/devices/r05/README b/avr/devices/r05/README
new file mode 100644
index 0000000..e69de29
diff --git a/avr/devices/r05/aqua_r05.xml b/avr/devices/r05/aqua_r05.xml
new file mode 100644
index 0000000..d8d51a2
--- /dev/null
+++ b/avr/devices/r05/aqua_r05.xml
@@ -0,0 +1,24 @@
+
+
+ AQUA
+ R
+ 5
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/avr/devices/r05/boot/0BUILD b/avr/devices/r05/boot/0BUILD
new file mode 100644
index 0000000..3a65629
--- /dev/null
+++ b/avr/devices/r05/boot/0BUILD
@@ -0,0 +1,32 @@
+
+
+
+
+
+
+
+ -I $(builddir)
+ -I $(srcdir)
+ -I $(topsrcdir)/avr
+ -I $(topbuilddir)/avr
+
+
+
+
+ boot.asm
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/avr/devices/r05/boot/boot.asm b/avr/devices/r05/boot/boot.asm
new file mode 100644
index 0000000..d86fa14
--- /dev/null
+++ b/avr/devices/r05/boot/boot.asm
@@ -0,0 +1,151 @@
+; ***************************************************************************
+; Source file for base system node on AtTiny 84
+;
+; This is for the maintenance system (i.e. the flash loader).
+;
+; All definitions and changes should go into this file.
+; ***************************************************************************
+
+;.equ clock=1000000 ; Define the clock frequency
+.equ clock=8000000 ; Define the clock frequency
+
+.nolist
+.include "include/tn841def.inc" ; Define device ATtiny841
+.list
+
+.include "version.asm"
+.include "../defs.asm"
+.include "devices/all/defs.asm"
+
+.include "common/calls.asm"
+.include "common/utils_wait.asm"
+
+
+
+; ***************************************************************************
+; defines
+
+
+;#define COM_ACCEPT_ALL_DEST 1
+
+
+
+; ---------------------------------------------------------------------------
+; LED
+
+.equ LED_DDR = DDRB
+.equ LED_PORT = PORTB
+.equ LED_PIN = PINB
+.equ LED_PINNUM = PORTB2
+
+
+; ***************************************************************************
+; code segment
+
+.cseg
+.org 0x0000
+
+
+
+; ---------------------------------------------------------------------------
+; Reset and interrupt vectors
+
+ rjmp main ; 1: RESET Reset vector use this for flashed system
+ reti ; 2: INT0 External Interrupt Request 0
+ reti ; 3: PCINT0 Pin Change Interrupt 0
+ reti ; 4: PCINT1 Pin Change Interrupt 1
+ reti ; 5: WDT Watchdog Time-out
+ reti ; 6: TIM1_CAPT Timer/Counter1 Capture Event
+ reti ; 7: TIM1_COMPA (OC1A) Timer/Counter1 Compare Match A
+ reti ; 8: TIM1_COMPB (OC1B) Timer/Counter1 Compare Match B
+ reti ; 9: TIM1_OVF (OVF1) Timer/Counter1 Overflow
+ reti ; 10: TIM0_COMPA (OC0A) Timer/Counter0 Compare Match A
+ reti ; 11: TIM0_COMPB (OC0B) Timer/Counter0 Compare Match B
+ reti ; 12: TIM0_OVF (OVF0) Timer/Counter0 Overflow
+ reti ; 13: ANA_COMP0 Analog Comparator 0
+ reti ; 14: ADC_READY ADC Conversion Complete
+ reti ; 15: EE_RDY (ERDY) EEPROM Ready
+ reti ; 16: ANA_COMP1 Analog Comparator 1
+ reti ; 17: TIM2_CAPT Timer/Counter2 Capture Event
+ reti ; 18: TIM2_COMPA (OC2A) Timer/Counter2 Compare Match A
+ reti ; 19: TIM2_COMPB (OC2B) Timer/Counter2 Compare Match B
+ reti ; 20: TIM2_OVF (OVF2) Timer/Counter2 Overflow
+ reti ; 21: SPI SPI Serial Transfer Complete
+ reti ; 22: USART0_RXS USART0 Rx Start
+ reti ; 23: USART0_RXC USART0 Rx Complete
+ reti ; 24: USART0_DRE USART0 Data Register Empty
+ reti ; 25: USART0_TXC USART0 Tx Complete
+ reti ; 26: USART1_RXS USART1 Rx Start
+ reti ; 27: USART1_RXC USART1 Rx Complete
+ reti ; 28: USART1_DRE USART1 Data Register Empty
+ reti ; 29: USART1_TXC USART1 Tx Complete
+ reti ; 30: TWI Two-Wire-Interface
+ reti ; 31: RESERVED reserved
+
+
+
+devInfoBlock: ; 12 bytes
+devInfoManufacturer: .db 'A', 'Q', 'U', 'A'
+devInfoId: .db DEVICEINFO_ID, 0
+devInfoVersion: .db DEVICEINFO_VERSION, DEVICEINFO_REVISION ; version, revision
+firmwareVersion: .db FIRMWARE_VARIANT_BOOT, FIRMWARE_VERSION_MAJOR
+ .db FIRMWARE_VERSION_MINOR, FIRMWARE_VERSION_PATCHLEVEL
+
+firmwareStart:
+ rjmp main ; will be overwritten when flashing
+
+
+
+; ***************************************************************************
+; main code
+
+
+.org BOOTLOADER_ADDR
+
+
+main:
+ rjmp bootLoader ; this routine is in modules/bootloader/main.asm
+
+
+
+
+; ***************************************************************************
+; includes
+
+.include "common/utils_wait_fixed.asm"
+.include "common/utils_copy_from_flash.asm"
+.include "common/utils_copy_sdram.asm"
+
+.include "modules/flash/defs.asm"
+.include "modules/flash/eeprom.asm"
+.include "modules/flash/io.asm"
+.include "modules/flash/io_attn.asm"
+.include "modules/flash/io_bitbang.asm"
+.include "modules/flash/flashxp.asm"
+.include "modules/flash/flash4p.asm"
+.include "modules/flash/flashprocess.asm"
+.include "modules/flash/wait.asm"
+.include "modules/bootloader/main.asm"
+.include "modules/network/msg/defs.asm"
+.include "modules/network/msg/crc.asm"
+
+
+
+systemSetSpeed:
+.if clock == 1000000
+ ldi r17, 0xd8
+ ldi r16, (1<
+
+
+
+
+
+
+ -I $(builddir)
+ -I $(srcdir)
+ -I $(topsrcdir)/avr
+ -I $(topbuilddir)/avr
+
+
+
+
+ main.asm
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/avr/devices/r05/main/main.asm b/avr/devices/r05/main/main.asm
new file mode 100644
index 0000000..14ccb80
--- /dev/null
+++ b/avr/devices/r05/main/main.asm
@@ -0,0 +1,347 @@
+; ***************************************************************************
+; copyright : (C) 2024 by Martin Preuss
+; email : martin@libchipcard.de
+;
+; ***************************************************************************
+; * This file is part of the project "AqHome". *
+; * Please see toplevel file COPYING of that project for license details. *
+; ***************************************************************************
+
+
+
+
+; ***************************************************************************
+; Source file for temperature sensor node on AtTiny 84
+;
+; This is for the full system (i.e. not the boot loader).
+;
+; All definitions and changes should go into this file.
+;
+;
+; ***************************************************************************
+
+
+;.equ clock=1000000 ; Define the clock frequency
+.equ clock=8000000 ; Define the clock frequency
+
+;#define WITH_LCD
+
+.nolist
+.include "include/tn841def.inc" ; Define device ATtiny841
+.list
+
+.include "../defs.asm"
+.include "version.asm"
+;.include "defs_all.asm"
+
+.include "devices/all/defs.asm"
+
+.include "common/calls.asm"
+.include "common/utils_wait.asm"
+.include "common/utils_io.asm"
+
+
+
+; ***************************************************************************
+; defines
+
+; ---------------------------------------------------------------------------
+; generic
+
+; ---------------------------------------------------------------------------
+; network interfaces
+
+.equ COMONUART0_IFACENUM = 1
+.equ COMONUART1_IFACENUM = 2
+
+
+; ---------------------------------------------------------------------------
+; firmware settings including list of modules used
+
+
+#define MAIN_WITHOUT_MSG_HANDLING ; we do message handling ourselfes
+
+#define MODULES_CLOCK
+#define MODULES_LED_SIMPLE
+#ifdef WITH_LCD
+ #define MODULES_TWI_MASTER ; using TWI display for debugging
+ #define MODULES_LCD
+ #define LCD_MINIMAL_FONT
+#else ; decrease code when using display
+ #define MODULES_OWI_MASTER
+ #define MODULES_DS18B20
+ #define APPS_STATS
+#endif
+#define MODULES_NETWORK
+#define MODULES_COMONUART0
+#define MODULES_COMONUART1
+#define APPS_NETWORK
+
+
+
+.equ NET_BUFFERS_NUM = 8
+.equ NET_BUFFERS_SIZE = 32
+
+.equ UART_HW_MSGNUMINBUF_SIZE = 8
+.equ UART_HW_MSGNUMOUTBUF_SIZE = 8
+
+
+
+; ---------------------------------------------------------------------------
+; defines for values
+
+.equ VALUE_ID_DS18B20_TEMP = 0x06
+
+.equ VALUE_ID_LEDSIMPLE_TIMING = 0x88
+
+
+; ***************************************************************************
+; code segment
+
+.cseg
+.org 000000
+
+
+
+; ---------------------------------------------------------------------------
+; Reset and interrupt vectors
+
+ rjmp BOOTLOADER_ADDR ; 1: RESET Reset vector use this for flashed system
+ reti ; 2: INT0 External Interrupt Request 0
+ rjmp ComOnUart0_AttnChangeIsr ; 3: PCINT0 Pin Change Interrupt 0
+ rjmp ComOnUart1_AttnChangeIsr ; 4: PCINT1 Pin Change Interrupt 1
+ reti ; 5: WDT Watchdog Time-out
+ reti ; 6: TIM1_CAPT Timer/Counter1 Capture Event
+ reti ; 7: TIM1_COMPA (OC1A) Timer/Counter1 Compare Match A
+ reti ; 8: TIM1_COMPB (OC1B) Timer/Counter1 Compare Match B
+ reti ; 9: TIM1_OVF (OVF1) Timer/Counter1 Overflow
+ rjmp baseTimerIrqOC0A ; 10: TIM0_COMPA (OC0A) Timer/Counter0 Compare Match A
+ reti ; 11: TIM0_COMPB (OC0B) Timer/Counter0 Compare Match B
+ reti ; 12: TIM0_OVF (OVF0) Timer/Counter0 Overflow
+ reti ; 13: ANA_COMP0 Analog Comparator 0
+ reti ; 14: ADC_READY ADC Conversion Complete
+ reti ; 15: EE_RDY (ERDY) EEPROM Ready
+ reti ; 16: ANA_COMP1 Analog Comparator 1
+ reti ; 17: TIM2_CAPT Timer/Counter2 Capture Event
+ reti ; 18: TIM2_COMPA (OC2A) Timer/Counter2 Compare Match A
+ reti ; 19: TIM2_COMPB (OC2B) Timer/Counter2 Compare Match B
+ reti ; 20: TIM2_OVF (OVF2) Timer/Counter2 Overflow
+ reti ; 21: SPI SPI Serial Transfer Complete
+ reti ; 22: USART0_RXS USART0 Rx Start
+ rjmp ComOnUart0_RxCharIsr ; 23: USART0_RXC USART0 Rx Complete
+ rjmp ComOnUart0_TxUdreIsr ; 24: USART0_DRE USART0 Data Register Empty
+ rjmp ComOnUart0_TxCharIsr ; 25: USART0_TXC USART0 Tx Complete
+ reti ; 26: USART1_RXS USART1 Rx Start
+ rjmp ComOnUart1_RxCharIsr ; 27: USART1_RXC USART1 Rx Complete
+ rjmp ComOnUart1_TxUdreIsr ; 28: USART1_DRE USART1 Data Register Empty
+ rjmp ComOnUart1_TxCharIsr ; 29: USART1_TXC USART1 Tx Complete
+ reti ; 30: TWI Two-Wire-Interface
+ reti ; 31: RESERVED reserved
+
+
+
+devInfoBlock: ; 12 bytes
+devInfoManufacturer: .db 'A', 'Q', 'U', 'A'
+devInfoId: .db DEVICEINFO_ID, 0
+devInfoVersion: .db DEVICEINFO_VERSION, DEVICEINFO_REVISION ; version, revision
+firmwareVersion: .db FIRMWARE_VARIANT_TEMP_WINDOW, FIRMWARE_VERSION_MAJOR
+ .db FIRMWARE_VERSION_MINOR, FIRMWARE_VERSION_PATCHLEVEL
+
+
+
+; ---------------------------------------------------------------------------
+; @routine firmwareStart @global
+
+firmwareStart:
+ rjmp main
+; @end
+
+
+
+; ---------------------------------------------------------------------------
+; @routine onSystemStart
+
+onSystemStart:
+ ret
+; @end
+
+
+
+
+
+
+
+onEvery100ms:
+onEverySecond:
+onEveryHour:
+onEveryDay:
+ ret
+
+
+
+onEveryMinute:
+#ifdef APPS_STATS
+ rcall sendPacketsIface2In
+#endif
+ ret
+; @end
+
+
+
+; ---------------------------------------------------------------------------
+; @routine onEveryLoop
+;
+; Called on every loop (i.e. after awakening from sleep).
+
+onEveryLoop:
+ rcall checkRecvdMsg
+ ret
+; @end
+
+
+
+; ---------------------------------------------------------------------------
+; @routine onMessageReceived
+;
+; Called on every message received
+
+onMessageReceived:
+ clc
+ ret
+; @end
+
+
+
+; ---------------------------------------------------------------------------
+; @routine checkRecvdMsg
+;
+; Read messages from either interface and forward to the other one.
+
+checkRecvdMsg:
+ rcall NET_PeekNextIncomingMsgNum ; check read queue (bufNum->r16)
+ brcc checkRecvdMsg_end ; no msg, jmp
+ rcall NET_Buffer_Locate ; (R17)
+ ; let system handle incoming messages
+ push r16
+ adiw xh:xl, 1
+ rcall letSysHandleMsg
+ sbiw xh:xl, 1
+ pop r16
+
+ ; forward to other interface
+ ld r17, X
+ andi r17, (NET_IFACE_BUFFER_IFACENUM1_BIT | NET_IFACE_BUFFER_IFACENUM0_BIT)
+ rcall reverseInterfaceNum ; (R16, R17)
+; ldi r17, COMONUART0_IFACENUM ; DEBUG: send everything to uart0 to test that code first
+ rcall addMsgToInterface
+ brcc checkRecvdMsg_end ; could not add, jmp
+ rcall NET_GetNextIncomingMsgNum ; take off the queue
+ rjmp checkRecvdMsg
+checkRecvdMsg_end:
+ ret
+; @end
+
+
+
+; ---------------------------------------------------------------------------
+; @routine letSysHandleMsg
+;
+; @param X pointer to msg to handle (point behind the buffer header!)
+; @clobbers any, !X
+
+letSysHandleMsg:
+ ld r16, X
+ cpi r16, 0xff
+ breq letSysHandleMsg_forMe
+ lds r17, comOnUart0_iface+NET_IFACE_OFFS_ADDRESS
+ cp r16, r17
+ brne letSysHandleMsg_end
+letSysHandleMsg_forMe:
+ push xl
+ push xh
+ rcall onMessageReceived
+ pop xh
+ pop xl
+ push xl
+ push xh
+ rcall mainModulesOnPacketReceived
+ pop xh
+ pop xl
+ push xl
+ push xh
+ rcall mainAppsOnPacketReceived
+ pop xh
+ pop xl
+letSysHandleMsg_end:
+ ret
+; @end
+
+
+
+; ---------------------------------------------------------------------------
+; @routine reverseInterfaceNum
+;
+; @param r17 buffer num
+; @return r17 reversed interface number
+; @clobbers r16, r17
+
+reverseInterfaceNum:
+ ldi r16, (1<
+
+
+
+
+
+
+ -I $(builddir)
+ -I $(srcdir)
+ -I $(topsrcdir)/avr
+ -I $(topbuilddir)/avr
+
+
+
+
+ main.asm
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/avr/devices/r05/test/main.asm b/avr/devices/r05/test/main.asm
new file mode 100644
index 0000000..4874b8c
--- /dev/null
+++ b/avr/devices/r05/test/main.asm
@@ -0,0 +1,242 @@
+; ***************************************************************************
+; copyright : (C) 2025 by Martin Preuss
+; email : martin@libchipcard.de
+;
+; ***************************************************************************
+; * This file is part of the project "AqHome". *
+; * Please see toplevel file COPYING of that project for license details. *
+; ***************************************************************************
+
+
+
+
+; ***************************************************************************
+; Source file for temperature sensor node on AtTiny 84
+;
+; This is for the full system (i.e. not the boot loader).
+;
+; All definitions and changes should go into this file.
+;
+;
+; ***************************************************************************
+
+
+;.equ clock=1000000 ; Define the clock frequency
+.equ clock=8000000 ; Define the clock frequency
+
+
+.nolist
+.include "include/tn841def.inc" ; Define device ATtiny841
+.list
+
+.include "../defs.asm"
+.include "version.asm"
+;.include "defs_all.asm"
+
+.include "devices/all/defs.asm"
+
+.include "common/calls.asm"
+.include "common/utils_wait.asm"
+.include "common/utils_io.asm"
+
+
+
+; ***************************************************************************
+; defines
+
+; ---------------------------------------------------------------------------
+; generic
+
+.equ COMONUART0_IFACENUM = 1
+.equ COMONUART1_IFACENUM = 2
+
+
+; ---------------------------------------------------------------------------
+; firmware settings including list of modules used
+
+
+;#define MAIN_WITHOUT_MSG_HANDLING ; we do message handling ourselfes
+;#define APP_STATS_NETDEV2
+
+#define MODULES_CLOCK
+;#define MODULES_COM
+;#define MODULES_COM_WITH_ADDR_PROTO
+;#define MODULES_LED
+#define MODULES_LED_SIMPLE
+;#define MODULES_TWI_MASTER
+;#define MODULES_LCD
+;#define LCD_MINIMAL_FONT
+;#define MODULES_SI7021
+;#define MODULES_STATS
+;#define MODULES_CNY70
+;#define MODULES_REED
+#define MODULES_OWI_MASTER
+#define MODULES_DS18B20
+;#define MODULES_MOTION
+#define MODULES_NETWORK
+;#define MODULES_TTYONUART1
+;#define MODULES_COMONUART0
+#define MODULES_COMONUART1
+
+#define APPS_STATS
+#define APPS_NETWORK
+#define APPS_REPORTSENSORS
+
+
+
+.equ NET_BUFFERS_NUM = 8
+.equ NET_BUFFERS_SIZE = 32
+
+.equ UART_HW_MSGNUMINBUF_SIZE = 8
+.equ UART_HW_MSGNUMOUTBUF_SIZE = 8
+
+
+
+; ---------------------------------------------------------------------------
+; defines for values
+
+.equ VALUE_ID_DS18B20_TEMP = 0x06
+
+.equ VALUE_ID_LEDSIMPLE_TIMING = 0x88
+
+
+; ***************************************************************************
+; code segment
+
+.cseg
+.org 000000
+
+
+
+; ---------------------------------------------------------------------------
+; Reset and interrupt vectors
+
+ rjmp BOOTLOADER_ADDR ; 1: RESET Reset vector use this for flashed system
+ reti ; 2: INT0 External Interrupt Request 0
+; rjmp ComOnUart0_AttnChangeIsr ; 3: PCINT0 Pin Change Interrupt 0
+ reti ; 3: PCINT0 Pin Change Interrupt 0
+ rjmp ComOnUart1_AttnChangeIsr ; 4: PCINT1 Pin Change Interrupt 1
+ reti ; 5: WDT Watchdog Time-out
+ reti ; 6: TIM1_CAPT Timer/Counter1 Capture Event
+ reti ; 7: TIM1_COMPA (OC1A) Timer/Counter1 Compare Match A
+ reti ; 8: TIM1_COMPB (OC1B) Timer/Counter1 Compare Match B
+ reti ; 9: TIM1_OVF (OVF1) Timer/Counter1 Overflow
+ rjmp baseTimerIrqOC0A ; 10: TIM0_COMPA (OC0A) Timer/Counter0 Compare Match A
+ reti ; 11: TIM0_COMPB (OC0B) Timer/Counter0 Compare Match B
+ reti ; 12: TIM0_OVF (OVF0) Timer/Counter0 Overflow
+ reti ; 13: ANA_COMP0 Analog Comparator 0
+ reti ; 14: ADC_READY ADC Conversion Complete
+ reti ; 15: EE_RDY (ERDY) EEPROM Ready
+ reti ; 16: ANA_COMP1 Analog Comparator 1
+ reti ; 17: TIM2_CAPT Timer/Counter2 Capture Event
+ reti ; 18: TIM2_COMPA (OC2A) Timer/Counter2 Compare Match A
+ reti ; 19: TIM2_COMPB (OC2B) Timer/Counter2 Compare Match B
+ reti ; 20: TIM2_OVF (OVF2) Timer/Counter2 Overflow
+ reti ; 21: SPI SPI Serial Transfer Complete
+ reti ; 22: USART0_RXS USART0 Rx Start
+; rjmp ComOnUart0_RxCharIsr ; 23: USART0_RXC USART0 Rx Complete
+ reti ; 23: USART0_RXC USART0 Rx Complete
+; rjmp ComOnUart0_TxUdreIsr ; 24: USART0_DRE USART0 Data Register Empty
+ reti ; 24: USART0_DRE USART0 Data Register Empty
+; rjmp ComOnUart0_TxCharIsr ; 25: USART0_TXC USART0 Tx Complete
+ reti ; 25: USART0_TXC USART0 Tx Complete
+ reti ; 26: USART1_RXS USART1 Rx Start
+ rjmp ComOnUart1_RxCharIsr ; 27: USART1_RXC USART1 Rx Complete
+; reti ; 27: USART1_RXC USART1 Rx Complete
+ rjmp ComOnUart1_TxUdreIsr ; 28: USART1_DRE USART1 Data Register Empty
+; reti ; 28: USART1_DRE USART1 Data Register Empty
+ rjmp ComOnUart1_TxCharIsr ; 29: USART1_TXC USART1 Tx Complete
+; reti ; 29: USART1_TXC USART1 Tx Complete
+ reti ; 30: TWI Two-Wire-Interface
+ reti ; 31: RESERVED reserved
+
+
+
+devInfoBlock: ; 12 bytes
+devInfoManufacturer: .db 'A', 'Q', 'U', 'A'
+devInfoId: .db DEVICEINFO_ID, 0
+devInfoVersion: .db DEVICEINFO_VERSION, DEVICEINFO_REVISION ; version, revision
+firmwareVersion: .db FIRMWARE_VARIANT_TEMP_WINDOW, FIRMWARE_VERSION_MAJOR
+ .db FIRMWARE_VERSION_MINOR, FIRMWARE_VERSION_PATCHLEVEL
+
+
+
+; ---------------------------------------------------------------------------
+; @routine firmwareStart @global
+
+firmwareStart:
+ rjmp main
+; @end
+
+
+
+; ---------------------------------------------------------------------------
+; @routine onSystemStart
+
+onSystemStart:
+ ; set interface number for UART0
+; ldi r16, COMONUART0_IFACENUM
+; sts comOnUart0_iface+NET_IFACE_OFFS_IFACENUM, r16
+ ; set interface number for UART1
+ ldi r16, COMONUART1_IFACENUM
+ sts comOnUart1_iface+NET_IFACE_OFFS_IFACENUM, r16
+
+ ret
+; @end
+
+
+
+
+
+
+
+onEvery100ms:
+onEverySecond:
+onEveryMinute:
+onEveryHour:
+onEveryDay:
+ ret
+
+
+
+
+; ---------------------------------------------------------------------------
+; @routine onEveryLoop
+;
+; Called on every loop (i.e. after awakening from sleep).
+
+onEveryLoop:
+ ret
+; @end
+
+
+
+; ---------------------------------------------------------------------------
+; @routine onMessageReceived
+;
+; Called on every message received
+
+onMessageReceived:
+ clc
+ ret
+; @end
+
+
+
+; ***************************************************************************
+; includes
+
+.include "devices/all/hw_tn841.asm"
+.include "devices/all/includes.asm"
+
+.include "common/debug.asm"
+
+
+
+; ---------------------------------------------------------------------------
+; defines for network interface
+
+.equ netInterfaceData = comOnUart1_iface
+;.equ netInterfaceData2 = comOnUart1_iface
+
+