.nolist .include "include/tn84def.inc" ; Define device ATtiny84 .list ; *************************************************************************** ; defines ; --------------------------------------------------------------------------- ; generic .equ clock=1000000 ; Define the clock frequency ; --------------------------------------------------------------------------- ; COM module .equ COM_BIT_LENGTH = 52000 ; 104000=9600, 52000=19200, 26000=38400 .equ COM_DDR_DATA = DDRA .equ COM_PORT_DATA = PORTA .equ COM_PIN_DATA = PINA .equ COM_PINNUM_DATA = PORTA1 .equ COM_DDR_ATTN = DDRA .equ COM_PORT_ATTN = PORTA .equ COM_PIN_ATTN = PINA .equ COM_PINNUM_ATTN = PORTA7 .equ COM_IRQ_ADDR_ATTN = PCMSK0 .equ COM_IRQ_BIT_ATTN = 7 ; bit 7 in PCMSK0 .equ COM_IRQ_GIFR_ATTN = PCIF0 .equ COM_IRQ_GIMSK_ATTN = PCIE0 ; --------------------------------------------------------------------------- ; TWI master module .equ LCD_TWI_ADDRESS = 0x3c .equ TWI_DDR_SCL = DDRA .equ TWI_PORT_SCL = PORTA .equ TWI_PIN_SCL = PINA .equ TWI_PINNUM_SCL = PORTA4 .equ TWI_DDR_SDA = DDRA .equ TWI_PORT_SDA = PORTA .equ TWI_PIN_SDA = PINA .equ TWI_PINNUM_SDA = PORTA6 ; --------------------------------------------------------------------------- ; BMP 280 .equ BMP280_ADDR = 0x76 ; *************************************************************************** ; code segment .cseg .org 000000 ; --------------------------------------------------------------------------- ; Reset and interrupt vectors rjmp main ; Reset vector reti ; EXT_INT0 rjmp comIsrPcint0 ; PCI0 reti ; PCI1 reti ; WATCHDOG reti ; ICP1 reti ; OC1A reti ; OC1B reti ; OVF1 rjmp timerIrqOC0A ; OC0A reti ; OC0B reti ; OVF0 reti ; ACI reti ; ADCC reti ; ERDY reti ; USI_STR reti ; USI_OVF ; *************************************************************************** ; includes .include "utils.asm" .include "timer.asm" .include "led.asm" .include "com.asm" .include "twimaster.asm" .include "lcd.asm" .include "bmp280.asm" ; *************************************************************************** ; data in SRAM .dseg ledA3Sram: .byte LED_SRAM_SIZE ; *************************************************************************** ; data in EEPROM .eseg ; *************************************************************************** ; data in FLASH .cseg ledA3Flash: .db DDRA+0x20, PORTA+0x20, PINA+0x20, (1<