1214 lines
50 KiB
Plaintext
1214 lines
50 KiB
Plaintext
|
|
Door.elf: file format elf32-avr
|
|
|
|
Sections:
|
|
Idx Name Size VMA LMA File off Algn
|
|
0 .data 0000008a 00800100 000006c4 00000758 2**0
|
|
CONTENTS, ALLOC, LOAD, DATA
|
|
1 .text 000006c4 00000000 00000000 00000094 2**1
|
|
CONTENTS, ALLOC, LOAD, READONLY, CODE
|
|
2 .bss 00000195 0080018a 0080018a 000007e2 2**0
|
|
ALLOC
|
|
3 .stab 000006cc 00000000 00000000 000007e4 2**2
|
|
CONTENTS, READONLY, DEBUGGING
|
|
4 .stabstr 00000082 00000000 00000000 00000eb0 2**0
|
|
CONTENTS, READONLY, DEBUGGING
|
|
5 .comment 0000002f 00000000 00000000 00000f32 2**0
|
|
CONTENTS, READONLY
|
|
6 .debug_aranges 00000050 00000000 00000000 00000f61 2**0
|
|
CONTENTS, READONLY, DEBUGGING
|
|
7 .debug_info 00002dfe 00000000 00000000 00000fb1 2**0
|
|
CONTENTS, READONLY, DEBUGGING
|
|
8 .debug_abbrev 0000044d 00000000 00000000 00003daf 2**0
|
|
CONTENTS, READONLY, DEBUGGING
|
|
9 .debug_line 0000063c 00000000 00000000 000041fc 2**0
|
|
CONTENTS, READONLY, DEBUGGING
|
|
10 .debug_frame 000000e4 00000000 00000000 00004838 2**2
|
|
CONTENTS, READONLY, DEBUGGING
|
|
11 .debug_str 00000c33 00000000 00000000 0000491c 2**0
|
|
CONTENTS, READONLY, DEBUGGING
|
|
12 .debug_loc 00000cd8 00000000 00000000 0000554f 2**0
|
|
CONTENTS, READONLY, DEBUGGING
|
|
13 .debug_ranges 000004a8 00000000 00000000 00006227 2**0
|
|
CONTENTS, READONLY, DEBUGGING
|
|
|
|
Disassembly of section .text:
|
|
|
|
00000000 <__vectors>:
|
|
0: 0c 94 35 00 jmp 0x6a ; 0x6a <__ctors_end>
|
|
4: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
8: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
c: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
10: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
14: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
18: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
1c: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
20: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
24: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
28: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
2c: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
30: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
34: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
38: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
3c: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
40: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
44: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
48: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
4c: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
50: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
54: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
58: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
5c: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
60: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
64: 0c 94 5d 00 jmp 0xba ; 0xba <__bad_interrupt>
|
|
|
|
00000068 <__ctors_start>:
|
|
68: 21 03 mulsu r18, r17
|
|
|
|
0000006a <__ctors_end>:
|
|
6a: 11 24 eor r1, r1
|
|
6c: 1f be out 0x3f, r1 ; 63
|
|
6e: cf ef ldi r28, 0xFF ; 255
|
|
70: d4 e0 ldi r29, 0x04 ; 4
|
|
72: de bf out 0x3e, r29 ; 62
|
|
74: cd bf out 0x3d, r28 ; 61
|
|
|
|
00000076 <__do_copy_data>:
|
|
76: 11 e0 ldi r17, 0x01 ; 1
|
|
78: a0 e0 ldi r26, 0x00 ; 0
|
|
7a: b1 e0 ldi r27, 0x01 ; 1
|
|
7c: e4 ec ldi r30, 0xC4 ; 196
|
|
7e: f6 e0 ldi r31, 0x06 ; 6
|
|
80: 02 c0 rjmp .+4 ; 0x86 <__do_copy_data+0x10>
|
|
82: 05 90 lpm r0, Z+
|
|
84: 0d 92 st X+, r0
|
|
86: aa 38 cpi r26, 0x8A ; 138
|
|
88: b1 07 cpc r27, r17
|
|
8a: d9 f7 brne .-10 ; 0x82 <__do_copy_data+0xc>
|
|
|
|
0000008c <__do_clear_bss>:
|
|
8c: 23 e0 ldi r18, 0x03 ; 3
|
|
8e: aa e8 ldi r26, 0x8A ; 138
|
|
90: b1 e0 ldi r27, 0x01 ; 1
|
|
92: 01 c0 rjmp .+2 ; 0x96 <.do_clear_bss_start>
|
|
|
|
00000094 <.do_clear_bss_loop>:
|
|
94: 1d 92 st X+, r1
|
|
|
|
00000096 <.do_clear_bss_start>:
|
|
96: af 31 cpi r26, 0x1F ; 31
|
|
98: b2 07 cpc r27, r18
|
|
9a: e1 f7 brne .-8 ; 0x94 <.do_clear_bss_loop>
|
|
|
|
0000009c <__do_global_ctors>:
|
|
9c: 10 e0 ldi r17, 0x00 ; 0
|
|
9e: ca e6 ldi r28, 0x6A ; 106
|
|
a0: d0 e0 ldi r29, 0x00 ; 0
|
|
a2: 04 c0 rjmp .+8 ; 0xac <__do_global_ctors+0x10>
|
|
a4: 22 97 sbiw r28, 0x02 ; 2
|
|
a6: fe 01 movw r30, r28
|
|
a8: 0e 94 5c 03 call 0x6b8 ; 0x6b8 <__tablejump__>
|
|
ac: c8 36 cpi r28, 0x68 ; 104
|
|
ae: d1 07 cpc r29, r17
|
|
b0: c9 f7 brne .-14 ; 0xa4 <__do_global_ctors+0x8>
|
|
b2: 0e 94 a3 02 call 0x546 ; 0x546 <main>
|
|
b6: 0c 94 60 03 jmp 0x6c0 ; 0x6c0 <_exit>
|
|
|
|
000000ba <__bad_interrupt>:
|
|
ba: 0c 94 00 00 jmp 0 ; 0x0 <__vectors>
|
|
|
|
000000be <_Z8read8bitv>:
|
|
uart_putchar(*text);
|
|
text++;
|
|
}
|
|
}
|
|
void printDec(uint16_t wert) {
|
|
print((wert/10000)+'0');
|
|
be: 20 e0 ldi r18, 0x00 ; 0
|
|
c0: 30 e0 ldi r19, 0x00 ; 0
|
|
c2: 80 e0 ldi r24, 0x00 ; 0
|
|
c4: 61 e0 ldi r22, 0x01 ; 1
|
|
c6: 70 e0 ldi r23, 0x00 ; 0
|
|
c8: 4a 99 sbic 0x09, 2 ; 9
|
|
ca: fe cf rjmp .-4 ; 0xc8 <_Z8read8bitv+0xa>
|
|
cc: 28 9a sbi 0x05, 0 ; 5
|
|
ce: e7 eb ldi r30, 0xB7 ; 183
|
|
d0: fb e0 ldi r31, 0x0B ; 11
|
|
d2: 31 97 sbiw r30, 0x01 ; 1
|
|
d4: f1 f7 brne .-4 ; 0xd2 <_Z8read8bitv+0x14>
|
|
d6: 00 c0 rjmp .+0 ; 0xd8 <_Z8read8bitv+0x1a>
|
|
d8: 00 00 nop
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
da: 4a 99 sbic 0x09, 2 ; 9
|
|
dc: 08 c0 rjmp .+16 ; 0xee <_Z8read8bitv+0x30>
|
|
de: ab 01 movw r20, r22
|
|
UDR0 = c;
|
|
e0: 02 2e mov r0, r18
|
|
text++;
|
|
}
|
|
}
|
|
void printDec(uint16_t wert) {
|
|
print((wert/10000)+'0');
|
|
print(((wert/1000)%10)+'0');
|
|
e2: 02 c0 rjmp .+4 ; 0xe8 <_Z8read8bitv+0x2a>
|
|
e4: 44 0f add r20, r20
|
|
e6: 55 1f adc r21, r21
|
|
e8: 0a 94 dec r0
|
|
ea: e2 f7 brpl .-8 ; 0xe4 <_Z8read8bitv+0x26>
|
|
ec: 84 2b or r24, r20
|
|
ee: 4a 9b sbis 0x09, 2 ; 9
|
|
f0: fe cf rjmp .-4 ; 0xee <_Z8read8bitv+0x30>
|
|
f2: 28 98 cbi 0x05, 0 ; 5
|
|
f4: f2 e4 ldi r31, 0x42 ; 66
|
|
f6: fa 95 dec r31
|
|
f8: f1 f7 brne .-4 ; 0xf6 <_Z8read8bitv+0x38>
|
|
fa: 00 c0 rjmp .+0 ; 0xfc <_Z8read8bitv+0x3e>
|
|
fc: 2f 5f subi r18, 0xFF ; 255
|
|
fe: 3f 4f sbci r19, 0xFF ; 255
|
|
100: 28 30 cpi r18, 0x08 ; 8
|
|
102: 31 05 cpc r19, r1
|
|
104: 09 f7 brne .-62 ; 0xc8 <_Z8read8bitv+0xa>
|
|
106: 08 95 ret
|
|
|
|
00000108 <_Z7recievev>:
|
|
108: 1f 93 push r17
|
|
10a: cf 93 push r28
|
|
10c: df 93 push r29
|
|
10e: 4a 99 sbic 0x09, 2 ; 9
|
|
110: 16 c2 rjmp .+1068 ; 0x53e <__stack+0x3f>
|
|
112: 8f e1 ldi r24, 0x1F ; 31
|
|
114: 9e e4 ldi r25, 0x4E ; 78
|
|
116: 01 97 sbiw r24, 0x01 ; 1
|
|
118: f1 f7 brne .-4 ; 0x116 <_Z7recievev+0xe>
|
|
11a: 00 c0 rjmp .+0 ; 0x11c <_Z7recievev+0x14>
|
|
11c: 00 00 nop
|
|
11e: 4a 99 sbic 0x09, 2 ; 9
|
|
120: 0e c2 rjmp .+1052 ; 0x53e <__stack+0x3f>
|
|
122: 4a 9b sbis 0x09, 2 ; 9
|
|
124: fe cf rjmp .-4 ; 0x122 <_Z7recievev+0x1a>
|
|
126: 0e 94 5f 00 call 0xbe ; 0xbe <_Z8read8bitv>
|
|
12a: 18 2f mov r17, r24
|
|
12c: 0e 94 5f 00 call 0xbe ; 0xbe <_Z8read8bitv>
|
|
130: 0e 94 5f 00 call 0xbe ; 0xbe <_Z8read8bitv>
|
|
134: 48 2f mov r20, r24
|
|
136: c8 2f mov r28, r24
|
|
138: d0 e0 ldi r29, 0x00 ; 0
|
|
13a: e0 ec ldi r30, 0xC0 ; 192
|
|
13c: f0 e0 ldi r31, 0x00 ; 0
|
|
13e: 80 81 ld r24, Z
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
140: 85 ff sbrs r24, 5
|
|
142: fd cf rjmp .-6 ; 0x13e <_Z7recievev+0x36>
|
|
144: 80 e3 ldi r24, 0x30 ; 48
|
|
UDR0 = c;
|
|
146: 80 93 c6 00 sts 0x00C6, r24
|
|
}
|
|
}
|
|
void printDec(uint16_t wert) {
|
|
print((wert/10000)+'0');
|
|
print(((wert/1000)%10)+'0');
|
|
print(((wert/100)%10)+'0');
|
|
14a: 60 e0 ldi r22, 0x00 ; 0
|
|
14c: 70 e0 ldi r23, 0x00 ; 0
|
|
14e: cb 01 movw r24, r22
|
|
150: 96 95 lsr r25
|
|
152: 87 95 ror r24
|
|
154: 96 95 lsr r25
|
|
156: 87 95 ror r24
|
|
158: 96 95 lsr r25
|
|
15a: 87 95 ror r24
|
|
15c: 9c 01 movw r18, r24
|
|
15e: 22 0f add r18, r18
|
|
160: 33 1f adc r19, r19
|
|
162: 88 0f add r24, r24
|
|
164: 99 1f adc r25, r25
|
|
166: 88 0f add r24, r24
|
|
168: 99 1f adc r25, r25
|
|
16a: 88 0f add r24, r24
|
|
16c: 99 1f adc r25, r25
|
|
16e: 82 0f add r24, r18
|
|
170: 93 1f adc r25, r19
|
|
172: 68 1b sub r22, r24
|
|
174: 79 0b sbc r23, r25
|
|
176: 60 5d subi r22, 0xD0 ; 208
|
|
178: e0 ec ldi r30, 0xC0 ; 192
|
|
17a: f0 e0 ldi r31, 0x00 ; 0
|
|
17c: 80 81 ld r24, Z
|
|
17e: 85 ff sbrs r24, 5
|
|
180: fd cf rjmp .-6 ; 0x17c <_Z7recievev+0x74>
|
|
182: 60 93 c6 00 sts 0x00C6, r22
|
|
186: 9e 01 movw r18, r28
|
|
188: 36 95 lsr r19
|
|
18a: 27 95 ror r18
|
|
18c: 36 95 lsr r19
|
|
18e: 27 95 ror r18
|
|
190: ab e7 ldi r26, 0x7B ; 123
|
|
192: b4 e1 ldi r27, 0x14 ; 20
|
|
194: 0e 94 4e 03 call 0x69c ; 0x69c <__umulhisi3>
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
198: 96 95 lsr r25
|
|
19a: 87 95 ror r24
|
|
UDR0 = c;
|
|
19c: 80 5d subi r24, 0xD0 ; 208
|
|
}
|
|
void printDec(uint16_t wert) {
|
|
print((wert/10000)+'0');
|
|
print(((wert/1000)%10)+'0');
|
|
print(((wert/100)%10)+'0');
|
|
print(((wert/10)%10)+'0');
|
|
19e: e0 ec ldi r30, 0xC0 ; 192
|
|
1a0: f0 e0 ldi r31, 0x00 ; 0
|
|
1a2: 90 81 ld r25, Z
|
|
1a4: 95 ff sbrs r25, 5
|
|
1a6: fd cf rjmp .-6 ; 0x1a2 <_Z7recievev+0x9a>
|
|
1a8: 80 93 c6 00 sts 0x00C6, r24
|
|
1ac: 9e 01 movw r18, r28
|
|
1ae: ad ec ldi r26, 0xCD ; 205
|
|
1b0: bc ec ldi r27, 0xCC ; 204
|
|
1b2: 0e 94 4e 03 call 0x69c ; 0x69c <__umulhisi3>
|
|
1b6: fc 01 movw r30, r24
|
|
1b8: f6 95 lsr r31
|
|
1ba: e7 95 ror r30
|
|
1bc: f6 95 lsr r31
|
|
1be: e7 95 ror r30
|
|
1c0: f6 95 lsr r31
|
|
1c2: e7 95 ror r30
|
|
1c4: 9f 01 movw r18, r30
|
|
1c6: 0e 94 4e 03 call 0x69c ; 0x69c <__umulhisi3>
|
|
1ca: 96 95 lsr r25
|
|
1cc: 87 95 ror r24
|
|
1ce: 96 95 lsr r25
|
|
1d0: 87 95 ror r24
|
|
1d2: 96 95 lsr r25
|
|
1d4: 87 95 ror r24
|
|
1d6: 9c 01 movw r18, r24
|
|
1d8: 22 0f add r18, r18
|
|
1da: 33 1f adc r19, r19
|
|
1dc: 88 0f add r24, r24
|
|
1de: 99 1f adc r25, r25
|
|
1e0: 88 0f add r24, r24
|
|
1e2: 99 1f adc r25, r25
|
|
1e4: 88 0f add r24, r24
|
|
1e6: 99 1f adc r25, r25
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
1e8: 82 0f add r24, r18
|
|
1ea: 93 1f adc r25, r19
|
|
1ec: e8 1b sub r30, r24
|
|
UDR0 = c;
|
|
1ee: f9 0b sbc r31, r25
|
|
void printDec(uint16_t wert) {
|
|
print((wert/10000)+'0');
|
|
print(((wert/1000)%10)+'0');
|
|
print(((wert/100)%10)+'0');
|
|
print(((wert/10)%10)+'0');
|
|
print((wert%10)+'0');
|
|
1f0: 9e 2f mov r25, r30
|
|
1f2: 90 5d subi r25, 0xD0 ; 208
|
|
1f4: e0 ec ldi r30, 0xC0 ; 192
|
|
1f6: f0 e0 ldi r31, 0x00 ; 0
|
|
1f8: 80 81 ld r24, Z
|
|
1fa: 85 ff sbrs r24, 5
|
|
1fc: fd cf rjmp .-6 ; 0x1f8 <_Z7recievev+0xf0>
|
|
1fe: 90 93 c6 00 sts 0x00C6, r25
|
|
202: 9e 01 movw r18, r28
|
|
204: ad ec ldi r26, 0xCD ; 205
|
|
206: bc ec ldi r27, 0xCC ; 204
|
|
208: 0e 94 4e 03 call 0x69c ; 0x69c <__umulhisi3>
|
|
20c: 96 95 lsr r25
|
|
20e: 87 95 ror r24
|
|
210: 96 95 lsr r25
|
|
212: 87 95 ror r24
|
|
214: 96 95 lsr r25
|
|
216: 87 95 ror r24
|
|
218: 9c 01 movw r18, r24
|
|
21a: 22 0f add r18, r18
|
|
21c: 33 1f adc r19, r19
|
|
21e: 88 0f add r24, r24
|
|
220: 99 1f adc r25, r25
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
222: 88 0f add r24, r24
|
|
224: 99 1f adc r25, r25
|
|
226: 88 0f add r24, r24
|
|
UDR0 = c;
|
|
228: 99 1f adc r25, r25
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
22a: 82 0f add r24, r18
|
|
22c: 93 1f adc r25, r19
|
|
22e: c8 1b sub r28, r24
|
|
UDR0 = c;
|
|
230: d9 0b sbc r29, r25
|
|
void printpulses(void) {
|
|
Serial.println("\n\r\n\rReceived: \n\rOFF \tON");
|
|
for (uint8_t i = 0; i < currentpulse; i++) {
|
|
Serial.printDec(pulses[i][0] * RESOLUTION);
|
|
Serial.print(" ");
|
|
Serial.printDec(pulses[i][1] * RESOLUTION);
|
|
232: c0 5d subi r28, 0xD0 ; 208
|
|
234: e0 ec ldi r30, 0xC0 ; 192
|
|
236: f0 e0 ldi r31, 0x00 ; 0
|
|
238: 80 81 ld r24, Z
|
|
23a: 85 ff sbrs r24, 5
|
|
23c: fd cf rjmp .-6 ; 0x238 <_Z7recievev+0x130>
|
|
23e: c0 93 c6 00 sts 0x00C6, r28
|
|
242: a4 e5 ldi r26, 0x54 ; 84
|
|
244: b1 e0 ldi r27, 0x01 ; 1
|
|
246: 90 e2 ldi r25, 0x20 ; 32
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
248: e0 ec ldi r30, 0xC0 ; 192
|
|
24a: f0 e0 ldi r31, 0x00 ; 0
|
|
24c: c6 ec ldi r28, 0xC6 ; 198
|
|
24e: d0 e0 ldi r29, 0x00 ; 0
|
|
250: 80 81 ld r24, Z
|
|
252: 85 ff sbrs r24, 5
|
|
254: fd cf rjmp .-6 ; 0x250 <_Z7recievev+0x148>
|
|
256: 98 83 st Y, r25
|
|
uart_putchar(*text);
|
|
text++;
|
|
}
|
|
}
|
|
void printDec(uint16_t wert) {
|
|
print((wert/10000)+'0');
|
|
258: 9d 91 ld r25, X+
|
|
25a: 91 11 cpse r25, r1
|
|
25c: f9 cf rjmp .-14 ; 0x250 <_Z7recievev+0x148>
|
|
25e: e0 ec ldi r30, 0xC0 ; 192
|
|
260: f0 e0 ldi r31, 0x00 ; 0
|
|
262: 80 81 ld r24, Z
|
|
264: 85 ff sbrs r24, 5
|
|
266: fd cf rjmp .-6 ; 0x262 <_Z7recievev+0x15a>
|
|
268: 8d e0 ldi r24, 0x0D ; 13
|
|
26a: 80 93 c6 00 sts 0x00C6, r24
|
|
26e: e0 ec ldi r30, 0xC0 ; 192
|
|
270: f0 e0 ldi r31, 0x00 ; 0
|
|
272: 80 81 ld r24, Z
|
|
274: 85 ff sbrs r24, 5
|
|
276: fd cf rjmp .-6 ; 0x272 <_Z7recievev+0x16a>
|
|
278: 8a e0 ldi r24, 0x0A ; 10
|
|
27a: 80 93 c6 00 sts 0x00C6, r24
|
|
print(((wert/1000)%10)+'0');
|
|
27e: 11 11 cpse r17, r1
|
|
280: 5e c1 rjmp .+700 ; 0x53e <__stack+0x3f>
|
|
282: 4f 3e cpi r20, 0xEF ; 239
|
|
284: 09 f0 breq .+2 ; 0x288 <_Z7recievev+0x180>
|
|
286: 5b c1 rjmp .+694 ; 0x53e <__stack+0x3f>
|
|
288: 0e 94 5f 00 call 0xbe ; 0xbe <_Z8read8bitv>
|
|
28c: 18 2f mov r17, r24
|
|
28e: 0e 94 5f 00 call 0xbe ; 0xbe <_Z8read8bitv>
|
|
292: 48 2f mov r20, r24
|
|
294: ab e5 ldi r26, 0x5B ; 91
|
|
296: b1 e0 ldi r27, 0x01 ; 1
|
|
298: 22 e5 ldi r18, 0x52 ; 82
|
|
29a: e0 ec ldi r30, 0xC0 ; 192
|
|
29c: f0 e0 ldi r31, 0x00 ; 0
|
|
29e: c6 ec ldi r28, 0xC6 ; 198
|
|
2a0: d0 e0 ldi r29, 0x00 ; 0
|
|
2a2: 90 81 ld r25, Z
|
|
2a4: 95 ff sbrs r25, 5
|
|
2a6: fd cf rjmp .-6 ; 0x2a2 <_Z7recievev+0x19a>
|
|
2a8: 28 83 st Y, r18
|
|
2aa: 2d 91 ld r18, X+
|
|
2ac: 21 11 cpse r18, r1
|
|
2ae: f9 cf rjmp .-14 ; 0x2a2 <_Z7recievev+0x19a>
|
|
2b0: e0 ec ldi r30, 0xC0 ; 192
|
|
2b2: f0 e0 ldi r31, 0x00 ; 0
|
|
2b4: 90 81 ld r25, Z
|
|
2b6: 95 ff sbrs r25, 5
|
|
2b8: fd cf rjmp .-6 ; 0x2b4 <_Z7recievev+0x1ac>
|
|
2ba: 8d e0 ldi r24, 0x0D ; 13
|
|
2bc: 80 93 c6 00 sts 0x00C6, r24
|
|
2c0: e0 ec ldi r30, 0xC0 ; 192
|
|
2c2: f0 e0 ldi r31, 0x00 ; 0
|
|
2c4: 90 81 ld r25, Z
|
|
2c6: 95 ff sbrs r25, 5
|
|
2c8: fd cf rjmp .-6 ; 0x2c4 <_Z7recievev+0x1bc>
|
|
2ca: 8a e0 ldi r24, 0x0A ; 10
|
|
2cc: 80 93 c6 00 sts 0x00C6, r24
|
|
2d0: e0 ec ldi r30, 0xC0 ; 192
|
|
2d2: f0 e0 ldi r31, 0x00 ; 0
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
2d4: 80 81 ld r24, Z
|
|
2d6: 85 ff sbrs r24, 5
|
|
2d8: fd cf rjmp .-6 ; 0x2d4 <_Z7recievev+0x1cc>
|
|
UDR0 = c;
|
|
2da: c1 2f mov r28, r17
|
|
}
|
|
}
|
|
void printDec(uint16_t wert) {
|
|
print((wert/10000)+'0');
|
|
print(((wert/1000)%10)+'0');
|
|
print(((wert/100)%10)+'0');
|
|
2dc: d0 e0 ldi r29, 0x00 ; 0
|
|
2de: 80 e3 ldi r24, 0x30 ; 48
|
|
2e0: 80 93 c6 00 sts 0x00C6, r24
|
|
2e4: 60 e0 ldi r22, 0x00 ; 0
|
|
2e6: 70 e0 ldi r23, 0x00 ; 0
|
|
2e8: cb 01 movw r24, r22
|
|
2ea: 96 95 lsr r25
|
|
2ec: 87 95 ror r24
|
|
2ee: 96 95 lsr r25
|
|
2f0: 87 95 ror r24
|
|
2f2: 96 95 lsr r25
|
|
2f4: 87 95 ror r24
|
|
2f6: 9c 01 movw r18, r24
|
|
2f8: 22 0f add r18, r18
|
|
2fa: 33 1f adc r19, r19
|
|
2fc: 88 0f add r24, r24
|
|
2fe: 99 1f adc r25, r25
|
|
300: 88 0f add r24, r24
|
|
302: 99 1f adc r25, r25
|
|
304: 88 0f add r24, r24
|
|
306: 99 1f adc r25, r25
|
|
308: 82 0f add r24, r18
|
|
30a: 93 1f adc r25, r19
|
|
30c: 68 1b sub r22, r24
|
|
30e: 79 0b sbc r23, r25
|
|
310: 60 5d subi r22, 0xD0 ; 208
|
|
312: e0 ec ldi r30, 0xC0 ; 192
|
|
314: f0 e0 ldi r31, 0x00 ; 0
|
|
316: 80 81 ld r24, Z
|
|
318: 85 ff sbrs r24, 5
|
|
31a: fd cf rjmp .-6 ; 0x316 <_Z7recievev+0x20e>
|
|
31c: 60 93 c6 00 sts 0x00C6, r22
|
|
320: 9e 01 movw r18, r28
|
|
322: 36 95 lsr r19
|
|
324: 27 95 ror r18
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
326: 36 95 lsr r19
|
|
328: 27 95 ror r18
|
|
32a: ab e7 ldi r26, 0x7B ; 123
|
|
UDR0 = c;
|
|
32c: b4 e1 ldi r27, 0x14 ; 20
|
|
}
|
|
void printDec(uint16_t wert) {
|
|
print((wert/10000)+'0');
|
|
print(((wert/1000)%10)+'0');
|
|
print(((wert/100)%10)+'0');
|
|
print(((wert/10)%10)+'0');
|
|
32e: 0e 94 4e 03 call 0x69c ; 0x69c <__umulhisi3>
|
|
332: 96 95 lsr r25
|
|
334: 87 95 ror r24
|
|
336: 80 5d subi r24, 0xD0 ; 208
|
|
338: e0 ec ldi r30, 0xC0 ; 192
|
|
33a: f0 e0 ldi r31, 0x00 ; 0
|
|
33c: 90 81 ld r25, Z
|
|
33e: 95 ff sbrs r25, 5
|
|
340: fd cf rjmp .-6 ; 0x33c <_Z7recievev+0x234>
|
|
342: 80 93 c6 00 sts 0x00C6, r24
|
|
346: 9e 01 movw r18, r28
|
|
348: ad ec ldi r26, 0xCD ; 205
|
|
34a: bc ec ldi r27, 0xCC ; 204
|
|
34c: 0e 94 4e 03 call 0x69c ; 0x69c <__umulhisi3>
|
|
350: fc 01 movw r30, r24
|
|
352: f6 95 lsr r31
|
|
354: e7 95 ror r30
|
|
356: f6 95 lsr r31
|
|
358: e7 95 ror r30
|
|
35a: f6 95 lsr r31
|
|
35c: e7 95 ror r30
|
|
35e: 9f 01 movw r18, r30
|
|
360: 0e 94 4e 03 call 0x69c ; 0x69c <__umulhisi3>
|
|
364: 96 95 lsr r25
|
|
366: 87 95 ror r24
|
|
368: 96 95 lsr r25
|
|
36a: 87 95 ror r24
|
|
36c: 96 95 lsr r25
|
|
36e: 87 95 ror r24
|
|
370: 9c 01 movw r18, r24
|
|
372: 22 0f add r18, r18
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
374: 33 1f adc r19, r19
|
|
376: 88 0f add r24, r24
|
|
378: 99 1f adc r25, r25
|
|
UDR0 = c;
|
|
37a: 88 0f add r24, r24
|
|
void printDec(uint16_t wert) {
|
|
print((wert/10000)+'0');
|
|
print(((wert/1000)%10)+'0');
|
|
print(((wert/100)%10)+'0');
|
|
print(((wert/10)%10)+'0');
|
|
print((wert%10)+'0');
|
|
37c: 99 1f adc r25, r25
|
|
37e: 88 0f add r24, r24
|
|
380: 99 1f adc r25, r25
|
|
382: 82 0f add r24, r18
|
|
384: 93 1f adc r25, r19
|
|
386: e8 1b sub r30, r24
|
|
388: f9 0b sbc r31, r25
|
|
38a: 9e 2f mov r25, r30
|
|
38c: 90 5d subi r25, 0xD0 ; 208
|
|
38e: e0 ec ldi r30, 0xC0 ; 192
|
|
390: f0 e0 ldi r31, 0x00 ; 0
|
|
392: 80 81 ld r24, Z
|
|
394: 85 ff sbrs r24, 5
|
|
396: fd cf rjmp .-6 ; 0x392 <_Z7recievev+0x28a>
|
|
398: 90 93 c6 00 sts 0x00C6, r25
|
|
39c: 9e 01 movw r18, r28
|
|
39e: ad ec ldi r26, 0xCD ; 205
|
|
3a0: bc ec ldi r27, 0xCC ; 204
|
|
3a2: 0e 94 4e 03 call 0x69c ; 0x69c <__umulhisi3>
|
|
3a6: 96 95 lsr r25
|
|
3a8: 87 95 ror r24
|
|
3aa: 96 95 lsr r25
|
|
3ac: 87 95 ror r24
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
3ae: 96 95 lsr r25
|
|
3b0: 87 95 ror r24
|
|
3b2: 9c 01 movw r18, r24
|
|
UDR0 = c;
|
|
3b4: 22 0f add r18, r18
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
3b6: 33 1f adc r19, r19
|
|
3b8: 88 0f add r24, r24
|
|
3ba: 99 1f adc r25, r25
|
|
UDR0 = c;
|
|
3bc: 88 0f add r24, r24
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
3be: 99 1f adc r25, r25
|
|
3c0: 88 0f add r24, r24
|
|
3c2: 99 1f adc r25, r25
|
|
UDR0 = c;
|
|
3c4: 82 0f add r24, r18
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
3c6: 93 1f adc r25, r19
|
|
3c8: c8 1b sub r28, r24
|
|
3ca: d9 0b sbc r29, r25
|
|
UDR0 = c;
|
|
3cc: c0 5d subi r28, 0xD0 ; 208
|
|
uint16_t volatile pulses[100][2]; // pair is high and low pulse
|
|
uint8_t volatile currentpulse = 0;
|
|
|
|
void printpulses(void) {
|
|
Serial.println("\n\r\n\rReceived: \n\rOFF \tON");
|
|
for (uint8_t i = 0; i < currentpulse; i++) {
|
|
3ce: e0 ec ldi r30, 0xC0 ; 192
|
|
3d0: f0 e0 ldi r31, 0x00 ; 0
|
|
3d2: 80 81 ld r24, Z
|
|
3d4: 85 ff sbrs r24, 5
|
|
3d6: fd cf rjmp .-6 ; 0x3d2 <_Z7recievev+0x2ca>
|
|
3d8: c0 93 c6 00 sts 0x00C6, r28
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
3dc: a6 e6 ldi r26, 0x66 ; 102
|
|
3de: b1 e0 ldi r27, 0x01 ; 1
|
|
3e0: 90 e2 ldi r25, 0x20 ; 32
|
|
UDR0 = c;
|
|
3e2: e0 ec ldi r30, 0xC0 ; 192
|
|
sei();
|
|
init();
|
|
println("Uart done!");
|
|
}
|
|
void print(const char *text) {
|
|
while (*text)
|
|
3e4: f0 e0 ldi r31, 0x00 ; 0
|
|
3e6: c6 ec ldi r28, 0xC6 ; 198
|
|
3e8: d0 e0 ldi r29, 0x00 ; 0
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
3ea: 80 81 ld r24, Z
|
|
3ec: 85 ff sbrs r24, 5
|
|
3ee: fd cf rjmp .-6 ; 0x3ea <_Z7recievev+0x2e2>
|
|
3f0: 98 83 st Y, r25
|
|
3f2: 9d 91 ld r25, X+
|
|
UDR0 = c;
|
|
3f4: 91 11 cpse r25, r1
|
|
3f6: f9 cf rjmp .-14 ; 0x3ea <_Z7recievev+0x2e2>
|
|
3f8: 50 e0 ldi r21, 0x00 ; 0
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
3fa: e0 ec ldi r30, 0xC0 ; 192
|
|
3fc: f0 e0 ldi r31, 0x00 ; 0
|
|
3fe: 80 81 ld r24, Z
|
|
400: 85 ff sbrs r24, 5
|
|
402: fd cf rjmp .-6 ; 0x3fe <_Z7recievev+0x2f6>
|
|
UDR0 = c;
|
|
404: 80 e3 ldi r24, 0x30 ; 48
|
|
406: 80 93 c6 00 sts 0x00C6, r24
|
|
40a: 60 e0 ldi r22, 0x00 ; 0
|
|
40c: 70 e0 ldi r23, 0x00 ; 0
|
|
sei();
|
|
init();
|
|
println("Uart done!");
|
|
}
|
|
void print(const char *text) {
|
|
while (*text)
|
|
40e: cb 01 movw r24, r22
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
410: 96 95 lsr r25
|
|
412: 87 95 ror r24
|
|
UDR0 = c;
|
|
414: 96 95 lsr r25
|
|
416: 87 95 ror r24
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
418: 96 95 lsr r25
|
|
41a: 87 95 ror r24
|
|
41c: 9c 01 movw r18, r24
|
|
UDR0 = c;
|
|
41e: 22 0f add r18, r18
|
|
sei();
|
|
init();
|
|
println("Uart done!");
|
|
}
|
|
void print(const char *text) {
|
|
while (*text)
|
|
420: 33 1f adc r19, r19
|
|
422: 88 0f add r24, r24
|
|
424: 99 1f adc r25, r25
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
426: 88 0f add r24, r24
|
|
428: 99 1f adc r25, r25
|
|
42a: 88 0f add r24, r24
|
|
42c: 99 1f adc r25, r25
|
|
42e: 82 0f add r24, r18
|
|
UDR0 = c;
|
|
430: 93 1f adc r25, r19
|
|
432: 68 1b sub r22, r24
|
|
434: 79 0b sbc r23, r25
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
436: 60 5d subi r22, 0xD0 ; 208
|
|
438: e0 ec ldi r30, 0xC0 ; 192
|
|
43a: f0 e0 ldi r31, 0x00 ; 0
|
|
43c: 80 81 ld r24, Z
|
|
43e: 85 ff sbrs r24, 5
|
|
UDR0 = c;
|
|
440: fd cf rjmp .-6 ; 0x43c <_Z7recievev+0x334>
|
|
442: 60 93 c6 00 sts 0x00C6, r22
|
|
}
|
|
|
|
// print it in a 'array' format
|
|
Serial.println("int IRsignal[] = {");
|
|
Serial.println("// OFF, ON (in 10's of microseconds)");
|
|
for (uint8_t i = 0; i < currentpulse-1; i++) {
|
|
446: 9a 01 movw r18, r20
|
|
448: 36 95 lsr r19
|
|
44a: 27 95 ror r18
|
|
44c: 36 95 lsr r19
|
|
44e: 27 95 ror r18
|
|
450: ab e7 ldi r26, 0x7B ; 123
|
|
452: b4 e1 ldi r27, 0x14 ; 20
|
|
454: 0e 94 4e 03 call 0x69c ; 0x69c <__umulhisi3>
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
458: 96 95 lsr r25
|
|
45a: 87 95 ror r24
|
|
45c: 80 5d subi r24, 0xD0 ; 208
|
|
UDR0 = c;
|
|
45e: e0 ec ldi r30, 0xC0 ; 192
|
|
Serial.print("\t"); // tab
|
|
Serial.printDec(pulses[i][0] * RESOLUTION / 10);
|
|
460: f0 e0 ldi r31, 0x00 ; 0
|
|
462: 90 81 ld r25, Z
|
|
464: 95 ff sbrs r25, 5
|
|
466: fd cf rjmp .-6 ; 0x462 <_Z7recievev+0x35a>
|
|
468: 80 93 c6 00 sts 0x00C6, r24
|
|
46c: 9a 01 movw r18, r20
|
|
46e: ad ec ldi r26, 0xCD ; 205
|
|
470: bc ec ldi r27, 0xCC ; 204
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
472: 0e 94 4e 03 call 0x69c ; 0x69c <__umulhisi3>
|
|
476: fc 01 movw r30, r24
|
|
478: f6 95 lsr r31
|
|
47a: e7 95 ror r30
|
|
47c: f6 95 lsr r31
|
|
47e: e7 95 ror r30
|
|
480: f6 95 lsr r31
|
|
482: e7 95 ror r30
|
|
484: 9f 01 movw r18, r30
|
|
486: 0e 94 4e 03 call 0x69c ; 0x69c <__umulhisi3>
|
|
48a: 96 95 lsr r25
|
|
48c: 87 95 ror r24
|
|
48e: 96 95 lsr r25
|
|
490: 87 95 ror r24
|
|
492: 96 95 lsr r25
|
|
494: 87 95 ror r24
|
|
496: 9c 01 movw r18, r24
|
|
uart_putchar(*text);
|
|
text++;
|
|
}
|
|
}
|
|
void printDec(uint16_t wert) {
|
|
print((wert/10000)+'0');
|
|
498: 22 0f add r18, r18
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
UDR0 = c;
|
|
49a: 33 1f adc r19, r19
|
|
text++;
|
|
}
|
|
}
|
|
void printDec(uint16_t wert) {
|
|
print((wert/10000)+'0');
|
|
print(((wert/1000)%10)+'0');
|
|
49c: 88 0f add r24, r24
|
|
49e: 99 1f adc r25, r25
|
|
4a0: 88 0f add r24, r24
|
|
4a2: 99 1f adc r25, r25
|
|
4a4: 88 0f add r24, r24
|
|
4a6: 99 1f adc r25, r25
|
|
4a8: 82 0f add r24, r18
|
|
4aa: 93 1f adc r25, r19
|
|
4ac: e8 1b sub r30, r24
|
|
4ae: f9 0b sbc r31, r25
|
|
4b0: 9e 2f mov r25, r30
|
|
4b2: 90 5d subi r25, 0xD0 ; 208
|
|
4b4: e0 ec ldi r30, 0xC0 ; 192
|
|
4b6: f0 e0 ldi r31, 0x00 ; 0
|
|
4b8: 80 81 ld r24, Z
|
|
4ba: 85 ff sbrs r24, 5
|
|
4bc: fd cf rjmp .-6 ; 0x4b8 <_Z7recievev+0x3b0>
|
|
4be: 90 93 c6 00 sts 0x00C6, r25
|
|
4c2: 9a 01 movw r18, r20
|
|
4c4: ad ec ldi r26, 0xCD ; 205
|
|
4c6: bc ec ldi r27, 0xCC ; 204
|
|
4c8: 0e 94 4e 03 call 0x69c ; 0x69c <__umulhisi3>
|
|
4cc: 96 95 lsr r25
|
|
4ce: 87 95 ror r24
|
|
4d0: 96 95 lsr r25
|
|
4d2: 87 95 ror r24
|
|
4d4: 96 95 lsr r25
|
|
4d6: 87 95 ror r24
|
|
4d8: 9c 01 movw r18, r24
|
|
4da: 22 0f add r18, r18
|
|
4dc: 33 1f adc r19, r19
|
|
4de: 88 0f add r24, r24
|
|
4e0: 99 1f adc r25, r25
|
|
4e2: 88 0f add r24, r24
|
|
4e4: 99 1f adc r25, r25
|
|
4e6: 88 0f add r24, r24
|
|
4e8: 99 1f adc r25, r25
|
|
4ea: 82 0f add r24, r18
|
|
4ec: 93 1f adc r25, r19
|
|
4ee: 48 1b sub r20, r24
|
|
4f0: 59 0b sbc r21, r25
|
|
4f2: 40 5d subi r20, 0xD0 ; 208
|
|
4f4: e0 ec ldi r30, 0xC0 ; 192
|
|
4f6: f0 e0 ldi r31, 0x00 ; 0
|
|
4f8: 80 81 ld r24, Z
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
4fa: 85 ff sbrs r24, 5
|
|
4fc: fd cf rjmp .-6 ; 0x4f8 <_Z7recievev+0x3f0>
|
|
4fe: 40 93 c6 00 sts 0x00C6, r20
|
|
}
|
|
}
|
|
void printDec(uint16_t wert) {
|
|
print((wert/10000)+'0');
|
|
print(((wert/1000)%10)+'0');
|
|
print(((wert/100)%10)+'0');
|
|
502: af e6 ldi r26, 0x6F ; 111
|
|
504: b1 e0 ldi r27, 0x01 ; 1
|
|
506: 90 e2 ldi r25, 0x20 ; 32
|
|
508: e0 ec ldi r30, 0xC0 ; 192
|
|
50a: f0 e0 ldi r31, 0x00 ; 0
|
|
50c: c6 ec ldi r28, 0xC6 ; 198
|
|
50e: d0 e0 ldi r29, 0x00 ; 0
|
|
510: 80 81 ld r24, Z
|
|
512: 85 ff sbrs r24, 5
|
|
514: fd cf rjmp .-6 ; 0x510 <__stack+0x11>
|
|
516: 98 83 st Y, r25
|
|
518: 9d 91 ld r25, X+
|
|
51a: 91 11 cpse r25, r1
|
|
51c: f9 cf rjmp .-14 ; 0x510 <__stack+0x11>
|
|
51e: e0 ec ldi r30, 0xC0 ; 192
|
|
520: f0 e0 ldi r31, 0x00 ; 0
|
|
522: 80 81 ld r24, Z
|
|
524: 85 ff sbrs r24, 5
|
|
526: fd cf rjmp .-6 ; 0x522 <__stack+0x23>
|
|
528: 8d e0 ldi r24, 0x0D ; 13
|
|
52a: 80 93 c6 00 sts 0x00C6, r24
|
|
52e: e0 ec ldi r30, 0xC0 ; 192
|
|
530: f0 e0 ldi r31, 0x00 ; 0
|
|
532: 80 81 ld r24, Z
|
|
534: 85 ff sbrs r24, 5
|
|
536: fd cf rjmp .-6 ; 0x532 <__stack+0x33>
|
|
538: 8a e0 ldi r24, 0x0A ; 10
|
|
53a: 80 93 c6 00 sts 0x00C6, r24
|
|
53e: df 91 pop r29
|
|
540: cf 91 pop r28
|
|
542: 1f 91 pop r17
|
|
544: 08 95 ret
|
|
|
|
00000546 <main>:
|
|
546: 78 94 sei
|
|
548: 82 e3 ldi r24, 0x32 ; 50
|
|
54a: 90 e0 ldi r25, 0x00 ; 0
|
|
54c: 26 e7 ldi r18, 0x76 ; 118
|
|
54e: 31 e0 ldi r19, 0x01 ; 1
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
550: e0 ec ldi r30, 0xC0 ; 192
|
|
552: f0 e0 ldi r31, 0x00 ; 0
|
|
554: a6 ec ldi r26, 0xC6 ; 198
|
|
UDR0 = c;
|
|
556: b0 e0 ldi r27, 0x00 ; 0
|
|
}
|
|
void printDec(uint16_t wert) {
|
|
print((wert/10000)+'0');
|
|
print(((wert/1000)%10)+'0');
|
|
print(((wert/100)%10)+'0');
|
|
print(((wert/10)%10)+'0');
|
|
558: 7d e0 ldi r23, 0x0D ; 13
|
|
55a: 6a e0 ldi r22, 0x0A ; 10
|
|
55c: 11 c0 rjmp .+34 ; 0x580 <main+0x3a>
|
|
55e: 40 81 ld r20, Z
|
|
560: 45 ff sbrs r20, 5
|
|
562: fd cf rjmp .-6 ; 0x55e <main+0x18>
|
|
564: 5c 93 st X, r21
|
|
566: 59 91 ld r21, Y+
|
|
568: 51 11 cpse r21, r1
|
|
56a: f9 cf rjmp .-14 ; 0x55e <main+0x18>
|
|
56c: 40 81 ld r20, Z
|
|
56e: 45 ff sbrs r20, 5
|
|
570: fd cf rjmp .-6 ; 0x56c <main+0x26>
|
|
572: 7c 93 st X, r23
|
|
574: 40 81 ld r20, Z
|
|
576: 45 ff sbrs r20, 5
|
|
578: fd cf rjmp .-6 ; 0x574 <main+0x2e>
|
|
57a: 6c 93 st X, r22
|
|
57c: 01 97 sbiw r24, 0x01 ; 1
|
|
57e: 19 f0 breq .+6 ; 0x586 <main+0x40>
|
|
580: e9 01 movw r28, r18
|
|
582: 57 e4 ldi r21, 0x47 ; 71
|
|
584: ec cf rjmp .-40 ; 0x55e <main+0x18>
|
|
586: 29 9a sbi 0x05, 1 ; 5
|
|
588: c0 ec ldi r28, 0xC0 ; 192
|
|
58a: d0 e0 ldi r29, 0x00 ; 0
|
|
58c: 06 ec ldi r16, 0xC6 ; 198
|
|
58e: 10 e0 ldi r17, 0x00 ; 0
|
|
590: 0f 2e mov r0, r31
|
|
592: fe e2 ldi r31, 0x2E ; 46
|
|
594: df 2e mov r13, r31
|
|
596: f0 2d mov r31, r0
|
|
598: 0f 2e mov r0, r31
|
|
59a: fd e0 ldi r31, 0x0D ; 13
|
|
59c: ef 2e mov r14, r31
|
|
59e: f0 2d mov r31, r0
|
|
5a0: 0f 2e mov r0, r31
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
5a2: fa e0 ldi r31, 0x0A ; 10
|
|
5a4: ff 2e mov r15, r31
|
|
5a6: f0 2d mov r31, r0
|
|
UDR0 = c;
|
|
5a8: 4a 99 sbic 0x09, 2 ; 9
|
|
void printDec(uint16_t wert) {
|
|
print((wert/10000)+'0');
|
|
print(((wert/1000)%10)+'0');
|
|
print(((wert/100)%10)+'0');
|
|
print(((wert/10)%10)+'0');
|
|
print((wert%10)+'0');
|
|
5aa: fe cf rjmp .-4 ; 0x5a8 <main+0x62>
|
|
5ac: 0e 94 84 00 call 0x108 ; 0x108 <_Z7recievev>
|
|
5b0: 88 81 ld r24, Y
|
|
5b2: 85 ff sbrs r24, 5
|
|
5b4: fd cf rjmp .-6 ; 0x5b0 <main+0x6a>
|
|
5b6: f8 01 movw r30, r16
|
|
5b8: d0 82 st Z, r13
|
|
5ba: 88 81 ld r24, Y
|
|
5bc: 85 ff sbrs r24, 5
|
|
5be: fd cf rjmp .-6 ; 0x5ba <main+0x74>
|
|
5c0: f8 01 movw r30, r16
|
|
5c2: e0 82 st Z, r14
|
|
5c4: 88 81 ld r24, Y
|
|
5c6: 85 ff sbrs r24, 5
|
|
5c8: fd cf rjmp .-6 ; 0x5c4 <main+0x7e>
|
|
5ca: f8 01 movw r30, r16
|
|
5cc: f0 82 st Z, r15
|
|
5ce: ff ef ldi r31, 0xFF ; 255
|
|
5d0: 24 e3 ldi r18, 0x34 ; 52
|
|
5d2: 8c e0 ldi r24, 0x0C ; 12
|
|
5d4: f1 50 subi r31, 0x01 ; 1
|
|
5d6: 20 40 sbci r18, 0x00 ; 0
|
|
5d8: 80 40 sbci r24, 0x00 ; 0
|
|
5da: e1 f7 brne .-8 ; 0x5d4 <main+0x8e>
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
5dc: 00 c0 rjmp .+0 ; 0x5de <main+0x98>
|
|
5de: 00 00 nop
|
|
5e0: 28 98 cbi 0x05, 0 ; 5
|
|
UDR0 = c;
|
|
5e2: e2 cf rjmp .-60 ; 0x5a8 <main+0x62>
|
|
|
|
000005e4 <_ZN4UartILm9600EEC1Ev>:
|
|
5e4: cf 93 push r28
|
|
sei();
|
|
init();
|
|
println("Uart done!");
|
|
}
|
|
void print(const char *text) {
|
|
while (*text)
|
|
5e6: df 93 push r29
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
5e8: 78 94 sei
|
|
5ea: 81 e8 ldi r24, 0x81 ; 129
|
|
5ec: 80 93 c4 00 sts 0x00C4, r24
|
|
sei();
|
|
init();
|
|
println("Uart done!");
|
|
}
|
|
void print(const char *text) {
|
|
while (*text)
|
|
5f0: 10 92 c0 00 sts 0x00C0, r1
|
|
5f4: 88 e0 ldi r24, 0x08 ; 8
|
|
Serial.print(", ");
|
|
Serial.printDec(pulses[i][1] * RESOLUTION / 10);
|
|
5f6: 80 93 c1 00 sts 0x00C1, r24
|
|
5fa: 86 e0 ldi r24, 0x06 ; 6
|
|
5fc: 80 93 c2 00 sts 0x00C2, r24
|
|
600: af e7 ldi r26, 0x7F ; 127
|
|
602: b1 e0 ldi r27, 0x01 ; 1
|
|
604: 95 e5 ldi r25, 0x55 ; 85
|
|
606: e0 ec ldi r30, 0xC0 ; 192
|
|
608: f0 e0 ldi r31, 0x00 ; 0
|
|
60a: c6 ec ldi r28, 0xC6 ; 198
|
|
60c: d0 e0 ldi r29, 0x00 ; 0
|
|
60e: 80 81 ld r24, Z
|
|
610: 85 ff sbrs r24, 5
|
|
612: fd cf rjmp .-6 ; 0x60e <_ZN4UartILm9600EEC1Ev+0x2a>
|
|
614: 98 83 st Y, r25
|
|
616: 9d 91 ld r25, X+
|
|
618: 91 11 cpse r25, r1
|
|
61a: f9 cf rjmp .-14 ; 0x60e <_ZN4UartILm9600EEC1Ev+0x2a>
|
|
61c: e0 ec ldi r30, 0xC0 ; 192
|
|
61e: f0 e0 ldi r31, 0x00 ; 0
|
|
620: 80 81 ld r24, Z
|
|
622: 85 ff sbrs r24, 5
|
|
624: fd cf rjmp .-6 ; 0x620 <_ZN4UartILm9600EEC1Ev+0x3c>
|
|
626: 8d e0 ldi r24, 0x0D ; 13
|
|
628: 80 93 c6 00 sts 0x00C6, r24
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
62c: e0 ec ldi r30, 0xC0 ; 192
|
|
62e: f0 e0 ldi r31, 0x00 ; 0
|
|
630: 80 81 ld r24, Z
|
|
UDR0 = c;
|
|
632: 85 ff sbrs r24, 5
|
|
634: fd cf rjmp .-6 ; 0x630 <_ZN4UartILm9600EEC1Ev+0x4c>
|
|
text++;
|
|
}
|
|
}
|
|
void printDec(uint16_t wert) {
|
|
print((wert/10000)+'0');
|
|
print(((wert/1000)%10)+'0');
|
|
636: 8a e0 ldi r24, 0x0A ; 10
|
|
638: 80 93 c6 00 sts 0x00C6, r24
|
|
63c: df 91 pop r29
|
|
63e: cf 91 pop r28
|
|
640: 08 95 ret
|
|
|
|
00000642 <_GLOBAL__sub_I_Serial>:
|
|
642: 8e e1 ldi r24, 0x1E ; 30
|
|
644: 93 e0 ldi r25, 0x03 ; 3
|
|
646: 0e 94 f2 02 call 0x5e4 ; 0x5e4 <_ZN4UartILm9600EEC1Ev>
|
|
64a: 55 9a sbi 0x0a, 5 ; 10
|
|
64c: 53 9a sbi 0x0a, 3 ; 10
|
|
64e: 23 9a sbi 0x04, 3 ; 4
|
|
650: 81 e2 ldi r24, 0x21 ; 33
|
|
652: 84 bd out 0x24, r24 ; 36
|
|
654: 81 e0 ldi r24, 0x01 ; 1
|
|
656: 85 bd out 0x25, r24 ; 37
|
|
658: 16 bc out 0x26, r1 ; 38
|
|
65a: 10 92 b6 00 sts 0x00B6, r1
|
|
65e: 91 ea ldi r25, 0xA1 ; 161
|
|
660: 90 93 b0 00 sts 0x00B0, r25
|
|
664: 80 93 b1 00 sts 0x00B1, r24
|
|
668: 10 92 b2 00 sts 0x00B2, r1
|
|
66c: 10 92 6e 00 sts 0x006E, r1
|
|
670: 10 92 70 00 sts 0x0070, r1
|
|
674: 18 bc out 0x28, r1 ; 40
|
|
676: 10 92 b4 00 sts 0x00B4, r1
|
|
67a: 10 92 b3 00 sts 0x00B3, r1
|
|
67e: 20 9a sbi 0x04, 0 ; 4
|
|
680: 21 9a sbi 0x04, 1 ; 4
|
|
682: 28 98 cbi 0x05, 0 ; 5
|
|
684: 29 98 cbi 0x05, 1 ; 5
|
|
686: 56 98 cbi 0x0a, 6 ; 10
|
|
688: 5e 98 cbi 0x0b, 6 ; 11
|
|
68a: 57 98 cbi 0x0a, 7 ; 10
|
|
UCSR0A= (0<<RXC0) | (0<<TXC0) | (0<<UDRE0) | (0<<FE0) | (0<<DOR0) | (0<<UPE0) | (0<<U2X0) | (0<<MPCM0);
|
|
UCSR0B= (0<<RXCIE0) | (0<<TXCIE0) | (0<<UDRIE0) | (0<<RXEN0) | (1<<TXEN0) | (0<<UCSZ02) | (0<<RXB80) | (0<<TXB80); //Enable TXEN im Register UCR TX-Data Enable
|
|
UCSR0C= (0<<UMSEL01) | (0<<UMSEL00) | (0<<UPM01) | (0<<UPM00) | (0<<USBS0) | (1<<UCSZ01) | (1<<UCSZ00) | (0<<UCPOL0); //8N1
|
|
}
|
|
uint8_t uart_putchar(uint8_t c) {
|
|
loop_until_bit_is_set(UCSR0A, UDRE0); //Ausgabe des Zeichens
|
|
68c: 5f 98 cbi 0x0b, 7 ; 11
|
|
68e: 10 be out 0x30, r1 ; 48
|
|
690: 10 92 7b 00 sts 0x007B, r1
|
|
}
|
|
}
|
|
void printDec(uint16_t wert) {
|
|
print((wert/10000)+'0');
|
|
print(((wert/1000)%10)+'0');
|
|
print(((wert/100)%10)+'0');
|
|
694: 83 e0 ldi r24, 0x03 ; 3
|
|
696: 80 93 7f 00 sts 0x007F, r24
|
|
69a: 08 95 ret
|
|
|
|
0000069c <__umulhisi3>:
|
|
69c: a2 9f mul r26, r18
|
|
69e: b0 01 movw r22, r0
|
|
6a0: b3 9f mul r27, r19
|
|
6a2: c0 01 movw r24, r0
|
|
6a4: a3 9f mul r26, r19
|
|
6a6: 01 d0 rcall .+2 ; 0x6aa <__umulhisi3+0xe>
|
|
6a8: b2 9f mul r27, r18
|
|
6aa: 70 0d add r23, r0
|
|
6ac: 81 1d adc r24, r1
|
|
6ae: 11 24 eor r1, r1
|
|
6b0: 91 1d adc r25, r1
|
|
6b2: 08 95 ret
|
|
|
|
000006b4 <__tablejump2__>:
|
|
6b4: ee 0f add r30, r30
|
|
6b6: ff 1f adc r31, r31
|
|
|
|
000006b8 <__tablejump__>:
|
|
6b8: 05 90 lpm r0, Z+
|
|
6ba: f4 91 lpm r31, Z
|
|
6bc: e0 2d mov r30, r0
|
|
6be: 09 94 ijmp
|
|
|
|
000006c0 <_exit>:
|
|
6c0: f8 94 cli
|
|
|
|
000006c2 <__stop_program>:
|
|
6c2: ff cf rjmp .-2 ; 0x6c2 <__stop_program>
|