
dht22.elf:     file format elf32-littlearm

Sections:
Idx Name          Size      VMA       LMA       File off  Algn
  0 .isr_vector   00000188  08000000  08000000  00010000  2**0
                  CONTENTS, ALLOC, LOAD, READONLY, DATA
  1 .text         00008e04  08000190  08000190  00010190  2**4
                  CONTENTS, ALLOC, LOAD, READONLY, CODE
  2 .rodata       0000046c  08008f98  08008f98  00018f98  2**3
                  CONTENTS, ALLOC, LOAD, READONLY, DATA
  3 .ARM.extab    00000000  08009404  08009404  000201dc  2**0
                  CONTENTS
  4 .ARM          00000008  08009404  08009404  00019404  2**2
                  CONTENTS, ALLOC, LOAD, READONLY, DATA
  5 .preinit_array 00000000  0800940c  0800940c  000201dc  2**0
                  CONTENTS, ALLOC, LOAD, DATA
  6 .init_array   00000004  0800940c  0800940c  0001940c  2**2
                  CONTENTS, ALLOC, LOAD, DATA
  7 .fini_array   00000004  08009410  08009410  00019410  2**2
                  CONTENTS, ALLOC, LOAD, DATA
  8 .data         000001dc  20000000  08009414  00020000  2**2
                  CONTENTS, ALLOC, LOAD, DATA
  9 .bss          000001e8  200001dc  080095f0  000201dc  2**2
                  ALLOC
 10 ._user_heap_stack 00000604  200003c4  080095f0  000203c4  2**0
                  ALLOC
 11 .ARM.attributes 00000030  00000000  00000000  000201dc  2**0
                  CONTENTS, READONLY
 12 .debug_info   0001aa83  00000000  00000000  0002020c  2**0
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 13 .debug_abbrev 000031c1  00000000  00000000  0003ac8f  2**0
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 14 .debug_aranges 00001368  00000000  00000000  0003de50  2**3
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 15 .debug_ranges 00001200  00000000  00000000  0003f1b8  2**3
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 16 .debug_macro  00029466  00000000  00000000  000403b8  2**0
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 17 .debug_line   00018b9f  00000000  00000000  0006981e  2**0
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 18 .debug_str    000f742b  00000000  00000000  000823bd  2**0
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 19 .comment      00000053  00000000  00000000  001797e8  2**0
                  CONTENTS, READONLY
 20 .debug_frame  000061f4  00000000  00000000  0017983c  2**2
                  CONTENTS, READONLY, DEBUGGING, OCTETS

Disassembly of section .text:

08000190 <__do_global_dtors_aux>:
 8000190:	b510      	push	{r4, lr}
 8000192:	4c05      	ldr	r4, [pc, #20]	; (80001a8 <__do_global_dtors_aux+0x18>)
 8000194:	7823      	ldrb	r3, [r4, #0]
 8000196:	b933      	cbnz	r3, 80001a6 <__do_global_dtors_aux+0x16>
 8000198:	4b04      	ldr	r3, [pc, #16]	; (80001ac <__do_global_dtors_aux+0x1c>)
 800019a:	b113      	cbz	r3, 80001a2 <__do_global_dtors_aux+0x12>
 800019c:	4804      	ldr	r0, [pc, #16]	; (80001b0 <__do_global_dtors_aux+0x20>)
 800019e:	f3af 8000 	nop.w
 80001a2:	2301      	movs	r3, #1
 80001a4:	7023      	strb	r3, [r4, #0]
 80001a6:	bd10      	pop	{r4, pc}
 80001a8:	200001dc 	.word	0x200001dc
 80001ac:	00000000 	.word	0x00000000
 80001b0:	08008f7c 	.word	0x08008f7c

080001b4 <frame_dummy>:
 80001b4:	b508      	push	{r3, lr}
 80001b6:	4b03      	ldr	r3, [pc, #12]	; (80001c4 <frame_dummy+0x10>)
 80001b8:	b11b      	cbz	r3, 80001c2 <frame_dummy+0xe>
 80001ba:	4903      	ldr	r1, [pc, #12]	; (80001c8 <frame_dummy+0x14>)
 80001bc:	4803      	ldr	r0, [pc, #12]	; (80001cc <frame_dummy+0x18>)
 80001be:	f3af 8000 	nop.w
 80001c2:	bd08      	pop	{r3, pc}
 80001c4:	00000000 	.word	0x00000000
 80001c8:	200001e0 	.word	0x200001e0
 80001cc:	08008f7c 	.word	0x08008f7c

080001d0 <strlen>:
 80001d0:	4603      	mov	r3, r0
 80001d2:	f813 2b01 	ldrb.w	r2, [r3], #1
 80001d6:	2a00      	cmp	r2, #0
 80001d8:	d1fb      	bne.n	80001d2 <strlen+0x2>
 80001da:	1a18      	subs	r0, r3, r0
 80001dc:	3801      	subs	r0, #1
 80001de:	4770      	bx	lr

080001e0 <memchr>:
 80001e0:	f001 01ff 	and.w	r1, r1, #255	; 0xff
 80001e4:	2a10      	cmp	r2, #16
 80001e6:	db2b      	blt.n	8000240 <memchr+0x60>
 80001e8:	f010 0f07 	tst.w	r0, #7
 80001ec:	d008      	beq.n	8000200 <memchr+0x20>
 80001ee:	f810 3b01 	ldrb.w	r3, [r0], #1
 80001f2:	3a01      	subs	r2, #1
 80001f4:	428b      	cmp	r3, r1
 80001f6:	d02d      	beq.n	8000254 <memchr+0x74>
 80001f8:	f010 0f07 	tst.w	r0, #7
 80001fc:	b342      	cbz	r2, 8000250 <memchr+0x70>
 80001fe:	d1f6      	bne.n	80001ee <memchr+0xe>
 8000200:	b4f0      	push	{r4, r5, r6, r7}
 8000202:	ea41 2101 	orr.w	r1, r1, r1, lsl #8
 8000206:	ea41 4101 	orr.w	r1, r1, r1, lsl #16
 800020a:	f022 0407 	bic.w	r4, r2, #7
 800020e:	f07f 0700 	mvns.w	r7, #0
 8000212:	2300      	movs	r3, #0
 8000214:	e8f0 5602 	ldrd	r5, r6, [r0], #8
 8000218:	3c08      	subs	r4, #8
 800021a:	ea85 0501 	eor.w	r5, r5, r1
 800021e:	ea86 0601 	eor.w	r6, r6, r1
 8000222:	fa85 f547 	uadd8	r5, r5, r7
 8000226:	faa3 f587 	sel	r5, r3, r7
 800022a:	fa86 f647 	uadd8	r6, r6, r7
 800022e:	faa5 f687 	sel	r6, r5, r7
 8000232:	b98e      	cbnz	r6, 8000258 <memchr+0x78>
 8000234:	d1ee      	bne.n	8000214 <memchr+0x34>
 8000236:	bcf0      	pop	{r4, r5, r6, r7}
 8000238:	f001 01ff 	and.w	r1, r1, #255	; 0xff
 800023c:	f002 0207 	and.w	r2, r2, #7
 8000240:	b132      	cbz	r2, 8000250 <memchr+0x70>
 8000242:	f810 3b01 	ldrb.w	r3, [r0], #1
 8000246:	3a01      	subs	r2, #1
 8000248:	ea83 0301 	eor.w	r3, r3, r1
 800024c:	b113      	cbz	r3, 8000254 <memchr+0x74>
 800024e:	d1f8      	bne.n	8000242 <memchr+0x62>
 8000250:	2000      	movs	r0, #0
 8000252:	4770      	bx	lr
 8000254:	3801      	subs	r0, #1
 8000256:	4770      	bx	lr
 8000258:	2d00      	cmp	r5, #0
 800025a:	bf06      	itte	eq
 800025c:	4635      	moveq	r5, r6
 800025e:	3803      	subeq	r0, #3
 8000260:	3807      	subne	r0, #7
 8000262:	f015 0f01 	tst.w	r5, #1
 8000266:	d107      	bne.n	8000278 <memchr+0x98>
 8000268:	3001      	adds	r0, #1
 800026a:	f415 7f80 	tst.w	r5, #256	; 0x100
 800026e:	bf02      	ittt	eq
 8000270:	3001      	addeq	r0, #1
 8000272:	f415 3fc0 	tsteq.w	r5, #98304	; 0x18000
 8000276:	3001      	addeq	r0, #1
 8000278:	bcf0      	pop	{r4, r5, r6, r7}
 800027a:	3801      	subs	r0, #1
 800027c:	4770      	bx	lr
 800027e:	bf00      	nop

08000280 <__aeabi_drsub>:
 8000280:	f081 4100 	eor.w	r1, r1, #2147483648	; 0x80000000
 8000284:	e002      	b.n	800028c <__adddf3>
 8000286:	bf00      	nop

08000288 <__aeabi_dsub>:
 8000288:	f083 4300 	eor.w	r3, r3, #2147483648	; 0x80000000

0800028c <__adddf3>:
 800028c:	b530      	push	{r4, r5, lr}
 800028e:	ea4f 0441 	mov.w	r4, r1, lsl #1
 8000292:	ea4f 0543 	mov.w	r5, r3, lsl #1
 8000296:	ea94 0f05 	teq	r4, r5
 800029a:	bf08      	it	eq
 800029c:	ea90 0f02 	teqeq	r0, r2
 80002a0:	bf1f      	itttt	ne
 80002a2:	ea54 0c00 	orrsne.w	ip, r4, r0
 80002a6:	ea55 0c02 	orrsne.w	ip, r5, r2
 80002aa:	ea7f 5c64 	mvnsne.w	ip, r4, asr #21
 80002ae:	ea7f 5c65 	mvnsne.w	ip, r5, asr #21
 80002b2:	f000 80e2 	beq.w	800047a <__adddf3+0x1ee>
 80002b6:	ea4f 5454 	mov.w	r4, r4, lsr #21
 80002ba:	ebd4 5555 	rsbs	r5, r4, r5, lsr #21
 80002be:	bfb8      	it	lt
 80002c0:	426d      	neglt	r5, r5
 80002c2:	dd0c      	ble.n	80002de <__adddf3+0x52>
 80002c4:	442c      	add	r4, r5
 80002c6:	ea80 0202 	eor.w	r2, r0, r2
 80002ca:	ea81 0303 	eor.w	r3, r1, r3
 80002ce:	ea82 0000 	eor.w	r0, r2, r0
 80002d2:	ea83 0101 	eor.w	r1, r3, r1
 80002d6:	ea80 0202 	eor.w	r2, r0, r2
 80002da:	ea81 0303 	eor.w	r3, r1, r3
 80002de:	2d36      	cmp	r5, #54	; 0x36
 80002e0:	bf88      	it	hi
 80002e2:	bd30      	pophi	{r4, r5, pc}
 80002e4:	f011 4f00 	tst.w	r1, #2147483648	; 0x80000000
 80002e8:	ea4f 3101 	mov.w	r1, r1, lsl #12
 80002ec:	f44f 1c80 	mov.w	ip, #1048576	; 0x100000
 80002f0:	ea4c 3111 	orr.w	r1, ip, r1, lsr #12
 80002f4:	d002      	beq.n	80002fc <__adddf3+0x70>
 80002f6:	4240      	negs	r0, r0
 80002f8:	eb61 0141 	sbc.w	r1, r1, r1, lsl #1
 80002fc:	f013 4f00 	tst.w	r3, #2147483648	; 0x80000000
 8000300:	ea4f 3303 	mov.w	r3, r3, lsl #12
 8000304:	ea4c 3313 	orr.w	r3, ip, r3, lsr #12
 8000308:	d002      	beq.n	8000310 <__adddf3+0x84>
 800030a:	4252      	negs	r2, r2
 800030c:	eb63 0343 	sbc.w	r3, r3, r3, lsl #1
 8000310:	ea94 0f05 	teq	r4, r5
 8000314:	f000 80a7 	beq.w	8000466 <__adddf3+0x1da>
 8000318:	f1a4 0401 	sub.w	r4, r4, #1
 800031c:	f1d5 0e20 	rsbs	lr, r5, #32
 8000320:	db0d      	blt.n	800033e <__adddf3+0xb2>
 8000322:	fa02 fc0e 	lsl.w	ip, r2, lr
 8000326:	fa22 f205 	lsr.w	r2, r2, r5
 800032a:	1880      	adds	r0, r0, r2
 800032c:	f141 0100 	adc.w	r1, r1, #0
 8000330:	fa03 f20e 	lsl.w	r2, r3, lr
 8000334:	1880      	adds	r0, r0, r2
 8000336:	fa43 f305 	asr.w	r3, r3, r5
 800033a:	4159      	adcs	r1, r3
 800033c:	e00e      	b.n	800035c <__adddf3+0xd0>
 800033e:	f1a5 0520 	sub.w	r5, r5, #32
 8000342:	f10e 0e20 	add.w	lr, lr, #32
 8000346:	2a01      	cmp	r2, #1
 8000348:	fa03 fc0e 	lsl.w	ip, r3, lr
 800034c:	bf28      	it	cs
 800034e:	f04c 0c02 	orrcs.w	ip, ip, #2
 8000352:	fa43 f305 	asr.w	r3, r3, r5
 8000356:	18c0      	adds	r0, r0, r3
 8000358:	eb51 71e3 	adcs.w	r1, r1, r3, asr #31
 800035c:	f001 4500 	and.w	r5, r1, #2147483648	; 0x80000000
 8000360:	d507      	bpl.n	8000372 <__adddf3+0xe6>
 8000362:	f04f 0e00 	mov.w	lr, #0
 8000366:	f1dc 0c00 	rsbs	ip, ip, #0
 800036a:	eb7e 0000 	sbcs.w	r0, lr, r0
 800036e:	eb6e 0101 	sbc.w	r1, lr, r1
 8000372:	f5b1 1f80 	cmp.w	r1, #1048576	; 0x100000
 8000376:	d31b      	bcc.n	80003b0 <__adddf3+0x124>
 8000378:	f5b1 1f00 	cmp.w	r1, #2097152	; 0x200000
 800037c:	d30c      	bcc.n	8000398 <__adddf3+0x10c>
 800037e:	0849      	lsrs	r1, r1, #1
 8000380:	ea5f 0030 	movs.w	r0, r0, rrx
 8000384:	ea4f 0c3c 	mov.w	ip, ip, rrx
 8000388:	f104 0401 	add.w	r4, r4, #1
 800038c:	ea4f 5244 	mov.w	r2, r4, lsl #21
 8000390:	f512 0f80 	cmn.w	r2, #4194304	; 0x400000
 8000394:	f080 809a 	bcs.w	80004cc <__adddf3+0x240>
 8000398:	f1bc 4f00 	cmp.w	ip, #2147483648	; 0x80000000
 800039c:	bf08      	it	eq
 800039e:	ea5f 0c50 	movseq.w	ip, r0, lsr #1
 80003a2:	f150 0000 	adcs.w	r0, r0, #0
 80003a6:	eb41 5104 	adc.w	r1, r1, r4, lsl #20
 80003aa:	ea41 0105 	orr.w	r1, r1, r5
 80003ae:	bd30      	pop	{r4, r5, pc}
 80003b0:	ea5f 0c4c 	movs.w	ip, ip, lsl #1
 80003b4:	4140      	adcs	r0, r0
 80003b6:	eb41 0101 	adc.w	r1, r1, r1
 80003ba:	3c01      	subs	r4, #1
 80003bc:	bf28      	it	cs
 80003be:	f5b1 1f80 	cmpcs.w	r1, #1048576	; 0x100000
 80003c2:	d2e9      	bcs.n	8000398 <__adddf3+0x10c>
 80003c4:	f091 0f00 	teq	r1, #0
 80003c8:	bf04      	itt	eq
 80003ca:	4601      	moveq	r1, r0
 80003cc:	2000      	moveq	r0, #0
 80003ce:	fab1 f381 	clz	r3, r1
 80003d2:	bf08      	it	eq
 80003d4:	3320      	addeq	r3, #32
 80003d6:	f1a3 030b 	sub.w	r3, r3, #11
 80003da:	f1b3 0220 	subs.w	r2, r3, #32
 80003de:	da0c      	bge.n	80003fa <__adddf3+0x16e>
 80003e0:	320c      	adds	r2, #12
 80003e2:	dd08      	ble.n	80003f6 <__adddf3+0x16a>
 80003e4:	f102 0c14 	add.w	ip, r2, #20
 80003e8:	f1c2 020c 	rsb	r2, r2, #12
 80003ec:	fa01 f00c 	lsl.w	r0, r1, ip
 80003f0:	fa21 f102 	lsr.w	r1, r1, r2
 80003f4:	e00c      	b.n	8000410 <__adddf3+0x184>
 80003f6:	f102 0214 	add.w	r2, r2, #20
 80003fa:	bfd8      	it	le
 80003fc:	f1c2 0c20 	rsble	ip, r2, #32
 8000400:	fa01 f102 	lsl.w	r1, r1, r2
 8000404:	fa20 fc0c 	lsr.w	ip, r0, ip
 8000408:	bfdc      	itt	le
 800040a:	ea41 010c 	orrle.w	r1, r1, ip
 800040e:	4090      	lslle	r0, r2
 8000410:	1ae4      	subs	r4, r4, r3
 8000412:	bfa2      	ittt	ge
 8000414:	eb01 5104 	addge.w	r1, r1, r4, lsl #20
 8000418:	4329      	orrge	r1, r5
 800041a:	bd30      	popge	{r4, r5, pc}
 800041c:	ea6f 0404 	mvn.w	r4, r4
 8000420:	3c1f      	subs	r4, #31
 8000422:	da1c      	bge.n	800045e <__adddf3+0x1d2>
 8000424:	340c      	adds	r4, #12
 8000426:	dc0e      	bgt.n	8000446 <__adddf3+0x1ba>
 8000428:	f104 0414 	add.w	r4, r4, #20
 800042c:	f1c4 0220 	rsb	r2, r4, #32
 8000430:	fa20 f004 	lsr.w	r0, r0, r4
 8000434:	fa01 f302 	lsl.w	r3, r1, r2
 8000438:	ea40 0003 	orr.w	r0, r0, r3
 800043c:	fa21 f304 	lsr.w	r3, r1, r4
 8000440:	ea45 0103 	orr.w	r1, r5, r3
 8000444:	bd30      	pop	{r4, r5, pc}
 8000446:	f1c4 040c 	rsb	r4, r4, #12
 800044a:	f1c4 0220 	rsb	r2, r4, #32
 800044e:	fa20 f002 	lsr.w	r0, r0, r2
 8000452:	fa01 f304 	lsl.w	r3, r1, r4
 8000456:	ea40 0003 	orr.w	r0, r0, r3
 800045a:	4629      	mov	r1, r5
 800045c:	bd30      	pop	{r4, r5, pc}
 800045e:	fa21 f004 	lsr.w	r0, r1, r4
 8000462:	4629      	mov	r1, r5
 8000464:	bd30      	pop	{r4, r5, pc}
 8000466:	f094 0f00 	teq	r4, #0
 800046a:	f483 1380 	eor.w	r3, r3, #1048576	; 0x100000
 800046e:	bf06      	itte	eq
 8000470:	f481 1180 	eoreq.w	r1, r1, #1048576	; 0x100000
 8000474:	3401      	addeq	r4, #1
 8000476:	3d01      	subne	r5, #1
 8000478:	e74e      	b.n	8000318 <__adddf3+0x8c>
 800047a:	ea7f 5c64 	mvns.w	ip, r4, asr #21
 800047e:	bf18      	it	ne
 8000480:	ea7f 5c65 	mvnsne.w	ip, r5, asr #21
 8000484:	d029      	beq.n	80004da <__adddf3+0x24e>
 8000486:	ea94 0f05 	teq	r4, r5
 800048a:	bf08      	it	eq
 800048c:	ea90 0f02 	teqeq	r0, r2
 8000490:	d005      	beq.n	800049e <__adddf3+0x212>
 8000492:	ea54 0c00 	orrs.w	ip, r4, r0
 8000496:	bf04      	itt	eq
 8000498:	4619      	moveq	r1, r3
 800049a:	4610      	moveq	r0, r2
 800049c:	bd30      	pop	{r4, r5, pc}
 800049e:	ea91 0f03 	teq	r1, r3
 80004a2:	bf1e      	ittt	ne
 80004a4:	2100      	movne	r1, #0
 80004a6:	2000      	movne	r0, #0
 80004a8:	bd30      	popne	{r4, r5, pc}
 80004aa:	ea5f 5c54 	movs.w	ip, r4, lsr #21
 80004ae:	d105      	bne.n	80004bc <__adddf3+0x230>
 80004b0:	0040      	lsls	r0, r0, #1
 80004b2:	4149      	adcs	r1, r1
 80004b4:	bf28      	it	cs
 80004b6:	f041 4100 	orrcs.w	r1, r1, #2147483648	; 0x80000000
 80004ba:	bd30      	pop	{r4, r5, pc}
 80004bc:	f514 0480 	adds.w	r4, r4, #4194304	; 0x400000
 80004c0:	bf3c      	itt	cc
 80004c2:	f501 1180 	addcc.w	r1, r1, #1048576	; 0x100000
 80004c6:	bd30      	popcc	{r4, r5, pc}
 80004c8:	f001 4500 	and.w	r5, r1, #2147483648	; 0x80000000
 80004cc:	f045 41fe 	orr.w	r1, r5, #2130706432	; 0x7f000000
 80004d0:	f441 0170 	orr.w	r1, r1, #15728640	; 0xf00000
 80004d4:	f04f 0000 	mov.w	r0, #0
 80004d8:	bd30      	pop	{r4, r5, pc}
 80004da:	ea7f 5c64 	mvns.w	ip, r4, asr #21
 80004de:	bf1a      	itte	ne
 80004e0:	4619      	movne	r1, r3
 80004e2:	4610      	movne	r0, r2
 80004e4:	ea7f 5c65 	mvnseq.w	ip, r5, asr #21
 80004e8:	bf1c      	itt	ne
 80004ea:	460b      	movne	r3, r1
 80004ec:	4602      	movne	r2, r0
 80004ee:	ea50 3401 	orrs.w	r4, r0, r1, lsl #12
 80004f2:	bf06      	itte	eq
 80004f4:	ea52 3503 	orrseq.w	r5, r2, r3, lsl #12
 80004f8:	ea91 0f03 	teqeq	r1, r3
 80004fc:	f441 2100 	orrne.w	r1, r1, #524288	; 0x80000
 8000500:	bd30      	pop	{r4, r5, pc}
 8000502:	bf00      	nop

08000504 <__aeabi_ui2d>:
 8000504:	f090 0f00 	teq	r0, #0
 8000508:	bf04      	itt	eq
 800050a:	2100      	moveq	r1, #0
 800050c:	4770      	bxeq	lr
 800050e:	b530      	push	{r4, r5, lr}
 8000510:	f44f 6480 	mov.w	r4, #1024	; 0x400
 8000514:	f104 0432 	add.w	r4, r4, #50	; 0x32
 8000518:	f04f 0500 	mov.w	r5, #0
 800051c:	f04f 0100 	mov.w	r1, #0
 8000520:	e750      	b.n	80003c4 <__adddf3+0x138>
 8000522:	bf00      	nop

08000524 <__aeabi_i2d>:
 8000524:	f090 0f00 	teq	r0, #0
 8000528:	bf04      	itt	eq
 800052a:	2100      	moveq	r1, #0
 800052c:	4770      	bxeq	lr
 800052e:	b530      	push	{r4, r5, lr}
 8000530:	f44f 6480 	mov.w	r4, #1024	; 0x400
 8000534:	f104 0432 	add.w	r4, r4, #50	; 0x32
 8000538:	f010 4500 	ands.w	r5, r0, #2147483648	; 0x80000000
 800053c:	bf48      	it	mi
 800053e:	4240      	negmi	r0, r0
 8000540:	f04f 0100 	mov.w	r1, #0
 8000544:	e73e      	b.n	80003c4 <__adddf3+0x138>
 8000546:	bf00      	nop

08000548 <__aeabi_f2d>:
 8000548:	0042      	lsls	r2, r0, #1
 800054a:	ea4f 01e2 	mov.w	r1, r2, asr #3
 800054e:	ea4f 0131 	mov.w	r1, r1, rrx
 8000552:	ea4f 7002 	mov.w	r0, r2, lsl #28
 8000556:	bf1f      	itttt	ne
 8000558:	f012 437f 	andsne.w	r3, r2, #4278190080	; 0xff000000
 800055c:	f093 4f7f 	teqne	r3, #4278190080	; 0xff000000
 8000560:	f081 5160 	eorne.w	r1, r1, #939524096	; 0x38000000
 8000564:	4770      	bxne	lr
 8000566:	f032 427f 	bics.w	r2, r2, #4278190080	; 0xff000000
 800056a:	bf08      	it	eq
 800056c:	4770      	bxeq	lr
 800056e:	f093 4f7f 	teq	r3, #4278190080	; 0xff000000
 8000572:	bf04      	itt	eq
 8000574:	f441 2100 	orreq.w	r1, r1, #524288	; 0x80000
 8000578:	4770      	bxeq	lr
 800057a:	b530      	push	{r4, r5, lr}
 800057c:	f44f 7460 	mov.w	r4, #896	; 0x380
 8000580:	f001 4500 	and.w	r5, r1, #2147483648	; 0x80000000
 8000584:	f021 4100 	bic.w	r1, r1, #2147483648	; 0x80000000
 8000588:	e71c      	b.n	80003c4 <__adddf3+0x138>
 800058a:	bf00      	nop

0800058c <__aeabi_ul2d>:
 800058c:	ea50 0201 	orrs.w	r2, r0, r1
 8000590:	bf08      	it	eq
 8000592:	4770      	bxeq	lr
 8000594:	b530      	push	{r4, r5, lr}
 8000596:	f04f 0500 	mov.w	r5, #0
 800059a:	e00a      	b.n	80005b2 <__aeabi_l2d+0x16>

0800059c <__aeabi_l2d>:
 800059c:	ea50 0201 	orrs.w	r2, r0, r1
 80005a0:	bf08      	it	eq
 80005a2:	4770      	bxeq	lr
 80005a4:	b530      	push	{r4, r5, lr}
 80005a6:	f011 4500 	ands.w	r5, r1, #2147483648	; 0x80000000
 80005aa:	d502      	bpl.n	80005b2 <__aeabi_l2d+0x16>
 80005ac:	4240      	negs	r0, r0
 80005ae:	eb61 0141 	sbc.w	r1, r1, r1, lsl #1
 80005b2:	f44f 6480 	mov.w	r4, #1024	; 0x400
 80005b6:	f104 0432 	add.w	r4, r4, #50	; 0x32
 80005ba:	ea5f 5c91 	movs.w	ip, r1, lsr #22
 80005be:	f43f aed8 	beq.w	8000372 <__adddf3+0xe6>
 80005c2:	f04f 0203 	mov.w	r2, #3
 80005c6:	ea5f 0cdc 	movs.w	ip, ip, lsr #3
 80005ca:	bf18      	it	ne
 80005cc:	3203      	addne	r2, #3
 80005ce:	ea5f 0cdc 	movs.w	ip, ip, lsr #3
 80005d2:	bf18      	it	ne
 80005d4:	3203      	addne	r2, #3
 80005d6:	eb02 02dc 	add.w	r2, r2, ip, lsr #3
 80005da:	f1c2 0320 	rsb	r3, r2, #32
 80005de:	fa00 fc03 	lsl.w	ip, r0, r3
 80005e2:	fa20 f002 	lsr.w	r0, r0, r2
 80005e6:	fa01 fe03 	lsl.w	lr, r1, r3
 80005ea:	ea40 000e 	orr.w	r0, r0, lr
 80005ee:	fa21 f102 	lsr.w	r1, r1, r2
 80005f2:	4414      	add	r4, r2
 80005f4:	e6bd      	b.n	8000372 <__adddf3+0xe6>
 80005f6:	bf00      	nop

080005f8 <__aeabi_dmul>:
 80005f8:	b570      	push	{r4, r5, r6, lr}
 80005fa:	f04f 0cff 	mov.w	ip, #255	; 0xff
 80005fe:	f44c 6ce0 	orr.w	ip, ip, #1792	; 0x700
 8000602:	ea1c 5411 	ands.w	r4, ip, r1, lsr #20
 8000606:	bf1d      	ittte	ne
 8000608:	ea1c 5513 	andsne.w	r5, ip, r3, lsr #20
 800060c:	ea94 0f0c 	teqne	r4, ip
 8000610:	ea95 0f0c 	teqne	r5, ip
 8000614:	f000 f8de 	bleq	80007d4 <__aeabi_dmul+0x1dc>
 8000618:	442c      	add	r4, r5
 800061a:	ea81 0603 	eor.w	r6, r1, r3
 800061e:	ea21 514c 	bic.w	r1, r1, ip, lsl #21
 8000622:	ea23 534c 	bic.w	r3, r3, ip, lsl #21
 8000626:	ea50 3501 	orrs.w	r5, r0, r1, lsl #12
 800062a:	bf18      	it	ne
 800062c:	ea52 3503 	orrsne.w	r5, r2, r3, lsl #12
 8000630:	f441 1180 	orr.w	r1, r1, #1048576	; 0x100000
 8000634:	f443 1380 	orr.w	r3, r3, #1048576	; 0x100000
 8000638:	d038      	beq.n	80006ac <__aeabi_dmul+0xb4>
 800063a:	fba0 ce02 	umull	ip, lr, r0, r2
 800063e:	f04f 0500 	mov.w	r5, #0
 8000642:	fbe1 e502 	umlal	lr, r5, r1, r2
 8000646:	f006 4200 	and.w	r2, r6, #2147483648	; 0x80000000
 800064a:	fbe0 e503 	umlal	lr, r5, r0, r3
 800064e:	f04f 0600 	mov.w	r6, #0
 8000652:	fbe1 5603 	umlal	r5, r6, r1, r3
 8000656:	f09c 0f00 	teq	ip, #0
 800065a:	bf18      	it	ne
 800065c:	f04e 0e01 	orrne.w	lr, lr, #1
 8000660:	f1a4 04ff 	sub.w	r4, r4, #255	; 0xff
 8000664:	f5b6 7f00 	cmp.w	r6, #512	; 0x200
 8000668:	f564 7440 	sbc.w	r4, r4, #768	; 0x300
 800066c:	d204      	bcs.n	8000678 <__aeabi_dmul+0x80>
 800066e:	ea5f 0e4e 	movs.w	lr, lr, lsl #1
 8000672:	416d      	adcs	r5, r5
 8000674:	eb46 0606 	adc.w	r6, r6, r6
 8000678:	ea42 21c6 	orr.w	r1, r2, r6, lsl #11
 800067c:	ea41 5155 	orr.w	r1, r1, r5, lsr #21
 8000680:	ea4f 20c5 	mov.w	r0, r5, lsl #11
 8000684:	ea40 505e 	orr.w	r0, r0, lr, lsr #21
 8000688:	ea4f 2ece 	mov.w	lr, lr, lsl #11
 800068c:	f1b4 0cfd 	subs.w	ip, r4, #253	; 0xfd
 8000690:	bf88      	it	hi
 8000692:	f5bc 6fe0 	cmphi.w	ip, #1792	; 0x700
 8000696:	d81e      	bhi.n	80006d6 <__aeabi_dmul+0xde>
 8000698:	f1be 4f00 	cmp.w	lr, #2147483648	; 0x80000000
 800069c:	bf08      	it	eq
 800069e:	ea5f 0e50 	movseq.w	lr, r0, lsr #1
 80006a2:	f150 0000 	adcs.w	r0, r0, #0
 80006a6:	eb41 5104 	adc.w	r1, r1, r4, lsl #20
 80006aa:	bd70      	pop	{r4, r5, r6, pc}
 80006ac:	f006 4600 	and.w	r6, r6, #2147483648	; 0x80000000
 80006b0:	ea46 0101 	orr.w	r1, r6, r1
 80006b4:	ea40 0002 	orr.w	r0, r0, r2
 80006b8:	ea81 0103 	eor.w	r1, r1, r3
 80006bc:	ebb4 045c 	subs.w	r4, r4, ip, lsr #1
 80006c0:	bfc2      	ittt	gt
 80006c2:	ebd4 050c 	rsbsgt	r5, r4, ip
 80006c6:	ea41 5104 	orrgt.w	r1, r1, r4, lsl #20
 80006ca:	bd70      	popgt	{r4, r5, r6, pc}
 80006cc:	f441 1180 	orr.w	r1, r1, #1048576	; 0x100000
 80006d0:	f04f 0e00 	mov.w	lr, #0
 80006d4:	3c01      	subs	r4, #1
 80006d6:	f300 80ab 	bgt.w	8000830 <__aeabi_dmul+0x238>
 80006da:	f114 0f36 	cmn.w	r4, #54	; 0x36
 80006de:	bfde      	ittt	le
 80006e0:	2000      	movle	r0, #0
 80006e2:	f001 4100 	andle.w	r1, r1, #2147483648	; 0x80000000
 80006e6:	bd70      	pople	{r4, r5, r6, pc}
 80006e8:	f1c4 0400 	rsb	r4, r4, #0
 80006ec:	3c20      	subs	r4, #32
 80006ee:	da35      	bge.n	800075c <__aeabi_dmul+0x164>
 80006f0:	340c      	adds	r4, #12
 80006f2:	dc1b      	bgt.n	800072c <__aeabi_dmul+0x134>
 80006f4:	f104 0414 	add.w	r4, r4, #20
 80006f8:	f1c4 0520 	rsb	r5, r4, #32
 80006fc:	fa00 f305 	lsl.w	r3, r0, r5
 8000700:	fa20 f004 	lsr.w	r0, r0, r4
 8000704:	fa01 f205 	lsl.w	r2, r1, r5
 8000708:	ea40 0002 	orr.w	r0, r0, r2
 800070c:	f001 4200 	and.w	r2, r1, #2147483648	; 0x80000000
 8000710:	f021 4100 	bic.w	r1, r1, #2147483648	; 0x80000000
 8000714:	eb10 70d3 	adds.w	r0, r0, r3, lsr #31
 8000718:	fa21 f604 	lsr.w	r6, r1, r4
 800071c:	eb42 0106 	adc.w	r1, r2, r6
 8000720:	ea5e 0e43 	orrs.w	lr, lr, r3, lsl #1
 8000724:	bf08      	it	eq
 8000726:	ea20 70d3 	biceq.w	r0, r0, r3, lsr #31
 800072a:	bd70      	pop	{r4, r5, r6, pc}
 800072c:	f1c4 040c 	rsb	r4, r4, #12
 8000730:	f1c4 0520 	rsb	r5, r4, #32
 8000734:	fa00 f304 	lsl.w	r3, r0, r4
 8000738:	fa20 f005 	lsr.w	r0, r0, r5
 800073c:	fa01 f204 	lsl.w	r2, r1, r4
 8000740:	ea40 0002 	orr.w	r0, r0, r2
 8000744:	f001 4100 	and.w	r1, r1, #2147483648	; 0x80000000
 8000748:	eb10 70d3 	adds.w	r0, r0, r3, lsr #31
 800074c:	f141 0100 	adc.w	r1, r1, #0
 8000750:	ea5e 0e43 	orrs.w	lr, lr, r3, lsl #1
 8000754:	bf08      	it	eq
 8000756:	ea20 70d3 	biceq.w	r0, r0, r3, lsr #31
 800075a:	bd70      	pop	{r4, r5, r6, pc}
 800075c:	f1c4 0520 	rsb	r5, r4, #32
 8000760:	fa00 f205 	lsl.w	r2, r0, r5
 8000764:	ea4e 0e02 	orr.w	lr, lr, r2
 8000768:	fa20 f304 	lsr.w	r3, r0, r4
 800076c:	fa01 f205 	lsl.w	r2, r1, r5
 8000770:	ea43 0302 	orr.w	r3, r3, r2
 8000774:	fa21 f004 	lsr.w	r0, r1, r4
 8000778:	f001 4100 	and.w	r1, r1, #2147483648	; 0x80000000
 800077c:	fa21 f204 	lsr.w	r2, r1, r4
 8000780:	ea20 0002 	bic.w	r0, r0, r2
 8000784:	eb00 70d3 	add.w	r0, r0, r3, lsr #31
 8000788:	ea5e 0e43 	orrs.w	lr, lr, r3, lsl #1
 800078c:	bf08      	it	eq
 800078e:	ea20 70d3 	biceq.w	r0, r0, r3, lsr #31
 8000792:	bd70      	pop	{r4, r5, r6, pc}
 8000794:	f094 0f00 	teq	r4, #0
 8000798:	d10f      	bne.n	80007ba <__aeabi_dmul+0x1c2>
 800079a:	f001 4600 	and.w	r6, r1, #2147483648	; 0x80000000
 800079e:	0040      	lsls	r0, r0, #1
 80007a0:	eb41 0101 	adc.w	r1, r1, r1
 80007a4:	f411 1f80 	tst.w	r1, #1048576	; 0x100000
 80007a8:	bf08      	it	eq
 80007aa:	3c01      	subeq	r4, #1
 80007ac:	d0f7      	beq.n	800079e <__aeabi_dmul+0x1a6>
 80007ae:	ea41 0106 	orr.w	r1, r1, r6
 80007b2:	f095 0f00 	teq	r5, #0
 80007b6:	bf18      	it	ne
 80007b8:	4770      	bxne	lr
 80007ba:	f003 4600 	and.w	r6, r3, #2147483648	; 0x80000000
 80007be:	0052      	lsls	r2, r2, #1
 80007c0:	eb43 0303 	adc.w	r3, r3, r3
 80007c4:	f413 1f80 	tst.w	r3, #1048576	; 0x100000
 80007c8:	bf08      	it	eq
 80007ca:	3d01      	subeq	r5, #1
 80007cc:	d0f7      	beq.n	80007be <__aeabi_dmul+0x1c6>
 80007ce:	ea43 0306 	orr.w	r3, r3, r6
 80007d2:	4770      	bx	lr
 80007d4:	ea94 0f0c 	teq	r4, ip
 80007d8:	ea0c 5513 	and.w	r5, ip, r3, lsr #20
 80007dc:	bf18      	it	ne
 80007de:	ea95 0f0c 	teqne	r5, ip
 80007e2:	d00c      	beq.n	80007fe <__aeabi_dmul+0x206>
 80007e4:	ea50 0641 	orrs.w	r6, r0, r1, lsl #1
 80007e8:	bf18      	it	ne
 80007ea:	ea52 0643 	orrsne.w	r6, r2, r3, lsl #1
 80007ee:	d1d1      	bne.n	8000794 <__aeabi_dmul+0x19c>
 80007f0:	ea81 0103 	eor.w	r1, r1, r3
 80007f4:	f001 4100 	and.w	r1, r1, #2147483648	; 0x80000000
 80007f8:	f04f 0000 	mov.w	r0, #0
 80007fc:	bd70      	pop	{r4, r5, r6, pc}
 80007fe:	ea50 0641 	orrs.w	r6, r0, r1, lsl #1
 8000802:	bf06      	itte	eq
 8000804:	4610      	moveq	r0, r2
 8000806:	4619      	moveq	r1, r3
 8000808:	ea52 0643 	orrsne.w	r6, r2, r3, lsl #1
 800080c:	d019      	beq.n	8000842 <__aeabi_dmul+0x24a>
 800080e:	ea94 0f0c 	teq	r4, ip
 8000812:	d102      	bne.n	800081a <__aeabi_dmul+0x222>
 8000814:	ea50 3601 	orrs.w	r6, r0, r1, lsl #12
 8000818:	d113      	bne.n	8000842 <__aeabi_dmul+0x24a>
 800081a:	ea95 0f0c 	teq	r5, ip
 800081e:	d105      	bne.n	800082c <__aeabi_dmul+0x234>
 8000820:	ea52 3603 	orrs.w	r6, r2, r3, lsl #12
 8000824:	bf1c      	itt	ne
 8000826:	4610      	movne	r0, r2
 8000828:	4619      	movne	r1, r3
 800082a:	d10a      	bne.n	8000842 <__aeabi_dmul+0x24a>
 800082c:	ea81 0103 	eor.w	r1, r1, r3
 8000830:	f001 4100 	and.w	r1, r1, #2147483648	; 0x80000000
 8000834:	f041 41fe 	orr.w	r1, r1, #2130706432	; 0x7f000000
 8000838:	f441 0170 	orr.w	r1, r1, #15728640	; 0xf00000
 800083c:	f04f 0000 	mov.w	r0, #0
 8000840:	bd70      	pop	{r4, r5, r6, pc}
 8000842:	f041 41fe 	orr.w	r1, r1, #2130706432	; 0x7f000000
 8000846:	f441 0178 	orr.w	r1, r1, #16252928	; 0xf80000
 800084a:	bd70      	pop	{r4, r5, r6, pc}

0800084c <__aeabi_ddiv>:
 800084c:	b570      	push	{r4, r5, r6, lr}
 800084e:	f04f 0cff 	mov.w	ip, #255	; 0xff
 8000852:	f44c 6ce0 	orr.w	ip, ip, #1792	; 0x700
 8000856:	ea1c 5411 	ands.w	r4, ip, r1, lsr #20
 800085a:	bf1d      	ittte	ne
 800085c:	ea1c 5513 	andsne.w	r5, ip, r3, lsr #20
 8000860:	ea94 0f0c 	teqne	r4, ip
 8000864:	ea95 0f0c 	teqne	r5, ip
 8000868:	f000 f8a7 	bleq	80009ba <__aeabi_ddiv+0x16e>
 800086c:	eba4 0405 	sub.w	r4, r4, r5
 8000870:	ea81 0e03 	eor.w	lr, r1, r3
 8000874:	ea52 3503 	orrs.w	r5, r2, r3, lsl #12
 8000878:	ea4f 3101 	mov.w	r1, r1, lsl #12
 800087c:	f000 8088 	beq.w	8000990 <__aeabi_ddiv+0x144>
 8000880:	ea4f 3303 	mov.w	r3, r3, lsl #12
 8000884:	f04f 5580 	mov.w	r5, #268435456	; 0x10000000
 8000888:	ea45 1313 	orr.w	r3, r5, r3, lsr #4
 800088c:	ea43 6312 	orr.w	r3, r3, r2, lsr #24
 8000890:	ea4f 2202 	mov.w	r2, r2, lsl #8
 8000894:	ea45 1511 	orr.w	r5, r5, r1, lsr #4
 8000898:	ea45 6510 	orr.w	r5, r5, r0, lsr #24
 800089c:	ea4f 2600 	mov.w	r6, r0, lsl #8
 80008a0:	f00e 4100 	and.w	r1, lr, #2147483648	; 0x80000000
 80008a4:	429d      	cmp	r5, r3
 80008a6:	bf08      	it	eq
 80008a8:	4296      	cmpeq	r6, r2
 80008aa:	f144 04fd 	adc.w	r4, r4, #253	; 0xfd
 80008ae:	f504 7440 	add.w	r4, r4, #768	; 0x300
 80008b2:	d202      	bcs.n	80008ba <__aeabi_ddiv+0x6e>
 80008b4:	085b      	lsrs	r3, r3, #1
 80008b6:	ea4f 0232 	mov.w	r2, r2, rrx
 80008ba:	1ab6      	subs	r6, r6, r2
 80008bc:	eb65 0503 	sbc.w	r5, r5, r3
 80008c0:	085b      	lsrs	r3, r3, #1
 80008c2:	ea4f 0232 	mov.w	r2, r2, rrx
 80008c6:	f44f 1080 	mov.w	r0, #1048576	; 0x100000
 80008ca:	f44f 2c00 	mov.w	ip, #524288	; 0x80000
 80008ce:	ebb6 0e02 	subs.w	lr, r6, r2
 80008d2:	eb75 0e03 	sbcs.w	lr, r5, r3
 80008d6:	bf22      	ittt	cs
 80008d8:	1ab6      	subcs	r6, r6, r2
 80008da:	4675      	movcs	r5, lr
 80008dc:	ea40 000c 	orrcs.w	r0, r0, ip
 80008e0:	085b      	lsrs	r3, r3, #1
 80008e2:	ea4f 0232 	mov.w	r2, r2, rrx
 80008e6:	ebb6 0e02 	subs.w	lr, r6, r2
 80008ea:	eb75 0e03 	sbcs.w	lr, r5, r3
 80008ee:	bf22      	ittt	cs
 80008f0:	1ab6      	subcs	r6, r6, r2
 80008f2:	4675      	movcs	r5, lr
 80008f4:	ea40 005c 	orrcs.w	r0, r0, ip, lsr #1
 80008f8:	085b      	lsrs	r3, r3, #1
 80008fa:	ea4f 0232 	mov.w	r2, r2, rrx
 80008fe:	ebb6 0e02 	subs.w	lr, r6, r2
 8000902:	eb75 0e03 	sbcs.w	lr, r5, r3
 8000906:	bf22      	ittt	cs
 8000908:	1ab6      	subcs	r6, r6, r2
 800090a:	4675      	movcs	r5, lr
 800090c:	ea40 009c 	orrcs.w	r0, r0, ip, lsr #2
 8000910:	085b      	lsrs	r3, r3, #1
 8000912:	ea4f 0232 	mov.w	r2, r2, rrx
 8000916:	ebb6 0e02 	subs.w	lr, r6, r2
 800091a:	eb75 0e03 	sbcs.w	lr, r5, r3
 800091e:	bf22      	ittt	cs
 8000920:	1ab6      	subcs	r6, r6, r2
 8000922:	4675      	movcs	r5, lr
 8000924:	ea40 00dc 	orrcs.w	r0, r0, ip, lsr #3
 8000928:	ea55 0e06 	orrs.w	lr, r5, r6
 800092c:	d018      	beq.n	8000960 <__aeabi_ddiv+0x114>
 800092e:	ea4f 1505 	mov.w	r5, r5, lsl #4
 8000932:	ea45 7516 	orr.w	r5, r5, r6, lsr #28
 8000936:	ea4f 1606 	mov.w	r6, r6, lsl #4
 800093a:	ea4f 03c3 	mov.w	r3, r3, lsl #3
 800093e:	ea43 7352 	orr.w	r3, r3, r2, lsr #29
 8000942:	ea4f 02c2 	mov.w	r2, r2, lsl #3
 8000946:	ea5f 1c1c 	movs.w	ip, ip, lsr #4
 800094a:	d1c0      	bne.n	80008ce <__aeabi_ddiv+0x82>
 800094c:	f411 1f80 	tst.w	r1, #1048576	; 0x100000
 8000950:	d10b      	bne.n	800096a <__aeabi_ddiv+0x11e>
 8000952:	ea41 0100 	orr.w	r1, r1, r0
 8000956:	f04f 0000 	mov.w	r0, #0
 800095a:	f04f 4c00 	mov.w	ip, #2147483648	; 0x80000000
 800095e:	e7b6      	b.n	80008ce <__aeabi_ddiv+0x82>
 8000960:	f411 1f80 	tst.w	r1, #1048576	; 0x100000
 8000964:	bf04      	itt	eq
 8000966:	4301      	orreq	r1, r0
 8000968:	2000      	moveq	r0, #0
 800096a:	f1b4 0cfd 	subs.w	ip, r4, #253	; 0xfd
 800096e:	bf88      	it	hi
 8000970:	f5bc 6fe0 	cmphi.w	ip, #1792	; 0x700
 8000974:	f63f aeaf 	bhi.w	80006d6 <__aeabi_dmul+0xde>
 8000978:	ebb5 0c03 	subs.w	ip, r5, r3
 800097c:	bf04      	itt	eq
 800097e:	ebb6 0c02 	subseq.w	ip, r6, r2
 8000982:	ea5f 0c50 	movseq.w	ip, r0, lsr #1
 8000986:	f150 0000 	adcs.w	r0, r0, #0
 800098a:	eb41 5104 	adc.w	r1, r1, r4, lsl #20
 800098e:	bd70      	pop	{r4, r5, r6, pc}
 8000990:	f00e 4e00 	and.w	lr, lr, #2147483648	; 0x80000000
 8000994:	ea4e 3111 	orr.w	r1, lr, r1, lsr #12
 8000998:	eb14 045c 	adds.w	r4, r4, ip, lsr #1
 800099c:	bfc2      	ittt	gt
 800099e:	ebd4 050c 	rsbsgt	r5, r4, ip
 80009a2:	ea41 5104 	orrgt.w	r1, r1, r4, lsl #20
 80009a6:	bd70      	popgt	{r4, r5, r6, pc}
 80009a8:	f441 1180 	orr.w	r1, r1, #1048576	; 0x100000
 80009ac:	f04f 0e00 	mov.w	lr, #0
 80009b0:	3c01      	subs	r4, #1
 80009b2:	e690      	b.n	80006d6 <__aeabi_dmul+0xde>
 80009b4:	ea45 0e06 	orr.w	lr, r5, r6
 80009b8:	e68d      	b.n	80006d6 <__aeabi_dmul+0xde>
 80009ba:	ea0c 5513 	and.w	r5, ip, r3, lsr #20
 80009be:	ea94 0f0c 	teq	r4, ip
 80009c2:	bf08      	it	eq
 80009c4:	ea95 0f0c 	teqeq	r5, ip
 80009c8:	f43f af3b 	beq.w	8000842 <__aeabi_dmul+0x24a>
 80009cc:	ea94 0f0c 	teq	r4, ip
 80009d0:	d10a      	bne.n	80009e8 <__aeabi_ddiv+0x19c>
 80009d2:	ea50 3401 	orrs.w	r4, r0, r1, lsl #12
 80009d6:	f47f af34 	bne.w	8000842 <__aeabi_dmul+0x24a>
 80009da:	ea95 0f0c 	teq	r5, ip
 80009de:	f47f af25 	bne.w	800082c <__aeabi_dmul+0x234>
 80009e2:	4610      	mov	r0, r2
 80009e4:	4619      	mov	r1, r3
 80009e6:	e72c      	b.n	8000842 <__aeabi_dmul+0x24a>
 80009e8:	ea95 0f0c 	teq	r5, ip
 80009ec:	d106      	bne.n	80009fc <__aeabi_ddiv+0x1b0>
 80009ee:	ea52 3503 	orrs.w	r5, r2, r3, lsl #12
 80009f2:	f43f aefd 	beq.w	80007f0 <__aeabi_dmul+0x1f8>
 80009f6:	4610      	mov	r0, r2
 80009f8:	4619      	mov	r1, r3
 80009fa:	e722      	b.n	8000842 <__aeabi_dmul+0x24a>
 80009fc:	ea50 0641 	orrs.w	r6, r0, r1, lsl #1
 8000a00:	bf18      	it	ne
 8000a02:	ea52 0643 	orrsne.w	r6, r2, r3, lsl #1
 8000a06:	f47f aec5 	bne.w	8000794 <__aeabi_dmul+0x19c>
 8000a0a:	ea50 0441 	orrs.w	r4, r0, r1, lsl #1
 8000a0e:	f47f af0d 	bne.w	800082c <__aeabi_dmul+0x234>
 8000a12:	ea52 0543 	orrs.w	r5, r2, r3, lsl #1
 8000a16:	f47f aeeb 	bne.w	80007f0 <__aeabi_dmul+0x1f8>
 8000a1a:	e712      	b.n	8000842 <__aeabi_dmul+0x24a>

08000a1c <__gedf2>:
 8000a1c:	f04f 3cff 	mov.w	ip, #4294967295
 8000a20:	e006      	b.n	8000a30 <__cmpdf2+0x4>
 8000a22:	bf00      	nop

08000a24 <__ledf2>:
 8000a24:	f04f 0c01 	mov.w	ip, #1
 8000a28:	e002      	b.n	8000a30 <__cmpdf2+0x4>
 8000a2a:	bf00      	nop

08000a2c <__cmpdf2>:
 8000a2c:	f04f 0c01 	mov.w	ip, #1
 8000a30:	f84d cd04 	str.w	ip, [sp, #-4]!
 8000a34:	ea4f 0c41 	mov.w	ip, r1, lsl #1
 8000a38:	ea7f 5c6c 	mvns.w	ip, ip, asr #21
 8000a3c:	ea4f 0c43 	mov.w	ip, r3, lsl #1
 8000a40:	bf18      	it	ne
 8000a42:	ea7f 5c6c 	mvnsne.w	ip, ip, asr #21
 8000a46:	d01b      	beq.n	8000a80 <__cmpdf2+0x54>
 8000a48:	b001      	add	sp, #4
 8000a4a:	ea50 0c41 	orrs.w	ip, r0, r1, lsl #1
 8000a4e:	bf0c      	ite	eq
 8000a50:	ea52 0c43 	orrseq.w	ip, r2, r3, lsl #1
 8000a54:	ea91 0f03 	teqne	r1, r3
 8000a58:	bf02      	ittt	eq
 8000a5a:	ea90 0f02 	teqeq	r0, r2
 8000a5e:	2000      	moveq	r0, #0
 8000a60:	4770      	bxeq	lr
 8000a62:	f110 0f00 	cmn.w	r0, #0
 8000a66:	ea91 0f03 	teq	r1, r3
 8000a6a:	bf58      	it	pl
 8000a6c:	4299      	cmppl	r1, r3
 8000a6e:	bf08      	it	eq
 8000a70:	4290      	cmpeq	r0, r2
 8000a72:	bf2c      	ite	cs
 8000a74:	17d8      	asrcs	r0, r3, #31
 8000a76:	ea6f 70e3 	mvncc.w	r0, r3, asr #31
 8000a7a:	f040 0001 	orr.w	r0, r0, #1
 8000a7e:	4770      	bx	lr
 8000a80:	ea4f 0c41 	mov.w	ip, r1, lsl #1
 8000a84:	ea7f 5c6c 	mvns.w	ip, ip, asr #21
 8000a88:	d102      	bne.n	8000a90 <__cmpdf2+0x64>
 8000a8a:	ea50 3c01 	orrs.w	ip, r0, r1, lsl #12
 8000a8e:	d107      	bne.n	8000aa0 <__cmpdf2+0x74>
 8000a90:	ea4f 0c43 	mov.w	ip, r3, lsl #1
 8000a94:	ea7f 5c6c 	mvns.w	ip, ip, asr #21
 8000a98:	d1d6      	bne.n	8000a48 <__cmpdf2+0x1c>
 8000a9a:	ea52 3c03 	orrs.w	ip, r2, r3, lsl #12
 8000a9e:	d0d3      	beq.n	8000a48 <__cmpdf2+0x1c>
 8000aa0:	f85d 0b04 	ldr.w	r0, [sp], #4
 8000aa4:	4770      	bx	lr
 8000aa6:	bf00      	nop

08000aa8 <__aeabi_cdrcmple>:
 8000aa8:	4684      	mov	ip, r0
 8000aaa:	4610      	mov	r0, r2
 8000aac:	4662      	mov	r2, ip
 8000aae:	468c      	mov	ip, r1
 8000ab0:	4619      	mov	r1, r3
 8000ab2:	4663      	mov	r3, ip
 8000ab4:	e000      	b.n	8000ab8 <__aeabi_cdcmpeq>
 8000ab6:	bf00      	nop

08000ab8 <__aeabi_cdcmpeq>:
 8000ab8:	b501      	push	{r0, lr}
 8000aba:	f7ff ffb7 	bl	8000a2c <__cmpdf2>
 8000abe:	2800      	cmp	r0, #0
 8000ac0:	bf48      	it	mi
 8000ac2:	f110 0f00 	cmnmi.w	r0, #0
 8000ac6:	bd01      	pop	{r0, pc}

08000ac8 <__aeabi_dcmpeq>:
 8000ac8:	f84d ed08 	str.w	lr, [sp, #-8]!
 8000acc:	f7ff fff4 	bl	8000ab8 <__aeabi_cdcmpeq>
 8000ad0:	bf0c      	ite	eq
 8000ad2:	2001      	moveq	r0, #1
 8000ad4:	2000      	movne	r0, #0
 8000ad6:	f85d fb08 	ldr.w	pc, [sp], #8
 8000ada:	bf00      	nop

08000adc <__aeabi_dcmplt>:
 8000adc:	f84d ed08 	str.w	lr, [sp, #-8]!
 8000ae0:	f7ff ffea 	bl	8000ab8 <__aeabi_cdcmpeq>
 8000ae4:	bf34      	ite	cc
 8000ae6:	2001      	movcc	r0, #1
 8000ae8:	2000      	movcs	r0, #0
 8000aea:	f85d fb08 	ldr.w	pc, [sp], #8
 8000aee:	bf00      	nop

08000af0 <__aeabi_dcmple>:
 8000af0:	f84d ed08 	str.w	lr, [sp, #-8]!
 8000af4:	f7ff ffe0 	bl	8000ab8 <__aeabi_cdcmpeq>
 8000af8:	bf94      	ite	ls
 8000afa:	2001      	movls	r0, #1
 8000afc:	2000      	movhi	r0, #0
 8000afe:	f85d fb08 	ldr.w	pc, [sp], #8
 8000b02:	bf00      	nop

08000b04 <__aeabi_dcmpge>:
 8000b04:	f84d ed08 	str.w	lr, [sp, #-8]!
 8000b08:	f7ff ffce 	bl	8000aa8 <__aeabi_cdrcmple>
 8000b0c:	bf94      	ite	ls
 8000b0e:	2001      	movls	r0, #1
 8000b10:	2000      	movhi	r0, #0
 8000b12:	f85d fb08 	ldr.w	pc, [sp], #8
 8000b16:	bf00      	nop

08000b18 <__aeabi_dcmpgt>:
 8000b18:	f84d ed08 	str.w	lr, [sp, #-8]!
 8000b1c:	f7ff ffc4 	bl	8000aa8 <__aeabi_cdrcmple>
 8000b20:	bf34      	ite	cc
 8000b22:	2001      	movcc	r0, #1
 8000b24:	2000      	movcs	r0, #0
 8000b26:	f85d fb08 	ldr.w	pc, [sp], #8
 8000b2a:	bf00      	nop

08000b2c <__aeabi_dcmpun>:
 8000b2c:	ea4f 0c41 	mov.w	ip, r1, lsl #1
 8000b30:	ea7f 5c6c 	mvns.w	ip, ip, asr #21
 8000b34:	d102      	bne.n	8000b3c <__aeabi_dcmpun+0x10>
 8000b36:	ea50 3c01 	orrs.w	ip, r0, r1, lsl #12
 8000b3a:	d10a      	bne.n	8000b52 <__aeabi_dcmpun+0x26>
 8000b3c:	ea4f 0c43 	mov.w	ip, r3, lsl #1
 8000b40:	ea7f 5c6c 	mvns.w	ip, ip, asr #21
 8000b44:	d102      	bne.n	8000b4c <__aeabi_dcmpun+0x20>
 8000b46:	ea52 3c03 	orrs.w	ip, r2, r3, lsl #12
 8000b4a:	d102      	bne.n	8000b52 <__aeabi_dcmpun+0x26>
 8000b4c:	f04f 0000 	mov.w	r0, #0
 8000b50:	4770      	bx	lr
 8000b52:	f04f 0001 	mov.w	r0, #1
 8000b56:	4770      	bx	lr

08000b58 <__aeabi_d2iz>:
 8000b58:	ea4f 0241 	mov.w	r2, r1, lsl #1
 8000b5c:	f512 1200 	adds.w	r2, r2, #2097152	; 0x200000
 8000b60:	d215      	bcs.n	8000b8e <__aeabi_d2iz+0x36>
 8000b62:	d511      	bpl.n	8000b88 <__aeabi_d2iz+0x30>
 8000b64:	f46f 7378 	mvn.w	r3, #992	; 0x3e0
 8000b68:	ebb3 5262 	subs.w	r2, r3, r2, asr #21
 8000b6c:	d912      	bls.n	8000b94 <__aeabi_d2iz+0x3c>
 8000b6e:	ea4f 23c1 	mov.w	r3, r1, lsl #11
 8000b72:	f043 4300 	orr.w	r3, r3, #2147483648	; 0x80000000
 8000b76:	ea43 5350 	orr.w	r3, r3, r0, lsr #21
 8000b7a:	f011 4f00 	tst.w	r1, #2147483648	; 0x80000000
 8000b7e:	fa23 f002 	lsr.w	r0, r3, r2
 8000b82:	bf18      	it	ne
 8000b84:	4240      	negne	r0, r0
 8000b86:	4770      	bx	lr
 8000b88:	f04f 0000 	mov.w	r0, #0
 8000b8c:	4770      	bx	lr
 8000b8e:	ea50 3001 	orrs.w	r0, r0, r1, lsl #12
 8000b92:	d105      	bne.n	8000ba0 <__aeabi_d2iz+0x48>
 8000b94:	f011 4000 	ands.w	r0, r1, #2147483648	; 0x80000000
 8000b98:	bf08      	it	eq
 8000b9a:	f06f 4000 	mvneq.w	r0, #2147483648	; 0x80000000
 8000b9e:	4770      	bx	lr
 8000ba0:	f04f 0000 	mov.w	r0, #0
 8000ba4:	4770      	bx	lr
 8000ba6:	bf00      	nop

08000ba8 <__aeabi_d2f>:
 8000ba8:	ea4f 0241 	mov.w	r2, r1, lsl #1
 8000bac:	f1b2 43e0 	subs.w	r3, r2, #1879048192	; 0x70000000
 8000bb0:	bf24      	itt	cs
 8000bb2:	f5b3 1c00 	subscs.w	ip, r3, #2097152	; 0x200000
 8000bb6:	f1dc 5cfe 	rsbscs	ip, ip, #532676608	; 0x1fc00000
 8000bba:	d90d      	bls.n	8000bd8 <__aeabi_d2f+0x30>
 8000bbc:	f001 4c00 	and.w	ip, r1, #2147483648	; 0x80000000
 8000bc0:	ea4f 02c0 	mov.w	r2, r0, lsl #3
 8000bc4:	ea4c 7050 	orr.w	r0, ip, r0, lsr #29
 8000bc8:	f1b2 4f00 	cmp.w	r2, #2147483648	; 0x80000000
 8000bcc:	eb40 0083 	adc.w	r0, r0, r3, lsl #2
 8000bd0:	bf08      	it	eq
 8000bd2:	f020 0001 	biceq.w	r0, r0, #1
 8000bd6:	4770      	bx	lr
 8000bd8:	f011 4f80 	tst.w	r1, #1073741824	; 0x40000000
 8000bdc:	d121      	bne.n	8000c22 <__aeabi_d2f+0x7a>
 8000bde:	f113 7238 	adds.w	r2, r3, #48234496	; 0x2e00000
 8000be2:	bfbc      	itt	lt
 8000be4:	f001 4000 	andlt.w	r0, r1, #2147483648	; 0x80000000
 8000be8:	4770      	bxlt	lr
 8000bea:	f441 1180 	orr.w	r1, r1, #1048576	; 0x100000
 8000bee:	ea4f 5252 	mov.w	r2, r2, lsr #21
 8000bf2:	f1c2 0218 	rsb	r2, r2, #24
 8000bf6:	f1c2 0c20 	rsb	ip, r2, #32
 8000bfa:	fa10 f30c 	lsls.w	r3, r0, ip
 8000bfe:	fa20 f002 	lsr.w	r0, r0, r2
 8000c02:	bf18      	it	ne
 8000c04:	f040 0001 	orrne.w	r0, r0, #1
 8000c08:	ea4f 23c1 	mov.w	r3, r1, lsl #11
 8000c0c:	ea4f 23d3 	mov.w	r3, r3, lsr #11
 8000c10:	fa03 fc0c 	lsl.w	ip, r3, ip
 8000c14:	ea40 000c 	orr.w	r0, r0, ip
 8000c18:	fa23 f302 	lsr.w	r3, r3, r2
 8000c1c:	ea4f 0343 	mov.w	r3, r3, lsl #1
 8000c20:	e7cc      	b.n	8000bbc <__aeabi_d2f+0x14>
 8000c22:	ea7f 5362 	mvns.w	r3, r2, asr #21
 8000c26:	d107      	bne.n	8000c38 <__aeabi_d2f+0x90>
 8000c28:	ea50 3301 	orrs.w	r3, r0, r1, lsl #12
 8000c2c:	bf1e      	ittt	ne
 8000c2e:	f04f 40fe 	movne.w	r0, #2130706432	; 0x7f000000
 8000c32:	f440 0040 	orrne.w	r0, r0, #12582912	; 0xc00000
 8000c36:	4770      	bxne	lr
 8000c38:	f001 4000 	and.w	r0, r1, #2147483648	; 0x80000000
 8000c3c:	f040 40fe 	orr.w	r0, r0, #2130706432	; 0x7f000000
 8000c40:	f440 0000 	orr.w	r0, r0, #8388608	; 0x800000
 8000c44:	4770      	bx	lr
 8000c46:	bf00      	nop

08000c48 <__aeabi_uldivmod>:
 8000c48:	b953      	cbnz	r3, 8000c60 <__aeabi_uldivmod+0x18>
 8000c4a:	b94a      	cbnz	r2, 8000c60 <__aeabi_uldivmod+0x18>
 8000c4c:	2900      	cmp	r1, #0
 8000c4e:	bf08      	it	eq
 8000c50:	2800      	cmpeq	r0, #0
 8000c52:	bf1c      	itt	ne
 8000c54:	f04f 31ff 	movne.w	r1, #4294967295
 8000c58:	f04f 30ff 	movne.w	r0, #4294967295
 8000c5c:	f000 b96e 	b.w	8000f3c <__aeabi_idiv0>
 8000c60:	f1ad 0c08 	sub.w	ip, sp, #8
 8000c64:	e96d ce04 	strd	ip, lr, [sp, #-16]!
 8000c68:	f000 f806 	bl	8000c78 <__udivmoddi4>
 8000c6c:	f8dd e004 	ldr.w	lr, [sp, #4]
 8000c70:	e9dd 2302 	ldrd	r2, r3, [sp, #8]
 8000c74:	b004      	add	sp, #16
 8000c76:	4770      	bx	lr

08000c78 <__udivmoddi4>:
 8000c78:	e92d 47f0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, lr}
 8000c7c:	9d08      	ldr	r5, [sp, #32]
 8000c7e:	4604      	mov	r4, r0
 8000c80:	468c      	mov	ip, r1
 8000c82:	2b00      	cmp	r3, #0
 8000c84:	f040 8083 	bne.w	8000d8e <__udivmoddi4+0x116>
 8000c88:	428a      	cmp	r2, r1
 8000c8a:	4617      	mov	r7, r2
 8000c8c:	d947      	bls.n	8000d1e <__udivmoddi4+0xa6>
 8000c8e:	fab2 f282 	clz	r2, r2
 8000c92:	b142      	cbz	r2, 8000ca6 <__udivmoddi4+0x2e>
 8000c94:	f1c2 0020 	rsb	r0, r2, #32
 8000c98:	fa24 f000 	lsr.w	r0, r4, r0
 8000c9c:	4091      	lsls	r1, r2
 8000c9e:	4097      	lsls	r7, r2
 8000ca0:	ea40 0c01 	orr.w	ip, r0, r1
 8000ca4:	4094      	lsls	r4, r2
 8000ca6:	ea4f 4817 	mov.w	r8, r7, lsr #16
 8000caa:	0c23      	lsrs	r3, r4, #16
 8000cac:	fbbc f6f8 	udiv	r6, ip, r8
 8000cb0:	fa1f fe87 	uxth.w	lr, r7
 8000cb4:	fb08 c116 	mls	r1, r8, r6, ip
 8000cb8:	ea43 4301 	orr.w	r3, r3, r1, lsl #16
 8000cbc:	fb06 f10e 	mul.w	r1, r6, lr
 8000cc0:	4299      	cmp	r1, r3
 8000cc2:	d909      	bls.n	8000cd8 <__udivmoddi4+0x60>
 8000cc4:	18fb      	adds	r3, r7, r3
 8000cc6:	f106 30ff 	add.w	r0, r6, #4294967295
 8000cca:	f080 8119 	bcs.w	8000f00 <__udivmoddi4+0x288>
 8000cce:	4299      	cmp	r1, r3
 8000cd0:	f240 8116 	bls.w	8000f00 <__udivmoddi4+0x288>
 8000cd4:	3e02      	subs	r6, #2
 8000cd6:	443b      	add	r3, r7
 8000cd8:	1a5b      	subs	r3, r3, r1
 8000cda:	b2a4      	uxth	r4, r4
 8000cdc:	fbb3 f0f8 	udiv	r0, r3, r8
 8000ce0:	fb08 3310 	mls	r3, r8, r0, r3
 8000ce4:	ea44 4403 	orr.w	r4, r4, r3, lsl #16
 8000ce8:	fb00 fe0e 	mul.w	lr, r0, lr
 8000cec:	45a6      	cmp	lr, r4
 8000cee:	d909      	bls.n	8000d04 <__udivmoddi4+0x8c>
 8000cf0:	193c      	adds	r4, r7, r4
 8000cf2:	f100 33ff 	add.w	r3, r0, #4294967295
 8000cf6:	f080 8105 	bcs.w	8000f04 <__udivmoddi4+0x28c>
 8000cfa:	45a6      	cmp	lr, r4
 8000cfc:	f240 8102 	bls.w	8000f04 <__udivmoddi4+0x28c>
 8000d00:	3802      	subs	r0, #2
 8000d02:	443c      	add	r4, r7
 8000d04:	ea40 4006 	orr.w	r0, r0, r6, lsl #16
 8000d08:	eba4 040e 	sub.w	r4, r4, lr
 8000d0c:	2600      	movs	r6, #0
 8000d0e:	b11d      	cbz	r5, 8000d18 <__udivmoddi4+0xa0>
 8000d10:	40d4      	lsrs	r4, r2
 8000d12:	2300      	movs	r3, #0
 8000d14:	e9c5 4300 	strd	r4, r3, [r5]
 8000d18:	4631      	mov	r1, r6
 8000d1a:	e8bd 87f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, pc}
 8000d1e:	b902      	cbnz	r2, 8000d22 <__udivmoddi4+0xaa>
 8000d20:	deff      	udf	#255	; 0xff
 8000d22:	fab2 f282 	clz	r2, r2
 8000d26:	2a00      	cmp	r2, #0
 8000d28:	d150      	bne.n	8000dcc <__udivmoddi4+0x154>
 8000d2a:	1bcb      	subs	r3, r1, r7
 8000d2c:	ea4f 4e17 	mov.w	lr, r7, lsr #16
 8000d30:	fa1f f887 	uxth.w	r8, r7
 8000d34:	2601      	movs	r6, #1
 8000d36:	fbb3 fcfe 	udiv	ip, r3, lr
 8000d3a:	0c21      	lsrs	r1, r4, #16
 8000d3c:	fb0e 331c 	mls	r3, lr, ip, r3
 8000d40:	ea41 4103 	orr.w	r1, r1, r3, lsl #16
 8000d44:	fb08 f30c 	mul.w	r3, r8, ip
 8000d48:	428b      	cmp	r3, r1
 8000d4a:	d907      	bls.n	8000d5c <__udivmoddi4+0xe4>
 8000d4c:	1879      	adds	r1, r7, r1
 8000d4e:	f10c 30ff 	add.w	r0, ip, #4294967295
 8000d52:	d202      	bcs.n	8000d5a <__udivmoddi4+0xe2>
 8000d54:	428b      	cmp	r3, r1
 8000d56:	f200 80e9 	bhi.w	8000f2c <__udivmoddi4+0x2b4>
 8000d5a:	4684      	mov	ip, r0
 8000d5c:	1ac9      	subs	r1, r1, r3
 8000d5e:	b2a3      	uxth	r3, r4
 8000d60:	fbb1 f0fe 	udiv	r0, r1, lr
 8000d64:	fb0e 1110 	mls	r1, lr, r0, r1
 8000d68:	ea43 4401 	orr.w	r4, r3, r1, lsl #16
 8000d6c:	fb08 f800 	mul.w	r8, r8, r0
 8000d70:	45a0      	cmp	r8, r4
 8000d72:	d907      	bls.n	8000d84 <__udivmoddi4+0x10c>
 8000d74:	193c      	adds	r4, r7, r4
 8000d76:	f100 33ff 	add.w	r3, r0, #4294967295
 8000d7a:	d202      	bcs.n	8000d82 <__udivmoddi4+0x10a>
 8000d7c:	45a0      	cmp	r8, r4
 8000d7e:	f200 80d9 	bhi.w	8000f34 <__udivmoddi4+0x2bc>
 8000d82:	4618      	mov	r0, r3
 8000d84:	eba4 0408 	sub.w	r4, r4, r8
 8000d88:	ea40 400c 	orr.w	r0, r0, ip, lsl #16
 8000d8c:	e7bf      	b.n	8000d0e <__udivmoddi4+0x96>
 8000d8e:	428b      	cmp	r3, r1
 8000d90:	d909      	bls.n	8000da6 <__udivmoddi4+0x12e>
 8000d92:	2d00      	cmp	r5, #0
 8000d94:	f000 80b1 	beq.w	8000efa <__udivmoddi4+0x282>
 8000d98:	2600      	movs	r6, #0
 8000d9a:	e9c5 0100 	strd	r0, r1, [r5]
 8000d9e:	4630      	mov	r0, r6
 8000da0:	4631      	mov	r1, r6
 8000da2:	e8bd 87f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, pc}
 8000da6:	fab3 f683 	clz	r6, r3
 8000daa:	2e00      	cmp	r6, #0
 8000dac:	d14a      	bne.n	8000e44 <__udivmoddi4+0x1cc>
 8000dae:	428b      	cmp	r3, r1
 8000db0:	d302      	bcc.n	8000db8 <__udivmoddi4+0x140>
 8000db2:	4282      	cmp	r2, r0
 8000db4:	f200 80b8 	bhi.w	8000f28 <__udivmoddi4+0x2b0>
 8000db8:	1a84      	subs	r4, r0, r2
 8000dba:	eb61 0103 	sbc.w	r1, r1, r3
 8000dbe:	2001      	movs	r0, #1
 8000dc0:	468c      	mov	ip, r1
 8000dc2:	2d00      	cmp	r5, #0
 8000dc4:	d0a8      	beq.n	8000d18 <__udivmoddi4+0xa0>
 8000dc6:	e9c5 4c00 	strd	r4, ip, [r5]
 8000dca:	e7a5      	b.n	8000d18 <__udivmoddi4+0xa0>
 8000dcc:	f1c2 0320 	rsb	r3, r2, #32
 8000dd0:	fa20 f603 	lsr.w	r6, r0, r3
 8000dd4:	4097      	lsls	r7, r2
 8000dd6:	fa01 f002 	lsl.w	r0, r1, r2
 8000dda:	ea4f 4e17 	mov.w	lr, r7, lsr #16
 8000dde:	40d9      	lsrs	r1, r3
 8000de0:	4330      	orrs	r0, r6
 8000de2:	0c03      	lsrs	r3, r0, #16
 8000de4:	fbb1 f6fe 	udiv	r6, r1, lr
 8000de8:	fa1f f887 	uxth.w	r8, r7
 8000dec:	fb0e 1116 	mls	r1, lr, r6, r1
 8000df0:	ea43 4301 	orr.w	r3, r3, r1, lsl #16
 8000df4:	fb06 f108 	mul.w	r1, r6, r8
 8000df8:	4299      	cmp	r1, r3
 8000dfa:	fa04 f402 	lsl.w	r4, r4, r2
 8000dfe:	d909      	bls.n	8000e14 <__udivmoddi4+0x19c>
 8000e00:	18fb      	adds	r3, r7, r3
 8000e02:	f106 3cff 	add.w	ip, r6, #4294967295
 8000e06:	f080 808d 	bcs.w	8000f24 <__udivmoddi4+0x2ac>
 8000e0a:	4299      	cmp	r1, r3
 8000e0c:	f240 808a 	bls.w	8000f24 <__udivmoddi4+0x2ac>
 8000e10:	3e02      	subs	r6, #2
 8000e12:	443b      	add	r3, r7
 8000e14:	1a5b      	subs	r3, r3, r1
 8000e16:	b281      	uxth	r1, r0
 8000e18:	fbb3 f0fe 	udiv	r0, r3, lr
 8000e1c:	fb0e 3310 	mls	r3, lr, r0, r3
 8000e20:	ea41 4103 	orr.w	r1, r1, r3, lsl #16
 8000e24:	fb00 f308 	mul.w	r3, r0, r8
 8000e28:	428b      	cmp	r3, r1
 8000e2a:	d907      	bls.n	8000e3c <__udivmoddi4+0x1c4>
 8000e2c:	1879      	adds	r1, r7, r1
 8000e2e:	f100 3cff 	add.w	ip, r0, #4294967295
 8000e32:	d273      	bcs.n	8000f1c <__udivmoddi4+0x2a4>
 8000e34:	428b      	cmp	r3, r1
 8000e36:	d971      	bls.n	8000f1c <__udivmoddi4+0x2a4>
 8000e38:	3802      	subs	r0, #2
 8000e3a:	4439      	add	r1, r7
 8000e3c:	1acb      	subs	r3, r1, r3
 8000e3e:	ea40 4606 	orr.w	r6, r0, r6, lsl #16
 8000e42:	e778      	b.n	8000d36 <__udivmoddi4+0xbe>
 8000e44:	f1c6 0c20 	rsb	ip, r6, #32
 8000e48:	fa03 f406 	lsl.w	r4, r3, r6
 8000e4c:	fa22 f30c 	lsr.w	r3, r2, ip
 8000e50:	431c      	orrs	r4, r3
 8000e52:	fa20 f70c 	lsr.w	r7, r0, ip
 8000e56:	fa01 f306 	lsl.w	r3, r1, r6
 8000e5a:	ea4f 4e14 	mov.w	lr, r4, lsr #16
 8000e5e:	fa21 f10c 	lsr.w	r1, r1, ip
 8000e62:	431f      	orrs	r7, r3
 8000e64:	0c3b      	lsrs	r3, r7, #16
 8000e66:	fbb1 f9fe 	udiv	r9, r1, lr
 8000e6a:	fa1f f884 	uxth.w	r8, r4
 8000e6e:	fb0e 1119 	mls	r1, lr, r9, r1
 8000e72:	ea43 4101 	orr.w	r1, r3, r1, lsl #16
 8000e76:	fb09 fa08 	mul.w	sl, r9, r8
 8000e7a:	458a      	cmp	sl, r1
 8000e7c:	fa02 f206 	lsl.w	r2, r2, r6
 8000e80:	fa00 f306 	lsl.w	r3, r0, r6
 8000e84:	d908      	bls.n	8000e98 <__udivmoddi4+0x220>
 8000e86:	1861      	adds	r1, r4, r1
 8000e88:	f109 30ff 	add.w	r0, r9, #4294967295
 8000e8c:	d248      	bcs.n	8000f20 <__udivmoddi4+0x2a8>
 8000e8e:	458a      	cmp	sl, r1
 8000e90:	d946      	bls.n	8000f20 <__udivmoddi4+0x2a8>
 8000e92:	f1a9 0902 	sub.w	r9, r9, #2
 8000e96:	4421      	add	r1, r4
 8000e98:	eba1 010a 	sub.w	r1, r1, sl
 8000e9c:	b2bf      	uxth	r7, r7
 8000e9e:	fbb1 f0fe 	udiv	r0, r1, lr
 8000ea2:	fb0e 1110 	mls	r1, lr, r0, r1
 8000ea6:	ea47 4701 	orr.w	r7, r7, r1, lsl #16
 8000eaa:	fb00 f808 	mul.w	r8, r0, r8
 8000eae:	45b8      	cmp	r8, r7
 8000eb0:	d907      	bls.n	8000ec2 <__udivmoddi4+0x24a>
 8000eb2:	19e7      	adds	r7, r4, r7
 8000eb4:	f100 31ff 	add.w	r1, r0, #4294967295
 8000eb8:	d22e      	bcs.n	8000f18 <__udivmoddi4+0x2a0>
 8000eba:	45b8      	cmp	r8, r7
 8000ebc:	d92c      	bls.n	8000f18 <__udivmoddi4+0x2a0>
 8000ebe:	3802      	subs	r0, #2
 8000ec0:	4427      	add	r7, r4
 8000ec2:	ea40 4009 	orr.w	r0, r0, r9, lsl #16
 8000ec6:	eba7 0708 	sub.w	r7, r7, r8
 8000eca:	fba0 8902 	umull	r8, r9, r0, r2
 8000ece:	454f      	cmp	r7, r9
 8000ed0:	46c6      	mov	lr, r8
 8000ed2:	4649      	mov	r1, r9
 8000ed4:	d31a      	bcc.n	8000f0c <__udivmoddi4+0x294>
 8000ed6:	d017      	beq.n	8000f08 <__udivmoddi4+0x290>
 8000ed8:	b15d      	cbz	r5, 8000ef2 <__udivmoddi4+0x27a>
 8000eda:	ebb3 020e 	subs.w	r2, r3, lr
 8000ede:	eb67 0701 	sbc.w	r7, r7, r1
 8000ee2:	fa07 fc0c 	lsl.w	ip, r7, ip
 8000ee6:	40f2      	lsrs	r2, r6
 8000ee8:	ea4c 0202 	orr.w	r2, ip, r2
 8000eec:	40f7      	lsrs	r7, r6
 8000eee:	e9c5 2700 	strd	r2, r7, [r5]
 8000ef2:	2600      	movs	r6, #0
 8000ef4:	4631      	mov	r1, r6
 8000ef6:	e8bd 87f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, pc}
 8000efa:	462e      	mov	r6, r5
 8000efc:	4628      	mov	r0, r5
 8000efe:	e70b      	b.n	8000d18 <__udivmoddi4+0xa0>
 8000f00:	4606      	mov	r6, r0
 8000f02:	e6e9      	b.n	8000cd8 <__udivmoddi4+0x60>
 8000f04:	4618      	mov	r0, r3
 8000f06:	e6fd      	b.n	8000d04 <__udivmoddi4+0x8c>
 8000f08:	4543      	cmp	r3, r8
 8000f0a:	d2e5      	bcs.n	8000ed8 <__udivmoddi4+0x260>
 8000f0c:	ebb8 0e02 	subs.w	lr, r8, r2
 8000f10:	eb69 0104 	sbc.w	r1, r9, r4
 8000f14:	3801      	subs	r0, #1
 8000f16:	e7df      	b.n	8000ed8 <__udivmoddi4+0x260>
 8000f18:	4608      	mov	r0, r1
 8000f1a:	e7d2      	b.n	8000ec2 <__udivmoddi4+0x24a>
 8000f1c:	4660      	mov	r0, ip
 8000f1e:	e78d      	b.n	8000e3c <__udivmoddi4+0x1c4>
 8000f20:	4681      	mov	r9, r0
 8000f22:	e7b9      	b.n	8000e98 <__udivmoddi4+0x220>
 8000f24:	4666      	mov	r6, ip
 8000f26:	e775      	b.n	8000e14 <__udivmoddi4+0x19c>
 8000f28:	4630      	mov	r0, r6
 8000f2a:	e74a      	b.n	8000dc2 <__udivmoddi4+0x14a>
 8000f2c:	f1ac 0c02 	sub.w	ip, ip, #2
 8000f30:	4439      	add	r1, r7
 8000f32:	e713      	b.n	8000d5c <__udivmoddi4+0xe4>
 8000f34:	3802      	subs	r0, #2
 8000f36:	443c      	add	r4, r7
 8000f38:	e724      	b.n	8000d84 <__udivmoddi4+0x10c>
 8000f3a:	bf00      	nop

08000f3c <__aeabi_idiv0>:
 8000f3c:	4770      	bx	lr
 8000f3e:	bf00      	nop

08000f40 <DWT_Delay_us>:

uint32_t DWT_Delay_Init(void);

// This Function Provides Delay In Microseconds Using DWT
__STATIC_INLINE void DWT_Delay_us(volatile uint32_t au32_microseconds)
{
 8000f40:	b580      	push	{r7, lr}
 8000f42:	b084      	sub	sp, #16
 8000f44:	af00      	add	r7, sp, #0
 8000f46:	6078      	str	r0, [r7, #4]
  uint32_t au32_initial_ticks = DWT->CYCCNT;
 8000f48:	4b0f      	ldr	r3, [pc, #60]	; (8000f88 <DWT_Delay_us+0x48>)
 8000f4a:	685b      	ldr	r3, [r3, #4]
 8000f4c:	60fb      	str	r3, [r7, #12]
  uint32_t au32_ticks = (HAL_RCC_GetHCLKFreq() / 1000000);
 8000f4e:	f003 fc01 	bl	8004754 <HAL_RCC_GetHCLKFreq>
 8000f52:	4603      	mov	r3, r0
 8000f54:	4a0d      	ldr	r2, [pc, #52]	; (8000f8c <DWT_Delay_us+0x4c>)
 8000f56:	fba2 2303 	umull	r2, r3, r2, r3
 8000f5a:	0c9b      	lsrs	r3, r3, #18
 8000f5c:	60bb      	str	r3, [r7, #8]
  au32_microseconds *= au32_ticks;
 8000f5e:	687b      	ldr	r3, [r7, #4]
 8000f60:	68ba      	ldr	r2, [r7, #8]
 8000f62:	fb02 f303 	mul.w	r3, r2, r3
 8000f66:	607b      	str	r3, [r7, #4]
  while ((DWT->CYCCNT - au32_initial_ticks) < au32_microseconds-au32_ticks);
 8000f68:	bf00      	nop
 8000f6a:	4b07      	ldr	r3, [pc, #28]	; (8000f88 <DWT_Delay_us+0x48>)
 8000f6c:	685a      	ldr	r2, [r3, #4]
 8000f6e:	68fb      	ldr	r3, [r7, #12]
 8000f70:	1ad2      	subs	r2, r2, r3
 8000f72:	6879      	ldr	r1, [r7, #4]
 8000f74:	68bb      	ldr	r3, [r7, #8]
 8000f76:	1acb      	subs	r3, r1, r3
 8000f78:	429a      	cmp	r2, r3
 8000f7a:	d3f6      	bcc.n	8000f6a <DWT_Delay_us+0x2a>
}
 8000f7c:	bf00      	nop
 8000f7e:	bf00      	nop
 8000f80:	3710      	adds	r7, #16
 8000f82:	46bd      	mov	sp, r7
 8000f84:	bd80      	pop	{r7, pc}
 8000f86:	bf00      	nop
 8000f88:	e0001000 	.word	0xe0001000
 8000f8c:	431bde83 	.word	0x431bde83

08000f90 <Data_Output>:
#include "HT.h"
#include "timer.h"
#include "stm32l4xx_hal.h"

void Data_Output (GPIO_TypeDef *PORT, uint16_t PIN) //direction vers le capteur
  {
 8000f90:	b580      	push	{r7, lr}
 8000f92:	b088      	sub	sp, #32
 8000f94:	af00      	add	r7, sp, #0
 8000f96:	6078      	str	r0, [r7, #4]
 8000f98:	460b      	mov	r3, r1
 8000f9a:	807b      	strh	r3, [r7, #2]
  	GPIO_InitTypeDef GPIO_InitStruct = {0};
 8000f9c:	f107 030c 	add.w	r3, r7, #12
 8000fa0:	2200      	movs	r2, #0
 8000fa2:	601a      	str	r2, [r3, #0]
 8000fa4:	605a      	str	r2, [r3, #4]
 8000fa6:	609a      	str	r2, [r3, #8]
 8000fa8:	60da      	str	r2, [r3, #12]
 8000faa:	611a      	str	r2, [r3, #16]

  	GPIO_InitStruct.Pin = PIN;
 8000fac:	887b      	ldrh	r3, [r7, #2]
 8000fae:	60fb      	str	r3, [r7, #12]
  	GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP; //pushpull
 8000fb0:	2301      	movs	r3, #1
 8000fb2:	613b      	str	r3, [r7, #16]
  	HAL_GPIO_Init(PORT, &GPIO_InitStruct);
 8000fb4:	f107 030c 	add.w	r3, r7, #12
 8000fb8:	4619      	mov	r1, r3
 8000fba:	6878      	ldr	r0, [r7, #4]
 8000fbc:	f001 f9a2 	bl	8002304 <HAL_GPIO_Init>
  }
 8000fc0:	bf00      	nop
 8000fc2:	3720      	adds	r7, #32
 8000fc4:	46bd      	mov	sp, r7
 8000fc6:	bd80      	pop	{r7, pc}

08000fc8 <Data_Input>:

void Data_Input (GPIO_TypeDef *PORT, uint16_t PIN) //direction vers le microcontroleur
  {
 8000fc8:	b580      	push	{r7, lr}
 8000fca:	b088      	sub	sp, #32
 8000fcc:	af00      	add	r7, sp, #0
 8000fce:	6078      	str	r0, [r7, #4]
 8000fd0:	460b      	mov	r3, r1
 8000fd2:	807b      	strh	r3, [r7, #2]
  	GPIO_InitTypeDef GPIO_InitStruct = {0};
 8000fd4:	f107 030c 	add.w	r3, r7, #12
 8000fd8:	2200      	movs	r2, #0
 8000fda:	601a      	str	r2, [r3, #0]
 8000fdc:	605a      	str	r2, [r3, #4]
 8000fde:	609a      	str	r2, [r3, #8]
 8000fe0:	60da      	str	r2, [r3, #12]
 8000fe2:	611a      	str	r2, [r3, #16]

  	GPIO_InitStruct.Pin = PIN;
 8000fe4:	887b      	ldrh	r3, [r7, #2]
 8000fe6:	60fb      	str	r3, [r7, #12]
  	GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
 8000fe8:	2300      	movs	r3, #0
 8000fea:	613b      	str	r3, [r7, #16]
  	HAL_GPIO_Init(PORT, &GPIO_InitStruct);
 8000fec:	f107 030c 	add.w	r3, r7, #12
 8000ff0:	4619      	mov	r1, r3
 8000ff2:	6878      	ldr	r0, [r7, #4]
 8000ff4:	f001 f986 	bl	8002304 <HAL_GPIO_Init>
  }
 8000ff8:	bf00      	nop
 8000ffa:	3720      	adds	r7, #32
 8000ffc:	46bd      	mov	sp, r7
 8000ffe:	bd80      	pop	{r7, pc}

08001000 <Read_data>:

void Read_data (uint8_t *data)
  {
 8001000:	b580      	push	{r7, lr}
 8001002:	b084      	sub	sp, #16
 8001004:	af00      	add	r7, sp, #0
 8001006:	6078      	str	r0, [r7, #4]
  	int i, k;
  	for (i=0;i<8;i++)
 8001008:	2300      	movs	r3, #0
 800100a:	60fb      	str	r3, [r7, #12]
 800100c:	e057      	b.n	80010be <Read_data+0xbe>
  	{
  		if (HAL_GPIO_ReadPin (GPIOA, GPIO_PIN_1) == GPIO_PIN_RESET)
 800100e:	2102      	movs	r1, #2
 8001010:	f04f 4090 	mov.w	r0, #1207959552	; 0x48000000
 8001014:	f001 fb20 	bl	8002658 <HAL_GPIO_ReadPin>
 8001018:	4603      	mov	r3, r0
 800101a:	2b00      	cmp	r3, #0
 800101c:	d11d      	bne.n	800105a <Read_data+0x5a>
  		{
  			(*data)&= ~(1<<(7-i)); //data bit is 0
 800101e:	687b      	ldr	r3, [r7, #4]
 8001020:	781b      	ldrb	r3, [r3, #0]
 8001022:	b25a      	sxtb	r2, r3
 8001024:	68fb      	ldr	r3, [r7, #12]
 8001026:	f1c3 0307 	rsb	r3, r3, #7
 800102a:	2101      	movs	r1, #1
 800102c:	fa01 f303 	lsl.w	r3, r1, r3
 8001030:	b25b      	sxtb	r3, r3
 8001032:	43db      	mvns	r3, r3
 8001034:	b25b      	sxtb	r3, r3
 8001036:	4013      	ands	r3, r2
 8001038:	b25b      	sxtb	r3, r3
 800103a:	b2da      	uxtb	r2, r3
 800103c:	687b      	ldr	r3, [r7, #4]
 800103e:	701a      	strb	r2, [r3, #0]
  			while(!(HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_1)));
 8001040:	bf00      	nop
 8001042:	2102      	movs	r1, #2
 8001044:	f04f 4090 	mov.w	r0, #1207959552	; 0x48000000
 8001048:	f001 fb06 	bl	8002658 <HAL_GPIO_ReadPin>
 800104c:	4603      	mov	r3, r0
 800104e:	2b00      	cmp	r3, #0
 8001050:	d0f7      	beq.n	8001042 <Read_data+0x42>
  			DWT_Delay_us(40);
 8001052:	2028      	movs	r0, #40	; 0x28
 8001054:	f7ff ff74 	bl	8000f40 <DWT_Delay_us>
 8001058:	e02e      	b.n	80010b8 <Read_data+0xb8>
  		}
  		else                       //data bit is 1
  		{
  			(*data)|= (1<<(7-i));
 800105a:	687b      	ldr	r3, [r7, #4]
 800105c:	781b      	ldrb	r3, [r3, #0]
 800105e:	b25a      	sxtb	r2, r3
 8001060:	68fb      	ldr	r3, [r7, #12]
 8001062:	f1c3 0307 	rsb	r3, r3, #7
 8001066:	2101      	movs	r1, #1
 8001068:	fa01 f303 	lsl.w	r3, r1, r3
 800106c:	b25b      	sxtb	r3, r3
 800106e:	4313      	orrs	r3, r2
 8001070:	b25b      	sxtb	r3, r3
 8001072:	b2da      	uxtb	r2, r3
 8001074:	687b      	ldr	r3, [r7, #4]
 8001076:	701a      	strb	r2, [r3, #0]
  			for (k=0;k<1000;k++)
 8001078:	2300      	movs	r3, #0
 800107a:	60bb      	str	r3, [r7, #8]
 800107c:	e00a      	b.n	8001094 <Read_data+0x94>
  			{
  				if (HAL_GPIO_ReadPin (GPIOA, GPIO_PIN_1) == GPIO_PIN_RESET)
 800107e:	2102      	movs	r1, #2
 8001080:	f04f 4090 	mov.w	r0, #1207959552	; 0x48000000
 8001084:	f001 fae8 	bl	8002658 <HAL_GPIO_ReadPin>
 8001088:	4603      	mov	r3, r0
 800108a:	2b00      	cmp	r3, #0
 800108c:	d007      	beq.n	800109e <Read_data+0x9e>
  			for (k=0;k<1000;k++)
 800108e:	68bb      	ldr	r3, [r7, #8]
 8001090:	3301      	adds	r3, #1
 8001092:	60bb      	str	r3, [r7, #8]
 8001094:	68bb      	ldr	r3, [r7, #8]
 8001096:	f5b3 7f7a 	cmp.w	r3, #1000	; 0x3e8
 800109a:	dbf0      	blt.n	800107e <Read_data+0x7e>
 800109c:	e000      	b.n	80010a0 <Read_data+0xa0>
  				  {
  				  	break;
 800109e:	bf00      	nop
  				  }
  			}
  			while(!(HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_1)));
 80010a0:	bf00      	nop
 80010a2:	2102      	movs	r1, #2
 80010a4:	f04f 4090 	mov.w	r0, #1207959552	; 0x48000000
 80010a8:	f001 fad6 	bl	8002658 <HAL_GPIO_ReadPin>
 80010ac:	4603      	mov	r3, r0
 80010ae:	2b00      	cmp	r3, #0
 80010b0:	d0f7      	beq.n	80010a2 <Read_data+0xa2>
  			DWT_Delay_us(40);
 80010b2:	2028      	movs	r0, #40	; 0x28
 80010b4:	f7ff ff44 	bl	8000f40 <DWT_Delay_us>
  	for (i=0;i<8;i++)
 80010b8:	68fb      	ldr	r3, [r7, #12]
 80010ba:	3301      	adds	r3, #1
 80010bc:	60fb      	str	r3, [r7, #12]
 80010be:	68fb      	ldr	r3, [r7, #12]
 80010c0:	2b07      	cmp	r3, #7
 80010c2:	dda4      	ble.n	800100e <Read_data+0xe>
  		}
  	 }
  }
 80010c4:	bf00      	nop
 80010c6:	bf00      	nop
 80010c8:	3710      	adds	r7, #16
 80010ca:	46bd      	mov	sp, r7
 80010cc:	bd80      	pop	{r7, pc}
	...

080010d0 <MX_GPIO_Init>:
        * Output
        * EVENT_OUT
        * EXTI
*/
void MX_GPIO_Init(void)
{
 80010d0:	b580      	push	{r7, lr}
 80010d2:	b08a      	sub	sp, #40	; 0x28
 80010d4:	af00      	add	r7, sp, #0

  GPIO_InitTypeDef GPIO_InitStruct = {0};
 80010d6:	f107 0314 	add.w	r3, r7, #20
 80010da:	2200      	movs	r2, #0
 80010dc:	601a      	str	r2, [r3, #0]
 80010de:	605a      	str	r2, [r3, #4]
 80010e0:	609a      	str	r2, [r3, #8]
 80010e2:	60da      	str	r2, [r3, #12]
 80010e4:	611a      	str	r2, [r3, #16]

  /* GPIO Ports Clock Enable */
  __HAL_RCC_GPIOC_CLK_ENABLE();
 80010e6:	4b32      	ldr	r3, [pc, #200]	; (80011b0 <MX_GPIO_Init+0xe0>)
 80010e8:	6cdb      	ldr	r3, [r3, #76]	; 0x4c
 80010ea:	4a31      	ldr	r2, [pc, #196]	; (80011b0 <MX_GPIO_Init+0xe0>)
 80010ec:	f043 0304 	orr.w	r3, r3, #4
 80010f0:	64d3      	str	r3, [r2, #76]	; 0x4c
 80010f2:	4b2f      	ldr	r3, [pc, #188]	; (80011b0 <MX_GPIO_Init+0xe0>)
 80010f4:	6cdb      	ldr	r3, [r3, #76]	; 0x4c
 80010f6:	f003 0304 	and.w	r3, r3, #4
 80010fa:	613b      	str	r3, [r7, #16]
 80010fc:	693b      	ldr	r3, [r7, #16]
  __HAL_RCC_GPIOH_CLK_ENABLE();
 80010fe:	4b2c      	ldr	r3, [pc, #176]	; (80011b0 <MX_GPIO_Init+0xe0>)
 8001100:	6cdb      	ldr	r3, [r3, #76]	; 0x4c
 8001102:	4a2b      	ldr	r2, [pc, #172]	; (80011b0 <MX_GPIO_Init+0xe0>)
 8001104:	f043 0380 	orr.w	r3, r3, #128	; 0x80
 8001108:	64d3      	str	r3, [r2, #76]	; 0x4c
 800110a:	4b29      	ldr	r3, [pc, #164]	; (80011b0 <MX_GPIO_Init+0xe0>)
 800110c:	6cdb      	ldr	r3, [r3, #76]	; 0x4c
 800110e:	f003 0380 	and.w	r3, r3, #128	; 0x80
 8001112:	60fb      	str	r3, [r7, #12]
 8001114:	68fb      	ldr	r3, [r7, #12]
  __HAL_RCC_GPIOA_CLK_ENABLE();
 8001116:	4b26      	ldr	r3, [pc, #152]	; (80011b0 <MX_GPIO_Init+0xe0>)
 8001118:	6cdb      	ldr	r3, [r3, #76]	; 0x4c
 800111a:	4a25      	ldr	r2, [pc, #148]	; (80011b0 <MX_GPIO_Init+0xe0>)
 800111c:	f043 0301 	orr.w	r3, r3, #1
 8001120:	64d3      	str	r3, [r2, #76]	; 0x4c
 8001122:	4b23      	ldr	r3, [pc, #140]	; (80011b0 <MX_GPIO_Init+0xe0>)
 8001124:	6cdb      	ldr	r3, [r3, #76]	; 0x4c
 8001126:	f003 0301 	and.w	r3, r3, #1
 800112a:	60bb      	str	r3, [r7, #8]
 800112c:	68bb      	ldr	r3, [r7, #8]
  __HAL_RCC_GPIOB_CLK_ENABLE();
 800112e:	4b20      	ldr	r3, [pc, #128]	; (80011b0 <MX_GPIO_Init+0xe0>)
 8001130:	6cdb      	ldr	r3, [r3, #76]	; 0x4c
 8001132:	4a1f      	ldr	r2, [pc, #124]	; (80011b0 <MX_GPIO_Init+0xe0>)
 8001134:	f043 0302 	orr.w	r3, r3, #2
 8001138:	64d3      	str	r3, [r2, #76]	; 0x4c
 800113a:	4b1d      	ldr	r3, [pc, #116]	; (80011b0 <MX_GPIO_Init+0xe0>)
 800113c:	6cdb      	ldr	r3, [r3, #76]	; 0x4c
 800113e:	f003 0302 	and.w	r3, r3, #2
 8001142:	607b      	str	r3, [r7, #4]
 8001144:	687b      	ldr	r3, [r7, #4]

  /*Configure GPIO pin Output Level */
  HAL_GPIO_WritePin(LD2_GPIO_Port, LD2_Pin, GPIO_PIN_RESET);
 8001146:	2200      	movs	r2, #0
 8001148:	2120      	movs	r1, #32
 800114a:	f04f 4090 	mov.w	r0, #1207959552	; 0x48000000
 800114e:	f001 fa9b 	bl	8002688 <HAL_GPIO_WritePin>

  /*Configure GPIO pin : PtPin */
  GPIO_InitStruct.Pin = B1_Pin;
 8001152:	f44f 5300 	mov.w	r3, #8192	; 0x2000
 8001156:	617b      	str	r3, [r7, #20]
  GPIO_InitStruct.Mode = GPIO_MODE_IT_FALLING;
 8001158:	f44f 1304 	mov.w	r3, #2162688	; 0x210000
 800115c:	61bb      	str	r3, [r7, #24]
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 800115e:	2300      	movs	r3, #0
 8001160:	61fb      	str	r3, [r7, #28]
  HAL_GPIO_Init(B1_GPIO_Port, &GPIO_InitStruct);
 8001162:	f107 0314 	add.w	r3, r7, #20
 8001166:	4619      	mov	r1, r3
 8001168:	4812      	ldr	r0, [pc, #72]	; (80011b4 <MX_GPIO_Init+0xe4>)
 800116a:	f001 f8cb 	bl	8002304 <HAL_GPIO_Init>

  /*Configure GPIO pin : PA1 */
  GPIO_InitStruct.Pin = GPIO_PIN_1;
 800116e:	2302      	movs	r3, #2
 8001170:	617b      	str	r3, [r7, #20]
  GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
 8001172:	2303      	movs	r3, #3
 8001174:	61bb      	str	r3, [r7, #24]
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 8001176:	2300      	movs	r3, #0
 8001178:	61fb      	str	r3, [r7, #28]
  HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
 800117a:	f107 0314 	add.w	r3, r7, #20
 800117e:	4619      	mov	r1, r3
 8001180:	f04f 4090 	mov.w	r0, #1207959552	; 0x48000000
 8001184:	f001 f8be 	bl	8002304 <HAL_GPIO_Init>

  /*Configure GPIO pin : PtPin */
  GPIO_InitStruct.Pin = LD2_Pin;
 8001188:	2320      	movs	r3, #32
 800118a:	617b      	str	r3, [r7, #20]
  GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
 800118c:	2301      	movs	r3, #1
 800118e:	61bb      	str	r3, [r7, #24]
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 8001190:	2300      	movs	r3, #0
 8001192:	61fb      	str	r3, [r7, #28]
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
 8001194:	2300      	movs	r3, #0
 8001196:	623b      	str	r3, [r7, #32]
  HAL_GPIO_Init(LD2_GPIO_Port, &GPIO_InitStruct);
 8001198:	f107 0314 	add.w	r3, r7, #20
 800119c:	4619      	mov	r1, r3
 800119e:	f04f 4090 	mov.w	r0, #1207959552	; 0x48000000
 80011a2:	f001 f8af 	bl	8002304 <HAL_GPIO_Init>

}
 80011a6:	bf00      	nop
 80011a8:	3728      	adds	r7, #40	; 0x28
 80011aa:	46bd      	mov	sp, r7
 80011ac:	bd80      	pop	{r7, pc}
 80011ae:	bf00      	nop
 80011b0:	40021000 	.word	0x40021000
 80011b4:	48000800 	.word	0x48000800

080011b8 <MX_I2C1_Init>:

I2C_HandleTypeDef hi2c1;

/* I2C1 init function */
void MX_I2C1_Init(void)
{
 80011b8:	b580      	push	{r7, lr}
 80011ba:	af00      	add	r7, sp, #0
  /* USER CODE END I2C1_Init 0 */

  /* USER CODE BEGIN I2C1_Init 1 */

  /* USER CODE END I2C1_Init 1 */
  hi2c1.Instance = I2C1;
 80011bc:	4b1b      	ldr	r3, [pc, #108]	; (800122c <MX_I2C1_Init+0x74>)
 80011be:	4a1c      	ldr	r2, [pc, #112]	; (8001230 <MX_I2C1_Init+0x78>)
 80011c0:	601a      	str	r2, [r3, #0]
  hi2c1.Init.Timing = 0x10909CEC;
 80011c2:	4b1a      	ldr	r3, [pc, #104]	; (800122c <MX_I2C1_Init+0x74>)
 80011c4:	4a1b      	ldr	r2, [pc, #108]	; (8001234 <MX_I2C1_Init+0x7c>)
 80011c6:	605a      	str	r2, [r3, #4]
  hi2c1.Init.OwnAddress1 = 0;
 80011c8:	4b18      	ldr	r3, [pc, #96]	; (800122c <MX_I2C1_Init+0x74>)
 80011ca:	2200      	movs	r2, #0
 80011cc:	609a      	str	r2, [r3, #8]
  hi2c1.Init.AddressingMode = I2C_ADDRESSINGMODE_7BIT;
 80011ce:	4b17      	ldr	r3, [pc, #92]	; (800122c <MX_I2C1_Init+0x74>)
 80011d0:	2201      	movs	r2, #1
 80011d2:	60da      	str	r2, [r3, #12]
  hi2c1.Init.DualAddressMode = I2C_DUALADDRESS_DISABLE;
 80011d4:	4b15      	ldr	r3, [pc, #84]	; (800122c <MX_I2C1_Init+0x74>)
 80011d6:	2200      	movs	r2, #0
 80011d8:	611a      	str	r2, [r3, #16]
  hi2c1.Init.OwnAddress2 = 0;
 80011da:	4b14      	ldr	r3, [pc, #80]	; (800122c <MX_I2C1_Init+0x74>)
 80011dc:	2200      	movs	r2, #0
 80011de:	615a      	str	r2, [r3, #20]
  hi2c1.Init.OwnAddress2Masks = I2C_OA2_NOMASK;
 80011e0:	4b12      	ldr	r3, [pc, #72]	; (800122c <MX_I2C1_Init+0x74>)
 80011e2:	2200      	movs	r2, #0
 80011e4:	619a      	str	r2, [r3, #24]
  hi2c1.Init.GeneralCallMode = I2C_GENERALCALL_DISABLE;
 80011e6:	4b11      	ldr	r3, [pc, #68]	; (800122c <MX_I2C1_Init+0x74>)
 80011e8:	2200      	movs	r2, #0
 80011ea:	61da      	str	r2, [r3, #28]
  hi2c1.Init.NoStretchMode = I2C_NOSTRETCH_DISABLE;
 80011ec:	4b0f      	ldr	r3, [pc, #60]	; (800122c <MX_I2C1_Init+0x74>)
 80011ee:	2200      	movs	r2, #0
 80011f0:	621a      	str	r2, [r3, #32]
  if (HAL_I2C_Init(&hi2c1) != HAL_OK)
 80011f2:	480e      	ldr	r0, [pc, #56]	; (800122c <MX_I2C1_Init+0x74>)
 80011f4:	f001 fa60 	bl	80026b8 <HAL_I2C_Init>
 80011f8:	4603      	mov	r3, r0
 80011fa:	2b00      	cmp	r3, #0
 80011fc:	d001      	beq.n	8001202 <MX_I2C1_Init+0x4a>
  {
    Error_Handler();
 80011fe:	f000 fbd0 	bl	80019a2 <Error_Handler>
  }
  /** Configure Analogue filter
  */
  if (HAL_I2CEx_ConfigAnalogFilter(&hi2c1, I2C_ANALOGFILTER_ENABLE) != HAL_OK)
 8001202:	2100      	movs	r1, #0
 8001204:	4809      	ldr	r0, [pc, #36]	; (800122c <MX_I2C1_Init+0x74>)
 8001206:	f002 fc55 	bl	8003ab4 <HAL_I2CEx_ConfigAnalogFilter>
 800120a:	4603      	mov	r3, r0
 800120c:	2b00      	cmp	r3, #0
 800120e:	d001      	beq.n	8001214 <MX_I2C1_Init+0x5c>
  {
    Error_Handler();
 8001210:	f000 fbc7 	bl	80019a2 <Error_Handler>
  }
  /** Configure Digital filter
  */
  if (HAL_I2CEx_ConfigDigitalFilter(&hi2c1, 0) != HAL_OK)
 8001214:	2100      	movs	r1, #0
 8001216:	4805      	ldr	r0, [pc, #20]	; (800122c <MX_I2C1_Init+0x74>)
 8001218:	f002 fc97 	bl	8003b4a <HAL_I2CEx_ConfigDigitalFilter>
 800121c:	4603      	mov	r3, r0
 800121e:	2b00      	cmp	r3, #0
 8001220:	d001      	beq.n	8001226 <MX_I2C1_Init+0x6e>
  {
    Error_Handler();
 8001222:	f000 fbbe 	bl	80019a2 <Error_Handler>
  }
  /* USER CODE BEGIN I2C1_Init 2 */

  /* USER CODE END I2C1_Init 2 */

}
 8001226:	bf00      	nop
 8001228:	bd80      	pop	{r7, pc}
 800122a:	bf00      	nop
 800122c:	20000214 	.word	0x20000214
 8001230:	40005400 	.word	0x40005400
 8001234:	10909cec 	.word	0x10909cec

08001238 <HAL_I2C_MspInit>:

void HAL_I2C_MspInit(I2C_HandleTypeDef* i2cHandle)
{
 8001238:	b580      	push	{r7, lr}
 800123a:	b0ac      	sub	sp, #176	; 0xb0
 800123c:	af00      	add	r7, sp, #0
 800123e:	6078      	str	r0, [r7, #4]

  GPIO_InitTypeDef GPIO_InitStruct = {0};
 8001240:	f107 039c 	add.w	r3, r7, #156	; 0x9c
 8001244:	2200      	movs	r2, #0
 8001246:	601a      	str	r2, [r3, #0]
 8001248:	605a      	str	r2, [r3, #4]
 800124a:	609a      	str	r2, [r3, #8]
 800124c:	60da      	str	r2, [r3, #12]
 800124e:	611a      	str	r2, [r3, #16]
  RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
 8001250:	f107 0314 	add.w	r3, r7, #20
 8001254:	2288      	movs	r2, #136	; 0x88
 8001256:	2100      	movs	r1, #0
 8001258:	4618      	mov	r0, r3
 800125a:	f004 fff1 	bl	8006240 <memset>
  if(i2cHandle->Instance==I2C1)
 800125e:	687b      	ldr	r3, [r7, #4]
 8001260:	681b      	ldr	r3, [r3, #0]
 8001262:	4a29      	ldr	r2, [pc, #164]	; (8001308 <HAL_I2C_MspInit+0xd0>)
 8001264:	4293      	cmp	r3, r2
 8001266:	d14b      	bne.n	8001300 <HAL_I2C_MspInit+0xc8>
  /* USER CODE BEGIN I2C1_MspInit 0 */

  /* USER CODE END I2C1_MspInit 0 */
  /** Initializes the peripherals clock
  */
    PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_I2C1;
 8001268:	2340      	movs	r3, #64	; 0x40
 800126a:	617b      	str	r3, [r7, #20]
    PeriphClkInit.I2c1ClockSelection = RCC_I2C1CLKSOURCE_PCLK1;
 800126c:	2300      	movs	r3, #0
 800126e:	667b      	str	r3, [r7, #100]	; 0x64
    if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
 8001270:	f107 0314 	add.w	r3, r7, #20
 8001274:	4618      	mov	r0, r3
 8001276:	f003 fb05 	bl	8004884 <HAL_RCCEx_PeriphCLKConfig>
 800127a:	4603      	mov	r3, r0
 800127c:	2b00      	cmp	r3, #0
 800127e:	d001      	beq.n	8001284 <HAL_I2C_MspInit+0x4c>
    {
      Error_Handler();
 8001280:	f000 fb8f 	bl	80019a2 <Error_Handler>
    }

    __HAL_RCC_GPIOB_CLK_ENABLE();
 8001284:	4b21      	ldr	r3, [pc, #132]	; (800130c <HAL_I2C_MspInit+0xd4>)
 8001286:	6cdb      	ldr	r3, [r3, #76]	; 0x4c
 8001288:	4a20      	ldr	r2, [pc, #128]	; (800130c <HAL_I2C_MspInit+0xd4>)
 800128a:	f043 0302 	orr.w	r3, r3, #2
 800128e:	64d3      	str	r3, [r2, #76]	; 0x4c
 8001290:	4b1e      	ldr	r3, [pc, #120]	; (800130c <HAL_I2C_MspInit+0xd4>)
 8001292:	6cdb      	ldr	r3, [r3, #76]	; 0x4c
 8001294:	f003 0302 	and.w	r3, r3, #2
 8001298:	613b      	str	r3, [r7, #16]
 800129a:	693b      	ldr	r3, [r7, #16]
    /**I2C1 GPIO Configuration
    PB8     ------> I2C1_SCL
    PB9     ------> I2C1_SDA
    */
    GPIO_InitStruct.Pin = GPIO_PIN_8|GPIO_PIN_9;
 800129c:	f44f 7340 	mov.w	r3, #768	; 0x300
 80012a0:	f8c7 309c 	str.w	r3, [r7, #156]	; 0x9c
    GPIO_InitStruct.Mode = GPIO_MODE_AF_OD;
 80012a4:	2312      	movs	r3, #18
 80012a6:	f8c7 30a0 	str.w	r3, [r7, #160]	; 0xa0
    GPIO_InitStruct.Pull = GPIO_NOPULL;
 80012aa:	2300      	movs	r3, #0
 80012ac:	f8c7 30a4 	str.w	r3, [r7, #164]	; 0xa4
    GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
 80012b0:	2303      	movs	r3, #3
 80012b2:	f8c7 30a8 	str.w	r3, [r7, #168]	; 0xa8
    GPIO_InitStruct.Alternate = GPIO_AF4_I2C1;
 80012b6:	2304      	movs	r3, #4
 80012b8:	f8c7 30ac 	str.w	r3, [r7, #172]	; 0xac
    HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
 80012bc:	f107 039c 	add.w	r3, r7, #156	; 0x9c
 80012c0:	4619      	mov	r1, r3
 80012c2:	4813      	ldr	r0, [pc, #76]	; (8001310 <HAL_I2C_MspInit+0xd8>)
 80012c4:	f001 f81e 	bl	8002304 <HAL_GPIO_Init>

    /* I2C1 clock enable */
    __HAL_RCC_I2C1_CLK_ENABLE();
 80012c8:	4b10      	ldr	r3, [pc, #64]	; (800130c <HAL_I2C_MspInit+0xd4>)
 80012ca:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 80012cc:	4a0f      	ldr	r2, [pc, #60]	; (800130c <HAL_I2C_MspInit+0xd4>)
 80012ce:	f443 1300 	orr.w	r3, r3, #2097152	; 0x200000
 80012d2:	6593      	str	r3, [r2, #88]	; 0x58
 80012d4:	4b0d      	ldr	r3, [pc, #52]	; (800130c <HAL_I2C_MspInit+0xd4>)
 80012d6:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 80012d8:	f403 1300 	and.w	r3, r3, #2097152	; 0x200000
 80012dc:	60fb      	str	r3, [r7, #12]
 80012de:	68fb      	ldr	r3, [r7, #12]

    /* I2C1 interrupt Init */
    HAL_NVIC_SetPriority(I2C1_EV_IRQn, 0, 0);
 80012e0:	2200      	movs	r2, #0
 80012e2:	2100      	movs	r1, #0
 80012e4:	201f      	movs	r0, #31
 80012e6:	f000 ff88 	bl	80021fa <HAL_NVIC_SetPriority>
    HAL_NVIC_EnableIRQ(I2C1_EV_IRQn);
 80012ea:	201f      	movs	r0, #31
 80012ec:	f000 ffa1 	bl	8002232 <HAL_NVIC_EnableIRQ>
    HAL_NVIC_SetPriority(I2C1_ER_IRQn, 0, 0);
 80012f0:	2200      	movs	r2, #0
 80012f2:	2100      	movs	r1, #0
 80012f4:	2020      	movs	r0, #32
 80012f6:	f000 ff80 	bl	80021fa <HAL_NVIC_SetPriority>
    HAL_NVIC_EnableIRQ(I2C1_ER_IRQn);
 80012fa:	2020      	movs	r0, #32
 80012fc:	f000 ff99 	bl	8002232 <HAL_NVIC_EnableIRQ>
  /* USER CODE BEGIN I2C1_MspInit 1 */

  /* USER CODE END I2C1_MspInit 1 */
  }
}
 8001300:	bf00      	nop
 8001302:	37b0      	adds	r7, #176	; 0xb0
 8001304:	46bd      	mov	sp, r7
 8001306:	bd80      	pop	{r7, pc}
 8001308:	40005400 	.word	0x40005400
 800130c:	40021000 	.word	0x40021000
 8001310:	48000400 	.word	0x48000400

08001314 <lcd_init>:
I2C_HandleTypeDef hi2c3;

UART_HandleTypeDef huart2;

void lcd_init(I2C_HandleTypeDef* I2Cx, rgb_lcd* DataStruct)
{
 8001314:	b580      	push	{r7, lr}
 8001316:	b08a      	sub	sp, #40	; 0x28
 8001318:	af02      	add	r7, sp, #8
 800131a:	6078      	str	r0, [r7, #4]
 800131c:	6039      	str	r1, [r7, #0]
	I2C_HandleTypeDef* Handle = I2Cx;
 800131e:	687b      	ldr	r3, [r7, #4]
 8001320:	61fb      	str	r3, [r7, #28]
	DataStruct->_displayfunction |= LCD_2LINE | LCD_5x10DOTS; // MODE 2 LIGNES
 8001322:	683b      	ldr	r3, [r7, #0]
 8001324:	781b      	ldrb	r3, [r3, #0]
 8001326:	f043 030c 	orr.w	r3, r3, #12
 800132a:	b2da      	uxtb	r2, r3
 800132c:	683b      	ldr	r3, [r7, #0]
 800132e:	701a      	strb	r2, [r3, #0]
	uint8_t data[2];
	data[0] = 0x80;
 8001330:	2380      	movs	r3, #128	; 0x80
 8001332:	763b      	strb	r3, [r7, #24]
	data[1] = LCD_FUNCTIONSET | DataStruct->_displayfunction;
 8001334:	683b      	ldr	r3, [r7, #0]
 8001336:	781b      	ldrb	r3, [r3, #0]
 8001338:	f043 0320 	orr.w	r3, r3, #32
 800133c:	b2db      	uxtb	r3, r3
 800133e:	767b      	strb	r3, [r7, #25]

	HAL_UART_Transmit(&huart2,(uint8_t *)data,2,10);
 8001340:	f107 0118 	add.w	r1, r7, #24
 8001344:	230a      	movs	r3, #10
 8001346:	2202      	movs	r2, #2
 8001348:	486c      	ldr	r0, [pc, #432]	; (80014fc <lcd_init+0x1e8>)
 800134a:	f004 fa81 	bl	8005850 <HAL_UART_Transmit>
	char newline[2] = "\r\n";
 800134e:	f640 230d 	movw	r3, #2573	; 0xa0d
 8001352:	82bb      	strh	r3, [r7, #20]
	HAL_UART_Transmit(&huart2, (uint8_t *) newline, 2, 10);
 8001354:	f107 0114 	add.w	r1, r7, #20
 8001358:	230a      	movs	r3, #10
 800135a:	2202      	movs	r2, #2
 800135c:	4867      	ldr	r0, [pc, #412]	; (80014fc <lcd_init+0x1e8>)
 800135e:	f004 fa77 	bl	8005850 <HAL_UART_Transmit>

	HAL_StatusTypeDef status = HAL_I2C_IsDeviceReady(Handle,LCD_ADDRESS,5,100);
 8001362:	2364      	movs	r3, #100	; 0x64
 8001364:	2205      	movs	r2, #5
 8001366:	217c      	movs	r1, #124	; 0x7c
 8001368:	69f8      	ldr	r0, [r7, #28]
 800136a:	f001 fb29 	bl	80029c0 <HAL_I2C_IsDeviceReady>
 800136e:	4603      	mov	r3, r0
 8001370:	74fb      	strb	r3, [r7, #19]
	HAL_UART_Transmit(&huart2,&status,1,10);
 8001372:	f107 0113 	add.w	r1, r7, #19
 8001376:	230a      	movs	r3, #10
 8001378:	2201      	movs	r2, #1
 800137a:	4860      	ldr	r0, [pc, #384]	; (80014fc <lcd_init+0x1e8>)
 800137c:	f004 fa68 	bl	8005850 <HAL_UART_Transmit>
	HAL_Delay(50);
 8001380:	2032      	movs	r0, #50	; 0x32
 8001382:	f000 fe3b 	bl	8001ffc <HAL_Delay>

	HAL_StatusTypeDef status2 = HAL_I2C_Master_Transmit(Handle, LCD_ADDRESS, data,2,5000);
 8001386:	f107 0218 	add.w	r2, r7, #24
 800138a:	f241 3388 	movw	r3, #5000	; 0x1388
 800138e:	9300      	str	r3, [sp, #0]
 8001390:	2302      	movs	r3, #2
 8001392:	217c      	movs	r1, #124	; 0x7c
 8001394:	69f8      	ldr	r0, [r7, #28]
 8001396:	f001 fa1f 	bl	80027d8 <HAL_I2C_Master_Transmit>
 800139a:	4603      	mov	r3, r0
 800139c:	74bb      	strb	r3, [r7, #18]
	HAL_UART_Transmit(&huart2,&status2,1,10);
 800139e:	f107 0112 	add.w	r1, r7, #18
 80013a2:	230a      	movs	r3, #10
 80013a4:	2201      	movs	r2, #1
 80013a6:	4855      	ldr	r0, [pc, #340]	; (80014fc <lcd_init+0x1e8>)
 80013a8:	f004 fa52 	bl	8005850 <HAL_UART_Transmit>
	HAL_Delay(50);
 80013ac:	2032      	movs	r0, #50	; 0x32
 80013ae:	f000 fe25 	bl	8001ffc <HAL_Delay>

	HAL_I2C_Master_Transmit(Handle,LCD_ADDRESS,data,2,5000);
 80013b2:	f107 0218 	add.w	r2, r7, #24
 80013b6:	f241 3388 	movw	r3, #5000	; 0x1388
 80013ba:	9300      	str	r3, [sp, #0]
 80013bc:	2302      	movs	r3, #2
 80013be:	217c      	movs	r1, #124	; 0x7c
 80013c0:	69f8      	ldr	r0, [r7, #28]
 80013c2:	f001 fa09 	bl	80027d8 <HAL_I2C_Master_Transmit>
	HAL_Delay(5);
 80013c6:	2005      	movs	r0, #5
 80013c8:	f000 fe18 	bl	8001ffc <HAL_Delay>

	HAL_I2C_Master_Transmit(Handle,LCD_ADDRESS,data,2,5000);
 80013cc:	f107 0218 	add.w	r2, r7, #24
 80013d0:	f241 3388 	movw	r3, #5000	; 0x1388
 80013d4:	9300      	str	r3, [sp, #0]
 80013d6:	2302      	movs	r3, #2
 80013d8:	217c      	movs	r1, #124	; 0x7c
 80013da:	69f8      	ldr	r0, [r7, #28]
 80013dc:	f001 f9fc 	bl	80027d8 <HAL_I2C_Master_Transmit>

	// CONTROL
	DataStruct->_displaycontrol = LCD_DISPLAYON | LCD_CURSOROFF | LCD_BLINKOFF;
 80013e0:	683b      	ldr	r3, [r7, #0]
 80013e2:	2204      	movs	r2, #4
 80013e4:	705a      	strb	r2, [r3, #1]

	data[1] = LCD_DISPLAYCONTROL | DataStruct->_displaycontrol;
 80013e6:	683b      	ldr	r3, [r7, #0]
 80013e8:	785b      	ldrb	r3, [r3, #1]
 80013ea:	f043 0308 	orr.w	r3, r3, #8
 80013ee:	b2db      	uxtb	r3, r3
 80013f0:	767b      	strb	r3, [r7, #25]
	HAL_I2C_Master_Transmit(Handle,LCD_ADDRESS, data,2,1000);
 80013f2:	f107 0218 	add.w	r2, r7, #24
 80013f6:	f44f 737a 	mov.w	r3, #1000	; 0x3e8
 80013fa:	9300      	str	r3, [sp, #0]
 80013fc:	2302      	movs	r3, #2
 80013fe:	217c      	movs	r1, #124	; 0x7c
 8001400:	69f8      	ldr	r0, [r7, #28]
 8001402:	f001 f9e9 	bl	80027d8 <HAL_I2C_Master_Transmit>

	data[1] = LCD_CLEARDISPLAY;
 8001406:	2301      	movs	r3, #1
 8001408:	767b      	strb	r3, [r7, #25]
	HAL_I2C_Master_Transmit(Handle, (uint16_t)LCD_ADDRESS, (uint8_t *)data,2,1000);
 800140a:	f107 0218 	add.w	r2, r7, #24
 800140e:	f44f 737a 	mov.w	r3, #1000	; 0x3e8
 8001412:	9300      	str	r3, [sp, #0]
 8001414:	2302      	movs	r3, #2
 8001416:	217c      	movs	r1, #124	; 0x7c
 8001418:	69f8      	ldr	r0, [r7, #28]
 800141a:	f001 f9dd 	bl	80027d8 <HAL_I2C_Master_Transmit>
	HAL_Delay(2);
 800141e:	2002      	movs	r0, #2
 8001420:	f000 fdec 	bl	8001ffc <HAL_Delay>

	// MODE
	DataStruct->_displaymode = LCD_ENTRYLEFT | LCD_ENTRYSHIFTDECREMENT;
 8001424:	683b      	ldr	r3, [r7, #0]
 8001426:	2202      	movs	r2, #2
 8001428:	709a      	strb	r2, [r3, #2]
	data[1] = LCD_ENTRYMODESET | DataStruct->_displaymode;
 800142a:	683b      	ldr	r3, [r7, #0]
 800142c:	789b      	ldrb	r3, [r3, #2]
 800142e:	f043 0304 	orr.w	r3, r3, #4
 8001432:	b2db      	uxtb	r3, r3
 8001434:	767b      	strb	r3, [r7, #25]
	HAL_I2C_Master_Transmit(Handle, (uint16_t)LCD_ADDRESS, (uint8_t *)data,2,1000);
 8001436:	f107 0218 	add.w	r2, r7, #24
 800143a:	f44f 737a 	mov.w	r3, #1000	; 0x3e8
 800143e:	9300      	str	r3, [sp, #0]
 8001440:	2302      	movs	r3, #2
 8001442:	217c      	movs	r1, #124	; 0x7c
 8001444:	69f8      	ldr	r0, [r7, #28]
 8001446:	f001 f9c7 	bl	80027d8 <HAL_I2C_Master_Transmit>

	// initialisation du lcd_rgb_Backight
		uint8_t data_backlight[2];
		data_backlight[0] = REG_MODE1;
 800144a:	2300      	movs	r3, #0
 800144c:	743b      	strb	r3, [r7, #16]
		data_backlight[1] = 0;
 800144e:	2300      	movs	r3, #0
 8001450:	747b      	strb	r3, [r7, #17]
		HAL_I2C_Master_Transmit(Handle, (uint16_t)RGB_ADDRESS, (uint8_t *)data_backlight,2,1000);
 8001452:	f107 0210 	add.w	r2, r7, #16
 8001456:	f44f 737a 	mov.w	r3, #1000	; 0x3e8
 800145a:	9300      	str	r3, [sp, #0]
 800145c:	2302      	movs	r3, #2
 800145e:	21c4      	movs	r1, #196	; 0xc4
 8001460:	69f8      	ldr	r0, [r7, #28]
 8001462:	f001 f9b9 	bl	80027d8 <HAL_I2C_Master_Transmit>

		data_backlight[0] = REG_OUTPUT;
 8001466:	2308      	movs	r3, #8
 8001468:	743b      	strb	r3, [r7, #16]
		data_backlight[1] = 0xFF;
 800146a:	23ff      	movs	r3, #255	; 0xff
 800146c:	747b      	strb	r3, [r7, #17]
		HAL_I2C_Master_Transmit(Handle, (uint16_t)RGB_ADDRESS, (uint8_t *)data_backlight,2,1000);
 800146e:	f107 0210 	add.w	r2, r7, #16
 8001472:	f44f 737a 	mov.w	r3, #1000	; 0x3e8
 8001476:	9300      	str	r3, [sp, #0]
 8001478:	2302      	movs	r3, #2
 800147a:	21c4      	movs	r1, #196	; 0xc4
 800147c:	69f8      	ldr	r0, [r7, #28]
 800147e:	f001 f9ab 	bl	80027d8 <HAL_I2C_Master_Transmit>

		data_backlight[0] = REG_MODE2;
 8001482:	2301      	movs	r3, #1
 8001484:	743b      	strb	r3, [r7, #16]
		data_backlight[1] = 0x20;
 8001486:	2320      	movs	r3, #32
 8001488:	747b      	strb	r3, [r7, #17]
		HAL_I2C_Master_Transmit(Handle, (uint16_t)RGB_ADDRESS, (uint8_t *)data_backlight,2,1000);
 800148a:	f107 0210 	add.w	r2, r7, #16
 800148e:	f44f 737a 	mov.w	r3, #1000	; 0x3e8
 8001492:	9300      	str	r3, [sp, #0]
 8001494:	2302      	movs	r3, #2
 8001496:	21c4      	movs	r1, #196	; 0xc4
 8001498:	69f8      	ldr	r0, [r7, #28]
 800149a:	f001 f99d 	bl	80027d8 <HAL_I2C_Master_Transmit>

		//couleur du LCD en Blanc
		uint8_t data_rgb[2];
		data_rgb[0] = REG_RED;
 800149e:	2304      	movs	r3, #4
 80014a0:	733b      	strb	r3, [r7, #12]
		data_rgb[1] = 255;
 80014a2:	23ff      	movs	r3, #255	; 0xff
 80014a4:	737b      	strb	r3, [r7, #13]
		HAL_I2C_Master_Transmit(Handle, (uint16_t)RGB_ADDRESS, (uint8_t *)data_rgb,2,1000);
 80014a6:	f107 020c 	add.w	r2, r7, #12
 80014aa:	f44f 737a 	mov.w	r3, #1000	; 0x3e8
 80014ae:	9300      	str	r3, [sp, #0]
 80014b0:	2302      	movs	r3, #2
 80014b2:	21c4      	movs	r1, #196	; 0xc4
 80014b4:	69f8      	ldr	r0, [r7, #28]
 80014b6:	f001 f98f 	bl	80027d8 <HAL_I2C_Master_Transmit>

		data_rgb[0] = REG_GREEN;
 80014ba:	2303      	movs	r3, #3
 80014bc:	733b      	strb	r3, [r7, #12]
		data_rgb[1] = 255;
 80014be:	23ff      	movs	r3, #255	; 0xff
 80014c0:	737b      	strb	r3, [r7, #13]
		HAL_I2C_Master_Transmit(Handle, (uint16_t)RGB_ADDRESS, (uint8_t *)data_rgb,2,1000);
 80014c2:	f107 020c 	add.w	r2, r7, #12
 80014c6:	f44f 737a 	mov.w	r3, #1000	; 0x3e8
 80014ca:	9300      	str	r3, [sp, #0]
 80014cc:	2302      	movs	r3, #2
 80014ce:	21c4      	movs	r1, #196	; 0xc4
 80014d0:	69f8      	ldr	r0, [r7, #28]
 80014d2:	f001 f981 	bl	80027d8 <HAL_I2C_Master_Transmit>

		data_rgb[0] = REG_BLUE;
 80014d6:	2302      	movs	r3, #2
 80014d8:	733b      	strb	r3, [r7, #12]
		data_rgb[1] = 255;
 80014da:	23ff      	movs	r3, #255	; 0xff
 80014dc:	737b      	strb	r3, [r7, #13]
		HAL_I2C_Master_Transmit(Handle, (uint16_t)RGB_ADDRESS, (uint8_t *)data_rgb,2,1000);
 80014de:	f107 020c 	add.w	r2, r7, #12
 80014e2:	f44f 737a 	mov.w	r3, #1000	; 0x3e8
 80014e6:	9300      	str	r3, [sp, #0]
 80014e8:	2302      	movs	r3, #2
 80014ea:	21c4      	movs	r1, #196	; 0xc4
 80014ec:	69f8      	ldr	r0, [r7, #28]
 80014ee:	f001 f973 	bl	80027d8 <HAL_I2C_Master_Transmit>


}
 80014f2:	bf00      	nop
 80014f4:	3720      	adds	r7, #32
 80014f6:	46bd      	mov	sp, r7
 80014f8:	bd80      	pop	{r7, pc}
 80014fa:	bf00      	nop
 80014fc:	200002ac 	.word	0x200002ac

08001500 <clearlcd>:



void clearlcd(void) // permet d'effacer tout ce qui s'affiche sur le lcd
{
 8001500:	b580      	push	{r7, lr}
 8001502:	af00      	add	r7, sp, #0
	lcd_position(&hi2c3,0,0);
 8001504:	2200      	movs	r2, #0
 8001506:	2100      	movs	r1, #0
 8001508:	4808      	ldr	r0, [pc, #32]	; (800152c <clearlcd+0x2c>)
 800150a:	f000 f83c 	bl	8001586 <lcd_position>
	lcd_print(&hi2c3,"                ");
 800150e:	4908      	ldr	r1, [pc, #32]	; (8001530 <clearlcd+0x30>)
 8001510:	4806      	ldr	r0, [pc, #24]	; (800152c <clearlcd+0x2c>)
 8001512:	f000 f80f 	bl	8001534 <lcd_print>
	lcd_position(&hi2c3,0,1);
 8001516:	2201      	movs	r2, #1
 8001518:	2100      	movs	r1, #0
 800151a:	4804      	ldr	r0, [pc, #16]	; (800152c <clearlcd+0x2c>)
 800151c:	f000 f833 	bl	8001586 <lcd_position>
	lcd_print(&hi2c3,"                ");
 8001520:	4903      	ldr	r1, [pc, #12]	; (8001530 <clearlcd+0x30>)
 8001522:	4802      	ldr	r0, [pc, #8]	; (800152c <clearlcd+0x2c>)
 8001524:	f000 f806 	bl	8001534 <lcd_print>
}
 8001528:	bf00      	nop
 800152a:	bd80      	pop	{r7, pc}
 800152c:	20000260 	.word	0x20000260
 8001530:	08008f98 	.word	0x08008f98

08001534 <lcd_print>:
    unsigned char data[2] = {0x40, value};
    HAL_I2C_Master_Transmit(Handle,LCD_ADDRESS, data,2,1000);
}

void lcd_print(I2C_HandleTypeDef* I2Cx, char *str)
{
 8001534:	b580      	push	{r7, lr}
 8001536:	b088      	sub	sp, #32
 8001538:	af02      	add	r7, sp, #8
 800153a:	6078      	str	r0, [r7, #4]
 800153c:	6039      	str	r1, [r7, #0]
	I2C_HandleTypeDef* Handle = I2Cx;
 800153e:	687b      	ldr	r3, [r7, #4]
 8001540:	613b      	str	r3, [r7, #16]
    char data[2];
    data[0] = 0x40;
 8001542:	2340      	movs	r3, #64	; 0x40
 8001544:	733b      	strb	r3, [r7, #12]
    int i=0;
 8001546:	2300      	movs	r3, #0
 8001548:	617b      	str	r3, [r7, #20]
    while(str[i] != '\0')
 800154a:	e011      	b.n	8001570 <lcd_print+0x3c>
    {
            data[1] = str[i];
 800154c:	697b      	ldr	r3, [r7, #20]
 800154e:	683a      	ldr	r2, [r7, #0]
 8001550:	4413      	add	r3, r2
 8001552:	781b      	ldrb	r3, [r3, #0]
 8001554:	737b      	strb	r3, [r7, #13]
            HAL_I2C_Master_Transmit(Handle,LCD_ADDRESS,(uint8_t *) data, 2,1000);
 8001556:	f107 020c 	add.w	r2, r7, #12
 800155a:	f44f 737a 	mov.w	r3, #1000	; 0x3e8
 800155e:	9300      	str	r3, [sp, #0]
 8001560:	2302      	movs	r3, #2
 8001562:	217c      	movs	r1, #124	; 0x7c
 8001564:	6938      	ldr	r0, [r7, #16]
 8001566:	f001 f937 	bl	80027d8 <HAL_I2C_Master_Transmit>
            i++;
 800156a:	697b      	ldr	r3, [r7, #20]
 800156c:	3301      	adds	r3, #1
 800156e:	617b      	str	r3, [r7, #20]
    while(str[i] != '\0')
 8001570:	697b      	ldr	r3, [r7, #20]
 8001572:	683a      	ldr	r2, [r7, #0]
 8001574:	4413      	add	r3, r2
 8001576:	781b      	ldrb	r3, [r3, #0]
 8001578:	2b00      	cmp	r3, #0
 800157a:	d1e7      	bne.n	800154c <lcd_print+0x18>
   }
}
 800157c:	bf00      	nop
 800157e:	bf00      	nop
 8001580:	3718      	adds	r7, #24
 8001582:	46bd      	mov	sp, r7
 8001584:	bd80      	pop	{r7, pc}

08001586 <lcd_position>:

void lcd_position(I2C_HandleTypeDef* I2Cx,char col, char row) // position du curseur le lcd
{
 8001586:	b580      	push	{r7, lr}
 8001588:	b086      	sub	sp, #24
 800158a:	af02      	add	r7, sp, #8
 800158c:	6078      	str	r0, [r7, #4]
 800158e:	460b      	mov	r3, r1
 8001590:	70fb      	strb	r3, [r7, #3]
 8001592:	4613      	mov	r3, r2
 8001594:	70bb      	strb	r3, [r7, #2]
	I2C_HandleTypeDef* Handle = I2Cx;
 8001596:	687b      	ldr	r3, [r7, #4]
 8001598:	60fb      	str	r3, [r7, #12]
    if(row == 0)
 800159a:	78bb      	ldrb	r3, [r7, #2]
 800159c:	2b00      	cmp	r3, #0
 800159e:	d104      	bne.n	80015aa <lcd_position+0x24>
    {
        col = col | 0x80;
 80015a0:	78fb      	ldrb	r3, [r7, #3]
 80015a2:	f063 037f 	orn	r3, r3, #127	; 0x7f
 80015a6:	70fb      	strb	r3, [r7, #3]
 80015a8:	e003      	b.n	80015b2 <lcd_position+0x2c>
    }
    else
    {
        col = col | 0xc0;
 80015aa:	78fb      	ldrb	r3, [r7, #3]
 80015ac:	f063 033f 	orn	r3, r3, #63	; 0x3f
 80015b0:	70fb      	strb	r3, [r7, #3]
    }

    char data[2];
    data[0] = 0x80;
 80015b2:	2380      	movs	r3, #128	; 0x80
 80015b4:	723b      	strb	r3, [r7, #8]
    data[1] = col;
 80015b6:	78fb      	ldrb	r3, [r7, #3]
 80015b8:	727b      	strb	r3, [r7, #9]
    HAL_I2C_Master_Transmit(Handle,LCD_ADDRESS,(uint8_t *) data, 2,1000);
 80015ba:	f107 0208 	add.w	r2, r7, #8
 80015be:	f44f 737a 	mov.w	r3, #1000	; 0x3e8
 80015c2:	9300      	str	r3, [sp, #0]
 80015c4:	2302      	movs	r3, #2
 80015c6:	217c      	movs	r1, #124	; 0x7c
 80015c8:	68f8      	ldr	r0, [r7, #12]
 80015ca:	f001 f905 	bl	80027d8 <HAL_I2C_Master_Transmit>
}
 80015ce:	bf00      	nop
 80015d0:	3710      	adds	r7, #16
 80015d2:	46bd      	mov	sp, r7
 80015d4:	bd80      	pop	{r7, pc}
	...

080015d8 <reglagecouleur>:

void reglagecouleur(uint8_t R,uint8_t G,uint8_t B)
{
 80015d8:	b580      	push	{r7, lr}
 80015da:	b088      	sub	sp, #32
 80015dc:	af02      	add	r7, sp, #8
 80015de:	4603      	mov	r3, r0
 80015e0:	71fb      	strb	r3, [r7, #7]
 80015e2:	460b      	mov	r3, r1
 80015e4:	71bb      	strb	r3, [r7, #6]
 80015e6:	4613      	mov	r3, r2
 80015e8:	717b      	strb	r3, [r7, #5]
	I2C_HandleTypeDef* Handle = &hi2c3;
 80015ea:	4b18      	ldr	r3, [pc, #96]	; (800164c <reglagecouleur+0x74>)
 80015ec:	617b      	str	r3, [r7, #20]
	uint8_t data_r[2];
	uint8_t data_g[2];
	uint8_t data_b[2];
	data_r[0] = REG_RED;
 80015ee:	2304      	movs	r3, #4
 80015f0:	743b      	strb	r3, [r7, #16]
	data_r[1] = R;
 80015f2:	79fb      	ldrb	r3, [r7, #7]
 80015f4:	747b      	strb	r3, [r7, #17]
	HAL_I2C_Master_Transmit(Handle, (uint16_t)RGB_ADDRESS, (uint8_t *)data_r,2,1000);
 80015f6:	f107 0210 	add.w	r2, r7, #16
 80015fa:	f44f 737a 	mov.w	r3, #1000	; 0x3e8
 80015fe:	9300      	str	r3, [sp, #0]
 8001600:	2302      	movs	r3, #2
 8001602:	21c4      	movs	r1, #196	; 0xc4
 8001604:	6978      	ldr	r0, [r7, #20]
 8001606:	f001 f8e7 	bl	80027d8 <HAL_I2C_Master_Transmit>

	data_g[0] = REG_GREEN;
 800160a:	2303      	movs	r3, #3
 800160c:	733b      	strb	r3, [r7, #12]
	data_g[1] = G;
 800160e:	79bb      	ldrb	r3, [r7, #6]
 8001610:	737b      	strb	r3, [r7, #13]
	HAL_I2C_Master_Transmit(Handle, (uint16_t)RGB_ADDRESS, (uint8_t *)data_g,2,1000);
 8001612:	f107 020c 	add.w	r2, r7, #12
 8001616:	f44f 737a 	mov.w	r3, #1000	; 0x3e8
 800161a:	9300      	str	r3, [sp, #0]
 800161c:	2302      	movs	r3, #2
 800161e:	21c4      	movs	r1, #196	; 0xc4
 8001620:	6978      	ldr	r0, [r7, #20]
 8001622:	f001 f8d9 	bl	80027d8 <HAL_I2C_Master_Transmit>

	data_b[0] = REG_BLUE;
 8001626:	2302      	movs	r3, #2
 8001628:	723b      	strb	r3, [r7, #8]
	data_b[1] = B;
 800162a:	797b      	ldrb	r3, [r7, #5]
 800162c:	727b      	strb	r3, [r7, #9]
	HAL_I2C_Master_Transmit(Handle, (uint16_t)RGB_ADDRESS, (uint8_t *)data_b,2,1000);
 800162e:	f107 0208 	add.w	r2, r7, #8
 8001632:	f44f 737a 	mov.w	r3, #1000	; 0x3e8
 8001636:	9300      	str	r3, [sp, #0]
 8001638:	2302      	movs	r3, #2
 800163a:	21c4      	movs	r1, #196	; 0xc4
 800163c:	6978      	ldr	r0, [r7, #20]
 800163e:	f001 f8cb 	bl	80027d8 <HAL_I2C_Master_Transmit>
}
 8001642:	bf00      	nop
 8001644:	3718      	adds	r7, #24
 8001646:	46bd      	mov	sp, r7
 8001648:	bd80      	pop	{r7, pc}
 800164a:	bf00      	nop
 800164c:	20000260 	.word	0x20000260

08001650 <DWT_Delay_us>:
{
 8001650:	b580      	push	{r7, lr}
 8001652:	b084      	sub	sp, #16
 8001654:	af00      	add	r7, sp, #0
 8001656:	6078      	str	r0, [r7, #4]
  uint32_t au32_initial_ticks = DWT->CYCCNT;
 8001658:	4b0f      	ldr	r3, [pc, #60]	; (8001698 <DWT_Delay_us+0x48>)
 800165a:	685b      	ldr	r3, [r3, #4]
 800165c:	60fb      	str	r3, [r7, #12]
  uint32_t au32_ticks = (HAL_RCC_GetHCLKFreq() / 1000000);
 800165e:	f003 f879 	bl	8004754 <HAL_RCC_GetHCLKFreq>
 8001662:	4603      	mov	r3, r0
 8001664:	4a0d      	ldr	r2, [pc, #52]	; (800169c <DWT_Delay_us+0x4c>)
 8001666:	fba2 2303 	umull	r2, r3, r2, r3
 800166a:	0c9b      	lsrs	r3, r3, #18
 800166c:	60bb      	str	r3, [r7, #8]
  au32_microseconds *= au32_ticks;
 800166e:	687b      	ldr	r3, [r7, #4]
 8001670:	68ba      	ldr	r2, [r7, #8]
 8001672:	fb02 f303 	mul.w	r3, r2, r3
 8001676:	607b      	str	r3, [r7, #4]
  while ((DWT->CYCCNT - au32_initial_ticks) < au32_microseconds-au32_ticks);
 8001678:	bf00      	nop
 800167a:	4b07      	ldr	r3, [pc, #28]	; (8001698 <DWT_Delay_us+0x48>)
 800167c:	685a      	ldr	r2, [r3, #4]
 800167e:	68fb      	ldr	r3, [r7, #12]
 8001680:	1ad2      	subs	r2, r2, r3
 8001682:	6879      	ldr	r1, [r7, #4]
 8001684:	68bb      	ldr	r3, [r7, #8]
 8001686:	1acb      	subs	r3, r1, r3
 8001688:	429a      	cmp	r2, r3
 800168a:	d3f6      	bcc.n	800167a <DWT_Delay_us+0x2a>
}
 800168c:	bf00      	nop
 800168e:	bf00      	nop
 8001690:	3710      	adds	r7, #16
 8001692:	46bd      	mov	sp, r7
 8001694:	bd80      	pop	{r7, pc}
 8001696:	bf00      	nop
 8001698:	e0001000 	.word	0xe0001000
 800169c:	431bde83 	.word	0x431bde83

080016a0 <main>:
/**
  * @brief  The application entry point.
  * @retval int
  */
int main(void)
{
 80016a0:	b580      	push	{r7, lr}
 80016a2:	b082      	sub	sp, #8
 80016a4:	af00      	add	r7, sp, #0
  /* USER CODE BEGIN 1 */

  int k = 0; //variable pour les boucles while
 80016a6:	2300      	movs	r3, #0
 80016a8:	607b      	str	r3, [r7, #4]
  /* USER CODE END 1 */

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

  /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  HAL_Init();
 80016aa:	f000 fc2b 	bl	8001f04 <HAL_Init>
  /* USER CODE BEGIN Init */

  /* USER CODE END Init */

  /* Configure the system clock */
  SystemClock_Config();
 80016ae:	f000 f927 	bl	8001900 <SystemClock_Config>
  /* USER CODE BEGIN SysInit */

  /* USER CODE END SysInit */

  /* Initialize all configured peripherals */
  MX_GPIO_Init();
 80016b2:	f7ff fd0d 	bl	80010d0 <MX_GPIO_Init>
  MX_USART2_UART_Init();
 80016b6:	f000 fb6f 	bl	8001d98 <MX_USART2_UART_Init>
  MX_I2C1_Init();
 80016ba:	f7ff fd7d 	bl	80011b8 <MX_I2C1_Init>
  MX_TIM2_Init();
 80016be:	f000 facf 	bl	8001c60 <MX_TIM2_Init>
  /* USER CODE BEGIN 2 */
  DWT_Delay_Init();
 80016c2:	f000 fb39 	bl	8001d38 <DWT_Delay_Init>
  lcd_init(&hi2c1, &lcdData); // initialise le lcd
 80016c6:	497b      	ldr	r1, [pc, #492]	; (80018b4 <main+0x214>)
 80016c8:	487b      	ldr	r0, [pc, #492]	; (80018b8 <main+0x218>)
 80016ca:	f7ff fe23 	bl	8001314 <lcd_init>
  lcd_position(&hi2c1,0,0);
 80016ce:	2200      	movs	r2, #0
 80016d0:	2100      	movs	r1, #0
 80016d2:	4879      	ldr	r0, [pc, #484]	; (80018b8 <main+0x218>)
 80016d4:	f7ff ff57 	bl	8001586 <lcd_position>
  lcd_print(&hi2c1,"Bonjour!!");
 80016d8:	4978      	ldr	r1, [pc, #480]	; (80018bc <main+0x21c>)
 80016da:	4877      	ldr	r0, [pc, #476]	; (80018b8 <main+0x218>)
 80016dc:	f7ff ff2a 	bl	8001534 <lcd_print>
  reglagecouleur(0,0,255);
 80016e0:	22ff      	movs	r2, #255	; 0xff
 80016e2:	2100      	movs	r1, #0
 80016e4:	2000      	movs	r0, #0
 80016e6:	f7ff ff77 	bl	80015d8 <reglagecouleur>
  HAL_Delay(3000);
 80016ea:	f640 30b8 	movw	r0, #3000	; 0xbb8
 80016ee:	f000 fc85 	bl	8001ffc <HAL_Delay>

    /* USER CODE BEGIN 3 */

	  /*commence la communication avec le capteur*/

	  HAL_Delay(3000);
 80016f2:	f640 30b8 	movw	r0, #3000	; 0xbb8
 80016f6:	f000 fc81 	bl	8001ffc <HAL_Delay>
	  Data_Output(GPIOA, GPIO_PIN_1); //info vers le capteur
 80016fa:	2102      	movs	r1, #2
 80016fc:	f04f 4090 	mov.w	r0, #1207959552	; 0x48000000
 8001700:	f7ff fc46 	bl	8000f90 <Data_Output>
	  HAL_GPIO_WritePin(GPIOA, GPIO_PIN_1, GPIO_PIN_RESET);
 8001704:	2200      	movs	r2, #0
 8001706:	2102      	movs	r1, #2
 8001708:	f04f 4090 	mov.w	r0, #1207959552	; 0x48000000
 800170c:	f000 ffbc 	bl	8002688 <HAL_GPIO_WritePin>
	  DWT_Delay_us(1200); //signal de commande
 8001710:	f44f 6096 	mov.w	r0, #1200	; 0x4b0
 8001714:	f7ff ff9c 	bl	8001650 <DWT_Delay_us>
	  HAL_GPIO_WritePin(GPIOA, GPIO_PIN_1, GPIO_PIN_SET);
 8001718:	2201      	movs	r2, #1
 800171a:	2102      	movs	r1, #2
 800171c:	f04f 4090 	mov.w	r0, #1207959552	; 0x48000000
 8001720:	f000 ffb2 	bl	8002688 <HAL_GPIO_WritePin>
	  DWT_Delay_us(30); //signal de commande
 8001724:	201e      	movs	r0, #30
 8001726:	f7ff ff93 	bl	8001650 <DWT_Delay_us>
	  Data_Input(GPIOA, GPIO_PIN_1); //info vers le microcontroleur
 800172a:	2102      	movs	r1, #2
 800172c:	f04f 4090 	mov.w	r0, #1207959552	; 0x48000000
 8001730:	f7ff fc4a 	bl	8000fc8 <Data_Input>

	  /*commence la reception de donnees*/

	  while(!(HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_1)));
 8001734:	bf00      	nop
 8001736:	2102      	movs	r1, #2
 8001738:	f04f 4090 	mov.w	r0, #1207959552	; 0x48000000
 800173c:	f000 ff8c 	bl	8002658 <HAL_GPIO_ReadPin>
 8001740:	4603      	mov	r3, r0
 8001742:	2b00      	cmp	r3, #0
 8001744:	d0f7      	beq.n	8001736 <main+0x96>

	  for (k=0;k<1000;k++)
 8001746:	2300      	movs	r3, #0
 8001748:	607b      	str	r3, [r7, #4]
 800174a:	e00a      	b.n	8001762 <main+0xc2>
	  {
		  if (HAL_GPIO_ReadPin (GPIOA, GPIO_PIN_1) == GPIO_PIN_RESET)
 800174c:	2102      	movs	r1, #2
 800174e:	f04f 4090 	mov.w	r0, #1207959552	; 0x48000000
 8001752:	f000 ff81 	bl	8002658 <HAL_GPIO_ReadPin>
 8001756:	4603      	mov	r3, r0
 8001758:	2b00      	cmp	r3, #0
 800175a:	d007      	beq.n	800176c <main+0xcc>
	  for (k=0;k<1000;k++)
 800175c:	687b      	ldr	r3, [r7, #4]
 800175e:	3301      	adds	r3, #1
 8001760:	607b      	str	r3, [r7, #4]
 8001762:	687b      	ldr	r3, [r7, #4]
 8001764:	f5b3 7f7a 	cmp.w	r3, #1000	; 0x3e8
 8001768:	dbf0      	blt.n	800174c <main+0xac>
 800176a:	e000      	b.n	800176e <main+0xce>
		  {
	  	  	break;
 800176c:	bf00      	nop
	  	  }
	  }

	  while(!(HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_1)));
 800176e:	bf00      	nop
 8001770:	2102      	movs	r1, #2
 8001772:	f04f 4090 	mov.w	r0, #1207959552	; 0x48000000
 8001776:	f000 ff6f 	bl	8002658 <HAL_GPIO_ReadPin>
 800177a:	4603      	mov	r3, r0
 800177c:	2b00      	cmp	r3, #0
 800177e:	d0f7      	beq.n	8001770 <main+0xd0>
	  DWT_Delay_us(40);
 8001780:	2028      	movs	r0, #40	; 0x28
 8001782:	f7ff ff65 	bl	8001650 <DWT_Delay_us>

	  Read_data(&dataH1); //dans la library HT.c
 8001786:	484e      	ldr	r0, [pc, #312]	; (80018c0 <main+0x220>)
 8001788:	f7ff fc3a 	bl	8001000 <Read_data>
	  Read_data(&dataH2);
 800178c:	484d      	ldr	r0, [pc, #308]	; (80018c4 <main+0x224>)
 800178e:	f7ff fc37 	bl	8001000 <Read_data>
	  Read_data(&dataT1);
 8001792:	484d      	ldr	r0, [pc, #308]	; (80018c8 <main+0x228>)
 8001794:	f7ff fc34 	bl	8001000 <Read_data>
	  Read_data(&dataT2);
 8001798:	484c      	ldr	r0, [pc, #304]	; (80018cc <main+0x22c>)
 800179a:	f7ff fc31 	bl	8001000 <Read_data>
	  Read_data(&SUM);
 800179e:	484c      	ldr	r0, [pc, #304]	; (80018d0 <main+0x230>)
 80017a0:	f7ff fc2e 	bl	8001000 <Read_data>

	  check = dataH1 + dataH2 + dataT1 + dataT2; //pour verifier la lecture dans le IDE
 80017a4:	4b46      	ldr	r3, [pc, #280]	; (80018c0 <main+0x220>)
 80017a6:	781a      	ldrb	r2, [r3, #0]
 80017a8:	4b46      	ldr	r3, [pc, #280]	; (80018c4 <main+0x224>)
 80017aa:	781b      	ldrb	r3, [r3, #0]
 80017ac:	4413      	add	r3, r2
 80017ae:	b2da      	uxtb	r2, r3
 80017b0:	4b45      	ldr	r3, [pc, #276]	; (80018c8 <main+0x228>)
 80017b2:	781b      	ldrb	r3, [r3, #0]
 80017b4:	4413      	add	r3, r2
 80017b6:	b2da      	uxtb	r2, r3
 80017b8:	4b44      	ldr	r3, [pc, #272]	; (80018cc <main+0x22c>)
 80017ba:	781b      	ldrb	r3, [r3, #0]
 80017bc:	4413      	add	r3, r2
 80017be:	b2da      	uxtb	r2, r3
 80017c0:	4b44      	ldr	r3, [pc, #272]	; (80018d4 <main+0x234>)
 80017c2:	701a      	strb	r2, [r3, #0]

	  RH = (dataH1<<8) | dataH2;
 80017c4:	4b3e      	ldr	r3, [pc, #248]	; (80018c0 <main+0x220>)
 80017c6:	781b      	ldrb	r3, [r3, #0]
 80017c8:	021b      	lsls	r3, r3, #8
 80017ca:	b21a      	sxth	r2, r3
 80017cc:	4b3d      	ldr	r3, [pc, #244]	; (80018c4 <main+0x224>)
 80017ce:	781b      	ldrb	r3, [r3, #0]
 80017d0:	b21b      	sxth	r3, r3
 80017d2:	4313      	orrs	r3, r2
 80017d4:	b21b      	sxth	r3, r3
 80017d6:	b29a      	uxth	r2, r3
 80017d8:	4b3f      	ldr	r3, [pc, #252]	; (80018d8 <main+0x238>)
 80017da:	801a      	strh	r2, [r3, #0]
	  TEMP = (dataT1<<8) | dataT2;
 80017dc:	4b3a      	ldr	r3, [pc, #232]	; (80018c8 <main+0x228>)
 80017de:	781b      	ldrb	r3, [r3, #0]
 80017e0:	021b      	lsls	r3, r3, #8
 80017e2:	b21a      	sxth	r2, r3
 80017e4:	4b39      	ldr	r3, [pc, #228]	; (80018cc <main+0x22c>)
 80017e6:	781b      	ldrb	r3, [r3, #0]
 80017e8:	b21b      	sxth	r3, r3
 80017ea:	4313      	orrs	r3, r2
 80017ec:	b21b      	sxth	r3, r3
 80017ee:	b29a      	uxth	r2, r3
 80017f0:	4b3a      	ldr	r3, [pc, #232]	; (80018dc <main+0x23c>)
 80017f2:	801a      	strh	r2, [r3, #0]

	  Humidite = RH / 10.0;
 80017f4:	4b38      	ldr	r3, [pc, #224]	; (80018d8 <main+0x238>)
 80017f6:	881b      	ldrh	r3, [r3, #0]
 80017f8:	4618      	mov	r0, r3
 80017fa:	f7fe fe93 	bl	8000524 <__aeabi_i2d>
 80017fe:	f04f 0200 	mov.w	r2, #0
 8001802:	4b37      	ldr	r3, [pc, #220]	; (80018e0 <main+0x240>)
 8001804:	f7ff f822 	bl	800084c <__aeabi_ddiv>
 8001808:	4602      	mov	r2, r0
 800180a:	460b      	mov	r3, r1
 800180c:	4610      	mov	r0, r2
 800180e:	4619      	mov	r1, r3
 8001810:	f7ff f9ca 	bl	8000ba8 <__aeabi_d2f>
 8001814:	4603      	mov	r3, r0
 8001816:	4a33      	ldr	r2, [pc, #204]	; (80018e4 <main+0x244>)
 8001818:	6013      	str	r3, [r2, #0]
	  Temperature = TEMP / 10.0;
 800181a:	4b30      	ldr	r3, [pc, #192]	; (80018dc <main+0x23c>)
 800181c:	881b      	ldrh	r3, [r3, #0]
 800181e:	4618      	mov	r0, r3
 8001820:	f7fe fe80 	bl	8000524 <__aeabi_i2d>
 8001824:	f04f 0200 	mov.w	r2, #0
 8001828:	4b2d      	ldr	r3, [pc, #180]	; (80018e0 <main+0x240>)
 800182a:	f7ff f80f 	bl	800084c <__aeabi_ddiv>
 800182e:	4602      	mov	r2, r0
 8001830:	460b      	mov	r3, r1
 8001832:	4610      	mov	r0, r2
 8001834:	4619      	mov	r1, r3
 8001836:	f7ff f9b7 	bl	8000ba8 <__aeabi_d2f>
 800183a:	4603      	mov	r3, r0
 800183c:	4a2a      	ldr	r2, [pc, #168]	; (80018e8 <main+0x248>)
 800183e:	6013      	str	r3, [r2, #0]

	  HAL_GPIO_WritePin(GPIOA, GPIO_PIN_1, GPIO_PIN_SET); //pour la prochaine lecture
 8001840:	2201      	movs	r2, #1
 8001842:	2102      	movs	r1, #2
 8001844:	f04f 4090 	mov.w	r0, #1207959552	; 0x48000000
 8001848:	f000 ff1e 	bl	8002688 <HAL_GPIO_WritePin>

	  /*commence transmission vers LCD*/
	  clearlcd();
 800184c:	f7ff fe58 	bl	8001500 <clearlcd>
	  sprintf(bufRH,"Humidite: %.1f", Humidite);
 8001850:	4b24      	ldr	r3, [pc, #144]	; (80018e4 <main+0x244>)
 8001852:	681b      	ldr	r3, [r3, #0]
 8001854:	4618      	mov	r0, r3
 8001856:	f7fe fe77 	bl	8000548 <__aeabi_f2d>
 800185a:	4602      	mov	r2, r0
 800185c:	460b      	mov	r3, r1
 800185e:	4923      	ldr	r1, [pc, #140]	; (80018ec <main+0x24c>)
 8001860:	4823      	ldr	r0, [pc, #140]	; (80018f0 <main+0x250>)
 8001862:	f005 f95f 	bl	8006b24 <siprintf>
	  sprintf(bufT, "Temp.: %.1f C", Temperature);
 8001866:	4b20      	ldr	r3, [pc, #128]	; (80018e8 <main+0x248>)
 8001868:	681b      	ldr	r3, [r3, #0]
 800186a:	4618      	mov	r0, r3
 800186c:	f7fe fe6c 	bl	8000548 <__aeabi_f2d>
 8001870:	4602      	mov	r2, r0
 8001872:	460b      	mov	r3, r1
 8001874:	491f      	ldr	r1, [pc, #124]	; (80018f4 <main+0x254>)
 8001876:	4820      	ldr	r0, [pc, #128]	; (80018f8 <main+0x258>)
 8001878:	f005 f954 	bl	8006b24 <siprintf>
	  lcd_position(&hi2c1,0,0);
 800187c:	2200      	movs	r2, #0
 800187e:	2100      	movs	r1, #0
 8001880:	480d      	ldr	r0, [pc, #52]	; (80018b8 <main+0x218>)
 8001882:	f7ff fe80 	bl	8001586 <lcd_position>
	  lcd_print(&hi2c1,bufRH);
 8001886:	491a      	ldr	r1, [pc, #104]	; (80018f0 <main+0x250>)
 8001888:	480b      	ldr	r0, [pc, #44]	; (80018b8 <main+0x218>)
 800188a:	f7ff fe53 	bl	8001534 <lcd_print>
	  lcd_print(&hi2c1,"%");
 800188e:	491b      	ldr	r1, [pc, #108]	; (80018fc <main+0x25c>)
 8001890:	4809      	ldr	r0, [pc, #36]	; (80018b8 <main+0x218>)
 8001892:	f7ff fe4f 	bl	8001534 <lcd_print>
	  lcd_position(&hi2c1,0,1);
 8001896:	2201      	movs	r2, #1
 8001898:	2100      	movs	r1, #0
 800189a:	4807      	ldr	r0, [pc, #28]	; (80018b8 <main+0x218>)
 800189c:	f7ff fe73 	bl	8001586 <lcd_position>
	  lcd_print(&hi2c1,bufT);
 80018a0:	4915      	ldr	r1, [pc, #84]	; (80018f8 <main+0x258>)
 80018a2:	4805      	ldr	r0, [pc, #20]	; (80018b8 <main+0x218>)
 80018a4:	f7ff fe46 	bl	8001534 <lcd_print>
	  reglagecouleur(0,0,255);
 80018a8:	22ff      	movs	r2, #255	; 0xff
 80018aa:	2100      	movs	r1, #0
 80018ac:	2000      	movs	r0, #0
 80018ae:	f7ff fe93 	bl	80015d8 <reglagecouleur>
	  HAL_Delay(3000);
 80018b2:	e71e      	b.n	80016f2 <main+0x52>
 80018b4:	200001f8 	.word	0x200001f8
 80018b8:	20000214 	.word	0x20000214
 80018bc:	08008fac 	.word	0x08008fac
 80018c0:	20000331 	.word	0x20000331
 80018c4:	20000361 	.word	0x20000361
 80018c8:	20000349 	.word	0x20000349
 80018cc:	20000330 	.word	0x20000330
 80018d0:	20000360 	.word	0x20000360
 80018d4:	20000348 	.word	0x20000348
 80018d8:	20000204 	.word	0x20000204
 80018dc:	20000206 	.word	0x20000206
 80018e0:	40240000 	.word	0x40240000
 80018e4:	20000200 	.word	0x20000200
 80018e8:	200001fc 	.word	0x200001fc
 80018ec:	08008fb8 	.word	0x08008fb8
 80018f0:	2000034c 	.word	0x2000034c
 80018f4:	08008fc8 	.word	0x08008fc8
 80018f8:	20000334 	.word	0x20000334
 80018fc:	08008fd8 	.word	0x08008fd8

08001900 <SystemClock_Config>:
/**
  * @brief System Clock Configuration
  * @retval None
  */
void SystemClock_Config(void)
{
 8001900:	b580      	push	{r7, lr}
 8001902:	b096      	sub	sp, #88	; 0x58
 8001904:	af00      	add	r7, sp, #0
  RCC_OscInitTypeDef RCC_OscInitStruct = {0};
 8001906:	f107 0314 	add.w	r3, r7, #20
 800190a:	2244      	movs	r2, #68	; 0x44
 800190c:	2100      	movs	r1, #0
 800190e:	4618      	mov	r0, r3
 8001910:	f004 fc96 	bl	8006240 <memset>
  RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
 8001914:	463b      	mov	r3, r7
 8001916:	2200      	movs	r2, #0
 8001918:	601a      	str	r2, [r3, #0]
 800191a:	605a      	str	r2, [r3, #4]
 800191c:	609a      	str	r2, [r3, #8]
 800191e:	60da      	str	r2, [r3, #12]
 8001920:	611a      	str	r2, [r3, #16]

  /** Configure the main internal regulator output voltage
  */
  if (HAL_PWREx_ControlVoltageScaling(PWR_REGULATOR_VOLTAGE_SCALE1) != HAL_OK)
 8001922:	f44f 7000 	mov.w	r0, #512	; 0x200
 8001926:	f002 f96b 	bl	8003c00 <HAL_PWREx_ControlVoltageScaling>
 800192a:	4603      	mov	r3, r0
 800192c:	2b00      	cmp	r3, #0
 800192e:	d001      	beq.n	8001934 <SystemClock_Config+0x34>
  {
    Error_Handler();
 8001930:	f000 f837 	bl	80019a2 <Error_Handler>
  }
  /** Initializes the RCC Oscillators according to the specified parameters
  * in the RCC_OscInitTypeDef structure.
  */
  RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;
 8001934:	2302      	movs	r3, #2
 8001936:	617b      	str	r3, [r7, #20]
  RCC_OscInitStruct.HSIState = RCC_HSI_ON;
 8001938:	f44f 7380 	mov.w	r3, #256	; 0x100
 800193c:	623b      	str	r3, [r7, #32]
  RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;
 800193e:	2310      	movs	r3, #16
 8001940:	627b      	str	r3, [r7, #36]	; 0x24
  RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
 8001942:	2302      	movs	r3, #2
 8001944:	63fb      	str	r3, [r7, #60]	; 0x3c
  RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSI;
 8001946:	2302      	movs	r3, #2
 8001948:	643b      	str	r3, [r7, #64]	; 0x40
  RCC_OscInitStruct.PLL.PLLM = 1;
 800194a:	2301      	movs	r3, #1
 800194c:	647b      	str	r3, [r7, #68]	; 0x44
  RCC_OscInitStruct.PLL.PLLN = 10;
 800194e:	230a      	movs	r3, #10
 8001950:	64bb      	str	r3, [r7, #72]	; 0x48
  RCC_OscInitStruct.PLL.PLLP = RCC_PLLP_DIV7;
 8001952:	2307      	movs	r3, #7
 8001954:	64fb      	str	r3, [r7, #76]	; 0x4c
  RCC_OscInitStruct.PLL.PLLQ = RCC_PLLQ_DIV2;
 8001956:	2302      	movs	r3, #2
 8001958:	653b      	str	r3, [r7, #80]	; 0x50
  RCC_OscInitStruct.PLL.PLLR = RCC_PLLR_DIV2;
 800195a:	2302      	movs	r3, #2
 800195c:	657b      	str	r3, [r7, #84]	; 0x54
  if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
 800195e:	f107 0314 	add.w	r3, r7, #20
 8001962:	4618      	mov	r0, r3
 8001964:	f002 f9a2 	bl	8003cac <HAL_RCC_OscConfig>
 8001968:	4603      	mov	r3, r0
 800196a:	2b00      	cmp	r3, #0
 800196c:	d001      	beq.n	8001972 <SystemClock_Config+0x72>
  {
    Error_Handler();
 800196e:	f000 f818 	bl	80019a2 <Error_Handler>
  }
  /** Initializes the CPU, AHB and APB buses clocks
  */
  RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
 8001972:	230f      	movs	r3, #15
 8001974:	603b      	str	r3, [r7, #0]
                              |RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
  RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
 8001976:	2303      	movs	r3, #3
 8001978:	607b      	str	r3, [r7, #4]
  RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
 800197a:	2300      	movs	r3, #0
 800197c:	60bb      	str	r3, [r7, #8]
  RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
 800197e:	2300      	movs	r3, #0
 8001980:	60fb      	str	r3, [r7, #12]
  RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
 8001982:	2300      	movs	r3, #0
 8001984:	613b      	str	r3, [r7, #16]

  if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_4) != HAL_OK)
 8001986:	463b      	mov	r3, r7
 8001988:	2104      	movs	r1, #4
 800198a:	4618      	mov	r0, r3
 800198c:	f002 fd74 	bl	8004478 <HAL_RCC_ClockConfig>
 8001990:	4603      	mov	r3, r0
 8001992:	2b00      	cmp	r3, #0
 8001994:	d001      	beq.n	800199a <SystemClock_Config+0x9a>
  {
    Error_Handler();
 8001996:	f000 f804 	bl	80019a2 <Error_Handler>
  }
}
 800199a:	bf00      	nop
 800199c:	3758      	adds	r7, #88	; 0x58
 800199e:	46bd      	mov	sp, r7
 80019a0:	bd80      	pop	{r7, pc}

080019a2 <Error_Handler>:
/**
  * @brief  This function is executed in case of error occurrence.
  * @retval None
  */
void Error_Handler(void)
{
 80019a2:	b480      	push	{r7}
 80019a4:	af00      	add	r7, sp, #0
  \details Disables IRQ interrupts by setting the I-bit in the CPSR.
           Can only be executed in Privileged modes.
 */
__STATIC_FORCEINLINE void __disable_irq(void)
{
  __ASM volatile ("cpsid i" : : : "memory");
 80019a6:	b672      	cpsid	i
}
 80019a8:	bf00      	nop
  /* USER CODE BEGIN Error_Handler_Debug */
  /* User can add his own implementation to report the HAL error return state */
  __disable_irq();
  while (1)
 80019aa:	e7fe      	b.n	80019aa <Error_Handler+0x8>

080019ac <HAL_MspInit>:
/* USER CODE END 0 */
/**
  * Initializes the Global MSP.
  */
void HAL_MspInit(void)
{
 80019ac:	b480      	push	{r7}
 80019ae:	b083      	sub	sp, #12
 80019b0:	af00      	add	r7, sp, #0
  /* USER CODE BEGIN MspInit 0 */

  /* USER CODE END MspInit 0 */

  __HAL_RCC_SYSCFG_CLK_ENABLE();
 80019b2:	4b0f      	ldr	r3, [pc, #60]	; (80019f0 <HAL_MspInit+0x44>)
 80019b4:	6e1b      	ldr	r3, [r3, #96]	; 0x60
 80019b6:	4a0e      	ldr	r2, [pc, #56]	; (80019f0 <HAL_MspInit+0x44>)
 80019b8:	f043 0301 	orr.w	r3, r3, #1
 80019bc:	6613      	str	r3, [r2, #96]	; 0x60
 80019be:	4b0c      	ldr	r3, [pc, #48]	; (80019f0 <HAL_MspInit+0x44>)
 80019c0:	6e1b      	ldr	r3, [r3, #96]	; 0x60
 80019c2:	f003 0301 	and.w	r3, r3, #1
 80019c6:	607b      	str	r3, [r7, #4]
 80019c8:	687b      	ldr	r3, [r7, #4]
  __HAL_RCC_PWR_CLK_ENABLE();
 80019ca:	4b09      	ldr	r3, [pc, #36]	; (80019f0 <HAL_MspInit+0x44>)
 80019cc:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 80019ce:	4a08      	ldr	r2, [pc, #32]	; (80019f0 <HAL_MspInit+0x44>)
 80019d0:	f043 5380 	orr.w	r3, r3, #268435456	; 0x10000000
 80019d4:	6593      	str	r3, [r2, #88]	; 0x58
 80019d6:	4b06      	ldr	r3, [pc, #24]	; (80019f0 <HAL_MspInit+0x44>)
 80019d8:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 80019da:	f003 5380 	and.w	r3, r3, #268435456	; 0x10000000
 80019de:	603b      	str	r3, [r7, #0]
 80019e0:	683b      	ldr	r3, [r7, #0]
  /* System interrupt init*/

  /* USER CODE BEGIN MspInit 1 */

  /* USER CODE END MspInit 1 */
}
 80019e2:	bf00      	nop
 80019e4:	370c      	adds	r7, #12
 80019e6:	46bd      	mov	sp, r7
 80019e8:	f85d 7b04 	ldr.w	r7, [sp], #4
 80019ec:	4770      	bx	lr
 80019ee:	bf00      	nop
 80019f0:	40021000 	.word	0x40021000

080019f4 <NMI_Handler>:
/******************************************************************************/
/**
  * @brief This function handles Non maskable interrupt.
  */
void NMI_Handler(void)
{
 80019f4:	b480      	push	{r7}
 80019f6:	af00      	add	r7, sp, #0
  /* USER CODE BEGIN NonMaskableInt_IRQn 0 */

  /* USER CODE END NonMaskableInt_IRQn 0 */
  /* USER CODE BEGIN NonMaskableInt_IRQn 1 */
  while (1)
 80019f8:	e7fe      	b.n	80019f8 <NMI_Handler+0x4>

080019fa <HardFault_Handler>:

/**
  * @brief This function handles Hard fault interrupt.
  */
void HardFault_Handler(void)
{
 80019fa:	b480      	push	{r7}
 80019fc:	af00      	add	r7, sp, #0
  /* USER CODE BEGIN HardFault_IRQn 0 */

  /* USER CODE END HardFault_IRQn 0 */
  while (1)
 80019fe:	e7fe      	b.n	80019fe <HardFault_Handler+0x4>

08001a00 <MemManage_Handler>:

/**
  * @brief This function handles Memory management fault.
  */
void MemManage_Handler(void)
{
 8001a00:	b480      	push	{r7}
 8001a02:	af00      	add	r7, sp, #0
  /* USER CODE BEGIN MemoryManagement_IRQn 0 */

  /* USER CODE END MemoryManagement_IRQn 0 */
  while (1)
 8001a04:	e7fe      	b.n	8001a04 <MemManage_Handler+0x4>

08001a06 <BusFault_Handler>:

/**
  * @brief This function handles Prefetch fault, memory access fault.
  */
void BusFault_Handler(void)
{
 8001a06:	b480      	push	{r7}
 8001a08:	af00      	add	r7, sp, #0
  /* USER CODE BEGIN BusFault_IRQn 0 */

  /* USER CODE END BusFault_IRQn 0 */
  while (1)
 8001a0a:	e7fe      	b.n	8001a0a <BusFault_Handler+0x4>

08001a0c <UsageFault_Handler>:

/**
  * @brief This function handles Undefined instruction or illegal state.
  */
void UsageFault_Handler(void)
{
 8001a0c:	b480      	push	{r7}
 8001a0e:	af00      	add	r7, sp, #0
  /* USER CODE BEGIN UsageFault_IRQn 0 */

  /* USER CODE END UsageFault_IRQn 0 */
  while (1)
 8001a10:	e7fe      	b.n	8001a10 <UsageFault_Handler+0x4>

08001a12 <SVC_Handler>:

/**
  * @brief This function handles System service call via SWI instruction.
  */
void SVC_Handler(void)
{
 8001a12:	b480      	push	{r7}
 8001a14:	af00      	add	r7, sp, #0

  /* USER CODE END SVCall_IRQn 0 */
  /* USER CODE BEGIN SVCall_IRQn 1 */

  /* USER CODE END SVCall_IRQn 1 */
}
 8001a16:	bf00      	nop
 8001a18:	46bd      	mov	sp, r7
 8001a1a:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001a1e:	4770      	bx	lr

08001a20 <DebugMon_Handler>:

/**
  * @brief This function handles Debug monitor.
  */
void DebugMon_Handler(void)
{
 8001a20:	b480      	push	{r7}
 8001a22:	af00      	add	r7, sp, #0

  /* USER CODE END DebugMonitor_IRQn 0 */
  /* USER CODE BEGIN DebugMonitor_IRQn 1 */

  /* USER CODE END DebugMonitor_IRQn 1 */
}
 8001a24:	bf00      	nop
 8001a26:	46bd      	mov	sp, r7
 8001a28:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001a2c:	4770      	bx	lr

08001a2e <PendSV_Handler>:

/**
  * @brief This function handles Pendable request for system service.
  */
void PendSV_Handler(void)
{
 8001a2e:	b480      	push	{r7}
 8001a30:	af00      	add	r7, sp, #0

  /* USER CODE END PendSV_IRQn 0 */
  /* USER CODE BEGIN PendSV_IRQn 1 */

  /* USER CODE END PendSV_IRQn 1 */
}
 8001a32:	bf00      	nop
 8001a34:	46bd      	mov	sp, r7
 8001a36:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001a3a:	4770      	bx	lr

08001a3c <SysTick_Handler>:

/**
  * @brief This function handles System tick timer.
  */
void SysTick_Handler(void)
{
 8001a3c:	b580      	push	{r7, lr}
 8001a3e:	af00      	add	r7, sp, #0
  /* USER CODE BEGIN SysTick_IRQn 0 */

  /* USER CODE END SysTick_IRQn 0 */
  HAL_IncTick();
 8001a40:	f000 fabc 	bl	8001fbc <HAL_IncTick>
  /* USER CODE BEGIN SysTick_IRQn 1 */

  /* USER CODE END SysTick_IRQn 1 */
}
 8001a44:	bf00      	nop
 8001a46:	bd80      	pop	{r7, pc}

08001a48 <I2C1_EV_IRQHandler>:

/**
  * @brief This function handles I2C1 event interrupt.
  */
void I2C1_EV_IRQHandler(void)
{
 8001a48:	b580      	push	{r7, lr}
 8001a4a:	af00      	add	r7, sp, #0
  /* USER CODE BEGIN I2C1_EV_IRQn 0 */

  /* USER CODE END I2C1_EV_IRQn 0 */
  HAL_I2C_EV_IRQHandler(&hi2c1);
 8001a4c:	4802      	ldr	r0, [pc, #8]	; (8001a58 <I2C1_EV_IRQHandler+0x10>)
 8001a4e:	f001 f8be 	bl	8002bce <HAL_I2C_EV_IRQHandler>
  /* USER CODE BEGIN I2C1_EV_IRQn 1 */

  /* USER CODE END I2C1_EV_IRQn 1 */
}
 8001a52:	bf00      	nop
 8001a54:	bd80      	pop	{r7, pc}
 8001a56:	bf00      	nop
 8001a58:	20000214 	.word	0x20000214

08001a5c <I2C1_ER_IRQHandler>:

/**
  * @brief This function handles I2C1 error interrupt.
  */
void I2C1_ER_IRQHandler(void)
{
 8001a5c:	b580      	push	{r7, lr}
 8001a5e:	af00      	add	r7, sp, #0
  /* USER CODE BEGIN I2C1_ER_IRQn 0 */

  /* USER CODE END I2C1_ER_IRQn 0 */
  HAL_I2C_ER_IRQHandler(&hi2c1);
 8001a60:	4802      	ldr	r0, [pc, #8]	; (8001a6c <I2C1_ER_IRQHandler+0x10>)
 8001a62:	f001 f8ce 	bl	8002c02 <HAL_I2C_ER_IRQHandler>
  /* USER CODE BEGIN I2C1_ER_IRQn 1 */

  /* USER CODE END I2C1_ER_IRQn 1 */
}
 8001a66:	bf00      	nop
 8001a68:	bd80      	pop	{r7, pc}
 8001a6a:	bf00      	nop
 8001a6c:	20000214 	.word	0x20000214

08001a70 <_getpid>:
void initialise_monitor_handles()
{
}

int _getpid(void)
{
 8001a70:	b480      	push	{r7}
 8001a72:	af00      	add	r7, sp, #0
	return 1;
 8001a74:	2301      	movs	r3, #1
}
 8001a76:	4618      	mov	r0, r3
 8001a78:	46bd      	mov	sp, r7
 8001a7a:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001a7e:	4770      	bx	lr

08001a80 <_kill>:

int _kill(int pid, int sig)
{
 8001a80:	b580      	push	{r7, lr}
 8001a82:	b082      	sub	sp, #8
 8001a84:	af00      	add	r7, sp, #0
 8001a86:	6078      	str	r0, [r7, #4]
 8001a88:	6039      	str	r1, [r7, #0]
	errno = EINVAL;
 8001a8a:	f004 fbaf 	bl	80061ec <__errno>
 8001a8e:	4603      	mov	r3, r0
 8001a90:	2216      	movs	r2, #22
 8001a92:	601a      	str	r2, [r3, #0]
	return -1;
 8001a94:	f04f 33ff 	mov.w	r3, #4294967295
}
 8001a98:	4618      	mov	r0, r3
 8001a9a:	3708      	adds	r7, #8
 8001a9c:	46bd      	mov	sp, r7
 8001a9e:	bd80      	pop	{r7, pc}

08001aa0 <_exit>:

void _exit (int status)
{
 8001aa0:	b580      	push	{r7, lr}
 8001aa2:	b082      	sub	sp, #8
 8001aa4:	af00      	add	r7, sp, #0
 8001aa6:	6078      	str	r0, [r7, #4]
	_kill(status, -1);
 8001aa8:	f04f 31ff 	mov.w	r1, #4294967295
 8001aac:	6878      	ldr	r0, [r7, #4]
 8001aae:	f7ff ffe7 	bl	8001a80 <_kill>
	while (1) {}		/* Make sure we hang here */
 8001ab2:	e7fe      	b.n	8001ab2 <_exit+0x12>

08001ab4 <_read>:
}

__attribute__((weak)) int _read(int file, char *ptr, int len)
{
 8001ab4:	b580      	push	{r7, lr}
 8001ab6:	b086      	sub	sp, #24
 8001ab8:	af00      	add	r7, sp, #0
 8001aba:	60f8      	str	r0, [r7, #12]
 8001abc:	60b9      	str	r1, [r7, #8]
 8001abe:	607a      	str	r2, [r7, #4]
	int DataIdx;

	for (DataIdx = 0; DataIdx < len; DataIdx++)
 8001ac0:	2300      	movs	r3, #0
 8001ac2:	617b      	str	r3, [r7, #20]
 8001ac4:	e00a      	b.n	8001adc <_read+0x28>
	{
		*ptr++ = __io_getchar();
 8001ac6:	f3af 8000 	nop.w
 8001aca:	4601      	mov	r1, r0
 8001acc:	68bb      	ldr	r3, [r7, #8]
 8001ace:	1c5a      	adds	r2, r3, #1
 8001ad0:	60ba      	str	r2, [r7, #8]
 8001ad2:	b2ca      	uxtb	r2, r1
 8001ad4:	701a      	strb	r2, [r3, #0]
	for (DataIdx = 0; DataIdx < len; DataIdx++)
 8001ad6:	697b      	ldr	r3, [r7, #20]
 8001ad8:	3301      	adds	r3, #1
 8001ada:	617b      	str	r3, [r7, #20]
 8001adc:	697a      	ldr	r2, [r7, #20]
 8001ade:	687b      	ldr	r3, [r7, #4]
 8001ae0:	429a      	cmp	r2, r3
 8001ae2:	dbf0      	blt.n	8001ac6 <_read+0x12>
	}

return len;
 8001ae4:	687b      	ldr	r3, [r7, #4]
}
 8001ae6:	4618      	mov	r0, r3
 8001ae8:	3718      	adds	r7, #24
 8001aea:	46bd      	mov	sp, r7
 8001aec:	bd80      	pop	{r7, pc}

08001aee <_write>:

__attribute__((weak)) int _write(int file, char *ptr, int len)
{
 8001aee:	b580      	push	{r7, lr}
 8001af0:	b086      	sub	sp, #24
 8001af2:	af00      	add	r7, sp, #0
 8001af4:	60f8      	str	r0, [r7, #12]
 8001af6:	60b9      	str	r1, [r7, #8]
 8001af8:	607a      	str	r2, [r7, #4]
	int DataIdx;

	for (DataIdx = 0; DataIdx < len; DataIdx++)
 8001afa:	2300      	movs	r3, #0
 8001afc:	617b      	str	r3, [r7, #20]
 8001afe:	e009      	b.n	8001b14 <_write+0x26>
	{
		__io_putchar(*ptr++);
 8001b00:	68bb      	ldr	r3, [r7, #8]
 8001b02:	1c5a      	adds	r2, r3, #1
 8001b04:	60ba      	str	r2, [r7, #8]
 8001b06:	781b      	ldrb	r3, [r3, #0]
 8001b08:	4618      	mov	r0, r3
 8001b0a:	f3af 8000 	nop.w
	for (DataIdx = 0; DataIdx < len; DataIdx++)
 8001b0e:	697b      	ldr	r3, [r7, #20]
 8001b10:	3301      	adds	r3, #1
 8001b12:	617b      	str	r3, [r7, #20]
 8001b14:	697a      	ldr	r2, [r7, #20]
 8001b16:	687b      	ldr	r3, [r7, #4]
 8001b18:	429a      	cmp	r2, r3
 8001b1a:	dbf1      	blt.n	8001b00 <_write+0x12>
	}
	return len;
 8001b1c:	687b      	ldr	r3, [r7, #4]
}
 8001b1e:	4618      	mov	r0, r3
 8001b20:	3718      	adds	r7, #24
 8001b22:	46bd      	mov	sp, r7
 8001b24:	bd80      	pop	{r7, pc}

08001b26 <_close>:

int _close(int file)
{
 8001b26:	b480      	push	{r7}
 8001b28:	b083      	sub	sp, #12
 8001b2a:	af00      	add	r7, sp, #0
 8001b2c:	6078      	str	r0, [r7, #4]
	return -1;
 8001b2e:	f04f 33ff 	mov.w	r3, #4294967295
}
 8001b32:	4618      	mov	r0, r3
 8001b34:	370c      	adds	r7, #12
 8001b36:	46bd      	mov	sp, r7
 8001b38:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001b3c:	4770      	bx	lr

08001b3e <_fstat>:


int _fstat(int file, struct stat *st)
{
 8001b3e:	b480      	push	{r7}
 8001b40:	b083      	sub	sp, #12
 8001b42:	af00      	add	r7, sp, #0
 8001b44:	6078      	str	r0, [r7, #4]
 8001b46:	6039      	str	r1, [r7, #0]
	st->st_mode = S_IFCHR;
 8001b48:	683b      	ldr	r3, [r7, #0]
 8001b4a:	f44f 5200 	mov.w	r2, #8192	; 0x2000
 8001b4e:	605a      	str	r2, [r3, #4]
	return 0;
 8001b50:	2300      	movs	r3, #0
}
 8001b52:	4618      	mov	r0, r3
 8001b54:	370c      	adds	r7, #12
 8001b56:	46bd      	mov	sp, r7
 8001b58:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001b5c:	4770      	bx	lr

08001b5e <_isatty>:

int _isatty(int file)
{
 8001b5e:	b480      	push	{r7}
 8001b60:	b083      	sub	sp, #12
 8001b62:	af00      	add	r7, sp, #0
 8001b64:	6078      	str	r0, [r7, #4]
	return 1;
 8001b66:	2301      	movs	r3, #1
}
 8001b68:	4618      	mov	r0, r3
 8001b6a:	370c      	adds	r7, #12
 8001b6c:	46bd      	mov	sp, r7
 8001b6e:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001b72:	4770      	bx	lr

08001b74 <_lseek>:

int _lseek(int file, int ptr, int dir)
{
 8001b74:	b480      	push	{r7}
 8001b76:	b085      	sub	sp, #20
 8001b78:	af00      	add	r7, sp, #0
 8001b7a:	60f8      	str	r0, [r7, #12]
 8001b7c:	60b9      	str	r1, [r7, #8]
 8001b7e:	607a      	str	r2, [r7, #4]
	return 0;
 8001b80:	2300      	movs	r3, #0
}
 8001b82:	4618      	mov	r0, r3
 8001b84:	3714      	adds	r7, #20
 8001b86:	46bd      	mov	sp, r7
 8001b88:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001b8c:	4770      	bx	lr
	...

08001b90 <_sbrk>:
 *
 * @param incr Memory size
 * @return Pointer to allocated memory
 */
void *_sbrk(ptrdiff_t incr)
{
 8001b90:	b580      	push	{r7, lr}
 8001b92:	b086      	sub	sp, #24
 8001b94:	af00      	add	r7, sp, #0
 8001b96:	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;
 8001b98:	4a14      	ldr	r2, [pc, #80]	; (8001bec <_sbrk+0x5c>)
 8001b9a:	4b15      	ldr	r3, [pc, #84]	; (8001bf0 <_sbrk+0x60>)
 8001b9c:	1ad3      	subs	r3, r2, r3
 8001b9e:	617b      	str	r3, [r7, #20]
  const uint8_t *max_heap = (uint8_t *)stack_limit;
 8001ba0:	697b      	ldr	r3, [r7, #20]
 8001ba2:	613b      	str	r3, [r7, #16]
  uint8_t *prev_heap_end;

  /* Initialize heap end at first call */
  if (NULL == __sbrk_heap_end)
 8001ba4:	4b13      	ldr	r3, [pc, #76]	; (8001bf4 <_sbrk+0x64>)
 8001ba6:	681b      	ldr	r3, [r3, #0]
 8001ba8:	2b00      	cmp	r3, #0
 8001baa:	d102      	bne.n	8001bb2 <_sbrk+0x22>
  {
    __sbrk_heap_end = &_end;
 8001bac:	4b11      	ldr	r3, [pc, #68]	; (8001bf4 <_sbrk+0x64>)
 8001bae:	4a12      	ldr	r2, [pc, #72]	; (8001bf8 <_sbrk+0x68>)
 8001bb0:	601a      	str	r2, [r3, #0]
  }

  /* Protect heap from growing into the reserved MSP stack */
  if (__sbrk_heap_end + incr > max_heap)
 8001bb2:	4b10      	ldr	r3, [pc, #64]	; (8001bf4 <_sbrk+0x64>)
 8001bb4:	681a      	ldr	r2, [r3, #0]
 8001bb6:	687b      	ldr	r3, [r7, #4]
 8001bb8:	4413      	add	r3, r2
 8001bba:	693a      	ldr	r2, [r7, #16]
 8001bbc:	429a      	cmp	r2, r3
 8001bbe:	d207      	bcs.n	8001bd0 <_sbrk+0x40>
  {
    errno = ENOMEM;
 8001bc0:	f004 fb14 	bl	80061ec <__errno>
 8001bc4:	4603      	mov	r3, r0
 8001bc6:	220c      	movs	r2, #12
 8001bc8:	601a      	str	r2, [r3, #0]
    return (void *)-1;
 8001bca:	f04f 33ff 	mov.w	r3, #4294967295
 8001bce:	e009      	b.n	8001be4 <_sbrk+0x54>
  }

  prev_heap_end = __sbrk_heap_end;
 8001bd0:	4b08      	ldr	r3, [pc, #32]	; (8001bf4 <_sbrk+0x64>)
 8001bd2:	681b      	ldr	r3, [r3, #0]
 8001bd4:	60fb      	str	r3, [r7, #12]
  __sbrk_heap_end += incr;
 8001bd6:	4b07      	ldr	r3, [pc, #28]	; (8001bf4 <_sbrk+0x64>)
 8001bd8:	681a      	ldr	r2, [r3, #0]
 8001bda:	687b      	ldr	r3, [r7, #4]
 8001bdc:	4413      	add	r3, r2
 8001bde:	4a05      	ldr	r2, [pc, #20]	; (8001bf4 <_sbrk+0x64>)
 8001be0:	6013      	str	r3, [r2, #0]

  return (void *)prev_heap_end;
 8001be2:	68fb      	ldr	r3, [r7, #12]
}
 8001be4:	4618      	mov	r0, r3
 8001be6:	3718      	adds	r7, #24
 8001be8:	46bd      	mov	sp, r7
 8001bea:	bd80      	pop	{r7, pc}
 8001bec:	20018000 	.word	0x20018000
 8001bf0:	00000400 	.word	0x00000400
 8001bf4:	20000208 	.word	0x20000208
 8001bf8:	200003c8 	.word	0x200003c8

08001bfc <SystemInit>:
  * @brief  Setup the microcontroller system.
  * @retval None
  */

void SystemInit(void)
{
 8001bfc:	b480      	push	{r7}
 8001bfe:	af00      	add	r7, sp, #0
  SCB->VTOR = VECT_TAB_BASE_ADDRESS | VECT_TAB_OFFSET;
#endif

  /* FPU settings ------------------------------------------------------------*/
#if (__FPU_PRESENT == 1) && (__FPU_USED == 1)
  SCB->CPACR |= ((3UL << 20U)|(3UL << 22U));  /* set CP10 and CP11 Full Access */
 8001c00:	4b15      	ldr	r3, [pc, #84]	; (8001c58 <SystemInit+0x5c>)
 8001c02:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8001c06:	4a14      	ldr	r2, [pc, #80]	; (8001c58 <SystemInit+0x5c>)
 8001c08:	f443 0370 	orr.w	r3, r3, #15728640	; 0xf00000
 8001c0c:	f8c2 3088 	str.w	r3, [r2, #136]	; 0x88
#endif

  /* Reset the RCC clock configuration to the default reset state ------------*/
  /* Set MSION bit */
  RCC->CR |= RCC_CR_MSION;
 8001c10:	4b12      	ldr	r3, [pc, #72]	; (8001c5c <SystemInit+0x60>)
 8001c12:	681b      	ldr	r3, [r3, #0]
 8001c14:	4a11      	ldr	r2, [pc, #68]	; (8001c5c <SystemInit+0x60>)
 8001c16:	f043 0301 	orr.w	r3, r3, #1
 8001c1a:	6013      	str	r3, [r2, #0]

  /* Reset CFGR register */
  RCC->CFGR = 0x00000000U;
 8001c1c:	4b0f      	ldr	r3, [pc, #60]	; (8001c5c <SystemInit+0x60>)
 8001c1e:	2200      	movs	r2, #0
 8001c20:	609a      	str	r2, [r3, #8]

  /* Reset HSEON, CSSON , HSION, and PLLON bits */
  RCC->CR &= 0xEAF6FFFFU;
 8001c22:	4b0e      	ldr	r3, [pc, #56]	; (8001c5c <SystemInit+0x60>)
 8001c24:	681b      	ldr	r3, [r3, #0]
 8001c26:	4a0d      	ldr	r2, [pc, #52]	; (8001c5c <SystemInit+0x60>)
 8001c28:	f023 53a8 	bic.w	r3, r3, #352321536	; 0x15000000
 8001c2c:	f423 2310 	bic.w	r3, r3, #589824	; 0x90000
 8001c30:	6013      	str	r3, [r2, #0]

  /* Reset PLLCFGR register */
  RCC->PLLCFGR = 0x00001000U;
 8001c32:	4b0a      	ldr	r3, [pc, #40]	; (8001c5c <SystemInit+0x60>)
 8001c34:	f44f 5280 	mov.w	r2, #4096	; 0x1000
 8001c38:	60da      	str	r2, [r3, #12]

  /* Reset HSEBYP bit */
  RCC->CR &= 0xFFFBFFFFU;
 8001c3a:	4b08      	ldr	r3, [pc, #32]	; (8001c5c <SystemInit+0x60>)
 8001c3c:	681b      	ldr	r3, [r3, #0]
 8001c3e:	4a07      	ldr	r2, [pc, #28]	; (8001c5c <SystemInit+0x60>)
 8001c40:	f423 2380 	bic.w	r3, r3, #262144	; 0x40000
 8001c44:	6013      	str	r3, [r2, #0]

  /* Disable all interrupts */
  RCC->CIER = 0x00000000U;
 8001c46:	4b05      	ldr	r3, [pc, #20]	; (8001c5c <SystemInit+0x60>)
 8001c48:	2200      	movs	r2, #0
 8001c4a:	619a      	str	r2, [r3, #24]
}
 8001c4c:	bf00      	nop
 8001c4e:	46bd      	mov	sp, r7
 8001c50:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001c54:	4770      	bx	lr
 8001c56:	bf00      	nop
 8001c58:	e000ed00 	.word	0xe000ed00
 8001c5c:	40021000 	.word	0x40021000

08001c60 <MX_TIM2_Init>:

TIM_HandleTypeDef htim2;

/* TIM2 init function */
void MX_TIM2_Init(void)
{
 8001c60:	b580      	push	{r7, lr}
 8001c62:	b088      	sub	sp, #32
 8001c64:	af00      	add	r7, sp, #0

  /* USER CODE BEGIN TIM2_Init 0 */

  /* USER CODE END TIM2_Init 0 */

  TIM_ClockConfigTypeDef sClockSourceConfig = {0};
 8001c66:	f107 0310 	add.w	r3, r7, #16
 8001c6a:	2200      	movs	r2, #0
 8001c6c:	601a      	str	r2, [r3, #0]
 8001c6e:	605a      	str	r2, [r3, #4]
 8001c70:	609a      	str	r2, [r3, #8]
 8001c72:	60da      	str	r2, [r3, #12]
  TIM_MasterConfigTypeDef sMasterConfig = {0};
 8001c74:	1d3b      	adds	r3, r7, #4
 8001c76:	2200      	movs	r2, #0
 8001c78:	601a      	str	r2, [r3, #0]
 8001c7a:	605a      	str	r2, [r3, #4]
 8001c7c:	609a      	str	r2, [r3, #8]

  /* USER CODE BEGIN TIM2_Init 1 */

  /* USER CODE END TIM2_Init 1 */
  htim2.Instance = TIM2;
 8001c7e:	4b1e      	ldr	r3, [pc, #120]	; (8001cf8 <MX_TIM2_Init+0x98>)
 8001c80:	f04f 4280 	mov.w	r2, #1073741824	; 0x40000000
 8001c84:	601a      	str	r2, [r3, #0]
  htim2.Init.Prescaler = 80-1;
 8001c86:	4b1c      	ldr	r3, [pc, #112]	; (8001cf8 <MX_TIM2_Init+0x98>)
 8001c88:	224f      	movs	r2, #79	; 0x4f
 8001c8a:	605a      	str	r2, [r3, #4]
  htim2.Init.CounterMode = TIM_COUNTERMODE_UP;
 8001c8c:	4b1a      	ldr	r3, [pc, #104]	; (8001cf8 <MX_TIM2_Init+0x98>)
 8001c8e:	2200      	movs	r2, #0
 8001c90:	609a      	str	r2, [r3, #8]
  htim2.Init.Period = 4294967295;
 8001c92:	4b19      	ldr	r3, [pc, #100]	; (8001cf8 <MX_TIM2_Init+0x98>)
 8001c94:	f04f 32ff 	mov.w	r2, #4294967295
 8001c98:	60da      	str	r2, [r3, #12]
  htim2.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
 8001c9a:	4b17      	ldr	r3, [pc, #92]	; (8001cf8 <MX_TIM2_Init+0x98>)
 8001c9c:	2200      	movs	r2, #0
 8001c9e:	611a      	str	r2, [r3, #16]
  htim2.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
 8001ca0:	4b15      	ldr	r3, [pc, #84]	; (8001cf8 <MX_TIM2_Init+0x98>)
 8001ca2:	2200      	movs	r2, #0
 8001ca4:	619a      	str	r2, [r3, #24]
  if (HAL_TIM_Base_Init(&htim2) != HAL_OK)
 8001ca6:	4814      	ldr	r0, [pc, #80]	; (8001cf8 <MX_TIM2_Init+0x98>)
 8001ca8:	f003 faa8 	bl	80051fc <HAL_TIM_Base_Init>
 8001cac:	4603      	mov	r3, r0
 8001cae:	2b00      	cmp	r3, #0
 8001cb0:	d001      	beq.n	8001cb6 <MX_TIM2_Init+0x56>
  {
    Error_Handler();
 8001cb2:	f7ff fe76 	bl	80019a2 <Error_Handler>
  }
  sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
 8001cb6:	f44f 5380 	mov.w	r3, #4096	; 0x1000
 8001cba:	613b      	str	r3, [r7, #16]
  if (HAL_TIM_ConfigClockSource(&htim2, &sClockSourceConfig) != HAL_OK)
 8001cbc:	f107 0310 	add.w	r3, r7, #16
 8001cc0:	4619      	mov	r1, r3
 8001cc2:	480d      	ldr	r0, [pc, #52]	; (8001cf8 <MX_TIM2_Init+0x98>)
 8001cc4:	f003 faf1 	bl	80052aa <HAL_TIM_ConfigClockSource>
 8001cc8:	4603      	mov	r3, r0
 8001cca:	2b00      	cmp	r3, #0
 8001ccc:	d001      	beq.n	8001cd2 <MX_TIM2_Init+0x72>
  {
    Error_Handler();
 8001cce:	f7ff fe68 	bl	80019a2 <Error_Handler>
  }
  sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
 8001cd2:	2300      	movs	r3, #0
 8001cd4:	607b      	str	r3, [r7, #4]
  sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
 8001cd6:	2300      	movs	r3, #0
 8001cd8:	60fb      	str	r3, [r7, #12]
  if (HAL_TIMEx_MasterConfigSynchronization(&htim2, &sMasterConfig) != HAL_OK)
 8001cda:	1d3b      	adds	r3, r7, #4
 8001cdc:	4619      	mov	r1, r3
 8001cde:	4806      	ldr	r0, [pc, #24]	; (8001cf8 <MX_TIM2_Init+0x98>)
 8001ce0:	f003 fce0 	bl	80056a4 <HAL_TIMEx_MasterConfigSynchronization>
 8001ce4:	4603      	mov	r3, r0
 8001ce6:	2b00      	cmp	r3, #0
 8001ce8:	d001      	beq.n	8001cee <MX_TIM2_Init+0x8e>
  {
    Error_Handler();
 8001cea:	f7ff fe5a 	bl	80019a2 <Error_Handler>
  }
  /* USER CODE BEGIN TIM2_Init 2 */

  /* USER CODE END TIM2_Init 2 */

}
 8001cee:	bf00      	nop
 8001cf0:	3720      	adds	r7, #32
 8001cf2:	46bd      	mov	sp, r7
 8001cf4:	bd80      	pop	{r7, pc}
 8001cf6:	bf00      	nop
 8001cf8:	20000364 	.word	0x20000364

08001cfc <HAL_TIM_Base_MspInit>:

void HAL_TIM_Base_MspInit(TIM_HandleTypeDef* tim_baseHandle)
{
 8001cfc:	b480      	push	{r7}
 8001cfe:	b085      	sub	sp, #20
 8001d00:	af00      	add	r7, sp, #0
 8001d02:	6078      	str	r0, [r7, #4]

  if(tim_baseHandle->Instance==TIM2)
 8001d04:	687b      	ldr	r3, [r7, #4]
 8001d06:	681b      	ldr	r3, [r3, #0]
 8001d08:	f1b3 4f80 	cmp.w	r3, #1073741824	; 0x40000000
 8001d0c:	d10b      	bne.n	8001d26 <HAL_TIM_Base_MspInit+0x2a>
  {
  /* USER CODE BEGIN TIM2_MspInit 0 */

  /* USER CODE END TIM2_MspInit 0 */
    /* TIM2 clock enable */
    __HAL_RCC_TIM2_CLK_ENABLE();
 8001d0e:	4b09      	ldr	r3, [pc, #36]	; (8001d34 <HAL_TIM_Base_MspInit+0x38>)
 8001d10:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 8001d12:	4a08      	ldr	r2, [pc, #32]	; (8001d34 <HAL_TIM_Base_MspInit+0x38>)
 8001d14:	f043 0301 	orr.w	r3, r3, #1
 8001d18:	6593      	str	r3, [r2, #88]	; 0x58
 8001d1a:	4b06      	ldr	r3, [pc, #24]	; (8001d34 <HAL_TIM_Base_MspInit+0x38>)
 8001d1c:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 8001d1e:	f003 0301 	and.w	r3, r3, #1
 8001d22:	60fb      	str	r3, [r7, #12]
 8001d24:	68fb      	ldr	r3, [r7, #12]
  /* USER CODE BEGIN TIM2_MspInit 1 */

  /* USER CODE END TIM2_MspInit 1 */
  }
}
 8001d26:	bf00      	nop
 8001d28:	3714      	adds	r7, #20
 8001d2a:	46bd      	mov	sp, r7
 8001d2c:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001d30:	4770      	bx	lr
 8001d32:	bf00      	nop
 8001d34:	40021000 	.word	0x40021000

08001d38 <DWT_Delay_Init>:

#include "timer.h"
#include "stm32l4xx_hal.h"

uint32_t DWT_Delay_Init(void)
{
 8001d38:	b480      	push	{r7}
 8001d3a:	af00      	add	r7, sp, #0
    /* Disable TRC */
    CoreDebug->DEMCR &= ~CoreDebug_DEMCR_TRCENA_Msk; // ~0x01000000;
 8001d3c:	4b14      	ldr	r3, [pc, #80]	; (8001d90 <DWT_Delay_Init+0x58>)
 8001d3e:	68db      	ldr	r3, [r3, #12]
 8001d40:	4a13      	ldr	r2, [pc, #76]	; (8001d90 <DWT_Delay_Init+0x58>)
 8001d42:	f023 7380 	bic.w	r3, r3, #16777216	; 0x1000000
 8001d46:	60d3      	str	r3, [r2, #12]
    /* Enable TRC */
    CoreDebug->DEMCR |=  CoreDebug_DEMCR_TRCENA_Msk; // 0x01000000;
 8001d48:	4b11      	ldr	r3, [pc, #68]	; (8001d90 <DWT_Delay_Init+0x58>)
 8001d4a:	68db      	ldr	r3, [r3, #12]
 8001d4c:	4a10      	ldr	r2, [pc, #64]	; (8001d90 <DWT_Delay_Init+0x58>)
 8001d4e:	f043 7380 	orr.w	r3, r3, #16777216	; 0x1000000
 8001d52:	60d3      	str	r3, [r2, #12]

    /* Disable clock cycle counter */
    DWT->CTRL &= ~DWT_CTRL_CYCCNTENA_Msk; //~0x00000001;
 8001d54:	4b0f      	ldr	r3, [pc, #60]	; (8001d94 <DWT_Delay_Init+0x5c>)
 8001d56:	681b      	ldr	r3, [r3, #0]
 8001d58:	4a0e      	ldr	r2, [pc, #56]	; (8001d94 <DWT_Delay_Init+0x5c>)
 8001d5a:	f023 0301 	bic.w	r3, r3, #1
 8001d5e:	6013      	str	r3, [r2, #0]
    /* Enable  clock cycle counter */
    DWT->CTRL |=  DWT_CTRL_CYCCNTENA_Msk; //0x00000001;
 8001d60:	4b0c      	ldr	r3, [pc, #48]	; (8001d94 <DWT_Delay_Init+0x5c>)
 8001d62:	681b      	ldr	r3, [r3, #0]
 8001d64:	4a0b      	ldr	r2, [pc, #44]	; (8001d94 <DWT_Delay_Init+0x5c>)
 8001d66:	f043 0301 	orr.w	r3, r3, #1
 8001d6a:	6013      	str	r3, [r2, #0]

    /* Reset the clock cycle counter value */
    DWT->CYCCNT = 0;
 8001d6c:	4b09      	ldr	r3, [pc, #36]	; (8001d94 <DWT_Delay_Init+0x5c>)
 8001d6e:	2200      	movs	r2, #0
 8001d70:	605a      	str	r2, [r3, #4]

    /* 3 NO OPERATION instructions */
    __ASM volatile ("NOP");
 8001d72:	bf00      	nop
    __ASM volatile ("NOP");
 8001d74:	bf00      	nop
    __ASM volatile ("NOP");
 8001d76:	bf00      	nop

    /* Check if clock cycle counter has started */
    if(DWT->CYCCNT)
 8001d78:	4b06      	ldr	r3, [pc, #24]	; (8001d94 <DWT_Delay_Init+0x5c>)
 8001d7a:	685b      	ldr	r3, [r3, #4]
 8001d7c:	2b00      	cmp	r3, #0
 8001d7e:	d001      	beq.n	8001d84 <DWT_Delay_Init+0x4c>
    {
       return 0; /*clock cycle counter started*/
 8001d80:	2300      	movs	r3, #0
 8001d82:	e000      	b.n	8001d86 <DWT_Delay_Init+0x4e>
    }
    else
    {
      return 1; /*clock cycle counter not started*/
 8001d84:	2301      	movs	r3, #1
    }
}
 8001d86:	4618      	mov	r0, r3
 8001d88:	46bd      	mov	sp, r7
 8001d8a:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001d8e:	4770      	bx	lr
 8001d90:	e000edf0 	.word	0xe000edf0
 8001d94:	e0001000 	.word	0xe0001000

08001d98 <MX_USART2_UART_Init>:
UART_HandleTypeDef huart2;

/* USART2 init function */

void MX_USART2_UART_Init(void)
{
 8001d98:	b580      	push	{r7, lr}
 8001d9a:	af00      	add	r7, sp, #0
  /* USER CODE END USART2_Init 0 */

  /* USER CODE BEGIN USART2_Init 1 */

  /* USER CODE END USART2_Init 1 */
  huart2.Instance = USART2;
 8001d9c:	4b14      	ldr	r3, [pc, #80]	; (8001df0 <MX_USART2_UART_Init+0x58>)
 8001d9e:	4a15      	ldr	r2, [pc, #84]	; (8001df4 <MX_USART2_UART_Init+0x5c>)
 8001da0:	601a      	str	r2, [r3, #0]
  huart2.Init.BaudRate = 115200;
 8001da2:	4b13      	ldr	r3, [pc, #76]	; (8001df0 <MX_USART2_UART_Init+0x58>)
 8001da4:	f44f 32e1 	mov.w	r2, #115200	; 0x1c200
 8001da8:	605a      	str	r2, [r3, #4]
  huart2.Init.WordLength = UART_WORDLENGTH_8B;
 8001daa:	4b11      	ldr	r3, [pc, #68]	; (8001df0 <MX_USART2_UART_Init+0x58>)
 8001dac:	2200      	movs	r2, #0
 8001dae:	609a      	str	r2, [r3, #8]
  huart2.Init.StopBits = UART_STOPBITS_1;
 8001db0:	4b0f      	ldr	r3, [pc, #60]	; (8001df0 <MX_USART2_UART_Init+0x58>)
 8001db2:	2200      	movs	r2, #0
 8001db4:	60da      	str	r2, [r3, #12]
  huart2.Init.Parity = UART_PARITY_NONE;
 8001db6:	4b0e      	ldr	r3, [pc, #56]	; (8001df0 <MX_USART2_UART_Init+0x58>)
 8001db8:	2200      	movs	r2, #0
 8001dba:	611a      	str	r2, [r3, #16]
  huart2.Init.Mode = UART_MODE_TX_RX;
 8001dbc:	4b0c      	ldr	r3, [pc, #48]	; (8001df0 <MX_USART2_UART_Init+0x58>)
 8001dbe:	220c      	movs	r2, #12
 8001dc0:	615a      	str	r2, [r3, #20]
  huart2.Init.HwFlowCtl = UART_HWCONTROL_NONE;
 8001dc2:	4b0b      	ldr	r3, [pc, #44]	; (8001df0 <MX_USART2_UART_Init+0x58>)
 8001dc4:	2200      	movs	r2, #0
 8001dc6:	619a      	str	r2, [r3, #24]
  huart2.Init.OverSampling = UART_OVERSAMPLING_16;
 8001dc8:	4b09      	ldr	r3, [pc, #36]	; (8001df0 <MX_USART2_UART_Init+0x58>)
 8001dca:	2200      	movs	r2, #0
 8001dcc:	61da      	str	r2, [r3, #28]
  huart2.Init.OneBitSampling = UART_ONE_BIT_SAMPLE_DISABLE;
 8001dce:	4b08      	ldr	r3, [pc, #32]	; (8001df0 <MX_USART2_UART_Init+0x58>)
 8001dd0:	2200      	movs	r2, #0
 8001dd2:	621a      	str	r2, [r3, #32]
  huart2.AdvancedInit.AdvFeatureInit = UART_ADVFEATURE_NO_INIT;
 8001dd4:	4b06      	ldr	r3, [pc, #24]	; (8001df0 <MX_USART2_UART_Init+0x58>)
 8001dd6:	2200      	movs	r2, #0
 8001dd8:	625a      	str	r2, [r3, #36]	; 0x24
  if (HAL_UART_Init(&huart2) != HAL_OK)
 8001dda:	4805      	ldr	r0, [pc, #20]	; (8001df0 <MX_USART2_UART_Init+0x58>)
 8001ddc:	f003 fcea 	bl	80057b4 <HAL_UART_Init>
 8001de0:	4603      	mov	r3, r0
 8001de2:	2b00      	cmp	r3, #0
 8001de4:	d001      	beq.n	8001dea <MX_USART2_UART_Init+0x52>
  {
    Error_Handler();
 8001de6:	f7ff fddc 	bl	80019a2 <Error_Handler>
  }
  /* USER CODE BEGIN USART2_Init 2 */

  /* USER CODE END USART2_Init 2 */

}
 8001dea:	bf00      	nop
 8001dec:	bd80      	pop	{r7, pc}
 8001dee:	bf00      	nop
 8001df0:	200002ac 	.word	0x200002ac
 8001df4:	40004400 	.word	0x40004400

08001df8 <HAL_UART_MspInit>:

void HAL_UART_MspInit(UART_HandleTypeDef* uartHandle)
{
 8001df8:	b580      	push	{r7, lr}
 8001dfa:	b0ac      	sub	sp, #176	; 0xb0
 8001dfc:	af00      	add	r7, sp, #0
 8001dfe:	6078      	str	r0, [r7, #4]

  GPIO_InitTypeDef GPIO_InitStruct = {0};
 8001e00:	f107 039c 	add.w	r3, r7, #156	; 0x9c
 8001e04:	2200      	movs	r2, #0
 8001e06:	601a      	str	r2, [r3, #0]
 8001e08:	605a      	str	r2, [r3, #4]
 8001e0a:	609a      	str	r2, [r3, #8]
 8001e0c:	60da      	str	r2, [r3, #12]
 8001e0e:	611a      	str	r2, [r3, #16]
  RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
 8001e10:	f107 0314 	add.w	r3, r7, #20
 8001e14:	2288      	movs	r2, #136	; 0x88
 8001e16:	2100      	movs	r1, #0
 8001e18:	4618      	mov	r0, r3
 8001e1a:	f004 fa11 	bl	8006240 <memset>
  if(uartHandle->Instance==USART2)
 8001e1e:	687b      	ldr	r3, [r7, #4]
 8001e20:	681b      	ldr	r3, [r3, #0]
 8001e22:	4a21      	ldr	r2, [pc, #132]	; (8001ea8 <HAL_UART_MspInit+0xb0>)
 8001e24:	4293      	cmp	r3, r2
 8001e26:	d13b      	bne.n	8001ea0 <HAL_UART_MspInit+0xa8>
  /* USER CODE BEGIN USART2_MspInit 0 */

  /* USER CODE END USART2_MspInit 0 */
  /** Initializes the peripherals clock
  */
    PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_USART2;
 8001e28:	2302      	movs	r3, #2
 8001e2a:	617b      	str	r3, [r7, #20]
    PeriphClkInit.Usart2ClockSelection = RCC_USART2CLKSOURCE_PCLK1;
 8001e2c:	2300      	movs	r3, #0
 8001e2e:	653b      	str	r3, [r7, #80]	; 0x50
    if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
 8001e30:	f107 0314 	add.w	r3, r7, #20
 8001e34:	4618      	mov	r0, r3
 8001e36:	f002 fd25 	bl	8004884 <HAL_RCCEx_PeriphCLKConfig>
 8001e3a:	4603      	mov	r3, r0
 8001e3c:	2b00      	cmp	r3, #0
 8001e3e:	d001      	beq.n	8001e44 <HAL_UART_MspInit+0x4c>
    {
      Error_Handler();
 8001e40:	f7ff fdaf 	bl	80019a2 <Error_Handler>
    }

    /* USART2 clock enable */
    __HAL_RCC_USART2_CLK_ENABLE();
 8001e44:	4b19      	ldr	r3, [pc, #100]	; (8001eac <HAL_UART_MspInit+0xb4>)
 8001e46:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 8001e48:	4a18      	ldr	r2, [pc, #96]	; (8001eac <HAL_UART_MspInit+0xb4>)
 8001e4a:	f443 3300 	orr.w	r3, r3, #131072	; 0x20000
 8001e4e:	6593      	str	r3, [r2, #88]	; 0x58
 8001e50:	4b16      	ldr	r3, [pc, #88]	; (8001eac <HAL_UART_MspInit+0xb4>)
 8001e52:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 8001e54:	f403 3300 	and.w	r3, r3, #131072	; 0x20000
 8001e58:	613b      	str	r3, [r7, #16]
 8001e5a:	693b      	ldr	r3, [r7, #16]

    __HAL_RCC_GPIOA_CLK_ENABLE();
 8001e5c:	4b13      	ldr	r3, [pc, #76]	; (8001eac <HAL_UART_MspInit+0xb4>)
 8001e5e:	6cdb      	ldr	r3, [r3, #76]	; 0x4c
 8001e60:	4a12      	ldr	r2, [pc, #72]	; (8001eac <HAL_UART_MspInit+0xb4>)
 8001e62:	f043 0301 	orr.w	r3, r3, #1
 8001e66:	64d3      	str	r3, [r2, #76]	; 0x4c
 8001e68:	4b10      	ldr	r3, [pc, #64]	; (8001eac <HAL_UART_MspInit+0xb4>)
 8001e6a:	6cdb      	ldr	r3, [r3, #76]	; 0x4c
 8001e6c:	f003 0301 	and.w	r3, r3, #1
 8001e70:	60fb      	str	r3, [r7, #12]
 8001e72:	68fb      	ldr	r3, [r7, #12]
    /**USART2 GPIO Configuration
    PA2     ------> USART2_TX
    PA3     ------> USART2_RX
    */
    GPIO_InitStruct.Pin = USART_TX_Pin|USART_RX_Pin;
 8001e74:	230c      	movs	r3, #12
 8001e76:	f8c7 309c 	str.w	r3, [r7, #156]	; 0x9c
    GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
 8001e7a:	2302      	movs	r3, #2
 8001e7c:	f8c7 30a0 	str.w	r3, [r7, #160]	; 0xa0
    GPIO_InitStruct.Pull = GPIO_NOPULL;
 8001e80:	2300      	movs	r3, #0
 8001e82:	f8c7 30a4 	str.w	r3, [r7, #164]	; 0xa4
    GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
 8001e86:	2303      	movs	r3, #3
 8001e88:	f8c7 30a8 	str.w	r3, [r7, #168]	; 0xa8
    GPIO_InitStruct.Alternate = GPIO_AF7_USART2;
 8001e8c:	2307      	movs	r3, #7
 8001e8e:	f8c7 30ac 	str.w	r3, [r7, #172]	; 0xac
    HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
 8001e92:	f107 039c 	add.w	r3, r7, #156	; 0x9c
 8001e96:	4619      	mov	r1, r3
 8001e98:	f04f 4090 	mov.w	r0, #1207959552	; 0x48000000
 8001e9c:	f000 fa32 	bl	8002304 <HAL_GPIO_Init>

  /* USER CODE BEGIN USART2_MspInit 1 */

  /* USER CODE END USART2_MspInit 1 */
  }
}
 8001ea0:	bf00      	nop
 8001ea2:	37b0      	adds	r7, #176	; 0xb0
 8001ea4:	46bd      	mov	sp, r7
 8001ea6:	bd80      	pop	{r7, pc}
 8001ea8:	40004400 	.word	0x40004400
 8001eac:	40021000 	.word	0x40021000

08001eb0 <Reset_Handler>:

    .section	.text.Reset_Handler
	.weak	Reset_Handler
	.type	Reset_Handler, %function
Reset_Handler:
  ldr   sp, =_estack    /* Set stack pointer */
 8001eb0:	f8df d034 	ldr.w	sp, [pc, #52]	; 8001ee8 <LoopForever+0x2>

/* Call the clock system initialization function.*/
    bl  SystemInit
 8001eb4:	f7ff fea2 	bl	8001bfc <SystemInit>

/* Copy the data segment initializers from flash to SRAM */
  ldr r0, =_sdata
 8001eb8:	480c      	ldr	r0, [pc, #48]	; (8001eec <LoopForever+0x6>)
  ldr r1, =_edata
 8001eba:	490d      	ldr	r1, [pc, #52]	; (8001ef0 <LoopForever+0xa>)
  ldr r2, =_sidata
 8001ebc:	4a0d      	ldr	r2, [pc, #52]	; (8001ef4 <LoopForever+0xe>)
  movs r3, #0
 8001ebe:	2300      	movs	r3, #0
  b LoopCopyDataInit
 8001ec0:	e002      	b.n	8001ec8 <LoopCopyDataInit>

08001ec2 <CopyDataInit>:

CopyDataInit:
  ldr r4, [r2, r3]
 8001ec2:	58d4      	ldr	r4, [r2, r3]
  str r4, [r0, r3]
 8001ec4:	50c4      	str	r4, [r0, r3]
  adds r3, r3, #4
 8001ec6:	3304      	adds	r3, #4

08001ec8 <LoopCopyDataInit>:

LoopCopyDataInit:
  adds r4, r0, r3
 8001ec8:	18c4      	adds	r4, r0, r3
  cmp r4, r1
 8001eca:	428c      	cmp	r4, r1
  bcc CopyDataInit
 8001ecc:	d3f9      	bcc.n	8001ec2 <CopyDataInit>
  
/* Zero fill the bss segment. */
  ldr r2, =_sbss
 8001ece:	4a0a      	ldr	r2, [pc, #40]	; (8001ef8 <LoopForever+0x12>)
  ldr r4, =_ebss
 8001ed0:	4c0a      	ldr	r4, [pc, #40]	; (8001efc <LoopForever+0x16>)
  movs r3, #0
 8001ed2:	2300      	movs	r3, #0
  b LoopFillZerobss
 8001ed4:	e001      	b.n	8001eda <LoopFillZerobss>

08001ed6 <FillZerobss>:

FillZerobss:
  str  r3, [r2]
 8001ed6:	6013      	str	r3, [r2, #0]
  adds r2, r2, #4
 8001ed8:	3204      	adds	r2, #4

08001eda <LoopFillZerobss>:

LoopFillZerobss:
  cmp r2, r4
 8001eda:	42a2      	cmp	r2, r4
  bcc FillZerobss
 8001edc:	d3fb      	bcc.n	8001ed6 <FillZerobss>

/* Call static constructors */
    bl __libc_init_array
 8001ede:	f004 f98b 	bl	80061f8 <__libc_init_array>
/* Call the application's entry point.*/
	bl	main
 8001ee2:	f7ff fbdd 	bl	80016a0 <main>

08001ee6 <LoopForever>:

LoopForever:
    b LoopForever
 8001ee6:	e7fe      	b.n	8001ee6 <LoopForever>
  ldr   sp, =_estack    /* Set stack pointer */
 8001ee8:	20018000 	.word	0x20018000
  ldr r0, =_sdata
 8001eec:	20000000 	.word	0x20000000
  ldr r1, =_edata
 8001ef0:	200001dc 	.word	0x200001dc
  ldr r2, =_sidata
 8001ef4:	08009414 	.word	0x08009414
  ldr r2, =_sbss
 8001ef8:	200001dc 	.word	0x200001dc
  ldr r4, =_ebss
 8001efc:	200003c4 	.word	0x200003c4

08001f00 <ADC1_2_IRQHandler>:
 * @retval : None
*/
    .section	.text.Default_Handler,"ax",%progbits
Default_Handler:
Infinite_Loop:
	b	Infinite_Loop
 8001f00:	e7fe      	b.n	8001f00 <ADC1_2_IRQHandler>
	...

08001f04 <HAL_Init>:
  *         each 1ms in the SysTick_Handler() interrupt handler.
  *
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_Init(void)
{
 8001f04:	b580      	push	{r7, lr}
 8001f06:	b082      	sub	sp, #8
 8001f08:	af00      	add	r7, sp, #0
  HAL_StatusTypeDef  status = HAL_OK;
 8001f0a:	2300      	movs	r3, #0
 8001f0c:	71fb      	strb	r3, [r7, #7]
#if (DATA_CACHE_ENABLE == 0)
   __HAL_FLASH_DATA_CACHE_DISABLE();
#endif /* DATA_CACHE_ENABLE */

#if (PREFETCH_ENABLE != 0)
  __HAL_FLASH_PREFETCH_BUFFER_ENABLE();
 8001f0e:	4b0c      	ldr	r3, [pc, #48]	; (8001f40 <HAL_Init+0x3c>)
 8001f10:	681b      	ldr	r3, [r3, #0]
 8001f12:	4a0b      	ldr	r2, [pc, #44]	; (8001f40 <HAL_Init+0x3c>)
 8001f14:	f443 7380 	orr.w	r3, r3, #256	; 0x100
 8001f18:	6013      	str	r3, [r2, #0]
#endif /* PREFETCH_ENABLE */

  /* Set Interrupt Group Priority */
  HAL_NVIC_SetPriorityGrouping(NVIC_PRIORITYGROUP_4);
 8001f1a:	2003      	movs	r0, #3
 8001f1c:	f000 f962 	bl	80021e4 <HAL_NVIC_SetPriorityGrouping>

  /* Use SysTick as time base source and configure 1ms tick (default clock after Reset is MSI) */
  if (HAL_InitTick(TICK_INT_PRIORITY) != HAL_OK)
 8001f20:	2000      	movs	r0, #0
 8001f22:	f000 f80f 	bl	8001f44 <HAL_InitTick>
 8001f26:	4603      	mov	r3, r0
 8001f28:	2b00      	cmp	r3, #0
 8001f2a:	d002      	beq.n	8001f32 <HAL_Init+0x2e>
  {
    status = HAL_ERROR;
 8001f2c:	2301      	movs	r3, #1
 8001f2e:	71fb      	strb	r3, [r7, #7]
 8001f30:	e001      	b.n	8001f36 <HAL_Init+0x32>
  }
  else
  {
    /* Init the low level hardware */
    HAL_MspInit();
 8001f32:	f7ff fd3b 	bl	80019ac <HAL_MspInit>
  }

  /* Return function status */
  return status;
 8001f36:	79fb      	ldrb	r3, [r7, #7]
}
 8001f38:	4618      	mov	r0, r3
 8001f3a:	3708      	adds	r7, #8
 8001f3c:	46bd      	mov	sp, r7
 8001f3e:	bd80      	pop	{r7, pc}
 8001f40:	40022000 	.word	0x40022000

08001f44 <HAL_InitTick>:
  *       implementation  in user file.
  * @param TickPriority  Tick interrupt priority.
  * @retval HAL status
  */
__weak HAL_StatusTypeDef HAL_InitTick(uint32_t TickPriority)
{
 8001f44:	b580      	push	{r7, lr}
 8001f46:	b084      	sub	sp, #16
 8001f48:	af00      	add	r7, sp, #0
 8001f4a:	6078      	str	r0, [r7, #4]
  HAL_StatusTypeDef  status = HAL_OK;
 8001f4c:	2300      	movs	r3, #0
 8001f4e:	73fb      	strb	r3, [r7, #15]

  /* Check uwTickFreq for MisraC 2012 (even if uwTickFreq is a enum type that doesn't take the value zero)*/
  if ((uint32_t)uwTickFreq != 0U)
 8001f50:	4b17      	ldr	r3, [pc, #92]	; (8001fb0 <HAL_InitTick+0x6c>)
 8001f52:	781b      	ldrb	r3, [r3, #0]
 8001f54:	2b00      	cmp	r3, #0
 8001f56:	d023      	beq.n	8001fa0 <HAL_InitTick+0x5c>
  {
    /*Configure the SysTick to have interrupt in 1ms time basis*/
    if (HAL_SYSTICK_Config(SystemCoreClock / (1000U / (uint32_t)uwTickFreq)) == 0U)
 8001f58:	4b16      	ldr	r3, [pc, #88]	; (8001fb4 <HAL_InitTick+0x70>)
 8001f5a:	681a      	ldr	r2, [r3, #0]
 8001f5c:	4b14      	ldr	r3, [pc, #80]	; (8001fb0 <HAL_InitTick+0x6c>)
 8001f5e:	781b      	ldrb	r3, [r3, #0]
 8001f60:	4619      	mov	r1, r3
 8001f62:	f44f 737a 	mov.w	r3, #1000	; 0x3e8
 8001f66:	fbb3 f3f1 	udiv	r3, r3, r1
 8001f6a:	fbb2 f3f3 	udiv	r3, r2, r3
 8001f6e:	4618      	mov	r0, r3
 8001f70:	f000 f96d 	bl	800224e <HAL_SYSTICK_Config>
 8001f74:	4603      	mov	r3, r0
 8001f76:	2b00      	cmp	r3, #0
 8001f78:	d10f      	bne.n	8001f9a <HAL_InitTick+0x56>
    {
      /* Configure the SysTick IRQ priority */
      if (TickPriority < (1UL << __NVIC_PRIO_BITS))
 8001f7a:	687b      	ldr	r3, [r7, #4]
 8001f7c:	2b0f      	cmp	r3, #15
 8001f7e:	d809      	bhi.n	8001f94 <HAL_InitTick+0x50>
      {
        HAL_NVIC_SetPriority(SysTick_IRQn, TickPriority, 0U);
 8001f80:	2200      	movs	r2, #0
 8001f82:	6879      	ldr	r1, [r7, #4]
 8001f84:	f04f 30ff 	mov.w	r0, #4294967295
 8001f88:	f000 f937 	bl	80021fa <HAL_NVIC_SetPriority>
        uwTickPrio = TickPriority;
 8001f8c:	4a0a      	ldr	r2, [pc, #40]	; (8001fb8 <HAL_InitTick+0x74>)
 8001f8e:	687b      	ldr	r3, [r7, #4]
 8001f90:	6013      	str	r3, [r2, #0]
 8001f92:	e007      	b.n	8001fa4 <HAL_InitTick+0x60>
      }
      else
      {
        status = HAL_ERROR;
 8001f94:	2301      	movs	r3, #1
 8001f96:	73fb      	strb	r3, [r7, #15]
 8001f98:	e004      	b.n	8001fa4 <HAL_InitTick+0x60>
      }
    }
    else
    {
      status = HAL_ERROR;
 8001f9a:	2301      	movs	r3, #1
 8001f9c:	73fb      	strb	r3, [r7, #15]
 8001f9e:	e001      	b.n	8001fa4 <HAL_InitTick+0x60>
    }
  }
  else
  {
    status = HAL_ERROR;
 8001fa0:	2301      	movs	r3, #1
 8001fa2:	73fb      	strb	r3, [r7, #15]
  }

  /* Return function status */
  return status;
 8001fa4:	7bfb      	ldrb	r3, [r7, #15]
}
 8001fa6:	4618      	mov	r0, r3
 8001fa8:	3710      	adds	r7, #16
 8001faa:	46bd      	mov	sp, r7
 8001fac:	bd80      	pop	{r7, pc}
 8001fae:	bf00      	nop
 8001fb0:	20000008 	.word	0x20000008
 8001fb4:	20000000 	.word	0x20000000
 8001fb8:	20000004 	.word	0x20000004

08001fbc <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)
{
 8001fbc:	b480      	push	{r7}
 8001fbe:	af00      	add	r7, sp, #0
  uwTick += (uint32_t)uwTickFreq;
 8001fc0:	4b06      	ldr	r3, [pc, #24]	; (8001fdc <HAL_IncTick+0x20>)
 8001fc2:	781b      	ldrb	r3, [r3, #0]
 8001fc4:	461a      	mov	r2, r3
 8001fc6:	4b06      	ldr	r3, [pc, #24]	; (8001fe0 <HAL_IncTick+0x24>)
 8001fc8:	681b      	ldr	r3, [r3, #0]
 8001fca:	4413      	add	r3, r2
 8001fcc:	4a04      	ldr	r2, [pc, #16]	; (8001fe0 <HAL_IncTick+0x24>)
 8001fce:	6013      	str	r3, [r2, #0]
}
 8001fd0:	bf00      	nop
 8001fd2:	46bd      	mov	sp, r7
 8001fd4:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001fd8:	4770      	bx	lr
 8001fda:	bf00      	nop
 8001fdc:	20000008 	.word	0x20000008
 8001fe0:	200003b0 	.word	0x200003b0

08001fe4 <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)
{
 8001fe4:	b480      	push	{r7}
 8001fe6:	af00      	add	r7, sp, #0
  return uwTick;
 8001fe8:	4b03      	ldr	r3, [pc, #12]	; (8001ff8 <HAL_GetTick+0x14>)
 8001fea:	681b      	ldr	r3, [r3, #0]
}
 8001fec:	4618      	mov	r0, r3
 8001fee:	46bd      	mov	sp, r7
 8001ff0:	f85d 7b04 	ldr.w	r7, [sp], #4
 8001ff4:	4770      	bx	lr
 8001ff6:	bf00      	nop
 8001ff8:	200003b0 	.word	0x200003b0

08001ffc <HAL_Delay>:
  *       implementations in user file.
  * @param Delay  specifies the delay time length, in milliseconds.
  * @retval None
  */
__weak void HAL_Delay(uint32_t Delay)
{
 8001ffc:	b580      	push	{r7, lr}
 8001ffe:	b084      	sub	sp, #16
 8002000:	af00      	add	r7, sp, #0
 8002002:	6078      	str	r0, [r7, #4]
  uint32_t tickstart = HAL_GetTick();
 8002004:	f7ff ffee 	bl	8001fe4 <HAL_GetTick>
 8002008:	60b8      	str	r0, [r7, #8]
  uint32_t wait = Delay;
 800200a:	687b      	ldr	r3, [r7, #4]
 800200c:	60fb      	str	r3, [r7, #12]

  /* Add a period to guaranty minimum wait */
  if (wait < HAL_MAX_DELAY)
 800200e:	68fb      	ldr	r3, [r7, #12]
 8002010:	f1b3 3fff 	cmp.w	r3, #4294967295
 8002014:	d005      	beq.n	8002022 <HAL_Delay+0x26>
  {
    wait += (uint32_t)uwTickFreq;
 8002016:	4b0a      	ldr	r3, [pc, #40]	; (8002040 <HAL_Delay+0x44>)
 8002018:	781b      	ldrb	r3, [r3, #0]
 800201a:	461a      	mov	r2, r3
 800201c:	68fb      	ldr	r3, [r7, #12]
 800201e:	4413      	add	r3, r2
 8002020:	60fb      	str	r3, [r7, #12]
  }

  while ((HAL_GetTick() - tickstart) < wait)
 8002022:	bf00      	nop
 8002024:	f7ff ffde 	bl	8001fe4 <HAL_GetTick>
 8002028:	4602      	mov	r2, r0
 800202a:	68bb      	ldr	r3, [r7, #8]
 800202c:	1ad3      	subs	r3, r2, r3
 800202e:	68fa      	ldr	r2, [r7, #12]
 8002030:	429a      	cmp	r2, r3
 8002032:	d8f7      	bhi.n	8002024 <HAL_Delay+0x28>
  {
  }
}
 8002034:	bf00      	nop
 8002036:	bf00      	nop
 8002038:	3710      	adds	r7, #16
 800203a:	46bd      	mov	sp, r7
 800203c:	bd80      	pop	{r7, pc}
 800203e:	bf00      	nop
 8002040:	20000008 	.word	0x20000008

08002044 <__NVIC_SetPriorityGrouping>:
           In case of a conflict between priority grouping and available
           priority bits (__NVIC_PRIO_BITS), the smallest possible priority group is set.
  \param [in]      PriorityGroup  Priority grouping field.
 */
__STATIC_INLINE void __NVIC_SetPriorityGrouping(uint32_t PriorityGroup)
{
 8002044:	b480      	push	{r7}
 8002046:	b085      	sub	sp, #20
 8002048:	af00      	add	r7, sp, #0
 800204a:	6078      	str	r0, [r7, #4]
  uint32_t reg_value;
  uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL);             /* only values 0..7 are used          */
 800204c:	687b      	ldr	r3, [r7, #4]
 800204e:	f003 0307 	and.w	r3, r3, #7
 8002052:	60fb      	str	r3, [r7, #12]

  reg_value  =  SCB->AIRCR;                                                   /* read old register configuration    */
 8002054:	4b0c      	ldr	r3, [pc, #48]	; (8002088 <__NVIC_SetPriorityGrouping+0x44>)
 8002056:	68db      	ldr	r3, [r3, #12]
 8002058:	60bb      	str	r3, [r7, #8]
  reg_value &= ~((uint32_t)(SCB_AIRCR_VECTKEY_Msk | SCB_AIRCR_PRIGROUP_Msk)); /* clear bits to change               */
 800205a:	68ba      	ldr	r2, [r7, #8]
 800205c:	f64f 03ff 	movw	r3, #63743	; 0xf8ff
 8002060:	4013      	ands	r3, r2
 8002062:	60bb      	str	r3, [r7, #8]
  reg_value  =  (reg_value                                   |
                ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) |
                (PriorityGroupTmp << SCB_AIRCR_PRIGROUP_Pos)  );              /* Insert write key and priority group */
 8002064:	68fb      	ldr	r3, [r7, #12]
 8002066:	021a      	lsls	r2, r3, #8
                ((uint32_t)0x5FAUL << SCB_AIRCR_VECTKEY_Pos) |
 8002068:	68bb      	ldr	r3, [r7, #8]
 800206a:	4313      	orrs	r3, r2
  reg_value  =  (reg_value                                   |
 800206c:	f043 63bf 	orr.w	r3, r3, #100139008	; 0x5f80000
 8002070:	f443 3300 	orr.w	r3, r3, #131072	; 0x20000
 8002074:	60bb      	str	r3, [r7, #8]
  SCB->AIRCR =  reg_value;
 8002076:	4a04      	ldr	r2, [pc, #16]	; (8002088 <__NVIC_SetPriorityGrouping+0x44>)
 8002078:	68bb      	ldr	r3, [r7, #8]
 800207a:	60d3      	str	r3, [r2, #12]
}
 800207c:	bf00      	nop
 800207e:	3714      	adds	r7, #20
 8002080:	46bd      	mov	sp, r7
 8002082:	f85d 7b04 	ldr.w	r7, [sp], #4
 8002086:	4770      	bx	lr
 8002088:	e000ed00 	.word	0xe000ed00

0800208c <__NVIC_GetPriorityGrouping>:
  \brief   Get Priority Grouping
  \details Reads the priority grouping field from the NVIC Interrupt Controller.
  \return                Priority grouping field (SCB->AIRCR [10:8] PRIGROUP field).
 */
__STATIC_INLINE uint32_t __NVIC_GetPriorityGrouping(void)
{
 800208c:	b480      	push	{r7}
 800208e:	af00      	add	r7, sp, #0
  return ((uint32_t)((SCB->AIRCR & SCB_AIRCR_PRIGROUP_Msk) >> SCB_AIRCR_PRIGROUP_Pos));
 8002090:	4b04      	ldr	r3, [pc, #16]	; (80020a4 <__NVIC_GetPriorityGrouping+0x18>)
 8002092:	68db      	ldr	r3, [r3, #12]
 8002094:	0a1b      	lsrs	r3, r3, #8
 8002096:	f003 0307 	and.w	r3, r3, #7
}
 800209a:	4618      	mov	r0, r3
 800209c:	46bd      	mov	sp, r7
 800209e:	f85d 7b04 	ldr.w	r7, [sp], #4
 80020a2:	4770      	bx	lr
 80020a4:	e000ed00 	.word	0xe000ed00

080020a8 <__NVIC_EnableIRQ>:
  \details Enables a device specific interrupt in the NVIC interrupt controller.
  \param [in]      IRQn  Device specific interrupt number.
  \note    IRQn must not be negative.
 */
__STATIC_INLINE void __NVIC_EnableIRQ(IRQn_Type IRQn)
{
 80020a8:	b480      	push	{r7}
 80020aa:	b083      	sub	sp, #12
 80020ac:	af00      	add	r7, sp, #0
 80020ae:	4603      	mov	r3, r0
 80020b0:	71fb      	strb	r3, [r7, #7]
  if ((int32_t)(IRQn) >= 0)
 80020b2:	f997 3007 	ldrsb.w	r3, [r7, #7]
 80020b6:	2b00      	cmp	r3, #0
 80020b8:	db0b      	blt.n	80020d2 <__NVIC_EnableIRQ+0x2a>
  {
    __COMPILER_BARRIER();
    NVIC->ISER[(((uint32_t)IRQn) >> 5UL)] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL));
 80020ba:	79fb      	ldrb	r3, [r7, #7]
 80020bc:	f003 021f 	and.w	r2, r3, #31
 80020c0:	4907      	ldr	r1, [pc, #28]	; (80020e0 <__NVIC_EnableIRQ+0x38>)
 80020c2:	f997 3007 	ldrsb.w	r3, [r7, #7]
 80020c6:	095b      	lsrs	r3, r3, #5
 80020c8:	2001      	movs	r0, #1
 80020ca:	fa00 f202 	lsl.w	r2, r0, r2
 80020ce:	f841 2023 	str.w	r2, [r1, r3, lsl #2]
    __COMPILER_BARRIER();
  }
}
 80020d2:	bf00      	nop
 80020d4:	370c      	adds	r7, #12
 80020d6:	46bd      	mov	sp, r7
 80020d8:	f85d 7b04 	ldr.w	r7, [sp], #4
 80020dc:	4770      	bx	lr
 80020de:	bf00      	nop
 80020e0:	e000e100 	.word	0xe000e100

080020e4 <__NVIC_SetPriority>:
  \param [in]      IRQn  Interrupt number.
  \param [in]  priority  Priority to set.
  \note    The priority cannot be set for every processor exception.
 */
__STATIC_INLINE void __NVIC_SetPriority(IRQn_Type IRQn, uint32_t priority)
{
 80020e4:	b480      	push	{r7}
 80020e6:	b083      	sub	sp, #12
 80020e8:	af00      	add	r7, sp, #0
 80020ea:	4603      	mov	r3, r0
 80020ec:	6039      	str	r1, [r7, #0]
 80020ee:	71fb      	strb	r3, [r7, #7]
  if ((int32_t)(IRQn) >= 0)
 80020f0:	f997 3007 	ldrsb.w	r3, [r7, #7]
 80020f4:	2b00      	cmp	r3, #0
 80020f6:	db0a      	blt.n	800210e <__NVIC_SetPriority+0x2a>
  {
    NVIC->IP[((uint32_t)IRQn)]               = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL);
 80020f8:	683b      	ldr	r3, [r7, #0]
 80020fa:	b2da      	uxtb	r2, r3
 80020fc:	490c      	ldr	r1, [pc, #48]	; (8002130 <__NVIC_SetPriority+0x4c>)
 80020fe:	f997 3007 	ldrsb.w	r3, [r7, #7]
 8002102:	0112      	lsls	r2, r2, #4
 8002104:	b2d2      	uxtb	r2, r2
 8002106:	440b      	add	r3, r1
 8002108:	f883 2300 	strb.w	r2, [r3, #768]	; 0x300
  }
  else
  {
    SCB->SHP[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL);
  }
}
 800210c:	e00a      	b.n	8002124 <__NVIC_SetPriority+0x40>
    SCB->SHP[(((uint32_t)IRQn) & 0xFUL)-4UL] = (uint8_t)((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL);
 800210e:	683b      	ldr	r3, [r7, #0]
 8002110:	b2da      	uxtb	r2, r3
 8002112:	4908      	ldr	r1, [pc, #32]	; (8002134 <__NVIC_SetPriority+0x50>)
 8002114:	79fb      	ldrb	r3, [r7, #7]
 8002116:	f003 030f 	and.w	r3, r3, #15
 800211a:	3b04      	subs	r3, #4
 800211c:	0112      	lsls	r2, r2, #4
 800211e:	b2d2      	uxtb	r2, r2
 8002120:	440b      	add	r3, r1
 8002122:	761a      	strb	r2, [r3, #24]
}
 8002124:	bf00      	nop
 8002126:	370c      	adds	r7, #12
 8002128:	46bd      	mov	sp, r7
 800212a:	f85d 7b04 	ldr.w	r7, [sp], #4
 800212e:	4770      	bx	lr
 8002130:	e000e100 	.word	0xe000e100
 8002134:	e000ed00 	.word	0xe000ed00

08002138 <NVIC_EncodePriority>:
  \param [in]   PreemptPriority  Preemptive priority value (starting from 0).
  \param [in]       SubPriority  Subpriority value (starting from 0).
  \return                        Encoded priority. Value can be used in the function \ref NVIC_SetPriority().
 */
__STATIC_INLINE uint32_t NVIC_EncodePriority (uint32_t PriorityGroup, uint32_t PreemptPriority, uint32_t SubPriority)
{
 8002138:	b480      	push	{r7}
 800213a:	b089      	sub	sp, #36	; 0x24
 800213c:	af00      	add	r7, sp, #0
 800213e:	60f8      	str	r0, [r7, #12]
 8002140:	60b9      	str	r1, [r7, #8]
 8002142:	607a      	str	r2, [r7, #4]
  uint32_t PriorityGroupTmp = (PriorityGroup & (uint32_t)0x07UL);   /* only values 0..7 are used          */
 8002144:	68fb      	ldr	r3, [r7, #12]
 8002146:	f003 0307 	and.w	r3, r3, #7
 800214a:	61fb      	str	r3, [r7, #28]
  uint32_t PreemptPriorityBits;
  uint32_t SubPriorityBits;

  PreemptPriorityBits = ((7UL - PriorityGroupTmp) > (uint32_t)(__NVIC_PRIO_BITS)) ? (uint32_t)(__NVIC_PRIO_BITS) : (uint32_t)(7UL - PriorityGroupTmp);
 800214c:	69fb      	ldr	r3, [r7, #28]
 800214e:	f1c3 0307 	rsb	r3, r3, #7
 8002152:	2b04      	cmp	r3, #4
 8002154:	bf28      	it	cs
 8002156:	2304      	movcs	r3, #4
 8002158:	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));
 800215a:	69fb      	ldr	r3, [r7, #28]
 800215c:	3304      	adds	r3, #4
 800215e:	2b06      	cmp	r3, #6
 8002160:	d902      	bls.n	8002168 <NVIC_EncodePriority+0x30>
 8002162:	69fb      	ldr	r3, [r7, #28]
 8002164:	3b03      	subs	r3, #3
 8002166:	e000      	b.n	800216a <NVIC_EncodePriority+0x32>
 8002168:	2300      	movs	r3, #0
 800216a:	617b      	str	r3, [r7, #20]

  return (
           ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) |
 800216c:	f04f 32ff 	mov.w	r2, #4294967295
 8002170:	69bb      	ldr	r3, [r7, #24]
 8002172:	fa02 f303 	lsl.w	r3, r2, r3
 8002176:	43da      	mvns	r2, r3
 8002178:	68bb      	ldr	r3, [r7, #8]
 800217a:	401a      	ands	r2, r3
 800217c:	697b      	ldr	r3, [r7, #20]
 800217e:	409a      	lsls	r2, r3
           ((SubPriority     & (uint32_t)((1UL << (SubPriorityBits    )) - 1UL)))
 8002180:	f04f 31ff 	mov.w	r1, #4294967295
 8002184:	697b      	ldr	r3, [r7, #20]
 8002186:	fa01 f303 	lsl.w	r3, r1, r3
 800218a:	43d9      	mvns	r1, r3
 800218c:	687b      	ldr	r3, [r7, #4]
 800218e:	400b      	ands	r3, r1
           ((PreemptPriority & (uint32_t)((1UL << (PreemptPriorityBits)) - 1UL)) << SubPriorityBits) |
 8002190:	4313      	orrs	r3, r2
         );
}
 8002192:	4618      	mov	r0, r3
 8002194:	3724      	adds	r7, #36	; 0x24
 8002196:	46bd      	mov	sp, r7
 8002198:	f85d 7b04 	ldr.w	r7, [sp], #4
 800219c:	4770      	bx	lr
	...

080021a0 <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)
{
 80021a0:	b580      	push	{r7, lr}
 80021a2:	b082      	sub	sp, #8
 80021a4:	af00      	add	r7, sp, #0
 80021a6:	6078      	str	r0, [r7, #4]
  if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk)
 80021a8:	687b      	ldr	r3, [r7, #4]
 80021aa:	3b01      	subs	r3, #1
 80021ac:	f1b3 7f80 	cmp.w	r3, #16777216	; 0x1000000
 80021b0:	d301      	bcc.n	80021b6 <SysTick_Config+0x16>
  {
    return (1UL);                                                   /* Reload value impossible */
 80021b2:	2301      	movs	r3, #1
 80021b4:	e00f      	b.n	80021d6 <SysTick_Config+0x36>
  }

  SysTick->LOAD  = (uint32_t)(ticks - 1UL);                         /* set reload register */
 80021b6:	4a0a      	ldr	r2, [pc, #40]	; (80021e0 <SysTick_Config+0x40>)
 80021b8:	687b      	ldr	r3, [r7, #4]
 80021ba:	3b01      	subs	r3, #1
 80021bc:	6053      	str	r3, [r2, #4]
  NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */
 80021be:	210f      	movs	r1, #15
 80021c0:	f04f 30ff 	mov.w	r0, #4294967295
 80021c4:	f7ff ff8e 	bl	80020e4 <__NVIC_SetPriority>
  SysTick->VAL   = 0UL;                                             /* Load the SysTick Counter Value */
 80021c8:	4b05      	ldr	r3, [pc, #20]	; (80021e0 <SysTick_Config+0x40>)
 80021ca:	2200      	movs	r2, #0
 80021cc:	609a      	str	r2, [r3, #8]
  SysTick->CTRL  = SysTick_CTRL_CLKSOURCE_Msk |
 80021ce:	4b04      	ldr	r3, [pc, #16]	; (80021e0 <SysTick_Config+0x40>)
 80021d0:	2207      	movs	r2, #7
 80021d2:	601a      	str	r2, [r3, #0]
                   SysTick_CTRL_TICKINT_Msk   |
                   SysTick_CTRL_ENABLE_Msk;                         /* Enable SysTick IRQ and SysTick Timer */
  return (0UL);                                                     /* Function successful */
 80021d4:	2300      	movs	r3, #0
}
 80021d6:	4618      	mov	r0, r3
 80021d8:	3708      	adds	r7, #8
 80021da:	46bd      	mov	sp, r7
 80021dc:	bd80      	pop	{r7, pc}
 80021de:	bf00      	nop
 80021e0:	e000e010 	.word	0xe000e010

080021e4 <HAL_NVIC_SetPriorityGrouping>:
  * @note   When the NVIC_PriorityGroup_0 is selected, IRQ pre-emption is no more possible.
  *         The pending IRQ priority will be managed only by the subpriority.
  * @retval None
  */
void HAL_NVIC_SetPriorityGrouping(uint32_t PriorityGroup)
{
 80021e4:	b580      	push	{r7, lr}
 80021e6:	b082      	sub	sp, #8
 80021e8:	af00      	add	r7, sp, #0
 80021ea:	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);
 80021ec:	6878      	ldr	r0, [r7, #4]
 80021ee:	f7ff ff29 	bl	8002044 <__NVIC_SetPriorityGrouping>
}
 80021f2:	bf00      	nop
 80021f4:	3708      	adds	r7, #8
 80021f6:	46bd      	mov	sp, r7
 80021f8:	bd80      	pop	{r7, pc}

080021fa <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)
{
 80021fa:	b580      	push	{r7, lr}
 80021fc:	b086      	sub	sp, #24
 80021fe:	af00      	add	r7, sp, #0
 8002200:	4603      	mov	r3, r0
 8002202:	60b9      	str	r1, [r7, #8]
 8002204:	607a      	str	r2, [r7, #4]
 8002206:	73fb      	strb	r3, [r7, #15]
  uint32_t prioritygroup = 0x00;
 8002208:	2300      	movs	r3, #0
 800220a:	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();
 800220c:	f7ff ff3e 	bl	800208c <__NVIC_GetPriorityGrouping>
 8002210:	6178      	str	r0, [r7, #20]

  NVIC_SetPriority(IRQn, NVIC_EncodePriority(prioritygroup, PreemptPriority, SubPriority));
 8002212:	687a      	ldr	r2, [r7, #4]
 8002214:	68b9      	ldr	r1, [r7, #8]
 8002216:	6978      	ldr	r0, [r7, #20]
 8002218:	f7ff ff8e 	bl	8002138 <NVIC_EncodePriority>
 800221c:	4602      	mov	r2, r0
 800221e:	f997 300f 	ldrsb.w	r3, [r7, #15]
 8002222:	4611      	mov	r1, r2
 8002224:	4618      	mov	r0, r3
 8002226:	f7ff ff5d 	bl	80020e4 <__NVIC_SetPriority>
}
 800222a:	bf00      	nop
 800222c:	3718      	adds	r7, #24
 800222e:	46bd      	mov	sp, r7
 8002230:	bd80      	pop	{r7, pc}

08002232 <HAL_NVIC_EnableIRQ>:
  *         This parameter can be an enumerator of IRQn_Type enumeration
  *         (For the complete STM32 Devices IRQ Channels list, please refer to the appropriate CMSIS device file (stm32l4xxxx.h))
  * @retval None
  */
void HAL_NVIC_EnableIRQ(IRQn_Type IRQn)
{
 8002232:	b580      	push	{r7, lr}
 8002234:	b082      	sub	sp, #8
 8002236:	af00      	add	r7, sp, #0
 8002238:	4603      	mov	r3, r0
 800223a:	71fb      	strb	r3, [r7, #7]
  /* Check the parameters */
  assert_param(IS_NVIC_DEVICE_IRQ(IRQn));
  
  /* Enable interrupt */
  NVIC_EnableIRQ(IRQn);
 800223c:	f997 3007 	ldrsb.w	r3, [r7, #7]
 8002240:	4618      	mov	r0, r3
 8002242:	f7ff ff31 	bl	80020a8 <__NVIC_EnableIRQ>
}
 8002246:	bf00      	nop
 8002248:	3708      	adds	r7, #8
 800224a:	46bd      	mov	sp, r7
 800224c:	bd80      	pop	{r7, pc}

0800224e <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)
{
 800224e:	b580      	push	{r7, lr}
 8002250:	b082      	sub	sp, #8
 8002252:	af00      	add	r7, sp, #0
 8002254:	6078      	str	r0, [r7, #4]
   return SysTick_Config(TicksNumb);
 8002256:	6878      	ldr	r0, [r7, #4]
 8002258:	f7ff ffa2 	bl	80021a0 <SysTick_Config>
 800225c:	4603      	mov	r3, r0
}
 800225e:	4618      	mov	r0, r3
 8002260:	3708      	adds	r7, #8
 8002262:	46bd      	mov	sp, r7
 8002264:	bd80      	pop	{r7, pc}

08002266 <HAL_DMA_Abort_IT>:
  * @param  hdma pointer to a DMA_HandleTypeDef structure that contains
  *                 the configuration information for the specified DMA Channel.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_DMA_Abort_IT(DMA_HandleTypeDef *hdma)
{
 8002266:	b580      	push	{r7, lr}
 8002268:	b084      	sub	sp, #16
 800226a:	af00      	add	r7, sp, #0
 800226c:	6078      	str	r0, [r7, #4]
  HAL_StatusTypeDef status = HAL_OK;
 800226e:	2300      	movs	r3, #0
 8002270:	73fb      	strb	r3, [r7, #15]

  if(HAL_DMA_STATE_BUSY != hdma->State)
 8002272:	687b      	ldr	r3, [r7, #4]
 8002274:	f893 3025 	ldrb.w	r3, [r3, #37]	; 0x25
 8002278:	b2db      	uxtb	r3, r3
 800227a:	2b02      	cmp	r3, #2
 800227c:	d005      	beq.n	800228a <HAL_DMA_Abort_IT+0x24>
  {
    /* no transfer ongoing */
    hdma->ErrorCode = HAL_DMA_ERROR_NO_XFER;
 800227e:	687b      	ldr	r3, [r7, #4]
 8002280:	2204      	movs	r2, #4
 8002282:	63da      	str	r2, [r3, #60]	; 0x3c

    status = HAL_ERROR;
 8002284:	2301      	movs	r3, #1
 8002286:	73fb      	strb	r3, [r7, #15]
 8002288:	e029      	b.n	80022de <HAL_DMA_Abort_IT+0x78>
  }
  else
  {
    /* Disable DMA IT */
    __HAL_DMA_DISABLE_IT(hdma, (DMA_IT_TC | DMA_IT_HT | DMA_IT_TE));
 800228a:	687b      	ldr	r3, [r7, #4]
 800228c:	681b      	ldr	r3, [r3, #0]
 800228e:	681a      	ldr	r2, [r3, #0]
 8002290:	687b      	ldr	r3, [r7, #4]
 8002292:	681b      	ldr	r3, [r3, #0]
 8002294:	f022 020e 	bic.w	r2, r2, #14
 8002298:	601a      	str	r2, [r3, #0]

    /* Disable the channel */
    __HAL_DMA_DISABLE(hdma);
 800229a:	687b      	ldr	r3, [r7, #4]
 800229c:	681b      	ldr	r3, [r3, #0]
 800229e:	681a      	ldr	r2, [r3, #0]
 80022a0:	687b      	ldr	r3, [r7, #4]
 80022a2:	681b      	ldr	r3, [r3, #0]
 80022a4:	f022 0201 	bic.w	r2, r2, #1
 80022a8:	601a      	str	r2, [r3, #0]
      hdma->DMAmuxRequestGenStatus->RGCFR = hdma->DMAmuxRequestGenStatusMask;
    }

#else
    /* Clear all flags */
    hdma->DmaBaseAddress->IFCR = (DMA_ISR_GIF1 << (hdma->ChannelIndex & 0x1CU));
 80022aa:	687b      	ldr	r3, [r7, #4]
 80022ac:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 80022ae:	f003 021c 	and.w	r2, r3, #28
 80022b2:	687b      	ldr	r3, [r7, #4]
 80022b4:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 80022b6:	2101      	movs	r1, #1
 80022b8:	fa01 f202 	lsl.w	r2, r1, r2
 80022bc:	605a      	str	r2, [r3, #4]
#endif /* DMAMUX1 */

    /* Change the DMA state */
    hdma->State = HAL_DMA_STATE_READY;
 80022be:	687b      	ldr	r3, [r7, #4]
 80022c0:	2201      	movs	r2, #1
 80022c2:	f883 2025 	strb.w	r2, [r3, #37]	; 0x25

    /* Process Unlocked */
    __HAL_UNLOCK(hdma);
 80022c6:	687b      	ldr	r3, [r7, #4]
 80022c8:	2200      	movs	r2, #0
 80022ca:	f883 2024 	strb.w	r2, [r3, #36]	; 0x24

    /* Call User Abort callback */
    if(hdma->XferAbortCallback != NULL)
 80022ce:	687b      	ldr	r3, [r7, #4]
 80022d0:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 80022d2:	2b00      	cmp	r3, #0
 80022d4:	d003      	beq.n	80022de <HAL_DMA_Abort_IT+0x78>
    {
      hdma->XferAbortCallback(hdma);
 80022d6:	687b      	ldr	r3, [r7, #4]
 80022d8:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 80022da:	6878      	ldr	r0, [r7, #4]
 80022dc:	4798      	blx	r3
    }
  }
  return status;
 80022de:	7bfb      	ldrb	r3, [r7, #15]
}
 80022e0:	4618      	mov	r0, r3
 80022e2:	3710      	adds	r7, #16
 80022e4:	46bd      	mov	sp, r7
 80022e6:	bd80      	pop	{r7, pc}

080022e8 <HAL_DMA_GetState>:
  * @param  hdma pointer to a DMA_HandleTypeDef structure that contains
  *               the configuration information for the specified DMA Channel.
  * @retval HAL state
  */
HAL_DMA_StateTypeDef HAL_DMA_GetState(DMA_HandleTypeDef *hdma)
{
 80022e8:	b480      	push	{r7}
 80022ea:	b083      	sub	sp, #12
 80022ec:	af00      	add	r7, sp, #0
 80022ee:	6078      	str	r0, [r7, #4]
  /* Return DMA handle state */
  return hdma->State;
 80022f0:	687b      	ldr	r3, [r7, #4]
 80022f2:	f893 3025 	ldrb.w	r3, [r3, #37]	; 0x25
 80022f6:	b2db      	uxtb	r3, r3
}
 80022f8:	4618      	mov	r0, r3
 80022fa:	370c      	adds	r7, #12
 80022fc:	46bd      	mov	sp, r7
 80022fe:	f85d 7b04 	ldr.w	r7, [sp], #4
 8002302:	4770      	bx	lr

08002304 <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)
{
 8002304:	b480      	push	{r7}
 8002306:	b087      	sub	sp, #28
 8002308:	af00      	add	r7, sp, #0
 800230a:	6078      	str	r0, [r7, #4]
 800230c:	6039      	str	r1, [r7, #0]
  uint32_t position = 0x00u;
 800230e:	2300      	movs	r3, #0
 8002310:	617b      	str	r3, [r7, #20]
  assert_param(IS_GPIO_ALL_INSTANCE(GPIOx));
  assert_param(IS_GPIO_PIN(GPIO_Init->Pin));
  assert_param(IS_GPIO_MODE(GPIO_Init->Mode));

  /* Configure the port pins */
  while (((GPIO_Init->Pin) >> position) != 0x00u)
 8002312:	e17f      	b.n	8002614 <HAL_GPIO_Init+0x310>
  {
    /* Get current io position */
    iocurrent = (GPIO_Init->Pin) & (1uL << position);
 8002314:	683b      	ldr	r3, [r7, #0]
 8002316:	681a      	ldr	r2, [r3, #0]
 8002318:	2101      	movs	r1, #1
 800231a:	697b      	ldr	r3, [r7, #20]
 800231c:	fa01 f303 	lsl.w	r3, r1, r3
 8002320:	4013      	ands	r3, r2
 8002322:	60fb      	str	r3, [r7, #12]

    if (iocurrent != 0x00u)
 8002324:	68fb      	ldr	r3, [r7, #12]
 8002326:	2b00      	cmp	r3, #0
 8002328:	f000 8171 	beq.w	800260e <HAL_GPIO_Init+0x30a>
    {
      /*--------------------- GPIO Mode Configuration ------------------------*/
      /* In case of Output or Alternate function mode selection */
      if (((GPIO_Init->Mode & GPIO_MODE) == MODE_OUTPUT) || ((GPIO_Init->Mode & GPIO_MODE) == MODE_AF))
 800232c:	683b      	ldr	r3, [r7, #0]
 800232e:	685b      	ldr	r3, [r3, #4]
 8002330:	f003 0303 	and.w	r3, r3, #3
 8002334:	2b01      	cmp	r3, #1
 8002336:	d005      	beq.n	8002344 <HAL_GPIO_Init+0x40>
 8002338:	683b      	ldr	r3, [r7, #0]
 800233a:	685b      	ldr	r3, [r3, #4]
 800233c:	f003 0303 	and.w	r3, r3, #3
 8002340:	2b02      	cmp	r3, #2
 8002342:	d130      	bne.n	80023a6 <HAL_GPIO_Init+0xa2>
      {
        /* Check the Speed parameter */
        assert_param(IS_GPIO_SPEED(GPIO_Init->Speed));

        /* Configure the IO Speed */
        temp = GPIOx->OSPEEDR;
 8002344:	687b      	ldr	r3, [r7, #4]
 8002346:	689b      	ldr	r3, [r3, #8]
 8002348:	613b      	str	r3, [r7, #16]
        temp &= ~(GPIO_OSPEEDR_OSPEED0 << (position * 2u));
 800234a:	697b      	ldr	r3, [r7, #20]
 800234c:	005b      	lsls	r3, r3, #1
 800234e:	2203      	movs	r2, #3
 8002350:	fa02 f303 	lsl.w	r3, r2, r3
 8002354:	43db      	mvns	r3, r3
 8002356:	693a      	ldr	r2, [r7, #16]
 8002358:	4013      	ands	r3, r2
 800235a:	613b      	str	r3, [r7, #16]
        temp |= (GPIO_Init->Speed << (position * 2u));
 800235c:	683b      	ldr	r3, [r7, #0]
 800235e:	68da      	ldr	r2, [r3, #12]
 8002360:	697b      	ldr	r3, [r7, #20]
 8002362:	005b      	lsls	r3, r3, #1
 8002364:	fa02 f303 	lsl.w	r3, r2, r3
 8002368:	693a      	ldr	r2, [r7, #16]
 800236a:	4313      	orrs	r3, r2
 800236c:	613b      	str	r3, [r7, #16]
        GPIOx->OSPEEDR = temp;
 800236e:	687b      	ldr	r3, [r7, #4]
 8002370:	693a      	ldr	r2, [r7, #16]
 8002372:	609a      	str	r2, [r3, #8]

        /* Configure the IO Output Type */
        temp = GPIOx->OTYPER;
 8002374:	687b      	ldr	r3, [r7, #4]
 8002376:	685b      	ldr	r3, [r3, #4]
 8002378:	613b      	str	r3, [r7, #16]
        temp &= ~(GPIO_OTYPER_OT0 << position) ;
 800237a:	2201      	movs	r2, #1
 800237c:	697b      	ldr	r3, [r7, #20]
 800237e:	fa02 f303 	lsl.w	r3, r2, r3
 8002382:	43db      	mvns	r3, r3
 8002384:	693a      	ldr	r2, [r7, #16]
 8002386:	4013      	ands	r3, r2
 8002388:	613b      	str	r3, [r7, #16]
        temp |= (((GPIO_Init->Mode & OUTPUT_TYPE) >> OUTPUT_TYPE_Pos) << position);
 800238a:	683b      	ldr	r3, [r7, #0]
 800238c:	685b      	ldr	r3, [r3, #4]
 800238e:	091b      	lsrs	r3, r3, #4
 8002390:	f003 0201 	and.w	r2, r3, #1
 8002394:	697b      	ldr	r3, [r7, #20]
 8002396:	fa02 f303 	lsl.w	r3, r2, r3
 800239a:	693a      	ldr	r2, [r7, #16]
 800239c:	4313      	orrs	r3, r2
 800239e:	613b      	str	r3, [r7, #16]
        GPIOx->OTYPER = temp;
 80023a0:	687b      	ldr	r3, [r7, #4]
 80023a2:	693a      	ldr	r2, [r7, #16]
 80023a4:	605a      	str	r2, [r3, #4]
      }

#if defined(STM32L471xx) || defined(STM32L475xx) || defined(STM32L476xx) || defined(STM32L485xx) || defined(STM32L486xx)

      /* In case of Analog mode, check if ADC control mode is selected */
      if((GPIO_Init->Mode & GPIO_MODE_ANALOG) == GPIO_MODE_ANALOG)
 80023a6:	683b      	ldr	r3, [r7, #0]
 80023a8:	685b      	ldr	r3, [r3, #4]
 80023aa:	f003 0303 	and.w	r3, r3, #3
 80023ae:	2b03      	cmp	r3, #3
 80023b0:	d118      	bne.n	80023e4 <HAL_GPIO_Init+0xe0>
      {
        /* Configure the IO Output Type */
        temp = GPIOx->ASCR;
 80023b2:	687b      	ldr	r3, [r7, #4]
 80023b4:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 80023b6:	613b      	str	r3, [r7, #16]
        temp &= ~(GPIO_ASCR_ASC0 << position) ;
 80023b8:	2201      	movs	r2, #1
 80023ba:	697b      	ldr	r3, [r7, #20]
 80023bc:	fa02 f303 	lsl.w	r3, r2, r3
 80023c0:	43db      	mvns	r3, r3
 80023c2:	693a      	ldr	r2, [r7, #16]
 80023c4:	4013      	ands	r3, r2
 80023c6:	613b      	str	r3, [r7, #16]
        temp |= (((GPIO_Init->Mode & GPIO_MODE_ANALOG_ADC_CONTROL) >> 3) << position);
 80023c8:	683b      	ldr	r3, [r7, #0]
 80023ca:	685b      	ldr	r3, [r3, #4]
 80023cc:	08db      	lsrs	r3, r3, #3
 80023ce:	f003 0201 	and.w	r2, r3, #1
 80023d2:	697b      	ldr	r3, [r7, #20]
 80023d4:	fa02 f303 	lsl.w	r3, r2, r3
 80023d8:	693a      	ldr	r2, [r7, #16]
 80023da:	4313      	orrs	r3, r2
 80023dc:	613b      	str	r3, [r7, #16]
        GPIOx->ASCR = temp;
 80023de:	687b      	ldr	r3, [r7, #4]
 80023e0:	693a      	ldr	r2, [r7, #16]
 80023e2:	62da      	str	r2, [r3, #44]	; 0x2c
      }

#endif /* STM32L471xx || STM32L475xx || STM32L476xx || STM32L485xx || STM32L486xx */

      /* Activate the Pull-up or Pull down resistor for the current IO */
      if ((GPIO_Init->Mode & GPIO_MODE) != MODE_ANALOG)
 80023e4:	683b      	ldr	r3, [r7, #0]
 80023e6:	685b      	ldr	r3, [r3, #4]
 80023e8:	f003 0303 	and.w	r3, r3, #3
 80023ec:	2b03      	cmp	r3, #3
 80023ee:	d017      	beq.n	8002420 <HAL_GPIO_Init+0x11c>
      {
        /* Check the Pull parameter */
        assert_param(IS_GPIO_PULL(GPIO_Init->Pull));

        temp = GPIOx->PUPDR;
 80023f0:	687b      	ldr	r3, [r7, #4]
 80023f2:	68db      	ldr	r3, [r3, #12]
 80023f4:	613b      	str	r3, [r7, #16]
        temp &= ~(GPIO_PUPDR_PUPD0 << (position * 2U));
 80023f6:	697b      	ldr	r3, [r7, #20]
 80023f8:	005b      	lsls	r3, r3, #1
 80023fa:	2203      	movs	r2, #3
 80023fc:	fa02 f303 	lsl.w	r3, r2, r3
 8002400:	43db      	mvns	r3, r3
 8002402:	693a      	ldr	r2, [r7, #16]
 8002404:	4013      	ands	r3, r2
 8002406:	613b      	str	r3, [r7, #16]
        temp |= ((GPIO_Init->Pull) << (position * 2U));
 8002408:	683b      	ldr	r3, [r7, #0]
 800240a:	689a      	ldr	r2, [r3, #8]
 800240c:	697b      	ldr	r3, [r7, #20]
 800240e:	005b      	lsls	r3, r3, #1
 8002410:	fa02 f303 	lsl.w	r3, r2, r3
 8002414:	693a      	ldr	r2, [r7, #16]
 8002416:	4313      	orrs	r3, r2
 8002418:	613b      	str	r3, [r7, #16]
        GPIOx->PUPDR = temp;
 800241a:	687b      	ldr	r3, [r7, #4]
 800241c:	693a      	ldr	r2, [r7, #16]
 800241e:	60da      	str	r2, [r3, #12]
      }

      /* In case of Alternate function mode selection */
      if ((GPIO_Init->Mode & GPIO_MODE) == MODE_AF)
 8002420:	683b      	ldr	r3, [r7, #0]
 8002422:	685b      	ldr	r3, [r3, #4]
 8002424:	f003 0303 	and.w	r3, r3, #3
 8002428:	2b02      	cmp	r3, #2
 800242a:	d123      	bne.n	8002474 <HAL_GPIO_Init+0x170>
        /* Check the Alternate function parameters */
        assert_param(IS_GPIO_AF_INSTANCE(GPIOx));
        assert_param(IS_GPIO_AF(GPIO_Init->Alternate));

        /* Configure Alternate function mapped with the current IO */
        temp = GPIOx->AFR[position >> 3u];
 800242c:	697b      	ldr	r3, [r7, #20]
 800242e:	08da      	lsrs	r2, r3, #3
 8002430:	687b      	ldr	r3, [r7, #4]
 8002432:	3208      	adds	r2, #8
 8002434:	f853 3022 	ldr.w	r3, [r3, r2, lsl #2]
 8002438:	613b      	str	r3, [r7, #16]
        temp &= ~(0xFu << ((position & 0x07u) * 4u));
 800243a:	697b      	ldr	r3, [r7, #20]
 800243c:	f003 0307 	and.w	r3, r3, #7
 8002440:	009b      	lsls	r3, r3, #2
 8002442:	220f      	movs	r2, #15
 8002444:	fa02 f303 	lsl.w	r3, r2, r3
 8002448:	43db      	mvns	r3, r3
 800244a:	693a      	ldr	r2, [r7, #16]
 800244c:	4013      	ands	r3, r2
 800244e:	613b      	str	r3, [r7, #16]
        temp |= ((GPIO_Init->Alternate) << ((position & 0x07u) * 4u));
 8002450:	683b      	ldr	r3, [r7, #0]
 8002452:	691a      	ldr	r2, [r3, #16]
 8002454:	697b      	ldr	r3, [r7, #20]
 8002456:	f003 0307 	and.w	r3, r3, #7
 800245a:	009b      	lsls	r3, r3, #2
 800245c:	fa02 f303 	lsl.w	r3, r2, r3
 8002460:	693a      	ldr	r2, [r7, #16]
 8002462:	4313      	orrs	r3, r2
 8002464:	613b      	str	r3, [r7, #16]
        GPIOx->AFR[position >> 3u] = temp;
 8002466:	697b      	ldr	r3, [r7, #20]
 8002468:	08da      	lsrs	r2, r3, #3
 800246a:	687b      	ldr	r3, [r7, #4]
 800246c:	3208      	adds	r2, #8
 800246e:	6939      	ldr	r1, [r7, #16]
 8002470:	f843 1022 	str.w	r1, [r3, r2, lsl #2]
      }

      /* Configure IO Direction mode (Input, Output, Alternate or Analog) */
      temp = GPIOx->MODER;
 8002474:	687b      	ldr	r3, [r7, #4]
 8002476:	681b      	ldr	r3, [r3, #0]
 8002478:	613b      	str	r3, [r7, #16]
      temp &= ~(GPIO_MODER_MODE0 << (position * 2u));
 800247a:	697b      	ldr	r3, [r7, #20]
 800247c:	005b      	lsls	r3, r3, #1
 800247e:	2203      	movs	r2, #3
 8002480:	fa02 f303 	lsl.w	r3, r2, r3
 8002484:	43db      	mvns	r3, r3
 8002486:	693a      	ldr	r2, [r7, #16]
 8002488:	4013      	ands	r3, r2
 800248a:	613b      	str	r3, [r7, #16]
      temp |= ((GPIO_Init->Mode & GPIO_MODE) << (position * 2u));
 800248c:	683b      	ldr	r3, [r7, #0]
 800248e:	685b      	ldr	r3, [r3, #4]
 8002490:	f003 0203 	and.w	r2, r3, #3
 8002494:	697b      	ldr	r3, [r7, #20]
 8002496:	005b      	lsls	r3, r3, #1
 8002498:	fa02 f303 	lsl.w	r3, r2, r3
 800249c:	693a      	ldr	r2, [r7, #16]
 800249e:	4313      	orrs	r3, r2
 80024a0:	613b      	str	r3, [r7, #16]
      GPIOx->MODER = temp;
 80024a2:	687b      	ldr	r3, [r7, #4]
 80024a4:	693a      	ldr	r2, [r7, #16]
 80024a6:	601a      	str	r2, [r3, #0]

      /*--------------------- EXTI Mode Configuration ------------------------*/
      /* Configure the External Interrupt or event for the current IO */
      if ((GPIO_Init->Mode & EXTI_MODE) != 0x00u)
 80024a8:	683b      	ldr	r3, [r7, #0]
 80024aa:	685b      	ldr	r3, [r3, #4]
 80024ac:	f403 3340 	and.w	r3, r3, #196608	; 0x30000
 80024b0:	2b00      	cmp	r3, #0
 80024b2:	f000 80ac 	beq.w	800260e <HAL_GPIO_Init+0x30a>
      {
        /* Enable SYSCFG Clock */
        __HAL_RCC_SYSCFG_CLK_ENABLE();
 80024b6:	4b5f      	ldr	r3, [pc, #380]	; (8002634 <HAL_GPIO_Init+0x330>)
 80024b8:	6e1b      	ldr	r3, [r3, #96]	; 0x60
 80024ba:	4a5e      	ldr	r2, [pc, #376]	; (8002634 <HAL_GPIO_Init+0x330>)
 80024bc:	f043 0301 	orr.w	r3, r3, #1
 80024c0:	6613      	str	r3, [r2, #96]	; 0x60
 80024c2:	4b5c      	ldr	r3, [pc, #368]	; (8002634 <HAL_GPIO_Init+0x330>)
 80024c4:	6e1b      	ldr	r3, [r3, #96]	; 0x60
 80024c6:	f003 0301 	and.w	r3, r3, #1
 80024ca:	60bb      	str	r3, [r7, #8]
 80024cc:	68bb      	ldr	r3, [r7, #8]

        temp = SYSCFG->EXTICR[position >> 2u];
 80024ce:	4a5a      	ldr	r2, [pc, #360]	; (8002638 <HAL_GPIO_Init+0x334>)
 80024d0:	697b      	ldr	r3, [r7, #20]
 80024d2:	089b      	lsrs	r3, r3, #2
 80024d4:	3302      	adds	r3, #2
 80024d6:	f852 3023 	ldr.w	r3, [r2, r3, lsl #2]
 80024da:	613b      	str	r3, [r7, #16]
        temp &= ~(0x0FuL << (4u * (position & 0x03u)));
 80024dc:	697b      	ldr	r3, [r7, #20]
 80024de:	f003 0303 	and.w	r3, r3, #3
 80024e2:	009b      	lsls	r3, r3, #2
 80024e4:	220f      	movs	r2, #15
 80024e6:	fa02 f303 	lsl.w	r3, r2, r3
 80024ea:	43db      	mvns	r3, r3
 80024ec:	693a      	ldr	r2, [r7, #16]
 80024ee:	4013      	ands	r3, r2
 80024f0:	613b      	str	r3, [r7, #16]
        temp |= (GPIO_GET_INDEX(GPIOx) << (4u * (position & 0x03u)));
 80024f2:	687b      	ldr	r3, [r7, #4]
 80024f4:	f1b3 4f90 	cmp.w	r3, #1207959552	; 0x48000000
 80024f8:	d025      	beq.n	8002546 <HAL_GPIO_Init+0x242>
 80024fa:	687b      	ldr	r3, [r7, #4]
 80024fc:	4a4f      	ldr	r2, [pc, #316]	; (800263c <HAL_GPIO_Init+0x338>)
 80024fe:	4293      	cmp	r3, r2
 8002500:	d01f      	beq.n	8002542 <HAL_GPIO_Init+0x23e>
 8002502:	687b      	ldr	r3, [r7, #4]
 8002504:	4a4e      	ldr	r2, [pc, #312]	; (8002640 <HAL_GPIO_Init+0x33c>)
 8002506:	4293      	cmp	r3, r2
 8002508:	d019      	beq.n	800253e <HAL_GPIO_Init+0x23a>
 800250a:	687b      	ldr	r3, [r7, #4]
 800250c:	4a4d      	ldr	r2, [pc, #308]	; (8002644 <HAL_GPIO_Init+0x340>)
 800250e:	4293      	cmp	r3, r2
 8002510:	d013      	beq.n	800253a <HAL_GPIO_Init+0x236>
 8002512:	687b      	ldr	r3, [r7, #4]
 8002514:	4a4c      	ldr	r2, [pc, #304]	; (8002648 <HAL_GPIO_Init+0x344>)
 8002516:	4293      	cmp	r3, r2
 8002518:	d00d      	beq.n	8002536 <HAL_GPIO_Init+0x232>
 800251a:	687b      	ldr	r3, [r7, #4]
 800251c:	4a4b      	ldr	r2, [pc, #300]	; (800264c <HAL_GPIO_Init+0x348>)
 800251e:	4293      	cmp	r3, r2
 8002520:	d007      	beq.n	8002532 <HAL_GPIO_Init+0x22e>
 8002522:	687b      	ldr	r3, [r7, #4]
 8002524:	4a4a      	ldr	r2, [pc, #296]	; (8002650 <HAL_GPIO_Init+0x34c>)
 8002526:	4293      	cmp	r3, r2
 8002528:	d101      	bne.n	800252e <HAL_GPIO_Init+0x22a>
 800252a:	2306      	movs	r3, #6
 800252c:	e00c      	b.n	8002548 <HAL_GPIO_Init+0x244>
 800252e:	2307      	movs	r3, #7
 8002530:	e00a      	b.n	8002548 <HAL_GPIO_Init+0x244>
 8002532:	2305      	movs	r3, #5
 8002534:	e008      	b.n	8002548 <HAL_GPIO_Init+0x244>
 8002536:	2304      	movs	r3, #4
 8002538:	e006      	b.n	8002548 <HAL_GPIO_Init+0x244>
 800253a:	2303      	movs	r3, #3
 800253c:	e004      	b.n	8002548 <HAL_GPIO_Init+0x244>
 800253e:	2302      	movs	r3, #2
 8002540:	e002      	b.n	8002548 <HAL_GPIO_Init+0x244>
 8002542:	2301      	movs	r3, #1
 8002544:	e000      	b.n	8002548 <HAL_GPIO_Init+0x244>
 8002546:	2300      	movs	r3, #0
 8002548:	697a      	ldr	r2, [r7, #20]
 800254a:	f002 0203 	and.w	r2, r2, #3
 800254e:	0092      	lsls	r2, r2, #2
 8002550:	4093      	lsls	r3, r2
 8002552:	693a      	ldr	r2, [r7, #16]
 8002554:	4313      	orrs	r3, r2
 8002556:	613b      	str	r3, [r7, #16]
        SYSCFG->EXTICR[position >> 2u] = temp;
 8002558:	4937      	ldr	r1, [pc, #220]	; (8002638 <HAL_GPIO_Init+0x334>)
 800255a:	697b      	ldr	r3, [r7, #20]
 800255c:	089b      	lsrs	r3, r3, #2
 800255e:	3302      	adds	r3, #2
 8002560:	693a      	ldr	r2, [r7, #16]
 8002562:	f841 2023 	str.w	r2, [r1, r3, lsl #2]

        /* Clear Rising Falling edge configuration */
        temp = EXTI->RTSR1;
 8002566:	4b3b      	ldr	r3, [pc, #236]	; (8002654 <HAL_GPIO_Init+0x350>)
 8002568:	689b      	ldr	r3, [r3, #8]
 800256a:	613b      	str	r3, [r7, #16]
        temp &= ~(iocurrent);
 800256c:	68fb      	ldr	r3, [r7, #12]
 800256e:	43db      	mvns	r3, r3
 8002570:	693a      	ldr	r2, [r7, #16]
 8002572:	4013      	ands	r3, r2
 8002574:	613b      	str	r3, [r7, #16]
        if ((GPIO_Init->Mode & TRIGGER_RISING) != 0x00u)
 8002576:	683b      	ldr	r3, [r7, #0]
 8002578:	685b      	ldr	r3, [r3, #4]
 800257a:	f403 1380 	and.w	r3, r3, #1048576	; 0x100000
 800257e:	2b00      	cmp	r3, #0
 8002580:	d003      	beq.n	800258a <HAL_GPIO_Init+0x286>
        {
          temp |= iocurrent;
 8002582:	693a      	ldr	r2, [r7, #16]
 8002584:	68fb      	ldr	r3, [r7, #12]
 8002586:	4313      	orrs	r3, r2
 8002588:	613b      	str	r3, [r7, #16]
        }
        EXTI->RTSR1 = temp;
 800258a:	4a32      	ldr	r2, [pc, #200]	; (8002654 <HAL_GPIO_Init+0x350>)
 800258c:	693b      	ldr	r3, [r7, #16]
 800258e:	6093      	str	r3, [r2, #8]

        temp = EXTI->FTSR1;
 8002590:	4b30      	ldr	r3, [pc, #192]	; (8002654 <HAL_GPIO_Init+0x350>)
 8002592:	68db      	ldr	r3, [r3, #12]
 8002594:	613b      	str	r3, [r7, #16]
        temp &= ~(iocurrent);
 8002596:	68fb      	ldr	r3, [r7, #12]
 8002598:	43db      	mvns	r3, r3
 800259a:	693a      	ldr	r2, [r7, #16]
 800259c:	4013      	ands	r3, r2
 800259e:	613b      	str	r3, [r7, #16]
        if ((GPIO_Init->Mode & TRIGGER_FALLING) != 0x00u)
 80025a0:	683b      	ldr	r3, [r7, #0]
 80025a2:	685b      	ldr	r3, [r3, #4]
 80025a4:	f403 1300 	and.w	r3, r3, #2097152	; 0x200000
 80025a8:	2b00      	cmp	r3, #0
 80025aa:	d003      	beq.n	80025b4 <HAL_GPIO_Init+0x2b0>
        {
          temp |= iocurrent;
 80025ac:	693a      	ldr	r2, [r7, #16]
 80025ae:	68fb      	ldr	r3, [r7, #12]
 80025b0:	4313      	orrs	r3, r2
 80025b2:	613b      	str	r3, [r7, #16]
        }
        EXTI->FTSR1 = temp;
 80025b4:	4a27      	ldr	r2, [pc, #156]	; (8002654 <HAL_GPIO_Init+0x350>)
 80025b6:	693b      	ldr	r3, [r7, #16]
 80025b8:	60d3      	str	r3, [r2, #12]

        /* Clear EXTI line configuration */
        temp = EXTI->EMR1;
 80025ba:	4b26      	ldr	r3, [pc, #152]	; (8002654 <HAL_GPIO_Init+0x350>)
 80025bc:	685b      	ldr	r3, [r3, #4]
 80025be:	613b      	str	r3, [r7, #16]
        temp &= ~(iocurrent);
 80025c0:	68fb      	ldr	r3, [r7, #12]
 80025c2:	43db      	mvns	r3, r3
 80025c4:	693a      	ldr	r2, [r7, #16]
 80025c6:	4013      	ands	r3, r2
 80025c8:	613b      	str	r3, [r7, #16]
        if ((GPIO_Init->Mode & EXTI_EVT) != 0x00u)
 80025ca:	683b      	ldr	r3, [r7, #0]
 80025cc:	685b      	ldr	r3, [r3, #4]
 80025ce:	f403 3300 	and.w	r3, r3, #131072	; 0x20000
 80025d2:	2b00      	cmp	r3, #0
 80025d4:	d003      	beq.n	80025de <HAL_GPIO_Init+0x2da>
        {
          temp |= iocurrent;
 80025d6:	693a      	ldr	r2, [r7, #16]
 80025d8:	68fb      	ldr	r3, [r7, #12]
 80025da:	4313      	orrs	r3, r2
 80025dc:	613b      	str	r3, [r7, #16]
        }
        EXTI->EMR1 = temp;
 80025de:	4a1d      	ldr	r2, [pc, #116]	; (8002654 <HAL_GPIO_Init+0x350>)
 80025e0:	693b      	ldr	r3, [r7, #16]
 80025e2:	6053      	str	r3, [r2, #4]

        temp = EXTI->IMR1;
 80025e4:	4b1b      	ldr	r3, [pc, #108]	; (8002654 <HAL_GPIO_Init+0x350>)
 80025e6:	681b      	ldr	r3, [r3, #0]
 80025e8:	613b      	str	r3, [r7, #16]
        temp &= ~(iocurrent);
 80025ea:	68fb      	ldr	r3, [r7, #12]
 80025ec:	43db      	mvns	r3, r3
 80025ee:	693a      	ldr	r2, [r7, #16]
 80025f0:	4013      	ands	r3, r2
 80025f2:	613b      	str	r3, [r7, #16]
        if ((GPIO_Init->Mode & EXTI_IT) != 0x00u)
 80025f4:	683b      	ldr	r3, [r7, #0]
 80025f6:	685b      	ldr	r3, [r3, #4]
 80025f8:	f403 3380 	and.w	r3, r3, #65536	; 0x10000
 80025fc:	2b00      	cmp	r3, #0
 80025fe:	d003      	beq.n	8002608 <HAL_GPIO_Init+0x304>
        {
          temp |= iocurrent;
 8002600:	693a      	ldr	r2, [r7, #16]
 8002602:	68fb      	ldr	r3, [r7, #12]
 8002604:	4313      	orrs	r3, r2
 8002606:	613b      	str	r3, [r7, #16]
        }
        EXTI->IMR1 = temp;
 8002608:	4a12      	ldr	r2, [pc, #72]	; (8002654 <HAL_GPIO_Init+0x350>)
 800260a:	693b      	ldr	r3, [r7, #16]
 800260c:	6013      	str	r3, [r2, #0]
      }
    }

    position++;
 800260e:	697b      	ldr	r3, [r7, #20]
 8002610:	3301      	adds	r3, #1
 8002612:	617b      	str	r3, [r7, #20]
  while (((GPIO_Init->Pin) >> position) != 0x00u)
 8002614:	683b      	ldr	r3, [r7, #0]
 8002616:	681a      	ldr	r2, [r3, #0]
 8002618:	697b      	ldr	r3, [r7, #20]
 800261a:	fa22 f303 	lsr.w	r3, r2, r3
 800261e:	2b00      	cmp	r3, #0
 8002620:	f47f ae78 	bne.w	8002314 <HAL_GPIO_Init+0x10>
  }
}
 8002624:	bf00      	nop
 8002626:	bf00      	nop
 8002628:	371c      	adds	r7, #28
 800262a:	46bd      	mov	sp, r7
 800262c:	f85d 7b04 	ldr.w	r7, [sp], #4
 8002630:	4770      	bx	lr
 8002632:	bf00      	nop
 8002634:	40021000 	.word	0x40021000
 8002638:	40010000 	.word	0x40010000
 800263c:	48000400 	.word	0x48000400
 8002640:	48000800 	.word	0x48000800
 8002644:	48000c00 	.word	0x48000c00
 8002648:	48001000 	.word	0x48001000
 800264c:	48001400 	.word	0x48001400
 8002650:	48001800 	.word	0x48001800
 8002654:	40010400 	.word	0x40010400

08002658 <HAL_GPIO_ReadPin>:
  * @param  GPIO_Pin specifies the port bit to read.
  *         This parameter can be any combination of 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)
{
 8002658:	b480      	push	{r7}
 800265a:	b085      	sub	sp, #20
 800265c:	af00      	add	r7, sp, #0
 800265e:	6078      	str	r0, [r7, #4]
 8002660:	460b      	mov	r3, r1
 8002662:	807b      	strh	r3, [r7, #2]
  GPIO_PinState bitstatus;

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

  if ((GPIOx->IDR & GPIO_Pin) != 0x00u)
 8002664:	687b      	ldr	r3, [r7, #4]
 8002666:	691a      	ldr	r2, [r3, #16]
 8002668:	887b      	ldrh	r3, [r7, #2]
 800266a:	4013      	ands	r3, r2
 800266c:	2b00      	cmp	r3, #0
 800266e:	d002      	beq.n	8002676 <HAL_GPIO_ReadPin+0x1e>
  {
    bitstatus = GPIO_PIN_SET;
 8002670:	2301      	movs	r3, #1
 8002672:	73fb      	strb	r3, [r7, #15]
 8002674:	e001      	b.n	800267a <HAL_GPIO_ReadPin+0x22>
  }
  else
  {
    bitstatus = GPIO_PIN_RESET;
 8002676:	2300      	movs	r3, #0
 8002678:	73fb      	strb	r3, [r7, #15]
  }
  return bitstatus;
 800267a:	7bfb      	ldrb	r3, [r7, #15]
}
 800267c:	4618      	mov	r0, r3
 800267e:	3714      	adds	r7, #20
 8002680:	46bd      	mov	sp, r7
 8002682:	f85d 7b04 	ldr.w	r7, [sp], #4
 8002686:	4770      	bx	lr

08002688 <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)
{
 8002688:	b480      	push	{r7}
 800268a:	b083      	sub	sp, #12
 800268c:	af00      	add	r7, sp, #0
 800268e:	6078      	str	r0, [r7, #4]
 8002690:	460b      	mov	r3, r1
 8002692:	807b      	strh	r3, [r7, #2]
 8002694:	4613      	mov	r3, r2
 8002696:	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)
 8002698:	787b      	ldrb	r3, [r7, #1]
 800269a:	2b00      	cmp	r3, #0
 800269c:	d003      	beq.n	80026a6 <HAL_GPIO_WritePin+0x1e>
  {
    GPIOx->BSRR = (uint32_t)GPIO_Pin;
 800269e:	887a      	ldrh	r2, [r7, #2]
 80026a0:	687b      	ldr	r3, [r7, #4]
 80026a2:	619a      	str	r2, [r3, #24]
  }
  else
  {
    GPIOx->BRR = (uint32_t)GPIO_Pin;
  }
}
 80026a4:	e002      	b.n	80026ac <HAL_GPIO_WritePin+0x24>
    GPIOx->BRR = (uint32_t)GPIO_Pin;
 80026a6:	887a      	ldrh	r2, [r7, #2]
 80026a8:	687b      	ldr	r3, [r7, #4]
 80026aa:	629a      	str	r2, [r3, #40]	; 0x28
}
 80026ac:	bf00      	nop
 80026ae:	370c      	adds	r7, #12
 80026b0:	46bd      	mov	sp, r7
 80026b2:	f85d 7b04 	ldr.w	r7, [sp], #4
 80026b6:	4770      	bx	lr

080026b8 <HAL_I2C_Init>:
  * @param  hi2c Pointer to a I2C_HandleTypeDef structure that contains
  *                the configuration information for the specified I2C.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_I2C_Init(I2C_HandleTypeDef *hi2c)
{
 80026b8:	b580      	push	{r7, lr}
 80026ba:	b082      	sub	sp, #8
 80026bc:	af00      	add	r7, sp, #0
 80026be:	6078      	str	r0, [r7, #4]
  /* Check the I2C handle allocation */
  if (hi2c == NULL)
 80026c0:	687b      	ldr	r3, [r7, #4]
 80026c2:	2b00      	cmp	r3, #0
 80026c4:	d101      	bne.n	80026ca <HAL_I2C_Init+0x12>
  {
    return HAL_ERROR;
 80026c6:	2301      	movs	r3, #1
 80026c8:	e081      	b.n	80027ce <HAL_I2C_Init+0x116>
  assert_param(IS_I2C_OWN_ADDRESS2(hi2c->Init.OwnAddress2));
  assert_param(IS_I2C_OWN_ADDRESS2_MASK(hi2c->Init.OwnAddress2Masks));
  assert_param(IS_I2C_GENERAL_CALL(hi2c->Init.GeneralCallMode));
  assert_param(IS_I2C_NO_STRETCH(hi2c->Init.NoStretchMode));

  if (hi2c->State == HAL_I2C_STATE_RESET)
 80026ca:	687b      	ldr	r3, [r7, #4]
 80026cc:	f893 3041 	ldrb.w	r3, [r3, #65]	; 0x41
 80026d0:	b2db      	uxtb	r3, r3
 80026d2:	2b00      	cmp	r3, #0
 80026d4:	d106      	bne.n	80026e4 <HAL_I2C_Init+0x2c>
  {
    /* Allocate lock resource and initialize it */
    hi2c->Lock = HAL_UNLOCKED;
 80026d6:	687b      	ldr	r3, [r7, #4]
 80026d8:	2200      	movs	r2, #0
 80026da:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

    /* Init the low level hardware : GPIO, CLOCK, CORTEX...etc */
    hi2c->MspInitCallback(hi2c);
#else
    /* Init the low level hardware : GPIO, CLOCK, CORTEX...etc */
    HAL_I2C_MspInit(hi2c);
 80026de:	6878      	ldr	r0, [r7, #4]
 80026e0:	f7fe fdaa 	bl	8001238 <HAL_I2C_MspInit>
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
  }

  hi2c->State = HAL_I2C_STATE_BUSY;
 80026e4:	687b      	ldr	r3, [r7, #4]
 80026e6:	2224      	movs	r2, #36	; 0x24
 80026e8:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41

  /* Disable the selected I2C peripheral */
  __HAL_I2C_DISABLE(hi2c);
 80026ec:	687b      	ldr	r3, [r7, #4]
 80026ee:	681b      	ldr	r3, [r3, #0]
 80026f0:	681a      	ldr	r2, [r3, #0]
 80026f2:	687b      	ldr	r3, [r7, #4]
 80026f4:	681b      	ldr	r3, [r3, #0]
 80026f6:	f022 0201 	bic.w	r2, r2, #1
 80026fa:	601a      	str	r2, [r3, #0]

  /*---------------------------- I2Cx TIMINGR Configuration ------------------*/
  /* Configure I2Cx: Frequency range */
  hi2c->Instance->TIMINGR = hi2c->Init.Timing & TIMING_CLEAR_MASK;
 80026fc:	687b      	ldr	r3, [r7, #4]
 80026fe:	685a      	ldr	r2, [r3, #4]
 8002700:	687b      	ldr	r3, [r7, #4]
 8002702:	681b      	ldr	r3, [r3, #0]
 8002704:	f022 6270 	bic.w	r2, r2, #251658240	; 0xf000000
 8002708:	611a      	str	r2, [r3, #16]

  /*---------------------------- I2Cx OAR1 Configuration ---------------------*/
  /* Disable Own Address1 before set the Own Address1 configuration */
  hi2c->Instance->OAR1 &= ~I2C_OAR1_OA1EN;
 800270a:	687b      	ldr	r3, [r7, #4]
 800270c:	681b      	ldr	r3, [r3, #0]
 800270e:	689a      	ldr	r2, [r3, #8]
 8002710:	687b      	ldr	r3, [r7, #4]
 8002712:	681b      	ldr	r3, [r3, #0]
 8002714:	f422 4200 	bic.w	r2, r2, #32768	; 0x8000
 8002718:	609a      	str	r2, [r3, #8]

  /* Configure I2Cx: Own Address1 and ack own address1 mode */
  if (hi2c->Init.AddressingMode == I2C_ADDRESSINGMODE_7BIT)
 800271a:	687b      	ldr	r3, [r7, #4]
 800271c:	68db      	ldr	r3, [r3, #12]
 800271e:	2b01      	cmp	r3, #1
 8002720:	d107      	bne.n	8002732 <HAL_I2C_Init+0x7a>
  {
    hi2c->Instance->OAR1 = (I2C_OAR1_OA1EN | hi2c->Init.OwnAddress1);
 8002722:	687b      	ldr	r3, [r7, #4]
 8002724:	689a      	ldr	r2, [r3, #8]
 8002726:	687b      	ldr	r3, [r7, #4]
 8002728:	681b      	ldr	r3, [r3, #0]
 800272a:	f442 4200 	orr.w	r2, r2, #32768	; 0x8000
 800272e:	609a      	str	r2, [r3, #8]
 8002730:	e006      	b.n	8002740 <HAL_I2C_Init+0x88>
  }
  else /* I2C_ADDRESSINGMODE_10BIT */
  {
    hi2c->Instance->OAR1 = (I2C_OAR1_OA1EN | I2C_OAR1_OA1MODE | hi2c->Init.OwnAddress1);
 8002732:	687b      	ldr	r3, [r7, #4]
 8002734:	689a      	ldr	r2, [r3, #8]
 8002736:	687b      	ldr	r3, [r7, #4]
 8002738:	681b      	ldr	r3, [r3, #0]
 800273a:	f442 4204 	orr.w	r2, r2, #33792	; 0x8400
 800273e:	609a      	str	r2, [r3, #8]
  }

  /*---------------------------- I2Cx CR2 Configuration ----------------------*/
  /* Configure I2Cx: Addressing Master mode */
  if (hi2c->Init.AddressingMode == I2C_ADDRESSINGMODE_10BIT)
 8002740:	687b      	ldr	r3, [r7, #4]
 8002742:	68db      	ldr	r3, [r3, #12]
 8002744:	2b02      	cmp	r3, #2
 8002746:	d104      	bne.n	8002752 <HAL_I2C_Init+0x9a>
  {
    hi2c->Instance->CR2 = (I2C_CR2_ADD10);
 8002748:	687b      	ldr	r3, [r7, #4]
 800274a:	681b      	ldr	r3, [r3, #0]
 800274c:	f44f 6200 	mov.w	r2, #2048	; 0x800
 8002750:	605a      	str	r2, [r3, #4]
  }
  /* Enable the AUTOEND by default, and enable NACK (should be disable only during Slave process */
  hi2c->Instance->CR2 |= (I2C_CR2_AUTOEND | I2C_CR2_NACK);
 8002752:	687b      	ldr	r3, [r7, #4]
 8002754:	681b      	ldr	r3, [r3, #0]
 8002756:	685b      	ldr	r3, [r3, #4]
 8002758:	687a      	ldr	r2, [r7, #4]
 800275a:	6812      	ldr	r2, [r2, #0]
 800275c:	f043 7300 	orr.w	r3, r3, #33554432	; 0x2000000
 8002760:	f443 4300 	orr.w	r3, r3, #32768	; 0x8000
 8002764:	6053      	str	r3, [r2, #4]

  /*---------------------------- I2Cx OAR2 Configuration ---------------------*/
  /* Disable Own Address2 before set the Own Address2 configuration */
  hi2c->Instance->OAR2 &= ~I2C_DUALADDRESS_ENABLE;
 8002766:	687b      	ldr	r3, [r7, #4]
 8002768:	681b      	ldr	r3, [r3, #0]
 800276a:	68da      	ldr	r2, [r3, #12]
 800276c:	687b      	ldr	r3, [r7, #4]
 800276e:	681b      	ldr	r3, [r3, #0]
 8002770:	f422 4200 	bic.w	r2, r2, #32768	; 0x8000
 8002774:	60da      	str	r2, [r3, #12]

  /* Configure I2Cx: Dual mode and Own Address2 */
  hi2c->Instance->OAR2 = (hi2c->Init.DualAddressMode | hi2c->Init.OwnAddress2 | \
 8002776:	687b      	ldr	r3, [r7, #4]
 8002778:	691a      	ldr	r2, [r3, #16]
 800277a:	687b      	ldr	r3, [r7, #4]
 800277c:	695b      	ldr	r3, [r3, #20]
 800277e:	ea42 0103 	orr.w	r1, r2, r3
                          (hi2c->Init.OwnAddress2Masks << 8));
 8002782:	687b      	ldr	r3, [r7, #4]
 8002784:	699b      	ldr	r3, [r3, #24]
 8002786:	021a      	lsls	r2, r3, #8
  hi2c->Instance->OAR2 = (hi2c->Init.DualAddressMode | hi2c->Init.OwnAddress2 | \
 8002788:	687b      	ldr	r3, [r7, #4]
 800278a:	681b      	ldr	r3, [r3, #0]
 800278c:	430a      	orrs	r2, r1
 800278e:	60da      	str	r2, [r3, #12]

  /*---------------------------- I2Cx CR1 Configuration ----------------------*/
  /* Configure I2Cx: Generalcall and NoStretch mode */
  hi2c->Instance->CR1 = (hi2c->Init.GeneralCallMode | hi2c->Init.NoStretchMode);
 8002790:	687b      	ldr	r3, [r7, #4]
 8002792:	69d9      	ldr	r1, [r3, #28]
 8002794:	687b      	ldr	r3, [r7, #4]
 8002796:	6a1a      	ldr	r2, [r3, #32]
 8002798:	687b      	ldr	r3, [r7, #4]
 800279a:	681b      	ldr	r3, [r3, #0]
 800279c:	430a      	orrs	r2, r1
 800279e:	601a      	str	r2, [r3, #0]

  /* Enable the selected I2C peripheral */
  __HAL_I2C_ENABLE(hi2c);
 80027a0:	687b      	ldr	r3, [r7, #4]
 80027a2:	681b      	ldr	r3, [r3, #0]
 80027a4:	681a      	ldr	r2, [r3, #0]
 80027a6:	687b      	ldr	r3, [r7, #4]
 80027a8:	681b      	ldr	r3, [r3, #0]
 80027aa:	f042 0201 	orr.w	r2, r2, #1
 80027ae:	601a      	str	r2, [r3, #0]

  hi2c->ErrorCode = HAL_I2C_ERROR_NONE;
 80027b0:	687b      	ldr	r3, [r7, #4]
 80027b2:	2200      	movs	r2, #0
 80027b4:	645a      	str	r2, [r3, #68]	; 0x44
  hi2c->State = HAL_I2C_STATE_READY;
 80027b6:	687b      	ldr	r3, [r7, #4]
 80027b8:	2220      	movs	r2, #32
 80027ba:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
  hi2c->PreviousState = I2C_STATE_NONE;
 80027be:	687b      	ldr	r3, [r7, #4]
 80027c0:	2200      	movs	r2, #0
 80027c2:	631a      	str	r2, [r3, #48]	; 0x30
  hi2c->Mode = HAL_I2C_MODE_NONE;
 80027c4:	687b      	ldr	r3, [r7, #4]
 80027c6:	2200      	movs	r2, #0
 80027c8:	f883 2042 	strb.w	r2, [r3, #66]	; 0x42

  return HAL_OK;
 80027cc:	2300      	movs	r3, #0
}
 80027ce:	4618      	mov	r0, r3
 80027d0:	3708      	adds	r7, #8
 80027d2:	46bd      	mov	sp, r7
 80027d4:	bd80      	pop	{r7, pc}
	...

080027d8 <HAL_I2C_Master_Transmit>:
  * @param  Timeout Timeout duration
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_I2C_Master_Transmit(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData,
                                          uint16_t Size, uint32_t Timeout)
{
 80027d8:	b580      	push	{r7, lr}
 80027da:	b088      	sub	sp, #32
 80027dc:	af02      	add	r7, sp, #8
 80027de:	60f8      	str	r0, [r7, #12]
 80027e0:	607a      	str	r2, [r7, #4]
 80027e2:	461a      	mov	r2, r3
 80027e4:	460b      	mov	r3, r1
 80027e6:	817b      	strh	r3, [r7, #10]
 80027e8:	4613      	mov	r3, r2
 80027ea:	813b      	strh	r3, [r7, #8]
  uint32_t tickstart;

  if (hi2c->State == HAL_I2C_STATE_READY)
 80027ec:	68fb      	ldr	r3, [r7, #12]
 80027ee:	f893 3041 	ldrb.w	r3, [r3, #65]	; 0x41
 80027f2:	b2db      	uxtb	r3, r3
 80027f4:	2b20      	cmp	r3, #32
 80027f6:	f040 80da 	bne.w	80029ae <HAL_I2C_Master_Transmit+0x1d6>
  {
    /* Process Locked */
    __HAL_LOCK(hi2c);
 80027fa:	68fb      	ldr	r3, [r7, #12]
 80027fc:	f893 3040 	ldrb.w	r3, [r3, #64]	; 0x40
 8002800:	2b01      	cmp	r3, #1
 8002802:	d101      	bne.n	8002808 <HAL_I2C_Master_Transmit+0x30>
 8002804:	2302      	movs	r3, #2
 8002806:	e0d3      	b.n	80029b0 <HAL_I2C_Master_Transmit+0x1d8>
 8002808:	68fb      	ldr	r3, [r7, #12]
 800280a:	2201      	movs	r2, #1
 800280c:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

    /* Init tickstart for timeout management*/
    tickstart = HAL_GetTick();
 8002810:	f7ff fbe8 	bl	8001fe4 <HAL_GetTick>
 8002814:	6178      	str	r0, [r7, #20]

    if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_BUSY, SET, I2C_TIMEOUT_BUSY, tickstart) != HAL_OK)
 8002816:	697b      	ldr	r3, [r7, #20]
 8002818:	9300      	str	r3, [sp, #0]
 800281a:	2319      	movs	r3, #25
 800281c:	2201      	movs	r2, #1
 800281e:	f44f 4100 	mov.w	r1, #32768	; 0x8000
 8002822:	68f8      	ldr	r0, [r7, #12]
 8002824:	f000 ff0d 	bl	8003642 <I2C_WaitOnFlagUntilTimeout>
 8002828:	4603      	mov	r3, r0
 800282a:	2b00      	cmp	r3, #0
 800282c:	d001      	beq.n	8002832 <HAL_I2C_Master_Transmit+0x5a>
    {
      return HAL_ERROR;
 800282e:	2301      	movs	r3, #1
 8002830:	e0be      	b.n	80029b0 <HAL_I2C_Master_Transmit+0x1d8>
    }

    hi2c->State     = HAL_I2C_STATE_BUSY_TX;
 8002832:	68fb      	ldr	r3, [r7, #12]
 8002834:	2221      	movs	r2, #33	; 0x21
 8002836:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
    hi2c->Mode      = HAL_I2C_MODE_MASTER;
 800283a:	68fb      	ldr	r3, [r7, #12]
 800283c:	2210      	movs	r2, #16
 800283e:	f883 2042 	strb.w	r2, [r3, #66]	; 0x42
    hi2c->ErrorCode = HAL_I2C_ERROR_NONE;
 8002842:	68fb      	ldr	r3, [r7, #12]
 8002844:	2200      	movs	r2, #0
 8002846:	645a      	str	r2, [r3, #68]	; 0x44

    /* Prepare transfer parameters */
    hi2c->pBuffPtr  = pData;
 8002848:	68fb      	ldr	r3, [r7, #12]
 800284a:	687a      	ldr	r2, [r7, #4]
 800284c:	625a      	str	r2, [r3, #36]	; 0x24
    hi2c->XferCount = Size;
 800284e:	68fb      	ldr	r3, [r7, #12]
 8002850:	893a      	ldrh	r2, [r7, #8]
 8002852:	855a      	strh	r2, [r3, #42]	; 0x2a
    hi2c->XferISR   = NULL;
 8002854:	68fb      	ldr	r3, [r7, #12]
 8002856:	2200      	movs	r2, #0
 8002858:	635a      	str	r2, [r3, #52]	; 0x34

    /* Send Slave Address */
    /* Set NBYTES to write and reload if hi2c->XferCount > MAX_NBYTE_SIZE and generate RESTART */
    if (hi2c->XferCount > MAX_NBYTE_SIZE)
 800285a:	68fb      	ldr	r3, [r7, #12]
 800285c:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 800285e:	b29b      	uxth	r3, r3
 8002860:	2bff      	cmp	r3, #255	; 0xff
 8002862:	d90e      	bls.n	8002882 <HAL_I2C_Master_Transmit+0xaa>
    {
      hi2c->XferSize = MAX_NBYTE_SIZE;
 8002864:	68fb      	ldr	r3, [r7, #12]
 8002866:	22ff      	movs	r2, #255	; 0xff
 8002868:	851a      	strh	r2, [r3, #40]	; 0x28
      I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_RELOAD_MODE,
 800286a:	68fb      	ldr	r3, [r7, #12]
 800286c:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 800286e:	b2da      	uxtb	r2, r3
 8002870:	8979      	ldrh	r1, [r7, #10]
 8002872:	4b51      	ldr	r3, [pc, #324]	; (80029b8 <HAL_I2C_Master_Transmit+0x1e0>)
 8002874:	9300      	str	r3, [sp, #0]
 8002876:	f04f 7380 	mov.w	r3, #16777216	; 0x1000000
 800287a:	68f8      	ldr	r0, [r7, #12]
 800287c:	f001 f88a 	bl	8003994 <I2C_TransferConfig>
 8002880:	e06c      	b.n	800295c <HAL_I2C_Master_Transmit+0x184>
                         I2C_GENERATE_START_WRITE);
    }
    else
    {
      hi2c->XferSize = hi2c->XferCount;
 8002882:	68fb      	ldr	r3, [r7, #12]
 8002884:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8002886:	b29a      	uxth	r2, r3
 8002888:	68fb      	ldr	r3, [r7, #12]
 800288a:	851a      	strh	r2, [r3, #40]	; 0x28
      I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_AUTOEND_MODE,
 800288c:	68fb      	ldr	r3, [r7, #12]
 800288e:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8002890:	b2da      	uxtb	r2, r3
 8002892:	8979      	ldrh	r1, [r7, #10]
 8002894:	4b48      	ldr	r3, [pc, #288]	; (80029b8 <HAL_I2C_Master_Transmit+0x1e0>)
 8002896:	9300      	str	r3, [sp, #0]
 8002898:	f04f 7300 	mov.w	r3, #33554432	; 0x2000000
 800289c:	68f8      	ldr	r0, [r7, #12]
 800289e:	f001 f879 	bl	8003994 <I2C_TransferConfig>
                         I2C_GENERATE_START_WRITE);
    }

    while (hi2c->XferCount > 0U)
 80028a2:	e05b      	b.n	800295c <HAL_I2C_Master_Transmit+0x184>
    {
      /* Wait until TXIS flag is set */
      if (I2C_WaitOnTXISFlagUntilTimeout(hi2c, Timeout, tickstart) != HAL_OK)
 80028a4:	697a      	ldr	r2, [r7, #20]
 80028a6:	6a39      	ldr	r1, [r7, #32]
 80028a8:	68f8      	ldr	r0, [r7, #12]
 80028aa:	f000 ff0a 	bl	80036c2 <I2C_WaitOnTXISFlagUntilTimeout>
 80028ae:	4603      	mov	r3, r0
 80028b0:	2b00      	cmp	r3, #0
 80028b2:	d001      	beq.n	80028b8 <HAL_I2C_Master_Transmit+0xe0>
      {
        return HAL_ERROR;
 80028b4:	2301      	movs	r3, #1
 80028b6:	e07b      	b.n	80029b0 <HAL_I2C_Master_Transmit+0x1d8>
      }
      /* Write data to TXDR */
      hi2c->Instance->TXDR = *hi2c->pBuffPtr;
 80028b8:	68fb      	ldr	r3, [r7, #12]
 80028ba:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 80028bc:	781a      	ldrb	r2, [r3, #0]
 80028be:	68fb      	ldr	r3, [r7, #12]
 80028c0:	681b      	ldr	r3, [r3, #0]
 80028c2:	629a      	str	r2, [r3, #40]	; 0x28

      /* Increment Buffer pointer */
      hi2c->pBuffPtr++;
 80028c4:	68fb      	ldr	r3, [r7, #12]
 80028c6:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 80028c8:	1c5a      	adds	r2, r3, #1
 80028ca:	68fb      	ldr	r3, [r7, #12]
 80028cc:	625a      	str	r2, [r3, #36]	; 0x24

      hi2c->XferCount--;
 80028ce:	68fb      	ldr	r3, [r7, #12]
 80028d0:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 80028d2:	b29b      	uxth	r3, r3
 80028d4:	3b01      	subs	r3, #1
 80028d6:	b29a      	uxth	r2, r3
 80028d8:	68fb      	ldr	r3, [r7, #12]
 80028da:	855a      	strh	r2, [r3, #42]	; 0x2a
      hi2c->XferSize--;
 80028dc:	68fb      	ldr	r3, [r7, #12]
 80028de:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 80028e0:	3b01      	subs	r3, #1
 80028e2:	b29a      	uxth	r2, r3
 80028e4:	68fb      	ldr	r3, [r7, #12]
 80028e6:	851a      	strh	r2, [r3, #40]	; 0x28

      if ((hi2c->XferCount != 0U) && (hi2c->XferSize == 0U))
 80028e8:	68fb      	ldr	r3, [r7, #12]
 80028ea:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 80028ec:	b29b      	uxth	r3, r3
 80028ee:	2b00      	cmp	r3, #0
 80028f0:	d034      	beq.n	800295c <HAL_I2C_Master_Transmit+0x184>
 80028f2:	68fb      	ldr	r3, [r7, #12]
 80028f4:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 80028f6:	2b00      	cmp	r3, #0
 80028f8:	d130      	bne.n	800295c <HAL_I2C_Master_Transmit+0x184>
      {
        /* Wait until TCR flag is set */
        if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_TCR, RESET, Timeout, tickstart) != HAL_OK)
 80028fa:	697b      	ldr	r3, [r7, #20]
 80028fc:	9300      	str	r3, [sp, #0]
 80028fe:	6a3b      	ldr	r3, [r7, #32]
 8002900:	2200      	movs	r2, #0
 8002902:	2180      	movs	r1, #128	; 0x80
 8002904:	68f8      	ldr	r0, [r7, #12]
 8002906:	f000 fe9c 	bl	8003642 <I2C_WaitOnFlagUntilTimeout>
 800290a:	4603      	mov	r3, r0
 800290c:	2b00      	cmp	r3, #0
 800290e:	d001      	beq.n	8002914 <HAL_I2C_Master_Transmit+0x13c>
        {
          return HAL_ERROR;
 8002910:	2301      	movs	r3, #1
 8002912:	e04d      	b.n	80029b0 <HAL_I2C_Master_Transmit+0x1d8>
        }

        if (hi2c->XferCount > MAX_NBYTE_SIZE)
 8002914:	68fb      	ldr	r3, [r7, #12]
 8002916:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8002918:	b29b      	uxth	r3, r3
 800291a:	2bff      	cmp	r3, #255	; 0xff
 800291c:	d90e      	bls.n	800293c <HAL_I2C_Master_Transmit+0x164>
        {
          hi2c->XferSize = MAX_NBYTE_SIZE;
 800291e:	68fb      	ldr	r3, [r7, #12]
 8002920:	22ff      	movs	r2, #255	; 0xff
 8002922:	851a      	strh	r2, [r3, #40]	; 0x28
          I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_RELOAD_MODE,
 8002924:	68fb      	ldr	r3, [r7, #12]
 8002926:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8002928:	b2da      	uxtb	r2, r3
 800292a:	8979      	ldrh	r1, [r7, #10]
 800292c:	2300      	movs	r3, #0
 800292e:	9300      	str	r3, [sp, #0]
 8002930:	f04f 7380 	mov.w	r3, #16777216	; 0x1000000
 8002934:	68f8      	ldr	r0, [r7, #12]
 8002936:	f001 f82d 	bl	8003994 <I2C_TransferConfig>
 800293a:	e00f      	b.n	800295c <HAL_I2C_Master_Transmit+0x184>
                             I2C_NO_STARTSTOP);
        }
        else
        {
          hi2c->XferSize = hi2c->XferCount;
 800293c:	68fb      	ldr	r3, [r7, #12]
 800293e:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8002940:	b29a      	uxth	r2, r3
 8002942:	68fb      	ldr	r3, [r7, #12]
 8002944:	851a      	strh	r2, [r3, #40]	; 0x28
          I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, I2C_AUTOEND_MODE,
 8002946:	68fb      	ldr	r3, [r7, #12]
 8002948:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 800294a:	b2da      	uxtb	r2, r3
 800294c:	8979      	ldrh	r1, [r7, #10]
 800294e:	2300      	movs	r3, #0
 8002950:	9300      	str	r3, [sp, #0]
 8002952:	f04f 7300 	mov.w	r3, #33554432	; 0x2000000
 8002956:	68f8      	ldr	r0, [r7, #12]
 8002958:	f001 f81c 	bl	8003994 <I2C_TransferConfig>
    while (hi2c->XferCount > 0U)
 800295c:	68fb      	ldr	r3, [r7, #12]
 800295e:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8002960:	b29b      	uxth	r3, r3
 8002962:	2b00      	cmp	r3, #0
 8002964:	d19e      	bne.n	80028a4 <HAL_I2C_Master_Transmit+0xcc>
      }
    }

    /* No need to Check TC flag, with AUTOEND mode the stop is automatically generated */
    /* Wait until STOPF flag is set */
    if (I2C_WaitOnSTOPFlagUntilTimeout(hi2c, Timeout, tickstart) != HAL_OK)
 8002966:	697a      	ldr	r2, [r7, #20]
 8002968:	6a39      	ldr	r1, [r7, #32]
 800296a:	68f8      	ldr	r0, [r7, #12]
 800296c:	f000 fee9 	bl	8003742 <I2C_WaitOnSTOPFlagUntilTimeout>
 8002970:	4603      	mov	r3, r0
 8002972:	2b00      	cmp	r3, #0
 8002974:	d001      	beq.n	800297a <HAL_I2C_Master_Transmit+0x1a2>
    {
      return HAL_ERROR;
 8002976:	2301      	movs	r3, #1
 8002978:	e01a      	b.n	80029b0 <HAL_I2C_Master_Transmit+0x1d8>
    }

    /* Clear STOP Flag */
    __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF);
 800297a:	68fb      	ldr	r3, [r7, #12]
 800297c:	681b      	ldr	r3, [r3, #0]
 800297e:	2220      	movs	r2, #32
 8002980:	61da      	str	r2, [r3, #28]

    /* Clear Configuration Register 2 */
    I2C_RESET_CR2(hi2c);
 8002982:	68fb      	ldr	r3, [r7, #12]
 8002984:	681b      	ldr	r3, [r3, #0]
 8002986:	6859      	ldr	r1, [r3, #4]
 8002988:	68fb      	ldr	r3, [r7, #12]
 800298a:	681a      	ldr	r2, [r3, #0]
 800298c:	4b0b      	ldr	r3, [pc, #44]	; (80029bc <HAL_I2C_Master_Transmit+0x1e4>)
 800298e:	400b      	ands	r3, r1
 8002990:	6053      	str	r3, [r2, #4]

    hi2c->State = HAL_I2C_STATE_READY;
 8002992:	68fb      	ldr	r3, [r7, #12]
 8002994:	2220      	movs	r2, #32
 8002996:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
    hi2c->Mode  = HAL_I2C_MODE_NONE;
 800299a:	68fb      	ldr	r3, [r7, #12]
 800299c:	2200      	movs	r2, #0
 800299e:	f883 2042 	strb.w	r2, [r3, #66]	; 0x42

    /* Process Unlocked */
    __HAL_UNLOCK(hi2c);
 80029a2:	68fb      	ldr	r3, [r7, #12]
 80029a4:	2200      	movs	r2, #0
 80029a6:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

    return HAL_OK;
 80029aa:	2300      	movs	r3, #0
 80029ac:	e000      	b.n	80029b0 <HAL_I2C_Master_Transmit+0x1d8>
  }
  else
  {
    return HAL_BUSY;
 80029ae:	2302      	movs	r3, #2
  }
}
 80029b0:	4618      	mov	r0, r3
 80029b2:	3718      	adds	r7, #24
 80029b4:	46bd      	mov	sp, r7
 80029b6:	bd80      	pop	{r7, pc}
 80029b8:	80002000 	.word	0x80002000
 80029bc:	fe00e800 	.word	0xfe00e800

080029c0 <HAL_I2C_IsDeviceReady>:
  * @param  Timeout Timeout duration
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_I2C_IsDeviceReady(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint32_t Trials,
                                        uint32_t Timeout)
{
 80029c0:	b580      	push	{r7, lr}
 80029c2:	b08a      	sub	sp, #40	; 0x28
 80029c4:	af02      	add	r7, sp, #8
 80029c6:	60f8      	str	r0, [r7, #12]
 80029c8:	607a      	str	r2, [r7, #4]
 80029ca:	603b      	str	r3, [r7, #0]
 80029cc:	460b      	mov	r3, r1
 80029ce:	817b      	strh	r3, [r7, #10]
  uint32_t tickstart;

  __IO uint32_t I2C_Trials = 0UL;
 80029d0:	2300      	movs	r3, #0
 80029d2:	617b      	str	r3, [r7, #20]

  FlagStatus tmp1;
  FlagStatus tmp2;

  if (hi2c->State == HAL_I2C_STATE_READY)
 80029d4:	68fb      	ldr	r3, [r7, #12]
 80029d6:	f893 3041 	ldrb.w	r3, [r3, #65]	; 0x41
 80029da:	b2db      	uxtb	r3, r3
 80029dc:	2b20      	cmp	r3, #32
 80029de:	f040 80f1 	bne.w	8002bc4 <HAL_I2C_IsDeviceReady+0x204>
  {
    if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_BUSY) == SET)
 80029e2:	68fb      	ldr	r3, [r7, #12]
 80029e4:	681b      	ldr	r3, [r3, #0]
 80029e6:	699b      	ldr	r3, [r3, #24]
 80029e8:	f403 4300 	and.w	r3, r3, #32768	; 0x8000
 80029ec:	f5b3 4f00 	cmp.w	r3, #32768	; 0x8000
 80029f0:	d101      	bne.n	80029f6 <HAL_I2C_IsDeviceReady+0x36>
    {
      return HAL_BUSY;
 80029f2:	2302      	movs	r3, #2
 80029f4:	e0e7      	b.n	8002bc6 <HAL_I2C_IsDeviceReady+0x206>
    }

    /* Process Locked */
    __HAL_LOCK(hi2c);
 80029f6:	68fb      	ldr	r3, [r7, #12]
 80029f8:	f893 3040 	ldrb.w	r3, [r3, #64]	; 0x40
 80029fc:	2b01      	cmp	r3, #1
 80029fe:	d101      	bne.n	8002a04 <HAL_I2C_IsDeviceReady+0x44>
 8002a00:	2302      	movs	r3, #2
 8002a02:	e0e0      	b.n	8002bc6 <HAL_I2C_IsDeviceReady+0x206>
 8002a04:	68fb      	ldr	r3, [r7, #12]
 8002a06:	2201      	movs	r2, #1
 8002a08:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

    hi2c->State = HAL_I2C_STATE_BUSY;
 8002a0c:	68fb      	ldr	r3, [r7, #12]
 8002a0e:	2224      	movs	r2, #36	; 0x24
 8002a10:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
    hi2c->ErrorCode = HAL_I2C_ERROR_NONE;
 8002a14:	68fb      	ldr	r3, [r7, #12]
 8002a16:	2200      	movs	r2, #0
 8002a18:	645a      	str	r2, [r3, #68]	; 0x44

    do
    {
      /* Generate Start */
      hi2c->Instance->CR2 = I2C_GENERATE_START(hi2c->Init.AddressingMode, DevAddress);
 8002a1a:	68fb      	ldr	r3, [r7, #12]
 8002a1c:	68db      	ldr	r3, [r3, #12]
 8002a1e:	2b01      	cmp	r3, #1
 8002a20:	d107      	bne.n	8002a32 <HAL_I2C_IsDeviceReady+0x72>
 8002a22:	897b      	ldrh	r3, [r7, #10]
 8002a24:	f3c3 0309 	ubfx	r3, r3, #0, #10
 8002a28:	f043 7300 	orr.w	r3, r3, #33554432	; 0x2000000
 8002a2c:	f443 5300 	orr.w	r3, r3, #8192	; 0x2000
 8002a30:	e004      	b.n	8002a3c <HAL_I2C_IsDeviceReady+0x7c>
 8002a32:	897b      	ldrh	r3, [r7, #10]
 8002a34:	f3c3 0309 	ubfx	r3, r3, #0, #10
 8002a38:	f443 5320 	orr.w	r3, r3, #10240	; 0x2800
 8002a3c:	68fa      	ldr	r2, [r7, #12]
 8002a3e:	6812      	ldr	r2, [r2, #0]
 8002a40:	6053      	str	r3, [r2, #4]

      /* No need to Check TC flag, with AUTOEND mode the stop is automatically generated */
      /* Wait until STOPF flag is set or a NACK flag is set*/
      tickstart = HAL_GetTick();
 8002a42:	f7ff facf 	bl	8001fe4 <HAL_GetTick>
 8002a46:	61b8      	str	r0, [r7, #24]

      tmp1 = __HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_STOPF);
 8002a48:	68fb      	ldr	r3, [r7, #12]
 8002a4a:	681b      	ldr	r3, [r3, #0]
 8002a4c:	699b      	ldr	r3, [r3, #24]
 8002a4e:	f003 0320 	and.w	r3, r3, #32
 8002a52:	2b20      	cmp	r3, #32
 8002a54:	bf0c      	ite	eq
 8002a56:	2301      	moveq	r3, #1
 8002a58:	2300      	movne	r3, #0
 8002a5a:	b2db      	uxtb	r3, r3
 8002a5c:	77fb      	strb	r3, [r7, #31]
      tmp2 = __HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_AF);
 8002a5e:	68fb      	ldr	r3, [r7, #12]
 8002a60:	681b      	ldr	r3, [r3, #0]
 8002a62:	699b      	ldr	r3, [r3, #24]
 8002a64:	f003 0310 	and.w	r3, r3, #16
 8002a68:	2b10      	cmp	r3, #16
 8002a6a:	bf0c      	ite	eq
 8002a6c:	2301      	moveq	r3, #1
 8002a6e:	2300      	movne	r3, #0
 8002a70:	b2db      	uxtb	r3, r3
 8002a72:	77bb      	strb	r3, [r7, #30]

      while ((tmp1 == RESET) && (tmp2 == RESET))
 8002a74:	e034      	b.n	8002ae0 <HAL_I2C_IsDeviceReady+0x120>
      {
        if (Timeout != HAL_MAX_DELAY)
 8002a76:	683b      	ldr	r3, [r7, #0]
 8002a78:	f1b3 3fff 	cmp.w	r3, #4294967295
 8002a7c:	d01a      	beq.n	8002ab4 <HAL_I2C_IsDeviceReady+0xf4>
        {
          if (((HAL_GetTick() - tickstart) > Timeout) || (Timeout == 0U))
 8002a7e:	f7ff fab1 	bl	8001fe4 <HAL_GetTick>
 8002a82:	4602      	mov	r2, r0
 8002a84:	69bb      	ldr	r3, [r7, #24]
 8002a86:	1ad3      	subs	r3, r2, r3
 8002a88:	683a      	ldr	r2, [r7, #0]
 8002a8a:	429a      	cmp	r2, r3
 8002a8c:	d302      	bcc.n	8002a94 <HAL_I2C_IsDeviceReady+0xd4>
 8002a8e:	683b      	ldr	r3, [r7, #0]
 8002a90:	2b00      	cmp	r3, #0
 8002a92:	d10f      	bne.n	8002ab4 <HAL_I2C_IsDeviceReady+0xf4>
          {
            /* Update I2C state */
            hi2c->State = HAL_I2C_STATE_READY;
 8002a94:	68fb      	ldr	r3, [r7, #12]
 8002a96:	2220      	movs	r2, #32
 8002a98:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41

            /* Update I2C error code */
            hi2c->ErrorCode |= HAL_I2C_ERROR_TIMEOUT;
 8002a9c:	68fb      	ldr	r3, [r7, #12]
 8002a9e:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8002aa0:	f043 0220 	orr.w	r2, r3, #32
 8002aa4:	68fb      	ldr	r3, [r7, #12]
 8002aa6:	645a      	str	r2, [r3, #68]	; 0x44

            /* Process Unlocked */
            __HAL_UNLOCK(hi2c);
 8002aa8:	68fb      	ldr	r3, [r7, #12]
 8002aaa:	2200      	movs	r2, #0
 8002aac:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

            return HAL_ERROR;
 8002ab0:	2301      	movs	r3, #1
 8002ab2:	e088      	b.n	8002bc6 <HAL_I2C_IsDeviceReady+0x206>
          }
        }

        tmp1 = __HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_STOPF);
 8002ab4:	68fb      	ldr	r3, [r7, #12]
 8002ab6:	681b      	ldr	r3, [r3, #0]
 8002ab8:	699b      	ldr	r3, [r3, #24]
 8002aba:	f003 0320 	and.w	r3, r3, #32
 8002abe:	2b20      	cmp	r3, #32
 8002ac0:	bf0c      	ite	eq
 8002ac2:	2301      	moveq	r3, #1
 8002ac4:	2300      	movne	r3, #0
 8002ac6:	b2db      	uxtb	r3, r3
 8002ac8:	77fb      	strb	r3, [r7, #31]
        tmp2 = __HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_AF);
 8002aca:	68fb      	ldr	r3, [r7, #12]
 8002acc:	681b      	ldr	r3, [r3, #0]
 8002ace:	699b      	ldr	r3, [r3, #24]
 8002ad0:	f003 0310 	and.w	r3, r3, #16
 8002ad4:	2b10      	cmp	r3, #16
 8002ad6:	bf0c      	ite	eq
 8002ad8:	2301      	moveq	r3, #1
 8002ada:	2300      	movne	r3, #0
 8002adc:	b2db      	uxtb	r3, r3
 8002ade:	77bb      	strb	r3, [r7, #30]
      while ((tmp1 == RESET) && (tmp2 == RESET))
 8002ae0:	7ffb      	ldrb	r3, [r7, #31]
 8002ae2:	2b00      	cmp	r3, #0
 8002ae4:	d102      	bne.n	8002aec <HAL_I2C_IsDeviceReady+0x12c>
 8002ae6:	7fbb      	ldrb	r3, [r7, #30]
 8002ae8:	2b00      	cmp	r3, #0
 8002aea:	d0c4      	beq.n	8002a76 <HAL_I2C_IsDeviceReady+0xb6>
      }

      /* Check if the NACKF flag has not been set */
      if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_AF) == RESET)
 8002aec:	68fb      	ldr	r3, [r7, #12]
 8002aee:	681b      	ldr	r3, [r3, #0]
 8002af0:	699b      	ldr	r3, [r3, #24]
 8002af2:	f003 0310 	and.w	r3, r3, #16
 8002af6:	2b10      	cmp	r3, #16
 8002af8:	d01a      	beq.n	8002b30 <HAL_I2C_IsDeviceReady+0x170>
      {
        /* Wait until STOPF flag is reset */
        if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_STOPF, RESET, Timeout, tickstart) != HAL_OK)
 8002afa:	69bb      	ldr	r3, [r7, #24]
 8002afc:	9300      	str	r3, [sp, #0]
 8002afe:	683b      	ldr	r3, [r7, #0]
 8002b00:	2200      	movs	r2, #0
 8002b02:	2120      	movs	r1, #32
 8002b04:	68f8      	ldr	r0, [r7, #12]
 8002b06:	f000 fd9c 	bl	8003642 <I2C_WaitOnFlagUntilTimeout>
 8002b0a:	4603      	mov	r3, r0
 8002b0c:	2b00      	cmp	r3, #0
 8002b0e:	d001      	beq.n	8002b14 <HAL_I2C_IsDeviceReady+0x154>
        {
          return HAL_ERROR;
 8002b10:	2301      	movs	r3, #1
 8002b12:	e058      	b.n	8002bc6 <HAL_I2C_IsDeviceReady+0x206>
        }

        /* Clear STOP Flag */
        __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF);
 8002b14:	68fb      	ldr	r3, [r7, #12]
 8002b16:	681b      	ldr	r3, [r3, #0]
 8002b18:	2220      	movs	r2, #32
 8002b1a:	61da      	str	r2, [r3, #28]

        /* Device is ready */
        hi2c->State = HAL_I2C_STATE_READY;
 8002b1c:	68fb      	ldr	r3, [r7, #12]
 8002b1e:	2220      	movs	r2, #32
 8002b20:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41

        /* Process Unlocked */
        __HAL_UNLOCK(hi2c);
 8002b24:	68fb      	ldr	r3, [r7, #12]
 8002b26:	2200      	movs	r2, #0
 8002b28:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

        return HAL_OK;
 8002b2c:	2300      	movs	r3, #0
 8002b2e:	e04a      	b.n	8002bc6 <HAL_I2C_IsDeviceReady+0x206>
      }
      else
      {
        /* Wait until STOPF flag is reset */
        if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_STOPF, RESET, Timeout, tickstart) != HAL_OK)
 8002b30:	69bb      	ldr	r3, [r7, #24]
 8002b32:	9300      	str	r3, [sp, #0]
 8002b34:	683b      	ldr	r3, [r7, #0]
 8002b36:	2200      	movs	r2, #0
 8002b38:	2120      	movs	r1, #32
 8002b3a:	68f8      	ldr	r0, [r7, #12]
 8002b3c:	f000 fd81 	bl	8003642 <I2C_WaitOnFlagUntilTimeout>
 8002b40:	4603      	mov	r3, r0
 8002b42:	2b00      	cmp	r3, #0
 8002b44:	d001      	beq.n	8002b4a <HAL_I2C_IsDeviceReady+0x18a>
        {
          return HAL_ERROR;
 8002b46:	2301      	movs	r3, #1
 8002b48:	e03d      	b.n	8002bc6 <HAL_I2C_IsDeviceReady+0x206>
        }

        /* Clear NACK Flag */
        __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF);
 8002b4a:	68fb      	ldr	r3, [r7, #12]
 8002b4c:	681b      	ldr	r3, [r3, #0]
 8002b4e:	2210      	movs	r2, #16
 8002b50:	61da      	str	r2, [r3, #28]

        /* Clear STOP Flag, auto generated with autoend*/
        __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF);
 8002b52:	68fb      	ldr	r3, [r7, #12]
 8002b54:	681b      	ldr	r3, [r3, #0]
 8002b56:	2220      	movs	r2, #32
 8002b58:	61da      	str	r2, [r3, #28]
      }

      /* Check if the maximum allowed number of trials has been reached */
      if (I2C_Trials == Trials)
 8002b5a:	697b      	ldr	r3, [r7, #20]
 8002b5c:	687a      	ldr	r2, [r7, #4]
 8002b5e:	429a      	cmp	r2, r3
 8002b60:	d118      	bne.n	8002b94 <HAL_I2C_IsDeviceReady+0x1d4>
      {
        /* Generate Stop */
        hi2c->Instance->CR2 |= I2C_CR2_STOP;
 8002b62:	68fb      	ldr	r3, [r7, #12]
 8002b64:	681b      	ldr	r3, [r3, #0]
 8002b66:	685a      	ldr	r2, [r3, #4]
 8002b68:	68fb      	ldr	r3, [r7, #12]
 8002b6a:	681b      	ldr	r3, [r3, #0]
 8002b6c:	f442 4280 	orr.w	r2, r2, #16384	; 0x4000
 8002b70:	605a      	str	r2, [r3, #4]

        /* Wait until STOPF flag is reset */
        if (I2C_WaitOnFlagUntilTimeout(hi2c, I2C_FLAG_STOPF, RESET, Timeout, tickstart) != HAL_OK)
 8002b72:	69bb      	ldr	r3, [r7, #24]
 8002b74:	9300      	str	r3, [sp, #0]
 8002b76:	683b      	ldr	r3, [r7, #0]
 8002b78:	2200      	movs	r2, #0
 8002b7a:	2120      	movs	r1, #32
 8002b7c:	68f8      	ldr	r0, [r7, #12]
 8002b7e:	f000 fd60 	bl	8003642 <I2C_WaitOnFlagUntilTimeout>
 8002b82:	4603      	mov	r3, r0
 8002b84:	2b00      	cmp	r3, #0
 8002b86:	d001      	beq.n	8002b8c <HAL_I2C_IsDeviceReady+0x1cc>
        {
          return HAL_ERROR;
 8002b88:	2301      	movs	r3, #1
 8002b8a:	e01c      	b.n	8002bc6 <HAL_I2C_IsDeviceReady+0x206>
        }

        /* Clear STOP Flag */
        __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF);
 8002b8c:	68fb      	ldr	r3, [r7, #12]
 8002b8e:	681b      	ldr	r3, [r3, #0]
 8002b90:	2220      	movs	r2, #32
 8002b92:	61da      	str	r2, [r3, #28]
      }

      /* Increment Trials */
      I2C_Trials++;
 8002b94:	697b      	ldr	r3, [r7, #20]
 8002b96:	3301      	adds	r3, #1
 8002b98:	617b      	str	r3, [r7, #20]
    } while (I2C_Trials < Trials);
 8002b9a:	697b      	ldr	r3, [r7, #20]
 8002b9c:	687a      	ldr	r2, [r7, #4]
 8002b9e:	429a      	cmp	r2, r3
 8002ba0:	f63f af3b 	bhi.w	8002a1a <HAL_I2C_IsDeviceReady+0x5a>

    /* Update I2C state */
    hi2c->State = HAL_I2C_STATE_READY;
 8002ba4:	68fb      	ldr	r3, [r7, #12]
 8002ba6:	2220      	movs	r2, #32
 8002ba8:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41

    /* Update I2C error code */
    hi2c->ErrorCode |= HAL_I2C_ERROR_TIMEOUT;
 8002bac:	68fb      	ldr	r3, [r7, #12]
 8002bae:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8002bb0:	f043 0220 	orr.w	r2, r3, #32
 8002bb4:	68fb      	ldr	r3, [r7, #12]
 8002bb6:	645a      	str	r2, [r3, #68]	; 0x44

    /* Process Unlocked */
    __HAL_UNLOCK(hi2c);
 8002bb8:	68fb      	ldr	r3, [r7, #12]
 8002bba:	2200      	movs	r2, #0
 8002bbc:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

    return HAL_ERROR;
 8002bc0:	2301      	movs	r3, #1
 8002bc2:	e000      	b.n	8002bc6 <HAL_I2C_IsDeviceReady+0x206>
  }
  else
  {
    return HAL_BUSY;
 8002bc4:	2302      	movs	r3, #2
  }
}
 8002bc6:	4618      	mov	r0, r3
 8002bc8:	3720      	adds	r7, #32
 8002bca:	46bd      	mov	sp, r7
 8002bcc:	bd80      	pop	{r7, pc}

08002bce <HAL_I2C_EV_IRQHandler>:
  * @param  hi2c Pointer to a I2C_HandleTypeDef structure that contains
  *                the configuration information for the specified I2C.
  * @retval None
  */
void HAL_I2C_EV_IRQHandler(I2C_HandleTypeDef *hi2c)
{
 8002bce:	b580      	push	{r7, lr}
 8002bd0:	b084      	sub	sp, #16
 8002bd2:	af00      	add	r7, sp, #0
 8002bd4:	6078      	str	r0, [r7, #4]
  /* Get current IT Flags and IT sources value */
  uint32_t itflags   = READ_REG(hi2c->Instance->ISR);
 8002bd6:	687b      	ldr	r3, [r7, #4]
 8002bd8:	681b      	ldr	r3, [r3, #0]
 8002bda:	699b      	ldr	r3, [r3, #24]
 8002bdc:	60fb      	str	r3, [r7, #12]
  uint32_t itsources = READ_REG(hi2c->Instance->CR1);
 8002bde:	687b      	ldr	r3, [r7, #4]
 8002be0:	681b      	ldr	r3, [r3, #0]
 8002be2:	681b      	ldr	r3, [r3, #0]
 8002be4:	60bb      	str	r3, [r7, #8]

  /* I2C events treatment -------------------------------------*/
  if (hi2c->XferISR != NULL)
 8002be6:	687b      	ldr	r3, [r7, #4]
 8002be8:	6b5b      	ldr	r3, [r3, #52]	; 0x34
 8002bea:	2b00      	cmp	r3, #0
 8002bec:	d005      	beq.n	8002bfa <HAL_I2C_EV_IRQHandler+0x2c>
  {
    hi2c->XferISR(hi2c, itflags, itsources);
 8002bee:	687b      	ldr	r3, [r7, #4]
 8002bf0:	6b5b      	ldr	r3, [r3, #52]	; 0x34
 8002bf2:	68ba      	ldr	r2, [r7, #8]
 8002bf4:	68f9      	ldr	r1, [r7, #12]
 8002bf6:	6878      	ldr	r0, [r7, #4]
 8002bf8:	4798      	blx	r3
  }
}
 8002bfa:	bf00      	nop
 8002bfc:	3710      	adds	r7, #16
 8002bfe:	46bd      	mov	sp, r7
 8002c00:	bd80      	pop	{r7, pc}

08002c02 <HAL_I2C_ER_IRQHandler>:
  * @param  hi2c Pointer to a I2C_HandleTypeDef structure that contains
  *                the configuration information for the specified I2C.
  * @retval None
  */
void HAL_I2C_ER_IRQHandler(I2C_HandleTypeDef *hi2c)
{
 8002c02:	b580      	push	{r7, lr}
 8002c04:	b086      	sub	sp, #24
 8002c06:	af00      	add	r7, sp, #0
 8002c08:	6078      	str	r0, [r7, #4]
  uint32_t itflags   = READ_REG(hi2c->Instance->ISR);
 8002c0a:	687b      	ldr	r3, [r7, #4]
 8002c0c:	681b      	ldr	r3, [r3, #0]
 8002c0e:	699b      	ldr	r3, [r3, #24]
 8002c10:	617b      	str	r3, [r7, #20]
  uint32_t itsources = READ_REG(hi2c->Instance->CR1);
 8002c12:	687b      	ldr	r3, [r7, #4]
 8002c14:	681b      	ldr	r3, [r3, #0]
 8002c16:	681b      	ldr	r3, [r3, #0]
 8002c18:	613b      	str	r3, [r7, #16]
  uint32_t tmperror;

  /* I2C Bus error interrupt occurred ------------------------------------*/
  if ((I2C_CHECK_FLAG(itflags, I2C_FLAG_BERR) != RESET) && \
 8002c1a:	697b      	ldr	r3, [r7, #20]
 8002c1c:	0a1b      	lsrs	r3, r3, #8
 8002c1e:	f003 0301 	and.w	r3, r3, #1
 8002c22:	2b00      	cmp	r3, #0
 8002c24:	d010      	beq.n	8002c48 <HAL_I2C_ER_IRQHandler+0x46>
      (I2C_CHECK_IT_SOURCE(itsources, I2C_IT_ERRI) != RESET))
 8002c26:	693b      	ldr	r3, [r7, #16]
 8002c28:	09db      	lsrs	r3, r3, #7
 8002c2a:	f003 0301 	and.w	r3, r3, #1
  if ((I2C_CHECK_FLAG(itflags, I2C_FLAG_BERR) != RESET) && \
 8002c2e:	2b00      	cmp	r3, #0
 8002c30:	d00a      	beq.n	8002c48 <HAL_I2C_ER_IRQHandler+0x46>
  {
    hi2c->ErrorCode |= HAL_I2C_ERROR_BERR;
 8002c32:	687b      	ldr	r3, [r7, #4]
 8002c34:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8002c36:	f043 0201 	orr.w	r2, r3, #1
 8002c3a:	687b      	ldr	r3, [r7, #4]
 8002c3c:	645a      	str	r2, [r3, #68]	; 0x44

    /* Clear BERR flag */
    __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_BERR);
 8002c3e:	687b      	ldr	r3, [r7, #4]
 8002c40:	681b      	ldr	r3, [r3, #0]
 8002c42:	f44f 7280 	mov.w	r2, #256	; 0x100
 8002c46:	61da      	str	r2, [r3, #28]
  }

  /* I2C Over-Run/Under-Run interrupt occurred ----------------------------------------*/
  if ((I2C_CHECK_FLAG(itflags, I2C_FLAG_OVR) != RESET) && \
 8002c48:	697b      	ldr	r3, [r7, #20]
 8002c4a:	0a9b      	lsrs	r3, r3, #10
 8002c4c:	f003 0301 	and.w	r3, r3, #1
 8002c50:	2b00      	cmp	r3, #0
 8002c52:	d010      	beq.n	8002c76 <HAL_I2C_ER_IRQHandler+0x74>
      (I2C_CHECK_IT_SOURCE(itsources, I2C_IT_ERRI) != RESET))
 8002c54:	693b      	ldr	r3, [r7, #16]
 8002c56:	09db      	lsrs	r3, r3, #7
 8002c58:	f003 0301 	and.w	r3, r3, #1
  if ((I2C_CHECK_FLAG(itflags, I2C_FLAG_OVR) != RESET) && \
 8002c5c:	2b00      	cmp	r3, #0
 8002c5e:	d00a      	beq.n	8002c76 <HAL_I2C_ER_IRQHandler+0x74>
  {
    hi2c->ErrorCode |= HAL_I2C_ERROR_OVR;
 8002c60:	687b      	ldr	r3, [r7, #4]
 8002c62:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8002c64:	f043 0208 	orr.w	r2, r3, #8
 8002c68:	687b      	ldr	r3, [r7, #4]
 8002c6a:	645a      	str	r2, [r3, #68]	; 0x44

    /* Clear OVR flag */
    __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_OVR);
 8002c6c:	687b      	ldr	r3, [r7, #4]
 8002c6e:	681b      	ldr	r3, [r3, #0]
 8002c70:	f44f 6280 	mov.w	r2, #1024	; 0x400
 8002c74:	61da      	str	r2, [r3, #28]
  }

  /* I2C Arbitration Loss error interrupt occurred -------------------------------------*/
  if ((I2C_CHECK_FLAG(itflags, I2C_FLAG_ARLO) != RESET) && \
 8002c76:	697b      	ldr	r3, [r7, #20]
 8002c78:	0a5b      	lsrs	r3, r3, #9
 8002c7a:	f003 0301 	and.w	r3, r3, #1
 8002c7e:	2b00      	cmp	r3, #0
 8002c80:	d010      	beq.n	8002ca4 <HAL_I2C_ER_IRQHandler+0xa2>
      (I2C_CHECK_IT_SOURCE(itsources, I2C_IT_ERRI) != RESET))
 8002c82:	693b      	ldr	r3, [r7, #16]
 8002c84:	09db      	lsrs	r3, r3, #7
 8002c86:	f003 0301 	and.w	r3, r3, #1
  if ((I2C_CHECK_FLAG(itflags, I2C_FLAG_ARLO) != RESET) && \
 8002c8a:	2b00      	cmp	r3, #0
 8002c8c:	d00a      	beq.n	8002ca4 <HAL_I2C_ER_IRQHandler+0xa2>
  {
    hi2c->ErrorCode |= HAL_I2C_ERROR_ARLO;
 8002c8e:	687b      	ldr	r3, [r7, #4]
 8002c90:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8002c92:	f043 0202 	orr.w	r2, r3, #2
 8002c96:	687b      	ldr	r3, [r7, #4]
 8002c98:	645a      	str	r2, [r3, #68]	; 0x44

    /* Clear ARLO flag */
    __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_ARLO);
 8002c9a:	687b      	ldr	r3, [r7, #4]
 8002c9c:	681b      	ldr	r3, [r3, #0]
 8002c9e:	f44f 7200 	mov.w	r2, #512	; 0x200
 8002ca2:	61da      	str	r2, [r3, #28]
  }

  /* Store current volatile hi2c->ErrorCode, misra rule */
  tmperror = hi2c->ErrorCode;
 8002ca4:	687b      	ldr	r3, [r7, #4]
 8002ca6:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8002ca8:	60fb      	str	r3, [r7, #12]

  /* Call the Error Callback in case of Error detected */
  if ((tmperror & (HAL_I2C_ERROR_BERR | HAL_I2C_ERROR_OVR | HAL_I2C_ERROR_ARLO)) !=  HAL_I2C_ERROR_NONE)
 8002caa:	68fb      	ldr	r3, [r7, #12]
 8002cac:	f003 030b 	and.w	r3, r3, #11
 8002cb0:	2b00      	cmp	r3, #0
 8002cb2:	d003      	beq.n	8002cbc <HAL_I2C_ER_IRQHandler+0xba>
  {
    I2C_ITError(hi2c, tmperror);
 8002cb4:	68f9      	ldr	r1, [r7, #12]
 8002cb6:	6878      	ldr	r0, [r7, #4]
 8002cb8:	f000 fb8a 	bl	80033d0 <I2C_ITError>
  }
}
 8002cbc:	bf00      	nop
 8002cbe:	3718      	adds	r7, #24
 8002cc0:	46bd      	mov	sp, r7
 8002cc2:	bd80      	pop	{r7, pc}

08002cc4 <HAL_I2C_SlaveTxCpltCallback>:
  * @param  hi2c Pointer to a I2C_HandleTypeDef structure that contains
  *                the configuration information for the specified I2C.
  * @retval None
  */
__weak void HAL_I2C_SlaveTxCpltCallback(I2C_HandleTypeDef *hi2c)
{
 8002cc4:	b480      	push	{r7}
 8002cc6:	b083      	sub	sp, #12
 8002cc8:	af00      	add	r7, sp, #0
 8002cca:	6078      	str	r0, [r7, #4]
  UNUSED(hi2c);

  /* NOTE : This function should not be modified, when the callback is needed,
            the HAL_I2C_SlaveTxCpltCallback could be implemented in the user file
   */
}
 8002ccc:	bf00      	nop
 8002cce:	370c      	adds	r7, #12
 8002cd0:	46bd      	mov	sp, r7
 8002cd2:	f85d 7b04 	ldr.w	r7, [sp], #4
 8002cd6:	4770      	bx	lr

08002cd8 <HAL_I2C_SlaveRxCpltCallback>:
  * @param  hi2c Pointer to a I2C_HandleTypeDef structure that contains
  *                the configuration information for the specified I2C.
  * @retval None
  */
__weak void HAL_I2C_SlaveRxCpltCallback(I2C_HandleTypeDef *hi2c)
{
 8002cd8:	b480      	push	{r7}
 8002cda:	b083      	sub	sp, #12
 8002cdc:	af00      	add	r7, sp, #0
 8002cde:	6078      	str	r0, [r7, #4]
  UNUSED(hi2c);

  /* NOTE : This function should not be modified, when the callback is needed,
            the HAL_I2C_SlaveRxCpltCallback could be implemented in the user file
   */
}
 8002ce0:	bf00      	nop
 8002ce2:	370c      	adds	r7, #12
 8002ce4:	46bd      	mov	sp, r7
 8002ce6:	f85d 7b04 	ldr.w	r7, [sp], #4
 8002cea:	4770      	bx	lr

08002cec <HAL_I2C_AddrCallback>:
  * @param  TransferDirection Master request Transfer Direction (Write/Read), value of @ref I2C_XFERDIRECTION
  * @param  AddrMatchCode Address Match Code
  * @retval None
  */
__weak void HAL_I2C_AddrCallback(I2C_HandleTypeDef *hi2c, uint8_t TransferDirection, uint16_t AddrMatchCode)
{
 8002cec:	b480      	push	{r7}
 8002cee:	b083      	sub	sp, #12
 8002cf0:	af00      	add	r7, sp, #0
 8002cf2:	6078      	str	r0, [r7, #4]
 8002cf4:	460b      	mov	r3, r1
 8002cf6:	70fb      	strb	r3, [r7, #3]
 8002cf8:	4613      	mov	r3, r2
 8002cfa:	803b      	strh	r3, [r7, #0]
  UNUSED(AddrMatchCode);

  /* NOTE : This function should not be modified, when the callback is needed,
            the HAL_I2C_AddrCallback() could be implemented in the user file
   */
}
 8002cfc:	bf00      	nop
 8002cfe:	370c      	adds	r7, #12
 8002d00:	46bd      	mov	sp, r7
 8002d02:	f85d 7b04 	ldr.w	r7, [sp], #4
 8002d06:	4770      	bx	lr

08002d08 <HAL_I2C_ListenCpltCallback>:
  * @param  hi2c Pointer to a I2C_HandleTypeDef structure that contains
  *                the configuration information for the specified I2C.
  * @retval None
  */
__weak void HAL_I2C_ListenCpltCallback(I2C_HandleTypeDef *hi2c)
{
 8002d08:	b480      	push	{r7}
 8002d0a:	b083      	sub	sp, #12
 8002d0c:	af00      	add	r7, sp, #0
 8002d0e:	6078      	str	r0, [r7, #4]
  UNUSED(hi2c);

  /* NOTE : This function should not be modified, when the callback is needed,
            the HAL_I2C_ListenCpltCallback() could be implemented in the user file
   */
}
 8002d10:	bf00      	nop
 8002d12:	370c      	adds	r7, #12
 8002d14:	46bd      	mov	sp, r7
 8002d16:	f85d 7b04 	ldr.w	r7, [sp], #4
 8002d1a:	4770      	bx	lr

08002d1c <HAL_I2C_ErrorCallback>:
  * @param  hi2c Pointer to a I2C_HandleTypeDef structure that contains
  *                the configuration information for the specified I2C.
  * @retval None
  */
__weak void HAL_I2C_ErrorCallback(I2C_HandleTypeDef *hi2c)
{
 8002d1c:	b480      	push	{r7}
 8002d1e:	b083      	sub	sp, #12
 8002d20:	af00      	add	r7, sp, #0
 8002d22:	6078      	str	r0, [r7, #4]
  UNUSED(hi2c);

  /* NOTE : This function should not be modified, when the callback is needed,
            the HAL_I2C_ErrorCallback could be implemented in the user file
   */
}
 8002d24:	bf00      	nop
 8002d26:	370c      	adds	r7, #12
 8002d28:	46bd      	mov	sp, r7
 8002d2a:	f85d 7b04 	ldr.w	r7, [sp], #4
 8002d2e:	4770      	bx	lr

08002d30 <HAL_I2C_AbortCpltCallback>:
  * @param  hi2c Pointer to a I2C_HandleTypeDef structure that contains
  *                the configuration information for the specified I2C.
  * @retval None
  */
__weak void HAL_I2C_AbortCpltCallback(I2C_HandleTypeDef *hi2c)
{
 8002d30:	b480      	push	{r7}
 8002d32:	b083      	sub	sp, #12
 8002d34:	af00      	add	r7, sp, #0
 8002d36:	6078      	str	r0, [r7, #4]
  UNUSED(hi2c);

  /* NOTE : This function should not be modified, when the callback is needed,
            the HAL_I2C_AbortCpltCallback could be implemented in the user file
   */
}
 8002d38:	bf00      	nop
 8002d3a:	370c      	adds	r7, #12
 8002d3c:	46bd      	mov	sp, r7
 8002d3e:	f85d 7b04 	ldr.w	r7, [sp], #4
 8002d42:	4770      	bx	lr

08002d44 <I2C_Slave_ISR_IT>:
  * @param  ITSources Interrupt sources enabled.
  * @retval HAL status
  */
static HAL_StatusTypeDef I2C_Slave_ISR_IT(struct __I2C_HandleTypeDef *hi2c, uint32_t ITFlags,
                                          uint32_t ITSources)
{
 8002d44:	b580      	push	{r7, lr}
 8002d46:	b086      	sub	sp, #24
 8002d48:	af00      	add	r7, sp, #0
 8002d4a:	60f8      	str	r0, [r7, #12]
 8002d4c:	60b9      	str	r1, [r7, #8]
 8002d4e:	607a      	str	r2, [r7, #4]
  uint32_t tmpoptions = hi2c->XferOptions;
 8002d50:	68fb      	ldr	r3, [r7, #12]
 8002d52:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8002d54:	617b      	str	r3, [r7, #20]
  uint32_t tmpITFlags = ITFlags;
 8002d56:	68bb      	ldr	r3, [r7, #8]
 8002d58:	613b      	str	r3, [r7, #16]

  /* Process locked */
  __HAL_LOCK(hi2c);
 8002d5a:	68fb      	ldr	r3, [r7, #12]
 8002d5c:	f893 3040 	ldrb.w	r3, [r3, #64]	; 0x40
 8002d60:	2b01      	cmp	r3, #1
 8002d62:	d101      	bne.n	8002d68 <I2C_Slave_ISR_IT+0x24>
 8002d64:	2302      	movs	r3, #2
 8002d66:	e0ec      	b.n	8002f42 <I2C_Slave_ISR_IT+0x1fe>
 8002d68:	68fb      	ldr	r3, [r7, #12]
 8002d6a:	2201      	movs	r2, #1
 8002d6c:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

  /* Check if STOPF is set */
  if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_STOPF) != RESET) && \
 8002d70:	693b      	ldr	r3, [r7, #16]
 8002d72:	095b      	lsrs	r3, r3, #5
 8002d74:	f003 0301 	and.w	r3, r3, #1
 8002d78:	2b00      	cmp	r3, #0
 8002d7a:	d009      	beq.n	8002d90 <I2C_Slave_ISR_IT+0x4c>
      (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_STOPI) != RESET))
 8002d7c:	687b      	ldr	r3, [r7, #4]
 8002d7e:	095b      	lsrs	r3, r3, #5
 8002d80:	f003 0301 	and.w	r3, r3, #1
  if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_STOPF) != RESET) && \
 8002d84:	2b00      	cmp	r3, #0
 8002d86:	d003      	beq.n	8002d90 <I2C_Slave_ISR_IT+0x4c>
  {
    /* Call I2C Slave complete process */
    I2C_ITSlaveCplt(hi2c, tmpITFlags);
 8002d88:	6939      	ldr	r1, [r7, #16]
 8002d8a:	68f8      	ldr	r0, [r7, #12]
 8002d8c:	f000 f9c0 	bl	8003110 <I2C_ITSlaveCplt>
  }

  if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_AF) != RESET) && \
 8002d90:	693b      	ldr	r3, [r7, #16]
 8002d92:	091b      	lsrs	r3, r3, #4
 8002d94:	f003 0301 	and.w	r3, r3, #1
 8002d98:	2b00      	cmp	r3, #0
 8002d9a:	d04d      	beq.n	8002e38 <I2C_Slave_ISR_IT+0xf4>
      (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_NACKI) != RESET))
 8002d9c:	687b      	ldr	r3, [r7, #4]
 8002d9e:	091b      	lsrs	r3, r3, #4
 8002da0:	f003 0301 	and.w	r3, r3, #1
  if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_AF) != RESET) && \
 8002da4:	2b00      	cmp	r3, #0
 8002da6:	d047      	beq.n	8002e38 <I2C_Slave_ISR_IT+0xf4>
  {
    /* Check that I2C transfer finished */
    /* if yes, normal use case, a NACK is sent by the MASTER when Transfer is finished */
    /* Mean XferCount == 0*/
    /* So clear Flag NACKF only */
    if (hi2c->XferCount == 0U)
 8002da8:	68fb      	ldr	r3, [r7, #12]
 8002daa:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8002dac:	b29b      	uxth	r3, r3
 8002dae:	2b00      	cmp	r3, #0
 8002db0:	d128      	bne.n	8002e04 <I2C_Slave_ISR_IT+0xc0>
    {
      if ((hi2c->State == HAL_I2C_STATE_LISTEN) && (tmpoptions == I2C_FIRST_AND_LAST_FRAME))
 8002db2:	68fb      	ldr	r3, [r7, #12]
 8002db4:	f893 3041 	ldrb.w	r3, [r3, #65]	; 0x41
 8002db8:	b2db      	uxtb	r3, r3
 8002dba:	2b28      	cmp	r3, #40	; 0x28
 8002dbc:	d108      	bne.n	8002dd0 <I2C_Slave_ISR_IT+0x8c>
 8002dbe:	697b      	ldr	r3, [r7, #20]
 8002dc0:	f1b3 7f00 	cmp.w	r3, #33554432	; 0x2000000
 8002dc4:	d104      	bne.n	8002dd0 <I2C_Slave_ISR_IT+0x8c>
        /* Same action must be done for (tmpoptions == I2C_LAST_FRAME) which removed for
           Warning[Pa134]: left and right operands are identical */
      {
        /* Call I2C Listen complete process */
        I2C_ITListenCplt(hi2c, tmpITFlags);
 8002dc6:	6939      	ldr	r1, [r7, #16]
 8002dc8:	68f8      	ldr	r0, [r7, #12]
 8002dca:	f000 faab 	bl	8003324 <I2C_ITListenCplt>
 8002dce:	e032      	b.n	8002e36 <I2C_Slave_ISR_IT+0xf2>
      }
      else if ((hi2c->State == HAL_I2C_STATE_BUSY_TX_LISTEN) && (tmpoptions != I2C_NO_OPTION_FRAME))
 8002dd0:	68fb      	ldr	r3, [r7, #12]
 8002dd2:	f893 3041 	ldrb.w	r3, [r3, #65]	; 0x41
 8002dd6:	b2db      	uxtb	r3, r3
 8002dd8:	2b29      	cmp	r3, #41	; 0x29
 8002dda:	d10e      	bne.n	8002dfa <I2C_Slave_ISR_IT+0xb6>
 8002ddc:	697b      	ldr	r3, [r7, #20]
 8002dde:	f513 3f80 	cmn.w	r3, #65536	; 0x10000
 8002de2:	d00a      	beq.n	8002dfa <I2C_Slave_ISR_IT+0xb6>
      {
        /* Clear NACK Flag */
        __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF);
 8002de4:	68fb      	ldr	r3, [r7, #12]
 8002de6:	681b      	ldr	r3, [r3, #0]
 8002de8:	2210      	movs	r2, #16
 8002dea:	61da      	str	r2, [r3, #28]

        /* Flush TX register */
        I2C_Flush_TXDR(hi2c);
 8002dec:	68f8      	ldr	r0, [r7, #12]
 8002dee:	f000 fbe6 	bl	80035be <I2C_Flush_TXDR>

        /* Last Byte is Transmitted */
        /* Call I2C Slave Sequential complete process */
        I2C_ITSlaveSeqCplt(hi2c);
 8002df2:	68f8      	ldr	r0, [r7, #12]
 8002df4:	f000 f92d 	bl	8003052 <I2C_ITSlaveSeqCplt>
 8002df8:	e01d      	b.n	8002e36 <I2C_Slave_ISR_IT+0xf2>
      }
      else
      {
        /* Clear NACK Flag */
        __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF);
 8002dfa:	68fb      	ldr	r3, [r7, #12]
 8002dfc:	681b      	ldr	r3, [r3, #0]
 8002dfe:	2210      	movs	r2, #16
 8002e00:	61da      	str	r2, [r3, #28]
    if (hi2c->XferCount == 0U)
 8002e02:	e096      	b.n	8002f32 <I2C_Slave_ISR_IT+0x1ee>
    }
    else
    {
      /* if no, error use case, a Non-Acknowledge of last Data is generated by the MASTER*/
      /* Clear NACK Flag */
      __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF);
 8002e04:	68fb      	ldr	r3, [r7, #12]
 8002e06:	681b      	ldr	r3, [r3, #0]
 8002e08:	2210      	movs	r2, #16
 8002e0a:	61da      	str	r2, [r3, #28]

      /* Set ErrorCode corresponding to a Non-Acknowledge */
      hi2c->ErrorCode |= HAL_I2C_ERROR_AF;
 8002e0c:	68fb      	ldr	r3, [r7, #12]
 8002e0e:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8002e10:	f043 0204 	orr.w	r2, r3, #4
 8002e14:	68fb      	ldr	r3, [r7, #12]
 8002e16:	645a      	str	r2, [r3, #68]	; 0x44

      if ((tmpoptions == I2C_FIRST_FRAME) || (tmpoptions == I2C_NEXT_FRAME))
 8002e18:	697b      	ldr	r3, [r7, #20]
 8002e1a:	2b00      	cmp	r3, #0
 8002e1c:	d004      	beq.n	8002e28 <I2C_Slave_ISR_IT+0xe4>
 8002e1e:	697b      	ldr	r3, [r7, #20]
 8002e20:	f1b3 7f80 	cmp.w	r3, #16777216	; 0x1000000
 8002e24:	f040 8085 	bne.w	8002f32 <I2C_Slave_ISR_IT+0x1ee>
      {
        /* Call the corresponding callback to inform upper layer of End of Transfer */
        I2C_ITError(hi2c, hi2c->ErrorCode);
 8002e28:	68fb      	ldr	r3, [r7, #12]
 8002e2a:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8002e2c:	4619      	mov	r1, r3
 8002e2e:	68f8      	ldr	r0, [r7, #12]
 8002e30:	f000 face 	bl	80033d0 <I2C_ITError>
    if (hi2c->XferCount == 0U)
 8002e34:	e07d      	b.n	8002f32 <I2C_Slave_ISR_IT+0x1ee>
 8002e36:	e07c      	b.n	8002f32 <I2C_Slave_ISR_IT+0x1ee>
      }
    }
  }
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_RXNE) != RESET) && \
 8002e38:	693b      	ldr	r3, [r7, #16]
 8002e3a:	089b      	lsrs	r3, r3, #2
 8002e3c:	f003 0301 	and.w	r3, r3, #1
 8002e40:	2b00      	cmp	r3, #0
 8002e42:	d030      	beq.n	8002ea6 <I2C_Slave_ISR_IT+0x162>
           (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_RXI) != RESET))
 8002e44:	687b      	ldr	r3, [r7, #4]
 8002e46:	089b      	lsrs	r3, r3, #2
 8002e48:	f003 0301 	and.w	r3, r3, #1
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_RXNE) != RESET) && \
 8002e4c:	2b00      	cmp	r3, #0
 8002e4e:	d02a      	beq.n	8002ea6 <I2C_Slave_ISR_IT+0x162>
  {
    if (hi2c->XferCount > 0U)
 8002e50:	68fb      	ldr	r3, [r7, #12]
 8002e52:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8002e54:	b29b      	uxth	r3, r3
 8002e56:	2b00      	cmp	r3, #0
 8002e58:	d018      	beq.n	8002e8c <I2C_Slave_ISR_IT+0x148>
    {
      /* Read data from RXDR */
      *hi2c->pBuffPtr = (uint8_t)hi2c->Instance->RXDR;
 8002e5a:	68fb      	ldr	r3, [r7, #12]
 8002e5c:	681b      	ldr	r3, [r3, #0]
 8002e5e:	6a5a      	ldr	r2, [r3, #36]	; 0x24
 8002e60:	68fb      	ldr	r3, [r7, #12]
 8002e62:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8002e64:	b2d2      	uxtb	r2, r2
 8002e66:	701a      	strb	r2, [r3, #0]

      /* Increment Buffer pointer */
      hi2c->pBuffPtr++;
 8002e68:	68fb      	ldr	r3, [r7, #12]
 8002e6a:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8002e6c:	1c5a      	adds	r2, r3, #1
 8002e6e:	68fb      	ldr	r3, [r7, #12]
 8002e70:	625a      	str	r2, [r3, #36]	; 0x24

      hi2c->XferSize--;
 8002e72:	68fb      	ldr	r3, [r7, #12]
 8002e74:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8002e76:	3b01      	subs	r3, #1
 8002e78:	b29a      	uxth	r2, r3
 8002e7a:	68fb      	ldr	r3, [r7, #12]
 8002e7c:	851a      	strh	r2, [r3, #40]	; 0x28
      hi2c->XferCount--;
 8002e7e:	68fb      	ldr	r3, [r7, #12]
 8002e80:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8002e82:	b29b      	uxth	r3, r3
 8002e84:	3b01      	subs	r3, #1
 8002e86:	b29a      	uxth	r2, r3
 8002e88:	68fb      	ldr	r3, [r7, #12]
 8002e8a:	855a      	strh	r2, [r3, #42]	; 0x2a
    }

    if ((hi2c->XferCount == 0U) && \
 8002e8c:	68fb      	ldr	r3, [r7, #12]
 8002e8e:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8002e90:	b29b      	uxth	r3, r3
 8002e92:	2b00      	cmp	r3, #0
 8002e94:	d14f      	bne.n	8002f36 <I2C_Slave_ISR_IT+0x1f2>
 8002e96:	697b      	ldr	r3, [r7, #20]
 8002e98:	f513 3f80 	cmn.w	r3, #65536	; 0x10000
 8002e9c:	d04b      	beq.n	8002f36 <I2C_Slave_ISR_IT+0x1f2>
        (tmpoptions != I2C_NO_OPTION_FRAME))
    {
      /* Call I2C Slave Sequential complete process */
      I2C_ITSlaveSeqCplt(hi2c);
 8002e9e:	68f8      	ldr	r0, [r7, #12]
 8002ea0:	f000 f8d7 	bl	8003052 <I2C_ITSlaveSeqCplt>
    if ((hi2c->XferCount == 0U) && \
 8002ea4:	e047      	b.n	8002f36 <I2C_Slave_ISR_IT+0x1f2>
    }
  }
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_ADDR) != RESET) && \
 8002ea6:	693b      	ldr	r3, [r7, #16]
 8002ea8:	08db      	lsrs	r3, r3, #3
 8002eaa:	f003 0301 	and.w	r3, r3, #1
 8002eae:	2b00      	cmp	r3, #0
 8002eb0:	d00a      	beq.n	8002ec8 <I2C_Slave_ISR_IT+0x184>
           (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_ADDRI) != RESET))
 8002eb2:	687b      	ldr	r3, [r7, #4]
 8002eb4:	08db      	lsrs	r3, r3, #3
 8002eb6:	f003 0301 	and.w	r3, r3, #1
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_ADDR) != RESET) && \
 8002eba:	2b00      	cmp	r3, #0
 8002ebc:	d004      	beq.n	8002ec8 <I2C_Slave_ISR_IT+0x184>
  {
    I2C_ITAddrCplt(hi2c, tmpITFlags);
 8002ebe:	6939      	ldr	r1, [r7, #16]
 8002ec0:	68f8      	ldr	r0, [r7, #12]
 8002ec2:	f000 f842 	bl	8002f4a <I2C_ITAddrCplt>
 8002ec6:	e037      	b.n	8002f38 <I2C_Slave_ISR_IT+0x1f4>
  }
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_TXIS) != RESET) && \
 8002ec8:	693b      	ldr	r3, [r7, #16]
 8002eca:	085b      	lsrs	r3, r3, #1
 8002ecc:	f003 0301 	and.w	r3, r3, #1
 8002ed0:	2b00      	cmp	r3, #0
 8002ed2:	d031      	beq.n	8002f38 <I2C_Slave_ISR_IT+0x1f4>
           (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_TXI) != RESET))
 8002ed4:	687b      	ldr	r3, [r7, #4]
 8002ed6:	085b      	lsrs	r3, r3, #1
 8002ed8:	f003 0301 	and.w	r3, r3, #1
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_TXIS) != RESET) && \
 8002edc:	2b00      	cmp	r3, #0
 8002ede:	d02b      	beq.n	8002f38 <I2C_Slave_ISR_IT+0x1f4>
  {
    /* Write data to TXDR only if XferCount not reach "0" */
    /* A TXIS flag can be set, during STOP treatment      */
    /* Check if all Data have already been sent */
    /* If it is the case, this last write in TXDR is not sent, correspond to a dummy TXIS event */
    if (hi2c->XferCount > 0U)
 8002ee0:	68fb      	ldr	r3, [r7, #12]
 8002ee2:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8002ee4:	b29b      	uxth	r3, r3
 8002ee6:	2b00      	cmp	r3, #0
 8002ee8:	d018      	beq.n	8002f1c <I2C_Slave_ISR_IT+0x1d8>
    {
      /* Write data to TXDR */
      hi2c->Instance->TXDR = *hi2c->pBuffPtr;
 8002eea:	68fb      	ldr	r3, [r7, #12]
 8002eec:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8002eee:	781a      	ldrb	r2, [r3, #0]
 8002ef0:	68fb      	ldr	r3, [r7, #12]
 8002ef2:	681b      	ldr	r3, [r3, #0]
 8002ef4:	629a      	str	r2, [r3, #40]	; 0x28

      /* Increment Buffer pointer */
      hi2c->pBuffPtr++;
 8002ef6:	68fb      	ldr	r3, [r7, #12]
 8002ef8:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8002efa:	1c5a      	adds	r2, r3, #1
 8002efc:	68fb      	ldr	r3, [r7, #12]
 8002efe:	625a      	str	r2, [r3, #36]	; 0x24

      hi2c->XferCount--;
 8002f00:	68fb      	ldr	r3, [r7, #12]
 8002f02:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8002f04:	b29b      	uxth	r3, r3
 8002f06:	3b01      	subs	r3, #1
 8002f08:	b29a      	uxth	r2, r3
 8002f0a:	68fb      	ldr	r3, [r7, #12]
 8002f0c:	855a      	strh	r2, [r3, #42]	; 0x2a
      hi2c->XferSize--;
 8002f0e:	68fb      	ldr	r3, [r7, #12]
 8002f10:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8002f12:	3b01      	subs	r3, #1
 8002f14:	b29a      	uxth	r2, r3
 8002f16:	68fb      	ldr	r3, [r7, #12]
 8002f18:	851a      	strh	r2, [r3, #40]	; 0x28
 8002f1a:	e00d      	b.n	8002f38 <I2C_Slave_ISR_IT+0x1f4>
    }
    else
    {
      if ((tmpoptions == I2C_NEXT_FRAME) || (tmpoptions == I2C_FIRST_FRAME))
 8002f1c:	697b      	ldr	r3, [r7, #20]
 8002f1e:	f1b3 7f80 	cmp.w	r3, #16777216	; 0x1000000
 8002f22:	d002      	beq.n	8002f2a <I2C_Slave_ISR_IT+0x1e6>
 8002f24:	697b      	ldr	r3, [r7, #20]
 8002f26:	2b00      	cmp	r3, #0
 8002f28:	d106      	bne.n	8002f38 <I2C_Slave_ISR_IT+0x1f4>
      {
        /* Last Byte is Transmitted */
        /* Call I2C Slave Sequential complete process */
        I2C_ITSlaveSeqCplt(hi2c);
 8002f2a:	68f8      	ldr	r0, [r7, #12]
 8002f2c:	f000 f891 	bl	8003052 <I2C_ITSlaveSeqCplt>
 8002f30:	e002      	b.n	8002f38 <I2C_Slave_ISR_IT+0x1f4>
    if (hi2c->XferCount == 0U)
 8002f32:	bf00      	nop
 8002f34:	e000      	b.n	8002f38 <I2C_Slave_ISR_IT+0x1f4>
    if ((hi2c->XferCount == 0U) && \
 8002f36:	bf00      	nop
  {
    /* Nothing to do */
  }

  /* Process Unlocked */
  __HAL_UNLOCK(hi2c);
 8002f38:	68fb      	ldr	r3, [r7, #12]
 8002f3a:	2200      	movs	r2, #0
 8002f3c:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

  return HAL_OK;
 8002f40:	2300      	movs	r3, #0
}
 8002f42:	4618      	mov	r0, r3
 8002f44:	3718      	adds	r7, #24
 8002f46:	46bd      	mov	sp, r7
 8002f48:	bd80      	pop	{r7, pc}

08002f4a <I2C_ITAddrCplt>:
  * @param  hi2c I2C handle.
  * @param  ITFlags Interrupt flags to handle.
  * @retval None
  */
static void I2C_ITAddrCplt(I2C_HandleTypeDef *hi2c, uint32_t ITFlags)
{
 8002f4a:	b580      	push	{r7, lr}
 8002f4c:	b084      	sub	sp, #16
 8002f4e:	af00      	add	r7, sp, #0
 8002f50:	6078      	str	r0, [r7, #4]
 8002f52:	6039      	str	r1, [r7, #0]

  /* Prevent unused argument(s) compilation warning */
  UNUSED(ITFlags);

  /* In case of Listen state, need to inform upper layer of address match code event */
  if (((uint32_t)hi2c->State & (uint32_t)HAL_I2C_STATE_LISTEN) == (uint32_t)HAL_I2C_STATE_LISTEN)
 8002f54:	687b      	ldr	r3, [r7, #4]
 8002f56:	f893 3041 	ldrb.w	r3, [r3, #65]	; 0x41
 8002f5a:	b2db      	uxtb	r3, r3
 8002f5c:	f003 0328 	and.w	r3, r3, #40	; 0x28
 8002f60:	2b28      	cmp	r3, #40	; 0x28
 8002f62:	d16a      	bne.n	800303a <I2C_ITAddrCplt+0xf0>
  {
    transferdirection = I2C_GET_DIR(hi2c);
 8002f64:	687b      	ldr	r3, [r7, #4]
 8002f66:	681b      	ldr	r3, [r3, #0]
 8002f68:	699b      	ldr	r3, [r3, #24]
 8002f6a:	0c1b      	lsrs	r3, r3, #16
 8002f6c:	b2db      	uxtb	r3, r3
 8002f6e:	f003 0301 	and.w	r3, r3, #1
 8002f72:	73fb      	strb	r3, [r7, #15]
    slaveaddrcode     = I2C_GET_ADDR_MATCH(hi2c);
 8002f74:	687b      	ldr	r3, [r7, #4]
 8002f76:	681b      	ldr	r3, [r3, #0]
 8002f78:	699b      	ldr	r3, [r3, #24]
 8002f7a:	0c1b      	lsrs	r3, r3, #16
 8002f7c:	b29b      	uxth	r3, r3
 8002f7e:	f003 03fe 	and.w	r3, r3, #254	; 0xfe
 8002f82:	81bb      	strh	r3, [r7, #12]
    ownadd1code       = I2C_GET_OWN_ADDRESS1(hi2c);
 8002f84:	687b      	ldr	r3, [r7, #4]
 8002f86:	681b      	ldr	r3, [r3, #0]
 8002f88:	689b      	ldr	r3, [r3, #8]
 8002f8a:	b29b      	uxth	r3, r3
 8002f8c:	f3c3 0309 	ubfx	r3, r3, #0, #10
 8002f90:	817b      	strh	r3, [r7, #10]
    ownadd2code       = I2C_GET_OWN_ADDRESS2(hi2c);
 8002f92:	687b      	ldr	r3, [r7, #4]
 8002f94:	681b      	ldr	r3, [r3, #0]
 8002f96:	68db      	ldr	r3, [r3, #12]
 8002f98:	b29b      	uxth	r3, r3
 8002f9a:	f003 03fe 	and.w	r3, r3, #254	; 0xfe
 8002f9e:	813b      	strh	r3, [r7, #8]

    /* If 10bits addressing mode is selected */
    if (hi2c->Init.AddressingMode == I2C_ADDRESSINGMODE_10BIT)
 8002fa0:	687b      	ldr	r3, [r7, #4]
 8002fa2:	68db      	ldr	r3, [r3, #12]
 8002fa4:	2b02      	cmp	r3, #2
 8002fa6:	d138      	bne.n	800301a <I2C_ITAddrCplt+0xd0>
    {
      if ((slaveaddrcode & SLAVE_ADDR_MSK) == ((ownadd1code >> SLAVE_ADDR_SHIFT) & SLAVE_ADDR_MSK))
 8002fa8:	897b      	ldrh	r3, [r7, #10]
 8002faa:	09db      	lsrs	r3, r3, #7
 8002fac:	b29a      	uxth	r2, r3
 8002fae:	89bb      	ldrh	r3, [r7, #12]
 8002fb0:	4053      	eors	r3, r2
 8002fb2:	b29b      	uxth	r3, r3
 8002fb4:	f003 0306 	and.w	r3, r3, #6
 8002fb8:	2b00      	cmp	r3, #0
 8002fba:	d11c      	bne.n	8002ff6 <I2C_ITAddrCplt+0xac>
      {
        slaveaddrcode = ownadd1code;
 8002fbc:	897b      	ldrh	r3, [r7, #10]
 8002fbe:	81bb      	strh	r3, [r7, #12]
        hi2c->AddrEventCount++;
 8002fc0:	687b      	ldr	r3, [r7, #4]
 8002fc2:	6c9b      	ldr	r3, [r3, #72]	; 0x48
 8002fc4:	1c5a      	adds	r2, r3, #1
 8002fc6:	687b      	ldr	r3, [r7, #4]
 8002fc8:	649a      	str	r2, [r3, #72]	; 0x48
        if (hi2c->AddrEventCount == 2U)
 8002fca:	687b      	ldr	r3, [r7, #4]
 8002fcc:	6c9b      	ldr	r3, [r3, #72]	; 0x48
 8002fce:	2b02      	cmp	r3, #2
 8002fd0:	d13b      	bne.n	800304a <I2C_ITAddrCplt+0x100>
        {
          /* Reset Address Event counter */
          hi2c->AddrEventCount = 0U;
 8002fd2:	687b      	ldr	r3, [r7, #4]
 8002fd4:	2200      	movs	r2, #0
 8002fd6:	649a      	str	r2, [r3, #72]	; 0x48

          /* Clear ADDR flag */
          __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_ADDR);
 8002fd8:	687b      	ldr	r3, [r7, #4]
 8002fda:	681b      	ldr	r3, [r3, #0]
 8002fdc:	2208      	movs	r2, #8
 8002fde:	61da      	str	r2, [r3, #28]

          /* Process Unlocked */
          __HAL_UNLOCK(hi2c);
 8002fe0:	687b      	ldr	r3, [r7, #4]
 8002fe2:	2200      	movs	r2, #0
 8002fe4:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

          /* Call Slave Addr callback */
#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1)
          hi2c->AddrCallback(hi2c, transferdirection, slaveaddrcode);
#else
          HAL_I2C_AddrCallback(hi2c, transferdirection, slaveaddrcode);
 8002fe8:	89ba      	ldrh	r2, [r7, #12]
 8002fea:	7bfb      	ldrb	r3, [r7, #15]
 8002fec:	4619      	mov	r1, r3
 8002fee:	6878      	ldr	r0, [r7, #4]
 8002ff0:	f7ff fe7c 	bl	8002cec <HAL_I2C_AddrCallback>
    __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_ADDR);

    /* Process Unlocked */
    __HAL_UNLOCK(hi2c);
  }
}
 8002ff4:	e029      	b.n	800304a <I2C_ITAddrCplt+0x100>
        slaveaddrcode = ownadd2code;
 8002ff6:	893b      	ldrh	r3, [r7, #8]
 8002ff8:	81bb      	strh	r3, [r7, #12]
        I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT);
 8002ffa:	f44f 4100 	mov.w	r1, #32768	; 0x8000
 8002ffe:	6878      	ldr	r0, [r7, #4]
 8003000:	f000 fcfa 	bl	80039f8 <I2C_Disable_IRQ>
        __HAL_UNLOCK(hi2c);
 8003004:	687b      	ldr	r3, [r7, #4]
 8003006:	2200      	movs	r2, #0
 8003008:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40
        HAL_I2C_AddrCallback(hi2c, transferdirection, slaveaddrcode);
 800300c:	89ba      	ldrh	r2, [r7, #12]
 800300e:	7bfb      	ldrb	r3, [r7, #15]
 8003010:	4619      	mov	r1, r3
 8003012:	6878      	ldr	r0, [r7, #4]
 8003014:	f7ff fe6a 	bl	8002cec <HAL_I2C_AddrCallback>
}
 8003018:	e017      	b.n	800304a <I2C_ITAddrCplt+0x100>
      I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT);
 800301a:	f44f 4100 	mov.w	r1, #32768	; 0x8000
 800301e:	6878      	ldr	r0, [r7, #4]
 8003020:	f000 fcea 	bl	80039f8 <I2C_Disable_IRQ>
      __HAL_UNLOCK(hi2c);
 8003024:	687b      	ldr	r3, [r7, #4]
 8003026:	2200      	movs	r2, #0
 8003028:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40
      HAL_I2C_AddrCallback(hi2c, transferdirection, slaveaddrcode);
 800302c:	89ba      	ldrh	r2, [r7, #12]
 800302e:	7bfb      	ldrb	r3, [r7, #15]
 8003030:	4619      	mov	r1, r3
 8003032:	6878      	ldr	r0, [r7, #4]
 8003034:	f7ff fe5a 	bl	8002cec <HAL_I2C_AddrCallback>
}
 8003038:	e007      	b.n	800304a <I2C_ITAddrCplt+0x100>
    __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_ADDR);
 800303a:	687b      	ldr	r3, [r7, #4]
 800303c:	681b      	ldr	r3, [r3, #0]
 800303e:	2208      	movs	r2, #8
 8003040:	61da      	str	r2, [r3, #28]
    __HAL_UNLOCK(hi2c);
 8003042:	687b      	ldr	r3, [r7, #4]
 8003044:	2200      	movs	r2, #0
 8003046:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40
}
 800304a:	bf00      	nop
 800304c:	3710      	adds	r7, #16
 800304e:	46bd      	mov	sp, r7
 8003050:	bd80      	pop	{r7, pc}

08003052 <I2C_ITSlaveSeqCplt>:
  * @brief  I2C Slave sequential complete process.
  * @param  hi2c I2C handle.
  * @retval None
  */
static void I2C_ITSlaveSeqCplt(I2C_HandleTypeDef *hi2c)
{
 8003052:	b580      	push	{r7, lr}
 8003054:	b084      	sub	sp, #16
 8003056:	af00      	add	r7, sp, #0
 8003058:	6078      	str	r0, [r7, #4]
  uint32_t tmpcr1value = READ_REG(hi2c->Instance->CR1);
 800305a:	687b      	ldr	r3, [r7, #4]
 800305c:	681b      	ldr	r3, [r3, #0]
 800305e:	681b      	ldr	r3, [r3, #0]
 8003060:	60fb      	str	r3, [r7, #12]

  /* Reset I2C handle mode */
  hi2c->Mode = HAL_I2C_MODE_NONE;
 8003062:	687b      	ldr	r3, [r7, #4]
 8003064:	2200      	movs	r2, #0
 8003066:	f883 2042 	strb.w	r2, [r3, #66]	; 0x42

  /* If a DMA is ongoing, Update handle size context */
  if (I2C_CHECK_IT_SOURCE(tmpcr1value, I2C_CR1_TXDMAEN) != RESET)
 800306a:	68fb      	ldr	r3, [r7, #12]
 800306c:	0b9b      	lsrs	r3, r3, #14
 800306e:	f003 0301 	and.w	r3, r3, #1
 8003072:	2b00      	cmp	r3, #0
 8003074:	d008      	beq.n	8003088 <I2C_ITSlaveSeqCplt+0x36>
  {
    /* Disable DMA Request */
    hi2c->Instance->CR1 &= ~I2C_CR1_TXDMAEN;
 8003076:	687b      	ldr	r3, [r7, #4]
 8003078:	681b      	ldr	r3, [r3, #0]
 800307a:	681a      	ldr	r2, [r3, #0]
 800307c:	687b      	ldr	r3, [r7, #4]
 800307e:	681b      	ldr	r3, [r3, #0]
 8003080:	f422 4280 	bic.w	r2, r2, #16384	; 0x4000
 8003084:	601a      	str	r2, [r3, #0]
 8003086:	e00d      	b.n	80030a4 <I2C_ITSlaveSeqCplt+0x52>
  }
  else if (I2C_CHECK_IT_SOURCE(tmpcr1value, I2C_CR1_RXDMAEN) != RESET)
 8003088:	68fb      	ldr	r3, [r7, #12]
 800308a:	0bdb      	lsrs	r3, r3, #15
 800308c:	f003 0301 	and.w	r3, r3, #1
 8003090:	2b00      	cmp	r3, #0
 8003092:	d007      	beq.n	80030a4 <I2C_ITSlaveSeqCplt+0x52>
  {
    /* Disable DMA Request */
    hi2c->Instance->CR1 &= ~I2C_CR1_RXDMAEN;
 8003094:	687b      	ldr	r3, [r7, #4]
 8003096:	681b      	ldr	r3, [r3, #0]
 8003098:	681a      	ldr	r2, [r3, #0]
 800309a:	687b      	ldr	r3, [r7, #4]
 800309c:	681b      	ldr	r3, [r3, #0]
 800309e:	f422 4200 	bic.w	r2, r2, #32768	; 0x8000
 80030a2:	601a      	str	r2, [r3, #0]
  else
  {
    /* Do nothing */
  }

  if (hi2c->State == HAL_I2C_STATE_BUSY_TX_LISTEN)
 80030a4:	687b      	ldr	r3, [r7, #4]
 80030a6:	f893 3041 	ldrb.w	r3, [r3, #65]	; 0x41
 80030aa:	b2db      	uxtb	r3, r3
 80030ac:	2b29      	cmp	r3, #41	; 0x29
 80030ae:	d112      	bne.n	80030d6 <I2C_ITSlaveSeqCplt+0x84>
  {
    /* Remove HAL_I2C_STATE_SLAVE_BUSY_TX, keep only HAL_I2C_STATE_LISTEN */
    hi2c->State         = HAL_I2C_STATE_LISTEN;
 80030b0:	687b      	ldr	r3, [r7, #4]
 80030b2:	2228      	movs	r2, #40	; 0x28
 80030b4:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
    hi2c->PreviousState = I2C_STATE_SLAVE_BUSY_TX;
 80030b8:	687b      	ldr	r3, [r7, #4]
 80030ba:	2221      	movs	r2, #33	; 0x21
 80030bc:	631a      	str	r2, [r3, #48]	; 0x30

    /* Disable Interrupts */
    I2C_Disable_IRQ(hi2c, I2C_XFER_TX_IT);
 80030be:	2101      	movs	r1, #1
 80030c0:	6878      	ldr	r0, [r7, #4]
 80030c2:	f000 fc99 	bl	80039f8 <I2C_Disable_IRQ>

    /* Process Unlocked */
    __HAL_UNLOCK(hi2c);
 80030c6:	687b      	ldr	r3, [r7, #4]
 80030c8:	2200      	movs	r2, #0
 80030ca:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

    /* Call the corresponding callback to inform upper layer of End of Transfer */
#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1)
    hi2c->SlaveTxCpltCallback(hi2c);
#else
    HAL_I2C_SlaveTxCpltCallback(hi2c);
 80030ce:	6878      	ldr	r0, [r7, #4]
 80030d0:	f7ff fdf8 	bl	8002cc4 <HAL_I2C_SlaveTxCpltCallback>
  }
  else
  {
    /* Nothing to do */
  }
}
 80030d4:	e017      	b.n	8003106 <I2C_ITSlaveSeqCplt+0xb4>
  else if (hi2c->State == HAL_I2C_STATE_BUSY_RX_LISTEN)
 80030d6:	687b      	ldr	r3, [r7, #4]
 80030d8:	f893 3041 	ldrb.w	r3, [r3, #65]	; 0x41
 80030dc:	b2db      	uxtb	r3, r3
 80030de:	2b2a      	cmp	r3, #42	; 0x2a
 80030e0:	d111      	bne.n	8003106 <I2C_ITSlaveSeqCplt+0xb4>
    hi2c->State         = HAL_I2C_STATE_LISTEN;
 80030e2:	687b      	ldr	r3, [r7, #4]
 80030e4:	2228      	movs	r2, #40	; 0x28
 80030e6:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
    hi2c->PreviousState = I2C_STATE_SLAVE_BUSY_RX;
 80030ea:	687b      	ldr	r3, [r7, #4]
 80030ec:	2222      	movs	r2, #34	; 0x22
 80030ee:	631a      	str	r2, [r3, #48]	; 0x30
    I2C_Disable_IRQ(hi2c, I2C_XFER_RX_IT);
 80030f0:	2102      	movs	r1, #2
 80030f2:	6878      	ldr	r0, [r7, #4]
 80030f4:	f000 fc80 	bl	80039f8 <I2C_Disable_IRQ>
    __HAL_UNLOCK(hi2c);
 80030f8:	687b      	ldr	r3, [r7, #4]
 80030fa:	2200      	movs	r2, #0
 80030fc:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40
    HAL_I2C_SlaveRxCpltCallback(hi2c);
 8003100:	6878      	ldr	r0, [r7, #4]
 8003102:	f7ff fde9 	bl	8002cd8 <HAL_I2C_SlaveRxCpltCallback>
}
 8003106:	bf00      	nop
 8003108:	3710      	adds	r7, #16
 800310a:	46bd      	mov	sp, r7
 800310c:	bd80      	pop	{r7, pc}
	...

08003110 <I2C_ITSlaveCplt>:
  * @param  hi2c I2C handle.
  * @param  ITFlags Interrupt flags to handle.
  * @retval None
  */
static void I2C_ITSlaveCplt(I2C_HandleTypeDef *hi2c, uint32_t ITFlags)
{
 8003110:	b580      	push	{r7, lr}
 8003112:	b086      	sub	sp, #24
 8003114:	af00      	add	r7, sp, #0
 8003116:	6078      	str	r0, [r7, #4]
 8003118:	6039      	str	r1, [r7, #0]
  uint32_t tmpcr1value = READ_REG(hi2c->Instance->CR1);
 800311a:	687b      	ldr	r3, [r7, #4]
 800311c:	681b      	ldr	r3, [r3, #0]
 800311e:	681b      	ldr	r3, [r3, #0]
 8003120:	613b      	str	r3, [r7, #16]
  uint32_t tmpITFlags = ITFlags;
 8003122:	683b      	ldr	r3, [r7, #0]
 8003124:	617b      	str	r3, [r7, #20]
  HAL_I2C_StateTypeDef tmpstate = hi2c->State;
 8003126:	687b      	ldr	r3, [r7, #4]
 8003128:	f893 3041 	ldrb.w	r3, [r3, #65]	; 0x41
 800312c:	73fb      	strb	r3, [r7, #15]

  /* Clear STOP Flag */
  __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF);
 800312e:	687b      	ldr	r3, [r7, #4]
 8003130:	681b      	ldr	r3, [r3, #0]
 8003132:	2220      	movs	r2, #32
 8003134:	61da      	str	r2, [r3, #28]

  /* Disable Interrupts and Store Previous state */
  if ((tmpstate == HAL_I2C_STATE_BUSY_TX) || (tmpstate == HAL_I2C_STATE_BUSY_TX_LISTEN))
 8003136:	7bfb      	ldrb	r3, [r7, #15]
 8003138:	2b21      	cmp	r3, #33	; 0x21
 800313a:	d002      	beq.n	8003142 <I2C_ITSlaveCplt+0x32>
 800313c:	7bfb      	ldrb	r3, [r7, #15]
 800313e:	2b29      	cmp	r3, #41	; 0x29
 8003140:	d108      	bne.n	8003154 <I2C_ITSlaveCplt+0x44>
  {
    I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT | I2C_XFER_TX_IT);
 8003142:	f248 0101 	movw	r1, #32769	; 0x8001
 8003146:	6878      	ldr	r0, [r7, #4]
 8003148:	f000 fc56 	bl	80039f8 <I2C_Disable_IRQ>
    hi2c->PreviousState = I2C_STATE_SLAVE_BUSY_TX;
 800314c:	687b      	ldr	r3, [r7, #4]
 800314e:	2221      	movs	r2, #33	; 0x21
 8003150:	631a      	str	r2, [r3, #48]	; 0x30
 8003152:	e00d      	b.n	8003170 <I2C_ITSlaveCplt+0x60>
  }
  else if ((tmpstate == HAL_I2C_STATE_BUSY_RX) || (tmpstate == HAL_I2C_STATE_BUSY_RX_LISTEN))
 8003154:	7bfb      	ldrb	r3, [r7, #15]
 8003156:	2b22      	cmp	r3, #34	; 0x22
 8003158:	d002      	beq.n	8003160 <I2C_ITSlaveCplt+0x50>
 800315a:	7bfb      	ldrb	r3, [r7, #15]
 800315c:	2b2a      	cmp	r3, #42	; 0x2a
 800315e:	d107      	bne.n	8003170 <I2C_ITSlaveCplt+0x60>
  {
    I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT | I2C_XFER_RX_IT);
 8003160:	f248 0102 	movw	r1, #32770	; 0x8002
 8003164:	6878      	ldr	r0, [r7, #4]
 8003166:	f000 fc47 	bl	80039f8 <I2C_Disable_IRQ>
    hi2c->PreviousState = I2C_STATE_SLAVE_BUSY_RX;
 800316a:	687b      	ldr	r3, [r7, #4]
 800316c:	2222      	movs	r2, #34	; 0x22
 800316e:	631a      	str	r2, [r3, #48]	; 0x30
  {
    /* Do nothing */
  }

  /* Disable Address Acknowledge */
  hi2c->Instance->CR2 |= I2C_CR2_NACK;
 8003170:	687b      	ldr	r3, [r7, #4]
 8003172:	681b      	ldr	r3, [r3, #0]
 8003174:	685a      	ldr	r2, [r3, #4]
 8003176:	687b      	ldr	r3, [r7, #4]
 8003178:	681b      	ldr	r3, [r3, #0]
 800317a:	f442 4200 	orr.w	r2, r2, #32768	; 0x8000
 800317e:	605a      	str	r2, [r3, #4]

  /* Clear Configuration Register 2 */
  I2C_RESET_CR2(hi2c);
 8003180:	687b      	ldr	r3, [r7, #4]
 8003182:	681b      	ldr	r3, [r3, #0]
 8003184:	6859      	ldr	r1, [r3, #4]
 8003186:	687b      	ldr	r3, [r7, #4]
 8003188:	681a      	ldr	r2, [r3, #0]
 800318a:	4b64      	ldr	r3, [pc, #400]	; (800331c <I2C_ITSlaveCplt+0x20c>)
 800318c:	400b      	ands	r3, r1
 800318e:	6053      	str	r3, [r2, #4]

  /* Flush TX register */
  I2C_Flush_TXDR(hi2c);
 8003190:	6878      	ldr	r0, [r7, #4]
 8003192:	f000 fa14 	bl	80035be <I2C_Flush_TXDR>

  /* If a DMA is ongoing, Update handle size context */
  if (I2C_CHECK_IT_SOURCE(tmpcr1value, I2C_CR1_TXDMAEN) != RESET)
 8003196:	693b      	ldr	r3, [r7, #16]
 8003198:	0b9b      	lsrs	r3, r3, #14
 800319a:	f003 0301 	and.w	r3, r3, #1
 800319e:	2b00      	cmp	r3, #0
 80031a0:	d013      	beq.n	80031ca <I2C_ITSlaveCplt+0xba>
  {
    /* Disable DMA Request */
    hi2c->Instance->CR1 &= ~I2C_CR1_TXDMAEN;
 80031a2:	687b      	ldr	r3, [r7, #4]
 80031a4:	681b      	ldr	r3, [r3, #0]
 80031a6:	681a      	ldr	r2, [r3, #0]
 80031a8:	687b      	ldr	r3, [r7, #4]
 80031aa:	681b      	ldr	r3, [r3, #0]
 80031ac:	f422 4280 	bic.w	r2, r2, #16384	; 0x4000
 80031b0:	601a      	str	r2, [r3, #0]

    if (hi2c->hdmatx != NULL)
 80031b2:	687b      	ldr	r3, [r7, #4]
 80031b4:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 80031b6:	2b00      	cmp	r3, #0
 80031b8:	d020      	beq.n	80031fc <I2C_ITSlaveCplt+0xec>
    {
      hi2c->XferCount = (uint16_t)I2C_GET_DMA_REMAIN_DATA(hi2c->hdmatx);
 80031ba:	687b      	ldr	r3, [r7, #4]
 80031bc:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 80031be:	681b      	ldr	r3, [r3, #0]
 80031c0:	685b      	ldr	r3, [r3, #4]
 80031c2:	b29a      	uxth	r2, r3
 80031c4:	687b      	ldr	r3, [r7, #4]
 80031c6:	855a      	strh	r2, [r3, #42]	; 0x2a
 80031c8:	e018      	b.n	80031fc <I2C_ITSlaveCplt+0xec>
    }
  }
  else if (I2C_CHECK_IT_SOURCE(tmpcr1value, I2C_CR1_RXDMAEN) != RESET)
 80031ca:	693b      	ldr	r3, [r7, #16]
 80031cc:	0bdb      	lsrs	r3, r3, #15
 80031ce:	f003 0301 	and.w	r3, r3, #1
 80031d2:	2b00      	cmp	r3, #0
 80031d4:	d012      	beq.n	80031fc <I2C_ITSlaveCplt+0xec>
  {
    /* Disable DMA Request */
    hi2c->Instance->CR1 &= ~I2C_CR1_RXDMAEN;
 80031d6:	687b      	ldr	r3, [r7, #4]
 80031d8:	681b      	ldr	r3, [r3, #0]
 80031da:	681a      	ldr	r2, [r3, #0]
 80031dc:	687b      	ldr	r3, [r7, #4]
 80031de:	681b      	ldr	r3, [r3, #0]
 80031e0:	f422 4200 	bic.w	r2, r2, #32768	; 0x8000
 80031e4:	601a      	str	r2, [r3, #0]

    if (hi2c->hdmarx != NULL)
 80031e6:	687b      	ldr	r3, [r7, #4]
 80031e8:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 80031ea:	2b00      	cmp	r3, #0
 80031ec:	d006      	beq.n	80031fc <I2C_ITSlaveCplt+0xec>
    {
      hi2c->XferCount = (uint16_t)I2C_GET_DMA_REMAIN_DATA(hi2c->hdmarx);
 80031ee:	687b      	ldr	r3, [r7, #4]
 80031f0:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 80031f2:	681b      	ldr	r3, [r3, #0]
 80031f4:	685b      	ldr	r3, [r3, #4]
 80031f6:	b29a      	uxth	r2, r3
 80031f8:	687b      	ldr	r3, [r7, #4]
 80031fa:	855a      	strh	r2, [r3, #42]	; 0x2a
  {
    /* Do nothing */
  }

  /* Store Last receive data if any */
  if (I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_RXNE) != RESET)
 80031fc:	697b      	ldr	r3, [r7, #20]
 80031fe:	089b      	lsrs	r3, r3, #2
 8003200:	f003 0301 	and.w	r3, r3, #1
 8003204:	2b00      	cmp	r3, #0
 8003206:	d020      	beq.n	800324a <I2C_ITSlaveCplt+0x13a>
  {
    /* Remove RXNE flag on temporary variable as read done */
    tmpITFlags &= ~I2C_FLAG_RXNE;
 8003208:	697b      	ldr	r3, [r7, #20]
 800320a:	f023 0304 	bic.w	r3, r3, #4
 800320e:	617b      	str	r3, [r7, #20]

    /* Read data from RXDR */
    *hi2c->pBuffPtr = (uint8_t)hi2c->Instance->RXDR;
 8003210:	687b      	ldr	r3, [r7, #4]
 8003212:	681b      	ldr	r3, [r3, #0]
 8003214:	6a5a      	ldr	r2, [r3, #36]	; 0x24
 8003216:	687b      	ldr	r3, [r7, #4]
 8003218:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 800321a:	b2d2      	uxtb	r2, r2
 800321c:	701a      	strb	r2, [r3, #0]

    /* Increment Buffer pointer */
    hi2c->pBuffPtr++;
 800321e:	687b      	ldr	r3, [r7, #4]
 8003220:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8003222:	1c5a      	adds	r2, r3, #1
 8003224:	687b      	ldr	r3, [r7, #4]
 8003226:	625a      	str	r2, [r3, #36]	; 0x24

    if ((hi2c->XferSize > 0U))
 8003228:	687b      	ldr	r3, [r7, #4]
 800322a:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 800322c:	2b00      	cmp	r3, #0
 800322e:	d00c      	beq.n	800324a <I2C_ITSlaveCplt+0x13a>
    {
      hi2c->XferSize--;
 8003230:	687b      	ldr	r3, [r7, #4]
 8003232:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8003234:	3b01      	subs	r3, #1
 8003236:	b29a      	uxth	r2, r3
 8003238:	687b      	ldr	r3, [r7, #4]
 800323a:	851a      	strh	r2, [r3, #40]	; 0x28
      hi2c->XferCount--;
 800323c:	687b      	ldr	r3, [r7, #4]
 800323e:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8003240:	b29b      	uxth	r3, r3
 8003242:	3b01      	subs	r3, #1
 8003244:	b29a      	uxth	r2, r3
 8003246:	687b      	ldr	r3, [r7, #4]
 8003248:	855a      	strh	r2, [r3, #42]	; 0x2a
    }
  }

  /* All data are not transferred, so set error code accordingly */
  if (hi2c->XferCount != 0U)
 800324a:	687b      	ldr	r3, [r7, #4]
 800324c:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 800324e:	b29b      	uxth	r3, r3
 8003250:	2b00      	cmp	r3, #0
 8003252:	d005      	beq.n	8003260 <I2C_ITSlaveCplt+0x150>
  {
    /* Set ErrorCode corresponding to a Non-Acknowledge */
    hi2c->ErrorCode |= HAL_I2C_ERROR_AF;
 8003254:	687b      	ldr	r3, [r7, #4]
 8003256:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8003258:	f043 0204 	orr.w	r2, r3, #4
 800325c:	687b      	ldr	r3, [r7, #4]
 800325e:	645a      	str	r2, [r3, #68]	; 0x44
  }

  hi2c->Mode = HAL_I2C_MODE_NONE;
 8003260:	687b      	ldr	r3, [r7, #4]
 8003262:	2200      	movs	r2, #0
 8003264:	f883 2042 	strb.w	r2, [r3, #66]	; 0x42
  hi2c->XferISR = NULL;
 8003268:	687b      	ldr	r3, [r7, #4]
 800326a:	2200      	movs	r2, #0
 800326c:	635a      	str	r2, [r3, #52]	; 0x34

  if (hi2c->ErrorCode != HAL_I2C_ERROR_NONE)
 800326e:	687b      	ldr	r3, [r7, #4]
 8003270:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8003272:	2b00      	cmp	r3, #0
 8003274:	d010      	beq.n	8003298 <I2C_ITSlaveCplt+0x188>
  {
    /* Call the corresponding callback to inform upper layer of End of Transfer */
    I2C_ITError(hi2c, hi2c->ErrorCode);
 8003276:	687b      	ldr	r3, [r7, #4]
 8003278:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 800327a:	4619      	mov	r1, r3
 800327c:	6878      	ldr	r0, [r7, #4]
 800327e:	f000 f8a7 	bl	80033d0 <I2C_ITError>

    /* Call the Listen Complete callback, to inform upper layer of the end of Listen usecase */
    if (hi2c->State == HAL_I2C_STATE_LISTEN)
 8003282:	687b      	ldr	r3, [r7, #4]
 8003284:	f893 3041 	ldrb.w	r3, [r3, #65]	; 0x41
 8003288:	b2db      	uxtb	r3, r3
 800328a:	2b28      	cmp	r3, #40	; 0x28
 800328c:	d141      	bne.n	8003312 <I2C_ITSlaveCplt+0x202>
    {
      /* Call I2C Listen complete process */
      I2C_ITListenCplt(hi2c, tmpITFlags);
 800328e:	6979      	ldr	r1, [r7, #20]
 8003290:	6878      	ldr	r0, [r7, #4]
 8003292:	f000 f847 	bl	8003324 <I2C_ITListenCplt>
    hi2c->SlaveTxCpltCallback(hi2c);
#else
    HAL_I2C_SlaveTxCpltCallback(hi2c);
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
  }
}
 8003296:	e03c      	b.n	8003312 <I2C_ITSlaveCplt+0x202>
  else if (hi2c->XferOptions != I2C_NO_OPTION_FRAME)
 8003298:	687b      	ldr	r3, [r7, #4]
 800329a:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 800329c:	f513 3f80 	cmn.w	r3, #65536	; 0x10000
 80032a0:	d014      	beq.n	80032cc <I2C_ITSlaveCplt+0x1bc>
    I2C_ITSlaveSeqCplt(hi2c);
 80032a2:	6878      	ldr	r0, [r7, #4]
 80032a4:	f7ff fed5 	bl	8003052 <I2C_ITSlaveSeqCplt>
    hi2c->XferOptions = I2C_NO_OPTION_FRAME;
 80032a8:	687b      	ldr	r3, [r7, #4]
 80032aa:	4a1d      	ldr	r2, [pc, #116]	; (8003320 <I2C_ITSlaveCplt+0x210>)
 80032ac:	62da      	str	r2, [r3, #44]	; 0x2c
    hi2c->State = HAL_I2C_STATE_READY;
 80032ae:	687b      	ldr	r3, [r7, #4]
 80032b0:	2220      	movs	r2, #32
 80032b2:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
    hi2c->PreviousState = I2C_STATE_NONE;
 80032b6:	687b      	ldr	r3, [r7, #4]
 80032b8:	2200      	movs	r2, #0
 80032ba:	631a      	str	r2, [r3, #48]	; 0x30
    __HAL_UNLOCK(hi2c);
 80032bc:	687b      	ldr	r3, [r7, #4]
 80032be:	2200      	movs	r2, #0
 80032c0:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40
    HAL_I2C_ListenCpltCallback(hi2c);
 80032c4:	6878      	ldr	r0, [r7, #4]
 80032c6:	f7ff fd1f 	bl	8002d08 <HAL_I2C_ListenCpltCallback>
}
 80032ca:	e022      	b.n	8003312 <I2C_ITSlaveCplt+0x202>
  else if (hi2c->State == HAL_I2C_STATE_BUSY_RX)
 80032cc:	687b      	ldr	r3, [r7, #4]
 80032ce:	f893 3041 	ldrb.w	r3, [r3, #65]	; 0x41
 80032d2:	b2db      	uxtb	r3, r3
 80032d4:	2b22      	cmp	r3, #34	; 0x22
 80032d6:	d10e      	bne.n	80032f6 <I2C_ITSlaveCplt+0x1e6>
    hi2c->State = HAL_I2C_STATE_READY;
 80032d8:	687b      	ldr	r3, [r7, #4]
 80032da:	2220      	movs	r2, #32
 80032dc:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
    hi2c->PreviousState = I2C_STATE_NONE;
 80032e0:	687b      	ldr	r3, [r7, #4]
 80032e2:	2200      	movs	r2, #0
 80032e4:	631a      	str	r2, [r3, #48]	; 0x30
    __HAL_UNLOCK(hi2c);
 80032e6:	687b      	ldr	r3, [r7, #4]
 80032e8:	2200      	movs	r2, #0
 80032ea:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40
    HAL_I2C_SlaveRxCpltCallback(hi2c);
 80032ee:	6878      	ldr	r0, [r7, #4]
 80032f0:	f7ff fcf2 	bl	8002cd8 <HAL_I2C_SlaveRxCpltCallback>
}
 80032f4:	e00d      	b.n	8003312 <I2C_ITSlaveCplt+0x202>
    hi2c->State = HAL_I2C_STATE_READY;
 80032f6:	687b      	ldr	r3, [r7, #4]
 80032f8:	2220      	movs	r2, #32
 80032fa:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
    hi2c->PreviousState = I2C_STATE_NONE;
 80032fe:	687b      	ldr	r3, [r7, #4]
 8003300:	2200      	movs	r2, #0
 8003302:	631a      	str	r2, [r3, #48]	; 0x30
    __HAL_UNLOCK(hi2c);
 8003304:	687b      	ldr	r3, [r7, #4]
 8003306:	2200      	movs	r2, #0
 8003308:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40
    HAL_I2C_SlaveTxCpltCallback(hi2c);
 800330c:	6878      	ldr	r0, [r7, #4]
 800330e:	f7ff fcd9 	bl	8002cc4 <HAL_I2C_SlaveTxCpltCallback>
}
 8003312:	bf00      	nop
 8003314:	3718      	adds	r7, #24
 8003316:	46bd      	mov	sp, r7
 8003318:	bd80      	pop	{r7, pc}
 800331a:	bf00      	nop
 800331c:	fe00e800 	.word	0xfe00e800
 8003320:	ffff0000 	.word	0xffff0000

08003324 <I2C_ITListenCplt>:
  * @param  hi2c I2C handle.
  * @param  ITFlags Interrupt flags to handle.
  * @retval None
  */
static void I2C_ITListenCplt(I2C_HandleTypeDef *hi2c, uint32_t ITFlags)
{
 8003324:	b580      	push	{r7, lr}
 8003326:	b082      	sub	sp, #8
 8003328:	af00      	add	r7, sp, #0
 800332a:	6078      	str	r0, [r7, #4]
 800332c:	6039      	str	r1, [r7, #0]
  /* Reset handle parameters */
  hi2c->XferOptions = I2C_NO_OPTION_FRAME;
 800332e:	687b      	ldr	r3, [r7, #4]
 8003330:	4a26      	ldr	r2, [pc, #152]	; (80033cc <I2C_ITListenCplt+0xa8>)
 8003332:	62da      	str	r2, [r3, #44]	; 0x2c
  hi2c->PreviousState = I2C_STATE_NONE;
 8003334:	687b      	ldr	r3, [r7, #4]
 8003336:	2200      	movs	r2, #0
 8003338:	631a      	str	r2, [r3, #48]	; 0x30
  hi2c->State = HAL_I2C_STATE_READY;
 800333a:	687b      	ldr	r3, [r7, #4]
 800333c:	2220      	movs	r2, #32
 800333e:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
  hi2c->Mode = HAL_I2C_MODE_NONE;
 8003342:	687b      	ldr	r3, [r7, #4]
 8003344:	2200      	movs	r2, #0
 8003346:	f883 2042 	strb.w	r2, [r3, #66]	; 0x42
  hi2c->XferISR = NULL;
 800334a:	687b      	ldr	r3, [r7, #4]
 800334c:	2200      	movs	r2, #0
 800334e:	635a      	str	r2, [r3, #52]	; 0x34

  /* Store Last receive data if any */
  if (I2C_CHECK_FLAG(ITFlags, I2C_FLAG_RXNE) != RESET)
 8003350:	683b      	ldr	r3, [r7, #0]
 8003352:	089b      	lsrs	r3, r3, #2
 8003354:	f003 0301 	and.w	r3, r3, #1
 8003358:	2b00      	cmp	r3, #0
 800335a:	d022      	beq.n	80033a2 <I2C_ITListenCplt+0x7e>
  {
    /* Read data from RXDR */
    *hi2c->pBuffPtr = (uint8_t)hi2c->Instance->RXDR;
 800335c:	687b      	ldr	r3, [r7, #4]
 800335e:	681b      	ldr	r3, [r3, #0]
 8003360:	6a5a      	ldr	r2, [r3, #36]	; 0x24
 8003362:	687b      	ldr	r3, [r7, #4]
 8003364:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8003366:	b2d2      	uxtb	r2, r2
 8003368:	701a      	strb	r2, [r3, #0]

    /* Increment Buffer pointer */
    hi2c->pBuffPtr++;
 800336a:	687b      	ldr	r3, [r7, #4]
 800336c:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 800336e:	1c5a      	adds	r2, r3, #1
 8003370:	687b      	ldr	r3, [r7, #4]
 8003372:	625a      	str	r2, [r3, #36]	; 0x24

    if ((hi2c->XferSize > 0U))
 8003374:	687b      	ldr	r3, [r7, #4]
 8003376:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8003378:	2b00      	cmp	r3, #0
 800337a:	d012      	beq.n	80033a2 <I2C_ITListenCplt+0x7e>
    {
      hi2c->XferSize--;
 800337c:	687b      	ldr	r3, [r7, #4]
 800337e:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8003380:	3b01      	subs	r3, #1
 8003382:	b29a      	uxth	r2, r3
 8003384:	687b      	ldr	r3, [r7, #4]
 8003386:	851a      	strh	r2, [r3, #40]	; 0x28
      hi2c->XferCount--;
 8003388:	687b      	ldr	r3, [r7, #4]
 800338a:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 800338c:	b29b      	uxth	r3, r3
 800338e:	3b01      	subs	r3, #1
 8003390:	b29a      	uxth	r2, r3
 8003392:	687b      	ldr	r3, [r7, #4]
 8003394:	855a      	strh	r2, [r3, #42]	; 0x2a

      /* Set ErrorCode corresponding to a Non-Acknowledge */
      hi2c->ErrorCode |= HAL_I2C_ERROR_AF;
 8003396:	687b      	ldr	r3, [r7, #4]
 8003398:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 800339a:	f043 0204 	orr.w	r2, r3, #4
 800339e:	687b      	ldr	r3, [r7, #4]
 80033a0:	645a      	str	r2, [r3, #68]	; 0x44
    }
  }

  /* Disable all Interrupts*/
  I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT | I2C_XFER_RX_IT | I2C_XFER_TX_IT);
 80033a2:	f248 0103 	movw	r1, #32771	; 0x8003
 80033a6:	6878      	ldr	r0, [r7, #4]
 80033a8:	f000 fb26 	bl	80039f8 <I2C_Disable_IRQ>

  /* Clear NACK Flag */
  __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF);
 80033ac:	687b      	ldr	r3, [r7, #4]
 80033ae:	681b      	ldr	r3, [r3, #0]
 80033b0:	2210      	movs	r2, #16
 80033b2:	61da      	str	r2, [r3, #28]

  /* Process Unlocked */
  __HAL_UNLOCK(hi2c);
 80033b4:	687b      	ldr	r3, [r7, #4]
 80033b6:	2200      	movs	r2, #0
 80033b8:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

  /* Call the Listen Complete callback, to inform upper layer of the end of Listen usecase */
#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1)
  hi2c->ListenCpltCallback(hi2c);
#else
  HAL_I2C_ListenCpltCallback(hi2c);
 80033bc:	6878      	ldr	r0, [r7, #4]
 80033be:	f7ff fca3 	bl	8002d08 <HAL_I2C_ListenCpltCallback>
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
}
 80033c2:	bf00      	nop
 80033c4:	3708      	adds	r7, #8
 80033c6:	46bd      	mov	sp, r7
 80033c8:	bd80      	pop	{r7, pc}
 80033ca:	bf00      	nop
 80033cc:	ffff0000 	.word	0xffff0000

080033d0 <I2C_ITError>:
  * @param  hi2c I2C handle.
  * @param  ErrorCode Error code to handle.
  * @retval None
  */
static void I2C_ITError(I2C_HandleTypeDef *hi2c, uint32_t ErrorCode)
{
 80033d0:	b580      	push	{r7, lr}
 80033d2:	b084      	sub	sp, #16
 80033d4:	af00      	add	r7, sp, #0
 80033d6:	6078      	str	r0, [r7, #4]
 80033d8:	6039      	str	r1, [r7, #0]
  HAL_I2C_StateTypeDef tmpstate = hi2c->State;
 80033da:	687b      	ldr	r3, [r7, #4]
 80033dc:	f893 3041 	ldrb.w	r3, [r3, #65]	; 0x41
 80033e0:	73fb      	strb	r3, [r7, #15]
  uint32_t tmppreviousstate;

  /* Reset handle parameters */
  hi2c->Mode          = HAL_I2C_MODE_NONE;
 80033e2:	687b      	ldr	r3, [r7, #4]
 80033e4:	2200      	movs	r2, #0
 80033e6:	f883 2042 	strb.w	r2, [r3, #66]	; 0x42
  hi2c->XferOptions   = I2C_NO_OPTION_FRAME;
 80033ea:	687b      	ldr	r3, [r7, #4]
 80033ec:	4a5d      	ldr	r2, [pc, #372]	; (8003564 <I2C_ITError+0x194>)
 80033ee:	62da      	str	r2, [r3, #44]	; 0x2c
  hi2c->XferCount     = 0U;
 80033f0:	687b      	ldr	r3, [r7, #4]
 80033f2:	2200      	movs	r2, #0
 80033f4:	855a      	strh	r2, [r3, #42]	; 0x2a

  /* Set new error code */
  hi2c->ErrorCode |= ErrorCode;
 80033f6:	687b      	ldr	r3, [r7, #4]
 80033f8:	6c5a      	ldr	r2, [r3, #68]	; 0x44
 80033fa:	683b      	ldr	r3, [r7, #0]
 80033fc:	431a      	orrs	r2, r3
 80033fe:	687b      	ldr	r3, [r7, #4]
 8003400:	645a      	str	r2, [r3, #68]	; 0x44

  /* Disable Interrupts */
  if ((tmpstate == HAL_I2C_STATE_LISTEN)         ||
 8003402:	7bfb      	ldrb	r3, [r7, #15]
 8003404:	2b28      	cmp	r3, #40	; 0x28
 8003406:	d005      	beq.n	8003414 <I2C_ITError+0x44>
 8003408:	7bfb      	ldrb	r3, [r7, #15]
 800340a:	2b29      	cmp	r3, #41	; 0x29
 800340c:	d002      	beq.n	8003414 <I2C_ITError+0x44>
      (tmpstate == HAL_I2C_STATE_BUSY_TX_LISTEN) ||
 800340e:	7bfb      	ldrb	r3, [r7, #15]
 8003410:	2b2a      	cmp	r3, #42	; 0x2a
 8003412:	d10b      	bne.n	800342c <I2C_ITError+0x5c>
      (tmpstate == HAL_I2C_STATE_BUSY_RX_LISTEN))
  {
    /* Disable all interrupts, except interrupts related to LISTEN state */
    I2C_Disable_IRQ(hi2c, I2C_XFER_RX_IT | I2C_XFER_TX_IT);
 8003414:	2103      	movs	r1, #3
 8003416:	6878      	ldr	r0, [r7, #4]
 8003418:	f000 faee 	bl	80039f8 <I2C_Disable_IRQ>

    /* keep HAL_I2C_STATE_LISTEN if set */
    hi2c->State         = HAL_I2C_STATE_LISTEN;
 800341c:	687b      	ldr	r3, [r7, #4]
 800341e:	2228      	movs	r2, #40	; 0x28
 8003420:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
    hi2c->XferISR       = I2C_Slave_ISR_IT;
 8003424:	687b      	ldr	r3, [r7, #4]
 8003426:	4a50      	ldr	r2, [pc, #320]	; (8003568 <I2C_ITError+0x198>)
 8003428:	635a      	str	r2, [r3, #52]	; 0x34
 800342a:	e011      	b.n	8003450 <I2C_ITError+0x80>
  }
  else
  {
    /* Disable all interrupts */
    I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT | I2C_XFER_RX_IT | I2C_XFER_TX_IT);
 800342c:	f248 0103 	movw	r1, #32771	; 0x8003
 8003430:	6878      	ldr	r0, [r7, #4]
 8003432:	f000 fae1 	bl	80039f8 <I2C_Disable_IRQ>

    /* If state is an abort treatment on going, don't change state */
    /* This change will be do later */
    if (hi2c->State != HAL_I2C_STATE_ABORT)
 8003436:	687b      	ldr	r3, [r7, #4]
 8003438:	f893 3041 	ldrb.w	r3, [r3, #65]	; 0x41
 800343c:	b2db      	uxtb	r3, r3
 800343e:	2b60      	cmp	r3, #96	; 0x60
 8003440:	d003      	beq.n	800344a <I2C_ITError+0x7a>
    {
      /* Set HAL_I2C_STATE_READY */
      hi2c->State         = HAL_I2C_STATE_READY;
 8003442:	687b      	ldr	r3, [r7, #4]
 8003444:	2220      	movs	r2, #32
 8003446:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
    }
    hi2c->XferISR       = NULL;
 800344a:	687b      	ldr	r3, [r7, #4]
 800344c:	2200      	movs	r2, #0
 800344e:	635a      	str	r2, [r3, #52]	; 0x34
  }

  /* Abort DMA TX transfer if any */
  tmppreviousstate = hi2c->PreviousState;
 8003450:	687b      	ldr	r3, [r7, #4]
 8003452:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8003454:	60bb      	str	r3, [r7, #8]
  if ((hi2c->hdmatx != NULL) && ((tmppreviousstate == I2C_STATE_MASTER_BUSY_TX) || \
 8003456:	687b      	ldr	r3, [r7, #4]
 8003458:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 800345a:	2b00      	cmp	r3, #0
 800345c:	d039      	beq.n	80034d2 <I2C_ITError+0x102>
 800345e:	68bb      	ldr	r3, [r7, #8]
 8003460:	2b11      	cmp	r3, #17
 8003462:	d002      	beq.n	800346a <I2C_ITError+0x9a>
 8003464:	68bb      	ldr	r3, [r7, #8]
 8003466:	2b21      	cmp	r3, #33	; 0x21
 8003468:	d133      	bne.n	80034d2 <I2C_ITError+0x102>
                                 (tmppreviousstate == I2C_STATE_SLAVE_BUSY_TX)))
  {
    if ((hi2c->Instance->CR1 & I2C_CR1_TXDMAEN) == I2C_CR1_TXDMAEN)
 800346a:	687b      	ldr	r3, [r7, #4]
 800346c:	681b      	ldr	r3, [r3, #0]
 800346e:	681b      	ldr	r3, [r3, #0]
 8003470:	f403 4380 	and.w	r3, r3, #16384	; 0x4000
 8003474:	f5b3 4f80 	cmp.w	r3, #16384	; 0x4000
 8003478:	d107      	bne.n	800348a <I2C_ITError+0xba>
    {
      hi2c->Instance->CR1 &= ~I2C_CR1_TXDMAEN;
 800347a:	687b      	ldr	r3, [r7, #4]
 800347c:	681b      	ldr	r3, [r3, #0]
 800347e:	681a      	ldr	r2, [r3, #0]
 8003480:	687b      	ldr	r3, [r7, #4]
 8003482:	681b      	ldr	r3, [r3, #0]
 8003484:	f422 4280 	bic.w	r2, r2, #16384	; 0x4000
 8003488:	601a      	str	r2, [r3, #0]
    }

    if (HAL_DMA_GetState(hi2c->hdmatx) != HAL_DMA_STATE_READY)
 800348a:	687b      	ldr	r3, [r7, #4]
 800348c:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 800348e:	4618      	mov	r0, r3
 8003490:	f7fe ff2a 	bl	80022e8 <HAL_DMA_GetState>
 8003494:	4603      	mov	r3, r0
 8003496:	2b01      	cmp	r3, #1
 8003498:	d017      	beq.n	80034ca <I2C_ITError+0xfa>
    {
      /* Set the I2C DMA Abort callback :
       will lead to call HAL_I2C_ErrorCallback() at end of DMA abort procedure */
      hi2c->hdmatx->XferAbortCallback = I2C_DMAAbort;
 800349a:	687b      	ldr	r3, [r7, #4]
 800349c:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 800349e:	4a33      	ldr	r2, [pc, #204]	; (800356c <I2C_ITError+0x19c>)
 80034a0:	639a      	str	r2, [r3, #56]	; 0x38

      /* Process Unlocked */
      __HAL_UNLOCK(hi2c);
 80034a2:	687b      	ldr	r3, [r7, #4]
 80034a4:	2200      	movs	r2, #0
 80034a6:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

      /* Abort DMA TX */
      if (HAL_DMA_Abort_IT(hi2c->hdmatx) != HAL_OK)
 80034aa:	687b      	ldr	r3, [r7, #4]
 80034ac:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 80034ae:	4618      	mov	r0, r3
 80034b0:	f7fe fed9 	bl	8002266 <HAL_DMA_Abort_IT>
 80034b4:	4603      	mov	r3, r0
 80034b6:	2b00      	cmp	r3, #0
 80034b8:	d04d      	beq.n	8003556 <I2C_ITError+0x186>
      {
        /* Call Directly XferAbortCallback function in case of error */
        hi2c->hdmatx->XferAbortCallback(hi2c->hdmatx);
 80034ba:	687b      	ldr	r3, [r7, #4]
 80034bc:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 80034be:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 80034c0:	687a      	ldr	r2, [r7, #4]
 80034c2:	6b92      	ldr	r2, [r2, #56]	; 0x38
 80034c4:	4610      	mov	r0, r2
 80034c6:	4798      	blx	r3
    if (HAL_DMA_GetState(hi2c->hdmatx) != HAL_DMA_STATE_READY)
 80034c8:	e045      	b.n	8003556 <I2C_ITError+0x186>
      }
    }
    else
    {
      I2C_TreatErrorCallback(hi2c);
 80034ca:	6878      	ldr	r0, [r7, #4]
 80034cc:	f000 f850 	bl	8003570 <I2C_TreatErrorCallback>
    if (HAL_DMA_GetState(hi2c->hdmatx) != HAL_DMA_STATE_READY)
 80034d0:	e041      	b.n	8003556 <I2C_ITError+0x186>
    }
  }
  /* Abort DMA RX transfer if any */
  else if ((hi2c->hdmarx != NULL) && ((tmppreviousstate == I2C_STATE_MASTER_BUSY_RX) || \
 80034d2:	687b      	ldr	r3, [r7, #4]
 80034d4:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 80034d6:	2b00      	cmp	r3, #0
 80034d8:	d039      	beq.n	800354e <I2C_ITError+0x17e>
 80034da:	68bb      	ldr	r3, [r7, #8]
 80034dc:	2b12      	cmp	r3, #18
 80034de:	d002      	beq.n	80034e6 <I2C_ITError+0x116>
 80034e0:	68bb      	ldr	r3, [r7, #8]
 80034e2:	2b22      	cmp	r3, #34	; 0x22
 80034e4:	d133      	bne.n	800354e <I2C_ITError+0x17e>
                                      (tmppreviousstate == I2C_STATE_SLAVE_BUSY_RX)))
  {
    if ((hi2c->Instance->CR1 & I2C_CR1_RXDMAEN) == I2C_CR1_RXDMAEN)
 80034e6:	687b      	ldr	r3, [r7, #4]
 80034e8:	681b      	ldr	r3, [r3, #0]
 80034ea:	681b      	ldr	r3, [r3, #0]
 80034ec:	f403 4300 	and.w	r3, r3, #32768	; 0x8000
 80034f0:	f5b3 4f00 	cmp.w	r3, #32768	; 0x8000
 80034f4:	d107      	bne.n	8003506 <I2C_ITError+0x136>
    {
      hi2c->Instance->CR1 &= ~I2C_CR1_RXDMAEN;
 80034f6:	687b      	ldr	r3, [r7, #4]
 80034f8:	681b      	ldr	r3, [r3, #0]
 80034fa:	681a      	ldr	r2, [r3, #0]
 80034fc:	687b      	ldr	r3, [r7, #4]
 80034fe:	681b      	ldr	r3, [r3, #0]
 8003500:	f422 4200 	bic.w	r2, r2, #32768	; 0x8000
 8003504:	601a      	str	r2, [r3, #0]
    }

    if (HAL_DMA_GetState(hi2c->hdmarx) != HAL_DMA_STATE_READY)
 8003506:	687b      	ldr	r3, [r7, #4]
 8003508:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 800350a:	4618      	mov	r0, r3
 800350c:	f7fe feec 	bl	80022e8 <HAL_DMA_GetState>
 8003510:	4603      	mov	r3, r0
 8003512:	2b01      	cmp	r3, #1
 8003514:	d017      	beq.n	8003546 <I2C_ITError+0x176>
    {
      /* Set the I2C DMA Abort callback :
        will lead to call HAL_I2C_ErrorCallback() at end of DMA abort procedure */
      hi2c->hdmarx->XferAbortCallback = I2C_DMAAbort;
 8003516:	687b      	ldr	r3, [r7, #4]
 8003518:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 800351a:	4a14      	ldr	r2, [pc, #80]	; (800356c <I2C_ITError+0x19c>)
 800351c:	639a      	str	r2, [r3, #56]	; 0x38

      /* Process Unlocked */
      __HAL_UNLOCK(hi2c);
 800351e:	687b      	ldr	r3, [r7, #4]
 8003520:	2200      	movs	r2, #0
 8003522:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

      /* Abort DMA RX */
      if (HAL_DMA_Abort_IT(hi2c->hdmarx) != HAL_OK)
 8003526:	687b      	ldr	r3, [r7, #4]
 8003528:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 800352a:	4618      	mov	r0, r3
 800352c:	f7fe fe9b 	bl	8002266 <HAL_DMA_Abort_IT>
 8003530:	4603      	mov	r3, r0
 8003532:	2b00      	cmp	r3, #0
 8003534:	d011      	beq.n	800355a <I2C_ITError+0x18a>
      {
        /* Call Directly hi2c->hdmarx->XferAbortCallback function in case of error */
        hi2c->hdmarx->XferAbortCallback(hi2c->hdmarx);
 8003536:	687b      	ldr	r3, [r7, #4]
 8003538:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 800353a:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 800353c:	687a      	ldr	r2, [r7, #4]
 800353e:	6bd2      	ldr	r2, [r2, #60]	; 0x3c
 8003540:	4610      	mov	r0, r2
 8003542:	4798      	blx	r3
    if (HAL_DMA_GetState(hi2c->hdmarx) != HAL_DMA_STATE_READY)
 8003544:	e009      	b.n	800355a <I2C_ITError+0x18a>
      }
    }
    else
    {
      I2C_TreatErrorCallback(hi2c);
 8003546:	6878      	ldr	r0, [r7, #4]
 8003548:	f000 f812 	bl	8003570 <I2C_TreatErrorCallback>
    if (HAL_DMA_GetState(hi2c->hdmarx) != HAL_DMA_STATE_READY)
 800354c:	e005      	b.n	800355a <I2C_ITError+0x18a>
    }
  }
  else
  {
    I2C_TreatErrorCallback(hi2c);
 800354e:	6878      	ldr	r0, [r7, #4]
 8003550:	f000 f80e 	bl	8003570 <I2C_TreatErrorCallback>
  }
}
 8003554:	e002      	b.n	800355c <I2C_ITError+0x18c>
    if (HAL_DMA_GetState(hi2c->hdmatx) != HAL_DMA_STATE_READY)
 8003556:	bf00      	nop
 8003558:	e000      	b.n	800355c <I2C_ITError+0x18c>
    if (HAL_DMA_GetState(hi2c->hdmarx) != HAL_DMA_STATE_READY)
 800355a:	bf00      	nop
}
 800355c:	bf00      	nop
 800355e:	3710      	adds	r7, #16
 8003560:	46bd      	mov	sp, r7
 8003562:	bd80      	pop	{r7, pc}
 8003564:	ffff0000 	.word	0xffff0000
 8003568:	08002d45 	.word	0x08002d45
 800356c:	08003607 	.word	0x08003607

08003570 <I2C_TreatErrorCallback>:
  * @brief  I2C Error callback treatment.
  * @param  hi2c I2C handle.
  * @retval None
  */
static void I2C_TreatErrorCallback(I2C_HandleTypeDef *hi2c)
{
 8003570:	b580      	push	{r7, lr}
 8003572:	b082      	sub	sp, #8
 8003574:	af00      	add	r7, sp, #0
 8003576:	6078      	str	r0, [r7, #4]
  if (hi2c->State == HAL_I2C_STATE_ABORT)
 8003578:	687b      	ldr	r3, [r7, #4]
 800357a:	f893 3041 	ldrb.w	r3, [r3, #65]	; 0x41
 800357e:	b2db      	uxtb	r3, r3
 8003580:	2b60      	cmp	r3, #96	; 0x60
 8003582:	d10e      	bne.n	80035a2 <I2C_TreatErrorCallback+0x32>
  {
    hi2c->State = HAL_I2C_STATE_READY;
 8003584:	687b      	ldr	r3, [r7, #4]
 8003586:	2220      	movs	r2, #32
 8003588:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
    hi2c->PreviousState = I2C_STATE_NONE;
 800358c:	687b      	ldr	r3, [r7, #4]
 800358e:	2200      	movs	r2, #0
 8003590:	631a      	str	r2, [r3, #48]	; 0x30

    /* Process Unlocked */
    __HAL_UNLOCK(hi2c);
 8003592:	687b      	ldr	r3, [r7, #4]
 8003594:	2200      	movs	r2, #0
 8003596:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

    /* Call the corresponding callback to inform upper layer of End of Transfer */
#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1)
    hi2c->AbortCpltCallback(hi2c);
#else
    HAL_I2C_AbortCpltCallback(hi2c);
 800359a:	6878      	ldr	r0, [r7, #4]
 800359c:	f7ff fbc8 	bl	8002d30 <HAL_I2C_AbortCpltCallback>
    hi2c->ErrorCallback(hi2c);
#else
    HAL_I2C_ErrorCallback(hi2c);
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
  }
}
 80035a0:	e009      	b.n	80035b6 <I2C_TreatErrorCallback+0x46>
    hi2c->PreviousState = I2C_STATE_NONE;
 80035a2:	687b      	ldr	r3, [r7, #4]
 80035a4:	2200      	movs	r2, #0
 80035a6:	631a      	str	r2, [r3, #48]	; 0x30
    __HAL_UNLOCK(hi2c);
 80035a8:	687b      	ldr	r3, [r7, #4]
 80035aa:	2200      	movs	r2, #0
 80035ac:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40
    HAL_I2C_ErrorCallback(hi2c);
 80035b0:	6878      	ldr	r0, [r7, #4]
 80035b2:	f7ff fbb3 	bl	8002d1c <HAL_I2C_ErrorCallback>
}
 80035b6:	bf00      	nop
 80035b8:	3708      	adds	r7, #8
 80035ba:	46bd      	mov	sp, r7
 80035bc:	bd80      	pop	{r7, pc}

080035be <I2C_Flush_TXDR>:
  * @brief  I2C Tx data register flush process.
  * @param  hi2c I2C handle.
  * @retval None
  */
static void I2C_Flush_TXDR(I2C_HandleTypeDef *hi2c)
{
 80035be:	b480      	push	{r7}
 80035c0:	b083      	sub	sp, #12
 80035c2:	af00      	add	r7, sp, #0
 80035c4:	6078      	str	r0, [r7, #4]
  /* If a pending TXIS flag is set */
  /* Write a dummy data in TXDR to clear it */
  if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_TXIS) != RESET)
 80035c6:	687b      	ldr	r3, [r7, #4]
 80035c8:	681b      	ldr	r3, [r3, #0]
 80035ca:	699b      	ldr	r3, [r3, #24]
 80035cc:	f003 0302 	and.w	r3, r3, #2
 80035d0:	2b02      	cmp	r3, #2
 80035d2:	d103      	bne.n	80035dc <I2C_Flush_TXDR+0x1e>
  {
    hi2c->Instance->TXDR = 0x00U;
 80035d4:	687b      	ldr	r3, [r7, #4]
 80035d6:	681b      	ldr	r3, [r3, #0]
 80035d8:	2200      	movs	r2, #0
 80035da:	629a      	str	r2, [r3, #40]	; 0x28
  }

  /* Flush TX register if not empty */
  if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_TXE) == RESET)
 80035dc:	687b      	ldr	r3, [r7, #4]
 80035de:	681b      	ldr	r3, [r3, #0]
 80035e0:	699b      	ldr	r3, [r3, #24]
 80035e2:	f003 0301 	and.w	r3, r3, #1
 80035e6:	2b01      	cmp	r3, #1
 80035e8:	d007      	beq.n	80035fa <I2C_Flush_TXDR+0x3c>
  {
    __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_TXE);
 80035ea:	687b      	ldr	r3, [r7, #4]
 80035ec:	681b      	ldr	r3, [r3, #0]
 80035ee:	699a      	ldr	r2, [r3, #24]
 80035f0:	687b      	ldr	r3, [r7, #4]
 80035f2:	681b      	ldr	r3, [r3, #0]
 80035f4:	f042 0201 	orr.w	r2, r2, #1
 80035f8:	619a      	str	r2, [r3, #24]
  }
}
 80035fa:	bf00      	nop
 80035fc:	370c      	adds	r7, #12
 80035fe:	46bd      	mov	sp, r7
 8003600:	f85d 7b04 	ldr.w	r7, [sp], #4
 8003604:	4770      	bx	lr

08003606 <I2C_DMAAbort>:
  *        (To be called at end of DMA Abort procedure).
  * @param hdma DMA handle.
  * @retval None
  */
static void I2C_DMAAbort(DMA_HandleTypeDef *hdma)
{
 8003606:	b580      	push	{r7, lr}
 8003608:	b084      	sub	sp, #16
 800360a:	af00      	add	r7, sp, #0
 800360c:	6078      	str	r0, [r7, #4]
  /* Derogation MISRAC2012-Rule-11.5 */
  I2C_HandleTypeDef *hi2c = (I2C_HandleTypeDef *)(((DMA_HandleTypeDef *)hdma)->Parent);
 800360e:	687b      	ldr	r3, [r7, #4]
 8003610:	6a9b      	ldr	r3, [r3, #40]	; 0x28
 8003612:	60fb      	str	r3, [r7, #12]

  /* Reset AbortCpltCallback */
  if (hi2c->hdmatx != NULL)
 8003614:	68fb      	ldr	r3, [r7, #12]
 8003616:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8003618:	2b00      	cmp	r3, #0
 800361a:	d003      	beq.n	8003624 <I2C_DMAAbort+0x1e>
  {
    hi2c->hdmatx->XferAbortCallback = NULL;
 800361c:	68fb      	ldr	r3, [r7, #12]
 800361e:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8003620:	2200      	movs	r2, #0
 8003622:	639a      	str	r2, [r3, #56]	; 0x38
  }
  if (hi2c->hdmarx != NULL)
 8003624:	68fb      	ldr	r3, [r7, #12]
 8003626:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8003628:	2b00      	cmp	r3, #0
 800362a:	d003      	beq.n	8003634 <I2C_DMAAbort+0x2e>
  {
    hi2c->hdmarx->XferAbortCallback = NULL;
 800362c:	68fb      	ldr	r3, [r7, #12]
 800362e:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8003630:	2200      	movs	r2, #0
 8003632:	639a      	str	r2, [r3, #56]	; 0x38
  }

  I2C_TreatErrorCallback(hi2c);
 8003634:	68f8      	ldr	r0, [r7, #12]
 8003636:	f7ff ff9b 	bl	8003570 <I2C_TreatErrorCallback>
}
 800363a:	bf00      	nop
 800363c:	3710      	adds	r7, #16
 800363e:	46bd      	mov	sp, r7
 8003640:	bd80      	pop	{r7, pc}

08003642 <I2C_WaitOnFlagUntilTimeout>:
  * @param  Tickstart Tick start value
  * @retval HAL status
  */
static HAL_StatusTypeDef I2C_WaitOnFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Flag, FlagStatus Status,
                                                    uint32_t Timeout, uint32_t Tickstart)
{
 8003642:	b580      	push	{r7, lr}
 8003644:	b084      	sub	sp, #16
 8003646:	af00      	add	r7, sp, #0
 8003648:	60f8      	str	r0, [r7, #12]
 800364a:	60b9      	str	r1, [r7, #8]
 800364c:	603b      	str	r3, [r7, #0]
 800364e:	4613      	mov	r3, r2
 8003650:	71fb      	strb	r3, [r7, #7]
  while (__HAL_I2C_GET_FLAG(hi2c, Flag) == Status)
 8003652:	e022      	b.n	800369a <I2C_WaitOnFlagUntilTimeout+0x58>
  {
    /* Check for the Timeout */
    if (Timeout != HAL_MAX_DELAY)
 8003654:	683b      	ldr	r3, [r7, #0]
 8003656:	f1b3 3fff 	cmp.w	r3, #4294967295
 800365a:	d01e      	beq.n	800369a <I2C_WaitOnFlagUntilTimeout+0x58>
    {
      if (((HAL_GetTick() - Tickstart) > Timeout) || (Timeout == 0U))
 800365c:	f7fe fcc2 	bl	8001fe4 <HAL_GetTick>
 8003660:	4602      	mov	r2, r0
 8003662:	69bb      	ldr	r3, [r7, #24]
 8003664:	1ad3      	subs	r3, r2, r3
 8003666:	683a      	ldr	r2, [r7, #0]
 8003668:	429a      	cmp	r2, r3
 800366a:	d302      	bcc.n	8003672 <I2C_WaitOnFlagUntilTimeout+0x30>
 800366c:	683b      	ldr	r3, [r7, #0]
 800366e:	2b00      	cmp	r3, #0
 8003670:	d113      	bne.n	800369a <I2C_WaitOnFlagUntilTimeout+0x58>
      {
        hi2c->ErrorCode |= HAL_I2C_ERROR_TIMEOUT;
 8003672:	68fb      	ldr	r3, [r7, #12]
 8003674:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8003676:	f043 0220 	orr.w	r2, r3, #32
 800367a:	68fb      	ldr	r3, [r7, #12]
 800367c:	645a      	str	r2, [r3, #68]	; 0x44
        hi2c->State = HAL_I2C_STATE_READY;
 800367e:	68fb      	ldr	r3, [r7, #12]
 8003680:	2220      	movs	r2, #32
 8003682:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
        hi2c->Mode = HAL_I2C_MODE_NONE;
 8003686:	68fb      	ldr	r3, [r7, #12]
 8003688:	2200      	movs	r2, #0
 800368a:	f883 2042 	strb.w	r2, [r3, #66]	; 0x42

        /* Process Unlocked */
        __HAL_UNLOCK(hi2c);
 800368e:	68fb      	ldr	r3, [r7, #12]
 8003690:	2200      	movs	r2, #0
 8003692:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40
        return HAL_ERROR;
 8003696:	2301      	movs	r3, #1
 8003698:	e00f      	b.n	80036ba <I2C_WaitOnFlagUntilTimeout+0x78>
  while (__HAL_I2C_GET_FLAG(hi2c, Flag) == Status)
 800369a:	68fb      	ldr	r3, [r7, #12]
 800369c:	681b      	ldr	r3, [r3, #0]
 800369e:	699a      	ldr	r2, [r3, #24]
 80036a0:	68bb      	ldr	r3, [r7, #8]
 80036a2:	4013      	ands	r3, r2
 80036a4:	68ba      	ldr	r2, [r7, #8]
 80036a6:	429a      	cmp	r2, r3
 80036a8:	bf0c      	ite	eq
 80036aa:	2301      	moveq	r3, #1
 80036ac:	2300      	movne	r3, #0
 80036ae:	b2db      	uxtb	r3, r3
 80036b0:	461a      	mov	r2, r3
 80036b2:	79fb      	ldrb	r3, [r7, #7]
 80036b4:	429a      	cmp	r2, r3
 80036b6:	d0cd      	beq.n	8003654 <I2C_WaitOnFlagUntilTimeout+0x12>
      }
    }
  }
  return HAL_OK;
 80036b8:	2300      	movs	r3, #0
}
 80036ba:	4618      	mov	r0, r3
 80036bc:	3710      	adds	r7, #16
 80036be:	46bd      	mov	sp, r7
 80036c0:	bd80      	pop	{r7, pc}

080036c2 <I2C_WaitOnTXISFlagUntilTimeout>:
  * @param  Tickstart Tick start value
  * @retval HAL status
  */
static HAL_StatusTypeDef I2C_WaitOnTXISFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Timeout,
                                                        uint32_t Tickstart)
{
 80036c2:	b580      	push	{r7, lr}
 80036c4:	b084      	sub	sp, #16
 80036c6:	af00      	add	r7, sp, #0
 80036c8:	60f8      	str	r0, [r7, #12]
 80036ca:	60b9      	str	r1, [r7, #8]
 80036cc:	607a      	str	r2, [r7, #4]
  while (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_TXIS) == RESET)
 80036ce:	e02c      	b.n	800372a <I2C_WaitOnTXISFlagUntilTimeout+0x68>
  {
    /* Check if an error is detected */
    if (I2C_IsErrorOccurred(hi2c, Timeout, Tickstart) != HAL_OK)
 80036d0:	687a      	ldr	r2, [r7, #4]
 80036d2:	68b9      	ldr	r1, [r7, #8]
 80036d4:	68f8      	ldr	r0, [r7, #12]
 80036d6:	f000 f871 	bl	80037bc <I2C_IsErrorOccurred>
 80036da:	4603      	mov	r3, r0
 80036dc:	2b00      	cmp	r3, #0
 80036de:	d001      	beq.n	80036e4 <I2C_WaitOnTXISFlagUntilTimeout+0x22>
    {
      return HAL_ERROR;
 80036e0:	2301      	movs	r3, #1
 80036e2:	e02a      	b.n	800373a <I2C_WaitOnTXISFlagUntilTimeout+0x78>
    }

    /* Check for the Timeout */
    if (Timeout != HAL_MAX_DELAY)
 80036e4:	68bb      	ldr	r3, [r7, #8]
 80036e6:	f1b3 3fff 	cmp.w	r3, #4294967295
 80036ea:	d01e      	beq.n	800372a <I2C_WaitOnTXISFlagUntilTimeout+0x68>
    {
      if (((HAL_GetTick() - Tickstart) > Timeout) || (Timeout == 0U))
 80036ec:	f7fe fc7a 	bl	8001fe4 <HAL_GetTick>
 80036f0:	4602      	mov	r2, r0
 80036f2:	687b      	ldr	r3, [r7, #4]
 80036f4:	1ad3      	subs	r3, r2, r3
 80036f6:	68ba      	ldr	r2, [r7, #8]
 80036f8:	429a      	cmp	r2, r3
 80036fa:	d302      	bcc.n	8003702 <I2C_WaitOnTXISFlagUntilTimeout+0x40>
 80036fc:	68bb      	ldr	r3, [r7, #8]
 80036fe:	2b00      	cmp	r3, #0
 8003700:	d113      	bne.n	800372a <I2C_WaitOnTXISFlagUntilTimeout+0x68>
      {
        hi2c->ErrorCode |= HAL_I2C_ERROR_TIMEOUT;
 8003702:	68fb      	ldr	r3, [r7, #12]
 8003704:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8003706:	f043 0220 	orr.w	r2, r3, #32
 800370a:	68fb      	ldr	r3, [r7, #12]
 800370c:	645a      	str	r2, [r3, #68]	; 0x44
        hi2c->State = HAL_I2C_STATE_READY;
 800370e:	68fb      	ldr	r3, [r7, #12]
 8003710:	2220      	movs	r2, #32
 8003712:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
        hi2c->Mode = HAL_I2C_MODE_NONE;
 8003716:	68fb      	ldr	r3, [r7, #12]
 8003718:	2200      	movs	r2, #0
 800371a:	f883 2042 	strb.w	r2, [r3, #66]	; 0x42

        /* Process Unlocked */
        __HAL_UNLOCK(hi2c);
 800371e:	68fb      	ldr	r3, [r7, #12]
 8003720:	2200      	movs	r2, #0
 8003722:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

        return HAL_ERROR;
 8003726:	2301      	movs	r3, #1
 8003728:	e007      	b.n	800373a <I2C_WaitOnTXISFlagUntilTimeout+0x78>
  while (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_TXIS) == RESET)
 800372a:	68fb      	ldr	r3, [r7, #12]
 800372c:	681b      	ldr	r3, [r3, #0]
 800372e:	699b      	ldr	r3, [r3, #24]
 8003730:	f003 0302 	and.w	r3, r3, #2
 8003734:	2b02      	cmp	r3, #2
 8003736:	d1cb      	bne.n	80036d0 <I2C_WaitOnTXISFlagUntilTimeout+0xe>
      }
    }
  }
  return HAL_OK;
 8003738:	2300      	movs	r3, #0
}
 800373a:	4618      	mov	r0, r3
 800373c:	3710      	adds	r7, #16
 800373e:	46bd      	mov	sp, r7
 8003740:	bd80      	pop	{r7, pc}

08003742 <I2C_WaitOnSTOPFlagUntilTimeout>:
  * @param  Tickstart Tick start value
  * @retval HAL status
  */
static HAL_StatusTypeDef I2C_WaitOnSTOPFlagUntilTimeout(I2C_HandleTypeDef *hi2c, uint32_t Timeout,
                                                        uint32_t Tickstart)
{
 8003742:	b580      	push	{r7, lr}
 8003744:	b084      	sub	sp, #16
 8003746:	af00      	add	r7, sp, #0
 8003748:	60f8      	str	r0, [r7, #12]
 800374a:	60b9      	str	r1, [r7, #8]
 800374c:	607a      	str	r2, [r7, #4]
  while (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_STOPF) == RESET)
 800374e:	e028      	b.n	80037a2 <I2C_WaitOnSTOPFlagUntilTimeout+0x60>
  {
    /* Check if an error is detected */
    if (I2C_IsErrorOccurred(hi2c, Timeout, Tickstart) != HAL_OK)
 8003750:	687a      	ldr	r2, [r7, #4]
 8003752:	68b9      	ldr	r1, [r7, #8]
 8003754:	68f8      	ldr	r0, [r7, #12]
 8003756:	f000 f831 	bl	80037bc <I2C_IsErrorOccurred>
 800375a:	4603      	mov	r3, r0
 800375c:	2b00      	cmp	r3, #0
 800375e:	d001      	beq.n	8003764 <I2C_WaitOnSTOPFlagUntilTimeout+0x22>
    {
      return HAL_ERROR;
 8003760:	2301      	movs	r3, #1
 8003762:	e026      	b.n	80037b2 <I2C_WaitOnSTOPFlagUntilTimeout+0x70>
    }

    /* Check for the Timeout */
    if (((HAL_GetTick() - Tickstart) > Timeout) || (Timeout == 0U))
 8003764:	f7fe fc3e 	bl	8001fe4 <HAL_GetTick>
 8003768:	4602      	mov	r2, r0
 800376a:	687b      	ldr	r3, [r7, #4]
 800376c:	1ad3      	subs	r3, r2, r3
 800376e:	68ba      	ldr	r2, [r7, #8]
 8003770:	429a      	cmp	r2, r3
 8003772:	d302      	bcc.n	800377a <I2C_WaitOnSTOPFlagUntilTimeout+0x38>
 8003774:	68bb      	ldr	r3, [r7, #8]
 8003776:	2b00      	cmp	r3, #0
 8003778:	d113      	bne.n	80037a2 <I2C_WaitOnSTOPFlagUntilTimeout+0x60>
    {
      hi2c->ErrorCode |= HAL_I2C_ERROR_TIMEOUT;
 800377a:	68fb      	ldr	r3, [r7, #12]
 800377c:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 800377e:	f043 0220 	orr.w	r2, r3, #32
 8003782:	68fb      	ldr	r3, [r7, #12]
 8003784:	645a      	str	r2, [r3, #68]	; 0x44
      hi2c->State = HAL_I2C_STATE_READY;
 8003786:	68fb      	ldr	r3, [r7, #12]
 8003788:	2220      	movs	r2, #32
 800378a:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
      hi2c->Mode = HAL_I2C_MODE_NONE;
 800378e:	68fb      	ldr	r3, [r7, #12]
 8003790:	2200      	movs	r2, #0
 8003792:	f883 2042 	strb.w	r2, [r3, #66]	; 0x42

      /* Process Unlocked */
      __HAL_UNLOCK(hi2c);
 8003796:	68fb      	ldr	r3, [r7, #12]
 8003798:	2200      	movs	r2, #0
 800379a:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

      return HAL_ERROR;
 800379e:	2301      	movs	r3, #1
 80037a0:	e007      	b.n	80037b2 <I2C_WaitOnSTOPFlagUntilTimeout+0x70>
  while (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_STOPF) == RESET)
 80037a2:	68fb      	ldr	r3, [r7, #12]
 80037a4:	681b      	ldr	r3, [r3, #0]
 80037a6:	699b      	ldr	r3, [r3, #24]
 80037a8:	f003 0320 	and.w	r3, r3, #32
 80037ac:	2b20      	cmp	r3, #32
 80037ae:	d1cf      	bne.n	8003750 <I2C_WaitOnSTOPFlagUntilTimeout+0xe>
    }
  }
  return HAL_OK;
 80037b0:	2300      	movs	r3, #0
}
 80037b2:	4618      	mov	r0, r3
 80037b4:	3710      	adds	r7, #16
 80037b6:	46bd      	mov	sp, r7
 80037b8:	bd80      	pop	{r7, pc}
	...

080037bc <I2C_IsErrorOccurred>:
  * @param  Timeout Timeout duration
  * @param  Tickstart Tick start value
  * @retval HAL status
  */
static HAL_StatusTypeDef I2C_IsErrorOccurred(I2C_HandleTypeDef *hi2c, uint32_t Timeout, uint32_t Tickstart)
{
 80037bc:	b580      	push	{r7, lr}
 80037be:	b08a      	sub	sp, #40	; 0x28
 80037c0:	af00      	add	r7, sp, #0
 80037c2:	60f8      	str	r0, [r7, #12]
 80037c4:	60b9      	str	r1, [r7, #8]
 80037c6:	607a      	str	r2, [r7, #4]
  HAL_StatusTypeDef status = HAL_OK;
 80037c8:	2300      	movs	r3, #0
 80037ca:	f887 3027 	strb.w	r3, [r7, #39]	; 0x27
  uint32_t itflag   = hi2c->Instance->ISR;
 80037ce:	68fb      	ldr	r3, [r7, #12]
 80037d0:	681b      	ldr	r3, [r3, #0]
 80037d2:	699b      	ldr	r3, [r3, #24]
 80037d4:	61bb      	str	r3, [r7, #24]
  uint32_t error_code = 0;
 80037d6:	2300      	movs	r3, #0
 80037d8:	623b      	str	r3, [r7, #32]
  uint32_t tickstart = Tickstart;
 80037da:	687b      	ldr	r3, [r7, #4]
 80037dc:	61fb      	str	r3, [r7, #28]
  uint32_t tmp1;
  HAL_I2C_ModeTypeDef tmp2;

  if (HAL_IS_BIT_SET(itflag, I2C_FLAG_AF))
 80037de:	69bb      	ldr	r3, [r7, #24]
 80037e0:	f003 0310 	and.w	r3, r3, #16
 80037e4:	2b00      	cmp	r3, #0
 80037e6:	d075      	beq.n	80038d4 <I2C_IsErrorOccurred+0x118>
  {
    /* Clear NACKF Flag */
    __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF);
 80037e8:	68fb      	ldr	r3, [r7, #12]
 80037ea:	681b      	ldr	r3, [r3, #0]
 80037ec:	2210      	movs	r2, #16
 80037ee:	61da      	str	r2, [r3, #28]

    /* Wait until STOP Flag is set or timeout occurred */
    /* AutoEnd should be initiate after AF */
    while ((__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_STOPF) == RESET) && (status == HAL_OK))
 80037f0:	e056      	b.n	80038a0 <I2C_IsErrorOccurred+0xe4>
    {
      /* Check for the Timeout */
      if (Timeout != HAL_MAX_DELAY)
 80037f2:	68bb      	ldr	r3, [r7, #8]
 80037f4:	f1b3 3fff 	cmp.w	r3, #4294967295
 80037f8:	d052      	beq.n	80038a0 <I2C_IsErrorOccurred+0xe4>
      {
        if (((HAL_GetTick() - tickstart) > Timeout) || (Timeout == 0U))
 80037fa:	f7fe fbf3 	bl	8001fe4 <HAL_GetTick>
 80037fe:	4602      	mov	r2, r0
 8003800:	69fb      	ldr	r3, [r7, #28]
 8003802:	1ad3      	subs	r3, r2, r3
 8003804:	68ba      	ldr	r2, [r7, #8]
 8003806:	429a      	cmp	r2, r3
 8003808:	d302      	bcc.n	8003810 <I2C_IsErrorOccurred+0x54>
 800380a:	68bb      	ldr	r3, [r7, #8]
 800380c:	2b00      	cmp	r3, #0
 800380e:	d147      	bne.n	80038a0 <I2C_IsErrorOccurred+0xe4>
        {
          tmp1 = (uint32_t)(hi2c->Instance->CR2 & I2C_CR2_STOP);
 8003810:	68fb      	ldr	r3, [r7, #12]
 8003812:	681b      	ldr	r3, [r3, #0]
 8003814:	685b      	ldr	r3, [r3, #4]
 8003816:	f403 4380 	and.w	r3, r3, #16384	; 0x4000
 800381a:	617b      	str	r3, [r7, #20]
          tmp2 = hi2c->Mode;
 800381c:	68fb      	ldr	r3, [r7, #12]
 800381e:	f893 3042 	ldrb.w	r3, [r3, #66]	; 0x42
 8003822:	74fb      	strb	r3, [r7, #19]

          /* In case of I2C still busy, try to regenerate a STOP manually */
          if ((__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_BUSY) != RESET) && \
 8003824:	68fb      	ldr	r3, [r7, #12]
 8003826:	681b      	ldr	r3, [r3, #0]
 8003828:	699b      	ldr	r3, [r3, #24]
 800382a:	f403 4300 	and.w	r3, r3, #32768	; 0x8000
 800382e:	f5b3 4f00 	cmp.w	r3, #32768	; 0x8000
 8003832:	d12e      	bne.n	8003892 <I2C_IsErrorOccurred+0xd6>
 8003834:	697b      	ldr	r3, [r7, #20]
 8003836:	f5b3 4f80 	cmp.w	r3, #16384	; 0x4000
 800383a:	d02a      	beq.n	8003892 <I2C_IsErrorOccurred+0xd6>
              (tmp1 != I2C_CR2_STOP) && \
 800383c:	7cfb      	ldrb	r3, [r7, #19]
 800383e:	2b20      	cmp	r3, #32
 8003840:	d027      	beq.n	8003892 <I2C_IsErrorOccurred+0xd6>
              (tmp2 != HAL_I2C_MODE_SLAVE))
          {
            /* Generate Stop */
            hi2c->Instance->CR2 |= I2C_CR2_STOP;
 8003842:	68fb      	ldr	r3, [r7, #12]
 8003844:	681b      	ldr	r3, [r3, #0]
 8003846:	685a      	ldr	r2, [r3, #4]
 8003848:	68fb      	ldr	r3, [r7, #12]
 800384a:	681b      	ldr	r3, [r3, #0]
 800384c:	f442 4280 	orr.w	r2, r2, #16384	; 0x4000
 8003850:	605a      	str	r2, [r3, #4]
            
            /* Update Tick with new reference */
            tickstart = HAL_GetTick();
 8003852:	f7fe fbc7 	bl	8001fe4 <HAL_GetTick>
 8003856:	61f8      	str	r0, [r7, #28]
          }
          
          while (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_STOPF) == RESET)
 8003858:	e01b      	b.n	8003892 <I2C_IsErrorOccurred+0xd6>
          {
            /* Check for the Timeout */
            if ((HAL_GetTick() - tickstart) > I2C_TIMEOUT_STOPF)
 800385a:	f7fe fbc3 	bl	8001fe4 <HAL_GetTick>
 800385e:	4602      	mov	r2, r0
 8003860:	69fb      	ldr	r3, [r7, #28]
 8003862:	1ad3      	subs	r3, r2, r3
 8003864:	2b19      	cmp	r3, #25
 8003866:	d914      	bls.n	8003892 <I2C_IsErrorOccurred+0xd6>
            {
              hi2c->ErrorCode |= HAL_I2C_ERROR_TIMEOUT;
 8003868:	68fb      	ldr	r3, [r7, #12]
 800386a:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 800386c:	f043 0220 	orr.w	r2, r3, #32
 8003870:	68fb      	ldr	r3, [r7, #12]
 8003872:	645a      	str	r2, [r3, #68]	; 0x44
              hi2c->State = HAL_I2C_STATE_READY;
 8003874:	68fb      	ldr	r3, [r7, #12]
 8003876:	2220      	movs	r2, #32
 8003878:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
              hi2c->Mode = HAL_I2C_MODE_NONE;
 800387c:	68fb      	ldr	r3, [r7, #12]
 800387e:	2200      	movs	r2, #0
 8003880:	f883 2042 	strb.w	r2, [r3, #66]	; 0x42
              
              /* Process Unlocked */
              __HAL_UNLOCK(hi2c);
 8003884:	68fb      	ldr	r3, [r7, #12]
 8003886:	2200      	movs	r2, #0
 8003888:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40
              
              status = HAL_ERROR;
 800388c:	2301      	movs	r3, #1
 800388e:	f887 3027 	strb.w	r3, [r7, #39]	; 0x27
          while (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_STOPF) == RESET)
 8003892:	68fb      	ldr	r3, [r7, #12]
 8003894:	681b      	ldr	r3, [r3, #0]
 8003896:	699b      	ldr	r3, [r3, #24]
 8003898:	f003 0320 	and.w	r3, r3, #32
 800389c:	2b20      	cmp	r3, #32
 800389e:	d1dc      	bne.n	800385a <I2C_IsErrorOccurred+0x9e>
    while ((__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_STOPF) == RESET) && (status == HAL_OK))
 80038a0:	68fb      	ldr	r3, [r7, #12]
 80038a2:	681b      	ldr	r3, [r3, #0]
 80038a4:	699b      	ldr	r3, [r3, #24]
 80038a6:	f003 0320 	and.w	r3, r3, #32
 80038aa:	2b20      	cmp	r3, #32
 80038ac:	d003      	beq.n	80038b6 <I2C_IsErrorOccurred+0xfa>
 80038ae:	f897 3027 	ldrb.w	r3, [r7, #39]	; 0x27
 80038b2:	2b00      	cmp	r3, #0
 80038b4:	d09d      	beq.n	80037f2 <I2C_IsErrorOccurred+0x36>
        }
      }
    }

    /* In case STOP Flag is detected, clear it */
    if (status == HAL_OK)
 80038b6:	f897 3027 	ldrb.w	r3, [r7, #39]	; 0x27
 80038ba:	2b00      	cmp	r3, #0
 80038bc:	d103      	bne.n	80038c6 <I2C_IsErrorOccurred+0x10a>
    {
      /* Clear STOP Flag */
      __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF);
 80038be:	68fb      	ldr	r3, [r7, #12]
 80038c0:	681b      	ldr	r3, [r3, #0]
 80038c2:	2220      	movs	r2, #32
 80038c4:	61da      	str	r2, [r3, #28]
    }

    error_code |= HAL_I2C_ERROR_AF;
 80038c6:	6a3b      	ldr	r3, [r7, #32]
 80038c8:	f043 0304 	orr.w	r3, r3, #4
 80038cc:	623b      	str	r3, [r7, #32]

    status = HAL_ERROR;
 80038ce:	2301      	movs	r3, #1
 80038d0:	f887 3027 	strb.w	r3, [r7, #39]	; 0x27
  }

  /* Refresh Content of Status register */
  itflag = hi2c->Instance->ISR;
 80038d4:	68fb      	ldr	r3, [r7, #12]
 80038d6:	681b      	ldr	r3, [r3, #0]
 80038d8:	699b      	ldr	r3, [r3, #24]
 80038da:	61bb      	str	r3, [r7, #24]

  /* Then verify if an additional errors occurs */
  /* Check if a Bus error occurred */
  if (HAL_IS_BIT_SET(itflag, I2C_FLAG_BERR))
 80038dc:	69bb      	ldr	r3, [r7, #24]
 80038de:	f403 7380 	and.w	r3, r3, #256	; 0x100
 80038e2:	2b00      	cmp	r3, #0
 80038e4:	d00b      	beq.n	80038fe <I2C_IsErrorOccurred+0x142>
  {
    error_code |= HAL_I2C_ERROR_BERR;
 80038e6:	6a3b      	ldr	r3, [r7, #32]
 80038e8:	f043 0301 	orr.w	r3, r3, #1
 80038ec:	623b      	str	r3, [r7, #32]

    /* Clear BERR flag */
    __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_BERR);
 80038ee:	68fb      	ldr	r3, [r7, #12]
 80038f0:	681b      	ldr	r3, [r3, #0]
 80038f2:	f44f 7280 	mov.w	r2, #256	; 0x100
 80038f6:	61da      	str	r2, [r3, #28]

    status = HAL_ERROR;
 80038f8:	2301      	movs	r3, #1
 80038fa:	f887 3027 	strb.w	r3, [r7, #39]	; 0x27
  }

  /* Check if an Over-Run/Under-Run error occurred */
  if (HAL_IS_BIT_SET(itflag, I2C_FLAG_OVR))
 80038fe:	69bb      	ldr	r3, [r7, #24]
 8003900:	f403 6380 	and.w	r3, r3, #1024	; 0x400
 8003904:	2b00      	cmp	r3, #0
 8003906:	d00b      	beq.n	8003920 <I2C_IsErrorOccurred+0x164>
  {
    error_code |= HAL_I2C_ERROR_OVR;
 8003908:	6a3b      	ldr	r3, [r7, #32]
 800390a:	f043 0308 	orr.w	r3, r3, #8
 800390e:	623b      	str	r3, [r7, #32]

    /* Clear OVR flag */
    __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_OVR);
 8003910:	68fb      	ldr	r3, [r7, #12]
 8003912:	681b      	ldr	r3, [r3, #0]
 8003914:	f44f 6280 	mov.w	r2, #1024	; 0x400
 8003918:	61da      	str	r2, [r3, #28]

    status = HAL_ERROR;
 800391a:	2301      	movs	r3, #1
 800391c:	f887 3027 	strb.w	r3, [r7, #39]	; 0x27
  }

  /* Check if an Arbitration Loss error occurred */
  if (HAL_IS_BIT_SET(itflag, I2C_FLAG_ARLO))
 8003920:	69bb      	ldr	r3, [r7, #24]
 8003922:	f403 7300 	and.w	r3, r3, #512	; 0x200
 8003926:	2b00      	cmp	r3, #0
 8003928:	d00b      	beq.n	8003942 <I2C_IsErrorOccurred+0x186>
  {
    error_code |= HAL_I2C_ERROR_ARLO;
 800392a:	6a3b      	ldr	r3, [r7, #32]
 800392c:	f043 0302 	orr.w	r3, r3, #2
 8003930:	623b      	str	r3, [r7, #32]

    /* Clear ARLO flag */
    __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_ARLO);
 8003932:	68fb      	ldr	r3, [r7, #12]
 8003934:	681b      	ldr	r3, [r3, #0]
 8003936:	f44f 7200 	mov.w	r2, #512	; 0x200
 800393a:	61da      	str	r2, [r3, #28]

    status = HAL_ERROR;
 800393c:	2301      	movs	r3, #1
 800393e:	f887 3027 	strb.w	r3, [r7, #39]	; 0x27
  }

  if (status != HAL_OK)
 8003942:	f897 3027 	ldrb.w	r3, [r7, #39]	; 0x27
 8003946:	2b00      	cmp	r3, #0
 8003948:	d01c      	beq.n	8003984 <I2C_IsErrorOccurred+0x1c8>
  {
    /* Flush TX register */
    I2C_Flush_TXDR(hi2c);
 800394a:	68f8      	ldr	r0, [r7, #12]
 800394c:	f7ff fe37 	bl	80035be <I2C_Flush_TXDR>

    /* Clear Configuration Register 2 */
    I2C_RESET_CR2(hi2c);
 8003950:	68fb      	ldr	r3, [r7, #12]
 8003952:	681b      	ldr	r3, [r3, #0]
 8003954:	6859      	ldr	r1, [r3, #4]
 8003956:	68fb      	ldr	r3, [r7, #12]
 8003958:	681a      	ldr	r2, [r3, #0]
 800395a:	4b0d      	ldr	r3, [pc, #52]	; (8003990 <I2C_IsErrorOccurred+0x1d4>)
 800395c:	400b      	ands	r3, r1
 800395e:	6053      	str	r3, [r2, #4]

    hi2c->ErrorCode |= error_code;
 8003960:	68fb      	ldr	r3, [r7, #12]
 8003962:	6c5a      	ldr	r2, [r3, #68]	; 0x44
 8003964:	6a3b      	ldr	r3, [r7, #32]
 8003966:	431a      	orrs	r2, r3
 8003968:	68fb      	ldr	r3, [r7, #12]
 800396a:	645a      	str	r2, [r3, #68]	; 0x44
    hi2c->State = HAL_I2C_STATE_READY;
 800396c:	68fb      	ldr	r3, [r7, #12]
 800396e:	2220      	movs	r2, #32
 8003970:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
    hi2c->Mode = HAL_I2C_MODE_NONE;
 8003974:	68fb      	ldr	r3, [r7, #12]
 8003976:	2200      	movs	r2, #0
 8003978:	f883 2042 	strb.w	r2, [r3, #66]	; 0x42

    /* Process Unlocked */
    __HAL_UNLOCK(hi2c);
 800397c:	68fb      	ldr	r3, [r7, #12]
 800397e:	2200      	movs	r2, #0
 8003980:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40
  }

  return status;
 8003984:	f897 3027 	ldrb.w	r3, [r7, #39]	; 0x27
}
 8003988:	4618      	mov	r0, r3
 800398a:	3728      	adds	r7, #40	; 0x28
 800398c:	46bd      	mov	sp, r7
 800398e:	bd80      	pop	{r7, pc}
 8003990:	fe00e800 	.word	0xfe00e800

08003994 <I2C_TransferConfig>:
  *     @arg @ref I2C_GENERATE_START_WRITE Generate Restart for write request.
  * @retval None
  */
static void I2C_TransferConfig(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t Size, uint32_t Mode,
                               uint32_t Request)
{
 8003994:	b480      	push	{r7}
 8003996:	b087      	sub	sp, #28
 8003998:	af00      	add	r7, sp, #0
 800399a:	60f8      	str	r0, [r7, #12]
 800399c:	607b      	str	r3, [r7, #4]
 800399e:	460b      	mov	r3, r1
 80039a0:	817b      	strh	r3, [r7, #10]
 80039a2:	4613      	mov	r3, r2
 80039a4:	727b      	strb	r3, [r7, #9]
  assert_param(IS_I2C_ALL_INSTANCE(hi2c->Instance));
  assert_param(IS_TRANSFER_MODE(Mode));
  assert_param(IS_TRANSFER_REQUEST(Request));

  /* Declaration of tmp to prevent undefined behavior of volatile usage */
  uint32_t tmp = ((uint32_t)(((uint32_t)DevAddress & I2C_CR2_SADD) | \
 80039a6:	897b      	ldrh	r3, [r7, #10]
 80039a8:	f3c3 0209 	ubfx	r2, r3, #0, #10
                            (((uint32_t)Size << I2C_CR2_NBYTES_Pos) & I2C_CR2_NBYTES) | \
 80039ac:	7a7b      	ldrb	r3, [r7, #9]
 80039ae:	041b      	lsls	r3, r3, #16
 80039b0:	f403 037f 	and.w	r3, r3, #16711680	; 0xff0000
  uint32_t tmp = ((uint32_t)(((uint32_t)DevAddress & I2C_CR2_SADD) | \
 80039b4:	431a      	orrs	r2, r3
                            (((uint32_t)Size << I2C_CR2_NBYTES_Pos) & I2C_CR2_NBYTES) | \
 80039b6:	687b      	ldr	r3, [r7, #4]
 80039b8:	431a      	orrs	r2, r3
  uint32_t tmp = ((uint32_t)(((uint32_t)DevAddress & I2C_CR2_SADD) | \
 80039ba:	6a3b      	ldr	r3, [r7, #32]
 80039bc:	4313      	orrs	r3, r2
 80039be:	f023 4300 	bic.w	r3, r3, #2147483648	; 0x80000000
 80039c2:	617b      	str	r3, [r7, #20]
                              (uint32_t)Mode | (uint32_t)Request) & (~0x80000000U));

  /* update CR2 register */
  MODIFY_REG(hi2c->Instance->CR2, \
 80039c4:	68fb      	ldr	r3, [r7, #12]
 80039c6:	681b      	ldr	r3, [r3, #0]
 80039c8:	685a      	ldr	r2, [r3, #4]
 80039ca:	6a3b      	ldr	r3, [r7, #32]
 80039cc:	0d5b      	lsrs	r3, r3, #21
 80039ce:	f403 6180 	and.w	r1, r3, #1024	; 0x400
 80039d2:	4b08      	ldr	r3, [pc, #32]	; (80039f4 <I2C_TransferConfig+0x60>)
 80039d4:	430b      	orrs	r3, r1
 80039d6:	43db      	mvns	r3, r3
 80039d8:	ea02 0103 	and.w	r1, r2, r3
 80039dc:	68fb      	ldr	r3, [r7, #12]
 80039de:	681b      	ldr	r3, [r3, #0]
 80039e0:	697a      	ldr	r2, [r7, #20]
 80039e2:	430a      	orrs	r2, r1
 80039e4:	605a      	str	r2, [r3, #4]
             ((I2C_CR2_SADD | I2C_CR2_NBYTES | I2C_CR2_RELOAD | I2C_CR2_AUTOEND | \
               (I2C_CR2_RD_WRN & (uint32_t)(Request >> (31U - I2C_CR2_RD_WRN_Pos))) | \
                I2C_CR2_START | I2C_CR2_STOP)), tmp);
}
 80039e6:	bf00      	nop
 80039e8:	371c      	adds	r7, #28
 80039ea:	46bd      	mov	sp, r7
 80039ec:	f85d 7b04 	ldr.w	r7, [sp], #4
 80039f0:	4770      	bx	lr
 80039f2:	bf00      	nop
 80039f4:	03ff63ff 	.word	0x03ff63ff

080039f8 <I2C_Disable_IRQ>:
  *                the configuration information for the specified I2C.
  * @param  InterruptRequest Value of @ref I2C_Interrupt_configuration_definition.
  * @retval None
  */
static void I2C_Disable_IRQ(I2C_HandleTypeDef *hi2c, uint16_t InterruptRequest)
{
 80039f8:	b480      	push	{r7}
 80039fa:	b085      	sub	sp, #20
 80039fc:	af00      	add	r7, sp, #0
 80039fe:	6078      	str	r0, [r7, #4]
 8003a00:	460b      	mov	r3, r1
 8003a02:	807b      	strh	r3, [r7, #2]
  uint32_t tmpisr = 0U;
 8003a04:	2300      	movs	r3, #0
 8003a06:	60fb      	str	r3, [r7, #12]

  if ((InterruptRequest & I2C_XFER_TX_IT) == I2C_XFER_TX_IT)
 8003a08:	887b      	ldrh	r3, [r7, #2]
 8003a0a:	f003 0301 	and.w	r3, r3, #1
 8003a0e:	2b00      	cmp	r3, #0
 8003a10:	d00f      	beq.n	8003a32 <I2C_Disable_IRQ+0x3a>
  {
    /* Disable TC and TXI interrupts */
    tmpisr |= I2C_IT_TCI | I2C_IT_TXI;
 8003a12:	68fb      	ldr	r3, [r7, #12]
 8003a14:	f043 0342 	orr.w	r3, r3, #66	; 0x42
 8003a18:	60fb      	str	r3, [r7, #12]

    if (((uint32_t)hi2c->State & (uint32_t)HAL_I2C_STATE_LISTEN) != (uint32_t)HAL_I2C_STATE_LISTEN)
 8003a1a:	687b      	ldr	r3, [r7, #4]
 8003a1c:	f893 3041 	ldrb.w	r3, [r3, #65]	; 0x41
 8003a20:	b2db      	uxtb	r3, r3
 8003a22:	f003 0328 	and.w	r3, r3, #40	; 0x28
 8003a26:	2b28      	cmp	r3, #40	; 0x28
 8003a28:	d003      	beq.n	8003a32 <I2C_Disable_IRQ+0x3a>
    {
      /* Disable NACK and STOP interrupts */
      tmpisr |= I2C_IT_STOPI | I2C_IT_NACKI | I2C_IT_ERRI;
 8003a2a:	68fb      	ldr	r3, [r7, #12]
 8003a2c:	f043 03b0 	orr.w	r3, r3, #176	; 0xb0
 8003a30:	60fb      	str	r3, [r7, #12]
    }
  }

  if ((InterruptRequest & I2C_XFER_RX_IT) == I2C_XFER_RX_IT)
 8003a32:	887b      	ldrh	r3, [r7, #2]
 8003a34:	f003 0302 	and.w	r3, r3, #2
 8003a38:	2b00      	cmp	r3, #0
 8003a3a:	d00f      	beq.n	8003a5c <I2C_Disable_IRQ+0x64>
  {
    /* Disable TC and RXI interrupts */
    tmpisr |= I2C_IT_TCI | I2C_IT_RXI;
 8003a3c:	68fb      	ldr	r3, [r7, #12]
 8003a3e:	f043 0344 	orr.w	r3, r3, #68	; 0x44
 8003a42:	60fb      	str	r3, [r7, #12]

    if (((uint32_t)hi2c->State & (uint32_t)HAL_I2C_STATE_LISTEN) != (uint32_t)HAL_I2C_STATE_LISTEN)
 8003a44:	687b      	ldr	r3, [r7, #4]
 8003a46:	f893 3041 	ldrb.w	r3, [r3, #65]	; 0x41
 8003a4a:	b2db      	uxtb	r3, r3
 8003a4c:	f003 0328 	and.w	r3, r3, #40	; 0x28
 8003a50:	2b28      	cmp	r3, #40	; 0x28
 8003a52:	d003      	beq.n	8003a5c <I2C_Disable_IRQ+0x64>
    {
      /* Disable NACK and STOP interrupts */
      tmpisr |= I2C_IT_STOPI | I2C_IT_NACKI | I2C_IT_ERRI;
 8003a54:	68fb      	ldr	r3, [r7, #12]
 8003a56:	f043 03b0 	orr.w	r3, r3, #176	; 0xb0
 8003a5a:	60fb      	str	r3, [r7, #12]
    }
  }

  if ((InterruptRequest & I2C_XFER_LISTEN_IT) == I2C_XFER_LISTEN_IT)
 8003a5c:	f9b7 3002 	ldrsh.w	r3, [r7, #2]
 8003a60:	2b00      	cmp	r3, #0
 8003a62:	da03      	bge.n	8003a6c <I2C_Disable_IRQ+0x74>
  {
    /* Disable ADDR, NACK and STOP interrupts */
    tmpisr |= I2C_IT_ADDRI | I2C_IT_STOPI | I2C_IT_NACKI | I2C_IT_ERRI;
 8003a64:	68fb      	ldr	r3, [r7, #12]
 8003a66:	f043 03b8 	orr.w	r3, r3, #184	; 0xb8
 8003a6a:	60fb      	str	r3, [r7, #12]
  }

  if (InterruptRequest == I2C_XFER_ERROR_IT)
 8003a6c:	887b      	ldrh	r3, [r7, #2]
 8003a6e:	2b10      	cmp	r3, #16
 8003a70:	d103      	bne.n	8003a7a <I2C_Disable_IRQ+0x82>
  {
    /* Enable ERR and NACK interrupts */
    tmpisr |= I2C_IT_ERRI | I2C_IT_NACKI;
 8003a72:	68fb      	ldr	r3, [r7, #12]
 8003a74:	f043 0390 	orr.w	r3, r3, #144	; 0x90
 8003a78:	60fb      	str	r3, [r7, #12]
  }

  if (InterruptRequest == I2C_XFER_CPLT_IT)
 8003a7a:	887b      	ldrh	r3, [r7, #2]
 8003a7c:	2b20      	cmp	r3, #32
 8003a7e:	d103      	bne.n	8003a88 <I2C_Disable_IRQ+0x90>
  {
    /* Enable STOP interrupts */
    tmpisr |= I2C_IT_STOPI;
 8003a80:	68fb      	ldr	r3, [r7, #12]
 8003a82:	f043 0320 	orr.w	r3, r3, #32
 8003a86:	60fb      	str	r3, [r7, #12]
  }

  if (InterruptRequest == I2C_XFER_RELOAD_IT)
 8003a88:	887b      	ldrh	r3, [r7, #2]
 8003a8a:	2b40      	cmp	r3, #64	; 0x40
 8003a8c:	d103      	bne.n	8003a96 <I2C_Disable_IRQ+0x9e>
  {
    /* Enable TC interrupts */
    tmpisr |= I2C_IT_TCI;
 8003a8e:	68fb      	ldr	r3, [r7, #12]
 8003a90:	f043 0340 	orr.w	r3, r3, #64	; 0x40
 8003a94:	60fb      	str	r3, [r7, #12]
  }

  /* Disable interrupts only at the end */
  /* to avoid a breaking situation like at "t" time */
  /* all disable interrupts request are not done */
  __HAL_I2C_DISABLE_IT(hi2c, tmpisr);
 8003a96:	687b      	ldr	r3, [r7, #4]
 8003a98:	681b      	ldr	r3, [r3, #0]
 8003a9a:	6819      	ldr	r1, [r3, #0]
 8003a9c:	68fb      	ldr	r3, [r7, #12]
 8003a9e:	43da      	mvns	r2, r3
 8003aa0:	687b      	ldr	r3, [r7, #4]
 8003aa2:	681b      	ldr	r3, [r3, #0]
 8003aa4:	400a      	ands	r2, r1
 8003aa6:	601a      	str	r2, [r3, #0]
}
 8003aa8:	bf00      	nop
 8003aaa:	3714      	adds	r7, #20
 8003aac:	46bd      	mov	sp, r7
 8003aae:	f85d 7b04 	ldr.w	r7, [sp], #4
 8003ab2:	4770      	bx	lr

08003ab4 <HAL_I2CEx_ConfigAnalogFilter>:
  *                the configuration information for the specified I2Cx peripheral.
  * @param  AnalogFilter New state of the Analog filter.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_I2CEx_ConfigAnalogFilter(I2C_HandleTypeDef *hi2c, uint32_t AnalogFilter)
{
 8003ab4:	b480      	push	{r7}
 8003ab6:	b083      	sub	sp, #12
 8003ab8:	af00      	add	r7, sp, #0
 8003aba:	6078      	str	r0, [r7, #4]
 8003abc:	6039      	str	r1, [r7, #0]
  /* Check the parameters */
  assert_param(IS_I2C_ALL_INSTANCE(hi2c->Instance));
  assert_param(IS_I2C_ANALOG_FILTER(AnalogFilter));

  if (hi2c->State == HAL_I2C_STATE_READY)
 8003abe:	687b      	ldr	r3, [r7, #4]
 8003ac0:	f893 3041 	ldrb.w	r3, [r3, #65]	; 0x41
 8003ac4:	b2db      	uxtb	r3, r3
 8003ac6:	2b20      	cmp	r3, #32
 8003ac8:	d138      	bne.n	8003b3c <HAL_I2CEx_ConfigAnalogFilter+0x88>
  {
    /* Process Locked */
    __HAL_LOCK(hi2c);
 8003aca:	687b      	ldr	r3, [r7, #4]
 8003acc:	f893 3040 	ldrb.w	r3, [r3, #64]	; 0x40
 8003ad0:	2b01      	cmp	r3, #1
 8003ad2:	d101      	bne.n	8003ad8 <HAL_I2CEx_ConfigAnalogFilter+0x24>
 8003ad4:	2302      	movs	r3, #2
 8003ad6:	e032      	b.n	8003b3e <HAL_I2CEx_ConfigAnalogFilter+0x8a>
 8003ad8:	687b      	ldr	r3, [r7, #4]
 8003ada:	2201      	movs	r2, #1
 8003adc:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

    hi2c->State = HAL_I2C_STATE_BUSY;
 8003ae0:	687b      	ldr	r3, [r7, #4]
 8003ae2:	2224      	movs	r2, #36	; 0x24
 8003ae4:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41

    /* Disable the selected I2C peripheral */
    __HAL_I2C_DISABLE(hi2c);
 8003ae8:	687b      	ldr	r3, [r7, #4]
 8003aea:	681b      	ldr	r3, [r3, #0]
 8003aec:	681a      	ldr	r2, [r3, #0]
 8003aee:	687b      	ldr	r3, [r7, #4]
 8003af0:	681b      	ldr	r3, [r3, #0]
 8003af2:	f022 0201 	bic.w	r2, r2, #1
 8003af6:	601a      	str	r2, [r3, #0]

    /* Reset I2Cx ANOFF bit */
    hi2c->Instance->CR1 &= ~(I2C_CR1_ANFOFF);
 8003af8:	687b      	ldr	r3, [r7, #4]
 8003afa:	681b      	ldr	r3, [r3, #0]
 8003afc:	681a      	ldr	r2, [r3, #0]
 8003afe:	687b      	ldr	r3, [r7, #4]
 8003b00:	681b      	ldr	r3, [r3, #0]
 8003b02:	f422 5280 	bic.w	r2, r2, #4096	; 0x1000
 8003b06:	601a      	str	r2, [r3, #0]

    /* Set analog filter bit*/
    hi2c->Instance->CR1 |= AnalogFilter;
 8003b08:	687b      	ldr	r3, [r7, #4]
 8003b0a:	681b      	ldr	r3, [r3, #0]
 8003b0c:	6819      	ldr	r1, [r3, #0]
 8003b0e:	687b      	ldr	r3, [r7, #4]
 8003b10:	681b      	ldr	r3, [r3, #0]
 8003b12:	683a      	ldr	r2, [r7, #0]
 8003b14:	430a      	orrs	r2, r1
 8003b16:	601a      	str	r2, [r3, #0]

    __HAL_I2C_ENABLE(hi2c);
 8003b18:	687b      	ldr	r3, [r7, #4]
 8003b1a:	681b      	ldr	r3, [r3, #0]
 8003b1c:	681a      	ldr	r2, [r3, #0]
 8003b1e:	687b      	ldr	r3, [r7, #4]
 8003b20:	681b      	ldr	r3, [r3, #0]
 8003b22:	f042 0201 	orr.w	r2, r2, #1
 8003b26:	601a      	str	r2, [r3, #0]

    hi2c->State = HAL_I2C_STATE_READY;
 8003b28:	687b      	ldr	r3, [r7, #4]
 8003b2a:	2220      	movs	r2, #32
 8003b2c:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41

    /* Process Unlocked */
    __HAL_UNLOCK(hi2c);
 8003b30:	687b      	ldr	r3, [r7, #4]
 8003b32:	2200      	movs	r2, #0
 8003b34:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

    return HAL_OK;
 8003b38:	2300      	movs	r3, #0
 8003b3a:	e000      	b.n	8003b3e <HAL_I2CEx_ConfigAnalogFilter+0x8a>
  }
  else
  {
    return HAL_BUSY;
 8003b3c:	2302      	movs	r3, #2
  }
}
 8003b3e:	4618      	mov	r0, r3
 8003b40:	370c      	adds	r7, #12
 8003b42:	46bd      	mov	sp, r7
 8003b44:	f85d 7b04 	ldr.w	r7, [sp], #4
 8003b48:	4770      	bx	lr

08003b4a <HAL_I2CEx_ConfigDigitalFilter>:
  *                the configuration information for the specified I2Cx peripheral.
  * @param  DigitalFilter Coefficient of digital noise filter between Min_Data=0x00 and Max_Data=0x0F.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_I2CEx_ConfigDigitalFilter(I2C_HandleTypeDef *hi2c, uint32_t DigitalFilter)
{
 8003b4a:	b480      	push	{r7}
 8003b4c:	b085      	sub	sp, #20
 8003b4e:	af00      	add	r7, sp, #0
 8003b50:	6078      	str	r0, [r7, #4]
 8003b52:	6039      	str	r1, [r7, #0]

  /* Check the parameters */
  assert_param(IS_I2C_ALL_INSTANCE(hi2c->Instance));
  assert_param(IS_I2C_DIGITAL_FILTER(DigitalFilter));

  if (hi2c->State == HAL_I2C_STATE_READY)
 8003b54:	687b      	ldr	r3, [r7, #4]
 8003b56:	f893 3041 	ldrb.w	r3, [r3, #65]	; 0x41
 8003b5a:	b2db      	uxtb	r3, r3
 8003b5c:	2b20      	cmp	r3, #32
 8003b5e:	d139      	bne.n	8003bd4 <HAL_I2CEx_ConfigDigitalFilter+0x8a>
  {
    /* Process Locked */
    __HAL_LOCK(hi2c);
 8003b60:	687b      	ldr	r3, [r7, #4]
 8003b62:	f893 3040 	ldrb.w	r3, [r3, #64]	; 0x40
 8003b66:	2b01      	cmp	r3, #1
 8003b68:	d101      	bne.n	8003b6e <HAL_I2CEx_ConfigDigitalFilter+0x24>
 8003b6a:	2302      	movs	r3, #2
 8003b6c:	e033      	b.n	8003bd6 <HAL_I2CEx_ConfigDigitalFilter+0x8c>
 8003b6e:	687b      	ldr	r3, [r7, #4]
 8003b70:	2201      	movs	r2, #1
 8003b72:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

    hi2c->State = HAL_I2C_STATE_BUSY;
 8003b76:	687b      	ldr	r3, [r7, #4]
 8003b78:	2224      	movs	r2, #36	; 0x24
 8003b7a:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41

    /* Disable the selected I2C peripheral */
    __HAL_I2C_DISABLE(hi2c);
 8003b7e:	687b      	ldr	r3, [r7, #4]
 8003b80:	681b      	ldr	r3, [r3, #0]
 8003b82:	681a      	ldr	r2, [r3, #0]
 8003b84:	687b      	ldr	r3, [r7, #4]
 8003b86:	681b      	ldr	r3, [r3, #0]
 8003b88:	f022 0201 	bic.w	r2, r2, #1
 8003b8c:	601a      	str	r2, [r3, #0]

    /* Get the old register value */
    tmpreg = hi2c->Instance->CR1;
 8003b8e:	687b      	ldr	r3, [r7, #4]
 8003b90:	681b      	ldr	r3, [r3, #0]
 8003b92:	681b      	ldr	r3, [r3, #0]
 8003b94:	60fb      	str	r3, [r7, #12]

    /* Reset I2Cx DNF bits [11:8] */
    tmpreg &= ~(I2C_CR1_DNF);
 8003b96:	68fb      	ldr	r3, [r7, #12]
 8003b98:	f423 6370 	bic.w	r3, r3, #3840	; 0xf00
 8003b9c:	60fb      	str	r3, [r7, #12]

    /* Set I2Cx DNF coefficient */
    tmpreg |= DigitalFilter << 8U;
 8003b9e:	683b      	ldr	r3, [r7, #0]
 8003ba0:	021b      	lsls	r3, r3, #8
 8003ba2:	68fa      	ldr	r2, [r7, #12]
 8003ba4:	4313      	orrs	r3, r2
 8003ba6:	60fb      	str	r3, [r7, #12]

    /* Store the new register value */
    hi2c->Instance->CR1 = tmpreg;
 8003ba8:	687b      	ldr	r3, [r7, #4]
 8003baa:	681b      	ldr	r3, [r3, #0]
 8003bac:	68fa      	ldr	r2, [r7, #12]
 8003bae:	601a      	str	r2, [r3, #0]

    __HAL_I2C_ENABLE(hi2c);
 8003bb0:	687b      	ldr	r3, [r7, #4]
 8003bb2:	681b      	ldr	r3, [r3, #0]
 8003bb4:	681a      	ldr	r2, [r3, #0]
 8003bb6:	687b      	ldr	r3, [r7, #4]
 8003bb8:	681b      	ldr	r3, [r3, #0]
 8003bba:	f042 0201 	orr.w	r2, r2, #1
 8003bbe:	601a      	str	r2, [r3, #0]

    hi2c->State = HAL_I2C_STATE_READY;
 8003bc0:	687b      	ldr	r3, [r7, #4]
 8003bc2:	2220      	movs	r2, #32
 8003bc4:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41

    /* Process Unlocked */
    __HAL_UNLOCK(hi2c);
 8003bc8:	687b      	ldr	r3, [r7, #4]
 8003bca:	2200      	movs	r2, #0
 8003bcc:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40

    return HAL_OK;
 8003bd0:	2300      	movs	r3, #0
 8003bd2:	e000      	b.n	8003bd6 <HAL_I2CEx_ConfigDigitalFilter+0x8c>
  }
  else
  {
    return HAL_BUSY;
 8003bd4:	2302      	movs	r3, #2
  }
}
 8003bd6:	4618      	mov	r0, r3
 8003bd8:	3714      	adds	r7, #20
 8003bda:	46bd      	mov	sp, r7
 8003bdc:	f85d 7b04 	ldr.w	r7, [sp], #4
 8003be0:	4770      	bx	lr
	...

08003be4 <HAL_PWREx_GetVoltageRange>:
  * @brief Return Voltage Scaling Range.
  * @retval VOS bit field (PWR_REGULATOR_VOLTAGE_SCALE1 or PWR_REGULATOR_VOLTAGE_SCALE2
  *         or PWR_REGULATOR_VOLTAGE_SCALE1_BOOST when applicable)
  */
uint32_t HAL_PWREx_GetVoltageRange(void)
{
 8003be4:	b480      	push	{r7}
 8003be6:	af00      	add	r7, sp, #0
    else
    {
      return PWR_REGULATOR_VOLTAGE_SCALE1_BOOST;
    }
#else
  return  (PWR->CR1 & PWR_CR1_VOS);
 8003be8:	4b04      	ldr	r3, [pc, #16]	; (8003bfc <HAL_PWREx_GetVoltageRange+0x18>)
 8003bea:	681b      	ldr	r3, [r3, #0]
 8003bec:	f403 63c0 	and.w	r3, r3, #1536	; 0x600
#endif
}
 8003bf0:	4618      	mov	r0, r3
 8003bf2:	46bd      	mov	sp, r7
 8003bf4:	f85d 7b04 	ldr.w	r7, [sp], #4
 8003bf8:	4770      	bx	lr
 8003bfa:	bf00      	nop
 8003bfc:	40007000 	.word	0x40007000

08003c00 <HAL_PWREx_ControlVoltageScaling>:
  *        cleared before returning the status. If the flag is not cleared within
  *        50 microseconds, HAL_TIMEOUT status is reported.
  * @retval HAL Status
  */
HAL_StatusTypeDef HAL_PWREx_ControlVoltageScaling(uint32_t VoltageScaling)
{
 8003c00:	b480      	push	{r7}
 8003c02:	b085      	sub	sp, #20
 8003c04:	af00      	add	r7, sp, #0
 8003c06:	6078      	str	r0, [r7, #4]
  }

#else

  /* If Set Range 1 */
  if (VoltageScaling == PWR_REGULATOR_VOLTAGE_SCALE1)
 8003c08:	687b      	ldr	r3, [r7, #4]
 8003c0a:	f5b3 7f00 	cmp.w	r3, #512	; 0x200
 8003c0e:	d130      	bne.n	8003c72 <HAL_PWREx_ControlVoltageScaling+0x72>
  {
    if (READ_BIT(PWR->CR1, PWR_CR1_VOS) != PWR_REGULATOR_VOLTAGE_SCALE1)
 8003c10:	4b23      	ldr	r3, [pc, #140]	; (8003ca0 <HAL_PWREx_ControlVoltageScaling+0xa0>)
 8003c12:	681b      	ldr	r3, [r3, #0]
 8003c14:	f403 63c0 	and.w	r3, r3, #1536	; 0x600
 8003c18:	f5b3 7f00 	cmp.w	r3, #512	; 0x200
 8003c1c:	d038      	beq.n	8003c90 <HAL_PWREx_ControlVoltageScaling+0x90>
    {
      /* Set Range 1 */
      MODIFY_REG(PWR->CR1, PWR_CR1_VOS, PWR_REGULATOR_VOLTAGE_SCALE1);
 8003c1e:	4b20      	ldr	r3, [pc, #128]	; (8003ca0 <HAL_PWREx_ControlVoltageScaling+0xa0>)
 8003c20:	681b      	ldr	r3, [r3, #0]
 8003c22:	f423 63c0 	bic.w	r3, r3, #1536	; 0x600
 8003c26:	4a1e      	ldr	r2, [pc, #120]	; (8003ca0 <HAL_PWREx_ControlVoltageScaling+0xa0>)
 8003c28:	f443 7300 	orr.w	r3, r3, #512	; 0x200
 8003c2c:	6013      	str	r3, [r2, #0]

      /* Wait until VOSF is cleared */
      wait_loop_index = ((PWR_FLAG_SETTING_DELAY_US * SystemCoreClock) / 1000000U) + 1U;
 8003c2e:	4b1d      	ldr	r3, [pc, #116]	; (8003ca4 <HAL_PWREx_ControlVoltageScaling+0xa4>)
 8003c30:	681b      	ldr	r3, [r3, #0]
 8003c32:	2232      	movs	r2, #50	; 0x32
 8003c34:	fb02 f303 	mul.w	r3, r2, r3
 8003c38:	4a1b      	ldr	r2, [pc, #108]	; (8003ca8 <HAL_PWREx_ControlVoltageScaling+0xa8>)
 8003c3a:	fba2 2303 	umull	r2, r3, r2, r3
 8003c3e:	0c9b      	lsrs	r3, r3, #18
 8003c40:	3301      	adds	r3, #1
 8003c42:	60fb      	str	r3, [r7, #12]
      while ((HAL_IS_BIT_SET(PWR->SR2, PWR_SR2_VOSF)) && (wait_loop_index != 0U))
 8003c44:	e002      	b.n	8003c4c <HAL_PWREx_ControlVoltageScaling+0x4c>
      {
        wait_loop_index--;
 8003c46:	68fb      	ldr	r3, [r7, #12]
 8003c48:	3b01      	subs	r3, #1
 8003c4a:	60fb      	str	r3, [r7, #12]
      while ((HAL_IS_BIT_SET(PWR->SR2, PWR_SR2_VOSF)) && (wait_loop_index != 0U))
 8003c4c:	4b14      	ldr	r3, [pc, #80]	; (8003ca0 <HAL_PWREx_ControlVoltageScaling+0xa0>)
 8003c4e:	695b      	ldr	r3, [r3, #20]
 8003c50:	f403 6380 	and.w	r3, r3, #1024	; 0x400
 8003c54:	f5b3 6f80 	cmp.w	r3, #1024	; 0x400
 8003c58:	d102      	bne.n	8003c60 <HAL_PWREx_ControlVoltageScaling+0x60>
 8003c5a:	68fb      	ldr	r3, [r7, #12]
 8003c5c:	2b00      	cmp	r3, #0
 8003c5e:	d1f2      	bne.n	8003c46 <HAL_PWREx_ControlVoltageScaling+0x46>
      }
      if (HAL_IS_BIT_SET(PWR->SR2, PWR_SR2_VOSF))
 8003c60:	4b0f      	ldr	r3, [pc, #60]	; (8003ca0 <HAL_PWREx_ControlVoltageScaling+0xa0>)
 8003c62:	695b      	ldr	r3, [r3, #20]
 8003c64:	f403 6380 	and.w	r3, r3, #1024	; 0x400
 8003c68:	f5b3 6f80 	cmp.w	r3, #1024	; 0x400
 8003c6c:	d110      	bne.n	8003c90 <HAL_PWREx_ControlVoltageScaling+0x90>
      {
        return HAL_TIMEOUT;
 8003c6e:	2303      	movs	r3, #3
 8003c70:	e00f      	b.n	8003c92 <HAL_PWREx_ControlVoltageScaling+0x92>
      }
    }
  }
  else
  {
    if (READ_BIT(PWR->CR1, PWR_CR1_VOS) != PWR_REGULATOR_VOLTAGE_SCALE2)
 8003c72:	4b0b      	ldr	r3, [pc, #44]	; (8003ca0 <HAL_PWREx_ControlVoltageScaling+0xa0>)
 8003c74:	681b      	ldr	r3, [r3, #0]
 8003c76:	f403 63c0 	and.w	r3, r3, #1536	; 0x600
 8003c7a:	f5b3 6f80 	cmp.w	r3, #1024	; 0x400
 8003c7e:	d007      	beq.n	8003c90 <HAL_PWREx_ControlVoltageScaling+0x90>
    {
      /* Set Range 2 */
      MODIFY_REG(PWR->CR1, PWR_CR1_VOS, PWR_REGULATOR_VOLTAGE_SCALE2);
 8003c80:	4b07      	ldr	r3, [pc, #28]	; (8003ca0 <HAL_PWREx_ControlVoltageScaling+0xa0>)
 8003c82:	681b      	ldr	r3, [r3, #0]
 8003c84:	f423 63c0 	bic.w	r3, r3, #1536	; 0x600
 8003c88:	4a05      	ldr	r2, [pc, #20]	; (8003ca0 <HAL_PWREx_ControlVoltageScaling+0xa0>)
 8003c8a:	f443 6380 	orr.w	r3, r3, #1024	; 0x400
 8003c8e:	6013      	str	r3, [r2, #0]
      /* No need to wait for VOSF to be cleared for this transition */
    }
  }
#endif

  return HAL_OK;
 8003c90:	2300      	movs	r3, #0
}
 8003c92:	4618      	mov	r0, r3
 8003c94:	3714      	adds	r7, #20
 8003c96:	46bd      	mov	sp, r7
 8003c98:	f85d 7b04 	ldr.w	r7, [sp], #4
 8003c9c:	4770      	bx	lr
 8003c9e:	bf00      	nop
 8003ca0:	40007000 	.word	0x40007000
 8003ca4:	20000000 	.word	0x20000000
 8003ca8:	431bde83 	.word	0x431bde83

08003cac <HAL_RCC_OscConfig>:
  *         supported by this macro. 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)
{
 8003cac:	b580      	push	{r7, lr}
 8003cae:	b088      	sub	sp, #32
 8003cb0:	af00      	add	r7, sp, #0
 8003cb2:	6078      	str	r0, [r7, #4]
  uint32_t tickstart;
  HAL_StatusTypeDef status;
  uint32_t sysclk_source, pll_config;

  /* Check Null pointer */
  if(RCC_OscInitStruct == NULL)
 8003cb4:	687b      	ldr	r3, [r7, #4]
 8003cb6:	2b00      	cmp	r3, #0
 8003cb8:	d101      	bne.n	8003cbe <HAL_RCC_OscConfig+0x12>
  {
    return HAL_ERROR;
 8003cba:	2301      	movs	r3, #1
 8003cbc:	e3d4      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
  }

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

  sysclk_source = __HAL_RCC_GET_SYSCLK_SOURCE();
 8003cbe:	4ba1      	ldr	r3, [pc, #644]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003cc0:	689b      	ldr	r3, [r3, #8]
 8003cc2:	f003 030c 	and.w	r3, r3, #12
 8003cc6:	61bb      	str	r3, [r7, #24]
  pll_config = __HAL_RCC_GET_PLL_OSCSOURCE();
 8003cc8:	4b9e      	ldr	r3, [pc, #632]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003cca:	68db      	ldr	r3, [r3, #12]
 8003ccc:	f003 0303 	and.w	r3, r3, #3
 8003cd0:	617b      	str	r3, [r7, #20]

  /*----------------------------- MSI Configuration --------------------------*/
  if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_MSI) == RCC_OSCILLATORTYPE_MSI)
 8003cd2:	687b      	ldr	r3, [r7, #4]
 8003cd4:	681b      	ldr	r3, [r3, #0]
 8003cd6:	f003 0310 	and.w	r3, r3, #16
 8003cda:	2b00      	cmp	r3, #0
 8003cdc:	f000 80e4 	beq.w	8003ea8 <HAL_RCC_OscConfig+0x1fc>
    assert_param(IS_RCC_MSI(RCC_OscInitStruct->MSIState));
    assert_param(IS_RCC_MSICALIBRATION_VALUE(RCC_OscInitStruct->MSICalibrationValue));
    assert_param(IS_RCC_MSI_CLOCK_RANGE(RCC_OscInitStruct->MSIClockRange));

    /* Check if MSI is used as system clock or as PLL source when PLL is selected as system clock */
    if((sysclk_source == RCC_CFGR_SWS_MSI) ||
 8003ce0:	69bb      	ldr	r3, [r7, #24]
 8003ce2:	2b00      	cmp	r3, #0
 8003ce4:	d007      	beq.n	8003cf6 <HAL_RCC_OscConfig+0x4a>
 8003ce6:	69bb      	ldr	r3, [r7, #24]
 8003ce8:	2b0c      	cmp	r3, #12
 8003cea:	f040 808b 	bne.w	8003e04 <HAL_RCC_OscConfig+0x158>
       ((sysclk_source == RCC_CFGR_SWS_PLL) && (pll_config == RCC_PLLSOURCE_MSI)))
 8003cee:	697b      	ldr	r3, [r7, #20]
 8003cf0:	2b01      	cmp	r3, #1
 8003cf2:	f040 8087 	bne.w	8003e04 <HAL_RCC_OscConfig+0x158>
    {
      if((READ_BIT(RCC->CR, RCC_CR_MSIRDY) != 0U) && (RCC_OscInitStruct->MSIState == RCC_MSI_OFF))
 8003cf6:	4b93      	ldr	r3, [pc, #588]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003cf8:	681b      	ldr	r3, [r3, #0]
 8003cfa:	f003 0302 	and.w	r3, r3, #2
 8003cfe:	2b00      	cmp	r3, #0
 8003d00:	d005      	beq.n	8003d0e <HAL_RCC_OscConfig+0x62>
 8003d02:	687b      	ldr	r3, [r7, #4]
 8003d04:	699b      	ldr	r3, [r3, #24]
 8003d06:	2b00      	cmp	r3, #0
 8003d08:	d101      	bne.n	8003d0e <HAL_RCC_OscConfig+0x62>
      {
        return HAL_ERROR;
 8003d0a:	2301      	movs	r3, #1
 8003d0c:	e3ac      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
      else
      {
        /* 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. */
        if(RCC_OscInitStruct->MSIClockRange > __HAL_RCC_GET_MSI_RANGE())
 8003d0e:	687b      	ldr	r3, [r7, #4]
 8003d10:	6a1a      	ldr	r2, [r3, #32]
 8003d12:	4b8c      	ldr	r3, [pc, #560]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003d14:	681b      	ldr	r3, [r3, #0]
 8003d16:	f003 0308 	and.w	r3, r3, #8
 8003d1a:	2b00      	cmp	r3, #0
 8003d1c:	d004      	beq.n	8003d28 <HAL_RCC_OscConfig+0x7c>
 8003d1e:	4b89      	ldr	r3, [pc, #548]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003d20:	681b      	ldr	r3, [r3, #0]
 8003d22:	f003 03f0 	and.w	r3, r3, #240	; 0xf0
 8003d26:	e005      	b.n	8003d34 <HAL_RCC_OscConfig+0x88>
 8003d28:	4b86      	ldr	r3, [pc, #536]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003d2a:	f8d3 3094 	ldr.w	r3, [r3, #148]	; 0x94
 8003d2e:	091b      	lsrs	r3, r3, #4
 8003d30:	f003 03f0 	and.w	r3, r3, #240	; 0xf0
 8003d34:	4293      	cmp	r3, r2
 8003d36:	d223      	bcs.n	8003d80 <HAL_RCC_OscConfig+0xd4>
        {
          /* First increase number of wait states update if necessary */
          if(RCC_SetFlashLatencyFromMSIRange(RCC_OscInitStruct->MSIClockRange) != HAL_OK)
 8003d38:	687b      	ldr	r3, [r7, #4]
 8003d3a:	6a1b      	ldr	r3, [r3, #32]
 8003d3c:	4618      	mov	r0, r3
 8003d3e:	f000 fd41 	bl	80047c4 <RCC_SetFlashLatencyFromMSIRange>
 8003d42:	4603      	mov	r3, r0
 8003d44:	2b00      	cmp	r3, #0
 8003d46:	d001      	beq.n	8003d4c <HAL_RCC_OscConfig+0xa0>
          {
            return HAL_ERROR;
 8003d48:	2301      	movs	r3, #1
 8003d4a:	e38d      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
          }

          /* Selects the Multiple Speed oscillator (MSI) clock range .*/
          __HAL_RCC_MSI_RANGE_CONFIG(RCC_OscInitStruct->MSIClockRange);
 8003d4c:	4b7d      	ldr	r3, [pc, #500]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003d4e:	681b      	ldr	r3, [r3, #0]
 8003d50:	4a7c      	ldr	r2, [pc, #496]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003d52:	f043 0308 	orr.w	r3, r3, #8
 8003d56:	6013      	str	r3, [r2, #0]
 8003d58:	4b7a      	ldr	r3, [pc, #488]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003d5a:	681b      	ldr	r3, [r3, #0]
 8003d5c:	f023 02f0 	bic.w	r2, r3, #240	; 0xf0
 8003d60:	687b      	ldr	r3, [r7, #4]
 8003d62:	6a1b      	ldr	r3, [r3, #32]
 8003d64:	4977      	ldr	r1, [pc, #476]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003d66:	4313      	orrs	r3, r2
 8003d68:	600b      	str	r3, [r1, #0]
          /* Adjusts the Multiple Speed oscillator (MSI) calibration value.*/
          __HAL_RCC_MSI_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->MSICalibrationValue);
 8003d6a:	4b76      	ldr	r3, [pc, #472]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003d6c:	685b      	ldr	r3, [r3, #4]
 8003d6e:	f423 427f 	bic.w	r2, r3, #65280	; 0xff00
 8003d72:	687b      	ldr	r3, [r7, #4]
 8003d74:	69db      	ldr	r3, [r3, #28]
 8003d76:	021b      	lsls	r3, r3, #8
 8003d78:	4972      	ldr	r1, [pc, #456]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003d7a:	4313      	orrs	r3, r2
 8003d7c:	604b      	str	r3, [r1, #4]
 8003d7e:	e025      	b.n	8003dcc <HAL_RCC_OscConfig+0x120>
        }
        else
        {
          /* Else, keep current flash latency while decreasing applies */
          /* Selects the Multiple Speed oscillator (MSI) clock range .*/
          __HAL_RCC_MSI_RANGE_CONFIG(RCC_OscInitStruct->MSIClockRange);
 8003d80:	4b70      	ldr	r3, [pc, #448]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003d82:	681b      	ldr	r3, [r3, #0]
 8003d84:	4a6f      	ldr	r2, [pc, #444]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003d86:	f043 0308 	orr.w	r3, r3, #8
 8003d8a:	6013      	str	r3, [r2, #0]
 8003d8c:	4b6d      	ldr	r3, [pc, #436]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003d8e:	681b      	ldr	r3, [r3, #0]
 8003d90:	f023 02f0 	bic.w	r2, r3, #240	; 0xf0
 8003d94:	687b      	ldr	r3, [r7, #4]
 8003d96:	6a1b      	ldr	r3, [r3, #32]
 8003d98:	496a      	ldr	r1, [pc, #424]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003d9a:	4313      	orrs	r3, r2
 8003d9c:	600b      	str	r3, [r1, #0]
          /* Adjusts the Multiple Speed oscillator (MSI) calibration value.*/
          __HAL_RCC_MSI_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->MSICalibrationValue);
 8003d9e:	4b69      	ldr	r3, [pc, #420]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003da0:	685b      	ldr	r3, [r3, #4]
 8003da2:	f423 427f 	bic.w	r2, r3, #65280	; 0xff00
 8003da6:	687b      	ldr	r3, [r7, #4]
 8003da8:	69db      	ldr	r3, [r3, #28]
 8003daa:	021b      	lsls	r3, r3, #8
 8003dac:	4965      	ldr	r1, [pc, #404]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003dae:	4313      	orrs	r3, r2
 8003db0:	604b      	str	r3, [r1, #4]

          /* Decrease number of wait states update if necessary */
          /* Only possible when MSI is the System clock source  */
          if(sysclk_source == RCC_CFGR_SWS_MSI)
 8003db2:	69bb      	ldr	r3, [r7, #24]
 8003db4:	2b00      	cmp	r3, #0
 8003db6:	d109      	bne.n	8003dcc <HAL_RCC_OscConfig+0x120>
          {
            if(RCC_SetFlashLatencyFromMSIRange(RCC_OscInitStruct->MSIClockRange) != HAL_OK)
 8003db8:	687b      	ldr	r3, [r7, #4]
 8003dba:	6a1b      	ldr	r3, [r3, #32]
 8003dbc:	4618      	mov	r0, r3
 8003dbe:	f000 fd01 	bl	80047c4 <RCC_SetFlashLatencyFromMSIRange>
 8003dc2:	4603      	mov	r3, r0
 8003dc4:	2b00      	cmp	r3, #0
 8003dc6:	d001      	beq.n	8003dcc <HAL_RCC_OscConfig+0x120>
            {
              return HAL_ERROR;
 8003dc8:	2301      	movs	r3, #1
 8003dca:	e34d      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
            }
          }
        }

        /* Update the SystemCoreClock global variable */
        SystemCoreClock = HAL_RCC_GetSysClockFreq() >> (AHBPrescTable[READ_BIT(RCC->CFGR, RCC_CFGR_HPRE) >> RCC_CFGR_HPRE_Pos] & 0x1FU);
 8003dcc:	f000 fc36 	bl	800463c <HAL_RCC_GetSysClockFreq>
 8003dd0:	4602      	mov	r2, r0
 8003dd2:	4b5c      	ldr	r3, [pc, #368]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003dd4:	689b      	ldr	r3, [r3, #8]
 8003dd6:	091b      	lsrs	r3, r3, #4
 8003dd8:	f003 030f 	and.w	r3, r3, #15
 8003ddc:	495a      	ldr	r1, [pc, #360]	; (8003f48 <HAL_RCC_OscConfig+0x29c>)
 8003dde:	5ccb      	ldrb	r3, [r1, r3]
 8003de0:	f003 031f 	and.w	r3, r3, #31
 8003de4:	fa22 f303 	lsr.w	r3, r2, r3
 8003de8:	4a58      	ldr	r2, [pc, #352]	; (8003f4c <HAL_RCC_OscConfig+0x2a0>)
 8003dea:	6013      	str	r3, [r2, #0]

        /* Configure the source of time base considering new system clocks settings*/
        status = HAL_InitTick(uwTickPrio);
 8003dec:	4b58      	ldr	r3, [pc, #352]	; (8003f50 <HAL_RCC_OscConfig+0x2a4>)
 8003dee:	681b      	ldr	r3, [r3, #0]
 8003df0:	4618      	mov	r0, r3
 8003df2:	f7fe f8a7 	bl	8001f44 <HAL_InitTick>
 8003df6:	4603      	mov	r3, r0
 8003df8:	73fb      	strb	r3, [r7, #15]
        if(status != HAL_OK)
 8003dfa:	7bfb      	ldrb	r3, [r7, #15]
 8003dfc:	2b00      	cmp	r3, #0
 8003dfe:	d052      	beq.n	8003ea6 <HAL_RCC_OscConfig+0x1fa>
        {
          return status;
 8003e00:	7bfb      	ldrb	r3, [r7, #15]
 8003e02:	e331      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
      }
    }
    else
    {
      /* Check the MSI State */
      if(RCC_OscInitStruct->MSIState != RCC_MSI_OFF)
 8003e04:	687b      	ldr	r3, [r7, #4]
 8003e06:	699b      	ldr	r3, [r3, #24]
 8003e08:	2b00      	cmp	r3, #0
 8003e0a:	d032      	beq.n	8003e72 <HAL_RCC_OscConfig+0x1c6>
      {
        /* Enable the Internal High Speed oscillator (MSI). */
        __HAL_RCC_MSI_ENABLE();
 8003e0c:	4b4d      	ldr	r3, [pc, #308]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003e0e:	681b      	ldr	r3, [r3, #0]
 8003e10:	4a4c      	ldr	r2, [pc, #304]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003e12:	f043 0301 	orr.w	r3, r3, #1
 8003e16:	6013      	str	r3, [r2, #0]

        /* Get timeout */
        tickstart = HAL_GetTick();
 8003e18:	f7fe f8e4 	bl	8001fe4 <HAL_GetTick>
 8003e1c:	6138      	str	r0, [r7, #16]

        /* Wait till MSI is ready */
        while(READ_BIT(RCC->CR, RCC_CR_MSIRDY) == 0U)
 8003e1e:	e008      	b.n	8003e32 <HAL_RCC_OscConfig+0x186>
        {
          if((HAL_GetTick() - tickstart) > MSI_TIMEOUT_VALUE)
 8003e20:	f7fe f8e0 	bl	8001fe4 <HAL_GetTick>
 8003e24:	4602      	mov	r2, r0
 8003e26:	693b      	ldr	r3, [r7, #16]
 8003e28:	1ad3      	subs	r3, r2, r3
 8003e2a:	2b02      	cmp	r3, #2
 8003e2c:	d901      	bls.n	8003e32 <HAL_RCC_OscConfig+0x186>
          {
            return HAL_TIMEOUT;
 8003e2e:	2303      	movs	r3, #3
 8003e30:	e31a      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
        while(READ_BIT(RCC->CR, RCC_CR_MSIRDY) == 0U)
 8003e32:	4b44      	ldr	r3, [pc, #272]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003e34:	681b      	ldr	r3, [r3, #0]
 8003e36:	f003 0302 	and.w	r3, r3, #2
 8003e3a:	2b00      	cmp	r3, #0
 8003e3c:	d0f0      	beq.n	8003e20 <HAL_RCC_OscConfig+0x174>
          }
        }
         /* Selects the Multiple Speed oscillator (MSI) clock range .*/
        __HAL_RCC_MSI_RANGE_CONFIG(RCC_OscInitStruct->MSIClockRange);
 8003e3e:	4b41      	ldr	r3, [pc, #260]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003e40:	681b      	ldr	r3, [r3, #0]
 8003e42:	4a40      	ldr	r2, [pc, #256]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003e44:	f043 0308 	orr.w	r3, r3, #8
 8003e48:	6013      	str	r3, [r2, #0]
 8003e4a:	4b3e      	ldr	r3, [pc, #248]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003e4c:	681b      	ldr	r3, [r3, #0]
 8003e4e:	f023 02f0 	bic.w	r2, r3, #240	; 0xf0
 8003e52:	687b      	ldr	r3, [r7, #4]
 8003e54:	6a1b      	ldr	r3, [r3, #32]
 8003e56:	493b      	ldr	r1, [pc, #236]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003e58:	4313      	orrs	r3, r2
 8003e5a:	600b      	str	r3, [r1, #0]
         /* Adjusts the Multiple Speed oscillator (MSI) calibration value.*/
        __HAL_RCC_MSI_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->MSICalibrationValue);
 8003e5c:	4b39      	ldr	r3, [pc, #228]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003e5e:	685b      	ldr	r3, [r3, #4]
 8003e60:	f423 427f 	bic.w	r2, r3, #65280	; 0xff00
 8003e64:	687b      	ldr	r3, [r7, #4]
 8003e66:	69db      	ldr	r3, [r3, #28]
 8003e68:	021b      	lsls	r3, r3, #8
 8003e6a:	4936      	ldr	r1, [pc, #216]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003e6c:	4313      	orrs	r3, r2
 8003e6e:	604b      	str	r3, [r1, #4]
 8003e70:	e01a      	b.n	8003ea8 <HAL_RCC_OscConfig+0x1fc>

      }
      else
      {
        /* Disable the Internal High Speed oscillator (MSI). */
        __HAL_RCC_MSI_DISABLE();
 8003e72:	4b34      	ldr	r3, [pc, #208]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003e74:	681b      	ldr	r3, [r3, #0]
 8003e76:	4a33      	ldr	r2, [pc, #204]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003e78:	f023 0301 	bic.w	r3, r3, #1
 8003e7c:	6013      	str	r3, [r2, #0]

        /* Get timeout */
        tickstart = HAL_GetTick();
 8003e7e:	f7fe f8b1 	bl	8001fe4 <HAL_GetTick>
 8003e82:	6138      	str	r0, [r7, #16]

        /* Wait till MSI is ready */
        while(READ_BIT(RCC->CR, RCC_CR_MSIRDY) != 0U)
 8003e84:	e008      	b.n	8003e98 <HAL_RCC_OscConfig+0x1ec>
        {
          if((HAL_GetTick() - tickstart) > MSI_TIMEOUT_VALUE)
 8003e86:	f7fe f8ad 	bl	8001fe4 <HAL_GetTick>
 8003e8a:	4602      	mov	r2, r0
 8003e8c:	693b      	ldr	r3, [r7, #16]
 8003e8e:	1ad3      	subs	r3, r2, r3
 8003e90:	2b02      	cmp	r3, #2
 8003e92:	d901      	bls.n	8003e98 <HAL_RCC_OscConfig+0x1ec>
          {
            return HAL_TIMEOUT;
 8003e94:	2303      	movs	r3, #3
 8003e96:	e2e7      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
        while(READ_BIT(RCC->CR, RCC_CR_MSIRDY) != 0U)
 8003e98:	4b2a      	ldr	r3, [pc, #168]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003e9a:	681b      	ldr	r3, [r3, #0]
 8003e9c:	f003 0302 	and.w	r3, r3, #2
 8003ea0:	2b00      	cmp	r3, #0
 8003ea2:	d1f0      	bne.n	8003e86 <HAL_RCC_OscConfig+0x1da>
 8003ea4:	e000      	b.n	8003ea8 <HAL_RCC_OscConfig+0x1fc>
      if((READ_BIT(RCC->CR, RCC_CR_MSIRDY) != 0U) && (RCC_OscInitStruct->MSIState == RCC_MSI_OFF))
 8003ea6:	bf00      	nop
        }
      }
    }
  }
  /*------------------------------- HSE Configuration ------------------------*/
  if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_HSE) == RCC_OSCILLATORTYPE_HSE)
 8003ea8:	687b      	ldr	r3, [r7, #4]
 8003eaa:	681b      	ldr	r3, [r3, #0]
 8003eac:	f003 0301 	and.w	r3, r3, #1
 8003eb0:	2b00      	cmp	r3, #0
 8003eb2:	d074      	beq.n	8003f9e <HAL_RCC_OscConfig+0x2f2>
  {
    /* Check the parameters */
    assert_param(IS_RCC_HSE(RCC_OscInitStruct->HSEState));

    /* When the HSE is used as system clock or clock source for PLL in these cases it is not allowed to be disabled */
    if((sysclk_source == RCC_CFGR_SWS_HSE) ||
 8003eb4:	69bb      	ldr	r3, [r7, #24]
 8003eb6:	2b08      	cmp	r3, #8
 8003eb8:	d005      	beq.n	8003ec6 <HAL_RCC_OscConfig+0x21a>
 8003eba:	69bb      	ldr	r3, [r7, #24]
 8003ebc:	2b0c      	cmp	r3, #12
 8003ebe:	d10e      	bne.n	8003ede <HAL_RCC_OscConfig+0x232>
       ((sysclk_source == RCC_CFGR_SWS_PLL) && (pll_config == RCC_PLLSOURCE_HSE)))
 8003ec0:	697b      	ldr	r3, [r7, #20]
 8003ec2:	2b03      	cmp	r3, #3
 8003ec4:	d10b      	bne.n	8003ede <HAL_RCC_OscConfig+0x232>
    {
      if((READ_BIT(RCC->CR, RCC_CR_HSERDY) != 0U) && (RCC_OscInitStruct->HSEState == RCC_HSE_OFF))
 8003ec6:	4b1f      	ldr	r3, [pc, #124]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003ec8:	681b      	ldr	r3, [r3, #0]
 8003eca:	f403 3300 	and.w	r3, r3, #131072	; 0x20000
 8003ece:	2b00      	cmp	r3, #0
 8003ed0:	d064      	beq.n	8003f9c <HAL_RCC_OscConfig+0x2f0>
 8003ed2:	687b      	ldr	r3, [r7, #4]
 8003ed4:	685b      	ldr	r3, [r3, #4]
 8003ed6:	2b00      	cmp	r3, #0
 8003ed8:	d160      	bne.n	8003f9c <HAL_RCC_OscConfig+0x2f0>
      {
        return HAL_ERROR;
 8003eda:	2301      	movs	r3, #1
 8003edc:	e2c4      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
      }
    }
    else
    {
      /* Set the new HSE configuration ---------------------------------------*/
      __HAL_RCC_HSE_CONFIG(RCC_OscInitStruct->HSEState);
 8003ede:	687b      	ldr	r3, [r7, #4]
 8003ee0:	685b      	ldr	r3, [r3, #4]
 8003ee2:	f5b3 3f80 	cmp.w	r3, #65536	; 0x10000
 8003ee6:	d106      	bne.n	8003ef6 <HAL_RCC_OscConfig+0x24a>
 8003ee8:	4b16      	ldr	r3, [pc, #88]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003eea:	681b      	ldr	r3, [r3, #0]
 8003eec:	4a15      	ldr	r2, [pc, #84]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003eee:	f443 3380 	orr.w	r3, r3, #65536	; 0x10000
 8003ef2:	6013      	str	r3, [r2, #0]
 8003ef4:	e01d      	b.n	8003f32 <HAL_RCC_OscConfig+0x286>
 8003ef6:	687b      	ldr	r3, [r7, #4]
 8003ef8:	685b      	ldr	r3, [r3, #4]
 8003efa:	f5b3 2fa0 	cmp.w	r3, #327680	; 0x50000
 8003efe:	d10c      	bne.n	8003f1a <HAL_RCC_OscConfig+0x26e>
 8003f00:	4b10      	ldr	r3, [pc, #64]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003f02:	681b      	ldr	r3, [r3, #0]
 8003f04:	4a0f      	ldr	r2, [pc, #60]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003f06:	f443 2380 	orr.w	r3, r3, #262144	; 0x40000
 8003f0a:	6013      	str	r3, [r2, #0]
 8003f0c:	4b0d      	ldr	r3, [pc, #52]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003f0e:	681b      	ldr	r3, [r3, #0]
 8003f10:	4a0c      	ldr	r2, [pc, #48]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003f12:	f443 3380 	orr.w	r3, r3, #65536	; 0x10000
 8003f16:	6013      	str	r3, [r2, #0]
 8003f18:	e00b      	b.n	8003f32 <HAL_RCC_OscConfig+0x286>
 8003f1a:	4b0a      	ldr	r3, [pc, #40]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003f1c:	681b      	ldr	r3, [r3, #0]
 8003f1e:	4a09      	ldr	r2, [pc, #36]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003f20:	f423 3380 	bic.w	r3, r3, #65536	; 0x10000
 8003f24:	6013      	str	r3, [r2, #0]
 8003f26:	4b07      	ldr	r3, [pc, #28]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003f28:	681b      	ldr	r3, [r3, #0]
 8003f2a:	4a06      	ldr	r2, [pc, #24]	; (8003f44 <HAL_RCC_OscConfig+0x298>)
 8003f2c:	f423 2380 	bic.w	r3, r3, #262144	; 0x40000
 8003f30:	6013      	str	r3, [r2, #0]

      /* Check the HSE State */
      if(RCC_OscInitStruct->HSEState != RCC_HSE_OFF)
 8003f32:	687b      	ldr	r3, [r7, #4]
 8003f34:	685b      	ldr	r3, [r3, #4]
 8003f36:	2b00      	cmp	r3, #0
 8003f38:	d01c      	beq.n	8003f74 <HAL_RCC_OscConfig+0x2c8>
      {
        /* Get Start Tick*/
        tickstart = HAL_GetTick();
 8003f3a:	f7fe f853 	bl	8001fe4 <HAL_GetTick>
 8003f3e:	6138      	str	r0, [r7, #16]

        /* Wait till HSE is ready */
        while(READ_BIT(RCC->CR, RCC_CR_HSERDY) == 0U)
 8003f40:	e011      	b.n	8003f66 <HAL_RCC_OscConfig+0x2ba>
 8003f42:	bf00      	nop
 8003f44:	40021000 	.word	0x40021000
 8003f48:	08008fdc 	.word	0x08008fdc
 8003f4c:	20000000 	.word	0x20000000
 8003f50:	20000004 	.word	0x20000004
        {
          if((HAL_GetTick() - tickstart) > HSE_TIMEOUT_VALUE)
 8003f54:	f7fe f846 	bl	8001fe4 <HAL_GetTick>
 8003f58:	4602      	mov	r2, r0
 8003f5a:	693b      	ldr	r3, [r7, #16]
 8003f5c:	1ad3      	subs	r3, r2, r3
 8003f5e:	2b64      	cmp	r3, #100	; 0x64
 8003f60:	d901      	bls.n	8003f66 <HAL_RCC_OscConfig+0x2ba>
          {
            return HAL_TIMEOUT;
 8003f62:	2303      	movs	r3, #3
 8003f64:	e280      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
        while(READ_BIT(RCC->CR, RCC_CR_HSERDY) == 0U)
 8003f66:	4baf      	ldr	r3, [pc, #700]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 8003f68:	681b      	ldr	r3, [r3, #0]
 8003f6a:	f403 3300 	and.w	r3, r3, #131072	; 0x20000
 8003f6e:	2b00      	cmp	r3, #0
 8003f70:	d0f0      	beq.n	8003f54 <HAL_RCC_OscConfig+0x2a8>
 8003f72:	e014      	b.n	8003f9e <HAL_RCC_OscConfig+0x2f2>
        }
      }
      else
      {
        /* Get Start Tick*/
        tickstart = HAL_GetTick();
 8003f74:	f7fe f836 	bl	8001fe4 <HAL_GetTick>
 8003f78:	6138      	str	r0, [r7, #16]

        /* Wait till HSE is disabled */
        while(READ_BIT(RCC->CR, RCC_CR_HSERDY) != 0U)
 8003f7a:	e008      	b.n	8003f8e <HAL_RCC_OscConfig+0x2e2>
        {
          if((HAL_GetTick() - tickstart) > HSE_TIMEOUT_VALUE)
 8003f7c:	f7fe f832 	bl	8001fe4 <HAL_GetTick>
 8003f80:	4602      	mov	r2, r0
 8003f82:	693b      	ldr	r3, [r7, #16]
 8003f84:	1ad3      	subs	r3, r2, r3
 8003f86:	2b64      	cmp	r3, #100	; 0x64
 8003f88:	d901      	bls.n	8003f8e <HAL_RCC_OscConfig+0x2e2>
          {
            return HAL_TIMEOUT;
 8003f8a:	2303      	movs	r3, #3
 8003f8c:	e26c      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
        while(READ_BIT(RCC->CR, RCC_CR_HSERDY) != 0U)
 8003f8e:	4ba5      	ldr	r3, [pc, #660]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 8003f90:	681b      	ldr	r3, [r3, #0]
 8003f92:	f403 3300 	and.w	r3, r3, #131072	; 0x20000
 8003f96:	2b00      	cmp	r3, #0
 8003f98:	d1f0      	bne.n	8003f7c <HAL_RCC_OscConfig+0x2d0>
 8003f9a:	e000      	b.n	8003f9e <HAL_RCC_OscConfig+0x2f2>
      if((READ_BIT(RCC->CR, RCC_CR_HSERDY) != 0U) && (RCC_OscInitStruct->HSEState == RCC_HSE_OFF))
 8003f9c:	bf00      	nop
        }
      }
    }
  }
  /*----------------------------- HSI Configuration --------------------------*/
  if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_HSI) == RCC_OSCILLATORTYPE_HSI)
 8003f9e:	687b      	ldr	r3, [r7, #4]
 8003fa0:	681b      	ldr	r3, [r3, #0]
 8003fa2:	f003 0302 	and.w	r3, r3, #2
 8003fa6:	2b00      	cmp	r3, #0
 8003fa8:	d060      	beq.n	800406c <HAL_RCC_OscConfig+0x3c0>
    /* Check the parameters */
    assert_param(IS_RCC_HSI(RCC_OscInitStruct->HSIState));
    assert_param(IS_RCC_HSI_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((sysclk_source == RCC_CFGR_SWS_HSI) ||
 8003faa:	69bb      	ldr	r3, [r7, #24]
 8003fac:	2b04      	cmp	r3, #4
 8003fae:	d005      	beq.n	8003fbc <HAL_RCC_OscConfig+0x310>
 8003fb0:	69bb      	ldr	r3, [r7, #24]
 8003fb2:	2b0c      	cmp	r3, #12
 8003fb4:	d119      	bne.n	8003fea <HAL_RCC_OscConfig+0x33e>
       ((sysclk_source == RCC_CFGR_SWS_PLL) && (pll_config == RCC_PLLSOURCE_HSI)))
 8003fb6:	697b      	ldr	r3, [r7, #20]
 8003fb8:	2b02      	cmp	r3, #2
 8003fba:	d116      	bne.n	8003fea <HAL_RCC_OscConfig+0x33e>
    {
      /* When HSI is used as system clock it will not be disabled */
      if((READ_BIT(RCC->CR, RCC_CR_HSIRDY) != 0U) && (RCC_OscInitStruct->HSIState == RCC_HSI_OFF))
 8003fbc:	4b99      	ldr	r3, [pc, #612]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 8003fbe:	681b      	ldr	r3, [r3, #0]
 8003fc0:	f403 6380 	and.w	r3, r3, #1024	; 0x400
 8003fc4:	2b00      	cmp	r3, #0
 8003fc6:	d005      	beq.n	8003fd4 <HAL_RCC_OscConfig+0x328>
 8003fc8:	687b      	ldr	r3, [r7, #4]
 8003fca:	68db      	ldr	r3, [r3, #12]
 8003fcc:	2b00      	cmp	r3, #0
 8003fce:	d101      	bne.n	8003fd4 <HAL_RCC_OscConfig+0x328>
      {
        return HAL_ERROR;
 8003fd0:	2301      	movs	r3, #1
 8003fd2:	e249      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
      }
      /* Otherwise, just the calibration is allowed */
      else
      {
        /* Adjusts the Internal High Speed oscillator (HSI) calibration value.*/
        __HAL_RCC_HSI_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->HSICalibrationValue);
 8003fd4:	4b93      	ldr	r3, [pc, #588]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 8003fd6:	685b      	ldr	r3, [r3, #4]
 8003fd8:	f023 52f8 	bic.w	r2, r3, #520093696	; 0x1f000000
 8003fdc:	687b      	ldr	r3, [r7, #4]
 8003fde:	691b      	ldr	r3, [r3, #16]
 8003fe0:	061b      	lsls	r3, r3, #24
 8003fe2:	4990      	ldr	r1, [pc, #576]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 8003fe4:	4313      	orrs	r3, r2
 8003fe6:	604b      	str	r3, [r1, #4]
      if((READ_BIT(RCC->CR, RCC_CR_HSIRDY) != 0U) && (RCC_OscInitStruct->HSIState == RCC_HSI_OFF))
 8003fe8:	e040      	b.n	800406c <HAL_RCC_OscConfig+0x3c0>
      }
    }
    else
    {
      /* Check the HSI State */
      if(RCC_OscInitStruct->HSIState != RCC_HSI_OFF)
 8003fea:	687b      	ldr	r3, [r7, #4]
 8003fec:	68db      	ldr	r3, [r3, #12]
 8003fee:	2b00      	cmp	r3, #0
 8003ff0:	d023      	beq.n	800403a <HAL_RCC_OscConfig+0x38e>
      {
        /* Enable the Internal High Speed oscillator (HSI). */
        __HAL_RCC_HSI_ENABLE();
 8003ff2:	4b8c      	ldr	r3, [pc, #560]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 8003ff4:	681b      	ldr	r3, [r3, #0]
 8003ff6:	4a8b      	ldr	r2, [pc, #556]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 8003ff8:	f443 7380 	orr.w	r3, r3, #256	; 0x100
 8003ffc:	6013      	str	r3, [r2, #0]

        /* Get Start Tick*/
        tickstart = HAL_GetTick();
 8003ffe:	f7fd fff1 	bl	8001fe4 <HAL_GetTick>
 8004002:	6138      	str	r0, [r7, #16]

        /* Wait till HSI is ready */
        while(READ_BIT(RCC->CR, RCC_CR_HSIRDY) == 0U)
 8004004:	e008      	b.n	8004018 <HAL_RCC_OscConfig+0x36c>
        {
          if((HAL_GetTick() - tickstart) > HSI_TIMEOUT_VALUE)
 8004006:	f7fd ffed 	bl	8001fe4 <HAL_GetTick>
 800400a:	4602      	mov	r2, r0
 800400c:	693b      	ldr	r3, [r7, #16]
 800400e:	1ad3      	subs	r3, r2, r3
 8004010:	2b02      	cmp	r3, #2
 8004012:	d901      	bls.n	8004018 <HAL_RCC_OscConfig+0x36c>
          {
            return HAL_TIMEOUT;
 8004014:	2303      	movs	r3, #3
 8004016:	e227      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
        while(READ_BIT(RCC->CR, RCC_CR_HSIRDY) == 0U)
 8004018:	4b82      	ldr	r3, [pc, #520]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 800401a:	681b      	ldr	r3, [r3, #0]
 800401c:	f403 6380 	and.w	r3, r3, #1024	; 0x400
 8004020:	2b00      	cmp	r3, #0
 8004022:	d0f0      	beq.n	8004006 <HAL_RCC_OscConfig+0x35a>
          }
        }

        /* Adjusts the Internal High Speed oscillator (HSI) calibration value.*/
        __HAL_RCC_HSI_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->HSICalibrationValue);
 8004024:	4b7f      	ldr	r3, [pc, #508]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 8004026:	685b      	ldr	r3, [r3, #4]
 8004028:	f023 52f8 	bic.w	r2, r3, #520093696	; 0x1f000000
 800402c:	687b      	ldr	r3, [r7, #4]
 800402e:	691b      	ldr	r3, [r3, #16]
 8004030:	061b      	lsls	r3, r3, #24
 8004032:	497c      	ldr	r1, [pc, #496]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 8004034:	4313      	orrs	r3, r2
 8004036:	604b      	str	r3, [r1, #4]
 8004038:	e018      	b.n	800406c <HAL_RCC_OscConfig+0x3c0>
      }
      else
      {
        /* Disable the Internal High Speed oscillator (HSI). */
        __HAL_RCC_HSI_DISABLE();
 800403a:	4b7a      	ldr	r3, [pc, #488]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 800403c:	681b      	ldr	r3, [r3, #0]
 800403e:	4a79      	ldr	r2, [pc, #484]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 8004040:	f423 7380 	bic.w	r3, r3, #256	; 0x100
 8004044:	6013      	str	r3, [r2, #0]

        /* Get Start Tick*/
        tickstart = HAL_GetTick();
 8004046:	f7fd ffcd 	bl	8001fe4 <HAL_GetTick>
 800404a:	6138      	str	r0, [r7, #16]

        /* Wait till HSI is disabled */
        while(READ_BIT(RCC->CR, RCC_CR_HSIRDY) != 0U)
 800404c:	e008      	b.n	8004060 <HAL_RCC_OscConfig+0x3b4>
        {
          if((HAL_GetTick() - tickstart) > HSI_TIMEOUT_VALUE)
 800404e:	f7fd ffc9 	bl	8001fe4 <HAL_GetTick>
 8004052:	4602      	mov	r2, r0
 8004054:	693b      	ldr	r3, [r7, #16]
 8004056:	1ad3      	subs	r3, r2, r3
 8004058:	2b02      	cmp	r3, #2
 800405a:	d901      	bls.n	8004060 <HAL_RCC_OscConfig+0x3b4>
          {
            return HAL_TIMEOUT;
 800405c:	2303      	movs	r3, #3
 800405e:	e203      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
        while(READ_BIT(RCC->CR, RCC_CR_HSIRDY) != 0U)
 8004060:	4b70      	ldr	r3, [pc, #448]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 8004062:	681b      	ldr	r3, [r3, #0]
 8004064:	f403 6380 	and.w	r3, r3, #1024	; 0x400
 8004068:	2b00      	cmp	r3, #0
 800406a:	d1f0      	bne.n	800404e <HAL_RCC_OscConfig+0x3a2>
        }
      }
    }
  }
  /*------------------------------ LSI Configuration -------------------------*/
  if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_LSI) == RCC_OSCILLATORTYPE_LSI)
 800406c:	687b      	ldr	r3, [r7, #4]
 800406e:	681b      	ldr	r3, [r3, #0]
 8004070:	f003 0308 	and.w	r3, r3, #8
 8004074:	2b00      	cmp	r3, #0
 8004076:	d03c      	beq.n	80040f2 <HAL_RCC_OscConfig+0x446>
  {
    /* Check the parameters */
    assert_param(IS_RCC_LSI(RCC_OscInitStruct->LSIState));

    /* Check the LSI State */
    if(RCC_OscInitStruct->LSIState != RCC_LSI_OFF)
 8004078:	687b      	ldr	r3, [r7, #4]
 800407a:	695b      	ldr	r3, [r3, #20]
 800407c:	2b00      	cmp	r3, #0
 800407e:	d01c      	beq.n	80040ba <HAL_RCC_OscConfig+0x40e>
        MODIFY_REG(RCC->CSR, RCC_CSR_LSIPREDIV, RCC_OscInitStruct->LSIDiv);
      }
#endif /* RCC_CSR_LSIPREDIV */

      /* Enable the Internal Low Speed oscillator (LSI). */
      __HAL_RCC_LSI_ENABLE();
 8004080:	4b68      	ldr	r3, [pc, #416]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 8004082:	f8d3 3094 	ldr.w	r3, [r3, #148]	; 0x94
 8004086:	4a67      	ldr	r2, [pc, #412]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 8004088:	f043 0301 	orr.w	r3, r3, #1
 800408c:	f8c2 3094 	str.w	r3, [r2, #148]	; 0x94

      /* Get Start Tick*/
      tickstart = HAL_GetTick();
 8004090:	f7fd ffa8 	bl	8001fe4 <HAL_GetTick>
 8004094:	6138      	str	r0, [r7, #16]

      /* Wait till LSI is ready */
      while(READ_BIT(RCC->CSR, RCC_CSR_LSIRDY) == 0U)
 8004096:	e008      	b.n	80040aa <HAL_RCC_OscConfig+0x3fe>
      {
        if((HAL_GetTick() - tickstart) > LSI_TIMEOUT_VALUE)
 8004098:	f7fd ffa4 	bl	8001fe4 <HAL_GetTick>
 800409c:	4602      	mov	r2, r0
 800409e:	693b      	ldr	r3, [r7, #16]
 80040a0:	1ad3      	subs	r3, r2, r3
 80040a2:	2b02      	cmp	r3, #2
 80040a4:	d901      	bls.n	80040aa <HAL_RCC_OscConfig+0x3fe>
        {
          return HAL_TIMEOUT;
 80040a6:	2303      	movs	r3, #3
 80040a8:	e1de      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
      while(READ_BIT(RCC->CSR, RCC_CSR_LSIRDY) == 0U)
 80040aa:	4b5e      	ldr	r3, [pc, #376]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 80040ac:	f8d3 3094 	ldr.w	r3, [r3, #148]	; 0x94
 80040b0:	f003 0302 	and.w	r3, r3, #2
 80040b4:	2b00      	cmp	r3, #0
 80040b6:	d0ef      	beq.n	8004098 <HAL_RCC_OscConfig+0x3ec>
 80040b8:	e01b      	b.n	80040f2 <HAL_RCC_OscConfig+0x446>
      }
    }
    else
    {
      /* Disable the Internal Low Speed oscillator (LSI). */
      __HAL_RCC_LSI_DISABLE();
 80040ba:	4b5a      	ldr	r3, [pc, #360]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 80040bc:	f8d3 3094 	ldr.w	r3, [r3, #148]	; 0x94
 80040c0:	4a58      	ldr	r2, [pc, #352]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 80040c2:	f023 0301 	bic.w	r3, r3, #1
 80040c6:	f8c2 3094 	str.w	r3, [r2, #148]	; 0x94

      /* Get Start Tick*/
      tickstart = HAL_GetTick();
 80040ca:	f7fd ff8b 	bl	8001fe4 <HAL_GetTick>
 80040ce:	6138      	str	r0, [r7, #16]

      /* Wait till LSI is disabled */
      while(READ_BIT(RCC->CSR, RCC_CSR_LSIRDY) != 0U)
 80040d0:	e008      	b.n	80040e4 <HAL_RCC_OscConfig+0x438>
      {
        if((HAL_GetTick() - tickstart) > LSI_TIMEOUT_VALUE)
 80040d2:	f7fd ff87 	bl	8001fe4 <HAL_GetTick>
 80040d6:	4602      	mov	r2, r0
 80040d8:	693b      	ldr	r3, [r7, #16]
 80040da:	1ad3      	subs	r3, r2, r3
 80040dc:	2b02      	cmp	r3, #2
 80040de:	d901      	bls.n	80040e4 <HAL_RCC_OscConfig+0x438>
        {
          return HAL_TIMEOUT;
 80040e0:	2303      	movs	r3, #3
 80040e2:	e1c1      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
      while(READ_BIT(RCC->CSR, RCC_CSR_LSIRDY) != 0U)
 80040e4:	4b4f      	ldr	r3, [pc, #316]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 80040e6:	f8d3 3094 	ldr.w	r3, [r3, #148]	; 0x94
 80040ea:	f003 0302 	and.w	r3, r3, #2
 80040ee:	2b00      	cmp	r3, #0
 80040f0:	d1ef      	bne.n	80040d2 <HAL_RCC_OscConfig+0x426>
        }
      }
    }
  }
  /*------------------------------ LSE Configuration -------------------------*/
  if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_LSE) == RCC_OSCILLATORTYPE_LSE)
 80040f2:	687b      	ldr	r3, [r7, #4]
 80040f4:	681b      	ldr	r3, [r3, #0]
 80040f6:	f003 0304 	and.w	r3, r3, #4
 80040fa:	2b00      	cmp	r3, #0
 80040fc:	f000 80a6 	beq.w	800424c <HAL_RCC_OscConfig+0x5a0>
  {
    FlagStatus       pwrclkchanged = RESET;
 8004100:	2300      	movs	r3, #0
 8004102:	77fb      	strb	r3, [r7, #31]
    /* 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_IS_BIT_CLR(RCC->APB1ENR1, RCC_APB1ENR1_PWREN))
 8004104:	4b47      	ldr	r3, [pc, #284]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 8004106:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 8004108:	f003 5380 	and.w	r3, r3, #268435456	; 0x10000000
 800410c:	2b00      	cmp	r3, #0
 800410e:	d10d      	bne.n	800412c <HAL_RCC_OscConfig+0x480>
    {
      __HAL_RCC_PWR_CLK_ENABLE();
 8004110:	4b44      	ldr	r3, [pc, #272]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 8004112:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 8004114:	4a43      	ldr	r2, [pc, #268]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 8004116:	f043 5380 	orr.w	r3, r3, #268435456	; 0x10000000
 800411a:	6593      	str	r3, [r2, #88]	; 0x58
 800411c:	4b41      	ldr	r3, [pc, #260]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 800411e:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 8004120:	f003 5380 	and.w	r3, r3, #268435456	; 0x10000000
 8004124:	60bb      	str	r3, [r7, #8]
 8004126:	68bb      	ldr	r3, [r7, #8]
      pwrclkchanged = SET;
 8004128:	2301      	movs	r3, #1
 800412a:	77fb      	strb	r3, [r7, #31]
    }

    if(HAL_IS_BIT_CLR(PWR->CR1, PWR_CR1_DBP))
 800412c:	4b3e      	ldr	r3, [pc, #248]	; (8004228 <HAL_RCC_OscConfig+0x57c>)
 800412e:	681b      	ldr	r3, [r3, #0]
 8004130:	f403 7380 	and.w	r3, r3, #256	; 0x100
 8004134:	2b00      	cmp	r3, #0
 8004136:	d118      	bne.n	800416a <HAL_RCC_OscConfig+0x4be>
    {
      /* Enable write access to Backup domain */
      SET_BIT(PWR->CR1, PWR_CR1_DBP);
 8004138:	4b3b      	ldr	r3, [pc, #236]	; (8004228 <HAL_RCC_OscConfig+0x57c>)
 800413a:	681b      	ldr	r3, [r3, #0]
 800413c:	4a3a      	ldr	r2, [pc, #232]	; (8004228 <HAL_RCC_OscConfig+0x57c>)
 800413e:	f443 7380 	orr.w	r3, r3, #256	; 0x100
 8004142:	6013      	str	r3, [r2, #0]

      /* Wait for Backup domain Write protection disable */
      tickstart = HAL_GetTick();
 8004144:	f7fd ff4e 	bl	8001fe4 <HAL_GetTick>
 8004148:	6138      	str	r0, [r7, #16]

      while(HAL_IS_BIT_CLR(PWR->CR1, PWR_CR1_DBP))
 800414a:	e008      	b.n	800415e <HAL_RCC_OscConfig+0x4b2>
      {
        if((HAL_GetTick() - tickstart) > RCC_DBP_TIMEOUT_VALUE)
 800414c:	f7fd ff4a 	bl	8001fe4 <HAL_GetTick>
 8004150:	4602      	mov	r2, r0
 8004152:	693b      	ldr	r3, [r7, #16]
 8004154:	1ad3      	subs	r3, r2, r3
 8004156:	2b02      	cmp	r3, #2
 8004158:	d901      	bls.n	800415e <HAL_RCC_OscConfig+0x4b2>
        {
          return HAL_TIMEOUT;
 800415a:	2303      	movs	r3, #3
 800415c:	e184      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
      while(HAL_IS_BIT_CLR(PWR->CR1, PWR_CR1_DBP))
 800415e:	4b32      	ldr	r3, [pc, #200]	; (8004228 <HAL_RCC_OscConfig+0x57c>)
 8004160:	681b      	ldr	r3, [r3, #0]
 8004162:	f403 7380 	and.w	r3, r3, #256	; 0x100
 8004166:	2b00      	cmp	r3, #0
 8004168:	d0f0      	beq.n	800414c <HAL_RCC_OscConfig+0x4a0>
    {
      CLEAR_BIT(RCC->BDCR, RCC_BDCR_LSEON);
      CLEAR_BIT(RCC->BDCR, RCC_BDCR_LSEBYP);
    }
#else
    __HAL_RCC_LSE_CONFIG(RCC_OscInitStruct->LSEState);
 800416a:	687b      	ldr	r3, [r7, #4]
 800416c:	689b      	ldr	r3, [r3, #8]
 800416e:	2b01      	cmp	r3, #1
 8004170:	d108      	bne.n	8004184 <HAL_RCC_OscConfig+0x4d8>
 8004172:	4b2c      	ldr	r3, [pc, #176]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 8004174:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8004178:	4a2a      	ldr	r2, [pc, #168]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 800417a:	f043 0301 	orr.w	r3, r3, #1
 800417e:	f8c2 3090 	str.w	r3, [r2, #144]	; 0x90
 8004182:	e024      	b.n	80041ce <HAL_RCC_OscConfig+0x522>
 8004184:	687b      	ldr	r3, [r7, #4]
 8004186:	689b      	ldr	r3, [r3, #8]
 8004188:	2b05      	cmp	r3, #5
 800418a:	d110      	bne.n	80041ae <HAL_RCC_OscConfig+0x502>
 800418c:	4b25      	ldr	r3, [pc, #148]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 800418e:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8004192:	4a24      	ldr	r2, [pc, #144]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 8004194:	f043 0304 	orr.w	r3, r3, #4
 8004198:	f8c2 3090 	str.w	r3, [r2, #144]	; 0x90
 800419c:	4b21      	ldr	r3, [pc, #132]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 800419e:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 80041a2:	4a20      	ldr	r2, [pc, #128]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 80041a4:	f043 0301 	orr.w	r3, r3, #1
 80041a8:	f8c2 3090 	str.w	r3, [r2, #144]	; 0x90
 80041ac:	e00f      	b.n	80041ce <HAL_RCC_OscConfig+0x522>
 80041ae:	4b1d      	ldr	r3, [pc, #116]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 80041b0:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 80041b4:	4a1b      	ldr	r2, [pc, #108]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 80041b6:	f023 0301 	bic.w	r3, r3, #1
 80041ba:	f8c2 3090 	str.w	r3, [r2, #144]	; 0x90
 80041be:	4b19      	ldr	r3, [pc, #100]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 80041c0:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 80041c4:	4a17      	ldr	r2, [pc, #92]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 80041c6:	f023 0304 	bic.w	r3, r3, #4
 80041ca:	f8c2 3090 	str.w	r3, [r2, #144]	; 0x90
#endif /* RCC_BDCR_LSESYSDIS */

    /* Check the LSE State */
    if(RCC_OscInitStruct->LSEState != RCC_LSE_OFF)
 80041ce:	687b      	ldr	r3, [r7, #4]
 80041d0:	689b      	ldr	r3, [r3, #8]
 80041d2:	2b00      	cmp	r3, #0
 80041d4:	d016      	beq.n	8004204 <HAL_RCC_OscConfig+0x558>
    {
      /* Get Start Tick*/
      tickstart = HAL_GetTick();
 80041d6:	f7fd ff05 	bl	8001fe4 <HAL_GetTick>
 80041da:	6138      	str	r0, [r7, #16]

      /* Wait till LSE is ready */
      while(READ_BIT(RCC->BDCR, RCC_BDCR_LSERDY) == 0U)
 80041dc:	e00a      	b.n	80041f4 <HAL_RCC_OscConfig+0x548>
      {
        if((HAL_GetTick() - tickstart) > RCC_LSE_TIMEOUT_VALUE)
 80041de:	f7fd ff01 	bl	8001fe4 <HAL_GetTick>
 80041e2:	4602      	mov	r2, r0
 80041e4:	693b      	ldr	r3, [r7, #16]
 80041e6:	1ad3      	subs	r3, r2, r3
 80041e8:	f241 3288 	movw	r2, #5000	; 0x1388
 80041ec:	4293      	cmp	r3, r2
 80041ee:	d901      	bls.n	80041f4 <HAL_RCC_OscConfig+0x548>
        {
          return HAL_TIMEOUT;
 80041f0:	2303      	movs	r3, #3
 80041f2:	e139      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
      while(READ_BIT(RCC->BDCR, RCC_BDCR_LSERDY) == 0U)
 80041f4:	4b0b      	ldr	r3, [pc, #44]	; (8004224 <HAL_RCC_OscConfig+0x578>)
 80041f6:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 80041fa:	f003 0302 	and.w	r3, r3, #2
 80041fe:	2b00      	cmp	r3, #0
 8004200:	d0ed      	beq.n	80041de <HAL_RCC_OscConfig+0x532>
 8004202:	e01a      	b.n	800423a <HAL_RCC_OscConfig+0x58e>
      }
    }
    else
    {
      /* Get Start Tick*/
      tickstart = HAL_GetTick();
 8004204:	f7fd feee 	bl	8001fe4 <HAL_GetTick>
 8004208:	6138      	str	r0, [r7, #16]

      /* Wait till LSE is disabled */
      while(READ_BIT(RCC->BDCR, RCC_BDCR_LSERDY) != 0U)
 800420a:	e00f      	b.n	800422c <HAL_RCC_OscConfig+0x580>
      {
        if((HAL_GetTick() - tickstart) > RCC_LSE_TIMEOUT_VALUE)
 800420c:	f7fd feea 	bl	8001fe4 <HAL_GetTick>
 8004210:	4602      	mov	r2, r0
 8004212:	693b      	ldr	r3, [r7, #16]
 8004214:	1ad3      	subs	r3, r2, r3
 8004216:	f241 3288 	movw	r2, #5000	; 0x1388
 800421a:	4293      	cmp	r3, r2
 800421c:	d906      	bls.n	800422c <HAL_RCC_OscConfig+0x580>
        {
          return HAL_TIMEOUT;
 800421e:	2303      	movs	r3, #3
 8004220:	e122      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
 8004222:	bf00      	nop
 8004224:	40021000 	.word	0x40021000
 8004228:	40007000 	.word	0x40007000
      while(READ_BIT(RCC->BDCR, RCC_BDCR_LSERDY) != 0U)
 800422c:	4b90      	ldr	r3, [pc, #576]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 800422e:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8004232:	f003 0302 	and.w	r3, r3, #2
 8004236:	2b00      	cmp	r3, #0
 8004238:	d1e8      	bne.n	800420c <HAL_RCC_OscConfig+0x560>
      CLEAR_BIT(RCC->BDCR, RCC_BDCR_LSESYSDIS);
#endif /* RCC_BDCR_LSESYSDIS */
    }

    /* Restore clock configuration if changed */
    if(pwrclkchanged == SET)
 800423a:	7ffb      	ldrb	r3, [r7, #31]
 800423c:	2b01      	cmp	r3, #1
 800423e:	d105      	bne.n	800424c <HAL_RCC_OscConfig+0x5a0>
    {
      __HAL_RCC_PWR_CLK_DISABLE();
 8004240:	4b8b      	ldr	r3, [pc, #556]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 8004242:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 8004244:	4a8a      	ldr	r2, [pc, #552]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 8004246:	f023 5380 	bic.w	r3, r3, #268435456	; 0x10000000
 800424a:	6593      	str	r3, [r2, #88]	; 0x58
#endif /* RCC_HSI48_SUPPORT */
  /*-------------------------------- PLL Configuration -----------------------*/
  /* Check the parameters */
  assert_param(IS_RCC_PLL(RCC_OscInitStruct->PLL.PLLState));

  if(RCC_OscInitStruct->PLL.PLLState != RCC_PLL_NONE)
 800424c:	687b      	ldr	r3, [r7, #4]
 800424e:	6a9b      	ldr	r3, [r3, #40]	; 0x28
 8004250:	2b00      	cmp	r3, #0
 8004252:	f000 8108 	beq.w	8004466 <HAL_RCC_OscConfig+0x7ba>
  {
    /* PLL On ? */
    if(RCC_OscInitStruct->PLL.PLLState == RCC_PLL_ON)
 8004256:	687b      	ldr	r3, [r7, #4]
 8004258:	6a9b      	ldr	r3, [r3, #40]	; 0x28
 800425a:	2b02      	cmp	r3, #2
 800425c:	f040 80d0 	bne.w	8004400 <HAL_RCC_OscConfig+0x754>
#endif /* RCC_PLLP_SUPPORT */
      assert_param(IS_RCC_PLLQ_VALUE(RCC_OscInitStruct->PLL.PLLQ));
      assert_param(IS_RCC_PLLR_VALUE(RCC_OscInitStruct->PLL.PLLR));

      /* Do nothing if PLL configuration is the unchanged */
      pll_config = RCC->PLLCFGR;
 8004260:	4b83      	ldr	r3, [pc, #524]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 8004262:	68db      	ldr	r3, [r3, #12]
 8004264:	617b      	str	r3, [r7, #20]
      if((READ_BIT(pll_config, RCC_PLLCFGR_PLLSRC)  != RCC_OscInitStruct->PLL.PLLSource) ||
 8004266:	697b      	ldr	r3, [r7, #20]
 8004268:	f003 0203 	and.w	r2, r3, #3
 800426c:	687b      	ldr	r3, [r7, #4]
 800426e:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8004270:	429a      	cmp	r2, r3
 8004272:	d130      	bne.n	80042d6 <HAL_RCC_OscConfig+0x62a>
         (READ_BIT(pll_config, RCC_PLLCFGR_PLLM)    != ((RCC_OscInitStruct->PLL.PLLM - 1U) << RCC_PLLCFGR_PLLM_Pos)) ||
 8004274:	697b      	ldr	r3, [r7, #20]
 8004276:	f003 0270 	and.w	r2, r3, #112	; 0x70
 800427a:	687b      	ldr	r3, [r7, #4]
 800427c:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 800427e:	3b01      	subs	r3, #1
 8004280:	011b      	lsls	r3, r3, #4
      if((READ_BIT(pll_config, RCC_PLLCFGR_PLLSRC)  != RCC_OscInitStruct->PLL.PLLSource) ||
 8004282:	429a      	cmp	r2, r3
 8004284:	d127      	bne.n	80042d6 <HAL_RCC_OscConfig+0x62a>
         (READ_BIT(pll_config, RCC_PLLCFGR_PLLN)    != (RCC_OscInitStruct->PLL.PLLN << RCC_PLLCFGR_PLLN_Pos)) ||
 8004286:	697b      	ldr	r3, [r7, #20]
 8004288:	f403 42fe 	and.w	r2, r3, #32512	; 0x7f00
 800428c:	687b      	ldr	r3, [r7, #4]
 800428e:	6b5b      	ldr	r3, [r3, #52]	; 0x34
 8004290:	021b      	lsls	r3, r3, #8
         (READ_BIT(pll_config, RCC_PLLCFGR_PLLM)    != ((RCC_OscInitStruct->PLL.PLLM - 1U) << RCC_PLLCFGR_PLLM_Pos)) ||
 8004292:	429a      	cmp	r2, r3
 8004294:	d11f      	bne.n	80042d6 <HAL_RCC_OscConfig+0x62a>
#if defined(RCC_PLLP_SUPPORT)
#if defined(RCC_PLLP_DIV_2_31_SUPPORT)
         (READ_BIT(pll_config, RCC_PLLCFGR_PLLPDIV) != (RCC_OscInitStruct->PLL.PLLP << RCC_PLLCFGR_PLLPDIV_Pos)) ||
#else
         (READ_BIT(pll_config, RCC_PLLCFGR_PLLP)    != ((RCC_OscInitStruct->PLL.PLLP == RCC_PLLP_DIV7) ? 0U : 1U)) ||
 8004296:	697b      	ldr	r3, [r7, #20]
 8004298:	f403 3300 	and.w	r3, r3, #131072	; 0x20000
 800429c:	687a      	ldr	r2, [r7, #4]
 800429e:	6b92      	ldr	r2, [r2, #56]	; 0x38
 80042a0:	2a07      	cmp	r2, #7
 80042a2:	bf14      	ite	ne
 80042a4:	2201      	movne	r2, #1
 80042a6:	2200      	moveq	r2, #0
 80042a8:	b2d2      	uxtb	r2, r2
         (READ_BIT(pll_config, RCC_PLLCFGR_PLLN)    != (RCC_OscInitStruct->PLL.PLLN << RCC_PLLCFGR_PLLN_Pos)) ||
 80042aa:	4293      	cmp	r3, r2
 80042ac:	d113      	bne.n	80042d6 <HAL_RCC_OscConfig+0x62a>
#endif
#endif
         (READ_BIT(pll_config, RCC_PLLCFGR_PLLQ)    != ((((RCC_OscInitStruct->PLL.PLLQ) >> 1U) - 1U) << RCC_PLLCFGR_PLLQ_Pos)) ||
 80042ae:	697b      	ldr	r3, [r7, #20]
 80042b0:	f403 02c0 	and.w	r2, r3, #6291456	; 0x600000
 80042b4:	687b      	ldr	r3, [r7, #4]
 80042b6:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 80042b8:	085b      	lsrs	r3, r3, #1
 80042ba:	3b01      	subs	r3, #1
 80042bc:	055b      	lsls	r3, r3, #21
         (READ_BIT(pll_config, RCC_PLLCFGR_PLLP)    != ((RCC_OscInitStruct->PLL.PLLP == RCC_PLLP_DIV7) ? 0U : 1U)) ||
 80042be:	429a      	cmp	r2, r3
 80042c0:	d109      	bne.n	80042d6 <HAL_RCC_OscConfig+0x62a>
         (READ_BIT(pll_config, RCC_PLLCFGR_PLLR)    != ((((RCC_OscInitStruct->PLL.PLLR) >> 1U) - 1U) << RCC_PLLCFGR_PLLR_Pos)))
 80042c2:	697b      	ldr	r3, [r7, #20]
 80042c4:	f003 62c0 	and.w	r2, r3, #100663296	; 0x6000000
 80042c8:	687b      	ldr	r3, [r7, #4]
 80042ca:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 80042cc:	085b      	lsrs	r3, r3, #1
 80042ce:	3b01      	subs	r3, #1
 80042d0:	065b      	lsls	r3, r3, #25
         (READ_BIT(pll_config, RCC_PLLCFGR_PLLQ)    != ((((RCC_OscInitStruct->PLL.PLLQ) >> 1U) - 1U) << RCC_PLLCFGR_PLLQ_Pos)) ||
 80042d2:	429a      	cmp	r2, r3
 80042d4:	d06e      	beq.n	80043b4 <HAL_RCC_OscConfig+0x708>
      {
        /* Check if the PLL is used as system clock or not */
        if(sysclk_source != RCC_CFGR_SWS_PLL)
 80042d6:	69bb      	ldr	r3, [r7, #24]
 80042d8:	2b0c      	cmp	r3, #12
 80042da:	d069      	beq.n	80043b0 <HAL_RCC_OscConfig+0x704>
        {
#if defined(RCC_PLLSAI1_SUPPORT) || defined(RCC_PLLSAI2_SUPPORT)
          /* Check if main PLL can be updated */
          /* Not possible if the source is shared by other enabled PLLSAIx */
          if((READ_BIT(RCC->CR, RCC_CR_PLLSAI1ON) != 0U)
 80042dc:	4b64      	ldr	r3, [pc, #400]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 80042de:	681b      	ldr	r3, [r3, #0]
 80042e0:	f003 6380 	and.w	r3, r3, #67108864	; 0x4000000
 80042e4:	2b00      	cmp	r3, #0
 80042e6:	d105      	bne.n	80042f4 <HAL_RCC_OscConfig+0x648>
#if defined(RCC_PLLSAI2_SUPPORT)
             || (READ_BIT(RCC->CR, RCC_CR_PLLSAI2ON) != 0U)
 80042e8:	4b61      	ldr	r3, [pc, #388]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 80042ea:	681b      	ldr	r3, [r3, #0]
 80042ec:	f003 5380 	and.w	r3, r3, #268435456	; 0x10000000
 80042f0:	2b00      	cmp	r3, #0
 80042f2:	d001      	beq.n	80042f8 <HAL_RCC_OscConfig+0x64c>
#endif
            )
          {
            return HAL_ERROR;
 80042f4:	2301      	movs	r3, #1
 80042f6:	e0b7      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
          }
          else
#endif /* RCC_PLLSAI1_SUPPORT || RCC_PLLSAI2_SUPPORT */
          {
            /* Disable the main PLL. */
            __HAL_RCC_PLL_DISABLE();
 80042f8:	4b5d      	ldr	r3, [pc, #372]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 80042fa:	681b      	ldr	r3, [r3, #0]
 80042fc:	4a5c      	ldr	r2, [pc, #368]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 80042fe:	f023 7380 	bic.w	r3, r3, #16777216	; 0x1000000
 8004302:	6013      	str	r3, [r2, #0]

            /* Get Start Tick*/
            tickstart = HAL_GetTick();
 8004304:	f7fd fe6e 	bl	8001fe4 <HAL_GetTick>
 8004308:	6138      	str	r0, [r7, #16]

            /* Wait till PLL is ready */
            while(READ_BIT(RCC->CR, RCC_CR_PLLRDY) != 0U)
 800430a:	e008      	b.n	800431e <HAL_RCC_OscConfig+0x672>
            {
              if((HAL_GetTick() - tickstart) > PLL_TIMEOUT_VALUE)
 800430c:	f7fd fe6a 	bl	8001fe4 <HAL_GetTick>
 8004310:	4602      	mov	r2, r0
 8004312:	693b      	ldr	r3, [r7, #16]
 8004314:	1ad3      	subs	r3, r2, r3
 8004316:	2b02      	cmp	r3, #2
 8004318:	d901      	bls.n	800431e <HAL_RCC_OscConfig+0x672>
              {
                return HAL_TIMEOUT;
 800431a:	2303      	movs	r3, #3
 800431c:	e0a4      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
            while(READ_BIT(RCC->CR, RCC_CR_PLLRDY) != 0U)
 800431e:	4b54      	ldr	r3, [pc, #336]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 8004320:	681b      	ldr	r3, [r3, #0]
 8004322:	f003 7300 	and.w	r3, r3, #33554432	; 0x2000000
 8004326:	2b00      	cmp	r3, #0
 8004328:	d1f0      	bne.n	800430c <HAL_RCC_OscConfig+0x660>
              }
            }

            /* Configure the main PLL clock source, multiplication and division factors. */
#if defined(RCC_PLLP_SUPPORT)
            __HAL_RCC_PLL_CONFIG(RCC_OscInitStruct->PLL.PLLSource,
 800432a:	4b51      	ldr	r3, [pc, #324]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 800432c:	68da      	ldr	r2, [r3, #12]
 800432e:	4b51      	ldr	r3, [pc, #324]	; (8004474 <HAL_RCC_OscConfig+0x7c8>)
 8004330:	4013      	ands	r3, r2
 8004332:	687a      	ldr	r2, [r7, #4]
 8004334:	6ad1      	ldr	r1, [r2, #44]	; 0x2c
 8004336:	687a      	ldr	r2, [r7, #4]
 8004338:	6b12      	ldr	r2, [r2, #48]	; 0x30
 800433a:	3a01      	subs	r2, #1
 800433c:	0112      	lsls	r2, r2, #4
 800433e:	4311      	orrs	r1, r2
 8004340:	687a      	ldr	r2, [r7, #4]
 8004342:	6b52      	ldr	r2, [r2, #52]	; 0x34
 8004344:	0212      	lsls	r2, r2, #8
 8004346:	4311      	orrs	r1, r2
 8004348:	687a      	ldr	r2, [r7, #4]
 800434a:	6bd2      	ldr	r2, [r2, #60]	; 0x3c
 800434c:	0852      	lsrs	r2, r2, #1
 800434e:	3a01      	subs	r2, #1
 8004350:	0552      	lsls	r2, r2, #21
 8004352:	4311      	orrs	r1, r2
 8004354:	687a      	ldr	r2, [r7, #4]
 8004356:	6c12      	ldr	r2, [r2, #64]	; 0x40
 8004358:	0852      	lsrs	r2, r2, #1
 800435a:	3a01      	subs	r2, #1
 800435c:	0652      	lsls	r2, r2, #25
 800435e:	4311      	orrs	r1, r2
 8004360:	687a      	ldr	r2, [r7, #4]
 8004362:	6b92      	ldr	r2, [r2, #56]	; 0x38
 8004364:	0912      	lsrs	r2, r2, #4
 8004366:	0452      	lsls	r2, r2, #17
 8004368:	430a      	orrs	r2, r1
 800436a:	4941      	ldr	r1, [pc, #260]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 800436c:	4313      	orrs	r3, r2
 800436e:	60cb      	str	r3, [r1, #12]
                                 RCC_OscInitStruct->PLL.PLLQ,
                                 RCC_OscInitStruct->PLL.PLLR);
#endif

            /* Enable the main PLL. */
            __HAL_RCC_PLL_ENABLE();
 8004370:	4b3f      	ldr	r3, [pc, #252]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 8004372:	681b      	ldr	r3, [r3, #0]
 8004374:	4a3e      	ldr	r2, [pc, #248]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 8004376:	f043 7380 	orr.w	r3, r3, #16777216	; 0x1000000
 800437a:	6013      	str	r3, [r2, #0]

            /* Enable PLL System Clock output. */
            __HAL_RCC_PLLCLKOUT_ENABLE(RCC_PLL_SYSCLK);
 800437c:	4b3c      	ldr	r3, [pc, #240]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 800437e:	68db      	ldr	r3, [r3, #12]
 8004380:	4a3b      	ldr	r2, [pc, #236]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 8004382:	f043 7380 	orr.w	r3, r3, #16777216	; 0x1000000
 8004386:	60d3      	str	r3, [r2, #12]

            /* Get Start Tick*/
            tickstart = HAL_GetTick();
 8004388:	f7fd fe2c 	bl	8001fe4 <HAL_GetTick>
 800438c:	6138      	str	r0, [r7, #16]

            /* Wait till PLL is ready */
            while(READ_BIT(RCC->CR, RCC_CR_PLLRDY) == 0U)
 800438e:	e008      	b.n	80043a2 <HAL_RCC_OscConfig+0x6f6>
            {
              if((HAL_GetTick() - tickstart) > PLL_TIMEOUT_VALUE)
 8004390:	f7fd fe28 	bl	8001fe4 <HAL_GetTick>
 8004394:	4602      	mov	r2, r0
 8004396:	693b      	ldr	r3, [r7, #16]
 8004398:	1ad3      	subs	r3, r2, r3
 800439a:	2b02      	cmp	r3, #2
 800439c:	d901      	bls.n	80043a2 <HAL_RCC_OscConfig+0x6f6>
              {
                return HAL_TIMEOUT;
 800439e:	2303      	movs	r3, #3
 80043a0:	e062      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
            while(READ_BIT(RCC->CR, RCC_CR_PLLRDY) == 0U)
 80043a2:	4b33      	ldr	r3, [pc, #204]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 80043a4:	681b      	ldr	r3, [r3, #0]
 80043a6:	f003 7300 	and.w	r3, r3, #33554432	; 0x2000000
 80043aa:	2b00      	cmp	r3, #0
 80043ac:	d0f0      	beq.n	8004390 <HAL_RCC_OscConfig+0x6e4>
        if(sysclk_source != RCC_CFGR_SWS_PLL)
 80043ae:	e05a      	b.n	8004466 <HAL_RCC_OscConfig+0x7ba>
          }
        }
        else
        {
          /* PLL is already used as System core clock */
          return HAL_ERROR;
 80043b0:	2301      	movs	r3, #1
 80043b2:	e059      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
      }
      else
      {
        /* PLL configuration is unchanged */
        /* Re-enable PLL if it was disabled (ie. low power mode) */
        if(READ_BIT(RCC->CR, RCC_CR_PLLRDY) == 0U)
 80043b4:	4b2e      	ldr	r3, [pc, #184]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 80043b6:	681b      	ldr	r3, [r3, #0]
 80043b8:	f003 7300 	and.w	r3, r3, #33554432	; 0x2000000
 80043bc:	2b00      	cmp	r3, #0
 80043be:	d152      	bne.n	8004466 <HAL_RCC_OscConfig+0x7ba>
        {
          /* Enable the main PLL. */
          __HAL_RCC_PLL_ENABLE();
 80043c0:	4b2b      	ldr	r3, [pc, #172]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 80043c2:	681b      	ldr	r3, [r3, #0]
 80043c4:	4a2a      	ldr	r2, [pc, #168]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 80043c6:	f043 7380 	orr.w	r3, r3, #16777216	; 0x1000000
 80043ca:	6013      	str	r3, [r2, #0]

          /* Enable PLL System Clock output. */
          __HAL_RCC_PLLCLKOUT_ENABLE(RCC_PLL_SYSCLK);
 80043cc:	4b28      	ldr	r3, [pc, #160]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 80043ce:	68db      	ldr	r3, [r3, #12]
 80043d0:	4a27      	ldr	r2, [pc, #156]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 80043d2:	f043 7380 	orr.w	r3, r3, #16777216	; 0x1000000
 80043d6:	60d3      	str	r3, [r2, #12]

          /* Get Start Tick*/
          tickstart = HAL_GetTick();
 80043d8:	f7fd fe04 	bl	8001fe4 <HAL_GetTick>
 80043dc:	6138      	str	r0, [r7, #16]

          /* Wait till PLL is ready */
          while(READ_BIT(RCC->CR, RCC_CR_PLLRDY) == 0U)
 80043de:	e008      	b.n	80043f2 <HAL_RCC_OscConfig+0x746>
          {
            if((HAL_GetTick() - tickstart) > PLL_TIMEOUT_VALUE)
 80043e0:	f7fd fe00 	bl	8001fe4 <HAL_GetTick>
 80043e4:	4602      	mov	r2, r0
 80043e6:	693b      	ldr	r3, [r7, #16]
 80043e8:	1ad3      	subs	r3, r2, r3
 80043ea:	2b02      	cmp	r3, #2
 80043ec:	d901      	bls.n	80043f2 <HAL_RCC_OscConfig+0x746>
            {
              return HAL_TIMEOUT;
 80043ee:	2303      	movs	r3, #3
 80043f0:	e03a      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
          while(READ_BIT(RCC->CR, RCC_CR_PLLRDY) == 0U)
 80043f2:	4b1f      	ldr	r3, [pc, #124]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 80043f4:	681b      	ldr	r3, [r3, #0]
 80043f6:	f003 7300 	and.w	r3, r3, #33554432	; 0x2000000
 80043fa:	2b00      	cmp	r3, #0
 80043fc:	d0f0      	beq.n	80043e0 <HAL_RCC_OscConfig+0x734>
 80043fe:	e032      	b.n	8004466 <HAL_RCC_OscConfig+0x7ba>
      }
    }
    else
    {
      /* Check that PLL is not used as system clock or not */
      if(sysclk_source != RCC_CFGR_SWS_PLL)
 8004400:	69bb      	ldr	r3, [r7, #24]
 8004402:	2b0c      	cmp	r3, #12
 8004404:	d02d      	beq.n	8004462 <HAL_RCC_OscConfig+0x7b6>
      {
        /* Disable the main PLL. */
        __HAL_RCC_PLL_DISABLE();
 8004406:	4b1a      	ldr	r3, [pc, #104]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 8004408:	681b      	ldr	r3, [r3, #0]
 800440a:	4a19      	ldr	r2, [pc, #100]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 800440c:	f023 7380 	bic.w	r3, r3, #16777216	; 0x1000000
 8004410:	6013      	str	r3, [r2, #0]

        /* Disable all PLL outputs to save power if no PLLs on */
#if defined(RCC_PLLSAI1_SUPPORT) && defined(RCC_CR_PLLSAI2RDY)
        if(READ_BIT(RCC->CR, (RCC_CR_PLLSAI1RDY | RCC_CR_PLLSAI2RDY)) == 0U)
 8004412:	4b17      	ldr	r3, [pc, #92]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 8004414:	681b      	ldr	r3, [r3, #0]
 8004416:	f003 5320 	and.w	r3, r3, #671088640	; 0x28000000
 800441a:	2b00      	cmp	r3, #0
 800441c:	d105      	bne.n	800442a <HAL_RCC_OscConfig+0x77e>
        {
          MODIFY_REG(RCC->PLLCFGR, RCC_PLLCFGR_PLLSRC, RCC_PLLSOURCE_NONE);
 800441e:	4b14      	ldr	r3, [pc, #80]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 8004420:	68db      	ldr	r3, [r3, #12]
 8004422:	4a13      	ldr	r2, [pc, #76]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 8004424:	f023 0303 	bic.w	r3, r3, #3
 8004428:	60d3      	str	r3, [r2, #12]
#else
        MODIFY_REG(RCC->PLLCFGR, RCC_PLLCFGR_PLLSRC, RCC_PLLSOURCE_NONE);
#endif /* RCC_PLLSAI1_SUPPORT && RCC_CR_PLLSAI2RDY */

#if defined(RCC_PLLSAI2_SUPPORT)
        __HAL_RCC_PLLCLKOUT_DISABLE(RCC_PLL_SYSCLK | RCC_PLL_48M1CLK | RCC_PLL_SAI3CLK);
 800442a:	4b11      	ldr	r3, [pc, #68]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 800442c:	68db      	ldr	r3, [r3, #12]
 800442e:	4a10      	ldr	r2, [pc, #64]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 8004430:	f023 7388 	bic.w	r3, r3, #17825792	; 0x1100000
 8004434:	f423 3380 	bic.w	r3, r3, #65536	; 0x10000
 8004438:	60d3      	str	r3, [r2, #12]
#else
        __HAL_RCC_PLLCLKOUT_DISABLE(RCC_PLL_SYSCLK | RCC_PLL_48M1CLK);
#endif /* RCC_PLLSAI2_SUPPORT */

        /* Get Start Tick*/
        tickstart = HAL_GetTick();
 800443a:	f7fd fdd3 	bl	8001fe4 <HAL_GetTick>
 800443e:	6138      	str	r0, [r7, #16]

        /* Wait till PLL is disabled */
        while(READ_BIT(RCC->CR, RCC_CR_PLLRDY) != 0U)
 8004440:	e008      	b.n	8004454 <HAL_RCC_OscConfig+0x7a8>
        {
          if((HAL_GetTick() - tickstart) > PLL_TIMEOUT_VALUE)
 8004442:	f7fd fdcf 	bl	8001fe4 <HAL_GetTick>
 8004446:	4602      	mov	r2, r0
 8004448:	693b      	ldr	r3, [r7, #16]
 800444a:	1ad3      	subs	r3, r2, r3
 800444c:	2b02      	cmp	r3, #2
 800444e:	d901      	bls.n	8004454 <HAL_RCC_OscConfig+0x7a8>
          {
            return HAL_TIMEOUT;
 8004450:	2303      	movs	r3, #3
 8004452:	e009      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
        while(READ_BIT(RCC->CR, RCC_CR_PLLRDY) != 0U)
 8004454:	4b06      	ldr	r3, [pc, #24]	; (8004470 <HAL_RCC_OscConfig+0x7c4>)
 8004456:	681b      	ldr	r3, [r3, #0]
 8004458:	f003 7300 	and.w	r3, r3, #33554432	; 0x2000000
 800445c:	2b00      	cmp	r3, #0
 800445e:	d1f0      	bne.n	8004442 <HAL_RCC_OscConfig+0x796>
 8004460:	e001      	b.n	8004466 <HAL_RCC_OscConfig+0x7ba>
        }
      }
      else
      {
        /* PLL is already used as System core clock */
        return HAL_ERROR;
 8004462:	2301      	movs	r3, #1
 8004464:	e000      	b.n	8004468 <HAL_RCC_OscConfig+0x7bc>
      }
    }
  }
  return HAL_OK;
 8004466:	2300      	movs	r3, #0
}
 8004468:	4618      	mov	r0, r3
 800446a:	3720      	adds	r7, #32
 800446c:	46bd      	mov	sp, r7
 800446e:	bd80      	pop	{r7, pc}
 8004470:	40021000 	.word	0x40021000
 8004474:	f99d808c 	.word	0xf99d808c

08004478 <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)
{
 8004478:	b580      	push	{r7, lr}
 800447a:	b084      	sub	sp, #16
 800447c:	af00      	add	r7, sp, #0
 800447e:	6078      	str	r0, [r7, #4]
 8004480:	6039      	str	r1, [r7, #0]
  uint32_t hpre = RCC_SYSCLK_DIV1;
#endif
  HAL_StatusTypeDef status;

  /* Check Null pointer */
  if(RCC_ClkInitStruct == NULL)
 8004482:	687b      	ldr	r3, [r7, #4]
 8004484:	2b00      	cmp	r3, #0
 8004486:	d101      	bne.n	800448c <HAL_RCC_ClockConfig+0x14>
  {
    return HAL_ERROR;
 8004488:	2301      	movs	r3, #1
 800448a:	e0c8      	b.n	800461e <HAL_RCC_ClockConfig+0x1a6>
  /* 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 number of wait states because of higher CPU frequency */
  if(FLatency > __HAL_FLASH_GET_LATENCY())
 800448c:	4b66      	ldr	r3, [pc, #408]	; (8004628 <HAL_RCC_ClockConfig+0x1b0>)
 800448e:	681b      	ldr	r3, [r3, #0]
 8004490:	f003 0307 	and.w	r3, r3, #7
 8004494:	683a      	ldr	r2, [r7, #0]
 8004496:	429a      	cmp	r2, r3
 8004498:	d910      	bls.n	80044bc <HAL_RCC_ClockConfig+0x44>
  {
    /* Program the new number of wait states to the LATENCY bits in the FLASH_ACR register */
    __HAL_FLASH_SET_LATENCY(FLatency);
 800449a:	4b63      	ldr	r3, [pc, #396]	; (8004628 <HAL_RCC_ClockConfig+0x1b0>)
 800449c:	681b      	ldr	r3, [r3, #0]
 800449e:	f023 0207 	bic.w	r2, r3, #7
 80044a2:	4961      	ldr	r1, [pc, #388]	; (8004628 <HAL_RCC_ClockConfig+0x1b0>)
 80044a4:	683b      	ldr	r3, [r7, #0]
 80044a6:	4313      	orrs	r3, r2
 80044a8:	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)
 80044aa:	4b5f      	ldr	r3, [pc, #380]	; (8004628 <HAL_RCC_ClockConfig+0x1b0>)
 80044ac:	681b      	ldr	r3, [r3, #0]
 80044ae:	f003 0307 	and.w	r3, r3, #7
 80044b2:	683a      	ldr	r2, [r7, #0]
 80044b4:	429a      	cmp	r2, r3
 80044b6:	d001      	beq.n	80044bc <HAL_RCC_ClockConfig+0x44>
    {
      return HAL_ERROR;
 80044b8:	2301      	movs	r3, #1
 80044ba:	e0b0      	b.n	800461e <HAL_RCC_ClockConfig+0x1a6>
    }
  }

  /*------------------------- SYSCLK Configuration ---------------------------*/
  if(((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_SYSCLK) == RCC_CLOCKTYPE_SYSCLK)
 80044bc:	687b      	ldr	r3, [r7, #4]
 80044be:	681b      	ldr	r3, [r3, #0]
 80044c0:	f003 0301 	and.w	r3, r3, #1
 80044c4:	2b00      	cmp	r3, #0
 80044c6:	d04c      	beq.n	8004562 <HAL_RCC_ClockConfig+0xea>
  {
    assert_param(IS_RCC_SYSCLKSOURCE(RCC_ClkInitStruct->SYSCLKSource));

    /* PLL is selected as System Clock Source */
    if(RCC_ClkInitStruct->SYSCLKSource == RCC_SYSCLKSOURCE_PLLCLK)
 80044c8:	687b      	ldr	r3, [r7, #4]
 80044ca:	685b      	ldr	r3, [r3, #4]
 80044cc:	2b03      	cmp	r3, #3
 80044ce:	d107      	bne.n	80044e0 <HAL_RCC_ClockConfig+0x68>
    {
      /* Check the PLL ready flag */
      if(READ_BIT(RCC->CR, RCC_CR_PLLRDY) == 0U)
 80044d0:	4b56      	ldr	r3, [pc, #344]	; (800462c <HAL_RCC_ClockConfig+0x1b4>)
 80044d2:	681b      	ldr	r3, [r3, #0]
 80044d4:	f003 7300 	and.w	r3, r3, #33554432	; 0x2000000
 80044d8:	2b00      	cmp	r3, #0
 80044da:	d121      	bne.n	8004520 <HAL_RCC_ClockConfig+0xa8>
      {
        return HAL_ERROR;
 80044dc:	2301      	movs	r3, #1
 80044de:	e09e      	b.n	800461e <HAL_RCC_ClockConfig+0x1a6>
#endif
    }
    else
    {
      /* HSE is selected as System Clock Source */
      if(RCC_ClkInitStruct->SYSCLKSource == RCC_SYSCLKSOURCE_HSE)
 80044e0:	687b      	ldr	r3, [r7, #4]
 80044e2:	685b      	ldr	r3, [r3, #4]
 80044e4:	2b02      	cmp	r3, #2
 80044e6:	d107      	bne.n	80044f8 <HAL_RCC_ClockConfig+0x80>
      {
        /* Check the HSE ready flag */
        if(READ_BIT(RCC->CR, RCC_CR_HSERDY) == 0U)
 80044e8:	4b50      	ldr	r3, [pc, #320]	; (800462c <HAL_RCC_ClockConfig+0x1b4>)
 80044ea:	681b      	ldr	r3, [r3, #0]
 80044ec:	f403 3300 	and.w	r3, r3, #131072	; 0x20000
 80044f0:	2b00      	cmp	r3, #0
 80044f2:	d115      	bne.n	8004520 <HAL_RCC_ClockConfig+0xa8>
        {
          return HAL_ERROR;
 80044f4:	2301      	movs	r3, #1
 80044f6:	e092      	b.n	800461e <HAL_RCC_ClockConfig+0x1a6>
        }
      }
      /* MSI is selected as System Clock Source */
      else if(RCC_ClkInitStruct->SYSCLKSource == RCC_SYSCLKSOURCE_MSI)
 80044f8:	687b      	ldr	r3, [r7, #4]
 80044fa:	685b      	ldr	r3, [r3, #4]
 80044fc:	2b00      	cmp	r3, #0
 80044fe:	d107      	bne.n	8004510 <HAL_RCC_ClockConfig+0x98>
      {
        /* Check the MSI ready flag */
        if(READ_BIT(RCC->CR, RCC_CR_MSIRDY) == 0U)
 8004500:	4b4a      	ldr	r3, [pc, #296]	; (800462c <HAL_RCC_ClockConfig+0x1b4>)
 8004502:	681b      	ldr	r3, [r3, #0]
 8004504:	f003 0302 	and.w	r3, r3, #2
 8004508:	2b00      	cmp	r3, #0
 800450a:	d109      	bne.n	8004520 <HAL_RCC_ClockConfig+0xa8>
        {
          return HAL_ERROR;
 800450c:	2301      	movs	r3, #1
 800450e:	e086      	b.n	800461e <HAL_RCC_ClockConfig+0x1a6>
      }
      /* HSI is selected as System Clock Source */
      else
      {
        /* Check the HSI ready flag */
        if(READ_BIT(RCC->CR, RCC_CR_HSIRDY) == 0U)
 8004510:	4b46      	ldr	r3, [pc, #280]	; (800462c <HAL_RCC_ClockConfig+0x1b4>)
 8004512:	681b      	ldr	r3, [r3, #0]
 8004514:	f403 6380 	and.w	r3, r3, #1024	; 0x400
 8004518:	2b00      	cmp	r3, #0
 800451a:	d101      	bne.n	8004520 <HAL_RCC_ClockConfig+0xa8>
        {
          return HAL_ERROR;
 800451c:	2301      	movs	r3, #1
 800451e:	e07e      	b.n	800461e <HAL_RCC_ClockConfig+0x1a6>
      }
#endif

    }

    MODIFY_REG(RCC->CFGR, RCC_CFGR_SW, RCC_ClkInitStruct->SYSCLKSource);
 8004520:	4b42      	ldr	r3, [pc, #264]	; (800462c <HAL_RCC_ClockConfig+0x1b4>)
 8004522:	689b      	ldr	r3, [r3, #8]
 8004524:	f023 0203 	bic.w	r2, r3, #3
 8004528:	687b      	ldr	r3, [r7, #4]
 800452a:	685b      	ldr	r3, [r3, #4]
 800452c:	493f      	ldr	r1, [pc, #252]	; (800462c <HAL_RCC_ClockConfig+0x1b4>)
 800452e:	4313      	orrs	r3, r2
 8004530:	608b      	str	r3, [r1, #8]

    /* Get Start Tick*/
    tickstart = HAL_GetTick();
 8004532:	f7fd fd57 	bl	8001fe4 <HAL_GetTick>
 8004536:	60f8      	str	r0, [r7, #12]

    while(__HAL_RCC_GET_SYSCLK_SOURCE() != (RCC_ClkInitStruct->SYSCLKSource << RCC_CFGR_SWS_Pos))
 8004538:	e00a      	b.n	8004550 <HAL_RCC_ClockConfig+0xd8>
    {
      if((HAL_GetTick() - tickstart) > CLOCKSWITCH_TIMEOUT_VALUE)
 800453a:	f7fd fd53 	bl	8001fe4 <HAL_GetTick>
 800453e:	4602      	mov	r2, r0
 8004540:	68fb      	ldr	r3, [r7, #12]
 8004542:	1ad3      	subs	r3, r2, r3
 8004544:	f241 3288 	movw	r2, #5000	; 0x1388
 8004548:	4293      	cmp	r3, r2
 800454a:	d901      	bls.n	8004550 <HAL_RCC_ClockConfig+0xd8>
      {
        return HAL_TIMEOUT;
 800454c:	2303      	movs	r3, #3
 800454e:	e066      	b.n	800461e <HAL_RCC_ClockConfig+0x1a6>
    while(__HAL_RCC_GET_SYSCLK_SOURCE() != (RCC_ClkInitStruct->SYSCLKSource << RCC_CFGR_SWS_Pos))
 8004550:	4b36      	ldr	r3, [pc, #216]	; (800462c <HAL_RCC_ClockConfig+0x1b4>)
 8004552:	689b      	ldr	r3, [r3, #8]
 8004554:	f003 020c 	and.w	r2, r3, #12
 8004558:	687b      	ldr	r3, [r7, #4]
 800455a:	685b      	ldr	r3, [r3, #4]
 800455c:	009b      	lsls	r3, r3, #2
 800455e:	429a      	cmp	r2, r3
 8004560:	d1eb      	bne.n	800453a <HAL_RCC_ClockConfig+0xc2>
      }
    }
  }

  /*-------------------------- HCLK Configuration --------------------------*/
  if(((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_HCLK) == RCC_CLOCKTYPE_HCLK)
 8004562:	687b      	ldr	r3, [r7, #4]
 8004564:	681b      	ldr	r3, [r3, #0]
 8004566:	f003 0302 	and.w	r3, r3, #2
 800456a:	2b00      	cmp	r3, #0
 800456c:	d008      	beq.n	8004580 <HAL_RCC_ClockConfig+0x108>
  {
    assert_param(IS_RCC_HCLK(RCC_ClkInitStruct->AHBCLKDivider));
    MODIFY_REG(RCC->CFGR, RCC_CFGR_HPRE, RCC_ClkInitStruct->AHBCLKDivider);
 800456e:	4b2f      	ldr	r3, [pc, #188]	; (800462c <HAL_RCC_ClockConfig+0x1b4>)
 8004570:	689b      	ldr	r3, [r3, #8]
 8004572:	f023 02f0 	bic.w	r2, r3, #240	; 0xf0
 8004576:	687b      	ldr	r3, [r7, #4]
 8004578:	689b      	ldr	r3, [r3, #8]
 800457a:	492c      	ldr	r1, [pc, #176]	; (800462c <HAL_RCC_ClockConfig+0x1b4>)
 800457c:	4313      	orrs	r3, r2
 800457e:	608b      	str	r3, [r1, #8]
    }
  }
#endif

  /* Decreasing the number of wait states because of lower CPU frequency */
  if(FLatency < __HAL_FLASH_GET_LATENCY())
 8004580:	4b29      	ldr	r3, [pc, #164]	; (8004628 <HAL_RCC_ClockConfig+0x1b0>)
 8004582:	681b      	ldr	r3, [r3, #0]
 8004584:	f003 0307 	and.w	r3, r3, #7
 8004588:	683a      	ldr	r2, [r7, #0]
 800458a:	429a      	cmp	r2, r3
 800458c:	d210      	bcs.n	80045b0 <HAL_RCC_ClockConfig+0x138>
  {
    /* Program the new number of wait states to the LATENCY bits in the FLASH_ACR register */
    __HAL_FLASH_SET_LATENCY(FLatency);
 800458e:	4b26      	ldr	r3, [pc, #152]	; (8004628 <HAL_RCC_ClockConfig+0x1b0>)
 8004590:	681b      	ldr	r3, [r3, #0]
 8004592:	f023 0207 	bic.w	r2, r3, #7
 8004596:	4924      	ldr	r1, [pc, #144]	; (8004628 <HAL_RCC_ClockConfig+0x1b0>)
 8004598:	683b      	ldr	r3, [r7, #0]
 800459a:	4313      	orrs	r3, r2
 800459c:	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)
 800459e:	4b22      	ldr	r3, [pc, #136]	; (8004628 <HAL_RCC_ClockConfig+0x1b0>)
 80045a0:	681b      	ldr	r3, [r3, #0]
 80045a2:	f003 0307 	and.w	r3, r3, #7
 80045a6:	683a      	ldr	r2, [r7, #0]
 80045a8:	429a      	cmp	r2, r3
 80045aa:	d001      	beq.n	80045b0 <HAL_RCC_ClockConfig+0x138>
    {
      return HAL_ERROR;
 80045ac:	2301      	movs	r3, #1
 80045ae:	e036      	b.n	800461e <HAL_RCC_ClockConfig+0x1a6>
    }
  }

  /*-------------------------- PCLK1 Configuration ---------------------------*/
  if(((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_PCLK1) == RCC_CLOCKTYPE_PCLK1)
 80045b0:	687b      	ldr	r3, [r7, #4]
 80045b2:	681b      	ldr	r3, [r3, #0]
 80045b4:	f003 0304 	and.w	r3, r3, #4
 80045b8:	2b00      	cmp	r3, #0
 80045ba:	d008      	beq.n	80045ce <HAL_RCC_ClockConfig+0x156>
  {
    assert_param(IS_RCC_PCLK(RCC_ClkInitStruct->APB1CLKDivider));
    MODIFY_REG(RCC->CFGR, RCC_CFGR_PPRE1, RCC_ClkInitStruct->APB1CLKDivider);
 80045bc:	4b1b      	ldr	r3, [pc, #108]	; (800462c <HAL_RCC_ClockConfig+0x1b4>)
 80045be:	689b      	ldr	r3, [r3, #8]
 80045c0:	f423 62e0 	bic.w	r2, r3, #1792	; 0x700
 80045c4:	687b      	ldr	r3, [r7, #4]
 80045c6:	68db      	ldr	r3, [r3, #12]
 80045c8:	4918      	ldr	r1, [pc, #96]	; (800462c <HAL_RCC_ClockConfig+0x1b4>)
 80045ca:	4313      	orrs	r3, r2
 80045cc:	608b      	str	r3, [r1, #8]
  }

  /*-------------------------- PCLK2 Configuration ---------------------------*/
  if(((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_PCLK2) == RCC_CLOCKTYPE_PCLK2)
 80045ce:	687b      	ldr	r3, [r7, #4]
 80045d0:	681b      	ldr	r3, [r3, #0]
 80045d2:	f003 0308 	and.w	r3, r3, #8
 80045d6:	2b00      	cmp	r3, #0
 80045d8:	d009      	beq.n	80045ee <HAL_RCC_ClockConfig+0x176>
  {
    assert_param(IS_RCC_PCLK(RCC_ClkInitStruct->APB2CLKDivider));
    MODIFY_REG(RCC->CFGR, RCC_CFGR_PPRE2, ((RCC_ClkInitStruct->APB2CLKDivider) << 3U));
 80045da:	4b14      	ldr	r3, [pc, #80]	; (800462c <HAL_RCC_ClockConfig+0x1b4>)
 80045dc:	689b      	ldr	r3, [r3, #8]
 80045de:	f423 5260 	bic.w	r2, r3, #14336	; 0x3800
 80045e2:	687b      	ldr	r3, [r7, #4]
 80045e4:	691b      	ldr	r3, [r3, #16]
 80045e6:	00db      	lsls	r3, r3, #3
 80045e8:	4910      	ldr	r1, [pc, #64]	; (800462c <HAL_RCC_ClockConfig+0x1b4>)
 80045ea:	4313      	orrs	r3, r2
 80045ec:	608b      	str	r3, [r1, #8]
  }

  /* Update the SystemCoreClock global variable */
  SystemCoreClock = HAL_RCC_GetSysClockFreq() >> (AHBPrescTable[READ_BIT(RCC->CFGR, RCC_CFGR_HPRE) >> RCC_CFGR_HPRE_Pos] & 0x1FU);
 80045ee:	f000 f825 	bl	800463c <HAL_RCC_GetSysClockFreq>
 80045f2:	4602      	mov	r2, r0
 80045f4:	4b0d      	ldr	r3, [pc, #52]	; (800462c <HAL_RCC_ClockConfig+0x1b4>)
 80045f6:	689b      	ldr	r3, [r3, #8]
 80045f8:	091b      	lsrs	r3, r3, #4
 80045fa:	f003 030f 	and.w	r3, r3, #15
 80045fe:	490c      	ldr	r1, [pc, #48]	; (8004630 <HAL_RCC_ClockConfig+0x1b8>)
 8004600:	5ccb      	ldrb	r3, [r1, r3]
 8004602:	f003 031f 	and.w	r3, r3, #31
 8004606:	fa22 f303 	lsr.w	r3, r2, r3
 800460a:	4a0a      	ldr	r2, [pc, #40]	; (8004634 <HAL_RCC_ClockConfig+0x1bc>)
 800460c:	6013      	str	r3, [r2, #0]

  /* Configure the source of time base considering new system clocks settings*/
  status = HAL_InitTick(uwTickPrio);
 800460e:	4b0a      	ldr	r3, [pc, #40]	; (8004638 <HAL_RCC_ClockConfig+0x1c0>)
 8004610:	681b      	ldr	r3, [r3, #0]
 8004612:	4618      	mov	r0, r3
 8004614:	f7fd fc96 	bl	8001f44 <HAL_InitTick>
 8004618:	4603      	mov	r3, r0
 800461a:	72fb      	strb	r3, [r7, #11]

  return status;
 800461c:	7afb      	ldrb	r3, [r7, #11]
}
 800461e:	4618      	mov	r0, r3
 8004620:	3710      	adds	r7, #16
 8004622:	46bd      	mov	sp, r7
 8004624:	bd80      	pop	{r7, pc}
 8004626:	bf00      	nop
 8004628:	40022000 	.word	0x40022000
 800462c:	40021000 	.word	0x40021000
 8004630:	08008fdc 	.word	0x08008fdc
 8004634:	20000000 	.word	0x20000000
 8004638:	20000004 	.word	0x20000004

0800463c <HAL_RCC_GetSysClockFreq>:
  *
  *
  * @retval SYSCLK frequency
  */
uint32_t HAL_RCC_GetSysClockFreq(void)
{
 800463c:	b480      	push	{r7}
 800463e:	b089      	sub	sp, #36	; 0x24
 8004640:	af00      	add	r7, sp, #0
  uint32_t msirange = 0U, sysclockfreq = 0U;
 8004642:	2300      	movs	r3, #0
 8004644:	61fb      	str	r3, [r7, #28]
 8004646:	2300      	movs	r3, #0
 8004648:	61bb      	str	r3, [r7, #24]
  uint32_t pllvco, pllsource, pllr, pllm;    /* no init needed */
  uint32_t sysclk_source, pll_oscsource;

  sysclk_source = __HAL_RCC_GET_SYSCLK_SOURCE();
 800464a:	4b3e      	ldr	r3, [pc, #248]	; (8004744 <HAL_RCC_GetSysClockFreq+0x108>)
 800464c:	689b      	ldr	r3, [r3, #8]
 800464e:	f003 030c 	and.w	r3, r3, #12
 8004652:	613b      	str	r3, [r7, #16]
  pll_oscsource = __HAL_RCC_GET_PLL_OSCSOURCE();
 8004654:	4b3b      	ldr	r3, [pc, #236]	; (8004744 <HAL_RCC_GetSysClockFreq+0x108>)
 8004656:	68db      	ldr	r3, [r3, #12]
 8004658:	f003 0303 	and.w	r3, r3, #3
 800465c:	60fb      	str	r3, [r7, #12]

  if((sysclk_source == RCC_CFGR_SWS_MSI) ||
 800465e:	693b      	ldr	r3, [r7, #16]
 8004660:	2b00      	cmp	r3, #0
 8004662:	d005      	beq.n	8004670 <HAL_RCC_GetSysClockFreq+0x34>
 8004664:	693b      	ldr	r3, [r7, #16]
 8004666:	2b0c      	cmp	r3, #12
 8004668:	d121      	bne.n	80046ae <HAL_RCC_GetSysClockFreq+0x72>
     ((sysclk_source == RCC_CFGR_SWS_PLL) && (pll_oscsource == RCC_PLLSOURCE_MSI)))
 800466a:	68fb      	ldr	r3, [r7, #12]
 800466c:	2b01      	cmp	r3, #1
 800466e:	d11e      	bne.n	80046ae <HAL_RCC_GetSysClockFreq+0x72>
  {
    /* MSI or PLL with MSI source used as system clock source */

    /* Get SYSCLK source */
    if(READ_BIT(RCC->CR, RCC_CR_MSIRGSEL) == 0U)
 8004670:	4b34      	ldr	r3, [pc, #208]	; (8004744 <HAL_RCC_GetSysClockFreq+0x108>)
 8004672:	681b      	ldr	r3, [r3, #0]
 8004674:	f003 0308 	and.w	r3, r3, #8
 8004678:	2b00      	cmp	r3, #0
 800467a:	d107      	bne.n	800468c <HAL_RCC_GetSysClockFreq+0x50>
    { /* MSISRANGE from RCC_CSR applies */
      msirange = READ_BIT(RCC->CSR, RCC_CSR_MSISRANGE) >> RCC_CSR_MSISRANGE_Pos;
 800467c:	4b31      	ldr	r3, [pc, #196]	; (8004744 <HAL_RCC_GetSysClockFreq+0x108>)
 800467e:	f8d3 3094 	ldr.w	r3, [r3, #148]	; 0x94
 8004682:	0a1b      	lsrs	r3, r3, #8
 8004684:	f003 030f 	and.w	r3, r3, #15
 8004688:	61fb      	str	r3, [r7, #28]
 800468a:	e005      	b.n	8004698 <HAL_RCC_GetSysClockFreq+0x5c>
    }
    else
    { /* MSIRANGE from RCC_CR applies */
      msirange = READ_BIT(RCC->CR, RCC_CR_MSIRANGE) >> RCC_CR_MSIRANGE_Pos;
 800468c:	4b2d      	ldr	r3, [pc, #180]	; (8004744 <HAL_RCC_GetSysClockFreq+0x108>)
 800468e:	681b      	ldr	r3, [r3, #0]
 8004690:	091b      	lsrs	r3, r3, #4
 8004692:	f003 030f 	and.w	r3, r3, #15
 8004696:	61fb      	str	r3, [r7, #28]
    }
    /*MSI frequency range in HZ*/
    msirange = MSIRangeTable[msirange];
 8004698:	4a2b      	ldr	r2, [pc, #172]	; (8004748 <HAL_RCC_GetSysClockFreq+0x10c>)
 800469a:	69fb      	ldr	r3, [r7, #28]
 800469c:	f852 3023 	ldr.w	r3, [r2, r3, lsl #2]
 80046a0:	61fb      	str	r3, [r7, #28]

    if(sysclk_source == RCC_CFGR_SWS_MSI)
 80046a2:	693b      	ldr	r3, [r7, #16]
 80046a4:	2b00      	cmp	r3, #0
 80046a6:	d10d      	bne.n	80046c4 <HAL_RCC_GetSysClockFreq+0x88>
    {
      /* MSI used as system clock source */
      sysclockfreq = msirange;
 80046a8:	69fb      	ldr	r3, [r7, #28]
 80046aa:	61bb      	str	r3, [r7, #24]
    if(sysclk_source == RCC_CFGR_SWS_MSI)
 80046ac:	e00a      	b.n	80046c4 <HAL_RCC_GetSysClockFreq+0x88>
    }
  }
  else if(sysclk_source == RCC_CFGR_SWS_HSI)
 80046ae:	693b      	ldr	r3, [r7, #16]
 80046b0:	2b04      	cmp	r3, #4
 80046b2:	d102      	bne.n	80046ba <HAL_RCC_GetSysClockFreq+0x7e>
  {
    /* HSI used as system clock source */
    sysclockfreq = HSI_VALUE;
 80046b4:	4b25      	ldr	r3, [pc, #148]	; (800474c <HAL_RCC_GetSysClockFreq+0x110>)
 80046b6:	61bb      	str	r3, [r7, #24]
 80046b8:	e004      	b.n	80046c4 <HAL_RCC_GetSysClockFreq+0x88>
  }
  else if(sysclk_source == RCC_CFGR_SWS_HSE)
 80046ba:	693b      	ldr	r3, [r7, #16]
 80046bc:	2b08      	cmp	r3, #8
 80046be:	d101      	bne.n	80046c4 <HAL_RCC_GetSysClockFreq+0x88>
  {
    /* HSE used as system clock source */
    sysclockfreq = HSE_VALUE;
 80046c0:	4b23      	ldr	r3, [pc, #140]	; (8004750 <HAL_RCC_GetSysClockFreq+0x114>)
 80046c2:	61bb      	str	r3, [r7, #24]
  else
  {
    /* unexpected case: sysclockfreq at 0 */
  }

  if(sysclk_source == RCC_CFGR_SWS_PLL)
 80046c4:	693b      	ldr	r3, [r7, #16]
 80046c6:	2b0c      	cmp	r3, #12
 80046c8:	d134      	bne.n	8004734 <HAL_RCC_GetSysClockFreq+0xf8>
    /* PLL used as system clock  source */

    /* PLL_VCO = (HSE_VALUE or HSI_VALUE or MSI_VALUE) * PLLN / PLLM
    SYSCLK = PLL_VCO / PLLR
    */
    pllsource = READ_BIT(RCC->PLLCFGR, RCC_PLLCFGR_PLLSRC);
 80046ca:	4b1e      	ldr	r3, [pc, #120]	; (8004744 <HAL_RCC_GetSysClockFreq+0x108>)
 80046cc:	68db      	ldr	r3, [r3, #12]
 80046ce:	f003 0303 	and.w	r3, r3, #3
 80046d2:	60bb      	str	r3, [r7, #8]

    switch (pllsource)
 80046d4:	68bb      	ldr	r3, [r7, #8]
 80046d6:	2b02      	cmp	r3, #2
 80046d8:	d003      	beq.n	80046e2 <HAL_RCC_GetSysClockFreq+0xa6>
 80046da:	68bb      	ldr	r3, [r7, #8]
 80046dc:	2b03      	cmp	r3, #3
 80046de:	d003      	beq.n	80046e8 <HAL_RCC_GetSysClockFreq+0xac>
 80046e0:	e005      	b.n	80046ee <HAL_RCC_GetSysClockFreq+0xb2>
    {
    case RCC_PLLSOURCE_HSI:  /* HSI used as PLL clock source */
      pllvco = HSI_VALUE;
 80046e2:	4b1a      	ldr	r3, [pc, #104]	; (800474c <HAL_RCC_GetSysClockFreq+0x110>)
 80046e4:	617b      	str	r3, [r7, #20]
      break;
 80046e6:	e005      	b.n	80046f4 <HAL_RCC_GetSysClockFreq+0xb8>

    case RCC_PLLSOURCE_HSE:  /* HSE used as PLL clock source */
      pllvco = HSE_VALUE;
 80046e8:	4b19      	ldr	r3, [pc, #100]	; (8004750 <HAL_RCC_GetSysClockFreq+0x114>)
 80046ea:	617b      	str	r3, [r7, #20]
      break;
 80046ec:	e002      	b.n	80046f4 <HAL_RCC_GetSysClockFreq+0xb8>

    case RCC_PLLSOURCE_MSI:  /* MSI used as PLL clock source */
    default:
      pllvco = msirange;
 80046ee:	69fb      	ldr	r3, [r7, #28]
 80046f0:	617b      	str	r3, [r7, #20]
      break;
 80046f2:	bf00      	nop
    }
    pllm = (READ_BIT(RCC->PLLCFGR, RCC_PLLCFGR_PLLM) >> RCC_PLLCFGR_PLLM_Pos) + 1U ;
 80046f4:	4b13      	ldr	r3, [pc, #76]	; (8004744 <HAL_RCC_GetSysClockFreq+0x108>)
 80046f6:	68db      	ldr	r3, [r3, #12]
 80046f8:	091b      	lsrs	r3, r3, #4
 80046fa:	f003 0307 	and.w	r3, r3, #7
 80046fe:	3301      	adds	r3, #1
 8004700:	607b      	str	r3, [r7, #4]
    pllvco = (pllvco * (READ_BIT(RCC->PLLCFGR, RCC_PLLCFGR_PLLN) >> RCC_PLLCFGR_PLLN_Pos)) / pllm;
 8004702:	4b10      	ldr	r3, [pc, #64]	; (8004744 <HAL_RCC_GetSysClockFreq+0x108>)
 8004704:	68db      	ldr	r3, [r3, #12]
 8004706:	0a1b      	lsrs	r3, r3, #8
 8004708:	f003 037f 	and.w	r3, r3, #127	; 0x7f
 800470c:	697a      	ldr	r2, [r7, #20]
 800470e:	fb02 f203 	mul.w	r2, r2, r3
 8004712:	687b      	ldr	r3, [r7, #4]
 8004714:	fbb2 f3f3 	udiv	r3, r2, r3
 8004718:	617b      	str	r3, [r7, #20]
    pllr = ((READ_BIT(RCC->PLLCFGR, RCC_PLLCFGR_PLLR) >> RCC_PLLCFGR_PLLR_Pos) + 1U ) * 2U;
 800471a:	4b0a      	ldr	r3, [pc, #40]	; (8004744 <HAL_RCC_GetSysClockFreq+0x108>)
 800471c:	68db      	ldr	r3, [r3, #12]
 800471e:	0e5b      	lsrs	r3, r3, #25
 8004720:	f003 0303 	and.w	r3, r3, #3
 8004724:	3301      	adds	r3, #1
 8004726:	005b      	lsls	r3, r3, #1
 8004728:	603b      	str	r3, [r7, #0]
    sysclockfreq = pllvco / pllr;
 800472a:	697a      	ldr	r2, [r7, #20]
 800472c:	683b      	ldr	r3, [r7, #0]
 800472e:	fbb2 f3f3 	udiv	r3, r2, r3
 8004732:	61bb      	str	r3, [r7, #24]
  }

  return sysclockfreq;
 8004734:	69bb      	ldr	r3, [r7, #24]
}
 8004736:	4618      	mov	r0, r3
 8004738:	3724      	adds	r7, #36	; 0x24
 800473a:	46bd      	mov	sp, r7
 800473c:	f85d 7b04 	ldr.w	r7, [sp], #4
 8004740:	4770      	bx	lr
 8004742:	bf00      	nop
 8004744:	40021000 	.word	0x40021000
 8004748:	08008ff4 	.word	0x08008ff4
 800474c:	00f42400 	.word	0x00f42400
 8004750:	007a1200 	.word	0x007a1200

08004754 <HAL_RCC_GetHCLKFreq>:
  *
  * @note   The SystemCoreClock CMSIS variable is used to store System Clock Frequency.
  * @retval HCLK frequency in Hz
  */
uint32_t HAL_RCC_GetHCLKFreq(void)
{
 8004754:	b480      	push	{r7}
 8004756:	af00      	add	r7, sp, #0
  return SystemCoreClock;
 8004758:	4b03      	ldr	r3, [pc, #12]	; (8004768 <HAL_RCC_GetHCLKFreq+0x14>)
 800475a:	681b      	ldr	r3, [r3, #0]
}
 800475c:	4618      	mov	r0, r3
 800475e:	46bd      	mov	sp, r7
 8004760:	f85d 7b04 	ldr.w	r7, [sp], #4
 8004764:	4770      	bx	lr
 8004766:	bf00      	nop
 8004768:	20000000 	.word	0x20000000

0800476c <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 in Hz
  */
uint32_t HAL_RCC_GetPCLK1Freq(void)
{
 800476c:	b580      	push	{r7, lr}
 800476e:	af00      	add	r7, sp, #0
  /* Get HCLK source and Compute PCLK1 frequency ---------------------------*/
  return (HAL_RCC_GetHCLKFreq() >> (APBPrescTable[READ_BIT(RCC->CFGR, RCC_CFGR_PPRE1) >> RCC_CFGR_PPRE1_Pos] & 0x1FU));
 8004770:	f7ff fff0 	bl	8004754 <HAL_RCC_GetHCLKFreq>
 8004774:	4602      	mov	r2, r0
 8004776:	4b06      	ldr	r3, [pc, #24]	; (8004790 <HAL_RCC_GetPCLK1Freq+0x24>)
 8004778:	689b      	ldr	r3, [r3, #8]
 800477a:	0a1b      	lsrs	r3, r3, #8
 800477c:	f003 0307 	and.w	r3, r3, #7
 8004780:	4904      	ldr	r1, [pc, #16]	; (8004794 <HAL_RCC_GetPCLK1Freq+0x28>)
 8004782:	5ccb      	ldrb	r3, [r1, r3]
 8004784:	f003 031f 	and.w	r3, r3, #31
 8004788:	fa22 f303 	lsr.w	r3, r2, r3
}
 800478c:	4618      	mov	r0, r3
 800478e:	bd80      	pop	{r7, pc}
 8004790:	40021000 	.word	0x40021000
 8004794:	08008fec 	.word	0x08008fec

08004798 <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 in Hz
  */
uint32_t HAL_RCC_GetPCLK2Freq(void)
{
 8004798:	b580      	push	{r7, lr}
 800479a:	af00      	add	r7, sp, #0
  /* Get HCLK source and Compute PCLK2 frequency ---------------------------*/
  return (HAL_RCC_GetHCLKFreq()>> (APBPrescTable[READ_BIT(RCC->CFGR, RCC_CFGR_PPRE2) >> RCC_CFGR_PPRE2_Pos] & 0x1FU));
 800479c:	f7ff ffda 	bl	8004754 <HAL_RCC_GetHCLKFreq>
 80047a0:	4602      	mov	r2, r0
 80047a2:	4b06      	ldr	r3, [pc, #24]	; (80047bc <HAL_RCC_GetPCLK2Freq+0x24>)
 80047a4:	689b      	ldr	r3, [r3, #8]
 80047a6:	0adb      	lsrs	r3, r3, #11
 80047a8:	f003 0307 	and.w	r3, r3, #7
 80047ac:	4904      	ldr	r1, [pc, #16]	; (80047c0 <HAL_RCC_GetPCLK2Freq+0x28>)
 80047ae:	5ccb      	ldrb	r3, [r1, r3]
 80047b0:	f003 031f 	and.w	r3, r3, #31
 80047b4:	fa22 f303 	lsr.w	r3, r2, r3
}
 80047b8:	4618      	mov	r0, r3
 80047ba:	bd80      	pop	{r7, pc}
 80047bc:	40021000 	.word	0x40021000
 80047c0:	08008fec 	.word	0x08008fec

080047c4 <RCC_SetFlashLatencyFromMSIRange>:
            voltage range.
  * @param  msirange  MSI range value from RCC_MSIRANGE_0 to RCC_MSIRANGE_11
  * @retval HAL status
  */
static HAL_StatusTypeDef RCC_SetFlashLatencyFromMSIRange(uint32_t msirange)
{
 80047c4:	b580      	push	{r7, lr}
 80047c6:	b086      	sub	sp, #24
 80047c8:	af00      	add	r7, sp, #0
 80047ca:	6078      	str	r0, [r7, #4]
  uint32_t vos;
  uint32_t latency = FLASH_LATENCY_0;  /* default value 0WS */
 80047cc:	2300      	movs	r3, #0
 80047ce:	613b      	str	r3, [r7, #16]

  if(__HAL_RCC_PWR_IS_CLK_ENABLED())
 80047d0:	4b2a      	ldr	r3, [pc, #168]	; (800487c <RCC_SetFlashLatencyFromMSIRange+0xb8>)
 80047d2:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 80047d4:	f003 5380 	and.w	r3, r3, #268435456	; 0x10000000
 80047d8:	2b00      	cmp	r3, #0
 80047da:	d003      	beq.n	80047e4 <RCC_SetFlashLatencyFromMSIRange+0x20>
  {
    vos = HAL_PWREx_GetVoltageRange();
 80047dc:	f7ff fa02 	bl	8003be4 <HAL_PWREx_GetVoltageRange>
 80047e0:	6178      	str	r0, [r7, #20]
 80047e2:	e014      	b.n	800480e <RCC_SetFlashLatencyFromMSIRange+0x4a>
  }
  else
  {
    __HAL_RCC_PWR_CLK_ENABLE();
 80047e4:	4b25      	ldr	r3, [pc, #148]	; (800487c <RCC_SetFlashLatencyFromMSIRange+0xb8>)
 80047e6:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 80047e8:	4a24      	ldr	r2, [pc, #144]	; (800487c <RCC_SetFlashLatencyFromMSIRange+0xb8>)
 80047ea:	f043 5380 	orr.w	r3, r3, #268435456	; 0x10000000
 80047ee:	6593      	str	r3, [r2, #88]	; 0x58
 80047f0:	4b22      	ldr	r3, [pc, #136]	; (800487c <RCC_SetFlashLatencyFromMSIRange+0xb8>)
 80047f2:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 80047f4:	f003 5380 	and.w	r3, r3, #268435456	; 0x10000000
 80047f8:	60fb      	str	r3, [r7, #12]
 80047fa:	68fb      	ldr	r3, [r7, #12]
    vos = HAL_PWREx_GetVoltageRange();
 80047fc:	f7ff f9f2 	bl	8003be4 <HAL_PWREx_GetVoltageRange>
 8004800:	6178      	str	r0, [r7, #20]
    __HAL_RCC_PWR_CLK_DISABLE();
 8004802:	4b1e      	ldr	r3, [pc, #120]	; (800487c <RCC_SetFlashLatencyFromMSIRange+0xb8>)
 8004804:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 8004806:	4a1d      	ldr	r2, [pc, #116]	; (800487c <RCC_SetFlashLatencyFromMSIRange+0xb8>)
 8004808:	f023 5380 	bic.w	r3, r3, #268435456	; 0x10000000
 800480c:	6593      	str	r3, [r2, #88]	; 0x58
  }

  if(vos == PWR_REGULATOR_VOLTAGE_SCALE1)
 800480e:	697b      	ldr	r3, [r7, #20]
 8004810:	f5b3 7f00 	cmp.w	r3, #512	; 0x200
 8004814:	d10b      	bne.n	800482e <RCC_SetFlashLatencyFromMSIRange+0x6a>
  {
    if(msirange > RCC_MSIRANGE_8)
 8004816:	687b      	ldr	r3, [r7, #4]
 8004818:	2b80      	cmp	r3, #128	; 0x80
 800481a:	d919      	bls.n	8004850 <RCC_SetFlashLatencyFromMSIRange+0x8c>
    {
      /* MSI > 16Mhz */
      if(msirange > RCC_MSIRANGE_10)
 800481c:	687b      	ldr	r3, [r7, #4]
 800481e:	2ba0      	cmp	r3, #160	; 0xa0
 8004820:	d902      	bls.n	8004828 <RCC_SetFlashLatencyFromMSIRange+0x64>
      {
        /* MSI 48Mhz */
        latency = FLASH_LATENCY_2; /* 2WS */
 8004822:	2302      	movs	r3, #2
 8004824:	613b      	str	r3, [r7, #16]
 8004826:	e013      	b.n	8004850 <RCC_SetFlashLatencyFromMSIRange+0x8c>
      }
      else
      {
        /* MSI 24Mhz or 32Mhz */
        latency = FLASH_LATENCY_1; /* 1WS */
 8004828:	2301      	movs	r3, #1
 800482a:	613b      	str	r3, [r7, #16]
 800482c:	e010      	b.n	8004850 <RCC_SetFlashLatencyFromMSIRange+0x8c>
        latency = FLASH_LATENCY_1; /* 1WS */
      }
      /* else MSI < 8Mhz default FLASH_LATENCY_0 0WS */
    }
#else
    if(msirange > RCC_MSIRANGE_8)
 800482e:	687b      	ldr	r3, [r7, #4]
 8004830:	2b80      	cmp	r3, #128	; 0x80
 8004832:	d902      	bls.n	800483a <RCC_SetFlashLatencyFromMSIRange+0x76>
    {
      /* MSI > 16Mhz */
      latency = FLASH_LATENCY_3; /* 3WS */
 8004834:	2303      	movs	r3, #3
 8004836:	613b      	str	r3, [r7, #16]
 8004838:	e00a      	b.n	8004850 <RCC_SetFlashLatencyFromMSIRange+0x8c>
    }
    else
    {
      if(msirange == RCC_MSIRANGE_8)
 800483a:	687b      	ldr	r3, [r7, #4]
 800483c:	2b80      	cmp	r3, #128	; 0x80
 800483e:	d102      	bne.n	8004846 <RCC_SetFlashLatencyFromMSIRange+0x82>
      {
        /* MSI 16Mhz */
        latency = FLASH_LATENCY_2; /* 2WS */
 8004840:	2302      	movs	r3, #2
 8004842:	613b      	str	r3, [r7, #16]
 8004844:	e004      	b.n	8004850 <RCC_SetFlashLatencyFromMSIRange+0x8c>
      }
      else if(msirange == RCC_MSIRANGE_7)
 8004846:	687b      	ldr	r3, [r7, #4]
 8004848:	2b70      	cmp	r3, #112	; 0x70
 800484a:	d101      	bne.n	8004850 <RCC_SetFlashLatencyFromMSIRange+0x8c>
      {
        /* MSI 8Mhz */
        latency = FLASH_LATENCY_1; /* 1WS */
 800484c:	2301      	movs	r3, #1
 800484e:	613b      	str	r3, [r7, #16]
      /* else MSI < 8Mhz default FLASH_LATENCY_0 0WS */
    }
#endif
  }

  __HAL_FLASH_SET_LATENCY(latency);
 8004850:	4b0b      	ldr	r3, [pc, #44]	; (8004880 <RCC_SetFlashLatencyFromMSIRange+0xbc>)
 8004852:	681b      	ldr	r3, [r3, #0]
 8004854:	f023 0207 	bic.w	r2, r3, #7
 8004858:	4909      	ldr	r1, [pc, #36]	; (8004880 <RCC_SetFlashLatencyFromMSIRange+0xbc>)
 800485a:	693b      	ldr	r3, [r7, #16]
 800485c:	4313      	orrs	r3, r2
 800485e:	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() != latency)
 8004860:	4b07      	ldr	r3, [pc, #28]	; (8004880 <RCC_SetFlashLatencyFromMSIRange+0xbc>)
 8004862:	681b      	ldr	r3, [r3, #0]
 8004864:	f003 0307 	and.w	r3, r3, #7
 8004868:	693a      	ldr	r2, [r7, #16]
 800486a:	429a      	cmp	r2, r3
 800486c:	d001      	beq.n	8004872 <RCC_SetFlashLatencyFromMSIRange+0xae>
  {
    return HAL_ERROR;
 800486e:	2301      	movs	r3, #1
 8004870:	e000      	b.n	8004874 <RCC_SetFlashLatencyFromMSIRange+0xb0>
  }

  return HAL_OK;
 8004872:	2300      	movs	r3, #0
}
 8004874:	4618      	mov	r0, r3
 8004876:	3718      	adds	r7, #24
 8004878:	46bd      	mov	sp, r7
 800487a:	bd80      	pop	{r7, pc}
 800487c:	40021000 	.word	0x40021000
 8004880:	40022000 	.word	0x40022000

08004884 <HAL_RCCEx_PeriphCLKConfig>:
  *         the RTC clock source: in this case the access to Backup domain is enabled.
  *
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_RCCEx_PeriphCLKConfig(RCC_PeriphCLKInitTypeDef  *PeriphClkInit)
{
 8004884:	b580      	push	{r7, lr}
 8004886:	b086      	sub	sp, #24
 8004888:	af00      	add	r7, sp, #0
 800488a:	6078      	str	r0, [r7, #4]
  uint32_t tmpregister, tickstart;     /* no init needed */
  HAL_StatusTypeDef ret = HAL_OK;      /* Intermediate status */
 800488c:	2300      	movs	r3, #0
 800488e:	74fb      	strb	r3, [r7, #19]
  HAL_StatusTypeDef status = HAL_OK;   /* Final status */
 8004890:	2300      	movs	r3, #0
 8004892:	74bb      	strb	r3, [r7, #18]
  assert_param(IS_RCC_PERIPHCLOCK(PeriphClkInit->PeriphClockSelection));

#if defined(SAI1)

  /*-------------------------- SAI1 clock source configuration ---------------------*/
  if((((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_SAI1) == RCC_PERIPHCLK_SAI1))
 8004894:	687b      	ldr	r3, [r7, #4]
 8004896:	681b      	ldr	r3, [r3, #0]
 8004898:	f403 6300 	and.w	r3, r3, #2048	; 0x800
 800489c:	2b00      	cmp	r3, #0
 800489e:	d041      	beq.n	8004924 <HAL_RCCEx_PeriphCLKConfig+0xa0>
  {
    /* Check the parameters */
    assert_param(IS_RCC_SAI1CLK(PeriphClkInit->Sai1ClockSelection));

    switch(PeriphClkInit->Sai1ClockSelection)
 80048a0:	687b      	ldr	r3, [r7, #4]
 80048a2:	6e5b      	ldr	r3, [r3, #100]	; 0x64
 80048a4:	f5b3 0f40 	cmp.w	r3, #12582912	; 0xc00000
 80048a8:	d02a      	beq.n	8004900 <HAL_RCCEx_PeriphCLKConfig+0x7c>
 80048aa:	f5b3 0f40 	cmp.w	r3, #12582912	; 0xc00000
 80048ae:	d824      	bhi.n	80048fa <HAL_RCCEx_PeriphCLKConfig+0x76>
 80048b0:	f5b3 0f00 	cmp.w	r3, #8388608	; 0x800000
 80048b4:	d008      	beq.n	80048c8 <HAL_RCCEx_PeriphCLKConfig+0x44>
 80048b6:	f5b3 0f00 	cmp.w	r3, #8388608	; 0x800000
 80048ba:	d81e      	bhi.n	80048fa <HAL_RCCEx_PeriphCLKConfig+0x76>
 80048bc:	2b00      	cmp	r3, #0
 80048be:	d00a      	beq.n	80048d6 <HAL_RCCEx_PeriphCLKConfig+0x52>
 80048c0:	f5b3 0f80 	cmp.w	r3, #4194304	; 0x400000
 80048c4:	d010      	beq.n	80048e8 <HAL_RCCEx_PeriphCLKConfig+0x64>
 80048c6:	e018      	b.n	80048fa <HAL_RCCEx_PeriphCLKConfig+0x76>
    {
    case RCC_SAI1CLKSOURCE_PLL:      /* PLL is used as clock source for SAI1*/
      /* Enable SAI Clock output generated from System PLL . */
#if defined(RCC_PLLSAI2_SUPPORT)
      __HAL_RCC_PLLCLKOUT_ENABLE(RCC_PLL_SAI3CLK);
 80048c8:	4b86      	ldr	r3, [pc, #536]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 80048ca:	68db      	ldr	r3, [r3, #12]
 80048cc:	4a85      	ldr	r2, [pc, #532]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 80048ce:	f443 3380 	orr.w	r3, r3, #65536	; 0x10000
 80048d2:	60d3      	str	r3, [r2, #12]
#else
      __HAL_RCC_PLLCLKOUT_ENABLE(RCC_PLL_SAI2CLK);
#endif /* RCC_PLLSAI2_SUPPORT */
      /* SAI1 clock source config set later after clock selection check */
      break;
 80048d4:	e015      	b.n	8004902 <HAL_RCCEx_PeriphCLKConfig+0x7e>

    case RCC_SAI1CLKSOURCE_PLLSAI1:  /* PLLSAI1 is used as clock source for SAI1*/
      /* PLLSAI1 input clock, parameters M, N & P configuration and clock output (PLLSAI1ClockOut) */
      ret = RCCEx_PLLSAI1_Config(&(PeriphClkInit->PLLSAI1), DIVIDER_P_UPDATE);
 80048d6:	687b      	ldr	r3, [r7, #4]
 80048d8:	3304      	adds	r3, #4
 80048da:	2100      	movs	r1, #0
 80048dc:	4618      	mov	r0, r3
 80048de:	f000 fabb 	bl	8004e58 <RCCEx_PLLSAI1_Config>
 80048e2:	4603      	mov	r3, r0
 80048e4:	74fb      	strb	r3, [r7, #19]
      /* SAI1 clock source config set later after clock selection check */
      break;
 80048e6:	e00c      	b.n	8004902 <HAL_RCCEx_PeriphCLKConfig+0x7e>

#if defined(RCC_PLLSAI2_SUPPORT)

    case RCC_SAI1CLKSOURCE_PLLSAI2:  /* PLLSAI2 is used as clock source for SAI1*/
      /* PLLSAI2 input clock, parameters M, N & P configuration clock output (PLLSAI2ClockOut) */
      ret = RCCEx_PLLSAI2_Config(&(PeriphClkInit->PLLSAI2), DIVIDER_P_UPDATE);
 80048e8:	687b      	ldr	r3, [r7, #4]
 80048ea:	3320      	adds	r3, #32
 80048ec:	2100      	movs	r1, #0
 80048ee:	4618      	mov	r0, r3
 80048f0:	f000 fba6 	bl	8005040 <RCCEx_PLLSAI2_Config>
 80048f4:	4603      	mov	r3, r0
 80048f6:	74fb      	strb	r3, [r7, #19]
      /* SAI1 clock source config set later after clock selection check */
      break;
 80048f8:	e003      	b.n	8004902 <HAL_RCCEx_PeriphCLKConfig+0x7e>
#endif /* STM32L4P5xx || STM32L4Q5xx || STM32L4R5xx || STM32L4R7xx || STM32L4R9xx || STM32L4S5xx || STM32L4S7xx || STM32L4S9xx */
      /* SAI1 clock source config set later after clock selection check */
      break;

    default:
      ret = HAL_ERROR;
 80048fa:	2301      	movs	r3, #1
 80048fc:	74fb      	strb	r3, [r7, #19]
      break;
 80048fe:	e000      	b.n	8004902 <HAL_RCCEx_PeriphCLKConfig+0x7e>
      break;
 8004900:	bf00      	nop
    }

    if(ret == HAL_OK)
 8004902:	7cfb      	ldrb	r3, [r7, #19]
 8004904:	2b00      	cmp	r3, #0
 8004906:	d10b      	bne.n	8004920 <HAL_RCCEx_PeriphCLKConfig+0x9c>
    {
      /* Set the source of SAI1 clock*/
      __HAL_RCC_SAI1_CONFIG(PeriphClkInit->Sai1ClockSelection);
 8004908:	4b76      	ldr	r3, [pc, #472]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 800490a:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 800490e:	f423 0240 	bic.w	r2, r3, #12582912	; 0xc00000
 8004912:	687b      	ldr	r3, [r7, #4]
 8004914:	6e5b      	ldr	r3, [r3, #100]	; 0x64
 8004916:	4973      	ldr	r1, [pc, #460]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 8004918:	4313      	orrs	r3, r2
 800491a:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88
 800491e:	e001      	b.n	8004924 <HAL_RCCEx_PeriphCLKConfig+0xa0>
    }
    else
    {
      /* set overall return value */
      status = ret;
 8004920:	7cfb      	ldrb	r3, [r7, #19]
 8004922:	74bb      	strb	r3, [r7, #18]
#endif /* SAI1 */

#if defined(SAI2)

  /*-------------------------- SAI2 clock source configuration ---------------------*/
  if((((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_SAI2) == RCC_PERIPHCLK_SAI2))
 8004924:	687b      	ldr	r3, [r7, #4]
 8004926:	681b      	ldr	r3, [r3, #0]
 8004928:	f403 5380 	and.w	r3, r3, #4096	; 0x1000
 800492c:	2b00      	cmp	r3, #0
 800492e:	d041      	beq.n	80049b4 <HAL_RCCEx_PeriphCLKConfig+0x130>
  {
    /* Check the parameters */
    assert_param(IS_RCC_SAI2CLK(PeriphClkInit->Sai2ClockSelection));

    switch(PeriphClkInit->Sai2ClockSelection)
 8004930:	687b      	ldr	r3, [r7, #4]
 8004932:	6e9b      	ldr	r3, [r3, #104]	; 0x68
 8004934:	f1b3 7f40 	cmp.w	r3, #50331648	; 0x3000000
 8004938:	d02a      	beq.n	8004990 <HAL_RCCEx_PeriphCLKConfig+0x10c>
 800493a:	f1b3 7f40 	cmp.w	r3, #50331648	; 0x3000000
 800493e:	d824      	bhi.n	800498a <HAL_RCCEx_PeriphCLKConfig+0x106>
 8004940:	f1b3 7f00 	cmp.w	r3, #33554432	; 0x2000000
 8004944:	d008      	beq.n	8004958 <HAL_RCCEx_PeriphCLKConfig+0xd4>
 8004946:	f1b3 7f00 	cmp.w	r3, #33554432	; 0x2000000
 800494a:	d81e      	bhi.n	800498a <HAL_RCCEx_PeriphCLKConfig+0x106>
 800494c:	2b00      	cmp	r3, #0
 800494e:	d00a      	beq.n	8004966 <HAL_RCCEx_PeriphCLKConfig+0xe2>
 8004950:	f1b3 7f80 	cmp.w	r3, #16777216	; 0x1000000
 8004954:	d010      	beq.n	8004978 <HAL_RCCEx_PeriphCLKConfig+0xf4>
 8004956:	e018      	b.n	800498a <HAL_RCCEx_PeriphCLKConfig+0x106>
    {
    case RCC_SAI2CLKSOURCE_PLL:      /* PLL is used as clock source for SAI2*/
      /* Enable SAI Clock output generated from System PLL . */
      __HAL_RCC_PLLCLKOUT_ENABLE(RCC_PLL_SAI3CLK);
 8004958:	4b62      	ldr	r3, [pc, #392]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 800495a:	68db      	ldr	r3, [r3, #12]
 800495c:	4a61      	ldr	r2, [pc, #388]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 800495e:	f443 3380 	orr.w	r3, r3, #65536	; 0x10000
 8004962:	60d3      	str	r3, [r2, #12]
      /* SAI2 clock source config set later after clock selection check */
      break;
 8004964:	e015      	b.n	8004992 <HAL_RCCEx_PeriphCLKConfig+0x10e>

    case RCC_SAI2CLKSOURCE_PLLSAI1: /* PLLSAI1 is used as clock source for SAI2*/
      /* PLLSAI1 input clock, parameters M, N & P configuration and clock output (PLLSAI1ClockOut) */
      ret = RCCEx_PLLSAI1_Config(&(PeriphClkInit->PLLSAI1), DIVIDER_P_UPDATE);
 8004966:	687b      	ldr	r3, [r7, #4]
 8004968:	3304      	adds	r3, #4
 800496a:	2100      	movs	r1, #0
 800496c:	4618      	mov	r0, r3
 800496e:	f000 fa73 	bl	8004e58 <RCCEx_PLLSAI1_Config>
 8004972:	4603      	mov	r3, r0
 8004974:	74fb      	strb	r3, [r7, #19]
      /* SAI2 clock source config set later after clock selection check */
      break;
 8004976:	e00c      	b.n	8004992 <HAL_RCCEx_PeriphCLKConfig+0x10e>

    case RCC_SAI2CLKSOURCE_PLLSAI2:  /* PLLSAI2 is used as clock source for SAI2*/
      /* PLLSAI2 input clock, parameters M, N & P configuration and clock output (PLLSAI2ClockOut) */
      ret = RCCEx_PLLSAI2_Config(&(PeriphClkInit->PLLSAI2), DIVIDER_P_UPDATE);
 8004978:	687b      	ldr	r3, [r7, #4]
 800497a:	3320      	adds	r3, #32
 800497c:	2100      	movs	r1, #0
 800497e:	4618      	mov	r0, r3
 8004980:	f000 fb5e 	bl	8005040 <RCCEx_PLLSAI2_Config>
 8004984:	4603      	mov	r3, r0
 8004986:	74fb      	strb	r3, [r7, #19]
      /* SAI2 clock source config set later after clock selection check */
      break;
 8004988:	e003      	b.n	8004992 <HAL_RCCEx_PeriphCLKConfig+0x10e>
#endif /* STM32L4P5xx || STM32L4Q5xx || STM32L4R5xx || STM32L4R7xx || STM32L4R9xx || STM32L4S5xx || STM32L4S7xx || STM32L4S9xx */
      /* SAI2 clock source config set later after clock selection check */
      break;

    default:
      ret = HAL_ERROR;
 800498a:	2301      	movs	r3, #1
 800498c:	74fb      	strb	r3, [r7, #19]
      break;
 800498e:	e000      	b.n	8004992 <HAL_RCCEx_PeriphCLKConfig+0x10e>
      break;
 8004990:	bf00      	nop
    }

    if(ret == HAL_OK)
 8004992:	7cfb      	ldrb	r3, [r7, #19]
 8004994:	2b00      	cmp	r3, #0
 8004996:	d10b      	bne.n	80049b0 <HAL_RCCEx_PeriphCLKConfig+0x12c>
    {
      /* Set the source of SAI2 clock*/
      __HAL_RCC_SAI2_CONFIG(PeriphClkInit->Sai2ClockSelection);
 8004998:	4b52      	ldr	r3, [pc, #328]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 800499a:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 800499e:	f023 7240 	bic.w	r2, r3, #50331648	; 0x3000000
 80049a2:	687b      	ldr	r3, [r7, #4]
 80049a4:	6e9b      	ldr	r3, [r3, #104]	; 0x68
 80049a6:	494f      	ldr	r1, [pc, #316]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 80049a8:	4313      	orrs	r3, r2
 80049aa:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88
 80049ae:	e001      	b.n	80049b4 <HAL_RCCEx_PeriphCLKConfig+0x130>
    }
    else
    {
      /* set overall return value */
      status = ret;
 80049b0:	7cfb      	ldrb	r3, [r7, #19]
 80049b2:	74bb      	strb	r3, [r7, #18]
    }
  }
#endif /* SAI2 */

  /*-------------------------- RTC clock source configuration ----------------------*/
  if((PeriphClkInit->PeriphClockSelection & RCC_PERIPHCLK_RTC) == RCC_PERIPHCLK_RTC)
 80049b4:	687b      	ldr	r3, [r7, #4]
 80049b6:	681b      	ldr	r3, [r3, #0]
 80049b8:	f403 3300 	and.w	r3, r3, #131072	; 0x20000
 80049bc:	2b00      	cmp	r3, #0
 80049be:	f000 80a0 	beq.w	8004b02 <HAL_RCCEx_PeriphCLKConfig+0x27e>
  {
    FlagStatus       pwrclkchanged = RESET;
 80049c2:	2300      	movs	r3, #0
 80049c4:	747b      	strb	r3, [r7, #17]

    /* Check for RTC Parameters used to output RTCCLK */
    assert_param(IS_RCC_RTCCLKSOURCE(PeriphClkInit->RTCClockSelection));

    /* Enable Power Clock */
    if(__HAL_RCC_PWR_IS_CLK_DISABLED() != 0U)
 80049c6:	4b47      	ldr	r3, [pc, #284]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 80049c8:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 80049ca:	f003 5380 	and.w	r3, r3, #268435456	; 0x10000000
 80049ce:	2b00      	cmp	r3, #0
 80049d0:	d101      	bne.n	80049d6 <HAL_RCCEx_PeriphCLKConfig+0x152>
 80049d2:	2301      	movs	r3, #1
 80049d4:	e000      	b.n	80049d8 <HAL_RCCEx_PeriphCLKConfig+0x154>
 80049d6:	2300      	movs	r3, #0
 80049d8:	2b00      	cmp	r3, #0
 80049da:	d00d      	beq.n	80049f8 <HAL_RCCEx_PeriphCLKConfig+0x174>
    {
      __HAL_RCC_PWR_CLK_ENABLE();
 80049dc:	4b41      	ldr	r3, [pc, #260]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 80049de:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 80049e0:	4a40      	ldr	r2, [pc, #256]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 80049e2:	f043 5380 	orr.w	r3, r3, #268435456	; 0x10000000
 80049e6:	6593      	str	r3, [r2, #88]	; 0x58
 80049e8:	4b3e      	ldr	r3, [pc, #248]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 80049ea:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 80049ec:	f003 5380 	and.w	r3, r3, #268435456	; 0x10000000
 80049f0:	60bb      	str	r3, [r7, #8]
 80049f2:	68bb      	ldr	r3, [r7, #8]
      pwrclkchanged = SET;
 80049f4:	2301      	movs	r3, #1
 80049f6:	747b      	strb	r3, [r7, #17]
    }

    /* Enable write access to Backup domain */
    SET_BIT(PWR->CR1, PWR_CR1_DBP);
 80049f8:	4b3b      	ldr	r3, [pc, #236]	; (8004ae8 <HAL_RCCEx_PeriphCLKConfig+0x264>)
 80049fa:	681b      	ldr	r3, [r3, #0]
 80049fc:	4a3a      	ldr	r2, [pc, #232]	; (8004ae8 <HAL_RCCEx_PeriphCLKConfig+0x264>)
 80049fe:	f443 7380 	orr.w	r3, r3, #256	; 0x100
 8004a02:	6013      	str	r3, [r2, #0]

    /* Wait for Backup domain Write protection disable */
    tickstart = HAL_GetTick();
 8004a04:	f7fd faee 	bl	8001fe4 <HAL_GetTick>
 8004a08:	60f8      	str	r0, [r7, #12]

    while(READ_BIT(PWR->CR1, PWR_CR1_DBP) == 0U)
 8004a0a:	e009      	b.n	8004a20 <HAL_RCCEx_PeriphCLKConfig+0x19c>
    {
      if((HAL_GetTick() - tickstart) > RCC_DBP_TIMEOUT_VALUE)
 8004a0c:	f7fd faea 	bl	8001fe4 <HAL_GetTick>
 8004a10:	4602      	mov	r2, r0
 8004a12:	68fb      	ldr	r3, [r7, #12]
 8004a14:	1ad3      	subs	r3, r2, r3
 8004a16:	2b02      	cmp	r3, #2
 8004a18:	d902      	bls.n	8004a20 <HAL_RCCEx_PeriphCLKConfig+0x19c>
      {
        ret = HAL_TIMEOUT;
 8004a1a:	2303      	movs	r3, #3
 8004a1c:	74fb      	strb	r3, [r7, #19]
        break;
 8004a1e:	e005      	b.n	8004a2c <HAL_RCCEx_PeriphCLKConfig+0x1a8>
    while(READ_BIT(PWR->CR1, PWR_CR1_DBP) == 0U)
 8004a20:	4b31      	ldr	r3, [pc, #196]	; (8004ae8 <HAL_RCCEx_PeriphCLKConfig+0x264>)
 8004a22:	681b      	ldr	r3, [r3, #0]
 8004a24:	f403 7380 	and.w	r3, r3, #256	; 0x100
 8004a28:	2b00      	cmp	r3, #0
 8004a2a:	d0ef      	beq.n	8004a0c <HAL_RCCEx_PeriphCLKConfig+0x188>
      }
    }

    if(ret == HAL_OK)
 8004a2c:	7cfb      	ldrb	r3, [r7, #19]
 8004a2e:	2b00      	cmp	r3, #0
 8004a30:	d15c      	bne.n	8004aec <HAL_RCCEx_PeriphCLKConfig+0x268>
    {
      /* Reset the Backup domain only if the RTC Clock source selection is modified from default */
      tmpregister = READ_BIT(RCC->BDCR, RCC_BDCR_RTCSEL);
 8004a32:	4b2c      	ldr	r3, [pc, #176]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 8004a34:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8004a38:	f403 7340 	and.w	r3, r3, #768	; 0x300
 8004a3c:	617b      	str	r3, [r7, #20]

      if((tmpregister != RCC_RTCCLKSOURCE_NONE) && (tmpregister != PeriphClkInit->RTCClockSelection))
 8004a3e:	697b      	ldr	r3, [r7, #20]
 8004a40:	2b00      	cmp	r3, #0
 8004a42:	d01f      	beq.n	8004a84 <HAL_RCCEx_PeriphCLKConfig+0x200>
 8004a44:	687b      	ldr	r3, [r7, #4]
 8004a46:	f8d3 3084 	ldr.w	r3, [r3, #132]	; 0x84
 8004a4a:	697a      	ldr	r2, [r7, #20]
 8004a4c:	429a      	cmp	r2, r3
 8004a4e:	d019      	beq.n	8004a84 <HAL_RCCEx_PeriphCLKConfig+0x200>
      {
        /* Store the content of BDCR register before the reset of Backup Domain */
        tmpregister = READ_BIT(RCC->BDCR, ~(RCC_BDCR_RTCSEL));
 8004a50:	4b24      	ldr	r3, [pc, #144]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 8004a52:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8004a56:	f423 7340 	bic.w	r3, r3, #768	; 0x300
 8004a5a:	617b      	str	r3, [r7, #20]
        /* RTC Clock selection can be changed only if the Backup Domain is reset */
        __HAL_RCC_BACKUPRESET_FORCE();
 8004a5c:	4b21      	ldr	r3, [pc, #132]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 8004a5e:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8004a62:	4a20      	ldr	r2, [pc, #128]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 8004a64:	f443 3380 	orr.w	r3, r3, #65536	; 0x10000
 8004a68:	f8c2 3090 	str.w	r3, [r2, #144]	; 0x90
        __HAL_RCC_BACKUPRESET_RELEASE();
 8004a6c:	4b1d      	ldr	r3, [pc, #116]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 8004a6e:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8004a72:	4a1c      	ldr	r2, [pc, #112]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 8004a74:	f423 3380 	bic.w	r3, r3, #65536	; 0x10000
 8004a78:	f8c2 3090 	str.w	r3, [r2, #144]	; 0x90
        /* Restore the Content of BDCR register */
        RCC->BDCR = tmpregister;
 8004a7c:	4a19      	ldr	r2, [pc, #100]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 8004a7e:	697b      	ldr	r3, [r7, #20]
 8004a80:	f8c2 3090 	str.w	r3, [r2, #144]	; 0x90
      }

      /* Wait for LSE reactivation if LSE was enable prior to Backup Domain reset */
      if (HAL_IS_BIT_SET(tmpregister, RCC_BDCR_LSEON))
 8004a84:	697b      	ldr	r3, [r7, #20]
 8004a86:	f003 0301 	and.w	r3, r3, #1
 8004a8a:	2b00      	cmp	r3, #0
 8004a8c:	d016      	beq.n	8004abc <HAL_RCCEx_PeriphCLKConfig+0x238>
      {
        /* Get Start Tick*/
        tickstart = HAL_GetTick();
 8004a8e:	f7fd faa9 	bl	8001fe4 <HAL_GetTick>
 8004a92:	60f8      	str	r0, [r7, #12]

        /* Wait till LSE is ready */
        while(READ_BIT(RCC->BDCR, RCC_BDCR_LSERDY) == 0U)
 8004a94:	e00b      	b.n	8004aae <HAL_RCCEx_PeriphCLKConfig+0x22a>
        {
          if((HAL_GetTick() - tickstart) > RCC_LSE_TIMEOUT_VALUE)
 8004a96:	f7fd faa5 	bl	8001fe4 <HAL_GetTick>
 8004a9a:	4602      	mov	r2, r0
 8004a9c:	68fb      	ldr	r3, [r7, #12]
 8004a9e:	1ad3      	subs	r3, r2, r3
 8004aa0:	f241 3288 	movw	r2, #5000	; 0x1388
 8004aa4:	4293      	cmp	r3, r2
 8004aa6:	d902      	bls.n	8004aae <HAL_RCCEx_PeriphCLKConfig+0x22a>
          {
            ret = HAL_TIMEOUT;
 8004aa8:	2303      	movs	r3, #3
 8004aaa:	74fb      	strb	r3, [r7, #19]
            break;
 8004aac:	e006      	b.n	8004abc <HAL_RCCEx_PeriphCLKConfig+0x238>
        while(READ_BIT(RCC->BDCR, RCC_BDCR_LSERDY) == 0U)
 8004aae:	4b0d      	ldr	r3, [pc, #52]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 8004ab0:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8004ab4:	f003 0302 	and.w	r3, r3, #2
 8004ab8:	2b00      	cmp	r3, #0
 8004aba:	d0ec      	beq.n	8004a96 <HAL_RCCEx_PeriphCLKConfig+0x212>
          }
        }
      }

      if(ret == HAL_OK)
 8004abc:	7cfb      	ldrb	r3, [r7, #19]
 8004abe:	2b00      	cmp	r3, #0
 8004ac0:	d10c      	bne.n	8004adc <HAL_RCCEx_PeriphCLKConfig+0x258>
      {
        /* Apply new RTC clock source selection */
        __HAL_RCC_RTC_CONFIG(PeriphClkInit->RTCClockSelection);
 8004ac2:	4b08      	ldr	r3, [pc, #32]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 8004ac4:	f8d3 3090 	ldr.w	r3, [r3, #144]	; 0x90
 8004ac8:	f423 7240 	bic.w	r2, r3, #768	; 0x300
 8004acc:	687b      	ldr	r3, [r7, #4]
 8004ace:	f8d3 3084 	ldr.w	r3, [r3, #132]	; 0x84
 8004ad2:	4904      	ldr	r1, [pc, #16]	; (8004ae4 <HAL_RCCEx_PeriphCLKConfig+0x260>)
 8004ad4:	4313      	orrs	r3, r2
 8004ad6:	f8c1 3090 	str.w	r3, [r1, #144]	; 0x90
 8004ada:	e009      	b.n	8004af0 <HAL_RCCEx_PeriphCLKConfig+0x26c>
      }
      else
      {
        /* set overall return value */
        status = ret;
 8004adc:	7cfb      	ldrb	r3, [r7, #19]
 8004ade:	74bb      	strb	r3, [r7, #18]
 8004ae0:	e006      	b.n	8004af0 <HAL_RCCEx_PeriphCLKConfig+0x26c>
 8004ae2:	bf00      	nop
 8004ae4:	40021000 	.word	0x40021000
 8004ae8:	40007000 	.word	0x40007000
      }
    }
    else
    {
      /* set overall return value */
      status = ret;
 8004aec:	7cfb      	ldrb	r3, [r7, #19]
 8004aee:	74bb      	strb	r3, [r7, #18]
    }

    /* Restore clock configuration if changed */
    if(pwrclkchanged == SET)
 8004af0:	7c7b      	ldrb	r3, [r7, #17]
 8004af2:	2b01      	cmp	r3, #1
 8004af4:	d105      	bne.n	8004b02 <HAL_RCCEx_PeriphCLKConfig+0x27e>
    {
      __HAL_RCC_PWR_CLK_DISABLE();
 8004af6:	4b9e      	ldr	r3, [pc, #632]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004af8:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 8004afa:	4a9d      	ldr	r2, [pc, #628]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004afc:	f023 5380 	bic.w	r3, r3, #268435456	; 0x10000000
 8004b00:	6593      	str	r3, [r2, #88]	; 0x58
    }
  }

  /*-------------------------- USART1 clock source configuration -------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_USART1) == RCC_PERIPHCLK_USART1)
 8004b02:	687b      	ldr	r3, [r7, #4]
 8004b04:	681b      	ldr	r3, [r3, #0]
 8004b06:	f003 0301 	and.w	r3, r3, #1
 8004b0a:	2b00      	cmp	r3, #0
 8004b0c:	d00a      	beq.n	8004b24 <HAL_RCCEx_PeriphCLKConfig+0x2a0>
  {
    /* Check the parameters */
    assert_param(IS_RCC_USART1CLKSOURCE(PeriphClkInit->Usart1ClockSelection));

    /* Configure the USART1 clock source */
    __HAL_RCC_USART1_CONFIG(PeriphClkInit->Usart1ClockSelection);
 8004b0e:	4b98      	ldr	r3, [pc, #608]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004b10:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8004b14:	f023 0203 	bic.w	r2, r3, #3
 8004b18:	687b      	ldr	r3, [r7, #4]
 8004b1a:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8004b1c:	4994      	ldr	r1, [pc, #592]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004b1e:	4313      	orrs	r3, r2
 8004b20:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88
  }

  /*-------------------------- USART2 clock source configuration -------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_USART2) == RCC_PERIPHCLK_USART2)
 8004b24:	687b      	ldr	r3, [r7, #4]
 8004b26:	681b      	ldr	r3, [r3, #0]
 8004b28:	f003 0302 	and.w	r3, r3, #2
 8004b2c:	2b00      	cmp	r3, #0
 8004b2e:	d00a      	beq.n	8004b46 <HAL_RCCEx_PeriphCLKConfig+0x2c2>
  {
    /* Check the parameters */
    assert_param(IS_RCC_USART2CLKSOURCE(PeriphClkInit->Usart2ClockSelection));

    /* Configure the USART2 clock source */
    __HAL_RCC_USART2_CONFIG(PeriphClkInit->Usart2ClockSelection);
 8004b30:	4b8f      	ldr	r3, [pc, #572]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004b32:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8004b36:	f023 020c 	bic.w	r2, r3, #12
 8004b3a:	687b      	ldr	r3, [r7, #4]
 8004b3c:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8004b3e:	498c      	ldr	r1, [pc, #560]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004b40:	4313      	orrs	r3, r2
 8004b42:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88
  }

#if defined(USART3)

  /*-------------------------- USART3 clock source configuration -------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_USART3) == RCC_PERIPHCLK_USART3)
 8004b46:	687b      	ldr	r3, [r7, #4]
 8004b48:	681b      	ldr	r3, [r3, #0]
 8004b4a:	f003 0304 	and.w	r3, r3, #4
 8004b4e:	2b00      	cmp	r3, #0
 8004b50:	d00a      	beq.n	8004b68 <HAL_RCCEx_PeriphCLKConfig+0x2e4>
  {
    /* Check the parameters */
    assert_param(IS_RCC_USART3CLKSOURCE(PeriphClkInit->Usart3ClockSelection));

    /* Configure the USART3 clock source */
    __HAL_RCC_USART3_CONFIG(PeriphClkInit->Usart3ClockSelection);
 8004b52:	4b87      	ldr	r3, [pc, #540]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004b54:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8004b58:	f023 0230 	bic.w	r2, r3, #48	; 0x30
 8004b5c:	687b      	ldr	r3, [r7, #4]
 8004b5e:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 8004b60:	4983      	ldr	r1, [pc, #524]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004b62:	4313      	orrs	r3, r2
 8004b64:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88
#endif /* USART3 */

#if defined(UART4)

  /*-------------------------- UART4 clock source configuration --------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_UART4) == RCC_PERIPHCLK_UART4)
 8004b68:	687b      	ldr	r3, [r7, #4]
 8004b6a:	681b      	ldr	r3, [r3, #0]
 8004b6c:	f003 0308 	and.w	r3, r3, #8
 8004b70:	2b00      	cmp	r3, #0
 8004b72:	d00a      	beq.n	8004b8a <HAL_RCCEx_PeriphCLKConfig+0x306>
  {
    /* Check the parameters */
    assert_param(IS_RCC_UART4CLKSOURCE(PeriphClkInit->Uart4ClockSelection));

    /* Configure the UART4 clock source */
    __HAL_RCC_UART4_CONFIG(PeriphClkInit->Uart4ClockSelection);
 8004b74:	4b7e      	ldr	r3, [pc, #504]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004b76:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8004b7a:	f023 02c0 	bic.w	r2, r3, #192	; 0xc0
 8004b7e:	687b      	ldr	r3, [r7, #4]
 8004b80:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8004b82:	497b      	ldr	r1, [pc, #492]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004b84:	4313      	orrs	r3, r2
 8004b86:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88
#endif /* UART4 */

#if defined(UART5)

  /*-------------------------- UART5 clock source configuration --------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_UART5) == RCC_PERIPHCLK_UART5)
 8004b8a:	687b      	ldr	r3, [r7, #4]
 8004b8c:	681b      	ldr	r3, [r3, #0]
 8004b8e:	f003 0310 	and.w	r3, r3, #16
 8004b92:	2b00      	cmp	r3, #0
 8004b94:	d00a      	beq.n	8004bac <HAL_RCCEx_PeriphCLKConfig+0x328>
  {
    /* Check the parameters */
    assert_param(IS_RCC_UART5CLKSOURCE(PeriphClkInit->Uart5ClockSelection));

    /* Configure the UART5 clock source */
    __HAL_RCC_UART5_CONFIG(PeriphClkInit->Uart5ClockSelection);
 8004b96:	4b76      	ldr	r3, [pc, #472]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004b98:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8004b9c:	f423 7240 	bic.w	r2, r3, #768	; 0x300
 8004ba0:	687b      	ldr	r3, [r7, #4]
 8004ba2:	6c9b      	ldr	r3, [r3, #72]	; 0x48
 8004ba4:	4972      	ldr	r1, [pc, #456]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004ba6:	4313      	orrs	r3, r2
 8004ba8:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88
  }

#endif /* UART5 */

  /*-------------------------- LPUART1 clock source configuration ------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_LPUART1) == RCC_PERIPHCLK_LPUART1)
 8004bac:	687b      	ldr	r3, [r7, #4]
 8004bae:	681b      	ldr	r3, [r3, #0]
 8004bb0:	f003 0320 	and.w	r3, r3, #32
 8004bb4:	2b00      	cmp	r3, #0
 8004bb6:	d00a      	beq.n	8004bce <HAL_RCCEx_PeriphCLKConfig+0x34a>
  {
    /* Check the parameters */
    assert_param(IS_RCC_LPUART1CLKSOURCE(PeriphClkInit->Lpuart1ClockSelection));

    /* Configure the LPUART1 clock source */
    __HAL_RCC_LPUART1_CONFIG(PeriphClkInit->Lpuart1ClockSelection);
 8004bb8:	4b6d      	ldr	r3, [pc, #436]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004bba:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8004bbe:	f423 6240 	bic.w	r2, r3, #3072	; 0xc00
 8004bc2:	687b      	ldr	r3, [r7, #4]
 8004bc4:	6cdb      	ldr	r3, [r3, #76]	; 0x4c
 8004bc6:	496a      	ldr	r1, [pc, #424]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004bc8:	4313      	orrs	r3, r2
 8004bca:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88
  }

  /*-------------------------- LPTIM1 clock source configuration -------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_LPTIM1) == (RCC_PERIPHCLK_LPTIM1))
 8004bce:	687b      	ldr	r3, [r7, #4]
 8004bd0:	681b      	ldr	r3, [r3, #0]
 8004bd2:	f403 7300 	and.w	r3, r3, #512	; 0x200
 8004bd6:	2b00      	cmp	r3, #0
 8004bd8:	d00a      	beq.n	8004bf0 <HAL_RCCEx_PeriphCLKConfig+0x36c>
  {
    assert_param(IS_RCC_LPTIM1CLK(PeriphClkInit->Lptim1ClockSelection));
    __HAL_RCC_LPTIM1_CONFIG(PeriphClkInit->Lptim1ClockSelection);
 8004bda:	4b65      	ldr	r3, [pc, #404]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004bdc:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8004be0:	f423 2240 	bic.w	r2, r3, #786432	; 0xc0000
 8004be4:	687b      	ldr	r3, [r7, #4]
 8004be6:	6ddb      	ldr	r3, [r3, #92]	; 0x5c
 8004be8:	4961      	ldr	r1, [pc, #388]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004bea:	4313      	orrs	r3, r2
 8004bec:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88
  }

  /*-------------------------- LPTIM2 clock source configuration -------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_LPTIM2) == (RCC_PERIPHCLK_LPTIM2))
 8004bf0:	687b      	ldr	r3, [r7, #4]
 8004bf2:	681b      	ldr	r3, [r3, #0]
 8004bf4:	f403 6380 	and.w	r3, r3, #1024	; 0x400
 8004bf8:	2b00      	cmp	r3, #0
 8004bfa:	d00a      	beq.n	8004c12 <HAL_RCCEx_PeriphCLKConfig+0x38e>
  {
    assert_param(IS_RCC_LPTIM2CLK(PeriphClkInit->Lptim2ClockSelection));
    __HAL_RCC_LPTIM2_CONFIG(PeriphClkInit->Lptim2ClockSelection);
 8004bfc:	4b5c      	ldr	r3, [pc, #368]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004bfe:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8004c02:	f423 1240 	bic.w	r2, r3, #3145728	; 0x300000
 8004c06:	687b      	ldr	r3, [r7, #4]
 8004c08:	6e1b      	ldr	r3, [r3, #96]	; 0x60
 8004c0a:	4959      	ldr	r1, [pc, #356]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004c0c:	4313      	orrs	r3, r2
 8004c0e:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88
  }

  /*-------------------------- I2C1 clock source configuration ---------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_I2C1) == RCC_PERIPHCLK_I2C1)
 8004c12:	687b      	ldr	r3, [r7, #4]
 8004c14:	681b      	ldr	r3, [r3, #0]
 8004c16:	f003 0340 	and.w	r3, r3, #64	; 0x40
 8004c1a:	2b00      	cmp	r3, #0
 8004c1c:	d00a      	beq.n	8004c34 <HAL_RCCEx_PeriphCLKConfig+0x3b0>
  {
    /* Check the parameters */
    assert_param(IS_RCC_I2C1CLKSOURCE(PeriphClkInit->I2c1ClockSelection));

    /* Configure the I2C1 clock source */
    __HAL_RCC_I2C1_CONFIG(PeriphClkInit->I2c1ClockSelection);
 8004c1e:	4b54      	ldr	r3, [pc, #336]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004c20:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8004c24:	f423 5240 	bic.w	r2, r3, #12288	; 0x3000
 8004c28:	687b      	ldr	r3, [r7, #4]
 8004c2a:	6d1b      	ldr	r3, [r3, #80]	; 0x50
 8004c2c:	4950      	ldr	r1, [pc, #320]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004c2e:	4313      	orrs	r3, r2
 8004c30:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88
  }

#if defined(I2C2)

  /*-------------------------- I2C2 clock source configuration ---------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_I2C2) == RCC_PERIPHCLK_I2C2)
 8004c34:	687b      	ldr	r3, [r7, #4]
 8004c36:	681b      	ldr	r3, [r3, #0]
 8004c38:	f003 0380 	and.w	r3, r3, #128	; 0x80
 8004c3c:	2b00      	cmp	r3, #0
 8004c3e:	d00a      	beq.n	8004c56 <HAL_RCCEx_PeriphCLKConfig+0x3d2>
  {
    /* Check the parameters */
    assert_param(IS_RCC_I2C2CLKSOURCE(PeriphClkInit->I2c2ClockSelection));

    /* Configure the I2C2 clock source */
    __HAL_RCC_I2C2_CONFIG(PeriphClkInit->I2c2ClockSelection);
 8004c40:	4b4b      	ldr	r3, [pc, #300]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004c42:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8004c46:	f423 4240 	bic.w	r2, r3, #49152	; 0xc000
 8004c4a:	687b      	ldr	r3, [r7, #4]
 8004c4c:	6d5b      	ldr	r3, [r3, #84]	; 0x54
 8004c4e:	4948      	ldr	r1, [pc, #288]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004c50:	4313      	orrs	r3, r2
 8004c52:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88
  }

#endif /* I2C2 */

  /*-------------------------- I2C3 clock source configuration ---------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_I2C3) == RCC_PERIPHCLK_I2C3)
 8004c56:	687b      	ldr	r3, [r7, #4]
 8004c58:	681b      	ldr	r3, [r3, #0]
 8004c5a:	f403 7380 	and.w	r3, r3, #256	; 0x100
 8004c5e:	2b00      	cmp	r3, #0
 8004c60:	d00a      	beq.n	8004c78 <HAL_RCCEx_PeriphCLKConfig+0x3f4>
  {
    /* Check the parameters */
    assert_param(IS_RCC_I2C3CLKSOURCE(PeriphClkInit->I2c3ClockSelection));

    /* Configure the I2C3 clock source */
    __HAL_RCC_I2C3_CONFIG(PeriphClkInit->I2c3ClockSelection);
 8004c62:	4b43      	ldr	r3, [pc, #268]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004c64:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8004c68:	f423 3240 	bic.w	r2, r3, #196608	; 0x30000
 8004c6c:	687b      	ldr	r3, [r7, #4]
 8004c6e:	6d9b      	ldr	r3, [r3, #88]	; 0x58
 8004c70:	493f      	ldr	r1, [pc, #252]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004c72:	4313      	orrs	r3, r2
 8004c74:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88
#endif /* I2C4 */

#if defined(USB_OTG_FS) || defined(USB)

  /*-------------------------- USB clock source configuration ----------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_USB) == (RCC_PERIPHCLK_USB))
 8004c78:	687b      	ldr	r3, [r7, #4]
 8004c7a:	681b      	ldr	r3, [r3, #0]
 8004c7c:	f403 5300 	and.w	r3, r3, #8192	; 0x2000
 8004c80:	2b00      	cmp	r3, #0
 8004c82:	d028      	beq.n	8004cd6 <HAL_RCCEx_PeriphCLKConfig+0x452>
  {
    assert_param(IS_RCC_USBCLKSOURCE(PeriphClkInit->UsbClockSelection));
    __HAL_RCC_USB_CONFIG(PeriphClkInit->UsbClockSelection);
 8004c84:	4b3a      	ldr	r3, [pc, #232]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004c86:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8004c8a:	f023 6240 	bic.w	r2, r3, #201326592	; 0xc000000
 8004c8e:	687b      	ldr	r3, [r7, #4]
 8004c90:	6edb      	ldr	r3, [r3, #108]	; 0x6c
 8004c92:	4937      	ldr	r1, [pc, #220]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004c94:	4313      	orrs	r3, r2
 8004c96:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88

    if(PeriphClkInit->UsbClockSelection == RCC_USBCLKSOURCE_PLL)
 8004c9a:	687b      	ldr	r3, [r7, #4]
 8004c9c:	6edb      	ldr	r3, [r3, #108]	; 0x6c
 8004c9e:	f1b3 6f00 	cmp.w	r3, #134217728	; 0x8000000
 8004ca2:	d106      	bne.n	8004cb2 <HAL_RCCEx_PeriphCLKConfig+0x42e>
    {
      /* Enable PLL48M1CLK output clock */
      __HAL_RCC_PLLCLKOUT_ENABLE(RCC_PLL_48M1CLK);
 8004ca4:	4b32      	ldr	r3, [pc, #200]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004ca6:	68db      	ldr	r3, [r3, #12]
 8004ca8:	4a31      	ldr	r2, [pc, #196]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004caa:	f443 1380 	orr.w	r3, r3, #1048576	; 0x100000
 8004cae:	60d3      	str	r3, [r2, #12]
 8004cb0:	e011      	b.n	8004cd6 <HAL_RCCEx_PeriphCLKConfig+0x452>
    }
    else
    {
#if defined(RCC_PLLSAI1_SUPPORT)
      if(PeriphClkInit->UsbClockSelection == RCC_USBCLKSOURCE_PLLSAI1)
 8004cb2:	687b      	ldr	r3, [r7, #4]
 8004cb4:	6edb      	ldr	r3, [r3, #108]	; 0x6c
 8004cb6:	f1b3 6f80 	cmp.w	r3, #67108864	; 0x4000000
 8004cba:	d10c      	bne.n	8004cd6 <HAL_RCCEx_PeriphCLKConfig+0x452>
      {
        /* PLLSAI1 input clock, parameters M, N & Q configuration and clock output (PLLSAI1ClockOut) */
        ret = RCCEx_PLLSAI1_Config(&(PeriphClkInit->PLLSAI1), DIVIDER_Q_UPDATE);
 8004cbc:	687b      	ldr	r3, [r7, #4]
 8004cbe:	3304      	adds	r3, #4
 8004cc0:	2101      	movs	r1, #1
 8004cc2:	4618      	mov	r0, r3
 8004cc4:	f000 f8c8 	bl	8004e58 <RCCEx_PLLSAI1_Config>
 8004cc8:	4603      	mov	r3, r0
 8004cca:	74fb      	strb	r3, [r7, #19]

        if(ret != HAL_OK)
 8004ccc:	7cfb      	ldrb	r3, [r7, #19]
 8004cce:	2b00      	cmp	r3, #0
 8004cd0:	d001      	beq.n	8004cd6 <HAL_RCCEx_PeriphCLKConfig+0x452>
        {
          /* set overall return value */
          status = ret;
 8004cd2:	7cfb      	ldrb	r3, [r7, #19]
 8004cd4:	74bb      	strb	r3, [r7, #18]
#endif /* USB_OTG_FS || USB */

#if defined(SDMMC1)

  /*-------------------------- SDMMC1 clock source configuration -------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_SDMMC1) == (RCC_PERIPHCLK_SDMMC1))
 8004cd6:	687b      	ldr	r3, [r7, #4]
 8004cd8:	681b      	ldr	r3, [r3, #0]
 8004cda:	f403 2300 	and.w	r3, r3, #524288	; 0x80000
 8004cde:	2b00      	cmp	r3, #0
 8004ce0:	d028      	beq.n	8004d34 <HAL_RCCEx_PeriphCLKConfig+0x4b0>
  {
    assert_param(IS_RCC_SDMMC1CLKSOURCE(PeriphClkInit->Sdmmc1ClockSelection));
    __HAL_RCC_SDMMC1_CONFIG(PeriphClkInit->Sdmmc1ClockSelection);
 8004ce2:	4b23      	ldr	r3, [pc, #140]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004ce4:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8004ce8:	f023 6240 	bic.w	r2, r3, #201326592	; 0xc000000
 8004cec:	687b      	ldr	r3, [r7, #4]
 8004cee:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 8004cf0:	491f      	ldr	r1, [pc, #124]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004cf2:	4313      	orrs	r3, r2
 8004cf4:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88

    if(PeriphClkInit->Sdmmc1ClockSelection == RCC_SDMMC1CLKSOURCE_PLL)   /* PLL "Q" ? */
 8004cf8:	687b      	ldr	r3, [r7, #4]
 8004cfa:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 8004cfc:	f1b3 6f00 	cmp.w	r3, #134217728	; 0x8000000
 8004d00:	d106      	bne.n	8004d10 <HAL_RCCEx_PeriphCLKConfig+0x48c>
    {
      /* Enable PLL48M1CLK output clock */
      __HAL_RCC_PLLCLKOUT_ENABLE(RCC_PLL_48M1CLK);
 8004d02:	4b1b      	ldr	r3, [pc, #108]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004d04:	68db      	ldr	r3, [r3, #12]
 8004d06:	4a1a      	ldr	r2, [pc, #104]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004d08:	f443 1380 	orr.w	r3, r3, #1048576	; 0x100000
 8004d0c:	60d3      	str	r3, [r2, #12]
 8004d0e:	e011      	b.n	8004d34 <HAL_RCCEx_PeriphCLKConfig+0x4b0>
    {
      /* Enable PLLSAI3CLK output */
      __HAL_RCC_PLLCLKOUT_ENABLE(RCC_PLL_SAI3CLK);
    }
#endif
    else if(PeriphClkInit->Sdmmc1ClockSelection == RCC_SDMMC1CLKSOURCE_PLLSAI1)
 8004d10:	687b      	ldr	r3, [r7, #4]
 8004d12:	6f1b      	ldr	r3, [r3, #112]	; 0x70
 8004d14:	f1b3 6f80 	cmp.w	r3, #67108864	; 0x4000000
 8004d18:	d10c      	bne.n	8004d34 <HAL_RCCEx_PeriphCLKConfig+0x4b0>
    {
      /* PLLSAI1 input clock, parameters M, N & Q configuration and clock output (PLLSAI1ClockOut) */
      ret = RCCEx_PLLSAI1_Config(&(PeriphClkInit->PLLSAI1), DIVIDER_Q_UPDATE);
 8004d1a:	687b      	ldr	r3, [r7, #4]
 8004d1c:	3304      	adds	r3, #4
 8004d1e:	2101      	movs	r1, #1
 8004d20:	4618      	mov	r0, r3
 8004d22:	f000 f899 	bl	8004e58 <RCCEx_PLLSAI1_Config>
 8004d26:	4603      	mov	r3, r0
 8004d28:	74fb      	strb	r3, [r7, #19]

      if(ret != HAL_OK)
 8004d2a:	7cfb      	ldrb	r3, [r7, #19]
 8004d2c:	2b00      	cmp	r3, #0
 8004d2e:	d001      	beq.n	8004d34 <HAL_RCCEx_PeriphCLKConfig+0x4b0>
      {
        /* set overall return value */
        status = ret;
 8004d30:	7cfb      	ldrb	r3, [r7, #19]
 8004d32:	74bb      	strb	r3, [r7, #18]
  }

#endif /* SDMMC1 */

  /*-------------------------- RNG clock source configuration ----------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_RNG) == (RCC_PERIPHCLK_RNG))
 8004d34:	687b      	ldr	r3, [r7, #4]
 8004d36:	681b      	ldr	r3, [r3, #0]
 8004d38:	f403 2380 	and.w	r3, r3, #262144	; 0x40000
 8004d3c:	2b00      	cmp	r3, #0
 8004d3e:	d02b      	beq.n	8004d98 <HAL_RCCEx_PeriphCLKConfig+0x514>
  {
    assert_param(IS_RCC_RNGCLKSOURCE(PeriphClkInit->RngClockSelection));
    __HAL_RCC_RNG_CONFIG(PeriphClkInit->RngClockSelection);
 8004d40:	4b0b      	ldr	r3, [pc, #44]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004d42:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8004d46:	f023 6240 	bic.w	r2, r3, #201326592	; 0xc000000
 8004d4a:	687b      	ldr	r3, [r7, #4]
 8004d4c:	6f5b      	ldr	r3, [r3, #116]	; 0x74
 8004d4e:	4908      	ldr	r1, [pc, #32]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004d50:	4313      	orrs	r3, r2
 8004d52:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88

    if(PeriphClkInit->RngClockSelection == RCC_RNGCLKSOURCE_PLL)
 8004d56:	687b      	ldr	r3, [r7, #4]
 8004d58:	6f5b      	ldr	r3, [r3, #116]	; 0x74
 8004d5a:	f1b3 6f00 	cmp.w	r3, #134217728	; 0x8000000
 8004d5e:	d109      	bne.n	8004d74 <HAL_RCCEx_PeriphCLKConfig+0x4f0>
    {
      /* Enable PLL48M1CLK output clock */
      __HAL_RCC_PLLCLKOUT_ENABLE(RCC_PLL_48M1CLK);
 8004d60:	4b03      	ldr	r3, [pc, #12]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004d62:	68db      	ldr	r3, [r3, #12]
 8004d64:	4a02      	ldr	r2, [pc, #8]	; (8004d70 <HAL_RCCEx_PeriphCLKConfig+0x4ec>)
 8004d66:	f443 1380 	orr.w	r3, r3, #1048576	; 0x100000
 8004d6a:	60d3      	str	r3, [r2, #12]
 8004d6c:	e014      	b.n	8004d98 <HAL_RCCEx_PeriphCLKConfig+0x514>
 8004d6e:	bf00      	nop
 8004d70:	40021000 	.word	0x40021000
    }
#if defined(RCC_PLLSAI1_SUPPORT)
    else if(PeriphClkInit->RngClockSelection == RCC_RNGCLKSOURCE_PLLSAI1)
 8004d74:	687b      	ldr	r3, [r7, #4]
 8004d76:	6f5b      	ldr	r3, [r3, #116]	; 0x74
 8004d78:	f1b3 6f80 	cmp.w	r3, #67108864	; 0x4000000
 8004d7c:	d10c      	bne.n	8004d98 <HAL_RCCEx_PeriphCLKConfig+0x514>
    {
      /* PLLSAI1 input clock, parameters M, N & Q configuration and clock output (PLLSAI1ClockOut) */
      ret = RCCEx_PLLSAI1_Config(&(PeriphClkInit->PLLSAI1), DIVIDER_Q_UPDATE);
 8004d7e:	687b      	ldr	r3, [r7, #4]
 8004d80:	3304      	adds	r3, #4
 8004d82:	2101      	movs	r1, #1
 8004d84:	4618      	mov	r0, r3
 8004d86:	f000 f867 	bl	8004e58 <RCCEx_PLLSAI1_Config>
 8004d8a:	4603      	mov	r3, r0
 8004d8c:	74fb      	strb	r3, [r7, #19]

      if(ret != HAL_OK)
 8004d8e:	7cfb      	ldrb	r3, [r7, #19]
 8004d90:	2b00      	cmp	r3, #0
 8004d92:	d001      	beq.n	8004d98 <HAL_RCCEx_PeriphCLKConfig+0x514>
      {
        /* set overall return value */
        status = ret;
 8004d94:	7cfb      	ldrb	r3, [r7, #19]
 8004d96:	74bb      	strb	r3, [r7, #18]
    }
  }

  /*-------------------------- ADC clock source configuration ----------------------*/
#if !defined(STM32L412xx) && !defined(STM32L422xx)
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_ADC) == RCC_PERIPHCLK_ADC)
 8004d98:	687b      	ldr	r3, [r7, #4]
 8004d9a:	681b      	ldr	r3, [r3, #0]
 8004d9c:	f403 4380 	and.w	r3, r3, #16384	; 0x4000
 8004da0:	2b00      	cmp	r3, #0
 8004da2:	d02f      	beq.n	8004e04 <HAL_RCCEx_PeriphCLKConfig+0x580>
  {
    /* Check the parameters */
    assert_param(IS_RCC_ADCCLKSOURCE(PeriphClkInit->AdcClockSelection));

    /* Configure the ADC interface clock source */
    __HAL_RCC_ADC_CONFIG(PeriphClkInit->AdcClockSelection);
 8004da4:	4b2b      	ldr	r3, [pc, #172]	; (8004e54 <HAL_RCCEx_PeriphCLKConfig+0x5d0>)
 8004da6:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8004daa:	f023 5240 	bic.w	r2, r3, #805306368	; 0x30000000
 8004dae:	687b      	ldr	r3, [r7, #4]
 8004db0:	6f9b      	ldr	r3, [r3, #120]	; 0x78
 8004db2:	4928      	ldr	r1, [pc, #160]	; (8004e54 <HAL_RCCEx_PeriphCLKConfig+0x5d0>)
 8004db4:	4313      	orrs	r3, r2
 8004db6:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88

#if defined(RCC_PLLSAI1_SUPPORT)
    if(PeriphClkInit->AdcClockSelection == RCC_ADCCLKSOURCE_PLLSAI1)
 8004dba:	687b      	ldr	r3, [r7, #4]
 8004dbc:	6f9b      	ldr	r3, [r3, #120]	; 0x78
 8004dbe:	f1b3 5f80 	cmp.w	r3, #268435456	; 0x10000000
 8004dc2:	d10d      	bne.n	8004de0 <HAL_RCCEx_PeriphCLKConfig+0x55c>
    {
      /* PLLSAI1 input clock, parameters M, N & R configuration and clock output (PLLSAI1ClockOut) */
      ret = RCCEx_PLLSAI1_Config(&(PeriphClkInit->PLLSAI1), DIVIDER_R_UPDATE);
 8004dc4:	687b      	ldr	r3, [r7, #4]
 8004dc6:	3304      	adds	r3, #4
 8004dc8:	2102      	movs	r1, #2
 8004dca:	4618      	mov	r0, r3
 8004dcc:	f000 f844 	bl	8004e58 <RCCEx_PLLSAI1_Config>
 8004dd0:	4603      	mov	r3, r0
 8004dd2:	74fb      	strb	r3, [r7, #19]

      if(ret != HAL_OK)
 8004dd4:	7cfb      	ldrb	r3, [r7, #19]
 8004dd6:	2b00      	cmp	r3, #0
 8004dd8:	d014      	beq.n	8004e04 <HAL_RCCEx_PeriphCLKConfig+0x580>
      {
        /* set overall return value */
        status = ret;
 8004dda:	7cfb      	ldrb	r3, [r7, #19]
 8004ddc:	74bb      	strb	r3, [r7, #18]
 8004dde:	e011      	b.n	8004e04 <HAL_RCCEx_PeriphCLKConfig+0x580>
    }
#endif /* RCC_PLLSAI1_SUPPORT */

#if defined(STM32L471xx) || defined(STM32L475xx) || defined(STM32L476xx) || defined(STM32L485xx) || defined(STM32L486xx) || defined(STM32L496xx) || defined(STM32L4A6xx)

    else if(PeriphClkInit->AdcClockSelection == RCC_ADCCLKSOURCE_PLLSAI2)
 8004de0:	687b      	ldr	r3, [r7, #4]
 8004de2:	6f9b      	ldr	r3, [r3, #120]	; 0x78
 8004de4:	f1b3 5f00 	cmp.w	r3, #536870912	; 0x20000000
 8004de8:	d10c      	bne.n	8004e04 <HAL_RCCEx_PeriphCLKConfig+0x580>
    {
      /* PLLSAI2 input clock, parameters M, N & R configuration and clock output (PLLSAI2ClockOut) */
      ret = RCCEx_PLLSAI2_Config(&(PeriphClkInit->PLLSAI2), DIVIDER_R_UPDATE);
 8004dea:	687b      	ldr	r3, [r7, #4]
 8004dec:	3320      	adds	r3, #32
 8004dee:	2102      	movs	r1, #2
 8004df0:	4618      	mov	r0, r3
 8004df2:	f000 f925 	bl	8005040 <RCCEx_PLLSAI2_Config>
 8004df6:	4603      	mov	r3, r0
 8004df8:	74fb      	strb	r3, [r7, #19]

      if(ret != HAL_OK)
 8004dfa:	7cfb      	ldrb	r3, [r7, #19]
 8004dfc:	2b00      	cmp	r3, #0
 8004dfe:	d001      	beq.n	8004e04 <HAL_RCCEx_PeriphCLKConfig+0x580>
      {
        /* set overall return value */
        status = ret;
 8004e00:	7cfb      	ldrb	r3, [r7, #19]
 8004e02:	74bb      	strb	r3, [r7, #18]
#endif /* !STM32L412xx && !STM32L422xx */

#if defined(SWPMI1)

  /*-------------------------- SWPMI1 clock source configuration -------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_SWPMI1) == RCC_PERIPHCLK_SWPMI1)
 8004e04:	687b      	ldr	r3, [r7, #4]
 8004e06:	681b      	ldr	r3, [r3, #0]
 8004e08:	f403 4300 	and.w	r3, r3, #32768	; 0x8000
 8004e0c:	2b00      	cmp	r3, #0
 8004e0e:	d00a      	beq.n	8004e26 <HAL_RCCEx_PeriphCLKConfig+0x5a2>
  {
    /* Check the parameters */
    assert_param(IS_RCC_SWPMI1CLKSOURCE(PeriphClkInit->Swpmi1ClockSelection));

    /* Configure the SWPMI1 clock source */
    __HAL_RCC_SWPMI1_CONFIG(PeriphClkInit->Swpmi1ClockSelection);
 8004e10:	4b10      	ldr	r3, [pc, #64]	; (8004e54 <HAL_RCCEx_PeriphCLKConfig+0x5d0>)
 8004e12:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8004e16:	f023 4280 	bic.w	r2, r3, #1073741824	; 0x40000000
 8004e1a:	687b      	ldr	r3, [r7, #4]
 8004e1c:	6fdb      	ldr	r3, [r3, #124]	; 0x7c
 8004e1e:	490d      	ldr	r1, [pc, #52]	; (8004e54 <HAL_RCCEx_PeriphCLKConfig+0x5d0>)
 8004e20:	4313      	orrs	r3, r2
 8004e22:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88
#endif /* SWPMI1 */

#if defined(DFSDM1_Filter0)

  /*-------------------------- DFSDM1 clock source configuration -------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_DFSDM1) == RCC_PERIPHCLK_DFSDM1)
 8004e26:	687b      	ldr	r3, [r7, #4]
 8004e28:	681b      	ldr	r3, [r3, #0]
 8004e2a:	f403 3380 	and.w	r3, r3, #65536	; 0x10000
 8004e2e:	2b00      	cmp	r3, #0
 8004e30:	d00b      	beq.n	8004e4a <HAL_RCCEx_PeriphCLKConfig+0x5c6>
  {
    /* Check the parameters */
    assert_param(IS_RCC_DFSDM1CLKSOURCE(PeriphClkInit->Dfsdm1ClockSelection));

    /* Configure the DFSDM1 interface clock source */
    __HAL_RCC_DFSDM1_CONFIG(PeriphClkInit->Dfsdm1ClockSelection);
 8004e32:	4b08      	ldr	r3, [pc, #32]	; (8004e54 <HAL_RCCEx_PeriphCLKConfig+0x5d0>)
 8004e34:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8004e38:	f023 4200 	bic.w	r2, r3, #2147483648	; 0x80000000
 8004e3c:	687b      	ldr	r3, [r7, #4]
 8004e3e:	f8d3 3080 	ldr.w	r3, [r3, #128]	; 0x80
 8004e42:	4904      	ldr	r1, [pc, #16]	; (8004e54 <HAL_RCCEx_PeriphCLKConfig+0x5d0>)
 8004e44:	4313      	orrs	r3, r2
 8004e46:	f8c1 3088 	str.w	r3, [r1, #136]	; 0x88
    }
  }

#endif /* OCTOSPI1 || OCTOSPI2 */

  return status;
 8004e4a:	7cbb      	ldrb	r3, [r7, #18]
}
 8004e4c:	4618      	mov	r0, r3
 8004e4e:	3718      	adds	r7, #24
 8004e50:	46bd      	mov	sp, r7
 8004e52:	bd80      	pop	{r7, pc}
 8004e54:	40021000 	.word	0x40021000

08004e58 <RCCEx_PLLSAI1_Config>:
  * @note   PLLSAI1 is temporary disable to apply new parameters
  *
  * @retval HAL status
  */
static HAL_StatusTypeDef RCCEx_PLLSAI1_Config(RCC_PLLSAI1InitTypeDef *PllSai1, uint32_t Divider)
{
 8004e58:	b580      	push	{r7, lr}
 8004e5a:	b084      	sub	sp, #16
 8004e5c:	af00      	add	r7, sp, #0
 8004e5e:	6078      	str	r0, [r7, #4]
 8004e60:	6039      	str	r1, [r7, #0]
  uint32_t tickstart;
  HAL_StatusTypeDef status = HAL_OK;
 8004e62:	2300      	movs	r3, #0
 8004e64:	73fb      	strb	r3, [r7, #15]
  assert_param(IS_RCC_PLLSAI1M_VALUE(PllSai1->PLLSAI1M));
  assert_param(IS_RCC_PLLSAI1N_VALUE(PllSai1->PLLSAI1N));
  assert_param(IS_RCC_PLLSAI1CLOCKOUT_VALUE(PllSai1->PLLSAI1ClockOut));

  /* Check that PLLSAI1 clock source and divider M can be applied */
  if(__HAL_RCC_GET_PLL_OSCSOURCE() != RCC_PLLSOURCE_NONE)
 8004e66:	4b75      	ldr	r3, [pc, #468]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004e68:	68db      	ldr	r3, [r3, #12]
 8004e6a:	f003 0303 	and.w	r3, r3, #3
 8004e6e:	2b00      	cmp	r3, #0
 8004e70:	d018      	beq.n	8004ea4 <RCCEx_PLLSAI1_Config+0x4c>
  {
    /* PLL clock source and divider M already set, check that no request for change  */
    if((__HAL_RCC_GET_PLL_OSCSOURCE() != PllSai1->PLLSAI1Source)
 8004e72:	4b72      	ldr	r3, [pc, #456]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004e74:	68db      	ldr	r3, [r3, #12]
 8004e76:	f003 0203 	and.w	r2, r3, #3
 8004e7a:	687b      	ldr	r3, [r7, #4]
 8004e7c:	681b      	ldr	r3, [r3, #0]
 8004e7e:	429a      	cmp	r2, r3
 8004e80:	d10d      	bne.n	8004e9e <RCCEx_PLLSAI1_Config+0x46>
       ||
       (PllSai1->PLLSAI1Source == RCC_PLLSOURCE_NONE)
 8004e82:	687b      	ldr	r3, [r7, #4]
 8004e84:	681b      	ldr	r3, [r3, #0]
       ||
 8004e86:	2b00      	cmp	r3, #0
 8004e88:	d009      	beq.n	8004e9e <RCCEx_PLLSAI1_Config+0x46>
#if !defined(RCC_PLLSAI1M_DIV_1_16_SUPPORT)
       ||
       (((READ_BIT(RCC->PLLCFGR, RCC_PLLCFGR_PLLM) >> RCC_PLLCFGR_PLLM_Pos) + 1U) != PllSai1->PLLSAI1M)
 8004e8a:	4b6c      	ldr	r3, [pc, #432]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004e8c:	68db      	ldr	r3, [r3, #12]
 8004e8e:	091b      	lsrs	r3, r3, #4
 8004e90:	f003 0307 	and.w	r3, r3, #7
 8004e94:	1c5a      	adds	r2, r3, #1
 8004e96:	687b      	ldr	r3, [r7, #4]
 8004e98:	685b      	ldr	r3, [r3, #4]
       ||
 8004e9a:	429a      	cmp	r2, r3
 8004e9c:	d047      	beq.n	8004f2e <RCCEx_PLLSAI1_Config+0xd6>
#endif
      )
    {
      status = HAL_ERROR;
 8004e9e:	2301      	movs	r3, #1
 8004ea0:	73fb      	strb	r3, [r7, #15]
 8004ea2:	e044      	b.n	8004f2e <RCCEx_PLLSAI1_Config+0xd6>
    }
  }
  else
  {
    /* Check PLLSAI1 clock source availability */
    switch(PllSai1->PLLSAI1Source)
 8004ea4:	687b      	ldr	r3, [r7, #4]
 8004ea6:	681b      	ldr	r3, [r3, #0]
 8004ea8:	2b03      	cmp	r3, #3
 8004eaa:	d018      	beq.n	8004ede <RCCEx_PLLSAI1_Config+0x86>
 8004eac:	2b03      	cmp	r3, #3
 8004eae:	d825      	bhi.n	8004efc <RCCEx_PLLSAI1_Config+0xa4>
 8004eb0:	2b01      	cmp	r3, #1
 8004eb2:	d002      	beq.n	8004eba <RCCEx_PLLSAI1_Config+0x62>
 8004eb4:	2b02      	cmp	r3, #2
 8004eb6:	d009      	beq.n	8004ecc <RCCEx_PLLSAI1_Config+0x74>
 8004eb8:	e020      	b.n	8004efc <RCCEx_PLLSAI1_Config+0xa4>
    {
    case RCC_PLLSOURCE_MSI:
      if(HAL_IS_BIT_CLR(RCC->CR, RCC_CR_MSIRDY))
 8004eba:	4b60      	ldr	r3, [pc, #384]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004ebc:	681b      	ldr	r3, [r3, #0]
 8004ebe:	f003 0302 	and.w	r3, r3, #2
 8004ec2:	2b00      	cmp	r3, #0
 8004ec4:	d11d      	bne.n	8004f02 <RCCEx_PLLSAI1_Config+0xaa>
      {
        status = HAL_ERROR;
 8004ec6:	2301      	movs	r3, #1
 8004ec8:	73fb      	strb	r3, [r7, #15]
      }
      break;
 8004eca:	e01a      	b.n	8004f02 <RCCEx_PLLSAI1_Config+0xaa>
    case RCC_PLLSOURCE_HSI:
      if(HAL_IS_BIT_CLR(RCC->CR, RCC_CR_HSIRDY))
 8004ecc:	4b5b      	ldr	r3, [pc, #364]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004ece:	681b      	ldr	r3, [r3, #0]
 8004ed0:	f403 6380 	and.w	r3, r3, #1024	; 0x400
 8004ed4:	2b00      	cmp	r3, #0
 8004ed6:	d116      	bne.n	8004f06 <RCCEx_PLLSAI1_Config+0xae>
      {
        status = HAL_ERROR;
 8004ed8:	2301      	movs	r3, #1
 8004eda:	73fb      	strb	r3, [r7, #15]
      }
      break;
 8004edc:	e013      	b.n	8004f06 <RCCEx_PLLSAI1_Config+0xae>
    case RCC_PLLSOURCE_HSE:
      if(HAL_IS_BIT_CLR(RCC->CR, RCC_CR_HSERDY))
 8004ede:	4b57      	ldr	r3, [pc, #348]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004ee0:	681b      	ldr	r3, [r3, #0]
 8004ee2:	f403 3300 	and.w	r3, r3, #131072	; 0x20000
 8004ee6:	2b00      	cmp	r3, #0
 8004ee8:	d10f      	bne.n	8004f0a <RCCEx_PLLSAI1_Config+0xb2>
      {
        if(HAL_IS_BIT_CLR(RCC->CR, RCC_CR_HSEBYP))
 8004eea:	4b54      	ldr	r3, [pc, #336]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004eec:	681b      	ldr	r3, [r3, #0]
 8004eee:	f403 2380 	and.w	r3, r3, #262144	; 0x40000
 8004ef2:	2b00      	cmp	r3, #0
 8004ef4:	d109      	bne.n	8004f0a <RCCEx_PLLSAI1_Config+0xb2>
        {
          status = HAL_ERROR;
 8004ef6:	2301      	movs	r3, #1
 8004ef8:	73fb      	strb	r3, [r7, #15]
        }
      }
      break;
 8004efa:	e006      	b.n	8004f0a <RCCEx_PLLSAI1_Config+0xb2>
    default:
      status = HAL_ERROR;
 8004efc:	2301      	movs	r3, #1
 8004efe:	73fb      	strb	r3, [r7, #15]
      break;
 8004f00:	e004      	b.n	8004f0c <RCCEx_PLLSAI1_Config+0xb4>
      break;
 8004f02:	bf00      	nop
 8004f04:	e002      	b.n	8004f0c <RCCEx_PLLSAI1_Config+0xb4>
      break;
 8004f06:	bf00      	nop
 8004f08:	e000      	b.n	8004f0c <RCCEx_PLLSAI1_Config+0xb4>
      break;
 8004f0a:	bf00      	nop
    }

    if(status == HAL_OK)
 8004f0c:	7bfb      	ldrb	r3, [r7, #15]
 8004f0e:	2b00      	cmp	r3, #0
 8004f10:	d10d      	bne.n	8004f2e <RCCEx_PLLSAI1_Config+0xd6>
#if defined(RCC_PLLSAI1M_DIV_1_16_SUPPORT)
      /* Set PLLSAI1 clock source */
      MODIFY_REG(RCC->PLLCFGR, RCC_PLLCFGR_PLLSRC, PllSai1->PLLSAI1Source);
#else
      /* Set PLLSAI1 clock source and divider M */
      MODIFY_REG(RCC->PLLCFGR, RCC_PLLCFGR_PLLSRC | RCC_PLLCFGR_PLLM, PllSai1->PLLSAI1Source | (PllSai1->PLLSAI1M - 1U) << RCC_PLLCFGR_PLLM_Pos);
 8004f12:	4b4a      	ldr	r3, [pc, #296]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004f14:	68db      	ldr	r3, [r3, #12]
 8004f16:	f023 0273 	bic.w	r2, r3, #115	; 0x73
 8004f1a:	687b      	ldr	r3, [r7, #4]
 8004f1c:	6819      	ldr	r1, [r3, #0]
 8004f1e:	687b      	ldr	r3, [r7, #4]
 8004f20:	685b      	ldr	r3, [r3, #4]
 8004f22:	3b01      	subs	r3, #1
 8004f24:	011b      	lsls	r3, r3, #4
 8004f26:	430b      	orrs	r3, r1
 8004f28:	4944      	ldr	r1, [pc, #272]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004f2a:	4313      	orrs	r3, r2
 8004f2c:	60cb      	str	r3, [r1, #12]
#endif
    }
  }

  if(status == HAL_OK)
 8004f2e:	7bfb      	ldrb	r3, [r7, #15]
 8004f30:	2b00      	cmp	r3, #0
 8004f32:	d17d      	bne.n	8005030 <RCCEx_PLLSAI1_Config+0x1d8>
  {
    /* Disable the PLLSAI1 */
    __HAL_RCC_PLLSAI1_DISABLE();
 8004f34:	4b41      	ldr	r3, [pc, #260]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004f36:	681b      	ldr	r3, [r3, #0]
 8004f38:	4a40      	ldr	r2, [pc, #256]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004f3a:	f023 6380 	bic.w	r3, r3, #67108864	; 0x4000000
 8004f3e:	6013      	str	r3, [r2, #0]

    /* Get Start Tick*/
    tickstart = HAL_GetTick();
 8004f40:	f7fd f850 	bl	8001fe4 <HAL_GetTick>
 8004f44:	60b8      	str	r0, [r7, #8]

    /* Wait till PLLSAI1 is ready to be updated */
    while(READ_BIT(RCC->CR, RCC_CR_PLLSAI1RDY) != 0U)
 8004f46:	e009      	b.n	8004f5c <RCCEx_PLLSAI1_Config+0x104>
    {
      if((HAL_GetTick() - tickstart) > PLLSAI1_TIMEOUT_VALUE)
 8004f48:	f7fd f84c 	bl	8001fe4 <HAL_GetTick>
 8004f4c:	4602      	mov	r2, r0
 8004f4e:	68bb      	ldr	r3, [r7, #8]
 8004f50:	1ad3      	subs	r3, r2, r3
 8004f52:	2b02      	cmp	r3, #2
 8004f54:	d902      	bls.n	8004f5c <RCCEx_PLLSAI1_Config+0x104>
      {
        status = HAL_TIMEOUT;
 8004f56:	2303      	movs	r3, #3
 8004f58:	73fb      	strb	r3, [r7, #15]
        break;
 8004f5a:	e005      	b.n	8004f68 <RCCEx_PLLSAI1_Config+0x110>
    while(READ_BIT(RCC->CR, RCC_CR_PLLSAI1RDY) != 0U)
 8004f5c:	4b37      	ldr	r3, [pc, #220]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004f5e:	681b      	ldr	r3, [r3, #0]
 8004f60:	f003 6300 	and.w	r3, r3, #134217728	; 0x8000000
 8004f64:	2b00      	cmp	r3, #0
 8004f66:	d1ef      	bne.n	8004f48 <RCCEx_PLLSAI1_Config+0xf0>
      }
    }

    if(status == HAL_OK)
 8004f68:	7bfb      	ldrb	r3, [r7, #15]
 8004f6a:	2b00      	cmp	r3, #0
 8004f6c:	d160      	bne.n	8005030 <RCCEx_PLLSAI1_Config+0x1d8>
    {
      if(Divider == DIVIDER_P_UPDATE)
 8004f6e:	683b      	ldr	r3, [r7, #0]
 8004f70:	2b00      	cmp	r3, #0
 8004f72:	d111      	bne.n	8004f98 <RCCEx_PLLSAI1_Config+0x140>
        MODIFY_REG(RCC->PLLSAI1CFGR,
                   RCC_PLLSAI1CFGR_PLLSAI1N | RCC_PLLSAI1CFGR_PLLSAI1PDIV,
                   (PllSai1->PLLSAI1N << RCC_PLLSAI1CFGR_PLLSAI1N_Pos) |
                   (PllSai1->PLLSAI1P << RCC_PLLSAI1CFGR_PLLSAI1PDIV_Pos));
#else
        MODIFY_REG(RCC->PLLSAI1CFGR,
 8004f74:	4b31      	ldr	r3, [pc, #196]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004f76:	691b      	ldr	r3, [r3, #16]
 8004f78:	f423 331f 	bic.w	r3, r3, #162816	; 0x27c00
 8004f7c:	f423 7340 	bic.w	r3, r3, #768	; 0x300
 8004f80:	687a      	ldr	r2, [r7, #4]
 8004f82:	6892      	ldr	r2, [r2, #8]
 8004f84:	0211      	lsls	r1, r2, #8
 8004f86:	687a      	ldr	r2, [r7, #4]
 8004f88:	68d2      	ldr	r2, [r2, #12]
 8004f8a:	0912      	lsrs	r2, r2, #4
 8004f8c:	0452      	lsls	r2, r2, #17
 8004f8e:	430a      	orrs	r2, r1
 8004f90:	492a      	ldr	r1, [pc, #168]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004f92:	4313      	orrs	r3, r2
 8004f94:	610b      	str	r3, [r1, #16]
 8004f96:	e027      	b.n	8004fe8 <RCCEx_PLLSAI1_Config+0x190>
                   ((PllSai1->PLLSAI1P >> 4U) << RCC_PLLSAI1CFGR_PLLSAI1P_Pos));
#endif /* RCC_PLLSAI1P_DIV_2_31_SUPPORT */

#endif /* RCC_PLLSAI1M_DIV_1_16_SUPPORT */
      }
      else if(Divider == DIVIDER_Q_UPDATE)
 8004f98:	683b      	ldr	r3, [r7, #0]
 8004f9a:	2b01      	cmp	r3, #1
 8004f9c:	d112      	bne.n	8004fc4 <RCCEx_PLLSAI1_Config+0x16c>
                   (PllSai1->PLLSAI1N << RCC_PLLSAI1CFGR_PLLSAI1N_Pos) |
                   (((PllSai1->PLLSAI1Q >> 1U) - 1U) << RCC_PLLSAI1CFGR_PLLSAI1Q_Pos) |
                   ((PllSai1->PLLSAI1M - 1U) << RCC_PLLSAI1CFGR_PLLSAI1M_Pos));
#else
        /* Configure the PLLSAI1 Division factor Q and Multiplication factor N*/
        MODIFY_REG(RCC->PLLSAI1CFGR,
 8004f9e:	4b27      	ldr	r3, [pc, #156]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004fa0:	691b      	ldr	r3, [r3, #16]
 8004fa2:	f423 03c0 	bic.w	r3, r3, #6291456	; 0x600000
 8004fa6:	f423 43fe 	bic.w	r3, r3, #32512	; 0x7f00
 8004faa:	687a      	ldr	r2, [r7, #4]
 8004fac:	6892      	ldr	r2, [r2, #8]
 8004fae:	0211      	lsls	r1, r2, #8
 8004fb0:	687a      	ldr	r2, [r7, #4]
 8004fb2:	6912      	ldr	r2, [r2, #16]
 8004fb4:	0852      	lsrs	r2, r2, #1
 8004fb6:	3a01      	subs	r2, #1
 8004fb8:	0552      	lsls	r2, r2, #21
 8004fba:	430a      	orrs	r2, r1
 8004fbc:	491f      	ldr	r1, [pc, #124]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004fbe:	4313      	orrs	r3, r2
 8004fc0:	610b      	str	r3, [r1, #16]
 8004fc2:	e011      	b.n	8004fe8 <RCCEx_PLLSAI1_Config+0x190>
                   (PllSai1->PLLSAI1N << RCC_PLLSAI1CFGR_PLLSAI1N_Pos) |
                   (((PllSai1->PLLSAI1R >> 1U) - 1U) << RCC_PLLSAI1CFGR_PLLSAI1R_Pos) |
                   ((PllSai1->PLLSAI1M - 1U) << RCC_PLLSAI1CFGR_PLLSAI1M_Pos));
#else
        /* Configure the PLLSAI1 Division factor R and Multiplication factor N*/
        MODIFY_REG(RCC->PLLSAI1CFGR,
 8004fc4:	4b1d      	ldr	r3, [pc, #116]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004fc6:	691b      	ldr	r3, [r3, #16]
 8004fc8:	f023 63c0 	bic.w	r3, r3, #100663296	; 0x6000000
 8004fcc:	f423 43fe 	bic.w	r3, r3, #32512	; 0x7f00
 8004fd0:	687a      	ldr	r2, [r7, #4]
 8004fd2:	6892      	ldr	r2, [r2, #8]
 8004fd4:	0211      	lsls	r1, r2, #8
 8004fd6:	687a      	ldr	r2, [r7, #4]
 8004fd8:	6952      	ldr	r2, [r2, #20]
 8004fda:	0852      	lsrs	r2, r2, #1
 8004fdc:	3a01      	subs	r2, #1
 8004fde:	0652      	lsls	r2, r2, #25
 8004fe0:	430a      	orrs	r2, r1
 8004fe2:	4916      	ldr	r1, [pc, #88]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004fe4:	4313      	orrs	r3, r2
 8004fe6:	610b      	str	r3, [r1, #16]
                   (((PllSai1->PLLSAI1R >> 1U) - 1U) << RCC_PLLSAI1CFGR_PLLSAI1R_Pos));
#endif /* RCC_PLLSAI1M_DIV_1_16_SUPPORT */
      }

      /* Enable the PLLSAI1 again by setting PLLSAI1ON to 1*/
      __HAL_RCC_PLLSAI1_ENABLE();
 8004fe8:	4b14      	ldr	r3, [pc, #80]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004fea:	681b      	ldr	r3, [r3, #0]
 8004fec:	4a13      	ldr	r2, [pc, #76]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8004fee:	f043 6380 	orr.w	r3, r3, #67108864	; 0x4000000
 8004ff2:	6013      	str	r3, [r2, #0]

      /* Get Start Tick*/
      tickstart = HAL_GetTick();
 8004ff4:	f7fc fff6 	bl	8001fe4 <HAL_GetTick>
 8004ff8:	60b8      	str	r0, [r7, #8]

      /* Wait till PLLSAI1 is ready */
      while(READ_BIT(RCC->CR, RCC_CR_PLLSAI1RDY) == 0U)
 8004ffa:	e009      	b.n	8005010 <RCCEx_PLLSAI1_Config+0x1b8>
      {
        if((HAL_GetTick() - tickstart) > PLLSAI1_TIMEOUT_VALUE)
 8004ffc:	f7fc fff2 	bl	8001fe4 <HAL_GetTick>
 8005000:	4602      	mov	r2, r0
 8005002:	68bb      	ldr	r3, [r7, #8]
 8005004:	1ad3      	subs	r3, r2, r3
 8005006:	2b02      	cmp	r3, #2
 8005008:	d902      	bls.n	8005010 <RCCEx_PLLSAI1_Config+0x1b8>
        {
          status = HAL_TIMEOUT;
 800500a:	2303      	movs	r3, #3
 800500c:	73fb      	strb	r3, [r7, #15]
          break;
 800500e:	e005      	b.n	800501c <RCCEx_PLLSAI1_Config+0x1c4>
      while(READ_BIT(RCC->CR, RCC_CR_PLLSAI1RDY) == 0U)
 8005010:	4b0a      	ldr	r3, [pc, #40]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8005012:	681b      	ldr	r3, [r3, #0]
 8005014:	f003 6300 	and.w	r3, r3, #134217728	; 0x8000000
 8005018:	2b00      	cmp	r3, #0
 800501a:	d0ef      	beq.n	8004ffc <RCCEx_PLLSAI1_Config+0x1a4>
        }
      }

      if(status == HAL_OK)
 800501c:	7bfb      	ldrb	r3, [r7, #15]
 800501e:	2b00      	cmp	r3, #0
 8005020:	d106      	bne.n	8005030 <RCCEx_PLLSAI1_Config+0x1d8>
      {
        /* Configure the PLLSAI1 Clock output(s) */
        __HAL_RCC_PLLSAI1CLKOUT_ENABLE(PllSai1->PLLSAI1ClockOut);
 8005022:	4b06      	ldr	r3, [pc, #24]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 8005024:	691a      	ldr	r2, [r3, #16]
 8005026:	687b      	ldr	r3, [r7, #4]
 8005028:	699b      	ldr	r3, [r3, #24]
 800502a:	4904      	ldr	r1, [pc, #16]	; (800503c <RCCEx_PLLSAI1_Config+0x1e4>)
 800502c:	4313      	orrs	r3, r2
 800502e:	610b      	str	r3, [r1, #16]
      }
    }
  }

  return status;
 8005030:	7bfb      	ldrb	r3, [r7, #15]
}
 8005032:	4618      	mov	r0, r3
 8005034:	3710      	adds	r7, #16
 8005036:	46bd      	mov	sp, r7
 8005038:	bd80      	pop	{r7, pc}
 800503a:	bf00      	nop
 800503c:	40021000 	.word	0x40021000

08005040 <RCCEx_PLLSAI2_Config>:
  * @note   PLLSAI2 is temporary disable to apply new parameters
  *
  * @retval HAL status
  */
static HAL_StatusTypeDef RCCEx_PLLSAI2_Config(RCC_PLLSAI2InitTypeDef *PllSai2, uint32_t Divider)
{
 8005040:	b580      	push	{r7, lr}
 8005042:	b084      	sub	sp, #16
 8005044:	af00      	add	r7, sp, #0
 8005046:	6078      	str	r0, [r7, #4]
 8005048:	6039      	str	r1, [r7, #0]
  uint32_t tickstart;
  HAL_StatusTypeDef status = HAL_OK;
 800504a:	2300      	movs	r3, #0
 800504c:	73fb      	strb	r3, [r7, #15]
  assert_param(IS_RCC_PLLSAI2M_VALUE(PllSai2->PLLSAI2M));
  assert_param(IS_RCC_PLLSAI2N_VALUE(PllSai2->PLLSAI2N));
  assert_param(IS_RCC_PLLSAI2CLOCKOUT_VALUE(PllSai2->PLLSAI2ClockOut));

  /* Check that PLLSAI2 clock source and divider M can be applied */
  if(__HAL_RCC_GET_PLL_OSCSOURCE() != RCC_PLLSOURCE_NONE)
 800504e:	4b6a      	ldr	r3, [pc, #424]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 8005050:	68db      	ldr	r3, [r3, #12]
 8005052:	f003 0303 	and.w	r3, r3, #3
 8005056:	2b00      	cmp	r3, #0
 8005058:	d018      	beq.n	800508c <RCCEx_PLLSAI2_Config+0x4c>
  {
    /* PLL clock source and divider M already set, check that no request for change  */
    if((__HAL_RCC_GET_PLL_OSCSOURCE() != PllSai2->PLLSAI2Source)
 800505a:	4b67      	ldr	r3, [pc, #412]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 800505c:	68db      	ldr	r3, [r3, #12]
 800505e:	f003 0203 	and.w	r2, r3, #3
 8005062:	687b      	ldr	r3, [r7, #4]
 8005064:	681b      	ldr	r3, [r3, #0]
 8005066:	429a      	cmp	r2, r3
 8005068:	d10d      	bne.n	8005086 <RCCEx_PLLSAI2_Config+0x46>
       ||
       (PllSai2->PLLSAI2Source == RCC_PLLSOURCE_NONE)
 800506a:	687b      	ldr	r3, [r7, #4]
 800506c:	681b      	ldr	r3, [r3, #0]
       ||
 800506e:	2b00      	cmp	r3, #0
 8005070:	d009      	beq.n	8005086 <RCCEx_PLLSAI2_Config+0x46>
#if !defined(RCC_PLLSAI2M_DIV_1_16_SUPPORT)
       ||
       (((READ_BIT(RCC->PLLCFGR, RCC_PLLCFGR_PLLM) >> RCC_PLLCFGR_PLLM_Pos) + 1U) != PllSai2->PLLSAI2M)
 8005072:	4b61      	ldr	r3, [pc, #388]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 8005074:	68db      	ldr	r3, [r3, #12]
 8005076:	091b      	lsrs	r3, r3, #4
 8005078:	f003 0307 	and.w	r3, r3, #7
 800507c:	1c5a      	adds	r2, r3, #1
 800507e:	687b      	ldr	r3, [r7, #4]
 8005080:	685b      	ldr	r3, [r3, #4]
       ||
 8005082:	429a      	cmp	r2, r3
 8005084:	d047      	beq.n	8005116 <RCCEx_PLLSAI2_Config+0xd6>
#endif
      )
    {
      status = HAL_ERROR;
 8005086:	2301      	movs	r3, #1
 8005088:	73fb      	strb	r3, [r7, #15]
 800508a:	e044      	b.n	8005116 <RCCEx_PLLSAI2_Config+0xd6>
    }
  }
  else
  {
    /* Check PLLSAI2 clock source availability */
    switch(PllSai2->PLLSAI2Source)
 800508c:	687b      	ldr	r3, [r7, #4]
 800508e:	681b      	ldr	r3, [r3, #0]
 8005090:	2b03      	cmp	r3, #3
 8005092:	d018      	beq.n	80050c6 <RCCEx_PLLSAI2_Config+0x86>
 8005094:	2b03      	cmp	r3, #3
 8005096:	d825      	bhi.n	80050e4 <RCCEx_PLLSAI2_Config+0xa4>
 8005098:	2b01      	cmp	r3, #1
 800509a:	d002      	beq.n	80050a2 <RCCEx_PLLSAI2_Config+0x62>
 800509c:	2b02      	cmp	r3, #2
 800509e:	d009      	beq.n	80050b4 <RCCEx_PLLSAI2_Config+0x74>
 80050a0:	e020      	b.n	80050e4 <RCCEx_PLLSAI2_Config+0xa4>
    {
    case RCC_PLLSOURCE_MSI:
      if(HAL_IS_BIT_CLR(RCC->CR, RCC_CR_MSIRDY))
 80050a2:	4b55      	ldr	r3, [pc, #340]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 80050a4:	681b      	ldr	r3, [r3, #0]
 80050a6:	f003 0302 	and.w	r3, r3, #2
 80050aa:	2b00      	cmp	r3, #0
 80050ac:	d11d      	bne.n	80050ea <RCCEx_PLLSAI2_Config+0xaa>
      {
        status = HAL_ERROR;
 80050ae:	2301      	movs	r3, #1
 80050b0:	73fb      	strb	r3, [r7, #15]
      }
      break;
 80050b2:	e01a      	b.n	80050ea <RCCEx_PLLSAI2_Config+0xaa>
    case RCC_PLLSOURCE_HSI:
      if(HAL_IS_BIT_CLR(RCC->CR, RCC_CR_HSIRDY))
 80050b4:	4b50      	ldr	r3, [pc, #320]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 80050b6:	681b      	ldr	r3, [r3, #0]
 80050b8:	f403 6380 	and.w	r3, r3, #1024	; 0x400
 80050bc:	2b00      	cmp	r3, #0
 80050be:	d116      	bne.n	80050ee <RCCEx_PLLSAI2_Config+0xae>
      {
        status = HAL_ERROR;
 80050c0:	2301      	movs	r3, #1
 80050c2:	73fb      	strb	r3, [r7, #15]
      }
      break;
 80050c4:	e013      	b.n	80050ee <RCCEx_PLLSAI2_Config+0xae>
    case RCC_PLLSOURCE_HSE:
      if(HAL_IS_BIT_CLR(RCC->CR, RCC_CR_HSERDY))
 80050c6:	4b4c      	ldr	r3, [pc, #304]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 80050c8:	681b      	ldr	r3, [r3, #0]
 80050ca:	f403 3300 	and.w	r3, r3, #131072	; 0x20000
 80050ce:	2b00      	cmp	r3, #0
 80050d0:	d10f      	bne.n	80050f2 <RCCEx_PLLSAI2_Config+0xb2>
      {
        if(HAL_IS_BIT_CLR(RCC->CR, RCC_CR_HSEBYP))
 80050d2:	4b49      	ldr	r3, [pc, #292]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 80050d4:	681b      	ldr	r3, [r3, #0]
 80050d6:	f403 2380 	and.w	r3, r3, #262144	; 0x40000
 80050da:	2b00      	cmp	r3, #0
 80050dc:	d109      	bne.n	80050f2 <RCCEx_PLLSAI2_Config+0xb2>
        {
          status = HAL_ERROR;
 80050de:	2301      	movs	r3, #1
 80050e0:	73fb      	strb	r3, [r7, #15]
        }
      }
      break;
 80050e2:	e006      	b.n	80050f2 <RCCEx_PLLSAI2_Config+0xb2>
    default:
      status = HAL_ERROR;
 80050e4:	2301      	movs	r3, #1
 80050e6:	73fb      	strb	r3, [r7, #15]
      break;
 80050e8:	e004      	b.n	80050f4 <RCCEx_PLLSAI2_Config+0xb4>
      break;
 80050ea:	bf00      	nop
 80050ec:	e002      	b.n	80050f4 <RCCEx_PLLSAI2_Config+0xb4>
      break;
 80050ee:	bf00      	nop
 80050f0:	e000      	b.n	80050f4 <RCCEx_PLLSAI2_Config+0xb4>
      break;
 80050f2:	bf00      	nop
    }

    if(status == HAL_OK)
 80050f4:	7bfb      	ldrb	r3, [r7, #15]
 80050f6:	2b00      	cmp	r3, #0
 80050f8:	d10d      	bne.n	8005116 <RCCEx_PLLSAI2_Config+0xd6>
#if defined(RCC_PLLSAI2M_DIV_1_16_SUPPORT)
      /* Set PLLSAI2 clock source */
      MODIFY_REG(RCC->PLLCFGR, RCC_PLLCFGR_PLLSRC, PllSai2->PLLSAI2Source);
#else
      /* Set PLLSAI2 clock source and divider M */
      MODIFY_REG(RCC->PLLCFGR, RCC_PLLCFGR_PLLSRC | RCC_PLLCFGR_PLLM, PllSai2->PLLSAI2Source | (PllSai2->PLLSAI2M - 1U) << RCC_PLLCFGR_PLLM_Pos);
 80050fa:	4b3f      	ldr	r3, [pc, #252]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 80050fc:	68db      	ldr	r3, [r3, #12]
 80050fe:	f023 0273 	bic.w	r2, r3, #115	; 0x73
 8005102:	687b      	ldr	r3, [r7, #4]
 8005104:	6819      	ldr	r1, [r3, #0]
 8005106:	687b      	ldr	r3, [r7, #4]
 8005108:	685b      	ldr	r3, [r3, #4]
 800510a:	3b01      	subs	r3, #1
 800510c:	011b      	lsls	r3, r3, #4
 800510e:	430b      	orrs	r3, r1
 8005110:	4939      	ldr	r1, [pc, #228]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 8005112:	4313      	orrs	r3, r2
 8005114:	60cb      	str	r3, [r1, #12]
#endif
    }
  }

  if(status == HAL_OK)
 8005116:	7bfb      	ldrb	r3, [r7, #15]
 8005118:	2b00      	cmp	r3, #0
 800511a:	d167      	bne.n	80051ec <RCCEx_PLLSAI2_Config+0x1ac>
  {
    /* Disable the PLLSAI2 */
    __HAL_RCC_PLLSAI2_DISABLE();
 800511c:	4b36      	ldr	r3, [pc, #216]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 800511e:	681b      	ldr	r3, [r3, #0]
 8005120:	4a35      	ldr	r2, [pc, #212]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 8005122:	f023 5380 	bic.w	r3, r3, #268435456	; 0x10000000
 8005126:	6013      	str	r3, [r2, #0]

    /* Get Start Tick*/
    tickstart = HAL_GetTick();
 8005128:	f7fc ff5c 	bl	8001fe4 <HAL_GetTick>
 800512c:	60b8      	str	r0, [r7, #8]

    /* Wait till PLLSAI2 is ready to be updated */
    while(READ_BIT(RCC->CR, RCC_CR_PLLSAI2RDY) != 0U)
 800512e:	e009      	b.n	8005144 <RCCEx_PLLSAI2_Config+0x104>
    {
      if((HAL_GetTick() - tickstart) > PLLSAI2_TIMEOUT_VALUE)
 8005130:	f7fc ff58 	bl	8001fe4 <HAL_GetTick>
 8005134:	4602      	mov	r2, r0
 8005136:	68bb      	ldr	r3, [r7, #8]
 8005138:	1ad3      	subs	r3, r2, r3
 800513a:	2b02      	cmp	r3, #2
 800513c:	d902      	bls.n	8005144 <RCCEx_PLLSAI2_Config+0x104>
      {
        status = HAL_TIMEOUT;
 800513e:	2303      	movs	r3, #3
 8005140:	73fb      	strb	r3, [r7, #15]
        break;
 8005142:	e005      	b.n	8005150 <RCCEx_PLLSAI2_Config+0x110>
    while(READ_BIT(RCC->CR, RCC_CR_PLLSAI2RDY) != 0U)
 8005144:	4b2c      	ldr	r3, [pc, #176]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 8005146:	681b      	ldr	r3, [r3, #0]
 8005148:	f003 5300 	and.w	r3, r3, #536870912	; 0x20000000
 800514c:	2b00      	cmp	r3, #0
 800514e:	d1ef      	bne.n	8005130 <RCCEx_PLLSAI2_Config+0xf0>
      }
    }

    if(status == HAL_OK)
 8005150:	7bfb      	ldrb	r3, [r7, #15]
 8005152:	2b00      	cmp	r3, #0
 8005154:	d14a      	bne.n	80051ec <RCCEx_PLLSAI2_Config+0x1ac>
    {
      if(Divider == DIVIDER_P_UPDATE)
 8005156:	683b      	ldr	r3, [r7, #0]
 8005158:	2b00      	cmp	r3, #0
 800515a:	d111      	bne.n	8005180 <RCCEx_PLLSAI2_Config+0x140>
        MODIFY_REG(RCC->PLLSAI2CFGR,
                   RCC_PLLSAI2CFGR_PLLSAI2N | RCC_PLLSAI2CFGR_PLLSAI2PDIV,
                   (PllSai2->PLLSAI2N << RCC_PLLSAI2CFGR_PLLSAI2N_Pos) |
                   (PllSai2->PLLSAI2P << RCC_PLLSAI2CFGR_PLLSAI2PDIV_Pos));
#else
        MODIFY_REG(RCC->PLLSAI2CFGR,
 800515c:	4b26      	ldr	r3, [pc, #152]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 800515e:	695b      	ldr	r3, [r3, #20]
 8005160:	f423 331f 	bic.w	r3, r3, #162816	; 0x27c00
 8005164:	f423 7340 	bic.w	r3, r3, #768	; 0x300
 8005168:	687a      	ldr	r2, [r7, #4]
 800516a:	6892      	ldr	r2, [r2, #8]
 800516c:	0211      	lsls	r1, r2, #8
 800516e:	687a      	ldr	r2, [r7, #4]
 8005170:	68d2      	ldr	r2, [r2, #12]
 8005172:	0912      	lsrs	r2, r2, #4
 8005174:	0452      	lsls	r2, r2, #17
 8005176:	430a      	orrs	r2, r1
 8005178:	491f      	ldr	r1, [pc, #124]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 800517a:	4313      	orrs	r3, r2
 800517c:	614b      	str	r3, [r1, #20]
 800517e:	e011      	b.n	80051a4 <RCCEx_PLLSAI2_Config+0x164>
                   (PllSai2->PLLSAI2N << RCC_PLLSAI2CFGR_PLLSAI2N_Pos) |
                   (((PllSai2->PLLSAI2R >> 1U) - 1U) << RCC_PLLSAI2CFGR_PLLSAI2R_Pos) |
                   ((PllSai2->PLLSAI2M - 1U) << RCC_PLLSAI2CFGR_PLLSAI2M_Pos));
#else
        /* Configure the PLLSAI2 Division factor R and Multiplication factor N*/
        MODIFY_REG(RCC->PLLSAI2CFGR,
 8005180:	4b1d      	ldr	r3, [pc, #116]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 8005182:	695b      	ldr	r3, [r3, #20]
 8005184:	f023 63c0 	bic.w	r3, r3, #100663296	; 0x6000000
 8005188:	f423 43fe 	bic.w	r3, r3, #32512	; 0x7f00
 800518c:	687a      	ldr	r2, [r7, #4]
 800518e:	6892      	ldr	r2, [r2, #8]
 8005190:	0211      	lsls	r1, r2, #8
 8005192:	687a      	ldr	r2, [r7, #4]
 8005194:	6912      	ldr	r2, [r2, #16]
 8005196:	0852      	lsrs	r2, r2, #1
 8005198:	3a01      	subs	r2, #1
 800519a:	0652      	lsls	r2, r2, #25
 800519c:	430a      	orrs	r2, r1
 800519e:	4916      	ldr	r1, [pc, #88]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 80051a0:	4313      	orrs	r3, r2
 80051a2:	614b      	str	r3, [r1, #20]
                   (((PllSai2->PLLSAI2R >> 1U) - 1U) << RCC_PLLSAI2CFGR_PLLSAI2R_Pos));
#endif /* RCC_PLLSAI2M_DIV_1_16_SUPPORT */
      }

      /* Enable the PLLSAI2 again by setting PLLSAI2ON to 1*/
      __HAL_RCC_PLLSAI2_ENABLE();
 80051a4:	4b14      	ldr	r3, [pc, #80]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 80051a6:	681b      	ldr	r3, [r3, #0]
 80051a8:	4a13      	ldr	r2, [pc, #76]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 80051aa:	f043 5380 	orr.w	r3, r3, #268435456	; 0x10000000
 80051ae:	6013      	str	r3, [r2, #0]

      /* Get Start Tick*/
      tickstart = HAL_GetTick();
 80051b0:	f7fc ff18 	bl	8001fe4 <HAL_GetTick>
 80051b4:	60b8      	str	r0, [r7, #8]

      /* Wait till PLLSAI2 is ready */
      while(READ_BIT(RCC->CR, RCC_CR_PLLSAI2RDY) == 0U)
 80051b6:	e009      	b.n	80051cc <RCCEx_PLLSAI2_Config+0x18c>
      {
        if((HAL_GetTick() - tickstart) > PLLSAI2_TIMEOUT_VALUE)
 80051b8:	f7fc ff14 	bl	8001fe4 <HAL_GetTick>
 80051bc:	4602      	mov	r2, r0
 80051be:	68bb      	ldr	r3, [r7, #8]
 80051c0:	1ad3      	subs	r3, r2, r3
 80051c2:	2b02      	cmp	r3, #2
 80051c4:	d902      	bls.n	80051cc <RCCEx_PLLSAI2_Config+0x18c>
        {
          status = HAL_TIMEOUT;
 80051c6:	2303      	movs	r3, #3
 80051c8:	73fb      	strb	r3, [r7, #15]
          break;
 80051ca:	e005      	b.n	80051d8 <RCCEx_PLLSAI2_Config+0x198>
      while(READ_BIT(RCC->CR, RCC_CR_PLLSAI2RDY) == 0U)
 80051cc:	4b0a      	ldr	r3, [pc, #40]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 80051ce:	681b      	ldr	r3, [r3, #0]
 80051d0:	f003 5300 	and.w	r3, r3, #536870912	; 0x20000000
 80051d4:	2b00      	cmp	r3, #0
 80051d6:	d0ef      	beq.n	80051b8 <RCCEx_PLLSAI2_Config+0x178>
        }
      }

      if(status == HAL_OK)
 80051d8:	7bfb      	ldrb	r3, [r7, #15]
 80051da:	2b00      	cmp	r3, #0
 80051dc:	d106      	bne.n	80051ec <RCCEx_PLLSAI2_Config+0x1ac>
      {
        /* Configure the PLLSAI2 Clock output(s) */
        __HAL_RCC_PLLSAI2CLKOUT_ENABLE(PllSai2->PLLSAI2ClockOut);
 80051de:	4b06      	ldr	r3, [pc, #24]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 80051e0:	695a      	ldr	r2, [r3, #20]
 80051e2:	687b      	ldr	r3, [r7, #4]
 80051e4:	695b      	ldr	r3, [r3, #20]
 80051e6:	4904      	ldr	r1, [pc, #16]	; (80051f8 <RCCEx_PLLSAI2_Config+0x1b8>)
 80051e8:	4313      	orrs	r3, r2
 80051ea:	614b      	str	r3, [r1, #20]
      }
    }
  }

  return status;
 80051ec:	7bfb      	ldrb	r3, [r7, #15]
}
 80051ee:	4618      	mov	r0, r3
 80051f0:	3710      	adds	r7, #16
 80051f2:	46bd      	mov	sp, r7
 80051f4:	bd80      	pop	{r7, pc}
 80051f6:	bf00      	nop
 80051f8:	40021000 	.word	0x40021000

080051fc <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)
{
 80051fc:	b580      	push	{r7, lr}
 80051fe:	b082      	sub	sp, #8
 8005200:	af00      	add	r7, sp, #0
 8005202:	6078      	str	r0, [r7, #4]
  /* Check the TIM handle allocation */
  if (htim == NULL)
 8005204:	687b      	ldr	r3, [r7, #4]
 8005206:	2b00      	cmp	r3, #0
 8005208:	d101      	bne.n	800520e <HAL_TIM_Base_Init+0x12>
  {
    return HAL_ERROR;
 800520a:	2301      	movs	r3, #1
 800520c:	e049      	b.n	80052a2 <HAL_TIM_Base_Init+0xa6>
  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)
 800520e:	687b      	ldr	r3, [r7, #4]
 8005210:	f893 303d 	ldrb.w	r3, [r3, #61]	; 0x3d
 8005214:	b2db      	uxtb	r3, r3
 8005216:	2b00      	cmp	r3, #0
 8005218:	d106      	bne.n	8005228 <HAL_TIM_Base_Init+0x2c>
  {
    /* Allocate lock resource and initialize it */
    htim->Lock = HAL_UNLOCKED;
 800521a:	687b      	ldr	r3, [r7, #4]
 800521c:	2200      	movs	r2, #0
 800521e:	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);
 8005222:	6878      	ldr	r0, [r7, #4]
 8005224:	f7fc fd6a 	bl	8001cfc <HAL_TIM_Base_MspInit>
#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */
  }

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

  /* Set the Time Base configuration */
  TIM_Base_SetConfig(htim->Instance, &htim->Init);
 8005230:	687b      	ldr	r3, [r7, #4]
 8005232:	681a      	ldr	r2, [r3, #0]
 8005234:	687b      	ldr	r3, [r7, #4]
 8005236:	3304      	adds	r3, #4
 8005238:	4619      	mov	r1, r3
 800523a:	4610      	mov	r0, r2
 800523c:	f000 f8fe 	bl	800543c <TIM_Base_SetConfig>

  /* Initialize the DMA burst operation state */
  htim->DMABurstState = HAL_DMA_BURST_STATE_READY;
 8005240:	687b      	ldr	r3, [r7, #4]
 8005242:	2201      	movs	r2, #1
 8005244:	f883 2048 	strb.w	r2, [r3, #72]	; 0x48

  /* Initialize the TIM channels state */
  TIM_CHANNEL_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_READY);
 8005248:	687b      	ldr	r3, [r7, #4]
 800524a:	2201      	movs	r2, #1
 800524c:	f883 203e 	strb.w	r2, [r3, #62]	; 0x3e
 8005250:	687b      	ldr	r3, [r7, #4]
 8005252:	2201      	movs	r2, #1
 8005254:	f883 203f 	strb.w	r2, [r3, #63]	; 0x3f
 8005258:	687b      	ldr	r3, [r7, #4]
 800525a:	2201      	movs	r2, #1
 800525c:	f883 2040 	strb.w	r2, [r3, #64]	; 0x40
 8005260:	687b      	ldr	r3, [r7, #4]
 8005262:	2201      	movs	r2, #1
 8005264:	f883 2041 	strb.w	r2, [r3, #65]	; 0x41
 8005268:	687b      	ldr	r3, [r7, #4]
 800526a:	2201      	movs	r2, #1
 800526c:	f883 2042 	strb.w	r2, [r3, #66]	; 0x42
 8005270:	687b      	ldr	r3, [r7, #4]
 8005272:	2201      	movs	r2, #1
 8005274:	f883 2043 	strb.w	r2, [r3, #67]	; 0x43
  TIM_CHANNEL_N_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_READY);
 8005278:	687b      	ldr	r3, [r7, #4]
 800527a:	2201      	movs	r2, #1
 800527c:	f883 2044 	strb.w	r2, [r3, #68]	; 0x44
 8005280:	687b      	ldr	r3, [r7, #4]
 8005282:	2201      	movs	r2, #1
 8005284:	f883 2045 	strb.w	r2, [r3, #69]	; 0x45
 8005288:	687b      	ldr	r3, [r7, #4]
 800528a:	2201      	movs	r2, #1
 800528c:	f883 2046 	strb.w	r2, [r3, #70]	; 0x46
 8005290:	687b      	ldr	r3, [r7, #4]
 8005292:	2201      	movs	r2, #1
 8005294:	f883 2047 	strb.w	r2, [r3, #71]	; 0x47

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

  return HAL_OK;
 80052a0:	2300      	movs	r3, #0
}
 80052a2:	4618      	mov	r0, r3
 80052a4:	3708      	adds	r7, #8
 80052a6:	46bd      	mov	sp, r7
 80052a8:	bd80      	pop	{r7, pc}

080052aa <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)
{
 80052aa:	b580      	push	{r7, lr}
 80052ac:	b084      	sub	sp, #16
 80052ae:	af00      	add	r7, sp, #0
 80052b0:	6078      	str	r0, [r7, #4]
 80052b2:	6039      	str	r1, [r7, #0]
  HAL_StatusTypeDef status = HAL_OK;
 80052b4:	2300      	movs	r3, #0
 80052b6:	73fb      	strb	r3, [r7, #15]
  uint32_t tmpsmcr;

  /* Process Locked */
  __HAL_LOCK(htim);
 80052b8:	687b      	ldr	r3, [r7, #4]
 80052ba:	f893 303c 	ldrb.w	r3, [r3, #60]	; 0x3c
 80052be:	2b01      	cmp	r3, #1
 80052c0:	d101      	bne.n	80052c6 <HAL_TIM_ConfigClockSource+0x1c>
 80052c2:	2302      	movs	r3, #2
 80052c4:	e0b6      	b.n	8005434 <HAL_TIM_ConfigClockSource+0x18a>
 80052c6:	687b      	ldr	r3, [r7, #4]
 80052c8:	2201      	movs	r2, #1
 80052ca:	f883 203c 	strb.w	r2, [r3, #60]	; 0x3c

  htim->State = HAL_TIM_STATE_BUSY;
 80052ce:	687b      	ldr	r3, [r7, #4]
 80052d0:	2202      	movs	r2, #2
 80052d2:	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;
 80052d6:	687b      	ldr	r3, [r7, #4]
 80052d8:	681b      	ldr	r3, [r3, #0]
 80052da:	689b      	ldr	r3, [r3, #8]
 80052dc:	60bb      	str	r3, [r7, #8]
  tmpsmcr &= ~(TIM_SMCR_SMS | TIM_SMCR_TS);
 80052de:	68bb      	ldr	r3, [r7, #8]
 80052e0:	f423 3380 	bic.w	r3, r3, #65536	; 0x10000
 80052e4:	f023 0377 	bic.w	r3, r3, #119	; 0x77
 80052e8:	60bb      	str	r3, [r7, #8]
  tmpsmcr &= ~(TIM_SMCR_ETF | TIM_SMCR_ETPS | TIM_SMCR_ECE | TIM_SMCR_ETP);
 80052ea:	68bb      	ldr	r3, [r7, #8]
 80052ec:	f423 437f 	bic.w	r3, r3, #65280	; 0xff00
 80052f0:	60bb      	str	r3, [r7, #8]
  htim->Instance->SMCR = tmpsmcr;
 80052f2:	687b      	ldr	r3, [r7, #4]
 80052f4:	681b      	ldr	r3, [r3, #0]
 80052f6:	68ba      	ldr	r2, [r7, #8]
 80052f8:	609a      	str	r2, [r3, #8]

  switch (sClockSourceConfig->ClockSource)
 80052fa:	683b      	ldr	r3, [r7, #0]
 80052fc:	681b      	ldr	r3, [r3, #0]
 80052fe:	f5b3 5f00 	cmp.w	r3, #8192	; 0x2000
 8005302:	d03e      	beq.n	8005382 <HAL_TIM_ConfigClockSource+0xd8>
 8005304:	f5b3 5f00 	cmp.w	r3, #8192	; 0x2000
 8005308:	f200 8087 	bhi.w	800541a <HAL_TIM_ConfigClockSource+0x170>
 800530c:	f5b3 5f80 	cmp.w	r3, #4096	; 0x1000
 8005310:	f000 8086 	beq.w	8005420 <HAL_TIM_ConfigClockSource+0x176>
 8005314:	f5b3 5f80 	cmp.w	r3, #4096	; 0x1000
 8005318:	d87f      	bhi.n	800541a <HAL_TIM_ConfigClockSource+0x170>
 800531a:	2b70      	cmp	r3, #112	; 0x70
 800531c:	d01a      	beq.n	8005354 <HAL_TIM_ConfigClockSource+0xaa>
 800531e:	2b70      	cmp	r3, #112	; 0x70
 8005320:	d87b      	bhi.n	800541a <HAL_TIM_ConfigClockSource+0x170>
 8005322:	2b60      	cmp	r3, #96	; 0x60
 8005324:	d050      	beq.n	80053c8 <HAL_TIM_ConfigClockSource+0x11e>
 8005326:	2b60      	cmp	r3, #96	; 0x60
 8005328:	d877      	bhi.n	800541a <HAL_TIM_ConfigClockSource+0x170>
 800532a:	2b50      	cmp	r3, #80	; 0x50
 800532c:	d03c      	beq.n	80053a8 <HAL_TIM_ConfigClockSource+0xfe>
 800532e:	2b50      	cmp	r3, #80	; 0x50
 8005330:	d873      	bhi.n	800541a <HAL_TIM_ConfigClockSource+0x170>
 8005332:	2b40      	cmp	r3, #64	; 0x40
 8005334:	d058      	beq.n	80053e8 <HAL_TIM_ConfigClockSource+0x13e>
 8005336:	2b40      	cmp	r3, #64	; 0x40
 8005338:	d86f      	bhi.n	800541a <HAL_TIM_ConfigClockSource+0x170>
 800533a:	2b30      	cmp	r3, #48	; 0x30
 800533c:	d064      	beq.n	8005408 <HAL_TIM_ConfigClockSource+0x15e>
 800533e:	2b30      	cmp	r3, #48	; 0x30
 8005340:	d86b      	bhi.n	800541a <HAL_TIM_ConfigClockSource+0x170>
 8005342:	2b20      	cmp	r3, #32
 8005344:	d060      	beq.n	8005408 <HAL_TIM_ConfigClockSource+0x15e>
 8005346:	2b20      	cmp	r3, #32
 8005348:	d867      	bhi.n	800541a <HAL_TIM_ConfigClockSource+0x170>
 800534a:	2b00      	cmp	r3, #0
 800534c:	d05c      	beq.n	8005408 <HAL_TIM_ConfigClockSource+0x15e>
 800534e:	2b10      	cmp	r3, #16
 8005350:	d05a      	beq.n	8005408 <HAL_TIM_ConfigClockSource+0x15e>
 8005352:	e062      	b.n	800541a <HAL_TIM_ConfigClockSource+0x170>
      assert_param(IS_TIM_CLOCKPRESCALER(sClockSourceConfig->ClockPrescaler));
      assert_param(IS_TIM_CLOCKPOLARITY(sClockSourceConfig->ClockPolarity));
      assert_param(IS_TIM_CLOCKFILTER(sClockSourceConfig->ClockFilter));

      /* Configure the ETR Clock source */
      TIM_ETR_SetConfig(htim->Instance,
 8005354:	687b      	ldr	r3, [r7, #4]
 8005356:	6818      	ldr	r0, [r3, #0]
 8005358:	683b      	ldr	r3, [r7, #0]
 800535a:	6899      	ldr	r1, [r3, #8]
 800535c:	683b      	ldr	r3, [r7, #0]
 800535e:	685a      	ldr	r2, [r3, #4]
 8005360:	683b      	ldr	r3, [r7, #0]
 8005362:	68db      	ldr	r3, [r3, #12]
 8005364:	f000 f97e 	bl	8005664 <TIM_ETR_SetConfig>
                        sClockSourceConfig->ClockPrescaler,
                        sClockSourceConfig->ClockPolarity,
                        sClockSourceConfig->ClockFilter);

      /* Select the External clock mode1 and the ETRF trigger */
      tmpsmcr = htim->Instance->SMCR;
 8005368:	687b      	ldr	r3, [r7, #4]
 800536a:	681b      	ldr	r3, [r3, #0]
 800536c:	689b      	ldr	r3, [r3, #8]
 800536e:	60bb      	str	r3, [r7, #8]
      tmpsmcr |= (TIM_SLAVEMODE_EXTERNAL1 | TIM_CLOCKSOURCE_ETRMODE1);
 8005370:	68bb      	ldr	r3, [r7, #8]
 8005372:	f043 0377 	orr.w	r3, r3, #119	; 0x77
 8005376:	60bb      	str	r3, [r7, #8]
      /* Write to TIMx SMCR */
      htim->Instance->SMCR = tmpsmcr;
 8005378:	687b      	ldr	r3, [r7, #4]
 800537a:	681b      	ldr	r3, [r3, #0]
 800537c:	68ba      	ldr	r2, [r7, #8]
 800537e:	609a      	str	r2, [r3, #8]
      break;
 8005380:	e04f      	b.n	8005422 <HAL_TIM_ConfigClockSource+0x178>
      assert_param(IS_TIM_CLOCKPRESCALER(sClockSourceConfig->ClockPrescaler));
      assert_param(IS_TIM_CLOCKPOLARITY(sClockSourceConfig->ClockPolarity));
      assert_param(IS_TIM_CLOCKFILTER(sClockSourceConfig->ClockFilter));

      /* Configure the ETR Clock source */
      TIM_ETR_SetConfig(htim->Instance,
 8005382:	687b      	ldr	r3, [r7, #4]
 8005384:	6818      	ldr	r0, [r3, #0]
 8005386:	683b      	ldr	r3, [r7, #0]
 8005388:	6899      	ldr	r1, [r3, #8]
 800538a:	683b      	ldr	r3, [r7, #0]
 800538c:	685a      	ldr	r2, [r3, #4]
 800538e:	683b      	ldr	r3, [r7, #0]
 8005390:	68db      	ldr	r3, [r3, #12]
 8005392:	f000 f967 	bl	8005664 <TIM_ETR_SetConfig>
                        sClockSourceConfig->ClockPrescaler,
                        sClockSourceConfig->ClockPolarity,
                        sClockSourceConfig->ClockFilter);
      /* Enable the External clock mode2 */
      htim->Instance->SMCR |= TIM_SMCR_ECE;
 8005396:	687b      	ldr	r3, [r7, #4]
 8005398:	681b      	ldr	r3, [r3, #0]
 800539a:	689a      	ldr	r2, [r3, #8]
 800539c:	687b      	ldr	r3, [r7, #4]
 800539e:	681b      	ldr	r3, [r3, #0]
 80053a0:	f442 4280 	orr.w	r2, r2, #16384	; 0x4000
 80053a4:	609a      	str	r2, [r3, #8]
      break;
 80053a6:	e03c      	b.n	8005422 <HAL_TIM_ConfigClockSource+0x178>

      /* Check TI1 input conditioning related parameters */
      assert_param(IS_TIM_CLOCKPOLARITY(sClockSourceConfig->ClockPolarity));
      assert_param(IS_TIM_CLOCKFILTER(sClockSourceConfig->ClockFilter));

      TIM_TI1_ConfigInputStage(htim->Instance,
 80053a8:	687b      	ldr	r3, [r7, #4]
 80053aa:	6818      	ldr	r0, [r3, #0]
 80053ac:	683b      	ldr	r3, [r7, #0]
 80053ae:	6859      	ldr	r1, [r3, #4]
 80053b0:	683b      	ldr	r3, [r7, #0]
 80053b2:	68db      	ldr	r3, [r3, #12]
 80053b4:	461a      	mov	r2, r3
 80053b6:	f000 f8db 	bl	8005570 <TIM_TI1_ConfigInputStage>
                               sClockSourceConfig->ClockPolarity,
                               sClockSourceConfig->ClockFilter);
      TIM_ITRx_SetConfig(htim->Instance, TIM_CLOCKSOURCE_TI1);
 80053ba:	687b      	ldr	r3, [r7, #4]
 80053bc:	681b      	ldr	r3, [r3, #0]
 80053be:	2150      	movs	r1, #80	; 0x50
 80053c0:	4618      	mov	r0, r3
 80053c2:	f000 f934 	bl	800562e <TIM_ITRx_SetConfig>
      break;
 80053c6:	e02c      	b.n	8005422 <HAL_TIM_ConfigClockSource+0x178>

      /* Check TI2 input conditioning related parameters */
      assert_param(IS_TIM_CLOCKPOLARITY(sClockSourceConfig->ClockPolarity));
      assert_param(IS_TIM_CLOCKFILTER(sClockSourceConfig->ClockFilter));

      TIM_TI2_ConfigInputStage(htim->Instance,
 80053c8:	687b      	ldr	r3, [r7, #4]
 80053ca:	6818      	ldr	r0, [r3, #0]
 80053cc:	683b      	ldr	r3, [r7, #0]
 80053ce:	6859      	ldr	r1, [r3, #4]
 80053d0:	683b      	ldr	r3, [r7, #0]
 80053d2:	68db      	ldr	r3, [r3, #12]
 80053d4:	461a      	mov	r2, r3
 80053d6:	f000 f8fa 	bl	80055ce <TIM_TI2_ConfigInputStage>
                               sClockSourceConfig->ClockPolarity,
                               sClockSourceConfig->ClockFilter);
      TIM_ITRx_SetConfig(htim->Instance, TIM_CLOCKSOURCE_TI2);
 80053da:	687b      	ldr	r3, [r7, #4]
 80053dc:	681b      	ldr	r3, [r3, #0]
 80053de:	2160      	movs	r1, #96	; 0x60
 80053e0:	4618      	mov	r0, r3
 80053e2:	f000 f924 	bl	800562e <TIM_ITRx_SetConfig>
      break;
 80053e6:	e01c      	b.n	8005422 <HAL_TIM_ConfigClockSource+0x178>

      /* Check TI1 input conditioning related parameters */
      assert_param(IS_TIM_CLOCKPOLARITY(sClockSourceConfig->ClockPolarity));
      assert_param(IS_TIM_CLOCKFILTER(sClockSourceConfig->ClockFilter));

      TIM_TI1_ConfigInputStage(htim->Instance,
 80053e8:	687b      	ldr	r3, [r7, #4]
 80053ea:	6818      	ldr	r0, [r3, #0]
 80053ec:	683b      	ldr	r3, [r7, #0]
 80053ee:	6859      	ldr	r1, [r3, #4]
 80053f0:	683b      	ldr	r3, [r7, #0]
 80053f2:	68db      	ldr	r3, [r3, #12]
 80053f4:	461a      	mov	r2, r3
 80053f6:	f000 f8bb 	bl	8005570 <TIM_TI1_ConfigInputStage>
                               sClockSourceConfig->ClockPolarity,
                               sClockSourceConfig->ClockFilter);
      TIM_ITRx_SetConfig(htim->Instance, TIM_CLOCKSOURCE_TI1ED);
 80053fa:	687b      	ldr	r3, [r7, #4]
 80053fc:	681b      	ldr	r3, [r3, #0]
 80053fe:	2140      	movs	r1, #64	; 0x40
 8005400:	4618      	mov	r0, r3
 8005402:	f000 f914 	bl	800562e <TIM_ITRx_SetConfig>
      break;
 8005406:	e00c      	b.n	8005422 <HAL_TIM_ConfigClockSource+0x178>
    case TIM_CLOCKSOURCE_ITR3:
    {
      /* Check whether or not the timer instance supports internal trigger input */
      assert_param(IS_TIM_CLOCKSOURCE_ITRX_INSTANCE(htim->Instance));

      TIM_ITRx_SetConfig(htim->Instance, sClockSourceConfig->ClockSource);
 8005408:	687b      	ldr	r3, [r7, #4]
 800540a:	681a      	ldr	r2, [r3, #0]
 800540c:	683b      	ldr	r3, [r7, #0]
 800540e:	681b      	ldr	r3, [r3, #0]
 8005410:	4619      	mov	r1, r3
 8005412:	4610      	mov	r0, r2
 8005414:	f000 f90b 	bl	800562e <TIM_ITRx_SetConfig>
      break;
 8005418:	e003      	b.n	8005422 <HAL_TIM_ConfigClockSource+0x178>
    }

    default:
      status = HAL_ERROR;
 800541a:	2301      	movs	r3, #1
 800541c:	73fb      	strb	r3, [r7, #15]
      break;
 800541e:	e000      	b.n	8005422 <HAL_TIM_ConfigClockSource+0x178>
      break;
 8005420:	bf00      	nop
  }
  htim->State = HAL_TIM_STATE_READY;
 8005422:	687b      	ldr	r3, [r7, #4]
 8005424:	2201      	movs	r2, #1
 8005426:	f883 203d 	strb.w	r2, [r3, #61]	; 0x3d

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

  return status;
 8005432:	7bfb      	ldrb	r3, [r7, #15]
}
 8005434:	4618      	mov	r0, r3
 8005436:	3710      	adds	r7, #16
 8005438:	46bd      	mov	sp, r7
 800543a:	bd80      	pop	{r7, pc}

0800543c <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)
{
 800543c:	b480      	push	{r7}
 800543e:	b085      	sub	sp, #20
 8005440:	af00      	add	r7, sp, #0
 8005442:	6078      	str	r0, [r7, #4]
 8005444:	6039      	str	r1, [r7, #0]
  uint32_t tmpcr1;
  tmpcr1 = TIMx->CR1;
 8005446:	687b      	ldr	r3, [r7, #4]
 8005448:	681b      	ldr	r3, [r3, #0]
 800544a:	60fb      	str	r3, [r7, #12]

  /* Set TIM Time Base Unit parameters ---------------------------------------*/
  if (IS_TIM_COUNTER_MODE_SELECT_INSTANCE(TIMx))
 800544c:	687b      	ldr	r3, [r7, #4]
 800544e:	4a40      	ldr	r2, [pc, #256]	; (8005550 <TIM_Base_SetConfig+0x114>)
 8005450:	4293      	cmp	r3, r2
 8005452:	d013      	beq.n	800547c <TIM_Base_SetConfig+0x40>
 8005454:	687b      	ldr	r3, [r7, #4]
 8005456:	f1b3 4f80 	cmp.w	r3, #1073741824	; 0x40000000
 800545a:	d00f      	beq.n	800547c <TIM_Base_SetConfig+0x40>
 800545c:	687b      	ldr	r3, [r7, #4]
 800545e:	4a3d      	ldr	r2, [pc, #244]	; (8005554 <TIM_Base_SetConfig+0x118>)
 8005460:	4293      	cmp	r3, r2
 8005462:	d00b      	beq.n	800547c <TIM_Base_SetConfig+0x40>
 8005464:	687b      	ldr	r3, [r7, #4]
 8005466:	4a3c      	ldr	r2, [pc, #240]	; (8005558 <TIM_Base_SetConfig+0x11c>)
 8005468:	4293      	cmp	r3, r2
 800546a:	d007      	beq.n	800547c <TIM_Base_SetConfig+0x40>
 800546c:	687b      	ldr	r3, [r7, #4]
 800546e:	4a3b      	ldr	r2, [pc, #236]	; (800555c <TIM_Base_SetConfig+0x120>)
 8005470:	4293      	cmp	r3, r2
 8005472:	d003      	beq.n	800547c <TIM_Base_SetConfig+0x40>
 8005474:	687b      	ldr	r3, [r7, #4]
 8005476:	4a3a      	ldr	r2, [pc, #232]	; (8005560 <TIM_Base_SetConfig+0x124>)
 8005478:	4293      	cmp	r3, r2
 800547a:	d108      	bne.n	800548e <TIM_Base_SetConfig+0x52>
  {
    /* Select the Counter Mode */
    tmpcr1 &= ~(TIM_CR1_DIR | TIM_CR1_CMS);
 800547c:	68fb      	ldr	r3, [r7, #12]
 800547e:	f023 0370 	bic.w	r3, r3, #112	; 0x70
 8005482:	60fb      	str	r3, [r7, #12]
    tmpcr1 |= Structure->CounterMode;
 8005484:	683b      	ldr	r3, [r7, #0]
 8005486:	685b      	ldr	r3, [r3, #4]
 8005488:	68fa      	ldr	r2, [r7, #12]
 800548a:	4313      	orrs	r3, r2
 800548c:	60fb      	str	r3, [r7, #12]
  }

  if (IS_TIM_CLOCK_DIVISION_INSTANCE(TIMx))
 800548e:	687b      	ldr	r3, [r7, #4]
 8005490:	4a2f      	ldr	r2, [pc, #188]	; (8005550 <TIM_Base_SetConfig+0x114>)
 8005492:	4293      	cmp	r3, r2
 8005494:	d01f      	beq.n	80054d6 <TIM_Base_SetConfig+0x9a>
 8005496:	687b      	ldr	r3, [r7, #4]
 8005498:	f1b3 4f80 	cmp.w	r3, #1073741824	; 0x40000000
 800549c:	d01b      	beq.n	80054d6 <TIM_Base_SetConfig+0x9a>
 800549e:	687b      	ldr	r3, [r7, #4]
 80054a0:	4a2c      	ldr	r2, [pc, #176]	; (8005554 <TIM_Base_SetConfig+0x118>)
 80054a2:	4293      	cmp	r3, r2
 80054a4:	d017      	beq.n	80054d6 <TIM_Base_SetConfig+0x9a>
 80054a6:	687b      	ldr	r3, [r7, #4]
 80054a8:	4a2b      	ldr	r2, [pc, #172]	; (8005558 <TIM_Base_SetConfig+0x11c>)
 80054aa:	4293      	cmp	r3, r2
 80054ac:	d013      	beq.n	80054d6 <TIM_Base_SetConfig+0x9a>
 80054ae:	687b      	ldr	r3, [r7, #4]
 80054b0:	4a2a      	ldr	r2, [pc, #168]	; (800555c <TIM_Base_SetConfig+0x120>)
 80054b2:	4293      	cmp	r3, r2
 80054b4:	d00f      	beq.n	80054d6 <TIM_Base_SetConfig+0x9a>
 80054b6:	687b      	ldr	r3, [r7, #4]
 80054b8:	4a29      	ldr	r2, [pc, #164]	; (8005560 <TIM_Base_SetConfig+0x124>)
 80054ba:	4293      	cmp	r3, r2
 80054bc:	d00b      	beq.n	80054d6 <TIM_Base_SetConfig+0x9a>
 80054be:	687b      	ldr	r3, [r7, #4]
 80054c0:	4a28      	ldr	r2, [pc, #160]	; (8005564 <TIM_Base_SetConfig+0x128>)
 80054c2:	4293      	cmp	r3, r2
 80054c4:	d007      	beq.n	80054d6 <TIM_Base_SetConfig+0x9a>
 80054c6:	687b      	ldr	r3, [r7, #4]
 80054c8:	4a27      	ldr	r2, [pc, #156]	; (8005568 <TIM_Base_SetConfig+0x12c>)
 80054ca:	4293      	cmp	r3, r2
 80054cc:	d003      	beq.n	80054d6 <TIM_Base_SetConfig+0x9a>
 80054ce:	687b      	ldr	r3, [r7, #4]
 80054d0:	4a26      	ldr	r2, [pc, #152]	; (800556c <TIM_Base_SetConfig+0x130>)
 80054d2:	4293      	cmp	r3, r2
 80054d4:	d108      	bne.n	80054e8 <TIM_Base_SetConfig+0xac>
  {
    /* Set the clock division */
    tmpcr1 &= ~TIM_CR1_CKD;
 80054d6:	68fb      	ldr	r3, [r7, #12]
 80054d8:	f423 7340 	bic.w	r3, r3, #768	; 0x300
 80054dc:	60fb      	str	r3, [r7, #12]
    tmpcr1 |= (uint32_t)Structure->ClockDivision;
 80054de:	683b      	ldr	r3, [r7, #0]
 80054e0:	68db      	ldr	r3, [r3, #12]
 80054e2:	68fa      	ldr	r2, [r7, #12]
 80054e4:	4313      	orrs	r3, r2
 80054e6:	60fb      	str	r3, [r7, #12]
  }

  /* Set the auto-reload preload */
  MODIFY_REG(tmpcr1, TIM_CR1_ARPE, Structure->AutoReloadPreload);
 80054e8:	68fb      	ldr	r3, [r7, #12]
 80054ea:	f023 0280 	bic.w	r2, r3, #128	; 0x80
 80054ee:	683b      	ldr	r3, [r7, #0]
 80054f0:	695b      	ldr	r3, [r3, #20]
 80054f2:	4313      	orrs	r3, r2
 80054f4:	60fb      	str	r3, [r7, #12]

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

  /* Set the Autoreload value */
  TIMx->ARR = (uint32_t)Structure->Period ;
 80054fc:	683b      	ldr	r3, [r7, #0]
 80054fe:	689a      	ldr	r2, [r3, #8]
 8005500:	687b      	ldr	r3, [r7, #4]
 8005502:	62da      	str	r2, [r3, #44]	; 0x2c

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

  if (IS_TIM_REPETITION_COUNTER_INSTANCE(TIMx))
 800550c:	687b      	ldr	r3, [r7, #4]
 800550e:	4a10      	ldr	r2, [pc, #64]	; (8005550 <TIM_Base_SetConfig+0x114>)
 8005510:	4293      	cmp	r3, r2
 8005512:	d00f      	beq.n	8005534 <TIM_Base_SetConfig+0xf8>
 8005514:	687b      	ldr	r3, [r7, #4]
 8005516:	4a12      	ldr	r2, [pc, #72]	; (8005560 <TIM_Base_SetConfig+0x124>)
 8005518:	4293      	cmp	r3, r2
 800551a:	d00b      	beq.n	8005534 <TIM_Base_SetConfig+0xf8>
 800551c:	687b      	ldr	r3, [r7, #4]
 800551e:	4a11      	ldr	r2, [pc, #68]	; (8005564 <TIM_Base_SetConfig+0x128>)
 8005520:	4293      	cmp	r3, r2
 8005522:	d007      	beq.n	8005534 <TIM_Base_SetConfig+0xf8>
 8005524:	687b      	ldr	r3, [r7, #4]
 8005526:	4a10      	ldr	r2, [pc, #64]	; (8005568 <TIM_Base_SetConfig+0x12c>)
 8005528:	4293      	cmp	r3, r2
 800552a:	d003      	beq.n	8005534 <TIM_Base_SetConfig+0xf8>
 800552c:	687b      	ldr	r3, [r7, #4]
 800552e:	4a0f      	ldr	r2, [pc, #60]	; (800556c <TIM_Base_SetConfig+0x130>)
 8005530:	4293      	cmp	r3, r2
 8005532:	d103      	bne.n	800553c <TIM_Base_SetConfig+0x100>
  {
    /* Set the Repetition Counter value */
    TIMx->RCR = Structure->RepetitionCounter;
 8005534:	683b      	ldr	r3, [r7, #0]
 8005536:	691a      	ldr	r2, [r3, #16]
 8005538:	687b      	ldr	r3, [r7, #4]
 800553a:	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;
 800553c:	687b      	ldr	r3, [r7, #4]
 800553e:	2201      	movs	r2, #1
 8005540:	615a      	str	r2, [r3, #20]
}
 8005542:	bf00      	nop
 8005544:	3714      	adds	r7, #20
 8005546:	46bd      	mov	sp, r7
 8005548:	f85d 7b04 	ldr.w	r7, [sp], #4
 800554c:	4770      	bx	lr
 800554e:	bf00      	nop
 8005550:	40012c00 	.word	0x40012c00
 8005554:	40000400 	.word	0x40000400
 8005558:	40000800 	.word	0x40000800
 800555c:	40000c00 	.word	0x40000c00
 8005560:	40013400 	.word	0x40013400
 8005564:	40014000 	.word	0x40014000
 8005568:	40014400 	.word	0x40014400
 800556c:	40014800 	.word	0x40014800

08005570 <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)
{
 8005570:	b480      	push	{r7}
 8005572:	b087      	sub	sp, #28
 8005574:	af00      	add	r7, sp, #0
 8005576:	60f8      	str	r0, [r7, #12]
 8005578:	60b9      	str	r1, [r7, #8]
 800557a:	607a      	str	r2, [r7, #4]
  uint32_t tmpccmr1;
  uint32_t tmpccer;

  /* Disable the Channel 1: Reset the CC1E Bit */
  tmpccer = TIMx->CCER;
 800557c:	68fb      	ldr	r3, [r7, #12]
 800557e:	6a1b      	ldr	r3, [r3, #32]
 8005580:	617b      	str	r3, [r7, #20]
  TIMx->CCER &= ~TIM_CCER_CC1E;
 8005582:	68fb      	ldr	r3, [r7, #12]
 8005584:	6a1b      	ldr	r3, [r3, #32]
 8005586:	f023 0201 	bic.w	r2, r3, #1
 800558a:	68fb      	ldr	r3, [r7, #12]
 800558c:	621a      	str	r2, [r3, #32]
  tmpccmr1 = TIMx->CCMR1;
 800558e:	68fb      	ldr	r3, [r7, #12]
 8005590:	699b      	ldr	r3, [r3, #24]
 8005592:	613b      	str	r3, [r7, #16]

  /* Set the filter */
  tmpccmr1 &= ~TIM_CCMR1_IC1F;
 8005594:	693b      	ldr	r3, [r7, #16]
 8005596:	f023 03f0 	bic.w	r3, r3, #240	; 0xf0
 800559a:	613b      	str	r3, [r7, #16]
  tmpccmr1 |= (TIM_ICFilter << 4U);
 800559c:	687b      	ldr	r3, [r7, #4]
 800559e:	011b      	lsls	r3, r3, #4
 80055a0:	693a      	ldr	r2, [r7, #16]
 80055a2:	4313      	orrs	r3, r2
 80055a4:	613b      	str	r3, [r7, #16]

  /* Select the Polarity and set the CC1E Bit */
  tmpccer &= ~(TIM_CCER_CC1P | TIM_CCER_CC1NP);
 80055a6:	697b      	ldr	r3, [r7, #20]
 80055a8:	f023 030a 	bic.w	r3, r3, #10
 80055ac:	617b      	str	r3, [r7, #20]
  tmpccer |= TIM_ICPolarity;
 80055ae:	697a      	ldr	r2, [r7, #20]
 80055b0:	68bb      	ldr	r3, [r7, #8]
 80055b2:	4313      	orrs	r3, r2
 80055b4:	617b      	str	r3, [r7, #20]

  /* Write to TIMx CCMR1 and CCER registers */
  TIMx->CCMR1 = tmpccmr1;
 80055b6:	68fb      	ldr	r3, [r7, #12]
 80055b8:	693a      	ldr	r2, [r7, #16]
 80055ba:	619a      	str	r2, [r3, #24]
  TIMx->CCER = tmpccer;
 80055bc:	68fb      	ldr	r3, [r7, #12]
 80055be:	697a      	ldr	r2, [r7, #20]
 80055c0:	621a      	str	r2, [r3, #32]
}
 80055c2:	bf00      	nop
 80055c4:	371c      	adds	r7, #28
 80055c6:	46bd      	mov	sp, r7
 80055c8:	f85d 7b04 	ldr.w	r7, [sp], #4
 80055cc:	4770      	bx	lr

080055ce <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)
{
 80055ce:	b480      	push	{r7}
 80055d0:	b087      	sub	sp, #28
 80055d2:	af00      	add	r7, sp, #0
 80055d4:	60f8      	str	r0, [r7, #12]
 80055d6:	60b9      	str	r1, [r7, #8]
 80055d8:	607a      	str	r2, [r7, #4]
  uint32_t tmpccmr1;
  uint32_t tmpccer;

  /* Disable the Channel 2: Reset the CC2E Bit */
  TIMx->CCER &= ~TIM_CCER_CC2E;
 80055da:	68fb      	ldr	r3, [r7, #12]
 80055dc:	6a1b      	ldr	r3, [r3, #32]
 80055de:	f023 0210 	bic.w	r2, r3, #16
 80055e2:	68fb      	ldr	r3, [r7, #12]
 80055e4:	621a      	str	r2, [r3, #32]
  tmpccmr1 = TIMx->CCMR1;
 80055e6:	68fb      	ldr	r3, [r7, #12]
 80055e8:	699b      	ldr	r3, [r3, #24]
 80055ea:	617b      	str	r3, [r7, #20]
  tmpccer = TIMx->CCER;
 80055ec:	68fb      	ldr	r3, [r7, #12]
 80055ee:	6a1b      	ldr	r3, [r3, #32]
 80055f0:	613b      	str	r3, [r7, #16]

  /* Set the filter */
  tmpccmr1 &= ~TIM_CCMR1_IC2F;
 80055f2:	697b      	ldr	r3, [r7, #20]
 80055f4:	f423 4370 	bic.w	r3, r3, #61440	; 0xf000
 80055f8:	617b      	str	r3, [r7, #20]
  tmpccmr1 |= (TIM_ICFilter << 12U);
 80055fa:	687b      	ldr	r3, [r7, #4]
 80055fc:	031b      	lsls	r3, r3, #12
 80055fe:	697a      	ldr	r2, [r7, #20]
 8005600:	4313      	orrs	r3, r2
 8005602:	617b      	str	r3, [r7, #20]

  /* Select the Polarity and set the CC2E Bit */
  tmpccer &= ~(TIM_CCER_CC2P | TIM_CCER_CC2NP);
 8005604:	693b      	ldr	r3, [r7, #16]
 8005606:	f023 03a0 	bic.w	r3, r3, #160	; 0xa0
 800560a:	613b      	str	r3, [r7, #16]
  tmpccer |= (TIM_ICPolarity << 4U);
 800560c:	68bb      	ldr	r3, [r7, #8]
 800560e:	011b      	lsls	r3, r3, #4
 8005610:	693a      	ldr	r2, [r7, #16]
 8005612:	4313      	orrs	r3, r2
 8005614:	613b      	str	r3, [r7, #16]

  /* Write to TIMx CCMR1 and CCER registers */
  TIMx->CCMR1 = tmpccmr1 ;
 8005616:	68fb      	ldr	r3, [r7, #12]
 8005618:	697a      	ldr	r2, [r7, #20]
 800561a:	619a      	str	r2, [r3, #24]
  TIMx->CCER = tmpccer;
 800561c:	68fb      	ldr	r3, [r7, #12]
 800561e:	693a      	ldr	r2, [r7, #16]
 8005620:	621a      	str	r2, [r3, #32]
}
 8005622:	bf00      	nop
 8005624:	371c      	adds	r7, #28
 8005626:	46bd      	mov	sp, r7
 8005628:	f85d 7b04 	ldr.w	r7, [sp], #4
 800562c:	4770      	bx	lr

0800562e <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)
{
 800562e:	b480      	push	{r7}
 8005630:	b085      	sub	sp, #20
 8005632:	af00      	add	r7, sp, #0
 8005634:	6078      	str	r0, [r7, #4]
 8005636:	6039      	str	r1, [r7, #0]
  uint32_t tmpsmcr;

  /* Get the TIMx SMCR register value */
  tmpsmcr = TIMx->SMCR;
 8005638:	687b      	ldr	r3, [r7, #4]
 800563a:	689b      	ldr	r3, [r3, #8]
 800563c:	60fb      	str	r3, [r7, #12]
  /* Reset the TS Bits */
  tmpsmcr &= ~TIM_SMCR_TS;
 800563e:	68fb      	ldr	r3, [r7, #12]
 8005640:	f023 0370 	bic.w	r3, r3, #112	; 0x70
 8005644:	60fb      	str	r3, [r7, #12]
  /* Set the Input Trigger source and the slave mode*/
  tmpsmcr |= (InputTriggerSource | TIM_SLAVEMODE_EXTERNAL1);
 8005646:	683a      	ldr	r2, [r7, #0]
 8005648:	68fb      	ldr	r3, [r7, #12]
 800564a:	4313      	orrs	r3, r2
 800564c:	f043 0307 	orr.w	r3, r3, #7
 8005650:	60fb      	str	r3, [r7, #12]
  /* Write to TIMx SMCR */
  TIMx->SMCR = tmpsmcr;
 8005652:	687b      	ldr	r3, [r7, #4]
 8005654:	68fa      	ldr	r2, [r7, #12]
 8005656:	609a      	str	r2, [r3, #8]
}
 8005658:	bf00      	nop
 800565a:	3714      	adds	r7, #20
 800565c:	46bd      	mov	sp, r7
 800565e:	f85d 7b04 	ldr.w	r7, [sp], #4
 8005662:	4770      	bx	lr

08005664 <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)
{
 8005664:	b480      	push	{r7}
 8005666:	b087      	sub	sp, #28
 8005668:	af00      	add	r7, sp, #0
 800566a:	60f8      	str	r0, [r7, #12]
 800566c:	60b9      	str	r1, [r7, #8]
 800566e:	607a      	str	r2, [r7, #4]
 8005670:	603b      	str	r3, [r7, #0]
  uint32_t tmpsmcr;

  tmpsmcr = TIMx->SMCR;
 8005672:	68fb      	ldr	r3, [r7, #12]
 8005674:	689b      	ldr	r3, [r3, #8]
 8005676:	617b      	str	r3, [r7, #20]

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

  /* Set the Prescaler, the Filter value and the Polarity */
  tmpsmcr |= (uint32_t)(TIM_ExtTRGPrescaler | (TIM_ExtTRGPolarity | (ExtTRGFilter << 8U)));
 8005680:	683b      	ldr	r3, [r7, #0]
 8005682:	021a      	lsls	r2, r3, #8
 8005684:	687b      	ldr	r3, [r7, #4]
 8005686:	431a      	orrs	r2, r3
 8005688:	68bb      	ldr	r3, [r7, #8]
 800568a:	4313      	orrs	r3, r2
 800568c:	697a      	ldr	r2, [r7, #20]
 800568e:	4313      	orrs	r3, r2
 8005690:	617b      	str	r3, [r7, #20]

  /* Write to TIMx SMCR */
  TIMx->SMCR = tmpsmcr;
 8005692:	68fb      	ldr	r3, [r7, #12]
 8005694:	697a      	ldr	r2, [r7, #20]
 8005696:	609a      	str	r2, [r3, #8]
}
 8005698:	bf00      	nop
 800569a:	371c      	adds	r7, #28
 800569c:	46bd      	mov	sp, r7
 800569e:	f85d 7b04 	ldr.w	r7, [sp], #4
 80056a2:	4770      	bx	lr

080056a4 <HAL_TIMEx_MasterConfigSynchronization>:
  *         mode.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_TIMEx_MasterConfigSynchronization(TIM_HandleTypeDef *htim,
                                                        TIM_MasterConfigTypeDef *sMasterConfig)
{
 80056a4:	b480      	push	{r7}
 80056a6:	b085      	sub	sp, #20
 80056a8:	af00      	add	r7, sp, #0
 80056aa:	6078      	str	r0, [r7, #4]
 80056ac:	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);
 80056ae:	687b      	ldr	r3, [r7, #4]
 80056b0:	f893 303c 	ldrb.w	r3, [r3, #60]	; 0x3c
 80056b4:	2b01      	cmp	r3, #1
 80056b6:	d101      	bne.n	80056bc <HAL_TIMEx_MasterConfigSynchronization+0x18>
 80056b8:	2302      	movs	r3, #2
 80056ba:	e068      	b.n	800578e <HAL_TIMEx_MasterConfigSynchronization+0xea>
 80056bc:	687b      	ldr	r3, [r7, #4]
 80056be:	2201      	movs	r2, #1
 80056c0:	f883 203c 	strb.w	r2, [r3, #60]	; 0x3c

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

  /* Get the TIMx CR2 register value */
  tmpcr2 = htim->Instance->CR2;
 80056cc:	687b      	ldr	r3, [r7, #4]
 80056ce:	681b      	ldr	r3, [r3, #0]
 80056d0:	685b      	ldr	r3, [r3, #4]
 80056d2:	60fb      	str	r3, [r7, #12]

  /* Get the TIMx SMCR register value */
  tmpsmcr = htim->Instance->SMCR;
 80056d4:	687b      	ldr	r3, [r7, #4]
 80056d6:	681b      	ldr	r3, [r3, #0]
 80056d8:	689b      	ldr	r3, [r3, #8]
 80056da:	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))
 80056dc:	687b      	ldr	r3, [r7, #4]
 80056de:	681b      	ldr	r3, [r3, #0]
 80056e0:	4a2e      	ldr	r2, [pc, #184]	; (800579c <HAL_TIMEx_MasterConfigSynchronization+0xf8>)
 80056e2:	4293      	cmp	r3, r2
 80056e4:	d004      	beq.n	80056f0 <HAL_TIMEx_MasterConfigSynchronization+0x4c>
 80056e6:	687b      	ldr	r3, [r7, #4]
 80056e8:	681b      	ldr	r3, [r3, #0]
 80056ea:	4a2d      	ldr	r2, [pc, #180]	; (80057a0 <HAL_TIMEx_MasterConfigSynchronization+0xfc>)
 80056ec:	4293      	cmp	r3, r2
 80056ee:	d108      	bne.n	8005702 <HAL_TIMEx_MasterConfigSynchronization+0x5e>
  {
    /* Check the parameters */
    assert_param(IS_TIM_TRGO2_SOURCE(sMasterConfig->MasterOutputTrigger2));

    /* Clear the MMS2 bits */
    tmpcr2 &= ~TIM_CR2_MMS2;
 80056f0:	68fb      	ldr	r3, [r7, #12]
 80056f2:	f423 0370 	bic.w	r3, r3, #15728640	; 0xf00000
 80056f6:	60fb      	str	r3, [r7, #12]
    /* Select the TRGO2 source*/
    tmpcr2 |= sMasterConfig->MasterOutputTrigger2;
 80056f8:	683b      	ldr	r3, [r7, #0]
 80056fa:	685b      	ldr	r3, [r3, #4]
 80056fc:	68fa      	ldr	r2, [r7, #12]
 80056fe:	4313      	orrs	r3, r2
 8005700:	60fb      	str	r3, [r7, #12]
  }

  /* Reset the MMS Bits */
  tmpcr2 &= ~TIM_CR2_MMS;
 8005702:	68fb      	ldr	r3, [r7, #12]
 8005704:	f023 0370 	bic.w	r3, r3, #112	; 0x70
 8005708:	60fb      	str	r3, [r7, #12]
  /* Select the TRGO source */
  tmpcr2 |=  sMasterConfig->MasterOutputTrigger;
 800570a:	683b      	ldr	r3, [r7, #0]
 800570c:	681b      	ldr	r3, [r3, #0]
 800570e:	68fa      	ldr	r2, [r7, #12]
 8005710:	4313      	orrs	r3, r2
 8005712:	60fb      	str	r3, [r7, #12]

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

  if (IS_TIM_SLAVE_INSTANCE(htim->Instance))
 800571c:	687b      	ldr	r3, [r7, #4]
 800571e:	681b      	ldr	r3, [r3, #0]
 8005720:	4a1e      	ldr	r2, [pc, #120]	; (800579c <HAL_TIMEx_MasterConfigSynchronization+0xf8>)
 8005722:	4293      	cmp	r3, r2
 8005724:	d01d      	beq.n	8005762 <HAL_TIMEx_MasterConfigSynchronization+0xbe>
 8005726:	687b      	ldr	r3, [r7, #4]
 8005728:	681b      	ldr	r3, [r3, #0]
 800572a:	f1b3 4f80 	cmp.w	r3, #1073741824	; 0x40000000
 800572e:	d018      	beq.n	8005762 <HAL_TIMEx_MasterConfigSynchronization+0xbe>
 8005730:	687b      	ldr	r3, [r7, #4]
 8005732:	681b      	ldr	r3, [r3, #0]
 8005734:	4a1b      	ldr	r2, [pc, #108]	; (80057a4 <HAL_TIMEx_MasterConfigSynchronization+0x100>)
 8005736:	4293      	cmp	r3, r2
 8005738:	d013      	beq.n	8005762 <HAL_TIMEx_MasterConfigSynchronization+0xbe>
 800573a:	687b      	ldr	r3, [r7, #4]
 800573c:	681b      	ldr	r3, [r3, #0]
 800573e:	4a1a      	ldr	r2, [pc, #104]	; (80057a8 <HAL_TIMEx_MasterConfigSynchronization+0x104>)
 8005740:	4293      	cmp	r3, r2
 8005742:	d00e      	beq.n	8005762 <HAL_TIMEx_MasterConfigSynchronization+0xbe>
 8005744:	687b      	ldr	r3, [r7, #4]
 8005746:	681b      	ldr	r3, [r3, #0]
 8005748:	4a18      	ldr	r2, [pc, #96]	; (80057ac <HAL_TIMEx_MasterConfigSynchronization+0x108>)
 800574a:	4293      	cmp	r3, r2
 800574c:	d009      	beq.n	8005762 <HAL_TIMEx_MasterConfigSynchronization+0xbe>
 800574e:	687b      	ldr	r3, [r7, #4]
 8005750:	681b      	ldr	r3, [r3, #0]
 8005752:	4a13      	ldr	r2, [pc, #76]	; (80057a0 <HAL_TIMEx_MasterConfigSynchronization+0xfc>)
 8005754:	4293      	cmp	r3, r2
 8005756:	d004      	beq.n	8005762 <HAL_TIMEx_MasterConfigSynchronization+0xbe>
 8005758:	687b      	ldr	r3, [r7, #4]
 800575a:	681b      	ldr	r3, [r3, #0]
 800575c:	4a14      	ldr	r2, [pc, #80]	; (80057b0 <HAL_TIMEx_MasterConfigSynchronization+0x10c>)
 800575e:	4293      	cmp	r3, r2
 8005760:	d10c      	bne.n	800577c <HAL_TIMEx_MasterConfigSynchronization+0xd8>
  {
    /* Reset the MSM Bit */
    tmpsmcr &= ~TIM_SMCR_MSM;
 8005762:	68bb      	ldr	r3, [r7, #8]
 8005764:	f023 0380 	bic.w	r3, r3, #128	; 0x80
 8005768:	60bb      	str	r3, [r7, #8]
    /* Set master mode */
    tmpsmcr |= sMasterConfig->MasterSlaveMode;
 800576a:	683b      	ldr	r3, [r7, #0]
 800576c:	689b      	ldr	r3, [r3, #8]
 800576e:	68ba      	ldr	r2, [r7, #8]
 8005770:	4313      	orrs	r3, r2
 8005772:	60bb      	str	r3, [r7, #8]

    /* Update TIMx SMCR */
    htim->Instance->SMCR = tmpsmcr;
 8005774:	687b      	ldr	r3, [r7, #4]
 8005776:	681b      	ldr	r3, [r3, #0]
 8005778:	68ba      	ldr	r2, [r7, #8]
 800577a:	609a      	str	r2, [r3, #8]
  }

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

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

  return HAL_OK;
 800578c:	2300      	movs	r3, #0
}
 800578e:	4618      	mov	r0, r3
 8005790:	3714      	adds	r7, #20
 8005792:	46bd      	mov	sp, r7
 8005794:	f85d 7b04 	ldr.w	r7, [sp], #4
 8005798:	4770      	bx	lr
 800579a:	bf00      	nop
 800579c:	40012c00 	.word	0x40012c00
 80057a0:	40013400 	.word	0x40013400
 80057a4:	40000400 	.word	0x40000400
 80057a8:	40000800 	.word	0x40000800
 80057ac:	40000c00 	.word	0x40000c00
 80057b0:	40014000 	.word	0x40014000

080057b4 <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)
{
 80057b4:	b580      	push	{r7, lr}
 80057b6:	b082      	sub	sp, #8
 80057b8:	af00      	add	r7, sp, #0
 80057ba:	6078      	str	r0, [r7, #4]
  /* Check the UART handle allocation */
  if (huart == NULL)
 80057bc:	687b      	ldr	r3, [r7, #4]
 80057be:	2b00      	cmp	r3, #0
 80057c0:	d101      	bne.n	80057c6 <HAL_UART_Init+0x12>
  {
    return HAL_ERROR;
 80057c2:	2301      	movs	r3, #1
 80057c4:	e040      	b.n	8005848 <HAL_UART_Init+0x94>
  {
    /* Check the parameters */
    assert_param((IS_UART_INSTANCE(huart->Instance)) || (IS_LPUART_INSTANCE(huart->Instance)));
  }

  if (huart->gState == HAL_UART_STATE_RESET)
 80057c6:	687b      	ldr	r3, [r7, #4]
 80057c8:	6f9b      	ldr	r3, [r3, #120]	; 0x78
 80057ca:	2b00      	cmp	r3, #0
 80057cc:	d106      	bne.n	80057dc <HAL_UART_Init+0x28>
  {
    /* Allocate lock resource and initialize it */
    huart->Lock = HAL_UNLOCKED;
 80057ce:	687b      	ldr	r3, [r7, #4]
 80057d0:	2200      	movs	r2, #0
 80057d2:	f883 2074 	strb.w	r2, [r3, #116]	; 0x74

    /* Init the low level hardware */
    huart->MspInitCallback(huart);
#else
    /* Init the low level hardware : GPIO, CLOCK */
    HAL_UART_MspInit(huart);
 80057d6:	6878      	ldr	r0, [r7, #4]
 80057d8:	f7fc fb0e 	bl	8001df8 <HAL_UART_MspInit>
#endif /* (USE_HAL_UART_REGISTER_CALLBACKS) */
  }

  huart->gState = HAL_UART_STATE_BUSY;
 80057dc:	687b      	ldr	r3, [r7, #4]
 80057de:	2224      	movs	r2, #36	; 0x24
 80057e0:	679a      	str	r2, [r3, #120]	; 0x78

  __HAL_UART_DISABLE(huart);
 80057e2:	687b      	ldr	r3, [r7, #4]
 80057e4:	681b      	ldr	r3, [r3, #0]
 80057e6:	681a      	ldr	r2, [r3, #0]
 80057e8:	687b      	ldr	r3, [r7, #4]
 80057ea:	681b      	ldr	r3, [r3, #0]
 80057ec:	f022 0201 	bic.w	r2, r2, #1
 80057f0:	601a      	str	r2, [r3, #0]

  /* Set the UART Communication parameters */
  if (UART_SetConfig(huart) == HAL_ERROR)
 80057f2:	6878      	ldr	r0, [r7, #4]
 80057f4:	f000 f8c0 	bl	8005978 <UART_SetConfig>
 80057f8:	4603      	mov	r3, r0
 80057fa:	2b01      	cmp	r3, #1
 80057fc:	d101      	bne.n	8005802 <HAL_UART_Init+0x4e>
  {
    return HAL_ERROR;
 80057fe:	2301      	movs	r3, #1
 8005800:	e022      	b.n	8005848 <HAL_UART_Init+0x94>
  }

  if (huart->AdvancedInit.AdvFeatureInit != UART_ADVFEATURE_NO_INIT)
 8005802:	687b      	ldr	r3, [r7, #4]
 8005804:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8005806:	2b00      	cmp	r3, #0
 8005808:	d002      	beq.n	8005810 <HAL_UART_Init+0x5c>
  {
    UART_AdvFeatureConfig(huart);
 800580a:	6878      	ldr	r0, [r7, #4]
 800580c:	f000 fb3e 	bl	8005e8c <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));
 8005810:	687b      	ldr	r3, [r7, #4]
 8005812:	681b      	ldr	r3, [r3, #0]
 8005814:	685a      	ldr	r2, [r3, #4]
 8005816:	687b      	ldr	r3, [r7, #4]
 8005818:	681b      	ldr	r3, [r3, #0]
 800581a:	f422 4290 	bic.w	r2, r2, #18432	; 0x4800
 800581e:	605a      	str	r2, [r3, #4]
  CLEAR_BIT(huart->Instance->CR3, (USART_CR3_SCEN | USART_CR3_HDSEL | USART_CR3_IREN));
 8005820:	687b      	ldr	r3, [r7, #4]
 8005822:	681b      	ldr	r3, [r3, #0]
 8005824:	689a      	ldr	r2, [r3, #8]
 8005826:	687b      	ldr	r3, [r7, #4]
 8005828:	681b      	ldr	r3, [r3, #0]
 800582a:	f022 022a 	bic.w	r2, r2, #42	; 0x2a
 800582e:	609a      	str	r2, [r3, #8]

  __HAL_UART_ENABLE(huart);
 8005830:	687b      	ldr	r3, [r7, #4]
 8005832:	681b      	ldr	r3, [r3, #0]
 8005834:	681a      	ldr	r2, [r3, #0]
 8005836:	687b      	ldr	r3, [r7, #4]
 8005838:	681b      	ldr	r3, [r3, #0]
 800583a:	f042 0201 	orr.w	r2, r2, #1
 800583e:	601a      	str	r2, [r3, #0]

  /* TEACK and/or REACK to check before moving huart->gState and huart->RxState to Ready */
  return (UART_CheckIdleState(huart));
 8005840:	6878      	ldr	r0, [r7, #4]
 8005842:	f000 fbc5 	bl	8005fd0 <UART_CheckIdleState>
 8005846:	4603      	mov	r3, r0
}
 8005848:	4618      	mov	r0, r3
 800584a:	3708      	adds	r7, #8
 800584c:	46bd      	mov	sp, r7
 800584e:	bd80      	pop	{r7, pc}

08005850 <HAL_UART_Transmit>:
  * @param Size    Amount of data elements (u8 or u16) to be sent.
  * @param Timeout Timeout duration.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_UART_Transmit(UART_HandleTypeDef *huart, const uint8_t *pData, uint16_t Size, uint32_t Timeout)
{
 8005850:	b580      	push	{r7, lr}
 8005852:	b08a      	sub	sp, #40	; 0x28
 8005854:	af02      	add	r7, sp, #8
 8005856:	60f8      	str	r0, [r7, #12]
 8005858:	60b9      	str	r1, [r7, #8]
 800585a:	603b      	str	r3, [r7, #0]
 800585c:	4613      	mov	r3, r2
 800585e:	80fb      	strh	r3, [r7, #6]
  const uint8_t  *pdata8bits;
  const uint16_t *pdata16bits;
  uint32_t tickstart;

  /* Check that a Tx process is not already ongoing */
  if (huart->gState == HAL_UART_STATE_READY)
 8005860:	68fb      	ldr	r3, [r7, #12]
 8005862:	6f9b      	ldr	r3, [r3, #120]	; 0x78
 8005864:	2b20      	cmp	r3, #32
 8005866:	f040 8082 	bne.w	800596e <HAL_UART_Transmit+0x11e>
  {
    if ((pData == NULL) || (Size == 0U))
 800586a:	68bb      	ldr	r3, [r7, #8]
 800586c:	2b00      	cmp	r3, #0
 800586e:	d002      	beq.n	8005876 <HAL_UART_Transmit+0x26>
 8005870:	88fb      	ldrh	r3, [r7, #6]
 8005872:	2b00      	cmp	r3, #0
 8005874:	d101      	bne.n	800587a <HAL_UART_Transmit+0x2a>
    {
      return  HAL_ERROR;
 8005876:	2301      	movs	r3, #1
 8005878:	e07a      	b.n	8005970 <HAL_UART_Transmit+0x120>
    }

    __HAL_LOCK(huart);
 800587a:	68fb      	ldr	r3, [r7, #12]
 800587c:	f893 3074 	ldrb.w	r3, [r3, #116]	; 0x74
 8005880:	2b01      	cmp	r3, #1
 8005882:	d101      	bne.n	8005888 <HAL_UART_Transmit+0x38>
 8005884:	2302      	movs	r3, #2
 8005886:	e073      	b.n	8005970 <HAL_UART_Transmit+0x120>
 8005888:	68fb      	ldr	r3, [r7, #12]
 800588a:	2201      	movs	r2, #1
 800588c:	f883 2074 	strb.w	r2, [r3, #116]	; 0x74

    huart->ErrorCode = HAL_UART_ERROR_NONE;
 8005890:	68fb      	ldr	r3, [r7, #12]
 8005892:	2200      	movs	r2, #0
 8005894:	f8c3 2080 	str.w	r2, [r3, #128]	; 0x80
    huart->gState = HAL_UART_STATE_BUSY_TX;
 8005898:	68fb      	ldr	r3, [r7, #12]
 800589a:	2221      	movs	r2, #33	; 0x21
 800589c:	679a      	str	r2, [r3, #120]	; 0x78

    /* Init tickstart for timeout management */
    tickstart = HAL_GetTick();
 800589e:	f7fc fba1 	bl	8001fe4 <HAL_GetTick>
 80058a2:	6178      	str	r0, [r7, #20]

    huart->TxXferSize  = Size;
 80058a4:	68fb      	ldr	r3, [r7, #12]
 80058a6:	88fa      	ldrh	r2, [r7, #6]
 80058a8:	f8a3 2050 	strh.w	r2, [r3, #80]	; 0x50
    huart->TxXferCount = Size;
 80058ac:	68fb      	ldr	r3, [r7, #12]
 80058ae:	88fa      	ldrh	r2, [r7, #6]
 80058b0:	f8a3 2052 	strh.w	r2, [r3, #82]	; 0x52

    /* In case of 9bits/No Parity transfer, pData needs to be handled as a uint16_t pointer */
    if ((huart->Init.WordLength == UART_WORDLENGTH_9B) && (huart->Init.Parity == UART_PARITY_NONE))
 80058b4:	68fb      	ldr	r3, [r7, #12]
 80058b6:	689b      	ldr	r3, [r3, #8]
 80058b8:	f5b3 5f80 	cmp.w	r3, #4096	; 0x1000
 80058bc:	d108      	bne.n	80058d0 <HAL_UART_Transmit+0x80>
 80058be:	68fb      	ldr	r3, [r7, #12]
 80058c0:	691b      	ldr	r3, [r3, #16]
 80058c2:	2b00      	cmp	r3, #0
 80058c4:	d104      	bne.n	80058d0 <HAL_UART_Transmit+0x80>
    {
      pdata8bits  = NULL;
 80058c6:	2300      	movs	r3, #0
 80058c8:	61fb      	str	r3, [r7, #28]
      pdata16bits = (const uint16_t *) pData;
 80058ca:	68bb      	ldr	r3, [r7, #8]
 80058cc:	61bb      	str	r3, [r7, #24]
 80058ce:	e003      	b.n	80058d8 <HAL_UART_Transmit+0x88>
    }
    else
    {
      pdata8bits  = pData;
 80058d0:	68bb      	ldr	r3, [r7, #8]
 80058d2:	61fb      	str	r3, [r7, #28]
      pdata16bits = NULL;
 80058d4:	2300      	movs	r3, #0
 80058d6:	61bb      	str	r3, [r7, #24]
    }

    __HAL_UNLOCK(huart);
 80058d8:	68fb      	ldr	r3, [r7, #12]
 80058da:	2200      	movs	r2, #0
 80058dc:	f883 2074 	strb.w	r2, [r3, #116]	; 0x74

    while (huart->TxXferCount > 0U)
 80058e0:	e02d      	b.n	800593e <HAL_UART_Transmit+0xee>
    {
      if (UART_WaitOnFlagUntilTimeout(huart, UART_FLAG_TXE, RESET, tickstart, Timeout) != HAL_OK)
 80058e2:	683b      	ldr	r3, [r7, #0]
 80058e4:	9300      	str	r3, [sp, #0]
 80058e6:	697b      	ldr	r3, [r7, #20]
 80058e8:	2200      	movs	r2, #0
 80058ea:	2180      	movs	r1, #128	; 0x80
 80058ec:	68f8      	ldr	r0, [r7, #12]
 80058ee:	f000 fbb8 	bl	8006062 <UART_WaitOnFlagUntilTimeout>
 80058f2:	4603      	mov	r3, r0
 80058f4:	2b00      	cmp	r3, #0
 80058f6:	d001      	beq.n	80058fc <HAL_UART_Transmit+0xac>
      {
        return HAL_TIMEOUT;
 80058f8:	2303      	movs	r3, #3
 80058fa:	e039      	b.n	8005970 <HAL_UART_Transmit+0x120>
      }
      if (pdata8bits == NULL)
 80058fc:	69fb      	ldr	r3, [r7, #28]
 80058fe:	2b00      	cmp	r3, #0
 8005900:	d10b      	bne.n	800591a <HAL_UART_Transmit+0xca>
      {
        huart->Instance->TDR = (uint16_t)(*pdata16bits & 0x01FFU);
 8005902:	69bb      	ldr	r3, [r7, #24]
 8005904:	881a      	ldrh	r2, [r3, #0]
 8005906:	68fb      	ldr	r3, [r7, #12]
 8005908:	681b      	ldr	r3, [r3, #0]
 800590a:	f3c2 0208 	ubfx	r2, r2, #0, #9
 800590e:	b292      	uxth	r2, r2
 8005910:	851a      	strh	r2, [r3, #40]	; 0x28
        pdata16bits++;
 8005912:	69bb      	ldr	r3, [r7, #24]
 8005914:	3302      	adds	r3, #2
 8005916:	61bb      	str	r3, [r7, #24]
 8005918:	e008      	b.n	800592c <HAL_UART_Transmit+0xdc>
      }
      else
      {
        huart->Instance->TDR = (uint8_t)(*pdata8bits & 0xFFU);
 800591a:	69fb      	ldr	r3, [r7, #28]
 800591c:	781a      	ldrb	r2, [r3, #0]
 800591e:	68fb      	ldr	r3, [r7, #12]
 8005920:	681b      	ldr	r3, [r3, #0]
 8005922:	b292      	uxth	r2, r2
 8005924:	851a      	strh	r2, [r3, #40]	; 0x28
        pdata8bits++;
 8005926:	69fb      	ldr	r3, [r7, #28]
 8005928:	3301      	adds	r3, #1
 800592a:	61fb      	str	r3, [r7, #28]
      }
      huart->TxXferCount--;
 800592c:	68fb      	ldr	r3, [r7, #12]
 800592e:	f8b3 3052 	ldrh.w	r3, [r3, #82]	; 0x52
 8005932:	b29b      	uxth	r3, r3
 8005934:	3b01      	subs	r3, #1
 8005936:	b29a      	uxth	r2, r3
 8005938:	68fb      	ldr	r3, [r7, #12]
 800593a:	f8a3 2052 	strh.w	r2, [r3, #82]	; 0x52
    while (huart->TxXferCount > 0U)
 800593e:	68fb      	ldr	r3, [r7, #12]
 8005940:	f8b3 3052 	ldrh.w	r3, [r3, #82]	; 0x52
 8005944:	b29b      	uxth	r3, r3
 8005946:	2b00      	cmp	r3, #0
 8005948:	d1cb      	bne.n	80058e2 <HAL_UART_Transmit+0x92>
    }

    if (UART_WaitOnFlagUntilTimeout(huart, UART_FLAG_TC, RESET, tickstart, Timeout) != HAL_OK)
 800594a:	683b      	ldr	r3, [r7, #0]
 800594c:	9300      	str	r3, [sp, #0]
 800594e:	697b      	ldr	r3, [r7, #20]
 8005950:	2200      	movs	r2, #0
 8005952:	2140      	movs	r1, #64	; 0x40
 8005954:	68f8      	ldr	r0, [r7, #12]
 8005956:	f000 fb84 	bl	8006062 <UART_WaitOnFlagUntilTimeout>
 800595a:	4603      	mov	r3, r0
 800595c:	2b00      	cmp	r3, #0
 800595e:	d001      	beq.n	8005964 <HAL_UART_Transmit+0x114>
    {
      return HAL_TIMEOUT;
 8005960:	2303      	movs	r3, #3
 8005962:	e005      	b.n	8005970 <HAL_UART_Transmit+0x120>
    }

    /* At end of Tx process, restore huart->gState to Ready */
    huart->gState = HAL_UART_STATE_READY;
 8005964:	68fb      	ldr	r3, [r7, #12]
 8005966:	2220      	movs	r2, #32
 8005968:	679a      	str	r2, [r3, #120]	; 0x78

    return HAL_OK;
 800596a:	2300      	movs	r3, #0
 800596c:	e000      	b.n	8005970 <HAL_UART_Transmit+0x120>
  }
  else
  {
    return HAL_BUSY;
 800596e:	2302      	movs	r3, #2
  }
}
 8005970:	4618      	mov	r0, r3
 8005972:	3720      	adds	r7, #32
 8005974:	46bd      	mov	sp, r7
 8005976:	bd80      	pop	{r7, pc}

08005978 <UART_SetConfig>:
  * @brief Configure the UART peripheral.
  * @param huart UART handle.
  * @retval HAL status
  */
HAL_StatusTypeDef UART_SetConfig(UART_HandleTypeDef *huart)
{
 8005978:	b5b0      	push	{r4, r5, r7, lr}
 800597a:	b088      	sub	sp, #32
 800597c:	af00      	add	r7, sp, #0
 800597e:	6078      	str	r0, [r7, #4]
  uint32_t tmpreg;
  uint16_t brrtemp;
  UART_ClockSourceTypeDef clocksource;
  uint32_t usartdiv;
  HAL_StatusTypeDef ret               = HAL_OK;
 8005980:	2300      	movs	r3, #0
 8005982:	76bb      	strb	r3, [r7, #26]
  *  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 ;
 8005984:	687b      	ldr	r3, [r7, #4]
 8005986:	689a      	ldr	r2, [r3, #8]
 8005988:	687b      	ldr	r3, [r7, #4]
 800598a:	691b      	ldr	r3, [r3, #16]
 800598c:	431a      	orrs	r2, r3
 800598e:	687b      	ldr	r3, [r7, #4]
 8005990:	695b      	ldr	r3, [r3, #20]
 8005992:	431a      	orrs	r2, r3
 8005994:	687b      	ldr	r3, [r7, #4]
 8005996:	69db      	ldr	r3, [r3, #28]
 8005998:	4313      	orrs	r3, r2
 800599a:	61fb      	str	r3, [r7, #28]
  MODIFY_REG(huart->Instance->CR1, USART_CR1_FIELDS, tmpreg);
 800599c:	687b      	ldr	r3, [r7, #4]
 800599e:	681b      	ldr	r3, [r3, #0]
 80059a0:	681a      	ldr	r2, [r3, #0]
 80059a2:	4bad      	ldr	r3, [pc, #692]	; (8005c58 <UART_SetConfig+0x2e0>)
 80059a4:	4013      	ands	r3, r2
 80059a6:	687a      	ldr	r2, [r7, #4]
 80059a8:	6812      	ldr	r2, [r2, #0]
 80059aa:	69f9      	ldr	r1, [r7, #28]
 80059ac:	430b      	orrs	r3, r1
 80059ae:	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);
 80059b0:	687b      	ldr	r3, [r7, #4]
 80059b2:	681b      	ldr	r3, [r3, #0]
 80059b4:	685b      	ldr	r3, [r3, #4]
 80059b6:	f423 5140 	bic.w	r1, r3, #12288	; 0x3000
 80059ba:	687b      	ldr	r3, [r7, #4]
 80059bc:	68da      	ldr	r2, [r3, #12]
 80059be:	687b      	ldr	r3, [r7, #4]
 80059c0:	681b      	ldr	r3, [r3, #0]
 80059c2:	430a      	orrs	r2, r1
 80059c4:	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;
 80059c6:	687b      	ldr	r3, [r7, #4]
 80059c8:	699b      	ldr	r3, [r3, #24]
 80059ca:	61fb      	str	r3, [r7, #28]

  if (!(UART_INSTANCE_LOWPOWER(huart)))
 80059cc:	687b      	ldr	r3, [r7, #4]
 80059ce:	681b      	ldr	r3, [r3, #0]
 80059d0:	4aa2      	ldr	r2, [pc, #648]	; (8005c5c <UART_SetConfig+0x2e4>)
 80059d2:	4293      	cmp	r3, r2
 80059d4:	d004      	beq.n	80059e0 <UART_SetConfig+0x68>
  {
    tmpreg |= huart->Init.OneBitSampling;
 80059d6:	687b      	ldr	r3, [r7, #4]
 80059d8:	6a1b      	ldr	r3, [r3, #32]
 80059da:	69fa      	ldr	r2, [r7, #28]
 80059dc:	4313      	orrs	r3, r2
 80059de:	61fb      	str	r3, [r7, #28]
  }
  MODIFY_REG(huart->Instance->CR3, USART_CR3_FIELDS, tmpreg);
 80059e0:	687b      	ldr	r3, [r7, #4]
 80059e2:	681b      	ldr	r3, [r3, #0]
 80059e4:	689b      	ldr	r3, [r3, #8]
 80059e6:	f423 6130 	bic.w	r1, r3, #2816	; 0xb00
 80059ea:	687b      	ldr	r3, [r7, #4]
 80059ec:	681b      	ldr	r3, [r3, #0]
 80059ee:	69fa      	ldr	r2, [r7, #28]
 80059f0:	430a      	orrs	r2, r1
 80059f2:	609a      	str	r2, [r3, #8]
  * - UART Clock Prescaler : set PRESCALER according to huart->Init.ClockPrescaler value */
  MODIFY_REG(huart->Instance->PRESC, USART_PRESC_PRESCALER, huart->Init.ClockPrescaler);
#endif /* USART_PRESC_PRESCALER */

  /*-------------------------- USART BRR Configuration -----------------------*/
  UART_GETCLOCKSOURCE(huart, clocksource);
 80059f4:	687b      	ldr	r3, [r7, #4]
 80059f6:	681b      	ldr	r3, [r3, #0]
 80059f8:	4a99      	ldr	r2, [pc, #612]	; (8005c60 <UART_SetConfig+0x2e8>)
 80059fa:	4293      	cmp	r3, r2
 80059fc:	d121      	bne.n	8005a42 <UART_SetConfig+0xca>
 80059fe:	4b99      	ldr	r3, [pc, #612]	; (8005c64 <UART_SetConfig+0x2ec>)
 8005a00:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8005a04:	f003 0303 	and.w	r3, r3, #3
 8005a08:	2b03      	cmp	r3, #3
 8005a0a:	d817      	bhi.n	8005a3c <UART_SetConfig+0xc4>
 8005a0c:	a201      	add	r2, pc, #4	; (adr r2, 8005a14 <UART_SetConfig+0x9c>)
 8005a0e:	f852 f023 	ldr.w	pc, [r2, r3, lsl #2]
 8005a12:	bf00      	nop
 8005a14:	08005a25 	.word	0x08005a25
 8005a18:	08005a31 	.word	0x08005a31
 8005a1c:	08005a2b 	.word	0x08005a2b
 8005a20:	08005a37 	.word	0x08005a37
 8005a24:	2301      	movs	r3, #1
 8005a26:	76fb      	strb	r3, [r7, #27]
 8005a28:	e0e7      	b.n	8005bfa <UART_SetConfig+0x282>
 8005a2a:	2302      	movs	r3, #2
 8005a2c:	76fb      	strb	r3, [r7, #27]
 8005a2e:	e0e4      	b.n	8005bfa <UART_SetConfig+0x282>
 8005a30:	2304      	movs	r3, #4
 8005a32:	76fb      	strb	r3, [r7, #27]
 8005a34:	e0e1      	b.n	8005bfa <UART_SetConfig+0x282>
 8005a36:	2308      	movs	r3, #8
 8005a38:	76fb      	strb	r3, [r7, #27]
 8005a3a:	e0de      	b.n	8005bfa <UART_SetConfig+0x282>
 8005a3c:	2310      	movs	r3, #16
 8005a3e:	76fb      	strb	r3, [r7, #27]
 8005a40:	e0db      	b.n	8005bfa <UART_SetConfig+0x282>
 8005a42:	687b      	ldr	r3, [r7, #4]
 8005a44:	681b      	ldr	r3, [r3, #0]
 8005a46:	4a88      	ldr	r2, [pc, #544]	; (8005c68 <UART_SetConfig+0x2f0>)
 8005a48:	4293      	cmp	r3, r2
 8005a4a:	d132      	bne.n	8005ab2 <UART_SetConfig+0x13a>
 8005a4c:	4b85      	ldr	r3, [pc, #532]	; (8005c64 <UART_SetConfig+0x2ec>)
 8005a4e:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8005a52:	f003 030c 	and.w	r3, r3, #12
 8005a56:	2b0c      	cmp	r3, #12
 8005a58:	d828      	bhi.n	8005aac <UART_SetConfig+0x134>
 8005a5a:	a201      	add	r2, pc, #4	; (adr r2, 8005a60 <UART_SetConfig+0xe8>)
 8005a5c:	f852 f023 	ldr.w	pc, [r2, r3, lsl #2]
 8005a60:	08005a95 	.word	0x08005a95
 8005a64:	08005aad 	.word	0x08005aad
 8005a68:	08005aad 	.word	0x08005aad
 8005a6c:	08005aad 	.word	0x08005aad
 8005a70:	08005aa1 	.word	0x08005aa1
 8005a74:	08005aad 	.word	0x08005aad
 8005a78:	08005aad 	.word	0x08005aad
 8005a7c:	08005aad 	.word	0x08005aad
 8005a80:	08005a9b 	.word	0x08005a9b
 8005a84:	08005aad 	.word	0x08005aad
 8005a88:	08005aad 	.word	0x08005aad
 8005a8c:	08005aad 	.word	0x08005aad
 8005a90:	08005aa7 	.word	0x08005aa7
 8005a94:	2300      	movs	r3, #0
 8005a96:	76fb      	strb	r3, [r7, #27]
 8005a98:	e0af      	b.n	8005bfa <UART_SetConfig+0x282>
 8005a9a:	2302      	movs	r3, #2
 8005a9c:	76fb      	strb	r3, [r7, #27]
 8005a9e:	e0ac      	b.n	8005bfa <UART_SetConfig+0x282>
 8005aa0:	2304      	movs	r3, #4
 8005aa2:	76fb      	strb	r3, [r7, #27]
 8005aa4:	e0a9      	b.n	8005bfa <UART_SetConfig+0x282>
 8005aa6:	2308      	movs	r3, #8
 8005aa8:	76fb      	strb	r3, [r7, #27]
 8005aaa:	e0a6      	b.n	8005bfa <UART_SetConfig+0x282>
 8005aac:	2310      	movs	r3, #16
 8005aae:	76fb      	strb	r3, [r7, #27]
 8005ab0:	e0a3      	b.n	8005bfa <UART_SetConfig+0x282>
 8005ab2:	687b      	ldr	r3, [r7, #4]
 8005ab4:	681b      	ldr	r3, [r3, #0]
 8005ab6:	4a6d      	ldr	r2, [pc, #436]	; (8005c6c <UART_SetConfig+0x2f4>)
 8005ab8:	4293      	cmp	r3, r2
 8005aba:	d120      	bne.n	8005afe <UART_SetConfig+0x186>
 8005abc:	4b69      	ldr	r3, [pc, #420]	; (8005c64 <UART_SetConfig+0x2ec>)
 8005abe:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8005ac2:	f003 0330 	and.w	r3, r3, #48	; 0x30
 8005ac6:	2b30      	cmp	r3, #48	; 0x30
 8005ac8:	d013      	beq.n	8005af2 <UART_SetConfig+0x17a>
 8005aca:	2b30      	cmp	r3, #48	; 0x30
 8005acc:	d814      	bhi.n	8005af8 <UART_SetConfig+0x180>
 8005ace:	2b20      	cmp	r3, #32
 8005ad0:	d009      	beq.n	8005ae6 <UART_SetConfig+0x16e>
 8005ad2:	2b20      	cmp	r3, #32
 8005ad4:	d810      	bhi.n	8005af8 <UART_SetConfig+0x180>
 8005ad6:	2b00      	cmp	r3, #0
 8005ad8:	d002      	beq.n	8005ae0 <UART_SetConfig+0x168>
 8005ada:	2b10      	cmp	r3, #16
 8005adc:	d006      	beq.n	8005aec <UART_SetConfig+0x174>
 8005ade:	e00b      	b.n	8005af8 <UART_SetConfig+0x180>
 8005ae0:	2300      	movs	r3, #0
 8005ae2:	76fb      	strb	r3, [r7, #27]
 8005ae4:	e089      	b.n	8005bfa <UART_SetConfig+0x282>
 8005ae6:	2302      	movs	r3, #2
 8005ae8:	76fb      	strb	r3, [r7, #27]
 8005aea:	e086      	b.n	8005bfa <UART_SetConfig+0x282>
 8005aec:	2304      	movs	r3, #4
 8005aee:	76fb      	strb	r3, [r7, #27]
 8005af0:	e083      	b.n	8005bfa <UART_SetConfig+0x282>
 8005af2:	2308      	movs	r3, #8
 8005af4:	76fb      	strb	r3, [r7, #27]
 8005af6:	e080      	b.n	8005bfa <UART_SetConfig+0x282>
 8005af8:	2310      	movs	r3, #16
 8005afa:	76fb      	strb	r3, [r7, #27]
 8005afc:	e07d      	b.n	8005bfa <UART_SetConfig+0x282>
 8005afe:	687b      	ldr	r3, [r7, #4]
 8005b00:	681b      	ldr	r3, [r3, #0]
 8005b02:	4a5b      	ldr	r2, [pc, #364]	; (8005c70 <UART_SetConfig+0x2f8>)
 8005b04:	4293      	cmp	r3, r2
 8005b06:	d120      	bne.n	8005b4a <UART_SetConfig+0x1d2>
 8005b08:	4b56      	ldr	r3, [pc, #344]	; (8005c64 <UART_SetConfig+0x2ec>)
 8005b0a:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8005b0e:	f003 03c0 	and.w	r3, r3, #192	; 0xc0
 8005b12:	2bc0      	cmp	r3, #192	; 0xc0
 8005b14:	d013      	beq.n	8005b3e <UART_SetConfig+0x1c6>
 8005b16:	2bc0      	cmp	r3, #192	; 0xc0
 8005b18:	d814      	bhi.n	8005b44 <UART_SetConfig+0x1cc>
 8005b1a:	2b80      	cmp	r3, #128	; 0x80
 8005b1c:	d009      	beq.n	8005b32 <UART_SetConfig+0x1ba>
 8005b1e:	2b80      	cmp	r3, #128	; 0x80
 8005b20:	d810      	bhi.n	8005b44 <UART_SetConfig+0x1cc>
 8005b22:	2b00      	cmp	r3, #0
 8005b24:	d002      	beq.n	8005b2c <UART_SetConfig+0x1b4>
 8005b26:	2b40      	cmp	r3, #64	; 0x40
 8005b28:	d006      	beq.n	8005b38 <UART_SetConfig+0x1c0>
 8005b2a:	e00b      	b.n	8005b44 <UART_SetConfig+0x1cc>
 8005b2c:	2300      	movs	r3, #0
 8005b2e:	76fb      	strb	r3, [r7, #27]
 8005b30:	e063      	b.n	8005bfa <UART_SetConfig+0x282>
 8005b32:	2302      	movs	r3, #2
 8005b34:	76fb      	strb	r3, [r7, #27]
 8005b36:	e060      	b.n	8005bfa <UART_SetConfig+0x282>
 8005b38:	2304      	movs	r3, #4
 8005b3a:	76fb      	strb	r3, [r7, #27]
 8005b3c:	e05d      	b.n	8005bfa <UART_SetConfig+0x282>
 8005b3e:	2308      	movs	r3, #8
 8005b40:	76fb      	strb	r3, [r7, #27]
 8005b42:	e05a      	b.n	8005bfa <UART_SetConfig+0x282>
 8005b44:	2310      	movs	r3, #16
 8005b46:	76fb      	strb	r3, [r7, #27]
 8005b48:	e057      	b.n	8005bfa <UART_SetConfig+0x282>
 8005b4a:	687b      	ldr	r3, [r7, #4]
 8005b4c:	681b      	ldr	r3, [r3, #0]
 8005b4e:	4a49      	ldr	r2, [pc, #292]	; (8005c74 <UART_SetConfig+0x2fc>)
 8005b50:	4293      	cmp	r3, r2
 8005b52:	d125      	bne.n	8005ba0 <UART_SetConfig+0x228>
 8005b54:	4b43      	ldr	r3, [pc, #268]	; (8005c64 <UART_SetConfig+0x2ec>)
 8005b56:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8005b5a:	f403 7340 	and.w	r3, r3, #768	; 0x300
 8005b5e:	f5b3 7f40 	cmp.w	r3, #768	; 0x300
 8005b62:	d017      	beq.n	8005b94 <UART_SetConfig+0x21c>
 8005b64:	f5b3 7f40 	cmp.w	r3, #768	; 0x300
 8005b68:	d817      	bhi.n	8005b9a <UART_SetConfig+0x222>
 8005b6a:	f5b3 7f00 	cmp.w	r3, #512	; 0x200
 8005b6e:	d00b      	beq.n	8005b88 <UART_SetConfig+0x210>
 8005b70:	f5b3 7f00 	cmp.w	r3, #512	; 0x200
 8005b74:	d811      	bhi.n	8005b9a <UART_SetConfig+0x222>
 8005b76:	2b00      	cmp	r3, #0
 8005b78:	d003      	beq.n	8005b82 <UART_SetConfig+0x20a>
 8005b7a:	f5b3 7f80 	cmp.w	r3, #256	; 0x100
 8005b7e:	d006      	beq.n	8005b8e <UART_SetConfig+0x216>
 8005b80:	e00b      	b.n	8005b9a <UART_SetConfig+0x222>
 8005b82:	2300      	movs	r3, #0
 8005b84:	76fb      	strb	r3, [r7, #27]
 8005b86:	e038      	b.n	8005bfa <UART_SetConfig+0x282>
 8005b88:	2302      	movs	r3, #2
 8005b8a:	76fb      	strb	r3, [r7, #27]
 8005b8c:	e035      	b.n	8005bfa <UART_SetConfig+0x282>
 8005b8e:	2304      	movs	r3, #4
 8005b90:	76fb      	strb	r3, [r7, #27]
 8005b92:	e032      	b.n	8005bfa <UART_SetConfig+0x282>
 8005b94:	2308      	movs	r3, #8
 8005b96:	76fb      	strb	r3, [r7, #27]
 8005b98:	e02f      	b.n	8005bfa <UART_SetConfig+0x282>
 8005b9a:	2310      	movs	r3, #16
 8005b9c:	76fb      	strb	r3, [r7, #27]
 8005b9e:	e02c      	b.n	8005bfa <UART_SetConfig+0x282>
 8005ba0:	687b      	ldr	r3, [r7, #4]
 8005ba2:	681b      	ldr	r3, [r3, #0]
 8005ba4:	4a2d      	ldr	r2, [pc, #180]	; (8005c5c <UART_SetConfig+0x2e4>)
 8005ba6:	4293      	cmp	r3, r2
 8005ba8:	d125      	bne.n	8005bf6 <UART_SetConfig+0x27e>
 8005baa:	4b2e      	ldr	r3, [pc, #184]	; (8005c64 <UART_SetConfig+0x2ec>)
 8005bac:	f8d3 3088 	ldr.w	r3, [r3, #136]	; 0x88
 8005bb0:	f403 6340 	and.w	r3, r3, #3072	; 0xc00
 8005bb4:	f5b3 6f40 	cmp.w	r3, #3072	; 0xc00
 8005bb8:	d017      	beq.n	8005bea <UART_SetConfig+0x272>
 8005bba:	f5b3 6f40 	cmp.w	r3, #3072	; 0xc00
 8005bbe:	d817      	bhi.n	8005bf0 <UART_SetConfig+0x278>
 8005bc0:	f5b3 6f00 	cmp.w	r3, #2048	; 0x800
 8005bc4:	d00b      	beq.n	8005bde <UART_SetConfig+0x266>
 8005bc6:	f5b3 6f00 	cmp.w	r3, #2048	; 0x800
 8005bca:	d811      	bhi.n	8005bf0 <UART_SetConfig+0x278>
 8005bcc:	2b00      	cmp	r3, #0
 8005bce:	d003      	beq.n	8005bd8 <UART_SetConfig+0x260>
 8005bd0:	f5b3 6f80 	cmp.w	r3, #1024	; 0x400
 8005bd4:	d006      	beq.n	8005be4 <UART_SetConfig+0x26c>
 8005bd6:	e00b      	b.n	8005bf0 <UART_SetConfig+0x278>
 8005bd8:	2300      	movs	r3, #0
 8005bda:	76fb      	strb	r3, [r7, #27]
 8005bdc:	e00d      	b.n	8005bfa <UART_SetConfig+0x282>
 8005bde:	2302      	movs	r3, #2
 8005be0:	76fb      	strb	r3, [r7, #27]
 8005be2:	e00a      	b.n	8005bfa <UART_SetConfig+0x282>
 8005be4:	2304      	movs	r3, #4
 8005be6:	76fb      	strb	r3, [r7, #27]
 8005be8:	e007      	b.n	8005bfa <UART_SetConfig+0x282>
 8005bea:	2308      	movs	r3, #8
 8005bec:	76fb      	strb	r3, [r7, #27]
 8005bee:	e004      	b.n	8005bfa <UART_SetConfig+0x282>
 8005bf0:	2310      	movs	r3, #16
 8005bf2:	76fb      	strb	r3, [r7, #27]
 8005bf4:	e001      	b.n	8005bfa <UART_SetConfig+0x282>
 8005bf6:	2310      	movs	r3, #16
 8005bf8:	76fb      	strb	r3, [r7, #27]

  /* Check LPUART instance */
  if (UART_INSTANCE_LOWPOWER(huart))
 8005bfa:	687b      	ldr	r3, [r7, #4]
 8005bfc:	681b      	ldr	r3, [r3, #0]
 8005bfe:	4a17      	ldr	r2, [pc, #92]	; (8005c5c <UART_SetConfig+0x2e4>)
 8005c00:	4293      	cmp	r3, r2
 8005c02:	f040 8087 	bne.w	8005d14 <UART_SetConfig+0x39c>
  {
    /* Retrieve frequency clock */
    switch (clocksource)
 8005c06:	7efb      	ldrb	r3, [r7, #27]
 8005c08:	2b08      	cmp	r3, #8
 8005c0a:	d837      	bhi.n	8005c7c <UART_SetConfig+0x304>
 8005c0c:	a201      	add	r2, pc, #4	; (adr r2, 8005c14 <UART_SetConfig+0x29c>)
 8005c0e:	f852 f023 	ldr.w	pc, [r2, r3, lsl #2]
 8005c12:	bf00      	nop
 8005c14:	08005c39 	.word	0x08005c39
 8005c18:	08005c7d 	.word	0x08005c7d
 8005c1c:	08005c41 	.word	0x08005c41
 8005c20:	08005c7d 	.word	0x08005c7d
 8005c24:	08005c47 	.word	0x08005c47
 8005c28:	08005c7d 	.word	0x08005c7d
 8005c2c:	08005c7d 	.word	0x08005c7d
 8005c30:	08005c7d 	.word	0x08005c7d
 8005c34:	08005c4f 	.word	0x08005c4f
    {
      case UART_CLOCKSOURCE_PCLK1:
        pclk = HAL_RCC_GetPCLK1Freq();
 8005c38:	f7fe fd98 	bl	800476c <HAL_RCC_GetPCLK1Freq>
 8005c3c:	6178      	str	r0, [r7, #20]
        break;
 8005c3e:	e022      	b.n	8005c86 <UART_SetConfig+0x30e>
      case UART_CLOCKSOURCE_HSI:
        pclk = (uint32_t) HSI_VALUE;
 8005c40:	4b0d      	ldr	r3, [pc, #52]	; (8005c78 <UART_SetConfig+0x300>)
 8005c42:	617b      	str	r3, [r7, #20]
        break;
 8005c44:	e01f      	b.n	8005c86 <UART_SetConfig+0x30e>
      case UART_CLOCKSOURCE_SYSCLK:
        pclk = HAL_RCC_GetSysClockFreq();
 8005c46:	f7fe fcf9 	bl	800463c <HAL_RCC_GetSysClockFreq>
 8005c4a:	6178      	str	r0, [r7, #20]
        break;
 8005c4c:	e01b      	b.n	8005c86 <UART_SetConfig+0x30e>
      case UART_CLOCKSOURCE_LSE:
        pclk = (uint32_t) LSE_VALUE;
 8005c4e:	f44f 4300 	mov.w	r3, #32768	; 0x8000
 8005c52:	617b      	str	r3, [r7, #20]
        break;
 8005c54:	e017      	b.n	8005c86 <UART_SetConfig+0x30e>
 8005c56:	bf00      	nop
 8005c58:	efff69f3 	.word	0xefff69f3
 8005c5c:	40008000 	.word	0x40008000
 8005c60:	40013800 	.word	0x40013800
 8005c64:	40021000 	.word	0x40021000
 8005c68:	40004400 	.word	0x40004400
 8005c6c:	40004800 	.word	0x40004800
 8005c70:	40004c00 	.word	0x40004c00
 8005c74:	40005000 	.word	0x40005000
 8005c78:	00f42400 	.word	0x00f42400
      default:
        pclk = 0U;
 8005c7c:	2300      	movs	r3, #0
 8005c7e:	617b      	str	r3, [r7, #20]
        ret = HAL_ERROR;
 8005c80:	2301      	movs	r3, #1
 8005c82:	76bb      	strb	r3, [r7, #26]
        break;
 8005c84:	bf00      	nop
    }

    /* If proper clock source reported */
    if (pclk != 0U)
 8005c86:	697b      	ldr	r3, [r7, #20]
 8005c88:	2b00      	cmp	r3, #0
 8005c8a:	f000 80f1 	beq.w	8005e70 <UART_SetConfig+0x4f8>
      } /* if ( (lpuart_ker_ck_pres < (3 * huart->Init.BaudRate) ) ||
                (lpuart_ker_ck_pres > (4096 * huart->Init.BaudRate) )) */
#else
      /* No Prescaler applicable */
      /* Ensure that Frequency clock is in the range [3 * baudrate, 4096 * baudrate] */
      if ((pclk < (3U * huart->Init.BaudRate)) ||
 8005c8e:	687b      	ldr	r3, [r7, #4]
 8005c90:	685a      	ldr	r2, [r3, #4]
 8005c92:	4613      	mov	r3, r2
 8005c94:	005b      	lsls	r3, r3, #1
 8005c96:	4413      	add	r3, r2
 8005c98:	697a      	ldr	r2, [r7, #20]
 8005c9a:	429a      	cmp	r2, r3
 8005c9c:	d305      	bcc.n	8005caa <UART_SetConfig+0x332>
          (pclk > (4096U * huart->Init.BaudRate)))
 8005c9e:	687b      	ldr	r3, [r7, #4]
 8005ca0:	685b      	ldr	r3, [r3, #4]
 8005ca2:	031b      	lsls	r3, r3, #12
      if ((pclk < (3U * huart->Init.BaudRate)) ||
 8005ca4:	697a      	ldr	r2, [r7, #20]
 8005ca6:	429a      	cmp	r2, r3
 8005ca8:	d902      	bls.n	8005cb0 <UART_SetConfig+0x338>
      {
        ret = HAL_ERROR;
 8005caa:	2301      	movs	r3, #1
 8005cac:	76bb      	strb	r3, [r7, #26]
 8005cae:	e0df      	b.n	8005e70 <UART_SetConfig+0x4f8>
      }
      else
      {
        usartdiv = (uint32_t)(UART_DIV_LPUART(pclk, huart->Init.BaudRate));
 8005cb0:	697b      	ldr	r3, [r7, #20]
 8005cb2:	4618      	mov	r0, r3
 8005cb4:	f04f 0100 	mov.w	r1, #0
 8005cb8:	f04f 0200 	mov.w	r2, #0
 8005cbc:	f04f 0300 	mov.w	r3, #0
 8005cc0:	020b      	lsls	r3, r1, #8
 8005cc2:	ea43 6310 	orr.w	r3, r3, r0, lsr #24
 8005cc6:	0202      	lsls	r2, r0, #8
 8005cc8:	6879      	ldr	r1, [r7, #4]
 8005cca:	6849      	ldr	r1, [r1, #4]
 8005ccc:	0849      	lsrs	r1, r1, #1
 8005cce:	4608      	mov	r0, r1
 8005cd0:	f04f 0100 	mov.w	r1, #0
 8005cd4:	1814      	adds	r4, r2, r0
 8005cd6:	eb43 0501 	adc.w	r5, r3, r1
 8005cda:	687b      	ldr	r3, [r7, #4]
 8005cdc:	685b      	ldr	r3, [r3, #4]
 8005cde:	461a      	mov	r2, r3
 8005ce0:	f04f 0300 	mov.w	r3, #0
 8005ce4:	4620      	mov	r0, r4
 8005ce6:	4629      	mov	r1, r5
 8005ce8:	f7fa ffae 	bl	8000c48 <__aeabi_uldivmod>
 8005cec:	4602      	mov	r2, r0
 8005cee:	460b      	mov	r3, r1
 8005cf0:	4613      	mov	r3, r2
 8005cf2:	613b      	str	r3, [r7, #16]
        if ((usartdiv >= LPUART_BRR_MIN) && (usartdiv <= LPUART_BRR_MAX))
 8005cf4:	693b      	ldr	r3, [r7, #16]
 8005cf6:	f5b3 7f40 	cmp.w	r3, #768	; 0x300
 8005cfa:	d308      	bcc.n	8005d0e <UART_SetConfig+0x396>
 8005cfc:	693b      	ldr	r3, [r7, #16]
 8005cfe:	f5b3 1f80 	cmp.w	r3, #1048576	; 0x100000
 8005d02:	d204      	bcs.n	8005d0e <UART_SetConfig+0x396>
        {
          huart->Instance->BRR = usartdiv;
 8005d04:	687b      	ldr	r3, [r7, #4]
 8005d06:	681b      	ldr	r3, [r3, #0]
 8005d08:	693a      	ldr	r2, [r7, #16]
 8005d0a:	60da      	str	r2, [r3, #12]
 8005d0c:	e0b0      	b.n	8005e70 <UART_SetConfig+0x4f8>
        }
        else
        {
          ret = HAL_ERROR;
 8005d0e:	2301      	movs	r3, #1
 8005d10:	76bb      	strb	r3, [r7, #26]
 8005d12:	e0ad      	b.n	8005e70 <UART_SetConfig+0x4f8>
      } /* if ( (pclk < (3 * huart->Init.BaudRate) ) || (pclk > (4096 * huart->Init.BaudRate) )) */
#endif /* USART_PRESC_PRESCALER */
    } /* if (pclk != 0) */
  }
  /* Check UART Over Sampling to set Baud Rate Register */
  else if (huart->Init.OverSampling == UART_OVERSAMPLING_8)
 8005d14:	687b      	ldr	r3, [r7, #4]
 8005d16:	69db      	ldr	r3, [r3, #28]
 8005d18:	f5b3 4f00 	cmp.w	r3, #32768	; 0x8000
 8005d1c:	d15b      	bne.n	8005dd6 <UART_SetConfig+0x45e>
  {
    switch (clocksource)
 8005d1e:	7efb      	ldrb	r3, [r7, #27]
 8005d20:	2b08      	cmp	r3, #8
 8005d22:	d828      	bhi.n	8005d76 <UART_SetConfig+0x3fe>
 8005d24:	a201      	add	r2, pc, #4	; (adr r2, 8005d2c <UART_SetConfig+0x3b4>)
 8005d26:	f852 f023 	ldr.w	pc, [r2, r3, lsl #2]
 8005d2a:	bf00      	nop
 8005d2c:	08005d51 	.word	0x08005d51
 8005d30:	08005d59 	.word	0x08005d59
 8005d34:	08005d61 	.word	0x08005d61
 8005d38:	08005d77 	.word	0x08005d77
 8005d3c:	08005d67 	.word	0x08005d67
 8005d40:	08005d77 	.word	0x08005d77
 8005d44:	08005d77 	.word	0x08005d77
 8005d48:	08005d77 	.word	0x08005d77
 8005d4c:	08005d6f 	.word	0x08005d6f
    {
      case UART_CLOCKSOURCE_PCLK1:
        pclk = HAL_RCC_GetPCLK1Freq();
 8005d50:	f7fe fd0c 	bl	800476c <HAL_RCC_GetPCLK1Freq>
 8005d54:	6178      	str	r0, [r7, #20]
        break;
 8005d56:	e013      	b.n	8005d80 <UART_SetConfig+0x408>
      case UART_CLOCKSOURCE_PCLK2:
        pclk = HAL_RCC_GetPCLK2Freq();
 8005d58:	f7fe fd1e 	bl	8004798 <HAL_RCC_GetPCLK2Freq>
 8005d5c:	6178      	str	r0, [r7, #20]
        break;
 8005d5e:	e00f      	b.n	8005d80 <UART_SetConfig+0x408>
      case UART_CLOCKSOURCE_HSI:
        pclk = (uint32_t) HSI_VALUE;
 8005d60:	4b49      	ldr	r3, [pc, #292]	; (8005e88 <UART_SetConfig+0x510>)
 8005d62:	617b      	str	r3, [r7, #20]
        break;
 8005d64:	e00c      	b.n	8005d80 <UART_SetConfig+0x408>
      case UART_CLOCKSOURCE_SYSCLK:
        pclk = HAL_RCC_GetSysClockFreq();
 8005d66:	f7fe fc69 	bl	800463c <HAL_RCC_GetSysClockFreq>
 8005d6a:	6178      	str	r0, [r7, #20]
        break;
 8005d6c:	e008      	b.n	8005d80 <UART_SetConfig+0x408>
      case UART_CLOCKSOURCE_LSE:
        pclk = (uint32_t) LSE_VALUE;
 8005d6e:	f44f 4300 	mov.w	r3, #32768	; 0x8000
 8005d72:	617b      	str	r3, [r7, #20]
        break;
 8005d74:	e004      	b.n	8005d80 <UART_SetConfig+0x408>
      default:
        pclk = 0U;
 8005d76:	2300      	movs	r3, #0
 8005d78:	617b      	str	r3, [r7, #20]
        ret = HAL_ERROR;
 8005d7a:	2301      	movs	r3, #1
 8005d7c:	76bb      	strb	r3, [r7, #26]
        break;
 8005d7e:	bf00      	nop
    }

    /* USARTDIV must be greater than or equal to 0d16 */
    if (pclk != 0U)
 8005d80:	697b      	ldr	r3, [r7, #20]
 8005d82:	2b00      	cmp	r3, #0
 8005d84:	d074      	beq.n	8005e70 <UART_SetConfig+0x4f8>
    {
#if defined(USART_PRESC_PRESCALER)
      usartdiv = (uint32_t)(UART_DIV_SAMPLING8(pclk, huart->Init.BaudRate, huart->Init.ClockPrescaler));
#else
      usartdiv = (uint32_t)(UART_DIV_SAMPLING8(pclk, huart->Init.BaudRate));
 8005d86:	697b      	ldr	r3, [r7, #20]
 8005d88:	005a      	lsls	r2, r3, #1
 8005d8a:	687b      	ldr	r3, [r7, #4]
 8005d8c:	685b      	ldr	r3, [r3, #4]
 8005d8e:	085b      	lsrs	r3, r3, #1
 8005d90:	441a      	add	r2, r3
 8005d92:	687b      	ldr	r3, [r7, #4]
 8005d94:	685b      	ldr	r3, [r3, #4]
 8005d96:	fbb2 f3f3 	udiv	r3, r2, r3
 8005d9a:	613b      	str	r3, [r7, #16]
#endif /* USART_PRESC_PRESCALER */
      if ((usartdiv >= UART_BRR_MIN) && (usartdiv <= UART_BRR_MAX))
 8005d9c:	693b      	ldr	r3, [r7, #16]
 8005d9e:	2b0f      	cmp	r3, #15
 8005da0:	d916      	bls.n	8005dd0 <UART_SetConfig+0x458>
 8005da2:	693b      	ldr	r3, [r7, #16]
 8005da4:	f5b3 3f80 	cmp.w	r3, #65536	; 0x10000
 8005da8:	d212      	bcs.n	8005dd0 <UART_SetConfig+0x458>
      {
        brrtemp = (uint16_t)(usartdiv & 0xFFF0U);
 8005daa:	693b      	ldr	r3, [r7, #16]
 8005dac:	b29b      	uxth	r3, r3
 8005dae:	f023 030f 	bic.w	r3, r3, #15
 8005db2:	81fb      	strh	r3, [r7, #14]
        brrtemp |= (uint16_t)((usartdiv & (uint16_t)0x000FU) >> 1U);
 8005db4:	693b      	ldr	r3, [r7, #16]
 8005db6:	085b      	lsrs	r3, r3, #1
 8005db8:	b29b      	uxth	r3, r3
 8005dba:	f003 0307 	and.w	r3, r3, #7
 8005dbe:	b29a      	uxth	r2, r3
 8005dc0:	89fb      	ldrh	r3, [r7, #14]
 8005dc2:	4313      	orrs	r3, r2
 8005dc4:	81fb      	strh	r3, [r7, #14]
        huart->Instance->BRR = brrtemp;
 8005dc6:	687b      	ldr	r3, [r7, #4]
 8005dc8:	681b      	ldr	r3, [r3, #0]
 8005dca:	89fa      	ldrh	r2, [r7, #14]
 8005dcc:	60da      	str	r2, [r3, #12]
 8005dce:	e04f      	b.n	8005e70 <UART_SetConfig+0x4f8>
      }
      else
      {
        ret = HAL_ERROR;
 8005dd0:	2301      	movs	r3, #1
 8005dd2:	76bb      	strb	r3, [r7, #26]
 8005dd4:	e04c      	b.n	8005e70 <UART_SetConfig+0x4f8>
      }
    }
  }
  else
  {
    switch (clocksource)
 8005dd6:	7efb      	ldrb	r3, [r7, #27]
 8005dd8:	2b08      	cmp	r3, #8
 8005dda:	d828      	bhi.n	8005e2e <UART_SetConfig+0x4b6>
 8005ddc:	a201      	add	r2, pc, #4	; (adr r2, 8005de4 <UART_SetConfig+0x46c>)
 8005dde:	f852 f023 	ldr.w	pc, [r2, r3, lsl #2]
 8005de2:	bf00      	nop
 8005de4:	08005e09 	.word	0x08005e09
 8005de8:	08005e11 	.word	0x08005e11
 8005dec:	08005e19 	.word	0x08005e19
 8005df0:	08005e2f 	.word	0x08005e2f
 8005df4:	08005e1f 	.word	0x08005e1f
 8005df8:	08005e2f 	.word	0x08005e2f
 8005dfc:	08005e2f 	.word	0x08005e2f
 8005e00:	08005e2f 	.word	0x08005e2f
 8005e04:	08005e27 	.word	0x08005e27
    {
      case UART_CLOCKSOURCE_PCLK1:
        pclk = HAL_RCC_GetPCLK1Freq();
 8005e08:	f7fe fcb0 	bl	800476c <HAL_RCC_GetPCLK1Freq>
 8005e0c:	6178      	str	r0, [r7, #20]
        break;
 8005e0e:	e013      	b.n	8005e38 <UART_SetConfig+0x4c0>
      case UART_CLOCKSOURCE_PCLK2:
        pclk = HAL_RCC_GetPCLK2Freq();
 8005e10:	f7fe fcc2 	bl	8004798 <HAL_RCC_GetPCLK2Freq>
 8005e14:	6178      	str	r0, [r7, #20]
        break;
 8005e16:	e00f      	b.n	8005e38 <UART_SetConfig+0x4c0>
      case UART_CLOCKSOURCE_HSI:
        pclk = (uint32_t) HSI_VALUE;
 8005e18:	4b1b      	ldr	r3, [pc, #108]	; (8005e88 <UART_SetConfig+0x510>)
 8005e1a:	617b      	str	r3, [r7, #20]
        break;
 8005e1c:	e00c      	b.n	8005e38 <UART_SetConfig+0x4c0>
      case UART_CLOCKSOURCE_SYSCLK:
        pclk = HAL_RCC_GetSysClockFreq();
 8005e1e:	f7fe fc0d 	bl	800463c <HAL_RCC_GetSysClockFreq>
 8005e22:	6178      	str	r0, [r7, #20]
        break;
 8005e24:	e008      	b.n	8005e38 <UART_SetConfig+0x4c0>
      case UART_CLOCKSOURCE_LSE:
        pclk = (uint32_t) LSE_VALUE;
 8005e26:	f44f 4300 	mov.w	r3, #32768	; 0x8000
 8005e2a:	617b      	str	r3, [r7, #20]
        break;
 8005e2c:	e004      	b.n	8005e38 <UART_SetConfig+0x4c0>
      default:
        pclk = 0U;
 8005e2e:	2300      	movs	r3, #0
 8005e30:	617b      	str	r3, [r7, #20]
        ret = HAL_ERROR;
 8005e32:	2301      	movs	r3, #1
 8005e34:	76bb      	strb	r3, [r7, #26]
        break;
 8005e36:	bf00      	nop
    }

    if (pclk != 0U)
 8005e38:	697b      	ldr	r3, [r7, #20]
 8005e3a:	2b00      	cmp	r3, #0
 8005e3c:	d018      	beq.n	8005e70 <UART_SetConfig+0x4f8>
    {
      /* USARTDIV must be greater than or equal to 0d16 */
#if defined(USART_PRESC_PRESCALER)
      usartdiv = (uint32_t)(UART_DIV_SAMPLING16(pclk, huart->Init.BaudRate, huart->Init.ClockPrescaler));
#else
      usartdiv = (uint32_t)(UART_DIV_SAMPLING16(pclk, huart->Init.BaudRate));
 8005e3e:	687b      	ldr	r3, [r7, #4]
 8005e40:	685b      	ldr	r3, [r3, #4]
 8005e42:	085a      	lsrs	r2, r3, #1
 8005e44:	697b      	ldr	r3, [r7, #20]
 8005e46:	441a      	add	r2, r3
 8005e48:	687b      	ldr	r3, [r7, #4]
 8005e4a:	685b      	ldr	r3, [r3, #4]
 8005e4c:	fbb2 f3f3 	udiv	r3, r2, r3
 8005e50:	613b      	str	r3, [r7, #16]
#endif /* USART_PRESC_PRESCALER */
      if ((usartdiv >= UART_BRR_MIN) && (usartdiv <= UART_BRR_MAX))
 8005e52:	693b      	ldr	r3, [r7, #16]
 8005e54:	2b0f      	cmp	r3, #15
 8005e56:	d909      	bls.n	8005e6c <UART_SetConfig+0x4f4>
 8005e58:	693b      	ldr	r3, [r7, #16]
 8005e5a:	f5b3 3f80 	cmp.w	r3, #65536	; 0x10000
 8005e5e:	d205      	bcs.n	8005e6c <UART_SetConfig+0x4f4>
      {
        huart->Instance->BRR = (uint16_t)usartdiv;
 8005e60:	693b      	ldr	r3, [r7, #16]
 8005e62:	b29a      	uxth	r2, r3
 8005e64:	687b      	ldr	r3, [r7, #4]
 8005e66:	681b      	ldr	r3, [r3, #0]
 8005e68:	60da      	str	r2, [r3, #12]
 8005e6a:	e001      	b.n	8005e70 <UART_SetConfig+0x4f8>
      }
      else
      {
        ret = HAL_ERROR;
 8005e6c:	2301      	movs	r3, #1
 8005e6e:	76bb      	strb	r3, [r7, #26]
  huart->NbTxDataToProcess = 1;
  huart->NbRxDataToProcess = 1;
#endif /* USART_CR1_FIFOEN */

  /* Clear ISR function pointers */
  huart->RxISR = NULL;
 8005e70:	687b      	ldr	r3, [r7, #4]
 8005e72:	2200      	movs	r2, #0
 8005e74:	665a      	str	r2, [r3, #100]	; 0x64
  huart->TxISR = NULL;
 8005e76:	687b      	ldr	r3, [r7, #4]
 8005e78:	2200      	movs	r2, #0
 8005e7a:	669a      	str	r2, [r3, #104]	; 0x68

  return ret;
 8005e7c:	7ebb      	ldrb	r3, [r7, #26]
}
 8005e7e:	4618      	mov	r0, r3
 8005e80:	3720      	adds	r7, #32
 8005e82:	46bd      	mov	sp, r7
 8005e84:	bdb0      	pop	{r4, r5, r7, pc}
 8005e86:	bf00      	nop
 8005e88:	00f42400 	.word	0x00f42400

08005e8c <UART_AdvFeatureConfig>:
  * @brief Configure the UART peripheral advanced features.
  * @param huart UART handle.
  * @retval None
  */
void UART_AdvFeatureConfig(UART_HandleTypeDef *huart)
{
 8005e8c:	b480      	push	{r7}
 8005e8e:	b083      	sub	sp, #12
 8005e90:	af00      	add	r7, sp, #0
 8005e92:	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))
 8005e94:	687b      	ldr	r3, [r7, #4]
 8005e96:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8005e98:	f003 0301 	and.w	r3, r3, #1
 8005e9c:	2b00      	cmp	r3, #0
 8005e9e:	d00a      	beq.n	8005eb6 <UART_AdvFeatureConfig+0x2a>
  {
    assert_param(IS_UART_ADVFEATURE_TXINV(huart->AdvancedInit.TxPinLevelInvert));
    MODIFY_REG(huart->Instance->CR2, USART_CR2_TXINV, huart->AdvancedInit.TxPinLevelInvert);
 8005ea0:	687b      	ldr	r3, [r7, #4]
 8005ea2:	681b      	ldr	r3, [r3, #0]
 8005ea4:	685b      	ldr	r3, [r3, #4]
 8005ea6:	f423 3100 	bic.w	r1, r3, #131072	; 0x20000
 8005eaa:	687b      	ldr	r3, [r7, #4]
 8005eac:	6a9a      	ldr	r2, [r3, #40]	; 0x28
 8005eae:	687b      	ldr	r3, [r7, #4]
 8005eb0:	681b      	ldr	r3, [r3, #0]
 8005eb2:	430a      	orrs	r2, r1
 8005eb4:	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))
 8005eb6:	687b      	ldr	r3, [r7, #4]
 8005eb8:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8005eba:	f003 0302 	and.w	r3, r3, #2
 8005ebe:	2b00      	cmp	r3, #0
 8005ec0:	d00a      	beq.n	8005ed8 <UART_AdvFeatureConfig+0x4c>
  {
    assert_param(IS_UART_ADVFEATURE_RXINV(huart->AdvancedInit.RxPinLevelInvert));
    MODIFY_REG(huart->Instance->CR2, USART_CR2_RXINV, huart->AdvancedInit.RxPinLevelInvert);
 8005ec2:	687b      	ldr	r3, [r7, #4]
 8005ec4:	681b      	ldr	r3, [r3, #0]
 8005ec6:	685b      	ldr	r3, [r3, #4]
 8005ec8:	f423 3180 	bic.w	r1, r3, #65536	; 0x10000
 8005ecc:	687b      	ldr	r3, [r7, #4]
 8005ece:	6ada      	ldr	r2, [r3, #44]	; 0x2c
 8005ed0:	687b      	ldr	r3, [r7, #4]
 8005ed2:	681b      	ldr	r3, [r3, #0]
 8005ed4:	430a      	orrs	r2, r1
 8005ed6:	605a      	str	r2, [r3, #4]
  }

  /* if required, configure data inversion */
  if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_DATAINVERT_INIT))
 8005ed8:	687b      	ldr	r3, [r7, #4]
 8005eda:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8005edc:	f003 0304 	and.w	r3, r3, #4
 8005ee0:	2b00      	cmp	r3, #0
 8005ee2:	d00a      	beq.n	8005efa <UART_AdvFeatureConfig+0x6e>
  {
    assert_param(IS_UART_ADVFEATURE_DATAINV(huart->AdvancedInit.DataInvert));
    MODIFY_REG(huart->Instance->CR2, USART_CR2_DATAINV, huart->AdvancedInit.DataInvert);
 8005ee4:	687b      	ldr	r3, [r7, #4]
 8005ee6:	681b      	ldr	r3, [r3, #0]
 8005ee8:	685b      	ldr	r3, [r3, #4]
 8005eea:	f423 2180 	bic.w	r1, r3, #262144	; 0x40000
 8005eee:	687b      	ldr	r3, [r7, #4]
 8005ef0:	6b1a      	ldr	r2, [r3, #48]	; 0x30
 8005ef2:	687b      	ldr	r3, [r7, #4]
 8005ef4:	681b      	ldr	r3, [r3, #0]
 8005ef6:	430a      	orrs	r2, r1
 8005ef8:	605a      	str	r2, [r3, #4]
  }

  /* if required, configure RX/TX pins swap */
  if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_SWAP_INIT))
 8005efa:	687b      	ldr	r3, [r7, #4]
 8005efc:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8005efe:	f003 0308 	and.w	r3, r3, #8
 8005f02:	2b00      	cmp	r3, #0
 8005f04:	d00a      	beq.n	8005f1c <UART_AdvFeatureConfig+0x90>
  {
    assert_param(IS_UART_ADVFEATURE_SWAP(huart->AdvancedInit.Swap));
    MODIFY_REG(huart->Instance->CR2, USART_CR2_SWAP, huart->AdvancedInit.Swap);
 8005f06:	687b      	ldr	r3, [r7, #4]
 8005f08:	681b      	ldr	r3, [r3, #0]
 8005f0a:	685b      	ldr	r3, [r3, #4]
 8005f0c:	f423 4100 	bic.w	r1, r3, #32768	; 0x8000
 8005f10:	687b      	ldr	r3, [r7, #4]
 8005f12:	6b5a      	ldr	r2, [r3, #52]	; 0x34
 8005f14:	687b      	ldr	r3, [r7, #4]
 8005f16:	681b      	ldr	r3, [r3, #0]
 8005f18:	430a      	orrs	r2, r1
 8005f1a:	605a      	str	r2, [r3, #4]
  }

  /* if required, configure RX overrun detection disabling */
  if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_RXOVERRUNDISABLE_INIT))
 8005f1c:	687b      	ldr	r3, [r7, #4]
 8005f1e:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8005f20:	f003 0310 	and.w	r3, r3, #16
 8005f24:	2b00      	cmp	r3, #0
 8005f26:	d00a      	beq.n	8005f3e <UART_AdvFeatureConfig+0xb2>
  {
    assert_param(IS_UART_OVERRUN(huart->AdvancedInit.OverrunDisable));
    MODIFY_REG(huart->Instance->CR3, USART_CR3_OVRDIS, huart->AdvancedInit.OverrunDisable);
 8005f28:	687b      	ldr	r3, [r7, #4]
 8005f2a:	681b      	ldr	r3, [r3, #0]
 8005f2c:	689b      	ldr	r3, [r3, #8]
 8005f2e:	f423 5180 	bic.w	r1, r3, #4096	; 0x1000
 8005f32:	687b      	ldr	r3, [r7, #4]
 8005f34:	6b9a      	ldr	r2, [r3, #56]	; 0x38
 8005f36:	687b      	ldr	r3, [r7, #4]
 8005f38:	681b      	ldr	r3, [r3, #0]
 8005f3a:	430a      	orrs	r2, r1
 8005f3c:	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))
 8005f3e:	687b      	ldr	r3, [r7, #4]
 8005f40:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8005f42:	f003 0320 	and.w	r3, r3, #32
 8005f46:	2b00      	cmp	r3, #0
 8005f48:	d00a      	beq.n	8005f60 <UART_AdvFeatureConfig+0xd4>
  {
    assert_param(IS_UART_ADVFEATURE_DMAONRXERROR(huart->AdvancedInit.DMADisableonRxError));
    MODIFY_REG(huart->Instance->CR3, USART_CR3_DDRE, huart->AdvancedInit.DMADisableonRxError);
 8005f4a:	687b      	ldr	r3, [r7, #4]
 8005f4c:	681b      	ldr	r3, [r3, #0]
 8005f4e:	689b      	ldr	r3, [r3, #8]
 8005f50:	f423 5100 	bic.w	r1, r3, #8192	; 0x2000
 8005f54:	687b      	ldr	r3, [r7, #4]
 8005f56:	6bda      	ldr	r2, [r3, #60]	; 0x3c
 8005f58:	687b      	ldr	r3, [r7, #4]
 8005f5a:	681b      	ldr	r3, [r3, #0]
 8005f5c:	430a      	orrs	r2, r1
 8005f5e:	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))
 8005f60:	687b      	ldr	r3, [r7, #4]
 8005f62:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8005f64:	f003 0340 	and.w	r3, r3, #64	; 0x40
 8005f68:	2b00      	cmp	r3, #0
 8005f6a:	d01a      	beq.n	8005fa2 <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);
 8005f6c:	687b      	ldr	r3, [r7, #4]
 8005f6e:	681b      	ldr	r3, [r3, #0]
 8005f70:	685b      	ldr	r3, [r3, #4]
 8005f72:	f423 1180 	bic.w	r1, r3, #1048576	; 0x100000
 8005f76:	687b      	ldr	r3, [r7, #4]
 8005f78:	6c1a      	ldr	r2, [r3, #64]	; 0x40
 8005f7a:	687b      	ldr	r3, [r7, #4]
 8005f7c:	681b      	ldr	r3, [r3, #0]
 8005f7e:	430a      	orrs	r2, r1
 8005f80:	605a      	str	r2, [r3, #4]
    /* set auto Baudrate detection parameters if detection is enabled */
    if (huart->AdvancedInit.AutoBaudRateEnable == UART_ADVFEATURE_AUTOBAUDRATE_ENABLE)
 8005f82:	687b      	ldr	r3, [r7, #4]
 8005f84:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 8005f86:	f5b3 1f80 	cmp.w	r3, #1048576	; 0x100000
 8005f8a:	d10a      	bne.n	8005fa2 <UART_AdvFeatureConfig+0x116>
    {
      assert_param(IS_UART_ADVFEATURE_AUTOBAUDRATEMODE(huart->AdvancedInit.AutoBaudRateMode));
      MODIFY_REG(huart->Instance->CR2, USART_CR2_ABRMODE, huart->AdvancedInit.AutoBaudRateMode);
 8005f8c:	687b      	ldr	r3, [r7, #4]
 8005f8e:	681b      	ldr	r3, [r3, #0]
 8005f90:	685b      	ldr	r3, [r3, #4]
 8005f92:	f423 01c0 	bic.w	r1, r3, #6291456	; 0x600000
 8005f96:	687b      	ldr	r3, [r7, #4]
 8005f98:	6c5a      	ldr	r2, [r3, #68]	; 0x44
 8005f9a:	687b      	ldr	r3, [r7, #4]
 8005f9c:	681b      	ldr	r3, [r3, #0]
 8005f9e:	430a      	orrs	r2, r1
 8005fa0:	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))
 8005fa2:	687b      	ldr	r3, [r7, #4]
 8005fa4:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8005fa6:	f003 0380 	and.w	r3, r3, #128	; 0x80
 8005faa:	2b00      	cmp	r3, #0
 8005fac:	d00a      	beq.n	8005fc4 <UART_AdvFeatureConfig+0x138>
  {
    assert_param(IS_UART_ADVFEATURE_MSBFIRST(huart->AdvancedInit.MSBFirst));
    MODIFY_REG(huart->Instance->CR2, USART_CR2_MSBFIRST, huart->AdvancedInit.MSBFirst);
 8005fae:	687b      	ldr	r3, [r7, #4]
 8005fb0:	681b      	ldr	r3, [r3, #0]
 8005fb2:	685b      	ldr	r3, [r3, #4]
 8005fb4:	f423 2100 	bic.w	r1, r3, #524288	; 0x80000
 8005fb8:	687b      	ldr	r3, [r7, #4]
 8005fba:	6c9a      	ldr	r2, [r3, #72]	; 0x48
 8005fbc:	687b      	ldr	r3, [r7, #4]
 8005fbe:	681b      	ldr	r3, [r3, #0]
 8005fc0:	430a      	orrs	r2, r1
 8005fc2:	605a      	str	r2, [r3, #4]
  }
}
 8005fc4:	bf00      	nop
 8005fc6:	370c      	adds	r7, #12
 8005fc8:	46bd      	mov	sp, r7
 8005fca:	f85d 7b04 	ldr.w	r7, [sp], #4
 8005fce:	4770      	bx	lr

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

  /* Initialize the UART ErrorCode */
  huart->ErrorCode = HAL_UART_ERROR_NONE;
 8005fd8:	687b      	ldr	r3, [r7, #4]
 8005fda:	2200      	movs	r2, #0
 8005fdc:	f8c3 2080 	str.w	r2, [r3, #128]	; 0x80

  /* Init tickstart for timeout management */
  tickstart = HAL_GetTick();
 8005fe0:	f7fc f800 	bl	8001fe4 <HAL_GetTick>
 8005fe4:	60f8      	str	r0, [r7, #12]

  /* Check if the Transmitter is enabled */
  if ((huart->Instance->CR1 & USART_CR1_TE) == USART_CR1_TE)
 8005fe6:	687b      	ldr	r3, [r7, #4]
 8005fe8:	681b      	ldr	r3, [r3, #0]
 8005fea:	681b      	ldr	r3, [r3, #0]
 8005fec:	f003 0308 	and.w	r3, r3, #8
 8005ff0:	2b08      	cmp	r3, #8
 8005ff2:	d10e      	bne.n	8006012 <UART_CheckIdleState+0x42>
  {
    /* Wait until TEACK flag is set */
    if (UART_WaitOnFlagUntilTimeout(huart, USART_ISR_TEACK, RESET, tickstart, HAL_UART_TIMEOUT_VALUE) != HAL_OK)
 8005ff4:	f06f 437e 	mvn.w	r3, #4261412864	; 0xfe000000
 8005ff8:	9300      	str	r3, [sp, #0]
 8005ffa:	68fb      	ldr	r3, [r7, #12]
 8005ffc:	2200      	movs	r2, #0
 8005ffe:	f44f 1100 	mov.w	r1, #2097152	; 0x200000
 8006002:	6878      	ldr	r0, [r7, #4]
 8006004:	f000 f82d 	bl	8006062 <UART_WaitOnFlagUntilTimeout>
 8006008:	4603      	mov	r3, r0
 800600a:	2b00      	cmp	r3, #0
 800600c:	d001      	beq.n	8006012 <UART_CheckIdleState+0x42>
    {
      /* Timeout occurred */
      return HAL_TIMEOUT;
 800600e:	2303      	movs	r3, #3
 8006010:	e023      	b.n	800605a <UART_CheckIdleState+0x8a>
    }
  }

  /* Check if the Receiver is enabled */
  if ((huart->Instance->CR1 & USART_CR1_RE) == USART_CR1_RE)
 8006012:	687b      	ldr	r3, [r7, #4]
 8006014:	681b      	ldr	r3, [r3, #0]
 8006016:	681b      	ldr	r3, [r3, #0]
 8006018:	f003 0304 	and.w	r3, r3, #4
 800601c:	2b04      	cmp	r3, #4
 800601e:	d10e      	bne.n	800603e <UART_CheckIdleState+0x6e>
  {
    /* Wait until REACK flag is set */
    if (UART_WaitOnFlagUntilTimeout(huart, USART_ISR_REACK, RESET, tickstart, HAL_UART_TIMEOUT_VALUE) != HAL_OK)
 8006020:	f06f 437e 	mvn.w	r3, #4261412864	; 0xfe000000
 8006024:	9300      	str	r3, [sp, #0]
 8006026:	68fb      	ldr	r3, [r7, #12]
 8006028:	2200      	movs	r2, #0
 800602a:	f44f 0180 	mov.w	r1, #4194304	; 0x400000
 800602e:	6878      	ldr	r0, [r7, #4]
 8006030:	f000 f817 	bl	8006062 <UART_WaitOnFlagUntilTimeout>
 8006034:	4603      	mov	r3, r0
 8006036:	2b00      	cmp	r3, #0
 8006038:	d001      	beq.n	800603e <UART_CheckIdleState+0x6e>
    {
      /* Timeout occurred */
      return HAL_TIMEOUT;
 800603a:	2303      	movs	r3, #3
 800603c:	e00d      	b.n	800605a <UART_CheckIdleState+0x8a>
    }
  }

  /* Initialize the UART State */
  huart->gState = HAL_UART_STATE_READY;
 800603e:	687b      	ldr	r3, [r7, #4]
 8006040:	2220      	movs	r2, #32
 8006042:	679a      	str	r2, [r3, #120]	; 0x78
  huart->RxState = HAL_UART_STATE_READY;
 8006044:	687b      	ldr	r3, [r7, #4]
 8006046:	2220      	movs	r2, #32
 8006048:	67da      	str	r2, [r3, #124]	; 0x7c
  huart->ReceptionType = HAL_UART_RECEPTION_STANDARD;
 800604a:	687b      	ldr	r3, [r7, #4]
 800604c:	2200      	movs	r2, #0
 800604e:	661a      	str	r2, [r3, #96]	; 0x60

  __HAL_UNLOCK(huart);
 8006050:	687b      	ldr	r3, [r7, #4]
 8006052:	2200      	movs	r2, #0
 8006054:	f883 2074 	strb.w	r2, [r3, #116]	; 0x74

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

08006062 <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)
{
 8006062:	b580      	push	{r7, lr}
 8006064:	b09c      	sub	sp, #112	; 0x70
 8006066:	af00      	add	r7, sp, #0
 8006068:	60f8      	str	r0, [r7, #12]
 800606a:	60b9      	str	r1, [r7, #8]
 800606c:	603b      	str	r3, [r7, #0]
 800606e:	4613      	mov	r3, r2
 8006070:	71fb      	strb	r3, [r7, #7]
  /* Wait until flag is set */
  while ((__HAL_UART_GET_FLAG(huart, Flag) ? SET : RESET) == Status)
 8006072:	e0a5      	b.n	80061c0 <UART_WaitOnFlagUntilTimeout+0x15e>
  {
    /* Check for the Timeout */
    if (Timeout != HAL_MAX_DELAY)
 8006074:	6fbb      	ldr	r3, [r7, #120]	; 0x78
 8006076:	f1b3 3fff 	cmp.w	r3, #4294967295
 800607a:	f000 80a1 	beq.w	80061c0 <UART_WaitOnFlagUntilTimeout+0x15e>
    {
      if (((HAL_GetTick() - Tickstart) > Timeout) || (Timeout == 0U))
 800607e:	f7fb ffb1 	bl	8001fe4 <HAL_GetTick>
 8006082:	4602      	mov	r2, r0
 8006084:	683b      	ldr	r3, [r7, #0]
 8006086:	1ad3      	subs	r3, r2, r3
 8006088:	6fba      	ldr	r2, [r7, #120]	; 0x78
 800608a:	429a      	cmp	r2, r3
 800608c:	d302      	bcc.n	8006094 <UART_WaitOnFlagUntilTimeout+0x32>
 800608e:	6fbb      	ldr	r3, [r7, #120]	; 0x78
 8006090:	2b00      	cmp	r3, #0
 8006092:	d13e      	bne.n	8006112 <UART_WaitOnFlagUntilTimeout+0xb0>
           interrupts for the interrupt process */
#if defined(USART_CR1_FIFOEN)
        ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE_RXFNEIE | USART_CR1_PEIE |
                                                USART_CR1_TXEIE_TXFNFIE));
#else
        ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE));
 8006094:	68fb      	ldr	r3, [r7, #12]
 8006096:	681b      	ldr	r3, [r3, #0]
 8006098:	653b      	str	r3, [r7, #80]	; 0x50
 */
__STATIC_FORCEINLINE uint32_t __LDREXW(volatile uint32_t *addr)
{
    uint32_t result;

   __ASM volatile ("ldrex %0, %1" : "=r" (result) : "Q" (*addr) );
 800609a:	6d3b      	ldr	r3, [r7, #80]	; 0x50
 800609c:	e853 3f00 	ldrex	r3, [r3]
 80060a0:	64fb      	str	r3, [r7, #76]	; 0x4c
   return(result);
 80060a2:	6cfb      	ldr	r3, [r7, #76]	; 0x4c
 80060a4:	f423 73d0 	bic.w	r3, r3, #416	; 0x1a0
 80060a8:	667b      	str	r3, [r7, #100]	; 0x64
 80060aa:	68fb      	ldr	r3, [r7, #12]
 80060ac:	681b      	ldr	r3, [r3, #0]
 80060ae:	461a      	mov	r2, r3
 80060b0:	6e7b      	ldr	r3, [r7, #100]	; 0x64
 80060b2:	65fb      	str	r3, [r7, #92]	; 0x5c
 80060b4:	65ba      	str	r2, [r7, #88]	; 0x58
 */
__STATIC_FORCEINLINE uint32_t __STREXW(uint32_t value, volatile uint32_t *addr)
{
   uint32_t result;

   __ASM volatile ("strex %0, %2, %1" : "=&r" (result), "=Q" (*addr) : "r" (value) );
 80060b6:	6db9      	ldr	r1, [r7, #88]	; 0x58
 80060b8:	6dfa      	ldr	r2, [r7, #92]	; 0x5c
 80060ba:	e841 2300 	strex	r3, r2, [r1]
 80060be:	657b      	str	r3, [r7, #84]	; 0x54
   return(result);
 80060c0:	6d7b      	ldr	r3, [r7, #84]	; 0x54
 80060c2:	2b00      	cmp	r3, #0
 80060c4:	d1e6      	bne.n	8006094 <UART_WaitOnFlagUntilTimeout+0x32>
#endif /* USART_CR1_FIFOEN */
        ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE);
 80060c6:	68fb      	ldr	r3, [r7, #12]
 80060c8:	681b      	ldr	r3, [r3, #0]
 80060ca:	3308      	adds	r3, #8
 80060cc:	63fb      	str	r3, [r7, #60]	; 0x3c
   __ASM volatile ("ldrex %0, %1" : "=r" (result) : "Q" (*addr) );
 80060ce:	6bfb      	ldr	r3, [r7, #60]	; 0x3c
 80060d0:	e853 3f00 	ldrex	r3, [r3]
 80060d4:	63bb      	str	r3, [r7, #56]	; 0x38
   return(result);
 80060d6:	6bbb      	ldr	r3, [r7, #56]	; 0x38
 80060d8:	f023 0301 	bic.w	r3, r3, #1
 80060dc:	663b      	str	r3, [r7, #96]	; 0x60
 80060de:	68fb      	ldr	r3, [r7, #12]
 80060e0:	681b      	ldr	r3, [r3, #0]
 80060e2:	3308      	adds	r3, #8
 80060e4:	6e3a      	ldr	r2, [r7, #96]	; 0x60
 80060e6:	64ba      	str	r2, [r7, #72]	; 0x48
 80060e8:	647b      	str	r3, [r7, #68]	; 0x44
   __ASM volatile ("strex %0, %2, %1" : "=&r" (result), "=Q" (*addr) : "r" (value) );
 80060ea:	6c79      	ldr	r1, [r7, #68]	; 0x44
 80060ec:	6cba      	ldr	r2, [r7, #72]	; 0x48
 80060ee:	e841 2300 	strex	r3, r2, [r1]
 80060f2:	643b      	str	r3, [r7, #64]	; 0x40
   return(result);
 80060f4:	6c3b      	ldr	r3, [r7, #64]	; 0x40
 80060f6:	2b00      	cmp	r3, #0
 80060f8:	d1e5      	bne.n	80060c6 <UART_WaitOnFlagUntilTimeout+0x64>

        huart->gState = HAL_UART_STATE_READY;
 80060fa:	68fb      	ldr	r3, [r7, #12]
 80060fc:	2220      	movs	r2, #32
 80060fe:	679a      	str	r2, [r3, #120]	; 0x78
        huart->RxState = HAL_UART_STATE_READY;
 8006100:	68fb      	ldr	r3, [r7, #12]
 8006102:	2220      	movs	r2, #32
 8006104:	67da      	str	r2, [r3, #124]	; 0x7c

        __HAL_UNLOCK(huart);
 8006106:	68fb      	ldr	r3, [r7, #12]
 8006108:	2200      	movs	r2, #0
 800610a:	f883 2074 	strb.w	r2, [r3, #116]	; 0x74

        return HAL_TIMEOUT;
 800610e:	2303      	movs	r3, #3
 8006110:	e067      	b.n	80061e2 <UART_WaitOnFlagUntilTimeout+0x180>
      }

      if (READ_BIT(huart->Instance->CR1, USART_CR1_RE) != 0U)
 8006112:	68fb      	ldr	r3, [r7, #12]
 8006114:	681b      	ldr	r3, [r3, #0]
 8006116:	681b      	ldr	r3, [r3, #0]
 8006118:	f003 0304 	and.w	r3, r3, #4
 800611c:	2b00      	cmp	r3, #0
 800611e:	d04f      	beq.n	80061c0 <UART_WaitOnFlagUntilTimeout+0x15e>
      {
        if (__HAL_UART_GET_FLAG(huart, UART_FLAG_RTOF) == SET)
 8006120:	68fb      	ldr	r3, [r7, #12]
 8006122:	681b      	ldr	r3, [r3, #0]
 8006124:	69db      	ldr	r3, [r3, #28]
 8006126:	f403 6300 	and.w	r3, r3, #2048	; 0x800
 800612a:	f5b3 6f00 	cmp.w	r3, #2048	; 0x800
 800612e:	d147      	bne.n	80061c0 <UART_WaitOnFlagUntilTimeout+0x15e>
        {
          /* Clear Receiver Timeout flag*/
          __HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_RTOF);
 8006130:	68fb      	ldr	r3, [r7, #12]
 8006132:	681b      	ldr	r3, [r3, #0]
 8006134:	f44f 6200 	mov.w	r2, #2048	; 0x800
 8006138:	621a      	str	r2, [r3, #32]
             interrupts for the interrupt process */
#if defined(USART_CR1_FIFOEN)
          ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE_RXFNEIE | USART_CR1_PEIE |
                                                  USART_CR1_TXEIE_TXFNFIE));
#else
          ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE));
 800613a:	68fb      	ldr	r3, [r7, #12]
 800613c:	681b      	ldr	r3, [r3, #0]
 800613e:	62bb      	str	r3, [r7, #40]	; 0x28
   __ASM volatile ("ldrex %0, %1" : "=r" (result) : "Q" (*addr) );
 8006140:	6abb      	ldr	r3, [r7, #40]	; 0x28
 8006142:	e853 3f00 	ldrex	r3, [r3]
 8006146:	627b      	str	r3, [r7, #36]	; 0x24
   return(result);
 8006148:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 800614a:	f423 73d0 	bic.w	r3, r3, #416	; 0x1a0
 800614e:	66fb      	str	r3, [r7, #108]	; 0x6c
 8006150:	68fb      	ldr	r3, [r7, #12]
 8006152:	681b      	ldr	r3, [r3, #0]
 8006154:	461a      	mov	r2, r3
 8006156:	6efb      	ldr	r3, [r7, #108]	; 0x6c
 8006158:	637b      	str	r3, [r7, #52]	; 0x34
 800615a:	633a      	str	r2, [r7, #48]	; 0x30
   __ASM volatile ("strex %0, %2, %1" : "=&r" (result), "=Q" (*addr) : "r" (value) );
 800615c:	6b39      	ldr	r1, [r7, #48]	; 0x30
 800615e:	6b7a      	ldr	r2, [r7, #52]	; 0x34
 8006160:	e841 2300 	strex	r3, r2, [r1]
 8006164:	62fb      	str	r3, [r7, #44]	; 0x2c
   return(result);
 8006166:	6afb      	ldr	r3, [r7, #44]	; 0x2c
 8006168:	2b00      	cmp	r3, #0
 800616a:	d1e6      	bne.n	800613a <UART_WaitOnFlagUntilTimeout+0xd8>
#endif
          ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE);
 800616c:	68fb      	ldr	r3, [r7, #12]
 800616e:	681b      	ldr	r3, [r3, #0]
 8006170:	3308      	adds	r3, #8
 8006172:	617b      	str	r3, [r7, #20]
   __ASM volatile ("ldrex %0, %1" : "=r" (result) : "Q" (*addr) );
 8006174:	697b      	ldr	r3, [r7, #20]
 8006176:	e853 3f00 	ldrex	r3, [r3]
 800617a:	613b      	str	r3, [r7, #16]
   return(result);
 800617c:	693b      	ldr	r3, [r7, #16]
 800617e:	f023 0301 	bic.w	r3, r3, #1
 8006182:	66bb      	str	r3, [r7, #104]	; 0x68
 8006184:	68fb      	ldr	r3, [r7, #12]
 8006186:	681b      	ldr	r3, [r3, #0]
 8006188:	3308      	adds	r3, #8
 800618a:	6eba      	ldr	r2, [r7, #104]	; 0x68
 800618c:	623a      	str	r2, [r7, #32]
 800618e:	61fb      	str	r3, [r7, #28]
   __ASM volatile ("strex %0, %2, %1" : "=&r" (result), "=Q" (*addr) : "r" (value) );
 8006190:	69f9      	ldr	r1, [r7, #28]
 8006192:	6a3a      	ldr	r2, [r7, #32]
 8006194:	e841 2300 	strex	r3, r2, [r1]
 8006198:	61bb      	str	r3, [r7, #24]
   return(result);
 800619a:	69bb      	ldr	r3, [r7, #24]
 800619c:	2b00      	cmp	r3, #0
 800619e:	d1e5      	bne.n	800616c <UART_WaitOnFlagUntilTimeout+0x10a>

          huart->gState = HAL_UART_STATE_READY;
 80061a0:	68fb      	ldr	r3, [r7, #12]
 80061a2:	2220      	movs	r2, #32
 80061a4:	679a      	str	r2, [r3, #120]	; 0x78
          huart->RxState = HAL_UART_STATE_READY;
 80061a6:	68fb      	ldr	r3, [r7, #12]
 80061a8:	2220      	movs	r2, #32
 80061aa:	67da      	str	r2, [r3, #124]	; 0x7c
          huart->ErrorCode = HAL_UART_ERROR_RTO;
 80061ac:	68fb      	ldr	r3, [r7, #12]
 80061ae:	2220      	movs	r2, #32
 80061b0:	f8c3 2080 	str.w	r2, [r3, #128]	; 0x80

          /* Process Unlocked */
          __HAL_UNLOCK(huart);
 80061b4:	68fb      	ldr	r3, [r7, #12]
 80061b6:	2200      	movs	r2, #0
 80061b8:	f883 2074 	strb.w	r2, [r3, #116]	; 0x74

          return HAL_TIMEOUT;
 80061bc:	2303      	movs	r3, #3
 80061be:	e010      	b.n	80061e2 <UART_WaitOnFlagUntilTimeout+0x180>
  while ((__HAL_UART_GET_FLAG(huart, Flag) ? SET : RESET) == Status)
 80061c0:	68fb      	ldr	r3, [r7, #12]
 80061c2:	681b      	ldr	r3, [r3, #0]
 80061c4:	69da      	ldr	r2, [r3, #28]
 80061c6:	68bb      	ldr	r3, [r7, #8]
 80061c8:	4013      	ands	r3, r2
 80061ca:	68ba      	ldr	r2, [r7, #8]
 80061cc:	429a      	cmp	r2, r3
 80061ce:	bf0c      	ite	eq
 80061d0:	2301      	moveq	r3, #1
 80061d2:	2300      	movne	r3, #0
 80061d4:	b2db      	uxtb	r3, r3
 80061d6:	461a      	mov	r2, r3
 80061d8:	79fb      	ldrb	r3, [r7, #7]
 80061da:	429a      	cmp	r2, r3
 80061dc:	f43f af4a 	beq.w	8006074 <UART_WaitOnFlagUntilTimeout+0x12>
        }
      }
    }
  }
  return HAL_OK;
 80061e0:	2300      	movs	r3, #0
}
 80061e2:	4618      	mov	r0, r3
 80061e4:	3770      	adds	r7, #112	; 0x70
 80061e6:	46bd      	mov	sp, r7
 80061e8:	bd80      	pop	{r7, pc}
	...

080061ec <__errno>:
 80061ec:	4b01      	ldr	r3, [pc, #4]	; (80061f4 <__errno+0x8>)
 80061ee:	6818      	ldr	r0, [r3, #0]
 80061f0:	4770      	bx	lr
 80061f2:	bf00      	nop
 80061f4:	2000000c 	.word	0x2000000c

080061f8 <__libc_init_array>:
 80061f8:	b570      	push	{r4, r5, r6, lr}
 80061fa:	4d0d      	ldr	r5, [pc, #52]	; (8006230 <__libc_init_array+0x38>)
 80061fc:	4c0d      	ldr	r4, [pc, #52]	; (8006234 <__libc_init_array+0x3c>)
 80061fe:	1b64      	subs	r4, r4, r5
 8006200:	10a4      	asrs	r4, r4, #2
 8006202:	2600      	movs	r6, #0
 8006204:	42a6      	cmp	r6, r4
 8006206:	d109      	bne.n	800621c <__libc_init_array+0x24>
 8006208:	4d0b      	ldr	r5, [pc, #44]	; (8006238 <__libc_init_array+0x40>)
 800620a:	4c0c      	ldr	r4, [pc, #48]	; (800623c <__libc_init_array+0x44>)
 800620c:	f002 feb6 	bl	8008f7c <_init>
 8006210:	1b64      	subs	r4, r4, r5
 8006212:	10a4      	asrs	r4, r4, #2
 8006214:	2600      	movs	r6, #0
 8006216:	42a6      	cmp	r6, r4
 8006218:	d105      	bne.n	8006226 <__libc_init_array+0x2e>
 800621a:	bd70      	pop	{r4, r5, r6, pc}
 800621c:	f855 3b04 	ldr.w	r3, [r5], #4
 8006220:	4798      	blx	r3
 8006222:	3601      	adds	r6, #1
 8006224:	e7ee      	b.n	8006204 <__libc_init_array+0xc>
 8006226:	f855 3b04 	ldr.w	r3, [r5], #4
 800622a:	4798      	blx	r3
 800622c:	3601      	adds	r6, #1
 800622e:	e7f2      	b.n	8006216 <__libc_init_array+0x1e>
 8006230:	0800940c 	.word	0x0800940c
 8006234:	0800940c 	.word	0x0800940c
 8006238:	0800940c 	.word	0x0800940c
 800623c:	08009410 	.word	0x08009410

08006240 <memset>:
 8006240:	4402      	add	r2, r0
 8006242:	4603      	mov	r3, r0
 8006244:	4293      	cmp	r3, r2
 8006246:	d100      	bne.n	800624a <memset+0xa>
 8006248:	4770      	bx	lr
 800624a:	f803 1b01 	strb.w	r1, [r3], #1
 800624e:	e7f9      	b.n	8006244 <memset+0x4>

08006250 <__cvt>:
 8006250:	e92d 47ff 	stmdb	sp!, {r0, r1, r2, r3, r4, r5, r6, r7, r8, r9, sl, lr}
 8006254:	ec55 4b10 	vmov	r4, r5, d0
 8006258:	2d00      	cmp	r5, #0
 800625a:	460e      	mov	r6, r1
 800625c:	4619      	mov	r1, r3
 800625e:	462b      	mov	r3, r5
 8006260:	bfbb      	ittet	lt
 8006262:	f105 4300 	addlt.w	r3, r5, #2147483648	; 0x80000000
 8006266:	461d      	movlt	r5, r3
 8006268:	2300      	movge	r3, #0
 800626a:	232d      	movlt	r3, #45	; 0x2d
 800626c:	700b      	strb	r3, [r1, #0]
 800626e:	9b0d      	ldr	r3, [sp, #52]	; 0x34
 8006270:	f8dd a030 	ldr.w	sl, [sp, #48]	; 0x30
 8006274:	4691      	mov	r9, r2
 8006276:	f023 0820 	bic.w	r8, r3, #32
 800627a:	bfbc      	itt	lt
 800627c:	4622      	movlt	r2, r4
 800627e:	4614      	movlt	r4, r2
 8006280:	f1b8 0f46 	cmp.w	r8, #70	; 0x46
 8006284:	d005      	beq.n	8006292 <__cvt+0x42>
 8006286:	f1b8 0f45 	cmp.w	r8, #69	; 0x45
 800628a:	d100      	bne.n	800628e <__cvt+0x3e>
 800628c:	3601      	adds	r6, #1
 800628e:	2102      	movs	r1, #2
 8006290:	e000      	b.n	8006294 <__cvt+0x44>
 8006292:	2103      	movs	r1, #3
 8006294:	ab03      	add	r3, sp, #12
 8006296:	9301      	str	r3, [sp, #4]
 8006298:	ab02      	add	r3, sp, #8
 800629a:	9300      	str	r3, [sp, #0]
 800629c:	ec45 4b10 	vmov	d0, r4, r5
 80062a0:	4653      	mov	r3, sl
 80062a2:	4632      	mov	r2, r6
 80062a4:	f000 fcec 	bl	8006c80 <_dtoa_r>
 80062a8:	f1b8 0f47 	cmp.w	r8, #71	; 0x47
 80062ac:	4607      	mov	r7, r0
 80062ae:	d102      	bne.n	80062b6 <__cvt+0x66>
 80062b0:	f019 0f01 	tst.w	r9, #1
 80062b4:	d022      	beq.n	80062fc <__cvt+0xac>
 80062b6:	f1b8 0f46 	cmp.w	r8, #70	; 0x46
 80062ba:	eb07 0906 	add.w	r9, r7, r6
 80062be:	d110      	bne.n	80062e2 <__cvt+0x92>
 80062c0:	783b      	ldrb	r3, [r7, #0]
 80062c2:	2b30      	cmp	r3, #48	; 0x30
 80062c4:	d10a      	bne.n	80062dc <__cvt+0x8c>
 80062c6:	2200      	movs	r2, #0
 80062c8:	2300      	movs	r3, #0
 80062ca:	4620      	mov	r0, r4
 80062cc:	4629      	mov	r1, r5
 80062ce:	f7fa fbfb 	bl	8000ac8 <__aeabi_dcmpeq>
 80062d2:	b918      	cbnz	r0, 80062dc <__cvt+0x8c>
 80062d4:	f1c6 0601 	rsb	r6, r6, #1
 80062d8:	f8ca 6000 	str.w	r6, [sl]
 80062dc:	f8da 3000 	ldr.w	r3, [sl]
 80062e0:	4499      	add	r9, r3
 80062e2:	2200      	movs	r2, #0
 80062e4:	2300      	movs	r3, #0
 80062e6:	4620      	mov	r0, r4
 80062e8:	4629      	mov	r1, r5
 80062ea:	f7fa fbed 	bl	8000ac8 <__aeabi_dcmpeq>
 80062ee:	b108      	cbz	r0, 80062f4 <__cvt+0xa4>
 80062f0:	f8cd 900c 	str.w	r9, [sp, #12]
 80062f4:	2230      	movs	r2, #48	; 0x30
 80062f6:	9b03      	ldr	r3, [sp, #12]
 80062f8:	454b      	cmp	r3, r9
 80062fa:	d307      	bcc.n	800630c <__cvt+0xbc>
 80062fc:	9b03      	ldr	r3, [sp, #12]
 80062fe:	9a0e      	ldr	r2, [sp, #56]	; 0x38
 8006300:	1bdb      	subs	r3, r3, r7
 8006302:	4638      	mov	r0, r7
 8006304:	6013      	str	r3, [r2, #0]
 8006306:	b004      	add	sp, #16
 8006308:	e8bd 87f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, pc}
 800630c:	1c59      	adds	r1, r3, #1
 800630e:	9103      	str	r1, [sp, #12]
 8006310:	701a      	strb	r2, [r3, #0]
 8006312:	e7f0      	b.n	80062f6 <__cvt+0xa6>

08006314 <__exponent>:
 8006314:	b5f7      	push	{r0, r1, r2, r4, r5, r6, r7, lr}
 8006316:	4603      	mov	r3, r0
 8006318:	2900      	cmp	r1, #0
 800631a:	bfb8      	it	lt
 800631c:	4249      	neglt	r1, r1
 800631e:	f803 2b02 	strb.w	r2, [r3], #2
 8006322:	bfb4      	ite	lt
 8006324:	222d      	movlt	r2, #45	; 0x2d
 8006326:	222b      	movge	r2, #43	; 0x2b
 8006328:	2909      	cmp	r1, #9
 800632a:	7042      	strb	r2, [r0, #1]
 800632c:	dd2a      	ble.n	8006384 <__exponent+0x70>
 800632e:	f10d 0407 	add.w	r4, sp, #7
 8006332:	46a4      	mov	ip, r4
 8006334:	270a      	movs	r7, #10
 8006336:	46a6      	mov	lr, r4
 8006338:	460a      	mov	r2, r1
 800633a:	fb91 f6f7 	sdiv	r6, r1, r7
 800633e:	fb07 1516 	mls	r5, r7, r6, r1
 8006342:	3530      	adds	r5, #48	; 0x30
 8006344:	2a63      	cmp	r2, #99	; 0x63
 8006346:	f104 34ff 	add.w	r4, r4, #4294967295
 800634a:	f80e 5c01 	strb.w	r5, [lr, #-1]
 800634e:	4631      	mov	r1, r6
 8006350:	dcf1      	bgt.n	8006336 <__exponent+0x22>
 8006352:	3130      	adds	r1, #48	; 0x30
 8006354:	f1ae 0502 	sub.w	r5, lr, #2
 8006358:	f804 1c01 	strb.w	r1, [r4, #-1]
 800635c:	1c44      	adds	r4, r0, #1
 800635e:	4629      	mov	r1, r5
 8006360:	4561      	cmp	r1, ip
 8006362:	d30a      	bcc.n	800637a <__exponent+0x66>
 8006364:	f10d 0209 	add.w	r2, sp, #9
 8006368:	eba2 020e 	sub.w	r2, r2, lr
 800636c:	4565      	cmp	r5, ip
 800636e:	bf88      	it	hi
 8006370:	2200      	movhi	r2, #0
 8006372:	4413      	add	r3, r2
 8006374:	1a18      	subs	r0, r3, r0
 8006376:	b003      	add	sp, #12
 8006378:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800637a:	f811 2b01 	ldrb.w	r2, [r1], #1
 800637e:	f804 2f01 	strb.w	r2, [r4, #1]!
 8006382:	e7ed      	b.n	8006360 <__exponent+0x4c>
 8006384:	2330      	movs	r3, #48	; 0x30
 8006386:	3130      	adds	r1, #48	; 0x30
 8006388:	7083      	strb	r3, [r0, #2]
 800638a:	70c1      	strb	r1, [r0, #3]
 800638c:	1d03      	adds	r3, r0, #4
 800638e:	e7f1      	b.n	8006374 <__exponent+0x60>

08006390 <_printf_float>:
 8006390:	e92d 4ff0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, lr}
 8006394:	ed2d 8b02 	vpush	{d8}
 8006398:	b08d      	sub	sp, #52	; 0x34
 800639a:	460c      	mov	r4, r1
 800639c:	f8dd 8060 	ldr.w	r8, [sp, #96]	; 0x60
 80063a0:	4616      	mov	r6, r2
 80063a2:	461f      	mov	r7, r3
 80063a4:	4605      	mov	r5, r0
 80063a6:	f001 fa57 	bl	8007858 <_localeconv_r>
 80063aa:	f8d0 a000 	ldr.w	sl, [r0]
 80063ae:	4650      	mov	r0, sl
 80063b0:	f7f9 ff0e 	bl	80001d0 <strlen>
 80063b4:	2300      	movs	r3, #0
 80063b6:	930a      	str	r3, [sp, #40]	; 0x28
 80063b8:	6823      	ldr	r3, [r4, #0]
 80063ba:	9305      	str	r3, [sp, #20]
 80063bc:	f8d8 3000 	ldr.w	r3, [r8]
 80063c0:	f894 b018 	ldrb.w	fp, [r4, #24]
 80063c4:	3307      	adds	r3, #7
 80063c6:	f023 0307 	bic.w	r3, r3, #7
 80063ca:	f103 0208 	add.w	r2, r3, #8
 80063ce:	f8c8 2000 	str.w	r2, [r8]
 80063d2:	e9d3 2300 	ldrd	r2, r3, [r3]
 80063d6:	e9c4 2312 	strd	r2, r3, [r4, #72]	; 0x48
 80063da:	e9d4 8912 	ldrd	r8, r9, [r4, #72]	; 0x48
 80063de:	f029 4300 	bic.w	r3, r9, #2147483648	; 0x80000000
 80063e2:	9307      	str	r3, [sp, #28]
 80063e4:	f8cd 8018 	str.w	r8, [sp, #24]
 80063e8:	ee08 0a10 	vmov	s16, r0
 80063ec:	4b9f      	ldr	r3, [pc, #636]	; (800666c <_printf_float+0x2dc>)
 80063ee:	e9dd 0106 	ldrd	r0, r1, [sp, #24]
 80063f2:	f04f 32ff 	mov.w	r2, #4294967295
 80063f6:	f7fa fb99 	bl	8000b2c <__aeabi_dcmpun>
 80063fa:	bb88      	cbnz	r0, 8006460 <_printf_float+0xd0>
 80063fc:	e9dd 0106 	ldrd	r0, r1, [sp, #24]
 8006400:	4b9a      	ldr	r3, [pc, #616]	; (800666c <_printf_float+0x2dc>)
 8006402:	f04f 32ff 	mov.w	r2, #4294967295
 8006406:	f7fa fb73 	bl	8000af0 <__aeabi_dcmple>
 800640a:	bb48      	cbnz	r0, 8006460 <_printf_float+0xd0>
 800640c:	2200      	movs	r2, #0
 800640e:	2300      	movs	r3, #0
 8006410:	4640      	mov	r0, r8
 8006412:	4649      	mov	r1, r9
 8006414:	f7fa fb62 	bl	8000adc <__aeabi_dcmplt>
 8006418:	b110      	cbz	r0, 8006420 <_printf_float+0x90>
 800641a:	232d      	movs	r3, #45	; 0x2d
 800641c:	f884 3043 	strb.w	r3, [r4, #67]	; 0x43
 8006420:	4b93      	ldr	r3, [pc, #588]	; (8006670 <_printf_float+0x2e0>)
 8006422:	4894      	ldr	r0, [pc, #592]	; (8006674 <_printf_float+0x2e4>)
 8006424:	f1bb 0f47 	cmp.w	fp, #71	; 0x47
 8006428:	bf94      	ite	ls
 800642a:	4698      	movls	r8, r3
 800642c:	4680      	movhi	r8, r0
 800642e:	2303      	movs	r3, #3
 8006430:	6123      	str	r3, [r4, #16]
 8006432:	9b05      	ldr	r3, [sp, #20]
 8006434:	f023 0204 	bic.w	r2, r3, #4
 8006438:	6022      	str	r2, [r4, #0]
 800643a:	f04f 0900 	mov.w	r9, #0
 800643e:	9700      	str	r7, [sp, #0]
 8006440:	4633      	mov	r3, r6
 8006442:	aa0b      	add	r2, sp, #44	; 0x2c
 8006444:	4621      	mov	r1, r4
 8006446:	4628      	mov	r0, r5
 8006448:	f000 f9d8 	bl	80067fc <_printf_common>
 800644c:	3001      	adds	r0, #1
 800644e:	f040 8090 	bne.w	8006572 <_printf_float+0x1e2>
 8006452:	f04f 30ff 	mov.w	r0, #4294967295
 8006456:	b00d      	add	sp, #52	; 0x34
 8006458:	ecbd 8b02 	vpop	{d8}
 800645c:	e8bd 8ff0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, pc}
 8006460:	4642      	mov	r2, r8
 8006462:	464b      	mov	r3, r9
 8006464:	4640      	mov	r0, r8
 8006466:	4649      	mov	r1, r9
 8006468:	f7fa fb60 	bl	8000b2c <__aeabi_dcmpun>
 800646c:	b140      	cbz	r0, 8006480 <_printf_float+0xf0>
 800646e:	464b      	mov	r3, r9
 8006470:	2b00      	cmp	r3, #0
 8006472:	bfbc      	itt	lt
 8006474:	232d      	movlt	r3, #45	; 0x2d
 8006476:	f884 3043 	strblt.w	r3, [r4, #67]	; 0x43
 800647a:	487f      	ldr	r0, [pc, #508]	; (8006678 <_printf_float+0x2e8>)
 800647c:	4b7f      	ldr	r3, [pc, #508]	; (800667c <_printf_float+0x2ec>)
 800647e:	e7d1      	b.n	8006424 <_printf_float+0x94>
 8006480:	6863      	ldr	r3, [r4, #4]
 8006482:	f00b 02df 	and.w	r2, fp, #223	; 0xdf
 8006486:	9206      	str	r2, [sp, #24]
 8006488:	1c5a      	adds	r2, r3, #1
 800648a:	d13f      	bne.n	800650c <_printf_float+0x17c>
 800648c:	2306      	movs	r3, #6
 800648e:	6063      	str	r3, [r4, #4]
 8006490:	9b05      	ldr	r3, [sp, #20]
 8006492:	6861      	ldr	r1, [r4, #4]
 8006494:	f443 6280 	orr.w	r2, r3, #1024	; 0x400
 8006498:	2300      	movs	r3, #0
 800649a:	9303      	str	r3, [sp, #12]
 800649c:	ab0a      	add	r3, sp, #40	; 0x28
 800649e:	e9cd b301 	strd	fp, r3, [sp, #4]
 80064a2:	ab09      	add	r3, sp, #36	; 0x24
 80064a4:	ec49 8b10 	vmov	d0, r8, r9
 80064a8:	9300      	str	r3, [sp, #0]
 80064aa:	6022      	str	r2, [r4, #0]
 80064ac:	f10d 0323 	add.w	r3, sp, #35	; 0x23
 80064b0:	4628      	mov	r0, r5
 80064b2:	f7ff fecd 	bl	8006250 <__cvt>
 80064b6:	9b06      	ldr	r3, [sp, #24]
 80064b8:	9909      	ldr	r1, [sp, #36]	; 0x24
 80064ba:	2b47      	cmp	r3, #71	; 0x47
 80064bc:	4680      	mov	r8, r0
 80064be:	d108      	bne.n	80064d2 <_printf_float+0x142>
 80064c0:	1cc8      	adds	r0, r1, #3
 80064c2:	db02      	blt.n	80064ca <_printf_float+0x13a>
 80064c4:	6863      	ldr	r3, [r4, #4]
 80064c6:	4299      	cmp	r1, r3
 80064c8:	dd41      	ble.n	800654e <_printf_float+0x1be>
 80064ca:	f1ab 0b02 	sub.w	fp, fp, #2
 80064ce:	fa5f fb8b 	uxtb.w	fp, fp
 80064d2:	f1bb 0f65 	cmp.w	fp, #101	; 0x65
 80064d6:	d820      	bhi.n	800651a <_printf_float+0x18a>
 80064d8:	3901      	subs	r1, #1
 80064da:	465a      	mov	r2, fp
 80064dc:	f104 0050 	add.w	r0, r4, #80	; 0x50
 80064e0:	9109      	str	r1, [sp, #36]	; 0x24
 80064e2:	f7ff ff17 	bl	8006314 <__exponent>
 80064e6:	9a0a      	ldr	r2, [sp, #40]	; 0x28
 80064e8:	1813      	adds	r3, r2, r0
 80064ea:	2a01      	cmp	r2, #1
 80064ec:	4681      	mov	r9, r0
 80064ee:	6123      	str	r3, [r4, #16]
 80064f0:	dc02      	bgt.n	80064f8 <_printf_float+0x168>
 80064f2:	6822      	ldr	r2, [r4, #0]
 80064f4:	07d2      	lsls	r2, r2, #31
 80064f6:	d501      	bpl.n	80064fc <_printf_float+0x16c>
 80064f8:	3301      	adds	r3, #1
 80064fa:	6123      	str	r3, [r4, #16]
 80064fc:	f89d 3023 	ldrb.w	r3, [sp, #35]	; 0x23
 8006500:	2b00      	cmp	r3, #0
 8006502:	d09c      	beq.n	800643e <_printf_float+0xae>
 8006504:	232d      	movs	r3, #45	; 0x2d
 8006506:	f884 3043 	strb.w	r3, [r4, #67]	; 0x43
 800650a:	e798      	b.n	800643e <_printf_float+0xae>
 800650c:	9a06      	ldr	r2, [sp, #24]
 800650e:	2a47      	cmp	r2, #71	; 0x47
 8006510:	d1be      	bne.n	8006490 <_printf_float+0x100>
 8006512:	2b00      	cmp	r3, #0
 8006514:	d1bc      	bne.n	8006490 <_printf_float+0x100>
 8006516:	2301      	movs	r3, #1
 8006518:	e7b9      	b.n	800648e <_printf_float+0xfe>
 800651a:	f1bb 0f66 	cmp.w	fp, #102	; 0x66
 800651e:	d118      	bne.n	8006552 <_printf_float+0x1c2>
 8006520:	2900      	cmp	r1, #0
 8006522:	6863      	ldr	r3, [r4, #4]
 8006524:	dd0b      	ble.n	800653e <_printf_float+0x1ae>
 8006526:	6121      	str	r1, [r4, #16]
 8006528:	b913      	cbnz	r3, 8006530 <_printf_float+0x1a0>
 800652a:	6822      	ldr	r2, [r4, #0]
 800652c:	07d0      	lsls	r0, r2, #31
 800652e:	d502      	bpl.n	8006536 <_printf_float+0x1a6>
 8006530:	3301      	adds	r3, #1
 8006532:	440b      	add	r3, r1
 8006534:	6123      	str	r3, [r4, #16]
 8006536:	65a1      	str	r1, [r4, #88]	; 0x58
 8006538:	f04f 0900 	mov.w	r9, #0
 800653c:	e7de      	b.n	80064fc <_printf_float+0x16c>
 800653e:	b913      	cbnz	r3, 8006546 <_printf_float+0x1b6>
 8006540:	6822      	ldr	r2, [r4, #0]
 8006542:	07d2      	lsls	r2, r2, #31
 8006544:	d501      	bpl.n	800654a <_printf_float+0x1ba>
 8006546:	3302      	adds	r3, #2
 8006548:	e7f4      	b.n	8006534 <_printf_float+0x1a4>
 800654a:	2301      	movs	r3, #1
 800654c:	e7f2      	b.n	8006534 <_printf_float+0x1a4>
 800654e:	f04f 0b67 	mov.w	fp, #103	; 0x67
 8006552:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 8006554:	4299      	cmp	r1, r3
 8006556:	db05      	blt.n	8006564 <_printf_float+0x1d4>
 8006558:	6823      	ldr	r3, [r4, #0]
 800655a:	6121      	str	r1, [r4, #16]
 800655c:	07d8      	lsls	r0, r3, #31
 800655e:	d5ea      	bpl.n	8006536 <_printf_float+0x1a6>
 8006560:	1c4b      	adds	r3, r1, #1
 8006562:	e7e7      	b.n	8006534 <_printf_float+0x1a4>
 8006564:	2900      	cmp	r1, #0
 8006566:	bfd4      	ite	le
 8006568:	f1c1 0202 	rsble	r2, r1, #2
 800656c:	2201      	movgt	r2, #1
 800656e:	4413      	add	r3, r2
 8006570:	e7e0      	b.n	8006534 <_printf_float+0x1a4>
 8006572:	6823      	ldr	r3, [r4, #0]
 8006574:	055a      	lsls	r2, r3, #21
 8006576:	d407      	bmi.n	8006588 <_printf_float+0x1f8>
 8006578:	6923      	ldr	r3, [r4, #16]
 800657a:	4642      	mov	r2, r8
 800657c:	4631      	mov	r1, r6
 800657e:	4628      	mov	r0, r5
 8006580:	47b8      	blx	r7
 8006582:	3001      	adds	r0, #1
 8006584:	d12c      	bne.n	80065e0 <_printf_float+0x250>
 8006586:	e764      	b.n	8006452 <_printf_float+0xc2>
 8006588:	f1bb 0f65 	cmp.w	fp, #101	; 0x65
 800658c:	f240 80e0 	bls.w	8006750 <_printf_float+0x3c0>
 8006590:	e9d4 0112 	ldrd	r0, r1, [r4, #72]	; 0x48
 8006594:	2200      	movs	r2, #0
 8006596:	2300      	movs	r3, #0
 8006598:	f7fa fa96 	bl	8000ac8 <__aeabi_dcmpeq>
 800659c:	2800      	cmp	r0, #0
 800659e:	d034      	beq.n	800660a <_printf_float+0x27a>
 80065a0:	4a37      	ldr	r2, [pc, #220]	; (8006680 <_printf_float+0x2f0>)
 80065a2:	2301      	movs	r3, #1
 80065a4:	4631      	mov	r1, r6
 80065a6:	4628      	mov	r0, r5
 80065a8:	47b8      	blx	r7
 80065aa:	3001      	adds	r0, #1
 80065ac:	f43f af51 	beq.w	8006452 <_printf_float+0xc2>
 80065b0:	e9dd 2309 	ldrd	r2, r3, [sp, #36]	; 0x24
 80065b4:	429a      	cmp	r2, r3
 80065b6:	db02      	blt.n	80065be <_printf_float+0x22e>
 80065b8:	6823      	ldr	r3, [r4, #0]
 80065ba:	07d8      	lsls	r0, r3, #31
 80065bc:	d510      	bpl.n	80065e0 <_printf_float+0x250>
 80065be:	ee18 3a10 	vmov	r3, s16
 80065c2:	4652      	mov	r2, sl
 80065c4:	4631      	mov	r1, r6
 80065c6:	4628      	mov	r0, r5
 80065c8:	47b8      	blx	r7
 80065ca:	3001      	adds	r0, #1
 80065cc:	f43f af41 	beq.w	8006452 <_printf_float+0xc2>
 80065d0:	f04f 0800 	mov.w	r8, #0
 80065d4:	f104 091a 	add.w	r9, r4, #26
 80065d8:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 80065da:	3b01      	subs	r3, #1
 80065dc:	4543      	cmp	r3, r8
 80065de:	dc09      	bgt.n	80065f4 <_printf_float+0x264>
 80065e0:	6823      	ldr	r3, [r4, #0]
 80065e2:	079b      	lsls	r3, r3, #30
 80065e4:	f100 8105 	bmi.w	80067f2 <_printf_float+0x462>
 80065e8:	68e0      	ldr	r0, [r4, #12]
 80065ea:	9b0b      	ldr	r3, [sp, #44]	; 0x2c
 80065ec:	4298      	cmp	r0, r3
 80065ee:	bfb8      	it	lt
 80065f0:	4618      	movlt	r0, r3
 80065f2:	e730      	b.n	8006456 <_printf_float+0xc6>
 80065f4:	2301      	movs	r3, #1
 80065f6:	464a      	mov	r2, r9
 80065f8:	4631      	mov	r1, r6
 80065fa:	4628      	mov	r0, r5
 80065fc:	47b8      	blx	r7
 80065fe:	3001      	adds	r0, #1
 8006600:	f43f af27 	beq.w	8006452 <_printf_float+0xc2>
 8006604:	f108 0801 	add.w	r8, r8, #1
 8006608:	e7e6      	b.n	80065d8 <_printf_float+0x248>
 800660a:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800660c:	2b00      	cmp	r3, #0
 800660e:	dc39      	bgt.n	8006684 <_printf_float+0x2f4>
 8006610:	4a1b      	ldr	r2, [pc, #108]	; (8006680 <_printf_float+0x2f0>)
 8006612:	2301      	movs	r3, #1
 8006614:	4631      	mov	r1, r6
 8006616:	4628      	mov	r0, r5
 8006618:	47b8      	blx	r7
 800661a:	3001      	adds	r0, #1
 800661c:	f43f af19 	beq.w	8006452 <_printf_float+0xc2>
 8006620:	e9dd 2309 	ldrd	r2, r3, [sp, #36]	; 0x24
 8006624:	4313      	orrs	r3, r2
 8006626:	d102      	bne.n	800662e <_printf_float+0x29e>
 8006628:	6823      	ldr	r3, [r4, #0]
 800662a:	07d9      	lsls	r1, r3, #31
 800662c:	d5d8      	bpl.n	80065e0 <_printf_float+0x250>
 800662e:	ee18 3a10 	vmov	r3, s16
 8006632:	4652      	mov	r2, sl
 8006634:	4631      	mov	r1, r6
 8006636:	4628      	mov	r0, r5
 8006638:	47b8      	blx	r7
 800663a:	3001      	adds	r0, #1
 800663c:	f43f af09 	beq.w	8006452 <_printf_float+0xc2>
 8006640:	f04f 0900 	mov.w	r9, #0
 8006644:	f104 0a1a 	add.w	sl, r4, #26
 8006648:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800664a:	425b      	negs	r3, r3
 800664c:	454b      	cmp	r3, r9
 800664e:	dc01      	bgt.n	8006654 <_printf_float+0x2c4>
 8006650:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 8006652:	e792      	b.n	800657a <_printf_float+0x1ea>
 8006654:	2301      	movs	r3, #1
 8006656:	4652      	mov	r2, sl
 8006658:	4631      	mov	r1, r6
 800665a:	4628      	mov	r0, r5
 800665c:	47b8      	blx	r7
 800665e:	3001      	adds	r0, #1
 8006660:	f43f aef7 	beq.w	8006452 <_printf_float+0xc2>
 8006664:	f109 0901 	add.w	r9, r9, #1
 8006668:	e7ee      	b.n	8006648 <_printf_float+0x2b8>
 800666a:	bf00      	nop
 800666c:	7fefffff 	.word	0x7fefffff
 8006670:	08009028 	.word	0x08009028
 8006674:	0800902c 	.word	0x0800902c
 8006678:	08009034 	.word	0x08009034
 800667c:	08009030 	.word	0x08009030
 8006680:	08009038 	.word	0x08009038
 8006684:	9a0a      	ldr	r2, [sp, #40]	; 0x28
 8006686:	6da3      	ldr	r3, [r4, #88]	; 0x58
 8006688:	429a      	cmp	r2, r3
 800668a:	bfa8      	it	ge
 800668c:	461a      	movge	r2, r3
 800668e:	2a00      	cmp	r2, #0
 8006690:	4691      	mov	r9, r2
 8006692:	dc37      	bgt.n	8006704 <_printf_float+0x374>
 8006694:	f04f 0b00 	mov.w	fp, #0
 8006698:	ea29 79e9 	bic.w	r9, r9, r9, asr #31
 800669c:	f104 021a 	add.w	r2, r4, #26
 80066a0:	6da3      	ldr	r3, [r4, #88]	; 0x58
 80066a2:	9305      	str	r3, [sp, #20]
 80066a4:	eba3 0309 	sub.w	r3, r3, r9
 80066a8:	455b      	cmp	r3, fp
 80066aa:	dc33      	bgt.n	8006714 <_printf_float+0x384>
 80066ac:	e9dd 2309 	ldrd	r2, r3, [sp, #36]	; 0x24
 80066b0:	429a      	cmp	r2, r3
 80066b2:	db3b      	blt.n	800672c <_printf_float+0x39c>
 80066b4:	6823      	ldr	r3, [r4, #0]
 80066b6:	07da      	lsls	r2, r3, #31
 80066b8:	d438      	bmi.n	800672c <_printf_float+0x39c>
 80066ba:	9a0a      	ldr	r2, [sp, #40]	; 0x28
 80066bc:	9b05      	ldr	r3, [sp, #20]
 80066be:	9909      	ldr	r1, [sp, #36]	; 0x24
 80066c0:	1ad3      	subs	r3, r2, r3
 80066c2:	eba2 0901 	sub.w	r9, r2, r1
 80066c6:	4599      	cmp	r9, r3
 80066c8:	bfa8      	it	ge
 80066ca:	4699      	movge	r9, r3
 80066cc:	f1b9 0f00 	cmp.w	r9, #0
 80066d0:	dc35      	bgt.n	800673e <_printf_float+0x3ae>
 80066d2:	f04f 0800 	mov.w	r8, #0
 80066d6:	ea29 79e9 	bic.w	r9, r9, r9, asr #31
 80066da:	f104 0a1a 	add.w	sl, r4, #26
 80066de:	e9dd 2309 	ldrd	r2, r3, [sp, #36]	; 0x24
 80066e2:	1a9b      	subs	r3, r3, r2
 80066e4:	eba3 0309 	sub.w	r3, r3, r9
 80066e8:	4543      	cmp	r3, r8
 80066ea:	f77f af79 	ble.w	80065e0 <_printf_float+0x250>
 80066ee:	2301      	movs	r3, #1
 80066f0:	4652      	mov	r2, sl
 80066f2:	4631      	mov	r1, r6
 80066f4:	4628      	mov	r0, r5
 80066f6:	47b8      	blx	r7
 80066f8:	3001      	adds	r0, #1
 80066fa:	f43f aeaa 	beq.w	8006452 <_printf_float+0xc2>
 80066fe:	f108 0801 	add.w	r8, r8, #1
 8006702:	e7ec      	b.n	80066de <_printf_float+0x34e>
 8006704:	4613      	mov	r3, r2
 8006706:	4631      	mov	r1, r6
 8006708:	4642      	mov	r2, r8
 800670a:	4628      	mov	r0, r5
 800670c:	47b8      	blx	r7
 800670e:	3001      	adds	r0, #1
 8006710:	d1c0      	bne.n	8006694 <_printf_float+0x304>
 8006712:	e69e      	b.n	8006452 <_printf_float+0xc2>
 8006714:	2301      	movs	r3, #1
 8006716:	4631      	mov	r1, r6
 8006718:	4628      	mov	r0, r5
 800671a:	9205      	str	r2, [sp, #20]
 800671c:	47b8      	blx	r7
 800671e:	3001      	adds	r0, #1
 8006720:	f43f ae97 	beq.w	8006452 <_printf_float+0xc2>
 8006724:	9a05      	ldr	r2, [sp, #20]
 8006726:	f10b 0b01 	add.w	fp, fp, #1
 800672a:	e7b9      	b.n	80066a0 <_printf_float+0x310>
 800672c:	ee18 3a10 	vmov	r3, s16
 8006730:	4652      	mov	r2, sl
 8006732:	4631      	mov	r1, r6
 8006734:	4628      	mov	r0, r5
 8006736:	47b8      	blx	r7
 8006738:	3001      	adds	r0, #1
 800673a:	d1be      	bne.n	80066ba <_printf_float+0x32a>
 800673c:	e689      	b.n	8006452 <_printf_float+0xc2>
 800673e:	9a05      	ldr	r2, [sp, #20]
 8006740:	464b      	mov	r3, r9
 8006742:	4442      	add	r2, r8
 8006744:	4631      	mov	r1, r6
 8006746:	4628      	mov	r0, r5
 8006748:	47b8      	blx	r7
 800674a:	3001      	adds	r0, #1
 800674c:	d1c1      	bne.n	80066d2 <_printf_float+0x342>
 800674e:	e680      	b.n	8006452 <_printf_float+0xc2>
 8006750:	9a0a      	ldr	r2, [sp, #40]	; 0x28
 8006752:	2a01      	cmp	r2, #1
 8006754:	dc01      	bgt.n	800675a <_printf_float+0x3ca>
 8006756:	07db      	lsls	r3, r3, #31
 8006758:	d538      	bpl.n	80067cc <_printf_float+0x43c>
 800675a:	2301      	movs	r3, #1
 800675c:	4642      	mov	r2, r8
 800675e:	4631      	mov	r1, r6
 8006760:	4628      	mov	r0, r5
 8006762:	47b8      	blx	r7
 8006764:	3001      	adds	r0, #1
 8006766:	f43f ae74 	beq.w	8006452 <_printf_float+0xc2>
 800676a:	ee18 3a10 	vmov	r3, s16
 800676e:	4652      	mov	r2, sl
 8006770:	4631      	mov	r1, r6
 8006772:	4628      	mov	r0, r5
 8006774:	47b8      	blx	r7
 8006776:	3001      	adds	r0, #1
 8006778:	f43f ae6b 	beq.w	8006452 <_printf_float+0xc2>
 800677c:	e9d4 0112 	ldrd	r0, r1, [r4, #72]	; 0x48
 8006780:	2200      	movs	r2, #0
 8006782:	2300      	movs	r3, #0
 8006784:	f7fa f9a0 	bl	8000ac8 <__aeabi_dcmpeq>
 8006788:	b9d8      	cbnz	r0, 80067c2 <_printf_float+0x432>
 800678a:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 800678c:	f108 0201 	add.w	r2, r8, #1
 8006790:	3b01      	subs	r3, #1
 8006792:	4631      	mov	r1, r6
 8006794:	4628      	mov	r0, r5
 8006796:	47b8      	blx	r7
 8006798:	3001      	adds	r0, #1
 800679a:	d10e      	bne.n	80067ba <_printf_float+0x42a>
 800679c:	e659      	b.n	8006452 <_printf_float+0xc2>
 800679e:	2301      	movs	r3, #1
 80067a0:	4652      	mov	r2, sl
 80067a2:	4631      	mov	r1, r6
 80067a4:	4628      	mov	r0, r5
 80067a6:	47b8      	blx	r7
 80067a8:	3001      	adds	r0, #1
 80067aa:	f43f ae52 	beq.w	8006452 <_printf_float+0xc2>
 80067ae:	f108 0801 	add.w	r8, r8, #1
 80067b2:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 80067b4:	3b01      	subs	r3, #1
 80067b6:	4543      	cmp	r3, r8
 80067b8:	dcf1      	bgt.n	800679e <_printf_float+0x40e>
 80067ba:	464b      	mov	r3, r9
 80067bc:	f104 0250 	add.w	r2, r4, #80	; 0x50
 80067c0:	e6dc      	b.n	800657c <_printf_float+0x1ec>
 80067c2:	f04f 0800 	mov.w	r8, #0
 80067c6:	f104 0a1a 	add.w	sl, r4, #26
 80067ca:	e7f2      	b.n	80067b2 <_printf_float+0x422>
 80067cc:	2301      	movs	r3, #1
 80067ce:	4642      	mov	r2, r8
 80067d0:	e7df      	b.n	8006792 <_printf_float+0x402>
 80067d2:	2301      	movs	r3, #1
 80067d4:	464a      	mov	r2, r9
 80067d6:	4631      	mov	r1, r6
 80067d8:	4628      	mov	r0, r5
 80067da:	47b8      	blx	r7
 80067dc:	3001      	adds	r0, #1
 80067de:	f43f ae38 	beq.w	8006452 <_printf_float+0xc2>
 80067e2:	f108 0801 	add.w	r8, r8, #1
 80067e6:	68e3      	ldr	r3, [r4, #12]
 80067e8:	990b      	ldr	r1, [sp, #44]	; 0x2c
 80067ea:	1a5b      	subs	r3, r3, r1
 80067ec:	4543      	cmp	r3, r8
 80067ee:	dcf0      	bgt.n	80067d2 <_printf_float+0x442>
 80067f0:	e6fa      	b.n	80065e8 <_printf_float+0x258>
 80067f2:	f04f 0800 	mov.w	r8, #0
 80067f6:	f104 0919 	add.w	r9, r4, #25
 80067fa:	e7f4      	b.n	80067e6 <_printf_float+0x456>

080067fc <_printf_common>:
 80067fc:	e92d 47f0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, lr}
 8006800:	4616      	mov	r6, r2
 8006802:	4699      	mov	r9, r3
 8006804:	688a      	ldr	r2, [r1, #8]
 8006806:	690b      	ldr	r3, [r1, #16]
 8006808:	f8dd 8020 	ldr.w	r8, [sp, #32]
 800680c:	4293      	cmp	r3, r2
 800680e:	bfb8      	it	lt
 8006810:	4613      	movlt	r3, r2
 8006812:	6033      	str	r3, [r6, #0]
 8006814:	f891 2043 	ldrb.w	r2, [r1, #67]	; 0x43
 8006818:	4607      	mov	r7, r0
 800681a:	460c      	mov	r4, r1
 800681c:	b10a      	cbz	r2, 8006822 <_printf_common+0x26>
 800681e:	3301      	adds	r3, #1
 8006820:	6033      	str	r3, [r6, #0]
 8006822:	6823      	ldr	r3, [r4, #0]
 8006824:	0699      	lsls	r1, r3, #26
 8006826:	bf42      	ittt	mi
 8006828:	6833      	ldrmi	r3, [r6, #0]
 800682a:	3302      	addmi	r3, #2
 800682c:	6033      	strmi	r3, [r6, #0]
 800682e:	6825      	ldr	r5, [r4, #0]
 8006830:	f015 0506 	ands.w	r5, r5, #6
 8006834:	d106      	bne.n	8006844 <_printf_common+0x48>
 8006836:	f104 0a19 	add.w	sl, r4, #25
 800683a:	68e3      	ldr	r3, [r4, #12]
 800683c:	6832      	ldr	r2, [r6, #0]
 800683e:	1a9b      	subs	r3, r3, r2
 8006840:	42ab      	cmp	r3, r5
 8006842:	dc26      	bgt.n	8006892 <_printf_common+0x96>
 8006844:	f894 2043 	ldrb.w	r2, [r4, #67]	; 0x43
 8006848:	1e13      	subs	r3, r2, #0
 800684a:	6822      	ldr	r2, [r4, #0]
 800684c:	bf18      	it	ne
 800684e:	2301      	movne	r3, #1
 8006850:	0692      	lsls	r2, r2, #26
 8006852:	d42b      	bmi.n	80068ac <_printf_common+0xb0>
 8006854:	f104 0243 	add.w	r2, r4, #67	; 0x43
 8006858:	4649      	mov	r1, r9
 800685a:	4638      	mov	r0, r7
 800685c:	47c0      	blx	r8
 800685e:	3001      	adds	r0, #1
 8006860:	d01e      	beq.n	80068a0 <_printf_common+0xa4>
 8006862:	6823      	ldr	r3, [r4, #0]
 8006864:	68e5      	ldr	r5, [r4, #12]
 8006866:	6832      	ldr	r2, [r6, #0]
 8006868:	f003 0306 	and.w	r3, r3, #6
 800686c:	2b04      	cmp	r3, #4
 800686e:	bf08      	it	eq
 8006870:	1aad      	subeq	r5, r5, r2
 8006872:	68a3      	ldr	r3, [r4, #8]
 8006874:	6922      	ldr	r2, [r4, #16]
 8006876:	bf0c      	ite	eq
 8006878:	ea25 75e5 	biceq.w	r5, r5, r5, asr #31
 800687c:	2500      	movne	r5, #0
 800687e:	4293      	cmp	r3, r2
 8006880:	bfc4      	itt	gt
 8006882:	1a9b      	subgt	r3, r3, r2
 8006884:	18ed      	addgt	r5, r5, r3
 8006886:	2600      	movs	r6, #0
 8006888:	341a      	adds	r4, #26
 800688a:	42b5      	cmp	r5, r6
 800688c:	d11a      	bne.n	80068c4 <_printf_common+0xc8>
 800688e:	2000      	movs	r0, #0
 8006890:	e008      	b.n	80068a4 <_printf_common+0xa8>
 8006892:	2301      	movs	r3, #1
 8006894:	4652      	mov	r2, sl
 8006896:	4649      	mov	r1, r9
 8006898:	4638      	mov	r0, r7
 800689a:	47c0      	blx	r8
 800689c:	3001      	adds	r0, #1
 800689e:	d103      	bne.n	80068a8 <_printf_common+0xac>
 80068a0:	f04f 30ff 	mov.w	r0, #4294967295
 80068a4:	e8bd 87f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, pc}
 80068a8:	3501      	adds	r5, #1
 80068aa:	e7c6      	b.n	800683a <_printf_common+0x3e>
 80068ac:	18e1      	adds	r1, r4, r3
 80068ae:	1c5a      	adds	r2, r3, #1
 80068b0:	2030      	movs	r0, #48	; 0x30
 80068b2:	f881 0043 	strb.w	r0, [r1, #67]	; 0x43
 80068b6:	4422      	add	r2, r4
 80068b8:	f894 1045 	ldrb.w	r1, [r4, #69]	; 0x45
 80068bc:	f882 1043 	strb.w	r1, [r2, #67]	; 0x43
 80068c0:	3302      	adds	r3, #2
 80068c2:	e7c7      	b.n	8006854 <_printf_common+0x58>
 80068c4:	2301      	movs	r3, #1
 80068c6:	4622      	mov	r2, r4
 80068c8:	4649      	mov	r1, r9
 80068ca:	4638      	mov	r0, r7
 80068cc:	47c0      	blx	r8
 80068ce:	3001      	adds	r0, #1
 80068d0:	d0e6      	beq.n	80068a0 <_printf_common+0xa4>
 80068d2:	3601      	adds	r6, #1
 80068d4:	e7d9      	b.n	800688a <_printf_common+0x8e>
	...

080068d8 <_printf_i>:
 80068d8:	e92d 47ff 	stmdb	sp!, {r0, r1, r2, r3, r4, r5, r6, r7, r8, r9, sl, lr}
 80068dc:	460c      	mov	r4, r1
 80068de:	4691      	mov	r9, r2
 80068e0:	7e27      	ldrb	r7, [r4, #24]
 80068e2:	990c      	ldr	r1, [sp, #48]	; 0x30
 80068e4:	2f78      	cmp	r7, #120	; 0x78
 80068e6:	4680      	mov	r8, r0
 80068e8:	469a      	mov	sl, r3
 80068ea:	f104 0243 	add.w	r2, r4, #67	; 0x43
 80068ee:	d807      	bhi.n	8006900 <_printf_i+0x28>
 80068f0:	2f62      	cmp	r7, #98	; 0x62
 80068f2:	d80a      	bhi.n	800690a <_printf_i+0x32>
 80068f4:	2f00      	cmp	r7, #0
 80068f6:	f000 80d8 	beq.w	8006aaa <_printf_i+0x1d2>
 80068fa:	2f58      	cmp	r7, #88	; 0x58
 80068fc:	f000 80a3 	beq.w	8006a46 <_printf_i+0x16e>
 8006900:	f104 0642 	add.w	r6, r4, #66	; 0x42
 8006904:	f884 7042 	strb.w	r7, [r4, #66]	; 0x42
 8006908:	e03a      	b.n	8006980 <_printf_i+0xa8>
 800690a:	f1a7 0363 	sub.w	r3, r7, #99	; 0x63
 800690e:	2b15      	cmp	r3, #21
 8006910:	d8f6      	bhi.n	8006900 <_printf_i+0x28>
 8006912:	a001      	add	r0, pc, #4	; (adr r0, 8006918 <_printf_i+0x40>)
 8006914:	f850 f023 	ldr.w	pc, [r0, r3, lsl #2]
 8006918:	08006971 	.word	0x08006971
 800691c:	08006985 	.word	0x08006985
 8006920:	08006901 	.word	0x08006901
 8006924:	08006901 	.word	0x08006901
 8006928:	08006901 	.word	0x08006901
 800692c:	08006901 	.word	0x08006901
 8006930:	08006985 	.word	0x08006985
 8006934:	08006901 	.word	0x08006901
 8006938:	08006901 	.word	0x08006901
 800693c:	08006901 	.word	0x08006901
 8006940:	08006901 	.word	0x08006901
 8006944:	08006a91 	.word	0x08006a91
 8006948:	080069b5 	.word	0x080069b5
 800694c:	08006a73 	.word	0x08006a73
 8006950:	08006901 	.word	0x08006901
 8006954:	08006901 	.word	0x08006901
 8006958:	08006ab3 	.word	0x08006ab3
 800695c:	08006901 	.word	0x08006901
 8006960:	080069b5 	.word	0x080069b5
 8006964:	08006901 	.word	0x08006901
 8006968:	08006901 	.word	0x08006901
 800696c:	08006a7b 	.word	0x08006a7b
 8006970:	680b      	ldr	r3, [r1, #0]
 8006972:	1d1a      	adds	r2, r3, #4
 8006974:	681b      	ldr	r3, [r3, #0]
 8006976:	600a      	str	r2, [r1, #0]
 8006978:	f104 0642 	add.w	r6, r4, #66	; 0x42
 800697c:	f884 3042 	strb.w	r3, [r4, #66]	; 0x42
 8006980:	2301      	movs	r3, #1
 8006982:	e0a3      	b.n	8006acc <_printf_i+0x1f4>
 8006984:	6825      	ldr	r5, [r4, #0]
 8006986:	6808      	ldr	r0, [r1, #0]
 8006988:	062e      	lsls	r6, r5, #24
 800698a:	f100 0304 	add.w	r3, r0, #4
 800698e:	d50a      	bpl.n	80069a6 <_printf_i+0xce>
 8006990:	6805      	ldr	r5, [r0, #0]
 8006992:	600b      	str	r3, [r1, #0]
 8006994:	2d00      	cmp	r5, #0
 8006996:	da03      	bge.n	80069a0 <_printf_i+0xc8>
 8006998:	232d      	movs	r3, #45	; 0x2d
 800699a:	426d      	negs	r5, r5
 800699c:	f884 3043 	strb.w	r3, [r4, #67]	; 0x43
 80069a0:	485e      	ldr	r0, [pc, #376]	; (8006b1c <_printf_i+0x244>)
 80069a2:	230a      	movs	r3, #10
 80069a4:	e019      	b.n	80069da <_printf_i+0x102>
 80069a6:	f015 0f40 	tst.w	r5, #64	; 0x40
 80069aa:	6805      	ldr	r5, [r0, #0]
 80069ac:	600b      	str	r3, [r1, #0]
 80069ae:	bf18      	it	ne
 80069b0:	b22d      	sxthne	r5, r5
 80069b2:	e7ef      	b.n	8006994 <_printf_i+0xbc>
 80069b4:	680b      	ldr	r3, [r1, #0]
 80069b6:	6825      	ldr	r5, [r4, #0]
 80069b8:	1d18      	adds	r0, r3, #4
 80069ba:	6008      	str	r0, [r1, #0]
 80069bc:	0628      	lsls	r0, r5, #24
 80069be:	d501      	bpl.n	80069c4 <_printf_i+0xec>
 80069c0:	681d      	ldr	r5, [r3, #0]
 80069c2:	e002      	b.n	80069ca <_printf_i+0xf2>
 80069c4:	0669      	lsls	r1, r5, #25
 80069c6:	d5fb      	bpl.n	80069c0 <_printf_i+0xe8>
 80069c8:	881d      	ldrh	r5, [r3, #0]
 80069ca:	4854      	ldr	r0, [pc, #336]	; (8006b1c <_printf_i+0x244>)
 80069cc:	2f6f      	cmp	r7, #111	; 0x6f
 80069ce:	bf0c      	ite	eq
 80069d0:	2308      	moveq	r3, #8
 80069d2:	230a      	movne	r3, #10
 80069d4:	2100      	movs	r1, #0
 80069d6:	f884 1043 	strb.w	r1, [r4, #67]	; 0x43
 80069da:	6866      	ldr	r6, [r4, #4]
 80069dc:	60a6      	str	r6, [r4, #8]
 80069de:	2e00      	cmp	r6, #0
 80069e0:	bfa2      	ittt	ge
 80069e2:	6821      	ldrge	r1, [r4, #0]
 80069e4:	f021 0104 	bicge.w	r1, r1, #4
 80069e8:	6021      	strge	r1, [r4, #0]
 80069ea:	b90d      	cbnz	r5, 80069f0 <_printf_i+0x118>
 80069ec:	2e00      	cmp	r6, #0
 80069ee:	d04d      	beq.n	8006a8c <_printf_i+0x1b4>
 80069f0:	4616      	mov	r6, r2
 80069f2:	fbb5 f1f3 	udiv	r1, r5, r3
 80069f6:	fb03 5711 	mls	r7, r3, r1, r5
 80069fa:	5dc7      	ldrb	r7, [r0, r7]
 80069fc:	f806 7d01 	strb.w	r7, [r6, #-1]!
 8006a00:	462f      	mov	r7, r5
 8006a02:	42bb      	cmp	r3, r7
 8006a04:	460d      	mov	r5, r1
 8006a06:	d9f4      	bls.n	80069f2 <_printf_i+0x11a>
 8006a08:	2b08      	cmp	r3, #8
 8006a0a:	d10b      	bne.n	8006a24 <_printf_i+0x14c>
 8006a0c:	6823      	ldr	r3, [r4, #0]
 8006a0e:	07df      	lsls	r7, r3, #31
 8006a10:	d508      	bpl.n	8006a24 <_printf_i+0x14c>
 8006a12:	6923      	ldr	r3, [r4, #16]
 8006a14:	6861      	ldr	r1, [r4, #4]
 8006a16:	4299      	cmp	r1, r3
 8006a18:	bfde      	ittt	le
 8006a1a:	2330      	movle	r3, #48	; 0x30
 8006a1c:	f806 3c01 	strble.w	r3, [r6, #-1]
 8006a20:	f106 36ff 	addle.w	r6, r6, #4294967295
 8006a24:	1b92      	subs	r2, r2, r6
 8006a26:	6122      	str	r2, [r4, #16]
 8006a28:	f8cd a000 	str.w	sl, [sp]
 8006a2c:	464b      	mov	r3, r9
 8006a2e:	aa03      	add	r2, sp, #12
 8006a30:	4621      	mov	r1, r4
 8006a32:	4640      	mov	r0, r8
 8006a34:	f7ff fee2 	bl	80067fc <_printf_common>
 8006a38:	3001      	adds	r0, #1
 8006a3a:	d14c      	bne.n	8006ad6 <_printf_i+0x1fe>
 8006a3c:	f04f 30ff 	mov.w	r0, #4294967295
 8006a40:	b004      	add	sp, #16
 8006a42:	e8bd 87f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, pc}
 8006a46:	4835      	ldr	r0, [pc, #212]	; (8006b1c <_printf_i+0x244>)
 8006a48:	f884 7045 	strb.w	r7, [r4, #69]	; 0x45
 8006a4c:	6823      	ldr	r3, [r4, #0]
 8006a4e:	680e      	ldr	r6, [r1, #0]
 8006a50:	061f      	lsls	r7, r3, #24
 8006a52:	f856 5b04 	ldr.w	r5, [r6], #4
 8006a56:	600e      	str	r6, [r1, #0]
 8006a58:	d514      	bpl.n	8006a84 <_printf_i+0x1ac>
 8006a5a:	07d9      	lsls	r1, r3, #31
 8006a5c:	bf44      	itt	mi
 8006a5e:	f043 0320 	orrmi.w	r3, r3, #32
 8006a62:	6023      	strmi	r3, [r4, #0]
 8006a64:	b91d      	cbnz	r5, 8006a6e <_printf_i+0x196>
 8006a66:	6823      	ldr	r3, [r4, #0]
 8006a68:	f023 0320 	bic.w	r3, r3, #32
 8006a6c:	6023      	str	r3, [r4, #0]
 8006a6e:	2310      	movs	r3, #16
 8006a70:	e7b0      	b.n	80069d4 <_printf_i+0xfc>
 8006a72:	6823      	ldr	r3, [r4, #0]
 8006a74:	f043 0320 	orr.w	r3, r3, #32
 8006a78:	6023      	str	r3, [r4, #0]
 8006a7a:	2378      	movs	r3, #120	; 0x78
 8006a7c:	4828      	ldr	r0, [pc, #160]	; (8006b20 <_printf_i+0x248>)
 8006a7e:	f884 3045 	strb.w	r3, [r4, #69]	; 0x45
 8006a82:	e7e3      	b.n	8006a4c <_printf_i+0x174>
 8006a84:	065e      	lsls	r6, r3, #25
 8006a86:	bf48      	it	mi
 8006a88:	b2ad      	uxthmi	r5, r5
 8006a8a:	e7e6      	b.n	8006a5a <_printf_i+0x182>
 8006a8c:	4616      	mov	r6, r2
 8006a8e:	e7bb      	b.n	8006a08 <_printf_i+0x130>
 8006a90:	680b      	ldr	r3, [r1, #0]
 8006a92:	6826      	ldr	r6, [r4, #0]
 8006a94:	6960      	ldr	r0, [r4, #20]
 8006a96:	1d1d      	adds	r5, r3, #4
 8006a98:	600d      	str	r5, [r1, #0]
 8006a9a:	0635      	lsls	r5, r6, #24
 8006a9c:	681b      	ldr	r3, [r3, #0]
 8006a9e:	d501      	bpl.n	8006aa4 <_printf_i+0x1cc>
 8006aa0:	6018      	str	r0, [r3, #0]
 8006aa2:	e002      	b.n	8006aaa <_printf_i+0x1d2>
 8006aa4:	0671      	lsls	r1, r6, #25
 8006aa6:	d5fb      	bpl.n	8006aa0 <_printf_i+0x1c8>
 8006aa8:	8018      	strh	r0, [r3, #0]
 8006aaa:	2300      	movs	r3, #0
 8006aac:	6123      	str	r3, [r4, #16]
 8006aae:	4616      	mov	r6, r2
 8006ab0:	e7ba      	b.n	8006a28 <_printf_i+0x150>
 8006ab2:	680b      	ldr	r3, [r1, #0]
 8006ab4:	1d1a      	adds	r2, r3, #4
 8006ab6:	600a      	str	r2, [r1, #0]
 8006ab8:	681e      	ldr	r6, [r3, #0]
 8006aba:	6862      	ldr	r2, [r4, #4]
 8006abc:	2100      	movs	r1, #0
 8006abe:	4630      	mov	r0, r6
 8006ac0:	f7f9 fb8e 	bl	80001e0 <memchr>
 8006ac4:	b108      	cbz	r0, 8006aca <_printf_i+0x1f2>
 8006ac6:	1b80      	subs	r0, r0, r6
 8006ac8:	6060      	str	r0, [r4, #4]
 8006aca:	6863      	ldr	r3, [r4, #4]
 8006acc:	6123      	str	r3, [r4, #16]
 8006ace:	2300      	movs	r3, #0
 8006ad0:	f884 3043 	strb.w	r3, [r4, #67]	; 0x43
 8006ad4:	e7a8      	b.n	8006a28 <_printf_i+0x150>
 8006ad6:	6923      	ldr	r3, [r4, #16]
 8006ad8:	4632      	mov	r2, r6
 8006ada:	4649      	mov	r1, r9
 8006adc:	4640      	mov	r0, r8
 8006ade:	47d0      	blx	sl
 8006ae0:	3001      	adds	r0, #1
 8006ae2:	d0ab      	beq.n	8006a3c <_printf_i+0x164>
 8006ae4:	6823      	ldr	r3, [r4, #0]
 8006ae6:	079b      	lsls	r3, r3, #30
 8006ae8:	d413      	bmi.n	8006b12 <_printf_i+0x23a>
 8006aea:	68e0      	ldr	r0, [r4, #12]
 8006aec:	9b03      	ldr	r3, [sp, #12]
 8006aee:	4298      	cmp	r0, r3
 8006af0:	bfb8      	it	lt
 8006af2:	4618      	movlt	r0, r3
 8006af4:	e7a4      	b.n	8006a40 <_printf_i+0x168>
 8006af6:	2301      	movs	r3, #1
 8006af8:	4632      	mov	r2, r6
 8006afa:	4649      	mov	r1, r9
 8006afc:	4640      	mov	r0, r8
 8006afe:	47d0      	blx	sl
 8006b00:	3001      	adds	r0, #1
 8006b02:	d09b      	beq.n	8006a3c <_printf_i+0x164>
 8006b04:	3501      	adds	r5, #1
 8006b06:	68e3      	ldr	r3, [r4, #12]
 8006b08:	9903      	ldr	r1, [sp, #12]
 8006b0a:	1a5b      	subs	r3, r3, r1
 8006b0c:	42ab      	cmp	r3, r5
 8006b0e:	dcf2      	bgt.n	8006af6 <_printf_i+0x21e>
 8006b10:	e7eb      	b.n	8006aea <_printf_i+0x212>
 8006b12:	2500      	movs	r5, #0
 8006b14:	f104 0619 	add.w	r6, r4, #25
 8006b18:	e7f5      	b.n	8006b06 <_printf_i+0x22e>
 8006b1a:	bf00      	nop
 8006b1c:	0800903a 	.word	0x0800903a
 8006b20:	0800904b 	.word	0x0800904b

08006b24 <siprintf>:
 8006b24:	b40e      	push	{r1, r2, r3}
 8006b26:	b500      	push	{lr}
 8006b28:	b09c      	sub	sp, #112	; 0x70
 8006b2a:	ab1d      	add	r3, sp, #116	; 0x74
 8006b2c:	9002      	str	r0, [sp, #8]
 8006b2e:	9006      	str	r0, [sp, #24]
 8006b30:	f06f 4100 	mvn.w	r1, #2147483648	; 0x80000000
 8006b34:	4809      	ldr	r0, [pc, #36]	; (8006b5c <siprintf+0x38>)
 8006b36:	9107      	str	r1, [sp, #28]
 8006b38:	9104      	str	r1, [sp, #16]
 8006b3a:	4909      	ldr	r1, [pc, #36]	; (8006b60 <siprintf+0x3c>)
 8006b3c:	f853 2b04 	ldr.w	r2, [r3], #4
 8006b40:	9105      	str	r1, [sp, #20]
 8006b42:	6800      	ldr	r0, [r0, #0]
 8006b44:	9301      	str	r3, [sp, #4]
 8006b46:	a902      	add	r1, sp, #8
 8006b48:	f001 fb34 	bl	80081b4 <_svfiprintf_r>
 8006b4c:	9b02      	ldr	r3, [sp, #8]
 8006b4e:	2200      	movs	r2, #0
 8006b50:	701a      	strb	r2, [r3, #0]
 8006b52:	b01c      	add	sp, #112	; 0x70
 8006b54:	f85d eb04 	ldr.w	lr, [sp], #4
 8006b58:	b003      	add	sp, #12
 8006b5a:	4770      	bx	lr
 8006b5c:	2000000c 	.word	0x2000000c
 8006b60:	ffff0208 	.word	0xffff0208

08006b64 <quorem>:
 8006b64:	e92d 4ff7 	stmdb	sp!, {r0, r1, r2, r4, r5, r6, r7, r8, r9, sl, fp, lr}
 8006b68:	6903      	ldr	r3, [r0, #16]
 8006b6a:	690c      	ldr	r4, [r1, #16]
 8006b6c:	42a3      	cmp	r3, r4
 8006b6e:	4607      	mov	r7, r0
 8006b70:	f2c0 8081 	blt.w	8006c76 <quorem+0x112>
 8006b74:	3c01      	subs	r4, #1
 8006b76:	f101 0814 	add.w	r8, r1, #20
 8006b7a:	f100 0514 	add.w	r5, r0, #20
 8006b7e:	eb05 0384 	add.w	r3, r5, r4, lsl #2
 8006b82:	9301      	str	r3, [sp, #4]
 8006b84:	f858 3024 	ldr.w	r3, [r8, r4, lsl #2]
 8006b88:	f855 2024 	ldr.w	r2, [r5, r4, lsl #2]
 8006b8c:	3301      	adds	r3, #1
 8006b8e:	429a      	cmp	r2, r3
 8006b90:	ea4f 0b84 	mov.w	fp, r4, lsl #2
 8006b94:	eb08 0984 	add.w	r9, r8, r4, lsl #2
 8006b98:	fbb2 f6f3 	udiv	r6, r2, r3
 8006b9c:	d331      	bcc.n	8006c02 <quorem+0x9e>
 8006b9e:	f04f 0e00 	mov.w	lr, #0
 8006ba2:	4640      	mov	r0, r8
 8006ba4:	46ac      	mov	ip, r5
 8006ba6:	46f2      	mov	sl, lr
 8006ba8:	f850 2b04 	ldr.w	r2, [r0], #4
 8006bac:	b293      	uxth	r3, r2
 8006bae:	fb06 e303 	mla	r3, r6, r3, lr
 8006bb2:	ea4f 4e13 	mov.w	lr, r3, lsr #16
 8006bb6:	b29b      	uxth	r3, r3
 8006bb8:	ebaa 0303 	sub.w	r3, sl, r3
 8006bbc:	0c12      	lsrs	r2, r2, #16
 8006bbe:	f8dc a000 	ldr.w	sl, [ip]
 8006bc2:	fb06 e202 	mla	r2, r6, r2, lr
 8006bc6:	fa13 f38a 	uxtah	r3, r3, sl
 8006bca:	ea4f 4e12 	mov.w	lr, r2, lsr #16
 8006bce:	fa1f fa82 	uxth.w	sl, r2
 8006bd2:	f8dc 2000 	ldr.w	r2, [ip]
 8006bd6:	ebca 4212 	rsb	r2, sl, r2, lsr #16
 8006bda:	eb02 4223 	add.w	r2, r2, r3, asr #16
 8006bde:	b29b      	uxth	r3, r3
 8006be0:	ea43 4302 	orr.w	r3, r3, r2, lsl #16
 8006be4:	4581      	cmp	r9, r0
 8006be6:	f84c 3b04 	str.w	r3, [ip], #4
 8006bea:	ea4f 4a22 	mov.w	sl, r2, asr #16
 8006bee:	d2db      	bcs.n	8006ba8 <quorem+0x44>
 8006bf0:	f855 300b 	ldr.w	r3, [r5, fp]
 8006bf4:	b92b      	cbnz	r3, 8006c02 <quorem+0x9e>
 8006bf6:	9b01      	ldr	r3, [sp, #4]
 8006bf8:	3b04      	subs	r3, #4
 8006bfa:	429d      	cmp	r5, r3
 8006bfc:	461a      	mov	r2, r3
 8006bfe:	d32e      	bcc.n	8006c5e <quorem+0xfa>
 8006c00:	613c      	str	r4, [r7, #16]
 8006c02:	4638      	mov	r0, r7
 8006c04:	f001 f8c0 	bl	8007d88 <__mcmp>
 8006c08:	2800      	cmp	r0, #0
 8006c0a:	db24      	blt.n	8006c56 <quorem+0xf2>
 8006c0c:	3601      	adds	r6, #1
 8006c0e:	4628      	mov	r0, r5
 8006c10:	f04f 0c00 	mov.w	ip, #0
 8006c14:	f858 2b04 	ldr.w	r2, [r8], #4
 8006c18:	f8d0 e000 	ldr.w	lr, [r0]
 8006c1c:	b293      	uxth	r3, r2
 8006c1e:	ebac 0303 	sub.w	r3, ip, r3
 8006c22:	0c12      	lsrs	r2, r2, #16
 8006c24:	fa13 f38e 	uxtah	r3, r3, lr
 8006c28:	ebc2 421e 	rsb	r2, r2, lr, lsr #16
 8006c2c:	eb02 4223 	add.w	r2, r2, r3, asr #16
 8006c30:	b29b      	uxth	r3, r3
 8006c32:	ea43 4302 	orr.w	r3, r3, r2, lsl #16
 8006c36:	45c1      	cmp	r9, r8
 8006c38:	f840 3b04 	str.w	r3, [r0], #4
 8006c3c:	ea4f 4c22 	mov.w	ip, r2, asr #16
 8006c40:	d2e8      	bcs.n	8006c14 <quorem+0xb0>
 8006c42:	f855 2024 	ldr.w	r2, [r5, r4, lsl #2]
 8006c46:	eb05 0384 	add.w	r3, r5, r4, lsl #2
 8006c4a:	b922      	cbnz	r2, 8006c56 <quorem+0xf2>
 8006c4c:	3b04      	subs	r3, #4
 8006c4e:	429d      	cmp	r5, r3
 8006c50:	461a      	mov	r2, r3
 8006c52:	d30a      	bcc.n	8006c6a <quorem+0x106>
 8006c54:	613c      	str	r4, [r7, #16]
 8006c56:	4630      	mov	r0, r6
 8006c58:	b003      	add	sp, #12
 8006c5a:	e8bd 8ff0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, pc}
 8006c5e:	6812      	ldr	r2, [r2, #0]
 8006c60:	3b04      	subs	r3, #4
 8006c62:	2a00      	cmp	r2, #0
 8006c64:	d1cc      	bne.n	8006c00 <quorem+0x9c>
 8006c66:	3c01      	subs	r4, #1
 8006c68:	e7c7      	b.n	8006bfa <quorem+0x96>
 8006c6a:	6812      	ldr	r2, [r2, #0]
 8006c6c:	3b04      	subs	r3, #4
 8006c6e:	2a00      	cmp	r2, #0
 8006c70:	d1f0      	bne.n	8006c54 <quorem+0xf0>
 8006c72:	3c01      	subs	r4, #1
 8006c74:	e7eb      	b.n	8006c4e <quorem+0xea>
 8006c76:	2000      	movs	r0, #0
 8006c78:	e7ee      	b.n	8006c58 <quorem+0xf4>
 8006c7a:	0000      	movs	r0, r0
 8006c7c:	0000      	movs	r0, r0
	...

08006c80 <_dtoa_r>:
 8006c80:	e92d 4ff0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, lr}
 8006c84:	ed2d 8b02 	vpush	{d8}
 8006c88:	ec57 6b10 	vmov	r6, r7, d0
 8006c8c:	b095      	sub	sp, #84	; 0x54
 8006c8e:	6a45      	ldr	r5, [r0, #36]	; 0x24
 8006c90:	f8dd 8080 	ldr.w	r8, [sp, #128]	; 0x80
 8006c94:	9105      	str	r1, [sp, #20]
 8006c96:	e9cd 6702 	strd	r6, r7, [sp, #8]
 8006c9a:	4604      	mov	r4, r0
 8006c9c:	9209      	str	r2, [sp, #36]	; 0x24
 8006c9e:	930f      	str	r3, [sp, #60]	; 0x3c
 8006ca0:	b975      	cbnz	r5, 8006cc0 <_dtoa_r+0x40>
 8006ca2:	2010      	movs	r0, #16
 8006ca4:	f000 fddc 	bl	8007860 <malloc>
 8006ca8:	4602      	mov	r2, r0
 8006caa:	6260      	str	r0, [r4, #36]	; 0x24
 8006cac:	b920      	cbnz	r0, 8006cb8 <_dtoa_r+0x38>
 8006cae:	4bb2      	ldr	r3, [pc, #712]	; (8006f78 <_dtoa_r+0x2f8>)
 8006cb0:	21ea      	movs	r1, #234	; 0xea
 8006cb2:	48b2      	ldr	r0, [pc, #712]	; (8006f7c <_dtoa_r+0x2fc>)
 8006cb4:	f001 fb8e 	bl	80083d4 <__assert_func>
 8006cb8:	e9c0 5501 	strd	r5, r5, [r0, #4]
 8006cbc:	6005      	str	r5, [r0, #0]
 8006cbe:	60c5      	str	r5, [r0, #12]
 8006cc0:	6a63      	ldr	r3, [r4, #36]	; 0x24
 8006cc2:	6819      	ldr	r1, [r3, #0]
 8006cc4:	b151      	cbz	r1, 8006cdc <_dtoa_r+0x5c>
 8006cc6:	685a      	ldr	r2, [r3, #4]
 8006cc8:	604a      	str	r2, [r1, #4]
 8006cca:	2301      	movs	r3, #1
 8006ccc:	4093      	lsls	r3, r2
 8006cce:	608b      	str	r3, [r1, #8]
 8006cd0:	4620      	mov	r0, r4
 8006cd2:	f000 fe1b 	bl	800790c <_Bfree>
 8006cd6:	6a63      	ldr	r3, [r4, #36]	; 0x24
 8006cd8:	2200      	movs	r2, #0
 8006cda:	601a      	str	r2, [r3, #0]
 8006cdc:	1e3b      	subs	r3, r7, #0
 8006cde:	bfb9      	ittee	lt
 8006ce0:	f023 4300 	biclt.w	r3, r3, #2147483648	; 0x80000000
 8006ce4:	9303      	strlt	r3, [sp, #12]
 8006ce6:	2300      	movge	r3, #0
 8006ce8:	f8c8 3000 	strge.w	r3, [r8]
 8006cec:	f8dd 900c 	ldr.w	r9, [sp, #12]
 8006cf0:	4ba3      	ldr	r3, [pc, #652]	; (8006f80 <_dtoa_r+0x300>)
 8006cf2:	bfbc      	itt	lt
 8006cf4:	2201      	movlt	r2, #1
 8006cf6:	f8c8 2000 	strlt.w	r2, [r8]
 8006cfa:	ea33 0309 	bics.w	r3, r3, r9
 8006cfe:	d11b      	bne.n	8006d38 <_dtoa_r+0xb8>
 8006d00:	9a0f      	ldr	r2, [sp, #60]	; 0x3c
 8006d02:	f242 730f 	movw	r3, #9999	; 0x270f
 8006d06:	6013      	str	r3, [r2, #0]
 8006d08:	f3c9 0313 	ubfx	r3, r9, #0, #20
 8006d0c:	4333      	orrs	r3, r6
 8006d0e:	f000 857a 	beq.w	8007806 <_dtoa_r+0xb86>
 8006d12:	9b21      	ldr	r3, [sp, #132]	; 0x84
 8006d14:	b963      	cbnz	r3, 8006d30 <_dtoa_r+0xb0>
 8006d16:	4b9b      	ldr	r3, [pc, #620]	; (8006f84 <_dtoa_r+0x304>)
 8006d18:	e024      	b.n	8006d64 <_dtoa_r+0xe4>
 8006d1a:	4b9b      	ldr	r3, [pc, #620]	; (8006f88 <_dtoa_r+0x308>)
 8006d1c:	9300      	str	r3, [sp, #0]
 8006d1e:	3308      	adds	r3, #8
 8006d20:	9a21      	ldr	r2, [sp, #132]	; 0x84
 8006d22:	6013      	str	r3, [r2, #0]
 8006d24:	9800      	ldr	r0, [sp, #0]
 8006d26:	b015      	add	sp, #84	; 0x54
 8006d28:	ecbd 8b02 	vpop	{d8}
 8006d2c:	e8bd 8ff0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, pc}
 8006d30:	4b94      	ldr	r3, [pc, #592]	; (8006f84 <_dtoa_r+0x304>)
 8006d32:	9300      	str	r3, [sp, #0]
 8006d34:	3303      	adds	r3, #3
 8006d36:	e7f3      	b.n	8006d20 <_dtoa_r+0xa0>
 8006d38:	ed9d 7b02 	vldr	d7, [sp, #8]
 8006d3c:	2200      	movs	r2, #0
 8006d3e:	ec51 0b17 	vmov	r0, r1, d7
 8006d42:	2300      	movs	r3, #0
 8006d44:	ed8d 7b0a 	vstr	d7, [sp, #40]	; 0x28
 8006d48:	f7f9 febe 	bl	8000ac8 <__aeabi_dcmpeq>
 8006d4c:	4680      	mov	r8, r0
 8006d4e:	b158      	cbz	r0, 8006d68 <_dtoa_r+0xe8>
 8006d50:	9a0f      	ldr	r2, [sp, #60]	; 0x3c
 8006d52:	2301      	movs	r3, #1
 8006d54:	6013      	str	r3, [r2, #0]
 8006d56:	9b21      	ldr	r3, [sp, #132]	; 0x84
 8006d58:	2b00      	cmp	r3, #0
 8006d5a:	f000 8551 	beq.w	8007800 <_dtoa_r+0xb80>
 8006d5e:	488b      	ldr	r0, [pc, #556]	; (8006f8c <_dtoa_r+0x30c>)
 8006d60:	6018      	str	r0, [r3, #0]
 8006d62:	1e43      	subs	r3, r0, #1
 8006d64:	9300      	str	r3, [sp, #0]
 8006d66:	e7dd      	b.n	8006d24 <_dtoa_r+0xa4>
 8006d68:	ed9d 0b0a 	vldr	d0, [sp, #40]	; 0x28
 8006d6c:	aa12      	add	r2, sp, #72	; 0x48
 8006d6e:	a913      	add	r1, sp, #76	; 0x4c
 8006d70:	4620      	mov	r0, r4
 8006d72:	f001 f8ad 	bl	8007ed0 <__d2b>
 8006d76:	f3c9 550a 	ubfx	r5, r9, #20, #11
 8006d7a:	4683      	mov	fp, r0
 8006d7c:	2d00      	cmp	r5, #0
 8006d7e:	d07c      	beq.n	8006e7a <_dtoa_r+0x1fa>
 8006d80:	9b0b      	ldr	r3, [sp, #44]	; 0x2c
 8006d82:	f8cd 8040 	str.w	r8, [sp, #64]	; 0x40
 8006d86:	f3c3 0313 	ubfx	r3, r3, #0, #20
 8006d8a:	e9dd 670a 	ldrd	r6, r7, [sp, #40]	; 0x28
 8006d8e:	f043 577f 	orr.w	r7, r3, #1069547520	; 0x3fc00000
 8006d92:	f447 1740 	orr.w	r7, r7, #3145728	; 0x300000
 8006d96:	f2a5 35ff 	subw	r5, r5, #1023	; 0x3ff
 8006d9a:	4b7d      	ldr	r3, [pc, #500]	; (8006f90 <_dtoa_r+0x310>)
 8006d9c:	2200      	movs	r2, #0
 8006d9e:	4630      	mov	r0, r6
 8006da0:	4639      	mov	r1, r7
 8006da2:	f7f9 fa71 	bl	8000288 <__aeabi_dsub>
 8006da6:	a36e      	add	r3, pc, #440	; (adr r3, 8006f60 <_dtoa_r+0x2e0>)
 8006da8:	e9d3 2300 	ldrd	r2, r3, [r3]
 8006dac:	f7f9 fc24 	bl	80005f8 <__aeabi_dmul>
 8006db0:	a36d      	add	r3, pc, #436	; (adr r3, 8006f68 <_dtoa_r+0x2e8>)
 8006db2:	e9d3 2300 	ldrd	r2, r3, [r3]
 8006db6:	f7f9 fa69 	bl	800028c <__adddf3>
 8006dba:	4606      	mov	r6, r0
 8006dbc:	4628      	mov	r0, r5
 8006dbe:	460f      	mov	r7, r1
 8006dc0:	f7f9 fbb0 	bl	8000524 <__aeabi_i2d>
 8006dc4:	a36a      	add	r3, pc, #424	; (adr r3, 8006f70 <_dtoa_r+0x2f0>)
 8006dc6:	e9d3 2300 	ldrd	r2, r3, [r3]
 8006dca:	f7f9 fc15 	bl	80005f8 <__aeabi_dmul>
 8006dce:	4602      	mov	r2, r0
 8006dd0:	460b      	mov	r3, r1
 8006dd2:	4630      	mov	r0, r6
 8006dd4:	4639      	mov	r1, r7
 8006dd6:	f7f9 fa59 	bl	800028c <__adddf3>
 8006dda:	4606      	mov	r6, r0
 8006ddc:	460f      	mov	r7, r1
 8006dde:	f7f9 febb 	bl	8000b58 <__aeabi_d2iz>
 8006de2:	2200      	movs	r2, #0
 8006de4:	4682      	mov	sl, r0
 8006de6:	2300      	movs	r3, #0
 8006de8:	4630      	mov	r0, r6
 8006dea:	4639      	mov	r1, r7
 8006dec:	f7f9 fe76 	bl	8000adc <__aeabi_dcmplt>
 8006df0:	b148      	cbz	r0, 8006e06 <_dtoa_r+0x186>
 8006df2:	4650      	mov	r0, sl
 8006df4:	f7f9 fb96 	bl	8000524 <__aeabi_i2d>
 8006df8:	4632      	mov	r2, r6
 8006dfa:	463b      	mov	r3, r7
 8006dfc:	f7f9 fe64 	bl	8000ac8 <__aeabi_dcmpeq>
 8006e00:	b908      	cbnz	r0, 8006e06 <_dtoa_r+0x186>
 8006e02:	f10a 3aff 	add.w	sl, sl, #4294967295
 8006e06:	f1ba 0f16 	cmp.w	sl, #22
 8006e0a:	d854      	bhi.n	8006eb6 <_dtoa_r+0x236>
 8006e0c:	4b61      	ldr	r3, [pc, #388]	; (8006f94 <_dtoa_r+0x314>)
 8006e0e:	eb03 03ca 	add.w	r3, r3, sl, lsl #3
 8006e12:	e9d3 2300 	ldrd	r2, r3, [r3]
 8006e16:	e9dd 010a 	ldrd	r0, r1, [sp, #40]	; 0x28
 8006e1a:	f7f9 fe5f 	bl	8000adc <__aeabi_dcmplt>
 8006e1e:	2800      	cmp	r0, #0
 8006e20:	d04b      	beq.n	8006eba <_dtoa_r+0x23a>
 8006e22:	f10a 3aff 	add.w	sl, sl, #4294967295
 8006e26:	2300      	movs	r3, #0
 8006e28:	930e      	str	r3, [sp, #56]	; 0x38
 8006e2a:	9b12      	ldr	r3, [sp, #72]	; 0x48
 8006e2c:	1b5d      	subs	r5, r3, r5
 8006e2e:	1e6b      	subs	r3, r5, #1
 8006e30:	9304      	str	r3, [sp, #16]
 8006e32:	bf43      	ittte	mi
 8006e34:	2300      	movmi	r3, #0
 8006e36:	f1c5 0801 	rsbmi	r8, r5, #1
 8006e3a:	9304      	strmi	r3, [sp, #16]
 8006e3c:	f04f 0800 	movpl.w	r8, #0
 8006e40:	f1ba 0f00 	cmp.w	sl, #0
 8006e44:	db3b      	blt.n	8006ebe <_dtoa_r+0x23e>
 8006e46:	9b04      	ldr	r3, [sp, #16]
 8006e48:	f8cd a034 	str.w	sl, [sp, #52]	; 0x34
 8006e4c:	4453      	add	r3, sl
 8006e4e:	9304      	str	r3, [sp, #16]
 8006e50:	2300      	movs	r3, #0
 8006e52:	9306      	str	r3, [sp, #24]
 8006e54:	9b05      	ldr	r3, [sp, #20]
 8006e56:	2b09      	cmp	r3, #9
 8006e58:	d869      	bhi.n	8006f2e <_dtoa_r+0x2ae>
 8006e5a:	2b05      	cmp	r3, #5
 8006e5c:	bfc4      	itt	gt
 8006e5e:	3b04      	subgt	r3, #4
 8006e60:	9305      	strgt	r3, [sp, #20]
 8006e62:	9b05      	ldr	r3, [sp, #20]
 8006e64:	f1a3 0302 	sub.w	r3, r3, #2
 8006e68:	bfcc      	ite	gt
 8006e6a:	2500      	movgt	r5, #0
 8006e6c:	2501      	movle	r5, #1
 8006e6e:	2b03      	cmp	r3, #3
 8006e70:	d869      	bhi.n	8006f46 <_dtoa_r+0x2c6>
 8006e72:	e8df f003 	tbb	[pc, r3]
 8006e76:	4e2c      	.short	0x4e2c
 8006e78:	5a4c      	.short	0x5a4c
 8006e7a:	e9dd 5312 	ldrd	r5, r3, [sp, #72]	; 0x48
 8006e7e:	441d      	add	r5, r3
 8006e80:	f205 4332 	addw	r3, r5, #1074	; 0x432
 8006e84:	2b20      	cmp	r3, #32
 8006e86:	bfc1      	itttt	gt
 8006e88:	f1c3 0340 	rsbgt	r3, r3, #64	; 0x40
 8006e8c:	f205 4012 	addwgt	r0, r5, #1042	; 0x412
 8006e90:	fa09 f303 	lslgt.w	r3, r9, r3
 8006e94:	fa26 f000 	lsrgt.w	r0, r6, r0
 8006e98:	bfda      	itte	le
 8006e9a:	f1c3 0320 	rsble	r3, r3, #32
 8006e9e:	fa06 f003 	lslle.w	r0, r6, r3
 8006ea2:	4318      	orrgt	r0, r3
 8006ea4:	f7f9 fb2e 	bl	8000504 <__aeabi_ui2d>
 8006ea8:	2301      	movs	r3, #1
 8006eaa:	4606      	mov	r6, r0
 8006eac:	f1a1 77f8 	sub.w	r7, r1, #32505856	; 0x1f00000
 8006eb0:	3d01      	subs	r5, #1
 8006eb2:	9310      	str	r3, [sp, #64]	; 0x40
 8006eb4:	e771      	b.n	8006d9a <_dtoa_r+0x11a>
 8006eb6:	2301      	movs	r3, #1
 8006eb8:	e7b6      	b.n	8006e28 <_dtoa_r+0x1a8>
 8006eba:	900e      	str	r0, [sp, #56]	; 0x38
 8006ebc:	e7b5      	b.n	8006e2a <_dtoa_r+0x1aa>
 8006ebe:	f1ca 0300 	rsb	r3, sl, #0
 8006ec2:	9306      	str	r3, [sp, #24]
 8006ec4:	2300      	movs	r3, #0
 8006ec6:	eba8 080a 	sub.w	r8, r8, sl
 8006eca:	930d      	str	r3, [sp, #52]	; 0x34
 8006ecc:	e7c2      	b.n	8006e54 <_dtoa_r+0x1d4>
 8006ece:	2300      	movs	r3, #0
 8006ed0:	9308      	str	r3, [sp, #32]
 8006ed2:	9b09      	ldr	r3, [sp, #36]	; 0x24
 8006ed4:	2b00      	cmp	r3, #0
 8006ed6:	dc39      	bgt.n	8006f4c <_dtoa_r+0x2cc>
 8006ed8:	f04f 0901 	mov.w	r9, #1
 8006edc:	f8cd 9004 	str.w	r9, [sp, #4]
 8006ee0:	464b      	mov	r3, r9
 8006ee2:	f8cd 9024 	str.w	r9, [sp, #36]	; 0x24
 8006ee6:	6a60      	ldr	r0, [r4, #36]	; 0x24
 8006ee8:	2200      	movs	r2, #0
 8006eea:	6042      	str	r2, [r0, #4]
 8006eec:	2204      	movs	r2, #4
 8006eee:	f102 0614 	add.w	r6, r2, #20
 8006ef2:	429e      	cmp	r6, r3
 8006ef4:	6841      	ldr	r1, [r0, #4]
 8006ef6:	d92f      	bls.n	8006f58 <_dtoa_r+0x2d8>
 8006ef8:	4620      	mov	r0, r4
 8006efa:	f000 fcc7 	bl	800788c <_Balloc>
 8006efe:	9000      	str	r0, [sp, #0]
 8006f00:	2800      	cmp	r0, #0
 8006f02:	d14b      	bne.n	8006f9c <_dtoa_r+0x31c>
 8006f04:	4b24      	ldr	r3, [pc, #144]	; (8006f98 <_dtoa_r+0x318>)
 8006f06:	4602      	mov	r2, r0
 8006f08:	f44f 71d5 	mov.w	r1, #426	; 0x1aa
 8006f0c:	e6d1      	b.n	8006cb2 <_dtoa_r+0x32>
 8006f0e:	2301      	movs	r3, #1
 8006f10:	e7de      	b.n	8006ed0 <_dtoa_r+0x250>
 8006f12:	2300      	movs	r3, #0
 8006f14:	9308      	str	r3, [sp, #32]
 8006f16:	9b09      	ldr	r3, [sp, #36]	; 0x24
 8006f18:	eb0a 0903 	add.w	r9, sl, r3
 8006f1c:	f109 0301 	add.w	r3, r9, #1
 8006f20:	2b01      	cmp	r3, #1
 8006f22:	9301      	str	r3, [sp, #4]
 8006f24:	bfb8      	it	lt
 8006f26:	2301      	movlt	r3, #1
 8006f28:	e7dd      	b.n	8006ee6 <_dtoa_r+0x266>
 8006f2a:	2301      	movs	r3, #1
 8006f2c:	e7f2      	b.n	8006f14 <_dtoa_r+0x294>
 8006f2e:	2501      	movs	r5, #1
 8006f30:	2300      	movs	r3, #0
 8006f32:	9305      	str	r3, [sp, #20]
 8006f34:	9508      	str	r5, [sp, #32]
 8006f36:	f04f 39ff 	mov.w	r9, #4294967295
 8006f3a:	2200      	movs	r2, #0
 8006f3c:	f8cd 9004 	str.w	r9, [sp, #4]
 8006f40:	2312      	movs	r3, #18
 8006f42:	9209      	str	r2, [sp, #36]	; 0x24
 8006f44:	e7cf      	b.n	8006ee6 <_dtoa_r+0x266>
 8006f46:	2301      	movs	r3, #1
 8006f48:	9308      	str	r3, [sp, #32]
 8006f4a:	e7f4      	b.n	8006f36 <_dtoa_r+0x2b6>
 8006f4c:	f8dd 9024 	ldr.w	r9, [sp, #36]	; 0x24
 8006f50:	f8cd 9004 	str.w	r9, [sp, #4]
 8006f54:	464b      	mov	r3, r9
 8006f56:	e7c6      	b.n	8006ee6 <_dtoa_r+0x266>
 8006f58:	3101      	adds	r1, #1
 8006f5a:	6041      	str	r1, [r0, #4]
 8006f5c:	0052      	lsls	r2, r2, #1
 8006f5e:	e7c6      	b.n	8006eee <_dtoa_r+0x26e>
 8006f60:	636f4361 	.word	0x636f4361
 8006f64:	3fd287a7 	.word	0x3fd287a7
 8006f68:	8b60c8b3 	.word	0x8b60c8b3
 8006f6c:	3fc68a28 	.word	0x3fc68a28
 8006f70:	509f79fb 	.word	0x509f79fb
 8006f74:	3fd34413 	.word	0x3fd34413
 8006f78:	08009069 	.word	0x08009069
 8006f7c:	08009080 	.word	0x08009080
 8006f80:	7ff00000 	.word	0x7ff00000
 8006f84:	08009065 	.word	0x08009065
 8006f88:	0800905c 	.word	0x0800905c
 8006f8c:	08009039 	.word	0x08009039
 8006f90:	3ff80000 	.word	0x3ff80000
 8006f94:	08009178 	.word	0x08009178
 8006f98:	080090df 	.word	0x080090df
 8006f9c:	6a63      	ldr	r3, [r4, #36]	; 0x24
 8006f9e:	9a00      	ldr	r2, [sp, #0]
 8006fa0:	601a      	str	r2, [r3, #0]
 8006fa2:	9b01      	ldr	r3, [sp, #4]
 8006fa4:	2b0e      	cmp	r3, #14
 8006fa6:	f200 80ad 	bhi.w	8007104 <_dtoa_r+0x484>
 8006faa:	2d00      	cmp	r5, #0
 8006fac:	f000 80aa 	beq.w	8007104 <_dtoa_r+0x484>
 8006fb0:	f1ba 0f00 	cmp.w	sl, #0
 8006fb4:	dd36      	ble.n	8007024 <_dtoa_r+0x3a4>
 8006fb6:	4ac3      	ldr	r2, [pc, #780]	; (80072c4 <_dtoa_r+0x644>)
 8006fb8:	f00a 030f 	and.w	r3, sl, #15
 8006fbc:	eb02 03c3 	add.w	r3, r2, r3, lsl #3
 8006fc0:	ed93 7b00 	vldr	d7, [r3]
 8006fc4:	f41a 7f80 	tst.w	sl, #256	; 0x100
 8006fc8:	ea4f 172a 	mov.w	r7, sl, asr #4
 8006fcc:	eeb0 8a47 	vmov.f32	s16, s14
 8006fd0:	eef0 8a67 	vmov.f32	s17, s15
 8006fd4:	d016      	beq.n	8007004 <_dtoa_r+0x384>
 8006fd6:	4bbc      	ldr	r3, [pc, #752]	; (80072c8 <_dtoa_r+0x648>)
 8006fd8:	e9dd 010a 	ldrd	r0, r1, [sp, #40]	; 0x28
 8006fdc:	e9d3 2308 	ldrd	r2, r3, [r3, #32]
 8006fe0:	f7f9 fc34 	bl	800084c <__aeabi_ddiv>
 8006fe4:	e9cd 0102 	strd	r0, r1, [sp, #8]
 8006fe8:	f007 070f 	and.w	r7, r7, #15
 8006fec:	2503      	movs	r5, #3
 8006fee:	4eb6      	ldr	r6, [pc, #728]	; (80072c8 <_dtoa_r+0x648>)
 8006ff0:	b957      	cbnz	r7, 8007008 <_dtoa_r+0x388>
 8006ff2:	e9dd 0102 	ldrd	r0, r1, [sp, #8]
 8006ff6:	ec53 2b18 	vmov	r2, r3, d8
 8006ffa:	f7f9 fc27 	bl	800084c <__aeabi_ddiv>
 8006ffe:	e9cd 0102 	strd	r0, r1, [sp, #8]
 8007002:	e029      	b.n	8007058 <_dtoa_r+0x3d8>
 8007004:	2502      	movs	r5, #2
 8007006:	e7f2      	b.n	8006fee <_dtoa_r+0x36e>
 8007008:	07f9      	lsls	r1, r7, #31
 800700a:	d508      	bpl.n	800701e <_dtoa_r+0x39e>
 800700c:	ec51 0b18 	vmov	r0, r1, d8
 8007010:	e9d6 2300 	ldrd	r2, r3, [r6]
 8007014:	f7f9 faf0 	bl	80005f8 <__aeabi_dmul>
 8007018:	ec41 0b18 	vmov	d8, r0, r1
 800701c:	3501      	adds	r5, #1
 800701e:	107f      	asrs	r7, r7, #1
 8007020:	3608      	adds	r6, #8
 8007022:	e7e5      	b.n	8006ff0 <_dtoa_r+0x370>
 8007024:	f000 80a6 	beq.w	8007174 <_dtoa_r+0x4f4>
 8007028:	f1ca 0600 	rsb	r6, sl, #0
 800702c:	4ba5      	ldr	r3, [pc, #660]	; (80072c4 <_dtoa_r+0x644>)
 800702e:	4fa6      	ldr	r7, [pc, #664]	; (80072c8 <_dtoa_r+0x648>)
 8007030:	f006 020f 	and.w	r2, r6, #15
 8007034:	eb03 03c2 	add.w	r3, r3, r2, lsl #3
 8007038:	e9d3 2300 	ldrd	r2, r3, [r3]
 800703c:	e9dd 010a 	ldrd	r0, r1, [sp, #40]	; 0x28
 8007040:	f7f9 fada 	bl	80005f8 <__aeabi_dmul>
 8007044:	e9cd 0102 	strd	r0, r1, [sp, #8]
 8007048:	1136      	asrs	r6, r6, #4
 800704a:	2300      	movs	r3, #0
 800704c:	2502      	movs	r5, #2
 800704e:	2e00      	cmp	r6, #0
 8007050:	f040 8085 	bne.w	800715e <_dtoa_r+0x4de>
 8007054:	2b00      	cmp	r3, #0
 8007056:	d1d2      	bne.n	8006ffe <_dtoa_r+0x37e>
 8007058:	9b0e      	ldr	r3, [sp, #56]	; 0x38
 800705a:	2b00      	cmp	r3, #0
 800705c:	f000 808c 	beq.w	8007178 <_dtoa_r+0x4f8>
 8007060:	e9dd 6702 	ldrd	r6, r7, [sp, #8]
 8007064:	4b99      	ldr	r3, [pc, #612]	; (80072cc <_dtoa_r+0x64c>)
 8007066:	2200      	movs	r2, #0
 8007068:	4630      	mov	r0, r6
 800706a:	4639      	mov	r1, r7
 800706c:	f7f9 fd36 	bl	8000adc <__aeabi_dcmplt>
 8007070:	2800      	cmp	r0, #0
 8007072:	f000 8081 	beq.w	8007178 <_dtoa_r+0x4f8>
 8007076:	9b01      	ldr	r3, [sp, #4]
 8007078:	2b00      	cmp	r3, #0
 800707a:	d07d      	beq.n	8007178 <_dtoa_r+0x4f8>
 800707c:	f1b9 0f00 	cmp.w	r9, #0
 8007080:	dd3c      	ble.n	80070fc <_dtoa_r+0x47c>
 8007082:	f10a 33ff 	add.w	r3, sl, #4294967295
 8007086:	9307      	str	r3, [sp, #28]
 8007088:	2200      	movs	r2, #0
 800708a:	4b91      	ldr	r3, [pc, #580]	; (80072d0 <_dtoa_r+0x650>)
 800708c:	4630      	mov	r0, r6
 800708e:	4639      	mov	r1, r7
 8007090:	f7f9 fab2 	bl	80005f8 <__aeabi_dmul>
 8007094:	e9cd 0102 	strd	r0, r1, [sp, #8]
 8007098:	3501      	adds	r5, #1
 800709a:	f8cd 9030 	str.w	r9, [sp, #48]	; 0x30
 800709e:	e9dd 6702 	ldrd	r6, r7, [sp, #8]
 80070a2:	4628      	mov	r0, r5
 80070a4:	f7f9 fa3e 	bl	8000524 <__aeabi_i2d>
 80070a8:	4632      	mov	r2, r6
 80070aa:	463b      	mov	r3, r7
 80070ac:	f7f9 faa4 	bl	80005f8 <__aeabi_dmul>
 80070b0:	4b88      	ldr	r3, [pc, #544]	; (80072d4 <_dtoa_r+0x654>)
 80070b2:	2200      	movs	r2, #0
 80070b4:	f7f9 f8ea 	bl	800028c <__adddf3>
 80070b8:	f1a1 7350 	sub.w	r3, r1, #54525952	; 0x3400000
 80070bc:	e9cd 0102 	strd	r0, r1, [sp, #8]
 80070c0:	9303      	str	r3, [sp, #12]
 80070c2:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 80070c4:	2b00      	cmp	r3, #0
 80070c6:	d15c      	bne.n	8007182 <_dtoa_r+0x502>
 80070c8:	4b83      	ldr	r3, [pc, #524]	; (80072d8 <_dtoa_r+0x658>)
 80070ca:	2200      	movs	r2, #0
 80070cc:	4630      	mov	r0, r6
 80070ce:	4639      	mov	r1, r7
 80070d0:	f7f9 f8da 	bl	8000288 <__aeabi_dsub>
 80070d4:	e9dd 2302 	ldrd	r2, r3, [sp, #8]
 80070d8:	4606      	mov	r6, r0
 80070da:	460f      	mov	r7, r1
 80070dc:	f7f9 fd1c 	bl	8000b18 <__aeabi_dcmpgt>
 80070e0:	2800      	cmp	r0, #0
 80070e2:	f040 8296 	bne.w	8007612 <_dtoa_r+0x992>
 80070e6:	e9dd 2102 	ldrd	r2, r1, [sp, #8]
 80070ea:	4630      	mov	r0, r6
 80070ec:	f101 4300 	add.w	r3, r1, #2147483648	; 0x80000000
 80070f0:	4639      	mov	r1, r7
 80070f2:	f7f9 fcf3 	bl	8000adc <__aeabi_dcmplt>
 80070f6:	2800      	cmp	r0, #0
 80070f8:	f040 8288 	bne.w	800760c <_dtoa_r+0x98c>
 80070fc:	e9dd 230a 	ldrd	r2, r3, [sp, #40]	; 0x28
 8007100:	e9cd 2302 	strd	r2, r3, [sp, #8]
 8007104:	9b13      	ldr	r3, [sp, #76]	; 0x4c
 8007106:	2b00      	cmp	r3, #0
 8007108:	f2c0 8158 	blt.w	80073bc <_dtoa_r+0x73c>
 800710c:	f1ba 0f0e 	cmp.w	sl, #14
 8007110:	f300 8154 	bgt.w	80073bc <_dtoa_r+0x73c>
 8007114:	4b6b      	ldr	r3, [pc, #428]	; (80072c4 <_dtoa_r+0x644>)
 8007116:	eb03 03ca 	add.w	r3, r3, sl, lsl #3
 800711a:	e9d3 8900 	ldrd	r8, r9, [r3]
 800711e:	9b09      	ldr	r3, [sp, #36]	; 0x24
 8007120:	2b00      	cmp	r3, #0
 8007122:	f280 80e3 	bge.w	80072ec <_dtoa_r+0x66c>
 8007126:	9b01      	ldr	r3, [sp, #4]
 8007128:	2b00      	cmp	r3, #0
 800712a:	f300 80df 	bgt.w	80072ec <_dtoa_r+0x66c>
 800712e:	f040 826d 	bne.w	800760c <_dtoa_r+0x98c>
 8007132:	4b69      	ldr	r3, [pc, #420]	; (80072d8 <_dtoa_r+0x658>)
 8007134:	2200      	movs	r2, #0
 8007136:	4640      	mov	r0, r8
 8007138:	4649      	mov	r1, r9
 800713a:	f7f9 fa5d 	bl	80005f8 <__aeabi_dmul>
 800713e:	e9dd 2302 	ldrd	r2, r3, [sp, #8]
 8007142:	f7f9 fcdf 	bl	8000b04 <__aeabi_dcmpge>
 8007146:	9e01      	ldr	r6, [sp, #4]
 8007148:	4637      	mov	r7, r6
 800714a:	2800      	cmp	r0, #0
 800714c:	f040 8243 	bne.w	80075d6 <_dtoa_r+0x956>
 8007150:	9d00      	ldr	r5, [sp, #0]
 8007152:	2331      	movs	r3, #49	; 0x31
 8007154:	f805 3b01 	strb.w	r3, [r5], #1
 8007158:	f10a 0a01 	add.w	sl, sl, #1
 800715c:	e23f      	b.n	80075de <_dtoa_r+0x95e>
 800715e:	07f2      	lsls	r2, r6, #31
 8007160:	d505      	bpl.n	800716e <_dtoa_r+0x4ee>
 8007162:	e9d7 2300 	ldrd	r2, r3, [r7]
 8007166:	f7f9 fa47 	bl	80005f8 <__aeabi_dmul>
 800716a:	3501      	adds	r5, #1
 800716c:	2301      	movs	r3, #1
 800716e:	1076      	asrs	r6, r6, #1
 8007170:	3708      	adds	r7, #8
 8007172:	e76c      	b.n	800704e <_dtoa_r+0x3ce>
 8007174:	2502      	movs	r5, #2
 8007176:	e76f      	b.n	8007058 <_dtoa_r+0x3d8>
 8007178:	9b01      	ldr	r3, [sp, #4]
 800717a:	f8cd a01c 	str.w	sl, [sp, #28]
 800717e:	930c      	str	r3, [sp, #48]	; 0x30
 8007180:	e78d      	b.n	800709e <_dtoa_r+0x41e>
 8007182:	9900      	ldr	r1, [sp, #0]
 8007184:	980c      	ldr	r0, [sp, #48]	; 0x30
 8007186:	9a0c      	ldr	r2, [sp, #48]	; 0x30
 8007188:	4b4e      	ldr	r3, [pc, #312]	; (80072c4 <_dtoa_r+0x644>)
 800718a:	ed9d 7b02 	vldr	d7, [sp, #8]
 800718e:	4401      	add	r1, r0
 8007190:	9102      	str	r1, [sp, #8]
 8007192:	9908      	ldr	r1, [sp, #32]
 8007194:	eeb0 8a47 	vmov.f32	s16, s14
 8007198:	eef0 8a67 	vmov.f32	s17, s15
 800719c:	eb03 03c2 	add.w	r3, r3, r2, lsl #3
 80071a0:	e953 2302 	ldrd	r2, r3, [r3, #-8]
 80071a4:	2900      	cmp	r1, #0
 80071a6:	d045      	beq.n	8007234 <_dtoa_r+0x5b4>
 80071a8:	494c      	ldr	r1, [pc, #304]	; (80072dc <_dtoa_r+0x65c>)
 80071aa:	2000      	movs	r0, #0
 80071ac:	f7f9 fb4e 	bl	800084c <__aeabi_ddiv>
 80071b0:	ec53 2b18 	vmov	r2, r3, d8
 80071b4:	f7f9 f868 	bl	8000288 <__aeabi_dsub>
 80071b8:	9d00      	ldr	r5, [sp, #0]
 80071ba:	ec41 0b18 	vmov	d8, r0, r1
 80071be:	4639      	mov	r1, r7
 80071c0:	4630      	mov	r0, r6
 80071c2:	f7f9 fcc9 	bl	8000b58 <__aeabi_d2iz>
 80071c6:	900c      	str	r0, [sp, #48]	; 0x30
 80071c8:	f7f9 f9ac 	bl	8000524 <__aeabi_i2d>
 80071cc:	4602      	mov	r2, r0
 80071ce:	460b      	mov	r3, r1
 80071d0:	4630      	mov	r0, r6
 80071d2:	4639      	mov	r1, r7
 80071d4:	f7f9 f858 	bl	8000288 <__aeabi_dsub>
 80071d8:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 80071da:	3330      	adds	r3, #48	; 0x30
 80071dc:	f805 3b01 	strb.w	r3, [r5], #1
 80071e0:	ec53 2b18 	vmov	r2, r3, d8
 80071e4:	4606      	mov	r6, r0
 80071e6:	460f      	mov	r7, r1
 80071e8:	f7f9 fc78 	bl	8000adc <__aeabi_dcmplt>
 80071ec:	2800      	cmp	r0, #0
 80071ee:	d165      	bne.n	80072bc <_dtoa_r+0x63c>
 80071f0:	4632      	mov	r2, r6
 80071f2:	463b      	mov	r3, r7
 80071f4:	4935      	ldr	r1, [pc, #212]	; (80072cc <_dtoa_r+0x64c>)
 80071f6:	2000      	movs	r0, #0
 80071f8:	f7f9 f846 	bl	8000288 <__aeabi_dsub>
 80071fc:	ec53 2b18 	vmov	r2, r3, d8
 8007200:	f7f9 fc6c 	bl	8000adc <__aeabi_dcmplt>
 8007204:	2800      	cmp	r0, #0
 8007206:	f040 80b9 	bne.w	800737c <_dtoa_r+0x6fc>
 800720a:	9b02      	ldr	r3, [sp, #8]
 800720c:	429d      	cmp	r5, r3
 800720e:	f43f af75 	beq.w	80070fc <_dtoa_r+0x47c>
 8007212:	4b2f      	ldr	r3, [pc, #188]	; (80072d0 <_dtoa_r+0x650>)
 8007214:	ec51 0b18 	vmov	r0, r1, d8
 8007218:	2200      	movs	r2, #0
 800721a:	f7f9 f9ed 	bl	80005f8 <__aeabi_dmul>
 800721e:	4b2c      	ldr	r3, [pc, #176]	; (80072d0 <_dtoa_r+0x650>)
 8007220:	ec41 0b18 	vmov	d8, r0, r1
 8007224:	2200      	movs	r2, #0
 8007226:	4630      	mov	r0, r6
 8007228:	4639      	mov	r1, r7
 800722a:	f7f9 f9e5 	bl	80005f8 <__aeabi_dmul>
 800722e:	4606      	mov	r6, r0
 8007230:	460f      	mov	r7, r1
 8007232:	e7c4      	b.n	80071be <_dtoa_r+0x53e>
 8007234:	ec51 0b17 	vmov	r0, r1, d7
 8007238:	f7f9 f9de 	bl	80005f8 <__aeabi_dmul>
 800723c:	9b02      	ldr	r3, [sp, #8]
 800723e:	9d00      	ldr	r5, [sp, #0]
 8007240:	930c      	str	r3, [sp, #48]	; 0x30
 8007242:	ec41 0b18 	vmov	d8, r0, r1
 8007246:	4639      	mov	r1, r7
 8007248:	4630      	mov	r0, r6
 800724a:	f7f9 fc85 	bl	8000b58 <__aeabi_d2iz>
 800724e:	9011      	str	r0, [sp, #68]	; 0x44
 8007250:	f7f9 f968 	bl	8000524 <__aeabi_i2d>
 8007254:	4602      	mov	r2, r0
 8007256:	460b      	mov	r3, r1
 8007258:	4630      	mov	r0, r6
 800725a:	4639      	mov	r1, r7
 800725c:	f7f9 f814 	bl	8000288 <__aeabi_dsub>
 8007260:	9b11      	ldr	r3, [sp, #68]	; 0x44
 8007262:	3330      	adds	r3, #48	; 0x30
 8007264:	f805 3b01 	strb.w	r3, [r5], #1
 8007268:	9b02      	ldr	r3, [sp, #8]
 800726a:	429d      	cmp	r5, r3
 800726c:	4606      	mov	r6, r0
 800726e:	460f      	mov	r7, r1
 8007270:	f04f 0200 	mov.w	r2, #0
 8007274:	d134      	bne.n	80072e0 <_dtoa_r+0x660>
 8007276:	4b19      	ldr	r3, [pc, #100]	; (80072dc <_dtoa_r+0x65c>)
 8007278:	ec51 0b18 	vmov	r0, r1, d8
 800727c:	f7f9 f806 	bl	800028c <__adddf3>
 8007280:	4602      	mov	r2, r0
 8007282:	460b      	mov	r3, r1
 8007284:	4630      	mov	r0, r6
 8007286:	4639      	mov	r1, r7
 8007288:	f7f9 fc46 	bl	8000b18 <__aeabi_dcmpgt>
 800728c:	2800      	cmp	r0, #0
 800728e:	d175      	bne.n	800737c <_dtoa_r+0x6fc>
 8007290:	ec53 2b18 	vmov	r2, r3, d8
 8007294:	4911      	ldr	r1, [pc, #68]	; (80072dc <_dtoa_r+0x65c>)
 8007296:	2000      	movs	r0, #0
 8007298:	f7f8 fff6 	bl	8000288 <__aeabi_dsub>
 800729c:	4602      	mov	r2, r0
 800729e:	460b      	mov	r3, r1
 80072a0:	4630      	mov	r0, r6
 80072a2:	4639      	mov	r1, r7
 80072a4:	f7f9 fc1a 	bl	8000adc <__aeabi_dcmplt>
 80072a8:	2800      	cmp	r0, #0
 80072aa:	f43f af27 	beq.w	80070fc <_dtoa_r+0x47c>
 80072ae:	9d0c      	ldr	r5, [sp, #48]	; 0x30
 80072b0:	1e6b      	subs	r3, r5, #1
 80072b2:	930c      	str	r3, [sp, #48]	; 0x30
 80072b4:	f815 3c01 	ldrb.w	r3, [r5, #-1]
 80072b8:	2b30      	cmp	r3, #48	; 0x30
 80072ba:	d0f8      	beq.n	80072ae <_dtoa_r+0x62e>
 80072bc:	f8dd a01c 	ldr.w	sl, [sp, #28]
 80072c0:	e04a      	b.n	8007358 <_dtoa_r+0x6d8>
 80072c2:	bf00      	nop
 80072c4:	08009178 	.word	0x08009178
 80072c8:	08009150 	.word	0x08009150
 80072cc:	3ff00000 	.word	0x3ff00000
 80072d0:	40240000 	.word	0x40240000
 80072d4:	401c0000 	.word	0x401c0000
 80072d8:	40140000 	.word	0x40140000
 80072dc:	3fe00000 	.word	0x3fe00000
 80072e0:	4baf      	ldr	r3, [pc, #700]	; (80075a0 <_dtoa_r+0x920>)
 80072e2:	f7f9 f989 	bl	80005f8 <__aeabi_dmul>
 80072e6:	4606      	mov	r6, r0
 80072e8:	460f      	mov	r7, r1
 80072ea:	e7ac      	b.n	8007246 <_dtoa_r+0x5c6>
 80072ec:	e9dd 6702 	ldrd	r6, r7, [sp, #8]
 80072f0:	9d00      	ldr	r5, [sp, #0]
 80072f2:	4642      	mov	r2, r8
 80072f4:	464b      	mov	r3, r9
 80072f6:	4630      	mov	r0, r6
 80072f8:	4639      	mov	r1, r7
 80072fa:	f7f9 faa7 	bl	800084c <__aeabi_ddiv>
 80072fe:	f7f9 fc2b 	bl	8000b58 <__aeabi_d2iz>
 8007302:	9002      	str	r0, [sp, #8]
 8007304:	f7f9 f90e 	bl	8000524 <__aeabi_i2d>
 8007308:	4642      	mov	r2, r8
 800730a:	464b      	mov	r3, r9
 800730c:	f7f9 f974 	bl	80005f8 <__aeabi_dmul>
 8007310:	4602      	mov	r2, r0
 8007312:	460b      	mov	r3, r1
 8007314:	4630      	mov	r0, r6
 8007316:	4639      	mov	r1, r7
 8007318:	f7f8 ffb6 	bl	8000288 <__aeabi_dsub>
 800731c:	9e02      	ldr	r6, [sp, #8]
 800731e:	9f01      	ldr	r7, [sp, #4]
 8007320:	3630      	adds	r6, #48	; 0x30
 8007322:	f805 6b01 	strb.w	r6, [r5], #1
 8007326:	9e00      	ldr	r6, [sp, #0]
 8007328:	1bae      	subs	r6, r5, r6
 800732a:	42b7      	cmp	r7, r6
 800732c:	4602      	mov	r2, r0
 800732e:	460b      	mov	r3, r1
 8007330:	d137      	bne.n	80073a2 <_dtoa_r+0x722>
 8007332:	f7f8 ffab 	bl	800028c <__adddf3>
 8007336:	4642      	mov	r2, r8
 8007338:	464b      	mov	r3, r9
 800733a:	4606      	mov	r6, r0
 800733c:	460f      	mov	r7, r1
 800733e:	f7f9 fbeb 	bl	8000b18 <__aeabi_dcmpgt>
 8007342:	b9c8      	cbnz	r0, 8007378 <_dtoa_r+0x6f8>
 8007344:	4642      	mov	r2, r8
 8007346:	464b      	mov	r3, r9
 8007348:	4630      	mov	r0, r6
 800734a:	4639      	mov	r1, r7
 800734c:	f7f9 fbbc 	bl	8000ac8 <__aeabi_dcmpeq>
 8007350:	b110      	cbz	r0, 8007358 <_dtoa_r+0x6d8>
 8007352:	9b02      	ldr	r3, [sp, #8]
 8007354:	07d9      	lsls	r1, r3, #31
 8007356:	d40f      	bmi.n	8007378 <_dtoa_r+0x6f8>
 8007358:	4620      	mov	r0, r4
 800735a:	4659      	mov	r1, fp
 800735c:	f000 fad6 	bl	800790c <_Bfree>
 8007360:	2300      	movs	r3, #0
 8007362:	702b      	strb	r3, [r5, #0]
 8007364:	9b0f      	ldr	r3, [sp, #60]	; 0x3c
 8007366:	f10a 0001 	add.w	r0, sl, #1
 800736a:	6018      	str	r0, [r3, #0]
 800736c:	9b21      	ldr	r3, [sp, #132]	; 0x84
 800736e:	2b00      	cmp	r3, #0
 8007370:	f43f acd8 	beq.w	8006d24 <_dtoa_r+0xa4>
 8007374:	601d      	str	r5, [r3, #0]
 8007376:	e4d5      	b.n	8006d24 <_dtoa_r+0xa4>
 8007378:	f8cd a01c 	str.w	sl, [sp, #28]
 800737c:	462b      	mov	r3, r5
 800737e:	461d      	mov	r5, r3
 8007380:	f813 2d01 	ldrb.w	r2, [r3, #-1]!
 8007384:	2a39      	cmp	r2, #57	; 0x39
 8007386:	d108      	bne.n	800739a <_dtoa_r+0x71a>
 8007388:	9a00      	ldr	r2, [sp, #0]
 800738a:	429a      	cmp	r2, r3
 800738c:	d1f7      	bne.n	800737e <_dtoa_r+0x6fe>
 800738e:	9a07      	ldr	r2, [sp, #28]
 8007390:	9900      	ldr	r1, [sp, #0]
 8007392:	3201      	adds	r2, #1
 8007394:	9207      	str	r2, [sp, #28]
 8007396:	2230      	movs	r2, #48	; 0x30
 8007398:	700a      	strb	r2, [r1, #0]
 800739a:	781a      	ldrb	r2, [r3, #0]
 800739c:	3201      	adds	r2, #1
 800739e:	701a      	strb	r2, [r3, #0]
 80073a0:	e78c      	b.n	80072bc <_dtoa_r+0x63c>
 80073a2:	4b7f      	ldr	r3, [pc, #508]	; (80075a0 <_dtoa_r+0x920>)
 80073a4:	2200      	movs	r2, #0
 80073a6:	f7f9 f927 	bl	80005f8 <__aeabi_dmul>
 80073aa:	2200      	movs	r2, #0
 80073ac:	2300      	movs	r3, #0
 80073ae:	4606      	mov	r6, r0
 80073b0:	460f      	mov	r7, r1
 80073b2:	f7f9 fb89 	bl	8000ac8 <__aeabi_dcmpeq>
 80073b6:	2800      	cmp	r0, #0
 80073b8:	d09b      	beq.n	80072f2 <_dtoa_r+0x672>
 80073ba:	e7cd      	b.n	8007358 <_dtoa_r+0x6d8>
 80073bc:	9a08      	ldr	r2, [sp, #32]
 80073be:	2a00      	cmp	r2, #0
 80073c0:	f000 80c4 	beq.w	800754c <_dtoa_r+0x8cc>
 80073c4:	9a05      	ldr	r2, [sp, #20]
 80073c6:	2a01      	cmp	r2, #1
 80073c8:	f300 80a8 	bgt.w	800751c <_dtoa_r+0x89c>
 80073cc:	9a10      	ldr	r2, [sp, #64]	; 0x40
 80073ce:	2a00      	cmp	r2, #0
 80073d0:	f000 80a0 	beq.w	8007514 <_dtoa_r+0x894>
 80073d4:	f203 4333 	addw	r3, r3, #1075	; 0x433
 80073d8:	9e06      	ldr	r6, [sp, #24]
 80073da:	4645      	mov	r5, r8
 80073dc:	9a04      	ldr	r2, [sp, #16]
 80073de:	2101      	movs	r1, #1
 80073e0:	441a      	add	r2, r3
 80073e2:	4620      	mov	r0, r4
 80073e4:	4498      	add	r8, r3
 80073e6:	9204      	str	r2, [sp, #16]
 80073e8:	f000 fb4c 	bl	8007a84 <__i2b>
 80073ec:	4607      	mov	r7, r0
 80073ee:	2d00      	cmp	r5, #0
 80073f0:	dd0b      	ble.n	800740a <_dtoa_r+0x78a>
 80073f2:	9b04      	ldr	r3, [sp, #16]
 80073f4:	2b00      	cmp	r3, #0
 80073f6:	dd08      	ble.n	800740a <_dtoa_r+0x78a>
 80073f8:	42ab      	cmp	r3, r5
 80073fa:	9a04      	ldr	r2, [sp, #16]
 80073fc:	bfa8      	it	ge
 80073fe:	462b      	movge	r3, r5
 8007400:	eba8 0803 	sub.w	r8, r8, r3
 8007404:	1aed      	subs	r5, r5, r3
 8007406:	1ad3      	subs	r3, r2, r3
 8007408:	9304      	str	r3, [sp, #16]
 800740a:	9b06      	ldr	r3, [sp, #24]
 800740c:	b1fb      	cbz	r3, 800744e <_dtoa_r+0x7ce>
 800740e:	9b08      	ldr	r3, [sp, #32]
 8007410:	2b00      	cmp	r3, #0
 8007412:	f000 809f 	beq.w	8007554 <_dtoa_r+0x8d4>
 8007416:	2e00      	cmp	r6, #0
 8007418:	dd11      	ble.n	800743e <_dtoa_r+0x7be>
 800741a:	4639      	mov	r1, r7
 800741c:	4632      	mov	r2, r6
 800741e:	4620      	mov	r0, r4
 8007420:	f000 fbec 	bl	8007bfc <__pow5mult>
 8007424:	465a      	mov	r2, fp
 8007426:	4601      	mov	r1, r0
 8007428:	4607      	mov	r7, r0
 800742a:	4620      	mov	r0, r4
 800742c:	f000 fb40 	bl	8007ab0 <__multiply>
 8007430:	4659      	mov	r1, fp
 8007432:	9007      	str	r0, [sp, #28]
 8007434:	4620      	mov	r0, r4
 8007436:	f000 fa69 	bl	800790c <_Bfree>
 800743a:	9b07      	ldr	r3, [sp, #28]
 800743c:	469b      	mov	fp, r3
 800743e:	9b06      	ldr	r3, [sp, #24]
 8007440:	1b9a      	subs	r2, r3, r6
 8007442:	d004      	beq.n	800744e <_dtoa_r+0x7ce>
 8007444:	4659      	mov	r1, fp
 8007446:	4620      	mov	r0, r4
 8007448:	f000 fbd8 	bl	8007bfc <__pow5mult>
 800744c:	4683      	mov	fp, r0
 800744e:	2101      	movs	r1, #1
 8007450:	4620      	mov	r0, r4
 8007452:	f000 fb17 	bl	8007a84 <__i2b>
 8007456:	9b0d      	ldr	r3, [sp, #52]	; 0x34
 8007458:	2b00      	cmp	r3, #0
 800745a:	4606      	mov	r6, r0
 800745c:	dd7c      	ble.n	8007558 <_dtoa_r+0x8d8>
 800745e:	461a      	mov	r2, r3
 8007460:	4601      	mov	r1, r0
 8007462:	4620      	mov	r0, r4
 8007464:	f000 fbca 	bl	8007bfc <__pow5mult>
 8007468:	9b05      	ldr	r3, [sp, #20]
 800746a:	2b01      	cmp	r3, #1
 800746c:	4606      	mov	r6, r0
 800746e:	dd76      	ble.n	800755e <_dtoa_r+0x8de>
 8007470:	2300      	movs	r3, #0
 8007472:	9306      	str	r3, [sp, #24]
 8007474:	6933      	ldr	r3, [r6, #16]
 8007476:	eb06 0383 	add.w	r3, r6, r3, lsl #2
 800747a:	6918      	ldr	r0, [r3, #16]
 800747c:	f000 fab2 	bl	80079e4 <__hi0bits>
 8007480:	f1c0 0020 	rsb	r0, r0, #32
 8007484:	9b04      	ldr	r3, [sp, #16]
 8007486:	4418      	add	r0, r3
 8007488:	f010 001f 	ands.w	r0, r0, #31
 800748c:	f000 8086 	beq.w	800759c <_dtoa_r+0x91c>
 8007490:	f1c0 0320 	rsb	r3, r0, #32
 8007494:	2b04      	cmp	r3, #4
 8007496:	dd7f      	ble.n	8007598 <_dtoa_r+0x918>
 8007498:	f1c0 001c 	rsb	r0, r0, #28
 800749c:	9b04      	ldr	r3, [sp, #16]
 800749e:	4403      	add	r3, r0
 80074a0:	4480      	add	r8, r0
 80074a2:	4405      	add	r5, r0
 80074a4:	9304      	str	r3, [sp, #16]
 80074a6:	f1b8 0f00 	cmp.w	r8, #0
 80074aa:	dd05      	ble.n	80074b8 <_dtoa_r+0x838>
 80074ac:	4659      	mov	r1, fp
 80074ae:	4642      	mov	r2, r8
 80074b0:	4620      	mov	r0, r4
 80074b2:	f000 fbfd 	bl	8007cb0 <__lshift>
 80074b6:	4683      	mov	fp, r0
 80074b8:	9b04      	ldr	r3, [sp, #16]
 80074ba:	2b00      	cmp	r3, #0
 80074bc:	dd05      	ble.n	80074ca <_dtoa_r+0x84a>
 80074be:	4631      	mov	r1, r6
 80074c0:	461a      	mov	r2, r3
 80074c2:	4620      	mov	r0, r4
 80074c4:	f000 fbf4 	bl	8007cb0 <__lshift>
 80074c8:	4606      	mov	r6, r0
 80074ca:	9b0e      	ldr	r3, [sp, #56]	; 0x38
 80074cc:	2b00      	cmp	r3, #0
 80074ce:	d069      	beq.n	80075a4 <_dtoa_r+0x924>
 80074d0:	4631      	mov	r1, r6
 80074d2:	4658      	mov	r0, fp
 80074d4:	f000 fc58 	bl	8007d88 <__mcmp>
 80074d8:	2800      	cmp	r0, #0
 80074da:	da63      	bge.n	80075a4 <_dtoa_r+0x924>
 80074dc:	2300      	movs	r3, #0
 80074de:	4659      	mov	r1, fp
 80074e0:	220a      	movs	r2, #10
 80074e2:	4620      	mov	r0, r4
 80074e4:	f000 fa34 	bl	8007950 <__multadd>
 80074e8:	9b08      	ldr	r3, [sp, #32]
 80074ea:	f10a 3aff 	add.w	sl, sl, #4294967295
 80074ee:	4683      	mov	fp, r0
 80074f0:	2b00      	cmp	r3, #0
 80074f2:	f000 818f 	beq.w	8007814 <_dtoa_r+0xb94>
 80074f6:	4639      	mov	r1, r7
 80074f8:	2300      	movs	r3, #0
 80074fa:	220a      	movs	r2, #10
 80074fc:	4620      	mov	r0, r4
 80074fe:	f000 fa27 	bl	8007950 <__multadd>
 8007502:	f1b9 0f00 	cmp.w	r9, #0
 8007506:	4607      	mov	r7, r0
 8007508:	f300 808e 	bgt.w	8007628 <_dtoa_r+0x9a8>
 800750c:	9b05      	ldr	r3, [sp, #20]
 800750e:	2b02      	cmp	r3, #2
 8007510:	dc50      	bgt.n	80075b4 <_dtoa_r+0x934>
 8007512:	e089      	b.n	8007628 <_dtoa_r+0x9a8>
 8007514:	9b12      	ldr	r3, [sp, #72]	; 0x48
 8007516:	f1c3 0336 	rsb	r3, r3, #54	; 0x36
 800751a:	e75d      	b.n	80073d8 <_dtoa_r+0x758>
 800751c:	9b01      	ldr	r3, [sp, #4]
 800751e:	1e5e      	subs	r6, r3, #1
 8007520:	9b06      	ldr	r3, [sp, #24]
 8007522:	42b3      	cmp	r3, r6
 8007524:	bfbf      	itttt	lt
 8007526:	9b06      	ldrlt	r3, [sp, #24]
 8007528:	9606      	strlt	r6, [sp, #24]
 800752a:	1af2      	sublt	r2, r6, r3
 800752c:	9b0d      	ldrlt	r3, [sp, #52]	; 0x34
 800752e:	bfb6      	itet	lt
 8007530:	189b      	addlt	r3, r3, r2
 8007532:	1b9e      	subge	r6, r3, r6
 8007534:	930d      	strlt	r3, [sp, #52]	; 0x34
 8007536:	9b01      	ldr	r3, [sp, #4]
 8007538:	bfb8      	it	lt
 800753a:	2600      	movlt	r6, #0
 800753c:	2b00      	cmp	r3, #0
 800753e:	bfb5      	itete	lt
 8007540:	eba8 0503 	sublt.w	r5, r8, r3
 8007544:	9b01      	ldrge	r3, [sp, #4]
 8007546:	2300      	movlt	r3, #0
 8007548:	4645      	movge	r5, r8
 800754a:	e747      	b.n	80073dc <_dtoa_r+0x75c>
 800754c:	9e06      	ldr	r6, [sp, #24]
 800754e:	9f08      	ldr	r7, [sp, #32]
 8007550:	4645      	mov	r5, r8
 8007552:	e74c      	b.n	80073ee <_dtoa_r+0x76e>
 8007554:	9a06      	ldr	r2, [sp, #24]
 8007556:	e775      	b.n	8007444 <_dtoa_r+0x7c4>
 8007558:	9b05      	ldr	r3, [sp, #20]
 800755a:	2b01      	cmp	r3, #1
 800755c:	dc18      	bgt.n	8007590 <_dtoa_r+0x910>
 800755e:	9b02      	ldr	r3, [sp, #8]
 8007560:	b9b3      	cbnz	r3, 8007590 <_dtoa_r+0x910>
 8007562:	9b03      	ldr	r3, [sp, #12]
 8007564:	f3c3 0313 	ubfx	r3, r3, #0, #20
 8007568:	b9a3      	cbnz	r3, 8007594 <_dtoa_r+0x914>
 800756a:	9b03      	ldr	r3, [sp, #12]
 800756c:	f023 4300 	bic.w	r3, r3, #2147483648	; 0x80000000
 8007570:	0d1b      	lsrs	r3, r3, #20
 8007572:	051b      	lsls	r3, r3, #20
 8007574:	b12b      	cbz	r3, 8007582 <_dtoa_r+0x902>
 8007576:	9b04      	ldr	r3, [sp, #16]
 8007578:	3301      	adds	r3, #1
 800757a:	9304      	str	r3, [sp, #16]
 800757c:	f108 0801 	add.w	r8, r8, #1
 8007580:	2301      	movs	r3, #1
 8007582:	9306      	str	r3, [sp, #24]
 8007584:	9b0d      	ldr	r3, [sp, #52]	; 0x34
 8007586:	2b00      	cmp	r3, #0
 8007588:	f47f af74 	bne.w	8007474 <_dtoa_r+0x7f4>
 800758c:	2001      	movs	r0, #1
 800758e:	e779      	b.n	8007484 <_dtoa_r+0x804>
 8007590:	2300      	movs	r3, #0
 8007592:	e7f6      	b.n	8007582 <_dtoa_r+0x902>
 8007594:	9b02      	ldr	r3, [sp, #8]
 8007596:	e7f4      	b.n	8007582 <_dtoa_r+0x902>
 8007598:	d085      	beq.n	80074a6 <_dtoa_r+0x826>
 800759a:	4618      	mov	r0, r3
 800759c:	301c      	adds	r0, #28
 800759e:	e77d      	b.n	800749c <_dtoa_r+0x81c>
 80075a0:	40240000 	.word	0x40240000
 80075a4:	9b01      	ldr	r3, [sp, #4]
 80075a6:	2b00      	cmp	r3, #0
 80075a8:	dc38      	bgt.n	800761c <_dtoa_r+0x99c>
 80075aa:	9b05      	ldr	r3, [sp, #20]
 80075ac:	2b02      	cmp	r3, #2
 80075ae:	dd35      	ble.n	800761c <_dtoa_r+0x99c>
 80075b0:	f8dd 9004 	ldr.w	r9, [sp, #4]
 80075b4:	f1b9 0f00 	cmp.w	r9, #0
 80075b8:	d10d      	bne.n	80075d6 <_dtoa_r+0x956>
 80075ba:	4631      	mov	r1, r6
 80075bc:	464b      	mov	r3, r9
 80075be:	2205      	movs	r2, #5
 80075c0:	4620      	mov	r0, r4
 80075c2:	f000 f9c5 	bl	8007950 <__multadd>
 80075c6:	4601      	mov	r1, r0
 80075c8:	4606      	mov	r6, r0
 80075ca:	4658      	mov	r0, fp
 80075cc:	f000 fbdc 	bl	8007d88 <__mcmp>
 80075d0:	2800      	cmp	r0, #0
 80075d2:	f73f adbd 	bgt.w	8007150 <_dtoa_r+0x4d0>
 80075d6:	9b09      	ldr	r3, [sp, #36]	; 0x24
 80075d8:	9d00      	ldr	r5, [sp, #0]
 80075da:	ea6f 0a03 	mvn.w	sl, r3
 80075de:	f04f 0800 	mov.w	r8, #0
 80075e2:	4631      	mov	r1, r6
 80075e4:	4620      	mov	r0, r4
 80075e6:	f000 f991 	bl	800790c <_Bfree>
 80075ea:	2f00      	cmp	r7, #0
 80075ec:	f43f aeb4 	beq.w	8007358 <_dtoa_r+0x6d8>
 80075f0:	f1b8 0f00 	cmp.w	r8, #0
 80075f4:	d005      	beq.n	8007602 <_dtoa_r+0x982>
 80075f6:	45b8      	cmp	r8, r7
 80075f8:	d003      	beq.n	8007602 <_dtoa_r+0x982>
 80075fa:	4641      	mov	r1, r8
 80075fc:	4620      	mov	r0, r4
 80075fe:	f000 f985 	bl	800790c <_Bfree>
 8007602:	4639      	mov	r1, r7
 8007604:	4620      	mov	r0, r4
 8007606:	f000 f981 	bl	800790c <_Bfree>
 800760a:	e6a5      	b.n	8007358 <_dtoa_r+0x6d8>
 800760c:	2600      	movs	r6, #0
 800760e:	4637      	mov	r7, r6
 8007610:	e7e1      	b.n	80075d6 <_dtoa_r+0x956>
 8007612:	9e0c      	ldr	r6, [sp, #48]	; 0x30
 8007614:	f8dd a01c 	ldr.w	sl, [sp, #28]
 8007618:	4637      	mov	r7, r6
 800761a:	e599      	b.n	8007150 <_dtoa_r+0x4d0>
 800761c:	9b08      	ldr	r3, [sp, #32]
 800761e:	f8dd 9004 	ldr.w	r9, [sp, #4]
 8007622:	2b00      	cmp	r3, #0
 8007624:	f000 80fd 	beq.w	8007822 <_dtoa_r+0xba2>
 8007628:	2d00      	cmp	r5, #0
 800762a:	dd05      	ble.n	8007638 <_dtoa_r+0x9b8>
 800762c:	4639      	mov	r1, r7
 800762e:	462a      	mov	r2, r5
 8007630:	4620      	mov	r0, r4
 8007632:	f000 fb3d 	bl	8007cb0 <__lshift>
 8007636:	4607      	mov	r7, r0
 8007638:	9b06      	ldr	r3, [sp, #24]
 800763a:	2b00      	cmp	r3, #0
 800763c:	d05c      	beq.n	80076f8 <_dtoa_r+0xa78>
 800763e:	6879      	ldr	r1, [r7, #4]
 8007640:	4620      	mov	r0, r4
 8007642:	f000 f923 	bl	800788c <_Balloc>
 8007646:	4605      	mov	r5, r0
 8007648:	b928      	cbnz	r0, 8007656 <_dtoa_r+0x9d6>
 800764a:	4b80      	ldr	r3, [pc, #512]	; (800784c <_dtoa_r+0xbcc>)
 800764c:	4602      	mov	r2, r0
 800764e:	f240 21ea 	movw	r1, #746	; 0x2ea
 8007652:	f7ff bb2e 	b.w	8006cb2 <_dtoa_r+0x32>
 8007656:	693a      	ldr	r2, [r7, #16]
 8007658:	3202      	adds	r2, #2
 800765a:	0092      	lsls	r2, r2, #2
 800765c:	f107 010c 	add.w	r1, r7, #12
 8007660:	300c      	adds	r0, #12
 8007662:	f000 f905 	bl	8007870 <memcpy>
 8007666:	2201      	movs	r2, #1
 8007668:	4629      	mov	r1, r5
 800766a:	4620      	mov	r0, r4
 800766c:	f000 fb20 	bl	8007cb0 <__lshift>
 8007670:	9b00      	ldr	r3, [sp, #0]
 8007672:	3301      	adds	r3, #1
 8007674:	9301      	str	r3, [sp, #4]
 8007676:	9b00      	ldr	r3, [sp, #0]
 8007678:	444b      	add	r3, r9
 800767a:	9307      	str	r3, [sp, #28]
 800767c:	9b02      	ldr	r3, [sp, #8]
 800767e:	f003 0301 	and.w	r3, r3, #1
 8007682:	46b8      	mov	r8, r7
 8007684:	9306      	str	r3, [sp, #24]
 8007686:	4607      	mov	r7, r0
 8007688:	9b01      	ldr	r3, [sp, #4]
 800768a:	4631      	mov	r1, r6
 800768c:	3b01      	subs	r3, #1
 800768e:	4658      	mov	r0, fp
 8007690:	9302      	str	r3, [sp, #8]
 8007692:	f7ff fa67 	bl	8006b64 <quorem>
 8007696:	4603      	mov	r3, r0
 8007698:	3330      	adds	r3, #48	; 0x30
 800769a:	9004      	str	r0, [sp, #16]
 800769c:	4641      	mov	r1, r8
 800769e:	4658      	mov	r0, fp
 80076a0:	9308      	str	r3, [sp, #32]
 80076a2:	f000 fb71 	bl	8007d88 <__mcmp>
 80076a6:	463a      	mov	r2, r7
 80076a8:	4681      	mov	r9, r0
 80076aa:	4631      	mov	r1, r6
 80076ac:	4620      	mov	r0, r4
 80076ae:	f000 fb87 	bl	8007dc0 <__mdiff>
 80076b2:	68c2      	ldr	r2, [r0, #12]
 80076b4:	9b08      	ldr	r3, [sp, #32]
 80076b6:	4605      	mov	r5, r0
 80076b8:	bb02      	cbnz	r2, 80076fc <_dtoa_r+0xa7c>
 80076ba:	4601      	mov	r1, r0
 80076bc:	4658      	mov	r0, fp
 80076be:	f000 fb63 	bl	8007d88 <__mcmp>
 80076c2:	9b08      	ldr	r3, [sp, #32]
 80076c4:	4602      	mov	r2, r0
 80076c6:	4629      	mov	r1, r5
 80076c8:	4620      	mov	r0, r4
 80076ca:	e9cd 3208 	strd	r3, r2, [sp, #32]
 80076ce:	f000 f91d 	bl	800790c <_Bfree>
 80076d2:	9b05      	ldr	r3, [sp, #20]
 80076d4:	9a09      	ldr	r2, [sp, #36]	; 0x24
 80076d6:	9d01      	ldr	r5, [sp, #4]
 80076d8:	ea43 0102 	orr.w	r1, r3, r2
 80076dc:	9b06      	ldr	r3, [sp, #24]
 80076de:	430b      	orrs	r3, r1
 80076e0:	9b08      	ldr	r3, [sp, #32]
 80076e2:	d10d      	bne.n	8007700 <_dtoa_r+0xa80>
 80076e4:	2b39      	cmp	r3, #57	; 0x39
 80076e6:	d029      	beq.n	800773c <_dtoa_r+0xabc>
 80076e8:	f1b9 0f00 	cmp.w	r9, #0
 80076ec:	dd01      	ble.n	80076f2 <_dtoa_r+0xa72>
 80076ee:	9b04      	ldr	r3, [sp, #16]
 80076f0:	3331      	adds	r3, #49	; 0x31
 80076f2:	9a02      	ldr	r2, [sp, #8]
 80076f4:	7013      	strb	r3, [r2, #0]
 80076f6:	e774      	b.n	80075e2 <_dtoa_r+0x962>
 80076f8:	4638      	mov	r0, r7
 80076fa:	e7b9      	b.n	8007670 <_dtoa_r+0x9f0>
 80076fc:	2201      	movs	r2, #1
 80076fe:	e7e2      	b.n	80076c6 <_dtoa_r+0xa46>
 8007700:	f1b9 0f00 	cmp.w	r9, #0
 8007704:	db06      	blt.n	8007714 <_dtoa_r+0xa94>
 8007706:	9905      	ldr	r1, [sp, #20]
 8007708:	ea41 0909 	orr.w	r9, r1, r9
 800770c:	9906      	ldr	r1, [sp, #24]
 800770e:	ea59 0101 	orrs.w	r1, r9, r1
 8007712:	d120      	bne.n	8007756 <_dtoa_r+0xad6>
 8007714:	2a00      	cmp	r2, #0
 8007716:	ddec      	ble.n	80076f2 <_dtoa_r+0xa72>
 8007718:	4659      	mov	r1, fp
 800771a:	2201      	movs	r2, #1
 800771c:	4620      	mov	r0, r4
 800771e:	9301      	str	r3, [sp, #4]
 8007720:	f000 fac6 	bl	8007cb0 <__lshift>
 8007724:	4631      	mov	r1, r6
 8007726:	4683      	mov	fp, r0
 8007728:	f000 fb2e 	bl	8007d88 <__mcmp>
 800772c:	2800      	cmp	r0, #0
 800772e:	9b01      	ldr	r3, [sp, #4]
 8007730:	dc02      	bgt.n	8007738 <_dtoa_r+0xab8>
 8007732:	d1de      	bne.n	80076f2 <_dtoa_r+0xa72>
 8007734:	07da      	lsls	r2, r3, #31
 8007736:	d5dc      	bpl.n	80076f2 <_dtoa_r+0xa72>
 8007738:	2b39      	cmp	r3, #57	; 0x39
 800773a:	d1d8      	bne.n	80076ee <_dtoa_r+0xa6e>
 800773c:	9a02      	ldr	r2, [sp, #8]
 800773e:	2339      	movs	r3, #57	; 0x39
 8007740:	7013      	strb	r3, [r2, #0]
 8007742:	462b      	mov	r3, r5
 8007744:	461d      	mov	r5, r3
 8007746:	3b01      	subs	r3, #1
 8007748:	f815 2c01 	ldrb.w	r2, [r5, #-1]
 800774c:	2a39      	cmp	r2, #57	; 0x39
 800774e:	d050      	beq.n	80077f2 <_dtoa_r+0xb72>
 8007750:	3201      	adds	r2, #1
 8007752:	701a      	strb	r2, [r3, #0]
 8007754:	e745      	b.n	80075e2 <_dtoa_r+0x962>
 8007756:	2a00      	cmp	r2, #0
 8007758:	dd03      	ble.n	8007762 <_dtoa_r+0xae2>
 800775a:	2b39      	cmp	r3, #57	; 0x39
 800775c:	d0ee      	beq.n	800773c <_dtoa_r+0xabc>
 800775e:	3301      	adds	r3, #1
 8007760:	e7c7      	b.n	80076f2 <_dtoa_r+0xa72>
 8007762:	9a01      	ldr	r2, [sp, #4]
 8007764:	9907      	ldr	r1, [sp, #28]
 8007766:	f802 3c01 	strb.w	r3, [r2, #-1]
 800776a:	428a      	cmp	r2, r1
 800776c:	d02a      	beq.n	80077c4 <_dtoa_r+0xb44>
 800776e:	4659      	mov	r1, fp
 8007770:	2300      	movs	r3, #0
 8007772:	220a      	movs	r2, #10
 8007774:	4620      	mov	r0, r4
 8007776:	f000 f8eb 	bl	8007950 <__multadd>
 800777a:	45b8      	cmp	r8, r7
 800777c:	4683      	mov	fp, r0
 800777e:	f04f 0300 	mov.w	r3, #0
 8007782:	f04f 020a 	mov.w	r2, #10
 8007786:	4641      	mov	r1, r8
 8007788:	4620      	mov	r0, r4
 800778a:	d107      	bne.n	800779c <_dtoa_r+0xb1c>
 800778c:	f000 f8e0 	bl	8007950 <__multadd>
 8007790:	4680      	mov	r8, r0
 8007792:	4607      	mov	r7, r0
 8007794:	9b01      	ldr	r3, [sp, #4]
 8007796:	3301      	adds	r3, #1
 8007798:	9301      	str	r3, [sp, #4]
 800779a:	e775      	b.n	8007688 <_dtoa_r+0xa08>
 800779c:	f000 f8d8 	bl	8007950 <__multadd>
 80077a0:	4639      	mov	r1, r7
 80077a2:	4680      	mov	r8, r0
 80077a4:	2300      	movs	r3, #0
 80077a6:	220a      	movs	r2, #10
 80077a8:	4620      	mov	r0, r4
 80077aa:	f000 f8d1 	bl	8007950 <__multadd>
 80077ae:	4607      	mov	r7, r0
 80077b0:	e7f0      	b.n	8007794 <_dtoa_r+0xb14>
 80077b2:	f1b9 0f00 	cmp.w	r9, #0
 80077b6:	9a00      	ldr	r2, [sp, #0]
 80077b8:	bfcc      	ite	gt
 80077ba:	464d      	movgt	r5, r9
 80077bc:	2501      	movle	r5, #1
 80077be:	4415      	add	r5, r2
 80077c0:	f04f 0800 	mov.w	r8, #0
 80077c4:	4659      	mov	r1, fp
 80077c6:	2201      	movs	r2, #1
 80077c8:	4620      	mov	r0, r4
 80077ca:	9301      	str	r3, [sp, #4]
 80077cc:	f000 fa70 	bl	8007cb0 <__lshift>
 80077d0:	4631      	mov	r1, r6
 80077d2:	4683      	mov	fp, r0
 80077d4:	f000 fad8 	bl	8007d88 <__mcmp>
 80077d8:	2800      	cmp	r0, #0
 80077da:	dcb2      	bgt.n	8007742 <_dtoa_r+0xac2>
 80077dc:	d102      	bne.n	80077e4 <_dtoa_r+0xb64>
 80077de:	9b01      	ldr	r3, [sp, #4]
 80077e0:	07db      	lsls	r3, r3, #31
 80077e2:	d4ae      	bmi.n	8007742 <_dtoa_r+0xac2>
 80077e4:	462b      	mov	r3, r5
 80077e6:	461d      	mov	r5, r3
 80077e8:	f813 2d01 	ldrb.w	r2, [r3, #-1]!
 80077ec:	2a30      	cmp	r2, #48	; 0x30
 80077ee:	d0fa      	beq.n	80077e6 <_dtoa_r+0xb66>
 80077f0:	e6f7      	b.n	80075e2 <_dtoa_r+0x962>
 80077f2:	9a00      	ldr	r2, [sp, #0]
 80077f4:	429a      	cmp	r2, r3
 80077f6:	d1a5      	bne.n	8007744 <_dtoa_r+0xac4>
 80077f8:	f10a 0a01 	add.w	sl, sl, #1
 80077fc:	2331      	movs	r3, #49	; 0x31
 80077fe:	e779      	b.n	80076f4 <_dtoa_r+0xa74>
 8007800:	4b13      	ldr	r3, [pc, #76]	; (8007850 <_dtoa_r+0xbd0>)
 8007802:	f7ff baaf 	b.w	8006d64 <_dtoa_r+0xe4>
 8007806:	9b21      	ldr	r3, [sp, #132]	; 0x84
 8007808:	2b00      	cmp	r3, #0
 800780a:	f47f aa86 	bne.w	8006d1a <_dtoa_r+0x9a>
 800780e:	4b11      	ldr	r3, [pc, #68]	; (8007854 <_dtoa_r+0xbd4>)
 8007810:	f7ff baa8 	b.w	8006d64 <_dtoa_r+0xe4>
 8007814:	f1b9 0f00 	cmp.w	r9, #0
 8007818:	dc03      	bgt.n	8007822 <_dtoa_r+0xba2>
 800781a:	9b05      	ldr	r3, [sp, #20]
 800781c:	2b02      	cmp	r3, #2
 800781e:	f73f aec9 	bgt.w	80075b4 <_dtoa_r+0x934>
 8007822:	9d00      	ldr	r5, [sp, #0]
 8007824:	4631      	mov	r1, r6
 8007826:	4658      	mov	r0, fp
 8007828:	f7ff f99c 	bl	8006b64 <quorem>
 800782c:	f100 0330 	add.w	r3, r0, #48	; 0x30
 8007830:	f805 3b01 	strb.w	r3, [r5], #1
 8007834:	9a00      	ldr	r2, [sp, #0]
 8007836:	1aaa      	subs	r2, r5, r2
 8007838:	4591      	cmp	r9, r2
 800783a:	ddba      	ble.n	80077b2 <_dtoa_r+0xb32>
 800783c:	4659      	mov	r1, fp
 800783e:	2300      	movs	r3, #0
 8007840:	220a      	movs	r2, #10
 8007842:	4620      	mov	r0, r4
 8007844:	f000 f884 	bl	8007950 <__multadd>
 8007848:	4683      	mov	fp, r0
 800784a:	e7eb      	b.n	8007824 <_dtoa_r+0xba4>
 800784c:	080090df 	.word	0x080090df
 8007850:	08009038 	.word	0x08009038
 8007854:	0800905c 	.word	0x0800905c

08007858 <_localeconv_r>:
 8007858:	4800      	ldr	r0, [pc, #0]	; (800785c <_localeconv_r+0x4>)
 800785a:	4770      	bx	lr
 800785c:	20000160 	.word	0x20000160

08007860 <malloc>:
 8007860:	4b02      	ldr	r3, [pc, #8]	; (800786c <malloc+0xc>)
 8007862:	4601      	mov	r1, r0
 8007864:	6818      	ldr	r0, [r3, #0]
 8007866:	f000 bbef 	b.w	8008048 <_malloc_r>
 800786a:	bf00      	nop
 800786c:	2000000c 	.word	0x2000000c

08007870 <memcpy>:
 8007870:	440a      	add	r2, r1
 8007872:	4291      	cmp	r1, r2
 8007874:	f100 33ff 	add.w	r3, r0, #4294967295
 8007878:	d100      	bne.n	800787c <memcpy+0xc>
 800787a:	4770      	bx	lr
 800787c:	b510      	push	{r4, lr}
 800787e:	f811 4b01 	ldrb.w	r4, [r1], #1
 8007882:	f803 4f01 	strb.w	r4, [r3, #1]!
 8007886:	4291      	cmp	r1, r2
 8007888:	d1f9      	bne.n	800787e <memcpy+0xe>
 800788a:	bd10      	pop	{r4, pc}

0800788c <_Balloc>:
 800788c:	b570      	push	{r4, r5, r6, lr}
 800788e:	6a46      	ldr	r6, [r0, #36]	; 0x24
 8007890:	4604      	mov	r4, r0
 8007892:	460d      	mov	r5, r1
 8007894:	b976      	cbnz	r6, 80078b4 <_Balloc+0x28>
 8007896:	2010      	movs	r0, #16
 8007898:	f7ff ffe2 	bl	8007860 <malloc>
 800789c:	4602      	mov	r2, r0
 800789e:	6260      	str	r0, [r4, #36]	; 0x24
 80078a0:	b920      	cbnz	r0, 80078ac <_Balloc+0x20>
 80078a2:	4b18      	ldr	r3, [pc, #96]	; (8007904 <_Balloc+0x78>)
 80078a4:	4818      	ldr	r0, [pc, #96]	; (8007908 <_Balloc+0x7c>)
 80078a6:	2166      	movs	r1, #102	; 0x66
 80078a8:	f000 fd94 	bl	80083d4 <__assert_func>
 80078ac:	e9c0 6601 	strd	r6, r6, [r0, #4]
 80078b0:	6006      	str	r6, [r0, #0]
 80078b2:	60c6      	str	r6, [r0, #12]
 80078b4:	6a66      	ldr	r6, [r4, #36]	; 0x24
 80078b6:	68f3      	ldr	r3, [r6, #12]
 80078b8:	b183      	cbz	r3, 80078dc <_Balloc+0x50>
 80078ba:	6a63      	ldr	r3, [r4, #36]	; 0x24
 80078bc:	68db      	ldr	r3, [r3, #12]
 80078be:	f853 0025 	ldr.w	r0, [r3, r5, lsl #2]
 80078c2:	b9b8      	cbnz	r0, 80078f4 <_Balloc+0x68>
 80078c4:	2101      	movs	r1, #1
 80078c6:	fa01 f605 	lsl.w	r6, r1, r5
 80078ca:	1d72      	adds	r2, r6, #5
 80078cc:	0092      	lsls	r2, r2, #2
 80078ce:	4620      	mov	r0, r4
 80078d0:	f000 fb5a 	bl	8007f88 <_calloc_r>
 80078d4:	b160      	cbz	r0, 80078f0 <_Balloc+0x64>
 80078d6:	e9c0 5601 	strd	r5, r6, [r0, #4]
 80078da:	e00e      	b.n	80078fa <_Balloc+0x6e>
 80078dc:	2221      	movs	r2, #33	; 0x21
 80078de:	2104      	movs	r1, #4
 80078e0:	4620      	mov	r0, r4
 80078e2:	f000 fb51 	bl	8007f88 <_calloc_r>
 80078e6:	6a63      	ldr	r3, [r4, #36]	; 0x24
 80078e8:	60f0      	str	r0, [r6, #12]
 80078ea:	68db      	ldr	r3, [r3, #12]
 80078ec:	2b00      	cmp	r3, #0
 80078ee:	d1e4      	bne.n	80078ba <_Balloc+0x2e>
 80078f0:	2000      	movs	r0, #0
 80078f2:	bd70      	pop	{r4, r5, r6, pc}
 80078f4:	6802      	ldr	r2, [r0, #0]
 80078f6:	f843 2025 	str.w	r2, [r3, r5, lsl #2]
 80078fa:	2300      	movs	r3, #0
 80078fc:	e9c0 3303 	strd	r3, r3, [r0, #12]
 8007900:	e7f7      	b.n	80078f2 <_Balloc+0x66>
 8007902:	bf00      	nop
 8007904:	08009069 	.word	0x08009069
 8007908:	080090f0 	.word	0x080090f0

0800790c <_Bfree>:
 800790c:	b570      	push	{r4, r5, r6, lr}
 800790e:	6a46      	ldr	r6, [r0, #36]	; 0x24
 8007910:	4605      	mov	r5, r0
 8007912:	460c      	mov	r4, r1
 8007914:	b976      	cbnz	r6, 8007934 <_Bfree+0x28>
 8007916:	2010      	movs	r0, #16
 8007918:	f7ff ffa2 	bl	8007860 <malloc>
 800791c:	4602      	mov	r2, r0
 800791e:	6268      	str	r0, [r5, #36]	; 0x24
 8007920:	b920      	cbnz	r0, 800792c <_Bfree+0x20>
 8007922:	4b09      	ldr	r3, [pc, #36]	; (8007948 <_Bfree+0x3c>)
 8007924:	4809      	ldr	r0, [pc, #36]	; (800794c <_Bfree+0x40>)
 8007926:	218a      	movs	r1, #138	; 0x8a
 8007928:	f000 fd54 	bl	80083d4 <__assert_func>
 800792c:	e9c0 6601 	strd	r6, r6, [r0, #4]
 8007930:	6006      	str	r6, [r0, #0]
 8007932:	60c6      	str	r6, [r0, #12]
 8007934:	b13c      	cbz	r4, 8007946 <_Bfree+0x3a>
 8007936:	6a6b      	ldr	r3, [r5, #36]	; 0x24
 8007938:	6862      	ldr	r2, [r4, #4]
 800793a:	68db      	ldr	r3, [r3, #12]
 800793c:	f853 1022 	ldr.w	r1, [r3, r2, lsl #2]
 8007940:	6021      	str	r1, [r4, #0]
 8007942:	f843 4022 	str.w	r4, [r3, r2, lsl #2]
 8007946:	bd70      	pop	{r4, r5, r6, pc}
 8007948:	08009069 	.word	0x08009069
 800794c:	080090f0 	.word	0x080090f0

08007950 <__multadd>:
 8007950:	e92d 41f0 	stmdb	sp!, {r4, r5, r6, r7, r8, lr}
 8007954:	690e      	ldr	r6, [r1, #16]
 8007956:	4607      	mov	r7, r0
 8007958:	4698      	mov	r8, r3
 800795a:	460c      	mov	r4, r1
 800795c:	f101 0014 	add.w	r0, r1, #20
 8007960:	2300      	movs	r3, #0
 8007962:	6805      	ldr	r5, [r0, #0]
 8007964:	b2a9      	uxth	r1, r5
 8007966:	fb02 8101 	mla	r1, r2, r1, r8
 800796a:	ea4f 4c11 	mov.w	ip, r1, lsr #16
 800796e:	0c2d      	lsrs	r5, r5, #16
 8007970:	fb02 c505 	mla	r5, r2, r5, ip
 8007974:	b289      	uxth	r1, r1
 8007976:	3301      	adds	r3, #1
 8007978:	eb01 4105 	add.w	r1, r1, r5, lsl #16
 800797c:	429e      	cmp	r6, r3
 800797e:	f840 1b04 	str.w	r1, [r0], #4
 8007982:	ea4f 4815 	mov.w	r8, r5, lsr #16
 8007986:	dcec      	bgt.n	8007962 <__multadd+0x12>
 8007988:	f1b8 0f00 	cmp.w	r8, #0
 800798c:	d022      	beq.n	80079d4 <__multadd+0x84>
 800798e:	68a3      	ldr	r3, [r4, #8]
 8007990:	42b3      	cmp	r3, r6
 8007992:	dc19      	bgt.n	80079c8 <__multadd+0x78>
 8007994:	6861      	ldr	r1, [r4, #4]
 8007996:	4638      	mov	r0, r7
 8007998:	3101      	adds	r1, #1
 800799a:	f7ff ff77 	bl	800788c <_Balloc>
 800799e:	4605      	mov	r5, r0
 80079a0:	b928      	cbnz	r0, 80079ae <__multadd+0x5e>
 80079a2:	4602      	mov	r2, r0
 80079a4:	4b0d      	ldr	r3, [pc, #52]	; (80079dc <__multadd+0x8c>)
 80079a6:	480e      	ldr	r0, [pc, #56]	; (80079e0 <__multadd+0x90>)
 80079a8:	21b5      	movs	r1, #181	; 0xb5
 80079aa:	f000 fd13 	bl	80083d4 <__assert_func>
 80079ae:	6922      	ldr	r2, [r4, #16]
 80079b0:	3202      	adds	r2, #2
 80079b2:	f104 010c 	add.w	r1, r4, #12
 80079b6:	0092      	lsls	r2, r2, #2
 80079b8:	300c      	adds	r0, #12
 80079ba:	f7ff ff59 	bl	8007870 <memcpy>
 80079be:	4621      	mov	r1, r4
 80079c0:	4638      	mov	r0, r7
 80079c2:	f7ff ffa3 	bl	800790c <_Bfree>
 80079c6:	462c      	mov	r4, r5
 80079c8:	eb04 0386 	add.w	r3, r4, r6, lsl #2
 80079cc:	3601      	adds	r6, #1
 80079ce:	f8c3 8014 	str.w	r8, [r3, #20]
 80079d2:	6126      	str	r6, [r4, #16]
 80079d4:	4620      	mov	r0, r4
 80079d6:	e8bd 81f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, pc}
 80079da:	bf00      	nop
 80079dc:	080090df 	.word	0x080090df
 80079e0:	080090f0 	.word	0x080090f0

080079e4 <__hi0bits>:
 80079e4:	0c03      	lsrs	r3, r0, #16
 80079e6:	041b      	lsls	r3, r3, #16
 80079e8:	b9d3      	cbnz	r3, 8007a20 <__hi0bits+0x3c>
 80079ea:	0400      	lsls	r0, r0, #16
 80079ec:	2310      	movs	r3, #16
 80079ee:	f010 4f7f 	tst.w	r0, #4278190080	; 0xff000000
 80079f2:	bf04      	itt	eq
 80079f4:	0200      	lsleq	r0, r0, #8
 80079f6:	3308      	addeq	r3, #8
 80079f8:	f010 4f70 	tst.w	r0, #4026531840	; 0xf0000000
 80079fc:	bf04      	itt	eq
 80079fe:	0100      	lsleq	r0, r0, #4
 8007a00:	3304      	addeq	r3, #4
 8007a02:	f010 4f40 	tst.w	r0, #3221225472	; 0xc0000000
 8007a06:	bf04      	itt	eq
 8007a08:	0080      	lsleq	r0, r0, #2
 8007a0a:	3302      	addeq	r3, #2
 8007a0c:	2800      	cmp	r0, #0
 8007a0e:	db05      	blt.n	8007a1c <__hi0bits+0x38>
 8007a10:	f010 4f80 	tst.w	r0, #1073741824	; 0x40000000
 8007a14:	f103 0301 	add.w	r3, r3, #1
 8007a18:	bf08      	it	eq
 8007a1a:	2320      	moveq	r3, #32
 8007a1c:	4618      	mov	r0, r3
 8007a1e:	4770      	bx	lr
 8007a20:	2300      	movs	r3, #0
 8007a22:	e7e4      	b.n	80079ee <__hi0bits+0xa>

08007a24 <__lo0bits>:
 8007a24:	6803      	ldr	r3, [r0, #0]
 8007a26:	f013 0207 	ands.w	r2, r3, #7
 8007a2a:	4601      	mov	r1, r0
 8007a2c:	d00b      	beq.n	8007a46 <__lo0bits+0x22>
 8007a2e:	07da      	lsls	r2, r3, #31
 8007a30:	d424      	bmi.n	8007a7c <__lo0bits+0x58>
 8007a32:	0798      	lsls	r0, r3, #30
 8007a34:	bf49      	itett	mi
 8007a36:	085b      	lsrmi	r3, r3, #1
 8007a38:	089b      	lsrpl	r3, r3, #2
 8007a3a:	2001      	movmi	r0, #1
 8007a3c:	600b      	strmi	r3, [r1, #0]
 8007a3e:	bf5c      	itt	pl
 8007a40:	600b      	strpl	r3, [r1, #0]
 8007a42:	2002      	movpl	r0, #2
 8007a44:	4770      	bx	lr
 8007a46:	b298      	uxth	r0, r3
 8007a48:	b9b0      	cbnz	r0, 8007a78 <__lo0bits+0x54>
 8007a4a:	0c1b      	lsrs	r3, r3, #16
 8007a4c:	2010      	movs	r0, #16
 8007a4e:	f013 0fff 	tst.w	r3, #255	; 0xff
 8007a52:	bf04      	itt	eq
 8007a54:	0a1b      	lsreq	r3, r3, #8
 8007a56:	3008      	addeq	r0, #8
 8007a58:	071a      	lsls	r2, r3, #28
 8007a5a:	bf04      	itt	eq
 8007a5c:	091b      	lsreq	r3, r3, #4
 8007a5e:	3004      	addeq	r0, #4
 8007a60:	079a      	lsls	r2, r3, #30
 8007a62:	bf04      	itt	eq
 8007a64:	089b      	lsreq	r3, r3, #2
 8007a66:	3002      	addeq	r0, #2
 8007a68:	07da      	lsls	r2, r3, #31
 8007a6a:	d403      	bmi.n	8007a74 <__lo0bits+0x50>
 8007a6c:	085b      	lsrs	r3, r3, #1
 8007a6e:	f100 0001 	add.w	r0, r0, #1
 8007a72:	d005      	beq.n	8007a80 <__lo0bits+0x5c>
 8007a74:	600b      	str	r3, [r1, #0]
 8007a76:	4770      	bx	lr
 8007a78:	4610      	mov	r0, r2
 8007a7a:	e7e8      	b.n	8007a4e <__lo0bits+0x2a>
 8007a7c:	2000      	movs	r0, #0
 8007a7e:	4770      	bx	lr
 8007a80:	2020      	movs	r0, #32
 8007a82:	4770      	bx	lr

08007a84 <__i2b>:
 8007a84:	b510      	push	{r4, lr}
 8007a86:	460c      	mov	r4, r1
 8007a88:	2101      	movs	r1, #1
 8007a8a:	f7ff feff 	bl	800788c <_Balloc>
 8007a8e:	4602      	mov	r2, r0
 8007a90:	b928      	cbnz	r0, 8007a9e <__i2b+0x1a>
 8007a92:	4b05      	ldr	r3, [pc, #20]	; (8007aa8 <__i2b+0x24>)
 8007a94:	4805      	ldr	r0, [pc, #20]	; (8007aac <__i2b+0x28>)
 8007a96:	f44f 71a0 	mov.w	r1, #320	; 0x140
 8007a9a:	f000 fc9b 	bl	80083d4 <__assert_func>
 8007a9e:	2301      	movs	r3, #1
 8007aa0:	6144      	str	r4, [r0, #20]
 8007aa2:	6103      	str	r3, [r0, #16]
 8007aa4:	bd10      	pop	{r4, pc}
 8007aa6:	bf00      	nop
 8007aa8:	080090df 	.word	0x080090df
 8007aac:	080090f0 	.word	0x080090f0

08007ab0 <__multiply>:
 8007ab0:	e92d 4ff0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, lr}
 8007ab4:	4614      	mov	r4, r2
 8007ab6:	690a      	ldr	r2, [r1, #16]
 8007ab8:	6923      	ldr	r3, [r4, #16]
 8007aba:	429a      	cmp	r2, r3
 8007abc:	bfb8      	it	lt
 8007abe:	460b      	movlt	r3, r1
 8007ac0:	460d      	mov	r5, r1
 8007ac2:	bfbc      	itt	lt
 8007ac4:	4625      	movlt	r5, r4
 8007ac6:	461c      	movlt	r4, r3
 8007ac8:	f8d5 a010 	ldr.w	sl, [r5, #16]
 8007acc:	f8d4 9010 	ldr.w	r9, [r4, #16]
 8007ad0:	68ab      	ldr	r3, [r5, #8]
 8007ad2:	6869      	ldr	r1, [r5, #4]
 8007ad4:	eb0a 0709 	add.w	r7, sl, r9
 8007ad8:	42bb      	cmp	r3, r7
 8007ada:	b085      	sub	sp, #20
 8007adc:	bfb8      	it	lt
 8007ade:	3101      	addlt	r1, #1
 8007ae0:	f7ff fed4 	bl	800788c <_Balloc>
 8007ae4:	b930      	cbnz	r0, 8007af4 <__multiply+0x44>
 8007ae6:	4602      	mov	r2, r0
 8007ae8:	4b42      	ldr	r3, [pc, #264]	; (8007bf4 <__multiply+0x144>)
 8007aea:	4843      	ldr	r0, [pc, #268]	; (8007bf8 <__multiply+0x148>)
 8007aec:	f240 115d 	movw	r1, #349	; 0x15d
 8007af0:	f000 fc70 	bl	80083d4 <__assert_func>
 8007af4:	f100 0614 	add.w	r6, r0, #20
 8007af8:	eb06 0887 	add.w	r8, r6, r7, lsl #2
 8007afc:	4633      	mov	r3, r6
 8007afe:	2200      	movs	r2, #0
 8007b00:	4543      	cmp	r3, r8
 8007b02:	d31e      	bcc.n	8007b42 <__multiply+0x92>
 8007b04:	f105 0c14 	add.w	ip, r5, #20
 8007b08:	f104 0314 	add.w	r3, r4, #20
 8007b0c:	eb0c 0c8a 	add.w	ip, ip, sl, lsl #2
 8007b10:	eb03 0289 	add.w	r2, r3, r9, lsl #2
 8007b14:	9202      	str	r2, [sp, #8]
 8007b16:	ebac 0205 	sub.w	r2, ip, r5
 8007b1a:	3a15      	subs	r2, #21
 8007b1c:	f022 0203 	bic.w	r2, r2, #3
 8007b20:	3204      	adds	r2, #4
 8007b22:	f105 0115 	add.w	r1, r5, #21
 8007b26:	458c      	cmp	ip, r1
 8007b28:	bf38      	it	cc
 8007b2a:	2204      	movcc	r2, #4
 8007b2c:	9201      	str	r2, [sp, #4]
 8007b2e:	9a02      	ldr	r2, [sp, #8]
 8007b30:	9303      	str	r3, [sp, #12]
 8007b32:	429a      	cmp	r2, r3
 8007b34:	d808      	bhi.n	8007b48 <__multiply+0x98>
 8007b36:	2f00      	cmp	r7, #0
 8007b38:	dc55      	bgt.n	8007be6 <__multiply+0x136>
 8007b3a:	6107      	str	r7, [r0, #16]
 8007b3c:	b005      	add	sp, #20
 8007b3e:	e8bd 8ff0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, pc}
 8007b42:	f843 2b04 	str.w	r2, [r3], #4
 8007b46:	e7db      	b.n	8007b00 <__multiply+0x50>
 8007b48:	f8b3 a000 	ldrh.w	sl, [r3]
 8007b4c:	f1ba 0f00 	cmp.w	sl, #0
 8007b50:	d020      	beq.n	8007b94 <__multiply+0xe4>
 8007b52:	f105 0e14 	add.w	lr, r5, #20
 8007b56:	46b1      	mov	r9, r6
 8007b58:	2200      	movs	r2, #0
 8007b5a:	f85e 4b04 	ldr.w	r4, [lr], #4
 8007b5e:	f8d9 b000 	ldr.w	fp, [r9]
 8007b62:	b2a1      	uxth	r1, r4
 8007b64:	fa1f fb8b 	uxth.w	fp, fp
 8007b68:	fb0a b101 	mla	r1, sl, r1, fp
 8007b6c:	4411      	add	r1, r2
 8007b6e:	f8d9 2000 	ldr.w	r2, [r9]
 8007b72:	0c24      	lsrs	r4, r4, #16
 8007b74:	0c12      	lsrs	r2, r2, #16
 8007b76:	fb0a 2404 	mla	r4, sl, r4, r2
 8007b7a:	eb04 4411 	add.w	r4, r4, r1, lsr #16
 8007b7e:	b289      	uxth	r1, r1
 8007b80:	ea41 4104 	orr.w	r1, r1, r4, lsl #16
 8007b84:	45f4      	cmp	ip, lr
 8007b86:	f849 1b04 	str.w	r1, [r9], #4
 8007b8a:	ea4f 4214 	mov.w	r2, r4, lsr #16
 8007b8e:	d8e4      	bhi.n	8007b5a <__multiply+0xaa>
 8007b90:	9901      	ldr	r1, [sp, #4]
 8007b92:	5072      	str	r2, [r6, r1]
 8007b94:	9a03      	ldr	r2, [sp, #12]
 8007b96:	f8b2 9002 	ldrh.w	r9, [r2, #2]
 8007b9a:	3304      	adds	r3, #4
 8007b9c:	f1b9 0f00 	cmp.w	r9, #0
 8007ba0:	d01f      	beq.n	8007be2 <__multiply+0x132>
 8007ba2:	6834      	ldr	r4, [r6, #0]
 8007ba4:	f105 0114 	add.w	r1, r5, #20
 8007ba8:	46b6      	mov	lr, r6
 8007baa:	f04f 0a00 	mov.w	sl, #0
 8007bae:	880a      	ldrh	r2, [r1, #0]
 8007bb0:	f8be b002 	ldrh.w	fp, [lr, #2]
 8007bb4:	fb09 b202 	mla	r2, r9, r2, fp
 8007bb8:	4492      	add	sl, r2
 8007bba:	b2a4      	uxth	r4, r4
 8007bbc:	ea44 440a 	orr.w	r4, r4, sl, lsl #16
 8007bc0:	f84e 4b04 	str.w	r4, [lr], #4
 8007bc4:	f851 4b04 	ldr.w	r4, [r1], #4
 8007bc8:	f8be 2000 	ldrh.w	r2, [lr]
 8007bcc:	0c24      	lsrs	r4, r4, #16
 8007bce:	fb09 2404 	mla	r4, r9, r4, r2
 8007bd2:	eb04 441a 	add.w	r4, r4, sl, lsr #16
 8007bd6:	458c      	cmp	ip, r1
 8007bd8:	ea4f 4a14 	mov.w	sl, r4, lsr #16
 8007bdc:	d8e7      	bhi.n	8007bae <__multiply+0xfe>
 8007bde:	9a01      	ldr	r2, [sp, #4]
 8007be0:	50b4      	str	r4, [r6, r2]
 8007be2:	3604      	adds	r6, #4
 8007be4:	e7a3      	b.n	8007b2e <__multiply+0x7e>
 8007be6:	f858 3d04 	ldr.w	r3, [r8, #-4]!
 8007bea:	2b00      	cmp	r3, #0
 8007bec:	d1a5      	bne.n	8007b3a <__multiply+0x8a>
 8007bee:	3f01      	subs	r7, #1
 8007bf0:	e7a1      	b.n	8007b36 <__multiply+0x86>
 8007bf2:	bf00      	nop
 8007bf4:	080090df 	.word	0x080090df
 8007bf8:	080090f0 	.word	0x080090f0

08007bfc <__pow5mult>:
 8007bfc:	e92d 43f8 	stmdb	sp!, {r3, r4, r5, r6, r7, r8, r9, lr}
 8007c00:	4615      	mov	r5, r2
 8007c02:	f012 0203 	ands.w	r2, r2, #3
 8007c06:	4606      	mov	r6, r0
 8007c08:	460f      	mov	r7, r1
 8007c0a:	d007      	beq.n	8007c1c <__pow5mult+0x20>
 8007c0c:	4c25      	ldr	r4, [pc, #148]	; (8007ca4 <__pow5mult+0xa8>)
 8007c0e:	3a01      	subs	r2, #1
 8007c10:	2300      	movs	r3, #0
 8007c12:	f854 2022 	ldr.w	r2, [r4, r2, lsl #2]
 8007c16:	f7ff fe9b 	bl	8007950 <__multadd>
 8007c1a:	4607      	mov	r7, r0
 8007c1c:	10ad      	asrs	r5, r5, #2
 8007c1e:	d03d      	beq.n	8007c9c <__pow5mult+0xa0>
 8007c20:	6a74      	ldr	r4, [r6, #36]	; 0x24
 8007c22:	b97c      	cbnz	r4, 8007c44 <__pow5mult+0x48>
 8007c24:	2010      	movs	r0, #16
 8007c26:	f7ff fe1b 	bl	8007860 <malloc>
 8007c2a:	4602      	mov	r2, r0
 8007c2c:	6270      	str	r0, [r6, #36]	; 0x24
 8007c2e:	b928      	cbnz	r0, 8007c3c <__pow5mult+0x40>
 8007c30:	4b1d      	ldr	r3, [pc, #116]	; (8007ca8 <__pow5mult+0xac>)
 8007c32:	481e      	ldr	r0, [pc, #120]	; (8007cac <__pow5mult+0xb0>)
 8007c34:	f44f 71d7 	mov.w	r1, #430	; 0x1ae
 8007c38:	f000 fbcc 	bl	80083d4 <__assert_func>
 8007c3c:	e9c0 4401 	strd	r4, r4, [r0, #4]
 8007c40:	6004      	str	r4, [r0, #0]
 8007c42:	60c4      	str	r4, [r0, #12]
 8007c44:	f8d6 8024 	ldr.w	r8, [r6, #36]	; 0x24
 8007c48:	f8d8 4008 	ldr.w	r4, [r8, #8]
 8007c4c:	b94c      	cbnz	r4, 8007c62 <__pow5mult+0x66>
 8007c4e:	f240 2171 	movw	r1, #625	; 0x271
 8007c52:	4630      	mov	r0, r6
 8007c54:	f7ff ff16 	bl	8007a84 <__i2b>
 8007c58:	2300      	movs	r3, #0
 8007c5a:	f8c8 0008 	str.w	r0, [r8, #8]
 8007c5e:	4604      	mov	r4, r0
 8007c60:	6003      	str	r3, [r0, #0]
 8007c62:	f04f 0900 	mov.w	r9, #0
 8007c66:	07eb      	lsls	r3, r5, #31
 8007c68:	d50a      	bpl.n	8007c80 <__pow5mult+0x84>
 8007c6a:	4639      	mov	r1, r7
 8007c6c:	4622      	mov	r2, r4
 8007c6e:	4630      	mov	r0, r6
 8007c70:	f7ff ff1e 	bl	8007ab0 <__multiply>
 8007c74:	4639      	mov	r1, r7
 8007c76:	4680      	mov	r8, r0
 8007c78:	4630      	mov	r0, r6
 8007c7a:	f7ff fe47 	bl	800790c <_Bfree>
 8007c7e:	4647      	mov	r7, r8
 8007c80:	106d      	asrs	r5, r5, #1
 8007c82:	d00b      	beq.n	8007c9c <__pow5mult+0xa0>
 8007c84:	6820      	ldr	r0, [r4, #0]
 8007c86:	b938      	cbnz	r0, 8007c98 <__pow5mult+0x9c>
 8007c88:	4622      	mov	r2, r4
 8007c8a:	4621      	mov	r1, r4
 8007c8c:	4630      	mov	r0, r6
 8007c8e:	f7ff ff0f 	bl	8007ab0 <__multiply>
 8007c92:	6020      	str	r0, [r4, #0]
 8007c94:	f8c0 9000 	str.w	r9, [r0]
 8007c98:	4604      	mov	r4, r0
 8007c9a:	e7e4      	b.n	8007c66 <__pow5mult+0x6a>
 8007c9c:	4638      	mov	r0, r7
 8007c9e:	e8bd 83f8 	ldmia.w	sp!, {r3, r4, r5, r6, r7, r8, r9, pc}
 8007ca2:	bf00      	nop
 8007ca4:	08009240 	.word	0x08009240
 8007ca8:	08009069 	.word	0x08009069
 8007cac:	080090f0 	.word	0x080090f0

08007cb0 <__lshift>:
 8007cb0:	e92d 47f0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, lr}
 8007cb4:	460c      	mov	r4, r1
 8007cb6:	6849      	ldr	r1, [r1, #4]
 8007cb8:	6923      	ldr	r3, [r4, #16]
 8007cba:	eb03 1862 	add.w	r8, r3, r2, asr #5
 8007cbe:	68a3      	ldr	r3, [r4, #8]
 8007cc0:	4607      	mov	r7, r0
 8007cc2:	4691      	mov	r9, r2
 8007cc4:	ea4f 1a62 	mov.w	sl, r2, asr #5
 8007cc8:	f108 0601 	add.w	r6, r8, #1
 8007ccc:	42b3      	cmp	r3, r6
 8007cce:	db0b      	blt.n	8007ce8 <__lshift+0x38>
 8007cd0:	4638      	mov	r0, r7
 8007cd2:	f7ff fddb 	bl	800788c <_Balloc>
 8007cd6:	4605      	mov	r5, r0
 8007cd8:	b948      	cbnz	r0, 8007cee <__lshift+0x3e>
 8007cda:	4602      	mov	r2, r0
 8007cdc:	4b28      	ldr	r3, [pc, #160]	; (8007d80 <__lshift+0xd0>)
 8007cde:	4829      	ldr	r0, [pc, #164]	; (8007d84 <__lshift+0xd4>)
 8007ce0:	f240 11d9 	movw	r1, #473	; 0x1d9
 8007ce4:	f000 fb76 	bl	80083d4 <__assert_func>
 8007ce8:	3101      	adds	r1, #1
 8007cea:	005b      	lsls	r3, r3, #1
 8007cec:	e7ee      	b.n	8007ccc <__lshift+0x1c>
 8007cee:	2300      	movs	r3, #0
 8007cf0:	f100 0114 	add.w	r1, r0, #20
 8007cf4:	f100 0210 	add.w	r2, r0, #16
 8007cf8:	4618      	mov	r0, r3
 8007cfa:	4553      	cmp	r3, sl
 8007cfc:	db33      	blt.n	8007d66 <__lshift+0xb6>
 8007cfe:	6920      	ldr	r0, [r4, #16]
 8007d00:	ea2a 7aea 	bic.w	sl, sl, sl, asr #31
 8007d04:	f104 0314 	add.w	r3, r4, #20
 8007d08:	f019 091f 	ands.w	r9, r9, #31
 8007d0c:	eb01 018a 	add.w	r1, r1, sl, lsl #2
 8007d10:	eb03 0c80 	add.w	ip, r3, r0, lsl #2
 8007d14:	d02b      	beq.n	8007d6e <__lshift+0xbe>
 8007d16:	f1c9 0e20 	rsb	lr, r9, #32
 8007d1a:	468a      	mov	sl, r1
 8007d1c:	2200      	movs	r2, #0
 8007d1e:	6818      	ldr	r0, [r3, #0]
 8007d20:	fa00 f009 	lsl.w	r0, r0, r9
 8007d24:	4302      	orrs	r2, r0
 8007d26:	f84a 2b04 	str.w	r2, [sl], #4
 8007d2a:	f853 2b04 	ldr.w	r2, [r3], #4
 8007d2e:	459c      	cmp	ip, r3
 8007d30:	fa22 f20e 	lsr.w	r2, r2, lr
 8007d34:	d8f3      	bhi.n	8007d1e <__lshift+0x6e>
 8007d36:	ebac 0304 	sub.w	r3, ip, r4
 8007d3a:	3b15      	subs	r3, #21
 8007d3c:	f023 0303 	bic.w	r3, r3, #3
 8007d40:	3304      	adds	r3, #4
 8007d42:	f104 0015 	add.w	r0, r4, #21
 8007d46:	4584      	cmp	ip, r0
 8007d48:	bf38      	it	cc
 8007d4a:	2304      	movcc	r3, #4
 8007d4c:	50ca      	str	r2, [r1, r3]
 8007d4e:	b10a      	cbz	r2, 8007d54 <__lshift+0xa4>
 8007d50:	f108 0602 	add.w	r6, r8, #2
 8007d54:	3e01      	subs	r6, #1
 8007d56:	4638      	mov	r0, r7
 8007d58:	612e      	str	r6, [r5, #16]
 8007d5a:	4621      	mov	r1, r4
 8007d5c:	f7ff fdd6 	bl	800790c <_Bfree>
 8007d60:	4628      	mov	r0, r5
 8007d62:	e8bd 87f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, pc}
 8007d66:	f842 0f04 	str.w	r0, [r2, #4]!
 8007d6a:	3301      	adds	r3, #1
 8007d6c:	e7c5      	b.n	8007cfa <__lshift+0x4a>
 8007d6e:	3904      	subs	r1, #4
 8007d70:	f853 2b04 	ldr.w	r2, [r3], #4
 8007d74:	f841 2f04 	str.w	r2, [r1, #4]!
 8007d78:	459c      	cmp	ip, r3
 8007d7a:	d8f9      	bhi.n	8007d70 <__lshift+0xc0>
 8007d7c:	e7ea      	b.n	8007d54 <__lshift+0xa4>
 8007d7e:	bf00      	nop
 8007d80:	080090df 	.word	0x080090df
 8007d84:	080090f0 	.word	0x080090f0

08007d88 <__mcmp>:
 8007d88:	b530      	push	{r4, r5, lr}
 8007d8a:	6902      	ldr	r2, [r0, #16]
 8007d8c:	690c      	ldr	r4, [r1, #16]
 8007d8e:	1b12      	subs	r2, r2, r4
 8007d90:	d10e      	bne.n	8007db0 <__mcmp+0x28>
 8007d92:	f100 0314 	add.w	r3, r0, #20
 8007d96:	3114      	adds	r1, #20
 8007d98:	eb03 0084 	add.w	r0, r3, r4, lsl #2
 8007d9c:	eb01 0184 	add.w	r1, r1, r4, lsl #2
 8007da0:	f850 5d04 	ldr.w	r5, [r0, #-4]!
 8007da4:	f851 4d04 	ldr.w	r4, [r1, #-4]!
 8007da8:	42a5      	cmp	r5, r4
 8007daa:	d003      	beq.n	8007db4 <__mcmp+0x2c>
 8007dac:	d305      	bcc.n	8007dba <__mcmp+0x32>
 8007dae:	2201      	movs	r2, #1
 8007db0:	4610      	mov	r0, r2
 8007db2:	bd30      	pop	{r4, r5, pc}
 8007db4:	4283      	cmp	r3, r0
 8007db6:	d3f3      	bcc.n	8007da0 <__mcmp+0x18>
 8007db8:	e7fa      	b.n	8007db0 <__mcmp+0x28>
 8007dba:	f04f 32ff 	mov.w	r2, #4294967295
 8007dbe:	e7f7      	b.n	8007db0 <__mcmp+0x28>

08007dc0 <__mdiff>:
 8007dc0:	e92d 4ff8 	stmdb	sp!, {r3, r4, r5, r6, r7, r8, r9, sl, fp, lr}
 8007dc4:	460c      	mov	r4, r1
 8007dc6:	4606      	mov	r6, r0
 8007dc8:	4611      	mov	r1, r2
 8007dca:	4620      	mov	r0, r4
 8007dcc:	4617      	mov	r7, r2
 8007dce:	f7ff ffdb 	bl	8007d88 <__mcmp>
 8007dd2:	1e05      	subs	r5, r0, #0
 8007dd4:	d110      	bne.n	8007df8 <__mdiff+0x38>
 8007dd6:	4629      	mov	r1, r5
 8007dd8:	4630      	mov	r0, r6
 8007dda:	f7ff fd57 	bl	800788c <_Balloc>
 8007dde:	b930      	cbnz	r0, 8007dee <__mdiff+0x2e>
 8007de0:	4b39      	ldr	r3, [pc, #228]	; (8007ec8 <__mdiff+0x108>)
 8007de2:	4602      	mov	r2, r0
 8007de4:	f240 2132 	movw	r1, #562	; 0x232
 8007de8:	4838      	ldr	r0, [pc, #224]	; (8007ecc <__mdiff+0x10c>)
 8007dea:	f000 faf3 	bl	80083d4 <__assert_func>
 8007dee:	2301      	movs	r3, #1
 8007df0:	e9c0 3504 	strd	r3, r5, [r0, #16]
 8007df4:	e8bd 8ff8 	ldmia.w	sp!, {r3, r4, r5, r6, r7, r8, r9, sl, fp, pc}
 8007df8:	bfa4      	itt	ge
 8007dfa:	463b      	movge	r3, r7
 8007dfc:	4627      	movge	r7, r4
 8007dfe:	4630      	mov	r0, r6
 8007e00:	6879      	ldr	r1, [r7, #4]
 8007e02:	bfa6      	itte	ge
 8007e04:	461c      	movge	r4, r3
 8007e06:	2500      	movge	r5, #0
 8007e08:	2501      	movlt	r5, #1
 8007e0a:	f7ff fd3f 	bl	800788c <_Balloc>
 8007e0e:	b920      	cbnz	r0, 8007e1a <__mdiff+0x5a>
 8007e10:	4b2d      	ldr	r3, [pc, #180]	; (8007ec8 <__mdiff+0x108>)
 8007e12:	4602      	mov	r2, r0
 8007e14:	f44f 7110 	mov.w	r1, #576	; 0x240
 8007e18:	e7e6      	b.n	8007de8 <__mdiff+0x28>
 8007e1a:	693e      	ldr	r6, [r7, #16]
 8007e1c:	60c5      	str	r5, [r0, #12]
 8007e1e:	6925      	ldr	r5, [r4, #16]
 8007e20:	f107 0114 	add.w	r1, r7, #20
 8007e24:	f104 0914 	add.w	r9, r4, #20
 8007e28:	f100 0e14 	add.w	lr, r0, #20
 8007e2c:	f107 0210 	add.w	r2, r7, #16
 8007e30:	eb01 0c86 	add.w	ip, r1, r6, lsl #2
 8007e34:	eb09 0585 	add.w	r5, r9, r5, lsl #2
 8007e38:	46f2      	mov	sl, lr
 8007e3a:	2700      	movs	r7, #0
 8007e3c:	f859 3b04 	ldr.w	r3, [r9], #4
 8007e40:	f852 bf04 	ldr.w	fp, [r2, #4]!
 8007e44:	fa1f f883 	uxth.w	r8, r3
 8007e48:	fa17 f78b 	uxtah	r7, r7, fp
 8007e4c:	0c1b      	lsrs	r3, r3, #16
 8007e4e:	eba7 0808 	sub.w	r8, r7, r8
 8007e52:	ebc3 431b 	rsb	r3, r3, fp, lsr #16
 8007e56:	eb03 4328 	add.w	r3, r3, r8, asr #16
 8007e5a:	fa1f f888 	uxth.w	r8, r8
 8007e5e:	141f      	asrs	r7, r3, #16
 8007e60:	454d      	cmp	r5, r9
 8007e62:	ea48 4303 	orr.w	r3, r8, r3, lsl #16
 8007e66:	f84a 3b04 	str.w	r3, [sl], #4
 8007e6a:	d8e7      	bhi.n	8007e3c <__mdiff+0x7c>
 8007e6c:	1b2b      	subs	r3, r5, r4
 8007e6e:	3b15      	subs	r3, #21
 8007e70:	f023 0303 	bic.w	r3, r3, #3
 8007e74:	3304      	adds	r3, #4
 8007e76:	3415      	adds	r4, #21
 8007e78:	42a5      	cmp	r5, r4
 8007e7a:	bf38      	it	cc
 8007e7c:	2304      	movcc	r3, #4
 8007e7e:	4419      	add	r1, r3
 8007e80:	4473      	add	r3, lr
 8007e82:	469e      	mov	lr, r3
 8007e84:	460d      	mov	r5, r1
 8007e86:	4565      	cmp	r5, ip
 8007e88:	d30e      	bcc.n	8007ea8 <__mdiff+0xe8>
 8007e8a:	f10c 0203 	add.w	r2, ip, #3
 8007e8e:	1a52      	subs	r2, r2, r1
 8007e90:	f022 0203 	bic.w	r2, r2, #3
 8007e94:	3903      	subs	r1, #3
 8007e96:	458c      	cmp	ip, r1
 8007e98:	bf38      	it	cc
 8007e9a:	2200      	movcc	r2, #0
 8007e9c:	441a      	add	r2, r3
 8007e9e:	f852 3d04 	ldr.w	r3, [r2, #-4]!
 8007ea2:	b17b      	cbz	r3, 8007ec4 <__mdiff+0x104>
 8007ea4:	6106      	str	r6, [r0, #16]
 8007ea6:	e7a5      	b.n	8007df4 <__mdiff+0x34>
 8007ea8:	f855 8b04 	ldr.w	r8, [r5], #4
 8007eac:	fa17 f488 	uxtah	r4, r7, r8
 8007eb0:	1422      	asrs	r2, r4, #16
 8007eb2:	eb02 4218 	add.w	r2, r2, r8, lsr #16
 8007eb6:	b2a4      	uxth	r4, r4
 8007eb8:	ea44 4402 	orr.w	r4, r4, r2, lsl #16
 8007ebc:	f84e 4b04 	str.w	r4, [lr], #4
 8007ec0:	1417      	asrs	r7, r2, #16
 8007ec2:	e7e0      	b.n	8007e86 <__mdiff+0xc6>
 8007ec4:	3e01      	subs	r6, #1
 8007ec6:	e7ea      	b.n	8007e9e <__mdiff+0xde>
 8007ec8:	080090df 	.word	0x080090df
 8007ecc:	080090f0 	.word	0x080090f0

08007ed0 <__d2b>:
 8007ed0:	e92d 43f7 	stmdb	sp!, {r0, r1, r2, r4, r5, r6, r7, r8, r9, lr}
 8007ed4:	4689      	mov	r9, r1
 8007ed6:	2101      	movs	r1, #1
 8007ed8:	ec57 6b10 	vmov	r6, r7, d0
 8007edc:	4690      	mov	r8, r2
 8007ede:	f7ff fcd5 	bl	800788c <_Balloc>
 8007ee2:	4604      	mov	r4, r0
 8007ee4:	b930      	cbnz	r0, 8007ef4 <__d2b+0x24>
 8007ee6:	4602      	mov	r2, r0
 8007ee8:	4b25      	ldr	r3, [pc, #148]	; (8007f80 <__d2b+0xb0>)
 8007eea:	4826      	ldr	r0, [pc, #152]	; (8007f84 <__d2b+0xb4>)
 8007eec:	f240 310a 	movw	r1, #778	; 0x30a
 8007ef0:	f000 fa70 	bl	80083d4 <__assert_func>
 8007ef4:	f3c7 550a 	ubfx	r5, r7, #20, #11
 8007ef8:	f3c7 0313 	ubfx	r3, r7, #0, #20
 8007efc:	bb35      	cbnz	r5, 8007f4c <__d2b+0x7c>
 8007efe:	2e00      	cmp	r6, #0
 8007f00:	9301      	str	r3, [sp, #4]
 8007f02:	d028      	beq.n	8007f56 <__d2b+0x86>
 8007f04:	4668      	mov	r0, sp
 8007f06:	9600      	str	r6, [sp, #0]
 8007f08:	f7ff fd8c 	bl	8007a24 <__lo0bits>
 8007f0c:	9900      	ldr	r1, [sp, #0]
 8007f0e:	b300      	cbz	r0, 8007f52 <__d2b+0x82>
 8007f10:	9a01      	ldr	r2, [sp, #4]
 8007f12:	f1c0 0320 	rsb	r3, r0, #32
 8007f16:	fa02 f303 	lsl.w	r3, r2, r3
 8007f1a:	430b      	orrs	r3, r1
 8007f1c:	40c2      	lsrs	r2, r0
 8007f1e:	6163      	str	r3, [r4, #20]
 8007f20:	9201      	str	r2, [sp, #4]
 8007f22:	9b01      	ldr	r3, [sp, #4]
 8007f24:	61a3      	str	r3, [r4, #24]
 8007f26:	2b00      	cmp	r3, #0
 8007f28:	bf14      	ite	ne
 8007f2a:	2202      	movne	r2, #2
 8007f2c:	2201      	moveq	r2, #1
 8007f2e:	6122      	str	r2, [r4, #16]
 8007f30:	b1d5      	cbz	r5, 8007f68 <__d2b+0x98>
 8007f32:	f2a5 4533 	subw	r5, r5, #1075	; 0x433
 8007f36:	4405      	add	r5, r0
 8007f38:	f8c9 5000 	str.w	r5, [r9]
 8007f3c:	f1c0 0035 	rsb	r0, r0, #53	; 0x35
 8007f40:	f8c8 0000 	str.w	r0, [r8]
 8007f44:	4620      	mov	r0, r4
 8007f46:	b003      	add	sp, #12
 8007f48:	e8bd 83f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, pc}
 8007f4c:	f443 1380 	orr.w	r3, r3, #1048576	; 0x100000
 8007f50:	e7d5      	b.n	8007efe <__d2b+0x2e>
 8007f52:	6161      	str	r1, [r4, #20]
 8007f54:	e7e5      	b.n	8007f22 <__d2b+0x52>
 8007f56:	a801      	add	r0, sp, #4
 8007f58:	f7ff fd64 	bl	8007a24 <__lo0bits>
 8007f5c:	9b01      	ldr	r3, [sp, #4]
 8007f5e:	6163      	str	r3, [r4, #20]
 8007f60:	2201      	movs	r2, #1
 8007f62:	6122      	str	r2, [r4, #16]
 8007f64:	3020      	adds	r0, #32
 8007f66:	e7e3      	b.n	8007f30 <__d2b+0x60>
 8007f68:	eb04 0382 	add.w	r3, r4, r2, lsl #2
 8007f6c:	f2a0 4032 	subw	r0, r0, #1074	; 0x432
 8007f70:	f8c9 0000 	str.w	r0, [r9]
 8007f74:	6918      	ldr	r0, [r3, #16]
 8007f76:	f7ff fd35 	bl	80079e4 <__hi0bits>
 8007f7a:	ebc0 1042 	rsb	r0, r0, r2, lsl #5
 8007f7e:	e7df      	b.n	8007f40 <__d2b+0x70>
 8007f80:	080090df 	.word	0x080090df
 8007f84:	080090f0 	.word	0x080090f0

08007f88 <_calloc_r>:
 8007f88:	b513      	push	{r0, r1, r4, lr}
 8007f8a:	434a      	muls	r2, r1
 8007f8c:	4611      	mov	r1, r2
 8007f8e:	9201      	str	r2, [sp, #4]
 8007f90:	f000 f85a 	bl	8008048 <_malloc_r>
 8007f94:	4604      	mov	r4, r0
 8007f96:	b118      	cbz	r0, 8007fa0 <_calloc_r+0x18>
 8007f98:	9a01      	ldr	r2, [sp, #4]
 8007f9a:	2100      	movs	r1, #0
 8007f9c:	f7fe f950 	bl	8006240 <memset>
 8007fa0:	4620      	mov	r0, r4
 8007fa2:	b002      	add	sp, #8
 8007fa4:	bd10      	pop	{r4, pc}
	...

08007fa8 <_free_r>:
 8007fa8:	b537      	push	{r0, r1, r2, r4, r5, lr}
 8007faa:	2900      	cmp	r1, #0
 8007fac:	d048      	beq.n	8008040 <_free_r+0x98>
 8007fae:	f851 3c04 	ldr.w	r3, [r1, #-4]
 8007fb2:	9001      	str	r0, [sp, #4]
 8007fb4:	2b00      	cmp	r3, #0
 8007fb6:	f1a1 0404 	sub.w	r4, r1, #4
 8007fba:	bfb8      	it	lt
 8007fbc:	18e4      	addlt	r4, r4, r3
 8007fbe:	f000 fa65 	bl	800848c <__malloc_lock>
 8007fc2:	4a20      	ldr	r2, [pc, #128]	; (8008044 <_free_r+0x9c>)
 8007fc4:	9801      	ldr	r0, [sp, #4]
 8007fc6:	6813      	ldr	r3, [r2, #0]
 8007fc8:	4615      	mov	r5, r2
 8007fca:	b933      	cbnz	r3, 8007fda <_free_r+0x32>
 8007fcc:	6063      	str	r3, [r4, #4]
 8007fce:	6014      	str	r4, [r2, #0]
 8007fd0:	b003      	add	sp, #12
 8007fd2:	e8bd 4030 	ldmia.w	sp!, {r4, r5, lr}
 8007fd6:	f000 ba5f 	b.w	8008498 <__malloc_unlock>
 8007fda:	42a3      	cmp	r3, r4
 8007fdc:	d90b      	bls.n	8007ff6 <_free_r+0x4e>
 8007fde:	6821      	ldr	r1, [r4, #0]
 8007fe0:	1862      	adds	r2, r4, r1
 8007fe2:	4293      	cmp	r3, r2
 8007fe4:	bf04      	itt	eq
 8007fe6:	681a      	ldreq	r2, [r3, #0]
 8007fe8:	685b      	ldreq	r3, [r3, #4]
 8007fea:	6063      	str	r3, [r4, #4]
 8007fec:	bf04      	itt	eq
 8007fee:	1852      	addeq	r2, r2, r1
 8007ff0:	6022      	streq	r2, [r4, #0]
 8007ff2:	602c      	str	r4, [r5, #0]
 8007ff4:	e7ec      	b.n	8007fd0 <_free_r+0x28>
 8007ff6:	461a      	mov	r2, r3
 8007ff8:	685b      	ldr	r3, [r3, #4]
 8007ffa:	b10b      	cbz	r3, 8008000 <_free_r+0x58>
 8007ffc:	42a3      	cmp	r3, r4
 8007ffe:	d9fa      	bls.n	8007ff6 <_free_r+0x4e>
 8008000:	6811      	ldr	r1, [r2, #0]
 8008002:	1855      	adds	r5, r2, r1
 8008004:	42a5      	cmp	r5, r4
 8008006:	d10b      	bne.n	8008020 <_free_r+0x78>
 8008008:	6824      	ldr	r4, [r4, #0]
 800800a:	4421      	add	r1, r4
 800800c:	1854      	adds	r4, r2, r1
 800800e:	42a3      	cmp	r3, r4
 8008010:	6011      	str	r1, [r2, #0]
 8008012:	d1dd      	bne.n	8007fd0 <_free_r+0x28>
 8008014:	681c      	ldr	r4, [r3, #0]
 8008016:	685b      	ldr	r3, [r3, #4]
 8008018:	6053      	str	r3, [r2, #4]
 800801a:	4421      	add	r1, r4
 800801c:	6011      	str	r1, [r2, #0]
 800801e:	e7d7      	b.n	8007fd0 <_free_r+0x28>
 8008020:	d902      	bls.n	8008028 <_free_r+0x80>
 8008022:	230c      	movs	r3, #12
 8008024:	6003      	str	r3, [r0, #0]
 8008026:	e7d3      	b.n	8007fd0 <_free_r+0x28>
 8008028:	6825      	ldr	r5, [r4, #0]
 800802a:	1961      	adds	r1, r4, r5
 800802c:	428b      	cmp	r3, r1
 800802e:	bf04      	itt	eq
 8008030:	6819      	ldreq	r1, [r3, #0]
 8008032:	685b      	ldreq	r3, [r3, #4]
 8008034:	6063      	str	r3, [r4, #4]
 8008036:	bf04      	itt	eq
 8008038:	1949      	addeq	r1, r1, r5
 800803a:	6021      	streq	r1, [r4, #0]
 800803c:	6054      	str	r4, [r2, #4]
 800803e:	e7c7      	b.n	8007fd0 <_free_r+0x28>
 8008040:	b003      	add	sp, #12
 8008042:	bd30      	pop	{r4, r5, pc}
 8008044:	2000020c 	.word	0x2000020c

08008048 <_malloc_r>:
 8008048:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 800804a:	1ccd      	adds	r5, r1, #3
 800804c:	f025 0503 	bic.w	r5, r5, #3
 8008050:	3508      	adds	r5, #8
 8008052:	2d0c      	cmp	r5, #12
 8008054:	bf38      	it	cc
 8008056:	250c      	movcc	r5, #12
 8008058:	2d00      	cmp	r5, #0
 800805a:	4606      	mov	r6, r0
 800805c:	db01      	blt.n	8008062 <_malloc_r+0x1a>
 800805e:	42a9      	cmp	r1, r5
 8008060:	d903      	bls.n	800806a <_malloc_r+0x22>
 8008062:	230c      	movs	r3, #12
 8008064:	6033      	str	r3, [r6, #0]
 8008066:	2000      	movs	r0, #0
 8008068:	bdf8      	pop	{r3, r4, r5, r6, r7, pc}
 800806a:	f000 fa0f 	bl	800848c <__malloc_lock>
 800806e:	4921      	ldr	r1, [pc, #132]	; (80080f4 <_malloc_r+0xac>)
 8008070:	680a      	ldr	r2, [r1, #0]
 8008072:	4614      	mov	r4, r2
 8008074:	b99c      	cbnz	r4, 800809e <_malloc_r+0x56>
 8008076:	4f20      	ldr	r7, [pc, #128]	; (80080f8 <_malloc_r+0xb0>)
 8008078:	683b      	ldr	r3, [r7, #0]
 800807a:	b923      	cbnz	r3, 8008086 <_malloc_r+0x3e>
 800807c:	4621      	mov	r1, r4
 800807e:	4630      	mov	r0, r6
 8008080:	f000 f998 	bl	80083b4 <_sbrk_r>
 8008084:	6038      	str	r0, [r7, #0]
 8008086:	4629      	mov	r1, r5
 8008088:	4630      	mov	r0, r6
 800808a:	f000 f993 	bl	80083b4 <_sbrk_r>
 800808e:	1c43      	adds	r3, r0, #1
 8008090:	d123      	bne.n	80080da <_malloc_r+0x92>
 8008092:	230c      	movs	r3, #12
 8008094:	6033      	str	r3, [r6, #0]
 8008096:	4630      	mov	r0, r6
 8008098:	f000 f9fe 	bl	8008498 <__malloc_unlock>
 800809c:	e7e3      	b.n	8008066 <_malloc_r+0x1e>
 800809e:	6823      	ldr	r3, [r4, #0]
 80080a0:	1b5b      	subs	r3, r3, r5
 80080a2:	d417      	bmi.n	80080d4 <_malloc_r+0x8c>
 80080a4:	2b0b      	cmp	r3, #11
 80080a6:	d903      	bls.n	80080b0 <_malloc_r+0x68>
 80080a8:	6023      	str	r3, [r4, #0]
 80080aa:	441c      	add	r4, r3
 80080ac:	6025      	str	r5, [r4, #0]
 80080ae:	e004      	b.n	80080ba <_malloc_r+0x72>
 80080b0:	6863      	ldr	r3, [r4, #4]
 80080b2:	42a2      	cmp	r2, r4
 80080b4:	bf0c      	ite	eq
 80080b6:	600b      	streq	r3, [r1, #0]
 80080b8:	6053      	strne	r3, [r2, #4]
 80080ba:	4630      	mov	r0, r6
 80080bc:	f000 f9ec 	bl	8008498 <__malloc_unlock>
 80080c0:	f104 000b 	add.w	r0, r4, #11
 80080c4:	1d23      	adds	r3, r4, #4
 80080c6:	f020 0007 	bic.w	r0, r0, #7
 80080ca:	1ac2      	subs	r2, r0, r3
 80080cc:	d0cc      	beq.n	8008068 <_malloc_r+0x20>
 80080ce:	1a1b      	subs	r3, r3, r0
 80080d0:	50a3      	str	r3, [r4, r2]
 80080d2:	e7c9      	b.n	8008068 <_malloc_r+0x20>
 80080d4:	4622      	mov	r2, r4
 80080d6:	6864      	ldr	r4, [r4, #4]
 80080d8:	e7cc      	b.n	8008074 <_malloc_r+0x2c>
 80080da:	1cc4      	adds	r4, r0, #3
 80080dc:	f024 0403 	bic.w	r4, r4, #3
 80080e0:	42a0      	cmp	r0, r4
 80080e2:	d0e3      	beq.n	80080ac <_malloc_r+0x64>
 80080e4:	1a21      	subs	r1, r4, r0
 80080e6:	4630      	mov	r0, r6
 80080e8:	f000 f964 	bl	80083b4 <_sbrk_r>
 80080ec:	3001      	adds	r0, #1
 80080ee:	d1dd      	bne.n	80080ac <_malloc_r+0x64>
 80080f0:	e7cf      	b.n	8008092 <_malloc_r+0x4a>
 80080f2:	bf00      	nop
 80080f4:	2000020c 	.word	0x2000020c
 80080f8:	20000210 	.word	0x20000210

080080fc <__ssputs_r>:
 80080fc:	e92d 47f0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, lr}
 8008100:	688e      	ldr	r6, [r1, #8]
 8008102:	429e      	cmp	r6, r3
 8008104:	4682      	mov	sl, r0
 8008106:	460c      	mov	r4, r1
 8008108:	4690      	mov	r8, r2
 800810a:	461f      	mov	r7, r3
 800810c:	d838      	bhi.n	8008180 <__ssputs_r+0x84>
 800810e:	898a      	ldrh	r2, [r1, #12]
 8008110:	f412 6f90 	tst.w	r2, #1152	; 0x480
 8008114:	d032      	beq.n	800817c <__ssputs_r+0x80>
 8008116:	6825      	ldr	r5, [r4, #0]
 8008118:	6909      	ldr	r1, [r1, #16]
 800811a:	eba5 0901 	sub.w	r9, r5, r1
 800811e:	6965      	ldr	r5, [r4, #20]
 8008120:	eb05 0545 	add.w	r5, r5, r5, lsl #1
 8008124:	eb05 75d5 	add.w	r5, r5, r5, lsr #31
 8008128:	3301      	adds	r3, #1
 800812a:	444b      	add	r3, r9
 800812c:	106d      	asrs	r5, r5, #1
 800812e:	429d      	cmp	r5, r3
 8008130:	bf38      	it	cc
 8008132:	461d      	movcc	r5, r3
 8008134:	0553      	lsls	r3, r2, #21
 8008136:	d531      	bpl.n	800819c <__ssputs_r+0xa0>
 8008138:	4629      	mov	r1, r5
 800813a:	f7ff ff85 	bl	8008048 <_malloc_r>
 800813e:	4606      	mov	r6, r0
 8008140:	b950      	cbnz	r0, 8008158 <__ssputs_r+0x5c>
 8008142:	230c      	movs	r3, #12
 8008144:	f8ca 3000 	str.w	r3, [sl]
 8008148:	89a3      	ldrh	r3, [r4, #12]
 800814a:	f043 0340 	orr.w	r3, r3, #64	; 0x40
 800814e:	81a3      	strh	r3, [r4, #12]
 8008150:	f04f 30ff 	mov.w	r0, #4294967295
 8008154:	e8bd 87f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, pc}
 8008158:	6921      	ldr	r1, [r4, #16]
 800815a:	464a      	mov	r2, r9
 800815c:	f7ff fb88 	bl	8007870 <memcpy>
 8008160:	89a3      	ldrh	r3, [r4, #12]
 8008162:	f423 6390 	bic.w	r3, r3, #1152	; 0x480
 8008166:	f043 0380 	orr.w	r3, r3, #128	; 0x80
 800816a:	81a3      	strh	r3, [r4, #12]
 800816c:	6126      	str	r6, [r4, #16]
 800816e:	6165      	str	r5, [r4, #20]
 8008170:	444e      	add	r6, r9
 8008172:	eba5 0509 	sub.w	r5, r5, r9
 8008176:	6026      	str	r6, [r4, #0]
 8008178:	60a5      	str	r5, [r4, #8]
 800817a:	463e      	mov	r6, r7
 800817c:	42be      	cmp	r6, r7
 800817e:	d900      	bls.n	8008182 <__ssputs_r+0x86>
 8008180:	463e      	mov	r6, r7
 8008182:	4632      	mov	r2, r6
 8008184:	6820      	ldr	r0, [r4, #0]
 8008186:	4641      	mov	r1, r8
 8008188:	f000 f966 	bl	8008458 <memmove>
 800818c:	68a3      	ldr	r3, [r4, #8]
 800818e:	6822      	ldr	r2, [r4, #0]
 8008190:	1b9b      	subs	r3, r3, r6
 8008192:	4432      	add	r2, r6
 8008194:	60a3      	str	r3, [r4, #8]
 8008196:	6022      	str	r2, [r4, #0]
 8008198:	2000      	movs	r0, #0
 800819a:	e7db      	b.n	8008154 <__ssputs_r+0x58>
 800819c:	462a      	mov	r2, r5
 800819e:	f000 f981 	bl	80084a4 <_realloc_r>
 80081a2:	4606      	mov	r6, r0
 80081a4:	2800      	cmp	r0, #0
 80081a6:	d1e1      	bne.n	800816c <__ssputs_r+0x70>
 80081a8:	6921      	ldr	r1, [r4, #16]
 80081aa:	4650      	mov	r0, sl
 80081ac:	f7ff fefc 	bl	8007fa8 <_free_r>
 80081b0:	e7c7      	b.n	8008142 <__ssputs_r+0x46>
	...

080081b4 <_svfiprintf_r>:
 80081b4:	e92d 4ff0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, lr}
 80081b8:	4698      	mov	r8, r3
 80081ba:	898b      	ldrh	r3, [r1, #12]
 80081bc:	061b      	lsls	r3, r3, #24
 80081be:	b09d      	sub	sp, #116	; 0x74
 80081c0:	4607      	mov	r7, r0
 80081c2:	460d      	mov	r5, r1
 80081c4:	4614      	mov	r4, r2
 80081c6:	d50e      	bpl.n	80081e6 <_svfiprintf_r+0x32>
 80081c8:	690b      	ldr	r3, [r1, #16]
 80081ca:	b963      	cbnz	r3, 80081e6 <_svfiprintf_r+0x32>
 80081cc:	2140      	movs	r1, #64	; 0x40
 80081ce:	f7ff ff3b 	bl	8008048 <_malloc_r>
 80081d2:	6028      	str	r0, [r5, #0]
 80081d4:	6128      	str	r0, [r5, #16]
 80081d6:	b920      	cbnz	r0, 80081e2 <_svfiprintf_r+0x2e>
 80081d8:	230c      	movs	r3, #12
 80081da:	603b      	str	r3, [r7, #0]
 80081dc:	f04f 30ff 	mov.w	r0, #4294967295
 80081e0:	e0d1      	b.n	8008386 <_svfiprintf_r+0x1d2>
 80081e2:	2340      	movs	r3, #64	; 0x40
 80081e4:	616b      	str	r3, [r5, #20]
 80081e6:	2300      	movs	r3, #0
 80081e8:	9309      	str	r3, [sp, #36]	; 0x24
 80081ea:	2320      	movs	r3, #32
 80081ec:	f88d 3029 	strb.w	r3, [sp, #41]	; 0x29
 80081f0:	f8cd 800c 	str.w	r8, [sp, #12]
 80081f4:	2330      	movs	r3, #48	; 0x30
 80081f6:	f8df 81a8 	ldr.w	r8, [pc, #424]	; 80083a0 <_svfiprintf_r+0x1ec>
 80081fa:	f88d 302a 	strb.w	r3, [sp, #42]	; 0x2a
 80081fe:	f04f 0901 	mov.w	r9, #1
 8008202:	4623      	mov	r3, r4
 8008204:	469a      	mov	sl, r3
 8008206:	f813 2b01 	ldrb.w	r2, [r3], #1
 800820a:	b10a      	cbz	r2, 8008210 <_svfiprintf_r+0x5c>
 800820c:	2a25      	cmp	r2, #37	; 0x25
 800820e:	d1f9      	bne.n	8008204 <_svfiprintf_r+0x50>
 8008210:	ebba 0b04 	subs.w	fp, sl, r4
 8008214:	d00b      	beq.n	800822e <_svfiprintf_r+0x7a>
 8008216:	465b      	mov	r3, fp
 8008218:	4622      	mov	r2, r4
 800821a:	4629      	mov	r1, r5
 800821c:	4638      	mov	r0, r7
 800821e:	f7ff ff6d 	bl	80080fc <__ssputs_r>
 8008222:	3001      	adds	r0, #1
 8008224:	f000 80aa 	beq.w	800837c <_svfiprintf_r+0x1c8>
 8008228:	9a09      	ldr	r2, [sp, #36]	; 0x24
 800822a:	445a      	add	r2, fp
 800822c:	9209      	str	r2, [sp, #36]	; 0x24
 800822e:	f89a 3000 	ldrb.w	r3, [sl]
 8008232:	2b00      	cmp	r3, #0
 8008234:	f000 80a2 	beq.w	800837c <_svfiprintf_r+0x1c8>
 8008238:	2300      	movs	r3, #0
 800823a:	f04f 32ff 	mov.w	r2, #4294967295
 800823e:	e9cd 2305 	strd	r2, r3, [sp, #20]
 8008242:	f10a 0a01 	add.w	sl, sl, #1
 8008246:	9304      	str	r3, [sp, #16]
 8008248:	9307      	str	r3, [sp, #28]
 800824a:	f88d 3053 	strb.w	r3, [sp, #83]	; 0x53
 800824e:	931a      	str	r3, [sp, #104]	; 0x68
 8008250:	4654      	mov	r4, sl
 8008252:	2205      	movs	r2, #5
 8008254:	f814 1b01 	ldrb.w	r1, [r4], #1
 8008258:	4851      	ldr	r0, [pc, #324]	; (80083a0 <_svfiprintf_r+0x1ec>)
 800825a:	f7f7 ffc1 	bl	80001e0 <memchr>
 800825e:	9a04      	ldr	r2, [sp, #16]
 8008260:	b9d8      	cbnz	r0, 800829a <_svfiprintf_r+0xe6>
 8008262:	06d0      	lsls	r0, r2, #27
 8008264:	bf44      	itt	mi
 8008266:	2320      	movmi	r3, #32
 8008268:	f88d 3053 	strbmi.w	r3, [sp, #83]	; 0x53
 800826c:	0711      	lsls	r1, r2, #28
 800826e:	bf44      	itt	mi
 8008270:	232b      	movmi	r3, #43	; 0x2b
 8008272:	f88d 3053 	strbmi.w	r3, [sp, #83]	; 0x53
 8008276:	f89a 3000 	ldrb.w	r3, [sl]
 800827a:	2b2a      	cmp	r3, #42	; 0x2a
 800827c:	d015      	beq.n	80082aa <_svfiprintf_r+0xf6>
 800827e:	9a07      	ldr	r2, [sp, #28]
 8008280:	4654      	mov	r4, sl
 8008282:	2000      	movs	r0, #0
 8008284:	f04f 0c0a 	mov.w	ip, #10
 8008288:	4621      	mov	r1, r4
 800828a:	f811 3b01 	ldrb.w	r3, [r1], #1
 800828e:	3b30      	subs	r3, #48	; 0x30
 8008290:	2b09      	cmp	r3, #9
 8008292:	d94e      	bls.n	8008332 <_svfiprintf_r+0x17e>
 8008294:	b1b0      	cbz	r0, 80082c4 <_svfiprintf_r+0x110>
 8008296:	9207      	str	r2, [sp, #28]
 8008298:	e014      	b.n	80082c4 <_svfiprintf_r+0x110>
 800829a:	eba0 0308 	sub.w	r3, r0, r8
 800829e:	fa09 f303 	lsl.w	r3, r9, r3
 80082a2:	4313      	orrs	r3, r2
 80082a4:	9304      	str	r3, [sp, #16]
 80082a6:	46a2      	mov	sl, r4
 80082a8:	e7d2      	b.n	8008250 <_svfiprintf_r+0x9c>
 80082aa:	9b03      	ldr	r3, [sp, #12]
 80082ac:	1d19      	adds	r1, r3, #4
 80082ae:	681b      	ldr	r3, [r3, #0]
 80082b0:	9103      	str	r1, [sp, #12]
 80082b2:	2b00      	cmp	r3, #0
 80082b4:	bfbb      	ittet	lt
 80082b6:	425b      	neglt	r3, r3
 80082b8:	f042 0202 	orrlt.w	r2, r2, #2
 80082bc:	9307      	strge	r3, [sp, #28]
 80082be:	9307      	strlt	r3, [sp, #28]
 80082c0:	bfb8      	it	lt
 80082c2:	9204      	strlt	r2, [sp, #16]
 80082c4:	7823      	ldrb	r3, [r4, #0]
 80082c6:	2b2e      	cmp	r3, #46	; 0x2e
 80082c8:	d10c      	bne.n	80082e4 <_svfiprintf_r+0x130>
 80082ca:	7863      	ldrb	r3, [r4, #1]
 80082cc:	2b2a      	cmp	r3, #42	; 0x2a
 80082ce:	d135      	bne.n	800833c <_svfiprintf_r+0x188>
 80082d0:	9b03      	ldr	r3, [sp, #12]
 80082d2:	1d1a      	adds	r2, r3, #4
 80082d4:	681b      	ldr	r3, [r3, #0]
 80082d6:	9203      	str	r2, [sp, #12]
 80082d8:	2b00      	cmp	r3, #0
 80082da:	bfb8      	it	lt
 80082dc:	f04f 33ff 	movlt.w	r3, #4294967295
 80082e0:	3402      	adds	r4, #2
 80082e2:	9305      	str	r3, [sp, #20]
 80082e4:	f8df a0c8 	ldr.w	sl, [pc, #200]	; 80083b0 <_svfiprintf_r+0x1fc>
 80082e8:	7821      	ldrb	r1, [r4, #0]
 80082ea:	2203      	movs	r2, #3
 80082ec:	4650      	mov	r0, sl
 80082ee:	f7f7 ff77 	bl	80001e0 <memchr>
 80082f2:	b140      	cbz	r0, 8008306 <_svfiprintf_r+0x152>
 80082f4:	2340      	movs	r3, #64	; 0x40
 80082f6:	eba0 000a 	sub.w	r0, r0, sl
 80082fa:	fa03 f000 	lsl.w	r0, r3, r0
 80082fe:	9b04      	ldr	r3, [sp, #16]
 8008300:	4303      	orrs	r3, r0
 8008302:	3401      	adds	r4, #1
 8008304:	9304      	str	r3, [sp, #16]
 8008306:	f814 1b01 	ldrb.w	r1, [r4], #1
 800830a:	4826      	ldr	r0, [pc, #152]	; (80083a4 <_svfiprintf_r+0x1f0>)
 800830c:	f88d 1028 	strb.w	r1, [sp, #40]	; 0x28
 8008310:	2206      	movs	r2, #6
 8008312:	f7f7 ff65 	bl	80001e0 <memchr>
 8008316:	2800      	cmp	r0, #0
 8008318:	d038      	beq.n	800838c <_svfiprintf_r+0x1d8>
 800831a:	4b23      	ldr	r3, [pc, #140]	; (80083a8 <_svfiprintf_r+0x1f4>)
 800831c:	bb1b      	cbnz	r3, 8008366 <_svfiprintf_r+0x1b2>
 800831e:	9b03      	ldr	r3, [sp, #12]
 8008320:	3307      	adds	r3, #7
 8008322:	f023 0307 	bic.w	r3, r3, #7
 8008326:	3308      	adds	r3, #8
 8008328:	9303      	str	r3, [sp, #12]
 800832a:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800832c:	4433      	add	r3, r6
 800832e:	9309      	str	r3, [sp, #36]	; 0x24
 8008330:	e767      	b.n	8008202 <_svfiprintf_r+0x4e>
 8008332:	fb0c 3202 	mla	r2, ip, r2, r3
 8008336:	460c      	mov	r4, r1
 8008338:	2001      	movs	r0, #1
 800833a:	e7a5      	b.n	8008288 <_svfiprintf_r+0xd4>
 800833c:	2300      	movs	r3, #0
 800833e:	3401      	adds	r4, #1
 8008340:	9305      	str	r3, [sp, #20]
 8008342:	4619      	mov	r1, r3
 8008344:	f04f 0c0a 	mov.w	ip, #10
 8008348:	4620      	mov	r0, r4
 800834a:	f810 2b01 	ldrb.w	r2, [r0], #1
 800834e:	3a30      	subs	r2, #48	; 0x30
 8008350:	2a09      	cmp	r2, #9
 8008352:	d903      	bls.n	800835c <_svfiprintf_r+0x1a8>
 8008354:	2b00      	cmp	r3, #0
 8008356:	d0c5      	beq.n	80082e4 <_svfiprintf_r+0x130>
 8008358:	9105      	str	r1, [sp, #20]
 800835a:	e7c3      	b.n	80082e4 <_svfiprintf_r+0x130>
 800835c:	fb0c 2101 	mla	r1, ip, r1, r2
 8008360:	4604      	mov	r4, r0
 8008362:	2301      	movs	r3, #1
 8008364:	e7f0      	b.n	8008348 <_svfiprintf_r+0x194>
 8008366:	ab03      	add	r3, sp, #12
 8008368:	9300      	str	r3, [sp, #0]
 800836a:	462a      	mov	r2, r5
 800836c:	4b0f      	ldr	r3, [pc, #60]	; (80083ac <_svfiprintf_r+0x1f8>)
 800836e:	a904      	add	r1, sp, #16
 8008370:	4638      	mov	r0, r7
 8008372:	f7fe f80d 	bl	8006390 <_printf_float>
 8008376:	1c42      	adds	r2, r0, #1
 8008378:	4606      	mov	r6, r0
 800837a:	d1d6      	bne.n	800832a <_svfiprintf_r+0x176>
 800837c:	89ab      	ldrh	r3, [r5, #12]
 800837e:	065b      	lsls	r3, r3, #25
 8008380:	f53f af2c 	bmi.w	80081dc <_svfiprintf_r+0x28>
 8008384:	9809      	ldr	r0, [sp, #36]	; 0x24
 8008386:	b01d      	add	sp, #116	; 0x74
 8008388:	e8bd 8ff0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, pc}
 800838c:	ab03      	add	r3, sp, #12
 800838e:	9300      	str	r3, [sp, #0]
 8008390:	462a      	mov	r2, r5
 8008392:	4b06      	ldr	r3, [pc, #24]	; (80083ac <_svfiprintf_r+0x1f8>)
 8008394:	a904      	add	r1, sp, #16
 8008396:	4638      	mov	r0, r7
 8008398:	f7fe fa9e 	bl	80068d8 <_printf_i>
 800839c:	e7eb      	b.n	8008376 <_svfiprintf_r+0x1c2>
 800839e:	bf00      	nop
 80083a0:	0800924c 	.word	0x0800924c
 80083a4:	08009256 	.word	0x08009256
 80083a8:	08006391 	.word	0x08006391
 80083ac:	080080fd 	.word	0x080080fd
 80083b0:	08009252 	.word	0x08009252

080083b4 <_sbrk_r>:
 80083b4:	b538      	push	{r3, r4, r5, lr}
 80083b6:	4d06      	ldr	r5, [pc, #24]	; (80083d0 <_sbrk_r+0x1c>)
 80083b8:	2300      	movs	r3, #0
 80083ba:	4604      	mov	r4, r0
 80083bc:	4608      	mov	r0, r1
 80083be:	602b      	str	r3, [r5, #0]
 80083c0:	f7f9 fbe6 	bl	8001b90 <_sbrk>
 80083c4:	1c43      	adds	r3, r0, #1
 80083c6:	d102      	bne.n	80083ce <_sbrk_r+0x1a>
 80083c8:	682b      	ldr	r3, [r5, #0]
 80083ca:	b103      	cbz	r3, 80083ce <_sbrk_r+0x1a>
 80083cc:	6023      	str	r3, [r4, #0]
 80083ce:	bd38      	pop	{r3, r4, r5, pc}
 80083d0:	200003b4 	.word	0x200003b4

080083d4 <__assert_func>:
 80083d4:	b51f      	push	{r0, r1, r2, r3, r4, lr}
 80083d6:	4614      	mov	r4, r2
 80083d8:	461a      	mov	r2, r3
 80083da:	4b09      	ldr	r3, [pc, #36]	; (8008400 <__assert_func+0x2c>)
 80083dc:	681b      	ldr	r3, [r3, #0]
 80083de:	4605      	mov	r5, r0
 80083e0:	68d8      	ldr	r0, [r3, #12]
 80083e2:	b14c      	cbz	r4, 80083f8 <__assert_func+0x24>
 80083e4:	4b07      	ldr	r3, [pc, #28]	; (8008404 <__assert_func+0x30>)
 80083e6:	9100      	str	r1, [sp, #0]
 80083e8:	e9cd 3401 	strd	r3, r4, [sp, #4]
 80083ec:	4906      	ldr	r1, [pc, #24]	; (8008408 <__assert_func+0x34>)
 80083ee:	462b      	mov	r3, r5
 80083f0:	f000 f80e 	bl	8008410 <fiprintf>
 80083f4:	f000 faa4 	bl	8008940 <abort>
 80083f8:	4b04      	ldr	r3, [pc, #16]	; (800840c <__assert_func+0x38>)
 80083fa:	461c      	mov	r4, r3
 80083fc:	e7f3      	b.n	80083e6 <__assert_func+0x12>
 80083fe:	bf00      	nop
 8008400:	2000000c 	.word	0x2000000c
 8008404:	0800925d 	.word	0x0800925d
 8008408:	0800926a 	.word	0x0800926a
 800840c:	08009298 	.word	0x08009298

08008410 <fiprintf>:
 8008410:	b40e      	push	{r1, r2, r3}
 8008412:	b503      	push	{r0, r1, lr}
 8008414:	4601      	mov	r1, r0
 8008416:	ab03      	add	r3, sp, #12
 8008418:	4805      	ldr	r0, [pc, #20]	; (8008430 <fiprintf+0x20>)
 800841a:	f853 2b04 	ldr.w	r2, [r3], #4
 800841e:	6800      	ldr	r0, [r0, #0]
 8008420:	9301      	str	r3, [sp, #4]
 8008422:	f000 f88f 	bl	8008544 <_vfiprintf_r>
 8008426:	b002      	add	sp, #8
 8008428:	f85d eb04 	ldr.w	lr, [sp], #4
 800842c:	b003      	add	sp, #12
 800842e:	4770      	bx	lr
 8008430:	2000000c 	.word	0x2000000c

08008434 <__ascii_mbtowc>:
 8008434:	b082      	sub	sp, #8
 8008436:	b901      	cbnz	r1, 800843a <__ascii_mbtowc+0x6>
 8008438:	a901      	add	r1, sp, #4
 800843a:	b142      	cbz	r2, 800844e <__ascii_mbtowc+0x1a>
 800843c:	b14b      	cbz	r3, 8008452 <__ascii_mbtowc+0x1e>
 800843e:	7813      	ldrb	r3, [r2, #0]
 8008440:	600b      	str	r3, [r1, #0]
 8008442:	7812      	ldrb	r2, [r2, #0]
 8008444:	1e10      	subs	r0, r2, #0
 8008446:	bf18      	it	ne
 8008448:	2001      	movne	r0, #1
 800844a:	b002      	add	sp, #8
 800844c:	4770      	bx	lr
 800844e:	4610      	mov	r0, r2
 8008450:	e7fb      	b.n	800844a <__ascii_mbtowc+0x16>
 8008452:	f06f 0001 	mvn.w	r0, #1
 8008456:	e7f8      	b.n	800844a <__ascii_mbtowc+0x16>

08008458 <memmove>:
 8008458:	4288      	cmp	r0, r1
 800845a:	b510      	push	{r4, lr}
 800845c:	eb01 0402 	add.w	r4, r1, r2
 8008460:	d902      	bls.n	8008468 <memmove+0x10>
 8008462:	4284      	cmp	r4, r0
 8008464:	4623      	mov	r3, r4
 8008466:	d807      	bhi.n	8008478 <memmove+0x20>
 8008468:	1e43      	subs	r3, r0, #1
 800846a:	42a1      	cmp	r1, r4
 800846c:	d008      	beq.n	8008480 <memmove+0x28>
 800846e:	f811 2b01 	ldrb.w	r2, [r1], #1
 8008472:	f803 2f01 	strb.w	r2, [r3, #1]!
 8008476:	e7f8      	b.n	800846a <memmove+0x12>
 8008478:	4402      	add	r2, r0
 800847a:	4601      	mov	r1, r0
 800847c:	428a      	cmp	r2, r1
 800847e:	d100      	bne.n	8008482 <memmove+0x2a>
 8008480:	bd10      	pop	{r4, pc}
 8008482:	f813 4d01 	ldrb.w	r4, [r3, #-1]!
 8008486:	f802 4d01 	strb.w	r4, [r2, #-1]!
 800848a:	e7f7      	b.n	800847c <memmove+0x24>

0800848c <__malloc_lock>:
 800848c:	4801      	ldr	r0, [pc, #4]	; (8008494 <__malloc_lock+0x8>)
 800848e:	f000 bc17 	b.w	8008cc0 <__retarget_lock_acquire_recursive>
 8008492:	bf00      	nop
 8008494:	200003bc 	.word	0x200003bc

08008498 <__malloc_unlock>:
 8008498:	4801      	ldr	r0, [pc, #4]	; (80084a0 <__malloc_unlock+0x8>)
 800849a:	f000 bc12 	b.w	8008cc2 <__retarget_lock_release_recursive>
 800849e:	bf00      	nop
 80084a0:	200003bc 	.word	0x200003bc

080084a4 <_realloc_r>:
 80084a4:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 80084a6:	4607      	mov	r7, r0
 80084a8:	4614      	mov	r4, r2
 80084aa:	460e      	mov	r6, r1
 80084ac:	b921      	cbnz	r1, 80084b8 <_realloc_r+0x14>
 80084ae:	e8bd 40f8 	ldmia.w	sp!, {r3, r4, r5, r6, r7, lr}
 80084b2:	4611      	mov	r1, r2
 80084b4:	f7ff bdc8 	b.w	8008048 <_malloc_r>
 80084b8:	b922      	cbnz	r2, 80084c4 <_realloc_r+0x20>
 80084ba:	f7ff fd75 	bl	8007fa8 <_free_r>
 80084be:	4625      	mov	r5, r4
 80084c0:	4628      	mov	r0, r5
 80084c2:	bdf8      	pop	{r3, r4, r5, r6, r7, pc}
 80084c4:	f000 fc62 	bl	8008d8c <_malloc_usable_size_r>
 80084c8:	42a0      	cmp	r0, r4
 80084ca:	d20f      	bcs.n	80084ec <_realloc_r+0x48>
 80084cc:	4621      	mov	r1, r4
 80084ce:	4638      	mov	r0, r7
 80084d0:	f7ff fdba 	bl	8008048 <_malloc_r>
 80084d4:	4605      	mov	r5, r0
 80084d6:	2800      	cmp	r0, #0
 80084d8:	d0f2      	beq.n	80084c0 <_realloc_r+0x1c>
 80084da:	4631      	mov	r1, r6
 80084dc:	4622      	mov	r2, r4
 80084de:	f7ff f9c7 	bl	8007870 <memcpy>
 80084e2:	4631      	mov	r1, r6
 80084e4:	4638      	mov	r0, r7
 80084e6:	f7ff fd5f 	bl	8007fa8 <_free_r>
 80084ea:	e7e9      	b.n	80084c0 <_realloc_r+0x1c>
 80084ec:	4635      	mov	r5, r6
 80084ee:	e7e7      	b.n	80084c0 <_realloc_r+0x1c>

080084f0 <__sfputc_r>:
 80084f0:	6893      	ldr	r3, [r2, #8]
 80084f2:	3b01      	subs	r3, #1
 80084f4:	2b00      	cmp	r3, #0
 80084f6:	b410      	push	{r4}
 80084f8:	6093      	str	r3, [r2, #8]
 80084fa:	da08      	bge.n	800850e <__sfputc_r+0x1e>
 80084fc:	6994      	ldr	r4, [r2, #24]
 80084fe:	42a3      	cmp	r3, r4
 8008500:	db01      	blt.n	8008506 <__sfputc_r+0x16>
 8008502:	290a      	cmp	r1, #10
 8008504:	d103      	bne.n	800850e <__sfputc_r+0x1e>
 8008506:	f85d 4b04 	ldr.w	r4, [sp], #4
 800850a:	f000 b94b 	b.w	80087a4 <__swbuf_r>
 800850e:	6813      	ldr	r3, [r2, #0]
 8008510:	1c58      	adds	r0, r3, #1
 8008512:	6010      	str	r0, [r2, #0]
 8008514:	7019      	strb	r1, [r3, #0]
 8008516:	4608      	mov	r0, r1
 8008518:	f85d 4b04 	ldr.w	r4, [sp], #4
 800851c:	4770      	bx	lr

0800851e <__sfputs_r>:
 800851e:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 8008520:	4606      	mov	r6, r0
 8008522:	460f      	mov	r7, r1
 8008524:	4614      	mov	r4, r2
 8008526:	18d5      	adds	r5, r2, r3
 8008528:	42ac      	cmp	r4, r5
 800852a:	d101      	bne.n	8008530 <__sfputs_r+0x12>
 800852c:	2000      	movs	r0, #0
 800852e:	e007      	b.n	8008540 <__sfputs_r+0x22>
 8008530:	f814 1b01 	ldrb.w	r1, [r4], #1
 8008534:	463a      	mov	r2, r7
 8008536:	4630      	mov	r0, r6
 8008538:	f7ff ffda 	bl	80084f0 <__sfputc_r>
 800853c:	1c43      	adds	r3, r0, #1
 800853e:	d1f3      	bne.n	8008528 <__sfputs_r+0xa>
 8008540:	bdf8      	pop	{r3, r4, r5, r6, r7, pc}
	...

08008544 <_vfiprintf_r>:
 8008544:	e92d 4ff0 	stmdb	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, lr}
 8008548:	460d      	mov	r5, r1
 800854a:	b09d      	sub	sp, #116	; 0x74
 800854c:	4614      	mov	r4, r2
 800854e:	4698      	mov	r8, r3
 8008550:	4606      	mov	r6, r0
 8008552:	b118      	cbz	r0, 800855c <_vfiprintf_r+0x18>
 8008554:	6983      	ldr	r3, [r0, #24]
 8008556:	b90b      	cbnz	r3, 800855c <_vfiprintf_r+0x18>
 8008558:	f000 fb14 	bl	8008b84 <__sinit>
 800855c:	4b89      	ldr	r3, [pc, #548]	; (8008784 <_vfiprintf_r+0x240>)
 800855e:	429d      	cmp	r5, r3
 8008560:	d11b      	bne.n	800859a <_vfiprintf_r+0x56>
 8008562:	6875      	ldr	r5, [r6, #4]
 8008564:	6e6b      	ldr	r3, [r5, #100]	; 0x64
 8008566:	07d9      	lsls	r1, r3, #31
 8008568:	d405      	bmi.n	8008576 <_vfiprintf_r+0x32>
 800856a:	89ab      	ldrh	r3, [r5, #12]
 800856c:	059a      	lsls	r2, r3, #22
 800856e:	d402      	bmi.n	8008576 <_vfiprintf_r+0x32>
 8008570:	6da8      	ldr	r0, [r5, #88]	; 0x58
 8008572:	f000 fba5 	bl	8008cc0 <__retarget_lock_acquire_recursive>
 8008576:	89ab      	ldrh	r3, [r5, #12]
 8008578:	071b      	lsls	r3, r3, #28
 800857a:	d501      	bpl.n	8008580 <_vfiprintf_r+0x3c>
 800857c:	692b      	ldr	r3, [r5, #16]
 800857e:	b9eb      	cbnz	r3, 80085bc <_vfiprintf_r+0x78>
 8008580:	4629      	mov	r1, r5
 8008582:	4630      	mov	r0, r6
 8008584:	f000 f96e 	bl	8008864 <__swsetup_r>
 8008588:	b1c0      	cbz	r0, 80085bc <_vfiprintf_r+0x78>
 800858a:	6e6b      	ldr	r3, [r5, #100]	; 0x64
 800858c:	07dc      	lsls	r4, r3, #31
 800858e:	d50e      	bpl.n	80085ae <_vfiprintf_r+0x6a>
 8008590:	f04f 30ff 	mov.w	r0, #4294967295
 8008594:	b01d      	add	sp, #116	; 0x74
 8008596:	e8bd 8ff0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, r9, sl, fp, pc}
 800859a:	4b7b      	ldr	r3, [pc, #492]	; (8008788 <_vfiprintf_r+0x244>)
 800859c:	429d      	cmp	r5, r3
 800859e:	d101      	bne.n	80085a4 <_vfiprintf_r+0x60>
 80085a0:	68b5      	ldr	r5, [r6, #8]
 80085a2:	e7df      	b.n	8008564 <_vfiprintf_r+0x20>
 80085a4:	4b79      	ldr	r3, [pc, #484]	; (800878c <_vfiprintf_r+0x248>)
 80085a6:	429d      	cmp	r5, r3
 80085a8:	bf08      	it	eq
 80085aa:	68f5      	ldreq	r5, [r6, #12]
 80085ac:	e7da      	b.n	8008564 <_vfiprintf_r+0x20>
 80085ae:	89ab      	ldrh	r3, [r5, #12]
 80085b0:	0598      	lsls	r0, r3, #22
 80085b2:	d4ed      	bmi.n	8008590 <_vfiprintf_r+0x4c>
 80085b4:	6da8      	ldr	r0, [r5, #88]	; 0x58
 80085b6:	f000 fb84 	bl	8008cc2 <__retarget_lock_release_recursive>
 80085ba:	e7e9      	b.n	8008590 <_vfiprintf_r+0x4c>
 80085bc:	2300      	movs	r3, #0
 80085be:	9309      	str	r3, [sp, #36]	; 0x24
 80085c0:	2320      	movs	r3, #32
 80085c2:	f88d 3029 	strb.w	r3, [sp, #41]	; 0x29
 80085c6:	f8cd 800c 	str.w	r8, [sp, #12]
 80085ca:	2330      	movs	r3, #48	; 0x30
 80085cc:	f8df 81c0 	ldr.w	r8, [pc, #448]	; 8008790 <_vfiprintf_r+0x24c>
 80085d0:	f88d 302a 	strb.w	r3, [sp, #42]	; 0x2a
 80085d4:	f04f 0901 	mov.w	r9, #1
 80085d8:	4623      	mov	r3, r4
 80085da:	469a      	mov	sl, r3
 80085dc:	f813 2b01 	ldrb.w	r2, [r3], #1
 80085e0:	b10a      	cbz	r2, 80085e6 <_vfiprintf_r+0xa2>
 80085e2:	2a25      	cmp	r2, #37	; 0x25
 80085e4:	d1f9      	bne.n	80085da <_vfiprintf_r+0x96>
 80085e6:	ebba 0b04 	subs.w	fp, sl, r4
 80085ea:	d00b      	beq.n	8008604 <_vfiprintf_r+0xc0>
 80085ec:	465b      	mov	r3, fp
 80085ee:	4622      	mov	r2, r4
 80085f0:	4629      	mov	r1, r5
 80085f2:	4630      	mov	r0, r6
 80085f4:	f7ff ff93 	bl	800851e <__sfputs_r>
 80085f8:	3001      	adds	r0, #1
 80085fa:	f000 80aa 	beq.w	8008752 <_vfiprintf_r+0x20e>
 80085fe:	9a09      	ldr	r2, [sp, #36]	; 0x24
 8008600:	445a      	add	r2, fp
 8008602:	9209      	str	r2, [sp, #36]	; 0x24
 8008604:	f89a 3000 	ldrb.w	r3, [sl]
 8008608:	2b00      	cmp	r3, #0
 800860a:	f000 80a2 	beq.w	8008752 <_vfiprintf_r+0x20e>
 800860e:	2300      	movs	r3, #0
 8008610:	f04f 32ff 	mov.w	r2, #4294967295
 8008614:	e9cd 2305 	strd	r2, r3, [sp, #20]
 8008618:	f10a 0a01 	add.w	sl, sl, #1
 800861c:	9304      	str	r3, [sp, #16]
 800861e:	9307      	str	r3, [sp, #28]
 8008620:	f88d 3053 	strb.w	r3, [sp, #83]	; 0x53
 8008624:	931a      	str	r3, [sp, #104]	; 0x68
 8008626:	4654      	mov	r4, sl
 8008628:	2205      	movs	r2, #5
 800862a:	f814 1b01 	ldrb.w	r1, [r4], #1
 800862e:	4858      	ldr	r0, [pc, #352]	; (8008790 <_vfiprintf_r+0x24c>)
 8008630:	f7f7 fdd6 	bl	80001e0 <memchr>
 8008634:	9a04      	ldr	r2, [sp, #16]
 8008636:	b9d8      	cbnz	r0, 8008670 <_vfiprintf_r+0x12c>
 8008638:	06d1      	lsls	r1, r2, #27
 800863a:	bf44      	itt	mi
 800863c:	2320      	movmi	r3, #32
 800863e:	f88d 3053 	strbmi.w	r3, [sp, #83]	; 0x53
 8008642:	0713      	lsls	r3, r2, #28
 8008644:	bf44      	itt	mi
 8008646:	232b      	movmi	r3, #43	; 0x2b
 8008648:	f88d 3053 	strbmi.w	r3, [sp, #83]	; 0x53
 800864c:	f89a 3000 	ldrb.w	r3, [sl]
 8008650:	2b2a      	cmp	r3, #42	; 0x2a
 8008652:	d015      	beq.n	8008680 <_vfiprintf_r+0x13c>
 8008654:	9a07      	ldr	r2, [sp, #28]
 8008656:	4654      	mov	r4, sl
 8008658:	2000      	movs	r0, #0
 800865a:	f04f 0c0a 	mov.w	ip, #10
 800865e:	4621      	mov	r1, r4
 8008660:	f811 3b01 	ldrb.w	r3, [r1], #1
 8008664:	3b30      	subs	r3, #48	; 0x30
 8008666:	2b09      	cmp	r3, #9
 8008668:	d94e      	bls.n	8008708 <_vfiprintf_r+0x1c4>
 800866a:	b1b0      	cbz	r0, 800869a <_vfiprintf_r+0x156>
 800866c:	9207      	str	r2, [sp, #28]
 800866e:	e014      	b.n	800869a <_vfiprintf_r+0x156>
 8008670:	eba0 0308 	sub.w	r3, r0, r8
 8008674:	fa09 f303 	lsl.w	r3, r9, r3
 8008678:	4313      	orrs	r3, r2
 800867a:	9304      	str	r3, [sp, #16]
 800867c:	46a2      	mov	sl, r4
 800867e:	e7d2      	b.n	8008626 <_vfiprintf_r+0xe2>
 8008680:	9b03      	ldr	r3, [sp, #12]
 8008682:	1d19      	adds	r1, r3, #4
 8008684:	681b      	ldr	r3, [r3, #0]
 8008686:	9103      	str	r1, [sp, #12]
 8008688:	2b00      	cmp	r3, #0
 800868a:	bfbb      	ittet	lt
 800868c:	425b      	neglt	r3, r3
 800868e:	f042 0202 	orrlt.w	r2, r2, #2
 8008692:	9307      	strge	r3, [sp, #28]
 8008694:	9307      	strlt	r3, [sp, #28]
 8008696:	bfb8      	it	lt
 8008698:	9204      	strlt	r2, [sp, #16]
 800869a:	7823      	ldrb	r3, [r4, #0]
 800869c:	2b2e      	cmp	r3, #46	; 0x2e
 800869e:	d10c      	bne.n	80086ba <_vfiprintf_r+0x176>
 80086a0:	7863      	ldrb	r3, [r4, #1]
 80086a2:	2b2a      	cmp	r3, #42	; 0x2a
 80086a4:	d135      	bne.n	8008712 <_vfiprintf_r+0x1ce>
 80086a6:	9b03      	ldr	r3, [sp, #12]
 80086a8:	1d1a      	adds	r2, r3, #4
 80086aa:	681b      	ldr	r3, [r3, #0]
 80086ac:	9203      	str	r2, [sp, #12]
 80086ae:	2b00      	cmp	r3, #0
 80086b0:	bfb8      	it	lt
 80086b2:	f04f 33ff 	movlt.w	r3, #4294967295
 80086b6:	3402      	adds	r4, #2
 80086b8:	9305      	str	r3, [sp, #20]
 80086ba:	f8df a0e4 	ldr.w	sl, [pc, #228]	; 80087a0 <_vfiprintf_r+0x25c>
 80086be:	7821      	ldrb	r1, [r4, #0]
 80086c0:	2203      	movs	r2, #3
 80086c2:	4650      	mov	r0, sl
 80086c4:	f7f7 fd8c 	bl	80001e0 <memchr>
 80086c8:	b140      	cbz	r0, 80086dc <_vfiprintf_r+0x198>
 80086ca:	2340      	movs	r3, #64	; 0x40
 80086cc:	eba0 000a 	sub.w	r0, r0, sl
 80086d0:	fa03 f000 	lsl.w	r0, r3, r0
 80086d4:	9b04      	ldr	r3, [sp, #16]
 80086d6:	4303      	orrs	r3, r0
 80086d8:	3401      	adds	r4, #1
 80086da:	9304      	str	r3, [sp, #16]
 80086dc:	f814 1b01 	ldrb.w	r1, [r4], #1
 80086e0:	482c      	ldr	r0, [pc, #176]	; (8008794 <_vfiprintf_r+0x250>)
 80086e2:	f88d 1028 	strb.w	r1, [sp, #40]	; 0x28
 80086e6:	2206      	movs	r2, #6
 80086e8:	f7f7 fd7a 	bl	80001e0 <memchr>
 80086ec:	2800      	cmp	r0, #0
 80086ee:	d03f      	beq.n	8008770 <_vfiprintf_r+0x22c>
 80086f0:	4b29      	ldr	r3, [pc, #164]	; (8008798 <_vfiprintf_r+0x254>)
 80086f2:	bb1b      	cbnz	r3, 800873c <_vfiprintf_r+0x1f8>
 80086f4:	9b03      	ldr	r3, [sp, #12]
 80086f6:	3307      	adds	r3, #7
 80086f8:	f023 0307 	bic.w	r3, r3, #7
 80086fc:	3308      	adds	r3, #8
 80086fe:	9303      	str	r3, [sp, #12]
 8008700:	9b09      	ldr	r3, [sp, #36]	; 0x24
 8008702:	443b      	add	r3, r7
 8008704:	9309      	str	r3, [sp, #36]	; 0x24
 8008706:	e767      	b.n	80085d8 <_vfiprintf_r+0x94>
 8008708:	fb0c 3202 	mla	r2, ip, r2, r3
 800870c:	460c      	mov	r4, r1
 800870e:	2001      	movs	r0, #1
 8008710:	e7a5      	b.n	800865e <_vfiprintf_r+0x11a>
 8008712:	2300      	movs	r3, #0
 8008714:	3401      	adds	r4, #1
 8008716:	9305      	str	r3, [sp, #20]
 8008718:	4619      	mov	r1, r3
 800871a:	f04f 0c0a 	mov.w	ip, #10
 800871e:	4620      	mov	r0, r4
 8008720:	f810 2b01 	ldrb.w	r2, [r0], #1
 8008724:	3a30      	subs	r2, #48	; 0x30
 8008726:	2a09      	cmp	r2, #9
 8008728:	d903      	bls.n	8008732 <_vfiprintf_r+0x1ee>
 800872a:	2b00      	cmp	r3, #0
 800872c:	d0c5      	beq.n	80086ba <_vfiprintf_r+0x176>
 800872e:	9105      	str	r1, [sp, #20]
 8008730:	e7c3      	b.n	80086ba <_vfiprintf_r+0x176>
 8008732:	fb0c 2101 	mla	r1, ip, r1, r2
 8008736:	4604      	mov	r4, r0
 8008738:	2301      	movs	r3, #1
 800873a:	e7f0      	b.n	800871e <_vfiprintf_r+0x1da>
 800873c:	ab03      	add	r3, sp, #12
 800873e:	9300      	str	r3, [sp, #0]
 8008740:	462a      	mov	r2, r5
 8008742:	4b16      	ldr	r3, [pc, #88]	; (800879c <_vfiprintf_r+0x258>)
 8008744:	a904      	add	r1, sp, #16
 8008746:	4630      	mov	r0, r6
 8008748:	f7fd fe22 	bl	8006390 <_printf_float>
 800874c:	4607      	mov	r7, r0
 800874e:	1c78      	adds	r0, r7, #1
 8008750:	d1d6      	bne.n	8008700 <_vfiprintf_r+0x1bc>
 8008752:	6e6b      	ldr	r3, [r5, #100]	; 0x64
 8008754:	07d9      	lsls	r1, r3, #31
 8008756:	d405      	bmi.n	8008764 <_vfiprintf_r+0x220>
 8008758:	89ab      	ldrh	r3, [r5, #12]
 800875a:	059a      	lsls	r2, r3, #22
 800875c:	d402      	bmi.n	8008764 <_vfiprintf_r+0x220>
 800875e:	6da8      	ldr	r0, [r5, #88]	; 0x58
 8008760:	f000 faaf 	bl	8008cc2 <__retarget_lock_release_recursive>
 8008764:	89ab      	ldrh	r3, [r5, #12]
 8008766:	065b      	lsls	r3, r3, #25
 8008768:	f53f af12 	bmi.w	8008590 <_vfiprintf_r+0x4c>
 800876c:	9809      	ldr	r0, [sp, #36]	; 0x24
 800876e:	e711      	b.n	8008594 <_vfiprintf_r+0x50>
 8008770:	ab03      	add	r3, sp, #12
 8008772:	9300      	str	r3, [sp, #0]
 8008774:	462a      	mov	r2, r5
 8008776:	4b09      	ldr	r3, [pc, #36]	; (800879c <_vfiprintf_r+0x258>)
 8008778:	a904      	add	r1, sp, #16
 800877a:	4630      	mov	r0, r6
 800877c:	f7fe f8ac 	bl	80068d8 <_printf_i>
 8008780:	e7e4      	b.n	800874c <_vfiprintf_r+0x208>
 8008782:	bf00      	nop
 8008784:	080093c4 	.word	0x080093c4
 8008788:	080093e4 	.word	0x080093e4
 800878c:	080093a4 	.word	0x080093a4
 8008790:	0800924c 	.word	0x0800924c
 8008794:	08009256 	.word	0x08009256
 8008798:	08006391 	.word	0x08006391
 800879c:	0800851f 	.word	0x0800851f
 80087a0:	08009252 	.word	0x08009252

080087a4 <__swbuf_r>:
 80087a4:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 80087a6:	460e      	mov	r6, r1
 80087a8:	4614      	mov	r4, r2
 80087aa:	4605      	mov	r5, r0
 80087ac:	b118      	cbz	r0, 80087b6 <__swbuf_r+0x12>
 80087ae:	6983      	ldr	r3, [r0, #24]
 80087b0:	b90b      	cbnz	r3, 80087b6 <__swbuf_r+0x12>
 80087b2:	f000 f9e7 	bl	8008b84 <__sinit>
 80087b6:	4b21      	ldr	r3, [pc, #132]	; (800883c <__swbuf_r+0x98>)
 80087b8:	429c      	cmp	r4, r3
 80087ba:	d12b      	bne.n	8008814 <__swbuf_r+0x70>
 80087bc:	686c      	ldr	r4, [r5, #4]
 80087be:	69a3      	ldr	r3, [r4, #24]
 80087c0:	60a3      	str	r3, [r4, #8]
 80087c2:	89a3      	ldrh	r3, [r4, #12]
 80087c4:	071a      	lsls	r2, r3, #28
 80087c6:	d52f      	bpl.n	8008828 <__swbuf_r+0x84>
 80087c8:	6923      	ldr	r3, [r4, #16]
 80087ca:	b36b      	cbz	r3, 8008828 <__swbuf_r+0x84>
 80087cc:	6923      	ldr	r3, [r4, #16]
 80087ce:	6820      	ldr	r0, [r4, #0]
 80087d0:	1ac0      	subs	r0, r0, r3
 80087d2:	6963      	ldr	r3, [r4, #20]
 80087d4:	b2f6      	uxtb	r6, r6
 80087d6:	4283      	cmp	r3, r0
 80087d8:	4637      	mov	r7, r6
 80087da:	dc04      	bgt.n	80087e6 <__swbuf_r+0x42>
 80087dc:	4621      	mov	r1, r4
 80087de:	4628      	mov	r0, r5
 80087e0:	f000 f93c 	bl	8008a5c <_fflush_r>
 80087e4:	bb30      	cbnz	r0, 8008834 <__swbuf_r+0x90>
 80087e6:	68a3      	ldr	r3, [r4, #8]
 80087e8:	3b01      	subs	r3, #1
 80087ea:	60a3      	str	r3, [r4, #8]
 80087ec:	6823      	ldr	r3, [r4, #0]
 80087ee:	1c5a      	adds	r2, r3, #1
 80087f0:	6022      	str	r2, [r4, #0]
 80087f2:	701e      	strb	r6, [r3, #0]
 80087f4:	6963      	ldr	r3, [r4, #20]
 80087f6:	3001      	adds	r0, #1
 80087f8:	4283      	cmp	r3, r0
 80087fa:	d004      	beq.n	8008806 <__swbuf_r+0x62>
 80087fc:	89a3      	ldrh	r3, [r4, #12]
 80087fe:	07db      	lsls	r3, r3, #31
 8008800:	d506      	bpl.n	8008810 <__swbuf_r+0x6c>
 8008802:	2e0a      	cmp	r6, #10
 8008804:	d104      	bne.n	8008810 <__swbuf_r+0x6c>
 8008806:	4621      	mov	r1, r4
 8008808:	4628      	mov	r0, r5
 800880a:	f000 f927 	bl	8008a5c <_fflush_r>
 800880e:	b988      	cbnz	r0, 8008834 <__swbuf_r+0x90>
 8008810:	4638      	mov	r0, r7
 8008812:	bdf8      	pop	{r3, r4, r5, r6, r7, pc}
 8008814:	4b0a      	ldr	r3, [pc, #40]	; (8008840 <__swbuf_r+0x9c>)
 8008816:	429c      	cmp	r4, r3
 8008818:	d101      	bne.n	800881e <__swbuf_r+0x7a>
 800881a:	68ac      	ldr	r4, [r5, #8]
 800881c:	e7cf      	b.n	80087be <__swbuf_r+0x1a>
 800881e:	4b09      	ldr	r3, [pc, #36]	; (8008844 <__swbuf_r+0xa0>)
 8008820:	429c      	cmp	r4, r3
 8008822:	bf08      	it	eq
 8008824:	68ec      	ldreq	r4, [r5, #12]
 8008826:	e7ca      	b.n	80087be <__swbuf_r+0x1a>
 8008828:	4621      	mov	r1, r4
 800882a:	4628      	mov	r0, r5
 800882c:	f000 f81a 	bl	8008864 <__swsetup_r>
 8008830:	2800      	cmp	r0, #0
 8008832:	d0cb      	beq.n	80087cc <__swbuf_r+0x28>
 8008834:	f04f 37ff 	mov.w	r7, #4294967295
 8008838:	e7ea      	b.n	8008810 <__swbuf_r+0x6c>
 800883a:	bf00      	nop
 800883c:	080093c4 	.word	0x080093c4
 8008840:	080093e4 	.word	0x080093e4
 8008844:	080093a4 	.word	0x080093a4

08008848 <__ascii_wctomb>:
 8008848:	b149      	cbz	r1, 800885e <__ascii_wctomb+0x16>
 800884a:	2aff      	cmp	r2, #255	; 0xff
 800884c:	bf85      	ittet	hi
 800884e:	238a      	movhi	r3, #138	; 0x8a
 8008850:	6003      	strhi	r3, [r0, #0]
 8008852:	700a      	strbls	r2, [r1, #0]
 8008854:	f04f 30ff 	movhi.w	r0, #4294967295
 8008858:	bf98      	it	ls
 800885a:	2001      	movls	r0, #1
 800885c:	4770      	bx	lr
 800885e:	4608      	mov	r0, r1
 8008860:	4770      	bx	lr
	...

08008864 <__swsetup_r>:
 8008864:	4b32      	ldr	r3, [pc, #200]	; (8008930 <__swsetup_r+0xcc>)
 8008866:	b570      	push	{r4, r5, r6, lr}
 8008868:	681d      	ldr	r5, [r3, #0]
 800886a:	4606      	mov	r6, r0
 800886c:	460c      	mov	r4, r1
 800886e:	b125      	cbz	r5, 800887a <__swsetup_r+0x16>
 8008870:	69ab      	ldr	r3, [r5, #24]
 8008872:	b913      	cbnz	r3, 800887a <__swsetup_r+0x16>
 8008874:	4628      	mov	r0, r5
 8008876:	f000 f985 	bl	8008b84 <__sinit>
 800887a:	4b2e      	ldr	r3, [pc, #184]	; (8008934 <__swsetup_r+0xd0>)
 800887c:	429c      	cmp	r4, r3
 800887e:	d10f      	bne.n	80088a0 <__swsetup_r+0x3c>
 8008880:	686c      	ldr	r4, [r5, #4]
 8008882:	89a3      	ldrh	r3, [r4, #12]
 8008884:	f9b4 200c 	ldrsh.w	r2, [r4, #12]
 8008888:	0719      	lsls	r1, r3, #28
 800888a:	d42c      	bmi.n	80088e6 <__swsetup_r+0x82>
 800888c:	06dd      	lsls	r5, r3, #27
 800888e:	d411      	bmi.n	80088b4 <__swsetup_r+0x50>
 8008890:	2309      	movs	r3, #9
 8008892:	6033      	str	r3, [r6, #0]
 8008894:	f042 0340 	orr.w	r3, r2, #64	; 0x40
 8008898:	81a3      	strh	r3, [r4, #12]
 800889a:	f04f 30ff 	mov.w	r0, #4294967295
 800889e:	e03e      	b.n	800891e <__swsetup_r+0xba>
 80088a0:	4b25      	ldr	r3, [pc, #148]	; (8008938 <__swsetup_r+0xd4>)
 80088a2:	429c      	cmp	r4, r3
 80088a4:	d101      	bne.n	80088aa <__swsetup_r+0x46>
 80088a6:	68ac      	ldr	r4, [r5, #8]
 80088a8:	e7eb      	b.n	8008882 <__swsetup_r+0x1e>
 80088aa:	4b24      	ldr	r3, [pc, #144]	; (800893c <__swsetup_r+0xd8>)
 80088ac:	429c      	cmp	r4, r3
 80088ae:	bf08      	it	eq
 80088b0:	68ec      	ldreq	r4, [r5, #12]
 80088b2:	e7e6      	b.n	8008882 <__swsetup_r+0x1e>
 80088b4:	0758      	lsls	r0, r3, #29
 80088b6:	d512      	bpl.n	80088de <__swsetup_r+0x7a>
 80088b8:	6b61      	ldr	r1, [r4, #52]	; 0x34
 80088ba:	b141      	cbz	r1, 80088ce <__swsetup_r+0x6a>
 80088bc:	f104 0344 	add.w	r3, r4, #68	; 0x44
 80088c0:	4299      	cmp	r1, r3
 80088c2:	d002      	beq.n	80088ca <__swsetup_r+0x66>
 80088c4:	4630      	mov	r0, r6
 80088c6:	f7ff fb6f 	bl	8007fa8 <_free_r>
 80088ca:	2300      	movs	r3, #0
 80088cc:	6363      	str	r3, [r4, #52]	; 0x34
 80088ce:	89a3      	ldrh	r3, [r4, #12]
 80088d0:	f023 0324 	bic.w	r3, r3, #36	; 0x24
 80088d4:	81a3      	strh	r3, [r4, #12]
 80088d6:	2300      	movs	r3, #0
 80088d8:	6063      	str	r3, [r4, #4]
 80088da:	6923      	ldr	r3, [r4, #16]
 80088dc:	6023      	str	r3, [r4, #0]
 80088de:	89a3      	ldrh	r3, [r4, #12]
 80088e0:	f043 0308 	orr.w	r3, r3, #8
 80088e4:	81a3      	strh	r3, [r4, #12]
 80088e6:	6923      	ldr	r3, [r4, #16]
 80088e8:	b94b      	cbnz	r3, 80088fe <__swsetup_r+0x9a>
 80088ea:	89a3      	ldrh	r3, [r4, #12]
 80088ec:	f403 7320 	and.w	r3, r3, #640	; 0x280
 80088f0:	f5b3 7f00 	cmp.w	r3, #512	; 0x200
 80088f4:	d003      	beq.n	80088fe <__swsetup_r+0x9a>
 80088f6:	4621      	mov	r1, r4
 80088f8:	4630      	mov	r0, r6
 80088fa:	f000 fa07 	bl	8008d0c <__smakebuf_r>
 80088fe:	89a0      	ldrh	r0, [r4, #12]
 8008900:	f9b4 200c 	ldrsh.w	r2, [r4, #12]
 8008904:	f010 0301 	ands.w	r3, r0, #1
 8008908:	d00a      	beq.n	8008920 <__swsetup_r+0xbc>
 800890a:	2300      	movs	r3, #0
 800890c:	60a3      	str	r3, [r4, #8]
 800890e:	6963      	ldr	r3, [r4, #20]
 8008910:	425b      	negs	r3, r3
 8008912:	61a3      	str	r3, [r4, #24]
 8008914:	6923      	ldr	r3, [r4, #16]
 8008916:	b943      	cbnz	r3, 800892a <__swsetup_r+0xc6>
 8008918:	f010 0080 	ands.w	r0, r0, #128	; 0x80
 800891c:	d1ba      	bne.n	8008894 <__swsetup_r+0x30>
 800891e:	bd70      	pop	{r4, r5, r6, pc}
 8008920:	0781      	lsls	r1, r0, #30
 8008922:	bf58      	it	pl
 8008924:	6963      	ldrpl	r3, [r4, #20]
 8008926:	60a3      	str	r3, [r4, #8]
 8008928:	e7f4      	b.n	8008914 <__swsetup_r+0xb0>
 800892a:	2000      	movs	r0, #0
 800892c:	e7f7      	b.n	800891e <__swsetup_r+0xba>
 800892e:	bf00      	nop
 8008930:	2000000c 	.word	0x2000000c
 8008934:	080093c4 	.word	0x080093c4
 8008938:	080093e4 	.word	0x080093e4
 800893c:	080093a4 	.word	0x080093a4

08008940 <abort>:
 8008940:	b508      	push	{r3, lr}
 8008942:	2006      	movs	r0, #6
 8008944:	f000 fa52 	bl	8008dec <raise>
 8008948:	2001      	movs	r0, #1
 800894a:	f7f9 f8a9 	bl	8001aa0 <_exit>
	...

08008950 <__sflush_r>:
 8008950:	898a      	ldrh	r2, [r1, #12]
 8008952:	e92d 41f0 	stmdb	sp!, {r4, r5, r6, r7, r8, lr}
 8008956:	4605      	mov	r5, r0
 8008958:	0710      	lsls	r0, r2, #28
 800895a:	460c      	mov	r4, r1
 800895c:	d458      	bmi.n	8008a10 <__sflush_r+0xc0>
 800895e:	684b      	ldr	r3, [r1, #4]
 8008960:	2b00      	cmp	r3, #0
 8008962:	dc05      	bgt.n	8008970 <__sflush_r+0x20>
 8008964:	6c0b      	ldr	r3, [r1, #64]	; 0x40
 8008966:	2b00      	cmp	r3, #0
 8008968:	dc02      	bgt.n	8008970 <__sflush_r+0x20>
 800896a:	2000      	movs	r0, #0
 800896c:	e8bd 81f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, pc}
 8008970:	6ae6      	ldr	r6, [r4, #44]	; 0x2c
 8008972:	2e00      	cmp	r6, #0
 8008974:	d0f9      	beq.n	800896a <__sflush_r+0x1a>
 8008976:	2300      	movs	r3, #0
 8008978:	f412 5280 	ands.w	r2, r2, #4096	; 0x1000
 800897c:	682f      	ldr	r7, [r5, #0]
 800897e:	602b      	str	r3, [r5, #0]
 8008980:	d032      	beq.n	80089e8 <__sflush_r+0x98>
 8008982:	6d60      	ldr	r0, [r4, #84]	; 0x54
 8008984:	89a3      	ldrh	r3, [r4, #12]
 8008986:	075a      	lsls	r2, r3, #29
 8008988:	d505      	bpl.n	8008996 <__sflush_r+0x46>
 800898a:	6863      	ldr	r3, [r4, #4]
 800898c:	1ac0      	subs	r0, r0, r3
 800898e:	6b63      	ldr	r3, [r4, #52]	; 0x34
 8008990:	b10b      	cbz	r3, 8008996 <__sflush_r+0x46>
 8008992:	6c23      	ldr	r3, [r4, #64]	; 0x40
 8008994:	1ac0      	subs	r0, r0, r3
 8008996:	2300      	movs	r3, #0
 8008998:	4602      	mov	r2, r0
 800899a:	6ae6      	ldr	r6, [r4, #44]	; 0x2c
 800899c:	6a21      	ldr	r1, [r4, #32]
 800899e:	4628      	mov	r0, r5
 80089a0:	47b0      	blx	r6
 80089a2:	1c43      	adds	r3, r0, #1
 80089a4:	89a3      	ldrh	r3, [r4, #12]
 80089a6:	d106      	bne.n	80089b6 <__sflush_r+0x66>
 80089a8:	6829      	ldr	r1, [r5, #0]
 80089aa:	291d      	cmp	r1, #29
 80089ac:	d82c      	bhi.n	8008a08 <__sflush_r+0xb8>
 80089ae:	4a2a      	ldr	r2, [pc, #168]	; (8008a58 <__sflush_r+0x108>)
 80089b0:	40ca      	lsrs	r2, r1
 80089b2:	07d6      	lsls	r6, r2, #31
 80089b4:	d528      	bpl.n	8008a08 <__sflush_r+0xb8>
 80089b6:	2200      	movs	r2, #0
 80089b8:	6062      	str	r2, [r4, #4]
 80089ba:	04d9      	lsls	r1, r3, #19
 80089bc:	6922      	ldr	r2, [r4, #16]
 80089be:	6022      	str	r2, [r4, #0]
 80089c0:	d504      	bpl.n	80089cc <__sflush_r+0x7c>
 80089c2:	1c42      	adds	r2, r0, #1
 80089c4:	d101      	bne.n	80089ca <__sflush_r+0x7a>
 80089c6:	682b      	ldr	r3, [r5, #0]
 80089c8:	b903      	cbnz	r3, 80089cc <__sflush_r+0x7c>
 80089ca:	6560      	str	r0, [r4, #84]	; 0x54
 80089cc:	6b61      	ldr	r1, [r4, #52]	; 0x34
 80089ce:	602f      	str	r7, [r5, #0]
 80089d0:	2900      	cmp	r1, #0
 80089d2:	d0ca      	beq.n	800896a <__sflush_r+0x1a>
 80089d4:	f104 0344 	add.w	r3, r4, #68	; 0x44
 80089d8:	4299      	cmp	r1, r3
 80089da:	d002      	beq.n	80089e2 <__sflush_r+0x92>
 80089dc:	4628      	mov	r0, r5
 80089de:	f7ff fae3 	bl	8007fa8 <_free_r>
 80089e2:	2000      	movs	r0, #0
 80089e4:	6360      	str	r0, [r4, #52]	; 0x34
 80089e6:	e7c1      	b.n	800896c <__sflush_r+0x1c>
 80089e8:	6a21      	ldr	r1, [r4, #32]
 80089ea:	2301      	movs	r3, #1
 80089ec:	4628      	mov	r0, r5
 80089ee:	47b0      	blx	r6
 80089f0:	1c41      	adds	r1, r0, #1
 80089f2:	d1c7      	bne.n	8008984 <__sflush_r+0x34>
 80089f4:	682b      	ldr	r3, [r5, #0]
 80089f6:	2b00      	cmp	r3, #0
 80089f8:	d0c4      	beq.n	8008984 <__sflush_r+0x34>
 80089fa:	2b1d      	cmp	r3, #29
 80089fc:	d001      	beq.n	8008a02 <__sflush_r+0xb2>
 80089fe:	2b16      	cmp	r3, #22
 8008a00:	d101      	bne.n	8008a06 <__sflush_r+0xb6>
 8008a02:	602f      	str	r7, [r5, #0]
 8008a04:	e7b1      	b.n	800896a <__sflush_r+0x1a>
 8008a06:	89a3      	ldrh	r3, [r4, #12]
 8008a08:	f043 0340 	orr.w	r3, r3, #64	; 0x40
 8008a0c:	81a3      	strh	r3, [r4, #12]
 8008a0e:	e7ad      	b.n	800896c <__sflush_r+0x1c>
 8008a10:	690f      	ldr	r7, [r1, #16]
 8008a12:	2f00      	cmp	r7, #0
 8008a14:	d0a9      	beq.n	800896a <__sflush_r+0x1a>
 8008a16:	0793      	lsls	r3, r2, #30
 8008a18:	680e      	ldr	r6, [r1, #0]
 8008a1a:	bf08      	it	eq
 8008a1c:	694b      	ldreq	r3, [r1, #20]
 8008a1e:	600f      	str	r7, [r1, #0]
 8008a20:	bf18      	it	ne
 8008a22:	2300      	movne	r3, #0
 8008a24:	eba6 0807 	sub.w	r8, r6, r7
 8008a28:	608b      	str	r3, [r1, #8]
 8008a2a:	f1b8 0f00 	cmp.w	r8, #0
 8008a2e:	dd9c      	ble.n	800896a <__sflush_r+0x1a>
 8008a30:	6a21      	ldr	r1, [r4, #32]
 8008a32:	6aa6      	ldr	r6, [r4, #40]	; 0x28
 8008a34:	4643      	mov	r3, r8
 8008a36:	463a      	mov	r2, r7
 8008a38:	4628      	mov	r0, r5
 8008a3a:	47b0      	blx	r6
 8008a3c:	2800      	cmp	r0, #0
 8008a3e:	dc06      	bgt.n	8008a4e <__sflush_r+0xfe>
 8008a40:	89a3      	ldrh	r3, [r4, #12]
 8008a42:	f043 0340 	orr.w	r3, r3, #64	; 0x40
 8008a46:	81a3      	strh	r3, [r4, #12]
 8008a48:	f04f 30ff 	mov.w	r0, #4294967295
 8008a4c:	e78e      	b.n	800896c <__sflush_r+0x1c>
 8008a4e:	4407      	add	r7, r0
 8008a50:	eba8 0800 	sub.w	r8, r8, r0
 8008a54:	e7e9      	b.n	8008a2a <__sflush_r+0xda>
 8008a56:	bf00      	nop
 8008a58:	20400001 	.word	0x20400001

08008a5c <_fflush_r>:
 8008a5c:	b538      	push	{r3, r4, r5, lr}
 8008a5e:	690b      	ldr	r3, [r1, #16]
 8008a60:	4605      	mov	r5, r0
 8008a62:	460c      	mov	r4, r1
 8008a64:	b913      	cbnz	r3, 8008a6c <_fflush_r+0x10>
 8008a66:	2500      	movs	r5, #0
 8008a68:	4628      	mov	r0, r5
 8008a6a:	bd38      	pop	{r3, r4, r5, pc}
 8008a6c:	b118      	cbz	r0, 8008a76 <_fflush_r+0x1a>
 8008a6e:	6983      	ldr	r3, [r0, #24]
 8008a70:	b90b      	cbnz	r3, 8008a76 <_fflush_r+0x1a>
 8008a72:	f000 f887 	bl	8008b84 <__sinit>
 8008a76:	4b14      	ldr	r3, [pc, #80]	; (8008ac8 <_fflush_r+0x6c>)
 8008a78:	429c      	cmp	r4, r3
 8008a7a:	d11b      	bne.n	8008ab4 <_fflush_r+0x58>
 8008a7c:	686c      	ldr	r4, [r5, #4]
 8008a7e:	f9b4 300c 	ldrsh.w	r3, [r4, #12]
 8008a82:	2b00      	cmp	r3, #0
 8008a84:	d0ef      	beq.n	8008a66 <_fflush_r+0xa>
 8008a86:	6e62      	ldr	r2, [r4, #100]	; 0x64
 8008a88:	07d0      	lsls	r0, r2, #31
 8008a8a:	d404      	bmi.n	8008a96 <_fflush_r+0x3a>
 8008a8c:	0599      	lsls	r1, r3, #22
 8008a8e:	d402      	bmi.n	8008a96 <_fflush_r+0x3a>
 8008a90:	6da0      	ldr	r0, [r4, #88]	; 0x58
 8008a92:	f000 f915 	bl	8008cc0 <__retarget_lock_acquire_recursive>
 8008a96:	4628      	mov	r0, r5
 8008a98:	4621      	mov	r1, r4
 8008a9a:	f7ff ff59 	bl	8008950 <__sflush_r>
 8008a9e:	6e63      	ldr	r3, [r4, #100]	; 0x64
 8008aa0:	07da      	lsls	r2, r3, #31
 8008aa2:	4605      	mov	r5, r0
 8008aa4:	d4e0      	bmi.n	8008a68 <_fflush_r+0xc>
 8008aa6:	89a3      	ldrh	r3, [r4, #12]
 8008aa8:	059b      	lsls	r3, r3, #22
 8008aaa:	d4dd      	bmi.n	8008a68 <_fflush_r+0xc>
 8008aac:	6da0      	ldr	r0, [r4, #88]	; 0x58
 8008aae:	f000 f908 	bl	8008cc2 <__retarget_lock_release_recursive>
 8008ab2:	e7d9      	b.n	8008a68 <_fflush_r+0xc>
 8008ab4:	4b05      	ldr	r3, [pc, #20]	; (8008acc <_fflush_r+0x70>)
 8008ab6:	429c      	cmp	r4, r3
 8008ab8:	d101      	bne.n	8008abe <_fflush_r+0x62>
 8008aba:	68ac      	ldr	r4, [r5, #8]
 8008abc:	e7df      	b.n	8008a7e <_fflush_r+0x22>
 8008abe:	4b04      	ldr	r3, [pc, #16]	; (8008ad0 <_fflush_r+0x74>)
 8008ac0:	429c      	cmp	r4, r3
 8008ac2:	bf08      	it	eq
 8008ac4:	68ec      	ldreq	r4, [r5, #12]
 8008ac6:	e7da      	b.n	8008a7e <_fflush_r+0x22>
 8008ac8:	080093c4 	.word	0x080093c4
 8008acc:	080093e4 	.word	0x080093e4
 8008ad0:	080093a4 	.word	0x080093a4

08008ad4 <std>:
 8008ad4:	2300      	movs	r3, #0
 8008ad6:	b510      	push	{r4, lr}
 8008ad8:	4604      	mov	r4, r0
 8008ada:	e9c0 3300 	strd	r3, r3, [r0]
 8008ade:	e9c0 3304 	strd	r3, r3, [r0, #16]
 8008ae2:	6083      	str	r3, [r0, #8]
 8008ae4:	8181      	strh	r1, [r0, #12]
 8008ae6:	6643      	str	r3, [r0, #100]	; 0x64
 8008ae8:	81c2      	strh	r2, [r0, #14]
 8008aea:	6183      	str	r3, [r0, #24]
 8008aec:	4619      	mov	r1, r3
 8008aee:	2208      	movs	r2, #8
 8008af0:	305c      	adds	r0, #92	; 0x5c
 8008af2:	f7fd fba5 	bl	8006240 <memset>
 8008af6:	4b05      	ldr	r3, [pc, #20]	; (8008b0c <std+0x38>)
 8008af8:	6263      	str	r3, [r4, #36]	; 0x24
 8008afa:	4b05      	ldr	r3, [pc, #20]	; (8008b10 <std+0x3c>)
 8008afc:	62a3      	str	r3, [r4, #40]	; 0x28
 8008afe:	4b05      	ldr	r3, [pc, #20]	; (8008b14 <std+0x40>)
 8008b00:	62e3      	str	r3, [r4, #44]	; 0x2c
 8008b02:	4b05      	ldr	r3, [pc, #20]	; (8008b18 <std+0x44>)
 8008b04:	6224      	str	r4, [r4, #32]
 8008b06:	6323      	str	r3, [r4, #48]	; 0x30
 8008b08:	bd10      	pop	{r4, pc}
 8008b0a:	bf00      	nop
 8008b0c:	08008e25 	.word	0x08008e25
 8008b10:	08008e47 	.word	0x08008e47
 8008b14:	08008e7f 	.word	0x08008e7f
 8008b18:	08008ea3 	.word	0x08008ea3

08008b1c <_cleanup_r>:
 8008b1c:	4901      	ldr	r1, [pc, #4]	; (8008b24 <_cleanup_r+0x8>)
 8008b1e:	f000 b8af 	b.w	8008c80 <_fwalk_reent>
 8008b22:	bf00      	nop
 8008b24:	08008a5d 	.word	0x08008a5d

08008b28 <__sfmoreglue>:
 8008b28:	b570      	push	{r4, r5, r6, lr}
 8008b2a:	1e4a      	subs	r2, r1, #1
 8008b2c:	2568      	movs	r5, #104	; 0x68
 8008b2e:	4355      	muls	r5, r2
 8008b30:	460e      	mov	r6, r1
 8008b32:	f105 0174 	add.w	r1, r5, #116	; 0x74
 8008b36:	f7ff fa87 	bl	8008048 <_malloc_r>
 8008b3a:	4604      	mov	r4, r0
 8008b3c:	b140      	cbz	r0, 8008b50 <__sfmoreglue+0x28>
 8008b3e:	2100      	movs	r1, #0
 8008b40:	e9c0 1600 	strd	r1, r6, [r0]
 8008b44:	300c      	adds	r0, #12
 8008b46:	60a0      	str	r0, [r4, #8]
 8008b48:	f105 0268 	add.w	r2, r5, #104	; 0x68
 8008b4c:	f7fd fb78 	bl	8006240 <memset>
 8008b50:	4620      	mov	r0, r4
 8008b52:	bd70      	pop	{r4, r5, r6, pc}

08008b54 <__sfp_lock_acquire>:
 8008b54:	4801      	ldr	r0, [pc, #4]	; (8008b5c <__sfp_lock_acquire+0x8>)
 8008b56:	f000 b8b3 	b.w	8008cc0 <__retarget_lock_acquire_recursive>
 8008b5a:	bf00      	nop
 8008b5c:	200003c0 	.word	0x200003c0

08008b60 <__sfp_lock_release>:
 8008b60:	4801      	ldr	r0, [pc, #4]	; (8008b68 <__sfp_lock_release+0x8>)
 8008b62:	f000 b8ae 	b.w	8008cc2 <__retarget_lock_release_recursive>
 8008b66:	bf00      	nop
 8008b68:	200003c0 	.word	0x200003c0

08008b6c <__sinit_lock_acquire>:
 8008b6c:	4801      	ldr	r0, [pc, #4]	; (8008b74 <__sinit_lock_acquire+0x8>)
 8008b6e:	f000 b8a7 	b.w	8008cc0 <__retarget_lock_acquire_recursive>
 8008b72:	bf00      	nop
 8008b74:	200003bb 	.word	0x200003bb

08008b78 <__sinit_lock_release>:
 8008b78:	4801      	ldr	r0, [pc, #4]	; (8008b80 <__sinit_lock_release+0x8>)
 8008b7a:	f000 b8a2 	b.w	8008cc2 <__retarget_lock_release_recursive>
 8008b7e:	bf00      	nop
 8008b80:	200003bb 	.word	0x200003bb

08008b84 <__sinit>:
 8008b84:	b510      	push	{r4, lr}
 8008b86:	4604      	mov	r4, r0
 8008b88:	f7ff fff0 	bl	8008b6c <__sinit_lock_acquire>
 8008b8c:	69a3      	ldr	r3, [r4, #24]
 8008b8e:	b11b      	cbz	r3, 8008b98 <__sinit+0x14>
 8008b90:	e8bd 4010 	ldmia.w	sp!, {r4, lr}
 8008b94:	f7ff bff0 	b.w	8008b78 <__sinit_lock_release>
 8008b98:	e9c4 3312 	strd	r3, r3, [r4, #72]	; 0x48
 8008b9c:	6523      	str	r3, [r4, #80]	; 0x50
 8008b9e:	4b13      	ldr	r3, [pc, #76]	; (8008bec <__sinit+0x68>)
 8008ba0:	4a13      	ldr	r2, [pc, #76]	; (8008bf0 <__sinit+0x6c>)
 8008ba2:	681b      	ldr	r3, [r3, #0]
 8008ba4:	62a2      	str	r2, [r4, #40]	; 0x28
 8008ba6:	42a3      	cmp	r3, r4
 8008ba8:	bf04      	itt	eq
 8008baa:	2301      	moveq	r3, #1
 8008bac:	61a3      	streq	r3, [r4, #24]
 8008bae:	4620      	mov	r0, r4
 8008bb0:	f000 f820 	bl	8008bf4 <__sfp>
 8008bb4:	6060      	str	r0, [r4, #4]
 8008bb6:	4620      	mov	r0, r4
 8008bb8:	f000 f81c 	bl	8008bf4 <__sfp>
 8008bbc:	60a0      	str	r0, [r4, #8]
 8008bbe:	4620      	mov	r0, r4
 8008bc0:	f000 f818 	bl	8008bf4 <__sfp>
 8008bc4:	2200      	movs	r2, #0
 8008bc6:	60e0      	str	r0, [r4, #12]
 8008bc8:	2104      	movs	r1, #4
 8008bca:	6860      	ldr	r0, [r4, #4]
 8008bcc:	f7ff ff82 	bl	8008ad4 <std>
 8008bd0:	68a0      	ldr	r0, [r4, #8]
 8008bd2:	2201      	movs	r2, #1
 8008bd4:	2109      	movs	r1, #9
 8008bd6:	f7ff ff7d 	bl	8008ad4 <std>
 8008bda:	68e0      	ldr	r0, [r4, #12]
 8008bdc:	2202      	movs	r2, #2
 8008bde:	2112      	movs	r1, #18
 8008be0:	f7ff ff78 	bl	8008ad4 <std>
 8008be4:	2301      	movs	r3, #1
 8008be6:	61a3      	str	r3, [r4, #24]
 8008be8:	e7d2      	b.n	8008b90 <__sinit+0xc>
 8008bea:	bf00      	nop
 8008bec:	08009024 	.word	0x08009024
 8008bf0:	08008b1d 	.word	0x08008b1d

08008bf4 <__sfp>:
 8008bf4:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 8008bf6:	4607      	mov	r7, r0
 8008bf8:	f7ff ffac 	bl	8008b54 <__sfp_lock_acquire>
 8008bfc:	4b1e      	ldr	r3, [pc, #120]	; (8008c78 <__sfp+0x84>)
 8008bfe:	681e      	ldr	r6, [r3, #0]
 8008c00:	69b3      	ldr	r3, [r6, #24]
 8008c02:	b913      	cbnz	r3, 8008c0a <__sfp+0x16>
 8008c04:	4630      	mov	r0, r6
 8008c06:	f7ff ffbd 	bl	8008b84 <__sinit>
 8008c0a:	3648      	adds	r6, #72	; 0x48
 8008c0c:	e9d6 3401 	ldrd	r3, r4, [r6, #4]
 8008c10:	3b01      	subs	r3, #1
 8008c12:	d503      	bpl.n	8008c1c <__sfp+0x28>
 8008c14:	6833      	ldr	r3, [r6, #0]
 8008c16:	b30b      	cbz	r3, 8008c5c <__sfp+0x68>
 8008c18:	6836      	ldr	r6, [r6, #0]
 8008c1a:	e7f7      	b.n	8008c0c <__sfp+0x18>
 8008c1c:	f9b4 500c 	ldrsh.w	r5, [r4, #12]
 8008c20:	b9d5      	cbnz	r5, 8008c58 <__sfp+0x64>
 8008c22:	4b16      	ldr	r3, [pc, #88]	; (8008c7c <__sfp+0x88>)
 8008c24:	60e3      	str	r3, [r4, #12]
 8008c26:	f104 0058 	add.w	r0, r4, #88	; 0x58
 8008c2a:	6665      	str	r5, [r4, #100]	; 0x64
 8008c2c:	f000 f847 	bl	8008cbe <__retarget_lock_init_recursive>
 8008c30:	f7ff ff96 	bl	8008b60 <__sfp_lock_release>
 8008c34:	e9c4 5501 	strd	r5, r5, [r4, #4]
 8008c38:	e9c4 5504 	strd	r5, r5, [r4, #16]
 8008c3c:	6025      	str	r5, [r4, #0]
 8008c3e:	61a5      	str	r5, [r4, #24]
 8008c40:	2208      	movs	r2, #8
 8008c42:	4629      	mov	r1, r5
 8008c44:	f104 005c 	add.w	r0, r4, #92	; 0x5c
 8008c48:	f7fd fafa 	bl	8006240 <memset>
 8008c4c:	e9c4 550d 	strd	r5, r5, [r4, #52]	; 0x34
 8008c50:	e9c4 5512 	strd	r5, r5, [r4, #72]	; 0x48
 8008c54:	4620      	mov	r0, r4
 8008c56:	bdf8      	pop	{r3, r4, r5, r6, r7, pc}
 8008c58:	3468      	adds	r4, #104	; 0x68
 8008c5a:	e7d9      	b.n	8008c10 <__sfp+0x1c>
 8008c5c:	2104      	movs	r1, #4
 8008c5e:	4638      	mov	r0, r7
 8008c60:	f7ff ff62 	bl	8008b28 <__sfmoreglue>
 8008c64:	4604      	mov	r4, r0
 8008c66:	6030      	str	r0, [r6, #0]
 8008c68:	2800      	cmp	r0, #0
 8008c6a:	d1d5      	bne.n	8008c18 <__sfp+0x24>
 8008c6c:	f7ff ff78 	bl	8008b60 <__sfp_lock_release>
 8008c70:	230c      	movs	r3, #12
 8008c72:	603b      	str	r3, [r7, #0]
 8008c74:	e7ee      	b.n	8008c54 <__sfp+0x60>
 8008c76:	bf00      	nop
 8008c78:	08009024 	.word	0x08009024
 8008c7c:	ffff0001 	.word	0xffff0001

08008c80 <_fwalk_reent>:
 8008c80:	e92d 43f8 	stmdb	sp!, {r3, r4, r5, r6, r7, r8, r9, lr}
 8008c84:	4606      	mov	r6, r0
 8008c86:	4688      	mov	r8, r1
 8008c88:	f100 0448 	add.w	r4, r0, #72	; 0x48
 8008c8c:	2700      	movs	r7, #0
 8008c8e:	e9d4 9501 	ldrd	r9, r5, [r4, #4]
 8008c92:	f1b9 0901 	subs.w	r9, r9, #1
 8008c96:	d505      	bpl.n	8008ca4 <_fwalk_reent+0x24>
 8008c98:	6824      	ldr	r4, [r4, #0]
 8008c9a:	2c00      	cmp	r4, #0
 8008c9c:	d1f7      	bne.n	8008c8e <_fwalk_reent+0xe>
 8008c9e:	4638      	mov	r0, r7
 8008ca0:	e8bd 83f8 	ldmia.w	sp!, {r3, r4, r5, r6, r7, r8, r9, pc}
 8008ca4:	89ab      	ldrh	r3, [r5, #12]
 8008ca6:	2b01      	cmp	r3, #1
 8008ca8:	d907      	bls.n	8008cba <_fwalk_reent+0x3a>
 8008caa:	f9b5 300e 	ldrsh.w	r3, [r5, #14]
 8008cae:	3301      	adds	r3, #1
 8008cb0:	d003      	beq.n	8008cba <_fwalk_reent+0x3a>
 8008cb2:	4629      	mov	r1, r5
 8008cb4:	4630      	mov	r0, r6
 8008cb6:	47c0      	blx	r8
 8008cb8:	4307      	orrs	r7, r0
 8008cba:	3568      	adds	r5, #104	; 0x68
 8008cbc:	e7e9      	b.n	8008c92 <_fwalk_reent+0x12>

08008cbe <__retarget_lock_init_recursive>:
 8008cbe:	4770      	bx	lr

08008cc0 <__retarget_lock_acquire_recursive>:
 8008cc0:	4770      	bx	lr

08008cc2 <__retarget_lock_release_recursive>:
 8008cc2:	4770      	bx	lr

08008cc4 <__swhatbuf_r>:
 8008cc4:	b570      	push	{r4, r5, r6, lr}
 8008cc6:	460e      	mov	r6, r1
 8008cc8:	f9b1 100e 	ldrsh.w	r1, [r1, #14]
 8008ccc:	2900      	cmp	r1, #0
 8008cce:	b096      	sub	sp, #88	; 0x58
 8008cd0:	4614      	mov	r4, r2
 8008cd2:	461d      	mov	r5, r3
 8008cd4:	da07      	bge.n	8008ce6 <__swhatbuf_r+0x22>
 8008cd6:	2300      	movs	r3, #0
 8008cd8:	602b      	str	r3, [r5, #0]
 8008cda:	89b3      	ldrh	r3, [r6, #12]
 8008cdc:	061a      	lsls	r2, r3, #24
 8008cde:	d410      	bmi.n	8008d02 <__swhatbuf_r+0x3e>
 8008ce0:	f44f 6380 	mov.w	r3, #1024	; 0x400
 8008ce4:	e00e      	b.n	8008d04 <__swhatbuf_r+0x40>
 8008ce6:	466a      	mov	r2, sp
 8008ce8:	f000 f902 	bl	8008ef0 <_fstat_r>
 8008cec:	2800      	cmp	r0, #0
 8008cee:	dbf2      	blt.n	8008cd6 <__swhatbuf_r+0x12>
 8008cf0:	9a01      	ldr	r2, [sp, #4]
 8008cf2:	f402 4270 	and.w	r2, r2, #61440	; 0xf000
 8008cf6:	f5a2 5300 	sub.w	r3, r2, #8192	; 0x2000
 8008cfa:	425a      	negs	r2, r3
 8008cfc:	415a      	adcs	r2, r3
 8008cfe:	602a      	str	r2, [r5, #0]
 8008d00:	e7ee      	b.n	8008ce0 <__swhatbuf_r+0x1c>
 8008d02:	2340      	movs	r3, #64	; 0x40
 8008d04:	2000      	movs	r0, #0
 8008d06:	6023      	str	r3, [r4, #0]
 8008d08:	b016      	add	sp, #88	; 0x58
 8008d0a:	bd70      	pop	{r4, r5, r6, pc}

08008d0c <__smakebuf_r>:
 8008d0c:	898b      	ldrh	r3, [r1, #12]
 8008d0e:	b573      	push	{r0, r1, r4, r5, r6, lr}
 8008d10:	079d      	lsls	r5, r3, #30
 8008d12:	4606      	mov	r6, r0
 8008d14:	460c      	mov	r4, r1
 8008d16:	d507      	bpl.n	8008d28 <__smakebuf_r+0x1c>
 8008d18:	f104 0347 	add.w	r3, r4, #71	; 0x47
 8008d1c:	6023      	str	r3, [r4, #0]
 8008d1e:	6123      	str	r3, [r4, #16]
 8008d20:	2301      	movs	r3, #1
 8008d22:	6163      	str	r3, [r4, #20]
 8008d24:	b002      	add	sp, #8
 8008d26:	bd70      	pop	{r4, r5, r6, pc}
 8008d28:	ab01      	add	r3, sp, #4
 8008d2a:	466a      	mov	r2, sp
 8008d2c:	f7ff ffca 	bl	8008cc4 <__swhatbuf_r>
 8008d30:	9900      	ldr	r1, [sp, #0]
 8008d32:	4605      	mov	r5, r0
 8008d34:	4630      	mov	r0, r6
 8008d36:	f7ff f987 	bl	8008048 <_malloc_r>
 8008d3a:	b948      	cbnz	r0, 8008d50 <__smakebuf_r+0x44>
 8008d3c:	f9b4 300c 	ldrsh.w	r3, [r4, #12]
 8008d40:	059a      	lsls	r2, r3, #22
 8008d42:	d4ef      	bmi.n	8008d24 <__smakebuf_r+0x18>
 8008d44:	f023 0303 	bic.w	r3, r3, #3
 8008d48:	f043 0302 	orr.w	r3, r3, #2
 8008d4c:	81a3      	strh	r3, [r4, #12]
 8008d4e:	e7e3      	b.n	8008d18 <__smakebuf_r+0xc>
 8008d50:	4b0d      	ldr	r3, [pc, #52]	; (8008d88 <__smakebuf_r+0x7c>)
 8008d52:	62b3      	str	r3, [r6, #40]	; 0x28
 8008d54:	89a3      	ldrh	r3, [r4, #12]
 8008d56:	6020      	str	r0, [r4, #0]
 8008d58:	f043 0380 	orr.w	r3, r3, #128	; 0x80
 8008d5c:	81a3      	strh	r3, [r4, #12]
 8008d5e:	9b00      	ldr	r3, [sp, #0]
 8008d60:	6163      	str	r3, [r4, #20]
 8008d62:	9b01      	ldr	r3, [sp, #4]
 8008d64:	6120      	str	r0, [r4, #16]
 8008d66:	b15b      	cbz	r3, 8008d80 <__smakebuf_r+0x74>
 8008d68:	f9b4 100e 	ldrsh.w	r1, [r4, #14]
 8008d6c:	4630      	mov	r0, r6
 8008d6e:	f000 f8d1 	bl	8008f14 <_isatty_r>
 8008d72:	b128      	cbz	r0, 8008d80 <__smakebuf_r+0x74>
 8008d74:	89a3      	ldrh	r3, [r4, #12]
 8008d76:	f023 0303 	bic.w	r3, r3, #3
 8008d7a:	f043 0301 	orr.w	r3, r3, #1
 8008d7e:	81a3      	strh	r3, [r4, #12]
 8008d80:	89a0      	ldrh	r0, [r4, #12]
 8008d82:	4305      	orrs	r5, r0
 8008d84:	81a5      	strh	r5, [r4, #12]
 8008d86:	e7cd      	b.n	8008d24 <__smakebuf_r+0x18>
 8008d88:	08008b1d 	.word	0x08008b1d

08008d8c <_malloc_usable_size_r>:
 8008d8c:	f851 3c04 	ldr.w	r3, [r1, #-4]
 8008d90:	1f18      	subs	r0, r3, #4
 8008d92:	2b00      	cmp	r3, #0
 8008d94:	bfbc      	itt	lt
 8008d96:	580b      	ldrlt	r3, [r1, r0]
 8008d98:	18c0      	addlt	r0, r0, r3
 8008d9a:	4770      	bx	lr

08008d9c <_raise_r>:
 8008d9c:	291f      	cmp	r1, #31
 8008d9e:	b538      	push	{r3, r4, r5, lr}
 8008da0:	4604      	mov	r4, r0
 8008da2:	460d      	mov	r5, r1
 8008da4:	d904      	bls.n	8008db0 <_raise_r+0x14>
 8008da6:	2316      	movs	r3, #22
 8008da8:	6003      	str	r3, [r0, #0]
 8008daa:	f04f 30ff 	mov.w	r0, #4294967295
 8008dae:	bd38      	pop	{r3, r4, r5, pc}
 8008db0:	6c42      	ldr	r2, [r0, #68]	; 0x44
 8008db2:	b112      	cbz	r2, 8008dba <_raise_r+0x1e>
 8008db4:	f852 3021 	ldr.w	r3, [r2, r1, lsl #2]
 8008db8:	b94b      	cbnz	r3, 8008dce <_raise_r+0x32>
 8008dba:	4620      	mov	r0, r4
 8008dbc:	f000 f830 	bl	8008e20 <_getpid_r>
 8008dc0:	462a      	mov	r2, r5
 8008dc2:	4601      	mov	r1, r0
 8008dc4:	4620      	mov	r0, r4
 8008dc6:	e8bd 4038 	ldmia.w	sp!, {r3, r4, r5, lr}
 8008dca:	f000 b817 	b.w	8008dfc <_kill_r>
 8008dce:	2b01      	cmp	r3, #1
 8008dd0:	d00a      	beq.n	8008de8 <_raise_r+0x4c>
 8008dd2:	1c59      	adds	r1, r3, #1
 8008dd4:	d103      	bne.n	8008dde <_raise_r+0x42>
 8008dd6:	2316      	movs	r3, #22
 8008dd8:	6003      	str	r3, [r0, #0]
 8008dda:	2001      	movs	r0, #1
 8008ddc:	e7e7      	b.n	8008dae <_raise_r+0x12>
 8008dde:	2400      	movs	r4, #0
 8008de0:	f842 4025 	str.w	r4, [r2, r5, lsl #2]
 8008de4:	4628      	mov	r0, r5
 8008de6:	4798      	blx	r3
 8008de8:	2000      	movs	r0, #0
 8008dea:	e7e0      	b.n	8008dae <_raise_r+0x12>

08008dec <raise>:
 8008dec:	4b02      	ldr	r3, [pc, #8]	; (8008df8 <raise+0xc>)
 8008dee:	4601      	mov	r1, r0
 8008df0:	6818      	ldr	r0, [r3, #0]
 8008df2:	f7ff bfd3 	b.w	8008d9c <_raise_r>
 8008df6:	bf00      	nop
 8008df8:	2000000c 	.word	0x2000000c

08008dfc <_kill_r>:
 8008dfc:	b538      	push	{r3, r4, r5, lr}
 8008dfe:	4d07      	ldr	r5, [pc, #28]	; (8008e1c <_kill_r+0x20>)
 8008e00:	2300      	movs	r3, #0
 8008e02:	4604      	mov	r4, r0
 8008e04:	4608      	mov	r0, r1
 8008e06:	4611      	mov	r1, r2
 8008e08:	602b      	str	r3, [r5, #0]
 8008e0a:	f7f8 fe39 	bl	8001a80 <_kill>
 8008e0e:	1c43      	adds	r3, r0, #1
 8008e10:	d102      	bne.n	8008e18 <_kill_r+0x1c>
 8008e12:	682b      	ldr	r3, [r5, #0]
 8008e14:	b103      	cbz	r3, 8008e18 <_kill_r+0x1c>
 8008e16:	6023      	str	r3, [r4, #0]
 8008e18:	bd38      	pop	{r3, r4, r5, pc}
 8008e1a:	bf00      	nop
 8008e1c:	200003b4 	.word	0x200003b4

08008e20 <_getpid_r>:
 8008e20:	f7f8 be26 	b.w	8001a70 <_getpid>

08008e24 <__sread>:
 8008e24:	b510      	push	{r4, lr}
 8008e26:	460c      	mov	r4, r1
 8008e28:	f9b1 100e 	ldrsh.w	r1, [r1, #14]
 8008e2c:	f000 f894 	bl	8008f58 <_read_r>
 8008e30:	2800      	cmp	r0, #0
 8008e32:	bfab      	itete	ge
 8008e34:	6d63      	ldrge	r3, [r4, #84]	; 0x54
 8008e36:	89a3      	ldrhlt	r3, [r4, #12]
 8008e38:	181b      	addge	r3, r3, r0
 8008e3a:	f423 5380 	biclt.w	r3, r3, #4096	; 0x1000
 8008e3e:	bfac      	ite	ge
 8008e40:	6563      	strge	r3, [r4, #84]	; 0x54
 8008e42:	81a3      	strhlt	r3, [r4, #12]
 8008e44:	bd10      	pop	{r4, pc}

08008e46 <__swrite>:
 8008e46:	e92d 41f0 	stmdb	sp!, {r4, r5, r6, r7, r8, lr}
 8008e4a:	461f      	mov	r7, r3
 8008e4c:	898b      	ldrh	r3, [r1, #12]
 8008e4e:	05db      	lsls	r3, r3, #23
 8008e50:	4605      	mov	r5, r0
 8008e52:	460c      	mov	r4, r1
 8008e54:	4616      	mov	r6, r2
 8008e56:	d505      	bpl.n	8008e64 <__swrite+0x1e>
 8008e58:	f9b1 100e 	ldrsh.w	r1, [r1, #14]
 8008e5c:	2302      	movs	r3, #2
 8008e5e:	2200      	movs	r2, #0
 8008e60:	f000 f868 	bl	8008f34 <_lseek_r>
 8008e64:	89a3      	ldrh	r3, [r4, #12]
 8008e66:	f9b4 100e 	ldrsh.w	r1, [r4, #14]
 8008e6a:	f423 5380 	bic.w	r3, r3, #4096	; 0x1000
 8008e6e:	81a3      	strh	r3, [r4, #12]
 8008e70:	4632      	mov	r2, r6
 8008e72:	463b      	mov	r3, r7
 8008e74:	4628      	mov	r0, r5
 8008e76:	e8bd 41f0 	ldmia.w	sp!, {r4, r5, r6, r7, r8, lr}
 8008e7a:	f000 b817 	b.w	8008eac <_write_r>

08008e7e <__sseek>:
 8008e7e:	b510      	push	{r4, lr}
 8008e80:	460c      	mov	r4, r1
 8008e82:	f9b1 100e 	ldrsh.w	r1, [r1, #14]
 8008e86:	f000 f855 	bl	8008f34 <_lseek_r>
 8008e8a:	1c43      	adds	r3, r0, #1
 8008e8c:	89a3      	ldrh	r3, [r4, #12]
 8008e8e:	bf15      	itete	ne
 8008e90:	6560      	strne	r0, [r4, #84]	; 0x54
 8008e92:	f423 5380 	biceq.w	r3, r3, #4096	; 0x1000
 8008e96:	f443 5380 	orrne.w	r3, r3, #4096	; 0x1000
 8008e9a:	81a3      	strheq	r3, [r4, #12]
 8008e9c:	bf18      	it	ne
 8008e9e:	81a3      	strhne	r3, [r4, #12]
 8008ea0:	bd10      	pop	{r4, pc}

08008ea2 <__sclose>:
 8008ea2:	f9b1 100e 	ldrsh.w	r1, [r1, #14]
 8008ea6:	f000 b813 	b.w	8008ed0 <_close_r>
	...

08008eac <_write_r>:
 8008eac:	b538      	push	{r3, r4, r5, lr}
 8008eae:	4d07      	ldr	r5, [pc, #28]	; (8008ecc <_write_r+0x20>)
 8008eb0:	4604      	mov	r4, r0
 8008eb2:	4608      	mov	r0, r1
 8008eb4:	4611      	mov	r1, r2
 8008eb6:	2200      	movs	r2, #0
 8008eb8:	602a      	str	r2, [r5, #0]
 8008eba:	461a      	mov	r2, r3
 8008ebc:	f7f8 fe17 	bl	8001aee <_write>
 8008ec0:	1c43      	adds	r3, r0, #1
 8008ec2:	d102      	bne.n	8008eca <_write_r+0x1e>
 8008ec4:	682b      	ldr	r3, [r5, #0]
 8008ec6:	b103      	cbz	r3, 8008eca <_write_r+0x1e>
 8008ec8:	6023      	str	r3, [r4, #0]
 8008eca:	bd38      	pop	{r3, r4, r5, pc}
 8008ecc:	200003b4 	.word	0x200003b4

08008ed0 <_close_r>:
 8008ed0:	b538      	push	{r3, r4, r5, lr}
 8008ed2:	4d06      	ldr	r5, [pc, #24]	; (8008eec <_close_r+0x1c>)
 8008ed4:	2300      	movs	r3, #0
 8008ed6:	4604      	mov	r4, r0
 8008ed8:	4608      	mov	r0, r1
 8008eda:	602b      	str	r3, [r5, #0]
 8008edc:	f7f8 fe23 	bl	8001b26 <_close>
 8008ee0:	1c43      	adds	r3, r0, #1
 8008ee2:	d102      	bne.n	8008eea <_close_r+0x1a>
 8008ee4:	682b      	ldr	r3, [r5, #0]
 8008ee6:	b103      	cbz	r3, 8008eea <_close_r+0x1a>
 8008ee8:	6023      	str	r3, [r4, #0]
 8008eea:	bd38      	pop	{r3, r4, r5, pc}
 8008eec:	200003b4 	.word	0x200003b4

08008ef0 <_fstat_r>:
 8008ef0:	b538      	push	{r3, r4, r5, lr}
 8008ef2:	4d07      	ldr	r5, [pc, #28]	; (8008f10 <_fstat_r+0x20>)
 8008ef4:	2300      	movs	r3, #0
 8008ef6:	4604      	mov	r4, r0
 8008ef8:	4608      	mov	r0, r1
 8008efa:	4611      	mov	r1, r2
 8008efc:	602b      	str	r3, [r5, #0]
 8008efe:	f7f8 fe1e 	bl	8001b3e <_fstat>
 8008f02:	1c43      	adds	r3, r0, #1
 8008f04:	d102      	bne.n	8008f0c <_fstat_r+0x1c>
 8008f06:	682b      	ldr	r3, [r5, #0]
 8008f08:	b103      	cbz	r3, 8008f0c <_fstat_r+0x1c>
 8008f0a:	6023      	str	r3, [r4, #0]
 8008f0c:	bd38      	pop	{r3, r4, r5, pc}
 8008f0e:	bf00      	nop
 8008f10:	200003b4 	.word	0x200003b4

08008f14 <_isatty_r>:
 8008f14:	b538      	push	{r3, r4, r5, lr}
 8008f16:	4d06      	ldr	r5, [pc, #24]	; (8008f30 <_isatty_r+0x1c>)
 8008f18:	2300      	movs	r3, #0
 8008f1a:	4604      	mov	r4, r0
 8008f1c:	4608      	mov	r0, r1
 8008f1e:	602b      	str	r3, [r5, #0]
 8008f20:	f7f8 fe1d 	bl	8001b5e <_isatty>
 8008f24:	1c43      	adds	r3, r0, #1
 8008f26:	d102      	bne.n	8008f2e <_isatty_r+0x1a>
 8008f28:	682b      	ldr	r3, [r5, #0]
 8008f2a:	b103      	cbz	r3, 8008f2e <_isatty_r+0x1a>
 8008f2c:	6023      	str	r3, [r4, #0]
 8008f2e:	bd38      	pop	{r3, r4, r5, pc}
 8008f30:	200003b4 	.word	0x200003b4

08008f34 <_lseek_r>:
 8008f34:	b538      	push	{r3, r4, r5, lr}
 8008f36:	4d07      	ldr	r5, [pc, #28]	; (8008f54 <_lseek_r+0x20>)
 8008f38:	4604      	mov	r4, r0
 8008f3a:	4608      	mov	r0, r1
 8008f3c:	4611      	mov	r1, r2
 8008f3e:	2200      	movs	r2, #0
 8008f40:	602a      	str	r2, [r5, #0]
 8008f42:	461a      	mov	r2, r3
 8008f44:	f7f8 fe16 	bl	8001b74 <_lseek>
 8008f48:	1c43      	adds	r3, r0, #1
 8008f4a:	d102      	bne.n	8008f52 <_lseek_r+0x1e>
 8008f4c:	682b      	ldr	r3, [r5, #0]
 8008f4e:	b103      	cbz	r3, 8008f52 <_lseek_r+0x1e>
 8008f50:	6023      	str	r3, [r4, #0]
 8008f52:	bd38      	pop	{r3, r4, r5, pc}
 8008f54:	200003b4 	.word	0x200003b4

08008f58 <_read_r>:
 8008f58:	b538      	push	{r3, r4, r5, lr}
 8008f5a:	4d07      	ldr	r5, [pc, #28]	; (8008f78 <_read_r+0x20>)
 8008f5c:	4604      	mov	r4, r0
 8008f5e:	4608      	mov	r0, r1
 8008f60:	4611      	mov	r1, r2
 8008f62:	2200      	movs	r2, #0
 8008f64:	602a      	str	r2, [r5, #0]
 8008f66:	461a      	mov	r2, r3
 8008f68:	f7f8 fda4 	bl	8001ab4 <_read>
 8008f6c:	1c43      	adds	r3, r0, #1
 8008f6e:	d102      	bne.n	8008f76 <_read_r+0x1e>
 8008f70:	682b      	ldr	r3, [r5, #0]
 8008f72:	b103      	cbz	r3, 8008f76 <_read_r+0x1e>
 8008f74:	6023      	str	r3, [r4, #0]
 8008f76:	bd38      	pop	{r3, r4, r5, pc}
 8008f78:	200003b4 	.word	0x200003b4

08008f7c <_init>:
 8008f7c:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 8008f7e:	bf00      	nop
 8008f80:	bcf8      	pop	{r3, r4, r5, r6, r7}
 8008f82:	bc08      	pop	{r3}
 8008f84:	469e      	mov	lr, r3
 8008f86:	4770      	bx	lr

08008f88 <_fini>:
 8008f88:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 8008f8a:	bf00      	nop
 8008f8c:	bcf8      	pop	{r3, r4, r5, r6, r7}
 8008f8e:	bc08      	pop	{r3}
 8008f90:	469e      	mov	lr, r3
 8008f92:	4770      	bx	lr
