
lab_8.elf:     file format elf32-littlearm

Sections:
Idx Name          Size      VMA       LMA       File off  Algn
  0 .isr_vector   000001f8  08000000  08000000  00010000  2**0
                  CONTENTS, ALLOC, LOAD, READONLY, DATA
  1 .text         00008a58  08000200  08000200  00010200  2**4
                  CONTENTS, ALLOC, LOAD, READONLY, CODE
  2 .rodata       00025d18  08008c58  08008c58  00018c58  2**3
                  CONTENTS, ALLOC, LOAD, READONLY, DATA
  3 .ARM.extab    00000000  0802e970  0802e970  000401e0  2**0
                  CONTENTS
  4 .ARM          00000008  0802e970  0802e970  0003e970  2**2
                  CONTENTS, ALLOC, LOAD, READONLY, DATA
  5 .preinit_array 00000000  0802e978  0802e978  000401e0  2**0
                  CONTENTS, ALLOC, LOAD, DATA
  6 .init_array   00000004  0802e978  0802e978  0003e978  2**2
                  CONTENTS, ALLOC, LOAD, DATA
  7 .fini_array   00000004  0802e97c  0802e97c  0003e97c  2**2
                  CONTENTS, ALLOC, LOAD, DATA
  8 .data         000001e0  20000000  0802e980  00040000  2**2
                  CONTENTS, ALLOC, LOAD, DATA
  9 .bss          00025978  200001e0  0802eb60  000401e0  2**2
                  ALLOC
 10 ._user_heap_stack 00000600  20025b58  0802eb60  00045b58  2**0
                  ALLOC
 11 .ARM.attributes 0000002e  00000000  00000000  000401e0  2**0
                  CONTENTS, READONLY
 12 .debug_info   000140f3  00000000  00000000  0004020e  2**0
                  CONTENTS, READONLY, DEBUGGING
 13 .debug_abbrev 0000300a  00000000  00000000  00054301  2**0
                  CONTENTS, READONLY, DEBUGGING
 14 .debug_aranges 00001190  00000000  00000000  00057310  2**3
                  CONTENTS, READONLY, DEBUGGING
 15 .debug_ranges 00000fd8  00000000  00000000  000584a0  2**3
                  CONTENTS, READONLY, DEBUGGING
 16 .debug_macro  0002a877  00000000  00000000  00059478  2**0
                  CONTENTS, READONLY, DEBUGGING
 17 .debug_line   00012725  00000000  00000000  00083cef  2**0
                  CONTENTS, READONLY, DEBUGGING
 18 .debug_str    000fd923  00000000  00000000  00096414  2**0
                  CONTENTS, READONLY, DEBUGGING
 19 .comment      0000007b  00000000  00000000  00193d37  2**0
                  CONTENTS, READONLY
 20 .debug_frame  000051dc  00000000  00000000  00193db4  2**2
                  CONTENTS, READONLY, DEBUGGING

Disassembly of section .text:

08000200 <__do_global_dtors_aux>:
 8000200:	b510      	push	{r4, lr}
 8000202:	4c05      	ldr	r4, [pc, #20]	; (8000218 <__do_global_dtors_aux+0x18>)
 8000204:	7823      	ldrb	r3, [r4, #0]
 8000206:	b933      	cbnz	r3, 8000216 <__do_global_dtors_aux+0x16>
 8000208:	4b04      	ldr	r3, [pc, #16]	; (800021c <__do_global_dtors_aux+0x1c>)
 800020a:	b113      	cbz	r3, 8000212 <__do_global_dtors_aux+0x12>
 800020c:	4804      	ldr	r0, [pc, #16]	; (8000220 <__do_global_dtors_aux+0x20>)
 800020e:	f3af 8000 	nop.w
 8000212:	2301      	movs	r3, #1
 8000214:	7023      	strb	r3, [r4, #0]
 8000216:	bd10      	pop	{r4, pc}
 8000218:	200001e0 	.word	0x200001e0
 800021c:	00000000 	.word	0x00000000
 8000220:	08008c40 	.word	0x08008c40

08000224 <frame_dummy>:
 8000224:	b508      	push	{r3, lr}
 8000226:	4b03      	ldr	r3, [pc, #12]	; (8000234 <frame_dummy+0x10>)
 8000228:	b11b      	cbz	r3, 8000232 <frame_dummy+0xe>
 800022a:	4903      	ldr	r1, [pc, #12]	; (8000238 <frame_dummy+0x14>)
 800022c:	4803      	ldr	r0, [pc, #12]	; (800023c <frame_dummy+0x18>)
 800022e:	f3af 8000 	nop.w
 8000232:	bd08      	pop	{r3, pc}
 8000234:	00000000 	.word	0x00000000
 8000238:	200001e4 	.word	0x200001e4
 800023c:	08008c40 	.word	0x08008c40

08000240 <strlen>:
 8000240:	4603      	mov	r3, r0
 8000242:	f813 2b01 	ldrb.w	r2, [r3], #1
 8000246:	2a00      	cmp	r2, #0
 8000248:	d1fb      	bne.n	8000242 <strlen+0x2>
 800024a:	1a18      	subs	r0, r3, r0
 800024c:	3801      	subs	r0, #1
 800024e:	4770      	bx	lr

08000250 <memchr>:
 8000250:	f001 01ff 	and.w	r1, r1, #255	; 0xff
 8000254:	2a10      	cmp	r2, #16
 8000256:	db2b      	blt.n	80002b0 <memchr+0x60>
 8000258:	f010 0f07 	tst.w	r0, #7
 800025c:	d008      	beq.n	8000270 <memchr+0x20>
 800025e:	f810 3b01 	ldrb.w	r3, [r0], #1
 8000262:	3a01      	subs	r2, #1
 8000264:	428b      	cmp	r3, r1
 8000266:	d02d      	beq.n	80002c4 <memchr+0x74>
 8000268:	f010 0f07 	tst.w	r0, #7
 800026c:	b342      	cbz	r2, 80002c0 <memchr+0x70>
 800026e:	d1f6      	bne.n	800025e <memchr+0xe>
 8000270:	b4f0      	push	{r4, r5, r6, r7}
 8000272:	ea41 2101 	orr.w	r1, r1, r1, lsl #8
 8000276:	ea41 4101 	orr.w	r1, r1, r1, lsl #16
 800027a:	f022 0407 	bic.w	r4, r2, #7
 800027e:	f07f 0700 	mvns.w	r7, #0
 8000282:	2300      	movs	r3, #0
 8000284:	e8f0 5602 	ldrd	r5, r6, [r0], #8
 8000288:	3c08      	subs	r4, #8
 800028a:	ea85 0501 	eor.w	r5, r5, r1
 800028e:	ea86 0601 	eor.w	r6, r6, r1
 8000292:	fa85 f547 	uadd8	r5, r5, r7
 8000296:	faa3 f587 	sel	r5, r3, r7
 800029a:	fa86 f647 	uadd8	r6, r6, r7
 800029e:	faa5 f687 	sel	r6, r5, r7
 80002a2:	b98e      	cbnz	r6, 80002c8 <memchr+0x78>
 80002a4:	d1ee      	bne.n	8000284 <memchr+0x34>
 80002a6:	bcf0      	pop	{r4, r5, r6, r7}
 80002a8:	f001 01ff 	and.w	r1, r1, #255	; 0xff
 80002ac:	f002 0207 	and.w	r2, r2, #7
 80002b0:	b132      	cbz	r2, 80002c0 <memchr+0x70>
 80002b2:	f810 3b01 	ldrb.w	r3, [r0], #1
 80002b6:	3a01      	subs	r2, #1
 80002b8:	ea83 0301 	eor.w	r3, r3, r1
 80002bc:	b113      	cbz	r3, 80002c4 <memchr+0x74>
 80002be:	d1f8      	bne.n	80002b2 <memchr+0x62>
 80002c0:	2000      	movs	r0, #0
 80002c2:	4770      	bx	lr
 80002c4:	3801      	subs	r0, #1
 80002c6:	4770      	bx	lr
 80002c8:	2d00      	cmp	r5, #0
 80002ca:	bf06      	itte	eq
 80002cc:	4635      	moveq	r5, r6
 80002ce:	3803      	subeq	r0, #3
 80002d0:	3807      	subne	r0, #7
 80002d2:	f015 0f01 	tst.w	r5, #1
 80002d6:	d107      	bne.n	80002e8 <memchr+0x98>
 80002d8:	3001      	adds	r0, #1
 80002da:	f415 7f80 	tst.w	r5, #256	; 0x100
 80002de:	bf02      	ittt	eq
 80002e0:	3001      	addeq	r0, #1
 80002e2:	f415 3fc0 	tsteq.w	r5, #98304	; 0x18000
 80002e6:	3001      	addeq	r0, #1
 80002e8:	bcf0      	pop	{r4, r5, r6, r7}
 80002ea:	3801      	subs	r0, #1
 80002ec:	4770      	bx	lr
 80002ee:	bf00      	nop

080002f0 <__aeabi_uldivmod>:
 80002f0:	b953      	cbnz	r3, 8000308 <__aeabi_uldivmod+0x18>
 80002f2:	b94a      	cbnz	r2, 8000308 <__aeabi_uldivmod+0x18>
 80002f4:	2900      	cmp	r1, #0
 80002f6:	bf08      	it	eq
 80002f8:	2800      	cmpeq	r0, #0
 80002fa:	bf1c      	itt	ne
 80002fc:	f04f 31ff 	movne.w	r1, #4294967295	; 0xffffffff
 8000300:	f04f 30ff 	movne.w	r0, #4294967295	; 0xffffffff
 8000304:	f000 b972 	b.w	80005ec <__aeabi_idiv0>
 8000308:	f1ad 0c08 	sub.w	ip, sp, #8
 800030c:	e96d ce04 	strd	ip, lr, [sp, #-16]!
 8000310:	f000 f806 	bl	8000320 <__udivmoddi4>
 8000314:	f8dd e004 	ldr.w	lr, [sp, #4]
 8000318:	e9dd 2302 	ldrd	r2, r3, [sp, #8]
 800031c:	b004      	add	sp, #16
 800031e:	4770      	bx	lr

08000320 <__udivmoddi4>:
 8000320:	e92d 47f0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, lr}
 8000324:	9e08      	ldr	r6, [sp, #32]
 8000326:	4604      	mov	r4, r0
 8000328:	4688      	mov	r8, r1
 800032a:	2b00      	cmp	r3, #0
 800032c:	d14b      	bne.n	80003c6 <__udivmoddi4+0xa6>
 800032e:	428a      	cmp	r2, r1
 8000330:	4615      	mov	r5, r2
 8000332:	d967      	bls.n	8000404 <__udivmoddi4+0xe4>
 8000334:	fab2 f282 	clz	r2, r2
 8000338:	b14a      	cbz	r2, 800034e <__udivmoddi4+0x2e>
 800033a:	f1c2 0720 	rsb	r7, r2, #32
 800033e:	fa01 f302 	lsl.w	r3, r1, r2
 8000342:	fa20 f707 	lsr.w	r7, r0, r7
 8000346:	4095      	lsls	r5, r2
 8000348:	ea47 0803 	orr.w	r8, r7, r3
 800034c:	4094      	lsls	r4, r2
 800034e:	ea4f 4e15 	mov.w	lr, r5, lsr #16
 8000352:	0c23      	lsrs	r3, r4, #16
 8000354:	fbb8 f7fe 	udiv	r7, r8, lr
 8000358:	fa1f fc85 	uxth.w	ip, r5
 800035c:	fb0e 8817 	mls	r8, lr, r7, r8
 8000360:	ea43 4308 	orr.w	r3, r3, r8, lsl #16
 8000364:	fb07 f10c 	mul.w	r1, r7, ip
 8000368:	4299      	cmp	r1, r3
 800036a:	d909      	bls.n	8000380 <__udivmoddi4+0x60>
 800036c:	18eb      	adds	r3, r5, r3
 800036e:	f107 30ff 	add.w	r0, r7, #4294967295	; 0xffffffff
 8000372:	f080 811b 	bcs.w	80005ac <__udivmoddi4+0x28c>
 8000376:	4299      	cmp	r1, r3
 8000378:	f240 8118 	bls.w	80005ac <__udivmoddi4+0x28c>
 800037c:	3f02      	subs	r7, #2
 800037e:	442b      	add	r3, r5
 8000380:	1a5b      	subs	r3, r3, r1
 8000382:	b2a4      	uxth	r4, r4
 8000384:	fbb3 f0fe 	udiv	r0, r3, lr
 8000388:	fb0e 3310 	mls	r3, lr, r0, r3
 800038c:	ea44 4403 	orr.w	r4, r4, r3, lsl #16
 8000390:	fb00 fc0c 	mul.w	ip, r0, ip
 8000394:	45a4      	cmp	ip, r4
 8000396:	d909      	bls.n	80003ac <__udivmoddi4+0x8c>
 8000398:	192c      	adds	r4, r5, r4
 800039a:	f100 33ff 	add.w	r3, r0, #4294967295	; 0xffffffff
 800039e:	f080 8107 	bcs.w	80005b0 <__udivmoddi4+0x290>
 80003a2:	45a4      	cmp	ip, r4
 80003a4:	f240 8104 	bls.w	80005b0 <__udivmoddi4+0x290>
 80003a8:	3802      	subs	r0, #2
 80003aa:	442c      	add	r4, r5
 80003ac:	ea40 4007 	orr.w	r0, r0, r7, lsl #16
 80003b0:	eba4 040c 	sub.w	r4, r4, ip
 80003b4:	2700      	movs	r7, #0
 80003b6:	b11e      	cbz	r6, 80003c0 <__udivmoddi4+0xa0>
 80003b8:	40d4      	lsrs	r4, r2
 80003ba:	2300      	movs	r3, #0
 80003bc:	e9c6 4300 	strd	r4, r3, [r6]
 80003c0:	4639      	mov	r1, r7
 80003c2:	e8bd 87f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, pc}
 80003c6:	428b      	cmp	r3, r1
 80003c8:	d909      	bls.n	80003de <__udivmoddi4+0xbe>
 80003ca:	2e00      	cmp	r6, #0
 80003cc:	f000 80eb 	beq.w	80005a6 <__udivmoddi4+0x286>
 80003d0:	2700      	movs	r7, #0
 80003d2:	e9c6 0100 	strd	r0, r1, [r6]
 80003d6:	4638      	mov	r0, r7
 80003d8:	4639      	mov	r1, r7
 80003da:	e8bd 87f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, pc}
 80003de:	fab3 f783 	clz	r7, r3
 80003e2:	2f00      	cmp	r7, #0
 80003e4:	d147      	bne.n	8000476 <__udivmoddi4+0x156>
 80003e6:	428b      	cmp	r3, r1
 80003e8:	d302      	bcc.n	80003f0 <__udivmoddi4+0xd0>
 80003ea:	4282      	cmp	r2, r0
 80003ec:	f200 80fa 	bhi.w	80005e4 <__udivmoddi4+0x2c4>
 80003f0:	1a84      	subs	r4, r0, r2
 80003f2:	eb61 0303 	sbc.w	r3, r1, r3
 80003f6:	2001      	movs	r0, #1
 80003f8:	4698      	mov	r8, r3
 80003fa:	2e00      	cmp	r6, #0
 80003fc:	d0e0      	beq.n	80003c0 <__udivmoddi4+0xa0>
 80003fe:	e9c6 4800 	strd	r4, r8, [r6]
 8000402:	e7dd      	b.n	80003c0 <__udivmoddi4+0xa0>
 8000404:	b902      	cbnz	r2, 8000408 <__udivmoddi4+0xe8>
 8000406:	deff      	udf	#255	; 0xff
 8000408:	fab2 f282 	clz	r2, r2
 800040c:	2a00      	cmp	r2, #0
 800040e:	f040 808f 	bne.w	8000530 <__udivmoddi4+0x210>
 8000412:	1b49      	subs	r1, r1, r5
 8000414:	ea4f 4e15 	mov.w	lr, r5, lsr #16
 8000418:	fa1f f885 	uxth.w	r8, r5
 800041c:	2701      	movs	r7, #1
 800041e:	fbb1 fcfe 	udiv	ip, r1, lr
 8000422:	0c23      	lsrs	r3, r4, #16
 8000424:	fb0e 111c 	mls	r1, lr, ip, r1
 8000428:	ea43 4301 	orr.w	r3, r3, r1, lsl #16
 800042c:	fb08 f10c 	mul.w	r1, r8, ip
 8000430:	4299      	cmp	r1, r3
 8000432:	d907      	bls.n	8000444 <__udivmoddi4+0x124>
 8000434:	18eb      	adds	r3, r5, r3
 8000436:	f10c 30ff 	add.w	r0, ip, #4294967295	; 0xffffffff
 800043a:	d202      	bcs.n	8000442 <__udivmoddi4+0x122>
 800043c:	4299      	cmp	r1, r3
 800043e:	f200 80cd 	bhi.w	80005dc <__udivmoddi4+0x2bc>
 8000442:	4684      	mov	ip, r0
 8000444:	1a59      	subs	r1, r3, r1
 8000446:	b2a3      	uxth	r3, r4
 8000448:	fbb1 f0fe 	udiv	r0, r1, lr
 800044c:	fb0e 1410 	mls	r4, lr, r0, r1
 8000450:	ea43 4404 	orr.w	r4, r3, r4, lsl #16
 8000454:	fb08 f800 	mul.w	r8, r8, r0
 8000458:	45a0      	cmp	r8, r4
 800045a:	d907      	bls.n	800046c <__udivmoddi4+0x14c>
 800045c:	192c      	adds	r4, r5, r4
 800045e:	f100 33ff 	add.w	r3, r0, #4294967295	; 0xffffffff
 8000462:	d202      	bcs.n	800046a <__udivmoddi4+0x14a>
 8000464:	45a0      	cmp	r8, r4
 8000466:	f200 80b6 	bhi.w	80005d6 <__udivmoddi4+0x2b6>
 800046a:	4618      	mov	r0, r3
 800046c:	eba4 0408 	sub.w	r4, r4, r8
 8000470:	ea40 400c 	orr.w	r0, r0, ip, lsl #16
 8000474:	e79f      	b.n	80003b6 <__udivmoddi4+0x96>
 8000476:	f1c7 0c20 	rsb	ip, r7, #32
 800047a:	40bb      	lsls	r3, r7
 800047c:	fa22 fe0c 	lsr.w	lr, r2, ip
 8000480:	ea4e 0e03 	orr.w	lr, lr, r3
 8000484:	fa01 f407 	lsl.w	r4, r1, r7
 8000488:	fa20 f50c 	lsr.w	r5, r0, ip
 800048c:	fa21 f30c 	lsr.w	r3, r1, ip
 8000490:	ea4f 481e 	mov.w	r8, lr, lsr #16
 8000494:	4325      	orrs	r5, r4
 8000496:	fbb3 f9f8 	udiv	r9, r3, r8
 800049a:	0c2c      	lsrs	r4, r5, #16
 800049c:	fb08 3319 	mls	r3, r8, r9, r3
 80004a0:	fa1f fa8e 	uxth.w	sl, lr
 80004a4:	ea44 4303 	orr.w	r3, r4, r3, lsl #16
 80004a8:	fb09 f40a 	mul.w	r4, r9, sl
 80004ac:	429c      	cmp	r4, r3
 80004ae:	fa02 f207 	lsl.w	r2, r2, r7
 80004b2:	fa00 f107 	lsl.w	r1, r0, r7
 80004b6:	d90b      	bls.n	80004d0 <__udivmoddi4+0x1b0>
 80004b8:	eb1e 0303 	adds.w	r3, lr, r3
 80004bc:	f109 30ff 	add.w	r0, r9, #4294967295	; 0xffffffff
 80004c0:	f080 8087 	bcs.w	80005d2 <__udivmoddi4+0x2b2>
 80004c4:	429c      	cmp	r4, r3
 80004c6:	f240 8084 	bls.w	80005d2 <__udivmoddi4+0x2b2>
 80004ca:	f1a9 0902 	sub.w	r9, r9, #2
 80004ce:	4473      	add	r3, lr
 80004d0:	1b1b      	subs	r3, r3, r4
 80004d2:	b2ad      	uxth	r5, r5
 80004d4:	fbb3 f0f8 	udiv	r0, r3, r8
 80004d8:	fb08 3310 	mls	r3, r8, r0, r3
 80004dc:	ea45 4403 	orr.w	r4, r5, r3, lsl #16
 80004e0:	fb00 fa0a 	mul.w	sl, r0, sl
 80004e4:	45a2      	cmp	sl, r4
 80004e6:	d908      	bls.n	80004fa <__udivmoddi4+0x1da>
 80004e8:	eb1e 0404 	adds.w	r4, lr, r4
 80004ec:	f100 33ff 	add.w	r3, r0, #4294967295	; 0xffffffff
 80004f0:	d26b      	bcs.n	80005ca <__udivmoddi4+0x2aa>
 80004f2:	45a2      	cmp	sl, r4
 80004f4:	d969      	bls.n	80005ca <__udivmoddi4+0x2aa>
 80004f6:	3802      	subs	r0, #2
 80004f8:	4474      	add	r4, lr
 80004fa:	ea40 4009 	orr.w	r0, r0, r9, lsl #16
 80004fe:	fba0 8902 	umull	r8, r9, r0, r2
 8000502:	eba4 040a 	sub.w	r4, r4, sl
 8000506:	454c      	cmp	r4, r9
 8000508:	46c2      	mov	sl, r8
 800050a:	464b      	mov	r3, r9
 800050c:	d354      	bcc.n	80005b8 <__udivmoddi4+0x298>
 800050e:	d051      	beq.n	80005b4 <__udivmoddi4+0x294>
 8000510:	2e00      	cmp	r6, #0
 8000512:	d069      	beq.n	80005e8 <__udivmoddi4+0x2c8>
 8000514:	ebb1 050a 	subs.w	r5, r1, sl
 8000518:	eb64 0403 	sbc.w	r4, r4, r3
 800051c:	fa04 fc0c 	lsl.w	ip, r4, ip
 8000520:	40fd      	lsrs	r5, r7
 8000522:	40fc      	lsrs	r4, r7
 8000524:	ea4c 0505 	orr.w	r5, ip, r5
 8000528:	e9c6 5400 	strd	r5, r4, [r6]
 800052c:	2700      	movs	r7, #0
 800052e:	e747      	b.n	80003c0 <__udivmoddi4+0xa0>
 8000530:	f1c2 0320 	rsb	r3, r2, #32
 8000534:	fa20 f703 	lsr.w	r7, r0, r3
 8000538:	4095      	lsls	r5, r2
 800053a:	fa01 f002 	lsl.w	r0, r1, r2
 800053e:	fa21 f303 	lsr.w	r3, r1, r3
 8000542:	ea4f 4e15 	mov.w	lr, r5, lsr #16
 8000546:	4338      	orrs	r0, r7
 8000548:	0c01      	lsrs	r1, r0, #16
 800054a:	fbb3 f7fe 	udiv	r7, r3, lr
 800054e:	fa1f f885 	uxth.w	r8, r5
 8000552:	fb0e 3317 	mls	r3, lr, r7, r3
 8000556:	ea41 4103 	orr.w	r1, r1, r3, lsl #16
 800055a:	fb07 f308 	mul.w	r3, r7, r8
 800055e:	428b      	cmp	r3, r1
 8000560:	fa04 f402 	lsl.w	r4, r4, r2
 8000564:	d907      	bls.n	8000576 <__udivmoddi4+0x256>
 8000566:	1869      	adds	r1, r5, r1
 8000568:	f107 3cff 	add.w	ip, r7, #4294967295	; 0xffffffff
 800056c:	d22f      	bcs.n	80005ce <__udivmoddi4+0x2ae>
 800056e:	428b      	cmp	r3, r1
 8000570:	d92d      	bls.n	80005ce <__udivmoddi4+0x2ae>
 8000572:	3f02      	subs	r7, #2
 8000574:	4429      	add	r1, r5
 8000576:	1acb      	subs	r3, r1, r3
 8000578:	b281      	uxth	r1, r0
 800057a:	fbb3 f0fe 	udiv	r0, r3, lr
 800057e:	fb0e 3310 	mls	r3, lr, r0, r3
 8000582:	ea41 4103 	orr.w	r1, r1, r3, lsl #16
 8000586:	fb00 f308 	mul.w	r3, r0, r8
 800058a:	428b      	cmp	r3, r1
 800058c:	d907      	bls.n	800059e <__udivmoddi4+0x27e>
 800058e:	1869      	adds	r1, r5, r1
 8000590:	f100 3cff 	add.w	ip, r0, #4294967295	; 0xffffffff
 8000594:	d217      	bcs.n	80005c6 <__udivmoddi4+0x2a6>
 8000596:	428b      	cmp	r3, r1
 8000598:	d915      	bls.n	80005c6 <__udivmoddi4+0x2a6>
 800059a:	3802      	subs	r0, #2
 800059c:	4429      	add	r1, r5
 800059e:	1ac9      	subs	r1, r1, r3
 80005a0:	ea40 4707 	orr.w	r7, r0, r7, lsl #16
 80005a4:	e73b      	b.n	800041e <__udivmoddi4+0xfe>
 80005a6:	4637      	mov	r7, r6
 80005a8:	4630      	mov	r0, r6
 80005aa:	e709      	b.n	80003c0 <__udivmoddi4+0xa0>
 80005ac:	4607      	mov	r7, r0
 80005ae:	e6e7      	b.n	8000380 <__udivmoddi4+0x60>
 80005b0:	4618      	mov	r0, r3
 80005b2:	e6fb      	b.n	80003ac <__udivmoddi4+0x8c>
 80005b4:	4541      	cmp	r1, r8
 80005b6:	d2ab      	bcs.n	8000510 <__udivmoddi4+0x1f0>
 80005b8:	ebb8 0a02 	subs.w	sl, r8, r2
 80005bc:	eb69 020e 	sbc.w	r2, r9, lr
 80005c0:	3801      	subs	r0, #1
 80005c2:	4613      	mov	r3, r2
 80005c4:	e7a4      	b.n	8000510 <__udivmoddi4+0x1f0>
 80005c6:	4660      	mov	r0, ip
 80005c8:	e7e9      	b.n	800059e <__udivmoddi4+0x27e>
 80005ca:	4618      	mov	r0, r3
 80005cc:	e795      	b.n	80004fa <__udivmoddi4+0x1da>
 80005ce:	4667      	mov	r7, ip
 80005d0:	e7d1      	b.n	8000576 <__udivmoddi4+0x256>
 80005d2:	4681      	mov	r9, r0
 80005d4:	e77c      	b.n	80004d0 <__udivmoddi4+0x1b0>
 80005d6:	3802      	subs	r0, #2
 80005d8:	442c      	add	r4, r5
 80005da:	e747      	b.n	800046c <__udivmoddi4+0x14c>
 80005dc:	f1ac 0c02 	sub.w	ip, ip, #2
 80005e0:	442b      	add	r3, r5
 80005e2:	e72f      	b.n	8000444 <__udivmoddi4+0x124>
 80005e4:	4638      	mov	r0, r7
 80005e6:	e708      	b.n	80003fa <__udivmoddi4+0xda>
 80005e8:	4637      	mov	r7, r6
 80005ea:	e6e9      	b.n	80003c0 <__udivmoddi4+0xa0>

080005ec <__aeabi_idiv0>:
 80005ec:	4770      	bx	lr
 80005ee:	bf00      	nop

080005f0 <MX_GPIO_Init>:
     PB13   ------> ETH_TXD1
     PG11   ------> ETH_TX_EN
     PG13   ------> ETH_TXD0
*/
void MX_GPIO_Init(void)
{
 80005f0:	b580      	push	{r7, lr}
 80005f2:	b08e      	sub	sp, #56	; 0x38
 80005f4:	af00      	add	r7, sp, #0

  GPIO_InitTypeDef GPIO_InitStruct = {0};
 80005f6:	f107 0324 	add.w	r3, r7, #36	; 0x24
 80005fa:	2200      	movs	r2, #0
 80005fc:	601a      	str	r2, [r3, #0]
 80005fe:	605a      	str	r2, [r3, #4]
 8000600:	609a      	str	r2, [r3, #8]
 8000602:	60da      	str	r2, [r3, #12]
 8000604:	611a      	str	r2, [r3, #16]

  /* GPIO Ports Clock Enable */
  __HAL_RCC_GPIOE_CLK_ENABLE();
 8000606:	4b8d      	ldr	r3, [pc, #564]	; (800083c <MX_GPIO_Init+0x24c>)
 8000608:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 800060a:	4a8c      	ldr	r2, [pc, #560]	; (800083c <MX_GPIO_Init+0x24c>)
 800060c:	f043 0310 	orr.w	r3, r3, #16
 8000610:	6313      	str	r3, [r2, #48]	; 0x30
 8000612:	4b8a      	ldr	r3, [pc, #552]	; (800083c <MX_GPIO_Init+0x24c>)
 8000614:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8000616:	f003 0310 	and.w	r3, r3, #16
 800061a:	623b      	str	r3, [r7, #32]
 800061c:	6a3b      	ldr	r3, [r7, #32]
  __HAL_RCC_GPIOC_CLK_ENABLE();
 800061e:	4b87      	ldr	r3, [pc, #540]	; (800083c <MX_GPIO_Init+0x24c>)
 8000620:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8000622:	4a86      	ldr	r2, [pc, #536]	; (800083c <MX_GPIO_Init+0x24c>)
 8000624:	f043 0304 	orr.w	r3, r3, #4
 8000628:	6313      	str	r3, [r2, #48]	; 0x30
 800062a:	4b84      	ldr	r3, [pc, #528]	; (800083c <MX_GPIO_Init+0x24c>)
 800062c:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 800062e:	f003 0304 	and.w	r3, r3, #4
 8000632:	61fb      	str	r3, [r7, #28]
 8000634:	69fb      	ldr	r3, [r7, #28]
  __HAL_RCC_GPIOF_CLK_ENABLE();
 8000636:	4b81      	ldr	r3, [pc, #516]	; (800083c <MX_GPIO_Init+0x24c>)
 8000638:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 800063a:	4a80      	ldr	r2, [pc, #512]	; (800083c <MX_GPIO_Init+0x24c>)
 800063c:	f043 0320 	orr.w	r3, r3, #32
 8000640:	6313      	str	r3, [r2, #48]	; 0x30
 8000642:	4b7e      	ldr	r3, [pc, #504]	; (800083c <MX_GPIO_Init+0x24c>)
 8000644:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8000646:	f003 0320 	and.w	r3, r3, #32
 800064a:	61bb      	str	r3, [r7, #24]
 800064c:	69bb      	ldr	r3, [r7, #24]
  __HAL_RCC_GPIOH_CLK_ENABLE();
 800064e:	4b7b      	ldr	r3, [pc, #492]	; (800083c <MX_GPIO_Init+0x24c>)
 8000650:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8000652:	4a7a      	ldr	r2, [pc, #488]	; (800083c <MX_GPIO_Init+0x24c>)
 8000654:	f043 0380 	orr.w	r3, r3, #128	; 0x80
 8000658:	6313      	str	r3, [r2, #48]	; 0x30
 800065a:	4b78      	ldr	r3, [pc, #480]	; (800083c <MX_GPIO_Init+0x24c>)
 800065c:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 800065e:	f003 0380 	and.w	r3, r3, #128	; 0x80
 8000662:	617b      	str	r3, [r7, #20]
 8000664:	697b      	ldr	r3, [r7, #20]
  __HAL_RCC_GPIOA_CLK_ENABLE();
 8000666:	4b75      	ldr	r3, [pc, #468]	; (800083c <MX_GPIO_Init+0x24c>)
 8000668:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 800066a:	4a74      	ldr	r2, [pc, #464]	; (800083c <MX_GPIO_Init+0x24c>)
 800066c:	f043 0301 	orr.w	r3, r3, #1
 8000670:	6313      	str	r3, [r2, #48]	; 0x30
 8000672:	4b72      	ldr	r3, [pc, #456]	; (800083c <MX_GPIO_Init+0x24c>)
 8000674:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8000676:	f003 0301 	and.w	r3, r3, #1
 800067a:	613b      	str	r3, [r7, #16]
 800067c:	693b      	ldr	r3, [r7, #16]
  __HAL_RCC_GPIOB_CLK_ENABLE();
 800067e:	4b6f      	ldr	r3, [pc, #444]	; (800083c <MX_GPIO_Init+0x24c>)
 8000680:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8000682:	4a6e      	ldr	r2, [pc, #440]	; (800083c <MX_GPIO_Init+0x24c>)
 8000684:	f043 0302 	orr.w	r3, r3, #2
 8000688:	6313      	str	r3, [r2, #48]	; 0x30
 800068a:	4b6c      	ldr	r3, [pc, #432]	; (800083c <MX_GPIO_Init+0x24c>)
 800068c:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 800068e:	f003 0302 	and.w	r3, r3, #2
 8000692:	60fb      	str	r3, [r7, #12]
 8000694:	68fb      	ldr	r3, [r7, #12]
  __HAL_RCC_GPIOD_CLK_ENABLE();
 8000696:	4b69      	ldr	r3, [pc, #420]	; (800083c <MX_GPIO_Init+0x24c>)
 8000698:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 800069a:	4a68      	ldr	r2, [pc, #416]	; (800083c <MX_GPIO_Init+0x24c>)
 800069c:	f043 0308 	orr.w	r3, r3, #8
 80006a0:	6313      	str	r3, [r2, #48]	; 0x30
 80006a2:	4b66      	ldr	r3, [pc, #408]	; (800083c <MX_GPIO_Init+0x24c>)
 80006a4:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 80006a6:	f003 0308 	and.w	r3, r3, #8
 80006aa:	60bb      	str	r3, [r7, #8]
 80006ac:	68bb      	ldr	r3, [r7, #8]
  __HAL_RCC_GPIOG_CLK_ENABLE();
 80006ae:	4b63      	ldr	r3, [pc, #396]	; (800083c <MX_GPIO_Init+0x24c>)
 80006b0:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 80006b2:	4a62      	ldr	r2, [pc, #392]	; (800083c <MX_GPIO_Init+0x24c>)
 80006b4:	f043 0340 	orr.w	r3, r3, #64	; 0x40
 80006b8:	6313      	str	r3, [r2, #48]	; 0x30
 80006ba:	4b60      	ldr	r3, [pc, #384]	; (800083c <MX_GPIO_Init+0x24c>)
 80006bc:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 80006be:	f003 0340 	and.w	r3, r3, #64	; 0x40
 80006c2:	607b      	str	r3, [r7, #4]
 80006c4:	687b      	ldr	r3, [r7, #4]

  /*Configure GPIO pin Output Level */
  HAL_GPIO_WritePin(GPIOE, T_CLK_Pin|T_MOSI_Pin|T_CS_Pin, GPIO_PIN_RESET);
 80006c6:	2200      	movs	r2, #0
 80006c8:	2168      	movs	r1, #104	; 0x68
 80006ca:	485d      	ldr	r0, [pc, #372]	; (8000840 <MX_GPIO_Init+0x250>)
 80006cc:	f001 f9f0 	bl	8001ab0 <HAL_GPIO_WritePin>

  /*Configure GPIO pin Output Level */
  HAL_GPIO_WritePin(GPIOB, LD3_Pin|LD2_Pin, GPIO_PIN_RESET);
 80006d0:	2200      	movs	r2, #0
 80006d2:	f44f 4181 	mov.w	r1, #16512	; 0x4080
 80006d6:	485b      	ldr	r0, [pc, #364]	; (8000844 <MX_GPIO_Init+0x254>)
 80006d8:	f001 f9ea 	bl	8001ab0 <HAL_GPIO_WritePin>

  /*Configure GPIO pin Output Level */
  HAL_GPIO_WritePin(USB_PowerSwitchOn_GPIO_Port, USB_PowerSwitchOn_Pin, GPIO_PIN_RESET);
 80006dc:	2200      	movs	r2, #0
 80006de:	2140      	movs	r1, #64	; 0x40
 80006e0:	4859      	ldr	r0, [pc, #356]	; (8000848 <MX_GPIO_Init+0x258>)
 80006e2:	f001 f9e5 	bl	8001ab0 <HAL_GPIO_WritePin>

  /*Configure GPIO pin Output Level */
  HAL_GPIO_WritePin(GPIOC, CS_Pin|DC_Pin|RST_Pin, GPIO_PIN_RESET);
 80006e6:	2200      	movs	r2, #0
 80006e8:	f44f 61e0 	mov.w	r1, #1792	; 0x700
 80006ec:	4857      	ldr	r0, [pc, #348]	; (800084c <MX_GPIO_Init+0x25c>)
 80006ee:	f001 f9df 	bl	8001ab0 <HAL_GPIO_WritePin>

  /*Configure GPIO pins : PEPin PEPin */
  GPIO_InitStruct.Pin = T_IRQ_Pin|T_MISO_Pin;
 80006f2:	2314      	movs	r3, #20
 80006f4:	627b      	str	r3, [r7, #36]	; 0x24
  GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
 80006f6:	2300      	movs	r3, #0
 80006f8:	62bb      	str	r3, [r7, #40]	; 0x28
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 80006fa:	2300      	movs	r3, #0
 80006fc:	62fb      	str	r3, [r7, #44]	; 0x2c
  HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);
 80006fe:	f107 0324 	add.w	r3, r7, #36	; 0x24
 8000702:	4619      	mov	r1, r3
 8000704:	484e      	ldr	r0, [pc, #312]	; (8000840 <MX_GPIO_Init+0x250>)
 8000706:	f001 f811 	bl	800172c <HAL_GPIO_Init>

  /*Configure GPIO pins : PEPin PEPin PEPin */
  GPIO_InitStruct.Pin = T_CLK_Pin|T_MOSI_Pin|T_CS_Pin;
 800070a:	2368      	movs	r3, #104	; 0x68
 800070c:	627b      	str	r3, [r7, #36]	; 0x24
  GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
 800070e:	2301      	movs	r3, #1
 8000710:	62bb      	str	r3, [r7, #40]	; 0x28
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 8000712:	2300      	movs	r3, #0
 8000714:	62fb      	str	r3, [r7, #44]	; 0x2c
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
 8000716:	2303      	movs	r3, #3
 8000718:	633b      	str	r3, [r7, #48]	; 0x30
  HAL_GPIO_Init(GPIOE, &GPIO_InitStruct);
 800071a:	f107 0324 	add.w	r3, r7, #36	; 0x24
 800071e:	4619      	mov	r1, r3
 8000720:	4847      	ldr	r0, [pc, #284]	; (8000840 <MX_GPIO_Init+0x250>)
 8000722:	f001 f803 	bl	800172c <HAL_GPIO_Init>

  /*Configure GPIO pin : PtPin */
  GPIO_InitStruct.Pin = User_Blue_Button_Pin;
 8000726:	f44f 5300 	mov.w	r3, #8192	; 0x2000
 800072a:	627b      	str	r3, [r7, #36]	; 0x24
  GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
 800072c:	2300      	movs	r3, #0
 800072e:	62bb      	str	r3, [r7, #40]	; 0x28
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 8000730:	2300      	movs	r3, #0
 8000732:	62fb      	str	r3, [r7, #44]	; 0x2c
  HAL_GPIO_Init(User_Blue_Button_GPIO_Port, &GPIO_InitStruct);
 8000734:	f107 0324 	add.w	r3, r7, #36	; 0x24
 8000738:	4619      	mov	r1, r3
 800073a:	4844      	ldr	r0, [pc, #272]	; (800084c <MX_GPIO_Init+0x25c>)
 800073c:	f000 fff6 	bl	800172c <HAL_GPIO_Init>

  /*Configure GPIO pins : PCPin PCPin PCPin */
  GPIO_InitStruct.Pin = RMII_MDC_Pin|RMII_RXD0_Pin|RMII_RXD1_Pin;
 8000740:	2332      	movs	r3, #50	; 0x32
 8000742:	627b      	str	r3, [r7, #36]	; 0x24
  GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
 8000744:	2302      	movs	r3, #2
 8000746:	62bb      	str	r3, [r7, #40]	; 0x28
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 8000748:	2300      	movs	r3, #0
 800074a:	62fb      	str	r3, [r7, #44]	; 0x2c
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
 800074c:	2303      	movs	r3, #3
 800074e:	633b      	str	r3, [r7, #48]	; 0x30
  GPIO_InitStruct.Alternate = GPIO_AF11_ETH;
 8000750:	230b      	movs	r3, #11
 8000752:	637b      	str	r3, [r7, #52]	; 0x34
  HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
 8000754:	f107 0324 	add.w	r3, r7, #36	; 0x24
 8000758:	4619      	mov	r1, r3
 800075a:	483c      	ldr	r0, [pc, #240]	; (800084c <MX_GPIO_Init+0x25c>)
 800075c:	f000 ffe6 	bl	800172c <HAL_GPIO_Init>

  /*Configure GPIO pins : PAPin PAPin PAPin */
  GPIO_InitStruct.Pin = RMII_REF_CLK_Pin|RMII_MDIO_Pin|RMII_CRS_DV_Pin;
 8000760:	2386      	movs	r3, #134	; 0x86
 8000762:	627b      	str	r3, [r7, #36]	; 0x24
  GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
 8000764:	2302      	movs	r3, #2
 8000766:	62bb      	str	r3, [r7, #40]	; 0x28
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 8000768:	2300      	movs	r3, #0
 800076a:	62fb      	str	r3, [r7, #44]	; 0x2c
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
 800076c:	2303      	movs	r3, #3
 800076e:	633b      	str	r3, [r7, #48]	; 0x30
  GPIO_InitStruct.Alternate = GPIO_AF11_ETH;
 8000770:	230b      	movs	r3, #11
 8000772:	637b      	str	r3, [r7, #52]	; 0x34
  HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
 8000774:	f107 0324 	add.w	r3, r7, #36	; 0x24
 8000778:	4619      	mov	r1, r3
 800077a:	4835      	ldr	r0, [pc, #212]	; (8000850 <MX_GPIO_Init+0x260>)
 800077c:	f000 ffd6 	bl	800172c <HAL_GPIO_Init>

  /*Configure GPIO pin : PtPin */
  GPIO_InitStruct.Pin = RMII_TXD1_Pin;
 8000780:	f44f 5300 	mov.w	r3, #8192	; 0x2000
 8000784:	627b      	str	r3, [r7, #36]	; 0x24
  GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
 8000786:	2302      	movs	r3, #2
 8000788:	62bb      	str	r3, [r7, #40]	; 0x28
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 800078a:	2300      	movs	r3, #0
 800078c:	62fb      	str	r3, [r7, #44]	; 0x2c
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
 800078e:	2303      	movs	r3, #3
 8000790:	633b      	str	r3, [r7, #48]	; 0x30
  GPIO_InitStruct.Alternate = GPIO_AF11_ETH;
 8000792:	230b      	movs	r3, #11
 8000794:	637b      	str	r3, [r7, #52]	; 0x34
  HAL_GPIO_Init(RMII_TXD1_GPIO_Port, &GPIO_InitStruct);
 8000796:	f107 0324 	add.w	r3, r7, #36	; 0x24
 800079a:	4619      	mov	r1, r3
 800079c:	4829      	ldr	r0, [pc, #164]	; (8000844 <MX_GPIO_Init+0x254>)
 800079e:	f000 ffc5 	bl	800172c <HAL_GPIO_Init>

  /*Configure GPIO pins : PBPin PBPin */
  GPIO_InitStruct.Pin = LD3_Pin|LD2_Pin;
 80007a2:	f44f 4381 	mov.w	r3, #16512	; 0x4080
 80007a6:	627b      	str	r3, [r7, #36]	; 0x24
  GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
 80007a8:	2301      	movs	r3, #1
 80007aa:	62bb      	str	r3, [r7, #40]	; 0x28
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 80007ac:	2300      	movs	r3, #0
 80007ae:	62fb      	str	r3, [r7, #44]	; 0x2c
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
 80007b0:	2300      	movs	r3, #0
 80007b2:	633b      	str	r3, [r7, #48]	; 0x30
  HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
 80007b4:	f107 0324 	add.w	r3, r7, #36	; 0x24
 80007b8:	4619      	mov	r1, r3
 80007ba:	4822      	ldr	r0, [pc, #136]	; (8000844 <MX_GPIO_Init+0x254>)
 80007bc:	f000 ffb6 	bl	800172c <HAL_GPIO_Init>

  /*Configure GPIO pin : PtPin */
  GPIO_InitStruct.Pin = USB_PowerSwitchOn_Pin;
 80007c0:	2340      	movs	r3, #64	; 0x40
 80007c2:	627b      	str	r3, [r7, #36]	; 0x24
  GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
 80007c4:	2301      	movs	r3, #1
 80007c6:	62bb      	str	r3, [r7, #40]	; 0x28
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 80007c8:	2300      	movs	r3, #0
 80007ca:	62fb      	str	r3, [r7, #44]	; 0x2c
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
 80007cc:	2300      	movs	r3, #0
 80007ce:	633b      	str	r3, [r7, #48]	; 0x30
  HAL_GPIO_Init(USB_PowerSwitchOn_GPIO_Port, &GPIO_InitStruct);
 80007d0:	f107 0324 	add.w	r3, r7, #36	; 0x24
 80007d4:	4619      	mov	r1, r3
 80007d6:	481c      	ldr	r0, [pc, #112]	; (8000848 <MX_GPIO_Init+0x258>)
 80007d8:	f000 ffa8 	bl	800172c <HAL_GPIO_Init>

  /*Configure GPIO pin : PtPin */
  GPIO_InitStruct.Pin = USB_OverCurrent_Pin;
 80007dc:	2380      	movs	r3, #128	; 0x80
 80007de:	627b      	str	r3, [r7, #36]	; 0x24
  GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
 80007e0:	2300      	movs	r3, #0
 80007e2:	62bb      	str	r3, [r7, #40]	; 0x28
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 80007e4:	2300      	movs	r3, #0
 80007e6:	62fb      	str	r3, [r7, #44]	; 0x2c
  HAL_GPIO_Init(USB_OverCurrent_GPIO_Port, &GPIO_InitStruct);
 80007e8:	f107 0324 	add.w	r3, r7, #36	; 0x24
 80007ec:	4619      	mov	r1, r3
 80007ee:	4816      	ldr	r0, [pc, #88]	; (8000848 <MX_GPIO_Init+0x258>)
 80007f0:	f000 ff9c 	bl	800172c <HAL_GPIO_Init>

  /*Configure GPIO pins : PCPin PCPin PCPin */
  GPIO_InitStruct.Pin = CS_Pin|DC_Pin|RST_Pin;
 80007f4:	f44f 63e0 	mov.w	r3, #1792	; 0x700
 80007f8:	627b      	str	r3, [r7, #36]	; 0x24
  GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
 80007fa:	2301      	movs	r3, #1
 80007fc:	62bb      	str	r3, [r7, #40]	; 0x28
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 80007fe:	2300      	movs	r3, #0
 8000800:	62fb      	str	r3, [r7, #44]	; 0x2c
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
 8000802:	2303      	movs	r3, #3
 8000804:	633b      	str	r3, [r7, #48]	; 0x30
  HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
 8000806:	f107 0324 	add.w	r3, r7, #36	; 0x24
 800080a:	4619      	mov	r1, r3
 800080c:	480f      	ldr	r0, [pc, #60]	; (800084c <MX_GPIO_Init+0x25c>)
 800080e:	f000 ff8d 	bl	800172c <HAL_GPIO_Init>

  /*Configure GPIO pins : PGPin PGPin */
  GPIO_InitStruct.Pin = RMII_TX_EN_Pin|RMII_TXD0_Pin;
 8000812:	f44f 5320 	mov.w	r3, #10240	; 0x2800
 8000816:	627b      	str	r3, [r7, #36]	; 0x24
  GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
 8000818:	2302      	movs	r3, #2
 800081a:	62bb      	str	r3, [r7, #40]	; 0x28
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 800081c:	2300      	movs	r3, #0
 800081e:	62fb      	str	r3, [r7, #44]	; 0x2c
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
 8000820:	2303      	movs	r3, #3
 8000822:	633b      	str	r3, [r7, #48]	; 0x30
  GPIO_InitStruct.Alternate = GPIO_AF11_ETH;
 8000824:	230b      	movs	r3, #11
 8000826:	637b      	str	r3, [r7, #52]	; 0x34
  HAL_GPIO_Init(GPIOG, &GPIO_InitStruct);
 8000828:	f107 0324 	add.w	r3, r7, #36	; 0x24
 800082c:	4619      	mov	r1, r3
 800082e:	4806      	ldr	r0, [pc, #24]	; (8000848 <MX_GPIO_Init+0x258>)
 8000830:	f000 ff7c 	bl	800172c <HAL_GPIO_Init>

}
 8000834:	bf00      	nop
 8000836:	3738      	adds	r7, #56	; 0x38
 8000838:	46bd      	mov	sp, r7
 800083a:	bd80      	pop	{r7, pc}
 800083c:	40023800 	.word	0x40023800
 8000840:	40021000 	.word	0x40021000
 8000844:	40020400 	.word	0x40020400
 8000848:	40021800 	.word	0x40021800
 800084c:	40020800 	.word	0x40020800
 8000850:	40020000 	.word	0x40020000

08000854 <GUI_init>:
#include "gui.h"

void GUI_init() {
 8000854:	b580      	push	{r7, lr}
 8000856:	af00      	add	r7, sp, #0
	ILI9341_Init();
 8000858:	f004 f916 	bl	8004a88 <ILI9341_Init>
	ILI9341_Set_Rotation(3);
 800085c:	2003      	movs	r0, #3
 800085e:	f004 f8b5 	bl	80049cc <ILI9341_Set_Rotation>
	ILI9341_Fill_Screen(WHITE);
 8000862:	f64f 70ff 	movw	r0, #65535	; 0xffff
 8000866:	f004 fab7 	bl	8004dd8 <ILI9341_Fill_Screen>

	assign_me();
 800086a:	f000 fb8b 	bl	8000f84 <assign_me>

	red_percent = 0;
 800086e:	4b08      	ldr	r3, [pc, #32]	; (8000890 <GUI_init+0x3c>)
 8000870:	2200      	movs	r2, #0
 8000872:	701a      	strb	r2, [r3, #0]
	green_percent = 0;
 8000874:	4b07      	ldr	r3, [pc, #28]	; (8000894 <GUI_init+0x40>)
 8000876:	2200      	movs	r2, #0
 8000878:	701a      	strb	r2, [r3, #0]
	blue_percent = 0;
 800087a:	4b07      	ldr	r3, [pc, #28]	; (8000898 <GUI_init+0x44>)
 800087c:	2200      	movs	r2, #0
 800087e:	701a      	strb	r2, [r3, #0]

	page_num = 1;
 8000880:	4b06      	ldr	r3, [pc, #24]	; (800089c <GUI_init+0x48>)
 8000882:	2201      	movs	r2, #1
 8000884:	701a      	strb	r2, [r3, #0]

	time = 0;
 8000886:	4b06      	ldr	r3, [pc, #24]	; (80008a0 <GUI_init+0x4c>)
 8000888:	2200      	movs	r2, #0
 800088a:	601a      	str	r2, [r3, #0]

}
 800088c:	bf00      	nop
 800088e:	bd80      	pop	{r7, pc}
 8000890:	20000208 	.word	0x20000208
 8000894:	20025a18 	.word	0x20025a18
 8000898:	20025a0c 	.word	0x20025a0c
 800089c:	20025a19 	.word	0x20025a19
 80008a0:	20025a14 	.word	0x20025a14

080008a4 <main_system>:

void main_system(){
 80008a4:	b580      	push	{r7, lr}
 80008a6:	af00      	add	r7, sp, #0
	if(page_num==1){
 80008a8:	4b07      	ldr	r3, [pc, #28]	; (80008c8 <main_system+0x24>)
 80008aa:	781b      	ldrb	r3, [r3, #0]
 80008ac:	2b01      	cmp	r3, #1
 80008ae:	d102      	bne.n	80008b6 <main_system+0x12>
		first_page();
 80008b0:	f000 f80c 	bl	80008cc <first_page>
	}
	else if(page_num==2){
		second_page();
	}
}
 80008b4:	e005      	b.n	80008c2 <main_system+0x1e>
	else if(page_num==2){
 80008b6:	4b04      	ldr	r3, [pc, #16]	; (80008c8 <main_system+0x24>)
 80008b8:	781b      	ldrb	r3, [r3, #0]
 80008ba:	2b02      	cmp	r3, #2
 80008bc:	d101      	bne.n	80008c2 <main_system+0x1e>
		second_page();
 80008be:	f000 f92d 	bl	8000b1c <second_page>
}
 80008c2:	bf00      	nop
 80008c4:	bd80      	pop	{r7, pc}
 80008c6:	bf00      	nop
 80008c8:	20025a19 	.word	0x20025a19

080008cc <first_page>:

void first_page() {
 80008cc:	b580      	push	{r7, lr}
 80008ce:	af00      	add	r7, sp, #0

	// render
	draw_change_page_button();
 80008d0:	f000 f824 	bl	800091c <draw_change_page_button>
	draw_color_buttons();
 80008d4:	f000 f80a 	bl	80008ec <draw_color_buttons>
	draw_progress_bars();
 80008d8:	f000 f83a 	bl	8000950 <draw_progress_bars>
	draw_color_percent();
 80008dc:	f000 f8d6 	bl	8000a8c <draw_color_percent>

	// update
	update_progress_bars();
 80008e0:	f000 f97c 	bl	8000bdc <update_progress_bars>
	update_page();
 80008e4:	f000 f926 	bl	8000b34 <update_page>

}
 80008e8:	bf00      	nop
 80008ea:	bd80      	pop	{r7, pc}

080008ec <draw_color_buttons>:

void draw_color_buttons() {
 80008ec:	b580      	push	{r7, lr}
 80008ee:	af00      	add	r7, sp, #0

	ILI9341_Draw_Filled_Circle(40, 100, 20, RED);
 80008f0:	f44f 4378 	mov.w	r3, #63488	; 0xf800
 80008f4:	2214      	movs	r2, #20
 80008f6:	2164      	movs	r1, #100	; 0x64
 80008f8:	2028      	movs	r0, #40	; 0x28
 80008fa:	f003 fc65 	bl	80041c8 <ILI9341_Draw_Filled_Circle>
	ILI9341_Draw_Filled_Circle(40, 150, 20, GREEN);
 80008fe:	f44f 63fc 	mov.w	r3, #2016	; 0x7e0
 8000902:	2214      	movs	r2, #20
 8000904:	2196      	movs	r1, #150	; 0x96
 8000906:	2028      	movs	r0, #40	; 0x28
 8000908:	f003 fc5e 	bl	80041c8 <ILI9341_Draw_Filled_Circle>
	ILI9341_Draw_Filled_Circle(40, 200, 20, BLUE);
 800090c:	231f      	movs	r3, #31
 800090e:	2214      	movs	r2, #20
 8000910:	21c8      	movs	r1, #200	; 0xc8
 8000912:	2028      	movs	r0, #40	; 0x28
 8000914:	f003 fc58 	bl	80041c8 <ILI9341_Draw_Filled_Circle>

}
 8000918:	bf00      	nop
 800091a:	bd80      	pop	{r7, pc}

0800091c <draw_change_page_button>:

void draw_change_page_button() {
 800091c:	b580      	push	{r7, lr}
 800091e:	af00      	add	r7, sp, #0

	ILI9341_Draw_Filled_Circle(150, 50, 20,
 8000920:	4b08      	ldr	r3, [pc, #32]	; (8000944 <draw_change_page_button+0x28>)
 8000922:	7818      	ldrb	r0, [r3, #0]
 8000924:	4b08      	ldr	r3, [pc, #32]	; (8000948 <draw_change_page_button+0x2c>)
 8000926:	7819      	ldrb	r1, [r3, #0]
 8000928:	4b08      	ldr	r3, [pc, #32]	; (800094c <draw_change_page_button+0x30>)
 800092a:	781b      	ldrb	r3, [r3, #0]
 800092c:	461a      	mov	r2, r3
 800092e:	f000 f9cd 	bl	8000ccc <remix_color>
 8000932:	4603      	mov	r3, r0
 8000934:	2214      	movs	r2, #20
 8000936:	2132      	movs	r1, #50	; 0x32
 8000938:	2096      	movs	r0, #150	; 0x96
 800093a:	f003 fc45 	bl	80041c8 <ILI9341_Draw_Filled_Circle>
			remix_color(red_percent, green_percent, blue_percent));

}
 800093e:	bf00      	nop
 8000940:	bd80      	pop	{r7, pc}
 8000942:	bf00      	nop
 8000944:	20000208 	.word	0x20000208
 8000948:	20025a18 	.word	0x20025a18
 800094c:	20025a0c 	.word	0x20025a0c

08000950 <draw_progress_bars>:

void draw_progress_bars() {
 8000950:	b580      	push	{r7, lr}
 8000952:	b082      	sub	sp, #8
 8000954:	af02      	add	r7, sp, #8

	ILI9341_Draw_Filled_Rectangle_Coord(80, 80, 80 + (160 * red_percent / 100),
 8000956:	4b49      	ldr	r3, [pc, #292]	; (8000a7c <draw_progress_bars+0x12c>)
 8000958:	781b      	ldrb	r3, [r3, #0]
 800095a:	461a      	mov	r2, r3
 800095c:	4613      	mov	r3, r2
 800095e:	009b      	lsls	r3, r3, #2
 8000960:	4413      	add	r3, r2
 8000962:	015b      	lsls	r3, r3, #5
 8000964:	4a46      	ldr	r2, [pc, #280]	; (8000a80 <draw_progress_bars+0x130>)
 8000966:	fb82 1203 	smull	r1, r2, r2, r3
 800096a:	1152      	asrs	r2, r2, #5
 800096c:	17db      	asrs	r3, r3, #31
 800096e:	1ad3      	subs	r3, r2, r3
 8000970:	b29b      	uxth	r3, r3
 8000972:	3350      	adds	r3, #80	; 0x50
 8000974:	b29a      	uxth	r2, r3
 8000976:	f44f 4378 	mov.w	r3, #63488	; 0xf800
 800097a:	9300      	str	r3, [sp, #0]
 800097c:	2378      	movs	r3, #120	; 0x78
 800097e:	2150      	movs	r1, #80	; 0x50
 8000980:	2050      	movs	r0, #80	; 0x50
 8000982:	f003 fca8 	bl	80042d6 <ILI9341_Draw_Filled_Rectangle_Coord>
			120, RED);
	ILI9341_Draw_Filled_Rectangle_Coord(80, 80 + 50,
			80 + (160 * green_percent / 100), 120 + 50, GREEN);
 8000986:	4b3f      	ldr	r3, [pc, #252]	; (8000a84 <draw_progress_bars+0x134>)
 8000988:	781b      	ldrb	r3, [r3, #0]
 800098a:	461a      	mov	r2, r3
 800098c:	4613      	mov	r3, r2
 800098e:	009b      	lsls	r3, r3, #2
 8000990:	4413      	add	r3, r2
 8000992:	015b      	lsls	r3, r3, #5
 8000994:	4a3a      	ldr	r2, [pc, #232]	; (8000a80 <draw_progress_bars+0x130>)
 8000996:	fb82 1203 	smull	r1, r2, r2, r3
 800099a:	1152      	asrs	r2, r2, #5
 800099c:	17db      	asrs	r3, r3, #31
 800099e:	1ad3      	subs	r3, r2, r3
	ILI9341_Draw_Filled_Rectangle_Coord(80, 80 + 50,
 80009a0:	b29b      	uxth	r3, r3
 80009a2:	3350      	adds	r3, #80	; 0x50
 80009a4:	b29a      	uxth	r2, r3
 80009a6:	f44f 63fc 	mov.w	r3, #2016	; 0x7e0
 80009aa:	9300      	str	r3, [sp, #0]
 80009ac:	23aa      	movs	r3, #170	; 0xaa
 80009ae:	2182      	movs	r1, #130	; 0x82
 80009b0:	2050      	movs	r0, #80	; 0x50
 80009b2:	f003 fc90 	bl	80042d6 <ILI9341_Draw_Filled_Rectangle_Coord>
	ILI9341_Draw_Filled_Rectangle_Coord(80, 80 + 100,
			80 + (160 * blue_percent / 100), 120 + 100, BLUE);
 80009b6:	4b34      	ldr	r3, [pc, #208]	; (8000a88 <draw_progress_bars+0x138>)
 80009b8:	781b      	ldrb	r3, [r3, #0]
 80009ba:	461a      	mov	r2, r3
 80009bc:	4613      	mov	r3, r2
 80009be:	009b      	lsls	r3, r3, #2
 80009c0:	4413      	add	r3, r2
 80009c2:	015b      	lsls	r3, r3, #5
 80009c4:	4a2e      	ldr	r2, [pc, #184]	; (8000a80 <draw_progress_bars+0x130>)
 80009c6:	fb82 1203 	smull	r1, r2, r2, r3
 80009ca:	1152      	asrs	r2, r2, #5
 80009cc:	17db      	asrs	r3, r3, #31
 80009ce:	1ad3      	subs	r3, r2, r3
	ILI9341_Draw_Filled_Rectangle_Coord(80, 80 + 100,
 80009d0:	b29b      	uxth	r3, r3
 80009d2:	3350      	adds	r3, #80	; 0x50
 80009d4:	b29a      	uxth	r2, r3
 80009d6:	231f      	movs	r3, #31
 80009d8:	9300      	str	r3, [sp, #0]
 80009da:	23dc      	movs	r3, #220	; 0xdc
 80009dc:	21b4      	movs	r1, #180	; 0xb4
 80009de:	2050      	movs	r0, #80	; 0x50
 80009e0:	f003 fc79 	bl	80042d6 <ILI9341_Draw_Filled_Rectangle_Coord>

	ILI9341_Draw_Filled_Rectangle_Coord(80 + (160 * red_percent / 100), 80, 240,
 80009e4:	4b25      	ldr	r3, [pc, #148]	; (8000a7c <draw_progress_bars+0x12c>)
 80009e6:	781b      	ldrb	r3, [r3, #0]
 80009e8:	461a      	mov	r2, r3
 80009ea:	4613      	mov	r3, r2
 80009ec:	009b      	lsls	r3, r3, #2
 80009ee:	4413      	add	r3, r2
 80009f0:	015b      	lsls	r3, r3, #5
 80009f2:	4a23      	ldr	r2, [pc, #140]	; (8000a80 <draw_progress_bars+0x130>)
 80009f4:	fb82 1203 	smull	r1, r2, r2, r3
 80009f8:	1152      	asrs	r2, r2, #5
 80009fa:	17db      	asrs	r3, r3, #31
 80009fc:	1ad3      	subs	r3, r2, r3
 80009fe:	b29b      	uxth	r3, r3
 8000a00:	3350      	adds	r3, #80	; 0x50
 8000a02:	b298      	uxth	r0, r3
 8000a04:	f64f 6359 	movw	r3, #65113	; 0xfe59
 8000a08:	9300      	str	r3, [sp, #0]
 8000a0a:	2378      	movs	r3, #120	; 0x78
 8000a0c:	22f0      	movs	r2, #240	; 0xf0
 8000a0e:	2150      	movs	r1, #80	; 0x50
 8000a10:	f003 fc61 	bl	80042d6 <ILI9341_Draw_Filled_Rectangle_Coord>
			120, LIGHTRED);
	ILI9341_Draw_Filled_Rectangle_Coord(80 + (160 * green_percent / 100),
 8000a14:	4b1b      	ldr	r3, [pc, #108]	; (8000a84 <draw_progress_bars+0x134>)
 8000a16:	781b      	ldrb	r3, [r3, #0]
 8000a18:	461a      	mov	r2, r3
 8000a1a:	4613      	mov	r3, r2
 8000a1c:	009b      	lsls	r3, r3, #2
 8000a1e:	4413      	add	r3, r2
 8000a20:	015b      	lsls	r3, r3, #5
 8000a22:	4a17      	ldr	r2, [pc, #92]	; (8000a80 <draw_progress_bars+0x130>)
 8000a24:	fb82 1203 	smull	r1, r2, r2, r3
 8000a28:	1152      	asrs	r2, r2, #5
 8000a2a:	17db      	asrs	r3, r3, #31
 8000a2c:	1ad3      	subs	r3, r2, r3
 8000a2e:	b29b      	uxth	r3, r3
 8000a30:	3350      	adds	r3, #80	; 0x50
 8000a32:	b298      	uxth	r0, r3
 8000a34:	f24d 73f9 	movw	r3, #55289	; 0xd7f9
 8000a38:	9300      	str	r3, [sp, #0]
 8000a3a:	23aa      	movs	r3, #170	; 0xaa
 8000a3c:	22f0      	movs	r2, #240	; 0xf0
 8000a3e:	2182      	movs	r1, #130	; 0x82
 8000a40:	f003 fc49 	bl	80042d6 <ILI9341_Draw_Filled_Rectangle_Coord>
			80 + 50, 240, 120 + 50, LIGHTGREEN);
	ILI9341_Draw_Filled_Rectangle_Coord(80 + (160 * blue_percent / 100),
 8000a44:	4b10      	ldr	r3, [pc, #64]	; (8000a88 <draw_progress_bars+0x138>)
 8000a46:	781b      	ldrb	r3, [r3, #0]
 8000a48:	461a      	mov	r2, r3
 8000a4a:	4613      	mov	r3, r2
 8000a4c:	009b      	lsls	r3, r3, #2
 8000a4e:	4413      	add	r3, r2
 8000a50:	015b      	lsls	r3, r3, #5
 8000a52:	4a0b      	ldr	r2, [pc, #44]	; (8000a80 <draw_progress_bars+0x130>)
 8000a54:	fb82 1203 	smull	r1, r2, r2, r3
 8000a58:	1152      	asrs	r2, r2, #5
 8000a5a:	17db      	asrs	r3, r3, #31
 8000a5c:	1ad3      	subs	r3, r2, r3
 8000a5e:	b29b      	uxth	r3, r3
 8000a60:	3350      	adds	r3, #80	; 0x50
 8000a62:	b298      	uxth	r0, r3
 8000a64:	f64c 63bf 	movw	r3, #52927	; 0xcebf
 8000a68:	9300      	str	r3, [sp, #0]
 8000a6a:	23dc      	movs	r3, #220	; 0xdc
 8000a6c:	22f0      	movs	r2, #240	; 0xf0
 8000a6e:	21b4      	movs	r1, #180	; 0xb4
 8000a70:	f003 fc31 	bl	80042d6 <ILI9341_Draw_Filled_Rectangle_Coord>
			80 + 100, 240, 120 + 100, LIGHTBLUE);

}
 8000a74:	bf00      	nop
 8000a76:	46bd      	mov	sp, r7
 8000a78:	bd80      	pop	{r7, pc}
 8000a7a:	bf00      	nop
 8000a7c:	20000208 	.word	0x20000208
 8000a80:	51eb851f 	.word	0x51eb851f
 8000a84:	20025a18 	.word	0x20025a18
 8000a88:	20025a0c 	.word	0x20025a0c

08000a8c <draw_color_percent>:

void draw_color_percent() {
 8000a8c:	b580      	push	{r7, lr}
 8000a8e:	b086      	sub	sp, #24
 8000a90:	af02      	add	r7, sp, #8

	char str[10];

	sprintf(str, "%d%%    ", red_percent);
 8000a92:	4b1e      	ldr	r3, [pc, #120]	; (8000b0c <draw_color_percent+0x80>)
 8000a94:	781b      	ldrb	r3, [r3, #0]
 8000a96:	461a      	mov	r2, r3
 8000a98:	1d3b      	adds	r3, r7, #4
 8000a9a:	491d      	ldr	r1, [pc, #116]	; (8000b10 <draw_color_percent+0x84>)
 8000a9c:	4618      	mov	r0, r3
 8000a9e:	f005 fa81 	bl	8005fa4 <siprintf>
	ILI9341_Draw_Text(str, 250, 90, BLACK, 3, WHITE);
 8000aa2:	1d38      	adds	r0, r7, #4
 8000aa4:	f64f 73ff 	movw	r3, #65535	; 0xffff
 8000aa8:	9301      	str	r3, [sp, #4]
 8000aaa:	2303      	movs	r3, #3
 8000aac:	9300      	str	r3, [sp, #0]
 8000aae:	2300      	movs	r3, #0
 8000ab0:	225a      	movs	r2, #90	; 0x5a
 8000ab2:	21fa      	movs	r1, #250	; 0xfa
 8000ab4:	f003 fd02 	bl	80044bc <ILI9341_Draw_Text>

	sprintf(str, "%d%%    ", green_percent);
 8000ab8:	4b16      	ldr	r3, [pc, #88]	; (8000b14 <draw_color_percent+0x88>)
 8000aba:	781b      	ldrb	r3, [r3, #0]
 8000abc:	461a      	mov	r2, r3
 8000abe:	1d3b      	adds	r3, r7, #4
 8000ac0:	4913      	ldr	r1, [pc, #76]	; (8000b10 <draw_color_percent+0x84>)
 8000ac2:	4618      	mov	r0, r3
 8000ac4:	f005 fa6e 	bl	8005fa4 <siprintf>
	ILI9341_Draw_Text(str, 250, 140, BLACK, 3, WHITE);
 8000ac8:	1d38      	adds	r0, r7, #4
 8000aca:	f64f 73ff 	movw	r3, #65535	; 0xffff
 8000ace:	9301      	str	r3, [sp, #4]
 8000ad0:	2303      	movs	r3, #3
 8000ad2:	9300      	str	r3, [sp, #0]
 8000ad4:	2300      	movs	r3, #0
 8000ad6:	228c      	movs	r2, #140	; 0x8c
 8000ad8:	21fa      	movs	r1, #250	; 0xfa
 8000ada:	f003 fcef 	bl	80044bc <ILI9341_Draw_Text>

	sprintf(str, "%d%%    ", blue_percent);
 8000ade:	4b0e      	ldr	r3, [pc, #56]	; (8000b18 <draw_color_percent+0x8c>)
 8000ae0:	781b      	ldrb	r3, [r3, #0]
 8000ae2:	461a      	mov	r2, r3
 8000ae4:	1d3b      	adds	r3, r7, #4
 8000ae6:	490a      	ldr	r1, [pc, #40]	; (8000b10 <draw_color_percent+0x84>)
 8000ae8:	4618      	mov	r0, r3
 8000aea:	f005 fa5b 	bl	8005fa4 <siprintf>
	ILI9341_Draw_Text(str, 250, 190, BLACK, 3, WHITE);
 8000aee:	1d38      	adds	r0, r7, #4
 8000af0:	f64f 73ff 	movw	r3, #65535	; 0xffff
 8000af4:	9301      	str	r3, [sp, #4]
 8000af6:	2303      	movs	r3, #3
 8000af8:	9300      	str	r3, [sp, #0]
 8000afa:	2300      	movs	r3, #0
 8000afc:	22be      	movs	r2, #190	; 0xbe
 8000afe:	21fa      	movs	r1, #250	; 0xfa
 8000b00:	f003 fcdc 	bl	80044bc <ILI9341_Draw_Text>

}
 8000b04:	bf00      	nop
 8000b06:	3710      	adds	r7, #16
 8000b08:	46bd      	mov	sp, r7
 8000b0a:	bd80      	pop	{r7, pc}
 8000b0c:	20000208 	.word	0x20000208
 8000b10:	08008c58 	.word	0x08008c58
 8000b14:	20025a18 	.word	0x20025a18
 8000b18:	20025a0c 	.word	0x20025a0c

08000b1c <second_page>:

void second_page() {
 8000b1c:	b580      	push	{r7, lr}
 8000b1e:	af00      	add	r7, sp, #0

			ILI9341_Draw_Image( (const char*)me, 3);
 8000b20:	2103      	movs	r1, #3
 8000b22:	4803      	ldr	r0, [pc, #12]	; (8000b30 <second_page+0x14>)
 8000b24:	f003 fcf8 	bl	8004518 <ILI9341_Draw_Image>

			update_page();
 8000b28:	f000 f804 	bl	8000b34 <update_page>

}
 8000b2c:	bf00      	nop
 8000b2e:	bd80      	pop	{r7, pc}
 8000b30:	2000020c 	.word	0x2000020c

08000b34 <update_page>:

void update_page() {
 8000b34:	b580      	push	{r7, lr}
 8000b36:	af00      	add	r7, sp, #0

	if (page_num == 1){
 8000b38:	4b25      	ldr	r3, [pc, #148]	; (8000bd0 <update_page+0x9c>)
 8000b3a:	781b      	ldrb	r3, [r3, #0]
 8000b3c:	2b01      	cmp	r3, #1
 8000b3e:	d12a      	bne.n	8000b96 <update_page+0x62>
	if (TP_Touchpad_Pressed()) {
 8000b40:	f004 fbcc 	bl	80052dc <TP_Touchpad_Pressed>
 8000b44:	4603      	mov	r3, r0
 8000b46:	2b00      	cmp	r3, #0
 8000b48:	d03f      	beq.n	8000bca <update_page+0x96>

		if (TP_Read_Coordinates(coordinates) == TOUCHPAD_DATA_OK) {
 8000b4a:	4822      	ldr	r0, [pc, #136]	; (8000bd4 <update_page+0xa0>)
 8000b4c:	f004 fb04 	bl	8005158 <TP_Read_Coordinates>
 8000b50:	4603      	mov	r3, r0
 8000b52:	2b01      	cmp	r3, #1
 8000b54:	d139      	bne.n	8000bca <update_page+0x96>

			if (coordinates[0] > 30 && coordinates[0] < 80
 8000b56:	4b1f      	ldr	r3, [pc, #124]	; (8000bd4 <update_page+0xa0>)
 8000b58:	881b      	ldrh	r3, [r3, #0]
 8000b5a:	2b1e      	cmp	r3, #30
 8000b5c:	d935      	bls.n	8000bca <update_page+0x96>
 8000b5e:	4b1d      	ldr	r3, [pc, #116]	; (8000bd4 <update_page+0xa0>)
 8000b60:	881b      	ldrh	r3, [r3, #0]
 8000b62:	2b4f      	cmp	r3, #79	; 0x4f
 8000b64:	d831      	bhi.n	8000bca <update_page+0x96>
					&& coordinates[1] < 200 && coordinates[1] > 150) {
 8000b66:	4b1b      	ldr	r3, [pc, #108]	; (8000bd4 <update_page+0xa0>)
 8000b68:	885b      	ldrh	r3, [r3, #2]
 8000b6a:	2bc7      	cmp	r3, #199	; 0xc7
 8000b6c:	d82d      	bhi.n	8000bca <update_page+0x96>
 8000b6e:	4b19      	ldr	r3, [pc, #100]	; (8000bd4 <update_page+0xa0>)
 8000b70:	885b      	ldrh	r3, [r3, #2]
 8000b72:	2b96      	cmp	r3, #150	; 0x96
 8000b74:	d929      	bls.n	8000bca <update_page+0x96>
				ILI9341_Fill_Screen(WHITE);
 8000b76:	f64f 70ff 	movw	r0, #65535	; 0xffff
 8000b7a:	f004 f92d 	bl	8004dd8 <ILI9341_Fill_Screen>
				page_num = 2;
 8000b7e:	4b14      	ldr	r3, [pc, #80]	; (8000bd0 <update_page+0x9c>)
 8000b80:	2202      	movs	r2, #2
 8000b82:	701a      	strb	r2, [r3, #0]
				HAL_Delay(200);
 8000b84:	20c8      	movs	r0, #200	; 0xc8
 8000b86:	f000 fcc9 	bl	800151c <HAL_Delay>
				time = HAL_GetTick();
 8000b8a:	f000 fcbb 	bl	8001504 <HAL_GetTick>
 8000b8e:	4602      	mov	r2, r0
 8000b90:	4b11      	ldr	r3, [pc, #68]	; (8000bd8 <update_page+0xa4>)
 8000b92:	601a      	str	r2, [r3, #0]
		if(TP_Touchpad_Pressed() || HAL_GetTick()-time > 5000){
			ILI9341_Fill_Screen(WHITE);
			page_num = 1;
		}
	}
}
 8000b94:	e019      	b.n	8000bca <update_page+0x96>
	else if(page_num == 2){
 8000b96:	4b0e      	ldr	r3, [pc, #56]	; (8000bd0 <update_page+0x9c>)
 8000b98:	781b      	ldrb	r3, [r3, #0]
 8000b9a:	2b02      	cmp	r3, #2
 8000b9c:	d115      	bne.n	8000bca <update_page+0x96>
		if(TP_Touchpad_Pressed() || HAL_GetTick()-time > 5000){
 8000b9e:	f004 fb9d 	bl	80052dc <TP_Touchpad_Pressed>
 8000ba2:	4603      	mov	r3, r0
 8000ba4:	2b00      	cmp	r3, #0
 8000ba6:	d109      	bne.n	8000bbc <update_page+0x88>
 8000ba8:	f000 fcac 	bl	8001504 <HAL_GetTick>
 8000bac:	4602      	mov	r2, r0
 8000bae:	4b0a      	ldr	r3, [pc, #40]	; (8000bd8 <update_page+0xa4>)
 8000bb0:	681b      	ldr	r3, [r3, #0]
 8000bb2:	1ad3      	subs	r3, r2, r3
 8000bb4:	f241 3288 	movw	r2, #5000	; 0x1388
 8000bb8:	4293      	cmp	r3, r2
 8000bba:	d906      	bls.n	8000bca <update_page+0x96>
			ILI9341_Fill_Screen(WHITE);
 8000bbc:	f64f 70ff 	movw	r0, #65535	; 0xffff
 8000bc0:	f004 f90a 	bl	8004dd8 <ILI9341_Fill_Screen>
			page_num = 1;
 8000bc4:	4b02      	ldr	r3, [pc, #8]	; (8000bd0 <update_page+0x9c>)
 8000bc6:	2201      	movs	r2, #1
 8000bc8:	701a      	strb	r2, [r3, #0]
}
 8000bca:	bf00      	nop
 8000bcc:	bd80      	pop	{r7, pc}
 8000bce:	bf00      	nop
 8000bd0:	20025a19 	.word	0x20025a19
 8000bd4:	20025a10 	.word	0x20025a10
 8000bd8:	20025a14 	.word	0x20025a14

08000bdc <update_progress_bars>:

void update_progress_bars() {
 8000bdc:	b580      	push	{r7, lr}
 8000bde:	af00      	add	r7, sp, #0

		if (TP_Touchpad_Pressed()) {
 8000be0:	f004 fb7c 	bl	80052dc <TP_Touchpad_Pressed>
 8000be4:	4603      	mov	r3, r0
 8000be6:	2b00      	cmp	r3, #0
 8000be8:	d065      	beq.n	8000cb6 <update_progress_bars+0xda>

			if (TP_Read_Coordinates(coordinates) == TOUCHPAD_DATA_OK) {
 8000bea:	4834      	ldr	r0, [pc, #208]	; (8000cbc <update_progress_bars+0xe0>)
 8000bec:	f004 fab4 	bl	8005158 <TP_Read_Coordinates>
 8000bf0:	4603      	mov	r3, r0
 8000bf2:	2b01      	cmp	r3, #1
 8000bf4:	d15f      	bne.n	8000cb6 <update_progress_bars+0xda>

				// push red button
				if (coordinates[0] > 90 && coordinates[0] < 140
 8000bf6:	4b31      	ldr	r3, [pc, #196]	; (8000cbc <update_progress_bars+0xe0>)
 8000bf8:	881b      	ldrh	r3, [r3, #0]
 8000bfa:	2b5a      	cmp	r3, #90	; 0x5a
 8000bfc:	d91a      	bls.n	8000c34 <update_progress_bars+0x58>
 8000bfe:	4b2f      	ldr	r3, [pc, #188]	; (8000cbc <update_progress_bars+0xe0>)
 8000c00:	881b      	ldrh	r3, [r3, #0]
 8000c02:	2b8b      	cmp	r3, #139	; 0x8b
 8000c04:	d816      	bhi.n	8000c34 <update_progress_bars+0x58>
						&& coordinates[1] < 310 && coordinates[1] > 260) {
 8000c06:	4b2d      	ldr	r3, [pc, #180]	; (8000cbc <update_progress_bars+0xe0>)
 8000c08:	885b      	ldrh	r3, [r3, #2]
 8000c0a:	f5b3 7f9b 	cmp.w	r3, #310	; 0x136
 8000c0e:	d211      	bcs.n	8000c34 <update_progress_bars+0x58>
 8000c10:	4b2a      	ldr	r3, [pc, #168]	; (8000cbc <update_progress_bars+0xe0>)
 8000c12:	885b      	ldrh	r3, [r3, #2]
 8000c14:	f5b3 7f82 	cmp.w	r3, #260	; 0x104
 8000c18:	d90c      	bls.n	8000c34 <update_progress_bars+0x58>

					red_percent += 10;
 8000c1a:	4b29      	ldr	r3, [pc, #164]	; (8000cc0 <update_progress_bars+0xe4>)
 8000c1c:	781b      	ldrb	r3, [r3, #0]
 8000c1e:	330a      	adds	r3, #10
 8000c20:	b2da      	uxtb	r2, r3
 8000c22:	4b27      	ldr	r3, [pc, #156]	; (8000cc0 <update_progress_bars+0xe4>)
 8000c24:	701a      	strb	r2, [r3, #0]
					if (red_percent > 100) {
 8000c26:	4b26      	ldr	r3, [pc, #152]	; (8000cc0 <update_progress_bars+0xe4>)
 8000c28:	781b      	ldrb	r3, [r3, #0]
 8000c2a:	2b64      	cmp	r3, #100	; 0x64
 8000c2c:	d902      	bls.n	8000c34 <update_progress_bars+0x58>
						red_percent = 0;
 8000c2e:	4b24      	ldr	r3, [pc, #144]	; (8000cc0 <update_progress_bars+0xe4>)
 8000c30:	2200      	movs	r2, #0
 8000c32:	701a      	strb	r2, [r3, #0]
					}

				}

				// push green button
				if (coordinates[0] > 130 && coordinates[0] < 180
 8000c34:	4b21      	ldr	r3, [pc, #132]	; (8000cbc <update_progress_bars+0xe0>)
 8000c36:	881b      	ldrh	r3, [r3, #0]
 8000c38:	2b82      	cmp	r3, #130	; 0x82
 8000c3a:	d91a      	bls.n	8000c72 <update_progress_bars+0x96>
 8000c3c:	4b1f      	ldr	r3, [pc, #124]	; (8000cbc <update_progress_bars+0xe0>)
 8000c3e:	881b      	ldrh	r3, [r3, #0]
 8000c40:	2bb3      	cmp	r3, #179	; 0xb3
 8000c42:	d816      	bhi.n	8000c72 <update_progress_bars+0x96>
						&& coordinates[1] < 310 && coordinates[1] > 260) {
 8000c44:	4b1d      	ldr	r3, [pc, #116]	; (8000cbc <update_progress_bars+0xe0>)
 8000c46:	885b      	ldrh	r3, [r3, #2]
 8000c48:	f5b3 7f9b 	cmp.w	r3, #310	; 0x136
 8000c4c:	d211      	bcs.n	8000c72 <update_progress_bars+0x96>
 8000c4e:	4b1b      	ldr	r3, [pc, #108]	; (8000cbc <update_progress_bars+0xe0>)
 8000c50:	885b      	ldrh	r3, [r3, #2]
 8000c52:	f5b3 7f82 	cmp.w	r3, #260	; 0x104
 8000c56:	d90c      	bls.n	8000c72 <update_progress_bars+0x96>
					green_percent += 10;
 8000c58:	4b1a      	ldr	r3, [pc, #104]	; (8000cc4 <update_progress_bars+0xe8>)
 8000c5a:	781b      	ldrb	r3, [r3, #0]
 8000c5c:	330a      	adds	r3, #10
 8000c5e:	b2da      	uxtb	r2, r3
 8000c60:	4b18      	ldr	r3, [pc, #96]	; (8000cc4 <update_progress_bars+0xe8>)
 8000c62:	701a      	strb	r2, [r3, #0]
					if (green_percent > 100) {
 8000c64:	4b17      	ldr	r3, [pc, #92]	; (8000cc4 <update_progress_bars+0xe8>)
 8000c66:	781b      	ldrb	r3, [r3, #0]
 8000c68:	2b64      	cmp	r3, #100	; 0x64
 8000c6a:	d902      	bls.n	8000c72 <update_progress_bars+0x96>
						green_percent = 0;
 8000c6c:	4b15      	ldr	r3, [pc, #84]	; (8000cc4 <update_progress_bars+0xe8>)
 8000c6e:	2200      	movs	r2, #0
 8000c70:	701a      	strb	r2, [r3, #0]
					}
				}

				// push blue button
				if (coordinates[0] > 190 && coordinates[0] < 220
 8000c72:	4b12      	ldr	r3, [pc, #72]	; (8000cbc <update_progress_bars+0xe0>)
 8000c74:	881b      	ldrh	r3, [r3, #0]
 8000c76:	2bbe      	cmp	r3, #190	; 0xbe
 8000c78:	d91a      	bls.n	8000cb0 <update_progress_bars+0xd4>
 8000c7a:	4b10      	ldr	r3, [pc, #64]	; (8000cbc <update_progress_bars+0xe0>)
 8000c7c:	881b      	ldrh	r3, [r3, #0]
 8000c7e:	2bdb      	cmp	r3, #219	; 0xdb
 8000c80:	d816      	bhi.n	8000cb0 <update_progress_bars+0xd4>
						&& coordinates[1] < 310 && coordinates[1] > 260) {
 8000c82:	4b0e      	ldr	r3, [pc, #56]	; (8000cbc <update_progress_bars+0xe0>)
 8000c84:	885b      	ldrh	r3, [r3, #2]
 8000c86:	f5b3 7f9b 	cmp.w	r3, #310	; 0x136
 8000c8a:	d211      	bcs.n	8000cb0 <update_progress_bars+0xd4>
 8000c8c:	4b0b      	ldr	r3, [pc, #44]	; (8000cbc <update_progress_bars+0xe0>)
 8000c8e:	885b      	ldrh	r3, [r3, #2]
 8000c90:	f5b3 7f82 	cmp.w	r3, #260	; 0x104
 8000c94:	d90c      	bls.n	8000cb0 <update_progress_bars+0xd4>
					blue_percent += 10;
 8000c96:	4b0c      	ldr	r3, [pc, #48]	; (8000cc8 <update_progress_bars+0xec>)
 8000c98:	781b      	ldrb	r3, [r3, #0]
 8000c9a:	330a      	adds	r3, #10
 8000c9c:	b2da      	uxtb	r2, r3
 8000c9e:	4b0a      	ldr	r3, [pc, #40]	; (8000cc8 <update_progress_bars+0xec>)
 8000ca0:	701a      	strb	r2, [r3, #0]
					if (blue_percent > 100) {
 8000ca2:	4b09      	ldr	r3, [pc, #36]	; (8000cc8 <update_progress_bars+0xec>)
 8000ca4:	781b      	ldrb	r3, [r3, #0]
 8000ca6:	2b64      	cmp	r3, #100	; 0x64
 8000ca8:	d902      	bls.n	8000cb0 <update_progress_bars+0xd4>
						blue_percent = 0;
 8000caa:	4b07      	ldr	r3, [pc, #28]	; (8000cc8 <update_progress_bars+0xec>)
 8000cac:	2200      	movs	r2, #0
 8000cae:	701a      	strb	r2, [r3, #0]
					}
				}

				HAL_Delay(200);
 8000cb0:	20c8      	movs	r0, #200	; 0xc8
 8000cb2:	f000 fc33 	bl	800151c <HAL_Delay>

			}

		}

}
 8000cb6:	bf00      	nop
 8000cb8:	bd80      	pop	{r7, pc}
 8000cba:	bf00      	nop
 8000cbc:	20025a10 	.word	0x20025a10
 8000cc0:	20000208 	.word	0x20000208
 8000cc4:	20025a18 	.word	0x20025a18
 8000cc8:	20025a0c 	.word	0x20025a0c

08000ccc <remix_color>:

// r g b in percent
uint16_t remix_color(uint8_t r, uint8_t g, uint8_t b) {
 8000ccc:	b480      	push	{r7}
 8000cce:	b083      	sub	sp, #12
 8000cd0:	af00      	add	r7, sp, #0
 8000cd2:	4603      	mov	r3, r0
 8000cd4:	71fb      	strb	r3, [r7, #7]
 8000cd6:	460b      	mov	r3, r1
 8000cd8:	71bb      	strb	r3, [r7, #6]
 8000cda:	4613      	mov	r3, r2
 8000cdc:	717b      	strb	r3, [r7, #5]

		return (((r * RED) / 100) & RED) | (((g * GREEN) / 100) & GREEN)
 8000cde:	79fa      	ldrb	r2, [r7, #7]
 8000ce0:	4613      	mov	r3, r2
 8000ce2:	015b      	lsls	r3, r3, #5
 8000ce4:	1a9b      	subs	r3, r3, r2
 8000ce6:	02db      	lsls	r3, r3, #11
 8000ce8:	4a18      	ldr	r2, [pc, #96]	; (8000d4c <remix_color+0x80>)
 8000cea:	fb82 1203 	smull	r1, r2, r2, r3
 8000cee:	1152      	asrs	r2, r2, #5
 8000cf0:	17db      	asrs	r3, r3, #31
 8000cf2:	1ad3      	subs	r3, r2, r3
 8000cf4:	b21a      	sxth	r2, r3
 8000cf6:	4b16      	ldr	r3, [pc, #88]	; (8000d50 <remix_color+0x84>)
 8000cf8:	4013      	ands	r3, r2
 8000cfa:	b219      	sxth	r1, r3
 8000cfc:	79ba      	ldrb	r2, [r7, #6]
 8000cfe:	4613      	mov	r3, r2
 8000d00:	019b      	lsls	r3, r3, #6
 8000d02:	1a9b      	subs	r3, r3, r2
 8000d04:	015b      	lsls	r3, r3, #5
 8000d06:	4a11      	ldr	r2, [pc, #68]	; (8000d4c <remix_color+0x80>)
 8000d08:	fb82 0203 	smull	r0, r2, r2, r3
 8000d0c:	1152      	asrs	r2, r2, #5
 8000d0e:	17db      	asrs	r3, r3, #31
 8000d10:	1ad3      	subs	r3, r2, r3
 8000d12:	b21b      	sxth	r3, r3
 8000d14:	f403 63fc 	and.w	r3, r3, #2016	; 0x7e0
 8000d18:	b21b      	sxth	r3, r3
 8000d1a:	430b      	orrs	r3, r1
 8000d1c:	b219      	sxth	r1, r3
				| (((b * BLUE) / 100) & BLUE);
 8000d1e:	797a      	ldrb	r2, [r7, #5]
 8000d20:	4613      	mov	r3, r2
 8000d22:	015b      	lsls	r3, r3, #5
 8000d24:	1a9b      	subs	r3, r3, r2
 8000d26:	4a09      	ldr	r2, [pc, #36]	; (8000d4c <remix_color+0x80>)
 8000d28:	fb82 0203 	smull	r0, r2, r2, r3
 8000d2c:	1152      	asrs	r2, r2, #5
 8000d2e:	17db      	asrs	r3, r3, #31
 8000d30:	1ad3      	subs	r3, r2, r3
 8000d32:	b21b      	sxth	r3, r3
 8000d34:	f003 031f 	and.w	r3, r3, #31
 8000d38:	b21b      	sxth	r3, r3
 8000d3a:	430b      	orrs	r3, r1
 8000d3c:	b21b      	sxth	r3, r3
 8000d3e:	b29b      	uxth	r3, r3

}
 8000d40:	4618      	mov	r0, r3
 8000d42:	370c      	adds	r7, #12
 8000d44:	46bd      	mov	sp, r7
 8000d46:	f85d 7b04 	ldr.w	r7, [sp], #4
 8000d4a:	4770      	bx	lr
 8000d4c:	51eb851f 	.word	0x51eb851f
 8000d50:	fffff800 	.word	0xfffff800

08000d54 <SCB_EnableICache>:
/**
  \brief   Enable I-Cache
  \details Turns on I-Cache
  */
__STATIC_INLINE void SCB_EnableICache (void)
{
 8000d54:	b480      	push	{r7}
 8000d56:	af00      	add	r7, sp, #0
  \details Acts as a special kind of Data Memory Barrier.
           It completes when all explicit memory accesses before this instruction complete.
 */
__STATIC_FORCEINLINE void __DSB(void)
{
  __ASM volatile ("dsb 0xF":::"memory");
 8000d58:	f3bf 8f4f 	dsb	sy
  __ASM volatile ("isb 0xF":::"memory");
 8000d5c:	f3bf 8f6f 	isb	sy
  #if defined (__ICACHE_PRESENT) && (__ICACHE_PRESENT == 1U)
    __DSB();
    __ISB();
    SCB->ICIALLU = 0UL;                     /* invalidate I-Cache */
 8000d60:	4b0b      	ldr	r3, [pc, #44]	; (8000d90 <SCB_EnableICache+0x3c>)
 8000d62:	2200      	movs	r2, #0
 8000d64:	f8c3 2250 	str.w	r2, [r3, #592]	; 0x250
  __ASM volatile ("dsb 0xF":::"memory");
 8000d68:	f3bf 8f4f 	dsb	sy
  __ASM volatile ("isb 0xF":::"memory");
 8000d6c:	f3bf 8f6f 	isb	sy
    __DSB();
    __ISB();
    SCB->CCR |=  (uint32_t)SCB_CCR_IC_Msk;  /* enable I-Cache */
 8000d70:	4b07      	ldr	r3, [pc, #28]	; (8000d90 <SCB_EnableICache+0x3c>)
 8000d72:	695b      	ldr	r3, [r3, #20]
 8000d74:	4a06      	ldr	r2, [pc, #24]	; (8000d90 <SCB_EnableICache+0x3c>)
 8000d76:	f443 3300 	orr.w	r3, r3, #131072	; 0x20000
 8000d7a:	6153      	str	r3, [r2, #20]
  __ASM volatile ("dsb 0xF":::"memory");
 8000d7c:	f3bf 8f4f 	dsb	sy
  __ASM volatile ("isb 0xF":::"memory");
 8000d80:	f3bf 8f6f 	isb	sy
    __DSB();
    __ISB();
  #endif
}
 8000d84:	bf00      	nop
 8000d86:	46bd      	mov	sp, r7
 8000d88:	f85d 7b04 	ldr.w	r7, [sp], #4
 8000d8c:	4770      	bx	lr
 8000d8e:	bf00      	nop
 8000d90:	e000ed00 	.word	0xe000ed00

08000d94 <SCB_EnableDCache>:
/**
  \brief   Enable D-Cache
  \details Turns on D-Cache
  */
__STATIC_INLINE void SCB_EnableDCache (void)
{
 8000d94:	b480      	push	{r7}
 8000d96:	b085      	sub	sp, #20
 8000d98:	af00      	add	r7, sp, #0
  #if defined (__DCACHE_PRESENT) && (__DCACHE_PRESENT == 1U)
    uint32_t ccsidr;
    uint32_t sets;
    uint32_t ways;

    SCB->CSSELR = 0U; /*(0U << 1U) | 0U;*/  /* Level 1 data cache */
 8000d9a:	4b1d      	ldr	r3, [pc, #116]	; (8000e10 <SCB_EnableDCache+0x7c>)
 8000d9c:	2200      	movs	r2, #0
 8000d9e:	f8c3 2084 	str.w	r2, [r3, #132]	; 0x84
  __ASM volatile ("dsb 0xF":::"memory");
 8000da2:	f3bf 8f4f 	dsb	sy
    __DSB();

    ccsidr = SCB->CCSIDR;
 8000da6:	4b1a      	ldr	r3, [pc, #104]	; (8000e10 <SCB_EnableDCache+0x7c>)
 8000da8:	f8d3 3080 	ldr.w	r3, [r3, #128]	; 0x80
 8000dac:	607b      	str	r3, [r7, #4]

                                            /* invalidate D-Cache */
    sets = (uint32_t)(CCSIDR_SETS(ccsidr));
 8000dae:	687b      	ldr	r3, [r7, #4]
 8000db0:	0b5b      	lsrs	r3, r3, #13
 8000db2:	f3c3 030e 	ubfx	r3, r3, #0, #15
 8000db6:	60fb      	str	r3, [r7, #12]
    do {
      ways = (uint32_t)(CCSIDR_WAYS(ccsidr));
 8000db8:	687b      	ldr	r3, [r7, #4]
 8000dba:	08db      	lsrs	r3, r3, #3
 8000dbc:	f3c3 0309 	ubfx	r3, r3, #0, #10
 8000dc0:	60bb      	str	r3, [r7, #8]
      do {
        SCB->DCISW = (((sets << SCB_DCISW_SET_Pos) & SCB_DCISW_SET_Msk) |
 8000dc2:	68fb      	ldr	r3, [r7, #12]
 8000dc4:	015a      	lsls	r2, r3, #5
 8000dc6:	f643 73e0 	movw	r3, #16352	; 0x3fe0
 8000dca:	4013      	ands	r3, r2
                      ((ways << SCB_DCISW_WAY_Pos) & SCB_DCISW_WAY_Msk)  );
 8000dcc:	68ba      	ldr	r2, [r7, #8]
 8000dce:	0792      	lsls	r2, r2, #30
        SCB->DCISW = (((sets << SCB_DCISW_SET_Pos) & SCB_DCISW_SET_Msk) |
 8000dd0:	490f      	ldr	r1, [pc, #60]	; (8000e10 <SCB_EnableDCache+0x7c>)
 8000dd2:	4313      	orrs	r3, r2
 8000dd4:	f8c1 3260 	str.w	r3, [r1, #608]	; 0x260
        #if defined ( __CC_ARM )
          __schedule_barrier();
        #endif
      } while (ways-- != 0U);
 8000dd8:	68bb      	ldr	r3, [r7, #8]
 8000dda:	1e5a      	subs	r2, r3, #1
 8000ddc:	60ba      	str	r2, [r7, #8]
 8000dde:	2b00      	cmp	r3, #0
 8000de0:	d1ef      	bne.n	8000dc2 <SCB_EnableDCache+0x2e>
    } while(sets-- != 0U);
 8000de2:	68fb      	ldr	r3, [r7, #12]
 8000de4:	1e5a      	subs	r2, r3, #1
 8000de6:	60fa      	str	r2, [r7, #12]
 8000de8:	2b00      	cmp	r3, #0
 8000dea:	d1e5      	bne.n	8000db8 <SCB_EnableDCache+0x24>
 8000dec:	f3bf 8f4f 	dsb	sy
    __DSB();

    SCB->CCR |=  (uint32_t)SCB_CCR_DC_Msk;  /* enable D-Cache */
 8000df0:	4b07      	ldr	r3, [pc, #28]	; (8000e10 <SCB_EnableDCache+0x7c>)
 8000df2:	695b      	ldr	r3, [r3, #20]
 8000df4:	4a06      	ldr	r2, [pc, #24]	; (8000e10 <SCB_EnableDCache+0x7c>)
 8000df6:	f443 3380 	orr.w	r3, r3, #65536	; 0x10000
 8000dfa:	6153      	str	r3, [r2, #20]
 8000dfc:	f3bf 8f4f 	dsb	sy
  __ASM volatile ("isb 0xF":::"memory");
 8000e00:	f3bf 8f6f 	isb	sy

    __DSB();
    __ISB();
  #endif
}
 8000e04:	bf00      	nop
 8000e06:	3714      	adds	r7, #20
 8000e08:	46bd      	mov	sp, r7
 8000e0a:	f85d 7b04 	ldr.w	r7, [sp], #4
 8000e0e:	4770      	bx	lr
 8000e10:	e000ed00 	.word	0xe000ed00

08000e14 <main>:
/**
  * @brief  The application entry point.
  * @retval int
  */
int main(void)
{
 8000e14:	b580      	push	{r7, lr}
 8000e16:	af00      	add	r7, sp, #0
  /* USER CODE BEGIN 1 */

  /* USER CODE END 1 */

  /* Enable I-Cache---------------------------------------------------------*/
  SCB_EnableICache();
 8000e18:	f7ff ff9c 	bl	8000d54 <SCB_EnableICache>

  /* Enable D-Cache---------------------------------------------------------*/
  SCB_EnableDCache();
 8000e1c:	f7ff ffba 	bl	8000d94 <SCB_EnableDCache>

  /* MCU Configuration--------------------------------------------------------*/

  /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  HAL_Init();
 8000e20:	f000 fb10 	bl	8001444 <HAL_Init>
  /* USER CODE BEGIN Init */

  /* USER CODE END Init */

  /* Configure the system clock */
  SystemClock_Config();
 8000e24:	f000 f810 	bl	8000e48 <SystemClock_Config>
  /* USER CODE BEGIN SysInit */

  /* USER CODE END SysInit */

  /* Initialize all configured peripherals */
  MX_GPIO_Init();
 8000e28:	f7ff fbe2 	bl	80005f0 <MX_GPIO_Init>
  MX_USART3_UART_Init();
 8000e2c:	f000 fa6c 	bl	8001308 <MX_USART3_UART_Init>
  MX_SPI5_Init();
 8000e30:	f000 f8fc 	bl	800102c <MX_SPI5_Init>
  MX_TIM1_Init();
 8000e34:	f000 f9f2 	bl	800121c <MX_TIM1_Init>
  MX_RNG_Init();
 8000e38:	f000 f8c4 	bl	8000fc4 <MX_RNG_Init>
  /* USER CODE BEGIN 2 */
  GUI_init();
 8000e3c:	f7ff fd0a 	bl	8000854 <GUI_init>

  /* Infinite loop */
  /* USER CODE BEGIN WHILE */
  while (1)
  {
	  main_system();
 8000e40:	f7ff fd30 	bl	80008a4 <main_system>
 8000e44:	e7fc      	b.n	8000e40 <main+0x2c>
	...

08000e48 <SystemClock_Config>:
/**
  * @brief System Clock Configuration
  * @retval None
  */
void SystemClock_Config(void)
{
 8000e48:	b580      	push	{r7, lr}
 8000e4a:	b0b8      	sub	sp, #224	; 0xe0
 8000e4c:	af00      	add	r7, sp, #0
  RCC_OscInitTypeDef RCC_OscInitStruct = {0};
 8000e4e:	f107 03ac 	add.w	r3, r7, #172	; 0xac
 8000e52:	2234      	movs	r2, #52	; 0x34
 8000e54:	2100      	movs	r1, #0
 8000e56:	4618      	mov	r0, r3
 8000e58:	f004 fa85 	bl	8005366 <memset>
  RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
 8000e5c:	f107 0398 	add.w	r3, r7, #152	; 0x98
 8000e60:	2200      	movs	r2, #0
 8000e62:	601a      	str	r2, [r3, #0]
 8000e64:	605a      	str	r2, [r3, #4]
 8000e66:	609a      	str	r2, [r3, #8]
 8000e68:	60da      	str	r2, [r3, #12]
 8000e6a:	611a      	str	r2, [r3, #16]
  RCC_PeriphCLKInitTypeDef PeriphClkInitStruct = {0};
 8000e6c:	f107 0308 	add.w	r3, r7, #8
 8000e70:	2290      	movs	r2, #144	; 0x90
 8000e72:	2100      	movs	r1, #0
 8000e74:	4618      	mov	r0, r3
 8000e76:	f004 fa76 	bl	8005366 <memset>

  /** Configure LSE Drive Capability
  */
  HAL_PWR_EnableBkUpAccess();
 8000e7a:	f000 fe33 	bl	8001ae4 <HAL_PWR_EnableBkUpAccess>
  /** Configure the main internal regulator output voltage
  */
  __HAL_RCC_PWR_CLK_ENABLE();
 8000e7e:	4b3a      	ldr	r3, [pc, #232]	; (8000f68 <SystemClock_Config+0x120>)
 8000e80:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 8000e82:	4a39      	ldr	r2, [pc, #228]	; (8000f68 <SystemClock_Config+0x120>)
 8000e84:	f043 5380 	orr.w	r3, r3, #268435456	; 0x10000000
 8000e88:	6413      	str	r3, [r2, #64]	; 0x40
 8000e8a:	4b37      	ldr	r3, [pc, #220]	; (8000f68 <SystemClock_Config+0x120>)
 8000e8c:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 8000e8e:	f003 5380 	and.w	r3, r3, #268435456	; 0x10000000
 8000e92:	607b      	str	r3, [r7, #4]
 8000e94:	687b      	ldr	r3, [r7, #4]
  __HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1);
 8000e96:	4b35      	ldr	r3, [pc, #212]	; (8000f6c <SystemClock_Config+0x124>)
 8000e98:	681b      	ldr	r3, [r3, #0]
 8000e9a:	4a34      	ldr	r2, [pc, #208]	; (8000f6c <SystemClock_Config+0x124>)
 8000e9c:	f443 4340 	orr.w	r3, r3, #49152	; 0xc000
 8000ea0:	6013      	str	r3, [r2, #0]
 8000ea2:	4b32      	ldr	r3, [pc, #200]	; (8000f6c <SystemClock_Config+0x124>)
 8000ea4:	681b      	ldr	r3, [r3, #0]
 8000ea6:	f403 4340 	and.w	r3, r3, #49152	; 0xc000
 8000eaa:	603b      	str	r3, [r7, #0]
 8000eac:	683b      	ldr	r3, [r7, #0]
  /** Initializes the RCC Oscillators according to the specified parameters
  * in the RCC_OscInitTypeDef structure.
  */
  RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSE;
 8000eae:	2301      	movs	r3, #1
 8000eb0:	f8c7 30ac 	str.w	r3, [r7, #172]	; 0xac
  RCC_OscInitStruct.HSEState = RCC_HSE_BYPASS;
 8000eb4:	f44f 23a0 	mov.w	r3, #327680	; 0x50000
 8000eb8:	f8c7 30b0 	str.w	r3, [r7, #176]	; 0xb0
  RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
 8000ebc:	2302      	movs	r3, #2
 8000ebe:	f8c7 30c4 	str.w	r3, [r7, #196]	; 0xc4
  RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSE;
 8000ec2:	f44f 0380 	mov.w	r3, #4194304	; 0x400000
 8000ec6:	f8c7 30c8 	str.w	r3, [r7, #200]	; 0xc8
  RCC_OscInitStruct.PLL.PLLM = 4;
 8000eca:	2304      	movs	r3, #4
 8000ecc:	f8c7 30cc 	str.w	r3, [r7, #204]	; 0xcc
  RCC_OscInitStruct.PLL.PLLN = 200;
 8000ed0:	23c8      	movs	r3, #200	; 0xc8
 8000ed2:	f8c7 30d0 	str.w	r3, [r7, #208]	; 0xd0
  RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV2;
 8000ed6:	2302      	movs	r3, #2
 8000ed8:	f8c7 30d4 	str.w	r3, [r7, #212]	; 0xd4
  RCC_OscInitStruct.PLL.PLLQ = 9;
 8000edc:	2309      	movs	r3, #9
 8000ede:	f8c7 30d8 	str.w	r3, [r7, #216]	; 0xd8
  if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
 8000ee2:	f107 03ac 	add.w	r3, r7, #172	; 0xac
 8000ee6:	4618      	mov	r0, r3
 8000ee8:	f000 fe5c 	bl	8001ba4 <HAL_RCC_OscConfig>
 8000eec:	4603      	mov	r3, r0
 8000eee:	2b00      	cmp	r3, #0
 8000ef0:	d001      	beq.n	8000ef6 <SystemClock_Config+0xae>
  {
    Error_Handler();
 8000ef2:	f000 f83f 	bl	8000f74 <Error_Handler>
  }
  /** Activate the Over-Drive mode
  */
  if (HAL_PWREx_EnableOverDrive() != HAL_OK)
 8000ef6:	f000 fe05 	bl	8001b04 <HAL_PWREx_EnableOverDrive>
 8000efa:	4603      	mov	r3, r0
 8000efc:	2b00      	cmp	r3, #0
 8000efe:	d001      	beq.n	8000f04 <SystemClock_Config+0xbc>
  {
    Error_Handler();
 8000f00:	f000 f838 	bl	8000f74 <Error_Handler>
  }
  /** Initializes the CPU, AHB and APB buses clocks
  */
  RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
 8000f04:	230f      	movs	r3, #15
 8000f06:	f8c7 3098 	str.w	r3, [r7, #152]	; 0x98
                              |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
  RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
 8000f0a:	2302      	movs	r3, #2
 8000f0c:	f8c7 309c 	str.w	r3, [r7, #156]	; 0x9c
  RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
 8000f10:	2300      	movs	r3, #0
 8000f12:	f8c7 30a0 	str.w	r3, [r7, #160]	; 0xa0
  RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV4;
 8000f16:	f44f 53a0 	mov.w	r3, #5120	; 0x1400
 8000f1a:	f8c7 30a4 	str.w	r3, [r7, #164]	; 0xa4
  RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV2;
 8000f1e:	f44f 5380 	mov.w	r3, #4096	; 0x1000
 8000f22:	f8c7 30a8 	str.w	r3, [r7, #168]	; 0xa8

  if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_6) != HAL_OK)
 8000f26:	f107 0398 	add.w	r3, r7, #152	; 0x98
 8000f2a:	2106      	movs	r1, #6
 8000f2c:	4618      	mov	r0, r3
 8000f2e:	f001 f8e7 	bl	8002100 <HAL_RCC_ClockConfig>
 8000f32:	4603      	mov	r3, r0
 8000f34:	2b00      	cmp	r3, #0
 8000f36:	d001      	beq.n	8000f3c <SystemClock_Config+0xf4>
  {
    Error_Handler();
 8000f38:	f000 f81c 	bl	8000f74 <Error_Handler>
  }
  PeriphClkInitStruct.PeriphClockSelection = RCC_PERIPHCLK_USART3|RCC_PERIPHCLK_CLK48;
 8000f3c:	4b0c      	ldr	r3, [pc, #48]	; (8000f70 <SystemClock_Config+0x128>)
 8000f3e:	60bb      	str	r3, [r7, #8]
  PeriphClkInitStruct.Usart3ClockSelection = RCC_USART3CLKSOURCE_PCLK1;
 8000f40:	2300      	movs	r3, #0
 8000f42:	657b      	str	r3, [r7, #84]	; 0x54
  PeriphClkInitStruct.Clk48ClockSelection = RCC_CLK48SOURCE_PLL;
 8000f44:	2300      	movs	r3, #0
 8000f46:	f8c7 3084 	str.w	r3, [r7, #132]	; 0x84
  if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInitStruct) != HAL_OK)
 8000f4a:	f107 0308 	add.w	r3, r7, #8
 8000f4e:	4618      	mov	r0, r3
 8000f50:	f001 face 	bl	80024f0 <HAL_RCCEx_PeriphCLKConfig>
 8000f54:	4603      	mov	r3, r0
 8000f56:	2b00      	cmp	r3, #0
 8000f58:	d001      	beq.n	8000f5e <SystemClock_Config+0x116>
  {
    Error_Handler();
 8000f5a:	f000 f80b 	bl	8000f74 <Error_Handler>
  }
}
 8000f5e:	bf00      	nop
 8000f60:	37e0      	adds	r7, #224	; 0xe0
 8000f62:	46bd      	mov	sp, r7
 8000f64:	bd80      	pop	{r7, pc}
 8000f66:	bf00      	nop
 8000f68:	40023800 	.word	0x40023800
 8000f6c:	40007000 	.word	0x40007000
 8000f70:	00200100 	.word	0x00200100

08000f74 <Error_Handler>:
/**
  * @brief  This function is executed in case of error occurrence.
  * @retval None
  */
void Error_Handler(void)
{
 8000f74:	b480      	push	{r7}
 8000f76:	af00      	add	r7, sp, #0
  /* USER CODE BEGIN Error_Handler_Debug */
  /* User can add his own implementation to report the HAL error return state */

  /* USER CODE END Error_Handler_Debug */
}
 8000f78:	bf00      	nop
 8000f7a:	46bd      	mov	sp, r7
 8000f7c:	f85d 7b04 	ldr.w	r7, [sp], #4
 8000f80:	4770      	bx	lr
	...

08000f84 <assign_me>:
#include "me.h"

void assign_me(){
 8000f84:	b580      	push	{r7, lr}
 8000f86:	f5ad 3d16 	sub.w	sp, sp, #153600	; 0x25800
 8000f8a:	af00      	add	r7, sp, #0

	uint8_t base_me[320*240*2] = {
 8000f8c:	463b      	mov	r3, r7
 8000f8e:	4a0b      	ldr	r2, [pc, #44]	; (8000fbc <assign_me+0x38>)
 8000f90:	4618      	mov	r0, r3
 8000f92:	4611      	mov	r1, r2
 8000f94:	f44f 3316 	mov.w	r3, #153600	; 0x25800
 8000f98:	461a      	mov	r2, r3
 8000f9a:	f004 f9d9 	bl	8005350 <memcpy>
			,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff
			,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff
			,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff
	};

	memcpy(me,base_me,sizeof(me));
 8000f9e:	4a08      	ldr	r2, [pc, #32]	; (8000fc0 <assign_me+0x3c>)
 8000fa0:	463b      	mov	r3, r7
 8000fa2:	4610      	mov	r0, r2
 8000fa4:	4619      	mov	r1, r3
 8000fa6:	f44f 3316 	mov.w	r3, #153600	; 0x25800
 8000faa:	461a      	mov	r2, r3
 8000fac:	f004 f9d0 	bl	8005350 <memcpy>

}
 8000fb0:	bf00      	nop
 8000fb2:	f507 3716 	add.w	r7, r7, #153600	; 0x25800
 8000fb6:	46bd      	mov	sp, r7
 8000fb8:	bd80      	pop	{r7, pc}
 8000fba:	bf00      	nop
 8000fbc:	08008c64 	.word	0x08008c64
 8000fc0:	2000020c 	.word	0x2000020c

08000fc4 <MX_RNG_Init>:

RNG_HandleTypeDef hrng;

/* RNG init function */
void MX_RNG_Init(void)
{
 8000fc4:	b580      	push	{r7, lr}
 8000fc6:	af00      	add	r7, sp, #0

  hrng.Instance = RNG;
 8000fc8:	4b06      	ldr	r3, [pc, #24]	; (8000fe4 <MX_RNG_Init+0x20>)
 8000fca:	4a07      	ldr	r2, [pc, #28]	; (8000fe8 <MX_RNG_Init+0x24>)
 8000fcc:	601a      	str	r2, [r3, #0]
  if (HAL_RNG_Init(&hrng) != HAL_OK)
 8000fce:	4805      	ldr	r0, [pc, #20]	; (8000fe4 <MX_RNG_Init+0x20>)
 8000fd0:	f001 feb4 	bl	8002d3c <HAL_RNG_Init>
 8000fd4:	4603      	mov	r3, r0
 8000fd6:	2b00      	cmp	r3, #0
 8000fd8:	d001      	beq.n	8000fde <MX_RNG_Init+0x1a>
  {
    Error_Handler();
 8000fda:	f7ff ffcb 	bl	8000f74 <Error_Handler>
  }

}
 8000fde:	bf00      	nop
 8000fe0:	bd80      	pop	{r7, pc}
 8000fe2:	bf00      	nop
 8000fe4:	20025a1c 	.word	0x20025a1c
 8000fe8:	50060800 	.word	0x50060800

08000fec <HAL_RNG_MspInit>:

void HAL_RNG_MspInit(RNG_HandleTypeDef* rngHandle)
{
 8000fec:	b480      	push	{r7}
 8000fee:	b085      	sub	sp, #20
 8000ff0:	af00      	add	r7, sp, #0
 8000ff2:	6078      	str	r0, [r7, #4]

  if(rngHandle->Instance==RNG)
 8000ff4:	687b      	ldr	r3, [r7, #4]
 8000ff6:	681b      	ldr	r3, [r3, #0]
 8000ff8:	4a0a      	ldr	r2, [pc, #40]	; (8001024 <HAL_RNG_MspInit+0x38>)
 8000ffa:	4293      	cmp	r3, r2
 8000ffc:	d10b      	bne.n	8001016 <HAL_RNG_MspInit+0x2a>
  {
  /* USER CODE BEGIN RNG_MspInit 0 */

  /* USER CODE END RNG_MspInit 0 */
    /* RNG clock enable */
    __HAL_RCC_RNG_CLK_ENABLE();
 8000ffe:	4b0a      	ldr	r3, [pc, #40]	; (8001028 <HAL_RNG_MspInit+0x3c>)
 8001000:	6b5b      	ldr	r3, [r3, #52]	; 0x34
 8001002:	4a09      	ldr	r2, [pc, #36]	; (8001028 <HAL_RNG_MspInit+0x3c>)
 8001004:	f043 0340 	orr.w	r3, r3, #64	; 0x40
 8001008:	6353      	str	r3, [r2, #52]	; 0x34
 800100a:	4b07      	ldr	r3, [pc, #28]	; (8001028 <HAL_RNG_MspInit+0x3c>)
 800100c:	6b5b      	ldr	r3, [r3, #52]	; 0x34
 800100e:	f003 0340 	and.w	r3, r3, #64	; 0x40
 8001012:	60fb      	str	r3, [r7, #12]
 8001014:	68fb      	ldr	r3, [r7, #12]
  /* USER CODE BEGIN RNG_MspInit 1 */

  /* USER CODE END RNG_MspInit 1 */
  }
}
 8001016:	bf00      	nop
 8001018:	3714      	adds	r7, #20
 800101a:	46bd      	mov	sp, r7
 800101c:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001020:	4770      	bx	lr
 8001022:	bf00      	nop
 8001024:	50060800 	.word	0x50060800
 8001028:	40023800 	.word	0x40023800

0800102c <MX_SPI5_Init>:

SPI_HandleTypeDef hspi5;

/* SPI5 init function */
void MX_SPI5_Init(void)
{
 800102c:	b580      	push	{r7, lr}
 800102e:	af00      	add	r7, sp, #0

  hspi5.Instance = SPI5;
 8001030:	4b1b      	ldr	r3, [pc, #108]	; (80010a0 <MX_SPI5_Init+0x74>)
 8001032:	4a1c      	ldr	r2, [pc, #112]	; (80010a4 <MX_SPI5_Init+0x78>)
 8001034:	601a      	str	r2, [r3, #0]
  hspi5.Init.Mode = SPI_MODE_MASTER;
 8001036:	4b1a      	ldr	r3, [pc, #104]	; (80010a0 <MX_SPI5_Init+0x74>)
 8001038:	f44f 7282 	mov.w	r2, #260	; 0x104
 800103c:	605a      	str	r2, [r3, #4]
  hspi5.Init.Direction = SPI_DIRECTION_2LINES;
 800103e:	4b18      	ldr	r3, [pc, #96]	; (80010a0 <MX_SPI5_Init+0x74>)
 8001040:	2200      	movs	r2, #0
 8001042:	609a      	str	r2, [r3, #8]
  hspi5.Init.DataSize = SPI_DATASIZE_8BIT;
 8001044:	4b16      	ldr	r3, [pc, #88]	; (80010a0 <MX_SPI5_Init+0x74>)
 8001046:	f44f 62e0 	mov.w	r2, #1792	; 0x700
 800104a:	60da      	str	r2, [r3, #12]
  hspi5.Init.CLKPolarity = SPI_POLARITY_LOW;
 800104c:	4b14      	ldr	r3, [pc, #80]	; (80010a0 <MX_SPI5_Init+0x74>)
 800104e:	2200      	movs	r2, #0
 8001050:	611a      	str	r2, [r3, #16]
  hspi5.Init.CLKPhase = SPI_PHASE_1EDGE;
 8001052:	4b13      	ldr	r3, [pc, #76]	; (80010a0 <MX_SPI5_Init+0x74>)
 8001054:	2200      	movs	r2, #0
 8001056:	615a      	str	r2, [r3, #20]
  hspi5.Init.NSS = SPI_NSS_SOFT;
 8001058:	4b11      	ldr	r3, [pc, #68]	; (80010a0 <MX_SPI5_Init+0x74>)
 800105a:	f44f 7200 	mov.w	r2, #512	; 0x200
 800105e:	619a      	str	r2, [r3, #24]
  hspi5.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_2;
 8001060:	4b0f      	ldr	r3, [pc, #60]	; (80010a0 <MX_SPI5_Init+0x74>)
 8001062:	2200      	movs	r2, #0
 8001064:	61da      	str	r2, [r3, #28]
  hspi5.Init.FirstBit = SPI_FIRSTBIT_MSB;
 8001066:	4b0e      	ldr	r3, [pc, #56]	; (80010a0 <MX_SPI5_Init+0x74>)
 8001068:	2200      	movs	r2, #0
 800106a:	621a      	str	r2, [r3, #32]
  hspi5.Init.TIMode = SPI_TIMODE_DISABLE;
 800106c:	4b0c      	ldr	r3, [pc, #48]	; (80010a0 <MX_SPI5_Init+0x74>)
 800106e:	2200      	movs	r2, #0
 8001070:	625a      	str	r2, [r3, #36]	; 0x24
  hspi5.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;
 8001072:	4b0b      	ldr	r3, [pc, #44]	; (80010a0 <MX_SPI5_Init+0x74>)
 8001074:	2200      	movs	r2, #0
 8001076:	629a      	str	r2, [r3, #40]	; 0x28
  hspi5.Init.CRCPolynomial = 7;
 8001078:	4b09      	ldr	r3, [pc, #36]	; (80010a0 <MX_SPI5_Init+0x74>)
 800107a:	2207      	movs	r2, #7
 800107c:	62da      	str	r2, [r3, #44]	; 0x2c
  hspi5.Init.CRCLength = SPI_CRC_LENGTH_DATASIZE;
 800107e:	4b08      	ldr	r3, [pc, #32]	; (80010a0 <MX_SPI5_Init+0x74>)
 8001080:	2200      	movs	r2, #0
 8001082:	631a      	str	r2, [r3, #48]	; 0x30
  hspi5.Init.NSSPMode = SPI_NSS_PULSE_DISABLE;
 8001084:	4b06      	ldr	r3, [pc, #24]	; (80010a0 <MX_SPI5_Init+0x74>)
 8001086:	2200      	movs	r2, #0
 8001088:	635a      	str	r2, [r3, #52]	; 0x34
  if (HAL_SPI_Init(&hspi5) != HAL_OK)
 800108a:	4805      	ldr	r0, [pc, #20]	; (80010a0 <MX_SPI5_Init+0x74>)
 800108c:	f001 fe80 	bl	8002d90 <HAL_SPI_Init>
 8001090:	4603      	mov	r3, r0
 8001092:	2b00      	cmp	r3, #0
 8001094:	d001      	beq.n	800109a <MX_SPI5_Init+0x6e>
  {
    Error_Handler();
 8001096:	f7ff ff6d 	bl	8000f74 <Error_Handler>
  }

}
 800109a:	bf00      	nop
 800109c:	bd80      	pop	{r7, pc}
 800109e:	bf00      	nop
 80010a0:	20025a2c 	.word	0x20025a2c
 80010a4:	40015000 	.word	0x40015000

080010a8 <HAL_SPI_MspInit>:

void HAL_SPI_MspInit(SPI_HandleTypeDef* spiHandle)
{
 80010a8:	b580      	push	{r7, lr}
 80010aa:	b08a      	sub	sp, #40	; 0x28
 80010ac:	af00      	add	r7, sp, #0
 80010ae:	6078      	str	r0, [r7, #4]

  GPIO_InitTypeDef GPIO_InitStruct = {0};
 80010b0:	f107 0314 	add.w	r3, r7, #20
 80010b4:	2200      	movs	r2, #0
 80010b6:	601a      	str	r2, [r3, #0]
 80010b8:	605a      	str	r2, [r3, #4]
 80010ba:	609a      	str	r2, [r3, #8]
 80010bc:	60da      	str	r2, [r3, #12]
 80010be:	611a      	str	r2, [r3, #16]
  if(spiHandle->Instance==SPI5)
 80010c0:	687b      	ldr	r3, [r7, #4]
 80010c2:	681b      	ldr	r3, [r3, #0]
 80010c4:	4a17      	ldr	r2, [pc, #92]	; (8001124 <HAL_SPI_MspInit+0x7c>)
 80010c6:	4293      	cmp	r3, r2
 80010c8:	d128      	bne.n	800111c <HAL_SPI_MspInit+0x74>
  {
  /* USER CODE BEGIN SPI5_MspInit 0 */

  /* USER CODE END SPI5_MspInit 0 */
    /* SPI5 clock enable */
    __HAL_RCC_SPI5_CLK_ENABLE();
 80010ca:	4b17      	ldr	r3, [pc, #92]	; (8001128 <HAL_SPI_MspInit+0x80>)
 80010cc:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 80010ce:	4a16      	ldr	r2, [pc, #88]	; (8001128 <HAL_SPI_MspInit+0x80>)
 80010d0:	f443 1380 	orr.w	r3, r3, #1048576	; 0x100000
 80010d4:	6453      	str	r3, [r2, #68]	; 0x44
 80010d6:	4b14      	ldr	r3, [pc, #80]	; (8001128 <HAL_SPI_MspInit+0x80>)
 80010d8:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 80010da:	f403 1380 	and.w	r3, r3, #1048576	; 0x100000
 80010de:	613b      	str	r3, [r7, #16]
 80010e0:	693b      	ldr	r3, [r7, #16]

    __HAL_RCC_GPIOF_CLK_ENABLE();
 80010e2:	4b11      	ldr	r3, [pc, #68]	; (8001128 <HAL_SPI_MspInit+0x80>)
 80010e4:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 80010e6:	4a10      	ldr	r2, [pc, #64]	; (8001128 <HAL_SPI_MspInit+0x80>)
 80010e8:	f043 0320 	orr.w	r3, r3, #32
 80010ec:	6313      	str	r3, [r2, #48]	; 0x30
 80010ee:	4b0e      	ldr	r3, [pc, #56]	; (8001128 <HAL_SPI_MspInit+0x80>)
 80010f0:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 80010f2:	f003 0320 	and.w	r3, r3, #32
 80010f6:	60fb      	str	r3, [r7, #12]
 80010f8:	68fb      	ldr	r3, [r7, #12]
    /**SPI5 GPIO Configuration
    PF7     ------> SPI5_SCK
    PF8     ------> SPI5_MISO
    PF9     ------> SPI5_MOSI
    */
    GPIO_InitStruct.Pin = GPIO_PIN_7|GPIO_PIN_8|GPIO_PIN_9;
 80010fa:	f44f 7360 	mov.w	r3, #896	; 0x380
 80010fe:	617b      	str	r3, [r7, #20]
    GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
 8001100:	2302      	movs	r3, #2
 8001102:	61bb      	str	r3, [r7, #24]
    GPIO_InitStruct.Pull = GPIO_NOPULL;
 8001104:	2300      	movs	r3, #0
 8001106:	61fb      	str	r3, [r7, #28]
    GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
 8001108:	2303      	movs	r3, #3
 800110a:	623b      	str	r3, [r7, #32]
    GPIO_InitStruct.Alternate = GPIO_AF5_SPI5;
 800110c:	2305      	movs	r3, #5
 800110e:	627b      	str	r3, [r7, #36]	; 0x24
    HAL_GPIO_Init(GPIOF, &GPIO_InitStruct);
 8001110:	f107 0314 	add.w	r3, r7, #20
 8001114:	4619      	mov	r1, r3
 8001116:	4805      	ldr	r0, [pc, #20]	; (800112c <HAL_SPI_MspInit+0x84>)
 8001118:	f000 fb08 	bl	800172c <HAL_GPIO_Init>

  /* USER CODE BEGIN SPI5_MspInit 1 */

  /* USER CODE END SPI5_MspInit 1 */
  }
}
 800111c:	bf00      	nop
 800111e:	3728      	adds	r7, #40	; 0x28
 8001120:	46bd      	mov	sp, r7
 8001122:	bd80      	pop	{r7, pc}
 8001124:	40015000 	.word	0x40015000
 8001128:	40023800 	.word	0x40023800
 800112c:	40021400 	.word	0x40021400

08001130 <HAL_MspInit>:
/* USER CODE END 0 */
/**
  * Initializes the Global MSP.
  */
void HAL_MspInit(void)
{
 8001130:	b480      	push	{r7}
 8001132:	b083      	sub	sp, #12
 8001134:	af00      	add	r7, sp, #0
  /* USER CODE BEGIN MspInit 0 */

  /* USER CODE END MspInit 0 */

  __HAL_RCC_PWR_CLK_ENABLE();
 8001136:	4b0f      	ldr	r3, [pc, #60]	; (8001174 <HAL_MspInit+0x44>)
 8001138:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 800113a:	4a0e      	ldr	r2, [pc, #56]	; (8001174 <HAL_MspInit+0x44>)
 800113c:	f043 5380 	orr.w	r3, r3, #268435456	; 0x10000000
 8001140:	6413      	str	r3, [r2, #64]	; 0x40
 8001142:	4b0c      	ldr	r3, [pc, #48]	; (8001174 <HAL_MspInit+0x44>)
 8001144:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 8001146:	f003 5380 	and.w	r3, r3, #268435456	; 0x10000000
 800114a:	607b      	str	r3, [r7, #4]
 800114c:	687b      	ldr	r3, [r7, #4]
  __HAL_RCC_SYSCFG_CLK_ENABLE();
 800114e:	4b09      	ldr	r3, [pc, #36]	; (8001174 <HAL_MspInit+0x44>)
 8001150:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8001152:	4a08      	ldr	r2, [pc, #32]	; (8001174 <HAL_MspInit+0x44>)
 8001154:	f443 4380 	orr.w	r3, r3, #16384	; 0x4000
 8001158:	6453      	str	r3, [r2, #68]	; 0x44
 800115a:	4b06      	ldr	r3, [pc, #24]	; (8001174 <HAL_MspInit+0x44>)
 800115c:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 800115e:	f403 4380 	and.w	r3, r3, #16384	; 0x4000
 8001162:	603b      	str	r3, [r7, #0]
 8001164:	683b      	ldr	r3, [r7, #0]
  /* System interrupt init*/

  /* USER CODE BEGIN MspInit 1 */

  /* USER CODE END MspInit 1 */
}
 8001166:	bf00      	nop
 8001168:	370c      	adds	r7, #12
 800116a:	46bd      	mov	sp, r7
 800116c:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001170:	4770      	bx	lr
 8001172:	bf00      	nop
 8001174:	40023800 	.word	0x40023800

08001178 <SysTick_Handler>:
/******************************************************************************/
/**
  * @brief This function handles System tick timer.
  */
void SysTick_Handler(void)
{
 8001178:	b580      	push	{r7, lr}
 800117a:	af00      	add	r7, sp, #0
  /* USER CODE BEGIN SysTick_IRQn 0 */

  /* USER CODE END SysTick_IRQn 0 */
  HAL_IncTick();
 800117c:	f000 f9ae 	bl	80014dc <HAL_IncTick>
  /* USER CODE BEGIN SysTick_IRQn 1 */

  /* USER CODE END SysTick_IRQn 1 */
}
 8001180:	bf00      	nop
 8001182:	bd80      	pop	{r7, pc}

08001184 <_sbrk>:
 *
 * @param incr Memory size
 * @return Pointer to allocated memory
 */
void *_sbrk(ptrdiff_t incr)
{
 8001184:	b580      	push	{r7, lr}
 8001186:	b086      	sub	sp, #24
 8001188:	af00      	add	r7, sp, #0
 800118a:	6078      	str	r0, [r7, #4]
  extern uint8_t _end; /* Symbol defined in the linker script */
  extern uint8_t _estack; /* Symbol defined in the linker script */
  extern uint32_t _Min_Stack_Size; /* Symbol defined in the linker script */
  const uint32_t stack_limit = (uint32_t)&_estack - (uint32_t)&_Min_Stack_Size;
 800118c:	4a14      	ldr	r2, [pc, #80]	; (80011e0 <_sbrk+0x5c>)
 800118e:	4b15      	ldr	r3, [pc, #84]	; (80011e4 <_sbrk+0x60>)
 8001190:	1ad3      	subs	r3, r2, r3
 8001192:	617b      	str	r3, [r7, #20]
  const uint8_t *max_heap = (uint8_t *)stack_limit;
 8001194:	697b      	ldr	r3, [r7, #20]
 8001196:	613b      	str	r3, [r7, #16]
  uint8_t *prev_heap_end;

  /* Initalize heap end at first call */
  if (NULL == __sbrk_heap_end)
 8001198:	4b13      	ldr	r3, [pc, #76]	; (80011e8 <_sbrk+0x64>)
 800119a:	681b      	ldr	r3, [r3, #0]
 800119c:	2b00      	cmp	r3, #0
 800119e:	d102      	bne.n	80011a6 <_sbrk+0x22>
  {
    __sbrk_heap_end = &_end;
 80011a0:	4b11      	ldr	r3, [pc, #68]	; (80011e8 <_sbrk+0x64>)
 80011a2:	4a12      	ldr	r2, [pc, #72]	; (80011ec <_sbrk+0x68>)
 80011a4:	601a      	str	r2, [r3, #0]
  }

  /* Protect heap from growing into the reserved MSP stack */
  if (__sbrk_heap_end + incr > max_heap)
 80011a6:	4b10      	ldr	r3, [pc, #64]	; (80011e8 <_sbrk+0x64>)
 80011a8:	681a      	ldr	r2, [r3, #0]
 80011aa:	687b      	ldr	r3, [r7, #4]
 80011ac:	4413      	add	r3, r2
 80011ae:	693a      	ldr	r2, [r7, #16]
 80011b0:	429a      	cmp	r2, r3
 80011b2:	d207      	bcs.n	80011c4 <_sbrk+0x40>
  {
    errno = ENOMEM;
 80011b4:	f004 f8a2 	bl	80052fc <__errno>
 80011b8:	4602      	mov	r2, r0
 80011ba:	230c      	movs	r3, #12
 80011bc:	6013      	str	r3, [r2, #0]
    return (void *)-1;
 80011be:	f04f 33ff 	mov.w	r3, #4294967295	; 0xffffffff
 80011c2:	e009      	b.n	80011d8 <_sbrk+0x54>
  }

  prev_heap_end = __sbrk_heap_end;
 80011c4:	4b08      	ldr	r3, [pc, #32]	; (80011e8 <_sbrk+0x64>)
 80011c6:	681b      	ldr	r3, [r3, #0]
 80011c8:	60fb      	str	r3, [r7, #12]
  __sbrk_heap_end += incr;
 80011ca:	4b07      	ldr	r3, [pc, #28]	; (80011e8 <_sbrk+0x64>)
 80011cc:	681a      	ldr	r2, [r3, #0]
 80011ce:	687b      	ldr	r3, [r7, #4]
 80011d0:	4413      	add	r3, r2
 80011d2:	4a05      	ldr	r2, [pc, #20]	; (80011e8 <_sbrk+0x64>)
 80011d4:	6013      	str	r3, [r2, #0]

  return (void *)prev_heap_end;
 80011d6:	68fb      	ldr	r3, [r7, #12]
}
 80011d8:	4618      	mov	r0, r3
 80011da:	3718      	adds	r7, #24
 80011dc:	46bd      	mov	sp, r7
 80011de:	bd80      	pop	{r7, pc}
 80011e0:	20080000 	.word	0x20080000
 80011e4:	00000400 	.word	0x00000400
 80011e8:	200001fc 	.word	0x200001fc
 80011ec:	20025b58 	.word	0x20025b58

080011f0 <SystemInit>:
  *         SystemFrequency variable.
  * @param  None
  * @retval None
  */
void SystemInit(void)
{
 80011f0:	b480      	push	{r7}
 80011f2:	af00      	add	r7, sp, #0
  /* FPU settings ------------------------------------------------------------*/
#if (__FPU_PRESENT == 1) && (__FPU_USED == 1)
  SCB->CPACR |= ((3UL << 10*2)|(3UL << 11*2));  /* set CP10 and CP11 Full Access */
 80011f4:	4b08      	ldr	r3, [pc, #32]	; (8001218 <SystemInit+0x28>)
 80011f6:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 80011fa:	4a07      	ldr	r2, [pc, #28]	; (8001218 <SystemInit+0x28>)
 80011fc:	f443 0370 	orr.w	r3, r3, #15728640	; 0xf00000
 8001200:	f8c2 3088 	str.w	r3, [r2, #136]	; 0x88

  /* Configure the Vector Table location add offset address ------------------*/
#ifdef VECT_TAB_SRAM
  SCB->VTOR = RAMDTCM_BASE | VECT_TAB_OFFSET; /* Vector Table Relocation in Internal SRAM */
#else
  SCB->VTOR = FLASH_BASE | VECT_TAB_OFFSET; /* Vector Table Relocation in Internal FLASH */
 8001204:	4b04      	ldr	r3, [pc, #16]	; (8001218 <SystemInit+0x28>)
 8001206:	f04f 6200 	mov.w	r2, #134217728	; 0x8000000
 800120a:	609a      	str	r2, [r3, #8]
#endif
}
 800120c:	bf00      	nop
 800120e:	46bd      	mov	sp, r7
 8001210:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001214:	4770      	bx	lr
 8001216:	bf00      	nop
 8001218:	e000ed00 	.word	0xe000ed00

0800121c <MX_TIM1_Init>:

TIM_HandleTypeDef htim1;

/* TIM1 init function */
void MX_TIM1_Init(void)
{
 800121c:	b580      	push	{r7, lr}
 800121e:	b088      	sub	sp, #32
 8001220:	af00      	add	r7, sp, #0
  TIM_ClockConfigTypeDef sClockSourceConfig = {0};
 8001222:	f107 0310 	add.w	r3, r7, #16
 8001226:	2200      	movs	r2, #0
 8001228:	601a      	str	r2, [r3, #0]
 800122a:	605a      	str	r2, [r3, #4]
 800122c:	609a      	str	r2, [r3, #8]
 800122e:	60da      	str	r2, [r3, #12]
  TIM_MasterConfigTypeDef sMasterConfig = {0};
 8001230:	1d3b      	adds	r3, r7, #4
 8001232:	2200      	movs	r2, #0
 8001234:	601a      	str	r2, [r3, #0]
 8001236:	605a      	str	r2, [r3, #4]
 8001238:	609a      	str	r2, [r3, #8]

  htim1.Instance = TIM1;
 800123a:	4b21      	ldr	r3, [pc, #132]	; (80012c0 <MX_TIM1_Init+0xa4>)
 800123c:	4a21      	ldr	r2, [pc, #132]	; (80012c4 <MX_TIM1_Init+0xa8>)
 800123e:	601a      	str	r2, [r3, #0]
  htim1.Init.Prescaler = 10000;
 8001240:	4b1f      	ldr	r3, [pc, #124]	; (80012c0 <MX_TIM1_Init+0xa4>)
 8001242:	f242 7210 	movw	r2, #10000	; 0x2710
 8001246:	605a      	str	r2, [r3, #4]
  htim1.Init.CounterMode = TIM_COUNTERMODE_UP;
 8001248:	4b1d      	ldr	r3, [pc, #116]	; (80012c0 <MX_TIM1_Init+0xa4>)
 800124a:	2200      	movs	r2, #0
 800124c:	609a      	str	r2, [r3, #8]
  htim1.Init.Period = 65535;
 800124e:	4b1c      	ldr	r3, [pc, #112]	; (80012c0 <MX_TIM1_Init+0xa4>)
 8001250:	f64f 72ff 	movw	r2, #65535	; 0xffff
 8001254:	60da      	str	r2, [r3, #12]
  htim1.Init.ClockDivision = TIM_CLOCKDIVISION_DIV2;
 8001256:	4b1a      	ldr	r3, [pc, #104]	; (80012c0 <MX_TIM1_Init+0xa4>)
 8001258:	f44f 7280 	mov.w	r2, #256	; 0x100
 800125c:	611a      	str	r2, [r3, #16]
  htim1.Init.RepetitionCounter = 0;
 800125e:	4b18      	ldr	r3, [pc, #96]	; (80012c0 <MX_TIM1_Init+0xa4>)
 8001260:	2200      	movs	r2, #0
 8001262:	615a      	str	r2, [r3, #20]
  htim1.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
 8001264:	4b16      	ldr	r3, [pc, #88]	; (80012c0 <MX_TIM1_Init+0xa4>)
 8001266:	2200      	movs	r2, #0
 8001268:	619a      	str	r2, [r3, #24]
  if (HAL_TIM_Base_Init(&htim1) != HAL_OK)
 800126a:	4815      	ldr	r0, [pc, #84]	; (80012c0 <MX_TIM1_Init+0xa4>)
 800126c:	f002 f8a5 	bl	80033ba <HAL_TIM_Base_Init>
 8001270:	4603      	mov	r3, r0
 8001272:	2b00      	cmp	r3, #0
 8001274:	d001      	beq.n	800127a <MX_TIM1_Init+0x5e>
  {
    Error_Handler();
 8001276:	f7ff fe7d 	bl	8000f74 <Error_Handler>
  }
  sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
 800127a:	f44f 5380 	mov.w	r3, #4096	; 0x1000
 800127e:	613b      	str	r3, [r7, #16]
  if (HAL_TIM_ConfigClockSource(&htim1, &sClockSourceConfig) != HAL_OK)
 8001280:	f107 0310 	add.w	r3, r7, #16
 8001284:	4619      	mov	r1, r3
 8001286:	480e      	ldr	r0, [pc, #56]	; (80012c0 <MX_TIM1_Init+0xa4>)
 8001288:	f002 f8c2 	bl	8003410 <HAL_TIM_ConfigClockSource>
 800128c:	4603      	mov	r3, r0
 800128e:	2b00      	cmp	r3, #0
 8001290:	d001      	beq.n	8001296 <MX_TIM1_Init+0x7a>
  {
    Error_Handler();
 8001292:	f7ff fe6f 	bl	8000f74 <Error_Handler>
  }
  sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
 8001296:	2300      	movs	r3, #0
 8001298:	607b      	str	r3, [r7, #4]
  sMasterConfig.MasterOutputTrigger2 = TIM_TRGO2_RESET;
 800129a:	2300      	movs	r3, #0
 800129c:	60bb      	str	r3, [r7, #8]
  sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
 800129e:	2300      	movs	r3, #0
 80012a0:	60fb      	str	r3, [r7, #12]
  if (HAL_TIMEx_MasterConfigSynchronization(&htim1, &sMasterConfig) != HAL_OK)
 80012a2:	1d3b      	adds	r3, r7, #4
 80012a4:	4619      	mov	r1, r3
 80012a6:	4806      	ldr	r0, [pc, #24]	; (80012c0 <MX_TIM1_Init+0xa4>)
 80012a8:	f002 faa6 	bl	80037f8 <HAL_TIMEx_MasterConfigSynchronization>
 80012ac:	4603      	mov	r3, r0
 80012ae:	2b00      	cmp	r3, #0
 80012b0:	d001      	beq.n	80012b6 <MX_TIM1_Init+0x9a>
  {
    Error_Handler();
 80012b2:	f7ff fe5f 	bl	8000f74 <Error_Handler>
  }

}
 80012b6:	bf00      	nop
 80012b8:	3720      	adds	r7, #32
 80012ba:	46bd      	mov	sp, r7
 80012bc:	bd80      	pop	{r7, pc}
 80012be:	bf00      	nop
 80012c0:	20025a90 	.word	0x20025a90
 80012c4:	40010000 	.word	0x40010000

080012c8 <HAL_TIM_Base_MspInit>:

void HAL_TIM_Base_MspInit(TIM_HandleTypeDef* tim_baseHandle)
{
 80012c8:	b480      	push	{r7}
 80012ca:	b085      	sub	sp, #20
 80012cc:	af00      	add	r7, sp, #0
 80012ce:	6078      	str	r0, [r7, #4]

  if(tim_baseHandle->Instance==TIM1)
 80012d0:	687b      	ldr	r3, [r7, #4]
 80012d2:	681b      	ldr	r3, [r3, #0]
 80012d4:	4a0a      	ldr	r2, [pc, #40]	; (8001300 <HAL_TIM_Base_MspInit+0x38>)
 80012d6:	4293      	cmp	r3, r2
 80012d8:	d10b      	bne.n	80012f2 <HAL_TIM_Base_MspInit+0x2a>
  {
  /* USER CODE BEGIN TIM1_MspInit 0 */

  /* USER CODE END TIM1_MspInit 0 */
    /* TIM1 clock enable */
    __HAL_RCC_TIM1_CLK_ENABLE();
 80012da:	4b0a      	ldr	r3, [pc, #40]	; (8001304 <HAL_TIM_Base_MspInit+0x3c>)
 80012dc:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 80012de:	4a09      	ldr	r2, [pc, #36]	; (8001304 <HAL_TIM_Base_MspInit+0x3c>)
 80012e0:	f043 0301 	orr.w	r3, r3, #1
 80012e4:	6453      	str	r3, [r2, #68]	; 0x44
 80012e6:	4b07      	ldr	r3, [pc, #28]	; (8001304 <HAL_TIM_Base_MspInit+0x3c>)
 80012e8:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 80012ea:	f003 0301 	and.w	r3, r3, #1
 80012ee:	60fb      	str	r3, [r7, #12]
 80012f0:	68fb      	ldr	r3, [r7, #12]
  /* USER CODE BEGIN TIM1_MspInit 1 */

  /* USER CODE END TIM1_MspInit 1 */
  }
}
 80012f2:	bf00      	nop
 80012f4:	3714      	adds	r7, #20
 80012f6:	46bd      	mov	sp, r7
 80012f8:	f85d 7b04 	ldr.w	r7, [sp], #4
 80012fc:	4770      	bx	lr
 80012fe:	bf00      	nop
 8001300:	40010000 	.word	0x40010000
 8001304:	40023800 	.word	0x40023800

08001308 <MX_USART3_UART_Init>:
UART_HandleTypeDef huart3;

/* USART3 init function */

void MX_USART3_UART_Init(void)
{
 8001308:	b580      	push	{r7, lr}
 800130a:	af00      	add	r7, sp, #0

  huart3.Instance = USART3;
 800130c:	4b14      	ldr	r3, [pc, #80]	; (8001360 <MX_USART3_UART_Init+0x58>)
 800130e:	4a15      	ldr	r2, [pc, #84]	; (8001364 <MX_USART3_UART_Init+0x5c>)
 8001310:	601a      	str	r2, [r3, #0]
  huart3.Init.BaudRate = 115200;
 8001312:	4b13      	ldr	r3, [pc, #76]	; (8001360 <MX_USART3_UART_Init+0x58>)
 8001314:	f44f 32e1 	mov.w	r2, #115200	; 0x1c200
 8001318:	605a      	str	r2, [r3, #4]
  huart3.Init.WordLength = UART_WORDLENGTH_8B;
 800131a:	4b11      	ldr	r3, [pc, #68]	; (8001360 <MX_USART3_UART_Init+0x58>)
 800131c:	2200      	movs	r2, #0
 800131e:	609a      	str	r2, [r3, #8]
  huart3.Init.StopBits = UART_STOPBITS_1;
 8001320:	4b0f      	ldr	r3, [pc, #60]	; (8001360 <MX_USART3_UART_Init+0x58>)
 8001322:	2200      	movs	r2, #0
 8001324:	60da      	str	r2, [r3, #12]
  huart3.Init.Parity = UART_PARITY_NONE;
 8001326:	4b0e      	ldr	r3, [pc, #56]	; (8001360 <MX_USART3_UART_Init+0x58>)
 8001328:	2200      	movs	r2, #0
 800132a:	611a      	str	r2, [r3, #16]
  huart3.Init.Mode = UART_MODE_TX_RX;
 800132c:	4b0c      	ldr	r3, [pc, #48]	; (8001360 <MX_USART3_UART_Init+0x58>)
 800132e:	220c      	movs	r2, #12
 8001330:	615a      	str	r2, [r3, #20]
  huart3.Init.HwFlowCtl = UART_HWCONTROL_NONE;
 8001332:	4b0b      	ldr	r3, [pc, #44]	; (8001360 <MX_USART3_UART_Init+0x58>)
 8001334:	2200      	movs	r2, #0
 8001336:	619a      	str	r2, [r3, #24]
  huart3.Init.OverSampling = UART_OVERSAMPLING_16;
 8001338:	4b09      	ldr	r3, [pc, #36]	; (8001360 <MX_USART3_UART_Init+0x58>)
 800133a:	2200      	movs	r2, #0
 800133c:	61da      	str	r2, [r3, #28]
  huart3.Init.OneBitSampling = UART_ONE_BIT_SAMPLE_DISABLE;
 800133e:	4b08      	ldr	r3, [pc, #32]	; (8001360 <MX_USART3_UART_Init+0x58>)
 8001340:	2200      	movs	r2, #0
 8001342:	621a      	str	r2, [r3, #32]
  huart3.AdvancedInit.AdvFeatureInit = UART_ADVFEATURE_NO_INIT;
 8001344:	4b06      	ldr	r3, [pc, #24]	; (8001360 <MX_USART3_UART_Init+0x58>)
 8001346:	2200      	movs	r2, #0
 8001348:	625a      	str	r2, [r3, #36]	; 0x24
  if (HAL_UART_Init(&huart3) != HAL_OK)
 800134a:	4805      	ldr	r0, [pc, #20]	; (8001360 <MX_USART3_UART_Init+0x58>)
 800134c:	f002 fae2 	bl	8003914 <HAL_UART_Init>
 8001350:	4603      	mov	r3, r0
 8001352:	2b00      	cmp	r3, #0
 8001354:	d001      	beq.n	800135a <MX_USART3_UART_Init+0x52>
  {
    Error_Handler();
 8001356:	f7ff fe0d 	bl	8000f74 <Error_Handler>
  }

}
 800135a:	bf00      	nop
 800135c:	bd80      	pop	{r7, pc}
 800135e:	bf00      	nop
 8001360:	20025ad0 	.word	0x20025ad0
 8001364:	40004800 	.word	0x40004800

08001368 <HAL_UART_MspInit>:

void HAL_UART_MspInit(UART_HandleTypeDef* uartHandle)
{
 8001368:	b580      	push	{r7, lr}
 800136a:	b08a      	sub	sp, #40	; 0x28
 800136c:	af00      	add	r7, sp, #0
 800136e:	6078      	str	r0, [r7, #4]

  GPIO_InitTypeDef GPIO_InitStruct = {0};
 8001370:	f107 0314 	add.w	r3, r7, #20
 8001374:	2200      	movs	r2, #0
 8001376:	601a      	str	r2, [r3, #0]
 8001378:	605a      	str	r2, [r3, #4]
 800137a:	609a      	str	r2, [r3, #8]
 800137c:	60da      	str	r2, [r3, #12]
 800137e:	611a      	str	r2, [r3, #16]
  if(uartHandle->Instance==USART3)
 8001380:	687b      	ldr	r3, [r7, #4]
 8001382:	681b      	ldr	r3, [r3, #0]
 8001384:	4a17      	ldr	r2, [pc, #92]	; (80013e4 <HAL_UART_MspInit+0x7c>)
 8001386:	4293      	cmp	r3, r2
 8001388:	d128      	bne.n	80013dc <HAL_UART_MspInit+0x74>
  {
  /* USER CODE BEGIN USART3_MspInit 0 */

  /* USER CODE END USART3_MspInit 0 */
    /* USART3 clock enable */
    __HAL_RCC_USART3_CLK_ENABLE();
 800138a:	4b17      	ldr	r3, [pc, #92]	; (80013e8 <HAL_UART_MspInit+0x80>)
 800138c:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 800138e:	4a16      	ldr	r2, [pc, #88]	; (80013e8 <HAL_UART_MspInit+0x80>)
 8001390:	f443 2380 	orr.w	r3, r3, #262144	; 0x40000
 8001394:	6413      	str	r3, [r2, #64]	; 0x40
 8001396:	4b14      	ldr	r3, [pc, #80]	; (80013e8 <HAL_UART_MspInit+0x80>)
 8001398:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 800139a:	f403 2380 	and.w	r3, r3, #262144	; 0x40000
 800139e:	613b      	str	r3, [r7, #16]
 80013a0:	693b      	ldr	r3, [r7, #16]

    __HAL_RCC_GPIOD_CLK_ENABLE();
 80013a2:	4b11      	ldr	r3, [pc, #68]	; (80013e8 <HAL_UART_MspInit+0x80>)
 80013a4:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 80013a6:	4a10      	ldr	r2, [pc, #64]	; (80013e8 <HAL_UART_MspInit+0x80>)
 80013a8:	f043 0308 	orr.w	r3, r3, #8
 80013ac:	6313      	str	r3, [r2, #48]	; 0x30
 80013ae:	4b0e      	ldr	r3, [pc, #56]	; (80013e8 <HAL_UART_MspInit+0x80>)
 80013b0:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 80013b2:	f003 0308 	and.w	r3, r3, #8
 80013b6:	60fb      	str	r3, [r7, #12]
 80013b8:	68fb      	ldr	r3, [r7, #12]
    /**USART3 GPIO Configuration
    PD8     ------> USART3_TX
    PD9     ------> USART3_RX
    */
    GPIO_InitStruct.Pin = STLK_RX_Pin|STLK_TX_Pin;
 80013ba:	f44f 7340 	mov.w	r3, #768	; 0x300
 80013be:	617b      	str	r3, [r7, #20]
    GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
 80013c0:	2302      	movs	r3, #2
 80013c2:	61bb      	str	r3, [r7, #24]
    GPIO_InitStruct.Pull = GPIO_NOPULL;
 80013c4:	2300      	movs	r3, #0
 80013c6:	61fb      	str	r3, [r7, #28]
    GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
 80013c8:	2303      	movs	r3, #3
 80013ca:	623b      	str	r3, [r7, #32]
    GPIO_InitStruct.Alternate = GPIO_AF7_USART3;
 80013cc:	2307      	movs	r3, #7
 80013ce:	627b      	str	r3, [r7, #36]	; 0x24
    HAL_GPIO_Init(GPIOD, &GPIO_InitStruct);
 80013d0:	f107 0314 	add.w	r3, r7, #20
 80013d4:	4619      	mov	r1, r3
 80013d6:	4805      	ldr	r0, [pc, #20]	; (80013ec <HAL_UART_MspInit+0x84>)
 80013d8:	f000 f9a8 	bl	800172c <HAL_GPIO_Init>

  /* USER CODE BEGIN USART3_MspInit 1 */

  /* USER CODE END USART3_MspInit 1 */
  }
}
 80013dc:	bf00      	nop
 80013de:	3728      	adds	r7, #40	; 0x28
 80013e0:	46bd      	mov	sp, r7
 80013e2:	bd80      	pop	{r7, pc}
 80013e4:	40004800 	.word	0x40004800
 80013e8:	40023800 	.word	0x40023800
 80013ec:	40020c00 	.word	0x40020c00

080013f0 <Reset_Handler>:

    .section  .text.Reset_Handler
  .weak  Reset_Handler
  .type  Reset_Handler, %function
Reset_Handler:  
  ldr   sp, =_estack      /* set stack pointer */
 80013f0:	f8df d034 	ldr.w	sp, [pc, #52]	; 8001428 <LoopFillZerobss+0x14>

/* Copy the data segment initializers from flash to SRAM */  
  movs  r1, #0
 80013f4:	2100      	movs	r1, #0
  b  LoopCopyDataInit
 80013f6:	e003      	b.n	8001400 <LoopCopyDataInit>

080013f8 <CopyDataInit>:

CopyDataInit:
  ldr  r3, =_sidata
 80013f8:	4b0c      	ldr	r3, [pc, #48]	; (800142c <LoopFillZerobss+0x18>)
  ldr  r3, [r3, r1]
 80013fa:	585b      	ldr	r3, [r3, r1]
  str  r3, [r0, r1]
 80013fc:	5043      	str	r3, [r0, r1]
  adds  r1, r1, #4
 80013fe:	3104      	adds	r1, #4

08001400 <LoopCopyDataInit>:
    
LoopCopyDataInit:
  ldr  r0, =_sdata
 8001400:	480b      	ldr	r0, [pc, #44]	; (8001430 <LoopFillZerobss+0x1c>)
  ldr  r3, =_edata
 8001402:	4b0c      	ldr	r3, [pc, #48]	; (8001434 <LoopFillZerobss+0x20>)
  adds  r2, r0, r1
 8001404:	1842      	adds	r2, r0, r1
  cmp  r2, r3
 8001406:	429a      	cmp	r2, r3
  bcc  CopyDataInit
 8001408:	d3f6      	bcc.n	80013f8 <CopyDataInit>
  ldr  r2, =_sbss
 800140a:	4a0b      	ldr	r2, [pc, #44]	; (8001438 <LoopFillZerobss+0x24>)
  b  LoopFillZerobss
 800140c:	e002      	b.n	8001414 <LoopFillZerobss>

0800140e <FillZerobss>:
/* Zero fill the bss segment. */  
FillZerobss:
  movs  r3, #0
 800140e:	2300      	movs	r3, #0
  str  r3, [r2], #4
 8001410:	f842 3b04 	str.w	r3, [r2], #4

08001414 <LoopFillZerobss>:
    
LoopFillZerobss:
  ldr  r3, = _ebss
 8001414:	4b09      	ldr	r3, [pc, #36]	; (800143c <LoopFillZerobss+0x28>)
  cmp  r2, r3
 8001416:	429a      	cmp	r2, r3
  bcc  FillZerobss
 8001418:	d3f9      	bcc.n	800140e <FillZerobss>

/* Call the clock system initialization function.*/
  bl  SystemInit   
 800141a:	f7ff fee9 	bl	80011f0 <SystemInit>
/* Call static constructors */
    bl __libc_init_array
 800141e:	f003 ff73 	bl	8005308 <__libc_init_array>
/* Call the application's entry point.*/
  bl  main
 8001422:	f7ff fcf7 	bl	8000e14 <main>
  bx  lr    
 8001426:	4770      	bx	lr
  ldr   sp, =_estack      /* set stack pointer */
 8001428:	20080000 	.word	0x20080000
  ldr  r3, =_sidata
 800142c:	0802e980 	.word	0x0802e980
  ldr  r0, =_sdata
 8001430:	20000000 	.word	0x20000000
  ldr  r3, =_edata
 8001434:	200001e0 	.word	0x200001e0
  ldr  r2, =_sbss
 8001438:	200001e0 	.word	0x200001e0
  ldr  r3, = _ebss
 800143c:	20025b58 	.word	0x20025b58

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

08001444 <HAL_Init>:
  *         need to ensure that the SysTick time base is always set to 1 millisecond
  *         to have correct HAL operation.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_Init(void)
{
 8001444:	b580      	push	{r7, lr}
 8001446:	af00      	add	r7, sp, #0
  /* Configure Instruction cache through ART accelerator */ 
#if (ART_ACCLERATOR_ENABLE != 0)
   __HAL_FLASH_ART_ENABLE();
 8001448:	4b0b      	ldr	r3, [pc, #44]	; (8001478 <HAL_Init+0x34>)
 800144a:	681b      	ldr	r3, [r3, #0]
 800144c:	4a0a      	ldr	r2, [pc, #40]	; (8001478 <HAL_Init+0x34>)
 800144e:	f443 7300 	orr.w	r3, r3, #512	; 0x200
 8001452:	6013      	str	r3, [r2, #0]
#endif /* ART_ACCLERATOR_ENABLE */

  /* Configure Flash prefetch */
#if (PREFETCH_ENABLE != 0U)
  __HAL_FLASH_PREFETCH_BUFFER_ENABLE();
 8001454:	4b08      	ldr	r3, [pc, #32]	; (8001478 <HAL_Init+0x34>)
 8001456:	681b      	ldr	r3, [r3, #0]
 8001458:	4a07      	ldr	r2, [pc, #28]	; (8001478 <HAL_Init+0x34>)
 800145a:	f443 7380 	orr.w	r3, r3, #256	; 0x100
 800145e:	6013      	str	r3, [r2, #0]
#endif /* PREFETCH_ENABLE */

  /* Set Interrupt Group Priority */
  HAL_NVIC_SetPriorityGrouping(NVIC_PRIORITYGROUP_4);
 8001460:	2003      	movs	r0, #3
 8001462:	f000 f92f 	bl	80016c4 <HAL_NVIC_SetPriorityGrouping>

  /* Use systick as time base source and configure 1ms tick (default clock after Reset is HSI) */
  HAL_InitTick(TICK_INT_PRIORITY);
 8001466:	2000      	movs	r0, #0
 8001468:	f000 f808 	bl	800147c <HAL_InitTick>
  
  /* Init the low level hardware */
  HAL_MspInit();
 800146c:	f7ff fe60 	bl	8001130 <HAL_MspInit>
  
  /* Return function status */
  return HAL_OK;
 8001470:	2300      	movs	r3, #0
}
 8001472:	4618      	mov	r0, r3
 8001474:	bd80      	pop	{r7, pc}
 8001476:	bf00      	nop
 8001478:	40023c00 	.word	0x40023c00

0800147c <HAL_InitTick>:
  *       implementation  in user file.
  * @param TickPriority Tick interrupt priority.
  * @retval HAL status
  */
__weak HAL_StatusTypeDef HAL_InitTick(uint32_t TickPriority)
{
 800147c:	b580      	push	{r7, lr}
 800147e:	b082      	sub	sp, #8
 8001480:	af00      	add	r7, sp, #0
 8001482:	6078      	str	r0, [r7, #4]
  /* Configure the SysTick to have interrupt in 1ms time basis*/
  if (HAL_SYSTICK_Config(SystemCoreClock / (1000U / uwTickFreq)) > 0U)
 8001484:	4b12      	ldr	r3, [pc, #72]	; (80014d0 <HAL_InitTick+0x54>)
 8001486:	681a      	ldr	r2, [r3, #0]
 8001488:	4b12      	ldr	r3, [pc, #72]	; (80014d4 <HAL_InitTick+0x58>)
 800148a:	781b      	ldrb	r3, [r3, #0]
 800148c:	4619      	mov	r1, r3
 800148e:	f44f 737a 	mov.w	r3, #1000	; 0x3e8
 8001492:	fbb3 f3f1 	udiv	r3, r3, r1
 8001496:	fbb2 f3f3 	udiv	r3, r2, r3
 800149a:	4618      	mov	r0, r3
 800149c:	f000 f939 	bl	8001712 <HAL_SYSTICK_Config>
 80014a0:	4603      	mov	r3, r0
 80014a2:	2b00      	cmp	r3, #0
 80014a4:	d001      	beq.n	80014aa <HAL_InitTick+0x2e>
  {
    return HAL_ERROR;
 80014a6:	2301      	movs	r3, #1
 80014a8:	e00e      	b.n	80014c8 <HAL_InitTick+0x4c>
  }

  /* Configure the SysTick IRQ priority */
  if (TickPriority < (1UL << __NVIC_PRIO_BITS))
 80014aa:	687b      	ldr	r3, [r7, #4]
 80014ac:	2b0f      	cmp	r3, #15
 80014ae:	d80a      	bhi.n	80014c6 <HAL_InitTick+0x4a>
  {
    HAL_NVIC_SetPriority(SysTick_IRQn, TickPriority, 0U);
 80014b0:	2200      	movs	r2, #0
 80014b2:	6879      	ldr	r1, [r7, #4]
 80014b4:	f04f 30ff 	mov.w	r0, #4294967295	; 0xffffffff
 80014b8:	f000 f90f 	bl	80016da <HAL_NVIC_SetPriority>
    uwTickPrio = TickPriority;
 80014bc:	4a06      	ldr	r2, [pc, #24]	; (80014d8 <HAL_InitTick+0x5c>)
 80014be:	687b      	ldr	r3, [r7, #4]
 80014c0:	6013      	str	r3, [r2, #0]
  {
    return HAL_ERROR;
  }

  /* Return function status */
  return HAL_OK;
 80014c2:	2300      	movs	r3, #0
 80014c4:	e000      	b.n	80014c8 <HAL_InitTick+0x4c>
    return HAL_ERROR;
 80014c6:	2301      	movs	r3, #1
}
 80014c8:	4618      	mov	r0, r3
 80014ca:	3708      	adds	r7, #8
 80014cc:	46bd      	mov	sp, r7
 80014ce:	bd80      	pop	{r7, pc}
 80014d0:	20000000 	.word	0x20000000
 80014d4:	20000008 	.word	0x20000008
 80014d8:	20000004 	.word	0x20000004

080014dc <HAL_IncTick>:
 * @note This function is declared as __weak to be overwritten in case of other 
  *      implementations in user file.
  * @retval None
  */
__weak void HAL_IncTick(void)
{
 80014dc:	b480      	push	{r7}
 80014de:	af00      	add	r7, sp, #0
  uwTick += uwTickFreq;
 80014e0:	4b06      	ldr	r3, [pc, #24]	; (80014fc <HAL_IncTick+0x20>)
 80014e2:	781b      	ldrb	r3, [r3, #0]
 80014e4:	461a      	mov	r2, r3
 80014e6:	4b06      	ldr	r3, [pc, #24]	; (8001500 <HAL_IncTick+0x24>)
 80014e8:	681b      	ldr	r3, [r3, #0]
 80014ea:	4413      	add	r3, r2
 80014ec:	4a04      	ldr	r2, [pc, #16]	; (8001500 <HAL_IncTick+0x24>)
 80014ee:	6013      	str	r3, [r2, #0]
}
 80014f0:	bf00      	nop
 80014f2:	46bd      	mov	sp, r7
 80014f4:	f85d 7b04 	ldr.w	r7, [sp], #4
 80014f8:	4770      	bx	lr
 80014fa:	bf00      	nop
 80014fc:	20000008 	.word	0x20000008
 8001500:	20025b50 	.word	0x20025b50

08001504 <HAL_GetTick>:
  * @note This function is declared as __weak to be overwritten in case of other 
  *       implementations in user file.
  * @retval tick value
  */
__weak uint32_t HAL_GetTick(void)
{
 8001504:	b480      	push	{r7}
 8001506:	af00      	add	r7, sp, #0
  return uwTick;
 8001508:	4b03      	ldr	r3, [pc, #12]	; (8001518 <HAL_GetTick+0x14>)
 800150a:	681b      	ldr	r3, [r3, #0]
}
 800150c:	4618      	mov	r0, r3
 800150e:	46bd      	mov	sp, r7
 8001510:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001514:	4770      	bx	lr
 8001516:	bf00      	nop
 8001518:	20025b50 	.word	0x20025b50

0800151c <HAL_Delay>:
  *       implementations in user file.
  * @param Delay  specifies the delay time length, in milliseconds.
  * @retval None
  */
__weak void HAL_Delay(uint32_t Delay)
{
 800151c:	b580      	push	{r7, lr}
 800151e:	b084      	sub	sp, #16
 8001520:	af00      	add	r7, sp, #0
 8001522:	6078      	str	r0, [r7, #4]
  uint32_t tickstart = HAL_GetTick();
 8001524:	f7ff ffee 	bl	8001504 <HAL_GetTick>
 8001528:	60b8      	str	r0, [r7, #8]
  uint32_t wait = Delay;
 800152a:	687b      	ldr	r3, [r7, #4]
 800152c:	60fb      	str	r3, [r7, #12]

  /* Add a freq to guarantee minimum wait */
  if (wait < HAL_MAX_DELAY)
 800152e:	68fb      	ldr	r3, [r7, #12]
 8001530:	f1b3 3fff 	cmp.w	r3, #4294967295	; 0xffffffff
 8001534:	d005      	beq.n	8001542 <HAL_Delay+0x26>
  {
    wait += (uint32_t)(uwTickFreq);
 8001536:	4b09      	ldr	r3, [pc, #36]	; (800155c <HAL_Delay+0x40>)
 8001538:	781b      	ldrb	r3, [r3, #0]
 800153a:	461a      	mov	r2, r3
 800153c:	68fb      	ldr	r3, [r7, #12]
 800153e:	4413      	add	r3, r2
 8001540:	60fb      	str	r3, [r7, #12]
  }

  while ((HAL_GetTick() - tickstart) < wait)
 8001542:	bf00      	nop
 8001544:	f7ff ffde 	bl	8001504 <HAL_GetTick>
 8001548:	4602      	mov	r2, r0
 800154a:	68bb      	ldr	r3, [r7, #8]
 800154c:	1ad3      	subs	r3, r2, r3
 800154e:	68fa      	ldr	r2, [r7, #12]
 8001550:	429a      	cmp	r2, r3
 8001552:	d8f7      	bhi.n	8001544 <HAL_Delay+0x28>
  {
  }
}
 8001554:	bf00      	nop
 8001556:	3710      	adds	r7, #16
 8001558:	46bd      	mov	sp, r7
 800155a:	bd80      	pop	{r7, pc}
 800155c:	20000008 	.word	0x20000008

08001560 <__NVIC_SetPriorityGrouping>:
{
 8001560:	b480      	push	{r7}
 8001562:	b085      	sub	sp, #20
 8001564:	af00      	add	r7, sp, #0
 8001566:	6078      	str	r0, [r7, #4]
  uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL);             /* only values 0..7 are used          */
 8001568:	687b      	ldr	r3, [r7, #4]
 800156a:	f003 0307 	and.w	r3, r3, #7
 800156e:	60fb      	str	r3, [r7, #12]
  reg_value  =  SCB->AIRCR;                                                   /* read old register configuration    */
 8001570:	4b0b      	ldr	r3, [pc, #44]	; (80015a0 <__NVIC_SetPriorityGrouping+0x40>)
 8001572:	68db      	ldr	r3, [r3, #12]
 8001574:	60bb      	str	r3, [r7, #8]
  reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change               */
 8001576:	68ba      	ldr	r2, [r7, #8]
 8001578:	f64f 03ff 	movw	r3, #63743	; 0xf8ff
 800157c:	4013      	ands	r3, r2
 800157e:	60bb      	str	r3, [r7, #8]
                (PriorityGroupTmp << SCB_AIRCR_PRIGROUP_Pos)  );              /* Insert write key and priority group */
 8001580:	68fb      	ldr	r3, [r7, #12]
 8001582:	021a      	lsls	r2, r3, #8
                ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) |
 8001584:	68bb      	ldr	r3, [r7, #8]
 8001586:	431a      	orrs	r2, r3
  reg_value  =  (reg_value                                   |
 8001588:	4b06      	ldr	r3, [pc, #24]	; (80015a4 <__NVIC_SetPriorityGrouping+0x44>)
 800158a:	4313      	orrs	r3, r2
 800158c:	60bb      	str	r3, [r7, #8]
  SCB->AIRCR =  reg_value;
 800158e:	4a04      	ldr	r2, [pc, #16]	; (80015a0 <__NVIC_SetPriorityGrouping+0x40>)
 8001590:	68bb      	ldr	r3, [r7, #8]
 8001592:	60d3      	str	r3, [r2, #12]
}
 8001594:	bf00      	nop
 8001596:	3714      	adds	r7, #20
 8001598:	46bd      	mov	sp, r7
 800159a:	f85d 7b04 	ldr.w	r7, [sp], #4
 800159e:	4770      	bx	lr
 80015a0:	e000ed00 	.word	0xe000ed00
 80015a4:	05fa0000 	.word	0x05fa0000

080015a8 <__NVIC_GetPriorityGrouping>:
{
 80015a8:	b480      	push	{r7}
 80015aa:	af00      	add	r7, sp, #0
  return ((uint32_t)((SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos));
 80015ac:	4b04      	ldr	r3, [pc, #16]	; (80015c0 <__NVIC_GetPriorityGrouping+0x18>)
 80015ae:	68db      	ldr	r3, [r3, #12]
 80015b0:	0a1b      	lsrs	r3, r3, #8
 80015b2:	f003 0307 	and.w	r3, r3, #7
}
 80015b6:	4618      	mov	r0, r3
 80015b8:	46bd      	mov	sp, r7
 80015ba:	f85d 7b04 	ldr.w	r7, [sp], #4
 80015be:	4770      	bx	lr
 80015c0:	e000ed00 	.word	0xe000ed00

080015c4 <__NVIC_SetPriority>:
{
 80015c4:	b480      	push	{r7}
 80015c6:	b083      	sub	sp, #12
 80015c8:	af00      	add	r7, sp, #0
 80015ca:	4603      	mov	r3, r0
 80015cc:	6039      	str	r1, [r7, #0]
 80015ce:	71fb      	strb	r3, [r7, #7]
  if ((int32_t)(IRQn) >= 0)
 80015d0:	f997 3007 	ldrsb.w	r3, [r7, #7]
 80015d4:	2b00      	cmp	r3, #0
 80015d6:	db0a      	blt.n	80015ee <__NVIC_SetPriority+0x2a>
    NVIC->IP[((uint32_t)IRQn)]                = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL);
 80015d8:	683b      	ldr	r3, [r7, #0]
 80015da:	b2da      	uxtb	r2, r3
 80015dc:	490c      	ldr	r1, [pc, #48]	; (8001610 <__NVIC_SetPriority+0x4c>)
 80015de:	f997 3007 	ldrsb.w	r3, [r7, #7]
 80015e2:	0112      	lsls	r2, r2, #4
 80015e4:	b2d2      	uxtb	r2, r2
 80015e6:	440b      	add	r3, r1
 80015e8:	f883 2300 	strb.w	r2, [r3, #768]	; 0x300
}
 80015ec:	e00a      	b.n	8001604 <__NVIC_SetPriority+0x40>
    SCB->SHPR[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL);
 80015ee:	683b      	ldr	r3, [r7, #0]
 80015f0:	b2da      	uxtb	r2, r3
 80015f2:	4908      	ldr	r1, [pc, #32]	; (8001614 <__NVIC_SetPriority+0x50>)
 80015f4:	79fb      	ldrb	r3, [r7, #7]
 80015f6:	f003 030f 	and.w	r3, r3, #15
 80015fa:	3b04      	subs	r3, #4
 80015fc:	0112      	lsls	r2, r2, #4
 80015fe:	b2d2      	uxtb	r2, r2
 8001600:	440b      	add	r3, r1
 8001602:	761a      	strb	r2, [r3, #24]
}
 8001604:	bf00      	nop
 8001606:	370c      	adds	r7, #12
 8001608:	46bd      	mov	sp, r7
 800160a:	f85d 7b04 	ldr.w	r7, [sp], #4
 800160e:	4770      	bx	lr
 8001610:	e000e100 	.word	0xe000e100
 8001614:	e000ed00 	.word	0xe000ed00

08001618 <NVIC_EncodePriority>:
{
 8001618:	b480      	push	{r7}
 800161a:	b089      	sub	sp, #36	; 0x24
 800161c:	af00      	add	r7, sp, #0
 800161e:	60f8      	str	r0, [r7, #12]
 8001620:	60b9      	str	r1, [r7, #8]
 8001622:	607a      	str	r2, [r7, #4]
  uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL);   /* only values 0..7 are used          */
 8001624:	68fb      	ldr	r3, [r7, #12]
 8001626:	f003 0307 	and.w	r3, r3, #7
 800162a:	61fb      	str	r3, [r7, #28]
  PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp);
 800162c:	69fb      	ldr	r3, [r7, #28]
 800162e:	f1c3 0307 	rsb	r3, r3, #7
 8001632:	2b04      	cmp	r3, #4
 8001634:	bf28      	it	cs
 8001636:	2304      	movcs	r3, #4
 8001638:	61bb      	str	r3, [r7, #24]
  SubPriorityBits     = ((PriorityGroupTmp + (uint32_t)(__NVIC_PRIO_BITS)) < (uint32_t)7UL) ? (uint32_t)0UL : (uint32_t)((PriorityGroupTmp - 7UL) + (uint32_t)(__NVIC_PRIO_BITS));
 800163a:	69fb      	ldr	r3, [r7, #28]
 800163c:	3304      	adds	r3, #4
 800163e:	2b06      	cmp	r3, #6
 8001640:	d902      	bls.n	8001648 <NVIC_EncodePriority+0x30>
 8001642:	69fb      	ldr	r3, [r7, #28]
 8001644:	3b03      	subs	r3, #3
 8001646:	e000      	b.n	800164a <NVIC_EncodePriority+0x32>
 8001648:	2300      	movs	r3, #0
 800164a:	617b      	str	r3, [r7, #20]
           ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) |
 800164c:	f04f 32ff 	mov.w	r2, #4294967295	; 0xffffffff
 8001650:	69bb      	ldr	r3, [r7, #24]
 8001652:	fa02 f303 	lsl.w	r3, r2, r3
 8001656:	43da      	mvns	r2, r3
 8001658:	68bb      	ldr	r3, [r7, #8]
 800165a:	401a      	ands	r2, r3
 800165c:	697b      	ldr	r3, [r7, #20]
 800165e:	409a      	lsls	r2, r3
           ((SubPriority     & (uint32_t)((1UL << (SubPriorityBits    )) - 1UL)))
 8001660:	f04f 31ff 	mov.w	r1, #4294967295	; 0xffffffff
 8001664:	697b      	ldr	r3, [r7, #20]
 8001666:	fa01 f303 	lsl.w	r3, r1, r3
 800166a:	43d9      	mvns	r1, r3
 800166c:	687b      	ldr	r3, [r7, #4]
 800166e:	400b      	ands	r3, r1
           ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) |
 8001670:	4313      	orrs	r3, r2
}
 8001672:	4618      	mov	r0, r3
 8001674:	3724      	adds	r7, #36	; 0x24
 8001676:	46bd      	mov	sp, r7
 8001678:	f85d 7b04 	ldr.w	r7, [sp], #4
 800167c:	4770      	bx	lr
	...

08001680 <SysTick_Config>:
  \note    When the variable <b>__Vendor_SysTickConfig</b> is set to 1, then the
           function <b>SysTick_Config</b> is not included. In this case, the file <b><i>device</i>.h</b>
           must contain a vendor-specific implementation of this function.
 */
__STATIC_INLINE uint32_t SysTick_Config(uint32_t ticks)
{
 8001680:	b580      	push	{r7, lr}
 8001682:	b082      	sub	sp, #8
 8001684:	af00      	add	r7, sp, #0
 8001686:	6078      	str	r0, [r7, #4]
  if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk)
 8001688:	687b      	ldr	r3, [r7, #4]
 800168a:	3b01      	subs	r3, #1
 800168c:	f1b3 7f80 	cmp.w	r3, #16777216	; 0x1000000
 8001690:	d301      	bcc.n	8001696 <SysTick_Config+0x16>
  {
    return (1UL);                                                   /* Reload value impossible */
 8001692:	2301      	movs	r3, #1
 8001694:	e00f      	b.n	80016b6 <SysTick_Config+0x36>
  }

  SysTick->LOAD  = (uint32_t)(ticks - 1UL);                         /* set reload register */
 8001696:	4a0a      	ldr	r2, [pc, #40]	; (80016c0 <SysTick_Config+0x40>)
 8001698:	687b      	ldr	r3, [r7, #4]
 800169a:	3b01      	subs	r3, #1
 800169c:	6053      	str	r3, [r2, #4]
  NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */
 800169e:	210f      	movs	r1, #15
 80016a0:	f04f 30ff 	mov.w	r0, #4294967295	; 0xffffffff
 80016a4:	f7ff ff8e 	bl	80015c4 <__NVIC_SetPriority>
  SysTick->VAL   = 0UL;                                             /* Load the SysTick Counter Value */
 80016a8:	4b05      	ldr	r3, [pc, #20]	; (80016c0 <SysTick_Config+0x40>)
 80016aa:	2200      	movs	r2, #0
 80016ac:	609a      	str	r2, [r3, #8]
  SysTick->CTRL  = SysTick_CTRL_CLKSOURCE_Msk |
 80016ae:	4b04      	ldr	r3, [pc, #16]	; (80016c0 <SysTick_Config+0x40>)
 80016b0:	2207      	movs	r2, #7
 80016b2:	601a      	str	r2, [r3, #0]
                   SysTick_CTRL_TICKINT_Msk   |
                   SysTick_CTRL_ENABLE_Msk;                         /* Enable SysTick IRQ and SysTick Timer */
  return (0UL);                                                     /* Function successful */
 80016b4:	2300      	movs	r3, #0
}
 80016b6:	4618      	mov	r0, r3
 80016b8:	3708      	adds	r7, #8
 80016ba:	46bd      	mov	sp, r7
 80016bc:	bd80      	pop	{r7, pc}
 80016be:	bf00      	nop
 80016c0:	e000e010 	.word	0xe000e010

080016c4 <HAL_NVIC_SetPriorityGrouping>:
  * @note   When the NVIC_PriorityGroup_0 is selected, IRQ preemption is no more possible. 
  *         The pending IRQ priority will be managed only by the subpriority. 
  * @retval None
  */
void HAL_NVIC_SetPriorityGrouping(uint32_t PriorityGroup)
{
 80016c4:	b580      	push	{r7, lr}
 80016c6:	b082      	sub	sp, #8
 80016c8:	af00      	add	r7, sp, #0
 80016ca:	6078      	str	r0, [r7, #4]
  /* Check the parameters */
  assert_param(IS_NVIC_PRIORITY_GROUP(PriorityGroup));
  
  /* Set the PRIGROUP[10:8] bits according to the PriorityGroup parameter value */
  NVIC_SetPriorityGrouping(PriorityGroup);
 80016cc:	6878      	ldr	r0, [r7, #4]
 80016ce:	f7ff ff47 	bl	8001560 <__NVIC_SetPriorityGrouping>
}
 80016d2:	bf00      	nop
 80016d4:	3708      	adds	r7, #8
 80016d6:	46bd      	mov	sp, r7
 80016d8:	bd80      	pop	{r7, pc}

080016da <HAL_NVIC_SetPriority>:
  *         This parameter can be a value between 0 and 15
  *         A lower priority value indicates a higher priority.          
  * @retval None
  */
void HAL_NVIC_SetPriority(IRQn_Type IRQn, uint32_t PreemptPriority, uint32_t SubPriority)
{ 
 80016da:	b580      	push	{r7, lr}
 80016dc:	b086      	sub	sp, #24
 80016de:	af00      	add	r7, sp, #0
 80016e0:	4603      	mov	r3, r0
 80016e2:	60b9      	str	r1, [r7, #8]
 80016e4:	607a      	str	r2, [r7, #4]
 80016e6:	73fb      	strb	r3, [r7, #15]
  uint32_t prioritygroup = 0x00;
 80016e8:	2300      	movs	r3, #0
 80016ea:	617b      	str	r3, [r7, #20]
  
  /* Check the parameters */
  assert_param(IS_NVIC_SUB_PRIORITY(SubPriority));
  assert_param(IS_NVIC_PREEMPTION_PRIORITY(PreemptPriority));
  
  prioritygroup = NVIC_GetPriorityGrouping();
 80016ec:	f7ff ff5c 	bl	80015a8 <__NVIC_GetPriorityGrouping>
 80016f0:	6178      	str	r0, [r7, #20]
  
  NVIC_SetPriority(IRQn, NVIC_EncodePriority(prioritygroup, PreemptPriority, SubPriority));
 80016f2:	687a      	ldr	r2, [r7, #4]
 80016f4:	68b9      	ldr	r1, [r7, #8]
 80016f6:	6978      	ldr	r0, [r7, #20]
 80016f8:	f7ff ff8e 	bl	8001618 <NVIC_EncodePriority>
 80016fc:	4602      	mov	r2, r0
 80016fe:	f997 300f 	ldrsb.w	r3, [r7, #15]
 8001702:	4611      	mov	r1, r2
 8001704:	4618      	mov	r0, r3
 8001706:	f7ff ff5d 	bl	80015c4 <__NVIC_SetPriority>
}
 800170a:	bf00      	nop
 800170c:	3718      	adds	r7, #24
 800170e:	46bd      	mov	sp, r7
 8001710:	bd80      	pop	{r7, pc}

08001712 <HAL_SYSTICK_Config>:
  * @param  TicksNumb Specifies the ticks Number of ticks between two interrupts.
  * @retval status:  - 0  Function succeeded.
  *                  - 1  Function failed.
  */
uint32_t HAL_SYSTICK_Config(uint32_t TicksNumb)
{
 8001712:	b580      	push	{r7, lr}
 8001714:	b082      	sub	sp, #8
 8001716:	af00      	add	r7, sp, #0
 8001718:	6078      	str	r0, [r7, #4]
   return SysTick_Config(TicksNumb);
 800171a:	6878      	ldr	r0, [r7, #4]
 800171c:	f7ff ffb0 	bl	8001680 <SysTick_Config>
 8001720:	4603      	mov	r3, r0
}
 8001722:	4618      	mov	r0, r3
 8001724:	3708      	adds	r7, #8
 8001726:	46bd      	mov	sp, r7
 8001728:	bd80      	pop	{r7, pc}
	...

0800172c <HAL_GPIO_Init>:
  * @param  GPIO_Init pointer to a GPIO_InitTypeDef structure that contains
  *         the configuration information for the specified GPIO peripheral.
  * @retval None
  */
void HAL_GPIO_Init(GPIO_TypeDef  *GPIOx, GPIO_InitTypeDef *GPIO_Init)
{
 800172c:	b480      	push	{r7}
 800172e:	b089      	sub	sp, #36	; 0x24
 8001730:	af00      	add	r7, sp, #0
 8001732:	6078      	str	r0, [r7, #4]
 8001734:	6039      	str	r1, [r7, #0]
  uint32_t position = 0x00;
 8001736:	2300      	movs	r3, #0
 8001738:	61fb      	str	r3, [r7, #28]
  uint32_t ioposition = 0x00;
 800173a:	2300      	movs	r3, #0
 800173c:	617b      	str	r3, [r7, #20]
  uint32_t iocurrent = 0x00;
 800173e:	2300      	movs	r3, #0
 8001740:	613b      	str	r3, [r7, #16]
  uint32_t temp = 0x00;
 8001742:	2300      	movs	r3, #0
 8001744:	61bb      	str	r3, [r7, #24]
  assert_param(IS_GPIO_PIN(GPIO_Init->Pin));
  assert_param(IS_GPIO_MODE(GPIO_Init->Mode));
  assert_param(IS_GPIO_PULL(GPIO_Init->Pull));

  /* Configure the port pins */
  for(position = 0; position < GPIO_NUMBER; position++)
 8001746:	2300      	movs	r3, #0
 8001748:	61fb      	str	r3, [r7, #28]
 800174a:	e175      	b.n	8001a38 <HAL_GPIO_Init+0x30c>
  {
    /* Get the IO position */
    ioposition = ((uint32_t)0x01) << position;
 800174c:	2201      	movs	r2, #1
 800174e:	69fb      	ldr	r3, [r7, #28]
 8001750:	fa02 f303 	lsl.w	r3, r2, r3
 8001754:	617b      	str	r3, [r7, #20]
    /* Get the current IO position */
    iocurrent = (uint32_t)(GPIO_Init->Pin) & ioposition;
 8001756:	683b      	ldr	r3, [r7, #0]
 8001758:	681b      	ldr	r3, [r3, #0]
 800175a:	697a      	ldr	r2, [r7, #20]
 800175c:	4013      	ands	r3, r2
 800175e:	613b      	str	r3, [r7, #16]

    if(iocurrent == ioposition)
 8001760:	693a      	ldr	r2, [r7, #16]
 8001762:	697b      	ldr	r3, [r7, #20]
 8001764:	429a      	cmp	r2, r3
 8001766:	f040 8164 	bne.w	8001a32 <HAL_GPIO_Init+0x306>
    {
      /*--------------------- GPIO Mode Configuration ------------------------*/
      /* In case of Output or Alternate function mode selection */
      if((GPIO_Init->Mode == GPIO_MODE_OUTPUT_PP) || (GPIO_Init->Mode == GPIO_MODE_AF_PP) ||
 800176a:	683b      	ldr	r3, [r7, #0]
 800176c:	685b      	ldr	r3, [r3, #4]
 800176e:	2b01      	cmp	r3, #1
 8001770:	d00b      	beq.n	800178a <HAL_GPIO_Init+0x5e>
 8001772:	683b      	ldr	r3, [r7, #0]
 8001774:	685b      	ldr	r3, [r3, #4]
 8001776:	2b02      	cmp	r3, #2
 8001778:	d007      	beq.n	800178a <HAL_GPIO_Init+0x5e>
         (GPIO_Init->Mode == GPIO_MODE_OUTPUT_OD) || (GPIO_Init->Mode == GPIO_MODE_AF_OD))
 800177a:	683b      	ldr	r3, [r7, #0]
 800177c:	685b      	ldr	r3, [r3, #4]
      if((GPIO_Init->Mode == GPIO_MODE_OUTPUT_PP) || (GPIO_Init->Mode == GPIO_MODE_AF_PP) ||
 800177e:	2b11      	cmp	r3, #17
 8001780:	d003      	beq.n	800178a <HAL_GPIO_Init+0x5e>
         (GPIO_Init->Mode == GPIO_MODE_OUTPUT_OD) || (GPIO_Init->Mode == GPIO_MODE_AF_OD))
 8001782:	683b      	ldr	r3, [r7, #0]
 8001784:	685b      	ldr	r3, [r3, #4]
 8001786:	2b12      	cmp	r3, #18
 8001788:	d130      	bne.n	80017ec <HAL_GPIO_Init+0xc0>
      {
        /* Check the Speed parameter */
        assert_param(IS_GPIO_SPEED(GPIO_Init->Speed));
        /* Configure the IO Speed */
        temp = GPIOx->OSPEEDR; 
 800178a:	687b      	ldr	r3, [r7, #4]
 800178c:	689b      	ldr	r3, [r3, #8]
 800178e:	61bb      	str	r3, [r7, #24]
        temp &= ~(GPIO_OSPEEDER_OSPEEDR0 << (position * 2));
 8001790:	69fb      	ldr	r3, [r7, #28]
 8001792:	005b      	lsls	r3, r3, #1
 8001794:	2203      	movs	r2, #3
 8001796:	fa02 f303 	lsl.w	r3, r2, r3
 800179a:	43db      	mvns	r3, r3
 800179c:	69ba      	ldr	r2, [r7, #24]
 800179e:	4013      	ands	r3, r2
 80017a0:	61bb      	str	r3, [r7, #24]
        temp |= (GPIO_Init->Speed << (position * 2));
 80017a2:	683b      	ldr	r3, [r7, #0]
 80017a4:	68da      	ldr	r2, [r3, #12]
 80017a6:	69fb      	ldr	r3, [r7, #28]
 80017a8:	005b      	lsls	r3, r3, #1
 80017aa:	fa02 f303 	lsl.w	r3, r2, r3
 80017ae:	69ba      	ldr	r2, [r7, #24]
 80017b0:	4313      	orrs	r3, r2
 80017b2:	61bb      	str	r3, [r7, #24]
        GPIOx->OSPEEDR = temp;
 80017b4:	687b      	ldr	r3, [r7, #4]
 80017b6:	69ba      	ldr	r2, [r7, #24]
 80017b8:	609a      	str	r2, [r3, #8]

        /* Configure the IO Output Type */
        temp = GPIOx->OTYPER;
 80017ba:	687b      	ldr	r3, [r7, #4]
 80017bc:	685b      	ldr	r3, [r3, #4]
 80017be:	61bb      	str	r3, [r7, #24]
        temp &= ~(GPIO_OTYPER_OT_0 << position) ;
 80017c0:	2201      	movs	r2, #1
 80017c2:	69fb      	ldr	r3, [r7, #28]
 80017c4:	fa02 f303 	lsl.w	r3, r2, r3
 80017c8:	43db      	mvns	r3, r3
 80017ca:	69ba      	ldr	r2, [r7, #24]
 80017cc:	4013      	ands	r3, r2
 80017ce:	61bb      	str	r3, [r7, #24]
        temp |= (((GPIO_Init->Mode & GPIO_OUTPUT_TYPE) >> 4) << position);
 80017d0:	683b      	ldr	r3, [r7, #0]
 80017d2:	685b      	ldr	r3, [r3, #4]
 80017d4:	091b      	lsrs	r3, r3, #4
 80017d6:	f003 0201 	and.w	r2, r3, #1
 80017da:	69fb      	ldr	r3, [r7, #28]
 80017dc:	fa02 f303 	lsl.w	r3, r2, r3
 80017e0:	69ba      	ldr	r2, [r7, #24]
 80017e2:	4313      	orrs	r3, r2
 80017e4:	61bb      	str	r3, [r7, #24]
        GPIOx->OTYPER = temp;
 80017e6:	687b      	ldr	r3, [r7, #4]
 80017e8:	69ba      	ldr	r2, [r7, #24]
 80017ea:	605a      	str	r2, [r3, #4]
      }

      /* Activate the Pull-up or Pull down resistor for the current IO */
      temp = GPIOx->PUPDR;
 80017ec:	687b      	ldr	r3, [r7, #4]
 80017ee:	68db      	ldr	r3, [r3, #12]
 80017f0:	61bb      	str	r3, [r7, #24]
      temp &= ~(GPIO_PUPDR_PUPDR0 << (position * 2));
 80017f2:	69fb      	ldr	r3, [r7, #28]
 80017f4:	005b      	lsls	r3, r3, #1
 80017f6:	2203      	movs	r2, #3
 80017f8:	fa02 f303 	lsl.w	r3, r2, r3
 80017fc:	43db      	mvns	r3, r3
 80017fe:	69ba      	ldr	r2, [r7, #24]
 8001800:	4013      	ands	r3, r2
 8001802:	61bb      	str	r3, [r7, #24]
      temp |= ((GPIO_Init->Pull) << (position * 2));
 8001804:	683b      	ldr	r3, [r7, #0]
 8001806:	689a      	ldr	r2, [r3, #8]
 8001808:	69fb      	ldr	r3, [r7, #28]
 800180a:	005b      	lsls	r3, r3, #1
 800180c:	fa02 f303 	lsl.w	r3, r2, r3
 8001810:	69ba      	ldr	r2, [r7, #24]
 8001812:	4313      	orrs	r3, r2
 8001814:	61bb      	str	r3, [r7, #24]
      GPIOx->PUPDR = temp;
 8001816:	687b      	ldr	r3, [r7, #4]
 8001818:	69ba      	ldr	r2, [r7, #24]
 800181a:	60da      	str	r2, [r3, #12]

      /* In case of Alternate function mode selection */
      if((GPIO_Init->Mode == GPIO_MODE_AF_PP) || (GPIO_Init->Mode == GPIO_MODE_AF_OD))
 800181c:	683b      	ldr	r3, [r7, #0]
 800181e:	685b      	ldr	r3, [r3, #4]
 8001820:	2b02      	cmp	r3, #2
 8001822:	d003      	beq.n	800182c <HAL_GPIO_Init+0x100>
 8001824:	683b      	ldr	r3, [r7, #0]
 8001826:	685b      	ldr	r3, [r3, #4]
 8001828:	2b12      	cmp	r3, #18
 800182a:	d123      	bne.n	8001874 <HAL_GPIO_Init+0x148>
      {
        /* Check the Alternate function parameter */
        assert_param(IS_GPIO_AF(GPIO_Init->Alternate));

        /* Configure Alternate function mapped with the current IO */
        temp = GPIOx->AFR[position >> 3];
 800182c:	69fb      	ldr	r3, [r7, #28]
 800182e:	08da      	lsrs	r2, r3, #3
 8001830:	687b      	ldr	r3, [r7, #4]
 8001832:	3208      	adds	r2, #8
 8001834:	f853 3022 	ldr.w	r3, [r3, r2, lsl #2]
 8001838:	61bb      	str	r3, [r7, #24]
        temp &= ~((uint32_t)0xF << ((uint32_t)(position & (uint32_t)0x07) * 4)) ;
 800183a:	69fb      	ldr	r3, [r7, #28]
 800183c:	f003 0307 	and.w	r3, r3, #7
 8001840:	009b      	lsls	r3, r3, #2
 8001842:	220f      	movs	r2, #15
 8001844:	fa02 f303 	lsl.w	r3, r2, r3
 8001848:	43db      	mvns	r3, r3
 800184a:	69ba      	ldr	r2, [r7, #24]
 800184c:	4013      	ands	r3, r2
 800184e:	61bb      	str	r3, [r7, #24]
        temp |= ((uint32_t)(GPIO_Init->Alternate) << (((uint32_t)position & (uint32_t)0x07) * 4));
 8001850:	683b      	ldr	r3, [r7, #0]
 8001852:	691a      	ldr	r2, [r3, #16]
 8001854:	69fb      	ldr	r3, [r7, #28]
 8001856:	f003 0307 	and.w	r3, r3, #7
 800185a:	009b      	lsls	r3, r3, #2
 800185c:	fa02 f303 	lsl.w	r3, r2, r3
 8001860:	69ba      	ldr	r2, [r7, #24]
 8001862:	4313      	orrs	r3, r2
 8001864:	61bb      	str	r3, [r7, #24]
        GPIOx->AFR[position >> 3] = temp;
 8001866:	69fb      	ldr	r3, [r7, #28]
 8001868:	08da      	lsrs	r2, r3, #3
 800186a:	687b      	ldr	r3, [r7, #4]
 800186c:	3208      	adds	r2, #8
 800186e:	69b9      	ldr	r1, [r7, #24]
 8001870:	f843 1022 	str.w	r1, [r3, r2, lsl #2]
      }
      
      /* Configure IO Direction mode (Input, Output, Alternate or Analog) */
      temp = GPIOx->MODER;
 8001874:	687b      	ldr	r3, [r7, #4]
 8001876:	681b      	ldr	r3, [r3, #0]
 8001878:	61bb      	str	r3, [r7, #24]
      temp &= ~(GPIO_MODER_MODER0 << (position * 2));
 800187a:	69fb      	ldr	r3, [r7, #28]
 800187c:	005b      	lsls	r3, r3, #1
 800187e:	2203      	movs	r2, #3
 8001880:	fa02 f303 	lsl.w	r3, r2, r3
 8001884:	43db      	mvns	r3, r3
 8001886:	69ba      	ldr	r2, [r7, #24]
 8001888:	4013      	ands	r3, r2
 800188a:	61bb      	str	r3, [r7, #24]
      temp |= ((GPIO_Init->Mode & GPIO_MODE) << (position * 2));
 800188c:	683b      	ldr	r3, [r7, #0]
 800188e:	685b      	ldr	r3, [r3, #4]
 8001890:	f003 0203 	and.w	r2, r3, #3
 8001894:	69fb      	ldr	r3, [r7, #28]
 8001896:	005b      	lsls	r3, r3, #1
 8001898:	fa02 f303 	lsl.w	r3, r2, r3
 800189c:	69ba      	ldr	r2, [r7, #24]
 800189e:	4313      	orrs	r3, r2
 80018a0:	61bb      	str	r3, [r7, #24]
      GPIOx->MODER = temp;
 80018a2:	687b      	ldr	r3, [r7, #4]
 80018a4:	69ba      	ldr	r2, [r7, #24]
 80018a6:	601a      	str	r2, [r3, #0]

      /*--------------------- EXTI Mode Configuration ------------------------*/
      /* Configure the External Interrupt or event for the current IO */
      if((GPIO_Init->Mode & EXTI_MODE) == EXTI_MODE)
 80018a8:	683b      	ldr	r3, [r7, #0]
 80018aa:	685b      	ldr	r3, [r3, #4]
 80018ac:	f003 5380 	and.w	r3, r3, #268435456	; 0x10000000
 80018b0:	2b00      	cmp	r3, #0
 80018b2:	f000 80be 	beq.w	8001a32 <HAL_GPIO_Init+0x306>
      {
        /* Enable SYSCFG Clock */
        __HAL_RCC_SYSCFG_CLK_ENABLE();
 80018b6:	4b65      	ldr	r3, [pc, #404]	; (8001a4c <HAL_GPIO_Init+0x320>)
 80018b8:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 80018ba:	4a64      	ldr	r2, [pc, #400]	; (8001a4c <HAL_GPIO_Init+0x320>)
 80018bc:	f443 4380 	orr.w	r3, r3, #16384	; 0x4000
 80018c0:	6453      	str	r3, [r2, #68]	; 0x44
 80018c2:	4b62      	ldr	r3, [pc, #392]	; (8001a4c <HAL_GPIO_Init+0x320>)
 80018c4:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 80018c6:	f403 4380 	and.w	r3, r3, #16384	; 0x4000
 80018ca:	60fb      	str	r3, [r7, #12]
 80018cc:	68fb      	ldr	r3, [r7, #12]

        temp = SYSCFG->EXTICR[position >> 2];
 80018ce:	4a60      	ldr	r2, [pc, #384]	; (8001a50 <HAL_GPIO_Init+0x324>)
 80018d0:	69fb      	ldr	r3, [r7, #28]
 80018d2:	089b      	lsrs	r3, r3, #2
 80018d4:	3302      	adds	r3, #2
 80018d6:	f852 3023 	ldr.w	r3, [r2, r3, lsl #2]
 80018da:	61bb      	str	r3, [r7, #24]
        temp &= ~(((uint32_t)0x0F) << (4 * (position & 0x03)));
 80018dc:	69fb      	ldr	r3, [r7, #28]
 80018de:	f003 0303 	and.w	r3, r3, #3
 80018e2:	009b      	lsls	r3, r3, #2
 80018e4:	220f      	movs	r2, #15
 80018e6:	fa02 f303 	lsl.w	r3, r2, r3
 80018ea:	43db      	mvns	r3, r3
 80018ec:	69ba      	ldr	r2, [r7, #24]
 80018ee:	4013      	ands	r3, r2
 80018f0:	61bb      	str	r3, [r7, #24]
        temp |= ((uint32_t)(GPIO_GET_INDEX(GPIOx)) << (4 * (position & 0x03)));
 80018f2:	687b      	ldr	r3, [r7, #4]
 80018f4:	4a57      	ldr	r2, [pc, #348]	; (8001a54 <HAL_GPIO_Init+0x328>)
 80018f6:	4293      	cmp	r3, r2
 80018f8:	d037      	beq.n	800196a <HAL_GPIO_Init+0x23e>
 80018fa:	687b      	ldr	r3, [r7, #4]
 80018fc:	4a56      	ldr	r2, [pc, #344]	; (8001a58 <HAL_GPIO_Init+0x32c>)
 80018fe:	4293      	cmp	r3, r2
 8001900:	d031      	beq.n	8001966 <HAL_GPIO_Init+0x23a>
 8001902:	687b      	ldr	r3, [r7, #4]
 8001904:	4a55      	ldr	r2, [pc, #340]	; (8001a5c <HAL_GPIO_Init+0x330>)
 8001906:	4293      	cmp	r3, r2
 8001908:	d02b      	beq.n	8001962 <HAL_GPIO_Init+0x236>
 800190a:	687b      	ldr	r3, [r7, #4]
 800190c:	4a54      	ldr	r2, [pc, #336]	; (8001a60 <HAL_GPIO_Init+0x334>)
 800190e:	4293      	cmp	r3, r2
 8001910:	d025      	beq.n	800195e <HAL_GPIO_Init+0x232>
 8001912:	687b      	ldr	r3, [r7, #4]
 8001914:	4a53      	ldr	r2, [pc, #332]	; (8001a64 <HAL_GPIO_Init+0x338>)
 8001916:	4293      	cmp	r3, r2
 8001918:	d01f      	beq.n	800195a <HAL_GPIO_Init+0x22e>
 800191a:	687b      	ldr	r3, [r7, #4]
 800191c:	4a52      	ldr	r2, [pc, #328]	; (8001a68 <HAL_GPIO_Init+0x33c>)
 800191e:	4293      	cmp	r3, r2
 8001920:	d019      	beq.n	8001956 <HAL_GPIO_Init+0x22a>
 8001922:	687b      	ldr	r3, [r7, #4]
 8001924:	4a51      	ldr	r2, [pc, #324]	; (8001a6c <HAL_GPIO_Init+0x340>)
 8001926:	4293      	cmp	r3, r2
 8001928:	d013      	beq.n	8001952 <HAL_GPIO_Init+0x226>
 800192a:	687b      	ldr	r3, [r7, #4]
 800192c:	4a50      	ldr	r2, [pc, #320]	; (8001a70 <HAL_GPIO_Init+0x344>)
 800192e:	4293      	cmp	r3, r2
 8001930:	d00d      	beq.n	800194e <HAL_GPIO_Init+0x222>
 8001932:	687b      	ldr	r3, [r7, #4]
 8001934:	4a4f      	ldr	r2, [pc, #316]	; (8001a74 <HAL_GPIO_Init+0x348>)
 8001936:	4293      	cmp	r3, r2
 8001938:	d007      	beq.n	800194a <HAL_GPIO_Init+0x21e>
 800193a:	687b      	ldr	r3, [r7, #4]
 800193c:	4a4e      	ldr	r2, [pc, #312]	; (8001a78 <HAL_GPIO_Init+0x34c>)
 800193e:	4293      	cmp	r3, r2
 8001940:	d101      	bne.n	8001946 <HAL_GPIO_Init+0x21a>
 8001942:	2309      	movs	r3, #9
 8001944:	e012      	b.n	800196c <HAL_GPIO_Init+0x240>
 8001946:	230a      	movs	r3, #10
 8001948:	e010      	b.n	800196c <HAL_GPIO_Init+0x240>
 800194a:	2308      	movs	r3, #8
 800194c:	e00e      	b.n	800196c <HAL_GPIO_Init+0x240>
 800194e:	2307      	movs	r3, #7
 8001950:	e00c      	b.n	800196c <HAL_GPIO_Init+0x240>
 8001952:	2306      	movs	r3, #6
 8001954:	e00a      	b.n	800196c <HAL_GPIO_Init+0x240>
 8001956:	2305      	movs	r3, #5
 8001958:	e008      	b.n	800196c <HAL_GPIO_Init+0x240>
 800195a:	2304      	movs	r3, #4
 800195c:	e006      	b.n	800196c <HAL_GPIO_Init+0x240>
 800195e:	2303      	movs	r3, #3
 8001960:	e004      	b.n	800196c <HAL_GPIO_Init+0x240>
 8001962:	2302      	movs	r3, #2
 8001964:	e002      	b.n	800196c <HAL_GPIO_Init+0x240>
 8001966:	2301      	movs	r3, #1
 8001968:	e000      	b.n	800196c <HAL_GPIO_Init+0x240>
 800196a:	2300      	movs	r3, #0
 800196c:	69fa      	ldr	r2, [r7, #28]
 800196e:	f002 0203 	and.w	r2, r2, #3
 8001972:	0092      	lsls	r2, r2, #2
 8001974:	4093      	lsls	r3, r2
 8001976:	69ba      	ldr	r2, [r7, #24]
 8001978:	4313      	orrs	r3, r2
 800197a:	61bb      	str	r3, [r7, #24]
        SYSCFG->EXTICR[position >> 2] = temp;
 800197c:	4934      	ldr	r1, [pc, #208]	; (8001a50 <HAL_GPIO_Init+0x324>)
 800197e:	69fb      	ldr	r3, [r7, #28]
 8001980:	089b      	lsrs	r3, r3, #2
 8001982:	3302      	adds	r3, #2
 8001984:	69ba      	ldr	r2, [r7, #24]
 8001986:	f841 2023 	str.w	r2, [r1, r3, lsl #2]

        /* Clear EXTI line configuration */
        temp = EXTI->IMR;
 800198a:	4b3c      	ldr	r3, [pc, #240]	; (8001a7c <HAL_GPIO_Init+0x350>)
 800198c:	681b      	ldr	r3, [r3, #0]
 800198e:	61bb      	str	r3, [r7, #24]
        temp &= ~((uint32_t)iocurrent);
 8001990:	693b      	ldr	r3, [r7, #16]
 8001992:	43db      	mvns	r3, r3
 8001994:	69ba      	ldr	r2, [r7, #24]
 8001996:	4013      	ands	r3, r2
 8001998:	61bb      	str	r3, [r7, #24]
        if((GPIO_Init->Mode & GPIO_MODE_IT) == GPIO_MODE_IT)
 800199a:	683b      	ldr	r3, [r7, #0]
 800199c:	685b      	ldr	r3, [r3, #4]
 800199e:	f403 3380 	and.w	r3, r3, #65536	; 0x10000
 80019a2:	2b00      	cmp	r3, #0
 80019a4:	d003      	beq.n	80019ae <HAL_GPIO_Init+0x282>
        {
          temp |= iocurrent;
 80019a6:	69ba      	ldr	r2, [r7, #24]
 80019a8:	693b      	ldr	r3, [r7, #16]
 80019aa:	4313      	orrs	r3, r2
 80019ac:	61bb      	str	r3, [r7, #24]
        }
        EXTI->IMR = temp;
 80019ae:	4a33      	ldr	r2, [pc, #204]	; (8001a7c <HAL_GPIO_Init+0x350>)
 80019b0:	69bb      	ldr	r3, [r7, #24]
 80019b2:	6013      	str	r3, [r2, #0]

        temp = EXTI->EMR;
 80019b4:	4b31      	ldr	r3, [pc, #196]	; (8001a7c <HAL_GPIO_Init+0x350>)
 80019b6:	685b      	ldr	r3, [r3, #4]
 80019b8:	61bb      	str	r3, [r7, #24]
        temp &= ~((uint32_t)iocurrent);
 80019ba:	693b      	ldr	r3, [r7, #16]
 80019bc:	43db      	mvns	r3, r3
 80019be:	69ba      	ldr	r2, [r7, #24]
 80019c0:	4013      	ands	r3, r2
 80019c2:	61bb      	str	r3, [r7, #24]
        if((GPIO_Init->Mode & GPIO_MODE_EVT) == GPIO_MODE_EVT)
 80019c4:	683b      	ldr	r3, [r7, #0]
 80019c6:	685b      	ldr	r3, [r3, #4]
 80019c8:	f403 3300 	and.w	r3, r3, #131072	; 0x20000
 80019cc:	2b00      	cmp	r3, #0
 80019ce:	d003      	beq.n	80019d8 <HAL_GPIO_Init+0x2ac>
        {
          temp |= iocurrent;
 80019d0:	69ba      	ldr	r2, [r7, #24]
 80019d2:	693b      	ldr	r3, [r7, #16]
 80019d4:	4313      	orrs	r3, r2
 80019d6:	61bb      	str	r3, [r7, #24]
        }
        EXTI->EMR = temp;
 80019d8:	4a28      	ldr	r2, [pc, #160]	; (8001a7c <HAL_GPIO_Init+0x350>)
 80019da:	69bb      	ldr	r3, [r7, #24]
 80019dc:	6053      	str	r3, [r2, #4]

        /* Clear Rising Falling edge configuration */
        temp = EXTI->RTSR;
 80019de:	4b27      	ldr	r3, [pc, #156]	; (8001a7c <HAL_GPIO_Init+0x350>)
 80019e0:	689b      	ldr	r3, [r3, #8]
 80019e2:	61bb      	str	r3, [r7, #24]
        temp &= ~((uint32_t)iocurrent);
 80019e4:	693b      	ldr	r3, [r7, #16]
 80019e6:	43db      	mvns	r3, r3
 80019e8:	69ba      	ldr	r2, [r7, #24]
 80019ea:	4013      	ands	r3, r2
 80019ec:	61bb      	str	r3, [r7, #24]
        if((GPIO_Init->Mode & RISING_EDGE) == RISING_EDGE)
 80019ee:	683b      	ldr	r3, [r7, #0]
 80019f0:	685b      	ldr	r3, [r3, #4]
 80019f2:	f403 1380 	and.w	r3, r3, #1048576	; 0x100000
 80019f6:	2b00      	cmp	r3, #0
 80019f8:	d003      	beq.n	8001a02 <HAL_GPIO_Init+0x2d6>
        {
          temp |= iocurrent;
 80019fa:	69ba      	ldr	r2, [r7, #24]
 80019fc:	693b      	ldr	r3, [r7, #16]
 80019fe:	4313      	orrs	r3, r2
 8001a00:	61bb      	str	r3, [r7, #24]
        }
        EXTI->RTSR = temp;
 8001a02:	4a1e      	ldr	r2, [pc, #120]	; (8001a7c <HAL_GPIO_Init+0x350>)
 8001a04:	69bb      	ldr	r3, [r7, #24]
 8001a06:	6093      	str	r3, [r2, #8]

        temp = EXTI->FTSR;
 8001a08:	4b1c      	ldr	r3, [pc, #112]	; (8001a7c <HAL_GPIO_Init+0x350>)
 8001a0a:	68db      	ldr	r3, [r3, #12]
 8001a0c:	61bb      	str	r3, [r7, #24]
        temp &= ~((uint32_t)iocurrent);
 8001a0e:	693b      	ldr	r3, [r7, #16]
 8001a10:	43db      	mvns	r3, r3
 8001a12:	69ba      	ldr	r2, [r7, #24]
 8001a14:	4013      	ands	r3, r2
 8001a16:	61bb      	str	r3, [r7, #24]
        if((GPIO_Init->Mode & FALLING_EDGE) == FALLING_EDGE)
 8001a18:	683b      	ldr	r3, [r7, #0]
 8001a1a:	685b      	ldr	r3, [r3, #4]
 8001a1c:	f403 1300 	and.w	r3, r3, #2097152	; 0x200000
 8001a20:	2b00      	cmp	r3, #0
 8001a22:	d003      	beq.n	8001a2c <HAL_GPIO_Init+0x300>
        {
          temp |= iocurrent;
 8001a24:	69ba      	ldr	r2, [r7, #24]
 8001a26:	693b      	ldr	r3, [r7, #16]
 8001a28:	4313      	orrs	r3, r2
 8001a2a:	61bb      	str	r3, [r7, #24]
        }
        EXTI->FTSR = temp;
 8001a2c:	4a13      	ldr	r2, [pc, #76]	; (8001a7c <HAL_GPIO_Init+0x350>)
 8001a2e:	69bb      	ldr	r3, [r7, #24]
 8001a30:	60d3      	str	r3, [r2, #12]
  for(position = 0; position < GPIO_NUMBER; position++)
 8001a32:	69fb      	ldr	r3, [r7, #28]
 8001a34:	3301      	adds	r3, #1
 8001a36:	61fb      	str	r3, [r7, #28]
 8001a38:	69fb      	ldr	r3, [r7, #28]
 8001a3a:	2b0f      	cmp	r3, #15
 8001a3c:	f67f ae86 	bls.w	800174c <HAL_GPIO_Init+0x20>
      }
    }
  }
}
 8001a40:	bf00      	nop
 8001a42:	3724      	adds	r7, #36	; 0x24
 8001a44:	46bd      	mov	sp, r7
 8001a46:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001a4a:	4770      	bx	lr
 8001a4c:	40023800 	.word	0x40023800
 8001a50:	40013800 	.word	0x40013800
 8001a54:	40020000 	.word	0x40020000
 8001a58:	40020400 	.word	0x40020400
 8001a5c:	40020800 	.word	0x40020800
 8001a60:	40020c00 	.word	0x40020c00
 8001a64:	40021000 	.word	0x40021000
 8001a68:	40021400 	.word	0x40021400
 8001a6c:	40021800 	.word	0x40021800
 8001a70:	40021c00 	.word	0x40021c00
 8001a74:	40022000 	.word	0x40022000
 8001a78:	40022400 	.word	0x40022400
 8001a7c:	40013c00 	.word	0x40013c00

08001a80 <HAL_GPIO_ReadPin>:
  * @param  GPIO_Pin specifies the port bit to read.
  *         This parameter can be GPIO_PIN_x where x can be (0..15).
  * @retval The input port pin value.
  */
GPIO_PinState HAL_GPIO_ReadPin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin)
{
 8001a80:	b480      	push	{r7}
 8001a82:	b085      	sub	sp, #20
 8001a84:	af00      	add	r7, sp, #0
 8001a86:	6078      	str	r0, [r7, #4]
 8001a88:	460b      	mov	r3, r1
 8001a8a:	807b      	strh	r3, [r7, #2]
  GPIO_PinState bitstatus;

  /* Check the parameters */
  assert_param(IS_GPIO_PIN(GPIO_Pin));

  if((GPIOx->IDR & GPIO_Pin) != (uint32_t)GPIO_PIN_RESET)
 8001a8c:	687b      	ldr	r3, [r7, #4]
 8001a8e:	691a      	ldr	r2, [r3, #16]
 8001a90:	887b      	ldrh	r3, [r7, #2]
 8001a92:	4013      	ands	r3, r2
 8001a94:	2b00      	cmp	r3, #0
 8001a96:	d002      	beq.n	8001a9e <HAL_GPIO_ReadPin+0x1e>
  {
    bitstatus = GPIO_PIN_SET;
 8001a98:	2301      	movs	r3, #1
 8001a9a:	73fb      	strb	r3, [r7, #15]
 8001a9c:	e001      	b.n	8001aa2 <HAL_GPIO_ReadPin+0x22>
  }
  else
  {
    bitstatus = GPIO_PIN_RESET;
 8001a9e:	2300      	movs	r3, #0
 8001aa0:	73fb      	strb	r3, [r7, #15]
  }
  return bitstatus;
 8001aa2:	7bfb      	ldrb	r3, [r7, #15]
}
 8001aa4:	4618      	mov	r0, r3
 8001aa6:	3714      	adds	r7, #20
 8001aa8:	46bd      	mov	sp, r7
 8001aaa:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001aae:	4770      	bx	lr

08001ab0 <HAL_GPIO_WritePin>:
  *            @arg GPIO_PIN_RESET: to clear the port pin
  *            @arg GPIO_PIN_SET: to set the port pin
  * @retval None
  */
void HAL_GPIO_WritePin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin, GPIO_PinState PinState)
{
 8001ab0:	b480      	push	{r7}
 8001ab2:	b083      	sub	sp, #12
 8001ab4:	af00      	add	r7, sp, #0
 8001ab6:	6078      	str	r0, [r7, #4]
 8001ab8:	460b      	mov	r3, r1
 8001aba:	807b      	strh	r3, [r7, #2]
 8001abc:	4613      	mov	r3, r2
 8001abe:	707b      	strb	r3, [r7, #1]
  /* Check the parameters */
  assert_param(IS_GPIO_PIN(GPIO_Pin));
  assert_param(IS_GPIO_PIN_ACTION(PinState));

  if(PinState != GPIO_PIN_RESET)
 8001ac0:	787b      	ldrb	r3, [r7, #1]
 8001ac2:	2b00      	cmp	r3, #0
 8001ac4:	d003      	beq.n	8001ace <HAL_GPIO_WritePin+0x1e>
  {
    GPIOx->BSRR = GPIO_Pin;
 8001ac6:	887a      	ldrh	r2, [r7, #2]
 8001ac8:	687b      	ldr	r3, [r7, #4]
 8001aca:	619a      	str	r2, [r3, #24]
  }
  else
  {
    GPIOx->BSRR = (uint32_t)GPIO_Pin << 16;
  }
}
 8001acc:	e003      	b.n	8001ad6 <HAL_GPIO_WritePin+0x26>
    GPIOx->BSRR = (uint32_t)GPIO_Pin << 16;
 8001ace:	887b      	ldrh	r3, [r7, #2]
 8001ad0:	041a      	lsls	r2, r3, #16
 8001ad2:	687b      	ldr	r3, [r7, #4]
 8001ad4:	619a      	str	r2, [r3, #24]
}
 8001ad6:	bf00      	nop
 8001ad8:	370c      	adds	r7, #12
 8001ada:	46bd      	mov	sp, r7
 8001adc:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001ae0:	4770      	bx	lr
	...

08001ae4 <HAL_PWR_EnableBkUpAccess>:
  * @note If the HSE divided by 2, 3, ..31 is used as the RTC clock, the 
  *         Backup Domain Access should be kept enabled.
  * @retval None
  */
void HAL_PWR_EnableBkUpAccess(void)
{
 8001ae4:	b480      	push	{r7}
 8001ae6:	af00      	add	r7, sp, #0
  /* Enable access to RTC and backup registers */
  SET_BIT(PWR->CR1, PWR_CR1_DBP);
 8001ae8:	4b05      	ldr	r3, [pc, #20]	; (8001b00 <HAL_PWR_EnableBkUpAccess+0x1c>)
 8001aea:	681b      	ldr	r3, [r3, #0]
 8001aec:	4a04      	ldr	r2, [pc, #16]	; (8001b00 <HAL_PWR_EnableBkUpAccess+0x1c>)
 8001aee:	f443 7380 	orr.w	r3, r3, #256	; 0x100
 8001af2:	6013      	str	r3, [r2, #0]
}
 8001af4:	bf00      	nop
 8001af6:	46bd      	mov	sp, r7
 8001af8:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001afc:	4770      	bx	lr
 8001afe:	bf00      	nop
 8001b00:	40007000 	.word	0x40007000

08001b04 <HAL_PWREx_EnableOverDrive>:
  *         During the Over-drive switch activation, no peripheral clocks should be enabled.   
  *         The peripheral clocks must be enabled once the Over-drive mode is activated.   
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_PWREx_EnableOverDrive(void)
{
 8001b04:	b580      	push	{r7, lr}
 8001b06:	b082      	sub	sp, #8
 8001b08:	af00      	add	r7, sp, #0
  uint32_t tickstart = 0;
 8001b0a:	2300      	movs	r3, #0
 8001b0c:	607b      	str	r3, [r7, #4]

  __HAL_RCC_PWR_CLK_ENABLE();
 8001b0e:	4b23      	ldr	r3, [pc, #140]	; (8001b9c <HAL_PWREx_EnableOverDrive+0x98>)
 8001b10:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 8001b12:	4a22      	ldr	r2, [pc, #136]	; (8001b9c <HAL_PWREx_EnableOverDrive+0x98>)
 8001b14:	f043 5380 	orr.w	r3, r3, #268435456	; 0x10000000
 8001b18:	6413      	str	r3, [r2, #64]	; 0x40
 8001b1a:	4b20      	ldr	r3, [pc, #128]	; (8001b9c <HAL_PWREx_EnableOverDrive+0x98>)
 8001b1c:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 8001b1e:	f003 5380 	and.w	r3, r3, #268435456	; 0x10000000
 8001b22:	603b      	str	r3, [r7, #0]
 8001b24:	683b      	ldr	r3, [r7, #0]
  
  /* Enable the Over-drive to extend the clock frequency to 216 MHz */
  __HAL_PWR_OVERDRIVE_ENABLE();
 8001b26:	4b1e      	ldr	r3, [pc, #120]	; (8001ba0 <HAL_PWREx_EnableOverDrive+0x9c>)
 8001b28:	681b      	ldr	r3, [r3, #0]
 8001b2a:	4a1d      	ldr	r2, [pc, #116]	; (8001ba0 <HAL_PWREx_EnableOverDrive+0x9c>)
 8001b2c:	f443 3380 	orr.w	r3, r3, #65536	; 0x10000
 8001b30:	6013      	str	r3, [r2, #0]

  /* Get tick */
  tickstart = HAL_GetTick();
 8001b32:	f7ff fce7 	bl	8001504 <HAL_GetTick>
 8001b36:	6078      	str	r0, [r7, #4]

  while(!__HAL_PWR_GET_FLAG(PWR_FLAG_ODRDY))
 8001b38:	e009      	b.n	8001b4e <HAL_PWREx_EnableOverDrive+0x4a>
  {
    if((HAL_GetTick() - tickstart ) > PWR_OVERDRIVE_TIMEOUT_VALUE)
 8001b3a:	f7ff fce3 	bl	8001504 <HAL_GetTick>
 8001b3e:	4602      	mov	r2, r0
 8001b40:	687b      	ldr	r3, [r7, #4]
 8001b42:	1ad3      	subs	r3, r2, r3
 8001b44:	f5b3 7f7a 	cmp.w	r3, #1000	; 0x3e8
 8001b48:	d901      	bls.n	8001b4e <HAL_PWREx_EnableOverDrive+0x4a>
    {
      return HAL_TIMEOUT;
 8001b4a:	2303      	movs	r3, #3
 8001b4c:	e022      	b.n	8001b94 <HAL_PWREx_EnableOverDrive+0x90>
  while(!__HAL_PWR_GET_FLAG(PWR_FLAG_ODRDY))
 8001b4e:	4b14      	ldr	r3, [pc, #80]	; (8001ba0 <HAL_PWREx_EnableOverDrive+0x9c>)
 8001b50:	685b      	ldr	r3, [r3, #4]
 8001b52:	f403 3380 	and.w	r3, r3, #65536	; 0x10000
 8001b56:	f5b3 3f80 	cmp.w	r3, #65536	; 0x10000
 8001b5a:	d1ee      	bne.n	8001b3a <HAL_PWREx_EnableOverDrive+0x36>
    }
  }
  
  /* Enable the Over-drive switch */
  __HAL_PWR_OVERDRIVESWITCHING_ENABLE();
 8001b5c:	4b10      	ldr	r3, [pc, #64]	; (8001ba0 <HAL_PWREx_EnableOverDrive+0x9c>)
 8001b5e:	681b      	ldr	r3, [r3, #0]
 8001b60:	4a0f      	ldr	r2, [pc, #60]	; (8001ba0 <HAL_PWREx_EnableOverDrive+0x9c>)
 8001b62:	f443 3300 	orr.w	r3, r3, #131072	; 0x20000
 8001b66:	6013      	str	r3, [r2, #0]

  /* Get tick */
  tickstart = HAL_GetTick();
 8001b68:	f7ff fccc 	bl	8001504 <HAL_GetTick>
 8001b6c:	6078      	str	r0, [r7, #4]

  while(!__HAL_PWR_GET_FLAG(PWR_FLAG_ODSWRDY))
 8001b6e:	e009      	b.n	8001b84 <HAL_PWREx_EnableOverDrive+0x80>
  {
    if((HAL_GetTick() - tickstart ) > PWR_OVERDRIVE_TIMEOUT_VALUE)
 8001b70:	f7ff fcc8 	bl	8001504 <HAL_GetTick>
 8001b74:	4602      	mov	r2, r0
 8001b76:	687b      	ldr	r3, [r7, #4]
 8001b78:	1ad3      	subs	r3, r2, r3
 8001b7a:	f5b3 7f7a 	cmp.w	r3, #1000	; 0x3e8
 8001b7e:	d901      	bls.n	8001b84 <HAL_PWREx_EnableOverDrive+0x80>
    {
      return HAL_TIMEOUT;
 8001b80:	2303      	movs	r3, #3
 8001b82:	e007      	b.n	8001b94 <HAL_PWREx_EnableOverDrive+0x90>
  while(!__HAL_PWR_GET_FLAG(PWR_FLAG_ODSWRDY))
 8001b84:	4b06      	ldr	r3, [pc, #24]	; (8001ba0 <HAL_PWREx_EnableOverDrive+0x9c>)
 8001b86:	685b      	ldr	r3, [r3, #4]
 8001b88:	f403 3300 	and.w	r3, r3, #131072	; 0x20000
 8001b8c:	f5b3 3f00 	cmp.w	r3, #131072	; 0x20000
 8001b90:	d1ee      	bne.n	8001b70 <HAL_PWREx_EnableOverDrive+0x6c>
    }
  } 
  return HAL_OK;
 8001b92:	2300      	movs	r3, #0
}
 8001b94:	4618      	mov	r0, r3
 8001b96:	3708      	adds	r7, #8
 8001b98:	46bd      	mov	sp, r7
 8001b9a:	bd80      	pop	{r7, pc}
 8001b9c:	40023800 	.word	0x40023800
 8001ba0:	40007000 	.word	0x40007000

08001ba4 <HAL_RCC_OscConfig>:
  *         supported by this function. User should request a transition to HSE Off
  *         first and then HSE On or HSE Bypass.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_RCC_OscConfig(RCC_OscInitTypeDef  *RCC_OscInitStruct)
{
 8001ba4:	b580      	push	{r7, lr}
 8001ba6:	b086      	sub	sp, #24
 8001ba8:	af00      	add	r7, sp, #0
 8001baa:	6078      	str	r0, [r7, #4]
  uint32_t tickstart;
  uint32_t pll_config;
  FlagStatus pwrclkchanged = RESET;
 8001bac:	2300      	movs	r3, #0
 8001bae:	75fb      	strb	r3, [r7, #23]

  /* Check Null pointer */
  if (RCC_OscInitStruct == NULL)
 8001bb0:	687b      	ldr	r3, [r7, #4]
 8001bb2:	2b00      	cmp	r3, #0
 8001bb4:	d101      	bne.n	8001bba <HAL_RCC_OscConfig+0x16>
  {
    return HAL_ERROR;
 8001bb6:	2301      	movs	r3, #1
 8001bb8:	e29b      	b.n	80020f2 <HAL_RCC_OscConfig+0x54e>

  /* Check the parameters */
  assert_param(IS_RCC_OSCILLATORTYPE(RCC_OscInitStruct->OscillatorType));

  /*------------------------------- HSE Configuration ------------------------*/
  if (((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_HSE) == RCC_OSCILLATORTYPE_HSE)
 8001bba:	687b      	ldr	r3, [r7, #4]
 8001bbc:	681b      	ldr	r3, [r3, #0]
 8001bbe:	f003 0301 	and.w	r3, r3, #1
 8001bc2:	2b00      	cmp	r3, #0
 8001bc4:	f000 8087 	beq.w	8001cd6 <HAL_RCC_OscConfig+0x132>
  {
    /* Check the parameters */
    assert_param(IS_RCC_HSE(RCC_OscInitStruct->HSEState));
    /* When the HSE is used as system clock or clock source for PLL, It can not be disabled */
    if ((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_HSE)
 8001bc8:	4b96      	ldr	r3, [pc, #600]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001bca:	689b      	ldr	r3, [r3, #8]
 8001bcc:	f003 030c 	and.w	r3, r3, #12
 8001bd0:	2b04      	cmp	r3, #4
 8001bd2:	d00c      	beq.n	8001bee <HAL_RCC_OscConfig+0x4a>
        || ((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_PLLCLK) && ((RCC->PLLCFGR & RCC_PLLCFGR_PLLSRC) == RCC_PLLCFGR_PLLSRC_HSE)))
 8001bd4:	4b93      	ldr	r3, [pc, #588]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001bd6:	689b      	ldr	r3, [r3, #8]
 8001bd8:	f003 030c 	and.w	r3, r3, #12
 8001bdc:	2b08      	cmp	r3, #8
 8001bde:	d112      	bne.n	8001c06 <HAL_RCC_OscConfig+0x62>
 8001be0:	4b90      	ldr	r3, [pc, #576]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001be2:	685b      	ldr	r3, [r3, #4]
 8001be4:	f403 0380 	and.w	r3, r3, #4194304	; 0x400000
 8001be8:	f5b3 0f80 	cmp.w	r3, #4194304	; 0x400000
 8001bec:	d10b      	bne.n	8001c06 <HAL_RCC_OscConfig+0x62>
    {
      if ((__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) != RESET) && (RCC_OscInitStruct->HSEState == RCC_HSE_OFF))
 8001bee:	4b8d      	ldr	r3, [pc, #564]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001bf0:	681b      	ldr	r3, [r3, #0]
 8001bf2:	f403 3300 	and.w	r3, r3, #131072	; 0x20000
 8001bf6:	2b00      	cmp	r3, #0
 8001bf8:	d06c      	beq.n	8001cd4 <HAL_RCC_OscConfig+0x130>
 8001bfa:	687b      	ldr	r3, [r7, #4]
 8001bfc:	685b      	ldr	r3, [r3, #4]
 8001bfe:	2b00      	cmp	r3, #0
 8001c00:	d168      	bne.n	8001cd4 <HAL_RCC_OscConfig+0x130>
      {
        return HAL_ERROR;
 8001c02:	2301      	movs	r3, #1
 8001c04:	e275      	b.n	80020f2 <HAL_RCC_OscConfig+0x54e>
      }
    }
    else
    {
      /* Set the new HSE configuration ---------------------------------------*/
      __HAL_RCC_HSE_CONFIG(RCC_OscInitStruct->HSEState);
 8001c06:	687b      	ldr	r3, [r7, #4]
 8001c08:	685b      	ldr	r3, [r3, #4]
 8001c0a:	f5b3 3f80 	cmp.w	r3, #65536	; 0x10000
 8001c0e:	d106      	bne.n	8001c1e <HAL_RCC_OscConfig+0x7a>
 8001c10:	4b84      	ldr	r3, [pc, #528]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001c12:	681b      	ldr	r3, [r3, #0]
 8001c14:	4a83      	ldr	r2, [pc, #524]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001c16:	f443 3380 	orr.w	r3, r3, #65536	; 0x10000
 8001c1a:	6013      	str	r3, [r2, #0]
 8001c1c:	e02e      	b.n	8001c7c <HAL_RCC_OscConfig+0xd8>
 8001c1e:	687b      	ldr	r3, [r7, #4]
 8001c20:	685b      	ldr	r3, [r3, #4]
 8001c22:	2b00      	cmp	r3, #0
 8001c24:	d10c      	bne.n	8001c40 <HAL_RCC_OscConfig+0x9c>
 8001c26:	4b7f      	ldr	r3, [pc, #508]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001c28:	681b      	ldr	r3, [r3, #0]
 8001c2a:	4a7e      	ldr	r2, [pc, #504]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001c2c:	f423 3380 	bic.w	r3, r3, #65536	; 0x10000
 8001c30:	6013      	str	r3, [r2, #0]
 8001c32:	4b7c      	ldr	r3, [pc, #496]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001c34:	681b      	ldr	r3, [r3, #0]
 8001c36:	4a7b      	ldr	r2, [pc, #492]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001c38:	f423 2380 	bic.w	r3, r3, #262144	; 0x40000
 8001c3c:	6013      	str	r3, [r2, #0]
 8001c3e:	e01d      	b.n	8001c7c <HAL_RCC_OscConfig+0xd8>
 8001c40:	687b      	ldr	r3, [r7, #4]
 8001c42:	685b      	ldr	r3, [r3, #4]
 8001c44:	f5b3 2fa0 	cmp.w	r3, #327680	; 0x50000
 8001c48:	d10c      	bne.n	8001c64 <HAL_RCC_OscConfig+0xc0>
 8001c4a:	4b76      	ldr	r3, [pc, #472]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001c4c:	681b      	ldr	r3, [r3, #0]
 8001c4e:	4a75      	ldr	r2, [pc, #468]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001c50:	f443 2380 	orr.w	r3, r3, #262144	; 0x40000
 8001c54:	6013      	str	r3, [r2, #0]
 8001c56:	4b73      	ldr	r3, [pc, #460]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001c58:	681b      	ldr	r3, [r3, #0]
 8001c5a:	4a72      	ldr	r2, [pc, #456]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001c5c:	f443 3380 	orr.w	r3, r3, #65536	; 0x10000
 8001c60:	6013      	str	r3, [r2, #0]
 8001c62:	e00b      	b.n	8001c7c <HAL_RCC_OscConfig+0xd8>
 8001c64:	4b6f      	ldr	r3, [pc, #444]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001c66:	681b      	ldr	r3, [r3, #0]
 8001c68:	4a6e      	ldr	r2, [pc, #440]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001c6a:	f423 3380 	bic.w	r3, r3, #65536	; 0x10000
 8001c6e:	6013      	str	r3, [r2, #0]
 8001c70:	4b6c      	ldr	r3, [pc, #432]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001c72:	681b      	ldr	r3, [r3, #0]
 8001c74:	4a6b      	ldr	r2, [pc, #428]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001c76:	f423 2380 	bic.w	r3, r3, #262144	; 0x40000
 8001c7a:	6013      	str	r3, [r2, #0]

      /* Check the HSE State */
      if (RCC_OscInitStruct->HSEState != RCC_HSE_OFF)
 8001c7c:	687b      	ldr	r3, [r7, #4]
 8001c7e:	685b      	ldr	r3, [r3, #4]
 8001c80:	2b00      	cmp	r3, #0
 8001c82:	d013      	beq.n	8001cac <HAL_RCC_OscConfig+0x108>
      {
        /* Get Start Tick*/
        tickstart = HAL_GetTick();
 8001c84:	f7ff fc3e 	bl	8001504 <HAL_GetTick>
 8001c88:	6138      	str	r0, [r7, #16]

        /* Wait till HSE is ready */
        while (__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) == RESET)
 8001c8a:	e008      	b.n	8001c9e <HAL_RCC_OscConfig+0xfa>
        {
          if ((HAL_GetTick() - tickstart) > HSE_TIMEOUT_VALUE)
 8001c8c:	f7ff fc3a 	bl	8001504 <HAL_GetTick>
 8001c90:	4602      	mov	r2, r0
 8001c92:	693b      	ldr	r3, [r7, #16]
 8001c94:	1ad3      	subs	r3, r2, r3
 8001c96:	2b64      	cmp	r3, #100	; 0x64
 8001c98:	d901      	bls.n	8001c9e <HAL_RCC_OscConfig+0xfa>
          {
            return HAL_TIMEOUT;
 8001c9a:	2303      	movs	r3, #3
 8001c9c:	e229      	b.n	80020f2 <HAL_RCC_OscConfig+0x54e>
        while (__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) == RESET)
 8001c9e:	4b61      	ldr	r3, [pc, #388]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001ca0:	681b      	ldr	r3, [r3, #0]
 8001ca2:	f403 3300 	and.w	r3, r3, #131072	; 0x20000
 8001ca6:	2b00      	cmp	r3, #0
 8001ca8:	d0f0      	beq.n	8001c8c <HAL_RCC_OscConfig+0xe8>
 8001caa:	e014      	b.n	8001cd6 <HAL_RCC_OscConfig+0x132>
        }
      }
      else
      {
        /* Get Start Tick*/
        tickstart = HAL_GetTick();
 8001cac:	f7ff fc2a 	bl	8001504 <HAL_GetTick>
 8001cb0:	6138      	str	r0, [r7, #16]

        /* Wait till HSE is bypassed or disabled */
        while (__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) != RESET)
 8001cb2:	e008      	b.n	8001cc6 <HAL_RCC_OscConfig+0x122>
        {
          if ((HAL_GetTick() - tickstart) > HSE_TIMEOUT_VALUE)
 8001cb4:	f7ff fc26 	bl	8001504 <HAL_GetTick>
 8001cb8:	4602      	mov	r2, r0
 8001cba:	693b      	ldr	r3, [r7, #16]
 8001cbc:	1ad3      	subs	r3, r2, r3
 8001cbe:	2b64      	cmp	r3, #100	; 0x64
 8001cc0:	d901      	bls.n	8001cc6 <HAL_RCC_OscConfig+0x122>
          {
            return HAL_TIMEOUT;
 8001cc2:	2303      	movs	r3, #3
 8001cc4:	e215      	b.n	80020f2 <HAL_RCC_OscConfig+0x54e>
        while (__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) != RESET)
 8001cc6:	4b57      	ldr	r3, [pc, #348]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001cc8:	681b      	ldr	r3, [r3, #0]
 8001cca:	f403 3300 	and.w	r3, r3, #131072	; 0x20000
 8001cce:	2b00      	cmp	r3, #0
 8001cd0:	d1f0      	bne.n	8001cb4 <HAL_RCC_OscConfig+0x110>
 8001cd2:	e000      	b.n	8001cd6 <HAL_RCC_OscConfig+0x132>
      if ((__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) != RESET) && (RCC_OscInitStruct->HSEState == RCC_HSE_OFF))
 8001cd4:	bf00      	nop
        }
      }
    }
  }
  /*----------------------------- HSI Configuration --------------------------*/
  if (((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_HSI) == RCC_OSCILLATORTYPE_HSI)
 8001cd6:	687b      	ldr	r3, [r7, #4]
 8001cd8:	681b      	ldr	r3, [r3, #0]
 8001cda:	f003 0302 	and.w	r3, r3, #2
 8001cde:	2b00      	cmp	r3, #0
 8001ce0:	d069      	beq.n	8001db6 <HAL_RCC_OscConfig+0x212>
    /* Check the parameters */
    assert_param(IS_RCC_HSI(RCC_OscInitStruct->HSIState));
    assert_param(IS_RCC_CALIBRATION_VALUE(RCC_OscInitStruct->HSICalibrationValue));

    /* Check if HSI is used as system clock or as PLL source when PLL is selected as system clock */
    if ((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_HSI)
 8001ce2:	4b50      	ldr	r3, [pc, #320]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001ce4:	689b      	ldr	r3, [r3, #8]
 8001ce6:	f003 030c 	and.w	r3, r3, #12
 8001cea:	2b00      	cmp	r3, #0
 8001cec:	d00b      	beq.n	8001d06 <HAL_RCC_OscConfig+0x162>
        || ((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_PLLCLK) && ((RCC->PLLCFGR & RCC_PLLCFGR_PLLSRC) == RCC_PLLCFGR_PLLSRC_HSI)))
 8001cee:	4b4d      	ldr	r3, [pc, #308]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001cf0:	689b      	ldr	r3, [r3, #8]
 8001cf2:	f003 030c 	and.w	r3, r3, #12
 8001cf6:	2b08      	cmp	r3, #8
 8001cf8:	d11c      	bne.n	8001d34 <HAL_RCC_OscConfig+0x190>
 8001cfa:	4b4a      	ldr	r3, [pc, #296]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001cfc:	685b      	ldr	r3, [r3, #4]
 8001cfe:	f403 0380 	and.w	r3, r3, #4194304	; 0x400000
 8001d02:	2b00      	cmp	r3, #0
 8001d04:	d116      	bne.n	8001d34 <HAL_RCC_OscConfig+0x190>
    {
      /* When HSI is used as system clock it will not disabled */
      if ((__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) != RESET) && (RCC_OscInitStruct->HSIState != RCC_HSI_ON))
 8001d06:	4b47      	ldr	r3, [pc, #284]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001d08:	681b      	ldr	r3, [r3, #0]
 8001d0a:	f003 0302 	and.w	r3, r3, #2
 8001d0e:	2b00      	cmp	r3, #0
 8001d10:	d005      	beq.n	8001d1e <HAL_RCC_OscConfig+0x17a>
 8001d12:	687b      	ldr	r3, [r7, #4]
 8001d14:	68db      	ldr	r3, [r3, #12]
 8001d16:	2b01      	cmp	r3, #1
 8001d18:	d001      	beq.n	8001d1e <HAL_RCC_OscConfig+0x17a>
      {
        return HAL_ERROR;
 8001d1a:	2301      	movs	r3, #1
 8001d1c:	e1e9      	b.n	80020f2 <HAL_RCC_OscConfig+0x54e>
      }
      /* Otherwise, just the calibration is allowed */
      else
      {
        /* Adjusts the Internal High Speed oscillator (HSI) calibration value.*/
        __HAL_RCC_HSI_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->HSICalibrationValue);
 8001d1e:	4b41      	ldr	r3, [pc, #260]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001d20:	681b      	ldr	r3, [r3, #0]
 8001d22:	f023 02f8 	bic.w	r2, r3, #248	; 0xf8
 8001d26:	687b      	ldr	r3, [r7, #4]
 8001d28:	691b      	ldr	r3, [r3, #16]
 8001d2a:	00db      	lsls	r3, r3, #3
 8001d2c:	493d      	ldr	r1, [pc, #244]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001d2e:	4313      	orrs	r3, r2
 8001d30:	600b      	str	r3, [r1, #0]
      if ((__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) != RESET) && (RCC_OscInitStruct->HSIState != RCC_HSI_ON))
 8001d32:	e040      	b.n	8001db6 <HAL_RCC_OscConfig+0x212>
      }
    }
    else
    {
      /* Check the HSI State */
      if ((RCC_OscInitStruct->HSIState) != RCC_HSI_OFF)
 8001d34:	687b      	ldr	r3, [r7, #4]
 8001d36:	68db      	ldr	r3, [r3, #12]
 8001d38:	2b00      	cmp	r3, #0
 8001d3a:	d023      	beq.n	8001d84 <HAL_RCC_OscConfig+0x1e0>
      {
        /* Enable the Internal High Speed oscillator (HSI). */
        __HAL_RCC_HSI_ENABLE();
 8001d3c:	4b39      	ldr	r3, [pc, #228]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001d3e:	681b      	ldr	r3, [r3, #0]
 8001d40:	4a38      	ldr	r2, [pc, #224]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001d42:	f043 0301 	orr.w	r3, r3, #1
 8001d46:	6013      	str	r3, [r2, #0]

        /* Get Start Tick*/
        tickstart = HAL_GetTick();
 8001d48:	f7ff fbdc 	bl	8001504 <HAL_GetTick>
 8001d4c:	6138      	str	r0, [r7, #16]

        /* Wait till HSI is ready */
        while (__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) == RESET)
 8001d4e:	e008      	b.n	8001d62 <HAL_RCC_OscConfig+0x1be>
        {
          if ((HAL_GetTick() - tickstart) > HSI_TIMEOUT_VALUE)
 8001d50:	f7ff fbd8 	bl	8001504 <HAL_GetTick>
 8001d54:	4602      	mov	r2, r0
 8001d56:	693b      	ldr	r3, [r7, #16]
 8001d58:	1ad3      	subs	r3, r2, r3
 8001d5a:	2b02      	cmp	r3, #2
 8001d5c:	d901      	bls.n	8001d62 <HAL_RCC_OscConfig+0x1be>
          {
            return HAL_TIMEOUT;
 8001d5e:	2303      	movs	r3, #3
 8001d60:	e1c7      	b.n	80020f2 <HAL_RCC_OscConfig+0x54e>
        while (__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) == RESET)
 8001d62:	4b30      	ldr	r3, [pc, #192]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001d64:	681b      	ldr	r3, [r3, #0]
 8001d66:	f003 0302 	and.w	r3, r3, #2
 8001d6a:	2b00      	cmp	r3, #0
 8001d6c:	d0f0      	beq.n	8001d50 <HAL_RCC_OscConfig+0x1ac>
          }
        }

        /* Adjusts the Internal High Speed oscillator (HSI) calibration value.*/
        __HAL_RCC_HSI_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->HSICalibrationValue);
 8001d6e:	4b2d      	ldr	r3, [pc, #180]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001d70:	681b      	ldr	r3, [r3, #0]
 8001d72:	f023 02f8 	bic.w	r2, r3, #248	; 0xf8
 8001d76:	687b      	ldr	r3, [r7, #4]
 8001d78:	691b      	ldr	r3, [r3, #16]
 8001d7a:	00db      	lsls	r3, r3, #3
 8001d7c:	4929      	ldr	r1, [pc, #164]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001d7e:	4313      	orrs	r3, r2
 8001d80:	600b      	str	r3, [r1, #0]
 8001d82:	e018      	b.n	8001db6 <HAL_RCC_OscConfig+0x212>
      }
      else
      {
        /* Disable the Internal High Speed oscillator (HSI). */
        __HAL_RCC_HSI_DISABLE();
 8001d84:	4b27      	ldr	r3, [pc, #156]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001d86:	681b      	ldr	r3, [r3, #0]
 8001d88:	4a26      	ldr	r2, [pc, #152]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001d8a:	f023 0301 	bic.w	r3, r3, #1
 8001d8e:	6013      	str	r3, [r2, #0]

        /* Get Start Tick*/
        tickstart = HAL_GetTick();
 8001d90:	f7ff fbb8 	bl	8001504 <HAL_GetTick>
 8001d94:	6138      	str	r0, [r7, #16]

        /* Wait till HSI is ready */
        while (__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) != RESET)
 8001d96:	e008      	b.n	8001daa <HAL_RCC_OscConfig+0x206>
        {
          if ((HAL_GetTick() - tickstart) > HSI_TIMEOUT_VALUE)
 8001d98:	f7ff fbb4 	bl	8001504 <HAL_GetTick>
 8001d9c:	4602      	mov	r2, r0
 8001d9e:	693b      	ldr	r3, [r7, #16]
 8001da0:	1ad3      	subs	r3, r2, r3
 8001da2:	2b02      	cmp	r3, #2
 8001da4:	d901      	bls.n	8001daa <HAL_RCC_OscConfig+0x206>
          {
            return HAL_TIMEOUT;
 8001da6:	2303      	movs	r3, #3
 8001da8:	e1a3      	b.n	80020f2 <HAL_RCC_OscConfig+0x54e>
        while (__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) != RESET)
 8001daa:	4b1e      	ldr	r3, [pc, #120]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001dac:	681b      	ldr	r3, [r3, #0]
 8001dae:	f003 0302 	and.w	r3, r3, #2
 8001db2:	2b00      	cmp	r3, #0
 8001db4:	d1f0      	bne.n	8001d98 <HAL_RCC_OscConfig+0x1f4>
        }
      }
    }
  }
  /*------------------------------ LSI Configuration -------------------------*/
  if (((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_LSI) == RCC_OSCILLATORTYPE_LSI)
 8001db6:	687b      	ldr	r3, [r7, #4]
 8001db8:	681b      	ldr	r3, [r3, #0]
 8001dba:	f003 0308 	and.w	r3, r3, #8
 8001dbe:	2b00      	cmp	r3, #0
 8001dc0:	d038      	beq.n	8001e34 <HAL_RCC_OscConfig+0x290>
  {
    /* Check the parameters */
    assert_param(IS_RCC_LSI(RCC_OscInitStruct->LSIState));

    /* Check the LSI State */
    if ((RCC_OscInitStruct->LSIState) != RCC_LSI_OFF)
 8001dc2:	687b      	ldr	r3, [r7, #4]
 8001dc4:	695b      	ldr	r3, [r3, #20]
 8001dc6:	2b00      	cmp	r3, #0
 8001dc8:	d019      	beq.n	8001dfe <HAL_RCC_OscConfig+0x25a>
    {
      /* Enable the Internal Low Speed oscillator (LSI). */
      __HAL_RCC_LSI_ENABLE();
 8001dca:	4b16      	ldr	r3, [pc, #88]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001dcc:	6f5b      	ldr	r3, [r3, #116]	; 0x74
 8001dce:	4a15      	ldr	r2, [pc, #84]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001dd0:	f043 0301 	orr.w	r3, r3, #1
 8001dd4:	6753      	str	r3, [r2, #116]	; 0x74

      /* Get Start Tick*/
      tickstart = HAL_GetTick();
 8001dd6:	f7ff fb95 	bl	8001504 <HAL_GetTick>
 8001dda:	6138      	str	r0, [r7, #16]

      /* Wait till LSI is ready */
      while (__HAL_RCC_GET_FLAG(RCC_FLAG_LSIRDY) == RESET)
 8001ddc:	e008      	b.n	8001df0 <HAL_RCC_OscConfig+0x24c>
      {
        if ((HAL_GetTick() - tickstart) > LSI_TIMEOUT_VALUE)
 8001dde:	f7ff fb91 	bl	8001504 <HAL_GetTick>
 8001de2:	4602      	mov	r2, r0
 8001de4:	693b      	ldr	r3, [r7, #16]
 8001de6:	1ad3      	subs	r3, r2, r3
 8001de8:	2b02      	cmp	r3, #2
 8001dea:	d901      	bls.n	8001df0 <HAL_RCC_OscConfig+0x24c>
        {
          return HAL_TIMEOUT;
 8001dec:	2303      	movs	r3, #3
 8001dee:	e180      	b.n	80020f2 <HAL_RCC_OscConfig+0x54e>
      while (__HAL_RCC_GET_FLAG(RCC_FLAG_LSIRDY) == RESET)
 8001df0:	4b0c      	ldr	r3, [pc, #48]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001df2:	6f5b      	ldr	r3, [r3, #116]	; 0x74
 8001df4:	f003 0302 	and.w	r3, r3, #2
 8001df8:	2b00      	cmp	r3, #0
 8001dfa:	d0f0      	beq.n	8001dde <HAL_RCC_OscConfig+0x23a>
 8001dfc:	e01a      	b.n	8001e34 <HAL_RCC_OscConfig+0x290>
      }
    }
    else
    {
      /* Disable the Internal Low Speed oscillator (LSI). */
      __HAL_RCC_LSI_DISABLE();
 8001dfe:	4b09      	ldr	r3, [pc, #36]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001e00:	6f5b      	ldr	r3, [r3, #116]	; 0x74
 8001e02:	4a08      	ldr	r2, [pc, #32]	; (8001e24 <HAL_RCC_OscConfig+0x280>)
 8001e04:	f023 0301 	bic.w	r3, r3, #1
 8001e08:	6753      	str	r3, [r2, #116]	; 0x74

      /* Get Start Tick*/
      tickstart = HAL_GetTick();
 8001e0a:	f7ff fb7b 	bl	8001504 <HAL_GetTick>
 8001e0e:	6138      	str	r0, [r7, #16]

      /* Wait till LSI is ready */
      while (__HAL_RCC_GET_FLAG(RCC_FLAG_LSIRDY) != RESET)
 8001e10:	e00a      	b.n	8001e28 <HAL_RCC_OscConfig+0x284>
      {
        if ((HAL_GetTick() - tickstart) > LSI_TIMEOUT_VALUE)
 8001e12:	f7ff fb77 	bl	8001504 <HAL_GetTick>
 8001e16:	4602      	mov	r2, r0
 8001e18:	693b      	ldr	r3, [r7, #16]
 8001e1a:	1ad3      	subs	r3, r2, r3
 8001e1c:	2b02      	cmp	r3, #2
 8001e1e:	d903      	bls.n	8001e28 <HAL_RCC_OscConfig+0x284>
        {
          return HAL_TIMEOUT;
 8001e20:	2303      	movs	r3, #3
 8001e22:	e166      	b.n	80020f2 <HAL_RCC_OscConfig+0x54e>
 8001e24:	40023800 	.word	0x40023800
      while (__HAL_RCC_GET_FLAG(RCC_FLAG_LSIRDY) != RESET)
 8001e28:	4b92      	ldr	r3, [pc, #584]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001e2a:	6f5b      	ldr	r3, [r3, #116]	; 0x74
 8001e2c:	f003 0302 	and.w	r3, r3, #2
 8001e30:	2b00      	cmp	r3, #0
 8001e32:	d1ee      	bne.n	8001e12 <HAL_RCC_OscConfig+0x26e>
        }
      }
    }
  }
  /*------------------------------ LSE Configuration -------------------------*/
  if (((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_LSE) == RCC_OSCILLATORTYPE_LSE)
 8001e34:	687b      	ldr	r3, [r7, #4]
 8001e36:	681b      	ldr	r3, [r3, #0]
 8001e38:	f003 0304 	and.w	r3, r3, #4
 8001e3c:	2b00      	cmp	r3, #0
 8001e3e:	f000 80a4 	beq.w	8001f8a <HAL_RCC_OscConfig+0x3e6>
    /* Check the parameters */
    assert_param(IS_RCC_LSE(RCC_OscInitStruct->LSEState));

    /* Update LSE configuration in Backup Domain control register    */
    /* Requires to enable write access to Backup Domain of necessary */
    if (__HAL_RCC_PWR_IS_CLK_DISABLED())
 8001e42:	4b8c      	ldr	r3, [pc, #560]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001e44:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 8001e46:	f003 5380 	and.w	r3, r3, #268435456	; 0x10000000
 8001e4a:	2b00      	cmp	r3, #0
 8001e4c:	d10d      	bne.n	8001e6a <HAL_RCC_OscConfig+0x2c6>
    {
      /* Enable Power Clock*/
      __HAL_RCC_PWR_CLK_ENABLE();
 8001e4e:	4b89      	ldr	r3, [pc, #548]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001e50:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 8001e52:	4a88      	ldr	r2, [pc, #544]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001e54:	f043 5380 	orr.w	r3, r3, #268435456	; 0x10000000
 8001e58:	6413      	str	r3, [r2, #64]	; 0x40
 8001e5a:	4b86      	ldr	r3, [pc, #536]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001e5c:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 8001e5e:	f003 5380 	and.w	r3, r3, #268435456	; 0x10000000
 8001e62:	60bb      	str	r3, [r7, #8]
 8001e64:	68bb      	ldr	r3, [r7, #8]
      pwrclkchanged = SET;
 8001e66:	2301      	movs	r3, #1
 8001e68:	75fb      	strb	r3, [r7, #23]
    }

    if (HAL_IS_BIT_CLR(PWR->CR1, PWR_CR1_DBP))
 8001e6a:	4b83      	ldr	r3, [pc, #524]	; (8002078 <HAL_RCC_OscConfig+0x4d4>)
 8001e6c:	681b      	ldr	r3, [r3, #0]
 8001e6e:	f403 7380 	and.w	r3, r3, #256	; 0x100
 8001e72:	2b00      	cmp	r3, #0
 8001e74:	d118      	bne.n	8001ea8 <HAL_RCC_OscConfig+0x304>
    {
      /* Enable write access to Backup domain */
      PWR->CR1 |= PWR_CR1_DBP;
 8001e76:	4b80      	ldr	r3, [pc, #512]	; (8002078 <HAL_RCC_OscConfig+0x4d4>)
 8001e78:	681b      	ldr	r3, [r3, #0]
 8001e7a:	4a7f      	ldr	r2, [pc, #508]	; (8002078 <HAL_RCC_OscConfig+0x4d4>)
 8001e7c:	f443 7380 	orr.w	r3, r3, #256	; 0x100
 8001e80:	6013      	str	r3, [r2, #0]

      /* Wait for Backup domain Write protection disable */
      tickstart = HAL_GetTick();
 8001e82:	f7ff fb3f 	bl	8001504 <HAL_GetTick>
 8001e86:	6138      	str	r0, [r7, #16]

      while (HAL_IS_BIT_CLR(PWR->CR1, PWR_CR1_DBP))
 8001e88:	e008      	b.n	8001e9c <HAL_RCC_OscConfig+0x2f8>
      {
        if ((HAL_GetTick() - tickstart) > RCC_DBP_TIMEOUT_VALUE)
 8001e8a:	f7ff fb3b 	bl	8001504 <HAL_GetTick>
 8001e8e:	4602      	mov	r2, r0
 8001e90:	693b      	ldr	r3, [r7, #16]
 8001e92:	1ad3      	subs	r3, r2, r3
 8001e94:	2b64      	cmp	r3, #100	; 0x64
 8001e96:	d901      	bls.n	8001e9c <HAL_RCC_OscConfig+0x2f8>
        {
          return HAL_TIMEOUT;
 8001e98:	2303      	movs	r3, #3
 8001e9a:	e12a      	b.n	80020f2 <HAL_RCC_OscConfig+0x54e>
      while (HAL_IS_BIT_CLR(PWR->CR1, PWR_CR1_DBP))
 8001e9c:	4b76      	ldr	r3, [pc, #472]	; (8002078 <HAL_RCC_OscConfig+0x4d4>)
 8001e9e:	681b      	ldr	r3, [r3, #0]
 8001ea0:	f403 7380 	and.w	r3, r3, #256	; 0x100
 8001ea4:	2b00      	cmp	r3, #0
 8001ea6:	d0f0      	beq.n	8001e8a <HAL_RCC_OscConfig+0x2e6>
        }
      }
    }

    /* Set the new LSE configuration -----------------------------------------*/
    __HAL_RCC_LSE_CONFIG(RCC_OscInitStruct->LSEState);
 8001ea8:	687b      	ldr	r3, [r7, #4]
 8001eaa:	689b      	ldr	r3, [r3, #8]
 8001eac:	2b01      	cmp	r3, #1
 8001eae:	d106      	bne.n	8001ebe <HAL_RCC_OscConfig+0x31a>
 8001eb0:	4b70      	ldr	r3, [pc, #448]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001eb2:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 8001eb4:	4a6f      	ldr	r2, [pc, #444]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001eb6:	f043 0301 	orr.w	r3, r3, #1
 8001eba:	6713      	str	r3, [r2, #112]	; 0x70
 8001ebc:	e02d      	b.n	8001f1a <HAL_RCC_OscConfig+0x376>
 8001ebe:	687b      	ldr	r3, [r7, #4]
 8001ec0:	689b      	ldr	r3, [r3, #8]
 8001ec2:	2b00      	cmp	r3, #0
 8001ec4:	d10c      	bne.n	8001ee0 <HAL_RCC_OscConfig+0x33c>
 8001ec6:	4b6b      	ldr	r3, [pc, #428]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001ec8:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 8001eca:	4a6a      	ldr	r2, [pc, #424]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001ecc:	f023 0301 	bic.w	r3, r3, #1
 8001ed0:	6713      	str	r3, [r2, #112]	; 0x70
 8001ed2:	4b68      	ldr	r3, [pc, #416]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001ed4:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 8001ed6:	4a67      	ldr	r2, [pc, #412]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001ed8:	f023 0304 	bic.w	r3, r3, #4
 8001edc:	6713      	str	r3, [r2, #112]	; 0x70
 8001ede:	e01c      	b.n	8001f1a <HAL_RCC_OscConfig+0x376>
 8001ee0:	687b      	ldr	r3, [r7, #4]
 8001ee2:	689b      	ldr	r3, [r3, #8]
 8001ee4:	2b05      	cmp	r3, #5
 8001ee6:	d10c      	bne.n	8001f02 <HAL_RCC_OscConfig+0x35e>
 8001ee8:	4b62      	ldr	r3, [pc, #392]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001eea:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 8001eec:	4a61      	ldr	r2, [pc, #388]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001eee:	f043 0304 	orr.w	r3, r3, #4
 8001ef2:	6713      	str	r3, [r2, #112]	; 0x70
 8001ef4:	4b5f      	ldr	r3, [pc, #380]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001ef6:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 8001ef8:	4a5e      	ldr	r2, [pc, #376]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001efa:	f043 0301 	orr.w	r3, r3, #1
 8001efe:	6713      	str	r3, [r2, #112]	; 0x70
 8001f00:	e00b      	b.n	8001f1a <HAL_RCC_OscConfig+0x376>
 8001f02:	4b5c      	ldr	r3, [pc, #368]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001f04:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 8001f06:	4a5b      	ldr	r2, [pc, #364]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001f08:	f023 0301 	bic.w	r3, r3, #1
 8001f0c:	6713      	str	r3, [r2, #112]	; 0x70
 8001f0e:	4b59      	ldr	r3, [pc, #356]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001f10:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 8001f12:	4a58      	ldr	r2, [pc, #352]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001f14:	f023 0304 	bic.w	r3, r3, #4
 8001f18:	6713      	str	r3, [r2, #112]	; 0x70
    /* Check the LSE State */
    if ((RCC_OscInitStruct->LSEState) != RCC_LSE_OFF)
 8001f1a:	687b      	ldr	r3, [r7, #4]
 8001f1c:	689b      	ldr	r3, [r3, #8]
 8001f1e:	2b00      	cmp	r3, #0
 8001f20:	d015      	beq.n	8001f4e <HAL_RCC_OscConfig+0x3aa>
    {
      /* Get Start Tick*/
      tickstart = HAL_GetTick();
 8001f22:	f7ff faef 	bl	8001504 <HAL_GetTick>
 8001f26:	6138      	str	r0, [r7, #16]

      /* Wait till LSE is ready */
      while (__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) == RESET)
 8001f28:	e00a      	b.n	8001f40 <HAL_RCC_OscConfig+0x39c>
      {
        if ((HAL_GetTick() - tickstart) > RCC_LSE_TIMEOUT_VALUE)
 8001f2a:	f7ff faeb 	bl	8001504 <HAL_GetTick>
 8001f2e:	4602      	mov	r2, r0
 8001f30:	693b      	ldr	r3, [r7, #16]
 8001f32:	1ad3      	subs	r3, r2, r3
 8001f34:	f241 3288 	movw	r2, #5000	; 0x1388
 8001f38:	4293      	cmp	r3, r2
 8001f3a:	d901      	bls.n	8001f40 <HAL_RCC_OscConfig+0x39c>
        {
          return HAL_TIMEOUT;
 8001f3c:	2303      	movs	r3, #3
 8001f3e:	e0d8      	b.n	80020f2 <HAL_RCC_OscConfig+0x54e>
      while (__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) == RESET)
 8001f40:	4b4c      	ldr	r3, [pc, #304]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001f42:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 8001f44:	f003 0302 	and.w	r3, r3, #2
 8001f48:	2b00      	cmp	r3, #0
 8001f4a:	d0ee      	beq.n	8001f2a <HAL_RCC_OscConfig+0x386>
 8001f4c:	e014      	b.n	8001f78 <HAL_RCC_OscConfig+0x3d4>
      }
    }
    else
    {
      /* Get Start Tick*/
      tickstart = HAL_GetTick();
 8001f4e:	f7ff fad9 	bl	8001504 <HAL_GetTick>
 8001f52:	6138      	str	r0, [r7, #16]

      /* Wait till LSE is ready */
      while (__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) != RESET)
 8001f54:	e00a      	b.n	8001f6c <HAL_RCC_OscConfig+0x3c8>
      {
        if ((HAL_GetTick() - tickstart) > RCC_LSE_TIMEOUT_VALUE)
 8001f56:	f7ff fad5 	bl	8001504 <HAL_GetTick>
 8001f5a:	4602      	mov	r2, r0
 8001f5c:	693b      	ldr	r3, [r7, #16]
 8001f5e:	1ad3      	subs	r3, r2, r3
 8001f60:	f241 3288 	movw	r2, #5000	; 0x1388
 8001f64:	4293      	cmp	r3, r2
 8001f66:	d901      	bls.n	8001f6c <HAL_RCC_OscConfig+0x3c8>
        {
          return HAL_TIMEOUT;
 8001f68:	2303      	movs	r3, #3
 8001f6a:	e0c2      	b.n	80020f2 <HAL_RCC_OscConfig+0x54e>
      while (__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) != RESET)
 8001f6c:	4b41      	ldr	r3, [pc, #260]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001f6e:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 8001f70:	f003 0302 	and.w	r3, r3, #2
 8001f74:	2b00      	cmp	r3, #0
 8001f76:	d1ee      	bne.n	8001f56 <HAL_RCC_OscConfig+0x3b2>
        }
      }
    }

    /* Restore clock configuration if changed */
    if (pwrclkchanged == SET)
 8001f78:	7dfb      	ldrb	r3, [r7, #23]
 8001f7a:	2b01      	cmp	r3, #1
 8001f7c:	d105      	bne.n	8001f8a <HAL_RCC_OscConfig+0x3e6>
    {
      __HAL_RCC_PWR_CLK_DISABLE();
 8001f7e:	4b3d      	ldr	r3, [pc, #244]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001f80:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 8001f82:	4a3c      	ldr	r2, [pc, #240]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001f84:	f023 5380 	bic.w	r3, r3, #268435456	; 0x10000000
 8001f88:	6413      	str	r3, [r2, #64]	; 0x40
    }
  }
  /*-------------------------------- PLL Configuration -----------------------*/
  /* Check the parameters */
  assert_param(IS_RCC_PLL(RCC_OscInitStruct->PLL.PLLState));
  if ((RCC_OscInitStruct->PLL.PLLState) != RCC_PLL_NONE)
 8001f8a:	687b      	ldr	r3, [r7, #4]
 8001f8c:	699b      	ldr	r3, [r3, #24]
 8001f8e:	2b00      	cmp	r3, #0
 8001f90:	f000 80ae 	beq.w	80020f0 <HAL_RCC_OscConfig+0x54c>
  {
    /* Check if the PLL is used as system clock or not */
    if (__HAL_RCC_GET_SYSCLK_SOURCE() != RCC_SYSCLKSOURCE_STATUS_PLLCLK)
 8001f94:	4b37      	ldr	r3, [pc, #220]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001f96:	689b      	ldr	r3, [r3, #8]
 8001f98:	f003 030c 	and.w	r3, r3, #12
 8001f9c:	2b08      	cmp	r3, #8
 8001f9e:	d06d      	beq.n	800207c <HAL_RCC_OscConfig+0x4d8>
    {
      if ((RCC_OscInitStruct->PLL.PLLState) == RCC_PLL_ON)
 8001fa0:	687b      	ldr	r3, [r7, #4]
 8001fa2:	699b      	ldr	r3, [r3, #24]
 8001fa4:	2b02      	cmp	r3, #2
 8001fa6:	d14b      	bne.n	8002040 <HAL_RCC_OscConfig+0x49c>
#if defined (RCC_PLLCFGR_PLLR)
        assert_param(IS_RCC_PLLR_VALUE(RCC_OscInitStruct->PLL.PLLR));
#endif

        /* Disable the main PLL. */
        __HAL_RCC_PLL_DISABLE();
 8001fa8:	4b32      	ldr	r3, [pc, #200]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001faa:	681b      	ldr	r3, [r3, #0]
 8001fac:	4a31      	ldr	r2, [pc, #196]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001fae:	f023 7380 	bic.w	r3, r3, #16777216	; 0x1000000
 8001fb2:	6013      	str	r3, [r2, #0]

        /* Get Start Tick*/
        tickstart = HAL_GetTick();
 8001fb4:	f7ff faa6 	bl	8001504 <HAL_GetTick>
 8001fb8:	6138      	str	r0, [r7, #16]

        /* Wait till PLL is ready */
        while (__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) != RESET)
 8001fba:	e008      	b.n	8001fce <HAL_RCC_OscConfig+0x42a>
        {
          if ((HAL_GetTick() - tickstart) > PLL_TIMEOUT_VALUE)
 8001fbc:	f7ff faa2 	bl	8001504 <HAL_GetTick>
 8001fc0:	4602      	mov	r2, r0
 8001fc2:	693b      	ldr	r3, [r7, #16]
 8001fc4:	1ad3      	subs	r3, r2, r3
 8001fc6:	2b02      	cmp	r3, #2
 8001fc8:	d901      	bls.n	8001fce <HAL_RCC_OscConfig+0x42a>
          {
            return HAL_TIMEOUT;
 8001fca:	2303      	movs	r3, #3
 8001fcc:	e091      	b.n	80020f2 <HAL_RCC_OscConfig+0x54e>
        while (__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) != RESET)
 8001fce:	4b29      	ldr	r3, [pc, #164]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8001fd0:	681b      	ldr	r3, [r3, #0]
 8001fd2:	f003 7300 	and.w	r3, r3, #33554432	; 0x2000000
 8001fd6:	2b00      	cmp	r3, #0
 8001fd8:	d1f0      	bne.n	8001fbc <HAL_RCC_OscConfig+0x418>
          }
        }

        /* Configure the main PLL clock source, multiplication and division factors. */
#if defined (RCC_PLLCFGR_PLLR)
        __HAL_RCC_PLL_CONFIG(RCC_OscInitStruct->PLL.PLLSource,
 8001fda:	687b      	ldr	r3, [r7, #4]
 8001fdc:	69da      	ldr	r2, [r3, #28]
 8001fde:	687b      	ldr	r3, [r7, #4]
 8001fe0:	6a1b      	ldr	r3, [r3, #32]
 8001fe2:	431a      	orrs	r2, r3
 8001fe4:	687b      	ldr	r3, [r7, #4]
 8001fe6:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8001fe8:	019b      	lsls	r3, r3, #6
 8001fea:	431a      	orrs	r2, r3
 8001fec:	687b      	ldr	r3, [r7, #4]
 8001fee:	6a9b      	ldr	r3, [r3, #40]	; 0x28
 8001ff0:	085b      	lsrs	r3, r3, #1
 8001ff2:	3b01      	subs	r3, #1
 8001ff4:	041b      	lsls	r3, r3, #16
 8001ff6:	431a      	orrs	r2, r3
 8001ff8:	687b      	ldr	r3, [r7, #4]
 8001ffa:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8001ffc:	061b      	lsls	r3, r3, #24
 8001ffe:	431a      	orrs	r2, r3
 8002000:	687b      	ldr	r3, [r7, #4]
 8002002:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8002004:	071b      	lsls	r3, r3, #28
 8002006:	491b      	ldr	r1, [pc, #108]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8002008:	4313      	orrs	r3, r2
 800200a:	604b      	str	r3, [r1, #4]
                             RCC_OscInitStruct->PLL.PLLP,
                             RCC_OscInitStruct->PLL.PLLQ);
#endif

        /* Enable the main PLL. */
        __HAL_RCC_PLL_ENABLE();
 800200c:	4b19      	ldr	r3, [pc, #100]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 800200e:	681b      	ldr	r3, [r3, #0]
 8002010:	4a18      	ldr	r2, [pc, #96]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8002012:	f043 7380 	orr.w	r3, r3, #16777216	; 0x1000000
 8002016:	6013      	str	r3, [r2, #0]

        /* Get Start Tick*/
        tickstart = HAL_GetTick();
 8002018:	f7ff fa74 	bl	8001504 <HAL_GetTick>
 800201c:	6138      	str	r0, [r7, #16]

        /* Wait till PLL is ready */
        while (__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) == RESET)
 800201e:	e008      	b.n	8002032 <HAL_RCC_OscConfig+0x48e>
        {
          if ((HAL_GetTick() - tickstart) > PLL_TIMEOUT_VALUE)
 8002020:	f7ff fa70 	bl	8001504 <HAL_GetTick>
 8002024:	4602      	mov	r2, r0
 8002026:	693b      	ldr	r3, [r7, #16]
 8002028:	1ad3      	subs	r3, r2, r3
 800202a:	2b02      	cmp	r3, #2
 800202c:	d901      	bls.n	8002032 <HAL_RCC_OscConfig+0x48e>
          {
            return HAL_TIMEOUT;
 800202e:	2303      	movs	r3, #3
 8002030:	e05f      	b.n	80020f2 <HAL_RCC_OscConfig+0x54e>
        while (__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) == RESET)
 8002032:	4b10      	ldr	r3, [pc, #64]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8002034:	681b      	ldr	r3, [r3, #0]
 8002036:	f003 7300 	and.w	r3, r3, #33554432	; 0x2000000
 800203a:	2b00      	cmp	r3, #0
 800203c:	d0f0      	beq.n	8002020 <HAL_RCC_OscConfig+0x47c>
 800203e:	e057      	b.n	80020f0 <HAL_RCC_OscConfig+0x54c>
        }
      }
      else
      {
        /* Disable the main PLL. */
        __HAL_RCC_PLL_DISABLE();
 8002040:	4b0c      	ldr	r3, [pc, #48]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8002042:	681b      	ldr	r3, [r3, #0]
 8002044:	4a0b      	ldr	r2, [pc, #44]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8002046:	f023 7380 	bic.w	r3, r3, #16777216	; 0x1000000
 800204a:	6013      	str	r3, [r2, #0]

        /* Get Start Tick*/
        tickstart = HAL_GetTick();
 800204c:	f7ff fa5a 	bl	8001504 <HAL_GetTick>
 8002050:	6138      	str	r0, [r7, #16]

        /* Wait till PLL is ready */
        while (__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) != RESET)
 8002052:	e008      	b.n	8002066 <HAL_RCC_OscConfig+0x4c2>
        {
          if ((HAL_GetTick() - tickstart) > PLL_TIMEOUT_VALUE)
 8002054:	f7ff fa56 	bl	8001504 <HAL_GetTick>
 8002058:	4602      	mov	r2, r0
 800205a:	693b      	ldr	r3, [r7, #16]
 800205c:	1ad3      	subs	r3, r2, r3
 800205e:	2b02      	cmp	r3, #2
 8002060:	d901      	bls.n	8002066 <HAL_RCC_OscConfig+0x4c2>
          {
            return HAL_TIMEOUT;
 8002062:	2303      	movs	r3, #3
 8002064:	e045      	b.n	80020f2 <HAL_RCC_OscConfig+0x54e>
        while (__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) != RESET)
 8002066:	4b03      	ldr	r3, [pc, #12]	; (8002074 <HAL_RCC_OscConfig+0x4d0>)
 8002068:	681b      	ldr	r3, [r3, #0]
 800206a:	f003 7300 	and.w	r3, r3, #33554432	; 0x2000000
 800206e:	2b00      	cmp	r3, #0
 8002070:	d1f0      	bne.n	8002054 <HAL_RCC_OscConfig+0x4b0>
 8002072:	e03d      	b.n	80020f0 <HAL_RCC_OscConfig+0x54c>
 8002074:	40023800 	.word	0x40023800
 8002078:	40007000 	.word	0x40007000
      }
    }
    else
    {
      /* Do not return HAL_ERROR if request repeats the current configuration */
      pll_config = RCC->PLLCFGR;
 800207c:	4b1f      	ldr	r3, [pc, #124]	; (80020fc <HAL_RCC_OscConfig+0x558>)
 800207e:	685b      	ldr	r3, [r3, #4]
 8002080:	60fb      	str	r3, [r7, #12]
#if defined (RCC_PLLCFGR_PLLR)
      if (((RCC_OscInitStruct->PLL.PLLState) == RCC_PLL_OFF) ||
 8002082:	687b      	ldr	r3, [r7, #4]
 8002084:	699b      	ldr	r3, [r3, #24]
 8002086:	2b01      	cmp	r3, #1
 8002088:	d030      	beq.n	80020ec <HAL_RCC_OscConfig+0x548>
          (READ_BIT(pll_config, RCC_PLLCFGR_PLLSRC) != RCC_OscInitStruct->PLL.PLLSource) ||
 800208a:	68fb      	ldr	r3, [r7, #12]
 800208c:	f403 0280 	and.w	r2, r3, #4194304	; 0x400000
 8002090:	687b      	ldr	r3, [r7, #4]
 8002092:	69db      	ldr	r3, [r3, #28]
      if (((RCC_OscInitStruct->PLL.PLLState) == RCC_PLL_OFF) ||
 8002094:	429a      	cmp	r2, r3
 8002096:	d129      	bne.n	80020ec <HAL_RCC_OscConfig+0x548>
          (READ_BIT(pll_config, RCC_PLLCFGR_PLLM) != RCC_OscInitStruct->PLL.PLLM) ||
 8002098:	68fb      	ldr	r3, [r7, #12]
 800209a:	f003 023f 	and.w	r2, r3, #63	; 0x3f
 800209e:	687b      	ldr	r3, [r7, #4]
 80020a0:	6a1b      	ldr	r3, [r3, #32]
          (READ_BIT(pll_config, RCC_PLLCFGR_PLLSRC) != RCC_OscInitStruct->PLL.PLLSource) ||
 80020a2:	429a      	cmp	r2, r3
 80020a4:	d122      	bne.n	80020ec <HAL_RCC_OscConfig+0x548>
          (READ_BIT(pll_config, RCC_PLLCFGR_PLLN) != (RCC_OscInitStruct->PLL.PLLN << RCC_PLLCFGR_PLLN_Pos)) ||
 80020a6:	68fa      	ldr	r2, [r7, #12]
 80020a8:	f647 73c0 	movw	r3, #32704	; 0x7fc0
 80020ac:	4013      	ands	r3, r2
 80020ae:	687a      	ldr	r2, [r7, #4]
 80020b0:	6a52      	ldr	r2, [r2, #36]	; 0x24
 80020b2:	0192      	lsls	r2, r2, #6
          (READ_BIT(pll_config, RCC_PLLCFGR_PLLM) != RCC_OscInitStruct->PLL.PLLM) ||
 80020b4:	4293      	cmp	r3, r2
 80020b6:	d119      	bne.n	80020ec <HAL_RCC_OscConfig+0x548>
          (READ_BIT(pll_config, RCC_PLLCFGR_PLLP) != ((((RCC_OscInitStruct->PLL.PLLP) >> 1U) - 1U) << RCC_PLLCFGR_PLLP_Pos)) ||
 80020b8:	68fb      	ldr	r3, [r7, #12]
 80020ba:	f403 3240 	and.w	r2, r3, #196608	; 0x30000
 80020be:	687b      	ldr	r3, [r7, #4]
 80020c0:	6a9b      	ldr	r3, [r3, #40]	; 0x28
 80020c2:	085b      	lsrs	r3, r3, #1
 80020c4:	3b01      	subs	r3, #1
 80020c6:	041b      	lsls	r3, r3, #16
          (READ_BIT(pll_config, RCC_PLLCFGR_PLLN) != (RCC_OscInitStruct->PLL.PLLN << RCC_PLLCFGR_PLLN_Pos)) ||
 80020c8:	429a      	cmp	r2, r3
 80020ca:	d10f      	bne.n	80020ec <HAL_RCC_OscConfig+0x548>
          (READ_BIT(pll_config, RCC_PLLCFGR_PLLQ) != (RCC_OscInitStruct->PLL.PLLQ << RCC_PLLCFGR_PLLQ_Pos)) ||
 80020cc:	68fb      	ldr	r3, [r7, #12]
 80020ce:	f003 6270 	and.w	r2, r3, #251658240	; 0xf000000
 80020d2:	687b      	ldr	r3, [r7, #4]
 80020d4:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 80020d6:	061b      	lsls	r3, r3, #24
          (READ_BIT(pll_config, RCC_PLLCFGR_PLLP) != ((((RCC_OscInitStruct->PLL.PLLP) >> 1U) - 1U) << RCC_PLLCFGR_PLLP_Pos)) ||
 80020d8:	429a      	cmp	r2, r3
 80020da:	d107      	bne.n	80020ec <HAL_RCC_OscConfig+0x548>
          (READ_BIT(pll_config, RCC_PLLCFGR_PLLR) != (RCC_OscInitStruct->PLL.PLLR << RCC_PLLCFGR_PLLR_Pos)))
 80020dc:	68fb      	ldr	r3, [r7, #12]
 80020de:	f003 42e0 	and.w	r2, r3, #1879048192	; 0x70000000
 80020e2:	687b      	ldr	r3, [r7, #4]
 80020e4:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 80020e6:	071b      	lsls	r3, r3, #28
          (READ_BIT(pll_config, RCC_PLLCFGR_PLLQ) != (RCC_OscInitStruct->PLL.PLLQ << RCC_PLLCFGR_PLLQ_Pos)) ||
 80020e8:	429a      	cmp	r2, r3
 80020ea:	d001      	beq.n	80020f0 <HAL_RCC_OscConfig+0x54c>
          (READ_BIT(pll_config, RCC_PLLCFGR_PLLN) != (RCC_OscInitStruct->PLL.PLLN << RCC_PLLCFGR_PLLN_Pos)) ||
          (READ_BIT(pll_config, RCC_PLLCFGR_PLLP) != ((((RCC_OscInitStruct->PLL.PLLP) >> 1U) - 1U) << RCC_PLLCFGR_PLLP_Pos)) ||
          (READ_BIT(pll_config, RCC_PLLCFGR_PLLQ) != (RCC_OscInitStruct->PLL.PLLQ << RCC_PLLCFGR_PLLQ_Pos)))
#endif
      {
        return HAL_ERROR;
 80020ec:	2301      	movs	r3, #1
 80020ee:	e000      	b.n	80020f2 <HAL_RCC_OscConfig+0x54e>
      }
    }
  }
  return HAL_OK;
 80020f0:	2300      	movs	r3, #0
}
 80020f2:	4618      	mov	r0, r3
 80020f4:	3718      	adds	r7, #24
 80020f6:	46bd      	mov	sp, r7
 80020f8:	bd80      	pop	{r7, pc}
 80020fa:	bf00      	nop
 80020fc:	40023800 	.word	0x40023800

08002100 <HAL_RCC_ClockConfig>:
  *         HPRE[3:0] bits to ensure that HCLK not exceed the maximum allowed frequency
  *         (for more details refer to section above "Initialization/de-initialization functions")
  * @retval None
  */
HAL_StatusTypeDef HAL_RCC_ClockConfig(RCC_ClkInitTypeDef  *RCC_ClkInitStruct, uint32_t FLatency)
{
 8002100:	b580      	push	{r7, lr}
 8002102:	b084      	sub	sp, #16
 8002104:	af00      	add	r7, sp, #0
 8002106:	6078      	str	r0, [r7, #4]
 8002108:	6039      	str	r1, [r7, #0]
  uint32_t tickstart = 0;
 800210a:	2300      	movs	r3, #0
 800210c:	60fb      	str	r3, [r7, #12]

  /* Check Null pointer */
  if (RCC_ClkInitStruct == NULL)
 800210e:	687b      	ldr	r3, [r7, #4]
 8002110:	2b00      	cmp	r3, #0
 8002112:	d101      	bne.n	8002118 <HAL_RCC_ClockConfig+0x18>
  {
    return HAL_ERROR;
 8002114:	2301      	movs	r3, #1
 8002116:	e0d0      	b.n	80022ba <HAL_RCC_ClockConfig+0x1ba>
  /* To correctly read data from FLASH memory, the number of wait states (LATENCY)
     must be correctly programmed according to the frequency of the CPU clock
     (HCLK) and the supply voltage of the device. */

  /* Increasing the CPU frequency */
  if (FLatency > __HAL_FLASH_GET_LATENCY())
 8002118:	4b6a      	ldr	r3, [pc, #424]	; (80022c4 <HAL_RCC_ClockConfig+0x1c4>)
 800211a:	681b      	ldr	r3, [r3, #0]
 800211c:	f003 030f 	and.w	r3, r3, #15
 8002120:	683a      	ldr	r2, [r7, #0]
 8002122:	429a      	cmp	r2, r3
 8002124:	d910      	bls.n	8002148 <HAL_RCC_ClockConfig+0x48>
  {
    /* Program the new number of wait states to the LATENCY bits in the FLASH_ACR register */
    __HAL_FLASH_SET_LATENCY(FLatency);
 8002126:	4b67      	ldr	r3, [pc, #412]	; (80022c4 <HAL_RCC_ClockConfig+0x1c4>)
 8002128:	681b      	ldr	r3, [r3, #0]
 800212a:	f023 020f 	bic.w	r2, r3, #15
 800212e:	4965      	ldr	r1, [pc, #404]	; (80022c4 <HAL_RCC_ClockConfig+0x1c4>)
 8002130:	683b      	ldr	r3, [r7, #0]
 8002132:	4313      	orrs	r3, r2
 8002134:	600b      	str	r3, [r1, #0]

    /* Check that the new number of wait states is taken into account to access the Flash
    memory by reading the FLASH_ACR register */
    if (__HAL_FLASH_GET_LATENCY() != FLatency)
 8002136:	4b63      	ldr	r3, [pc, #396]	; (80022c4 <HAL_RCC_ClockConfig+0x1c4>)
 8002138:	681b      	ldr	r3, [r3, #0]
 800213a:	f003 030f 	and.w	r3, r3, #15
 800213e:	683a      	ldr	r2, [r7, #0]
 8002140:	429a      	cmp	r2, r3
 8002142:	d001      	beq.n	8002148 <HAL_RCC_ClockConfig+0x48>
    {
      return HAL_ERROR;
 8002144:	2301      	movs	r3, #1
 8002146:	e0b8      	b.n	80022ba <HAL_RCC_ClockConfig+0x1ba>
    }
  }

  /*-------------------------- HCLK Configuration --------------------------*/
  if (((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_HCLK) == RCC_CLOCKTYPE_HCLK)
 8002148:	687b      	ldr	r3, [r7, #4]
 800214a:	681b      	ldr	r3, [r3, #0]
 800214c:	f003 0302 	and.w	r3, r3, #2
 8002150:	2b00      	cmp	r3, #0
 8002152:	d020      	beq.n	8002196 <HAL_RCC_ClockConfig+0x96>
  {
    /* Set the highest APBx dividers in order to ensure that we do not go through
       a non-spec phase whatever we decrease or increase HCLK. */
    if (((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_PCLK1) == RCC_CLOCKTYPE_PCLK1)
 8002154:	687b      	ldr	r3, [r7, #4]
 8002156:	681b      	ldr	r3, [r3, #0]
 8002158:	f003 0304 	and.w	r3, r3, #4
 800215c:	2b00      	cmp	r3, #0
 800215e:	d005      	beq.n	800216c <HAL_RCC_ClockConfig+0x6c>
    {
      MODIFY_REG(RCC->CFGR, RCC_CFGR_PPRE1, RCC_HCLK_DIV16);
 8002160:	4b59      	ldr	r3, [pc, #356]	; (80022c8 <HAL_RCC_ClockConfig+0x1c8>)
 8002162:	689b      	ldr	r3, [r3, #8]
 8002164:	4a58      	ldr	r2, [pc, #352]	; (80022c8 <HAL_RCC_ClockConfig+0x1c8>)
 8002166:	f443 53e0 	orr.w	r3, r3, #7168	; 0x1c00
 800216a:	6093      	str	r3, [r2, #8]
    }

    if (((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_PCLK2) == RCC_CLOCKTYPE_PCLK2)
 800216c:	687b      	ldr	r3, [r7, #4]
 800216e:	681b      	ldr	r3, [r3, #0]
 8002170:	f003 0308 	and.w	r3, r3, #8
 8002174:	2b00      	cmp	r3, #0
 8002176:	d005      	beq.n	8002184 <HAL_RCC_ClockConfig+0x84>
    {
      MODIFY_REG(RCC->CFGR, RCC_CFGR_PPRE2, (RCC_HCLK_DIV16 << 3));
 8002178:	4b53      	ldr	r3, [pc, #332]	; (80022c8 <HAL_RCC_ClockConfig+0x1c8>)
 800217a:	689b      	ldr	r3, [r3, #8]
 800217c:	4a52      	ldr	r2, [pc, #328]	; (80022c8 <HAL_RCC_ClockConfig+0x1c8>)
 800217e:	f443 4360 	orr.w	r3, r3, #57344	; 0xe000
 8002182:	6093      	str	r3, [r2, #8]
    }

    /* Set the new HCLK clock divider */
    assert_param(IS_RCC_HCLK(RCC_ClkInitStruct->AHBCLKDivider));
    MODIFY_REG(RCC->CFGR, RCC_CFGR_HPRE, RCC_ClkInitStruct->AHBCLKDivider);
 8002184:	4b50      	ldr	r3, [pc, #320]	; (80022c8 <HAL_RCC_ClockConfig+0x1c8>)
 8002186:	689b      	ldr	r3, [r3, #8]
 8002188:	f023 02f0 	bic.w	r2, r3, #240	; 0xf0
 800218c:	687b      	ldr	r3, [r7, #4]
 800218e:	689b      	ldr	r3, [r3, #8]
 8002190:	494d      	ldr	r1, [pc, #308]	; (80022c8 <HAL_RCC_ClockConfig+0x1c8>)
 8002192:	4313      	orrs	r3, r2
 8002194:	608b      	str	r3, [r1, #8]
  }

  /*------------------------- SYSCLK Configuration ---------------------------*/
  if (((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_SYSCLK) == RCC_CLOCKTYPE_SYSCLK)
 8002196:	687b      	ldr	r3, [r7, #4]
 8002198:	681b      	ldr	r3, [r3, #0]
 800219a:	f003 0301 	and.w	r3, r3, #1
 800219e:	2b00      	cmp	r3, #0
 80021a0:	d040      	beq.n	8002224 <HAL_RCC_ClockConfig+0x124>
  {
    assert_param(IS_RCC_SYSCLKSOURCE(RCC_ClkInitStruct->SYSCLKSource));

    /* HSE is selected as System Clock Source */
    if (RCC_ClkInitStruct->SYSCLKSource == RCC_SYSCLKSOURCE_HSE)
 80021a2:	687b      	ldr	r3, [r7, #4]
 80021a4:	685b      	ldr	r3, [r3, #4]
 80021a6:	2b01      	cmp	r3, #1
 80021a8:	d107      	bne.n	80021ba <HAL_RCC_ClockConfig+0xba>
    {
      /* Check the HSE ready flag */
      if (__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) == RESET)
 80021aa:	4b47      	ldr	r3, [pc, #284]	; (80022c8 <HAL_RCC_ClockConfig+0x1c8>)
 80021ac:	681b      	ldr	r3, [r3, #0]
 80021ae:	f403 3300 	and.w	r3, r3, #131072	; 0x20000
 80021b2:	2b00      	cmp	r3, #0
 80021b4:	d115      	bne.n	80021e2 <HAL_RCC_ClockConfig+0xe2>
      {
        return HAL_ERROR;
 80021b6:	2301      	movs	r3, #1
 80021b8:	e07f      	b.n	80022ba <HAL_RCC_ClockConfig+0x1ba>
      }
    }
    /* PLL is selected as System Clock Source */
    else if (RCC_ClkInitStruct->SYSCLKSource == RCC_SYSCLKSOURCE_PLLCLK)
 80021ba:	687b      	ldr	r3, [r7, #4]
 80021bc:	685b      	ldr	r3, [r3, #4]
 80021be:	2b02      	cmp	r3, #2
 80021c0:	d107      	bne.n	80021d2 <HAL_RCC_ClockConfig+0xd2>
    {
      /* Check the PLL ready flag */
      if (__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) == RESET)
 80021c2:	4b41      	ldr	r3, [pc, #260]	; (80022c8 <HAL_RCC_ClockConfig+0x1c8>)
 80021c4:	681b      	ldr	r3, [r3, #0]
 80021c6:	f003 7300 	and.w	r3, r3, #33554432	; 0x2000000
 80021ca:	2b00      	cmp	r3, #0
 80021cc:	d109      	bne.n	80021e2 <HAL_RCC_ClockConfig+0xe2>
      {
        return HAL_ERROR;
 80021ce:	2301      	movs	r3, #1
 80021d0:	e073      	b.n	80022ba <HAL_RCC_ClockConfig+0x1ba>
    }
    /* HSI is selected as System Clock Source */
    else
    {
      /* Check the HSI ready flag */
      if (__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) == RESET)
 80021d2:	4b3d      	ldr	r3, [pc, #244]	; (80022c8 <HAL_RCC_ClockConfig+0x1c8>)
 80021d4:	681b      	ldr	r3, [r3, #0]
 80021d6:	f003 0302 	and.w	r3, r3, #2
 80021da:	2b00      	cmp	r3, #0
 80021dc:	d101      	bne.n	80021e2 <HAL_RCC_ClockConfig+0xe2>
      {
        return HAL_ERROR;
 80021de:	2301      	movs	r3, #1
 80021e0:	e06b      	b.n	80022ba <HAL_RCC_ClockConfig+0x1ba>
      }
    }

    __HAL_RCC_SYSCLK_CONFIG(RCC_ClkInitStruct->SYSCLKSource);
 80021e2:	4b39      	ldr	r3, [pc, #228]	; (80022c8 <HAL_RCC_ClockConfig+0x1c8>)
 80021e4:	689b      	ldr	r3, [r3, #8]
 80021e6:	f023 0203 	bic.w	r2, r3, #3
 80021ea:	687b      	ldr	r3, [r7, #4]
 80021ec:	685b      	ldr	r3, [r3, #4]
 80021ee:	4936      	ldr	r1, [pc, #216]	; (80022c8 <HAL_RCC_ClockConfig+0x1c8>)
 80021f0:	4313      	orrs	r3, r2
 80021f2:	608b      	str	r3, [r1, #8]

    /* Get Start Tick*/
    tickstart = HAL_GetTick();
 80021f4:	f7ff f986 	bl	8001504 <HAL_GetTick>
 80021f8:	60f8      	str	r0, [r7, #12]

    while (__HAL_RCC_GET_SYSCLK_SOURCE() != (RCC_ClkInitStruct->SYSCLKSource << RCC_CFGR_SWS_Pos))
 80021fa:	e00a      	b.n	8002212 <HAL_RCC_ClockConfig+0x112>
    {
      if ((HAL_GetTick() - tickstart) > CLOCKSWITCH_TIMEOUT_VALUE)
 80021fc:	f7ff f982 	bl	8001504 <HAL_GetTick>
 8002200:	4602      	mov	r2, r0
 8002202:	68fb      	ldr	r3, [r7, #12]
 8002204:	1ad3      	subs	r3, r2, r3
 8002206:	f241 3288 	movw	r2, #5000	; 0x1388
 800220a:	4293      	cmp	r3, r2
 800220c:	d901      	bls.n	8002212 <HAL_RCC_ClockConfig+0x112>
      {
        return HAL_TIMEOUT;
 800220e:	2303      	movs	r3, #3
 8002210:	e053      	b.n	80022ba <HAL_RCC_ClockConfig+0x1ba>
    while (__HAL_RCC_GET_SYSCLK_SOURCE() != (RCC_ClkInitStruct->SYSCLKSource << RCC_CFGR_SWS_Pos))
 8002212:	4b2d      	ldr	r3, [pc, #180]	; (80022c8 <HAL_RCC_ClockConfig+0x1c8>)
 8002214:	689b      	ldr	r3, [r3, #8]
 8002216:	f003 020c 	and.w	r2, r3, #12
 800221a:	687b      	ldr	r3, [r7, #4]
 800221c:	685b      	ldr	r3, [r3, #4]
 800221e:	009b      	lsls	r3, r3, #2
 8002220:	429a      	cmp	r2, r3
 8002222:	d1eb      	bne.n	80021fc <HAL_RCC_ClockConfig+0xfc>
      }
    }
  }

  /* Decreasing the number of wait states because of lower CPU frequency */
  if (FLatency < __HAL_FLASH_GET_LATENCY())
 8002224:	4b27      	ldr	r3, [pc, #156]	; (80022c4 <HAL_RCC_ClockConfig+0x1c4>)
 8002226:	681b      	ldr	r3, [r3, #0]
 8002228:	f003 030f 	and.w	r3, r3, #15
 800222c:	683a      	ldr	r2, [r7, #0]
 800222e:	429a      	cmp	r2, r3
 8002230:	d210      	bcs.n	8002254 <HAL_RCC_ClockConfig+0x154>
  {
    /* Program the new number of wait states to the LATENCY bits in the FLASH_ACR register */
    __HAL_FLASH_SET_LATENCY(FLatency);
 8002232:	4b24      	ldr	r3, [pc, #144]	; (80022c4 <HAL_RCC_ClockConfig+0x1c4>)
 8002234:	681b      	ldr	r3, [r3, #0]
 8002236:	f023 020f 	bic.w	r2, r3, #15
 800223a:	4922      	ldr	r1, [pc, #136]	; (80022c4 <HAL_RCC_ClockConfig+0x1c4>)
 800223c:	683b      	ldr	r3, [r7, #0]
 800223e:	4313      	orrs	r3, r2
 8002240:	600b      	str	r3, [r1, #0]

    /* Check that the new number of wait states is taken into account to access the Flash
    memory by reading the FLASH_ACR register */
    if (__HAL_FLASH_GET_LATENCY() != FLatency)
 8002242:	4b20      	ldr	r3, [pc, #128]	; (80022c4 <HAL_RCC_ClockConfig+0x1c4>)
 8002244:	681b      	ldr	r3, [r3, #0]
 8002246:	f003 030f 	and.w	r3, r3, #15
 800224a:	683a      	ldr	r2, [r7, #0]
 800224c:	429a      	cmp	r2, r3
 800224e:	d001      	beq.n	8002254 <HAL_RCC_ClockConfig+0x154>
    {
      return HAL_ERROR;
 8002250:	2301      	movs	r3, #1
 8002252:	e032      	b.n	80022ba <HAL_RCC_ClockConfig+0x1ba>
    }
  }

  /*-------------------------- PCLK1 Configuration ---------------------------*/
  if (((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_PCLK1) == RCC_CLOCKTYPE_PCLK1)
 8002254:	687b      	ldr	r3, [r7, #4]
 8002256:	681b      	ldr	r3, [r3, #0]
 8002258:	f003 0304 	and.w	r3, r3, #4
 800225c:	2b00      	cmp	r3, #0
 800225e:	d008      	beq.n	8002272 <HAL_RCC_ClockConfig+0x172>
  {
    assert_param(IS_RCC_PCLK(RCC_ClkInitStruct->APB1CLKDivider));
    MODIFY_REG(RCC->CFGR, RCC_CFGR_PPRE1, RCC_ClkInitStruct->APB1CLKDivider);
 8002260:	4b19      	ldr	r3, [pc, #100]	; (80022c8 <HAL_RCC_ClockConfig+0x1c8>)
 8002262:	689b      	ldr	r3, [r3, #8]
 8002264:	f423 52e0 	bic.w	r2, r3, #7168	; 0x1c00
 8002268:	687b      	ldr	r3, [r7, #4]
 800226a:	68db      	ldr	r3, [r3, #12]
 800226c:	4916      	ldr	r1, [pc, #88]	; (80022c8 <HAL_RCC_ClockConfig+0x1c8>)
 800226e:	4313      	orrs	r3, r2
 8002270:	608b      	str	r3, [r1, #8]
  }

  /*-------------------------- PCLK2 Configuration ---------------------------*/
  if (((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_PCLK2) == RCC_CLOCKTYPE_PCLK2)
 8002272:	687b      	ldr	r3, [r7, #4]
 8002274:	681b      	ldr	r3, [r3, #0]
 8002276:	f003 0308 	and.w	r3, r3, #8
 800227a:	2b00      	cmp	r3, #0
 800227c:	d009      	beq.n	8002292 <HAL_RCC_ClockConfig+0x192>
  {
    assert_param(IS_RCC_PCLK(RCC_ClkInitStruct->APB2CLKDivider));
    MODIFY_REG(RCC->CFGR, RCC_CFGR_PPRE2, ((RCC_ClkInitStruct->APB2CLKDivider) << 3));
 800227e:	4b12      	ldr	r3, [pc, #72]	; (80022c8 <HAL_RCC_ClockConfig+0x1c8>)
 8002280:	689b      	ldr	r3, [r3, #8]
 8002282:	f423 4260 	bic.w	r2, r3, #57344	; 0xe000
 8002286:	687b      	ldr	r3, [r7, #4]
 8002288:	691b      	ldr	r3, [r3, #16]
 800228a:	00db      	lsls	r3, r3, #3
 800228c:	490e      	ldr	r1, [pc, #56]	; (80022c8 <HAL_RCC_ClockConfig+0x1c8>)
 800228e:	4313      	orrs	r3, r2
 8002290:	608b      	str	r3, [r1, #8]
  }

  /* Update the SystemCoreClock global variable */
  SystemCoreClock = HAL_RCC_GetSysClockFreq() >> AHBPrescTable[(RCC->CFGR & RCC_CFGR_HPRE) >> RCC_CFGR_HPRE_Pos];
 8002292:	f000 f821 	bl	80022d8 <HAL_RCC_GetSysClockFreq>
 8002296:	4601      	mov	r1, r0
 8002298:	4b0b      	ldr	r3, [pc, #44]	; (80022c8 <HAL_RCC_ClockConfig+0x1c8>)
 800229a:	689b      	ldr	r3, [r3, #8]
 800229c:	091b      	lsrs	r3, r3, #4
 800229e:	f003 030f 	and.w	r3, r3, #15
 80022a2:	4a0a      	ldr	r2, [pc, #40]	; (80022cc <HAL_RCC_ClockConfig+0x1cc>)
 80022a4:	5cd3      	ldrb	r3, [r2, r3]
 80022a6:	fa21 f303 	lsr.w	r3, r1, r3
 80022aa:	4a09      	ldr	r2, [pc, #36]	; (80022d0 <HAL_RCC_ClockConfig+0x1d0>)
 80022ac:	6013      	str	r3, [r2, #0]

  /* Configure the source of time base considering new system clocks settings*/
  HAL_InitTick(uwTickPrio);
 80022ae:	4b09      	ldr	r3, [pc, #36]	; (80022d4 <HAL_RCC_ClockConfig+0x1d4>)
 80022b0:	681b      	ldr	r3, [r3, #0]
 80022b2:	4618      	mov	r0, r3
 80022b4:	f7ff f8e2 	bl	800147c <HAL_InitTick>

  return HAL_OK;
 80022b8:	2300      	movs	r3, #0
}
 80022ba:	4618      	mov	r0, r3
 80022bc:	3710      	adds	r7, #16
 80022be:	46bd      	mov	sp, r7
 80022c0:	bd80      	pop	{r7, pc}
 80022c2:	bf00      	nop
 80022c4:	40023c00 	.word	0x40023c00
 80022c8:	40023800 	.word	0x40023800
 80022cc:	0802e464 	.word	0x0802e464
 80022d0:	20000000 	.word	0x20000000
 80022d4:	20000004 	.word	0x20000004

080022d8 <HAL_RCC_GetSysClockFreq>:
  *
  *
  * @retval SYSCLK frequency
  */
uint32_t HAL_RCC_GetSysClockFreq(void)
{
 80022d8:	b5f0      	push	{r4, r5, r6, r7, lr}
 80022da:	b085      	sub	sp, #20
 80022dc:	af00      	add	r7, sp, #0
  uint32_t pllm = 0, pllvco = 0, pllp = 0;
 80022de:	2300      	movs	r3, #0
 80022e0:	607b      	str	r3, [r7, #4]
 80022e2:	2300      	movs	r3, #0
 80022e4:	60fb      	str	r3, [r7, #12]
 80022e6:	2300      	movs	r3, #0
 80022e8:	603b      	str	r3, [r7, #0]
  uint32_t sysclockfreq = 0;
 80022ea:	2300      	movs	r3, #0
 80022ec:	60bb      	str	r3, [r7, #8]

  /* Get SYSCLK source -------------------------------------------------------*/
  switch (RCC->CFGR & RCC_CFGR_SWS)
 80022ee:	4b63      	ldr	r3, [pc, #396]	; (800247c <HAL_RCC_GetSysClockFreq+0x1a4>)
 80022f0:	689b      	ldr	r3, [r3, #8]
 80022f2:	f003 030c 	and.w	r3, r3, #12
 80022f6:	2b04      	cmp	r3, #4
 80022f8:	d007      	beq.n	800230a <HAL_RCC_GetSysClockFreq+0x32>
 80022fa:	2b08      	cmp	r3, #8
 80022fc:	d008      	beq.n	8002310 <HAL_RCC_GetSysClockFreq+0x38>
 80022fe:	2b00      	cmp	r3, #0
 8002300:	f040 80b4 	bne.w	800246c <HAL_RCC_GetSysClockFreq+0x194>
  {
    case RCC_SYSCLKSOURCE_STATUS_HSI:  /* HSI used as system clock source */
    {
      sysclockfreq = HSI_VALUE;
 8002304:	4b5e      	ldr	r3, [pc, #376]	; (8002480 <HAL_RCC_GetSysClockFreq+0x1a8>)
 8002306:	60bb      	str	r3, [r7, #8]
      break;
 8002308:	e0b3      	b.n	8002472 <HAL_RCC_GetSysClockFreq+0x19a>
    }
    case RCC_SYSCLKSOURCE_STATUS_HSE:  /* HSE used as system clock  source */
    {
      sysclockfreq = HSE_VALUE;
 800230a:	4b5e      	ldr	r3, [pc, #376]	; (8002484 <HAL_RCC_GetSysClockFreq+0x1ac>)
 800230c:	60bb      	str	r3, [r7, #8]
      break;
 800230e:	e0b0      	b.n	8002472 <HAL_RCC_GetSysClockFreq+0x19a>
    }
    case RCC_SYSCLKSOURCE_STATUS_PLLCLK:  /* PLL used as system clock  source */
    {
      /* PLL_VCO = (HSE_VALUE or HSI_VALUE / PLLM) * PLLN
      SYSCLK = PLL_VCO / PLLP */
      pllm = RCC->PLLCFGR & RCC_PLLCFGR_PLLM;
 8002310:	4b5a      	ldr	r3, [pc, #360]	; (800247c <HAL_RCC_GetSysClockFreq+0x1a4>)
 8002312:	685b      	ldr	r3, [r3, #4]
 8002314:	f003 033f 	and.w	r3, r3, #63	; 0x3f
 8002318:	607b      	str	r3, [r7, #4]
      if (__HAL_RCC_GET_PLL_OSCSOURCE() != RCC_PLLCFGR_PLLSRC_HSI)
 800231a:	4b58      	ldr	r3, [pc, #352]	; (800247c <HAL_RCC_GetSysClockFreq+0x1a4>)
 800231c:	685b      	ldr	r3, [r3, #4]
 800231e:	f403 0380 	and.w	r3, r3, #4194304	; 0x400000
 8002322:	2b00      	cmp	r3, #0
 8002324:	d04a      	beq.n	80023bc <HAL_RCC_GetSysClockFreq+0xe4>
      {
        /* HSE used as PLL clock source */
        pllvco = (uint32_t)((((uint64_t) HSE_VALUE * ((uint64_t)((RCC->PLLCFGR & RCC_PLLCFGR_PLLN) >> RCC_PLLCFGR_PLLN_Pos)))) / (uint64_t)pllm);
 8002326:	4b55      	ldr	r3, [pc, #340]	; (800247c <HAL_RCC_GetSysClockFreq+0x1a4>)
 8002328:	685b      	ldr	r3, [r3, #4]
 800232a:	099b      	lsrs	r3, r3, #6
 800232c:	f04f 0400 	mov.w	r4, #0
 8002330:	f240 11ff 	movw	r1, #511	; 0x1ff
 8002334:	f04f 0200 	mov.w	r2, #0
 8002338:	ea03 0501 	and.w	r5, r3, r1
 800233c:	ea04 0602 	and.w	r6, r4, r2
 8002340:	4629      	mov	r1, r5
 8002342:	4632      	mov	r2, r6
 8002344:	f04f 0300 	mov.w	r3, #0
 8002348:	f04f 0400 	mov.w	r4, #0
 800234c:	0154      	lsls	r4, r2, #5
 800234e:	ea44 64d1 	orr.w	r4, r4, r1, lsr #27
 8002352:	014b      	lsls	r3, r1, #5
 8002354:	4619      	mov	r1, r3
 8002356:	4622      	mov	r2, r4
 8002358:	1b49      	subs	r1, r1, r5
 800235a:	eb62 0206 	sbc.w	r2, r2, r6
 800235e:	f04f 0300 	mov.w	r3, #0
 8002362:	f04f 0400 	mov.w	r4, #0
 8002366:	0194      	lsls	r4, r2, #6
 8002368:	ea44 6491 	orr.w	r4, r4, r1, lsr #26
 800236c:	018b      	lsls	r3, r1, #6
 800236e:	1a5b      	subs	r3, r3, r1
 8002370:	eb64 0402 	sbc.w	r4, r4, r2
 8002374:	f04f 0100 	mov.w	r1, #0
 8002378:	f04f 0200 	mov.w	r2, #0
 800237c:	00e2      	lsls	r2, r4, #3
 800237e:	ea42 7253 	orr.w	r2, r2, r3, lsr #29
 8002382:	00d9      	lsls	r1, r3, #3
 8002384:	460b      	mov	r3, r1
 8002386:	4614      	mov	r4, r2
 8002388:	195b      	adds	r3, r3, r5
 800238a:	eb44 0406 	adc.w	r4, r4, r6
 800238e:	f04f 0100 	mov.w	r1, #0
 8002392:	f04f 0200 	mov.w	r2, #0
 8002396:	0262      	lsls	r2, r4, #9
 8002398:	ea42 52d3 	orr.w	r2, r2, r3, lsr #23
 800239c:	0259      	lsls	r1, r3, #9
 800239e:	460b      	mov	r3, r1
 80023a0:	4614      	mov	r4, r2
 80023a2:	4618      	mov	r0, r3
 80023a4:	4621      	mov	r1, r4
 80023a6:	687b      	ldr	r3, [r7, #4]
 80023a8:	f04f 0400 	mov.w	r4, #0
 80023ac:	461a      	mov	r2, r3
 80023ae:	4623      	mov	r3, r4
 80023b0:	f7fd ff9e 	bl	80002f0 <__aeabi_uldivmod>
 80023b4:	4603      	mov	r3, r0
 80023b6:	460c      	mov	r4, r1
 80023b8:	60fb      	str	r3, [r7, #12]
 80023ba:	e049      	b.n	8002450 <HAL_RCC_GetSysClockFreq+0x178>
      }
      else
      {
        /* HSI used as PLL clock source */
        pllvco = (uint32_t)((((uint64_t) HSI_VALUE * ((uint64_t)((RCC->PLLCFGR & RCC_PLLCFGR_PLLN) >> RCC_PLLCFGR_PLLN_Pos)))) / (uint64_t)pllm);
 80023bc:	4b2f      	ldr	r3, [pc, #188]	; (800247c <HAL_RCC_GetSysClockFreq+0x1a4>)
 80023be:	685b      	ldr	r3, [r3, #4]
 80023c0:	099b      	lsrs	r3, r3, #6
 80023c2:	f04f 0400 	mov.w	r4, #0
 80023c6:	f240 11ff 	movw	r1, #511	; 0x1ff
 80023ca:	f04f 0200 	mov.w	r2, #0
 80023ce:	ea03 0501 	and.w	r5, r3, r1
 80023d2:	ea04 0602 	and.w	r6, r4, r2
 80023d6:	4629      	mov	r1, r5
 80023d8:	4632      	mov	r2, r6
 80023da:	f04f 0300 	mov.w	r3, #0
 80023de:	f04f 0400 	mov.w	r4, #0
 80023e2:	0154      	lsls	r4, r2, #5
 80023e4:	ea44 64d1 	orr.w	r4, r4, r1, lsr #27
 80023e8:	014b      	lsls	r3, r1, #5
 80023ea:	4619      	mov	r1, r3
 80023ec:	4622      	mov	r2, r4
 80023ee:	1b49      	subs	r1, r1, r5
 80023f0:	eb62 0206 	sbc.w	r2, r2, r6
 80023f4:	f04f 0300 	mov.w	r3, #0
 80023f8:	f04f 0400 	mov.w	r4, #0
 80023fc:	0194      	lsls	r4, r2, #6
 80023fe:	ea44 6491 	orr.w	r4, r4, r1, lsr #26
 8002402:	018b      	lsls	r3, r1, #6
 8002404:	1a5b      	subs	r3, r3, r1
 8002406:	eb64 0402 	sbc.w	r4, r4, r2
 800240a:	f04f 0100 	mov.w	r1, #0
 800240e:	f04f 0200 	mov.w	r2, #0
 8002412:	00e2      	lsls	r2, r4, #3
 8002414:	ea42 7253 	orr.w	r2, r2, r3, lsr #29
 8002418:	00d9      	lsls	r1, r3, #3
 800241a:	460b      	mov	r3, r1
 800241c:	4614      	mov	r4, r2
 800241e:	195b      	adds	r3, r3, r5
 8002420:	eb44 0406 	adc.w	r4, r4, r6
 8002424:	f04f 0100 	mov.w	r1, #0
 8002428:	f04f 0200 	mov.w	r2, #0
 800242c:	02a2      	lsls	r2, r4, #10
 800242e:	ea42 5293 	orr.w	r2, r2, r3, lsr #22
 8002432:	0299      	lsls	r1, r3, #10
 8002434:	460b      	mov	r3, r1
 8002436:	4614      	mov	r4, r2
 8002438:	4618      	mov	r0, r3
 800243a:	4621      	mov	r1, r4
 800243c:	687b      	ldr	r3, [r7, #4]
 800243e:	f04f 0400 	mov.w	r4, #0
 8002442:	461a      	mov	r2, r3
 8002444:	4623      	mov	r3, r4
 8002446:	f7fd ff53 	bl	80002f0 <__aeabi_uldivmod>
 800244a:	4603      	mov	r3, r0
 800244c:	460c      	mov	r4, r1
 800244e:	60fb      	str	r3, [r7, #12]
      }
      pllp = ((((RCC->PLLCFGR & RCC_PLLCFGR_PLLP) >> RCC_PLLCFGR_PLLP_Pos) + 1) * 2);
 8002450:	4b0a      	ldr	r3, [pc, #40]	; (800247c <HAL_RCC_GetSysClockFreq+0x1a4>)
 8002452:	685b      	ldr	r3, [r3, #4]
 8002454:	0c1b      	lsrs	r3, r3, #16
 8002456:	f003 0303 	and.w	r3, r3, #3
 800245a:	3301      	adds	r3, #1
 800245c:	005b      	lsls	r3, r3, #1
 800245e:	603b      	str	r3, [r7, #0]

      sysclockfreq = pllvco / pllp;
 8002460:	68fa      	ldr	r2, [r7, #12]
 8002462:	683b      	ldr	r3, [r7, #0]
 8002464:	fbb2 f3f3 	udiv	r3, r2, r3
 8002468:	60bb      	str	r3, [r7, #8]
      break;
 800246a:	e002      	b.n	8002472 <HAL_RCC_GetSysClockFreq+0x19a>
    }
    default:
    {
      sysclockfreq = HSI_VALUE;
 800246c:	4b04      	ldr	r3, [pc, #16]	; (8002480 <HAL_RCC_GetSysClockFreq+0x1a8>)
 800246e:	60bb      	str	r3, [r7, #8]
      break;
 8002470:	bf00      	nop
    }
  }
  return sysclockfreq;
 8002472:	68bb      	ldr	r3, [r7, #8]
}
 8002474:	4618      	mov	r0, r3
 8002476:	3714      	adds	r7, #20
 8002478:	46bd      	mov	sp, r7
 800247a:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800247c:	40023800 	.word	0x40023800
 8002480:	00f42400 	.word	0x00f42400
 8002484:	007a1200 	.word	0x007a1200

08002488 <HAL_RCC_GetHCLKFreq>:
  *         right HCLK value. Otherwise, any configuration based on this function will be incorrect.
  * @note   The SystemCoreClock CMSIS variable is used to store System Clock Frequency.
  * @retval HCLK frequency
  */
uint32_t HAL_RCC_GetHCLKFreq(void)
{
 8002488:	b480      	push	{r7}
 800248a:	af00      	add	r7, sp, #0
  return SystemCoreClock;
 800248c:	4b03      	ldr	r3, [pc, #12]	; (800249c <HAL_RCC_GetHCLKFreq+0x14>)
 800248e:	681b      	ldr	r3, [r3, #0]
}
 8002490:	4618      	mov	r0, r3
 8002492:	46bd      	mov	sp, r7
 8002494:	f85d 7b04 	ldr.w	r7, [sp], #4
 8002498:	4770      	bx	lr
 800249a:	bf00      	nop
 800249c:	20000000 	.word	0x20000000

080024a0 <HAL_RCC_GetPCLK1Freq>:
  * @note   Each time PCLK1 changes, this function must be called to update the
  *         right PCLK1 value. Otherwise, any configuration based on this function will be incorrect.
  * @retval PCLK1 frequency
  */
uint32_t HAL_RCC_GetPCLK1Freq(void)
{
 80024a0:	b580      	push	{r7, lr}
 80024a2:	af00      	add	r7, sp, #0
  /* Get HCLK source and Compute PCLK1 frequency ---------------------------*/
  return (HAL_RCC_GetHCLKFreq() >> APBPrescTable[(RCC->CFGR & RCC_CFGR_PPRE1) >> RCC_CFGR_PPRE1_Pos]);
 80024a4:	f7ff fff0 	bl	8002488 <HAL_RCC_GetHCLKFreq>
 80024a8:	4601      	mov	r1, r0
 80024aa:	4b05      	ldr	r3, [pc, #20]	; (80024c0 <HAL_RCC_GetPCLK1Freq+0x20>)
 80024ac:	689b      	ldr	r3, [r3, #8]
 80024ae:	0a9b      	lsrs	r3, r3, #10
 80024b0:	f003 0307 	and.w	r3, r3, #7
 80024b4:	4a03      	ldr	r2, [pc, #12]	; (80024c4 <HAL_RCC_GetPCLK1Freq+0x24>)
 80024b6:	5cd3      	ldrb	r3, [r2, r3]
 80024b8:	fa21 f303 	lsr.w	r3, r1, r3
}
 80024bc:	4618      	mov	r0, r3
 80024be:	bd80      	pop	{r7, pc}
 80024c0:	40023800 	.word	0x40023800
 80024c4:	0802e474 	.word	0x0802e474

080024c8 <HAL_RCC_GetPCLK2Freq>:
  * @note   Each time PCLK2 changes, this function must be called to update the
  *         right PCLK2 value. Otherwise, any configuration based on this function will be incorrect.
  * @retval PCLK2 frequency
  */
uint32_t HAL_RCC_GetPCLK2Freq(void)
{
 80024c8:	b580      	push	{r7, lr}
 80024ca:	af00      	add	r7, sp, #0
  /* Get HCLK source and Compute PCLK2 frequency ---------------------------*/
  return (HAL_RCC_GetHCLKFreq() >> APBPrescTable[(RCC->CFGR & RCC_CFGR_PPRE2) >> RCC_CFGR_PPRE2_Pos]);
 80024cc:	f7ff ffdc 	bl	8002488 <HAL_RCC_GetHCLKFreq>
 80024d0:	4601      	mov	r1, r0
 80024d2:	4b05      	ldr	r3, [pc, #20]	; (80024e8 <HAL_RCC_GetPCLK2Freq+0x20>)
 80024d4:	689b      	ldr	r3, [r3, #8]
 80024d6:	0b5b      	lsrs	r3, r3, #13
 80024d8:	f003 0307 	and.w	r3, r3, #7
 80024dc:	4a03      	ldr	r2, [pc, #12]	; (80024ec <HAL_RCC_GetPCLK2Freq+0x24>)
 80024de:	5cd3      	ldrb	r3, [r2, r3]
 80024e0:	fa21 f303 	lsr.w	r3, r1, r3
}
 80024e4:	4618      	mov	r0, r3
 80024e6:	bd80      	pop	{r7, pc}
 80024e8:	40023800 	.word	0x40023800
 80024ec:	0802e474 	.word	0x0802e474

080024f0 <HAL_RCCEx_PeriphCLKConfig>:
  *         the backup registers) are set to their reset values.
  *
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_RCCEx_PeriphCLKConfig(RCC_PeriphCLKInitTypeDef  *PeriphClkInit)
{
 80024f0:	b580      	push	{r7, lr}
 80024f2:	b088      	sub	sp, #32
 80024f4:	af00      	add	r7, sp, #0
 80024f6:	6078      	str	r0, [r7, #4]
  uint32_t tickstart = 0;
 80024f8:	2300      	movs	r3, #0
 80024fa:	617b      	str	r3, [r7, #20]
  uint32_t tmpreg0 = 0;
 80024fc:	2300      	movs	r3, #0
 80024fe:	613b      	str	r3, [r7, #16]
  uint32_t tmpreg1 = 0;
 8002500:	2300      	movs	r3, #0
 8002502:	60fb      	str	r3, [r7, #12]
  uint32_t plli2sused = 0;
 8002504:	2300      	movs	r3, #0
 8002506:	61fb      	str	r3, [r7, #28]
  uint32_t pllsaiused = 0;
 8002508:	2300      	movs	r3, #0
 800250a:	61bb      	str	r3, [r7, #24]

  /* Check the parameters */
  assert_param(IS_RCC_PERIPHCLOCK(PeriphClkInit->PeriphClockSelection));

  /*----------------------------------- I2S configuration ----------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_I2S) == (RCC_PERIPHCLK_I2S))
 800250c:	687b      	ldr	r3, [r7, #4]
 800250e:	681b      	ldr	r3, [r3, #0]
 8002510:	f003 0301 	and.w	r3, r3, #1
 8002514:	2b00      	cmp	r3, #0
 8002516:	d012      	beq.n	800253e <HAL_RCCEx_PeriphCLKConfig+0x4e>
  {
    /* Check the parameters */
    assert_param(IS_RCC_I2SCLKSOURCE(PeriphClkInit->I2sClockSelection));

    /* Configure I2S Clock source */
    __HAL_RCC_I2S_CONFIG(PeriphClkInit->I2sClockSelection);
 8002518:	4b69      	ldr	r3, [pc, #420]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 800251a:	689b      	ldr	r3, [r3, #8]
 800251c:	4a68      	ldr	r2, [pc, #416]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 800251e:	f423 0300 	bic.w	r3, r3, #8388608	; 0x800000
 8002522:	6093      	str	r3, [r2, #8]
 8002524:	4b66      	ldr	r3, [pc, #408]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 8002526:	689a      	ldr	r2, [r3, #8]
 8002528:	687b      	ldr	r3, [r7, #4]
 800252a:	6b5b      	ldr	r3, [r3, #52]	; 0x34
 800252c:	4964      	ldr	r1, [pc, #400]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 800252e:	4313      	orrs	r3, r2
 8002530:	608b      	str	r3, [r1, #8]

    /* Enable the PLLI2S when it's used as clock source for I2S */
    if(PeriphClkInit->I2sClockSelection == RCC_I2SCLKSOURCE_PLLI2S)
 8002532:	687b      	ldr	r3, [r7, #4]
 8002534:	6b5b      	ldr	r3, [r3, #52]	; 0x34
 8002536:	2b00      	cmp	r3, #0
 8002538:	d101      	bne.n	800253e <HAL_RCCEx_PeriphCLKConfig+0x4e>
    {
      plli2sused = 1;
 800253a:	2301      	movs	r3, #1
 800253c:	61fb      	str	r3, [r7, #28]
    }
  }

  /*------------------------------------ SAI1 configuration --------------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_SAI1) == (RCC_PERIPHCLK_SAI1))
 800253e:	687b      	ldr	r3, [r7, #4]
 8002540:	681b      	ldr	r3, [r3, #0]
 8002542:	f403 2300 	and.w	r3, r3, #524288	; 0x80000
 8002546:	2b00      	cmp	r3, #0
 8002548:	d017      	beq.n	800257a <HAL_RCCEx_PeriphCLKConfig+0x8a>
  {
    /* Check the parameters */
    assert_param(IS_RCC_SAI1CLKSOURCE(PeriphClkInit->Sai1ClockSelection));

    /* Configure SAI1 Clock source */
    __HAL_RCC_SAI1_CONFIG(PeriphClkInit->Sai1ClockSelection);
 800254a:	4b5d      	ldr	r3, [pc, #372]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 800254c:	f8d3 308c 	ldr.w	r3, [r3, #140]	; 0x8c
 8002550:	f423 1240 	bic.w	r2, r3, #3145728	; 0x300000
 8002554:	687b      	ldr	r3, [r7, #4]
 8002556:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8002558:	4959      	ldr	r1, [pc, #356]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 800255a:	4313      	orrs	r3, r2
 800255c:	f8c1 308c 	str.w	r3, [r1, #140]	; 0x8c
    /* Enable the PLLI2S when it's used as clock source for SAI */
    if(PeriphClkInit->Sai1ClockSelection == RCC_SAI1CLKSOURCE_PLLI2S)
 8002560:	687b      	ldr	r3, [r7, #4]
 8002562:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8002564:	f5b3 1f80 	cmp.w	r3, #1048576	; 0x100000
 8002568:	d101      	bne.n	800256e <HAL_RCCEx_PeriphCLKConfig+0x7e>
    {
      plli2sused = 1;
 800256a:	2301      	movs	r3, #1
 800256c:	61fb      	str	r3, [r7, #28]
    }
    /* Enable the PLLSAI when it's used as clock source for SAI */
    if(PeriphClkInit->Sai1ClockSelection == RCC_SAI1CLKSOURCE_PLLSAI)
 800256e:	687b      	ldr	r3, [r7, #4]
 8002570:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8002572:	2b00      	cmp	r3, #0
 8002574:	d101      	bne.n	800257a <HAL_RCCEx_PeriphCLKConfig+0x8a>
    {
      pllsaiused = 1;
 8002576:	2301      	movs	r3, #1
 8002578:	61bb      	str	r3, [r7, #24]
    }
  }

  /*------------------------------------ SAI2 configuration --------------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_SAI2) == (RCC_PERIPHCLK_SAI2))
 800257a:	687b      	ldr	r3, [r7, #4]
 800257c:	681b      	ldr	r3, [r3, #0]
 800257e:	f403 1380 	and.w	r3, r3, #1048576	; 0x100000
 8002582:	2b00      	cmp	r3, #0
 8002584:	d017      	beq.n	80025b6 <HAL_RCCEx_PeriphCLKConfig+0xc6>
  {
    /* Check the parameters */
    assert_param(IS_RCC_SAI2CLKSOURCE(PeriphClkInit->Sai2ClockSelection));

    /* Configure SAI2 Clock source */
    __HAL_RCC_SAI2_CONFIG(PeriphClkInit->Sai2ClockSelection);
 8002586:	4b4e      	ldr	r3, [pc, #312]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 8002588:	f8d3 308c 	ldr.w	r3, [r3, #140]	; 0x8c
 800258c:	f423 0240 	bic.w	r2, r3, #12582912	; 0xc00000
 8002590:	687b      	ldr	r3, [r7, #4]
 8002592:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 8002594:	494a      	ldr	r1, [pc, #296]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 8002596:	4313      	orrs	r3, r2
 8002598:	f8c1 308c 	str.w	r3, [r1, #140]	; 0x8c

    /* Enable the PLLI2S when it's used as clock source for SAI */
    if(PeriphClkInit->Sai2ClockSelection == RCC_SAI2CLKSOURCE_PLLI2S)
 800259c:	687b      	ldr	r3, [r7, #4]
 800259e:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 80025a0:	f5b3 0f80 	cmp.w	r3, #4194304	; 0x400000
 80025a4:	d101      	bne.n	80025aa <HAL_RCCEx_PeriphCLKConfig+0xba>
    {
      plli2sused = 1;
 80025a6:	2301      	movs	r3, #1
 80025a8:	61fb      	str	r3, [r7, #28]
    }
    /* Enable the PLLSAI when it's used as clock source for SAI */
    if(PeriphClkInit->Sai2ClockSelection == RCC_SAI2CLKSOURCE_PLLSAI)
 80025aa:	687b      	ldr	r3, [r7, #4]
 80025ac:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 80025ae:	2b00      	cmp	r3, #0
 80025b0:	d101      	bne.n	80025b6 <HAL_RCCEx_PeriphCLKConfig+0xc6>
    {
      pllsaiused = 1;
 80025b2:	2301      	movs	r3, #1
 80025b4:	61bb      	str	r3, [r7, #24]
    }
  }

  /*-------------------------------------- SPDIF-RX Configuration -----------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_SPDIFRX) == RCC_PERIPHCLK_SPDIFRX)
 80025b6:	687b      	ldr	r3, [r7, #4]
 80025b8:	681b      	ldr	r3, [r3, #0]
 80025ba:	f003 7380 	and.w	r3, r3, #16777216	; 0x1000000
 80025be:	2b00      	cmp	r3, #0
 80025c0:	d001      	beq.n	80025c6 <HAL_RCCEx_PeriphCLKConfig+0xd6>
  {
      plli2sused = 1;
 80025c2:	2301      	movs	r3, #1
 80025c4:	61fb      	str	r3, [r7, #28]
  }

  /*------------------------------------ RTC configuration --------------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_RTC) == (RCC_PERIPHCLK_RTC))
 80025c6:	687b      	ldr	r3, [r7, #4]
 80025c8:	681b      	ldr	r3, [r3, #0]
 80025ca:	f003 0320 	and.w	r3, r3, #32
 80025ce:	2b00      	cmp	r3, #0
 80025d0:	f000 808b 	beq.w	80026ea <HAL_RCCEx_PeriphCLKConfig+0x1fa>
  {
    /* Check for RTC Parameters used to output RTCCLK */
    assert_param(IS_RCC_RTCCLKSOURCE(PeriphClkInit->RTCClockSelection));

    /* Enable Power Clock*/
    __HAL_RCC_PWR_CLK_ENABLE();
 80025d4:	4b3a      	ldr	r3, [pc, #232]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 80025d6:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 80025d8:	4a39      	ldr	r2, [pc, #228]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 80025da:	f043 5380 	orr.w	r3, r3, #268435456	; 0x10000000
 80025de:	6413      	str	r3, [r2, #64]	; 0x40
 80025e0:	4b37      	ldr	r3, [pc, #220]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 80025e2:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 80025e4:	f003 5380 	and.w	r3, r3, #268435456	; 0x10000000
 80025e8:	60bb      	str	r3, [r7, #8]
 80025ea:	68bb      	ldr	r3, [r7, #8]

    /* Enable write access to Backup domain */
    PWR->CR1 |= PWR_CR1_DBP;
 80025ec:	4b35      	ldr	r3, [pc, #212]	; (80026c4 <HAL_RCCEx_PeriphCLKConfig+0x1d4>)
 80025ee:	681b      	ldr	r3, [r3, #0]
 80025f0:	4a34      	ldr	r2, [pc, #208]	; (80026c4 <HAL_RCCEx_PeriphCLKConfig+0x1d4>)
 80025f2:	f443 7380 	orr.w	r3, r3, #256	; 0x100
 80025f6:	6013      	str	r3, [r2, #0]

    /* Get Start Tick*/
    tickstart = HAL_GetTick();
 80025f8:	f7fe ff84 	bl	8001504 <HAL_GetTick>
 80025fc:	6178      	str	r0, [r7, #20]

    /* Wait for Backup domain Write protection disable */
    while((PWR->CR1 & PWR_CR1_DBP) == RESET)
 80025fe:	e008      	b.n	8002612 <HAL_RCCEx_PeriphCLKConfig+0x122>
    {
      if((HAL_GetTick() - tickstart) > RCC_DBP_TIMEOUT_VALUE)
 8002600:	f7fe ff80 	bl	8001504 <HAL_GetTick>
 8002604:	4602      	mov	r2, r0
 8002606:	697b      	ldr	r3, [r7, #20]
 8002608:	1ad3      	subs	r3, r2, r3
 800260a:	2b64      	cmp	r3, #100	; 0x64
 800260c:	d901      	bls.n	8002612 <HAL_RCCEx_PeriphCLKConfig+0x122>
      {
        return HAL_TIMEOUT;
 800260e:	2303      	movs	r3, #3
 8002610:	e38d      	b.n	8002d2e <HAL_RCCEx_PeriphCLKConfig+0x83e>
    while((PWR->CR1 & PWR_CR1_DBP) == RESET)
 8002612:	4b2c      	ldr	r3, [pc, #176]	; (80026c4 <HAL_RCCEx_PeriphCLKConfig+0x1d4>)
 8002614:	681b      	ldr	r3, [r3, #0]
 8002616:	f403 7380 	and.w	r3, r3, #256	; 0x100
 800261a:	2b00      	cmp	r3, #0
 800261c:	d0f0      	beq.n	8002600 <HAL_RCCEx_PeriphCLKConfig+0x110>
      }
    }

    /* Reset the Backup domain only if the RTC Clock source selection is modified */
    tmpreg0 = (RCC->BDCR & RCC_BDCR_RTCSEL);
 800261e:	4b28      	ldr	r3, [pc, #160]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 8002620:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 8002622:	f403 7340 	and.w	r3, r3, #768	; 0x300
 8002626:	613b      	str	r3, [r7, #16]

    if((tmpreg0 != 0x00000000U) && (tmpreg0 != (PeriphClkInit->RTCClockSelection & RCC_BDCR_RTCSEL)))
 8002628:	693b      	ldr	r3, [r7, #16]
 800262a:	2b00      	cmp	r3, #0
 800262c:	d035      	beq.n	800269a <HAL_RCCEx_PeriphCLKConfig+0x1aa>
 800262e:	687b      	ldr	r3, [r7, #4]
 8002630:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8002632:	f403 7340 	and.w	r3, r3, #768	; 0x300
 8002636:	693a      	ldr	r2, [r7, #16]
 8002638:	429a      	cmp	r2, r3
 800263a:	d02e      	beq.n	800269a <HAL_RCCEx_PeriphCLKConfig+0x1aa>
    {
      /* Store the content of BDCR register before the reset of Backup Domain */
      tmpreg0 = (RCC->BDCR & ~(RCC_BDCR_RTCSEL));
 800263c:	4b20      	ldr	r3, [pc, #128]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 800263e:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 8002640:	f423 7340 	bic.w	r3, r3, #768	; 0x300
 8002644:	613b      	str	r3, [r7, #16]

      /* RTC Clock selection can be changed only if the Backup Domain is reset */
      __HAL_RCC_BACKUPRESET_FORCE();
 8002646:	4b1e      	ldr	r3, [pc, #120]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 8002648:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 800264a:	4a1d      	ldr	r2, [pc, #116]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 800264c:	f443 3380 	orr.w	r3, r3, #65536	; 0x10000
 8002650:	6713      	str	r3, [r2, #112]	; 0x70
      __HAL_RCC_BACKUPRESET_RELEASE();
 8002652:	4b1b      	ldr	r3, [pc, #108]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 8002654:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 8002656:	4a1a      	ldr	r2, [pc, #104]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 8002658:	f423 3380 	bic.w	r3, r3, #65536	; 0x10000
 800265c:	6713      	str	r3, [r2, #112]	; 0x70

      /* Restore the Content of BDCR register */
      RCC->BDCR = tmpreg0;
 800265e:	4a18      	ldr	r2, [pc, #96]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 8002660:	693b      	ldr	r3, [r7, #16]
 8002662:	6713      	str	r3, [r2, #112]	; 0x70

      /* Wait for LSE reactivation if LSE was enable prior to Backup Domain reset */
      if (HAL_IS_BIT_SET(RCC->BDCR, RCC_BDCR_LSEON))
 8002664:	4b16      	ldr	r3, [pc, #88]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 8002666:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 8002668:	f003 0301 	and.w	r3, r3, #1
 800266c:	2b01      	cmp	r3, #1
 800266e:	d114      	bne.n	800269a <HAL_RCCEx_PeriphCLKConfig+0x1aa>
      {
        /* Get Start Tick*/
        tickstart = HAL_GetTick();
 8002670:	f7fe ff48 	bl	8001504 <HAL_GetTick>
 8002674:	6178      	str	r0, [r7, #20]

        /* Wait till LSE is ready */
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) == RESET)
 8002676:	e00a      	b.n	800268e <HAL_RCCEx_PeriphCLKConfig+0x19e>
        {
          if((HAL_GetTick() - tickstart ) > RCC_LSE_TIMEOUT_VALUE)
 8002678:	f7fe ff44 	bl	8001504 <HAL_GetTick>
 800267c:	4602      	mov	r2, r0
 800267e:	697b      	ldr	r3, [r7, #20]
 8002680:	1ad3      	subs	r3, r2, r3
 8002682:	f241 3288 	movw	r2, #5000	; 0x1388
 8002686:	4293      	cmp	r3, r2
 8002688:	d901      	bls.n	800268e <HAL_RCCEx_PeriphCLKConfig+0x19e>
          {
            return HAL_TIMEOUT;
 800268a:	2303      	movs	r3, #3
 800268c:	e34f      	b.n	8002d2e <HAL_RCCEx_PeriphCLKConfig+0x83e>
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) == RESET)
 800268e:	4b0c      	ldr	r3, [pc, #48]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 8002690:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 8002692:	f003 0302 	and.w	r3, r3, #2
 8002696:	2b00      	cmp	r3, #0
 8002698:	d0ee      	beq.n	8002678 <HAL_RCCEx_PeriphCLKConfig+0x188>
          }
        }
      }
    }
    __HAL_RCC_RTC_CONFIG(PeriphClkInit->RTCClockSelection);
 800269a:	687b      	ldr	r3, [r7, #4]
 800269c:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 800269e:	f403 7340 	and.w	r3, r3, #768	; 0x300
 80026a2:	f5b3 7f40 	cmp.w	r3, #768	; 0x300
 80026a6:	d111      	bne.n	80026cc <HAL_RCCEx_PeriphCLKConfig+0x1dc>
 80026a8:	4b05      	ldr	r3, [pc, #20]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 80026aa:	689b      	ldr	r3, [r3, #8]
 80026ac:	f423 12f8 	bic.w	r2, r3, #2031616	; 0x1f0000
 80026b0:	687b      	ldr	r3, [r7, #4]
 80026b2:	6b19      	ldr	r1, [r3, #48]	; 0x30
 80026b4:	4b04      	ldr	r3, [pc, #16]	; (80026c8 <HAL_RCCEx_PeriphCLKConfig+0x1d8>)
 80026b6:	400b      	ands	r3, r1
 80026b8:	4901      	ldr	r1, [pc, #4]	; (80026c0 <HAL_RCCEx_PeriphCLKConfig+0x1d0>)
 80026ba:	4313      	orrs	r3, r2
 80026bc:	608b      	str	r3, [r1, #8]
 80026be:	e00b      	b.n	80026d8 <HAL_RCCEx_PeriphCLKConfig+0x1e8>
 80026c0:	40023800 	.word	0x40023800
 80026c4:	40007000 	.word	0x40007000
 80026c8:	0ffffcff 	.word	0x0ffffcff
 80026cc:	4bb3      	ldr	r3, [pc, #716]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 80026ce:	689b      	ldr	r3, [r3, #8]
 80026d0:	4ab2      	ldr	r2, [pc, #712]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 80026d2:	f423 13f8 	bic.w	r3, r3, #2031616	; 0x1f0000
 80026d6:	6093      	str	r3, [r2, #8]
 80026d8:	4bb0      	ldr	r3, [pc, #704]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 80026da:	6f1a      	ldr	r2, [r3, #112]	; 0x70
 80026dc:	687b      	ldr	r3, [r7, #4]
 80026de:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 80026e0:	f3c3 030b 	ubfx	r3, r3, #0, #12
 80026e4:	49ad      	ldr	r1, [pc, #692]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 80026e6:	4313      	orrs	r3, r2
 80026e8:	670b      	str	r3, [r1, #112]	; 0x70
  }

  /*------------------------------------ TIM configuration --------------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_TIM) == (RCC_PERIPHCLK_TIM))
 80026ea:	687b      	ldr	r3, [r7, #4]
 80026ec:	681b      	ldr	r3, [r3, #0]
 80026ee:	f003 0310 	and.w	r3, r3, #16
 80026f2:	2b00      	cmp	r3, #0
 80026f4:	d010      	beq.n	8002718 <HAL_RCCEx_PeriphCLKConfig+0x228>
  {
    /* Check the parameters */
    assert_param(IS_RCC_TIMPRES(PeriphClkInit->TIMPresSelection));

    /* Configure Timer Prescaler */
    __HAL_RCC_TIMCLKPRESCALER(PeriphClkInit->TIMPresSelection);
 80026f6:	4ba9      	ldr	r3, [pc, #676]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 80026f8:	f8d3 308c 	ldr.w	r3, [r3, #140]	; 0x8c
 80026fc:	4aa7      	ldr	r2, [pc, #668]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 80026fe:	f023 7380 	bic.w	r3, r3, #16777216	; 0x1000000
 8002702:	f8c2 308c 	str.w	r3, [r2, #140]	; 0x8c
 8002706:	4ba5      	ldr	r3, [pc, #660]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002708:	f8d3 208c 	ldr.w	r2, [r3, #140]	; 0x8c
 800270c:	687b      	ldr	r3, [r7, #4]
 800270e:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8002710:	49a2      	ldr	r1, [pc, #648]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002712:	4313      	orrs	r3, r2
 8002714:	f8c1 308c 	str.w	r3, [r1, #140]	; 0x8c
  }

  /*-------------------------------------- I2C1 Configuration -----------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_I2C1) == RCC_PERIPHCLK_I2C1)
 8002718:	687b      	ldr	r3, [r7, #4]
 800271a:	681b      	ldr	r3, [r3, #0]
 800271c:	f403 4380 	and.w	r3, r3, #16384	; 0x4000
 8002720:	2b00      	cmp	r3, #0
 8002722:	d00a      	beq.n	800273a <HAL_RCCEx_PeriphCLKConfig+0x24a>
  {
    /* Check the parameters */
    assert_param(IS_RCC_I2C1CLKSOURCE(PeriphClkInit->I2c1ClockSelection));

    /* Configure the I2C1 clock source */
    __HAL_RCC_I2C1_CONFIG(PeriphClkInit->I2c1ClockSelection);
 8002724:	4b9d      	ldr	r3, [pc, #628]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002726:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 800272a:	f423 3240 	bic.w	r2, r3, #196608	; 0x30000
 800272e:	687b      	ldr	r3, [r7, #4]
 8002730:	6e5b      	ldr	r3, [r3, #100]	; 0x64
 8002732:	499a      	ldr	r1, [pc, #616]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002734:	4313      	orrs	r3, r2
 8002736:	f8c1 3090 	str.w	r3, [r1, #144]	; 0x90
  }

  /*-------------------------------------- I2C2 Configuration -----------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_I2C2) == RCC_PERIPHCLK_I2C2)
 800273a:	687b      	ldr	r3, [r7, #4]
 800273c:	681b      	ldr	r3, [r3, #0]
 800273e:	f403 4300 	and.w	r3, r3, #32768	; 0x8000
 8002742:	2b00      	cmp	r3, #0
 8002744:	d00a      	beq.n	800275c <HAL_RCCEx_PeriphCLKConfig+0x26c>
  {
    /* Check the parameters */
    assert_param(IS_RCC_I2C2CLKSOURCE(PeriphClkInit->I2c2ClockSelection));

    /* Configure the I2C2 clock source */
    __HAL_RCC_I2C2_CONFIG(PeriphClkInit->I2c2ClockSelection);
 8002746:	4b95      	ldr	r3, [pc, #596]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002748:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 800274c:	f423 2240 	bic.w	r2, r3, #786432	; 0xc0000
 8002750:	687b      	ldr	r3, [r7, #4]
 8002752:	6e9b      	ldr	r3, [r3, #104]	; 0x68
 8002754:	4991      	ldr	r1, [pc, #580]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002756:	4313      	orrs	r3, r2
 8002758:	f8c1 3090 	str.w	r3, [r1, #144]	; 0x90
  }

  /*-------------------------------------- I2C3 Configuration -----------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_I2C3) == RCC_PERIPHCLK_I2C3)
 800275c:	687b      	ldr	r3, [r7, #4]
 800275e:	681b      	ldr	r3, [r3, #0]
 8002760:	f403 3380 	and.w	r3, r3, #65536	; 0x10000
 8002764:	2b00      	cmp	r3, #0
 8002766:	d00a      	beq.n	800277e <HAL_RCCEx_PeriphCLKConfig+0x28e>
  {
    /* Check the parameters */
    assert_param(IS_RCC_I2C3CLKSOURCE(PeriphClkInit->I2c3ClockSelection));

    /* Configure the I2C3 clock source */
    __HAL_RCC_I2C3_CONFIG(PeriphClkInit->I2c3ClockSelection);
 8002768:	4b8c      	ldr	r3, [pc, #560]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 800276a:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 800276e:	f423 1240 	bic.w	r2, r3, #3145728	; 0x300000
 8002772:	687b      	ldr	r3, [r7, #4]
 8002774:	6edb      	ldr	r3, [r3, #108]	; 0x6c
 8002776:	4989      	ldr	r1, [pc, #548]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002778:	4313      	orrs	r3, r2
 800277a:	f8c1 3090 	str.w	r3, [r1, #144]	; 0x90
  }

  /*-------------------------------------- I2C4 Configuration -----------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_I2C4) == RCC_PERIPHCLK_I2C4)
 800277e:	687b      	ldr	r3, [r7, #4]
 8002780:	681b      	ldr	r3, [r3, #0]
 8002782:	f403 3300 	and.w	r3, r3, #131072	; 0x20000
 8002786:	2b00      	cmp	r3, #0
 8002788:	d00a      	beq.n	80027a0 <HAL_RCCEx_PeriphCLKConfig+0x2b0>
  {
    /* Check the parameters */
    assert_param(IS_RCC_I2C4CLKSOURCE(PeriphClkInit->I2c4ClockSelection));

    /* Configure the I2C4 clock source */
    __HAL_RCC_I2C4_CONFIG(PeriphClkInit->I2c4ClockSelection);
 800278a:	4b84      	ldr	r3, [pc, #528]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 800278c:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8002790:	f423 0240 	bic.w	r2, r3, #12582912	; 0xc00000
 8002794:	687b      	ldr	r3, [r7, #4]
 8002796:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 8002798:	4980      	ldr	r1, [pc, #512]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 800279a:	4313      	orrs	r3, r2
 800279c:	f8c1 3090 	str.w	r3, [r1, #144]	; 0x90
  }

  /*-------------------------------------- USART1 Configuration -----------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_USART1) == RCC_PERIPHCLK_USART1)
 80027a0:	687b      	ldr	r3, [r7, #4]
 80027a2:	681b      	ldr	r3, [r3, #0]
 80027a4:	f003 0340 	and.w	r3, r3, #64	; 0x40
 80027a8:	2b00      	cmp	r3, #0
 80027aa:	d00a      	beq.n	80027c2 <HAL_RCCEx_PeriphCLKConfig+0x2d2>
  {
    /* Check the parameters */
    assert_param(IS_RCC_USART1CLKSOURCE(PeriphClkInit->Usart1ClockSelection));

    /* Configure the USART1 clock source */
    __HAL_RCC_USART1_CONFIG(PeriphClkInit->Usart1ClockSelection);
 80027ac:	4b7b      	ldr	r3, [pc, #492]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 80027ae:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 80027b2:	f023 0203 	bic.w	r2, r3, #3
 80027b6:	687b      	ldr	r3, [r7, #4]
 80027b8:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 80027ba:	4978      	ldr	r1, [pc, #480]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 80027bc:	4313      	orrs	r3, r2
 80027be:	f8c1 3090 	str.w	r3, [r1, #144]	; 0x90
  }

  /*-------------------------------------- USART2 Configuration -----------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_USART2) == RCC_PERIPHCLK_USART2)
 80027c2:	687b      	ldr	r3, [r7, #4]
 80027c4:	681b      	ldr	r3, [r3, #0]
 80027c6:	f003 0380 	and.w	r3, r3, #128	; 0x80
 80027ca:	2b00      	cmp	r3, #0
 80027cc:	d00a      	beq.n	80027e4 <HAL_RCCEx_PeriphCLKConfig+0x2f4>
  {
    /* Check the parameters */
    assert_param(IS_RCC_USART2CLKSOURCE(PeriphClkInit->Usart2ClockSelection));

    /* Configure the USART2 clock source */
    __HAL_RCC_USART2_CONFIG(PeriphClkInit->Usart2ClockSelection);
 80027ce:	4b73      	ldr	r3, [pc, #460]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 80027d0:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 80027d4:	f023 020c 	bic.w	r2, r3, #12
 80027d8:	687b      	ldr	r3, [r7, #4]
 80027da:	6c9b      	ldr	r3, [r3, #72]	; 0x48
 80027dc:	496f      	ldr	r1, [pc, #444]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 80027de:	4313      	orrs	r3, r2
 80027e0:	f8c1 3090 	str.w	r3, [r1, #144]	; 0x90
  }

  /*-------------------------------------- USART3 Configuration -----------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_USART3) == RCC_PERIPHCLK_USART3)
 80027e4:	687b      	ldr	r3, [r7, #4]
 80027e6:	681b      	ldr	r3, [r3, #0]
 80027e8:	f403 7380 	and.w	r3, r3, #256	; 0x100
 80027ec:	2b00      	cmp	r3, #0
 80027ee:	d00a      	beq.n	8002806 <HAL_RCCEx_PeriphCLKConfig+0x316>
  {
    /* Check the parameters */
    assert_param(IS_RCC_USART3CLKSOURCE(PeriphClkInit->Usart3ClockSelection));

    /* Configure the USART3 clock source */
    __HAL_RCC_USART3_CONFIG(PeriphClkInit->Usart3ClockSelection);
 80027f0:	4b6a      	ldr	r3, [pc, #424]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 80027f2:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 80027f6:	f023 0230 	bic.w	r2, r3, #48	; 0x30
 80027fa:	687b      	ldr	r3, [r7, #4]
 80027fc:	6cdb      	ldr	r3, [r3, #76]	; 0x4c
 80027fe:	4967      	ldr	r1, [pc, #412]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002800:	4313      	orrs	r3, r2
 8002802:	f8c1 3090 	str.w	r3, [r1, #144]	; 0x90
  }

  /*-------------------------------------- UART4 Configuration -----------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_UART4) == RCC_PERIPHCLK_UART4)
 8002806:	687b      	ldr	r3, [r7, #4]
 8002808:	681b      	ldr	r3, [r3, #0]
 800280a:	f403 7300 	and.w	r3, r3, #512	; 0x200
 800280e:	2b00      	cmp	r3, #0
 8002810:	d00a      	beq.n	8002828 <HAL_RCCEx_PeriphCLKConfig+0x338>
  {
    /* Check the parameters */
    assert_param(IS_RCC_UART4CLKSOURCE(PeriphClkInit->Uart4ClockSelection));

    /* Configure the UART4 clock source */
    __HAL_RCC_UART4_CONFIG(PeriphClkInit->Uart4ClockSelection);
 8002812:	4b62      	ldr	r3, [pc, #392]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002814:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8002818:	f023 02c0 	bic.w	r2, r3, #192	; 0xc0
 800281c:	687b      	ldr	r3, [r7, #4]
 800281e:	6d1b      	ldr	r3, [r3, #80]	; 0x50
 8002820:	495e      	ldr	r1, [pc, #376]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002822:	4313      	orrs	r3, r2
 8002824:	f8c1 3090 	str.w	r3, [r1, #144]	; 0x90
  }

  /*-------------------------------------- UART5 Configuration -----------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_UART5) == RCC_PERIPHCLK_UART5)
 8002828:	687b      	ldr	r3, [r7, #4]
 800282a:	681b      	ldr	r3, [r3, #0]
 800282c:	f403 6380 	and.w	r3, r3, #1024	; 0x400
 8002830:	2b00      	cmp	r3, #0
 8002832:	d00a      	beq.n	800284a <HAL_RCCEx_PeriphCLKConfig+0x35a>
  {
    /* Check the parameters */
    assert_param(IS_RCC_UART5CLKSOURCE(PeriphClkInit->Uart5ClockSelection));

    /* Configure the UART5 clock source */
    __HAL_RCC_UART5_CONFIG(PeriphClkInit->Uart5ClockSelection);
 8002834:	4b59      	ldr	r3, [pc, #356]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002836:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 800283a:	f423 7240 	bic.w	r2, r3, #768	; 0x300
 800283e:	687b      	ldr	r3, [r7, #4]
 8002840:	6d5b      	ldr	r3, [r3, #84]	; 0x54
 8002842:	4956      	ldr	r1, [pc, #344]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002844:	4313      	orrs	r3, r2
 8002846:	f8c1 3090 	str.w	r3, [r1, #144]	; 0x90
  }

  /*-------------------------------------- USART6 Configuration -----------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_USART6) == RCC_PERIPHCLK_USART6)
 800284a:	687b      	ldr	r3, [r7, #4]
 800284c:	681b      	ldr	r3, [r3, #0]
 800284e:	f403 6300 	and.w	r3, r3, #2048	; 0x800
 8002852:	2b00      	cmp	r3, #0
 8002854:	d00a      	beq.n	800286c <HAL_RCCEx_PeriphCLKConfig+0x37c>
  {
    /* Check the parameters */
    assert_param(IS_RCC_USART6CLKSOURCE(PeriphClkInit->Usart6ClockSelection));

    /* Configure the USART6 clock source */
    __HAL_RCC_USART6_CONFIG(PeriphClkInit->Usart6ClockSelection);
 8002856:	4b51      	ldr	r3, [pc, #324]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002858:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 800285c:	f423 6240 	bic.w	r2, r3, #3072	; 0xc00
 8002860:	687b      	ldr	r3, [r7, #4]
 8002862:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 8002864:	494d      	ldr	r1, [pc, #308]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002866:	4313      	orrs	r3, r2
 8002868:	f8c1 3090 	str.w	r3, [r1, #144]	; 0x90
  }

  /*-------------------------------------- UART7 Configuration -----------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_UART7) == RCC_PERIPHCLK_UART7)
 800286c:	687b      	ldr	r3, [r7, #4]
 800286e:	681b      	ldr	r3, [r3, #0]
 8002870:	f403 5380 	and.w	r3, r3, #4096	; 0x1000
 8002874:	2b00      	cmp	r3, #0
 8002876:	d00a      	beq.n	800288e <HAL_RCCEx_PeriphCLKConfig+0x39e>
  {
    /* Check the parameters */
    assert_param(IS_RCC_UART7CLKSOURCE(PeriphClkInit->Uart7ClockSelection));

    /* Configure the UART7 clock source */
    __HAL_RCC_UART7_CONFIG(PeriphClkInit->Uart7ClockSelection);
 8002878:	4b48      	ldr	r3, [pc, #288]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 800287a:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 800287e:	f423 5240 	bic.w	r2, r3, #12288	; 0x3000
 8002882:	687b      	ldr	r3, [r7, #4]
 8002884:	6ddb      	ldr	r3, [r3, #92]	; 0x5c
 8002886:	4945      	ldr	r1, [pc, #276]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002888:	4313      	orrs	r3, r2
 800288a:	f8c1 3090 	str.w	r3, [r1, #144]	; 0x90
  }

  /*-------------------------------------- UART8 Configuration -----------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_UART8) == RCC_PERIPHCLK_UART8)
 800288e:	687b      	ldr	r3, [r7, #4]
 8002890:	681b      	ldr	r3, [r3, #0]
 8002892:	f403 5300 	and.w	r3, r3, #8192	; 0x2000
 8002896:	2b00      	cmp	r3, #0
 8002898:	d00a      	beq.n	80028b0 <HAL_RCCEx_PeriphCLKConfig+0x3c0>
  {
    /* Check the parameters */
    assert_param(IS_RCC_UART8CLKSOURCE(PeriphClkInit->Uart8ClockSelection));

    /* Configure the UART8 clock source */
    __HAL_RCC_UART8_CONFIG(PeriphClkInit->Uart8ClockSelection);
 800289a:	4b40      	ldr	r3, [pc, #256]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 800289c:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 80028a0:	f423 4240 	bic.w	r2, r3, #49152	; 0xc000
 80028a4:	687b      	ldr	r3, [r7, #4]
 80028a6:	6e1b      	ldr	r3, [r3, #96]	; 0x60
 80028a8:	493c      	ldr	r1, [pc, #240]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 80028aa:	4313      	orrs	r3, r2
 80028ac:	f8c1 3090 	str.w	r3, [r1, #144]	; 0x90
  }

  /*--------------------------------------- CEC Configuration -----------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_CEC) == RCC_PERIPHCLK_CEC)
 80028b0:	687b      	ldr	r3, [r7, #4]
 80028b2:	681b      	ldr	r3, [r3, #0]
 80028b4:	f403 0380 	and.w	r3, r3, #4194304	; 0x400000
 80028b8:	2b00      	cmp	r3, #0
 80028ba:	d00a      	beq.n	80028d2 <HAL_RCCEx_PeriphCLKConfig+0x3e2>
  {
    /* Check the parameters */
    assert_param(IS_RCC_CECCLKSOURCE(PeriphClkInit->CecClockSelection));

    /* Configure the CEC clock source */
    __HAL_RCC_CEC_CONFIG(PeriphClkInit->CecClockSelection);
 80028bc:	4b37      	ldr	r3, [pc, #220]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 80028be:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 80028c2:	f023 6280 	bic.w	r2, r3, #67108864	; 0x4000000
 80028c6:	687b      	ldr	r3, [r7, #4]
 80028c8:	6f9b      	ldr	r3, [r3, #120]	; 0x78
 80028ca:	4934      	ldr	r1, [pc, #208]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 80028cc:	4313      	orrs	r3, r2
 80028ce:	f8c1 3090 	str.w	r3, [r1, #144]	; 0x90
  }

  /*-------------------------------------- CK48 Configuration -----------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_CLK48) == RCC_PERIPHCLK_CLK48)
 80028d2:	687b      	ldr	r3, [r7, #4]
 80028d4:	681b      	ldr	r3, [r3, #0]
 80028d6:	f403 1300 	and.w	r3, r3, #2097152	; 0x200000
 80028da:	2b00      	cmp	r3, #0
 80028dc:	d011      	beq.n	8002902 <HAL_RCCEx_PeriphCLKConfig+0x412>
  {
    /* Check the parameters */
    assert_param(IS_RCC_CLK48SOURCE(PeriphClkInit->Clk48ClockSelection));

    /* Configure the CLK48 source */
    __HAL_RCC_CLK48_CONFIG(PeriphClkInit->Clk48ClockSelection);
 80028de:	4b2f      	ldr	r3, [pc, #188]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 80028e0:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 80028e4:	f023 6200 	bic.w	r2, r3, #134217728	; 0x8000000
 80028e8:	687b      	ldr	r3, [r7, #4]
 80028ea:	6fdb      	ldr	r3, [r3, #124]	; 0x7c
 80028ec:	492b      	ldr	r1, [pc, #172]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 80028ee:	4313      	orrs	r3, r2
 80028f0:	f8c1 3090 	str.w	r3, [r1, #144]	; 0x90

    /* Enable the PLLSAI when it's used as clock source for CK48 */
    if(PeriphClkInit->Clk48ClockSelection == RCC_CLK48SOURCE_PLLSAIP)
 80028f4:	687b      	ldr	r3, [r7, #4]
 80028f6:	6fdb      	ldr	r3, [r3, #124]	; 0x7c
 80028f8:	f1b3 6f00 	cmp.w	r3, #134217728	; 0x8000000
 80028fc:	d101      	bne.n	8002902 <HAL_RCCEx_PeriphCLKConfig+0x412>
    {
      pllsaiused = 1;
 80028fe:	2301      	movs	r3, #1
 8002900:	61bb      	str	r3, [r7, #24]
    }
  }

  /*-------------------------------------- LTDC Configuration -----------------------------------*/
#if defined(STM32F746xx) || defined(STM32F756xx) || defined (STM32F767xx) || defined (STM32F769xx) || defined (STM32F777xx) || defined (STM32F779xx) || defined (STM32F750xx)
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_LTDC) == RCC_PERIPHCLK_LTDC)
 8002902:	687b      	ldr	r3, [r7, #4]
 8002904:	681b      	ldr	r3, [r3, #0]
 8002906:	f003 0308 	and.w	r3, r3, #8
 800290a:	2b00      	cmp	r3, #0
 800290c:	d001      	beq.n	8002912 <HAL_RCCEx_PeriphCLKConfig+0x422>
  {
    pllsaiused = 1;
 800290e:	2301      	movs	r3, #1
 8002910:	61bb      	str	r3, [r7, #24]
  }
#endif /* STM32F746xx || STM32F756xx || STM32F767xx || STM32F769xx || STM32F777xx || STM32F779xx || STM32F750xx */

  /*-------------------------------------- LPTIM1 Configuration -----------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_LPTIM1) == RCC_PERIPHCLK_LPTIM1)
 8002912:	687b      	ldr	r3, [r7, #4]
 8002914:	681b      	ldr	r3, [r3, #0]
 8002916:	f403 2380 	and.w	r3, r3, #262144	; 0x40000
 800291a:	2b00      	cmp	r3, #0
 800291c:	d00a      	beq.n	8002934 <HAL_RCCEx_PeriphCLKConfig+0x444>
  {
    /* Check the parameters */
    assert_param(IS_RCC_LPTIM1CLK(PeriphClkInit->Lptim1ClockSelection));

    /* Configure the LTPIM1 clock source */
    __HAL_RCC_LPTIM1_CONFIG(PeriphClkInit->Lptim1ClockSelection);
 800291e:	4b1f      	ldr	r3, [pc, #124]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002920:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8002924:	f023 7240 	bic.w	r2, r3, #50331648	; 0x3000000
 8002928:	687b      	ldr	r3, [r7, #4]
 800292a:	6f5b      	ldr	r3, [r3, #116]	; 0x74
 800292c:	491b      	ldr	r1, [pc, #108]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 800292e:	4313      	orrs	r3, r2
 8002930:	f8c1 3090 	str.w	r3, [r1, #144]	; 0x90
   }

  /*------------------------------------- SDMMC1 Configuration ------------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_SDMMC1) == RCC_PERIPHCLK_SDMMC1)
 8002934:	687b      	ldr	r3, [r7, #4]
 8002936:	681b      	ldr	r3, [r3, #0]
 8002938:	f403 0300 	and.w	r3, r3, #8388608	; 0x800000
 800293c:	2b00      	cmp	r3, #0
 800293e:	d00b      	beq.n	8002958 <HAL_RCCEx_PeriphCLKConfig+0x468>
  {
    /* Check the parameters */
    assert_param(IS_RCC_SDMMC1CLKSOURCE(PeriphClkInit->Sdmmc1ClockSelection));

    /* Configure the SDMMC1 clock source */
    __HAL_RCC_SDMMC1_CONFIG(PeriphClkInit->Sdmmc1ClockSelection);
 8002940:	4b16      	ldr	r3, [pc, #88]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002942:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8002946:	f023 5280 	bic.w	r2, r3, #268435456	; 0x10000000
 800294a:	687b      	ldr	r3, [r7, #4]
 800294c:	f8d3 3080 	ldr.w	r3, [r3, #128]	; 0x80
 8002950:	4912      	ldr	r1, [pc, #72]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002952:	4313      	orrs	r3, r2
 8002954:	f8c1 3090 	str.w	r3, [r1, #144]	; 0x90
  }

#if defined (STM32F765xx) || defined (STM32F767xx) || defined (STM32F769xx) || defined (STM32F777xx) || defined (STM32F779xx)
  /*------------------------------------- SDMMC2 Configuration ------------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_SDMMC2) == RCC_PERIPHCLK_SDMMC2)
 8002958:	687b      	ldr	r3, [r7, #4]
 800295a:	681b      	ldr	r3, [r3, #0]
 800295c:	f003 6380 	and.w	r3, r3, #67108864	; 0x4000000
 8002960:	2b00      	cmp	r3, #0
 8002962:	d00b      	beq.n	800297c <HAL_RCCEx_PeriphCLKConfig+0x48c>
  {
    /* Check the parameters */
    assert_param(IS_RCC_SDMMC2CLKSOURCE(PeriphClkInit->Sdmmc2ClockSelection));

    /* Configure the SDMMC2 clock source */
    __HAL_RCC_SDMMC2_CONFIG(PeriphClkInit->Sdmmc2ClockSelection);
 8002964:	4b0d      	ldr	r3, [pc, #52]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002966:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 800296a:	f023 5200 	bic.w	r2, r3, #536870912	; 0x20000000
 800296e:	687b      	ldr	r3, [r7, #4]
 8002970:	f8d3 3084 	ldr.w	r3, [r3, #132]	; 0x84
 8002974:	4909      	ldr	r1, [pc, #36]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 8002976:	4313      	orrs	r3, r2
 8002978:	f8c1 3090 	str.w	r3, [r1, #144]	; 0x90
  }

  /*------------------------------------- DFSDM1 Configuration -------------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_DFSDM1) == RCC_PERIPHCLK_DFSDM1)
 800297c:	687b      	ldr	r3, [r7, #4]
 800297e:	681b      	ldr	r3, [r3, #0]
 8002980:	f003 6300 	and.w	r3, r3, #134217728	; 0x8000000
 8002984:	2b00      	cmp	r3, #0
 8002986:	d00f      	beq.n	80029a8 <HAL_RCCEx_PeriphCLKConfig+0x4b8>
  {
    /* Check the parameters */
    assert_param(IS_RCC_DFSDM1CLKSOURCE(PeriphClkInit->Dfsdm1ClockSelection));

    /* Configure the DFSDM1 interface clock source */
    __HAL_RCC_DFSDM1_CONFIG(PeriphClkInit->Dfsdm1ClockSelection);
 8002988:	4b04      	ldr	r3, [pc, #16]	; (800299c <HAL_RCCEx_PeriphCLKConfig+0x4ac>)
 800298a:	f8d3 308c 	ldr.w	r3, [r3, #140]	; 0x8c
 800298e:	f023 7200 	bic.w	r2, r3, #33554432	; 0x2000000
 8002992:	687b      	ldr	r3, [r7, #4]
 8002994:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8002998:	e002      	b.n	80029a0 <HAL_RCCEx_PeriphCLKConfig+0x4b0>
 800299a:	bf00      	nop
 800299c:	40023800 	.word	0x40023800
 80029a0:	4985      	ldr	r1, [pc, #532]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 80029a2:	4313      	orrs	r3, r2
 80029a4:	f8c1 308c 	str.w	r3, [r1, #140]	; 0x8c
  }

  /*------------------------------------- DFSDM AUDIO Configuration -------------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_DFSDM1_AUDIO) == RCC_PERIPHCLK_DFSDM1_AUDIO)
 80029a8:	687b      	ldr	r3, [r7, #4]
 80029aa:	681b      	ldr	r3, [r3, #0]
 80029ac:	f003 5380 	and.w	r3, r3, #268435456	; 0x10000000
 80029b0:	2b00      	cmp	r3, #0
 80029b2:	d00b      	beq.n	80029cc <HAL_RCCEx_PeriphCLKConfig+0x4dc>
  {
    /* Check the parameters */
    assert_param(IS_RCC_DFSDM1AUDIOCLKSOURCE(PeriphClkInit->Dfsdm1AudioClockSelection));

    /* Configure the DFSDM interface clock source */
    __HAL_RCC_DFSDM1AUDIO_CONFIG(PeriphClkInit->Dfsdm1AudioClockSelection);
 80029b4:	4b80      	ldr	r3, [pc, #512]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 80029b6:	f8d3 308c 	ldr.w	r3, [r3, #140]	; 0x8c
 80029ba:	f023 6280 	bic.w	r2, r3, #67108864	; 0x4000000
 80029be:	687b      	ldr	r3, [r7, #4]
 80029c0:	f8d3 308c 	ldr.w	r3, [r3, #140]	; 0x8c
 80029c4:	497c      	ldr	r1, [pc, #496]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 80029c6:	4313      	orrs	r3, r2
 80029c8:	f8c1 308c 	str.w	r3, [r1, #140]	; 0x8c
  }
#endif /* STM32F767xx || STM32F769xx || STM32F777xx || STM32F779xx */

  /*-------------------------------------- PLLI2S Configuration ---------------------------------*/
  /* PLLI2S is configured when a peripheral will use it as source clock : SAI1, SAI2, I2S or SPDIF-RX */
  if((plli2sused == 1) || (PeriphClkInit->PeriphClockSelection == RCC_PERIPHCLK_PLLI2S))
 80029cc:	69fb      	ldr	r3, [r7, #28]
 80029ce:	2b01      	cmp	r3, #1
 80029d0:	d005      	beq.n	80029de <HAL_RCCEx_PeriphCLKConfig+0x4ee>
 80029d2:	687b      	ldr	r3, [r7, #4]
 80029d4:	681b      	ldr	r3, [r3, #0]
 80029d6:	f1b3 7f00 	cmp.w	r3, #33554432	; 0x2000000
 80029da:	f040 80d6 	bne.w	8002b8a <HAL_RCCEx_PeriphCLKConfig+0x69a>
  {
    /* Disable the PLLI2S */
    __HAL_RCC_PLLI2S_DISABLE();
 80029de:	4b76      	ldr	r3, [pc, #472]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 80029e0:	681b      	ldr	r3, [r3, #0]
 80029e2:	4a75      	ldr	r2, [pc, #468]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 80029e4:	f023 6380 	bic.w	r3, r3, #67108864	; 0x4000000
 80029e8:	6013      	str	r3, [r2, #0]

    /* Get Start Tick*/
    tickstart = HAL_GetTick();
 80029ea:	f7fe fd8b 	bl	8001504 <HAL_GetTick>
 80029ee:	6178      	str	r0, [r7, #20]

    /* Wait till PLLI2S is disabled */
    while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLI2SRDY)  != RESET)
 80029f0:	e008      	b.n	8002a04 <HAL_RCCEx_PeriphCLKConfig+0x514>
    {
      if((HAL_GetTick() - tickstart) > PLLI2S_TIMEOUT_VALUE)
 80029f2:	f7fe fd87 	bl	8001504 <HAL_GetTick>
 80029f6:	4602      	mov	r2, r0
 80029f8:	697b      	ldr	r3, [r7, #20]
 80029fa:	1ad3      	subs	r3, r2, r3
 80029fc:	2b64      	cmp	r3, #100	; 0x64
 80029fe:	d901      	bls.n	8002a04 <HAL_RCCEx_PeriphCLKConfig+0x514>
      {
        /* return in case of Timeout detected */
        return HAL_TIMEOUT;
 8002a00:	2303      	movs	r3, #3
 8002a02:	e194      	b.n	8002d2e <HAL_RCCEx_PeriphCLKConfig+0x83e>
    while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLI2SRDY)  != RESET)
 8002a04:	4b6c      	ldr	r3, [pc, #432]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 8002a06:	681b      	ldr	r3, [r3, #0]
 8002a08:	f003 6300 	and.w	r3, r3, #134217728	; 0x8000000
 8002a0c:	2b00      	cmp	r3, #0
 8002a0e:	d1f0      	bne.n	80029f2 <HAL_RCCEx_PeriphCLKConfig+0x502>

    /* check for common PLLI2S Parameters */
    assert_param(IS_RCC_PLLI2SN_VALUE(PeriphClkInit->PLLI2S.PLLI2SN));

    /*----------------- In Case of PLLI2S is selected as source clock for I2S -------------------*/
    if(((((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_I2S) == RCC_PERIPHCLK_I2S) && (PeriphClkInit->I2sClockSelection == RCC_I2SCLKSOURCE_PLLI2S)))
 8002a10:	687b      	ldr	r3, [r7, #4]
 8002a12:	681b      	ldr	r3, [r3, #0]
 8002a14:	f003 0301 	and.w	r3, r3, #1
 8002a18:	2b00      	cmp	r3, #0
 8002a1a:	d021      	beq.n	8002a60 <HAL_RCCEx_PeriphCLKConfig+0x570>
 8002a1c:	687b      	ldr	r3, [r7, #4]
 8002a1e:	6b5b      	ldr	r3, [r3, #52]	; 0x34
 8002a20:	2b00      	cmp	r3, #0
 8002a22:	d11d      	bne.n	8002a60 <HAL_RCCEx_PeriphCLKConfig+0x570>
    {
      /* check for Parameters */
      assert_param(IS_RCC_PLLI2SR_VALUE(PeriphClkInit->PLLI2S.PLLI2SR));

      /* Read PLLI2SP and PLLI2SQ value from PLLI2SCFGR register (this value is not needed for I2S configuration) */
      tmpreg0 = ((RCC->PLLI2SCFGR & RCC_PLLI2SCFGR_PLLI2SP) >> RCC_PLLI2SCFGR_PLLI2SP_Pos);
 8002a24:	4b64      	ldr	r3, [pc, #400]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 8002a26:	f8d3 3084 	ldr.w	r3, [r3, #132]	; 0x84
 8002a2a:	0c1b      	lsrs	r3, r3, #16
 8002a2c:	f003 0303 	and.w	r3, r3, #3
 8002a30:	613b      	str	r3, [r7, #16]
      tmpreg1 = ((RCC->PLLI2SCFGR & RCC_PLLI2SCFGR_PLLI2SQ) >> RCC_PLLI2SCFGR_PLLI2SQ_Pos);
 8002a32:	4b61      	ldr	r3, [pc, #388]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 8002a34:	f8d3 3084 	ldr.w	r3, [r3, #132]	; 0x84
 8002a38:	0e1b      	lsrs	r3, r3, #24
 8002a3a:	f003 030f 	and.w	r3, r3, #15
 8002a3e:	60fb      	str	r3, [r7, #12]
      /* Configure the PLLI2S division factors */
      /* PLLI2S_VCO = f(VCO clock) = f(PLLI2S clock input) x (PLLI2SN/PLLM) */
      /* I2SCLK = f(PLLI2S clock output) = f(VCO clock) / PLLI2SR */
      __HAL_RCC_PLLI2S_CONFIG(PeriphClkInit->PLLI2S.PLLI2SN , tmpreg0, tmpreg1, PeriphClkInit->PLLI2S.PLLI2SR);
 8002a40:	687b      	ldr	r3, [r7, #4]
 8002a42:	685b      	ldr	r3, [r3, #4]
 8002a44:	019a      	lsls	r2, r3, #6
 8002a46:	693b      	ldr	r3, [r7, #16]
 8002a48:	041b      	lsls	r3, r3, #16
 8002a4a:	431a      	orrs	r2, r3
 8002a4c:	68fb      	ldr	r3, [r7, #12]
 8002a4e:	061b      	lsls	r3, r3, #24
 8002a50:	431a      	orrs	r2, r3
 8002a52:	687b      	ldr	r3, [r7, #4]
 8002a54:	689b      	ldr	r3, [r3, #8]
 8002a56:	071b      	lsls	r3, r3, #28
 8002a58:	4957      	ldr	r1, [pc, #348]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 8002a5a:	4313      	orrs	r3, r2
 8002a5c:	f8c1 3084 	str.w	r3, [r1, #132]	; 0x84
    }

    /*----------------- In Case of PLLI2S is selected as source clock for SAI -------------------*/
    if(((((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_SAI1) == RCC_PERIPHCLK_SAI1) && (PeriphClkInit->Sai1ClockSelection == RCC_SAI1CLKSOURCE_PLLI2S)) ||
 8002a60:	687b      	ldr	r3, [r7, #4]
 8002a62:	681b      	ldr	r3, [r3, #0]
 8002a64:	f403 2300 	and.w	r3, r3, #524288	; 0x80000
 8002a68:	2b00      	cmp	r3, #0
 8002a6a:	d004      	beq.n	8002a76 <HAL_RCCEx_PeriphCLKConfig+0x586>
 8002a6c:	687b      	ldr	r3, [r7, #4]
 8002a6e:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8002a70:	f5b3 1f80 	cmp.w	r3, #1048576	; 0x100000
 8002a74:	d00a      	beq.n	8002a8c <HAL_RCCEx_PeriphCLKConfig+0x59c>
       ((((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_SAI2) == RCC_PERIPHCLK_SAI2) && (PeriphClkInit->Sai2ClockSelection == RCC_SAI2CLKSOURCE_PLLI2S)))
 8002a76:	687b      	ldr	r3, [r7, #4]
 8002a78:	681b      	ldr	r3, [r3, #0]
 8002a7a:	f403 1380 	and.w	r3, r3, #1048576	; 0x100000
    if(((((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_SAI1) == RCC_PERIPHCLK_SAI1) && (PeriphClkInit->Sai1ClockSelection == RCC_SAI1CLKSOURCE_PLLI2S)) ||
 8002a7e:	2b00      	cmp	r3, #0
 8002a80:	d02e      	beq.n	8002ae0 <HAL_RCCEx_PeriphCLKConfig+0x5f0>
       ((((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_SAI2) == RCC_PERIPHCLK_SAI2) && (PeriphClkInit->Sai2ClockSelection == RCC_SAI2CLKSOURCE_PLLI2S)))
 8002a82:	687b      	ldr	r3, [r7, #4]
 8002a84:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 8002a86:	f5b3 0f80 	cmp.w	r3, #4194304	; 0x400000
 8002a8a:	d129      	bne.n	8002ae0 <HAL_RCCEx_PeriphCLKConfig+0x5f0>
      assert_param(IS_RCC_PLLI2SQ_VALUE(PeriphClkInit->PLLI2S.PLLI2SQ));
      /* Check for PLLI2S/DIVQ parameters */
      assert_param(IS_RCC_PLLI2S_DIVQ_VALUE(PeriphClkInit->PLLI2SDivQ));

      /* Read PLLI2SP and PLLI2SR values from PLLI2SCFGR register (this value is not needed for SAI configuration) */
      tmpreg0 = ((RCC->PLLI2SCFGR & RCC_PLLI2SCFGR_PLLI2SP) >> RCC_PLLI2SCFGR_PLLI2SP_Pos);
 8002a8c:	4b4a      	ldr	r3, [pc, #296]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 8002a8e:	f8d3 3084 	ldr.w	r3, [r3, #132]	; 0x84
 8002a92:	0c1b      	lsrs	r3, r3, #16
 8002a94:	f003 0303 	and.w	r3, r3, #3
 8002a98:	613b      	str	r3, [r7, #16]
      tmpreg1 = ((RCC->PLLI2SCFGR & RCC_PLLI2SCFGR_PLLI2SR) >> RCC_PLLI2SCFGR_PLLI2SR_Pos);
 8002a9a:	4b47      	ldr	r3, [pc, #284]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 8002a9c:	f8d3 3084 	ldr.w	r3, [r3, #132]	; 0x84
 8002aa0:	0f1b      	lsrs	r3, r3, #28
 8002aa2:	f003 0307 	and.w	r3, r3, #7
 8002aa6:	60fb      	str	r3, [r7, #12]
      /* Configure the PLLI2S division factors */
      /* PLLI2S_VCO Input  = PLL_SOURCE/PLLM */
      /* PLLI2S_VCO Output = PLLI2S_VCO Input * PLLI2SN */
      /* SAI_CLK(first level) = PLLI2S_VCO Output/PLLI2SQ */
      __HAL_RCC_PLLI2S_CONFIG(PeriphClkInit->PLLI2S.PLLI2SN, tmpreg0, PeriphClkInit->PLLI2S.PLLI2SQ, tmpreg1);
 8002aa8:	687b      	ldr	r3, [r7, #4]
 8002aaa:	685b      	ldr	r3, [r3, #4]
 8002aac:	019a      	lsls	r2, r3, #6
 8002aae:	693b      	ldr	r3, [r7, #16]
 8002ab0:	041b      	lsls	r3, r3, #16
 8002ab2:	431a      	orrs	r2, r3
 8002ab4:	687b      	ldr	r3, [r7, #4]
 8002ab6:	68db      	ldr	r3, [r3, #12]
 8002ab8:	061b      	lsls	r3, r3, #24
 8002aba:	431a      	orrs	r2, r3
 8002abc:	68fb      	ldr	r3, [r7, #12]
 8002abe:	071b      	lsls	r3, r3, #28
 8002ac0:	493d      	ldr	r1, [pc, #244]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 8002ac2:	4313      	orrs	r3, r2
 8002ac4:	f8c1 3084 	str.w	r3, [r1, #132]	; 0x84

      /* SAI_CLK_x = SAI_CLK(first level)/PLLI2SDIVQ */
      __HAL_RCC_PLLI2S_PLLSAICLKDIVQ_CONFIG(PeriphClkInit->PLLI2SDivQ);
 8002ac8:	4b3b      	ldr	r3, [pc, #236]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 8002aca:	f8d3 308c 	ldr.w	r3, [r3, #140]	; 0x8c
 8002ace:	f023 021f 	bic.w	r2, r3, #31
 8002ad2:	687b      	ldr	r3, [r7, #4]
 8002ad4:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8002ad6:	3b01      	subs	r3, #1
 8002ad8:	4937      	ldr	r1, [pc, #220]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 8002ada:	4313      	orrs	r3, r2
 8002adc:	f8c1 308c 	str.w	r3, [r1, #140]	; 0x8c
    }

    /*----------------- In Case of PLLI2S is selected as source clock for SPDIF-RX -------------------*/
    if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_SPDIFRX) == RCC_PERIPHCLK_SPDIFRX)
 8002ae0:	687b      	ldr	r3, [r7, #4]
 8002ae2:	681b      	ldr	r3, [r3, #0]
 8002ae4:	f003 7380 	and.w	r3, r3, #16777216	; 0x1000000
 8002ae8:	2b00      	cmp	r3, #0
 8002aea:	d01d      	beq.n	8002b28 <HAL_RCCEx_PeriphCLKConfig+0x638>
    {
      /* check for Parameters */
      assert_param(IS_RCC_PLLI2SP_VALUE(PeriphClkInit->PLLI2S.PLLI2SP));

     /* Read PLLI2SR value from PLLI2SCFGR register (this value is not needed for SPDIF-RX configuration) */
      tmpreg0 = ((RCC->PLLI2SCFGR & RCC_PLLI2SCFGR_PLLI2SQ) >> RCC_PLLI2SCFGR_PLLI2SQ_Pos);
 8002aec:	4b32      	ldr	r3, [pc, #200]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 8002aee:	f8d3 3084 	ldr.w	r3, [r3, #132]	; 0x84
 8002af2:	0e1b      	lsrs	r3, r3, #24
 8002af4:	f003 030f 	and.w	r3, r3, #15
 8002af8:	613b      	str	r3, [r7, #16]
      tmpreg1 = ((RCC->PLLI2SCFGR & RCC_PLLI2SCFGR_PLLI2SR) >> RCC_PLLI2SCFGR_PLLI2SR_Pos);
 8002afa:	4b2f      	ldr	r3, [pc, #188]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 8002afc:	f8d3 3084 	ldr.w	r3, [r3, #132]	; 0x84
 8002b00:	0f1b      	lsrs	r3, r3, #28
 8002b02:	f003 0307 	and.w	r3, r3, #7
 8002b06:	60fb      	str	r3, [r7, #12]
      /* Configure the PLLI2S division factors */
      /* PLLI2S_VCO = f(VCO clock) = f(PLLI2S clock input) x (PLLI2SN/PLLM) */
      /* SPDIFCLK = f(PLLI2S clock output) = f(VCO clock) / PLLI2SP */
      __HAL_RCC_PLLI2S_CONFIG(PeriphClkInit->PLLI2S.PLLI2SN , PeriphClkInit->PLLI2S.PLLI2SP, tmpreg0, tmpreg1);
 8002b08:	687b      	ldr	r3, [r7, #4]
 8002b0a:	685b      	ldr	r3, [r3, #4]
 8002b0c:	019a      	lsls	r2, r3, #6
 8002b0e:	687b      	ldr	r3, [r7, #4]
 8002b10:	691b      	ldr	r3, [r3, #16]
 8002b12:	041b      	lsls	r3, r3, #16
 8002b14:	431a      	orrs	r2, r3
 8002b16:	693b      	ldr	r3, [r7, #16]
 8002b18:	061b      	lsls	r3, r3, #24
 8002b1a:	431a      	orrs	r2, r3
 8002b1c:	68fb      	ldr	r3, [r7, #12]
 8002b1e:	071b      	lsls	r3, r3, #28
 8002b20:	4925      	ldr	r1, [pc, #148]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 8002b22:	4313      	orrs	r3, r2
 8002b24:	f8c1 3084 	str.w	r3, [r1, #132]	; 0x84
    }

    /*----------------- In Case of PLLI2S is just selected  -----------------*/
    if((PeriphClkInit->PeriphClockSelection & RCC_PERIPHCLK_PLLI2S) == RCC_PERIPHCLK_PLLI2S)
 8002b28:	687b      	ldr	r3, [r7, #4]
 8002b2a:	681b      	ldr	r3, [r3, #0]
 8002b2c:	f003 7300 	and.w	r3, r3, #33554432	; 0x2000000
 8002b30:	2b00      	cmp	r3, #0
 8002b32:	d011      	beq.n	8002b58 <HAL_RCCEx_PeriphCLKConfig+0x668>
      assert_param(IS_RCC_PLLI2SQ_VALUE(PeriphClkInit->PLLI2S.PLLI2SQ));

      /* Configure the PLLI2S division factors */
      /* PLLI2S_VCO = f(VCO clock) = f(PLLI2S clock input) x (PLLI2SN/PLLI2SM) */
      /* SPDIFRXCLK = f(PLLI2S clock output) = f(VCO clock) / PLLI2SP */
      __HAL_RCC_PLLI2S_CONFIG(PeriphClkInit->PLLI2S.PLLI2SN , PeriphClkInit->PLLI2S.PLLI2SP, PeriphClkInit->PLLI2S.PLLI2SQ, PeriphClkInit->PLLI2S.PLLI2SR);
 8002b34:	687b      	ldr	r3, [r7, #4]
 8002b36:	685b      	ldr	r3, [r3, #4]
 8002b38:	019a      	lsls	r2, r3, #6
 8002b3a:	687b      	ldr	r3, [r7, #4]
 8002b3c:	691b      	ldr	r3, [r3, #16]
 8002b3e:	041b      	lsls	r3, r3, #16
 8002b40:	431a      	orrs	r2, r3
 8002b42:	687b      	ldr	r3, [r7, #4]
 8002b44:	68db      	ldr	r3, [r3, #12]
 8002b46:	061b      	lsls	r3, r3, #24
 8002b48:	431a      	orrs	r2, r3
 8002b4a:	687b      	ldr	r3, [r7, #4]
 8002b4c:	689b      	ldr	r3, [r3, #8]
 8002b4e:	071b      	lsls	r3, r3, #28
 8002b50:	4919      	ldr	r1, [pc, #100]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 8002b52:	4313      	orrs	r3, r2
 8002b54:	f8c1 3084 	str.w	r3, [r1, #132]	; 0x84
    }

    /* Enable the PLLI2S */
    __HAL_RCC_PLLI2S_ENABLE();
 8002b58:	4b17      	ldr	r3, [pc, #92]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 8002b5a:	681b      	ldr	r3, [r3, #0]
 8002b5c:	4a16      	ldr	r2, [pc, #88]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 8002b5e:	f043 6380 	orr.w	r3, r3, #67108864	; 0x4000000
 8002b62:	6013      	str	r3, [r2, #0]

    /* Get Start Tick*/
    tickstart = HAL_GetTick();
 8002b64:	f7fe fcce 	bl	8001504 <HAL_GetTick>
 8002b68:	6178      	str	r0, [r7, #20]

    /* Wait till PLLI2S is ready */
    while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLI2SRDY)  == RESET)
 8002b6a:	e008      	b.n	8002b7e <HAL_RCCEx_PeriphCLKConfig+0x68e>
    {
      if((HAL_GetTick() - tickstart) > PLLI2S_TIMEOUT_VALUE)
 8002b6c:	f7fe fcca 	bl	8001504 <HAL_GetTick>
 8002b70:	4602      	mov	r2, r0
 8002b72:	697b      	ldr	r3, [r7, #20]
 8002b74:	1ad3      	subs	r3, r2, r3
 8002b76:	2b64      	cmp	r3, #100	; 0x64
 8002b78:	d901      	bls.n	8002b7e <HAL_RCCEx_PeriphCLKConfig+0x68e>
      {
        /* return in case of Timeout detected */
        return HAL_TIMEOUT;
 8002b7a:	2303      	movs	r3, #3
 8002b7c:	e0d7      	b.n	8002d2e <HAL_RCCEx_PeriphCLKConfig+0x83e>
    while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLI2SRDY)  == RESET)
 8002b7e:	4b0e      	ldr	r3, [pc, #56]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 8002b80:	681b      	ldr	r3, [r3, #0]
 8002b82:	f003 6300 	and.w	r3, r3, #134217728	; 0x8000000
 8002b86:	2b00      	cmp	r3, #0
 8002b88:	d0f0      	beq.n	8002b6c <HAL_RCCEx_PeriphCLKConfig+0x67c>
    }
  }

  /*-------------------------------------- PLLSAI Configuration ---------------------------------*/
  /* PLLSAI is configured when a peripheral will use it as source clock : SAI1, SAI2, LTDC or CK48 */
  if(pllsaiused == 1)
 8002b8a:	69bb      	ldr	r3, [r7, #24]
 8002b8c:	2b01      	cmp	r3, #1
 8002b8e:	f040 80cd 	bne.w	8002d2c <HAL_RCCEx_PeriphCLKConfig+0x83c>
  {
    /* Disable PLLSAI Clock */
    __HAL_RCC_PLLSAI_DISABLE();
 8002b92:	4b09      	ldr	r3, [pc, #36]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 8002b94:	681b      	ldr	r3, [r3, #0]
 8002b96:	4a08      	ldr	r2, [pc, #32]	; (8002bb8 <HAL_RCCEx_PeriphCLKConfig+0x6c8>)
 8002b98:	f023 5380 	bic.w	r3, r3, #268435456	; 0x10000000
 8002b9c:	6013      	str	r3, [r2, #0]

    /* Get Start Tick*/
    tickstart = HAL_GetTick();
 8002b9e:	f7fe fcb1 	bl	8001504 <HAL_GetTick>
 8002ba2:	6178      	str	r0, [r7, #20]

    /* Wait till PLLSAI is disabled */
    while(__HAL_RCC_PLLSAI_GET_FLAG() != RESET)
 8002ba4:	e00a      	b.n	8002bbc <HAL_RCCEx_PeriphCLKConfig+0x6cc>
    {
      if((HAL_GetTick() - tickstart) > PLLSAI_TIMEOUT_VALUE)
 8002ba6:	f7fe fcad 	bl	8001504 <HAL_GetTick>
 8002baa:	4602      	mov	r2, r0
 8002bac:	697b      	ldr	r3, [r7, #20]
 8002bae:	1ad3      	subs	r3, r2, r3
 8002bb0:	2b64      	cmp	r3, #100	; 0x64
 8002bb2:	d903      	bls.n	8002bbc <HAL_RCCEx_PeriphCLKConfig+0x6cc>
      {
        /* return in case of Timeout detected */
        return HAL_TIMEOUT;
 8002bb4:	2303      	movs	r3, #3
 8002bb6:	e0ba      	b.n	8002d2e <HAL_RCCEx_PeriphCLKConfig+0x83e>
 8002bb8:	40023800 	.word	0x40023800
    while(__HAL_RCC_PLLSAI_GET_FLAG() != RESET)
 8002bbc:	4b5e      	ldr	r3, [pc, #376]	; (8002d38 <HAL_RCCEx_PeriphCLKConfig+0x848>)
 8002bbe:	681b      	ldr	r3, [r3, #0]
 8002bc0:	f003 5300 	and.w	r3, r3, #536870912	; 0x20000000
 8002bc4:	f1b3 5f00 	cmp.w	r3, #536870912	; 0x20000000
 8002bc8:	d0ed      	beq.n	8002ba6 <HAL_RCCEx_PeriphCLKConfig+0x6b6>

    /* Check the PLLSAI division factors */
    assert_param(IS_RCC_PLLSAIN_VALUE(PeriphClkInit->PLLSAI.PLLSAIN));

    /*----------------- In Case of PLLSAI is selected as source clock for SAI -------------------*/
    if(((((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_SAI1) == RCC_PERIPHCLK_SAI1) && (PeriphClkInit->Sai1ClockSelection == RCC_SAI1CLKSOURCE_PLLSAI)) ||\
 8002bca:	687b      	ldr	r3, [r7, #4]
 8002bcc:	681b      	ldr	r3, [r3, #0]
 8002bce:	f403 2300 	and.w	r3, r3, #524288	; 0x80000
 8002bd2:	2b00      	cmp	r3, #0
 8002bd4:	d003      	beq.n	8002bde <HAL_RCCEx_PeriphCLKConfig+0x6ee>
 8002bd6:	687b      	ldr	r3, [r7, #4]
 8002bd8:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8002bda:	2b00      	cmp	r3, #0
 8002bdc:	d009      	beq.n	8002bf2 <HAL_RCCEx_PeriphCLKConfig+0x702>
       ((((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_SAI2) == RCC_PERIPHCLK_SAI2) && (PeriphClkInit->Sai2ClockSelection == RCC_SAI2CLKSOURCE_PLLSAI)))
 8002bde:	687b      	ldr	r3, [r7, #4]
 8002be0:	681b      	ldr	r3, [r3, #0]
 8002be2:	f403 1380 	and.w	r3, r3, #1048576	; 0x100000
    if(((((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_SAI1) == RCC_PERIPHCLK_SAI1) && (PeriphClkInit->Sai1ClockSelection == RCC_SAI1CLKSOURCE_PLLSAI)) ||\
 8002be6:	2b00      	cmp	r3, #0
 8002be8:	d02e      	beq.n	8002c48 <HAL_RCCEx_PeriphCLKConfig+0x758>
       ((((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_SAI2) == RCC_PERIPHCLK_SAI2) && (PeriphClkInit->Sai2ClockSelection == RCC_SAI2CLKSOURCE_PLLSAI)))
 8002bea:	687b      	ldr	r3, [r7, #4]
 8002bec:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 8002bee:	2b00      	cmp	r3, #0
 8002bf0:	d12a      	bne.n	8002c48 <HAL_RCCEx_PeriphCLKConfig+0x758>
      assert_param(IS_RCC_PLLSAIQ_VALUE(PeriphClkInit->PLLSAI.PLLSAIQ));
      /* check for PLLSAI/DIVQ Parameter */
      assert_param(IS_RCC_PLLSAI_DIVQ_VALUE(PeriphClkInit->PLLSAIDivQ));

      /* Read PLLSAIP value from PLLSAICFGR register (this value is not needed for SAI configuration) */
      tmpreg0 = ((RCC->PLLSAICFGR & RCC_PLLSAICFGR_PLLSAIP) >> RCC_PLLSAICFGR_PLLSAIP_Pos);
 8002bf2:	4b51      	ldr	r3, [pc, #324]	; (8002d38 <HAL_RCCEx_PeriphCLKConfig+0x848>)
 8002bf4:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8002bf8:	0c1b      	lsrs	r3, r3, #16
 8002bfa:	f003 0303 	and.w	r3, r3, #3
 8002bfe:	613b      	str	r3, [r7, #16]
      tmpreg1 = ((RCC->PLLSAICFGR & RCC_PLLI2SCFGR_PLLI2SR) >> RCC_PLLSAICFGR_PLLSAIR_Pos);
 8002c00:	4b4d      	ldr	r3, [pc, #308]	; (8002d38 <HAL_RCCEx_PeriphCLKConfig+0x848>)
 8002c02:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8002c06:	0f1b      	lsrs	r3, r3, #28
 8002c08:	f003 0307 	and.w	r3, r3, #7
 8002c0c:	60fb      	str	r3, [r7, #12]
      /* PLLSAI_VCO Input  = PLL_SOURCE/PLLM */
      /* PLLSAI_VCO Output = PLLSAI_VCO Input * PLLSAIN */
      /* SAI_CLK(first level) = PLLSAI_VCO Output/PLLSAIQ */
      __HAL_RCC_PLLSAI_CONFIG(PeriphClkInit->PLLSAI.PLLSAIN , tmpreg0, PeriphClkInit->PLLSAI.PLLSAIQ, tmpreg1);
 8002c0e:	687b      	ldr	r3, [r7, #4]
 8002c10:	695b      	ldr	r3, [r3, #20]
 8002c12:	019a      	lsls	r2, r3, #6
 8002c14:	693b      	ldr	r3, [r7, #16]
 8002c16:	041b      	lsls	r3, r3, #16
 8002c18:	431a      	orrs	r2, r3
 8002c1a:	687b      	ldr	r3, [r7, #4]
 8002c1c:	699b      	ldr	r3, [r3, #24]
 8002c1e:	061b      	lsls	r3, r3, #24
 8002c20:	431a      	orrs	r2, r3
 8002c22:	68fb      	ldr	r3, [r7, #12]
 8002c24:	071b      	lsls	r3, r3, #28
 8002c26:	4944      	ldr	r1, [pc, #272]	; (8002d38 <HAL_RCCEx_PeriphCLKConfig+0x848>)
 8002c28:	4313      	orrs	r3, r2
 8002c2a:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88

      /* SAI_CLK_x = SAI_CLK(first level)/PLLSAIDIVQ */
      __HAL_RCC_PLLSAI_PLLSAICLKDIVQ_CONFIG(PeriphClkInit->PLLSAIDivQ);
 8002c2e:	4b42      	ldr	r3, [pc, #264]	; (8002d38 <HAL_RCCEx_PeriphCLKConfig+0x848>)
 8002c30:	f8d3 308c 	ldr.w	r3, [r3, #140]	; 0x8c
 8002c34:	f423 52f8 	bic.w	r2, r3, #7936	; 0x1f00
 8002c38:	687b      	ldr	r3, [r7, #4]
 8002c3a:	6a9b      	ldr	r3, [r3, #40]	; 0x28
 8002c3c:	3b01      	subs	r3, #1
 8002c3e:	021b      	lsls	r3, r3, #8
 8002c40:	493d      	ldr	r1, [pc, #244]	; (8002d38 <HAL_RCCEx_PeriphCLKConfig+0x848>)
 8002c42:	4313      	orrs	r3, r2
 8002c44:	f8c1 308c 	str.w	r3, [r1, #140]	; 0x8c
    }

    /*----------------- In Case of PLLSAI is selected as source clock for CLK48 -------------------*/
    /* In Case of PLLI2S is selected as source clock for CK48 */
    if((((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_CLK48) == RCC_PERIPHCLK_CLK48) && (PeriphClkInit->Clk48ClockSelection == RCC_CLK48SOURCE_PLLSAIP))
 8002c48:	687b      	ldr	r3, [r7, #4]
 8002c4a:	681b      	ldr	r3, [r3, #0]
 8002c4c:	f403 1300 	and.w	r3, r3, #2097152	; 0x200000
 8002c50:	2b00      	cmp	r3, #0
 8002c52:	d022      	beq.n	8002c9a <HAL_RCCEx_PeriphCLKConfig+0x7aa>
 8002c54:	687b      	ldr	r3, [r7, #4]
 8002c56:	6fdb      	ldr	r3, [r3, #124]	; 0x7c
 8002c58:	f1b3 6f00 	cmp.w	r3, #134217728	; 0x8000000
 8002c5c:	d11d      	bne.n	8002c9a <HAL_RCCEx_PeriphCLKConfig+0x7aa>
    {
      /* check for Parameters */
      assert_param(IS_RCC_PLLSAIP_VALUE(PeriphClkInit->PLLSAI.PLLSAIP));
      /* Read PLLSAIQ and PLLSAIR value from PLLSAICFGR register (this value is not needed for CK48 configuration) */
      tmpreg0 = ((RCC->PLLSAICFGR & RCC_PLLSAICFGR_PLLSAIQ) >> RCC_PLLSAICFGR_PLLSAIQ_Pos);
 8002c5e:	4b36      	ldr	r3, [pc, #216]	; (8002d38 <HAL_RCCEx_PeriphCLKConfig+0x848>)
 8002c60:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8002c64:	0e1b      	lsrs	r3, r3, #24
 8002c66:	f003 030f 	and.w	r3, r3, #15
 8002c6a:	613b      	str	r3, [r7, #16]
      tmpreg1 = ((RCC->PLLSAICFGR & RCC_PLLSAICFGR_PLLSAIR) >> RCC_PLLSAICFGR_PLLSAIR_Pos);
 8002c6c:	4b32      	ldr	r3, [pc, #200]	; (8002d38 <HAL_RCCEx_PeriphCLKConfig+0x848>)
 8002c6e:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8002c72:	0f1b      	lsrs	r3, r3, #28
 8002c74:	f003 0307 	and.w	r3, r3, #7
 8002c78:	60fb      	str	r3, [r7, #12]

      /* Configure the PLLSAI division factors */
      /* PLLSAI_VCO = f(VCO clock) = f(PLLSAI clock input) x (PLLI2SN/PLLM) */
      /* 48CLK = f(PLLSAI clock output) = f(VCO clock) / PLLSAIP */
      __HAL_RCC_PLLSAI_CONFIG(PeriphClkInit->PLLSAI.PLLSAIN , PeriphClkInit->PLLSAI.PLLSAIP, tmpreg0, tmpreg1);
 8002c7a:	687b      	ldr	r3, [r7, #4]
 8002c7c:	695b      	ldr	r3, [r3, #20]
 8002c7e:	019a      	lsls	r2, r3, #6
 8002c80:	687b      	ldr	r3, [r7, #4]
 8002c82:	6a1b      	ldr	r3, [r3, #32]
 8002c84:	041b      	lsls	r3, r3, #16
 8002c86:	431a      	orrs	r2, r3
 8002c88:	693b      	ldr	r3, [r7, #16]
 8002c8a:	061b      	lsls	r3, r3, #24
 8002c8c:	431a      	orrs	r2, r3
 8002c8e:	68fb      	ldr	r3, [r7, #12]
 8002c90:	071b      	lsls	r3, r3, #28
 8002c92:	4929      	ldr	r1, [pc, #164]	; (8002d38 <HAL_RCCEx_PeriphCLKConfig+0x848>)
 8002c94:	4313      	orrs	r3, r2
 8002c96:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88
    }

#if defined(STM32F746xx) || defined(STM32F756xx) || defined (STM32F767xx) || defined (STM32F769xx) || defined (STM32F777xx) || defined (STM32F779xx) || defined (STM32F750xx)
    /*---------------------------- LTDC configuration -------------------------------*/
    if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_LTDC) == (RCC_PERIPHCLK_LTDC))
 8002c9a:	687b      	ldr	r3, [r7, #4]
 8002c9c:	681b      	ldr	r3, [r3, #0]
 8002c9e:	f003 0308 	and.w	r3, r3, #8
 8002ca2:	2b00      	cmp	r3, #0
 8002ca4:	d028      	beq.n	8002cf8 <HAL_RCCEx_PeriphCLKConfig+0x808>
    {
      assert_param(IS_RCC_PLLSAIR_VALUE(PeriphClkInit->PLLSAI.PLLSAIR));
      assert_param(IS_RCC_PLLSAI_DIVR_VALUE(PeriphClkInit->PLLSAIDivR));

      /* Read PLLSAIP and PLLSAIQ value from PLLSAICFGR register (these value are not needed for LTDC configuration) */
      tmpreg0 = ((RCC->PLLSAICFGR & RCC_PLLSAICFGR_PLLSAIQ) >> RCC_PLLSAICFGR_PLLSAIQ_Pos);
 8002ca6:	4b24      	ldr	r3, [pc, #144]	; (8002d38 <HAL_RCCEx_PeriphCLKConfig+0x848>)
 8002ca8:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8002cac:	0e1b      	lsrs	r3, r3, #24
 8002cae:	f003 030f 	and.w	r3, r3, #15
 8002cb2:	613b      	str	r3, [r7, #16]
      tmpreg1 = ((RCC->PLLSAICFGR & RCC_PLLSAICFGR_PLLSAIP) >> RCC_PLLSAICFGR_PLLSAIP_Pos);
 8002cb4:	4b20      	ldr	r3, [pc, #128]	; (8002d38 <HAL_RCCEx_PeriphCLKConfig+0x848>)
 8002cb6:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8002cba:	0c1b      	lsrs	r3, r3, #16
 8002cbc:	f003 0303 	and.w	r3, r3, #3
 8002cc0:	60fb      	str	r3, [r7, #12]

      /* PLLSAI_VCO Input  = PLL_SOURCE/PLLM */
      /* PLLSAI_VCO Output = PLLSAI_VCO Input * PLLSAIN */
      /* LTDC_CLK(first level) = PLLSAI_VCO Output/PLLSAIR */
      __HAL_RCC_PLLSAI_CONFIG(PeriphClkInit->PLLSAI.PLLSAIN , tmpreg1, tmpreg0, PeriphClkInit->PLLSAI.PLLSAIR);
 8002cc2:	687b      	ldr	r3, [r7, #4]
 8002cc4:	695b      	ldr	r3, [r3, #20]
 8002cc6:	019a      	lsls	r2, r3, #6
 8002cc8:	68fb      	ldr	r3, [r7, #12]
 8002cca:	041b      	lsls	r3, r3, #16
 8002ccc:	431a      	orrs	r2, r3
 8002cce:	693b      	ldr	r3, [r7, #16]
 8002cd0:	061b      	lsls	r3, r3, #24
 8002cd2:	431a      	orrs	r2, r3
 8002cd4:	687b      	ldr	r3, [r7, #4]
 8002cd6:	69db      	ldr	r3, [r3, #28]
 8002cd8:	071b      	lsls	r3, r3, #28
 8002cda:	4917      	ldr	r1, [pc, #92]	; (8002d38 <HAL_RCCEx_PeriphCLKConfig+0x848>)
 8002cdc:	4313      	orrs	r3, r2
 8002cde:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88

      /* LTDC_CLK = LTDC_CLK(first level)/PLLSAIDIVR */
      __HAL_RCC_PLLSAI_PLLSAICLKDIVR_CONFIG(PeriphClkInit->PLLSAIDivR);
 8002ce2:	4b15      	ldr	r3, [pc, #84]	; (8002d38 <HAL_RCCEx_PeriphCLKConfig+0x848>)
 8002ce4:	f8d3 308c 	ldr.w	r3, [r3, #140]	; 0x8c
 8002ce8:	f423 3240 	bic.w	r2, r3, #196608	; 0x30000
 8002cec:	687b      	ldr	r3, [r7, #4]
 8002cee:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8002cf0:	4911      	ldr	r1, [pc, #68]	; (8002d38 <HAL_RCCEx_PeriphCLKConfig+0x848>)
 8002cf2:	4313      	orrs	r3, r2
 8002cf4:	f8c1 308c 	str.w	r3, [r1, #140]	; 0x8c
    }
#endif /* STM32F746xx || STM32F756xx || STM32F767xx || STM32F769xx || STM32F777xx || STM32F779xx || STM32F750xx  */

    /* Enable PLLSAI Clock */
    __HAL_RCC_PLLSAI_ENABLE();
 8002cf8:	4b0f      	ldr	r3, [pc, #60]	; (8002d38 <HAL_RCCEx_PeriphCLKConfig+0x848>)
 8002cfa:	681b      	ldr	r3, [r3, #0]
 8002cfc:	4a0e      	ldr	r2, [pc, #56]	; (8002d38 <HAL_RCCEx_PeriphCLKConfig+0x848>)
 8002cfe:	f043 5380 	orr.w	r3, r3, #268435456	; 0x10000000
 8002d02:	6013      	str	r3, [r2, #0]

    /* Get Start Tick*/
    tickstart = HAL_GetTick();
 8002d04:	f7fe fbfe 	bl	8001504 <HAL_GetTick>
 8002d08:	6178      	str	r0, [r7, #20]

    /* Wait till PLLSAI is ready */
    while(__HAL_RCC_PLLSAI_GET_FLAG() == RESET)
 8002d0a:	e008      	b.n	8002d1e <HAL_RCCEx_PeriphCLKConfig+0x82e>
    {
      if((HAL_GetTick() - tickstart) > PLLSAI_TIMEOUT_VALUE)
 8002d0c:	f7fe fbfa 	bl	8001504 <HAL_GetTick>
 8002d10:	4602      	mov	r2, r0
 8002d12:	697b      	ldr	r3, [r7, #20]
 8002d14:	1ad3      	subs	r3, r2, r3
 8002d16:	2b64      	cmp	r3, #100	; 0x64
 8002d18:	d901      	bls.n	8002d1e <HAL_RCCEx_PeriphCLKConfig+0x82e>
      {
        /* return in case of Timeout detected */
        return HAL_TIMEOUT;
 8002d1a:	2303      	movs	r3, #3
 8002d1c:	e007      	b.n	8002d2e <HAL_RCCEx_PeriphCLKConfig+0x83e>
    while(__HAL_RCC_PLLSAI_GET_FLAG() == RESET)
 8002d1e:	4b06      	ldr	r3, [pc, #24]	; (8002d38 <HAL_RCCEx_PeriphCLKConfig+0x848>)
 8002d20:	681b      	ldr	r3, [r3, #0]
 8002d22:	f003 5300 	and.w	r3, r3, #536870912	; 0x20000000
 8002d26:	f1b3 5f00 	cmp.w	r3, #536870912	; 0x20000000
 8002d2a:	d1ef      	bne.n	8002d0c <HAL_RCCEx_PeriphCLKConfig+0x81c>
      }
    }
  }
  return HAL_OK;
 8002d2c:	2300      	movs	r3, #0
}
 8002d2e:	4618      	mov	r0, r3
 8002d30:	3720      	adds	r7, #32
 8002d32:	46bd      	mov	sp, r7
 8002d34:	bd80      	pop	{r7, pc}
 8002d36:	bf00      	nop
 8002d38:	40023800 	.word	0x40023800

08002d3c <HAL_RNG_Init>:
  * @param  hrng pointer to a RNG_HandleTypeDef structure that contains
  *                the configuration information for RNG.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_RNG_Init(RNG_HandleTypeDef *hrng)
{
 8002d3c:	b580      	push	{r7, lr}
 8002d3e:	b082      	sub	sp, #8
 8002d40:	af00      	add	r7, sp, #0
 8002d42:	6078      	str	r0, [r7, #4]
  /* Check the RNG handle allocation */
  if (hrng == NULL)
 8002d44:	687b      	ldr	r3, [r7, #4]
 8002d46:	2b00      	cmp	r3, #0
 8002d48:	d101      	bne.n	8002d4e <HAL_RNG_Init+0x12>
  {
    return HAL_ERROR;
 8002d4a:	2301      	movs	r3, #1
 8002d4c:	e01c      	b.n	8002d88 <HAL_RNG_Init+0x4c>

    /* Init the low level hardware */
    hrng->MspInitCallback(hrng);
  }
#else
  if (hrng->State == HAL_RNG_STATE_RESET)
 8002d4e:	687b      	ldr	r3, [r7, #4]
 8002d50:	795b      	ldrb	r3, [r3, #5]
 8002d52:	b2db      	uxtb	r3, r3
 8002d54:	2b00      	cmp	r3, #0
 8002d56:	d105      	bne.n	8002d64 <HAL_RNG_Init+0x28>
  {
    /* Allocate lock resource and initialize it */
    hrng->Lock = HAL_UNLOCKED;
 8002d58:	687b      	ldr	r3, [r7, #4]
 8002d5a:	2200      	movs	r2, #0
 8002d5c:	711a      	strb	r2, [r3, #4]

    /* Init the low level hardware */
    HAL_RNG_MspInit(hrng);
 8002d5e:	6878      	ldr	r0, [r7, #4]
 8002d60:	f7fe f944 	bl	8000fec <HAL_RNG_MspInit>
  }
#endif /* USE_HAL_RNG_REGISTER_CALLBACKS */

  /* Change RNG peripheral state */
  hrng->State = HAL_RNG_STATE_BUSY;
 8002d64:	687b      	ldr	r3, [r7, #4]
 8002d66:	2202      	movs	r2, #2
 8002d68:	715a      	strb	r2, [r3, #5]


  /* Enable the RNG Peripheral */
  __HAL_RNG_ENABLE(hrng);
 8002d6a:	687b      	ldr	r3, [r7, #4]
 8002d6c:	681b      	ldr	r3, [r3, #0]
 8002d6e:	681a      	ldr	r2, [r3, #0]
 8002d70:	687b      	ldr	r3, [r7, #4]
 8002d72:	681b      	ldr	r3, [r3, #0]
 8002d74:	f042 0204 	orr.w	r2, r2, #4
 8002d78:	601a      	str	r2, [r3, #0]

  /* Initialize the RNG state */
  hrng->State = HAL_RNG_STATE_READY;
 8002d7a:	687b      	ldr	r3, [r7, #4]
 8002d7c:	2201      	movs	r2, #1
 8002d7e:	715a      	strb	r2, [r3, #5]

  /* Initialise the error code */
  hrng->ErrorCode = HAL_RNG_ERROR_NONE;
 8002d80:	687b      	ldr	r3, [r7, #4]
 8002d82:	2200      	movs	r2, #0
 8002d84:	609a      	str	r2, [r3, #8]

  /* Return function status */
  return HAL_OK;
 8002d86:	2300      	movs	r3, #0
}
 8002d88:	4618      	mov	r0, r3
 8002d8a:	3708      	adds	r7, #8
 8002d8c:	46bd      	mov	sp, r7
 8002d8e:	bd80      	pop	{r7, pc}

08002d90 <HAL_SPI_Init>:
  * @param  hspi pointer to a SPI_HandleTypeDef structure that contains
  *               the configuration information for SPI module.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_SPI_Init(SPI_HandleTypeDef *hspi)
{
 8002d90:	b580      	push	{r7, lr}
 8002d92:	b084      	sub	sp, #16
 8002d94:	af00      	add	r7, sp, #0
 8002d96:	6078      	str	r0, [r7, #4]
  uint32_t frxth;

  /* Check the SPI handle allocation */
  if (hspi == NULL)
 8002d98:	687b      	ldr	r3, [r7, #4]
 8002d9a:	2b00      	cmp	r3, #0
 8002d9c:	d101      	bne.n	8002da2 <HAL_SPI_Init+0x12>
  {
    return HAL_ERROR;
 8002d9e:	2301      	movs	r3, #1
 8002da0:	e084      	b.n	8002eac <HAL_SPI_Init+0x11c>
  {
    assert_param(IS_SPI_CRC_POLYNOMIAL(hspi->Init.CRCPolynomial));
    assert_param(IS_SPI_CRC_LENGTH(hspi->Init.CRCLength));
  }
#else
  hspi->Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;
 8002da2:	687b      	ldr	r3, [r7, #4]
 8002da4:	2200      	movs	r2, #0
 8002da6:	629a      	str	r2, [r3, #40]	; 0x28
#endif /* USE_SPI_CRC */

  if (hspi->State == HAL_SPI_STATE_RESET)
 8002da8:	687b      	ldr	r3, [r7, #4]
 8002daa:	f893 305d 	ldrb.w	r3, [r3, #93]	; 0x5d
 8002dae:	b2db      	uxtb	r3, r3
 8002db0:	2b00      	cmp	r3, #0
 8002db2:	d106      	bne.n	8002dc2 <HAL_SPI_Init+0x32>
  {
    /* Allocate lock resource and initialize it */
    hspi->Lock = HAL_UNLOCKED;
 8002db4:	687b      	ldr	r3, [r7, #4]
 8002db6:	2200      	movs	r2, #0
 8002db8:	f883 205c 	strb.w	r2, [r3, #92]	; 0x5c

    /* Init the low level hardware : GPIO, CLOCK, NVIC... */
    hspi->MspInitCallback(hspi);
#else
    /* Init the low level hardware : GPIO, CLOCK, NVIC... */
    HAL_SPI_MspInit(hspi);
 8002dbc:	6878      	ldr	r0, [r7, #4]
 8002dbe:	f7fe f973 	bl	80010a8 <HAL_SPI_MspInit>
#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
  }

  hspi->State = HAL_SPI_STATE_BUSY;
 8002dc2:	687b      	ldr	r3, [r7, #4]
 8002dc4:	2202      	movs	r2, #2
 8002dc6:	f883 205d 	strb.w	r2, [r3, #93]	; 0x5d

  /* Disable the selected SPI peripheral */
  __HAL_SPI_DISABLE(hspi);
 8002dca:	687b      	ldr	r3, [r7, #4]
 8002dcc:	681b      	ldr	r3, [r3, #0]
 8002dce:	681a      	ldr	r2, [r3, #0]
 8002dd0:	687b      	ldr	r3, [r7, #4]
 8002dd2:	681b      	ldr	r3, [r3, #0]
 8002dd4:	f022 0240 	bic.w	r2, r2, #64	; 0x40
 8002dd8:	601a      	str	r2, [r3, #0]

  /* Align by default the rs fifo threshold on the data size */
  if (hspi->Init.DataSize > SPI_DATASIZE_8BIT)
 8002dda:	687b      	ldr	r3, [r7, #4]
 8002ddc:	68db      	ldr	r3, [r3, #12]
 8002dde:	f5b3 6fe0 	cmp.w	r3, #1792	; 0x700
 8002de2:	d902      	bls.n	8002dea <HAL_SPI_Init+0x5a>
  {
    frxth = SPI_RXFIFO_THRESHOLD_HF;
 8002de4:	2300      	movs	r3, #0
 8002de6:	60fb      	str	r3, [r7, #12]
 8002de8:	e002      	b.n	8002df0 <HAL_SPI_Init+0x60>
  }
  else
  {
    frxth = SPI_RXFIFO_THRESHOLD_QF;
 8002dea:	f44f 5380 	mov.w	r3, #4096	; 0x1000
 8002dee:	60fb      	str	r3, [r7, #12]
  }

  /* CRC calculation is valid only for 16Bit and 8 Bit */
  if ((hspi->Init.DataSize != SPI_DATASIZE_16BIT) && (hspi->Init.DataSize != SPI_DATASIZE_8BIT))
 8002df0:	687b      	ldr	r3, [r7, #4]
 8002df2:	68db      	ldr	r3, [r3, #12]
 8002df4:	f5b3 6f70 	cmp.w	r3, #3840	; 0xf00
 8002df8:	d007      	beq.n	8002e0a <HAL_SPI_Init+0x7a>
 8002dfa:	687b      	ldr	r3, [r7, #4]
 8002dfc:	68db      	ldr	r3, [r3, #12]
 8002dfe:	f5b3 6fe0 	cmp.w	r3, #1792	; 0x700
 8002e02:	d002      	beq.n	8002e0a <HAL_SPI_Init+0x7a>
  {
    /* CRC must be disabled */
    hspi->Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;
 8002e04:	687b      	ldr	r3, [r7, #4]
 8002e06:	2200      	movs	r2, #0
 8002e08:	629a      	str	r2, [r3, #40]	; 0x28
  }

  /* Align the CRC Length on the data size */
  if (hspi->Init.CRCLength == SPI_CRC_LENGTH_DATASIZE)
 8002e0a:	687b      	ldr	r3, [r7, #4]
 8002e0c:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8002e0e:	2b00      	cmp	r3, #0
 8002e10:	d10b      	bne.n	8002e2a <HAL_SPI_Init+0x9a>
  {
    /* CRC Length aligned on the data size : value set by default */
    if (hspi->Init.DataSize > SPI_DATASIZE_8BIT)
 8002e12:	687b      	ldr	r3, [r7, #4]
 8002e14:	68db      	ldr	r3, [r3, #12]
 8002e16:	f5b3 6fe0 	cmp.w	r3, #1792	; 0x700
 8002e1a:	d903      	bls.n	8002e24 <HAL_SPI_Init+0x94>
    {
      hspi->Init.CRCLength = SPI_CRC_LENGTH_16BIT;
 8002e1c:	687b      	ldr	r3, [r7, #4]
 8002e1e:	2202      	movs	r2, #2
 8002e20:	631a      	str	r2, [r3, #48]	; 0x30
 8002e22:	e002      	b.n	8002e2a <HAL_SPI_Init+0x9a>
    }
    else
    {
      hspi->Init.CRCLength = SPI_CRC_LENGTH_8BIT;
 8002e24:	687b      	ldr	r3, [r7, #4]
 8002e26:	2201      	movs	r2, #1
 8002e28:	631a      	str	r2, [r3, #48]	; 0x30
  }

  /*----------------------- SPIx CR1 & CR2 Configuration ---------------------*/
  /* Configure : SPI Mode, Communication Mode, Clock polarity and phase, NSS management,
  Communication speed, First bit and CRC calculation state */
  WRITE_REG(hspi->Instance->CR1, (hspi->Init.Mode | hspi->Init.Direction |
 8002e2a:	687b      	ldr	r3, [r7, #4]
 8002e2c:	685a      	ldr	r2, [r3, #4]
 8002e2e:	687b      	ldr	r3, [r7, #4]
 8002e30:	689b      	ldr	r3, [r3, #8]
 8002e32:	431a      	orrs	r2, r3
 8002e34:	687b      	ldr	r3, [r7, #4]
 8002e36:	691b      	ldr	r3, [r3, #16]
 8002e38:	431a      	orrs	r2, r3
 8002e3a:	687b      	ldr	r3, [r7, #4]
 8002e3c:	695b      	ldr	r3, [r3, #20]
 8002e3e:	431a      	orrs	r2, r3
 8002e40:	687b      	ldr	r3, [r7, #4]
 8002e42:	699b      	ldr	r3, [r3, #24]
 8002e44:	f403 7300 	and.w	r3, r3, #512	; 0x200
 8002e48:	431a      	orrs	r2, r3
 8002e4a:	687b      	ldr	r3, [r7, #4]
 8002e4c:	69db      	ldr	r3, [r3, #28]
 8002e4e:	431a      	orrs	r2, r3
 8002e50:	687b      	ldr	r3, [r7, #4]
 8002e52:	6a1b      	ldr	r3, [r3, #32]
 8002e54:	ea42 0103 	orr.w	r1, r2, r3
 8002e58:	687b      	ldr	r3, [r7, #4]
 8002e5a:	6a9a      	ldr	r2, [r3, #40]	; 0x28
 8002e5c:	687b      	ldr	r3, [r7, #4]
 8002e5e:	681b      	ldr	r3, [r3, #0]
 8002e60:	430a      	orrs	r2, r1
 8002e62:	601a      	str	r2, [r3, #0]
    hspi->Instance->CR1 |= SPI_CR1_CRCL;
  }
#endif /* USE_SPI_CRC */

  /* Configure : NSS management, TI Mode, NSS Pulse, Data size and Rx Fifo threshold */
  WRITE_REG(hspi->Instance->CR2, (((hspi->Init.NSS >> 16U) & SPI_CR2_SSOE) | hspi->Init.TIMode |
 8002e64:	687b      	ldr	r3, [r7, #4]
 8002e66:	699b      	ldr	r3, [r3, #24]
 8002e68:	0c1b      	lsrs	r3, r3, #16
 8002e6a:	f003 0204 	and.w	r2, r3, #4
 8002e6e:	687b      	ldr	r3, [r7, #4]
 8002e70:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8002e72:	431a      	orrs	r2, r3
 8002e74:	687b      	ldr	r3, [r7, #4]
 8002e76:	6b5b      	ldr	r3, [r3, #52]	; 0x34
 8002e78:	431a      	orrs	r2, r3
 8002e7a:	687b      	ldr	r3, [r7, #4]
 8002e7c:	68db      	ldr	r3, [r3, #12]
 8002e7e:	ea42 0103 	orr.w	r1, r2, r3
 8002e82:	687b      	ldr	r3, [r7, #4]
 8002e84:	681b      	ldr	r3, [r3, #0]
 8002e86:	68fa      	ldr	r2, [r7, #12]
 8002e88:	430a      	orrs	r2, r1
 8002e8a:	605a      	str	r2, [r3, #4]
  }
#endif /* USE_SPI_CRC */

#if defined(SPI_I2SCFGR_I2SMOD)
  /* Activate the SPI mode (Make sure that I2SMOD bit in I2SCFGR register is reset) */
  CLEAR_BIT(hspi->Instance->I2SCFGR, SPI_I2SCFGR_I2SMOD);
 8002e8c:	687b      	ldr	r3, [r7, #4]
 8002e8e:	681b      	ldr	r3, [r3, #0]
 8002e90:	69da      	ldr	r2, [r3, #28]
 8002e92:	687b      	ldr	r3, [r7, #4]
 8002e94:	681b      	ldr	r3, [r3, #0]
 8002e96:	f422 6200 	bic.w	r2, r2, #2048	; 0x800
 8002e9a:	61da      	str	r2, [r3, #28]
#endif /* SPI_I2SCFGR_I2SMOD */

  hspi->ErrorCode = HAL_SPI_ERROR_NONE;
 8002e9c:	687b      	ldr	r3, [r7, #4]
 8002e9e:	2200      	movs	r2, #0
 8002ea0:	661a      	str	r2, [r3, #96]	; 0x60
  hspi->State     = HAL_SPI_STATE_READY;
 8002ea2:	687b      	ldr	r3, [r7, #4]
 8002ea4:	2201      	movs	r2, #1
 8002ea6:	f883 205d 	strb.w	r2, [r3, #93]	; 0x5d

  return HAL_OK;
 8002eaa:	2300      	movs	r3, #0
}
 8002eac:	4618      	mov	r0, r3
 8002eae:	3710      	adds	r7, #16
 8002eb0:	46bd      	mov	sp, r7
 8002eb2:	bd80      	pop	{r7, pc}

08002eb4 <HAL_SPI_Transmit>:
  * @param  Size amount of data to be sent
  * @param  Timeout Timeout duration
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_SPI_Transmit(SPI_HandleTypeDef *hspi, uint8_t *pData, uint16_t Size, uint32_t Timeout)
{
 8002eb4:	b580      	push	{r7, lr}
 8002eb6:	b088      	sub	sp, #32
 8002eb8:	af00      	add	r7, sp, #0
 8002eba:	60f8      	str	r0, [r7, #12]
 8002ebc:	60b9      	str	r1, [r7, #8]
 8002ebe:	603b      	str	r3, [r7, #0]
 8002ec0:	4613      	mov	r3, r2
 8002ec2:	80fb      	strh	r3, [r7, #6]
  uint32_t tickstart;
  HAL_StatusTypeDef errorcode = HAL_OK;
 8002ec4:	2300      	movs	r3, #0
 8002ec6:	77fb      	strb	r3, [r7, #31]

  /* Check Direction parameter */
  assert_param(IS_SPI_DIRECTION_2LINES_OR_1LINE(hspi->Init.Direction));

  /* Process Locked */
  __HAL_LOCK(hspi);
 8002ec8:	68fb      	ldr	r3, [r7, #12]
 8002eca:	f893 305c 	ldrb.w	r3, [r3, #92]	; 0x5c
 8002ece:	2b01      	cmp	r3, #1
 8002ed0:	d101      	bne.n	8002ed6 <HAL_SPI_Transmit+0x22>
 8002ed2:	2302      	movs	r3, #2
 8002ed4:	e150      	b.n	8003178 <HAL_SPI_Transmit+0x2c4>
 8002ed6:	68fb      	ldr	r3, [r7, #12]
 8002ed8:	2201      	movs	r2, #1
 8002eda:	f883 205c 	strb.w	r2, [r3, #92]	; 0x5c

  /* Init tickstart for timeout management*/
  tickstart = HAL_GetTick();
 8002ede:	f7fe fb11 	bl	8001504 <HAL_GetTick>
 8002ee2:	61b8      	str	r0, [r7, #24]
  initial_TxXferCount = Size;
 8002ee4:	88fb      	ldrh	r3, [r7, #6]
 8002ee6:	82fb      	strh	r3, [r7, #22]

  if (hspi->State != HAL_SPI_STATE_READY)
 8002ee8:	68fb      	ldr	r3, [r7, #12]
 8002eea:	f893 305d 	ldrb.w	r3, [r3, #93]	; 0x5d
 8002eee:	b2db      	uxtb	r3, r3
 8002ef0:	2b01      	cmp	r3, #1
 8002ef2:	d002      	beq.n	8002efa <HAL_SPI_Transmit+0x46>
  {
    errorcode = HAL_BUSY;
 8002ef4:	2302      	movs	r3, #2
 8002ef6:	77fb      	strb	r3, [r7, #31]
    goto error;
 8002ef8:	e135      	b.n	8003166 <HAL_SPI_Transmit+0x2b2>
  }

  if ((pData == NULL) || (Size == 0U))
 8002efa:	68bb      	ldr	r3, [r7, #8]
 8002efc:	2b00      	cmp	r3, #0
 8002efe:	d002      	beq.n	8002f06 <HAL_SPI_Transmit+0x52>
 8002f00:	88fb      	ldrh	r3, [r7, #6]
 8002f02:	2b00      	cmp	r3, #0
 8002f04:	d102      	bne.n	8002f0c <HAL_SPI_Transmit+0x58>
  {
    errorcode = HAL_ERROR;
 8002f06:	2301      	movs	r3, #1
 8002f08:	77fb      	strb	r3, [r7, #31]
    goto error;
 8002f0a:	e12c      	b.n	8003166 <HAL_SPI_Transmit+0x2b2>
  }

  /* Set the transaction information */
  hspi->State       = HAL_SPI_STATE_BUSY_TX;
 8002f0c:	68fb      	ldr	r3, [r7, #12]
 8002f0e:	2203      	movs	r2, #3
 8002f10:	f883 205d 	strb.w	r2, [r3, #93]	; 0x5d
  hspi->ErrorCode   = HAL_SPI_ERROR_NONE;
 8002f14:	68fb      	ldr	r3, [r7, #12]
 8002f16:	2200      	movs	r2, #0
 8002f18:	661a      	str	r2, [r3, #96]	; 0x60
  hspi->pTxBuffPtr  = (uint8_t *)pData;
 8002f1a:	68fb      	ldr	r3, [r7, #12]
 8002f1c:	68ba      	ldr	r2, [r7, #8]
 8002f1e:	639a      	str	r2, [r3, #56]	; 0x38
  hspi->TxXferSize  = Size;
 8002f20:	68fb      	ldr	r3, [r7, #12]
 8002f22:	88fa      	ldrh	r2, [r7, #6]
 8002f24:	879a      	strh	r2, [r3, #60]	; 0x3c
  hspi->TxXferCount = Size;
 8002f26:	68fb      	ldr	r3, [r7, #12]
 8002f28:	88fa      	ldrh	r2, [r7, #6]
 8002f2a:	87da      	strh	r2, [r3, #62]	; 0x3e

  /*Init field not used in handle to zero */
  hspi->pRxBuffPtr  = (uint8_t *)NULL;
 8002f2c:	68fb      	ldr	r3, [r7, #12]
 8002f2e:	2200      	movs	r2, #0
 8002f30:	641a      	str	r2, [r3, #64]	; 0x40
  hspi->RxXferSize  = 0U;
 8002f32:	68fb      	ldr	r3, [r7, #12]
 8002f34:	2200      	movs	r2, #0
 8002f36:	f8a3 2044 	strh.w	r2, [r3, #68]	; 0x44
  hspi->RxXferCount = 0U;
 8002f3a:	68fb      	ldr	r3, [r7, #12]
 8002f3c:	2200      	movs	r2, #0
 8002f3e:	f8a3 2046 	strh.w	r2, [r3, #70]	; 0x46
  hspi->TxISR       = NULL;
 8002f42:	68fb      	ldr	r3, [r7, #12]
 8002f44:	2200      	movs	r2, #0
 8002f46:	651a      	str	r2, [r3, #80]	; 0x50
  hspi->RxISR       = NULL;
 8002f48:	68fb      	ldr	r3, [r7, #12]
 8002f4a:	2200      	movs	r2, #0
 8002f4c:	64da      	str	r2, [r3, #76]	; 0x4c

  /* Configure communication direction : 1Line */
  if (hspi->Init.Direction == SPI_DIRECTION_1LINE)
 8002f4e:	68fb      	ldr	r3, [r7, #12]
 8002f50:	689b      	ldr	r3, [r3, #8]
 8002f52:	f5b3 4f00 	cmp.w	r3, #32768	; 0x8000
 8002f56:	d107      	bne.n	8002f68 <HAL_SPI_Transmit+0xb4>
  {
    SPI_1LINE_TX(hspi);
 8002f58:	68fb      	ldr	r3, [r7, #12]
 8002f5a:	681b      	ldr	r3, [r3, #0]
 8002f5c:	681a      	ldr	r2, [r3, #0]
 8002f5e:	68fb      	ldr	r3, [r7, #12]
 8002f60:	681b      	ldr	r3, [r3, #0]
 8002f62:	f442 4280 	orr.w	r2, r2, #16384	; 0x4000
 8002f66:	601a      	str	r2, [r3, #0]
    SPI_RESET_CRC(hspi);
  }
#endif /* USE_SPI_CRC */

  /* Check if the SPI is already enabled */
  if ((hspi->Instance->CR1 & SPI_CR1_SPE) != SPI_CR1_SPE)
 8002f68:	68fb      	ldr	r3, [r7, #12]
 8002f6a:	681b      	ldr	r3, [r3, #0]
 8002f6c:	681b      	ldr	r3, [r3, #0]
 8002f6e:	f003 0340 	and.w	r3, r3, #64	; 0x40
 8002f72:	2b40      	cmp	r3, #64	; 0x40
 8002f74:	d007      	beq.n	8002f86 <HAL_SPI_Transmit+0xd2>
  {
    /* Enable SPI peripheral */
    __HAL_SPI_ENABLE(hspi);
 8002f76:	68fb      	ldr	r3, [r7, #12]
 8002f78:	681b      	ldr	r3, [r3, #0]
 8002f7a:	681a      	ldr	r2, [r3, #0]
 8002f7c:	68fb      	ldr	r3, [r7, #12]
 8002f7e:	681b      	ldr	r3, [r3, #0]
 8002f80:	f042 0240 	orr.w	r2, r2, #64	; 0x40
 8002f84:	601a      	str	r2, [r3, #0]
  }

  /* Transmit data in 16 Bit mode */
  if (hspi->Init.DataSize > SPI_DATASIZE_8BIT)
 8002f86:	68fb      	ldr	r3, [r7, #12]
 8002f88:	68db      	ldr	r3, [r3, #12]
 8002f8a:	f5b3 6fe0 	cmp.w	r3, #1792	; 0x700
 8002f8e:	d94b      	bls.n	8003028 <HAL_SPI_Transmit+0x174>
  {
    if ((hspi->Init.Mode == SPI_MODE_SLAVE) || (initial_TxXferCount == 0x01U))
 8002f90:	68fb      	ldr	r3, [r7, #12]
 8002f92:	685b      	ldr	r3, [r3, #4]
 8002f94:	2b00      	cmp	r3, #0
 8002f96:	d002      	beq.n	8002f9e <HAL_SPI_Transmit+0xea>
 8002f98:	8afb      	ldrh	r3, [r7, #22]
 8002f9a:	2b01      	cmp	r3, #1
 8002f9c:	d13e      	bne.n	800301c <HAL_SPI_Transmit+0x168>
    {
      hspi->Instance->DR = *((uint16_t *)hspi->pTxBuffPtr);
 8002f9e:	68fb      	ldr	r3, [r7, #12]
 8002fa0:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8002fa2:	881a      	ldrh	r2, [r3, #0]
 8002fa4:	68fb      	ldr	r3, [r7, #12]
 8002fa6:	681b      	ldr	r3, [r3, #0]
 8002fa8:	60da      	str	r2, [r3, #12]
      hspi->pTxBuffPtr += sizeof(uint16_t);
 8002faa:	68fb      	ldr	r3, [r7, #12]
 8002fac:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8002fae:	1c9a      	adds	r2, r3, #2
 8002fb0:	68fb      	ldr	r3, [r7, #12]
 8002fb2:	639a      	str	r2, [r3, #56]	; 0x38
      hspi->TxXferCount--;
 8002fb4:	68fb      	ldr	r3, [r7, #12]
 8002fb6:	8fdb      	ldrh	r3, [r3, #62]	; 0x3e
 8002fb8:	b29b      	uxth	r3, r3
 8002fba:	3b01      	subs	r3, #1
 8002fbc:	b29a      	uxth	r2, r3
 8002fbe:	68fb      	ldr	r3, [r7, #12]
 8002fc0:	87da      	strh	r2, [r3, #62]	; 0x3e
    }
    /* Transmit data in 16 Bit mode */
    while (hspi->TxXferCount > 0U)
 8002fc2:	e02b      	b.n	800301c <HAL_SPI_Transmit+0x168>
    {
      /* Wait until TXE flag is set to send data */
      if (__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_TXE))
 8002fc4:	68fb      	ldr	r3, [r7, #12]
 8002fc6:	681b      	ldr	r3, [r3, #0]
 8002fc8:	689b      	ldr	r3, [r3, #8]
 8002fca:	f003 0302 	and.w	r3, r3, #2
 8002fce:	2b02      	cmp	r3, #2
 8002fd0:	d112      	bne.n	8002ff8 <HAL_SPI_Transmit+0x144>
      {
        hspi->Instance->DR = *((uint16_t *)hspi->pTxBuffPtr);
 8002fd2:	68fb      	ldr	r3, [r7, #12]
 8002fd4:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8002fd6:	881a      	ldrh	r2, [r3, #0]
 8002fd8:	68fb      	ldr	r3, [r7, #12]
 8002fda:	681b      	ldr	r3, [r3, #0]
 8002fdc:	60da      	str	r2, [r3, #12]
        hspi->pTxBuffPtr += sizeof(uint16_t);
 8002fde:	68fb      	ldr	r3, [r7, #12]
 8002fe0:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8002fe2:	1c9a      	adds	r2, r3, #2
 8002fe4:	68fb      	ldr	r3, [r7, #12]
 8002fe6:	639a      	str	r2, [r3, #56]	; 0x38
        hspi->TxXferCount--;
 8002fe8:	68fb      	ldr	r3, [r7, #12]
 8002fea:	8fdb      	ldrh	r3, [r3, #62]	; 0x3e
 8002fec:	b29b      	uxth	r3, r3
 8002fee:	3b01      	subs	r3, #1
 8002ff0:	b29a      	uxth	r2, r3
 8002ff2:	68fb      	ldr	r3, [r7, #12]
 8002ff4:	87da      	strh	r2, [r3, #62]	; 0x3e
 8002ff6:	e011      	b.n	800301c <HAL_SPI_Transmit+0x168>
      }
      else
      {
        /* Timeout management */
        if ((((HAL_GetTick() - tickstart) >=  Timeout) && (Timeout != HAL_MAX_DELAY)) || (Timeout == 0U))
 8002ff8:	f7fe fa84 	bl	8001504 <HAL_GetTick>
 8002ffc:	4602      	mov	r2, r0
 8002ffe:	69bb      	ldr	r3, [r7, #24]
 8003000:	1ad3      	subs	r3, r2, r3
 8003002:	683a      	ldr	r2, [r7, #0]
 8003004:	429a      	cmp	r2, r3
 8003006:	d803      	bhi.n	8003010 <HAL_SPI_Transmit+0x15c>
 8003008:	683b      	ldr	r3, [r7, #0]
 800300a:	f1b3 3fff 	cmp.w	r3, #4294967295	; 0xffffffff
 800300e:	d102      	bne.n	8003016 <HAL_SPI_Transmit+0x162>
 8003010:	683b      	ldr	r3, [r7, #0]
 8003012:	2b00      	cmp	r3, #0
 8003014:	d102      	bne.n	800301c <HAL_SPI_Transmit+0x168>
        {
          errorcode = HAL_TIMEOUT;
 8003016:	2303      	movs	r3, #3
 8003018:	77fb      	strb	r3, [r7, #31]
          goto error;
 800301a:	e0a4      	b.n	8003166 <HAL_SPI_Transmit+0x2b2>
    while (hspi->TxXferCount > 0U)
 800301c:	68fb      	ldr	r3, [r7, #12]
 800301e:	8fdb      	ldrh	r3, [r3, #62]	; 0x3e
 8003020:	b29b      	uxth	r3, r3
 8003022:	2b00      	cmp	r3, #0
 8003024:	d1ce      	bne.n	8002fc4 <HAL_SPI_Transmit+0x110>
 8003026:	e07c      	b.n	8003122 <HAL_SPI_Transmit+0x26e>
    }
  }
  /* Transmit data in 8 Bit mode */
  else
  {
    if ((hspi->Init.Mode == SPI_MODE_SLAVE) || (initial_TxXferCount == 0x01U))
 8003028:	68fb      	ldr	r3, [r7, #12]
 800302a:	685b      	ldr	r3, [r3, #4]
 800302c:	2b00      	cmp	r3, #0
 800302e:	d002      	beq.n	8003036 <HAL_SPI_Transmit+0x182>
 8003030:	8afb      	ldrh	r3, [r7, #22]
 8003032:	2b01      	cmp	r3, #1
 8003034:	d170      	bne.n	8003118 <HAL_SPI_Transmit+0x264>
    {
      if (hspi->TxXferCount > 1U)
 8003036:	68fb      	ldr	r3, [r7, #12]
 8003038:	8fdb      	ldrh	r3, [r3, #62]	; 0x3e
 800303a:	b29b      	uxth	r3, r3
 800303c:	2b01      	cmp	r3, #1
 800303e:	d912      	bls.n	8003066 <HAL_SPI_Transmit+0x1b2>
      {
        /* write on the data register in packing mode */
        hspi->Instance->DR = *((uint16_t *)hspi->pTxBuffPtr);
 8003040:	68fb      	ldr	r3, [r7, #12]
 8003042:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8003044:	881a      	ldrh	r2, [r3, #0]
 8003046:	68fb      	ldr	r3, [r7, #12]
 8003048:	681b      	ldr	r3, [r3, #0]
 800304a:	60da      	str	r2, [r3, #12]
        hspi->pTxBuffPtr += sizeof(uint16_t);
 800304c:	68fb      	ldr	r3, [r7, #12]
 800304e:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8003050:	1c9a      	adds	r2, r3, #2
 8003052:	68fb      	ldr	r3, [r7, #12]
 8003054:	639a      	str	r2, [r3, #56]	; 0x38
        hspi->TxXferCount -= 2U;
 8003056:	68fb      	ldr	r3, [r7, #12]
 8003058:	8fdb      	ldrh	r3, [r3, #62]	; 0x3e
 800305a:	b29b      	uxth	r3, r3
 800305c:	3b02      	subs	r3, #2
 800305e:	b29a      	uxth	r2, r3
 8003060:	68fb      	ldr	r3, [r7, #12]
 8003062:	87da      	strh	r2, [r3, #62]	; 0x3e
 8003064:	e058      	b.n	8003118 <HAL_SPI_Transmit+0x264>
      }
      else
      {
        *((__IO uint8_t *)&hspi->Instance->DR) = (*hspi->pTxBuffPtr);
 8003066:	68fb      	ldr	r3, [r7, #12]
 8003068:	6b9a      	ldr	r2, [r3, #56]	; 0x38
 800306a:	68fb      	ldr	r3, [r7, #12]
 800306c:	681b      	ldr	r3, [r3, #0]
 800306e:	330c      	adds	r3, #12
 8003070:	7812      	ldrb	r2, [r2, #0]
 8003072:	701a      	strb	r2, [r3, #0]
        hspi->pTxBuffPtr ++;
 8003074:	68fb      	ldr	r3, [r7, #12]
 8003076:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8003078:	1c5a      	adds	r2, r3, #1
 800307a:	68fb      	ldr	r3, [r7, #12]
 800307c:	639a      	str	r2, [r3, #56]	; 0x38
        hspi->TxXferCount--;
 800307e:	68fb      	ldr	r3, [r7, #12]
 8003080:	8fdb      	ldrh	r3, [r3, #62]	; 0x3e
 8003082:	b29b      	uxth	r3, r3
 8003084:	3b01      	subs	r3, #1
 8003086:	b29a      	uxth	r2, r3
 8003088:	68fb      	ldr	r3, [r7, #12]
 800308a:	87da      	strh	r2, [r3, #62]	; 0x3e
      }
    }
    while (hspi->TxXferCount > 0U)
 800308c:	e044      	b.n	8003118 <HAL_SPI_Transmit+0x264>
    {
      /* Wait until TXE flag is set to send data */
      if (__HAL_SPI_GET_FLAG(hspi, SPI_FLAG_TXE))
 800308e:	68fb      	ldr	r3, [r7, #12]
 8003090:	681b      	ldr	r3, [r3, #0]
 8003092:	689b      	ldr	r3, [r3, #8]
 8003094:	f003 0302 	and.w	r3, r3, #2
 8003098:	2b02      	cmp	r3, #2
 800309a:	d12b      	bne.n	80030f4 <HAL_SPI_Transmit+0x240>
      {
        if (hspi->TxXferCount > 1U)
 800309c:	68fb      	ldr	r3, [r7, #12]
 800309e:	8fdb      	ldrh	r3, [r3, #62]	; 0x3e
 80030a0:	b29b      	uxth	r3, r3
 80030a2:	2b01      	cmp	r3, #1
 80030a4:	d912      	bls.n	80030cc <HAL_SPI_Transmit+0x218>
        {
          /* write on the data register in packing mode */
          hspi->Instance->DR = *((uint16_t *)hspi->pTxBuffPtr);
 80030a6:	68fb      	ldr	r3, [r7, #12]
 80030a8:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 80030aa:	881a      	ldrh	r2, [r3, #0]
 80030ac:	68fb      	ldr	r3, [r7, #12]
 80030ae:	681b      	ldr	r3, [r3, #0]
 80030b0:	60da      	str	r2, [r3, #12]
          hspi->pTxBuffPtr += sizeof(uint16_t);
 80030b2:	68fb      	ldr	r3, [r7, #12]
 80030b4:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 80030b6:	1c9a      	adds	r2, r3, #2
 80030b8:	68fb      	ldr	r3, [r7, #12]
 80030ba:	639a      	str	r2, [r3, #56]	; 0x38
          hspi->TxXferCount -= 2U;
 80030bc:	68fb      	ldr	r3, [r7, #12]
 80030be:	8fdb      	ldrh	r3, [r3, #62]	; 0x3e
 80030c0:	b29b      	uxth	r3, r3
 80030c2:	3b02      	subs	r3, #2
 80030c4:	b29a      	uxth	r2, r3
 80030c6:	68fb      	ldr	r3, [r7, #12]
 80030c8:	87da      	strh	r2, [r3, #62]	; 0x3e
 80030ca:	e025      	b.n	8003118 <HAL_SPI_Transmit+0x264>
        }
        else
        {
          *((__IO uint8_t *)&hspi->Instance->DR) = (*hspi->pTxBuffPtr);
 80030cc:	68fb      	ldr	r3, [r7, #12]
 80030ce:	6b9a      	ldr	r2, [r3, #56]	; 0x38
 80030d0:	68fb      	ldr	r3, [r7, #12]
 80030d2:	681b      	ldr	r3, [r3, #0]
 80030d4:	330c      	adds	r3, #12
 80030d6:	7812      	ldrb	r2, [r2, #0]
 80030d8:	701a      	strb	r2, [r3, #0]
          hspi->pTxBuffPtr++;
 80030da:	68fb      	ldr	r3, [r7, #12]
 80030dc:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 80030de:	1c5a      	adds	r2, r3, #1
 80030e0:	68fb      	ldr	r3, [r7, #12]
 80030e2:	639a      	str	r2, [r3, #56]	; 0x38
          hspi->TxXferCount--;
 80030e4:	68fb      	ldr	r3, [r7, #12]
 80030e6:	8fdb      	ldrh	r3, [r3, #62]	; 0x3e
 80030e8:	b29b      	uxth	r3, r3
 80030ea:	3b01      	subs	r3, #1
 80030ec:	b29a      	uxth	r2, r3
 80030ee:	68fb      	ldr	r3, [r7, #12]
 80030f0:	87da      	strh	r2, [r3, #62]	; 0x3e
 80030f2:	e011      	b.n	8003118 <HAL_SPI_Transmit+0x264>
        }
      }
      else
      {
        /* Timeout management */
        if ((((HAL_GetTick() - tickstart) >=  Timeout) && (Timeout != HAL_MAX_DELAY)) || (Timeout == 0U))
 80030f4:	f7fe fa06 	bl	8001504 <HAL_GetTick>
 80030f8:	4602      	mov	r2, r0
 80030fa:	69bb      	ldr	r3, [r7, #24]
 80030fc:	1ad3      	subs	r3, r2, r3
 80030fe:	683a      	ldr	r2, [r7, #0]
 8003100:	429a      	cmp	r2, r3
 8003102:	d803      	bhi.n	800310c <HAL_SPI_Transmit+0x258>
 8003104:	683b      	ldr	r3, [r7, #0]
 8003106:	f1b3 3fff 	cmp.w	r3, #4294967295	; 0xffffffff
 800310a:	d102      	bne.n	8003112 <HAL_SPI_Transmit+0x25e>
 800310c:	683b      	ldr	r3, [r7, #0]
 800310e:	2b00      	cmp	r3, #0
 8003110:	d102      	bne.n	8003118 <HAL_SPI_Transmit+0x264>
        {
          errorcode = HAL_TIMEOUT;
 8003112:	2303      	movs	r3, #3
 8003114:	77fb      	strb	r3, [r7, #31]
          goto error;
 8003116:	e026      	b.n	8003166 <HAL_SPI_Transmit+0x2b2>
    while (hspi->TxXferCount > 0U)
 8003118:	68fb      	ldr	r3, [r7, #12]
 800311a:	8fdb      	ldrh	r3, [r3, #62]	; 0x3e
 800311c:	b29b      	uxth	r3, r3
 800311e:	2b00      	cmp	r3, #0
 8003120:	d1b5      	bne.n	800308e <HAL_SPI_Transmit+0x1da>
    SET_BIT(hspi->Instance->CR1, SPI_CR1_CRCNEXT);
  }
#endif /* USE_SPI_CRC */

  /* Check the end of the transaction */
  if (SPI_EndRxTxTransaction(hspi, Timeout, tickstart) != HAL_OK)
 8003122:	69ba      	ldr	r2, [r7, #24]
 8003124:	6839      	ldr	r1, [r7, #0]
 8003126:	68f8      	ldr	r0, [r7, #12]
 8003128:	f000 f901 	bl	800332e <SPI_EndRxTxTransaction>
 800312c:	4603      	mov	r3, r0
 800312e:	2b00      	cmp	r3, #0
 8003130:	d002      	beq.n	8003138 <HAL_SPI_Transmit+0x284>
  {
    hspi->ErrorCode = HAL_SPI_ERROR_FLAG;
 8003132:	68fb      	ldr	r3, [r7, #12]
 8003134:	2220      	movs	r2, #32
 8003136:	661a      	str	r2, [r3, #96]	; 0x60
  }

  /* Clear overrun flag in 2 Lines communication mode because received is not read */
  if (hspi->Init.Direction == SPI_DIRECTION_2LINES)
 8003138:	68fb      	ldr	r3, [r7, #12]
 800313a:	689b      	ldr	r3, [r3, #8]
 800313c:	2b00      	cmp	r3, #0
 800313e:	d10a      	bne.n	8003156 <HAL_SPI_Transmit+0x2a2>
  {
    __HAL_SPI_CLEAR_OVRFLAG(hspi);
 8003140:	2300      	movs	r3, #0
 8003142:	613b      	str	r3, [r7, #16]
 8003144:	68fb      	ldr	r3, [r7, #12]
 8003146:	681b      	ldr	r3, [r3, #0]
 8003148:	68db      	ldr	r3, [r3, #12]
 800314a:	613b      	str	r3, [r7, #16]
 800314c:	68fb      	ldr	r3, [r7, #12]
 800314e:	681b      	ldr	r3, [r3, #0]
 8003150:	689b      	ldr	r3, [r3, #8]
 8003152:	613b      	str	r3, [r7, #16]
 8003154:	693b      	ldr	r3, [r7, #16]
  }

  if (hspi->ErrorCode != HAL_SPI_ERROR_NONE)
 8003156:	68fb      	ldr	r3, [r7, #12]
 8003158:	6e1b      	ldr	r3, [r3, #96]	; 0x60
 800315a:	2b00      	cmp	r3, #0
 800315c:	d002      	beq.n	8003164 <HAL_SPI_Transmit+0x2b0>
  {
    errorcode = HAL_ERROR;
 800315e:	2301      	movs	r3, #1
 8003160:	77fb      	strb	r3, [r7, #31]
 8003162:	e000      	b.n	8003166 <HAL_SPI_Transmit+0x2b2>
  }

error:
 8003164:	bf00      	nop
  hspi->State = HAL_SPI_STATE_READY;
 8003166:	68fb      	ldr	r3, [r7, #12]
 8003168:	2201      	movs	r2, #1
 800316a:	f883 205d 	strb.w	r2, [r3, #93]	; 0x5d
  /* Process Unlocked */
  __HAL_UNLOCK(hspi);
 800316e:	68fb      	ldr	r3, [r7, #12]
 8003170:	2200      	movs	r2, #0
 8003172:	f883 205c 	strb.w	r2, [r3, #92]	; 0x5c
  return errorcode;
 8003176:	7ffb      	ldrb	r3, [r7, #31]
}
 8003178:	4618      	mov	r0, r3
 800317a:	3720      	adds	r7, #32
 800317c:	46bd      	mov	sp, r7
 800317e:	bd80      	pop	{r7, pc}

08003180 <SPI_WaitFlagStateUntilTimeout>:
  * @param  Tickstart tick start value
  * @retval HAL status
  */
static HAL_StatusTypeDef SPI_WaitFlagStateUntilTimeout(SPI_HandleTypeDef *hspi, uint32_t Flag, FlagStatus State,
                                                       uint32_t Timeout, uint32_t Tickstart)
{
 8003180:	b580      	push	{r7, lr}
 8003182:	b084      	sub	sp, #16
 8003184:	af00      	add	r7, sp, #0
 8003186:	60f8      	str	r0, [r7, #12]
 8003188:	60b9      	str	r1, [r7, #8]
 800318a:	603b      	str	r3, [r7, #0]
 800318c:	4613      	mov	r3, r2
 800318e:	71fb      	strb	r3, [r7, #7]
  while ((__HAL_SPI_GET_FLAG(hspi, Flag) ? SET : RESET) != State)
 8003190:	e04c      	b.n	800322c <SPI_WaitFlagStateUntilTimeout+0xac>
  {
    if (Timeout != HAL_MAX_DELAY)
 8003192:	683b      	ldr	r3, [r7, #0]
 8003194:	f1b3 3fff 	cmp.w	r3, #4294967295	; 0xffffffff
 8003198:	d048      	beq.n	800322c <SPI_WaitFlagStateUntilTimeout+0xac>
    {
      if (((HAL_GetTick() - Tickstart) >= Timeout) || (Timeout == 0U))
 800319a:	f7fe f9b3 	bl	8001504 <HAL_GetTick>
 800319e:	4602      	mov	r2, r0
 80031a0:	69bb      	ldr	r3, [r7, #24]
 80031a2:	1ad3      	subs	r3, r2, r3
 80031a4:	683a      	ldr	r2, [r7, #0]
 80031a6:	429a      	cmp	r2, r3
 80031a8:	d902      	bls.n	80031b0 <SPI_WaitFlagStateUntilTimeout+0x30>
 80031aa:	683b      	ldr	r3, [r7, #0]
 80031ac:	2b00      	cmp	r3, #0
 80031ae:	d13d      	bne.n	800322c <SPI_WaitFlagStateUntilTimeout+0xac>
        /* Disable the SPI and reset the CRC: the CRC value should be cleared
        on both master and slave sides in order to resynchronize the master
        and slave for their respective CRC calculation */

        /* Disable TXE, RXNE and ERR interrupts for the interrupt process */
        __HAL_SPI_DISABLE_IT(hspi, (SPI_IT_TXE | SPI_IT_RXNE | SPI_IT_ERR));
 80031b0:	68fb      	ldr	r3, [r7, #12]
 80031b2:	681b      	ldr	r3, [r3, #0]
 80031b4:	685a      	ldr	r2, [r3, #4]
 80031b6:	68fb      	ldr	r3, [r7, #12]
 80031b8:	681b      	ldr	r3, [r3, #0]
 80031ba:	f022 02e0 	bic.w	r2, r2, #224	; 0xe0
 80031be:	605a      	str	r2, [r3, #4]

        if ((hspi->Init.Mode == SPI_MODE_MASTER) && ((hspi->Init.Direction == SPI_DIRECTION_1LINE)
 80031c0:	68fb      	ldr	r3, [r7, #12]
 80031c2:	685b      	ldr	r3, [r3, #4]
 80031c4:	f5b3 7f82 	cmp.w	r3, #260	; 0x104
 80031c8:	d111      	bne.n	80031ee <SPI_WaitFlagStateUntilTimeout+0x6e>
 80031ca:	68fb      	ldr	r3, [r7, #12]
 80031cc:	689b      	ldr	r3, [r3, #8]
 80031ce:	f5b3 4f00 	cmp.w	r3, #32768	; 0x8000
 80031d2:	d004      	beq.n	80031de <SPI_WaitFlagStateUntilTimeout+0x5e>
                                                     || (hspi->Init.Direction == SPI_DIRECTION_2LINES_RXONLY)))
 80031d4:	68fb      	ldr	r3, [r7, #12]
 80031d6:	689b      	ldr	r3, [r3, #8]
 80031d8:	f5b3 6f80 	cmp.w	r3, #1024	; 0x400
 80031dc:	d107      	bne.n	80031ee <SPI_WaitFlagStateUntilTimeout+0x6e>
        {
          /* Disable SPI peripheral */
          __HAL_SPI_DISABLE(hspi);
 80031de:	68fb      	ldr	r3, [r7, #12]
 80031e0:	681b      	ldr	r3, [r3, #0]
 80031e2:	681a      	ldr	r2, [r3, #0]
 80031e4:	68fb      	ldr	r3, [r7, #12]
 80031e6:	681b      	ldr	r3, [r3, #0]
 80031e8:	f022 0240 	bic.w	r2, r2, #64	; 0x40
 80031ec:	601a      	str	r2, [r3, #0]
        }

        /* Reset CRC Calculation */
        if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE)
 80031ee:	68fb      	ldr	r3, [r7, #12]
 80031f0:	6a9b      	ldr	r3, [r3, #40]	; 0x28
 80031f2:	f5b3 5f00 	cmp.w	r3, #8192	; 0x2000
 80031f6:	d10f      	bne.n	8003218 <SPI_WaitFlagStateUntilTimeout+0x98>
        {
          SPI_RESET_CRC(hspi);
 80031f8:	68fb      	ldr	r3, [r7, #12]
 80031fa:	681b      	ldr	r3, [r3, #0]
 80031fc:	681a      	ldr	r2, [r3, #0]
 80031fe:	68fb      	ldr	r3, [r7, #12]
 8003200:	681b      	ldr	r3, [r3, #0]
 8003202:	f422 5200 	bic.w	r2, r2, #8192	; 0x2000
 8003206:	601a      	str	r2, [r3, #0]
 8003208:	68fb      	ldr	r3, [r7, #12]
 800320a:	681b      	ldr	r3, [r3, #0]
 800320c:	681a      	ldr	r2, [r3, #0]
 800320e:	68fb      	ldr	r3, [r7, #12]
 8003210:	681b      	ldr	r3, [r3, #0]
 8003212:	f442 5200 	orr.w	r2, r2, #8192	; 0x2000
 8003216:	601a      	str	r2, [r3, #0]
        }

        hspi->State = HAL_SPI_STATE_READY;
 8003218:	68fb      	ldr	r3, [r7, #12]
 800321a:	2201      	movs	r2, #1
 800321c:	f883 205d 	strb.w	r2, [r3, #93]	; 0x5d

        /* Process Unlocked */
        __HAL_UNLOCK(hspi);
 8003220:	68fb      	ldr	r3, [r7, #12]
 8003222:	2200      	movs	r2, #0
 8003224:	f883 205c 	strb.w	r2, [r3, #92]	; 0x5c

        return HAL_TIMEOUT;
 8003228:	2303      	movs	r3, #3
 800322a:	e00f      	b.n	800324c <SPI_WaitFlagStateUntilTimeout+0xcc>
  while ((__HAL_SPI_GET_FLAG(hspi, Flag) ? SET : RESET) != State)
 800322c:	68fb      	ldr	r3, [r7, #12]
 800322e:	681b      	ldr	r3, [r3, #0]
 8003230:	689a      	ldr	r2, [r3, #8]
 8003232:	68bb      	ldr	r3, [r7, #8]
 8003234:	4013      	ands	r3, r2
 8003236:	68ba      	ldr	r2, [r7, #8]
 8003238:	429a      	cmp	r2, r3
 800323a:	bf0c      	ite	eq
 800323c:	2301      	moveq	r3, #1
 800323e:	2300      	movne	r3, #0
 8003240:	b2db      	uxtb	r3, r3
 8003242:	461a      	mov	r2, r3
 8003244:	79fb      	ldrb	r3, [r7, #7]
 8003246:	429a      	cmp	r2, r3
 8003248:	d1a3      	bne.n	8003192 <SPI_WaitFlagStateUntilTimeout+0x12>
      }
    }
  }

  return HAL_OK;
 800324a:	2300      	movs	r3, #0
}
 800324c:	4618      	mov	r0, r3
 800324e:	3710      	adds	r7, #16
 8003250:	46bd      	mov	sp, r7
 8003252:	bd80      	pop	{r7, pc}

08003254 <SPI_WaitFifoStateUntilTimeout>:
  * @param  Tickstart tick start value
  * @retval HAL status
  */
static HAL_StatusTypeDef SPI_WaitFifoStateUntilTimeout(SPI_HandleTypeDef *hspi, uint32_t Fifo, uint32_t State,
                                                       uint32_t Timeout, uint32_t Tickstart)
{
 8003254:	b580      	push	{r7, lr}
 8003256:	b084      	sub	sp, #16
 8003258:	af00      	add	r7, sp, #0
 800325a:	60f8      	str	r0, [r7, #12]
 800325c:	60b9      	str	r1, [r7, #8]
 800325e:	607a      	str	r2, [r7, #4]
 8003260:	603b      	str	r3, [r7, #0]
  while ((hspi->Instance->SR & Fifo) != State)
 8003262:	e057      	b.n	8003314 <SPI_WaitFifoStateUntilTimeout+0xc0>
  {
    if ((Fifo == SPI_SR_FRLVL) && (State == SPI_FRLVL_EMPTY))
 8003264:	68bb      	ldr	r3, [r7, #8]
 8003266:	f5b3 6fc0 	cmp.w	r3, #1536	; 0x600
 800326a:	d106      	bne.n	800327a <SPI_WaitFifoStateUntilTimeout+0x26>
 800326c:	687b      	ldr	r3, [r7, #4]
 800326e:	2b00      	cmp	r3, #0
 8003270:	d103      	bne.n	800327a <SPI_WaitFifoStateUntilTimeout+0x26>
    {
      /* Read 8bit CRC to flush Data Register */
      READ_REG(*((__IO uint8_t *)&hspi->Instance->DR));
 8003272:	68fb      	ldr	r3, [r7, #12]
 8003274:	681b      	ldr	r3, [r3, #0]
 8003276:	330c      	adds	r3, #12
 8003278:	781b      	ldrb	r3, [r3, #0]
    }

    if (Timeout != HAL_MAX_DELAY)
 800327a:	683b      	ldr	r3, [r7, #0]
 800327c:	f1b3 3fff 	cmp.w	r3, #4294967295	; 0xffffffff
 8003280:	d048      	beq.n	8003314 <SPI_WaitFifoStateUntilTimeout+0xc0>
    {
      if (((HAL_GetTick() - Tickstart) >= Timeout) || (Timeout == 0U))
 8003282:	f7fe f93f 	bl	8001504 <HAL_GetTick>
 8003286:	4602      	mov	r2, r0
 8003288:	69bb      	ldr	r3, [r7, #24]
 800328a:	1ad3      	subs	r3, r2, r3
 800328c:	683a      	ldr	r2, [r7, #0]
 800328e:	429a      	cmp	r2, r3
 8003290:	d902      	bls.n	8003298 <SPI_WaitFifoStateUntilTimeout+0x44>
 8003292:	683b      	ldr	r3, [r7, #0]
 8003294:	2b00      	cmp	r3, #0
 8003296:	d13d      	bne.n	8003314 <SPI_WaitFifoStateUntilTimeout+0xc0>
        /* Disable the SPI and reset the CRC: the CRC value should be cleared
           on both master and slave sides in order to resynchronize the master
           and slave for their respective CRC calculation */

        /* Disable TXE, RXNE and ERR interrupts for the interrupt process */
        __HAL_SPI_DISABLE_IT(hspi, (SPI_IT_TXE | SPI_IT_RXNE | SPI_IT_ERR));
 8003298:	68fb      	ldr	r3, [r7, #12]
 800329a:	681b      	ldr	r3, [r3, #0]
 800329c:	685a      	ldr	r2, [r3, #4]
 800329e:	68fb      	ldr	r3, [r7, #12]
 80032a0:	681b      	ldr	r3, [r3, #0]
 80032a2:	f022 02e0 	bic.w	r2, r2, #224	; 0xe0
 80032a6:	605a      	str	r2, [r3, #4]

        if ((hspi->Init.Mode == SPI_MODE_MASTER) && ((hspi->Init.Direction == SPI_DIRECTION_1LINE)
 80032a8:	68fb      	ldr	r3, [r7, #12]
 80032aa:	685b      	ldr	r3, [r3, #4]
 80032ac:	f5b3 7f82 	cmp.w	r3, #260	; 0x104
 80032b0:	d111      	bne.n	80032d6 <SPI_WaitFifoStateUntilTimeout+0x82>
 80032b2:	68fb      	ldr	r3, [r7, #12]
 80032b4:	689b      	ldr	r3, [r3, #8]
 80032b6:	f5b3 4f00 	cmp.w	r3, #32768	; 0x8000
 80032ba:	d004      	beq.n	80032c6 <SPI_WaitFifoStateUntilTimeout+0x72>
                                                     || (hspi->Init.Direction == SPI_DIRECTION_2LINES_RXONLY)))
 80032bc:	68fb      	ldr	r3, [r7, #12]
 80032be:	689b      	ldr	r3, [r3, #8]
 80032c0:	f5b3 6f80 	cmp.w	r3, #1024	; 0x400
 80032c4:	d107      	bne.n	80032d6 <SPI_WaitFifoStateUntilTimeout+0x82>
        {
          /* Disable SPI peripheral */
          __HAL_SPI_DISABLE(hspi);
 80032c6:	68fb      	ldr	r3, [r7, #12]
 80032c8:	681b      	ldr	r3, [r3, #0]
 80032ca:	681a      	ldr	r2, [r3, #0]
 80032cc:	68fb      	ldr	r3, [r7, #12]
 80032ce:	681b      	ldr	r3, [r3, #0]
 80032d0:	f022 0240 	bic.w	r2, r2, #64	; 0x40
 80032d4:	601a      	str	r2, [r3, #0]
        }

        /* Reset CRC Calculation */
        if (hspi->Init.CRCCalculation == SPI_CRCCALCULATION_ENABLE)
 80032d6:	68fb      	ldr	r3, [r7, #12]
 80032d8:	6a9b      	ldr	r3, [r3, #40]	; 0x28
 80032da:	f5b3 5f00 	cmp.w	r3, #8192	; 0x2000
 80032de:	d10f      	bne.n	8003300 <SPI_WaitFifoStateUntilTimeout+0xac>
        {
          SPI_RESET_CRC(hspi);
 80032e0:	68fb      	ldr	r3, [r7, #12]
 80032e2:	681b      	ldr	r3, [r3, #0]
 80032e4:	681a      	ldr	r2, [r3, #0]
 80032e6:	68fb      	ldr	r3, [r7, #12]
 80032e8:	681b      	ldr	r3, [r3, #0]
 80032ea:	f422 5200 	bic.w	r2, r2, #8192	; 0x2000
 80032ee:	601a      	str	r2, [r3, #0]
 80032f0:	68fb      	ldr	r3, [r7, #12]
 80032f2:	681b      	ldr	r3, [r3, #0]
 80032f4:	681a      	ldr	r2, [r3, #0]
 80032f6:	68fb      	ldr	r3, [r7, #12]
 80032f8:	681b      	ldr	r3, [r3, #0]
 80032fa:	f442 5200 	orr.w	r2, r2, #8192	; 0x2000
 80032fe:	601a      	str	r2, [r3, #0]
        }

        hspi->State = HAL_SPI_STATE_READY;
 8003300:	68fb      	ldr	r3, [r7, #12]
 8003302:	2201      	movs	r2, #1
 8003304:	f883 205d 	strb.w	r2, [r3, #93]	; 0x5d

        /* Process Unlocked */
        __HAL_UNLOCK(hspi);
 8003308:	68fb      	ldr	r3, [r7, #12]
 800330a:	2200      	movs	r2, #0
 800330c:	f883 205c 	strb.w	r2, [r3, #92]	; 0x5c

        return HAL_TIMEOUT;
 8003310:	2303      	movs	r3, #3
 8003312:	e008      	b.n	8003326 <SPI_WaitFifoStateUntilTimeout+0xd2>
  while ((hspi->Instance->SR & Fifo) != State)
 8003314:	68fb      	ldr	r3, [r7, #12]
 8003316:	681b      	ldr	r3, [r3, #0]
 8003318:	689a      	ldr	r2, [r3, #8]
 800331a:	68bb      	ldr	r3, [r7, #8]
 800331c:	4013      	ands	r3, r2
 800331e:	687a      	ldr	r2, [r7, #4]
 8003320:	429a      	cmp	r2, r3
 8003322:	d19f      	bne.n	8003264 <SPI_WaitFifoStateUntilTimeout+0x10>
      }
    }
  }

  return HAL_OK;
 8003324:	2300      	movs	r3, #0
}
 8003326:	4618      	mov	r0, r3
 8003328:	3710      	adds	r7, #16
 800332a:	46bd      	mov	sp, r7
 800332c:	bd80      	pop	{r7, pc}

0800332e <SPI_EndRxTxTransaction>:
  * @param  Timeout Timeout duration
  * @param  Tickstart tick start value
  * @retval HAL status
  */
static HAL_StatusTypeDef SPI_EndRxTxTransaction(SPI_HandleTypeDef *hspi, uint32_t Timeout, uint32_t Tickstart)
{
 800332e:	b580      	push	{r7, lr}
 8003330:	b086      	sub	sp, #24
 8003332:	af02      	add	r7, sp, #8
 8003334:	60f8      	str	r0, [r7, #12]
 8003336:	60b9      	str	r1, [r7, #8]
 8003338:	607a      	str	r2, [r7, #4]
  /* Control if the TX fifo is empty */
  if (SPI_WaitFifoStateUntilTimeout(hspi, SPI_FLAG_FTLVL, SPI_FTLVL_EMPTY, Timeout, Tickstart) != HAL_OK)
 800333a:	687b      	ldr	r3, [r7, #4]
 800333c:	9300      	str	r3, [sp, #0]
 800333e:	68bb      	ldr	r3, [r7, #8]
 8003340:	2200      	movs	r2, #0
 8003342:	f44f 51c0 	mov.w	r1, #6144	; 0x1800
 8003346:	68f8      	ldr	r0, [r7, #12]
 8003348:	f7ff ff84 	bl	8003254 <SPI_WaitFifoStateUntilTimeout>
 800334c:	4603      	mov	r3, r0
 800334e:	2b00      	cmp	r3, #0
 8003350:	d007      	beq.n	8003362 <SPI_EndRxTxTransaction+0x34>
  {
    SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_FLAG);
 8003352:	68fb      	ldr	r3, [r7, #12]
 8003354:	6e1b      	ldr	r3, [r3, #96]	; 0x60
 8003356:	f043 0220 	orr.w	r2, r3, #32
 800335a:	68fb      	ldr	r3, [r7, #12]
 800335c:	661a      	str	r2, [r3, #96]	; 0x60
    return HAL_TIMEOUT;
 800335e:	2303      	movs	r3, #3
 8003360:	e027      	b.n	80033b2 <SPI_EndRxTxTransaction+0x84>
  }

  /* Control the BSY flag */
  if (SPI_WaitFlagStateUntilTimeout(hspi, SPI_FLAG_BSY, RESET, Timeout, Tickstart) != HAL_OK)
 8003362:	687b      	ldr	r3, [r7, #4]
 8003364:	9300      	str	r3, [sp, #0]
 8003366:	68bb      	ldr	r3, [r7, #8]
 8003368:	2200      	movs	r2, #0
 800336a:	2180      	movs	r1, #128	; 0x80
 800336c:	68f8      	ldr	r0, [r7, #12]
 800336e:	f7ff ff07 	bl	8003180 <SPI_WaitFlagStateUntilTimeout>
 8003372:	4603      	mov	r3, r0
 8003374:	2b00      	cmp	r3, #0
 8003376:	d007      	beq.n	8003388 <SPI_EndRxTxTransaction+0x5a>
  {
    SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_FLAG);
 8003378:	68fb      	ldr	r3, [r7, #12]
 800337a:	6e1b      	ldr	r3, [r3, #96]	; 0x60
 800337c:	f043 0220 	orr.w	r2, r3, #32
 8003380:	68fb      	ldr	r3, [r7, #12]
 8003382:	661a      	str	r2, [r3, #96]	; 0x60
    return HAL_TIMEOUT;
 8003384:	2303      	movs	r3, #3
 8003386:	e014      	b.n	80033b2 <SPI_EndRxTxTransaction+0x84>
  }

  /* Control if the RX fifo is empty */
  if (SPI_WaitFifoStateUntilTimeout(hspi, SPI_FLAG_FRLVL, SPI_FRLVL_EMPTY, Timeout, Tickstart) != HAL_OK)
 8003388:	687b      	ldr	r3, [r7, #4]
 800338a:	9300      	str	r3, [sp, #0]
 800338c:	68bb      	ldr	r3, [r7, #8]
 800338e:	2200      	movs	r2, #0
 8003390:	f44f 61c0 	mov.w	r1, #1536	; 0x600
 8003394:	68f8      	ldr	r0, [r7, #12]
 8003396:	f7ff ff5d 	bl	8003254 <SPI_WaitFifoStateUntilTimeout>
 800339a:	4603      	mov	r3, r0
 800339c:	2b00      	cmp	r3, #0
 800339e:	d007      	beq.n	80033b0 <SPI_EndRxTxTransaction+0x82>
  {
    SET_BIT(hspi->ErrorCode, HAL_SPI_ERROR_FLAG);
 80033a0:	68fb      	ldr	r3, [r7, #12]
 80033a2:	6e1b      	ldr	r3, [r3, #96]	; 0x60
 80033a4:	f043 0220 	orr.w	r2, r3, #32
 80033a8:	68fb      	ldr	r3, [r7, #12]
 80033aa:	661a      	str	r2, [r3, #96]	; 0x60
    return HAL_TIMEOUT;
 80033ac:	2303      	movs	r3, #3
 80033ae:	e000      	b.n	80033b2 <SPI_EndRxTxTransaction+0x84>
  }

  return HAL_OK;
 80033b0:	2300      	movs	r3, #0
}
 80033b2:	4618      	mov	r0, r3
 80033b4:	3710      	adds	r7, #16
 80033b6:	46bd      	mov	sp, r7
 80033b8:	bd80      	pop	{r7, pc}

080033ba <HAL_TIM_Base_Init>:
  *         Ex: call @ref HAL_TIM_Base_DeInit() before HAL_TIM_Base_Init()
  * @param  htim TIM Base handle
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_TIM_Base_Init(TIM_HandleTypeDef *htim)
{
 80033ba:	b580      	push	{r7, lr}
 80033bc:	b082      	sub	sp, #8
 80033be:	af00      	add	r7, sp, #0
 80033c0:	6078      	str	r0, [r7, #4]
  /* Check the TIM handle allocation */
  if (htim == NULL)
 80033c2:	687b      	ldr	r3, [r7, #4]
 80033c4:	2b00      	cmp	r3, #0
 80033c6:	d101      	bne.n	80033cc <HAL_TIM_Base_Init+0x12>
  {
    return HAL_ERROR;
 80033c8:	2301      	movs	r3, #1
 80033ca:	e01d      	b.n	8003408 <HAL_TIM_Base_Init+0x4e>
  assert_param(IS_TIM_INSTANCE(htim->Instance));
  assert_param(IS_TIM_COUNTER_MODE(htim->Init.CounterMode));
  assert_param(IS_TIM_CLOCKDIVISION_DIV(htim->Init.ClockDivision));
  assert_param(IS_TIM_AUTORELOAD_PRELOAD(htim->Init.AutoReloadPreload));

  if (htim->State == HAL_TIM_STATE_RESET)
 80033cc:	687b      	ldr	r3, [r7, #4]
 80033ce:	f893 303d 	ldrb.w	r3, [r3, #61]	; 0x3d
 80033d2:	b2db      	uxtb	r3, r3
 80033d4:	2b00      	cmp	r3, #0
 80033d6:	d106      	bne.n	80033e6 <HAL_TIM_Base_Init+0x2c>
  {
    /* Allocate lock resource and initialize it */
    htim->Lock = HAL_UNLOCKED;
 80033d8:	687b      	ldr	r3, [r7, #4]
 80033da:	2200      	movs	r2, #0
 80033dc:	f883 203c 	strb.w	r2, [r3, #60]	; 0x3c
    }
    /* Init the low level hardware : GPIO, CLOCK, NVIC */
    htim->Base_MspInitCallback(htim);
#else
    /* Init the low level hardware : GPIO, CLOCK, NVIC */
    HAL_TIM_Base_MspInit(htim);
 80033e0:	6878      	ldr	r0, [r7, #4]
 80033e2:	f7fd ff71 	bl	80012c8 <HAL_TIM_Base_MspInit>
#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */
  }

  /* Set the TIM state */
  htim->State = HAL_TIM_STATE_BUSY;
 80033e6:	687b      	ldr	r3, [r7, #4]
 80033e8:	2202      	movs	r2, #2
 80033ea:	f883 203d 	strb.w	r2, [r3, #61]	; 0x3d

  /* Set the Time Base configuration */
  TIM_Base_SetConfig(htim->Instance, &htim->Init);
 80033ee:	687b      	ldr	r3, [r7, #4]
 80033f0:	681a      	ldr	r2, [r3, #0]
 80033f2:	687b      	ldr	r3, [r7, #4]
 80033f4:	3304      	adds	r3, #4
 80033f6:	4619      	mov	r1, r3
 80033f8:	4610      	mov	r0, r2
 80033fa:	f000 f8c3 	bl	8003584 <TIM_Base_SetConfig>

  /* Initialize the TIM state*/
  htim->State = HAL_TIM_STATE_READY;
 80033fe:	687b      	ldr	r3, [r7, #4]
 8003400:	2201      	movs	r2, #1
 8003402:	f883 203d 	strb.w	r2, [r3, #61]	; 0x3d

  return HAL_OK;
 8003406:	2300      	movs	r3, #0
}
 8003408:	4618      	mov	r0, r3
 800340a:	3708      	adds	r7, #8
 800340c:	46bd      	mov	sp, r7
 800340e:	bd80      	pop	{r7, pc}

08003410 <HAL_TIM_ConfigClockSource>:
  * @param  sClockSourceConfig pointer to a TIM_ClockConfigTypeDef structure that
  *         contains the clock source information for the TIM peripheral.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_TIM_ConfigClockSource(TIM_HandleTypeDef *htim, TIM_ClockConfigTypeDef *sClockSourceConfig)
{
 8003410:	b580      	push	{r7, lr}
 8003412:	b084      	sub	sp, #16
 8003414:	af00      	add	r7, sp, #0
 8003416:	6078      	str	r0, [r7, #4]
 8003418:	6039      	str	r1, [r7, #0]
  uint32_t tmpsmcr;

  /* Process Locked */
  __HAL_LOCK(htim);
 800341a:	687b      	ldr	r3, [r7, #4]
 800341c:	f893 303c 	ldrb.w	r3, [r3, #60]	; 0x3c
 8003420:	2b01      	cmp	r3, #1
 8003422:	d101      	bne.n	8003428 <HAL_TIM_ConfigClockSource+0x18>
 8003424:	2302      	movs	r3, #2
 8003426:	e0a6      	b.n	8003576 <HAL_TIM_ConfigClockSource+0x166>
 8003428:	687b      	ldr	r3, [r7, #4]
 800342a:	2201      	movs	r2, #1
 800342c:	f883 203c 	strb.w	r2, [r3, #60]	; 0x3c

  htim->State = HAL_TIM_STATE_BUSY;
 8003430:	687b      	ldr	r3, [r7, #4]
 8003432:	2202      	movs	r2, #2
 8003434:	f883 203d 	strb.w	r2, [r3, #61]	; 0x3d

  /* Check the parameters */
  assert_param(IS_TIM_CLOCKSOURCE(sClockSourceConfig->ClockSource));

  /* Reset the SMS, TS, ECE, ETPS and ETRF bits */
  tmpsmcr = htim->Instance->SMCR;
 8003438:	687b      	ldr	r3, [r7, #4]
 800343a:	681b      	ldr	r3, [r3, #0]
 800343c:	689b      	ldr	r3, [r3, #8]
 800343e:	60fb      	str	r3, [r7, #12]
  tmpsmcr &= ~(TIM_SMCR_SMS | TIM_SMCR_TS);
 8003440:	68fa      	ldr	r2, [r7, #12]
 8003442:	4b4f      	ldr	r3, [pc, #316]	; (8003580 <HAL_TIM_ConfigClockSource+0x170>)
 8003444:	4013      	ands	r3, r2
 8003446:	60fb      	str	r3, [r7, #12]
  tmpsmcr &= ~(TIM_SMCR_ETF | TIM_SMCR_ETPS | TIM_SMCR_ECE | TIM_SMCR_ETP);
 8003448:	68fb      	ldr	r3, [r7, #12]
 800344a:	f423 437f 	bic.w	r3, r3, #65280	; 0xff00
 800344e:	60fb      	str	r3, [r7, #12]
  htim->Instance->SMCR = tmpsmcr;
 8003450:	687b      	ldr	r3, [r7, #4]
 8003452:	681b      	ldr	r3, [r3, #0]
 8003454:	68fa      	ldr	r2, [r7, #12]
 8003456:	609a      	str	r2, [r3, #8]

  switch (sClockSourceConfig->ClockSource)
 8003458:	683b      	ldr	r3, [r7, #0]
 800345a:	681b      	ldr	r3, [r3, #0]
 800345c:	2b40      	cmp	r3, #64	; 0x40
 800345e:	d067      	beq.n	8003530 <HAL_TIM_ConfigClockSource+0x120>
 8003460:	2b40      	cmp	r3, #64	; 0x40
 8003462:	d80b      	bhi.n	800347c <HAL_TIM_ConfigClockSource+0x6c>
 8003464:	2b10      	cmp	r3, #16
 8003466:	d073      	beq.n	8003550 <HAL_TIM_ConfigClockSource+0x140>
 8003468:	2b10      	cmp	r3, #16
 800346a:	d802      	bhi.n	8003472 <HAL_TIM_ConfigClockSource+0x62>
 800346c:	2b00      	cmp	r3, #0
 800346e:	d06f      	beq.n	8003550 <HAL_TIM_ConfigClockSource+0x140>
      TIM_ITRx_SetConfig(htim->Instance, sClockSourceConfig->ClockSource);
      break;
    }

    default:
      break;
 8003470:	e078      	b.n	8003564 <HAL_TIM_ConfigClockSource+0x154>
  switch (sClockSourceConfig->ClockSource)
 8003472:	2b20      	cmp	r3, #32
 8003474:	d06c      	beq.n	8003550 <HAL_TIM_ConfigClockSource+0x140>
 8003476:	2b30      	cmp	r3, #48	; 0x30
 8003478:	d06a      	beq.n	8003550 <HAL_TIM_ConfigClockSource+0x140>
      break;
 800347a:	e073      	b.n	8003564 <HAL_TIM_ConfigClockSource+0x154>
  switch (sClockSourceConfig->ClockSource)
 800347c:	2b70      	cmp	r3, #112	; 0x70
 800347e:	d00d      	beq.n	800349c <HAL_TIM_ConfigClockSource+0x8c>
 8003480:	2b70      	cmp	r3, #112	; 0x70
 8003482:	d804      	bhi.n	800348e <HAL_TIM_ConfigClockSource+0x7e>
 8003484:	2b50      	cmp	r3, #80	; 0x50
 8003486:	d033      	beq.n	80034f0 <HAL_TIM_ConfigClockSource+0xe0>
 8003488:	2b60      	cmp	r3, #96	; 0x60
 800348a:	d041      	beq.n	8003510 <HAL_TIM_ConfigClockSource+0x100>
      break;
 800348c:	e06a      	b.n	8003564 <HAL_TIM_ConfigClockSource+0x154>
  switch (sClockSourceConfig->ClockSource)
 800348e:	f5b3 5f80 	cmp.w	r3, #4096	; 0x1000
 8003492:	d066      	beq.n	8003562 <HAL_TIM_ConfigClockSource+0x152>
 8003494:	f5b3 5f00 	cmp.w	r3, #8192	; 0x2000
 8003498:	d017      	beq.n	80034ca <HAL_TIM_ConfigClockSource+0xba>
      break;
 800349a:	e063      	b.n	8003564 <HAL_TIM_ConfigClockSource+0x154>
      TIM_ETR_SetConfig(htim->Instance,
 800349c:	687b      	ldr	r3, [r7, #4]
 800349e:	6818      	ldr	r0, [r3, #0]
 80034a0:	683b      	ldr	r3, [r7, #0]
 80034a2:	6899      	ldr	r1, [r3, #8]
 80034a4:	683b      	ldr	r3, [r7, #0]
 80034a6:	685a      	ldr	r2, [r3, #4]
 80034a8:	683b      	ldr	r3, [r7, #0]
 80034aa:	68db      	ldr	r3, [r3, #12]
 80034ac:	f000 f984 	bl	80037b8 <TIM_ETR_SetConfig>
      tmpsmcr = htim->Instance->SMCR;
 80034b0:	687b      	ldr	r3, [r7, #4]
 80034b2:	681b      	ldr	r3, [r3, #0]
 80034b4:	689b      	ldr	r3, [r3, #8]
 80034b6:	60fb      	str	r3, [r7, #12]
      tmpsmcr |= (TIM_SLAVEMODE_EXTERNAL1 | TIM_CLOCKSOURCE_ETRMODE1);
 80034b8:	68fb      	ldr	r3, [r7, #12]
 80034ba:	f043 0377 	orr.w	r3, r3, #119	; 0x77
 80034be:	60fb      	str	r3, [r7, #12]
      htim->Instance->SMCR = tmpsmcr;
 80034c0:	687b      	ldr	r3, [r7, #4]
 80034c2:	681b      	ldr	r3, [r3, #0]
 80034c4:	68fa      	ldr	r2, [r7, #12]
 80034c6:	609a      	str	r2, [r3, #8]
      break;
 80034c8:	e04c      	b.n	8003564 <HAL_TIM_ConfigClockSource+0x154>
      TIM_ETR_SetConfig(htim->Instance,
 80034ca:	687b      	ldr	r3, [r7, #4]
 80034cc:	6818      	ldr	r0, [r3, #0]
 80034ce:	683b      	ldr	r3, [r7, #0]
 80034d0:	6899      	ldr	r1, [r3, #8]
 80034d2:	683b      	ldr	r3, [r7, #0]
 80034d4:	685a      	ldr	r2, [r3, #4]
 80034d6:	683b      	ldr	r3, [r7, #0]
 80034d8:	68db      	ldr	r3, [r3, #12]
 80034da:	f000 f96d 	bl	80037b8 <TIM_ETR_SetConfig>
      htim->Instance->SMCR |= TIM_SMCR_ECE;
 80034de:	687b      	ldr	r3, [r7, #4]
 80034e0:	681b      	ldr	r3, [r3, #0]
 80034e2:	689a      	ldr	r2, [r3, #8]
 80034e4:	687b      	ldr	r3, [r7, #4]
 80034e6:	681b      	ldr	r3, [r3, #0]
 80034e8:	f442 4280 	orr.w	r2, r2, #16384	; 0x4000
 80034ec:	609a      	str	r2, [r3, #8]
      break;
 80034ee:	e039      	b.n	8003564 <HAL_TIM_ConfigClockSource+0x154>
      TIM_TI1_ConfigInputStage(htim->Instance,
 80034f0:	687b      	ldr	r3, [r7, #4]
 80034f2:	6818      	ldr	r0, [r3, #0]
 80034f4:	683b      	ldr	r3, [r7, #0]
 80034f6:	6859      	ldr	r1, [r3, #4]
 80034f8:	683b      	ldr	r3, [r7, #0]
 80034fa:	68db      	ldr	r3, [r3, #12]
 80034fc:	461a      	mov	r2, r3
 80034fe:	f000 f8e1 	bl	80036c4 <TIM_TI1_ConfigInputStage>
      TIM_ITRx_SetConfig(htim->Instance, TIM_CLOCKSOURCE_TI1);
 8003502:	687b      	ldr	r3, [r7, #4]
 8003504:	681b      	ldr	r3, [r3, #0]
 8003506:	2150      	movs	r1, #80	; 0x50
 8003508:	4618      	mov	r0, r3
 800350a:	f000 f93a 	bl	8003782 <TIM_ITRx_SetConfig>
      break;
 800350e:	e029      	b.n	8003564 <HAL_TIM_ConfigClockSource+0x154>
      TIM_TI2_ConfigInputStage(htim->Instance,
 8003510:	687b      	ldr	r3, [r7, #4]
 8003512:	6818      	ldr	r0, [r3, #0]
 8003514:	683b      	ldr	r3, [r7, #0]
 8003516:	6859      	ldr	r1, [r3, #4]
 8003518:	683b      	ldr	r3, [r7, #0]
 800351a:	68db      	ldr	r3, [r3, #12]
 800351c:	461a      	mov	r2, r3
 800351e:	f000 f900 	bl	8003722 <TIM_TI2_ConfigInputStage>
      TIM_ITRx_SetConfig(htim->Instance, TIM_CLOCKSOURCE_TI2);
 8003522:	687b      	ldr	r3, [r7, #4]
 8003524:	681b      	ldr	r3, [r3, #0]
 8003526:	2160      	movs	r1, #96	; 0x60
 8003528:	4618      	mov	r0, r3
 800352a:	f000 f92a 	bl	8003782 <TIM_ITRx_SetConfig>
      break;
 800352e:	e019      	b.n	8003564 <HAL_TIM_ConfigClockSource+0x154>
      TIM_TI1_ConfigInputStage(htim->Instance,
 8003530:	687b      	ldr	r3, [r7, #4]
 8003532:	6818      	ldr	r0, [r3, #0]
 8003534:	683b      	ldr	r3, [r7, #0]
 8003536:	6859      	ldr	r1, [r3, #4]
 8003538:	683b      	ldr	r3, [r7, #0]
 800353a:	68db      	ldr	r3, [r3, #12]
 800353c:	461a      	mov	r2, r3
 800353e:	f000 f8c1 	bl	80036c4 <TIM_TI1_ConfigInputStage>
      TIM_ITRx_SetConfig(htim->Instance, TIM_CLOCKSOURCE_TI1ED);
 8003542:	687b      	ldr	r3, [r7, #4]
 8003544:	681b      	ldr	r3, [r3, #0]
 8003546:	2140      	movs	r1, #64	; 0x40
 8003548:	4618      	mov	r0, r3
 800354a:	f000 f91a 	bl	8003782 <TIM_ITRx_SetConfig>
      break;
 800354e:	e009      	b.n	8003564 <HAL_TIM_ConfigClockSource+0x154>
      TIM_ITRx_SetConfig(htim->Instance, sClockSourceConfig->ClockSource);
 8003550:	687b      	ldr	r3, [r7, #4]
 8003552:	681a      	ldr	r2, [r3, #0]
 8003554:	683b      	ldr	r3, [r7, #0]
 8003556:	681b      	ldr	r3, [r3, #0]
 8003558:	4619      	mov	r1, r3
 800355a:	4610      	mov	r0, r2
 800355c:	f000 f911 	bl	8003782 <TIM_ITRx_SetConfig>
      break;
 8003560:	e000      	b.n	8003564 <HAL_TIM_ConfigClockSource+0x154>
      break;
 8003562:	bf00      	nop
  }
  htim->State = HAL_TIM_STATE_READY;
 8003564:	687b      	ldr	r3, [r7, #4]
 8003566:	2201      	movs	r2, #1
 8003568:	f883 203d 	strb.w	r2, [r3, #61]	; 0x3d

  __HAL_UNLOCK(htim);
 800356c:	687b      	ldr	r3, [r7, #4]
 800356e:	2200      	movs	r2, #0
 8003570:	f883 203c 	strb.w	r2, [r3, #60]	; 0x3c

  return HAL_OK;
 8003574:	2300      	movs	r3, #0
}
 8003576:	4618      	mov	r0, r3
 8003578:	3710      	adds	r7, #16
 800357a:	46bd      	mov	sp, r7
 800357c:	bd80      	pop	{r7, pc}
 800357e:	bf00      	nop
 8003580:	fffeff88 	.word	0xfffeff88

08003584 <TIM_Base_SetConfig>:
  * @param  TIMx TIM peripheral
  * @param  Structure TIM Base configuration structure
  * @retval None
  */
void TIM_Base_SetConfig(TIM_TypeDef *TIMx, TIM_Base_InitTypeDef *Structure)
{
 8003584:	b480      	push	{r7}
 8003586:	b085      	sub	sp, #20
 8003588:	af00      	add	r7, sp, #0
 800358a:	6078      	str	r0, [r7, #4]
 800358c:	6039      	str	r1, [r7, #0]
  uint32_t tmpcr1;
  tmpcr1 = TIMx->CR1;
 800358e:	687b      	ldr	r3, [r7, #4]
 8003590:	681b      	ldr	r3, [r3, #0]
 8003592:	60fb      	str	r3, [r7, #12]

  /* Set TIM Time Base Unit parameters ---------------------------------------*/
  if (IS_TIM_COUNTER_MODE_SELECT_INSTANCE(TIMx))
 8003594:	687b      	ldr	r3, [r7, #4]
 8003596:	4a40      	ldr	r2, [pc, #256]	; (8003698 <TIM_Base_SetConfig+0x114>)
 8003598:	4293      	cmp	r3, r2
 800359a:	d013      	beq.n	80035c4 <TIM_Base_SetConfig+0x40>
 800359c:	687b      	ldr	r3, [r7, #4]
 800359e:	f1b3 4f80 	cmp.w	r3, #1073741824	; 0x40000000
 80035a2:	d00f      	beq.n	80035c4 <TIM_Base_SetConfig+0x40>
 80035a4:	687b      	ldr	r3, [r7, #4]
 80035a6:	4a3d      	ldr	r2, [pc, #244]	; (800369c <TIM_Base_SetConfig+0x118>)
 80035a8:	4293      	cmp	r3, r2
 80035aa:	d00b      	beq.n	80035c4 <TIM_Base_SetConfig+0x40>
 80035ac:	687b      	ldr	r3, [r7, #4]
 80035ae:	4a3c      	ldr	r2, [pc, #240]	; (80036a0 <TIM_Base_SetConfig+0x11c>)
 80035b0:	4293      	cmp	r3, r2
 80035b2:	d007      	beq.n	80035c4 <TIM_Base_SetConfig+0x40>
 80035b4:	687b      	ldr	r3, [r7, #4]
 80035b6:	4a3b      	ldr	r2, [pc, #236]	; (80036a4 <TIM_Base_SetConfig+0x120>)
 80035b8:	4293      	cmp	r3, r2
 80035ba:	d003      	beq.n	80035c4 <TIM_Base_SetConfig+0x40>
 80035bc:	687b      	ldr	r3, [r7, #4]
 80035be:	4a3a      	ldr	r2, [pc, #232]	; (80036a8 <TIM_Base_SetConfig+0x124>)
 80035c0:	4293      	cmp	r3, r2
 80035c2:	d108      	bne.n	80035d6 <TIM_Base_SetConfig+0x52>
  {
    /* Select the Counter Mode */
    tmpcr1 &= ~(TIM_CR1_DIR | TIM_CR1_CMS);
 80035c4:	68fb      	ldr	r3, [r7, #12]
 80035c6:	f023 0370 	bic.w	r3, r3, #112	; 0x70
 80035ca:	60fb      	str	r3, [r7, #12]
    tmpcr1 |= Structure->CounterMode;
 80035cc:	683b      	ldr	r3, [r7, #0]
 80035ce:	685b      	ldr	r3, [r3, #4]
 80035d0:	68fa      	ldr	r2, [r7, #12]
 80035d2:	4313      	orrs	r3, r2
 80035d4:	60fb      	str	r3, [r7, #12]
  }

  if (IS_TIM_CLOCK_DIVISION_INSTANCE(TIMx))
 80035d6:	687b      	ldr	r3, [r7, #4]
 80035d8:	4a2f      	ldr	r2, [pc, #188]	; (8003698 <TIM_Base_SetConfig+0x114>)
 80035da:	4293      	cmp	r3, r2
 80035dc:	d02b      	beq.n	8003636 <TIM_Base_SetConfig+0xb2>
 80035de:	687b      	ldr	r3, [r7, #4]
 80035e0:	f1b3 4f80 	cmp.w	r3, #1073741824	; 0x40000000
 80035e4:	d027      	beq.n	8003636 <TIM_Base_SetConfig+0xb2>
 80035e6:	687b      	ldr	r3, [r7, #4]
 80035e8:	4a2c      	ldr	r2, [pc, #176]	; (800369c <TIM_Base_SetConfig+0x118>)
 80035ea:	4293      	cmp	r3, r2
 80035ec:	d023      	beq.n	8003636 <TIM_Base_SetConfig+0xb2>
 80035ee:	687b      	ldr	r3, [r7, #4]
 80035f0:	4a2b      	ldr	r2, [pc, #172]	; (80036a0 <TIM_Base_SetConfig+0x11c>)
 80035f2:	4293      	cmp	r3, r2
 80035f4:	d01f      	beq.n	8003636 <TIM_Base_SetConfig+0xb2>
 80035f6:	687b      	ldr	r3, [r7, #4]
 80035f8:	4a2a      	ldr	r2, [pc, #168]	; (80036a4 <TIM_Base_SetConfig+0x120>)
 80035fa:	4293      	cmp	r3, r2
 80035fc:	d01b      	beq.n	8003636 <TIM_Base_SetConfig+0xb2>
 80035fe:	687b      	ldr	r3, [r7, #4]
 8003600:	4a29      	ldr	r2, [pc, #164]	; (80036a8 <TIM_Base_SetConfig+0x124>)
 8003602:	4293      	cmp	r3, r2
 8003604:	d017      	beq.n	8003636 <TIM_Base_SetConfig+0xb2>
 8003606:	687b      	ldr	r3, [r7, #4]
 8003608:	4a28      	ldr	r2, [pc, #160]	; (80036ac <TIM_Base_SetConfig+0x128>)
 800360a:	4293      	cmp	r3, r2
 800360c:	d013      	beq.n	8003636 <TIM_Base_SetConfig+0xb2>
 800360e:	687b      	ldr	r3, [r7, #4]
 8003610:	4a27      	ldr	r2, [pc, #156]	; (80036b0 <TIM_Base_SetConfig+0x12c>)
 8003612:	4293      	cmp	r3, r2
 8003614:	d00f      	beq.n	8003636 <TIM_Base_SetConfig+0xb2>
 8003616:	687b      	ldr	r3, [r7, #4]
 8003618:	4a26      	ldr	r2, [pc, #152]	; (80036b4 <TIM_Base_SetConfig+0x130>)
 800361a:	4293      	cmp	r3, r2
 800361c:	d00b      	beq.n	8003636 <TIM_Base_SetConfig+0xb2>
 800361e:	687b      	ldr	r3, [r7, #4]
 8003620:	4a25      	ldr	r2, [pc, #148]	; (80036b8 <TIM_Base_SetConfig+0x134>)
 8003622:	4293      	cmp	r3, r2
 8003624:	d007      	beq.n	8003636 <TIM_Base_SetConfig+0xb2>
 8003626:	687b      	ldr	r3, [r7, #4]
 8003628:	4a24      	ldr	r2, [pc, #144]	; (80036bc <TIM_Base_SetConfig+0x138>)
 800362a:	4293      	cmp	r3, r2
 800362c:	d003      	beq.n	8003636 <TIM_Base_SetConfig+0xb2>
 800362e:	687b      	ldr	r3, [r7, #4]
 8003630:	4a23      	ldr	r2, [pc, #140]	; (80036c0 <TIM_Base_SetConfig+0x13c>)
 8003632:	4293      	cmp	r3, r2
 8003634:	d108      	bne.n	8003648 <TIM_Base_SetConfig+0xc4>
  {
    /* Set the clock division */
    tmpcr1 &= ~TIM_CR1_CKD;
 8003636:	68fb      	ldr	r3, [r7, #12]
 8003638:	f423 7340 	bic.w	r3, r3, #768	; 0x300
 800363c:	60fb      	str	r3, [r7, #12]
    tmpcr1 |= (uint32_t)Structure->ClockDivision;
 800363e:	683b      	ldr	r3, [r7, #0]
 8003640:	68db      	ldr	r3, [r3, #12]
 8003642:	68fa      	ldr	r2, [r7, #12]
 8003644:	4313      	orrs	r3, r2
 8003646:	60fb      	str	r3, [r7, #12]
  }

  /* Set the auto-reload preload */
  MODIFY_REG(tmpcr1, TIM_CR1_ARPE, Structure->AutoReloadPreload);
 8003648:	68fb      	ldr	r3, [r7, #12]
 800364a:	f023 0280 	bic.w	r2, r3, #128	; 0x80
 800364e:	683b      	ldr	r3, [r7, #0]
 8003650:	695b      	ldr	r3, [r3, #20]
 8003652:	4313      	orrs	r3, r2
 8003654:	60fb      	str	r3, [r7, #12]

  TIMx->CR1 = tmpcr1;
 8003656:	687b      	ldr	r3, [r7, #4]
 8003658:	68fa      	ldr	r2, [r7, #12]
 800365a:	601a      	str	r2, [r3, #0]

  /* Set the Autoreload value */
  TIMx->ARR = (uint32_t)Structure->Period ;
 800365c:	683b      	ldr	r3, [r7, #0]
 800365e:	689a      	ldr	r2, [r3, #8]
 8003660:	687b      	ldr	r3, [r7, #4]
 8003662:	62da      	str	r2, [r3, #44]	; 0x2c

  /* Set the Prescaler value */
  TIMx->PSC = Structure->Prescaler;
 8003664:	683b      	ldr	r3, [r7, #0]
 8003666:	681a      	ldr	r2, [r3, #0]
 8003668:	687b      	ldr	r3, [r7, #4]
 800366a:	629a      	str	r2, [r3, #40]	; 0x28

  if (IS_TIM_REPETITION_COUNTER_INSTANCE(TIMx))
 800366c:	687b      	ldr	r3, [r7, #4]
 800366e:	4a0a      	ldr	r2, [pc, #40]	; (8003698 <TIM_Base_SetConfig+0x114>)
 8003670:	4293      	cmp	r3, r2
 8003672:	d003      	beq.n	800367c <TIM_Base_SetConfig+0xf8>
 8003674:	687b      	ldr	r3, [r7, #4]
 8003676:	4a0c      	ldr	r2, [pc, #48]	; (80036a8 <TIM_Base_SetConfig+0x124>)
 8003678:	4293      	cmp	r3, r2
 800367a:	d103      	bne.n	8003684 <TIM_Base_SetConfig+0x100>
  {
    /* Set the Repetition Counter value */
    TIMx->RCR = Structure->RepetitionCounter;
 800367c:	683b      	ldr	r3, [r7, #0]
 800367e:	691a      	ldr	r2, [r3, #16]
 8003680:	687b      	ldr	r3, [r7, #4]
 8003682:	631a      	str	r2, [r3, #48]	; 0x30
  }

  /* Generate an update event to reload the Prescaler
     and the repetition counter (only for advanced timer) value immediately */
  TIMx->EGR = TIM_EGR_UG;
 8003684:	687b      	ldr	r3, [r7, #4]
 8003686:	2201      	movs	r2, #1
 8003688:	615a      	str	r2, [r3, #20]
}
 800368a:	bf00      	nop
 800368c:	3714      	adds	r7, #20
 800368e:	46bd      	mov	sp, r7
 8003690:	f85d 7b04 	ldr.w	r7, [sp], #4
 8003694:	4770      	bx	lr
 8003696:	bf00      	nop
 8003698:	40010000 	.word	0x40010000
 800369c:	40000400 	.word	0x40000400
 80036a0:	40000800 	.word	0x40000800
 80036a4:	40000c00 	.word	0x40000c00
 80036a8:	40010400 	.word	0x40010400
 80036ac:	40014000 	.word	0x40014000
 80036b0:	40014400 	.word	0x40014400
 80036b4:	40014800 	.word	0x40014800
 80036b8:	40001800 	.word	0x40001800
 80036bc:	40001c00 	.word	0x40001c00
 80036c0:	40002000 	.word	0x40002000

080036c4 <TIM_TI1_ConfigInputStage>:
  * @param  TIM_ICFilter Specifies the Input Capture Filter.
  *          This parameter must be a value between 0x00 and 0x0F.
  * @retval None
  */
static void TIM_TI1_ConfigInputStage(TIM_TypeDef *TIMx, uint32_t TIM_ICPolarity, uint32_t TIM_ICFilter)
{
 80036c4:	b480      	push	{r7}
 80036c6:	b087      	sub	sp, #28
 80036c8:	af00      	add	r7, sp, #0
 80036ca:	60f8      	str	r0, [r7, #12]
 80036cc:	60b9      	str	r1, [r7, #8]
 80036ce:	607a      	str	r2, [r7, #4]
  uint32_t tmpccmr1;
  uint32_t tmpccer;

  /* Disable the Channel 1: Reset the CC1E Bit */
  tmpccer = TIMx->CCER;
 80036d0:	68fb      	ldr	r3, [r7, #12]
 80036d2:	6a1b      	ldr	r3, [r3, #32]
 80036d4:	617b      	str	r3, [r7, #20]
  TIMx->CCER &= ~TIM_CCER_CC1E;
 80036d6:	68fb      	ldr	r3, [r7, #12]
 80036d8:	6a1b      	ldr	r3, [r3, #32]
 80036da:	f023 0201 	bic.w	r2, r3, #1
 80036de:	68fb      	ldr	r3, [r7, #12]
 80036e0:	621a      	str	r2, [r3, #32]
  tmpccmr1 = TIMx->CCMR1;
 80036e2:	68fb      	ldr	r3, [r7, #12]
 80036e4:	699b      	ldr	r3, [r3, #24]
 80036e6:	613b      	str	r3, [r7, #16]

  /* Set the filter */
  tmpccmr1 &= ~TIM_CCMR1_IC1F;
 80036e8:	693b      	ldr	r3, [r7, #16]
 80036ea:	f023 03f0 	bic.w	r3, r3, #240	; 0xf0
 80036ee:	613b      	str	r3, [r7, #16]
  tmpccmr1 |= (TIM_ICFilter << 4U);
 80036f0:	687b      	ldr	r3, [r7, #4]
 80036f2:	011b      	lsls	r3, r3, #4
 80036f4:	693a      	ldr	r2, [r7, #16]
 80036f6:	4313      	orrs	r3, r2
 80036f8:	613b      	str	r3, [r7, #16]

  /* Select the Polarity and set the CC1E Bit */
  tmpccer &= ~(TIM_CCER_CC1P | TIM_CCER_CC1NP);
 80036fa:	697b      	ldr	r3, [r7, #20]
 80036fc:	f023 030a 	bic.w	r3, r3, #10
 8003700:	617b      	str	r3, [r7, #20]
  tmpccer |= TIM_ICPolarity;
 8003702:	697a      	ldr	r2, [r7, #20]
 8003704:	68bb      	ldr	r3, [r7, #8]
 8003706:	4313      	orrs	r3, r2
 8003708:	617b      	str	r3, [r7, #20]

  /* Write to TIMx CCMR1 and CCER registers */
  TIMx->CCMR1 = tmpccmr1;
 800370a:	68fb      	ldr	r3, [r7, #12]
 800370c:	693a      	ldr	r2, [r7, #16]
 800370e:	619a      	str	r2, [r3, #24]
  TIMx->CCER = tmpccer;
 8003710:	68fb      	ldr	r3, [r7, #12]
 8003712:	697a      	ldr	r2, [r7, #20]
 8003714:	621a      	str	r2, [r3, #32]
}
 8003716:	bf00      	nop
 8003718:	371c      	adds	r7, #28
 800371a:	46bd      	mov	sp, r7
 800371c:	f85d 7b04 	ldr.w	r7, [sp], #4
 8003720:	4770      	bx	lr

08003722 <TIM_TI2_ConfigInputStage>:
  * @param  TIM_ICFilter Specifies the Input Capture Filter.
  *          This parameter must be a value between 0x00 and 0x0F.
  * @retval None
  */
static void TIM_TI2_ConfigInputStage(TIM_TypeDef *TIMx, uint32_t TIM_ICPolarity, uint32_t TIM_ICFilter)
{
 8003722:	b480      	push	{r7}
 8003724:	b087      	sub	sp, #28
 8003726:	af00      	add	r7, sp, #0
 8003728:	60f8      	str	r0, [r7, #12]
 800372a:	60b9      	str	r1, [r7, #8]
 800372c:	607a      	str	r2, [r7, #4]
  uint32_t tmpccmr1;
  uint32_t tmpccer;

  /* Disable the Channel 2: Reset the CC2E Bit */
  TIMx->CCER &= ~TIM_CCER_CC2E;
 800372e:	68fb      	ldr	r3, [r7, #12]
 8003730:	6a1b      	ldr	r3, [r3, #32]
 8003732:	f023 0210 	bic.w	r2, r3, #16
 8003736:	68fb      	ldr	r3, [r7, #12]
 8003738:	621a      	str	r2, [r3, #32]
  tmpccmr1 = TIMx->CCMR1;
 800373a:	68fb      	ldr	r3, [r7, #12]
 800373c:	699b      	ldr	r3, [r3, #24]
 800373e:	617b      	str	r3, [r7, #20]
  tmpccer = TIMx->CCER;
 8003740:	68fb      	ldr	r3, [r7, #12]
 8003742:	6a1b      	ldr	r3, [r3, #32]
 8003744:	613b      	str	r3, [r7, #16]

  /* Set the filter */
  tmpccmr1 &= ~TIM_CCMR1_IC2F;
 8003746:	697b      	ldr	r3, [r7, #20]
 8003748:	f423 4370 	bic.w	r3, r3, #61440	; 0xf000
 800374c:	617b      	str	r3, [r7, #20]
  tmpccmr1 |= (TIM_ICFilter << 12U);
 800374e:	687b      	ldr	r3, [r7, #4]
 8003750:	031b      	lsls	r3, r3, #12
 8003752:	697a      	ldr	r2, [r7, #20]
 8003754:	4313      	orrs	r3, r2
 8003756:	617b      	str	r3, [r7, #20]

  /* Select the Polarity and set the CC2E Bit */
  tmpccer &= ~(TIM_CCER_CC2P | TIM_CCER_CC2NP);
 8003758:	693b      	ldr	r3, [r7, #16]
 800375a:	f023 03a0 	bic.w	r3, r3, #160	; 0xa0
 800375e:	613b      	str	r3, [r7, #16]
  tmpccer |= (TIM_ICPolarity << 4U);
 8003760:	68bb      	ldr	r3, [r7, #8]
 8003762:	011b      	lsls	r3, r3, #4
 8003764:	693a      	ldr	r2, [r7, #16]
 8003766:	4313      	orrs	r3, r2
 8003768:	613b      	str	r3, [r7, #16]

  /* Write to TIMx CCMR1 and CCER registers */
  TIMx->CCMR1 = tmpccmr1 ;
 800376a:	68fb      	ldr	r3, [r7, #12]
 800376c:	697a      	ldr	r2, [r7, #20]
 800376e:	619a      	str	r2, [r3, #24]
  TIMx->CCER = tmpccer;
 8003770:	68fb      	ldr	r3, [r7, #12]
 8003772:	693a      	ldr	r2, [r7, #16]
 8003774:	621a      	str	r2, [r3, #32]
}
 8003776:	bf00      	nop
 8003778:	371c      	adds	r7, #28
 800377a:	46bd      	mov	sp, r7
 800377c:	f85d 7b04 	ldr.w	r7, [sp], #4
 8003780:	4770      	bx	lr

08003782 <TIM_ITRx_SetConfig>:
  *            @arg TIM_TS_TI2FP2: Filtered Timer Input 2
  *            @arg TIM_TS_ETRF: External Trigger input
  * @retval None
  */
static void TIM_ITRx_SetConfig(TIM_TypeDef *TIMx, uint32_t InputTriggerSource)
{
 8003782:	b480      	push	{r7}
 8003784:	b085      	sub	sp, #20
 8003786:	af00      	add	r7, sp, #0
 8003788:	6078      	str	r0, [r7, #4]
 800378a:	6039      	str	r1, [r7, #0]
  uint32_t tmpsmcr;

  /* Get the TIMx SMCR register value */
  tmpsmcr = TIMx->SMCR;
 800378c:	687b      	ldr	r3, [r7, #4]
 800378e:	689b      	ldr	r3, [r3, #8]
 8003790:	60fb      	str	r3, [r7, #12]
  /* Reset the TS Bits */
  tmpsmcr &= ~TIM_SMCR_TS;
 8003792:	68fb      	ldr	r3, [r7, #12]
 8003794:	f023 0370 	bic.w	r3, r3, #112	; 0x70
 8003798:	60fb      	str	r3, [r7, #12]
  /* Set the Input Trigger source and the slave mode*/
  tmpsmcr |= (InputTriggerSource | TIM_SLAVEMODE_EXTERNAL1);
 800379a:	683a      	ldr	r2, [r7, #0]
 800379c:	68fb      	ldr	r3, [r7, #12]
 800379e:	4313      	orrs	r3, r2
 80037a0:	f043 0307 	orr.w	r3, r3, #7
 80037a4:	60fb      	str	r3, [r7, #12]
  /* Write to TIMx SMCR */
  TIMx->SMCR = tmpsmcr;
 80037a6:	687b      	ldr	r3, [r7, #4]
 80037a8:	68fa      	ldr	r2, [r7, #12]
 80037aa:	609a      	str	r2, [r3, #8]
}
 80037ac:	bf00      	nop
 80037ae:	3714      	adds	r7, #20
 80037b0:	46bd      	mov	sp, r7
 80037b2:	f85d 7b04 	ldr.w	r7, [sp], #4
 80037b6:	4770      	bx	lr

080037b8 <TIM_ETR_SetConfig>:
  *          This parameter must be a value between 0x00 and 0x0F
  * @retval None
  */
void TIM_ETR_SetConfig(TIM_TypeDef *TIMx, uint32_t TIM_ExtTRGPrescaler,
                       uint32_t TIM_ExtTRGPolarity, uint32_t ExtTRGFilter)
{
 80037b8:	b480      	push	{r7}
 80037ba:	b087      	sub	sp, #28
 80037bc:	af00      	add	r7, sp, #0
 80037be:	60f8      	str	r0, [r7, #12]
 80037c0:	60b9      	str	r1, [r7, #8]
 80037c2:	607a      	str	r2, [r7, #4]
 80037c4:	603b      	str	r3, [r7, #0]
  uint32_t tmpsmcr;

  tmpsmcr = TIMx->SMCR;
 80037c6:	68fb      	ldr	r3, [r7, #12]
 80037c8:	689b      	ldr	r3, [r3, #8]
 80037ca:	617b      	str	r3, [r7, #20]

  /* Reset the ETR Bits */
  tmpsmcr &= ~(TIM_SMCR_ETF | TIM_SMCR_ETPS | TIM_SMCR_ECE | TIM_SMCR_ETP);
 80037cc:	697b      	ldr	r3, [r7, #20]
 80037ce:	f423 437f 	bic.w	r3, r3, #65280	; 0xff00
 80037d2:	617b      	str	r3, [r7, #20]

  /* Set the Prescaler, the Filter value and the Polarity */
  tmpsmcr |= (uint32_t)(TIM_ExtTRGPrescaler | (TIM_ExtTRGPolarity | (ExtTRGFilter << 8U)));
 80037d4:	683b      	ldr	r3, [r7, #0]
 80037d6:	021a      	lsls	r2, r3, #8
 80037d8:	687b      	ldr	r3, [r7, #4]
 80037da:	431a      	orrs	r2, r3
 80037dc:	68bb      	ldr	r3, [r7, #8]
 80037de:	4313      	orrs	r3, r2
 80037e0:	697a      	ldr	r2, [r7, #20]
 80037e2:	4313      	orrs	r3, r2
 80037e4:	617b      	str	r3, [r7, #20]

  /* Write to TIMx SMCR */
  TIMx->SMCR = tmpsmcr;
 80037e6:	68fb      	ldr	r3, [r7, #12]
 80037e8:	697a      	ldr	r2, [r7, #20]
 80037ea:	609a      	str	r2, [r3, #8]
}
 80037ec:	bf00      	nop
 80037ee:	371c      	adds	r7, #28
 80037f0:	46bd      	mov	sp, r7
 80037f2:	f85d 7b04 	ldr.w	r7, [sp], #4
 80037f6:	4770      	bx	lr

080037f8 <HAL_TIMEx_MasterConfigSynchronization>:
  *         mode.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_TIMEx_MasterConfigSynchronization(TIM_HandleTypeDef *htim,
                                                        TIM_MasterConfigTypeDef *sMasterConfig)
{
 80037f8:	b480      	push	{r7}
 80037fa:	b085      	sub	sp, #20
 80037fc:	af00      	add	r7, sp, #0
 80037fe:	6078      	str	r0, [r7, #4]
 8003800:	6039      	str	r1, [r7, #0]
  assert_param(IS_TIM_MASTER_INSTANCE(htim->Instance));
  assert_param(IS_TIM_TRGO_SOURCE(sMasterConfig->MasterOutputTrigger));
  assert_param(IS_TIM_MSM_STATE(sMasterConfig->MasterSlaveMode));

  /* Check input state */
  __HAL_LOCK(htim);
 8003802:	687b      	ldr	r3, [r7, #4]
 8003804:	f893 303c 	ldrb.w	r3, [r3, #60]	; 0x3c
 8003808:	2b01      	cmp	r3, #1
 800380a:	d101      	bne.n	8003810 <HAL_TIMEx_MasterConfigSynchronization+0x18>
 800380c:	2302      	movs	r3, #2
 800380e:	e06d      	b.n	80038ec <HAL_TIMEx_MasterConfigSynchronization+0xf4>
 8003810:	687b      	ldr	r3, [r7, #4]
 8003812:	2201      	movs	r2, #1
 8003814:	f883 203c 	strb.w	r2, [r3, #60]	; 0x3c

  /* Change the handler state */
  htim->State = HAL_TIM_STATE_BUSY;
 8003818:	687b      	ldr	r3, [r7, #4]
 800381a:	2202      	movs	r2, #2
 800381c:	f883 203d 	strb.w	r2, [r3, #61]	; 0x3d

  /* Get the TIMx CR2 register value */
  tmpcr2 = htim->Instance->CR2;
 8003820:	687b      	ldr	r3, [r7, #4]
 8003822:	681b      	ldr	r3, [r3, #0]
 8003824:	685b      	ldr	r3, [r3, #4]
 8003826:	60fb      	str	r3, [r7, #12]

  /* Get the TIMx SMCR register value */
  tmpsmcr = htim->Instance->SMCR;
 8003828:	687b      	ldr	r3, [r7, #4]
 800382a:	681b      	ldr	r3, [r3, #0]
 800382c:	689b      	ldr	r3, [r3, #8]
 800382e:	60bb      	str	r3, [r7, #8]

  /* If the timer supports ADC synchronization through TRGO2, set the master mode selection 2 */
  if (IS_TIM_TRGO2_INSTANCE(htim->Instance))
 8003830:	687b      	ldr	r3, [r7, #4]
 8003832:	681b      	ldr	r3, [r3, #0]
 8003834:	4a30      	ldr	r2, [pc, #192]	; (80038f8 <HAL_TIMEx_MasterConfigSynchronization+0x100>)
 8003836:	4293      	cmp	r3, r2
 8003838:	d004      	beq.n	8003844 <HAL_TIMEx_MasterConfigSynchronization+0x4c>
 800383a:	687b      	ldr	r3, [r7, #4]
 800383c:	681b      	ldr	r3, [r3, #0]
 800383e:	4a2f      	ldr	r2, [pc, #188]	; (80038fc <HAL_TIMEx_MasterConfigSynchronization+0x104>)
 8003840:	4293      	cmp	r3, r2
 8003842:	d108      	bne.n	8003856 <HAL_TIMEx_MasterConfigSynchronization+0x5e>
  {
    /* Check the parameters */
    assert_param(IS_TIM_TRGO2_SOURCE(sMasterConfig->MasterOutputTrigger2));

    /* Clear the MMS2 bits */
    tmpcr2 &= ~TIM_CR2_MMS2;
 8003844:	68fb      	ldr	r3, [r7, #12]
 8003846:	f423 0370 	bic.w	r3, r3, #15728640	; 0xf00000
 800384a:	60fb      	str	r3, [r7, #12]
    /* Select the TRGO2 source*/
    tmpcr2 |= sMasterConfig->MasterOutputTrigger2;
 800384c:	683b      	ldr	r3, [r7, #0]
 800384e:	685b      	ldr	r3, [r3, #4]
 8003850:	68fa      	ldr	r2, [r7, #12]
 8003852:	4313      	orrs	r3, r2
 8003854:	60fb      	str	r3, [r7, #12]
  }

  /* Reset the MMS Bits */
  tmpcr2 &= ~TIM_CR2_MMS;
 8003856:	68fb      	ldr	r3, [r7, #12]
 8003858:	f023 0370 	bic.w	r3, r3, #112	; 0x70
 800385c:	60fb      	str	r3, [r7, #12]
  /* Select the TRGO source */
  tmpcr2 |=  sMasterConfig->MasterOutputTrigger;
 800385e:	683b      	ldr	r3, [r7, #0]
 8003860:	681b      	ldr	r3, [r3, #0]
 8003862:	68fa      	ldr	r2, [r7, #12]
 8003864:	4313      	orrs	r3, r2
 8003866:	60fb      	str	r3, [r7, #12]

  /* Update TIMx CR2 */
  htim->Instance->CR2 = tmpcr2;
 8003868:	687b      	ldr	r3, [r7, #4]
 800386a:	681b      	ldr	r3, [r3, #0]
 800386c:	68fa      	ldr	r2, [r7, #12]
 800386e:	605a      	str	r2, [r3, #4]

  if (IS_TIM_SLAVE_INSTANCE(htim->Instance))
 8003870:	687b      	ldr	r3, [r7, #4]
 8003872:	681b      	ldr	r3, [r3, #0]
 8003874:	4a20      	ldr	r2, [pc, #128]	; (80038f8 <HAL_TIMEx_MasterConfigSynchronization+0x100>)
 8003876:	4293      	cmp	r3, r2
 8003878:	d022      	beq.n	80038c0 <HAL_TIMEx_MasterConfigSynchronization+0xc8>
 800387a:	687b      	ldr	r3, [r7, #4]
 800387c:	681b      	ldr	r3, [r3, #0]
 800387e:	f1b3 4f80 	cmp.w	r3, #1073741824	; 0x40000000
 8003882:	d01d      	beq.n	80038c0 <HAL_TIMEx_MasterConfigSynchronization+0xc8>
 8003884:	687b      	ldr	r3, [r7, #4]
 8003886:	681b      	ldr	r3, [r3, #0]
 8003888:	4a1d      	ldr	r2, [pc, #116]	; (8003900 <HAL_TIMEx_MasterConfigSynchronization+0x108>)
 800388a:	4293      	cmp	r3, r2
 800388c:	d018      	beq.n	80038c0 <HAL_TIMEx_MasterConfigSynchronization+0xc8>
 800388e:	687b      	ldr	r3, [r7, #4]
 8003890:	681b      	ldr	r3, [r3, #0]
 8003892:	4a1c      	ldr	r2, [pc, #112]	; (8003904 <HAL_TIMEx_MasterConfigSynchronization+0x10c>)
 8003894:	4293      	cmp	r3, r2
 8003896:	d013      	beq.n	80038c0 <HAL_TIMEx_MasterConfigSynchronization+0xc8>
 8003898:	687b      	ldr	r3, [r7, #4]
 800389a:	681b      	ldr	r3, [r3, #0]
 800389c:	4a1a      	ldr	r2, [pc, #104]	; (8003908 <HAL_TIMEx_MasterConfigSynchronization+0x110>)
 800389e:	4293      	cmp	r3, r2
 80038a0:	d00e      	beq.n	80038c0 <HAL_TIMEx_MasterConfigSynchronization+0xc8>
 80038a2:	687b      	ldr	r3, [r7, #4]
 80038a4:	681b      	ldr	r3, [r3, #0]
 80038a6:	4a15      	ldr	r2, [pc, #84]	; (80038fc <HAL_TIMEx_MasterConfigSynchronization+0x104>)
 80038a8:	4293      	cmp	r3, r2
 80038aa:	d009      	beq.n	80038c0 <HAL_TIMEx_MasterConfigSynchronization+0xc8>
 80038ac:	687b      	ldr	r3, [r7, #4]
 80038ae:	681b      	ldr	r3, [r3, #0]
 80038b0:	4a16      	ldr	r2, [pc, #88]	; (800390c <HAL_TIMEx_MasterConfigSynchronization+0x114>)
 80038b2:	4293      	cmp	r3, r2
 80038b4:	d004      	beq.n	80038c0 <HAL_TIMEx_MasterConfigSynchronization+0xc8>
 80038b6:	687b      	ldr	r3, [r7, #4]
 80038b8:	681b      	ldr	r3, [r3, #0]
 80038ba:	4a15      	ldr	r2, [pc, #84]	; (8003910 <HAL_TIMEx_MasterConfigSynchronization+0x118>)
 80038bc:	4293      	cmp	r3, r2
 80038be:	d10c      	bne.n	80038da <HAL_TIMEx_MasterConfigSynchronization+0xe2>
  {
    /* Reset the MSM Bit */
    tmpsmcr &= ~TIM_SMCR_MSM;
 80038c0:	68bb      	ldr	r3, [r7, #8]
 80038c2:	f023 0380 	bic.w	r3, r3, #128	; 0x80
 80038c6:	60bb      	str	r3, [r7, #8]
    /* Set master mode */
    tmpsmcr |= sMasterConfig->MasterSlaveMode;
 80038c8:	683b      	ldr	r3, [r7, #0]
 80038ca:	689b      	ldr	r3, [r3, #8]
 80038cc:	68ba      	ldr	r2, [r7, #8]
 80038ce:	4313      	orrs	r3, r2
 80038d0:	60bb      	str	r3, [r7, #8]

    /* Update TIMx SMCR */
    htim->Instance->SMCR = tmpsmcr;
 80038d2:	687b      	ldr	r3, [r7, #4]
 80038d4:	681b      	ldr	r3, [r3, #0]
 80038d6:	68ba      	ldr	r2, [r7, #8]
 80038d8:	609a      	str	r2, [r3, #8]
  }

  /* Change the htim state */
  htim->State = HAL_TIM_STATE_READY;
 80038da:	687b      	ldr	r3, [r7, #4]
 80038dc:	2201      	movs	r2, #1
 80038de:	f883 203d 	strb.w	r2, [r3, #61]	; 0x3d

  __HAL_UNLOCK(htim);
 80038e2:	687b      	ldr	r3, [r7, #4]
 80038e4:	2200      	movs	r2, #0
 80038e6:	f883 203c 	strb.w	r2, [r3, #60]	; 0x3c

  return HAL_OK;
 80038ea:	2300      	movs	r3, #0
}
 80038ec:	4618      	mov	r0, r3
 80038ee:	3714      	adds	r7, #20
 80038f0:	46bd      	mov	sp, r7
 80038f2:	f85d 7b04 	ldr.w	r7, [sp], #4
 80038f6:	4770      	bx	lr
 80038f8:	40010000 	.word	0x40010000
 80038fc:	40010400 	.word	0x40010400
 8003900:	40000400 	.word	0x40000400
 8003904:	40000800 	.word	0x40000800
 8003908:	40000c00 	.word	0x40000c00
 800390c:	40014000 	.word	0x40014000
 8003910:	40001800 	.word	0x40001800

08003914 <HAL_UART_Init>:
  *        parameters in the UART_InitTypeDef and initialize the associated handle.
  * @param huart UART handle.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_UART_Init(UART_HandleTypeDef *huart)
{
 8003914:	b580      	push	{r7, lr}
 8003916:	b082      	sub	sp, #8
 8003918:	af00      	add	r7, sp, #0
 800391a:	6078      	str	r0, [r7, #4]
  /* Check the UART handle allocation */
  if (huart == NULL)
 800391c:	687b      	ldr	r3, [r7, #4]
 800391e:	2b00      	cmp	r3, #0
 8003920:	d101      	bne.n	8003926 <HAL_UART_Init+0x12>
  {
    return HAL_ERROR;
 8003922:	2301      	movs	r3, #1
 8003924:	e040      	b.n	80039a8 <HAL_UART_Init+0x94>
  {
    /* Check the parameters */
    assert_param(IS_UART_INSTANCE(huart->Instance));
  }

  if (huart->gState == HAL_UART_STATE_RESET)
 8003926:	687b      	ldr	r3, [r7, #4]
 8003928:	6f5b      	ldr	r3, [r3, #116]	; 0x74
 800392a:	2b00      	cmp	r3, #0
 800392c:	d106      	bne.n	800393c <HAL_UART_Init+0x28>
  {
    /* Allocate lock resource and initialize it */
    huart->Lock = HAL_UNLOCKED;
 800392e:	687b      	ldr	r3, [r7, #4]
 8003930:	2200      	movs	r2, #0
 8003932:	f883 2070 	strb.w	r2, [r3, #112]	; 0x70

    /* Init the low level hardware */
    huart->MspInitCallback(huart);
#else
    /* Init the low level hardware : GPIO, CLOCK */
    HAL_UART_MspInit(huart);
 8003936:	6878      	ldr	r0, [r7, #4]
 8003938:	f7fd fd16 	bl	8001368 <HAL_UART_MspInit>
#endif /* (USE_HAL_UART_REGISTER_CALLBACKS) */
  }

  huart->gState = HAL_UART_STATE_BUSY;
 800393c:	687b      	ldr	r3, [r7, #4]
 800393e:	2224      	movs	r2, #36	; 0x24
 8003940:	675a      	str	r2, [r3, #116]	; 0x74

  __HAL_UART_DISABLE(huart);
 8003942:	687b      	ldr	r3, [r7, #4]
 8003944:	681b      	ldr	r3, [r3, #0]
 8003946:	681a      	ldr	r2, [r3, #0]
 8003948:	687b      	ldr	r3, [r7, #4]
 800394a:	681b      	ldr	r3, [r3, #0]
 800394c:	f022 0201 	bic.w	r2, r2, #1
 8003950:	601a      	str	r2, [r3, #0]

  /* Set the UART Communication parameters */
  if (UART_SetConfig(huart) == HAL_ERROR)
 8003952:	6878      	ldr	r0, [r7, #4]
 8003954:	f000 f82c 	bl	80039b0 <UART_SetConfig>
 8003958:	4603      	mov	r3, r0
 800395a:	2b01      	cmp	r3, #1
 800395c:	d101      	bne.n	8003962 <HAL_UART_Init+0x4e>
  {
    return HAL_ERROR;
 800395e:	2301      	movs	r3, #1
 8003960:	e022      	b.n	80039a8 <HAL_UART_Init+0x94>
  }

  if (huart->AdvancedInit.AdvFeatureInit != UART_ADVFEATURE_NO_INIT)
 8003962:	687b      	ldr	r3, [r7, #4]
 8003964:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8003966:	2b00      	cmp	r3, #0
 8003968:	d002      	beq.n	8003970 <HAL_UART_Init+0x5c>
  {
    UART_AdvFeatureConfig(huart);
 800396a:	6878      	ldr	r0, [r7, #4]
 800396c:	f000 faca 	bl	8003f04 <UART_AdvFeatureConfig>
  }

  /* In asynchronous mode, the following bits must be kept cleared:
  - LINEN and CLKEN bits in the USART_CR2 register,
  - SCEN, HDSEL and IREN  bits in the USART_CR3 register.*/
  CLEAR_BIT(huart->Instance->CR2, (USART_CR2_LINEN | USART_CR2_CLKEN));
 8003970:	687b      	ldr	r3, [r7, #4]
 8003972:	681b      	ldr	r3, [r3, #0]
 8003974:	685a      	ldr	r2, [r3, #4]
 8003976:	687b      	ldr	r3, [r7, #4]
 8003978:	681b      	ldr	r3, [r3, #0]
 800397a:	f422 4290 	bic.w	r2, r2, #18432	; 0x4800
 800397e:	605a      	str	r2, [r3, #4]
  CLEAR_BIT(huart->Instance->CR3, (USART_CR3_SCEN | USART_CR3_HDSEL | USART_CR3_IREN));
 8003980:	687b      	ldr	r3, [r7, #4]
 8003982:	681b      	ldr	r3, [r3, #0]
 8003984:	689a      	ldr	r2, [r3, #8]
 8003986:	687b      	ldr	r3, [r7, #4]
 8003988:	681b      	ldr	r3, [r3, #0]
 800398a:	f022 022a 	bic.w	r2, r2, #42	; 0x2a
 800398e:	609a      	str	r2, [r3, #8]

  __HAL_UART_ENABLE(huart);
 8003990:	687b      	ldr	r3, [r7, #4]
 8003992:	681b      	ldr	r3, [r3, #0]
 8003994:	681a      	ldr	r2, [r3, #0]
 8003996:	687b      	ldr	r3, [r7, #4]
 8003998:	681b      	ldr	r3, [r3, #0]
 800399a:	f042 0201 	orr.w	r2, r2, #1
 800399e:	601a      	str	r2, [r3, #0]

  /* TEACK and/or REACK to check before moving huart->gState and huart->RxState to Ready */
  return (UART_CheckIdleState(huart));
 80039a0:	6878      	ldr	r0, [r7, #4]
 80039a2:	f000 fb51 	bl	8004048 <UART_CheckIdleState>
 80039a6:	4603      	mov	r3, r0
}
 80039a8:	4618      	mov	r0, r3
 80039aa:	3708      	adds	r7, #8
 80039ac:	46bd      	mov	sp, r7
 80039ae:	bd80      	pop	{r7, pc}

080039b0 <UART_SetConfig>:
  * @brief Configure the UART peripheral.
  * @param huart UART handle.
  * @retval HAL status
  */
HAL_StatusTypeDef UART_SetConfig(UART_HandleTypeDef *huart)
{
 80039b0:	b580      	push	{r7, lr}
 80039b2:	b088      	sub	sp, #32
 80039b4:	af00      	add	r7, sp, #0
 80039b6:	6078      	str	r0, [r7, #4]
  uint32_t tmpreg;
  uint16_t brrtemp;
  UART_ClockSourceTypeDef clocksource;
  uint32_t usartdiv                   = 0x00000000U;
 80039b8:	2300      	movs	r3, #0
 80039ba:	61bb      	str	r3, [r7, #24]
  HAL_StatusTypeDef ret               = HAL_OK;
 80039bc:	2300      	movs	r3, #0
 80039be:	75fb      	strb	r3, [r7, #23]
  *  the UART Word Length, Parity, Mode and oversampling:
  *  set the M bits according to huart->Init.WordLength value
  *  set PCE and PS bits according to huart->Init.Parity value
  *  set TE and RE bits according to huart->Init.Mode value
  *  set OVER8 bit according to huart->Init.OverSampling value */
  tmpreg = (uint32_t)huart->Init.WordLength | huart->Init.Parity | huart->Init.Mode | huart->Init.OverSampling ;
 80039c0:	687b      	ldr	r3, [r7, #4]
 80039c2:	689a      	ldr	r2, [r3, #8]
 80039c4:	687b      	ldr	r3, [r7, #4]
 80039c6:	691b      	ldr	r3, [r3, #16]
 80039c8:	431a      	orrs	r2, r3
 80039ca:	687b      	ldr	r3, [r7, #4]
 80039cc:	695b      	ldr	r3, [r3, #20]
 80039ce:	431a      	orrs	r2, r3
 80039d0:	687b      	ldr	r3, [r7, #4]
 80039d2:	69db      	ldr	r3, [r3, #28]
 80039d4:	4313      	orrs	r3, r2
 80039d6:	613b      	str	r3, [r7, #16]
  MODIFY_REG(huart->Instance->CR1, USART_CR1_FIELDS, tmpreg);
 80039d8:	687b      	ldr	r3, [r7, #4]
 80039da:	681b      	ldr	r3, [r3, #0]
 80039dc:	681a      	ldr	r2, [r3, #0]
 80039de:	4bb1      	ldr	r3, [pc, #708]	; (8003ca4 <UART_SetConfig+0x2f4>)
 80039e0:	4013      	ands	r3, r2
 80039e2:	687a      	ldr	r2, [r7, #4]
 80039e4:	6812      	ldr	r2, [r2, #0]
 80039e6:	6939      	ldr	r1, [r7, #16]
 80039e8:	430b      	orrs	r3, r1
 80039ea:	6013      	str	r3, [r2, #0]

  /*-------------------------- USART CR2 Configuration -----------------------*/
  /* Configure the UART Stop Bits: Set STOP[13:12] bits according
  * to huart->Init.StopBits value */
  MODIFY_REG(huart->Instance->CR2, USART_CR2_STOP, huart->Init.StopBits);
 80039ec:	687b      	ldr	r3, [r7, #4]
 80039ee:	681b      	ldr	r3, [r3, #0]
 80039f0:	685b      	ldr	r3, [r3, #4]
 80039f2:	f423 5140 	bic.w	r1, r3, #12288	; 0x3000
 80039f6:	687b      	ldr	r3, [r7, #4]
 80039f8:	68da      	ldr	r2, [r3, #12]
 80039fa:	687b      	ldr	r3, [r7, #4]
 80039fc:	681b      	ldr	r3, [r3, #0]
 80039fe:	430a      	orrs	r2, r1
 8003a00:	605a      	str	r2, [r3, #4]
  /* Configure
  * - UART HardWare Flow Control: set CTSE and RTSE bits according
  *   to huart->Init.HwFlowCtl value
  * - one-bit sampling method versus three samples' majority rule according
  *   to huart->Init.OneBitSampling (not applicable to LPUART) */
  tmpreg = (uint32_t)huart->Init.HwFlowCtl;
 8003a02:	687b      	ldr	r3, [r7, #4]
 8003a04:	699b      	ldr	r3, [r3, #24]
 8003a06:	613b      	str	r3, [r7, #16]

  tmpreg |= huart->Init.OneBitSampling;
 8003a08:	687b      	ldr	r3, [r7, #4]
 8003a0a:	6a1b      	ldr	r3, [r3, #32]
 8003a0c:	693a      	ldr	r2, [r7, #16]
 8003a0e:	4313      	orrs	r3, r2
 8003a10:	613b      	str	r3, [r7, #16]
  MODIFY_REG(huart->Instance->CR3, USART_CR3_FIELDS, tmpreg);
 8003a12:	687b      	ldr	r3, [r7, #4]
 8003a14:	681b      	ldr	r3, [r3, #0]
 8003a16:	689b      	ldr	r3, [r3, #8]
 8003a18:	f423 6130 	bic.w	r1, r3, #2816	; 0xb00
 8003a1c:	687b      	ldr	r3, [r7, #4]
 8003a1e:	681b      	ldr	r3, [r3, #0]
 8003a20:	693a      	ldr	r2, [r7, #16]
 8003a22:	430a      	orrs	r2, r1
 8003a24:	609a      	str	r2, [r3, #8]


  /*-------------------------- USART BRR Configuration -----------------------*/
  UART_GETCLOCKSOURCE(huart, clocksource);
 8003a26:	687b      	ldr	r3, [r7, #4]
 8003a28:	681b      	ldr	r3, [r3, #0]
 8003a2a:	4a9f      	ldr	r2, [pc, #636]	; (8003ca8 <UART_SetConfig+0x2f8>)
 8003a2c:	4293      	cmp	r3, r2
 8003a2e:	d121      	bne.n	8003a74 <UART_SetConfig+0xc4>
 8003a30:	4b9e      	ldr	r3, [pc, #632]	; (8003cac <UART_SetConfig+0x2fc>)
 8003a32:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8003a36:	f003 0303 	and.w	r3, r3, #3
 8003a3a:	2b03      	cmp	r3, #3
 8003a3c:	d816      	bhi.n	8003a6c <UART_SetConfig+0xbc>
 8003a3e:	a201      	add	r2, pc, #4	; (adr r2, 8003a44 <UART_SetConfig+0x94>)
 8003a40:	f852 f023 	ldr.w	pc, [r2, r3, lsl #2]
 8003a44:	08003a55 	.word	0x08003a55
 8003a48:	08003a61 	.word	0x08003a61
 8003a4c:	08003a5b 	.word	0x08003a5b
 8003a50:	08003a67 	.word	0x08003a67
 8003a54:	2301      	movs	r3, #1
 8003a56:	77fb      	strb	r3, [r7, #31]
 8003a58:	e151      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003a5a:	2302      	movs	r3, #2
 8003a5c:	77fb      	strb	r3, [r7, #31]
 8003a5e:	e14e      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003a60:	2304      	movs	r3, #4
 8003a62:	77fb      	strb	r3, [r7, #31]
 8003a64:	e14b      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003a66:	2308      	movs	r3, #8
 8003a68:	77fb      	strb	r3, [r7, #31]
 8003a6a:	e148      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003a6c:	2310      	movs	r3, #16
 8003a6e:	77fb      	strb	r3, [r7, #31]
 8003a70:	bf00      	nop
 8003a72:	e144      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003a74:	687b      	ldr	r3, [r7, #4]
 8003a76:	681b      	ldr	r3, [r3, #0]
 8003a78:	4a8d      	ldr	r2, [pc, #564]	; (8003cb0 <UART_SetConfig+0x300>)
 8003a7a:	4293      	cmp	r3, r2
 8003a7c:	d134      	bne.n	8003ae8 <UART_SetConfig+0x138>
 8003a7e:	4b8b      	ldr	r3, [pc, #556]	; (8003cac <UART_SetConfig+0x2fc>)
 8003a80:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8003a84:	f003 030c 	and.w	r3, r3, #12
 8003a88:	2b0c      	cmp	r3, #12
 8003a8a:	d829      	bhi.n	8003ae0 <UART_SetConfig+0x130>
 8003a8c:	a201      	add	r2, pc, #4	; (adr r2, 8003a94 <UART_SetConfig+0xe4>)
 8003a8e:	f852 f023 	ldr.w	pc, [r2, r3, lsl #2]
 8003a92:	bf00      	nop
 8003a94:	08003ac9 	.word	0x08003ac9
 8003a98:	08003ae1 	.word	0x08003ae1
 8003a9c:	08003ae1 	.word	0x08003ae1
 8003aa0:	08003ae1 	.word	0x08003ae1
 8003aa4:	08003ad5 	.word	0x08003ad5
 8003aa8:	08003ae1 	.word	0x08003ae1
 8003aac:	08003ae1 	.word	0x08003ae1
 8003ab0:	08003ae1 	.word	0x08003ae1
 8003ab4:	08003acf 	.word	0x08003acf
 8003ab8:	08003ae1 	.word	0x08003ae1
 8003abc:	08003ae1 	.word	0x08003ae1
 8003ac0:	08003ae1 	.word	0x08003ae1
 8003ac4:	08003adb 	.word	0x08003adb
 8003ac8:	2300      	movs	r3, #0
 8003aca:	77fb      	strb	r3, [r7, #31]
 8003acc:	e117      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003ace:	2302      	movs	r3, #2
 8003ad0:	77fb      	strb	r3, [r7, #31]
 8003ad2:	e114      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003ad4:	2304      	movs	r3, #4
 8003ad6:	77fb      	strb	r3, [r7, #31]
 8003ad8:	e111      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003ada:	2308      	movs	r3, #8
 8003adc:	77fb      	strb	r3, [r7, #31]
 8003ade:	e10e      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003ae0:	2310      	movs	r3, #16
 8003ae2:	77fb      	strb	r3, [r7, #31]
 8003ae4:	bf00      	nop
 8003ae6:	e10a      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003ae8:	687b      	ldr	r3, [r7, #4]
 8003aea:	681b      	ldr	r3, [r3, #0]
 8003aec:	4a71      	ldr	r2, [pc, #452]	; (8003cb4 <UART_SetConfig+0x304>)
 8003aee:	4293      	cmp	r3, r2
 8003af0:	d120      	bne.n	8003b34 <UART_SetConfig+0x184>
 8003af2:	4b6e      	ldr	r3, [pc, #440]	; (8003cac <UART_SetConfig+0x2fc>)
 8003af4:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8003af8:	f003 0330 	and.w	r3, r3, #48	; 0x30
 8003afc:	2b10      	cmp	r3, #16
 8003afe:	d00f      	beq.n	8003b20 <UART_SetConfig+0x170>
 8003b00:	2b10      	cmp	r3, #16
 8003b02:	d802      	bhi.n	8003b0a <UART_SetConfig+0x15a>
 8003b04:	2b00      	cmp	r3, #0
 8003b06:	d005      	beq.n	8003b14 <UART_SetConfig+0x164>
 8003b08:	e010      	b.n	8003b2c <UART_SetConfig+0x17c>
 8003b0a:	2b20      	cmp	r3, #32
 8003b0c:	d005      	beq.n	8003b1a <UART_SetConfig+0x16a>
 8003b0e:	2b30      	cmp	r3, #48	; 0x30
 8003b10:	d009      	beq.n	8003b26 <UART_SetConfig+0x176>
 8003b12:	e00b      	b.n	8003b2c <UART_SetConfig+0x17c>
 8003b14:	2300      	movs	r3, #0
 8003b16:	77fb      	strb	r3, [r7, #31]
 8003b18:	e0f1      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003b1a:	2302      	movs	r3, #2
 8003b1c:	77fb      	strb	r3, [r7, #31]
 8003b1e:	e0ee      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003b20:	2304      	movs	r3, #4
 8003b22:	77fb      	strb	r3, [r7, #31]
 8003b24:	e0eb      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003b26:	2308      	movs	r3, #8
 8003b28:	77fb      	strb	r3, [r7, #31]
 8003b2a:	e0e8      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003b2c:	2310      	movs	r3, #16
 8003b2e:	77fb      	strb	r3, [r7, #31]
 8003b30:	bf00      	nop
 8003b32:	e0e4      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003b34:	687b      	ldr	r3, [r7, #4]
 8003b36:	681b      	ldr	r3, [r3, #0]
 8003b38:	4a5f      	ldr	r2, [pc, #380]	; (8003cb8 <UART_SetConfig+0x308>)
 8003b3a:	4293      	cmp	r3, r2
 8003b3c:	d120      	bne.n	8003b80 <UART_SetConfig+0x1d0>
 8003b3e:	4b5b      	ldr	r3, [pc, #364]	; (8003cac <UART_SetConfig+0x2fc>)
 8003b40:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8003b44:	f003 03c0 	and.w	r3, r3, #192	; 0xc0
 8003b48:	2b40      	cmp	r3, #64	; 0x40
 8003b4a:	d00f      	beq.n	8003b6c <UART_SetConfig+0x1bc>
 8003b4c:	2b40      	cmp	r3, #64	; 0x40
 8003b4e:	d802      	bhi.n	8003b56 <UART_SetConfig+0x1a6>
 8003b50:	2b00      	cmp	r3, #0
 8003b52:	d005      	beq.n	8003b60 <UART_SetConfig+0x1b0>
 8003b54:	e010      	b.n	8003b78 <UART_SetConfig+0x1c8>
 8003b56:	2b80      	cmp	r3, #128	; 0x80
 8003b58:	d005      	beq.n	8003b66 <UART_SetConfig+0x1b6>
 8003b5a:	2bc0      	cmp	r3, #192	; 0xc0
 8003b5c:	d009      	beq.n	8003b72 <UART_SetConfig+0x1c2>
 8003b5e:	e00b      	b.n	8003b78 <UART_SetConfig+0x1c8>
 8003b60:	2300      	movs	r3, #0
 8003b62:	77fb      	strb	r3, [r7, #31]
 8003b64:	e0cb      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003b66:	2302      	movs	r3, #2
 8003b68:	77fb      	strb	r3, [r7, #31]
 8003b6a:	e0c8      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003b6c:	2304      	movs	r3, #4
 8003b6e:	77fb      	strb	r3, [r7, #31]
 8003b70:	e0c5      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003b72:	2308      	movs	r3, #8
 8003b74:	77fb      	strb	r3, [r7, #31]
 8003b76:	e0c2      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003b78:	2310      	movs	r3, #16
 8003b7a:	77fb      	strb	r3, [r7, #31]
 8003b7c:	bf00      	nop
 8003b7e:	e0be      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003b80:	687b      	ldr	r3, [r7, #4]
 8003b82:	681b      	ldr	r3, [r3, #0]
 8003b84:	4a4d      	ldr	r2, [pc, #308]	; (8003cbc <UART_SetConfig+0x30c>)
 8003b86:	4293      	cmp	r3, r2
 8003b88:	d124      	bne.n	8003bd4 <UART_SetConfig+0x224>
 8003b8a:	4b48      	ldr	r3, [pc, #288]	; (8003cac <UART_SetConfig+0x2fc>)
 8003b8c:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8003b90:	f403 7340 	and.w	r3, r3, #768	; 0x300
 8003b94:	f5b3 7f80 	cmp.w	r3, #256	; 0x100
 8003b98:	d012      	beq.n	8003bc0 <UART_SetConfig+0x210>
 8003b9a:	f5b3 7f80 	cmp.w	r3, #256	; 0x100
 8003b9e:	d802      	bhi.n	8003ba6 <UART_SetConfig+0x1f6>
 8003ba0:	2b00      	cmp	r3, #0
 8003ba2:	d007      	beq.n	8003bb4 <UART_SetConfig+0x204>
 8003ba4:	e012      	b.n	8003bcc <UART_SetConfig+0x21c>
 8003ba6:	f5b3 7f00 	cmp.w	r3, #512	; 0x200
 8003baa:	d006      	beq.n	8003bba <UART_SetConfig+0x20a>
 8003bac:	f5b3 7f40 	cmp.w	r3, #768	; 0x300
 8003bb0:	d009      	beq.n	8003bc6 <UART_SetConfig+0x216>
 8003bb2:	e00b      	b.n	8003bcc <UART_SetConfig+0x21c>
 8003bb4:	2300      	movs	r3, #0
 8003bb6:	77fb      	strb	r3, [r7, #31]
 8003bb8:	e0a1      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003bba:	2302      	movs	r3, #2
 8003bbc:	77fb      	strb	r3, [r7, #31]
 8003bbe:	e09e      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003bc0:	2304      	movs	r3, #4
 8003bc2:	77fb      	strb	r3, [r7, #31]
 8003bc4:	e09b      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003bc6:	2308      	movs	r3, #8
 8003bc8:	77fb      	strb	r3, [r7, #31]
 8003bca:	e098      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003bcc:	2310      	movs	r3, #16
 8003bce:	77fb      	strb	r3, [r7, #31]
 8003bd0:	bf00      	nop
 8003bd2:	e094      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003bd4:	687b      	ldr	r3, [r7, #4]
 8003bd6:	681b      	ldr	r3, [r3, #0]
 8003bd8:	4a39      	ldr	r2, [pc, #228]	; (8003cc0 <UART_SetConfig+0x310>)
 8003bda:	4293      	cmp	r3, r2
 8003bdc:	d124      	bne.n	8003c28 <UART_SetConfig+0x278>
 8003bde:	4b33      	ldr	r3, [pc, #204]	; (8003cac <UART_SetConfig+0x2fc>)
 8003be0:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8003be4:	f403 6340 	and.w	r3, r3, #3072	; 0xc00
 8003be8:	f5b3 6f80 	cmp.w	r3, #1024	; 0x400
 8003bec:	d012      	beq.n	8003c14 <UART_SetConfig+0x264>
 8003bee:	f5b3 6f80 	cmp.w	r3, #1024	; 0x400
 8003bf2:	d802      	bhi.n	8003bfa <UART_SetConfig+0x24a>
 8003bf4:	2b00      	cmp	r3, #0
 8003bf6:	d007      	beq.n	8003c08 <UART_SetConfig+0x258>
 8003bf8:	e012      	b.n	8003c20 <UART_SetConfig+0x270>
 8003bfa:	f5b3 6f00 	cmp.w	r3, #2048	; 0x800
 8003bfe:	d006      	beq.n	8003c0e <UART_SetConfig+0x25e>
 8003c00:	f5b3 6f40 	cmp.w	r3, #3072	; 0xc00
 8003c04:	d009      	beq.n	8003c1a <UART_SetConfig+0x26a>
 8003c06:	e00b      	b.n	8003c20 <UART_SetConfig+0x270>
 8003c08:	2301      	movs	r3, #1
 8003c0a:	77fb      	strb	r3, [r7, #31]
 8003c0c:	e077      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003c0e:	2302      	movs	r3, #2
 8003c10:	77fb      	strb	r3, [r7, #31]
 8003c12:	e074      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003c14:	2304      	movs	r3, #4
 8003c16:	77fb      	strb	r3, [r7, #31]
 8003c18:	e071      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003c1a:	2308      	movs	r3, #8
 8003c1c:	77fb      	strb	r3, [r7, #31]
 8003c1e:	e06e      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003c20:	2310      	movs	r3, #16
 8003c22:	77fb      	strb	r3, [r7, #31]
 8003c24:	bf00      	nop
 8003c26:	e06a      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003c28:	687b      	ldr	r3, [r7, #4]
 8003c2a:	681b      	ldr	r3, [r3, #0]
 8003c2c:	4a25      	ldr	r2, [pc, #148]	; (8003cc4 <UART_SetConfig+0x314>)
 8003c2e:	4293      	cmp	r3, r2
 8003c30:	d124      	bne.n	8003c7c <UART_SetConfig+0x2cc>
 8003c32:	4b1e      	ldr	r3, [pc, #120]	; (8003cac <UART_SetConfig+0x2fc>)
 8003c34:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8003c38:	f403 5340 	and.w	r3, r3, #12288	; 0x3000
 8003c3c:	f5b3 5f80 	cmp.w	r3, #4096	; 0x1000
 8003c40:	d012      	beq.n	8003c68 <UART_SetConfig+0x2b8>
 8003c42:	f5b3 5f80 	cmp.w	r3, #4096	; 0x1000
 8003c46:	d802      	bhi.n	8003c4e <UART_SetConfig+0x29e>
 8003c48:	2b00      	cmp	r3, #0
 8003c4a:	d007      	beq.n	8003c5c <UART_SetConfig+0x2ac>
 8003c4c:	e012      	b.n	8003c74 <UART_SetConfig+0x2c4>
 8003c4e:	f5b3 5f00 	cmp.w	r3, #8192	; 0x2000
 8003c52:	d006      	beq.n	8003c62 <UART_SetConfig+0x2b2>
 8003c54:	f5b3 5f40 	cmp.w	r3, #12288	; 0x3000
 8003c58:	d009      	beq.n	8003c6e <UART_SetConfig+0x2be>
 8003c5a:	e00b      	b.n	8003c74 <UART_SetConfig+0x2c4>
 8003c5c:	2300      	movs	r3, #0
 8003c5e:	77fb      	strb	r3, [r7, #31]
 8003c60:	e04d      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003c62:	2302      	movs	r3, #2
 8003c64:	77fb      	strb	r3, [r7, #31]
 8003c66:	e04a      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003c68:	2304      	movs	r3, #4
 8003c6a:	77fb      	strb	r3, [r7, #31]
 8003c6c:	e047      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003c6e:	2308      	movs	r3, #8
 8003c70:	77fb      	strb	r3, [r7, #31]
 8003c72:	e044      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003c74:	2310      	movs	r3, #16
 8003c76:	77fb      	strb	r3, [r7, #31]
 8003c78:	bf00      	nop
 8003c7a:	e040      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003c7c:	687b      	ldr	r3, [r7, #4]
 8003c7e:	681b      	ldr	r3, [r3, #0]
 8003c80:	4a11      	ldr	r2, [pc, #68]	; (8003cc8 <UART_SetConfig+0x318>)
 8003c82:	4293      	cmp	r3, r2
 8003c84:	d139      	bne.n	8003cfa <UART_SetConfig+0x34a>
 8003c86:	4b09      	ldr	r3, [pc, #36]	; (8003cac <UART_SetConfig+0x2fc>)
 8003c88:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8003c8c:	f403 4340 	and.w	r3, r3, #49152	; 0xc000
 8003c90:	f5b3 4f80 	cmp.w	r3, #16384	; 0x4000
 8003c94:	d027      	beq.n	8003ce6 <UART_SetConfig+0x336>
 8003c96:	f5b3 4f80 	cmp.w	r3, #16384	; 0x4000
 8003c9a:	d817      	bhi.n	8003ccc <UART_SetConfig+0x31c>
 8003c9c:	2b00      	cmp	r3, #0
 8003c9e:	d01c      	beq.n	8003cda <UART_SetConfig+0x32a>
 8003ca0:	e027      	b.n	8003cf2 <UART_SetConfig+0x342>
 8003ca2:	bf00      	nop
 8003ca4:	efff69f3 	.word	0xefff69f3
 8003ca8:	40011000 	.word	0x40011000
 8003cac:	40023800 	.word	0x40023800
 8003cb0:	40004400 	.word	0x40004400
 8003cb4:	40004800 	.word	0x40004800
 8003cb8:	40004c00 	.word	0x40004c00
 8003cbc:	40005000 	.word	0x40005000
 8003cc0:	40011400 	.word	0x40011400
 8003cc4:	40007800 	.word	0x40007800
 8003cc8:	40007c00 	.word	0x40007c00
 8003ccc:	f5b3 4f00 	cmp.w	r3, #32768	; 0x8000
 8003cd0:	d006      	beq.n	8003ce0 <UART_SetConfig+0x330>
 8003cd2:	f5b3 4f40 	cmp.w	r3, #49152	; 0xc000
 8003cd6:	d009      	beq.n	8003cec <UART_SetConfig+0x33c>
 8003cd8:	e00b      	b.n	8003cf2 <UART_SetConfig+0x342>
 8003cda:	2300      	movs	r3, #0
 8003cdc:	77fb      	strb	r3, [r7, #31]
 8003cde:	e00e      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003ce0:	2302      	movs	r3, #2
 8003ce2:	77fb      	strb	r3, [r7, #31]
 8003ce4:	e00b      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003ce6:	2304      	movs	r3, #4
 8003ce8:	77fb      	strb	r3, [r7, #31]
 8003cea:	e008      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003cec:	2308      	movs	r3, #8
 8003cee:	77fb      	strb	r3, [r7, #31]
 8003cf0:	e005      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003cf2:	2310      	movs	r3, #16
 8003cf4:	77fb      	strb	r3, [r7, #31]
 8003cf6:	bf00      	nop
 8003cf8:	e001      	b.n	8003cfe <UART_SetConfig+0x34e>
 8003cfa:	2310      	movs	r3, #16
 8003cfc:	77fb      	strb	r3, [r7, #31]

  if (huart->Init.OverSampling == UART_OVERSAMPLING_8)
 8003cfe:	687b      	ldr	r3, [r7, #4]
 8003d00:	69db      	ldr	r3, [r3, #28]
 8003d02:	f5b3 4f00 	cmp.w	r3, #32768	; 0x8000
 8003d06:	d17f      	bne.n	8003e08 <UART_SetConfig+0x458>
  {
    switch (clocksource)
 8003d08:	7ffb      	ldrb	r3, [r7, #31]
 8003d0a:	2b08      	cmp	r3, #8
 8003d0c:	d85c      	bhi.n	8003dc8 <UART_SetConfig+0x418>
 8003d0e:	a201      	add	r2, pc, #4	; (adr r2, 8003d14 <UART_SetConfig+0x364>)
 8003d10:	f852 f023 	ldr.w	pc, [r2, r3, lsl #2]
 8003d14:	08003d39 	.word	0x08003d39
 8003d18:	08003d59 	.word	0x08003d59
 8003d1c:	08003d79 	.word	0x08003d79
 8003d20:	08003dc9 	.word	0x08003dc9
 8003d24:	08003d91 	.word	0x08003d91
 8003d28:	08003dc9 	.word	0x08003dc9
 8003d2c:	08003dc9 	.word	0x08003dc9
 8003d30:	08003dc9 	.word	0x08003dc9
 8003d34:	08003db1 	.word	0x08003db1
    {
      case UART_CLOCKSOURCE_PCLK1:
        pclk = HAL_RCC_GetPCLK1Freq();
 8003d38:	f7fe fbb2 	bl	80024a0 <HAL_RCC_GetPCLK1Freq>
 8003d3c:	60f8      	str	r0, [r7, #12]
        usartdiv = (uint16_t)(UART_DIV_SAMPLING8(pclk, huart->Init.BaudRate));
 8003d3e:	68fb      	ldr	r3, [r7, #12]
 8003d40:	005a      	lsls	r2, r3, #1
 8003d42:	687b      	ldr	r3, [r7, #4]
 8003d44:	685b      	ldr	r3, [r3, #4]
 8003d46:	085b      	lsrs	r3, r3, #1
 8003d48:	441a      	add	r2, r3
 8003d4a:	687b      	ldr	r3, [r7, #4]
 8003d4c:	685b      	ldr	r3, [r3, #4]
 8003d4e:	fbb2 f3f3 	udiv	r3, r2, r3
 8003d52:	b29b      	uxth	r3, r3
 8003d54:	61bb      	str	r3, [r7, #24]
        break;
 8003d56:	e03a      	b.n	8003dce <UART_SetConfig+0x41e>
      case UART_CLOCKSOURCE_PCLK2:
        pclk = HAL_RCC_GetPCLK2Freq();
 8003d58:	f7fe fbb6 	bl	80024c8 <HAL_RCC_GetPCLK2Freq>
 8003d5c:	60f8      	str	r0, [r7, #12]
        usartdiv = (uint16_t)(UART_DIV_SAMPLING8(pclk, huart->Init.BaudRate));
 8003d5e:	68fb      	ldr	r3, [r7, #12]
 8003d60:	005a      	lsls	r2, r3, #1
 8003d62:	687b      	ldr	r3, [r7, #4]
 8003d64:	685b      	ldr	r3, [r3, #4]
 8003d66:	085b      	lsrs	r3, r3, #1
 8003d68:	441a      	add	r2, r3
 8003d6a:	687b      	ldr	r3, [r7, #4]
 8003d6c:	685b      	ldr	r3, [r3, #4]
 8003d6e:	fbb2 f3f3 	udiv	r3, r2, r3
 8003d72:	b29b      	uxth	r3, r3
 8003d74:	61bb      	str	r3, [r7, #24]
        break;
 8003d76:	e02a      	b.n	8003dce <UART_SetConfig+0x41e>
      case UART_CLOCKSOURCE_HSI:
        usartdiv = (uint16_t)(UART_DIV_SAMPLING8(HSI_VALUE, huart->Init.BaudRate));
 8003d78:	687b      	ldr	r3, [r7, #4]
 8003d7a:	685b      	ldr	r3, [r3, #4]
 8003d7c:	085a      	lsrs	r2, r3, #1
 8003d7e:	4b5f      	ldr	r3, [pc, #380]	; (8003efc <UART_SetConfig+0x54c>)
 8003d80:	4413      	add	r3, r2
 8003d82:	687a      	ldr	r2, [r7, #4]
 8003d84:	6852      	ldr	r2, [r2, #4]
 8003d86:	fbb3 f3f2 	udiv	r3, r3, r2
 8003d8a:	b29b      	uxth	r3, r3
 8003d8c:	61bb      	str	r3, [r7, #24]
        break;
 8003d8e:	e01e      	b.n	8003dce <UART_SetConfig+0x41e>
      case UART_CLOCKSOURCE_SYSCLK:
        pclk = HAL_RCC_GetSysClockFreq();
 8003d90:	f7fe faa2 	bl	80022d8 <HAL_RCC_GetSysClockFreq>
 8003d94:	60f8      	str	r0, [r7, #12]
        usartdiv = (uint16_t)(UART_DIV_SAMPLING8(pclk, huart->Init.BaudRate));
 8003d96:	68fb      	ldr	r3, [r7, #12]
 8003d98:	005a      	lsls	r2, r3, #1
 8003d9a:	687b      	ldr	r3, [r7, #4]
 8003d9c:	685b      	ldr	r3, [r3, #4]
 8003d9e:	085b      	lsrs	r3, r3, #1
 8003da0:	441a      	add	r2, r3
 8003da2:	687b      	ldr	r3, [r7, #4]
 8003da4:	685b      	ldr	r3, [r3, #4]
 8003da6:	fbb2 f3f3 	udiv	r3, r2, r3
 8003daa:	b29b      	uxth	r3, r3
 8003dac:	61bb      	str	r3, [r7, #24]
        break;
 8003dae:	e00e      	b.n	8003dce <UART_SetConfig+0x41e>
      case UART_CLOCKSOURCE_LSE:
        usartdiv = (uint16_t)(UART_DIV_SAMPLING8(LSE_VALUE, huart->Init.BaudRate));
 8003db0:	687b      	ldr	r3, [r7, #4]
 8003db2:	685b      	ldr	r3, [r3, #4]
 8003db4:	085b      	lsrs	r3, r3, #1
 8003db6:	f503 3280 	add.w	r2, r3, #65536	; 0x10000
 8003dba:	687b      	ldr	r3, [r7, #4]
 8003dbc:	685b      	ldr	r3, [r3, #4]
 8003dbe:	fbb2 f3f3 	udiv	r3, r2, r3
 8003dc2:	b29b      	uxth	r3, r3
 8003dc4:	61bb      	str	r3, [r7, #24]
        break;
 8003dc6:	e002      	b.n	8003dce <UART_SetConfig+0x41e>
      default:
        ret = HAL_ERROR;
 8003dc8:	2301      	movs	r3, #1
 8003dca:	75fb      	strb	r3, [r7, #23]
        break;
 8003dcc:	bf00      	nop
    }

    /* USARTDIV must be greater than or equal to 0d16 */
    if ((usartdiv >= UART_BRR_MIN) && (usartdiv <= UART_BRR_MAX))
 8003dce:	69bb      	ldr	r3, [r7, #24]
 8003dd0:	2b0f      	cmp	r3, #15
 8003dd2:	d916      	bls.n	8003e02 <UART_SetConfig+0x452>
 8003dd4:	69bb      	ldr	r3, [r7, #24]
 8003dd6:	f5b3 3f80 	cmp.w	r3, #65536	; 0x10000
 8003dda:	d212      	bcs.n	8003e02 <UART_SetConfig+0x452>
    {
      brrtemp = (uint16_t)(usartdiv & 0xFFF0U);
 8003ddc:	69bb      	ldr	r3, [r7, #24]
 8003dde:	b29b      	uxth	r3, r3
 8003de0:	f023 030f 	bic.w	r3, r3, #15
 8003de4:	817b      	strh	r3, [r7, #10]
      brrtemp |= (uint16_t)((usartdiv & (uint16_t)0x000FU) >> 1U);
 8003de6:	69bb      	ldr	r3, [r7, #24]
 8003de8:	085b      	lsrs	r3, r3, #1
 8003dea:	b29b      	uxth	r3, r3
 8003dec:	f003 0307 	and.w	r3, r3, #7
 8003df0:	b29a      	uxth	r2, r3
 8003df2:	897b      	ldrh	r3, [r7, #10]
 8003df4:	4313      	orrs	r3, r2
 8003df6:	817b      	strh	r3, [r7, #10]
      huart->Instance->BRR = brrtemp;
 8003df8:	687b      	ldr	r3, [r7, #4]
 8003dfa:	681b      	ldr	r3, [r3, #0]
 8003dfc:	897a      	ldrh	r2, [r7, #10]
 8003dfe:	60da      	str	r2, [r3, #12]
 8003e00:	e070      	b.n	8003ee4 <UART_SetConfig+0x534>
    }
    else
    {
      ret = HAL_ERROR;
 8003e02:	2301      	movs	r3, #1
 8003e04:	75fb      	strb	r3, [r7, #23]
 8003e06:	e06d      	b.n	8003ee4 <UART_SetConfig+0x534>
    }
  }
  else
  {
    switch (clocksource)
 8003e08:	7ffb      	ldrb	r3, [r7, #31]
 8003e0a:	2b08      	cmp	r3, #8
 8003e0c:	d859      	bhi.n	8003ec2 <UART_SetConfig+0x512>
 8003e0e:	a201      	add	r2, pc, #4	; (adr r2, 8003e14 <UART_SetConfig+0x464>)
 8003e10:	f852 f023 	ldr.w	pc, [r2, r3, lsl #2]
 8003e14:	08003e39 	.word	0x08003e39
 8003e18:	08003e57 	.word	0x08003e57
 8003e1c:	08003e75 	.word	0x08003e75
 8003e20:	08003ec3 	.word	0x08003ec3
 8003e24:	08003e8d 	.word	0x08003e8d
 8003e28:	08003ec3 	.word	0x08003ec3
 8003e2c:	08003ec3 	.word	0x08003ec3
 8003e30:	08003ec3 	.word	0x08003ec3
 8003e34:	08003eab 	.word	0x08003eab
    {
      case UART_CLOCKSOURCE_PCLK1:
        pclk = HAL_RCC_GetPCLK1Freq();
 8003e38:	f7fe fb32 	bl	80024a0 <HAL_RCC_GetPCLK1Freq>
 8003e3c:	60f8      	str	r0, [r7, #12]
        usartdiv = (uint16_t)(UART_DIV_SAMPLING16(pclk, huart->Init.BaudRate));
 8003e3e:	687b      	ldr	r3, [r7, #4]
 8003e40:	685b      	ldr	r3, [r3, #4]
 8003e42:	085a      	lsrs	r2, r3, #1
 8003e44:	68fb      	ldr	r3, [r7, #12]
 8003e46:	441a      	add	r2, r3
 8003e48:	687b      	ldr	r3, [r7, #4]
 8003e4a:	685b      	ldr	r3, [r3, #4]
 8003e4c:	fbb2 f3f3 	udiv	r3, r2, r3
 8003e50:	b29b      	uxth	r3, r3
 8003e52:	61bb      	str	r3, [r7, #24]
        break;
 8003e54:	e038      	b.n	8003ec8 <UART_SetConfig+0x518>
      case UART_CLOCKSOURCE_PCLK2:
        pclk = HAL_RCC_GetPCLK2Freq();
 8003e56:	f7fe fb37 	bl	80024c8 <HAL_RCC_GetPCLK2Freq>
 8003e5a:	60f8      	str	r0, [r7, #12]
        usartdiv = (uint16_t)(UART_DIV_SAMPLING16(pclk, huart->Init.BaudRate));
 8003e5c:	687b      	ldr	r3, [r7, #4]
 8003e5e:	685b      	ldr	r3, [r3, #4]
 8003e60:	085a      	lsrs	r2, r3, #1
 8003e62:	68fb      	ldr	r3, [r7, #12]
 8003e64:	441a      	add	r2, r3
 8003e66:	687b      	ldr	r3, [r7, #4]
 8003e68:	685b      	ldr	r3, [r3, #4]
 8003e6a:	fbb2 f3f3 	udiv	r3, r2, r3
 8003e6e:	b29b      	uxth	r3, r3
 8003e70:	61bb      	str	r3, [r7, #24]
        break;
 8003e72:	e029      	b.n	8003ec8 <UART_SetConfig+0x518>
      case UART_CLOCKSOURCE_HSI:
        usartdiv = (uint16_t)(UART_DIV_SAMPLING16(HSI_VALUE, huart->Init.BaudRate));
 8003e74:	687b      	ldr	r3, [r7, #4]
 8003e76:	685b      	ldr	r3, [r3, #4]
 8003e78:	085a      	lsrs	r2, r3, #1
 8003e7a:	4b21      	ldr	r3, [pc, #132]	; (8003f00 <UART_SetConfig+0x550>)
 8003e7c:	4413      	add	r3, r2
 8003e7e:	687a      	ldr	r2, [r7, #4]
 8003e80:	6852      	ldr	r2, [r2, #4]
 8003e82:	fbb3 f3f2 	udiv	r3, r3, r2
 8003e86:	b29b      	uxth	r3, r3
 8003e88:	61bb      	str	r3, [r7, #24]
        break;
 8003e8a:	e01d      	b.n	8003ec8 <UART_SetConfig+0x518>
      case UART_CLOCKSOURCE_SYSCLK:
        pclk = HAL_RCC_GetSysClockFreq();
 8003e8c:	f7fe fa24 	bl	80022d8 <HAL_RCC_GetSysClockFreq>
 8003e90:	60f8      	str	r0, [r7, #12]
        usartdiv = (uint16_t)(UART_DIV_SAMPLING16(pclk, huart->Init.BaudRate));
 8003e92:	687b      	ldr	r3, [r7, #4]
 8003e94:	685b      	ldr	r3, [r3, #4]
 8003e96:	085a      	lsrs	r2, r3, #1
 8003e98:	68fb      	ldr	r3, [r7, #12]
 8003e9a:	441a      	add	r2, r3
 8003e9c:	687b      	ldr	r3, [r7, #4]
 8003e9e:	685b      	ldr	r3, [r3, #4]
 8003ea0:	fbb2 f3f3 	udiv	r3, r2, r3
 8003ea4:	b29b      	uxth	r3, r3
 8003ea6:	61bb      	str	r3, [r7, #24]
        break;
 8003ea8:	e00e      	b.n	8003ec8 <UART_SetConfig+0x518>
      case UART_CLOCKSOURCE_LSE:
        usartdiv = (uint16_t)(UART_DIV_SAMPLING16(LSE_VALUE, huart->Init.BaudRate));
 8003eaa:	687b      	ldr	r3, [r7, #4]
 8003eac:	685b      	ldr	r3, [r3, #4]
 8003eae:	085b      	lsrs	r3, r3, #1
 8003eb0:	f503 4200 	add.w	r2, r3, #32768	; 0x8000
 8003eb4:	687b      	ldr	r3, [r7, #4]
 8003eb6:	685b      	ldr	r3, [r3, #4]
 8003eb8:	fbb2 f3f3 	udiv	r3, r2, r3
 8003ebc:	b29b      	uxth	r3, r3
 8003ebe:	61bb      	str	r3, [r7, #24]
        break;
 8003ec0:	e002      	b.n	8003ec8 <UART_SetConfig+0x518>
      default:
        ret = HAL_ERROR;
 8003ec2:	2301      	movs	r3, #1
 8003ec4:	75fb      	strb	r3, [r7, #23]
        break;
 8003ec6:	bf00      	nop
    }

    /* USARTDIV must be greater than or equal to 0d16 */
    if ((usartdiv >= UART_BRR_MIN) && (usartdiv <= UART_BRR_MAX))
 8003ec8:	69bb      	ldr	r3, [r7, #24]
 8003eca:	2b0f      	cmp	r3, #15
 8003ecc:	d908      	bls.n	8003ee0 <UART_SetConfig+0x530>
 8003ece:	69bb      	ldr	r3, [r7, #24]
 8003ed0:	f5b3 3f80 	cmp.w	r3, #65536	; 0x10000
 8003ed4:	d204      	bcs.n	8003ee0 <UART_SetConfig+0x530>
    {
      huart->Instance->BRR = usartdiv;
 8003ed6:	687b      	ldr	r3, [r7, #4]
 8003ed8:	681b      	ldr	r3, [r3, #0]
 8003eda:	69ba      	ldr	r2, [r7, #24]
 8003edc:	60da      	str	r2, [r3, #12]
 8003ede:	e001      	b.n	8003ee4 <UART_SetConfig+0x534>
    }
    else
    {
      ret = HAL_ERROR;
 8003ee0:	2301      	movs	r3, #1
 8003ee2:	75fb      	strb	r3, [r7, #23]
    }
  }


  /* Clear ISR function pointers */
  huart->RxISR = NULL;
 8003ee4:	687b      	ldr	r3, [r7, #4]
 8003ee6:	2200      	movs	r2, #0
 8003ee8:	661a      	str	r2, [r3, #96]	; 0x60
  huart->TxISR = NULL;
 8003eea:	687b      	ldr	r3, [r7, #4]
 8003eec:	2200      	movs	r2, #0
 8003eee:	665a      	str	r2, [r3, #100]	; 0x64

  return ret;
 8003ef0:	7dfb      	ldrb	r3, [r7, #23]
}
 8003ef2:	4618      	mov	r0, r3
 8003ef4:	3720      	adds	r7, #32
 8003ef6:	46bd      	mov	sp, r7
 8003ef8:	bd80      	pop	{r7, pc}
 8003efa:	bf00      	nop
 8003efc:	01e84800 	.word	0x01e84800
 8003f00:	00f42400 	.word	0x00f42400

08003f04 <UART_AdvFeatureConfig>:
  * @brief Configure the UART peripheral advanced features.
  * @param huart UART handle.
  * @retval None
  */
void UART_AdvFeatureConfig(UART_HandleTypeDef *huart)
{
 8003f04:	b480      	push	{r7}
 8003f06:	b083      	sub	sp, #12
 8003f08:	af00      	add	r7, sp, #0
 8003f0a:	6078      	str	r0, [r7, #4]
  /* Check whether the set of advanced features to configure is properly set */
  assert_param(IS_UART_ADVFEATURE_INIT(huart->AdvancedInit.AdvFeatureInit));

  /* if required, configure TX pin active level inversion */
  if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_TXINVERT_INIT))
 8003f0c:	687b      	ldr	r3, [r7, #4]
 8003f0e:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8003f10:	f003 0301 	and.w	r3, r3, #1
 8003f14:	2b00      	cmp	r3, #0
 8003f16:	d00a      	beq.n	8003f2e <UART_AdvFeatureConfig+0x2a>
  {
    assert_param(IS_UART_ADVFEATURE_TXINV(huart->AdvancedInit.TxPinLevelInvert));
    MODIFY_REG(huart->Instance->CR2, USART_CR2_TXINV, huart->AdvancedInit.TxPinLevelInvert);
 8003f18:	687b      	ldr	r3, [r7, #4]
 8003f1a:	681b      	ldr	r3, [r3, #0]
 8003f1c:	685b      	ldr	r3, [r3, #4]
 8003f1e:	f423 3100 	bic.w	r1, r3, #131072	; 0x20000
 8003f22:	687b      	ldr	r3, [r7, #4]
 8003f24:	6a9a      	ldr	r2, [r3, #40]	; 0x28
 8003f26:	687b      	ldr	r3, [r7, #4]
 8003f28:	681b      	ldr	r3, [r3, #0]
 8003f2a:	430a      	orrs	r2, r1
 8003f2c:	605a      	str	r2, [r3, #4]
  }

  /* if required, configure RX pin active level inversion */
  if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_RXINVERT_INIT))
 8003f2e:	687b      	ldr	r3, [r7, #4]
 8003f30:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8003f32:	f003 0302 	and.w	r3, r3, #2
 8003f36:	2b00      	cmp	r3, #0
 8003f38:	d00a      	beq.n	8003f50 <UART_AdvFeatureConfig+0x4c>
  {
    assert_param(IS_UART_ADVFEATURE_RXINV(huart->AdvancedInit.RxPinLevelInvert));
    MODIFY_REG(huart->Instance->CR2, USART_CR2_RXINV, huart->AdvancedInit.RxPinLevelInvert);
 8003f3a:	687b      	ldr	r3, [r7, #4]
 8003f3c:	681b      	ldr	r3, [r3, #0]
 8003f3e:	685b      	ldr	r3, [r3, #4]
 8003f40:	f423 3180 	bic.w	r1, r3, #65536	; 0x10000
 8003f44:	687b      	ldr	r3, [r7, #4]
 8003f46:	6ada      	ldr	r2, [r3, #44]	; 0x2c
 8003f48:	687b      	ldr	r3, [r7, #4]
 8003f4a:	681b      	ldr	r3, [r3, #0]
 8003f4c:	430a      	orrs	r2, r1
 8003f4e:	605a      	str	r2, [r3, #4]
  }

  /* if required, configure data inversion */
  if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_DATAINVERT_INIT))
 8003f50:	687b      	ldr	r3, [r7, #4]
 8003f52:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8003f54:	f003 0304 	and.w	r3, r3, #4
 8003f58:	2b00      	cmp	r3, #0
 8003f5a:	d00a      	beq.n	8003f72 <UART_AdvFeatureConfig+0x6e>
  {
    assert_param(IS_UART_ADVFEATURE_DATAINV(huart->AdvancedInit.DataInvert));
    MODIFY_REG(huart->Instance->CR2, USART_CR2_DATAINV, huart->AdvancedInit.DataInvert);
 8003f5c:	687b      	ldr	r3, [r7, #4]
 8003f5e:	681b      	ldr	r3, [r3, #0]
 8003f60:	685b      	ldr	r3, [r3, #4]
 8003f62:	f423 2180 	bic.w	r1, r3, #262144	; 0x40000
 8003f66:	687b      	ldr	r3, [r7, #4]
 8003f68:	6b1a      	ldr	r2, [r3, #48]	; 0x30
 8003f6a:	687b      	ldr	r3, [r7, #4]
 8003f6c:	681b      	ldr	r3, [r3, #0]
 8003f6e:	430a      	orrs	r2, r1
 8003f70:	605a      	str	r2, [r3, #4]
  }

  /* if required, configure RX/TX pins swap */
  if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_SWAP_INIT))
 8003f72:	687b      	ldr	r3, [r7, #4]
 8003f74:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8003f76:	f003 0308 	and.w	r3, r3, #8
 8003f7a:	2b00      	cmp	r3, #0
 8003f7c:	d00a      	beq.n	8003f94 <UART_AdvFeatureConfig+0x90>
  {
    assert_param(IS_UART_ADVFEATURE_SWAP(huart->AdvancedInit.Swap));
    MODIFY_REG(huart->Instance->CR2, USART_CR2_SWAP, huart->AdvancedInit.Swap);
 8003f7e:	687b      	ldr	r3, [r7, #4]
 8003f80:	681b      	ldr	r3, [r3, #0]
 8003f82:	685b      	ldr	r3, [r3, #4]
 8003f84:	f423 4100 	bic.w	r1, r3, #32768	; 0x8000
 8003f88:	687b      	ldr	r3, [r7, #4]
 8003f8a:	6b5a      	ldr	r2, [r3, #52]	; 0x34
 8003f8c:	687b      	ldr	r3, [r7, #4]
 8003f8e:	681b      	ldr	r3, [r3, #0]
 8003f90:	430a      	orrs	r2, r1
 8003f92:	605a      	str	r2, [r3, #4]
  }

  /* if required, configure RX overrun detection disabling */
  if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_RXOVERRUNDISABLE_INIT))
 8003f94:	687b      	ldr	r3, [r7, #4]
 8003f96:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8003f98:	f003 0310 	and.w	r3, r3, #16
 8003f9c:	2b00      	cmp	r3, #0
 8003f9e:	d00a      	beq.n	8003fb6 <UART_AdvFeatureConfig+0xb2>
  {
    assert_param(IS_UART_OVERRUN(huart->AdvancedInit.OverrunDisable));
    MODIFY_REG(huart->Instance->CR3, USART_CR3_OVRDIS, huart->AdvancedInit.OverrunDisable);
 8003fa0:	687b      	ldr	r3, [r7, #4]
 8003fa2:	681b      	ldr	r3, [r3, #0]
 8003fa4:	689b      	ldr	r3, [r3, #8]
 8003fa6:	f423 5180 	bic.w	r1, r3, #4096	; 0x1000
 8003faa:	687b      	ldr	r3, [r7, #4]
 8003fac:	6b9a      	ldr	r2, [r3, #56]	; 0x38
 8003fae:	687b      	ldr	r3, [r7, #4]
 8003fb0:	681b      	ldr	r3, [r3, #0]
 8003fb2:	430a      	orrs	r2, r1
 8003fb4:	609a      	str	r2, [r3, #8]
  }

  /* if required, configure DMA disabling on reception error */
  if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_DMADISABLEONERROR_INIT))
 8003fb6:	687b      	ldr	r3, [r7, #4]
 8003fb8:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8003fba:	f003 0320 	and.w	r3, r3, #32
 8003fbe:	2b00      	cmp	r3, #0
 8003fc0:	d00a      	beq.n	8003fd8 <UART_AdvFeatureConfig+0xd4>
  {
    assert_param(IS_UART_ADVFEATURE_DMAONRXERROR(huart->AdvancedInit.DMADisableonRxError));
    MODIFY_REG(huart->Instance->CR3, USART_CR3_DDRE, huart->AdvancedInit.DMADisableonRxError);
 8003fc2:	687b      	ldr	r3, [r7, #4]
 8003fc4:	681b      	ldr	r3, [r3, #0]
 8003fc6:	689b      	ldr	r3, [r3, #8]
 8003fc8:	f423 5100 	bic.w	r1, r3, #8192	; 0x2000
 8003fcc:	687b      	ldr	r3, [r7, #4]
 8003fce:	6bda      	ldr	r2, [r3, #60]	; 0x3c
 8003fd0:	687b      	ldr	r3, [r7, #4]
 8003fd2:	681b      	ldr	r3, [r3, #0]
 8003fd4:	430a      	orrs	r2, r1
 8003fd6:	609a      	str	r2, [r3, #8]
  }

  /* if required, configure auto Baud rate detection scheme */
  if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_AUTOBAUDRATE_INIT))
 8003fd8:	687b      	ldr	r3, [r7, #4]
 8003fda:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8003fdc:	f003 0340 	and.w	r3, r3, #64	; 0x40
 8003fe0:	2b00      	cmp	r3, #0
 8003fe2:	d01a      	beq.n	800401a <UART_AdvFeatureConfig+0x116>
  {
    assert_param(IS_USART_AUTOBAUDRATE_DETECTION_INSTANCE(huart->Instance));
    assert_param(IS_UART_ADVFEATURE_AUTOBAUDRATE(huart->AdvancedInit.AutoBaudRateEnable));
    MODIFY_REG(huart->Instance->CR2, USART_CR2_ABREN, huart->AdvancedInit.AutoBaudRateEnable);
 8003fe4:	687b      	ldr	r3, [r7, #4]
 8003fe6:	681b      	ldr	r3, [r3, #0]
 8003fe8:	685b      	ldr	r3, [r3, #4]
 8003fea:	f423 1180 	bic.w	r1, r3, #1048576	; 0x100000
 8003fee:	687b      	ldr	r3, [r7, #4]
 8003ff0:	6c1a      	ldr	r2, [r3, #64]	; 0x40
 8003ff2:	687b      	ldr	r3, [r7, #4]
 8003ff4:	681b      	ldr	r3, [r3, #0]
 8003ff6:	430a      	orrs	r2, r1
 8003ff8:	605a      	str	r2, [r3, #4]
    /* set auto Baudrate detection parameters if detection is enabled */
    if (huart->AdvancedInit.AutoBaudRateEnable == UART_ADVFEATURE_AUTOBAUDRATE_ENABLE)
 8003ffa:	687b      	ldr	r3, [r7, #4]
 8003ffc:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 8003ffe:	f5b3 1f80 	cmp.w	r3, #1048576	; 0x100000
 8004002:	d10a      	bne.n	800401a <UART_AdvFeatureConfig+0x116>
    {
      assert_param(IS_UART_ADVFEATURE_AUTOBAUDRATEMODE(huart->AdvancedInit.AutoBaudRateMode));
      MODIFY_REG(huart->Instance->CR2, USART_CR2_ABRMODE, huart->AdvancedInit.AutoBaudRateMode);
 8004004:	687b      	ldr	r3, [r7, #4]
 8004006:	681b      	ldr	r3, [r3, #0]
 8004008:	685b      	ldr	r3, [r3, #4]
 800400a:	f423 01c0 	bic.w	r1, r3, #6291456	; 0x600000
 800400e:	687b      	ldr	r3, [r7, #4]
 8004010:	6c5a      	ldr	r2, [r3, #68]	; 0x44
 8004012:	687b      	ldr	r3, [r7, #4]
 8004014:	681b      	ldr	r3, [r3, #0]
 8004016:	430a      	orrs	r2, r1
 8004018:	605a      	str	r2, [r3, #4]
    }
  }

  /* if required, configure MSB first on communication line */
  if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_MSBFIRST_INIT))
 800401a:	687b      	ldr	r3, [r7, #4]
 800401c:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 800401e:	f003 0380 	and.w	r3, r3, #128	; 0x80
 8004022:	2b00      	cmp	r3, #0
 8004024:	d00a      	beq.n	800403c <UART_AdvFeatureConfig+0x138>
  {
    assert_param(IS_UART_ADVFEATURE_MSBFIRST(huart->AdvancedInit.MSBFirst));
    MODIFY_REG(huart->Instance->CR2, USART_CR2_MSBFIRST, huart->AdvancedInit.MSBFirst);
 8004026:	687b      	ldr	r3, [r7, #4]
 8004028:	681b      	ldr	r3, [r3, #0]
 800402a:	685b      	ldr	r3, [r3, #4]
 800402c:	f423 2100 	bic.w	r1, r3, #524288	; 0x80000
 8004030:	687b      	ldr	r3, [r7, #4]
 8004032:	6c9a      	ldr	r2, [r3, #72]	; 0x48
 8004034:	687b      	ldr	r3, [r7, #4]
 8004036:	681b      	ldr	r3, [r3, #0]
 8004038:	430a      	orrs	r2, r1
 800403a:	605a      	str	r2, [r3, #4]
  }
}
 800403c:	bf00      	nop
 800403e:	370c      	adds	r7, #12
 8004040:	46bd      	mov	sp, r7
 8004042:	f85d 7b04 	ldr.w	r7, [sp], #4
 8004046:	4770      	bx	lr

08004048 <UART_CheckIdleState>:
  * @brief Check the UART Idle State.
  * @param huart UART handle.
  * @retval HAL status
  */
HAL_StatusTypeDef UART_CheckIdleState(UART_HandleTypeDef *huart)
{
 8004048:	b580      	push	{r7, lr}
 800404a:	b086      	sub	sp, #24
 800404c:	af02      	add	r7, sp, #8
 800404e:	6078      	str	r0, [r7, #4]
  uint32_t tickstart;

  /* Initialize the UART ErrorCode */
  huart->ErrorCode = HAL_UART_ERROR_NONE;
 8004050:	687b      	ldr	r3, [r7, #4]
 8004052:	2200      	movs	r2, #0
 8004054:	67da      	str	r2, [r3, #124]	; 0x7c

  /* Init tickstart for timeout managment*/
  tickstart = HAL_GetTick();
 8004056:	f7fd fa55 	bl	8001504 <HAL_GetTick>
 800405a:	60f8      	str	r0, [r7, #12]

  /* Check if the Transmitter is enabled */
  if ((huart->Instance->CR1 & USART_CR1_TE) == USART_CR1_TE)
 800405c:	687b      	ldr	r3, [r7, #4]
 800405e:	681b      	ldr	r3, [r3, #0]
 8004060:	681b      	ldr	r3, [r3, #0]
 8004062:	f003 0308 	and.w	r3, r3, #8
 8004066:	2b08      	cmp	r3, #8
 8004068:	d10e      	bne.n	8004088 <UART_CheckIdleState+0x40>
  {
    /* Wait until TEACK flag is set */
    if (UART_WaitOnFlagUntilTimeout(huart, USART_ISR_TEACK, RESET, tickstart, HAL_UART_TIMEOUT_VALUE) != HAL_OK)
 800406a:	f06f 437e 	mvn.w	r3, #4261412864	; 0xfe000000
 800406e:	9300      	str	r3, [sp, #0]
 8004070:	68fb      	ldr	r3, [r7, #12]
 8004072:	2200      	movs	r2, #0
 8004074:	f44f 1100 	mov.w	r1, #2097152	; 0x200000
 8004078:	6878      	ldr	r0, [r7, #4]
 800407a:	f000 f82a 	bl	80040d2 <UART_WaitOnFlagUntilTimeout>
 800407e:	4603      	mov	r3, r0
 8004080:	2b00      	cmp	r3, #0
 8004082:	d001      	beq.n	8004088 <UART_CheckIdleState+0x40>
    {
      /* Timeout occurred */
      return HAL_TIMEOUT;
 8004084:	2303      	movs	r3, #3
 8004086:	e020      	b.n	80040ca <UART_CheckIdleState+0x82>
    }
  }
#if defined(USART_ISR_REACK)

  /* Check if the Receiver is enabled */
  if ((huart->Instance->CR1 & USART_CR1_RE) == USART_CR1_RE)
 8004088:	687b      	ldr	r3, [r7, #4]
 800408a:	681b      	ldr	r3, [r3, #0]
 800408c:	681b      	ldr	r3, [r3, #0]
 800408e:	f003 0304 	and.w	r3, r3, #4
 8004092:	2b04      	cmp	r3, #4
 8004094:	d10e      	bne.n	80040b4 <UART_CheckIdleState+0x6c>
  {
    /* Wait until REACK flag is set */
    if (UART_WaitOnFlagUntilTimeout(huart, USART_ISR_REACK, RESET, tickstart, HAL_UART_TIMEOUT_VALUE) != HAL_OK)
 8004096:	f06f 437e 	mvn.w	r3, #4261412864	; 0xfe000000
 800409a:	9300      	str	r3, [sp, #0]
 800409c:	68fb      	ldr	r3, [r7, #12]
 800409e:	2200      	movs	r2, #0
 80040a0:	f44f 0180 	mov.w	r1, #4194304	; 0x400000
 80040a4:	6878      	ldr	r0, [r7, #4]
 80040a6:	f000 f814 	bl	80040d2 <UART_WaitOnFlagUntilTimeout>
 80040aa:	4603      	mov	r3, r0
 80040ac:	2b00      	cmp	r3, #0
 80040ae:	d001      	beq.n	80040b4 <UART_CheckIdleState+0x6c>
    {
      /* Timeout occurred */
      return HAL_TIMEOUT;
 80040b0:	2303      	movs	r3, #3
 80040b2:	e00a      	b.n	80040ca <UART_CheckIdleState+0x82>
    }
  }
#endif

  /* Initialize the UART State */
  huart->gState = HAL_UART_STATE_READY;
 80040b4:	687b      	ldr	r3, [r7, #4]
 80040b6:	2220      	movs	r2, #32
 80040b8:	675a      	str	r2, [r3, #116]	; 0x74
  huart->RxState = HAL_UART_STATE_READY;
 80040ba:	687b      	ldr	r3, [r7, #4]
 80040bc:	2220      	movs	r2, #32
 80040be:	679a      	str	r2, [r3, #120]	; 0x78

  __HAL_UNLOCK(huart);
 80040c0:	687b      	ldr	r3, [r7, #4]
 80040c2:	2200      	movs	r2, #0
 80040c4:	f883 2070 	strb.w	r2, [r3, #112]	; 0x70

  return HAL_OK;
 80040c8:	2300      	movs	r3, #0
}
 80040ca:	4618      	mov	r0, r3
 80040cc:	3710      	adds	r7, #16
 80040ce:	46bd      	mov	sp, r7
 80040d0:	bd80      	pop	{r7, pc}

080040d2 <UART_WaitOnFlagUntilTimeout>:
  * @param Timeout   Timeout duration
  * @retval HAL status
  */
HAL_StatusTypeDef UART_WaitOnFlagUntilTimeout(UART_HandleTypeDef *huart, uint32_t Flag, FlagStatus Status,
                                              uint32_t Tickstart, uint32_t Timeout)
{
 80040d2:	b580      	push	{r7, lr}
 80040d4:	b084      	sub	sp, #16
 80040d6:	af00      	add	r7, sp, #0
 80040d8:	60f8      	str	r0, [r7, #12]
 80040da:	60b9      	str	r1, [r7, #8]
 80040dc:	603b      	str	r3, [r7, #0]
 80040de:	4613      	mov	r3, r2
 80040e0:	71fb      	strb	r3, [r7, #7]
  /* Wait until flag is set */
  while ((__HAL_UART_GET_FLAG(huart, Flag) ? SET : RESET) == Status)
 80040e2:	e05d      	b.n	80041a0 <UART_WaitOnFlagUntilTimeout+0xce>
  {
    /* Check for the Timeout */
    if (Timeout != HAL_MAX_DELAY)
 80040e4:	69bb      	ldr	r3, [r7, #24]
 80040e6:	f1b3 3fff 	cmp.w	r3, #4294967295	; 0xffffffff
 80040ea:	d059      	beq.n	80041a0 <UART_WaitOnFlagUntilTimeout+0xce>
    {
      if (((HAL_GetTick() - Tickstart) > Timeout) || (Timeout == 0U))
 80040ec:	f7fd fa0a 	bl	8001504 <HAL_GetTick>
 80040f0:	4602      	mov	r2, r0
 80040f2:	683b      	ldr	r3, [r7, #0]
 80040f4:	1ad3      	subs	r3, r2, r3
 80040f6:	69ba      	ldr	r2, [r7, #24]
 80040f8:	429a      	cmp	r2, r3
 80040fa:	d302      	bcc.n	8004102 <UART_WaitOnFlagUntilTimeout+0x30>
 80040fc:	69bb      	ldr	r3, [r7, #24]
 80040fe:	2b00      	cmp	r3, #0
 8004100:	d11b      	bne.n	800413a <UART_WaitOnFlagUntilTimeout+0x68>
      {
        /* Disable TXE, RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts for the interrupt process */
        CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE));
 8004102:	68fb      	ldr	r3, [r7, #12]
 8004104:	681b      	ldr	r3, [r3, #0]
 8004106:	681a      	ldr	r2, [r3, #0]
 8004108:	68fb      	ldr	r3, [r7, #12]
 800410a:	681b      	ldr	r3, [r3, #0]
 800410c:	f422 72d0 	bic.w	r2, r2, #416	; 0x1a0
 8004110:	601a      	str	r2, [r3, #0]
        CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE);
 8004112:	68fb      	ldr	r3, [r7, #12]
 8004114:	681b      	ldr	r3, [r3, #0]
 8004116:	689a      	ldr	r2, [r3, #8]
 8004118:	68fb      	ldr	r3, [r7, #12]
 800411a:	681b      	ldr	r3, [r3, #0]
 800411c:	f022 0201 	bic.w	r2, r2, #1
 8004120:	609a      	str	r2, [r3, #8]

        huart->gState = HAL_UART_STATE_READY;
 8004122:	68fb      	ldr	r3, [r7, #12]
 8004124:	2220      	movs	r2, #32
 8004126:	675a      	str	r2, [r3, #116]	; 0x74
        huart->RxState = HAL_UART_STATE_READY;
 8004128:	68fb      	ldr	r3, [r7, #12]
 800412a:	2220      	movs	r2, #32
 800412c:	679a      	str	r2, [r3, #120]	; 0x78

        __HAL_UNLOCK(huart);
 800412e:	68fb      	ldr	r3, [r7, #12]
 8004130:	2200      	movs	r2, #0
 8004132:	f883 2070 	strb.w	r2, [r3, #112]	; 0x70

        return HAL_TIMEOUT;
 8004136:	2303      	movs	r3, #3
 8004138:	e042      	b.n	80041c0 <UART_WaitOnFlagUntilTimeout+0xee>
      }

      if (READ_BIT(huart->Instance->CR1, USART_CR1_RE) != 0U)
 800413a:	68fb      	ldr	r3, [r7, #12]
 800413c:	681b      	ldr	r3, [r3, #0]
 800413e:	681b      	ldr	r3, [r3, #0]
 8004140:	f003 0304 	and.w	r3, r3, #4
 8004144:	2b00      	cmp	r3, #0
 8004146:	d02b      	beq.n	80041a0 <UART_WaitOnFlagUntilTimeout+0xce>
      {
        if (__HAL_UART_GET_FLAG(huart, UART_FLAG_RTOF) == SET)
 8004148:	68fb      	ldr	r3, [r7, #12]
 800414a:	681b      	ldr	r3, [r3, #0]
 800414c:	69db      	ldr	r3, [r3, #28]
 800414e:	f403 6300 	and.w	r3, r3, #2048	; 0x800
 8004152:	f5b3 6f00 	cmp.w	r3, #2048	; 0x800
 8004156:	d123      	bne.n	80041a0 <UART_WaitOnFlagUntilTimeout+0xce>
        {
          /* Clear Receiver Timeout flag*/
          __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_RTOF);
 8004158:	68fb      	ldr	r3, [r7, #12]
 800415a:	681b      	ldr	r3, [r3, #0]
 800415c:	f44f 6200 	mov.w	r2, #2048	; 0x800
 8004160:	621a      	str	r2, [r3, #32]
          
          /* Disable TXE, RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts for the interrupt process */
          CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE));
 8004162:	68fb      	ldr	r3, [r7, #12]
 8004164:	681b      	ldr	r3, [r3, #0]
 8004166:	681a      	ldr	r2, [r3, #0]
 8004168:	68fb      	ldr	r3, [r7, #12]
 800416a:	681b      	ldr	r3, [r3, #0]
 800416c:	f422 72d0 	bic.w	r2, r2, #416	; 0x1a0
 8004170:	601a      	str	r2, [r3, #0]
          CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE);
 8004172:	68fb      	ldr	r3, [r7, #12]
 8004174:	681b      	ldr	r3, [r3, #0]
 8004176:	689a      	ldr	r2, [r3, #8]
 8004178:	68fb      	ldr	r3, [r7, #12]
 800417a:	681b      	ldr	r3, [r3, #0]
 800417c:	f022 0201 	bic.w	r2, r2, #1
 8004180:	609a      	str	r2, [r3, #8]

          huart->gState = HAL_UART_STATE_READY;
 8004182:	68fb      	ldr	r3, [r7, #12]
 8004184:	2220      	movs	r2, #32
 8004186:	675a      	str	r2, [r3, #116]	; 0x74
          huart->RxState = HAL_UART_STATE_READY;
 8004188:	68fb      	ldr	r3, [r7, #12]
 800418a:	2220      	movs	r2, #32
 800418c:	679a      	str	r2, [r3, #120]	; 0x78
          huart->ErrorCode = HAL_UART_ERROR_RTO;
 800418e:	68fb      	ldr	r3, [r7, #12]
 8004190:	2220      	movs	r2, #32
 8004192:	67da      	str	r2, [r3, #124]	; 0x7c
          
          /* Process Unlocked */
          __HAL_UNLOCK(huart);
 8004194:	68fb      	ldr	r3, [r7, #12]
 8004196:	2200      	movs	r2, #0
 8004198:	f883 2070 	strb.w	r2, [r3, #112]	; 0x70
          
          return HAL_TIMEOUT;
 800419c:	2303      	movs	r3, #3
 800419e:	e00f      	b.n	80041c0 <UART_WaitOnFlagUntilTimeout+0xee>
  while ((__HAL_UART_GET_FLAG(huart, Flag) ? SET : RESET) == Status)
 80041a0:	68fb      	ldr	r3, [r7, #12]
 80041a2:	681b      	ldr	r3, [r3, #0]
 80041a4:	69da      	ldr	r2, [r3, #28]
 80041a6:	68bb      	ldr	r3, [r7, #8]
 80041a8:	4013      	ands	r3, r2
 80041aa:	68ba      	ldr	r2, [r7, #8]
 80041ac:	429a      	cmp	r2, r3
 80041ae:	bf0c      	ite	eq
 80041b0:	2301      	moveq	r3, #1
 80041b2:	2300      	movne	r3, #0
 80041b4:	b2db      	uxtb	r3, r3
 80041b6:	461a      	mov	r2, r3
 80041b8:	79fb      	ldrb	r3, [r7, #7]
 80041ba:	429a      	cmp	r2, r3
 80041bc:	d092      	beq.n	80040e4 <UART_WaitOnFlagUntilTimeout+0x12>
        }
      }
    }
  }
  return HAL_OK;
 80041be:	2300      	movs	r3, #0
}
 80041c0:	4618      	mov	r0, r3
 80041c2:	3710      	adds	r7, #16
 80041c4:	46bd      	mov	sp, r7
 80041c6:	bd80      	pop	{r7, pc}

080041c8 <ILI9341_Draw_Filled_Circle>:
    }
}

/*Draw filled circle at X,Y location with specified radius and colour. X and Y represent circles center */
void ILI9341_Draw_Filled_Circle(uint16_t X, uint16_t Y, uint16_t Radius, uint16_t Colour)
{
 80041c8:	b590      	push	{r4, r7, lr}
 80041ca:	b08b      	sub	sp, #44	; 0x2c
 80041cc:	af00      	add	r7, sp, #0
 80041ce:	4604      	mov	r4, r0
 80041d0:	4608      	mov	r0, r1
 80041d2:	4611      	mov	r1, r2
 80041d4:	461a      	mov	r2, r3
 80041d6:	4623      	mov	r3, r4
 80041d8:	80fb      	strh	r3, [r7, #6]
 80041da:	4603      	mov	r3, r0
 80041dc:	80bb      	strh	r3, [r7, #4]
 80041de:	460b      	mov	r3, r1
 80041e0:	807b      	strh	r3, [r7, #2]
 80041e2:	4613      	mov	r3, r2
 80041e4:	803b      	strh	r3, [r7, #0]
	
		int x = Radius;
 80041e6:	887b      	ldrh	r3, [r7, #2]
 80041e8:	627b      	str	r3, [r7, #36]	; 0x24
    int y = 0;
 80041ea:	2300      	movs	r3, #0
 80041ec:	623b      	str	r3, [r7, #32]
    int xChange = 1 - (Radius << 1);
 80041ee:	887b      	ldrh	r3, [r7, #2]
 80041f0:	005b      	lsls	r3, r3, #1
 80041f2:	f1c3 0301 	rsb	r3, r3, #1
 80041f6:	61fb      	str	r3, [r7, #28]
    int yChange = 0;
 80041f8:	2300      	movs	r3, #0
 80041fa:	61bb      	str	r3, [r7, #24]
    int radiusError = 0;
 80041fc:	2300      	movs	r3, #0
 80041fe:	617b      	str	r3, [r7, #20]

    while (x >= y)
 8004200:	e061      	b.n	80042c6 <ILI9341_Draw_Filled_Circle+0xfe>
    {
        for (int i = X - x; i <= X + x; i++)
 8004202:	88fa      	ldrh	r2, [r7, #6]
 8004204:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 8004206:	1ad3      	subs	r3, r2, r3
 8004208:	613b      	str	r3, [r7, #16]
 800420a:	e018      	b.n	800423e <ILI9341_Draw_Filled_Circle+0x76>
        {
            ILI9341_Draw_Pixel(i, Y + y,Colour);
 800420c:	693b      	ldr	r3, [r7, #16]
 800420e:	b298      	uxth	r0, r3
 8004210:	6a3b      	ldr	r3, [r7, #32]
 8004212:	b29a      	uxth	r2, r3
 8004214:	88bb      	ldrh	r3, [r7, #4]
 8004216:	4413      	add	r3, r2
 8004218:	b29b      	uxth	r3, r3
 800421a:	883a      	ldrh	r2, [r7, #0]
 800421c:	4619      	mov	r1, r3
 800421e:	f000 fe01 	bl	8004e24 <ILI9341_Draw_Pixel>
            ILI9341_Draw_Pixel(i, Y - y,Colour);
 8004222:	693b      	ldr	r3, [r7, #16]
 8004224:	b298      	uxth	r0, r3
 8004226:	6a3b      	ldr	r3, [r7, #32]
 8004228:	b29b      	uxth	r3, r3
 800422a:	88ba      	ldrh	r2, [r7, #4]
 800422c:	1ad3      	subs	r3, r2, r3
 800422e:	b29b      	uxth	r3, r3
 8004230:	883a      	ldrh	r2, [r7, #0]
 8004232:	4619      	mov	r1, r3
 8004234:	f000 fdf6 	bl	8004e24 <ILI9341_Draw_Pixel>
        for (int i = X - x; i <= X + x; i++)
 8004238:	693b      	ldr	r3, [r7, #16]
 800423a:	3301      	adds	r3, #1
 800423c:	613b      	str	r3, [r7, #16]
 800423e:	88fa      	ldrh	r2, [r7, #6]
 8004240:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 8004242:	4413      	add	r3, r2
 8004244:	693a      	ldr	r2, [r7, #16]
 8004246:	429a      	cmp	r2, r3
 8004248:	dde0      	ble.n	800420c <ILI9341_Draw_Filled_Circle+0x44>
        }
        for (int i = X - y; i <= X + y; i++)
 800424a:	88fa      	ldrh	r2, [r7, #6]
 800424c:	6a3b      	ldr	r3, [r7, #32]
 800424e:	1ad3      	subs	r3, r2, r3
 8004250:	60fb      	str	r3, [r7, #12]
 8004252:	e018      	b.n	8004286 <ILI9341_Draw_Filled_Circle+0xbe>
        {
            ILI9341_Draw_Pixel(i, Y + x,Colour);
 8004254:	68fb      	ldr	r3, [r7, #12]
 8004256:	b298      	uxth	r0, r3
 8004258:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 800425a:	b29a      	uxth	r2, r3
 800425c:	88bb      	ldrh	r3, [r7, #4]
 800425e:	4413      	add	r3, r2
 8004260:	b29b      	uxth	r3, r3
 8004262:	883a      	ldrh	r2, [r7, #0]
 8004264:	4619      	mov	r1, r3
 8004266:	f000 fddd 	bl	8004e24 <ILI9341_Draw_Pixel>
            ILI9341_Draw_Pixel(i, Y - x,Colour);
 800426a:	68fb      	ldr	r3, [r7, #12]
 800426c:	b298      	uxth	r0, r3
 800426e:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 8004270:	b29b      	uxth	r3, r3
 8004272:	88ba      	ldrh	r2, [r7, #4]
 8004274:	1ad3      	subs	r3, r2, r3
 8004276:	b29b      	uxth	r3, r3
 8004278:	883a      	ldrh	r2, [r7, #0]
 800427a:	4619      	mov	r1, r3
 800427c:	f000 fdd2 	bl	8004e24 <ILI9341_Draw_Pixel>
        for (int i = X - y; i <= X + y; i++)
 8004280:	68fb      	ldr	r3, [r7, #12]
 8004282:	3301      	adds	r3, #1
 8004284:	60fb      	str	r3, [r7, #12]
 8004286:	88fa      	ldrh	r2, [r7, #6]
 8004288:	6a3b      	ldr	r3, [r7, #32]
 800428a:	4413      	add	r3, r2
 800428c:	68fa      	ldr	r2, [r7, #12]
 800428e:	429a      	cmp	r2, r3
 8004290:	dde0      	ble.n	8004254 <ILI9341_Draw_Filled_Circle+0x8c>
        }

        y++;
 8004292:	6a3b      	ldr	r3, [r7, #32]
 8004294:	3301      	adds	r3, #1
 8004296:	623b      	str	r3, [r7, #32]
        radiusError += yChange;
 8004298:	697a      	ldr	r2, [r7, #20]
 800429a:	69bb      	ldr	r3, [r7, #24]
 800429c:	4413      	add	r3, r2
 800429e:	617b      	str	r3, [r7, #20]
        yChange += 2;
 80042a0:	69bb      	ldr	r3, [r7, #24]
 80042a2:	3302      	adds	r3, #2
 80042a4:	61bb      	str	r3, [r7, #24]
        if (((radiusError << 1) + xChange) > 0)
 80042a6:	697b      	ldr	r3, [r7, #20]
 80042a8:	005a      	lsls	r2, r3, #1
 80042aa:	69fb      	ldr	r3, [r7, #28]
 80042ac:	4413      	add	r3, r2
 80042ae:	2b00      	cmp	r3, #0
 80042b0:	dd09      	ble.n	80042c6 <ILI9341_Draw_Filled_Circle+0xfe>
        {
            x--;
 80042b2:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 80042b4:	3b01      	subs	r3, #1
 80042b6:	627b      	str	r3, [r7, #36]	; 0x24
            radiusError += xChange;
 80042b8:	697a      	ldr	r2, [r7, #20]
 80042ba:	69fb      	ldr	r3, [r7, #28]
 80042bc:	4413      	add	r3, r2
 80042be:	617b      	str	r3, [r7, #20]
            xChange += 2;
 80042c0:	69fb      	ldr	r3, [r7, #28]
 80042c2:	3302      	adds	r3, #2
 80042c4:	61fb      	str	r3, [r7, #28]
    while (x >= y)
 80042c6:	6a7a      	ldr	r2, [r7, #36]	; 0x24
 80042c8:	6a3b      	ldr	r3, [r7, #32]
 80042ca:	429a      	cmp	r2, r3
 80042cc:	da99      	bge.n	8004202 <ILI9341_Draw_Filled_Circle+0x3a>
        }
    }
		//Really slow implementation, will require future overhaul
		//TODO:	https://stackoverflow.com/questions/1201200/fast-algorithm-for-drawing-filled-circles	
}
 80042ce:	bf00      	nop
 80042d0:	372c      	adds	r7, #44	; 0x2c
 80042d2:	46bd      	mov	sp, r7
 80042d4:	bd90      	pop	{r4, r7, pc}

080042d6 <ILI9341_Draw_Filled_Rectangle_Coord>:
	
}

/*Draw a filled rectangle between positions X0,Y0 and X1,Y1 with specified colour*/
void ILI9341_Draw_Filled_Rectangle_Coord(uint16_t X0, uint16_t Y0, uint16_t X1, uint16_t Y1, uint16_t Colour)
{
 80042d6:	b590      	push	{r4, r7, lr}
 80042d8:	b089      	sub	sp, #36	; 0x24
 80042da:	af02      	add	r7, sp, #8
 80042dc:	4604      	mov	r4, r0
 80042de:	4608      	mov	r0, r1
 80042e0:	4611      	mov	r1, r2
 80042e2:	461a      	mov	r2, r3
 80042e4:	4623      	mov	r3, r4
 80042e6:	80fb      	strh	r3, [r7, #6]
 80042e8:	4603      	mov	r3, r0
 80042ea:	80bb      	strh	r3, [r7, #4]
 80042ec:	460b      	mov	r3, r1
 80042ee:	807b      	strh	r3, [r7, #2]
 80042f0:	4613      	mov	r3, r2
 80042f2:	803b      	strh	r3, [r7, #0]
	uint16_t 	X_length = 0;
 80042f4:	2300      	movs	r3, #0
 80042f6:	82fb      	strh	r3, [r7, #22]
	uint16_t 	Y_length = 0;
 80042f8:	2300      	movs	r3, #0
 80042fa:	82bb      	strh	r3, [r7, #20]
	uint8_t		Negative_X = 0;
 80042fc:	2300      	movs	r3, #0
 80042fe:	74fb      	strb	r3, [r7, #19]
	uint8_t 	Negative_Y = 0;
 8004300:	2300      	movs	r3, #0
 8004302:	74bb      	strb	r3, [r7, #18]
	int32_t 	Calc_Negative = 0;
 8004304:	2300      	movs	r3, #0
 8004306:	60bb      	str	r3, [r7, #8]
	
	uint16_t X0_true = 0;
 8004308:	2300      	movs	r3, #0
 800430a:	823b      	strh	r3, [r7, #16]
	uint16_t Y0_true = 0;
 800430c:	2300      	movs	r3, #0
 800430e:	81fb      	strh	r3, [r7, #14]
	
	Calc_Negative = X1 - X0;
 8004310:	887a      	ldrh	r2, [r7, #2]
 8004312:	88fb      	ldrh	r3, [r7, #6]
 8004314:	1ad3      	subs	r3, r2, r3
 8004316:	60bb      	str	r3, [r7, #8]
	if(Calc_Negative < 0) Negative_X = 1;
 8004318:	68bb      	ldr	r3, [r7, #8]
 800431a:	2b00      	cmp	r3, #0
 800431c:	da01      	bge.n	8004322 <ILI9341_Draw_Filled_Rectangle_Coord+0x4c>
 800431e:	2301      	movs	r3, #1
 8004320:	74fb      	strb	r3, [r7, #19]
	Calc_Negative = 0;
 8004322:	2300      	movs	r3, #0
 8004324:	60bb      	str	r3, [r7, #8]
	
	Calc_Negative = Y1 - Y0;
 8004326:	883a      	ldrh	r2, [r7, #0]
 8004328:	88bb      	ldrh	r3, [r7, #4]
 800432a:	1ad3      	subs	r3, r2, r3
 800432c:	60bb      	str	r3, [r7, #8]
	if(Calc_Negative < 0) Negative_Y = 1;
 800432e:	68bb      	ldr	r3, [r7, #8]
 8004330:	2b00      	cmp	r3, #0
 8004332:	da01      	bge.n	8004338 <ILI9341_Draw_Filled_Rectangle_Coord+0x62>
 8004334:	2301      	movs	r3, #1
 8004336:	74bb      	strb	r3, [r7, #18]
	
	
	//DRAW HORIZONTAL!
	if(!Negative_X)
 8004338:	7cfb      	ldrb	r3, [r7, #19]
 800433a:	2b00      	cmp	r3, #0
 800433c:	d106      	bne.n	800434c <ILI9341_Draw_Filled_Rectangle_Coord+0x76>
	{
		X_length = X1 - X0;
 800433e:	887a      	ldrh	r2, [r7, #2]
 8004340:	88fb      	ldrh	r3, [r7, #6]
 8004342:	1ad3      	subs	r3, r2, r3
 8004344:	82fb      	strh	r3, [r7, #22]
		X0_true = X0;
 8004346:	88fb      	ldrh	r3, [r7, #6]
 8004348:	823b      	strh	r3, [r7, #16]
 800434a:	e005      	b.n	8004358 <ILI9341_Draw_Filled_Rectangle_Coord+0x82>
	}
	else
	{
		X_length = X0 - X1;
 800434c:	88fa      	ldrh	r2, [r7, #6]
 800434e:	887b      	ldrh	r3, [r7, #2]
 8004350:	1ad3      	subs	r3, r2, r3
 8004352:	82fb      	strh	r3, [r7, #22]
		X0_true = X1;
 8004354:	887b      	ldrh	r3, [r7, #2]
 8004356:	823b      	strh	r3, [r7, #16]
	}
	
	//DRAW VERTICAL!
	if(!Negative_Y)
 8004358:	7cbb      	ldrb	r3, [r7, #18]
 800435a:	2b00      	cmp	r3, #0
 800435c:	d106      	bne.n	800436c <ILI9341_Draw_Filled_Rectangle_Coord+0x96>
	{
		Y_length = Y1 - Y0;
 800435e:	883a      	ldrh	r2, [r7, #0]
 8004360:	88bb      	ldrh	r3, [r7, #4]
 8004362:	1ad3      	subs	r3, r2, r3
 8004364:	82bb      	strh	r3, [r7, #20]
		Y0_true = Y0;		
 8004366:	88bb      	ldrh	r3, [r7, #4]
 8004368:	81fb      	strh	r3, [r7, #14]
 800436a:	e005      	b.n	8004378 <ILI9341_Draw_Filled_Rectangle_Coord+0xa2>
	}
	else
	{
		Y_length = Y0 - Y1;
 800436c:	88ba      	ldrh	r2, [r7, #4]
 800436e:	883b      	ldrh	r3, [r7, #0]
 8004370:	1ad3      	subs	r3, r2, r3
 8004372:	82bb      	strh	r3, [r7, #20]
		Y0_true = Y1;	
 8004374:	883b      	ldrh	r3, [r7, #0]
 8004376:	81fb      	strh	r3, [r7, #14]
	}
	
	ILI9341_Draw_Rectangle(X0_true, Y0_true, X_length, Y_length, Colour);	
 8004378:	8abc      	ldrh	r4, [r7, #20]
 800437a:	8afa      	ldrh	r2, [r7, #22]
 800437c:	89f9      	ldrh	r1, [r7, #14]
 800437e:	8a38      	ldrh	r0, [r7, #16]
 8004380:	8d3b      	ldrh	r3, [r7, #40]	; 0x28
 8004382:	9300      	str	r3, [sp, #0]
 8004384:	4623      	mov	r3, r4
 8004386:	f000 fe27 	bl	8004fd8 <ILI9341_Draw_Rectangle>
}
 800438a:	bf00      	nop
 800438c:	371c      	adds	r7, #28
 800438e:	46bd      	mov	sp, r7
 8004390:	bd90      	pop	{r4, r7, pc}
	...

08004394 <ILI9341_Draw_Char>:

/*Draws a character (fonts imported from fonts.h) at X,Y location with specified font colour, size and Background colour*/
/*See fonts.h implementation of font on what is required for changing to a different font when switching fonts libraries*/
void ILI9341_Draw_Char(char Character, uint16_t X, uint16_t Y, uint16_t Colour, uint16_t Size, uint16_t Background_Colour)
{
 8004394:	b590      	push	{r4, r7, lr}
 8004396:	b089      	sub	sp, #36	; 0x24
 8004398:	af02      	add	r7, sp, #8
 800439a:	4604      	mov	r4, r0
 800439c:	4608      	mov	r0, r1
 800439e:	4611      	mov	r1, r2
 80043a0:	461a      	mov	r2, r3
 80043a2:	4623      	mov	r3, r4
 80043a4:	71fb      	strb	r3, [r7, #7]
 80043a6:	4603      	mov	r3, r0
 80043a8:	80bb      	strh	r3, [r7, #4]
 80043aa:	460b      	mov	r3, r1
 80043ac:	807b      	strh	r3, [r7, #2]
 80043ae:	4613      	mov	r3, r2
 80043b0:	803b      	strh	r3, [r7, #0]
		uint8_t 	function_char;
    uint8_t 	i,j;
		
		function_char = Character;
 80043b2:	79fb      	ldrb	r3, [r7, #7]
 80043b4:	75fb      	strb	r3, [r7, #23]
		
    if (function_char < ' ') {
 80043b6:	7dfb      	ldrb	r3, [r7, #23]
 80043b8:	2b1f      	cmp	r3, #31
 80043ba:	d802      	bhi.n	80043c2 <ILI9341_Draw_Char+0x2e>
        Character = 0;
 80043bc:	2300      	movs	r3, #0
 80043be:	71fb      	strb	r3, [r7, #7]
 80043c0:	e002      	b.n	80043c8 <ILI9341_Draw_Char+0x34>
    } else {
        function_char -= 32;
 80043c2:	7dfb      	ldrb	r3, [r7, #23]
 80043c4:	3b20      	subs	r3, #32
 80043c6:	75fb      	strb	r3, [r7, #23]
		}
   	
		char temp[CHAR_WIDTH];
		for(uint8_t k = 0; k<CHAR_WIDTH; k++)
 80043c8:	2300      	movs	r3, #0
 80043ca:	753b      	strb	r3, [r7, #20]
 80043cc:	e012      	b.n	80043f4 <ILI9341_Draw_Char+0x60>
		{
		temp[k] = font[function_char][k];
 80043ce:	7dfa      	ldrb	r2, [r7, #23]
 80043d0:	7d38      	ldrb	r0, [r7, #20]
 80043d2:	7d39      	ldrb	r1, [r7, #20]
 80043d4:	4c38      	ldr	r4, [pc, #224]	; (80044b8 <ILI9341_Draw_Char+0x124>)
 80043d6:	4613      	mov	r3, r2
 80043d8:	005b      	lsls	r3, r3, #1
 80043da:	4413      	add	r3, r2
 80043dc:	005b      	lsls	r3, r3, #1
 80043de:	4423      	add	r3, r4
 80043e0:	4403      	add	r3, r0
 80043e2:	781a      	ldrb	r2, [r3, #0]
 80043e4:	f107 0318 	add.w	r3, r7, #24
 80043e8:	440b      	add	r3, r1
 80043ea:	f803 2c0c 	strb.w	r2, [r3, #-12]
		for(uint8_t k = 0; k<CHAR_WIDTH; k++)
 80043ee:	7d3b      	ldrb	r3, [r7, #20]
 80043f0:	3301      	adds	r3, #1
 80043f2:	753b      	strb	r3, [r7, #20]
 80043f4:	7d3b      	ldrb	r3, [r7, #20]
 80043f6:	2b05      	cmp	r3, #5
 80043f8:	d9e9      	bls.n	80043ce <ILI9341_Draw_Char+0x3a>
		}
		
    // Draw pixels
		ILI9341_Draw_Rectangle(X, Y, CHAR_WIDTH*Size, CHAR_HEIGHT*Size, Background_Colour);
 80043fa:	8d3b      	ldrh	r3, [r7, #40]	; 0x28
 80043fc:	461a      	mov	r2, r3
 80043fe:	0052      	lsls	r2, r2, #1
 8004400:	4413      	add	r3, r2
 8004402:	005b      	lsls	r3, r3, #1
 8004404:	b29a      	uxth	r2, r3
 8004406:	8d3b      	ldrh	r3, [r7, #40]	; 0x28
 8004408:	00db      	lsls	r3, r3, #3
 800440a:	b29c      	uxth	r4, r3
 800440c:	8879      	ldrh	r1, [r7, #2]
 800440e:	88b8      	ldrh	r0, [r7, #4]
 8004410:	8dbb      	ldrh	r3, [r7, #44]	; 0x2c
 8004412:	9300      	str	r3, [sp, #0]
 8004414:	4623      	mov	r3, r4
 8004416:	f000 fddf 	bl	8004fd8 <ILI9341_Draw_Rectangle>
    for (j=0; j<CHAR_WIDTH; j++) {
 800441a:	2300      	movs	r3, #0
 800441c:	757b      	strb	r3, [r7, #21]
 800441e:	e044      	b.n	80044aa <ILI9341_Draw_Char+0x116>
        for (i=0; i<CHAR_HEIGHT; i++) {
 8004420:	2300      	movs	r3, #0
 8004422:	75bb      	strb	r3, [r7, #22]
 8004424:	e03b      	b.n	800449e <ILI9341_Draw_Char+0x10a>
            if (temp[j] & (1<<i)) {			
 8004426:	7d7b      	ldrb	r3, [r7, #21]
 8004428:	f107 0218 	add.w	r2, r7, #24
 800442c:	4413      	add	r3, r2
 800442e:	f813 3c0c 	ldrb.w	r3, [r3, #-12]
 8004432:	461a      	mov	r2, r3
 8004434:	7dbb      	ldrb	r3, [r7, #22]
 8004436:	fa42 f303 	asr.w	r3, r2, r3
 800443a:	f003 0301 	and.w	r3, r3, #1
 800443e:	2b00      	cmp	r3, #0
 8004440:	d02a      	beq.n	8004498 <ILI9341_Draw_Char+0x104>
							if(Size == 1)
 8004442:	8d3b      	ldrh	r3, [r7, #40]	; 0x28
 8004444:	2b01      	cmp	r3, #1
 8004446:	d10e      	bne.n	8004466 <ILI9341_Draw_Char+0xd2>
							{
              ILI9341_Draw_Pixel(X+j, Y+i, Colour);
 8004448:	7d7b      	ldrb	r3, [r7, #21]
 800444a:	b29a      	uxth	r2, r3
 800444c:	88bb      	ldrh	r3, [r7, #4]
 800444e:	4413      	add	r3, r2
 8004450:	b298      	uxth	r0, r3
 8004452:	7dbb      	ldrb	r3, [r7, #22]
 8004454:	b29a      	uxth	r2, r3
 8004456:	887b      	ldrh	r3, [r7, #2]
 8004458:	4413      	add	r3, r2
 800445a:	b29b      	uxth	r3, r3
 800445c:	883a      	ldrh	r2, [r7, #0]
 800445e:	4619      	mov	r1, r3
 8004460:	f000 fce0 	bl	8004e24 <ILI9341_Draw_Pixel>
 8004464:	e018      	b.n	8004498 <ILI9341_Draw_Char+0x104>
							}
							else
							{
							ILI9341_Draw_Rectangle(X+(j*Size), Y+(i*Size), Size, Size, Colour);
 8004466:	7d7b      	ldrb	r3, [r7, #21]
 8004468:	b29b      	uxth	r3, r3
 800446a:	8d3a      	ldrh	r2, [r7, #40]	; 0x28
 800446c:	fb12 f303 	smulbb	r3, r2, r3
 8004470:	b29a      	uxth	r2, r3
 8004472:	88bb      	ldrh	r3, [r7, #4]
 8004474:	4413      	add	r3, r2
 8004476:	b298      	uxth	r0, r3
 8004478:	7dbb      	ldrb	r3, [r7, #22]
 800447a:	b29b      	uxth	r3, r3
 800447c:	8d3a      	ldrh	r2, [r7, #40]	; 0x28
 800447e:	fb12 f303 	smulbb	r3, r2, r3
 8004482:	b29a      	uxth	r2, r3
 8004484:	887b      	ldrh	r3, [r7, #2]
 8004486:	4413      	add	r3, r2
 8004488:	b299      	uxth	r1, r3
 800448a:	8d3c      	ldrh	r4, [r7, #40]	; 0x28
 800448c:	8d3a      	ldrh	r2, [r7, #40]	; 0x28
 800448e:	883b      	ldrh	r3, [r7, #0]
 8004490:	9300      	str	r3, [sp, #0]
 8004492:	4623      	mov	r3, r4
 8004494:	f000 fda0 	bl	8004fd8 <ILI9341_Draw_Rectangle>
        for (i=0; i<CHAR_HEIGHT; i++) {
 8004498:	7dbb      	ldrb	r3, [r7, #22]
 800449a:	3301      	adds	r3, #1
 800449c:	75bb      	strb	r3, [r7, #22]
 800449e:	7dbb      	ldrb	r3, [r7, #22]
 80044a0:	2b07      	cmp	r3, #7
 80044a2:	d9c0      	bls.n	8004426 <ILI9341_Draw_Char+0x92>
    for (j=0; j<CHAR_WIDTH; j++) {
 80044a4:	7d7b      	ldrb	r3, [r7, #21]
 80044a6:	3301      	adds	r3, #1
 80044a8:	757b      	strb	r3, [r7, #21]
 80044aa:	7d7b      	ldrb	r3, [r7, #21]
 80044ac:	2b05      	cmp	r3, #5
 80044ae:	d9b7      	bls.n	8004420 <ILI9341_Draw_Char+0x8c>
							}
            }						
        }
    }
}
 80044b0:	bf00      	nop
 80044b2:	371c      	adds	r7, #28
 80044b4:	46bd      	mov	sp, r7
 80044b6:	bd90      	pop	{r4, r7, pc}
 80044b8:	0802e47c 	.word	0x0802e47c

080044bc <ILI9341_Draw_Text>:

/*Draws an array of characters (fonts imported from fonts.h) at X,Y location with specified font colour, size and Background colour*/
/*See fonts.h implementation of font on what is required for changing to a different font when switching fonts libraries*/
void ILI9341_Draw_Text(const char* Text, uint16_t X, uint16_t Y, uint16_t Colour, uint16_t Size, uint16_t Background_Colour)
{
 80044bc:	b590      	push	{r4, r7, lr}
 80044be:	b087      	sub	sp, #28
 80044c0:	af02      	add	r7, sp, #8
 80044c2:	60f8      	str	r0, [r7, #12]
 80044c4:	4608      	mov	r0, r1
 80044c6:	4611      	mov	r1, r2
 80044c8:	461a      	mov	r2, r3
 80044ca:	4603      	mov	r3, r0
 80044cc:	817b      	strh	r3, [r7, #10]
 80044ce:	460b      	mov	r3, r1
 80044d0:	813b      	strh	r3, [r7, #8]
 80044d2:	4613      	mov	r3, r2
 80044d4:	80fb      	strh	r3, [r7, #6]
    while (*Text) {
 80044d6:	e016      	b.n	8004506 <ILI9341_Draw_Text+0x4a>
        ILI9341_Draw_Char(*Text++, X, Y, Colour, Size, Background_Colour);
 80044d8:	68fb      	ldr	r3, [r7, #12]
 80044da:	1c5a      	adds	r2, r3, #1
 80044dc:	60fa      	str	r2, [r7, #12]
 80044de:	7818      	ldrb	r0, [r3, #0]
 80044e0:	88fc      	ldrh	r4, [r7, #6]
 80044e2:	893a      	ldrh	r2, [r7, #8]
 80044e4:	8979      	ldrh	r1, [r7, #10]
 80044e6:	8cbb      	ldrh	r3, [r7, #36]	; 0x24
 80044e8:	9301      	str	r3, [sp, #4]
 80044ea:	8c3b      	ldrh	r3, [r7, #32]
 80044ec:	9300      	str	r3, [sp, #0]
 80044ee:	4623      	mov	r3, r4
 80044f0:	f7ff ff50 	bl	8004394 <ILI9341_Draw_Char>
        X += CHAR_WIDTH*Size;
 80044f4:	8c3b      	ldrh	r3, [r7, #32]
 80044f6:	461a      	mov	r2, r3
 80044f8:	0052      	lsls	r2, r2, #1
 80044fa:	4413      	add	r3, r2
 80044fc:	005b      	lsls	r3, r3, #1
 80044fe:	b29a      	uxth	r2, r3
 8004500:	897b      	ldrh	r3, [r7, #10]
 8004502:	4413      	add	r3, r2
 8004504:	817b      	strh	r3, [r7, #10]
    while (*Text) {
 8004506:	68fb      	ldr	r3, [r7, #12]
 8004508:	781b      	ldrb	r3, [r3, #0]
 800450a:	2b00      	cmp	r3, #0
 800450c:	d1e4      	bne.n	80044d8 <ILI9341_Draw_Text+0x1c>
    }
}
 800450e:	bf00      	nop
 8004510:	3714      	adds	r7, #20
 8004512:	46bd      	mov	sp, r7
 8004514:	bd90      	pop	{r4, r7, pc}
	...

08004518 <ILI9341_Draw_Image>:

/*Draws a full screen picture from flash. Image converted from RGB .jpeg/other to C array using online converter*/
//USING CONVERTER: http://www.digole.com/tools/PicturetoC_Hex_converter.php
//65K colour (2Bytes / Pixel)
void ILI9341_Draw_Image(const char* Image_Array, uint8_t Orientation)
{
 8004518:	b580      	push	{r7, lr}
 800451a:	f5ad 7d0c 	sub.w	sp, sp, #560	; 0x230
 800451e:	af00      	add	r7, sp, #0
 8004520:	1d3b      	adds	r3, r7, #4
 8004522:	6018      	str	r0, [r3, #0]
 8004524:	460a      	mov	r2, r1
 8004526:	1cfb      	adds	r3, r7, #3
 8004528:	701a      	strb	r2, [r3, #0]
	if(Orientation == SCREEN_HORIZONTAL_1)
 800452a:	1cfb      	adds	r3, r7, #3
 800452c:	781b      	ldrb	r3, [r3, #0]
 800452e:	2b01      	cmp	r3, #1
 8004530:	d159      	bne.n	80045e6 <ILI9341_Draw_Image+0xce>
	{
		ILI9341_Set_Rotation(SCREEN_HORIZONTAL_1);
 8004532:	2001      	movs	r0, #1
 8004534:	f000 fa4a 	bl	80049cc <ILI9341_Set_Rotation>
		ILI9341_Set_Address(0,0,ILI9341_SCREEN_WIDTH,ILI9341_SCREEN_HEIGHT);
 8004538:	23f0      	movs	r3, #240	; 0xf0
 800453a:	f44f 72a0 	mov.w	r2, #320	; 0x140
 800453e:	2100      	movs	r1, #0
 8004540:	2000      	movs	r0, #0
 8004542:	f000 f9d9 	bl	80048f8 <ILI9341_Set_Address>
			
		HAL_GPIO_WritePin(GPIOC, DC_Pin, GPIO_PIN_SET);	
 8004546:	2201      	movs	r2, #1
 8004548:	f44f 7100 	mov.w	r1, #512	; 0x200
 800454c:	48b5      	ldr	r0, [pc, #724]	; (8004824 <ILI9341_Draw_Image+0x30c>)
 800454e:	f7fd faaf 	bl	8001ab0 <HAL_GPIO_WritePin>
		HAL_GPIO_WritePin(GPIOC, CS_Pin, GPIO_PIN_RESET);
 8004552:	2200      	movs	r2, #0
 8004554:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004558:	48b2      	ldr	r0, [pc, #712]	; (8004824 <ILI9341_Draw_Image+0x30c>)
 800455a:	f7fd faa9 	bl	8001ab0 <HAL_GPIO_WritePin>
		
		unsigned char Temp_small_buffer[BURST_MAX_SIZE];
		uint32_t counter = 0;
 800455e:	2300      	movs	r3, #0
 8004560:	f8c7 322c 	str.w	r3, [r7, #556]	; 0x22c
		for(uint32_t i = 0; i < ILI9341_SCREEN_WIDTH*ILI9341_SCREEN_HEIGHT*2/BURST_MAX_SIZE; i++)
 8004564:	2300      	movs	r3, #0
 8004566:	f8c7 3228 	str.w	r3, [r7, #552]	; 0x228
 800456a:	e030      	b.n	80045ce <ILI9341_Draw_Image+0xb6>
		{			
				for(uint32_t k = 0; k< BURST_MAX_SIZE; k++)
 800456c:	2300      	movs	r3, #0
 800456e:	f8c7 3224 	str.w	r3, [r7, #548]	; 0x224
 8004572:	e014      	b.n	800459e <ILI9341_Draw_Image+0x86>
				{
					Temp_small_buffer[k]	= Image_Array[counter+k];		
 8004574:	f8d7 222c 	ldr.w	r2, [r7, #556]	; 0x22c
 8004578:	f8d7 3224 	ldr.w	r3, [r7, #548]	; 0x224
 800457c:	4413      	add	r3, r2
 800457e:	1d3a      	adds	r2, r7, #4
 8004580:	6812      	ldr	r2, [r2, #0]
 8004582:	4413      	add	r3, r2
 8004584:	7819      	ldrb	r1, [r3, #0]
 8004586:	f107 020c 	add.w	r2, r7, #12
 800458a:	f8d7 3224 	ldr.w	r3, [r7, #548]	; 0x224
 800458e:	4413      	add	r3, r2
 8004590:	460a      	mov	r2, r1
 8004592:	701a      	strb	r2, [r3, #0]
				for(uint32_t k = 0; k< BURST_MAX_SIZE; k++)
 8004594:	f8d7 3224 	ldr.w	r3, [r7, #548]	; 0x224
 8004598:	3301      	adds	r3, #1
 800459a:	f8c7 3224 	str.w	r3, [r7, #548]	; 0x224
 800459e:	f8d7 3224 	ldr.w	r3, [r7, #548]	; 0x224
 80045a2:	f5b3 7ffa 	cmp.w	r3, #500	; 0x1f4
 80045a6:	d3e5      	bcc.n	8004574 <ILI9341_Draw_Image+0x5c>
				}						
				HAL_SPI_Transmit(&hspi5, (unsigned char*)Temp_small_buffer, BURST_MAX_SIZE, 10);	
 80045a8:	f107 010c 	add.w	r1, r7, #12
 80045ac:	230a      	movs	r3, #10
 80045ae:	f44f 72fa 	mov.w	r2, #500	; 0x1f4
 80045b2:	489d      	ldr	r0, [pc, #628]	; (8004828 <ILI9341_Draw_Image+0x310>)
 80045b4:	f7fe fc7e 	bl	8002eb4 <HAL_SPI_Transmit>
				counter += BURST_MAX_SIZE;			
 80045b8:	f8d7 322c 	ldr.w	r3, [r7, #556]	; 0x22c
 80045bc:	f503 73fa 	add.w	r3, r3, #500	; 0x1f4
 80045c0:	f8c7 322c 	str.w	r3, [r7, #556]	; 0x22c
		for(uint32_t i = 0; i < ILI9341_SCREEN_WIDTH*ILI9341_SCREEN_HEIGHT*2/BURST_MAX_SIZE; i++)
 80045c4:	f8d7 3228 	ldr.w	r3, [r7, #552]	; 0x228
 80045c8:	3301      	adds	r3, #1
 80045ca:	f8c7 3228 	str.w	r3, [r7, #552]	; 0x228
 80045ce:	f8d7 3228 	ldr.w	r3, [r7, #552]	; 0x228
 80045d2:	f5b3 7f99 	cmp.w	r3, #306	; 0x132
 80045d6:	d9c9      	bls.n	800456c <ILI9341_Draw_Image+0x54>
		}
		HAL_GPIO_WritePin(GPIOC, CS_Pin, GPIO_PIN_SET);
 80045d8:	2201      	movs	r2, #1
 80045da:	f44f 7180 	mov.w	r1, #256	; 0x100
 80045de:	4891      	ldr	r0, [pc, #580]	; (8004824 <ILI9341_Draw_Image+0x30c>)
 80045e0:	f7fd fa66 	bl	8001ab0 <HAL_GPIO_WritePin>
				HAL_SPI_Transmit(&hspi5, (unsigned char*)Temp_small_buffer, BURST_MAX_SIZE, 10);	
				counter += BURST_MAX_SIZE;			
		}
		HAL_GPIO_WritePin(GPIOC, CS_Pin, GPIO_PIN_SET);
	}
}
 80045e4:	e118      	b.n	8004818 <ILI9341_Draw_Image+0x300>
	else if(Orientation == SCREEN_HORIZONTAL_2)
 80045e6:	1cfb      	adds	r3, r7, #3
 80045e8:	781b      	ldrb	r3, [r3, #0]
 80045ea:	2b03      	cmp	r3, #3
 80045ec:	d159      	bne.n	80046a2 <ILI9341_Draw_Image+0x18a>
		ILI9341_Set_Rotation(SCREEN_HORIZONTAL_2);
 80045ee:	2003      	movs	r0, #3
 80045f0:	f000 f9ec 	bl	80049cc <ILI9341_Set_Rotation>
		ILI9341_Set_Address(0,0,ILI9341_SCREEN_WIDTH,ILI9341_SCREEN_HEIGHT);
 80045f4:	23f0      	movs	r3, #240	; 0xf0
 80045f6:	f44f 72a0 	mov.w	r2, #320	; 0x140
 80045fa:	2100      	movs	r1, #0
 80045fc:	2000      	movs	r0, #0
 80045fe:	f000 f97b 	bl	80048f8 <ILI9341_Set_Address>
		HAL_GPIO_WritePin(GPIOC, DC_Pin, GPIO_PIN_SET);	
 8004602:	2201      	movs	r2, #1
 8004604:	f44f 7100 	mov.w	r1, #512	; 0x200
 8004608:	4886      	ldr	r0, [pc, #536]	; (8004824 <ILI9341_Draw_Image+0x30c>)
 800460a:	f7fd fa51 	bl	8001ab0 <HAL_GPIO_WritePin>
		HAL_GPIO_WritePin(GPIOC, CS_Pin, GPIO_PIN_RESET);
 800460e:	2200      	movs	r2, #0
 8004610:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004614:	4883      	ldr	r0, [pc, #524]	; (8004824 <ILI9341_Draw_Image+0x30c>)
 8004616:	f7fd fa4b 	bl	8001ab0 <HAL_GPIO_WritePin>
		uint32_t counter = 0;
 800461a:	2300      	movs	r3, #0
 800461c:	f8c7 3220 	str.w	r3, [r7, #544]	; 0x220
		for(uint32_t i = 0; i < ILI9341_SCREEN_WIDTH*ILI9341_SCREEN_HEIGHT*2/BURST_MAX_SIZE; i++)
 8004620:	2300      	movs	r3, #0
 8004622:	f8c7 321c 	str.w	r3, [r7, #540]	; 0x21c
 8004626:	e030      	b.n	800468a <ILI9341_Draw_Image+0x172>
				for(uint32_t k = 0; k< BURST_MAX_SIZE; k++)
 8004628:	2300      	movs	r3, #0
 800462a:	f8c7 3218 	str.w	r3, [r7, #536]	; 0x218
 800462e:	e014      	b.n	800465a <ILI9341_Draw_Image+0x142>
					Temp_small_buffer[k]	= Image_Array[counter+k];		
 8004630:	f8d7 2220 	ldr.w	r2, [r7, #544]	; 0x220
 8004634:	f8d7 3218 	ldr.w	r3, [r7, #536]	; 0x218
 8004638:	4413      	add	r3, r2
 800463a:	1d3a      	adds	r2, r7, #4
 800463c:	6812      	ldr	r2, [r2, #0]
 800463e:	4413      	add	r3, r2
 8004640:	7819      	ldrb	r1, [r3, #0]
 8004642:	f107 020c 	add.w	r2, r7, #12
 8004646:	f8d7 3218 	ldr.w	r3, [r7, #536]	; 0x218
 800464a:	4413      	add	r3, r2
 800464c:	460a      	mov	r2, r1
 800464e:	701a      	strb	r2, [r3, #0]
				for(uint32_t k = 0; k< BURST_MAX_SIZE; k++)
 8004650:	f8d7 3218 	ldr.w	r3, [r7, #536]	; 0x218
 8004654:	3301      	adds	r3, #1
 8004656:	f8c7 3218 	str.w	r3, [r7, #536]	; 0x218
 800465a:	f8d7 3218 	ldr.w	r3, [r7, #536]	; 0x218
 800465e:	f5b3 7ffa 	cmp.w	r3, #500	; 0x1f4
 8004662:	d3e5      	bcc.n	8004630 <ILI9341_Draw_Image+0x118>
				HAL_SPI_Transmit(&hspi5, (unsigned char*)Temp_small_buffer, BURST_MAX_SIZE, 10);	
 8004664:	f107 010c 	add.w	r1, r7, #12
 8004668:	230a      	movs	r3, #10
 800466a:	f44f 72fa 	mov.w	r2, #500	; 0x1f4
 800466e:	486e      	ldr	r0, [pc, #440]	; (8004828 <ILI9341_Draw_Image+0x310>)
 8004670:	f7fe fc20 	bl	8002eb4 <HAL_SPI_Transmit>
				counter += BURST_MAX_SIZE;			
 8004674:	f8d7 3220 	ldr.w	r3, [r7, #544]	; 0x220
 8004678:	f503 73fa 	add.w	r3, r3, #500	; 0x1f4
 800467c:	f8c7 3220 	str.w	r3, [r7, #544]	; 0x220
		for(uint32_t i = 0; i < ILI9341_SCREEN_WIDTH*ILI9341_SCREEN_HEIGHT*2/BURST_MAX_SIZE; i++)
 8004680:	f8d7 321c 	ldr.w	r3, [r7, #540]	; 0x21c
 8004684:	3301      	adds	r3, #1
 8004686:	f8c7 321c 	str.w	r3, [r7, #540]	; 0x21c
 800468a:	f8d7 321c 	ldr.w	r3, [r7, #540]	; 0x21c
 800468e:	f5b3 7f99 	cmp.w	r3, #306	; 0x132
 8004692:	d9c9      	bls.n	8004628 <ILI9341_Draw_Image+0x110>
		HAL_GPIO_WritePin(GPIOC, CS_Pin, GPIO_PIN_SET);
 8004694:	2201      	movs	r2, #1
 8004696:	f44f 7180 	mov.w	r1, #256	; 0x100
 800469a:	4862      	ldr	r0, [pc, #392]	; (8004824 <ILI9341_Draw_Image+0x30c>)
 800469c:	f7fd fa08 	bl	8001ab0 <HAL_GPIO_WritePin>
}
 80046a0:	e0ba      	b.n	8004818 <ILI9341_Draw_Image+0x300>
	else if(Orientation == SCREEN_VERTICAL_2)
 80046a2:	1cfb      	adds	r3, r7, #3
 80046a4:	781b      	ldrb	r3, [r3, #0]
 80046a6:	2b02      	cmp	r3, #2
 80046a8:	d159      	bne.n	800475e <ILI9341_Draw_Image+0x246>
		ILI9341_Set_Rotation(SCREEN_VERTICAL_2);
 80046aa:	2002      	movs	r0, #2
 80046ac:	f000 f98e 	bl	80049cc <ILI9341_Set_Rotation>
		ILI9341_Set_Address(0,0,ILI9341_SCREEN_HEIGHT,ILI9341_SCREEN_WIDTH);
 80046b0:	f44f 73a0 	mov.w	r3, #320	; 0x140
 80046b4:	22f0      	movs	r2, #240	; 0xf0
 80046b6:	2100      	movs	r1, #0
 80046b8:	2000      	movs	r0, #0
 80046ba:	f000 f91d 	bl	80048f8 <ILI9341_Set_Address>
		HAL_GPIO_WritePin(GPIOC, DC_Pin, GPIO_PIN_SET);	
 80046be:	2201      	movs	r2, #1
 80046c0:	f44f 7100 	mov.w	r1, #512	; 0x200
 80046c4:	4857      	ldr	r0, [pc, #348]	; (8004824 <ILI9341_Draw_Image+0x30c>)
 80046c6:	f7fd f9f3 	bl	8001ab0 <HAL_GPIO_WritePin>
		HAL_GPIO_WritePin(GPIOC, CS_Pin, GPIO_PIN_RESET);
 80046ca:	2200      	movs	r2, #0
 80046cc:	f44f 7180 	mov.w	r1, #256	; 0x100
 80046d0:	4854      	ldr	r0, [pc, #336]	; (8004824 <ILI9341_Draw_Image+0x30c>)
 80046d2:	f7fd f9ed 	bl	8001ab0 <HAL_GPIO_WritePin>
		uint32_t counter = 0;
 80046d6:	2300      	movs	r3, #0
 80046d8:	f8c7 3214 	str.w	r3, [r7, #532]	; 0x214
		for(uint32_t i = 0; i < ILI9341_SCREEN_WIDTH*ILI9341_SCREEN_HEIGHT*2/BURST_MAX_SIZE; i++)
 80046dc:	2300      	movs	r3, #0
 80046de:	f8c7 3210 	str.w	r3, [r7, #528]	; 0x210
 80046e2:	e030      	b.n	8004746 <ILI9341_Draw_Image+0x22e>
				for(uint32_t k = 0; k< BURST_MAX_SIZE; k++)
 80046e4:	2300      	movs	r3, #0
 80046e6:	f8c7 320c 	str.w	r3, [r7, #524]	; 0x20c
 80046ea:	e014      	b.n	8004716 <ILI9341_Draw_Image+0x1fe>
					Temp_small_buffer[k]	= Image_Array[counter+k];		
 80046ec:	f8d7 2214 	ldr.w	r2, [r7, #532]	; 0x214
 80046f0:	f8d7 320c 	ldr.w	r3, [r7, #524]	; 0x20c
 80046f4:	4413      	add	r3, r2
 80046f6:	1d3a      	adds	r2, r7, #4
 80046f8:	6812      	ldr	r2, [r2, #0]
 80046fa:	4413      	add	r3, r2
 80046fc:	7819      	ldrb	r1, [r3, #0]
 80046fe:	f107 020c 	add.w	r2, r7, #12
 8004702:	f8d7 320c 	ldr.w	r3, [r7, #524]	; 0x20c
 8004706:	4413      	add	r3, r2
 8004708:	460a      	mov	r2, r1
 800470a:	701a      	strb	r2, [r3, #0]
				for(uint32_t k = 0; k< BURST_MAX_SIZE; k++)
 800470c:	f8d7 320c 	ldr.w	r3, [r7, #524]	; 0x20c
 8004710:	3301      	adds	r3, #1
 8004712:	f8c7 320c 	str.w	r3, [r7, #524]	; 0x20c
 8004716:	f8d7 320c 	ldr.w	r3, [r7, #524]	; 0x20c
 800471a:	f5b3 7ffa 	cmp.w	r3, #500	; 0x1f4
 800471e:	d3e5      	bcc.n	80046ec <ILI9341_Draw_Image+0x1d4>
				HAL_SPI_Transmit(&hspi5, (unsigned char*)Temp_small_buffer, BURST_MAX_SIZE, 10);	
 8004720:	f107 010c 	add.w	r1, r7, #12
 8004724:	230a      	movs	r3, #10
 8004726:	f44f 72fa 	mov.w	r2, #500	; 0x1f4
 800472a:	483f      	ldr	r0, [pc, #252]	; (8004828 <ILI9341_Draw_Image+0x310>)
 800472c:	f7fe fbc2 	bl	8002eb4 <HAL_SPI_Transmit>
				counter += BURST_MAX_SIZE;			
 8004730:	f8d7 3214 	ldr.w	r3, [r7, #532]	; 0x214
 8004734:	f503 73fa 	add.w	r3, r3, #500	; 0x1f4
 8004738:	f8c7 3214 	str.w	r3, [r7, #532]	; 0x214
		for(uint32_t i = 0; i < ILI9341_SCREEN_WIDTH*ILI9341_SCREEN_HEIGHT*2/BURST_MAX_SIZE; i++)
 800473c:	f8d7 3210 	ldr.w	r3, [r7, #528]	; 0x210
 8004740:	3301      	adds	r3, #1
 8004742:	f8c7 3210 	str.w	r3, [r7, #528]	; 0x210
 8004746:	f8d7 3210 	ldr.w	r3, [r7, #528]	; 0x210
 800474a:	f5b3 7f99 	cmp.w	r3, #306	; 0x132
 800474e:	d9c9      	bls.n	80046e4 <ILI9341_Draw_Image+0x1cc>
		HAL_GPIO_WritePin(GPIOC, CS_Pin, GPIO_PIN_SET);
 8004750:	2201      	movs	r2, #1
 8004752:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004756:	4833      	ldr	r0, [pc, #204]	; (8004824 <ILI9341_Draw_Image+0x30c>)
 8004758:	f7fd f9aa 	bl	8001ab0 <HAL_GPIO_WritePin>
}
 800475c:	e05c      	b.n	8004818 <ILI9341_Draw_Image+0x300>
	else if(Orientation == SCREEN_VERTICAL_1)
 800475e:	1cfb      	adds	r3, r7, #3
 8004760:	781b      	ldrb	r3, [r3, #0]
 8004762:	2b00      	cmp	r3, #0
 8004764:	d158      	bne.n	8004818 <ILI9341_Draw_Image+0x300>
		ILI9341_Set_Rotation(SCREEN_VERTICAL_1);
 8004766:	2000      	movs	r0, #0
 8004768:	f000 f930 	bl	80049cc <ILI9341_Set_Rotation>
		ILI9341_Set_Address(0,0,ILI9341_SCREEN_HEIGHT,ILI9341_SCREEN_WIDTH);
 800476c:	f44f 73a0 	mov.w	r3, #320	; 0x140
 8004770:	22f0      	movs	r2, #240	; 0xf0
 8004772:	2100      	movs	r1, #0
 8004774:	2000      	movs	r0, #0
 8004776:	f000 f8bf 	bl	80048f8 <ILI9341_Set_Address>
		HAL_GPIO_WritePin(GPIOC, DC_Pin, GPIO_PIN_SET);	
 800477a:	2201      	movs	r2, #1
 800477c:	f44f 7100 	mov.w	r1, #512	; 0x200
 8004780:	4828      	ldr	r0, [pc, #160]	; (8004824 <ILI9341_Draw_Image+0x30c>)
 8004782:	f7fd f995 	bl	8001ab0 <HAL_GPIO_WritePin>
		HAL_GPIO_WritePin(GPIOC, CS_Pin, GPIO_PIN_RESET);
 8004786:	2200      	movs	r2, #0
 8004788:	f44f 7180 	mov.w	r1, #256	; 0x100
 800478c:	4825      	ldr	r0, [pc, #148]	; (8004824 <ILI9341_Draw_Image+0x30c>)
 800478e:	f7fd f98f 	bl	8001ab0 <HAL_GPIO_WritePin>
		uint32_t counter = 0;
 8004792:	2300      	movs	r3, #0
 8004794:	f8c7 3208 	str.w	r3, [r7, #520]	; 0x208
		for(uint32_t i = 0; i < ILI9341_SCREEN_WIDTH*ILI9341_SCREEN_HEIGHT*2/BURST_MAX_SIZE; i++)
 8004798:	2300      	movs	r3, #0
 800479a:	f8c7 3204 	str.w	r3, [r7, #516]	; 0x204
 800479e:	e030      	b.n	8004802 <ILI9341_Draw_Image+0x2ea>
				for(uint32_t k = 0; k< BURST_MAX_SIZE; k++)
 80047a0:	2300      	movs	r3, #0
 80047a2:	f8c7 3200 	str.w	r3, [r7, #512]	; 0x200
 80047a6:	e014      	b.n	80047d2 <ILI9341_Draw_Image+0x2ba>
					Temp_small_buffer[k]	= Image_Array[counter+k];		
 80047a8:	f8d7 2208 	ldr.w	r2, [r7, #520]	; 0x208
 80047ac:	f8d7 3200 	ldr.w	r3, [r7, #512]	; 0x200
 80047b0:	4413      	add	r3, r2
 80047b2:	1d3a      	adds	r2, r7, #4
 80047b4:	6812      	ldr	r2, [r2, #0]
 80047b6:	4413      	add	r3, r2
 80047b8:	7819      	ldrb	r1, [r3, #0]
 80047ba:	f107 020c 	add.w	r2, r7, #12
 80047be:	f8d7 3200 	ldr.w	r3, [r7, #512]	; 0x200
 80047c2:	4413      	add	r3, r2
 80047c4:	460a      	mov	r2, r1
 80047c6:	701a      	strb	r2, [r3, #0]
				for(uint32_t k = 0; k< BURST_MAX_SIZE; k++)
 80047c8:	f8d7 3200 	ldr.w	r3, [r7, #512]	; 0x200
 80047cc:	3301      	adds	r3, #1
 80047ce:	f8c7 3200 	str.w	r3, [r7, #512]	; 0x200
 80047d2:	f8d7 3200 	ldr.w	r3, [r7, #512]	; 0x200
 80047d6:	f5b3 7ffa 	cmp.w	r3, #500	; 0x1f4
 80047da:	d3e5      	bcc.n	80047a8 <ILI9341_Draw_Image+0x290>
				HAL_SPI_Transmit(&hspi5, (unsigned char*)Temp_small_buffer, BURST_MAX_SIZE, 10);	
 80047dc:	f107 010c 	add.w	r1, r7, #12
 80047e0:	230a      	movs	r3, #10
 80047e2:	f44f 72fa 	mov.w	r2, #500	; 0x1f4
 80047e6:	4810      	ldr	r0, [pc, #64]	; (8004828 <ILI9341_Draw_Image+0x310>)
 80047e8:	f7fe fb64 	bl	8002eb4 <HAL_SPI_Transmit>
				counter += BURST_MAX_SIZE;			
 80047ec:	f8d7 3208 	ldr.w	r3, [r7, #520]	; 0x208
 80047f0:	f503 73fa 	add.w	r3, r3, #500	; 0x1f4
 80047f4:	f8c7 3208 	str.w	r3, [r7, #520]	; 0x208
		for(uint32_t i = 0; i < ILI9341_SCREEN_WIDTH*ILI9341_SCREEN_HEIGHT*2/BURST_MAX_SIZE; i++)
 80047f8:	f8d7 3204 	ldr.w	r3, [r7, #516]	; 0x204
 80047fc:	3301      	adds	r3, #1
 80047fe:	f8c7 3204 	str.w	r3, [r7, #516]	; 0x204
 8004802:	f8d7 3204 	ldr.w	r3, [r7, #516]	; 0x204
 8004806:	f5b3 7f99 	cmp.w	r3, #306	; 0x132
 800480a:	d9c9      	bls.n	80047a0 <ILI9341_Draw_Image+0x288>
		HAL_GPIO_WritePin(GPIOC, CS_Pin, GPIO_PIN_SET);
 800480c:	2201      	movs	r2, #1
 800480e:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004812:	4804      	ldr	r0, [pc, #16]	; (8004824 <ILI9341_Draw_Image+0x30c>)
 8004814:	f7fd f94c 	bl	8001ab0 <HAL_GPIO_WritePin>
}
 8004818:	bf00      	nop
 800481a:	f507 770c 	add.w	r7, r7, #560	; 0x230
 800481e:	46bd      	mov	sp, r7
 8004820:	bd80      	pop	{r7, pc}
 8004822:	bf00      	nop
 8004824:	40020800 	.word	0x40020800
 8004828:	20025a2c 	.word	0x20025a2c

0800482c <ILI9341_SPI_Init>:
volatile uint16_t LCD_HEIGHT = ILI9341_SCREEN_HEIGHT;
volatile uint16_t LCD_WIDTH	 = ILI9341_SCREEN_WIDTH;

/* Initialize SPI */
void ILI9341_SPI_Init(void)
{
 800482c:	b580      	push	{r7, lr}
 800482e:	af00      	add	r7, sp, #0
MX_SPI5_Init();																							//SPI INIT
 8004830:	f7fc fbfc 	bl	800102c <MX_SPI5_Init>
MX_GPIO_Init();																							//GPIO INIT
 8004834:	f7fb fedc 	bl	80005f0 <MX_GPIO_Init>
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_RESET);	//CS OFF
 8004838:	2200      	movs	r2, #0
 800483a:	f44f 7180 	mov.w	r1, #256	; 0x100
 800483e:	4802      	ldr	r0, [pc, #8]	; (8004848 <ILI9341_SPI_Init+0x1c>)
 8004840:	f7fd f936 	bl	8001ab0 <HAL_GPIO_WritePin>
}
 8004844:	bf00      	nop
 8004846:	bd80      	pop	{r7, pc}
 8004848:	40020800 	.word	0x40020800

0800484c <ILI9341_SPI_Send>:

/*Send data (char) to LCD*/
void ILI9341_SPI_Send(unsigned char SPI_Data)
{
 800484c:	b580      	push	{r7, lr}
 800484e:	b082      	sub	sp, #8
 8004850:	af00      	add	r7, sp, #0
 8004852:	4603      	mov	r3, r0
 8004854:	71fb      	strb	r3, [r7, #7]
HAL_SPI_Transmit(HSPI_INSTANCE, &SPI_Data, 1, 1);
 8004856:	1df9      	adds	r1, r7, #7
 8004858:	2301      	movs	r3, #1
 800485a:	2201      	movs	r2, #1
 800485c:	4803      	ldr	r0, [pc, #12]	; (800486c <ILI9341_SPI_Send+0x20>)
 800485e:	f7fe fb29 	bl	8002eb4 <HAL_SPI_Transmit>
}
 8004862:	bf00      	nop
 8004864:	3708      	adds	r7, #8
 8004866:	46bd      	mov	sp, r7
 8004868:	bd80      	pop	{r7, pc}
 800486a:	bf00      	nop
 800486c:	20025a2c 	.word	0x20025a2c

08004870 <ILI9341_Write_Command>:

/* Send command (char) to LCD */
void ILI9341_Write_Command(uint8_t Command)
{
 8004870:	b580      	push	{r7, lr}
 8004872:	b082      	sub	sp, #8
 8004874:	af00      	add	r7, sp, #0
 8004876:	4603      	mov	r3, r0
 8004878:	71fb      	strb	r3, [r7, #7]
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_RESET);
 800487a:	2200      	movs	r2, #0
 800487c:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004880:	480b      	ldr	r0, [pc, #44]	; (80048b0 <ILI9341_Write_Command+0x40>)
 8004882:	f7fd f915 	bl	8001ab0 <HAL_GPIO_WritePin>
HAL_GPIO_WritePin(LCD_DC_PORT, LCD_DC_PIN, GPIO_PIN_RESET);	
 8004886:	2200      	movs	r2, #0
 8004888:	f44f 7100 	mov.w	r1, #512	; 0x200
 800488c:	4808      	ldr	r0, [pc, #32]	; (80048b0 <ILI9341_Write_Command+0x40>)
 800488e:	f7fd f90f 	bl	8001ab0 <HAL_GPIO_WritePin>
ILI9341_SPI_Send(Command);
 8004892:	79fb      	ldrb	r3, [r7, #7]
 8004894:	4618      	mov	r0, r3
 8004896:	f7ff ffd9 	bl	800484c <ILI9341_SPI_Send>
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_SET);		
 800489a:	2201      	movs	r2, #1
 800489c:	f44f 7180 	mov.w	r1, #256	; 0x100
 80048a0:	4803      	ldr	r0, [pc, #12]	; (80048b0 <ILI9341_Write_Command+0x40>)
 80048a2:	f7fd f905 	bl	8001ab0 <HAL_GPIO_WritePin>
}
 80048a6:	bf00      	nop
 80048a8:	3708      	adds	r7, #8
 80048aa:	46bd      	mov	sp, r7
 80048ac:	bd80      	pop	{r7, pc}
 80048ae:	bf00      	nop
 80048b0:	40020800 	.word	0x40020800

080048b4 <ILI9341_Write_Data>:

/* Send Data (char) to LCD */
void ILI9341_Write_Data(uint8_t Data)
{
 80048b4:	b580      	push	{r7, lr}
 80048b6:	b082      	sub	sp, #8
 80048b8:	af00      	add	r7, sp, #0
 80048ba:	4603      	mov	r3, r0
 80048bc:	71fb      	strb	r3, [r7, #7]
HAL_GPIO_WritePin(LCD_DC_PORT, LCD_DC_PIN, GPIO_PIN_SET);	
 80048be:	2201      	movs	r2, #1
 80048c0:	f44f 7100 	mov.w	r1, #512	; 0x200
 80048c4:	480b      	ldr	r0, [pc, #44]	; (80048f4 <ILI9341_Write_Data+0x40>)
 80048c6:	f7fd f8f3 	bl	8001ab0 <HAL_GPIO_WritePin>
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_RESET);
 80048ca:	2200      	movs	r2, #0
 80048cc:	f44f 7180 	mov.w	r1, #256	; 0x100
 80048d0:	4808      	ldr	r0, [pc, #32]	; (80048f4 <ILI9341_Write_Data+0x40>)
 80048d2:	f7fd f8ed 	bl	8001ab0 <HAL_GPIO_WritePin>
ILI9341_SPI_Send(Data);	
 80048d6:	79fb      	ldrb	r3, [r7, #7]
 80048d8:	4618      	mov	r0, r3
 80048da:	f7ff ffb7 	bl	800484c <ILI9341_SPI_Send>
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_SET);
 80048de:	2201      	movs	r2, #1
 80048e0:	f44f 7180 	mov.w	r1, #256	; 0x100
 80048e4:	4803      	ldr	r0, [pc, #12]	; (80048f4 <ILI9341_Write_Data+0x40>)
 80048e6:	f7fd f8e3 	bl	8001ab0 <HAL_GPIO_WritePin>
}
 80048ea:	bf00      	nop
 80048ec:	3708      	adds	r7, #8
 80048ee:	46bd      	mov	sp, r7
 80048f0:	bd80      	pop	{r7, pc}
 80048f2:	bf00      	nop
 80048f4:	40020800 	.word	0x40020800

080048f8 <ILI9341_Set_Address>:

/* Set Address - Location block - to draw into */
void ILI9341_Set_Address(uint16_t X1, uint16_t Y1, uint16_t X2, uint16_t Y2)
{
 80048f8:	b590      	push	{r4, r7, lr}
 80048fa:	b083      	sub	sp, #12
 80048fc:	af00      	add	r7, sp, #0
 80048fe:	4604      	mov	r4, r0
 8004900:	4608      	mov	r0, r1
 8004902:	4611      	mov	r1, r2
 8004904:	461a      	mov	r2, r3
 8004906:	4623      	mov	r3, r4
 8004908:	80fb      	strh	r3, [r7, #6]
 800490a:	4603      	mov	r3, r0
 800490c:	80bb      	strh	r3, [r7, #4]
 800490e:	460b      	mov	r3, r1
 8004910:	807b      	strh	r3, [r7, #2]
 8004912:	4613      	mov	r3, r2
 8004914:	803b      	strh	r3, [r7, #0]
ILI9341_Write_Command(0x2A);
 8004916:	202a      	movs	r0, #42	; 0x2a
 8004918:	f7ff ffaa 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(X1>>8);
 800491c:	88fb      	ldrh	r3, [r7, #6]
 800491e:	0a1b      	lsrs	r3, r3, #8
 8004920:	b29b      	uxth	r3, r3
 8004922:	b2db      	uxtb	r3, r3
 8004924:	4618      	mov	r0, r3
 8004926:	f7ff ffc5 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(X1);
 800492a:	88fb      	ldrh	r3, [r7, #6]
 800492c:	b2db      	uxtb	r3, r3
 800492e:	4618      	mov	r0, r3
 8004930:	f7ff ffc0 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(X2>>8);
 8004934:	887b      	ldrh	r3, [r7, #2]
 8004936:	0a1b      	lsrs	r3, r3, #8
 8004938:	b29b      	uxth	r3, r3
 800493a:	b2db      	uxtb	r3, r3
 800493c:	4618      	mov	r0, r3
 800493e:	f7ff ffb9 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(X2);
 8004942:	887b      	ldrh	r3, [r7, #2]
 8004944:	b2db      	uxtb	r3, r3
 8004946:	4618      	mov	r0, r3
 8004948:	f7ff ffb4 	bl	80048b4 <ILI9341_Write_Data>

ILI9341_Write_Command(0x2B);
 800494c:	202b      	movs	r0, #43	; 0x2b
 800494e:	f7ff ff8f 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(Y1>>8);
 8004952:	88bb      	ldrh	r3, [r7, #4]
 8004954:	0a1b      	lsrs	r3, r3, #8
 8004956:	b29b      	uxth	r3, r3
 8004958:	b2db      	uxtb	r3, r3
 800495a:	4618      	mov	r0, r3
 800495c:	f7ff ffaa 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(Y1);
 8004960:	88bb      	ldrh	r3, [r7, #4]
 8004962:	b2db      	uxtb	r3, r3
 8004964:	4618      	mov	r0, r3
 8004966:	f7ff ffa5 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(Y2>>8);
 800496a:	883b      	ldrh	r3, [r7, #0]
 800496c:	0a1b      	lsrs	r3, r3, #8
 800496e:	b29b      	uxth	r3, r3
 8004970:	b2db      	uxtb	r3, r3
 8004972:	4618      	mov	r0, r3
 8004974:	f7ff ff9e 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(Y2);
 8004978:	883b      	ldrh	r3, [r7, #0]
 800497a:	b2db      	uxtb	r3, r3
 800497c:	4618      	mov	r0, r3
 800497e:	f7ff ff99 	bl	80048b4 <ILI9341_Write_Data>

ILI9341_Write_Command(0x2C);
 8004982:	202c      	movs	r0, #44	; 0x2c
 8004984:	f7ff ff74 	bl	8004870 <ILI9341_Write_Command>
}
 8004988:	bf00      	nop
 800498a:	370c      	adds	r7, #12
 800498c:	46bd      	mov	sp, r7
 800498e:	bd90      	pop	{r4, r7, pc}

08004990 <ILI9341_Reset>:

/*HARDWARE RESET*/
void ILI9341_Reset(void)
{
 8004990:	b580      	push	{r7, lr}
 8004992:	af00      	add	r7, sp, #0
HAL_GPIO_WritePin(LCD_RST_PORT, LCD_RST_PIN, GPIO_PIN_SET);
 8004994:	2201      	movs	r2, #1
 8004996:	f44f 6180 	mov.w	r1, #1024	; 0x400
 800499a:	480b      	ldr	r0, [pc, #44]	; (80049c8 <ILI9341_Reset+0x38>)
 800499c:	f7fd f888 	bl	8001ab0 <HAL_GPIO_WritePin>
HAL_Delay(200);
 80049a0:	20c8      	movs	r0, #200	; 0xc8
 80049a2:	f7fc fdbb 	bl	800151c <HAL_Delay>
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_RESET);
 80049a6:	2200      	movs	r2, #0
 80049a8:	f44f 7180 	mov.w	r1, #256	; 0x100
 80049ac:	4806      	ldr	r0, [pc, #24]	; (80049c8 <ILI9341_Reset+0x38>)
 80049ae:	f7fd f87f 	bl	8001ab0 <HAL_GPIO_WritePin>
HAL_Delay(200);
 80049b2:	20c8      	movs	r0, #200	; 0xc8
 80049b4:	f7fc fdb2 	bl	800151c <HAL_Delay>
HAL_GPIO_WritePin(LCD_RST_PORT, LCD_RST_PIN, GPIO_PIN_SET);	
 80049b8:	2201      	movs	r2, #1
 80049ba:	f44f 6180 	mov.w	r1, #1024	; 0x400
 80049be:	4802      	ldr	r0, [pc, #8]	; (80049c8 <ILI9341_Reset+0x38>)
 80049c0:	f7fd f876 	bl	8001ab0 <HAL_GPIO_WritePin>
}
 80049c4:	bf00      	nop
 80049c6:	bd80      	pop	{r7, pc}
 80049c8:	40020800 	.word	0x40020800

080049cc <ILI9341_Set_Rotation>:

/*Ser rotation of the screen - changes x0 and y0*/
void ILI9341_Set_Rotation(uint8_t Rotation) 
{
 80049cc:	b580      	push	{r7, lr}
 80049ce:	b084      	sub	sp, #16
 80049d0:	af00      	add	r7, sp, #0
 80049d2:	4603      	mov	r3, r0
 80049d4:	71fb      	strb	r3, [r7, #7]
	
uint8_t screen_rotation = Rotation;
 80049d6:	79fb      	ldrb	r3, [r7, #7]
 80049d8:	73fb      	strb	r3, [r7, #15]

ILI9341_Write_Command(0x36);
 80049da:	2036      	movs	r0, #54	; 0x36
 80049dc:	f7ff ff48 	bl	8004870 <ILI9341_Write_Command>
HAL_Delay(1);
 80049e0:	2001      	movs	r0, #1
 80049e2:	f7fc fd9b 	bl	800151c <HAL_Delay>
	
switch(screen_rotation) 
 80049e6:	7bfb      	ldrb	r3, [r7, #15]
 80049e8:	2b03      	cmp	r3, #3
 80049ea:	d837      	bhi.n	8004a5c <ILI9341_Set_Rotation+0x90>
 80049ec:	a201      	add	r2, pc, #4	; (adr r2, 80049f4 <ILI9341_Set_Rotation+0x28>)
 80049ee:	f852 f023 	ldr.w	pc, [r2, r3, lsl #2]
 80049f2:	bf00      	nop
 80049f4:	08004a05 	.word	0x08004a05
 80049f8:	08004a1b 	.word	0x08004a1b
 80049fc:	08004a31 	.word	0x08004a31
 8004a00:	08004a47 	.word	0x08004a47
	{
		case SCREEN_VERTICAL_1:
			ILI9341_Write_Data(0x40|0x08);
 8004a04:	2048      	movs	r0, #72	; 0x48
 8004a06:	f7ff ff55 	bl	80048b4 <ILI9341_Write_Data>
			LCD_WIDTH = 240;
 8004a0a:	4b17      	ldr	r3, [pc, #92]	; (8004a68 <ILI9341_Set_Rotation+0x9c>)
 8004a0c:	22f0      	movs	r2, #240	; 0xf0
 8004a0e:	801a      	strh	r2, [r3, #0]
			LCD_HEIGHT = 320;
 8004a10:	4b16      	ldr	r3, [pc, #88]	; (8004a6c <ILI9341_Set_Rotation+0xa0>)
 8004a12:	f44f 72a0 	mov.w	r2, #320	; 0x140
 8004a16:	801a      	strh	r2, [r3, #0]
			break;
 8004a18:	e021      	b.n	8004a5e <ILI9341_Set_Rotation+0x92>
		case SCREEN_HORIZONTAL_1:
			ILI9341_Write_Data(0x20|0x08);
 8004a1a:	2028      	movs	r0, #40	; 0x28
 8004a1c:	f7ff ff4a 	bl	80048b4 <ILI9341_Write_Data>
			LCD_WIDTH  = 320;
 8004a20:	4b11      	ldr	r3, [pc, #68]	; (8004a68 <ILI9341_Set_Rotation+0x9c>)
 8004a22:	f44f 72a0 	mov.w	r2, #320	; 0x140
 8004a26:	801a      	strh	r2, [r3, #0]
			LCD_HEIGHT = 240;
 8004a28:	4b10      	ldr	r3, [pc, #64]	; (8004a6c <ILI9341_Set_Rotation+0xa0>)
 8004a2a:	22f0      	movs	r2, #240	; 0xf0
 8004a2c:	801a      	strh	r2, [r3, #0]
			break;
 8004a2e:	e016      	b.n	8004a5e <ILI9341_Set_Rotation+0x92>
		case SCREEN_VERTICAL_2:
			ILI9341_Write_Data(0x80|0x08);
 8004a30:	2088      	movs	r0, #136	; 0x88
 8004a32:	f7ff ff3f 	bl	80048b4 <ILI9341_Write_Data>
			LCD_WIDTH  = 240;
 8004a36:	4b0c      	ldr	r3, [pc, #48]	; (8004a68 <ILI9341_Set_Rotation+0x9c>)
 8004a38:	22f0      	movs	r2, #240	; 0xf0
 8004a3a:	801a      	strh	r2, [r3, #0]
			LCD_HEIGHT = 320;
 8004a3c:	4b0b      	ldr	r3, [pc, #44]	; (8004a6c <ILI9341_Set_Rotation+0xa0>)
 8004a3e:	f44f 72a0 	mov.w	r2, #320	; 0x140
 8004a42:	801a      	strh	r2, [r3, #0]
			break;
 8004a44:	e00b      	b.n	8004a5e <ILI9341_Set_Rotation+0x92>
		case SCREEN_HORIZONTAL_2:
			ILI9341_Write_Data(0x40|0x80|0x20|0x08);
 8004a46:	20e8      	movs	r0, #232	; 0xe8
 8004a48:	f7ff ff34 	bl	80048b4 <ILI9341_Write_Data>
			LCD_WIDTH  = 320;
 8004a4c:	4b06      	ldr	r3, [pc, #24]	; (8004a68 <ILI9341_Set_Rotation+0x9c>)
 8004a4e:	f44f 72a0 	mov.w	r2, #320	; 0x140
 8004a52:	801a      	strh	r2, [r3, #0]
			LCD_HEIGHT = 240;
 8004a54:	4b05      	ldr	r3, [pc, #20]	; (8004a6c <ILI9341_Set_Rotation+0xa0>)
 8004a56:	22f0      	movs	r2, #240	; 0xf0
 8004a58:	801a      	strh	r2, [r3, #0]
			break;
 8004a5a:	e000      	b.n	8004a5e <ILI9341_Set_Rotation+0x92>
		default:
			//EXIT IF SCREEN ROTATION NOT VALID!
			break;
 8004a5c:	bf00      	nop
	}
}
 8004a5e:	bf00      	nop
 8004a60:	3710      	adds	r7, #16
 8004a62:	46bd      	mov	sp, r7
 8004a64:	bd80      	pop	{r7, pc}
 8004a66:	bf00      	nop
 8004a68:	2000000c 	.word	0x2000000c
 8004a6c:	2000000a 	.word	0x2000000a

08004a70 <ILI9341_Enable>:

/*Enable LCD display*/
void ILI9341_Enable(void)
{
 8004a70:	b580      	push	{r7, lr}
 8004a72:	af00      	add	r7, sp, #0
HAL_GPIO_WritePin(LCD_RST_PORT, LCD_RST_PIN, GPIO_PIN_SET);
 8004a74:	2201      	movs	r2, #1
 8004a76:	f44f 6180 	mov.w	r1, #1024	; 0x400
 8004a7a:	4802      	ldr	r0, [pc, #8]	; (8004a84 <ILI9341_Enable+0x14>)
 8004a7c:	f7fd f818 	bl	8001ab0 <HAL_GPIO_WritePin>
}
 8004a80:	bf00      	nop
 8004a82:	bd80      	pop	{r7, pc}
 8004a84:	40020800 	.word	0x40020800

08004a88 <ILI9341_Init>:

/*Initialize LCD display*/
void ILI9341_Init(void)
{
 8004a88:	b580      	push	{r7, lr}
 8004a8a:	af00      	add	r7, sp, #0

ILI9341_Enable();
 8004a8c:	f7ff fff0 	bl	8004a70 <ILI9341_Enable>
ILI9341_SPI_Init();
 8004a90:	f7ff fecc 	bl	800482c <ILI9341_SPI_Init>
ILI9341_Reset();
 8004a94:	f7ff ff7c 	bl	8004990 <ILI9341_Reset>

//SOFTWARE RESET
ILI9341_Write_Command(0x01);
 8004a98:	2001      	movs	r0, #1
 8004a9a:	f7ff fee9 	bl	8004870 <ILI9341_Write_Command>
HAL_Delay(1000);
 8004a9e:	f44f 707a 	mov.w	r0, #1000	; 0x3e8
 8004aa2:	f7fc fd3b 	bl	800151c <HAL_Delay>
	
//POWER CONTROL A
ILI9341_Write_Command(0xCB);
 8004aa6:	20cb      	movs	r0, #203	; 0xcb
 8004aa8:	f7ff fee2 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(0x39);
 8004aac:	2039      	movs	r0, #57	; 0x39
 8004aae:	f7ff ff01 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x2C);
 8004ab2:	202c      	movs	r0, #44	; 0x2c
 8004ab4:	f7ff fefe 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x00);
 8004ab8:	2000      	movs	r0, #0
 8004aba:	f7ff fefb 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x34);
 8004abe:	2034      	movs	r0, #52	; 0x34
 8004ac0:	f7ff fef8 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x02);
 8004ac4:	2002      	movs	r0, #2
 8004ac6:	f7ff fef5 	bl	80048b4 <ILI9341_Write_Data>

//POWER CONTROL B
ILI9341_Write_Command(0xCF);
 8004aca:	20cf      	movs	r0, #207	; 0xcf
 8004acc:	f7ff fed0 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(0x00);
 8004ad0:	2000      	movs	r0, #0
 8004ad2:	f7ff feef 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0xC1);
 8004ad6:	20c1      	movs	r0, #193	; 0xc1
 8004ad8:	f7ff feec 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x30);
 8004adc:	2030      	movs	r0, #48	; 0x30
 8004ade:	f7ff fee9 	bl	80048b4 <ILI9341_Write_Data>

//DRIVER TIMING CONTROL A
ILI9341_Write_Command(0xE8);
 8004ae2:	20e8      	movs	r0, #232	; 0xe8
 8004ae4:	f7ff fec4 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(0x85);
 8004ae8:	2085      	movs	r0, #133	; 0x85
 8004aea:	f7ff fee3 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x00);
 8004aee:	2000      	movs	r0, #0
 8004af0:	f7ff fee0 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x78);
 8004af4:	2078      	movs	r0, #120	; 0x78
 8004af6:	f7ff fedd 	bl	80048b4 <ILI9341_Write_Data>

//DRIVER TIMING CONTROL B
ILI9341_Write_Command(0xEA);
 8004afa:	20ea      	movs	r0, #234	; 0xea
 8004afc:	f7ff feb8 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(0x00);
 8004b00:	2000      	movs	r0, #0
 8004b02:	f7ff fed7 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x00);
 8004b06:	2000      	movs	r0, #0
 8004b08:	f7ff fed4 	bl	80048b4 <ILI9341_Write_Data>

//POWER ON SEQUENCE CONTROL
ILI9341_Write_Command(0xED);
 8004b0c:	20ed      	movs	r0, #237	; 0xed
 8004b0e:	f7ff feaf 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(0x64);
 8004b12:	2064      	movs	r0, #100	; 0x64
 8004b14:	f7ff fece 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x03);
 8004b18:	2003      	movs	r0, #3
 8004b1a:	f7ff fecb 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x12);
 8004b1e:	2012      	movs	r0, #18
 8004b20:	f7ff fec8 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x81);
 8004b24:	2081      	movs	r0, #129	; 0x81
 8004b26:	f7ff fec5 	bl	80048b4 <ILI9341_Write_Data>

//PUMP RATIO CONTROL
ILI9341_Write_Command(0xF7);
 8004b2a:	20f7      	movs	r0, #247	; 0xf7
 8004b2c:	f7ff fea0 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(0x20);
 8004b30:	2020      	movs	r0, #32
 8004b32:	f7ff febf 	bl	80048b4 <ILI9341_Write_Data>

//POWER CONTROL,VRH[5:0]
ILI9341_Write_Command(0xC0);
 8004b36:	20c0      	movs	r0, #192	; 0xc0
 8004b38:	f7ff fe9a 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(0x23);
 8004b3c:	2023      	movs	r0, #35	; 0x23
 8004b3e:	f7ff feb9 	bl	80048b4 <ILI9341_Write_Data>

//POWER CONTROL,SAP[2:0];BT[3:0]
ILI9341_Write_Command(0xC1);
 8004b42:	20c1      	movs	r0, #193	; 0xc1
 8004b44:	f7ff fe94 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(0x10);
 8004b48:	2010      	movs	r0, #16
 8004b4a:	f7ff feb3 	bl	80048b4 <ILI9341_Write_Data>

//VCM CONTROL
ILI9341_Write_Command(0xC5);
 8004b4e:	20c5      	movs	r0, #197	; 0xc5
 8004b50:	f7ff fe8e 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(0x3E);
 8004b54:	203e      	movs	r0, #62	; 0x3e
 8004b56:	f7ff fead 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x28);
 8004b5a:	2028      	movs	r0, #40	; 0x28
 8004b5c:	f7ff feaa 	bl	80048b4 <ILI9341_Write_Data>

//VCM CONTROL 2
ILI9341_Write_Command(0xC7);
 8004b60:	20c7      	movs	r0, #199	; 0xc7
 8004b62:	f7ff fe85 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(0x86);
 8004b66:	2086      	movs	r0, #134	; 0x86
 8004b68:	f7ff fea4 	bl	80048b4 <ILI9341_Write_Data>

//MEMORY ACCESS CONTROL
ILI9341_Write_Command(0x36);
 8004b6c:	2036      	movs	r0, #54	; 0x36
 8004b6e:	f7ff fe7f 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(0x48);
 8004b72:	2048      	movs	r0, #72	; 0x48
 8004b74:	f7ff fe9e 	bl	80048b4 <ILI9341_Write_Data>

//PIXEL FORMAT
ILI9341_Write_Command(0x3A);
 8004b78:	203a      	movs	r0, #58	; 0x3a
 8004b7a:	f7ff fe79 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(0x55);
 8004b7e:	2055      	movs	r0, #85	; 0x55
 8004b80:	f7ff fe98 	bl	80048b4 <ILI9341_Write_Data>

//FRAME RATIO CONTROL, STANDARD RGB COLOR
ILI9341_Write_Command(0xB1);
 8004b84:	20b1      	movs	r0, #177	; 0xb1
 8004b86:	f7ff fe73 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(0x00);
 8004b8a:	2000      	movs	r0, #0
 8004b8c:	f7ff fe92 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x18);
 8004b90:	2018      	movs	r0, #24
 8004b92:	f7ff fe8f 	bl	80048b4 <ILI9341_Write_Data>

//DISPLAY FUNCTION CONTROL
ILI9341_Write_Command(0xB6);
 8004b96:	20b6      	movs	r0, #182	; 0xb6
 8004b98:	f7ff fe6a 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(0x08);
 8004b9c:	2008      	movs	r0, #8
 8004b9e:	f7ff fe89 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x82);
 8004ba2:	2082      	movs	r0, #130	; 0x82
 8004ba4:	f7ff fe86 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x27);
 8004ba8:	2027      	movs	r0, #39	; 0x27
 8004baa:	f7ff fe83 	bl	80048b4 <ILI9341_Write_Data>

//3GAMMA FUNCTION DISABLE
ILI9341_Write_Command(0xF2);
 8004bae:	20f2      	movs	r0, #242	; 0xf2
 8004bb0:	f7ff fe5e 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(0x00);
 8004bb4:	2000      	movs	r0, #0
 8004bb6:	f7ff fe7d 	bl	80048b4 <ILI9341_Write_Data>

//GAMMA CURVE SELECTED
ILI9341_Write_Command(0x26);
 8004bba:	2026      	movs	r0, #38	; 0x26
 8004bbc:	f7ff fe58 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(0x01);
 8004bc0:	2001      	movs	r0, #1
 8004bc2:	f7ff fe77 	bl	80048b4 <ILI9341_Write_Data>

//POSITIVE GAMMA CORRECTION
ILI9341_Write_Command(0xE0);
 8004bc6:	20e0      	movs	r0, #224	; 0xe0
 8004bc8:	f7ff fe52 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(0x0F);
 8004bcc:	200f      	movs	r0, #15
 8004bce:	f7ff fe71 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x31);
 8004bd2:	2031      	movs	r0, #49	; 0x31
 8004bd4:	f7ff fe6e 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x2B);
 8004bd8:	202b      	movs	r0, #43	; 0x2b
 8004bda:	f7ff fe6b 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x0C);
 8004bde:	200c      	movs	r0, #12
 8004be0:	f7ff fe68 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x0E);
 8004be4:	200e      	movs	r0, #14
 8004be6:	f7ff fe65 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x08);
 8004bea:	2008      	movs	r0, #8
 8004bec:	f7ff fe62 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x4E);
 8004bf0:	204e      	movs	r0, #78	; 0x4e
 8004bf2:	f7ff fe5f 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0xF1);
 8004bf6:	20f1      	movs	r0, #241	; 0xf1
 8004bf8:	f7ff fe5c 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x37);
 8004bfc:	2037      	movs	r0, #55	; 0x37
 8004bfe:	f7ff fe59 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x07);
 8004c02:	2007      	movs	r0, #7
 8004c04:	f7ff fe56 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x10);
 8004c08:	2010      	movs	r0, #16
 8004c0a:	f7ff fe53 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x03);
 8004c0e:	2003      	movs	r0, #3
 8004c10:	f7ff fe50 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x0E);
 8004c14:	200e      	movs	r0, #14
 8004c16:	f7ff fe4d 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x09);
 8004c1a:	2009      	movs	r0, #9
 8004c1c:	f7ff fe4a 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x00);
 8004c20:	2000      	movs	r0, #0
 8004c22:	f7ff fe47 	bl	80048b4 <ILI9341_Write_Data>

//NEGATIVE GAMMA CORRECTION
ILI9341_Write_Command(0xE1);
 8004c26:	20e1      	movs	r0, #225	; 0xe1
 8004c28:	f7ff fe22 	bl	8004870 <ILI9341_Write_Command>
ILI9341_Write_Data(0x00);
 8004c2c:	2000      	movs	r0, #0
 8004c2e:	f7ff fe41 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x0E);
 8004c32:	200e      	movs	r0, #14
 8004c34:	f7ff fe3e 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x14);
 8004c38:	2014      	movs	r0, #20
 8004c3a:	f7ff fe3b 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x03);
 8004c3e:	2003      	movs	r0, #3
 8004c40:	f7ff fe38 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x11);
 8004c44:	2011      	movs	r0, #17
 8004c46:	f7ff fe35 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x07);
 8004c4a:	2007      	movs	r0, #7
 8004c4c:	f7ff fe32 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x31);
 8004c50:	2031      	movs	r0, #49	; 0x31
 8004c52:	f7ff fe2f 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0xC1);
 8004c56:	20c1      	movs	r0, #193	; 0xc1
 8004c58:	f7ff fe2c 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x48);
 8004c5c:	2048      	movs	r0, #72	; 0x48
 8004c5e:	f7ff fe29 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x08);
 8004c62:	2008      	movs	r0, #8
 8004c64:	f7ff fe26 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x0F);
 8004c68:	200f      	movs	r0, #15
 8004c6a:	f7ff fe23 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x0C);
 8004c6e:	200c      	movs	r0, #12
 8004c70:	f7ff fe20 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x31);
 8004c74:	2031      	movs	r0, #49	; 0x31
 8004c76:	f7ff fe1d 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x36);
 8004c7a:	2036      	movs	r0, #54	; 0x36
 8004c7c:	f7ff fe1a 	bl	80048b4 <ILI9341_Write_Data>
ILI9341_Write_Data(0x0F);
 8004c80:	200f      	movs	r0, #15
 8004c82:	f7ff fe17 	bl	80048b4 <ILI9341_Write_Data>

//EXIT SLEEP
ILI9341_Write_Command(0x11);
 8004c86:	2011      	movs	r0, #17
 8004c88:	f7ff fdf2 	bl	8004870 <ILI9341_Write_Command>
HAL_Delay(120);
 8004c8c:	2078      	movs	r0, #120	; 0x78
 8004c8e:	f7fc fc45 	bl	800151c <HAL_Delay>

//TURN ON DISPLAY
ILI9341_Write_Command(0x29);
 8004c92:	2029      	movs	r0, #41	; 0x29
 8004c94:	f7ff fdec 	bl	8004870 <ILI9341_Write_Command>

//STARTING ROTATION
ILI9341_Set_Rotation(SCREEN_VERTICAL_1);
 8004c98:	2000      	movs	r0, #0
 8004c9a:	f7ff fe97 	bl	80049cc <ILI9341_Set_Rotation>
}
 8004c9e:	bf00      	nop
 8004ca0:	bd80      	pop	{r7, pc}
	...

08004ca4 <ILI9341_Draw_Colour_Burst>:
}

//INTERNAL FUNCTION OF LIBRARY
/*Sends block colour information to LCD*/
void ILI9341_Draw_Colour_Burst(uint16_t Colour, uint32_t Size)
{
 8004ca4:	b5b0      	push	{r4, r5, r7, lr}
 8004ca6:	b08c      	sub	sp, #48	; 0x30
 8004ca8:	af00      	add	r7, sp, #0
 8004caa:	4603      	mov	r3, r0
 8004cac:	6039      	str	r1, [r7, #0]
 8004cae:	80fb      	strh	r3, [r7, #6]
 8004cb0:	466b      	mov	r3, sp
 8004cb2:	461d      	mov	r5, r3
//SENDS COLOUR
uint32_t Buffer_Size = 0;
 8004cb4:	2300      	movs	r3, #0
 8004cb6:	627b      	str	r3, [r7, #36]	; 0x24
if((Size*2) < BURST_MAX_SIZE)
 8004cb8:	683b      	ldr	r3, [r7, #0]
 8004cba:	005b      	lsls	r3, r3, #1
 8004cbc:	f5b3 7ffa 	cmp.w	r3, #500	; 0x1f4
 8004cc0:	d202      	bcs.n	8004cc8 <ILI9341_Draw_Colour_Burst+0x24>
{
	Buffer_Size = Size;
 8004cc2:	683b      	ldr	r3, [r7, #0]
 8004cc4:	627b      	str	r3, [r7, #36]	; 0x24
 8004cc6:	e002      	b.n	8004cce <ILI9341_Draw_Colour_Burst+0x2a>
}
else
{
	Buffer_Size = BURST_MAX_SIZE;
 8004cc8:	f44f 73fa 	mov.w	r3, #500	; 0x1f4
 8004ccc:	627b      	str	r3, [r7, #36]	; 0x24
}
	
HAL_GPIO_WritePin(LCD_DC_PORT, LCD_DC_PIN, GPIO_PIN_SET);	
 8004cce:	2201      	movs	r2, #1
 8004cd0:	f44f 7100 	mov.w	r1, #512	; 0x200
 8004cd4:	483e      	ldr	r0, [pc, #248]	; (8004dd0 <ILI9341_Draw_Colour_Burst+0x12c>)
 8004cd6:	f7fc feeb 	bl	8001ab0 <HAL_GPIO_WritePin>
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_RESET);
 8004cda:	2200      	movs	r2, #0
 8004cdc:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004ce0:	483b      	ldr	r0, [pc, #236]	; (8004dd0 <ILI9341_Draw_Colour_Burst+0x12c>)
 8004ce2:	f7fc fee5 	bl	8001ab0 <HAL_GPIO_WritePin>

unsigned char chifted = 	Colour>>8;;
 8004ce6:	88fb      	ldrh	r3, [r7, #6]
 8004ce8:	0a1b      	lsrs	r3, r3, #8
 8004cea:	b29b      	uxth	r3, r3
 8004cec:	f887 3023 	strb.w	r3, [r7, #35]	; 0x23
unsigned char burst_buffer[Buffer_Size];
 8004cf0:	6a78      	ldr	r0, [r7, #36]	; 0x24
 8004cf2:	4603      	mov	r3, r0
 8004cf4:	3b01      	subs	r3, #1
 8004cf6:	61fb      	str	r3, [r7, #28]
 8004cf8:	4601      	mov	r1, r0
 8004cfa:	f04f 0200 	mov.w	r2, #0
 8004cfe:	f04f 0300 	mov.w	r3, #0
 8004d02:	f04f 0400 	mov.w	r4, #0
 8004d06:	00d4      	lsls	r4, r2, #3
 8004d08:	ea44 7451 	orr.w	r4, r4, r1, lsr #29
 8004d0c:	00cb      	lsls	r3, r1, #3
 8004d0e:	4601      	mov	r1, r0
 8004d10:	f04f 0200 	mov.w	r2, #0
 8004d14:	f04f 0300 	mov.w	r3, #0
 8004d18:	f04f 0400 	mov.w	r4, #0
 8004d1c:	00d4      	lsls	r4, r2, #3
 8004d1e:	ea44 7451 	orr.w	r4, r4, r1, lsr #29
 8004d22:	00cb      	lsls	r3, r1, #3
 8004d24:	1dc3      	adds	r3, r0, #7
 8004d26:	08db      	lsrs	r3, r3, #3
 8004d28:	00db      	lsls	r3, r3, #3
 8004d2a:	ebad 0d03 	sub.w	sp, sp, r3
 8004d2e:	466b      	mov	r3, sp
 8004d30:	3300      	adds	r3, #0
 8004d32:	61bb      	str	r3, [r7, #24]
for(uint32_t j = 0; j < Buffer_Size; j+=2)
 8004d34:	2300      	movs	r3, #0
 8004d36:	62bb      	str	r3, [r7, #40]	; 0x28
 8004d38:	e00e      	b.n	8004d58 <ILI9341_Draw_Colour_Burst+0xb4>
	{
		burst_buffer[j] = 	chifted;
 8004d3a:	69ba      	ldr	r2, [r7, #24]
 8004d3c:	6abb      	ldr	r3, [r7, #40]	; 0x28
 8004d3e:	4413      	add	r3, r2
 8004d40:	f897 2023 	ldrb.w	r2, [r7, #35]	; 0x23
 8004d44:	701a      	strb	r2, [r3, #0]
		burst_buffer[j+1] = Colour;
 8004d46:	6abb      	ldr	r3, [r7, #40]	; 0x28
 8004d48:	3301      	adds	r3, #1
 8004d4a:	88fa      	ldrh	r2, [r7, #6]
 8004d4c:	b2d1      	uxtb	r1, r2
 8004d4e:	69ba      	ldr	r2, [r7, #24]
 8004d50:	54d1      	strb	r1, [r2, r3]
for(uint32_t j = 0; j < Buffer_Size; j+=2)
 8004d52:	6abb      	ldr	r3, [r7, #40]	; 0x28
 8004d54:	3302      	adds	r3, #2
 8004d56:	62bb      	str	r3, [r7, #40]	; 0x28
 8004d58:	6aba      	ldr	r2, [r7, #40]	; 0x28
 8004d5a:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 8004d5c:	429a      	cmp	r2, r3
 8004d5e:	d3ec      	bcc.n	8004d3a <ILI9341_Draw_Colour_Burst+0x96>
	}

uint32_t Sending_Size = Size*2;
 8004d60:	683b      	ldr	r3, [r7, #0]
 8004d62:	005b      	lsls	r3, r3, #1
 8004d64:	617b      	str	r3, [r7, #20]
uint32_t Sending_in_Block = Sending_Size/Buffer_Size;
 8004d66:	697a      	ldr	r2, [r7, #20]
 8004d68:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 8004d6a:	fbb2 f3f3 	udiv	r3, r2, r3
 8004d6e:	613b      	str	r3, [r7, #16]
uint32_t Remainder_from_block = Sending_Size%Buffer_Size;
 8004d70:	697b      	ldr	r3, [r7, #20]
 8004d72:	6a7a      	ldr	r2, [r7, #36]	; 0x24
 8004d74:	fbb3 f2f2 	udiv	r2, r3, r2
 8004d78:	6a79      	ldr	r1, [r7, #36]	; 0x24
 8004d7a:	fb01 f202 	mul.w	r2, r1, r2
 8004d7e:	1a9b      	subs	r3, r3, r2
 8004d80:	60fb      	str	r3, [r7, #12]

if(Sending_in_Block != 0)
 8004d82:	693b      	ldr	r3, [r7, #16]
 8004d84:	2b00      	cmp	r3, #0
 8004d86:	d010      	beq.n	8004daa <ILI9341_Draw_Colour_Burst+0x106>
{
	for(uint32_t j = 0; j < (Sending_in_Block); j++)
 8004d88:	2300      	movs	r3, #0
 8004d8a:	62fb      	str	r3, [r7, #44]	; 0x2c
 8004d8c:	e009      	b.n	8004da2 <ILI9341_Draw_Colour_Burst+0xfe>
		{
		HAL_SPI_Transmit(HSPI_INSTANCE, (unsigned char *)burst_buffer, Buffer_Size, 10);	
 8004d8e:	69b9      	ldr	r1, [r7, #24]
 8004d90:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 8004d92:	b29a      	uxth	r2, r3
 8004d94:	230a      	movs	r3, #10
 8004d96:	480f      	ldr	r0, [pc, #60]	; (8004dd4 <ILI9341_Draw_Colour_Burst+0x130>)
 8004d98:	f7fe f88c 	bl	8002eb4 <HAL_SPI_Transmit>
	for(uint32_t j = 0; j < (Sending_in_Block); j++)
 8004d9c:	6afb      	ldr	r3, [r7, #44]	; 0x2c
 8004d9e:	3301      	adds	r3, #1
 8004da0:	62fb      	str	r3, [r7, #44]	; 0x2c
 8004da2:	6afa      	ldr	r2, [r7, #44]	; 0x2c
 8004da4:	693b      	ldr	r3, [r7, #16]
 8004da6:	429a      	cmp	r2, r3
 8004da8:	d3f1      	bcc.n	8004d8e <ILI9341_Draw_Colour_Burst+0xea>
		}
}

//REMAINDER!
HAL_SPI_Transmit(HSPI_INSTANCE, (unsigned char *)burst_buffer, Remainder_from_block, 10);	
 8004daa:	69b9      	ldr	r1, [r7, #24]
 8004dac:	68fb      	ldr	r3, [r7, #12]
 8004dae:	b29a      	uxth	r2, r3
 8004db0:	230a      	movs	r3, #10
 8004db2:	4808      	ldr	r0, [pc, #32]	; (8004dd4 <ILI9341_Draw_Colour_Burst+0x130>)
 8004db4:	f7fe f87e 	bl	8002eb4 <HAL_SPI_Transmit>
	
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_SET);
 8004db8:	2201      	movs	r2, #1
 8004dba:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004dbe:	4804      	ldr	r0, [pc, #16]	; (8004dd0 <ILI9341_Draw_Colour_Burst+0x12c>)
 8004dc0:	f7fc fe76 	bl	8001ab0 <HAL_GPIO_WritePin>
 8004dc4:	46ad      	mov	sp, r5
}
 8004dc6:	bf00      	nop
 8004dc8:	3730      	adds	r7, #48	; 0x30
 8004dca:	46bd      	mov	sp, r7
 8004dcc:	bdb0      	pop	{r4, r5, r7, pc}
 8004dce:	bf00      	nop
 8004dd0:	40020800 	.word	0x40020800
 8004dd4:	20025a2c 	.word	0x20025a2c

08004dd8 <ILI9341_Fill_Screen>:

//FILL THE ENTIRE SCREEN WITH SELECTED COLOUR (either #define-d ones or custom 16bit)
/*Sets address (entire screen) and Sends Height*Width ammount of colour information to LCD*/
void ILI9341_Fill_Screen(uint16_t Colour)
{
 8004dd8:	b580      	push	{r7, lr}
 8004dda:	b082      	sub	sp, #8
 8004ddc:	af00      	add	r7, sp, #0
 8004dde:	4603      	mov	r3, r0
 8004de0:	80fb      	strh	r3, [r7, #6]
ILI9341_Set_Address(0,0,LCD_WIDTH,LCD_HEIGHT);	
 8004de2:	4b0e      	ldr	r3, [pc, #56]	; (8004e1c <ILI9341_Fill_Screen+0x44>)
 8004de4:	881b      	ldrh	r3, [r3, #0]
 8004de6:	b29a      	uxth	r2, r3
 8004de8:	4b0d      	ldr	r3, [pc, #52]	; (8004e20 <ILI9341_Fill_Screen+0x48>)
 8004dea:	881b      	ldrh	r3, [r3, #0]
 8004dec:	b29b      	uxth	r3, r3
 8004dee:	2100      	movs	r1, #0
 8004df0:	2000      	movs	r0, #0
 8004df2:	f7ff fd81 	bl	80048f8 <ILI9341_Set_Address>
ILI9341_Draw_Colour_Burst(Colour, LCD_WIDTH*LCD_HEIGHT);	
 8004df6:	4b09      	ldr	r3, [pc, #36]	; (8004e1c <ILI9341_Fill_Screen+0x44>)
 8004df8:	881b      	ldrh	r3, [r3, #0]
 8004dfa:	b29b      	uxth	r3, r3
 8004dfc:	461a      	mov	r2, r3
 8004dfe:	4b08      	ldr	r3, [pc, #32]	; (8004e20 <ILI9341_Fill_Screen+0x48>)
 8004e00:	881b      	ldrh	r3, [r3, #0]
 8004e02:	b29b      	uxth	r3, r3
 8004e04:	fb03 f302 	mul.w	r3, r3, r2
 8004e08:	461a      	mov	r2, r3
 8004e0a:	88fb      	ldrh	r3, [r7, #6]
 8004e0c:	4611      	mov	r1, r2
 8004e0e:	4618      	mov	r0, r3
 8004e10:	f7ff ff48 	bl	8004ca4 <ILI9341_Draw_Colour_Burst>
}
 8004e14:	bf00      	nop
 8004e16:	3708      	adds	r7, #8
 8004e18:	46bd      	mov	sp, r7
 8004e1a:	bd80      	pop	{r7, pc}
 8004e1c:	2000000c 	.word	0x2000000c
 8004e20:	2000000a 	.word	0x2000000a

08004e24 <ILI9341_Draw_Pixel>:
//Location is dependant on screen orientation. x0 and y0 locations change with orientations.
//Using pixels to draw big simple structures is not recommended as it is really slow
//Try using either rectangles or lines if possible
//
void ILI9341_Draw_Pixel(uint16_t X,uint16_t Y,uint16_t Colour) 
{
 8004e24:	b580      	push	{r7, lr}
 8004e26:	b086      	sub	sp, #24
 8004e28:	af00      	add	r7, sp, #0
 8004e2a:	4603      	mov	r3, r0
 8004e2c:	80fb      	strh	r3, [r7, #6]
 8004e2e:	460b      	mov	r3, r1
 8004e30:	80bb      	strh	r3, [r7, #4]
 8004e32:	4613      	mov	r3, r2
 8004e34:	807b      	strh	r3, [r7, #2]
if((X >=LCD_WIDTH) || (Y >=LCD_HEIGHT)) return;	//OUT OF BOUNDS!
 8004e36:	4b64      	ldr	r3, [pc, #400]	; (8004fc8 <ILI9341_Draw_Pixel+0x1a4>)
 8004e38:	881b      	ldrh	r3, [r3, #0]
 8004e3a:	b29b      	uxth	r3, r3
 8004e3c:	88fa      	ldrh	r2, [r7, #6]
 8004e3e:	429a      	cmp	r2, r3
 8004e40:	f080 80be 	bcs.w	8004fc0 <ILI9341_Draw_Pixel+0x19c>
 8004e44:	4b61      	ldr	r3, [pc, #388]	; (8004fcc <ILI9341_Draw_Pixel+0x1a8>)
 8004e46:	881b      	ldrh	r3, [r3, #0]
 8004e48:	b29b      	uxth	r3, r3
 8004e4a:	88ba      	ldrh	r2, [r7, #4]
 8004e4c:	429a      	cmp	r2, r3
 8004e4e:	f080 80b7 	bcs.w	8004fc0 <ILI9341_Draw_Pixel+0x19c>
	
//ADDRESS
HAL_GPIO_WritePin(LCD_DC_PORT, LCD_DC_PIN, GPIO_PIN_RESET);	
 8004e52:	2200      	movs	r2, #0
 8004e54:	f44f 7100 	mov.w	r1, #512	; 0x200
 8004e58:	485d      	ldr	r0, [pc, #372]	; (8004fd0 <ILI9341_Draw_Pixel+0x1ac>)
 8004e5a:	f7fc fe29 	bl	8001ab0 <HAL_GPIO_WritePin>
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_RESET);
 8004e5e:	2200      	movs	r2, #0
 8004e60:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004e64:	485a      	ldr	r0, [pc, #360]	; (8004fd0 <ILI9341_Draw_Pixel+0x1ac>)
 8004e66:	f7fc fe23 	bl	8001ab0 <HAL_GPIO_WritePin>
ILI9341_SPI_Send(0x2A);
 8004e6a:	202a      	movs	r0, #42	; 0x2a
 8004e6c:	f7ff fcee 	bl	800484c <ILI9341_SPI_Send>
HAL_GPIO_WritePin(LCD_DC_PORT, LCD_DC_PIN, GPIO_PIN_SET);	
 8004e70:	2201      	movs	r2, #1
 8004e72:	f44f 7100 	mov.w	r1, #512	; 0x200
 8004e76:	4856      	ldr	r0, [pc, #344]	; (8004fd0 <ILI9341_Draw_Pixel+0x1ac>)
 8004e78:	f7fc fe1a 	bl	8001ab0 <HAL_GPIO_WritePin>
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_SET);		
 8004e7c:	2201      	movs	r2, #1
 8004e7e:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004e82:	4853      	ldr	r0, [pc, #332]	; (8004fd0 <ILI9341_Draw_Pixel+0x1ac>)
 8004e84:	f7fc fe14 	bl	8001ab0 <HAL_GPIO_WritePin>

//XDATA
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_RESET);	
 8004e88:	2200      	movs	r2, #0
 8004e8a:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004e8e:	4850      	ldr	r0, [pc, #320]	; (8004fd0 <ILI9341_Draw_Pixel+0x1ac>)
 8004e90:	f7fc fe0e 	bl	8001ab0 <HAL_GPIO_WritePin>
unsigned char Temp_Buffer[4] = {X>>8,X, (X+1)>>8, (X+1)};
 8004e94:	88fb      	ldrh	r3, [r7, #6]
 8004e96:	0a1b      	lsrs	r3, r3, #8
 8004e98:	b29b      	uxth	r3, r3
 8004e9a:	b2db      	uxtb	r3, r3
 8004e9c:	753b      	strb	r3, [r7, #20]
 8004e9e:	88fb      	ldrh	r3, [r7, #6]
 8004ea0:	b2db      	uxtb	r3, r3
 8004ea2:	757b      	strb	r3, [r7, #21]
 8004ea4:	88fb      	ldrh	r3, [r7, #6]
 8004ea6:	3301      	adds	r3, #1
 8004ea8:	121b      	asrs	r3, r3, #8
 8004eaa:	b2db      	uxtb	r3, r3
 8004eac:	75bb      	strb	r3, [r7, #22]
 8004eae:	88fb      	ldrh	r3, [r7, #6]
 8004eb0:	b2db      	uxtb	r3, r3
 8004eb2:	3301      	adds	r3, #1
 8004eb4:	b2db      	uxtb	r3, r3
 8004eb6:	75fb      	strb	r3, [r7, #23]
HAL_SPI_Transmit(HSPI_INSTANCE, Temp_Buffer, 4, 1);
 8004eb8:	f107 0114 	add.w	r1, r7, #20
 8004ebc:	2301      	movs	r3, #1
 8004ebe:	2204      	movs	r2, #4
 8004ec0:	4844      	ldr	r0, [pc, #272]	; (8004fd4 <ILI9341_Draw_Pixel+0x1b0>)
 8004ec2:	f7fd fff7 	bl	8002eb4 <HAL_SPI_Transmit>
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_SET);
 8004ec6:	2201      	movs	r2, #1
 8004ec8:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004ecc:	4840      	ldr	r0, [pc, #256]	; (8004fd0 <ILI9341_Draw_Pixel+0x1ac>)
 8004ece:	f7fc fdef 	bl	8001ab0 <HAL_GPIO_WritePin>

//ADDRESS
HAL_GPIO_WritePin(LCD_DC_PORT, LCD_DC_PIN, GPIO_PIN_RESET);	
 8004ed2:	2200      	movs	r2, #0
 8004ed4:	f44f 7100 	mov.w	r1, #512	; 0x200
 8004ed8:	483d      	ldr	r0, [pc, #244]	; (8004fd0 <ILI9341_Draw_Pixel+0x1ac>)
 8004eda:	f7fc fde9 	bl	8001ab0 <HAL_GPIO_WritePin>
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_RESET);	
 8004ede:	2200      	movs	r2, #0
 8004ee0:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004ee4:	483a      	ldr	r0, [pc, #232]	; (8004fd0 <ILI9341_Draw_Pixel+0x1ac>)
 8004ee6:	f7fc fde3 	bl	8001ab0 <HAL_GPIO_WritePin>
ILI9341_SPI_Send(0x2B);
 8004eea:	202b      	movs	r0, #43	; 0x2b
 8004eec:	f7ff fcae 	bl	800484c <ILI9341_SPI_Send>
HAL_GPIO_WritePin(LCD_DC_PORT, LCD_DC_PIN, GPIO_PIN_SET);			
 8004ef0:	2201      	movs	r2, #1
 8004ef2:	f44f 7100 	mov.w	r1, #512	; 0x200
 8004ef6:	4836      	ldr	r0, [pc, #216]	; (8004fd0 <ILI9341_Draw_Pixel+0x1ac>)
 8004ef8:	f7fc fdda 	bl	8001ab0 <HAL_GPIO_WritePin>
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_SET);			
 8004efc:	2201      	movs	r2, #1
 8004efe:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004f02:	4833      	ldr	r0, [pc, #204]	; (8004fd0 <ILI9341_Draw_Pixel+0x1ac>)
 8004f04:	f7fc fdd4 	bl	8001ab0 <HAL_GPIO_WritePin>

//YDATA
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_RESET);
 8004f08:	2200      	movs	r2, #0
 8004f0a:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004f0e:	4830      	ldr	r0, [pc, #192]	; (8004fd0 <ILI9341_Draw_Pixel+0x1ac>)
 8004f10:	f7fc fdce 	bl	8001ab0 <HAL_GPIO_WritePin>
unsigned char Temp_Buffer1[4] = {Y>>8,Y, (Y+1)>>8, (Y+1)};
 8004f14:	88bb      	ldrh	r3, [r7, #4]
 8004f16:	0a1b      	lsrs	r3, r3, #8
 8004f18:	b29b      	uxth	r3, r3
 8004f1a:	b2db      	uxtb	r3, r3
 8004f1c:	743b      	strb	r3, [r7, #16]
 8004f1e:	88bb      	ldrh	r3, [r7, #4]
 8004f20:	b2db      	uxtb	r3, r3
 8004f22:	747b      	strb	r3, [r7, #17]
 8004f24:	88bb      	ldrh	r3, [r7, #4]
 8004f26:	3301      	adds	r3, #1
 8004f28:	121b      	asrs	r3, r3, #8
 8004f2a:	b2db      	uxtb	r3, r3
 8004f2c:	74bb      	strb	r3, [r7, #18]
 8004f2e:	88bb      	ldrh	r3, [r7, #4]
 8004f30:	b2db      	uxtb	r3, r3
 8004f32:	3301      	adds	r3, #1
 8004f34:	b2db      	uxtb	r3, r3
 8004f36:	74fb      	strb	r3, [r7, #19]
HAL_SPI_Transmit(HSPI_INSTANCE, Temp_Buffer1, 4, 1);
 8004f38:	f107 0110 	add.w	r1, r7, #16
 8004f3c:	2301      	movs	r3, #1
 8004f3e:	2204      	movs	r2, #4
 8004f40:	4824      	ldr	r0, [pc, #144]	; (8004fd4 <ILI9341_Draw_Pixel+0x1b0>)
 8004f42:	f7fd ffb7 	bl	8002eb4 <HAL_SPI_Transmit>
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_SET);
 8004f46:	2201      	movs	r2, #1
 8004f48:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004f4c:	4820      	ldr	r0, [pc, #128]	; (8004fd0 <ILI9341_Draw_Pixel+0x1ac>)
 8004f4e:	f7fc fdaf 	bl	8001ab0 <HAL_GPIO_WritePin>

//ADDRESS	
HAL_GPIO_WritePin(LCD_DC_PORT, LCD_DC_PIN, GPIO_PIN_RESET);	
 8004f52:	2200      	movs	r2, #0
 8004f54:	f44f 7100 	mov.w	r1, #512	; 0x200
 8004f58:	481d      	ldr	r0, [pc, #116]	; (8004fd0 <ILI9341_Draw_Pixel+0x1ac>)
 8004f5a:	f7fc fda9 	bl	8001ab0 <HAL_GPIO_WritePin>
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_RESET);	
 8004f5e:	2200      	movs	r2, #0
 8004f60:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004f64:	481a      	ldr	r0, [pc, #104]	; (8004fd0 <ILI9341_Draw_Pixel+0x1ac>)
 8004f66:	f7fc fda3 	bl	8001ab0 <HAL_GPIO_WritePin>
ILI9341_SPI_Send(0x2C);
 8004f6a:	202c      	movs	r0, #44	; 0x2c
 8004f6c:	f7ff fc6e 	bl	800484c <ILI9341_SPI_Send>
HAL_GPIO_WritePin(LCD_DC_PORT, LCD_DC_PIN, GPIO_PIN_SET);			
 8004f70:	2201      	movs	r2, #1
 8004f72:	f44f 7100 	mov.w	r1, #512	; 0x200
 8004f76:	4816      	ldr	r0, [pc, #88]	; (8004fd0 <ILI9341_Draw_Pixel+0x1ac>)
 8004f78:	f7fc fd9a 	bl	8001ab0 <HAL_GPIO_WritePin>
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_SET);			
 8004f7c:	2201      	movs	r2, #1
 8004f7e:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004f82:	4813      	ldr	r0, [pc, #76]	; (8004fd0 <ILI9341_Draw_Pixel+0x1ac>)
 8004f84:	f7fc fd94 	bl	8001ab0 <HAL_GPIO_WritePin>

//COLOUR	
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_RESET);
 8004f88:	2200      	movs	r2, #0
 8004f8a:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004f8e:	4810      	ldr	r0, [pc, #64]	; (8004fd0 <ILI9341_Draw_Pixel+0x1ac>)
 8004f90:	f7fc fd8e 	bl	8001ab0 <HAL_GPIO_WritePin>
unsigned char Temp_Buffer2[2] = {Colour>>8, Colour};
 8004f94:	887b      	ldrh	r3, [r7, #2]
 8004f96:	0a1b      	lsrs	r3, r3, #8
 8004f98:	b29b      	uxth	r3, r3
 8004f9a:	b2db      	uxtb	r3, r3
 8004f9c:	733b      	strb	r3, [r7, #12]
 8004f9e:	887b      	ldrh	r3, [r7, #2]
 8004fa0:	b2db      	uxtb	r3, r3
 8004fa2:	737b      	strb	r3, [r7, #13]
HAL_SPI_Transmit(HSPI_INSTANCE, Temp_Buffer2, 2, 1);
 8004fa4:	f107 010c 	add.w	r1, r7, #12
 8004fa8:	2301      	movs	r3, #1
 8004faa:	2202      	movs	r2, #2
 8004fac:	4809      	ldr	r0, [pc, #36]	; (8004fd4 <ILI9341_Draw_Pixel+0x1b0>)
 8004fae:	f7fd ff81 	bl	8002eb4 <HAL_SPI_Transmit>
HAL_GPIO_WritePin(LCD_CS_PORT, LCD_CS_PIN, GPIO_PIN_SET);
 8004fb2:	2201      	movs	r2, #1
 8004fb4:	f44f 7180 	mov.w	r1, #256	; 0x100
 8004fb8:	4805      	ldr	r0, [pc, #20]	; (8004fd0 <ILI9341_Draw_Pixel+0x1ac>)
 8004fba:	f7fc fd79 	bl	8001ab0 <HAL_GPIO_WritePin>
 8004fbe:	e000      	b.n	8004fc2 <ILI9341_Draw_Pixel+0x19e>
if((X >=LCD_WIDTH) || (Y >=LCD_HEIGHT)) return;	//OUT OF BOUNDS!
 8004fc0:	bf00      	nop
	
}
 8004fc2:	3718      	adds	r7, #24
 8004fc4:	46bd      	mov	sp, r7
 8004fc6:	bd80      	pop	{r7, pc}
 8004fc8:	2000000c 	.word	0x2000000c
 8004fcc:	2000000a 	.word	0x2000000a
 8004fd0:	40020800 	.word	0x40020800
 8004fd4:	20025a2c 	.word	0x20025a2c

08004fd8 <ILI9341_Draw_Rectangle>:
//Rectangle is hollow. X and Y positions mark the upper left corner of rectangle
//As with all other draw calls x0 and y0 locations dependant on screen orientation
//

void ILI9341_Draw_Rectangle(uint16_t X, uint16_t Y, uint16_t Width, uint16_t Height, uint16_t Colour)
{
 8004fd8:	b590      	push	{r4, r7, lr}
 8004fda:	b083      	sub	sp, #12
 8004fdc:	af00      	add	r7, sp, #0
 8004fde:	4604      	mov	r4, r0
 8004fe0:	4608      	mov	r0, r1
 8004fe2:	4611      	mov	r1, r2
 8004fe4:	461a      	mov	r2, r3
 8004fe6:	4623      	mov	r3, r4
 8004fe8:	80fb      	strh	r3, [r7, #6]
 8004fea:	4603      	mov	r3, r0
 8004fec:	80bb      	strh	r3, [r7, #4]
 8004fee:	460b      	mov	r3, r1
 8004ff0:	807b      	strh	r3, [r7, #2]
 8004ff2:	4613      	mov	r3, r2
 8004ff4:	803b      	strh	r3, [r7, #0]
if((X >=LCD_WIDTH) || (Y >=LCD_HEIGHT)) return;
 8004ff6:	4b25      	ldr	r3, [pc, #148]	; (800508c <ILI9341_Draw_Rectangle+0xb4>)
 8004ff8:	881b      	ldrh	r3, [r3, #0]
 8004ffa:	b29b      	uxth	r3, r3
 8004ffc:	88fa      	ldrh	r2, [r7, #6]
 8004ffe:	429a      	cmp	r2, r3
 8005000:	d23f      	bcs.n	8005082 <ILI9341_Draw_Rectangle+0xaa>
 8005002:	4b23      	ldr	r3, [pc, #140]	; (8005090 <ILI9341_Draw_Rectangle+0xb8>)
 8005004:	881b      	ldrh	r3, [r3, #0]
 8005006:	b29b      	uxth	r3, r3
 8005008:	88ba      	ldrh	r2, [r7, #4]
 800500a:	429a      	cmp	r2, r3
 800500c:	d239      	bcs.n	8005082 <ILI9341_Draw_Rectangle+0xaa>
if((X+Width-1)>=LCD_WIDTH)
 800500e:	88fa      	ldrh	r2, [r7, #6]
 8005010:	887b      	ldrh	r3, [r7, #2]
 8005012:	4413      	add	r3, r2
 8005014:	3b01      	subs	r3, #1
 8005016:	4a1d      	ldr	r2, [pc, #116]	; (800508c <ILI9341_Draw_Rectangle+0xb4>)
 8005018:	8812      	ldrh	r2, [r2, #0]
 800501a:	b292      	uxth	r2, r2
 800501c:	4293      	cmp	r3, r2
 800501e:	db05      	blt.n	800502c <ILI9341_Draw_Rectangle+0x54>
	{
		Width=LCD_WIDTH-X;
 8005020:	4b1a      	ldr	r3, [pc, #104]	; (800508c <ILI9341_Draw_Rectangle+0xb4>)
 8005022:	881b      	ldrh	r3, [r3, #0]
 8005024:	b29a      	uxth	r2, r3
 8005026:	88fb      	ldrh	r3, [r7, #6]
 8005028:	1ad3      	subs	r3, r2, r3
 800502a:	807b      	strh	r3, [r7, #2]
	}
if((Y+Height-1)>=LCD_HEIGHT)
 800502c:	88ba      	ldrh	r2, [r7, #4]
 800502e:	883b      	ldrh	r3, [r7, #0]
 8005030:	4413      	add	r3, r2
 8005032:	3b01      	subs	r3, #1
 8005034:	4a16      	ldr	r2, [pc, #88]	; (8005090 <ILI9341_Draw_Rectangle+0xb8>)
 8005036:	8812      	ldrh	r2, [r2, #0]
 8005038:	b292      	uxth	r2, r2
 800503a:	4293      	cmp	r3, r2
 800503c:	db05      	blt.n	800504a <ILI9341_Draw_Rectangle+0x72>
	{
		Height=LCD_HEIGHT-Y;
 800503e:	4b14      	ldr	r3, [pc, #80]	; (8005090 <ILI9341_Draw_Rectangle+0xb8>)
 8005040:	881b      	ldrh	r3, [r3, #0]
 8005042:	b29a      	uxth	r2, r3
 8005044:	88bb      	ldrh	r3, [r7, #4]
 8005046:	1ad3      	subs	r3, r2, r3
 8005048:	803b      	strh	r3, [r7, #0]
	}
ILI9341_Set_Address(X, Y, X+Width-1, Y+Height-1);
 800504a:	88fa      	ldrh	r2, [r7, #6]
 800504c:	887b      	ldrh	r3, [r7, #2]
 800504e:	4413      	add	r3, r2
 8005050:	b29b      	uxth	r3, r3
 8005052:	3b01      	subs	r3, #1
 8005054:	b29c      	uxth	r4, r3
 8005056:	88ba      	ldrh	r2, [r7, #4]
 8005058:	883b      	ldrh	r3, [r7, #0]
 800505a:	4413      	add	r3, r2
 800505c:	b29b      	uxth	r3, r3
 800505e:	3b01      	subs	r3, #1
 8005060:	b29b      	uxth	r3, r3
 8005062:	88b9      	ldrh	r1, [r7, #4]
 8005064:	88f8      	ldrh	r0, [r7, #6]
 8005066:	4622      	mov	r2, r4
 8005068:	f7ff fc46 	bl	80048f8 <ILI9341_Set_Address>
ILI9341_Draw_Colour_Burst(Colour, Height*Width);
 800506c:	883b      	ldrh	r3, [r7, #0]
 800506e:	887a      	ldrh	r2, [r7, #2]
 8005070:	fb02 f303 	mul.w	r3, r2, r3
 8005074:	461a      	mov	r2, r3
 8005076:	8b3b      	ldrh	r3, [r7, #24]
 8005078:	4611      	mov	r1, r2
 800507a:	4618      	mov	r0, r3
 800507c:	f7ff fe12 	bl	8004ca4 <ILI9341_Draw_Colour_Burst>
 8005080:	e000      	b.n	8005084 <ILI9341_Draw_Rectangle+0xac>
if((X >=LCD_WIDTH) || (Y >=LCD_HEIGHT)) return;
 8005082:	bf00      	nop
}
 8005084:	370c      	adds	r7, #12
 8005086:	46bd      	mov	sp, r7
 8005088:	bd90      	pop	{r4, r7, pc}
 800508a:	bf00      	nop
 800508c:	2000000c 	.word	0x2000000c
 8005090:	2000000a 	.word	0x2000000a

08005094 <TP_Read>:
#include "ILI9341_Touchscreen.h"
#include "stm32f7xx_hal.h"

//Internal Touchpad command, do not call directly
uint16_t TP_Read(void)
{
 8005094:	b580      	push	{r7, lr}
 8005096:	b082      	sub	sp, #8
 8005098:	af00      	add	r7, sp, #0
    uint8_t i = 16;
 800509a:	2310      	movs	r3, #16
 800509c:	71fb      	strb	r3, [r7, #7]
    uint16_t value = 0;
 800509e:	2300      	movs	r3, #0
 80050a0:	80bb      	strh	r3, [r7, #4]

    while(i > 0x00)
 80050a2:	e019      	b.n	80050d8 <TP_Read+0x44>
    {
        value <<= 1;
 80050a4:	88bb      	ldrh	r3, [r7, #4]
 80050a6:	005b      	lsls	r3, r3, #1
 80050a8:	80bb      	strh	r3, [r7, #4]

				HAL_GPIO_WritePin(TP_CLK_PORT, TP_CLK_PIN, GPIO_PIN_SET);
 80050aa:	2201      	movs	r2, #1
 80050ac:	2108      	movs	r1, #8
 80050ae:	480e      	ldr	r0, [pc, #56]	; (80050e8 <TP_Read+0x54>)
 80050b0:	f7fc fcfe 	bl	8001ab0 <HAL_GPIO_WritePin>
				HAL_GPIO_WritePin(TP_CLK_PORT, TP_CLK_PIN, GPIO_PIN_RESET);
 80050b4:	2200      	movs	r2, #0
 80050b6:	2108      	movs	r1, #8
 80050b8:	480b      	ldr	r0, [pc, #44]	; (80050e8 <TP_Read+0x54>)
 80050ba:	f7fc fcf9 	bl	8001ab0 <HAL_GPIO_WritePin>
			
        if(HAL_GPIO_ReadPin(TP_MISO_PORT, TP_MISO_PIN) != 0)
 80050be:	2110      	movs	r1, #16
 80050c0:	4809      	ldr	r0, [pc, #36]	; (80050e8 <TP_Read+0x54>)
 80050c2:	f7fc fcdd 	bl	8001a80 <HAL_GPIO_ReadPin>
 80050c6:	4603      	mov	r3, r0
 80050c8:	2b00      	cmp	r3, #0
 80050ca:	d002      	beq.n	80050d2 <TP_Read+0x3e>
        {
            value++;
 80050cc:	88bb      	ldrh	r3, [r7, #4]
 80050ce:	3301      	adds	r3, #1
 80050d0:	80bb      	strh	r3, [r7, #4]
        }

        i--;
 80050d2:	79fb      	ldrb	r3, [r7, #7]
 80050d4:	3b01      	subs	r3, #1
 80050d6:	71fb      	strb	r3, [r7, #7]
    while(i > 0x00)
 80050d8:	79fb      	ldrb	r3, [r7, #7]
 80050da:	2b00      	cmp	r3, #0
 80050dc:	d1e2      	bne.n	80050a4 <TP_Read+0x10>
    };

    return value;
 80050de:	88bb      	ldrh	r3, [r7, #4]
}
 80050e0:	4618      	mov	r0, r3
 80050e2:	3708      	adds	r7, #8
 80050e4:	46bd      	mov	sp, r7
 80050e6:	bd80      	pop	{r7, pc}
 80050e8:	40021000 	.word	0x40021000

080050ec <TP_Write>:

//Internal Touchpad command, do not call directly
void TP_Write(uint8_t value)
{
 80050ec:	b580      	push	{r7, lr}
 80050ee:	b084      	sub	sp, #16
 80050f0:	af00      	add	r7, sp, #0
 80050f2:	4603      	mov	r3, r0
 80050f4:	71fb      	strb	r3, [r7, #7]
    uint8_t i = 0x08;
 80050f6:	2308      	movs	r3, #8
 80050f8:	73fb      	strb	r3, [r7, #15]

		HAL_GPIO_WritePin(TP_CLK_PORT, TP_CLK_PIN, GPIO_PIN_RESET);	
 80050fa:	2200      	movs	r2, #0
 80050fc:	2108      	movs	r1, #8
 80050fe:	4815      	ldr	r0, [pc, #84]	; (8005154 <TP_Write+0x68>)
 8005100:	f7fc fcd6 	bl	8001ab0 <HAL_GPIO_WritePin>
	
    while(i > 0)
 8005104:	e01e      	b.n	8005144 <TP_Write+0x58>
    {
        if((value & 0x80) != 0x00)
 8005106:	f997 3007 	ldrsb.w	r3, [r7, #7]
 800510a:	2b00      	cmp	r3, #0
 800510c:	da05      	bge.n	800511a <TP_Write+0x2e>
        {
						HAL_GPIO_WritePin(TP_MOSI_PORT, TP_MOSI_PIN, GPIO_PIN_SET);
 800510e:	2201      	movs	r2, #1
 8005110:	2120      	movs	r1, #32
 8005112:	4810      	ldr	r0, [pc, #64]	; (8005154 <TP_Write+0x68>)
 8005114:	f7fc fccc 	bl	8001ab0 <HAL_GPIO_WritePin>
 8005118:	e004      	b.n	8005124 <TP_Write+0x38>
        }
        else
        {
						HAL_GPIO_WritePin(TP_MOSI_PORT, TP_MOSI_PIN, GPIO_PIN_RESET);
 800511a:	2200      	movs	r2, #0
 800511c:	2120      	movs	r1, #32
 800511e:	480d      	ldr	r0, [pc, #52]	; (8005154 <TP_Write+0x68>)
 8005120:	f7fc fcc6 	bl	8001ab0 <HAL_GPIO_WritePin>
        }

        value <<= 1;
 8005124:	79fb      	ldrb	r3, [r7, #7]
 8005126:	005b      	lsls	r3, r3, #1
 8005128:	71fb      	strb	r3, [r7, #7]
				HAL_GPIO_WritePin(TP_CLK_PORT, TP_CLK_PIN, GPIO_PIN_SET);
 800512a:	2201      	movs	r2, #1
 800512c:	2108      	movs	r1, #8
 800512e:	4809      	ldr	r0, [pc, #36]	; (8005154 <TP_Write+0x68>)
 8005130:	f7fc fcbe 	bl	8001ab0 <HAL_GPIO_WritePin>
				HAL_GPIO_WritePin(TP_CLK_PORT, TP_CLK_PIN, GPIO_PIN_RESET);        
 8005134:	2200      	movs	r2, #0
 8005136:	2108      	movs	r1, #8
 8005138:	4806      	ldr	r0, [pc, #24]	; (8005154 <TP_Write+0x68>)
 800513a:	f7fc fcb9 	bl	8001ab0 <HAL_GPIO_WritePin>
        i--;
 800513e:	7bfb      	ldrb	r3, [r7, #15]
 8005140:	3b01      	subs	r3, #1
 8005142:	73fb      	strb	r3, [r7, #15]
    while(i > 0)
 8005144:	7bfb      	ldrb	r3, [r7, #15]
 8005146:	2b00      	cmp	r3, #0
 8005148:	d1dd      	bne.n	8005106 <TP_Write+0x1a>
    };
}
 800514a:	bf00      	nop
 800514c:	3710      	adds	r7, #16
 800514e:	46bd      	mov	sp, r7
 8005150:	bd80      	pop	{r7, pc}
 8005152:	bf00      	nop
 8005154:	40021000 	.word	0x40021000

08005158 <TP_Read_Coordinates>:



//Read coordinates of touchscreen press. Position[0] = X, Position[1] = Y
uint8_t TP_Read_Coordinates(uint16_t Coordinates[2])
{
 8005158:	b580      	push	{r7, lr}
 800515a:	b08a      	sub	sp, #40	; 0x28
 800515c:	af00      	add	r7, sp, #0
 800515e:	6078      	str	r0, [r7, #4]
		HAL_GPIO_WritePin(TP_CLK_PORT, TP_CLK_PIN, GPIO_PIN_SET);		
 8005160:	2201      	movs	r2, #1
 8005162:	2108      	movs	r1, #8
 8005164:	485a      	ldr	r0, [pc, #360]	; (80052d0 <TP_Read_Coordinates+0x178>)
 8005166:	f7fc fca3 	bl	8001ab0 <HAL_GPIO_WritePin>
		HAL_GPIO_WritePin(TP_MOSI_PORT, TP_MOSI_PIN, GPIO_PIN_SET);		
 800516a:	2201      	movs	r2, #1
 800516c:	2120      	movs	r1, #32
 800516e:	4858      	ldr	r0, [pc, #352]	; (80052d0 <TP_Read_Coordinates+0x178>)
 8005170:	f7fc fc9e 	bl	8001ab0 <HAL_GPIO_WritePin>
		HAL_GPIO_WritePin(TP_CS_PORT, TP_CS_PIN, GPIO_PIN_SET);		
 8005174:	2201      	movs	r2, #1
 8005176:	2140      	movs	r1, #64	; 0x40
 8005178:	4855      	ldr	r0, [pc, #340]	; (80052d0 <TP_Read_Coordinates+0x178>)
 800517a:	f7fc fc99 	bl	8001ab0 <HAL_GPIO_WritePin>

	
	
    uint32_t avg_x, avg_y = 0;		
 800517e:	2300      	movs	r3, #0
 8005180:	623b      	str	r3, [r7, #32]
		uint16_t rawx, rawy = 0;	
 8005182:	2300      	movs	r3, #0
 8005184:	81fb      	strh	r3, [r7, #14]
		uint32_t calculating_x, calculating_y = 0;
 8005186:	2300      	movs	r3, #0
 8005188:	61bb      	str	r3, [r7, #24]
	
    uint32_t samples = NO_OF_POSITION_SAMPLES;
 800518a:	f44f 737a 	mov.w	r3, #1000	; 0x3e8
 800518e:	617b      	str	r3, [r7, #20]
    uint32_t counted_samples = 0;
 8005190:	2300      	movs	r3, #0
 8005192:	613b      	str	r3, [r7, #16]

		HAL_GPIO_WritePin(TP_CS_PORT, TP_CS_PIN, GPIO_PIN_RESET);
 8005194:	2200      	movs	r2, #0
 8005196:	2140      	movs	r1, #64	; 0x40
 8005198:	484d      	ldr	r0, [pc, #308]	; (80052d0 <TP_Read_Coordinates+0x178>)
 800519a:	f7fc fc89 	bl	8001ab0 <HAL_GPIO_WritePin>

	
    while((samples > 0)&&(HAL_GPIO_ReadPin(TP_IRQ_PORT, TP_IRQ_PIN) == 0))
 800519e:	e023      	b.n	80051e8 <TP_Read_Coordinates+0x90>
    {			
        TP_Write(CMD_RDY);
 80051a0:	2090      	movs	r0, #144	; 0x90
 80051a2:	f7ff ffa3 	bl	80050ec <TP_Write>

				rawy = TP_Read();	
 80051a6:	f7ff ff75 	bl	8005094 <TP_Read>
 80051aa:	4603      	mov	r3, r0
 80051ac:	81fb      	strh	r3, [r7, #14]
				avg_y += rawy;
 80051ae:	89fb      	ldrh	r3, [r7, #14]
 80051b0:	6a3a      	ldr	r2, [r7, #32]
 80051b2:	4413      	add	r3, r2
 80051b4:	623b      	str	r3, [r7, #32]
				calculating_y += rawy;
 80051b6:	89fb      	ldrh	r3, [r7, #14]
 80051b8:	69ba      	ldr	r2, [r7, #24]
 80051ba:	4413      	add	r3, r2
 80051bc:	61bb      	str	r3, [r7, #24]

				
        TP_Write(CMD_RDX);
 80051be:	20d0      	movs	r0, #208	; 0xd0
 80051c0:	f7ff ff94 	bl	80050ec <TP_Write>
        rawx = TP_Read();
 80051c4:	f7ff ff66 	bl	8005094 <TP_Read>
 80051c8:	4603      	mov	r3, r0
 80051ca:	81bb      	strh	r3, [r7, #12]
				avg_x += rawx;
 80051cc:	89bb      	ldrh	r3, [r7, #12]
 80051ce:	6a7a      	ldr	r2, [r7, #36]	; 0x24
 80051d0:	4413      	add	r3, r2
 80051d2:	627b      	str	r3, [r7, #36]	; 0x24
				calculating_x += rawx;
 80051d4:	89bb      	ldrh	r3, [r7, #12]
 80051d6:	69fa      	ldr	r2, [r7, #28]
 80051d8:	4413      	add	r3, r2
 80051da:	61fb      	str	r3, [r7, #28]
        samples--;
 80051dc:	697b      	ldr	r3, [r7, #20]
 80051de:	3b01      	subs	r3, #1
 80051e0:	617b      	str	r3, [r7, #20]
				counted_samples++;
 80051e2:	693b      	ldr	r3, [r7, #16]
 80051e4:	3301      	adds	r3, #1
 80051e6:	613b      	str	r3, [r7, #16]
    while((samples > 0)&&(HAL_GPIO_ReadPin(TP_IRQ_PORT, TP_IRQ_PIN) == 0))
 80051e8:	697b      	ldr	r3, [r7, #20]
 80051ea:	2b00      	cmp	r3, #0
 80051ec:	d006      	beq.n	80051fc <TP_Read_Coordinates+0xa4>
 80051ee:	2104      	movs	r1, #4
 80051f0:	4837      	ldr	r0, [pc, #220]	; (80052d0 <TP_Read_Coordinates+0x178>)
 80051f2:	f7fc fc45 	bl	8001a80 <HAL_GPIO_ReadPin>
 80051f6:	4603      	mov	r3, r0
 80051f8:	2b00      	cmp	r3, #0
 80051fa:	d0d1      	beq.n	80051a0 <TP_Read_Coordinates+0x48>
    };
		
		HAL_GPIO_WritePin(TP_CS_PORT, TP_CS_PIN, GPIO_PIN_SET);
 80051fc:	2201      	movs	r2, #1
 80051fe:	2140      	movs	r1, #64	; 0x40
 8005200:	4833      	ldr	r0, [pc, #204]	; (80052d0 <TP_Read_Coordinates+0x178>)
 8005202:	f7fc fc55 	bl	8001ab0 <HAL_GPIO_WritePin>

		
		if((counted_samples == NO_OF_POSITION_SAMPLES)&&(HAL_GPIO_ReadPin(TP_IRQ_PORT, TP_IRQ_PIN) == 0))
 8005206:	693b      	ldr	r3, [r7, #16]
 8005208:	f5b3 7f7a 	cmp.w	r3, #1000	; 0x3e8
 800520c:	d14d      	bne.n	80052aa <TP_Read_Coordinates+0x152>
 800520e:	2104      	movs	r1, #4
 8005210:	482f      	ldr	r0, [pc, #188]	; (80052d0 <TP_Read_Coordinates+0x178>)
 8005212:	f7fc fc35 	bl	8001a80 <HAL_GPIO_ReadPin>
 8005216:	4603      	mov	r3, r0
 8005218:	2b00      	cmp	r3, #0
 800521a:	d146      	bne.n	80052aa <TP_Read_Coordinates+0x152>
		{
		
		calculating_x /= counted_samples;
 800521c:	69fa      	ldr	r2, [r7, #28]
 800521e:	693b      	ldr	r3, [r7, #16]
 8005220:	fbb2 f3f3 	udiv	r3, r2, r3
 8005224:	61fb      	str	r3, [r7, #28]
		calculating_y /= counted_samples;
 8005226:	69ba      	ldr	r2, [r7, #24]
 8005228:	693b      	ldr	r3, [r7, #16]
 800522a:	fbb2 f3f3 	udiv	r3, r2, r3
 800522e:	61bb      	str	r3, [r7, #24]
		
		rawx = calculating_x;
 8005230:	69fb      	ldr	r3, [r7, #28]
 8005232:	81bb      	strh	r3, [r7, #12]
		rawy = calculating_y;		
 8005234:	69bb      	ldr	r3, [r7, #24]
 8005236:	81fb      	strh	r3, [r7, #14]
		
		rawx *= -1;
 8005238:	89bb      	ldrh	r3, [r7, #12]
 800523a:	425b      	negs	r3, r3
 800523c:	81bb      	strh	r3, [r7, #12]
		rawy *= -1;
 800523e:	89fb      	ldrh	r3, [r7, #14]
 8005240:	425b      	negs	r3, r3
 8005242:	81fb      	strh	r3, [r7, #14]
		
		//CONVERTING 16bit Value to Screen coordinates
    // 65535/273 = 240!
		// 65535/204 = 320!
    Coordinates[0] = ((240 - (rawx/X_TRANSLATION)) - X_OFFSET)*X_MAGNITUDE;
 8005244:	89ba      	ldrh	r2, [r7, #12]
 8005246:	4b23      	ldr	r3, [pc, #140]	; (80052d4 <TP_Read_Coordinates+0x17c>)
 8005248:	fba3 1302 	umull	r1, r3, r3, r2
 800524c:	1ad2      	subs	r2, r2, r3
 800524e:	0852      	lsrs	r2, r2, #1
 8005250:	4413      	add	r3, r2
 8005252:	0a1b      	lsrs	r3, r3, #8
 8005254:	b29b      	uxth	r3, r3
 8005256:	f1c3 03e3 	rsb	r3, r3, #227	; 0xe3
 800525a:	ee07 3a90 	vmov	s15, r3
 800525e:	eeb8 7be7 	vcvt.f64.s32	d7, s15
 8005262:	ed9f 6b19 	vldr	d6, [pc, #100]	; 80052c8 <TP_Read_Coordinates+0x170>
 8005266:	ee27 7b06 	vmul.f64	d7, d7, d6
 800526a:	eefc 7bc7 	vcvt.u32.f64	s15, d7
 800526e:	ee17 3a90 	vmov	r3, s15
 8005272:	b29a      	uxth	r2, r3
 8005274:	687b      	ldr	r3, [r7, #4]
 8005276:	801a      	strh	r2, [r3, #0]
		Coordinates[1] = ((rawy/Y_TRANSLATION)- Y_OFFSET)*Y_MAGNITUDE;
 8005278:	89fb      	ldrh	r3, [r7, #14]
 800527a:	4a17      	ldr	r2, [pc, #92]	; (80052d8 <TP_Read_Coordinates+0x180>)
 800527c:	fba2 2303 	umull	r2, r3, r2, r3
 8005280:	09db      	lsrs	r3, r3, #7
 8005282:	b29b      	uxth	r3, r3
 8005284:	3b0f      	subs	r3, #15
 8005286:	ee07 3a90 	vmov	s15, r3
 800528a:	eeb8 7be7 	vcvt.f64.s32	d7, s15
 800528e:	ed9f 6b0e 	vldr	d6, [pc, #56]	; 80052c8 <TP_Read_Coordinates+0x170>
 8005292:	ee27 7b06 	vmul.f64	d7, d7, d6
 8005296:	687b      	ldr	r3, [r7, #4]
 8005298:	3302      	adds	r3, #2
 800529a:	eefc 7bc7 	vcvt.u32.f64	s15, d7
 800529e:	ee17 2a90 	vmov	r2, s15
 80052a2:	b292      	uxth	r2, r2
 80052a4:	801a      	strh	r2, [r3, #0]
		
		return TOUCHPAD_DATA_OK;			
 80052a6:	2301      	movs	r3, #1
 80052a8:	e007      	b.n	80052ba <TP_Read_Coordinates+0x162>
		}
		else
		{
			Coordinates[0] = 0;
 80052aa:	687b      	ldr	r3, [r7, #4]
 80052ac:	2200      	movs	r2, #0
 80052ae:	801a      	strh	r2, [r3, #0]
			Coordinates[1] = 0;
 80052b0:	687b      	ldr	r3, [r7, #4]
 80052b2:	3302      	adds	r3, #2
 80052b4:	2200      	movs	r2, #0
 80052b6:	801a      	strh	r2, [r3, #0]
			return TOUCHPAD_DATA_NOISY;
 80052b8:	2300      	movs	r3, #0
		}
}
 80052ba:	4618      	mov	r0, r3
 80052bc:	3728      	adds	r7, #40	; 0x28
 80052be:	46bd      	mov	sp, r7
 80052c0:	bd80      	pop	{r7, pc}
 80052c2:	bf00      	nop
 80052c4:	f3af 8000 	nop.w
 80052c8:	28f5c28f 	.word	0x28f5c28f
 80052cc:	3ff28f5c 	.word	0x3ff28f5c
 80052d0:	40021000 	.word	0x40021000
 80052d4:	e01e01e1 	.word	0xe01e01e1
 80052d8:	a0a0a0a1 	.word	0xa0a0a0a1

080052dc <TP_Touchpad_Pressed>:

//Check if Touchpad was pressed. Returns TOUCHPAD_PRESSED (1) or TOUCHPAD_NOT_PRESSED (0)
uint8_t TP_Touchpad_Pressed(void)
{
 80052dc:	b580      	push	{r7, lr}
 80052de:	af00      	add	r7, sp, #0
	if(HAL_GPIO_ReadPin(TP_IRQ_PORT, TP_IRQ_PIN) == 0)
 80052e0:	2104      	movs	r1, #4
 80052e2:	4805      	ldr	r0, [pc, #20]	; (80052f8 <TP_Touchpad_Pressed+0x1c>)
 80052e4:	f7fc fbcc 	bl	8001a80 <HAL_GPIO_ReadPin>
 80052e8:	4603      	mov	r3, r0
 80052ea:	2b00      	cmp	r3, #0
 80052ec:	d101      	bne.n	80052f2 <TP_Touchpad_Pressed+0x16>
	{
		return TOUCHPAD_PRESSED;
 80052ee:	2301      	movs	r3, #1
 80052f0:	e000      	b.n	80052f4 <TP_Touchpad_Pressed+0x18>
	}
	else
	{
		return TOUCHPAD_NOT_PRESSED;
 80052f2:	2300      	movs	r3, #0
	}
}
 80052f4:	4618      	mov	r0, r3
 80052f6:	bd80      	pop	{r7, pc}
 80052f8:	40021000 	.word	0x40021000

080052fc <__errno>:
 80052fc:	4b01      	ldr	r3, [pc, #4]	; (8005304 <__errno+0x8>)
 80052fe:	6818      	ldr	r0, [r3, #0]
 8005300:	4770      	bx	lr
 8005302:	bf00      	nop
 8005304:	20000010 	.word	0x20000010

08005308 <__libc_init_array>:
 8005308:	b570      	push	{r4, r5, r6, lr}
 800530a:	4e0d      	ldr	r6, [pc, #52]	; (8005340 <__libc_init_array+0x38>)
 800530c:	4c0d      	ldr	r4, [pc, #52]	; (8005344 <__libc_init_array+0x3c>)
 800530e:	1ba4      	subs	r4, r4, r6
 8005310:	10a4      	asrs	r4, r4, #2
 8005312:	2500      	movs	r5, #0
 8005314:	42a5      	cmp	r5, r4
 8005316:	d109      	bne.n	800532c <__libc_init_array+0x24>
 8005318:	4e0b      	ldr	r6, [pc, #44]	; (8005348 <__libc_init_array+0x40>)
 800531a:	4c0c      	ldr	r4, [pc, #48]	; (800534c <__libc_init_array+0x44>)
 800531c:	f003 fc90 	bl	8008c40 <_init>
 8005320:	1ba4      	subs	r4, r4, r6
 8005322:	10a4      	asrs	r4, r4, #2
 8005324:	2500      	movs	r5, #0
 8005326:	42a5      	cmp	r5, r4
 8005328:	d105      	bne.n	8005336 <__libc_init_array+0x2e>
 800532a:	bd70      	pop	{r4, r5, r6, pc}
 800532c:	f856 3025 	ldr.w	r3, [r6, r5, lsl #2]
 8005330:	4798      	blx	r3
 8005332:	3501      	adds	r5, #1
 8005334:	e7ee      	b.n	8005314 <__libc_init_array+0xc>
 8005336:	f856 3025 	ldr.w	r3, [r6, r5, lsl #2]
 800533a:	4798      	blx	r3
 800533c:	3501      	adds	r5, #1
 800533e:	e7f2      	b.n	8005326 <__libc_init_array+0x1e>
 8005340:	0802e978 	.word	0x0802e978
 8005344:	0802e978 	.word	0x0802e978
 8005348:	0802e978 	.word	0x0802e978
 800534c:	0802e97c 	.word	0x0802e97c

08005350 <memcpy>:
 8005350:	b510      	push	{r4, lr}
 8005352:	1e43      	subs	r3, r0, #1
 8005354:	440a      	add	r2, r1
 8005356:	4291      	cmp	r1, r2
 8005358:	d100      	bne.n	800535c <memcpy+0xc>
 800535a:	bd10      	pop	{r4, pc}
 800535c:	f811 4b01 	ldrb.w	r4, [r1], #1
 8005360:	f803 4f01 	strb.w	r4, [r3, #1]!
 8005364:	e7f7      	b.n	8005356 <memcpy+0x6>

08005366 <memset>:
 8005366:	4402      	add	r2, r0
 8005368:	4603      	mov	r3, r0
 800536a:	4293      	cmp	r3, r2
 800536c:	d100      	bne.n	8005370 <memset+0xa>
 800536e:	4770      	bx	lr
 8005370:	f803 1b01 	strb.w	r1, [r3], #1
 8005374:	e7f9      	b.n	800536a <memset+0x4>

08005376 <__cvt>:
 8005376:	b5f0      	push	{r4, r5, r6, r7, lr}
 8005378:	ed2d 8b02 	vpush	{d8}
 800537c:	eeb0 8b40 	vmov.f64	d8, d0
 8005380:	b085      	sub	sp, #20
 8005382:	4617      	mov	r7, r2
 8005384:	9d0d      	ldr	r5, [sp, #52]	; 0x34
 8005386:	9e0c      	ldr	r6, [sp, #48]	; 0x30
 8005388:	ee18 2a90 	vmov	r2, s17
 800538c:	f025 0520 	bic.w	r5, r5, #32
 8005390:	2a00      	cmp	r2, #0
 8005392:	bfb6      	itet	lt
 8005394:	222d      	movlt	r2, #45	; 0x2d
 8005396:	2200      	movge	r2, #0
 8005398:	eeb1 8b40 	vneglt.f64	d8, d0
 800539c:	2d46      	cmp	r5, #70	; 0x46
 800539e:	460c      	mov	r4, r1
 80053a0:	701a      	strb	r2, [r3, #0]
 80053a2:	d004      	beq.n	80053ae <__cvt+0x38>
 80053a4:	2d45      	cmp	r5, #69	; 0x45
 80053a6:	d100      	bne.n	80053aa <__cvt+0x34>
 80053a8:	3401      	adds	r4, #1
 80053aa:	2102      	movs	r1, #2
 80053ac:	e000      	b.n	80053b0 <__cvt+0x3a>
 80053ae:	2103      	movs	r1, #3
 80053b0:	ab03      	add	r3, sp, #12
 80053b2:	9301      	str	r3, [sp, #4]
 80053b4:	ab02      	add	r3, sp, #8
 80053b6:	9300      	str	r3, [sp, #0]
 80053b8:	4622      	mov	r2, r4
 80053ba:	4633      	mov	r3, r6
 80053bc:	eeb0 0b48 	vmov.f64	d0, d8
 80053c0:	f001 fd1e 	bl	8006e00 <_dtoa_r>
 80053c4:	2d47      	cmp	r5, #71	; 0x47
 80053c6:	d101      	bne.n	80053cc <__cvt+0x56>
 80053c8:	07fb      	lsls	r3, r7, #31
 80053ca:	d51e      	bpl.n	800540a <__cvt+0x94>
 80053cc:	2d46      	cmp	r5, #70	; 0x46
 80053ce:	eb00 0304 	add.w	r3, r0, r4
 80053d2:	d10c      	bne.n	80053ee <__cvt+0x78>
 80053d4:	7802      	ldrb	r2, [r0, #0]
 80053d6:	2a30      	cmp	r2, #48	; 0x30
 80053d8:	d107      	bne.n	80053ea <__cvt+0x74>
 80053da:	eeb5 8b40 	vcmp.f64	d8, #0.0
 80053de:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 80053e2:	bf1c      	itt	ne
 80053e4:	f1c4 0401 	rsbne	r4, r4, #1
 80053e8:	6034      	strne	r4, [r6, #0]
 80053ea:	6832      	ldr	r2, [r6, #0]
 80053ec:	4413      	add	r3, r2
 80053ee:	eeb5 8b40 	vcmp.f64	d8, #0.0
 80053f2:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 80053f6:	d007      	beq.n	8005408 <__cvt+0x92>
 80053f8:	2130      	movs	r1, #48	; 0x30
 80053fa:	9a03      	ldr	r2, [sp, #12]
 80053fc:	429a      	cmp	r2, r3
 80053fe:	d204      	bcs.n	800540a <__cvt+0x94>
 8005400:	1c54      	adds	r4, r2, #1
 8005402:	9403      	str	r4, [sp, #12]
 8005404:	7011      	strb	r1, [r2, #0]
 8005406:	e7f8      	b.n	80053fa <__cvt+0x84>
 8005408:	9303      	str	r3, [sp, #12]
 800540a:	9b03      	ldr	r3, [sp, #12]
 800540c:	9a0e      	ldr	r2, [sp, #56]	; 0x38
 800540e:	1a1b      	subs	r3, r3, r0
 8005410:	6013      	str	r3, [r2, #0]
 8005412:	b005      	add	sp, #20
 8005414:	ecbd 8b02 	vpop	{d8}
 8005418:	bdf0      	pop	{r4, r5, r6, r7, pc}

0800541a <__exponent>:
 800541a:	b5f7      	push	{r0, r1, r2, r4, r5, r6, r7, lr}
 800541c:	2900      	cmp	r1, #0
 800541e:	4604      	mov	r4, r0
 8005420:	bfba      	itte	lt
 8005422:	4249      	neglt	r1, r1
 8005424:	232d      	movlt	r3, #45	; 0x2d
 8005426:	232b      	movge	r3, #43	; 0x2b
 8005428:	2909      	cmp	r1, #9
 800542a:	f804 2b02 	strb.w	r2, [r4], #2
 800542e:	7043      	strb	r3, [r0, #1]
 8005430:	dd20      	ble.n	8005474 <__exponent+0x5a>
 8005432:	f10d 0307 	add.w	r3, sp, #7
 8005436:	461f      	mov	r7, r3
 8005438:	260a      	movs	r6, #10
 800543a:	fb91 f5f6 	sdiv	r5, r1, r6
 800543e:	fb06 1115 	mls	r1, r6, r5, r1
 8005442:	3130      	adds	r1, #48	; 0x30
 8005444:	2d09      	cmp	r5, #9
 8005446:	f803 1c01 	strb.w	r1, [r3, #-1]
 800544a:	f103 32ff 	add.w	r2, r3, #4294967295	; 0xffffffff
 800544e:	4629      	mov	r1, r5
 8005450:	dc09      	bgt.n	8005466 <__exponent+0x4c>
 8005452:	3130      	adds	r1, #48	; 0x30
 8005454:	3b02      	subs	r3, #2
 8005456:	f802 1c01 	strb.w	r1, [r2, #-1]
 800545a:	42bb      	cmp	r3, r7
 800545c:	4622      	mov	r2, r4
 800545e:	d304      	bcc.n	800546a <__exponent+0x50>
 8005460:	1a10      	subs	r0, r2, r0
 8005462:	b003      	add	sp, #12
 8005464:	bdf0      	pop	{r4, r5, r6, r7, pc}
 8005466:	4613      	mov	r3, r2
 8005468:	e7e7      	b.n	800543a <__exponent+0x20>
 800546a:	f813 2b01 	ldrb.w	r2, [r3], #1
 800546e:	f804 2b01 	strb.w	r2, [r4], #1
 8005472:	e7f2      	b.n	800545a <__exponent+0x40>
 8005474:	2330      	movs	r3, #48	; 0x30
 8005476:	4419      	add	r1, r3
 8005478:	7083      	strb	r3, [r0, #2]
 800547a:	1d02      	adds	r2, r0, #4
 800547c:	70c1      	strb	r1, [r0, #3]
 800547e:	e7ef      	b.n	8005460 <__exponent+0x46>

08005480 <_printf_float>:
 8005480:	e92d 4ff0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, lr}
 8005484:	b08d      	sub	sp, #52	; 0x34
 8005486:	460c      	mov	r4, r1
 8005488:	4616      	mov	r6, r2
 800548a:	461f      	mov	r7, r3
 800548c:	f8dd 8058 	ldr.w	r8, [sp, #88]	; 0x58
 8005490:	4605      	mov	r5, r0
 8005492:	f002 fd2d 	bl	8007ef0 <_localeconv_r>
 8005496:	f8d0 b000 	ldr.w	fp, [r0]
 800549a:	4658      	mov	r0, fp
 800549c:	f7fa fed0 	bl	8000240 <strlen>
 80054a0:	2300      	movs	r3, #0
 80054a2:	930a      	str	r3, [sp, #40]	; 0x28
 80054a4:	f8d8 3000 	ldr.w	r3, [r8]
 80054a8:	9005      	str	r0, [sp, #20]
 80054aa:	3307      	adds	r3, #7
 80054ac:	f023 0307 	bic.w	r3, r3, #7
 80054b0:	f103 0108 	add.w	r1, r3, #8
 80054b4:	f894 9018 	ldrb.w	r9, [r4, #24]
 80054b8:	6822      	ldr	r2, [r4, #0]
 80054ba:	f8c8 1000 	str.w	r1, [r8]
 80054be:	e9d3 0100 	ldrd	r0, r1, [r3]
 80054c2:	e9c4 0112 	strd	r0, r1, [r4, #72]	; 0x48
 80054c6:	ed9f 7ba2 	vldr	d7, [pc, #648]	; 8005750 <_printf_float+0x2d0>
 80054ca:	ed94 0b12 	vldr	d0, [r4, #72]	; 0x48
 80054ce:	eeb0 6bc0 	vabs.f64	d6, d0
 80054d2:	eeb4 6b47 	vcmp.f64	d6, d7
 80054d6:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 80054da:	dd24      	ble.n	8005526 <_printf_float+0xa6>
 80054dc:	eeb5 0bc0 	vcmpe.f64	d0, #0.0
 80054e0:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 80054e4:	d502      	bpl.n	80054ec <_printf_float+0x6c>
 80054e6:	232d      	movs	r3, #45	; 0x2d
 80054e8:	f884 3043 	strb.w	r3, [r4, #67]	; 0x43
 80054ec:	499a      	ldr	r1, [pc, #616]	; (8005758 <_printf_float+0x2d8>)
 80054ee:	4b9b      	ldr	r3, [pc, #620]	; (800575c <_printf_float+0x2dc>)
 80054f0:	f1b9 0f47 	cmp.w	r9, #71	; 0x47
 80054f4:	bf8c      	ite	hi
 80054f6:	4688      	movhi	r8, r1
 80054f8:	4698      	movls	r8, r3
 80054fa:	f022 0204 	bic.w	r2, r2, #4
 80054fe:	2303      	movs	r3, #3
 8005500:	6123      	str	r3, [r4, #16]
 8005502:	6022      	str	r2, [r4, #0]
 8005504:	f04f 0a00 	mov.w	sl, #0
 8005508:	9700      	str	r7, [sp, #0]
 800550a:	4633      	mov	r3, r6
 800550c:	aa0b      	add	r2, sp, #44	; 0x2c
 800550e:	4621      	mov	r1, r4
 8005510:	4628      	mov	r0, r5
 8005512:	f000 f9e1 	bl	80058d8 <_printf_common>
 8005516:	3001      	adds	r0, #1
 8005518:	f040 8089 	bne.w	800562e <_printf_float+0x1ae>
 800551c:	f04f 30ff 	mov.w	r0, #4294967295	; 0xffffffff
 8005520:	b00d      	add	sp, #52	; 0x34
 8005522:	e8bd 8ff0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, pc}
 8005526:	eeb4 0b40 	vcmp.f64	d0, d0
 800552a:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 800552e:	d702      	bvc.n	8005536 <_printf_float+0xb6>
 8005530:	498b      	ldr	r1, [pc, #556]	; (8005760 <_printf_float+0x2e0>)
 8005532:	4b8c      	ldr	r3, [pc, #560]	; (8005764 <_printf_float+0x2e4>)
 8005534:	e7dc      	b.n	80054f0 <_printf_float+0x70>
 8005536:	6861      	ldr	r1, [r4, #4]
 8005538:	1c4b      	adds	r3, r1, #1
 800553a:	f442 6280 	orr.w	r2, r2, #1024	; 0x400
 800553e:	ab0a      	add	r3, sp, #40	; 0x28
 8005540:	a809      	add	r0, sp, #36	; 0x24
 8005542:	d13b      	bne.n	80055bc <_printf_float+0x13c>
 8005544:	2106      	movs	r1, #6
 8005546:	6061      	str	r1, [r4, #4]
 8005548:	f04f 0c00 	mov.w	ip, #0
 800554c:	e9cd 3c02 	strd	r3, ip, [sp, #8]
 8005550:	e9cd 0900 	strd	r0, r9, [sp]
 8005554:	f10d 0323 	add.w	r3, sp, #35	; 0x23
 8005558:	6022      	str	r2, [r4, #0]
 800555a:	6861      	ldr	r1, [r4, #4]
 800555c:	4628      	mov	r0, r5
 800555e:	f7ff ff0a 	bl	8005376 <__cvt>
 8005562:	f009 03df 	and.w	r3, r9, #223	; 0xdf
 8005566:	2b47      	cmp	r3, #71	; 0x47
 8005568:	4680      	mov	r8, r0
 800556a:	d109      	bne.n	8005580 <_printf_float+0x100>
 800556c:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800556e:	1cd8      	adds	r0, r3, #3
 8005570:	db02      	blt.n	8005578 <_printf_float+0xf8>
 8005572:	6862      	ldr	r2, [r4, #4]
 8005574:	4293      	cmp	r3, r2
 8005576:	dd47      	ble.n	8005608 <_printf_float+0x188>
 8005578:	f1a9 0902 	sub.w	r9, r9, #2
 800557c:	fa5f f989 	uxtb.w	r9, r9
 8005580:	f1b9 0f65 	cmp.w	r9, #101	; 0x65
 8005584:	9909      	ldr	r1, [sp, #36]	; 0x24
 8005586:	d824      	bhi.n	80055d2 <_printf_float+0x152>
 8005588:	3901      	subs	r1, #1
 800558a:	464a      	mov	r2, r9
 800558c:	f104 0050 	add.w	r0, r4, #80	; 0x50
 8005590:	9109      	str	r1, [sp, #36]	; 0x24
 8005592:	f7ff ff42 	bl	800541a <__exponent>
 8005596:	9a0a      	ldr	r2, [sp, #40]	; 0x28
 8005598:	1813      	adds	r3, r2, r0
 800559a:	2a01      	cmp	r2, #1
 800559c:	4682      	mov	sl, r0
 800559e:	6123      	str	r3, [r4, #16]
 80055a0:	dc02      	bgt.n	80055a8 <_printf_float+0x128>
 80055a2:	6822      	ldr	r2, [r4, #0]
 80055a4:	07d1      	lsls	r1, r2, #31
 80055a6:	d501      	bpl.n	80055ac <_printf_float+0x12c>
 80055a8:	3301      	adds	r3, #1
 80055aa:	6123      	str	r3, [r4, #16]
 80055ac:	f89d 3023 	ldrb.w	r3, [sp, #35]	; 0x23
 80055b0:	2b00      	cmp	r3, #0
 80055b2:	d0a9      	beq.n	8005508 <_printf_float+0x88>
 80055b4:	232d      	movs	r3, #45	; 0x2d
 80055b6:	f884 3043 	strb.w	r3, [r4, #67]	; 0x43
 80055ba:	e7a5      	b.n	8005508 <_printf_float+0x88>
 80055bc:	f1b9 0f67 	cmp.w	r9, #103	; 0x67
 80055c0:	f000 8178 	beq.w	80058b4 <_printf_float+0x434>
 80055c4:	f1b9 0f47 	cmp.w	r9, #71	; 0x47
 80055c8:	d1be      	bne.n	8005548 <_printf_float+0xc8>
 80055ca:	2900      	cmp	r1, #0
 80055cc:	d1bc      	bne.n	8005548 <_printf_float+0xc8>
 80055ce:	2101      	movs	r1, #1
 80055d0:	e7b9      	b.n	8005546 <_printf_float+0xc6>
 80055d2:	f1b9 0f66 	cmp.w	r9, #102	; 0x66
 80055d6:	d119      	bne.n	800560c <_printf_float+0x18c>
 80055d8:	2900      	cmp	r1, #0
 80055da:	6863      	ldr	r3, [r4, #4]
 80055dc:	dd0c      	ble.n	80055f8 <_printf_float+0x178>
 80055de:	6121      	str	r1, [r4, #16]
 80055e0:	b913      	cbnz	r3, 80055e8 <_printf_float+0x168>
 80055e2:	6822      	ldr	r2, [r4, #0]
 80055e4:	07d2      	lsls	r2, r2, #31
 80055e6:	d502      	bpl.n	80055ee <_printf_float+0x16e>
 80055e8:	3301      	adds	r3, #1
 80055ea:	440b      	add	r3, r1
 80055ec:	6123      	str	r3, [r4, #16]
 80055ee:	9b09      	ldr	r3, [sp, #36]	; 0x24
 80055f0:	65a3      	str	r3, [r4, #88]	; 0x58
 80055f2:	f04f 0a00 	mov.w	sl, #0
 80055f6:	e7d9      	b.n	80055ac <_printf_float+0x12c>
 80055f8:	b913      	cbnz	r3, 8005600 <_printf_float+0x180>
 80055fa:	6822      	ldr	r2, [r4, #0]
 80055fc:	07d0      	lsls	r0, r2, #31
 80055fe:	d501      	bpl.n	8005604 <_printf_float+0x184>
 8005600:	3302      	adds	r3, #2
 8005602:	e7f3      	b.n	80055ec <_printf_float+0x16c>
 8005604:	2301      	movs	r3, #1
 8005606:	e7f1      	b.n	80055ec <_printf_float+0x16c>
 8005608:	f04f 0967 	mov.w	r9, #103	; 0x67
 800560c:	e9dd 3209 	ldrd	r3, r2, [sp, #36]	; 0x24
 8005610:	4293      	cmp	r3, r2
 8005612:	db05      	blt.n	8005620 <_printf_float+0x1a0>
 8005614:	6822      	ldr	r2, [r4, #0]
 8005616:	6123      	str	r3, [r4, #16]
 8005618:	07d1      	lsls	r1, r2, #31
 800561a:	d5e8      	bpl.n	80055ee <_printf_float+0x16e>
 800561c:	3301      	adds	r3, #1
 800561e:	e7e5      	b.n	80055ec <_printf_float+0x16c>
 8005620:	2b00      	cmp	r3, #0
 8005622:	bfd4      	ite	le
 8005624:	f1c3 0302 	rsble	r3, r3, #2
 8005628:	2301      	movgt	r3, #1
 800562a:	4413      	add	r3, r2
 800562c:	e7de      	b.n	80055ec <_printf_float+0x16c>
 800562e:	6823      	ldr	r3, [r4, #0]
 8005630:	055a      	lsls	r2, r3, #21
 8005632:	d407      	bmi.n	8005644 <_printf_float+0x1c4>
 8005634:	6923      	ldr	r3, [r4, #16]
 8005636:	4642      	mov	r2, r8
 8005638:	4631      	mov	r1, r6
 800563a:	4628      	mov	r0, r5
 800563c:	47b8      	blx	r7
 800563e:	3001      	adds	r0, #1
 8005640:	d12a      	bne.n	8005698 <_printf_float+0x218>
 8005642:	e76b      	b.n	800551c <_printf_float+0x9c>
 8005644:	f1b9 0f65 	cmp.w	r9, #101	; 0x65
 8005648:	f240 80de 	bls.w	8005808 <_printf_float+0x388>
 800564c:	ed94 7b12 	vldr	d7, [r4, #72]	; 0x48
 8005650:	eeb5 7b40 	vcmp.f64	d7, #0.0
 8005654:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 8005658:	d133      	bne.n	80056c2 <_printf_float+0x242>
 800565a:	2301      	movs	r3, #1
 800565c:	4a42      	ldr	r2, [pc, #264]	; (8005768 <_printf_float+0x2e8>)
 800565e:	4631      	mov	r1, r6
 8005660:	4628      	mov	r0, r5
 8005662:	47b8      	blx	r7
 8005664:	3001      	adds	r0, #1
 8005666:	f43f af59 	beq.w	800551c <_printf_float+0x9c>
 800566a:	e9dd 2309 	ldrd	r2, r3, [sp, #36]	; 0x24
 800566e:	429a      	cmp	r2, r3
 8005670:	db02      	blt.n	8005678 <_printf_float+0x1f8>
 8005672:	6823      	ldr	r3, [r4, #0]
 8005674:	07d8      	lsls	r0, r3, #31
 8005676:	d50f      	bpl.n	8005698 <_printf_float+0x218>
 8005678:	9b05      	ldr	r3, [sp, #20]
 800567a:	465a      	mov	r2, fp
 800567c:	4631      	mov	r1, r6
 800567e:	4628      	mov	r0, r5
 8005680:	47b8      	blx	r7
 8005682:	3001      	adds	r0, #1
 8005684:	f43f af4a 	beq.w	800551c <_printf_float+0x9c>
 8005688:	f04f 0800 	mov.w	r8, #0
 800568c:	f104 091a 	add.w	r9, r4, #26
 8005690:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 8005692:	3b01      	subs	r3, #1
 8005694:	4543      	cmp	r3, r8
 8005696:	dc09      	bgt.n	80056ac <_printf_float+0x22c>
 8005698:	6823      	ldr	r3, [r4, #0]
 800569a:	079b      	lsls	r3, r3, #30
 800569c:	f100 8105 	bmi.w	80058aa <_printf_float+0x42a>
 80056a0:	68e0      	ldr	r0, [r4, #12]
 80056a2:	9b0b      	ldr	r3, [sp, #44]	; 0x2c
 80056a4:	4298      	cmp	r0, r3
 80056a6:	bfb8      	it	lt
 80056a8:	4618      	movlt	r0, r3
 80056aa:	e739      	b.n	8005520 <_printf_float+0xa0>
 80056ac:	2301      	movs	r3, #1
 80056ae:	464a      	mov	r2, r9
 80056b0:	4631      	mov	r1, r6
 80056b2:	4628      	mov	r0, r5
 80056b4:	47b8      	blx	r7
 80056b6:	3001      	adds	r0, #1
 80056b8:	f43f af30 	beq.w	800551c <_printf_float+0x9c>
 80056bc:	f108 0801 	add.w	r8, r8, #1
 80056c0:	e7e6      	b.n	8005690 <_printf_float+0x210>
 80056c2:	9b09      	ldr	r3, [sp, #36]	; 0x24
 80056c4:	2b00      	cmp	r3, #0
 80056c6:	dc2b      	bgt.n	8005720 <_printf_float+0x2a0>
 80056c8:	2301      	movs	r3, #1
 80056ca:	4a27      	ldr	r2, [pc, #156]	; (8005768 <_printf_float+0x2e8>)
 80056cc:	4631      	mov	r1, r6
 80056ce:	4628      	mov	r0, r5
 80056d0:	47b8      	blx	r7
 80056d2:	3001      	adds	r0, #1
 80056d4:	f43f af22 	beq.w	800551c <_printf_float+0x9c>
 80056d8:	9b09      	ldr	r3, [sp, #36]	; 0x24
 80056da:	b923      	cbnz	r3, 80056e6 <_printf_float+0x266>
 80056dc:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 80056de:	b913      	cbnz	r3, 80056e6 <_printf_float+0x266>
 80056e0:	6823      	ldr	r3, [r4, #0]
 80056e2:	07d9      	lsls	r1, r3, #31
 80056e4:	d5d8      	bpl.n	8005698 <_printf_float+0x218>
 80056e6:	9b05      	ldr	r3, [sp, #20]
 80056e8:	465a      	mov	r2, fp
 80056ea:	4631      	mov	r1, r6
 80056ec:	4628      	mov	r0, r5
 80056ee:	47b8      	blx	r7
 80056f0:	3001      	adds	r0, #1
 80056f2:	f43f af13 	beq.w	800551c <_printf_float+0x9c>
 80056f6:	f04f 0900 	mov.w	r9, #0
 80056fa:	f104 0a1a 	add.w	sl, r4, #26
 80056fe:	9b09      	ldr	r3, [sp, #36]	; 0x24
 8005700:	425b      	negs	r3, r3
 8005702:	454b      	cmp	r3, r9
 8005704:	dc01      	bgt.n	800570a <_printf_float+0x28a>
 8005706:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 8005708:	e795      	b.n	8005636 <_printf_float+0x1b6>
 800570a:	2301      	movs	r3, #1
 800570c:	4652      	mov	r2, sl
 800570e:	4631      	mov	r1, r6
 8005710:	4628      	mov	r0, r5
 8005712:	47b8      	blx	r7
 8005714:	3001      	adds	r0, #1
 8005716:	f43f af01 	beq.w	800551c <_printf_float+0x9c>
 800571a:	f109 0901 	add.w	r9, r9, #1
 800571e:	e7ee      	b.n	80056fe <_printf_float+0x27e>
 8005720:	9a0a      	ldr	r2, [sp, #40]	; 0x28
 8005722:	6da3      	ldr	r3, [r4, #88]	; 0x58
 8005724:	429a      	cmp	r2, r3
 8005726:	bfa8      	it	ge
 8005728:	461a      	movge	r2, r3
 800572a:	2a00      	cmp	r2, #0
 800572c:	4691      	mov	r9, r2
 800572e:	dd07      	ble.n	8005740 <_printf_float+0x2c0>
 8005730:	4613      	mov	r3, r2
 8005732:	4631      	mov	r1, r6
 8005734:	4642      	mov	r2, r8
 8005736:	4628      	mov	r0, r5
 8005738:	47b8      	blx	r7
 800573a:	3001      	adds	r0, #1
 800573c:	f43f aeee 	beq.w	800551c <_printf_float+0x9c>
 8005740:	f104 031a 	add.w	r3, r4, #26
 8005744:	f04f 0a00 	mov.w	sl, #0
 8005748:	ea29 79e9 	bic.w	r9, r9, r9, asr #31
 800574c:	9307      	str	r3, [sp, #28]
 800574e:	e017      	b.n	8005780 <_printf_float+0x300>
 8005750:	ffffffff 	.word	0xffffffff
 8005754:	7fefffff 	.word	0x7fefffff
 8005758:	0802e6c0 	.word	0x0802e6c0
 800575c:	0802e6bc 	.word	0x0802e6bc
 8005760:	0802e6c8 	.word	0x0802e6c8
 8005764:	0802e6c4 	.word	0x0802e6c4
 8005768:	0802e6cc 	.word	0x0802e6cc
 800576c:	2301      	movs	r3, #1
 800576e:	9a07      	ldr	r2, [sp, #28]
 8005770:	4631      	mov	r1, r6
 8005772:	4628      	mov	r0, r5
 8005774:	47b8      	blx	r7
 8005776:	3001      	adds	r0, #1
 8005778:	f43f aed0 	beq.w	800551c <_printf_float+0x9c>
 800577c:	f10a 0a01 	add.w	sl, sl, #1
 8005780:	6da3      	ldr	r3, [r4, #88]	; 0x58
 8005782:	9306      	str	r3, [sp, #24]
 8005784:	eba3 0309 	sub.w	r3, r3, r9
 8005788:	4553      	cmp	r3, sl
 800578a:	dcef      	bgt.n	800576c <_printf_float+0x2ec>
 800578c:	9b06      	ldr	r3, [sp, #24]
 800578e:	4498      	add	r8, r3
 8005790:	e9dd 2309 	ldrd	r2, r3, [sp, #36]	; 0x24
 8005794:	429a      	cmp	r2, r3
 8005796:	db15      	blt.n	80057c4 <_printf_float+0x344>
 8005798:	6823      	ldr	r3, [r4, #0]
 800579a:	07da      	lsls	r2, r3, #31
 800579c:	d412      	bmi.n	80057c4 <_printf_float+0x344>
 800579e:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 80057a0:	9a06      	ldr	r2, [sp, #24]
 80057a2:	9909      	ldr	r1, [sp, #36]	; 0x24
 80057a4:	1a9a      	subs	r2, r3, r2
 80057a6:	eba3 0a01 	sub.w	sl, r3, r1
 80057aa:	4592      	cmp	sl, r2
 80057ac:	bfa8      	it	ge
 80057ae:	4692      	movge	sl, r2
 80057b0:	f1ba 0f00 	cmp.w	sl, #0
 80057b4:	dc0e      	bgt.n	80057d4 <_printf_float+0x354>
 80057b6:	f04f 0800 	mov.w	r8, #0
 80057ba:	ea2a 7aea 	bic.w	sl, sl, sl, asr #31
 80057be:	f104 091a 	add.w	r9, r4, #26
 80057c2:	e019      	b.n	80057f8 <_printf_float+0x378>
 80057c4:	9b05      	ldr	r3, [sp, #20]
 80057c6:	465a      	mov	r2, fp
 80057c8:	4631      	mov	r1, r6
 80057ca:	4628      	mov	r0, r5
 80057cc:	47b8      	blx	r7
 80057ce:	3001      	adds	r0, #1
 80057d0:	d1e5      	bne.n	800579e <_printf_float+0x31e>
 80057d2:	e6a3      	b.n	800551c <_printf_float+0x9c>
 80057d4:	4653      	mov	r3, sl
 80057d6:	4642      	mov	r2, r8
 80057d8:	4631      	mov	r1, r6
 80057da:	4628      	mov	r0, r5
 80057dc:	47b8      	blx	r7
 80057de:	3001      	adds	r0, #1
 80057e0:	d1e9      	bne.n	80057b6 <_printf_float+0x336>
 80057e2:	e69b      	b.n	800551c <_printf_float+0x9c>
 80057e4:	2301      	movs	r3, #1
 80057e6:	464a      	mov	r2, r9
 80057e8:	4631      	mov	r1, r6
 80057ea:	4628      	mov	r0, r5
 80057ec:	47b8      	blx	r7
 80057ee:	3001      	adds	r0, #1
 80057f0:	f43f ae94 	beq.w	800551c <_printf_float+0x9c>
 80057f4:	f108 0801 	add.w	r8, r8, #1
 80057f8:	e9dd 2309 	ldrd	r2, r3, [sp, #36]	; 0x24
 80057fc:	1a9b      	subs	r3, r3, r2
 80057fe:	eba3 030a 	sub.w	r3, r3, sl
 8005802:	4543      	cmp	r3, r8
 8005804:	dcee      	bgt.n	80057e4 <_printf_float+0x364>
 8005806:	e747      	b.n	8005698 <_printf_float+0x218>
 8005808:	9a0a      	ldr	r2, [sp, #40]	; 0x28
 800580a:	2a01      	cmp	r2, #1
 800580c:	dc01      	bgt.n	8005812 <_printf_float+0x392>
 800580e:	07db      	lsls	r3, r3, #31
 8005810:	d539      	bpl.n	8005886 <_printf_float+0x406>
 8005812:	2301      	movs	r3, #1
 8005814:	4642      	mov	r2, r8
 8005816:	4631      	mov	r1, r6
 8005818:	4628      	mov	r0, r5
 800581a:	47b8      	blx	r7
 800581c:	3001      	adds	r0, #1
 800581e:	f43f ae7d 	beq.w	800551c <_printf_float+0x9c>
 8005822:	9b05      	ldr	r3, [sp, #20]
 8005824:	465a      	mov	r2, fp
 8005826:	4631      	mov	r1, r6
 8005828:	4628      	mov	r0, r5
 800582a:	47b8      	blx	r7
 800582c:	3001      	adds	r0, #1
 800582e:	f108 0801 	add.w	r8, r8, #1
 8005832:	f43f ae73 	beq.w	800551c <_printf_float+0x9c>
 8005836:	ed94 7b12 	vldr	d7, [r4, #72]	; 0x48
 800583a:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 800583c:	eeb5 7b40 	vcmp.f64	d7, #0.0
 8005840:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 8005844:	f103 33ff 	add.w	r3, r3, #4294967295	; 0xffffffff
 8005848:	d018      	beq.n	800587c <_printf_float+0x3fc>
 800584a:	4642      	mov	r2, r8
 800584c:	4631      	mov	r1, r6
 800584e:	4628      	mov	r0, r5
 8005850:	47b8      	blx	r7
 8005852:	3001      	adds	r0, #1
 8005854:	d10e      	bne.n	8005874 <_printf_float+0x3f4>
 8005856:	e661      	b.n	800551c <_printf_float+0x9c>
 8005858:	2301      	movs	r3, #1
 800585a:	464a      	mov	r2, r9
 800585c:	4631      	mov	r1, r6
 800585e:	4628      	mov	r0, r5
 8005860:	47b8      	blx	r7
 8005862:	3001      	adds	r0, #1
 8005864:	f43f ae5a 	beq.w	800551c <_printf_float+0x9c>
 8005868:	f108 0801 	add.w	r8, r8, #1
 800586c:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 800586e:	3b01      	subs	r3, #1
 8005870:	4543      	cmp	r3, r8
 8005872:	dcf1      	bgt.n	8005858 <_printf_float+0x3d8>
 8005874:	4653      	mov	r3, sl
 8005876:	f104 0250 	add.w	r2, r4, #80	; 0x50
 800587a:	e6dd      	b.n	8005638 <_printf_float+0x1b8>
 800587c:	f04f 0800 	mov.w	r8, #0
 8005880:	f104 091a 	add.w	r9, r4, #26
 8005884:	e7f2      	b.n	800586c <_printf_float+0x3ec>
 8005886:	2301      	movs	r3, #1
 8005888:	e7df      	b.n	800584a <_printf_float+0x3ca>
 800588a:	2301      	movs	r3, #1
 800588c:	464a      	mov	r2, r9
 800588e:	4631      	mov	r1, r6
 8005890:	4628      	mov	r0, r5
 8005892:	47b8      	blx	r7
 8005894:	3001      	adds	r0, #1
 8005896:	f43f ae41 	beq.w	800551c <_printf_float+0x9c>
 800589a:	f108 0801 	add.w	r8, r8, #1
 800589e:	68e3      	ldr	r3, [r4, #12]
 80058a0:	9a0b      	ldr	r2, [sp, #44]	; 0x2c
 80058a2:	1a9b      	subs	r3, r3, r2
 80058a4:	4543      	cmp	r3, r8
 80058a6:	dcf0      	bgt.n	800588a <_printf_float+0x40a>
 80058a8:	e6fa      	b.n	80056a0 <_printf_float+0x220>
 80058aa:	f04f 0800 	mov.w	r8, #0
 80058ae:	f104 0919 	add.w	r9, r4, #25
 80058b2:	e7f4      	b.n	800589e <_printf_float+0x41e>
 80058b4:	2900      	cmp	r1, #0
 80058b6:	f43f ae8a 	beq.w	80055ce <_printf_float+0x14e>
 80058ba:	f04f 0c00 	mov.w	ip, #0
 80058be:	e9cd 3c02 	strd	r3, ip, [sp, #8]
 80058c2:	e9cd 0900 	strd	r0, r9, [sp]
 80058c6:	6022      	str	r2, [r4, #0]
 80058c8:	f10d 0323 	add.w	r3, sp, #35	; 0x23
 80058cc:	4628      	mov	r0, r5
 80058ce:	f7ff fd52 	bl	8005376 <__cvt>
 80058d2:	4680      	mov	r8, r0
 80058d4:	e64a      	b.n	800556c <_printf_float+0xec>
 80058d6:	bf00      	nop

080058d8 <_printf_common>:
 80058d8:	e92d 47f0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, lr}
 80058dc:	4691      	mov	r9, r2
 80058de:	461f      	mov	r7, r3
 80058e0:	688a      	ldr	r2, [r1, #8]
 80058e2:	690b      	ldr	r3, [r1, #16]
 80058e4:	f8dd 8020 	ldr.w	r8, [sp, #32]
 80058e8:	4293      	cmp	r3, r2
 80058ea:	bfb8      	it	lt
 80058ec:	4613      	movlt	r3, r2
 80058ee:	f8c9 3000 	str.w	r3, [r9]
 80058f2:	f891 2043 	ldrb.w	r2, [r1, #67]	; 0x43
 80058f6:	4606      	mov	r6, r0
 80058f8:	460c      	mov	r4, r1
 80058fa:	b112      	cbz	r2, 8005902 <_printf_common+0x2a>
 80058fc:	3301      	adds	r3, #1
 80058fe:	f8c9 3000 	str.w	r3, [r9]
 8005902:	6823      	ldr	r3, [r4, #0]
 8005904:	0699      	lsls	r1, r3, #26
 8005906:	bf42      	ittt	mi
 8005908:	f8d9 3000 	ldrmi.w	r3, [r9]
 800590c:	3302      	addmi	r3, #2
 800590e:	f8c9 3000 	strmi.w	r3, [r9]
 8005912:	6825      	ldr	r5, [r4, #0]
 8005914:	f015 0506 	ands.w	r5, r5, #6
 8005918:	d107      	bne.n	800592a <_printf_common+0x52>
 800591a:	f104 0a19 	add.w	sl, r4, #25
 800591e:	68e3      	ldr	r3, [r4, #12]
 8005920:	f8d9 2000 	ldr.w	r2, [r9]
 8005924:	1a9b      	subs	r3, r3, r2
 8005926:	42ab      	cmp	r3, r5
 8005928:	dc28      	bgt.n	800597c <_printf_common+0xa4>
 800592a:	f894 3043 	ldrb.w	r3, [r4, #67]	; 0x43
 800592e:	6822      	ldr	r2, [r4, #0]
 8005930:	3300      	adds	r3, #0
 8005932:	bf18      	it	ne
 8005934:	2301      	movne	r3, #1
 8005936:	0692      	lsls	r2, r2, #26
 8005938:	d42d      	bmi.n	8005996 <_printf_common+0xbe>
 800593a:	f104 0243 	add.w	r2, r4, #67	; 0x43
 800593e:	4639      	mov	r1, r7
 8005940:	4630      	mov	r0, r6
 8005942:	47c0      	blx	r8
 8005944:	3001      	adds	r0, #1
 8005946:	d020      	beq.n	800598a <_printf_common+0xb2>
 8005948:	6823      	ldr	r3, [r4, #0]
 800594a:	68e5      	ldr	r5, [r4, #12]
 800594c:	f8d9 2000 	ldr.w	r2, [r9]
 8005950:	f003 0306 	and.w	r3, r3, #6
 8005954:	2b04      	cmp	r3, #4
 8005956:	bf08      	it	eq
 8005958:	1aad      	subeq	r5, r5, r2
 800595a:	68a3      	ldr	r3, [r4, #8]
 800595c:	6922      	ldr	r2, [r4, #16]
 800595e:	bf0c      	ite	eq
 8005960:	ea25 75e5 	biceq.w	r5, r5, r5, asr #31
 8005964:	2500      	movne	r5, #0
 8005966:	4293      	cmp	r3, r2
 8005968:	bfc4      	itt	gt
 800596a:	1a9b      	subgt	r3, r3, r2
 800596c:	18ed      	addgt	r5, r5, r3
 800596e:	f04f 0900 	mov.w	r9, #0
 8005972:	341a      	adds	r4, #26
 8005974:	454d      	cmp	r5, r9
 8005976:	d11a      	bne.n	80059ae <_printf_common+0xd6>
 8005978:	2000      	movs	r0, #0
 800597a:	e008      	b.n	800598e <_printf_common+0xb6>
 800597c:	2301      	movs	r3, #1
 800597e:	4652      	mov	r2, sl
 8005980:	4639      	mov	r1, r7
 8005982:	4630      	mov	r0, r6
 8005984:	47c0      	blx	r8
 8005986:	3001      	adds	r0, #1
 8005988:	d103      	bne.n	8005992 <_printf_common+0xba>
 800598a:	f04f 30ff 	mov.w	r0, #4294967295	; 0xffffffff
 800598e:	e8bd 87f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, pc}
 8005992:	3501      	adds	r5, #1
 8005994:	e7c3      	b.n	800591e <_printf_common+0x46>
 8005996:	18e1      	adds	r1, r4, r3
 8005998:	1c5a      	adds	r2, r3, #1
 800599a:	2030      	movs	r0, #48	; 0x30
 800599c:	f881 0043 	strb.w	r0, [r1, #67]	; 0x43
 80059a0:	4422      	add	r2, r4
 80059a2:	f894 1045 	ldrb.w	r1, [r4, #69]	; 0x45
 80059a6:	f882 1043 	strb.w	r1, [r2, #67]	; 0x43
 80059aa:	3302      	adds	r3, #2
 80059ac:	e7c5      	b.n	800593a <_printf_common+0x62>
 80059ae:	2301      	movs	r3, #1
 80059b0:	4622      	mov	r2, r4
 80059b2:	4639      	mov	r1, r7
 80059b4:	4630      	mov	r0, r6
 80059b6:	47c0      	blx	r8
 80059b8:	3001      	adds	r0, #1
 80059ba:	d0e6      	beq.n	800598a <_printf_common+0xb2>
 80059bc:	f109 0901 	add.w	r9, r9, #1
 80059c0:	e7d8      	b.n	8005974 <_printf_common+0x9c>
	...

080059c4 <_printf_i>:
 80059c4:	e92d 43f0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, lr}
 80059c8:	f101 0c43 	add.w	ip, r1, #67	; 0x43
 80059cc:	460c      	mov	r4, r1
 80059ce:	7e09      	ldrb	r1, [r1, #24]
 80059d0:	b085      	sub	sp, #20
 80059d2:	296e      	cmp	r1, #110	; 0x6e
 80059d4:	4617      	mov	r7, r2
 80059d6:	4606      	mov	r6, r0
 80059d8:	4698      	mov	r8, r3
 80059da:	9a0c      	ldr	r2, [sp, #48]	; 0x30
 80059dc:	f000 80b3 	beq.w	8005b46 <_printf_i+0x182>
 80059e0:	d822      	bhi.n	8005a28 <_printf_i+0x64>
 80059e2:	2963      	cmp	r1, #99	; 0x63
 80059e4:	d036      	beq.n	8005a54 <_printf_i+0x90>
 80059e6:	d80a      	bhi.n	80059fe <_printf_i+0x3a>
 80059e8:	2900      	cmp	r1, #0
 80059ea:	f000 80b9 	beq.w	8005b60 <_printf_i+0x19c>
 80059ee:	2958      	cmp	r1, #88	; 0x58
 80059f0:	f000 8083 	beq.w	8005afa <_printf_i+0x136>
 80059f4:	f104 0542 	add.w	r5, r4, #66	; 0x42
 80059f8:	f884 1042 	strb.w	r1, [r4, #66]	; 0x42
 80059fc:	e032      	b.n	8005a64 <_printf_i+0xa0>
 80059fe:	2964      	cmp	r1, #100	; 0x64
 8005a00:	d001      	beq.n	8005a06 <_printf_i+0x42>
 8005a02:	2969      	cmp	r1, #105	; 0x69
 8005a04:	d1f6      	bne.n	80059f4 <_printf_i+0x30>
 8005a06:	6820      	ldr	r0, [r4, #0]
 8005a08:	6813      	ldr	r3, [r2, #0]
 8005a0a:	0605      	lsls	r5, r0, #24
 8005a0c:	f103 0104 	add.w	r1, r3, #4
 8005a10:	d52a      	bpl.n	8005a68 <_printf_i+0xa4>
 8005a12:	681b      	ldr	r3, [r3, #0]
 8005a14:	6011      	str	r1, [r2, #0]
 8005a16:	2b00      	cmp	r3, #0
 8005a18:	da03      	bge.n	8005a22 <_printf_i+0x5e>
 8005a1a:	222d      	movs	r2, #45	; 0x2d
 8005a1c:	425b      	negs	r3, r3
 8005a1e:	f884 2043 	strb.w	r2, [r4, #67]	; 0x43
 8005a22:	486f      	ldr	r0, [pc, #444]	; (8005be0 <_printf_i+0x21c>)
 8005a24:	220a      	movs	r2, #10
 8005a26:	e039      	b.n	8005a9c <_printf_i+0xd8>
 8005a28:	2973      	cmp	r1, #115	; 0x73
 8005a2a:	f000 809d 	beq.w	8005b68 <_printf_i+0x1a4>
 8005a2e:	d808      	bhi.n	8005a42 <_printf_i+0x7e>
 8005a30:	296f      	cmp	r1, #111	; 0x6f
 8005a32:	d020      	beq.n	8005a76 <_printf_i+0xb2>
 8005a34:	2970      	cmp	r1, #112	; 0x70
 8005a36:	d1dd      	bne.n	80059f4 <_printf_i+0x30>
 8005a38:	6823      	ldr	r3, [r4, #0]
 8005a3a:	f043 0320 	orr.w	r3, r3, #32
 8005a3e:	6023      	str	r3, [r4, #0]
 8005a40:	e003      	b.n	8005a4a <_printf_i+0x86>
 8005a42:	2975      	cmp	r1, #117	; 0x75
 8005a44:	d017      	beq.n	8005a76 <_printf_i+0xb2>
 8005a46:	2978      	cmp	r1, #120	; 0x78
 8005a48:	d1d4      	bne.n	80059f4 <_printf_i+0x30>
 8005a4a:	2378      	movs	r3, #120	; 0x78
 8005a4c:	f884 3045 	strb.w	r3, [r4, #69]	; 0x45
 8005a50:	4864      	ldr	r0, [pc, #400]	; (8005be4 <_printf_i+0x220>)
 8005a52:	e055      	b.n	8005b00 <_printf_i+0x13c>
 8005a54:	6813      	ldr	r3, [r2, #0]
 8005a56:	1d19      	adds	r1, r3, #4
 8005a58:	681b      	ldr	r3, [r3, #0]
 8005a5a:	6011      	str	r1, [r2, #0]
 8005a5c:	f104 0542 	add.w	r5, r4, #66	; 0x42
 8005a60:	f884 3042 	strb.w	r3, [r4, #66]	; 0x42
 8005a64:	2301      	movs	r3, #1
 8005a66:	e08c      	b.n	8005b82 <_printf_i+0x1be>
 8005a68:	681b      	ldr	r3, [r3, #0]
 8005a6a:	6011      	str	r1, [r2, #0]
 8005a6c:	f010 0f40 	tst.w	r0, #64	; 0x40
 8005a70:	bf18      	it	ne
 8005a72:	b21b      	sxthne	r3, r3
 8005a74:	e7cf      	b.n	8005a16 <_printf_i+0x52>
 8005a76:	6813      	ldr	r3, [r2, #0]
 8005a78:	6825      	ldr	r5, [r4, #0]
 8005a7a:	1d18      	adds	r0, r3, #4
 8005a7c:	6010      	str	r0, [r2, #0]
 8005a7e:	0628      	lsls	r0, r5, #24
 8005a80:	d501      	bpl.n	8005a86 <_printf_i+0xc2>
 8005a82:	681b      	ldr	r3, [r3, #0]
 8005a84:	e002      	b.n	8005a8c <_printf_i+0xc8>
 8005a86:	0668      	lsls	r0, r5, #25
 8005a88:	d5fb      	bpl.n	8005a82 <_printf_i+0xbe>
 8005a8a:	881b      	ldrh	r3, [r3, #0]
 8005a8c:	4854      	ldr	r0, [pc, #336]	; (8005be0 <_printf_i+0x21c>)
 8005a8e:	296f      	cmp	r1, #111	; 0x6f
 8005a90:	bf14      	ite	ne
 8005a92:	220a      	movne	r2, #10
 8005a94:	2208      	moveq	r2, #8
 8005a96:	2100      	movs	r1, #0
 8005a98:	f884 1043 	strb.w	r1, [r4, #67]	; 0x43
 8005a9c:	6865      	ldr	r5, [r4, #4]
 8005a9e:	60a5      	str	r5, [r4, #8]
 8005aa0:	2d00      	cmp	r5, #0
 8005aa2:	f2c0 8095 	blt.w	8005bd0 <_printf_i+0x20c>
 8005aa6:	6821      	ldr	r1, [r4, #0]
 8005aa8:	f021 0104 	bic.w	r1, r1, #4
 8005aac:	6021      	str	r1, [r4, #0]
 8005aae:	2b00      	cmp	r3, #0
 8005ab0:	d13d      	bne.n	8005b2e <_printf_i+0x16a>
 8005ab2:	2d00      	cmp	r5, #0
 8005ab4:	f040 808e 	bne.w	8005bd4 <_printf_i+0x210>
 8005ab8:	4665      	mov	r5, ip
 8005aba:	2a08      	cmp	r2, #8
 8005abc:	d10b      	bne.n	8005ad6 <_printf_i+0x112>
 8005abe:	6823      	ldr	r3, [r4, #0]
 8005ac0:	07db      	lsls	r3, r3, #31
 8005ac2:	d508      	bpl.n	8005ad6 <_printf_i+0x112>
 8005ac4:	6923      	ldr	r3, [r4, #16]
 8005ac6:	6862      	ldr	r2, [r4, #4]
 8005ac8:	429a      	cmp	r2, r3
 8005aca:	bfde      	ittt	le
 8005acc:	2330      	movle	r3, #48	; 0x30
 8005ace:	f805 3c01 	strble.w	r3, [r5, #-1]
 8005ad2:	f105 35ff 	addle.w	r5, r5, #4294967295	; 0xffffffff
 8005ad6:	ebac 0305 	sub.w	r3, ip, r5
 8005ada:	6123      	str	r3, [r4, #16]
 8005adc:	f8cd 8000 	str.w	r8, [sp]
 8005ae0:	463b      	mov	r3, r7
 8005ae2:	aa03      	add	r2, sp, #12
 8005ae4:	4621      	mov	r1, r4
 8005ae6:	4630      	mov	r0, r6
 8005ae8:	f7ff fef6 	bl	80058d8 <_printf_common>
 8005aec:	3001      	adds	r0, #1
 8005aee:	d14d      	bne.n	8005b8c <_printf_i+0x1c8>
 8005af0:	f04f 30ff 	mov.w	r0, #4294967295	; 0xffffffff
 8005af4:	b005      	add	sp, #20
 8005af6:	e8bd 83f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, pc}
 8005afa:	4839      	ldr	r0, [pc, #228]	; (8005be0 <_printf_i+0x21c>)
 8005afc:	f884 1045 	strb.w	r1, [r4, #69]	; 0x45
 8005b00:	6813      	ldr	r3, [r2, #0]
 8005b02:	6821      	ldr	r1, [r4, #0]
 8005b04:	1d1d      	adds	r5, r3, #4
 8005b06:	681b      	ldr	r3, [r3, #0]
 8005b08:	6015      	str	r5, [r2, #0]
 8005b0a:	060a      	lsls	r2, r1, #24
 8005b0c:	d50b      	bpl.n	8005b26 <_printf_i+0x162>
 8005b0e:	07ca      	lsls	r2, r1, #31
 8005b10:	bf44      	itt	mi
 8005b12:	f041 0120 	orrmi.w	r1, r1, #32
 8005b16:	6021      	strmi	r1, [r4, #0]
 8005b18:	b91b      	cbnz	r3, 8005b22 <_printf_i+0x15e>
 8005b1a:	6822      	ldr	r2, [r4, #0]
 8005b1c:	f022 0220 	bic.w	r2, r2, #32
 8005b20:	6022      	str	r2, [r4, #0]
 8005b22:	2210      	movs	r2, #16
 8005b24:	e7b7      	b.n	8005a96 <_printf_i+0xd2>
 8005b26:	064d      	lsls	r5, r1, #25
 8005b28:	bf48      	it	mi
 8005b2a:	b29b      	uxthmi	r3, r3
 8005b2c:	e7ef      	b.n	8005b0e <_printf_i+0x14a>
 8005b2e:	4665      	mov	r5, ip
 8005b30:	fbb3 f1f2 	udiv	r1, r3, r2
 8005b34:	fb02 3311 	mls	r3, r2, r1, r3
 8005b38:	5cc3      	ldrb	r3, [r0, r3]
 8005b3a:	f805 3d01 	strb.w	r3, [r5, #-1]!
 8005b3e:	460b      	mov	r3, r1
 8005b40:	2900      	cmp	r1, #0
 8005b42:	d1f5      	bne.n	8005b30 <_printf_i+0x16c>
 8005b44:	e7b9      	b.n	8005aba <_printf_i+0xf6>
 8005b46:	6813      	ldr	r3, [r2, #0]
 8005b48:	6825      	ldr	r5, [r4, #0]
 8005b4a:	6961      	ldr	r1, [r4, #20]
 8005b4c:	1d18      	adds	r0, r3, #4
 8005b4e:	6010      	str	r0, [r2, #0]
 8005b50:	0628      	lsls	r0, r5, #24
 8005b52:	681b      	ldr	r3, [r3, #0]
 8005b54:	d501      	bpl.n	8005b5a <_printf_i+0x196>
 8005b56:	6019      	str	r1, [r3, #0]
 8005b58:	e002      	b.n	8005b60 <_printf_i+0x19c>
 8005b5a:	066a      	lsls	r2, r5, #25
 8005b5c:	d5fb      	bpl.n	8005b56 <_printf_i+0x192>
 8005b5e:	8019      	strh	r1, [r3, #0]
 8005b60:	2300      	movs	r3, #0
 8005b62:	6123      	str	r3, [r4, #16]
 8005b64:	4665      	mov	r5, ip
 8005b66:	e7b9      	b.n	8005adc <_printf_i+0x118>
 8005b68:	6813      	ldr	r3, [r2, #0]
 8005b6a:	1d19      	adds	r1, r3, #4
 8005b6c:	6011      	str	r1, [r2, #0]
 8005b6e:	681d      	ldr	r5, [r3, #0]
 8005b70:	6862      	ldr	r2, [r4, #4]
 8005b72:	2100      	movs	r1, #0
 8005b74:	4628      	mov	r0, r5
 8005b76:	f7fa fb6b 	bl	8000250 <memchr>
 8005b7a:	b108      	cbz	r0, 8005b80 <_printf_i+0x1bc>
 8005b7c:	1b40      	subs	r0, r0, r5
 8005b7e:	6060      	str	r0, [r4, #4]
 8005b80:	6863      	ldr	r3, [r4, #4]
 8005b82:	6123      	str	r3, [r4, #16]
 8005b84:	2300      	movs	r3, #0
 8005b86:	f884 3043 	strb.w	r3, [r4, #67]	; 0x43
 8005b8a:	e7a7      	b.n	8005adc <_printf_i+0x118>
 8005b8c:	6923      	ldr	r3, [r4, #16]
 8005b8e:	462a      	mov	r2, r5
 8005b90:	4639      	mov	r1, r7
 8005b92:	4630      	mov	r0, r6
 8005b94:	47c0      	blx	r8
 8005b96:	3001      	adds	r0, #1
 8005b98:	d0aa      	beq.n	8005af0 <_printf_i+0x12c>
 8005b9a:	6823      	ldr	r3, [r4, #0]
 8005b9c:	079b      	lsls	r3, r3, #30
 8005b9e:	d413      	bmi.n	8005bc8 <_printf_i+0x204>
 8005ba0:	68e0      	ldr	r0, [r4, #12]
 8005ba2:	9b03      	ldr	r3, [sp, #12]
 8005ba4:	4298      	cmp	r0, r3
 8005ba6:	bfb8      	it	lt
 8005ba8:	4618      	movlt	r0, r3
 8005baa:	e7a3      	b.n	8005af4 <_printf_i+0x130>
 8005bac:	2301      	movs	r3, #1
 8005bae:	464a      	mov	r2, r9
 8005bb0:	4639      	mov	r1, r7
 8005bb2:	4630      	mov	r0, r6
 8005bb4:	47c0      	blx	r8
 8005bb6:	3001      	adds	r0, #1
 8005bb8:	d09a      	beq.n	8005af0 <_printf_i+0x12c>
 8005bba:	3501      	adds	r5, #1
 8005bbc:	68e3      	ldr	r3, [r4, #12]
 8005bbe:	9a03      	ldr	r2, [sp, #12]
 8005bc0:	1a9b      	subs	r3, r3, r2
 8005bc2:	42ab      	cmp	r3, r5
 8005bc4:	dcf2      	bgt.n	8005bac <_printf_i+0x1e8>
 8005bc6:	e7eb      	b.n	8005ba0 <_printf_i+0x1dc>
 8005bc8:	2500      	movs	r5, #0
 8005bca:	f104 0919 	add.w	r9, r4, #25
 8005bce:	e7f5      	b.n	8005bbc <_printf_i+0x1f8>
 8005bd0:	2b00      	cmp	r3, #0
 8005bd2:	d1ac      	bne.n	8005b2e <_printf_i+0x16a>
 8005bd4:	7803      	ldrb	r3, [r0, #0]
 8005bd6:	f884 3042 	strb.w	r3, [r4, #66]	; 0x42
 8005bda:	f104 0542 	add.w	r5, r4, #66	; 0x42
 8005bde:	e76c      	b.n	8005aba <_printf_i+0xf6>
 8005be0:	0802e6ce 	.word	0x0802e6ce
 8005be4:	0802e6df 	.word	0x0802e6df

08005be8 <_scanf_float>:
 8005be8:	e92d 4ff0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, lr}
 8005bec:	469a      	mov	sl, r3
 8005bee:	688b      	ldr	r3, [r1, #8]
 8005bf0:	4616      	mov	r6, r2
 8005bf2:	1e5a      	subs	r2, r3, #1
 8005bf4:	f5b2 7fae 	cmp.w	r2, #348	; 0x15c
 8005bf8:	b087      	sub	sp, #28
 8005bfa:	bf83      	ittte	hi
 8005bfc:	f46f 72ae 	mvnhi.w	r2, #348	; 0x15c
 8005c00:	189b      	addhi	r3, r3, r2
 8005c02:	9301      	strhi	r3, [sp, #4]
 8005c04:	2300      	movls	r3, #0
 8005c06:	bf86      	itte	hi
 8005c08:	f240 135d 	movwhi	r3, #349	; 0x15d
 8005c0c:	608b      	strhi	r3, [r1, #8]
 8005c0e:	9301      	strls	r3, [sp, #4]
 8005c10:	680b      	ldr	r3, [r1, #0]
 8005c12:	4688      	mov	r8, r1
 8005c14:	f04f 0b00 	mov.w	fp, #0
 8005c18:	f443 63f0 	orr.w	r3, r3, #1920	; 0x780
 8005c1c:	f848 3b1c 	str.w	r3, [r8], #28
 8005c20:	e9cd bb03 	strd	fp, fp, [sp, #12]
 8005c24:	4607      	mov	r7, r0
 8005c26:	460c      	mov	r4, r1
 8005c28:	4645      	mov	r5, r8
 8005c2a:	465a      	mov	r2, fp
 8005c2c:	46d9      	mov	r9, fp
 8005c2e:	f8cd b008 	str.w	fp, [sp, #8]
 8005c32:	68a1      	ldr	r1, [r4, #8]
 8005c34:	b181      	cbz	r1, 8005c58 <_scanf_float+0x70>
 8005c36:	6833      	ldr	r3, [r6, #0]
 8005c38:	781b      	ldrb	r3, [r3, #0]
 8005c3a:	2b49      	cmp	r3, #73	; 0x49
 8005c3c:	d071      	beq.n	8005d22 <_scanf_float+0x13a>
 8005c3e:	d84d      	bhi.n	8005cdc <_scanf_float+0xf4>
 8005c40:	2b39      	cmp	r3, #57	; 0x39
 8005c42:	d840      	bhi.n	8005cc6 <_scanf_float+0xde>
 8005c44:	2b31      	cmp	r3, #49	; 0x31
 8005c46:	f080 8088 	bcs.w	8005d5a <_scanf_float+0x172>
 8005c4a:	2b2d      	cmp	r3, #45	; 0x2d
 8005c4c:	f000 8090 	beq.w	8005d70 <_scanf_float+0x188>
 8005c50:	d815      	bhi.n	8005c7e <_scanf_float+0x96>
 8005c52:	2b2b      	cmp	r3, #43	; 0x2b
 8005c54:	f000 808c 	beq.w	8005d70 <_scanf_float+0x188>
 8005c58:	f1b9 0f00 	cmp.w	r9, #0
 8005c5c:	d003      	beq.n	8005c66 <_scanf_float+0x7e>
 8005c5e:	6823      	ldr	r3, [r4, #0]
 8005c60:	f423 7380 	bic.w	r3, r3, #256	; 0x100
 8005c64:	6023      	str	r3, [r4, #0]
 8005c66:	3a01      	subs	r2, #1
 8005c68:	2a01      	cmp	r2, #1
 8005c6a:	f200 80ea 	bhi.w	8005e42 <_scanf_float+0x25a>
 8005c6e:	4545      	cmp	r5, r8
 8005c70:	f200 80dc 	bhi.w	8005e2c <_scanf_float+0x244>
 8005c74:	2601      	movs	r6, #1
 8005c76:	4630      	mov	r0, r6
 8005c78:	b007      	add	sp, #28
 8005c7a:	e8bd 8ff0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, pc}
 8005c7e:	2b2e      	cmp	r3, #46	; 0x2e
 8005c80:	f000 809f 	beq.w	8005dc2 <_scanf_float+0x1da>
 8005c84:	2b30      	cmp	r3, #48	; 0x30
 8005c86:	d1e7      	bne.n	8005c58 <_scanf_float+0x70>
 8005c88:	6820      	ldr	r0, [r4, #0]
 8005c8a:	f410 7f80 	tst.w	r0, #256	; 0x100
 8005c8e:	d064      	beq.n	8005d5a <_scanf_float+0x172>
 8005c90:	9b01      	ldr	r3, [sp, #4]
 8005c92:	f020 0080 	bic.w	r0, r0, #128	; 0x80
 8005c96:	6020      	str	r0, [r4, #0]
 8005c98:	f109 0901 	add.w	r9, r9, #1
 8005c9c:	b11b      	cbz	r3, 8005ca6 <_scanf_float+0xbe>
 8005c9e:	3b01      	subs	r3, #1
 8005ca0:	3101      	adds	r1, #1
 8005ca2:	9301      	str	r3, [sp, #4]
 8005ca4:	60a1      	str	r1, [r4, #8]
 8005ca6:	68a3      	ldr	r3, [r4, #8]
 8005ca8:	3b01      	subs	r3, #1
 8005caa:	60a3      	str	r3, [r4, #8]
 8005cac:	6923      	ldr	r3, [r4, #16]
 8005cae:	3301      	adds	r3, #1
 8005cb0:	6123      	str	r3, [r4, #16]
 8005cb2:	6873      	ldr	r3, [r6, #4]
 8005cb4:	3b01      	subs	r3, #1
 8005cb6:	2b00      	cmp	r3, #0
 8005cb8:	6073      	str	r3, [r6, #4]
 8005cba:	f340 80ac 	ble.w	8005e16 <_scanf_float+0x22e>
 8005cbe:	6833      	ldr	r3, [r6, #0]
 8005cc0:	3301      	adds	r3, #1
 8005cc2:	6033      	str	r3, [r6, #0]
 8005cc4:	e7b5      	b.n	8005c32 <_scanf_float+0x4a>
 8005cc6:	2b45      	cmp	r3, #69	; 0x45
 8005cc8:	f000 8085 	beq.w	8005dd6 <_scanf_float+0x1ee>
 8005ccc:	2b46      	cmp	r3, #70	; 0x46
 8005cce:	d06a      	beq.n	8005da6 <_scanf_float+0x1be>
 8005cd0:	2b41      	cmp	r3, #65	; 0x41
 8005cd2:	d1c1      	bne.n	8005c58 <_scanf_float+0x70>
 8005cd4:	2a01      	cmp	r2, #1
 8005cd6:	d1bf      	bne.n	8005c58 <_scanf_float+0x70>
 8005cd8:	2202      	movs	r2, #2
 8005cda:	e046      	b.n	8005d6a <_scanf_float+0x182>
 8005cdc:	2b65      	cmp	r3, #101	; 0x65
 8005cde:	d07a      	beq.n	8005dd6 <_scanf_float+0x1ee>
 8005ce0:	d818      	bhi.n	8005d14 <_scanf_float+0x12c>
 8005ce2:	2b54      	cmp	r3, #84	; 0x54
 8005ce4:	d066      	beq.n	8005db4 <_scanf_float+0x1cc>
 8005ce6:	d811      	bhi.n	8005d0c <_scanf_float+0x124>
 8005ce8:	2b4e      	cmp	r3, #78	; 0x4e
 8005cea:	d1b5      	bne.n	8005c58 <_scanf_float+0x70>
 8005cec:	2a00      	cmp	r2, #0
 8005cee:	d146      	bne.n	8005d7e <_scanf_float+0x196>
 8005cf0:	f1b9 0f00 	cmp.w	r9, #0
 8005cf4:	d145      	bne.n	8005d82 <_scanf_float+0x19a>
 8005cf6:	6821      	ldr	r1, [r4, #0]
 8005cf8:	f401 60e0 	and.w	r0, r1, #1792	; 0x700
 8005cfc:	f5b0 6fe0 	cmp.w	r0, #1792	; 0x700
 8005d00:	d13f      	bne.n	8005d82 <_scanf_float+0x19a>
 8005d02:	f421 61f0 	bic.w	r1, r1, #1920	; 0x780
 8005d06:	6021      	str	r1, [r4, #0]
 8005d08:	2201      	movs	r2, #1
 8005d0a:	e02e      	b.n	8005d6a <_scanf_float+0x182>
 8005d0c:	2b59      	cmp	r3, #89	; 0x59
 8005d0e:	d01e      	beq.n	8005d4e <_scanf_float+0x166>
 8005d10:	2b61      	cmp	r3, #97	; 0x61
 8005d12:	e7de      	b.n	8005cd2 <_scanf_float+0xea>
 8005d14:	2b6e      	cmp	r3, #110	; 0x6e
 8005d16:	d0e9      	beq.n	8005cec <_scanf_float+0x104>
 8005d18:	d815      	bhi.n	8005d46 <_scanf_float+0x15e>
 8005d1a:	2b66      	cmp	r3, #102	; 0x66
 8005d1c:	d043      	beq.n	8005da6 <_scanf_float+0x1be>
 8005d1e:	2b69      	cmp	r3, #105	; 0x69
 8005d20:	d19a      	bne.n	8005c58 <_scanf_float+0x70>
 8005d22:	f1bb 0f00 	cmp.w	fp, #0
 8005d26:	d138      	bne.n	8005d9a <_scanf_float+0x1b2>
 8005d28:	f1b9 0f00 	cmp.w	r9, #0
 8005d2c:	d197      	bne.n	8005c5e <_scanf_float+0x76>
 8005d2e:	6821      	ldr	r1, [r4, #0]
 8005d30:	f401 60e0 	and.w	r0, r1, #1792	; 0x700
 8005d34:	f5b0 6fe0 	cmp.w	r0, #1792	; 0x700
 8005d38:	d195      	bne.n	8005c66 <_scanf_float+0x7e>
 8005d3a:	f421 61f0 	bic.w	r1, r1, #1920	; 0x780
 8005d3e:	6021      	str	r1, [r4, #0]
 8005d40:	f04f 0b01 	mov.w	fp, #1
 8005d44:	e011      	b.n	8005d6a <_scanf_float+0x182>
 8005d46:	2b74      	cmp	r3, #116	; 0x74
 8005d48:	d034      	beq.n	8005db4 <_scanf_float+0x1cc>
 8005d4a:	2b79      	cmp	r3, #121	; 0x79
 8005d4c:	d184      	bne.n	8005c58 <_scanf_float+0x70>
 8005d4e:	f1bb 0f07 	cmp.w	fp, #7
 8005d52:	d181      	bne.n	8005c58 <_scanf_float+0x70>
 8005d54:	f04f 0b08 	mov.w	fp, #8
 8005d58:	e007      	b.n	8005d6a <_scanf_float+0x182>
 8005d5a:	eb12 0f0b 	cmn.w	r2, fp
 8005d5e:	f47f af7b 	bne.w	8005c58 <_scanf_float+0x70>
 8005d62:	6821      	ldr	r1, [r4, #0]
 8005d64:	f421 71c0 	bic.w	r1, r1, #384	; 0x180
 8005d68:	6021      	str	r1, [r4, #0]
 8005d6a:	702b      	strb	r3, [r5, #0]
 8005d6c:	3501      	adds	r5, #1
 8005d6e:	e79a      	b.n	8005ca6 <_scanf_float+0xbe>
 8005d70:	6821      	ldr	r1, [r4, #0]
 8005d72:	0608      	lsls	r0, r1, #24
 8005d74:	f57f af70 	bpl.w	8005c58 <_scanf_float+0x70>
 8005d78:	f021 0180 	bic.w	r1, r1, #128	; 0x80
 8005d7c:	e7f4      	b.n	8005d68 <_scanf_float+0x180>
 8005d7e:	2a02      	cmp	r2, #2
 8005d80:	d047      	beq.n	8005e12 <_scanf_float+0x22a>
 8005d82:	f1bb 0f01 	cmp.w	fp, #1
 8005d86:	d003      	beq.n	8005d90 <_scanf_float+0x1a8>
 8005d88:	f1bb 0f04 	cmp.w	fp, #4
 8005d8c:	f47f af64 	bne.w	8005c58 <_scanf_float+0x70>
 8005d90:	f10b 0b01 	add.w	fp, fp, #1
 8005d94:	fa5f fb8b 	uxtb.w	fp, fp
 8005d98:	e7e7      	b.n	8005d6a <_scanf_float+0x182>
 8005d9a:	f1bb 0f03 	cmp.w	fp, #3
 8005d9e:	d0f7      	beq.n	8005d90 <_scanf_float+0x1a8>
 8005da0:	f1bb 0f05 	cmp.w	fp, #5
 8005da4:	e7f2      	b.n	8005d8c <_scanf_float+0x1a4>
 8005da6:	f1bb 0f02 	cmp.w	fp, #2
 8005daa:	f47f af55 	bne.w	8005c58 <_scanf_float+0x70>
 8005dae:	f04f 0b03 	mov.w	fp, #3
 8005db2:	e7da      	b.n	8005d6a <_scanf_float+0x182>
 8005db4:	f1bb 0f06 	cmp.w	fp, #6
 8005db8:	f47f af4e 	bne.w	8005c58 <_scanf_float+0x70>
 8005dbc:	f04f 0b07 	mov.w	fp, #7
 8005dc0:	e7d3      	b.n	8005d6a <_scanf_float+0x182>
 8005dc2:	6821      	ldr	r1, [r4, #0]
 8005dc4:	0588      	lsls	r0, r1, #22
 8005dc6:	f57f af47 	bpl.w	8005c58 <_scanf_float+0x70>
 8005dca:	f421 7120 	bic.w	r1, r1, #640	; 0x280
 8005dce:	6021      	str	r1, [r4, #0]
 8005dd0:	f8cd 9008 	str.w	r9, [sp, #8]
 8005dd4:	e7c9      	b.n	8005d6a <_scanf_float+0x182>
 8005dd6:	6821      	ldr	r1, [r4, #0]
 8005dd8:	f401 60a0 	and.w	r0, r1, #1280	; 0x500
 8005ddc:	f5b0 6f80 	cmp.w	r0, #1024	; 0x400
 8005de0:	d006      	beq.n	8005df0 <_scanf_float+0x208>
 8005de2:	0548      	lsls	r0, r1, #21
 8005de4:	f57f af38 	bpl.w	8005c58 <_scanf_float+0x70>
 8005de8:	f1b9 0f00 	cmp.w	r9, #0
 8005dec:	f43f af3b 	beq.w	8005c66 <_scanf_float+0x7e>
 8005df0:	0588      	lsls	r0, r1, #22
 8005df2:	bf58      	it	pl
 8005df4:	9802      	ldrpl	r0, [sp, #8]
 8005df6:	f421 61f0 	bic.w	r1, r1, #1920	; 0x780
 8005dfa:	bf58      	it	pl
 8005dfc:	eba9 0000 	subpl.w	r0, r9, r0
 8005e00:	f441 71c0 	orr.w	r1, r1, #384	; 0x180
 8005e04:	bf58      	it	pl
 8005e06:	e9cd 0503 	strdpl	r0, r5, [sp, #12]
 8005e0a:	6021      	str	r1, [r4, #0]
 8005e0c:	f04f 0900 	mov.w	r9, #0
 8005e10:	e7ab      	b.n	8005d6a <_scanf_float+0x182>
 8005e12:	2203      	movs	r2, #3
 8005e14:	e7a9      	b.n	8005d6a <_scanf_float+0x182>
 8005e16:	f8d4 3180 	ldr.w	r3, [r4, #384]	; 0x180
 8005e1a:	9205      	str	r2, [sp, #20]
 8005e1c:	4631      	mov	r1, r6
 8005e1e:	4638      	mov	r0, r7
 8005e20:	4798      	blx	r3
 8005e22:	9a05      	ldr	r2, [sp, #20]
 8005e24:	2800      	cmp	r0, #0
 8005e26:	f43f af04 	beq.w	8005c32 <_scanf_float+0x4a>
 8005e2a:	e715      	b.n	8005c58 <_scanf_float+0x70>
 8005e2c:	f8d4 317c 	ldr.w	r3, [r4, #380]	; 0x17c
 8005e30:	f815 1d01 	ldrb.w	r1, [r5, #-1]!
 8005e34:	4632      	mov	r2, r6
 8005e36:	4638      	mov	r0, r7
 8005e38:	4798      	blx	r3
 8005e3a:	6923      	ldr	r3, [r4, #16]
 8005e3c:	3b01      	subs	r3, #1
 8005e3e:	6123      	str	r3, [r4, #16]
 8005e40:	e715      	b.n	8005c6e <_scanf_float+0x86>
 8005e42:	f10b 33ff 	add.w	r3, fp, #4294967295	; 0xffffffff
 8005e46:	2b06      	cmp	r3, #6
 8005e48:	d80a      	bhi.n	8005e60 <_scanf_float+0x278>
 8005e4a:	f1bb 0f02 	cmp.w	fp, #2
 8005e4e:	d966      	bls.n	8005f1e <_scanf_float+0x336>
 8005e50:	f1ab 0b03 	sub.w	fp, fp, #3
 8005e54:	fa5f fb8b 	uxtb.w	fp, fp
 8005e58:	eba5 0b0b 	sub.w	fp, r5, fp
 8005e5c:	455d      	cmp	r5, fp
 8005e5e:	d149      	bne.n	8005ef4 <_scanf_float+0x30c>
 8005e60:	6823      	ldr	r3, [r4, #0]
 8005e62:	05da      	lsls	r2, r3, #23
 8005e64:	d51f      	bpl.n	8005ea6 <_scanf_float+0x2be>
 8005e66:	055b      	lsls	r3, r3, #21
 8005e68:	d466      	bmi.n	8005f38 <_scanf_float+0x350>
 8005e6a:	f815 1c01 	ldrb.w	r1, [r5, #-1]
 8005e6e:	6923      	ldr	r3, [r4, #16]
 8005e70:	2965      	cmp	r1, #101	; 0x65
 8005e72:	f103 33ff 	add.w	r3, r3, #4294967295	; 0xffffffff
 8005e76:	f105 3bff 	add.w	fp, r5, #4294967295	; 0xffffffff
 8005e7a:	6123      	str	r3, [r4, #16]
 8005e7c:	d00d      	beq.n	8005e9a <_scanf_float+0x2b2>
 8005e7e:	2945      	cmp	r1, #69	; 0x45
 8005e80:	d00b      	beq.n	8005e9a <_scanf_float+0x2b2>
 8005e82:	f8d4 317c 	ldr.w	r3, [r4, #380]	; 0x17c
 8005e86:	4632      	mov	r2, r6
 8005e88:	4638      	mov	r0, r7
 8005e8a:	4798      	blx	r3
 8005e8c:	6923      	ldr	r3, [r4, #16]
 8005e8e:	f815 1c02 	ldrb.w	r1, [r5, #-2]
 8005e92:	3b01      	subs	r3, #1
 8005e94:	f1a5 0b02 	sub.w	fp, r5, #2
 8005e98:	6123      	str	r3, [r4, #16]
 8005e9a:	f8d4 317c 	ldr.w	r3, [r4, #380]	; 0x17c
 8005e9e:	4632      	mov	r2, r6
 8005ea0:	4638      	mov	r0, r7
 8005ea2:	4798      	blx	r3
 8005ea4:	465d      	mov	r5, fp
 8005ea6:	6826      	ldr	r6, [r4, #0]
 8005ea8:	f016 0610 	ands.w	r6, r6, #16
 8005eac:	d170      	bne.n	8005f90 <_scanf_float+0x3a8>
 8005eae:	702e      	strb	r6, [r5, #0]
 8005eb0:	6823      	ldr	r3, [r4, #0]
 8005eb2:	f403 63c0 	and.w	r3, r3, #1536	; 0x600
 8005eb6:	f5b3 6f80 	cmp.w	r3, #1024	; 0x400
 8005eba:	d140      	bne.n	8005f3e <_scanf_float+0x356>
 8005ebc:	9b02      	ldr	r3, [sp, #8]
 8005ebe:	eba9 0303 	sub.w	r3, r9, r3
 8005ec2:	425a      	negs	r2, r3
 8005ec4:	2b00      	cmp	r3, #0
 8005ec6:	d147      	bne.n	8005f58 <_scanf_float+0x370>
 8005ec8:	2200      	movs	r2, #0
 8005eca:	4638      	mov	r0, r7
 8005ecc:	4641      	mov	r1, r8
 8005ece:	f000 fe6b 	bl	8006ba8 <_strtod_r>
 8005ed2:	6820      	ldr	r0, [r4, #0]
 8005ed4:	f8da 3000 	ldr.w	r3, [sl]
 8005ed8:	f010 0f02 	tst.w	r0, #2
 8005edc:	f103 0204 	add.w	r2, r3, #4
 8005ee0:	f8ca 2000 	str.w	r2, [sl]
 8005ee4:	d043      	beq.n	8005f6e <_scanf_float+0x386>
 8005ee6:	681b      	ldr	r3, [r3, #0]
 8005ee8:	ed83 0b00 	vstr	d0, [r3]
 8005eec:	68e3      	ldr	r3, [r4, #12]
 8005eee:	3301      	adds	r3, #1
 8005ef0:	60e3      	str	r3, [r4, #12]
 8005ef2:	e6c0      	b.n	8005c76 <_scanf_float+0x8e>
 8005ef4:	f8d4 317c 	ldr.w	r3, [r4, #380]	; 0x17c
 8005ef8:	f815 1d01 	ldrb.w	r1, [r5, #-1]!
 8005efc:	4632      	mov	r2, r6
 8005efe:	4638      	mov	r0, r7
 8005f00:	4798      	blx	r3
 8005f02:	6923      	ldr	r3, [r4, #16]
 8005f04:	3b01      	subs	r3, #1
 8005f06:	6123      	str	r3, [r4, #16]
 8005f08:	e7a8      	b.n	8005e5c <_scanf_float+0x274>
 8005f0a:	f8d4 317c 	ldr.w	r3, [r4, #380]	; 0x17c
 8005f0e:	f815 1d01 	ldrb.w	r1, [r5, #-1]!
 8005f12:	4632      	mov	r2, r6
 8005f14:	4638      	mov	r0, r7
 8005f16:	4798      	blx	r3
 8005f18:	6923      	ldr	r3, [r4, #16]
 8005f1a:	3b01      	subs	r3, #1
 8005f1c:	6123      	str	r3, [r4, #16]
 8005f1e:	4545      	cmp	r5, r8
 8005f20:	d8f3      	bhi.n	8005f0a <_scanf_float+0x322>
 8005f22:	e6a7      	b.n	8005c74 <_scanf_float+0x8c>
 8005f24:	f8d4 317c 	ldr.w	r3, [r4, #380]	; 0x17c
 8005f28:	f815 1d01 	ldrb.w	r1, [r5, #-1]!
 8005f2c:	4632      	mov	r2, r6
 8005f2e:	4638      	mov	r0, r7
 8005f30:	4798      	blx	r3
 8005f32:	6923      	ldr	r3, [r4, #16]
 8005f34:	3b01      	subs	r3, #1
 8005f36:	6123      	str	r3, [r4, #16]
 8005f38:	4545      	cmp	r5, r8
 8005f3a:	d8f3      	bhi.n	8005f24 <_scanf_float+0x33c>
 8005f3c:	e69a      	b.n	8005c74 <_scanf_float+0x8c>
 8005f3e:	9b03      	ldr	r3, [sp, #12]
 8005f40:	2b00      	cmp	r3, #0
 8005f42:	d0c1      	beq.n	8005ec8 <_scanf_float+0x2e0>
 8005f44:	9904      	ldr	r1, [sp, #16]
 8005f46:	230a      	movs	r3, #10
 8005f48:	4632      	mov	r2, r6
 8005f4a:	3101      	adds	r1, #1
 8005f4c:	4638      	mov	r0, r7
 8005f4e:	f000 feb7 	bl	8006cc0 <_strtol_r>
 8005f52:	9b03      	ldr	r3, [sp, #12]
 8005f54:	9d04      	ldr	r5, [sp, #16]
 8005f56:	1ac2      	subs	r2, r0, r3
 8005f58:	f204 136f 	addw	r3, r4, #367	; 0x16f
 8005f5c:	429d      	cmp	r5, r3
 8005f5e:	bf28      	it	cs
 8005f60:	f504 75b7 	addcs.w	r5, r4, #366	; 0x16e
 8005f64:	490b      	ldr	r1, [pc, #44]	; (8005f94 <_scanf_float+0x3ac>)
 8005f66:	4628      	mov	r0, r5
 8005f68:	f000 f81c 	bl	8005fa4 <siprintf>
 8005f6c:	e7ac      	b.n	8005ec8 <_scanf_float+0x2e0>
 8005f6e:	f010 0004 	ands.w	r0, r0, #4
 8005f72:	d1b8      	bne.n	8005ee6 <_scanf_float+0x2fe>
 8005f74:	eeb4 0b40 	vcmp.f64	d0, d0
 8005f78:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 8005f7c:	681d      	ldr	r5, [r3, #0]
 8005f7e:	d704      	bvc.n	8005f8a <_scanf_float+0x3a2>
 8005f80:	f000 f80a 	bl	8005f98 <nanf>
 8005f84:	ed85 0a00 	vstr	s0, [r5]
 8005f88:	e7b0      	b.n	8005eec <_scanf_float+0x304>
 8005f8a:	eeb7 0bc0 	vcvt.f32.f64	s0, d0
 8005f8e:	e7f9      	b.n	8005f84 <_scanf_float+0x39c>
 8005f90:	2600      	movs	r6, #0
 8005f92:	e670      	b.n	8005c76 <_scanf_float+0x8e>
 8005f94:	0802e6f0 	.word	0x0802e6f0

08005f98 <nanf>:
 8005f98:	ed9f 0a01 	vldr	s0, [pc, #4]	; 8005fa0 <nanf+0x8>
 8005f9c:	4770      	bx	lr
 8005f9e:	bf00      	nop
 8005fa0:	7fc00000 	.word	0x7fc00000

08005fa4 <siprintf>:
 8005fa4:	b40e      	push	{r1, r2, r3}
 8005fa6:	b500      	push	{lr}
 8005fa8:	b09c      	sub	sp, #112	; 0x70
 8005faa:	ab1d      	add	r3, sp, #116	; 0x74
 8005fac:	9002      	str	r0, [sp, #8]
 8005fae:	9006      	str	r0, [sp, #24]
 8005fb0:	f06f 4100 	mvn.w	r1, #2147483648	; 0x80000000
 8005fb4:	4809      	ldr	r0, [pc, #36]	; (8005fdc <siprintf+0x38>)
 8005fb6:	9107      	str	r1, [sp, #28]
 8005fb8:	9104      	str	r1, [sp, #16]
 8005fba:	4909      	ldr	r1, [pc, #36]	; (8005fe0 <siprintf+0x3c>)
 8005fbc:	f853 2b04 	ldr.w	r2, [r3], #4
 8005fc0:	9105      	str	r1, [sp, #20]
 8005fc2:	6800      	ldr	r0, [r0, #0]
 8005fc4:	9301      	str	r3, [sp, #4]
 8005fc6:	a902      	add	r1, sp, #8
 8005fc8:	f002 fcca 	bl	8008960 <_svfiprintf_r>
 8005fcc:	9b02      	ldr	r3, [sp, #8]
 8005fce:	2200      	movs	r2, #0
 8005fd0:	701a      	strb	r2, [r3, #0]
 8005fd2:	b01c      	add	sp, #112	; 0x70
 8005fd4:	f85d eb04 	ldr.w	lr, [sp], #4
 8005fd8:	b003      	add	sp, #12
 8005fda:	4770      	bx	lr
 8005fdc:	20000010 	.word	0x20000010
 8005fe0:	ffff0208 	.word	0xffff0208

08005fe4 <sulp>:
 8005fe4:	b570      	push	{r4, r5, r6, lr}
 8005fe6:	4604      	mov	r4, r0
 8005fe8:	460d      	mov	r5, r1
 8005fea:	4616      	mov	r6, r2
 8005fec:	ec45 4b10 	vmov	d0, r4, r5
 8005ff0:	f002 fa72 	bl	80084d8 <__ulp>
 8005ff4:	b17e      	cbz	r6, 8006016 <sulp+0x32>
 8005ff6:	f3c5 530a 	ubfx	r3, r5, #20, #11
 8005ffa:	f1c3 036b 	rsb	r3, r3, #107	; 0x6b
 8005ffe:	2b00      	cmp	r3, #0
 8006000:	dd09      	ble.n	8006016 <sulp+0x32>
 8006002:	051b      	lsls	r3, r3, #20
 8006004:	f103 517f 	add.w	r1, r3, #1069547520	; 0x3fc00000
 8006008:	2000      	movs	r0, #0
 800600a:	f501 1140 	add.w	r1, r1, #3145728	; 0x300000
 800600e:	ec41 0b17 	vmov	d7, r0, r1
 8006012:	ee20 0b07 	vmul.f64	d0, d0, d7
 8006016:	bd70      	pop	{r4, r5, r6, pc}

08006018 <_strtod_l>:
 8006018:	e92d 4ff0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, lr}
 800601c:	ed2d 8b0c 	vpush	{d8-d13}
 8006020:	4698      	mov	r8, r3
 8006022:	b09d      	sub	sp, #116	; 0x74
 8006024:	2300      	movs	r3, #0
 8006026:	4604      	mov	r4, r0
 8006028:	4640      	mov	r0, r8
 800602a:	460e      	mov	r6, r1
 800602c:	9214      	str	r2, [sp, #80]	; 0x50
 800602e:	9318      	str	r3, [sp, #96]	; 0x60
 8006030:	f001 ff5b 	bl	8007eea <__localeconv_l>
 8006034:	4681      	mov	r9, r0
 8006036:	6800      	ldr	r0, [r0, #0]
 8006038:	f7fa f902 	bl	8000240 <strlen>
 800603c:	f04f 0a00 	mov.w	sl, #0
 8006040:	4607      	mov	r7, r0
 8006042:	f04f 0b00 	mov.w	fp, #0
 8006046:	9617      	str	r6, [sp, #92]	; 0x5c
 8006048:	9b17      	ldr	r3, [sp, #92]	; 0x5c
 800604a:	781a      	ldrb	r2, [r3, #0]
 800604c:	2a0d      	cmp	r2, #13
 800604e:	d834      	bhi.n	80060ba <_strtod_l+0xa2>
 8006050:	2a09      	cmp	r2, #9
 8006052:	d238      	bcs.n	80060c6 <_strtod_l+0xae>
 8006054:	2a00      	cmp	r2, #0
 8006056:	d040      	beq.n	80060da <_strtod_l+0xc2>
 8006058:	2300      	movs	r3, #0
 800605a:	930d      	str	r3, [sp, #52]	; 0x34
 800605c:	9d17      	ldr	r5, [sp, #92]	; 0x5c
 800605e:	782b      	ldrb	r3, [r5, #0]
 8006060:	2b30      	cmp	r3, #48	; 0x30
 8006062:	f040 80b3 	bne.w	80061cc <_strtod_l+0x1b4>
 8006066:	786b      	ldrb	r3, [r5, #1]
 8006068:	2b58      	cmp	r3, #88	; 0x58
 800606a:	d001      	beq.n	8006070 <_strtod_l+0x58>
 800606c:	2b78      	cmp	r3, #120	; 0x78
 800606e:	d169      	bne.n	8006144 <_strtod_l+0x12c>
 8006070:	9b0d      	ldr	r3, [sp, #52]	; 0x34
 8006072:	9301      	str	r3, [sp, #4]
 8006074:	ab18      	add	r3, sp, #96	; 0x60
 8006076:	9300      	str	r3, [sp, #0]
 8006078:	f8cd 8008 	str.w	r8, [sp, #8]
 800607c:	ab19      	add	r3, sp, #100	; 0x64
 800607e:	4a8f      	ldr	r2, [pc, #572]	; (80062bc <_strtod_l+0x2a4>)
 8006080:	a917      	add	r1, sp, #92	; 0x5c
 8006082:	4620      	mov	r0, r4
 8006084:	f001 fc57 	bl	8007936 <__gethex>
 8006088:	f010 0607 	ands.w	r6, r0, #7
 800608c:	4607      	mov	r7, r0
 800608e:	d005      	beq.n	800609c <_strtod_l+0x84>
 8006090:	2e06      	cmp	r6, #6
 8006092:	d12c      	bne.n	80060ee <_strtod_l+0xd6>
 8006094:	3501      	adds	r5, #1
 8006096:	2300      	movs	r3, #0
 8006098:	9517      	str	r5, [sp, #92]	; 0x5c
 800609a:	930d      	str	r3, [sp, #52]	; 0x34
 800609c:	9b14      	ldr	r3, [sp, #80]	; 0x50
 800609e:	2b00      	cmp	r3, #0
 80060a0:	f040 855e 	bne.w	8006b60 <_strtod_l+0xb48>
 80060a4:	9b0d      	ldr	r3, [sp, #52]	; 0x34
 80060a6:	b1eb      	cbz	r3, 80060e4 <_strtod_l+0xcc>
 80060a8:	ec4b ab17 	vmov	d7, sl, fp
 80060ac:	eeb1 0b47 	vneg.f64	d0, d7
 80060b0:	b01d      	add	sp, #116	; 0x74
 80060b2:	ecbd 8b0c 	vpop	{d8-d13}
 80060b6:	e8bd 8ff0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, pc}
 80060ba:	2a2b      	cmp	r2, #43	; 0x2b
 80060bc:	d015      	beq.n	80060ea <_strtod_l+0xd2>
 80060be:	2a2d      	cmp	r2, #45	; 0x2d
 80060c0:	d004      	beq.n	80060cc <_strtod_l+0xb4>
 80060c2:	2a20      	cmp	r2, #32
 80060c4:	d1c8      	bne.n	8006058 <_strtod_l+0x40>
 80060c6:	3301      	adds	r3, #1
 80060c8:	9317      	str	r3, [sp, #92]	; 0x5c
 80060ca:	e7bd      	b.n	8006048 <_strtod_l+0x30>
 80060cc:	2201      	movs	r2, #1
 80060ce:	920d      	str	r2, [sp, #52]	; 0x34
 80060d0:	1c5a      	adds	r2, r3, #1
 80060d2:	9217      	str	r2, [sp, #92]	; 0x5c
 80060d4:	785b      	ldrb	r3, [r3, #1]
 80060d6:	2b00      	cmp	r3, #0
 80060d8:	d1c0      	bne.n	800605c <_strtod_l+0x44>
 80060da:	9b14      	ldr	r3, [sp, #80]	; 0x50
 80060dc:	9617      	str	r6, [sp, #92]	; 0x5c
 80060de:	2b00      	cmp	r3, #0
 80060e0:	f040 853c 	bne.w	8006b5c <_strtod_l+0xb44>
 80060e4:	ec4b ab10 	vmov	d0, sl, fp
 80060e8:	e7e2      	b.n	80060b0 <_strtod_l+0x98>
 80060ea:	2200      	movs	r2, #0
 80060ec:	e7ef      	b.n	80060ce <_strtod_l+0xb6>
 80060ee:	9a18      	ldr	r2, [sp, #96]	; 0x60
 80060f0:	b13a      	cbz	r2, 8006102 <_strtod_l+0xea>
 80060f2:	2135      	movs	r1, #53	; 0x35
 80060f4:	a81a      	add	r0, sp, #104	; 0x68
 80060f6:	f002 fae8 	bl	80086ca <__copybits>
 80060fa:	9918      	ldr	r1, [sp, #96]	; 0x60
 80060fc:	4620      	mov	r0, r4
 80060fe:	f001 ff53 	bl	8007fa8 <_Bfree>
 8006102:	3e01      	subs	r6, #1
 8006104:	2e04      	cmp	r6, #4
 8006106:	d806      	bhi.n	8006116 <_strtod_l+0xfe>
 8006108:	e8df f006 	tbb	[pc, r6]
 800610c:	1714030a 	.word	0x1714030a
 8006110:	0a          	.byte	0x0a
 8006111:	00          	.byte	0x00
 8006112:	e9dd ab1a 	ldrd	sl, fp, [sp, #104]	; 0x68
 8006116:	073b      	lsls	r3, r7, #28
 8006118:	d5c0      	bpl.n	800609c <_strtod_l+0x84>
 800611a:	f04b 4b00 	orr.w	fp, fp, #2147483648	; 0x80000000
 800611e:	e7bd      	b.n	800609c <_strtod_l+0x84>
 8006120:	e9dd a31a 	ldrd	sl, r3, [sp, #104]	; 0x68
 8006124:	9a19      	ldr	r2, [sp, #100]	; 0x64
 8006126:	f423 1380 	bic.w	r3, r3, #1048576	; 0x100000
 800612a:	f202 4233 	addw	r2, r2, #1075	; 0x433
 800612e:	ea43 5b02 	orr.w	fp, r3, r2, lsl #20
 8006132:	e7f0      	b.n	8006116 <_strtod_l+0xfe>
 8006134:	f8df b188 	ldr.w	fp, [pc, #392]	; 80062c0 <_strtod_l+0x2a8>
 8006138:	e7ed      	b.n	8006116 <_strtod_l+0xfe>
 800613a:	f06f 4b00 	mvn.w	fp, #2147483648	; 0x80000000
 800613e:	f04f 3aff 	mov.w	sl, #4294967295	; 0xffffffff
 8006142:	e7e8      	b.n	8006116 <_strtod_l+0xfe>
 8006144:	9b17      	ldr	r3, [sp, #92]	; 0x5c
 8006146:	1c5a      	adds	r2, r3, #1
 8006148:	9217      	str	r2, [sp, #92]	; 0x5c
 800614a:	785b      	ldrb	r3, [r3, #1]
 800614c:	2b30      	cmp	r3, #48	; 0x30
 800614e:	d0f9      	beq.n	8006144 <_strtod_l+0x12c>
 8006150:	2b00      	cmp	r3, #0
 8006152:	d0a3      	beq.n	800609c <_strtod_l+0x84>
 8006154:	2301      	movs	r3, #1
 8006156:	930a      	str	r3, [sp, #40]	; 0x28
 8006158:	9b17      	ldr	r3, [sp, #92]	; 0x5c
 800615a:	930c      	str	r3, [sp, #48]	; 0x30
 800615c:	2300      	movs	r3, #0
 800615e:	9306      	str	r3, [sp, #24]
 8006160:	9308      	str	r3, [sp, #32]
 8006162:	461d      	mov	r5, r3
 8006164:	220a      	movs	r2, #10
 8006166:	9817      	ldr	r0, [sp, #92]	; 0x5c
 8006168:	f890 8000 	ldrb.w	r8, [r0]
 800616c:	f1a8 0330 	sub.w	r3, r8, #48	; 0x30
 8006170:	b2d9      	uxtb	r1, r3
 8006172:	2909      	cmp	r1, #9
 8006174:	d92c      	bls.n	80061d0 <_strtod_l+0x1b8>
 8006176:	463a      	mov	r2, r7
 8006178:	f8d9 1000 	ldr.w	r1, [r9]
 800617c:	f002 fcf8 	bl	8008b70 <strncmp>
 8006180:	2800      	cmp	r0, #0
 8006182:	d035      	beq.n	80061f0 <_strtod_l+0x1d8>
 8006184:	2000      	movs	r0, #0
 8006186:	4642      	mov	r2, r8
 8006188:	462b      	mov	r3, r5
 800618a:	4601      	mov	r1, r0
 800618c:	9004      	str	r0, [sp, #16]
 800618e:	2a65      	cmp	r2, #101	; 0x65
 8006190:	d001      	beq.n	8006196 <_strtod_l+0x17e>
 8006192:	2a45      	cmp	r2, #69	; 0x45
 8006194:	d117      	bne.n	80061c6 <_strtod_l+0x1ae>
 8006196:	b923      	cbnz	r3, 80061a2 <_strtod_l+0x18a>
 8006198:	b910      	cbnz	r0, 80061a0 <_strtod_l+0x188>
 800619a:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 800619c:	2b00      	cmp	r3, #0
 800619e:	d09c      	beq.n	80060da <_strtod_l+0xc2>
 80061a0:	2300      	movs	r3, #0
 80061a2:	9e17      	ldr	r6, [sp, #92]	; 0x5c
 80061a4:	1c72      	adds	r2, r6, #1
 80061a6:	9217      	str	r2, [sp, #92]	; 0x5c
 80061a8:	7872      	ldrb	r2, [r6, #1]
 80061aa:	2a2b      	cmp	r2, #43	; 0x2b
 80061ac:	f000 8082 	beq.w	80062b4 <_strtod_l+0x29c>
 80061b0:	2a2d      	cmp	r2, #45	; 0x2d
 80061b2:	d079      	beq.n	80062a8 <_strtod_l+0x290>
 80061b4:	f04f 0e00 	mov.w	lr, #0
 80061b8:	f1a2 0c30 	sub.w	ip, r2, #48	; 0x30
 80061bc:	f1bc 0f09 	cmp.w	ip, #9
 80061c0:	f240 8086 	bls.w	80062d0 <_strtod_l+0x2b8>
 80061c4:	9617      	str	r6, [sp, #92]	; 0x5c
 80061c6:	f04f 0800 	mov.w	r8, #0
 80061ca:	e0a8      	b.n	800631e <_strtod_l+0x306>
 80061cc:	2300      	movs	r3, #0
 80061ce:	e7c2      	b.n	8006156 <_strtod_l+0x13e>
 80061d0:	2d08      	cmp	r5, #8
 80061d2:	bfd5      	itete	le
 80061d4:	9908      	ldrle	r1, [sp, #32]
 80061d6:	9906      	ldrgt	r1, [sp, #24]
 80061d8:	fb02 3301 	mlale	r3, r2, r1, r3
 80061dc:	fb02 3301 	mlagt	r3, r2, r1, r3
 80061e0:	f100 0001 	add.w	r0, r0, #1
 80061e4:	bfd4      	ite	le
 80061e6:	9308      	strle	r3, [sp, #32]
 80061e8:	9306      	strgt	r3, [sp, #24]
 80061ea:	3501      	adds	r5, #1
 80061ec:	9017      	str	r0, [sp, #92]	; 0x5c
 80061ee:	e7ba      	b.n	8006166 <_strtod_l+0x14e>
 80061f0:	9b17      	ldr	r3, [sp, #92]	; 0x5c
 80061f2:	19da      	adds	r2, r3, r7
 80061f4:	9217      	str	r2, [sp, #92]	; 0x5c
 80061f6:	5dda      	ldrb	r2, [r3, r7]
 80061f8:	2d00      	cmp	r5, #0
 80061fa:	d038      	beq.n	800626e <_strtod_l+0x256>
 80061fc:	4601      	mov	r1, r0
 80061fe:	462b      	mov	r3, r5
 8006200:	f1a2 0730 	sub.w	r7, r2, #48	; 0x30
 8006204:	2f09      	cmp	r7, #9
 8006206:	d913      	bls.n	8006230 <_strtod_l+0x218>
 8006208:	2701      	movs	r7, #1
 800620a:	9704      	str	r7, [sp, #16]
 800620c:	e7bf      	b.n	800618e <_strtod_l+0x176>
 800620e:	9b17      	ldr	r3, [sp, #92]	; 0x5c
 8006210:	1c5a      	adds	r2, r3, #1
 8006212:	9217      	str	r2, [sp, #92]	; 0x5c
 8006214:	785a      	ldrb	r2, [r3, #1]
 8006216:	3001      	adds	r0, #1
 8006218:	2a30      	cmp	r2, #48	; 0x30
 800621a:	d0f8      	beq.n	800620e <_strtod_l+0x1f6>
 800621c:	f1a2 0331 	sub.w	r3, r2, #49	; 0x31
 8006220:	2b08      	cmp	r3, #8
 8006222:	f200 84a2 	bhi.w	8006b6a <_strtod_l+0xb52>
 8006226:	9b17      	ldr	r3, [sp, #92]	; 0x5c
 8006228:	930c      	str	r3, [sp, #48]	; 0x30
 800622a:	4601      	mov	r1, r0
 800622c:	2000      	movs	r0, #0
 800622e:	4603      	mov	r3, r0
 8006230:	f1b2 0830 	subs.w	r8, r2, #48	; 0x30
 8006234:	f100 0701 	add.w	r7, r0, #1
 8006238:	d013      	beq.n	8006262 <_strtod_l+0x24a>
 800623a:	4439      	add	r1, r7
 800623c:	eb00 0e03 	add.w	lr, r0, r3
 8006240:	461f      	mov	r7, r3
 8006242:	f04f 0c0a 	mov.w	ip, #10
 8006246:	45be      	cmp	lr, r7
 8006248:	d113      	bne.n	8006272 <_strtod_l+0x25a>
 800624a:	181f      	adds	r7, r3, r0
 800624c:	2f08      	cmp	r7, #8
 800624e:	f103 0301 	add.w	r3, r3, #1
 8006252:	4403      	add	r3, r0
 8006254:	dc1d      	bgt.n	8006292 <_strtod_l+0x27a>
 8006256:	9a08      	ldr	r2, [sp, #32]
 8006258:	200a      	movs	r0, #10
 800625a:	fb00 8202 	mla	r2, r0, r2, r8
 800625e:	9208      	str	r2, [sp, #32]
 8006260:	2700      	movs	r7, #0
 8006262:	9a17      	ldr	r2, [sp, #92]	; 0x5c
 8006264:	1c50      	adds	r0, r2, #1
 8006266:	9017      	str	r0, [sp, #92]	; 0x5c
 8006268:	7852      	ldrb	r2, [r2, #1]
 800626a:	4638      	mov	r0, r7
 800626c:	e7c8      	b.n	8006200 <_strtod_l+0x1e8>
 800626e:	4628      	mov	r0, r5
 8006270:	e7d2      	b.n	8006218 <_strtod_l+0x200>
 8006272:	2f08      	cmp	r7, #8
 8006274:	f107 0701 	add.w	r7, r7, #1
 8006278:	dc04      	bgt.n	8006284 <_strtod_l+0x26c>
 800627a:	9a08      	ldr	r2, [sp, #32]
 800627c:	fb0c f202 	mul.w	r2, ip, r2
 8006280:	9208      	str	r2, [sp, #32]
 8006282:	e7e0      	b.n	8006246 <_strtod_l+0x22e>
 8006284:	2f10      	cmp	r7, #16
 8006286:	bfde      	ittt	le
 8006288:	9a06      	ldrle	r2, [sp, #24]
 800628a:	fb0c f202 	mulle.w	r2, ip, r2
 800628e:	9206      	strle	r2, [sp, #24]
 8006290:	e7d9      	b.n	8006246 <_strtod_l+0x22e>
 8006292:	2b10      	cmp	r3, #16
 8006294:	bfdf      	itttt	le
 8006296:	9a06      	ldrle	r2, [sp, #24]
 8006298:	200a      	movle	r0, #10
 800629a:	fb00 8202 	mlale	r2, r0, r2, r8
 800629e:	9206      	strle	r2, [sp, #24]
 80062a0:	e7de      	b.n	8006260 <_strtod_l+0x248>
 80062a2:	2301      	movs	r3, #1
 80062a4:	9304      	str	r3, [sp, #16]
 80062a6:	e777      	b.n	8006198 <_strtod_l+0x180>
 80062a8:	f04f 0e01 	mov.w	lr, #1
 80062ac:	1cb2      	adds	r2, r6, #2
 80062ae:	9217      	str	r2, [sp, #92]	; 0x5c
 80062b0:	78b2      	ldrb	r2, [r6, #2]
 80062b2:	e781      	b.n	80061b8 <_strtod_l+0x1a0>
 80062b4:	f04f 0e00 	mov.w	lr, #0
 80062b8:	e7f8      	b.n	80062ac <_strtod_l+0x294>
 80062ba:	bf00      	nop
 80062bc:	0802e6f8 	.word	0x0802e6f8
 80062c0:	7ff00000 	.word	0x7ff00000
 80062c4:	9a17      	ldr	r2, [sp, #92]	; 0x5c
 80062c6:	f102 0c01 	add.w	ip, r2, #1
 80062ca:	f8cd c05c 	str.w	ip, [sp, #92]	; 0x5c
 80062ce:	7852      	ldrb	r2, [r2, #1]
 80062d0:	2a30      	cmp	r2, #48	; 0x30
 80062d2:	d0f7      	beq.n	80062c4 <_strtod_l+0x2ac>
 80062d4:	f1a2 0c31 	sub.w	ip, r2, #49	; 0x31
 80062d8:	f1bc 0f08 	cmp.w	ip, #8
 80062dc:	f63f af73 	bhi.w	80061c6 <_strtod_l+0x1ae>
 80062e0:	f1a2 0830 	sub.w	r8, r2, #48	; 0x30
 80062e4:	9a17      	ldr	r2, [sp, #92]	; 0x5c
 80062e6:	920e      	str	r2, [sp, #56]	; 0x38
 80062e8:	9a17      	ldr	r2, [sp, #92]	; 0x5c
 80062ea:	f102 0c01 	add.w	ip, r2, #1
 80062ee:	f8cd c05c 	str.w	ip, [sp, #92]	; 0x5c
 80062f2:	7852      	ldrb	r2, [r2, #1]
 80062f4:	f1a2 0930 	sub.w	r9, r2, #48	; 0x30
 80062f8:	f1b9 0f09 	cmp.w	r9, #9
 80062fc:	d939      	bls.n	8006372 <_strtod_l+0x35a>
 80062fe:	9f0e      	ldr	r7, [sp, #56]	; 0x38
 8006300:	ebac 0c07 	sub.w	ip, ip, r7
 8006304:	f1bc 0f08 	cmp.w	ip, #8
 8006308:	f644 6c1f 	movw	ip, #19999	; 0x4e1f
 800630c:	dc37      	bgt.n	800637e <_strtod_l+0x366>
 800630e:	45e0      	cmp	r8, ip
 8006310:	bfa8      	it	ge
 8006312:	46e0      	movge	r8, ip
 8006314:	f1be 0f00 	cmp.w	lr, #0
 8006318:	d001      	beq.n	800631e <_strtod_l+0x306>
 800631a:	f1c8 0800 	rsb	r8, r8, #0
 800631e:	2b00      	cmp	r3, #0
 8006320:	d151      	bne.n	80063c6 <_strtod_l+0x3ae>
 8006322:	2800      	cmp	r0, #0
 8006324:	f47f aeba 	bne.w	800609c <_strtod_l+0x84>
 8006328:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 800632a:	2b00      	cmp	r3, #0
 800632c:	f47f aeb6 	bne.w	800609c <_strtod_l+0x84>
 8006330:	9b04      	ldr	r3, [sp, #16]
 8006332:	2b00      	cmp	r3, #0
 8006334:	f47f aed1 	bne.w	80060da <_strtod_l+0xc2>
 8006338:	2a4e      	cmp	r2, #78	; 0x4e
 800633a:	d027      	beq.n	800638c <_strtod_l+0x374>
 800633c:	dc21      	bgt.n	8006382 <_strtod_l+0x36a>
 800633e:	2a49      	cmp	r2, #73	; 0x49
 8006340:	f47f aecb 	bne.w	80060da <_strtod_l+0xc2>
 8006344:	499a      	ldr	r1, [pc, #616]	; (80065b0 <_strtod_l+0x598>)
 8006346:	a817      	add	r0, sp, #92	; 0x5c
 8006348:	f001 fd28 	bl	8007d9c <__match>
 800634c:	2800      	cmp	r0, #0
 800634e:	f43f aec4 	beq.w	80060da <_strtod_l+0xc2>
 8006352:	9b17      	ldr	r3, [sp, #92]	; 0x5c
 8006354:	4997      	ldr	r1, [pc, #604]	; (80065b4 <_strtod_l+0x59c>)
 8006356:	3b01      	subs	r3, #1
 8006358:	a817      	add	r0, sp, #92	; 0x5c
 800635a:	9317      	str	r3, [sp, #92]	; 0x5c
 800635c:	f001 fd1e 	bl	8007d9c <__match>
 8006360:	b910      	cbnz	r0, 8006368 <_strtod_l+0x350>
 8006362:	9b17      	ldr	r3, [sp, #92]	; 0x5c
 8006364:	3301      	adds	r3, #1
 8006366:	9317      	str	r3, [sp, #92]	; 0x5c
 8006368:	f8df b260 	ldr.w	fp, [pc, #608]	; 80065cc <_strtod_l+0x5b4>
 800636c:	f04f 0a00 	mov.w	sl, #0
 8006370:	e694      	b.n	800609c <_strtod_l+0x84>
 8006372:	270a      	movs	r7, #10
 8006374:	fb07 2808 	mla	r8, r7, r8, r2
 8006378:	f1a8 0830 	sub.w	r8, r8, #48	; 0x30
 800637c:	e7b4      	b.n	80062e8 <_strtod_l+0x2d0>
 800637e:	46e0      	mov	r8, ip
 8006380:	e7c8      	b.n	8006314 <_strtod_l+0x2fc>
 8006382:	2a69      	cmp	r2, #105	; 0x69
 8006384:	d0de      	beq.n	8006344 <_strtod_l+0x32c>
 8006386:	2a6e      	cmp	r2, #110	; 0x6e
 8006388:	f47f aea7 	bne.w	80060da <_strtod_l+0xc2>
 800638c:	498a      	ldr	r1, [pc, #552]	; (80065b8 <_strtod_l+0x5a0>)
 800638e:	a817      	add	r0, sp, #92	; 0x5c
 8006390:	f001 fd04 	bl	8007d9c <__match>
 8006394:	2800      	cmp	r0, #0
 8006396:	f43f aea0 	beq.w	80060da <_strtod_l+0xc2>
 800639a:	9b17      	ldr	r3, [sp, #92]	; 0x5c
 800639c:	781b      	ldrb	r3, [r3, #0]
 800639e:	2b28      	cmp	r3, #40	; 0x28
 80063a0:	d10e      	bne.n	80063c0 <_strtod_l+0x3a8>
 80063a2:	aa1a      	add	r2, sp, #104	; 0x68
 80063a4:	4985      	ldr	r1, [pc, #532]	; (80065bc <_strtod_l+0x5a4>)
 80063a6:	a817      	add	r0, sp, #92	; 0x5c
 80063a8:	f001 fd0c 	bl	8007dc4 <__hexnan>
 80063ac:	2805      	cmp	r0, #5
 80063ae:	d107      	bne.n	80063c0 <_strtod_l+0x3a8>
 80063b0:	9b1b      	ldr	r3, [sp, #108]	; 0x6c
 80063b2:	f8dd a068 	ldr.w	sl, [sp, #104]	; 0x68
 80063b6:	f043 4bff 	orr.w	fp, r3, #2139095040	; 0x7f800000
 80063ba:	f44b 0be0 	orr.w	fp, fp, #7340032	; 0x700000
 80063be:	e66d      	b.n	800609c <_strtod_l+0x84>
 80063c0:	f8df b20c 	ldr.w	fp, [pc, #524]	; 80065d0 <_strtod_l+0x5b8>
 80063c4:	e7d2      	b.n	800636c <_strtod_l+0x354>
 80063c6:	eddd 7a08 	vldr	s15, [sp, #32]
 80063ca:	eeb8 7b67 	vcvt.f64.u32	d7, s15
 80063ce:	eba8 0201 	sub.w	r2, r8, r1
 80063d2:	2d00      	cmp	r5, #0
 80063d4:	bf08      	it	eq
 80063d6:	461d      	moveq	r5, r3
 80063d8:	2b10      	cmp	r3, #16
 80063da:	9204      	str	r2, [sp, #16]
 80063dc:	ed8d 7b0a 	vstr	d7, [sp, #40]	; 0x28
 80063e0:	461a      	mov	r2, r3
 80063e2:	bfa8      	it	ge
 80063e4:	2210      	movge	r2, #16
 80063e6:	2b09      	cmp	r3, #9
 80063e8:	e9dd ab0a 	ldrd	sl, fp, [sp, #40]	; 0x28
 80063ec:	dc14      	bgt.n	8006418 <_strtod_l+0x400>
 80063ee:	9904      	ldr	r1, [sp, #16]
 80063f0:	2900      	cmp	r1, #0
 80063f2:	f43f ae53 	beq.w	800609c <_strtod_l+0x84>
 80063f6:	9904      	ldr	r1, [sp, #16]
 80063f8:	dd72      	ble.n	80064e0 <_strtod_l+0x4c8>
 80063fa:	2916      	cmp	r1, #22
 80063fc:	dc5a      	bgt.n	80064b4 <_strtod_l+0x49c>
 80063fe:	4970      	ldr	r1, [pc, #448]	; (80065c0 <_strtod_l+0x5a8>)
 8006400:	9b04      	ldr	r3, [sp, #16]
 8006402:	eb01 01c3 	add.w	r1, r1, r3, lsl #3
 8006406:	ed91 7b00 	vldr	d7, [r1]
 800640a:	ec4b ab16 	vmov	d6, sl, fp
 800640e:	ee27 7b06 	vmul.f64	d7, d7, d6
 8006412:	ec5b ab17 	vmov	sl, fp, d7
 8006416:	e641      	b.n	800609c <_strtod_l+0x84>
 8006418:	4969      	ldr	r1, [pc, #420]	; (80065c0 <_strtod_l+0x5a8>)
 800641a:	eddd 7a06 	vldr	s15, [sp, #24]
 800641e:	eb01 01c2 	add.w	r1, r1, r2, lsl #3
 8006422:	ed11 6b12 	vldr	d6, [r1, #-72]	; 0xffffffb8
 8006426:	ed9d 5b0a 	vldr	d5, [sp, #40]	; 0x28
 800642a:	2b0f      	cmp	r3, #15
 800642c:	eeb8 7b67 	vcvt.f64.u32	d7, s15
 8006430:	eea5 7b06 	vfma.f64	d7, d5, d6
 8006434:	ec5b ab17 	vmov	sl, fp, d7
 8006438:	ddd9      	ble.n	80063ee <_strtod_l+0x3d6>
 800643a:	9904      	ldr	r1, [sp, #16]
 800643c:	1a9a      	subs	r2, r3, r2
 800643e:	440a      	add	r2, r1
 8006440:	2a00      	cmp	r2, #0
 8006442:	f340 8096 	ble.w	8006572 <_strtod_l+0x55a>
 8006446:	f012 000f 	ands.w	r0, r2, #15
 800644a:	d00a      	beq.n	8006462 <_strtod_l+0x44a>
 800644c:	495c      	ldr	r1, [pc, #368]	; (80065c0 <_strtod_l+0x5a8>)
 800644e:	eb01 01c0 	add.w	r1, r1, r0, lsl #3
 8006452:	ed91 7b00 	vldr	d7, [r1]
 8006456:	ec4b ab16 	vmov	d6, sl, fp
 800645a:	ee27 7b06 	vmul.f64	d7, d7, d6
 800645e:	ec5b ab17 	vmov	sl, fp, d7
 8006462:	f032 020f 	bics.w	r2, r2, #15
 8006466:	d072      	beq.n	800654e <_strtod_l+0x536>
 8006468:	f5b2 7f9a 	cmp.w	r2, #308	; 0x134
 800646c:	dd45      	ble.n	80064fa <_strtod_l+0x4e2>
 800646e:	2500      	movs	r5, #0
 8006470:	46a8      	mov	r8, r5
 8006472:	9506      	str	r5, [sp, #24]
 8006474:	46a9      	mov	r9, r5
 8006476:	2322      	movs	r3, #34	; 0x22
 8006478:	f8df b150 	ldr.w	fp, [pc, #336]	; 80065cc <_strtod_l+0x5b4>
 800647c:	6023      	str	r3, [r4, #0]
 800647e:	f04f 0a00 	mov.w	sl, #0
 8006482:	9b06      	ldr	r3, [sp, #24]
 8006484:	2b00      	cmp	r3, #0
 8006486:	f43f ae09 	beq.w	800609c <_strtod_l+0x84>
 800648a:	9918      	ldr	r1, [sp, #96]	; 0x60
 800648c:	4620      	mov	r0, r4
 800648e:	f001 fd8b 	bl	8007fa8 <_Bfree>
 8006492:	4649      	mov	r1, r9
 8006494:	4620      	mov	r0, r4
 8006496:	f001 fd87 	bl	8007fa8 <_Bfree>
 800649a:	4641      	mov	r1, r8
 800649c:	4620      	mov	r0, r4
 800649e:	f001 fd83 	bl	8007fa8 <_Bfree>
 80064a2:	9906      	ldr	r1, [sp, #24]
 80064a4:	4620      	mov	r0, r4
 80064a6:	f001 fd7f 	bl	8007fa8 <_Bfree>
 80064aa:	4629      	mov	r1, r5
 80064ac:	4620      	mov	r0, r4
 80064ae:	f001 fd7b 	bl	8007fa8 <_Bfree>
 80064b2:	e5f3      	b.n	800609c <_strtod_l+0x84>
 80064b4:	9804      	ldr	r0, [sp, #16]
 80064b6:	f1c3 0125 	rsb	r1, r3, #37	; 0x25
 80064ba:	4281      	cmp	r1, r0
 80064bc:	dbbd      	blt.n	800643a <_strtod_l+0x422>
 80064be:	4a40      	ldr	r2, [pc, #256]	; (80065c0 <_strtod_l+0x5a8>)
 80064c0:	f1c3 030f 	rsb	r3, r3, #15
 80064c4:	eb02 01c3 	add.w	r1, r2, r3, lsl #3
 80064c8:	ed91 7b00 	vldr	d7, [r1]
 80064cc:	ec4b ab16 	vmov	d6, sl, fp
 80064d0:	1ac3      	subs	r3, r0, r3
 80064d2:	eb02 02c3 	add.w	r2, r2, r3, lsl #3
 80064d6:	ee27 7b06 	vmul.f64	d7, d7, d6
 80064da:	ed92 6b00 	vldr	d6, [r2]
 80064de:	e796      	b.n	800640e <_strtod_l+0x3f6>
 80064e0:	3116      	adds	r1, #22
 80064e2:	dbaa      	blt.n	800643a <_strtod_l+0x422>
 80064e4:	4936      	ldr	r1, [pc, #216]	; (80065c0 <_strtod_l+0x5a8>)
 80064e6:	9b04      	ldr	r3, [sp, #16]
 80064e8:	eba1 01c3 	sub.w	r1, r1, r3, lsl #3
 80064ec:	ed91 7b00 	vldr	d7, [r1]
 80064f0:	ec4b ab16 	vmov	d6, sl, fp
 80064f4:	ee86 7b07 	vdiv.f64	d7, d6, d7
 80064f8:	e78b      	b.n	8006412 <_strtod_l+0x3fa>
 80064fa:	e9cd ab06 	strd	sl, fp, [sp, #24]
 80064fe:	2000      	movs	r0, #0
 8006500:	4e30      	ldr	r6, [pc, #192]	; (80065c4 <_strtod_l+0x5ac>)
 8006502:	1112      	asrs	r2, r2, #4
 8006504:	4601      	mov	r1, r0
 8006506:	2a01      	cmp	r2, #1
 8006508:	dc23      	bgt.n	8006552 <_strtod_l+0x53a>
 800650a:	b108      	cbz	r0, 8006510 <_strtod_l+0x4f8>
 800650c:	e9dd ab06 	ldrd	sl, fp, [sp, #24]
 8006510:	4a2c      	ldr	r2, [pc, #176]	; (80065c4 <_strtod_l+0x5ac>)
 8006512:	482d      	ldr	r0, [pc, #180]	; (80065c8 <_strtod_l+0x5b0>)
 8006514:	eb02 01c1 	add.w	r1, r2, r1, lsl #3
 8006518:	f1ab 7b54 	sub.w	fp, fp, #55574528	; 0x3500000
 800651c:	ed91 7b00 	vldr	d7, [r1]
 8006520:	ec4b ab16 	vmov	d6, sl, fp
 8006524:	ee27 7b06 	vmul.f64	d7, d7, d6
 8006528:	ed8d 7b06 	vstr	d7, [sp, #24]
 800652c:	9907      	ldr	r1, [sp, #28]
 800652e:	4a27      	ldr	r2, [pc, #156]	; (80065cc <_strtod_l+0x5b4>)
 8006530:	400a      	ands	r2, r1
 8006532:	4282      	cmp	r2, r0
 8006534:	e9dd ab06 	ldrd	sl, fp, [sp, #24]
 8006538:	d899      	bhi.n	800646e <_strtod_l+0x456>
 800653a:	f5a0 1080 	sub.w	r0, r0, #1048576	; 0x100000
 800653e:	4282      	cmp	r2, r0
 8006540:	bf86      	itte	hi
 8006542:	f8df b090 	ldrhi.w	fp, [pc, #144]	; 80065d4 <_strtod_l+0x5bc>
 8006546:	f04f 3aff 	movhi.w	sl, #4294967295	; 0xffffffff
 800654a:	f101 7b54 	addls.w	fp, r1, #55574528	; 0x3500000
 800654e:	2700      	movs	r7, #0
 8006550:	e070      	b.n	8006634 <_strtod_l+0x61c>
 8006552:	07d7      	lsls	r7, r2, #31
 8006554:	d50a      	bpl.n	800656c <_strtod_l+0x554>
 8006556:	eb06 00c1 	add.w	r0, r6, r1, lsl #3
 800655a:	ed90 7b00 	vldr	d7, [r0]
 800655e:	ed9d 6b06 	vldr	d6, [sp, #24]
 8006562:	ee26 7b07 	vmul.f64	d7, d6, d7
 8006566:	ed8d 7b06 	vstr	d7, [sp, #24]
 800656a:	2001      	movs	r0, #1
 800656c:	3101      	adds	r1, #1
 800656e:	1052      	asrs	r2, r2, #1
 8006570:	e7c9      	b.n	8006506 <_strtod_l+0x4ee>
 8006572:	d0ec      	beq.n	800654e <_strtod_l+0x536>
 8006574:	4252      	negs	r2, r2
 8006576:	f012 000f 	ands.w	r0, r2, #15
 800657a:	d00a      	beq.n	8006592 <_strtod_l+0x57a>
 800657c:	4910      	ldr	r1, [pc, #64]	; (80065c0 <_strtod_l+0x5a8>)
 800657e:	eb01 01c0 	add.w	r1, r1, r0, lsl #3
 8006582:	ed91 7b00 	vldr	d7, [r1]
 8006586:	ec4b ab16 	vmov	d6, sl, fp
 800658a:	ee86 7b07 	vdiv.f64	d7, d6, d7
 800658e:	ec5b ab17 	vmov	sl, fp, d7
 8006592:	1112      	asrs	r2, r2, #4
 8006594:	d0db      	beq.n	800654e <_strtod_l+0x536>
 8006596:	2a1f      	cmp	r2, #31
 8006598:	dd1e      	ble.n	80065d8 <_strtod_l+0x5c0>
 800659a:	2500      	movs	r5, #0
 800659c:	46a8      	mov	r8, r5
 800659e:	9506      	str	r5, [sp, #24]
 80065a0:	46a9      	mov	r9, r5
 80065a2:	2322      	movs	r3, #34	; 0x22
 80065a4:	f04f 0a00 	mov.w	sl, #0
 80065a8:	f04f 0b00 	mov.w	fp, #0
 80065ac:	6023      	str	r3, [r4, #0]
 80065ae:	e768      	b.n	8006482 <_strtod_l+0x46a>
 80065b0:	0802e6c1 	.word	0x0802e6c1
 80065b4:	0802e74b 	.word	0x0802e74b
 80065b8:	0802e6c9 	.word	0x0802e6c9
 80065bc:	0802e70c 	.word	0x0802e70c
 80065c0:	0802e788 	.word	0x0802e788
 80065c4:	0802e760 	.word	0x0802e760
 80065c8:	7ca00000 	.word	0x7ca00000
 80065cc:	7ff00000 	.word	0x7ff00000
 80065d0:	fff80000 	.word	0xfff80000
 80065d4:	7fefffff 	.word	0x7fefffff
 80065d8:	e9cd ab06 	strd	sl, fp, [sp, #24]
 80065dc:	f012 0710 	ands.w	r7, r2, #16
 80065e0:	49ab      	ldr	r1, [pc, #684]	; (8006890 <_strtod_l+0x878>)
 80065e2:	bf18      	it	ne
 80065e4:	276a      	movne	r7, #106	; 0x6a
 80065e6:	2000      	movs	r0, #0
 80065e8:	2a00      	cmp	r2, #0
 80065ea:	f300 8113 	bgt.w	8006814 <_strtod_l+0x7fc>
 80065ee:	b108      	cbz	r0, 80065f4 <_strtod_l+0x5dc>
 80065f0:	e9dd ab06 	ldrd	sl, fp, [sp, #24]
 80065f4:	b1bf      	cbz	r7, 8006626 <_strtod_l+0x60e>
 80065f6:	f3cb 520a 	ubfx	r2, fp, #20, #11
 80065fa:	f1c2 026b 	rsb	r2, r2, #107	; 0x6b
 80065fe:	2a00      	cmp	r2, #0
 8006600:	4659      	mov	r1, fp
 8006602:	dd10      	ble.n	8006626 <_strtod_l+0x60e>
 8006604:	2a1f      	cmp	r2, #31
 8006606:	f340 8113 	ble.w	8006830 <_strtod_l+0x818>
 800660a:	2a34      	cmp	r2, #52	; 0x34
 800660c:	bfde      	ittt	le
 800660e:	3a20      	suble	r2, #32
 8006610:	f04f 30ff 	movle.w	r0, #4294967295	; 0xffffffff
 8006614:	fa00 f202 	lslle.w	r2, r0, r2
 8006618:	f04f 0a00 	mov.w	sl, #0
 800661c:	bfcc      	ite	gt
 800661e:	f04f 7b5c 	movgt.w	fp, #57671680	; 0x3700000
 8006622:	ea02 0b01 	andle.w	fp, r2, r1
 8006626:	ec4b ab17 	vmov	d7, sl, fp
 800662a:	eeb5 7b40 	vcmp.f64	d7, #0.0
 800662e:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 8006632:	d0b2      	beq.n	800659a <_strtod_l+0x582>
 8006634:	9a08      	ldr	r2, [sp, #32]
 8006636:	9200      	str	r2, [sp, #0]
 8006638:	990c      	ldr	r1, [sp, #48]	; 0x30
 800663a:	462a      	mov	r2, r5
 800663c:	4620      	mov	r0, r4
 800663e:	f001 fd05 	bl	800804c <__s2b>
 8006642:	9006      	str	r0, [sp, #24]
 8006644:	2800      	cmp	r0, #0
 8006646:	f43f af12 	beq.w	800646e <_strtod_l+0x456>
 800664a:	9a04      	ldr	r2, [sp, #16]
 800664c:	9b04      	ldr	r3, [sp, #16]
 800664e:	2a00      	cmp	r2, #0
 8006650:	f1c3 0300 	rsb	r3, r3, #0
 8006654:	ed9f 9b88 	vldr	d9, [pc, #544]	; 8006878 <_strtod_l+0x860>
 8006658:	bfa8      	it	ge
 800665a:	2300      	movge	r3, #0
 800665c:	ed9f ab88 	vldr	d10, [pc, #544]	; 8006880 <_strtod_l+0x868>
 8006660:	ed9f bb89 	vldr	d11, [pc, #548]	; 8006888 <_strtod_l+0x870>
 8006664:	930e      	str	r3, [sp, #56]	; 0x38
 8006666:	2500      	movs	r5, #0
 8006668:	ea22 73e2 	bic.w	r3, r2, r2, asr #31
 800666c:	9310      	str	r3, [sp, #64]	; 0x40
 800666e:	46a8      	mov	r8, r5
 8006670:	9b06      	ldr	r3, [sp, #24]
 8006672:	4620      	mov	r0, r4
 8006674:	6859      	ldr	r1, [r3, #4]
 8006676:	f001 fc63 	bl	8007f40 <_Balloc>
 800667a:	4681      	mov	r9, r0
 800667c:	2800      	cmp	r0, #0
 800667e:	f43f aefa 	beq.w	8006476 <_strtod_l+0x45e>
 8006682:	9b06      	ldr	r3, [sp, #24]
 8006684:	691a      	ldr	r2, [r3, #16]
 8006686:	3202      	adds	r2, #2
 8006688:	f103 010c 	add.w	r1, r3, #12
 800668c:	0092      	lsls	r2, r2, #2
 800668e:	300c      	adds	r0, #12
 8006690:	f7fe fe5e 	bl	8005350 <memcpy>
 8006694:	aa1a      	add	r2, sp, #104	; 0x68
 8006696:	a919      	add	r1, sp, #100	; 0x64
 8006698:	ec4b ab10 	vmov	d0, sl, fp
 800669c:	4620      	mov	r0, r4
 800669e:	e9cd ab0a 	strd	sl, fp, [sp, #40]	; 0x28
 80066a2:	f001 ff8f 	bl	80085c4 <__d2b>
 80066a6:	9018      	str	r0, [sp, #96]	; 0x60
 80066a8:	2800      	cmp	r0, #0
 80066aa:	f43f aee4 	beq.w	8006476 <_strtod_l+0x45e>
 80066ae:	2101      	movs	r1, #1
 80066b0:	4620      	mov	r0, r4
 80066b2:	f001 fd57 	bl	8008164 <__i2b>
 80066b6:	4680      	mov	r8, r0
 80066b8:	2800      	cmp	r0, #0
 80066ba:	f43f aedc 	beq.w	8006476 <_strtod_l+0x45e>
 80066be:	9e19      	ldr	r6, [sp, #100]	; 0x64
 80066c0:	9a1a      	ldr	r2, [sp, #104]	; 0x68
 80066c2:	2e00      	cmp	r6, #0
 80066c4:	bfb1      	iteee	lt
 80066c6:	9b10      	ldrlt	r3, [sp, #64]	; 0x40
 80066c8:	9b0e      	ldrge	r3, [sp, #56]	; 0x38
 80066ca:	9810      	ldrge	r0, [sp, #64]	; 0x40
 80066cc:	18f3      	addge	r3, r6, r3
 80066ce:	bfba      	itte	lt
 80066d0:	1b98      	sublt	r0, r3, r6
 80066d2:	9b0e      	ldrlt	r3, [sp, #56]	; 0x38
 80066d4:	9308      	strge	r3, [sp, #32]
 80066d6:	eba6 0607 	sub.w	r6, r6, r7
 80066da:	bfb8      	it	lt
 80066dc:	9308      	strlt	r3, [sp, #32]
 80066de:	4416      	add	r6, r2
 80066e0:	4b6c      	ldr	r3, [pc, #432]	; (8006894 <_strtod_l+0x87c>)
 80066e2:	3e01      	subs	r6, #1
 80066e4:	429e      	cmp	r6, r3
 80066e6:	f1c2 0236 	rsb	r2, r2, #54	; 0x36
 80066ea:	f280 80b4 	bge.w	8006856 <_strtod_l+0x83e>
 80066ee:	1b9b      	subs	r3, r3, r6
 80066f0:	2b1f      	cmp	r3, #31
 80066f2:	eba2 0203 	sub.w	r2, r2, r3
 80066f6:	f04f 0101 	mov.w	r1, #1
 80066fa:	f300 80a0 	bgt.w	800683e <_strtod_l+0x826>
 80066fe:	fa01 f303 	lsl.w	r3, r1, r3
 8006702:	9311      	str	r3, [sp, #68]	; 0x44
 8006704:	2300      	movs	r3, #0
 8006706:	930f      	str	r3, [sp, #60]	; 0x3c
 8006708:	9b08      	ldr	r3, [sp, #32]
 800670a:	4413      	add	r3, r2
 800670c:	4402      	add	r2, r0
 800670e:	18be      	adds	r6, r7, r2
 8006710:	9a08      	ldr	r2, [sp, #32]
 8006712:	429a      	cmp	r2, r3
 8006714:	bfa8      	it	ge
 8006716:	461a      	movge	r2, r3
 8006718:	42b2      	cmp	r2, r6
 800671a:	bfa8      	it	ge
 800671c:	4632      	movge	r2, r6
 800671e:	2a00      	cmp	r2, #0
 8006720:	dd04      	ble.n	800672c <_strtod_l+0x714>
 8006722:	9908      	ldr	r1, [sp, #32]
 8006724:	1a9b      	subs	r3, r3, r2
 8006726:	1ab6      	subs	r6, r6, r2
 8006728:	1a8a      	subs	r2, r1, r2
 800672a:	9208      	str	r2, [sp, #32]
 800672c:	9a0e      	ldr	r2, [sp, #56]	; 0x38
 800672e:	b1c2      	cbz	r2, 8006762 <_strtod_l+0x74a>
 8006730:	4641      	mov	r1, r8
 8006732:	4620      	mov	r0, r4
 8006734:	9315      	str	r3, [sp, #84]	; 0x54
 8006736:	f001 fdb5 	bl	80082a4 <__pow5mult>
 800673a:	4680      	mov	r8, r0
 800673c:	2800      	cmp	r0, #0
 800673e:	f43f ae9a 	beq.w	8006476 <_strtod_l+0x45e>
 8006742:	4601      	mov	r1, r0
 8006744:	9a18      	ldr	r2, [sp, #96]	; 0x60
 8006746:	4620      	mov	r0, r4
 8006748:	f001 fd15 	bl	8008176 <__multiply>
 800674c:	900c      	str	r0, [sp, #48]	; 0x30
 800674e:	2800      	cmp	r0, #0
 8006750:	f43f ae91 	beq.w	8006476 <_strtod_l+0x45e>
 8006754:	9918      	ldr	r1, [sp, #96]	; 0x60
 8006756:	4620      	mov	r0, r4
 8006758:	f001 fc26 	bl	8007fa8 <_Bfree>
 800675c:	9a0c      	ldr	r2, [sp, #48]	; 0x30
 800675e:	9b15      	ldr	r3, [sp, #84]	; 0x54
 8006760:	9218      	str	r2, [sp, #96]	; 0x60
 8006762:	2b00      	cmp	r3, #0
 8006764:	dc7c      	bgt.n	8006860 <_strtod_l+0x848>
 8006766:	9b04      	ldr	r3, [sp, #16]
 8006768:	2b00      	cmp	r3, #0
 800676a:	dd08      	ble.n	800677e <_strtod_l+0x766>
 800676c:	4649      	mov	r1, r9
 800676e:	9a10      	ldr	r2, [sp, #64]	; 0x40
 8006770:	4620      	mov	r0, r4
 8006772:	f001 fd97 	bl	80082a4 <__pow5mult>
 8006776:	4681      	mov	r9, r0
 8006778:	2800      	cmp	r0, #0
 800677a:	f43f ae7c 	beq.w	8006476 <_strtod_l+0x45e>
 800677e:	2e00      	cmp	r6, #0
 8006780:	dd08      	ble.n	8006794 <_strtod_l+0x77c>
 8006782:	4649      	mov	r1, r9
 8006784:	4632      	mov	r2, r6
 8006786:	4620      	mov	r0, r4
 8006788:	f001 fdda 	bl	8008340 <__lshift>
 800678c:	4681      	mov	r9, r0
 800678e:	2800      	cmp	r0, #0
 8006790:	f43f ae71 	beq.w	8006476 <_strtod_l+0x45e>
 8006794:	9b08      	ldr	r3, [sp, #32]
 8006796:	2b00      	cmp	r3, #0
 8006798:	dd08      	ble.n	80067ac <_strtod_l+0x794>
 800679a:	4641      	mov	r1, r8
 800679c:	461a      	mov	r2, r3
 800679e:	4620      	mov	r0, r4
 80067a0:	f001 fdce 	bl	8008340 <__lshift>
 80067a4:	4680      	mov	r8, r0
 80067a6:	2800      	cmp	r0, #0
 80067a8:	f43f ae65 	beq.w	8006476 <_strtod_l+0x45e>
 80067ac:	464a      	mov	r2, r9
 80067ae:	9918      	ldr	r1, [sp, #96]	; 0x60
 80067b0:	4620      	mov	r0, r4
 80067b2:	f001 fe33 	bl	800841c <__mdiff>
 80067b6:	4605      	mov	r5, r0
 80067b8:	2800      	cmp	r0, #0
 80067ba:	f43f ae5c 	beq.w	8006476 <_strtod_l+0x45e>
 80067be:	68c3      	ldr	r3, [r0, #12]
 80067c0:	930c      	str	r3, [sp, #48]	; 0x30
 80067c2:	2300      	movs	r3, #0
 80067c4:	60c3      	str	r3, [r0, #12]
 80067c6:	4641      	mov	r1, r8
 80067c8:	f001 fe0e 	bl	80083e8 <__mcmp>
 80067cc:	2800      	cmp	r0, #0
 80067ce:	da63      	bge.n	8006898 <_strtod_l+0x880>
 80067d0:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 80067d2:	b9e3      	cbnz	r3, 800680e <_strtod_l+0x7f6>
 80067d4:	f1ba 0f00 	cmp.w	sl, #0
 80067d8:	d119      	bne.n	800680e <_strtod_l+0x7f6>
 80067da:	f3cb 0313 	ubfx	r3, fp, #0, #20
 80067de:	b9b3      	cbnz	r3, 800680e <_strtod_l+0x7f6>
 80067e0:	f02b 4300 	bic.w	r3, fp, #2147483648	; 0x80000000
 80067e4:	0d1b      	lsrs	r3, r3, #20
 80067e6:	051b      	lsls	r3, r3, #20
 80067e8:	f1b3 6fd6 	cmp.w	r3, #112197632	; 0x6b00000
 80067ec:	d90f      	bls.n	800680e <_strtod_l+0x7f6>
 80067ee:	696b      	ldr	r3, [r5, #20]
 80067f0:	b913      	cbnz	r3, 80067f8 <_strtod_l+0x7e0>
 80067f2:	692b      	ldr	r3, [r5, #16]
 80067f4:	2b01      	cmp	r3, #1
 80067f6:	dd0a      	ble.n	800680e <_strtod_l+0x7f6>
 80067f8:	4629      	mov	r1, r5
 80067fa:	2201      	movs	r2, #1
 80067fc:	4620      	mov	r0, r4
 80067fe:	f001 fd9f 	bl	8008340 <__lshift>
 8006802:	4641      	mov	r1, r8
 8006804:	4605      	mov	r5, r0
 8006806:	f001 fdef 	bl	80083e8 <__mcmp>
 800680a:	2800      	cmp	r0, #0
 800680c:	dc75      	bgt.n	80068fa <_strtod_l+0x8e2>
 800680e:	2f00      	cmp	r7, #0
 8006810:	d17f      	bne.n	8006912 <_strtod_l+0x8fa>
 8006812:	e63a      	b.n	800648a <_strtod_l+0x472>
 8006814:	07d6      	lsls	r6, r2, #31
 8006816:	d508      	bpl.n	800682a <_strtod_l+0x812>
 8006818:	ed9d 6b06 	vldr	d6, [sp, #24]
 800681c:	ed91 7b00 	vldr	d7, [r1]
 8006820:	ee26 7b07 	vmul.f64	d7, d6, d7
 8006824:	ed8d 7b06 	vstr	d7, [sp, #24]
 8006828:	2001      	movs	r0, #1
 800682a:	1052      	asrs	r2, r2, #1
 800682c:	3108      	adds	r1, #8
 800682e:	e6db      	b.n	80065e8 <_strtod_l+0x5d0>
 8006830:	f04f 31ff 	mov.w	r1, #4294967295	; 0xffffffff
 8006834:	fa01 f202 	lsl.w	r2, r1, r2
 8006838:	ea02 0a0a 	and.w	sl, r2, sl
 800683c:	e6f3      	b.n	8006626 <_strtod_l+0x60e>
 800683e:	f1c6 467f 	rsb	r6, r6, #4278190080	; 0xff000000
 8006842:	f506 067f 	add.w	r6, r6, #16711680	; 0xff0000
 8006846:	f506 467b 	add.w	r6, r6, #64256	; 0xfb00
 800684a:	36e2      	adds	r6, #226	; 0xe2
 800684c:	fa01 f306 	lsl.w	r3, r1, r6
 8006850:	930f      	str	r3, [sp, #60]	; 0x3c
 8006852:	9111      	str	r1, [sp, #68]	; 0x44
 8006854:	e758      	b.n	8006708 <_strtod_l+0x6f0>
 8006856:	2300      	movs	r3, #0
 8006858:	930f      	str	r3, [sp, #60]	; 0x3c
 800685a:	2301      	movs	r3, #1
 800685c:	9311      	str	r3, [sp, #68]	; 0x44
 800685e:	e753      	b.n	8006708 <_strtod_l+0x6f0>
 8006860:	461a      	mov	r2, r3
 8006862:	9918      	ldr	r1, [sp, #96]	; 0x60
 8006864:	4620      	mov	r0, r4
 8006866:	f001 fd6b 	bl	8008340 <__lshift>
 800686a:	9018      	str	r0, [sp, #96]	; 0x60
 800686c:	2800      	cmp	r0, #0
 800686e:	f47f af7a 	bne.w	8006766 <_strtod_l+0x74e>
 8006872:	e600      	b.n	8006476 <_strtod_l+0x45e>
 8006874:	f3af 8000 	nop.w
 8006878:	94a03595 	.word	0x94a03595
 800687c:	3fdfffff 	.word	0x3fdfffff
 8006880:	35afe535 	.word	0x35afe535
 8006884:	3fe00000 	.word	0x3fe00000
 8006888:	94a03595 	.word	0x94a03595
 800688c:	3fcfffff 	.word	0x3fcfffff
 8006890:	0802e720 	.word	0x0802e720
 8006894:	fffffc02 	.word	0xfffffc02
 8006898:	f8cd b020 	str.w	fp, [sp, #32]
 800689c:	f040 8085 	bne.w	80069aa <_strtod_l+0x992>
 80068a0:	9a0c      	ldr	r2, [sp, #48]	; 0x30
 80068a2:	f3cb 0313 	ubfx	r3, fp, #0, #20
 80068a6:	b322      	cbz	r2, 80068f2 <_strtod_l+0x8da>
 80068a8:	4ab7      	ldr	r2, [pc, #732]	; (8006b88 <_strtod_l+0xb70>)
 80068aa:	4293      	cmp	r3, r2
 80068ac:	d154      	bne.n	8006958 <_strtod_l+0x940>
 80068ae:	4651      	mov	r1, sl
 80068b0:	b1e7      	cbz	r7, 80068ec <_strtod_l+0x8d4>
 80068b2:	4bb6      	ldr	r3, [pc, #728]	; (8006b8c <_strtod_l+0xb74>)
 80068b4:	465a      	mov	r2, fp
 80068b6:	4013      	ands	r3, r2
 80068b8:	f1b3 6fd4 	cmp.w	r3, #111149056	; 0x6a00000
 80068bc:	f04f 32ff 	mov.w	r2, #4294967295	; 0xffffffff
 80068c0:	d803      	bhi.n	80068ca <_strtod_l+0x8b2>
 80068c2:	0d1b      	lsrs	r3, r3, #20
 80068c4:	f1c3 036b 	rsb	r3, r3, #107	; 0x6b
 80068c8:	409a      	lsls	r2, r3
 80068ca:	4291      	cmp	r1, r2
 80068cc:	d144      	bne.n	8006958 <_strtod_l+0x940>
 80068ce:	4bb0      	ldr	r3, [pc, #704]	; (8006b90 <_strtod_l+0xb78>)
 80068d0:	9a08      	ldr	r2, [sp, #32]
 80068d2:	429a      	cmp	r2, r3
 80068d4:	d102      	bne.n	80068dc <_strtod_l+0x8c4>
 80068d6:	3101      	adds	r1, #1
 80068d8:	f43f adcd 	beq.w	8006476 <_strtod_l+0x45e>
 80068dc:	4bab      	ldr	r3, [pc, #684]	; (8006b8c <_strtod_l+0xb74>)
 80068de:	9a08      	ldr	r2, [sp, #32]
 80068e0:	401a      	ands	r2, r3
 80068e2:	f502 1b80 	add.w	fp, r2, #1048576	; 0x100000
 80068e6:	f04f 0a00 	mov.w	sl, #0
 80068ea:	e790      	b.n	800680e <_strtod_l+0x7f6>
 80068ec:	f04f 32ff 	mov.w	r2, #4294967295	; 0xffffffff
 80068f0:	e7eb      	b.n	80068ca <_strtod_l+0x8b2>
 80068f2:	bb8b      	cbnz	r3, 8006958 <_strtod_l+0x940>
 80068f4:	f1ba 0f00 	cmp.w	sl, #0
 80068f8:	d12e      	bne.n	8006958 <_strtod_l+0x940>
 80068fa:	465b      	mov	r3, fp
 80068fc:	4aa3      	ldr	r2, [pc, #652]	; (8006b8c <_strtod_l+0xb74>)
 80068fe:	b30f      	cbz	r7, 8006944 <_strtod_l+0x92c>
 8006900:	ea02 010b 	and.w	r1, r2, fp
 8006904:	f1b1 6fd6 	cmp.w	r1, #112197632	; 0x6b00000
 8006908:	dc1c      	bgt.n	8006944 <_strtod_l+0x92c>
 800690a:	f1b1 7f5c 	cmp.w	r1, #57671680	; 0x3700000
 800690e:	f77f ae48 	ble.w	80065a2 <_strtod_l+0x58a>
 8006912:	4aa0      	ldr	r2, [pc, #640]	; (8006b94 <_strtod_l+0xb7c>)
 8006914:	2300      	movs	r3, #0
 8006916:	e9cd 3212 	strd	r3, r2, [sp, #72]	; 0x48
 800691a:	ed9d 6b12 	vldr	d6, [sp, #72]	; 0x48
 800691e:	ec4b ab17 	vmov	d7, sl, fp
 8006922:	ee27 7b06 	vmul.f64	d7, d7, d6
 8006926:	ed8d 7b04 	vstr	d7, [sp, #16]
 800692a:	9b05      	ldr	r3, [sp, #20]
 800692c:	e9dd ab04 	ldrd	sl, fp, [sp, #16]
 8006930:	2b00      	cmp	r3, #0
 8006932:	f47f adaa 	bne.w	800648a <_strtod_l+0x472>
 8006936:	9b04      	ldr	r3, [sp, #16]
 8006938:	2b00      	cmp	r3, #0
 800693a:	f47f ada6 	bne.w	800648a <_strtod_l+0x472>
 800693e:	2322      	movs	r3, #34	; 0x22
 8006940:	6023      	str	r3, [r4, #0]
 8006942:	e5a2      	b.n	800648a <_strtod_l+0x472>
 8006944:	4013      	ands	r3, r2
 8006946:	f5a3 1380 	sub.w	r3, r3, #1048576	; 0x100000
 800694a:	ea6f 5b13 	mvn.w	fp, r3, lsr #20
 800694e:	ea6f 5b0b 	mvn.w	fp, fp, lsl #20
 8006952:	f04f 3aff 	mov.w	sl, #4294967295	; 0xffffffff
 8006956:	e75a      	b.n	800680e <_strtod_l+0x7f6>
 8006958:	9b0f      	ldr	r3, [sp, #60]	; 0x3c
 800695a:	b18b      	cbz	r3, 8006980 <_strtod_l+0x968>
 800695c:	9a08      	ldr	r2, [sp, #32]
 800695e:	4213      	tst	r3, r2
 8006960:	f43f af55 	beq.w	800680e <_strtod_l+0x7f6>
 8006964:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 8006966:	463a      	mov	r2, r7
 8006968:	4650      	mov	r0, sl
 800696a:	4659      	mov	r1, fp
 800696c:	b163      	cbz	r3, 8006988 <_strtod_l+0x970>
 800696e:	f7ff fb39 	bl	8005fe4 <sulp>
 8006972:	ed9d 7b0a 	vldr	d7, [sp, #40]	; 0x28
 8006976:	ee37 7b00 	vadd.f64	d7, d7, d0
 800697a:	ec5b ab17 	vmov	sl, fp, d7
 800697e:	e746      	b.n	800680e <_strtod_l+0x7f6>
 8006980:	9b11      	ldr	r3, [sp, #68]	; 0x44
 8006982:	ea13 0f0a 	tst.w	r3, sl
 8006986:	e7eb      	b.n	8006960 <_strtod_l+0x948>
 8006988:	f7ff fb2c 	bl	8005fe4 <sulp>
 800698c:	ed9d 7b0a 	vldr	d7, [sp, #40]	; 0x28
 8006990:	ee37 7b40 	vsub.f64	d7, d7, d0
 8006994:	ed8d 7b04 	vstr	d7, [sp, #16]
 8006998:	eeb5 7b40 	vcmp.f64	d7, #0.0
 800699c:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 80069a0:	e9dd ab04 	ldrd	sl, fp, [sp, #16]
 80069a4:	f43f adfd 	beq.w	80065a2 <_strtod_l+0x58a>
 80069a8:	e731      	b.n	800680e <_strtod_l+0x7f6>
 80069aa:	4641      	mov	r1, r8
 80069ac:	4628      	mov	r0, r5
 80069ae:	f001 fe58 	bl	8008662 <__ratio>
 80069b2:	eeb0 7b00 	vmov.f64	d7, #0	; 0x40000000  2.0
 80069b6:	eeb4 0bc7 	vcmpe.f64	d0, d7
 80069ba:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 80069be:	d869      	bhi.n	8006a94 <_strtod_l+0xa7c>
 80069c0:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 80069c2:	2b00      	cmp	r3, #0
 80069c4:	d045      	beq.n	8006a52 <_strtod_l+0xa3a>
 80069c6:	4b74      	ldr	r3, [pc, #464]	; (8006b98 <_strtod_l+0xb80>)
 80069c8:	2200      	movs	r2, #0
 80069ca:	eeb7 8b00 	vmov.f64	d8, #112	; 0x3f800000  1.0
 80069ce:	9808      	ldr	r0, [sp, #32]
 80069d0:	496e      	ldr	r1, [pc, #440]	; (8006b8c <_strtod_l+0xb74>)
 80069d2:	ea00 0601 	and.w	r6, r0, r1
 80069d6:	4871      	ldr	r0, [pc, #452]	; (8006b9c <_strtod_l+0xb84>)
 80069d8:	4286      	cmp	r6, r0
 80069da:	f040 8089 	bne.w	8006af0 <_strtod_l+0xad8>
 80069de:	910f      	str	r1, [sp, #60]	; 0x3c
 80069e0:	e9dd 010a 	ldrd	r0, r1, [sp, #40]	; 0x28
 80069e4:	e9cd 0112 	strd	r0, r1, [sp, #72]	; 0x48
 80069e8:	9908      	ldr	r1, [sp, #32]
 80069ea:	f1a1 7b54 	sub.w	fp, r1, #55574528	; 0x3500000
 80069ee:	ec4b ab10 	vmov	d0, sl, fp
 80069f2:	ec43 2b1c 	vmov	d12, r2, r3
 80069f6:	f001 fd6f 	bl	80084d8 <__ulp>
 80069fa:	ec4b ab1d 	vmov	d13, sl, fp
 80069fe:	eeac db00 	vfma.f64	d13, d12, d0
 8006a02:	ed8d db08 	vstr	d13, [sp, #32]
 8006a06:	9b09      	ldr	r3, [sp, #36]	; 0x24
 8006a08:	990f      	ldr	r1, [sp, #60]	; 0x3c
 8006a0a:	4a65      	ldr	r2, [pc, #404]	; (8006ba0 <_strtod_l+0xb88>)
 8006a0c:	4019      	ands	r1, r3
 8006a0e:	4291      	cmp	r1, r2
 8006a10:	e9dd ab08 	ldrd	sl, fp, [sp, #32]
 8006a14:	d948      	bls.n	8006aa8 <_strtod_l+0xa90>
 8006a16:	9b0b      	ldr	r3, [sp, #44]	; 0x2c
 8006a18:	f102 7254 	add.w	r2, r2, #55574528	; 0x3500000
 8006a1c:	4293      	cmp	r3, r2
 8006a1e:	d103      	bne.n	8006a28 <_strtod_l+0xa10>
 8006a20:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 8006a22:	3301      	adds	r3, #1
 8006a24:	f43f ad27 	beq.w	8006476 <_strtod_l+0x45e>
 8006a28:	f8df b164 	ldr.w	fp, [pc, #356]	; 8006b90 <_strtod_l+0xb78>
 8006a2c:	f04f 3aff 	mov.w	sl, #4294967295	; 0xffffffff
 8006a30:	9918      	ldr	r1, [sp, #96]	; 0x60
 8006a32:	4620      	mov	r0, r4
 8006a34:	f001 fab8 	bl	8007fa8 <_Bfree>
 8006a38:	4649      	mov	r1, r9
 8006a3a:	4620      	mov	r0, r4
 8006a3c:	f001 fab4 	bl	8007fa8 <_Bfree>
 8006a40:	4641      	mov	r1, r8
 8006a42:	4620      	mov	r0, r4
 8006a44:	f001 fab0 	bl	8007fa8 <_Bfree>
 8006a48:	4629      	mov	r1, r5
 8006a4a:	4620      	mov	r0, r4
 8006a4c:	f001 faac 	bl	8007fa8 <_Bfree>
 8006a50:	e60e      	b.n	8006670 <_strtod_l+0x658>
 8006a52:	f1ba 0f00 	cmp.w	sl, #0
 8006a56:	d113      	bne.n	8006a80 <_strtod_l+0xa68>
 8006a58:	9b08      	ldr	r3, [sp, #32]
 8006a5a:	f3c3 0313 	ubfx	r3, r3, #0, #20
 8006a5e:	b9b3      	cbnz	r3, 8006a8e <_strtod_l+0xa76>
 8006a60:	eeb7 7b00 	vmov.f64	d7, #112	; 0x3f800000  1.0
 8006a64:	eeb4 0bc7 	vcmpe.f64	d0, d7
 8006a68:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 8006a6c:	eeb6 8b00 	vmov.f64	d8, #96	; 0x3f000000  0.5
 8006a70:	d401      	bmi.n	8006a76 <_strtod_l+0xa5e>
 8006a72:	ee20 8b08 	vmul.f64	d8, d0, d8
 8006a76:	eeb1 7b48 	vneg.f64	d7, d8
 8006a7a:	ec53 2b17 	vmov	r2, r3, d7
 8006a7e:	e7a6      	b.n	80069ce <_strtod_l+0x9b6>
 8006a80:	f1ba 0f01 	cmp.w	sl, #1
 8006a84:	d103      	bne.n	8006a8e <_strtod_l+0xa76>
 8006a86:	9b08      	ldr	r3, [sp, #32]
 8006a88:	2b00      	cmp	r3, #0
 8006a8a:	f43f ad8a 	beq.w	80065a2 <_strtod_l+0x58a>
 8006a8e:	2200      	movs	r2, #0
 8006a90:	4b44      	ldr	r3, [pc, #272]	; (8006ba4 <_strtod_l+0xb8c>)
 8006a92:	e79a      	b.n	80069ca <_strtod_l+0x9b2>
 8006a94:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 8006a96:	eeb6 8b00 	vmov.f64	d8, #96	; 0x3f000000  0.5
 8006a9a:	ee20 8b08 	vmul.f64	d8, d0, d8
 8006a9e:	2b00      	cmp	r3, #0
 8006aa0:	d0e9      	beq.n	8006a76 <_strtod_l+0xa5e>
 8006aa2:	ec53 2b18 	vmov	r2, r3, d8
 8006aa6:	e792      	b.n	80069ce <_strtod_l+0x9b6>
 8006aa8:	f103 7b54 	add.w	fp, r3, #55574528	; 0x3500000
 8006aac:	2f00      	cmp	r7, #0
 8006aae:	d1bf      	bne.n	8006a30 <_strtod_l+0xa18>
 8006ab0:	f02b 4300 	bic.w	r3, fp, #2147483648	; 0x80000000
 8006ab4:	0d1b      	lsrs	r3, r3, #20
 8006ab6:	051b      	lsls	r3, r3, #20
 8006ab8:	429e      	cmp	r6, r3
 8006aba:	d1b9      	bne.n	8006a30 <_strtod_l+0xa18>
 8006abc:	eebd 0bc8 	vcvt.s32.f64	s0, d8
 8006ac0:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 8006ac2:	eeb8 0bc0 	vcvt.f64.s32	d0, s0
 8006ac6:	ee38 8b40 	vsub.f64	d8, d8, d0
 8006aca:	b92b      	cbnz	r3, 8006ad8 <_strtod_l+0xac0>
 8006acc:	f1ba 0f00 	cmp.w	sl, #0
 8006ad0:	d102      	bne.n	8006ad8 <_strtod_l+0xac0>
 8006ad2:	f3cb 0213 	ubfx	r2, fp, #0, #20
 8006ad6:	b3d2      	cbz	r2, 8006b4e <_strtod_l+0xb36>
 8006ad8:	eeb4 8bc9 	vcmpe.f64	d8, d9
 8006adc:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 8006ae0:	f53f acd3 	bmi.w	800648a <_strtod_l+0x472>
 8006ae4:	eeb4 8bca 	vcmpe.f64	d8, d10
 8006ae8:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 8006aec:	dda0      	ble.n	8006a30 <_strtod_l+0xa18>
 8006aee:	e4cc      	b.n	800648a <_strtod_l+0x472>
 8006af0:	b1ef      	cbz	r7, 8006b2e <_strtod_l+0xb16>
 8006af2:	f1b6 6fd4 	cmp.w	r6, #111149056	; 0x6a00000
 8006af6:	d81a      	bhi.n	8006b2e <_strtod_l+0xb16>
 8006af8:	ed9f 7b21 	vldr	d7, [pc, #132]	; 8006b80 <_strtod_l+0xb68>
 8006afc:	eeb4 8bc7 	vcmpe.f64	d8, d7
 8006b00:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 8006b04:	d810      	bhi.n	8006b28 <_strtod_l+0xb10>
 8006b06:	eefc 7bc8 	vcvt.u32.f64	s15, d8
 8006b0a:	ee17 3a90 	vmov	r3, s15
 8006b0e:	2b00      	cmp	r3, #0
 8006b10:	bf08      	it	eq
 8006b12:	2301      	moveq	r3, #1
 8006b14:	ee07 3a90 	vmov	s15, r3
 8006b18:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 8006b1a:	eeb8 8b67 	vcvt.f64.u32	d8, s15
 8006b1e:	b99b      	cbnz	r3, 8006b48 <_strtod_l+0xb30>
 8006b20:	eeb1 7b48 	vneg.f64	d7, d8
 8006b24:	ec53 2b17 	vmov	r2, r3, d7
 8006b28:	f103 61d6 	add.w	r1, r3, #112197632	; 0x6b00000
 8006b2c:	1b8b      	subs	r3, r1, r6
 8006b2e:	ed9d 0b0a 	vldr	d0, [sp, #40]	; 0x28
 8006b32:	ec43 2b1c 	vmov	d12, r2, r3
 8006b36:	f001 fccf 	bl	80084d8 <__ulp>
 8006b3a:	ed9d 7b0a 	vldr	d7, [sp, #40]	; 0x28
 8006b3e:	eeac 7b00 	vfma.f64	d7, d12, d0
 8006b42:	ec5b ab17 	vmov	sl, fp, d7
 8006b46:	e7b1      	b.n	8006aac <_strtod_l+0xa94>
 8006b48:	ec53 2b18 	vmov	r2, r3, d8
 8006b4c:	e7ec      	b.n	8006b28 <_strtod_l+0xb10>
 8006b4e:	eeb4 8bcb 	vcmpe.f64	d8, d11
 8006b52:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 8006b56:	f57f af6b 	bpl.w	8006a30 <_strtod_l+0xa18>
 8006b5a:	e496      	b.n	800648a <_strtod_l+0x472>
 8006b5c:	2300      	movs	r3, #0
 8006b5e:	930d      	str	r3, [sp, #52]	; 0x34
 8006b60:	9a14      	ldr	r2, [sp, #80]	; 0x50
 8006b62:	9b17      	ldr	r3, [sp, #92]	; 0x5c
 8006b64:	6013      	str	r3, [r2, #0]
 8006b66:	f7ff ba9d 	b.w	80060a4 <_strtod_l+0x8c>
 8006b6a:	2a65      	cmp	r2, #101	; 0x65
 8006b6c:	f04f 0100 	mov.w	r1, #0
 8006b70:	f43f ab97 	beq.w	80062a2 <_strtod_l+0x28a>
 8006b74:	2701      	movs	r7, #1
 8006b76:	460b      	mov	r3, r1
 8006b78:	9704      	str	r7, [sp, #16]
 8006b7a:	f7ff bb0a 	b.w	8006192 <_strtod_l+0x17a>
 8006b7e:	bf00      	nop
 8006b80:	ffc00000 	.word	0xffc00000
 8006b84:	41dfffff 	.word	0x41dfffff
 8006b88:	000fffff 	.word	0x000fffff
 8006b8c:	7ff00000 	.word	0x7ff00000
 8006b90:	7fefffff 	.word	0x7fefffff
 8006b94:	39500000 	.word	0x39500000
 8006b98:	3ff00000 	.word	0x3ff00000
 8006b9c:	7fe00000 	.word	0x7fe00000
 8006ba0:	7c9fffff 	.word	0x7c9fffff
 8006ba4:	bff00000 	.word	0xbff00000

08006ba8 <_strtod_r>:
 8006ba8:	4b05      	ldr	r3, [pc, #20]	; (8006bc0 <_strtod_r+0x18>)
 8006baa:	681b      	ldr	r3, [r3, #0]
 8006bac:	b410      	push	{r4}
 8006bae:	6a1b      	ldr	r3, [r3, #32]
 8006bb0:	4c04      	ldr	r4, [pc, #16]	; (8006bc4 <_strtod_r+0x1c>)
 8006bb2:	2b00      	cmp	r3, #0
 8006bb4:	bf08      	it	eq
 8006bb6:	4623      	moveq	r3, r4
 8006bb8:	f85d 4b04 	ldr.w	r4, [sp], #4
 8006bbc:	f7ff ba2c 	b.w	8006018 <_strtod_l>
 8006bc0:	20000010 	.word	0x20000010
 8006bc4:	20000074 	.word	0x20000074

08006bc8 <_strtol_l.isra.0>:
 8006bc8:	e92d 47f0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, lr}
 8006bcc:	4680      	mov	r8, r0
 8006bce:	4689      	mov	r9, r1
 8006bd0:	4692      	mov	sl, r2
 8006bd2:	461e      	mov	r6, r3
 8006bd4:	460f      	mov	r7, r1
 8006bd6:	463d      	mov	r5, r7
 8006bd8:	9808      	ldr	r0, [sp, #32]
 8006bda:	f815 4b01 	ldrb.w	r4, [r5], #1
 8006bde:	f001 f981 	bl	8007ee4 <__locale_ctype_ptr_l>
 8006be2:	4420      	add	r0, r4
 8006be4:	7843      	ldrb	r3, [r0, #1]
 8006be6:	f013 0308 	ands.w	r3, r3, #8
 8006bea:	d132      	bne.n	8006c52 <_strtol_l.isra.0+0x8a>
 8006bec:	2c2d      	cmp	r4, #45	; 0x2d
 8006bee:	d132      	bne.n	8006c56 <_strtol_l.isra.0+0x8e>
 8006bf0:	787c      	ldrb	r4, [r7, #1]
 8006bf2:	1cbd      	adds	r5, r7, #2
 8006bf4:	2201      	movs	r2, #1
 8006bf6:	2e00      	cmp	r6, #0
 8006bf8:	d05d      	beq.n	8006cb6 <_strtol_l.isra.0+0xee>
 8006bfa:	2e10      	cmp	r6, #16
 8006bfc:	d109      	bne.n	8006c12 <_strtol_l.isra.0+0x4a>
 8006bfe:	2c30      	cmp	r4, #48	; 0x30
 8006c00:	d107      	bne.n	8006c12 <_strtol_l.isra.0+0x4a>
 8006c02:	782b      	ldrb	r3, [r5, #0]
 8006c04:	f003 03df 	and.w	r3, r3, #223	; 0xdf
 8006c08:	2b58      	cmp	r3, #88	; 0x58
 8006c0a:	d14f      	bne.n	8006cac <_strtol_l.isra.0+0xe4>
 8006c0c:	786c      	ldrb	r4, [r5, #1]
 8006c0e:	2610      	movs	r6, #16
 8006c10:	3502      	adds	r5, #2
 8006c12:	2a00      	cmp	r2, #0
 8006c14:	bf14      	ite	ne
 8006c16:	f04f 4100 	movne.w	r1, #2147483648	; 0x80000000
 8006c1a:	f06f 4100 	mvneq.w	r1, #2147483648	; 0x80000000
 8006c1e:	2700      	movs	r7, #0
 8006c20:	fbb1 fcf6 	udiv	ip, r1, r6
 8006c24:	4638      	mov	r0, r7
 8006c26:	fb06 1e1c 	mls	lr, r6, ip, r1
 8006c2a:	f1a4 0330 	sub.w	r3, r4, #48	; 0x30
 8006c2e:	2b09      	cmp	r3, #9
 8006c30:	d817      	bhi.n	8006c62 <_strtol_l.isra.0+0x9a>
 8006c32:	461c      	mov	r4, r3
 8006c34:	42a6      	cmp	r6, r4
 8006c36:	dd23      	ble.n	8006c80 <_strtol_l.isra.0+0xb8>
 8006c38:	1c7b      	adds	r3, r7, #1
 8006c3a:	d007      	beq.n	8006c4c <_strtol_l.isra.0+0x84>
 8006c3c:	4584      	cmp	ip, r0
 8006c3e:	d31c      	bcc.n	8006c7a <_strtol_l.isra.0+0xb2>
 8006c40:	d101      	bne.n	8006c46 <_strtol_l.isra.0+0x7e>
 8006c42:	45a6      	cmp	lr, r4
 8006c44:	db19      	blt.n	8006c7a <_strtol_l.isra.0+0xb2>
 8006c46:	fb00 4006 	mla	r0, r0, r6, r4
 8006c4a:	2701      	movs	r7, #1
 8006c4c:	f815 4b01 	ldrb.w	r4, [r5], #1
 8006c50:	e7eb      	b.n	8006c2a <_strtol_l.isra.0+0x62>
 8006c52:	462f      	mov	r7, r5
 8006c54:	e7bf      	b.n	8006bd6 <_strtol_l.isra.0+0xe>
 8006c56:	2c2b      	cmp	r4, #43	; 0x2b
 8006c58:	bf04      	itt	eq
 8006c5a:	1cbd      	addeq	r5, r7, #2
 8006c5c:	787c      	ldrbeq	r4, [r7, #1]
 8006c5e:	461a      	mov	r2, r3
 8006c60:	e7c9      	b.n	8006bf6 <_strtol_l.isra.0+0x2e>
 8006c62:	f1a4 0341 	sub.w	r3, r4, #65	; 0x41
 8006c66:	2b19      	cmp	r3, #25
 8006c68:	d801      	bhi.n	8006c6e <_strtol_l.isra.0+0xa6>
 8006c6a:	3c37      	subs	r4, #55	; 0x37
 8006c6c:	e7e2      	b.n	8006c34 <_strtol_l.isra.0+0x6c>
 8006c6e:	f1a4 0361 	sub.w	r3, r4, #97	; 0x61
 8006c72:	2b19      	cmp	r3, #25
 8006c74:	d804      	bhi.n	8006c80 <_strtol_l.isra.0+0xb8>
 8006c76:	3c57      	subs	r4, #87	; 0x57
 8006c78:	e7dc      	b.n	8006c34 <_strtol_l.isra.0+0x6c>
 8006c7a:	f04f 37ff 	mov.w	r7, #4294967295	; 0xffffffff
 8006c7e:	e7e5      	b.n	8006c4c <_strtol_l.isra.0+0x84>
 8006c80:	1c7b      	adds	r3, r7, #1
 8006c82:	d108      	bne.n	8006c96 <_strtol_l.isra.0+0xce>
 8006c84:	2322      	movs	r3, #34	; 0x22
 8006c86:	f8c8 3000 	str.w	r3, [r8]
 8006c8a:	4608      	mov	r0, r1
 8006c8c:	f1ba 0f00 	cmp.w	sl, #0
 8006c90:	d107      	bne.n	8006ca2 <_strtol_l.isra.0+0xda>
 8006c92:	e8bd 87f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, pc}
 8006c96:	b102      	cbz	r2, 8006c9a <_strtol_l.isra.0+0xd2>
 8006c98:	4240      	negs	r0, r0
 8006c9a:	f1ba 0f00 	cmp.w	sl, #0
 8006c9e:	d0f8      	beq.n	8006c92 <_strtol_l.isra.0+0xca>
 8006ca0:	b10f      	cbz	r7, 8006ca6 <_strtol_l.isra.0+0xde>
 8006ca2:	f105 39ff 	add.w	r9, r5, #4294967295	; 0xffffffff
 8006ca6:	f8ca 9000 	str.w	r9, [sl]
 8006caa:	e7f2      	b.n	8006c92 <_strtol_l.isra.0+0xca>
 8006cac:	2430      	movs	r4, #48	; 0x30
 8006cae:	2e00      	cmp	r6, #0
 8006cb0:	d1af      	bne.n	8006c12 <_strtol_l.isra.0+0x4a>
 8006cb2:	2608      	movs	r6, #8
 8006cb4:	e7ad      	b.n	8006c12 <_strtol_l.isra.0+0x4a>
 8006cb6:	2c30      	cmp	r4, #48	; 0x30
 8006cb8:	d0a3      	beq.n	8006c02 <_strtol_l.isra.0+0x3a>
 8006cba:	260a      	movs	r6, #10
 8006cbc:	e7a9      	b.n	8006c12 <_strtol_l.isra.0+0x4a>
	...

08006cc0 <_strtol_r>:
 8006cc0:	b537      	push	{r0, r1, r2, r4, r5, lr}
 8006cc2:	4c06      	ldr	r4, [pc, #24]	; (8006cdc <_strtol_r+0x1c>)
 8006cc4:	4d06      	ldr	r5, [pc, #24]	; (8006ce0 <_strtol_r+0x20>)
 8006cc6:	6824      	ldr	r4, [r4, #0]
 8006cc8:	6a24      	ldr	r4, [r4, #32]
 8006cca:	2c00      	cmp	r4, #0
 8006ccc:	bf08      	it	eq
 8006cce:	462c      	moveq	r4, r5
 8006cd0:	9400      	str	r4, [sp, #0]
 8006cd2:	f7ff ff79 	bl	8006bc8 <_strtol_l.isra.0>
 8006cd6:	b003      	add	sp, #12
 8006cd8:	bd30      	pop	{r4, r5, pc}
 8006cda:	bf00      	nop
 8006cdc:	20000010 	.word	0x20000010
 8006ce0:	20000074 	.word	0x20000074

08006ce4 <quorem>:
 8006ce4:	e92d 4ff7 	stmdb	sp!, {r0, r1, r2, r4, r5, r6, r7, r8, r9, sl, fp, lr}
 8006ce8:	6903      	ldr	r3, [r0, #16]
 8006cea:	690c      	ldr	r4, [r1, #16]
 8006cec:	42a3      	cmp	r3, r4
 8006cee:	4680      	mov	r8, r0
 8006cf0:	f2c0 8082 	blt.w	8006df8 <quorem+0x114>
 8006cf4:	3c01      	subs	r4, #1
 8006cf6:	f101 0714 	add.w	r7, r1, #20
 8006cfa:	ea4f 0c84 	mov.w	ip, r4, lsl #2
 8006cfe:	f100 0614 	add.w	r6, r0, #20
 8006d02:	f857 5024 	ldr.w	r5, [r7, r4, lsl #2]
 8006d06:	f856 0024 	ldr.w	r0, [r6, r4, lsl #2]
 8006d0a:	eb06 030c 	add.w	r3, r6, ip
 8006d0e:	3501      	adds	r5, #1
 8006d10:	eb07 090c 	add.w	r9, r7, ip
 8006d14:	9301      	str	r3, [sp, #4]
 8006d16:	fbb0 f5f5 	udiv	r5, r0, r5
 8006d1a:	b395      	cbz	r5, 8006d82 <quorem+0x9e>
 8006d1c:	f04f 0a00 	mov.w	sl, #0
 8006d20:	4638      	mov	r0, r7
 8006d22:	46b6      	mov	lr, r6
 8006d24:	46d3      	mov	fp, sl
 8006d26:	f850 2b04 	ldr.w	r2, [r0], #4
 8006d2a:	b293      	uxth	r3, r2
 8006d2c:	fb05 a303 	mla	r3, r5, r3, sl
 8006d30:	ea4f 4a13 	mov.w	sl, r3, lsr #16
 8006d34:	b29b      	uxth	r3, r3
 8006d36:	ebab 0303 	sub.w	r3, fp, r3
 8006d3a:	0c12      	lsrs	r2, r2, #16
 8006d3c:	f8de b000 	ldr.w	fp, [lr]
 8006d40:	fb05 a202 	mla	r2, r5, r2, sl
 8006d44:	fa13 f38b 	uxtah	r3, r3, fp
 8006d48:	ea4f 4a12 	mov.w	sl, r2, lsr #16
 8006d4c:	fa1f fb82 	uxth.w	fp, r2
 8006d50:	f8de 2000 	ldr.w	r2, [lr]
 8006d54:	ebcb 4212 	rsb	r2, fp, r2, lsr #16
 8006d58:	eb02 4223 	add.w	r2, r2, r3, asr #16
 8006d5c:	b29b      	uxth	r3, r3
 8006d5e:	ea43 4302 	orr.w	r3, r3, r2, lsl #16
 8006d62:	4581      	cmp	r9, r0
 8006d64:	ea4f 4b22 	mov.w	fp, r2, asr #16
 8006d68:	f84e 3b04 	str.w	r3, [lr], #4
 8006d6c:	d2db      	bcs.n	8006d26 <quorem+0x42>
 8006d6e:	f856 300c 	ldr.w	r3, [r6, ip]
 8006d72:	b933      	cbnz	r3, 8006d82 <quorem+0x9e>
 8006d74:	9b01      	ldr	r3, [sp, #4]
 8006d76:	3b04      	subs	r3, #4
 8006d78:	429e      	cmp	r6, r3
 8006d7a:	461a      	mov	r2, r3
 8006d7c:	d330      	bcc.n	8006de0 <quorem+0xfc>
 8006d7e:	f8c8 4010 	str.w	r4, [r8, #16]
 8006d82:	4640      	mov	r0, r8
 8006d84:	f001 fb30 	bl	80083e8 <__mcmp>
 8006d88:	2800      	cmp	r0, #0
 8006d8a:	db25      	blt.n	8006dd8 <quorem+0xf4>
 8006d8c:	3501      	adds	r5, #1
 8006d8e:	4630      	mov	r0, r6
 8006d90:	f04f 0c00 	mov.w	ip, #0
 8006d94:	f857 2b04 	ldr.w	r2, [r7], #4
 8006d98:	f8d0 e000 	ldr.w	lr, [r0]
 8006d9c:	b293      	uxth	r3, r2
 8006d9e:	ebac 0303 	sub.w	r3, ip, r3
 8006da2:	0c12      	lsrs	r2, r2, #16
 8006da4:	fa13 f38e 	uxtah	r3, r3, lr
 8006da8:	ebc2 421e 	rsb	r2, r2, lr, lsr #16
 8006dac:	eb02 4223 	add.w	r2, r2, r3, asr #16
 8006db0:	b29b      	uxth	r3, r3
 8006db2:	ea43 4302 	orr.w	r3, r3, r2, lsl #16
 8006db6:	45b9      	cmp	r9, r7
 8006db8:	ea4f 4c22 	mov.w	ip, r2, asr #16
 8006dbc:	f840 3b04 	str.w	r3, [r0], #4
 8006dc0:	d2e8      	bcs.n	8006d94 <quorem+0xb0>
 8006dc2:	f856 2024 	ldr.w	r2, [r6, r4, lsl #2]
 8006dc6:	eb06 0384 	add.w	r3, r6, r4, lsl #2
 8006dca:	b92a      	cbnz	r2, 8006dd8 <quorem+0xf4>
 8006dcc:	3b04      	subs	r3, #4
 8006dce:	429e      	cmp	r6, r3
 8006dd0:	461a      	mov	r2, r3
 8006dd2:	d30b      	bcc.n	8006dec <quorem+0x108>
 8006dd4:	f8c8 4010 	str.w	r4, [r8, #16]
 8006dd8:	4628      	mov	r0, r5
 8006dda:	b003      	add	sp, #12
 8006ddc:	e8bd 8ff0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, pc}
 8006de0:	6812      	ldr	r2, [r2, #0]
 8006de2:	3b04      	subs	r3, #4
 8006de4:	2a00      	cmp	r2, #0
 8006de6:	d1ca      	bne.n	8006d7e <quorem+0x9a>
 8006de8:	3c01      	subs	r4, #1
 8006dea:	e7c5      	b.n	8006d78 <quorem+0x94>
 8006dec:	6812      	ldr	r2, [r2, #0]
 8006dee:	3b04      	subs	r3, #4
 8006df0:	2a00      	cmp	r2, #0
 8006df2:	d1ef      	bne.n	8006dd4 <quorem+0xf0>
 8006df4:	3c01      	subs	r4, #1
 8006df6:	e7ea      	b.n	8006dce <quorem+0xea>
 8006df8:	2000      	movs	r0, #0
 8006dfa:	e7ee      	b.n	8006dda <quorem+0xf6>
 8006dfc:	0000      	movs	r0, r0
	...

08006e00 <_dtoa_r>:
 8006e00:	e92d 4ff0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, lr}
 8006e04:	ec57 6b10 	vmov	r6, r7, d0
 8006e08:	b095      	sub	sp, #84	; 0x54
 8006e0a:	6a45      	ldr	r5, [r0, #36]	; 0x24
 8006e0c:	9108      	str	r1, [sp, #32]
 8006e0e:	4604      	mov	r4, r0
 8006e10:	920a      	str	r2, [sp, #40]	; 0x28
 8006e12:	9311      	str	r3, [sp, #68]	; 0x44
 8006e14:	f8dd 8078 	ldr.w	r8, [sp, #120]	; 0x78
 8006e18:	e9cd 6702 	strd	r6, r7, [sp, #8]
 8006e1c:	b93d      	cbnz	r5, 8006e2e <_dtoa_r+0x2e>
 8006e1e:	2010      	movs	r0, #16
 8006e20:	f001 f874 	bl	8007f0c <malloc>
 8006e24:	6260      	str	r0, [r4, #36]	; 0x24
 8006e26:	e9c0 5501 	strd	r5, r5, [r0, #4]
 8006e2a:	6005      	str	r5, [r0, #0]
 8006e2c:	60c5      	str	r5, [r0, #12]
 8006e2e:	6a63      	ldr	r3, [r4, #36]	; 0x24
 8006e30:	6819      	ldr	r1, [r3, #0]
 8006e32:	b151      	cbz	r1, 8006e4a <_dtoa_r+0x4a>
 8006e34:	685a      	ldr	r2, [r3, #4]
 8006e36:	604a      	str	r2, [r1, #4]
 8006e38:	2301      	movs	r3, #1
 8006e3a:	4093      	lsls	r3, r2
 8006e3c:	608b      	str	r3, [r1, #8]
 8006e3e:	4620      	mov	r0, r4
 8006e40:	f001 f8b2 	bl	8007fa8 <_Bfree>
 8006e44:	6a63      	ldr	r3, [r4, #36]	; 0x24
 8006e46:	2200      	movs	r2, #0
 8006e48:	601a      	str	r2, [r3, #0]
 8006e4a:	1e3b      	subs	r3, r7, #0
 8006e4c:	bfb9      	ittee	lt
 8006e4e:	f023 4300 	biclt.w	r3, r3, #2147483648	; 0x80000000
 8006e52:	9303      	strlt	r3, [sp, #12]
 8006e54:	2300      	movge	r3, #0
 8006e56:	f8c8 3000 	strge.w	r3, [r8]
 8006e5a:	9d03      	ldr	r5, [sp, #12]
 8006e5c:	4bac      	ldr	r3, [pc, #688]	; (8007110 <_dtoa_r+0x310>)
 8006e5e:	bfbc      	itt	lt
 8006e60:	2201      	movlt	r2, #1
 8006e62:	f8c8 2000 	strlt.w	r2, [r8]
 8006e66:	43ab      	bics	r3, r5
 8006e68:	d11b      	bne.n	8006ea2 <_dtoa_r+0xa2>
 8006e6a:	9a11      	ldr	r2, [sp, #68]	; 0x44
 8006e6c:	f242 730f 	movw	r3, #9999	; 0x270f
 8006e70:	6013      	str	r3, [r2, #0]
 8006e72:	9b02      	ldr	r3, [sp, #8]
 8006e74:	b923      	cbnz	r3, 8006e80 <_dtoa_r+0x80>
 8006e76:	f3c5 0513 	ubfx	r5, r5, #0, #20
 8006e7a:	2d00      	cmp	r5, #0
 8006e7c:	f000 84dd 	beq.w	800783a <_dtoa_r+0xa3a>
 8006e80:	9b1f      	ldr	r3, [sp, #124]	; 0x7c
 8006e82:	b953      	cbnz	r3, 8006e9a <_dtoa_r+0x9a>
 8006e84:	4ba3      	ldr	r3, [pc, #652]	; (8007114 <_dtoa_r+0x314>)
 8006e86:	e020      	b.n	8006eca <_dtoa_r+0xca>
 8006e88:	4ba3      	ldr	r3, [pc, #652]	; (8007118 <_dtoa_r+0x318>)
 8006e8a:	9304      	str	r3, [sp, #16]
 8006e8c:	3308      	adds	r3, #8
 8006e8e:	9a1f      	ldr	r2, [sp, #124]	; 0x7c
 8006e90:	6013      	str	r3, [r2, #0]
 8006e92:	9804      	ldr	r0, [sp, #16]
 8006e94:	b015      	add	sp, #84	; 0x54
 8006e96:	e8bd 8ff0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, pc}
 8006e9a:	4b9e      	ldr	r3, [pc, #632]	; (8007114 <_dtoa_r+0x314>)
 8006e9c:	9304      	str	r3, [sp, #16]
 8006e9e:	3303      	adds	r3, #3
 8006ea0:	e7f5      	b.n	8006e8e <_dtoa_r+0x8e>
 8006ea2:	ed9d 7b02 	vldr	d7, [sp, #8]
 8006ea6:	eeb5 7b40 	vcmp.f64	d7, #0.0
 8006eaa:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 8006eae:	ed8d 7b04 	vstr	d7, [sp, #16]
 8006eb2:	d10c      	bne.n	8006ece <_dtoa_r+0xce>
 8006eb4:	9a11      	ldr	r2, [sp, #68]	; 0x44
 8006eb6:	2301      	movs	r3, #1
 8006eb8:	6013      	str	r3, [r2, #0]
 8006eba:	9b1f      	ldr	r3, [sp, #124]	; 0x7c
 8006ebc:	2b00      	cmp	r3, #0
 8006ebe:	f000 84b9 	beq.w	8007834 <_dtoa_r+0xa34>
 8006ec2:	4b96      	ldr	r3, [pc, #600]	; (800711c <_dtoa_r+0x31c>)
 8006ec4:	9a1f      	ldr	r2, [sp, #124]	; 0x7c
 8006ec6:	6013      	str	r3, [r2, #0]
 8006ec8:	3b01      	subs	r3, #1
 8006eca:	9304      	str	r3, [sp, #16]
 8006ecc:	e7e1      	b.n	8006e92 <_dtoa_r+0x92>
 8006ece:	a913      	add	r1, sp, #76	; 0x4c
 8006ed0:	aa12      	add	r2, sp, #72	; 0x48
 8006ed2:	ed9d 0b04 	vldr	d0, [sp, #16]
 8006ed6:	4620      	mov	r0, r4
 8006ed8:	f001 fb74 	bl	80085c4 <__d2b>
 8006edc:	f3c5 560a 	ubfx	r6, r5, #20, #11
 8006ee0:	9001      	str	r0, [sp, #4]
 8006ee2:	9912      	ldr	r1, [sp, #72]	; 0x48
 8006ee4:	2e00      	cmp	r6, #0
 8006ee6:	d046      	beq.n	8006f76 <_dtoa_r+0x176>
 8006ee8:	9805      	ldr	r0, [sp, #20]
 8006eea:	f3c0 0013 	ubfx	r0, r0, #0, #20
 8006eee:	e9dd 2304 	ldrd	r2, r3, [sp, #16]
 8006ef2:	f040 537f 	orr.w	r3, r0, #1069547520	; 0x3fc00000
 8006ef6:	f443 1340 	orr.w	r3, r3, #3145728	; 0x300000
 8006efa:	f2a6 3aff 	subw	sl, r6, #1023	; 0x3ff
 8006efe:	2700      	movs	r7, #0
 8006f00:	ee07 aa90 	vmov	s15, sl
 8006f04:	ec43 2b16 	vmov	d6, r2, r3
 8006f08:	eeb8 5be7 	vcvt.f64.s32	d5, s15
 8006f0c:	ed9f 4b7a 	vldr	d4, [pc, #488]	; 80070f8 <_dtoa_r+0x2f8>
 8006f10:	eeb7 7b08 	vmov.f64	d7, #120	; 0x3fc00000  1.5
 8006f14:	ee36 7b47 	vsub.f64	d7, d6, d7
 8006f18:	ed9f 6b79 	vldr	d6, [pc, #484]	; 8007100 <_dtoa_r+0x300>
 8006f1c:	eea7 6b04 	vfma.f64	d6, d7, d4
 8006f20:	eeb0 7b46 	vmov.f64	d7, d6
 8006f24:	ed9f 6b78 	vldr	d6, [pc, #480]	; 8007108 <_dtoa_r+0x308>
 8006f28:	eea5 7b06 	vfma.f64	d7, d5, d6
 8006f2c:	eefd 6bc7 	vcvt.s32.f64	s13, d7
 8006f30:	eeb5 7bc0 	vcmpe.f64	d7, #0.0
 8006f34:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 8006f38:	ee16 ba90 	vmov	fp, s13
 8006f3c:	d508      	bpl.n	8006f50 <_dtoa_r+0x150>
 8006f3e:	eeb8 6be6 	vcvt.f64.s32	d6, s13
 8006f42:	eeb4 6b47 	vcmp.f64	d6, d7
 8006f46:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 8006f4a:	bf18      	it	ne
 8006f4c:	f10b 3bff 	addne.w	fp, fp, #4294967295	; 0xffffffff
 8006f50:	f1bb 0f16 	cmp.w	fp, #22
 8006f54:	d834      	bhi.n	8006fc0 <_dtoa_r+0x1c0>
 8006f56:	4b72      	ldr	r3, [pc, #456]	; (8007120 <_dtoa_r+0x320>)
 8006f58:	eb03 03cb 	add.w	r3, r3, fp, lsl #3
 8006f5c:	ed93 7b00 	vldr	d7, [r3]
 8006f60:	ed9d 6b02 	vldr	d6, [sp, #8]
 8006f64:	eeb4 7bc6 	vcmpe.f64	d7, d6
 8006f68:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 8006f6c:	dd01      	ble.n	8006f72 <_dtoa_r+0x172>
 8006f6e:	f10b 3bff 	add.w	fp, fp, #4294967295	; 0xffffffff
 8006f72:	2300      	movs	r3, #0
 8006f74:	e025      	b.n	8006fc2 <_dtoa_r+0x1c2>
 8006f76:	9b13      	ldr	r3, [sp, #76]	; 0x4c
 8006f78:	eb01 0a03 	add.w	sl, r1, r3
 8006f7c:	f20a 4332 	addw	r3, sl, #1074	; 0x432
 8006f80:	2b20      	cmp	r3, #32
 8006f82:	dd17      	ble.n	8006fb4 <_dtoa_r+0x1b4>
 8006f84:	f1c3 0340 	rsb	r3, r3, #64	; 0x40
 8006f88:	9a02      	ldr	r2, [sp, #8]
 8006f8a:	409d      	lsls	r5, r3
 8006f8c:	f20a 4312 	addw	r3, sl, #1042	; 0x412
 8006f90:	fa22 f303 	lsr.w	r3, r2, r3
 8006f94:	432b      	orrs	r3, r5
 8006f96:	ee07 3a90 	vmov	s15, r3
 8006f9a:	eeb8 7b67 	vcvt.f64.u32	d7, s15
 8006f9e:	f10a 3aff 	add.w	sl, sl, #4294967295	; 0xffffffff
 8006fa2:	ed8d 7b04 	vstr	d7, [sp, #16]
 8006fa6:	9805      	ldr	r0, [sp, #20]
 8006fa8:	e9dd 2304 	ldrd	r2, r3, [sp, #16]
 8006fac:	2701      	movs	r7, #1
 8006fae:	f1a0 73f8 	sub.w	r3, r0, #32505856	; 0x1f00000
 8006fb2:	e7a5      	b.n	8006f00 <_dtoa_r+0x100>
 8006fb4:	9a02      	ldr	r2, [sp, #8]
 8006fb6:	f1c3 0320 	rsb	r3, r3, #32
 8006fba:	fa02 f303 	lsl.w	r3, r2, r3
 8006fbe:	e7ea      	b.n	8006f96 <_dtoa_r+0x196>
 8006fc0:	2301      	movs	r3, #1
 8006fc2:	eba1 0a0a 	sub.w	sl, r1, sl
 8006fc6:	9310      	str	r3, [sp, #64]	; 0x40
 8006fc8:	f1ba 0301 	subs.w	r3, sl, #1
 8006fcc:	9307      	str	r3, [sp, #28]
 8006fce:	bf43      	ittte	mi
 8006fd0:	2300      	movmi	r3, #0
 8006fd2:	f1ca 0a01 	rsbmi	sl, sl, #1
 8006fd6:	9307      	strmi	r3, [sp, #28]
 8006fd8:	f04f 0a00 	movpl.w	sl, #0
 8006fdc:	f1bb 0f00 	cmp.w	fp, #0
 8006fe0:	db19      	blt.n	8007016 <_dtoa_r+0x216>
 8006fe2:	9b07      	ldr	r3, [sp, #28]
 8006fe4:	f8cd b02c 	str.w	fp, [sp, #44]	; 0x2c
 8006fe8:	445b      	add	r3, fp
 8006fea:	9307      	str	r3, [sp, #28]
 8006fec:	f04f 0800 	mov.w	r8, #0
 8006ff0:	9b08      	ldr	r3, [sp, #32]
 8006ff2:	2b09      	cmp	r3, #9
 8006ff4:	d866      	bhi.n	80070c4 <_dtoa_r+0x2c4>
 8006ff6:	2b05      	cmp	r3, #5
 8006ff8:	bfc4      	itt	gt
 8006ffa:	3b04      	subgt	r3, #4
 8006ffc:	9308      	strgt	r3, [sp, #32]
 8006ffe:	9b08      	ldr	r3, [sp, #32]
 8007000:	f1a3 0302 	sub.w	r3, r3, #2
 8007004:	bfcc      	ite	gt
 8007006:	2500      	movgt	r5, #0
 8007008:	2501      	movle	r5, #1
 800700a:	2b03      	cmp	r3, #3
 800700c:	d866      	bhi.n	80070dc <_dtoa_r+0x2dc>
 800700e:	e8df f003 	tbb	[pc, r3]
 8007012:	5755      	.short	0x5755
 8007014:	4909      	.short	0x4909
 8007016:	2300      	movs	r3, #0
 8007018:	ebaa 0a0b 	sub.w	sl, sl, fp
 800701c:	f1cb 0800 	rsb	r8, fp, #0
 8007020:	930b      	str	r3, [sp, #44]	; 0x2c
 8007022:	e7e5      	b.n	8006ff0 <_dtoa_r+0x1f0>
 8007024:	2301      	movs	r3, #1
 8007026:	9309      	str	r3, [sp, #36]	; 0x24
 8007028:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 800702a:	2b00      	cmp	r3, #0
 800702c:	dd59      	ble.n	80070e2 <_dtoa_r+0x2e2>
 800702e:	9306      	str	r3, [sp, #24]
 8007030:	4699      	mov	r9, r3
 8007032:	6a66      	ldr	r6, [r4, #36]	; 0x24
 8007034:	2200      	movs	r2, #0
 8007036:	6072      	str	r2, [r6, #4]
 8007038:	2204      	movs	r2, #4
 800703a:	f102 0014 	add.w	r0, r2, #20
 800703e:	4298      	cmp	r0, r3
 8007040:	6871      	ldr	r1, [r6, #4]
 8007042:	d953      	bls.n	80070ec <_dtoa_r+0x2ec>
 8007044:	4620      	mov	r0, r4
 8007046:	f000 ff7b 	bl	8007f40 <_Balloc>
 800704a:	6a63      	ldr	r3, [r4, #36]	; 0x24
 800704c:	6030      	str	r0, [r6, #0]
 800704e:	681b      	ldr	r3, [r3, #0]
 8007050:	9304      	str	r3, [sp, #16]
 8007052:	f1b9 0f0e 	cmp.w	r9, #14
 8007056:	f200 80c2 	bhi.w	80071de <_dtoa_r+0x3de>
 800705a:	2d00      	cmp	r5, #0
 800705c:	f000 80bf 	beq.w	80071de <_dtoa_r+0x3de>
 8007060:	ed9d 7b02 	vldr	d7, [sp, #8]
 8007064:	f1bb 0f00 	cmp.w	fp, #0
 8007068:	ed8d 7b0e 	vstr	d7, [sp, #56]	; 0x38
 800706c:	f340 80e6 	ble.w	800723c <_dtoa_r+0x43c>
 8007070:	4a2b      	ldr	r2, [pc, #172]	; (8007120 <_dtoa_r+0x320>)
 8007072:	f00b 030f 	and.w	r3, fp, #15
 8007076:	eb02 03c3 	add.w	r3, r2, r3, lsl #3
 800707a:	ed93 7b00 	vldr	d7, [r3]
 800707e:	ea4f 132b 	mov.w	r3, fp, asr #4
 8007082:	06da      	lsls	r2, r3, #27
 8007084:	f140 80d8 	bpl.w	8007238 <_dtoa_r+0x438>
 8007088:	4a26      	ldr	r2, [pc, #152]	; (8007124 <_dtoa_r+0x324>)
 800708a:	ed9d 5b0e 	vldr	d5, [sp, #56]	; 0x38
 800708e:	ed92 6b08 	vldr	d6, [r2, #32]
 8007092:	ee85 6b06 	vdiv.f64	d6, d5, d6
 8007096:	ed8d 6b02 	vstr	d6, [sp, #8]
 800709a:	f003 030f 	and.w	r3, r3, #15
 800709e:	2203      	movs	r2, #3
 80070a0:	4920      	ldr	r1, [pc, #128]	; (8007124 <_dtoa_r+0x324>)
 80070a2:	e04a      	b.n	800713a <_dtoa_r+0x33a>
 80070a4:	2301      	movs	r3, #1
 80070a6:	9309      	str	r3, [sp, #36]	; 0x24
 80070a8:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 80070aa:	445b      	add	r3, fp
 80070ac:	f103 0901 	add.w	r9, r3, #1
 80070b0:	9306      	str	r3, [sp, #24]
 80070b2:	464b      	mov	r3, r9
 80070b4:	2b01      	cmp	r3, #1
 80070b6:	bfb8      	it	lt
 80070b8:	2301      	movlt	r3, #1
 80070ba:	e7ba      	b.n	8007032 <_dtoa_r+0x232>
 80070bc:	2300      	movs	r3, #0
 80070be:	e7b2      	b.n	8007026 <_dtoa_r+0x226>
 80070c0:	2300      	movs	r3, #0
 80070c2:	e7f0      	b.n	80070a6 <_dtoa_r+0x2a6>
 80070c4:	2501      	movs	r5, #1
 80070c6:	2300      	movs	r3, #0
 80070c8:	e9cd 3508 	strd	r3, r5, [sp, #32]
 80070cc:	f04f 33ff 	mov.w	r3, #4294967295	; 0xffffffff
 80070d0:	9306      	str	r3, [sp, #24]
 80070d2:	4699      	mov	r9, r3
 80070d4:	2200      	movs	r2, #0
 80070d6:	2312      	movs	r3, #18
 80070d8:	920a      	str	r2, [sp, #40]	; 0x28
 80070da:	e7aa      	b.n	8007032 <_dtoa_r+0x232>
 80070dc:	2301      	movs	r3, #1
 80070de:	9309      	str	r3, [sp, #36]	; 0x24
 80070e0:	e7f4      	b.n	80070cc <_dtoa_r+0x2cc>
 80070e2:	2301      	movs	r3, #1
 80070e4:	9306      	str	r3, [sp, #24]
 80070e6:	4699      	mov	r9, r3
 80070e8:	461a      	mov	r2, r3
 80070ea:	e7f5      	b.n	80070d8 <_dtoa_r+0x2d8>
 80070ec:	3101      	adds	r1, #1
 80070ee:	6071      	str	r1, [r6, #4]
 80070f0:	0052      	lsls	r2, r2, #1
 80070f2:	e7a2      	b.n	800703a <_dtoa_r+0x23a>
 80070f4:	f3af 8000 	nop.w
 80070f8:	636f4361 	.word	0x636f4361
 80070fc:	3fd287a7 	.word	0x3fd287a7
 8007100:	8b60c8b3 	.word	0x8b60c8b3
 8007104:	3fc68a28 	.word	0x3fc68a28
 8007108:	509f79fb 	.word	0x509f79fb
 800710c:	3fd34413 	.word	0x3fd34413
 8007110:	7ff00000 	.word	0x7ff00000
 8007114:	0802e751 	.word	0x0802e751
 8007118:	0802e748 	.word	0x0802e748
 800711c:	0802e6cd 	.word	0x0802e6cd
 8007120:	0802e788 	.word	0x0802e788
 8007124:	0802e760 	.word	0x0802e760
 8007128:	07de      	lsls	r6, r3, #31
 800712a:	d504      	bpl.n	8007136 <_dtoa_r+0x336>
 800712c:	ed91 6b00 	vldr	d6, [r1]
 8007130:	3201      	adds	r2, #1
 8007132:	ee27 7b06 	vmul.f64	d7, d7, d6
 8007136:	105b      	asrs	r3, r3, #1
 8007138:	3108      	adds	r1, #8
 800713a:	2b00      	cmp	r3, #0
 800713c:	d1f4      	bne.n	8007128 <_dtoa_r+0x328>
 800713e:	ed9d 6b02 	vldr	d6, [sp, #8]
 8007142:	ee86 7b07 	vdiv.f64	d7, d6, d7
 8007146:	ed8d 7b02 	vstr	d7, [sp, #8]
 800714a:	9b10      	ldr	r3, [sp, #64]	; 0x40
 800714c:	2b00      	cmp	r3, #0
 800714e:	f000 80a7 	beq.w	80072a0 <_dtoa_r+0x4a0>
 8007152:	eeb7 6b00 	vmov.f64	d6, #112	; 0x3f800000  1.0
 8007156:	ed9d 7b02 	vldr	d7, [sp, #8]
 800715a:	eeb4 7bc6 	vcmpe.f64	d7, d6
 800715e:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 8007162:	f140 809d 	bpl.w	80072a0 <_dtoa_r+0x4a0>
 8007166:	f1b9 0f00 	cmp.w	r9, #0
 800716a:	f000 8099 	beq.w	80072a0 <_dtoa_r+0x4a0>
 800716e:	9b06      	ldr	r3, [sp, #24]
 8007170:	2b00      	cmp	r3, #0
 8007172:	dd30      	ble.n	80071d6 <_dtoa_r+0x3d6>
 8007174:	eeb2 6b04 	vmov.f64	d6, #36	; 0x41200000  10.0
 8007178:	ee27 7b06 	vmul.f64	d7, d7, d6
 800717c:	ed8d 7b02 	vstr	d7, [sp, #8]
 8007180:	9d06      	ldr	r5, [sp, #24]
 8007182:	f10b 33ff 	add.w	r3, fp, #4294967295	; 0xffffffff
 8007186:	3201      	adds	r2, #1
 8007188:	ed9d 6b02 	vldr	d6, [sp, #8]
 800718c:	eeb1 5b0c 	vmov.f64	d5, #28	; 0x40e00000  7.0
 8007190:	ee07 2a90 	vmov	s15, r2
 8007194:	eeb8 7be7 	vcvt.f64.s32	d7, s15
 8007198:	eea7 5b06 	vfma.f64	d5, d7, d6
 800719c:	ed8d 5b02 	vstr	d5, [sp, #8]
 80071a0:	9a03      	ldr	r2, [sp, #12]
 80071a2:	e9dd 0102 	ldrd	r0, r1, [sp, #8]
 80071a6:	f1a2 7150 	sub.w	r1, r2, #54525952	; 0x3400000
 80071aa:	2d00      	cmp	r5, #0
 80071ac:	d17b      	bne.n	80072a6 <_dtoa_r+0x4a6>
 80071ae:	eeb1 7b04 	vmov.f64	d7, #20	; 0x40a00000  5.0
 80071b2:	ee36 6b47 	vsub.f64	d6, d6, d7
 80071b6:	ec41 0b17 	vmov	d7, r0, r1
 80071ba:	eeb4 6bc7 	vcmpe.f64	d6, d7
 80071be:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 80071c2:	f300 8253 	bgt.w	800766c <_dtoa_r+0x86c>
 80071c6:	eeb1 7b47 	vneg.f64	d7, d7
 80071ca:	eeb4 6bc7 	vcmpe.f64	d6, d7
 80071ce:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 80071d2:	f100 8249 	bmi.w	8007668 <_dtoa_r+0x868>
 80071d6:	e9dd 230e 	ldrd	r2, r3, [sp, #56]	; 0x38
 80071da:	e9cd 2302 	strd	r2, r3, [sp, #8]
 80071de:	9b13      	ldr	r3, [sp, #76]	; 0x4c
 80071e0:	2b00      	cmp	r3, #0
 80071e2:	f2c0 8119 	blt.w	8007418 <_dtoa_r+0x618>
 80071e6:	f1bb 0f0e 	cmp.w	fp, #14
 80071ea:	f300 8115 	bgt.w	8007418 <_dtoa_r+0x618>
 80071ee:	4bc3      	ldr	r3, [pc, #780]	; (80074fc <_dtoa_r+0x6fc>)
 80071f0:	eb03 03cb 	add.w	r3, r3, fp, lsl #3
 80071f4:	ed93 6b00 	vldr	d6, [r3]
 80071f8:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 80071fa:	2b00      	cmp	r3, #0
 80071fc:	f280 80ba 	bge.w	8007374 <_dtoa_r+0x574>
 8007200:	f1b9 0f00 	cmp.w	r9, #0
 8007204:	f300 80b6 	bgt.w	8007374 <_dtoa_r+0x574>
 8007208:	f040 822d 	bne.w	8007666 <_dtoa_r+0x866>
 800720c:	eeb1 7b04 	vmov.f64	d7, #20	; 0x40a00000  5.0
 8007210:	ee26 6b07 	vmul.f64	d6, d6, d7
 8007214:	ed9d 7b02 	vldr	d7, [sp, #8]
 8007218:	eeb4 6bc7 	vcmpe.f64	d6, d7
 800721c:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 8007220:	464d      	mov	r5, r9
 8007222:	464f      	mov	r7, r9
 8007224:	f280 8204 	bge.w	8007630 <_dtoa_r+0x830>
 8007228:	9b04      	ldr	r3, [sp, #16]
 800722a:	9a04      	ldr	r2, [sp, #16]
 800722c:	1c5e      	adds	r6, r3, #1
 800722e:	2331      	movs	r3, #49	; 0x31
 8007230:	7013      	strb	r3, [r2, #0]
 8007232:	f10b 0b01 	add.w	fp, fp, #1
 8007236:	e1ff      	b.n	8007638 <_dtoa_r+0x838>
 8007238:	2202      	movs	r2, #2
 800723a:	e731      	b.n	80070a0 <_dtoa_r+0x2a0>
 800723c:	d02e      	beq.n	800729c <_dtoa_r+0x49c>
 800723e:	f1cb 0300 	rsb	r3, fp, #0
 8007242:	4aae      	ldr	r2, [pc, #696]	; (80074fc <_dtoa_r+0x6fc>)
 8007244:	f003 010f 	and.w	r1, r3, #15
 8007248:	eb02 02c1 	add.w	r2, r2, r1, lsl #3
 800724c:	ed92 7b00 	vldr	d7, [r2]
 8007250:	ed9d 6b0e 	vldr	d6, [sp, #56]	; 0x38
 8007254:	ee26 7b07 	vmul.f64	d7, d6, d7
 8007258:	ed8d 7b0c 	vstr	d7, [sp, #48]	; 0x30
 800725c:	e9dd 120c 	ldrd	r1, r2, [sp, #48]	; 0x30
 8007260:	e9cd 1202 	strd	r1, r2, [sp, #8]
 8007264:	49a6      	ldr	r1, [pc, #664]	; (8007500 <_dtoa_r+0x700>)
 8007266:	111b      	asrs	r3, r3, #4
 8007268:	2000      	movs	r0, #0
 800726a:	2202      	movs	r2, #2
 800726c:	b93b      	cbnz	r3, 800727e <_dtoa_r+0x47e>
 800726e:	2800      	cmp	r0, #0
 8007270:	f43f af6b 	beq.w	800714a <_dtoa_r+0x34a>
 8007274:	e9dd 010c 	ldrd	r0, r1, [sp, #48]	; 0x30
 8007278:	e9cd 0102 	strd	r0, r1, [sp, #8]
 800727c:	e765      	b.n	800714a <_dtoa_r+0x34a>
 800727e:	07dd      	lsls	r5, r3, #31
 8007280:	d509      	bpl.n	8007296 <_dtoa_r+0x496>
 8007282:	ed9d 6b0c 	vldr	d6, [sp, #48]	; 0x30
 8007286:	ed91 7b00 	vldr	d7, [r1]
 800728a:	ee26 7b07 	vmul.f64	d7, d6, d7
 800728e:	ed8d 7b0c 	vstr	d7, [sp, #48]	; 0x30
 8007292:	3201      	adds	r2, #1
 8007294:	2001      	movs	r0, #1
 8007296:	105b      	asrs	r3, r3, #1
 8007298:	3108      	adds	r1, #8
 800729a:	e7e7      	b.n	800726c <_dtoa_r+0x46c>
 800729c:	2202      	movs	r2, #2
 800729e:	e754      	b.n	800714a <_dtoa_r+0x34a>
 80072a0:	465b      	mov	r3, fp
 80072a2:	464d      	mov	r5, r9
 80072a4:	e770      	b.n	8007188 <_dtoa_r+0x388>
 80072a6:	4a95      	ldr	r2, [pc, #596]	; (80074fc <_dtoa_r+0x6fc>)
 80072a8:	eb02 02c5 	add.w	r2, r2, r5, lsl #3
 80072ac:	ed12 4b02 	vldr	d4, [r2, #-8]
 80072b0:	9a09      	ldr	r2, [sp, #36]	; 0x24
 80072b2:	ec41 0b17 	vmov	d7, r0, r1
 80072b6:	b35a      	cbz	r2, 8007310 <_dtoa_r+0x510>
 80072b8:	eeb6 3b00 	vmov.f64	d3, #96	; 0x3f000000  0.5
 80072bc:	eeb7 2b00 	vmov.f64	d2, #112	; 0x3f800000  1.0
 80072c0:	9e04      	ldr	r6, [sp, #16]
 80072c2:	ee83 5b04 	vdiv.f64	d5, d3, d4
 80072c6:	eeb2 3b04 	vmov.f64	d3, #36	; 0x41200000  10.0
 80072ca:	ee35 7b47 	vsub.f64	d7, d5, d7
 80072ce:	eefd 4bc6 	vcvt.s32.f64	s9, d6
 80072d2:	ee14 2a90 	vmov	r2, s9
 80072d6:	eeb8 5be4 	vcvt.f64.s32	d5, s9
 80072da:	3230      	adds	r2, #48	; 0x30
 80072dc:	ee36 6b45 	vsub.f64	d6, d6, d5
 80072e0:	eeb4 6bc7 	vcmpe.f64	d6, d7
 80072e4:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 80072e8:	f806 2b01 	strb.w	r2, [r6], #1
 80072ec:	d43b      	bmi.n	8007366 <_dtoa_r+0x566>
 80072ee:	ee32 5b46 	vsub.f64	d5, d2, d6
 80072f2:	eeb4 5bc7 	vcmpe.f64	d5, d7
 80072f6:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 80072fa:	d472      	bmi.n	80073e2 <_dtoa_r+0x5e2>
 80072fc:	9a04      	ldr	r2, [sp, #16]
 80072fe:	1ab2      	subs	r2, r6, r2
 8007300:	4295      	cmp	r5, r2
 8007302:	f77f af68 	ble.w	80071d6 <_dtoa_r+0x3d6>
 8007306:	ee27 7b03 	vmul.f64	d7, d7, d3
 800730a:	ee26 6b03 	vmul.f64	d6, d6, d3
 800730e:	e7de      	b.n	80072ce <_dtoa_r+0x4ce>
 8007310:	9a04      	ldr	r2, [sp, #16]
 8007312:	ee24 7b07 	vmul.f64	d7, d4, d7
 8007316:	1956      	adds	r6, r2, r5
 8007318:	4611      	mov	r1, r2
 800731a:	eeb2 3b04 	vmov.f64	d3, #36	; 0x41200000  10.0
 800731e:	eefd 4bc6 	vcvt.s32.f64	s9, d6
 8007322:	ee14 2a90 	vmov	r2, s9
 8007326:	3230      	adds	r2, #48	; 0x30
 8007328:	f801 2b01 	strb.w	r2, [r1], #1
 800732c:	42b1      	cmp	r1, r6
 800732e:	eeb8 5be4 	vcvt.f64.s32	d5, s9
 8007332:	ee36 6b45 	vsub.f64	d6, d6, d5
 8007336:	d11a      	bne.n	800736e <_dtoa_r+0x56e>
 8007338:	eeb6 5b00 	vmov.f64	d5, #96	; 0x3f000000  0.5
 800733c:	ee37 4b05 	vadd.f64	d4, d7, d5
 8007340:	eeb4 6bc4 	vcmpe.f64	d6, d4
 8007344:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 8007348:	dc4b      	bgt.n	80073e2 <_dtoa_r+0x5e2>
 800734a:	ee35 7b47 	vsub.f64	d7, d5, d7
 800734e:	eeb4 6bc7 	vcmpe.f64	d6, d7
 8007352:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 8007356:	f57f af3e 	bpl.w	80071d6 <_dtoa_r+0x3d6>
 800735a:	f816 2c01 	ldrb.w	r2, [r6, #-1]
 800735e:	2a30      	cmp	r2, #48	; 0x30
 8007360:	f106 31ff 	add.w	r1, r6, #4294967295	; 0xffffffff
 8007364:	d001      	beq.n	800736a <_dtoa_r+0x56a>
 8007366:	469b      	mov	fp, r3
 8007368:	e02a      	b.n	80073c0 <_dtoa_r+0x5c0>
 800736a:	460e      	mov	r6, r1
 800736c:	e7f5      	b.n	800735a <_dtoa_r+0x55a>
 800736e:	ee26 6b03 	vmul.f64	d6, d6, d3
 8007372:	e7d4      	b.n	800731e <_dtoa_r+0x51e>
 8007374:	ed9d 7b02 	vldr	d7, [sp, #8]
 8007378:	eeb2 4b04 	vmov.f64	d4, #36	; 0x41200000  10.0
 800737c:	9e04      	ldr	r6, [sp, #16]
 800737e:	ee87 5b06 	vdiv.f64	d5, d7, d6
 8007382:	eebd 5bc5 	vcvt.s32.f64	s10, d5
 8007386:	ee15 3a10 	vmov	r3, s10
 800738a:	3330      	adds	r3, #48	; 0x30
 800738c:	f806 3b01 	strb.w	r3, [r6], #1
 8007390:	9b04      	ldr	r3, [sp, #16]
 8007392:	1af3      	subs	r3, r6, r3
 8007394:	4599      	cmp	r9, r3
 8007396:	eeb8 3bc5 	vcvt.f64.s32	d3, s10
 800739a:	eea3 7b46 	vfms.f64	d7, d3, d6
 800739e:	d133      	bne.n	8007408 <_dtoa_r+0x608>
 80073a0:	ee37 7b07 	vadd.f64	d7, d7, d7
 80073a4:	eeb4 7bc6 	vcmpe.f64	d7, d6
 80073a8:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 80073ac:	dc18      	bgt.n	80073e0 <_dtoa_r+0x5e0>
 80073ae:	eeb4 7b46 	vcmp.f64	d7, d6
 80073b2:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 80073b6:	d103      	bne.n	80073c0 <_dtoa_r+0x5c0>
 80073b8:	ee15 3a10 	vmov	r3, s10
 80073bc:	07db      	lsls	r3, r3, #31
 80073be:	d40f      	bmi.n	80073e0 <_dtoa_r+0x5e0>
 80073c0:	9901      	ldr	r1, [sp, #4]
 80073c2:	4620      	mov	r0, r4
 80073c4:	f000 fdf0 	bl	8007fa8 <_Bfree>
 80073c8:	2300      	movs	r3, #0
 80073ca:	9a11      	ldr	r2, [sp, #68]	; 0x44
 80073cc:	7033      	strb	r3, [r6, #0]
 80073ce:	f10b 0301 	add.w	r3, fp, #1
 80073d2:	6013      	str	r3, [r2, #0]
 80073d4:	9b1f      	ldr	r3, [sp, #124]	; 0x7c
 80073d6:	2b00      	cmp	r3, #0
 80073d8:	f43f ad5b 	beq.w	8006e92 <_dtoa_r+0x92>
 80073dc:	601e      	str	r6, [r3, #0]
 80073de:	e558      	b.n	8006e92 <_dtoa_r+0x92>
 80073e0:	465b      	mov	r3, fp
 80073e2:	f816 1c01 	ldrb.w	r1, [r6, #-1]
 80073e6:	2939      	cmp	r1, #57	; 0x39
 80073e8:	f106 32ff 	add.w	r2, r6, #4294967295	; 0xffffffff
 80073ec:	d106      	bne.n	80073fc <_dtoa_r+0x5fc>
 80073ee:	9904      	ldr	r1, [sp, #16]
 80073f0:	4291      	cmp	r1, r2
 80073f2:	d107      	bne.n	8007404 <_dtoa_r+0x604>
 80073f4:	2230      	movs	r2, #48	; 0x30
 80073f6:	700a      	strb	r2, [r1, #0]
 80073f8:	3301      	adds	r3, #1
 80073fa:	460a      	mov	r2, r1
 80073fc:	7811      	ldrb	r1, [r2, #0]
 80073fe:	3101      	adds	r1, #1
 8007400:	7011      	strb	r1, [r2, #0]
 8007402:	e7b0      	b.n	8007366 <_dtoa_r+0x566>
 8007404:	4616      	mov	r6, r2
 8007406:	e7ec      	b.n	80073e2 <_dtoa_r+0x5e2>
 8007408:	ee27 7b04 	vmul.f64	d7, d7, d4
 800740c:	eeb5 7b40 	vcmp.f64	d7, #0.0
 8007410:	eef1 fa10 	vmrs	APSR_nzcv, fpscr
 8007414:	d1b3      	bne.n	800737e <_dtoa_r+0x57e>
 8007416:	e7d3      	b.n	80073c0 <_dtoa_r+0x5c0>
 8007418:	9a09      	ldr	r2, [sp, #36]	; 0x24
 800741a:	2a00      	cmp	r2, #0
 800741c:	f000 808d 	beq.w	800753a <_dtoa_r+0x73a>
 8007420:	9a08      	ldr	r2, [sp, #32]
 8007422:	2a01      	cmp	r2, #1
 8007424:	dc72      	bgt.n	800750c <_dtoa_r+0x70c>
 8007426:	2f00      	cmp	r7, #0
 8007428:	d06c      	beq.n	8007504 <_dtoa_r+0x704>
 800742a:	f203 4333 	addw	r3, r3, #1075	; 0x433
 800742e:	4645      	mov	r5, r8
 8007430:	4656      	mov	r6, sl
 8007432:	9a07      	ldr	r2, [sp, #28]
 8007434:	2101      	movs	r1, #1
 8007436:	441a      	add	r2, r3
 8007438:	4620      	mov	r0, r4
 800743a:	449a      	add	sl, r3
 800743c:	9207      	str	r2, [sp, #28]
 800743e:	f000 fe91 	bl	8008164 <__i2b>
 8007442:	4607      	mov	r7, r0
 8007444:	2e00      	cmp	r6, #0
 8007446:	dd0b      	ble.n	8007460 <_dtoa_r+0x660>
 8007448:	9b07      	ldr	r3, [sp, #28]
 800744a:	2b00      	cmp	r3, #0
 800744c:	dd08      	ble.n	8007460 <_dtoa_r+0x660>
 800744e:	42b3      	cmp	r3, r6
 8007450:	9a07      	ldr	r2, [sp, #28]
 8007452:	bfa8      	it	ge
 8007454:	4633      	movge	r3, r6
 8007456:	ebaa 0a03 	sub.w	sl, sl, r3
 800745a:	1af6      	subs	r6, r6, r3
 800745c:	1ad3      	subs	r3, r2, r3
 800745e:	9307      	str	r3, [sp, #28]
 8007460:	f1b8 0f00 	cmp.w	r8, #0
 8007464:	d01d      	beq.n	80074a2 <_dtoa_r+0x6a2>
 8007466:	9b09      	ldr	r3, [sp, #36]	; 0x24
 8007468:	2b00      	cmp	r3, #0
 800746a:	d06a      	beq.n	8007542 <_dtoa_r+0x742>
 800746c:	b18d      	cbz	r5, 8007492 <_dtoa_r+0x692>
 800746e:	4639      	mov	r1, r7
 8007470:	462a      	mov	r2, r5
 8007472:	4620      	mov	r0, r4
 8007474:	f000 ff16 	bl	80082a4 <__pow5mult>
 8007478:	9a01      	ldr	r2, [sp, #4]
 800747a:	4601      	mov	r1, r0
 800747c:	4607      	mov	r7, r0
 800747e:	4620      	mov	r0, r4
 8007480:	f000 fe79 	bl	8008176 <__multiply>
 8007484:	9901      	ldr	r1, [sp, #4]
 8007486:	900c      	str	r0, [sp, #48]	; 0x30
 8007488:	4620      	mov	r0, r4
 800748a:	f000 fd8d 	bl	8007fa8 <_Bfree>
 800748e:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 8007490:	9301      	str	r3, [sp, #4]
 8007492:	ebb8 0205 	subs.w	r2, r8, r5
 8007496:	d004      	beq.n	80074a2 <_dtoa_r+0x6a2>
 8007498:	9901      	ldr	r1, [sp, #4]
 800749a:	4620      	mov	r0, r4
 800749c:	f000 ff02 	bl	80082a4 <__pow5mult>
 80074a0:	9001      	str	r0, [sp, #4]
 80074a2:	2101      	movs	r1, #1
 80074a4:	4620      	mov	r0, r4
 80074a6:	f000 fe5d 	bl	8008164 <__i2b>
 80074aa:	9b0b      	ldr	r3, [sp, #44]	; 0x2c
 80074ac:	4605      	mov	r5, r0
 80074ae:	2b00      	cmp	r3, #0
 80074b0:	f000 81ca 	beq.w	8007848 <_dtoa_r+0xa48>
 80074b4:	461a      	mov	r2, r3
 80074b6:	4601      	mov	r1, r0
 80074b8:	4620      	mov	r0, r4
 80074ba:	f000 fef3 	bl	80082a4 <__pow5mult>
 80074be:	9b08      	ldr	r3, [sp, #32]
 80074c0:	2b01      	cmp	r3, #1
 80074c2:	4605      	mov	r5, r0
 80074c4:	dc44      	bgt.n	8007550 <_dtoa_r+0x750>
 80074c6:	9b02      	ldr	r3, [sp, #8]
 80074c8:	2b00      	cmp	r3, #0
 80074ca:	d13c      	bne.n	8007546 <_dtoa_r+0x746>
 80074cc:	9b03      	ldr	r3, [sp, #12]
 80074ce:	f3c3 0313 	ubfx	r3, r3, #0, #20
 80074d2:	2b00      	cmp	r3, #0
 80074d4:	d137      	bne.n	8007546 <_dtoa_r+0x746>
 80074d6:	9b03      	ldr	r3, [sp, #12]
 80074d8:	f023 4300 	bic.w	r3, r3, #2147483648	; 0x80000000
 80074dc:	0d1b      	lsrs	r3, r3, #20
 80074de:	051b      	lsls	r3, r3, #20
 80074e0:	2b00      	cmp	r3, #0
 80074e2:	d033      	beq.n	800754c <_dtoa_r+0x74c>
 80074e4:	9b07      	ldr	r3, [sp, #28]
 80074e6:	3301      	adds	r3, #1
 80074e8:	f10a 0a01 	add.w	sl, sl, #1
 80074ec:	9307      	str	r3, [sp, #28]
 80074ee:	f04f 0801 	mov.w	r8, #1
 80074f2:	9b0b      	ldr	r3, [sp, #44]	; 0x2c
 80074f4:	bb73      	cbnz	r3, 8007554 <_dtoa_r+0x754>
 80074f6:	2001      	movs	r0, #1
 80074f8:	e034      	b.n	8007564 <_dtoa_r+0x764>
 80074fa:	bf00      	nop
 80074fc:	0802e788 	.word	0x0802e788
 8007500:	0802e760 	.word	0x0802e760
 8007504:	9b12      	ldr	r3, [sp, #72]	; 0x48
 8007506:	f1c3 0336 	rsb	r3, r3, #54	; 0x36
 800750a:	e790      	b.n	800742e <_dtoa_r+0x62e>
 800750c:	f109 35ff 	add.w	r5, r9, #4294967295	; 0xffffffff
 8007510:	45a8      	cmp	r8, r5
 8007512:	bfbf      	itttt	lt
 8007514:	9b0b      	ldrlt	r3, [sp, #44]	; 0x2c
 8007516:	eba5 0808 	sublt.w	r8, r5, r8
 800751a:	4443      	addlt	r3, r8
 800751c:	930b      	strlt	r3, [sp, #44]	; 0x2c
 800751e:	bfb6      	itet	lt
 8007520:	46a8      	movlt	r8, r5
 8007522:	eba8 0505 	subge.w	r5, r8, r5
 8007526:	2500      	movlt	r5, #0
 8007528:	f1b9 0f00 	cmp.w	r9, #0
 800752c:	bfb9      	ittee	lt
 800752e:	ebaa 0609 	sublt.w	r6, sl, r9
 8007532:	2300      	movlt	r3, #0
 8007534:	4656      	movge	r6, sl
 8007536:	464b      	movge	r3, r9
 8007538:	e77b      	b.n	8007432 <_dtoa_r+0x632>
 800753a:	4645      	mov	r5, r8
 800753c:	4656      	mov	r6, sl
 800753e:	9f09      	ldr	r7, [sp, #36]	; 0x24
 8007540:	e780      	b.n	8007444 <_dtoa_r+0x644>
 8007542:	4642      	mov	r2, r8
 8007544:	e7a8      	b.n	8007498 <_dtoa_r+0x698>
 8007546:	f04f 0800 	mov.w	r8, #0
 800754a:	e7d2      	b.n	80074f2 <_dtoa_r+0x6f2>
 800754c:	4698      	mov	r8, r3
 800754e:	e7d0      	b.n	80074f2 <_dtoa_r+0x6f2>
 8007550:	f04f 0800 	mov.w	r8, #0
 8007554:	692b      	ldr	r3, [r5, #16]
 8007556:	eb05 0383 	add.w	r3, r5, r3, lsl #2
 800755a:	6918      	ldr	r0, [r3, #16]
 800755c:	f000 fdb4 	bl	80080c8 <__hi0bits>
 8007560:	f1c0 0020 	rsb	r0, r0, #32
 8007564:	9b07      	ldr	r3, [sp, #28]
 8007566:	4418      	add	r0, r3
 8007568:	f010 001f 	ands.w	r0, r0, #31
 800756c:	d047      	beq.n	80075fe <_dtoa_r+0x7fe>
 800756e:	f1c0 0320 	rsb	r3, r0, #32
 8007572:	2b04      	cmp	r3, #4
 8007574:	dd3b      	ble.n	80075ee <_dtoa_r+0x7ee>
 8007576:	9b07      	ldr	r3, [sp, #28]
 8007578:	f1c0 001c 	rsb	r0, r0, #28
 800757c:	4482      	add	sl, r0
 800757e:	4406      	add	r6, r0
 8007580:	4403      	add	r3, r0
 8007582:	9307      	str	r3, [sp, #28]
 8007584:	f1ba 0f00 	cmp.w	sl, #0
 8007588:	dd05      	ble.n	8007596 <_dtoa_r+0x796>
 800758a:	4652      	mov	r2, sl
 800758c:	9901      	ldr	r1, [sp, #4]
 800758e:	4620      	mov	r0, r4
 8007590:	f000 fed6 	bl	8008340 <__lshift>
 8007594:	9001      	str	r0, [sp, #4]
 8007596:	9b07      	ldr	r3, [sp, #28]
 8007598:	2b00      	cmp	r3, #0
 800759a:	dd05      	ble.n	80075a8 <_dtoa_r+0x7a8>
 800759c:	4629      	mov	r1, r5
 800759e:	461a      	mov	r2, r3
 80075a0:	4620      	mov	r0, r4
 80075a2:	f000 fecd 	bl	8008340 <__lshift>
 80075a6:	4605      	mov	r5, r0
 80075a8:	9b10      	ldr	r3, [sp, #64]	; 0x40
 80075aa:	b353      	cbz	r3, 8007602 <_dtoa_r+0x802>
 80075ac:	4629      	mov	r1, r5
 80075ae:	9801      	ldr	r0, [sp, #4]
 80075b0:	f000 ff1a 	bl	80083e8 <__mcmp>
 80075b4:	2800      	cmp	r0, #0
 80075b6:	da24      	bge.n	8007602 <_dtoa_r+0x802>
 80075b8:	2300      	movs	r3, #0
 80075ba:	220a      	movs	r2, #10
 80075bc:	9901      	ldr	r1, [sp, #4]
 80075be:	4620      	mov	r0, r4
 80075c0:	f000 fd09 	bl	8007fd6 <__multadd>
 80075c4:	9b09      	ldr	r3, [sp, #36]	; 0x24
 80075c6:	9001      	str	r0, [sp, #4]
 80075c8:	f10b 3bff 	add.w	fp, fp, #4294967295	; 0xffffffff
 80075cc:	2b00      	cmp	r3, #0
 80075ce:	f000 8142 	beq.w	8007856 <_dtoa_r+0xa56>
 80075d2:	2300      	movs	r3, #0
 80075d4:	4639      	mov	r1, r7
 80075d6:	220a      	movs	r2, #10
 80075d8:	4620      	mov	r0, r4
 80075da:	f000 fcfc 	bl	8007fd6 <__multadd>
 80075de:	9b06      	ldr	r3, [sp, #24]
 80075e0:	2b00      	cmp	r3, #0
 80075e2:	4607      	mov	r7, r0
 80075e4:	dc4b      	bgt.n	800767e <_dtoa_r+0x87e>
 80075e6:	9b08      	ldr	r3, [sp, #32]
 80075e8:	2b02      	cmp	r3, #2
 80075ea:	dd48      	ble.n	800767e <_dtoa_r+0x87e>
 80075ec:	e011      	b.n	8007612 <_dtoa_r+0x812>
 80075ee:	d0c9      	beq.n	8007584 <_dtoa_r+0x784>
 80075f0:	9a07      	ldr	r2, [sp, #28]
 80075f2:	331c      	adds	r3, #28
 80075f4:	441a      	add	r2, r3
 80075f6:	449a      	add	sl, r3
 80075f8:	441e      	add	r6, r3
 80075fa:	4613      	mov	r3, r2
 80075fc:	e7c1      	b.n	8007582 <_dtoa_r+0x782>
 80075fe:	4603      	mov	r3, r0
 8007600:	e7f6      	b.n	80075f0 <_dtoa_r+0x7f0>
 8007602:	f1b9 0f00 	cmp.w	r9, #0
 8007606:	dc34      	bgt.n	8007672 <_dtoa_r+0x872>
 8007608:	9b08      	ldr	r3, [sp, #32]
 800760a:	2b02      	cmp	r3, #2
 800760c:	dd31      	ble.n	8007672 <_dtoa_r+0x872>
 800760e:	f8cd 9018 	str.w	r9, [sp, #24]
 8007612:	9b06      	ldr	r3, [sp, #24]
 8007614:	b963      	cbnz	r3, 8007630 <_dtoa_r+0x830>
 8007616:	4629      	mov	r1, r5
 8007618:	2205      	movs	r2, #5
 800761a:	4620      	mov	r0, r4
 800761c:	f000 fcdb 	bl	8007fd6 <__multadd>
 8007620:	4601      	mov	r1, r0
 8007622:	4605      	mov	r5, r0
 8007624:	9801      	ldr	r0, [sp, #4]
 8007626:	f000 fedf 	bl	80083e8 <__mcmp>
 800762a:	2800      	cmp	r0, #0
 800762c:	f73f adfc 	bgt.w	8007228 <_dtoa_r+0x428>
 8007630:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 8007632:	9e04      	ldr	r6, [sp, #16]
 8007634:	ea6f 0b03 	mvn.w	fp, r3
 8007638:	f04f 0900 	mov.w	r9, #0
 800763c:	4629      	mov	r1, r5
 800763e:	4620      	mov	r0, r4
 8007640:	f000 fcb2 	bl	8007fa8 <_Bfree>
 8007644:	2f00      	cmp	r7, #0
 8007646:	f43f aebb 	beq.w	80073c0 <_dtoa_r+0x5c0>
 800764a:	f1b9 0f00 	cmp.w	r9, #0
 800764e:	d005      	beq.n	800765c <_dtoa_r+0x85c>
 8007650:	45b9      	cmp	r9, r7
 8007652:	d003      	beq.n	800765c <_dtoa_r+0x85c>
 8007654:	4649      	mov	r1, r9
 8007656:	4620      	mov	r0, r4
 8007658:	f000 fca6 	bl	8007fa8 <_Bfree>
 800765c:	4639      	mov	r1, r7
 800765e:	4620      	mov	r0, r4
 8007660:	f000 fca2 	bl	8007fa8 <_Bfree>
 8007664:	e6ac      	b.n	80073c0 <_dtoa_r+0x5c0>
 8007666:	2500      	movs	r5, #0
 8007668:	462f      	mov	r7, r5
 800766a:	e7e1      	b.n	8007630 <_dtoa_r+0x830>
 800766c:	469b      	mov	fp, r3
 800766e:	462f      	mov	r7, r5
 8007670:	e5da      	b.n	8007228 <_dtoa_r+0x428>
 8007672:	9b09      	ldr	r3, [sp, #36]	; 0x24
 8007674:	f8cd 9018 	str.w	r9, [sp, #24]
 8007678:	2b00      	cmp	r3, #0
 800767a:	f000 80f3 	beq.w	8007864 <_dtoa_r+0xa64>
 800767e:	2e00      	cmp	r6, #0
 8007680:	dd05      	ble.n	800768e <_dtoa_r+0x88e>
 8007682:	4639      	mov	r1, r7
 8007684:	4632      	mov	r2, r6
 8007686:	4620      	mov	r0, r4
 8007688:	f000 fe5a 	bl	8008340 <__lshift>
 800768c:	4607      	mov	r7, r0
 800768e:	f1b8 0f00 	cmp.w	r8, #0
 8007692:	d04c      	beq.n	800772e <_dtoa_r+0x92e>
 8007694:	6879      	ldr	r1, [r7, #4]
 8007696:	4620      	mov	r0, r4
 8007698:	f000 fc52 	bl	8007f40 <_Balloc>
 800769c:	693a      	ldr	r2, [r7, #16]
 800769e:	3202      	adds	r2, #2
 80076a0:	4606      	mov	r6, r0
 80076a2:	0092      	lsls	r2, r2, #2
 80076a4:	f107 010c 	add.w	r1, r7, #12
 80076a8:	300c      	adds	r0, #12
 80076aa:	f7fd fe51 	bl	8005350 <memcpy>
 80076ae:	2201      	movs	r2, #1
 80076b0:	4631      	mov	r1, r6
 80076b2:	4620      	mov	r0, r4
 80076b4:	f000 fe44 	bl	8008340 <__lshift>
 80076b8:	9b02      	ldr	r3, [sp, #8]
 80076ba:	f8dd a010 	ldr.w	sl, [sp, #16]
 80076be:	f003 0301 	and.w	r3, r3, #1
 80076c2:	46b9      	mov	r9, r7
 80076c4:	9307      	str	r3, [sp, #28]
 80076c6:	4607      	mov	r7, r0
 80076c8:	4629      	mov	r1, r5
 80076ca:	9801      	ldr	r0, [sp, #4]
 80076cc:	f7ff fb0a 	bl	8006ce4 <quorem>
 80076d0:	4649      	mov	r1, r9
 80076d2:	4606      	mov	r6, r0
 80076d4:	f100 0830 	add.w	r8, r0, #48	; 0x30
 80076d8:	9801      	ldr	r0, [sp, #4]
 80076da:	f000 fe85 	bl	80083e8 <__mcmp>
 80076de:	463a      	mov	r2, r7
 80076e0:	9002      	str	r0, [sp, #8]
 80076e2:	4629      	mov	r1, r5
 80076e4:	4620      	mov	r0, r4
 80076e6:	f000 fe99 	bl	800841c <__mdiff>
 80076ea:	68c3      	ldr	r3, [r0, #12]
 80076ec:	4602      	mov	r2, r0
 80076ee:	bb03      	cbnz	r3, 8007732 <_dtoa_r+0x932>
 80076f0:	4601      	mov	r1, r0
 80076f2:	9009      	str	r0, [sp, #36]	; 0x24
 80076f4:	9801      	ldr	r0, [sp, #4]
 80076f6:	f000 fe77 	bl	80083e8 <__mcmp>
 80076fa:	9a09      	ldr	r2, [sp, #36]	; 0x24
 80076fc:	4603      	mov	r3, r0
 80076fe:	4611      	mov	r1, r2
 8007700:	4620      	mov	r0, r4
 8007702:	9309      	str	r3, [sp, #36]	; 0x24
 8007704:	f000 fc50 	bl	8007fa8 <_Bfree>
 8007708:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800770a:	b9a3      	cbnz	r3, 8007736 <_dtoa_r+0x936>
 800770c:	9a08      	ldr	r2, [sp, #32]
 800770e:	b992      	cbnz	r2, 8007736 <_dtoa_r+0x936>
 8007710:	9a07      	ldr	r2, [sp, #28]
 8007712:	b982      	cbnz	r2, 8007736 <_dtoa_r+0x936>
 8007714:	f1b8 0f39 	cmp.w	r8, #57	; 0x39
 8007718:	d029      	beq.n	800776e <_dtoa_r+0x96e>
 800771a:	9b02      	ldr	r3, [sp, #8]
 800771c:	2b00      	cmp	r3, #0
 800771e:	dd01      	ble.n	8007724 <_dtoa_r+0x924>
 8007720:	f106 0831 	add.w	r8, r6, #49	; 0x31
 8007724:	f10a 0601 	add.w	r6, sl, #1
 8007728:	f88a 8000 	strb.w	r8, [sl]
 800772c:	e786      	b.n	800763c <_dtoa_r+0x83c>
 800772e:	4638      	mov	r0, r7
 8007730:	e7c2      	b.n	80076b8 <_dtoa_r+0x8b8>
 8007732:	2301      	movs	r3, #1
 8007734:	e7e3      	b.n	80076fe <_dtoa_r+0x8fe>
 8007736:	9a02      	ldr	r2, [sp, #8]
 8007738:	2a00      	cmp	r2, #0
 800773a:	db04      	blt.n	8007746 <_dtoa_r+0x946>
 800773c:	d124      	bne.n	8007788 <_dtoa_r+0x988>
 800773e:	9a08      	ldr	r2, [sp, #32]
 8007740:	bb12      	cbnz	r2, 8007788 <_dtoa_r+0x988>
 8007742:	9a07      	ldr	r2, [sp, #28]
 8007744:	bb02      	cbnz	r2, 8007788 <_dtoa_r+0x988>
 8007746:	2b00      	cmp	r3, #0
 8007748:	ddec      	ble.n	8007724 <_dtoa_r+0x924>
 800774a:	2201      	movs	r2, #1
 800774c:	9901      	ldr	r1, [sp, #4]
 800774e:	4620      	mov	r0, r4
 8007750:	f000 fdf6 	bl	8008340 <__lshift>
 8007754:	4629      	mov	r1, r5
 8007756:	9001      	str	r0, [sp, #4]
 8007758:	f000 fe46 	bl	80083e8 <__mcmp>
 800775c:	2800      	cmp	r0, #0
 800775e:	dc03      	bgt.n	8007768 <_dtoa_r+0x968>
 8007760:	d1e0      	bne.n	8007724 <_dtoa_r+0x924>
 8007762:	f018 0f01 	tst.w	r8, #1
 8007766:	d0dd      	beq.n	8007724 <_dtoa_r+0x924>
 8007768:	f1b8 0f39 	cmp.w	r8, #57	; 0x39
 800776c:	d1d8      	bne.n	8007720 <_dtoa_r+0x920>
 800776e:	2339      	movs	r3, #57	; 0x39
 8007770:	f10a 0601 	add.w	r6, sl, #1
 8007774:	f88a 3000 	strb.w	r3, [sl]
 8007778:	f816 3c01 	ldrb.w	r3, [r6, #-1]
 800777c:	2b39      	cmp	r3, #57	; 0x39
 800777e:	f106 32ff 	add.w	r2, r6, #4294967295	; 0xffffffff
 8007782:	d04c      	beq.n	800781e <_dtoa_r+0xa1e>
 8007784:	3301      	adds	r3, #1
 8007786:	e051      	b.n	800782c <_dtoa_r+0xa2c>
 8007788:	2b00      	cmp	r3, #0
 800778a:	f10a 0601 	add.w	r6, sl, #1
 800778e:	dd05      	ble.n	800779c <_dtoa_r+0x99c>
 8007790:	f1b8 0f39 	cmp.w	r8, #57	; 0x39
 8007794:	d0eb      	beq.n	800776e <_dtoa_r+0x96e>
 8007796:	f108 0801 	add.w	r8, r8, #1
 800779a:	e7c5      	b.n	8007728 <_dtoa_r+0x928>
 800779c:	9b04      	ldr	r3, [sp, #16]
 800779e:	9a06      	ldr	r2, [sp, #24]
 80077a0:	f806 8c01 	strb.w	r8, [r6, #-1]
 80077a4:	1af3      	subs	r3, r6, r3
 80077a6:	4293      	cmp	r3, r2
 80077a8:	d021      	beq.n	80077ee <_dtoa_r+0x9ee>
 80077aa:	2300      	movs	r3, #0
 80077ac:	220a      	movs	r2, #10
 80077ae:	9901      	ldr	r1, [sp, #4]
 80077b0:	4620      	mov	r0, r4
 80077b2:	f000 fc10 	bl	8007fd6 <__multadd>
 80077b6:	45b9      	cmp	r9, r7
 80077b8:	9001      	str	r0, [sp, #4]
 80077ba:	f04f 0300 	mov.w	r3, #0
 80077be:	f04f 020a 	mov.w	r2, #10
 80077c2:	4649      	mov	r1, r9
 80077c4:	4620      	mov	r0, r4
 80077c6:	d105      	bne.n	80077d4 <_dtoa_r+0x9d4>
 80077c8:	f000 fc05 	bl	8007fd6 <__multadd>
 80077cc:	4681      	mov	r9, r0
 80077ce:	4607      	mov	r7, r0
 80077d0:	46b2      	mov	sl, r6
 80077d2:	e779      	b.n	80076c8 <_dtoa_r+0x8c8>
 80077d4:	f000 fbff 	bl	8007fd6 <__multadd>
 80077d8:	4639      	mov	r1, r7
 80077da:	4681      	mov	r9, r0
 80077dc:	2300      	movs	r3, #0
 80077de:	220a      	movs	r2, #10
 80077e0:	4620      	mov	r0, r4
 80077e2:	f000 fbf8 	bl	8007fd6 <__multadd>
 80077e6:	4607      	mov	r7, r0
 80077e8:	e7f2      	b.n	80077d0 <_dtoa_r+0x9d0>
 80077ea:	f04f 0900 	mov.w	r9, #0
 80077ee:	2201      	movs	r2, #1
 80077f0:	9901      	ldr	r1, [sp, #4]
 80077f2:	4620      	mov	r0, r4
 80077f4:	f000 fda4 	bl	8008340 <__lshift>
 80077f8:	4629      	mov	r1, r5
 80077fa:	9001      	str	r0, [sp, #4]
 80077fc:	f000 fdf4 	bl	80083e8 <__mcmp>
 8007800:	2800      	cmp	r0, #0
 8007802:	dcb9      	bgt.n	8007778 <_dtoa_r+0x978>
 8007804:	d102      	bne.n	800780c <_dtoa_r+0xa0c>
 8007806:	f018 0f01 	tst.w	r8, #1
 800780a:	d1b5      	bne.n	8007778 <_dtoa_r+0x978>
 800780c:	f816 3c01 	ldrb.w	r3, [r6, #-1]
 8007810:	2b30      	cmp	r3, #48	; 0x30
 8007812:	f106 32ff 	add.w	r2, r6, #4294967295	; 0xffffffff
 8007816:	f47f af11 	bne.w	800763c <_dtoa_r+0x83c>
 800781a:	4616      	mov	r6, r2
 800781c:	e7f6      	b.n	800780c <_dtoa_r+0xa0c>
 800781e:	9b04      	ldr	r3, [sp, #16]
 8007820:	4293      	cmp	r3, r2
 8007822:	d105      	bne.n	8007830 <_dtoa_r+0xa30>
 8007824:	9a04      	ldr	r2, [sp, #16]
 8007826:	f10b 0b01 	add.w	fp, fp, #1
 800782a:	2331      	movs	r3, #49	; 0x31
 800782c:	7013      	strb	r3, [r2, #0]
 800782e:	e705      	b.n	800763c <_dtoa_r+0x83c>
 8007830:	4616      	mov	r6, r2
 8007832:	e7a1      	b.n	8007778 <_dtoa_r+0x978>
 8007834:	4b16      	ldr	r3, [pc, #88]	; (8007890 <_dtoa_r+0xa90>)
 8007836:	f7ff bb48 	b.w	8006eca <_dtoa_r+0xca>
 800783a:	9b1f      	ldr	r3, [sp, #124]	; 0x7c
 800783c:	2b00      	cmp	r3, #0
 800783e:	f47f ab23 	bne.w	8006e88 <_dtoa_r+0x88>
 8007842:	4b14      	ldr	r3, [pc, #80]	; (8007894 <_dtoa_r+0xa94>)
 8007844:	f7ff bb41 	b.w	8006eca <_dtoa_r+0xca>
 8007848:	9b08      	ldr	r3, [sp, #32]
 800784a:	2b01      	cmp	r3, #1
 800784c:	f77f ae3b 	ble.w	80074c6 <_dtoa_r+0x6c6>
 8007850:	f8dd 802c 	ldr.w	r8, [sp, #44]	; 0x2c
 8007854:	e64f      	b.n	80074f6 <_dtoa_r+0x6f6>
 8007856:	9b06      	ldr	r3, [sp, #24]
 8007858:	2b00      	cmp	r3, #0
 800785a:	dc03      	bgt.n	8007864 <_dtoa_r+0xa64>
 800785c:	9b08      	ldr	r3, [sp, #32]
 800785e:	2b02      	cmp	r3, #2
 8007860:	f73f aed7 	bgt.w	8007612 <_dtoa_r+0x812>
 8007864:	9e04      	ldr	r6, [sp, #16]
 8007866:	9801      	ldr	r0, [sp, #4]
 8007868:	4629      	mov	r1, r5
 800786a:	f7ff fa3b 	bl	8006ce4 <quorem>
 800786e:	f100 0830 	add.w	r8, r0, #48	; 0x30
 8007872:	f806 8b01 	strb.w	r8, [r6], #1
 8007876:	9b04      	ldr	r3, [sp, #16]
 8007878:	9a06      	ldr	r2, [sp, #24]
 800787a:	1af3      	subs	r3, r6, r3
 800787c:	429a      	cmp	r2, r3
 800787e:	ddb4      	ble.n	80077ea <_dtoa_r+0x9ea>
 8007880:	2300      	movs	r3, #0
 8007882:	220a      	movs	r2, #10
 8007884:	9901      	ldr	r1, [sp, #4]
 8007886:	4620      	mov	r0, r4
 8007888:	f000 fba5 	bl	8007fd6 <__multadd>
 800788c:	9001      	str	r0, [sp, #4]
 800788e:	e7ea      	b.n	8007866 <_dtoa_r+0xa66>
 8007890:	0802e6cc 	.word	0x0802e6cc
 8007894:	0802e748 	.word	0x0802e748

08007898 <rshift>:
 8007898:	b5f0      	push	{r4, r5, r6, r7, lr}
 800789a:	6906      	ldr	r6, [r0, #16]
 800789c:	114b      	asrs	r3, r1, #5
 800789e:	429e      	cmp	r6, r3
 80078a0:	f100 0414 	add.w	r4, r0, #20
 80078a4:	dd30      	ble.n	8007908 <rshift+0x70>
 80078a6:	f011 011f 	ands.w	r1, r1, #31
 80078aa:	eb04 0686 	add.w	r6, r4, r6, lsl #2
 80078ae:	eb04 0283 	add.w	r2, r4, r3, lsl #2
 80078b2:	d108      	bne.n	80078c6 <rshift+0x2e>
 80078b4:	4621      	mov	r1, r4
 80078b6:	42b2      	cmp	r2, r6
 80078b8:	460b      	mov	r3, r1
 80078ba:	d211      	bcs.n	80078e0 <rshift+0x48>
 80078bc:	f852 3b04 	ldr.w	r3, [r2], #4
 80078c0:	f841 3b04 	str.w	r3, [r1], #4
 80078c4:	e7f7      	b.n	80078b6 <rshift+0x1e>
 80078c6:	f854 5023 	ldr.w	r5, [r4, r3, lsl #2]
 80078ca:	f1c1 0c20 	rsb	ip, r1, #32
 80078ce:	40cd      	lsrs	r5, r1
 80078d0:	3204      	adds	r2, #4
 80078d2:	4623      	mov	r3, r4
 80078d4:	42b2      	cmp	r2, r6
 80078d6:	4617      	mov	r7, r2
 80078d8:	d30c      	bcc.n	80078f4 <rshift+0x5c>
 80078da:	601d      	str	r5, [r3, #0]
 80078dc:	b105      	cbz	r5, 80078e0 <rshift+0x48>
 80078de:	3304      	adds	r3, #4
 80078e0:	1b1a      	subs	r2, r3, r4
 80078e2:	42a3      	cmp	r3, r4
 80078e4:	ea4f 02a2 	mov.w	r2, r2, asr #2
 80078e8:	bf08      	it	eq
 80078ea:	2300      	moveq	r3, #0
 80078ec:	6102      	str	r2, [r0, #16]
 80078ee:	bf08      	it	eq
 80078f0:	6143      	streq	r3, [r0, #20]
 80078f2:	bdf0      	pop	{r4, r5, r6, r7, pc}
 80078f4:	683f      	ldr	r7, [r7, #0]
 80078f6:	fa07 f70c 	lsl.w	r7, r7, ip
 80078fa:	433d      	orrs	r5, r7
 80078fc:	f843 5b04 	str.w	r5, [r3], #4
 8007900:	f852 5b04 	ldr.w	r5, [r2], #4
 8007904:	40cd      	lsrs	r5, r1
 8007906:	e7e5      	b.n	80078d4 <rshift+0x3c>
 8007908:	4623      	mov	r3, r4
 800790a:	e7e9      	b.n	80078e0 <rshift+0x48>

0800790c <__hexdig_fun>:
 800790c:	f1a0 0330 	sub.w	r3, r0, #48	; 0x30
 8007910:	2b09      	cmp	r3, #9
 8007912:	d802      	bhi.n	800791a <__hexdig_fun+0xe>
 8007914:	3820      	subs	r0, #32
 8007916:	b2c0      	uxtb	r0, r0
 8007918:	4770      	bx	lr
 800791a:	f1a0 0361 	sub.w	r3, r0, #97	; 0x61
 800791e:	2b05      	cmp	r3, #5
 8007920:	d801      	bhi.n	8007926 <__hexdig_fun+0x1a>
 8007922:	3847      	subs	r0, #71	; 0x47
 8007924:	e7f7      	b.n	8007916 <__hexdig_fun+0xa>
 8007926:	f1a0 0341 	sub.w	r3, r0, #65	; 0x41
 800792a:	2b05      	cmp	r3, #5
 800792c:	d801      	bhi.n	8007932 <__hexdig_fun+0x26>
 800792e:	3827      	subs	r0, #39	; 0x27
 8007930:	e7f1      	b.n	8007916 <__hexdig_fun+0xa>
 8007932:	2000      	movs	r0, #0
 8007934:	4770      	bx	lr

08007936 <__gethex>:
 8007936:	e92d 4ff0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, lr}
 800793a:	b08b      	sub	sp, #44	; 0x2c
 800793c:	468a      	mov	sl, r1
 800793e:	9002      	str	r0, [sp, #8]
 8007940:	9816      	ldr	r0, [sp, #88]	; 0x58
 8007942:	9306      	str	r3, [sp, #24]
 8007944:	4690      	mov	r8, r2
 8007946:	f000 fad0 	bl	8007eea <__localeconv_l>
 800794a:	6803      	ldr	r3, [r0, #0]
 800794c:	9303      	str	r3, [sp, #12]
 800794e:	4618      	mov	r0, r3
 8007950:	f7f8 fc76 	bl	8000240 <strlen>
 8007954:	9b03      	ldr	r3, [sp, #12]
 8007956:	9001      	str	r0, [sp, #4]
 8007958:	4403      	add	r3, r0
 800795a:	f04f 0b00 	mov.w	fp, #0
 800795e:	f813 3c01 	ldrb.w	r3, [r3, #-1]
 8007962:	9307      	str	r3, [sp, #28]
 8007964:	f8da 3000 	ldr.w	r3, [sl]
 8007968:	3302      	adds	r3, #2
 800796a:	461f      	mov	r7, r3
 800796c:	f813 0b01 	ldrb.w	r0, [r3], #1
 8007970:	2830      	cmp	r0, #48	; 0x30
 8007972:	d06c      	beq.n	8007a4e <__gethex+0x118>
 8007974:	f7ff ffca 	bl	800790c <__hexdig_fun>
 8007978:	4604      	mov	r4, r0
 800797a:	2800      	cmp	r0, #0
 800797c:	d16a      	bne.n	8007a54 <__gethex+0x11e>
 800797e:	9a01      	ldr	r2, [sp, #4]
 8007980:	9903      	ldr	r1, [sp, #12]
 8007982:	4638      	mov	r0, r7
 8007984:	f001 f8f4 	bl	8008b70 <strncmp>
 8007988:	2800      	cmp	r0, #0
 800798a:	d166      	bne.n	8007a5a <__gethex+0x124>
 800798c:	9b01      	ldr	r3, [sp, #4]
 800798e:	5cf8      	ldrb	r0, [r7, r3]
 8007990:	18fe      	adds	r6, r7, r3
 8007992:	f7ff ffbb 	bl	800790c <__hexdig_fun>
 8007996:	2800      	cmp	r0, #0
 8007998:	d062      	beq.n	8007a60 <__gethex+0x12a>
 800799a:	4633      	mov	r3, r6
 800799c:	7818      	ldrb	r0, [r3, #0]
 800799e:	2830      	cmp	r0, #48	; 0x30
 80079a0:	461f      	mov	r7, r3
 80079a2:	f103 0301 	add.w	r3, r3, #1
 80079a6:	d0f9      	beq.n	800799c <__gethex+0x66>
 80079a8:	f7ff ffb0 	bl	800790c <__hexdig_fun>
 80079ac:	fab0 f580 	clz	r5, r0
 80079b0:	096d      	lsrs	r5, r5, #5
 80079b2:	4634      	mov	r4, r6
 80079b4:	f04f 0b01 	mov.w	fp, #1
 80079b8:	463a      	mov	r2, r7
 80079ba:	4616      	mov	r6, r2
 80079bc:	3201      	adds	r2, #1
 80079be:	7830      	ldrb	r0, [r6, #0]
 80079c0:	f7ff ffa4 	bl	800790c <__hexdig_fun>
 80079c4:	2800      	cmp	r0, #0
 80079c6:	d1f8      	bne.n	80079ba <__gethex+0x84>
 80079c8:	9a01      	ldr	r2, [sp, #4]
 80079ca:	9903      	ldr	r1, [sp, #12]
 80079cc:	4630      	mov	r0, r6
 80079ce:	f001 f8cf 	bl	8008b70 <strncmp>
 80079d2:	b950      	cbnz	r0, 80079ea <__gethex+0xb4>
 80079d4:	b954      	cbnz	r4, 80079ec <__gethex+0xb6>
 80079d6:	9b01      	ldr	r3, [sp, #4]
 80079d8:	18f4      	adds	r4, r6, r3
 80079da:	4622      	mov	r2, r4
 80079dc:	4616      	mov	r6, r2
 80079de:	3201      	adds	r2, #1
 80079e0:	7830      	ldrb	r0, [r6, #0]
 80079e2:	f7ff ff93 	bl	800790c <__hexdig_fun>
 80079e6:	2800      	cmp	r0, #0
 80079e8:	d1f8      	bne.n	80079dc <__gethex+0xa6>
 80079ea:	b10c      	cbz	r4, 80079f0 <__gethex+0xba>
 80079ec:	1ba4      	subs	r4, r4, r6
 80079ee:	00a4      	lsls	r4, r4, #2
 80079f0:	7833      	ldrb	r3, [r6, #0]
 80079f2:	2b50      	cmp	r3, #80	; 0x50
 80079f4:	d001      	beq.n	80079fa <__gethex+0xc4>
 80079f6:	2b70      	cmp	r3, #112	; 0x70
 80079f8:	d140      	bne.n	8007a7c <__gethex+0x146>
 80079fa:	7873      	ldrb	r3, [r6, #1]
 80079fc:	2b2b      	cmp	r3, #43	; 0x2b
 80079fe:	d031      	beq.n	8007a64 <__gethex+0x12e>
 8007a00:	2b2d      	cmp	r3, #45	; 0x2d
 8007a02:	d033      	beq.n	8007a6c <__gethex+0x136>
 8007a04:	1c71      	adds	r1, r6, #1
 8007a06:	f04f 0900 	mov.w	r9, #0
 8007a0a:	7808      	ldrb	r0, [r1, #0]
 8007a0c:	f7ff ff7e 	bl	800790c <__hexdig_fun>
 8007a10:	1e43      	subs	r3, r0, #1
 8007a12:	b2db      	uxtb	r3, r3
 8007a14:	2b18      	cmp	r3, #24
 8007a16:	d831      	bhi.n	8007a7c <__gethex+0x146>
 8007a18:	f1a0 0210 	sub.w	r2, r0, #16
 8007a1c:	f811 0f01 	ldrb.w	r0, [r1, #1]!
 8007a20:	f7ff ff74 	bl	800790c <__hexdig_fun>
 8007a24:	1e43      	subs	r3, r0, #1
 8007a26:	b2db      	uxtb	r3, r3
 8007a28:	2b18      	cmp	r3, #24
 8007a2a:	d922      	bls.n	8007a72 <__gethex+0x13c>
 8007a2c:	f1b9 0f00 	cmp.w	r9, #0
 8007a30:	d000      	beq.n	8007a34 <__gethex+0xfe>
 8007a32:	4252      	negs	r2, r2
 8007a34:	4414      	add	r4, r2
 8007a36:	f8ca 1000 	str.w	r1, [sl]
 8007a3a:	b30d      	cbz	r5, 8007a80 <__gethex+0x14a>
 8007a3c:	f1bb 0f00 	cmp.w	fp, #0
 8007a40:	bf0c      	ite	eq
 8007a42:	2706      	moveq	r7, #6
 8007a44:	2700      	movne	r7, #0
 8007a46:	4638      	mov	r0, r7
 8007a48:	b00b      	add	sp, #44	; 0x2c
 8007a4a:	e8bd 8ff0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, pc}
 8007a4e:	f10b 0b01 	add.w	fp, fp, #1
 8007a52:	e78a      	b.n	800796a <__gethex+0x34>
 8007a54:	2500      	movs	r5, #0
 8007a56:	462c      	mov	r4, r5
 8007a58:	e7ae      	b.n	80079b8 <__gethex+0x82>
 8007a5a:	463e      	mov	r6, r7
 8007a5c:	2501      	movs	r5, #1
 8007a5e:	e7c7      	b.n	80079f0 <__gethex+0xba>
 8007a60:	4604      	mov	r4, r0
 8007a62:	e7fb      	b.n	8007a5c <__gethex+0x126>
 8007a64:	f04f 0900 	mov.w	r9, #0
 8007a68:	1cb1      	adds	r1, r6, #2
 8007a6a:	e7ce      	b.n	8007a0a <__gethex+0xd4>
 8007a6c:	f04f 0901 	mov.w	r9, #1
 8007a70:	e7fa      	b.n	8007a68 <__gethex+0x132>
 8007a72:	230a      	movs	r3, #10
 8007a74:	fb03 0202 	mla	r2, r3, r2, r0
 8007a78:	3a10      	subs	r2, #16
 8007a7a:	e7cf      	b.n	8007a1c <__gethex+0xe6>
 8007a7c:	4631      	mov	r1, r6
 8007a7e:	e7da      	b.n	8007a36 <__gethex+0x100>
 8007a80:	1bf3      	subs	r3, r6, r7
 8007a82:	3b01      	subs	r3, #1
 8007a84:	4629      	mov	r1, r5
 8007a86:	2b07      	cmp	r3, #7
 8007a88:	dc49      	bgt.n	8007b1e <__gethex+0x1e8>
 8007a8a:	9802      	ldr	r0, [sp, #8]
 8007a8c:	f000 fa58 	bl	8007f40 <_Balloc>
 8007a90:	9b01      	ldr	r3, [sp, #4]
 8007a92:	f100 0914 	add.w	r9, r0, #20
 8007a96:	f04f 0b00 	mov.w	fp, #0
 8007a9a:	f1c3 0301 	rsb	r3, r3, #1
 8007a9e:	4605      	mov	r5, r0
 8007aa0:	f8cd 9010 	str.w	r9, [sp, #16]
 8007aa4:	46da      	mov	sl, fp
 8007aa6:	9308      	str	r3, [sp, #32]
 8007aa8:	42b7      	cmp	r7, r6
 8007aaa:	d33b      	bcc.n	8007b24 <__gethex+0x1ee>
 8007aac:	9804      	ldr	r0, [sp, #16]
 8007aae:	f840 ab04 	str.w	sl, [r0], #4
 8007ab2:	eba0 0009 	sub.w	r0, r0, r9
 8007ab6:	1080      	asrs	r0, r0, #2
 8007ab8:	6128      	str	r0, [r5, #16]
 8007aba:	0147      	lsls	r7, r0, #5
 8007abc:	4650      	mov	r0, sl
 8007abe:	f000 fb03 	bl	80080c8 <__hi0bits>
 8007ac2:	f8d8 6000 	ldr.w	r6, [r8]
 8007ac6:	1a3f      	subs	r7, r7, r0
 8007ac8:	42b7      	cmp	r7, r6
 8007aca:	dd64      	ble.n	8007b96 <__gethex+0x260>
 8007acc:	1bbf      	subs	r7, r7, r6
 8007ace:	4639      	mov	r1, r7
 8007ad0:	4628      	mov	r0, r5
 8007ad2:	f000 fe14 	bl	80086fe <__any_on>
 8007ad6:	4682      	mov	sl, r0
 8007ad8:	b178      	cbz	r0, 8007afa <__gethex+0x1c4>
 8007ada:	1e7b      	subs	r3, r7, #1
 8007adc:	1159      	asrs	r1, r3, #5
 8007ade:	f003 021f 	and.w	r2, r3, #31
 8007ae2:	f04f 0a01 	mov.w	sl, #1
 8007ae6:	f859 1021 	ldr.w	r1, [r9, r1, lsl #2]
 8007aea:	fa0a f202 	lsl.w	r2, sl, r2
 8007aee:	420a      	tst	r2, r1
 8007af0:	d003      	beq.n	8007afa <__gethex+0x1c4>
 8007af2:	4553      	cmp	r3, sl
 8007af4:	dc46      	bgt.n	8007b84 <__gethex+0x24e>
 8007af6:	f04f 0a02 	mov.w	sl, #2
 8007afa:	4639      	mov	r1, r7
 8007afc:	4628      	mov	r0, r5
 8007afe:	f7ff fecb 	bl	8007898 <rshift>
 8007b02:	443c      	add	r4, r7
 8007b04:	f8d8 3008 	ldr.w	r3, [r8, #8]
 8007b08:	42a3      	cmp	r3, r4
 8007b0a:	da52      	bge.n	8007bb2 <__gethex+0x27c>
 8007b0c:	4629      	mov	r1, r5
 8007b0e:	9802      	ldr	r0, [sp, #8]
 8007b10:	f000 fa4a 	bl	8007fa8 <_Bfree>
 8007b14:	9a14      	ldr	r2, [sp, #80]	; 0x50
 8007b16:	2300      	movs	r3, #0
 8007b18:	6013      	str	r3, [r2, #0]
 8007b1a:	27a3      	movs	r7, #163	; 0xa3
 8007b1c:	e793      	b.n	8007a46 <__gethex+0x110>
 8007b1e:	3101      	adds	r1, #1
 8007b20:	105b      	asrs	r3, r3, #1
 8007b22:	e7b0      	b.n	8007a86 <__gethex+0x150>
 8007b24:	1e73      	subs	r3, r6, #1
 8007b26:	9305      	str	r3, [sp, #20]
 8007b28:	9a07      	ldr	r2, [sp, #28]
 8007b2a:	f816 3c01 	ldrb.w	r3, [r6, #-1]
 8007b2e:	4293      	cmp	r3, r2
 8007b30:	d018      	beq.n	8007b64 <__gethex+0x22e>
 8007b32:	f1bb 0f20 	cmp.w	fp, #32
 8007b36:	d107      	bne.n	8007b48 <__gethex+0x212>
 8007b38:	9b04      	ldr	r3, [sp, #16]
 8007b3a:	f8c3 a000 	str.w	sl, [r3]
 8007b3e:	3304      	adds	r3, #4
 8007b40:	f04f 0a00 	mov.w	sl, #0
 8007b44:	9304      	str	r3, [sp, #16]
 8007b46:	46d3      	mov	fp, sl
 8007b48:	f816 0c01 	ldrb.w	r0, [r6, #-1]
 8007b4c:	f7ff fede 	bl	800790c <__hexdig_fun>
 8007b50:	f000 000f 	and.w	r0, r0, #15
 8007b54:	fa00 f00b 	lsl.w	r0, r0, fp
 8007b58:	ea4a 0a00 	orr.w	sl, sl, r0
 8007b5c:	f10b 0b04 	add.w	fp, fp, #4
 8007b60:	9b05      	ldr	r3, [sp, #20]
 8007b62:	e00d      	b.n	8007b80 <__gethex+0x24a>
 8007b64:	9b05      	ldr	r3, [sp, #20]
 8007b66:	9a08      	ldr	r2, [sp, #32]
 8007b68:	4413      	add	r3, r2
 8007b6a:	42bb      	cmp	r3, r7
 8007b6c:	d3e1      	bcc.n	8007b32 <__gethex+0x1fc>
 8007b6e:	4618      	mov	r0, r3
 8007b70:	9a01      	ldr	r2, [sp, #4]
 8007b72:	9903      	ldr	r1, [sp, #12]
 8007b74:	9309      	str	r3, [sp, #36]	; 0x24
 8007b76:	f000 fffb 	bl	8008b70 <strncmp>
 8007b7a:	9b09      	ldr	r3, [sp, #36]	; 0x24
 8007b7c:	2800      	cmp	r0, #0
 8007b7e:	d1d8      	bne.n	8007b32 <__gethex+0x1fc>
 8007b80:	461e      	mov	r6, r3
 8007b82:	e791      	b.n	8007aa8 <__gethex+0x172>
 8007b84:	1eb9      	subs	r1, r7, #2
 8007b86:	4628      	mov	r0, r5
 8007b88:	f000 fdb9 	bl	80086fe <__any_on>
 8007b8c:	2800      	cmp	r0, #0
 8007b8e:	d0b2      	beq.n	8007af6 <__gethex+0x1c0>
 8007b90:	f04f 0a03 	mov.w	sl, #3
 8007b94:	e7b1      	b.n	8007afa <__gethex+0x1c4>
 8007b96:	da09      	bge.n	8007bac <__gethex+0x276>
 8007b98:	1bf7      	subs	r7, r6, r7
 8007b9a:	4629      	mov	r1, r5
 8007b9c:	463a      	mov	r2, r7
 8007b9e:	9802      	ldr	r0, [sp, #8]
 8007ba0:	f000 fbce 	bl	8008340 <__lshift>
 8007ba4:	1be4      	subs	r4, r4, r7
 8007ba6:	4605      	mov	r5, r0
 8007ba8:	f100 0914 	add.w	r9, r0, #20
 8007bac:	f04f 0a00 	mov.w	sl, #0
 8007bb0:	e7a8      	b.n	8007b04 <__gethex+0x1ce>
 8007bb2:	f8d8 0004 	ldr.w	r0, [r8, #4]
 8007bb6:	42a0      	cmp	r0, r4
 8007bb8:	dd6a      	ble.n	8007c90 <__gethex+0x35a>
 8007bba:	1b04      	subs	r4, r0, r4
 8007bbc:	42a6      	cmp	r6, r4
 8007bbe:	dc2e      	bgt.n	8007c1e <__gethex+0x2e8>
 8007bc0:	f8d8 300c 	ldr.w	r3, [r8, #12]
 8007bc4:	2b02      	cmp	r3, #2
 8007bc6:	d022      	beq.n	8007c0e <__gethex+0x2d8>
 8007bc8:	2b03      	cmp	r3, #3
 8007bca:	d024      	beq.n	8007c16 <__gethex+0x2e0>
 8007bcc:	2b01      	cmp	r3, #1
 8007bce:	d115      	bne.n	8007bfc <__gethex+0x2c6>
 8007bd0:	42a6      	cmp	r6, r4
 8007bd2:	d113      	bne.n	8007bfc <__gethex+0x2c6>
 8007bd4:	2e01      	cmp	r6, #1
 8007bd6:	dc0b      	bgt.n	8007bf0 <__gethex+0x2ba>
 8007bd8:	9a06      	ldr	r2, [sp, #24]
 8007bda:	f8d8 3004 	ldr.w	r3, [r8, #4]
 8007bde:	6013      	str	r3, [r2, #0]
 8007be0:	2301      	movs	r3, #1
 8007be2:	612b      	str	r3, [r5, #16]
 8007be4:	f8c9 3000 	str.w	r3, [r9]
 8007be8:	9b14      	ldr	r3, [sp, #80]	; 0x50
 8007bea:	2762      	movs	r7, #98	; 0x62
 8007bec:	601d      	str	r5, [r3, #0]
 8007bee:	e72a      	b.n	8007a46 <__gethex+0x110>
 8007bf0:	1e71      	subs	r1, r6, #1
 8007bf2:	4628      	mov	r0, r5
 8007bf4:	f000 fd83 	bl	80086fe <__any_on>
 8007bf8:	2800      	cmp	r0, #0
 8007bfa:	d1ed      	bne.n	8007bd8 <__gethex+0x2a2>
 8007bfc:	4629      	mov	r1, r5
 8007bfe:	9802      	ldr	r0, [sp, #8]
 8007c00:	f000 f9d2 	bl	8007fa8 <_Bfree>
 8007c04:	9a14      	ldr	r2, [sp, #80]	; 0x50
 8007c06:	2300      	movs	r3, #0
 8007c08:	6013      	str	r3, [r2, #0]
 8007c0a:	2750      	movs	r7, #80	; 0x50
 8007c0c:	e71b      	b.n	8007a46 <__gethex+0x110>
 8007c0e:	9b15      	ldr	r3, [sp, #84]	; 0x54
 8007c10:	2b00      	cmp	r3, #0
 8007c12:	d0e1      	beq.n	8007bd8 <__gethex+0x2a2>
 8007c14:	e7f2      	b.n	8007bfc <__gethex+0x2c6>
 8007c16:	9b15      	ldr	r3, [sp, #84]	; 0x54
 8007c18:	2b00      	cmp	r3, #0
 8007c1a:	d1dd      	bne.n	8007bd8 <__gethex+0x2a2>
 8007c1c:	e7ee      	b.n	8007bfc <__gethex+0x2c6>
 8007c1e:	1e67      	subs	r7, r4, #1
 8007c20:	f1ba 0f00 	cmp.w	sl, #0
 8007c24:	d131      	bne.n	8007c8a <__gethex+0x354>
 8007c26:	b127      	cbz	r7, 8007c32 <__gethex+0x2fc>
 8007c28:	4639      	mov	r1, r7
 8007c2a:	4628      	mov	r0, r5
 8007c2c:	f000 fd67 	bl	80086fe <__any_on>
 8007c30:	4682      	mov	sl, r0
 8007c32:	117a      	asrs	r2, r7, #5
 8007c34:	2301      	movs	r3, #1
 8007c36:	f007 071f 	and.w	r7, r7, #31
 8007c3a:	fa03 f707 	lsl.w	r7, r3, r7
 8007c3e:	f859 3022 	ldr.w	r3, [r9, r2, lsl #2]
 8007c42:	4621      	mov	r1, r4
 8007c44:	421f      	tst	r7, r3
 8007c46:	4628      	mov	r0, r5
 8007c48:	bf18      	it	ne
 8007c4a:	f04a 0a02 	orrne.w	sl, sl, #2
 8007c4e:	1b36      	subs	r6, r6, r4
 8007c50:	f7ff fe22 	bl	8007898 <rshift>
 8007c54:	f8d8 4004 	ldr.w	r4, [r8, #4]
 8007c58:	2702      	movs	r7, #2
 8007c5a:	f1ba 0f00 	cmp.w	sl, #0
 8007c5e:	d048      	beq.n	8007cf2 <__gethex+0x3bc>
 8007c60:	f8d8 300c 	ldr.w	r3, [r8, #12]
 8007c64:	2b02      	cmp	r3, #2
 8007c66:	d015      	beq.n	8007c94 <__gethex+0x35e>
 8007c68:	2b03      	cmp	r3, #3
 8007c6a:	d017      	beq.n	8007c9c <__gethex+0x366>
 8007c6c:	2b01      	cmp	r3, #1
 8007c6e:	d109      	bne.n	8007c84 <__gethex+0x34e>
 8007c70:	f01a 0f02 	tst.w	sl, #2
 8007c74:	d006      	beq.n	8007c84 <__gethex+0x34e>
 8007c76:	f8d9 3000 	ldr.w	r3, [r9]
 8007c7a:	ea4a 0a03 	orr.w	sl, sl, r3
 8007c7e:	f01a 0f01 	tst.w	sl, #1
 8007c82:	d10e      	bne.n	8007ca2 <__gethex+0x36c>
 8007c84:	f047 0710 	orr.w	r7, r7, #16
 8007c88:	e033      	b.n	8007cf2 <__gethex+0x3bc>
 8007c8a:	f04f 0a01 	mov.w	sl, #1
 8007c8e:	e7d0      	b.n	8007c32 <__gethex+0x2fc>
 8007c90:	2701      	movs	r7, #1
 8007c92:	e7e2      	b.n	8007c5a <__gethex+0x324>
 8007c94:	9b15      	ldr	r3, [sp, #84]	; 0x54
 8007c96:	f1c3 0301 	rsb	r3, r3, #1
 8007c9a:	9315      	str	r3, [sp, #84]	; 0x54
 8007c9c:	9b15      	ldr	r3, [sp, #84]	; 0x54
 8007c9e:	2b00      	cmp	r3, #0
 8007ca0:	d0f0      	beq.n	8007c84 <__gethex+0x34e>
 8007ca2:	f8d5 9010 	ldr.w	r9, [r5, #16]
 8007ca6:	f105 0314 	add.w	r3, r5, #20
 8007caa:	ea4f 0a89 	mov.w	sl, r9, lsl #2
 8007cae:	eb03 010a 	add.w	r1, r3, sl
 8007cb2:	f04f 0c00 	mov.w	ip, #0
 8007cb6:	4618      	mov	r0, r3
 8007cb8:	f853 2b04 	ldr.w	r2, [r3], #4
 8007cbc:	f1b2 3fff 	cmp.w	r2, #4294967295	; 0xffffffff
 8007cc0:	d01c      	beq.n	8007cfc <__gethex+0x3c6>
 8007cc2:	3201      	adds	r2, #1
 8007cc4:	6002      	str	r2, [r0, #0]
 8007cc6:	2f02      	cmp	r7, #2
 8007cc8:	f105 0314 	add.w	r3, r5, #20
 8007ccc:	d138      	bne.n	8007d40 <__gethex+0x40a>
 8007cce:	f8d8 2000 	ldr.w	r2, [r8]
 8007cd2:	3a01      	subs	r2, #1
 8007cd4:	42b2      	cmp	r2, r6
 8007cd6:	d10a      	bne.n	8007cee <__gethex+0x3b8>
 8007cd8:	1171      	asrs	r1, r6, #5
 8007cda:	2201      	movs	r2, #1
 8007cdc:	f006 061f 	and.w	r6, r6, #31
 8007ce0:	f853 3021 	ldr.w	r3, [r3, r1, lsl #2]
 8007ce4:	fa02 f606 	lsl.w	r6, r2, r6
 8007ce8:	421e      	tst	r6, r3
 8007cea:	bf18      	it	ne
 8007cec:	4617      	movne	r7, r2
 8007cee:	f047 0720 	orr.w	r7, r7, #32
 8007cf2:	9b14      	ldr	r3, [sp, #80]	; 0x50
 8007cf4:	601d      	str	r5, [r3, #0]
 8007cf6:	9b06      	ldr	r3, [sp, #24]
 8007cf8:	601c      	str	r4, [r3, #0]
 8007cfa:	e6a4      	b.n	8007a46 <__gethex+0x110>
 8007cfc:	4299      	cmp	r1, r3
 8007cfe:	f843 cc04 	str.w	ip, [r3, #-4]
 8007d02:	d8d8      	bhi.n	8007cb6 <__gethex+0x380>
 8007d04:	68ab      	ldr	r3, [r5, #8]
 8007d06:	4599      	cmp	r9, r3
 8007d08:	db12      	blt.n	8007d30 <__gethex+0x3fa>
 8007d0a:	6869      	ldr	r1, [r5, #4]
 8007d0c:	9802      	ldr	r0, [sp, #8]
 8007d0e:	3101      	adds	r1, #1
 8007d10:	f000 f916 	bl	8007f40 <_Balloc>
 8007d14:	692a      	ldr	r2, [r5, #16]
 8007d16:	3202      	adds	r2, #2
 8007d18:	f105 010c 	add.w	r1, r5, #12
 8007d1c:	4683      	mov	fp, r0
 8007d1e:	0092      	lsls	r2, r2, #2
 8007d20:	300c      	adds	r0, #12
 8007d22:	f7fd fb15 	bl	8005350 <memcpy>
 8007d26:	4629      	mov	r1, r5
 8007d28:	9802      	ldr	r0, [sp, #8]
 8007d2a:	f000 f93d 	bl	8007fa8 <_Bfree>
 8007d2e:	465d      	mov	r5, fp
 8007d30:	692b      	ldr	r3, [r5, #16]
 8007d32:	1c5a      	adds	r2, r3, #1
 8007d34:	eb05 0383 	add.w	r3, r5, r3, lsl #2
 8007d38:	612a      	str	r2, [r5, #16]
 8007d3a:	2201      	movs	r2, #1
 8007d3c:	615a      	str	r2, [r3, #20]
 8007d3e:	e7c2      	b.n	8007cc6 <__gethex+0x390>
 8007d40:	692a      	ldr	r2, [r5, #16]
 8007d42:	454a      	cmp	r2, r9
 8007d44:	dd0b      	ble.n	8007d5e <__gethex+0x428>
 8007d46:	2101      	movs	r1, #1
 8007d48:	4628      	mov	r0, r5
 8007d4a:	f7ff fda5 	bl	8007898 <rshift>
 8007d4e:	f8d8 3008 	ldr.w	r3, [r8, #8]
 8007d52:	3401      	adds	r4, #1
 8007d54:	42a3      	cmp	r3, r4
 8007d56:	f6ff aed9 	blt.w	8007b0c <__gethex+0x1d6>
 8007d5a:	2701      	movs	r7, #1
 8007d5c:	e7c7      	b.n	8007cee <__gethex+0x3b8>
 8007d5e:	f016 061f 	ands.w	r6, r6, #31
 8007d62:	d0fa      	beq.n	8007d5a <__gethex+0x424>
 8007d64:	449a      	add	sl, r3
 8007d66:	f1c6 0620 	rsb	r6, r6, #32
 8007d6a:	f85a 0c04 	ldr.w	r0, [sl, #-4]
 8007d6e:	f000 f9ab 	bl	80080c8 <__hi0bits>
 8007d72:	42b0      	cmp	r0, r6
 8007d74:	dbe7      	blt.n	8007d46 <__gethex+0x410>
 8007d76:	e7f0      	b.n	8007d5a <__gethex+0x424>

08007d78 <L_shift>:
 8007d78:	f1c2 0208 	rsb	r2, r2, #8
 8007d7c:	0092      	lsls	r2, r2, #2
 8007d7e:	b570      	push	{r4, r5, r6, lr}
 8007d80:	f1c2 0620 	rsb	r6, r2, #32
 8007d84:	6843      	ldr	r3, [r0, #4]
 8007d86:	6804      	ldr	r4, [r0, #0]
 8007d88:	fa03 f506 	lsl.w	r5, r3, r6
 8007d8c:	432c      	orrs	r4, r5
 8007d8e:	40d3      	lsrs	r3, r2
 8007d90:	6004      	str	r4, [r0, #0]
 8007d92:	f840 3f04 	str.w	r3, [r0, #4]!
 8007d96:	4288      	cmp	r0, r1
 8007d98:	d3f4      	bcc.n	8007d84 <L_shift+0xc>
 8007d9a:	bd70      	pop	{r4, r5, r6, pc}

08007d9c <__match>:
 8007d9c:	b530      	push	{r4, r5, lr}
 8007d9e:	6803      	ldr	r3, [r0, #0]
 8007da0:	3301      	adds	r3, #1
 8007da2:	f811 4b01 	ldrb.w	r4, [r1], #1
 8007da6:	b914      	cbnz	r4, 8007dae <__match+0x12>
 8007da8:	6003      	str	r3, [r0, #0]
 8007daa:	2001      	movs	r0, #1
 8007dac:	bd30      	pop	{r4, r5, pc}
 8007dae:	f813 2b01 	ldrb.w	r2, [r3], #1
 8007db2:	f1a2 0541 	sub.w	r5, r2, #65	; 0x41
 8007db6:	2d19      	cmp	r5, #25
 8007db8:	bf98      	it	ls
 8007dba:	3220      	addls	r2, #32
 8007dbc:	42a2      	cmp	r2, r4
 8007dbe:	d0f0      	beq.n	8007da2 <__match+0x6>
 8007dc0:	2000      	movs	r0, #0
 8007dc2:	e7f3      	b.n	8007dac <__match+0x10>

08007dc4 <__hexnan>:
 8007dc4:	e92d 4ff0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, lr}
 8007dc8:	680b      	ldr	r3, [r1, #0]
 8007dca:	6801      	ldr	r1, [r0, #0]
 8007dcc:	115f      	asrs	r7, r3, #5
 8007dce:	eb02 0787 	add.w	r7, r2, r7, lsl #2
 8007dd2:	f013 031f 	ands.w	r3, r3, #31
 8007dd6:	b087      	sub	sp, #28
 8007dd8:	bf18      	it	ne
 8007dda:	3704      	addne	r7, #4
 8007ddc:	2500      	movs	r5, #0
 8007dde:	1f3e      	subs	r6, r7, #4
 8007de0:	4682      	mov	sl, r0
 8007de2:	4690      	mov	r8, r2
 8007de4:	9301      	str	r3, [sp, #4]
 8007de6:	f847 5c04 	str.w	r5, [r7, #-4]
 8007dea:	46b1      	mov	r9, r6
 8007dec:	4634      	mov	r4, r6
 8007dee:	9502      	str	r5, [sp, #8]
 8007df0:	46ab      	mov	fp, r5
 8007df2:	784a      	ldrb	r2, [r1, #1]
 8007df4:	1c4b      	adds	r3, r1, #1
 8007df6:	9303      	str	r3, [sp, #12]
 8007df8:	b342      	cbz	r2, 8007e4c <__hexnan+0x88>
 8007dfa:	4610      	mov	r0, r2
 8007dfc:	9105      	str	r1, [sp, #20]
 8007dfe:	9204      	str	r2, [sp, #16]
 8007e00:	f7ff fd84 	bl	800790c <__hexdig_fun>
 8007e04:	2800      	cmp	r0, #0
 8007e06:	d143      	bne.n	8007e90 <__hexnan+0xcc>
 8007e08:	9a04      	ldr	r2, [sp, #16]
 8007e0a:	9905      	ldr	r1, [sp, #20]
 8007e0c:	2a20      	cmp	r2, #32
 8007e0e:	d818      	bhi.n	8007e42 <__hexnan+0x7e>
 8007e10:	9b02      	ldr	r3, [sp, #8]
 8007e12:	459b      	cmp	fp, r3
 8007e14:	dd13      	ble.n	8007e3e <__hexnan+0x7a>
 8007e16:	454c      	cmp	r4, r9
 8007e18:	d206      	bcs.n	8007e28 <__hexnan+0x64>
 8007e1a:	2d07      	cmp	r5, #7
 8007e1c:	dc04      	bgt.n	8007e28 <__hexnan+0x64>
 8007e1e:	462a      	mov	r2, r5
 8007e20:	4649      	mov	r1, r9
 8007e22:	4620      	mov	r0, r4
 8007e24:	f7ff ffa8 	bl	8007d78 <L_shift>
 8007e28:	4544      	cmp	r4, r8
 8007e2a:	d944      	bls.n	8007eb6 <__hexnan+0xf2>
 8007e2c:	2300      	movs	r3, #0
 8007e2e:	f1a4 0904 	sub.w	r9, r4, #4
 8007e32:	f844 3c04 	str.w	r3, [r4, #-4]
 8007e36:	f8cd b008 	str.w	fp, [sp, #8]
 8007e3a:	464c      	mov	r4, r9
 8007e3c:	461d      	mov	r5, r3
 8007e3e:	9903      	ldr	r1, [sp, #12]
 8007e40:	e7d7      	b.n	8007df2 <__hexnan+0x2e>
 8007e42:	2a29      	cmp	r2, #41	; 0x29
 8007e44:	d14a      	bne.n	8007edc <__hexnan+0x118>
 8007e46:	3102      	adds	r1, #2
 8007e48:	f8ca 1000 	str.w	r1, [sl]
 8007e4c:	f1bb 0f00 	cmp.w	fp, #0
 8007e50:	d044      	beq.n	8007edc <__hexnan+0x118>
 8007e52:	454c      	cmp	r4, r9
 8007e54:	d206      	bcs.n	8007e64 <__hexnan+0xa0>
 8007e56:	2d07      	cmp	r5, #7
 8007e58:	dc04      	bgt.n	8007e64 <__hexnan+0xa0>
 8007e5a:	462a      	mov	r2, r5
 8007e5c:	4649      	mov	r1, r9
 8007e5e:	4620      	mov	r0, r4
 8007e60:	f7ff ff8a 	bl	8007d78 <L_shift>
 8007e64:	4544      	cmp	r4, r8
 8007e66:	d928      	bls.n	8007eba <__hexnan+0xf6>
 8007e68:	4643      	mov	r3, r8
 8007e6a:	f854 2b04 	ldr.w	r2, [r4], #4
 8007e6e:	f843 2b04 	str.w	r2, [r3], #4
 8007e72:	42a6      	cmp	r6, r4
 8007e74:	d2f9      	bcs.n	8007e6a <__hexnan+0xa6>
 8007e76:	2200      	movs	r2, #0
 8007e78:	f843 2b04 	str.w	r2, [r3], #4
 8007e7c:	429e      	cmp	r6, r3
 8007e7e:	d2fb      	bcs.n	8007e78 <__hexnan+0xb4>
 8007e80:	6833      	ldr	r3, [r6, #0]
 8007e82:	b91b      	cbnz	r3, 8007e8c <__hexnan+0xc8>
 8007e84:	4546      	cmp	r6, r8
 8007e86:	d127      	bne.n	8007ed8 <__hexnan+0x114>
 8007e88:	2301      	movs	r3, #1
 8007e8a:	6033      	str	r3, [r6, #0]
 8007e8c:	2005      	movs	r0, #5
 8007e8e:	e026      	b.n	8007ede <__hexnan+0x11a>
 8007e90:	3501      	adds	r5, #1
 8007e92:	2d08      	cmp	r5, #8
 8007e94:	f10b 0b01 	add.w	fp, fp, #1
 8007e98:	dd06      	ble.n	8007ea8 <__hexnan+0xe4>
 8007e9a:	4544      	cmp	r4, r8
 8007e9c:	d9cf      	bls.n	8007e3e <__hexnan+0x7a>
 8007e9e:	2300      	movs	r3, #0
 8007ea0:	f844 3c04 	str.w	r3, [r4, #-4]
 8007ea4:	2501      	movs	r5, #1
 8007ea6:	3c04      	subs	r4, #4
 8007ea8:	6822      	ldr	r2, [r4, #0]
 8007eaa:	f000 000f 	and.w	r0, r0, #15
 8007eae:	ea40 1002 	orr.w	r0, r0, r2, lsl #4
 8007eb2:	6020      	str	r0, [r4, #0]
 8007eb4:	e7c3      	b.n	8007e3e <__hexnan+0x7a>
 8007eb6:	2508      	movs	r5, #8
 8007eb8:	e7c1      	b.n	8007e3e <__hexnan+0x7a>
 8007eba:	9b01      	ldr	r3, [sp, #4]
 8007ebc:	2b00      	cmp	r3, #0
 8007ebe:	d0df      	beq.n	8007e80 <__hexnan+0xbc>
 8007ec0:	f04f 32ff 	mov.w	r2, #4294967295	; 0xffffffff
 8007ec4:	f1c3 0320 	rsb	r3, r3, #32
 8007ec8:	fa22 f303 	lsr.w	r3, r2, r3
 8007ecc:	f857 2c04 	ldr.w	r2, [r7, #-4]
 8007ed0:	401a      	ands	r2, r3
 8007ed2:	f847 2c04 	str.w	r2, [r7, #-4]
 8007ed6:	e7d3      	b.n	8007e80 <__hexnan+0xbc>
 8007ed8:	3e04      	subs	r6, #4
 8007eda:	e7d1      	b.n	8007e80 <__hexnan+0xbc>
 8007edc:	2004      	movs	r0, #4
 8007ede:	b007      	add	sp, #28
 8007ee0:	e8bd 8ff0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, pc}

08007ee4 <__locale_ctype_ptr_l>:
 8007ee4:	f8d0 00ec 	ldr.w	r0, [r0, #236]	; 0xec
 8007ee8:	4770      	bx	lr

08007eea <__localeconv_l>:
 8007eea:	30f0      	adds	r0, #240	; 0xf0
 8007eec:	4770      	bx	lr
	...

08007ef0 <_localeconv_r>:
 8007ef0:	4b04      	ldr	r3, [pc, #16]	; (8007f04 <_localeconv_r+0x14>)
 8007ef2:	681b      	ldr	r3, [r3, #0]
 8007ef4:	6a18      	ldr	r0, [r3, #32]
 8007ef6:	4b04      	ldr	r3, [pc, #16]	; (8007f08 <_localeconv_r+0x18>)
 8007ef8:	2800      	cmp	r0, #0
 8007efa:	bf08      	it	eq
 8007efc:	4618      	moveq	r0, r3
 8007efe:	30f0      	adds	r0, #240	; 0xf0
 8007f00:	4770      	bx	lr
 8007f02:	bf00      	nop
 8007f04:	20000010 	.word	0x20000010
 8007f08:	20000074 	.word	0x20000074

08007f0c <malloc>:
 8007f0c:	4b02      	ldr	r3, [pc, #8]	; (8007f18 <malloc+0xc>)
 8007f0e:	4601      	mov	r1, r0
 8007f10:	6818      	ldr	r0, [r3, #0]
 8007f12:	f000 bc71 	b.w	80087f8 <_malloc_r>
 8007f16:	bf00      	nop
 8007f18:	20000010 	.word	0x20000010

08007f1c <__ascii_mbtowc>:
 8007f1c:	b082      	sub	sp, #8
 8007f1e:	b901      	cbnz	r1, 8007f22 <__ascii_mbtowc+0x6>
 8007f20:	a901      	add	r1, sp, #4
 8007f22:	b142      	cbz	r2, 8007f36 <__ascii_mbtowc+0x1a>
 8007f24:	b14b      	cbz	r3, 8007f3a <__ascii_mbtowc+0x1e>
 8007f26:	7813      	ldrb	r3, [r2, #0]
 8007f28:	600b      	str	r3, [r1, #0]
 8007f2a:	7812      	ldrb	r2, [r2, #0]
 8007f2c:	1c10      	adds	r0, r2, #0
 8007f2e:	bf18      	it	ne
 8007f30:	2001      	movne	r0, #1
 8007f32:	b002      	add	sp, #8
 8007f34:	4770      	bx	lr
 8007f36:	4610      	mov	r0, r2
 8007f38:	e7fb      	b.n	8007f32 <__ascii_mbtowc+0x16>
 8007f3a:	f06f 0001 	mvn.w	r0, #1
 8007f3e:	e7f8      	b.n	8007f32 <__ascii_mbtowc+0x16>

08007f40 <_Balloc>:
 8007f40:	b570      	push	{r4, r5, r6, lr}
 8007f42:	6a45      	ldr	r5, [r0, #36]	; 0x24
 8007f44:	4604      	mov	r4, r0
 8007f46:	460e      	mov	r6, r1
 8007f48:	b93d      	cbnz	r5, 8007f5a <_Balloc+0x1a>
 8007f4a:	2010      	movs	r0, #16
 8007f4c:	f7ff ffde 	bl	8007f0c <malloc>
 8007f50:	6260      	str	r0, [r4, #36]	; 0x24
 8007f52:	e9c0 5501 	strd	r5, r5, [r0, #4]
 8007f56:	6005      	str	r5, [r0, #0]
 8007f58:	60c5      	str	r5, [r0, #12]
 8007f5a:	6a65      	ldr	r5, [r4, #36]	; 0x24
 8007f5c:	68eb      	ldr	r3, [r5, #12]
 8007f5e:	b183      	cbz	r3, 8007f82 <_Balloc+0x42>
 8007f60:	6a63      	ldr	r3, [r4, #36]	; 0x24
 8007f62:	68db      	ldr	r3, [r3, #12]
 8007f64:	f853 0026 	ldr.w	r0, [r3, r6, lsl #2]
 8007f68:	b9b8      	cbnz	r0, 8007f9a <_Balloc+0x5a>
 8007f6a:	2101      	movs	r1, #1
 8007f6c:	fa01 f506 	lsl.w	r5, r1, r6
 8007f70:	1d6a      	adds	r2, r5, #5
 8007f72:	0092      	lsls	r2, r2, #2
 8007f74:	4620      	mov	r0, r4
 8007f76:	f000 fbe3 	bl	8008740 <_calloc_r>
 8007f7a:	b160      	cbz	r0, 8007f96 <_Balloc+0x56>
 8007f7c:	e9c0 6501 	strd	r6, r5, [r0, #4]
 8007f80:	e00e      	b.n	8007fa0 <_Balloc+0x60>
 8007f82:	2221      	movs	r2, #33	; 0x21
 8007f84:	2104      	movs	r1, #4
 8007f86:	4620      	mov	r0, r4
 8007f88:	f000 fbda 	bl	8008740 <_calloc_r>
 8007f8c:	6a63      	ldr	r3, [r4, #36]	; 0x24
 8007f8e:	60e8      	str	r0, [r5, #12]
 8007f90:	68db      	ldr	r3, [r3, #12]
 8007f92:	2b00      	cmp	r3, #0
 8007f94:	d1e4      	bne.n	8007f60 <_Balloc+0x20>
 8007f96:	2000      	movs	r0, #0
 8007f98:	bd70      	pop	{r4, r5, r6, pc}
 8007f9a:	6802      	ldr	r2, [r0, #0]
 8007f9c:	f843 2026 	str.w	r2, [r3, r6, lsl #2]
 8007fa0:	2300      	movs	r3, #0
 8007fa2:	e9c0 3303 	strd	r3, r3, [r0, #12]
 8007fa6:	e7f7      	b.n	8007f98 <_Balloc+0x58>

08007fa8 <_Bfree>:
 8007fa8:	b570      	push	{r4, r5, r6, lr}
 8007faa:	6a44      	ldr	r4, [r0, #36]	; 0x24
 8007fac:	4606      	mov	r6, r0
 8007fae:	460d      	mov	r5, r1
 8007fb0:	b93c      	cbnz	r4, 8007fc2 <_Bfree+0x1a>
 8007fb2:	2010      	movs	r0, #16
 8007fb4:	f7ff ffaa 	bl	8007f0c <malloc>
 8007fb8:	6270      	str	r0, [r6, #36]	; 0x24
 8007fba:	e9c0 4401 	strd	r4, r4, [r0, #4]
 8007fbe:	6004      	str	r4, [r0, #0]
 8007fc0:	60c4      	str	r4, [r0, #12]
 8007fc2:	b13d      	cbz	r5, 8007fd4 <_Bfree+0x2c>
 8007fc4:	6a73      	ldr	r3, [r6, #36]	; 0x24
 8007fc6:	686a      	ldr	r2, [r5, #4]
 8007fc8:	68db      	ldr	r3, [r3, #12]
 8007fca:	f853 1022 	ldr.w	r1, [r3, r2, lsl #2]
 8007fce:	6029      	str	r1, [r5, #0]
 8007fd0:	f843 5022 	str.w	r5, [r3, r2, lsl #2]
 8007fd4:	bd70      	pop	{r4, r5, r6, pc}

08007fd6 <__multadd>:
 8007fd6:	e92d 41f0 	stmdb	sp!, {r4, r5, r6, r7, r8, lr}
 8007fda:	690d      	ldr	r5, [r1, #16]
 8007fdc:	461f      	mov	r7, r3
 8007fde:	4606      	mov	r6, r0
 8007fe0:	460c      	mov	r4, r1
 8007fe2:	f101 0c14 	add.w	ip, r1, #20
 8007fe6:	2300      	movs	r3, #0
 8007fe8:	f8dc 0000 	ldr.w	r0, [ip]
 8007fec:	b281      	uxth	r1, r0
 8007fee:	fb02 7101 	mla	r1, r2, r1, r7
 8007ff2:	0c0f      	lsrs	r7, r1, #16
 8007ff4:	0c00      	lsrs	r0, r0, #16
 8007ff6:	fb02 7000 	mla	r0, r2, r0, r7
 8007ffa:	b289      	uxth	r1, r1
 8007ffc:	3301      	adds	r3, #1
 8007ffe:	eb01 4100 	add.w	r1, r1, r0, lsl #16
 8008002:	429d      	cmp	r5, r3
 8008004:	ea4f 4710 	mov.w	r7, r0, lsr #16
 8008008:	f84c 1b04 	str.w	r1, [ip], #4
 800800c:	dcec      	bgt.n	8007fe8 <__multadd+0x12>
 800800e:	b1d7      	cbz	r7, 8008046 <__multadd+0x70>
 8008010:	68a3      	ldr	r3, [r4, #8]
 8008012:	42ab      	cmp	r3, r5
 8008014:	dc12      	bgt.n	800803c <__multadd+0x66>
 8008016:	6861      	ldr	r1, [r4, #4]
 8008018:	4630      	mov	r0, r6
 800801a:	3101      	adds	r1, #1
 800801c:	f7ff ff90 	bl	8007f40 <_Balloc>
 8008020:	6922      	ldr	r2, [r4, #16]
 8008022:	3202      	adds	r2, #2
 8008024:	f104 010c 	add.w	r1, r4, #12
 8008028:	4680      	mov	r8, r0
 800802a:	0092      	lsls	r2, r2, #2
 800802c:	300c      	adds	r0, #12
 800802e:	f7fd f98f 	bl	8005350 <memcpy>
 8008032:	4621      	mov	r1, r4
 8008034:	4630      	mov	r0, r6
 8008036:	f7ff ffb7 	bl	8007fa8 <_Bfree>
 800803a:	4644      	mov	r4, r8
 800803c:	eb04 0385 	add.w	r3, r4, r5, lsl #2
 8008040:	3501      	adds	r5, #1
 8008042:	615f      	str	r7, [r3, #20]
 8008044:	6125      	str	r5, [r4, #16]
 8008046:	4620      	mov	r0, r4
 8008048:	e8bd 81f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, pc}

0800804c <__s2b>:
 800804c:	e92d 43f8 	stmdb	sp!, {r3, r4, r5, r6, r7, r8, r9, lr}
 8008050:	460c      	mov	r4, r1
 8008052:	4615      	mov	r5, r2
 8008054:	461f      	mov	r7, r3
 8008056:	2209      	movs	r2, #9
 8008058:	3308      	adds	r3, #8
 800805a:	4606      	mov	r6, r0
 800805c:	fb93 f3f2 	sdiv	r3, r3, r2
 8008060:	2100      	movs	r1, #0
 8008062:	2201      	movs	r2, #1
 8008064:	429a      	cmp	r2, r3
 8008066:	db20      	blt.n	80080aa <__s2b+0x5e>
 8008068:	4630      	mov	r0, r6
 800806a:	f7ff ff69 	bl	8007f40 <_Balloc>
 800806e:	9b08      	ldr	r3, [sp, #32]
 8008070:	6143      	str	r3, [r0, #20]
 8008072:	2d09      	cmp	r5, #9
 8008074:	f04f 0301 	mov.w	r3, #1
 8008078:	6103      	str	r3, [r0, #16]
 800807a:	dd19      	ble.n	80080b0 <__s2b+0x64>
 800807c:	f104 0809 	add.w	r8, r4, #9
 8008080:	46c1      	mov	r9, r8
 8008082:	442c      	add	r4, r5
 8008084:	f819 3b01 	ldrb.w	r3, [r9], #1
 8008088:	4601      	mov	r1, r0
 800808a:	3b30      	subs	r3, #48	; 0x30
 800808c:	220a      	movs	r2, #10
 800808e:	4630      	mov	r0, r6
 8008090:	f7ff ffa1 	bl	8007fd6 <__multadd>
 8008094:	45a1      	cmp	r9, r4
 8008096:	d1f5      	bne.n	8008084 <__s2b+0x38>
 8008098:	eb08 0405 	add.w	r4, r8, r5
 800809c:	3c08      	subs	r4, #8
 800809e:	1b2d      	subs	r5, r5, r4
 80080a0:	1963      	adds	r3, r4, r5
 80080a2:	42bb      	cmp	r3, r7
 80080a4:	db07      	blt.n	80080b6 <__s2b+0x6a>
 80080a6:	e8bd 83f8 	ldmia.w	sp!, {r3, r4, r5, r6, r7, r8, r9, pc}
 80080aa:	0052      	lsls	r2, r2, #1
 80080ac:	3101      	adds	r1, #1
 80080ae:	e7d9      	b.n	8008064 <__s2b+0x18>
 80080b0:	340a      	adds	r4, #10
 80080b2:	2509      	movs	r5, #9
 80080b4:	e7f3      	b.n	800809e <__s2b+0x52>
 80080b6:	f814 3b01 	ldrb.w	r3, [r4], #1
 80080ba:	4601      	mov	r1, r0
 80080bc:	3b30      	subs	r3, #48	; 0x30
 80080be:	220a      	movs	r2, #10
 80080c0:	4630      	mov	r0, r6
 80080c2:	f7ff ff88 	bl	8007fd6 <__multadd>
 80080c6:	e7eb      	b.n	80080a0 <__s2b+0x54>

080080c8 <__hi0bits>:
 80080c8:	0c02      	lsrs	r2, r0, #16
 80080ca:	0412      	lsls	r2, r2, #16
 80080cc:	4603      	mov	r3, r0
 80080ce:	b9b2      	cbnz	r2, 80080fe <__hi0bits+0x36>
 80080d0:	0403      	lsls	r3, r0, #16
 80080d2:	2010      	movs	r0, #16
 80080d4:	f013 4f7f 	tst.w	r3, #4278190080	; 0xff000000
 80080d8:	bf04      	itt	eq
 80080da:	021b      	lsleq	r3, r3, #8
 80080dc:	3008      	addeq	r0, #8
 80080de:	f013 4f70 	tst.w	r3, #4026531840	; 0xf0000000
 80080e2:	bf04      	itt	eq
 80080e4:	011b      	lsleq	r3, r3, #4
 80080e6:	3004      	addeq	r0, #4
 80080e8:	f013 4f40 	tst.w	r3, #3221225472	; 0xc0000000
 80080ec:	bf04      	itt	eq
 80080ee:	009b      	lsleq	r3, r3, #2
 80080f0:	3002      	addeq	r0, #2
 80080f2:	2b00      	cmp	r3, #0
 80080f4:	db06      	blt.n	8008104 <__hi0bits+0x3c>
 80080f6:	005b      	lsls	r3, r3, #1
 80080f8:	d503      	bpl.n	8008102 <__hi0bits+0x3a>
 80080fa:	3001      	adds	r0, #1
 80080fc:	4770      	bx	lr
 80080fe:	2000      	movs	r0, #0
 8008100:	e7e8      	b.n	80080d4 <__hi0bits+0xc>
 8008102:	2020      	movs	r0, #32
 8008104:	4770      	bx	lr

08008106 <__lo0bits>:
 8008106:	6803      	ldr	r3, [r0, #0]
 8008108:	f013 0207 	ands.w	r2, r3, #7
 800810c:	4601      	mov	r1, r0
 800810e:	d00b      	beq.n	8008128 <__lo0bits+0x22>
 8008110:	07da      	lsls	r2, r3, #31
 8008112:	d423      	bmi.n	800815c <__lo0bits+0x56>
 8008114:	0798      	lsls	r0, r3, #30
 8008116:	bf49      	itett	mi
 8008118:	085b      	lsrmi	r3, r3, #1
 800811a:	089b      	lsrpl	r3, r3, #2
 800811c:	2001      	movmi	r0, #1
 800811e:	600b      	strmi	r3, [r1, #0]
 8008120:	bf5c      	itt	pl
 8008122:	600b      	strpl	r3, [r1, #0]
 8008124:	2002      	movpl	r0, #2
 8008126:	4770      	bx	lr
 8008128:	b298      	uxth	r0, r3
 800812a:	b9a8      	cbnz	r0, 8008158 <__lo0bits+0x52>
 800812c:	0c1b      	lsrs	r3, r3, #16
 800812e:	2010      	movs	r0, #16
 8008130:	f013 0fff 	tst.w	r3, #255	; 0xff
 8008134:	bf04      	itt	eq
 8008136:	0a1b      	lsreq	r3, r3, #8
 8008138:	3008      	addeq	r0, #8
 800813a:	071a      	lsls	r2, r3, #28
 800813c:	bf04      	itt	eq
 800813e:	091b      	lsreq	r3, r3, #4
 8008140:	3004      	addeq	r0, #4
 8008142:	079a      	lsls	r2, r3, #30
 8008144:	bf04      	itt	eq
 8008146:	089b      	lsreq	r3, r3, #2
 8008148:	3002      	addeq	r0, #2
 800814a:	07da      	lsls	r2, r3, #31
 800814c:	d402      	bmi.n	8008154 <__lo0bits+0x4e>
 800814e:	085b      	lsrs	r3, r3, #1
 8008150:	d006      	beq.n	8008160 <__lo0bits+0x5a>
 8008152:	3001      	adds	r0, #1
 8008154:	600b      	str	r3, [r1, #0]
 8008156:	4770      	bx	lr
 8008158:	4610      	mov	r0, r2
 800815a:	e7e9      	b.n	8008130 <__lo0bits+0x2a>
 800815c:	2000      	movs	r0, #0
 800815e:	4770      	bx	lr
 8008160:	2020      	movs	r0, #32
 8008162:	4770      	bx	lr

08008164 <__i2b>:
 8008164:	b510      	push	{r4, lr}
 8008166:	460c      	mov	r4, r1
 8008168:	2101      	movs	r1, #1
 800816a:	f7ff fee9 	bl	8007f40 <_Balloc>
 800816e:	2201      	movs	r2, #1
 8008170:	6144      	str	r4, [r0, #20]
 8008172:	6102      	str	r2, [r0, #16]
 8008174:	bd10      	pop	{r4, pc}

08008176 <__multiply>:
 8008176:	e92d 4ff7 	stmdb	sp!, {r0, r1, r2, r4, r5, r6, r7, r8, r9, sl, fp, lr}
 800817a:	4614      	mov	r4, r2
 800817c:	690a      	ldr	r2, [r1, #16]
 800817e:	6923      	ldr	r3, [r4, #16]
 8008180:	429a      	cmp	r2, r3
 8008182:	bfb8      	it	lt
 8008184:	460b      	movlt	r3, r1
 8008186:	4688      	mov	r8, r1
 8008188:	bfbc      	itt	lt
 800818a:	46a0      	movlt	r8, r4
 800818c:	461c      	movlt	r4, r3
 800818e:	f8d8 7010 	ldr.w	r7, [r8, #16]
 8008192:	f8d4 9010 	ldr.w	r9, [r4, #16]
 8008196:	f8d8 3008 	ldr.w	r3, [r8, #8]
 800819a:	f8d8 1004 	ldr.w	r1, [r8, #4]
 800819e:	eb07 0609 	add.w	r6, r7, r9
 80081a2:	42b3      	cmp	r3, r6
 80081a4:	bfb8      	it	lt
 80081a6:	3101      	addlt	r1, #1
 80081a8:	f7ff feca 	bl	8007f40 <_Balloc>
 80081ac:	f100 0514 	add.w	r5, r0, #20
 80081b0:	eb05 0e86 	add.w	lr, r5, r6, lsl #2
 80081b4:	462b      	mov	r3, r5
 80081b6:	2200      	movs	r2, #0
 80081b8:	4573      	cmp	r3, lr
 80081ba:	d316      	bcc.n	80081ea <__multiply+0x74>
 80081bc:	f104 0214 	add.w	r2, r4, #20
 80081c0:	f108 0114 	add.w	r1, r8, #20
 80081c4:	eb02 0389 	add.w	r3, r2, r9, lsl #2
 80081c8:	eb01 0787 	add.w	r7, r1, r7, lsl #2
 80081cc:	9300      	str	r3, [sp, #0]
 80081ce:	9b00      	ldr	r3, [sp, #0]
 80081d0:	9201      	str	r2, [sp, #4]
 80081d2:	4293      	cmp	r3, r2
 80081d4:	d80c      	bhi.n	80081f0 <__multiply+0x7a>
 80081d6:	2e00      	cmp	r6, #0
 80081d8:	dd03      	ble.n	80081e2 <__multiply+0x6c>
 80081da:	f85e 3d04 	ldr.w	r3, [lr, #-4]!
 80081de:	2b00      	cmp	r3, #0
 80081e0:	d05d      	beq.n	800829e <__multiply+0x128>
 80081e2:	6106      	str	r6, [r0, #16]
 80081e4:	b003      	add	sp, #12
 80081e6:	e8bd 8ff0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, pc}
 80081ea:	f843 2b04 	str.w	r2, [r3], #4
 80081ee:	e7e3      	b.n	80081b8 <__multiply+0x42>
 80081f0:	f8b2 b000 	ldrh.w	fp, [r2]
 80081f4:	f1bb 0f00 	cmp.w	fp, #0
 80081f8:	d023      	beq.n	8008242 <__multiply+0xcc>
 80081fa:	4689      	mov	r9, r1
 80081fc:	46ac      	mov	ip, r5
 80081fe:	f04f 0800 	mov.w	r8, #0
 8008202:	f859 4b04 	ldr.w	r4, [r9], #4
 8008206:	f8dc a000 	ldr.w	sl, [ip]
 800820a:	b2a3      	uxth	r3, r4
 800820c:	fa1f fa8a 	uxth.w	sl, sl
 8008210:	fb0b a303 	mla	r3, fp, r3, sl
 8008214:	ea4f 4a14 	mov.w	sl, r4, lsr #16
 8008218:	f8dc 4000 	ldr.w	r4, [ip]
 800821c:	4443      	add	r3, r8
 800821e:	ea4f 4814 	mov.w	r8, r4, lsr #16
 8008222:	fb0b 840a 	mla	r4, fp, sl, r8
 8008226:	eb04 4413 	add.w	r4, r4, r3, lsr #16
 800822a:	46e2      	mov	sl, ip
 800822c:	b29b      	uxth	r3, r3
 800822e:	ea43 4304 	orr.w	r3, r3, r4, lsl #16
 8008232:	454f      	cmp	r7, r9
 8008234:	ea4f 4814 	mov.w	r8, r4, lsr #16
 8008238:	f84a 3b04 	str.w	r3, [sl], #4
 800823c:	d82b      	bhi.n	8008296 <__multiply+0x120>
 800823e:	f8cc 8004 	str.w	r8, [ip, #4]
 8008242:	9b01      	ldr	r3, [sp, #4]
 8008244:	f8b3 a002 	ldrh.w	sl, [r3, #2]
 8008248:	3204      	adds	r2, #4
 800824a:	f1ba 0f00 	cmp.w	sl, #0
 800824e:	d020      	beq.n	8008292 <__multiply+0x11c>
 8008250:	682b      	ldr	r3, [r5, #0]
 8008252:	4689      	mov	r9, r1
 8008254:	46a8      	mov	r8, r5
 8008256:	f04f 0b00 	mov.w	fp, #0
 800825a:	f8b9 c000 	ldrh.w	ip, [r9]
 800825e:	f8b8 4002 	ldrh.w	r4, [r8, #2]
 8008262:	fb0a 440c 	mla	r4, sl, ip, r4
 8008266:	445c      	add	r4, fp
 8008268:	46c4      	mov	ip, r8
 800826a:	b29b      	uxth	r3, r3
 800826c:	ea43 4304 	orr.w	r3, r3, r4, lsl #16
 8008270:	f84c 3b04 	str.w	r3, [ip], #4
 8008274:	f859 3b04 	ldr.w	r3, [r9], #4
 8008278:	f8b8 b004 	ldrh.w	fp, [r8, #4]
 800827c:	0c1b      	lsrs	r3, r3, #16
 800827e:	fb0a b303 	mla	r3, sl, r3, fp
 8008282:	eb03 4314 	add.w	r3, r3, r4, lsr #16
 8008286:	454f      	cmp	r7, r9
 8008288:	ea4f 4b13 	mov.w	fp, r3, lsr #16
 800828c:	d805      	bhi.n	800829a <__multiply+0x124>
 800828e:	f8c8 3004 	str.w	r3, [r8, #4]
 8008292:	3504      	adds	r5, #4
 8008294:	e79b      	b.n	80081ce <__multiply+0x58>
 8008296:	46d4      	mov	ip, sl
 8008298:	e7b3      	b.n	8008202 <__multiply+0x8c>
 800829a:	46e0      	mov	r8, ip
 800829c:	e7dd      	b.n	800825a <__multiply+0xe4>
 800829e:	3e01      	subs	r6, #1
 80082a0:	e799      	b.n	80081d6 <__multiply+0x60>
	...

080082a4 <__pow5mult>:
 80082a4:	e92d 43f8 	stmdb	sp!, {r3, r4, r5, r6, r7, r8, r9, lr}
 80082a8:	4615      	mov	r5, r2
 80082aa:	f012 0203 	ands.w	r2, r2, #3
 80082ae:	4606      	mov	r6, r0
 80082b0:	460f      	mov	r7, r1
 80082b2:	d007      	beq.n	80082c4 <__pow5mult+0x20>
 80082b4:	3a01      	subs	r2, #1
 80082b6:	4c21      	ldr	r4, [pc, #132]	; (800833c <__pow5mult+0x98>)
 80082b8:	2300      	movs	r3, #0
 80082ba:	f854 2022 	ldr.w	r2, [r4, r2, lsl #2]
 80082be:	f7ff fe8a 	bl	8007fd6 <__multadd>
 80082c2:	4607      	mov	r7, r0
 80082c4:	10ad      	asrs	r5, r5, #2
 80082c6:	d035      	beq.n	8008334 <__pow5mult+0x90>
 80082c8:	6a74      	ldr	r4, [r6, #36]	; 0x24
 80082ca:	b93c      	cbnz	r4, 80082dc <__pow5mult+0x38>
 80082cc:	2010      	movs	r0, #16
 80082ce:	f7ff fe1d 	bl	8007f0c <malloc>
 80082d2:	6270      	str	r0, [r6, #36]	; 0x24
 80082d4:	e9c0 4401 	strd	r4, r4, [r0, #4]
 80082d8:	6004      	str	r4, [r0, #0]
 80082da:	60c4      	str	r4, [r0, #12]
 80082dc:	f8d6 8024 	ldr.w	r8, [r6, #36]	; 0x24
 80082e0:	f8d8 4008 	ldr.w	r4, [r8, #8]
 80082e4:	b94c      	cbnz	r4, 80082fa <__pow5mult+0x56>
 80082e6:	f240 2171 	movw	r1, #625	; 0x271
 80082ea:	4630      	mov	r0, r6
 80082ec:	f7ff ff3a 	bl	8008164 <__i2b>
 80082f0:	2300      	movs	r3, #0
 80082f2:	f8c8 0008 	str.w	r0, [r8, #8]
 80082f6:	4604      	mov	r4, r0
 80082f8:	6003      	str	r3, [r0, #0]
 80082fa:	f04f 0800 	mov.w	r8, #0
 80082fe:	07eb      	lsls	r3, r5, #31
 8008300:	d50a      	bpl.n	8008318 <__pow5mult+0x74>
 8008302:	4639      	mov	r1, r7
 8008304:	4622      	mov	r2, r4
 8008306:	4630      	mov	r0, r6
 8008308:	f7ff ff35 	bl	8008176 <__multiply>
 800830c:	4639      	mov	r1, r7
 800830e:	4681      	mov	r9, r0
 8008310:	4630      	mov	r0, r6
 8008312:	f7ff fe49 	bl	8007fa8 <_Bfree>
 8008316:	464f      	mov	r7, r9
 8008318:	106d      	asrs	r5, r5, #1
 800831a:	d00b      	beq.n	8008334 <__pow5mult+0x90>
 800831c:	6820      	ldr	r0, [r4, #0]
 800831e:	b938      	cbnz	r0, 8008330 <__pow5mult+0x8c>
 8008320:	4622      	mov	r2, r4
 8008322:	4621      	mov	r1, r4
 8008324:	4630      	mov	r0, r6
 8008326:	f7ff ff26 	bl	8008176 <__multiply>
 800832a:	6020      	str	r0, [r4, #0]
 800832c:	f8c0 8000 	str.w	r8, [r0]
 8008330:	4604      	mov	r4, r0
 8008332:	e7e4      	b.n	80082fe <__pow5mult+0x5a>
 8008334:	4638      	mov	r0, r7
 8008336:	e8bd 83f8 	ldmia.w	sp!, {r3, r4, r5, r6, r7, r8, r9, pc}
 800833a:	bf00      	nop
 800833c:	0802e850 	.word	0x0802e850

08008340 <__lshift>:
 8008340:	e92d 47f0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, lr}
 8008344:	460c      	mov	r4, r1
 8008346:	ea4f 1a62 	mov.w	sl, r2, asr #5
 800834a:	6923      	ldr	r3, [r4, #16]
 800834c:	6849      	ldr	r1, [r1, #4]
 800834e:	eb0a 0903 	add.w	r9, sl, r3
 8008352:	68a3      	ldr	r3, [r4, #8]
 8008354:	4607      	mov	r7, r0
 8008356:	4616      	mov	r6, r2
 8008358:	f109 0501 	add.w	r5, r9, #1
 800835c:	42ab      	cmp	r3, r5
 800835e:	db32      	blt.n	80083c6 <__lshift+0x86>
 8008360:	4638      	mov	r0, r7
 8008362:	f7ff fded 	bl	8007f40 <_Balloc>
 8008366:	2300      	movs	r3, #0
 8008368:	4680      	mov	r8, r0
 800836a:	f100 0114 	add.w	r1, r0, #20
 800836e:	461a      	mov	r2, r3
 8008370:	4553      	cmp	r3, sl
 8008372:	db2b      	blt.n	80083cc <__lshift+0x8c>
 8008374:	6920      	ldr	r0, [r4, #16]
 8008376:	ea2a 7aea 	bic.w	sl, sl, sl, asr #31
 800837a:	f104 0314 	add.w	r3, r4, #20
 800837e:	f016 021f 	ands.w	r2, r6, #31
 8008382:	eb01 018a 	add.w	r1, r1, sl, lsl #2
 8008386:	eb03 0c80 	add.w	ip, r3, r0, lsl #2
 800838a:	d025      	beq.n	80083d8 <__lshift+0x98>
 800838c:	f1c2 0e20 	rsb	lr, r2, #32
 8008390:	2000      	movs	r0, #0
 8008392:	681e      	ldr	r6, [r3, #0]
 8008394:	468a      	mov	sl, r1
 8008396:	4096      	lsls	r6, r2
 8008398:	4330      	orrs	r0, r6
 800839a:	f84a 0b04 	str.w	r0, [sl], #4
 800839e:	f853 0b04 	ldr.w	r0, [r3], #4
 80083a2:	459c      	cmp	ip, r3
 80083a4:	fa20 f00e 	lsr.w	r0, r0, lr
 80083a8:	d814      	bhi.n	80083d4 <__lshift+0x94>
 80083aa:	6048      	str	r0, [r1, #4]
 80083ac:	b108      	cbz	r0, 80083b2 <__lshift+0x72>
 80083ae:	f109 0502 	add.w	r5, r9, #2
 80083b2:	3d01      	subs	r5, #1
 80083b4:	4638      	mov	r0, r7
 80083b6:	f8c8 5010 	str.w	r5, [r8, #16]
 80083ba:	4621      	mov	r1, r4
 80083bc:	f7ff fdf4 	bl	8007fa8 <_Bfree>
 80083c0:	4640      	mov	r0, r8
 80083c2:	e8bd 87f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, pc}
 80083c6:	3101      	adds	r1, #1
 80083c8:	005b      	lsls	r3, r3, #1
 80083ca:	e7c7      	b.n	800835c <__lshift+0x1c>
 80083cc:	f841 2023 	str.w	r2, [r1, r3, lsl #2]
 80083d0:	3301      	adds	r3, #1
 80083d2:	e7cd      	b.n	8008370 <__lshift+0x30>
 80083d4:	4651      	mov	r1, sl
 80083d6:	e7dc      	b.n	8008392 <__lshift+0x52>
 80083d8:	3904      	subs	r1, #4
 80083da:	f853 2b04 	ldr.w	r2, [r3], #4
 80083de:	f841 2f04 	str.w	r2, [r1, #4]!
 80083e2:	459c      	cmp	ip, r3
 80083e4:	d8f9      	bhi.n	80083da <__lshift+0x9a>
 80083e6:	e7e4      	b.n	80083b2 <__lshift+0x72>

080083e8 <__mcmp>:
 80083e8:	6903      	ldr	r3, [r0, #16]
 80083ea:	690a      	ldr	r2, [r1, #16]
 80083ec:	1a9b      	subs	r3, r3, r2
 80083ee:	b530      	push	{r4, r5, lr}
 80083f0:	d10c      	bne.n	800840c <__mcmp+0x24>
 80083f2:	0092      	lsls	r2, r2, #2
 80083f4:	3014      	adds	r0, #20
 80083f6:	3114      	adds	r1, #20
 80083f8:	1884      	adds	r4, r0, r2
 80083fa:	4411      	add	r1, r2
 80083fc:	f854 5d04 	ldr.w	r5, [r4, #-4]!
 8008400:	f851 2d04 	ldr.w	r2, [r1, #-4]!
 8008404:	4295      	cmp	r5, r2
 8008406:	d003      	beq.n	8008410 <__mcmp+0x28>
 8008408:	d305      	bcc.n	8008416 <__mcmp+0x2e>
 800840a:	2301      	movs	r3, #1
 800840c:	4618      	mov	r0, r3
 800840e:	bd30      	pop	{r4, r5, pc}
 8008410:	42a0      	cmp	r0, r4
 8008412:	d3f3      	bcc.n	80083fc <__mcmp+0x14>
 8008414:	e7fa      	b.n	800840c <__mcmp+0x24>
 8008416:	f04f 33ff 	mov.w	r3, #4294967295	; 0xffffffff
 800841a:	e7f7      	b.n	800840c <__mcmp+0x24>

0800841c <__mdiff>:
 800841c:	e92d 47f0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, lr}
 8008420:	460d      	mov	r5, r1
 8008422:	4607      	mov	r7, r0
 8008424:	4611      	mov	r1, r2
 8008426:	4628      	mov	r0, r5
 8008428:	4614      	mov	r4, r2
 800842a:	f7ff ffdd 	bl	80083e8 <__mcmp>
 800842e:	1e06      	subs	r6, r0, #0
 8008430:	d108      	bne.n	8008444 <__mdiff+0x28>
 8008432:	4631      	mov	r1, r6
 8008434:	4638      	mov	r0, r7
 8008436:	f7ff fd83 	bl	8007f40 <_Balloc>
 800843a:	2301      	movs	r3, #1
 800843c:	e9c0 3604 	strd	r3, r6, [r0, #16]
 8008440:	e8bd 87f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, pc}
 8008444:	bfa4      	itt	ge
 8008446:	4623      	movge	r3, r4
 8008448:	462c      	movge	r4, r5
 800844a:	4638      	mov	r0, r7
 800844c:	6861      	ldr	r1, [r4, #4]
 800844e:	bfa6      	itte	ge
 8008450:	461d      	movge	r5, r3
 8008452:	2600      	movge	r6, #0
 8008454:	2601      	movlt	r6, #1
 8008456:	f7ff fd73 	bl	8007f40 <_Balloc>
 800845a:	692b      	ldr	r3, [r5, #16]
 800845c:	60c6      	str	r6, [r0, #12]
 800845e:	6926      	ldr	r6, [r4, #16]
 8008460:	f105 0914 	add.w	r9, r5, #20
 8008464:	f104 0214 	add.w	r2, r4, #20
 8008468:	eb02 0786 	add.w	r7, r2, r6, lsl #2
 800846c:	eb09 0883 	add.w	r8, r9, r3, lsl #2
 8008470:	f100 0514 	add.w	r5, r0, #20
 8008474:	f04f 0e00 	mov.w	lr, #0
 8008478:	f852 ab04 	ldr.w	sl, [r2], #4
 800847c:	f859 4b04 	ldr.w	r4, [r9], #4
 8008480:	fa1e f18a 	uxtah	r1, lr, sl
 8008484:	b2a3      	uxth	r3, r4
 8008486:	1ac9      	subs	r1, r1, r3
 8008488:	0c23      	lsrs	r3, r4, #16
 800848a:	ebc3 431a 	rsb	r3, r3, sl, lsr #16
 800848e:	eb03 4321 	add.w	r3, r3, r1, asr #16
 8008492:	b289      	uxth	r1, r1
 8008494:	ea4f 4e23 	mov.w	lr, r3, asr #16
 8008498:	45c8      	cmp	r8, r9
 800849a:	ea41 4303 	orr.w	r3, r1, r3, lsl #16
 800849e:	4694      	mov	ip, r2
 80084a0:	f845 3b04 	str.w	r3, [r5], #4
 80084a4:	d8e8      	bhi.n	8008478 <__mdiff+0x5c>
 80084a6:	45bc      	cmp	ip, r7
 80084a8:	d304      	bcc.n	80084b4 <__mdiff+0x98>
 80084aa:	f855 3d04 	ldr.w	r3, [r5, #-4]!
 80084ae:	b183      	cbz	r3, 80084d2 <__mdiff+0xb6>
 80084b0:	6106      	str	r6, [r0, #16]
 80084b2:	e7c5      	b.n	8008440 <__mdiff+0x24>
 80084b4:	f85c 1b04 	ldr.w	r1, [ip], #4
 80084b8:	fa1e f381 	uxtah	r3, lr, r1
 80084bc:	141a      	asrs	r2, r3, #16
 80084be:	eb02 4211 	add.w	r2, r2, r1, lsr #16
 80084c2:	b29b      	uxth	r3, r3
 80084c4:	ea43 4302 	orr.w	r3, r3, r2, lsl #16
 80084c8:	ea4f 4e22 	mov.w	lr, r2, asr #16
 80084cc:	f845 3b04 	str.w	r3, [r5], #4
 80084d0:	e7e9      	b.n	80084a6 <__mdiff+0x8a>
 80084d2:	3e01      	subs	r6, #1
 80084d4:	e7e9      	b.n	80084aa <__mdiff+0x8e>
	...

080084d8 <__ulp>:
 80084d8:	4b12      	ldr	r3, [pc, #72]	; (8008524 <__ulp+0x4c>)
 80084da:	ee10 2a90 	vmov	r2, s1
 80084de:	401a      	ands	r2, r3
 80084e0:	f1a2 7350 	sub.w	r3, r2, #54525952	; 0x3400000
 80084e4:	2b00      	cmp	r3, #0
 80084e6:	dd04      	ble.n	80084f2 <__ulp+0x1a>
 80084e8:	2000      	movs	r0, #0
 80084ea:	4619      	mov	r1, r3
 80084ec:	ec41 0b10 	vmov	d0, r0, r1
 80084f0:	4770      	bx	lr
 80084f2:	425b      	negs	r3, r3
 80084f4:	151b      	asrs	r3, r3, #20
 80084f6:	2b13      	cmp	r3, #19
 80084f8:	f04f 0000 	mov.w	r0, #0
 80084fc:	f04f 0100 	mov.w	r1, #0
 8008500:	dc04      	bgt.n	800850c <__ulp+0x34>
 8008502:	f44f 2200 	mov.w	r2, #524288	; 0x80000
 8008506:	fa42 f103 	asr.w	r1, r2, r3
 800850a:	e7ef      	b.n	80084ec <__ulp+0x14>
 800850c:	3b14      	subs	r3, #20
 800850e:	2b1e      	cmp	r3, #30
 8008510:	f04f 0201 	mov.w	r2, #1
 8008514:	bfda      	itte	le
 8008516:	f1c3 031f 	rsble	r3, r3, #31
 800851a:	fa02 f303 	lslle.w	r3, r2, r3
 800851e:	4613      	movgt	r3, r2
 8008520:	4618      	mov	r0, r3
 8008522:	e7e3      	b.n	80084ec <__ulp+0x14>
 8008524:	7ff00000 	.word	0x7ff00000

08008528 <__b2d>:
 8008528:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 800852a:	6905      	ldr	r5, [r0, #16]
 800852c:	f100 0714 	add.w	r7, r0, #20
 8008530:	eb07 0585 	add.w	r5, r7, r5, lsl #2
 8008534:	1f2e      	subs	r6, r5, #4
 8008536:	f855 4c04 	ldr.w	r4, [r5, #-4]
 800853a:	4620      	mov	r0, r4
 800853c:	f7ff fdc4 	bl	80080c8 <__hi0bits>
 8008540:	f1c0 0320 	rsb	r3, r0, #32
 8008544:	280a      	cmp	r0, #10
 8008546:	600b      	str	r3, [r1, #0]
 8008548:	f8df c074 	ldr.w	ip, [pc, #116]	; 80085c0 <__b2d+0x98>
 800854c:	dc14      	bgt.n	8008578 <__b2d+0x50>
 800854e:	f1c0 0e0b 	rsb	lr, r0, #11
 8008552:	fa24 f10e 	lsr.w	r1, r4, lr
 8008556:	42b7      	cmp	r7, r6
 8008558:	ea41 030c 	orr.w	r3, r1, ip
 800855c:	bf34      	ite	cc
 800855e:	f855 1c08 	ldrcc.w	r1, [r5, #-8]
 8008562:	2100      	movcs	r1, #0
 8008564:	3015      	adds	r0, #21
 8008566:	fa04 f000 	lsl.w	r0, r4, r0
 800856a:	fa21 f10e 	lsr.w	r1, r1, lr
 800856e:	ea40 0201 	orr.w	r2, r0, r1
 8008572:	ec43 2b10 	vmov	d0, r2, r3
 8008576:	bdf8      	pop	{r3, r4, r5, r6, r7, pc}
 8008578:	42b7      	cmp	r7, r6
 800857a:	bf3a      	itte	cc
 800857c:	f1a5 0608 	subcc.w	r6, r5, #8
 8008580:	f855 1c08 	ldrcc.w	r1, [r5, #-8]
 8008584:	2100      	movcs	r1, #0
 8008586:	380b      	subs	r0, #11
 8008588:	d015      	beq.n	80085b6 <__b2d+0x8e>
 800858a:	4084      	lsls	r4, r0
 800858c:	f1c0 0520 	rsb	r5, r0, #32
 8008590:	f044 547f 	orr.w	r4, r4, #1069547520	; 0x3fc00000
 8008594:	f444 1440 	orr.w	r4, r4, #3145728	; 0x300000
 8008598:	42be      	cmp	r6, r7
 800859a:	fa21 fc05 	lsr.w	ip, r1, r5
 800859e:	ea44 030c 	orr.w	r3, r4, ip
 80085a2:	bf8c      	ite	hi
 80085a4:	f856 4c04 	ldrhi.w	r4, [r6, #-4]
 80085a8:	2400      	movls	r4, #0
 80085aa:	fa01 f000 	lsl.w	r0, r1, r0
 80085ae:	40ec      	lsrs	r4, r5
 80085b0:	ea40 0204 	orr.w	r2, r0, r4
 80085b4:	e7dd      	b.n	8008572 <__b2d+0x4a>
 80085b6:	ea44 030c 	orr.w	r3, r4, ip
 80085ba:	460a      	mov	r2, r1
 80085bc:	e7d9      	b.n	8008572 <__b2d+0x4a>
 80085be:	bf00      	nop
 80085c0:	3ff00000 	.word	0x3ff00000

080085c4 <__d2b>:
 80085c4:	e92d 43f7 	stmdb	sp!, {r0, r1, r2, r4, r5, r6, r7, r8, r9, lr}
 80085c8:	460e      	mov	r6, r1
 80085ca:	2101      	movs	r1, #1
 80085cc:	ec59 8b10 	vmov	r8, r9, d0
 80085d0:	4615      	mov	r5, r2
 80085d2:	f7ff fcb5 	bl	8007f40 <_Balloc>
 80085d6:	f3c9 540a 	ubfx	r4, r9, #20, #11
 80085da:	4607      	mov	r7, r0
 80085dc:	f3c9 0313 	ubfx	r3, r9, #0, #20
 80085e0:	bb34      	cbnz	r4, 8008630 <__d2b+0x6c>
 80085e2:	9301      	str	r3, [sp, #4]
 80085e4:	f1b8 0300 	subs.w	r3, r8, #0
 80085e8:	d027      	beq.n	800863a <__d2b+0x76>
 80085ea:	a802      	add	r0, sp, #8
 80085ec:	f840 3d08 	str.w	r3, [r0, #-8]!
 80085f0:	f7ff fd89 	bl	8008106 <__lo0bits>
 80085f4:	9900      	ldr	r1, [sp, #0]
 80085f6:	b1f0      	cbz	r0, 8008636 <__d2b+0x72>
 80085f8:	9a01      	ldr	r2, [sp, #4]
 80085fa:	f1c0 0320 	rsb	r3, r0, #32
 80085fe:	fa02 f303 	lsl.w	r3, r2, r3
 8008602:	430b      	orrs	r3, r1
 8008604:	40c2      	lsrs	r2, r0
 8008606:	617b      	str	r3, [r7, #20]
 8008608:	9201      	str	r2, [sp, #4]
 800860a:	9b01      	ldr	r3, [sp, #4]
 800860c:	61bb      	str	r3, [r7, #24]
 800860e:	2b00      	cmp	r3, #0
 8008610:	bf14      	ite	ne
 8008612:	2102      	movne	r1, #2
 8008614:	2101      	moveq	r1, #1
 8008616:	6139      	str	r1, [r7, #16]
 8008618:	b1c4      	cbz	r4, 800864c <__d2b+0x88>
 800861a:	f2a4 4433 	subw	r4, r4, #1075	; 0x433
 800861e:	4404      	add	r4, r0
 8008620:	6034      	str	r4, [r6, #0]
 8008622:	f1c0 0035 	rsb	r0, r0, #53	; 0x35
 8008626:	6028      	str	r0, [r5, #0]
 8008628:	4638      	mov	r0, r7
 800862a:	b003      	add	sp, #12
 800862c:	e8bd 83f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, pc}
 8008630:	f443 1380 	orr.w	r3, r3, #1048576	; 0x100000
 8008634:	e7d5      	b.n	80085e2 <__d2b+0x1e>
 8008636:	6179      	str	r1, [r7, #20]
 8008638:	e7e7      	b.n	800860a <__d2b+0x46>
 800863a:	a801      	add	r0, sp, #4
 800863c:	f7ff fd63 	bl	8008106 <__lo0bits>
 8008640:	9b01      	ldr	r3, [sp, #4]
 8008642:	617b      	str	r3, [r7, #20]
 8008644:	2101      	movs	r1, #1
 8008646:	6139      	str	r1, [r7, #16]
 8008648:	3020      	adds	r0, #32
 800864a:	e7e5      	b.n	8008618 <__d2b+0x54>
 800864c:	eb07 0381 	add.w	r3, r7, r1, lsl #2
 8008650:	f2a0 4032 	subw	r0, r0, #1074	; 0x432
 8008654:	6030      	str	r0, [r6, #0]
 8008656:	6918      	ldr	r0, [r3, #16]
 8008658:	f7ff fd36 	bl	80080c8 <__hi0bits>
 800865c:	ebc0 1041 	rsb	r0, r0, r1, lsl #5
 8008660:	e7e1      	b.n	8008626 <__d2b+0x62>

08008662 <__ratio>:
 8008662:	e92d 4ff7 	stmdb	sp!, {r0, r1, r2, r4, r5, r6, r7, r8, r9, sl, fp, lr}
 8008666:	4688      	mov	r8, r1
 8008668:	4669      	mov	r1, sp
 800866a:	4681      	mov	r9, r0
 800866c:	f7ff ff5c 	bl	8008528 <__b2d>
 8008670:	a901      	add	r1, sp, #4
 8008672:	4640      	mov	r0, r8
 8008674:	ec57 6b10 	vmov	r6, r7, d0
 8008678:	ee10 4a10 	vmov	r4, s0
 800867c:	f7ff ff54 	bl	8008528 <__b2d>
 8008680:	f8d9 3010 	ldr.w	r3, [r9, #16]
 8008684:	f8d8 2010 	ldr.w	r2, [r8, #16]
 8008688:	eba3 0c02 	sub.w	ip, r3, r2
 800868c:	e9dd 3200 	ldrd	r3, r2, [sp]
 8008690:	1a9b      	subs	r3, r3, r2
 8008692:	eb03 134c 	add.w	r3, r3, ip, lsl #5
 8008696:	ec51 0b10 	vmov	r0, r1, d0
 800869a:	2b00      	cmp	r3, #0
 800869c:	ee10 aa10 	vmov	sl, s0
 80086a0:	bfce      	itee	gt
 80086a2:	463a      	movgt	r2, r7
 80086a4:	ebc3 3303 	rsble	r3, r3, r3, lsl #12
 80086a8:	460a      	movle	r2, r1
 80086aa:	463d      	mov	r5, r7
 80086ac:	468b      	mov	fp, r1
 80086ae:	bfcc      	ite	gt
 80086b0:	eb02 5503 	addgt.w	r5, r2, r3, lsl #20
 80086b4:	eb02 5b03 	addle.w	fp, r2, r3, lsl #20
 80086b8:	ec45 4b17 	vmov	d7, r4, r5
 80086bc:	ec4b ab16 	vmov	d6, sl, fp
 80086c0:	ee87 0b06 	vdiv.f64	d0, d7, d6
 80086c4:	b003      	add	sp, #12
 80086c6:	e8bd 8ff0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, pc}

080086ca <__copybits>:
 80086ca:	3901      	subs	r1, #1
 80086cc:	b510      	push	{r4, lr}
 80086ce:	1149      	asrs	r1, r1, #5
 80086d0:	6914      	ldr	r4, [r2, #16]
 80086d2:	3101      	adds	r1, #1
 80086d4:	f102 0314 	add.w	r3, r2, #20
 80086d8:	eb00 0181 	add.w	r1, r0, r1, lsl #2
 80086dc:	eb03 0484 	add.w	r4, r3, r4, lsl #2
 80086e0:	42a3      	cmp	r3, r4
 80086e2:	4602      	mov	r2, r0
 80086e4:	d303      	bcc.n	80086ee <__copybits+0x24>
 80086e6:	2300      	movs	r3, #0
 80086e8:	428a      	cmp	r2, r1
 80086ea:	d305      	bcc.n	80086f8 <__copybits+0x2e>
 80086ec:	bd10      	pop	{r4, pc}
 80086ee:	f853 2b04 	ldr.w	r2, [r3], #4
 80086f2:	f840 2b04 	str.w	r2, [r0], #4
 80086f6:	e7f3      	b.n	80086e0 <__copybits+0x16>
 80086f8:	f842 3b04 	str.w	r3, [r2], #4
 80086fc:	e7f4      	b.n	80086e8 <__copybits+0x1e>

080086fe <__any_on>:
 80086fe:	f100 0214 	add.w	r2, r0, #20
 8008702:	6900      	ldr	r0, [r0, #16]
 8008704:	114b      	asrs	r3, r1, #5
 8008706:	4298      	cmp	r0, r3
 8008708:	b510      	push	{r4, lr}
 800870a:	db11      	blt.n	8008730 <__any_on+0x32>
 800870c:	dd0a      	ble.n	8008724 <__any_on+0x26>
 800870e:	f011 011f 	ands.w	r1, r1, #31
 8008712:	d007      	beq.n	8008724 <__any_on+0x26>
 8008714:	f852 4023 	ldr.w	r4, [r2, r3, lsl #2]
 8008718:	fa24 f001 	lsr.w	r0, r4, r1
 800871c:	fa00 f101 	lsl.w	r1, r0, r1
 8008720:	428c      	cmp	r4, r1
 8008722:	d10b      	bne.n	800873c <__any_on+0x3e>
 8008724:	eb02 0383 	add.w	r3, r2, r3, lsl #2
 8008728:	4293      	cmp	r3, r2
 800872a:	d803      	bhi.n	8008734 <__any_on+0x36>
 800872c:	2000      	movs	r0, #0
 800872e:	bd10      	pop	{r4, pc}
 8008730:	4603      	mov	r3, r0
 8008732:	e7f7      	b.n	8008724 <__any_on+0x26>
 8008734:	f853 1d04 	ldr.w	r1, [r3, #-4]!
 8008738:	2900      	cmp	r1, #0
 800873a:	d0f5      	beq.n	8008728 <__any_on+0x2a>
 800873c:	2001      	movs	r0, #1
 800873e:	e7f6      	b.n	800872e <__any_on+0x30>

08008740 <_calloc_r>:
 8008740:	b538      	push	{r3, r4, r5, lr}
 8008742:	fb02 f401 	mul.w	r4, r2, r1
 8008746:	4621      	mov	r1, r4
 8008748:	f000 f856 	bl	80087f8 <_malloc_r>
 800874c:	4605      	mov	r5, r0
 800874e:	b118      	cbz	r0, 8008758 <_calloc_r+0x18>
 8008750:	4622      	mov	r2, r4
 8008752:	2100      	movs	r1, #0
 8008754:	f7fc fe07 	bl	8005366 <memset>
 8008758:	4628      	mov	r0, r5
 800875a:	bd38      	pop	{r3, r4, r5, pc}

0800875c <_free_r>:
 800875c:	b538      	push	{r3, r4, r5, lr}
 800875e:	4605      	mov	r5, r0
 8008760:	2900      	cmp	r1, #0
 8008762:	d045      	beq.n	80087f0 <_free_r+0x94>
 8008764:	f851 3c04 	ldr.w	r3, [r1, #-4]
 8008768:	1f0c      	subs	r4, r1, #4
 800876a:	2b00      	cmp	r3, #0
 800876c:	bfb8      	it	lt
 800876e:	18e4      	addlt	r4, r4, r3
 8008770:	f000 fa36 	bl	8008be0 <__malloc_lock>
 8008774:	4a1f      	ldr	r2, [pc, #124]	; (80087f4 <_free_r+0x98>)
 8008776:	6813      	ldr	r3, [r2, #0]
 8008778:	4610      	mov	r0, r2
 800877a:	b933      	cbnz	r3, 800878a <_free_r+0x2e>
 800877c:	6063      	str	r3, [r4, #4]
 800877e:	6014      	str	r4, [r2, #0]
 8008780:	4628      	mov	r0, r5
 8008782:	e8bd 4038 	ldmia.w	sp!, {r3, r4, r5, lr}
 8008786:	f000 ba2c 	b.w	8008be2 <__malloc_unlock>
 800878a:	42a3      	cmp	r3, r4
 800878c:	d90c      	bls.n	80087a8 <_free_r+0x4c>
 800878e:	6821      	ldr	r1, [r4, #0]
 8008790:	1862      	adds	r2, r4, r1
 8008792:	4293      	cmp	r3, r2
 8008794:	bf04      	itt	eq
 8008796:	681a      	ldreq	r2, [r3, #0]
 8008798:	685b      	ldreq	r3, [r3, #4]
 800879a:	6063      	str	r3, [r4, #4]
 800879c:	bf04      	itt	eq
 800879e:	1852      	addeq	r2, r2, r1
 80087a0:	6022      	streq	r2, [r4, #0]
 80087a2:	6004      	str	r4, [r0, #0]
 80087a4:	e7ec      	b.n	8008780 <_free_r+0x24>
 80087a6:	4613      	mov	r3, r2
 80087a8:	685a      	ldr	r2, [r3, #4]
 80087aa:	b10a      	cbz	r2, 80087b0 <_free_r+0x54>
 80087ac:	42a2      	cmp	r2, r4
 80087ae:	d9fa      	bls.n	80087a6 <_free_r+0x4a>
 80087b0:	6819      	ldr	r1, [r3, #0]
 80087b2:	1858      	adds	r0, r3, r1
 80087b4:	42a0      	cmp	r0, r4
 80087b6:	d10b      	bne.n	80087d0 <_free_r+0x74>
 80087b8:	6820      	ldr	r0, [r4, #0]
 80087ba:	4401      	add	r1, r0
 80087bc:	1858      	adds	r0, r3, r1
 80087be:	4282      	cmp	r2, r0
 80087c0:	6019      	str	r1, [r3, #0]
 80087c2:	d1dd      	bne.n	8008780 <_free_r+0x24>
 80087c4:	6810      	ldr	r0, [r2, #0]
 80087c6:	6852      	ldr	r2, [r2, #4]
 80087c8:	605a      	str	r2, [r3, #4]
 80087ca:	4401      	add	r1, r0
 80087cc:	6019      	str	r1, [r3, #0]
 80087ce:	e7d7      	b.n	8008780 <_free_r+0x24>
 80087d0:	d902      	bls.n	80087d8 <_free_r+0x7c>
 80087d2:	230c      	movs	r3, #12
 80087d4:	602b      	str	r3, [r5, #0]
 80087d6:	e7d3      	b.n	8008780 <_free_r+0x24>
 80087d8:	6820      	ldr	r0, [r4, #0]
 80087da:	1821      	adds	r1, r4, r0
 80087dc:	428a      	cmp	r2, r1
 80087de:	bf04      	itt	eq
 80087e0:	6811      	ldreq	r1, [r2, #0]
 80087e2:	6852      	ldreq	r2, [r2, #4]
 80087e4:	6062      	str	r2, [r4, #4]
 80087e6:	bf04      	itt	eq
 80087e8:	1809      	addeq	r1, r1, r0
 80087ea:	6021      	streq	r1, [r4, #0]
 80087ec:	605c      	str	r4, [r3, #4]
 80087ee:	e7c7      	b.n	8008780 <_free_r+0x24>
 80087f0:	bd38      	pop	{r3, r4, r5, pc}
 80087f2:	bf00      	nop
 80087f4:	20000200 	.word	0x20000200

080087f8 <_malloc_r>:
 80087f8:	b570      	push	{r4, r5, r6, lr}
 80087fa:	1ccd      	adds	r5, r1, #3
 80087fc:	f025 0503 	bic.w	r5, r5, #3
 8008800:	3508      	adds	r5, #8
 8008802:	2d0c      	cmp	r5, #12
 8008804:	bf38      	it	cc
 8008806:	250c      	movcc	r5, #12
 8008808:	2d00      	cmp	r5, #0
 800880a:	4606      	mov	r6, r0
 800880c:	db01      	blt.n	8008812 <_malloc_r+0x1a>
 800880e:	42a9      	cmp	r1, r5
 8008810:	d903      	bls.n	800881a <_malloc_r+0x22>
 8008812:	230c      	movs	r3, #12
 8008814:	6033      	str	r3, [r6, #0]
 8008816:	2000      	movs	r0, #0
 8008818:	bd70      	pop	{r4, r5, r6, pc}
 800881a:	f000 f9e1 	bl	8008be0 <__malloc_lock>
 800881e:	4a21      	ldr	r2, [pc, #132]	; (80088a4 <_malloc_r+0xac>)
 8008820:	6814      	ldr	r4, [r2, #0]
 8008822:	4621      	mov	r1, r4
 8008824:	b991      	cbnz	r1, 800884c <_malloc_r+0x54>
 8008826:	4c20      	ldr	r4, [pc, #128]	; (80088a8 <_malloc_r+0xb0>)
 8008828:	6823      	ldr	r3, [r4, #0]
 800882a:	b91b      	cbnz	r3, 8008834 <_malloc_r+0x3c>
 800882c:	4630      	mov	r0, r6
 800882e:	f000 f98f 	bl	8008b50 <_sbrk_r>
 8008832:	6020      	str	r0, [r4, #0]
 8008834:	4629      	mov	r1, r5
 8008836:	4630      	mov	r0, r6
 8008838:	f000 f98a 	bl	8008b50 <_sbrk_r>
 800883c:	1c43      	adds	r3, r0, #1
 800883e:	d124      	bne.n	800888a <_malloc_r+0x92>
 8008840:	230c      	movs	r3, #12
 8008842:	6033      	str	r3, [r6, #0]
 8008844:	4630      	mov	r0, r6
 8008846:	f000 f9cc 	bl	8008be2 <__malloc_unlock>
 800884a:	e7e4      	b.n	8008816 <_malloc_r+0x1e>
 800884c:	680b      	ldr	r3, [r1, #0]
 800884e:	1b5b      	subs	r3, r3, r5
 8008850:	d418      	bmi.n	8008884 <_malloc_r+0x8c>
 8008852:	2b0b      	cmp	r3, #11
 8008854:	d90f      	bls.n	8008876 <_malloc_r+0x7e>
 8008856:	600b      	str	r3, [r1, #0]
 8008858:	50cd      	str	r5, [r1, r3]
 800885a:	18cc      	adds	r4, r1, r3
 800885c:	4630      	mov	r0, r6
 800885e:	f000 f9c0 	bl	8008be2 <__malloc_unlock>
 8008862:	f104 000b 	add.w	r0, r4, #11
 8008866:	1d23      	adds	r3, r4, #4
 8008868:	f020 0007 	bic.w	r0, r0, #7
 800886c:	1ac3      	subs	r3, r0, r3
 800886e:	d0d3      	beq.n	8008818 <_malloc_r+0x20>
 8008870:	425a      	negs	r2, r3
 8008872:	50e2      	str	r2, [r4, r3]
 8008874:	e7d0      	b.n	8008818 <_malloc_r+0x20>
 8008876:	428c      	cmp	r4, r1
 8008878:	684b      	ldr	r3, [r1, #4]
 800887a:	bf16      	itet	ne
 800887c:	6063      	strne	r3, [r4, #4]
 800887e:	6013      	streq	r3, [r2, #0]
 8008880:	460c      	movne	r4, r1
 8008882:	e7eb      	b.n	800885c <_malloc_r+0x64>
 8008884:	460c      	mov	r4, r1
 8008886:	6849      	ldr	r1, [r1, #4]
 8008888:	e7cc      	b.n	8008824 <_malloc_r+0x2c>
 800888a:	1cc4      	adds	r4, r0, #3
 800888c:	f024 0403 	bic.w	r4, r4, #3
 8008890:	42a0      	cmp	r0, r4
 8008892:	d005      	beq.n	80088a0 <_malloc_r+0xa8>
 8008894:	1a21      	subs	r1, r4, r0
 8008896:	4630      	mov	r0, r6
 8008898:	f000 f95a 	bl	8008b50 <_sbrk_r>
 800889c:	3001      	adds	r0, #1
 800889e:	d0cf      	beq.n	8008840 <_malloc_r+0x48>
 80088a0:	6025      	str	r5, [r4, #0]
 80088a2:	e7db      	b.n	800885c <_malloc_r+0x64>
 80088a4:	20000200 	.word	0x20000200
 80088a8:	20000204 	.word	0x20000204

080088ac <__ssputs_r>:
 80088ac:	e92d 47f0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, lr}
 80088b0:	688e      	ldr	r6, [r1, #8]
 80088b2:	429e      	cmp	r6, r3
 80088b4:	4682      	mov	sl, r0
 80088b6:	460c      	mov	r4, r1
 80088b8:	4690      	mov	r8, r2
 80088ba:	4699      	mov	r9, r3
 80088bc:	d837      	bhi.n	800892e <__ssputs_r+0x82>
 80088be:	898a      	ldrh	r2, [r1, #12]
 80088c0:	f412 6f90 	tst.w	r2, #1152	; 0x480
 80088c4:	d031      	beq.n	800892a <__ssputs_r+0x7e>
 80088c6:	6825      	ldr	r5, [r4, #0]
 80088c8:	6909      	ldr	r1, [r1, #16]
 80088ca:	1a6f      	subs	r7, r5, r1
 80088cc:	6965      	ldr	r5, [r4, #20]
 80088ce:	2302      	movs	r3, #2
 80088d0:	eb05 0545 	add.w	r5, r5, r5, lsl #1
 80088d4:	fb95 f5f3 	sdiv	r5, r5, r3
 80088d8:	f109 0301 	add.w	r3, r9, #1
 80088dc:	443b      	add	r3, r7
 80088de:	429d      	cmp	r5, r3
 80088e0:	bf38      	it	cc
 80088e2:	461d      	movcc	r5, r3
 80088e4:	0553      	lsls	r3, r2, #21
 80088e6:	d530      	bpl.n	800894a <__ssputs_r+0x9e>
 80088e8:	4629      	mov	r1, r5
 80088ea:	f7ff ff85 	bl	80087f8 <_malloc_r>
 80088ee:	4606      	mov	r6, r0
 80088f0:	b950      	cbnz	r0, 8008908 <__ssputs_r+0x5c>
 80088f2:	230c      	movs	r3, #12
 80088f4:	f8ca 3000 	str.w	r3, [sl]
 80088f8:	89a3      	ldrh	r3, [r4, #12]
 80088fa:	f043 0340 	orr.w	r3, r3, #64	; 0x40
 80088fe:	81a3      	strh	r3, [r4, #12]
 8008900:	f04f 30ff 	mov.w	r0, #4294967295	; 0xffffffff
 8008904:	e8bd 87f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, pc}
 8008908:	463a      	mov	r2, r7
 800890a:	6921      	ldr	r1, [r4, #16]
 800890c:	f7fc fd20 	bl	8005350 <memcpy>
 8008910:	89a3      	ldrh	r3, [r4, #12]
 8008912:	f423 6390 	bic.w	r3, r3, #1152	; 0x480
 8008916:	f043 0380 	orr.w	r3, r3, #128	; 0x80
 800891a:	81a3      	strh	r3, [r4, #12]
 800891c:	6126      	str	r6, [r4, #16]
 800891e:	6165      	str	r5, [r4, #20]
 8008920:	443e      	add	r6, r7
 8008922:	1bed      	subs	r5, r5, r7
 8008924:	6026      	str	r6, [r4, #0]
 8008926:	60a5      	str	r5, [r4, #8]
 8008928:	464e      	mov	r6, r9
 800892a:	454e      	cmp	r6, r9
 800892c:	d900      	bls.n	8008930 <__ssputs_r+0x84>
 800892e:	464e      	mov	r6, r9
 8008930:	4632      	mov	r2, r6
 8008932:	4641      	mov	r1, r8
 8008934:	6820      	ldr	r0, [r4, #0]
 8008936:	f000 f93a 	bl	8008bae <memmove>
 800893a:	68a3      	ldr	r3, [r4, #8]
 800893c:	1b9b      	subs	r3, r3, r6
 800893e:	60a3      	str	r3, [r4, #8]
 8008940:	6823      	ldr	r3, [r4, #0]
 8008942:	441e      	add	r6, r3
 8008944:	6026      	str	r6, [r4, #0]
 8008946:	2000      	movs	r0, #0
 8008948:	e7dc      	b.n	8008904 <__ssputs_r+0x58>
 800894a:	462a      	mov	r2, r5
 800894c:	f000 f94a 	bl	8008be4 <_realloc_r>
 8008950:	4606      	mov	r6, r0
 8008952:	2800      	cmp	r0, #0
 8008954:	d1e2      	bne.n	800891c <__ssputs_r+0x70>
 8008956:	6921      	ldr	r1, [r4, #16]
 8008958:	4650      	mov	r0, sl
 800895a:	f7ff feff 	bl	800875c <_free_r>
 800895e:	e7c8      	b.n	80088f2 <__ssputs_r+0x46>

08008960 <_svfiprintf_r>:
 8008960:	e92d 4ff0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, lr}
 8008964:	461d      	mov	r5, r3
 8008966:	898b      	ldrh	r3, [r1, #12]
 8008968:	061f      	lsls	r7, r3, #24
 800896a:	b09d      	sub	sp, #116	; 0x74
 800896c:	4680      	mov	r8, r0
 800896e:	460c      	mov	r4, r1
 8008970:	4616      	mov	r6, r2
 8008972:	d50f      	bpl.n	8008994 <_svfiprintf_r+0x34>
 8008974:	690b      	ldr	r3, [r1, #16]
 8008976:	b96b      	cbnz	r3, 8008994 <_svfiprintf_r+0x34>
 8008978:	2140      	movs	r1, #64	; 0x40
 800897a:	f7ff ff3d 	bl	80087f8 <_malloc_r>
 800897e:	6020      	str	r0, [r4, #0]
 8008980:	6120      	str	r0, [r4, #16]
 8008982:	b928      	cbnz	r0, 8008990 <_svfiprintf_r+0x30>
 8008984:	230c      	movs	r3, #12
 8008986:	f8c8 3000 	str.w	r3, [r8]
 800898a:	f04f 30ff 	mov.w	r0, #4294967295	; 0xffffffff
 800898e:	e0c8      	b.n	8008b22 <_svfiprintf_r+0x1c2>
 8008990:	2340      	movs	r3, #64	; 0x40
 8008992:	6163      	str	r3, [r4, #20]
 8008994:	2300      	movs	r3, #0
 8008996:	9309      	str	r3, [sp, #36]	; 0x24
 8008998:	2320      	movs	r3, #32
 800899a:	f88d 3029 	strb.w	r3, [sp, #41]	; 0x29
 800899e:	2330      	movs	r3, #48	; 0x30
 80089a0:	f88d 302a 	strb.w	r3, [sp, #42]	; 0x2a
 80089a4:	9503      	str	r5, [sp, #12]
 80089a6:	f04f 0b01 	mov.w	fp, #1
 80089aa:	4637      	mov	r7, r6
 80089ac:	463d      	mov	r5, r7
 80089ae:	f815 3b01 	ldrb.w	r3, [r5], #1
 80089b2:	b10b      	cbz	r3, 80089b8 <_svfiprintf_r+0x58>
 80089b4:	2b25      	cmp	r3, #37	; 0x25
 80089b6:	d13e      	bne.n	8008a36 <_svfiprintf_r+0xd6>
 80089b8:	ebb7 0a06 	subs.w	sl, r7, r6
 80089bc:	d00b      	beq.n	80089d6 <_svfiprintf_r+0x76>
 80089be:	4653      	mov	r3, sl
 80089c0:	4632      	mov	r2, r6
 80089c2:	4621      	mov	r1, r4
 80089c4:	4640      	mov	r0, r8
 80089c6:	f7ff ff71 	bl	80088ac <__ssputs_r>
 80089ca:	3001      	adds	r0, #1
 80089cc:	f000 80a4 	beq.w	8008b18 <_svfiprintf_r+0x1b8>
 80089d0:	9b09      	ldr	r3, [sp, #36]	; 0x24
 80089d2:	4453      	add	r3, sl
 80089d4:	9309      	str	r3, [sp, #36]	; 0x24
 80089d6:	783b      	ldrb	r3, [r7, #0]
 80089d8:	2b00      	cmp	r3, #0
 80089da:	f000 809d 	beq.w	8008b18 <_svfiprintf_r+0x1b8>
 80089de:	2300      	movs	r3, #0
 80089e0:	f04f 32ff 	mov.w	r2, #4294967295	; 0xffffffff
 80089e4:	e9cd 2305 	strd	r2, r3, [sp, #20]
 80089e8:	9304      	str	r3, [sp, #16]
 80089ea:	9307      	str	r3, [sp, #28]
 80089ec:	f88d 3053 	strb.w	r3, [sp, #83]	; 0x53
 80089f0:	931a      	str	r3, [sp, #104]	; 0x68
 80089f2:	462f      	mov	r7, r5
 80089f4:	2205      	movs	r2, #5
 80089f6:	f817 1b01 	ldrb.w	r1, [r7], #1
 80089fa:	4850      	ldr	r0, [pc, #320]	; (8008b3c <_svfiprintf_r+0x1dc>)
 80089fc:	f7f7 fc28 	bl	8000250 <memchr>
 8008a00:	9b04      	ldr	r3, [sp, #16]
 8008a02:	b9d0      	cbnz	r0, 8008a3a <_svfiprintf_r+0xda>
 8008a04:	06d9      	lsls	r1, r3, #27
 8008a06:	bf44      	itt	mi
 8008a08:	2220      	movmi	r2, #32
 8008a0a:	f88d 2053 	strbmi.w	r2, [sp, #83]	; 0x53
 8008a0e:	071a      	lsls	r2, r3, #28
 8008a10:	bf44      	itt	mi
 8008a12:	222b      	movmi	r2, #43	; 0x2b
 8008a14:	f88d 2053 	strbmi.w	r2, [sp, #83]	; 0x53
 8008a18:	782a      	ldrb	r2, [r5, #0]
 8008a1a:	2a2a      	cmp	r2, #42	; 0x2a
 8008a1c:	d015      	beq.n	8008a4a <_svfiprintf_r+0xea>
 8008a1e:	9a07      	ldr	r2, [sp, #28]
 8008a20:	462f      	mov	r7, r5
 8008a22:	2000      	movs	r0, #0
 8008a24:	250a      	movs	r5, #10
 8008a26:	4639      	mov	r1, r7
 8008a28:	f811 3b01 	ldrb.w	r3, [r1], #1
 8008a2c:	3b30      	subs	r3, #48	; 0x30
 8008a2e:	2b09      	cmp	r3, #9
 8008a30:	d94d      	bls.n	8008ace <_svfiprintf_r+0x16e>
 8008a32:	b1b8      	cbz	r0, 8008a64 <_svfiprintf_r+0x104>
 8008a34:	e00f      	b.n	8008a56 <_svfiprintf_r+0xf6>
 8008a36:	462f      	mov	r7, r5
 8008a38:	e7b8      	b.n	80089ac <_svfiprintf_r+0x4c>
 8008a3a:	4a40      	ldr	r2, [pc, #256]	; (8008b3c <_svfiprintf_r+0x1dc>)
 8008a3c:	1a80      	subs	r0, r0, r2
 8008a3e:	fa0b f000 	lsl.w	r0, fp, r0
 8008a42:	4318      	orrs	r0, r3
 8008a44:	9004      	str	r0, [sp, #16]
 8008a46:	463d      	mov	r5, r7
 8008a48:	e7d3      	b.n	80089f2 <_svfiprintf_r+0x92>
 8008a4a:	9a03      	ldr	r2, [sp, #12]
 8008a4c:	1d11      	adds	r1, r2, #4
 8008a4e:	6812      	ldr	r2, [r2, #0]
 8008a50:	9103      	str	r1, [sp, #12]
 8008a52:	2a00      	cmp	r2, #0
 8008a54:	db01      	blt.n	8008a5a <_svfiprintf_r+0xfa>
 8008a56:	9207      	str	r2, [sp, #28]
 8008a58:	e004      	b.n	8008a64 <_svfiprintf_r+0x104>
 8008a5a:	4252      	negs	r2, r2
 8008a5c:	f043 0302 	orr.w	r3, r3, #2
 8008a60:	9207      	str	r2, [sp, #28]
 8008a62:	9304      	str	r3, [sp, #16]
 8008a64:	783b      	ldrb	r3, [r7, #0]
 8008a66:	2b2e      	cmp	r3, #46	; 0x2e
 8008a68:	d10c      	bne.n	8008a84 <_svfiprintf_r+0x124>
 8008a6a:	787b      	ldrb	r3, [r7, #1]
 8008a6c:	2b2a      	cmp	r3, #42	; 0x2a
 8008a6e:	d133      	bne.n	8008ad8 <_svfiprintf_r+0x178>
 8008a70:	9b03      	ldr	r3, [sp, #12]
 8008a72:	1d1a      	adds	r2, r3, #4
 8008a74:	681b      	ldr	r3, [r3, #0]
 8008a76:	9203      	str	r2, [sp, #12]
 8008a78:	2b00      	cmp	r3, #0
 8008a7a:	bfb8      	it	lt
 8008a7c:	f04f 33ff 	movlt.w	r3, #4294967295	; 0xffffffff
 8008a80:	3702      	adds	r7, #2
 8008a82:	9305      	str	r3, [sp, #20]
 8008a84:	4d2e      	ldr	r5, [pc, #184]	; (8008b40 <_svfiprintf_r+0x1e0>)
 8008a86:	7839      	ldrb	r1, [r7, #0]
 8008a88:	2203      	movs	r2, #3
 8008a8a:	4628      	mov	r0, r5
 8008a8c:	f7f7 fbe0 	bl	8000250 <memchr>
 8008a90:	b138      	cbz	r0, 8008aa2 <_svfiprintf_r+0x142>
 8008a92:	2340      	movs	r3, #64	; 0x40
 8008a94:	1b40      	subs	r0, r0, r5
 8008a96:	fa03 f000 	lsl.w	r0, r3, r0
 8008a9a:	9b04      	ldr	r3, [sp, #16]
 8008a9c:	4303      	orrs	r3, r0
 8008a9e:	3701      	adds	r7, #1
 8008aa0:	9304      	str	r3, [sp, #16]
 8008aa2:	7839      	ldrb	r1, [r7, #0]
 8008aa4:	4827      	ldr	r0, [pc, #156]	; (8008b44 <_svfiprintf_r+0x1e4>)
 8008aa6:	f88d 1028 	strb.w	r1, [sp, #40]	; 0x28
 8008aaa:	2206      	movs	r2, #6
 8008aac:	1c7e      	adds	r6, r7, #1
 8008aae:	f7f7 fbcf 	bl	8000250 <memchr>
 8008ab2:	2800      	cmp	r0, #0
 8008ab4:	d038      	beq.n	8008b28 <_svfiprintf_r+0x1c8>
 8008ab6:	4b24      	ldr	r3, [pc, #144]	; (8008b48 <_svfiprintf_r+0x1e8>)
 8008ab8:	bb13      	cbnz	r3, 8008b00 <_svfiprintf_r+0x1a0>
 8008aba:	9b03      	ldr	r3, [sp, #12]
 8008abc:	3307      	adds	r3, #7
 8008abe:	f023 0307 	bic.w	r3, r3, #7
 8008ac2:	3308      	adds	r3, #8
 8008ac4:	9303      	str	r3, [sp, #12]
 8008ac6:	9b09      	ldr	r3, [sp, #36]	; 0x24
 8008ac8:	444b      	add	r3, r9
 8008aca:	9309      	str	r3, [sp, #36]	; 0x24
 8008acc:	e76d      	b.n	80089aa <_svfiprintf_r+0x4a>
 8008ace:	fb05 3202 	mla	r2, r5, r2, r3
 8008ad2:	2001      	movs	r0, #1
 8008ad4:	460f      	mov	r7, r1
 8008ad6:	e7a6      	b.n	8008a26 <_svfiprintf_r+0xc6>
 8008ad8:	2300      	movs	r3, #0
 8008ada:	3701      	adds	r7, #1
 8008adc:	9305      	str	r3, [sp, #20]
 8008ade:	4619      	mov	r1, r3
 8008ae0:	250a      	movs	r5, #10
 8008ae2:	4638      	mov	r0, r7
 8008ae4:	f810 2b01 	ldrb.w	r2, [r0], #1
 8008ae8:	3a30      	subs	r2, #48	; 0x30
 8008aea:	2a09      	cmp	r2, #9
 8008aec:	d903      	bls.n	8008af6 <_svfiprintf_r+0x196>
 8008aee:	2b00      	cmp	r3, #0
 8008af0:	d0c8      	beq.n	8008a84 <_svfiprintf_r+0x124>
 8008af2:	9105      	str	r1, [sp, #20]
 8008af4:	e7c6      	b.n	8008a84 <_svfiprintf_r+0x124>
 8008af6:	fb05 2101 	mla	r1, r5, r1, r2
 8008afa:	2301      	movs	r3, #1
 8008afc:	4607      	mov	r7, r0
 8008afe:	e7f0      	b.n	8008ae2 <_svfiprintf_r+0x182>
 8008b00:	ab03      	add	r3, sp, #12
 8008b02:	9300      	str	r3, [sp, #0]
 8008b04:	4622      	mov	r2, r4
 8008b06:	4b11      	ldr	r3, [pc, #68]	; (8008b4c <_svfiprintf_r+0x1ec>)
 8008b08:	a904      	add	r1, sp, #16
 8008b0a:	4640      	mov	r0, r8
 8008b0c:	f7fc fcb8 	bl	8005480 <_printf_float>
 8008b10:	f1b0 3fff 	cmp.w	r0, #4294967295	; 0xffffffff
 8008b14:	4681      	mov	r9, r0
 8008b16:	d1d6      	bne.n	8008ac6 <_svfiprintf_r+0x166>
 8008b18:	89a3      	ldrh	r3, [r4, #12]
 8008b1a:	065b      	lsls	r3, r3, #25
 8008b1c:	f53f af35 	bmi.w	800898a <_svfiprintf_r+0x2a>
 8008b20:	9809      	ldr	r0, [sp, #36]	; 0x24
 8008b22:	b01d      	add	sp, #116	; 0x74
 8008b24:	e8bd 8ff0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, pc}
 8008b28:	ab03      	add	r3, sp, #12
 8008b2a:	9300      	str	r3, [sp, #0]
 8008b2c:	4622      	mov	r2, r4
 8008b2e:	4b07      	ldr	r3, [pc, #28]	; (8008b4c <_svfiprintf_r+0x1ec>)
 8008b30:	a904      	add	r1, sp, #16
 8008b32:	4640      	mov	r0, r8
 8008b34:	f7fc ff46 	bl	80059c4 <_printf_i>
 8008b38:	e7ea      	b.n	8008b10 <_svfiprintf_r+0x1b0>
 8008b3a:	bf00      	nop
 8008b3c:	0802e85c 	.word	0x0802e85c
 8008b40:	0802e862 	.word	0x0802e862
 8008b44:	0802e866 	.word	0x0802e866
 8008b48:	08005481 	.word	0x08005481
 8008b4c:	080088ad 	.word	0x080088ad

08008b50 <_sbrk_r>:
 8008b50:	b538      	push	{r3, r4, r5, lr}
 8008b52:	4c06      	ldr	r4, [pc, #24]	; (8008b6c <_sbrk_r+0x1c>)
 8008b54:	2300      	movs	r3, #0
 8008b56:	4605      	mov	r5, r0
 8008b58:	4608      	mov	r0, r1
 8008b5a:	6023      	str	r3, [r4, #0]
 8008b5c:	f7f8 fb12 	bl	8001184 <_sbrk>
 8008b60:	1c43      	adds	r3, r0, #1
 8008b62:	d102      	bne.n	8008b6a <_sbrk_r+0x1a>
 8008b64:	6823      	ldr	r3, [r4, #0]
 8008b66:	b103      	cbz	r3, 8008b6a <_sbrk_r+0x1a>
 8008b68:	602b      	str	r3, [r5, #0]
 8008b6a:	bd38      	pop	{r3, r4, r5, pc}
 8008b6c:	20025b54 	.word	0x20025b54

08008b70 <strncmp>:
 8008b70:	b510      	push	{r4, lr}
 8008b72:	b16a      	cbz	r2, 8008b90 <strncmp+0x20>
 8008b74:	3901      	subs	r1, #1
 8008b76:	1884      	adds	r4, r0, r2
 8008b78:	f810 3b01 	ldrb.w	r3, [r0], #1
 8008b7c:	f811 2f01 	ldrb.w	r2, [r1, #1]!
 8008b80:	4293      	cmp	r3, r2
 8008b82:	d103      	bne.n	8008b8c <strncmp+0x1c>
 8008b84:	42a0      	cmp	r0, r4
 8008b86:	d001      	beq.n	8008b8c <strncmp+0x1c>
 8008b88:	2b00      	cmp	r3, #0
 8008b8a:	d1f5      	bne.n	8008b78 <strncmp+0x8>
 8008b8c:	1a98      	subs	r0, r3, r2
 8008b8e:	bd10      	pop	{r4, pc}
 8008b90:	4610      	mov	r0, r2
 8008b92:	e7fc      	b.n	8008b8e <strncmp+0x1e>

08008b94 <__ascii_wctomb>:
 8008b94:	b149      	cbz	r1, 8008baa <__ascii_wctomb+0x16>
 8008b96:	2aff      	cmp	r2, #255	; 0xff
 8008b98:	bf85      	ittet	hi
 8008b9a:	238a      	movhi	r3, #138	; 0x8a
 8008b9c:	6003      	strhi	r3, [r0, #0]
 8008b9e:	700a      	strbls	r2, [r1, #0]
 8008ba0:	f04f 30ff 	movhi.w	r0, #4294967295	; 0xffffffff
 8008ba4:	bf98      	it	ls
 8008ba6:	2001      	movls	r0, #1
 8008ba8:	4770      	bx	lr
 8008baa:	4608      	mov	r0, r1
 8008bac:	4770      	bx	lr

08008bae <memmove>:
 8008bae:	4288      	cmp	r0, r1
 8008bb0:	b510      	push	{r4, lr}
 8008bb2:	eb01 0302 	add.w	r3, r1, r2
 8008bb6:	d807      	bhi.n	8008bc8 <memmove+0x1a>
 8008bb8:	1e42      	subs	r2, r0, #1
 8008bba:	4299      	cmp	r1, r3
 8008bbc:	d00a      	beq.n	8008bd4 <memmove+0x26>
 8008bbe:	f811 4b01 	ldrb.w	r4, [r1], #1
 8008bc2:	f802 4f01 	strb.w	r4, [r2, #1]!
 8008bc6:	e7f8      	b.n	8008bba <memmove+0xc>
 8008bc8:	4283      	cmp	r3, r0
 8008bca:	d9f5      	bls.n	8008bb8 <memmove+0xa>
 8008bcc:	1881      	adds	r1, r0, r2
 8008bce:	1ad2      	subs	r2, r2, r3
 8008bd0:	42d3      	cmn	r3, r2
 8008bd2:	d100      	bne.n	8008bd6 <memmove+0x28>
 8008bd4:	bd10      	pop	{r4, pc}
 8008bd6:	f813 4d01 	ldrb.w	r4, [r3, #-1]!
 8008bda:	f801 4d01 	strb.w	r4, [r1, #-1]!
 8008bde:	e7f7      	b.n	8008bd0 <memmove+0x22>

08008be0 <__malloc_lock>:
 8008be0:	4770      	bx	lr

08008be2 <__malloc_unlock>:
 8008be2:	4770      	bx	lr

08008be4 <_realloc_r>:
 8008be4:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 8008be6:	4607      	mov	r7, r0
 8008be8:	4614      	mov	r4, r2
 8008bea:	460e      	mov	r6, r1
 8008bec:	b921      	cbnz	r1, 8008bf8 <_realloc_r+0x14>
 8008bee:	4611      	mov	r1, r2
 8008bf0:	e8bd 40f8 	ldmia.w	sp!, {r3, r4, r5, r6, r7, lr}
 8008bf4:	f7ff be00 	b.w	80087f8 <_malloc_r>
 8008bf8:	b922      	cbnz	r2, 8008c04 <_realloc_r+0x20>
 8008bfa:	f7ff fdaf 	bl	800875c <_free_r>
 8008bfe:	4625      	mov	r5, r4
 8008c00:	4628      	mov	r0, r5
 8008c02:	bdf8      	pop	{r3, r4, r5, r6, r7, pc}
 8008c04:	f000 f814 	bl	8008c30 <_malloc_usable_size_r>
 8008c08:	42a0      	cmp	r0, r4
 8008c0a:	d20f      	bcs.n	8008c2c <_realloc_r+0x48>
 8008c0c:	4621      	mov	r1, r4
 8008c0e:	4638      	mov	r0, r7
 8008c10:	f7ff fdf2 	bl	80087f8 <_malloc_r>
 8008c14:	4605      	mov	r5, r0
 8008c16:	2800      	cmp	r0, #0
 8008c18:	d0f2      	beq.n	8008c00 <_realloc_r+0x1c>
 8008c1a:	4631      	mov	r1, r6
 8008c1c:	4622      	mov	r2, r4
 8008c1e:	f7fc fb97 	bl	8005350 <memcpy>
 8008c22:	4631      	mov	r1, r6
 8008c24:	4638      	mov	r0, r7
 8008c26:	f7ff fd99 	bl	800875c <_free_r>
 8008c2a:	e7e9      	b.n	8008c00 <_realloc_r+0x1c>
 8008c2c:	4635      	mov	r5, r6
 8008c2e:	e7e7      	b.n	8008c00 <_realloc_r+0x1c>

08008c30 <_malloc_usable_size_r>:
 8008c30:	f851 3c04 	ldr.w	r3, [r1, #-4]
 8008c34:	1f18      	subs	r0, r3, #4
 8008c36:	2b00      	cmp	r3, #0
 8008c38:	bfbc      	itt	lt
 8008c3a:	580b      	ldrlt	r3, [r1, r0]
 8008c3c:	18c0      	addlt	r0, r0, r3
 8008c3e:	4770      	bx	lr

08008c40 <_init>:
 8008c40:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 8008c42:	bf00      	nop
 8008c44:	bcf8      	pop	{r3, r4, r5, r6, r7}
 8008c46:	bc08      	pop	{r3}
 8008c48:	469e      	mov	lr, r3
 8008c4a:	4770      	bx	lr

08008c4c <_fini>:
 8008c4c:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 8008c4e:	bf00      	nop
 8008c50:	bcf8      	pop	{r3, r4, r5, r6, r7}
 8008c52:	bc08      	pop	{r3}
 8008c54:	469e      	mov	lr, r3
 8008c56:	4770      	bx	lr
