; *************************************************************************** ; 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 LED controller node on AtTiny 85 ; ; This is for the full system (i.e. not the boot loader). ; *************************************************************************** .equ clock=1000000 ; Define the clock frequency .nolist .include "include/tn85def.inc" ; Define device ATtiny85 .list .include "../defs.asm" .include "devices/all/defs.asm" .include "common/calls.asm" .include "common/utils_wait.asm" ; wait macro ; *************************************************************************** ; defines .equ NET_BUFFERS_NUM = 6 .equ NET_BUFFERS_SIZE = 32 ; --------------------------------------------------------------------------- ; firmware settings including list of modules used .equ FIRMWARE_VERSION_MAJOR = 0 .equ FIRMWARE_VERSION_MINOR = 0 .equ FIRMWARE_VERSION_PATCHLEVEL = 1 #define MODULES_CLOCK #define MODULES_LED_SIMPLE #define MODULES_NETWORK #define MODULES_UART_BITBANG #define MODULES_TWI_MASTER #define MODULES_SI7021 #define MODULES_CCS811 #define APPS_NETWORK #define APPS_REPORTSENSORS #define APPS_STATS ; --------------------------------------------------------------------------- ; defines for modules .equ VALUE_ID_SI7021_TEMP = 0x01 .equ VALUE_ID_SI7021_HUM = 0x02 .equ VALUE_ID_CO2 = 0x07 .equ VALUE_ID_TVOC = 0x08 .equ VALUE_ID_DEBUG = 0x7f .equ VALUE_ID_LEDSIMPLE_TIMING = 0x88 ; *************************************************************************** ; code segment .cseg .org 000000 ; --------------------------------------------------------------------------- ; Reset and interrupt vectors rjmp BOOTLOADER_ADDR ; Reset vector ; use this for flashed system reti ; EXT_INT0 rjmp UART_BitBang_PcintIsr ; PCI0 reti ; OC1A reti ; OVF1 reti ; OVF0 reti ; ERDY reti ; ACI reti ; ADCC reti ; OC1B rjmp baseTimerIrqOC0A ; OC0A reti ; OC0B reti ; WATCHDOG reti ; USI_STR reti ; USI_OVF 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_MAIN, FIRMWARE_VERSION_MAJOR .db FIRMWARE_VERSION_MINOR, FIRMWARE_VERSION_PATCHLEVEL firmwareStart: rjmp main ; --------------------------------------------------------------------------- ; @routine onSystemStart onSystemStart: ret ; @end ; --------------------------------------------------------------------------- ; @routine onMessageReceived ; ; Called on every message received onMessageReceived: clc ret ; @end ; --------------------------------------------------------------------------- ; @routine onEvery100ms ; ; Called every 100ms. Add your routine calls here. No arguments, no results. onEvery100ms: onEverySecond: onEveryMinute: onEveryHour: onEveryDay: ret ; @end ; --------------------------------------------------------------------------- ; @routine onEveryLoop ; ; Called on every loop (i.e. after awakening from sleep). ; onEveryLoop: ret ; @end ; *************************************************************************** ; includes .include "devices/all/hw_tn85.asm" .include "devices/all/includes.asm" ; --------------------------------------------------------------------------- ; defines for network interface .equ netInterfaceData = uart_bitbang_iface