
I2C_Driver.elf:     file format elf32-littlearm

Sections:
Idx Name          Size      VMA       LMA       File off  Algn
  0 .isr_vector   00000194  08000000  08000000  00010000  2**0
                  CONTENTS, ALLOC, LOAD, READONLY, DATA
  1 .text         00001130  08000194  08000194  00010194  2**2
                  CONTENTS, ALLOC, LOAD, READONLY, CODE
  2 .rodata       00000008  080012c4  080012c4  000112c4  2**2
                  CONTENTS, ALLOC, LOAD, READONLY, DATA
  3 .ARM.extab    00000000  080012cc  080012cc  00020020  2**0
                  CONTENTS
  4 .ARM          00000000  080012cc  080012cc  00020020  2**0
                  CONTENTS
  5 .preinit_array 00000000  080012cc  080012cc  00020020  2**0
                  CONTENTS, ALLOC, LOAD, DATA
  6 .init_array   00000004  080012cc  080012cc  000112cc  2**2
                  CONTENTS, ALLOC, LOAD, DATA
  7 .fini_array   00000004  080012d0  080012d0  000112d0  2**2
                  CONTENTS, ALLOC, LOAD, DATA
  8 .data         00000020  20000000  080012d4  00020000  2**2
                  CONTENTS, ALLOC, LOAD, DATA
  9 .bss          00000050  20000020  080012f4  00020020  2**2
                  ALLOC
 10 ._user_heap_stack 00000600  20000070  080012f4  00020070  2**0
                  ALLOC
 11 .ARM.attributes 00000030  00000000  00000000  00020020  2**0
                  CONTENTS, READONLY
 12 .comment      00000043  00000000  00000000  00020050  2**0
                  CONTENTS, READONLY
 13 .debug_info   00002f95  00000000  00000000  00020093  2**0
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 14 .debug_abbrev 00000ae0  00000000  00000000  00023028  2**0
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 15 .debug_aranges 00000268  00000000  00000000  00023b08  2**3
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 16 .debug_rnglists 000001c3  00000000  00000000  00023d70  2**0
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 17 .debug_macro  0000e881  00000000  00000000  00023f33  2**0
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 18 .debug_line   00002ef6  00000000  00000000  000327b4  2**0
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 19 .debug_str    00051ead  00000000  00000000  000356aa  2**0
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 20 .debug_frame  00000900  00000000  00000000  00087558  2**2
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 21 .debug_line_str 00000050  00000000  00000000  00087e58  2**0
                  CONTENTS, READONLY, DEBUGGING, OCTETS

Disassembly of section .text:

