diff --git a/Microcontrollers/Microcontrollers.atsln b/Microcontrollers/Microcontrollers.atsln
index 2d3ad28..2bfd4d1 100644
--- a/Microcontrollers/Microcontrollers.atsln
+++ b/Microcontrollers/Microcontrollers.atsln
@@ -17,11 +17,17 @@ Project("{54F91283-7BC4-4236-8FF9-10F437C3AD48}") = "opdracht 2.1", "opdracht 2.
EndProject
Project("{54F91283-7BC4-4236-8FF9-10F437C3AD48}") = "Opdracht 2.2", "Opdracht 2.2\Opdracht 2.2.cproj", "{7328E66F-4181-4553-9542-DA5CC2A74A4E}"
EndProject
-Project("{54F91283-7BC4-4236-8FF9-10F437C3AD48}") = "opdracht 2.3", "opdracht 2.3\opdracht 2.3.cproj", "{E0046CE4-D6F8-435F-9C6E-72E6EB89CCB3}"
+Project("{54F91283-7BC4-4236-8FF9-10F437C3AD48}") = "opdracht 2.3", "opdracht 2.3\opdracht 2.3.cproj", "{9154C165-89AB-43CF-8C28-23147BC26FDC}"
EndProject
Project("{54F91283-7BC4-4236-8FF9-10F437C3AD48}") = "opdracht 2.5", "opdracht 2.5\opdracht 2.5.cproj", "{C81B68AA-F4BB-4A5D-81F8-2737DCD1D4A7}"
EndProject
+<<<<<<< HEAD
Project("{54F91283-7BC4-4236-8FF9-10F437C3AD48}") = "testlcd", "testlcd\testlcd.cproj", "{B964892D-A92F-44D4-AF99-3ADC61820917}"
+=======
+Project("{54F91283-7BC4-4236-8FF9-10F437C3AD48}") = "opdracht 2.4", "opdracht 2.4\opdracht 2.4.cproj", "{0FA0C637-5AC0-44F3-999B-49C114B97183}"
+EndProject
+Project("{54F91283-7BC4-4236-8FF9-10F437C3AD48}") = "opdracht 3.3", "opdracht 3.3\opdracht 3.3.cproj", "{985D5C75-F61E-49F1-A532-66A1E6141552}"
+>>>>>>> 12029c15d35456f0080287d83bbdee63f625a09b
EndProject
Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution
@@ -57,18 +63,29 @@ Global
{7328E66F-4181-4553-9542-DA5CC2A74A4E}.Debug|AVR.Build.0 = Debug|AVR
{7328E66F-4181-4553-9542-DA5CC2A74A4E}.Release|AVR.ActiveCfg = Release|AVR
{7328E66F-4181-4553-9542-DA5CC2A74A4E}.Release|AVR.Build.0 = Release|AVR
- {E0046CE4-D6F8-435F-9C6E-72E6EB89CCB3}.Debug|AVR.ActiveCfg = Debug|AVR
- {E0046CE4-D6F8-435F-9C6E-72E6EB89CCB3}.Debug|AVR.Build.0 = Debug|AVR
- {E0046CE4-D6F8-435F-9C6E-72E6EB89CCB3}.Release|AVR.ActiveCfg = Release|AVR
- {E0046CE4-D6F8-435F-9C6E-72E6EB89CCB3}.Release|AVR.Build.0 = Release|AVR
+ {9154C165-89AB-43CF-8C28-23147BC26FDC}.Debug|AVR.ActiveCfg = Debug|AVR
+ {9154C165-89AB-43CF-8C28-23147BC26FDC}.Debug|AVR.Build.0 = Debug|AVR
+ {9154C165-89AB-43CF-8C28-23147BC26FDC}.Release|AVR.ActiveCfg = Release|AVR
+ {9154C165-89AB-43CF-8C28-23147BC26FDC}.Release|AVR.Build.0 = Release|AVR
{C81B68AA-F4BB-4A5D-81F8-2737DCD1D4A7}.Debug|AVR.ActiveCfg = Debug|AVR
{C81B68AA-F4BB-4A5D-81F8-2737DCD1D4A7}.Debug|AVR.Build.0 = Debug|AVR
{C81B68AA-F4BB-4A5D-81F8-2737DCD1D4A7}.Release|AVR.ActiveCfg = Release|AVR
{C81B68AA-F4BB-4A5D-81F8-2737DCD1D4A7}.Release|AVR.Build.0 = Release|AVR
+<<<<<<< HEAD
{B964892D-A92F-44D4-AF99-3ADC61820917}.Debug|AVR.ActiveCfg = Debug|AVR
{B964892D-A92F-44D4-AF99-3ADC61820917}.Debug|AVR.Build.0 = Debug|AVR
{B964892D-A92F-44D4-AF99-3ADC61820917}.Release|AVR.ActiveCfg = Release|AVR
{B964892D-A92F-44D4-AF99-3ADC61820917}.Release|AVR.Build.0 = Release|AVR
+=======
+ {0FA0C637-5AC0-44F3-999B-49C114B97183}.Debug|AVR.ActiveCfg = Debug|AVR
+ {0FA0C637-5AC0-44F3-999B-49C114B97183}.Debug|AVR.Build.0 = Debug|AVR
+ {0FA0C637-5AC0-44F3-999B-49C114B97183}.Release|AVR.ActiveCfg = Release|AVR
+ {0FA0C637-5AC0-44F3-999B-49C114B97183}.Release|AVR.Build.0 = Release|AVR
+ {985D5C75-F61E-49F1-A532-66A1E6141552}.Debug|AVR.ActiveCfg = Debug|AVR
+ {985D5C75-F61E-49F1-A532-66A1E6141552}.Debug|AVR.Build.0 = Debug|AVR
+ {985D5C75-F61E-49F1-A532-66A1E6141552}.Release|AVR.ActiveCfg = Release|AVR
+ {985D5C75-F61E-49F1-A532-66A1E6141552}.Release|AVR.Build.0 = Release|AVR
+>>>>>>> 12029c15d35456f0080287d83bbdee63f625a09b
EndGlobalSection
GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE
diff --git a/Microcontrollers/opdracht 2.3/opdracht 2.3.cproj b/Microcontrollers/opdracht 2.3/opdracht 2.3.cproj
index 93b2609..b3965e7 100644
--- a/Microcontrollers/opdracht 2.3/opdracht 2.3.cproj
+++ b/Microcontrollers/opdracht 2.3/opdracht 2.3.cproj
@@ -4,7 +4,7 @@
2.0
7.0
com.microchip.xc8
- {e0046ce4-d6f8-435f-9c6e-72e6eb89ccb3}
+ {9154c165-89ab-43cf-8c28-23147bc26fdc}
ATmega128
none
Executable
diff --git a/Microcontrollers/opdracht 3.3/Debug/Makefile b/Microcontrollers/opdracht 3.3/Debug/Makefile
new file mode 100644
index 0000000..8acc317
--- /dev/null
+++ b/Microcontrollers/opdracht 3.3/Debug/Makefile
@@ -0,0 +1,127 @@
+################################################################################
+# Automatically-generated file. Do not edit!
+################################################################################
+
+SHELL := cmd.exe
+RM := rm -rf
+
+USER_OBJS :=
+
+LIBS :=
+PROJ :=
+
+O_SRCS :=
+C_SRCS :=
+S_SRCS :=
+S_UPPER_SRCS :=
+OBJ_SRCS :=
+ASM_SRCS :=
+PREPROCESSING_SRCS :=
+OBJS :=
+OBJS_AS_ARGS :=
+C_DEPS :=
+C_DEPS_AS_ARGS :=
+EXECUTABLES :=
+OUTPUT_FILE_PATH :=
+OUTPUT_FILE_PATH_AS_ARGS :=
+AVR_APP_PATH :=$$$AVR_APP_PATH$$$
+QUOTE := "
+ADDITIONAL_DEPENDENCIES:=
+OUTPUT_FILE_DEP:=
+LIB_DEP:=
+LINKER_SCRIPT_DEP:=
+
+# Every subdirectory with source files must be described here
+SUBDIRS :=
+
+
+# Add inputs and outputs from these tool invocations to the build variables
+C_SRCS += \
+../main.c
+
+
+PREPROCESSING_SRCS +=
+
+
+ASM_SRCS +=
+
+
+OBJS += \
+main.o
+
+OBJS_AS_ARGS += \
+main.o
+
+C_DEPS += \
+main.d
+
+C_DEPS_AS_ARGS += \
+main.d
+
+OUTPUT_FILE_PATH +=opdracht\ 3.3.elf
+
+OUTPUT_FILE_PATH_AS_ARGS +="opdracht 3.3.elf"
+
+ADDITIONAL_DEPENDENCIES:=
+
+OUTPUT_FILE_DEP:= ./makedep.mk
+
+LIB_DEP+=
+
+LINKER_SCRIPT_DEP+=
+
+
+# AVR32/GNU C Compiler
+./main.o: .././main.c
+ @echo Building file: $<
+ @echo Invoking: AVR/GNU C Compiler : 5.4.0
+ $(QUOTE)C:\Program Files (x86)\Atmel\Studio\7.0\toolchain\avr8\avr8-gnu-toolchain\bin\avr-gcc.exe$(QUOTE) -x c -funsigned-char -funsigned-bitfields -DDEBUG -I"C:\Program Files (x86)\Atmel\Studio\7.0\Packs\atmel\ATmega_DFP\1.6.364\include" -Og -ffunction-sections -fdata-sections -fpack-struct -fshort-enums -mrelax -g2 -Wall -mmcu=atmega128 -B "C:\Program Files (x86)\Atmel\Studio\7.0\Packs\atmel\ATmega_DFP\1.6.364\gcc\dev\atmega128" -c -std=gnu99 -MD -MP -MF "$(@:%.o=%.d)" -MT"$(@:%.o=%.d)" -MT"$(@:%.o=%.o)" -o "$@" "$<"
+ @echo Finished building: $<
+
+
+
+
+
+# AVR32/GNU Preprocessing Assembler
+
+
+
+# AVR32/GNU Assembler
+
+
+
+
+ifneq ($(MAKECMDGOALS),clean)
+ifneq ($(strip $(C_DEPS)),)
+-include $(C_DEPS)
+endif
+endif
+
+# Add inputs and outputs from these tool invocations to the build variables
+
+# All Target
+all: $(OUTPUT_FILE_PATH) $(ADDITIONAL_DEPENDENCIES)
+
+$(OUTPUT_FILE_PATH): $(OBJS) $(USER_OBJS) $(OUTPUT_FILE_DEP) $(LIB_DEP) $(LINKER_SCRIPT_DEP)
+ @echo Building target: $@
+ @echo Invoking: AVR/GNU Linker : 5.4.0
+ $(QUOTE)C:\Program Files (x86)\Atmel\Studio\7.0\toolchain\avr8\avr8-gnu-toolchain\bin\avr-gcc.exe$(QUOTE) -o$(OUTPUT_FILE_PATH_AS_ARGS) $(OBJS_AS_ARGS) $(USER_OBJS) $(LIBS) -Wl,-Map="opdracht 3.3.map" -Wl,--start-group -Wl,-lm -Wl,--end-group -Wl,--gc-sections -mrelax -mmcu=atmega128 -B "C:\Program Files (x86)\Atmel\Studio\7.0\Packs\atmel\ATmega_DFP\1.6.364\gcc\dev\atmega128"
+ @echo Finished building target: $@
+ "C:\Program Files (x86)\Atmel\Studio\7.0\toolchain\avr8\avr8-gnu-toolchain\bin\avr-objcopy.exe" -O ihex -R .eeprom -R .fuse -R .lock -R .signature -R .user_signatures "opdracht 3.3.elf" "opdracht 3.3.hex"
+ "C:\Program Files (x86)\Atmel\Studio\7.0\toolchain\avr8\avr8-gnu-toolchain\bin\avr-objcopy.exe" -j .eeprom --set-section-flags=.eeprom=alloc,load --change-section-lma .eeprom=0 --no-change-warnings -O ihex "opdracht 3.3.elf" "opdracht 3.3.eep" || exit 0
+ "C:\Program Files (x86)\Atmel\Studio\7.0\toolchain\avr8\avr8-gnu-toolchain\bin\avr-objdump.exe" -h -S "opdracht 3.3.elf" > "opdracht 3.3.lss"
+ "C:\Program Files (x86)\Atmel\Studio\7.0\toolchain\avr8\avr8-gnu-toolchain\bin\avr-objcopy.exe" -O srec -R .eeprom -R .fuse -R .lock -R .signature -R .user_signatures "opdracht 3.3.elf" "opdracht 3.3.srec"
+ "C:\Program Files (x86)\Atmel\Studio\7.0\toolchain\avr8\avr8-gnu-toolchain\bin\avr-size.exe" "opdracht 3.3.elf"
+
+
+
+
+
+
+
+# Other Targets
+clean:
+ -$(RM) $(OBJS_AS_ARGS) $(EXECUTABLES)
+ -$(RM) $(C_DEPS_AS_ARGS)
+ rm -rf "opdracht 3.3.elf" "opdracht 3.3.a" "opdracht 3.3.hex" "opdracht 3.3.lss" "opdracht 3.3.eep" "opdracht 3.3.map" "opdracht 3.3.srec" "opdracht 3.3.usersignatures"
+
\ No newline at end of file
diff --git a/Microcontrollers/opdracht 3.3/Debug/makedep.mk b/Microcontrollers/opdracht 3.3/Debug/makedep.mk
new file mode 100644
index 0000000..6a14fde
--- /dev/null
+++ b/Microcontrollers/opdracht 3.3/Debug/makedep.mk
@@ -0,0 +1,6 @@
+################################################################################
+# Automatically-generated file. Do not edit or delete the file
+################################################################################
+
+main.c
+
diff --git a/Microcontrollers/opdracht 3.3/Debug/opdracht 3.3.eep b/Microcontrollers/opdracht 3.3/Debug/opdracht 3.3.eep
new file mode 100644
index 0000000..7c166a1
--- /dev/null
+++ b/Microcontrollers/opdracht 3.3/Debug/opdracht 3.3.eep
@@ -0,0 +1 @@
+:00000001FF
diff --git a/Microcontrollers/opdracht 3.3/Debug/opdracht 3.3.lss b/Microcontrollers/opdracht 3.3/Debug/opdracht 3.3.lss
new file mode 100644
index 0000000..1ee8b02
--- /dev/null
+++ b/Microcontrollers/opdracht 3.3/Debug/opdracht 3.3.lss
@@ -0,0 +1,262 @@
+
+opdracht 3.3.elf: file format elf32-avr
+
+Sections:
+Idx Name Size VMA LMA File off Algn
+ 0 .data 00000000 00800100 00800100 00000196 2**0
+ CONTENTS, ALLOC, LOAD, DATA
+ 1 .text 00000142 00000000 00000000 00000054 2**1
+ CONTENTS, ALLOC, LOAD, READONLY, CODE
+ 2 .comment 00000030 00000000 00000000 00000196 2**0
+ CONTENTS, READONLY
+ 3 .note.gnu.avr.deviceinfo 0000003c 00000000 00000000 000001c8 2**2
+ CONTENTS, READONLY
+ 4 .debug_aranges 00000038 00000000 00000000 00000204 2**0
+ CONTENTS, READONLY, DEBUGGING
+ 5 .debug_info 00000944 00000000 00000000 0000023c 2**0
+ CONTENTS, READONLY, DEBUGGING
+ 6 .debug_abbrev 00000878 00000000 00000000 00000b80 2**0
+ CONTENTS, READONLY, DEBUGGING
+ 7 .debug_line 00000317 00000000 00000000 000013f8 2**0
+ CONTENTS, READONLY, DEBUGGING
+ 8 .debug_frame 00000068 00000000 00000000 00001710 2**2
+ CONTENTS, READONLY, DEBUGGING
+ 9 .debug_str 0000046a 00000000 00000000 00001778 2**0
+ CONTENTS, READONLY, DEBUGGING
+ 10 .debug_loc 000000b3 00000000 00000000 00001be2 2**0
+ CONTENTS, READONLY, DEBUGGING
+ 11 .debug_ranges 00000028 00000000 00000000 00001c95 2**0
+ CONTENTS, READONLY, DEBUGGING
+
+Disassembly of section .text:
+
+00000000 <__vectors>:
+ 0: 45 c0 rjmp .+138 ; 0x8c <__ctors_end>
+ 2: 00 00 nop
+ 4: 60 c0 rjmp .+192 ; 0xc6 <__bad_interrupt>
+ 6: 00 00 nop
+ 8: 5e c0 rjmp .+188 ; 0xc6 <__bad_interrupt>
+ a: 00 00 nop
+ c: 5c c0 rjmp .+184 ; 0xc6 <__bad_interrupt>
+ e: 00 00 nop
+ 10: 5a c0 rjmp .+180 ; 0xc6 <__bad_interrupt>
+ 12: 00 00 nop
+ 14: 58 c0 rjmp .+176 ; 0xc6 <__bad_interrupt>
+ 16: 00 00 nop
+ 18: 56 c0 rjmp .+172 ; 0xc6 <__bad_interrupt>
+ 1a: 00 00 nop
+ 1c: 54 c0 rjmp .+168 ; 0xc6 <__bad_interrupt>
+ 1e: 00 00 nop
+ 20: 52 c0 rjmp .+164 ; 0xc6 <__bad_interrupt>
+ 22: 00 00 nop
+ 24: 69 c0 rjmp .+210 ; 0xf8 <__vector_9>
+ 26: 00 00 nop
+ 28: 4e c0 rjmp .+156 ; 0xc6 <__bad_interrupt>
+ 2a: 00 00 nop
+ 2c: 4c c0 rjmp .+152 ; 0xc6 <__bad_interrupt>
+ 2e: 00 00 nop
+ 30: 4a c0 rjmp .+148 ; 0xc6 <__bad_interrupt>
+ 32: 00 00 nop
+ 34: 48 c0 rjmp .+144 ; 0xc6 <__bad_interrupt>
+ 36: 00 00 nop
+ 38: 46 c0 rjmp .+140 ; 0xc6 <__bad_interrupt>
+ 3a: 00 00 nop
+ 3c: 44 c0 rjmp .+136 ; 0xc6 <__bad_interrupt>
+ 3e: 00 00 nop
+ 40: 42 c0 rjmp .+132 ; 0xc6 <__bad_interrupt>
+ 42: 00 00 nop
+ 44: 40 c0 rjmp .+128 ; 0xc6 <__bad_interrupt>
+ 46: 00 00 nop
+ 48: 3e c0 rjmp .+124 ; 0xc6 <__bad_interrupt>
+ 4a: 00 00 nop
+ 4c: 3c c0 rjmp .+120 ; 0xc6 <__bad_interrupt>
+ 4e: 00 00 nop
+ 50: 3a c0 rjmp .+116 ; 0xc6 <__bad_interrupt>
+ 52: 00 00 nop
+ 54: 38 c0 rjmp .+112 ; 0xc6 <__bad_interrupt>
+ 56: 00 00 nop
+ 58: 36 c0 rjmp .+108 ; 0xc6 <__bad_interrupt>
+ 5a: 00 00 nop
+ 5c: 34 c0 rjmp .+104 ; 0xc6 <__bad_interrupt>
+ 5e: 00 00 nop
+ 60: 32 c0 rjmp .+100 ; 0xc6 <__bad_interrupt>
+ 62: 00 00 nop
+ 64: 30 c0 rjmp .+96 ; 0xc6 <__bad_interrupt>
+ 66: 00 00 nop
+ 68: 2e c0 rjmp .+92 ; 0xc6 <__bad_interrupt>
+ 6a: 00 00 nop
+ 6c: 2c c0 rjmp .+88 ; 0xc6 <__bad_interrupt>
+ 6e: 00 00 nop
+ 70: 2a c0 rjmp .+84 ; 0xc6 <__bad_interrupt>
+ 72: 00 00 nop
+ 74: 28 c0 rjmp .+80 ; 0xc6 <__bad_interrupt>
+ 76: 00 00 nop
+ 78: 26 c0 rjmp .+76 ; 0xc6 <__bad_interrupt>
+ 7a: 00 00 nop
+ 7c: 24 c0 rjmp .+72 ; 0xc6 <__bad_interrupt>
+ 7e: 00 00 nop
+ 80: 22 c0 rjmp .+68 ; 0xc6 <__bad_interrupt>
+ 82: 00 00 nop
+ 84: 20 c0 rjmp .+64 ; 0xc6 <__bad_interrupt>
+ 86: 00 00 nop
+ 88: 1e c0 rjmp .+60 ; 0xc6 <__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
+
+00000098 <__do_copy_data>:
+ 98: 11 e0 ldi r17, 0x01 ; 1
+ 9a: a0 e0 ldi r26, 0x00 ; 0
+ 9c: b1 e0 ldi r27, 0x01 ; 1
+ 9e: e2 e4 ldi r30, 0x42 ; 66
+ a0: f1 e0 ldi r31, 0x01 ; 1
+ a2: 00 e0 ldi r16, 0x00 ; 0
+ a4: 0b bf out 0x3b, r16 ; 59
+ a6: 02 c0 rjmp .+4 ; 0xac <__do_copy_data+0x14>
+ a8: 07 90 elpm r0, Z+
+ aa: 0d 92 st X+, r0
+ ac: a0 30 cpi r26, 0x00 ; 0
+ ae: b1 07 cpc r27, r17
+ b0: d9 f7 brne .-10 ; 0xa8 <__do_copy_data+0x10>
+
+000000b2 <__do_clear_bss>:
+ b2: 21 e0 ldi r18, 0x01 ; 1
+ b4: a0 e0 ldi r26, 0x00 ; 0
+ b6: b1 e0 ldi r27, 0x01 ; 1
+ b8: 01 c0 rjmp .+2 ; 0xbc <.do_clear_bss_start>
+
+000000ba <.do_clear_bss_loop>:
+ ba: 1d 92 st X+, r1
+
+000000bc <.do_clear_bss_start>:
+ bc: a0 30 cpi r26, 0x00 ; 0
+ be: b2 07 cpc r27, r18
+ c0: e1 f7 brne .-8 ; 0xba <.do_clear_bss_loop>
+ c2: 34 d0 rcall .+104 ; 0x12c
+ c4: 3c c0 rjmp .+120 ; 0x13e <_exit>
+
+000000c6 <__bad_interrupt>:
+ c6: 9c cf rjmp .-200 ; 0x0 <__vectors>
+
+000000c8 :
+#define BIT(x) (1 << (x))
+
+// wait(): busy waiting for 'ms' millisecond
+// Used library: util/delay.h
+void wait( int ms ) {
+ for (int tms=0; tms
+ #else
+ //round up by default
+ __ticks_dc = (uint32_t)(ceil(fabs(__tmp)));
+ #endif
+
+ __builtin_avr_delay_cycles(__ticks_dc);
+ ce: e3 ec ldi r30, 0xC3 ; 195
+ d0: f9 e0 ldi r31, 0x09 ; 9
+ d2: 31 97 sbiw r30, 0x01 ; 1
+ d4: f1 f7 brne .-4 ; 0xd2
+ d6: 00 c0 rjmp .+0 ; 0xd8
+ d8: 00 00 nop
+ da: 2f 5f subi r18, 0xFF ; 255
+ dc: 3f 4f sbci r19, 0xFF ; 255
+ de: 28 17 cp r18, r24
+ e0: 39 07 cpc r19, r25
+ e2: ac f3 brlt .-22 ; 0xce
+ _delay_ms( 1 ); // library function (max 30 ms at 8MHz)
+ }
+}
+ e4: 08 95 ret
+
+000000e6 :
+
+volatile int msCount = 0;
+
+void timer2Init( void ) {
+ OCR2 = 150; //155 // Compare value of counter 2
+ e6: 86 e9 ldi r24, 0x96 ; 150
+ e8: 83 bd out 0x23, r24 ; 35
+ TIMSK |= BIT(7); // T2 compare match interrupt enable
+ ea: 87 b7 in r24, 0x37 ; 55
+ ec: 80 68 ori r24, 0x80 ; 128
+ ee: 87 bf out 0x37, r24 ; 55
+ sei(); // turn_on intr all
+ f0: 78 94 sei
+ TCCR2 = 0b00001101; // Initialize T2: timer, prescaler=32, compare output disconnected,CTC,RUN
+ f2: 8d e0 ldi r24, 0x0D ; 13
+ f4: 85 bd out 0x25, r24 ; 37
+ f6: 08 95 ret
+
+000000f8 <__vector_9>:
+}
+unsigned int msThersh = 15;
+
+ISR( TIMER2_COMP_vect ) {
+ f8: 1f 92 push r1
+ fa: 0f 92 push r0
+ fc: 0f b6 in r0, 0x3f ; 63
+ fe: 0f 92 push r0
+ 100: 11 24 eor r1, r1
+ 102: 8f 93 push r24
+ 104: 9f 93 push r25
+ PORTC ^= BIT(0);
+ 106: 95 b3 in r25, 0x15 ; 21
+ 108: 81 e0 ldi r24, 0x01 ; 1
+ 10a: 89 27 eor r24, r25
+ 10c: 85 bb out 0x15, r24 ; 21
+ if(OCR2 == 250){
+ 10e: 83 b5 in r24, 0x23 ; 35
+ 110: 8a 3f cpi r24, 0xFA ; 250
+ 112: 19 f4 brne .+6 ; 0x11a <__vector_9+0x22>
+ OCR2 = 150;
+ 114: 86 e9 ldi r24, 0x96 ; 150
+ 116: 83 bd out 0x23, r24 ; 35
+ 118: 02 c0 rjmp .+4 ; 0x11e <__vector_9+0x26>
+ } else {
+ OCR2 = 250;
+ 11a: 8a ef ldi r24, 0xFA ; 250
+ 11c: 83 bd out 0x23, r24 ; 35
+ }
+
+}
+ 11e: 9f 91 pop r25
+ 120: 8f 91 pop r24
+ 122: 0f 90 pop r0
+ 124: 0f be out 0x3f, r0 ; 63
+ 126: 0f 90 pop r0
+ 128: 1f 90 pop r1
+ 12a: 18 95 reti
+
+0000012c :
+
+int main( void ) {
+ DDRC = 0xFF;
+ 12c: 8f ef ldi r24, 0xFF ; 255
+ 12e: 84 bb out 0x14, r24 ; 20
+ PORTC = BIT(0); // set PORTC for output (toggle PC0)
+ 130: 81 e0 ldi r24, 0x01 ; 1
+ 132: 85 bb out 0x15, r24 ; 21
+ timer2Init();
+ 134: d8 df rcall .-80 ; 0xe6
+
+ while (1) {
+ // do something else
+ wait(10); // every 10 ms (busy waiting
+ 136: 8a e0 ldi r24, 0x0A ; 10
+ 138: 90 e0 ldi r25, 0x00 ; 0
+ 13a: c6 df rcall .-116 ; 0xc8
+ 13c: fc cf rjmp .-8 ; 0x136
+
+0000013e <_exit>:
+ 13e: f8 94 cli
+
+00000140 <__stop_program>:
+ 140: ff cf rjmp .-2 ; 0x140 <__stop_program>
diff --git a/Microcontrollers/opdracht 3.3/Debug/opdracht 3.3.srec b/Microcontrollers/opdracht 3.3/Debug/opdracht 3.3.srec
new file mode 100644
index 0000000..67299cd
--- /dev/null
+++ b/Microcontrollers/opdracht 3.3/Debug/opdracht 3.3.srec
@@ -0,0 +1,23 @@
+S01400006F7064726163687420332E332E7372656307
+S113000045C0000060C000005EC000005CC000008D
+S11300105AC0000058C0000056C0000054C0000080
+S113002052C0000069C000004EC000004CC0000077
+S11300304AC0000048C0000046C0000044C00000A0
+S113004042C0000040C000003EC000003CC00000B0
+S11300503AC0000038C0000036C0000034C00000C0
+S113006032C0000030C000002EC000002CC00000D0
+S11300702AC0000028C0000026C0000024C00000E0
+S113008022C0000020C000001EC0000011241FBEBA
+S1130090CFEFD0E1DEBFCDBF11E0A0E0B1E0E2E4FC
+S11300A0F1E000E00BBF02C007900D92A030B10751
+S11300B0D9F721E0A0E0B1E001C01D92A030B20761
+S11300C0E1F734D03CC09CCF20E030E008C0E3EC42
+S11300D0F9E03197F1F700C000002F5F3F4F281778
+S11300E03907ACF3089586E983BD87B7806887BF75
+S11300F078948DE085BD08951F920F920FB60F92EC
+S113010011248F939F9395B381E0892785BB83B591
+S11301108A3F19F486E983BD02C08AEF83BD9F91AB
+S11301208F910F900FBE0F901F9018958FEF84BB87
+S113013081E085BBD8DF8AE090E0C6DFFCCFF8948D
+S1050140FFCFEB
+S9030000FC
diff --git a/Microcontrollers/opdracht 3.3/main.c b/Microcontrollers/opdracht 3.3/main.c
new file mode 100644
index 0000000..39318aa
--- /dev/null
+++ b/Microcontrollers/opdracht 3.3/main.c
@@ -0,0 +1,52 @@
+/*
+ * timer_t2_ms.c
+ *
+ * Created: 21/02/2021 13:20:32
+ * Author : Etienne
+ */
+
+#define F_CPU 10e6
+#include
+#include
+#include
+
+#define BIT(x) (1 << (x))
+
+// wait(): busy waiting for 'ms' millisecond
+// Used library: util/delay.h
+void wait( int ms ) {
+ for (int tms=0; tms
+
+
+
+
+
+ Device
+ Startup
+
+
+ Atmel
+ 1.6.0
+ C:/Program Files (x86)\Atmel\Studio\7.0\Packs
+
+
+
+
+ C:/Program Files (x86)\Atmel\Studio\7.0\Packs\atmel\ATmega_DFP\1.6.364\include\
+
+ include
+ C
+
+
+ include/
+
+
+
+
+ C:/Program Files (x86)\Atmel\Studio\7.0\Packs\atmel\ATmega_DFP\1.6.364\include\avr\iom128.h
+
+ header
+ C
+ JdJ7J9I/SJh965SEyyyVYw==
+
+ include/avr/iom128.h
+
+
+
+
+ C:/Program Files (x86)\Atmel\Studio\7.0\Packs\atmel\ATmega_DFP\1.6.364\templates\main.c
+ template
+ source
+ C Exe
+ rR6mgUtO8q2QLIRcSnx1LA==
+
+ templates/main.c
+ Main file (.c)
+
+
+
+ C:/Program Files (x86)\Atmel\Studio\7.0\Packs\atmel\ATmega_DFP\1.6.364\templates\main.cpp
+ template
+ source
+ C Exe
+ mkKaE95TOoATsuBGv6jmxg==
+
+ templates/main.cpp
+ Main file (.cpp)
+
+
+
+ C:/Program Files (x86)\Atmel\Studio\7.0\Packs\atmel\ATmega_DFP\1.6.364\gcc\dev\atmega128
+
+ libraryPrefix
+ GCC
+
+
+ gcc/dev/atmega128
+
+
+
+
+ ATmega_DFP
+ C:/Program Files (x86)/Atmel/Studio/7.0/Packs/atmel/ATmega_DFP/1.6.364/Atmel.ATmega_DFP.pdsc
+ 1.6.364
+ true
+ ATmega128
+
+
+
+ Resolved
+ Fixed
+ true
+
+
+
\ No newline at end of file
diff --git a/Microcontrollers/opdracht 3.3/opdracht 3.3.cproj b/Microcontrollers/opdracht 3.3/opdracht 3.3.cproj
new file mode 100644
index 0000000..4ad83d2
--- /dev/null
+++ b/Microcontrollers/opdracht 3.3/opdracht 3.3.cproj
@@ -0,0 +1,130 @@
+
+
+
+ 2.0
+ 7.0
+ com.Atmel.AVRGCC8.C
+ {985d5c75-f61e-49f1-a532-66a1e6141552}
+ ATmega128
+ none
+ Executable
+ C
+ $(MSBuildProjectName)
+ .elf
+ $(MSBuildProjectDirectory)\$(Configuration)
+ opdracht 3.3
+ opdracht 3.3
+ opdracht 3.3
+ Native
+ true
+ false
+ true
+ true
+
+
+ true
+
+ 2
+ 0
+ 0
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ -mmcu=atmega128 -B "%24(PackRepoDir)\atmel\ATmega_DFP\1.6.364\gcc\dev\atmega128"
+ True
+ True
+ True
+ True
+ True
+ False
+ True
+ True
+
+
+ NDEBUG
+
+
+
+
+ %24(PackRepoDir)\atmel\ATmega_DFP\1.6.364\include\
+
+
+ Optimize for size (-Os)
+ True
+ True
+ True
+
+
+ libm
+
+
+
+
+ %24(PackRepoDir)\atmel\ATmega_DFP\1.6.364\include\
+
+
+
+
+
+
+
+
+ -mmcu=atmega128 -B "%24(PackRepoDir)\atmel\ATmega_DFP\1.6.364\gcc\dev\atmega128"
+ True
+ True
+ True
+ True
+ True
+ False
+ True
+ True
+
+
+ DEBUG
+
+
+
+
+ %24(PackRepoDir)\atmel\ATmega_DFP\1.6.364\include\
+
+
+ Optimize debugging experience (-Og)
+ True
+ True
+ Default (-g2)
+ True
+
+
+ libm
+
+
+
+
+ %24(PackRepoDir)\atmel\ATmega_DFP\1.6.364\include\
+
+
+ Default (-Wa,-g)
+
+
+
+
+
+ compile
+
+
+
+
\ No newline at end of file