Opdracht 2.2.elf: file format elf32-avr Sections: Idx Name Size VMA LMA File off Algn 0 .data 00000000 00800100 00800100 00000192 2**0 ALLOC, LOAD, DATA 1 .text 000000a4 00000000 00000000 00000054 2**1 CONTENTS, ALLOC, LOAD, READONLY, CODE 2 .comment 0000002f 00000000 00000000 00000192 2**0 CONTENTS, READONLY 3 .debug_aranges 00000038 00000000 00000000 000001c1 2**0 CONTENTS, READONLY, DEBUGGING 4 .debug_info 00000b2a 00000000 00000000 000001f9 2**0 CONTENTS, READONLY, DEBUGGING 5 .debug_abbrev 00000830 00000000 00000000 00000d23 2**0 CONTENTS, READONLY, DEBUGGING 6 .debug_line 000002e4 00000000 00000000 00001553 2**0 CONTENTS, READONLY, DEBUGGING 7 .debug_frame 00000074 00000000 00000000 00001838 2**2 CONTENTS, READONLY, DEBUGGING 8 .debug_str 0000027d 00000000 00000000 000018ac 2**0 CONTENTS, READONLY, DEBUGGING 9 .debug_loc 000000e2 00000000 00000000 00001b29 2**0 CONTENTS, READONLY, DEBUGGING 10 .debug_ranges 00000028 00000000 00000000 00001c0b 2**0 CONTENTS, READONLY, DEBUGGING 11 .text 00000004 0000013a 0000013a 0000018e 2**1 CONTENTS, ALLOC, LOAD, READONLY, CODE 12 .note.gnu.avr.deviceinfo 0000003c 00000000 00000000 00001c34 2**2 CONTENTS, READONLY, DEBUGGING 13 .text.wait 0000001e 0000011c 0000011c 00000170 2**1 CONTENTS, ALLOC, LOAD, READONLY, CODE 14 .text.__vector_2 00000028 000000a4 000000a4 000000f8 2**1 CONTENTS, ALLOC, LOAD, READONLY, CODE 15 .text.__vector_3 00000028 000000cc 000000cc 00000120 2**1 CONTENTS, ALLOC, LOAD, READONLY, CODE 16 .text.main 00000028 000000f4 000000f4 00000148 2**1 CONTENTS, ALLOC, LOAD, READONLY, CODE Disassembly of section .text: 00000000 <__vectors>: 0: 0c 94 46 00 jmp 0x8c ; 0x8c <__ctors_end> 4: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 8: 0c 94 52 00 jmp 0xa4 ; 0xa4 <_etext> c: 0c 94 66 00 jmp 0xcc ; 0xcc <__vector_3> 10: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 14: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 18: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 1c: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 20: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 24: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 28: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 2c: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 30: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 34: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 38: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 3c: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 40: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 44: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 48: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 4c: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 50: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 54: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 58: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 5c: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 60: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 64: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 68: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 6c: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 70: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 74: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 78: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 7c: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 80: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 84: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 88: 0c 94 9d 00 jmp 0x13a ; 0x13a <__bad_interrupt> 0000008c <__ctors_end>: 8c: 11 24 eor r1, r1 8e: 1f be out 0x3f, r1 ; 63 90: cf ef ldi r28, 0xFF ; 255 92: d0 e1 ldi r29, 0x10 ; 16 94: de bf out 0x3e, r29 ; 62 96: cd bf out 0x3d, r28 ; 61 98: 0e 94 7a 00 call 0xf4 ; 0xf4
9c: 0c 94 50 00 jmp 0xa0 ; 0xa0 <_exit> 000000a0 <_exit>: a0: f8 94 cli 000000a2 <__stop_program>: a2: ff cf rjmp .-2 ; 0xa2 <__stop_program> Disassembly of section .text: 0000013a <__bad_interrupt>: 13a: 0c 94 00 00 jmp 0 ; 0x0 <__TEXT_REGION_ORIGIN__> Disassembly of section .text.wait: 0000011c : #include #include #include void wait( int ms ) { for (int i=0; i #else //round up by default __ticks_dc = (uint32_t)(ceil(fabs(__tmp))); #endif __builtin_avr_delay_cycles(__ticks_dc); 122: e3 ec ldi r30, 0xC3 ; 195 124: f9 e0 ldi r31, 0x09 ; 9 126: 31 97 sbiw r30, 0x01 ; 1 128: f1 f7 brne .-4 ; 0x126 12a: 00 c0 rjmp .+0 ; 0x12c 12c: 00 00 nop 12e: 2f 5f subi r18, 0xFF ; 255 130: 3f 4f sbci r19, 0xFF ; 255 132: 28 17 cp r18, r24 134: 39 07 cpc r19, r25 136: ac f3 brlt .-22 ; 0x122 _delay_ms( 1 ); // library function (max 30 ms at 8MHz) } } 138: 08 95 ret Disassembly of section .text.__vector_2: 000000a4 <__vector_2>: ISR( INT1_vect ) { a4: 1f 92 push r1 a6: 0f 92 push r0 a8: 0f b6 in r0, 0x3f ; 63 aa: 0f 92 push r0 ac: 11 24 eor r1, r1 ae: 8f 93 push r24 if (PORTC == 0b10000000) b0: 85 b3 in r24, 0x15 ; 21 b2: 80 38 cpi r24, 0x80 ; 128 b4: 11 f4 brne .+4 ; 0xba <__vector_2+0x16> { PORTC == 0b00000001; b6: 85 b3 in r24, 0x15 ; 21 b8: 03 c0 rjmp .+6 ; 0xc0 <__vector_2+0x1c> } else { PORTC = PORTC << 1; ba: 85 b3 in r24, 0x15 ; 21 bc: 88 0f add r24, r24 be: 85 bb out 0x15, r24 ; 21 } } c0: 8f 91 pop r24 c2: 0f 90 pop r0 c4: 0f be out 0x3f, r0 ; 63 c6: 0f 90 pop r0 c8: 1f 90 pop r1 ca: 18 95 reti Disassembly of section .text.__vector_3: 000000cc <__vector_3>: ISR( INT2_vect ) { cc: 1f 92 push r1 ce: 0f 92 push r0 d0: 0f b6 in r0, 0x3f ; 63 d2: 0f 92 push r0 d4: 11 24 eor r1, r1 d6: 8f 93 push r24 if (PORTC == 0b00000001) d8: 85 b3 in r24, 0x15 ; 21 da: 81 30 cpi r24, 0x01 ; 1 dc: 11 f4 brne .+4 ; 0xe2 <__vector_3+0x16> { PORTC = 0b10000000; de: 80 e8 ldi r24, 0x80 ; 128 e0: 85 bb out 0x15, r24 ; 21 } PORTC = PORTC >> 1; e2: 85 b3 in r24, 0x15 ; 21 e4: 86 95 lsr r24 e6: 85 bb out 0x15, r24 ; 21 } e8: 8f 91 pop r24 ea: 0f 90 pop r0 ec: 0f be out 0x3f, r0 ; 63 ee: 0f 90 pop r0 f0: 1f 90 pop r1 f2: 18 95 reti Disassembly of section .text.main: 000000f4
: int main(void) { /* Replace with your application code */ // Init I/O DDRD = 0xF0; // PORTD (7:4) is output, (3:0) is input f4: 80 ef ldi r24, 0xF0 ; 240 f6: 81 bb out 0x11, r24 ; 17 DDRC = 0xFF; f8: 8f ef ldi r24, 0xFF ; 255 fa: 84 bb out 0x14, r24 ; 20 // Init Interrupt hardware EICRA |= 0x2C; // INT2 falling edge, INT1 rising edge fc: ea e6 ldi r30, 0x6A ; 106 fe: f0 e0 ldi r31, 0x00 ; 0 100: 80 81 ld r24, Z 102: 8c 62 ori r24, 0x2C ; 44 104: 80 83 st Z, r24 EIMSK |= 0x06; // Enable INT2 & INT1 106: 89 b7 in r24, 0x39 ; 57 108: 86 60 ori r24, 0x06 ; 6 10a: 89 bf out 0x39, r24 ; 57 PORTC = 0x01; 10c: 81 e0 ldi r24, 0x01 ; 1 10e: 85 bb out 0x15, r24 ; 21 sei(); 110: 78 94 sei while (1) { wait(500); 112: 84 ef ldi r24, 0xF4 ; 244 114: 91 e0 ldi r25, 0x01 ; 1 116: 0e 94 8e 00 call 0x11c ; 0x11c 11a: fb cf rjmp .-10 ; 0x112