08000194 <__do_global_dtors_aux>:
 8000194:	b510      	push	{r4, lr}
 8000196:	4c05      	ldr	r4, [pc, #20]	; (80001ac <__do_global_dtors_aux+0x18>)
 8000198:	7823      	ldrb	r3, [r4, #0]
 800019a:	b933      	cbnz	r3, 80001aa <__do_global_dtors_aux+0x16>
 800019c:	4b04      	ldr	r3, [pc, #16]	; (80001b0 <__do_global_dtors_aux+0x1c>)
 800019e:	b113      	cbz	r3, 80001a6 <__do_global_dtors_aux+0x12>
 80001a0:	4804      	ldr	r0, [pc, #16]	; (80001b4 <__do_global_dtors_aux+0x20>)
 80001a2:	f3af 8000 	nop.w
 80001a6:	2301      	movs	r3, #1
 80001a8:	7023      	strb	r3, [r4, #0]
 80001aa:	bd10      	pop	{r4, pc}
 80001ac:	20000020 	.word	0x20000020
 80001b0:	00000000 	.word	0x00000000
 80001b4:	080012ac 	.word	0x080012ac

080001b8 <frame_dummy>:
 80001b8:	b508      	push	{r3, lr}
 80001ba:	4b03      	ldr	r3, [pc, #12]	; (80001c8 <frame_dummy+0x10>)
 80001bc:	b11b      	cbz	r3, 80001c6 <frame_dummy+0xe>
 80001be:	4903      	ldr	r1, [pc, #12]	; (80001cc <frame_dummy+0x14>)
 80001c0:	4803      	ldr	r0, [pc, #12]	; (80001d0 <frame_dummy+0x18>)
 80001c2:	f3af 8000 	nop.w
 80001c6:	bd08      	pop	{r3, pc}
 80001c8:	00000000 	.word	0x00000000
 80001cc:	20000024 	.word	0x20000024
 80001d0:	080012ac 	.word	0x080012ac

080001d4 <GPIO_Config>:
 * 			0x0		or		GPIO_PUPD_None
 * 			0x1		or		GPIO_PullUp
 * 			0x2		or		GPIO_PullDown
 */
void GPIO_Config(GPIO_Config_t *GPIO_Config, GPIO_TypeDef *Port, uint8_t Pin, uint8_t Mode, uint8_t OType, uint8_t OSpeed, uint8_t PUPD)
{
 80001d4:	b480      	push	{r7}
 80001d6:	b085      	sub	sp, #20
 80001d8:	af00      	add	r7, sp, #0
 80001da:	60f8      	str	r0, [r7, #12]
 80001dc:	60b9      	str	r1, [r7, #8]
 80001de:	4611      	mov	r1, r2
 80001e0:	461a      	mov	r2, r3
 80001e2:	460b      	mov	r3, r1
 80001e4:	71fb      	strb	r3, [r7, #7]
 80001e6:	4613      	mov	r3, r2
 80001e8:	71bb      	strb	r3, [r7, #6]
	GPIO_Config->GPIO_Pin = Pin;
 80001ea:	68fb      	ldr	r3, [r7, #12]
 80001ec:	79fa      	ldrb	r2, [r7, #7]
 80001ee:	701a      	strb	r2, [r3, #0]
	GPIO_Config->GPIO_Port = Port;
 80001f0:	68fb      	ldr	r3, [r7, #12]
 80001f2:	68ba      	ldr	r2, [r7, #8]
 80001f4:	609a      	str	r2, [r3, #8]
	GPIO_Config->GPIO_MODE = Mode;
 80001f6:	68fb      	ldr	r3, [r7, #12]
 80001f8:	79ba      	ldrb	r2, [r7, #6]
 80001fa:	705a      	strb	r2, [r3, #1]
	GPIO_Config->GPIO_OTYPE = OType;
 80001fc:	68fb      	ldr	r3, [r7, #12]
 80001fe:	7e3a      	ldrb	r2, [r7, #24]
 8000200:	709a      	strb	r2, [r3, #2]
	GPIO_Config->GPIO_OSPEED = OSpeed;
 8000202:	68fb      	ldr	r3, [r7, #12]
 8000204:	7f3a      	ldrb	r2, [r7, #28]
 8000206:	70da      	strb	r2, [r3, #3]
	GPIO_Config->GPIO_PUPD = PUPD;
 8000208:	68fb      	ldr	r3, [r7, #12]
 800020a:	f897 2020 	ldrb.w	r2, [r7, #32]
 800020e:	711a      	strb	r2, [r3, #4]
}
 8000210:	bf00      	nop
 8000212:	3714      	adds	r7, #20
 8000214:	46bd      	mov	sp, r7
 8000216:	f85d 7b04 	ldr.w	r7, [sp], #4
 800021a:	4770      	bx	lr

0800021c <GPIO_PeriphClck>:
 * @param	GPIOx: Defines the specific GPIO port, where x can range from A - E, or H.
 *
 * @param	state: Specifies whether to enable or disable the peripheral.
 */
void GPIO_PeriphClck(GPIO_TypeDef *GPIOx, FunctionalState state)
{
 800021c:	b580      	push	{r7, lr}
 800021e:	b082      	sub	sp, #8
 8000220:	af00      	add	r7, sp, #0
 8000222:	6078      	str	r0, [r7, #4]
 8000224:	460b      	mov	r3, r1
 8000226:	70fb      	strb	r3, [r7, #3]
	if(state == ENABLE)
 8000228:	78fb      	ldrb	r3, [r7, #3]
 800022a:	2b01      	cmp	r3, #1
 800022c:	d135      	bne.n	800029a <GPIO_PeriphClck+0x7e>
	{
		if(GPIOx == GPIOA)
 800022e:	687b      	ldr	r3, [r7, #4]
 8000230:	4a36      	ldr	r2, [pc, #216]	; (800030c <GPIO_PeriphClck+0xf0>)
 8000232:	4293      	cmp	r3, r2
 8000234:	d104      	bne.n	8000240 <GPIO_PeriphClck+0x24>
		{
			RCC_AHB1Cmd(GPIOA_Enable, ENABLE);
 8000236:	2101      	movs	r1, #1
 8000238:	2001      	movs	r0, #1
 800023a:	f000 fca3 	bl	8000b84 <RCC_AHB1Cmd>
			RCC_AHB1Cmd(GPIOH_Enable, DISABLE);
		}

	}

}
 800023e:	e061      	b.n	8000304 <GPIO_PeriphClck+0xe8>
		else if(GPIOx == GPIOB)
 8000240:	687b      	ldr	r3, [r7, #4]
 8000242:	4a33      	ldr	r2, [pc, #204]	; (8000310 <GPIO_PeriphClck+0xf4>)
 8000244:	4293      	cmp	r3, r2
 8000246:	d104      	bne.n	8000252 <GPIO_PeriphClck+0x36>
			RCC_AHB1Cmd(GPIOB_Enable, ENABLE);
 8000248:	2101      	movs	r1, #1
 800024a:	2002      	movs	r0, #2
 800024c:	f000 fc9a 	bl	8000b84 <RCC_AHB1Cmd>
}
 8000250:	e058      	b.n	8000304 <GPIO_PeriphClck+0xe8>
		else if(GPIOx == GPIOC)
 8000252:	687b      	ldr	r3, [r7, #4]
 8000254:	4a2f      	ldr	r2, [pc, #188]	; (8000314 <GPIO_PeriphClck+0xf8>)
 8000256:	4293      	cmp	r3, r2
 8000258:	d104      	bne.n	8000264 <GPIO_PeriphClck+0x48>
			RCC_AHB1Cmd(GPIOC_Enable, ENABLE);
 800025a:	2101      	movs	r1, #1
 800025c:	2004      	movs	r0, #4
 800025e:	f000 fc91 	bl	8000b84 <RCC_AHB1Cmd>
}
 8000262:	e04f      	b.n	8000304 <GPIO_PeriphClck+0xe8>
		else if(GPIOx == GPIOD)
 8000264:	687b      	ldr	r3, [r7, #4]
 8000266:	4a2c      	ldr	r2, [pc, #176]	; (8000318 <GPIO_PeriphClck+0xfc>)
 8000268:	4293      	cmp	r3, r2
 800026a:	d104      	bne.n	8000276 <GPIO_PeriphClck+0x5a>
			RCC_AHB1Cmd(GPIOD_Enable, ENABLE);
 800026c:	2101      	movs	r1, #1
 800026e:	2008      	movs	r0, #8
 8000270:	f000 fc88 	bl	8000b84 <RCC_AHB1Cmd>
}
 8000274:	e046      	b.n	8000304 <GPIO_PeriphClck+0xe8>
		else if(GPIOx == GPIOE)
 8000276:	687b      	ldr	r3, [r7, #4]
 8000278:	4a28      	ldr	r2, [pc, #160]	; (800031c <GPIO_PeriphClck+0x100>)
 800027a:	4293      	cmp	r3, r2
 800027c:	d104      	bne.n	8000288 <GPIO_PeriphClck+0x6c>
			RCC_AHB1Cmd(GPIOE_Enable, ENABLE);
 800027e:	2101      	movs	r1, #1
 8000280:	2010      	movs	r0, #16
 8000282:	f000 fc7f 	bl	8000b84 <RCC_AHB1Cmd>
}
 8000286:	e03d      	b.n	8000304 <GPIO_PeriphClck+0xe8>
		else if(GPIOx == GPIOH)
 8000288:	687b      	ldr	r3, [r7, #4]
 800028a:	4a25      	ldr	r2, [pc, #148]	; (8000320 <GPIO_PeriphClck+0x104>)
 800028c:	4293      	cmp	r3, r2
 800028e:	d139      	bne.n	8000304 <GPIO_PeriphClck+0xe8>
			RCC_AHB1Cmd(GPIOH_Enable, ENABLE);
 8000290:	2101      	movs	r1, #1
 8000292:	2080      	movs	r0, #128	; 0x80
 8000294:	f000 fc76 	bl	8000b84 <RCC_AHB1Cmd>
}
 8000298:	e034      	b.n	8000304 <GPIO_PeriphClck+0xe8>
		if(GPIOx == GPIOA)
 800029a:	687b      	ldr	r3, [r7, #4]
 800029c:	4a1b      	ldr	r2, [pc, #108]	; (800030c <GPIO_PeriphClck+0xf0>)
 800029e:	4293      	cmp	r3, r2
 80002a0:	d104      	bne.n	80002ac <GPIO_PeriphClck+0x90>
			RCC_AHB1Cmd(GPIOA_Enable, DISABLE);
 80002a2:	2100      	movs	r1, #0
 80002a4:	2001      	movs	r0, #1
 80002a6:	f000 fc6d 	bl	8000b84 <RCC_AHB1Cmd>
}
 80002aa:	e02b      	b.n	8000304 <GPIO_PeriphClck+0xe8>
		else if(GPIOx == GPIOB)
 80002ac:	687b      	ldr	r3, [r7, #4]
 80002ae:	4a18      	ldr	r2, [pc, #96]	; (8000310 <GPIO_PeriphClck+0xf4>)
 80002b0:	4293      	cmp	r3, r2
 80002b2:	d104      	bne.n	80002be <GPIO_PeriphClck+0xa2>
			RCC_AHB1Cmd(GPIOB_Enable, DISABLE);
 80002b4:	2100      	movs	r1, #0
 80002b6:	2002      	movs	r0, #2
 80002b8:	f000 fc64 	bl	8000b84 <RCC_AHB1Cmd>
}
 80002bc:	e022      	b.n	8000304 <GPIO_PeriphClck+0xe8>
		else if(GPIOx == GPIOC)
 80002be:	687b      	ldr	r3, [r7, #4]
 80002c0:	4a14      	ldr	r2, [pc, #80]	; (8000314 <GPIO_PeriphClck+0xf8>)
 80002c2:	4293      	cmp	r3, r2
 80002c4:	d104      	bne.n	80002d0 <GPIO_PeriphClck+0xb4>
			RCC_AHB1Cmd(GPIOC_Enable, DISABLE);
 80002c6:	2100      	movs	r1, #0
 80002c8:	2004      	movs	r0, #4
 80002ca:	f000 fc5b 	bl	8000b84 <RCC_AHB1Cmd>
}
 80002ce:	e019      	b.n	8000304 <GPIO_PeriphClck+0xe8>
		else if(GPIOx == GPIOD)
 80002d0:	687b      	ldr	r3, [r7, #4]
 80002d2:	4a11      	ldr	r2, [pc, #68]	; (8000318 <GPIO_PeriphClck+0xfc>)
 80002d4:	4293      	cmp	r3, r2
 80002d6:	d104      	bne.n	80002e2 <GPIO_PeriphClck+0xc6>
			RCC_AHB1Cmd(GPIOD_Enable, DISABLE);
 80002d8:	2100      	movs	r1, #0
 80002da:	2008      	movs	r0, #8
 80002dc:	f000 fc52 	bl	8000b84 <RCC_AHB1Cmd>
}
 80002e0:	e010      	b.n	8000304 <GPIO_PeriphClck+0xe8>
		else if(GPIOx == GPIOE)
 80002e2:	687b      	ldr	r3, [r7, #4]
 80002e4:	4a0d      	ldr	r2, [pc, #52]	; (800031c <GPIO_PeriphClck+0x100>)
 80002e6:	4293      	cmp	r3, r2
 80002e8:	d104      	bne.n	80002f4 <GPIO_PeriphClck+0xd8>
			RCC_AHB1Cmd(GPIOE_Enable, DISABLE);
 80002ea:	2100      	movs	r1, #0
 80002ec:	2010      	movs	r0, #16
 80002ee:	f000 fc49 	bl	8000b84 <RCC_AHB1Cmd>
}
 80002f2:	e007      	b.n	8000304 <GPIO_PeriphClck+0xe8>
		else if(GPIOx == GPIOH)
 80002f4:	687b      	ldr	r3, [r7, #4]
 80002f6:	4a0a      	ldr	r2, [pc, #40]	; (8000320 <GPIO_PeriphClck+0x104>)
 80002f8:	4293      	cmp	r3, r2
 80002fa:	d103      	bne.n	8000304 <GPIO_PeriphClck+0xe8>
			RCC_AHB1Cmd(GPIOH_Enable, DISABLE);
 80002fc:	2100      	movs	r1, #0
 80002fe:	2080      	movs	r0, #128	; 0x80
 8000300:	f000 fc40 	bl	8000b84 <RCC_AHB1Cmd>
}
 8000304:	bf00      	nop
 8000306:	3708      	adds	r7, #8
 8000308:	46bd      	mov	sp, r7
 800030a:	bd80      	pop	{r7, pc}
 800030c:	40020000 	.word	0x40020000
 8000310:	40020400 	.word	0x40020400
 8000314:	40020800 	.word	0x40020800
 8000318:	40020c00 	.word	0x40020c00
 800031c:	40021000 	.word	0x40021000
 8000320:	40021c00 	.word	0x40021c00

08000324 <GPIO_AlternateFunctionConfig>:
 * @param	alt_function: This will take in the alternate function value that the user wishes to use.
 * 			The specific alternate function values and their functions are present in the data sheet.
 * 			The inputs for this function are AF0 - AF15;
 */
void GPIO_AlternateFunctionConfig(GPIO_Config_t *GPIO_Config, AFR_Config_t alt_function)
{
 8000324:	b480      	push	{r7}
 8000326:	b085      	sub	sp, #20
 8000328:	af00      	add	r7, sp, #0
 800032a:	6078      	str	r0, [r7, #4]
 800032c:	460b      	mov	r3, r1
 800032e:	70fb      	strb	r3, [r7, #3]
	uint8_t pin = GPIO_Config->GPIO_Pin;
 8000330:	687b      	ldr	r3, [r7, #4]
 8000332:	781b      	ldrb	r3, [r3, #0]
 8000334:	73fb      	strb	r3, [r7, #15]
	uint8_t alt_function_array = pin/8;
 8000336:	7bfb      	ldrb	r3, [r7, #15]
 8000338:	08db      	lsrs	r3, r3, #3
 800033a:	73bb      	strb	r3, [r7, #14]

	if(alt_function_array == 1)
 800033c:	7bbb      	ldrb	r3, [r7, #14]
 800033e:	2b01      	cmp	r3, #1
 8000340:	d102      	bne.n	8000348 <GPIO_AlternateFunctionConfig+0x24>
	{
		pin -= 8;
 8000342:	7bfb      	ldrb	r3, [r7, #15]
 8000344:	3b08      	subs	r3, #8
 8000346:	73fb      	strb	r3, [r7, #15]
	}

	GPIO_Config->GPIO_Port->AFR[alt_function_array] &= ~(AF15 << (pin * 4));
 8000348:	687b      	ldr	r3, [r7, #4]
 800034a:	689b      	ldr	r3, [r3, #8]
 800034c:	7bba      	ldrb	r2, [r7, #14]
 800034e:	3208      	adds	r2, #8
 8000350:	f853 1022 	ldr.w	r1, [r3, r2, lsl #2]
 8000354:	7bfb      	ldrb	r3, [r7, #15]
 8000356:	009b      	lsls	r3, r3, #2
 8000358:	220f      	movs	r2, #15
 800035a:	fa02 f303 	lsl.w	r3, r2, r3
 800035e:	43db      	mvns	r3, r3
 8000360:	4618      	mov	r0, r3
 8000362:	687b      	ldr	r3, [r7, #4]
 8000364:	689b      	ldr	r3, [r3, #8]
 8000366:	7bba      	ldrb	r2, [r7, #14]
 8000368:	4001      	ands	r1, r0
 800036a:	3208      	adds	r2, #8
 800036c:	f843 1022 	str.w	r1, [r3, r2, lsl #2]
	GPIO_Config->GPIO_Port->AFR[alt_function_array] |= (alt_function << (pin * 4));
 8000370:	687b      	ldr	r3, [r7, #4]
 8000372:	689b      	ldr	r3, [r3, #8]
 8000374:	7bba      	ldrb	r2, [r7, #14]
 8000376:	3208      	adds	r2, #8
 8000378:	f853 1022 	ldr.w	r1, [r3, r2, lsl #2]
 800037c:	78fa      	ldrb	r2, [r7, #3]
 800037e:	7bfb      	ldrb	r3, [r7, #15]
 8000380:	009b      	lsls	r3, r3, #2
 8000382:	fa02 f303 	lsl.w	r3, r2, r3
 8000386:	4618      	mov	r0, r3
 8000388:	687b      	ldr	r3, [r7, #4]
 800038a:	689b      	ldr	r3, [r3, #8]
 800038c:	7bba      	ldrb	r2, [r7, #14]
 800038e:	4301      	orrs	r1, r0
 8000390:	3208      	adds	r2, #8
 8000392:	f843 1022 	str.w	r1, [r3, r2, lsl #2]
}
 8000396:	bf00      	nop
 8000398:	3714      	adds	r7, #20
 800039a:	46bd      	mov	sp, r7
 800039c:	f85d 7b04 	ldr.w	r7, [sp], #4
 80003a0:	4770      	bx	lr
	...

080003a4 <GPIO_Init>:
 *
 * @param	GPIO_Config: pointer to the GPIO_Config_t data structure that contains the
 * 			configuration parameters for the specific GPIO pin.
 */
void GPIO_Init(GPIO_Config_t *GPIO_Config, AFR_Config_t alt_function)
{
 80003a4:	b580      	push	{r7, lr}
 80003a6:	b084      	sub	sp, #16
 80003a8:	af00      	add	r7, sp, #0
 80003aa:	6078      	str	r0, [r7, #4]
 80003ac:	460b      	mov	r3, r1
 80003ae:	70fb      	strb	r3, [r7, #3]
	uint8_t pin = GPIO_Config->GPIO_Pin;
 80003b0:	687b      	ldr	r3, [r7, #4]
 80003b2:	781b      	ldrb	r3, [r3, #0]
 80003b4:	73fb      	strb	r3, [r7, #15]
	uint32_t temp_variable;

	GPIO_PeriphClck(GPIO_Config->GPIO_Port, ENABLE);
 80003b6:	687b      	ldr	r3, [r7, #4]
 80003b8:	689b      	ldr	r3, [r3, #8]
 80003ba:	2101      	movs	r1, #1
 80003bc:	4618      	mov	r0, r3
 80003be:	f7ff ff2d 	bl	800021c <GPIO_PeriphClck>

	if(GPIO_Config->GPIO_Pin == AllPins)
 80003c2:	687b      	ldr	r3, [r7, #4]
 80003c4:	781b      	ldrb	r3, [r3, #0]
 80003c6:	2b10      	cmp	r3, #16
 80003c8:	f040 8094 	bne.w	80004f4 <GPIO_Init+0x150>
	{
		if(GPIO_Config->GPIO_Port == GPIOA)
 80003cc:	687b      	ldr	r3, [r7, #4]
 80003ce:	689b      	ldr	r3, [r3, #8]
 80003d0:	4a88      	ldr	r2, [pc, #544]	; (80005f4 <GPIO_Init+0x250>)
 80003d2:	4293      	cmp	r3, r2
 80003d4:	d112      	bne.n	80003fc <GPIO_Init+0x58>
		{
			/*Use the lock configuration to lock PA13 and PA14*/
			GPIO_Config->GPIO_Port->LCKR = LCKR_1_Pin13_Pin14;
 80003d6:	687b      	ldr	r3, [r7, #4]
 80003d8:	689b      	ldr	r3, [r3, #8]
 80003da:	f44f 32b0 	mov.w	r2, #90112	; 0x16000
 80003de:	61da      	str	r2, [r3, #28]
			GPIO_Config->GPIO_Port->LCKR = LCKR_0_Pin13_Pin14;
 80003e0:	687b      	ldr	r3, [r7, #4]
 80003e2:	689b      	ldr	r3, [r3, #8]
 80003e4:	f44f 42c0 	mov.w	r2, #24576	; 0x6000
 80003e8:	61da      	str	r2, [r3, #28]
			GPIO_Config->GPIO_Port->LCKR = LCKR_1_Pin13_Pin14;
 80003ea:	687b      	ldr	r3, [r7, #4]
 80003ec:	689b      	ldr	r3, [r3, #8]
 80003ee:	f44f 32b0 	mov.w	r2, #90112	; 0x16000
 80003f2:	61da      	str	r2, [r3, #28]
			temp_variable = GPIO_Config->GPIO_Port->LCKR;
 80003f4:	687b      	ldr	r3, [r7, #4]
 80003f6:	689b      	ldr	r3, [r3, #8]
 80003f8:	69db      	ldr	r3, [r3, #28]
 80003fa:	60bb      	str	r3, [r7, #8]
		}

		/*Used to set each pin is AllPins is set by user*/
		for(pin = 0; pin < 16; pin++)
 80003fc:	2300      	movs	r3, #0
 80003fe:	73fb      	strb	r3, [r7, #15]
 8000400:	e074      	b.n	80004ec <GPIO_Init+0x148>
		{
			GPIO_Config->GPIO_Port->MODER &= ~(GPIO_Mode_Reset << (pin * 2));
 8000402:	687b      	ldr	r3, [r7, #4]
 8000404:	689b      	ldr	r3, [r3, #8]
 8000406:	681a      	ldr	r2, [r3, #0]
 8000408:	7bfb      	ldrb	r3, [r7, #15]
 800040a:	005b      	lsls	r3, r3, #1
 800040c:	2103      	movs	r1, #3
 800040e:	fa01 f303 	lsl.w	r3, r1, r3
 8000412:	43db      	mvns	r3, r3
 8000414:	4619      	mov	r1, r3
 8000416:	687b      	ldr	r3, [r7, #4]
 8000418:	689b      	ldr	r3, [r3, #8]
 800041a:	400a      	ands	r2, r1
 800041c:	601a      	str	r2, [r3, #0]
			GPIO_Config->GPIO_Port->MODER |= ((GPIO_Config->GPIO_MODE) << (pin * 2));
 800041e:	687b      	ldr	r3, [r7, #4]
 8000420:	689b      	ldr	r3, [r3, #8]
 8000422:	681a      	ldr	r2, [r3, #0]
 8000424:	687b      	ldr	r3, [r7, #4]
 8000426:	785b      	ldrb	r3, [r3, #1]
 8000428:	4619      	mov	r1, r3
 800042a:	7bfb      	ldrb	r3, [r7, #15]
 800042c:	005b      	lsls	r3, r3, #1
 800042e:	fa01 f303 	lsl.w	r3, r1, r3
 8000432:	4619      	mov	r1, r3
 8000434:	687b      	ldr	r3, [r7, #4]
 8000436:	689b      	ldr	r3, [r3, #8]
 8000438:	430a      	orrs	r2, r1
 800043a:	601a      	str	r2, [r3, #0]

			GPIO_Config->GPIO_Port->OTYPER &= ~(GPIO_OType_Reset << pin);
 800043c:	687b      	ldr	r3, [r7, #4]
 800043e:	689b      	ldr	r3, [r3, #8]
 8000440:	685a      	ldr	r2, [r3, #4]
 8000442:	7bfb      	ldrb	r3, [r7, #15]
 8000444:	2101      	movs	r1, #1
 8000446:	fa01 f303 	lsl.w	r3, r1, r3
 800044a:	43db      	mvns	r3, r3
 800044c:	4619      	mov	r1, r3
 800044e:	687b      	ldr	r3, [r7, #4]
 8000450:	689b      	ldr	r3, [r3, #8]
 8000452:	400a      	ands	r2, r1
 8000454:	605a      	str	r2, [r3, #4]
			GPIO_Config->GPIO_Port->OTYPER |= ((GPIO_Config->GPIO_OTYPE) << pin);
 8000456:	687b      	ldr	r3, [r7, #4]
 8000458:	689b      	ldr	r3, [r3, #8]
 800045a:	685a      	ldr	r2, [r3, #4]
 800045c:	687b      	ldr	r3, [r7, #4]
 800045e:	789b      	ldrb	r3, [r3, #2]
 8000460:	4619      	mov	r1, r3
 8000462:	7bfb      	ldrb	r3, [r7, #15]
 8000464:	fa01 f303 	lsl.w	r3, r1, r3
 8000468:	4619      	mov	r1, r3
 800046a:	687b      	ldr	r3, [r7, #4]
 800046c:	689b      	ldr	r3, [r3, #8]
 800046e:	430a      	orrs	r2, r1
 8000470:	605a      	str	r2, [r3, #4]

			GPIO_Config->GPIO_Port->OSPEEDR &= ~(GPIO_OSpeed_Reset << (pin * 2));
 8000472:	687b      	ldr	r3, [r7, #4]
 8000474:	689b      	ldr	r3, [r3, #8]
 8000476:	689a      	ldr	r2, [r3, #8]
 8000478:	7bfb      	ldrb	r3, [r7, #15]
 800047a:	005b      	lsls	r3, r3, #1
 800047c:	2101      	movs	r1, #1
 800047e:	fa01 f303 	lsl.w	r3, r1, r3
 8000482:	43db      	mvns	r3, r3
 8000484:	4619      	mov	r1, r3
 8000486:	687b      	ldr	r3, [r7, #4]
 8000488:	689b      	ldr	r3, [r3, #8]
 800048a:	400a      	ands	r2, r1
 800048c:	609a      	str	r2, [r3, #8]
			GPIO_Config->GPIO_Port->OSPEEDR |= ((GPIO_Config->GPIO_OSPEED) << (pin * 2));
 800048e:	687b      	ldr	r3, [r7, #4]
 8000490:	689b      	ldr	r3, [r3, #8]
 8000492:	689a      	ldr	r2, [r3, #8]
 8000494:	687b      	ldr	r3, [r7, #4]
 8000496:	78db      	ldrb	r3, [r3, #3]
 8000498:	4619      	mov	r1, r3
 800049a:	7bfb      	ldrb	r3, [r7, #15]
 800049c:	005b      	lsls	r3, r3, #1
 800049e:	fa01 f303 	lsl.w	r3, r1, r3
 80004a2:	4619      	mov	r1, r3
 80004a4:	687b      	ldr	r3, [r7, #4]
 80004a6:	689b      	ldr	r3, [r3, #8]
 80004a8:	430a      	orrs	r2, r1
 80004aa:	609a      	str	r2, [r3, #8]

			GPIO_Config->GPIO_Port->PUPDR &= ~(GPIO_PUPD_Reset << (pin * 2));
 80004ac:	687b      	ldr	r3, [r7, #4]
 80004ae:	689b      	ldr	r3, [r3, #8]
 80004b0:	68da      	ldr	r2, [r3, #12]
 80004b2:	7bfb      	ldrb	r3, [r7, #15]
 80004b4:	005b      	lsls	r3, r3, #1
 80004b6:	2103      	movs	r1, #3
 80004b8:	fa01 f303 	lsl.w	r3, r1, r3
 80004bc:	43db      	mvns	r3, r3
 80004be:	4619      	mov	r1, r3
 80004c0:	687b      	ldr	r3, [r7, #4]
 80004c2:	689b      	ldr	r3, [r3, #8]
 80004c4:	400a      	ands	r2, r1
 80004c6:	60da      	str	r2, [r3, #12]
			GPIO_Config->GPIO_Port->PUPDR |= ((GPIO_Config->GPIO_PUPD) << (pin * 2));
 80004c8:	687b      	ldr	r3, [r7, #4]
 80004ca:	689b      	ldr	r3, [r3, #8]
 80004cc:	68da      	ldr	r2, [r3, #12]
 80004ce:	687b      	ldr	r3, [r7, #4]
 80004d0:	791b      	ldrb	r3, [r3, #4]
 80004d2:	4619      	mov	r1, r3
 80004d4:	7bfb      	ldrb	r3, [r7, #15]
 80004d6:	005b      	lsls	r3, r3, #1
 80004d8:	fa01 f303 	lsl.w	r3, r1, r3
 80004dc:	4619      	mov	r1, r3
 80004de:	687b      	ldr	r3, [r7, #4]
 80004e0:	689b      	ldr	r3, [r3, #8]
 80004e2:	430a      	orrs	r2, r1
 80004e4:	60da      	str	r2, [r3, #12]
		for(pin = 0; pin < 16; pin++)
 80004e6:	7bfb      	ldrb	r3, [r7, #15]
 80004e8:	3301      	adds	r3, #1
 80004ea:	73fb      	strb	r3, [r7, #15]
 80004ec:	7bfb      	ldrb	r3, [r7, #15]
 80004ee:	2b0f      	cmp	r3, #15
 80004f0:	d987      	bls.n	8000402 <GPIO_Init+0x5e>

		GPIO_Config->GPIO_Port->PUPDR &= ~(GPIO_PUPD_Reset << (pin * 2));
		GPIO_Config->GPIO_Port->PUPDR |= ((GPIO_Config->GPIO_PUPD) << (pin * 2));
	}

}
 80004f2:	e07a      	b.n	80005ea <GPIO_Init+0x246>
		GPIO_Config->GPIO_Port->MODER &= ~(GPIO_Mode_Reset << (pin * 2));
 80004f4:	687b      	ldr	r3, [r7, #4]
 80004f6:	689b      	ldr	r3, [r3, #8]
 80004f8:	681a      	ldr	r2, [r3, #0]
 80004fa:	7bfb      	ldrb	r3, [r7, #15]
 80004fc:	005b      	lsls	r3, r3, #1
 80004fe:	2103      	movs	r1, #3
 8000500:	fa01 f303 	lsl.w	r3, r1, r3
 8000504:	43db      	mvns	r3, r3
 8000506:	4619      	mov	r1, r3
 8000508:	687b      	ldr	r3, [r7, #4]
 800050a:	689b      	ldr	r3, [r3, #8]
 800050c:	400a      	ands	r2, r1
 800050e:	601a      	str	r2, [r3, #0]
		GPIO_Config->GPIO_Port->MODER |= ((GPIO_Config->GPIO_MODE) << (pin * 2));
 8000510:	687b      	ldr	r3, [r7, #4]
 8000512:	689b      	ldr	r3, [r3, #8]
 8000514:	681a      	ldr	r2, [r3, #0]
 8000516:	687b      	ldr	r3, [r7, #4]
 8000518:	785b      	ldrb	r3, [r3, #1]
 800051a:	4619      	mov	r1, r3
 800051c:	7bfb      	ldrb	r3, [r7, #15]
 800051e:	005b      	lsls	r3, r3, #1
 8000520:	fa01 f303 	lsl.w	r3, r1, r3
 8000524:	4619      	mov	r1, r3
 8000526:	687b      	ldr	r3, [r7, #4]
 8000528:	689b      	ldr	r3, [r3, #8]
 800052a:	430a      	orrs	r2, r1
 800052c:	601a      	str	r2, [r3, #0]
		if(GPIO_Config->GPIO_MODE == GPIO_AF)
 800052e:	687b      	ldr	r3, [r7, #4]
 8000530:	785b      	ldrb	r3, [r3, #1]
 8000532:	2b02      	cmp	r3, #2
 8000534:	d104      	bne.n	8000540 <GPIO_Init+0x19c>
			GPIO_AlternateFunctionConfig(GPIO_Config, alt_function);
 8000536:	78fb      	ldrb	r3, [r7, #3]
 8000538:	4619      	mov	r1, r3
 800053a:	6878      	ldr	r0, [r7, #4]
 800053c:	f7ff fef2 	bl	8000324 <GPIO_AlternateFunctionConfig>
		GPIO_Config->GPIO_Port->OTYPER &= ~(GPIO_OType_Reset << pin);
 8000540:	687b      	ldr	r3, [r7, #4]
 8000542:	689b      	ldr	r3, [r3, #8]
 8000544:	685a      	ldr	r2, [r3, #4]
 8000546:	7bfb      	ldrb	r3, [r7, #15]
 8000548:	2101      	movs	r1, #1
 800054a:	fa01 f303 	lsl.w	r3, r1, r3
 800054e:	43db      	mvns	r3, r3
 8000550:	4619      	mov	r1, r3
 8000552:	687b      	ldr	r3, [r7, #4]
 8000554:	689b      	ldr	r3, [r3, #8]
 8000556:	400a      	ands	r2, r1
 8000558:	605a      	str	r2, [r3, #4]
		GPIO_Config->GPIO_Port->OTYPER |= ((GPIO_Config->GPIO_OTYPE) << pin);
 800055a:	687b      	ldr	r3, [r7, #4]
 800055c:	689b      	ldr	r3, [r3, #8]
 800055e:	685a      	ldr	r2, [r3, #4]
 8000560:	687b      	ldr	r3, [r7, #4]
 8000562:	789b      	ldrb	r3, [r3, #2]
 8000564:	4619      	mov	r1, r3
 8000566:	7bfb      	ldrb	r3, [r7, #15]
 8000568:	fa01 f303 	lsl.w	r3, r1, r3
 800056c:	4619      	mov	r1, r3
 800056e:	687b      	ldr	r3, [r7, #4]
 8000570:	689b      	ldr	r3, [r3, #8]
 8000572:	430a      	orrs	r2, r1
 8000574:	605a      	str	r2, [r3, #4]
		GPIO_Config->GPIO_Port->OSPEEDR &= ~(GPIO_OSpeed_Reset << (pin * 2));
 8000576:	687b      	ldr	r3, [r7, #4]
 8000578:	689b      	ldr	r3, [r3, #8]
 800057a:	689a      	ldr	r2, [r3, #8]
 800057c:	7bfb      	ldrb	r3, [r7, #15]
 800057e:	005b      	lsls	r3, r3, #1
 8000580:	2101      	movs	r1, #1
 8000582:	fa01 f303 	lsl.w	r3, r1, r3
 8000586:	43db      	mvns	r3, r3
 8000588:	4619      	mov	r1, r3
 800058a:	687b      	ldr	r3, [r7, #4]
 800058c:	689b      	ldr	r3, [r3, #8]
 800058e:	400a      	ands	r2, r1
 8000590:	609a      	str	r2, [r3, #8]
		GPIO_Config->GPIO_Port->OSPEEDR |= ((GPIO_Config->GPIO_OSPEED) << (pin * 2));
 8000592:	687b      	ldr	r3, [r7, #4]
 8000594:	689b      	ldr	r3, [r3, #8]
 8000596:	689a      	ldr	r2, [r3, #8]
 8000598:	687b      	ldr	r3, [r7, #4]
 800059a:	78db      	ldrb	r3, [r3, #3]
 800059c:	4619      	mov	r1, r3
 800059e:	7bfb      	ldrb	r3, [r7, #15]
 80005a0:	005b      	lsls	r3, r3, #1
 80005a2:	fa01 f303 	lsl.w	r3, r1, r3
 80005a6:	4619      	mov	r1, r3
 80005a8:	687b      	ldr	r3, [r7, #4]
 80005aa:	689b      	ldr	r3, [r3, #8]
 80005ac:	430a      	orrs	r2, r1
 80005ae:	609a      	str	r2, [r3, #8]
		GPIO_Config->GPIO_Port->PUPDR &= ~(GPIO_PUPD_Reset << (pin * 2));
 80005b0:	687b      	ldr	r3, [r7, #4]
 80005b2:	689b      	ldr	r3, [r3, #8]
 80005b4:	68da      	ldr	r2, [r3, #12]
 80005b6:	7bfb      	ldrb	r3, [r7, #15]
 80005b8:	005b      	lsls	r3, r3, #1
 80005ba:	2103      	movs	r1, #3
 80005bc:	fa01 f303 	lsl.w	r3, r1, r3
 80005c0:	43db      	mvns	r3, r3
 80005c2:	4619      	mov	r1, r3
 80005c4:	687b      	ldr	r3, [r7, #4]
 80005c6:	689b      	ldr	r3, [r3, #8]
 80005c8:	400a      	ands	r2, r1
 80005ca:	60da      	str	r2, [r3, #12]
		GPIO_Config->GPIO_Port->PUPDR |= ((GPIO_Config->GPIO_PUPD) << (pin * 2));
 80005cc:	687b      	ldr	r3, [r7, #4]
 80005ce:	689b      	ldr	r3, [r3, #8]
 80005d0:	68da      	ldr	r2, [r3, #12]
 80005d2:	687b      	ldr	r3, [r7, #4]
 80005d4:	791b      	ldrb	r3, [r3, #4]
 80005d6:	4619      	mov	r1, r3
 80005d8:	7bfb      	ldrb	r3, [r7, #15]
 80005da:	005b      	lsls	r3, r3, #1
 80005dc:	fa01 f303 	lsl.w	r3, r1, r3
 80005e0:	4619      	mov	r1, r3
 80005e2:	687b      	ldr	r3, [r7, #4]
 80005e4:	689b      	ldr	r3, [r3, #8]
 80005e6:	430a      	orrs	r2, r1
 80005e8:	60da      	str	r2, [r3, #12]
}
 80005ea:	bf00      	nop
 80005ec:	3710      	adds	r7, #16
 80005ee:	46bd      	mov	sp, r7
 80005f0:	bd80      	pop	{r7, pc}
 80005f2:	bf00      	nop
 80005f4:	40020000 	.word	0x40020000

080005f8 <Enable_I2C_Periph>:
 * @brief	A helper function used to set GPIO pins to correct settings to use I2C peripheral.
 *
 * @note	Sets the specified pins to alternate function, open drain, low speed and pull-up resistor.
 */
static void Enable_I2C_Periph(GPIO_TypeDef *GPIOx, uint8_t pin, AFR_Config_t alt_function)
{
 80005f8:	b580      	push	{r7, lr}
 80005fa:	b08a      	sub	sp, #40	; 0x28
 80005fc:	af04      	add	r7, sp, #16
 80005fe:	6078      	str	r0, [r7, #4]
 8000600:	460b      	mov	r3, r1
 8000602:	70fb      	strb	r3, [r7, #3]
 8000604:	4613      	mov	r3, r2
 8000606:	70bb      	strb	r3, [r7, #2]
	GPIO_Config_t I2C_Periph;
	GPIO_Config(&I2C_Periph, GPIOx, pin, GPIO_AF, GPIO_OpenDrain, GPIO_LowSpeed, GPIO_PullUp);
 8000608:	78fa      	ldrb	r2, [r7, #3]
 800060a:	f107 000c 	add.w	r0, r7, #12
 800060e:	2301      	movs	r3, #1
 8000610:	9302      	str	r3, [sp, #8]
 8000612:	2300      	movs	r3, #0
 8000614:	9301      	str	r3, [sp, #4]
 8000616:	2301      	movs	r3, #1
 8000618:	9300      	str	r3, [sp, #0]
 800061a:	2302      	movs	r3, #2
 800061c:	6879      	ldr	r1, [r7, #4]
 800061e:	f7ff fdd9 	bl	80001d4 <GPIO_Config>
	GPIO_Init(&I2C_Periph, alt_function);
 8000622:	78ba      	ldrb	r2, [r7, #2]
 8000624:	f107 030c 	add.w	r3, r7, #12
 8000628:	4611      	mov	r1, r2
 800062a:	4618      	mov	r0, r3
 800062c:	f7ff feba 	bl	80003a4 <GPIO_Init>
}
 8000630:	bf00      	nop
 8000632:	3718      	adds	r7, #24
 8000634:	46bd      	mov	sp, r7
 8000636:	bd80      	pop	{r7, pc}

08000638 <Generate_Start_Condition>:

/*
 * @brief	A helper function that generates the start condition.
 */
static void Generate_Start_Condition(I2C_Handle_t *I2C_Handle)
{
 8000638:	b480      	push	{r7}
 800063a:	b083      	sub	sp, #12
 800063c:	af00      	add	r7, sp, #0
 800063e:	6078      	str	r0, [r7, #4]
	I2C_Handle->I2Cx->CR1 |= CR1_Start;
 8000640:	687b      	ldr	r3, [r7, #4]
 8000642:	68db      	ldr	r3, [r3, #12]
 8000644:	681a      	ldr	r2, [r3, #0]
 8000646:	687b      	ldr	r3, [r7, #4]
 8000648:	68db      	ldr	r3, [r3, #12]
 800064a:	f442 7280 	orr.w	r2, r2, #256	; 0x100
 800064e:	601a      	str	r2, [r3, #0]
}
 8000650:	bf00      	nop
 8000652:	370c      	adds	r7, #12
 8000654:	46bd      	mov	sp, r7
 8000656:	f85d 7b04 	ldr.w	r7, [sp], #4
 800065a:	4770      	bx	lr

0800065c <Check_Flag>:
 * brief	A helper function that keeps track of specific flags in the status register.
 *
 * @retval	Returns status of the flag which is defined in an enumeration.
 */
static Flag_Status Check_Flag(I2C_Handle_t *I2C_Handle, uint32_t flag)
{
 800065c:	b480      	push	{r7}
 800065e:	b083      	sub	sp, #12
 8000660:	af00      	add	r7, sp, #0
 8000662:	6078      	str	r0, [r7, #4]
 8000664:	6039      	str	r1, [r7, #0]
	if(I2C_Handle->I2Cx->SR1 & flag)
 8000666:	687b      	ldr	r3, [r7, #4]
 8000668:	68db      	ldr	r3, [r3, #12]
 800066a:	695a      	ldr	r2, [r3, #20]
 800066c:	683b      	ldr	r3, [r7, #0]
 800066e:	4013      	ands	r3, r2
 8000670:	2b00      	cmp	r3, #0
 8000672:	d001      	beq.n	8000678 <Check_Flag+0x1c>
	{
		return Flag_Set;
 8000674:	2301      	movs	r3, #1
 8000676:	e000      	b.n	800067a <Check_Flag+0x1e>
	}

	else
	{
		return Flag_Unset;
 8000678:	2300      	movs	r3, #0
	}

}
 800067a:	4618      	mov	r0, r3
 800067c:	370c      	adds	r7, #12
 800067e:	46bd      	mov	sp, r7
 8000680:	f85d 7b04 	ldr.w	r7, [sp], #4
 8000684:	4770      	bx	lr

08000686 <Generate_Stop_Condition>:

/*
 * brief	A helper function that generates a stop condition
 */
static void Generate_Stop_Condition(I2C_Handle_t *I2C_Handle)
{
 8000686:	b480      	push	{r7}
 8000688:	b083      	sub	sp, #12
 800068a:	af00      	add	r7, sp, #0
 800068c:	6078      	str	r0, [r7, #4]
	I2C_Handle->I2Cx->CR1 |= CR1_STOP;
 800068e:	687b      	ldr	r3, [r7, #4]
 8000690:	68db      	ldr	r3, [r3, #12]
 8000692:	681a      	ldr	r2, [r3, #0]
 8000694:	687b      	ldr	r3, [r7, #4]
 8000696:	68db      	ldr	r3, [r3, #12]
 8000698:	f442 7200 	orr.w	r2, r2, #512	; 0x200
 800069c:	601a      	str	r2, [r3, #0]
}
 800069e:	bf00      	nop
 80006a0:	370c      	adds	r7, #12
 80006a2:	46bd      	mov	sp, r7
 80006a4:	f85d 7b04 	ldr.w	r7, [sp], #4
 80006a8:	4770      	bx	lr

080006aa <Send_Slave_Address>:

/*
 * @brief	A helper function used to send the slave address with either a read or write in the LSB.
 */
static void Send_Slave_Address(I2C_Handle_t *I2C_Handle)
{
 80006aa:	b480      	push	{r7}
 80006ac:	b085      	sub	sp, #20
 80006ae:	af00      	add	r7, sp, #0
 80006b0:	6078      	str	r0, [r7, #4]
	uint8_t slave_address = I2C_Handle->slave_address;
 80006b2:	687b      	ldr	r3, [r7, #4]
 80006b4:	7f1b      	ldrb	r3, [r3, #28]
 80006b6:	73fb      	strb	r3, [r7, #15]

	//Determine whether read or write mode is active first
	if(I2C_Handle->I2C_Bus_Direction == I2C_Recieve)
 80006b8:	687b      	ldr	r3, [r7, #4]
 80006ba:	7f5b      	ldrb	r3, [r3, #29]
 80006bc:	2b02      	cmp	r3, #2
 80006be:	d10a      	bne.n	80006d6 <Send_Slave_Address+0x2c>
	{
		//If the user wishes to read data, append a 1 to the end of the address
		slave_address = ((slave_address << 1) | (I2C_Read << 0U));
 80006c0:	7bfb      	ldrb	r3, [r7, #15]
 80006c2:	005b      	lsls	r3, r3, #1
 80006c4:	b2db      	uxtb	r3, r3
 80006c6:	f043 0301 	orr.w	r3, r3, #1
 80006ca:	73fb      	strb	r3, [r7, #15]
		I2C_Handle->I2Cx->DR = slave_address;
 80006cc:	687b      	ldr	r3, [r7, #4]
 80006ce:	68db      	ldr	r3, [r3, #12]
 80006d0:	7bfa      	ldrb	r2, [r7, #15]
 80006d2:	611a      	str	r2, [r3, #16]
		//If the user wishes to write data append a 0 to the end of the address
		slave_address = ((slave_address << 1) | (I2C_Write << 0U));
		I2C_Handle->I2Cx->DR = slave_address;
	}

}
 80006d4:	e006      	b.n	80006e4 <Send_Slave_Address+0x3a>
		slave_address = ((slave_address << 1) | (I2C_Write << 0U));
 80006d6:	7bfb      	ldrb	r3, [r7, #15]
 80006d8:	005b      	lsls	r3, r3, #1
 80006da:	73fb      	strb	r3, [r7, #15]
		I2C_Handle->I2Cx->DR = slave_address;
 80006dc:	687b      	ldr	r3, [r7, #4]
 80006de:	68db      	ldr	r3, [r3, #12]
 80006e0:	7bfa      	ldrb	r2, [r7, #15]
 80006e2:	611a      	str	r2, [r3, #16]
}
 80006e4:	bf00      	nop
 80006e6:	3714      	adds	r7, #20
 80006e8:	46bd      	mov	sp, r7
 80006ea:	f85d 7b04 	ldr.w	r7, [sp], #4
 80006ee:	4770      	bx	lr

080006f0 <Clear_Addr_Flag>:
 *
 * @note	If the I2C peripheral is in receiver mode and is set to only recieve 1 byte, the ACK
 * 			bit will be disabled before clearning addr flag.
 */
static void Clear_Addr_Flag(I2C_Handle_t *I2C_Handle)
{
 80006f0:	b480      	push	{r7}
 80006f2:	b085      	sub	sp, #20
 80006f4:	af00      	add	r7, sp, #0
 80006f6:	6078      	str	r0, [r7, #4]
	uint32_t temporary_variable = 0;
 80006f8:	2300      	movs	r3, #0
 80006fa:	60fb      	str	r3, [r7, #12]

	if((I2C_Handle->I2C_Bus_Direction == I2C_Recieve) && (I2C_Handle->Rx_Length == 1))
 80006fc:	687b      	ldr	r3, [r7, #4]
 80006fe:	7f5b      	ldrb	r3, [r3, #29]
 8000700:	2b02      	cmp	r3, #2
 8000702:	d114      	bne.n	800072e <Clear_Addr_Flag+0x3e>
 8000704:	687b      	ldr	r3, [r7, #4]
 8000706:	7c5b      	ldrb	r3, [r3, #17]
 8000708:	2b01      	cmp	r3, #1
 800070a:	d110      	bne.n	800072e <Clear_Addr_Flag+0x3e>
	{
		//Disable the Ack
		I2C_Handle->I2Cx->CR1 &= ~(CR1_ACK_Enable);
 800070c:	687b      	ldr	r3, [r7, #4]
 800070e:	68db      	ldr	r3, [r3, #12]
 8000710:	681a      	ldr	r2, [r3, #0]
 8000712:	687b      	ldr	r3, [r7, #4]
 8000714:	68db      	ldr	r3, [r3, #12]
 8000716:	f422 6280 	bic.w	r2, r2, #1024	; 0x400
 800071a:	601a      	str	r2, [r3, #0]

		//Clear addr flag
		temporary_variable = I2C_Handle->I2Cx->SR1;
 800071c:	687b      	ldr	r3, [r7, #4]
 800071e:	68db      	ldr	r3, [r3, #12]
 8000720:	695b      	ldr	r3, [r3, #20]
 8000722:	60fb      	str	r3, [r7, #12]
		temporary_variable = I2C_Handle->I2Cx->SR2;
 8000724:	687b      	ldr	r3, [r7, #4]
 8000726:	68db      	ldr	r3, [r3, #12]
 8000728:	699b      	ldr	r3, [r3, #24]
 800072a:	60fb      	str	r3, [r7, #12]
 800072c:	e008      	b.n	8000740 <Clear_Addr_Flag+0x50>
	}

	else
	{
		//Clear the addr flag
		temporary_variable = I2C_Handle->I2Cx->SR1;
 800072e:	687b      	ldr	r3, [r7, #4]
 8000730:	68db      	ldr	r3, [r3, #12]
 8000732:	695b      	ldr	r3, [r3, #20]
 8000734:	60fb      	str	r3, [r7, #12]
		temporary_variable = I2C_Handle->I2Cx->SR2;
 8000736:	687b      	ldr	r3, [r7, #4]
 8000738:	68db      	ldr	r3, [r3, #12]
 800073a:	699b      	ldr	r3, [r3, #24]
 800073c:	60fb      	str	r3, [r7, #12]
	}


}
 800073e:	bf00      	nop
 8000740:	bf00      	nop
 8000742:	3714      	adds	r7, #20
 8000744:	46bd      	mov	sp, r7
 8000746:	f85d 7b04 	ldr.w	r7, [sp], #4
 800074a:	4770      	bx	lr

0800074c <I2C_Config>:
 * @brief	Configures the I2C data structure with user input.
 *
 * @note	If I2C2 or I2C3 is specified, pin_scl and pin_sda parameters are not used.
 */
void I2C_Config(I2C_Handle_t *I2C_Handle, I2C_TypeDef *I2Cx, uint32_t scl_speed, uint8_t duty_cycle, uint8_t pin_scl, uint8_t pin_sda)
{
 800074c:	b480      	push	{r7}
 800074e:	b085      	sub	sp, #20
 8000750:	af00      	add	r7, sp, #0
 8000752:	60f8      	str	r0, [r7, #12]
 8000754:	60b9      	str	r1, [r7, #8]
 8000756:	607a      	str	r2, [r7, #4]
 8000758:	70fb      	strb	r3, [r7, #3]
	I2C_Handle->I2Cx = I2Cx;
 800075a:	68fb      	ldr	r3, [r7, #12]
 800075c:	68ba      	ldr	r2, [r7, #8]
 800075e:	60da      	str	r2, [r3, #12]
	I2C_Handle->I2C_Config.scl_speed = scl_speed;
 8000760:	68fb      	ldr	r3, [r7, #12]
 8000762:	687a      	ldr	r2, [r7, #4]
 8000764:	605a      	str	r2, [r3, #4]
	I2C_Handle->I2C_Config.fm_dutycycle = duty_cycle;
 8000766:	68fb      	ldr	r3, [r7, #12]
 8000768:	78fa      	ldrb	r2, [r7, #3]
 800076a:	721a      	strb	r2, [r3, #8]
	I2C_Handle->I2C_Config.pin_scl = pin_scl;
 800076c:	68fb      	ldr	r3, [r7, #12]
 800076e:	7e3a      	ldrb	r2, [r7, #24]
 8000770:	725a      	strb	r2, [r3, #9]
	I2C_Handle->I2C_Config.pin_sda = pin_sda;
 8000772:	68fb      	ldr	r3, [r7, #12]
 8000774:	7f3a      	ldrb	r2, [r7, #28]
 8000776:	729a      	strb	r2, [r3, #10]
}
 8000778:	bf00      	nop
 800077a:	3714      	adds	r7, #20
 800077c:	46bd      	mov	sp, r7
 800077e:	f85d 7b04 	ldr.w	r7, [sp], #4
 8000782:	4770      	bx	lr

08000784 <I2C_DeInit>:

/*
 * @brief	Deinitializes the I2C by turning off the I2C access at the APB1ENR.
 */
void I2C_DeInit(I2C_Handle_t *I2C_Handle)
{
 8000784:	b480      	push	{r7}
 8000786:	b083      	sub	sp, #12
 8000788:	af00      	add	r7, sp, #0
 800078a:	6078      	str	r0, [r7, #4]
	if(I2C_Handle->I2Cx == I2C1)
 800078c:	687b      	ldr	r3, [r7, #4]
 800078e:	68db      	ldr	r3, [r3, #12]
 8000790:	4a10      	ldr	r2, [pc, #64]	; (80007d4 <I2C_DeInit+0x50>)
 8000792:	4293      	cmp	r3, r2
 8000794:	d106      	bne.n	80007a4 <I2C_DeInit+0x20>
	{
		RCC->APB1ENR &= ~I2C1EN;
 8000796:	4b10      	ldr	r3, [pc, #64]	; (80007d8 <I2C_DeInit+0x54>)
 8000798:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 800079a:	4a0f      	ldr	r2, [pc, #60]	; (80007d8 <I2C_DeInit+0x54>)
 800079c:	f423 1300 	bic.w	r3, r3, #2097152	; 0x200000
 80007a0:	6413      	str	r3, [r2, #64]	; 0x40

	else
	{
		RCC->APB1ENR &= ~I2C3EN;
	}
}
 80007a2:	e011      	b.n	80007c8 <I2C_DeInit+0x44>
	else if(I2C_Handle->I2Cx == I2C2)
 80007a4:	687b      	ldr	r3, [r7, #4]
 80007a6:	68db      	ldr	r3, [r3, #12]
 80007a8:	4a0c      	ldr	r2, [pc, #48]	; (80007dc <I2C_DeInit+0x58>)
 80007aa:	4293      	cmp	r3, r2
 80007ac:	d106      	bne.n	80007bc <I2C_DeInit+0x38>
		RCC->APB1ENR &= ~I2C2EN;
 80007ae:	4b0a      	ldr	r3, [pc, #40]	; (80007d8 <I2C_DeInit+0x54>)
 80007b0:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 80007b2:	4a09      	ldr	r2, [pc, #36]	; (80007d8 <I2C_DeInit+0x54>)
 80007b4:	f423 0380 	bic.w	r3, r3, #4194304	; 0x400000
 80007b8:	6413      	str	r3, [r2, #64]	; 0x40
}
 80007ba:	e005      	b.n	80007c8 <I2C_DeInit+0x44>
		RCC->APB1ENR &= ~I2C3EN;
 80007bc:	4b06      	ldr	r3, [pc, #24]	; (80007d8 <I2C_DeInit+0x54>)
 80007be:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 80007c0:	4a05      	ldr	r2, [pc, #20]	; (80007d8 <I2C_DeInit+0x54>)
 80007c2:	f423 0300 	bic.w	r3, r3, #8388608	; 0x800000
 80007c6:	6413      	str	r3, [r2, #64]	; 0x40
}
 80007c8:	bf00      	nop
 80007ca:	370c      	adds	r7, #12
 80007cc:	46bd      	mov	sp, r7
 80007ce:	f85d 7b04 	ldr.w	r7, [sp], #4
 80007d2:	4770      	bx	lr
 80007d4:	40005400 	.word	0x40005400
 80007d8:	40023800 	.word	0x40023800
 80007dc:	40005800 	.word	0x40005800

080007e0 <I2C_Init>:
 *
 * @note	For standard mode F(scl) is 1000000 and for fast mode F(scl) is 3333333. These values are defined in
 * 			the header file as MAX_SM_TRISE_FREQ and MAX_FM_TRISE_FREQ.
 */
void I2C_Init(I2C_Handle_t *I2C_Handle)
{
 80007e0:	b580      	push	{r7, lr}
 80007e2:	b088      	sub	sp, #32
 80007e4:	af00      	add	r7, sp, #0
 80007e6:	6078      	str	r0, [r7, #4]
	RCC_ClockFrequency_t ClockSource;

	uint16_t ccr_value;
	uint8_t trise_value;

	if(I2C_Handle->I2Cx == I2C1)
 80007e8:	687b      	ldr	r3, [r7, #4]
 80007ea:	68db      	ldr	r3, [r3, #12]
 80007ec:	4a69      	ldr	r2, [pc, #420]	; (8000994 <I2C_Init+0x1b4>)
 80007ee:	4293      	cmp	r3, r2
 80007f0:	d113      	bne.n	800081a <I2C_Init+0x3a>
	{
		//Enable I2C1_SDA Line
		Enable_I2C_Periph(GPIOB, (I2C_Handle->I2C_Config.pin_sda), AF4);
 80007f2:	687b      	ldr	r3, [r7, #4]
 80007f4:	7a9b      	ldrb	r3, [r3, #10]
 80007f6:	2204      	movs	r2, #4
 80007f8:	4619      	mov	r1, r3
 80007fa:	4867      	ldr	r0, [pc, #412]	; (8000998 <I2C_Init+0x1b8>)
 80007fc:	f7ff fefc 	bl	80005f8 <Enable_I2C_Periph>
		//Enable I2C1_SCL Line
		Enable_I2C_Periph(GPIOB, (I2C_Handle->I2C_Config.pin_scl), AF4);
 8000800:	687b      	ldr	r3, [r7, #4]
 8000802:	7a5b      	ldrb	r3, [r3, #9]
 8000804:	2204      	movs	r2, #4
 8000806:	4619      	mov	r1, r3
 8000808:	4863      	ldr	r0, [pc, #396]	; (8000998 <I2C_Init+0x1b8>)
 800080a:	f7ff fef5 	bl	80005f8 <Enable_I2C_Periph>
		//Enable Clock Access to I2C1
		RCC_APB1Cmd(I2C1_Enable, ENABLE);
 800080e:	2101      	movs	r1, #1
 8000810:	f44f 1000 	mov.w	r0, #2097152	; 0x200000
 8000814:	f000 f9d6 	bl	8000bc4 <RCC_APB1Cmd>
 8000818:	e023      	b.n	8000862 <I2C_Init+0x82>
	}

	else if(I2C_Handle->I2Cx == I2C2)
 800081a:	687b      	ldr	r3, [r7, #4]
 800081c:	68db      	ldr	r3, [r3, #12]
 800081e:	4a5f      	ldr	r2, [pc, #380]	; (800099c <I2C_Init+0x1bc>)
 8000820:	4293      	cmp	r3, r2
 8000822:	d10f      	bne.n	8000844 <I2C_Init+0x64>
	{
		//Enable I2C2_SCL Line for PB10
		Enable_I2C_Periph(GPIOB, 10, AF4);
 8000824:	2204      	movs	r2, #4
 8000826:	210a      	movs	r1, #10
 8000828:	485b      	ldr	r0, [pc, #364]	; (8000998 <I2C_Init+0x1b8>)
 800082a:	f7ff fee5 	bl	80005f8 <Enable_I2C_Periph>
		//Enable I2C2_SDA Line for PB3
		Enable_I2C_Periph(GPIOB, 3, AF9);
 800082e:	2209      	movs	r2, #9
 8000830:	2103      	movs	r1, #3
 8000832:	4859      	ldr	r0, [pc, #356]	; (8000998 <I2C_Init+0x1b8>)
 8000834:	f7ff fee0 	bl	80005f8 <Enable_I2C_Periph>
		//Enable Clock Access to I2C2
		RCC_APB1Cmd(I2C2_Enable, ENABLE);
 8000838:	2101      	movs	r1, #1
 800083a:	f44f 0080 	mov.w	r0, #4194304	; 0x400000
 800083e:	f000 f9c1 	bl	8000bc4 <RCC_APB1Cmd>
 8000842:	e00e      	b.n	8000862 <I2C_Init+0x82>
	}

	else
	{
		//Enable I2C3_SCL Line for PA8
		Enable_I2C_Periph(GPIOA, 3, AF4);
 8000844:	2204      	movs	r2, #4
 8000846:	2103      	movs	r1, #3
 8000848:	4855      	ldr	r0, [pc, #340]	; (80009a0 <I2C_Init+0x1c0>)
 800084a:	f7ff fed5 	bl	80005f8 <Enable_I2C_Periph>
		//Enable I2C3_SDA Line for PC9
		Enable_I2C_Periph(GPIOC, 9, AF9);
 800084e:	2209      	movs	r2, #9
 8000850:	2109      	movs	r1, #9
 8000852:	4854      	ldr	r0, [pc, #336]	; (80009a4 <I2C_Init+0x1c4>)
 8000854:	f7ff fed0 	bl	80005f8 <Enable_I2C_Periph>
		//Enable Clock Access to I2C3
		RCC_APB1Cmd(I2C3_Enable, ENABLE);
 8000858:	2101      	movs	r1, #1
 800085a:	f44f 0000 	mov.w	r0, #8388608	; 0x800000
 800085e:	f000 f9b1 	bl	8000bc4 <RCC_APB1Cmd>

	//I2C_Handle->I2Cx->CR1 |= CR1_SWRST;
	//I2C_Handle->I2Cx->CR1 &= ~CR1_SWRST;

	//Determining Peripheral Clock Speed
	RCC_GetClockFreq(&ClockSource);
 8000862:	f107 030c 	add.w	r3, r7, #12
 8000866:	4618      	mov	r0, r3
 8000868:	f000 f9ec 	bl	8000c44 <RCC_GetClockFreq>
	I2C_Handle->I2C_Config.peripheral_clk = (ClockSource.PCLCK1)/1000000U & (0x3F);
 800086c:	697b      	ldr	r3, [r7, #20]
 800086e:	4a4e      	ldr	r2, [pc, #312]	; (80009a8 <I2C_Init+0x1c8>)
 8000870:	fba2 2303 	umull	r2, r3, r2, r3
 8000874:	0c9b      	lsrs	r3, r3, #18
 8000876:	b2db      	uxtb	r3, r3
 8000878:	f003 033f 	and.w	r3, r3, #63	; 0x3f
 800087c:	b2da      	uxtb	r2, r3
 800087e:	687b      	ldr	r3, [r7, #4]
 8000880:	701a      	strb	r2, [r3, #0]
	I2C_Handle->I2Cx->CR2 |= (I2C_Handle->I2C_Config.peripheral_clk) << CR2_Freq_Pos;
 8000882:	687b      	ldr	r3, [r7, #4]
 8000884:	68db      	ldr	r3, [r3, #12]
 8000886:	685a      	ldr	r2, [r3, #4]
 8000888:	687b      	ldr	r3, [r7, #4]
 800088a:	781b      	ldrb	r3, [r3, #0]
 800088c:	4619      	mov	r1, r3
 800088e:	687b      	ldr	r3, [r7, #4]
 8000890:	68db      	ldr	r3, [r3, #12]
 8000892:	430a      	orrs	r2, r1
 8000894:	605a      	str	r2, [r3, #4]

	//CCR Calculations:

	//Check for standard mode
	if(I2C_Handle->I2C_Config.scl_speed <= SM_100KHZ)
 8000896:	687b      	ldr	r3, [r7, #4]
 8000898:	685b      	ldr	r3, [r3, #4]
 800089a:	4a44      	ldr	r2, [pc, #272]	; (80009ac <I2C_Init+0x1cc>)
 800089c:	4293      	cmp	r3, r2
 800089e:	d817      	bhi.n	80008d0 <I2C_Init+0xf0>
	{
		//Clear the fast mode bit ensuring it is set to 0 (set to standard mode)
		I2C_Handle->I2Cx->CCR &= ~CCR_Speed_FM_Mode;
 80008a0:	687b      	ldr	r3, [r7, #4]
 80008a2:	68db      	ldr	r3, [r3, #12]
 80008a4:	69da      	ldr	r2, [r3, #28]
 80008a6:	687b      	ldr	r3, [r7, #4]
 80008a8:	68db      	ldr	r3, [r3, #12]
 80008aa:	f422 4200 	bic.w	r2, r2, #32768	; 0x8000
 80008ae:	61da      	str	r2, [r3, #28]
		//In standard mode, the duty cycle is 50%
		ccr_value = (ClockSource.PCLCK1)/(2 * (I2C_Handle->I2C_Config.scl_speed));
 80008b0:	697a      	ldr	r2, [r7, #20]
 80008b2:	687b      	ldr	r3, [r7, #4]
 80008b4:	685b      	ldr	r3, [r3, #4]
 80008b6:	005b      	lsls	r3, r3, #1
 80008b8:	fbb2 f3f3 	udiv	r3, r2, r3
 80008bc:	83fb      	strh	r3, [r7, #30]

		//calculate the Trise value
		trise_value = ((ClockSource.PCLCK1)/(MAX_SM_TRISE_FREQ)) + 1;
 80008be:	697b      	ldr	r3, [r7, #20]
 80008c0:	4a39      	ldr	r2, [pc, #228]	; (80009a8 <I2C_Init+0x1c8>)
 80008c2:	fba2 2303 	umull	r2, r3, r2, r3
 80008c6:	0c9b      	lsrs	r3, r3, #18
 80008c8:	b2db      	uxtb	r3, r3
 80008ca:	3301      	adds	r3, #1
 80008cc:	777b      	strb	r3, [r7, #29]
 80008ce:	e044      	b.n	800095a <I2C_Init+0x17a>

	//Check for fast mode
	else
	{
		//Set I2C to fast mode
		I2C_Handle->I2Cx->CCR |= CCR_Speed_FM_Mode;
 80008d0:	687b      	ldr	r3, [r7, #4]
 80008d2:	68db      	ldr	r3, [r3, #12]
 80008d4:	69da      	ldr	r2, [r3, #28]
 80008d6:	687b      	ldr	r3, [r7, #4]
 80008d8:	68db      	ldr	r3, [r3, #12]
 80008da:	f442 4200 	orr.w	r2, r2, #32768	; 0x8000
 80008de:	61da      	str	r2, [r3, #28]

		if(I2C_Handle->I2C_Config.fm_dutycycle == FM_DUTY_2)
 80008e0:	687b      	ldr	r3, [r7, #4]
 80008e2:	7a1b      	ldrb	r3, [r3, #8]
 80008e4:	2b00      	cmp	r3, #0
 80008e6:	d116      	bne.n	8000916 <I2C_Init+0x136>
		{
			//Clear the Duty cycle bit so it is set to 0 (which means duty cycle of 2)
			I2C_Handle->I2Cx->CCR &= ~FM_DUTY_16_9;
 80008e8:	687b      	ldr	r3, [r7, #4]
 80008ea:	68db      	ldr	r3, [r3, #12]
 80008ec:	69da      	ldr	r2, [r3, #28]
 80008ee:	687b      	ldr	r3, [r7, #4]
 80008f0:	68db      	ldr	r3, [r3, #12]
 80008f2:	f422 4280 	bic.w	r2, r2, #16384	; 0x4000
 80008f6:	61da      	str	r2, [r3, #28]
			ccr_value = ((I2C_Handle->I2C_Config.peripheral_clk)/(3 * I2C_Handle->I2C_Config.scl_speed)) & (0xFFF);
 80008f8:	687b      	ldr	r3, [r7, #4]
 80008fa:	781b      	ldrb	r3, [r3, #0]
 80008fc:	4619      	mov	r1, r3
 80008fe:	687b      	ldr	r3, [r7, #4]
 8000900:	685a      	ldr	r2, [r3, #4]
 8000902:	4613      	mov	r3, r2
 8000904:	005b      	lsls	r3, r3, #1
 8000906:	4413      	add	r3, r2
 8000908:	fbb1 f3f3 	udiv	r3, r1, r3
 800090c:	b29b      	uxth	r3, r3
 800090e:	f3c3 030b 	ubfx	r3, r3, #0, #12
 8000912:	83fb      	strh	r3, [r7, #30]
 8000914:	e017      	b.n	8000946 <I2C_Init+0x166>
		}

		else
		{
			//Set duty cycle and calculate CCR value
			I2C_Handle->I2Cx->CCR |= FM_DUTY_16_9;
 8000916:	687b      	ldr	r3, [r7, #4]
 8000918:	68db      	ldr	r3, [r3, #12]
 800091a:	69da      	ldr	r2, [r3, #28]
 800091c:	687b      	ldr	r3, [r7, #4]
 800091e:	68db      	ldr	r3, [r3, #12]
 8000920:	f442 4280 	orr.w	r2, r2, #16384	; 0x4000
 8000924:	61da      	str	r2, [r3, #28]
			ccr_value = ((I2C_Handle->I2C_Config.peripheral_clk)/(25 * I2C_Handle->I2C_Config.scl_speed)) & (0xFFF);
 8000926:	687b      	ldr	r3, [r7, #4]
 8000928:	781b      	ldrb	r3, [r3, #0]
 800092a:	4619      	mov	r1, r3
 800092c:	687b      	ldr	r3, [r7, #4]
 800092e:	685a      	ldr	r2, [r3, #4]
 8000930:	4613      	mov	r3, r2
 8000932:	009b      	lsls	r3, r3, #2
 8000934:	4413      	add	r3, r2
 8000936:	009a      	lsls	r2, r3, #2
 8000938:	4413      	add	r3, r2
 800093a:	fbb1 f3f3 	udiv	r3, r1, r3
 800093e:	b29b      	uxth	r3, r3
 8000940:	f3c3 030b 	ubfx	r3, r3, #0, #12
 8000944:	83fb      	strh	r3, [r7, #30]
		}

		//calculate the Trise value
		trise_value = ((I2C_Handle->I2C_Config.peripheral_clk)/(MAX_FM_TRISE_FREQ)) + 1;
 8000946:	687b      	ldr	r3, [r7, #4]
 8000948:	781b      	ldrb	r3, [r3, #0]
 800094a:	461a      	mov	r2, r3
 800094c:	4b18      	ldr	r3, [pc, #96]	; (80009b0 <I2C_Init+0x1d0>)
 800094e:	fba3 2302 	umull	r2, r3, r3, r2
 8000952:	0d5b      	lsrs	r3, r3, #21
 8000954:	b2db      	uxtb	r3, r3
 8000956:	3301      	adds	r3, #1
 8000958:	777b      	strb	r3, [r7, #29]

	}

	//Set CCR and Trise register values
	I2C_Handle->I2Cx->CCR |= (ccr_value & 0xFFF) << CCR_CCR_Pos;
 800095a:	687b      	ldr	r3, [r7, #4]
 800095c:	68db      	ldr	r3, [r3, #12]
 800095e:	69d9      	ldr	r1, [r3, #28]
 8000960:	8bfb      	ldrh	r3, [r7, #30]
 8000962:	f3c3 020b 	ubfx	r2, r3, #0, #12
 8000966:	687b      	ldr	r3, [r7, #4]
 8000968:	68db      	ldr	r3, [r3, #12]
 800096a:	430a      	orrs	r2, r1
 800096c:	61da      	str	r2, [r3, #28]
	I2C_Handle->I2Cx->TRISE = (trise_value & 0x1F);
 800096e:	7f7a      	ldrb	r2, [r7, #29]
 8000970:	687b      	ldr	r3, [r7, #4]
 8000972:	68db      	ldr	r3, [r3, #12]
 8000974:	f002 021f 	and.w	r2, r2, #31
 8000978:	621a      	str	r2, [r3, #32]


	//Enable Peripheral
	I2C_Handle->I2Cx->CR1 |= CR1_PE_Enable;
 800097a:	687b      	ldr	r3, [r7, #4]
 800097c:	68db      	ldr	r3, [r3, #12]
 800097e:	681a      	ldr	r2, [r3, #0]
 8000980:	687b      	ldr	r3, [r7, #4]
 8000982:	68db      	ldr	r3, [r3, #12]
 8000984:	f042 0201 	orr.w	r2, r2, #1
 8000988:	601a      	str	r2, [r3, #0]
}
 800098a:	bf00      	nop
 800098c:	3720      	adds	r7, #32
 800098e:	46bd      	mov	sp, r7
 8000990:	bd80      	pop	{r7, pc}
 8000992:	bf00      	nop
 8000994:	40005400 	.word	0x40005400
 8000998:	40020400 	.word	0x40020400
 800099c:	40005800 	.word	0x40005800
 80009a0:	40020000 	.word	0x40020000
 80009a4:	40020800 	.word	0x40020800
 80009a8:	431bde83 	.word	0x431bde83
 80009ac:	000186a0 	.word	0x000186a0
 80009b0:	a10fb0af 	.word	0xa10fb0af

080009b4 <I2C_MasterTransmit>:
 *
 * @param 	restart_condition: This will be used to impact whether or not the master releases the SDA or SCL line
 * 			by sending a stop condition.
 */
void I2C_MasterTransmit(I2C_Handle_t *I2C_Handle, uint8_t *TxData, uint8_t slave_address, uint8_t number_of_bytes, uint8_t restart_condition)
{
 80009b4:	b580      	push	{r7, lr}
 80009b6:	b084      	sub	sp, #16
 80009b8:	af00      	add	r7, sp, #0
 80009ba:	60f8      	str	r0, [r7, #12]
 80009bc:	60b9      	str	r1, [r7, #8]
 80009be:	4611      	mov	r1, r2
 80009c0:	461a      	mov	r2, r3
 80009c2:	460b      	mov	r3, r1
 80009c4:	71fb      	strb	r3, [r7, #7]
 80009c6:	4613      	mov	r3, r2
 80009c8:	71bb      	strb	r3, [r7, #6]
	I2C_Handle->I2C_Bus_Direction = I2C_Transmit;
 80009ca:	68fb      	ldr	r3, [r7, #12]
 80009cc:	2201      	movs	r2, #1
 80009ce:	775a      	strb	r2, [r3, #29]
	I2C_Handle->slave_address = slave_address;
 80009d0:	68fb      	ldr	r3, [r7, #12]
 80009d2:	79fa      	ldrb	r2, [r7, #7]
 80009d4:	771a      	strb	r2, [r3, #28]

	//Enable the ACK bit
	I2C_Handle->I2Cx->CR1 |= CR1_ACK_Enable;
 80009d6:	68fb      	ldr	r3, [r7, #12]
 80009d8:	68db      	ldr	r3, [r3, #12]
 80009da:	681a      	ldr	r2, [r3, #0]
 80009dc:	68fb      	ldr	r3, [r7, #12]
 80009de:	68db      	ldr	r3, [r3, #12]
 80009e0:	f442 6280 	orr.w	r2, r2, #1024	; 0x400
 80009e4:	601a      	str	r2, [r3, #0]

	//Generate start condition
	Generate_Start_Condition(I2C_Handle);
 80009e6:	68f8      	ldr	r0, [r7, #12]
 80009e8:	f7ff fe26 	bl	8000638 <Generate_Start_Condition>
	//Ensure the SB flag is set indictaing start condition was generated
	while(!(Check_Flag(I2C_Handle, SR1_SB_Flag)));
 80009ec:	bf00      	nop
 80009ee:	2101      	movs	r1, #1
 80009f0:	68f8      	ldr	r0, [r7, #12]
 80009f2:	f7ff fe33 	bl	800065c <Check_Flag>
 80009f6:	4603      	mov	r3, r0
 80009f8:	2b00      	cmp	r3, #0
 80009fa:	d0f8      	beq.n	80009ee <I2C_MasterTransmit+0x3a>

	//Send slave address
	Send_Slave_Address(I2C_Handle);
 80009fc:	68f8      	ldr	r0, [r7, #12]
 80009fe:	f7ff fe54 	bl	80006aa <Send_Slave_Address>
	//Ensure the addr flag has been set indicating the end of address transmission
	while(!(Check_Flag(I2C_Handle, SR1_ADDR_Flag)));
 8000a02:	bf00      	nop
 8000a04:	2102      	movs	r1, #2
 8000a06:	68f8      	ldr	r0, [r7, #12]
 8000a08:	f7ff fe28 	bl	800065c <Check_Flag>
 8000a0c:	4603      	mov	r3, r0
 8000a0e:	2b00      	cmp	r3, #0
 8000a10:	d0f8      	beq.n	8000a04 <I2C_MasterTransmit+0x50>

	//Clear the address flag
	Clear_Addr_Flag(I2C_Handle);
 8000a12:	68f8      	ldr	r0, [r7, #12]
 8000a14:	f7ff fe6c 	bl	80006f0 <Clear_Addr_Flag>

	while(number_of_bytes > 0)
 8000a18:	e012      	b.n	8000a40 <I2C_MasterTransmit+0x8c>
	{
		while(!(Check_Flag(I2C_Handle, SR1_TXE_Flag)));
 8000a1a:	bf00      	nop
 8000a1c:	2180      	movs	r1, #128	; 0x80
 8000a1e:	68f8      	ldr	r0, [r7, #12]
 8000a20:	f7ff fe1c 	bl	800065c <Check_Flag>
 8000a24:	4603      	mov	r3, r0
 8000a26:	2b00      	cmp	r3, #0
 8000a28:	d0f8      	beq.n	8000a1c <I2C_MasterTransmit+0x68>

		I2C_Handle->I2Cx->DR = *TxData;
 8000a2a:	68bb      	ldr	r3, [r7, #8]
 8000a2c:	781a      	ldrb	r2, [r3, #0]
 8000a2e:	68fb      	ldr	r3, [r7, #12]
 8000a30:	68db      	ldr	r3, [r3, #12]
 8000a32:	611a      	str	r2, [r3, #16]

		number_of_bytes--;
 8000a34:	79bb      	ldrb	r3, [r7, #6]
 8000a36:	3b01      	subs	r3, #1
 8000a38:	71bb      	strb	r3, [r7, #6]

		TxData++;
 8000a3a:	68bb      	ldr	r3, [r7, #8]
 8000a3c:	3301      	adds	r3, #1
 8000a3e:	60bb      	str	r3, [r7, #8]
	while(number_of_bytes > 0)
 8000a40:	79bb      	ldrb	r3, [r7, #6]
 8000a42:	2b00      	cmp	r3, #0
 8000a44:	d1e9      	bne.n	8000a1a <I2C_MasterTransmit+0x66>
	}

	while(!(Check_Flag(I2C_Handle, SR1_TXE_Flag)));
 8000a46:	bf00      	nop
 8000a48:	2180      	movs	r1, #128	; 0x80
 8000a4a:	68f8      	ldr	r0, [r7, #12]
 8000a4c:	f7ff fe06 	bl	800065c <Check_Flag>
 8000a50:	4603      	mov	r3, r0
 8000a52:	2b00      	cmp	r3, #0
 8000a54:	d0f8      	beq.n	8000a48 <I2C_MasterTransmit+0x94>
	while(!(Check_Flag(I2C_Handle, SR1_BTF_Flag)));
 8000a56:	bf00      	nop
 8000a58:	2104      	movs	r1, #4
 8000a5a:	68f8      	ldr	r0, [r7, #12]
 8000a5c:	f7ff fdfe 	bl	800065c <Check_Flag>
 8000a60:	4603      	mov	r3, r0
 8000a62:	2b00      	cmp	r3, #0
 8000a64:	d0f8      	beq.n	8000a58 <I2C_MasterTransmit+0xa4>

	if(restart_condition == I2C_No_Restart)
 8000a66:	7e3b      	ldrb	r3, [r7, #24]
 8000a68:	2b00      	cmp	r3, #0
 8000a6a:	d105      	bne.n	8000a78 <I2C_MasterTransmit+0xc4>
	{
		Generate_Stop_Condition(I2C_Handle);
 8000a6c:	68f8      	ldr	r0, [r7, #12]
 8000a6e:	f7ff fe0a 	bl	8000686 <Generate_Stop_Condition>
		I2C_Handle->I2C_Bus_Direction = I2C_Ready;
 8000a72:	68fb      	ldr	r3, [r7, #12]
 8000a74:	2200      	movs	r2, #0
 8000a76:	775a      	strb	r2, [r3, #29]
	}



}
 8000a78:	bf00      	nop
 8000a7a:	3710      	adds	r7, #16
 8000a7c:	46bd      	mov	sp, r7
 8000a7e:	bd80      	pop	{r7, pc}

08000a80 <I2C_MasterRecieve>:
 *
 * @param	restart_condition: This will be used to impact whether or not the master releases the SDA or SCL line
 * 			by sending a stop condition.
 */
void I2C_MasterRecieve(I2C_Handle_t *I2C_Handle, uint8_t *RxData, uint8_t slave_address, uint8_t number_of_bytes, uint8_t restart_condition)
{
 8000a80:	b580      	push	{r7, lr}
 8000a82:	b084      	sub	sp, #16
 8000a84:	af00      	add	r7, sp, #0
 8000a86:	60f8      	str	r0, [r7, #12]
 8000a88:	60b9      	str	r1, [r7, #8]
 8000a8a:	4611      	mov	r1, r2
 8000a8c:	461a      	mov	r2, r3
 8000a8e:	460b      	mov	r3, r1
 8000a90:	71fb      	strb	r3, [r7, #7]
 8000a92:	4613      	mov	r3, r2
 8000a94:	71bb      	strb	r3, [r7, #6]
	I2C_Handle->I2C_Bus_Direction = I2C_Recieve;
 8000a96:	68fb      	ldr	r3, [r7, #12]
 8000a98:	2202      	movs	r2, #2
 8000a9a:	775a      	strb	r2, [r3, #29]
	I2C_Handle->slave_address = slave_address;
 8000a9c:	68fb      	ldr	r3, [r7, #12]
 8000a9e:	79fa      	ldrb	r2, [r7, #7]
 8000aa0:	771a      	strb	r2, [r3, #28]
	I2C_Handle->Rx_Length = number_of_bytes;
 8000aa2:	68fb      	ldr	r3, [r7, #12]
 8000aa4:	79ba      	ldrb	r2, [r7, #6]
 8000aa6:	745a      	strb	r2, [r3, #17]

	//Generate start condition and ensure the SB flag is raised
	Generate_Start_Condition(I2C_Handle);
 8000aa8:	68f8      	ldr	r0, [r7, #12]
 8000aaa:	f7ff fdc5 	bl	8000638 <Generate_Start_Condition>
	while(!(Check_Flag(I2C_Handle, SR1_SB_Flag)));
 8000aae:	bf00      	nop
 8000ab0:	2101      	movs	r1, #1
 8000ab2:	68f8      	ldr	r0, [r7, #12]
 8000ab4:	f7ff fdd2 	bl	800065c <Check_Flag>
 8000ab8:	4603      	mov	r3, r0
 8000aba:	2b00      	cmp	r3, #0
 8000abc:	d0f8      	beq.n	8000ab0 <I2C_MasterRecieve+0x30>

	//Send slave address with read as the LSB and ensure the addr flag is raised
	Send_Slave_Address(I2C_Handle);
 8000abe:	68f8      	ldr	r0, [r7, #12]
 8000ac0:	f7ff fdf3 	bl	80006aa <Send_Slave_Address>
	while(!(Check_Flag(I2C_Handle, SR1_ADDR_Flag)));
 8000ac4:	bf00      	nop
 8000ac6:	2102      	movs	r1, #2
 8000ac8:	68f8      	ldr	r0, [r7, #12]
 8000aca:	f7ff fdc7 	bl	800065c <Check_Flag>
 8000ace:	4603      	mov	r3, r0
 8000ad0:	2b00      	cmp	r3, #0
 8000ad2:	d0f8      	beq.n	8000ac6 <I2C_MasterRecieve+0x46>

	//Clear addr flag
	Clear_Addr_Flag(I2C_Handle);
 8000ad4:	68f8      	ldr	r0, [r7, #12]
 8000ad6:	f7ff fe0b 	bl	80006f0 <Clear_Addr_Flag>

	//Check if number of bytes to be transmitted is 1
	if(number_of_bytes == 1)
 8000ada:	79bb      	ldrb	r3, [r7, #6]
 8000adc:	2b01      	cmp	r3, #1
 8000ade:	d116      	bne.n	8000b0e <I2C_MasterRecieve+0x8e>
	{

		//wait until RXNE flag is raised
		while(!(Check_Flag(I2C_Handle, SR1_RXNE_Flag)));
 8000ae0:	bf00      	nop
 8000ae2:	2140      	movs	r1, #64	; 0x40
 8000ae4:	68f8      	ldr	r0, [r7, #12]
 8000ae6:	f7ff fdb9 	bl	800065c <Check_Flag>
 8000aea:	4603      	mov	r3, r0
 8000aec:	2b00      	cmp	r3, #0
 8000aee:	d0f8      	beq.n	8000ae2 <I2C_MasterRecieve+0x62>

		if(restart_condition == I2C_No_Restart)
 8000af0:	7e3b      	ldrb	r3, [r7, #24]
 8000af2:	2b00      	cmp	r3, #0
 8000af4:	d105      	bne.n	8000b02 <I2C_MasterRecieve+0x82>
		{
			//Generate stop condition
			Generate_Stop_Condition(I2C_Handle);
 8000af6:	68f8      	ldr	r0, [r7, #12]
 8000af8:	f7ff fdc5 	bl	8000686 <Generate_Stop_Condition>
			I2C_Handle->I2C_Bus_Direction = I2C_Ready;
 8000afc:	68fb      	ldr	r3, [r7, #12]
 8000afe:	2200      	movs	r2, #0
 8000b00:	775a      	strb	r2, [r3, #29]
		}

		//Read data
		*RxData = I2C_Handle->I2Cx->DR;
 8000b02:	68fb      	ldr	r3, [r7, #12]
 8000b04:	68db      	ldr	r3, [r3, #12]
 8000b06:	691b      	ldr	r3, [r3, #16]
 8000b08:	b2da      	uxtb	r2, r3
 8000b0a:	68bb      	ldr	r3, [r7, #8]
 8000b0c:	701a      	strb	r2, [r3, #0]
	}

	//Check if number of bytes to be read is greater than 1
	if(number_of_bytes > 1)
 8000b0e:	79bb      	ldrb	r3, [r7, #6]
 8000b10:	2b01      	cmp	r3, #1
 8000b12:	d92b      	bls.n	8000b6c <I2C_MasterRecieve+0xec>
	{

		while(number_of_bytes > 0)
 8000b14:	e027      	b.n	8000b66 <I2C_MasterRecieve+0xe6>
		{

			while(!(Check_Flag(I2C_Handle, SR1_RXNE_Flag)));
 8000b16:	bf00      	nop
 8000b18:	2140      	movs	r1, #64	; 0x40
 8000b1a:	68f8      	ldr	r0, [r7, #12]
 8000b1c:	f7ff fd9e 	bl	800065c <Check_Flag>
 8000b20:	4603      	mov	r3, r0
 8000b22:	2b00      	cmp	r3, #0
 8000b24:	d0f8      	beq.n	8000b18 <I2C_MasterRecieve+0x98>

			*RxData = I2C_Handle->I2Cx->DR;
 8000b26:	68fb      	ldr	r3, [r7, #12]
 8000b28:	68db      	ldr	r3, [r3, #12]
 8000b2a:	691b      	ldr	r3, [r3, #16]
 8000b2c:	b2da      	uxtb	r2, r3
 8000b2e:	68bb      	ldr	r3, [r7, #8]
 8000b30:	701a      	strb	r2, [r3, #0]

			if(number_of_bytes == 2)
 8000b32:	79bb      	ldrb	r3, [r7, #6]
 8000b34:	2b02      	cmp	r3, #2
 8000b36:	d110      	bne.n	8000b5a <I2C_MasterRecieve+0xda>
			{
				I2C_Handle->I2Cx->CR1 &= ~(CR1_ACK_Enable);
 8000b38:	68fb      	ldr	r3, [r7, #12]
 8000b3a:	68db      	ldr	r3, [r3, #12]
 8000b3c:	681a      	ldr	r2, [r3, #0]
 8000b3e:	68fb      	ldr	r3, [r7, #12]
 8000b40:	68db      	ldr	r3, [r3, #12]
 8000b42:	f422 6280 	bic.w	r2, r2, #1024	; 0x400
 8000b46:	601a      	str	r2, [r3, #0]

				if(restart_condition == I2C_No_Restart)
 8000b48:	7e3b      	ldrb	r3, [r7, #24]
 8000b4a:	2b00      	cmp	r3, #0
 8000b4c:	d105      	bne.n	8000b5a <I2C_MasterRecieve+0xda>
				{
					//Generate stop condition
					Generate_Stop_Condition(I2C_Handle);
 8000b4e:	68f8      	ldr	r0, [r7, #12]
 8000b50:	f7ff fd99 	bl	8000686 <Generate_Stop_Condition>
					I2C_Handle->I2C_Bus_Direction = I2C_Ready;
 8000b54:	68fb      	ldr	r3, [r7, #12]
 8000b56:	2200      	movs	r2, #0
 8000b58:	775a      	strb	r2, [r3, #29]
				}
			}

			RxData++;
 8000b5a:	68bb      	ldr	r3, [r7, #8]
 8000b5c:	3301      	adds	r3, #1
 8000b5e:	60bb      	str	r3, [r7, #8]

			number_of_bytes--;
 8000b60:	79bb      	ldrb	r3, [r7, #6]
 8000b62:	3b01      	subs	r3, #1
 8000b64:	71bb      	strb	r3, [r7, #6]
		while(number_of_bytes > 0)
 8000b66:	79bb      	ldrb	r3, [r7, #6]
 8000b68:	2b00      	cmp	r3, #0
 8000b6a:	d1d4      	bne.n	8000b16 <I2C_MasterRecieve+0x96>

		}
	}

	I2C_Handle->I2Cx->CR1 |= CR1_ACK_Enable;
 8000b6c:	68fb      	ldr	r3, [r7, #12]
 8000b6e:	68db      	ldr	r3, [r3, #12]
 8000b70:	681a      	ldr	r2, [r3, #0]
 8000b72:	68fb      	ldr	r3, [r7, #12]
 8000b74:	68db      	ldr	r3, [r3, #12]
 8000b76:	f442 6280 	orr.w	r2, r2, #1024	; 0x400
 8000b7a:	601a      	str	r2, [r3, #0]
}
 8000b7c:	bf00      	nop
 8000b7e:	3710      	adds	r7, #16
 8000b80:	46bd      	mov	sp, r7
 8000b82:	bd80      	pop	{r7, pc}

08000b84 <RCC_AHB1Cmd>:
 * @param	AHB1_Periph: Specific peripheral selected by the user (GPIOx, SPIx, I2Cx etc)
 *
 * @param	State: Specifies whether to enable or disable the peripheral.
 */
void RCC_AHB1Cmd(uint32_t AHB1_Periph, FunctionalState State)
{
 8000b84:	b480      	push	{r7}
 8000b86:	b083      	sub	sp, #12
 8000b88:	af00      	add	r7, sp, #0
 8000b8a:	6078      	str	r0, [r7, #4]
 8000b8c:	460b      	mov	r3, r1
 8000b8e:	70fb      	strb	r3, [r7, #3]
	if(State == ENABLE)
 8000b90:	78fb      	ldrb	r3, [r7, #3]
 8000b92:	2b01      	cmp	r3, #1
 8000b94:	d106      	bne.n	8000ba4 <RCC_AHB1Cmd+0x20>
	{
		RCC->AHB1ENR |= AHB1_Periph;
 8000b96:	4b0a      	ldr	r3, [pc, #40]	; (8000bc0 <RCC_AHB1Cmd+0x3c>)
 8000b98:	6b1a      	ldr	r2, [r3, #48]	; 0x30
 8000b9a:	4909      	ldr	r1, [pc, #36]	; (8000bc0 <RCC_AHB1Cmd+0x3c>)
 8000b9c:	687b      	ldr	r3, [r7, #4]
 8000b9e:	4313      	orrs	r3, r2
 8000ba0:	630b      	str	r3, [r1, #48]	; 0x30

	else
	{
		RCC->AHB1ENR &= ~AHB1_Periph;
	}
}
 8000ba2:	e006      	b.n	8000bb2 <RCC_AHB1Cmd+0x2e>
		RCC->AHB1ENR &= ~AHB1_Periph;
 8000ba4:	4b06      	ldr	r3, [pc, #24]	; (8000bc0 <RCC_AHB1Cmd+0x3c>)
 8000ba6:	6b1a      	ldr	r2, [r3, #48]	; 0x30
 8000ba8:	687b      	ldr	r3, [r7, #4]
 8000baa:	43db      	mvns	r3, r3
 8000bac:	4904      	ldr	r1, [pc, #16]	; (8000bc0 <RCC_AHB1Cmd+0x3c>)
 8000bae:	4013      	ands	r3, r2
 8000bb0:	630b      	str	r3, [r1, #48]	; 0x30
}
 8000bb2:	bf00      	nop
 8000bb4:	370c      	adds	r7, #12
 8000bb6:	46bd      	mov	sp, r7
 8000bb8:	f85d 7b04 	ldr.w	r7, [sp], #4
 8000bbc:	4770      	bx	lr
 8000bbe:	bf00      	nop
 8000bc0:	40023800 	.word	0x40023800

08000bc4 <RCC_APB1Cmd>:
 * @param	APB1_Periph: Specific peripheral selected by the user (GPIOx, SPIx, I2Cx etc)
 *
 * @param	State: Specifies whether to enable or disable the peripheral.
 */
void RCC_APB1Cmd(uint32_t APB1_Periph, FunctionalState State)
{
 8000bc4:	b480      	push	{r7}
 8000bc6:	b083      	sub	sp, #12
 8000bc8:	af00      	add	r7, sp, #0
 8000bca:	6078      	str	r0, [r7, #4]
 8000bcc:	460b      	mov	r3, r1
 8000bce:	70fb      	strb	r3, [r7, #3]
	if(State == ENABLE)
 8000bd0:	78fb      	ldrb	r3, [r7, #3]
 8000bd2:	2b01      	cmp	r3, #1
 8000bd4:	d106      	bne.n	8000be4 <RCC_APB1Cmd+0x20>
	{
		RCC->APB1ENR |= APB1_Periph;
 8000bd6:	4b0a      	ldr	r3, [pc, #40]	; (8000c00 <RCC_APB1Cmd+0x3c>)
 8000bd8:	6c1a      	ldr	r2, [r3, #64]	; 0x40
 8000bda:	4909      	ldr	r1, [pc, #36]	; (8000c00 <RCC_APB1Cmd+0x3c>)
 8000bdc:	687b      	ldr	r3, [r7, #4]
 8000bde:	4313      	orrs	r3, r2
 8000be0:	640b      	str	r3, [r1, #64]	; 0x40

	else
	{
		RCC->APB1ENR &= ~APB1_Periph;
	}
}
 8000be2:	e006      	b.n	8000bf2 <RCC_APB1Cmd+0x2e>
		RCC->APB1ENR &= ~APB1_Periph;
 8000be4:	4b06      	ldr	r3, [pc, #24]	; (8000c00 <RCC_APB1Cmd+0x3c>)
 8000be6:	6c1a      	ldr	r2, [r3, #64]	; 0x40
 8000be8:	687b      	ldr	r3, [r7, #4]
 8000bea:	43db      	mvns	r3, r3
 8000bec:	4904      	ldr	r1, [pc, #16]	; (8000c00 <RCC_APB1Cmd+0x3c>)
 8000bee:	4013      	ands	r3, r2
 8000bf0:	640b      	str	r3, [r1, #64]	; 0x40
}
 8000bf2:	bf00      	nop
 8000bf4:	370c      	adds	r7, #12
 8000bf6:	46bd      	mov	sp, r7
 8000bf8:	f85d 7b04 	ldr.w	r7, [sp], #4
 8000bfc:	4770      	bx	lr
 8000bfe:	bf00      	nop
 8000c00:	40023800 	.word	0x40023800

08000c04 <RCC_APB2Cmd>:
 * @param	APB2_Periph: Specific peripheral selected by the user (GPIOx, SPIx, I2Cx etc)
 *
 * @param	State: Specifies whether to enable or disable the peripheral.
 */
void RCC_APB2Cmd(uint32_t APB2_Periph, FunctionalState State)
{
 8000c04:	b480      	push	{r7}
 8000c06:	b083      	sub	sp, #12
 8000c08:	af00      	add	r7, sp, #0
 8000c0a:	6078      	str	r0, [r7, #4]
 8000c0c:	460b      	mov	r3, r1
 8000c0e:	70fb      	strb	r3, [r7, #3]
	if(State == ENABLE)
 8000c10:	78fb      	ldrb	r3, [r7, #3]
 8000c12:	2b01      	cmp	r3, #1
 8000c14:	d106      	bne.n	8000c24 <RCC_APB2Cmd+0x20>
	{
		RCC->APB2ENR |= APB2_Periph;
 8000c16:	4b0a      	ldr	r3, [pc, #40]	; (8000c40 <RCC_APB2Cmd+0x3c>)
 8000c18:	6c5a      	ldr	r2, [r3, #68]	; 0x44
 8000c1a:	4909      	ldr	r1, [pc, #36]	; (8000c40 <RCC_APB2Cmd+0x3c>)
 8000c1c:	687b      	ldr	r3, [r7, #4]
 8000c1e:	4313      	orrs	r3, r2
 8000c20:	644b      	str	r3, [r1, #68]	; 0x44

	else
	{
		RCC->APB2ENR &= ~APB2_Periph;
	}
}
 8000c22:	e006      	b.n	8000c32 <RCC_APB2Cmd+0x2e>
		RCC->APB2ENR &= ~APB2_Periph;
 8000c24:	4b06      	ldr	r3, [pc, #24]	; (8000c40 <RCC_APB2Cmd+0x3c>)
 8000c26:	6c5a      	ldr	r2, [r3, #68]	; 0x44
 8000c28:	687b      	ldr	r3, [r7, #4]
 8000c2a:	43db      	mvns	r3, r3
 8000c2c:	4904      	ldr	r1, [pc, #16]	; (8000c40 <RCC_APB2Cmd+0x3c>)
 8000c2e:	4013      	ands	r3, r2
 8000c30:	644b      	str	r3, [r1, #68]	; 0x44
}
 8000c32:	bf00      	nop
 8000c34:	370c      	adds	r7, #12
 8000c36:	46bd      	mov	sp, r7
 8000c38:	f85d 7b04 	ldr.w	r7, [sp], #4
 8000c3c:	4770      	bx	lr
 8000c3e:	bf00      	nop
 8000c40:	40023800 	.word	0x40023800

08000c44 <RCC_GetClockFreq>:
 *
 * @param	ClockSource: Points to the ClockSource data structure which contains the varibales to hold
 * 			the frequencies of the SYSCLCK, HCLCK, PCLCK1, PCLCK2.
 */
void RCC_GetClockFreq(RCC_ClockFrequency_t *ClockSource)
{
 8000c44:	b480      	push	{r7}
 8000c46:	b08b      	sub	sp, #44	; 0x2c
 8000c48:	af00      	add	r7, sp, #0
 8000c4a:	6078      	str	r0, [r7, #4]
	uint32_t pll_Value = 0, plln = 0, pllm = 2, pllp = 2, pll_src = 0, pll_fvco = 0;
 8000c4c:	2300      	movs	r3, #0
 8000c4e:	623b      	str	r3, [r7, #32]
 8000c50:	2300      	movs	r3, #0
 8000c52:	61fb      	str	r3, [r7, #28]
 8000c54:	2302      	movs	r3, #2
 8000c56:	61bb      	str	r3, [r7, #24]
 8000c58:	2302      	movs	r3, #2
 8000c5a:	617b      	str	r3, [r7, #20]
 8000c5c:	2300      	movs	r3, #0
 8000c5e:	627b      	str	r3, [r7, #36]	; 0x24
 8000c60:	2300      	movs	r3, #0
 8000c62:	613b      	str	r3, [r7, #16]

	uint32_t temp_variable, prescaler;

	/*Determine the clock source for the SYSCLCK*/
	if(((RCC->CFGR & RCC_CFGR_SWS_Mask) >> 2) == 0x0)
 8000c64:	4b43      	ldr	r3, [pc, #268]	; (8000d74 <RCC_GetClockFreq+0x130>)
 8000c66:	689b      	ldr	r3, [r3, #8]
 8000c68:	089b      	lsrs	r3, r3, #2
 8000c6a:	f003 0303 	and.w	r3, r3, #3
 8000c6e:	2b00      	cmp	r3, #0
 8000c70:	d103      	bne.n	8000c7a <RCC_GetClockFreq+0x36>
	{
		ClockSource->SYSCLCK = HSI_Value;
 8000c72:	687b      	ldr	r3, [r7, #4]
 8000c74:	4a40      	ldr	r2, [pc, #256]	; (8000d78 <RCC_GetClockFreq+0x134>)
 8000c76:	601a      	str	r2, [r3, #0]
 8000c78:	e03f      	b.n	8000cfa <RCC_GetClockFreq+0xb6>
	}

	else if(((RCC->CFGR & RCC_CFGR_SWS_Mask) >> 2) == 0x1)
 8000c7a:	4b3e      	ldr	r3, [pc, #248]	; (8000d74 <RCC_GetClockFreq+0x130>)
 8000c7c:	689b      	ldr	r3, [r3, #8]
 8000c7e:	089b      	lsrs	r3, r3, #2
 8000c80:	f003 0303 	and.w	r3, r3, #3
 8000c84:	2b01      	cmp	r3, #1
 8000c86:	d103      	bne.n	8000c90 <RCC_GetClockFreq+0x4c>
	{
		ClockSource->SYSCLCK = HSE_Value;
 8000c88:	687b      	ldr	r3, [r7, #4]
 8000c8a:	4a3c      	ldr	r2, [pc, #240]	; (8000d7c <RCC_GetClockFreq+0x138>)
 8000c8c:	601a      	str	r2, [r3, #0]
 8000c8e:	e034      	b.n	8000cfa <RCC_GetClockFreq+0xb6>
	}

	else if(((RCC->CFGR & RCC_CFGR_SWS_Mask) >> 2) == 0x2)
 8000c90:	4b38      	ldr	r3, [pc, #224]	; (8000d74 <RCC_GetClockFreq+0x130>)
 8000c92:	689b      	ldr	r3, [r3, #8]
 8000c94:	089b      	lsrs	r3, r3, #2
 8000c96:	f003 0303 	and.w	r3, r3, #3
 8000c9a:	2b02      	cmp	r3, #2
 8000c9c:	d12d      	bne.n	8000cfa <RCC_GetClockFreq+0xb6>
	{
		/*Determine the input source of the PLL*/
		if(RCC->PLLCFGR & RCC_PLLCFGR_PLLSRC_Mask)
 8000c9e:	4b35      	ldr	r3, [pc, #212]	; (8000d74 <RCC_GetClockFreq+0x130>)
 8000ca0:	685b      	ldr	r3, [r3, #4]
 8000ca2:	f403 0380 	and.w	r3, r3, #4194304	; 0x400000
 8000ca6:	2b00      	cmp	r3, #0
 8000ca8:	d002      	beq.n	8000cb0 <RCC_GetClockFreq+0x6c>
		{
			pll_src = HSE_Value;
 8000caa:	4b34      	ldr	r3, [pc, #208]	; (8000d7c <RCC_GetClockFreq+0x138>)
 8000cac:	627b      	str	r3, [r7, #36]	; 0x24
 8000cae:	e001      	b.n	8000cb4 <RCC_GetClockFreq+0x70>
		}

		else
		{
			pll_src = HSI_Value;
 8000cb0:	4b31      	ldr	r3, [pc, #196]	; (8000d78 <RCC_GetClockFreq+0x134>)
 8000cb2:	627b      	str	r3, [r7, #36]	; 0x24
		}

		plln = ((RCC->PLLCFGR & RCC_PLLCFGR_PLLN_Mask) >> 6);
 8000cb4:	4b2f      	ldr	r3, [pc, #188]	; (8000d74 <RCC_GetClockFreq+0x130>)
 8000cb6:	685b      	ldr	r3, [r3, #4]
 8000cb8:	099b      	lsrs	r3, r3, #6
 8000cba:	f3c3 0308 	ubfx	r3, r3, #0, #9
 8000cbe:	61fb      	str	r3, [r7, #28]
		pllm = (RCC->PLLCFGR & RCC_PLLCFGR_PLLM_Mask);
 8000cc0:	4b2c      	ldr	r3, [pc, #176]	; (8000d74 <RCC_GetClockFreq+0x130>)
 8000cc2:	685b      	ldr	r3, [r3, #4]
 8000cc4:	f003 033f 	and.w	r3, r3, #63	; 0x3f
 8000cc8:	61bb      	str	r3, [r7, #24]
		pll_fvco = (pll_src/pllm) * plln;
 8000cca:	6a7a      	ldr	r2, [r7, #36]	; 0x24
 8000ccc:	69bb      	ldr	r3, [r7, #24]
 8000cce:	fbb2 f2f3 	udiv	r2, r2, r3
 8000cd2:	69fb      	ldr	r3, [r7, #28]
 8000cd4:	fb02 f303 	mul.w	r3, r2, r3
 8000cd8:	613b      	str	r3, [r7, #16]
		pllp = ((((RCC->PLLCFGR & RCC_PLLCFGR_PLLP_Mask) >> 16) * 2) + 2);
 8000cda:	4b26      	ldr	r3, [pc, #152]	; (8000d74 <RCC_GetClockFreq+0x130>)
 8000cdc:	685b      	ldr	r3, [r3, #4]
 8000cde:	0c1b      	lsrs	r3, r3, #16
 8000ce0:	f003 0303 	and.w	r3, r3, #3
 8000ce4:	3301      	adds	r3, #1
 8000ce6:	005b      	lsls	r3, r3, #1
 8000ce8:	617b      	str	r3, [r7, #20]
		pll_Value = pll_fvco/pllp;
 8000cea:	693a      	ldr	r2, [r7, #16]
 8000cec:	697b      	ldr	r3, [r7, #20]
 8000cee:	fbb2 f3f3 	udiv	r3, r2, r3
 8000cf2:	623b      	str	r3, [r7, #32]

		ClockSource->SYSCLCK = pll_Value;
 8000cf4:	687b      	ldr	r3, [r7, #4]
 8000cf6:	6a3a      	ldr	r2, [r7, #32]
 8000cf8:	601a      	str	r2, [r3, #0]
	}

	/*Determine the frequency of the HCLCK*/
	temp_variable = ((RCC->CFGR & RCC_CFGR_HPRE_Mask) >> 4);
 8000cfa:	4b1e      	ldr	r3, [pc, #120]	; (8000d74 <RCC_GetClockFreq+0x130>)
 8000cfc:	689b      	ldr	r3, [r3, #8]
 8000cfe:	091b      	lsrs	r3, r3, #4
 8000d00:	f003 030f 	and.w	r3, r3, #15
 8000d04:	60fb      	str	r3, [r7, #12]
	prescaler = prescalerTable[temp_variable];
 8000d06:	4a1e      	ldr	r2, [pc, #120]	; (8000d80 <RCC_GetClockFreq+0x13c>)
 8000d08:	68fb      	ldr	r3, [r7, #12]
 8000d0a:	f832 3013 	ldrh.w	r3, [r2, r3, lsl #1]
 8000d0e:	b29b      	uxth	r3, r3
 8000d10:	60bb      	str	r3, [r7, #8]
	ClockSource->HCLCK = (ClockSource->SYSCLCK) >> prescaler;
 8000d12:	687b      	ldr	r3, [r7, #4]
 8000d14:	681a      	ldr	r2, [r3, #0]
 8000d16:	68bb      	ldr	r3, [r7, #8]
 8000d18:	40da      	lsrs	r2, r3
 8000d1a:	687b      	ldr	r3, [r7, #4]
 8000d1c:	605a      	str	r2, [r3, #4]

	/*Determine the frequency of the PCLCK1*/
	temp_variable = ((RCC->CFGR & RCC_CFGR_PPRE1_Mask) >> 10);
 8000d1e:	4b15      	ldr	r3, [pc, #84]	; (8000d74 <RCC_GetClockFreq+0x130>)
 8000d20:	689b      	ldr	r3, [r3, #8]
 8000d22:	0a9b      	lsrs	r3, r3, #10
 8000d24:	f003 0307 	and.w	r3, r3, #7
 8000d28:	60fb      	str	r3, [r7, #12]
	prescaler = prescalerTable[temp_variable];
 8000d2a:	4a15      	ldr	r2, [pc, #84]	; (8000d80 <RCC_GetClockFreq+0x13c>)
 8000d2c:	68fb      	ldr	r3, [r7, #12]
 8000d2e:	f832 3013 	ldrh.w	r3, [r2, r3, lsl #1]
 8000d32:	b29b      	uxth	r3, r3
 8000d34:	60bb      	str	r3, [r7, #8]
	ClockSource->PCLCK1 = (ClockSource->HCLCK) >> prescaler;
 8000d36:	687b      	ldr	r3, [r7, #4]
 8000d38:	685a      	ldr	r2, [r3, #4]
 8000d3a:	68bb      	ldr	r3, [r7, #8]
 8000d3c:	40da      	lsrs	r2, r3
 8000d3e:	687b      	ldr	r3, [r7, #4]
 8000d40:	609a      	str	r2, [r3, #8]

	/*Determine frequency of PCLCK2*/
	temp_variable = ((RCC->CFGR & RCC_CFGR_PPRE2_Mask) >> 13);
 8000d42:	4b0c      	ldr	r3, [pc, #48]	; (8000d74 <RCC_GetClockFreq+0x130>)
 8000d44:	689b      	ldr	r3, [r3, #8]
 8000d46:	0b5b      	lsrs	r3, r3, #13
 8000d48:	f003 0307 	and.w	r3, r3, #7
 8000d4c:	60fb      	str	r3, [r7, #12]
	prescaler = prescalerTable[temp_variable];
 8000d4e:	4a0c      	ldr	r2, [pc, #48]	; (8000d80 <RCC_GetClockFreq+0x13c>)
 8000d50:	68fb      	ldr	r3, [r7, #12]
 8000d52:	f832 3013 	ldrh.w	r3, [r2, r3, lsl #1]
 8000d56:	b29b      	uxth	r3, r3
 8000d58:	60bb      	str	r3, [r7, #8]
	ClockSource->PCLCK2 = (ClockSource->HCLCK) >> prescaler;
 8000d5a:	687b      	ldr	r3, [r7, #4]
 8000d5c:	685a      	ldr	r2, [r3, #4]
 8000d5e:	68bb      	ldr	r3, [r7, #8]
 8000d60:	40da      	lsrs	r2, r3
 8000d62:	687b      	ldr	r3, [r7, #4]
 8000d64:	60da      	str	r2, [r3, #12]

}
 8000d66:	bf00      	nop
 8000d68:	372c      	adds	r7, #44	; 0x2c
 8000d6a:	46bd      	mov	sp, r7
 8000d6c:	f85d 7b04 	ldr.w	r7, [sp], #4
 8000d70:	4770      	bx	lr
 8000d72:	bf00      	nop
 8000d74:	40023800 	.word	0x40023800
 8000d78:	00f42400 	.word	0x00f42400
 8000d7c:	007a1200 	.word	0x007a1200
 8000d80:	20000000 	.word	0x20000000

08000d84 <UART_Config>:
 *
 * @param	baudrate: Allows the user to input their desired baud-rate for the UART peripheral.
 *
 */
void UART_Config(UART_Config_t *UART_Config, USART_TypeDef *UARTx, uint16_t mode, uint32_t baudrate)
{
 8000d84:	b480      	push	{r7}
 8000d86:	b085      	sub	sp, #20
 8000d88:	af00      	add	r7, sp, #0
 8000d8a:	60f8      	str	r0, [r7, #12]
 8000d8c:	60b9      	str	r1, [r7, #8]
 8000d8e:	603b      	str	r3, [r7, #0]
 8000d90:	4613      	mov	r3, r2
 8000d92:	80fb      	strh	r3, [r7, #6]
	UART_Config->UARTx = UARTx;
 8000d94:	68fb      	ldr	r3, [r7, #12]
 8000d96:	68ba      	ldr	r2, [r7, #8]
 8000d98:	611a      	str	r2, [r3, #16]
	UART_Config->Mode = mode;
 8000d9a:	68fb      	ldr	r3, [r7, #12]
 8000d9c:	88fa      	ldrh	r2, [r7, #6]
 8000d9e:	819a      	strh	r2, [r3, #12]
	UART_Config->BaudRate = baudrate;
 8000da0:	68fb      	ldr	r3, [r7, #12]
 8000da2:	683a      	ldr	r2, [r7, #0]
 8000da4:	609a      	str	r2, [r3, #8]
	UART_Config->World_Length = UART_WORDLEN_8BITS;
 8000da6:	68fb      	ldr	r3, [r7, #12]
 8000da8:	2200      	movs	r2, #0
 8000daa:	805a      	strh	r2, [r3, #2]
	UART_Config->Parity = UART_PARITY_DISABLED;
 8000dac:	68fb      	ldr	r3, [r7, #12]
 8000dae:	2200      	movs	r2, #0
 8000db0:	80da      	strh	r2, [r3, #6]
	UART_Config->oversampling = UART_OVERSAMPLING_16;
 8000db2:	68fb      	ldr	r3, [r7, #12]
 8000db4:	2200      	movs	r2, #0
 8000db6:	809a      	strh	r2, [r3, #4]
	UART_Config->Stop_Bits = UART_STOPBITS_1;
 8000db8:	68fb      	ldr	r3, [r7, #12]
 8000dba:	2200      	movs	r2, #0
 8000dbc:	801a      	strh	r2, [r3, #0]
}
 8000dbe:	bf00      	nop
 8000dc0:	3714      	adds	r7, #20
 8000dc2:	46bd      	mov	sp, r7
 8000dc4:	f85d 7b04 	ldr.w	r7, [sp], #4
 8000dc8:	4770      	bx	lr

08000dca <Select_UART_Periph>:
 *
 * @param	alt_function: Defines the alternate function value to input into the Alternate function register.
 *
 */
void Select_UART_Periph(GPIO_TypeDef *GPIOx, uint8_t pin, AFR_Config_t alt_function)
{
 8000dca:	b580      	push	{r7, lr}
 8000dcc:	b08c      	sub	sp, #48	; 0x30
 8000dce:	af04      	add	r7, sp, #16
 8000dd0:	6078      	str	r0, [r7, #4]
 8000dd2:	460b      	mov	r3, r1
 8000dd4:	70fb      	strb	r3, [r7, #3]
 8000dd6:	4613      	mov	r3, r2
 8000dd8:	70bb      	strb	r3, [r7, #2]
	GPIO_Config_t GPIOx_UARTx_Tx, GPIOx_UARTx_Rx;

	GPIO_Config(&GPIOx_UARTx_Tx, GPIOx, pin, GPIO_AF, GPIO_PushPull, GPIO_LowSpeed, GPIO_PUPD_None);
 8000dda:	78fa      	ldrb	r2, [r7, #3]
 8000ddc:	f107 0014 	add.w	r0, r7, #20
 8000de0:	2300      	movs	r3, #0
 8000de2:	9302      	str	r3, [sp, #8]
 8000de4:	2300      	movs	r3, #0
 8000de6:	9301      	str	r3, [sp, #4]
 8000de8:	2300      	movs	r3, #0
 8000dea:	9300      	str	r3, [sp, #0]
 8000dec:	2302      	movs	r3, #2
 8000dee:	6879      	ldr	r1, [r7, #4]
 8000df0:	f7ff f9f0 	bl	80001d4 <GPIO_Config>
	GPIO_Init(&GPIOx_UARTx_Tx, alt_function);
 8000df4:	78ba      	ldrb	r2, [r7, #2]
 8000df6:	f107 0314 	add.w	r3, r7, #20
 8000dfa:	4611      	mov	r1, r2
 8000dfc:	4618      	mov	r0, r3
 8000dfe:	f7ff fad1 	bl	80003a4 <GPIO_Init>

	GPIO_Config(&GPIOx_UARTx_Rx, GPIOx, (pin + 1), GPIO_AF, GPIO_PushPull, GPIO_LowSpeed, GPIO_PUPD_None);
 8000e02:	78fb      	ldrb	r3, [r7, #3]
 8000e04:	3301      	adds	r3, #1
 8000e06:	b2da      	uxtb	r2, r3
 8000e08:	f107 0008 	add.w	r0, r7, #8
 8000e0c:	2300      	movs	r3, #0
 8000e0e:	9302      	str	r3, [sp, #8]
 8000e10:	2300      	movs	r3, #0
 8000e12:	9301      	str	r3, [sp, #4]
 8000e14:	2300      	movs	r3, #0
 8000e16:	9300      	str	r3, [sp, #0]
 8000e18:	2302      	movs	r3, #2
 8000e1a:	6879      	ldr	r1, [r7, #4]
 8000e1c:	f7ff f9da 	bl	80001d4 <GPIO_Config>
	GPIO_Init(&GPIOx_UARTx_Rx, alt_function);
 8000e20:	78ba      	ldrb	r2, [r7, #2]
 8000e22:	f107 0308 	add.w	r3, r7, #8
 8000e26:	4611      	mov	r1, r2
 8000e28:	4618      	mov	r0, r3
 8000e2a:	f7ff fabb 	bl	80003a4 <GPIO_Init>
}
 8000e2e:	bf00      	nop
 8000e30:	3720      	adds	r7, #32
 8000e32:	46bd      	mov	sp, r7
 8000e34:	bd80      	pop	{r7, pc}
	...

08000e38 <Enable_UART_Periph>:
 * 			based on the peripheral selected by the user.
 *
 * @param	UARTx: Defines which UART peripheral the user chooses, this can be: USART1, USART2 or USART6.
 */
void Enable_UART_Periph(USART_TypeDef *UARTx)
{
 8000e38:	b580      	push	{r7, lr}
 8000e3a:	b082      	sub	sp, #8
 8000e3c:	af00      	add	r7, sp, #0
 8000e3e:	6078      	str	r0, [r7, #4]
	if(UARTx == USART2)
 8000e40:	687b      	ldr	r3, [r7, #4]
 8000e42:	4a1c      	ldr	r2, [pc, #112]	; (8000eb4 <Enable_UART_Periph+0x7c>)
 8000e44:	4293      	cmp	r3, r2
 8000e46:	d10f      	bne.n	8000e68 <Enable_UART_Periph+0x30>
	{

		Select_UART_Periph(GPIOA, Pin2, AF7);
 8000e48:	2207      	movs	r2, #7
 8000e4a:	2102      	movs	r1, #2
 8000e4c:	481a      	ldr	r0, [pc, #104]	; (8000eb8 <Enable_UART_Periph+0x80>)
 8000e4e:	f7ff ffbc 	bl	8000dca <Select_UART_Periph>
		Select_UART_Periph(GPIOD, Pin5, AF7);
 8000e52:	2207      	movs	r2, #7
 8000e54:	2105      	movs	r1, #5
 8000e56:	4819      	ldr	r0, [pc, #100]	; (8000ebc <Enable_UART_Periph+0x84>)
 8000e58:	f7ff ffb7 	bl	8000dca <Select_UART_Periph>

		RCC_APB1Cmd(USART2_Enable, ENABLE);
 8000e5c:	2101      	movs	r1, #1
 8000e5e:	f44f 3000 	mov.w	r0, #131072	; 0x20000
 8000e62:	f7ff feaf 	bl	8000bc4 <RCC_APB1Cmd>
		Select_UART_Periph(GPIOC, Pin6, AF7);

		RCC_APB2Cmd(USART6_Enable, ENABLE);

	}
}
 8000e66:	e020      	b.n	8000eaa <Enable_UART_Periph+0x72>
	else if(UARTx == USART1)
 8000e68:	687b      	ldr	r3, [r7, #4]
 8000e6a:	4a15      	ldr	r2, [pc, #84]	; (8000ec0 <Enable_UART_Periph+0x88>)
 8000e6c:	4293      	cmp	r3, r2
 8000e6e:	d10e      	bne.n	8000e8e <Enable_UART_Periph+0x56>
		Select_UART_Periph(GPIOA, Pin9, AF7);
 8000e70:	2207      	movs	r2, #7
 8000e72:	2109      	movs	r1, #9
 8000e74:	4810      	ldr	r0, [pc, #64]	; (8000eb8 <Enable_UART_Periph+0x80>)
 8000e76:	f7ff ffa8 	bl	8000dca <Select_UART_Periph>
		Select_UART_Periph(GPIOB, Pin6, AF7);
 8000e7a:	2207      	movs	r2, #7
 8000e7c:	2106      	movs	r1, #6
 8000e7e:	4811      	ldr	r0, [pc, #68]	; (8000ec4 <Enable_UART_Periph+0x8c>)
 8000e80:	f7ff ffa3 	bl	8000dca <Select_UART_Periph>
		RCC_APB2Cmd(USART1_Enable, ENABLE);
 8000e84:	2101      	movs	r1, #1
 8000e86:	2010      	movs	r0, #16
 8000e88:	f7ff febc 	bl	8000c04 <RCC_APB2Cmd>
}
 8000e8c:	e00d      	b.n	8000eaa <Enable_UART_Periph+0x72>
		Select_UART_Periph(GPIOA, Pin11, AF8);
 8000e8e:	2208      	movs	r2, #8
 8000e90:	210b      	movs	r1, #11
 8000e92:	4809      	ldr	r0, [pc, #36]	; (8000eb8 <Enable_UART_Periph+0x80>)
 8000e94:	f7ff ff99 	bl	8000dca <Select_UART_Periph>
		Select_UART_Periph(GPIOC, Pin6, AF7);
 8000e98:	2207      	movs	r2, #7
 8000e9a:	2106      	movs	r1, #6
 8000e9c:	480a      	ldr	r0, [pc, #40]	; (8000ec8 <Enable_UART_Periph+0x90>)
 8000e9e:	f7ff ff94 	bl	8000dca <Select_UART_Periph>
		RCC_APB2Cmd(USART6_Enable, ENABLE);
 8000ea2:	2101      	movs	r1, #1
 8000ea4:	2020      	movs	r0, #32
 8000ea6:	f7ff fead 	bl	8000c04 <RCC_APB2Cmd>
}
 8000eaa:	bf00      	nop
 8000eac:	3708      	adds	r7, #8
 8000eae:	46bd      	mov	sp, r7
 8000eb0:	bd80      	pop	{r7, pc}
 8000eb2:	bf00      	nop
 8000eb4:	40004400 	.word	0x40004400
 8000eb8:	40020000 	.word	0x40020000
 8000ebc:	40020c00 	.word	0x40020c00
 8000ec0:	40011000 	.word	0x40011000
 8000ec4:	40020400 	.word	0x40020400
 8000ec8:	40020800 	.word	0x40020800

08000ecc <Set_BaudRate>:
 *@param	ClockSource: Defines the specific clock source for the MCU which includes SYSCLK,
 *			HCLK, PCLK1, PCLK2.
 *
 */
void Set_BaudRate(RCC_ClockFrequency_t *ClockSource, UART_Config_t *UART_Config)
{
 8000ecc:	b580      	push	{r7, lr}
 8000ece:	b08a      	sub	sp, #40	; 0x28
 8000ed0:	af00      	add	r7, sp, #0
 8000ed2:	6078      	str	r0, [r7, #4]
 8000ed4:	6039      	str	r1, [r7, #0]
	RCC_GetClockFreq(ClockSource);
 8000ed6:	6878      	ldr	r0, [r7, #4]
 8000ed8:	f7ff feb4 	bl	8000c44 <RCC_GetClockFreq>

	uint32_t periph_clk, over8, usartdiv, baudrate;
	uint32_t mantissa_value, fraction_value, tempvariable = 0;
 8000edc:	2300      	movs	r3, #0
 8000ede:	623b      	str	r3, [r7, #32]

	over8 = (UART_Config->UARTx->CR1) & (UART_CR1_OVER8_Mask);
 8000ee0:	683b      	ldr	r3, [r7, #0]
 8000ee2:	691b      	ldr	r3, [r3, #16]
 8000ee4:	68db      	ldr	r3, [r3, #12]
 8000ee6:	f403 4300 	and.w	r3, r3, #32768	; 0x8000
 8000eea:	61fb      	str	r3, [r7, #28]
	baudrate = UART_Config->BaudRate;
 8000eec:	683b      	ldr	r3, [r7, #0]
 8000eee:	689b      	ldr	r3, [r3, #8]
 8000ef0:	61bb      	str	r3, [r7, #24]

	if(UART_Config->UARTx == USART2)
 8000ef2:	683b      	ldr	r3, [r7, #0]
 8000ef4:	691b      	ldr	r3, [r3, #16]
 8000ef6:	4a32      	ldr	r2, [pc, #200]	; (8000fc0 <Set_BaudRate+0xf4>)
 8000ef8:	4293      	cmp	r3, r2
 8000efa:	d103      	bne.n	8000f04 <Set_BaudRate+0x38>
	{
		periph_clk = ClockSource->PCLCK1;
 8000efc:	687b      	ldr	r3, [r7, #4]
 8000efe:	689b      	ldr	r3, [r3, #8]
 8000f00:	627b      	str	r3, [r7, #36]	; 0x24
 8000f02:	e002      	b.n	8000f0a <Set_BaudRate+0x3e>
	}

	else
	{
		periph_clk = ClockSource->PCLCK2;
 8000f04:	687b      	ldr	r3, [r7, #4]
 8000f06:	68db      	ldr	r3, [r3, #12]
 8000f08:	627b      	str	r3, [r7, #36]	; 0x24
	}

	/*Over-sampling by 16*/
	if(over8 == 0)
 8000f0a:	69fb      	ldr	r3, [r7, #28]
 8000f0c:	2b00      	cmp	r3, #0
 8000f0e:	d125      	bne.n	8000f5c <Set_BaudRate+0x90>
	{
		usartdiv = (periph_clk * 100)/(16 * baudrate);
 8000f10:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 8000f12:	2264      	movs	r2, #100	; 0x64
 8000f14:	fb03 f202 	mul.w	r2, r3, r2
 8000f18:	69bb      	ldr	r3, [r7, #24]
 8000f1a:	011b      	lsls	r3, r3, #4
 8000f1c:	fbb2 f3f3 	udiv	r3, r2, r3
 8000f20:	617b      	str	r3, [r7, #20]
		mantissa_value = usartdiv/100;
 8000f22:	697b      	ldr	r3, [r7, #20]
 8000f24:	4a27      	ldr	r2, [pc, #156]	; (8000fc4 <Set_BaudRate+0xf8>)
 8000f26:	fba2 2303 	umull	r2, r3, r2, r3
 8000f2a:	095b      	lsrs	r3, r3, #5
 8000f2c:	613b      	str	r3, [r7, #16]
		tempvariable |= mantissa_value << 4;
 8000f2e:	693b      	ldr	r3, [r7, #16]
 8000f30:	011b      	lsls	r3, r3, #4
 8000f32:	6a3a      	ldr	r2, [r7, #32]
 8000f34:	4313      	orrs	r3, r2
 8000f36:	623b      	str	r3, [r7, #32]

		fraction_value = (((usartdiv - (mantissa_value * 100)) * 16) + 50)/100;
 8000f38:	693b      	ldr	r3, [r7, #16]
 8000f3a:	2264      	movs	r2, #100	; 0x64
 8000f3c:	fb02 f303 	mul.w	r3, r2, r3
 8000f40:	697a      	ldr	r2, [r7, #20]
 8000f42:	1ad3      	subs	r3, r2, r3
 8000f44:	011b      	lsls	r3, r3, #4
 8000f46:	3332      	adds	r3, #50	; 0x32
 8000f48:	4a1e      	ldr	r2, [pc, #120]	; (8000fc4 <Set_BaudRate+0xf8>)
 8000f4a:	fba2 2303 	umull	r2, r3, r2, r3
 8000f4e:	095b      	lsrs	r3, r3, #5
 8000f50:	60fb      	str	r3, [r7, #12]
		tempvariable |= fraction_value;
 8000f52:	6a3a      	ldr	r2, [r7, #32]
 8000f54:	68fb      	ldr	r3, [r7, #12]
 8000f56:	4313      	orrs	r3, r2
 8000f58:	623b      	str	r3, [r7, #32]
 8000f5a:	e024      	b.n	8000fa6 <Set_BaudRate+0xda>
	}

	/*Over-sampling by 8*/
	else
	{
		usartdiv = ((periph_clk * 100)/(8 * baudrate));
 8000f5c:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 8000f5e:	2264      	movs	r2, #100	; 0x64
 8000f60:	fb03 f202 	mul.w	r2, r3, r2
 8000f64:	69bb      	ldr	r3, [r7, #24]
 8000f66:	00db      	lsls	r3, r3, #3
 8000f68:	fbb2 f3f3 	udiv	r3, r2, r3
 8000f6c:	617b      	str	r3, [r7, #20]
		mantissa_value = usartdiv/100;
 8000f6e:	697b      	ldr	r3, [r7, #20]
 8000f70:	4a14      	ldr	r2, [pc, #80]	; (8000fc4 <Set_BaudRate+0xf8>)
 8000f72:	fba2 2303 	umull	r2, r3, r2, r3
 8000f76:	095b      	lsrs	r3, r3, #5
 8000f78:	613b      	str	r3, [r7, #16]
		tempvariable |= (mantissa_value << 4);
 8000f7a:	693b      	ldr	r3, [r7, #16]
 8000f7c:	011b      	lsls	r3, r3, #4
 8000f7e:	6a3a      	ldr	r2, [r7, #32]
 8000f80:	4313      	orrs	r3, r2
 8000f82:	623b      	str	r3, [r7, #32]
		fraction_value = (((usartdiv - (mantissa_value * 100)) * 8) + 50)/100;
 8000f84:	693b      	ldr	r3, [r7, #16]
 8000f86:	2264      	movs	r2, #100	; 0x64
 8000f88:	fb02 f303 	mul.w	r3, r2, r3
 8000f8c:	697a      	ldr	r2, [r7, #20]
 8000f8e:	1ad3      	subs	r3, r2, r3
 8000f90:	00db      	lsls	r3, r3, #3
 8000f92:	3332      	adds	r3, #50	; 0x32
 8000f94:	4a0b      	ldr	r2, [pc, #44]	; (8000fc4 <Set_BaudRate+0xf8>)
 8000f96:	fba2 2303 	umull	r2, r3, r2, r3
 8000f9a:	095b      	lsrs	r3, r3, #5
 8000f9c:	60fb      	str	r3, [r7, #12]
		tempvariable |= fraction_value;
 8000f9e:	6a3a      	ldr	r2, [r7, #32]
 8000fa0:	68fb      	ldr	r3, [r7, #12]
 8000fa2:	4313      	orrs	r3, r2
 8000fa4:	623b      	str	r3, [r7, #32]
	}

	UART_Config->UARTx->BRR |= tempvariable;
 8000fa6:	683b      	ldr	r3, [r7, #0]
 8000fa8:	691b      	ldr	r3, [r3, #16]
 8000faa:	6899      	ldr	r1, [r3, #8]
 8000fac:	683b      	ldr	r3, [r7, #0]
 8000fae:	691b      	ldr	r3, [r3, #16]
 8000fb0:	6a3a      	ldr	r2, [r7, #32]
 8000fb2:	430a      	orrs	r2, r1
 8000fb4:	609a      	str	r2, [r3, #8]
}
 8000fb6:	bf00      	nop
 8000fb8:	3728      	adds	r7, #40	; 0x28
 8000fba:	46bd      	mov	sp, r7
 8000fbc:	bd80      	pop	{r7, pc}
 8000fbe:	bf00      	nop
 8000fc0:	40004400 	.word	0x40004400
 8000fc4:	51eb851f 	.word	0x51eb851f

08000fc8 <UART_Init>:
 *
 * @param	UART_Config_t: This points to the UART_Config_t data structure that holds all of the information for the
 * 			specific UART peripheral.
 */
void UART_Init(UART_Config_t *UART_Config)
{
 8000fc8:	b580      	push	{r7, lr}
 8000fca:	b086      	sub	sp, #24
 8000fcc:	af00      	add	r7, sp, #0
 8000fce:	6078      	str	r0, [r7, #4]
	RCC_ClockFrequency_t Clock_Source;

	Enable_UART_Periph(UART_Config->UARTx);
 8000fd0:	687b      	ldr	r3, [r7, #4]
 8000fd2:	691b      	ldr	r3, [r3, #16]
 8000fd4:	4618      	mov	r0, r3
 8000fd6:	f7ff ff2f 	bl	8000e38 <Enable_UART_Periph>

	/**Configuring UART**/

	/*Select the Word-Length (8 bits/9 bits)*/
	UART_Config->UARTx->CR1 &= ~UART_WORDLEN_9BITS;
 8000fda:	687b      	ldr	r3, [r7, #4]
 8000fdc:	691b      	ldr	r3, [r3, #16]
 8000fde:	68da      	ldr	r2, [r3, #12]
 8000fe0:	687b      	ldr	r3, [r7, #4]
 8000fe2:	691b      	ldr	r3, [r3, #16]
 8000fe4:	f422 5280 	bic.w	r2, r2, #4096	; 0x1000
 8000fe8:	60da      	str	r2, [r3, #12]
	UART_Config->UARTx->CR1 |= UART_Config->World_Length;
 8000fea:	687b      	ldr	r3, [r7, #4]
 8000fec:	691b      	ldr	r3, [r3, #16]
 8000fee:	68da      	ldr	r2, [r3, #12]
 8000ff0:	687b      	ldr	r3, [r7, #4]
 8000ff2:	885b      	ldrh	r3, [r3, #2]
 8000ff4:	4619      	mov	r1, r3
 8000ff6:	687b      	ldr	r3, [r7, #4]
 8000ff8:	691b      	ldr	r3, [r3, #16]
 8000ffa:	430a      	orrs	r2, r1
 8000ffc:	60da      	str	r2, [r3, #12]

	/*Select over-sampling (8 or 16)*/
	UART_Config->UARTx->CR1 &= ~UART_OVERSAMPLING_8;
 8000ffe:	687b      	ldr	r3, [r7, #4]
 8001000:	691b      	ldr	r3, [r3, #16]
 8001002:	68da      	ldr	r2, [r3, #12]
 8001004:	687b      	ldr	r3, [r7, #4]
 8001006:	691b      	ldr	r3, [r3, #16]
 8001008:	f422 4200 	bic.w	r2, r2, #32768	; 0x8000
 800100c:	60da      	str	r2, [r3, #12]
	UART_Config->UARTx->CR1 |= UART_Config->oversampling;
 800100e:	687b      	ldr	r3, [r7, #4]
 8001010:	691b      	ldr	r3, [r3, #16]
 8001012:	68da      	ldr	r2, [r3, #12]
 8001014:	687b      	ldr	r3, [r7, #4]
 8001016:	889b      	ldrh	r3, [r3, #4]
 8001018:	4619      	mov	r1, r3
 800101a:	687b      	ldr	r3, [r7, #4]
 800101c:	691b      	ldr	r3, [r3, #16]
 800101e:	430a      	orrs	r2, r1
 8001020:	60da      	str	r2, [r3, #12]

	/*Select transmission direction (Tx, Rx or Tx & Rx)*/
	UART_Config->UARTx->CR1 &= ~UART_MODE_TXRX;
 8001022:	687b      	ldr	r3, [r7, #4]
 8001024:	691b      	ldr	r3, [r3, #16]
 8001026:	68da      	ldr	r2, [r3, #12]
 8001028:	687b      	ldr	r3, [r7, #4]
 800102a:	691b      	ldr	r3, [r3, #16]
 800102c:	f022 020c 	bic.w	r2, r2, #12
 8001030:	60da      	str	r2, [r3, #12]
	UART_Config->UARTx->CR1 |= UART_Config->Mode;
 8001032:	687b      	ldr	r3, [r7, #4]
 8001034:	691b      	ldr	r3, [r3, #16]
 8001036:	68da      	ldr	r2, [r3, #12]
 8001038:	687b      	ldr	r3, [r7, #4]
 800103a:	899b      	ldrh	r3, [r3, #12]
 800103c:	4619      	mov	r1, r3
 800103e:	687b      	ldr	r3, [r7, #4]
 8001040:	691b      	ldr	r3, [r3, #16]
 8001042:	430a      	orrs	r2, r1
 8001044:	60da      	str	r2, [r3, #12]

	/*Select parity (odd or even)*/
	UART_Config->UARTx->CR1 &= ~UART_PARITY_ODD;
 8001046:	687b      	ldr	r3, [r7, #4]
 8001048:	691b      	ldr	r3, [r3, #16]
 800104a:	68da      	ldr	r2, [r3, #12]
 800104c:	687b      	ldr	r3, [r7, #4]
 800104e:	691b      	ldr	r3, [r3, #16]
 8001050:	f422 62c0 	bic.w	r2, r2, #1536	; 0x600
 8001054:	60da      	str	r2, [r3, #12]
	UART_Config->UARTx->CR1 |= UART_Config->Parity;
 8001056:	687b      	ldr	r3, [r7, #4]
 8001058:	691b      	ldr	r3, [r3, #16]
 800105a:	68da      	ldr	r2, [r3, #12]
 800105c:	687b      	ldr	r3, [r7, #4]
 800105e:	88db      	ldrh	r3, [r3, #6]
 8001060:	4619      	mov	r1, r3
 8001062:	687b      	ldr	r3, [r7, #4]
 8001064:	691b      	ldr	r3, [r3, #16]
 8001066:	430a      	orrs	r2, r1
 8001068:	60da      	str	r2, [r3, #12]

	/*Select number of stop bits (0.5, 1, 1.5, 2)*/
	UART_Config->UARTx->CR2 &= ~UART_STOPBITS_1_5;
 800106a:	687b      	ldr	r3, [r7, #4]
 800106c:	691b      	ldr	r3, [r3, #16]
 800106e:	691a      	ldr	r2, [r3, #16]
 8001070:	687b      	ldr	r3, [r7, #4]
 8001072:	691b      	ldr	r3, [r3, #16]
 8001074:	f422 5240 	bic.w	r2, r2, #12288	; 0x3000
 8001078:	611a      	str	r2, [r3, #16]
	UART_Config->UARTx->CR2 |= UART_Config->Stop_Bits;
 800107a:	687b      	ldr	r3, [r7, #4]
 800107c:	691b      	ldr	r3, [r3, #16]
 800107e:	691a      	ldr	r2, [r3, #16]
 8001080:	687b      	ldr	r3, [r7, #4]
 8001082:	881b      	ldrh	r3, [r3, #0]
 8001084:	4619      	mov	r1, r3
 8001086:	687b      	ldr	r3, [r7, #4]
 8001088:	691b      	ldr	r3, [r3, #16]
 800108a:	430a      	orrs	r2, r1
 800108c:	611a      	str	r2, [r3, #16]

	/*Calculate and set baud-rate*/
	Set_BaudRate(&Clock_Source, UART_Config);
 800108e:	f107 0308 	add.w	r3, r7, #8
 8001092:	6879      	ldr	r1, [r7, #4]
 8001094:	4618      	mov	r0, r3
 8001096:	f7ff ff19 	bl	8000ecc <Set_BaudRate>

	/*Enable UART*/
	UART_Config->UARTx->CR1 |= UART_CR1_Enable;
 800109a:	687b      	ldr	r3, [r7, #4]
 800109c:	691b      	ldr	r3, [r3, #16]
 800109e:	68da      	ldr	r2, [r3, #12]
 80010a0:	687b      	ldr	r3, [r7, #4]
 80010a2:	691b      	ldr	r3, [r3, #16]
 80010a4:	f442 5200 	orr.w	r2, r2, #8192	; 0x2000
 80010a8:	60da      	str	r2, [r3, #12]

}
 80010aa:	bf00      	nop
 80010ac:	3718      	adds	r7, #24
 80010ae:	46bd      	mov	sp, r7
 80010b0:	bd80      	pop	{r7, pc}

080010b2 <WriteByte>:
 * 			specific UART peripheral.
 *
 * @param	data: This specifies the data the user wishes to transmit.
 */
void WriteByte(UART_Config_t *UART_Config, uint16_t data)
{
 80010b2:	b480      	push	{r7}
 80010b4:	b083      	sub	sp, #12
 80010b6:	af00      	add	r7, sp, #0
 80010b8:	6078      	str	r0, [r7, #4]
 80010ba:	460b      	mov	r3, r1
 80010bc:	807b      	strh	r3, [r7, #2]
	while(!(UART_Config->UARTx->SR) && (UART_SR_TXE_Mask)){}
 80010be:	bf00      	nop
 80010c0:	687b      	ldr	r3, [r7, #4]
 80010c2:	691b      	ldr	r3, [r3, #16]
 80010c4:	681b      	ldr	r3, [r3, #0]
 80010c6:	2b00      	cmp	r3, #0
 80010c8:	d0fa      	beq.n	80010c0 <WriteByte+0xe>

	//Word length is 9 bits
	if(UART_Config->UARTx->CR1 & UART_WORDLEN_9BITS)
 80010ca:	687b      	ldr	r3, [r7, #4]
 80010cc:	691b      	ldr	r3, [r3, #16]
 80010ce:	68db      	ldr	r3, [r3, #12]
 80010d0:	f403 5380 	and.w	r3, r3, #4096	; 0x1000
 80010d4:	2b00      	cmp	r3, #0
 80010d6:	d01a      	beq.n	800110e <WriteByte+0x5c>
	{
		//If parity is enabled 8 bits of data are sent with the 9th bit being the parity bit
		if((UART_Config->UARTx->CR1 & UART_PARITY_EVEN) || (UART_Config->UARTx->CR1 & UART_PARITY_ODD))
 80010d8:	687b      	ldr	r3, [r7, #4]
 80010da:	691b      	ldr	r3, [r3, #16]
 80010dc:	68db      	ldr	r3, [r3, #12]
 80010de:	f403 6380 	and.w	r3, r3, #1024	; 0x400
 80010e2:	2b00      	cmp	r3, #0
 80010e4:	d106      	bne.n	80010f4 <WriteByte+0x42>
 80010e6:	687b      	ldr	r3, [r7, #4]
 80010e8:	691b      	ldr	r3, [r3, #16]
 80010ea:	68db      	ldr	r3, [r3, #12]
 80010ec:	f403 63c0 	and.w	r3, r3, #1536	; 0x600
 80010f0:	2b00      	cmp	r3, #0
 80010f2:	d005      	beq.n	8001100 <WriteByte+0x4e>
		{
			UART_Config->UARTx->DR = ((uint8_t)data);
 80010f4:	887b      	ldrh	r3, [r7, #2]
 80010f6:	b2da      	uxtb	r2, r3
 80010f8:	687b      	ldr	r3, [r7, #4]
 80010fa:	691b      	ldr	r3, [r3, #16]
 80010fc:	605a      	str	r2, [r3, #4]
 80010fe:	e021      	b.n	8001144 <WriteByte+0x92>
		}

		//If parity is disabled then all 9 bits of data will be read as information
		else
		{
			UART_Config->UARTx->DR = (data & 0x1FF);
 8001100:	887a      	ldrh	r2, [r7, #2]
 8001102:	687b      	ldr	r3, [r7, #4]
 8001104:	691b      	ldr	r3, [r3, #16]
 8001106:	f3c2 0208 	ubfx	r2, r2, #0, #9
 800110a:	605a      	str	r2, [r3, #4]
		else
		{
			UART_Config->UARTx->DR = ((uint8_t)data);
		}
	}
}
 800110c:	e01a      	b.n	8001144 <WriteByte+0x92>
		if((UART_Config->UARTx->CR1 & UART_PARITY_EVEN) || (UART_Config->UARTx->CR1 & UART_PARITY_ODD))
 800110e:	687b      	ldr	r3, [r7, #4]
 8001110:	691b      	ldr	r3, [r3, #16]
 8001112:	68db      	ldr	r3, [r3, #12]
 8001114:	f403 6380 	and.w	r3, r3, #1024	; 0x400
 8001118:	2b00      	cmp	r3, #0
 800111a:	d106      	bne.n	800112a <WriteByte+0x78>
 800111c:	687b      	ldr	r3, [r7, #4]
 800111e:	691b      	ldr	r3, [r3, #16]
 8001120:	68db      	ldr	r3, [r3, #12]
 8001122:	f403 63c0 	and.w	r3, r3, #1536	; 0x600
 8001126:	2b00      	cmp	r3, #0
 8001128:	d006      	beq.n	8001138 <WriteByte+0x86>
			UART_Config->UARTx->DR = (data & 0x7F);
 800112a:	887a      	ldrh	r2, [r7, #2]
 800112c:	687b      	ldr	r3, [r7, #4]
 800112e:	691b      	ldr	r3, [r3, #16]
 8001130:	f002 027f 	and.w	r2, r2, #127	; 0x7f
 8001134:	605a      	str	r2, [r3, #4]
 8001136:	e005      	b.n	8001144 <WriteByte+0x92>
			UART_Config->UARTx->DR = ((uint8_t)data);
 8001138:	887b      	ldrh	r3, [r7, #2]
 800113a:	b2da      	uxtb	r2, r3
 800113c:	687b      	ldr	r3, [r7, #4]
 800113e:	691b      	ldr	r3, [r3, #16]
 8001140:	605a      	str	r2, [r3, #4]
}
 8001142:	e7ff      	b.n	8001144 <WriteByte+0x92>
 8001144:	bf00      	nop
 8001146:	370c      	adds	r7, #12
 8001148:	46bd      	mov	sp, r7
 800114a:	f85d 7b04 	ldr.w	r7, [sp], #4
 800114e:	4770      	bx	lr

08001150 <main>:

I2C_Handle_t I2C_Example;
UART_Config_t UART2;

int main()
{
 8001150:	b580      	push	{r7, lr}
 8001152:	b088      	sub	sp, #32
 8001154:	af02      	add	r7, sp, #8
	//This data represents: 06:47:00 AM on 01/14/2023 with the clock kept in 24 hour mode
	uint8_t output_data[8] = {0x00, 0, 71, 6, 7, 20, 1, 35};
 8001156:	4a28      	ldr	r2, [pc, #160]	; (80011f8 <main+0xa8>)
 8001158:	f107 030c 	add.w	r3, r7, #12
 800115c:	e892 0003 	ldmia.w	r2, {r0, r1}
 8001160:	e883 0003 	stmia.w	r3, {r0, r1}
	uint8_t output_register_address[1] = {0x00};
 8001164:	2300      	movs	r3, #0
 8001166:	723b      	strb	r3, [r7, #8]
	uint8_t input_data[7];

	//Configure UART settings
	UART_Config(&UART2, USART2, UART_MODE_TX, 115200);
 8001168:	f44f 33e1 	mov.w	r3, #115200	; 0x1c200
 800116c:	2208      	movs	r2, #8
 800116e:	4923      	ldr	r1, [pc, #140]	; (80011fc <main+0xac>)
 8001170:	4823      	ldr	r0, [pc, #140]	; (8001200 <main+0xb0>)
 8001172:	f7ff fe07 	bl	8000d84 <UART_Config>

	//Initilize the UART
	UART_Init(&UART2);
 8001176:	4822      	ldr	r0, [pc, #136]	; (8001200 <main+0xb0>)
 8001178:	f7ff ff26 	bl	8000fc8 <UART_Init>

	//Configure the I2C clock settings
	I2C_Config(&I2C_Example, I2C1, SM_100KHZ, FM_DUTY_2, Pin8, Pin9);
 800117c:	2309      	movs	r3, #9
 800117e:	9301      	str	r3, [sp, #4]
 8001180:	2308      	movs	r3, #8
 8001182:	9300      	str	r3, [sp, #0]
 8001184:	2300      	movs	r3, #0
 8001186:	4a1f      	ldr	r2, [pc, #124]	; (8001204 <main+0xb4>)
 8001188:	491f      	ldr	r1, [pc, #124]	; (8001208 <main+0xb8>)
 800118a:	4820      	ldr	r0, [pc, #128]	; (800120c <main+0xbc>)
 800118c:	f7ff fade 	bl	800074c <I2C_Config>

	//Initialize I2C
	I2C_Init(&I2C_Example);
 8001190:	481e      	ldr	r0, [pc, #120]	; (800120c <main+0xbc>)
 8001192:	f7ff fb25 	bl	80007e0 <I2C_Init>

	//Transmit data into the real time clock
	I2C_MasterTransmit(&I2C_Example, output_data, slave_address, 8, I2C_Restart);
 8001196:	2268      	movs	r2, #104	; 0x68
 8001198:	f107 010c 	add.w	r1, r7, #12
 800119c:	2301      	movs	r3, #1
 800119e:	9300      	str	r3, [sp, #0]
 80011a0:	2308      	movs	r3, #8
 80011a2:	481a      	ldr	r0, [pc, #104]	; (800120c <main+0xbc>)
 80011a4:	f7ff fc06 	bl	80009b4 <I2C_MasterTransmit>

	//Transmit 0x0 to return the address pointer to the top of the stack in the slave
	I2C_MasterTransmit(&I2C_Example, output_register_address, slave_address, 1, I2C_Restart);
 80011a8:	2268      	movs	r2, #104	; 0x68
 80011aa:	f107 0108 	add.w	r1, r7, #8
 80011ae:	2301      	movs	r3, #1
 80011b0:	9300      	str	r3, [sp, #0]
 80011b2:	2301      	movs	r3, #1
 80011b4:	4815      	ldr	r0, [pc, #84]	; (800120c <main+0xbc>)
 80011b6:	f7ff fbfd 	bl	80009b4 <I2C_MasterTransmit>

	//Read the data from the slave
	I2C_MasterRecieve(&I2C_Example, input_data, slave_address, 7, I2C_No_Restart);
 80011ba:	2268      	movs	r2, #104	; 0x68
 80011bc:	4639      	mov	r1, r7
 80011be:	2300      	movs	r3, #0
 80011c0:	9300      	str	r3, [sp, #0]
 80011c2:	2307      	movs	r3, #7
 80011c4:	4811      	ldr	r0, [pc, #68]	; (800120c <main+0xbc>)
 80011c6:	f7ff fc5b 	bl	8000a80 <I2C_MasterRecieve>

	for(int i = 0; i < 8; i++)
 80011ca:	2300      	movs	r3, #0
 80011cc:	617b      	str	r3, [r7, #20]
 80011ce:	e00b      	b.n	80011e8 <main+0x98>
	{
		//For purpose of debugging, I chose to print each byte individually as opposed to printing the array all at once
		WriteByte(&UART2, input_data[i]);
 80011d0:	463a      	mov	r2, r7
 80011d2:	697b      	ldr	r3, [r7, #20]
 80011d4:	4413      	add	r3, r2
 80011d6:	781b      	ldrb	r3, [r3, #0]
 80011d8:	b29b      	uxth	r3, r3
 80011da:	4619      	mov	r1, r3
 80011dc:	4808      	ldr	r0, [pc, #32]	; (8001200 <main+0xb0>)
 80011de:	f7ff ff68 	bl	80010b2 <WriteByte>
	for(int i = 0; i < 8; i++)
 80011e2:	697b      	ldr	r3, [r7, #20]
 80011e4:	3301      	adds	r3, #1
 80011e6:	617b      	str	r3, [r7, #20]
 80011e8:	697b      	ldr	r3, [r7, #20]
 80011ea:	2b07      	cmp	r3, #7
 80011ec:	ddf0      	ble.n	80011d0 <main+0x80>
	}

	//Deactivate I2C access
	I2C_DeInit(&I2C_Example);
 80011ee:	4807      	ldr	r0, [pc, #28]	; (800120c <main+0xbc>)
 80011f0:	f7ff fac8 	bl	8000784 <I2C_DeInit>


	while(1)
 80011f4:	e7fe      	b.n	80011f4 <main+0xa4>
 80011f6:	bf00      	nop
 80011f8:	080012c4 	.word	0x080012c4
 80011fc:	40004400 	.word	0x40004400
 8001200:	2000005c 	.word	0x2000005c
 8001204:	000186a0 	.word	0x000186a0
 8001208:	40005400 	.word	0x40005400
 800120c:	2000003c 	.word	0x2000003c

08001210 <Reset_Handler>:

  .section .text.Reset_Handler
  .weak Reset_Handler
  .type Reset_Handler, %function
Reset_Handler:
  ldr   r0, =_estack
 8001210:	480d      	ldr	r0, [pc, #52]	; (8001248 <LoopForever+0x2>)
  mov   sp, r0          /* set stack pointer */
 8001212:	4685      	mov	sp, r0
/* Call the clock system initialization function.*/
  bl  SystemInit
 8001214:	f3af 8000 	nop.w

/* Copy the data segment initializers from flash to SRAM */
  ldr r0, =_sdata
 8001218:	480c      	ldr	r0, [pc, #48]	; (800124c <LoopForever+0x6>)
  ldr r1, =_edata
 800121a:	490d      	ldr	r1, [pc, #52]	; (8001250 <LoopForever+0xa>)
  ldr r2, =_sidata
 800121c:	4a0d      	ldr	r2, [pc, #52]	; (8001254 <LoopForever+0xe>)
  movs r3, #0
 800121e:	2300      	movs	r3, #0
  b LoopCopyDataInit
 8001220:	e002      	b.n	8001228 <LoopCopyDataInit>

08001222 <CopyDataInit>:

CopyDataInit:
  ldr r4, [r2, r3]
 8001222:	58d4      	ldr	r4, [r2, r3]
  str r4, [r0, r3]
 8001224:	50c4      	str	r4, [r0, r3]
  adds r3, r3, #4
 8001226:	3304      	adds	r3, #4

08001228 <LoopCopyDataInit>:

LoopCopyDataInit:
  adds r4, r0, r3
 8001228:	18c4      	adds	r4, r0, r3
  cmp r4, r1
 800122a:	428c      	cmp	r4, r1
  bcc CopyDataInit
 800122c:	d3f9      	bcc.n	8001222 <CopyDataInit>

/* Zero fill the bss segment. */
  ldr r2, =_sbss
 800122e:	4a0a      	ldr	r2, [pc, #40]	; (8001258 <LoopForever+0x12>)
  ldr r4, =_ebss
 8001230:	4c0a      	ldr	r4, [pc, #40]	; (800125c <LoopForever+0x16>)
  movs r3, #0
 8001232:	2300      	movs	r3, #0
  b LoopFillZerobss
 8001234:	e001      	b.n	800123a <LoopFillZerobss>

08001236 <FillZerobss>:

FillZerobss:
  str  r3, [r2]
 8001236:	6013      	str	r3, [r2, #0]
  adds r2, r2, #4
 8001238:	3204      	adds	r2, #4

0800123a <LoopFillZerobss>:

LoopFillZerobss:
  cmp r2, r4
 800123a:	42a2      	cmp	r2, r4
  bcc FillZerobss
 800123c:	d3fb      	bcc.n	8001236 <FillZerobss>

/* Call static constructors */
  bl __libc_init_array
 800123e:	f000 f811 	bl	8001264 <__libc_init_array>
/* Call the application's entry point.*/
  bl main
 8001242:	f7ff ff85 	bl	8001150 <main>

08001246 <LoopForever>:

LoopForever:
  b LoopForever
 8001246:	e7fe      	b.n	8001246 <LoopForever>
  ldr   r0, =_estack
 8001248:	20018000 	.word	0x20018000
  ldr r0, =_sdata
 800124c:	20000000 	.word	0x20000000
  ldr r1, =_edata
 8001250:	20000020 	.word	0x20000020
  ldr r2, =_sidata
 8001254:	080012d4 	.word	0x080012d4
  ldr r2, =_sbss
 8001258:	20000020 	.word	0x20000020
  ldr r4, =_ebss
 800125c:	20000070 	.word	0x20000070

08001260 <ADC_IRQHandler>:
 * @retval : None
*/
  .section .text.Default_Handler,"ax",%progbits
Default_Handler:
Infinite_Loop:
  b Infinite_Loop
 8001260:	e7fe      	b.n	8001260 <ADC_IRQHandler>
	...

08001264 <__libc_init_array>:
 8001264:	b570      	push	{r4, r5, r6, lr}
 8001266:	4d0d      	ldr	r5, [pc, #52]	; (800129c <__libc_init_array+0x38>)
 8001268:	4c0d      	ldr	r4, [pc, #52]	; (80012a0 <__libc_init_array+0x3c>)
 800126a:	1b64      	subs	r4, r4, r5
 800126c:	10a4      	asrs	r4, r4, #2
 800126e:	2600      	movs	r6, #0
 8001270:	42a6      	cmp	r6, r4
 8001272:	d109      	bne.n	8001288 <__libc_init_array+0x24>
 8001274:	4d0b      	ldr	r5, [pc, #44]	; (80012a4 <__libc_init_array+0x40>)
 8001276:	4c0c      	ldr	r4, [pc, #48]	; (80012a8 <__libc_init_array+0x44>)
 8001278:	f000 f818 	bl	80012ac <_init>
 800127c:	1b64      	subs	r4, r4, r5
 800127e:	10a4      	asrs	r4, r4, #2
 8001280:	2600      	movs	r6, #0
 8001282:	42a6      	cmp	r6, r4
 8001284:	d105      	bne.n	8001292 <__libc_init_array+0x2e>
 8001286:	bd70      	pop	{r4, r5, r6, pc}
 8001288:	f855 3b04 	ldr.w	r3, [r5], #4
 800128c:	4798      	blx	r3
 800128e:	3601      	adds	r6, #1
 8001290:	e7ee      	b.n	8001270 <__libc_init_array+0xc>
 8001292:	f855 3b04 	ldr.w	r3, [r5], #4
 8001296:	4798      	blx	r3
 8001298:	3601      	adds	r6, #1
 800129a:	e7f2      	b.n	8001282 <__libc_init_array+0x1e>
 800129c:	080012cc 	.word	0x080012cc
 80012a0:	080012cc 	.word	0x080012cc
 80012a4:	080012cc 	.word	0x080012cc
 80012a8:	080012d0 	.word	0x080012d0

080012ac <_init>:
 80012ac:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 80012ae:	bf00      	nop
 80012b0:	bcf8      	pop	{r3, r4, r5, r6, r7}
 80012b2:	bc08      	pop	{r3}
 80012b4:	469e      	mov	lr, r3
 80012b6:	4770      	bx	lr

080012b8 <_fini>:
 80012b8:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 80012ba:	bf00      	nop
 80012bc:	bcf8      	pop	{r3, r4, r5, r6, r7}
 80012be:	bc08      	pop	{r3}
 80012c0:	469e      	mov	lr, r3
 80012c2:	4770      	bx	lr
