diff options
author | Erich Eckner <git@eckner.net> | 2016-10-17 18:14:02 +0200 |
---|---|---|
committer | Erich Eckner <git@eckner.net> | 2016-10-17 18:14:02 +0200 |
commit | f836382825ff9e1e01bc0e88eed88540c3a43354 (patch) | |
tree | b38bae4be378f01ae263a54c2a39115659c93733 | |
download | Bewegungsmelder-f836382825ff9e1e01bc0e88eed88540c3a43354.tar.xz |
initial commit
-rw-r--r-- | .gitignore | 2 | ||||
-rw-r--r-- | Bewegungsmelder.asm | 153 | ||||
-rw-r--r-- | Bewegungsmelder.asmproj | 64 | ||||
-rw-r--r-- | Bewegungsmelder.atsln | 20 | ||||
-rw-r--r-- | Bewegungsmelder.atsuo | bin | 0 -> 10240 bytes |
5 files changed, 239 insertions, 0 deletions
diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..0f3a6b1 --- /dev/null +++ b/.gitignore @@ -0,0 +1,2 @@ +Debug +Release diff --git a/Bewegungsmelder.asm b/Bewegungsmelder.asm new file mode 100644 index 0000000..a87f8d0 --- /dev/null +++ b/Bewegungsmelder.asm @@ -0,0 +1,153 @@ +/*
+ * Bewegungsmelder.asm
+ *
+ * Created: 12.01.2015 13:13:40
+ * Author: Erich
+ */
+
+.INCLUDE "tn24def.inc"
+
+; auf internen 128kHz-Oszillator stellen!
+
+.DEF statusBits = r25 ; 0: hell, 1: akku voll, 2: akku nicht leer
+.EQU hellBit = 0
+.EQU akkuVollBit = 1
+.EQU akkuNLeerBit = 2
+.EQU hellSpannung = 0x80 ; Schwellwert, ab dem es hell ist
+.EQU akkuVollSpannung = 0xb9 ; Schwellwert, ab dem der Akku voll ist (= 14,4V)
+.EQU akkuLeerSpannung = 0x99 ; Schwellwert, ab dem der Akku leer ist (= 12,0V)
+.EQU zaehlerschritte = 0xffff - 0x2d00 ; 90s?
+
+ rjmp RESET
+ reti
+ reti
+ reti
+ reti
+ reti
+ reti
+ reti
+ rjmp TIMER1_OVERFLOW ; Timer1 ist übergelaufen
+ reti
+ reti
+ reti
+ reti
+ rjmp ADC_INTERRUPT ; ADC-Conversion Interrupt
+ reti
+ reti
+ reti
+
+ RESET:
+ ldi r16,low(RAMEND) ; Stackpointer initialisieren
+ out SPL,r16
+
+ sbi DIDR0,ADC0D ; digitalen Eingang an ADC0 (Phototransistor) deaktivieren
+ sbi DIDR0,ADC1D ; digitalen Eingang an ADC1 (Akkuspannung) deaktivieren
+ ldi r16,0x00
+ out ADMUX,r16 ; VCC als Spannungsreferenz und ADC0 zur Single-Ended-Messung wählen
+ ldi r16,0x10
+ out ADCSRB,r16 ; linksbündige Ergebnisse, (free-running Mode wählen - wenn Auto-Trigger "an" wäre)
+ ldi r16,0xc8
+ out ADCSRA,r16 ; ADC an, Wandlung starten, Auto-Tigger aus, (Interrupt-Flag), ADC-Interrupt an, Vorteiler = 2 (=> 64kHz)
+
+ ldi r16,0x06
+ out PRR,r16 ; Clocks: Timer/Counter 1 an, Timer/Counter 0 aus, USI aus, ADC an ... zum Stromsparen
+ ldi r16,0x00
+ out WDTCSR,r16 ; Watchdog aus
+
+ ldi r16,0x05
+ out TCCR1B,r16 ; Timer/Counter 1: Vorteiler auf 1024
+ ldi r16,0x01
+ out TIMSK1,r16 ; Timer/Counter 1: Overflow-Interrupt an
+
+ ldi r16,0x04
+ out PORTA,r16 ; LED2 aus, (3x n.d.), LED1 aus, Akku ein, kein Pull-up an PORTA1 (Akkuspannung) & PORTA0 (Phototransistor)
+ ldi r16,0x04
+ out PORTB,r16 ; Pull-up an PORTB2 (Bewegungsmelder-Signal), Licht aus, Laden aus
+ ldi r16,0x8c
+ out DDRA,r16 ; Ausgänge: PORTA7 (LED2), PORTA3 (LED1), PORTA2 (Akkuschalter)
+ ldi r16,0x03
+ out DDRB,r16 ; Ausgänge: PORTB1 (Licht), PORTB0 (Ladeschalter)
+
+ sei ; Interrupts an
+
+MAINLOOP:
+ sbrs statusBits,akkuNLeerBit ; Akku leer?
+ cbi PORTA,2 ; JA! -> Akku abklemmen
+ sbrc statusBits,akkuNLeerBit ; Akku leer?
+ sbi PORTA,2 ; nein -> Akku an
+
+ sbrs statusBits,akkuNLeerBit
+ sbi PORTA,3
+ sbrc statusBits,akkuNLeerBit
+ cbi PORTA,3
+
+ sbrs statusBits,akkuVollBit ; Akku voll?
+ rjmp AKKU_NICHT_VOLL ; nein!
+
+ sbi PORTA,7 ; LED2 an
+ sbi PORTB,0 ; Akkuladeschaltung deaktivieren
+
+ rjmp BEWEGUNG_AUSWERTEN
+AKKU_NICHT_VOLL:
+ cbi PORTA,7 ; LED2 aus
+ cbi PORTB,0 ; Akkuladeschaltung aktivieren
+
+BEWEGUNG_AUSWERTEN:
+ sbic PINB,2 ; Signal am Bewegungsmelder?
+ rjmp MAINLOOP ; nein!
+
+ sbrc statusBits,hellBit ; ist es hell?
+ rjmp MAINLOOP ; ja!
+
+ ldi r16,high(zaehlerschritte)
+ ldi r17,low(zaehlerschritte)
+ out TCNT1H,r16
+ out TCNT1L,r17 ; Timer/Counter 1 resetten
+ sbi PORTB,1 ; Licht an!
+; sbi PORTA,3 ; LED1 an
+
+ rjmp MAINLOOP
+
+ADC_INTERRUPT:
+ push r16 ; r16 und SREG pushen
+ in r16,SREG
+ push r16
+
+ in r16,ADCH ; Spannungswert holen
+
+ sbis ADMUX,MUX0
+ rjmp ADC_PHOTO
+ADC_AKKU: ; Akkuspannung wurde gemessen
+ cbi ADMUX,MUX0 ; als nächstes Phototransistor messen
+
+ cbr statusBits,((1<<akkuNLeerBit) | (1<<akkuVollBit))
+
+ cpi r16,akkuLeerSpannung
+ brcs ADC_ENDE ; r16 <= akkuLeerSpannung?
+ sbr statusBits,(1<<akkuNLeerBit); nein!
+
+ cpi r16,akkuVollSpannung
+ brcs ADC_ENDE ; r16 <= akkuVollSpannung?
+ sbr statusBits,(1<<akkuVollBit) ; nein!
+
+ rjmp ADC_ENDE
+
+ADC_PHOTO: ; Phototransistorspannung wurde gemessen
+ sbi ADMUX,MUX0 ; als nächstes Akkuspannung messen
+
+ sbr statusBits,(1<<hellBit)
+ cpi r16,hellSpannung
+ brcs ADC_ENDE ; r16 <= hellSpannung?
+ cbr statusBits,(1<<hellBit) ; nein!
+
+ADC_ENDE:
+ pop r16 ; SREG und r16 popen
+ out SREG,r16
+ pop r16
+ sbi ADCSRA,ADSC ; nächste Wandlung starten
+ reti ; ADC_INTERRUPT
+
+TIMER1_OVERFLOW:
+ cbi PORTB,1 ; Licht aus!
+; cbi PORTA,3 ; LED1 aus
+ reti ; TIMER1_OVERFLOW
diff --git a/Bewegungsmelder.asmproj b/Bewegungsmelder.asmproj new file mode 100644 index 0000000..480bc86 --- /dev/null +++ b/Bewegungsmelder.asmproj @@ -0,0 +1,64 @@ +<?xml version="1.0" encoding="utf-8"?>
+<Project DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
+ <PropertyGroup>
+ <SchemaVersion>2.0</SchemaVersion>
+ <ProjectVersion>6.2</ProjectVersion>
+ <ToolchainName>com.Atmel.AVRAssembler</ToolchainName>
+ <ProjectGuid>{08511b70-0df4-40ae-bf6b-83c4827afcf5}</ProjectGuid>
+ <avrdeviceseries>none</avrdeviceseries>
+ <avrdevice>ATtiny24</avrdevice>
+ <OutputFileName>$(MSBuildProjectName)</OutputFileName>
+ <OutputFileExtension>.obj</OutputFileExtension>
+ <OutputDirectory>$(MSBuildProjectDirectory)\$(Configuration)</OutputDirectory>
+ <Language>ASSEMBLY</Language>
+ <AssemblyName>Bewegungsmelder</AssemblyName>
+ <Name>Bewegungsmelder</Name>
+ <RootNamespace>Bewegungsmelder</RootNamespace>
+ <EntryFile>$(MSBuildProjectDirectory)\Bewegungsmelder.asm</EntryFile>
+ <ToolchainFlavour>Native</ToolchainFlavour>
+ <KeepTimersRunning>true</KeepTimersRunning>
+ <OverrideVtor>false</OverrideVtor>
+ <CacheFlash>true</CacheFlash>
+ <ProgFlashFromRam>true</ProgFlashFromRam>
+ <RamSnippetAddress>0x20000000</RamSnippetAddress>
+ <UncachedRange />
+ <preserveEEPROM>true</preserveEEPROM>
+ <OverrideVtorValue>exception_table</OverrideVtorValue>
+ <BootSegment>2</BootSegment>
+ <eraseonlaunchrule>1</eraseonlaunchrule>
+ <AsfFrameworkConfig>
+ <framework-data xmlns="">
+ <options />
+ <configurations />
+ <files />
+ <documentation help="" />
+ <offline-documentation help="" />
+ <dependencies>
+ <content-extension eid="atmel.asf" uuidref="Atmel.ASF" version="3.19.0" />
+ </dependencies>
+ </framework-data>
+ </AsfFrameworkConfig>
+ <avrtool />
+ </PropertyGroup>
+ <PropertyGroup Condition=" '$(Configuration)' == 'Debug' ">
+ <ToolchainSettings>
+ <AvrAssembler>
+ <avrasm.assembler.general.IncludeFile>(%24IncludeFile)</avrasm.assembler.general.IncludeFile>
+ </AvrAssembler>
+ </ToolchainSettings>
+ <OutputType>Executable</OutputType>
+ </PropertyGroup>
+ <PropertyGroup Condition=" '$(Configuration)' == 'Release' ">
+ <ToolchainSettings>
+ <AvrAssembler>
+ <avrasm.assembler.general.IncludeFile>(%24IncludeFile)</avrasm.assembler.general.IncludeFile>
+ </AvrAssembler>
+ </ToolchainSettings>
+ </PropertyGroup>
+ <ItemGroup>
+ <Compile Include="Bewegungsmelder.asm">
+ <SubType>Code</SubType>
+ </Compile>
+ </ItemGroup>
+ <Import Project="$(AVRSTUDIO_EXE_PATH)\\Vs\\Assembler.targets" />
+</Project>
\ No newline at end of file diff --git a/Bewegungsmelder.atsln b/Bewegungsmelder.atsln new file mode 100644 index 0000000..2cf23eb --- /dev/null +++ b/Bewegungsmelder.atsln @@ -0,0 +1,20 @@ +
+Microsoft Visual Studio Solution File, Format Version 11.00
+# Atmel Studio Solution File, Format Version 11.00
+Project("{18226A42-8477-4023-8AD2-40C49DA407C9}") = "Bewegungsmelder", "Bewegungsmelder.asmproj", "{08511B70-0DF4-40AE-BF6B-83C4827AFCF5}"
+EndProject
+Global
+ GlobalSection(SolutionConfigurationPlatforms) = preSolution
+ Debug|AVR = Debug|AVR
+ Release|AVR = Release|AVR
+ EndGlobalSection
+ GlobalSection(ProjectConfigurationPlatforms) = postSolution
+ {08511B70-0DF4-40AE-BF6B-83C4827AFCF5}.Debug|AVR.ActiveCfg = Debug|AVR
+ {08511B70-0DF4-40AE-BF6B-83C4827AFCF5}.Debug|AVR.Build.0 = Debug|AVR
+ {08511B70-0DF4-40AE-BF6B-83C4827AFCF5}.Release|AVR.ActiveCfg = Release|AVR
+ {08511B70-0DF4-40AE-BF6B-83C4827AFCF5}.Release|AVR.Build.0 = Release|AVR
+ EndGlobalSection
+ GlobalSection(SolutionProperties) = preSolution
+ HideSolutionNode = FALSE
+ EndGlobalSection
+EndGlobal
diff --git a/Bewegungsmelder.atsuo b/Bewegungsmelder.atsuo Binary files differnew file mode 100644 index 0000000..d37b887 --- /dev/null +++ b/Bewegungsmelder.atsuo |