; *************************************************************************** ; 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. * ; *************************************************************************** #ifndef AVR_MODULES_UART_HW2_TTYONUART1_H #define AVR_MODULES_UART_HW2_TTYONUART1_H .equ TTYONUART1_SKIPTIME = 2 .equ TTYONUART_IFACE_OFFS_BEGIN = UART_HW2_IFACE_SIZE .equ TTYONUART_IFACE_OFFS_BUFFER2 = TTYONUART_IFACE_OFFS_BEGIN .equ TTYONUART_IFACE_SIZE = TTYONUART_IFACE_OFFS_BUFFER2+UART_HW2_BUFFER_SIZE .dseg ; ttyOnUart1_iface: .byte TTYONUART_IFACE_SIZE ttyOnUart1_iface: .byte UART_HW2_IFACE_SIZE .cseg ; --------------------------------------------------------------------------- ; @routine TtyOnUart1_Init @global ; ; @clobbers R16, R17, Y (X) TtyOnUart1_Init: rcall comOnUart0StopRx rcall comOnUart0StopTx ldi yl, LOW(ttyOnUart1_iface) ldi yh, HIGH(ttyOnUart1_iface) rcall NET_Interface_Init ; (R16, R17, X) ldi r16, 0xff std Y+UART_HW2_IFACE_OFFS_WRITEBUFNUM, r16 ldi r16, UART_HW2_MODE_IDLE std Y+UART_HW2_IFACE_OFFS_MODE, r16 clr r16 std Y+NET_IFACE_OFFS_IFACENUM, r16 ; set baudrate .if clock == 8000000 ldi r16, 25 ; (19.2Kb/s at 8MHz) ldi r17, 0 .endif .if clock == 1000000 ldi r16, 2 ; (19.2Kb/s at 1MHz) ldi r17, 0 .endif outr UBRR1H, r17 outr UBRR1L, r16 ; set character format ; ldi r16, (1<