
ADC_test.elf:     file format elf32-littlearm

Sections:
Idx Name          Size      VMA       LMA       File off  Algn
  0 .isr_vector   000000bc  08000000  08000000  00010000  2**0
                  CONTENTS, ALLOC, LOAD, READONLY, DATA
  1 .text         0000e29c  080000bc  080000bc  000100bc  2**2
                  CONTENTS, ALLOC, LOAD, READONLY, CODE
  2 .rodata       00001240  0800e358  0800e358  0001e358  2**3
                  CONTENTS, ALLOC, LOAD, READONLY, DATA
  3 .ARM.extab    00000000  0800f598  0800f598  000200f0  2**0
                  CONTENTS
  4 .ARM          00000000  0800f598  0800f598  000200f0  2**0
                  CONTENTS
  5 .preinit_array 00000000  0800f598  0800f598  000200f0  2**0
                  CONTENTS, ALLOC, LOAD, DATA
  6 .init_array   00000004  0800f598  0800f598  0001f598  2**2
                  CONTENTS, ALLOC, LOAD, DATA
  7 .fini_array   00000004  0800f59c  0800f59c  0001f59c  2**2
                  CONTENTS, ALLOC, LOAD, DATA
  8 .data         000000f0  20000000  0800f5a0  00020000  2**2
                  CONTENTS, ALLOC, LOAD, DATA
  9 .bss          000021fc  200000f0  0800f690  000200f0  2**2
                  ALLOC
 10 ._user_heap_stack 00000604  200022ec  0800f690  000222ec  2**0
                  ALLOC
 11 .ARM.attributes 00000028  00000000  00000000  000200f0  2**0
                  CONTENTS, READONLY
 12 .debug_info   000150d8  00000000  00000000  00020118  2**0
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 13 .debug_abbrev 0000308c  00000000  00000000  000351f0  2**0
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 14 .debug_aranges 000012a0  00000000  00000000  00038280  2**3
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 15 .debug_ranges 00001160  00000000  00000000  00039520  2**3
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 16 .debug_line   00010be6  00000000  00000000  0003a680  2**0
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 17 .debug_str    00005314  00000000  00000000  0004b266  2**0
                  CONTENTS, READONLY, DEBUGGING, OCTETS
 18 .comment      00000053  00000000  00000000  0005057a  2**0
                  CONTENTS, READONLY
 19 .debug_frame  000055fc  00000000  00000000  000505d0  2**2
                  CONTENTS, READONLY, DEBUGGING, OCTETS

Disassembly of section .text:

080000bc <__do_global_dtors_aux>:
 80000bc:	b510      	push	{r4, lr}
 80000be:	4c06      	ldr	r4, [pc, #24]	; (80000d8 <__do_global_dtors_aux+0x1c>)
 80000c0:	7823      	ldrb	r3, [r4, #0]
 80000c2:	2b00      	cmp	r3, #0
 80000c4:	d107      	bne.n	80000d6 <__do_global_dtors_aux+0x1a>
 80000c6:	4b05      	ldr	r3, [pc, #20]	; (80000dc <__do_global_dtors_aux+0x20>)
 80000c8:	2b00      	cmp	r3, #0
 80000ca:	d002      	beq.n	80000d2 <__do_global_dtors_aux+0x16>
 80000cc:	4804      	ldr	r0, [pc, #16]	; (80000e0 <__do_global_dtors_aux+0x24>)
 80000ce:	e000      	b.n	80000d2 <__do_global_dtors_aux+0x16>
 80000d0:	bf00      	nop
 80000d2:	2301      	movs	r3, #1
 80000d4:	7023      	strb	r3, [r4, #0]
 80000d6:	bd10      	pop	{r4, pc}
 80000d8:	200000f0 	.word	0x200000f0
 80000dc:	00000000 	.word	0x00000000
 80000e0:	0800e340 	.word	0x0800e340

080000e4 <frame_dummy>:
 80000e4:	4b04      	ldr	r3, [pc, #16]	; (80000f8 <frame_dummy+0x14>)
 80000e6:	b510      	push	{r4, lr}
 80000e8:	2b00      	cmp	r3, #0
 80000ea:	d003      	beq.n	80000f4 <frame_dummy+0x10>
 80000ec:	4903      	ldr	r1, [pc, #12]	; (80000fc <frame_dummy+0x18>)
 80000ee:	4804      	ldr	r0, [pc, #16]	; (8000100 <frame_dummy+0x1c>)
 80000f0:	e000      	b.n	80000f4 <frame_dummy+0x10>
 80000f2:	bf00      	nop
 80000f4:	bd10      	pop	{r4, pc}
 80000f6:	46c0      	nop			; (mov r8, r8)
 80000f8:	00000000 	.word	0x00000000
 80000fc:	200000f4 	.word	0x200000f4
 8000100:	0800e340 	.word	0x0800e340

08000104 <__udivsi3>:
 8000104:	2200      	movs	r2, #0
 8000106:	0843      	lsrs	r3, r0, #1
 8000108:	428b      	cmp	r3, r1
 800010a:	d374      	bcc.n	80001f6 <__udivsi3+0xf2>
 800010c:	0903      	lsrs	r3, r0, #4
 800010e:	428b      	cmp	r3, r1
 8000110:	d35f      	bcc.n	80001d2 <__udivsi3+0xce>
 8000112:	0a03      	lsrs	r3, r0, #8
 8000114:	428b      	cmp	r3, r1
 8000116:	d344      	bcc.n	80001a2 <__udivsi3+0x9e>
 8000118:	0b03      	lsrs	r3, r0, #12
 800011a:	428b      	cmp	r3, r1
 800011c:	d328      	bcc.n	8000170 <__udivsi3+0x6c>
 800011e:	0c03      	lsrs	r3, r0, #16
 8000120:	428b      	cmp	r3, r1
 8000122:	d30d      	bcc.n	8000140 <__udivsi3+0x3c>
 8000124:	22ff      	movs	r2, #255	; 0xff
 8000126:	0209      	lsls	r1, r1, #8
 8000128:	ba12      	rev	r2, r2
 800012a:	0c03      	lsrs	r3, r0, #16
 800012c:	428b      	cmp	r3, r1
 800012e:	d302      	bcc.n	8000136 <__udivsi3+0x32>
 8000130:	1212      	asrs	r2, r2, #8
 8000132:	0209      	lsls	r1, r1, #8
 8000134:	d065      	beq.n	8000202 <__udivsi3+0xfe>
 8000136:	0b03      	lsrs	r3, r0, #12
 8000138:	428b      	cmp	r3, r1
 800013a:	d319      	bcc.n	8000170 <__udivsi3+0x6c>
 800013c:	e000      	b.n	8000140 <__udivsi3+0x3c>
 800013e:	0a09      	lsrs	r1, r1, #8
 8000140:	0bc3      	lsrs	r3, r0, #15
 8000142:	428b      	cmp	r3, r1
 8000144:	d301      	bcc.n	800014a <__udivsi3+0x46>
 8000146:	03cb      	lsls	r3, r1, #15
 8000148:	1ac0      	subs	r0, r0, r3
 800014a:	4152      	adcs	r2, r2
 800014c:	0b83      	lsrs	r3, r0, #14
 800014e:	428b      	cmp	r3, r1
 8000150:	d301      	bcc.n	8000156 <__udivsi3+0x52>
 8000152:	038b      	lsls	r3, r1, #14
 8000154:	1ac0      	subs	r0, r0, r3
 8000156:	4152      	adcs	r2, r2
 8000158:	0b43      	lsrs	r3, r0, #13
 800015a:	428b      	cmp	r3, r1
 800015c:	d301      	bcc.n	8000162 <__udivsi3+0x5e>
 800015e:	034b      	lsls	r3, r1, #13
 8000160:	1ac0      	subs	r0, r0, r3
 8000162:	4152      	adcs	r2, r2
 8000164:	0b03      	lsrs	r3, r0, #12
 8000166:	428b      	cmp	r3, r1
 8000168:	d301      	bcc.n	800016e <__udivsi3+0x6a>
 800016a:	030b      	lsls	r3, r1, #12
 800016c:	1ac0      	subs	r0, r0, r3
 800016e:	4152      	adcs	r2, r2
 8000170:	0ac3      	lsrs	r3, r0, #11
 8000172:	428b      	cmp	r3, r1
 8000174:	d301      	bcc.n	800017a <__udivsi3+0x76>
 8000176:	02cb      	lsls	r3, r1, #11
 8000178:	1ac0      	subs	r0, r0, r3
 800017a:	4152      	adcs	r2, r2
 800017c:	0a83      	lsrs	r3, r0, #10
 800017e:	428b      	cmp	r3, r1
 8000180:	d301      	bcc.n	8000186 <__udivsi3+0x82>
 8000182:	028b      	lsls	r3, r1, #10
 8000184:	1ac0      	subs	r0, r0, r3
 8000186:	4152      	adcs	r2, r2
 8000188:	0a43      	lsrs	r3, r0, #9
 800018a:	428b      	cmp	r3, r1
 800018c:	d301      	bcc.n	8000192 <__udivsi3+0x8e>
 800018e:	024b      	lsls	r3, r1, #9
 8000190:	1ac0      	subs	r0, r0, r3
 8000192:	4152      	adcs	r2, r2
 8000194:	0a03      	lsrs	r3, r0, #8
 8000196:	428b      	cmp	r3, r1
 8000198:	d301      	bcc.n	800019e <__udivsi3+0x9a>
 800019a:	020b      	lsls	r3, r1, #8
 800019c:	1ac0      	subs	r0, r0, r3
 800019e:	4152      	adcs	r2, r2
 80001a0:	d2cd      	bcs.n	800013e <__udivsi3+0x3a>
 80001a2:	09c3      	lsrs	r3, r0, #7
 80001a4:	428b      	cmp	r3, r1
 80001a6:	d301      	bcc.n	80001ac <__udivsi3+0xa8>
 80001a8:	01cb      	lsls	r3, r1, #7
 80001aa:	1ac0      	subs	r0, r0, r3
 80001ac:	4152      	adcs	r2, r2
 80001ae:	0983      	lsrs	r3, r0, #6
 80001b0:	428b      	cmp	r3, r1
 80001b2:	d301      	bcc.n	80001b8 <__udivsi3+0xb4>
 80001b4:	018b      	lsls	r3, r1, #6
 80001b6:	1ac0      	subs	r0, r0, r3
 80001b8:	4152      	adcs	r2, r2
 80001ba:	0943      	lsrs	r3, r0, #5
 80001bc:	428b      	cmp	r3, r1
 80001be:	d301      	bcc.n	80001c4 <__udivsi3+0xc0>
 80001c0:	014b      	lsls	r3, r1, #5
 80001c2:	1ac0      	subs	r0, r0, r3
 80001c4:	4152      	adcs	r2, r2
 80001c6:	0903      	lsrs	r3, r0, #4
 80001c8:	428b      	cmp	r3, r1
 80001ca:	d301      	bcc.n	80001d0 <__udivsi3+0xcc>
 80001cc:	010b      	lsls	r3, r1, #4
 80001ce:	1ac0      	subs	r0, r0, r3
 80001d0:	4152      	adcs	r2, r2
 80001d2:	08c3      	lsrs	r3, r0, #3
 80001d4:	428b      	cmp	r3, r1
 80001d6:	d301      	bcc.n	80001dc <__udivsi3+0xd8>
 80001d8:	00cb      	lsls	r3, r1, #3
 80001da:	1ac0      	subs	r0, r0, r3
 80001dc:	4152      	adcs	r2, r2
 80001de:	0883      	lsrs	r3, r0, #2
 80001e0:	428b      	cmp	r3, r1
 80001e2:	d301      	bcc.n	80001e8 <__udivsi3+0xe4>
 80001e4:	008b      	lsls	r3, r1, #2
 80001e6:	1ac0      	subs	r0, r0, r3
 80001e8:	4152      	adcs	r2, r2
 80001ea:	0843      	lsrs	r3, r0, #1
 80001ec:	428b      	cmp	r3, r1
 80001ee:	d301      	bcc.n	80001f4 <__udivsi3+0xf0>
 80001f0:	004b      	lsls	r3, r1, #1
 80001f2:	1ac0      	subs	r0, r0, r3
 80001f4:	4152      	adcs	r2, r2
 80001f6:	1a41      	subs	r1, r0, r1
 80001f8:	d200      	bcs.n	80001fc <__udivsi3+0xf8>
 80001fa:	4601      	mov	r1, r0
 80001fc:	4152      	adcs	r2, r2
 80001fe:	4610      	mov	r0, r2
 8000200:	4770      	bx	lr
 8000202:	e7ff      	b.n	8000204 <__udivsi3+0x100>
 8000204:	b501      	push	{r0, lr}
 8000206:	2000      	movs	r0, #0
 8000208:	f000 f8f0 	bl	80003ec <__aeabi_idiv0>
 800020c:	bd02      	pop	{r1, pc}
 800020e:	46c0      	nop			; (mov r8, r8)

08000210 <__aeabi_uidivmod>:
 8000210:	2900      	cmp	r1, #0
 8000212:	d0f7      	beq.n	8000204 <__udivsi3+0x100>
 8000214:	e776      	b.n	8000104 <__udivsi3>
 8000216:	4770      	bx	lr

08000218 <__divsi3>:
 8000218:	4603      	mov	r3, r0
 800021a:	430b      	orrs	r3, r1
 800021c:	d47f      	bmi.n	800031e <__divsi3+0x106>
 800021e:	2200      	movs	r2, #0
 8000220:	0843      	lsrs	r3, r0, #1
 8000222:	428b      	cmp	r3, r1
 8000224:	d374      	bcc.n	8000310 <__divsi3+0xf8>
 8000226:	0903      	lsrs	r3, r0, #4
 8000228:	428b      	cmp	r3, r1
 800022a:	d35f      	bcc.n	80002ec <__divsi3+0xd4>
 800022c:	0a03      	lsrs	r3, r0, #8
 800022e:	428b      	cmp	r3, r1
 8000230:	d344      	bcc.n	80002bc <__divsi3+0xa4>
 8000232:	0b03      	lsrs	r3, r0, #12
 8000234:	428b      	cmp	r3, r1
 8000236:	d328      	bcc.n	800028a <__divsi3+0x72>
 8000238:	0c03      	lsrs	r3, r0, #16
 800023a:	428b      	cmp	r3, r1
 800023c:	d30d      	bcc.n	800025a <__divsi3+0x42>
 800023e:	22ff      	movs	r2, #255	; 0xff
 8000240:	0209      	lsls	r1, r1, #8
 8000242:	ba12      	rev	r2, r2
 8000244:	0c03      	lsrs	r3, r0, #16
 8000246:	428b      	cmp	r3, r1
 8000248:	d302      	bcc.n	8000250 <__divsi3+0x38>
 800024a:	1212      	asrs	r2, r2, #8
 800024c:	0209      	lsls	r1, r1, #8
 800024e:	d065      	beq.n	800031c <__divsi3+0x104>
 8000250:	0b03      	lsrs	r3, r0, #12
 8000252:	428b      	cmp	r3, r1
 8000254:	d319      	bcc.n	800028a <__divsi3+0x72>
 8000256:	e000      	b.n	800025a <__divsi3+0x42>
 8000258:	0a09      	lsrs	r1, r1, #8
 800025a:	0bc3      	lsrs	r3, r0, #15
 800025c:	428b      	cmp	r3, r1
 800025e:	d301      	bcc.n	8000264 <__divsi3+0x4c>
 8000260:	03cb      	lsls	r3, r1, #15
 8000262:	1ac0      	subs	r0, r0, r3
 8000264:	4152      	adcs	r2, r2
 8000266:	0b83      	lsrs	r3, r0, #14
 8000268:	428b      	cmp	r3, r1
 800026a:	d301      	bcc.n	8000270 <__divsi3+0x58>
 800026c:	038b      	lsls	r3, r1, #14
 800026e:	1ac0      	subs	r0, r0, r3
 8000270:	4152      	adcs	r2, r2
 8000272:	0b43      	lsrs	r3, r0, #13
 8000274:	428b      	cmp	r3, r1
 8000276:	d301      	bcc.n	800027c <__divsi3+0x64>
 8000278:	034b      	lsls	r3, r1, #13
 800027a:	1ac0      	subs	r0, r0, r3
 800027c:	4152      	adcs	r2, r2
 800027e:	0b03      	lsrs	r3, r0, #12
 8000280:	428b      	cmp	r3, r1
 8000282:	d301      	bcc.n	8000288 <__divsi3+0x70>
 8000284:	030b      	lsls	r3, r1, #12
 8000286:	1ac0      	subs	r0, r0, r3
 8000288:	4152      	adcs	r2, r2
 800028a:	0ac3      	lsrs	r3, r0, #11
 800028c:	428b      	cmp	r3, r1
 800028e:	d301      	bcc.n	8000294 <__divsi3+0x7c>
 8000290:	02cb      	lsls	r3, r1, #11
 8000292:	1ac0      	subs	r0, r0, r3
 8000294:	4152      	adcs	r2, r2
 8000296:	0a83      	lsrs	r3, r0, #10
 8000298:	428b      	cmp	r3, r1
 800029a:	d301      	bcc.n	80002a0 <__divsi3+0x88>
 800029c:	028b      	lsls	r3, r1, #10
 800029e:	1ac0      	subs	r0, r0, r3
 80002a0:	4152      	adcs	r2, r2
 80002a2:	0a43      	lsrs	r3, r0, #9
 80002a4:	428b      	cmp	r3, r1
 80002a6:	d301      	bcc.n	80002ac <__divsi3+0x94>
 80002a8:	024b      	lsls	r3, r1, #9
 80002aa:	1ac0      	subs	r0, r0, r3
 80002ac:	4152      	adcs	r2, r2
 80002ae:	0a03      	lsrs	r3, r0, #8
 80002b0:	428b      	cmp	r3, r1
 80002b2:	d301      	bcc.n	80002b8 <__divsi3+0xa0>
 80002b4:	020b      	lsls	r3, r1, #8
 80002b6:	1ac0      	subs	r0, r0, r3
 80002b8:	4152      	adcs	r2, r2
 80002ba:	d2cd      	bcs.n	8000258 <__divsi3+0x40>
 80002bc:	09c3      	lsrs	r3, r0, #7
 80002be:	428b      	cmp	r3, r1
 80002c0:	d301      	bcc.n	80002c6 <__divsi3+0xae>
 80002c2:	01cb      	lsls	r3, r1, #7
 80002c4:	1ac0      	subs	r0, r0, r3
 80002c6:	4152      	adcs	r2, r2
 80002c8:	0983      	lsrs	r3, r0, #6
 80002ca:	428b      	cmp	r3, r1
 80002cc:	d301      	bcc.n	80002d2 <__divsi3+0xba>
 80002ce:	018b      	lsls	r3, r1, #6
 80002d0:	1ac0      	subs	r0, r0, r3
 80002d2:	4152      	adcs	r2, r2
 80002d4:	0943      	lsrs	r3, r0, #5
 80002d6:	428b      	cmp	r3, r1
 80002d8:	d301      	bcc.n	80002de <__divsi3+0xc6>
 80002da:	014b      	lsls	r3, r1, #5
 80002dc:	1ac0      	subs	r0, r0, r3
 80002de:	4152      	adcs	r2, r2
 80002e0:	0903      	lsrs	r3, r0, #4
 80002e2:	428b      	cmp	r3, r1
 80002e4:	d301      	bcc.n	80002ea <__divsi3+0xd2>
 80002e6:	010b      	lsls	r3, r1, #4
 80002e8:	1ac0      	subs	r0, r0, r3
 80002ea:	4152      	adcs	r2, r2
 80002ec:	08c3      	lsrs	r3, r0, #3
 80002ee:	428b      	cmp	r3, r1
 80002f0:	d301      	bcc.n	80002f6 <__divsi3+0xde>
 80002f2:	00cb      	lsls	r3, r1, #3
 80002f4:	1ac0      	subs	r0, r0, r3
 80002f6:	4152      	adcs	r2, r2
 80002f8:	0883      	lsrs	r3, r0, #2
 80002fa:	428b      	cmp	r3, r1
 80002fc:	d301      	bcc.n	8000302 <__divsi3+0xea>
 80002fe:	008b      	lsls	r3, r1, #2
 8000300:	1ac0      	subs	r0, r0, r3
 8000302:	4152      	adcs	r2, r2
 8000304:	0843      	lsrs	r3, r0, #1
 8000306:	428b      	cmp	r3, r1
 8000308:	d301      	bcc.n	800030e <__divsi3+0xf6>
 800030a:	004b      	lsls	r3, r1, #1
 800030c:	1ac0      	subs	r0, r0, r3
 800030e:	4152      	adcs	r2, r2
 8000310:	1a41      	subs	r1, r0, r1
 8000312:	d200      	bcs.n	8000316 <__divsi3+0xfe>
 8000314:	4601      	mov	r1, r0
 8000316:	4152      	adcs	r2, r2
 8000318:	4610      	mov	r0, r2
 800031a:	4770      	bx	lr
 800031c:	e05d      	b.n	80003da <__divsi3+0x1c2>
 800031e:	0fca      	lsrs	r2, r1, #31
 8000320:	d000      	beq.n	8000324 <__divsi3+0x10c>
 8000322:	4249      	negs	r1, r1
 8000324:	1003      	asrs	r3, r0, #32
 8000326:	d300      	bcc.n	800032a <__divsi3+0x112>
 8000328:	4240      	negs	r0, r0
 800032a:	4053      	eors	r3, r2
 800032c:	2200      	movs	r2, #0
 800032e:	469c      	mov	ip, r3
 8000330:	0903      	lsrs	r3, r0, #4
 8000332:	428b      	cmp	r3, r1
 8000334:	d32d      	bcc.n	8000392 <__divsi3+0x17a>
 8000336:	0a03      	lsrs	r3, r0, #8
 8000338:	428b      	cmp	r3, r1
 800033a:	d312      	bcc.n	8000362 <__divsi3+0x14a>
 800033c:	22fc      	movs	r2, #252	; 0xfc
 800033e:	0189      	lsls	r1, r1, #6
 8000340:	ba12      	rev	r2, r2
 8000342:	0a03      	lsrs	r3, r0, #8
 8000344:	428b      	cmp	r3, r1
 8000346:	d30c      	bcc.n	8000362 <__divsi3+0x14a>
 8000348:	0189      	lsls	r1, r1, #6
 800034a:	1192      	asrs	r2, r2, #6
 800034c:	428b      	cmp	r3, r1
 800034e:	d308      	bcc.n	8000362 <__divsi3+0x14a>
 8000350:	0189      	lsls	r1, r1, #6
 8000352:	1192      	asrs	r2, r2, #6
 8000354:	428b      	cmp	r3, r1
 8000356:	d304      	bcc.n	8000362 <__divsi3+0x14a>
 8000358:	0189      	lsls	r1, r1, #6
 800035a:	d03a      	beq.n	80003d2 <__divsi3+0x1ba>
 800035c:	1192      	asrs	r2, r2, #6
 800035e:	e000      	b.n	8000362 <__divsi3+0x14a>
 8000360:	0989      	lsrs	r1, r1, #6
 8000362:	09c3      	lsrs	r3, r0, #7
 8000364:	428b      	cmp	r3, r1
 8000366:	d301      	bcc.n	800036c <__divsi3+0x154>
 8000368:	01cb      	lsls	r3, r1, #7
 800036a:	1ac0      	subs	r0, r0, r3
 800036c:	4152      	adcs	r2, r2
 800036e:	0983      	lsrs	r3, r0, #6
 8000370:	428b      	cmp	r3, r1
 8000372:	d301      	bcc.n	8000378 <__divsi3+0x160>
 8000374:	018b      	lsls	r3, r1, #6
 8000376:	1ac0      	subs	r0, r0, r3
 8000378:	4152      	adcs	r2, r2
 800037a:	0943      	lsrs	r3, r0, #5
 800037c:	428b      	cmp	r3, r1
 800037e:	d301      	bcc.n	8000384 <__divsi3+0x16c>
 8000380:	014b      	lsls	r3, r1, #5
 8000382:	1ac0      	subs	r0, r0, r3
 8000384:	4152      	adcs	r2, r2
 8000386:	0903      	lsrs	r3, r0, #4
 8000388:	428b      	cmp	r3, r1
 800038a:	d301      	bcc.n	8000390 <__divsi3+0x178>
 800038c:	010b      	lsls	r3, r1, #4
 800038e:	1ac0      	subs	r0, r0, r3
 8000390:	4152      	adcs	r2, r2
 8000392:	08c3      	lsrs	r3, r0, #3
 8000394:	428b      	cmp	r3, r1
 8000396:	d301      	bcc.n	800039c <__divsi3+0x184>
 8000398:	00cb      	lsls	r3, r1, #3
 800039a:	1ac0      	subs	r0, r0, r3
 800039c:	4152      	adcs	r2, r2
 800039e:	0883      	lsrs	r3, r0, #2
 80003a0:	428b      	cmp	r3, r1
 80003a2:	d301      	bcc.n	80003a8 <__divsi3+0x190>
 80003a4:	008b      	lsls	r3, r1, #2
 80003a6:	1ac0      	subs	r0, r0, r3
 80003a8:	4152      	adcs	r2, r2
 80003aa:	d2d9      	bcs.n	8000360 <__divsi3+0x148>
 80003ac:	0843      	lsrs	r3, r0, #1
 80003ae:	428b      	cmp	r3, r1
 80003b0:	d301      	bcc.n	80003b6 <__divsi3+0x19e>
 80003b2:	004b      	lsls	r3, r1, #1
 80003b4:	1ac0      	subs	r0, r0, r3
 80003b6:	4152      	adcs	r2, r2
 80003b8:	1a41      	subs	r1, r0, r1
 80003ba:	d200      	bcs.n	80003be <__divsi3+0x1a6>
 80003bc:	4601      	mov	r1, r0
 80003be:	4663      	mov	r3, ip
 80003c0:	4152      	adcs	r2, r2
 80003c2:	105b      	asrs	r3, r3, #1
 80003c4:	4610      	mov	r0, r2
 80003c6:	d301      	bcc.n	80003cc <__divsi3+0x1b4>
 80003c8:	4240      	negs	r0, r0
 80003ca:	2b00      	cmp	r3, #0
 80003cc:	d500      	bpl.n	80003d0 <__divsi3+0x1b8>
 80003ce:	4249      	negs	r1, r1
 80003d0:	4770      	bx	lr
 80003d2:	4663      	mov	r3, ip
 80003d4:	105b      	asrs	r3, r3, #1
 80003d6:	d300      	bcc.n	80003da <__divsi3+0x1c2>
 80003d8:	4240      	negs	r0, r0
 80003da:	b501      	push	{r0, lr}
 80003dc:	2000      	movs	r0, #0
 80003de:	f000 f805 	bl	80003ec <__aeabi_idiv0>
 80003e2:	bd02      	pop	{r1, pc}

080003e4 <__aeabi_idivmod>:
 80003e4:	2900      	cmp	r1, #0
 80003e6:	d0f8      	beq.n	80003da <__divsi3+0x1c2>
 80003e8:	e716      	b.n	8000218 <__divsi3>
 80003ea:	4770      	bx	lr

080003ec <__aeabi_idiv0>:
 80003ec:	4770      	bx	lr
 80003ee:	46c0      	nop			; (mov r8, r8)

080003f0 <__aeabi_cfrcmple>:
 80003f0:	4684      	mov	ip, r0
 80003f2:	1c08      	adds	r0, r1, #0
 80003f4:	4661      	mov	r1, ip
 80003f6:	e7ff      	b.n	80003f8 <__aeabi_cfcmpeq>

080003f8 <__aeabi_cfcmpeq>:
 80003f8:	b51f      	push	{r0, r1, r2, r3, r4, lr}
 80003fa:	f000 fb6d 	bl	8000ad8 <__lesf2>
 80003fe:	2800      	cmp	r0, #0
 8000400:	d401      	bmi.n	8000406 <__aeabi_cfcmpeq+0xe>
 8000402:	2100      	movs	r1, #0
 8000404:	42c8      	cmn	r0, r1
 8000406:	bd1f      	pop	{r0, r1, r2, r3, r4, pc}

08000408 <__aeabi_fcmpeq>:
 8000408:	b510      	push	{r4, lr}
 800040a:	f000 faf1 	bl	80009f0 <__eqsf2>
 800040e:	4240      	negs	r0, r0
 8000410:	3001      	adds	r0, #1
 8000412:	bd10      	pop	{r4, pc}

08000414 <__aeabi_fcmplt>:
 8000414:	b510      	push	{r4, lr}
 8000416:	f000 fb5f 	bl	8000ad8 <__lesf2>
 800041a:	2800      	cmp	r0, #0
 800041c:	db01      	blt.n	8000422 <__aeabi_fcmplt+0xe>
 800041e:	2000      	movs	r0, #0
 8000420:	bd10      	pop	{r4, pc}
 8000422:	2001      	movs	r0, #1
 8000424:	bd10      	pop	{r4, pc}
 8000426:	46c0      	nop			; (mov r8, r8)

08000428 <__aeabi_fcmple>:
 8000428:	b510      	push	{r4, lr}
 800042a:	f000 fb55 	bl	8000ad8 <__lesf2>
 800042e:	2800      	cmp	r0, #0
 8000430:	dd01      	ble.n	8000436 <__aeabi_fcmple+0xe>
 8000432:	2000      	movs	r0, #0
 8000434:	bd10      	pop	{r4, pc}
 8000436:	2001      	movs	r0, #1
 8000438:	bd10      	pop	{r4, pc}
 800043a:	46c0      	nop			; (mov r8, r8)

0800043c <__aeabi_fcmpgt>:
 800043c:	b510      	push	{r4, lr}
 800043e:	f000 faff 	bl	8000a40 <__gesf2>
 8000442:	2800      	cmp	r0, #0
 8000444:	dc01      	bgt.n	800044a <__aeabi_fcmpgt+0xe>
 8000446:	2000      	movs	r0, #0
 8000448:	bd10      	pop	{r4, pc}
 800044a:	2001      	movs	r0, #1
 800044c:	bd10      	pop	{r4, pc}
 800044e:	46c0      	nop			; (mov r8, r8)

08000450 <__aeabi_fcmpge>:
 8000450:	b510      	push	{r4, lr}
 8000452:	f000 faf5 	bl	8000a40 <__gesf2>
 8000456:	2800      	cmp	r0, #0
 8000458:	da01      	bge.n	800045e <__aeabi_fcmpge+0xe>
 800045a:	2000      	movs	r0, #0
 800045c:	bd10      	pop	{r4, pc}
 800045e:	2001      	movs	r0, #1
 8000460:	bd10      	pop	{r4, pc}
 8000462:	46c0      	nop			; (mov r8, r8)

08000464 <__aeabi_d2uiz>:
 8000464:	b570      	push	{r4, r5, r6, lr}
 8000466:	2200      	movs	r2, #0
 8000468:	4b0c      	ldr	r3, [pc, #48]	; (800049c <__aeabi_d2uiz+0x38>)
 800046a:	0004      	movs	r4, r0
 800046c:	000d      	movs	r5, r1
 800046e:	f002 fc9b 	bl	8002da8 <__aeabi_dcmpge>
 8000472:	2800      	cmp	r0, #0
 8000474:	d104      	bne.n	8000480 <__aeabi_d2uiz+0x1c>
 8000476:	0020      	movs	r0, r4
 8000478:	0029      	movs	r1, r5
 800047a:	f002 fb2b 	bl	8002ad4 <__aeabi_d2iz>
 800047e:	bd70      	pop	{r4, r5, r6, pc}
 8000480:	4b06      	ldr	r3, [pc, #24]	; (800049c <__aeabi_d2uiz+0x38>)
 8000482:	2200      	movs	r2, #0
 8000484:	0020      	movs	r0, r4
 8000486:	0029      	movs	r1, r5
 8000488:	f001 ff92 	bl	80023b0 <__aeabi_dsub>
 800048c:	f002 fb22 	bl	8002ad4 <__aeabi_d2iz>
 8000490:	2380      	movs	r3, #128	; 0x80
 8000492:	061b      	lsls	r3, r3, #24
 8000494:	469c      	mov	ip, r3
 8000496:	4460      	add	r0, ip
 8000498:	e7f1      	b.n	800047e <__aeabi_d2uiz+0x1a>
 800049a:	46c0      	nop			; (mov r8, r8)
 800049c:	41e00000 	.word	0x41e00000

080004a0 <__aeabi_fadd>:
 80004a0:	b5f0      	push	{r4, r5, r6, r7, lr}
 80004a2:	4646      	mov	r6, r8
 80004a4:	46d6      	mov	lr, sl
 80004a6:	464f      	mov	r7, r9
 80004a8:	024d      	lsls	r5, r1, #9
 80004aa:	0242      	lsls	r2, r0, #9
 80004ac:	b5c0      	push	{r6, r7, lr}
 80004ae:	0a52      	lsrs	r2, r2, #9
 80004b0:	0a6e      	lsrs	r6, r5, #9
 80004b2:	0047      	lsls	r7, r0, #1
 80004b4:	46b0      	mov	r8, r6
 80004b6:	0e3f      	lsrs	r7, r7, #24
 80004b8:	004e      	lsls	r6, r1, #1
 80004ba:	0fc4      	lsrs	r4, r0, #31
 80004bc:	00d0      	lsls	r0, r2, #3
 80004be:	4694      	mov	ip, r2
 80004c0:	003b      	movs	r3, r7
 80004c2:	4682      	mov	sl, r0
 80004c4:	0e36      	lsrs	r6, r6, #24
 80004c6:	0fc9      	lsrs	r1, r1, #31
 80004c8:	09ad      	lsrs	r5, r5, #6
 80004ca:	428c      	cmp	r4, r1
 80004cc:	d06d      	beq.n	80005aa <__aeabi_fadd+0x10a>
 80004ce:	1bb8      	subs	r0, r7, r6
 80004d0:	4681      	mov	r9, r0
 80004d2:	2800      	cmp	r0, #0
 80004d4:	dd4d      	ble.n	8000572 <__aeabi_fadd+0xd2>
 80004d6:	2e00      	cmp	r6, #0
 80004d8:	d100      	bne.n	80004dc <__aeabi_fadd+0x3c>
 80004da:	e088      	b.n	80005ee <__aeabi_fadd+0x14e>
 80004dc:	2fff      	cmp	r7, #255	; 0xff
 80004de:	d05a      	beq.n	8000596 <__aeabi_fadd+0xf6>
 80004e0:	2380      	movs	r3, #128	; 0x80
 80004e2:	04db      	lsls	r3, r3, #19
 80004e4:	431d      	orrs	r5, r3
 80004e6:	464b      	mov	r3, r9
 80004e8:	2201      	movs	r2, #1
 80004ea:	2b1b      	cmp	r3, #27
 80004ec:	dc0a      	bgt.n	8000504 <__aeabi_fadd+0x64>
 80004ee:	002b      	movs	r3, r5
 80004f0:	464a      	mov	r2, r9
 80004f2:	4649      	mov	r1, r9
 80004f4:	40d3      	lsrs	r3, r2
 80004f6:	2220      	movs	r2, #32
 80004f8:	1a52      	subs	r2, r2, r1
 80004fa:	4095      	lsls	r5, r2
 80004fc:	002a      	movs	r2, r5
 80004fe:	1e55      	subs	r5, r2, #1
 8000500:	41aa      	sbcs	r2, r5
 8000502:	431a      	orrs	r2, r3
 8000504:	4653      	mov	r3, sl
 8000506:	1a9a      	subs	r2, r3, r2
 8000508:	0153      	lsls	r3, r2, #5
 800050a:	d400      	bmi.n	800050e <__aeabi_fadd+0x6e>
 800050c:	e0b9      	b.n	8000682 <__aeabi_fadd+0x1e2>
 800050e:	0192      	lsls	r2, r2, #6
 8000510:	0996      	lsrs	r6, r2, #6
 8000512:	0030      	movs	r0, r6
 8000514:	f002 fc52 	bl	8002dbc <__clzsi2>
 8000518:	3805      	subs	r0, #5
 800051a:	4086      	lsls	r6, r0
 800051c:	4287      	cmp	r7, r0
 800051e:	dd00      	ble.n	8000522 <__aeabi_fadd+0x82>
 8000520:	e0d4      	b.n	80006cc <__aeabi_fadd+0x22c>
 8000522:	0033      	movs	r3, r6
 8000524:	1bc7      	subs	r7, r0, r7
 8000526:	2020      	movs	r0, #32
 8000528:	3701      	adds	r7, #1
 800052a:	40fb      	lsrs	r3, r7
 800052c:	1bc7      	subs	r7, r0, r7
 800052e:	40be      	lsls	r6, r7
 8000530:	0032      	movs	r2, r6
 8000532:	1e56      	subs	r6, r2, #1
 8000534:	41b2      	sbcs	r2, r6
 8000536:	2700      	movs	r7, #0
 8000538:	431a      	orrs	r2, r3
 800053a:	0753      	lsls	r3, r2, #29
 800053c:	d004      	beq.n	8000548 <__aeabi_fadd+0xa8>
 800053e:	230f      	movs	r3, #15
 8000540:	4013      	ands	r3, r2
 8000542:	2b04      	cmp	r3, #4
 8000544:	d000      	beq.n	8000548 <__aeabi_fadd+0xa8>
 8000546:	3204      	adds	r2, #4
 8000548:	0153      	lsls	r3, r2, #5
 800054a:	d400      	bmi.n	800054e <__aeabi_fadd+0xae>
 800054c:	e09c      	b.n	8000688 <__aeabi_fadd+0x1e8>
 800054e:	1c7b      	adds	r3, r7, #1
 8000550:	2ffe      	cmp	r7, #254	; 0xfe
 8000552:	d100      	bne.n	8000556 <__aeabi_fadd+0xb6>
 8000554:	e09a      	b.n	800068c <__aeabi_fadd+0x1ec>
 8000556:	0192      	lsls	r2, r2, #6
 8000558:	0a52      	lsrs	r2, r2, #9
 800055a:	4694      	mov	ip, r2
 800055c:	b2db      	uxtb	r3, r3
 800055e:	05d8      	lsls	r0, r3, #23
 8000560:	4663      	mov	r3, ip
 8000562:	07e4      	lsls	r4, r4, #31
 8000564:	4318      	orrs	r0, r3
 8000566:	4320      	orrs	r0, r4
 8000568:	bce0      	pop	{r5, r6, r7}
 800056a:	46ba      	mov	sl, r7
 800056c:	46b1      	mov	r9, r6
 800056e:	46a8      	mov	r8, r5
 8000570:	bdf0      	pop	{r4, r5, r6, r7, pc}
 8000572:	2800      	cmp	r0, #0
 8000574:	d049      	beq.n	800060a <__aeabi_fadd+0x16a>
 8000576:	1bf3      	subs	r3, r6, r7
 8000578:	2f00      	cmp	r7, #0
 800057a:	d000      	beq.n	800057e <__aeabi_fadd+0xde>
 800057c:	e0b6      	b.n	80006ec <__aeabi_fadd+0x24c>
 800057e:	4652      	mov	r2, sl
 8000580:	2a00      	cmp	r2, #0
 8000582:	d060      	beq.n	8000646 <__aeabi_fadd+0x1a6>
 8000584:	3b01      	subs	r3, #1
 8000586:	2b00      	cmp	r3, #0
 8000588:	d100      	bne.n	800058c <__aeabi_fadd+0xec>
 800058a:	e0fc      	b.n	8000786 <__aeabi_fadd+0x2e6>
 800058c:	2eff      	cmp	r6, #255	; 0xff
 800058e:	d000      	beq.n	8000592 <__aeabi_fadd+0xf2>
 8000590:	e0b4      	b.n	80006fc <__aeabi_fadd+0x25c>
 8000592:	000c      	movs	r4, r1
 8000594:	4642      	mov	r2, r8
 8000596:	2a00      	cmp	r2, #0
 8000598:	d078      	beq.n	800068c <__aeabi_fadd+0x1ec>
 800059a:	2080      	movs	r0, #128	; 0x80
 800059c:	03c0      	lsls	r0, r0, #15
 800059e:	4310      	orrs	r0, r2
 80005a0:	0242      	lsls	r2, r0, #9
 80005a2:	0a53      	lsrs	r3, r2, #9
 80005a4:	469c      	mov	ip, r3
 80005a6:	23ff      	movs	r3, #255	; 0xff
 80005a8:	e7d9      	b.n	800055e <__aeabi_fadd+0xbe>
 80005aa:	1bb9      	subs	r1, r7, r6
 80005ac:	2900      	cmp	r1, #0
 80005ae:	dd71      	ble.n	8000694 <__aeabi_fadd+0x1f4>
 80005b0:	2e00      	cmp	r6, #0
 80005b2:	d03f      	beq.n	8000634 <__aeabi_fadd+0x194>
 80005b4:	2fff      	cmp	r7, #255	; 0xff
 80005b6:	d0ee      	beq.n	8000596 <__aeabi_fadd+0xf6>
 80005b8:	2380      	movs	r3, #128	; 0x80
 80005ba:	04db      	lsls	r3, r3, #19
 80005bc:	431d      	orrs	r5, r3
 80005be:	2201      	movs	r2, #1
 80005c0:	291b      	cmp	r1, #27
 80005c2:	dc07      	bgt.n	80005d4 <__aeabi_fadd+0x134>
 80005c4:	002a      	movs	r2, r5
 80005c6:	2320      	movs	r3, #32
 80005c8:	40ca      	lsrs	r2, r1
 80005ca:	1a59      	subs	r1, r3, r1
 80005cc:	408d      	lsls	r5, r1
 80005ce:	1e6b      	subs	r3, r5, #1
 80005d0:	419d      	sbcs	r5, r3
 80005d2:	432a      	orrs	r2, r5
 80005d4:	4452      	add	r2, sl
 80005d6:	0153      	lsls	r3, r2, #5
 80005d8:	d553      	bpl.n	8000682 <__aeabi_fadd+0x1e2>
 80005da:	3701      	adds	r7, #1
 80005dc:	2fff      	cmp	r7, #255	; 0xff
 80005de:	d055      	beq.n	800068c <__aeabi_fadd+0x1ec>
 80005e0:	2301      	movs	r3, #1
 80005e2:	497b      	ldr	r1, [pc, #492]	; (80007d0 <__aeabi_fadd+0x330>)
 80005e4:	4013      	ands	r3, r2
 80005e6:	0852      	lsrs	r2, r2, #1
 80005e8:	400a      	ands	r2, r1
 80005ea:	431a      	orrs	r2, r3
 80005ec:	e7a5      	b.n	800053a <__aeabi_fadd+0x9a>
 80005ee:	2d00      	cmp	r5, #0
 80005f0:	d02c      	beq.n	800064c <__aeabi_fadd+0x1ac>
 80005f2:	2301      	movs	r3, #1
 80005f4:	425b      	negs	r3, r3
 80005f6:	469c      	mov	ip, r3
 80005f8:	44e1      	add	r9, ip
 80005fa:	464b      	mov	r3, r9
 80005fc:	2b00      	cmp	r3, #0
 80005fe:	d100      	bne.n	8000602 <__aeabi_fadd+0x162>
 8000600:	e0ad      	b.n	800075e <__aeabi_fadd+0x2be>
 8000602:	2fff      	cmp	r7, #255	; 0xff
 8000604:	d000      	beq.n	8000608 <__aeabi_fadd+0x168>
 8000606:	e76e      	b.n	80004e6 <__aeabi_fadd+0x46>
 8000608:	e7c5      	b.n	8000596 <__aeabi_fadd+0xf6>
 800060a:	20fe      	movs	r0, #254	; 0xfe
 800060c:	1c7e      	adds	r6, r7, #1
 800060e:	4230      	tst	r0, r6
 8000610:	d160      	bne.n	80006d4 <__aeabi_fadd+0x234>
 8000612:	2f00      	cmp	r7, #0
 8000614:	d000      	beq.n	8000618 <__aeabi_fadd+0x178>
 8000616:	e093      	b.n	8000740 <__aeabi_fadd+0x2a0>
 8000618:	4652      	mov	r2, sl
 800061a:	2a00      	cmp	r2, #0
 800061c:	d100      	bne.n	8000620 <__aeabi_fadd+0x180>
 800061e:	e0b6      	b.n	800078e <__aeabi_fadd+0x2ee>
 8000620:	2d00      	cmp	r5, #0
 8000622:	d09c      	beq.n	800055e <__aeabi_fadd+0xbe>
 8000624:	1b52      	subs	r2, r2, r5
 8000626:	0150      	lsls	r0, r2, #5
 8000628:	d400      	bmi.n	800062c <__aeabi_fadd+0x18c>
 800062a:	e0c3      	b.n	80007b4 <__aeabi_fadd+0x314>
 800062c:	4653      	mov	r3, sl
 800062e:	000c      	movs	r4, r1
 8000630:	1aea      	subs	r2, r5, r3
 8000632:	e782      	b.n	800053a <__aeabi_fadd+0x9a>
 8000634:	2d00      	cmp	r5, #0
 8000636:	d009      	beq.n	800064c <__aeabi_fadd+0x1ac>
 8000638:	3901      	subs	r1, #1
 800063a:	2900      	cmp	r1, #0
 800063c:	d100      	bne.n	8000640 <__aeabi_fadd+0x1a0>
 800063e:	e08b      	b.n	8000758 <__aeabi_fadd+0x2b8>
 8000640:	2fff      	cmp	r7, #255	; 0xff
 8000642:	d1bc      	bne.n	80005be <__aeabi_fadd+0x11e>
 8000644:	e7a7      	b.n	8000596 <__aeabi_fadd+0xf6>
 8000646:	000c      	movs	r4, r1
 8000648:	4642      	mov	r2, r8
 800064a:	0037      	movs	r7, r6
 800064c:	2fff      	cmp	r7, #255	; 0xff
 800064e:	d0a2      	beq.n	8000596 <__aeabi_fadd+0xf6>
 8000650:	0252      	lsls	r2, r2, #9
 8000652:	0a53      	lsrs	r3, r2, #9
 8000654:	469c      	mov	ip, r3
 8000656:	b2fb      	uxtb	r3, r7
 8000658:	e781      	b.n	800055e <__aeabi_fadd+0xbe>
 800065a:	21fe      	movs	r1, #254	; 0xfe
 800065c:	3701      	adds	r7, #1
 800065e:	4239      	tst	r1, r7
 8000660:	d165      	bne.n	800072e <__aeabi_fadd+0x28e>
 8000662:	2b00      	cmp	r3, #0
 8000664:	d17e      	bne.n	8000764 <__aeabi_fadd+0x2c4>
 8000666:	2800      	cmp	r0, #0
 8000668:	d100      	bne.n	800066c <__aeabi_fadd+0x1cc>
 800066a:	e0aa      	b.n	80007c2 <__aeabi_fadd+0x322>
 800066c:	2d00      	cmp	r5, #0
 800066e:	d100      	bne.n	8000672 <__aeabi_fadd+0x1d2>
 8000670:	e775      	b.n	800055e <__aeabi_fadd+0xbe>
 8000672:	002a      	movs	r2, r5
 8000674:	4452      	add	r2, sl
 8000676:	2700      	movs	r7, #0
 8000678:	0153      	lsls	r3, r2, #5
 800067a:	d502      	bpl.n	8000682 <__aeabi_fadd+0x1e2>
 800067c:	4b55      	ldr	r3, [pc, #340]	; (80007d4 <__aeabi_fadd+0x334>)
 800067e:	3701      	adds	r7, #1
 8000680:	401a      	ands	r2, r3
 8000682:	0753      	lsls	r3, r2, #29
 8000684:	d000      	beq.n	8000688 <__aeabi_fadd+0x1e8>
 8000686:	e75a      	b.n	800053e <__aeabi_fadd+0x9e>
 8000688:	08d2      	lsrs	r2, r2, #3
 800068a:	e7df      	b.n	800064c <__aeabi_fadd+0x1ac>
 800068c:	2200      	movs	r2, #0
 800068e:	23ff      	movs	r3, #255	; 0xff
 8000690:	4694      	mov	ip, r2
 8000692:	e764      	b.n	800055e <__aeabi_fadd+0xbe>
 8000694:	2900      	cmp	r1, #0
 8000696:	d0e0      	beq.n	800065a <__aeabi_fadd+0x1ba>
 8000698:	1bf3      	subs	r3, r6, r7
 800069a:	2f00      	cmp	r7, #0
 800069c:	d03e      	beq.n	800071c <__aeabi_fadd+0x27c>
 800069e:	2eff      	cmp	r6, #255	; 0xff
 80006a0:	d100      	bne.n	80006a4 <__aeabi_fadd+0x204>
 80006a2:	e777      	b.n	8000594 <__aeabi_fadd+0xf4>
 80006a4:	2280      	movs	r2, #128	; 0x80
 80006a6:	0001      	movs	r1, r0
 80006a8:	04d2      	lsls	r2, r2, #19
 80006aa:	4311      	orrs	r1, r2
 80006ac:	468a      	mov	sl, r1
 80006ae:	2201      	movs	r2, #1
 80006b0:	2b1b      	cmp	r3, #27
 80006b2:	dc08      	bgt.n	80006c6 <__aeabi_fadd+0x226>
 80006b4:	4652      	mov	r2, sl
 80006b6:	2120      	movs	r1, #32
 80006b8:	4650      	mov	r0, sl
 80006ba:	40da      	lsrs	r2, r3
 80006bc:	1acb      	subs	r3, r1, r3
 80006be:	4098      	lsls	r0, r3
 80006c0:	1e43      	subs	r3, r0, #1
 80006c2:	4198      	sbcs	r0, r3
 80006c4:	4302      	orrs	r2, r0
 80006c6:	0037      	movs	r7, r6
 80006c8:	1952      	adds	r2, r2, r5
 80006ca:	e784      	b.n	80005d6 <__aeabi_fadd+0x136>
 80006cc:	4a41      	ldr	r2, [pc, #260]	; (80007d4 <__aeabi_fadd+0x334>)
 80006ce:	1a3f      	subs	r7, r7, r0
 80006d0:	4032      	ands	r2, r6
 80006d2:	e732      	b.n	800053a <__aeabi_fadd+0x9a>
 80006d4:	4653      	mov	r3, sl
 80006d6:	1b5e      	subs	r6, r3, r5
 80006d8:	0173      	lsls	r3, r6, #5
 80006da:	d42d      	bmi.n	8000738 <__aeabi_fadd+0x298>
 80006dc:	2e00      	cmp	r6, #0
 80006de:	d000      	beq.n	80006e2 <__aeabi_fadd+0x242>
 80006e0:	e717      	b.n	8000512 <__aeabi_fadd+0x72>
 80006e2:	2200      	movs	r2, #0
 80006e4:	2400      	movs	r4, #0
 80006e6:	2300      	movs	r3, #0
 80006e8:	4694      	mov	ip, r2
 80006ea:	e738      	b.n	800055e <__aeabi_fadd+0xbe>
 80006ec:	2eff      	cmp	r6, #255	; 0xff
 80006ee:	d100      	bne.n	80006f2 <__aeabi_fadd+0x252>
 80006f0:	e74f      	b.n	8000592 <__aeabi_fadd+0xf2>
 80006f2:	2280      	movs	r2, #128	; 0x80
 80006f4:	4650      	mov	r0, sl
 80006f6:	04d2      	lsls	r2, r2, #19
 80006f8:	4310      	orrs	r0, r2
 80006fa:	4682      	mov	sl, r0
 80006fc:	2201      	movs	r2, #1
 80006fe:	2b1b      	cmp	r3, #27
 8000700:	dc08      	bgt.n	8000714 <__aeabi_fadd+0x274>
 8000702:	4652      	mov	r2, sl
 8000704:	2420      	movs	r4, #32
 8000706:	4650      	mov	r0, sl
 8000708:	40da      	lsrs	r2, r3
 800070a:	1ae3      	subs	r3, r4, r3
 800070c:	4098      	lsls	r0, r3
 800070e:	1e43      	subs	r3, r0, #1
 8000710:	4198      	sbcs	r0, r3
 8000712:	4302      	orrs	r2, r0
 8000714:	000c      	movs	r4, r1
 8000716:	0037      	movs	r7, r6
 8000718:	1aaa      	subs	r2, r5, r2
 800071a:	e6f5      	b.n	8000508 <__aeabi_fadd+0x68>
 800071c:	2800      	cmp	r0, #0
 800071e:	d093      	beq.n	8000648 <__aeabi_fadd+0x1a8>
 8000720:	3b01      	subs	r3, #1
 8000722:	2b00      	cmp	r3, #0
 8000724:	d04f      	beq.n	80007c6 <__aeabi_fadd+0x326>
 8000726:	2eff      	cmp	r6, #255	; 0xff
 8000728:	d1c1      	bne.n	80006ae <__aeabi_fadd+0x20e>
 800072a:	4642      	mov	r2, r8
 800072c:	e733      	b.n	8000596 <__aeabi_fadd+0xf6>
 800072e:	2fff      	cmp	r7, #255	; 0xff
 8000730:	d0ac      	beq.n	800068c <__aeabi_fadd+0x1ec>
 8000732:	4455      	add	r5, sl
 8000734:	086a      	lsrs	r2, r5, #1
 8000736:	e7a4      	b.n	8000682 <__aeabi_fadd+0x1e2>
 8000738:	4653      	mov	r3, sl
 800073a:	000c      	movs	r4, r1
 800073c:	1aee      	subs	r6, r5, r3
 800073e:	e6e8      	b.n	8000512 <__aeabi_fadd+0x72>
 8000740:	4653      	mov	r3, sl
 8000742:	2b00      	cmp	r3, #0
 8000744:	d128      	bne.n	8000798 <__aeabi_fadd+0x2f8>
 8000746:	2d00      	cmp	r5, #0
 8000748:	d000      	beq.n	800074c <__aeabi_fadd+0x2ac>
 800074a:	e722      	b.n	8000592 <__aeabi_fadd+0xf2>
 800074c:	2380      	movs	r3, #128	; 0x80
 800074e:	03db      	lsls	r3, r3, #15
 8000750:	469c      	mov	ip, r3
 8000752:	2400      	movs	r4, #0
 8000754:	23ff      	movs	r3, #255	; 0xff
 8000756:	e702      	b.n	800055e <__aeabi_fadd+0xbe>
 8000758:	002a      	movs	r2, r5
 800075a:	4452      	add	r2, sl
 800075c:	e73b      	b.n	80005d6 <__aeabi_fadd+0x136>
 800075e:	4653      	mov	r3, sl
 8000760:	1b5a      	subs	r2, r3, r5
 8000762:	e6d1      	b.n	8000508 <__aeabi_fadd+0x68>
 8000764:	2800      	cmp	r0, #0
 8000766:	d100      	bne.n	800076a <__aeabi_fadd+0x2ca>
 8000768:	e714      	b.n	8000594 <__aeabi_fadd+0xf4>
 800076a:	2d00      	cmp	r5, #0
 800076c:	d100      	bne.n	8000770 <__aeabi_fadd+0x2d0>
 800076e:	e712      	b.n	8000596 <__aeabi_fadd+0xf6>
 8000770:	2380      	movs	r3, #128	; 0x80
 8000772:	03db      	lsls	r3, r3, #15
 8000774:	421a      	tst	r2, r3
 8000776:	d100      	bne.n	800077a <__aeabi_fadd+0x2da>
 8000778:	e70d      	b.n	8000596 <__aeabi_fadd+0xf6>
 800077a:	4641      	mov	r1, r8
 800077c:	4219      	tst	r1, r3
 800077e:	d000      	beq.n	8000782 <__aeabi_fadd+0x2e2>
 8000780:	e709      	b.n	8000596 <__aeabi_fadd+0xf6>
 8000782:	4642      	mov	r2, r8
 8000784:	e707      	b.n	8000596 <__aeabi_fadd+0xf6>
 8000786:	000c      	movs	r4, r1
 8000788:	0037      	movs	r7, r6
 800078a:	1aaa      	subs	r2, r5, r2
 800078c:	e6bc      	b.n	8000508 <__aeabi_fadd+0x68>
 800078e:	2d00      	cmp	r5, #0
 8000790:	d013      	beq.n	80007ba <__aeabi_fadd+0x31a>
 8000792:	000c      	movs	r4, r1
 8000794:	46c4      	mov	ip, r8
 8000796:	e6e2      	b.n	800055e <__aeabi_fadd+0xbe>
 8000798:	2d00      	cmp	r5, #0
 800079a:	d100      	bne.n	800079e <__aeabi_fadd+0x2fe>
 800079c:	e6fb      	b.n	8000596 <__aeabi_fadd+0xf6>
 800079e:	2380      	movs	r3, #128	; 0x80
 80007a0:	03db      	lsls	r3, r3, #15
 80007a2:	421a      	tst	r2, r3
 80007a4:	d100      	bne.n	80007a8 <__aeabi_fadd+0x308>
 80007a6:	e6f6      	b.n	8000596 <__aeabi_fadd+0xf6>
 80007a8:	4640      	mov	r0, r8
 80007aa:	4218      	tst	r0, r3
 80007ac:	d000      	beq.n	80007b0 <__aeabi_fadd+0x310>
 80007ae:	e6f2      	b.n	8000596 <__aeabi_fadd+0xf6>
 80007b0:	000c      	movs	r4, r1
 80007b2:	e6ef      	b.n	8000594 <__aeabi_fadd+0xf4>
 80007b4:	2a00      	cmp	r2, #0
 80007b6:	d000      	beq.n	80007ba <__aeabi_fadd+0x31a>
 80007b8:	e763      	b.n	8000682 <__aeabi_fadd+0x1e2>
 80007ba:	2200      	movs	r2, #0
 80007bc:	2400      	movs	r4, #0
 80007be:	4694      	mov	ip, r2
 80007c0:	e6cd      	b.n	800055e <__aeabi_fadd+0xbe>
 80007c2:	46c4      	mov	ip, r8
 80007c4:	e6cb      	b.n	800055e <__aeabi_fadd+0xbe>
 80007c6:	002a      	movs	r2, r5
 80007c8:	0037      	movs	r7, r6
 80007ca:	4452      	add	r2, sl
 80007cc:	e703      	b.n	80005d6 <__aeabi_fadd+0x136>
 80007ce:	46c0      	nop			; (mov r8, r8)
 80007d0:	7dffffff 	.word	0x7dffffff
 80007d4:	fbffffff 	.word	0xfbffffff

080007d8 <__aeabi_fdiv>:
 80007d8:	b5f0      	push	{r4, r5, r6, r7, lr}
 80007da:	464f      	mov	r7, r9
 80007dc:	4646      	mov	r6, r8
 80007de:	46d6      	mov	lr, sl
 80007e0:	0245      	lsls	r5, r0, #9
 80007e2:	b5c0      	push	{r6, r7, lr}
 80007e4:	0047      	lsls	r7, r0, #1
 80007e6:	1c0c      	adds	r4, r1, #0
 80007e8:	0a6d      	lsrs	r5, r5, #9
 80007ea:	0e3f      	lsrs	r7, r7, #24
 80007ec:	0fc6      	lsrs	r6, r0, #31
 80007ee:	2f00      	cmp	r7, #0
 80007f0:	d066      	beq.n	80008c0 <__aeabi_fdiv+0xe8>
 80007f2:	2fff      	cmp	r7, #255	; 0xff
 80007f4:	d06c      	beq.n	80008d0 <__aeabi_fdiv+0xf8>
 80007f6:	2300      	movs	r3, #0
 80007f8:	00ea      	lsls	r2, r5, #3
 80007fa:	2580      	movs	r5, #128	; 0x80
 80007fc:	4699      	mov	r9, r3
 80007fe:	469a      	mov	sl, r3
 8000800:	04ed      	lsls	r5, r5, #19
 8000802:	4315      	orrs	r5, r2
 8000804:	3f7f      	subs	r7, #127	; 0x7f
 8000806:	0260      	lsls	r0, r4, #9
 8000808:	0061      	lsls	r1, r4, #1
 800080a:	0a43      	lsrs	r3, r0, #9
 800080c:	4698      	mov	r8, r3
 800080e:	0e09      	lsrs	r1, r1, #24
 8000810:	0fe4      	lsrs	r4, r4, #31
 8000812:	2900      	cmp	r1, #0
 8000814:	d048      	beq.n	80008a8 <__aeabi_fdiv+0xd0>
 8000816:	29ff      	cmp	r1, #255	; 0xff
 8000818:	d010      	beq.n	800083c <__aeabi_fdiv+0x64>
 800081a:	2280      	movs	r2, #128	; 0x80
 800081c:	00d8      	lsls	r0, r3, #3
 800081e:	04d2      	lsls	r2, r2, #19
 8000820:	4302      	orrs	r2, r0
 8000822:	4690      	mov	r8, r2
 8000824:	2000      	movs	r0, #0
 8000826:	397f      	subs	r1, #127	; 0x7f
 8000828:	464a      	mov	r2, r9
 800082a:	0033      	movs	r3, r6
 800082c:	1a7f      	subs	r7, r7, r1
 800082e:	4302      	orrs	r2, r0
 8000830:	496c      	ldr	r1, [pc, #432]	; (80009e4 <__aeabi_fdiv+0x20c>)
 8000832:	0092      	lsls	r2, r2, #2
 8000834:	588a      	ldr	r2, [r1, r2]
 8000836:	4063      	eors	r3, r4
 8000838:	b2db      	uxtb	r3, r3
 800083a:	4697      	mov	pc, r2
 800083c:	2b00      	cmp	r3, #0
 800083e:	d16d      	bne.n	800091c <__aeabi_fdiv+0x144>
 8000840:	2002      	movs	r0, #2
 8000842:	3fff      	subs	r7, #255	; 0xff
 8000844:	e033      	b.n	80008ae <__aeabi_fdiv+0xd6>
 8000846:	2300      	movs	r3, #0
 8000848:	4698      	mov	r8, r3
 800084a:	0026      	movs	r6, r4
 800084c:	4645      	mov	r5, r8
 800084e:	4682      	mov	sl, r0
 8000850:	4653      	mov	r3, sl
 8000852:	2b02      	cmp	r3, #2
 8000854:	d100      	bne.n	8000858 <__aeabi_fdiv+0x80>
 8000856:	e07f      	b.n	8000958 <__aeabi_fdiv+0x180>
 8000858:	2b03      	cmp	r3, #3
 800085a:	d100      	bne.n	800085e <__aeabi_fdiv+0x86>
 800085c:	e094      	b.n	8000988 <__aeabi_fdiv+0x1b0>
 800085e:	2b01      	cmp	r3, #1
 8000860:	d017      	beq.n	8000892 <__aeabi_fdiv+0xba>
 8000862:	0038      	movs	r0, r7
 8000864:	307f      	adds	r0, #127	; 0x7f
 8000866:	2800      	cmp	r0, #0
 8000868:	dd5f      	ble.n	800092a <__aeabi_fdiv+0x152>
 800086a:	076b      	lsls	r3, r5, #29
 800086c:	d004      	beq.n	8000878 <__aeabi_fdiv+0xa0>
 800086e:	230f      	movs	r3, #15
 8000870:	402b      	ands	r3, r5
 8000872:	2b04      	cmp	r3, #4
 8000874:	d000      	beq.n	8000878 <__aeabi_fdiv+0xa0>
 8000876:	3504      	adds	r5, #4
 8000878:	012b      	lsls	r3, r5, #4
 800087a:	d503      	bpl.n	8000884 <__aeabi_fdiv+0xac>
 800087c:	0038      	movs	r0, r7
 800087e:	4b5a      	ldr	r3, [pc, #360]	; (80009e8 <__aeabi_fdiv+0x210>)
 8000880:	3080      	adds	r0, #128	; 0x80
 8000882:	401d      	ands	r5, r3
 8000884:	28fe      	cmp	r0, #254	; 0xfe
 8000886:	dc67      	bgt.n	8000958 <__aeabi_fdiv+0x180>
 8000888:	01ad      	lsls	r5, r5, #6
 800088a:	0a6d      	lsrs	r5, r5, #9
 800088c:	b2c0      	uxtb	r0, r0
 800088e:	e002      	b.n	8000896 <__aeabi_fdiv+0xbe>
 8000890:	001e      	movs	r6, r3
 8000892:	2000      	movs	r0, #0
 8000894:	2500      	movs	r5, #0
 8000896:	05c0      	lsls	r0, r0, #23
 8000898:	4328      	orrs	r0, r5
 800089a:	07f6      	lsls	r6, r6, #31
 800089c:	4330      	orrs	r0, r6
 800089e:	bce0      	pop	{r5, r6, r7}
 80008a0:	46ba      	mov	sl, r7
 80008a2:	46b1      	mov	r9, r6
 80008a4:	46a8      	mov	r8, r5
 80008a6:	bdf0      	pop	{r4, r5, r6, r7, pc}
 80008a8:	2b00      	cmp	r3, #0
 80008aa:	d12b      	bne.n	8000904 <__aeabi_fdiv+0x12c>
 80008ac:	2001      	movs	r0, #1
 80008ae:	464a      	mov	r2, r9
 80008b0:	0033      	movs	r3, r6
 80008b2:	494e      	ldr	r1, [pc, #312]	; (80009ec <__aeabi_fdiv+0x214>)
 80008b4:	4302      	orrs	r2, r0
 80008b6:	0092      	lsls	r2, r2, #2
 80008b8:	588a      	ldr	r2, [r1, r2]
 80008ba:	4063      	eors	r3, r4
 80008bc:	b2db      	uxtb	r3, r3
 80008be:	4697      	mov	pc, r2
 80008c0:	2d00      	cmp	r5, #0
 80008c2:	d113      	bne.n	80008ec <__aeabi_fdiv+0x114>
 80008c4:	2304      	movs	r3, #4
 80008c6:	4699      	mov	r9, r3
 80008c8:	3b03      	subs	r3, #3
 80008ca:	2700      	movs	r7, #0
 80008cc:	469a      	mov	sl, r3
 80008ce:	e79a      	b.n	8000806 <__aeabi_fdiv+0x2e>
 80008d0:	2d00      	cmp	r5, #0
 80008d2:	d105      	bne.n	80008e0 <__aeabi_fdiv+0x108>
 80008d4:	2308      	movs	r3, #8
 80008d6:	4699      	mov	r9, r3
 80008d8:	3b06      	subs	r3, #6
 80008da:	27ff      	movs	r7, #255	; 0xff
 80008dc:	469a      	mov	sl, r3
 80008de:	e792      	b.n	8000806 <__aeabi_fdiv+0x2e>
 80008e0:	230c      	movs	r3, #12
 80008e2:	4699      	mov	r9, r3
 80008e4:	3b09      	subs	r3, #9
 80008e6:	27ff      	movs	r7, #255	; 0xff
 80008e8:	469a      	mov	sl, r3
 80008ea:	e78c      	b.n	8000806 <__aeabi_fdiv+0x2e>
 80008ec:	0028      	movs	r0, r5
 80008ee:	f002 fa65 	bl	8002dbc <__clzsi2>
 80008f2:	2776      	movs	r7, #118	; 0x76
 80008f4:	1f43      	subs	r3, r0, #5
 80008f6:	409d      	lsls	r5, r3
 80008f8:	2300      	movs	r3, #0
 80008fa:	427f      	negs	r7, r7
 80008fc:	4699      	mov	r9, r3
 80008fe:	469a      	mov	sl, r3
 8000900:	1a3f      	subs	r7, r7, r0
 8000902:	e780      	b.n	8000806 <__aeabi_fdiv+0x2e>
 8000904:	0018      	movs	r0, r3
 8000906:	f002 fa59 	bl	8002dbc <__clzsi2>
 800090a:	4642      	mov	r2, r8
 800090c:	1f43      	subs	r3, r0, #5
 800090e:	2176      	movs	r1, #118	; 0x76
 8000910:	409a      	lsls	r2, r3
 8000912:	4249      	negs	r1, r1
 8000914:	1a09      	subs	r1, r1, r0
 8000916:	4690      	mov	r8, r2
 8000918:	2000      	movs	r0, #0
 800091a:	e785      	b.n	8000828 <__aeabi_fdiv+0x50>
 800091c:	21ff      	movs	r1, #255	; 0xff
 800091e:	2003      	movs	r0, #3
 8000920:	e782      	b.n	8000828 <__aeabi_fdiv+0x50>
 8000922:	001e      	movs	r6, r3
 8000924:	20ff      	movs	r0, #255	; 0xff
 8000926:	2500      	movs	r5, #0
 8000928:	e7b5      	b.n	8000896 <__aeabi_fdiv+0xbe>
 800092a:	2301      	movs	r3, #1
 800092c:	1a1b      	subs	r3, r3, r0
 800092e:	2b1b      	cmp	r3, #27
 8000930:	dcaf      	bgt.n	8000892 <__aeabi_fdiv+0xba>
 8000932:	379e      	adds	r7, #158	; 0x9e
 8000934:	0029      	movs	r1, r5
 8000936:	40bd      	lsls	r5, r7
 8000938:	40d9      	lsrs	r1, r3
 800093a:	1e6a      	subs	r2, r5, #1
 800093c:	4195      	sbcs	r5, r2
 800093e:	430d      	orrs	r5, r1
 8000940:	076b      	lsls	r3, r5, #29
 8000942:	d004      	beq.n	800094e <__aeabi_fdiv+0x176>
 8000944:	230f      	movs	r3, #15
 8000946:	402b      	ands	r3, r5
 8000948:	2b04      	cmp	r3, #4
 800094a:	d000      	beq.n	800094e <__aeabi_fdiv+0x176>
 800094c:	3504      	adds	r5, #4
 800094e:	016b      	lsls	r3, r5, #5
 8000950:	d544      	bpl.n	80009dc <__aeabi_fdiv+0x204>
 8000952:	2001      	movs	r0, #1
 8000954:	2500      	movs	r5, #0
 8000956:	e79e      	b.n	8000896 <__aeabi_fdiv+0xbe>
 8000958:	20ff      	movs	r0, #255	; 0xff
 800095a:	2500      	movs	r5, #0
 800095c:	e79b      	b.n	8000896 <__aeabi_fdiv+0xbe>
 800095e:	2580      	movs	r5, #128	; 0x80
 8000960:	2600      	movs	r6, #0
 8000962:	20ff      	movs	r0, #255	; 0xff
 8000964:	03ed      	lsls	r5, r5, #15
 8000966:	e796      	b.n	8000896 <__aeabi_fdiv+0xbe>
 8000968:	2300      	movs	r3, #0
 800096a:	4698      	mov	r8, r3
 800096c:	2080      	movs	r0, #128	; 0x80
 800096e:	03c0      	lsls	r0, r0, #15
 8000970:	4205      	tst	r5, r0
 8000972:	d009      	beq.n	8000988 <__aeabi_fdiv+0x1b0>
 8000974:	4643      	mov	r3, r8
 8000976:	4203      	tst	r3, r0
 8000978:	d106      	bne.n	8000988 <__aeabi_fdiv+0x1b0>
 800097a:	4645      	mov	r5, r8
 800097c:	4305      	orrs	r5, r0
 800097e:	026d      	lsls	r5, r5, #9
 8000980:	0026      	movs	r6, r4
 8000982:	20ff      	movs	r0, #255	; 0xff
 8000984:	0a6d      	lsrs	r5, r5, #9
 8000986:	e786      	b.n	8000896 <__aeabi_fdiv+0xbe>
 8000988:	2080      	movs	r0, #128	; 0x80
 800098a:	03c0      	lsls	r0, r0, #15
 800098c:	4305      	orrs	r5, r0
 800098e:	026d      	lsls	r5, r5, #9
 8000990:	20ff      	movs	r0, #255	; 0xff
 8000992:	0a6d      	lsrs	r5, r5, #9
 8000994:	e77f      	b.n	8000896 <__aeabi_fdiv+0xbe>
 8000996:	4641      	mov	r1, r8
 8000998:	016a      	lsls	r2, r5, #5
 800099a:	0148      	lsls	r0, r1, #5
 800099c:	4282      	cmp	r2, r0
 800099e:	d219      	bcs.n	80009d4 <__aeabi_fdiv+0x1fc>
 80009a0:	211b      	movs	r1, #27
 80009a2:	2500      	movs	r5, #0
 80009a4:	3f01      	subs	r7, #1
 80009a6:	2601      	movs	r6, #1
 80009a8:	0014      	movs	r4, r2
 80009aa:	006d      	lsls	r5, r5, #1
 80009ac:	0052      	lsls	r2, r2, #1
 80009ae:	2c00      	cmp	r4, #0
 80009b0:	db01      	blt.n	80009b6 <__aeabi_fdiv+0x1de>
 80009b2:	4290      	cmp	r0, r2
 80009b4:	d801      	bhi.n	80009ba <__aeabi_fdiv+0x1e2>
 80009b6:	1a12      	subs	r2, r2, r0
 80009b8:	4335      	orrs	r5, r6
 80009ba:	3901      	subs	r1, #1
 80009bc:	2900      	cmp	r1, #0
 80009be:	d1f3      	bne.n	80009a8 <__aeabi_fdiv+0x1d0>
 80009c0:	1e50      	subs	r0, r2, #1
 80009c2:	4182      	sbcs	r2, r0
 80009c4:	0038      	movs	r0, r7
 80009c6:	307f      	adds	r0, #127	; 0x7f
 80009c8:	001e      	movs	r6, r3
 80009ca:	4315      	orrs	r5, r2
 80009cc:	2800      	cmp	r0, #0
 80009ce:	dd00      	ble.n	80009d2 <__aeabi_fdiv+0x1fa>
 80009d0:	e74b      	b.n	800086a <__aeabi_fdiv+0x92>
 80009d2:	e7aa      	b.n	800092a <__aeabi_fdiv+0x152>
 80009d4:	211a      	movs	r1, #26
 80009d6:	2501      	movs	r5, #1
 80009d8:	1a12      	subs	r2, r2, r0
 80009da:	e7e4      	b.n	80009a6 <__aeabi_fdiv+0x1ce>
 80009dc:	01ad      	lsls	r5, r5, #6
 80009de:	2000      	movs	r0, #0
 80009e0:	0a6d      	lsrs	r5, r5, #9
 80009e2:	e758      	b.n	8000896 <__aeabi_fdiv+0xbe>
 80009e4:	0800e500 	.word	0x0800e500
 80009e8:	f7ffffff 	.word	0xf7ffffff
 80009ec:	0800e540 	.word	0x0800e540

080009f0 <__eqsf2>:
 80009f0:	b570      	push	{r4, r5, r6, lr}
 80009f2:	0042      	lsls	r2, r0, #1
 80009f4:	024e      	lsls	r6, r1, #9
 80009f6:	004c      	lsls	r4, r1, #1
 80009f8:	0245      	lsls	r5, r0, #9
 80009fa:	0a6d      	lsrs	r5, r5, #9
 80009fc:	0e12      	lsrs	r2, r2, #24
 80009fe:	0fc3      	lsrs	r3, r0, #31
 8000a00:	0a76      	lsrs	r6, r6, #9
 8000a02:	0e24      	lsrs	r4, r4, #24
 8000a04:	0fc9      	lsrs	r1, r1, #31
 8000a06:	2aff      	cmp	r2, #255	; 0xff
 8000a08:	d00f      	beq.n	8000a2a <__eqsf2+0x3a>
 8000a0a:	2cff      	cmp	r4, #255	; 0xff
 8000a0c:	d011      	beq.n	8000a32 <__eqsf2+0x42>
 8000a0e:	2001      	movs	r0, #1
 8000a10:	42a2      	cmp	r2, r4
 8000a12:	d000      	beq.n	8000a16 <__eqsf2+0x26>
 8000a14:	bd70      	pop	{r4, r5, r6, pc}
 8000a16:	42b5      	cmp	r5, r6
 8000a18:	d1fc      	bne.n	8000a14 <__eqsf2+0x24>
 8000a1a:	428b      	cmp	r3, r1
 8000a1c:	d00d      	beq.n	8000a3a <__eqsf2+0x4a>
 8000a1e:	2a00      	cmp	r2, #0
 8000a20:	d1f8      	bne.n	8000a14 <__eqsf2+0x24>
 8000a22:	0028      	movs	r0, r5
 8000a24:	1e45      	subs	r5, r0, #1
 8000a26:	41a8      	sbcs	r0, r5
 8000a28:	e7f4      	b.n	8000a14 <__eqsf2+0x24>
 8000a2a:	2001      	movs	r0, #1
 8000a2c:	2d00      	cmp	r5, #0
 8000a2e:	d1f1      	bne.n	8000a14 <__eqsf2+0x24>
 8000a30:	e7eb      	b.n	8000a0a <__eqsf2+0x1a>
 8000a32:	2001      	movs	r0, #1
 8000a34:	2e00      	cmp	r6, #0
 8000a36:	d1ed      	bne.n	8000a14 <__eqsf2+0x24>
 8000a38:	e7e9      	b.n	8000a0e <__eqsf2+0x1e>
 8000a3a:	2000      	movs	r0, #0
 8000a3c:	e7ea      	b.n	8000a14 <__eqsf2+0x24>
 8000a3e:	46c0      	nop			; (mov r8, r8)

08000a40 <__gesf2>:
 8000a40:	b5f0      	push	{r4, r5, r6, r7, lr}
 8000a42:	0042      	lsls	r2, r0, #1
 8000a44:	0246      	lsls	r6, r0, #9
 8000a46:	024d      	lsls	r5, r1, #9
 8000a48:	004c      	lsls	r4, r1, #1
 8000a4a:	0fc3      	lsrs	r3, r0, #31
 8000a4c:	0a76      	lsrs	r6, r6, #9
 8000a4e:	0e12      	lsrs	r2, r2, #24
 8000a50:	0a6d      	lsrs	r5, r5, #9
 8000a52:	0e24      	lsrs	r4, r4, #24
 8000a54:	0fc8      	lsrs	r0, r1, #31
 8000a56:	2aff      	cmp	r2, #255	; 0xff
 8000a58:	d01f      	beq.n	8000a9a <__gesf2+0x5a>
 8000a5a:	2cff      	cmp	r4, #255	; 0xff
 8000a5c:	d010      	beq.n	8000a80 <__gesf2+0x40>
 8000a5e:	2a00      	cmp	r2, #0
 8000a60:	d11f      	bne.n	8000aa2 <__gesf2+0x62>
 8000a62:	4271      	negs	r1, r6
 8000a64:	4171      	adcs	r1, r6
 8000a66:	2c00      	cmp	r4, #0
 8000a68:	d101      	bne.n	8000a6e <__gesf2+0x2e>
 8000a6a:	2d00      	cmp	r5, #0
 8000a6c:	d01e      	beq.n	8000aac <__gesf2+0x6c>
 8000a6e:	2900      	cmp	r1, #0
 8000a70:	d10e      	bne.n	8000a90 <__gesf2+0x50>
 8000a72:	4283      	cmp	r3, r0
 8000a74:	d01e      	beq.n	8000ab4 <__gesf2+0x74>
 8000a76:	2102      	movs	r1, #2
 8000a78:	1e58      	subs	r0, r3, #1
 8000a7a:	4008      	ands	r0, r1
 8000a7c:	3801      	subs	r0, #1
 8000a7e:	bdf0      	pop	{r4, r5, r6, r7, pc}
 8000a80:	2d00      	cmp	r5, #0
 8000a82:	d126      	bne.n	8000ad2 <__gesf2+0x92>
 8000a84:	2a00      	cmp	r2, #0
 8000a86:	d1f4      	bne.n	8000a72 <__gesf2+0x32>
 8000a88:	4271      	negs	r1, r6
 8000a8a:	4171      	adcs	r1, r6
 8000a8c:	2900      	cmp	r1, #0
 8000a8e:	d0f0      	beq.n	8000a72 <__gesf2+0x32>
 8000a90:	2800      	cmp	r0, #0
 8000a92:	d1f4      	bne.n	8000a7e <__gesf2+0x3e>
 8000a94:	2001      	movs	r0, #1
 8000a96:	4240      	negs	r0, r0
 8000a98:	e7f1      	b.n	8000a7e <__gesf2+0x3e>
 8000a9a:	2e00      	cmp	r6, #0
 8000a9c:	d119      	bne.n	8000ad2 <__gesf2+0x92>
 8000a9e:	2cff      	cmp	r4, #255	; 0xff
 8000aa0:	d0ee      	beq.n	8000a80 <__gesf2+0x40>
 8000aa2:	2c00      	cmp	r4, #0
 8000aa4:	d1e5      	bne.n	8000a72 <__gesf2+0x32>
 8000aa6:	2d00      	cmp	r5, #0
 8000aa8:	d1e3      	bne.n	8000a72 <__gesf2+0x32>
 8000aaa:	e7e4      	b.n	8000a76 <__gesf2+0x36>
 8000aac:	2000      	movs	r0, #0
 8000aae:	2e00      	cmp	r6, #0
 8000ab0:	d0e5      	beq.n	8000a7e <__gesf2+0x3e>
 8000ab2:	e7e0      	b.n	8000a76 <__gesf2+0x36>
 8000ab4:	42a2      	cmp	r2, r4
 8000ab6:	dc05      	bgt.n	8000ac4 <__gesf2+0x84>
 8000ab8:	dbea      	blt.n	8000a90 <__gesf2+0x50>
 8000aba:	42ae      	cmp	r6, r5
 8000abc:	d802      	bhi.n	8000ac4 <__gesf2+0x84>
 8000abe:	d3e7      	bcc.n	8000a90 <__gesf2+0x50>
 8000ac0:	2000      	movs	r0, #0
 8000ac2:	e7dc      	b.n	8000a7e <__gesf2+0x3e>
 8000ac4:	4241      	negs	r1, r0
 8000ac6:	4141      	adcs	r1, r0
 8000ac8:	4248      	negs	r0, r1
 8000aca:	2102      	movs	r1, #2
 8000acc:	4008      	ands	r0, r1
 8000ace:	3801      	subs	r0, #1
 8000ad0:	e7d5      	b.n	8000a7e <__gesf2+0x3e>
 8000ad2:	2002      	movs	r0, #2
 8000ad4:	4240      	negs	r0, r0
 8000ad6:	e7d2      	b.n	8000a7e <__gesf2+0x3e>

08000ad8 <__lesf2>:
 8000ad8:	b5f0      	push	{r4, r5, r6, r7, lr}
 8000ada:	0042      	lsls	r2, r0, #1
 8000adc:	0246      	lsls	r6, r0, #9
 8000ade:	024d      	lsls	r5, r1, #9
 8000ae0:	004c      	lsls	r4, r1, #1
 8000ae2:	0fc3      	lsrs	r3, r0, #31
 8000ae4:	0a76      	lsrs	r6, r6, #9
 8000ae6:	0e12      	lsrs	r2, r2, #24
 8000ae8:	0a6d      	lsrs	r5, r5, #9
 8000aea:	0e24      	lsrs	r4, r4, #24
 8000aec:	0fc8      	lsrs	r0, r1, #31
 8000aee:	2aff      	cmp	r2, #255	; 0xff
 8000af0:	d00d      	beq.n	8000b0e <__lesf2+0x36>
 8000af2:	2cff      	cmp	r4, #255	; 0xff
 8000af4:	d00f      	beq.n	8000b16 <__lesf2+0x3e>
 8000af6:	2a00      	cmp	r2, #0
 8000af8:	d123      	bne.n	8000b42 <__lesf2+0x6a>
 8000afa:	4271      	negs	r1, r6
 8000afc:	4171      	adcs	r1, r6
 8000afe:	2c00      	cmp	r4, #0
 8000b00:	d10f      	bne.n	8000b22 <__lesf2+0x4a>
 8000b02:	2d00      	cmp	r5, #0
 8000b04:	d10d      	bne.n	8000b22 <__lesf2+0x4a>
 8000b06:	2000      	movs	r0, #0
 8000b08:	2e00      	cmp	r6, #0
 8000b0a:	d014      	beq.n	8000b36 <__lesf2+0x5e>
 8000b0c:	e00d      	b.n	8000b2a <__lesf2+0x52>
 8000b0e:	2e00      	cmp	r6, #0
 8000b10:	d110      	bne.n	8000b34 <__lesf2+0x5c>
 8000b12:	2cff      	cmp	r4, #255	; 0xff
 8000b14:	d115      	bne.n	8000b42 <__lesf2+0x6a>
 8000b16:	2d00      	cmp	r5, #0
 8000b18:	d10c      	bne.n	8000b34 <__lesf2+0x5c>
 8000b1a:	2a00      	cmp	r2, #0
 8000b1c:	d103      	bne.n	8000b26 <__lesf2+0x4e>
 8000b1e:	4271      	negs	r1, r6
 8000b20:	4171      	adcs	r1, r6
 8000b22:	2900      	cmp	r1, #0
 8000b24:	d108      	bne.n	8000b38 <__lesf2+0x60>
 8000b26:	4283      	cmp	r3, r0
 8000b28:	d010      	beq.n	8000b4c <__lesf2+0x74>
 8000b2a:	2102      	movs	r1, #2
 8000b2c:	1e58      	subs	r0, r3, #1
 8000b2e:	4008      	ands	r0, r1
 8000b30:	3801      	subs	r0, #1
 8000b32:	e000      	b.n	8000b36 <__lesf2+0x5e>
 8000b34:	2002      	movs	r0, #2
 8000b36:	bdf0      	pop	{r4, r5, r6, r7, pc}
 8000b38:	2800      	cmp	r0, #0
 8000b3a:	d1fc      	bne.n	8000b36 <__lesf2+0x5e>
 8000b3c:	2001      	movs	r0, #1
 8000b3e:	4240      	negs	r0, r0
 8000b40:	e7f9      	b.n	8000b36 <__lesf2+0x5e>
 8000b42:	2c00      	cmp	r4, #0
 8000b44:	d1ef      	bne.n	8000b26 <__lesf2+0x4e>
 8000b46:	2d00      	cmp	r5, #0
 8000b48:	d1ed      	bne.n	8000b26 <__lesf2+0x4e>
 8000b4a:	e7ee      	b.n	8000b2a <__lesf2+0x52>
 8000b4c:	42a2      	cmp	r2, r4
 8000b4e:	dc05      	bgt.n	8000b5c <__lesf2+0x84>
 8000b50:	dbf2      	blt.n	8000b38 <__lesf2+0x60>
 8000b52:	42ae      	cmp	r6, r5
 8000b54:	d802      	bhi.n	8000b5c <__lesf2+0x84>
 8000b56:	d3ef      	bcc.n	8000b38 <__lesf2+0x60>
 8000b58:	2000      	movs	r0, #0
 8000b5a:	e7ec      	b.n	8000b36 <__lesf2+0x5e>
 8000b5c:	4241      	negs	r1, r0
 8000b5e:	4141      	adcs	r1, r0
 8000b60:	4248      	negs	r0, r1
 8000b62:	2102      	movs	r1, #2
 8000b64:	4008      	ands	r0, r1
 8000b66:	3801      	subs	r0, #1
 8000b68:	e7e5      	b.n	8000b36 <__lesf2+0x5e>
 8000b6a:	46c0      	nop			; (mov r8, r8)

08000b6c <__aeabi_fmul>:
 8000b6c:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 8000b6e:	4657      	mov	r7, sl
 8000b70:	464e      	mov	r6, r9
 8000b72:	4645      	mov	r5, r8
 8000b74:	46de      	mov	lr, fp
 8000b76:	0244      	lsls	r4, r0, #9
 8000b78:	b5e0      	push	{r5, r6, r7, lr}
 8000b7a:	0045      	lsls	r5, r0, #1
 8000b7c:	1c0f      	adds	r7, r1, #0
 8000b7e:	0a64      	lsrs	r4, r4, #9
 8000b80:	0e2d      	lsrs	r5, r5, #24
 8000b82:	0fc6      	lsrs	r6, r0, #31
 8000b84:	2d00      	cmp	r5, #0
 8000b86:	d047      	beq.n	8000c18 <__aeabi_fmul+0xac>
 8000b88:	2dff      	cmp	r5, #255	; 0xff
 8000b8a:	d04d      	beq.n	8000c28 <__aeabi_fmul+0xbc>
 8000b8c:	2300      	movs	r3, #0
 8000b8e:	2080      	movs	r0, #128	; 0x80
 8000b90:	469a      	mov	sl, r3
 8000b92:	469b      	mov	fp, r3
 8000b94:	00e4      	lsls	r4, r4, #3
 8000b96:	04c0      	lsls	r0, r0, #19
 8000b98:	4304      	orrs	r4, r0
 8000b9a:	3d7f      	subs	r5, #127	; 0x7f
 8000b9c:	0278      	lsls	r0, r7, #9
 8000b9e:	0a43      	lsrs	r3, r0, #9
 8000ba0:	4699      	mov	r9, r3
 8000ba2:	007a      	lsls	r2, r7, #1
 8000ba4:	0ffb      	lsrs	r3, r7, #31
 8000ba6:	4698      	mov	r8, r3
 8000ba8:	0e12      	lsrs	r2, r2, #24
 8000baa:	464b      	mov	r3, r9
 8000bac:	d044      	beq.n	8000c38 <__aeabi_fmul+0xcc>
 8000bae:	2aff      	cmp	r2, #255	; 0xff
 8000bb0:	d011      	beq.n	8000bd6 <__aeabi_fmul+0x6a>
 8000bb2:	00d8      	lsls	r0, r3, #3
 8000bb4:	2380      	movs	r3, #128	; 0x80
 8000bb6:	04db      	lsls	r3, r3, #19
 8000bb8:	4303      	orrs	r3, r0
 8000bba:	4699      	mov	r9, r3
 8000bbc:	2000      	movs	r0, #0
 8000bbe:	3a7f      	subs	r2, #127	; 0x7f
 8000bc0:	18ad      	adds	r5, r5, r2
 8000bc2:	4647      	mov	r7, r8
 8000bc4:	4653      	mov	r3, sl
 8000bc6:	4077      	eors	r7, r6
 8000bc8:	1c69      	adds	r1, r5, #1
 8000bca:	2b0f      	cmp	r3, #15
 8000bcc:	d83f      	bhi.n	8000c4e <__aeabi_fmul+0xe2>
 8000bce:	4a72      	ldr	r2, [pc, #456]	; (8000d98 <__aeabi_fmul+0x22c>)
 8000bd0:	009b      	lsls	r3, r3, #2
 8000bd2:	58d3      	ldr	r3, [r2, r3]
 8000bd4:	469f      	mov	pc, r3
 8000bd6:	35ff      	adds	r5, #255	; 0xff
 8000bd8:	2b00      	cmp	r3, #0
 8000bda:	d000      	beq.n	8000bde <__aeabi_fmul+0x72>
 8000bdc:	e079      	b.n	8000cd2 <__aeabi_fmul+0x166>
 8000bde:	4652      	mov	r2, sl
 8000be0:	2302      	movs	r3, #2
 8000be2:	431a      	orrs	r2, r3
 8000be4:	4692      	mov	sl, r2
 8000be6:	2002      	movs	r0, #2
 8000be8:	e7eb      	b.n	8000bc2 <__aeabi_fmul+0x56>
 8000bea:	4647      	mov	r7, r8
 8000bec:	464c      	mov	r4, r9
 8000bee:	4683      	mov	fp, r0
 8000bf0:	465b      	mov	r3, fp
 8000bf2:	2b02      	cmp	r3, #2
 8000bf4:	d028      	beq.n	8000c48 <__aeabi_fmul+0xdc>
 8000bf6:	2b03      	cmp	r3, #3
 8000bf8:	d100      	bne.n	8000bfc <__aeabi_fmul+0x90>
 8000bfa:	e0c6      	b.n	8000d8a <__aeabi_fmul+0x21e>
 8000bfc:	2b01      	cmp	r3, #1
 8000bfe:	d14f      	bne.n	8000ca0 <__aeabi_fmul+0x134>
 8000c00:	2000      	movs	r0, #0
 8000c02:	2400      	movs	r4, #0
 8000c04:	05c0      	lsls	r0, r0, #23
 8000c06:	07ff      	lsls	r7, r7, #31
 8000c08:	4320      	orrs	r0, r4
 8000c0a:	4338      	orrs	r0, r7
 8000c0c:	bcf0      	pop	{r4, r5, r6, r7}
 8000c0e:	46bb      	mov	fp, r7
 8000c10:	46b2      	mov	sl, r6
 8000c12:	46a9      	mov	r9, r5
 8000c14:	46a0      	mov	r8, r4
 8000c16:	bdf8      	pop	{r3, r4, r5, r6, r7, pc}
 8000c18:	2c00      	cmp	r4, #0
 8000c1a:	d171      	bne.n	8000d00 <__aeabi_fmul+0x194>
 8000c1c:	2304      	movs	r3, #4
 8000c1e:	469a      	mov	sl, r3
 8000c20:	3b03      	subs	r3, #3
 8000c22:	2500      	movs	r5, #0
 8000c24:	469b      	mov	fp, r3
 8000c26:	e7b9      	b.n	8000b9c <__aeabi_fmul+0x30>
 8000c28:	2c00      	cmp	r4, #0
 8000c2a:	d163      	bne.n	8000cf4 <__aeabi_fmul+0x188>
 8000c2c:	2308      	movs	r3, #8
 8000c2e:	469a      	mov	sl, r3
 8000c30:	3b06      	subs	r3, #6
 8000c32:	25ff      	movs	r5, #255	; 0xff
 8000c34:	469b      	mov	fp, r3
 8000c36:	e7b1      	b.n	8000b9c <__aeabi_fmul+0x30>
 8000c38:	2b00      	cmp	r3, #0
 8000c3a:	d150      	bne.n	8000cde <__aeabi_fmul+0x172>
 8000c3c:	4652      	mov	r2, sl
 8000c3e:	3301      	adds	r3, #1
 8000c40:	431a      	orrs	r2, r3
 8000c42:	4692      	mov	sl, r2
 8000c44:	2001      	movs	r0, #1
 8000c46:	e7bc      	b.n	8000bc2 <__aeabi_fmul+0x56>
 8000c48:	20ff      	movs	r0, #255	; 0xff
 8000c4a:	2400      	movs	r4, #0
 8000c4c:	e7da      	b.n	8000c04 <__aeabi_fmul+0x98>
 8000c4e:	4648      	mov	r0, r9
 8000c50:	0c26      	lsrs	r6, r4, #16
 8000c52:	0424      	lsls	r4, r4, #16
 8000c54:	0c22      	lsrs	r2, r4, #16
 8000c56:	0404      	lsls	r4, r0, #16
 8000c58:	0c24      	lsrs	r4, r4, #16
 8000c5a:	464b      	mov	r3, r9
 8000c5c:	0020      	movs	r0, r4
 8000c5e:	0c1b      	lsrs	r3, r3, #16
 8000c60:	4350      	muls	r0, r2
 8000c62:	4374      	muls	r4, r6
 8000c64:	435a      	muls	r2, r3
 8000c66:	435e      	muls	r6, r3
 8000c68:	1912      	adds	r2, r2, r4
 8000c6a:	0c03      	lsrs	r3, r0, #16
 8000c6c:	189b      	adds	r3, r3, r2
 8000c6e:	429c      	cmp	r4, r3
 8000c70:	d903      	bls.n	8000c7a <__aeabi_fmul+0x10e>
 8000c72:	2280      	movs	r2, #128	; 0x80
 8000c74:	0252      	lsls	r2, r2, #9
 8000c76:	4694      	mov	ip, r2
 8000c78:	4466      	add	r6, ip
 8000c7a:	0400      	lsls	r0, r0, #16
 8000c7c:	041a      	lsls	r2, r3, #16
 8000c7e:	0c00      	lsrs	r0, r0, #16
 8000c80:	1812      	adds	r2, r2, r0
 8000c82:	0194      	lsls	r4, r2, #6
 8000c84:	1e60      	subs	r0, r4, #1
 8000c86:	4184      	sbcs	r4, r0
 8000c88:	0c1b      	lsrs	r3, r3, #16
 8000c8a:	0e92      	lsrs	r2, r2, #26
 8000c8c:	199b      	adds	r3, r3, r6
 8000c8e:	4314      	orrs	r4, r2
 8000c90:	019b      	lsls	r3, r3, #6
 8000c92:	431c      	orrs	r4, r3
 8000c94:	011b      	lsls	r3, r3, #4
 8000c96:	d572      	bpl.n	8000d7e <__aeabi_fmul+0x212>
 8000c98:	2001      	movs	r0, #1
 8000c9a:	0863      	lsrs	r3, r4, #1
 8000c9c:	4004      	ands	r4, r0
 8000c9e:	431c      	orrs	r4, r3
 8000ca0:	0008      	movs	r0, r1
 8000ca2:	307f      	adds	r0, #127	; 0x7f
 8000ca4:	2800      	cmp	r0, #0
 8000ca6:	dd3c      	ble.n	8000d22 <__aeabi_fmul+0x1b6>
 8000ca8:	0763      	lsls	r3, r4, #29
 8000caa:	d004      	beq.n	8000cb6 <__aeabi_fmul+0x14a>
 8000cac:	230f      	movs	r3, #15
 8000cae:	4023      	ands	r3, r4
 8000cb0:	2b04      	cmp	r3, #4
 8000cb2:	d000      	beq.n	8000cb6 <__aeabi_fmul+0x14a>
 8000cb4:	3404      	adds	r4, #4
 8000cb6:	0123      	lsls	r3, r4, #4
 8000cb8:	d503      	bpl.n	8000cc2 <__aeabi_fmul+0x156>
 8000cba:	3180      	adds	r1, #128	; 0x80
 8000cbc:	0008      	movs	r0, r1
 8000cbe:	4b37      	ldr	r3, [pc, #220]	; (8000d9c <__aeabi_fmul+0x230>)
 8000cc0:	401c      	ands	r4, r3
 8000cc2:	28fe      	cmp	r0, #254	; 0xfe
 8000cc4:	dcc0      	bgt.n	8000c48 <__aeabi_fmul+0xdc>
 8000cc6:	01a4      	lsls	r4, r4, #6
 8000cc8:	0a64      	lsrs	r4, r4, #9
 8000cca:	b2c0      	uxtb	r0, r0
 8000ccc:	e79a      	b.n	8000c04 <__aeabi_fmul+0x98>
 8000cce:	0037      	movs	r7, r6
 8000cd0:	e78e      	b.n	8000bf0 <__aeabi_fmul+0x84>
 8000cd2:	4652      	mov	r2, sl
 8000cd4:	2303      	movs	r3, #3
 8000cd6:	431a      	orrs	r2, r3
 8000cd8:	4692      	mov	sl, r2
 8000cda:	2003      	movs	r0, #3
 8000cdc:	e771      	b.n	8000bc2 <__aeabi_fmul+0x56>
 8000cde:	4648      	mov	r0, r9
 8000ce0:	f002 f86c 	bl	8002dbc <__clzsi2>
 8000ce4:	464a      	mov	r2, r9
 8000ce6:	1f43      	subs	r3, r0, #5
 8000ce8:	409a      	lsls	r2, r3
 8000cea:	1a2d      	subs	r5, r5, r0
 8000cec:	4691      	mov	r9, r2
 8000cee:	2000      	movs	r0, #0
 8000cf0:	3d76      	subs	r5, #118	; 0x76
 8000cf2:	e766      	b.n	8000bc2 <__aeabi_fmul+0x56>
 8000cf4:	230c      	movs	r3, #12
 8000cf6:	469a      	mov	sl, r3
 8000cf8:	3b09      	subs	r3, #9
 8000cfa:	25ff      	movs	r5, #255	; 0xff
 8000cfc:	469b      	mov	fp, r3
 8000cfe:	e74d      	b.n	8000b9c <__aeabi_fmul+0x30>
 8000d00:	0020      	movs	r0, r4
 8000d02:	f002 f85b 	bl	8002dbc <__clzsi2>
 8000d06:	2576      	movs	r5, #118	; 0x76
 8000d08:	1f43      	subs	r3, r0, #5
 8000d0a:	409c      	lsls	r4, r3
 8000d0c:	2300      	movs	r3, #0
 8000d0e:	426d      	negs	r5, r5
 8000d10:	469a      	mov	sl, r3
 8000d12:	469b      	mov	fp, r3
 8000d14:	1a2d      	subs	r5, r5, r0
 8000d16:	e741      	b.n	8000b9c <__aeabi_fmul+0x30>
 8000d18:	2480      	movs	r4, #128	; 0x80
 8000d1a:	2700      	movs	r7, #0
 8000d1c:	20ff      	movs	r0, #255	; 0xff
 8000d1e:	03e4      	lsls	r4, r4, #15
 8000d20:	e770      	b.n	8000c04 <__aeabi_fmul+0x98>
 8000d22:	2301      	movs	r3, #1
 8000d24:	1a1b      	subs	r3, r3, r0
 8000d26:	2b1b      	cmp	r3, #27
 8000d28:	dd00      	ble.n	8000d2c <__aeabi_fmul+0x1c0>
 8000d2a:	e769      	b.n	8000c00 <__aeabi_fmul+0x94>
 8000d2c:	319e      	adds	r1, #158	; 0x9e
 8000d2e:	0020      	movs	r0, r4
 8000d30:	408c      	lsls	r4, r1
 8000d32:	40d8      	lsrs	r0, r3
 8000d34:	1e63      	subs	r3, r4, #1
 8000d36:	419c      	sbcs	r4, r3
 8000d38:	4304      	orrs	r4, r0
 8000d3a:	0763      	lsls	r3, r4, #29
 8000d3c:	d004      	beq.n	8000d48 <__aeabi_fmul+0x1dc>
 8000d3e:	230f      	movs	r3, #15
 8000d40:	4023      	ands	r3, r4
 8000d42:	2b04      	cmp	r3, #4
 8000d44:	d000      	beq.n	8000d48 <__aeabi_fmul+0x1dc>
 8000d46:	3404      	adds	r4, #4
 8000d48:	0163      	lsls	r3, r4, #5
 8000d4a:	d51a      	bpl.n	8000d82 <__aeabi_fmul+0x216>
 8000d4c:	2001      	movs	r0, #1
 8000d4e:	2400      	movs	r4, #0
 8000d50:	e758      	b.n	8000c04 <__aeabi_fmul+0x98>
 8000d52:	2080      	movs	r0, #128	; 0x80
 8000d54:	03c0      	lsls	r0, r0, #15
 8000d56:	4204      	tst	r4, r0
 8000d58:	d009      	beq.n	8000d6e <__aeabi_fmul+0x202>
 8000d5a:	464b      	mov	r3, r9
 8000d5c:	4203      	tst	r3, r0
 8000d5e:	d106      	bne.n	8000d6e <__aeabi_fmul+0x202>
 8000d60:	464c      	mov	r4, r9
 8000d62:	4304      	orrs	r4, r0
 8000d64:	0264      	lsls	r4, r4, #9
 8000d66:	4647      	mov	r7, r8
 8000d68:	20ff      	movs	r0, #255	; 0xff
 8000d6a:	0a64      	lsrs	r4, r4, #9
 8000d6c:	e74a      	b.n	8000c04 <__aeabi_fmul+0x98>
 8000d6e:	2080      	movs	r0, #128	; 0x80
 8000d70:	03c0      	lsls	r0, r0, #15
 8000d72:	4304      	orrs	r4, r0
 8000d74:	0264      	lsls	r4, r4, #9
 8000d76:	0037      	movs	r7, r6
 8000d78:	20ff      	movs	r0, #255	; 0xff
 8000d7a:	0a64      	lsrs	r4, r4, #9
 8000d7c:	e742      	b.n	8000c04 <__aeabi_fmul+0x98>
 8000d7e:	0029      	movs	r1, r5
 8000d80:	e78e      	b.n	8000ca0 <__aeabi_fmul+0x134>
 8000d82:	01a4      	lsls	r4, r4, #6
 8000d84:	2000      	movs	r0, #0
 8000d86:	0a64      	lsrs	r4, r4, #9
 8000d88:	e73c      	b.n	8000c04 <__aeabi_fmul+0x98>
 8000d8a:	2080      	movs	r0, #128	; 0x80
 8000d8c:	03c0      	lsls	r0, r0, #15
 8000d8e:	4304      	orrs	r4, r0
 8000d90:	0264      	lsls	r4, r4, #9
 8000d92:	20ff      	movs	r0, #255	; 0xff
 8000d94:	0a64      	lsrs	r4, r4, #9
 8000d96:	e735      	b.n	8000c04 <__aeabi_fmul+0x98>
 8000d98:	0800e580 	.word	0x0800e580
 8000d9c:	f7ffffff 	.word	0xf7ffffff

08000da0 <__aeabi_fsub>:
 8000da0:	b5f0      	push	{r4, r5, r6, r7, lr}
 8000da2:	4646      	mov	r6, r8
 8000da4:	46d6      	mov	lr, sl
 8000da6:	464f      	mov	r7, r9
 8000da8:	0243      	lsls	r3, r0, #9
 8000daa:	0a5b      	lsrs	r3, r3, #9
 8000dac:	00da      	lsls	r2, r3, #3
 8000dae:	4694      	mov	ip, r2
 8000db0:	024a      	lsls	r2, r1, #9
 8000db2:	b5c0      	push	{r6, r7, lr}
 8000db4:	0044      	lsls	r4, r0, #1
 8000db6:	0a56      	lsrs	r6, r2, #9
 8000db8:	1c05      	adds	r5, r0, #0
 8000dba:	46b0      	mov	r8, r6
 8000dbc:	0e24      	lsrs	r4, r4, #24
 8000dbe:	004e      	lsls	r6, r1, #1
 8000dc0:	0992      	lsrs	r2, r2, #6
 8000dc2:	001f      	movs	r7, r3
 8000dc4:	0020      	movs	r0, r4
 8000dc6:	4692      	mov	sl, r2
 8000dc8:	0fed      	lsrs	r5, r5, #31
 8000dca:	0e36      	lsrs	r6, r6, #24
 8000dcc:	0fc9      	lsrs	r1, r1, #31
 8000dce:	2eff      	cmp	r6, #255	; 0xff
 8000dd0:	d100      	bne.n	8000dd4 <__aeabi_fsub+0x34>
 8000dd2:	e07f      	b.n	8000ed4 <__aeabi_fsub+0x134>
 8000dd4:	2201      	movs	r2, #1
 8000dd6:	4051      	eors	r1, r2
 8000dd8:	428d      	cmp	r5, r1
 8000dda:	d051      	beq.n	8000e80 <__aeabi_fsub+0xe0>
 8000ddc:	1ba2      	subs	r2, r4, r6
 8000dde:	4691      	mov	r9, r2
 8000de0:	2a00      	cmp	r2, #0
 8000de2:	dc00      	bgt.n	8000de6 <__aeabi_fsub+0x46>
 8000de4:	e07e      	b.n	8000ee4 <__aeabi_fsub+0x144>
 8000de6:	2e00      	cmp	r6, #0
 8000de8:	d100      	bne.n	8000dec <__aeabi_fsub+0x4c>
 8000dea:	e099      	b.n	8000f20 <__aeabi_fsub+0x180>
 8000dec:	2cff      	cmp	r4, #255	; 0xff
 8000dee:	d100      	bne.n	8000df2 <__aeabi_fsub+0x52>
 8000df0:	e08c      	b.n	8000f0c <__aeabi_fsub+0x16c>
 8000df2:	2380      	movs	r3, #128	; 0x80
 8000df4:	4652      	mov	r2, sl
 8000df6:	04db      	lsls	r3, r3, #19
 8000df8:	431a      	orrs	r2, r3
 8000dfa:	4692      	mov	sl, r2
 8000dfc:	464a      	mov	r2, r9
 8000dfe:	2301      	movs	r3, #1
 8000e00:	2a1b      	cmp	r2, #27
 8000e02:	dc08      	bgt.n	8000e16 <__aeabi_fsub+0x76>
 8000e04:	4653      	mov	r3, sl
 8000e06:	2120      	movs	r1, #32
 8000e08:	40d3      	lsrs	r3, r2
 8000e0a:	1a89      	subs	r1, r1, r2
 8000e0c:	4652      	mov	r2, sl
 8000e0e:	408a      	lsls	r2, r1
 8000e10:	1e51      	subs	r1, r2, #1
 8000e12:	418a      	sbcs	r2, r1
 8000e14:	4313      	orrs	r3, r2
 8000e16:	4662      	mov	r2, ip
 8000e18:	1ad3      	subs	r3, r2, r3
 8000e1a:	015a      	lsls	r2, r3, #5
 8000e1c:	d400      	bmi.n	8000e20 <__aeabi_fsub+0x80>
 8000e1e:	e0f3      	b.n	8001008 <__aeabi_fsub+0x268>
 8000e20:	019b      	lsls	r3, r3, #6
 8000e22:	099e      	lsrs	r6, r3, #6
 8000e24:	0030      	movs	r0, r6
 8000e26:	f001 ffc9 	bl	8002dbc <__clzsi2>
 8000e2a:	3805      	subs	r0, #5
 8000e2c:	4086      	lsls	r6, r0
 8000e2e:	4284      	cmp	r4, r0
 8000e30:	dd00      	ble.n	8000e34 <__aeabi_fsub+0x94>
 8000e32:	e0f7      	b.n	8001024 <__aeabi_fsub+0x284>
 8000e34:	0032      	movs	r2, r6
 8000e36:	1b04      	subs	r4, r0, r4
 8000e38:	2020      	movs	r0, #32
 8000e3a:	3401      	adds	r4, #1
 8000e3c:	40e2      	lsrs	r2, r4
 8000e3e:	1b04      	subs	r4, r0, r4
 8000e40:	40a6      	lsls	r6, r4
 8000e42:	0033      	movs	r3, r6
 8000e44:	1e5e      	subs	r6, r3, #1
 8000e46:	41b3      	sbcs	r3, r6
 8000e48:	2400      	movs	r4, #0
 8000e4a:	4313      	orrs	r3, r2
 8000e4c:	075a      	lsls	r2, r3, #29
 8000e4e:	d004      	beq.n	8000e5a <__aeabi_fsub+0xba>
 8000e50:	220f      	movs	r2, #15
 8000e52:	401a      	ands	r2, r3
 8000e54:	2a04      	cmp	r2, #4
 8000e56:	d000      	beq.n	8000e5a <__aeabi_fsub+0xba>
 8000e58:	3304      	adds	r3, #4
 8000e5a:	015a      	lsls	r2, r3, #5
 8000e5c:	d400      	bmi.n	8000e60 <__aeabi_fsub+0xc0>
 8000e5e:	e0d6      	b.n	800100e <__aeabi_fsub+0x26e>
 8000e60:	1c62      	adds	r2, r4, #1
 8000e62:	2cfe      	cmp	r4, #254	; 0xfe
 8000e64:	d100      	bne.n	8000e68 <__aeabi_fsub+0xc8>
 8000e66:	e0da      	b.n	800101e <__aeabi_fsub+0x27e>
 8000e68:	019b      	lsls	r3, r3, #6
 8000e6a:	0a5f      	lsrs	r7, r3, #9
 8000e6c:	b2d0      	uxtb	r0, r2
 8000e6e:	05c0      	lsls	r0, r0, #23
 8000e70:	4338      	orrs	r0, r7
 8000e72:	07ed      	lsls	r5, r5, #31
 8000e74:	4328      	orrs	r0, r5
 8000e76:	bce0      	pop	{r5, r6, r7}
 8000e78:	46ba      	mov	sl, r7
 8000e7a:	46b1      	mov	r9, r6
 8000e7c:	46a8      	mov	r8, r5
 8000e7e:	bdf0      	pop	{r4, r5, r6, r7, pc}
 8000e80:	1ba2      	subs	r2, r4, r6
 8000e82:	4691      	mov	r9, r2
 8000e84:	2a00      	cmp	r2, #0
 8000e86:	dd63      	ble.n	8000f50 <__aeabi_fsub+0x1b0>
 8000e88:	2e00      	cmp	r6, #0
 8000e8a:	d100      	bne.n	8000e8e <__aeabi_fsub+0xee>
 8000e8c:	e099      	b.n	8000fc2 <__aeabi_fsub+0x222>
 8000e8e:	2cff      	cmp	r4, #255	; 0xff
 8000e90:	d03c      	beq.n	8000f0c <__aeabi_fsub+0x16c>
 8000e92:	2380      	movs	r3, #128	; 0x80
 8000e94:	4652      	mov	r2, sl
 8000e96:	04db      	lsls	r3, r3, #19
 8000e98:	431a      	orrs	r2, r3
 8000e9a:	4692      	mov	sl, r2
 8000e9c:	464a      	mov	r2, r9
 8000e9e:	2301      	movs	r3, #1
 8000ea0:	2a1b      	cmp	r2, #27
 8000ea2:	dc08      	bgt.n	8000eb6 <__aeabi_fsub+0x116>
 8000ea4:	4653      	mov	r3, sl
 8000ea6:	2120      	movs	r1, #32
 8000ea8:	40d3      	lsrs	r3, r2
 8000eaa:	1a89      	subs	r1, r1, r2
 8000eac:	4652      	mov	r2, sl
 8000eae:	408a      	lsls	r2, r1
 8000eb0:	1e51      	subs	r1, r2, #1
 8000eb2:	418a      	sbcs	r2, r1
 8000eb4:	4313      	orrs	r3, r2
 8000eb6:	4463      	add	r3, ip
 8000eb8:	015a      	lsls	r2, r3, #5
 8000eba:	d400      	bmi.n	8000ebe <__aeabi_fsub+0x11e>
 8000ebc:	e0a4      	b.n	8001008 <__aeabi_fsub+0x268>
 8000ebe:	3401      	adds	r4, #1
 8000ec0:	2cff      	cmp	r4, #255	; 0xff
 8000ec2:	d100      	bne.n	8000ec6 <__aeabi_fsub+0x126>
 8000ec4:	e0ab      	b.n	800101e <__aeabi_fsub+0x27e>
 8000ec6:	2201      	movs	r2, #1
 8000ec8:	4997      	ldr	r1, [pc, #604]	; (8001128 <__aeabi_fsub+0x388>)
 8000eca:	401a      	ands	r2, r3
 8000ecc:	085b      	lsrs	r3, r3, #1
 8000ece:	400b      	ands	r3, r1
 8000ed0:	4313      	orrs	r3, r2
 8000ed2:	e7bb      	b.n	8000e4c <__aeabi_fsub+0xac>
 8000ed4:	2a00      	cmp	r2, #0
 8000ed6:	d032      	beq.n	8000f3e <__aeabi_fsub+0x19e>
 8000ed8:	428d      	cmp	r5, r1
 8000eda:	d035      	beq.n	8000f48 <__aeabi_fsub+0x1a8>
 8000edc:	22ff      	movs	r2, #255	; 0xff
 8000ede:	4252      	negs	r2, r2
 8000ee0:	4691      	mov	r9, r2
 8000ee2:	44a1      	add	r9, r4
 8000ee4:	464a      	mov	r2, r9
 8000ee6:	2a00      	cmp	r2, #0
 8000ee8:	d051      	beq.n	8000f8e <__aeabi_fsub+0x1ee>
 8000eea:	1b30      	subs	r0, r6, r4
 8000eec:	2c00      	cmp	r4, #0
 8000eee:	d000      	beq.n	8000ef2 <__aeabi_fsub+0x152>
 8000ef0:	e09c      	b.n	800102c <__aeabi_fsub+0x28c>
 8000ef2:	4663      	mov	r3, ip
 8000ef4:	2b00      	cmp	r3, #0
 8000ef6:	d100      	bne.n	8000efa <__aeabi_fsub+0x15a>
 8000ef8:	e0df      	b.n	80010ba <__aeabi_fsub+0x31a>
 8000efa:	3801      	subs	r0, #1
 8000efc:	2800      	cmp	r0, #0
 8000efe:	d100      	bne.n	8000f02 <__aeabi_fsub+0x162>
 8000f00:	e0f7      	b.n	80010f2 <__aeabi_fsub+0x352>
 8000f02:	2eff      	cmp	r6, #255	; 0xff
 8000f04:	d000      	beq.n	8000f08 <__aeabi_fsub+0x168>
 8000f06:	e099      	b.n	800103c <__aeabi_fsub+0x29c>
 8000f08:	000d      	movs	r5, r1
 8000f0a:	4643      	mov	r3, r8
 8000f0c:	2b00      	cmp	r3, #0
 8000f0e:	d100      	bne.n	8000f12 <__aeabi_fsub+0x172>
 8000f10:	e085      	b.n	800101e <__aeabi_fsub+0x27e>
 8000f12:	2780      	movs	r7, #128	; 0x80
 8000f14:	03ff      	lsls	r7, r7, #15
 8000f16:	431f      	orrs	r7, r3
 8000f18:	027f      	lsls	r7, r7, #9
 8000f1a:	20ff      	movs	r0, #255	; 0xff
 8000f1c:	0a7f      	lsrs	r7, r7, #9
 8000f1e:	e7a6      	b.n	8000e6e <__aeabi_fsub+0xce>
 8000f20:	4652      	mov	r2, sl
 8000f22:	2a00      	cmp	r2, #0
 8000f24:	d074      	beq.n	8001010 <__aeabi_fsub+0x270>
 8000f26:	2201      	movs	r2, #1
 8000f28:	4252      	negs	r2, r2
 8000f2a:	4690      	mov	r8, r2
 8000f2c:	44c1      	add	r9, r8
 8000f2e:	464a      	mov	r2, r9
 8000f30:	2a00      	cmp	r2, #0
 8000f32:	d100      	bne.n	8000f36 <__aeabi_fsub+0x196>
 8000f34:	e0c8      	b.n	80010c8 <__aeabi_fsub+0x328>
 8000f36:	2cff      	cmp	r4, #255	; 0xff
 8000f38:	d000      	beq.n	8000f3c <__aeabi_fsub+0x19c>
 8000f3a:	e75f      	b.n	8000dfc <__aeabi_fsub+0x5c>
 8000f3c:	e7e6      	b.n	8000f0c <__aeabi_fsub+0x16c>
 8000f3e:	2201      	movs	r2, #1
 8000f40:	4051      	eors	r1, r2
 8000f42:	42a9      	cmp	r1, r5
 8000f44:	d000      	beq.n	8000f48 <__aeabi_fsub+0x1a8>
 8000f46:	e749      	b.n	8000ddc <__aeabi_fsub+0x3c>
 8000f48:	22ff      	movs	r2, #255	; 0xff
 8000f4a:	4252      	negs	r2, r2
 8000f4c:	4691      	mov	r9, r2
 8000f4e:	44a1      	add	r9, r4
 8000f50:	464a      	mov	r2, r9
 8000f52:	2a00      	cmp	r2, #0
 8000f54:	d043      	beq.n	8000fde <__aeabi_fsub+0x23e>
 8000f56:	1b31      	subs	r1, r6, r4
 8000f58:	2c00      	cmp	r4, #0
 8000f5a:	d100      	bne.n	8000f5e <__aeabi_fsub+0x1be>
 8000f5c:	e08c      	b.n	8001078 <__aeabi_fsub+0x2d8>
 8000f5e:	2eff      	cmp	r6, #255	; 0xff
 8000f60:	d100      	bne.n	8000f64 <__aeabi_fsub+0x1c4>
 8000f62:	e092      	b.n	800108a <__aeabi_fsub+0x2ea>
 8000f64:	2380      	movs	r3, #128	; 0x80
 8000f66:	4662      	mov	r2, ip
 8000f68:	04db      	lsls	r3, r3, #19
 8000f6a:	431a      	orrs	r2, r3
 8000f6c:	4694      	mov	ip, r2
 8000f6e:	2301      	movs	r3, #1
 8000f70:	291b      	cmp	r1, #27
 8000f72:	dc09      	bgt.n	8000f88 <__aeabi_fsub+0x1e8>
 8000f74:	2020      	movs	r0, #32
 8000f76:	4663      	mov	r3, ip
 8000f78:	4662      	mov	r2, ip
 8000f7a:	40cb      	lsrs	r3, r1
 8000f7c:	1a41      	subs	r1, r0, r1
 8000f7e:	408a      	lsls	r2, r1
 8000f80:	0011      	movs	r1, r2
 8000f82:	1e48      	subs	r0, r1, #1
 8000f84:	4181      	sbcs	r1, r0
 8000f86:	430b      	orrs	r3, r1
 8000f88:	0034      	movs	r4, r6
 8000f8a:	4453      	add	r3, sl
 8000f8c:	e794      	b.n	8000eb8 <__aeabi_fsub+0x118>
 8000f8e:	22fe      	movs	r2, #254	; 0xfe
 8000f90:	1c66      	adds	r6, r4, #1
 8000f92:	4232      	tst	r2, r6
 8000f94:	d164      	bne.n	8001060 <__aeabi_fsub+0x2c0>
 8000f96:	2c00      	cmp	r4, #0
 8000f98:	d000      	beq.n	8000f9c <__aeabi_fsub+0x1fc>
 8000f9a:	e082      	b.n	80010a2 <__aeabi_fsub+0x302>
 8000f9c:	4663      	mov	r3, ip
 8000f9e:	2b00      	cmp	r3, #0
 8000fa0:	d100      	bne.n	8000fa4 <__aeabi_fsub+0x204>
 8000fa2:	e0ab      	b.n	80010fc <__aeabi_fsub+0x35c>
 8000fa4:	4653      	mov	r3, sl
 8000fa6:	2b00      	cmp	r3, #0
 8000fa8:	d100      	bne.n	8000fac <__aeabi_fsub+0x20c>
 8000faa:	e760      	b.n	8000e6e <__aeabi_fsub+0xce>
 8000fac:	4663      	mov	r3, ip
 8000fae:	4652      	mov	r2, sl
 8000fb0:	1a9b      	subs	r3, r3, r2
 8000fb2:	015a      	lsls	r2, r3, #5
 8000fb4:	d400      	bmi.n	8000fb8 <__aeabi_fsub+0x218>
 8000fb6:	e0aa      	b.n	800110e <__aeabi_fsub+0x36e>
 8000fb8:	4663      	mov	r3, ip
 8000fba:	4652      	mov	r2, sl
 8000fbc:	000d      	movs	r5, r1
 8000fbe:	1ad3      	subs	r3, r2, r3
 8000fc0:	e744      	b.n	8000e4c <__aeabi_fsub+0xac>
 8000fc2:	4652      	mov	r2, sl
 8000fc4:	2a00      	cmp	r2, #0
 8000fc6:	d023      	beq.n	8001010 <__aeabi_fsub+0x270>
 8000fc8:	2201      	movs	r2, #1
 8000fca:	4252      	negs	r2, r2
 8000fcc:	4690      	mov	r8, r2
 8000fce:	44c1      	add	r9, r8
 8000fd0:	464a      	mov	r2, r9
 8000fd2:	2a00      	cmp	r2, #0
 8000fd4:	d075      	beq.n	80010c2 <__aeabi_fsub+0x322>
 8000fd6:	2cff      	cmp	r4, #255	; 0xff
 8000fd8:	d000      	beq.n	8000fdc <__aeabi_fsub+0x23c>
 8000fda:	e75f      	b.n	8000e9c <__aeabi_fsub+0xfc>
 8000fdc:	e796      	b.n	8000f0c <__aeabi_fsub+0x16c>
 8000fde:	26fe      	movs	r6, #254	; 0xfe
 8000fe0:	3401      	adds	r4, #1
 8000fe2:	4226      	tst	r6, r4
 8000fe4:	d153      	bne.n	800108e <__aeabi_fsub+0x2ee>
 8000fe6:	2800      	cmp	r0, #0
 8000fe8:	d172      	bne.n	80010d0 <__aeabi_fsub+0x330>
 8000fea:	4663      	mov	r3, ip
 8000fec:	2b00      	cmp	r3, #0
 8000fee:	d100      	bne.n	8000ff2 <__aeabi_fsub+0x252>
 8000ff0:	e093      	b.n	800111a <__aeabi_fsub+0x37a>
 8000ff2:	4653      	mov	r3, sl
 8000ff4:	2b00      	cmp	r3, #0
 8000ff6:	d100      	bne.n	8000ffa <__aeabi_fsub+0x25a>
 8000ff8:	e739      	b.n	8000e6e <__aeabi_fsub+0xce>
 8000ffa:	4463      	add	r3, ip
 8000ffc:	2400      	movs	r4, #0
 8000ffe:	015a      	lsls	r2, r3, #5
 8001000:	d502      	bpl.n	8001008 <__aeabi_fsub+0x268>
 8001002:	4a4a      	ldr	r2, [pc, #296]	; (800112c <__aeabi_fsub+0x38c>)
 8001004:	3401      	adds	r4, #1
 8001006:	4013      	ands	r3, r2
 8001008:	075a      	lsls	r2, r3, #29
 800100a:	d000      	beq.n	800100e <__aeabi_fsub+0x26e>
 800100c:	e720      	b.n	8000e50 <__aeabi_fsub+0xb0>
 800100e:	08db      	lsrs	r3, r3, #3
 8001010:	2cff      	cmp	r4, #255	; 0xff
 8001012:	d100      	bne.n	8001016 <__aeabi_fsub+0x276>
 8001014:	e77a      	b.n	8000f0c <__aeabi_fsub+0x16c>
 8001016:	025b      	lsls	r3, r3, #9
 8001018:	0a5f      	lsrs	r7, r3, #9
 800101a:	b2e0      	uxtb	r0, r4
 800101c:	e727      	b.n	8000e6e <__aeabi_fsub+0xce>
 800101e:	20ff      	movs	r0, #255	; 0xff
 8001020:	2700      	movs	r7, #0
 8001022:	e724      	b.n	8000e6e <__aeabi_fsub+0xce>
 8001024:	4b41      	ldr	r3, [pc, #260]	; (800112c <__aeabi_fsub+0x38c>)
 8001026:	1a24      	subs	r4, r4, r0
 8001028:	4033      	ands	r3, r6
 800102a:	e70f      	b.n	8000e4c <__aeabi_fsub+0xac>
 800102c:	2eff      	cmp	r6, #255	; 0xff
 800102e:	d100      	bne.n	8001032 <__aeabi_fsub+0x292>
 8001030:	e76a      	b.n	8000f08 <__aeabi_fsub+0x168>
 8001032:	2380      	movs	r3, #128	; 0x80
 8001034:	4662      	mov	r2, ip
 8001036:	04db      	lsls	r3, r3, #19
 8001038:	431a      	orrs	r2, r3
 800103a:	4694      	mov	ip, r2
 800103c:	2301      	movs	r3, #1
 800103e:	281b      	cmp	r0, #27
 8001040:	dc09      	bgt.n	8001056 <__aeabi_fsub+0x2b6>
 8001042:	2420      	movs	r4, #32
 8001044:	4663      	mov	r3, ip
 8001046:	4662      	mov	r2, ip
 8001048:	40c3      	lsrs	r3, r0
 800104a:	1a20      	subs	r0, r4, r0
 800104c:	4082      	lsls	r2, r0
 800104e:	0010      	movs	r0, r2
 8001050:	1e44      	subs	r4, r0, #1
 8001052:	41a0      	sbcs	r0, r4
 8001054:	4303      	orrs	r3, r0
 8001056:	4652      	mov	r2, sl
 8001058:	000d      	movs	r5, r1
 800105a:	0034      	movs	r4, r6
 800105c:	1ad3      	subs	r3, r2, r3
 800105e:	e6dc      	b.n	8000e1a <__aeabi_fsub+0x7a>
 8001060:	4663      	mov	r3, ip
 8001062:	4652      	mov	r2, sl
 8001064:	1a9e      	subs	r6, r3, r2
 8001066:	0173      	lsls	r3, r6, #5
 8001068:	d417      	bmi.n	800109a <__aeabi_fsub+0x2fa>
 800106a:	2e00      	cmp	r6, #0
 800106c:	d000      	beq.n	8001070 <__aeabi_fsub+0x2d0>
 800106e:	e6d9      	b.n	8000e24 <__aeabi_fsub+0x84>
 8001070:	2500      	movs	r5, #0
 8001072:	2000      	movs	r0, #0
 8001074:	2700      	movs	r7, #0
 8001076:	e6fa      	b.n	8000e6e <__aeabi_fsub+0xce>
 8001078:	4663      	mov	r3, ip
 800107a:	2b00      	cmp	r3, #0
 800107c:	d044      	beq.n	8001108 <__aeabi_fsub+0x368>
 800107e:	3901      	subs	r1, #1
 8001080:	2900      	cmp	r1, #0
 8001082:	d04c      	beq.n	800111e <__aeabi_fsub+0x37e>
 8001084:	2eff      	cmp	r6, #255	; 0xff
 8001086:	d000      	beq.n	800108a <__aeabi_fsub+0x2ea>
 8001088:	e771      	b.n	8000f6e <__aeabi_fsub+0x1ce>
 800108a:	4643      	mov	r3, r8
 800108c:	e73e      	b.n	8000f0c <__aeabi_fsub+0x16c>
 800108e:	2cff      	cmp	r4, #255	; 0xff
 8001090:	d0c5      	beq.n	800101e <__aeabi_fsub+0x27e>
 8001092:	4652      	mov	r2, sl
 8001094:	4462      	add	r2, ip
 8001096:	0853      	lsrs	r3, r2, #1
 8001098:	e7b6      	b.n	8001008 <__aeabi_fsub+0x268>
 800109a:	4663      	mov	r3, ip
 800109c:	000d      	movs	r5, r1
 800109e:	1ad6      	subs	r6, r2, r3
 80010a0:	e6c0      	b.n	8000e24 <__aeabi_fsub+0x84>
 80010a2:	4662      	mov	r2, ip
 80010a4:	2a00      	cmp	r2, #0
 80010a6:	d116      	bne.n	80010d6 <__aeabi_fsub+0x336>
 80010a8:	4653      	mov	r3, sl
 80010aa:	2b00      	cmp	r3, #0
 80010ac:	d000      	beq.n	80010b0 <__aeabi_fsub+0x310>
 80010ae:	e72b      	b.n	8000f08 <__aeabi_fsub+0x168>
 80010b0:	2780      	movs	r7, #128	; 0x80
 80010b2:	2500      	movs	r5, #0
 80010b4:	20ff      	movs	r0, #255	; 0xff
 80010b6:	03ff      	lsls	r7, r7, #15
 80010b8:	e6d9      	b.n	8000e6e <__aeabi_fsub+0xce>
 80010ba:	000d      	movs	r5, r1
 80010bc:	4643      	mov	r3, r8
 80010be:	0034      	movs	r4, r6
 80010c0:	e7a6      	b.n	8001010 <__aeabi_fsub+0x270>
 80010c2:	4653      	mov	r3, sl
 80010c4:	4463      	add	r3, ip
 80010c6:	e6f7      	b.n	8000eb8 <__aeabi_fsub+0x118>
 80010c8:	4663      	mov	r3, ip
 80010ca:	4652      	mov	r2, sl
 80010cc:	1a9b      	subs	r3, r3, r2
 80010ce:	e6a4      	b.n	8000e1a <__aeabi_fsub+0x7a>
 80010d0:	4662      	mov	r2, ip
 80010d2:	2a00      	cmp	r2, #0
 80010d4:	d0d9      	beq.n	800108a <__aeabi_fsub+0x2ea>
 80010d6:	4652      	mov	r2, sl
 80010d8:	2a00      	cmp	r2, #0
 80010da:	d100      	bne.n	80010de <__aeabi_fsub+0x33e>
 80010dc:	e716      	b.n	8000f0c <__aeabi_fsub+0x16c>
 80010de:	2280      	movs	r2, #128	; 0x80
 80010e0:	03d2      	lsls	r2, r2, #15
 80010e2:	4213      	tst	r3, r2
 80010e4:	d100      	bne.n	80010e8 <__aeabi_fsub+0x348>
 80010e6:	e711      	b.n	8000f0c <__aeabi_fsub+0x16c>
 80010e8:	4640      	mov	r0, r8
 80010ea:	4210      	tst	r0, r2
 80010ec:	d000      	beq.n	80010f0 <__aeabi_fsub+0x350>
 80010ee:	e70d      	b.n	8000f0c <__aeabi_fsub+0x16c>
 80010f0:	e70a      	b.n	8000f08 <__aeabi_fsub+0x168>
 80010f2:	4652      	mov	r2, sl
 80010f4:	000d      	movs	r5, r1
 80010f6:	0034      	movs	r4, r6
 80010f8:	1ad3      	subs	r3, r2, r3
 80010fa:	e68e      	b.n	8000e1a <__aeabi_fsub+0x7a>
 80010fc:	4653      	mov	r3, sl
 80010fe:	2b00      	cmp	r3, #0
 8001100:	d008      	beq.n	8001114 <__aeabi_fsub+0x374>
 8001102:	000d      	movs	r5, r1
 8001104:	4647      	mov	r7, r8
 8001106:	e6b2      	b.n	8000e6e <__aeabi_fsub+0xce>
 8001108:	4643      	mov	r3, r8
 800110a:	0034      	movs	r4, r6
 800110c:	e780      	b.n	8001010 <__aeabi_fsub+0x270>
 800110e:	2b00      	cmp	r3, #0
 8001110:	d000      	beq.n	8001114 <__aeabi_fsub+0x374>
 8001112:	e779      	b.n	8001008 <__aeabi_fsub+0x268>
 8001114:	2500      	movs	r5, #0
 8001116:	2700      	movs	r7, #0
 8001118:	e6a9      	b.n	8000e6e <__aeabi_fsub+0xce>
 800111a:	4647      	mov	r7, r8
 800111c:	e6a7      	b.n	8000e6e <__aeabi_fsub+0xce>
 800111e:	4653      	mov	r3, sl
 8001120:	0034      	movs	r4, r6
 8001122:	4463      	add	r3, ip
 8001124:	e6c8      	b.n	8000eb8 <__aeabi_fsub+0x118>
 8001126:	46c0      	nop			; (mov r8, r8)
 8001128:	7dffffff 	.word	0x7dffffff
 800112c:	fbffffff 	.word	0xfbffffff

08001130 <__aeabi_i2f>:
 8001130:	b570      	push	{r4, r5, r6, lr}
 8001132:	2800      	cmp	r0, #0
 8001134:	d013      	beq.n	800115e <__aeabi_i2f+0x2e>
 8001136:	17c3      	asrs	r3, r0, #31
 8001138:	18c5      	adds	r5, r0, r3
 800113a:	405d      	eors	r5, r3
 800113c:	0fc4      	lsrs	r4, r0, #31
 800113e:	0028      	movs	r0, r5
 8001140:	f001 fe3c 	bl	8002dbc <__clzsi2>
 8001144:	239e      	movs	r3, #158	; 0x9e
 8001146:	0001      	movs	r1, r0
 8001148:	1a1b      	subs	r3, r3, r0
 800114a:	2b96      	cmp	r3, #150	; 0x96
 800114c:	dc0f      	bgt.n	800116e <__aeabi_i2f+0x3e>
 800114e:	2808      	cmp	r0, #8
 8001150:	dd01      	ble.n	8001156 <__aeabi_i2f+0x26>
 8001152:	3908      	subs	r1, #8
 8001154:	408d      	lsls	r5, r1
 8001156:	026d      	lsls	r5, r5, #9
 8001158:	0a6d      	lsrs	r5, r5, #9
 800115a:	b2d8      	uxtb	r0, r3
 800115c:	e002      	b.n	8001164 <__aeabi_i2f+0x34>
 800115e:	2400      	movs	r4, #0
 8001160:	2000      	movs	r0, #0
 8001162:	2500      	movs	r5, #0
 8001164:	05c0      	lsls	r0, r0, #23
 8001166:	4328      	orrs	r0, r5
 8001168:	07e4      	lsls	r4, r4, #31
 800116a:	4320      	orrs	r0, r4
 800116c:	bd70      	pop	{r4, r5, r6, pc}
 800116e:	2b99      	cmp	r3, #153	; 0x99
 8001170:	dd0b      	ble.n	800118a <__aeabi_i2f+0x5a>
 8001172:	2205      	movs	r2, #5
 8001174:	002e      	movs	r6, r5
 8001176:	1a12      	subs	r2, r2, r0
 8001178:	40d6      	lsrs	r6, r2
 800117a:	0002      	movs	r2, r0
 800117c:	321b      	adds	r2, #27
 800117e:	4095      	lsls	r5, r2
 8001180:	0028      	movs	r0, r5
 8001182:	1e45      	subs	r5, r0, #1
 8001184:	41a8      	sbcs	r0, r5
 8001186:	0035      	movs	r5, r6
 8001188:	4305      	orrs	r5, r0
 800118a:	2905      	cmp	r1, #5
 800118c:	dd01      	ble.n	8001192 <__aeabi_i2f+0x62>
 800118e:	1f4a      	subs	r2, r1, #5
 8001190:	4095      	lsls	r5, r2
 8001192:	002a      	movs	r2, r5
 8001194:	4e08      	ldr	r6, [pc, #32]	; (80011b8 <__aeabi_i2f+0x88>)
 8001196:	4032      	ands	r2, r6
 8001198:	0768      	lsls	r0, r5, #29
 800119a:	d009      	beq.n	80011b0 <__aeabi_i2f+0x80>
 800119c:	200f      	movs	r0, #15
 800119e:	4028      	ands	r0, r5
 80011a0:	2804      	cmp	r0, #4
 80011a2:	d005      	beq.n	80011b0 <__aeabi_i2f+0x80>
 80011a4:	3204      	adds	r2, #4
 80011a6:	0150      	lsls	r0, r2, #5
 80011a8:	d502      	bpl.n	80011b0 <__aeabi_i2f+0x80>
 80011aa:	239f      	movs	r3, #159	; 0x9f
 80011ac:	4032      	ands	r2, r6
 80011ae:	1a5b      	subs	r3, r3, r1
 80011b0:	0192      	lsls	r2, r2, #6
 80011b2:	0a55      	lsrs	r5, r2, #9
 80011b4:	b2d8      	uxtb	r0, r3
 80011b6:	e7d5      	b.n	8001164 <__aeabi_i2f+0x34>
 80011b8:	fbffffff 	.word	0xfbffffff

080011bc <__aeabi_ui2f>:
 80011bc:	b570      	push	{r4, r5, r6, lr}
 80011be:	1e05      	subs	r5, r0, #0
 80011c0:	d00e      	beq.n	80011e0 <__aeabi_ui2f+0x24>
 80011c2:	f001 fdfb 	bl	8002dbc <__clzsi2>
 80011c6:	239e      	movs	r3, #158	; 0x9e
 80011c8:	0004      	movs	r4, r0
 80011ca:	1a1b      	subs	r3, r3, r0
 80011cc:	2b96      	cmp	r3, #150	; 0x96
 80011ce:	dc0c      	bgt.n	80011ea <__aeabi_ui2f+0x2e>
 80011d0:	2808      	cmp	r0, #8
 80011d2:	dd01      	ble.n	80011d8 <__aeabi_ui2f+0x1c>
 80011d4:	3c08      	subs	r4, #8
 80011d6:	40a5      	lsls	r5, r4
 80011d8:	026d      	lsls	r5, r5, #9
 80011da:	0a6d      	lsrs	r5, r5, #9
 80011dc:	b2d8      	uxtb	r0, r3
 80011de:	e001      	b.n	80011e4 <__aeabi_ui2f+0x28>
 80011e0:	2000      	movs	r0, #0
 80011e2:	2500      	movs	r5, #0
 80011e4:	05c0      	lsls	r0, r0, #23
 80011e6:	4328      	orrs	r0, r5
 80011e8:	bd70      	pop	{r4, r5, r6, pc}
 80011ea:	2b99      	cmp	r3, #153	; 0x99
 80011ec:	dd09      	ble.n	8001202 <__aeabi_ui2f+0x46>
 80011ee:	0002      	movs	r2, r0
 80011f0:	0029      	movs	r1, r5
 80011f2:	321b      	adds	r2, #27
 80011f4:	4091      	lsls	r1, r2
 80011f6:	1e4a      	subs	r2, r1, #1
 80011f8:	4191      	sbcs	r1, r2
 80011fa:	2205      	movs	r2, #5
 80011fc:	1a12      	subs	r2, r2, r0
 80011fe:	40d5      	lsrs	r5, r2
 8001200:	430d      	orrs	r5, r1
 8001202:	2c05      	cmp	r4, #5
 8001204:	dd01      	ble.n	800120a <__aeabi_ui2f+0x4e>
 8001206:	1f62      	subs	r2, r4, #5
 8001208:	4095      	lsls	r5, r2
 800120a:	0029      	movs	r1, r5
 800120c:	4e08      	ldr	r6, [pc, #32]	; (8001230 <__aeabi_ui2f+0x74>)
 800120e:	4031      	ands	r1, r6
 8001210:	076a      	lsls	r2, r5, #29
 8001212:	d009      	beq.n	8001228 <__aeabi_ui2f+0x6c>
 8001214:	200f      	movs	r0, #15
 8001216:	4028      	ands	r0, r5
 8001218:	2804      	cmp	r0, #4
 800121a:	d005      	beq.n	8001228 <__aeabi_ui2f+0x6c>
 800121c:	3104      	adds	r1, #4
 800121e:	014a      	lsls	r2, r1, #5
 8001220:	d502      	bpl.n	8001228 <__aeabi_ui2f+0x6c>
 8001222:	239f      	movs	r3, #159	; 0x9f
 8001224:	4031      	ands	r1, r6
 8001226:	1b1b      	subs	r3, r3, r4
 8001228:	0189      	lsls	r1, r1, #6
 800122a:	0a4d      	lsrs	r5, r1, #9
 800122c:	b2d8      	uxtb	r0, r3
 800122e:	e7d9      	b.n	80011e4 <__aeabi_ui2f+0x28>
 8001230:	fbffffff 	.word	0xfbffffff

08001234 <__aeabi_dadd>:
 8001234:	b5f0      	push	{r4, r5, r6, r7, lr}
 8001236:	464f      	mov	r7, r9
 8001238:	46d6      	mov	lr, sl
 800123a:	4646      	mov	r6, r8
 800123c:	000d      	movs	r5, r1
 800123e:	0001      	movs	r1, r0
 8001240:	0018      	movs	r0, r3
 8001242:	b5c0      	push	{r6, r7, lr}
 8001244:	0017      	movs	r7, r2
 8001246:	032b      	lsls	r3, r5, #12
 8001248:	0a5a      	lsrs	r2, r3, #9
 800124a:	0f4b      	lsrs	r3, r1, #29
 800124c:	4313      	orrs	r3, r2
 800124e:	00ca      	lsls	r2, r1, #3
 8001250:	4691      	mov	r9, r2
 8001252:	0302      	lsls	r2, r0, #12
 8001254:	006e      	lsls	r6, r5, #1
 8001256:	0041      	lsls	r1, r0, #1
 8001258:	0a52      	lsrs	r2, r2, #9
 800125a:	0fec      	lsrs	r4, r5, #31
 800125c:	0f7d      	lsrs	r5, r7, #29
 800125e:	4315      	orrs	r5, r2
 8001260:	0d76      	lsrs	r6, r6, #21
 8001262:	0d49      	lsrs	r1, r1, #21
 8001264:	0fc0      	lsrs	r0, r0, #31
 8001266:	4682      	mov	sl, r0
 8001268:	46ac      	mov	ip, r5
 800126a:	00ff      	lsls	r7, r7, #3
 800126c:	1a72      	subs	r2, r6, r1
 800126e:	4284      	cmp	r4, r0
 8001270:	d100      	bne.n	8001274 <__aeabi_dadd+0x40>
 8001272:	e098      	b.n	80013a6 <__aeabi_dadd+0x172>
 8001274:	2a00      	cmp	r2, #0
 8001276:	dc00      	bgt.n	800127a <__aeabi_dadd+0x46>
 8001278:	e081      	b.n	800137e <__aeabi_dadd+0x14a>
 800127a:	2900      	cmp	r1, #0
 800127c:	d100      	bne.n	8001280 <__aeabi_dadd+0x4c>
 800127e:	e0b6      	b.n	80013ee <__aeabi_dadd+0x1ba>
 8001280:	49c9      	ldr	r1, [pc, #804]	; (80015a8 <__aeabi_dadd+0x374>)
 8001282:	428e      	cmp	r6, r1
 8001284:	d100      	bne.n	8001288 <__aeabi_dadd+0x54>
 8001286:	e172      	b.n	800156e <__aeabi_dadd+0x33a>
 8001288:	2180      	movs	r1, #128	; 0x80
 800128a:	0028      	movs	r0, r5
 800128c:	0409      	lsls	r1, r1, #16
 800128e:	4308      	orrs	r0, r1
 8001290:	4684      	mov	ip, r0
 8001292:	2a38      	cmp	r2, #56	; 0x38
 8001294:	dd00      	ble.n	8001298 <__aeabi_dadd+0x64>
 8001296:	e15e      	b.n	8001556 <__aeabi_dadd+0x322>
 8001298:	2a1f      	cmp	r2, #31
 800129a:	dd00      	ble.n	800129e <__aeabi_dadd+0x6a>
 800129c:	e1ee      	b.n	800167c <__aeabi_dadd+0x448>
 800129e:	2020      	movs	r0, #32
 80012a0:	0039      	movs	r1, r7
 80012a2:	4665      	mov	r5, ip
 80012a4:	1a80      	subs	r0, r0, r2
 80012a6:	4087      	lsls	r7, r0
 80012a8:	40d1      	lsrs	r1, r2
 80012aa:	4085      	lsls	r5, r0
 80012ac:	430d      	orrs	r5, r1
 80012ae:	0039      	movs	r1, r7
 80012b0:	1e4f      	subs	r7, r1, #1
 80012b2:	41b9      	sbcs	r1, r7
 80012b4:	4667      	mov	r7, ip
 80012b6:	40d7      	lsrs	r7, r2
 80012b8:	4329      	orrs	r1, r5
 80012ba:	1bdb      	subs	r3, r3, r7
 80012bc:	464a      	mov	r2, r9
 80012be:	1a55      	subs	r5, r2, r1
 80012c0:	45a9      	cmp	r9, r5
 80012c2:	4189      	sbcs	r1, r1
 80012c4:	4249      	negs	r1, r1
 80012c6:	1a5b      	subs	r3, r3, r1
 80012c8:	4698      	mov	r8, r3
 80012ca:	4643      	mov	r3, r8
 80012cc:	021b      	lsls	r3, r3, #8
 80012ce:	d400      	bmi.n	80012d2 <__aeabi_dadd+0x9e>
 80012d0:	e0cc      	b.n	800146c <__aeabi_dadd+0x238>
 80012d2:	4643      	mov	r3, r8
 80012d4:	025b      	lsls	r3, r3, #9
 80012d6:	0a5b      	lsrs	r3, r3, #9
 80012d8:	4698      	mov	r8, r3
 80012da:	4643      	mov	r3, r8
 80012dc:	2b00      	cmp	r3, #0
 80012de:	d100      	bne.n	80012e2 <__aeabi_dadd+0xae>
 80012e0:	e12c      	b.n	800153c <__aeabi_dadd+0x308>
 80012e2:	4640      	mov	r0, r8
 80012e4:	f001 fd6a 	bl	8002dbc <__clzsi2>
 80012e8:	0001      	movs	r1, r0
 80012ea:	3908      	subs	r1, #8
 80012ec:	2220      	movs	r2, #32
 80012ee:	0028      	movs	r0, r5
 80012f0:	4643      	mov	r3, r8
 80012f2:	1a52      	subs	r2, r2, r1
 80012f4:	408b      	lsls	r3, r1
 80012f6:	40d0      	lsrs	r0, r2
 80012f8:	408d      	lsls	r5, r1
 80012fa:	4303      	orrs	r3, r0
 80012fc:	428e      	cmp	r6, r1
 80012fe:	dd00      	ble.n	8001302 <__aeabi_dadd+0xce>
 8001300:	e117      	b.n	8001532 <__aeabi_dadd+0x2fe>
 8001302:	1b8e      	subs	r6, r1, r6
 8001304:	1c72      	adds	r2, r6, #1
 8001306:	2a1f      	cmp	r2, #31
 8001308:	dd00      	ble.n	800130c <__aeabi_dadd+0xd8>
 800130a:	e1a7      	b.n	800165c <__aeabi_dadd+0x428>
 800130c:	2120      	movs	r1, #32
 800130e:	0018      	movs	r0, r3
 8001310:	002e      	movs	r6, r5
 8001312:	1a89      	subs	r1, r1, r2
 8001314:	408d      	lsls	r5, r1
 8001316:	4088      	lsls	r0, r1
 8001318:	40d6      	lsrs	r6, r2
 800131a:	40d3      	lsrs	r3, r2
 800131c:	1e69      	subs	r1, r5, #1
 800131e:	418d      	sbcs	r5, r1
 8001320:	4330      	orrs	r0, r6
 8001322:	4698      	mov	r8, r3
 8001324:	2600      	movs	r6, #0
 8001326:	4305      	orrs	r5, r0
 8001328:	076b      	lsls	r3, r5, #29
 800132a:	d009      	beq.n	8001340 <__aeabi_dadd+0x10c>
 800132c:	230f      	movs	r3, #15
 800132e:	402b      	ands	r3, r5
 8001330:	2b04      	cmp	r3, #4
 8001332:	d005      	beq.n	8001340 <__aeabi_dadd+0x10c>
 8001334:	1d2b      	adds	r3, r5, #4
 8001336:	42ab      	cmp	r3, r5
 8001338:	41ad      	sbcs	r5, r5
 800133a:	426d      	negs	r5, r5
 800133c:	44a8      	add	r8, r5
 800133e:	001d      	movs	r5, r3
 8001340:	4643      	mov	r3, r8
 8001342:	021b      	lsls	r3, r3, #8
 8001344:	d400      	bmi.n	8001348 <__aeabi_dadd+0x114>
 8001346:	e094      	b.n	8001472 <__aeabi_dadd+0x23e>
 8001348:	4b97      	ldr	r3, [pc, #604]	; (80015a8 <__aeabi_dadd+0x374>)
 800134a:	1c72      	adds	r2, r6, #1
 800134c:	429a      	cmp	r2, r3
 800134e:	d100      	bne.n	8001352 <__aeabi_dadd+0x11e>
 8001350:	e09d      	b.n	800148e <__aeabi_dadd+0x25a>
 8001352:	4641      	mov	r1, r8
 8001354:	4b95      	ldr	r3, [pc, #596]	; (80015ac <__aeabi_dadd+0x378>)
 8001356:	08ed      	lsrs	r5, r5, #3
 8001358:	4019      	ands	r1, r3
 800135a:	000b      	movs	r3, r1
 800135c:	0552      	lsls	r2, r2, #21
 800135e:	0749      	lsls	r1, r1, #29
 8001360:	025b      	lsls	r3, r3, #9
 8001362:	4329      	orrs	r1, r5
 8001364:	0b1b      	lsrs	r3, r3, #12
 8001366:	0d52      	lsrs	r2, r2, #21
 8001368:	0512      	lsls	r2, r2, #20
 800136a:	4313      	orrs	r3, r2
 800136c:	07e4      	lsls	r4, r4, #31
 800136e:	4323      	orrs	r3, r4
 8001370:	0008      	movs	r0, r1
 8001372:	0019      	movs	r1, r3
 8001374:	bce0      	pop	{r5, r6, r7}
 8001376:	46ba      	mov	sl, r7
 8001378:	46b1      	mov	r9, r6
 800137a:	46a8      	mov	r8, r5
 800137c:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800137e:	2a00      	cmp	r2, #0
 8001380:	d043      	beq.n	800140a <__aeabi_dadd+0x1d6>
 8001382:	1b8a      	subs	r2, r1, r6
 8001384:	2e00      	cmp	r6, #0
 8001386:	d000      	beq.n	800138a <__aeabi_dadd+0x156>
 8001388:	e12a      	b.n	80015e0 <__aeabi_dadd+0x3ac>
 800138a:	464c      	mov	r4, r9
 800138c:	431c      	orrs	r4, r3
 800138e:	d100      	bne.n	8001392 <__aeabi_dadd+0x15e>
 8001390:	e1d1      	b.n	8001736 <__aeabi_dadd+0x502>
 8001392:	1e54      	subs	r4, r2, #1
 8001394:	2a01      	cmp	r2, #1
 8001396:	d100      	bne.n	800139a <__aeabi_dadd+0x166>
 8001398:	e21f      	b.n	80017da <__aeabi_dadd+0x5a6>
 800139a:	4d83      	ldr	r5, [pc, #524]	; (80015a8 <__aeabi_dadd+0x374>)
 800139c:	42aa      	cmp	r2, r5
 800139e:	d100      	bne.n	80013a2 <__aeabi_dadd+0x16e>
 80013a0:	e272      	b.n	8001888 <__aeabi_dadd+0x654>
 80013a2:	0022      	movs	r2, r4
 80013a4:	e123      	b.n	80015ee <__aeabi_dadd+0x3ba>
 80013a6:	2a00      	cmp	r2, #0
 80013a8:	dc00      	bgt.n	80013ac <__aeabi_dadd+0x178>
 80013aa:	e098      	b.n	80014de <__aeabi_dadd+0x2aa>
 80013ac:	2900      	cmp	r1, #0
 80013ae:	d042      	beq.n	8001436 <__aeabi_dadd+0x202>
 80013b0:	497d      	ldr	r1, [pc, #500]	; (80015a8 <__aeabi_dadd+0x374>)
 80013b2:	428e      	cmp	r6, r1
 80013b4:	d100      	bne.n	80013b8 <__aeabi_dadd+0x184>
 80013b6:	e0da      	b.n	800156e <__aeabi_dadd+0x33a>
 80013b8:	2180      	movs	r1, #128	; 0x80
 80013ba:	0028      	movs	r0, r5
 80013bc:	0409      	lsls	r1, r1, #16
 80013be:	4308      	orrs	r0, r1
 80013c0:	4684      	mov	ip, r0
 80013c2:	2a38      	cmp	r2, #56	; 0x38
 80013c4:	dd00      	ble.n	80013c8 <__aeabi_dadd+0x194>
 80013c6:	e129      	b.n	800161c <__aeabi_dadd+0x3e8>
 80013c8:	2a1f      	cmp	r2, #31
 80013ca:	dc00      	bgt.n	80013ce <__aeabi_dadd+0x19a>
 80013cc:	e187      	b.n	80016de <__aeabi_dadd+0x4aa>
 80013ce:	0011      	movs	r1, r2
 80013d0:	4665      	mov	r5, ip
 80013d2:	3920      	subs	r1, #32
 80013d4:	40cd      	lsrs	r5, r1
 80013d6:	2a20      	cmp	r2, #32
 80013d8:	d004      	beq.n	80013e4 <__aeabi_dadd+0x1b0>
 80013da:	2040      	movs	r0, #64	; 0x40
 80013dc:	4661      	mov	r1, ip
 80013de:	1a82      	subs	r2, r0, r2
 80013e0:	4091      	lsls	r1, r2
 80013e2:	430f      	orrs	r7, r1
 80013e4:	0039      	movs	r1, r7
 80013e6:	1e4f      	subs	r7, r1, #1
 80013e8:	41b9      	sbcs	r1, r7
 80013ea:	430d      	orrs	r5, r1
 80013ec:	e11b      	b.n	8001626 <__aeabi_dadd+0x3f2>
 80013ee:	0029      	movs	r1, r5
 80013f0:	4339      	orrs	r1, r7
 80013f2:	d100      	bne.n	80013f6 <__aeabi_dadd+0x1c2>
 80013f4:	e0b5      	b.n	8001562 <__aeabi_dadd+0x32e>
 80013f6:	1e51      	subs	r1, r2, #1
 80013f8:	2a01      	cmp	r2, #1
 80013fa:	d100      	bne.n	80013fe <__aeabi_dadd+0x1ca>
 80013fc:	e1ab      	b.n	8001756 <__aeabi_dadd+0x522>
 80013fe:	486a      	ldr	r0, [pc, #424]	; (80015a8 <__aeabi_dadd+0x374>)
 8001400:	4282      	cmp	r2, r0
 8001402:	d100      	bne.n	8001406 <__aeabi_dadd+0x1d2>
 8001404:	e1b2      	b.n	800176c <__aeabi_dadd+0x538>
 8001406:	000a      	movs	r2, r1
 8001408:	e743      	b.n	8001292 <__aeabi_dadd+0x5e>
 800140a:	4969      	ldr	r1, [pc, #420]	; (80015b0 <__aeabi_dadd+0x37c>)
 800140c:	1c75      	adds	r5, r6, #1
 800140e:	420d      	tst	r5, r1
 8001410:	d000      	beq.n	8001414 <__aeabi_dadd+0x1e0>
 8001412:	e0cf      	b.n	80015b4 <__aeabi_dadd+0x380>
 8001414:	2e00      	cmp	r6, #0
 8001416:	d000      	beq.n	800141a <__aeabi_dadd+0x1e6>
 8001418:	e193      	b.n	8001742 <__aeabi_dadd+0x50e>
 800141a:	4649      	mov	r1, r9
 800141c:	4319      	orrs	r1, r3
 800141e:	d100      	bne.n	8001422 <__aeabi_dadd+0x1ee>
 8001420:	e1d1      	b.n	80017c6 <__aeabi_dadd+0x592>
 8001422:	4661      	mov	r1, ip
 8001424:	4339      	orrs	r1, r7
 8001426:	d000      	beq.n	800142a <__aeabi_dadd+0x1f6>
 8001428:	e1e3      	b.n	80017f2 <__aeabi_dadd+0x5be>
 800142a:	4649      	mov	r1, r9
 800142c:	0758      	lsls	r0, r3, #29
 800142e:	08c9      	lsrs	r1, r1, #3
 8001430:	4301      	orrs	r1, r0
 8001432:	08db      	lsrs	r3, r3, #3
 8001434:	e026      	b.n	8001484 <__aeabi_dadd+0x250>
 8001436:	0029      	movs	r1, r5
 8001438:	4339      	orrs	r1, r7
 800143a:	d100      	bne.n	800143e <__aeabi_dadd+0x20a>
 800143c:	e091      	b.n	8001562 <__aeabi_dadd+0x32e>
 800143e:	1e51      	subs	r1, r2, #1
 8001440:	2a01      	cmp	r2, #1
 8001442:	d005      	beq.n	8001450 <__aeabi_dadd+0x21c>
 8001444:	4858      	ldr	r0, [pc, #352]	; (80015a8 <__aeabi_dadd+0x374>)
 8001446:	4282      	cmp	r2, r0
 8001448:	d100      	bne.n	800144c <__aeabi_dadd+0x218>
 800144a:	e18f      	b.n	800176c <__aeabi_dadd+0x538>
 800144c:	000a      	movs	r2, r1
 800144e:	e7b8      	b.n	80013c2 <__aeabi_dadd+0x18e>
 8001450:	003d      	movs	r5, r7
 8001452:	444d      	add	r5, r9
 8001454:	454d      	cmp	r5, r9
 8001456:	4189      	sbcs	r1, r1
 8001458:	4463      	add	r3, ip
 800145a:	4698      	mov	r8, r3
 800145c:	4249      	negs	r1, r1
 800145e:	4488      	add	r8, r1
 8001460:	4643      	mov	r3, r8
 8001462:	2602      	movs	r6, #2
 8001464:	021b      	lsls	r3, r3, #8
 8001466:	d500      	bpl.n	800146a <__aeabi_dadd+0x236>
 8001468:	e0eb      	b.n	8001642 <__aeabi_dadd+0x40e>
 800146a:	3e01      	subs	r6, #1
 800146c:	076b      	lsls	r3, r5, #29
 800146e:	d000      	beq.n	8001472 <__aeabi_dadd+0x23e>
 8001470:	e75c      	b.n	800132c <__aeabi_dadd+0xf8>
 8001472:	4643      	mov	r3, r8
 8001474:	08e9      	lsrs	r1, r5, #3
 8001476:	075a      	lsls	r2, r3, #29
 8001478:	4311      	orrs	r1, r2
 800147a:	0032      	movs	r2, r6
 800147c:	08db      	lsrs	r3, r3, #3
 800147e:	484a      	ldr	r0, [pc, #296]	; (80015a8 <__aeabi_dadd+0x374>)
 8001480:	4282      	cmp	r2, r0
 8001482:	d021      	beq.n	80014c8 <__aeabi_dadd+0x294>
 8001484:	031b      	lsls	r3, r3, #12
 8001486:	0552      	lsls	r2, r2, #21
 8001488:	0b1b      	lsrs	r3, r3, #12
 800148a:	0d52      	lsrs	r2, r2, #21
 800148c:	e76c      	b.n	8001368 <__aeabi_dadd+0x134>
 800148e:	2300      	movs	r3, #0
 8001490:	2100      	movs	r1, #0
 8001492:	e769      	b.n	8001368 <__aeabi_dadd+0x134>
 8001494:	002a      	movs	r2, r5
 8001496:	433a      	orrs	r2, r7
 8001498:	d069      	beq.n	800156e <__aeabi_dadd+0x33a>
 800149a:	464a      	mov	r2, r9
 800149c:	0758      	lsls	r0, r3, #29
 800149e:	08d1      	lsrs	r1, r2, #3
 80014a0:	08da      	lsrs	r2, r3, #3
 80014a2:	2380      	movs	r3, #128	; 0x80
 80014a4:	031b      	lsls	r3, r3, #12
 80014a6:	4308      	orrs	r0, r1
 80014a8:	421a      	tst	r2, r3
 80014aa:	d007      	beq.n	80014bc <__aeabi_dadd+0x288>
 80014ac:	0029      	movs	r1, r5
 80014ae:	08ed      	lsrs	r5, r5, #3
 80014b0:	421d      	tst	r5, r3
 80014b2:	d103      	bne.n	80014bc <__aeabi_dadd+0x288>
 80014b4:	002a      	movs	r2, r5
 80014b6:	08ff      	lsrs	r7, r7, #3
 80014b8:	0748      	lsls	r0, r1, #29
 80014ba:	4338      	orrs	r0, r7
 80014bc:	0f43      	lsrs	r3, r0, #29
 80014be:	00c1      	lsls	r1, r0, #3
 80014c0:	075b      	lsls	r3, r3, #29
 80014c2:	08c9      	lsrs	r1, r1, #3
 80014c4:	4319      	orrs	r1, r3
 80014c6:	0013      	movs	r3, r2
 80014c8:	000a      	movs	r2, r1
 80014ca:	431a      	orrs	r2, r3
 80014cc:	d100      	bne.n	80014d0 <__aeabi_dadd+0x29c>
 80014ce:	e213      	b.n	80018f8 <__aeabi_dadd+0x6c4>
 80014d0:	2280      	movs	r2, #128	; 0x80
 80014d2:	0312      	lsls	r2, r2, #12
 80014d4:	4313      	orrs	r3, r2
 80014d6:	031b      	lsls	r3, r3, #12
 80014d8:	4a33      	ldr	r2, [pc, #204]	; (80015a8 <__aeabi_dadd+0x374>)
 80014da:	0b1b      	lsrs	r3, r3, #12
 80014dc:	e744      	b.n	8001368 <__aeabi_dadd+0x134>
 80014de:	2a00      	cmp	r2, #0
 80014e0:	d04b      	beq.n	800157a <__aeabi_dadd+0x346>
 80014e2:	1b8a      	subs	r2, r1, r6
 80014e4:	2e00      	cmp	r6, #0
 80014e6:	d100      	bne.n	80014ea <__aeabi_dadd+0x2b6>
 80014e8:	e0e7      	b.n	80016ba <__aeabi_dadd+0x486>
 80014ea:	482f      	ldr	r0, [pc, #188]	; (80015a8 <__aeabi_dadd+0x374>)
 80014ec:	4281      	cmp	r1, r0
 80014ee:	d100      	bne.n	80014f2 <__aeabi_dadd+0x2be>
 80014f0:	e195      	b.n	800181e <__aeabi_dadd+0x5ea>
 80014f2:	2080      	movs	r0, #128	; 0x80
 80014f4:	0400      	lsls	r0, r0, #16
 80014f6:	4303      	orrs	r3, r0
 80014f8:	2a38      	cmp	r2, #56	; 0x38
 80014fa:	dd00      	ble.n	80014fe <__aeabi_dadd+0x2ca>
 80014fc:	e143      	b.n	8001786 <__aeabi_dadd+0x552>
 80014fe:	2a1f      	cmp	r2, #31
 8001500:	dd00      	ble.n	8001504 <__aeabi_dadd+0x2d0>
 8001502:	e1db      	b.n	80018bc <__aeabi_dadd+0x688>
 8001504:	2020      	movs	r0, #32
 8001506:	001d      	movs	r5, r3
 8001508:	464e      	mov	r6, r9
 800150a:	1a80      	subs	r0, r0, r2
 800150c:	4085      	lsls	r5, r0
 800150e:	40d6      	lsrs	r6, r2
 8001510:	4335      	orrs	r5, r6
 8001512:	464e      	mov	r6, r9
 8001514:	4086      	lsls	r6, r0
 8001516:	0030      	movs	r0, r6
 8001518:	40d3      	lsrs	r3, r2
 800151a:	1e46      	subs	r6, r0, #1
 800151c:	41b0      	sbcs	r0, r6
 800151e:	449c      	add	ip, r3
 8001520:	4305      	orrs	r5, r0
 8001522:	19ed      	adds	r5, r5, r7
 8001524:	42bd      	cmp	r5, r7
 8001526:	419b      	sbcs	r3, r3
 8001528:	425b      	negs	r3, r3
 800152a:	4463      	add	r3, ip
 800152c:	4698      	mov	r8, r3
 800152e:	000e      	movs	r6, r1
 8001530:	e07f      	b.n	8001632 <__aeabi_dadd+0x3fe>
 8001532:	4a1e      	ldr	r2, [pc, #120]	; (80015ac <__aeabi_dadd+0x378>)
 8001534:	1a76      	subs	r6, r6, r1
 8001536:	4013      	ands	r3, r2
 8001538:	4698      	mov	r8, r3
 800153a:	e6f5      	b.n	8001328 <__aeabi_dadd+0xf4>
 800153c:	0028      	movs	r0, r5
 800153e:	f001 fc3d 	bl	8002dbc <__clzsi2>
 8001542:	0001      	movs	r1, r0
 8001544:	3118      	adds	r1, #24
 8001546:	291f      	cmp	r1, #31
 8001548:	dc00      	bgt.n	800154c <__aeabi_dadd+0x318>
 800154a:	e6cf      	b.n	80012ec <__aeabi_dadd+0xb8>
 800154c:	002b      	movs	r3, r5
 800154e:	3808      	subs	r0, #8
 8001550:	4083      	lsls	r3, r0
 8001552:	2500      	movs	r5, #0
 8001554:	e6d2      	b.n	80012fc <__aeabi_dadd+0xc8>
 8001556:	4662      	mov	r2, ip
 8001558:	433a      	orrs	r2, r7
 800155a:	0011      	movs	r1, r2
 800155c:	1e4f      	subs	r7, r1, #1
 800155e:	41b9      	sbcs	r1, r7
 8001560:	e6ac      	b.n	80012bc <__aeabi_dadd+0x88>
 8001562:	4649      	mov	r1, r9
 8001564:	0758      	lsls	r0, r3, #29
 8001566:	08c9      	lsrs	r1, r1, #3
 8001568:	4301      	orrs	r1, r0
 800156a:	08db      	lsrs	r3, r3, #3
 800156c:	e787      	b.n	800147e <__aeabi_dadd+0x24a>
 800156e:	4649      	mov	r1, r9
 8001570:	075a      	lsls	r2, r3, #29
 8001572:	08c9      	lsrs	r1, r1, #3
 8001574:	4311      	orrs	r1, r2
 8001576:	08db      	lsrs	r3, r3, #3
 8001578:	e7a6      	b.n	80014c8 <__aeabi_dadd+0x294>
 800157a:	490d      	ldr	r1, [pc, #52]	; (80015b0 <__aeabi_dadd+0x37c>)
 800157c:	1c70      	adds	r0, r6, #1
 800157e:	4208      	tst	r0, r1
 8001580:	d000      	beq.n	8001584 <__aeabi_dadd+0x350>
 8001582:	e0bb      	b.n	80016fc <__aeabi_dadd+0x4c8>
 8001584:	2e00      	cmp	r6, #0
 8001586:	d000      	beq.n	800158a <__aeabi_dadd+0x356>
 8001588:	e114      	b.n	80017b4 <__aeabi_dadd+0x580>
 800158a:	4649      	mov	r1, r9
 800158c:	4319      	orrs	r1, r3
 800158e:	d100      	bne.n	8001592 <__aeabi_dadd+0x35e>
 8001590:	e175      	b.n	800187e <__aeabi_dadd+0x64a>
 8001592:	0029      	movs	r1, r5
 8001594:	4339      	orrs	r1, r7
 8001596:	d000      	beq.n	800159a <__aeabi_dadd+0x366>
 8001598:	e17e      	b.n	8001898 <__aeabi_dadd+0x664>
 800159a:	4649      	mov	r1, r9
 800159c:	0758      	lsls	r0, r3, #29
 800159e:	08c9      	lsrs	r1, r1, #3
 80015a0:	4301      	orrs	r1, r0
 80015a2:	08db      	lsrs	r3, r3, #3
 80015a4:	e76e      	b.n	8001484 <__aeabi_dadd+0x250>
 80015a6:	46c0      	nop			; (mov r8, r8)
 80015a8:	000007ff 	.word	0x000007ff
 80015ac:	ff7fffff 	.word	0xff7fffff
 80015b0:	000007fe 	.word	0x000007fe
 80015b4:	4649      	mov	r1, r9
 80015b6:	1bcd      	subs	r5, r1, r7
 80015b8:	4661      	mov	r1, ip
 80015ba:	1a58      	subs	r0, r3, r1
 80015bc:	45a9      	cmp	r9, r5
 80015be:	4189      	sbcs	r1, r1
 80015c0:	4249      	negs	r1, r1
 80015c2:	4688      	mov	r8, r1
 80015c4:	0001      	movs	r1, r0
 80015c6:	4640      	mov	r0, r8
 80015c8:	1a09      	subs	r1, r1, r0
 80015ca:	4688      	mov	r8, r1
 80015cc:	0209      	lsls	r1, r1, #8
 80015ce:	d500      	bpl.n	80015d2 <__aeabi_dadd+0x39e>
 80015d0:	e0a6      	b.n	8001720 <__aeabi_dadd+0x4ec>
 80015d2:	4641      	mov	r1, r8
 80015d4:	4329      	orrs	r1, r5
 80015d6:	d000      	beq.n	80015da <__aeabi_dadd+0x3a6>
 80015d8:	e67f      	b.n	80012da <__aeabi_dadd+0xa6>
 80015da:	2300      	movs	r3, #0
 80015dc:	2400      	movs	r4, #0
 80015de:	e751      	b.n	8001484 <__aeabi_dadd+0x250>
 80015e0:	4cc7      	ldr	r4, [pc, #796]	; (8001900 <__aeabi_dadd+0x6cc>)
 80015e2:	42a1      	cmp	r1, r4
 80015e4:	d100      	bne.n	80015e8 <__aeabi_dadd+0x3b4>
 80015e6:	e0c7      	b.n	8001778 <__aeabi_dadd+0x544>
 80015e8:	2480      	movs	r4, #128	; 0x80
 80015ea:	0424      	lsls	r4, r4, #16
 80015ec:	4323      	orrs	r3, r4
 80015ee:	2a38      	cmp	r2, #56	; 0x38
 80015f0:	dc54      	bgt.n	800169c <__aeabi_dadd+0x468>
 80015f2:	2a1f      	cmp	r2, #31
 80015f4:	dd00      	ble.n	80015f8 <__aeabi_dadd+0x3c4>
 80015f6:	e0cc      	b.n	8001792 <__aeabi_dadd+0x55e>
 80015f8:	2420      	movs	r4, #32
 80015fa:	4648      	mov	r0, r9
 80015fc:	1aa4      	subs	r4, r4, r2
 80015fe:	001d      	movs	r5, r3
 8001600:	464e      	mov	r6, r9
 8001602:	40a0      	lsls	r0, r4
 8001604:	40d6      	lsrs	r6, r2
 8001606:	40a5      	lsls	r5, r4
 8001608:	0004      	movs	r4, r0
 800160a:	40d3      	lsrs	r3, r2
 800160c:	4662      	mov	r2, ip
 800160e:	4335      	orrs	r5, r6
 8001610:	1e66      	subs	r6, r4, #1
 8001612:	41b4      	sbcs	r4, r6
 8001614:	1ad3      	subs	r3, r2, r3
 8001616:	469c      	mov	ip, r3
 8001618:	4325      	orrs	r5, r4
 800161a:	e044      	b.n	80016a6 <__aeabi_dadd+0x472>
 800161c:	4662      	mov	r2, ip
 800161e:	433a      	orrs	r2, r7
 8001620:	0015      	movs	r5, r2
 8001622:	1e6f      	subs	r7, r5, #1
 8001624:	41bd      	sbcs	r5, r7
 8001626:	444d      	add	r5, r9
 8001628:	454d      	cmp	r5, r9
 800162a:	4189      	sbcs	r1, r1
 800162c:	4249      	negs	r1, r1
 800162e:	4688      	mov	r8, r1
 8001630:	4498      	add	r8, r3
 8001632:	4643      	mov	r3, r8
 8001634:	021b      	lsls	r3, r3, #8
 8001636:	d400      	bmi.n	800163a <__aeabi_dadd+0x406>
 8001638:	e718      	b.n	800146c <__aeabi_dadd+0x238>
 800163a:	4bb1      	ldr	r3, [pc, #708]	; (8001900 <__aeabi_dadd+0x6cc>)
 800163c:	3601      	adds	r6, #1
 800163e:	429e      	cmp	r6, r3
 8001640:	d049      	beq.n	80016d6 <__aeabi_dadd+0x4a2>
 8001642:	4642      	mov	r2, r8
 8001644:	4baf      	ldr	r3, [pc, #700]	; (8001904 <__aeabi_dadd+0x6d0>)
 8001646:	2101      	movs	r1, #1
 8001648:	401a      	ands	r2, r3
 800164a:	0013      	movs	r3, r2
 800164c:	086a      	lsrs	r2, r5, #1
 800164e:	400d      	ands	r5, r1
 8001650:	4315      	orrs	r5, r2
 8001652:	07d9      	lsls	r1, r3, #31
 8001654:	085b      	lsrs	r3, r3, #1
 8001656:	4698      	mov	r8, r3
 8001658:	430d      	orrs	r5, r1
 800165a:	e665      	b.n	8001328 <__aeabi_dadd+0xf4>
 800165c:	0018      	movs	r0, r3
 800165e:	3e1f      	subs	r6, #31
 8001660:	40f0      	lsrs	r0, r6
 8001662:	2a20      	cmp	r2, #32
 8001664:	d003      	beq.n	800166e <__aeabi_dadd+0x43a>
 8001666:	2140      	movs	r1, #64	; 0x40
 8001668:	1a8a      	subs	r2, r1, r2
 800166a:	4093      	lsls	r3, r2
 800166c:	431d      	orrs	r5, r3
 800166e:	1e69      	subs	r1, r5, #1
 8001670:	418d      	sbcs	r5, r1
 8001672:	2300      	movs	r3, #0
 8001674:	2600      	movs	r6, #0
 8001676:	4698      	mov	r8, r3
 8001678:	4305      	orrs	r5, r0
 800167a:	e6f7      	b.n	800146c <__aeabi_dadd+0x238>
 800167c:	0011      	movs	r1, r2
 800167e:	4665      	mov	r5, ip
 8001680:	3920      	subs	r1, #32
 8001682:	40cd      	lsrs	r5, r1
 8001684:	2a20      	cmp	r2, #32
 8001686:	d004      	beq.n	8001692 <__aeabi_dadd+0x45e>
 8001688:	2040      	movs	r0, #64	; 0x40
 800168a:	4661      	mov	r1, ip
 800168c:	1a82      	subs	r2, r0, r2
 800168e:	4091      	lsls	r1, r2
 8001690:	430f      	orrs	r7, r1
 8001692:	0039      	movs	r1, r7
 8001694:	1e4f      	subs	r7, r1, #1
 8001696:	41b9      	sbcs	r1, r7
 8001698:	4329      	orrs	r1, r5
 800169a:	e60f      	b.n	80012bc <__aeabi_dadd+0x88>
 800169c:	464a      	mov	r2, r9
 800169e:	4313      	orrs	r3, r2
 80016a0:	001d      	movs	r5, r3
 80016a2:	1e6b      	subs	r3, r5, #1
 80016a4:	419d      	sbcs	r5, r3
 80016a6:	1b7d      	subs	r5, r7, r5
 80016a8:	42af      	cmp	r7, r5
 80016aa:	419b      	sbcs	r3, r3
 80016ac:	4662      	mov	r2, ip
 80016ae:	425b      	negs	r3, r3
 80016b0:	1ad3      	subs	r3, r2, r3
 80016b2:	4698      	mov	r8, r3
 80016b4:	4654      	mov	r4, sl
 80016b6:	000e      	movs	r6, r1
 80016b8:	e607      	b.n	80012ca <__aeabi_dadd+0x96>
 80016ba:	4648      	mov	r0, r9
 80016bc:	4318      	orrs	r0, r3
 80016be:	d100      	bne.n	80016c2 <__aeabi_dadd+0x48e>
 80016c0:	e0b3      	b.n	800182a <__aeabi_dadd+0x5f6>
 80016c2:	1e50      	subs	r0, r2, #1
 80016c4:	2a01      	cmp	r2, #1
 80016c6:	d100      	bne.n	80016ca <__aeabi_dadd+0x496>
 80016c8:	e10d      	b.n	80018e6 <__aeabi_dadd+0x6b2>
 80016ca:	4d8d      	ldr	r5, [pc, #564]	; (8001900 <__aeabi_dadd+0x6cc>)
 80016cc:	42aa      	cmp	r2, r5
 80016ce:	d100      	bne.n	80016d2 <__aeabi_dadd+0x49e>
 80016d0:	e0a5      	b.n	800181e <__aeabi_dadd+0x5ea>
 80016d2:	0002      	movs	r2, r0
 80016d4:	e710      	b.n	80014f8 <__aeabi_dadd+0x2c4>
 80016d6:	0032      	movs	r2, r6
 80016d8:	2300      	movs	r3, #0
 80016da:	2100      	movs	r1, #0
 80016dc:	e644      	b.n	8001368 <__aeabi_dadd+0x134>
 80016de:	2120      	movs	r1, #32
 80016e0:	0038      	movs	r0, r7
 80016e2:	1a89      	subs	r1, r1, r2
 80016e4:	4665      	mov	r5, ip
 80016e6:	408f      	lsls	r7, r1
 80016e8:	408d      	lsls	r5, r1
 80016ea:	40d0      	lsrs	r0, r2
 80016ec:	1e79      	subs	r1, r7, #1
 80016ee:	418f      	sbcs	r7, r1
 80016f0:	4305      	orrs	r5, r0
 80016f2:	433d      	orrs	r5, r7
 80016f4:	4667      	mov	r7, ip
 80016f6:	40d7      	lsrs	r7, r2
 80016f8:	19db      	adds	r3, r3, r7
 80016fa:	e794      	b.n	8001626 <__aeabi_dadd+0x3f2>
 80016fc:	4a80      	ldr	r2, [pc, #512]	; (8001900 <__aeabi_dadd+0x6cc>)
 80016fe:	4290      	cmp	r0, r2
 8001700:	d100      	bne.n	8001704 <__aeabi_dadd+0x4d0>
 8001702:	e0ec      	b.n	80018de <__aeabi_dadd+0x6aa>
 8001704:	0039      	movs	r1, r7
 8001706:	4449      	add	r1, r9
 8001708:	4549      	cmp	r1, r9
 800170a:	4192      	sbcs	r2, r2
 800170c:	4463      	add	r3, ip
 800170e:	4252      	negs	r2, r2
 8001710:	189b      	adds	r3, r3, r2
 8001712:	07dd      	lsls	r5, r3, #31
 8001714:	0849      	lsrs	r1, r1, #1
 8001716:	085b      	lsrs	r3, r3, #1
 8001718:	4698      	mov	r8, r3
 800171a:	0006      	movs	r6, r0
 800171c:	430d      	orrs	r5, r1
 800171e:	e6a5      	b.n	800146c <__aeabi_dadd+0x238>
 8001720:	464a      	mov	r2, r9
 8001722:	1abd      	subs	r5, r7, r2
 8001724:	42af      	cmp	r7, r5
 8001726:	4189      	sbcs	r1, r1
 8001728:	4662      	mov	r2, ip
 800172a:	4249      	negs	r1, r1
 800172c:	1ad3      	subs	r3, r2, r3
 800172e:	1a5b      	subs	r3, r3, r1
 8001730:	4698      	mov	r8, r3
 8001732:	4654      	mov	r4, sl
 8001734:	e5d1      	b.n	80012da <__aeabi_dadd+0xa6>
 8001736:	076c      	lsls	r4, r5, #29
 8001738:	08f9      	lsrs	r1, r7, #3
 800173a:	4321      	orrs	r1, r4
 800173c:	08eb      	lsrs	r3, r5, #3
 800173e:	0004      	movs	r4, r0
 8001740:	e69d      	b.n	800147e <__aeabi_dadd+0x24a>
 8001742:	464a      	mov	r2, r9
 8001744:	431a      	orrs	r2, r3
 8001746:	d175      	bne.n	8001834 <__aeabi_dadd+0x600>
 8001748:	4661      	mov	r1, ip
 800174a:	4339      	orrs	r1, r7
 800174c:	d114      	bne.n	8001778 <__aeabi_dadd+0x544>
 800174e:	2380      	movs	r3, #128	; 0x80
 8001750:	2400      	movs	r4, #0
 8001752:	031b      	lsls	r3, r3, #12
 8001754:	e6bc      	b.n	80014d0 <__aeabi_dadd+0x29c>
 8001756:	464a      	mov	r2, r9
 8001758:	1bd5      	subs	r5, r2, r7
 800175a:	45a9      	cmp	r9, r5
 800175c:	4189      	sbcs	r1, r1
 800175e:	4662      	mov	r2, ip
 8001760:	4249      	negs	r1, r1
 8001762:	1a9b      	subs	r3, r3, r2
 8001764:	1a5b      	subs	r3, r3, r1
 8001766:	4698      	mov	r8, r3
 8001768:	2601      	movs	r6, #1
 800176a:	e5ae      	b.n	80012ca <__aeabi_dadd+0x96>
 800176c:	464a      	mov	r2, r9
 800176e:	08d1      	lsrs	r1, r2, #3
 8001770:	075a      	lsls	r2, r3, #29
 8001772:	4311      	orrs	r1, r2
 8001774:	08db      	lsrs	r3, r3, #3
 8001776:	e6a7      	b.n	80014c8 <__aeabi_dadd+0x294>
 8001778:	4663      	mov	r3, ip
 800177a:	08f9      	lsrs	r1, r7, #3
 800177c:	075a      	lsls	r2, r3, #29
 800177e:	4654      	mov	r4, sl
 8001780:	4311      	orrs	r1, r2
 8001782:	08db      	lsrs	r3, r3, #3
 8001784:	e6a0      	b.n	80014c8 <__aeabi_dadd+0x294>
 8001786:	464a      	mov	r2, r9
 8001788:	4313      	orrs	r3, r2
 800178a:	001d      	movs	r5, r3
 800178c:	1e6b      	subs	r3, r5, #1
 800178e:	419d      	sbcs	r5, r3
 8001790:	e6c7      	b.n	8001522 <__aeabi_dadd+0x2ee>
 8001792:	0014      	movs	r4, r2
 8001794:	001e      	movs	r6, r3
 8001796:	3c20      	subs	r4, #32
 8001798:	40e6      	lsrs	r6, r4
 800179a:	2a20      	cmp	r2, #32
 800179c:	d005      	beq.n	80017aa <__aeabi_dadd+0x576>
 800179e:	2440      	movs	r4, #64	; 0x40
 80017a0:	1aa2      	subs	r2, r4, r2
 80017a2:	4093      	lsls	r3, r2
 80017a4:	464a      	mov	r2, r9
 80017a6:	431a      	orrs	r2, r3
 80017a8:	4691      	mov	r9, r2
 80017aa:	464d      	mov	r5, r9
 80017ac:	1e6b      	subs	r3, r5, #1
 80017ae:	419d      	sbcs	r5, r3
 80017b0:	4335      	orrs	r5, r6
 80017b2:	e778      	b.n	80016a6 <__aeabi_dadd+0x472>
 80017b4:	464a      	mov	r2, r9
 80017b6:	431a      	orrs	r2, r3
 80017b8:	d000      	beq.n	80017bc <__aeabi_dadd+0x588>
 80017ba:	e66b      	b.n	8001494 <__aeabi_dadd+0x260>
 80017bc:	076b      	lsls	r3, r5, #29
 80017be:	08f9      	lsrs	r1, r7, #3
 80017c0:	4319      	orrs	r1, r3
 80017c2:	08eb      	lsrs	r3, r5, #3
 80017c4:	e680      	b.n	80014c8 <__aeabi_dadd+0x294>
 80017c6:	4661      	mov	r1, ip
 80017c8:	4339      	orrs	r1, r7
 80017ca:	d054      	beq.n	8001876 <__aeabi_dadd+0x642>
 80017cc:	4663      	mov	r3, ip
 80017ce:	08f9      	lsrs	r1, r7, #3
 80017d0:	075c      	lsls	r4, r3, #29
 80017d2:	4321      	orrs	r1, r4
 80017d4:	08db      	lsrs	r3, r3, #3
 80017d6:	0004      	movs	r4, r0
 80017d8:	e654      	b.n	8001484 <__aeabi_dadd+0x250>
 80017da:	464a      	mov	r2, r9
 80017dc:	1abd      	subs	r5, r7, r2
 80017de:	42af      	cmp	r7, r5
 80017e0:	4189      	sbcs	r1, r1
 80017e2:	4662      	mov	r2, ip
 80017e4:	4249      	negs	r1, r1
 80017e6:	1ad3      	subs	r3, r2, r3
 80017e8:	1a5b      	subs	r3, r3, r1
 80017ea:	4698      	mov	r8, r3
 80017ec:	0004      	movs	r4, r0
 80017ee:	2601      	movs	r6, #1
 80017f0:	e56b      	b.n	80012ca <__aeabi_dadd+0x96>
 80017f2:	464a      	mov	r2, r9
 80017f4:	1bd5      	subs	r5, r2, r7
 80017f6:	45a9      	cmp	r9, r5
 80017f8:	4189      	sbcs	r1, r1
 80017fa:	4662      	mov	r2, ip
 80017fc:	4249      	negs	r1, r1
 80017fe:	1a9a      	subs	r2, r3, r2
 8001800:	1a52      	subs	r2, r2, r1
 8001802:	4690      	mov	r8, r2
 8001804:	0212      	lsls	r2, r2, #8
 8001806:	d532      	bpl.n	800186e <__aeabi_dadd+0x63a>
 8001808:	464a      	mov	r2, r9
 800180a:	1abd      	subs	r5, r7, r2
 800180c:	42af      	cmp	r7, r5
 800180e:	4189      	sbcs	r1, r1
 8001810:	4662      	mov	r2, ip
 8001812:	4249      	negs	r1, r1
 8001814:	1ad3      	subs	r3, r2, r3
 8001816:	1a5b      	subs	r3, r3, r1
 8001818:	4698      	mov	r8, r3
 800181a:	0004      	movs	r4, r0
 800181c:	e584      	b.n	8001328 <__aeabi_dadd+0xf4>
 800181e:	4663      	mov	r3, ip
 8001820:	08f9      	lsrs	r1, r7, #3
 8001822:	075a      	lsls	r2, r3, #29
 8001824:	4311      	orrs	r1, r2
 8001826:	08db      	lsrs	r3, r3, #3
 8001828:	e64e      	b.n	80014c8 <__aeabi_dadd+0x294>
 800182a:	08f9      	lsrs	r1, r7, #3
 800182c:	0768      	lsls	r0, r5, #29
 800182e:	4301      	orrs	r1, r0
 8001830:	08eb      	lsrs	r3, r5, #3
 8001832:	e624      	b.n	800147e <__aeabi_dadd+0x24a>
 8001834:	4662      	mov	r2, ip
 8001836:	433a      	orrs	r2, r7
 8001838:	d100      	bne.n	800183c <__aeabi_dadd+0x608>
 800183a:	e698      	b.n	800156e <__aeabi_dadd+0x33a>
 800183c:	464a      	mov	r2, r9
 800183e:	08d1      	lsrs	r1, r2, #3
 8001840:	075a      	lsls	r2, r3, #29
 8001842:	4311      	orrs	r1, r2
 8001844:	08da      	lsrs	r2, r3, #3
 8001846:	2380      	movs	r3, #128	; 0x80
 8001848:	031b      	lsls	r3, r3, #12
 800184a:	421a      	tst	r2, r3
 800184c:	d008      	beq.n	8001860 <__aeabi_dadd+0x62c>
 800184e:	4660      	mov	r0, ip
 8001850:	08c5      	lsrs	r5, r0, #3
 8001852:	421d      	tst	r5, r3
 8001854:	d104      	bne.n	8001860 <__aeabi_dadd+0x62c>
 8001856:	4654      	mov	r4, sl
 8001858:	002a      	movs	r2, r5
 800185a:	08f9      	lsrs	r1, r7, #3
 800185c:	0743      	lsls	r3, r0, #29
 800185e:	4319      	orrs	r1, r3
 8001860:	0f4b      	lsrs	r3, r1, #29
 8001862:	00c9      	lsls	r1, r1, #3
 8001864:	075b      	lsls	r3, r3, #29
 8001866:	08c9      	lsrs	r1, r1, #3
 8001868:	4319      	orrs	r1, r3
 800186a:	0013      	movs	r3, r2
 800186c:	e62c      	b.n	80014c8 <__aeabi_dadd+0x294>
 800186e:	4641      	mov	r1, r8
 8001870:	4329      	orrs	r1, r5
 8001872:	d000      	beq.n	8001876 <__aeabi_dadd+0x642>
 8001874:	e5fa      	b.n	800146c <__aeabi_dadd+0x238>
 8001876:	2300      	movs	r3, #0
 8001878:	000a      	movs	r2, r1
 800187a:	2400      	movs	r4, #0
 800187c:	e602      	b.n	8001484 <__aeabi_dadd+0x250>
 800187e:	076b      	lsls	r3, r5, #29
 8001880:	08f9      	lsrs	r1, r7, #3
 8001882:	4319      	orrs	r1, r3
 8001884:	08eb      	lsrs	r3, r5, #3
 8001886:	e5fd      	b.n	8001484 <__aeabi_dadd+0x250>
 8001888:	4663      	mov	r3, ip
 800188a:	08f9      	lsrs	r1, r7, #3
 800188c:	075b      	lsls	r3, r3, #29
 800188e:	4319      	orrs	r1, r3
 8001890:	4663      	mov	r3, ip
 8001892:	0004      	movs	r4, r0
 8001894:	08db      	lsrs	r3, r3, #3
 8001896:	e617      	b.n	80014c8 <__aeabi_dadd+0x294>
 8001898:	003d      	movs	r5, r7
 800189a:	444d      	add	r5, r9
 800189c:	4463      	add	r3, ip
 800189e:	454d      	cmp	r5, r9
 80018a0:	4189      	sbcs	r1, r1
 80018a2:	4698      	mov	r8, r3
 80018a4:	4249      	negs	r1, r1
 80018a6:	4488      	add	r8, r1
 80018a8:	4643      	mov	r3, r8
 80018aa:	021b      	lsls	r3, r3, #8
 80018ac:	d400      	bmi.n	80018b0 <__aeabi_dadd+0x67c>
 80018ae:	e5dd      	b.n	800146c <__aeabi_dadd+0x238>
 80018b0:	4642      	mov	r2, r8
 80018b2:	4b14      	ldr	r3, [pc, #80]	; (8001904 <__aeabi_dadd+0x6d0>)
 80018b4:	2601      	movs	r6, #1
 80018b6:	401a      	ands	r2, r3
 80018b8:	4690      	mov	r8, r2
 80018ba:	e5d7      	b.n	800146c <__aeabi_dadd+0x238>
 80018bc:	0010      	movs	r0, r2
 80018be:	001e      	movs	r6, r3
 80018c0:	3820      	subs	r0, #32
 80018c2:	40c6      	lsrs	r6, r0
 80018c4:	2a20      	cmp	r2, #32
 80018c6:	d005      	beq.n	80018d4 <__aeabi_dadd+0x6a0>
 80018c8:	2040      	movs	r0, #64	; 0x40
 80018ca:	1a82      	subs	r2, r0, r2
 80018cc:	4093      	lsls	r3, r2
 80018ce:	464a      	mov	r2, r9
 80018d0:	431a      	orrs	r2, r3
 80018d2:	4691      	mov	r9, r2
 80018d4:	464d      	mov	r5, r9
 80018d6:	1e6b      	subs	r3, r5, #1
 80018d8:	419d      	sbcs	r5, r3
 80018da:	4335      	orrs	r5, r6
 80018dc:	e621      	b.n	8001522 <__aeabi_dadd+0x2ee>
 80018de:	0002      	movs	r2, r0
 80018e0:	2300      	movs	r3, #0
 80018e2:	2100      	movs	r1, #0
 80018e4:	e540      	b.n	8001368 <__aeabi_dadd+0x134>
 80018e6:	464a      	mov	r2, r9
 80018e8:	19d5      	adds	r5, r2, r7
 80018ea:	42bd      	cmp	r5, r7
 80018ec:	4189      	sbcs	r1, r1
 80018ee:	4463      	add	r3, ip
 80018f0:	4698      	mov	r8, r3
 80018f2:	4249      	negs	r1, r1
 80018f4:	4488      	add	r8, r1
 80018f6:	e5b3      	b.n	8001460 <__aeabi_dadd+0x22c>
 80018f8:	2100      	movs	r1, #0
 80018fa:	4a01      	ldr	r2, [pc, #4]	; (8001900 <__aeabi_dadd+0x6cc>)
 80018fc:	000b      	movs	r3, r1
 80018fe:	e533      	b.n	8001368 <__aeabi_dadd+0x134>
 8001900:	000007ff 	.word	0x000007ff
 8001904:	ff7fffff 	.word	0xff7fffff

08001908 <__aeabi_ddiv>:
 8001908:	b5f0      	push	{r4, r5, r6, r7, lr}
 800190a:	4657      	mov	r7, sl
 800190c:	464e      	mov	r6, r9
 800190e:	4645      	mov	r5, r8
 8001910:	46de      	mov	lr, fp
 8001912:	b5e0      	push	{r5, r6, r7, lr}
 8001914:	4681      	mov	r9, r0
 8001916:	0005      	movs	r5, r0
 8001918:	030c      	lsls	r4, r1, #12
 800191a:	0048      	lsls	r0, r1, #1
 800191c:	4692      	mov	sl, r2
 800191e:	001f      	movs	r7, r3
 8001920:	b085      	sub	sp, #20
 8001922:	0b24      	lsrs	r4, r4, #12
 8001924:	0d40      	lsrs	r0, r0, #21
 8001926:	0fce      	lsrs	r6, r1, #31
 8001928:	2800      	cmp	r0, #0
 800192a:	d059      	beq.n	80019e0 <__aeabi_ddiv+0xd8>
 800192c:	4b87      	ldr	r3, [pc, #540]	; (8001b4c <__aeabi_ddiv+0x244>)
 800192e:	4298      	cmp	r0, r3
 8001930:	d100      	bne.n	8001934 <__aeabi_ddiv+0x2c>
 8001932:	e098      	b.n	8001a66 <__aeabi_ddiv+0x15e>
 8001934:	0f6b      	lsrs	r3, r5, #29
 8001936:	00e4      	lsls	r4, r4, #3
 8001938:	431c      	orrs	r4, r3
 800193a:	2380      	movs	r3, #128	; 0x80
 800193c:	041b      	lsls	r3, r3, #16
 800193e:	4323      	orrs	r3, r4
 8001940:	4698      	mov	r8, r3
 8001942:	4b83      	ldr	r3, [pc, #524]	; (8001b50 <__aeabi_ddiv+0x248>)
 8001944:	00ed      	lsls	r5, r5, #3
 8001946:	469b      	mov	fp, r3
 8001948:	2300      	movs	r3, #0
 800194a:	4699      	mov	r9, r3
 800194c:	4483      	add	fp, r0
 800194e:	9300      	str	r3, [sp, #0]
 8001950:	033c      	lsls	r4, r7, #12
 8001952:	007b      	lsls	r3, r7, #1
 8001954:	4650      	mov	r0, sl
 8001956:	0b24      	lsrs	r4, r4, #12
 8001958:	0d5b      	lsrs	r3, r3, #21
 800195a:	0fff      	lsrs	r7, r7, #31
 800195c:	2b00      	cmp	r3, #0
 800195e:	d067      	beq.n	8001a30 <__aeabi_ddiv+0x128>
 8001960:	4a7a      	ldr	r2, [pc, #488]	; (8001b4c <__aeabi_ddiv+0x244>)
 8001962:	4293      	cmp	r3, r2
 8001964:	d018      	beq.n	8001998 <__aeabi_ddiv+0x90>
 8001966:	497a      	ldr	r1, [pc, #488]	; (8001b50 <__aeabi_ddiv+0x248>)
 8001968:	0f42      	lsrs	r2, r0, #29
 800196a:	468c      	mov	ip, r1
 800196c:	00e4      	lsls	r4, r4, #3
 800196e:	4659      	mov	r1, fp
 8001970:	4314      	orrs	r4, r2
 8001972:	2280      	movs	r2, #128	; 0x80
 8001974:	4463      	add	r3, ip
 8001976:	0412      	lsls	r2, r2, #16
 8001978:	1acb      	subs	r3, r1, r3
 800197a:	4314      	orrs	r4, r2
 800197c:	469b      	mov	fp, r3
 800197e:	00c2      	lsls	r2, r0, #3
 8001980:	2000      	movs	r0, #0
 8001982:	0033      	movs	r3, r6
 8001984:	407b      	eors	r3, r7
 8001986:	469a      	mov	sl, r3
 8001988:	464b      	mov	r3, r9
 800198a:	2b0f      	cmp	r3, #15
 800198c:	d900      	bls.n	8001990 <__aeabi_ddiv+0x88>
 800198e:	e0ef      	b.n	8001b70 <__aeabi_ddiv+0x268>
 8001990:	4970      	ldr	r1, [pc, #448]	; (8001b54 <__aeabi_ddiv+0x24c>)
 8001992:	009b      	lsls	r3, r3, #2
 8001994:	58cb      	ldr	r3, [r1, r3]
 8001996:	469f      	mov	pc, r3
 8001998:	4b6f      	ldr	r3, [pc, #444]	; (8001b58 <__aeabi_ddiv+0x250>)
 800199a:	4652      	mov	r2, sl
 800199c:	469c      	mov	ip, r3
 800199e:	4322      	orrs	r2, r4
 80019a0:	44e3      	add	fp, ip
 80019a2:	2a00      	cmp	r2, #0
 80019a4:	d000      	beq.n	80019a8 <__aeabi_ddiv+0xa0>
 80019a6:	e095      	b.n	8001ad4 <__aeabi_ddiv+0x1cc>
 80019a8:	4649      	mov	r1, r9
 80019aa:	2302      	movs	r3, #2
 80019ac:	4319      	orrs	r1, r3
 80019ae:	4689      	mov	r9, r1
 80019b0:	2400      	movs	r4, #0
 80019b2:	2002      	movs	r0, #2
 80019b4:	e7e5      	b.n	8001982 <__aeabi_ddiv+0x7a>
 80019b6:	2300      	movs	r3, #0
 80019b8:	2400      	movs	r4, #0
 80019ba:	2500      	movs	r5, #0
 80019bc:	4652      	mov	r2, sl
 80019be:	051b      	lsls	r3, r3, #20
 80019c0:	4323      	orrs	r3, r4
 80019c2:	07d2      	lsls	r2, r2, #31
 80019c4:	4313      	orrs	r3, r2
 80019c6:	0028      	movs	r0, r5
 80019c8:	0019      	movs	r1, r3
 80019ca:	b005      	add	sp, #20
 80019cc:	bcf0      	pop	{r4, r5, r6, r7}
 80019ce:	46bb      	mov	fp, r7
 80019d0:	46b2      	mov	sl, r6
 80019d2:	46a9      	mov	r9, r5
 80019d4:	46a0      	mov	r8, r4
 80019d6:	bdf0      	pop	{r4, r5, r6, r7, pc}
 80019d8:	2400      	movs	r4, #0
 80019da:	2500      	movs	r5, #0
 80019dc:	4b5b      	ldr	r3, [pc, #364]	; (8001b4c <__aeabi_ddiv+0x244>)
 80019de:	e7ed      	b.n	80019bc <__aeabi_ddiv+0xb4>
 80019e0:	464b      	mov	r3, r9
 80019e2:	4323      	orrs	r3, r4
 80019e4:	4698      	mov	r8, r3
 80019e6:	d100      	bne.n	80019ea <__aeabi_ddiv+0xe2>
 80019e8:	e089      	b.n	8001afe <__aeabi_ddiv+0x1f6>
 80019ea:	2c00      	cmp	r4, #0
 80019ec:	d100      	bne.n	80019f0 <__aeabi_ddiv+0xe8>
 80019ee:	e1e0      	b.n	8001db2 <__aeabi_ddiv+0x4aa>
 80019f0:	0020      	movs	r0, r4
 80019f2:	f001 f9e3 	bl	8002dbc <__clzsi2>
 80019f6:	0001      	movs	r1, r0
 80019f8:	0002      	movs	r2, r0
 80019fa:	390b      	subs	r1, #11
 80019fc:	231d      	movs	r3, #29
 80019fe:	1a5b      	subs	r3, r3, r1
 8001a00:	4649      	mov	r1, r9
 8001a02:	0010      	movs	r0, r2
 8001a04:	40d9      	lsrs	r1, r3
 8001a06:	3808      	subs	r0, #8
 8001a08:	4084      	lsls	r4, r0
 8001a0a:	000b      	movs	r3, r1
 8001a0c:	464d      	mov	r5, r9
 8001a0e:	4323      	orrs	r3, r4
 8001a10:	4698      	mov	r8, r3
 8001a12:	4085      	lsls	r5, r0
 8001a14:	4851      	ldr	r0, [pc, #324]	; (8001b5c <__aeabi_ddiv+0x254>)
 8001a16:	033c      	lsls	r4, r7, #12
 8001a18:	1a83      	subs	r3, r0, r2
 8001a1a:	469b      	mov	fp, r3
 8001a1c:	2300      	movs	r3, #0
 8001a1e:	4699      	mov	r9, r3
 8001a20:	9300      	str	r3, [sp, #0]
 8001a22:	007b      	lsls	r3, r7, #1
 8001a24:	4650      	mov	r0, sl
 8001a26:	0b24      	lsrs	r4, r4, #12
 8001a28:	0d5b      	lsrs	r3, r3, #21
 8001a2a:	0fff      	lsrs	r7, r7, #31
 8001a2c:	2b00      	cmp	r3, #0
 8001a2e:	d197      	bne.n	8001960 <__aeabi_ddiv+0x58>
 8001a30:	4652      	mov	r2, sl
 8001a32:	4322      	orrs	r2, r4
 8001a34:	d055      	beq.n	8001ae2 <__aeabi_ddiv+0x1da>
 8001a36:	2c00      	cmp	r4, #0
 8001a38:	d100      	bne.n	8001a3c <__aeabi_ddiv+0x134>
 8001a3a:	e1ca      	b.n	8001dd2 <__aeabi_ddiv+0x4ca>
 8001a3c:	0020      	movs	r0, r4
 8001a3e:	f001 f9bd 	bl	8002dbc <__clzsi2>
 8001a42:	0002      	movs	r2, r0
 8001a44:	3a0b      	subs	r2, #11
 8001a46:	231d      	movs	r3, #29
 8001a48:	0001      	movs	r1, r0
 8001a4a:	1a9b      	subs	r3, r3, r2
 8001a4c:	4652      	mov	r2, sl
 8001a4e:	3908      	subs	r1, #8
 8001a50:	40da      	lsrs	r2, r3
 8001a52:	408c      	lsls	r4, r1
 8001a54:	4314      	orrs	r4, r2
 8001a56:	4652      	mov	r2, sl
 8001a58:	408a      	lsls	r2, r1
 8001a5a:	4b41      	ldr	r3, [pc, #260]	; (8001b60 <__aeabi_ddiv+0x258>)
 8001a5c:	4458      	add	r0, fp
 8001a5e:	469b      	mov	fp, r3
 8001a60:	4483      	add	fp, r0
 8001a62:	2000      	movs	r0, #0
 8001a64:	e78d      	b.n	8001982 <__aeabi_ddiv+0x7a>
 8001a66:	464b      	mov	r3, r9
 8001a68:	4323      	orrs	r3, r4
 8001a6a:	4698      	mov	r8, r3
 8001a6c:	d140      	bne.n	8001af0 <__aeabi_ddiv+0x1e8>
 8001a6e:	2308      	movs	r3, #8
 8001a70:	4699      	mov	r9, r3
 8001a72:	3b06      	subs	r3, #6
 8001a74:	2500      	movs	r5, #0
 8001a76:	4683      	mov	fp, r0
 8001a78:	9300      	str	r3, [sp, #0]
 8001a7a:	e769      	b.n	8001950 <__aeabi_ddiv+0x48>
 8001a7c:	46b2      	mov	sl, r6
 8001a7e:	9b00      	ldr	r3, [sp, #0]
 8001a80:	2b02      	cmp	r3, #2
 8001a82:	d0a9      	beq.n	80019d8 <__aeabi_ddiv+0xd0>
 8001a84:	2b03      	cmp	r3, #3
 8001a86:	d100      	bne.n	8001a8a <__aeabi_ddiv+0x182>
 8001a88:	e211      	b.n	8001eae <__aeabi_ddiv+0x5a6>
 8001a8a:	2b01      	cmp	r3, #1
 8001a8c:	d093      	beq.n	80019b6 <__aeabi_ddiv+0xae>
 8001a8e:	4a35      	ldr	r2, [pc, #212]	; (8001b64 <__aeabi_ddiv+0x25c>)
 8001a90:	445a      	add	r2, fp
 8001a92:	2a00      	cmp	r2, #0
 8001a94:	dc00      	bgt.n	8001a98 <__aeabi_ddiv+0x190>
 8001a96:	e13c      	b.n	8001d12 <__aeabi_ddiv+0x40a>
 8001a98:	076b      	lsls	r3, r5, #29
 8001a9a:	d000      	beq.n	8001a9e <__aeabi_ddiv+0x196>
 8001a9c:	e1a7      	b.n	8001dee <__aeabi_ddiv+0x4e6>
 8001a9e:	08ed      	lsrs	r5, r5, #3
 8001aa0:	4643      	mov	r3, r8
 8001aa2:	01db      	lsls	r3, r3, #7
 8001aa4:	d506      	bpl.n	8001ab4 <__aeabi_ddiv+0x1ac>
 8001aa6:	4642      	mov	r2, r8
 8001aa8:	4b2f      	ldr	r3, [pc, #188]	; (8001b68 <__aeabi_ddiv+0x260>)
 8001aaa:	401a      	ands	r2, r3
 8001aac:	4690      	mov	r8, r2
 8001aae:	2280      	movs	r2, #128	; 0x80
 8001ab0:	00d2      	lsls	r2, r2, #3
 8001ab2:	445a      	add	r2, fp
 8001ab4:	4b2d      	ldr	r3, [pc, #180]	; (8001b6c <__aeabi_ddiv+0x264>)
 8001ab6:	429a      	cmp	r2, r3
 8001ab8:	dc8e      	bgt.n	80019d8 <__aeabi_ddiv+0xd0>
 8001aba:	4643      	mov	r3, r8
 8001abc:	0552      	lsls	r2, r2, #21
 8001abe:	0758      	lsls	r0, r3, #29
 8001ac0:	025c      	lsls	r4, r3, #9
 8001ac2:	4305      	orrs	r5, r0
 8001ac4:	0b24      	lsrs	r4, r4, #12
 8001ac6:	0d53      	lsrs	r3, r2, #21
 8001ac8:	e778      	b.n	80019bc <__aeabi_ddiv+0xb4>
 8001aca:	46ba      	mov	sl, r7
 8001acc:	46a0      	mov	r8, r4
 8001ace:	0015      	movs	r5, r2
 8001ad0:	9000      	str	r0, [sp, #0]
 8001ad2:	e7d4      	b.n	8001a7e <__aeabi_ddiv+0x176>
 8001ad4:	464a      	mov	r2, r9
 8001ad6:	2303      	movs	r3, #3
 8001ad8:	431a      	orrs	r2, r3
 8001ada:	4691      	mov	r9, r2
 8001adc:	2003      	movs	r0, #3
 8001ade:	4652      	mov	r2, sl
 8001ae0:	e74f      	b.n	8001982 <__aeabi_ddiv+0x7a>
 8001ae2:	4649      	mov	r1, r9
 8001ae4:	2301      	movs	r3, #1
 8001ae6:	4319      	orrs	r1, r3
 8001ae8:	4689      	mov	r9, r1
 8001aea:	2400      	movs	r4, #0
 8001aec:	2001      	movs	r0, #1
 8001aee:	e748      	b.n	8001982 <__aeabi_ddiv+0x7a>
 8001af0:	230c      	movs	r3, #12
 8001af2:	4699      	mov	r9, r3
 8001af4:	3b09      	subs	r3, #9
 8001af6:	46a0      	mov	r8, r4
 8001af8:	4683      	mov	fp, r0
 8001afa:	9300      	str	r3, [sp, #0]
 8001afc:	e728      	b.n	8001950 <__aeabi_ddiv+0x48>
 8001afe:	2304      	movs	r3, #4
 8001b00:	4699      	mov	r9, r3
 8001b02:	2300      	movs	r3, #0
 8001b04:	469b      	mov	fp, r3
 8001b06:	3301      	adds	r3, #1
 8001b08:	2500      	movs	r5, #0
 8001b0a:	9300      	str	r3, [sp, #0]
 8001b0c:	e720      	b.n	8001950 <__aeabi_ddiv+0x48>
 8001b0e:	2300      	movs	r3, #0
 8001b10:	2480      	movs	r4, #128	; 0x80
 8001b12:	469a      	mov	sl, r3
 8001b14:	2500      	movs	r5, #0
 8001b16:	4b0d      	ldr	r3, [pc, #52]	; (8001b4c <__aeabi_ddiv+0x244>)
 8001b18:	0324      	lsls	r4, r4, #12
 8001b1a:	e74f      	b.n	80019bc <__aeabi_ddiv+0xb4>
 8001b1c:	2380      	movs	r3, #128	; 0x80
 8001b1e:	4641      	mov	r1, r8
 8001b20:	031b      	lsls	r3, r3, #12
 8001b22:	4219      	tst	r1, r3
 8001b24:	d008      	beq.n	8001b38 <__aeabi_ddiv+0x230>
 8001b26:	421c      	tst	r4, r3
 8001b28:	d106      	bne.n	8001b38 <__aeabi_ddiv+0x230>
 8001b2a:	431c      	orrs	r4, r3
 8001b2c:	0324      	lsls	r4, r4, #12
 8001b2e:	46ba      	mov	sl, r7
 8001b30:	0015      	movs	r5, r2
 8001b32:	4b06      	ldr	r3, [pc, #24]	; (8001b4c <__aeabi_ddiv+0x244>)
 8001b34:	0b24      	lsrs	r4, r4, #12
 8001b36:	e741      	b.n	80019bc <__aeabi_ddiv+0xb4>
 8001b38:	2480      	movs	r4, #128	; 0x80
 8001b3a:	4643      	mov	r3, r8
 8001b3c:	0324      	lsls	r4, r4, #12
 8001b3e:	431c      	orrs	r4, r3
 8001b40:	0324      	lsls	r4, r4, #12
 8001b42:	46b2      	mov	sl, r6
 8001b44:	4b01      	ldr	r3, [pc, #4]	; (8001b4c <__aeabi_ddiv+0x244>)
 8001b46:	0b24      	lsrs	r4, r4, #12
 8001b48:	e738      	b.n	80019bc <__aeabi_ddiv+0xb4>
 8001b4a:	46c0      	nop			; (mov r8, r8)
 8001b4c:	000007ff 	.word	0x000007ff
 8001b50:	fffffc01 	.word	0xfffffc01
 8001b54:	0800e5c0 	.word	0x0800e5c0
 8001b58:	fffff801 	.word	0xfffff801
 8001b5c:	fffffc0d 	.word	0xfffffc0d
 8001b60:	000003f3 	.word	0x000003f3
 8001b64:	000003ff 	.word	0x000003ff
 8001b68:	feffffff 	.word	0xfeffffff
 8001b6c:	000007fe 	.word	0x000007fe
 8001b70:	4544      	cmp	r4, r8
 8001b72:	d200      	bcs.n	8001b76 <__aeabi_ddiv+0x26e>
 8001b74:	e116      	b.n	8001da4 <__aeabi_ddiv+0x49c>
 8001b76:	d100      	bne.n	8001b7a <__aeabi_ddiv+0x272>
 8001b78:	e111      	b.n	8001d9e <__aeabi_ddiv+0x496>
 8001b7a:	2301      	movs	r3, #1
 8001b7c:	425b      	negs	r3, r3
 8001b7e:	469c      	mov	ip, r3
 8001b80:	002e      	movs	r6, r5
 8001b82:	4640      	mov	r0, r8
 8001b84:	2500      	movs	r5, #0
 8001b86:	44e3      	add	fp, ip
 8001b88:	0223      	lsls	r3, r4, #8
 8001b8a:	0e14      	lsrs	r4, r2, #24
 8001b8c:	431c      	orrs	r4, r3
 8001b8e:	0c1b      	lsrs	r3, r3, #16
 8001b90:	4699      	mov	r9, r3
 8001b92:	0423      	lsls	r3, r4, #16
 8001b94:	0c1f      	lsrs	r7, r3, #16
 8001b96:	0212      	lsls	r2, r2, #8
 8001b98:	4649      	mov	r1, r9
 8001b9a:	9200      	str	r2, [sp, #0]
 8001b9c:	9701      	str	r7, [sp, #4]
 8001b9e:	f7fe fb37 	bl	8000210 <__aeabi_uidivmod>
 8001ba2:	0002      	movs	r2, r0
 8001ba4:	437a      	muls	r2, r7
 8001ba6:	040b      	lsls	r3, r1, #16
 8001ba8:	0c31      	lsrs	r1, r6, #16
 8001baa:	4680      	mov	r8, r0
 8001bac:	4319      	orrs	r1, r3
 8001bae:	428a      	cmp	r2, r1
 8001bb0:	d90b      	bls.n	8001bca <__aeabi_ddiv+0x2c2>
 8001bb2:	2301      	movs	r3, #1
 8001bb4:	425b      	negs	r3, r3
 8001bb6:	469c      	mov	ip, r3
 8001bb8:	1909      	adds	r1, r1, r4
 8001bba:	44e0      	add	r8, ip
 8001bbc:	428c      	cmp	r4, r1
 8001bbe:	d804      	bhi.n	8001bca <__aeabi_ddiv+0x2c2>
 8001bc0:	428a      	cmp	r2, r1
 8001bc2:	d902      	bls.n	8001bca <__aeabi_ddiv+0x2c2>
 8001bc4:	1e83      	subs	r3, r0, #2
 8001bc6:	4698      	mov	r8, r3
 8001bc8:	1909      	adds	r1, r1, r4
 8001bca:	1a88      	subs	r0, r1, r2
 8001bcc:	4649      	mov	r1, r9
 8001bce:	f7fe fb1f 	bl	8000210 <__aeabi_uidivmod>
 8001bd2:	0409      	lsls	r1, r1, #16
 8001bd4:	468c      	mov	ip, r1
 8001bd6:	0431      	lsls	r1, r6, #16
 8001bd8:	4666      	mov	r6, ip
 8001bda:	9a01      	ldr	r2, [sp, #4]
 8001bdc:	0c09      	lsrs	r1, r1, #16
 8001bde:	4342      	muls	r2, r0
 8001be0:	0003      	movs	r3, r0
 8001be2:	4331      	orrs	r1, r6
 8001be4:	428a      	cmp	r2, r1
 8001be6:	d904      	bls.n	8001bf2 <__aeabi_ddiv+0x2ea>
 8001be8:	1909      	adds	r1, r1, r4
 8001bea:	3b01      	subs	r3, #1
 8001bec:	428c      	cmp	r4, r1
 8001bee:	d800      	bhi.n	8001bf2 <__aeabi_ddiv+0x2ea>
 8001bf0:	e111      	b.n	8001e16 <__aeabi_ddiv+0x50e>
 8001bf2:	1a89      	subs	r1, r1, r2
 8001bf4:	4642      	mov	r2, r8
 8001bf6:	9e00      	ldr	r6, [sp, #0]
 8001bf8:	0412      	lsls	r2, r2, #16
 8001bfa:	431a      	orrs	r2, r3
 8001bfc:	0c33      	lsrs	r3, r6, #16
 8001bfe:	001f      	movs	r7, r3
 8001c00:	0c10      	lsrs	r0, r2, #16
 8001c02:	4690      	mov	r8, r2
 8001c04:	9302      	str	r3, [sp, #8]
 8001c06:	0413      	lsls	r3, r2, #16
 8001c08:	0432      	lsls	r2, r6, #16
 8001c0a:	0c16      	lsrs	r6, r2, #16
 8001c0c:	0032      	movs	r2, r6
 8001c0e:	0c1b      	lsrs	r3, r3, #16
 8001c10:	435a      	muls	r2, r3
 8001c12:	9603      	str	r6, [sp, #12]
 8001c14:	437b      	muls	r3, r7
 8001c16:	4346      	muls	r6, r0
 8001c18:	4378      	muls	r0, r7
 8001c1a:	0c17      	lsrs	r7, r2, #16
 8001c1c:	46bc      	mov	ip, r7
 8001c1e:	199b      	adds	r3, r3, r6
 8001c20:	4463      	add	r3, ip
 8001c22:	429e      	cmp	r6, r3
 8001c24:	d903      	bls.n	8001c2e <__aeabi_ddiv+0x326>
 8001c26:	2680      	movs	r6, #128	; 0x80
 8001c28:	0276      	lsls	r6, r6, #9
 8001c2a:	46b4      	mov	ip, r6
 8001c2c:	4460      	add	r0, ip
 8001c2e:	0c1e      	lsrs	r6, r3, #16
 8001c30:	1830      	adds	r0, r6, r0
 8001c32:	0416      	lsls	r6, r2, #16
 8001c34:	041b      	lsls	r3, r3, #16
 8001c36:	0c36      	lsrs	r6, r6, #16
 8001c38:	199e      	adds	r6, r3, r6
 8001c3a:	4281      	cmp	r1, r0
 8001c3c:	d200      	bcs.n	8001c40 <__aeabi_ddiv+0x338>
 8001c3e:	e09c      	b.n	8001d7a <__aeabi_ddiv+0x472>
 8001c40:	d100      	bne.n	8001c44 <__aeabi_ddiv+0x33c>
 8001c42:	e097      	b.n	8001d74 <__aeabi_ddiv+0x46c>
 8001c44:	1bae      	subs	r6, r5, r6
 8001c46:	1a09      	subs	r1, r1, r0
 8001c48:	42b5      	cmp	r5, r6
 8001c4a:	4180      	sbcs	r0, r0
 8001c4c:	4240      	negs	r0, r0
 8001c4e:	1a08      	subs	r0, r1, r0
 8001c50:	4284      	cmp	r4, r0
 8001c52:	d100      	bne.n	8001c56 <__aeabi_ddiv+0x34e>
 8001c54:	e111      	b.n	8001e7a <__aeabi_ddiv+0x572>
 8001c56:	4649      	mov	r1, r9
 8001c58:	f7fe fada 	bl	8000210 <__aeabi_uidivmod>
 8001c5c:	9a01      	ldr	r2, [sp, #4]
 8001c5e:	040b      	lsls	r3, r1, #16
 8001c60:	4342      	muls	r2, r0
 8001c62:	0c31      	lsrs	r1, r6, #16
 8001c64:	0005      	movs	r5, r0
 8001c66:	4319      	orrs	r1, r3
 8001c68:	428a      	cmp	r2, r1
 8001c6a:	d907      	bls.n	8001c7c <__aeabi_ddiv+0x374>
 8001c6c:	1909      	adds	r1, r1, r4
 8001c6e:	3d01      	subs	r5, #1
 8001c70:	428c      	cmp	r4, r1
 8001c72:	d803      	bhi.n	8001c7c <__aeabi_ddiv+0x374>
 8001c74:	428a      	cmp	r2, r1
 8001c76:	d901      	bls.n	8001c7c <__aeabi_ddiv+0x374>
 8001c78:	1e85      	subs	r5, r0, #2
 8001c7a:	1909      	adds	r1, r1, r4
 8001c7c:	1a88      	subs	r0, r1, r2
 8001c7e:	4649      	mov	r1, r9
 8001c80:	f7fe fac6 	bl	8000210 <__aeabi_uidivmod>
 8001c84:	0409      	lsls	r1, r1, #16
 8001c86:	468c      	mov	ip, r1
 8001c88:	0431      	lsls	r1, r6, #16
 8001c8a:	4666      	mov	r6, ip
 8001c8c:	9a01      	ldr	r2, [sp, #4]
 8001c8e:	0c09      	lsrs	r1, r1, #16
 8001c90:	4342      	muls	r2, r0
 8001c92:	0003      	movs	r3, r0
 8001c94:	4331      	orrs	r1, r6
 8001c96:	428a      	cmp	r2, r1
 8001c98:	d907      	bls.n	8001caa <__aeabi_ddiv+0x3a2>
 8001c9a:	1909      	adds	r1, r1, r4
 8001c9c:	3b01      	subs	r3, #1
 8001c9e:	428c      	cmp	r4, r1
 8001ca0:	d803      	bhi.n	8001caa <__aeabi_ddiv+0x3a2>
 8001ca2:	428a      	cmp	r2, r1
 8001ca4:	d901      	bls.n	8001caa <__aeabi_ddiv+0x3a2>
 8001ca6:	1e83      	subs	r3, r0, #2
 8001ca8:	1909      	adds	r1, r1, r4
 8001caa:	9e03      	ldr	r6, [sp, #12]
 8001cac:	1a89      	subs	r1, r1, r2
 8001cae:	0032      	movs	r2, r6
 8001cb0:	042d      	lsls	r5, r5, #16
 8001cb2:	431d      	orrs	r5, r3
 8001cb4:	9f02      	ldr	r7, [sp, #8]
 8001cb6:	042b      	lsls	r3, r5, #16
 8001cb8:	0c1b      	lsrs	r3, r3, #16
 8001cba:	435a      	muls	r2, r3
 8001cbc:	437b      	muls	r3, r7
 8001cbe:	469c      	mov	ip, r3
 8001cc0:	0c28      	lsrs	r0, r5, #16
 8001cc2:	4346      	muls	r6, r0
 8001cc4:	0c13      	lsrs	r3, r2, #16
 8001cc6:	44b4      	add	ip, r6
 8001cc8:	4463      	add	r3, ip
 8001cca:	4378      	muls	r0, r7
 8001ccc:	429e      	cmp	r6, r3
 8001cce:	d903      	bls.n	8001cd8 <__aeabi_ddiv+0x3d0>
 8001cd0:	2680      	movs	r6, #128	; 0x80
 8001cd2:	0276      	lsls	r6, r6, #9
 8001cd4:	46b4      	mov	ip, r6
 8001cd6:	4460      	add	r0, ip
 8001cd8:	0c1e      	lsrs	r6, r3, #16
 8001cda:	0412      	lsls	r2, r2, #16
 8001cdc:	041b      	lsls	r3, r3, #16
 8001cde:	0c12      	lsrs	r2, r2, #16
 8001ce0:	1830      	adds	r0, r6, r0
 8001ce2:	189b      	adds	r3, r3, r2
 8001ce4:	4281      	cmp	r1, r0
 8001ce6:	d306      	bcc.n	8001cf6 <__aeabi_ddiv+0x3ee>
 8001ce8:	d002      	beq.n	8001cf0 <__aeabi_ddiv+0x3e8>
 8001cea:	2301      	movs	r3, #1
 8001cec:	431d      	orrs	r5, r3
 8001cee:	e6ce      	b.n	8001a8e <__aeabi_ddiv+0x186>
 8001cf0:	2b00      	cmp	r3, #0
 8001cf2:	d100      	bne.n	8001cf6 <__aeabi_ddiv+0x3ee>
 8001cf4:	e6cb      	b.n	8001a8e <__aeabi_ddiv+0x186>
 8001cf6:	1861      	adds	r1, r4, r1
 8001cf8:	1e6e      	subs	r6, r5, #1
 8001cfa:	42a1      	cmp	r1, r4
 8001cfc:	d200      	bcs.n	8001d00 <__aeabi_ddiv+0x3f8>
 8001cfe:	e0a4      	b.n	8001e4a <__aeabi_ddiv+0x542>
 8001d00:	4281      	cmp	r1, r0
 8001d02:	d200      	bcs.n	8001d06 <__aeabi_ddiv+0x3fe>
 8001d04:	e0c9      	b.n	8001e9a <__aeabi_ddiv+0x592>
 8001d06:	d100      	bne.n	8001d0a <__aeabi_ddiv+0x402>
 8001d08:	e0d9      	b.n	8001ebe <__aeabi_ddiv+0x5b6>
 8001d0a:	0035      	movs	r5, r6
 8001d0c:	e7ed      	b.n	8001cea <__aeabi_ddiv+0x3e2>
 8001d0e:	2501      	movs	r5, #1
 8001d10:	426d      	negs	r5, r5
 8001d12:	2101      	movs	r1, #1
 8001d14:	1a89      	subs	r1, r1, r2
 8001d16:	2938      	cmp	r1, #56	; 0x38
 8001d18:	dd00      	ble.n	8001d1c <__aeabi_ddiv+0x414>
 8001d1a:	e64c      	b.n	80019b6 <__aeabi_ddiv+0xae>
 8001d1c:	291f      	cmp	r1, #31
 8001d1e:	dc00      	bgt.n	8001d22 <__aeabi_ddiv+0x41a>
 8001d20:	e07f      	b.n	8001e22 <__aeabi_ddiv+0x51a>
 8001d22:	231f      	movs	r3, #31
 8001d24:	425b      	negs	r3, r3
 8001d26:	1a9a      	subs	r2, r3, r2
 8001d28:	4643      	mov	r3, r8
 8001d2a:	40d3      	lsrs	r3, r2
 8001d2c:	2920      	cmp	r1, #32
 8001d2e:	d004      	beq.n	8001d3a <__aeabi_ddiv+0x432>
 8001d30:	4644      	mov	r4, r8
 8001d32:	4a65      	ldr	r2, [pc, #404]	; (8001ec8 <__aeabi_ddiv+0x5c0>)
 8001d34:	445a      	add	r2, fp
 8001d36:	4094      	lsls	r4, r2
 8001d38:	4325      	orrs	r5, r4
 8001d3a:	1e6a      	subs	r2, r5, #1
 8001d3c:	4195      	sbcs	r5, r2
 8001d3e:	2207      	movs	r2, #7
 8001d40:	432b      	orrs	r3, r5
 8001d42:	0015      	movs	r5, r2
 8001d44:	2400      	movs	r4, #0
 8001d46:	401d      	ands	r5, r3
 8001d48:	421a      	tst	r2, r3
 8001d4a:	d100      	bne.n	8001d4e <__aeabi_ddiv+0x446>
 8001d4c:	e0a1      	b.n	8001e92 <__aeabi_ddiv+0x58a>
 8001d4e:	220f      	movs	r2, #15
 8001d50:	2400      	movs	r4, #0
 8001d52:	401a      	ands	r2, r3
 8001d54:	2a04      	cmp	r2, #4
 8001d56:	d100      	bne.n	8001d5a <__aeabi_ddiv+0x452>
 8001d58:	e098      	b.n	8001e8c <__aeabi_ddiv+0x584>
 8001d5a:	1d1a      	adds	r2, r3, #4
 8001d5c:	429a      	cmp	r2, r3
 8001d5e:	419b      	sbcs	r3, r3
 8001d60:	425b      	negs	r3, r3
 8001d62:	18e4      	adds	r4, r4, r3
 8001d64:	0013      	movs	r3, r2
 8001d66:	0222      	lsls	r2, r4, #8
 8001d68:	d400      	bmi.n	8001d6c <__aeabi_ddiv+0x464>
 8001d6a:	e08f      	b.n	8001e8c <__aeabi_ddiv+0x584>
 8001d6c:	2301      	movs	r3, #1
 8001d6e:	2400      	movs	r4, #0
 8001d70:	2500      	movs	r5, #0
 8001d72:	e623      	b.n	80019bc <__aeabi_ddiv+0xb4>
 8001d74:	42b5      	cmp	r5, r6
 8001d76:	d300      	bcc.n	8001d7a <__aeabi_ddiv+0x472>
 8001d78:	e764      	b.n	8001c44 <__aeabi_ddiv+0x33c>
 8001d7a:	4643      	mov	r3, r8
 8001d7c:	1e5a      	subs	r2, r3, #1
 8001d7e:	9b00      	ldr	r3, [sp, #0]
 8001d80:	469c      	mov	ip, r3
 8001d82:	4465      	add	r5, ip
 8001d84:	001f      	movs	r7, r3
 8001d86:	429d      	cmp	r5, r3
 8001d88:	419b      	sbcs	r3, r3
 8001d8a:	425b      	negs	r3, r3
 8001d8c:	191b      	adds	r3, r3, r4
 8001d8e:	18c9      	adds	r1, r1, r3
 8001d90:	428c      	cmp	r4, r1
 8001d92:	d23a      	bcs.n	8001e0a <__aeabi_ddiv+0x502>
 8001d94:	4288      	cmp	r0, r1
 8001d96:	d863      	bhi.n	8001e60 <__aeabi_ddiv+0x558>
 8001d98:	d060      	beq.n	8001e5c <__aeabi_ddiv+0x554>
 8001d9a:	4690      	mov	r8, r2
 8001d9c:	e752      	b.n	8001c44 <__aeabi_ddiv+0x33c>
 8001d9e:	42aa      	cmp	r2, r5
 8001da0:	d900      	bls.n	8001da4 <__aeabi_ddiv+0x49c>
 8001da2:	e6ea      	b.n	8001b7a <__aeabi_ddiv+0x272>
 8001da4:	4643      	mov	r3, r8
 8001da6:	07de      	lsls	r6, r3, #31
 8001da8:	0858      	lsrs	r0, r3, #1
 8001daa:	086b      	lsrs	r3, r5, #1
 8001dac:	431e      	orrs	r6, r3
 8001dae:	07ed      	lsls	r5, r5, #31
 8001db0:	e6ea      	b.n	8001b88 <__aeabi_ddiv+0x280>
 8001db2:	4648      	mov	r0, r9
 8001db4:	f001 f802 	bl	8002dbc <__clzsi2>
 8001db8:	0001      	movs	r1, r0
 8001dba:	0002      	movs	r2, r0
 8001dbc:	3115      	adds	r1, #21
 8001dbe:	3220      	adds	r2, #32
 8001dc0:	291c      	cmp	r1, #28
 8001dc2:	dc00      	bgt.n	8001dc6 <__aeabi_ddiv+0x4be>
 8001dc4:	e61a      	b.n	80019fc <__aeabi_ddiv+0xf4>
 8001dc6:	464b      	mov	r3, r9
 8001dc8:	3808      	subs	r0, #8
 8001dca:	4083      	lsls	r3, r0
 8001dcc:	2500      	movs	r5, #0
 8001dce:	4698      	mov	r8, r3
 8001dd0:	e620      	b.n	8001a14 <__aeabi_ddiv+0x10c>
 8001dd2:	f000 fff3 	bl	8002dbc <__clzsi2>
 8001dd6:	0003      	movs	r3, r0
 8001dd8:	001a      	movs	r2, r3
 8001dda:	3215      	adds	r2, #21
 8001ddc:	3020      	adds	r0, #32
 8001dde:	2a1c      	cmp	r2, #28
 8001de0:	dc00      	bgt.n	8001de4 <__aeabi_ddiv+0x4dc>
 8001de2:	e630      	b.n	8001a46 <__aeabi_ddiv+0x13e>
 8001de4:	4654      	mov	r4, sl
 8001de6:	3b08      	subs	r3, #8
 8001de8:	2200      	movs	r2, #0
 8001dea:	409c      	lsls	r4, r3
 8001dec:	e635      	b.n	8001a5a <__aeabi_ddiv+0x152>
 8001dee:	230f      	movs	r3, #15
 8001df0:	402b      	ands	r3, r5
 8001df2:	2b04      	cmp	r3, #4
 8001df4:	d100      	bne.n	8001df8 <__aeabi_ddiv+0x4f0>
 8001df6:	e652      	b.n	8001a9e <__aeabi_ddiv+0x196>
 8001df8:	2305      	movs	r3, #5
 8001dfa:	425b      	negs	r3, r3
 8001dfc:	42ab      	cmp	r3, r5
 8001dfe:	419b      	sbcs	r3, r3
 8001e00:	3504      	adds	r5, #4
 8001e02:	425b      	negs	r3, r3
 8001e04:	08ed      	lsrs	r5, r5, #3
 8001e06:	4498      	add	r8, r3
 8001e08:	e64a      	b.n	8001aa0 <__aeabi_ddiv+0x198>
 8001e0a:	428c      	cmp	r4, r1
 8001e0c:	d1c5      	bne.n	8001d9a <__aeabi_ddiv+0x492>
 8001e0e:	42af      	cmp	r7, r5
 8001e10:	d9c0      	bls.n	8001d94 <__aeabi_ddiv+0x48c>
 8001e12:	4690      	mov	r8, r2
 8001e14:	e716      	b.n	8001c44 <__aeabi_ddiv+0x33c>
 8001e16:	428a      	cmp	r2, r1
 8001e18:	d800      	bhi.n	8001e1c <__aeabi_ddiv+0x514>
 8001e1a:	e6ea      	b.n	8001bf2 <__aeabi_ddiv+0x2ea>
 8001e1c:	1e83      	subs	r3, r0, #2
 8001e1e:	1909      	adds	r1, r1, r4
 8001e20:	e6e7      	b.n	8001bf2 <__aeabi_ddiv+0x2ea>
 8001e22:	4a2a      	ldr	r2, [pc, #168]	; (8001ecc <__aeabi_ddiv+0x5c4>)
 8001e24:	0028      	movs	r0, r5
 8001e26:	445a      	add	r2, fp
 8001e28:	4643      	mov	r3, r8
 8001e2a:	4095      	lsls	r5, r2
 8001e2c:	4093      	lsls	r3, r2
 8001e2e:	40c8      	lsrs	r0, r1
 8001e30:	1e6a      	subs	r2, r5, #1
 8001e32:	4195      	sbcs	r5, r2
 8001e34:	4644      	mov	r4, r8
 8001e36:	4303      	orrs	r3, r0
 8001e38:	432b      	orrs	r3, r5
 8001e3a:	40cc      	lsrs	r4, r1
 8001e3c:	075a      	lsls	r2, r3, #29
 8001e3e:	d092      	beq.n	8001d66 <__aeabi_ddiv+0x45e>
 8001e40:	220f      	movs	r2, #15
 8001e42:	401a      	ands	r2, r3
 8001e44:	2a04      	cmp	r2, #4
 8001e46:	d188      	bne.n	8001d5a <__aeabi_ddiv+0x452>
 8001e48:	e78d      	b.n	8001d66 <__aeabi_ddiv+0x45e>
 8001e4a:	0035      	movs	r5, r6
 8001e4c:	4281      	cmp	r1, r0
 8001e4e:	d000      	beq.n	8001e52 <__aeabi_ddiv+0x54a>
 8001e50:	e74b      	b.n	8001cea <__aeabi_ddiv+0x3e2>
 8001e52:	9a00      	ldr	r2, [sp, #0]
 8001e54:	4293      	cmp	r3, r2
 8001e56:	d000      	beq.n	8001e5a <__aeabi_ddiv+0x552>
 8001e58:	e747      	b.n	8001cea <__aeabi_ddiv+0x3e2>
 8001e5a:	e618      	b.n	8001a8e <__aeabi_ddiv+0x186>
 8001e5c:	42ae      	cmp	r6, r5
 8001e5e:	d99c      	bls.n	8001d9a <__aeabi_ddiv+0x492>
 8001e60:	2302      	movs	r3, #2
 8001e62:	425b      	negs	r3, r3
 8001e64:	469c      	mov	ip, r3
 8001e66:	9b00      	ldr	r3, [sp, #0]
 8001e68:	44e0      	add	r8, ip
 8001e6a:	469c      	mov	ip, r3
 8001e6c:	4465      	add	r5, ip
 8001e6e:	429d      	cmp	r5, r3
 8001e70:	419b      	sbcs	r3, r3
 8001e72:	425b      	negs	r3, r3
 8001e74:	191b      	adds	r3, r3, r4
 8001e76:	18c9      	adds	r1, r1, r3
 8001e78:	e6e4      	b.n	8001c44 <__aeabi_ddiv+0x33c>
 8001e7a:	4a15      	ldr	r2, [pc, #84]	; (8001ed0 <__aeabi_ddiv+0x5c8>)
 8001e7c:	445a      	add	r2, fp
 8001e7e:	2a00      	cmp	r2, #0
 8001e80:	dc00      	bgt.n	8001e84 <__aeabi_ddiv+0x57c>
 8001e82:	e744      	b.n	8001d0e <__aeabi_ddiv+0x406>
 8001e84:	2301      	movs	r3, #1
 8001e86:	2500      	movs	r5, #0
 8001e88:	4498      	add	r8, r3
 8001e8a:	e609      	b.n	8001aa0 <__aeabi_ddiv+0x198>
 8001e8c:	0765      	lsls	r5, r4, #29
 8001e8e:	0264      	lsls	r4, r4, #9
 8001e90:	0b24      	lsrs	r4, r4, #12
 8001e92:	08db      	lsrs	r3, r3, #3
 8001e94:	431d      	orrs	r5, r3
 8001e96:	2300      	movs	r3, #0
 8001e98:	e590      	b.n	80019bc <__aeabi_ddiv+0xb4>
 8001e9a:	9e00      	ldr	r6, [sp, #0]
 8001e9c:	3d02      	subs	r5, #2
 8001e9e:	0072      	lsls	r2, r6, #1
 8001ea0:	42b2      	cmp	r2, r6
 8001ea2:	41bf      	sbcs	r7, r7
 8001ea4:	427f      	negs	r7, r7
 8001ea6:	193c      	adds	r4, r7, r4
 8001ea8:	1909      	adds	r1, r1, r4
 8001eaa:	9200      	str	r2, [sp, #0]
 8001eac:	e7ce      	b.n	8001e4c <__aeabi_ddiv+0x544>
 8001eae:	2480      	movs	r4, #128	; 0x80
 8001eb0:	4643      	mov	r3, r8
 8001eb2:	0324      	lsls	r4, r4, #12
 8001eb4:	431c      	orrs	r4, r3
 8001eb6:	0324      	lsls	r4, r4, #12
 8001eb8:	4b06      	ldr	r3, [pc, #24]	; (8001ed4 <__aeabi_ddiv+0x5cc>)
 8001eba:	0b24      	lsrs	r4, r4, #12
 8001ebc:	e57e      	b.n	80019bc <__aeabi_ddiv+0xb4>
 8001ebe:	9a00      	ldr	r2, [sp, #0]
 8001ec0:	429a      	cmp	r2, r3
 8001ec2:	d3ea      	bcc.n	8001e9a <__aeabi_ddiv+0x592>
 8001ec4:	0035      	movs	r5, r6
 8001ec6:	e7c4      	b.n	8001e52 <__aeabi_ddiv+0x54a>
 8001ec8:	0000043e 	.word	0x0000043e
 8001ecc:	0000041e 	.word	0x0000041e
 8001ed0:	000003ff 	.word	0x000003ff
 8001ed4:	000007ff 	.word	0x000007ff

08001ed8 <__aeabi_dmul>:
 8001ed8:	b5f0      	push	{r4, r5, r6, r7, lr}
 8001eda:	4657      	mov	r7, sl
 8001edc:	464e      	mov	r6, r9
 8001ede:	4645      	mov	r5, r8
 8001ee0:	46de      	mov	lr, fp
 8001ee2:	b5e0      	push	{r5, r6, r7, lr}
 8001ee4:	4698      	mov	r8, r3
 8001ee6:	030c      	lsls	r4, r1, #12
 8001ee8:	004b      	lsls	r3, r1, #1
 8001eea:	0006      	movs	r6, r0
 8001eec:	4692      	mov	sl, r2
 8001eee:	b087      	sub	sp, #28
 8001ef0:	0b24      	lsrs	r4, r4, #12
 8001ef2:	0d5b      	lsrs	r3, r3, #21
 8001ef4:	0fcf      	lsrs	r7, r1, #31
 8001ef6:	2b00      	cmp	r3, #0
 8001ef8:	d06c      	beq.n	8001fd4 <__aeabi_dmul+0xfc>
 8001efa:	4add      	ldr	r2, [pc, #884]	; (8002270 <__aeabi_dmul+0x398>)
 8001efc:	4293      	cmp	r3, r2
 8001efe:	d100      	bne.n	8001f02 <__aeabi_dmul+0x2a>
 8001f00:	e086      	b.n	8002010 <__aeabi_dmul+0x138>
 8001f02:	0f42      	lsrs	r2, r0, #29
 8001f04:	00e4      	lsls	r4, r4, #3
 8001f06:	4314      	orrs	r4, r2
 8001f08:	2280      	movs	r2, #128	; 0x80
 8001f0a:	0412      	lsls	r2, r2, #16
 8001f0c:	4314      	orrs	r4, r2
 8001f0e:	4ad9      	ldr	r2, [pc, #868]	; (8002274 <__aeabi_dmul+0x39c>)
 8001f10:	00c5      	lsls	r5, r0, #3
 8001f12:	4694      	mov	ip, r2
 8001f14:	4463      	add	r3, ip
 8001f16:	9300      	str	r3, [sp, #0]
 8001f18:	2300      	movs	r3, #0
 8001f1a:	4699      	mov	r9, r3
 8001f1c:	469b      	mov	fp, r3
 8001f1e:	4643      	mov	r3, r8
 8001f20:	4642      	mov	r2, r8
 8001f22:	031e      	lsls	r6, r3, #12
 8001f24:	0fd2      	lsrs	r2, r2, #31
 8001f26:	005b      	lsls	r3, r3, #1
 8001f28:	4650      	mov	r0, sl
 8001f2a:	4690      	mov	r8, r2
 8001f2c:	0b36      	lsrs	r6, r6, #12
 8001f2e:	0d5b      	lsrs	r3, r3, #21
 8001f30:	d100      	bne.n	8001f34 <__aeabi_dmul+0x5c>
 8001f32:	e078      	b.n	8002026 <__aeabi_dmul+0x14e>
 8001f34:	4ace      	ldr	r2, [pc, #824]	; (8002270 <__aeabi_dmul+0x398>)
 8001f36:	4293      	cmp	r3, r2
 8001f38:	d01d      	beq.n	8001f76 <__aeabi_dmul+0x9e>
 8001f3a:	49ce      	ldr	r1, [pc, #824]	; (8002274 <__aeabi_dmul+0x39c>)
 8001f3c:	0f42      	lsrs	r2, r0, #29
 8001f3e:	468c      	mov	ip, r1
 8001f40:	9900      	ldr	r1, [sp, #0]
 8001f42:	4463      	add	r3, ip
 8001f44:	00f6      	lsls	r6, r6, #3
 8001f46:	468c      	mov	ip, r1
 8001f48:	4316      	orrs	r6, r2
 8001f4a:	2280      	movs	r2, #128	; 0x80
 8001f4c:	449c      	add	ip, r3
 8001f4e:	0412      	lsls	r2, r2, #16
 8001f50:	4663      	mov	r3, ip
 8001f52:	4316      	orrs	r6, r2
 8001f54:	00c2      	lsls	r2, r0, #3
 8001f56:	2000      	movs	r0, #0
 8001f58:	9300      	str	r3, [sp, #0]
 8001f5a:	9900      	ldr	r1, [sp, #0]
 8001f5c:	4643      	mov	r3, r8
 8001f5e:	3101      	adds	r1, #1
 8001f60:	468c      	mov	ip, r1
 8001f62:	4649      	mov	r1, r9
 8001f64:	407b      	eors	r3, r7
 8001f66:	9301      	str	r3, [sp, #4]
 8001f68:	290f      	cmp	r1, #15
 8001f6a:	d900      	bls.n	8001f6e <__aeabi_dmul+0x96>
 8001f6c:	e07e      	b.n	800206c <__aeabi_dmul+0x194>
 8001f6e:	4bc2      	ldr	r3, [pc, #776]	; (8002278 <__aeabi_dmul+0x3a0>)
 8001f70:	0089      	lsls	r1, r1, #2
 8001f72:	5859      	ldr	r1, [r3, r1]
 8001f74:	468f      	mov	pc, r1
 8001f76:	4652      	mov	r2, sl
 8001f78:	9b00      	ldr	r3, [sp, #0]
 8001f7a:	4332      	orrs	r2, r6
 8001f7c:	d000      	beq.n	8001f80 <__aeabi_dmul+0xa8>
 8001f7e:	e156      	b.n	800222e <__aeabi_dmul+0x356>
 8001f80:	49bb      	ldr	r1, [pc, #748]	; (8002270 <__aeabi_dmul+0x398>)
 8001f82:	2600      	movs	r6, #0
 8001f84:	468c      	mov	ip, r1
 8001f86:	4463      	add	r3, ip
 8001f88:	4649      	mov	r1, r9
 8001f8a:	9300      	str	r3, [sp, #0]
 8001f8c:	2302      	movs	r3, #2
 8001f8e:	4319      	orrs	r1, r3
 8001f90:	4689      	mov	r9, r1
 8001f92:	2002      	movs	r0, #2
 8001f94:	e7e1      	b.n	8001f5a <__aeabi_dmul+0x82>
 8001f96:	4643      	mov	r3, r8
 8001f98:	9301      	str	r3, [sp, #4]
 8001f9a:	0034      	movs	r4, r6
 8001f9c:	0015      	movs	r5, r2
 8001f9e:	4683      	mov	fp, r0
 8001fa0:	465b      	mov	r3, fp
 8001fa2:	2b02      	cmp	r3, #2
 8001fa4:	d05e      	beq.n	8002064 <__aeabi_dmul+0x18c>
 8001fa6:	2b03      	cmp	r3, #3
 8001fa8:	d100      	bne.n	8001fac <__aeabi_dmul+0xd4>
 8001faa:	e1f3      	b.n	8002394 <__aeabi_dmul+0x4bc>
 8001fac:	2b01      	cmp	r3, #1
 8001fae:	d000      	beq.n	8001fb2 <__aeabi_dmul+0xda>
 8001fb0:	e118      	b.n	80021e4 <__aeabi_dmul+0x30c>
 8001fb2:	2200      	movs	r2, #0
 8001fb4:	2400      	movs	r4, #0
 8001fb6:	2500      	movs	r5, #0
 8001fb8:	9b01      	ldr	r3, [sp, #4]
 8001fba:	0512      	lsls	r2, r2, #20
 8001fbc:	4322      	orrs	r2, r4
 8001fbe:	07db      	lsls	r3, r3, #31
 8001fc0:	431a      	orrs	r2, r3
 8001fc2:	0028      	movs	r0, r5
 8001fc4:	0011      	movs	r1, r2
 8001fc6:	b007      	add	sp, #28
 8001fc8:	bcf0      	pop	{r4, r5, r6, r7}
 8001fca:	46bb      	mov	fp, r7
 8001fcc:	46b2      	mov	sl, r6
 8001fce:	46a9      	mov	r9, r5
 8001fd0:	46a0      	mov	r8, r4
 8001fd2:	bdf0      	pop	{r4, r5, r6, r7, pc}
 8001fd4:	0025      	movs	r5, r4
 8001fd6:	4305      	orrs	r5, r0
 8001fd8:	d100      	bne.n	8001fdc <__aeabi_dmul+0x104>
 8001fda:	e141      	b.n	8002260 <__aeabi_dmul+0x388>
 8001fdc:	2c00      	cmp	r4, #0
 8001fde:	d100      	bne.n	8001fe2 <__aeabi_dmul+0x10a>
 8001fe0:	e1ad      	b.n	800233e <__aeabi_dmul+0x466>
 8001fe2:	0020      	movs	r0, r4
 8001fe4:	f000 feea 	bl	8002dbc <__clzsi2>
 8001fe8:	0001      	movs	r1, r0
 8001fea:	0002      	movs	r2, r0
 8001fec:	390b      	subs	r1, #11
 8001fee:	231d      	movs	r3, #29
 8001ff0:	0010      	movs	r0, r2
 8001ff2:	1a5b      	subs	r3, r3, r1
 8001ff4:	0031      	movs	r1, r6
 8001ff6:	0035      	movs	r5, r6
 8001ff8:	3808      	subs	r0, #8
 8001ffa:	4084      	lsls	r4, r0
 8001ffc:	40d9      	lsrs	r1, r3
 8001ffe:	4085      	lsls	r5, r0
 8002000:	430c      	orrs	r4, r1
 8002002:	489e      	ldr	r0, [pc, #632]	; (800227c <__aeabi_dmul+0x3a4>)
 8002004:	1a83      	subs	r3, r0, r2
 8002006:	9300      	str	r3, [sp, #0]
 8002008:	2300      	movs	r3, #0
 800200a:	4699      	mov	r9, r3
 800200c:	469b      	mov	fp, r3
 800200e:	e786      	b.n	8001f1e <__aeabi_dmul+0x46>
 8002010:	0005      	movs	r5, r0
 8002012:	4325      	orrs	r5, r4
 8002014:	d000      	beq.n	8002018 <__aeabi_dmul+0x140>
 8002016:	e11c      	b.n	8002252 <__aeabi_dmul+0x37a>
 8002018:	2208      	movs	r2, #8
 800201a:	9300      	str	r3, [sp, #0]
 800201c:	2302      	movs	r3, #2
 800201e:	2400      	movs	r4, #0
 8002020:	4691      	mov	r9, r2
 8002022:	469b      	mov	fp, r3
 8002024:	e77b      	b.n	8001f1e <__aeabi_dmul+0x46>
 8002026:	4652      	mov	r2, sl
 8002028:	4332      	orrs	r2, r6
 800202a:	d100      	bne.n	800202e <__aeabi_dmul+0x156>
 800202c:	e10a      	b.n	8002244 <__aeabi_dmul+0x36c>
 800202e:	2e00      	cmp	r6, #0
 8002030:	d100      	bne.n	8002034 <__aeabi_dmul+0x15c>
 8002032:	e176      	b.n	8002322 <__aeabi_dmul+0x44a>
 8002034:	0030      	movs	r0, r6
 8002036:	f000 fec1 	bl	8002dbc <__clzsi2>
 800203a:	0002      	movs	r2, r0
 800203c:	3a0b      	subs	r2, #11
 800203e:	231d      	movs	r3, #29
 8002040:	0001      	movs	r1, r0
 8002042:	1a9b      	subs	r3, r3, r2
 8002044:	4652      	mov	r2, sl
 8002046:	3908      	subs	r1, #8
 8002048:	40da      	lsrs	r2, r3
 800204a:	408e      	lsls	r6, r1
 800204c:	4316      	orrs	r6, r2
 800204e:	4652      	mov	r2, sl
 8002050:	408a      	lsls	r2, r1
 8002052:	9b00      	ldr	r3, [sp, #0]
 8002054:	4989      	ldr	r1, [pc, #548]	; (800227c <__aeabi_dmul+0x3a4>)
 8002056:	1a18      	subs	r0, r3, r0
 8002058:	0003      	movs	r3, r0
 800205a:	468c      	mov	ip, r1
 800205c:	4463      	add	r3, ip
 800205e:	2000      	movs	r0, #0
 8002060:	9300      	str	r3, [sp, #0]
 8002062:	e77a      	b.n	8001f5a <__aeabi_dmul+0x82>
 8002064:	2400      	movs	r4, #0
 8002066:	2500      	movs	r5, #0
 8002068:	4a81      	ldr	r2, [pc, #516]	; (8002270 <__aeabi_dmul+0x398>)
 800206a:	e7a5      	b.n	8001fb8 <__aeabi_dmul+0xe0>
 800206c:	0c2f      	lsrs	r7, r5, #16
 800206e:	042d      	lsls	r5, r5, #16
 8002070:	0c2d      	lsrs	r5, r5, #16
 8002072:	002b      	movs	r3, r5
 8002074:	0c11      	lsrs	r1, r2, #16
 8002076:	0412      	lsls	r2, r2, #16
 8002078:	0c12      	lsrs	r2, r2, #16
 800207a:	4353      	muls	r3, r2
 800207c:	4698      	mov	r8, r3
 800207e:	0013      	movs	r3, r2
 8002080:	0028      	movs	r0, r5
 8002082:	437b      	muls	r3, r7
 8002084:	4699      	mov	r9, r3
 8002086:	4348      	muls	r0, r1
 8002088:	4448      	add	r0, r9
 800208a:	4683      	mov	fp, r0
 800208c:	4640      	mov	r0, r8
 800208e:	000b      	movs	r3, r1
 8002090:	0c00      	lsrs	r0, r0, #16
 8002092:	4682      	mov	sl, r0
 8002094:	4658      	mov	r0, fp
 8002096:	437b      	muls	r3, r7
 8002098:	4450      	add	r0, sl
 800209a:	9302      	str	r3, [sp, #8]
 800209c:	4581      	cmp	r9, r0
 800209e:	d906      	bls.n	80020ae <__aeabi_dmul+0x1d6>
 80020a0:	469a      	mov	sl, r3
 80020a2:	2380      	movs	r3, #128	; 0x80
 80020a4:	025b      	lsls	r3, r3, #9
 80020a6:	4699      	mov	r9, r3
 80020a8:	44ca      	add	sl, r9
 80020aa:	4653      	mov	r3, sl
 80020ac:	9302      	str	r3, [sp, #8]
 80020ae:	0c03      	lsrs	r3, r0, #16
 80020b0:	469b      	mov	fp, r3
 80020b2:	4643      	mov	r3, r8
 80020b4:	041b      	lsls	r3, r3, #16
 80020b6:	0400      	lsls	r0, r0, #16
 80020b8:	0c1b      	lsrs	r3, r3, #16
 80020ba:	4698      	mov	r8, r3
 80020bc:	0003      	movs	r3, r0
 80020be:	4443      	add	r3, r8
 80020c0:	9304      	str	r3, [sp, #16]
 80020c2:	0c33      	lsrs	r3, r6, #16
 80020c4:	4699      	mov	r9, r3
 80020c6:	002b      	movs	r3, r5
 80020c8:	0436      	lsls	r6, r6, #16
 80020ca:	0c36      	lsrs	r6, r6, #16
 80020cc:	4373      	muls	r3, r6
 80020ce:	4698      	mov	r8, r3
 80020d0:	0033      	movs	r3, r6
 80020d2:	437b      	muls	r3, r7
 80020d4:	469a      	mov	sl, r3
 80020d6:	464b      	mov	r3, r9
 80020d8:	435d      	muls	r5, r3
 80020da:	435f      	muls	r7, r3
 80020dc:	4643      	mov	r3, r8
 80020de:	4455      	add	r5, sl
 80020e0:	0c18      	lsrs	r0, r3, #16
 80020e2:	1940      	adds	r0, r0, r5
 80020e4:	4582      	cmp	sl, r0
 80020e6:	d903      	bls.n	80020f0 <__aeabi_dmul+0x218>
 80020e8:	2380      	movs	r3, #128	; 0x80
 80020ea:	025b      	lsls	r3, r3, #9
 80020ec:	469a      	mov	sl, r3
 80020ee:	4457      	add	r7, sl
 80020f0:	0c05      	lsrs	r5, r0, #16
 80020f2:	19eb      	adds	r3, r5, r7
 80020f4:	9305      	str	r3, [sp, #20]
 80020f6:	4643      	mov	r3, r8
 80020f8:	041d      	lsls	r5, r3, #16
 80020fa:	0c2d      	lsrs	r5, r5, #16
 80020fc:	0400      	lsls	r0, r0, #16
 80020fe:	1940      	adds	r0, r0, r5
 8002100:	0c25      	lsrs	r5, r4, #16
 8002102:	0424      	lsls	r4, r4, #16
 8002104:	0c24      	lsrs	r4, r4, #16
 8002106:	0027      	movs	r7, r4
 8002108:	4357      	muls	r7, r2
 800210a:	436a      	muls	r2, r5
 800210c:	4690      	mov	r8, r2
 800210e:	002a      	movs	r2, r5
 8002110:	0c3b      	lsrs	r3, r7, #16
 8002112:	469a      	mov	sl, r3
 8002114:	434a      	muls	r2, r1
 8002116:	4361      	muls	r1, r4
 8002118:	4441      	add	r1, r8
 800211a:	4451      	add	r1, sl
 800211c:	4483      	add	fp, r0
 800211e:	4588      	cmp	r8, r1
 8002120:	d903      	bls.n	800212a <__aeabi_dmul+0x252>
 8002122:	2380      	movs	r3, #128	; 0x80
 8002124:	025b      	lsls	r3, r3, #9
 8002126:	4698      	mov	r8, r3
 8002128:	4442      	add	r2, r8
 800212a:	043f      	lsls	r7, r7, #16
 800212c:	0c0b      	lsrs	r3, r1, #16
 800212e:	0c3f      	lsrs	r7, r7, #16
 8002130:	0409      	lsls	r1, r1, #16
 8002132:	19c9      	adds	r1, r1, r7
 8002134:	0027      	movs	r7, r4
 8002136:	4698      	mov	r8, r3
 8002138:	464b      	mov	r3, r9
 800213a:	4377      	muls	r7, r6
 800213c:	435c      	muls	r4, r3
 800213e:	436e      	muls	r6, r5
 8002140:	435d      	muls	r5, r3
 8002142:	0c3b      	lsrs	r3, r7, #16
 8002144:	4699      	mov	r9, r3
 8002146:	19a4      	adds	r4, r4, r6
 8002148:	444c      	add	r4, r9
 800214a:	4442      	add	r2, r8
 800214c:	9503      	str	r5, [sp, #12]
 800214e:	42a6      	cmp	r6, r4
 8002150:	d904      	bls.n	800215c <__aeabi_dmul+0x284>
 8002152:	2380      	movs	r3, #128	; 0x80
 8002154:	025b      	lsls	r3, r3, #9
 8002156:	4698      	mov	r8, r3
 8002158:	4445      	add	r5, r8
 800215a:	9503      	str	r5, [sp, #12]
 800215c:	9b02      	ldr	r3, [sp, #8]
 800215e:	043f      	lsls	r7, r7, #16
 8002160:	445b      	add	r3, fp
 8002162:	001e      	movs	r6, r3
 8002164:	4283      	cmp	r3, r0
 8002166:	4180      	sbcs	r0, r0
 8002168:	0423      	lsls	r3, r4, #16
 800216a:	4698      	mov	r8, r3
 800216c:	9b05      	ldr	r3, [sp, #20]
 800216e:	0c3f      	lsrs	r7, r7, #16
 8002170:	4447      	add	r7, r8
 8002172:	4698      	mov	r8, r3
 8002174:	1876      	adds	r6, r6, r1
 8002176:	428e      	cmp	r6, r1
 8002178:	4189      	sbcs	r1, r1
 800217a:	4447      	add	r7, r8
 800217c:	4240      	negs	r0, r0
 800217e:	183d      	adds	r5, r7, r0
 8002180:	46a8      	mov	r8, r5
 8002182:	4693      	mov	fp, r2
 8002184:	4249      	negs	r1, r1
 8002186:	468a      	mov	sl, r1
 8002188:	44c3      	add	fp, r8
 800218a:	429f      	cmp	r7, r3
 800218c:	41bf      	sbcs	r7, r7
 800218e:	4580      	cmp	r8, r0
 8002190:	4180      	sbcs	r0, r0
 8002192:	9b03      	ldr	r3, [sp, #12]
 8002194:	44da      	add	sl, fp
 8002196:	4698      	mov	r8, r3
 8002198:	4653      	mov	r3, sl
 800219a:	4240      	negs	r0, r0
 800219c:	427f      	negs	r7, r7
 800219e:	4307      	orrs	r7, r0
 80021a0:	0c24      	lsrs	r4, r4, #16
 80021a2:	4593      	cmp	fp, r2
 80021a4:	4192      	sbcs	r2, r2
 80021a6:	458a      	cmp	sl, r1
 80021a8:	4189      	sbcs	r1, r1
 80021aa:	193f      	adds	r7, r7, r4
 80021ac:	0ddc      	lsrs	r4, r3, #23
 80021ae:	9b04      	ldr	r3, [sp, #16]
 80021b0:	0275      	lsls	r5, r6, #9
 80021b2:	431d      	orrs	r5, r3
 80021b4:	1e68      	subs	r0, r5, #1
 80021b6:	4185      	sbcs	r5, r0
 80021b8:	4653      	mov	r3, sl
 80021ba:	4252      	negs	r2, r2
 80021bc:	4249      	negs	r1, r1
 80021be:	430a      	orrs	r2, r1
 80021c0:	18bf      	adds	r7, r7, r2
 80021c2:	4447      	add	r7, r8
 80021c4:	0df6      	lsrs	r6, r6, #23
 80021c6:	027f      	lsls	r7, r7, #9
 80021c8:	4335      	orrs	r5, r6
 80021ca:	025a      	lsls	r2, r3, #9
 80021cc:	433c      	orrs	r4, r7
 80021ce:	4315      	orrs	r5, r2
 80021d0:	01fb      	lsls	r3, r7, #7
 80021d2:	d400      	bmi.n	80021d6 <__aeabi_dmul+0x2fe>
 80021d4:	e0c1      	b.n	800235a <__aeabi_dmul+0x482>
 80021d6:	2101      	movs	r1, #1
 80021d8:	086a      	lsrs	r2, r5, #1
 80021da:	400d      	ands	r5, r1
 80021dc:	4315      	orrs	r5, r2
 80021de:	07e2      	lsls	r2, r4, #31
 80021e0:	4315      	orrs	r5, r2
 80021e2:	0864      	lsrs	r4, r4, #1
 80021e4:	4926      	ldr	r1, [pc, #152]	; (8002280 <__aeabi_dmul+0x3a8>)
 80021e6:	4461      	add	r1, ip
 80021e8:	2900      	cmp	r1, #0
 80021ea:	dd56      	ble.n	800229a <__aeabi_dmul+0x3c2>
 80021ec:	076b      	lsls	r3, r5, #29
 80021ee:	d009      	beq.n	8002204 <__aeabi_dmul+0x32c>
 80021f0:	220f      	movs	r2, #15
 80021f2:	402a      	ands	r2, r5
 80021f4:	2a04      	cmp	r2, #4
 80021f6:	d005      	beq.n	8002204 <__aeabi_dmul+0x32c>
 80021f8:	1d2a      	adds	r2, r5, #4
 80021fa:	42aa      	cmp	r2, r5
 80021fc:	41ad      	sbcs	r5, r5
 80021fe:	426d      	negs	r5, r5
 8002200:	1964      	adds	r4, r4, r5
 8002202:	0015      	movs	r5, r2
 8002204:	01e3      	lsls	r3, r4, #7
 8002206:	d504      	bpl.n	8002212 <__aeabi_dmul+0x33a>
 8002208:	2180      	movs	r1, #128	; 0x80
 800220a:	4a1e      	ldr	r2, [pc, #120]	; (8002284 <__aeabi_dmul+0x3ac>)
 800220c:	00c9      	lsls	r1, r1, #3
 800220e:	4014      	ands	r4, r2
 8002210:	4461      	add	r1, ip
 8002212:	4a1d      	ldr	r2, [pc, #116]	; (8002288 <__aeabi_dmul+0x3b0>)
 8002214:	4291      	cmp	r1, r2
 8002216:	dd00      	ble.n	800221a <__aeabi_dmul+0x342>
 8002218:	e724      	b.n	8002064 <__aeabi_dmul+0x18c>
 800221a:	0762      	lsls	r2, r4, #29
 800221c:	08ed      	lsrs	r5, r5, #3
 800221e:	0264      	lsls	r4, r4, #9
 8002220:	0549      	lsls	r1, r1, #21
 8002222:	4315      	orrs	r5, r2
 8002224:	0b24      	lsrs	r4, r4, #12
 8002226:	0d4a      	lsrs	r2, r1, #21
 8002228:	e6c6      	b.n	8001fb8 <__aeabi_dmul+0xe0>
 800222a:	9701      	str	r7, [sp, #4]
 800222c:	e6b8      	b.n	8001fa0 <__aeabi_dmul+0xc8>
 800222e:	4a10      	ldr	r2, [pc, #64]	; (8002270 <__aeabi_dmul+0x398>)
 8002230:	2003      	movs	r0, #3
 8002232:	4694      	mov	ip, r2
 8002234:	4463      	add	r3, ip
 8002236:	464a      	mov	r2, r9
 8002238:	9300      	str	r3, [sp, #0]
 800223a:	2303      	movs	r3, #3
 800223c:	431a      	orrs	r2, r3
 800223e:	4691      	mov	r9, r2
 8002240:	4652      	mov	r2, sl
 8002242:	e68a      	b.n	8001f5a <__aeabi_dmul+0x82>
 8002244:	4649      	mov	r1, r9
 8002246:	2301      	movs	r3, #1
 8002248:	4319      	orrs	r1, r3
 800224a:	4689      	mov	r9, r1
 800224c:	2600      	movs	r6, #0
 800224e:	2001      	movs	r0, #1
 8002250:	e683      	b.n	8001f5a <__aeabi_dmul+0x82>
 8002252:	220c      	movs	r2, #12
 8002254:	9300      	str	r3, [sp, #0]
 8002256:	2303      	movs	r3, #3
 8002258:	0005      	movs	r5, r0
 800225a:	4691      	mov	r9, r2
 800225c:	469b      	mov	fp, r3
 800225e:	e65e      	b.n	8001f1e <__aeabi_dmul+0x46>
 8002260:	2304      	movs	r3, #4
 8002262:	4699      	mov	r9, r3
 8002264:	2300      	movs	r3, #0
 8002266:	9300      	str	r3, [sp, #0]
 8002268:	3301      	adds	r3, #1
 800226a:	2400      	movs	r4, #0
 800226c:	469b      	mov	fp, r3
 800226e:	e656      	b.n	8001f1e <__aeabi_dmul+0x46>
 8002270:	000007ff 	.word	0x000007ff
 8002274:	fffffc01 	.word	0xfffffc01
 8002278:	0800e600 	.word	0x0800e600
 800227c:	fffffc0d 	.word	0xfffffc0d
 8002280:	000003ff 	.word	0x000003ff
 8002284:	feffffff 	.word	0xfeffffff
 8002288:	000007fe 	.word	0x000007fe
 800228c:	2300      	movs	r3, #0
 800228e:	2480      	movs	r4, #128	; 0x80
 8002290:	2500      	movs	r5, #0
 8002292:	4a44      	ldr	r2, [pc, #272]	; (80023a4 <__aeabi_dmul+0x4cc>)
 8002294:	9301      	str	r3, [sp, #4]
 8002296:	0324      	lsls	r4, r4, #12
 8002298:	e68e      	b.n	8001fb8 <__aeabi_dmul+0xe0>
 800229a:	2001      	movs	r0, #1
 800229c:	1a40      	subs	r0, r0, r1
 800229e:	2838      	cmp	r0, #56	; 0x38
 80022a0:	dd00      	ble.n	80022a4 <__aeabi_dmul+0x3cc>
 80022a2:	e686      	b.n	8001fb2 <__aeabi_dmul+0xda>
 80022a4:	281f      	cmp	r0, #31
 80022a6:	dd5b      	ble.n	8002360 <__aeabi_dmul+0x488>
 80022a8:	221f      	movs	r2, #31
 80022aa:	0023      	movs	r3, r4
 80022ac:	4252      	negs	r2, r2
 80022ae:	1a51      	subs	r1, r2, r1
 80022b0:	40cb      	lsrs	r3, r1
 80022b2:	0019      	movs	r1, r3
 80022b4:	2820      	cmp	r0, #32
 80022b6:	d003      	beq.n	80022c0 <__aeabi_dmul+0x3e8>
 80022b8:	4a3b      	ldr	r2, [pc, #236]	; (80023a8 <__aeabi_dmul+0x4d0>)
 80022ba:	4462      	add	r2, ip
 80022bc:	4094      	lsls	r4, r2
 80022be:	4325      	orrs	r5, r4
 80022c0:	1e6a      	subs	r2, r5, #1
 80022c2:	4195      	sbcs	r5, r2
 80022c4:	002a      	movs	r2, r5
 80022c6:	430a      	orrs	r2, r1
 80022c8:	2107      	movs	r1, #7
 80022ca:	000d      	movs	r5, r1
 80022cc:	2400      	movs	r4, #0
 80022ce:	4015      	ands	r5, r2
 80022d0:	4211      	tst	r1, r2
 80022d2:	d05b      	beq.n	800238c <__aeabi_dmul+0x4b4>
 80022d4:	210f      	movs	r1, #15
 80022d6:	2400      	movs	r4, #0
 80022d8:	4011      	ands	r1, r2
 80022da:	2904      	cmp	r1, #4
 80022dc:	d053      	beq.n	8002386 <__aeabi_dmul+0x4ae>
 80022de:	1d11      	adds	r1, r2, #4
 80022e0:	4291      	cmp	r1, r2
 80022e2:	4192      	sbcs	r2, r2
 80022e4:	4252      	negs	r2, r2
 80022e6:	18a4      	adds	r4, r4, r2
 80022e8:	000a      	movs	r2, r1
 80022ea:	0223      	lsls	r3, r4, #8
 80022ec:	d54b      	bpl.n	8002386 <__aeabi_dmul+0x4ae>
 80022ee:	2201      	movs	r2, #1
 80022f0:	2400      	movs	r4, #0
 80022f2:	2500      	movs	r5, #0
 80022f4:	e660      	b.n	8001fb8 <__aeabi_dmul+0xe0>
 80022f6:	2380      	movs	r3, #128	; 0x80
 80022f8:	031b      	lsls	r3, r3, #12
 80022fa:	421c      	tst	r4, r3
 80022fc:	d009      	beq.n	8002312 <__aeabi_dmul+0x43a>
 80022fe:	421e      	tst	r6, r3
 8002300:	d107      	bne.n	8002312 <__aeabi_dmul+0x43a>
 8002302:	4333      	orrs	r3, r6
 8002304:	031c      	lsls	r4, r3, #12
 8002306:	4643      	mov	r3, r8
 8002308:	0015      	movs	r5, r2
 800230a:	0b24      	lsrs	r4, r4, #12
 800230c:	4a25      	ldr	r2, [pc, #148]	; (80023a4 <__aeabi_dmul+0x4cc>)
 800230e:	9301      	str	r3, [sp, #4]
 8002310:	e652      	b.n	8001fb8 <__aeabi_dmul+0xe0>
 8002312:	2280      	movs	r2, #128	; 0x80
 8002314:	0312      	lsls	r2, r2, #12
 8002316:	4314      	orrs	r4, r2
 8002318:	0324      	lsls	r4, r4, #12
 800231a:	4a22      	ldr	r2, [pc, #136]	; (80023a4 <__aeabi_dmul+0x4cc>)
 800231c:	0b24      	lsrs	r4, r4, #12
 800231e:	9701      	str	r7, [sp, #4]
 8002320:	e64a      	b.n	8001fb8 <__aeabi_dmul+0xe0>
 8002322:	f000 fd4b 	bl	8002dbc <__clzsi2>
 8002326:	0003      	movs	r3, r0
 8002328:	001a      	movs	r2, r3
 800232a:	3215      	adds	r2, #21
 800232c:	3020      	adds	r0, #32
 800232e:	2a1c      	cmp	r2, #28
 8002330:	dc00      	bgt.n	8002334 <__aeabi_dmul+0x45c>
 8002332:	e684      	b.n	800203e <__aeabi_dmul+0x166>
 8002334:	4656      	mov	r6, sl
 8002336:	3b08      	subs	r3, #8
 8002338:	2200      	movs	r2, #0
 800233a:	409e      	lsls	r6, r3
 800233c:	e689      	b.n	8002052 <__aeabi_dmul+0x17a>
 800233e:	f000 fd3d 	bl	8002dbc <__clzsi2>
 8002342:	0001      	movs	r1, r0
 8002344:	0002      	movs	r2, r0
 8002346:	3115      	adds	r1, #21
 8002348:	3220      	adds	r2, #32
 800234a:	291c      	cmp	r1, #28
 800234c:	dc00      	bgt.n	8002350 <__aeabi_dmul+0x478>
 800234e:	e64e      	b.n	8001fee <__aeabi_dmul+0x116>
 8002350:	0034      	movs	r4, r6
 8002352:	3808      	subs	r0, #8
 8002354:	2500      	movs	r5, #0
 8002356:	4084      	lsls	r4, r0
 8002358:	e653      	b.n	8002002 <__aeabi_dmul+0x12a>
 800235a:	9b00      	ldr	r3, [sp, #0]
 800235c:	469c      	mov	ip, r3
 800235e:	e741      	b.n	80021e4 <__aeabi_dmul+0x30c>
 8002360:	4912      	ldr	r1, [pc, #72]	; (80023ac <__aeabi_dmul+0x4d4>)
 8002362:	0022      	movs	r2, r4
 8002364:	4461      	add	r1, ip
 8002366:	002e      	movs	r6, r5
 8002368:	408d      	lsls	r5, r1
 800236a:	408a      	lsls	r2, r1
 800236c:	40c6      	lsrs	r6, r0
 800236e:	1e69      	subs	r1, r5, #1
 8002370:	418d      	sbcs	r5, r1
 8002372:	4332      	orrs	r2, r6
 8002374:	432a      	orrs	r2, r5
 8002376:	40c4      	lsrs	r4, r0
 8002378:	0753      	lsls	r3, r2, #29
 800237a:	d0b6      	beq.n	80022ea <__aeabi_dmul+0x412>
 800237c:	210f      	movs	r1, #15
 800237e:	4011      	ands	r1, r2
 8002380:	2904      	cmp	r1, #4
 8002382:	d1ac      	bne.n	80022de <__aeabi_dmul+0x406>
 8002384:	e7b1      	b.n	80022ea <__aeabi_dmul+0x412>
 8002386:	0765      	lsls	r5, r4, #29
 8002388:	0264      	lsls	r4, r4, #9
 800238a:	0b24      	lsrs	r4, r4, #12
 800238c:	08d2      	lsrs	r2, r2, #3
 800238e:	4315      	orrs	r5, r2
 8002390:	2200      	movs	r2, #0
 8002392:	e611      	b.n	8001fb8 <__aeabi_dmul+0xe0>
 8002394:	2280      	movs	r2, #128	; 0x80
 8002396:	0312      	lsls	r2, r2, #12
 8002398:	4314      	orrs	r4, r2
 800239a:	0324      	lsls	r4, r4, #12
 800239c:	4a01      	ldr	r2, [pc, #4]	; (80023a4 <__aeabi_dmul+0x4cc>)
 800239e:	0b24      	lsrs	r4, r4, #12
 80023a0:	e60a      	b.n	8001fb8 <__aeabi_dmul+0xe0>
 80023a2:	46c0      	nop			; (mov r8, r8)
 80023a4:	000007ff 	.word	0x000007ff
 80023a8:	0000043e 	.word	0x0000043e
 80023ac:	0000041e 	.word	0x0000041e

080023b0 <__aeabi_dsub>:
 80023b0:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 80023b2:	4657      	mov	r7, sl
 80023b4:	464e      	mov	r6, r9
 80023b6:	4645      	mov	r5, r8
 80023b8:	46de      	mov	lr, fp
 80023ba:	0004      	movs	r4, r0
 80023bc:	b5e0      	push	{r5, r6, r7, lr}
 80023be:	001f      	movs	r7, r3
 80023c0:	0010      	movs	r0, r2
 80023c2:	030b      	lsls	r3, r1, #12
 80023c4:	0f62      	lsrs	r2, r4, #29
 80023c6:	004e      	lsls	r6, r1, #1
 80023c8:	0fcd      	lsrs	r5, r1, #31
 80023ca:	0a5b      	lsrs	r3, r3, #9
 80023cc:	0339      	lsls	r1, r7, #12
 80023ce:	4313      	orrs	r3, r2
 80023d0:	0a49      	lsrs	r1, r1, #9
 80023d2:	00e2      	lsls	r2, r4, #3
 80023d4:	0f44      	lsrs	r4, r0, #29
 80023d6:	4321      	orrs	r1, r4
 80023d8:	4cc2      	ldr	r4, [pc, #776]	; (80026e4 <__aeabi_dsub+0x334>)
 80023da:	4691      	mov	r9, r2
 80023dc:	4692      	mov	sl, r2
 80023de:	00c0      	lsls	r0, r0, #3
 80023e0:	007a      	lsls	r2, r7, #1
 80023e2:	4680      	mov	r8, r0
 80023e4:	0d76      	lsrs	r6, r6, #21
 80023e6:	0d52      	lsrs	r2, r2, #21
 80023e8:	0fff      	lsrs	r7, r7, #31
 80023ea:	42a2      	cmp	r2, r4
 80023ec:	d100      	bne.n	80023f0 <__aeabi_dsub+0x40>
 80023ee:	e0b4      	b.n	800255a <__aeabi_dsub+0x1aa>
 80023f0:	2401      	movs	r4, #1
 80023f2:	4067      	eors	r7, r4
 80023f4:	46bb      	mov	fp, r7
 80023f6:	42bd      	cmp	r5, r7
 80023f8:	d100      	bne.n	80023fc <__aeabi_dsub+0x4c>
 80023fa:	e088      	b.n	800250e <__aeabi_dsub+0x15e>
 80023fc:	1ab4      	subs	r4, r6, r2
 80023fe:	46a4      	mov	ip, r4
 8002400:	2c00      	cmp	r4, #0
 8002402:	dc00      	bgt.n	8002406 <__aeabi_dsub+0x56>
 8002404:	e0b2      	b.n	800256c <__aeabi_dsub+0x1bc>
 8002406:	2a00      	cmp	r2, #0
 8002408:	d100      	bne.n	800240c <__aeabi_dsub+0x5c>
 800240a:	e0c5      	b.n	8002598 <__aeabi_dsub+0x1e8>
 800240c:	4ab5      	ldr	r2, [pc, #724]	; (80026e4 <__aeabi_dsub+0x334>)
 800240e:	4296      	cmp	r6, r2
 8002410:	d100      	bne.n	8002414 <__aeabi_dsub+0x64>
 8002412:	e28b      	b.n	800292c <__aeabi_dsub+0x57c>
 8002414:	2280      	movs	r2, #128	; 0x80
 8002416:	0412      	lsls	r2, r2, #16
 8002418:	4311      	orrs	r1, r2
 800241a:	4662      	mov	r2, ip
 800241c:	2a38      	cmp	r2, #56	; 0x38
 800241e:	dd00      	ble.n	8002422 <__aeabi_dsub+0x72>
 8002420:	e1a1      	b.n	8002766 <__aeabi_dsub+0x3b6>
 8002422:	2a1f      	cmp	r2, #31
 8002424:	dd00      	ble.n	8002428 <__aeabi_dsub+0x78>
 8002426:	e216      	b.n	8002856 <__aeabi_dsub+0x4a6>
 8002428:	2720      	movs	r7, #32
 800242a:	000c      	movs	r4, r1
 800242c:	1abf      	subs	r7, r7, r2
 800242e:	40bc      	lsls	r4, r7
 8002430:	0002      	movs	r2, r0
 8002432:	46a0      	mov	r8, r4
 8002434:	4664      	mov	r4, ip
 8002436:	40b8      	lsls	r0, r7
 8002438:	40e2      	lsrs	r2, r4
 800243a:	4644      	mov	r4, r8
 800243c:	4314      	orrs	r4, r2
 800243e:	0002      	movs	r2, r0
 8002440:	1e50      	subs	r0, r2, #1
 8002442:	4182      	sbcs	r2, r0
 8002444:	4660      	mov	r0, ip
 8002446:	40c1      	lsrs	r1, r0
 8002448:	4322      	orrs	r2, r4
 800244a:	1a5b      	subs	r3, r3, r1
 800244c:	4649      	mov	r1, r9
 800244e:	1a8c      	subs	r4, r1, r2
 8002450:	45a1      	cmp	r9, r4
 8002452:	4192      	sbcs	r2, r2
 8002454:	4252      	negs	r2, r2
 8002456:	1a9b      	subs	r3, r3, r2
 8002458:	4698      	mov	r8, r3
 800245a:	4643      	mov	r3, r8
 800245c:	021b      	lsls	r3, r3, #8
 800245e:	d400      	bmi.n	8002462 <__aeabi_dsub+0xb2>
 8002460:	e117      	b.n	8002692 <__aeabi_dsub+0x2e2>
 8002462:	4643      	mov	r3, r8
 8002464:	025b      	lsls	r3, r3, #9
 8002466:	0a5b      	lsrs	r3, r3, #9
 8002468:	4698      	mov	r8, r3
 800246a:	4643      	mov	r3, r8
 800246c:	2b00      	cmp	r3, #0
 800246e:	d100      	bne.n	8002472 <__aeabi_dsub+0xc2>
 8002470:	e16c      	b.n	800274c <__aeabi_dsub+0x39c>
 8002472:	4640      	mov	r0, r8
 8002474:	f000 fca2 	bl	8002dbc <__clzsi2>
 8002478:	0002      	movs	r2, r0
 800247a:	3a08      	subs	r2, #8
 800247c:	2120      	movs	r1, #32
 800247e:	0020      	movs	r0, r4
 8002480:	4643      	mov	r3, r8
 8002482:	1a89      	subs	r1, r1, r2
 8002484:	4093      	lsls	r3, r2
 8002486:	40c8      	lsrs	r0, r1
 8002488:	4094      	lsls	r4, r2
 800248a:	4303      	orrs	r3, r0
 800248c:	4296      	cmp	r6, r2
 800248e:	dd00      	ble.n	8002492 <__aeabi_dsub+0xe2>
 8002490:	e157      	b.n	8002742 <__aeabi_dsub+0x392>
 8002492:	1b96      	subs	r6, r2, r6
 8002494:	1c71      	adds	r1, r6, #1
 8002496:	291f      	cmp	r1, #31
 8002498:	dd00      	ble.n	800249c <__aeabi_dsub+0xec>
 800249a:	e1cb      	b.n	8002834 <__aeabi_dsub+0x484>
 800249c:	2220      	movs	r2, #32
 800249e:	0018      	movs	r0, r3
 80024a0:	0026      	movs	r6, r4
 80024a2:	1a52      	subs	r2, r2, r1
 80024a4:	4094      	lsls	r4, r2
 80024a6:	4090      	lsls	r0, r2
 80024a8:	40ce      	lsrs	r6, r1
 80024aa:	40cb      	lsrs	r3, r1
 80024ac:	1e62      	subs	r2, r4, #1
 80024ae:	4194      	sbcs	r4, r2
 80024b0:	4330      	orrs	r0, r6
 80024b2:	4698      	mov	r8, r3
 80024b4:	2600      	movs	r6, #0
 80024b6:	4304      	orrs	r4, r0
 80024b8:	0763      	lsls	r3, r4, #29
 80024ba:	d009      	beq.n	80024d0 <__aeabi_dsub+0x120>
 80024bc:	230f      	movs	r3, #15
 80024be:	4023      	ands	r3, r4
 80024c0:	2b04      	cmp	r3, #4
 80024c2:	d005      	beq.n	80024d0 <__aeabi_dsub+0x120>
 80024c4:	1d23      	adds	r3, r4, #4
 80024c6:	42a3      	cmp	r3, r4
 80024c8:	41a4      	sbcs	r4, r4
 80024ca:	4264      	negs	r4, r4
 80024cc:	44a0      	add	r8, r4
 80024ce:	001c      	movs	r4, r3
 80024d0:	4643      	mov	r3, r8
 80024d2:	021b      	lsls	r3, r3, #8
 80024d4:	d400      	bmi.n	80024d8 <__aeabi_dsub+0x128>
 80024d6:	e0df      	b.n	8002698 <__aeabi_dsub+0x2e8>
 80024d8:	4b82      	ldr	r3, [pc, #520]	; (80026e4 <__aeabi_dsub+0x334>)
 80024da:	3601      	adds	r6, #1
 80024dc:	429e      	cmp	r6, r3
 80024de:	d100      	bne.n	80024e2 <__aeabi_dsub+0x132>
 80024e0:	e0fb      	b.n	80026da <__aeabi_dsub+0x32a>
 80024e2:	4642      	mov	r2, r8
 80024e4:	4b80      	ldr	r3, [pc, #512]	; (80026e8 <__aeabi_dsub+0x338>)
 80024e6:	08e4      	lsrs	r4, r4, #3
 80024e8:	401a      	ands	r2, r3
 80024ea:	0013      	movs	r3, r2
 80024ec:	0571      	lsls	r1, r6, #21
 80024ee:	0752      	lsls	r2, r2, #29
 80024f0:	025b      	lsls	r3, r3, #9
 80024f2:	4322      	orrs	r2, r4
 80024f4:	0b1b      	lsrs	r3, r3, #12
 80024f6:	0d49      	lsrs	r1, r1, #21
 80024f8:	0509      	lsls	r1, r1, #20
 80024fa:	07ed      	lsls	r5, r5, #31
 80024fc:	4319      	orrs	r1, r3
 80024fe:	4329      	orrs	r1, r5
 8002500:	0010      	movs	r0, r2
 8002502:	bcf0      	pop	{r4, r5, r6, r7}
 8002504:	46bb      	mov	fp, r7
 8002506:	46b2      	mov	sl, r6
 8002508:	46a9      	mov	r9, r5
 800250a:	46a0      	mov	r8, r4
 800250c:	bdf8      	pop	{r3, r4, r5, r6, r7, pc}
 800250e:	1ab4      	subs	r4, r6, r2
 8002510:	46a4      	mov	ip, r4
 8002512:	2c00      	cmp	r4, #0
 8002514:	dd58      	ble.n	80025c8 <__aeabi_dsub+0x218>
 8002516:	2a00      	cmp	r2, #0
 8002518:	d100      	bne.n	800251c <__aeabi_dsub+0x16c>
 800251a:	e09e      	b.n	800265a <__aeabi_dsub+0x2aa>
 800251c:	4a71      	ldr	r2, [pc, #452]	; (80026e4 <__aeabi_dsub+0x334>)
 800251e:	4296      	cmp	r6, r2
 8002520:	d100      	bne.n	8002524 <__aeabi_dsub+0x174>
 8002522:	e13b      	b.n	800279c <__aeabi_dsub+0x3ec>
 8002524:	2280      	movs	r2, #128	; 0x80
 8002526:	0412      	lsls	r2, r2, #16
 8002528:	4311      	orrs	r1, r2
 800252a:	4662      	mov	r2, ip
 800252c:	2a38      	cmp	r2, #56	; 0x38
 800252e:	dd00      	ble.n	8002532 <__aeabi_dsub+0x182>
 8002530:	e0c1      	b.n	80026b6 <__aeabi_dsub+0x306>
 8002532:	2a1f      	cmp	r2, #31
 8002534:	dc00      	bgt.n	8002538 <__aeabi_dsub+0x188>
 8002536:	e1bb      	b.n	80028b0 <__aeabi_dsub+0x500>
 8002538:	000c      	movs	r4, r1
 800253a:	3a20      	subs	r2, #32
 800253c:	40d4      	lsrs	r4, r2
 800253e:	0022      	movs	r2, r4
 8002540:	4664      	mov	r4, ip
 8002542:	2c20      	cmp	r4, #32
 8002544:	d004      	beq.n	8002550 <__aeabi_dsub+0x1a0>
 8002546:	2740      	movs	r7, #64	; 0x40
 8002548:	1b3f      	subs	r7, r7, r4
 800254a:	40b9      	lsls	r1, r7
 800254c:	4308      	orrs	r0, r1
 800254e:	4680      	mov	r8, r0
 8002550:	4644      	mov	r4, r8
 8002552:	1e61      	subs	r1, r4, #1
 8002554:	418c      	sbcs	r4, r1
 8002556:	4314      	orrs	r4, r2
 8002558:	e0b1      	b.n	80026be <__aeabi_dsub+0x30e>
 800255a:	000c      	movs	r4, r1
 800255c:	4304      	orrs	r4, r0
 800255e:	d02a      	beq.n	80025b6 <__aeabi_dsub+0x206>
 8002560:	46bb      	mov	fp, r7
 8002562:	42bd      	cmp	r5, r7
 8002564:	d02d      	beq.n	80025c2 <__aeabi_dsub+0x212>
 8002566:	4c61      	ldr	r4, [pc, #388]	; (80026ec <__aeabi_dsub+0x33c>)
 8002568:	46a4      	mov	ip, r4
 800256a:	44b4      	add	ip, r6
 800256c:	4664      	mov	r4, ip
 800256e:	2c00      	cmp	r4, #0
 8002570:	d05c      	beq.n	800262c <__aeabi_dsub+0x27c>
 8002572:	1b94      	subs	r4, r2, r6
 8002574:	46a4      	mov	ip, r4
 8002576:	2e00      	cmp	r6, #0
 8002578:	d000      	beq.n	800257c <__aeabi_dsub+0x1cc>
 800257a:	e115      	b.n	80027a8 <__aeabi_dsub+0x3f8>
 800257c:	464d      	mov	r5, r9
 800257e:	431d      	orrs	r5, r3
 8002580:	d100      	bne.n	8002584 <__aeabi_dsub+0x1d4>
 8002582:	e1c3      	b.n	800290c <__aeabi_dsub+0x55c>
 8002584:	1e65      	subs	r5, r4, #1
 8002586:	2c01      	cmp	r4, #1
 8002588:	d100      	bne.n	800258c <__aeabi_dsub+0x1dc>
 800258a:	e20c      	b.n	80029a6 <__aeabi_dsub+0x5f6>
 800258c:	4e55      	ldr	r6, [pc, #340]	; (80026e4 <__aeabi_dsub+0x334>)
 800258e:	42b4      	cmp	r4, r6
 8002590:	d100      	bne.n	8002594 <__aeabi_dsub+0x1e4>
 8002592:	e1f8      	b.n	8002986 <__aeabi_dsub+0x5d6>
 8002594:	46ac      	mov	ip, r5
 8002596:	e10e      	b.n	80027b6 <__aeabi_dsub+0x406>
 8002598:	000a      	movs	r2, r1
 800259a:	4302      	orrs	r2, r0
 800259c:	d100      	bne.n	80025a0 <__aeabi_dsub+0x1f0>
 800259e:	e136      	b.n	800280e <__aeabi_dsub+0x45e>
 80025a0:	0022      	movs	r2, r4
 80025a2:	3a01      	subs	r2, #1
 80025a4:	2c01      	cmp	r4, #1
 80025a6:	d100      	bne.n	80025aa <__aeabi_dsub+0x1fa>
 80025a8:	e1c6      	b.n	8002938 <__aeabi_dsub+0x588>
 80025aa:	4c4e      	ldr	r4, [pc, #312]	; (80026e4 <__aeabi_dsub+0x334>)
 80025ac:	45a4      	cmp	ip, r4
 80025ae:	d100      	bne.n	80025b2 <__aeabi_dsub+0x202>
 80025b0:	e0f4      	b.n	800279c <__aeabi_dsub+0x3ec>
 80025b2:	4694      	mov	ip, r2
 80025b4:	e731      	b.n	800241a <__aeabi_dsub+0x6a>
 80025b6:	2401      	movs	r4, #1
 80025b8:	4067      	eors	r7, r4
 80025ba:	46bb      	mov	fp, r7
 80025bc:	42bd      	cmp	r5, r7
 80025be:	d000      	beq.n	80025c2 <__aeabi_dsub+0x212>
 80025c0:	e71c      	b.n	80023fc <__aeabi_dsub+0x4c>
 80025c2:	4c4a      	ldr	r4, [pc, #296]	; (80026ec <__aeabi_dsub+0x33c>)
 80025c4:	46a4      	mov	ip, r4
 80025c6:	44b4      	add	ip, r6
 80025c8:	4664      	mov	r4, ip
 80025ca:	2c00      	cmp	r4, #0
 80025cc:	d100      	bne.n	80025d0 <__aeabi_dsub+0x220>
 80025ce:	e0cf      	b.n	8002770 <__aeabi_dsub+0x3c0>
 80025d0:	1b94      	subs	r4, r2, r6
 80025d2:	46a4      	mov	ip, r4
 80025d4:	2e00      	cmp	r6, #0
 80025d6:	d100      	bne.n	80025da <__aeabi_dsub+0x22a>
 80025d8:	e15c      	b.n	8002894 <__aeabi_dsub+0x4e4>
 80025da:	4e42      	ldr	r6, [pc, #264]	; (80026e4 <__aeabi_dsub+0x334>)
 80025dc:	42b2      	cmp	r2, r6
 80025de:	d100      	bne.n	80025e2 <__aeabi_dsub+0x232>
 80025e0:	e1ec      	b.n	80029bc <__aeabi_dsub+0x60c>
 80025e2:	2680      	movs	r6, #128	; 0x80
 80025e4:	0436      	lsls	r6, r6, #16
 80025e6:	4333      	orrs	r3, r6
 80025e8:	4664      	mov	r4, ip
 80025ea:	2c38      	cmp	r4, #56	; 0x38
 80025ec:	dd00      	ble.n	80025f0 <__aeabi_dsub+0x240>
 80025ee:	e1b3      	b.n	8002958 <__aeabi_dsub+0x5a8>
 80025f0:	2c1f      	cmp	r4, #31
 80025f2:	dd00      	ble.n	80025f6 <__aeabi_dsub+0x246>
 80025f4:	e238      	b.n	8002a68 <__aeabi_dsub+0x6b8>
 80025f6:	2620      	movs	r6, #32
 80025f8:	1b36      	subs	r6, r6, r4
 80025fa:	001c      	movs	r4, r3
 80025fc:	40b4      	lsls	r4, r6
 80025fe:	464f      	mov	r7, r9
 8002600:	46a0      	mov	r8, r4
 8002602:	4664      	mov	r4, ip
 8002604:	40e7      	lsrs	r7, r4
 8002606:	4644      	mov	r4, r8
 8002608:	433c      	orrs	r4, r7
 800260a:	464f      	mov	r7, r9
 800260c:	40b7      	lsls	r7, r6
 800260e:	003e      	movs	r6, r7
 8002610:	1e77      	subs	r7, r6, #1
 8002612:	41be      	sbcs	r6, r7
 8002614:	4334      	orrs	r4, r6
 8002616:	4666      	mov	r6, ip
 8002618:	40f3      	lsrs	r3, r6
 800261a:	18c9      	adds	r1, r1, r3
 800261c:	1824      	adds	r4, r4, r0
 800261e:	4284      	cmp	r4, r0
 8002620:	419b      	sbcs	r3, r3
 8002622:	425b      	negs	r3, r3
 8002624:	4698      	mov	r8, r3
 8002626:	0016      	movs	r6, r2
 8002628:	4488      	add	r8, r1
 800262a:	e04e      	b.n	80026ca <__aeabi_dsub+0x31a>
 800262c:	4a30      	ldr	r2, [pc, #192]	; (80026f0 <__aeabi_dsub+0x340>)
 800262e:	1c74      	adds	r4, r6, #1
 8002630:	4214      	tst	r4, r2
 8002632:	d000      	beq.n	8002636 <__aeabi_dsub+0x286>
 8002634:	e0d6      	b.n	80027e4 <__aeabi_dsub+0x434>
 8002636:	464a      	mov	r2, r9
 8002638:	431a      	orrs	r2, r3
 800263a:	2e00      	cmp	r6, #0
 800263c:	d000      	beq.n	8002640 <__aeabi_dsub+0x290>
 800263e:	e15b      	b.n	80028f8 <__aeabi_dsub+0x548>
 8002640:	2a00      	cmp	r2, #0
 8002642:	d100      	bne.n	8002646 <__aeabi_dsub+0x296>
 8002644:	e1a5      	b.n	8002992 <__aeabi_dsub+0x5e2>
 8002646:	000a      	movs	r2, r1
 8002648:	4302      	orrs	r2, r0
 800264a:	d000      	beq.n	800264e <__aeabi_dsub+0x29e>
 800264c:	e1bb      	b.n	80029c6 <__aeabi_dsub+0x616>
 800264e:	464a      	mov	r2, r9
 8002650:	0759      	lsls	r1, r3, #29
 8002652:	08d2      	lsrs	r2, r2, #3
 8002654:	430a      	orrs	r2, r1
 8002656:	08db      	lsrs	r3, r3, #3
 8002658:	e027      	b.n	80026aa <__aeabi_dsub+0x2fa>
 800265a:	000a      	movs	r2, r1
 800265c:	4302      	orrs	r2, r0
 800265e:	d100      	bne.n	8002662 <__aeabi_dsub+0x2b2>
 8002660:	e174      	b.n	800294c <__aeabi_dsub+0x59c>
 8002662:	0022      	movs	r2, r4
 8002664:	3a01      	subs	r2, #1
 8002666:	2c01      	cmp	r4, #1
 8002668:	d005      	beq.n	8002676 <__aeabi_dsub+0x2c6>
 800266a:	4c1e      	ldr	r4, [pc, #120]	; (80026e4 <__aeabi_dsub+0x334>)
 800266c:	45a4      	cmp	ip, r4
 800266e:	d100      	bne.n	8002672 <__aeabi_dsub+0x2c2>
 8002670:	e094      	b.n	800279c <__aeabi_dsub+0x3ec>
 8002672:	4694      	mov	ip, r2
 8002674:	e759      	b.n	800252a <__aeabi_dsub+0x17a>
 8002676:	4448      	add	r0, r9
 8002678:	4548      	cmp	r0, r9
 800267a:	4192      	sbcs	r2, r2
 800267c:	185b      	adds	r3, r3, r1
 800267e:	4698      	mov	r8, r3
 8002680:	0004      	movs	r4, r0
 8002682:	4252      	negs	r2, r2
 8002684:	4490      	add	r8, r2
 8002686:	4643      	mov	r3, r8
 8002688:	2602      	movs	r6, #2
 800268a:	021b      	lsls	r3, r3, #8
 800268c:	d500      	bpl.n	8002690 <__aeabi_dsub+0x2e0>
 800268e:	e0c4      	b.n	800281a <__aeabi_dsub+0x46a>
 8002690:	3e01      	subs	r6, #1
 8002692:	0763      	lsls	r3, r4, #29
 8002694:	d000      	beq.n	8002698 <__aeabi_dsub+0x2e8>
 8002696:	e711      	b.n	80024bc <__aeabi_dsub+0x10c>
 8002698:	4643      	mov	r3, r8
 800269a:	46b4      	mov	ip, r6
 800269c:	0759      	lsls	r1, r3, #29
 800269e:	08e2      	lsrs	r2, r4, #3
 80026a0:	430a      	orrs	r2, r1
 80026a2:	08db      	lsrs	r3, r3, #3
 80026a4:	490f      	ldr	r1, [pc, #60]	; (80026e4 <__aeabi_dsub+0x334>)
 80026a6:	458c      	cmp	ip, r1
 80026a8:	d040      	beq.n	800272c <__aeabi_dsub+0x37c>
 80026aa:	4661      	mov	r1, ip
 80026ac:	031b      	lsls	r3, r3, #12
 80026ae:	0549      	lsls	r1, r1, #21
 80026b0:	0b1b      	lsrs	r3, r3, #12
 80026b2:	0d49      	lsrs	r1, r1, #21
 80026b4:	e720      	b.n	80024f8 <__aeabi_dsub+0x148>
 80026b6:	4301      	orrs	r1, r0
 80026b8:	000c      	movs	r4, r1
 80026ba:	1e61      	subs	r1, r4, #1
 80026bc:	418c      	sbcs	r4, r1
 80026be:	444c      	add	r4, r9
 80026c0:	454c      	cmp	r4, r9
 80026c2:	4192      	sbcs	r2, r2
 80026c4:	4252      	negs	r2, r2
 80026c6:	4690      	mov	r8, r2
 80026c8:	4498      	add	r8, r3
 80026ca:	4643      	mov	r3, r8
 80026cc:	021b      	lsls	r3, r3, #8
 80026ce:	d5e0      	bpl.n	8002692 <__aeabi_dsub+0x2e2>
 80026d0:	4b04      	ldr	r3, [pc, #16]	; (80026e4 <__aeabi_dsub+0x334>)
 80026d2:	3601      	adds	r6, #1
 80026d4:	429e      	cmp	r6, r3
 80026d6:	d000      	beq.n	80026da <__aeabi_dsub+0x32a>
 80026d8:	e09f      	b.n	800281a <__aeabi_dsub+0x46a>
 80026da:	0031      	movs	r1, r6
 80026dc:	2300      	movs	r3, #0
 80026de:	2200      	movs	r2, #0
 80026e0:	e70a      	b.n	80024f8 <__aeabi_dsub+0x148>
 80026e2:	46c0      	nop			; (mov r8, r8)
 80026e4:	000007ff 	.word	0x000007ff
 80026e8:	ff7fffff 	.word	0xff7fffff
 80026ec:	fffff801 	.word	0xfffff801
 80026f0:	000007fe 	.word	0x000007fe
 80026f4:	2a00      	cmp	r2, #0
 80026f6:	d100      	bne.n	80026fa <__aeabi_dsub+0x34a>
 80026f8:	e160      	b.n	80029bc <__aeabi_dsub+0x60c>
 80026fa:	000a      	movs	r2, r1
 80026fc:	4302      	orrs	r2, r0
 80026fe:	d04d      	beq.n	800279c <__aeabi_dsub+0x3ec>
 8002700:	464a      	mov	r2, r9
 8002702:	075c      	lsls	r4, r3, #29
 8002704:	08d2      	lsrs	r2, r2, #3
 8002706:	4322      	orrs	r2, r4
 8002708:	2480      	movs	r4, #128	; 0x80
 800270a:	08db      	lsrs	r3, r3, #3
 800270c:	0324      	lsls	r4, r4, #12
 800270e:	4223      	tst	r3, r4
 8002710:	d007      	beq.n	8002722 <__aeabi_dsub+0x372>
 8002712:	08ce      	lsrs	r6, r1, #3
 8002714:	4226      	tst	r6, r4
 8002716:	d104      	bne.n	8002722 <__aeabi_dsub+0x372>
 8002718:	465d      	mov	r5, fp
 800271a:	0033      	movs	r3, r6
 800271c:	08c2      	lsrs	r2, r0, #3
 800271e:	0749      	lsls	r1, r1, #29
 8002720:	430a      	orrs	r2, r1
 8002722:	0f51      	lsrs	r1, r2, #29
 8002724:	00d2      	lsls	r2, r2, #3
 8002726:	08d2      	lsrs	r2, r2, #3
 8002728:	0749      	lsls	r1, r1, #29
 800272a:	430a      	orrs	r2, r1
 800272c:	0011      	movs	r1, r2
 800272e:	4319      	orrs	r1, r3
 8002730:	d100      	bne.n	8002734 <__aeabi_dsub+0x384>
 8002732:	e1c8      	b.n	8002ac6 <__aeabi_dsub+0x716>
 8002734:	2180      	movs	r1, #128	; 0x80
 8002736:	0309      	lsls	r1, r1, #12
 8002738:	430b      	orrs	r3, r1
 800273a:	031b      	lsls	r3, r3, #12
 800273c:	49d5      	ldr	r1, [pc, #852]	; (8002a94 <__aeabi_dsub+0x6e4>)
 800273e:	0b1b      	lsrs	r3, r3, #12
 8002740:	e6da      	b.n	80024f8 <__aeabi_dsub+0x148>
 8002742:	49d5      	ldr	r1, [pc, #852]	; (8002a98 <__aeabi_dsub+0x6e8>)
 8002744:	1ab6      	subs	r6, r6, r2
 8002746:	400b      	ands	r3, r1
 8002748:	4698      	mov	r8, r3
 800274a:	e6b5      	b.n	80024b8 <__aeabi_dsub+0x108>
 800274c:	0020      	movs	r0, r4
 800274e:	f000 fb35 	bl	8002dbc <__clzsi2>
 8002752:	0002      	movs	r2, r0
 8002754:	3218      	adds	r2, #24
 8002756:	2a1f      	cmp	r2, #31
 8002758:	dc00      	bgt.n	800275c <__aeabi_dsub+0x3ac>
 800275a:	e68f      	b.n	800247c <__aeabi_dsub+0xcc>
 800275c:	0023      	movs	r3, r4
 800275e:	3808      	subs	r0, #8
 8002760:	4083      	lsls	r3, r0
 8002762:	2400      	movs	r4, #0
 8002764:	e692      	b.n	800248c <__aeabi_dsub+0xdc>
 8002766:	4308      	orrs	r0, r1
 8002768:	0002      	movs	r2, r0
 800276a:	1e50      	subs	r0, r2, #1
 800276c:	4182      	sbcs	r2, r0
 800276e:	e66d      	b.n	800244c <__aeabi_dsub+0x9c>
 8002770:	4cca      	ldr	r4, [pc, #808]	; (8002a9c <__aeabi_dsub+0x6ec>)
 8002772:	1c72      	adds	r2, r6, #1
 8002774:	4222      	tst	r2, r4
 8002776:	d000      	beq.n	800277a <__aeabi_dsub+0x3ca>
 8002778:	e0ad      	b.n	80028d6 <__aeabi_dsub+0x526>
 800277a:	464a      	mov	r2, r9
 800277c:	431a      	orrs	r2, r3
 800277e:	2e00      	cmp	r6, #0
 8002780:	d1b8      	bne.n	80026f4 <__aeabi_dsub+0x344>
 8002782:	2a00      	cmp	r2, #0
 8002784:	d100      	bne.n	8002788 <__aeabi_dsub+0x3d8>
 8002786:	e158      	b.n	8002a3a <__aeabi_dsub+0x68a>
 8002788:	000a      	movs	r2, r1
 800278a:	4302      	orrs	r2, r0
 800278c:	d000      	beq.n	8002790 <__aeabi_dsub+0x3e0>
 800278e:	e159      	b.n	8002a44 <__aeabi_dsub+0x694>
 8002790:	464a      	mov	r2, r9
 8002792:	0759      	lsls	r1, r3, #29
 8002794:	08d2      	lsrs	r2, r2, #3
 8002796:	430a      	orrs	r2, r1
 8002798:	08db      	lsrs	r3, r3, #3
 800279a:	e786      	b.n	80026aa <__aeabi_dsub+0x2fa>
 800279c:	464a      	mov	r2, r9
 800279e:	0759      	lsls	r1, r3, #29
 80027a0:	08d2      	lsrs	r2, r2, #3
 80027a2:	430a      	orrs	r2, r1
 80027a4:	08db      	lsrs	r3, r3, #3
 80027a6:	e7c1      	b.n	800272c <__aeabi_dsub+0x37c>
 80027a8:	4dba      	ldr	r5, [pc, #744]	; (8002a94 <__aeabi_dsub+0x6e4>)
 80027aa:	42aa      	cmp	r2, r5
 80027ac:	d100      	bne.n	80027b0 <__aeabi_dsub+0x400>
 80027ae:	e11e      	b.n	80029ee <__aeabi_dsub+0x63e>
 80027b0:	2580      	movs	r5, #128	; 0x80
 80027b2:	042d      	lsls	r5, r5, #16
 80027b4:	432b      	orrs	r3, r5
 80027b6:	4664      	mov	r4, ip
 80027b8:	2c38      	cmp	r4, #56	; 0x38
 80027ba:	dc5d      	bgt.n	8002878 <__aeabi_dsub+0x4c8>
 80027bc:	2c1f      	cmp	r4, #31
 80027be:	dd00      	ble.n	80027c2 <__aeabi_dsub+0x412>
 80027c0:	e0d0      	b.n	8002964 <__aeabi_dsub+0x5b4>
 80027c2:	2520      	movs	r5, #32
 80027c4:	4667      	mov	r7, ip
 80027c6:	1b2d      	subs	r5, r5, r4
 80027c8:	464e      	mov	r6, r9
 80027ca:	001c      	movs	r4, r3
 80027cc:	40fe      	lsrs	r6, r7
 80027ce:	40ac      	lsls	r4, r5
 80027d0:	4334      	orrs	r4, r6
 80027d2:	464e      	mov	r6, r9
 80027d4:	40ae      	lsls	r6, r5
 80027d6:	0035      	movs	r5, r6
 80027d8:	40fb      	lsrs	r3, r7
 80027da:	1e6e      	subs	r6, r5, #1
 80027dc:	41b5      	sbcs	r5, r6
 80027de:	1ac9      	subs	r1, r1, r3
 80027e0:	432c      	orrs	r4, r5
 80027e2:	e04e      	b.n	8002882 <__aeabi_dsub+0x4d2>
 80027e4:	464a      	mov	r2, r9
 80027e6:	1a14      	subs	r4, r2, r0
 80027e8:	45a1      	cmp	r9, r4
 80027ea:	4192      	sbcs	r2, r2
 80027ec:	4252      	negs	r2, r2
 80027ee:	4690      	mov	r8, r2
 80027f0:	1a5f      	subs	r7, r3, r1
 80027f2:	003a      	movs	r2, r7
 80027f4:	4647      	mov	r7, r8
 80027f6:	1bd2      	subs	r2, r2, r7
 80027f8:	4690      	mov	r8, r2
 80027fa:	0212      	lsls	r2, r2, #8
 80027fc:	d500      	bpl.n	8002800 <__aeabi_dsub+0x450>
 80027fe:	e08b      	b.n	8002918 <__aeabi_dsub+0x568>
 8002800:	4642      	mov	r2, r8
 8002802:	4322      	orrs	r2, r4
 8002804:	d000      	beq.n	8002808 <__aeabi_dsub+0x458>
 8002806:	e630      	b.n	800246a <__aeabi_dsub+0xba>
 8002808:	2300      	movs	r3, #0
 800280a:	2500      	movs	r5, #0
 800280c:	e74d      	b.n	80026aa <__aeabi_dsub+0x2fa>
 800280e:	464a      	mov	r2, r9
 8002810:	0759      	lsls	r1, r3, #29
 8002812:	08d2      	lsrs	r2, r2, #3
 8002814:	430a      	orrs	r2, r1
 8002816:	08db      	lsrs	r3, r3, #3
 8002818:	e744      	b.n	80026a4 <__aeabi_dsub+0x2f4>
 800281a:	4642      	mov	r2, r8
 800281c:	4b9e      	ldr	r3, [pc, #632]	; (8002a98 <__aeabi_dsub+0x6e8>)
 800281e:	0861      	lsrs	r1, r4, #1
 8002820:	401a      	ands	r2, r3
 8002822:	0013      	movs	r3, r2
 8002824:	2201      	movs	r2, #1
 8002826:	4014      	ands	r4, r2
 8002828:	430c      	orrs	r4, r1
 800282a:	07da      	lsls	r2, r3, #31
 800282c:	085b      	lsrs	r3, r3, #1
 800282e:	4698      	mov	r8, r3
 8002830:	4314      	orrs	r4, r2
 8002832:	e641      	b.n	80024b8 <__aeabi_dsub+0x108>
 8002834:	001a      	movs	r2, r3
 8002836:	3e1f      	subs	r6, #31
 8002838:	40f2      	lsrs	r2, r6
 800283a:	0016      	movs	r6, r2
 800283c:	2920      	cmp	r1, #32
 800283e:	d003      	beq.n	8002848 <__aeabi_dsub+0x498>
 8002840:	2240      	movs	r2, #64	; 0x40
 8002842:	1a51      	subs	r1, r2, r1
 8002844:	408b      	lsls	r3, r1
 8002846:	431c      	orrs	r4, r3
 8002848:	1e62      	subs	r2, r4, #1
 800284a:	4194      	sbcs	r4, r2
 800284c:	2300      	movs	r3, #0
 800284e:	4334      	orrs	r4, r6
 8002850:	4698      	mov	r8, r3
 8002852:	2600      	movs	r6, #0
 8002854:	e71d      	b.n	8002692 <__aeabi_dsub+0x2e2>
 8002856:	000c      	movs	r4, r1
 8002858:	3a20      	subs	r2, #32
 800285a:	40d4      	lsrs	r4, r2
 800285c:	0022      	movs	r2, r4
 800285e:	4664      	mov	r4, ip
 8002860:	2c20      	cmp	r4, #32
 8002862:	d004      	beq.n	800286e <__aeabi_dsub+0x4be>
 8002864:	2740      	movs	r7, #64	; 0x40
 8002866:	1b3f      	subs	r7, r7, r4
 8002868:	40b9      	lsls	r1, r7
 800286a:	4308      	orrs	r0, r1
 800286c:	4680      	mov	r8, r0
 800286e:	4644      	mov	r4, r8
 8002870:	1e61      	subs	r1, r4, #1
 8002872:	418c      	sbcs	r4, r1
 8002874:	4322      	orrs	r2, r4
 8002876:	e5e9      	b.n	800244c <__aeabi_dsub+0x9c>
 8002878:	464c      	mov	r4, r9
 800287a:	4323      	orrs	r3, r4
 800287c:	001c      	movs	r4, r3
 800287e:	1e63      	subs	r3, r4, #1
 8002880:	419c      	sbcs	r4, r3
 8002882:	1b04      	subs	r4, r0, r4
 8002884:	42a0      	cmp	r0, r4
 8002886:	419b      	sbcs	r3, r3
 8002888:	425b      	negs	r3, r3
 800288a:	1acb      	subs	r3, r1, r3
 800288c:	4698      	mov	r8, r3
 800288e:	465d      	mov	r5, fp
 8002890:	0016      	movs	r6, r2
 8002892:	e5e2      	b.n	800245a <__aeabi_dsub+0xaa>
 8002894:	464e      	mov	r6, r9
 8002896:	431e      	orrs	r6, r3
 8002898:	d100      	bne.n	800289c <__aeabi_dsub+0x4ec>
 800289a:	e0ae      	b.n	80029fa <__aeabi_dsub+0x64a>
 800289c:	1e66      	subs	r6, r4, #1
 800289e:	2c01      	cmp	r4, #1
 80028a0:	d100      	bne.n	80028a4 <__aeabi_dsub+0x4f4>
 80028a2:	e0fd      	b.n	8002aa0 <__aeabi_dsub+0x6f0>
 80028a4:	4f7b      	ldr	r7, [pc, #492]	; (8002a94 <__aeabi_dsub+0x6e4>)
 80028a6:	42bc      	cmp	r4, r7
 80028a8:	d100      	bne.n	80028ac <__aeabi_dsub+0x4fc>
 80028aa:	e107      	b.n	8002abc <__aeabi_dsub+0x70c>
 80028ac:	46b4      	mov	ip, r6
 80028ae:	e69b      	b.n	80025e8 <__aeabi_dsub+0x238>
 80028b0:	4664      	mov	r4, ip
 80028b2:	2220      	movs	r2, #32
 80028b4:	1b12      	subs	r2, r2, r4
 80028b6:	000c      	movs	r4, r1
 80028b8:	4094      	lsls	r4, r2
 80028ba:	0007      	movs	r7, r0
 80028bc:	4090      	lsls	r0, r2
 80028be:	46a0      	mov	r8, r4
 80028c0:	4664      	mov	r4, ip
 80028c2:	1e42      	subs	r2, r0, #1
 80028c4:	4190      	sbcs	r0, r2
 80028c6:	4662      	mov	r2, ip
 80028c8:	40e7      	lsrs	r7, r4
 80028ca:	4644      	mov	r4, r8
 80028cc:	40d1      	lsrs	r1, r2
 80028ce:	433c      	orrs	r4, r7
 80028d0:	4304      	orrs	r4, r0
 80028d2:	185b      	adds	r3, r3, r1
 80028d4:	e6f3      	b.n	80026be <__aeabi_dsub+0x30e>
 80028d6:	4c6f      	ldr	r4, [pc, #444]	; (8002a94 <__aeabi_dsub+0x6e4>)
 80028d8:	42a2      	cmp	r2, r4
 80028da:	d100      	bne.n	80028de <__aeabi_dsub+0x52e>
 80028dc:	e0d5      	b.n	8002a8a <__aeabi_dsub+0x6da>
 80028de:	4448      	add	r0, r9
 80028e0:	185b      	adds	r3, r3, r1
 80028e2:	4548      	cmp	r0, r9
 80028e4:	4189      	sbcs	r1, r1
 80028e6:	4249      	negs	r1, r1
 80028e8:	185b      	adds	r3, r3, r1
 80028ea:	07dc      	lsls	r4, r3, #31
 80028ec:	0840      	lsrs	r0, r0, #1
 80028ee:	085b      	lsrs	r3, r3, #1
 80028f0:	4698      	mov	r8, r3
 80028f2:	0016      	movs	r6, r2
 80028f4:	4304      	orrs	r4, r0
 80028f6:	e6cc      	b.n	8002692 <__aeabi_dsub+0x2e2>
 80028f8:	2a00      	cmp	r2, #0
 80028fa:	d000      	beq.n	80028fe <__aeabi_dsub+0x54e>
 80028fc:	e082      	b.n	8002a04 <__aeabi_dsub+0x654>
 80028fe:	000a      	movs	r2, r1
 8002900:	4302      	orrs	r2, r0
 8002902:	d140      	bne.n	8002986 <__aeabi_dsub+0x5d6>
 8002904:	2380      	movs	r3, #128	; 0x80
 8002906:	2500      	movs	r5, #0
 8002908:	031b      	lsls	r3, r3, #12
 800290a:	e713      	b.n	8002734 <__aeabi_dsub+0x384>
 800290c:	074b      	lsls	r3, r1, #29
 800290e:	08c2      	lsrs	r2, r0, #3
 8002910:	431a      	orrs	r2, r3
 8002912:	465d      	mov	r5, fp
 8002914:	08cb      	lsrs	r3, r1, #3
 8002916:	e6c5      	b.n	80026a4 <__aeabi_dsub+0x2f4>
 8002918:	464a      	mov	r2, r9
 800291a:	1a84      	subs	r4, r0, r2
 800291c:	42a0      	cmp	r0, r4
 800291e:	4192      	sbcs	r2, r2
 8002920:	1acb      	subs	r3, r1, r3
 8002922:	4252      	negs	r2, r2
 8002924:	1a9b      	subs	r3, r3, r2
 8002926:	4698      	mov	r8, r3
 8002928:	465d      	mov	r5, fp
 800292a:	e59e      	b.n	800246a <__aeabi_dsub+0xba>
 800292c:	464a      	mov	r2, r9
 800292e:	0759      	lsls	r1, r3, #29
 8002930:	08d2      	lsrs	r2, r2, #3
 8002932:	430a      	orrs	r2, r1
 8002934:	08db      	lsrs	r3, r3, #3
 8002936:	e6f9      	b.n	800272c <__aeabi_dsub+0x37c>
 8002938:	464a      	mov	r2, r9
 800293a:	1a14      	subs	r4, r2, r0
 800293c:	45a1      	cmp	r9, r4
 800293e:	4192      	sbcs	r2, r2
 8002940:	1a5b      	subs	r3, r3, r1
 8002942:	4252      	negs	r2, r2
 8002944:	1a9b      	subs	r3, r3, r2
 8002946:	4698      	mov	r8, r3
 8002948:	2601      	movs	r6, #1
 800294a:	e586      	b.n	800245a <__aeabi_dsub+0xaa>
 800294c:	464a      	mov	r2, r9
 800294e:	0759      	lsls	r1, r3, #29
 8002950:	08d2      	lsrs	r2, r2, #3
 8002952:	430a      	orrs	r2, r1
 8002954:	08db      	lsrs	r3, r3, #3
 8002956:	e6a5      	b.n	80026a4 <__aeabi_dsub+0x2f4>
 8002958:	464c      	mov	r4, r9
 800295a:	4323      	orrs	r3, r4
 800295c:	001c      	movs	r4, r3
 800295e:	1e63      	subs	r3, r4, #1
 8002960:	419c      	sbcs	r4, r3
 8002962:	e65b      	b.n	800261c <__aeabi_dsub+0x26c>
 8002964:	4665      	mov	r5, ip
 8002966:	001e      	movs	r6, r3
 8002968:	3d20      	subs	r5, #32
 800296a:	40ee      	lsrs	r6, r5
 800296c:	2c20      	cmp	r4, #32
 800296e:	d005      	beq.n	800297c <__aeabi_dsub+0x5cc>
 8002970:	2540      	movs	r5, #64	; 0x40
 8002972:	1b2d      	subs	r5, r5, r4
 8002974:	40ab      	lsls	r3, r5
 8002976:	464c      	mov	r4, r9
 8002978:	431c      	orrs	r4, r3
 800297a:	46a2      	mov	sl, r4
 800297c:	4654      	mov	r4, sl
 800297e:	1e63      	subs	r3, r4, #1
 8002980:	419c      	sbcs	r4, r3
 8002982:	4334      	orrs	r4, r6
 8002984:	e77d      	b.n	8002882 <__aeabi_dsub+0x4d2>
 8002986:	074b      	lsls	r3, r1, #29
 8002988:	08c2      	lsrs	r2, r0, #3
 800298a:	431a      	orrs	r2, r3
 800298c:	465d      	mov	r5, fp
 800298e:	08cb      	lsrs	r3, r1, #3
 8002990:	e6cc      	b.n	800272c <__aeabi_dsub+0x37c>
 8002992:	000a      	movs	r2, r1
 8002994:	4302      	orrs	r2, r0
 8002996:	d100      	bne.n	800299a <__aeabi_dsub+0x5ea>
 8002998:	e736      	b.n	8002808 <__aeabi_dsub+0x458>
 800299a:	074b      	lsls	r3, r1, #29
 800299c:	08c2      	lsrs	r2, r0, #3
 800299e:	431a      	orrs	r2, r3
 80029a0:	465d      	mov	r5, fp
 80029a2:	08cb      	lsrs	r3, r1, #3
 80029a4:	e681      	b.n	80026aa <__aeabi_dsub+0x2fa>
 80029a6:	464a      	mov	r2, r9
 80029a8:	1a84      	subs	r4, r0, r2
 80029aa:	42a0      	cmp	r0, r4
 80029ac:	4192      	sbcs	r2, r2
 80029ae:	1acb      	subs	r3, r1, r3
 80029b0:	4252      	negs	r2, r2
 80029b2:	1a9b      	subs	r3, r3, r2
 80029b4:	4698      	mov	r8, r3
 80029b6:	465d      	mov	r5, fp
 80029b8:	2601      	movs	r6, #1
 80029ba:	e54e      	b.n	800245a <__aeabi_dsub+0xaa>
 80029bc:	074b      	lsls	r3, r1, #29
 80029be:	08c2      	lsrs	r2, r0, #3
 80029c0:	431a      	orrs	r2, r3
 80029c2:	08cb      	lsrs	r3, r1, #3
 80029c4:	e6b2      	b.n	800272c <__aeabi_dsub+0x37c>
 80029c6:	464a      	mov	r2, r9
 80029c8:	1a14      	subs	r4, r2, r0
 80029ca:	45a1      	cmp	r9, r4
 80029cc:	4192      	sbcs	r2, r2
 80029ce:	1a5f      	subs	r7, r3, r1
 80029d0:	4252      	negs	r2, r2
 80029d2:	1aba      	subs	r2, r7, r2
 80029d4:	4690      	mov	r8, r2
 80029d6:	0212      	lsls	r2, r2, #8
 80029d8:	d56b      	bpl.n	8002ab2 <__aeabi_dsub+0x702>
 80029da:	464a      	mov	r2, r9
 80029dc:	1a84      	subs	r4, r0, r2
 80029de:	42a0      	cmp	r0, r4
 80029e0:	4192      	sbcs	r2, r2
 80029e2:	1acb      	subs	r3, r1, r3
 80029e4:	4252      	negs	r2, r2
 80029e6:	1a9b      	subs	r3, r3, r2
 80029e8:	4698      	mov	r8, r3
 80029ea:	465d      	mov	r5, fp
 80029ec:	e564      	b.n	80024b8 <__aeabi_dsub+0x108>
 80029ee:	074b      	lsls	r3, r1, #29
 80029f0:	08c2      	lsrs	r2, r0, #3
 80029f2:	431a      	orrs	r2, r3
 80029f4:	465d      	mov	r5, fp
 80029f6:	08cb      	lsrs	r3, r1, #3
 80029f8:	e698      	b.n	800272c <__aeabi_dsub+0x37c>
 80029fa:	074b      	lsls	r3, r1, #29
 80029fc:	08c2      	lsrs	r2, r0, #3
 80029fe:	431a      	orrs	r2, r3
 8002a00:	08cb      	lsrs	r3, r1, #3
 8002a02:	e64f      	b.n	80026a4 <__aeabi_dsub+0x2f4>
 8002a04:	000a      	movs	r2, r1
 8002a06:	4302      	orrs	r2, r0
 8002a08:	d090      	beq.n	800292c <__aeabi_dsub+0x57c>
 8002a0a:	464a      	mov	r2, r9
 8002a0c:	075c      	lsls	r4, r3, #29
 8002a0e:	08d2      	lsrs	r2, r2, #3
 8002a10:	4314      	orrs	r4, r2
 8002a12:	2280      	movs	r2, #128	; 0x80
 8002a14:	08db      	lsrs	r3, r3, #3
 8002a16:	0312      	lsls	r2, r2, #12
 8002a18:	4213      	tst	r3, r2
 8002a1a:	d008      	beq.n	8002a2e <__aeabi_dsub+0x67e>
 8002a1c:	08ce      	lsrs	r6, r1, #3
 8002a1e:	4216      	tst	r6, r2
 8002a20:	d105      	bne.n	8002a2e <__aeabi_dsub+0x67e>
 8002a22:	08c0      	lsrs	r0, r0, #3
 8002a24:	0749      	lsls	r1, r1, #29
 8002a26:	4308      	orrs	r0, r1
 8002a28:	0004      	movs	r4, r0
 8002a2a:	465d      	mov	r5, fp
 8002a2c:	0033      	movs	r3, r6
 8002a2e:	0f61      	lsrs	r1, r4, #29
 8002a30:	00e2      	lsls	r2, r4, #3
 8002a32:	0749      	lsls	r1, r1, #29
 8002a34:	08d2      	lsrs	r2, r2, #3
 8002a36:	430a      	orrs	r2, r1
 8002a38:	e678      	b.n	800272c <__aeabi_dsub+0x37c>
 8002a3a:	074b      	lsls	r3, r1, #29
 8002a3c:	08c2      	lsrs	r2, r0, #3
 8002a3e:	431a      	orrs	r2, r3
 8002a40:	08cb      	lsrs	r3, r1, #3
 8002a42:	e632      	b.n	80026aa <__aeabi_dsub+0x2fa>
 8002a44:	4448      	add	r0, r9
 8002a46:	185b      	adds	r3, r3, r1
 8002a48:	4548      	cmp	r0, r9
 8002a4a:	4192      	sbcs	r2, r2
 8002a4c:	4698      	mov	r8, r3
 8002a4e:	4252      	negs	r2, r2
 8002a50:	4490      	add	r8, r2
 8002a52:	4643      	mov	r3, r8
 8002a54:	0004      	movs	r4, r0
 8002a56:	021b      	lsls	r3, r3, #8
 8002a58:	d400      	bmi.n	8002a5c <__aeabi_dsub+0x6ac>
 8002a5a:	e61a      	b.n	8002692 <__aeabi_dsub+0x2e2>
 8002a5c:	4642      	mov	r2, r8
 8002a5e:	4b0e      	ldr	r3, [pc, #56]	; (8002a98 <__aeabi_dsub+0x6e8>)
 8002a60:	2601      	movs	r6, #1
 8002a62:	401a      	ands	r2, r3
 8002a64:	4690      	mov	r8, r2
 8002a66:	e614      	b.n	8002692 <__aeabi_dsub+0x2e2>
 8002a68:	4666      	mov	r6, ip
 8002a6a:	001f      	movs	r7, r3
 8002a6c:	3e20      	subs	r6, #32
 8002a6e:	40f7      	lsrs	r7, r6
 8002a70:	2c20      	cmp	r4, #32
 8002a72:	d005      	beq.n	8002a80 <__aeabi_dsub+0x6d0>
 8002a74:	2640      	movs	r6, #64	; 0x40
 8002a76:	1b36      	subs	r6, r6, r4
 8002a78:	40b3      	lsls	r3, r6
 8002a7a:	464c      	mov	r4, r9
 8002a7c:	431c      	orrs	r4, r3
 8002a7e:	46a2      	mov	sl, r4
 8002a80:	4654      	mov	r4, sl
 8002a82:	1e63      	subs	r3, r4, #1
 8002a84:	419c      	sbcs	r4, r3
 8002a86:	433c      	orrs	r4, r7
 8002a88:	e5c8      	b.n	800261c <__aeabi_dsub+0x26c>
 8002a8a:	0011      	movs	r1, r2
 8002a8c:	2300      	movs	r3, #0
 8002a8e:	2200      	movs	r2, #0
 8002a90:	e532      	b.n	80024f8 <__aeabi_dsub+0x148>
 8002a92:	46c0      	nop			; (mov r8, r8)
 8002a94:	000007ff 	.word	0x000007ff
 8002a98:	ff7fffff 	.word	0xff7fffff
 8002a9c:	000007fe 	.word	0x000007fe
 8002aa0:	464a      	mov	r2, r9
 8002aa2:	1814      	adds	r4, r2, r0
 8002aa4:	4284      	cmp	r4, r0
 8002aa6:	4192      	sbcs	r2, r2
 8002aa8:	185b      	adds	r3, r3, r1
 8002aaa:	4698      	mov	r8, r3
 8002aac:	4252      	negs	r2, r2
 8002aae:	4490      	add	r8, r2
 8002ab0:	e5e9      	b.n	8002686 <__aeabi_dsub+0x2d6>
 8002ab2:	4642      	mov	r2, r8
 8002ab4:	4322      	orrs	r2, r4
 8002ab6:	d100      	bne.n	8002aba <__aeabi_dsub+0x70a>
 8002ab8:	e6a6      	b.n	8002808 <__aeabi_dsub+0x458>
 8002aba:	e5ea      	b.n	8002692 <__aeabi_dsub+0x2e2>
 8002abc:	074b      	lsls	r3, r1, #29
 8002abe:	08c2      	lsrs	r2, r0, #3
 8002ac0:	431a      	orrs	r2, r3
 8002ac2:	08cb      	lsrs	r3, r1, #3
 8002ac4:	e632      	b.n	800272c <__aeabi_dsub+0x37c>
 8002ac6:	2200      	movs	r2, #0
 8002ac8:	4901      	ldr	r1, [pc, #4]	; (8002ad0 <__aeabi_dsub+0x720>)
 8002aca:	0013      	movs	r3, r2
 8002acc:	e514      	b.n	80024f8 <__aeabi_dsub+0x148>
 8002ace:	46c0      	nop			; (mov r8, r8)
 8002ad0:	000007ff 	.word	0x000007ff

08002ad4 <__aeabi_d2iz>:
 8002ad4:	000a      	movs	r2, r1
 8002ad6:	b530      	push	{r4, r5, lr}
 8002ad8:	4c13      	ldr	r4, [pc, #76]	; (8002b28 <__aeabi_d2iz+0x54>)
 8002ada:	0053      	lsls	r3, r2, #1
 8002adc:	0309      	lsls	r1, r1, #12
 8002ade:	0005      	movs	r5, r0
 8002ae0:	0b09      	lsrs	r1, r1, #12
 8002ae2:	2000      	movs	r0, #0
 8002ae4:	0d5b      	lsrs	r3, r3, #21
 8002ae6:	0fd2      	lsrs	r2, r2, #31
 8002ae8:	42a3      	cmp	r3, r4
 8002aea:	dd04      	ble.n	8002af6 <__aeabi_d2iz+0x22>
 8002aec:	480f      	ldr	r0, [pc, #60]	; (8002b2c <__aeabi_d2iz+0x58>)
 8002aee:	4283      	cmp	r3, r0
 8002af0:	dd02      	ble.n	8002af8 <__aeabi_d2iz+0x24>
 8002af2:	4b0f      	ldr	r3, [pc, #60]	; (8002b30 <__aeabi_d2iz+0x5c>)
 8002af4:	18d0      	adds	r0, r2, r3
 8002af6:	bd30      	pop	{r4, r5, pc}
 8002af8:	2080      	movs	r0, #128	; 0x80
 8002afa:	0340      	lsls	r0, r0, #13
 8002afc:	4301      	orrs	r1, r0
 8002afe:	480d      	ldr	r0, [pc, #52]	; (8002b34 <__aeabi_d2iz+0x60>)
 8002b00:	1ac0      	subs	r0, r0, r3
 8002b02:	281f      	cmp	r0, #31
 8002b04:	dd08      	ble.n	8002b18 <__aeabi_d2iz+0x44>
 8002b06:	480c      	ldr	r0, [pc, #48]	; (8002b38 <__aeabi_d2iz+0x64>)
 8002b08:	1ac3      	subs	r3, r0, r3
 8002b0a:	40d9      	lsrs	r1, r3
 8002b0c:	000b      	movs	r3, r1
 8002b0e:	4258      	negs	r0, r3
 8002b10:	2a00      	cmp	r2, #0
 8002b12:	d1f0      	bne.n	8002af6 <__aeabi_d2iz+0x22>
 8002b14:	0018      	movs	r0, r3
 8002b16:	e7ee      	b.n	8002af6 <__aeabi_d2iz+0x22>
 8002b18:	4c08      	ldr	r4, [pc, #32]	; (8002b3c <__aeabi_d2iz+0x68>)
 8002b1a:	40c5      	lsrs	r5, r0
 8002b1c:	46a4      	mov	ip, r4
 8002b1e:	4463      	add	r3, ip
 8002b20:	4099      	lsls	r1, r3
 8002b22:	000b      	movs	r3, r1
 8002b24:	432b      	orrs	r3, r5
 8002b26:	e7f2      	b.n	8002b0e <__aeabi_d2iz+0x3a>
 8002b28:	000003fe 	.word	0x000003fe
 8002b2c:	0000041d 	.word	0x0000041d
 8002b30:	7fffffff 	.word	0x7fffffff
 8002b34:	00000433 	.word	0x00000433
 8002b38:	00000413 	.word	0x00000413
 8002b3c:	fffffbed 	.word	0xfffffbed

08002b40 <__aeabi_i2d>:
 8002b40:	b570      	push	{r4, r5, r6, lr}
 8002b42:	2800      	cmp	r0, #0
 8002b44:	d016      	beq.n	8002b74 <__aeabi_i2d+0x34>
 8002b46:	17c3      	asrs	r3, r0, #31
 8002b48:	18c5      	adds	r5, r0, r3
 8002b4a:	405d      	eors	r5, r3
 8002b4c:	0fc4      	lsrs	r4, r0, #31
 8002b4e:	0028      	movs	r0, r5
 8002b50:	f000 f934 	bl	8002dbc <__clzsi2>
 8002b54:	4a11      	ldr	r2, [pc, #68]	; (8002b9c <__aeabi_i2d+0x5c>)
 8002b56:	1a12      	subs	r2, r2, r0
 8002b58:	280a      	cmp	r0, #10
 8002b5a:	dc16      	bgt.n	8002b8a <__aeabi_i2d+0x4a>
 8002b5c:	0003      	movs	r3, r0
 8002b5e:	002e      	movs	r6, r5
 8002b60:	3315      	adds	r3, #21
 8002b62:	409e      	lsls	r6, r3
 8002b64:	230b      	movs	r3, #11
 8002b66:	1a18      	subs	r0, r3, r0
 8002b68:	40c5      	lsrs	r5, r0
 8002b6a:	0553      	lsls	r3, r2, #21
 8002b6c:	032d      	lsls	r5, r5, #12
 8002b6e:	0b2d      	lsrs	r5, r5, #12
 8002b70:	0d5b      	lsrs	r3, r3, #21
 8002b72:	e003      	b.n	8002b7c <__aeabi_i2d+0x3c>
 8002b74:	2400      	movs	r4, #0
 8002b76:	2300      	movs	r3, #0
 8002b78:	2500      	movs	r5, #0
 8002b7a:	2600      	movs	r6, #0
 8002b7c:	051b      	lsls	r3, r3, #20
 8002b7e:	432b      	orrs	r3, r5
 8002b80:	07e4      	lsls	r4, r4, #31
 8002b82:	4323      	orrs	r3, r4
 8002b84:	0030      	movs	r0, r6
 8002b86:	0019      	movs	r1, r3
 8002b88:	bd70      	pop	{r4, r5, r6, pc}
 8002b8a:	380b      	subs	r0, #11
 8002b8c:	4085      	lsls	r5, r0
 8002b8e:	0553      	lsls	r3, r2, #21
 8002b90:	032d      	lsls	r5, r5, #12
 8002b92:	2600      	movs	r6, #0
 8002b94:	0b2d      	lsrs	r5, r5, #12
 8002b96:	0d5b      	lsrs	r3, r3, #21
 8002b98:	e7f0      	b.n	8002b7c <__aeabi_i2d+0x3c>
 8002b9a:	46c0      	nop			; (mov r8, r8)
 8002b9c:	0000041e 	.word	0x0000041e

08002ba0 <__aeabi_f2d>:
 8002ba0:	b570      	push	{r4, r5, r6, lr}
 8002ba2:	0043      	lsls	r3, r0, #1
 8002ba4:	0246      	lsls	r6, r0, #9
 8002ba6:	0fc4      	lsrs	r4, r0, #31
 8002ba8:	20fe      	movs	r0, #254	; 0xfe
 8002baa:	0e1b      	lsrs	r3, r3, #24
 8002bac:	1c59      	adds	r1, r3, #1
 8002bae:	0a75      	lsrs	r5, r6, #9
 8002bb0:	4208      	tst	r0, r1
 8002bb2:	d00c      	beq.n	8002bce <__aeabi_f2d+0x2e>
 8002bb4:	22e0      	movs	r2, #224	; 0xe0
 8002bb6:	0092      	lsls	r2, r2, #2
 8002bb8:	4694      	mov	ip, r2
 8002bba:	076d      	lsls	r5, r5, #29
 8002bbc:	0b36      	lsrs	r6, r6, #12
 8002bbe:	4463      	add	r3, ip
 8002bc0:	051b      	lsls	r3, r3, #20
 8002bc2:	4333      	orrs	r3, r6
 8002bc4:	07e4      	lsls	r4, r4, #31
 8002bc6:	4323      	orrs	r3, r4
 8002bc8:	0028      	movs	r0, r5
 8002bca:	0019      	movs	r1, r3
 8002bcc:	bd70      	pop	{r4, r5, r6, pc}
 8002bce:	2b00      	cmp	r3, #0
 8002bd0:	d114      	bne.n	8002bfc <__aeabi_f2d+0x5c>
 8002bd2:	2d00      	cmp	r5, #0
 8002bd4:	d01b      	beq.n	8002c0e <__aeabi_f2d+0x6e>
 8002bd6:	0028      	movs	r0, r5
 8002bd8:	f000 f8f0 	bl	8002dbc <__clzsi2>
 8002bdc:	280a      	cmp	r0, #10
 8002bde:	dc1c      	bgt.n	8002c1a <__aeabi_f2d+0x7a>
 8002be0:	230b      	movs	r3, #11
 8002be2:	002a      	movs	r2, r5
 8002be4:	1a1b      	subs	r3, r3, r0
 8002be6:	40da      	lsrs	r2, r3
 8002be8:	0003      	movs	r3, r0
 8002bea:	3315      	adds	r3, #21
 8002bec:	409d      	lsls	r5, r3
 8002bee:	4b0e      	ldr	r3, [pc, #56]	; (8002c28 <__aeabi_f2d+0x88>)
 8002bf0:	0312      	lsls	r2, r2, #12
 8002bf2:	1a1b      	subs	r3, r3, r0
 8002bf4:	055b      	lsls	r3, r3, #21
 8002bf6:	0b16      	lsrs	r6, r2, #12
 8002bf8:	0d5b      	lsrs	r3, r3, #21
 8002bfa:	e7e1      	b.n	8002bc0 <__aeabi_f2d+0x20>
 8002bfc:	2d00      	cmp	r5, #0
 8002bfe:	d009      	beq.n	8002c14 <__aeabi_f2d+0x74>
 8002c00:	0b32      	lsrs	r2, r6, #12
 8002c02:	2680      	movs	r6, #128	; 0x80
 8002c04:	0336      	lsls	r6, r6, #12
 8002c06:	4b09      	ldr	r3, [pc, #36]	; (8002c2c <__aeabi_f2d+0x8c>)
 8002c08:	076d      	lsls	r5, r5, #29
 8002c0a:	4316      	orrs	r6, r2
 8002c0c:	e7d8      	b.n	8002bc0 <__aeabi_f2d+0x20>
 8002c0e:	2300      	movs	r3, #0
 8002c10:	2600      	movs	r6, #0
 8002c12:	e7d5      	b.n	8002bc0 <__aeabi_f2d+0x20>
 8002c14:	2600      	movs	r6, #0
 8002c16:	4b05      	ldr	r3, [pc, #20]	; (8002c2c <__aeabi_f2d+0x8c>)
 8002c18:	e7d2      	b.n	8002bc0 <__aeabi_f2d+0x20>
 8002c1a:	0003      	movs	r3, r0
 8002c1c:	002a      	movs	r2, r5
 8002c1e:	3b0b      	subs	r3, #11
 8002c20:	409a      	lsls	r2, r3
 8002c22:	2500      	movs	r5, #0
 8002c24:	e7e3      	b.n	8002bee <__aeabi_f2d+0x4e>
 8002c26:	46c0      	nop			; (mov r8, r8)
 8002c28:	00000389 	.word	0x00000389
 8002c2c:	000007ff 	.word	0x000007ff

08002c30 <__aeabi_d2f>:
 8002c30:	0002      	movs	r2, r0
 8002c32:	004b      	lsls	r3, r1, #1
 8002c34:	b5f0      	push	{r4, r5, r6, r7, lr}
 8002c36:	0308      	lsls	r0, r1, #12
 8002c38:	0d5b      	lsrs	r3, r3, #21
 8002c3a:	4e3d      	ldr	r6, [pc, #244]	; (8002d30 <__aeabi_d2f+0x100>)
 8002c3c:	0fcc      	lsrs	r4, r1, #31
 8002c3e:	0a40      	lsrs	r0, r0, #9
 8002c40:	0f51      	lsrs	r1, r2, #29
 8002c42:	1c5f      	adds	r7, r3, #1
 8002c44:	4308      	orrs	r0, r1
 8002c46:	00d5      	lsls	r5, r2, #3
 8002c48:	4237      	tst	r7, r6
 8002c4a:	d00a      	beq.n	8002c62 <__aeabi_d2f+0x32>
 8002c4c:	4939      	ldr	r1, [pc, #228]	; (8002d34 <__aeabi_d2f+0x104>)
 8002c4e:	185e      	adds	r6, r3, r1
 8002c50:	2efe      	cmp	r6, #254	; 0xfe
 8002c52:	dd16      	ble.n	8002c82 <__aeabi_d2f+0x52>
 8002c54:	23ff      	movs	r3, #255	; 0xff
 8002c56:	2100      	movs	r1, #0
 8002c58:	05db      	lsls	r3, r3, #23
 8002c5a:	430b      	orrs	r3, r1
 8002c5c:	07e0      	lsls	r0, r4, #31
 8002c5e:	4318      	orrs	r0, r3
 8002c60:	bdf0      	pop	{r4, r5, r6, r7, pc}
 8002c62:	2b00      	cmp	r3, #0
 8002c64:	d106      	bne.n	8002c74 <__aeabi_d2f+0x44>
 8002c66:	4328      	orrs	r0, r5
 8002c68:	d027      	beq.n	8002cba <__aeabi_d2f+0x8a>
 8002c6a:	2105      	movs	r1, #5
 8002c6c:	0189      	lsls	r1, r1, #6
 8002c6e:	0a49      	lsrs	r1, r1, #9
 8002c70:	b2db      	uxtb	r3, r3
 8002c72:	e7f1      	b.n	8002c58 <__aeabi_d2f+0x28>
 8002c74:	4305      	orrs	r5, r0
 8002c76:	d0ed      	beq.n	8002c54 <__aeabi_d2f+0x24>
 8002c78:	2180      	movs	r1, #128	; 0x80
 8002c7a:	03c9      	lsls	r1, r1, #15
 8002c7c:	23ff      	movs	r3, #255	; 0xff
 8002c7e:	4301      	orrs	r1, r0
 8002c80:	e7ea      	b.n	8002c58 <__aeabi_d2f+0x28>
 8002c82:	2e00      	cmp	r6, #0
 8002c84:	dd1c      	ble.n	8002cc0 <__aeabi_d2f+0x90>
 8002c86:	0192      	lsls	r2, r2, #6
 8002c88:	0011      	movs	r1, r2
 8002c8a:	1e4a      	subs	r2, r1, #1
 8002c8c:	4191      	sbcs	r1, r2
 8002c8e:	00c0      	lsls	r0, r0, #3
 8002c90:	0f6d      	lsrs	r5, r5, #29
 8002c92:	4301      	orrs	r1, r0
 8002c94:	4329      	orrs	r1, r5
 8002c96:	074b      	lsls	r3, r1, #29
 8002c98:	d048      	beq.n	8002d2c <__aeabi_d2f+0xfc>
 8002c9a:	230f      	movs	r3, #15
 8002c9c:	400b      	ands	r3, r1
 8002c9e:	2b04      	cmp	r3, #4
 8002ca0:	d000      	beq.n	8002ca4 <__aeabi_d2f+0x74>
 8002ca2:	3104      	adds	r1, #4
 8002ca4:	2380      	movs	r3, #128	; 0x80
 8002ca6:	04db      	lsls	r3, r3, #19
 8002ca8:	400b      	ands	r3, r1
 8002caa:	d03f      	beq.n	8002d2c <__aeabi_d2f+0xfc>
 8002cac:	1c72      	adds	r2, r6, #1
 8002cae:	2efe      	cmp	r6, #254	; 0xfe
 8002cb0:	d0d0      	beq.n	8002c54 <__aeabi_d2f+0x24>
 8002cb2:	0189      	lsls	r1, r1, #6
 8002cb4:	0a49      	lsrs	r1, r1, #9
 8002cb6:	b2d3      	uxtb	r3, r2
 8002cb8:	e7ce      	b.n	8002c58 <__aeabi_d2f+0x28>
 8002cba:	2300      	movs	r3, #0
 8002cbc:	2100      	movs	r1, #0
 8002cbe:	e7cb      	b.n	8002c58 <__aeabi_d2f+0x28>
 8002cc0:	0032      	movs	r2, r6
 8002cc2:	3217      	adds	r2, #23
 8002cc4:	db22      	blt.n	8002d0c <__aeabi_d2f+0xdc>
 8002cc6:	2180      	movs	r1, #128	; 0x80
 8002cc8:	221e      	movs	r2, #30
 8002cca:	0409      	lsls	r1, r1, #16
 8002ccc:	4308      	orrs	r0, r1
 8002cce:	1b92      	subs	r2, r2, r6
 8002cd0:	2a1f      	cmp	r2, #31
 8002cd2:	dd1d      	ble.n	8002d10 <__aeabi_d2f+0xe0>
 8002cd4:	2102      	movs	r1, #2
 8002cd6:	4249      	negs	r1, r1
 8002cd8:	1b8e      	subs	r6, r1, r6
 8002cda:	0001      	movs	r1, r0
 8002cdc:	40f1      	lsrs	r1, r6
 8002cde:	000e      	movs	r6, r1
 8002ce0:	2a20      	cmp	r2, #32
 8002ce2:	d004      	beq.n	8002cee <__aeabi_d2f+0xbe>
 8002ce4:	4a14      	ldr	r2, [pc, #80]	; (8002d38 <__aeabi_d2f+0x108>)
 8002ce6:	4694      	mov	ip, r2
 8002ce8:	4463      	add	r3, ip
 8002cea:	4098      	lsls	r0, r3
 8002cec:	4305      	orrs	r5, r0
 8002cee:	0029      	movs	r1, r5
 8002cf0:	1e4d      	subs	r5, r1, #1
 8002cf2:	41a9      	sbcs	r1, r5
 8002cf4:	4331      	orrs	r1, r6
 8002cf6:	2600      	movs	r6, #0
 8002cf8:	074b      	lsls	r3, r1, #29
 8002cfa:	d1ce      	bne.n	8002c9a <__aeabi_d2f+0x6a>
 8002cfc:	2080      	movs	r0, #128	; 0x80
 8002cfe:	000b      	movs	r3, r1
 8002d00:	04c0      	lsls	r0, r0, #19
 8002d02:	2201      	movs	r2, #1
 8002d04:	4003      	ands	r3, r0
 8002d06:	4201      	tst	r1, r0
 8002d08:	d1d3      	bne.n	8002cb2 <__aeabi_d2f+0x82>
 8002d0a:	e7af      	b.n	8002c6c <__aeabi_d2f+0x3c>
 8002d0c:	2300      	movs	r3, #0
 8002d0e:	e7ac      	b.n	8002c6a <__aeabi_d2f+0x3a>
 8002d10:	490a      	ldr	r1, [pc, #40]	; (8002d3c <__aeabi_d2f+0x10c>)
 8002d12:	468c      	mov	ip, r1
 8002d14:	0029      	movs	r1, r5
 8002d16:	4463      	add	r3, ip
 8002d18:	40d1      	lsrs	r1, r2
 8002d1a:	409d      	lsls	r5, r3
 8002d1c:	000a      	movs	r2, r1
 8002d1e:	0029      	movs	r1, r5
 8002d20:	4098      	lsls	r0, r3
 8002d22:	1e4d      	subs	r5, r1, #1
 8002d24:	41a9      	sbcs	r1, r5
 8002d26:	4301      	orrs	r1, r0
 8002d28:	4311      	orrs	r1, r2
 8002d2a:	e7e4      	b.n	8002cf6 <__aeabi_d2f+0xc6>
 8002d2c:	0033      	movs	r3, r6
 8002d2e:	e79d      	b.n	8002c6c <__aeabi_d2f+0x3c>
 8002d30:	000007fe 	.word	0x000007fe
 8002d34:	fffffc80 	.word	0xfffffc80
 8002d38:	fffffca2 	.word	0xfffffca2
 8002d3c:	fffffc82 	.word	0xfffffc82

08002d40 <__aeabi_cdrcmple>:
 8002d40:	4684      	mov	ip, r0
 8002d42:	1c10      	adds	r0, r2, #0
 8002d44:	4662      	mov	r2, ip
 8002d46:	468c      	mov	ip, r1
 8002d48:	1c19      	adds	r1, r3, #0
 8002d4a:	4663      	mov	r3, ip
 8002d4c:	e000      	b.n	8002d50 <__aeabi_cdcmpeq>
 8002d4e:	46c0      	nop			; (mov r8, r8)

08002d50 <__aeabi_cdcmpeq>:
 8002d50:	b51f      	push	{r0, r1, r2, r3, r4, lr}
 8002d52:	f000 f8ff 	bl	8002f54 <__ledf2>
 8002d56:	2800      	cmp	r0, #0
 8002d58:	d401      	bmi.n	8002d5e <__aeabi_cdcmpeq+0xe>
 8002d5a:	2100      	movs	r1, #0
 8002d5c:	42c8      	cmn	r0, r1
 8002d5e:	bd1f      	pop	{r0, r1, r2, r3, r4, pc}

08002d60 <__aeabi_dcmpeq>:
 8002d60:	b510      	push	{r4, lr}
 8002d62:	f000 f849 	bl	8002df8 <__eqdf2>
 8002d66:	4240      	negs	r0, r0
 8002d68:	3001      	adds	r0, #1
 8002d6a:	bd10      	pop	{r4, pc}

08002d6c <__aeabi_dcmplt>:
 8002d6c:	b510      	push	{r4, lr}
 8002d6e:	f000 f8f1 	bl	8002f54 <__ledf2>
 8002d72:	2800      	cmp	r0, #0
 8002d74:	db01      	blt.n	8002d7a <__aeabi_dcmplt+0xe>
 8002d76:	2000      	movs	r0, #0
 8002d78:	bd10      	pop	{r4, pc}
 8002d7a:	2001      	movs	r0, #1
 8002d7c:	bd10      	pop	{r4, pc}
 8002d7e:	46c0      	nop			; (mov r8, r8)

08002d80 <__aeabi_dcmple>:
 8002d80:	b510      	push	{r4, lr}
 8002d82:	f000 f8e7 	bl	8002f54 <__ledf2>
 8002d86:	2800      	cmp	r0, #0
 8002d88:	dd01      	ble.n	8002d8e <__aeabi_dcmple+0xe>
 8002d8a:	2000      	movs	r0, #0
 8002d8c:	bd10      	pop	{r4, pc}
 8002d8e:	2001      	movs	r0, #1
 8002d90:	bd10      	pop	{r4, pc}
 8002d92:	46c0      	nop			; (mov r8, r8)

08002d94 <__aeabi_dcmpgt>:
 8002d94:	b510      	push	{r4, lr}
 8002d96:	f000 f86b 	bl	8002e70 <__gedf2>
 8002d9a:	2800      	cmp	r0, #0
 8002d9c:	dc01      	bgt.n	8002da2 <__aeabi_dcmpgt+0xe>
 8002d9e:	2000      	movs	r0, #0
 8002da0:	bd10      	pop	{r4, pc}
 8002da2:	2001      	movs	r0, #1
 8002da4:	bd10      	pop	{r4, pc}
 8002da6:	46c0      	nop			; (mov r8, r8)

08002da8 <__aeabi_dcmpge>:
 8002da8:	b510      	push	{r4, lr}
 8002daa:	f000 f861 	bl	8002e70 <__gedf2>
 8002dae:	2800      	cmp	r0, #0
 8002db0:	da01      	bge.n	8002db6 <__aeabi_dcmpge+0xe>
 8002db2:	2000      	movs	r0, #0
 8002db4:	bd10      	pop	{r4, pc}
 8002db6:	2001      	movs	r0, #1
 8002db8:	bd10      	pop	{r4, pc}
 8002dba:	46c0      	nop			; (mov r8, r8)

08002dbc <__clzsi2>:
 8002dbc:	211c      	movs	r1, #28
 8002dbe:	2301      	movs	r3, #1
 8002dc0:	041b      	lsls	r3, r3, #16
 8002dc2:	4298      	cmp	r0, r3
 8002dc4:	d301      	bcc.n	8002dca <__clzsi2+0xe>
 8002dc6:	0c00      	lsrs	r0, r0, #16
 8002dc8:	3910      	subs	r1, #16
 8002dca:	0a1b      	lsrs	r3, r3, #8
 8002dcc:	4298      	cmp	r0, r3
 8002dce:	d301      	bcc.n	8002dd4 <__clzsi2+0x18>
 8002dd0:	0a00      	lsrs	r0, r0, #8
 8002dd2:	3908      	subs	r1, #8
 8002dd4:	091b      	lsrs	r3, r3, #4
 8002dd6:	4298      	cmp	r0, r3
 8002dd8:	d301      	bcc.n	8002dde <__clzsi2+0x22>
 8002dda:	0900      	lsrs	r0, r0, #4
 8002ddc:	3904      	subs	r1, #4
 8002dde:	a202      	add	r2, pc, #8	; (adr r2, 8002de8 <__clzsi2+0x2c>)
 8002de0:	5c10      	ldrb	r0, [r2, r0]
 8002de2:	1840      	adds	r0, r0, r1
 8002de4:	4770      	bx	lr
 8002de6:	46c0      	nop			; (mov r8, r8)
 8002de8:	02020304 	.word	0x02020304
 8002dec:	01010101 	.word	0x01010101
	...

08002df8 <__eqdf2>:
 8002df8:	b5f0      	push	{r4, r5, r6, r7, lr}
 8002dfa:	464f      	mov	r7, r9
 8002dfc:	4646      	mov	r6, r8
 8002dfe:	46d6      	mov	lr, sl
 8002e00:	4694      	mov	ip, r2
 8002e02:	4691      	mov	r9, r2
 8002e04:	031a      	lsls	r2, r3, #12
 8002e06:	0b12      	lsrs	r2, r2, #12
 8002e08:	4d18      	ldr	r5, [pc, #96]	; (8002e6c <__eqdf2+0x74>)
 8002e0a:	b5c0      	push	{r6, r7, lr}
 8002e0c:	004c      	lsls	r4, r1, #1
 8002e0e:	030f      	lsls	r7, r1, #12
 8002e10:	4692      	mov	sl, r2
 8002e12:	005a      	lsls	r2, r3, #1
 8002e14:	0006      	movs	r6, r0
 8002e16:	4680      	mov	r8, r0
 8002e18:	0b3f      	lsrs	r7, r7, #12
 8002e1a:	2001      	movs	r0, #1
 8002e1c:	0d64      	lsrs	r4, r4, #21
 8002e1e:	0fc9      	lsrs	r1, r1, #31
 8002e20:	0d52      	lsrs	r2, r2, #21
 8002e22:	0fdb      	lsrs	r3, r3, #31
 8002e24:	42ac      	cmp	r4, r5
 8002e26:	d00a      	beq.n	8002e3e <__eqdf2+0x46>
 8002e28:	42aa      	cmp	r2, r5
 8002e2a:	d003      	beq.n	8002e34 <__eqdf2+0x3c>
 8002e2c:	4294      	cmp	r4, r2
 8002e2e:	d101      	bne.n	8002e34 <__eqdf2+0x3c>
 8002e30:	4557      	cmp	r7, sl
 8002e32:	d00d      	beq.n	8002e50 <__eqdf2+0x58>
 8002e34:	bce0      	pop	{r5, r6, r7}
 8002e36:	46ba      	mov	sl, r7
 8002e38:	46b1      	mov	r9, r6
 8002e3a:	46a8      	mov	r8, r5
 8002e3c:	bdf0      	pop	{r4, r5, r6, r7, pc}
 8002e3e:	003d      	movs	r5, r7
 8002e40:	4335      	orrs	r5, r6
 8002e42:	d1f7      	bne.n	8002e34 <__eqdf2+0x3c>
 8002e44:	42a2      	cmp	r2, r4
 8002e46:	d1f5      	bne.n	8002e34 <__eqdf2+0x3c>
 8002e48:	4652      	mov	r2, sl
 8002e4a:	4665      	mov	r5, ip
 8002e4c:	432a      	orrs	r2, r5
 8002e4e:	d1f1      	bne.n	8002e34 <__eqdf2+0x3c>
 8002e50:	2001      	movs	r0, #1
 8002e52:	45c8      	cmp	r8, r9
 8002e54:	d1ee      	bne.n	8002e34 <__eqdf2+0x3c>
 8002e56:	4299      	cmp	r1, r3
 8002e58:	d006      	beq.n	8002e68 <__eqdf2+0x70>
 8002e5a:	2c00      	cmp	r4, #0
 8002e5c:	d1ea      	bne.n	8002e34 <__eqdf2+0x3c>
 8002e5e:	433e      	orrs	r6, r7
 8002e60:	0030      	movs	r0, r6
 8002e62:	1e46      	subs	r6, r0, #1
 8002e64:	41b0      	sbcs	r0, r6
 8002e66:	e7e5      	b.n	8002e34 <__eqdf2+0x3c>
 8002e68:	2000      	movs	r0, #0
 8002e6a:	e7e3      	b.n	8002e34 <__eqdf2+0x3c>
 8002e6c:	000007ff 	.word	0x000007ff

08002e70 <__gedf2>:
 8002e70:	b5f0      	push	{r4, r5, r6, r7, lr}
 8002e72:	464e      	mov	r6, r9
 8002e74:	4645      	mov	r5, r8
 8002e76:	4657      	mov	r7, sl
 8002e78:	46de      	mov	lr, fp
 8002e7a:	0004      	movs	r4, r0
 8002e7c:	0018      	movs	r0, r3
 8002e7e:	b5e0      	push	{r5, r6, r7, lr}
 8002e80:	0016      	movs	r6, r2
 8002e82:	031b      	lsls	r3, r3, #12
 8002e84:	0b1b      	lsrs	r3, r3, #12
 8002e86:	4d32      	ldr	r5, [pc, #200]	; (8002f50 <__gedf2+0xe0>)
 8002e88:	030f      	lsls	r7, r1, #12
 8002e8a:	004a      	lsls	r2, r1, #1
 8002e8c:	4699      	mov	r9, r3
 8002e8e:	0043      	lsls	r3, r0, #1
 8002e90:	46a4      	mov	ip, r4
 8002e92:	46b0      	mov	r8, r6
 8002e94:	0b3f      	lsrs	r7, r7, #12
 8002e96:	0d52      	lsrs	r2, r2, #21
 8002e98:	0fc9      	lsrs	r1, r1, #31
 8002e9a:	0d5b      	lsrs	r3, r3, #21
 8002e9c:	0fc0      	lsrs	r0, r0, #31
 8002e9e:	42aa      	cmp	r2, r5
 8002ea0:	d029      	beq.n	8002ef6 <__gedf2+0x86>
 8002ea2:	42ab      	cmp	r3, r5
 8002ea4:	d018      	beq.n	8002ed8 <__gedf2+0x68>
 8002ea6:	2a00      	cmp	r2, #0
 8002ea8:	d12a      	bne.n	8002f00 <__gedf2+0x90>
 8002eaa:	433c      	orrs	r4, r7
 8002eac:	46a3      	mov	fp, r4
 8002eae:	4265      	negs	r5, r4
 8002eb0:	4165      	adcs	r5, r4
 8002eb2:	2b00      	cmp	r3, #0
 8002eb4:	d102      	bne.n	8002ebc <__gedf2+0x4c>
 8002eb6:	464c      	mov	r4, r9
 8002eb8:	4326      	orrs	r6, r4
 8002eba:	d027      	beq.n	8002f0c <__gedf2+0x9c>
 8002ebc:	2d00      	cmp	r5, #0
 8002ebe:	d115      	bne.n	8002eec <__gedf2+0x7c>
 8002ec0:	4281      	cmp	r1, r0
 8002ec2:	d028      	beq.n	8002f16 <__gedf2+0xa6>
 8002ec4:	2002      	movs	r0, #2
 8002ec6:	3901      	subs	r1, #1
 8002ec8:	4008      	ands	r0, r1
 8002eca:	3801      	subs	r0, #1
 8002ecc:	bcf0      	pop	{r4, r5, r6, r7}
 8002ece:	46bb      	mov	fp, r7
 8002ed0:	46b2      	mov	sl, r6
 8002ed2:	46a9      	mov	r9, r5
 8002ed4:	46a0      	mov	r8, r4
 8002ed6:	bdf0      	pop	{r4, r5, r6, r7, pc}
 8002ed8:	464d      	mov	r5, r9
 8002eda:	432e      	orrs	r6, r5
 8002edc:	d12f      	bne.n	8002f3e <__gedf2+0xce>
 8002ede:	2a00      	cmp	r2, #0
 8002ee0:	d1ee      	bne.n	8002ec0 <__gedf2+0x50>
 8002ee2:	433c      	orrs	r4, r7
 8002ee4:	4265      	negs	r5, r4
 8002ee6:	4165      	adcs	r5, r4
 8002ee8:	2d00      	cmp	r5, #0
 8002eea:	d0e9      	beq.n	8002ec0 <__gedf2+0x50>
 8002eec:	2800      	cmp	r0, #0
 8002eee:	d1ed      	bne.n	8002ecc <__gedf2+0x5c>
 8002ef0:	2001      	movs	r0, #1
 8002ef2:	4240      	negs	r0, r0
 8002ef4:	e7ea      	b.n	8002ecc <__gedf2+0x5c>
 8002ef6:	003d      	movs	r5, r7
 8002ef8:	4325      	orrs	r5, r4
 8002efa:	d120      	bne.n	8002f3e <__gedf2+0xce>
 8002efc:	4293      	cmp	r3, r2
 8002efe:	d0eb      	beq.n	8002ed8 <__gedf2+0x68>
 8002f00:	2b00      	cmp	r3, #0
 8002f02:	d1dd      	bne.n	8002ec0 <__gedf2+0x50>
 8002f04:	464c      	mov	r4, r9
 8002f06:	4326      	orrs	r6, r4
 8002f08:	d1da      	bne.n	8002ec0 <__gedf2+0x50>
 8002f0a:	e7db      	b.n	8002ec4 <__gedf2+0x54>
 8002f0c:	465b      	mov	r3, fp
 8002f0e:	2000      	movs	r0, #0
 8002f10:	2b00      	cmp	r3, #0
 8002f12:	d0db      	beq.n	8002ecc <__gedf2+0x5c>
 8002f14:	e7d6      	b.n	8002ec4 <__gedf2+0x54>
 8002f16:	429a      	cmp	r2, r3
 8002f18:	dc0a      	bgt.n	8002f30 <__gedf2+0xc0>
 8002f1a:	dbe7      	blt.n	8002eec <__gedf2+0x7c>
 8002f1c:	454f      	cmp	r7, r9
 8002f1e:	d8d1      	bhi.n	8002ec4 <__gedf2+0x54>
 8002f20:	d010      	beq.n	8002f44 <__gedf2+0xd4>
 8002f22:	2000      	movs	r0, #0
 8002f24:	454f      	cmp	r7, r9
 8002f26:	d2d1      	bcs.n	8002ecc <__gedf2+0x5c>
 8002f28:	2900      	cmp	r1, #0
 8002f2a:	d0e1      	beq.n	8002ef0 <__gedf2+0x80>
 8002f2c:	0008      	movs	r0, r1
 8002f2e:	e7cd      	b.n	8002ecc <__gedf2+0x5c>
 8002f30:	4243      	negs	r3, r0
 8002f32:	4158      	adcs	r0, r3
 8002f34:	2302      	movs	r3, #2
 8002f36:	4240      	negs	r0, r0
 8002f38:	4018      	ands	r0, r3
 8002f3a:	3801      	subs	r0, #1
 8002f3c:	e7c6      	b.n	8002ecc <__gedf2+0x5c>
 8002f3e:	2002      	movs	r0, #2
 8002f40:	4240      	negs	r0, r0
 8002f42:	e7c3      	b.n	8002ecc <__gedf2+0x5c>
 8002f44:	45c4      	cmp	ip, r8
 8002f46:	d8bd      	bhi.n	8002ec4 <__gedf2+0x54>
 8002f48:	2000      	movs	r0, #0
 8002f4a:	45c4      	cmp	ip, r8
 8002f4c:	d2be      	bcs.n	8002ecc <__gedf2+0x5c>
 8002f4e:	e7eb      	b.n	8002f28 <__gedf2+0xb8>
 8002f50:	000007ff 	.word	0x000007ff

08002f54 <__ledf2>:
 8002f54:	b5f0      	push	{r4, r5, r6, r7, lr}
 8002f56:	464e      	mov	r6, r9
 8002f58:	4645      	mov	r5, r8
 8002f5a:	4657      	mov	r7, sl
 8002f5c:	46de      	mov	lr, fp
 8002f5e:	0004      	movs	r4, r0
 8002f60:	0018      	movs	r0, r3
 8002f62:	b5e0      	push	{r5, r6, r7, lr}
 8002f64:	0016      	movs	r6, r2
 8002f66:	031b      	lsls	r3, r3, #12
 8002f68:	0b1b      	lsrs	r3, r3, #12
 8002f6a:	4d31      	ldr	r5, [pc, #196]	; (8003030 <__ledf2+0xdc>)
 8002f6c:	030f      	lsls	r7, r1, #12
 8002f6e:	004a      	lsls	r2, r1, #1
 8002f70:	4699      	mov	r9, r3
 8002f72:	0043      	lsls	r3, r0, #1
 8002f74:	46a4      	mov	ip, r4
 8002f76:	46b0      	mov	r8, r6
 8002f78:	0b3f      	lsrs	r7, r7, #12
 8002f7a:	0d52      	lsrs	r2, r2, #21
 8002f7c:	0fc9      	lsrs	r1, r1, #31
 8002f7e:	0d5b      	lsrs	r3, r3, #21
 8002f80:	0fc0      	lsrs	r0, r0, #31
 8002f82:	42aa      	cmp	r2, r5
 8002f84:	d011      	beq.n	8002faa <__ledf2+0x56>
 8002f86:	42ab      	cmp	r3, r5
 8002f88:	d014      	beq.n	8002fb4 <__ledf2+0x60>
 8002f8a:	2a00      	cmp	r2, #0
 8002f8c:	d12f      	bne.n	8002fee <__ledf2+0x9a>
 8002f8e:	433c      	orrs	r4, r7
 8002f90:	46a3      	mov	fp, r4
 8002f92:	4265      	negs	r5, r4
 8002f94:	4165      	adcs	r5, r4
 8002f96:	2b00      	cmp	r3, #0
 8002f98:	d114      	bne.n	8002fc4 <__ledf2+0x70>
 8002f9a:	464c      	mov	r4, r9
 8002f9c:	4326      	orrs	r6, r4
 8002f9e:	d111      	bne.n	8002fc4 <__ledf2+0x70>
 8002fa0:	465b      	mov	r3, fp
 8002fa2:	2000      	movs	r0, #0
 8002fa4:	2b00      	cmp	r3, #0
 8002fa6:	d017      	beq.n	8002fd8 <__ledf2+0x84>
 8002fa8:	e010      	b.n	8002fcc <__ledf2+0x78>
 8002faa:	003d      	movs	r5, r7
 8002fac:	4325      	orrs	r5, r4
 8002fae:	d112      	bne.n	8002fd6 <__ledf2+0x82>
 8002fb0:	4293      	cmp	r3, r2
 8002fb2:	d11c      	bne.n	8002fee <__ledf2+0x9a>
 8002fb4:	464d      	mov	r5, r9
 8002fb6:	432e      	orrs	r6, r5
 8002fb8:	d10d      	bne.n	8002fd6 <__ledf2+0x82>
 8002fba:	2a00      	cmp	r2, #0
 8002fbc:	d104      	bne.n	8002fc8 <__ledf2+0x74>
 8002fbe:	433c      	orrs	r4, r7
 8002fc0:	4265      	negs	r5, r4
 8002fc2:	4165      	adcs	r5, r4
 8002fc4:	2d00      	cmp	r5, #0
 8002fc6:	d10d      	bne.n	8002fe4 <__ledf2+0x90>
 8002fc8:	4281      	cmp	r1, r0
 8002fca:	d016      	beq.n	8002ffa <__ledf2+0xa6>
 8002fcc:	2002      	movs	r0, #2
 8002fce:	3901      	subs	r1, #1
 8002fd0:	4008      	ands	r0, r1
 8002fd2:	3801      	subs	r0, #1
 8002fd4:	e000      	b.n	8002fd8 <__ledf2+0x84>
 8002fd6:	2002      	movs	r0, #2
 8002fd8:	bcf0      	pop	{r4, r5, r6, r7}
 8002fda:	46bb      	mov	fp, r7
 8002fdc:	46b2      	mov	sl, r6
 8002fde:	46a9      	mov	r9, r5
 8002fe0:	46a0      	mov	r8, r4
 8002fe2:	bdf0      	pop	{r4, r5, r6, r7, pc}
 8002fe4:	2800      	cmp	r0, #0
 8002fe6:	d1f7      	bne.n	8002fd8 <__ledf2+0x84>
 8002fe8:	2001      	movs	r0, #1
 8002fea:	4240      	negs	r0, r0
 8002fec:	e7f4      	b.n	8002fd8 <__ledf2+0x84>
 8002fee:	2b00      	cmp	r3, #0
 8002ff0:	d1ea      	bne.n	8002fc8 <__ledf2+0x74>
 8002ff2:	464c      	mov	r4, r9
 8002ff4:	4326      	orrs	r6, r4
 8002ff6:	d1e7      	bne.n	8002fc8 <__ledf2+0x74>
 8002ff8:	e7e8      	b.n	8002fcc <__ledf2+0x78>
 8002ffa:	429a      	cmp	r2, r3
 8002ffc:	dd06      	ble.n	800300c <__ledf2+0xb8>
 8002ffe:	4243      	negs	r3, r0
 8003000:	4158      	adcs	r0, r3
 8003002:	2302      	movs	r3, #2
 8003004:	4240      	negs	r0, r0
 8003006:	4018      	ands	r0, r3
 8003008:	3801      	subs	r0, #1
 800300a:	e7e5      	b.n	8002fd8 <__ledf2+0x84>
 800300c:	429a      	cmp	r2, r3
 800300e:	dbe9      	blt.n	8002fe4 <__ledf2+0x90>
 8003010:	454f      	cmp	r7, r9
 8003012:	d8db      	bhi.n	8002fcc <__ledf2+0x78>
 8003014:	d006      	beq.n	8003024 <__ledf2+0xd0>
 8003016:	2000      	movs	r0, #0
 8003018:	454f      	cmp	r7, r9
 800301a:	d2dd      	bcs.n	8002fd8 <__ledf2+0x84>
 800301c:	2900      	cmp	r1, #0
 800301e:	d0e3      	beq.n	8002fe8 <__ledf2+0x94>
 8003020:	0008      	movs	r0, r1
 8003022:	e7d9      	b.n	8002fd8 <__ledf2+0x84>
 8003024:	45c4      	cmp	ip, r8
 8003026:	d8d1      	bhi.n	8002fcc <__ledf2+0x78>
 8003028:	2000      	movs	r0, #0
 800302a:	45c4      	cmp	ip, r8
 800302c:	d2d4      	bcs.n	8002fd8 <__ledf2+0x84>
 800302e:	e7f5      	b.n	800301c <__ledf2+0xc8>
 8003030:	000007ff 	.word	0x000007ff

08003034 <__gnu_thumb1_case_uqi>:
 8003034:	b402      	push	{r1}
 8003036:	4671      	mov	r1, lr
 8003038:	0849      	lsrs	r1, r1, #1
 800303a:	0049      	lsls	r1, r1, #1
 800303c:	5c09      	ldrb	r1, [r1, r0]
 800303e:	0049      	lsls	r1, r1, #1
 8003040:	448e      	add	lr, r1
 8003042:	bc02      	pop	{r1}
 8003044:	4770      	bx	lr
 8003046:	46c0      	nop			; (mov r8, r8)

08003048 <__gnu_thumb1_case_shi>:
 8003048:	b403      	push	{r0, r1}
 800304a:	4671      	mov	r1, lr
 800304c:	0849      	lsrs	r1, r1, #1
 800304e:	0040      	lsls	r0, r0, #1
 8003050:	0049      	lsls	r1, r1, #1
 8003052:	5e09      	ldrsh	r1, [r1, r0]
 8003054:	0049      	lsls	r1, r1, #1
 8003056:	448e      	add	lr, r1
 8003058:	bc03      	pop	{r0, r1}
 800305a:	4770      	bx	lr

0800305c <__aeabi_ui2d>:
 800305c:	b510      	push	{r4, lr}
 800305e:	1e04      	subs	r4, r0, #0
 8003060:	d010      	beq.n	8003084 <__aeabi_ui2d+0x28>
 8003062:	f7ff feab 	bl	8002dbc <__clzsi2>
 8003066:	4b0f      	ldr	r3, [pc, #60]	; (80030a4 <__aeabi_ui2d+0x48>)
 8003068:	1a1b      	subs	r3, r3, r0
 800306a:	280a      	cmp	r0, #10
 800306c:	dc11      	bgt.n	8003092 <__aeabi_ui2d+0x36>
 800306e:	220b      	movs	r2, #11
 8003070:	0021      	movs	r1, r4
 8003072:	1a12      	subs	r2, r2, r0
 8003074:	40d1      	lsrs	r1, r2
 8003076:	3015      	adds	r0, #21
 8003078:	030a      	lsls	r2, r1, #12
 800307a:	055b      	lsls	r3, r3, #21
 800307c:	4084      	lsls	r4, r0
 800307e:	0b12      	lsrs	r2, r2, #12
 8003080:	0d5b      	lsrs	r3, r3, #21
 8003082:	e001      	b.n	8003088 <__aeabi_ui2d+0x2c>
 8003084:	2300      	movs	r3, #0
 8003086:	2200      	movs	r2, #0
 8003088:	051b      	lsls	r3, r3, #20
 800308a:	4313      	orrs	r3, r2
 800308c:	0020      	movs	r0, r4
 800308e:	0019      	movs	r1, r3
 8003090:	bd10      	pop	{r4, pc}
 8003092:	0022      	movs	r2, r4
 8003094:	380b      	subs	r0, #11
 8003096:	4082      	lsls	r2, r0
 8003098:	055b      	lsls	r3, r3, #21
 800309a:	0312      	lsls	r2, r2, #12
 800309c:	2400      	movs	r4, #0
 800309e:	0b12      	lsrs	r2, r2, #12
 80030a0:	0d5b      	lsrs	r3, r3, #21
 80030a2:	e7f1      	b.n	8003088 <__aeabi_ui2d+0x2c>
 80030a4:	0000041e 	.word	0x0000041e

080030a8 <__aeabi_dcmpun>:
 80030a8:	b570      	push	{r4, r5, r6, lr}
 80030aa:	0005      	movs	r5, r0
 80030ac:	480c      	ldr	r0, [pc, #48]	; (80030e0 <__aeabi_dcmpun+0x38>)
 80030ae:	030c      	lsls	r4, r1, #12
 80030b0:	0016      	movs	r6, r2
 80030b2:	0049      	lsls	r1, r1, #1
 80030b4:	031a      	lsls	r2, r3, #12
 80030b6:	005b      	lsls	r3, r3, #1
 80030b8:	0b24      	lsrs	r4, r4, #12
 80030ba:	0d49      	lsrs	r1, r1, #21
 80030bc:	0b12      	lsrs	r2, r2, #12
 80030be:	0d5b      	lsrs	r3, r3, #21
 80030c0:	4281      	cmp	r1, r0
 80030c2:	d008      	beq.n	80030d6 <__aeabi_dcmpun+0x2e>
 80030c4:	4906      	ldr	r1, [pc, #24]	; (80030e0 <__aeabi_dcmpun+0x38>)
 80030c6:	2000      	movs	r0, #0
 80030c8:	428b      	cmp	r3, r1
 80030ca:	d103      	bne.n	80030d4 <__aeabi_dcmpun+0x2c>
 80030cc:	4332      	orrs	r2, r6
 80030ce:	0010      	movs	r0, r2
 80030d0:	1e42      	subs	r2, r0, #1
 80030d2:	4190      	sbcs	r0, r2
 80030d4:	bd70      	pop	{r4, r5, r6, pc}
 80030d6:	2001      	movs	r0, #1
 80030d8:	432c      	orrs	r4, r5
 80030da:	d1fb      	bne.n	80030d4 <__aeabi_dcmpun+0x2c>
 80030dc:	e7f2      	b.n	80030c4 <__aeabi_dcmpun+0x1c>
 80030de:	46c0      	nop			; (mov r8, r8)
 80030e0:	000007ff 	.word	0x000007ff

080030e4 <LCD_Drawnum>:
	float freq = 100.0;
	LCD_Drawnum(3, 0, 1, &freq, &fmax);
	return 0;
}*/
void LCD_Drawnum(int size, int side, int row, float *num, float *num2)
{
 80030e4:	b590      	push	{r4, r7, lr}
 80030e6:	b08d      	sub	sp, #52	; 0x34
 80030e8:	af04      	add	r7, sp, #16
 80030ea:	60f8      	str	r0, [r7, #12]
 80030ec:	60b9      	str	r1, [r7, #8]
 80030ee:	607a      	str	r2, [r7, #4]
 80030f0:	603b      	str	r3, [r7, #0]
	char fma[15];
	gcvt(*num2, 6, fma);
 80030f2:	6b3b      	ldr	r3, [r7, #48]	; 0x30
 80030f4:	681b      	ldr	r3, [r3, #0]
 80030f6:	1c18      	adds	r0, r3, #0
 80030f8:	f7ff fd52 	bl	8002ba0 <__aeabi_f2d>
 80030fc:	2410      	movs	r4, #16
 80030fe:	193b      	adds	r3, r7, r4
 8003100:	2206      	movs	r2, #6
 8003102:	f006 fd63 	bl	8009bcc <gcvt>
	LCD_DrawString(60,120,YELLOW, BLUE, "FMAX", 16, 0);
 8003106:	4a0e      	ldr	r2, [pc, #56]	; (8003140 <LCD_Drawnum+0x5c>)
 8003108:	2300      	movs	r3, #0
 800310a:	9302      	str	r3, [sp, #8]
 800310c:	2310      	movs	r3, #16
 800310e:	9301      	str	r3, [sp, #4]
 8003110:	4b0c      	ldr	r3, [pc, #48]	; (8003144 <LCD_Drawnum+0x60>)
 8003112:	9300      	str	r3, [sp, #0]
 8003114:	231f      	movs	r3, #31
 8003116:	2178      	movs	r1, #120	; 0x78
 8003118:	203c      	movs	r0, #60	; 0x3c
 800311a:	f000 fe2f 	bl	8003d7c <LCD_DrawString>
	LCD_DrawString(60,140,YELLOW, BLUE, fma, 16, 0);
 800311e:	4a08      	ldr	r2, [pc, #32]	; (8003140 <LCD_Drawnum+0x5c>)
 8003120:	2300      	movs	r3, #0
 8003122:	9302      	str	r3, [sp, #8]
 8003124:	2310      	movs	r3, #16
 8003126:	9301      	str	r3, [sp, #4]
 8003128:	193b      	adds	r3, r7, r4
 800312a:	9300      	str	r3, [sp, #0]
 800312c:	231f      	movs	r3, #31
 800312e:	218c      	movs	r1, #140	; 0x8c
 8003130:	203c      	movs	r0, #60	; 0x3c
 8003132:	f000 fe23 	bl	8003d7c <LCD_DrawString>

}
 8003136:	46c0      	nop			; (mov r8, r8)
 8003138:	46bd      	mov	sp, r7
 800313a:	b009      	add	sp, #36	; 0x24
 800313c:	bd90      	pop	{r4, r7, pc}
 800313e:	46c0      	nop			; (mov r8, r8)
 8003140:	0000ffe0 	.word	0x0000ffe0
 8003144:	0800e358 	.word	0x0800e358

08003148 <RearrangeFFT>:
	
	return;
}

void RearrangeFFT(float* data_re, float* data_im, const unsigned int N)
{
 8003148:	b580      	push	{r7, lr}
 800314a:	b08a      	sub	sp, #40	; 0x28
 800314c:	af00      	add	r7, sp, #0
 800314e:	60f8      	str	r0, [r7, #12]
 8003150:	60b9      	str	r1, [r7, #8]
 8003152:	607a      	str	r2, [r7, #4]
	unsigned int target = 0;
 8003154:	2300      	movs	r3, #0
 8003156:	627b      	str	r3, [r7, #36]	; 0x24
	for (int n = 0; n < N; n++)
 8003158:	2300      	movs	r3, #0
 800315a:	623b      	str	r3, [r7, #32]
 800315c:	e045      	b.n	80031ea <RearrangeFFT+0xa2>
	{
		if (target > n)
 800315e:	6a3b      	ldr	r3, [r7, #32]
 8003160:	6a7a      	ldr	r2, [r7, #36]	; 0x24
 8003162:	429a      	cmp	r2, r3
 8003164:	d92b      	bls.n	80031be <RearrangeFFT+0x76>
		{
			SWAP(data_re[target], data_re[n]);
 8003166:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 8003168:	009b      	lsls	r3, r3, #2
 800316a:	68fa      	ldr	r2, [r7, #12]
 800316c:	18d3      	adds	r3, r2, r3
 800316e:	681b      	ldr	r3, [r3, #0]
 8003170:	61bb      	str	r3, [r7, #24]
 8003172:	6a3b      	ldr	r3, [r7, #32]
 8003174:	009b      	lsls	r3, r3, #2
 8003176:	68fa      	ldr	r2, [r7, #12]
 8003178:	18d2      	adds	r2, r2, r3
 800317a:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 800317c:	009b      	lsls	r3, r3, #2
 800317e:	68f9      	ldr	r1, [r7, #12]
 8003180:	18cb      	adds	r3, r1, r3
 8003182:	6812      	ldr	r2, [r2, #0]
 8003184:	601a      	str	r2, [r3, #0]
 8003186:	6a3b      	ldr	r3, [r7, #32]
 8003188:	009b      	lsls	r3, r3, #2
 800318a:	68fa      	ldr	r2, [r7, #12]
 800318c:	18d3      	adds	r3, r2, r3
 800318e:	69ba      	ldr	r2, [r7, #24]
 8003190:	601a      	str	r2, [r3, #0]
			SWAP(data_im[target], data_im[n]);
 8003192:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 8003194:	009b      	lsls	r3, r3, #2
 8003196:	68ba      	ldr	r2, [r7, #8]
 8003198:	18d3      	adds	r3, r2, r3
 800319a:	681b      	ldr	r3, [r3, #0]
 800319c:	617b      	str	r3, [r7, #20]
 800319e:	6a3b      	ldr	r3, [r7, #32]
 80031a0:	009b      	lsls	r3, r3, #2
 80031a2:	68ba      	ldr	r2, [r7, #8]
 80031a4:	18d2      	adds	r2, r2, r3
 80031a6:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 80031a8:	009b      	lsls	r3, r3, #2
 80031aa:	68b9      	ldr	r1, [r7, #8]
 80031ac:	18cb      	adds	r3, r1, r3
 80031ae:	6812      	ldr	r2, [r2, #0]
 80031b0:	601a      	str	r2, [r3, #0]
 80031b2:	6a3b      	ldr	r3, [r7, #32]
 80031b4:	009b      	lsls	r3, r3, #2
 80031b6:	68ba      	ldr	r2, [r7, #8]
 80031b8:	18d3      	adds	r3, r2, r3
 80031ba:	697a      	ldr	r2, [r7, #20]
 80031bc:	601a      	str	r2, [r3, #0]
		}
		unsigned int mask = N;
 80031be:	687b      	ldr	r3, [r7, #4]
 80031c0:	61fb      	str	r3, [r7, #28]
		while (target & (mask >>= 1))
 80031c2:	e004      	b.n	80031ce <RearrangeFFT+0x86>
			target &= ~mask;
 80031c4:	69fb      	ldr	r3, [r7, #28]
 80031c6:	43da      	mvns	r2, r3
 80031c8:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 80031ca:	4013      	ands	r3, r2
 80031cc:	627b      	str	r3, [r7, #36]	; 0x24
		while (target & (mask >>= 1))
 80031ce:	69fb      	ldr	r3, [r7, #28]
 80031d0:	085b      	lsrs	r3, r3, #1
 80031d2:	61fb      	str	r3, [r7, #28]
 80031d4:	69fb      	ldr	r3, [r7, #28]
 80031d6:	6a7a      	ldr	r2, [r7, #36]	; 0x24
 80031d8:	4013      	ands	r3, r2
 80031da:	d1f3      	bne.n	80031c4 <RearrangeFFT+0x7c>
		target |= mask;
 80031dc:	6a7a      	ldr	r2, [r7, #36]	; 0x24
 80031de:	69fb      	ldr	r3, [r7, #28]
 80031e0:	4313      	orrs	r3, r2
 80031e2:	627b      	str	r3, [r7, #36]	; 0x24
	for (int n = 0; n < N; n++)
 80031e4:	6a3b      	ldr	r3, [r7, #32]
 80031e6:	3301      	adds	r3, #1
 80031e8:	623b      	str	r3, [r7, #32]
 80031ea:	6a3b      	ldr	r3, [r7, #32]
 80031ec:	687a      	ldr	r2, [r7, #4]
 80031ee:	429a      	cmp	r2, r3
 80031f0:	d8b5      	bhi.n	800315e <RearrangeFFT+0x16>
	}
}
 80031f2:	46c0      	nop			; (mov r8, r8)
 80031f4:	46c0      	nop			; (mov r8, r8)
 80031f6:	46bd      	mov	sp, r7
 80031f8:	b00a      	add	sp, #40	; 0x28
 80031fa:	bd80      	pop	{r7, pc}

080031fc <ComputeFFT>:

void ComputeFFT(float* data_re, float* data_im, const unsigned int N)
{
 80031fc:	b5b0      	push	{r4, r5, r7, lr}
 80031fe:	b090      	sub	sp, #64	; 0x40
 8003200:	af00      	add	r7, sp, #0
 8003202:	60f8      	str	r0, [r7, #12]
 8003204:	60b9      	str	r1, [r7, #8]
 8003206:	607a      	str	r2, [r7, #4]
	for (int step = 1; step < N; step <<= 1)
 8003208:	2301      	movs	r3, #1
 800320a:	63fb      	str	r3, [r7, #60]	; 0x3c
 800320c:	e0e6      	b.n	80033dc <ComputeFFT+0x1e0>
	{
		const unsigned int jump = step << 1;
 800320e:	6bfb      	ldr	r3, [r7, #60]	; 0x3c
 8003210:	005b      	lsls	r3, r3, #1
 8003212:	62bb      	str	r3, [r7, #40]	; 0x28
		const float step_d = (float) step;
 8003214:	6bf8      	ldr	r0, [r7, #60]	; 0x3c
 8003216:	f7fd ff8b 	bl	8001130 <__aeabi_i2f>
 800321a:	1c03      	adds	r3, r0, #0
 800321c:	627b      	str	r3, [r7, #36]	; 0x24
		float twiddle_re = 1.0;
 800321e:	23fe      	movs	r3, #254	; 0xfe
 8003220:	059b      	lsls	r3, r3, #22
 8003222:	63bb      	str	r3, [r7, #56]	; 0x38
		float twiddle_im = 0.0;
 8003224:	2300      	movs	r3, #0
 8003226:	637b      	str	r3, [r7, #52]	; 0x34
		for (int group = 0; group < step; group++)
 8003228:	2300      	movs	r3, #0
 800322a:	633b      	str	r3, [r7, #48]	; 0x30
 800322c:	e0ce      	b.n	80033cc <ComputeFFT+0x1d0>
		{
			for (int pair = group; pair < N; pair += jump)
 800322e:	6b3b      	ldr	r3, [r7, #48]	; 0x30
 8003230:	62fb      	str	r3, [r7, #44]	; 0x2c
 8003232:	e075      	b.n	8003320 <ComputeFFT+0x124>
			{
				const unsigned int match = pair + step;
 8003234:	6afa      	ldr	r2, [r7, #44]	; 0x2c
 8003236:	6bfb      	ldr	r3, [r7, #60]	; 0x3c
 8003238:	18d3      	adds	r3, r2, r3
 800323a:	61fb      	str	r3, [r7, #28]
				const float product_re = twiddle_re * data_re[match] - twiddle_im * data_im[match];
 800323c:	69fb      	ldr	r3, [r7, #28]
 800323e:	009b      	lsls	r3, r3, #2
 8003240:	68fa      	ldr	r2, [r7, #12]
 8003242:	18d3      	adds	r3, r2, r3
 8003244:	681b      	ldr	r3, [r3, #0]
 8003246:	6bb9      	ldr	r1, [r7, #56]	; 0x38
 8003248:	1c18      	adds	r0, r3, #0
 800324a:	f7fd fc8f 	bl	8000b6c <__aeabi_fmul>
 800324e:	1c03      	adds	r3, r0, #0
 8003250:	1c1c      	adds	r4, r3, #0
 8003252:	69fb      	ldr	r3, [r7, #28]
 8003254:	009b      	lsls	r3, r3, #2
 8003256:	68ba      	ldr	r2, [r7, #8]
 8003258:	18d3      	adds	r3, r2, r3
 800325a:	681b      	ldr	r3, [r3, #0]
 800325c:	6b79      	ldr	r1, [r7, #52]	; 0x34
 800325e:	1c18      	adds	r0, r3, #0
 8003260:	f7fd fc84 	bl	8000b6c <__aeabi_fmul>
 8003264:	1c03      	adds	r3, r0, #0
 8003266:	1c19      	adds	r1, r3, #0
 8003268:	1c20      	adds	r0, r4, #0
 800326a:	f7fd fd99 	bl	8000da0 <__aeabi_fsub>
 800326e:	1c03      	adds	r3, r0, #0
 8003270:	61bb      	str	r3, [r7, #24]
				const float product_im = twiddle_im * data_re[match] + twiddle_re * data_im[match];
 8003272:	69fb      	ldr	r3, [r7, #28]
 8003274:	009b      	lsls	r3, r3, #2
 8003276:	68fa      	ldr	r2, [r7, #12]
 8003278:	18d3      	adds	r3, r2, r3
 800327a:	681b      	ldr	r3, [r3, #0]
 800327c:	6b79      	ldr	r1, [r7, #52]	; 0x34
 800327e:	1c18      	adds	r0, r3, #0
 8003280:	f7fd fc74 	bl	8000b6c <__aeabi_fmul>
 8003284:	1c03      	adds	r3, r0, #0
 8003286:	1c1c      	adds	r4, r3, #0
 8003288:	69fb      	ldr	r3, [r7, #28]
 800328a:	009b      	lsls	r3, r3, #2
 800328c:	68ba      	ldr	r2, [r7, #8]
 800328e:	18d3      	adds	r3, r2, r3
 8003290:	681b      	ldr	r3, [r3, #0]
 8003292:	6bb9      	ldr	r1, [r7, #56]	; 0x38
 8003294:	1c18      	adds	r0, r3, #0
 8003296:	f7fd fc69 	bl	8000b6c <__aeabi_fmul>
 800329a:	1c03      	adds	r3, r0, #0
 800329c:	1c19      	adds	r1, r3, #0
 800329e:	1c20      	adds	r0, r4, #0
 80032a0:	f7fd f8fe 	bl	80004a0 <__aeabi_fadd>
 80032a4:	1c03      	adds	r3, r0, #0
 80032a6:	617b      	str	r3, [r7, #20]
				data_re[match] = data_re[pair] - product_re;
 80032a8:	6afb      	ldr	r3, [r7, #44]	; 0x2c
 80032aa:	009b      	lsls	r3, r3, #2
 80032ac:	68fa      	ldr	r2, [r7, #12]
 80032ae:	18d3      	adds	r3, r2, r3
 80032b0:	6818      	ldr	r0, [r3, #0]
 80032b2:	69fb      	ldr	r3, [r7, #28]
 80032b4:	009b      	lsls	r3, r3, #2
 80032b6:	68fa      	ldr	r2, [r7, #12]
 80032b8:	18d4      	adds	r4, r2, r3
 80032ba:	69b9      	ldr	r1, [r7, #24]
 80032bc:	f7fd fd70 	bl	8000da0 <__aeabi_fsub>
 80032c0:	1c03      	adds	r3, r0, #0
 80032c2:	6023      	str	r3, [r4, #0]
				data_im[match] = data_im[pair] - product_im;
 80032c4:	6afb      	ldr	r3, [r7, #44]	; 0x2c
 80032c6:	009b      	lsls	r3, r3, #2
 80032c8:	68ba      	ldr	r2, [r7, #8]
 80032ca:	18d3      	adds	r3, r2, r3
 80032cc:	6818      	ldr	r0, [r3, #0]
 80032ce:	69fb      	ldr	r3, [r7, #28]
 80032d0:	009b      	lsls	r3, r3, #2
 80032d2:	68ba      	ldr	r2, [r7, #8]
 80032d4:	18d4      	adds	r4, r2, r3
 80032d6:	6979      	ldr	r1, [r7, #20]
 80032d8:	f7fd fd62 	bl	8000da0 <__aeabi_fsub>
 80032dc:	1c03      	adds	r3, r0, #0
 80032de:	6023      	str	r3, [r4, #0]
				data_re[pair] += product_re;
 80032e0:	6afb      	ldr	r3, [r7, #44]	; 0x2c
 80032e2:	009b      	lsls	r3, r3, #2
 80032e4:	68fa      	ldr	r2, [r7, #12]
 80032e6:	18d3      	adds	r3, r2, r3
 80032e8:	6818      	ldr	r0, [r3, #0]
 80032ea:	6afb      	ldr	r3, [r7, #44]	; 0x2c
 80032ec:	009b      	lsls	r3, r3, #2
 80032ee:	68fa      	ldr	r2, [r7, #12]
 80032f0:	18d4      	adds	r4, r2, r3
 80032f2:	69b9      	ldr	r1, [r7, #24]
 80032f4:	f7fd f8d4 	bl	80004a0 <__aeabi_fadd>
 80032f8:	1c03      	adds	r3, r0, #0
 80032fa:	6023      	str	r3, [r4, #0]
				data_im[pair] += product_im;
 80032fc:	6afb      	ldr	r3, [r7, #44]	; 0x2c
 80032fe:	009b      	lsls	r3, r3, #2
 8003300:	68ba      	ldr	r2, [r7, #8]
 8003302:	18d3      	adds	r3, r2, r3
 8003304:	6818      	ldr	r0, [r3, #0]
 8003306:	6afb      	ldr	r3, [r7, #44]	; 0x2c
 8003308:	009b      	lsls	r3, r3, #2
 800330a:	68ba      	ldr	r2, [r7, #8]
 800330c:	18d4      	adds	r4, r2, r3
 800330e:	6979      	ldr	r1, [r7, #20]
 8003310:	f7fd f8c6 	bl	80004a0 <__aeabi_fadd>
 8003314:	1c03      	adds	r3, r0, #0
 8003316:	6023      	str	r3, [r4, #0]
			for (int pair = group; pair < N; pair += jump)
 8003318:	6afa      	ldr	r2, [r7, #44]	; 0x2c
 800331a:	6abb      	ldr	r3, [r7, #40]	; 0x28
 800331c:	18d3      	adds	r3, r2, r3
 800331e:	62fb      	str	r3, [r7, #44]	; 0x2c
 8003320:	6afb      	ldr	r3, [r7, #44]	; 0x2c
 8003322:	687a      	ldr	r2, [r7, #4]
 8003324:	429a      	cmp	r2, r3
 8003326:	d885      	bhi.n	8003234 <ComputeFFT+0x38>
			}
			if ((group + 1) == step)
 8003328:	6b3b      	ldr	r3, [r7, #48]	; 0x30
 800332a:	3301      	adds	r3, #1
 800332c:	6bfa      	ldr	r2, [r7, #60]	; 0x3c
 800332e:	429a      	cmp	r2, r3
 8003330:	d048      	beq.n	80033c4 <ComputeFFT+0x1c8>
				continue;
			float angle = -PI * ((float) group + 1) / step_d;
 8003332:	6b38      	ldr	r0, [r7, #48]	; 0x30
 8003334:	f7fd fefc 	bl	8001130 <__aeabi_i2f>
 8003338:	1c03      	adds	r3, r0, #0
 800333a:	21fe      	movs	r1, #254	; 0xfe
 800333c:	0589      	lsls	r1, r1, #22
 800333e:	1c18      	adds	r0, r3, #0
 8003340:	f7fd f8ae 	bl	80004a0 <__aeabi_fadd>
 8003344:	1c03      	adds	r3, r0, #0
 8003346:	1c18      	adds	r0, r3, #0
 8003348:	f7ff fc2a 	bl	8002ba0 <__aeabi_f2d>
 800334c:	4a28      	ldr	r2, [pc, #160]	; (80033f0 <ComputeFFT+0x1f4>)
 800334e:	4b29      	ldr	r3, [pc, #164]	; (80033f4 <ComputeFFT+0x1f8>)
 8003350:	f7fe fdc2 	bl	8001ed8 <__aeabi_dmul>
 8003354:	0002      	movs	r2, r0
 8003356:	000b      	movs	r3, r1
 8003358:	0014      	movs	r4, r2
 800335a:	001d      	movs	r5, r3
 800335c:	6a78      	ldr	r0, [r7, #36]	; 0x24
 800335e:	f7ff fc1f 	bl	8002ba0 <__aeabi_f2d>
 8003362:	0002      	movs	r2, r0
 8003364:	000b      	movs	r3, r1
 8003366:	0020      	movs	r0, r4
 8003368:	0029      	movs	r1, r5
 800336a:	f7fe facd 	bl	8001908 <__aeabi_ddiv>
 800336e:	0002      	movs	r2, r0
 8003370:	000b      	movs	r3, r1
 8003372:	0010      	movs	r0, r2
 8003374:	0019      	movs	r1, r3
 8003376:	f7ff fc5b 	bl	8002c30 <__aeabi_d2f>
 800337a:	1c03      	adds	r3, r0, #0
 800337c:	623b      	str	r3, [r7, #32]
			twiddle_re = cos(angle);
 800337e:	6a38      	ldr	r0, [r7, #32]
 8003380:	f7ff fc0e 	bl	8002ba0 <__aeabi_f2d>
 8003384:	0002      	movs	r2, r0
 8003386:	000b      	movs	r3, r1
 8003388:	0010      	movs	r0, r2
 800338a:	0019      	movs	r1, r3
 800338c:	f009 f850 	bl	800c430 <cos>
 8003390:	0002      	movs	r2, r0
 8003392:	000b      	movs	r3, r1
 8003394:	0010      	movs	r0, r2
 8003396:	0019      	movs	r1, r3
 8003398:	f7ff fc4a 	bl	8002c30 <__aeabi_d2f>
 800339c:	1c03      	adds	r3, r0, #0
 800339e:	63bb      	str	r3, [r7, #56]	; 0x38
			twiddle_im = sin(angle);
 80033a0:	6a38      	ldr	r0, [r7, #32]
 80033a2:	f7ff fbfd 	bl	8002ba0 <__aeabi_f2d>
 80033a6:	0002      	movs	r2, r0
 80033a8:	000b      	movs	r3, r1
 80033aa:	0010      	movs	r0, r2
 80033ac:	0019      	movs	r1, r3
 80033ae:	f009 f881 	bl	800c4b4 <sin>
 80033b2:	0002      	movs	r2, r0
 80033b4:	000b      	movs	r3, r1
 80033b6:	0010      	movs	r0, r2
 80033b8:	0019      	movs	r1, r3
 80033ba:	f7ff fc39 	bl	8002c30 <__aeabi_d2f>
 80033be:	1c03      	adds	r3, r0, #0
 80033c0:	637b      	str	r3, [r7, #52]	; 0x34
 80033c2:	e000      	b.n	80033c6 <ComputeFFT+0x1ca>
				continue;
 80033c4:	46c0      	nop			; (mov r8, r8)
		for (int group = 0; group < step; group++)
 80033c6:	6b3b      	ldr	r3, [r7, #48]	; 0x30
 80033c8:	3301      	adds	r3, #1
 80033ca:	633b      	str	r3, [r7, #48]	; 0x30
 80033cc:	6b3a      	ldr	r2, [r7, #48]	; 0x30
 80033ce:	6bfb      	ldr	r3, [r7, #60]	; 0x3c
 80033d0:	429a      	cmp	r2, r3
 80033d2:	da00      	bge.n	80033d6 <ComputeFFT+0x1da>
 80033d4:	e72b      	b.n	800322e <ComputeFFT+0x32>
	for (int step = 1; step < N; step <<= 1)
 80033d6:	6bfb      	ldr	r3, [r7, #60]	; 0x3c
 80033d8:	005b      	lsls	r3, r3, #1
 80033da:	63fb      	str	r3, [r7, #60]	; 0x3c
 80033dc:	6bfb      	ldr	r3, [r7, #60]	; 0x3c
 80033de:	687a      	ldr	r2, [r7, #4]
 80033e0:	429a      	cmp	r2, r3
 80033e2:	d900      	bls.n	80033e6 <ComputeFFT+0x1ea>
 80033e4:	e713      	b.n	800320e <ComputeFFT+0x12>
		}
	}
}
 80033e6:	46c0      	nop			; (mov r8, r8)
 80033e8:	46c0      	nop			; (mov r8, r8)
 80033ea:	46bd      	mov	sp, r7
 80033ec:	b010      	add	sp, #64	; 0x40
 80033ee:	bdb0      	pop	{r4, r5, r7, pc}
 80033f0:	53c8d4f1 	.word	0x53c8d4f1
 80033f4:	c00921fb 	.word	0xc00921fb

080033f8 <Mag>:

float Mag(float x1, float x2)
{
 80033f8:	b5b0      	push	{r4, r5, r7, lr}
 80033fa:	b082      	sub	sp, #8
 80033fc:	af00      	add	r7, sp, #0
 80033fe:	6078      	str	r0, [r7, #4]
 8003400:	6039      	str	r1, [r7, #0]
	return sqrt(pow(x1, 2) + pow(x2, 2));
 8003402:	6878      	ldr	r0, [r7, #4]
 8003404:	f7ff fbcc 	bl	8002ba0 <__aeabi_f2d>
 8003408:	2200      	movs	r2, #0
 800340a:	2380      	movs	r3, #128	; 0x80
 800340c:	05db      	lsls	r3, r3, #23
 800340e:	f009 f897 	bl	800c540 <pow>
 8003412:	0004      	movs	r4, r0
 8003414:	000d      	movs	r5, r1
 8003416:	6838      	ldr	r0, [r7, #0]
 8003418:	f7ff fbc2 	bl	8002ba0 <__aeabi_f2d>
 800341c:	2200      	movs	r2, #0
 800341e:	2380      	movs	r3, #128	; 0x80
 8003420:	05db      	lsls	r3, r3, #23
 8003422:	f009 f88d 	bl	800c540 <pow>
 8003426:	0002      	movs	r2, r0
 8003428:	000b      	movs	r3, r1
 800342a:	0020      	movs	r0, r4
 800342c:	0029      	movs	r1, r5
 800342e:	f7fd ff01 	bl	8001234 <__aeabi_dadd>
 8003432:	0002      	movs	r2, r0
 8003434:	000b      	movs	r3, r1
 8003436:	0010      	movs	r0, r2
 8003438:	0019      	movs	r1, r3
 800343a:	f009 f939 	bl	800c6b0 <sqrt>
 800343e:	0002      	movs	r2, r0
 8003440:	000b      	movs	r3, r1
 8003442:	0010      	movs	r0, r2
 8003444:	0019      	movs	r1, r3
 8003446:	f7ff fbf3 	bl	8002c30 <__aeabi_d2f>
 800344a:	1c03      	adds	r3, r0, #0
}
 800344c:	1c18      	adds	r0, r3, #0
 800344e:	46bd      	mov	sp, r7
 8003450:	b002      	add	sp, #8
 8003452:	bdb0      	pop	{r4, r5, r7, pc}

08003454 <ArgMax>:

float ArgMax(float* data_re, float* data_im, const unsigned int N, const float samp_freq, bool center)
{
 8003454:	b5b0      	push	{r4, r5, r7, lr}
 8003456:	b08a      	sub	sp, #40	; 0x28
 8003458:	af00      	add	r7, sp, #0
 800345a:	60f8      	str	r0, [r7, #12]
 800345c:	60b9      	str	r1, [r7, #8]
 800345e:	607a      	str	r2, [r7, #4]
 8003460:	603b      	str	r3, [r7, #0]
	float df = samp_freq / N;
 8003462:	6878      	ldr	r0, [r7, #4]
 8003464:	f7fd feaa 	bl	80011bc <__aeabi_ui2f>
 8003468:	1c03      	adds	r3, r0, #0
 800346a:	1c19      	adds	r1, r3, #0
 800346c:	6838      	ldr	r0, [r7, #0]
 800346e:	f7fd f9b3 	bl	80007d8 <__aeabi_fdiv>
 8003472:	1c03      	adds	r3, r0, #0
 8003474:	617b      	str	r3, [r7, #20]
	float vmax = 0.0;
 8003476:	2300      	movs	r3, #0
 8003478:	627b      	str	r3, [r7, #36]	; 0x24
	float fmax = 0.0;
 800347a:	2300      	movs	r3, #0
 800347c:	623b      	str	r3, [r7, #32]
	for (int n = 0; n < N; n++)
 800347e:	2300      	movs	r3, #0
 8003480:	61fb      	str	r3, [r7, #28]
 8003482:	e069      	b.n	8003558 <ArgMax+0x104>
	{
		const float val = Mag(data_re[n], data_im[n]);
 8003484:	69fb      	ldr	r3, [r7, #28]
 8003486:	009b      	lsls	r3, r3, #2
 8003488:	68fa      	ldr	r2, [r7, #12]
 800348a:	18d3      	adds	r3, r2, r3
 800348c:	6818      	ldr	r0, [r3, #0]
 800348e:	69fb      	ldr	r3, [r7, #28]
 8003490:	009b      	lsls	r3, r3, #2
 8003492:	68ba      	ldr	r2, [r7, #8]
 8003494:	18d3      	adds	r3, r2, r3
 8003496:	681b      	ldr	r3, [r3, #0]
 8003498:	1c19      	adds	r1, r3, #0
 800349a:	f7ff ffad 	bl	80033f8 <Mag>
 800349e:	1c03      	adds	r3, r0, #0
 80034a0:	613b      	str	r3, [r7, #16]
		if (val > vmax)
 80034a2:	6a79      	ldr	r1, [r7, #36]	; 0x24
 80034a4:	6938      	ldr	r0, [r7, #16]
 80034a6:	f7fc ffc9 	bl	800043c <__aeabi_fcmpgt>
 80034aa:	1e03      	subs	r3, r0, #0
 80034ac:	d051      	beq.n	8003552 <ArgMax+0xfe>
		{
			vmax = val;
 80034ae:	693b      	ldr	r3, [r7, #16]
 80034b0:	627b      	str	r3, [r7, #36]	; 0x24
			float f = 0.0;
 80034b2:	2300      	movs	r3, #0
 80034b4:	61bb      	str	r3, [r7, #24]
			if (center)
 80034b6:	2338      	movs	r3, #56	; 0x38
 80034b8:	18fb      	adds	r3, r7, r3
 80034ba:	781b      	ldrb	r3, [r3, #0]
 80034bc:	2b00      	cmp	r3, #0
 80034be:	d033      	beq.n	8003528 <ArgMax+0xd4>
				f = (-samp_freq / 2 + n * df) + (df / 2) * (N % 2);
 80034c0:	683b      	ldr	r3, [r7, #0]
 80034c2:	2280      	movs	r2, #128	; 0x80
 80034c4:	0612      	lsls	r2, r2, #24
 80034c6:	4053      	eors	r3, r2
 80034c8:	2180      	movs	r1, #128	; 0x80
 80034ca:	05c9      	lsls	r1, r1, #23
 80034cc:	1c18      	adds	r0, r3, #0
 80034ce:	f7fd f983 	bl	80007d8 <__aeabi_fdiv>
 80034d2:	1c03      	adds	r3, r0, #0
 80034d4:	1c1c      	adds	r4, r3, #0
 80034d6:	69f8      	ldr	r0, [r7, #28]
 80034d8:	f7fd fe2a 	bl	8001130 <__aeabi_i2f>
 80034dc:	1c03      	adds	r3, r0, #0
 80034de:	6979      	ldr	r1, [r7, #20]
 80034e0:	1c18      	adds	r0, r3, #0
 80034e2:	f7fd fb43 	bl	8000b6c <__aeabi_fmul>
 80034e6:	1c03      	adds	r3, r0, #0
 80034e8:	1c19      	adds	r1, r3, #0
 80034ea:	1c20      	adds	r0, r4, #0
 80034ec:	f7fc ffd8 	bl	80004a0 <__aeabi_fadd>
 80034f0:	1c03      	adds	r3, r0, #0
 80034f2:	1c1c      	adds	r4, r3, #0
 80034f4:	2180      	movs	r1, #128	; 0x80
 80034f6:	05c9      	lsls	r1, r1, #23
 80034f8:	6978      	ldr	r0, [r7, #20]
 80034fa:	f7fd f96d 	bl	80007d8 <__aeabi_fdiv>
 80034fe:	1c03      	adds	r3, r0, #0
 8003500:	1c1d      	adds	r5, r3, #0
 8003502:	687b      	ldr	r3, [r7, #4]
 8003504:	2201      	movs	r2, #1
 8003506:	4013      	ands	r3, r2
 8003508:	0018      	movs	r0, r3
 800350a:	f7fd fe57 	bl	80011bc <__aeabi_ui2f>
 800350e:	1c03      	adds	r3, r0, #0
 8003510:	1c19      	adds	r1, r3, #0
 8003512:	1c28      	adds	r0, r5, #0
 8003514:	f7fd fb2a 	bl	8000b6c <__aeabi_fmul>
 8003518:	1c03      	adds	r3, r0, #0
 800351a:	1c19      	adds	r1, r3, #0
 800351c:	1c20      	adds	r0, r4, #0
 800351e:	f7fc ffbf 	bl	80004a0 <__aeabi_fadd>
 8003522:	1c03      	adds	r3, r0, #0
 8003524:	61bb      	str	r3, [r7, #24]
 8003526:	e009      	b.n	800353c <ArgMax+0xe8>
			else
				f = n * df;
 8003528:	69f8      	ldr	r0, [r7, #28]
 800352a:	f7fd fe01 	bl	8001130 <__aeabi_i2f>
 800352e:	1c03      	adds	r3, r0, #0
 8003530:	1c19      	adds	r1, r3, #0
 8003532:	6978      	ldr	r0, [r7, #20]
 8003534:	f7fd fb1a 	bl	8000b6c <__aeabi_fmul>
 8003538:	1c03      	adds	r3, r0, #0
 800353a:	61bb      	str	r3, [r7, #24]
			fmax = (f < 1)? fmax : f;
 800353c:	21fe      	movs	r1, #254	; 0xfe
 800353e:	0589      	lsls	r1, r1, #22
 8003540:	69b8      	ldr	r0, [r7, #24]
 8003542:	f7fc ff67 	bl	8000414 <__aeabi_fcmplt>
 8003546:	1e03      	subs	r3, r0, #0
 8003548:	d001      	beq.n	800354e <ArgMax+0xfa>
 800354a:	6a3b      	ldr	r3, [r7, #32]
 800354c:	e000      	b.n	8003550 <ArgMax+0xfc>
 800354e:	69bb      	ldr	r3, [r7, #24]
 8003550:	623b      	str	r3, [r7, #32]
	for (int n = 0; n < N; n++)
 8003552:	69fb      	ldr	r3, [r7, #28]
 8003554:	3301      	adds	r3, #1
 8003556:	61fb      	str	r3, [r7, #28]
 8003558:	69fb      	ldr	r3, [r7, #28]
 800355a:	687a      	ldr	r2, [r7, #4]
 800355c:	429a      	cmp	r2, r3
 800355e:	d891      	bhi.n	8003484 <ArgMax+0x30>
		}
	}
	return fmax;
 8003560:	6a3b      	ldr	r3, [r7, #32]
}
 8003562:	1c18      	adds	r0, r3, #0
 8003564:	46bd      	mov	sp, r7
 8003566:	b00a      	add	sp, #40	; 0x28
 8003568:	bdb0      	pop	{r4, r5, r7, pc}

0800356a <nano_wait>:
#define LCD_RESET_CLR GPIO_TYPE->BRR=1<<LCD_RESET

//============================================================================
// Wait for n nanoseconds. (Maximum: 4.294 seconds)
//============================================================================
void nano_wait(unsigned int n) {
 800356a:	b580      	push	{r7, lr}
 800356c:	b082      	sub	sp, #8
 800356e:	af00      	add	r7, sp, #0
 8003570:	6078      	str	r0, [r7, #4]
    asm(    "        mov r0,%0\n"
 8003572:	687b      	ldr	r3, [r7, #4]
 8003574:	1c18      	adds	r0, r3, #0

08003576 <repeat>:
 8003576:	3853      	subs	r0, #83	; 0x53
 8003578:	dcfd      	bgt.n	8003576 <repeat>
            "repeat: sub r0,#83\n"
            "        bgt repeat\n" : : "r"(n) : "r0", "cc");
}
 800357a:	46c0      	nop			; (mov r8, r8)
 800357c:	46bd      	mov	sp, r7
 800357e:	b002      	add	sp, #8
 8003580:	bd80      	pop	{r7, pc}
	...

08003584 <LCD_Reset>:

void LCD_Reset(void)
{
 8003584:	b580      	push	{r7, lr}
 8003586:	af00      	add	r7, sp, #0
    // Assert reset
    GPIOA->BRR = 1<<LCD_RESET;
 8003588:	2390      	movs	r3, #144	; 0x90
 800358a:	05db      	lsls	r3, r3, #23
 800358c:	2204      	movs	r2, #4
 800358e:	629a      	str	r2, [r3, #40]	; 0x28
    nano_wait(100000000);
 8003590:	4b07      	ldr	r3, [pc, #28]	; (80035b0 <LCD_Reset+0x2c>)
 8003592:	0018      	movs	r0, r3
 8003594:	f7ff ffe9 	bl	800356a <nano_wait>
    GPIOA->BSRR = 1<<LCD_RESET;
 8003598:	2390      	movs	r3, #144	; 0x90
 800359a:	05db      	lsls	r3, r3, #23
 800359c:	2204      	movs	r2, #4
 800359e:	619a      	str	r2, [r3, #24]
    nano_wait(50000000);
 80035a0:	4b04      	ldr	r3, [pc, #16]	; (80035b4 <LCD_Reset+0x30>)
 80035a2:	0018      	movs	r0, r3
 80035a4:	f7ff ffe1 	bl	800356a <nano_wait>
}
 80035a8:	46c0      	nop			; (mov r8, r8)
 80035aa:	46bd      	mov	sp, r7
 80035ac:	bd80      	pop	{r7, pc}
 80035ae:	46c0      	nop			; (mov r8, r8)
 80035b0:	05f5e100 	.word	0x05f5e100
 80035b4:	02faf080 	.word	0x02faf080

080035b8 <LCD_WR_REG>:

#else /* not SLOW_SPI */

// Write to an LCD "register"
void LCD_WR_REG(uint8_t data)
{
 80035b8:	b580      	push	{r7, lr}
 80035ba:	b082      	sub	sp, #8
 80035bc:	af00      	add	r7, sp, #0
 80035be:	0002      	movs	r2, r0
 80035c0:	1dfb      	adds	r3, r7, #7
 80035c2:	701a      	strb	r2, [r3, #0]
    while((SPI->SR & SPI_SR_BSY) != 0)
 80035c4:	46c0      	nop			; (mov r8, r8)
 80035c6:	4b08      	ldr	r3, [pc, #32]	; (80035e8 <LCD_WR_REG+0x30>)
 80035c8:	689b      	ldr	r3, [r3, #8]
 80035ca:	2280      	movs	r2, #128	; 0x80
 80035cc:	4013      	ands	r3, r2
 80035ce:	d1fa      	bne.n	80035c6 <LCD_WR_REG+0xe>
        ;
    // Don't clear RS until the previous operation is done.
    LCD_RS_CLR;
 80035d0:	2390      	movs	r3, #144	; 0x90
 80035d2:	05db      	lsls	r3, r3, #23
 80035d4:	2208      	movs	r2, #8
 80035d6:	629a      	str	r2, [r3, #40]	; 0x28
    *((uint8_t*)&SPI->DR) = data;
 80035d8:	4a04      	ldr	r2, [pc, #16]	; (80035ec <LCD_WR_REG+0x34>)
 80035da:	1dfb      	adds	r3, r7, #7
 80035dc:	781b      	ldrb	r3, [r3, #0]
 80035de:	7013      	strb	r3, [r2, #0]
}
 80035e0:	46c0      	nop			; (mov r8, r8)
 80035e2:	46bd      	mov	sp, r7
 80035e4:	b002      	add	sp, #8
 80035e6:	bd80      	pop	{r7, pc}
 80035e8:	40013000 	.word	0x40013000
 80035ec:	4001300c 	.word	0x4001300c

080035f0 <LCD_WR_DATA>:

// Write 8-bit data to the LCD
void LCD_WR_DATA(uint8_t data)
{
 80035f0:	b580      	push	{r7, lr}
 80035f2:	b082      	sub	sp, #8
 80035f4:	af00      	add	r7, sp, #0
 80035f6:	0002      	movs	r2, r0
 80035f8:	1dfb      	adds	r3, r7, #7
 80035fa:	701a      	strb	r2, [r3, #0]
    while((SPI->SR & SPI_SR_BSY) != 0)
 80035fc:	46c0      	nop			; (mov r8, r8)
 80035fe:	4b08      	ldr	r3, [pc, #32]	; (8003620 <LCD_WR_DATA+0x30>)
 8003600:	689b      	ldr	r3, [r3, #8]
 8003602:	2280      	movs	r2, #128	; 0x80
 8003604:	4013      	ands	r3, r2
 8003606:	d1fa      	bne.n	80035fe <LCD_WR_DATA+0xe>
        ;
    // Don't set RS until the previous operation is done.
    LCD_RS_SET;
 8003608:	2390      	movs	r3, #144	; 0x90
 800360a:	05db      	lsls	r3, r3, #23
 800360c:	2208      	movs	r2, #8
 800360e:	619a      	str	r2, [r3, #24]
    *((uint8_t*)&SPI->DR) = data;
 8003610:	4a04      	ldr	r2, [pc, #16]	; (8003624 <LCD_WR_DATA+0x34>)
 8003612:	1dfb      	adds	r3, r7, #7
 8003614:	781b      	ldrb	r3, [r3, #0]
 8003616:	7013      	strb	r3, [r2, #0]
}
 8003618:	46c0      	nop			; (mov r8, r8)
 800361a:	46bd      	mov	sp, r7
 800361c:	b002      	add	sp, #8
 800361e:	bd80      	pop	{r7, pc}
 8003620:	40013000 	.word	0x40013000
 8003624:	4001300c 	.word	0x4001300c

08003628 <LCD_WriteData16_Prepare>:

// Prepare to write 16-bit data to the LCD
void LCD_WriteData16_Prepare()
{
 8003628:	b580      	push	{r7, lr}
 800362a:	af00      	add	r7, sp, #0
    LCD_RS_SET;
 800362c:	2390      	movs	r3, #144	; 0x90
 800362e:	05db      	lsls	r3, r3, #23
 8003630:	2208      	movs	r2, #8
 8003632:	619a      	str	r2, [r3, #24]
    SPI->CR2 |= SPI_CR2_DS;
 8003634:	4b04      	ldr	r3, [pc, #16]	; (8003648 <LCD_WriteData16_Prepare+0x20>)
 8003636:	685a      	ldr	r2, [r3, #4]
 8003638:	4b03      	ldr	r3, [pc, #12]	; (8003648 <LCD_WriteData16_Prepare+0x20>)
 800363a:	21f0      	movs	r1, #240	; 0xf0
 800363c:	0109      	lsls	r1, r1, #4
 800363e:	430a      	orrs	r2, r1
 8003640:	605a      	str	r2, [r3, #4]
}
 8003642:	46c0      	nop			; (mov r8, r8)
 8003644:	46bd      	mov	sp, r7
 8003646:	bd80      	pop	{r7, pc}
 8003648:	40013000 	.word	0x40013000

0800364c <LCD_WriteData16>:

// Write 16-bit data
void LCD_WriteData16(u16 data)
{
 800364c:	b580      	push	{r7, lr}
 800364e:	b082      	sub	sp, #8
 8003650:	af00      	add	r7, sp, #0
 8003652:	0002      	movs	r2, r0
 8003654:	1dbb      	adds	r3, r7, #6
 8003656:	801a      	strh	r2, [r3, #0]
    while((SPI->SR & SPI_SR_TXE) == 0)
 8003658:	46c0      	nop			; (mov r8, r8)
 800365a:	4b06      	ldr	r3, [pc, #24]	; (8003674 <LCD_WriteData16+0x28>)
 800365c:	689b      	ldr	r3, [r3, #8]
 800365e:	2202      	movs	r2, #2
 8003660:	4013      	ands	r3, r2
 8003662:	d0fa      	beq.n	800365a <LCD_WriteData16+0xe>
        ;
    SPI->DR = data;
 8003664:	4b03      	ldr	r3, [pc, #12]	; (8003674 <LCD_WriteData16+0x28>)
 8003666:	1dba      	adds	r2, r7, #6
 8003668:	8812      	ldrh	r2, [r2, #0]
 800366a:	60da      	str	r2, [r3, #12]
}
 800366c:	46c0      	nop			; (mov r8, r8)
 800366e:	46bd      	mov	sp, r7
 8003670:	b002      	add	sp, #8
 8003672:	bd80      	pop	{r7, pc}
 8003674:	40013000 	.word	0x40013000

08003678 <LCD_WriteData16_End>:

// Finish writing 16-bit data
void LCD_WriteData16_End()
{
 8003678:	b580      	push	{r7, lr}
 800367a:	af00      	add	r7, sp, #0
    SPI->CR2 &= ~SPI_CR2_DS; // bad value forces it back to 8-bit mode
 800367c:	4b04      	ldr	r3, [pc, #16]	; (8003690 <LCD_WriteData16_End+0x18>)
 800367e:	685a      	ldr	r2, [r3, #4]
 8003680:	4b03      	ldr	r3, [pc, #12]	; (8003690 <LCD_WriteData16_End+0x18>)
 8003682:	4904      	ldr	r1, [pc, #16]	; (8003694 <LCD_WriteData16_End+0x1c>)
 8003684:	400a      	ands	r2, r1
 8003686:	605a      	str	r2, [r3, #4]
}
 8003688:	46c0      	nop			; (mov r8, r8)
 800368a:	46bd      	mov	sp, r7
 800368c:	bd80      	pop	{r7, pc}
 800368e:	46c0      	nop			; (mov r8, r8)
 8003690:	40013000 	.word	0x40013000
 8003694:	fffff0ff 	.word	0xfffff0ff

08003698 <LCD_WriteReg>:
#endif /* not SLOW_SPI */

// Select an LCD "register" and write 8-bit data to it.
void LCD_WriteReg(uint8_t LCD_Reg, uint16_t LCD_RegValue)
{
 8003698:	b580      	push	{r7, lr}
 800369a:	b082      	sub	sp, #8
 800369c:	af00      	add	r7, sp, #0
 800369e:	0002      	movs	r2, r0
 80036a0:	1dfb      	adds	r3, r7, #7
 80036a2:	701a      	strb	r2, [r3, #0]
 80036a4:	1d3b      	adds	r3, r7, #4
 80036a6:	1c0a      	adds	r2, r1, #0
 80036a8:	801a      	strh	r2, [r3, #0]
    LCD_WR_REG(LCD_Reg);
 80036aa:	1dfb      	adds	r3, r7, #7
 80036ac:	781b      	ldrb	r3, [r3, #0]
 80036ae:	0018      	movs	r0, r3
 80036b0:	f7ff ff82 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(LCD_RegValue);
 80036b4:	1d3b      	adds	r3, r7, #4
 80036b6:	881b      	ldrh	r3, [r3, #0]
 80036b8:	b2db      	uxtb	r3, r3
 80036ba:	0018      	movs	r0, r3
 80036bc:	f7ff ff98 	bl	80035f0 <LCD_WR_DATA>
}
 80036c0:	46c0      	nop			; (mov r8, r8)
 80036c2:	46bd      	mov	sp, r7
 80036c4:	b002      	add	sp, #8
 80036c6:	bd80      	pop	{r7, pc}

080036c8 <LCD_WriteRAM_Prepare>:

// Issue the "write RAM" command configured for the display.
void LCD_WriteRAM_Prepare(void)
{
 80036c8:	b580      	push	{r7, lr}
 80036ca:	af00      	add	r7, sp, #0
    LCD_WR_REG(lcddev.wramcmd);
 80036cc:	4b04      	ldr	r3, [pc, #16]	; (80036e0 <LCD_WriteRAM_Prepare+0x18>)
 80036ce:	891b      	ldrh	r3, [r3, #8]
 80036d0:	b2db      	uxtb	r3, r3
 80036d2:	0018      	movs	r0, r3
 80036d4:	f7ff ff70 	bl	80035b8 <LCD_WR_REG>
}
 80036d8:	46c0      	nop			; (mov r8, r8)
 80036da:	46bd      	mov	sp, r7
 80036dc:	bd80      	pop	{r7, pc}
 80036de:	46c0      	nop			; (mov r8, r8)
 80036e0:	20002134 	.word	0x20002134

080036e4 <LCD_direction>:

// Configure the lcddev fields for the display orientation.
void LCD_direction(u8 direction)
{
 80036e4:	b580      	push	{r7, lr}
 80036e6:	b082      	sub	sp, #8
 80036e8:	af00      	add	r7, sp, #0
 80036ea:	0002      	movs	r2, r0
 80036ec:	1dfb      	adds	r3, r7, #7
 80036ee:	701a      	strb	r2, [r3, #0]
    lcddev.setxcmd=0x2A;
 80036f0:	4b25      	ldr	r3, [pc, #148]	; (8003788 <LCD_direction+0xa4>)
 80036f2:	222a      	movs	r2, #42	; 0x2a
 80036f4:	815a      	strh	r2, [r3, #10]
    lcddev.setycmd=0x2B;
 80036f6:	4b24      	ldr	r3, [pc, #144]	; (8003788 <LCD_direction+0xa4>)
 80036f8:	222b      	movs	r2, #43	; 0x2b
 80036fa:	819a      	strh	r2, [r3, #12]
    lcddev.wramcmd=0x2C;
 80036fc:	4b22      	ldr	r3, [pc, #136]	; (8003788 <LCD_direction+0xa4>)
 80036fe:	222c      	movs	r2, #44	; 0x2c
 8003700:	811a      	strh	r2, [r3, #8]
    switch(direction){
 8003702:	1dfb      	adds	r3, r7, #7
 8003704:	781b      	ldrb	r3, [r3, #0]
 8003706:	2b03      	cmp	r3, #3
 8003708:	d02c      	beq.n	8003764 <LCD_direction+0x80>
 800370a:	dc37      	bgt.n	800377c <LCD_direction+0x98>
 800370c:	2b02      	cmp	r3, #2
 800370e:	d01d      	beq.n	800374c <LCD_direction+0x68>
 8003710:	dc34      	bgt.n	800377c <LCD_direction+0x98>
 8003712:	2b00      	cmp	r3, #0
 8003714:	d002      	beq.n	800371c <LCD_direction+0x38>
 8003716:	2b01      	cmp	r3, #1
 8003718:	d00c      	beq.n	8003734 <LCD_direction+0x50>
    case 3:
        lcddev.width=LCD_H;
        lcddev.height=LCD_W;
        LCD_WriteReg(0x36,(1<<3)|(1<<7)|(1<<5));//BGR==1,MY==1,MX==0,MV==1
        break;
    default:break;
 800371a:	e02f      	b.n	800377c <LCD_direction+0x98>
        lcddev.width=LCD_W;
 800371c:	4b1a      	ldr	r3, [pc, #104]	; (8003788 <LCD_direction+0xa4>)
 800371e:	22f0      	movs	r2, #240	; 0xf0
 8003720:	801a      	strh	r2, [r3, #0]
        lcddev.height=LCD_H;
 8003722:	4b19      	ldr	r3, [pc, #100]	; (8003788 <LCD_direction+0xa4>)
 8003724:	22a0      	movs	r2, #160	; 0xa0
 8003726:	0052      	lsls	r2, r2, #1
 8003728:	805a      	strh	r2, [r3, #2]
        LCD_WriteReg(0x36,(1<<3)|(0<<6)|(0<<7));//BGR==1,MY==0,MX==0,MV==0
 800372a:	2108      	movs	r1, #8
 800372c:	2036      	movs	r0, #54	; 0x36
 800372e:	f7ff ffb3 	bl	8003698 <LCD_WriteReg>
        break;
 8003732:	e024      	b.n	800377e <LCD_direction+0x9a>
        lcddev.width=LCD_H;
 8003734:	4b14      	ldr	r3, [pc, #80]	; (8003788 <LCD_direction+0xa4>)
 8003736:	22a0      	movs	r2, #160	; 0xa0
 8003738:	0052      	lsls	r2, r2, #1
 800373a:	801a      	strh	r2, [r3, #0]
        lcddev.height=LCD_W;
 800373c:	4b12      	ldr	r3, [pc, #72]	; (8003788 <LCD_direction+0xa4>)
 800373e:	22f0      	movs	r2, #240	; 0xf0
 8003740:	805a      	strh	r2, [r3, #2]
        LCD_WriteReg(0x36,(1<<3)|(0<<7)|(1<<6)|(1<<5));//BGR==1,MY==1,MX==0,MV==1
 8003742:	2168      	movs	r1, #104	; 0x68
 8003744:	2036      	movs	r0, #54	; 0x36
 8003746:	f7ff ffa7 	bl	8003698 <LCD_WriteReg>
        break;
 800374a:	e018      	b.n	800377e <LCD_direction+0x9a>
        lcddev.width=LCD_W;
 800374c:	4b0e      	ldr	r3, [pc, #56]	; (8003788 <LCD_direction+0xa4>)
 800374e:	22f0      	movs	r2, #240	; 0xf0
 8003750:	801a      	strh	r2, [r3, #0]
        lcddev.height=LCD_H;
 8003752:	4b0d      	ldr	r3, [pc, #52]	; (8003788 <LCD_direction+0xa4>)
 8003754:	22a0      	movs	r2, #160	; 0xa0
 8003756:	0052      	lsls	r2, r2, #1
 8003758:	805a      	strh	r2, [r3, #2]
        LCD_WriteReg(0x36,(1<<3)|(1<<6)|(1<<7));//BGR==1,MY==0,MX==0,MV==0
 800375a:	21c8      	movs	r1, #200	; 0xc8
 800375c:	2036      	movs	r0, #54	; 0x36
 800375e:	f7ff ff9b 	bl	8003698 <LCD_WriteReg>
        break;
 8003762:	e00c      	b.n	800377e <LCD_direction+0x9a>
        lcddev.width=LCD_H;
 8003764:	4b08      	ldr	r3, [pc, #32]	; (8003788 <LCD_direction+0xa4>)
 8003766:	22a0      	movs	r2, #160	; 0xa0
 8003768:	0052      	lsls	r2, r2, #1
 800376a:	801a      	strh	r2, [r3, #0]
        lcddev.height=LCD_W;
 800376c:	4b06      	ldr	r3, [pc, #24]	; (8003788 <LCD_direction+0xa4>)
 800376e:	22f0      	movs	r2, #240	; 0xf0
 8003770:	805a      	strh	r2, [r3, #2]
        LCD_WriteReg(0x36,(1<<3)|(1<<7)|(1<<5));//BGR==1,MY==1,MX==0,MV==1
 8003772:	21a8      	movs	r1, #168	; 0xa8
 8003774:	2036      	movs	r0, #54	; 0x36
 8003776:	f7ff ff8f 	bl	8003698 <LCD_WriteReg>
        break;
 800377a:	e000      	b.n	800377e <LCD_direction+0x9a>
    default:break;
 800377c:	46c0      	nop			; (mov r8, r8)
    }
}
 800377e:	46c0      	nop			; (mov r8, r8)
 8003780:	46bd      	mov	sp, r7
 8003782:	b002      	add	sp, #8
 8003784:	bd80      	pop	{r7, pc}
 8003786:	46c0      	nop			; (mov r8, r8)
 8003788:	20002134 	.word	0x20002134

0800378c <LCD_Init>:

// Do the initialization sequence for the display.
void LCD_Init()
{
 800378c:	b580      	push	{r7, lr}
 800378e:	af00      	add	r7, sp, #0
    LCD_Reset();
 8003790:	f7ff fef8 	bl	8003584 <LCD_Reset>
    // Initialization sequence for 2.2inch ILI9341
    LCD_WR_REG(0xCF);
 8003794:	20cf      	movs	r0, #207	; 0xcf
 8003796:	f7ff ff0f 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x00);
 800379a:	2000      	movs	r0, #0
 800379c:	f7ff ff28 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0xD9); // C1
 80037a0:	20d9      	movs	r0, #217	; 0xd9
 80037a2:	f7ff ff25 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0X30);
 80037a6:	2030      	movs	r0, #48	; 0x30
 80037a8:	f7ff ff22 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0xED);
 80037ac:	20ed      	movs	r0, #237	; 0xed
 80037ae:	f7ff ff03 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x64);
 80037b2:	2064      	movs	r0, #100	; 0x64
 80037b4:	f7ff ff1c 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x03);
 80037b8:	2003      	movs	r0, #3
 80037ba:	f7ff ff19 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0X12);
 80037be:	2012      	movs	r0, #18
 80037c0:	f7ff ff16 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0X81);
 80037c4:	2081      	movs	r0, #129	; 0x81
 80037c6:	f7ff ff13 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0xE8);
 80037ca:	20e8      	movs	r0, #232	; 0xe8
 80037cc:	f7ff fef4 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x85);
 80037d0:	2085      	movs	r0, #133	; 0x85
 80037d2:	f7ff ff0d 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x10);
 80037d6:	2010      	movs	r0, #16
 80037d8:	f7ff ff0a 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x7A);
 80037dc:	207a      	movs	r0, #122	; 0x7a
 80037de:	f7ff ff07 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0xCB);
 80037e2:	20cb      	movs	r0, #203	; 0xcb
 80037e4:	f7ff fee8 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x39);
 80037e8:	2039      	movs	r0, #57	; 0x39
 80037ea:	f7ff ff01 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x2C);
 80037ee:	202c      	movs	r0, #44	; 0x2c
 80037f0:	f7ff fefe 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x00);
 80037f4:	2000      	movs	r0, #0
 80037f6:	f7ff fefb 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x34);
 80037fa:	2034      	movs	r0, #52	; 0x34
 80037fc:	f7ff fef8 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x02);
 8003800:	2002      	movs	r0, #2
 8003802:	f7ff fef5 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0xF7);
 8003806:	20f7      	movs	r0, #247	; 0xf7
 8003808:	f7ff fed6 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x20);
 800380c:	2020      	movs	r0, #32
 800380e:	f7ff feef 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0xEA);
 8003812:	20ea      	movs	r0, #234	; 0xea
 8003814:	f7ff fed0 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x00);
 8003818:	2000      	movs	r0, #0
 800381a:	f7ff fee9 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x00);
 800381e:	2000      	movs	r0, #0
 8003820:	f7ff fee6 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0xC0);    // Power control
 8003824:	20c0      	movs	r0, #192	; 0xc0
 8003826:	f7ff fec7 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x21);   // VRH[5:0]  //1B
 800382a:	2021      	movs	r0, #33	; 0x21
 800382c:	f7ff fee0 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0xC1);    // Power control
 8003830:	20c1      	movs	r0, #193	; 0xc1
 8003832:	f7ff fec1 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x12);   // SAP[2:0];BT[3:0] //01
 8003836:	2012      	movs	r0, #18
 8003838:	f7ff feda 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0xC5);    // VCM control
 800383c:	20c5      	movs	r0, #197	; 0xc5
 800383e:	f7ff febb 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x39);   // 3F
 8003842:	2039      	movs	r0, #57	; 0x39
 8003844:	f7ff fed4 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x37);   // 3C
 8003848:	2037      	movs	r0, #55	; 0x37
 800384a:	f7ff fed1 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0xC7);    // VCM control2
 800384e:	20c7      	movs	r0, #199	; 0xc7
 8003850:	f7ff feb2 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0XAB);   // B0
 8003854:	20ab      	movs	r0, #171	; 0xab
 8003856:	f7ff fecb 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0x36);    // Memory Access Control
 800385a:	2036      	movs	r0, #54	; 0x36
 800385c:	f7ff feac 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x48);
 8003860:	2048      	movs	r0, #72	; 0x48
 8003862:	f7ff fec5 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0x3A);
 8003866:	203a      	movs	r0, #58	; 0x3a
 8003868:	f7ff fea6 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x55);
 800386c:	2055      	movs	r0, #85	; 0x55
 800386e:	f7ff febf 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0xB1);
 8003872:	20b1      	movs	r0, #177	; 0xb1
 8003874:	f7ff fea0 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x00);
 8003878:	2000      	movs	r0, #0
 800387a:	f7ff feb9 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x1B);   // 1A
 800387e:	201b      	movs	r0, #27
 8003880:	f7ff feb6 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0xB6);    // Display Function Control
 8003884:	20b6      	movs	r0, #182	; 0xb6
 8003886:	f7ff fe97 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x0A);
 800388a:	200a      	movs	r0, #10
 800388c:	f7ff feb0 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0xA2);
 8003890:	20a2      	movs	r0, #162	; 0xa2
 8003892:	f7ff fead 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0xF2);    // 3Gamma Function Disable
 8003896:	20f2      	movs	r0, #242	; 0xf2
 8003898:	f7ff fe8e 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x00);
 800389c:	2000      	movs	r0, #0
 800389e:	f7ff fea7 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0x26);    // Gamma curve selected
 80038a2:	2026      	movs	r0, #38	; 0x26
 80038a4:	f7ff fe88 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x01);
 80038a8:	2001      	movs	r0, #1
 80038aa:	f7ff fea1 	bl	80035f0 <LCD_WR_DATA>

    LCD_WR_REG(0xE0);     // Set Gamma
 80038ae:	20e0      	movs	r0, #224	; 0xe0
 80038b0:	f7ff fe82 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x0F);
 80038b4:	200f      	movs	r0, #15
 80038b6:	f7ff fe9b 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x23);
 80038ba:	2023      	movs	r0, #35	; 0x23
 80038bc:	f7ff fe98 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x1F);
 80038c0:	201f      	movs	r0, #31
 80038c2:	f7ff fe95 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x0B);
 80038c6:	200b      	movs	r0, #11
 80038c8:	f7ff fe92 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x0E);
 80038cc:	200e      	movs	r0, #14
 80038ce:	f7ff fe8f 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x08);
 80038d2:	2008      	movs	r0, #8
 80038d4:	f7ff fe8c 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x4B);
 80038d8:	204b      	movs	r0, #75	; 0x4b
 80038da:	f7ff fe89 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0XA8);
 80038de:	20a8      	movs	r0, #168	; 0xa8
 80038e0:	f7ff fe86 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x3B);
 80038e4:	203b      	movs	r0, #59	; 0x3b
 80038e6:	f7ff fe83 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x0A);
 80038ea:	200a      	movs	r0, #10
 80038ec:	f7ff fe80 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x14);
 80038f0:	2014      	movs	r0, #20
 80038f2:	f7ff fe7d 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x06);
 80038f6:	2006      	movs	r0, #6
 80038f8:	f7ff fe7a 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x10);
 80038fc:	2010      	movs	r0, #16
 80038fe:	f7ff fe77 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x09);
 8003902:	2009      	movs	r0, #9
 8003904:	f7ff fe74 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x00);
 8003908:	2000      	movs	r0, #0
 800390a:	f7ff fe71 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0XE1);      // Set Gamma
 800390e:	20e1      	movs	r0, #225	; 0xe1
 8003910:	f7ff fe52 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x00);
 8003914:	2000      	movs	r0, #0
 8003916:	f7ff fe6b 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x1C);
 800391a:	201c      	movs	r0, #28
 800391c:	f7ff fe68 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x20);
 8003920:	2020      	movs	r0, #32
 8003922:	f7ff fe65 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x04);
 8003926:	2004      	movs	r0, #4
 8003928:	f7ff fe62 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x10);
 800392c:	2010      	movs	r0, #16
 800392e:	f7ff fe5f 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x08);
 8003932:	2008      	movs	r0, #8
 8003934:	f7ff fe5c 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x34);
 8003938:	2034      	movs	r0, #52	; 0x34
 800393a:	f7ff fe59 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x47);
 800393e:	2047      	movs	r0, #71	; 0x47
 8003940:	f7ff fe56 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x44);
 8003944:	2044      	movs	r0, #68	; 0x44
 8003946:	f7ff fe53 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x05);
 800394a:	2005      	movs	r0, #5
 800394c:	f7ff fe50 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x0B);
 8003950:	200b      	movs	r0, #11
 8003952:	f7ff fe4d 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x09);
 8003956:	2009      	movs	r0, #9
 8003958:	f7ff fe4a 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x2F);
 800395c:	202f      	movs	r0, #47	; 0x2f
 800395e:	f7ff fe47 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x36);
 8003962:	2036      	movs	r0, #54	; 0x36
 8003964:	f7ff fe44 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x0F);
 8003968:	200f      	movs	r0, #15
 800396a:	f7ff fe41 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0x2B);
 800396e:	202b      	movs	r0, #43	; 0x2b
 8003970:	f7ff fe22 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x00);
 8003974:	2000      	movs	r0, #0
 8003976:	f7ff fe3b 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x00);
 800397a:	2000      	movs	r0, #0
 800397c:	f7ff fe38 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x01);
 8003980:	2001      	movs	r0, #1
 8003982:	f7ff fe35 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x3f);
 8003986:	203f      	movs	r0, #63	; 0x3f
 8003988:	f7ff fe32 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0x2A);
 800398c:	202a      	movs	r0, #42	; 0x2a
 800398e:	f7ff fe13 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(0x00);
 8003992:	2000      	movs	r0, #0
 8003994:	f7ff fe2c 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x00);
 8003998:	2000      	movs	r0, #0
 800399a:	f7ff fe29 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x00);
 800399e:	2000      	movs	r0, #0
 80039a0:	f7ff fe26 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0xef);
 80039a4:	20ef      	movs	r0, #239	; 0xef
 80039a6:	f7ff fe23 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_REG(0x11);     // Exit Sleep
 80039aa:	2011      	movs	r0, #17
 80039ac:	f7ff fe04 	bl	80035b8 <LCD_WR_REG>
    nano_wait(120000000); // Wait 120 ms
 80039b0:	4b06      	ldr	r3, [pc, #24]	; (80039cc <LCD_Init+0x240>)
 80039b2:	0018      	movs	r0, r3
 80039b4:	f7ff fdd9 	bl	800356a <nano_wait>
    LCD_WR_REG(0x29);     // Display on
 80039b8:	2029      	movs	r0, #41	; 0x29
 80039ba:	f7ff fdfd 	bl	80035b8 <LCD_WR_REG>

    LCD_direction(USE_HORIZONTAL);
 80039be:	2000      	movs	r0, #0
 80039c0:	f7ff fe90 	bl	80036e4 <LCD_direction>
}
 80039c4:	46c0      	nop			; (mov r8, r8)
 80039c6:	46bd      	mov	sp, r7
 80039c8:	bd80      	pop	{r7, pc}
 80039ca:	46c0      	nop			; (mov r8, r8)
 80039cc:	07270e00 	.word	0x07270e00

080039d0 <LCD_Clear>:

//===========================================================================
// Set the entire display to one color
//===========================================================================
void LCD_Clear(u16 Color)
{
 80039d0:	b580      	push	{r7, lr}
 80039d2:	b084      	sub	sp, #16
 80039d4:	af00      	add	r7, sp, #0
 80039d6:	0002      	movs	r2, r0
 80039d8:	1dbb      	adds	r3, r7, #6
 80039da:	801a      	strh	r2, [r3, #0]
    unsigned int i,m;
    LCD_SetWindow(0,0,lcddev.width-1,lcddev.height-1);
 80039dc:	4b17      	ldr	r3, [pc, #92]	; (8003a3c <LCD_Clear+0x6c>)
 80039de:	881b      	ldrh	r3, [r3, #0]
 80039e0:	1e5a      	subs	r2, r3, #1
 80039e2:	4b16      	ldr	r3, [pc, #88]	; (8003a3c <LCD_Clear+0x6c>)
 80039e4:	885b      	ldrh	r3, [r3, #2]
 80039e6:	3b01      	subs	r3, #1
 80039e8:	2100      	movs	r1, #0
 80039ea:	2000      	movs	r0, #0
 80039ec:	f000 f828 	bl	8003a40 <LCD_SetWindow>
    LCD_WriteData16_Prepare();
 80039f0:	f7ff fe1a 	bl	8003628 <LCD_WriteData16_Prepare>
    for(i=0;i<lcddev.height;i++)
 80039f4:	2300      	movs	r3, #0
 80039f6:	60fb      	str	r3, [r7, #12]
 80039f8:	e013      	b.n	8003a22 <LCD_Clear+0x52>
    {
        for(m=0;m<lcddev.width;m++)
 80039fa:	2300      	movs	r3, #0
 80039fc:	60bb      	str	r3, [r7, #8]
 80039fe:	e007      	b.n	8003a10 <LCD_Clear+0x40>
        {
            LCD_WriteData16(Color);
 8003a00:	1dbb      	adds	r3, r7, #6
 8003a02:	881b      	ldrh	r3, [r3, #0]
 8003a04:	0018      	movs	r0, r3
 8003a06:	f7ff fe21 	bl	800364c <LCD_WriteData16>
        for(m=0;m<lcddev.width;m++)
 8003a0a:	68bb      	ldr	r3, [r7, #8]
 8003a0c:	3301      	adds	r3, #1
 8003a0e:	60bb      	str	r3, [r7, #8]
 8003a10:	4b0a      	ldr	r3, [pc, #40]	; (8003a3c <LCD_Clear+0x6c>)
 8003a12:	881b      	ldrh	r3, [r3, #0]
 8003a14:	001a      	movs	r2, r3
 8003a16:	68bb      	ldr	r3, [r7, #8]
 8003a18:	4293      	cmp	r3, r2
 8003a1a:	d3f1      	bcc.n	8003a00 <LCD_Clear+0x30>
    for(i=0;i<lcddev.height;i++)
 8003a1c:	68fb      	ldr	r3, [r7, #12]
 8003a1e:	3301      	adds	r3, #1
 8003a20:	60fb      	str	r3, [r7, #12]
 8003a22:	4b06      	ldr	r3, [pc, #24]	; (8003a3c <LCD_Clear+0x6c>)
 8003a24:	885b      	ldrh	r3, [r3, #2]
 8003a26:	001a      	movs	r2, r3
 8003a28:	68fb      	ldr	r3, [r7, #12]
 8003a2a:	4293      	cmp	r3, r2
 8003a2c:	d3e5      	bcc.n	80039fa <LCD_Clear+0x2a>
        }
    }
    LCD_WriteData16_End();
 8003a2e:	f7ff fe23 	bl	8003678 <LCD_WriteData16_End>
}
 8003a32:	46c0      	nop			; (mov r8, r8)
 8003a34:	46bd      	mov	sp, r7
 8003a36:	b004      	add	sp, #16
 8003a38:	bd80      	pop	{r7, pc}
 8003a3a:	46c0      	nop			; (mov r8, r8)
 8003a3c:	20002134 	.word	0x20002134

08003a40 <LCD_SetWindow>:
//===========================================================================
// Select a subset of the display to work on, and issue the "Write RAM"
// command to prepare to send pixel data to it.
//===========================================================================
void LCD_SetWindow(uint16_t xStart, uint16_t yStart, uint16_t xEnd, uint16_t yEnd)
{
 8003a40:	b5b0      	push	{r4, r5, r7, lr}
 8003a42:	b082      	sub	sp, #8
 8003a44:	af00      	add	r7, sp, #0
 8003a46:	0005      	movs	r5, r0
 8003a48:	000c      	movs	r4, r1
 8003a4a:	0010      	movs	r0, r2
 8003a4c:	0019      	movs	r1, r3
 8003a4e:	1dbb      	adds	r3, r7, #6
 8003a50:	1c2a      	adds	r2, r5, #0
 8003a52:	801a      	strh	r2, [r3, #0]
 8003a54:	1d3b      	adds	r3, r7, #4
 8003a56:	1c22      	adds	r2, r4, #0
 8003a58:	801a      	strh	r2, [r3, #0]
 8003a5a:	1cbb      	adds	r3, r7, #2
 8003a5c:	1c02      	adds	r2, r0, #0
 8003a5e:	801a      	strh	r2, [r3, #0]
 8003a60:	003b      	movs	r3, r7
 8003a62:	1c0a      	adds	r2, r1, #0
 8003a64:	801a      	strh	r2, [r3, #0]
    LCD_WR_REG(lcddev.setxcmd);
 8003a66:	4b25      	ldr	r3, [pc, #148]	; (8003afc <LCD_SetWindow+0xbc>)
 8003a68:	895b      	ldrh	r3, [r3, #10]
 8003a6a:	b2db      	uxtb	r3, r3
 8003a6c:	0018      	movs	r0, r3
 8003a6e:	f7ff fda3 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(xStart>>8);
 8003a72:	1dbb      	adds	r3, r7, #6
 8003a74:	881b      	ldrh	r3, [r3, #0]
 8003a76:	0a1b      	lsrs	r3, r3, #8
 8003a78:	b29b      	uxth	r3, r3
 8003a7a:	b2db      	uxtb	r3, r3
 8003a7c:	0018      	movs	r0, r3
 8003a7e:	f7ff fdb7 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x00FF&xStart);
 8003a82:	1dbb      	adds	r3, r7, #6
 8003a84:	881b      	ldrh	r3, [r3, #0]
 8003a86:	b2db      	uxtb	r3, r3
 8003a88:	0018      	movs	r0, r3
 8003a8a:	f7ff fdb1 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(xEnd>>8);
 8003a8e:	1cbb      	adds	r3, r7, #2
 8003a90:	881b      	ldrh	r3, [r3, #0]
 8003a92:	0a1b      	lsrs	r3, r3, #8
 8003a94:	b29b      	uxth	r3, r3
 8003a96:	b2db      	uxtb	r3, r3
 8003a98:	0018      	movs	r0, r3
 8003a9a:	f7ff fda9 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x00FF&xEnd);
 8003a9e:	1cbb      	adds	r3, r7, #2
 8003aa0:	881b      	ldrh	r3, [r3, #0]
 8003aa2:	b2db      	uxtb	r3, r3
 8003aa4:	0018      	movs	r0, r3
 8003aa6:	f7ff fda3 	bl	80035f0 <LCD_WR_DATA>

    LCD_WR_REG(lcddev.setycmd);
 8003aaa:	4b14      	ldr	r3, [pc, #80]	; (8003afc <LCD_SetWindow+0xbc>)
 8003aac:	899b      	ldrh	r3, [r3, #12]
 8003aae:	b2db      	uxtb	r3, r3
 8003ab0:	0018      	movs	r0, r3
 8003ab2:	f7ff fd81 	bl	80035b8 <LCD_WR_REG>
    LCD_WR_DATA(yStart>>8);
 8003ab6:	1d3b      	adds	r3, r7, #4
 8003ab8:	881b      	ldrh	r3, [r3, #0]
 8003aba:	0a1b      	lsrs	r3, r3, #8
 8003abc:	b29b      	uxth	r3, r3
 8003abe:	b2db      	uxtb	r3, r3
 8003ac0:	0018      	movs	r0, r3
 8003ac2:	f7ff fd95 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x00FF&yStart);
 8003ac6:	1d3b      	adds	r3, r7, #4
 8003ac8:	881b      	ldrh	r3, [r3, #0]
 8003aca:	b2db      	uxtb	r3, r3
 8003acc:	0018      	movs	r0, r3
 8003ace:	f7ff fd8f 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(yEnd>>8);
 8003ad2:	003b      	movs	r3, r7
 8003ad4:	881b      	ldrh	r3, [r3, #0]
 8003ad6:	0a1b      	lsrs	r3, r3, #8
 8003ad8:	b29b      	uxth	r3, r3
 8003ada:	b2db      	uxtb	r3, r3
 8003adc:	0018      	movs	r0, r3
 8003ade:	f7ff fd87 	bl	80035f0 <LCD_WR_DATA>
    LCD_WR_DATA(0x00FF&yEnd);
 8003ae2:	003b      	movs	r3, r7
 8003ae4:	881b      	ldrh	r3, [r3, #0]
 8003ae6:	b2db      	uxtb	r3, r3
 8003ae8:	0018      	movs	r0, r3
 8003aea:	f7ff fd81 	bl	80035f0 <LCD_WR_DATA>

    LCD_WriteRAM_Prepare();
 8003aee:	f7ff fdeb 	bl	80036c8 <LCD_WriteRAM_Prepare>
}
 8003af2:	46c0      	nop			; (mov r8, r8)
 8003af4:	46bd      	mov	sp, r7
 8003af6:	b002      	add	sp, #8
 8003af8:	bdb0      	pop	{r4, r5, r7, pc}
 8003afa:	46c0      	nop			; (mov r8, r8)
 8003afc:	20002134 	.word	0x20002134

08003b00 <LCD_DrawPoint>:

//===========================================================================
// Draw a single dot of color c at (x,y)
//===========================================================================
void LCD_DrawPoint(u16 x, u16 y, u16 c)
{
 8003b00:	b590      	push	{r4, r7, lr}
 8003b02:	b083      	sub	sp, #12
 8003b04:	af00      	add	r7, sp, #0
 8003b06:	0004      	movs	r4, r0
 8003b08:	0008      	movs	r0, r1
 8003b0a:	0011      	movs	r1, r2
 8003b0c:	1dbb      	adds	r3, r7, #6
 8003b0e:	1c22      	adds	r2, r4, #0
 8003b10:	801a      	strh	r2, [r3, #0]
 8003b12:	1d3b      	adds	r3, r7, #4
 8003b14:	1c02      	adds	r2, r0, #0
 8003b16:	801a      	strh	r2, [r3, #0]
 8003b18:	1cbb      	adds	r3, r7, #2
 8003b1a:	1c0a      	adds	r2, r1, #0
 8003b1c:	801a      	strh	r2, [r3, #0]
    LCD_SetWindow(x,y,x,y);
 8003b1e:	1d3b      	adds	r3, r7, #4
 8003b20:	881c      	ldrh	r4, [r3, #0]
 8003b22:	1dbb      	adds	r3, r7, #6
 8003b24:	881a      	ldrh	r2, [r3, #0]
 8003b26:	1d3b      	adds	r3, r7, #4
 8003b28:	8819      	ldrh	r1, [r3, #0]
 8003b2a:	1dbb      	adds	r3, r7, #6
 8003b2c:	8818      	ldrh	r0, [r3, #0]
 8003b2e:	0023      	movs	r3, r4
 8003b30:	f7ff ff86 	bl	8003a40 <LCD_SetWindow>
    LCD_WriteData16_Prepare();
 8003b34:	f7ff fd78 	bl	8003628 <LCD_WriteData16_Prepare>
    LCD_WriteData16(c);
 8003b38:	1cbb      	adds	r3, r7, #2
 8003b3a:	881b      	ldrh	r3, [r3, #0]
 8003b3c:	0018      	movs	r0, r3
 8003b3e:	f7ff fd85 	bl	800364c <LCD_WriteData16>
    LCD_WriteData16_End();
 8003b42:	f7ff fd99 	bl	8003678 <LCD_WriteData16_End>
}
 8003b46:	46c0      	nop			; (mov r8, r8)
 8003b48:	46bd      	mov	sp, r7
 8003b4a:	b003      	add	sp, #12
 8003b4c:	bd90      	pop	{r4, r7, pc}
	...

08003b50 <LCD_DrawChar>:
// num is the ASCII character number
// size is the height of the character (either 12 or 16)
// When mode is set, the background will be transparent.
//===========================================================================
void LCD_DrawChar(u16 x,u16 y,u16 fc, u16 bc, char num, u8 size, u8 mode)
{
 8003b50:	b5b0      	push	{r4, r5, r7, lr}
 8003b52:	b084      	sub	sp, #16
 8003b54:	af00      	add	r7, sp, #0
 8003b56:	0005      	movs	r5, r0
 8003b58:	000c      	movs	r4, r1
 8003b5a:	0010      	movs	r0, r2
 8003b5c:	0019      	movs	r1, r3
 8003b5e:	1dbb      	adds	r3, r7, #6
 8003b60:	1c2a      	adds	r2, r5, #0
 8003b62:	801a      	strh	r2, [r3, #0]
 8003b64:	1d3b      	adds	r3, r7, #4
 8003b66:	1c22      	adds	r2, r4, #0
 8003b68:	801a      	strh	r2, [r3, #0]
 8003b6a:	1cbb      	adds	r3, r7, #2
 8003b6c:	1c02      	adds	r2, r0, #0
 8003b6e:	801a      	strh	r2, [r3, #0]
 8003b70:	003b      	movs	r3, r7
 8003b72:	1c0a      	adds	r2, r1, #0
 8003b74:	801a      	strh	r2, [r3, #0]
    u8 temp;
    u8 pos,t;
    num=num-' ';
 8003b76:	2220      	movs	r2, #32
 8003b78:	18bb      	adds	r3, r7, r2
 8003b7a:	18ba      	adds	r2, r7, r2
 8003b7c:	7812      	ldrb	r2, [r2, #0]
 8003b7e:	3a20      	subs	r2, #32
 8003b80:	701a      	strb	r2, [r3, #0]
    LCD_SetWindow(x,y,x+size/2-1,y+size-1);
 8003b82:	2124      	movs	r1, #36	; 0x24
 8003b84:	187b      	adds	r3, r7, r1
 8003b86:	781b      	ldrb	r3, [r3, #0]
 8003b88:	085b      	lsrs	r3, r3, #1
 8003b8a:	b2db      	uxtb	r3, r3
 8003b8c:	b29a      	uxth	r2, r3
 8003b8e:	1dbb      	adds	r3, r7, #6
 8003b90:	881b      	ldrh	r3, [r3, #0]
 8003b92:	18d3      	adds	r3, r2, r3
 8003b94:	b29b      	uxth	r3, r3
 8003b96:	3b01      	subs	r3, #1
 8003b98:	b29c      	uxth	r4, r3
 8003b9a:	187b      	adds	r3, r7, r1
 8003b9c:	781b      	ldrb	r3, [r3, #0]
 8003b9e:	b29a      	uxth	r2, r3
 8003ba0:	1d3b      	adds	r3, r7, #4
 8003ba2:	881b      	ldrh	r3, [r3, #0]
 8003ba4:	18d3      	adds	r3, r2, r3
 8003ba6:	b29b      	uxth	r3, r3
 8003ba8:	3b01      	subs	r3, #1
 8003baa:	b29a      	uxth	r2, r3
 8003bac:	1d3b      	adds	r3, r7, #4
 8003bae:	8819      	ldrh	r1, [r3, #0]
 8003bb0:	1dbb      	adds	r3, r7, #6
 8003bb2:	8818      	ldrh	r0, [r3, #0]
 8003bb4:	0013      	movs	r3, r2
 8003bb6:	0022      	movs	r2, r4
 8003bb8:	f7ff ff42 	bl	8003a40 <LCD_SetWindow>
    if (!mode) {
 8003bbc:	2328      	movs	r3, #40	; 0x28
 8003bbe:	18fb      	adds	r3, r7, r3
 8003bc0:	781b      	ldrb	r3, [r3, #0]
 8003bc2:	2b00      	cmp	r3, #0
 8003bc4:	d166      	bne.n	8003c94 <LCD_DrawChar+0x144>
        LCD_WriteData16_Prepare();
 8003bc6:	f7ff fd2f 	bl	8003628 <LCD_WriteData16_Prepare>
        for(pos=0;pos<size;pos++) {
 8003bca:	230e      	movs	r3, #14
 8003bcc:	18fb      	adds	r3, r7, r3
 8003bce:	2200      	movs	r2, #0
 8003bd0:	701a      	strb	r2, [r3, #0]
 8003bd2:	e054      	b.n	8003c7e <LCD_DrawChar+0x12e>
            if (size==12)
 8003bd4:	2324      	movs	r3, #36	; 0x24
 8003bd6:	18fb      	adds	r3, r7, r3
 8003bd8:	781b      	ldrb	r3, [r3, #0]
 8003bda:	2b0c      	cmp	r3, #12
 8003bdc:	d110      	bne.n	8003c00 <LCD_DrawChar+0xb0>
                temp=asc2_1206[num][pos];
 8003bde:	2320      	movs	r3, #32
 8003be0:	18fb      	adds	r3, r7, r3
 8003be2:	781a      	ldrb	r2, [r3, #0]
 8003be4:	230e      	movs	r3, #14
 8003be6:	18fb      	adds	r3, r7, r3
 8003be8:	7818      	ldrb	r0, [r3, #0]
 8003bea:	230f      	movs	r3, #15
 8003bec:	18f9      	adds	r1, r7, r3
 8003bee:	4c61      	ldr	r4, [pc, #388]	; (8003d74 <LCD_DrawChar+0x224>)
 8003bf0:	0013      	movs	r3, r2
 8003bf2:	005b      	lsls	r3, r3, #1
 8003bf4:	189b      	adds	r3, r3, r2
 8003bf6:	009b      	lsls	r3, r3, #2
 8003bf8:	18e3      	adds	r3, r4, r3
 8003bfa:	5c1b      	ldrb	r3, [r3, r0]
 8003bfc:	700b      	strb	r3, [r1, #0]
 8003bfe:	e00c      	b.n	8003c1a <LCD_DrawChar+0xca>
            else
                temp=asc2_1608[num][pos];
 8003c00:	2320      	movs	r3, #32
 8003c02:	18fb      	adds	r3, r7, r3
 8003c04:	7819      	ldrb	r1, [r3, #0]
 8003c06:	230e      	movs	r3, #14
 8003c08:	18fb      	adds	r3, r7, r3
 8003c0a:	781a      	ldrb	r2, [r3, #0]
 8003c0c:	230f      	movs	r3, #15
 8003c0e:	18fb      	adds	r3, r7, r3
 8003c10:	4859      	ldr	r0, [pc, #356]	; (8003d78 <LCD_DrawChar+0x228>)
 8003c12:	0109      	lsls	r1, r1, #4
 8003c14:	1841      	adds	r1, r0, r1
 8003c16:	5c8a      	ldrb	r2, [r1, r2]
 8003c18:	701a      	strb	r2, [r3, #0]
            for (t=0;t<size/2;t++) {
 8003c1a:	230d      	movs	r3, #13
 8003c1c:	18fb      	adds	r3, r7, r3
 8003c1e:	2200      	movs	r2, #0
 8003c20:	701a      	strb	r2, [r3, #0]
 8003c22:	e01c      	b.n	8003c5e <LCD_DrawChar+0x10e>
                if (temp&0x01)
 8003c24:	230f      	movs	r3, #15
 8003c26:	18fb      	adds	r3, r7, r3
 8003c28:	781b      	ldrb	r3, [r3, #0]
 8003c2a:	2201      	movs	r2, #1
 8003c2c:	4013      	ands	r3, r2
 8003c2e:	d005      	beq.n	8003c3c <LCD_DrawChar+0xec>
                    LCD_WriteData16(fc);
 8003c30:	1cbb      	adds	r3, r7, #2
 8003c32:	881b      	ldrh	r3, [r3, #0]
 8003c34:	0018      	movs	r0, r3
 8003c36:	f7ff fd09 	bl	800364c <LCD_WriteData16>
 8003c3a:	e004      	b.n	8003c46 <LCD_DrawChar+0xf6>
                else
                    LCD_WriteData16(bc);
 8003c3c:	003b      	movs	r3, r7
 8003c3e:	881b      	ldrh	r3, [r3, #0]
 8003c40:	0018      	movs	r0, r3
 8003c42:	f7ff fd03 	bl	800364c <LCD_WriteData16>
                temp>>=1;
 8003c46:	220f      	movs	r2, #15
 8003c48:	18bb      	adds	r3, r7, r2
 8003c4a:	18ba      	adds	r2, r7, r2
 8003c4c:	7812      	ldrb	r2, [r2, #0]
 8003c4e:	0852      	lsrs	r2, r2, #1
 8003c50:	701a      	strb	r2, [r3, #0]
            for (t=0;t<size/2;t++) {
 8003c52:	210d      	movs	r1, #13
 8003c54:	187b      	adds	r3, r7, r1
 8003c56:	781a      	ldrb	r2, [r3, #0]
 8003c58:	187b      	adds	r3, r7, r1
 8003c5a:	3201      	adds	r2, #1
 8003c5c:	701a      	strb	r2, [r3, #0]
 8003c5e:	2324      	movs	r3, #36	; 0x24
 8003c60:	18fb      	adds	r3, r7, r3
 8003c62:	781b      	ldrb	r3, [r3, #0]
 8003c64:	085b      	lsrs	r3, r3, #1
 8003c66:	b2db      	uxtb	r3, r3
 8003c68:	220d      	movs	r2, #13
 8003c6a:	18ba      	adds	r2, r7, r2
 8003c6c:	7812      	ldrb	r2, [r2, #0]
 8003c6e:	429a      	cmp	r2, r3
 8003c70:	d3d8      	bcc.n	8003c24 <LCD_DrawChar+0xd4>
        for(pos=0;pos<size;pos++) {
 8003c72:	210e      	movs	r1, #14
 8003c74:	187b      	adds	r3, r7, r1
 8003c76:	781a      	ldrb	r2, [r3, #0]
 8003c78:	187b      	adds	r3, r7, r1
 8003c7a:	3201      	adds	r2, #1
 8003c7c:	701a      	strb	r2, [r3, #0]
 8003c7e:	230e      	movs	r3, #14
 8003c80:	18fa      	adds	r2, r7, r3
 8003c82:	2324      	movs	r3, #36	; 0x24
 8003c84:	18fb      	adds	r3, r7, r3
 8003c86:	7812      	ldrb	r2, [r2, #0]
 8003c88:	781b      	ldrb	r3, [r3, #0]
 8003c8a:	429a      	cmp	r2, r3
 8003c8c:	d3a2      	bcc.n	8003bd4 <LCD_DrawChar+0x84>

            }
        }
        LCD_WriteData16_End();
 8003c8e:	f7ff fcf3 	bl	8003678 <LCD_WriteData16_End>
                    LCD_DrawPoint(x+t,y+pos,fc);
                temp>>=1;
            }
        }
    }
}
 8003c92:	e06b      	b.n	8003d6c <LCD_DrawChar+0x21c>
        for(pos=0;pos<size;pos++)
 8003c94:	230e      	movs	r3, #14
 8003c96:	18fb      	adds	r3, r7, r3
 8003c98:	2200      	movs	r2, #0
 8003c9a:	701a      	strb	r2, [r3, #0]
 8003c9c:	e05e      	b.n	8003d5c <LCD_DrawChar+0x20c>
            if (size==12)
 8003c9e:	2324      	movs	r3, #36	; 0x24
 8003ca0:	18fb      	adds	r3, r7, r3
 8003ca2:	781b      	ldrb	r3, [r3, #0]
 8003ca4:	2b0c      	cmp	r3, #12
 8003ca6:	d110      	bne.n	8003cca <LCD_DrawChar+0x17a>
                temp=asc2_1206[num][pos];
 8003ca8:	2320      	movs	r3, #32
 8003caa:	18fb      	adds	r3, r7, r3
 8003cac:	781a      	ldrb	r2, [r3, #0]
 8003cae:	230e      	movs	r3, #14
 8003cb0:	18fb      	adds	r3, r7, r3
 8003cb2:	7818      	ldrb	r0, [r3, #0]
 8003cb4:	230f      	movs	r3, #15
 8003cb6:	18f9      	adds	r1, r7, r3
 8003cb8:	4c2e      	ldr	r4, [pc, #184]	; (8003d74 <LCD_DrawChar+0x224>)
 8003cba:	0013      	movs	r3, r2
 8003cbc:	005b      	lsls	r3, r3, #1
 8003cbe:	189b      	adds	r3, r3, r2
 8003cc0:	009b      	lsls	r3, r3, #2
 8003cc2:	18e3      	adds	r3, r4, r3
 8003cc4:	5c1b      	ldrb	r3, [r3, r0]
 8003cc6:	700b      	strb	r3, [r1, #0]
 8003cc8:	e00c      	b.n	8003ce4 <LCD_DrawChar+0x194>
                temp=asc2_1608[num][pos];
 8003cca:	2320      	movs	r3, #32
 8003ccc:	18fb      	adds	r3, r7, r3
 8003cce:	7819      	ldrb	r1, [r3, #0]
 8003cd0:	230e      	movs	r3, #14
 8003cd2:	18fb      	adds	r3, r7, r3
 8003cd4:	781a      	ldrb	r2, [r3, #0]
 8003cd6:	230f      	movs	r3, #15
 8003cd8:	18fb      	adds	r3, r7, r3
 8003cda:	4827      	ldr	r0, [pc, #156]	; (8003d78 <LCD_DrawChar+0x228>)
 8003cdc:	0109      	lsls	r1, r1, #4
 8003cde:	1841      	adds	r1, r0, r1
 8003ce0:	5c8a      	ldrb	r2, [r1, r2]
 8003ce2:	701a      	strb	r2, [r3, #0]
            for (t=0;t<size/2;t++)
 8003ce4:	230d      	movs	r3, #13
 8003ce6:	18fb      	adds	r3, r7, r3
 8003ce8:	2200      	movs	r2, #0
 8003cea:	701a      	strb	r2, [r3, #0]
 8003cec:	e026      	b.n	8003d3c <LCD_DrawChar+0x1ec>
                if(temp&0x01)
 8003cee:	230f      	movs	r3, #15
 8003cf0:	18fb      	adds	r3, r7, r3
 8003cf2:	781b      	ldrb	r3, [r3, #0]
 8003cf4:	2201      	movs	r2, #1
 8003cf6:	4013      	ands	r3, r2
 8003cf8:	d014      	beq.n	8003d24 <LCD_DrawChar+0x1d4>
                    LCD_DrawPoint(x+t,y+pos,fc);
 8003cfa:	230d      	movs	r3, #13
 8003cfc:	18fb      	adds	r3, r7, r3
 8003cfe:	781b      	ldrb	r3, [r3, #0]
 8003d00:	b29a      	uxth	r2, r3
 8003d02:	1dbb      	adds	r3, r7, #6
 8003d04:	881b      	ldrh	r3, [r3, #0]
 8003d06:	18d3      	adds	r3, r2, r3
 8003d08:	b298      	uxth	r0, r3
 8003d0a:	230e      	movs	r3, #14
 8003d0c:	18fb      	adds	r3, r7, r3
 8003d0e:	781b      	ldrb	r3, [r3, #0]
 8003d10:	b29a      	uxth	r2, r3
 8003d12:	1d3b      	adds	r3, r7, #4
 8003d14:	881b      	ldrh	r3, [r3, #0]
 8003d16:	18d3      	adds	r3, r2, r3
 8003d18:	b299      	uxth	r1, r3
 8003d1a:	1cbb      	adds	r3, r7, #2
 8003d1c:	881b      	ldrh	r3, [r3, #0]
 8003d1e:	001a      	movs	r2, r3
 8003d20:	f7ff feee 	bl	8003b00 <LCD_DrawPoint>
                temp>>=1;
 8003d24:	220f      	movs	r2, #15
 8003d26:	18bb      	adds	r3, r7, r2
 8003d28:	18ba      	adds	r2, r7, r2
 8003d2a:	7812      	ldrb	r2, [r2, #0]
 8003d2c:	0852      	lsrs	r2, r2, #1
 8003d2e:	701a      	strb	r2, [r3, #0]
            for (t=0;t<size/2;t++)
 8003d30:	210d      	movs	r1, #13
 8003d32:	187b      	adds	r3, r7, r1
 8003d34:	781a      	ldrb	r2, [r3, #0]
 8003d36:	187b      	adds	r3, r7, r1
 8003d38:	3201      	adds	r2, #1
 8003d3a:	701a      	strb	r2, [r3, #0]
 8003d3c:	2324      	movs	r3, #36	; 0x24
 8003d3e:	18fb      	adds	r3, r7, r3
 8003d40:	781b      	ldrb	r3, [r3, #0]
 8003d42:	085b      	lsrs	r3, r3, #1
 8003d44:	b2db      	uxtb	r3, r3
 8003d46:	220d      	movs	r2, #13
 8003d48:	18ba      	adds	r2, r7, r2
 8003d4a:	7812      	ldrb	r2, [r2, #0]
 8003d4c:	429a      	cmp	r2, r3
 8003d4e:	d3ce      	bcc.n	8003cee <LCD_DrawChar+0x19e>
        for(pos=0;pos<size;pos++)
 8003d50:	210e      	movs	r1, #14
 8003d52:	187b      	adds	r3, r7, r1
 8003d54:	781a      	ldrb	r2, [r3, #0]
 8003d56:	187b      	adds	r3, r7, r1
 8003d58:	3201      	adds	r2, #1
 8003d5a:	701a      	strb	r2, [r3, #0]
 8003d5c:	230e      	movs	r3, #14
 8003d5e:	18fa      	adds	r2, r7, r3
 8003d60:	2324      	movs	r3, #36	; 0x24
 8003d62:	18fb      	adds	r3, r7, r3
 8003d64:	7812      	ldrb	r2, [r2, #0]
 8003d66:	781b      	ldrb	r3, [r3, #0]
 8003d68:	429a      	cmp	r2, r3
 8003d6a:	d398      	bcc.n	8003c9e <LCD_DrawChar+0x14e>
}
 8003d6c:	46c0      	nop			; (mov r8, r8)
 8003d6e:	46bd      	mov	sp, r7
 8003d70:	b004      	add	sp, #16
 8003d72:	bdb0      	pop	{r4, r5, r7, pc}
 8003d74:	0800e640 	.word	0x0800e640
 8003d78:	0800eab4 	.word	0x0800eab4

08003d7c <LCD_DrawString>:
// p is the pointer to the string.
// size is the height of the character (either 12 or 16)
// When mode is set, the background will be transparent.
//===========================================================================
void LCD_DrawString(u16 x,u16 y, u16 fc, u16 bg, const char *p, u8 size, u8 mode)
{
 8003d7c:	b5f0      	push	{r4, r5, r6, r7, lr}
 8003d7e:	b087      	sub	sp, #28
 8003d80:	af04      	add	r7, sp, #16
 8003d82:	0005      	movs	r5, r0
 8003d84:	000c      	movs	r4, r1
 8003d86:	0010      	movs	r0, r2
 8003d88:	0019      	movs	r1, r3
 8003d8a:	1dbb      	adds	r3, r7, #6
 8003d8c:	1c2a      	adds	r2, r5, #0
 8003d8e:	801a      	strh	r2, [r3, #0]
 8003d90:	1d3b      	adds	r3, r7, #4
 8003d92:	1c22      	adds	r2, r4, #0
 8003d94:	801a      	strh	r2, [r3, #0]
 8003d96:	1cbb      	adds	r3, r7, #2
 8003d98:	1c02      	adds	r2, r0, #0
 8003d9a:	801a      	strh	r2, [r3, #0]
 8003d9c:	003b      	movs	r3, r7
 8003d9e:	1c0a      	adds	r2, r1, #0
 8003da0:	801a      	strh	r2, [r3, #0]
    while((*p<='~')&&(*p>=' '))
 8003da2:	e036      	b.n	8003e12 <LCD_DrawString+0x96>
    {
        if(x>(lcddev.width-1)||y>(lcddev.height-1))
 8003da4:	4b21      	ldr	r3, [pc, #132]	; (8003e2c <LCD_DrawString+0xb0>)
 8003da6:	881b      	ldrh	r3, [r3, #0]
 8003da8:	1dba      	adds	r2, r7, #6
 8003daa:	8812      	ldrh	r2, [r2, #0]
 8003dac:	429a      	cmp	r2, r3
 8003dae:	d239      	bcs.n	8003e24 <LCD_DrawString+0xa8>
 8003db0:	4b1e      	ldr	r3, [pc, #120]	; (8003e2c <LCD_DrawString+0xb0>)
 8003db2:	885b      	ldrh	r3, [r3, #2]
 8003db4:	1d3a      	adds	r2, r7, #4
 8003db6:	8812      	ldrh	r2, [r2, #0]
 8003db8:	429a      	cmp	r2, r3
 8003dba:	d233      	bcs.n	8003e24 <LCD_DrawString+0xa8>
        return;
        LCD_DrawChar(x,y,fc,bg,*p,size,mode);
 8003dbc:	6a3b      	ldr	r3, [r7, #32]
 8003dbe:	781b      	ldrb	r3, [r3, #0]
 8003dc0:	003a      	movs	r2, r7
 8003dc2:	8815      	ldrh	r5, [r2, #0]
 8003dc4:	1cba      	adds	r2, r7, #2
 8003dc6:	8814      	ldrh	r4, [r2, #0]
 8003dc8:	1d3a      	adds	r2, r7, #4
 8003dca:	8811      	ldrh	r1, [r2, #0]
 8003dcc:	1dba      	adds	r2, r7, #6
 8003dce:	8810      	ldrh	r0, [r2, #0]
 8003dd0:	2220      	movs	r2, #32
 8003dd2:	2608      	movs	r6, #8
 8003dd4:	46b4      	mov	ip, r6
 8003dd6:	44bc      	add	ip, r7
 8003dd8:	4462      	add	r2, ip
 8003dda:	7812      	ldrb	r2, [r2, #0]
 8003ddc:	9202      	str	r2, [sp, #8]
 8003dde:	261c      	movs	r6, #28
 8003de0:	2208      	movs	r2, #8
 8003de2:	18ba      	adds	r2, r7, r2
 8003de4:	1992      	adds	r2, r2, r6
 8003de6:	7812      	ldrb	r2, [r2, #0]
 8003de8:	9201      	str	r2, [sp, #4]
 8003dea:	9300      	str	r3, [sp, #0]
 8003dec:	002b      	movs	r3, r5
 8003dee:	0022      	movs	r2, r4
 8003df0:	f7ff feae 	bl	8003b50 <LCD_DrawChar>
        x+=size/2;
 8003df4:	2308      	movs	r3, #8
 8003df6:	18fb      	adds	r3, r7, r3
 8003df8:	199b      	adds	r3, r3, r6
 8003dfa:	781b      	ldrb	r3, [r3, #0]
 8003dfc:	085b      	lsrs	r3, r3, #1
 8003dfe:	b2db      	uxtb	r3, r3
 8003e00:	b299      	uxth	r1, r3
 8003e02:	1dbb      	adds	r3, r7, #6
 8003e04:	1dba      	adds	r2, r7, #6
 8003e06:	8812      	ldrh	r2, [r2, #0]
 8003e08:	188a      	adds	r2, r1, r2
 8003e0a:	801a      	strh	r2, [r3, #0]
        p++;
 8003e0c:	6a3b      	ldr	r3, [r7, #32]
 8003e0e:	3301      	adds	r3, #1
 8003e10:	623b      	str	r3, [r7, #32]
    while((*p<='~')&&(*p>=' '))
 8003e12:	6a3b      	ldr	r3, [r7, #32]
 8003e14:	781b      	ldrb	r3, [r3, #0]
 8003e16:	2b7e      	cmp	r3, #126	; 0x7e
 8003e18:	d805      	bhi.n	8003e26 <LCD_DrawString+0xaa>
 8003e1a:	6a3b      	ldr	r3, [r7, #32]
 8003e1c:	781b      	ldrb	r3, [r3, #0]
 8003e1e:	2b1f      	cmp	r3, #31
 8003e20:	d8c0      	bhi.n	8003da4 <LCD_DrawString+0x28>
 8003e22:	e000      	b.n	8003e26 <LCD_DrawString+0xaa>
        return;
 8003e24:	46c0      	nop			; (mov r8, r8)
    }
}
 8003e26:	46bd      	mov	sp, r7
 8003e28:	b003      	add	sp, #12
 8003e2a:	bdf0      	pop	{r4, r5, r6, r7, pc}
 8003e2c:	20002134 	.word	0x20002134

08003e30 <main>:
/**
  * @brief  The application entry point.
  * @retval int
  */
int main(void)
{
 8003e30:	b580      	push	{r7, lr}
 8003e32:	af00      	add	r7, sp, #0
  /* USER CODE END 1 */

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

  /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  HAL_Init();
 8003e34:	f001 fd34 	bl	80058a0 <HAL_Init>
  /* USER CODE BEGIN Init */

  /* USER CODE END Init */

  /* Configure the system clock */
  SystemClock_Config();
 8003e38:	f000 f904 	bl	8004044 <SystemClock_Config>
  /* USER CODE BEGIN SysInit */

  /* USER CODE END SysInit */

  /* Initialize all configured peripherals */
  MX_GPIO_Init();
 8003e3c:	f000 fb4a 	bl	80044d4 <MX_GPIO_Init>
  MX_DMA_Init();
 8003e40:	f000 fb2a 	bl	8004498 <MX_DMA_Init>
  MX_ADC_Init();
 8003e44:	f000 f95c 	bl	8004100 <MX_ADC_Init>
  MX_SPI1_Init();
 8003e48:	f000 f9f4 	bl	8004234 <MX_SPI1_Init>
  MX_TIM1_Init();
 8003e4c:	f000 fa8c 	bl	8004368 <MX_TIM1_Init>
  MX_I2C1_Init();
 8003e50:	f000 f9b0 	bl	80041b4 <MX_I2C1_Init>

  /* USER CODE END 2 */

  /* Infinite loop */
  /* USER CODE BEGIN WHILE */
  HAL_GPIO_WritePin(GPIOB, GPIO_PIN_11, GPIO_PIN_SET);
 8003e54:	2380      	movs	r3, #128	; 0x80
 8003e56:	011b      	lsls	r3, r3, #4
 8003e58:	480c      	ldr	r0, [pc, #48]	; (8003e8c <main+0x5c>)
 8003e5a:	2201      	movs	r2, #1
 8003e5c:	0019      	movs	r1, r3
 8003e5e:	f002 fe02 	bl	8006a66 <HAL_GPIO_WritePin>
  initialize();
 8003e62:	f000 fcbf 	bl	80047e4 <initialize>
  LCD_Init();
 8003e66:	f7ff fc91 	bl	800378c <LCD_Init>
  LCD_Clear(BLUE);
 8003e6a:	201f      	movs	r0, #31
 8003e6c:	f7ff fdb0 	bl	80039d0 <LCD_Clear>
  resetSel();
 8003e70:	f001 f834 	bl	8004edc <resetSel>
  menu_home();
 8003e74:	f000 fdd8 	bl	8004a28 <menu_home>
  auto_tune();
 8003e78:	f000 fc6a 	bl	8004750 <auto_tune>
  HAL_Delay(1000);
 8003e7c:	23fa      	movs	r3, #250	; 0xfa
 8003e7e:	009b      	lsls	r3, r3, #2
 8003e80:	0018      	movs	r0, r3
 8003e82:	f001 fd71 	bl	8005968 <HAL_Delay>
  dspmain();
 8003e86:	f000 f803 	bl	8003e90 <dspmain>
  while(1)
 8003e8a:	e7fe      	b.n	8003e8a <main+0x5a>
 8003e8c:	48000400 	.word	0x48000400

08003e90 <dspmain>:

    /* USER CODE BEGIN 3 */
  /* USER CODE END 3 */
}
int dspmain()
{
 8003e90:	b5f0      	push	{r4, r5, r6, r7, lr}
 8003e92:	4c59      	ldr	r4, [pc, #356]	; (8003ff8 <dspmain+0x168>)
 8003e94:	44a5      	add	sp, r4
 8003e96:	af02      	add	r7, sp, #8
	//printf("--------program start--------\n");

	// define standard mapping
	TuneMap standard;
	standard.E1 = 329.63;
 8003e98:	4958      	ldr	r1, [pc, #352]	; (8003ffc <dspmain+0x16c>)
 8003e9a:	187b      	adds	r3, r7, r1
 8003e9c:	4a58      	ldr	r2, [pc, #352]	; (8004000 <dspmain+0x170>)
 8003e9e:	601a      	str	r2, [r3, #0]
	standard.B = 246.94;
 8003ea0:	187b      	adds	r3, r7, r1
 8003ea2:	4a58      	ldr	r2, [pc, #352]	; (8004004 <dspmain+0x174>)
 8003ea4:	605a      	str	r2, [r3, #4]
	standard.G = 196.00;
 8003ea6:	187b      	adds	r3, r7, r1
 8003ea8:	4a57      	ldr	r2, [pc, #348]	; (8004008 <dspmain+0x178>)
 8003eaa:	609a      	str	r2, [r3, #8]
	standard.D = 146.83;
 8003eac:	187b      	adds	r3, r7, r1
 8003eae:	4a57      	ldr	r2, [pc, #348]	; (800400c <dspmain+0x17c>)
 8003eb0:	60da      	str	r2, [r3, #12]
	standard.A = 110.00;
 8003eb2:	187b      	adds	r3, r7, r1
 8003eb4:	4a56      	ldr	r2, [pc, #344]	; (8004010 <dspmain+0x180>)
 8003eb6:	611a      	str	r2, [r3, #16]
	standard.E2 = 82.41;
 8003eb8:	187b      	adds	r3, r7, r1
 8003eba:	4a56      	ldr	r2, [pc, #344]	; (8004014 <dspmain+0x184>)
 8003ebc:	615a      	str	r2, [r3, #20]
	//printf("fmax = %f\n", fmax);

	//printf("---------program end---------\n");
	LCD_Drawnum(3, 0, 1, &freq, &fmax);
	*/
	bool center = true;
 8003ebe:	4b56      	ldr	r3, [pc, #344]	; (8004018 <dspmain+0x188>)
 8003ec0:	18fb      	adds	r3, r7, r3
 8003ec2:	2201      	movs	r2, #1
 8003ec4:	701a      	strb	r2, [r3, #0]
	float data_re[BUF_LEN] = {0};
 8003ec6:	4b55      	ldr	r3, [pc, #340]	; (800401c <dspmain+0x18c>)
 8003ec8:	4a55      	ldr	r2, [pc, #340]	; (8004020 <dspmain+0x190>)
 8003eca:	4694      	mov	ip, r2
 8003ecc:	44bc      	add	ip, r7
 8003ece:	4463      	add	r3, ip
 8003ed0:	0018      	movs	r0, r3
 8003ed2:	2380      	movs	r3, #128	; 0x80
 8003ed4:	019b      	lsls	r3, r3, #6
 8003ed6:	001a      	movs	r2, r3
 8003ed8:	2100      	movs	r1, #0
 8003eda:	f005 fed1 	bl	8009c80 <memset>
	for(int i =0; i < BUF_LEN; i++)
 8003ede:	2300      	movs	r3, #0
 8003ee0:	4a50      	ldr	r2, [pc, #320]	; (8004024 <dspmain+0x194>)
 8003ee2:	18ba      	adds	r2, r7, r2
 8003ee4:	6013      	str	r3, [r2, #0]
 8003ee6:	e045      	b.n	8003f74 <dspmain+0xe4>
	{
		data_re[i] =(center)? (float) adc_buf[i] * (pow(-1,i)): (float) adc_buf[i];
 8003ee8:	4b4b      	ldr	r3, [pc, #300]	; (8004018 <dspmain+0x188>)
 8003eea:	18fb      	adds	r3, r7, r3
 8003eec:	781b      	ldrb	r3, [r3, #0]
 8003eee:	2b00      	cmp	r3, #0
 8003ef0:	d026      	beq.n	8003f40 <dspmain+0xb0>
 8003ef2:	4b4d      	ldr	r3, [pc, #308]	; (8004028 <dspmain+0x198>)
 8003ef4:	4e4b      	ldr	r6, [pc, #300]	; (8004024 <dspmain+0x194>)
 8003ef6:	19ba      	adds	r2, r7, r6
 8003ef8:	6812      	ldr	r2, [r2, #0]
 8003efa:	0092      	lsls	r2, r2, #2
 8003efc:	58d3      	ldr	r3, [r2, r3]
 8003efe:	0018      	movs	r0, r3
 8003f00:	f7fd f95c 	bl	80011bc <__aeabi_ui2f>
 8003f04:	1c03      	adds	r3, r0, #0
 8003f06:	1c18      	adds	r0, r3, #0
 8003f08:	f7fe fe4a 	bl	8002ba0 <__aeabi_f2d>
 8003f0c:	0004      	movs	r4, r0
 8003f0e:	000d      	movs	r5, r1
 8003f10:	19bb      	adds	r3, r7, r6
 8003f12:	6818      	ldr	r0, [r3, #0]
 8003f14:	f7fe fe14 	bl	8002b40 <__aeabi_i2d>
 8003f18:	0002      	movs	r2, r0
 8003f1a:	000b      	movs	r3, r1
 8003f1c:	2000      	movs	r0, #0
 8003f1e:	4943      	ldr	r1, [pc, #268]	; (800402c <dspmain+0x19c>)
 8003f20:	f008 fb0e 	bl	800c540 <pow>
 8003f24:	0002      	movs	r2, r0
 8003f26:	000b      	movs	r3, r1
 8003f28:	0020      	movs	r0, r4
 8003f2a:	0029      	movs	r1, r5
 8003f2c:	f7fd ffd4 	bl	8001ed8 <__aeabi_dmul>
 8003f30:	0002      	movs	r2, r0
 8003f32:	000b      	movs	r3, r1
 8003f34:	0010      	movs	r0, r2
 8003f36:	0019      	movs	r1, r3
 8003f38:	f7fe fe7a 	bl	8002c30 <__aeabi_d2f>
 8003f3c:	1c03      	adds	r3, r0, #0
 8003f3e:	e009      	b.n	8003f54 <dspmain+0xc4>
 8003f40:	4b39      	ldr	r3, [pc, #228]	; (8004028 <dspmain+0x198>)
 8003f42:	4a38      	ldr	r2, [pc, #224]	; (8004024 <dspmain+0x194>)
 8003f44:	18ba      	adds	r2, r7, r2
 8003f46:	6812      	ldr	r2, [r2, #0]
 8003f48:	0092      	lsls	r2, r2, #2
 8003f4a:	58d3      	ldr	r3, [r2, r3]
 8003f4c:	0018      	movs	r0, r3
 8003f4e:	f7fd f935 	bl	80011bc <__aeabi_ui2f>
 8003f52:	1c03      	adds	r3, r0, #0
 8003f54:	4a31      	ldr	r2, [pc, #196]	; (800401c <dspmain+0x18c>)
 8003f56:	4932      	ldr	r1, [pc, #200]	; (8004020 <dspmain+0x190>)
 8003f58:	468c      	mov	ip, r1
 8003f5a:	44bc      	add	ip, r7
 8003f5c:	4462      	add	r2, ip
 8003f5e:	4831      	ldr	r0, [pc, #196]	; (8004024 <dspmain+0x194>)
 8003f60:	1839      	adds	r1, r7, r0
 8003f62:	6809      	ldr	r1, [r1, #0]
 8003f64:	0089      	lsls	r1, r1, #2
 8003f66:	508b      	str	r3, [r1, r2]
	for(int i =0; i < BUF_LEN; i++)
 8003f68:	0002      	movs	r2, r0
 8003f6a:	18bb      	adds	r3, r7, r2
 8003f6c:	681b      	ldr	r3, [r3, #0]
 8003f6e:	3301      	adds	r3, #1
 8003f70:	18ba      	adds	r2, r7, r2
 8003f72:	6013      	str	r3, [r2, #0]
 8003f74:	4b2b      	ldr	r3, [pc, #172]	; (8004024 <dspmain+0x194>)
 8003f76:	18fb      	adds	r3, r7, r3
 8003f78:	681a      	ldr	r2, [r3, #0]
 8003f7a:	2380      	movs	r3, #128	; 0x80
 8003f7c:	011b      	lsls	r3, r3, #4
 8003f7e:	429a      	cmp	r2, r3
 8003f80:	dbb2      	blt.n	8003ee8 <dspmain+0x58>

	}
	float data_im[BUF_LEN] = {0};
 8003f82:	4b2b      	ldr	r3, [pc, #172]	; (8004030 <dspmain+0x1a0>)
 8003f84:	4a26      	ldr	r2, [pc, #152]	; (8004020 <dspmain+0x190>)
 8003f86:	4694      	mov	ip, r2
 8003f88:	44bc      	add	ip, r7
 8003f8a:	4463      	add	r3, ip
 8003f8c:	0018      	movs	r0, r3
 8003f8e:	2380      	movs	r3, #128	; 0x80
 8003f90:	019b      	lsls	r3, r3, #6
 8003f92:	001a      	movs	r2, r3
 8003f94:	2100      	movs	r1, #0
 8003f96:	f005 fe73 	bl	8009c80 <memset>
	RearrangeFFT(data_re, data_im, BUF_LEN);
 8003f9a:	2380      	movs	r3, #128	; 0x80
 8003f9c:	011a      	lsls	r2, r3, #4
 8003f9e:	2508      	movs	r5, #8
 8003fa0:	1979      	adds	r1, r7, r5
 8003fa2:	4e24      	ldr	r6, [pc, #144]	; (8004034 <dspmain+0x1a4>)
 8003fa4:	19bb      	adds	r3, r7, r6
 8003fa6:	0018      	movs	r0, r3
 8003fa8:	f7ff f8ce 	bl	8003148 <RearrangeFFT>
	ComputeFFT(data_re, data_im, BUF_LEN);
 8003fac:	2380      	movs	r3, #128	; 0x80
 8003fae:	011a      	lsls	r2, r3, #4
 8003fb0:	1979      	adds	r1, r7, r5
 8003fb2:	19bb      	adds	r3, r7, r6
 8003fb4:	0018      	movs	r0, r3
 8003fb6:	f7ff f921 	bl	80031fc <ComputeFFT>
	float fmax = ArgMax(data_re, data_im, BUF_LEN, fs, center);
 8003fba:	4c1f      	ldr	r4, [pc, #124]	; (8004038 <dspmain+0x1a8>)
 8003fbc:	2380      	movs	r3, #128	; 0x80
 8003fbe:	011a      	lsls	r2, r3, #4
 8003fc0:	1979      	adds	r1, r7, r5
 8003fc2:	19b8      	adds	r0, r7, r6
 8003fc4:	4b14      	ldr	r3, [pc, #80]	; (8004018 <dspmain+0x188>)
 8003fc6:	18fb      	adds	r3, r7, r3
 8003fc8:	781b      	ldrb	r3, [r3, #0]
 8003fca:	9300      	str	r3, [sp, #0]
 8003fcc:	1c23      	adds	r3, r4, #0
 8003fce:	f7ff fa41 	bl	8003454 <ArgMax>
 8003fd2:	1c03      	adds	r3, r0, #0
 8003fd4:	607b      	str	r3, [r7, #4]
	float freq = 100.0;
 8003fd6:	4b19      	ldr	r3, [pc, #100]	; (800403c <dspmain+0x1ac>)
 8003fd8:	603b      	str	r3, [r7, #0]
	LCD_Drawnum(3, 0, 1, &freq, &fmax);
 8003fda:	003a      	movs	r2, r7
 8003fdc:	1d3b      	adds	r3, r7, #4
 8003fde:	9300      	str	r3, [sp, #0]
 8003fe0:	0013      	movs	r3, r2
 8003fe2:	2201      	movs	r2, #1
 8003fe4:	2100      	movs	r1, #0
 8003fe6:	2003      	movs	r0, #3
 8003fe8:	f7ff f87c 	bl	80030e4 <LCD_Drawnum>
	return 0;
 8003fec:	2300      	movs	r3, #0
}
 8003fee:	0018      	movs	r0, r3
 8003ff0:	46bd      	mov	sp, r7
 8003ff2:	4b13      	ldr	r3, [pc, #76]	; (8004040 <dspmain+0x1b0>)
 8003ff4:	449d      	add	sp, r3
 8003ff6:	bdf0      	pop	{r4, r5, r6, r7, pc}
 8003ff8:	ffffbfcc 	.word	0xffffbfcc
 8003ffc:	00004008 	.word	0x00004008
 8004000:	43a4d0a4 	.word	0x43a4d0a4
 8004004:	4376f0a4 	.word	0x4376f0a4
 8004008:	43440000 	.word	0x43440000
 800400c:	4312d47b 	.word	0x4312d47b
 8004010:	42dc0000 	.word	0x42dc0000
 8004014:	42a4d1ec 	.word	0x42a4d1ec
 8004018:	00004023 	.word	0x00004023
 800401c:	ffffdfe0 	.word	0xffffdfe0
 8004020:	00004028 	.word	0x00004028
 8004024:	00004024 	.word	0x00004024
 8004028:	2000010c 	.word	0x2000010c
 800402c:	bff00000 	.word	0xbff00000
 8004030:	ffffbfe0 	.word	0xffffbfe0
 8004034:	00002008 	.word	0x00002008
 8004038:	4759038f 	.word	0x4759038f
 800403c:	42c80000 	.word	0x42c80000
 8004040:	0000402c 	.word	0x0000402c

08004044 <SystemClock_Config>:
/**
  * @brief System Clock Configuration
  * @retval None
  */
void SystemClock_Config(void)
{
 8004044:	b590      	push	{r4, r7, lr}
 8004046:	b099      	sub	sp, #100	; 0x64
 8004048:	af00      	add	r7, sp, #0
  RCC_OscInitTypeDef RCC_OscInitStruct = {0};
 800404a:	242c      	movs	r4, #44	; 0x2c
 800404c:	193b      	adds	r3, r7, r4
 800404e:	0018      	movs	r0, r3
 8004050:	2334      	movs	r3, #52	; 0x34
 8004052:	001a      	movs	r2, r3
 8004054:	2100      	movs	r1, #0
 8004056:	f005 fe13 	bl	8009c80 <memset>
  RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
 800405a:	231c      	movs	r3, #28
 800405c:	18fb      	adds	r3, r7, r3
 800405e:	0018      	movs	r0, r3
 8004060:	2310      	movs	r3, #16
 8004062:	001a      	movs	r2, r3
 8004064:	2100      	movs	r1, #0
 8004066:	f005 fe0b 	bl	8009c80 <memset>
  RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
 800406a:	003b      	movs	r3, r7
 800406c:	0018      	movs	r0, r3
 800406e:	231c      	movs	r3, #28
 8004070:	001a      	movs	r2, r3
 8004072:	2100      	movs	r1, #0
 8004074:	f005 fe04 	bl	8009c80 <memset>

  /** Initializes the RCC Oscillators according to the specified parameters
  * in the RCC_OscInitTypeDef structure.
  */
  RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI|RCC_OSCILLATORTYPE_HSI14;
 8004078:	0021      	movs	r1, r4
 800407a:	187b      	adds	r3, r7, r1
 800407c:	2212      	movs	r2, #18
 800407e:	601a      	str	r2, [r3, #0]
  RCC_OscInitStruct.HSIState = RCC_HSI_ON;
 8004080:	187b      	adds	r3, r7, r1
 8004082:	2201      	movs	r2, #1
 8004084:	60da      	str	r2, [r3, #12]
  RCC_OscInitStruct.HSI14State = RCC_HSI14_ON;
 8004086:	187b      	adds	r3, r7, r1
 8004088:	2201      	movs	r2, #1
 800408a:	615a      	str	r2, [r3, #20]
  RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;
 800408c:	187b      	adds	r3, r7, r1
 800408e:	2210      	movs	r2, #16
 8004090:	611a      	str	r2, [r3, #16]
  RCC_OscInitStruct.HSI14CalibrationValue = 16;
 8004092:	187b      	adds	r3, r7, r1
 8004094:	2210      	movs	r2, #16
 8004096:	619a      	str	r2, [r3, #24]
  RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE;
 8004098:	187b      	adds	r3, r7, r1
 800409a:	2200      	movs	r2, #0
 800409c:	625a      	str	r2, [r3, #36]	; 0x24
  if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
 800409e:	187b      	adds	r3, r7, r1
 80040a0:	0018      	movs	r0, r3
 80040a2:	f004 f955 	bl	8008350 <HAL_RCC_OscConfig>
 80040a6:	1e03      	subs	r3, r0, #0
 80040a8:	d001      	beq.n	80040ae <SystemClock_Config+0x6a>
  {
    Error_Handler();
 80040aa:	f000 fb95 	bl	80047d8 <Error_Handler>
  }
  /** Initializes the CPU, AHB and APB buses clocks
  */
  RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
 80040ae:	211c      	movs	r1, #28
 80040b0:	187b      	adds	r3, r7, r1
 80040b2:	2207      	movs	r2, #7
 80040b4:	601a      	str	r2, [r3, #0]
                              |RCC_CLOCKTYPE_PCLK1;
  RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_HSI;
 80040b6:	187b      	adds	r3, r7, r1
 80040b8:	2200      	movs	r2, #0
 80040ba:	605a      	str	r2, [r3, #4]
  RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
 80040bc:	187b      	adds	r3, r7, r1
 80040be:	2200      	movs	r2, #0
 80040c0:	609a      	str	r2, [r3, #8]
  RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
 80040c2:	187b      	adds	r3, r7, r1
 80040c4:	2200      	movs	r2, #0
 80040c6:	60da      	str	r2, [r3, #12]

  if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_0) != HAL_OK)
 80040c8:	187b      	adds	r3, r7, r1
 80040ca:	2100      	movs	r1, #0
 80040cc:	0018      	movs	r0, r3
 80040ce:	f004 fcc5 	bl	8008a5c <HAL_RCC_ClockConfig>
 80040d2:	1e03      	subs	r3, r0, #0
 80040d4:	d001      	beq.n	80040da <SystemClock_Config+0x96>
  {
    Error_Handler();
 80040d6:	f000 fb7f 	bl	80047d8 <Error_Handler>
  }
  PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_I2C1;
 80040da:	003b      	movs	r3, r7
 80040dc:	2220      	movs	r2, #32
 80040de:	601a      	str	r2, [r3, #0]
  PeriphClkInit.I2c1ClockSelection = RCC_I2C1CLKSOURCE_HSI;
 80040e0:	003b      	movs	r3, r7
 80040e2:	2200      	movs	r2, #0
 80040e4:	615a      	str	r2, [r3, #20]
  if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
 80040e6:	003b      	movs	r3, r7
 80040e8:	0018      	movs	r0, r3
 80040ea:	f004 fe11 	bl	8008d10 <HAL_RCCEx_PeriphCLKConfig>
 80040ee:	1e03      	subs	r3, r0, #0
 80040f0:	d001      	beq.n	80040f6 <SystemClock_Config+0xb2>
  {
    Error_Handler();
 80040f2:	f000 fb71 	bl	80047d8 <Error_Handler>
  }
}
 80040f6:	46c0      	nop			; (mov r8, r8)
 80040f8:	46bd      	mov	sp, r7
 80040fa:	b019      	add	sp, #100	; 0x64
 80040fc:	bd90      	pop	{r4, r7, pc}
	...

08004100 <MX_ADC_Init>:
  * @brief ADC Initialization Function
  * @param None
  * @retval None
  */
static void MX_ADC_Init(void)
{
 8004100:	b580      	push	{r7, lr}
 8004102:	b084      	sub	sp, #16
 8004104:	af00      	add	r7, sp, #0

  /* USER CODE BEGIN ADC_Init 0 */

  /* USER CODE END ADC_Init 0 */

  ADC_ChannelConfTypeDef sConfig = {0};
 8004106:	1d3b      	adds	r3, r7, #4
 8004108:	0018      	movs	r0, r3
 800410a:	230c      	movs	r3, #12
 800410c:	001a      	movs	r2, r3
 800410e:	2100      	movs	r1, #0
 8004110:	f005 fdb6 	bl	8009c80 <memset>
  /* USER CODE BEGIN ADC_Init 1 */

  /* USER CODE END ADC_Init 1 */
  /** Configure the global features of the ADC (Clock, Resolution, Data Alignment and number of conversion)
  */
  hadc.Instance = ADC1;
 8004114:	4b25      	ldr	r3, [pc, #148]	; (80041ac <MX_ADC_Init+0xac>)
 8004116:	4a26      	ldr	r2, [pc, #152]	; (80041b0 <MX_ADC_Init+0xb0>)
 8004118:	601a      	str	r2, [r3, #0]
  hadc.Init.ClockPrescaler = ADC_CLOCK_ASYNC_DIV1;
 800411a:	4b24      	ldr	r3, [pc, #144]	; (80041ac <MX_ADC_Init+0xac>)
 800411c:	2200      	movs	r2, #0
 800411e:	605a      	str	r2, [r3, #4]
  hadc.Init.Resolution = ADC_RESOLUTION_12B;
 8004120:	4b22      	ldr	r3, [pc, #136]	; (80041ac <MX_ADC_Init+0xac>)
 8004122:	2200      	movs	r2, #0
 8004124:	609a      	str	r2, [r3, #8]
  hadc.Init.DataAlign = ADC_DATAALIGN_RIGHT;
 8004126:	4b21      	ldr	r3, [pc, #132]	; (80041ac <MX_ADC_Init+0xac>)
 8004128:	2200      	movs	r2, #0
 800412a:	60da      	str	r2, [r3, #12]
  hadc.Init.ScanConvMode = ADC_SCAN_DIRECTION_FORWARD;
 800412c:	4b1f      	ldr	r3, [pc, #124]	; (80041ac <MX_ADC_Init+0xac>)
 800412e:	2201      	movs	r2, #1
 8004130:	611a      	str	r2, [r3, #16]
  hadc.Init.EOCSelection = ADC_EOC_SINGLE_CONV;
 8004132:	4b1e      	ldr	r3, [pc, #120]	; (80041ac <MX_ADC_Init+0xac>)
 8004134:	2204      	movs	r2, #4
 8004136:	615a      	str	r2, [r3, #20]
  hadc.Init.LowPowerAutoWait = DISABLE;
 8004138:	4b1c      	ldr	r3, [pc, #112]	; (80041ac <MX_ADC_Init+0xac>)
 800413a:	2200      	movs	r2, #0
 800413c:	761a      	strb	r2, [r3, #24]
  hadc.Init.LowPowerAutoPowerOff = DISABLE;
 800413e:	4b1b      	ldr	r3, [pc, #108]	; (80041ac <MX_ADC_Init+0xac>)
 8004140:	2200      	movs	r2, #0
 8004142:	765a      	strb	r2, [r3, #25]
  hadc.Init.ContinuousConvMode = ENABLE;
 8004144:	4b19      	ldr	r3, [pc, #100]	; (80041ac <MX_ADC_Init+0xac>)
 8004146:	2201      	movs	r2, #1
 8004148:	769a      	strb	r2, [r3, #26]
  hadc.Init.DiscontinuousConvMode = DISABLE;
 800414a:	4b18      	ldr	r3, [pc, #96]	; (80041ac <MX_ADC_Init+0xac>)
 800414c:	2200      	movs	r2, #0
 800414e:	76da      	strb	r2, [r3, #27]
  hadc.Init.ExternalTrigConv = ADC_SOFTWARE_START;
 8004150:	4b16      	ldr	r3, [pc, #88]	; (80041ac <MX_ADC_Init+0xac>)
 8004152:	22c2      	movs	r2, #194	; 0xc2
 8004154:	32ff      	adds	r2, #255	; 0xff
 8004156:	61da      	str	r2, [r3, #28]
  hadc.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
 8004158:	4b14      	ldr	r3, [pc, #80]	; (80041ac <MX_ADC_Init+0xac>)
 800415a:	2200      	movs	r2, #0
 800415c:	621a      	str	r2, [r3, #32]
  hadc.Init.DMAContinuousRequests = ENABLE;
 800415e:	4b13      	ldr	r3, [pc, #76]	; (80041ac <MX_ADC_Init+0xac>)
 8004160:	2224      	movs	r2, #36	; 0x24
 8004162:	2101      	movs	r1, #1
 8004164:	5499      	strb	r1, [r3, r2]
  hadc.Init.Overrun = ADC_OVR_DATA_PRESERVED;
 8004166:	4b11      	ldr	r3, [pc, #68]	; (80041ac <MX_ADC_Init+0xac>)
 8004168:	2201      	movs	r2, #1
 800416a:	629a      	str	r2, [r3, #40]	; 0x28
  if (HAL_ADC_Init(&hadc) != HAL_OK)
 800416c:	4b0f      	ldr	r3, [pc, #60]	; (80041ac <MX_ADC_Init+0xac>)
 800416e:	0018      	movs	r0, r3
 8004170:	f001 fc1e 	bl	80059b0 <HAL_ADC_Init>
 8004174:	1e03      	subs	r3, r0, #0
 8004176:	d001      	beq.n	800417c <MX_ADC_Init+0x7c>
  {
    Error_Handler();
 8004178:	f000 fb2e 	bl	80047d8 <Error_Handler>
  }
  /** Configure for the selected ADC regular channel to be converted.
  */
  sConfig.Channel = ADC_CHANNEL_0;
 800417c:	1d3b      	adds	r3, r7, #4
 800417e:	2200      	movs	r2, #0
 8004180:	601a      	str	r2, [r3, #0]
  sConfig.Rank = ADC_RANK_CHANNEL_NUMBER;
 8004182:	1d3b      	adds	r3, r7, #4
 8004184:	2280      	movs	r2, #128	; 0x80
 8004186:	0152      	lsls	r2, r2, #5
 8004188:	605a      	str	r2, [r3, #4]
  sConfig.SamplingTime = ADC_SAMPLETIME_239CYCLES_5;
 800418a:	1d3b      	adds	r3, r7, #4
 800418c:	2207      	movs	r2, #7
 800418e:	609a      	str	r2, [r3, #8]
  if (HAL_ADC_ConfigChannel(&hadc, &sConfig) != HAL_OK)
 8004190:	1d3a      	adds	r2, r7, #4
 8004192:	4b06      	ldr	r3, [pc, #24]	; (80041ac <MX_ADC_Init+0xac>)
 8004194:	0011      	movs	r1, r2
 8004196:	0018      	movs	r0, r3
 8004198:	f001 fdd4 	bl	8005d44 <HAL_ADC_ConfigChannel>
 800419c:	1e03      	subs	r3, r0, #0
 800419e:	d001      	beq.n	80041a4 <MX_ADC_Init+0xa4>
  {
    Error_Handler();
 80041a0:	f000 fb1a 	bl	80047d8 <Error_Handler>
  }
  /* USER CODE BEGIN ADC_Init 2 */

  /* USER CODE END ADC_Init 2 */

}
 80041a4:	46c0      	nop			; (mov r8, r8)
 80041a6:	46bd      	mov	sp, r7
 80041a8:	b004      	add	sp, #16
 80041aa:	bd80      	pop	{r7, pc}
 80041ac:	20002294 	.word	0x20002294
 80041b0:	40012400 	.word	0x40012400

080041b4 <MX_I2C1_Init>:
  * @brief I2C1 Initialization Function
  * @param None
  * @retval None
  */
static void MX_I2C1_Init(void)
{
 80041b4:	b580      	push	{r7, lr}
 80041b6:	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;
 80041b8:	4b1b      	ldr	r3, [pc, #108]	; (8004228 <MX_I2C1_Init+0x74>)
 80041ba:	4a1c      	ldr	r2, [pc, #112]	; (800422c <MX_I2C1_Init+0x78>)
 80041bc:	601a      	str	r2, [r3, #0]
  hi2c1.Init.Timing = 0x2000090E;
 80041be:	4b1a      	ldr	r3, [pc, #104]	; (8004228 <MX_I2C1_Init+0x74>)
 80041c0:	4a1b      	ldr	r2, [pc, #108]	; (8004230 <MX_I2C1_Init+0x7c>)
 80041c2:	605a      	str	r2, [r3, #4]
  hi2c1.Init.OwnAddress1 = 0;
 80041c4:	4b18      	ldr	r3, [pc, #96]	; (8004228 <MX_I2C1_Init+0x74>)
 80041c6:	2200      	movs	r2, #0
 80041c8:	609a      	str	r2, [r3, #8]
  hi2c1.Init.AddressingMode = I2C_ADDRESSINGMODE_7BIT;
 80041ca:	4b17      	ldr	r3, [pc, #92]	; (8004228 <MX_I2C1_Init+0x74>)
 80041cc:	2201      	movs	r2, #1
 80041ce:	60da      	str	r2, [r3, #12]
  hi2c1.Init.DualAddressMode = I2C_DUALADDRESS_DISABLE;
 80041d0:	4b15      	ldr	r3, [pc, #84]	; (8004228 <MX_I2C1_Init+0x74>)
 80041d2:	2200      	movs	r2, #0
 80041d4:	611a      	str	r2, [r3, #16]
  hi2c1.Init.OwnAddress2 = 0;
 80041d6:	4b14      	ldr	r3, [pc, #80]	; (8004228 <MX_I2C1_Init+0x74>)
 80041d8:	2200      	movs	r2, #0
 80041da:	615a      	str	r2, [r3, #20]
  hi2c1.Init.OwnAddress2Masks = I2C_OA2_NOMASK;
 80041dc:	4b12      	ldr	r3, [pc, #72]	; (8004228 <MX_I2C1_Init+0x74>)
 80041de:	2200      	movs	r2, #0
 80041e0:	619a      	str	r2, [r3, #24]
  hi2c1.Init.GeneralCallMode = I2C_GENERALCALL_DISABLE;
 80041e2:	4b11      	ldr	r3, [pc, #68]	; (8004228 <MX_I2C1_Init+0x74>)
 80041e4:	2200      	movs	r2, #0
 80041e6:	61da      	str	r2, [r3, #28]
  hi2c1.Init.NoStretchMode = I2C_NOSTRETCH_DISABLE;
 80041e8:	4b0f      	ldr	r3, [pc, #60]	; (8004228 <MX_I2C1_Init+0x74>)
 80041ea:	2200      	movs	r2, #0
 80041ec:	621a      	str	r2, [r3, #32]
  if (HAL_I2C_Init(&hi2c1) != HAL_OK)
 80041ee:	4b0e      	ldr	r3, [pc, #56]	; (8004228 <MX_I2C1_Init+0x74>)
 80041f0:	0018      	movs	r0, r3
 80041f2:	f002 fc71 	bl	8006ad8 <HAL_I2C_Init>
 80041f6:	1e03      	subs	r3, r0, #0
 80041f8:	d001      	beq.n	80041fe <MX_I2C1_Init+0x4a>
  {
    Error_Handler();
 80041fa:	f000 faed 	bl	80047d8 <Error_Handler>
  }
  /** Configure Analogue filter
  */
  if (HAL_I2CEx_ConfigAnalogFilter(&hi2c1, I2C_ANALOGFILTER_ENABLE) != HAL_OK)
 80041fe:	4b0a      	ldr	r3, [pc, #40]	; (8004228 <MX_I2C1_Init+0x74>)
 8004200:	2100      	movs	r1, #0
 8004202:	0018      	movs	r0, r3
 8004204:	f004 f80c 	bl	8008220 <HAL_I2CEx_ConfigAnalogFilter>
 8004208:	1e03      	subs	r3, r0, #0
 800420a:	d001      	beq.n	8004210 <MX_I2C1_Init+0x5c>
  {
    Error_Handler();
 800420c:	f000 fae4 	bl	80047d8 <Error_Handler>
  }
  /** Configure Digital filter
  */
  if (HAL_I2CEx_ConfigDigitalFilter(&hi2c1, 0) != HAL_OK)
 8004210:	4b05      	ldr	r3, [pc, #20]	; (8004228 <MX_I2C1_Init+0x74>)
 8004212:	2100      	movs	r1, #0
 8004214:	0018      	movs	r0, r3
 8004216:	f004 f84f 	bl	80082b8 <HAL_I2CEx_ConfigDigitalFilter>
 800421a:	1e03      	subs	r3, r0, #0
 800421c:	d001      	beq.n	8004222 <MX_I2C1_Init+0x6e>
  {
    Error_Handler();
 800421e:	f000 fadb 	bl	80047d8 <Error_Handler>
  }
  /* USER CODE BEGIN I2C1_Init 2 */

  /* USER CODE END I2C1_Init 2 */

}
 8004222:	46c0      	nop			; (mov r8, r8)
 8004224:	46bd      	mov	sp, r7
 8004226:	bd80      	pop	{r7, pc}
 8004228:	20002148 	.word	0x20002148
 800422c:	40005400 	.word	0x40005400
 8004230:	2000090e 	.word	0x2000090e

08004234 <MX_SPI1_Init>:
  * @brief SPI1 Initialization Function
  * @param None
  * @retval None
  */
static void MX_SPI1_Init(void)
{
 8004234:	b580      	push	{r7, lr}
 8004236:	af00      	add	r7, sp, #0

  /* USER CODE BEGIN SPI1_Init 1 */

  /* USER CODE END SPI1_Init 1 */
  /* SPI1 parameter configuration*/
  hspi1.Instance = SPI1;
 8004238:	4b45      	ldr	r3, [pc, #276]	; (8004350 <MX_SPI1_Init+0x11c>)
 800423a:	4a46      	ldr	r2, [pc, #280]	; (8004354 <MX_SPI1_Init+0x120>)
 800423c:	601a      	str	r2, [r3, #0]
  hspi1.Init.Mode = SPI_MODE_MASTER;
 800423e:	4b44      	ldr	r3, [pc, #272]	; (8004350 <MX_SPI1_Init+0x11c>)
 8004240:	2282      	movs	r2, #130	; 0x82
 8004242:	0052      	lsls	r2, r2, #1
 8004244:	605a      	str	r2, [r3, #4]
  hspi1.Init.Direction = SPI_DIRECTION_2LINES;
 8004246:	4b42      	ldr	r3, [pc, #264]	; (8004350 <MX_SPI1_Init+0x11c>)
 8004248:	2200      	movs	r2, #0
 800424a:	609a      	str	r2, [r3, #8]
  hspi1.Init.DataSize = SPI_DATASIZE_4BIT;
 800424c:	4b40      	ldr	r3, [pc, #256]	; (8004350 <MX_SPI1_Init+0x11c>)
 800424e:	22c0      	movs	r2, #192	; 0xc0
 8004250:	0092      	lsls	r2, r2, #2
 8004252:	60da      	str	r2, [r3, #12]
  hspi1.Init.CLKPolarity = SPI_POLARITY_LOW;
 8004254:	4b3e      	ldr	r3, [pc, #248]	; (8004350 <MX_SPI1_Init+0x11c>)
 8004256:	2200      	movs	r2, #0
 8004258:	611a      	str	r2, [r3, #16]
  hspi1.Init.CLKPhase = SPI_PHASE_1EDGE;
 800425a:	4b3d      	ldr	r3, [pc, #244]	; (8004350 <MX_SPI1_Init+0x11c>)
 800425c:	2200      	movs	r2, #0
 800425e:	615a      	str	r2, [r3, #20]
  hspi1.Init.NSS = SPI_NSS_HARD_OUTPUT;
 8004260:	4b3b      	ldr	r3, [pc, #236]	; (8004350 <MX_SPI1_Init+0x11c>)
 8004262:	2280      	movs	r2, #128	; 0x80
 8004264:	02d2      	lsls	r2, r2, #11
 8004266:	619a      	str	r2, [r3, #24]
  hspi1.Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_2;
 8004268:	4b39      	ldr	r3, [pc, #228]	; (8004350 <MX_SPI1_Init+0x11c>)
 800426a:	2200      	movs	r2, #0
 800426c:	61da      	str	r2, [r3, #28]
  hspi1.Init.FirstBit = SPI_FIRSTBIT_MSB;
 800426e:	4b38      	ldr	r3, [pc, #224]	; (8004350 <MX_SPI1_Init+0x11c>)
 8004270:	2200      	movs	r2, #0
 8004272:	621a      	str	r2, [r3, #32]
  hspi1.Init.TIMode = SPI_TIMODE_DISABLE;
 8004274:	4b36      	ldr	r3, [pc, #216]	; (8004350 <MX_SPI1_Init+0x11c>)
 8004276:	2200      	movs	r2, #0
 8004278:	625a      	str	r2, [r3, #36]	; 0x24
  hspi1.Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;
 800427a:	4b35      	ldr	r3, [pc, #212]	; (8004350 <MX_SPI1_Init+0x11c>)
 800427c:	2200      	movs	r2, #0
 800427e:	629a      	str	r2, [r3, #40]	; 0x28
  hspi1.Init.CRCPolynomial = 7;
 8004280:	4b33      	ldr	r3, [pc, #204]	; (8004350 <MX_SPI1_Init+0x11c>)
 8004282:	2207      	movs	r2, #7
 8004284:	62da      	str	r2, [r3, #44]	; 0x2c
  hspi1.Init.CRCLength = SPI_CRC_LENGTH_DATASIZE;
 8004286:	4b32      	ldr	r3, [pc, #200]	; (8004350 <MX_SPI1_Init+0x11c>)
 8004288:	2200      	movs	r2, #0
 800428a:	631a      	str	r2, [r3, #48]	; 0x30
  hspi1.Init.NSSPMode = SPI_NSS_PULSE_ENABLE;
 800428c:	4b30      	ldr	r3, [pc, #192]	; (8004350 <MX_SPI1_Init+0x11c>)
 800428e:	2208      	movs	r2, #8
 8004290:	635a      	str	r2, [r3, #52]	; 0x34
  if (HAL_SPI_Init(&hspi1) != HAL_OK)
 8004292:	4b2f      	ldr	r3, [pc, #188]	; (8004350 <MX_SPI1_Init+0x11c>)
 8004294:	0018      	movs	r0, r3
 8004296:	f004 fe3b 	bl	8008f10 <HAL_SPI_Init>
 800429a:	1e03      	subs	r3, r0, #0
 800429c:	d001      	beq.n	80042a2 <MX_SPI1_Init+0x6e>
  {
    Error_Handler();
 800429e:	f000 fa9b 	bl	80047d8 <Error_Handler>
  }
  /* USER CODE BEGIN SPI1_Init 2 */

  RCC->AHBENR |= RCC_AHBENR_GPIOAEN;
 80042a2:	4b2d      	ldr	r3, [pc, #180]	; (8004358 <MX_SPI1_Init+0x124>)
 80042a4:	695a      	ldr	r2, [r3, #20]
 80042a6:	4b2c      	ldr	r3, [pc, #176]	; (8004358 <MX_SPI1_Init+0x124>)
 80042a8:	2180      	movs	r1, #128	; 0x80
 80042aa:	0289      	lsls	r1, r1, #10
 80042ac:	430a      	orrs	r2, r1
 80042ae:	615a      	str	r2, [r3, #20]
  GPIOA -> MODER &= ~GPIO_MODER_MODER4 & ~GPIO_MODER_MODER5 & ~GPIO_MODER_MODER7;
 80042b0:	2390      	movs	r3, #144	; 0x90
 80042b2:	05db      	lsls	r3, r3, #23
 80042b4:	681a      	ldr	r2, [r3, #0]
 80042b6:	2390      	movs	r3, #144	; 0x90
 80042b8:	05db      	lsls	r3, r3, #23
 80042ba:	4928      	ldr	r1, [pc, #160]	; (800435c <MX_SPI1_Init+0x128>)
 80042bc:	400a      	ands	r2, r1
 80042be:	601a      	str	r2, [r3, #0]
  GPIOA -> MODER |= GPIO_MODER_MODER4_1 | GPIO_MODER_MODER5_1 | GPIO_MODER_MODER7_1;
 80042c0:	2390      	movs	r3, #144	; 0x90
 80042c2:	05db      	lsls	r3, r3, #23
 80042c4:	681a      	ldr	r2, [r3, #0]
 80042c6:	2390      	movs	r3, #144	; 0x90
 80042c8:	05db      	lsls	r3, r3, #23
 80042ca:	218a      	movs	r1, #138	; 0x8a
 80042cc:	0209      	lsls	r1, r1, #8
 80042ce:	430a      	orrs	r2, r1
 80042d0:	601a      	str	r2, [r3, #0]
  GPIOA -> MODER &= ~GPIO_MODER_MODER2 & ~GPIO_MODER_MODER3;
 80042d2:	2390      	movs	r3, #144	; 0x90
 80042d4:	05db      	lsls	r3, r3, #23
 80042d6:	681a      	ldr	r2, [r3, #0]
 80042d8:	2390      	movs	r3, #144	; 0x90
 80042da:	05db      	lsls	r3, r3, #23
 80042dc:	21f0      	movs	r1, #240	; 0xf0
 80042de:	438a      	bics	r2, r1
 80042e0:	601a      	str	r2, [r3, #0]
  GPIOA -> MODER |= GPIO_MODER_MODER2_0 | GPIO_MODER_MODER3_0;
 80042e2:	2390      	movs	r3, #144	; 0x90
 80042e4:	05db      	lsls	r3, r3, #23
 80042e6:	681a      	ldr	r2, [r3, #0]
 80042e8:	2390      	movs	r3, #144	; 0x90
 80042ea:	05db      	lsls	r3, r3, #23
 80042ec:	2150      	movs	r1, #80	; 0x50
 80042ee:	430a      	orrs	r2, r1
 80042f0:	601a      	str	r2, [r3, #0]
  GPIOA->AFR[0] &= ~GPIO_AFRL_AFRL4 & ~GPIO_AFRL_AFRL5 & ~GPIO_AFRL_AFRL7;
 80042f2:	2390      	movs	r3, #144	; 0x90
 80042f4:	05db      	lsls	r3, r3, #23
 80042f6:	6a1a      	ldr	r2, [r3, #32]
 80042f8:	2390      	movs	r3, #144	; 0x90
 80042fa:	05db      	lsls	r3, r3, #23
 80042fc:	4918      	ldr	r1, [pc, #96]	; (8004360 <MX_SPI1_Init+0x12c>)
 80042fe:	400a      	ands	r2, r1
 8004300:	621a      	str	r2, [r3, #32]

  RCC->APB2ENR |= RCC_APB2ENR_SPI1EN;
 8004302:	4b15      	ldr	r3, [pc, #84]	; (8004358 <MX_SPI1_Init+0x124>)
 8004304:	699a      	ldr	r2, [r3, #24]
 8004306:	4b14      	ldr	r3, [pc, #80]	; (8004358 <MX_SPI1_Init+0x124>)
 8004308:	2180      	movs	r1, #128	; 0x80
 800430a:	0149      	lsls	r1, r1, #5
 800430c:	430a      	orrs	r2, r1
 800430e:	619a      	str	r2, [r3, #24]
  SPI1->CR1 |= SPI_CR1_MSTR | SPI_CR1_BIDIMODE | SPI_CR1_BIDIOE;
 8004310:	4b10      	ldr	r3, [pc, #64]	; (8004354 <MX_SPI1_Init+0x120>)
 8004312:	681a      	ldr	r2, [r3, #0]
 8004314:	4b0f      	ldr	r3, [pc, #60]	; (8004354 <MX_SPI1_Init+0x120>)
 8004316:	4913      	ldr	r1, [pc, #76]	; (8004364 <MX_SPI1_Init+0x130>)
 8004318:	430a      	orrs	r2, r1
 800431a:	601a      	str	r2, [r3, #0]
  SPI1->CR1 &= ~SPI_CR1_BR;
 800431c:	4b0d      	ldr	r3, [pc, #52]	; (8004354 <MX_SPI1_Init+0x120>)
 800431e:	681a      	ldr	r2, [r3, #0]
 8004320:	4b0c      	ldr	r3, [pc, #48]	; (8004354 <MX_SPI1_Init+0x120>)
 8004322:	2138      	movs	r1, #56	; 0x38
 8004324:	438a      	bics	r2, r1
 8004326:	601a      	str	r2, [r3, #0]
  SPI1->CR2 = SPI_CR2_DS_2 | SPI_CR2_DS_1 | SPI_CR2_DS_0;
 8004328:	4b0a      	ldr	r3, [pc, #40]	; (8004354 <MX_SPI1_Init+0x120>)
 800432a:	22e0      	movs	r2, #224	; 0xe0
 800432c:	00d2      	lsls	r2, r2, #3
 800432e:	605a      	str	r2, [r3, #4]
  SPI1->CR2 |= SPI_CR2_NSSP | SPI_CR2_SSOE;
 8004330:	4b08      	ldr	r3, [pc, #32]	; (8004354 <MX_SPI1_Init+0x120>)
 8004332:	685a      	ldr	r2, [r3, #4]
 8004334:	4b07      	ldr	r3, [pc, #28]	; (8004354 <MX_SPI1_Init+0x120>)
 8004336:	210c      	movs	r1, #12
 8004338:	430a      	orrs	r2, r1
 800433a:	605a      	str	r2, [r3, #4]
  SPI1->CR1 |= SPI_CR1_SPE;
 800433c:	4b05      	ldr	r3, [pc, #20]	; (8004354 <MX_SPI1_Init+0x120>)
 800433e:	681a      	ldr	r2, [r3, #0]
 8004340:	4b04      	ldr	r3, [pc, #16]	; (8004354 <MX_SPI1_Init+0x120>)
 8004342:	2140      	movs	r1, #64	; 0x40
 8004344:	430a      	orrs	r2, r1
 8004346:	601a      	str	r2, [r3, #0]

  /* USER CODE END SPI1_Init 2 */

}
 8004348:	46c0      	nop			; (mov r8, r8)
 800434a:	46bd      	mov	sp, r7
 800434c:	bd80      	pop	{r7, pc}
 800434e:	46c0      	nop			; (mov r8, r8)
 8004350:	200021ec 	.word	0x200021ec
 8004354:	40013000 	.word	0x40013000
 8004358:	40021000 	.word	0x40021000
 800435c:	ffff30ff 	.word	0xffff30ff
 8004360:	0f00ffff 	.word	0x0f00ffff
 8004364:	0000c004 	.word	0x0000c004

08004368 <MX_TIM1_Init>:
  * @brief TIM1 Initialization Function
  * @param None
  * @retval None
  */
static void MX_TIM1_Init(void)
{
 8004368:	b580      	push	{r7, lr}
 800436a:	b092      	sub	sp, #72	; 0x48
 800436c:	af00      	add	r7, sp, #0

  /* USER CODE BEGIN TIM1_Init 0 */

  /* USER CODE END TIM1_Init 0 */

  TIM_MasterConfigTypeDef sMasterConfig = {0};
 800436e:	2340      	movs	r3, #64	; 0x40
 8004370:	18fb      	adds	r3, r7, r3
 8004372:	0018      	movs	r0, r3
 8004374:	2308      	movs	r3, #8
 8004376:	001a      	movs	r2, r3
 8004378:	2100      	movs	r1, #0
 800437a:	f005 fc81 	bl	8009c80 <memset>
  TIM_OC_InitTypeDef sConfigOC = {0};
 800437e:	2324      	movs	r3, #36	; 0x24
 8004380:	18fb      	adds	r3, r7, r3
 8004382:	0018      	movs	r0, r3
 8004384:	231c      	movs	r3, #28
 8004386:	001a      	movs	r2, r3
 8004388:	2100      	movs	r1, #0
 800438a:	f005 fc79 	bl	8009c80 <memset>
  TIM_BreakDeadTimeConfigTypeDef sBreakDeadTimeConfig = {0};
 800438e:	1d3b      	adds	r3, r7, #4
 8004390:	0018      	movs	r0, r3
 8004392:	2320      	movs	r3, #32
 8004394:	001a      	movs	r2, r3
 8004396:	2100      	movs	r1, #0
 8004398:	f005 fc72 	bl	8009c80 <memset>

  /* USER CODE BEGIN TIM1_Init 1 */

  /* USER CODE END TIM1_Init 1 */
  htim1.Instance = TIM1;
 800439c:	4b3a      	ldr	r3, [pc, #232]	; (8004488 <MX_TIM1_Init+0x120>)
 800439e:	4a3b      	ldr	r2, [pc, #236]	; (800448c <MX_TIM1_Init+0x124>)
 80043a0:	601a      	str	r2, [r3, #0]
  htim1.Init.Prescaler = 0;
 80043a2:	4b39      	ldr	r3, [pc, #228]	; (8004488 <MX_TIM1_Init+0x120>)
 80043a4:	2200      	movs	r2, #0
 80043a6:	605a      	str	r2, [r3, #4]
  htim1.Init.CounterMode = TIM_COUNTERMODE_UP;
 80043a8:	4b37      	ldr	r3, [pc, #220]	; (8004488 <MX_TIM1_Init+0x120>)
 80043aa:	2200      	movs	r2, #0
 80043ac:	609a      	str	r2, [r3, #8]
  htim1.Init.Period = 7500;
 80043ae:	4b36      	ldr	r3, [pc, #216]	; (8004488 <MX_TIM1_Init+0x120>)
 80043b0:	4a37      	ldr	r2, [pc, #220]	; (8004490 <MX_TIM1_Init+0x128>)
 80043b2:	60da      	str	r2, [r3, #12]
  htim1.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
 80043b4:	4b34      	ldr	r3, [pc, #208]	; (8004488 <MX_TIM1_Init+0x120>)
 80043b6:	2200      	movs	r2, #0
 80043b8:	611a      	str	r2, [r3, #16]
  htim1.Init.RepetitionCounter = 0;
 80043ba:	4b33      	ldr	r3, [pc, #204]	; (8004488 <MX_TIM1_Init+0x120>)
 80043bc:	2200      	movs	r2, #0
 80043be:	615a      	str	r2, [r3, #20]
  htim1.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
 80043c0:	4b31      	ldr	r3, [pc, #196]	; (8004488 <MX_TIM1_Init+0x120>)
 80043c2:	2200      	movs	r2, #0
 80043c4:	619a      	str	r2, [r3, #24]
  if (HAL_TIM_PWM_Init(&htim1) != HAL_OK)
 80043c6:	4b30      	ldr	r3, [pc, #192]	; (8004488 <MX_TIM1_Init+0x120>)
 80043c8:	0018      	movs	r0, r3
 80043ca:	f004 fe59 	bl	8009080 <HAL_TIM_PWM_Init>
 80043ce:	1e03      	subs	r3, r0, #0
 80043d0:	d001      	beq.n	80043d6 <MX_TIM1_Init+0x6e>
  {
    Error_Handler();
 80043d2:	f000 fa01 	bl	80047d8 <Error_Handler>
  }
  sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
 80043d6:	2140      	movs	r1, #64	; 0x40
 80043d8:	187b      	adds	r3, r7, r1
 80043da:	2200      	movs	r2, #0
 80043dc:	601a      	str	r2, [r3, #0]
  sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
 80043de:	187b      	adds	r3, r7, r1
 80043e0:	2200      	movs	r2, #0
 80043e2:	605a      	str	r2, [r3, #4]
  if (HAL_TIMEx_MasterConfigSynchronization(&htim1, &sMasterConfig) != HAL_OK)
 80043e4:	187a      	adds	r2, r7, r1
 80043e6:	4b28      	ldr	r3, [pc, #160]	; (8004488 <MX_TIM1_Init+0x120>)
 80043e8:	0011      	movs	r1, r2
 80043ea:	0018      	movs	r0, r3
 80043ec:	f005 fb32 	bl	8009a54 <HAL_TIMEx_MasterConfigSynchronization>
 80043f0:	1e03      	subs	r3, r0, #0
 80043f2:	d001      	beq.n	80043f8 <MX_TIM1_Init+0x90>
  {
    Error_Handler();
 80043f4:	f000 f9f0 	bl	80047d8 <Error_Handler>
  }
  sConfigOC.OCMode = TIM_OCMODE_PWM1;
 80043f8:	2124      	movs	r1, #36	; 0x24
 80043fa:	187b      	adds	r3, r7, r1
 80043fc:	2260      	movs	r2, #96	; 0x60
 80043fe:	601a      	str	r2, [r3, #0]
  sConfigOC.Pulse = 7500/2;
 8004400:	187b      	adds	r3, r7, r1
 8004402:	4a24      	ldr	r2, [pc, #144]	; (8004494 <MX_TIM1_Init+0x12c>)
 8004404:	605a      	str	r2, [r3, #4]
  sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
 8004406:	187b      	adds	r3, r7, r1
 8004408:	2200      	movs	r2, #0
 800440a:	609a      	str	r2, [r3, #8]
  sConfigOC.OCNPolarity = TIM_OCNPOLARITY_HIGH;
 800440c:	187b      	adds	r3, r7, r1
 800440e:	2200      	movs	r2, #0
 8004410:	60da      	str	r2, [r3, #12]
  sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
 8004412:	187b      	adds	r3, r7, r1
 8004414:	2200      	movs	r2, #0
 8004416:	611a      	str	r2, [r3, #16]
  sConfigOC.OCIdleState = TIM_OCIDLESTATE_RESET;
 8004418:	187b      	adds	r3, r7, r1
 800441a:	2200      	movs	r2, #0
 800441c:	615a      	str	r2, [r3, #20]
  sConfigOC.OCNIdleState = TIM_OCNIDLESTATE_RESET;
 800441e:	187b      	adds	r3, r7, r1
 8004420:	2200      	movs	r2, #0
 8004422:	619a      	str	r2, [r3, #24]
  if (HAL_TIM_PWM_ConfigChannel(&htim1, &sConfigOC, TIM_CHANNEL_1) != HAL_OK)
 8004424:	1879      	adds	r1, r7, r1
 8004426:	4b18      	ldr	r3, [pc, #96]	; (8004488 <MX_TIM1_Init+0x120>)
 8004428:	2200      	movs	r2, #0
 800442a:	0018      	movs	r0, r3
 800442c:	f004 ffac 	bl	8009388 <HAL_TIM_PWM_ConfigChannel>
 8004430:	1e03      	subs	r3, r0, #0
 8004432:	d001      	beq.n	8004438 <MX_TIM1_Init+0xd0>
  {
    Error_Handler();
 8004434:	f000 f9d0 	bl	80047d8 <Error_Handler>
  }
  sBreakDeadTimeConfig.OffStateRunMode = TIM_OSSR_DISABLE;
 8004438:	1d3b      	adds	r3, r7, #4
 800443a:	2200      	movs	r2, #0
 800443c:	601a      	str	r2, [r3, #0]
  sBreakDeadTimeConfig.OffStateIDLEMode = TIM_OSSI_DISABLE;
 800443e:	1d3b      	adds	r3, r7, #4
 8004440:	2200      	movs	r2, #0
 8004442:	605a      	str	r2, [r3, #4]
  sBreakDeadTimeConfig.LockLevel = TIM_LOCKLEVEL_OFF;
 8004444:	1d3b      	adds	r3, r7, #4
 8004446:	2200      	movs	r2, #0
 8004448:	609a      	str	r2, [r3, #8]
  sBreakDeadTimeConfig.DeadTime = 0;
 800444a:	1d3b      	adds	r3, r7, #4
 800444c:	2200      	movs	r2, #0
 800444e:	60da      	str	r2, [r3, #12]
  sBreakDeadTimeConfig.BreakState = TIM_BREAK_DISABLE;
 8004450:	1d3b      	adds	r3, r7, #4
 8004452:	2200      	movs	r2, #0
 8004454:	611a      	str	r2, [r3, #16]
  sBreakDeadTimeConfig.BreakPolarity = TIM_BREAKPOLARITY_HIGH;
 8004456:	1d3b      	adds	r3, r7, #4
 8004458:	2280      	movs	r2, #128	; 0x80
 800445a:	0192      	lsls	r2, r2, #6
 800445c:	615a      	str	r2, [r3, #20]
  sBreakDeadTimeConfig.AutomaticOutput = TIM_AUTOMATICOUTPUT_DISABLE;
 800445e:	1d3b      	adds	r3, r7, #4
 8004460:	2200      	movs	r2, #0
 8004462:	61da      	str	r2, [r3, #28]
  if (HAL_TIMEx_ConfigBreakDeadTime(&htim1, &sBreakDeadTimeConfig) != HAL_OK)
 8004464:	1d3a      	adds	r2, r7, #4
 8004466:	4b08      	ldr	r3, [pc, #32]	; (8004488 <MX_TIM1_Init+0x120>)
 8004468:	0011      	movs	r1, r2
 800446a:	0018      	movs	r0, r3
 800446c:	f005 fb50 	bl	8009b10 <HAL_TIMEx_ConfigBreakDeadTime>
 8004470:	1e03      	subs	r3, r0, #0
 8004472:	d001      	beq.n	8004478 <MX_TIM1_Init+0x110>
  {
    Error_Handler();
 8004474:	f000 f9b0 	bl	80047d8 <Error_Handler>
  /* USER CODE BEGIN TIM1_Init 2 */



  /* USER CODE END TIM1_Init 2 */
  HAL_TIM_MspPostInit(&htim1);
 8004478:	4b03      	ldr	r3, [pc, #12]	; (8004488 <MX_TIM1_Init+0x120>)
 800447a:	0018      	movs	r0, r3
 800447c:	f001 f8ae 	bl	80055dc <HAL_TIM_MspPostInit>

}
 8004480:	46c0      	nop			; (mov r8, r8)
 8004482:	46bd      	mov	sp, r7
 8004484:	b012      	add	sp, #72	; 0x48
 8004486:	bd80      	pop	{r7, pc}
 8004488:	200021a4 	.word	0x200021a4
 800448c:	40012c00 	.word	0x40012c00
 8004490:	00001d4c 	.word	0x00001d4c
 8004494:	00000ea6 	.word	0x00000ea6

08004498 <MX_DMA_Init>:

/**
  * Enable DMA controller clock
  */
static void MX_DMA_Init(void)
{
 8004498:	b580      	push	{r7, lr}
 800449a:	b082      	sub	sp, #8
 800449c:	af00      	add	r7, sp, #0

  /* DMA controller clock enable */
  __HAL_RCC_DMA1_CLK_ENABLE();
 800449e:	4b0c      	ldr	r3, [pc, #48]	; (80044d0 <MX_DMA_Init+0x38>)
 80044a0:	695a      	ldr	r2, [r3, #20]
 80044a2:	4b0b      	ldr	r3, [pc, #44]	; (80044d0 <MX_DMA_Init+0x38>)
 80044a4:	2101      	movs	r1, #1
 80044a6:	430a      	orrs	r2, r1
 80044a8:	615a      	str	r2, [r3, #20]
 80044aa:	4b09      	ldr	r3, [pc, #36]	; (80044d0 <MX_DMA_Init+0x38>)
 80044ac:	695b      	ldr	r3, [r3, #20]
 80044ae:	2201      	movs	r2, #1
 80044b0:	4013      	ands	r3, r2
 80044b2:	607b      	str	r3, [r7, #4]
 80044b4:	687b      	ldr	r3, [r7, #4]

  /* DMA interrupt init */
  /* DMA1_Ch1_IRQn interrupt configuration */
  HAL_NVIC_SetPriority(DMA1_Ch1_IRQn, 0, 0);
 80044b6:	2200      	movs	r2, #0
 80044b8:	2100      	movs	r1, #0
 80044ba:	2009      	movs	r0, #9
 80044bc:	f001 ff04 	bl	80062c8 <HAL_NVIC_SetPriority>
  HAL_NVIC_EnableIRQ(DMA1_Ch1_IRQn);
 80044c0:	2009      	movs	r0, #9
 80044c2:	f001 ff16 	bl	80062f2 <HAL_NVIC_EnableIRQ>

}
 80044c6:	46c0      	nop			; (mov r8, r8)
 80044c8:	46bd      	mov	sp, r7
 80044ca:	b002      	add	sp, #8
 80044cc:	bd80      	pop	{r7, pc}
 80044ce:	46c0      	nop			; (mov r8, r8)
 80044d0:	40021000 	.word	0x40021000

080044d4 <MX_GPIO_Init>:
  * @brief GPIO Initialization Function
  * @param None
  * @retval None
  */
static void MX_GPIO_Init(void)
{
 80044d4:	b590      	push	{r4, r7, lr}
 80044d6:	b089      	sub	sp, #36	; 0x24
 80044d8:	af00      	add	r7, sp, #0
  GPIO_InitTypeDef GPIO_InitStruct = {0};
 80044da:	240c      	movs	r4, #12
 80044dc:	193b      	adds	r3, r7, r4
 80044de:	0018      	movs	r0, r3
 80044e0:	2314      	movs	r3, #20
 80044e2:	001a      	movs	r2, r3
 80044e4:	2100      	movs	r1, #0
 80044e6:	f005 fbcb 	bl	8009c80 <memset>

  /* GPIO Ports Clock Enable */
  __HAL_RCC_GPIOA_CLK_ENABLE();
 80044ea:	4b55      	ldr	r3, [pc, #340]	; (8004640 <MX_GPIO_Init+0x16c>)
 80044ec:	695a      	ldr	r2, [r3, #20]
 80044ee:	4b54      	ldr	r3, [pc, #336]	; (8004640 <MX_GPIO_Init+0x16c>)
 80044f0:	2180      	movs	r1, #128	; 0x80
 80044f2:	0289      	lsls	r1, r1, #10
 80044f4:	430a      	orrs	r2, r1
 80044f6:	615a      	str	r2, [r3, #20]
 80044f8:	4b51      	ldr	r3, [pc, #324]	; (8004640 <MX_GPIO_Init+0x16c>)
 80044fa:	695a      	ldr	r2, [r3, #20]
 80044fc:	2380      	movs	r3, #128	; 0x80
 80044fe:	029b      	lsls	r3, r3, #10
 8004500:	4013      	ands	r3, r2
 8004502:	60bb      	str	r3, [r7, #8]
 8004504:	68bb      	ldr	r3, [r7, #8]
  __HAL_RCC_GPIOB_CLK_ENABLE();
 8004506:	4b4e      	ldr	r3, [pc, #312]	; (8004640 <MX_GPIO_Init+0x16c>)
 8004508:	695a      	ldr	r2, [r3, #20]
 800450a:	4b4d      	ldr	r3, [pc, #308]	; (8004640 <MX_GPIO_Init+0x16c>)
 800450c:	2180      	movs	r1, #128	; 0x80
 800450e:	02c9      	lsls	r1, r1, #11
 8004510:	430a      	orrs	r2, r1
 8004512:	615a      	str	r2, [r3, #20]
 8004514:	4b4a      	ldr	r3, [pc, #296]	; (8004640 <MX_GPIO_Init+0x16c>)
 8004516:	695a      	ldr	r2, [r3, #20]
 8004518:	2380      	movs	r3, #128	; 0x80
 800451a:	02db      	lsls	r3, r3, #11
 800451c:	4013      	ands	r3, r2
 800451e:	607b      	str	r3, [r7, #4]
 8004520:	687b      	ldr	r3, [r7, #4]
  __HAL_RCC_GPIOC_CLK_ENABLE();
 8004522:	4b47      	ldr	r3, [pc, #284]	; (8004640 <MX_GPIO_Init+0x16c>)
 8004524:	695a      	ldr	r2, [r3, #20]
 8004526:	4b46      	ldr	r3, [pc, #280]	; (8004640 <MX_GPIO_Init+0x16c>)
 8004528:	2180      	movs	r1, #128	; 0x80
 800452a:	0309      	lsls	r1, r1, #12
 800452c:	430a      	orrs	r2, r1
 800452e:	615a      	str	r2, [r3, #20]
 8004530:	4b43      	ldr	r3, [pc, #268]	; (8004640 <MX_GPIO_Init+0x16c>)
 8004532:	695a      	ldr	r2, [r3, #20]
 8004534:	2380      	movs	r3, #128	; 0x80
 8004536:	031b      	lsls	r3, r3, #12
 8004538:	4013      	ands	r3, r2
 800453a:	603b      	str	r3, [r7, #0]
 800453c:	683b      	ldr	r3, [r7, #0]

  /*Configure GPIO pin Output Level */
  HAL_GPIO_WritePin(GPIOA, GPIO_PIN_2|GPIO_PIN_3, GPIO_PIN_RESET);
 800453e:	2390      	movs	r3, #144	; 0x90
 8004540:	05db      	lsls	r3, r3, #23
 8004542:	2200      	movs	r2, #0
 8004544:	210c      	movs	r1, #12
 8004546:	0018      	movs	r0, r3
 8004548:	f002 fa8d 	bl	8006a66 <HAL_GPIO_WritePin>

  /*Configure GPIO pin Output Level */
  HAL_GPIO_WritePin(GPIOB, GPIO_PIN_11|GPIO_PIN_12|GPIO_PIN_13|GPIO_PIN_14
 800454c:	23f8      	movs	r3, #248	; 0xf8
 800454e:	021b      	lsls	r3, r3, #8
 8004550:	483c      	ldr	r0, [pc, #240]	; (8004644 <MX_GPIO_Init+0x170>)
 8004552:	2200      	movs	r2, #0
 8004554:	0019      	movs	r1, r3
 8004556:	f002 fa86 	bl	8006a66 <HAL_GPIO_WritePin>
                          |GPIO_PIN_15, GPIO_PIN_RESET);

  /*Configure GPIO pin Output Level */
  HAL_GPIO_WritePin(GPIOC, GPIO_PIN_6|GPIO_PIN_7|GPIO_PIN_8|GPIO_PIN_10, GPIO_PIN_RESET);
 800455a:	23b8      	movs	r3, #184	; 0xb8
 800455c:	00db      	lsls	r3, r3, #3
 800455e:	483a      	ldr	r0, [pc, #232]	; (8004648 <MX_GPIO_Init+0x174>)
 8004560:	2200      	movs	r2, #0
 8004562:	0019      	movs	r1, r3
 8004564:	f002 fa7f 	bl	8006a66 <HAL_GPIO_WritePin>

  /*Configure GPIO pins : PA2 PA3 */
  GPIO_InitStruct.Pin = GPIO_PIN_2|GPIO_PIN_3;
 8004568:	193b      	adds	r3, r7, r4
 800456a:	220c      	movs	r2, #12
 800456c:	601a      	str	r2, [r3, #0]
  GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
 800456e:	193b      	adds	r3, r7, r4
 8004570:	2201      	movs	r2, #1
 8004572:	605a      	str	r2, [r3, #4]
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 8004574:	193b      	adds	r3, r7, r4
 8004576:	2200      	movs	r2, #0
 8004578:	609a      	str	r2, [r3, #8]
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
 800457a:	193b      	adds	r3, r7, r4
 800457c:	2200      	movs	r2, #0
 800457e:	60da      	str	r2, [r3, #12]
  HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
 8004580:	193a      	adds	r2, r7, r4
 8004582:	2390      	movs	r3, #144	; 0x90
 8004584:	05db      	lsls	r3, r3, #23
 8004586:	0011      	movs	r1, r2
 8004588:	0018      	movs	r0, r3
 800458a:	f002 f8d7 	bl	800673c <HAL_GPIO_Init>

  /*Configure GPIO pins : PB11 PB12 PB13 PB14
                           PB15 */
  GPIO_InitStruct.Pin = GPIO_PIN_11|GPIO_PIN_12|GPIO_PIN_13|GPIO_PIN_14
 800458e:	0021      	movs	r1, r4
 8004590:	187b      	adds	r3, r7, r1
 8004592:	22f8      	movs	r2, #248	; 0xf8
 8004594:	0212      	lsls	r2, r2, #8
 8004596:	601a      	str	r2, [r3, #0]
                          |GPIO_PIN_15;
  GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
 8004598:	000c      	movs	r4, r1
 800459a:	193b      	adds	r3, r7, r4
 800459c:	2201      	movs	r2, #1
 800459e:	605a      	str	r2, [r3, #4]
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 80045a0:	193b      	adds	r3, r7, r4
 80045a2:	2200      	movs	r2, #0
 80045a4:	609a      	str	r2, [r3, #8]
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
 80045a6:	193b      	adds	r3, r7, r4
 80045a8:	2200      	movs	r2, #0
 80045aa:	60da      	str	r2, [r3, #12]
  HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
 80045ac:	193b      	adds	r3, r7, r4
 80045ae:	4a25      	ldr	r2, [pc, #148]	; (8004644 <MX_GPIO_Init+0x170>)
 80045b0:	0019      	movs	r1, r3
 80045b2:	0010      	movs	r0, r2
 80045b4:	f002 f8c2 	bl	800673c <HAL_GPIO_Init>

  /*Configure GPIO pins : PC6 PC7 PC8 PC10 */
  GPIO_InitStruct.Pin = GPIO_PIN_6|GPIO_PIN_7|GPIO_PIN_8|GPIO_PIN_10;
 80045b8:	0021      	movs	r1, r4
 80045ba:	187b      	adds	r3, r7, r1
 80045bc:	22b8      	movs	r2, #184	; 0xb8
 80045be:	00d2      	lsls	r2, r2, #3
 80045c0:	601a      	str	r2, [r3, #0]
  GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
 80045c2:	000c      	movs	r4, r1
 80045c4:	193b      	adds	r3, r7, r4
 80045c6:	2201      	movs	r2, #1
 80045c8:	605a      	str	r2, [r3, #4]
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 80045ca:	193b      	adds	r3, r7, r4
 80045cc:	2200      	movs	r2, #0
 80045ce:	609a      	str	r2, [r3, #8]
  GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
 80045d0:	193b      	adds	r3, r7, r4
 80045d2:	2200      	movs	r2, #0
 80045d4:	60da      	str	r2, [r3, #12]
  HAL_GPIO_Init(GPIOC, &GPIO_InitStruct);
 80045d6:	193b      	adds	r3, r7, r4
 80045d8:	4a1b      	ldr	r2, [pc, #108]	; (8004648 <MX_GPIO_Init+0x174>)
 80045da:	0019      	movs	r1, r3
 80045dc:	0010      	movs	r0, r2
 80045de:	f002 f8ad 	bl	800673c <HAL_GPIO_Init>

  /*Configure GPIO pins : PA10 PA11 */
  GPIO_InitStruct.Pin = GPIO_PIN_10|GPIO_PIN_11;
 80045e2:	193b      	adds	r3, r7, r4
 80045e4:	22c0      	movs	r2, #192	; 0xc0
 80045e6:	0112      	lsls	r2, r2, #4
 80045e8:	601a      	str	r2, [r3, #0]
  GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
 80045ea:	193b      	adds	r3, r7, r4
 80045ec:	2200      	movs	r2, #0
 80045ee:	605a      	str	r2, [r3, #4]
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 80045f0:	193b      	adds	r3, r7, r4
 80045f2:	2200      	movs	r2, #0
 80045f4:	609a      	str	r2, [r3, #8]
  HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
 80045f6:	193a      	adds	r2, r7, r4
 80045f8:	2390      	movs	r3, #144	; 0x90
 80045fa:	05db      	lsls	r3, r3, #23
 80045fc:	0011      	movs	r1, r2
 80045fe:	0018      	movs	r0, r3
 8004600:	f002 f89c 	bl	800673c <HAL_GPIO_Init>

  /*Configure GPIO pins : PB4 PB5 PB6 PB7 */
  GPIO_InitStruct.Pin = GPIO_PIN_4|GPIO_PIN_5|GPIO_PIN_6|GPIO_PIN_7;
 8004604:	0021      	movs	r1, r4
 8004606:	187b      	adds	r3, r7, r1
 8004608:	22f0      	movs	r2, #240	; 0xf0
 800460a:	601a      	str	r2, [r3, #0]
  GPIO_InitStruct.Mode = GPIO_MODE_IT_RISING;
 800460c:	187b      	adds	r3, r7, r1
 800460e:	2288      	movs	r2, #136	; 0x88
 8004610:	0352      	lsls	r2, r2, #13
 8004612:	605a      	str	r2, [r3, #4]
  GPIO_InitStruct.Pull = GPIO_NOPULL;
 8004614:	187b      	adds	r3, r7, r1
 8004616:	2200      	movs	r2, #0
 8004618:	609a      	str	r2, [r3, #8]
  HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
 800461a:	187b      	adds	r3, r7, r1
 800461c:	4a09      	ldr	r2, [pc, #36]	; (8004644 <MX_GPIO_Init+0x170>)
 800461e:	0019      	movs	r1, r3
 8004620:	0010      	movs	r0, r2
 8004622:	f002 f88b 	bl	800673c <HAL_GPIO_Init>

  /* EXTI interrupt init*/
  HAL_NVIC_SetPriority(EXTI4_15_IRQn, 0, 0);
 8004626:	2200      	movs	r2, #0
 8004628:	2100      	movs	r1, #0
 800462a:	2007      	movs	r0, #7
 800462c:	f001 fe4c 	bl	80062c8 <HAL_NVIC_SetPriority>
  HAL_NVIC_EnableIRQ(EXTI4_15_IRQn);
 8004630:	2007      	movs	r0, #7
 8004632:	f001 fe5e 	bl	80062f2 <HAL_NVIC_EnableIRQ>

}
 8004636:	46c0      	nop			; (mov r8, r8)
 8004638:	46bd      	mov	sp, r7
 800463a:	b009      	add	sp, #36	; 0x24
 800463c:	bd90      	pop	{r4, r7, pc}
 800463e:	46c0      	nop			; (mov r8, r8)
 8004640:	40021000 	.word	0x40021000
 8004644:	48000400 	.word	0x48000400
 8004648:	48000800 	.word	0x48000800

0800464c <HAL_GPIO_EXTI_Callback>:
//===========================================================================
// EXTERNAL INTERRUPT CALLBACK
// Used for navigation buttons and trigger
//===========================================================================
void HAL_GPIO_EXTI_Callback(uint16_t GPIO_Pin)
{
 800464c:	b580      	push	{r7, lr}
 800464e:	b082      	sub	sp, #8
 8004650:	af00      	add	r7, sp, #0
 8004652:	0002      	movs	r2, r0
 8004654:	1dbb      	adds	r3, r7, #6
 8004656:	801a      	strh	r2, [r3, #0]
	curr = HAL_GetTick();
 8004658:	f001 f97c 	bl	8005954 <HAL_GetTick>
 800465c:	0002      	movs	r2, r0
 800465e:	4b24      	ldr	r3, [pc, #144]	; (80046f0 <HAL_GPIO_EXTI_Callback+0xa4>)
 8004660:	601a      	str	r2, [r3, #0]
	UNUSED(GPIO_Pin);
	if((GPIO_Pin == (1<<4)) && (curr - prev > 200)) //Left button
 8004662:	1dbb      	adds	r3, r7, #6
 8004664:	881b      	ldrh	r3, [r3, #0]
 8004666:	2b10      	cmp	r3, #16
 8004668:	d10c      	bne.n	8004684 <HAL_GPIO_EXTI_Callback+0x38>
 800466a:	4b21      	ldr	r3, [pc, #132]	; (80046f0 <HAL_GPIO_EXTI_Callback+0xa4>)
 800466c:	681a      	ldr	r2, [r3, #0]
 800466e:	4b21      	ldr	r3, [pc, #132]	; (80046f4 <HAL_GPIO_EXTI_Callback+0xa8>)
 8004670:	681b      	ldr	r3, [r3, #0]
 8004672:	1ad3      	subs	r3, r2, r3
 8004674:	2bc8      	cmp	r3, #200	; 0xc8
 8004676:	d905      	bls.n	8004684 <HAL_GPIO_EXTI_Callback+0x38>
	{
		move_left();//move left
 8004678:	f000 fa32 	bl	8004ae0 <move_left>
		prev = curr;
 800467c:	4b1c      	ldr	r3, [pc, #112]	; (80046f0 <HAL_GPIO_EXTI_Callback+0xa4>)
 800467e:	681a      	ldr	r2, [r3, #0]
 8004680:	4b1c      	ldr	r3, [pc, #112]	; (80046f4 <HAL_GPIO_EXTI_Callback+0xa8>)
 8004682:	601a      	str	r2, [r3, #0]
	}
	if(((GPIO_Pin == (1<<5)) | (GPIO_Pin == (1<<7))) && (curr - prev > 200)) //select button
 8004684:	1dbb      	adds	r3, r7, #6
 8004686:	881b      	ldrh	r3, [r3, #0]
 8004688:	3b20      	subs	r3, #32
 800468a:	425a      	negs	r2, r3
 800468c:	4153      	adcs	r3, r2
 800468e:	b2da      	uxtb	r2, r3
 8004690:	1dbb      	adds	r3, r7, #6
 8004692:	881b      	ldrh	r3, [r3, #0]
 8004694:	3b80      	subs	r3, #128	; 0x80
 8004696:	4259      	negs	r1, r3
 8004698:	414b      	adcs	r3, r1
 800469a:	b2db      	uxtb	r3, r3
 800469c:	4313      	orrs	r3, r2
 800469e:	b2db      	uxtb	r3, r3
 80046a0:	2b00      	cmp	r3, #0
 80046a2:	d00f      	beq.n	80046c4 <HAL_GPIO_EXTI_Callback+0x78>
 80046a4:	4b12      	ldr	r3, [pc, #72]	; (80046f0 <HAL_GPIO_EXTI_Callback+0xa4>)
 80046a6:	681a      	ldr	r2, [r3, #0]
 80046a8:	4b12      	ldr	r3, [pc, #72]	; (80046f4 <HAL_GPIO_EXTI_Callback+0xa8>)
 80046aa:	681b      	ldr	r3, [r3, #0]
 80046ac:	1ad3      	subs	r3, r2, r3
 80046ae:	2bc8      	cmp	r3, #200	; 0xc8
 80046b0:	d908      	bls.n	80046c4 <HAL_GPIO_EXTI_Callback+0x78>
		{
			display_select(currentSelectIndex); //select option
 80046b2:	4b11      	ldr	r3, [pc, #68]	; (80046f8 <HAL_GPIO_EXTI_Callback+0xac>)
 80046b4:	681b      	ldr	r3, [r3, #0]
 80046b6:	0018      	movs	r0, r3
 80046b8:	f000 fb6c 	bl	8004d94 <display_select>
			prev = curr;
 80046bc:	4b0c      	ldr	r3, [pc, #48]	; (80046f0 <HAL_GPIO_EXTI_Callback+0xa4>)
 80046be:	681a      	ldr	r2, [r3, #0]
 80046c0:	4b0c      	ldr	r3, [pc, #48]	; (80046f4 <HAL_GPIO_EXTI_Callback+0xa8>)
 80046c2:	601a      	str	r2, [r3, #0]
		}
	if((GPIO_Pin == (1<<6)) && (curr - prev > 200)) // right button
 80046c4:	1dbb      	adds	r3, r7, #6
 80046c6:	881b      	ldrh	r3, [r3, #0]
 80046c8:	2b40      	cmp	r3, #64	; 0x40
 80046ca:	d10c      	bne.n	80046e6 <HAL_GPIO_EXTI_Callback+0x9a>
 80046cc:	4b08      	ldr	r3, [pc, #32]	; (80046f0 <HAL_GPIO_EXTI_Callback+0xa4>)
 80046ce:	681a      	ldr	r2, [r3, #0]
 80046d0:	4b08      	ldr	r3, [pc, #32]	; (80046f4 <HAL_GPIO_EXTI_Callback+0xa8>)
 80046d2:	681b      	ldr	r3, [r3, #0]
 80046d4:	1ad3      	subs	r3, r2, r3
 80046d6:	2bc8      	cmp	r3, #200	; 0xc8
 80046d8:	d905      	bls.n	80046e6 <HAL_GPIO_EXTI_Callback+0x9a>
	{
		move_right();//move right
 80046da:	f000 f9cb 	bl	8004a74 <move_right>
		prev = curr;
 80046de:	4b04      	ldr	r3, [pc, #16]	; (80046f0 <HAL_GPIO_EXTI_Callback+0xa4>)
 80046e0:	681a      	ldr	r2, [r3, #0]
 80046e2:	4b04      	ldr	r3, [pc, #16]	; (80046f4 <HAL_GPIO_EXTI_Callback+0xa8>)
 80046e4:	601a      	str	r2, [r3, #0]
	}
}
 80046e6:	46c0      	nop			; (mov r8, r8)
 80046e8:	46bd      	mov	sp, r7
 80046ea:	b002      	add	sp, #8
 80046ec:	bd80      	pop	{r7, pc}
 80046ee:	46c0      	nop			; (mov r8, r8)
 80046f0:	20002120 	.word	0x20002120
 80046f4:	2000211c 	.word	0x2000211c
 80046f8:	2000210c 	.word	0x2000210c

080046fc <HAL_ADC_ConvHalfCpltCallback>:
// Called when first half of buffer is filled
void HAL_ADC_ConvHalfCpltCallback(ADC_HandleTypeDef* hadc) {
 80046fc:	b580      	push	{r7, lr}
 80046fe:	b082      	sub	sp, #8
 8004700:	af00      	add	r7, sp, #0
 8004702:	6078      	str	r0, [r7, #4]
  __NOP();
 8004704:	46c0      	nop			; (mov r8, r8)
}
 8004706:	46c0      	nop			; (mov r8, r8)
 8004708:	46bd      	mov	sp, r7
 800470a:	b002      	add	sp, #8
 800470c:	bd80      	pop	{r7, pc}

0800470e <HAL_ADC_ConvCpltCallback>:

// Called when buffer is completely filled
void HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef* hadc) {
 800470e:	b580      	push	{r7, lr}
 8004710:	b082      	sub	sp, #8
 8004712:	af00      	add	r7, sp, #0
 8004714:	6078      	str	r0, [r7, #4]
  //dspmain();
}
 8004716:	46c0      	nop			; (mov r8, r8)
 8004718:	46bd      	mov	sp, r7
 800471a:	b002      	add	sp, #8
 800471c:	bd80      	pop	{r7, pc}
	...

08004720 <battery>:
void battery() {
 8004720:	b580      	push	{r7, lr}
 8004722:	af00      	add	r7, sp, #0
	HAL_I2C_Master_Receive_IT(&hi2c1, 100, batbuf, I2C_BUF_LEN);
 8004724:	4a04      	ldr	r2, [pc, #16]	; (8004738 <battery+0x18>)
 8004726:	4805      	ldr	r0, [pc, #20]	; (800473c <battery+0x1c>)
 8004728:	2304      	movs	r3, #4
 800472a:	2164      	movs	r1, #100	; 0x64
 800472c:	f002 fa6a 	bl	8006c04 <HAL_I2C_Master_Receive_IT>
}
 8004730:	46c0      	nop			; (mov r8, r8)
 8004732:	46bd      	mov	sp, r7
 8004734:	bd80      	pop	{r7, pc}
 8004736:	46c0      	nop			; (mov r8, r8)
 8004738:	20002194 	.word	0x20002194
 800473c:	20002148 	.word	0x20002148

08004740 <HAL_I2C_MasterRxCpltCallback>:
void HAL_I2C_MasterRxCpltCallback (I2C_HandleTypeDef * hi2c)
{
 8004740:	b580      	push	{r7, lr}
 8004742:	b082      	sub	sp, #8
 8004744:	af00      	add	r7, sp, #0
 8004746:	6078      	str	r0, [r7, #4]
	//for(int i = 0; i < 4; i++)
		//LCD_Draw4digit(i, 0, i, batbuf);
}
 8004748:	46c0      	nop			; (mov r8, r8)
 800474a:	46bd      	mov	sp, r7
 800474c:	b002      	add	sp, #8
 800474e:	bd80      	pop	{r7, pc}

08004750 <auto_tune>:
		renew +=  tmp * fact;
	  }

}
void auto_tune()
{
 8004750:	b580      	push	{r7, lr}
 8004752:	b084      	sub	sp, #16
 8004754:	af04      	add	r7, sp, #16
	LCD_DrawString(80 ,80,  YELLOW, BLUE,"Take samples", 16, 0);
 8004756:	4a0b      	ldr	r2, [pc, #44]	; (8004784 <auto_tune+0x34>)
 8004758:	2300      	movs	r3, #0
 800475a:	9302      	str	r3, [sp, #8]
 800475c:	2310      	movs	r3, #16
 800475e:	9301      	str	r3, [sp, #4]
 8004760:	4b09      	ldr	r3, [pc, #36]	; (8004788 <auto_tune+0x38>)
 8004762:	9300      	str	r3, [sp, #0]
 8004764:	231f      	movs	r3, #31
 8004766:	2150      	movs	r1, #80	; 0x50
 8004768:	2050      	movs	r0, #80	; 0x50
 800476a:	f7ff fb07 	bl	8003d7c <LCD_DrawString>
	HAL_ADC_Start_DMA(&hadc, adc_buf, ADC_BUF_LEN);
 800476e:	2380      	movs	r3, #128	; 0x80
 8004770:	011a      	lsls	r2, r3, #4
 8004772:	4906      	ldr	r1, [pc, #24]	; (800478c <auto_tune+0x3c>)
 8004774:	4b06      	ldr	r3, [pc, #24]	; (8004790 <auto_tune+0x40>)
 8004776:	0018      	movs	r0, r3
 8004778:	f001 fa5a 	bl	8005c30 <HAL_ADC_Start_DMA>
	//dspmain();
}
 800477c:	46c0      	nop			; (mov r8, r8)
 800477e:	46bd      	mov	sp, r7
 8004780:	bd80      	pop	{r7, pc}
 8004782:	46c0      	nop			; (mov r8, r8)
 8004784:	0000ffe0 	.word	0x0000ffe0
 8004788:	0800e374 	.word	0x0800e374
 800478c:	2000010c 	.word	0x2000010c
 8004790:	20002294 	.word	0x20002294

08004794 <startmotor>:
void startmotor()
{
 8004794:	b580      	push	{r7, lr}
 8004796:	af00      	add	r7, sp, #0
	HAL_TIM_PWM_Start(&htim1, TIM_CHANNEL_1);
 8004798:	4b03      	ldr	r3, [pc, #12]	; (80047a8 <startmotor+0x14>)
 800479a:	2100      	movs	r1, #0
 800479c:	0018      	movs	r0, r3
 800479e:	f004 fcbf 	bl	8009120 <HAL_TIM_PWM_Start>
}
 80047a2:	46c0      	nop			; (mov r8, r8)
 80047a4:	46bd      	mov	sp, r7
 80047a6:	bd80      	pop	{r7, pc}
 80047a8:	200021a4 	.word	0x200021a4

080047ac <stopmotor>:
void stopmotor()
{
 80047ac:	b580      	push	{r7, lr}
 80047ae:	af00      	add	r7, sp, #0
	HAL_TIM_PWM_Stop(&htim1, TIM_CHANNEL_1);
 80047b0:	4b07      	ldr	r3, [pc, #28]	; (80047d0 <stopmotor+0x24>)
 80047b2:	2100      	movs	r1, #0
 80047b4:	0018      	movs	r0, r3
 80047b6:	f004 fd6b 	bl	8009290 <HAL_TIM_PWM_Stop>
	HAL_GPIO_WritePin(GPIOB, GPIO_PIN_11, GPIO_PIN_SET);
 80047ba:	2380      	movs	r3, #128	; 0x80
 80047bc:	011b      	lsls	r3, r3, #4
 80047be:	4805      	ldr	r0, [pc, #20]	; (80047d4 <stopmotor+0x28>)
 80047c0:	2201      	movs	r2, #1
 80047c2:	0019      	movs	r1, r3
 80047c4:	f002 f94f 	bl	8006a66 <HAL_GPIO_WritePin>
}
 80047c8:	46c0      	nop			; (mov r8, r8)
 80047ca:	46bd      	mov	sp, r7
 80047cc:	bd80      	pop	{r7, pc}
 80047ce:	46c0      	nop			; (mov r8, r8)
 80047d0:	200021a4 	.word	0x200021a4
 80047d4:	48000400 	.word	0x48000400

080047d8 <Error_Handler>:
/**
  * @brief  This function is executed in case of error occurrence.
  * @retval None
  */
void Error_Handler(void)
{
 80047d8:	b580      	push	{r7, lr}
 80047da:	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");
 80047dc:	b672      	cpsid	i
}
 80047de:	46c0      	nop			; (mov r8, r8)
  /* USER CODE BEGIN Error_Handler_Debug */
  /* User can add his own implementation to report the HAL error return state */
  __disable_irq();
  while (1)
 80047e0:	e7fe      	b.n	80047e0 <Error_Handler+0x8>
	...

080047e4 <initialize>:
uint8_t pressHistory[3] = {0,0,0};
extern const Picture *image;
struct display *currDisplay;

void initialize()
{
 80047e4:	b580      	push	{r7, lr}
 80047e6:	b08a      	sub	sp, #40	; 0x28
 80047e8:	af00      	add	r7, sp, #0
	struct display *home = malloc(sizeof(struct display));
 80047ea:	2020      	movs	r0, #32
 80047ec:	f005 fa3e 	bl	8009c6c <malloc>
 80047f0:	0003      	movs	r3, r0
 80047f2:	627b      	str	r3, [r7, #36]	; 0x24
	struct display *info = malloc(sizeof(struct display));
 80047f4:	2020      	movs	r0, #32
 80047f6:	f005 fa39 	bl	8009c6c <malloc>
 80047fa:	0003      	movs	r3, r0
 80047fc:	623b      	str	r3, [r7, #32]
	struct display *samp = malloc(sizeof(struct display));
 80047fe:	2020      	movs	r0, #32
 8004800:	f005 fa34 	bl	8009c6c <malloc>
 8004804:	0003      	movs	r3, r0
 8004806:	61fb      	str	r3, [r7, #28]
	struct display *tune = malloc(sizeof(struct display));
 8004808:	2020      	movs	r0, #32
 800480a:	f005 fa2f 	bl	8009c6c <malloc>
 800480e:	0003      	movs	r3, r0
 8004810:	61bb      	str	r3, [r7, #24]
	struct display *manual = malloc(sizeof(struct display));
 8004812:	2020      	movs	r0, #32
 8004814:	f005 fa2a 	bl	8009c6c <malloc>
 8004818:	0003      	movs	r3, r0
 800481a:	617b      	str	r3, [r7, #20]
	struct display *peg = malloc(sizeof(struct display));
 800481c:	2020      	movs	r0, #32
 800481e:	f005 fa25 	bl	8009c6c <malloc>
 8004822:	0003      	movs	r3, r0
 8004824:	613b      	str	r3, [r7, #16]
	struct display *rotate = malloc(sizeof(struct display));
 8004826:	2020      	movs	r0, #32
 8004828:	f005 fa20 	bl	8009c6c <malloc>
 800482c:	0003      	movs	r3, r0
 800482e:	60fb      	str	r3, [r7, #12]
	struct display *Auto = malloc(sizeof(struct display));
 8004830:	2020      	movs	r0, #32
 8004832:	f005 fa1b 	bl	8009c6c <malloc>
 8004836:	0003      	movs	r3, r0
 8004838:	60bb      	str	r3, [r7, #8]
	struct display *bat = malloc(sizeof(struct display));
 800483a:	2020      	movs	r0, #32
 800483c:	f005 fa16 	bl	8009c6c <malloc>
 8004840:	0003      	movs	r3, r0
 8004842:	607b      	str	r3, [r7, #4]

	home->ttl = menu_home;
 8004844:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 8004846:	4a6a      	ldr	r2, [pc, #424]	; (80049f0 <initialize+0x20c>)
 8004848:	601a      	str	r2, [r3, #0]
	home->scrollmax = 3;
 800484a:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 800484c:	2203      	movs	r2, #3
 800484e:	60da      	str	r2, [r3, #12]
	home->selectionmax = 3;
 8004850:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 8004852:	2203      	movs	r2, #3
 8004854:	611a      	str	r2, [r3, #16]
	home->backout = NULL;
 8004856:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 8004858:	2200      	movs	r2, #0
 800485a:	61da      	str	r2, [r3, #28]
	home->nextsel = NULL;
 800485c:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 800485e:	2200      	movs	r2, #0
 8004860:	615a      	str	r2, [r3, #20]
	home->childsel = info;
 8004862:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 8004864:	6a3a      	ldr	r2, [r7, #32]
 8004866:	619a      	str	r2, [r3, #24]
	home->identity = 'h';
 8004868:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 800486a:	2268      	movs	r2, #104	; 0x68
 800486c:	711a      	strb	r2, [r3, #4]
	home->selection = menu;
 800486e:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 8004870:	4a60      	ldr	r2, [pc, #384]	; (80049f4 <initialize+0x210>)
 8004872:	609a      	str	r2, [r3, #8]
	//info
	info->scrollmax = 2;
 8004874:	6a3b      	ldr	r3, [r7, #32]
 8004876:	2202      	movs	r2, #2
 8004878:	60da      	str	r2, [r3, #12]
	info->selectionmax = 2;
 800487a:	6a3b      	ldr	r3, [r7, #32]
 800487c:	2202      	movs	r2, #2
 800487e:	611a      	str	r2, [r3, #16]
	info->ttl = Infomode;
 8004880:	6a3b      	ldr	r3, [r7, #32]
 8004882:	4a5d      	ldr	r2, [pc, #372]	; (80049f8 <initialize+0x214>)
 8004884:	601a      	str	r2, [r3, #0]
	info->backout = home;
 8004886:	6a3b      	ldr	r3, [r7, #32]
 8004888:	6a7a      	ldr	r2, [r7, #36]	; 0x24
 800488a:	61da      	str	r2, [r3, #28]
	info->nextsel = tune;
 800488c:	6a3b      	ldr	r3, [r7, #32]
 800488e:	69ba      	ldr	r2, [r7, #24]
 8004890:	615a      	str	r2, [r3, #20]
	info->childsel = bat;
 8004892:	6a3b      	ldr	r3, [r7, #32]
 8004894:	687a      	ldr	r2, [r7, #4]
 8004896:	619a      	str	r2, [r3, #24]
	info->identity = 'i';
 8004898:	6a3b      	ldr	r3, [r7, #32]
 800489a:	2269      	movs	r2, #105	; 0x69
 800489c:	711a      	strb	r2, [r3, #4]
	info->selection = Info;
 800489e:	6a3b      	ldr	r3, [r7, #32]
 80048a0:	4a56      	ldr	r2, [pc, #344]	; (80049fc <initialize+0x218>)
 80048a2:	609a      	str	r2, [r3, #8]

	//info
	bat->scrollmax = 0;
 80048a4:	687b      	ldr	r3, [r7, #4]
 80048a6:	2200      	movs	r2, #0
 80048a8:	60da      	str	r2, [r3, #12]
	bat->selectionmax = 0;
 80048aa:	687b      	ldr	r3, [r7, #4]
 80048ac:	2200      	movs	r2, #0
 80048ae:	611a      	str	r2, [r3, #16]
	bat->ttl = battery;
 80048b0:	687b      	ldr	r3, [r7, #4]
 80048b2:	4a53      	ldr	r2, [pc, #332]	; (8004a00 <initialize+0x21c>)
 80048b4:	601a      	str	r2, [r3, #0]
	bat->backout = NULL;
 80048b6:	687b      	ldr	r3, [r7, #4]
 80048b8:	2200      	movs	r2, #0
 80048ba:	61da      	str	r2, [r3, #28]
	bat->nextsel = NULL;
 80048bc:	687b      	ldr	r3, [r7, #4]
 80048be:	2200      	movs	r2, #0
 80048c0:	615a      	str	r2, [r3, #20]
	bat->childsel = NULL;
 80048c2:	687b      	ldr	r3, [r7, #4]
 80048c4:	2200      	movs	r2, #0
 80048c6:	619a      	str	r2, [r3, #24]
	bat->identity = 'b';
 80048c8:	687b      	ldr	r3, [r7, #4]
 80048ca:	2262      	movs	r2, #98	; 0x62
 80048cc:	711a      	strb	r2, [r3, #4]
	bat->selection = Info;
 80048ce:	687b      	ldr	r3, [r7, #4]
 80048d0:	4a4a      	ldr	r2, [pc, #296]	; (80049fc <initialize+0x218>)
 80048d2:	609a      	str	r2, [r3, #8]
	//Tune
	tune->scrollmax = 3;
 80048d4:	69bb      	ldr	r3, [r7, #24]
 80048d6:	2203      	movs	r2, #3
 80048d8:	60da      	str	r2, [r3, #12]
	tune->selectionmax = 7;
 80048da:	69bb      	ldr	r3, [r7, #24]
 80048dc:	2207      	movs	r2, #7
 80048de:	611a      	str	r2, [r3, #16]
	tune->ttl = Tunemode;
 80048e0:	69bb      	ldr	r3, [r7, #24]
 80048e2:	4a48      	ldr	r2, [pc, #288]	; (8004a04 <initialize+0x220>)
 80048e4:	601a      	str	r2, [r3, #0]
	tune->backout = home;
 80048e6:	69bb      	ldr	r3, [r7, #24]
 80048e8:	6a7a      	ldr	r2, [r7, #36]	; 0x24
 80048ea:	61da      	str	r2, [r3, #28]
	tune->childsel = peg;
 80048ec:	69bb      	ldr	r3, [r7, #24]
 80048ee:	693a      	ldr	r2, [r7, #16]
 80048f0:	619a      	str	r2, [r3, #24]
	tune->nextsel = manual;
 80048f2:	69bb      	ldr	r3, [r7, #24]
 80048f4:	697a      	ldr	r2, [r7, #20]
 80048f6:	615a      	str	r2, [r3, #20]
	tune->identity = 't';
 80048f8:	69bb      	ldr	r3, [r7, #24]
 80048fa:	2274      	movs	r2, #116	; 0x74
 80048fc:	711a      	strb	r2, [r3, #4]
	tune->selection = Tune;
 80048fe:	69bb      	ldr	r3, [r7, #24]
 8004900:	4a41      	ldr	r2, [pc, #260]	; (8004a08 <initialize+0x224>)
 8004902:	609a      	str	r2, [r3, #8]

	//Peg
	peg->scrollmax = 3;
 8004904:	693b      	ldr	r3, [r7, #16]
 8004906:	2203      	movs	r2, #3
 8004908:	60da      	str	r2, [r3, #12]
	peg->selectionmax = 3;
 800490a:	693b      	ldr	r3, [r7, #16]
 800490c:	2203      	movs	r2, #3
 800490e:	611a      	str	r2, [r3, #16]
	peg->ttl = pegDisplay;
 8004910:	693b      	ldr	r3, [r7, #16]
 8004912:	4a3e      	ldr	r2, [pc, #248]	; (8004a0c <initialize+0x228>)
 8004914:	601a      	str	r2, [r3, #0]
	peg->backout = tune;
 8004916:	693b      	ldr	r3, [r7, #16]
 8004918:	69ba      	ldr	r2, [r7, #24]
 800491a:	61da      	str	r2, [r3, #28]
	peg->childsel = Auto;
 800491c:	693b      	ldr	r3, [r7, #16]
 800491e:	68ba      	ldr	r2, [r7, #8]
 8004920:	619a      	str	r2, [r3, #24]
	peg->nextsel = NULL;
 8004922:	693b      	ldr	r3, [r7, #16]
 8004924:	2200      	movs	r2, #0
 8004926:	615a      	str	r2, [r3, #20]
	peg->identity = 'p';
 8004928:	693b      	ldr	r3, [r7, #16]
 800492a:	2270      	movs	r2, #112	; 0x70
 800492c:	711a      	strb	r2, [r3, #4]
	peg->selection = Peg;
 800492e:	693b      	ldr	r3, [r7, #16]
 8004930:	4a37      	ldr	r2, [pc, #220]	; (8004a10 <initialize+0x22c>)
 8004932:	609a      	str	r2, [r3, #8]

	//Auto
	Auto->scrollmax = 0;
 8004934:	68bb      	ldr	r3, [r7, #8]
 8004936:	2200      	movs	r2, #0
 8004938:	60da      	str	r2, [r3, #12]
	Auto->selectionmax = 0;
 800493a:	68bb      	ldr	r3, [r7, #8]
 800493c:	2200      	movs	r2, #0
 800493e:	611a      	str	r2, [r3, #16]
	Auto->ttl = autoRotate;
 8004940:	68bb      	ldr	r3, [r7, #8]
 8004942:	4a34      	ldr	r2, [pc, #208]	; (8004a14 <initialize+0x230>)
 8004944:	601a      	str	r2, [r3, #0]
	Auto->backout = peg;
 8004946:	68bb      	ldr	r3, [r7, #8]
 8004948:	693a      	ldr	r2, [r7, #16]
 800494a:	61da      	str	r2, [r3, #28]
	Auto->childsel = NULL;
 800494c:	68bb      	ldr	r3, [r7, #8]
 800494e:	2200      	movs	r2, #0
 8004950:	619a      	str	r2, [r3, #24]
	Auto->nextsel = samp;
 8004952:	68bb      	ldr	r3, [r7, #8]
 8004954:	69fa      	ldr	r2, [r7, #28]
 8004956:	615a      	str	r2, [r3, #20]
	Auto->identity = 'a';
 8004958:	68bb      	ldr	r3, [r7, #8]
 800495a:	2261      	movs	r2, #97	; 0x61
 800495c:	711a      	strb	r2, [r3, #4]

	//sample
	samp->scrollmax = 0;
 800495e:	69fb      	ldr	r3, [r7, #28]
 8004960:	2200      	movs	r2, #0
 8004962:	60da      	str	r2, [r3, #12]
	samp->selectionmax = 0;
 8004964:	69fb      	ldr	r3, [r7, #28]
 8004966:	2200      	movs	r2, #0
 8004968:	611a      	str	r2, [r3, #16]
	samp->ttl = auto_tune;
 800496a:	69fb      	ldr	r3, [r7, #28]
 800496c:	4a2a      	ldr	r2, [pc, #168]	; (8004a18 <initialize+0x234>)
 800496e:	601a      	str	r2, [r3, #0]
	samp->backout = peg;
 8004970:	69fb      	ldr	r3, [r7, #28]
 8004972:	693a      	ldr	r2, [r7, #16]
 8004974:	61da      	str	r2, [r3, #28]
	samp->childsel = NULL;
 8004976:	69fb      	ldr	r3, [r7, #28]
 8004978:	2200      	movs	r2, #0
 800497a:	619a      	str	r2, [r3, #24]
	samp->nextsel = NULL;
 800497c:	69fb      	ldr	r3, [r7, #28]
 800497e:	2200      	movs	r2, #0
 8004980:	615a      	str	r2, [r3, #20]
	samp->identity = 'a';
 8004982:	69fb      	ldr	r3, [r7, #28]
 8004984:	2261      	movs	r2, #97	; 0x61
 8004986:	711a      	strb	r2, [r3, #4]

	//Manual
	manual->scrollmax = 3;
 8004988:	697b      	ldr	r3, [r7, #20]
 800498a:	2203      	movs	r2, #3
 800498c:	60da      	str	r2, [r3, #12]
	manual->selectionmax = 3;
 800498e:	697b      	ldr	r3, [r7, #20]
 8004990:	2203      	movs	r2, #3
 8004992:	611a      	str	r2, [r3, #16]
	manual->ttl = Infomode;
 8004994:	697b      	ldr	r3, [r7, #20]
 8004996:	4a18      	ldr	r2, [pc, #96]	; (80049f8 <initialize+0x214>)
 8004998:	601a      	str	r2, [r3, #0]
	manual->backout = home;
 800499a:	697b      	ldr	r3, [r7, #20]
 800499c:	6a7a      	ldr	r2, [r7, #36]	; 0x24
 800499e:	61da      	str	r2, [r3, #28]
	manual->childsel = rotate;
 80049a0:	697b      	ldr	r3, [r7, #20]
 80049a2:	68fa      	ldr	r2, [r7, #12]
 80049a4:	619a      	str	r2, [r3, #24]
	manual->nextsel = info;
 80049a6:	697b      	ldr	r3, [r7, #20]
 80049a8:	6a3a      	ldr	r2, [r7, #32]
 80049aa:	615a      	str	r2, [r3, #20]
	manual->identity = 'm';
 80049ac:	697b      	ldr	r3, [r7, #20]
 80049ae:	226d      	movs	r2, #109	; 0x6d
 80049b0:	711a      	strb	r2, [r3, #4]
	manual->selection = Manual;
 80049b2:	697b      	ldr	r3, [r7, #20]
 80049b4:	4a19      	ldr	r2, [pc, #100]	; (8004a1c <initialize+0x238>)
 80049b6:	609a      	str	r2, [r3, #8]

	//backout
	rotate->ttl = manualRotate;
 80049b8:	68fb      	ldr	r3, [r7, #12]
 80049ba:	4a19      	ldr	r2, [pc, #100]	; (8004a20 <initialize+0x23c>)
 80049bc:	601a      	str	r2, [r3, #0]
	rotate->scrollmax = 0;
 80049be:	68fb      	ldr	r3, [r7, #12]
 80049c0:	2200      	movs	r2, #0
 80049c2:	60da      	str	r2, [r3, #12]
	rotate->selectionmax = 0;
 80049c4:	68fb      	ldr	r3, [r7, #12]
 80049c6:	2200      	movs	r2, #0
 80049c8:	611a      	str	r2, [r3, #16]
	rotate->backout = NULL;
 80049ca:	68fb      	ldr	r3, [r7, #12]
 80049cc:	2200      	movs	r2, #0
 80049ce:	61da      	str	r2, [r3, #28]
	rotate->nextsel = NULL;
 80049d0:	68fb      	ldr	r3, [r7, #12]
 80049d2:	2200      	movs	r2, #0
 80049d4:	615a      	str	r2, [r3, #20]
	rotate->childsel = NULL;
 80049d6:	68fb      	ldr	r3, [r7, #12]
 80049d8:	2200      	movs	r2, #0
 80049da:	619a      	str	r2, [r3, #24]
	rotate->identity = 'r';
 80049dc:	68fb      	ldr	r3, [r7, #12]
 80049de:	2272      	movs	r2, #114	; 0x72
 80049e0:	711a      	strb	r2, [r3, #4]
	//back->selection = null;

	currDisplay = home;
 80049e2:	4b10      	ldr	r3, [pc, #64]	; (8004a24 <initialize+0x240>)
 80049e4:	6a7a      	ldr	r2, [r7, #36]	; 0x24
 80049e6:	601a      	str	r2, [r3, #0]
}
 80049e8:	46c0      	nop			; (mov r8, r8)
 80049ea:	46bd      	mov	sp, r7
 80049ec:	b00a      	add	sp, #40	; 0x28
 80049ee:	bd80      	pop	{r7, pc}
 80049f0:	08004a29 	.word	0x08004a29
 80049f4:	20000000 	.word	0x20000000
 80049f8:	08004f79 	.word	0x08004f79
 80049fc:	20000034 	.word	0x20000034
 8004a00:	08004721 	.word	0x08004721
 8004a04:	080050f9 	.word	0x080050f9
 8004a08:	2000000c 	.word	0x2000000c
 8004a0c:	080051c5 	.word	0x080051c5
 8004a10:	2000003c 	.word	0x2000003c
 8004a14:	08004fc5 	.word	0x08004fc5
 8004a18:	08004751 	.word	0x08004751
 8004a1c:	20000028 	.word	0x20000028
 8004a20:	08004fa5 	.word	0x08004fa5
 8004a24:	200022d4 	.word	0x200022d4

08004a28 <menu_home>:
struct display *currDisplay;
void menu_home()
{
 8004a28:	b580      	push	{r7, lr}
 8004a2a:	b084      	sub	sp, #16
 8004a2c:	af04      	add	r7, sp, #16
LCD_DrawString(25,200,  YELLOW, BLACK, menu[0], 16, 0);
 8004a2e:	4b0e      	ldr	r3, [pc, #56]	; (8004a68 <menu_home+0x40>)
 8004a30:	681b      	ldr	r3, [r3, #0]
 8004a32:	490e      	ldr	r1, [pc, #56]	; (8004a6c <menu_home+0x44>)
 8004a34:	2200      	movs	r2, #0
 8004a36:	9202      	str	r2, [sp, #8]
 8004a38:	2210      	movs	r2, #16
 8004a3a:	9201      	str	r2, [sp, #4]
 8004a3c:	9300      	str	r3, [sp, #0]
 8004a3e:	2300      	movs	r3, #0
 8004a40:	000a      	movs	r2, r1
 8004a42:	21c8      	movs	r1, #200	; 0xc8
 8004a44:	2019      	movs	r0, #25
 8004a46:	f7ff f999 	bl	8003d7c <LCD_DrawString>
LCD_DrawString(80 ,40,  YELLOW, BLUE,"Home Menu", 16, 0);
 8004a4a:	4a08      	ldr	r2, [pc, #32]	; (8004a6c <menu_home+0x44>)
 8004a4c:	2300      	movs	r3, #0
 8004a4e:	9302      	str	r3, [sp, #8]
 8004a50:	2310      	movs	r3, #16
 8004a52:	9301      	str	r3, [sp, #4]
 8004a54:	4b06      	ldr	r3, [pc, #24]	; (8004a70 <menu_home+0x48>)
 8004a56:	9300      	str	r3, [sp, #0]
 8004a58:	231f      	movs	r3, #31
 8004a5a:	2128      	movs	r1, #40	; 0x28
 8004a5c:	2050      	movs	r0, #80	; 0x50
 8004a5e:	f7ff f98d 	bl	8003d7c <LCD_DrawString>
}
 8004a62:	46c0      	nop			; (mov r8, r8)
 8004a64:	46bd      	mov	sp, r7
 8004a66:	bd80      	pop	{r7, pc}
 8004a68:	20000000 	.word	0x20000000
 8004a6c:	0000ffe0 	.word	0x0000ffe0
 8004a70:	0800e444 	.word	0x0800e444

08004a74 <move_right>:
void move_right()
{
 8004a74:	b580      	push	{r7, lr}
 8004a76:	af00      	add	r7, sp, #0
	if (currentScrollIndex == (currDisplay->scrollmax -1)) {
 8004a78:	4b14      	ldr	r3, [pc, #80]	; (8004acc <move_right+0x58>)
 8004a7a:	681b      	ldr	r3, [r3, #0]
 8004a7c:	68db      	ldr	r3, [r3, #12]
 8004a7e:	1e5a      	subs	r2, r3, #1
 8004a80:	4b13      	ldr	r3, [pc, #76]	; (8004ad0 <move_right+0x5c>)
 8004a82:	681b      	ldr	r3, [r3, #0]
 8004a84:	429a      	cmp	r2, r3
 8004a86:	d10a      	bne.n	8004a9e <move_right+0x2a>
					//if highlighted choice is very last choice, wrap around to first choice
					display_move(currentScrollIndex +1, currentSelectIndex+1,2);
 8004a88:	4b11      	ldr	r3, [pc, #68]	; (8004ad0 <move_right+0x5c>)
 8004a8a:	681b      	ldr	r3, [r3, #0]
 8004a8c:	1c58      	adds	r0, r3, #1
 8004a8e:	4b11      	ldr	r3, [pc, #68]	; (8004ad4 <move_right+0x60>)
 8004a90:	681b      	ldr	r3, [r3, #0]
 8004a92:	3301      	adds	r3, #1
 8004a94:	2202      	movs	r2, #2
 8004a96:	0019      	movs	r1, r3
 8004a98:	f000 f852 	bl	8004b40 <display_move>
 8004a9c:	e009      	b.n	8004ab2 <move_right+0x3e>
				} else {
					//else just highlight selection to previous choice
					display_move(currentScrollIndex +1, currentSelectIndex+1,0);
 8004a9e:	4b0c      	ldr	r3, [pc, #48]	; (8004ad0 <move_right+0x5c>)
 8004aa0:	681b      	ldr	r3, [r3, #0]
 8004aa2:	1c58      	adds	r0, r3, #1
 8004aa4:	4b0b      	ldr	r3, [pc, #44]	; (8004ad4 <move_right+0x60>)
 8004aa6:	681b      	ldr	r3, [r3, #0]
 8004aa8:	3301      	adds	r3, #1
 8004aaa:	2200      	movs	r2, #0
 8004aac:	0019      	movs	r1, r3
 8004aae:	f000 f847 	bl	8004b40 <display_move>
				}
				HAL_GPIO_WritePin(GPIOC, GPIO_PIN_8, GPIO_PIN_SET);
 8004ab2:	2380      	movs	r3, #128	; 0x80
 8004ab4:	005b      	lsls	r3, r3, #1
 8004ab6:	4808      	ldr	r0, [pc, #32]	; (8004ad8 <move_right+0x64>)
 8004ab8:	2201      	movs	r2, #1
 8004aba:	0019      	movs	r1, r3
 8004abc:	f001 ffd3 	bl	8006a66 <HAL_GPIO_WritePin>
				goright = 0; // reset right indication flag
 8004ac0:	4b06      	ldr	r3, [pc, #24]	; (8004adc <move_right+0x68>)
 8004ac2:	2200      	movs	r2, #0
 8004ac4:	601a      	str	r2, [r3, #0]
}
 8004ac6:	46c0      	nop			; (mov r8, r8)
 8004ac8:	46bd      	mov	sp, r7
 8004aca:	bd80      	pop	{r7, pc}
 8004acc:	200022d4 	.word	0x200022d4
 8004ad0:	20002110 	.word	0x20002110
 8004ad4:	2000210c 	.word	0x2000210c
 8004ad8:	48000800 	.word	0x48000800
 8004adc:	20002118 	.word	0x20002118

08004ae0 <move_left>:
void move_left()
{
 8004ae0:	b580      	push	{r7, lr}
 8004ae2:	af00      	add	r7, sp, #0
	if (currentScrollIndex == 0) {
 8004ae4:	4b12      	ldr	r3, [pc, #72]	; (8004b30 <move_left+0x50>)
 8004ae6:	681b      	ldr	r3, [r3, #0]
 8004ae8:	2b00      	cmp	r3, #0
 8004aea:	d10a      	bne.n	8004b02 <move_left+0x22>
					//if highlighted choice is very first choice, wrap around to last choice
					display_move(currentScrollIndex -1, currentSelectIndex-1,1);
 8004aec:	4b10      	ldr	r3, [pc, #64]	; (8004b30 <move_left+0x50>)
 8004aee:	681b      	ldr	r3, [r3, #0]
 8004af0:	1e58      	subs	r0, r3, #1
 8004af2:	4b10      	ldr	r3, [pc, #64]	; (8004b34 <move_left+0x54>)
 8004af4:	681b      	ldr	r3, [r3, #0]
 8004af6:	3b01      	subs	r3, #1
 8004af8:	2201      	movs	r2, #1
 8004afa:	0019      	movs	r1, r3
 8004afc:	f000 f820 	bl	8004b40 <display_move>
 8004b00:	e009      	b.n	8004b16 <move_left+0x36>

				} else {
					//else just highlight selection left to previous choice
					display_move(currentScrollIndex -1, currentSelectIndex-1,0);
 8004b02:	4b0b      	ldr	r3, [pc, #44]	; (8004b30 <move_left+0x50>)
 8004b04:	681b      	ldr	r3, [r3, #0]
 8004b06:	1e58      	subs	r0, r3, #1
 8004b08:	4b0a      	ldr	r3, [pc, #40]	; (8004b34 <move_left+0x54>)
 8004b0a:	681b      	ldr	r3, [r3, #0]
 8004b0c:	3b01      	subs	r3, #1
 8004b0e:	2200      	movs	r2, #0
 8004b10:	0019      	movs	r1, r3
 8004b12:	f000 f815 	bl	8004b40 <display_move>
				}
				HAL_GPIO_WritePin(GPIOC, GPIO_PIN_8, GPIO_PIN_SET);
 8004b16:	2380      	movs	r3, #128	; 0x80
 8004b18:	005b      	lsls	r3, r3, #1
 8004b1a:	4807      	ldr	r0, [pc, #28]	; (8004b38 <move_left+0x58>)
 8004b1c:	2201      	movs	r2, #1
 8004b1e:	0019      	movs	r1, r3
 8004b20:	f001 ffa1 	bl	8006a66 <HAL_GPIO_WritePin>
				goleft = 0; //reset left indication flag
 8004b24:	4b05      	ldr	r3, [pc, #20]	; (8004b3c <move_left+0x5c>)
 8004b26:	2200      	movs	r2, #0
 8004b28:	601a      	str	r2, [r3, #0]
}
 8004b2a:	46c0      	nop			; (mov r8, r8)
 8004b2c:	46bd      	mov	sp, r7
 8004b2e:	bd80      	pop	{r7, pc}
 8004b30:	20002110 	.word	0x20002110
 8004b34:	2000210c 	.word	0x2000210c
 8004b38:	48000800 	.word	0x48000800
 8004b3c:	20002114 	.word	0x20002114

08004b40 <display_move>:
void display_move(int scrollIndex, int selectIndex, int enable) {
 8004b40:	b580      	push	{r7, lr}
 8004b42:	b08c      	sub	sp, #48	; 0x30
 8004b44:	af04      	add	r7, sp, #16
 8004b46:	60f8      	str	r0, [r7, #12]
 8004b48:	60b9      	str	r1, [r7, #8]
 8004b4a:	607a      	str	r2, [r7, #4]
	//just unhighlighting previous choice and highlighting current choice
	if((currDisplay->selectionmax > 3) && (enable > 0))
 8004b4c:	4b8d      	ldr	r3, [pc, #564]	; (8004d84 <display_move+0x244>)
 8004b4e:	681b      	ldr	r3, [r3, #0]
 8004b50:	691b      	ldr	r3, [r3, #16]
 8004b52:	2b03      	cmp	r3, #3
 8004b54:	dc00      	bgt.n	8004b58 <display_move+0x18>
 8004b56:	e0a8      	b.n	8004caa <display_move+0x16a>
 8004b58:	687b      	ldr	r3, [r7, #4]
 8004b5a:	2b00      	cmp	r3, #0
 8004b5c:	dc00      	bgt.n	8004b60 <display_move+0x20>
 8004b5e:	e0a4      	b.n	8004caa <display_move+0x16a>
	{
		if(enable == 1)
 8004b60:	687b      	ldr	r3, [r7, #4]
 8004b62:	2b01      	cmp	r3, #1
 8004b64:	d150      	bne.n	8004c08 <display_move+0xc8>
		{
			if(selectIndex < 0)
 8004b66:	68bb      	ldr	r3, [r7, #8]
 8004b68:	2b00      	cmp	r3, #0
 8004b6a:	da04      	bge.n	8004b76 <display_move+0x36>
				selectIndex = currDisplay->selectionmax-1;
 8004b6c:	4b85      	ldr	r3, [pc, #532]	; (8004d84 <display_move+0x244>)
 8004b6e:	681b      	ldr	r3, [r3, #0]
 8004b70:	691b      	ldr	r3, [r3, #16]
 8004b72:	3b01      	subs	r3, #1
 8004b74:	60bb      	str	r3, [r7, #8]
			LCD_DrawString(25,200,  YELLOW, BLACK, currDisplay->selection[selectIndex], 16, 0);
 8004b76:	4b83      	ldr	r3, [pc, #524]	; (8004d84 <display_move+0x244>)
 8004b78:	681b      	ldr	r3, [r3, #0]
 8004b7a:	689a      	ldr	r2, [r3, #8]
 8004b7c:	68bb      	ldr	r3, [r7, #8]
 8004b7e:	009b      	lsls	r3, r3, #2
 8004b80:	18d3      	adds	r3, r2, r3
 8004b82:	681b      	ldr	r3, [r3, #0]
 8004b84:	4980      	ldr	r1, [pc, #512]	; (8004d88 <display_move+0x248>)
 8004b86:	2200      	movs	r2, #0
 8004b88:	9202      	str	r2, [sp, #8]
 8004b8a:	2210      	movs	r2, #16
 8004b8c:	9201      	str	r2, [sp, #4]
 8004b8e:	9300      	str	r3, [sp, #0]
 8004b90:	2300      	movs	r3, #0
 8004b92:	000a      	movs	r2, r1
 8004b94:	21c8      	movs	r1, #200	; 0xc8
 8004b96:	2019      	movs	r0, #25
 8004b98:	f7ff f8f0 	bl	8003d7c <LCD_DrawString>
			int idx = selectIndex;
 8004b9c:	68bb      	ldr	r3, [r7, #8]
 8004b9e:	61fb      	str	r3, [r7, #28]
			for(int i = 1; i < 3; i++)
 8004ba0:	2301      	movs	r3, #1
 8004ba2:	61bb      	str	r3, [r7, #24]
 8004ba4:	e02a      	b.n	8004bfc <display_move+0xbc>
				{idx++;
 8004ba6:	69fb      	ldr	r3, [r7, #28]
 8004ba8:	3301      	adds	r3, #1
 8004baa:	61fb      	str	r3, [r7, #28]
				if(idx >= currDisplay->selectionmax)
 8004bac:	4b75      	ldr	r3, [pc, #468]	; (8004d84 <display_move+0x244>)
 8004bae:	681b      	ldr	r3, [r3, #0]
 8004bb0:	691b      	ldr	r3, [r3, #16]
 8004bb2:	69fa      	ldr	r2, [r7, #28]
 8004bb4:	429a      	cmp	r2, r3
 8004bb6:	db01      	blt.n	8004bbc <display_move+0x7c>
					idx = 0;
 8004bb8:	2300      	movs	r3, #0
 8004bba:	61fb      	str	r3, [r7, #28]
				LCD_DrawString(75*i + 25,200,  YELLOW, BLUE, currDisplay->selection[idx], 16, 0);
 8004bbc:	69bb      	ldr	r3, [r7, #24]
 8004bbe:	b29b      	uxth	r3, r3
 8004bc0:	1c1a      	adds	r2, r3, #0
 8004bc2:	0092      	lsls	r2, r2, #2
 8004bc4:	18d3      	adds	r3, r2, r3
 8004bc6:	1c1a      	adds	r2, r3, #0
 8004bc8:	0112      	lsls	r2, r2, #4
 8004bca:	1ad3      	subs	r3, r2, r3
 8004bcc:	b29b      	uxth	r3, r3
 8004bce:	3319      	adds	r3, #25
 8004bd0:	b298      	uxth	r0, r3
 8004bd2:	4b6c      	ldr	r3, [pc, #432]	; (8004d84 <display_move+0x244>)
 8004bd4:	681b      	ldr	r3, [r3, #0]
 8004bd6:	689a      	ldr	r2, [r3, #8]
 8004bd8:	69fb      	ldr	r3, [r7, #28]
 8004bda:	009b      	lsls	r3, r3, #2
 8004bdc:	18d3      	adds	r3, r2, r3
 8004bde:	681b      	ldr	r3, [r3, #0]
 8004be0:	4969      	ldr	r1, [pc, #420]	; (8004d88 <display_move+0x248>)
 8004be2:	2200      	movs	r2, #0
 8004be4:	9202      	str	r2, [sp, #8]
 8004be6:	2210      	movs	r2, #16
 8004be8:	9201      	str	r2, [sp, #4]
 8004bea:	9300      	str	r3, [sp, #0]
 8004bec:	231f      	movs	r3, #31
 8004bee:	000a      	movs	r2, r1
 8004bf0:	21c8      	movs	r1, #200	; 0xc8
 8004bf2:	f7ff f8c3 	bl	8003d7c <LCD_DrawString>
			for(int i = 1; i < 3; i++)
 8004bf6:	69bb      	ldr	r3, [r7, #24]
 8004bf8:	3301      	adds	r3, #1
 8004bfa:	61bb      	str	r3, [r7, #24]
 8004bfc:	69bb      	ldr	r3, [r7, #24]
 8004bfe:	2b02      	cmp	r3, #2
 8004c00:	ddd1      	ble.n	8004ba6 <display_move+0x66>
				}
			scrollIndex = 0;
 8004c02:	2300      	movs	r3, #0
 8004c04:	60fb      	str	r3, [r7, #12]
		if(enable == 1)
 8004c06:	e0b2      	b.n	8004d6e <display_move+0x22e>
		}
		else
		{
			if(selectIndex >= currDisplay->selectionmax)
 8004c08:	4b5e      	ldr	r3, [pc, #376]	; (8004d84 <display_move+0x244>)
 8004c0a:	681b      	ldr	r3, [r3, #0]
 8004c0c:	691b      	ldr	r3, [r3, #16]
 8004c0e:	68ba      	ldr	r2, [r7, #8]
 8004c10:	429a      	cmp	r2, r3
 8004c12:	db01      	blt.n	8004c18 <display_move+0xd8>
				selectIndex = 0;
 8004c14:	2300      	movs	r3, #0
 8004c16:	60bb      	str	r3, [r7, #8]
			LCD_DrawString(75*2 +25,200,  YELLOW, BLACK, currDisplay->selection[selectIndex], 16, 0);
 8004c18:	4b5a      	ldr	r3, [pc, #360]	; (8004d84 <display_move+0x244>)
 8004c1a:	681b      	ldr	r3, [r3, #0]
 8004c1c:	689a      	ldr	r2, [r3, #8]
 8004c1e:	68bb      	ldr	r3, [r7, #8]
 8004c20:	009b      	lsls	r3, r3, #2
 8004c22:	18d3      	adds	r3, r2, r3
 8004c24:	681b      	ldr	r3, [r3, #0]
 8004c26:	4958      	ldr	r1, [pc, #352]	; (8004d88 <display_move+0x248>)
 8004c28:	2200      	movs	r2, #0
 8004c2a:	9202      	str	r2, [sp, #8]
 8004c2c:	2210      	movs	r2, #16
 8004c2e:	9201      	str	r2, [sp, #4]
 8004c30:	9300      	str	r3, [sp, #0]
 8004c32:	2300      	movs	r3, #0
 8004c34:	000a      	movs	r2, r1
 8004c36:	21c8      	movs	r1, #200	; 0xc8
 8004c38:	20af      	movs	r0, #175	; 0xaf
 8004c3a:	f7ff f89f 	bl	8003d7c <LCD_DrawString>
			int idx = selectIndex;
 8004c3e:	68bb      	ldr	r3, [r7, #8]
 8004c40:	617b      	str	r3, [r7, #20]
			for(int i = 1; i >= 0; i--)
 8004c42:	2301      	movs	r3, #1
 8004c44:	613b      	str	r3, [r7, #16]
 8004c46:	e02a      	b.n	8004c9e <display_move+0x15e>
			{idx--;
 8004c48:	697b      	ldr	r3, [r7, #20]
 8004c4a:	3b01      	subs	r3, #1
 8004c4c:	617b      	str	r3, [r7, #20]
			if(idx < 0)
 8004c4e:	697b      	ldr	r3, [r7, #20]
 8004c50:	2b00      	cmp	r3, #0
 8004c52:	da04      	bge.n	8004c5e <display_move+0x11e>
				idx = currDisplay->selectionmax-1;
 8004c54:	4b4b      	ldr	r3, [pc, #300]	; (8004d84 <display_move+0x244>)
 8004c56:	681b      	ldr	r3, [r3, #0]
 8004c58:	691b      	ldr	r3, [r3, #16]
 8004c5a:	3b01      	subs	r3, #1
 8004c5c:	617b      	str	r3, [r7, #20]
			LCD_DrawString(75*i + 25,200,  YELLOW, BLUE, currDisplay->selection[idx], 16, 0);
 8004c5e:	693b      	ldr	r3, [r7, #16]
 8004c60:	b29b      	uxth	r3, r3
 8004c62:	1c1a      	adds	r2, r3, #0
 8004c64:	0092      	lsls	r2, r2, #2
 8004c66:	18d3      	adds	r3, r2, r3
 8004c68:	1c1a      	adds	r2, r3, #0
 8004c6a:	0112      	lsls	r2, r2, #4
 8004c6c:	1ad3      	subs	r3, r2, r3
 8004c6e:	b29b      	uxth	r3, r3
 8004c70:	3319      	adds	r3, #25
 8004c72:	b298      	uxth	r0, r3
 8004c74:	4b43      	ldr	r3, [pc, #268]	; (8004d84 <display_move+0x244>)
 8004c76:	681b      	ldr	r3, [r3, #0]
 8004c78:	689a      	ldr	r2, [r3, #8]
 8004c7a:	697b      	ldr	r3, [r7, #20]
 8004c7c:	009b      	lsls	r3, r3, #2
 8004c7e:	18d3      	adds	r3, r2, r3
 8004c80:	681b      	ldr	r3, [r3, #0]
 8004c82:	4941      	ldr	r1, [pc, #260]	; (8004d88 <display_move+0x248>)
 8004c84:	2200      	movs	r2, #0
 8004c86:	9202      	str	r2, [sp, #8]
 8004c88:	2210      	movs	r2, #16
 8004c8a:	9201      	str	r2, [sp, #4]
 8004c8c:	9300      	str	r3, [sp, #0]
 8004c8e:	231f      	movs	r3, #31
 8004c90:	000a      	movs	r2, r1
 8004c92:	21c8      	movs	r1, #200	; 0xc8
 8004c94:	f7ff f872 	bl	8003d7c <LCD_DrawString>
			for(int i = 1; i >= 0; i--)
 8004c98:	693b      	ldr	r3, [r7, #16]
 8004c9a:	3b01      	subs	r3, #1
 8004c9c:	613b      	str	r3, [r7, #16]
 8004c9e:	693b      	ldr	r3, [r7, #16]
 8004ca0:	2b00      	cmp	r3, #0
 8004ca2:	dad1      	bge.n	8004c48 <display_move+0x108>
			}
			scrollIndex = 2;
 8004ca4:	2302      	movs	r3, #2
 8004ca6:	60fb      	str	r3, [r7, #12]
		if(enable == 1)
 8004ca8:	e061      	b.n	8004d6e <display_move+0x22e>
		}
	}
	else
	{
	if(enable == 1)
 8004caa:	687b      	ldr	r3, [r7, #4]
 8004cac:	2b01      	cmp	r3, #1
 8004cae:	d10a      	bne.n	8004cc6 <display_move+0x186>
		{selectIndex = currDisplay->selectionmax-1; scrollIndex = currDisplay->scrollmax-1;}
 8004cb0:	4b34      	ldr	r3, [pc, #208]	; (8004d84 <display_move+0x244>)
 8004cb2:	681b      	ldr	r3, [r3, #0]
 8004cb4:	691b      	ldr	r3, [r3, #16]
 8004cb6:	3b01      	subs	r3, #1
 8004cb8:	60bb      	str	r3, [r7, #8]
 8004cba:	4b32      	ldr	r3, [pc, #200]	; (8004d84 <display_move+0x244>)
 8004cbc:	681b      	ldr	r3, [r3, #0]
 8004cbe:	68db      	ldr	r3, [r3, #12]
 8004cc0:	3b01      	subs	r3, #1
 8004cc2:	60fb      	str	r3, [r7, #12]
 8004cc4:	e006      	b.n	8004cd4 <display_move+0x194>
	else if(enable == 2)
 8004cc6:	687b      	ldr	r3, [r7, #4]
 8004cc8:	2b02      	cmp	r3, #2
 8004cca:	d103      	bne.n	8004cd4 <display_move+0x194>
		{selectIndex = 0; scrollIndex = 0;}
 8004ccc:	2300      	movs	r3, #0
 8004cce:	60bb      	str	r3, [r7, #8]
 8004cd0:	2300      	movs	r3, #0
 8004cd2:	60fb      	str	r3, [r7, #12]
	if(selectIndex > currDisplay->selectionmax-1)
 8004cd4:	4b2b      	ldr	r3, [pc, #172]	; (8004d84 <display_move+0x244>)
 8004cd6:	681b      	ldr	r3, [r3, #0]
 8004cd8:	691b      	ldr	r3, [r3, #16]
 8004cda:	68ba      	ldr	r2, [r7, #8]
 8004cdc:	429a      	cmp	r2, r3
 8004cde:	db02      	blt.n	8004ce6 <display_move+0x1a6>
		selectIndex = 0;
 8004ce0:	2300      	movs	r3, #0
 8004ce2:	60bb      	str	r3, [r7, #8]
 8004ce4:	e007      	b.n	8004cf6 <display_move+0x1b6>
	else if(selectIndex < 0)
 8004ce6:	68bb      	ldr	r3, [r7, #8]
 8004ce8:	2b00      	cmp	r3, #0
 8004cea:	da04      	bge.n	8004cf6 <display_move+0x1b6>
		selectIndex = currDisplay->selectionmax-1;
 8004cec:	4b25      	ldr	r3, [pc, #148]	; (8004d84 <display_move+0x244>)
 8004cee:	681b      	ldr	r3, [r3, #0]
 8004cf0:	691b      	ldr	r3, [r3, #16]
 8004cf2:	3b01      	subs	r3, #1
 8004cf4:	60bb      	str	r3, [r7, #8]

	LCD_DrawString(75*scrollIndex + 25,200,  YELLOW, BLACK, currDisplay->selection[selectIndex], 16, 0);
 8004cf6:	68fb      	ldr	r3, [r7, #12]
 8004cf8:	b29b      	uxth	r3, r3
 8004cfa:	1c1a      	adds	r2, r3, #0
 8004cfc:	0092      	lsls	r2, r2, #2
 8004cfe:	18d3      	adds	r3, r2, r3
 8004d00:	1c1a      	adds	r2, r3, #0
 8004d02:	0112      	lsls	r2, r2, #4
 8004d04:	1ad3      	subs	r3, r2, r3
 8004d06:	b29b      	uxth	r3, r3
 8004d08:	3319      	adds	r3, #25
 8004d0a:	b298      	uxth	r0, r3
 8004d0c:	4b1d      	ldr	r3, [pc, #116]	; (8004d84 <display_move+0x244>)
 8004d0e:	681b      	ldr	r3, [r3, #0]
 8004d10:	689a      	ldr	r2, [r3, #8]
 8004d12:	68bb      	ldr	r3, [r7, #8]
 8004d14:	009b      	lsls	r3, r3, #2
 8004d16:	18d3      	adds	r3, r2, r3
 8004d18:	681b      	ldr	r3, [r3, #0]
 8004d1a:	491b      	ldr	r1, [pc, #108]	; (8004d88 <display_move+0x248>)
 8004d1c:	2200      	movs	r2, #0
 8004d1e:	9202      	str	r2, [sp, #8]
 8004d20:	2210      	movs	r2, #16
 8004d22:	9201      	str	r2, [sp, #4]
 8004d24:	9300      	str	r3, [sp, #0]
 8004d26:	2300      	movs	r3, #0
 8004d28:	000a      	movs	r2, r1
 8004d2a:	21c8      	movs	r1, #200	; 0xc8
 8004d2c:	f7ff f826 	bl	8003d7c <LCD_DrawString>
	LCD_DrawString(75*currentScrollIndex + 25,200,  YELLOW, BLUE, currDisplay->selection[currentSelectIndex], 16, 0);
 8004d30:	4b16      	ldr	r3, [pc, #88]	; (8004d8c <display_move+0x24c>)
 8004d32:	681b      	ldr	r3, [r3, #0]
 8004d34:	b29b      	uxth	r3, r3
 8004d36:	1c1a      	adds	r2, r3, #0
 8004d38:	0092      	lsls	r2, r2, #2
 8004d3a:	18d3      	adds	r3, r2, r3
 8004d3c:	1c1a      	adds	r2, r3, #0
 8004d3e:	0112      	lsls	r2, r2, #4
 8004d40:	1ad3      	subs	r3, r2, r3
 8004d42:	b29b      	uxth	r3, r3
 8004d44:	3319      	adds	r3, #25
 8004d46:	b298      	uxth	r0, r3
 8004d48:	4b0e      	ldr	r3, [pc, #56]	; (8004d84 <display_move+0x244>)
 8004d4a:	681b      	ldr	r3, [r3, #0]
 8004d4c:	689a      	ldr	r2, [r3, #8]
 8004d4e:	4b10      	ldr	r3, [pc, #64]	; (8004d90 <display_move+0x250>)
 8004d50:	681b      	ldr	r3, [r3, #0]
 8004d52:	009b      	lsls	r3, r3, #2
 8004d54:	18d3      	adds	r3, r2, r3
 8004d56:	681b      	ldr	r3, [r3, #0]
 8004d58:	490b      	ldr	r1, [pc, #44]	; (8004d88 <display_move+0x248>)
 8004d5a:	2200      	movs	r2, #0
 8004d5c:	9202      	str	r2, [sp, #8]
 8004d5e:	2210      	movs	r2, #16
 8004d60:	9201      	str	r2, [sp, #4]
 8004d62:	9300      	str	r3, [sp, #0]
 8004d64:	231f      	movs	r3, #31
 8004d66:	000a      	movs	r2, r1
 8004d68:	21c8      	movs	r1, #200	; 0xc8
 8004d6a:	f7ff f807 	bl	8003d7c <LCD_DrawString>
	}
	currentSelectIndex = selectIndex;
 8004d6e:	4b08      	ldr	r3, [pc, #32]	; (8004d90 <display_move+0x250>)
 8004d70:	68ba      	ldr	r2, [r7, #8]
 8004d72:	601a      	str	r2, [r3, #0]
	currentScrollIndex = scrollIndex;
 8004d74:	4b05      	ldr	r3, [pc, #20]	; (8004d8c <display_move+0x24c>)
 8004d76:	68fa      	ldr	r2, [r7, #12]
 8004d78:	601a      	str	r2, [r3, #0]
}
 8004d7a:	46c0      	nop			; (mov r8, r8)
 8004d7c:	46bd      	mov	sp, r7
 8004d7e:	b008      	add	sp, #32
 8004d80:	bd80      	pop	{r7, pc}
 8004d82:	46c0      	nop			; (mov r8, r8)
 8004d84:	200022d4 	.word	0x200022d4
 8004d88:	0000ffe0 	.word	0x0000ffe0
 8004d8c:	20002110 	.word	0x20002110
 8004d90:	2000210c 	.word	0x2000210c

08004d94 <display_select>:

void display_select(int selectIndex) {
 8004d94:	b590      	push	{r4, r7, lr}
 8004d96:	b089      	sub	sp, #36	; 0x24
 8004d98:	af04      	add	r7, sp, #16
 8004d9a:	6078      	str	r0, [r7, #4]
	//selection cases of where to go
	//highlight selected choice in red
    LCD_DrawString(75*currentScrollIndex + 25,200,  YELLOW, RED, currDisplay->selection[currentSelectIndex], 16, 0);
 8004d9c:	4b4a      	ldr	r3, [pc, #296]	; (8004ec8 <display_select+0x134>)
 8004d9e:	681b      	ldr	r3, [r3, #0]
 8004da0:	b29b      	uxth	r3, r3
 8004da2:	1c1a      	adds	r2, r3, #0
 8004da4:	0092      	lsls	r2, r2, #2
 8004da6:	18d3      	adds	r3, r2, r3
 8004da8:	1c1a      	adds	r2, r3, #0
 8004daa:	0112      	lsls	r2, r2, #4
 8004dac:	1ad3      	subs	r3, r2, r3
 8004dae:	b29b      	uxth	r3, r3
 8004db0:	3319      	adds	r3, #25
 8004db2:	b298      	uxth	r0, r3
 8004db4:	4b45      	ldr	r3, [pc, #276]	; (8004ecc <display_select+0x138>)
 8004db6:	681b      	ldr	r3, [r3, #0]
 8004db8:	689a      	ldr	r2, [r3, #8]
 8004dba:	4b45      	ldr	r3, [pc, #276]	; (8004ed0 <display_select+0x13c>)
 8004dbc:	681b      	ldr	r3, [r3, #0]
 8004dbe:	009b      	lsls	r3, r3, #2
 8004dc0:	18d3      	adds	r3, r2, r3
 8004dc2:	681b      	ldr	r3, [r3, #0]
 8004dc4:	22f8      	movs	r2, #248	; 0xf8
 8004dc6:	0212      	lsls	r2, r2, #8
 8004dc8:	4c42      	ldr	r4, [pc, #264]	; (8004ed4 <display_select+0x140>)
 8004dca:	2100      	movs	r1, #0
 8004dcc:	9102      	str	r1, [sp, #8]
 8004dce:	2110      	movs	r1, #16
 8004dd0:	9101      	str	r1, [sp, #4]
 8004dd2:	9300      	str	r3, [sp, #0]
 8004dd4:	0013      	movs	r3, r2
 8004dd6:	0022      	movs	r2, r4
 8004dd8:	21c8      	movs	r1, #200	; 0xc8
 8004dda:	f7fe ffcf 	bl	8003d7c <LCD_DrawString>
    lastPressed = selectIndex;
 8004dde:	687b      	ldr	r3, [r7, #4]
 8004de0:	b2da      	uxtb	r2, r3
 8004de2:	4b3d      	ldr	r3, [pc, #244]	; (8004ed8 <display_select+0x144>)
 8004de4:	701a      	strb	r2, [r3, #0]

    if((currentSelectIndex == 0) && (currDisplay->identity != 'h'))
 8004de6:	4b3a      	ldr	r3, [pc, #232]	; (8004ed0 <display_select+0x13c>)
 8004de8:	681b      	ldr	r3, [r3, #0]
 8004dea:	2b00      	cmp	r3, #0
 8004dec:	d113      	bne.n	8004e16 <display_select+0x82>
 8004dee:	4b37      	ldr	r3, [pc, #220]	; (8004ecc <display_select+0x138>)
 8004df0:	681b      	ldr	r3, [r3, #0]
 8004df2:	791b      	ldrb	r3, [r3, #4]
 8004df4:	2b68      	cmp	r3, #104	; 0x68
 8004df6:	d00e      	beq.n	8004e16 <display_select+0x82>
    {//Tune mode is selected so go to tune display
    	currDisplay = currDisplay->backout;
 8004df8:	4b34      	ldr	r3, [pc, #208]	; (8004ecc <display_select+0x138>)
 8004dfa:	681b      	ldr	r3, [r3, #0]
 8004dfc:	69da      	ldr	r2, [r3, #28]
 8004dfe:	4b33      	ldr	r3, [pc, #204]	; (8004ecc <display_select+0x138>)
 8004e00:	601a      	str	r2, [r3, #0]
    	LCD_Clear(BLUE);
 8004e02:	201f      	movs	r0, #31
 8004e04:	f7fe fde4 	bl	80039d0 <LCD_Clear>
    	resetSel();
 8004e08:	f000 f868 	bl	8004edc <resetSel>
    	currDisplay->ttl();
 8004e0c:	4b2f      	ldr	r3, [pc, #188]	; (8004ecc <display_select+0x138>)
 8004e0e:	681b      	ldr	r3, [r3, #0]
 8004e10:	681b      	ldr	r3, [r3, #0]
 8004e12:	4798      	blx	r3
    	{
    		child->ttl();
    		LCD_DrawString(75*selectIndex + 25,200,  YELLOW, BLACK, currDisplay->selection[selectIndex], 16, 0);
    	}
    }
}
 8004e14:	e053      	b.n	8004ebe <display_select+0x12a>
    else if(currDisplay->childsel != NULL)
 8004e16:	4b2d      	ldr	r3, [pc, #180]	; (8004ecc <display_select+0x138>)
 8004e18:	681b      	ldr	r3, [r3, #0]
 8004e1a:	699b      	ldr	r3, [r3, #24]
 8004e1c:	2b00      	cmp	r3, #0
 8004e1e:	d04e      	beq.n	8004ebe <display_select+0x12a>
    	struct display * child = currDisplay->childsel;
 8004e20:	4b2a      	ldr	r3, [pc, #168]	; (8004ecc <display_select+0x138>)
 8004e22:	681b      	ldr	r3, [r3, #0]
 8004e24:	699b      	ldr	r3, [r3, #24]
 8004e26:	60fb      	str	r3, [r7, #12]
    	if(currDisplay->identity == 'h'){i = 0;}
 8004e28:	4b28      	ldr	r3, [pc, #160]	; (8004ecc <display_select+0x138>)
 8004e2a:	681b      	ldr	r3, [r3, #0]
 8004e2c:	791b      	ldrb	r3, [r3, #4]
 8004e2e:	2b68      	cmp	r3, #104	; 0x68
 8004e30:	d102      	bne.n	8004e38 <display_select+0xa4>
 8004e32:	2300      	movs	r3, #0
 8004e34:	60bb      	str	r3, [r7, #8]
 8004e36:	e008      	b.n	8004e4a <display_select+0xb6>
    		i = 1;
 8004e38:	2301      	movs	r3, #1
 8004e3a:	60bb      	str	r3, [r7, #8]
    	while((i < currentSelectIndex)&&(child->nextsel != NULL))
 8004e3c:	e005      	b.n	8004e4a <display_select+0xb6>
    		child = child->nextsel;
 8004e3e:	68fb      	ldr	r3, [r7, #12]
 8004e40:	695b      	ldr	r3, [r3, #20]
 8004e42:	60fb      	str	r3, [r7, #12]
    		i++;
 8004e44:	68bb      	ldr	r3, [r7, #8]
 8004e46:	3301      	adds	r3, #1
 8004e48:	60bb      	str	r3, [r7, #8]
    	while((i < currentSelectIndex)&&(child->nextsel != NULL))
 8004e4a:	4b21      	ldr	r3, [pc, #132]	; (8004ed0 <display_select+0x13c>)
 8004e4c:	681b      	ldr	r3, [r3, #0]
 8004e4e:	68ba      	ldr	r2, [r7, #8]
 8004e50:	429a      	cmp	r2, r3
 8004e52:	da03      	bge.n	8004e5c <display_select+0xc8>
 8004e54:	68fb      	ldr	r3, [r7, #12]
 8004e56:	695b      	ldr	r3, [r3, #20]
 8004e58:	2b00      	cmp	r3, #0
 8004e5a:	d1f0      	bne.n	8004e3e <display_select+0xaa>
    	if(child->selectionmax > 0)
 8004e5c:	68fb      	ldr	r3, [r7, #12]
 8004e5e:	691b      	ldr	r3, [r3, #16]
 8004e60:	2b00      	cmp	r3, #0
 8004e62:	dd0c      	ble.n	8004e7e <display_select+0xea>
    		currDisplay = child;
 8004e64:	4b19      	ldr	r3, [pc, #100]	; (8004ecc <display_select+0x138>)
 8004e66:	68fa      	ldr	r2, [r7, #12]
 8004e68:	601a      	str	r2, [r3, #0]
    		LCD_Clear(BLUE);
 8004e6a:	201f      	movs	r0, #31
 8004e6c:	f7fe fdb0 	bl	80039d0 <LCD_Clear>
    		currDisplay->ttl();
 8004e70:	4b16      	ldr	r3, [pc, #88]	; (8004ecc <display_select+0x138>)
 8004e72:	681b      	ldr	r3, [r3, #0]
 8004e74:	681b      	ldr	r3, [r3, #0]
 8004e76:	4798      	blx	r3
    		resetSel();
 8004e78:	f000 f830 	bl	8004edc <resetSel>
}
 8004e7c:	e01f      	b.n	8004ebe <display_select+0x12a>
    		child->ttl();
 8004e7e:	68fb      	ldr	r3, [r7, #12]
 8004e80:	681b      	ldr	r3, [r3, #0]
 8004e82:	4798      	blx	r3
    		LCD_DrawString(75*selectIndex + 25,200,  YELLOW, BLACK, currDisplay->selection[selectIndex], 16, 0);
 8004e84:	687b      	ldr	r3, [r7, #4]
 8004e86:	b29b      	uxth	r3, r3
 8004e88:	1c1a      	adds	r2, r3, #0
 8004e8a:	0092      	lsls	r2, r2, #2
 8004e8c:	18d3      	adds	r3, r2, r3
 8004e8e:	1c1a      	adds	r2, r3, #0
 8004e90:	0112      	lsls	r2, r2, #4
 8004e92:	1ad3      	subs	r3, r2, r3
 8004e94:	b29b      	uxth	r3, r3
 8004e96:	3319      	adds	r3, #25
 8004e98:	b298      	uxth	r0, r3
 8004e9a:	4b0c      	ldr	r3, [pc, #48]	; (8004ecc <display_select+0x138>)
 8004e9c:	681b      	ldr	r3, [r3, #0]
 8004e9e:	689a      	ldr	r2, [r3, #8]
 8004ea0:	687b      	ldr	r3, [r7, #4]
 8004ea2:	009b      	lsls	r3, r3, #2
 8004ea4:	18d3      	adds	r3, r2, r3
 8004ea6:	681b      	ldr	r3, [r3, #0]
 8004ea8:	490a      	ldr	r1, [pc, #40]	; (8004ed4 <display_select+0x140>)
 8004eaa:	2200      	movs	r2, #0
 8004eac:	9202      	str	r2, [sp, #8]
 8004eae:	2210      	movs	r2, #16
 8004eb0:	9201      	str	r2, [sp, #4]
 8004eb2:	9300      	str	r3, [sp, #0]
 8004eb4:	2300      	movs	r3, #0
 8004eb6:	000a      	movs	r2, r1
 8004eb8:	21c8      	movs	r1, #200	; 0xc8
 8004eba:	f7fe ff5f 	bl	8003d7c <LCD_DrawString>
}
 8004ebe:	46c0      	nop			; (mov r8, r8)
 8004ec0:	46bd      	mov	sp, r7
 8004ec2:	b005      	add	sp, #20
 8004ec4:	bd90      	pop	{r4, r7, pc}
 8004ec6:	46c0      	nop			; (mov r8, r8)
 8004ec8:	20002110 	.word	0x20002110
 8004ecc:	200022d4 	.word	0x200022d4
 8004ed0:	2000210c 	.word	0x2000210c
 8004ed4:	0000ffe0 	.word	0x0000ffe0
 8004ed8:	20000078 	.word	0x20000078

08004edc <resetSel>:
void resetSel()
{
 8004edc:	b580      	push	{r7, lr}
 8004ede:	b086      	sub	sp, #24
 8004ee0:	af04      	add	r7, sp, #16
	//LCD_Clear(BLUE);
	LCD_DrawString(25,200,  YELLOW, BLACK, (currDisplay->selection)[0], 16, 0);
 8004ee2:	4b21      	ldr	r3, [pc, #132]	; (8004f68 <resetSel+0x8c>)
 8004ee4:	681b      	ldr	r3, [r3, #0]
 8004ee6:	689b      	ldr	r3, [r3, #8]
 8004ee8:	681b      	ldr	r3, [r3, #0]
 8004eea:	4920      	ldr	r1, [pc, #128]	; (8004f6c <resetSel+0x90>)
 8004eec:	2200      	movs	r2, #0
 8004eee:	9202      	str	r2, [sp, #8]
 8004ef0:	2210      	movs	r2, #16
 8004ef2:	9201      	str	r2, [sp, #4]
 8004ef4:	9300      	str	r3, [sp, #0]
 8004ef6:	2300      	movs	r3, #0
 8004ef8:	000a      	movs	r2, r1
 8004efa:	21c8      	movs	r1, #200	; 0xc8
 8004efc:	2019      	movs	r0, #25
 8004efe:	f7fe ff3d 	bl	8003d7c <LCD_DrawString>
	for (int i = 1; i < currDisplay->scrollmax; i++) {
 8004f02:	2301      	movs	r3, #1
 8004f04:	607b      	str	r3, [r7, #4]
 8004f06:	e01f      	b.n	8004f48 <resetSel+0x6c>
			LCD_DrawString(75*i + 25,200,  YELLOW, BLUE, (currDisplay->selection)[i], 16, 0);
 8004f08:	687b      	ldr	r3, [r7, #4]
 8004f0a:	b29b      	uxth	r3, r3
 8004f0c:	1c1a      	adds	r2, r3, #0
 8004f0e:	0092      	lsls	r2, r2, #2
 8004f10:	18d3      	adds	r3, r2, r3
 8004f12:	1c1a      	adds	r2, r3, #0
 8004f14:	0112      	lsls	r2, r2, #4
 8004f16:	1ad3      	subs	r3, r2, r3
 8004f18:	b29b      	uxth	r3, r3
 8004f1a:	3319      	adds	r3, #25
 8004f1c:	b298      	uxth	r0, r3
 8004f1e:	4b12      	ldr	r3, [pc, #72]	; (8004f68 <resetSel+0x8c>)
 8004f20:	681b      	ldr	r3, [r3, #0]
 8004f22:	689a      	ldr	r2, [r3, #8]
 8004f24:	687b      	ldr	r3, [r7, #4]
 8004f26:	009b      	lsls	r3, r3, #2
 8004f28:	18d3      	adds	r3, r2, r3
 8004f2a:	681b      	ldr	r3, [r3, #0]
 8004f2c:	490f      	ldr	r1, [pc, #60]	; (8004f6c <resetSel+0x90>)
 8004f2e:	2200      	movs	r2, #0
 8004f30:	9202      	str	r2, [sp, #8]
 8004f32:	2210      	movs	r2, #16
 8004f34:	9201      	str	r2, [sp, #4]
 8004f36:	9300      	str	r3, [sp, #0]
 8004f38:	231f      	movs	r3, #31
 8004f3a:	000a      	movs	r2, r1
 8004f3c:	21c8      	movs	r1, #200	; 0xc8
 8004f3e:	f7fe ff1d 	bl	8003d7c <LCD_DrawString>
	for (int i = 1; i < currDisplay->scrollmax; i++) {
 8004f42:	687b      	ldr	r3, [r7, #4]
 8004f44:	3301      	adds	r3, #1
 8004f46:	607b      	str	r3, [r7, #4]
 8004f48:	4b07      	ldr	r3, [pc, #28]	; (8004f68 <resetSel+0x8c>)
 8004f4a:	681b      	ldr	r3, [r3, #0]
 8004f4c:	68db      	ldr	r3, [r3, #12]
 8004f4e:	687a      	ldr	r2, [r7, #4]
 8004f50:	429a      	cmp	r2, r3
 8004f52:	dbd9      	blt.n	8004f08 <resetSel+0x2c>
		}
	currentScrollIndex = 0;
 8004f54:	4b06      	ldr	r3, [pc, #24]	; (8004f70 <resetSel+0x94>)
 8004f56:	2200      	movs	r2, #0
 8004f58:	601a      	str	r2, [r3, #0]
	currentSelectIndex = 0;
 8004f5a:	4b06      	ldr	r3, [pc, #24]	; (8004f74 <resetSel+0x98>)
 8004f5c:	2200      	movs	r2, #0
 8004f5e:	601a      	str	r2, [r3, #0]
}
 8004f60:	46c0      	nop			; (mov r8, r8)
 8004f62:	46bd      	mov	sp, r7
 8004f64:	b002      	add	sp, #8
 8004f66:	bd80      	pop	{r7, pc}
 8004f68:	200022d4 	.word	0x200022d4
 8004f6c:	0000ffe0 	.word	0x0000ffe0
 8004f70:	20002110 	.word	0x20002110
 8004f74:	2000210c 	.word	0x2000210c

08004f78 <Infomode>:
void Infomode()
{//Info mode that displays product usage and info
 8004f78:	b580      	push	{r7, lr}
 8004f7a:	b084      	sub	sp, #16
 8004f7c:	af04      	add	r7, sp, #16
	LCD_DrawString(25 ,50,  YELLOW, BLUE,"Info will be displayed", 16, 0);
 8004f7e:	4a07      	ldr	r2, [pc, #28]	; (8004f9c <Infomode+0x24>)
 8004f80:	2300      	movs	r3, #0
 8004f82:	9302      	str	r3, [sp, #8]
 8004f84:	2310      	movs	r3, #16
 8004f86:	9301      	str	r3, [sp, #4]
 8004f88:	4b05      	ldr	r3, [pc, #20]	; (8004fa0 <Infomode+0x28>)
 8004f8a:	9300      	str	r3, [sp, #0]
 8004f8c:	231f      	movs	r3, #31
 8004f8e:	2132      	movs	r1, #50	; 0x32
 8004f90:	2019      	movs	r0, #25
 8004f92:	f7fe fef3 	bl	8003d7c <LCD_DrawString>
	//currently nothing is displayed for now
}
 8004f96:	46c0      	nop			; (mov r8, r8)
 8004f98:	46bd      	mov	sp, r7
 8004f9a:	bd80      	pop	{r7, pc}
 8004f9c:	0000ffe0 	.word	0x0000ffe0
 8004fa0:	0800e450 	.word	0x0800e450

08004fa4 <manualRotate>:
	LCD_DrawString(25 ,75,  YELLOW, BLUE,"Re-String Purpose", 16, 0);

}

void manualRotate()
{
 8004fa4:	b580      	push	{r7, lr}
 8004fa6:	af00      	add	r7, sp, #0
	stepperMotor(currentSelectIndex, 7500, 90, 1);
 8004fa8:	4b04      	ldr	r3, [pc, #16]	; (8004fbc <manualRotate+0x18>)
 8004faa:	6818      	ldr	r0, [r3, #0]
 8004fac:	4904      	ldr	r1, [pc, #16]	; (8004fc0 <manualRotate+0x1c>)
 8004fae:	2301      	movs	r3, #1
 8004fb0:	225a      	movs	r2, #90	; 0x5a
 8004fb2:	f000 f817 	bl	8004fe4 <stepperMotor>
}
 8004fb6:	46c0      	nop			; (mov r8, r8)
 8004fb8:	46bd      	mov	sp, r7
 8004fba:	bd80      	pop	{r7, pc}
 8004fbc:	2000210c 	.word	0x2000210c
 8004fc0:	00001d4c 	.word	0x00001d4c

08004fc4 <autoRotate>:
void autoRotate()
{
 8004fc4:	b580      	push	{r7, lr}
 8004fc6:	af00      	add	r7, sp, #0
	stepperMotor(currentSelectIndex, 7500, 90, 2);
 8004fc8:	4b04      	ldr	r3, [pc, #16]	; (8004fdc <autoRotate+0x18>)
 8004fca:	6818      	ldr	r0, [r3, #0]
 8004fcc:	4904      	ldr	r1, [pc, #16]	; (8004fe0 <autoRotate+0x1c>)
 8004fce:	2302      	movs	r3, #2
 8004fd0:	225a      	movs	r2, #90	; 0x5a
 8004fd2:	f000 f807 	bl	8004fe4 <stepperMotor>
}
 8004fd6:	46c0      	nop			; (mov r8, r8)
 8004fd8:	46bd      	mov	sp, r7
 8004fda:	bd80      	pop	{r7, pc}
 8004fdc:	2000210c 	.word	0x2000210c
 8004fe0:	00001d4c 	.word	0x00001d4c

08004fe4 <stepperMotor>:
void stepperMotor(int direction, int per, int angle, int mode)
{// stepper motor control
 8004fe4:	b590      	push	{r4, r7, lr}
 8004fe6:	b089      	sub	sp, #36	; 0x24
 8004fe8:	af00      	add	r7, sp, #0
 8004fea:	60f8      	str	r0, [r7, #12]
 8004fec:	60b9      	str	r1, [r7, #8]
 8004fee:	607a      	str	r2, [r7, #4]
 8004ff0:	603b      	str	r3, [r7, #0]
	if(direction == 1) // directional change
 8004ff2:	68fb      	ldr	r3, [r7, #12]
 8004ff4:	2b01      	cmp	r3, #1
 8004ff6:	d107      	bne.n	8005008 <stepperMotor+0x24>
	{
		HAL_GPIO_WritePin(GPIOB, GPIO_PIN_14, GPIO_PIN_RESET);
 8004ff8:	2380      	movs	r3, #128	; 0x80
 8004ffa:	01db      	lsls	r3, r3, #7
 8004ffc:	4835      	ldr	r0, [pc, #212]	; (80050d4 <stepperMotor+0xf0>)
 8004ffe:	2200      	movs	r2, #0
 8005000:	0019      	movs	r1, r3
 8005002:	f001 fd30 	bl	8006a66 <HAL_GPIO_WritePin>
 8005006:	e006      	b.n	8005016 <stepperMotor+0x32>
	}
	else
	{
		HAL_GPIO_WritePin(GPIOB, GPIO_PIN_14, GPIO_PIN_SET);
 8005008:	2380      	movs	r3, #128	; 0x80
 800500a:	01db      	lsls	r3, r3, #7
 800500c:	4831      	ldr	r0, [pc, #196]	; (80050d4 <stepperMotor+0xf0>)
 800500e:	2201      	movs	r2, #1
 8005010:	0019      	movs	r1, r3
 8005012:	f001 fd28 	bl	8006a66 <HAL_GPIO_WritePin>
	}
	HAL_GPIO_WritePin(GPIOB, GPIO_PIN_11, GPIO_PIN_RESET); //motor Enable
 8005016:	2380      	movs	r3, #128	; 0x80
 8005018:	011b      	lsls	r3, r3, #4
 800501a:	482e      	ldr	r0, [pc, #184]	; (80050d4 <stepperMotor+0xf0>)
 800501c:	2200      	movs	r2, #0
 800501e:	0019      	movs	r1, r3
 8005020:	f001 fd21 	bl	8006a66 <HAL_GPIO_WritePin>
	//change_pwm(per);// this is to change pwm signal in case we want to speed or low down motore
	// change_pwm might not even be used
	HAL_GPIO_WritePin(GPIOC, GPIO_PIN_8, GPIO_PIN_RESET);//seting motor to full drive
 8005024:	2380      	movs	r3, #128	; 0x80
 8005026:	005b      	lsls	r3, r3, #1
 8005028:	482b      	ldr	r0, [pc, #172]	; (80050d8 <stepperMotor+0xf4>)
 800502a:	2200      	movs	r2, #0
 800502c:	0019      	movs	r1, r3
 800502e:	f001 fd1a 	bl	8006a66 <HAL_GPIO_WritePin>

	if(mode == 1) //Manual stepper rotation
 8005032:	683b      	ldr	r3, [r7, #0]
 8005034:	2b01      	cmp	r3, #1
 8005036:	d114      	bne.n	8005062 <stepperMotor+0x7e>
	{startmotor();
 8005038:	f7ff fbac 	bl	8004794 <startmotor>
	while(updateToggleHistory(5) | updateToggleHistory(7))
 800503c:	e003      	b.n	8005046 <stepperMotor+0x62>
	{//while trigger button is being pressed, currently mapped to selection button for testing
		nano_wait(5000000);
 800503e:	4b27      	ldr	r3, [pc, #156]	; (80050dc <stepperMotor+0xf8>)
 8005040:	0018      	movs	r0, r3
 8005042:	f7fe fa92 	bl	800356a <nano_wait>
	while(updateToggleHistory(5) | updateToggleHistory(7))
 8005046:	2005      	movs	r0, #5
 8005048:	f000 f8fc 	bl	8005244 <updateToggleHistory>
 800504c:	0003      	movs	r3, r0
 800504e:	001c      	movs	r4, r3
 8005050:	2007      	movs	r0, #7
 8005052:	f000 f8f7 	bl	8005244 <updateToggleHistory>
 8005056:	0003      	movs	r3, r0
 8005058:	4323      	orrs	r3, r4
 800505a:	b2db      	uxtb	r3, r3
 800505c:	2b00      	cmp	r3, #0
 800505e:	d1ee      	bne.n	800503e <stepperMotor+0x5a>
 8005060:	e032      	b.n	80050c8 <stepperMotor+0xe4>

	}
	}
	else //Angular precise stepper movements
		{
		uint32_t timemotor = per* angle /10000/1.8*3.95; //period * number of steps(angle) / 10000 / 1.8degrees per step * 1.25
 8005062:	68bb      	ldr	r3, [r7, #8]
 8005064:	687a      	ldr	r2, [r7, #4]
 8005066:	4353      	muls	r3, r2
 8005068:	491d      	ldr	r1, [pc, #116]	; (80050e0 <stepperMotor+0xfc>)
 800506a:	0018      	movs	r0, r3
 800506c:	f7fb f8d4 	bl	8000218 <__divsi3>
 8005070:	0003      	movs	r3, r0
 8005072:	0018      	movs	r0, r3
 8005074:	f7fd fd64 	bl	8002b40 <__aeabi_i2d>
 8005078:	4a1a      	ldr	r2, [pc, #104]	; (80050e4 <stepperMotor+0x100>)
 800507a:	4b1b      	ldr	r3, [pc, #108]	; (80050e8 <stepperMotor+0x104>)
 800507c:	f7fc fc44 	bl	8001908 <__aeabi_ddiv>
 8005080:	0002      	movs	r2, r0
 8005082:	000b      	movs	r3, r1
 8005084:	0010      	movs	r0, r2
 8005086:	0019      	movs	r1, r3
 8005088:	4a18      	ldr	r2, [pc, #96]	; (80050ec <stepperMotor+0x108>)
 800508a:	4b19      	ldr	r3, [pc, #100]	; (80050f0 <stepperMotor+0x10c>)
 800508c:	f7fc ff24 	bl	8001ed8 <__aeabi_dmul>
 8005090:	0002      	movs	r2, r0
 8005092:	000b      	movs	r3, r1
 8005094:	0010      	movs	r0, r2
 8005096:	0019      	movs	r1, r3
 8005098:	f7fb f9e4 	bl	8000464 <__aeabi_d2uiz>
 800509c:	0003      	movs	r3, r0
 800509e:	61bb      	str	r3, [r7, #24]
		startmotor();
 80050a0:	f7ff fb78 	bl	8004794 <startmotor>
		uint32_t motorstarttime = HAL_GetTick();
 80050a4:	f000 fc56 	bl	8005954 <HAL_GetTick>
 80050a8:	0003      	movs	r3, r0
 80050aa:	617b      	str	r3, [r7, #20]
		for(int i =0; i < timemotor; i++)
 80050ac:	2300      	movs	r3, #0
 80050ae:	61fb      	str	r3, [r7, #28]
 80050b0:	e006      	b.n	80050c0 <stepperMotor+0xdc>
		{
			nano_wait(1000000);
 80050b2:	4b10      	ldr	r3, [pc, #64]	; (80050f4 <stepperMotor+0x110>)
 80050b4:	0018      	movs	r0, r3
 80050b6:	f7fe fa58 	bl	800356a <nano_wait>
		for(int i =0; i < timemotor; i++)
 80050ba:	69fb      	ldr	r3, [r7, #28]
 80050bc:	3301      	adds	r3, #1
 80050be:	61fb      	str	r3, [r7, #28]
 80050c0:	69fb      	ldr	r3, [r7, #28]
 80050c2:	69ba      	ldr	r2, [r7, #24]
 80050c4:	429a      	cmp	r2, r3
 80050c6:	d8f4      	bhi.n	80050b2 <stepperMotor+0xce>
		//{//while trigger is pressed and angle time is not exceeded, continue running the motor
		//}
		}

	//stop motor
	stopmotor();
 80050c8:	f7ff fb70 	bl	80047ac <stopmotor>
}
 80050cc:	46c0      	nop			; (mov r8, r8)
 80050ce:	46bd      	mov	sp, r7
 80050d0:	b009      	add	sp, #36	; 0x24
 80050d2:	bd90      	pop	{r4, r7, pc}
 80050d4:	48000400 	.word	0x48000400
 80050d8:	48000800 	.word	0x48000800
 80050dc:	004c4b40 	.word	0x004c4b40
 80050e0:	00002710 	.word	0x00002710
 80050e4:	cccccccd 	.word	0xcccccccd
 80050e8:	3ffccccc 	.word	0x3ffccccc
 80050ec:	9999999a 	.word	0x9999999a
 80050f0:	400f9999 	.word	0x400f9999
 80050f4:	000f4240 	.word	0x000f4240

080050f8 <Tunemode>:
void Tunemode() {
 80050f8:	b580      	push	{r7, lr}
 80050fa:	b084      	sub	sp, #16
 80050fc:	af04      	add	r7, sp, #16
	//introduce scroll index which represents the current index in the list of tune
	/*currentSelectIndex is just representing the index respective to which of current three selection
	on the screen is being highlighted */
	//display peg diagram
	LCD_DrawString(95 ,25,  YELLOW, BLUE,"-----", 16, 0);
 80050fe:	4a2b      	ldr	r2, [pc, #172]	; (80051ac <Tunemode+0xb4>)
 8005100:	2300      	movs	r3, #0
 8005102:	9302      	str	r3, [sp, #8]
 8005104:	2310      	movs	r3, #16
 8005106:	9301      	str	r3, [sp, #4]
 8005108:	4b29      	ldr	r3, [pc, #164]	; (80051b0 <Tunemode+0xb8>)
 800510a:	9300      	str	r3, [sp, #0]
 800510c:	231f      	movs	r3, #31
 800510e:	2119      	movs	r1, #25
 8005110:	205f      	movs	r0, #95	; 0x5f
 8005112:	f7fe fe33 	bl	8003d7c <LCD_DrawString>
	LCD_DrawString(60 ,40,  YELLOW, BLUE,"3 - |    | - 4", 16, 0);
 8005116:	4a25      	ldr	r2, [pc, #148]	; (80051ac <Tunemode+0xb4>)
 8005118:	2300      	movs	r3, #0
 800511a:	9302      	str	r3, [sp, #8]
 800511c:	2310      	movs	r3, #16
 800511e:	9301      	str	r3, [sp, #4]
 8005120:	4b24      	ldr	r3, [pc, #144]	; (80051b4 <Tunemode+0xbc>)
 8005122:	9300      	str	r3, [sp, #0]
 8005124:	231f      	movs	r3, #31
 8005126:	2128      	movs	r1, #40	; 0x28
 8005128:	203c      	movs	r0, #60	; 0x3c
 800512a:	f7fe fe27 	bl	8003d7c <LCD_DrawString>
	LCD_DrawString(60 ,60,  YELLOW, BLUE,"2 - |    | - 5", 16, 0);
 800512e:	4a1f      	ldr	r2, [pc, #124]	; (80051ac <Tunemode+0xb4>)
 8005130:	2300      	movs	r3, #0
 8005132:	9302      	str	r3, [sp, #8]
 8005134:	2310      	movs	r3, #16
 8005136:	9301      	str	r3, [sp, #4]
 8005138:	4b1f      	ldr	r3, [pc, #124]	; (80051b8 <Tunemode+0xc0>)
 800513a:	9300      	str	r3, [sp, #0]
 800513c:	231f      	movs	r3, #31
 800513e:	213c      	movs	r1, #60	; 0x3c
 8005140:	203c      	movs	r0, #60	; 0x3c
 8005142:	f7fe fe1b 	bl	8003d7c <LCD_DrawString>
	LCD_DrawString(60 ,80,  YELLOW, BLUE,"1 - |    | - 6", 16, 0);
 8005146:	4a19      	ldr	r2, [pc, #100]	; (80051ac <Tunemode+0xb4>)
 8005148:	2300      	movs	r3, #0
 800514a:	9302      	str	r3, [sp, #8]
 800514c:	2310      	movs	r3, #16
 800514e:	9301      	str	r3, [sp, #4]
 8005150:	4b1a      	ldr	r3, [pc, #104]	; (80051bc <Tunemode+0xc4>)
 8005152:	9300      	str	r3, [sp, #0]
 8005154:	231f      	movs	r3, #31
 8005156:	2150      	movs	r1, #80	; 0x50
 8005158:	203c      	movs	r0, #60	; 0x3c
 800515a:	f7fe fe0f 	bl	8003d7c <LCD_DrawString>
	LCD_DrawString(95 ,100,  YELLOW, BLUE,"-----", 16, 0);
 800515e:	4a13      	ldr	r2, [pc, #76]	; (80051ac <Tunemode+0xb4>)
 8005160:	2300      	movs	r3, #0
 8005162:	9302      	str	r3, [sp, #8]
 8005164:	2310      	movs	r3, #16
 8005166:	9301      	str	r3, [sp, #4]
 8005168:	4b11      	ldr	r3, [pc, #68]	; (80051b0 <Tunemode+0xb8>)
 800516a:	9300      	str	r3, [sp, #0]
 800516c:	231f      	movs	r3, #31
 800516e:	2164      	movs	r1, #100	; 0x64
 8005170:	205f      	movs	r0, #95	; 0x5f
 8005172:	f7fe fe03 	bl	8003d7c <LCD_DrawString>
	LCD_DrawString(100 ,115,  YELLOW, BLUE,"||||", 16, 0);
 8005176:	4a0d      	ldr	r2, [pc, #52]	; (80051ac <Tunemode+0xb4>)
 8005178:	2300      	movs	r3, #0
 800517a:	9302      	str	r3, [sp, #8]
 800517c:	2310      	movs	r3, #16
 800517e:	9301      	str	r3, [sp, #4]
 8005180:	4b0f      	ldr	r3, [pc, #60]	; (80051c0 <Tunemode+0xc8>)
 8005182:	9300      	str	r3, [sp, #0]
 8005184:	231f      	movs	r3, #31
 8005186:	2173      	movs	r1, #115	; 0x73
 8005188:	2064      	movs	r0, #100	; 0x64
 800518a:	f7fe fdf7 	bl	8003d7c <LCD_DrawString>
	LCD_DrawString(100 ,130,  YELLOW, BLUE,"||||", 16, 0);
 800518e:	4a07      	ldr	r2, [pc, #28]	; (80051ac <Tunemode+0xb4>)
 8005190:	2300      	movs	r3, #0
 8005192:	9302      	str	r3, [sp, #8]
 8005194:	2310      	movs	r3, #16
 8005196:	9301      	str	r3, [sp, #4]
 8005198:	4b09      	ldr	r3, [pc, #36]	; (80051c0 <Tunemode+0xc8>)
 800519a:	9300      	str	r3, [sp, #0]
 800519c:	231f      	movs	r3, #31
 800519e:	2182      	movs	r1, #130	; 0x82
 80051a0:	2064      	movs	r0, #100	; 0x64
 80051a2:	f7fe fdeb 	bl	8003d7c <LCD_DrawString>
}
 80051a6:	46c0      	nop			; (mov r8, r8)
 80051a8:	46bd      	mov	sp, r7
 80051aa:	bd80      	pop	{r7, pc}
 80051ac:	0000ffe0 	.word	0x0000ffe0
 80051b0:	0800e494 	.word	0x0800e494
 80051b4:	0800e49c 	.word	0x0800e49c
 80051b8:	0800e4ac 	.word	0x0800e4ac
 80051bc:	0800e4bc 	.word	0x0800e4bc
 80051c0:	0800e4cc 	.word	0x0800e4cc

080051c4 <pegDisplay>:

void pegDisplay()
{
 80051c4:	b580      	push	{r7, lr}
 80051c6:	b084      	sub	sp, #16
 80051c8:	af04      	add	r7, sp, #16
	LCD_DrawString(60 ,40,  YELLOW, BLUE,pegsel[currentSelectIndex-1], 16, 0);
 80051ca:	4b19      	ldr	r3, [pc, #100]	; (8005230 <pegDisplay+0x6c>)
 80051cc:	681b      	ldr	r3, [r3, #0]
 80051ce:	1e5a      	subs	r2, r3, #1
 80051d0:	4b18      	ldr	r3, [pc, #96]	; (8005234 <pegDisplay+0x70>)
 80051d2:	0092      	lsls	r2, r2, #2
 80051d4:	58d3      	ldr	r3, [r2, r3]
 80051d6:	4918      	ldr	r1, [pc, #96]	; (8005238 <pegDisplay+0x74>)
 80051d8:	2200      	movs	r2, #0
 80051da:	9202      	str	r2, [sp, #8]
 80051dc:	2210      	movs	r2, #16
 80051de:	9201      	str	r2, [sp, #4]
 80051e0:	9300      	str	r3, [sp, #0]
 80051e2:	231f      	movs	r3, #31
 80051e4:	000a      	movs	r2, r1
 80051e6:	2128      	movs	r1, #40	; 0x28
 80051e8:	203c      	movs	r0, #60	; 0x3c
 80051ea:	f7fe fdc7 	bl	8003d7c <LCD_DrawString>
	LCD_DrawString(60 ,60,  YELLOW, BLUE,"Play Note", 16, 0);
 80051ee:	4a12      	ldr	r2, [pc, #72]	; (8005238 <pegDisplay+0x74>)
 80051f0:	2300      	movs	r3, #0
 80051f2:	9302      	str	r3, [sp, #8]
 80051f4:	2310      	movs	r3, #16
 80051f6:	9301      	str	r3, [sp, #4]
 80051f8:	4b10      	ldr	r3, [pc, #64]	; (800523c <pegDisplay+0x78>)
 80051fa:	9300      	str	r3, [sp, #0]
 80051fc:	231f      	movs	r3, #31
 80051fe:	213c      	movs	r1, #60	; 0x3c
 8005200:	203c      	movs	r0, #60	; 0x3c
 8005202:	f7fe fdbb 	bl	8003d7c <LCD_DrawString>
	LCD_DrawString(140 ,60,  YELLOW, BLUE, note[currentSelectIndex-1], 16, 0);
 8005206:	4b0a      	ldr	r3, [pc, #40]	; (8005230 <pegDisplay+0x6c>)
 8005208:	681b      	ldr	r3, [r3, #0]
 800520a:	1e5a      	subs	r2, r3, #1
 800520c:	4b0c      	ldr	r3, [pc, #48]	; (8005240 <pegDisplay+0x7c>)
 800520e:	0092      	lsls	r2, r2, #2
 8005210:	58d3      	ldr	r3, [r2, r3]
 8005212:	4909      	ldr	r1, [pc, #36]	; (8005238 <pegDisplay+0x74>)
 8005214:	2200      	movs	r2, #0
 8005216:	9202      	str	r2, [sp, #8]
 8005218:	2210      	movs	r2, #16
 800521a:	9201      	str	r2, [sp, #4]
 800521c:	9300      	str	r3, [sp, #0]
 800521e:	231f      	movs	r3, #31
 8005220:	000a      	movs	r2, r1
 8005222:	213c      	movs	r1, #60	; 0x3c
 8005224:	208c      	movs	r0, #140	; 0x8c
 8005226:	f7fe fda9 	bl	8003d7c <LCD_DrawString>
}
 800522a:	46c0      	nop			; (mov r8, r8)
 800522c:	46bd      	mov	sp, r7
 800522e:	bd80      	pop	{r7, pc}
 8005230:	2000210c 	.word	0x2000210c
 8005234:	20000048 	.word	0x20000048
 8005238:	0000ffe0 	.word	0x0000ffe0
 800523c:	0800e4d4 	.word	0x0800e4d4
 8005240:	20000060 	.word	0x20000060

08005244 <updateToggleHistory>:


uint8_t updateToggleHistory(uint8_t button) {
 8005244:	b5f0      	push	{r4, r5, r6, r7, lr}
 8005246:	b085      	sub	sp, #20
 8005248:	af00      	add	r7, sp, #0
 800524a:	0002      	movs	r2, r0
 800524c:	1dfb      	adds	r3, r7, #7
 800524e:	701a      	strb	r2, [r3, #0]
	uint8_t prev = pressHistory[button - 2];
 8005250:	1dfb      	adds	r3, r7, #7
 8005252:	781b      	ldrb	r3, [r3, #0]
 8005254:	1e9a      	subs	r2, r3, #2
 8005256:	260f      	movs	r6, #15
 8005258:	19bb      	adds	r3, r7, r6
 800525a:	492c      	ldr	r1, [pc, #176]	; (800530c <updateToggleHistory+0xc8>)
 800525c:	5c8a      	ldrb	r2, [r1, r2]
 800525e:	701a      	strb	r2, [r3, #0]
	uint8_t new = HAL_GPIO_ReadPin(GPIOB, 1 << (button));
 8005260:	1dfb      	adds	r3, r7, #7
 8005262:	781b      	ldrb	r3, [r3, #0]
 8005264:	2201      	movs	r2, #1
 8005266:	409a      	lsls	r2, r3
 8005268:	0013      	movs	r3, r2
 800526a:	b29b      	uxth	r3, r3
 800526c:	250e      	movs	r5, #14
 800526e:	197c      	adds	r4, r7, r5
 8005270:	4a27      	ldr	r2, [pc, #156]	; (8005310 <updateToggleHistory+0xcc>)
 8005272:	0019      	movs	r1, r3
 8005274:	0010      	movs	r0, r2
 8005276:	f001 fbd9 	bl	8006a2c <HAL_GPIO_ReadPin>
 800527a:	0003      	movs	r3, r0
 800527c:	7023      	strb	r3, [r4, #0]
	pressHistory[button - 2] = new;
 800527e:	1dfb      	adds	r3, r7, #7
 8005280:	781b      	ldrb	r3, [r3, #0]
 8005282:	3b02      	subs	r3, #2
 8005284:	4a21      	ldr	r2, [pc, #132]	; (800530c <updateToggleHistory+0xc8>)
 8005286:	0028      	movs	r0, r5
 8005288:	1839      	adds	r1, r7, r0
 800528a:	7809      	ldrb	r1, [r1, #0]
 800528c:	54d1      	strb	r1, [r2, r3]
	if (lastButton == button && (prev == 1 || new == 1)) return 0;
 800528e:	4b21      	ldr	r3, [pc, #132]	; (8005314 <updateToggleHistory+0xd0>)
 8005290:	781b      	ldrb	r3, [r3, #0]
 8005292:	1dfa      	adds	r2, r7, #7
 8005294:	7812      	ldrb	r2, [r2, #0]
 8005296:	429a      	cmp	r2, r3
 8005298:	d109      	bne.n	80052ae <updateToggleHistory+0x6a>
 800529a:	19bb      	adds	r3, r7, r6
 800529c:	781b      	ldrb	r3, [r3, #0]
 800529e:	2b01      	cmp	r3, #1
 80052a0:	d003      	beq.n	80052aa <updateToggleHistory+0x66>
 80052a2:	183b      	adds	r3, r7, r0
 80052a4:	781b      	ldrb	r3, [r3, #0]
 80052a6:	2b01      	cmp	r3, #1
 80052a8:	d101      	bne.n	80052ae <updateToggleHistory+0x6a>
 80052aa:	2300      	movs	r3, #0
 80052ac:	e029      	b.n	8005302 <updateToggleHistory+0xbe>
	else if (prev == 1 && new == 1) {
 80052ae:	230f      	movs	r3, #15
 80052b0:	18fb      	adds	r3, r7, r3
 80052b2:	781b      	ldrb	r3, [r3, #0]
 80052b4:	2b01      	cmp	r3, #1
 80052b6:	d109      	bne.n	80052cc <updateToggleHistory+0x88>
 80052b8:	230e      	movs	r3, #14
 80052ba:	18fb      	adds	r3, r7, r3
 80052bc:	781b      	ldrb	r3, [r3, #0]
 80052be:	2b01      	cmp	r3, #1
 80052c0:	d104      	bne.n	80052cc <updateToggleHistory+0x88>
		lastButton = button;
 80052c2:	4b14      	ldr	r3, [pc, #80]	; (8005314 <updateToggleHistory+0xd0>)
 80052c4:	1dfa      	adds	r2, r7, #7
 80052c6:	7812      	ldrb	r2, [r2, #0]
 80052c8:	701a      	strb	r2, [r3, #0]
 80052ca:	e00c      	b.n	80052e6 <updateToggleHistory+0xa2>
	} else if (prev == 0 && new == 0){
 80052cc:	230f      	movs	r3, #15
 80052ce:	18fb      	adds	r3, r7, r3
 80052d0:	781b      	ldrb	r3, [r3, #0]
 80052d2:	2b00      	cmp	r3, #0
 80052d4:	d107      	bne.n	80052e6 <updateToggleHistory+0xa2>
 80052d6:	230e      	movs	r3, #14
 80052d8:	18fb      	adds	r3, r7, r3
 80052da:	781b      	ldrb	r3, [r3, #0]
 80052dc:	2b00      	cmp	r3, #0
 80052de:	d102      	bne.n	80052e6 <updateToggleHistory+0xa2>
		lastButton = -1;
 80052e0:	4b0c      	ldr	r3, [pc, #48]	; (8005314 <updateToggleHistory+0xd0>)
 80052e2:	22ff      	movs	r2, #255	; 0xff
 80052e4:	701a      	strb	r2, [r3, #0]
	}

	return prev && new;
 80052e6:	230f      	movs	r3, #15
 80052e8:	18fb      	adds	r3, r7, r3
 80052ea:	781b      	ldrb	r3, [r3, #0]
 80052ec:	2b00      	cmp	r3, #0
 80052ee:	d006      	beq.n	80052fe <updateToggleHistory+0xba>
 80052f0:	230e      	movs	r3, #14
 80052f2:	18fb      	adds	r3, r7, r3
 80052f4:	781b      	ldrb	r3, [r3, #0]
 80052f6:	2b00      	cmp	r3, #0
 80052f8:	d001      	beq.n	80052fe <updateToggleHistory+0xba>
 80052fa:	2301      	movs	r3, #1
 80052fc:	e000      	b.n	8005300 <updateToggleHistory+0xbc>
 80052fe:	2300      	movs	r3, #0
 8005300:	b2db      	uxtb	r3, r3


  /* USER CODE END 3 */
}
 8005302:	0018      	movs	r0, r3
 8005304:	46bd      	mov	sp, r7
 8005306:	b005      	add	sp, #20
 8005308:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800530a:	46c0      	nop			; (mov r8, r8)
 800530c:	20002124 	.word	0x20002124
 8005310:	48000400 	.word	0x48000400
 8005314:	20000079 	.word	0x20000079

08005318 <HAL_MspInit>:
void HAL_TIM_MspPostInit(TIM_HandleTypeDef *htim);
                    /**
  * Initializes the Global MSP.
  */
void HAL_MspInit(void)
{
 8005318:	b580      	push	{r7, lr}
 800531a:	b082      	sub	sp, #8
 800531c:	af00      	add	r7, sp, #0
  /* USER CODE BEGIN MspInit 0 */

  /* USER CODE END MspInit 0 */

  __HAL_RCC_SYSCFG_CLK_ENABLE();
 800531e:	4b0f      	ldr	r3, [pc, #60]	; (800535c <HAL_MspInit+0x44>)
 8005320:	699a      	ldr	r2, [r3, #24]
 8005322:	4b0e      	ldr	r3, [pc, #56]	; (800535c <HAL_MspInit+0x44>)
 8005324:	2101      	movs	r1, #1
 8005326:	430a      	orrs	r2, r1
 8005328:	619a      	str	r2, [r3, #24]
 800532a:	4b0c      	ldr	r3, [pc, #48]	; (800535c <HAL_MspInit+0x44>)
 800532c:	699b      	ldr	r3, [r3, #24]
 800532e:	2201      	movs	r2, #1
 8005330:	4013      	ands	r3, r2
 8005332:	607b      	str	r3, [r7, #4]
 8005334:	687b      	ldr	r3, [r7, #4]
  __HAL_RCC_PWR_CLK_ENABLE();
 8005336:	4b09      	ldr	r3, [pc, #36]	; (800535c <HAL_MspInit+0x44>)
 8005338:	69da      	ldr	r2, [r3, #28]
 800533a:	4b08      	ldr	r3, [pc, #32]	; (800535c <HAL_MspInit+0x44>)
 800533c:	2180      	movs	r1, #128	; 0x80
 800533e:	0549      	lsls	r1, r1, #21
 8005340:	430a      	orrs	r2, r1
 8005342:	61da      	str	r2, [r3, #28]
 8005344:	4b05      	ldr	r3, [pc, #20]	; (800535c <HAL_MspInit+0x44>)
 8005346:	69da      	ldr	r2, [r3, #28]
 8005348:	2380      	movs	r3, #128	; 0x80
 800534a:	055b      	lsls	r3, r3, #21
 800534c:	4013      	ands	r3, r2
 800534e:	603b      	str	r3, [r7, #0]
 8005350:	683b      	ldr	r3, [r7, #0]
  /* System interrupt init*/

  /* USER CODE BEGIN MspInit 1 */

  /* USER CODE END MspInit 1 */
}
 8005352:	46c0      	nop			; (mov r8, r8)
 8005354:	46bd      	mov	sp, r7
 8005356:	b002      	add	sp, #8
 8005358:	bd80      	pop	{r7, pc}
 800535a:	46c0      	nop			; (mov r8, r8)
 800535c:	40021000 	.word	0x40021000

08005360 <HAL_ADC_MspInit>:
* This function configures the hardware resources used in this example
* @param hadc: ADC handle pointer
* @retval None
*/
void HAL_ADC_MspInit(ADC_HandleTypeDef* hadc)
{
 8005360:	b590      	push	{r4, r7, lr}
 8005362:	b08b      	sub	sp, #44	; 0x2c
 8005364:	af00      	add	r7, sp, #0
 8005366:	6078      	str	r0, [r7, #4]
  GPIO_InitTypeDef GPIO_InitStruct = {0};
 8005368:	2414      	movs	r4, #20
 800536a:	193b      	adds	r3, r7, r4
 800536c:	0018      	movs	r0, r3
 800536e:	2314      	movs	r3, #20
 8005370:	001a      	movs	r2, r3
 8005372:	2100      	movs	r1, #0
 8005374:	f004 fc84 	bl	8009c80 <memset>
  if(hadc->Instance==ADC1)
 8005378:	687b      	ldr	r3, [r7, #4]
 800537a:	681b      	ldr	r3, [r3, #0]
 800537c:	4a35      	ldr	r2, [pc, #212]	; (8005454 <HAL_ADC_MspInit+0xf4>)
 800537e:	4293      	cmp	r3, r2
 8005380:	d163      	bne.n	800544a <HAL_ADC_MspInit+0xea>
  {
  /* USER CODE BEGIN ADC1_MspInit 0 */

  /* USER CODE END ADC1_MspInit 0 */
    /* Peripheral clock enable */
    __HAL_RCC_ADC1_CLK_ENABLE();
 8005382:	4b35      	ldr	r3, [pc, #212]	; (8005458 <HAL_ADC_MspInit+0xf8>)
 8005384:	699a      	ldr	r2, [r3, #24]
 8005386:	4b34      	ldr	r3, [pc, #208]	; (8005458 <HAL_ADC_MspInit+0xf8>)
 8005388:	2180      	movs	r1, #128	; 0x80
 800538a:	0089      	lsls	r1, r1, #2
 800538c:	430a      	orrs	r2, r1
 800538e:	619a      	str	r2, [r3, #24]
 8005390:	4b31      	ldr	r3, [pc, #196]	; (8005458 <HAL_ADC_MspInit+0xf8>)
 8005392:	699a      	ldr	r2, [r3, #24]
 8005394:	2380      	movs	r3, #128	; 0x80
 8005396:	009b      	lsls	r3, r3, #2
 8005398:	4013      	ands	r3, r2
 800539a:	613b      	str	r3, [r7, #16]
 800539c:	693b      	ldr	r3, [r7, #16]

    __HAL_RCC_GPIOA_CLK_ENABLE();
 800539e:	4b2e      	ldr	r3, [pc, #184]	; (8005458 <HAL_ADC_MspInit+0xf8>)
 80053a0:	695a      	ldr	r2, [r3, #20]
 80053a2:	4b2d      	ldr	r3, [pc, #180]	; (8005458 <HAL_ADC_MspInit+0xf8>)
 80053a4:	2180      	movs	r1, #128	; 0x80
 80053a6:	0289      	lsls	r1, r1, #10
 80053a8:	430a      	orrs	r2, r1
 80053aa:	615a      	str	r2, [r3, #20]
 80053ac:	4b2a      	ldr	r3, [pc, #168]	; (8005458 <HAL_ADC_MspInit+0xf8>)
 80053ae:	695a      	ldr	r2, [r3, #20]
 80053b0:	2380      	movs	r3, #128	; 0x80
 80053b2:	029b      	lsls	r3, r3, #10
 80053b4:	4013      	ands	r3, r2
 80053b6:	60fb      	str	r3, [r7, #12]
 80053b8:	68fb      	ldr	r3, [r7, #12]
    /**ADC GPIO Configuration
    PA0     ------> ADC_IN0
    */
    GPIO_InitStruct.Pin = GPIO_PIN_0;
 80053ba:	193b      	adds	r3, r7, r4
 80053bc:	2201      	movs	r2, #1
 80053be:	601a      	str	r2, [r3, #0]
    GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
 80053c0:	193b      	adds	r3, r7, r4
 80053c2:	2203      	movs	r2, #3
 80053c4:	605a      	str	r2, [r3, #4]
    GPIO_InitStruct.Pull = GPIO_NOPULL;
 80053c6:	193b      	adds	r3, r7, r4
 80053c8:	2200      	movs	r2, #0
 80053ca:	609a      	str	r2, [r3, #8]
    HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
 80053cc:	193a      	adds	r2, r7, r4
 80053ce:	2390      	movs	r3, #144	; 0x90
 80053d0:	05db      	lsls	r3, r3, #23
 80053d2:	0011      	movs	r1, r2
 80053d4:	0018      	movs	r0, r3
 80053d6:	f001 f9b1 	bl	800673c <HAL_GPIO_Init>

    /* ADC1 DMA Init */
    /* ADC Init */
    hdma_adc.Instance = DMA1_Channel1;
 80053da:	4b20      	ldr	r3, [pc, #128]	; (800545c <HAL_ADC_MspInit+0xfc>)
 80053dc:	4a20      	ldr	r2, [pc, #128]	; (8005460 <HAL_ADC_MspInit+0x100>)
 80053de:	601a      	str	r2, [r3, #0]
    hdma_adc.Init.Direction = DMA_PERIPH_TO_MEMORY;
 80053e0:	4b1e      	ldr	r3, [pc, #120]	; (800545c <HAL_ADC_MspInit+0xfc>)
 80053e2:	2200      	movs	r2, #0
 80053e4:	605a      	str	r2, [r3, #4]
    hdma_adc.Init.PeriphInc = DMA_PINC_DISABLE;
 80053e6:	4b1d      	ldr	r3, [pc, #116]	; (800545c <HAL_ADC_MspInit+0xfc>)
 80053e8:	2200      	movs	r2, #0
 80053ea:	609a      	str	r2, [r3, #8]
    hdma_adc.Init.MemInc = DMA_MINC_ENABLE;
 80053ec:	4b1b      	ldr	r3, [pc, #108]	; (800545c <HAL_ADC_MspInit+0xfc>)
 80053ee:	2280      	movs	r2, #128	; 0x80
 80053f0:	60da      	str	r2, [r3, #12]
    hdma_adc.Init.PeriphDataAlignment = DMA_PDATAALIGN_HALFWORD;
 80053f2:	4b1a      	ldr	r3, [pc, #104]	; (800545c <HAL_ADC_MspInit+0xfc>)
 80053f4:	2280      	movs	r2, #128	; 0x80
 80053f6:	0052      	lsls	r2, r2, #1
 80053f8:	611a      	str	r2, [r3, #16]
    hdma_adc.Init.MemDataAlignment = DMA_MDATAALIGN_HALFWORD;
 80053fa:	4b18      	ldr	r3, [pc, #96]	; (800545c <HAL_ADC_MspInit+0xfc>)
 80053fc:	2280      	movs	r2, #128	; 0x80
 80053fe:	00d2      	lsls	r2, r2, #3
 8005400:	615a      	str	r2, [r3, #20]
    hdma_adc.Init.Mode = DMA_CIRCULAR;
 8005402:	4b16      	ldr	r3, [pc, #88]	; (800545c <HAL_ADC_MspInit+0xfc>)
 8005404:	2220      	movs	r2, #32
 8005406:	619a      	str	r2, [r3, #24]
    hdma_adc.Init.Priority = DMA_PRIORITY_LOW;
 8005408:	4b14      	ldr	r3, [pc, #80]	; (800545c <HAL_ADC_MspInit+0xfc>)
 800540a:	2200      	movs	r2, #0
 800540c:	61da      	str	r2, [r3, #28]
    if (HAL_DMA_Init(&hdma_adc) != HAL_OK)
 800540e:	4b13      	ldr	r3, [pc, #76]	; (800545c <HAL_ADC_MspInit+0xfc>)
 8005410:	0018      	movs	r0, r3
 8005412:	f000 ff8b 	bl	800632c <HAL_DMA_Init>
 8005416:	1e03      	subs	r3, r0, #0
 8005418:	d001      	beq.n	800541e <HAL_ADC_MspInit+0xbe>
    {
      Error_Handler();
 800541a:	f7ff f9dd 	bl	80047d8 <Error_Handler>
    }

    __HAL_DMA1_REMAP(HAL_DMA1_CH1_ADC);
 800541e:	4a11      	ldr	r2, [pc, #68]	; (8005464 <HAL_ADC_MspInit+0x104>)
 8005420:	23a8      	movs	r3, #168	; 0xa8
 8005422:	58d3      	ldr	r3, [r2, r3]
 8005424:	490f      	ldr	r1, [pc, #60]	; (8005464 <HAL_ADC_MspInit+0x104>)
 8005426:	220f      	movs	r2, #15
 8005428:	4393      	bics	r3, r2
 800542a:	22a8      	movs	r2, #168	; 0xa8
 800542c:	508b      	str	r3, [r1, r2]
 800542e:	4a0d      	ldr	r2, [pc, #52]	; (8005464 <HAL_ADC_MspInit+0x104>)
 8005430:	23a8      	movs	r3, #168	; 0xa8
 8005432:	58d3      	ldr	r3, [r2, r3]
 8005434:	490b      	ldr	r1, [pc, #44]	; (8005464 <HAL_ADC_MspInit+0x104>)
 8005436:	2201      	movs	r2, #1
 8005438:	4313      	orrs	r3, r2
 800543a:	22a8      	movs	r2, #168	; 0xa8
 800543c:	508b      	str	r3, [r1, r2]

    __HAL_LINKDMA(hadc,DMA_Handle,hdma_adc);
 800543e:	687b      	ldr	r3, [r7, #4]
 8005440:	4a06      	ldr	r2, [pc, #24]	; (800545c <HAL_ADC_MspInit+0xfc>)
 8005442:	631a      	str	r2, [r3, #48]	; 0x30
 8005444:	4b05      	ldr	r3, [pc, #20]	; (800545c <HAL_ADC_MspInit+0xfc>)
 8005446:	687a      	ldr	r2, [r7, #4]
 8005448:	625a      	str	r2, [r3, #36]	; 0x24
  /* USER CODE BEGIN ADC1_MspInit 1 */

  /* USER CODE END ADC1_MspInit 1 */
  }

}
 800544a:	46c0      	nop			; (mov r8, r8)
 800544c:	46bd      	mov	sp, r7
 800544e:	b00b      	add	sp, #44	; 0x2c
 8005450:	bd90      	pop	{r4, r7, pc}
 8005452:	46c0      	nop			; (mov r8, r8)
 8005454:	40012400 	.word	0x40012400
 8005458:	40021000 	.word	0x40021000
 800545c:	20002250 	.word	0x20002250
 8005460:	40020008 	.word	0x40020008
 8005464:	40020000 	.word	0x40020000

08005468 <HAL_I2C_MspInit>:
* This function configures the hardware resources used in this example
* @param hi2c: I2C handle pointer
* @retval None
*/
void HAL_I2C_MspInit(I2C_HandleTypeDef* hi2c)
{
 8005468:	b590      	push	{r4, r7, lr}
 800546a:	b08b      	sub	sp, #44	; 0x2c
 800546c:	af00      	add	r7, sp, #0
 800546e:	6078      	str	r0, [r7, #4]
  GPIO_InitTypeDef GPIO_InitStruct = {0};
 8005470:	2414      	movs	r4, #20
 8005472:	193b      	adds	r3, r7, r4
 8005474:	0018      	movs	r0, r3
 8005476:	2314      	movs	r3, #20
 8005478:	001a      	movs	r2, r3
 800547a:	2100      	movs	r1, #0
 800547c:	f004 fc00 	bl	8009c80 <memset>
  if(hi2c->Instance==I2C1)
 8005480:	687b      	ldr	r3, [r7, #4]
 8005482:	681b      	ldr	r3, [r3, #0]
 8005484:	4a1c      	ldr	r2, [pc, #112]	; (80054f8 <HAL_I2C_MspInit+0x90>)
 8005486:	4293      	cmp	r3, r2
 8005488:	d132      	bne.n	80054f0 <HAL_I2C_MspInit+0x88>
  {
  /* USER CODE BEGIN I2C1_MspInit 0 */

  /* USER CODE END I2C1_MspInit 0 */

    __HAL_RCC_GPIOB_CLK_ENABLE();
 800548a:	4b1c      	ldr	r3, [pc, #112]	; (80054fc <HAL_I2C_MspInit+0x94>)
 800548c:	695a      	ldr	r2, [r3, #20]
 800548e:	4b1b      	ldr	r3, [pc, #108]	; (80054fc <HAL_I2C_MspInit+0x94>)
 8005490:	2180      	movs	r1, #128	; 0x80
 8005492:	02c9      	lsls	r1, r1, #11
 8005494:	430a      	orrs	r2, r1
 8005496:	615a      	str	r2, [r3, #20]
 8005498:	4b18      	ldr	r3, [pc, #96]	; (80054fc <HAL_I2C_MspInit+0x94>)
 800549a:	695a      	ldr	r2, [r3, #20]
 800549c:	2380      	movs	r3, #128	; 0x80
 800549e:	02db      	lsls	r3, r3, #11
 80054a0:	4013      	ands	r3, r2
 80054a2:	613b      	str	r3, [r7, #16]
 80054a4:	693b      	ldr	r3, [r7, #16]
    /**I2C1 GPIO Configuration
    PB8     ------> I2C1_SCL
    PB9     ------> I2C1_SDA
    */
    GPIO_InitStruct.Pin = GPIO_PIN_8|GPIO_PIN_9;
 80054a6:	193b      	adds	r3, r7, r4
 80054a8:	22c0      	movs	r2, #192	; 0xc0
 80054aa:	0092      	lsls	r2, r2, #2
 80054ac:	601a      	str	r2, [r3, #0]
    GPIO_InitStruct.Mode = GPIO_MODE_AF_OD;
 80054ae:	0021      	movs	r1, r4
 80054b0:	187b      	adds	r3, r7, r1
 80054b2:	2212      	movs	r2, #18
 80054b4:	605a      	str	r2, [r3, #4]
    GPIO_InitStruct.Pull = GPIO_NOPULL;
 80054b6:	187b      	adds	r3, r7, r1
 80054b8:	2200      	movs	r2, #0
 80054ba:	609a      	str	r2, [r3, #8]
    GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
 80054bc:	187b      	adds	r3, r7, r1
 80054be:	2203      	movs	r2, #3
 80054c0:	60da      	str	r2, [r3, #12]
    GPIO_InitStruct.Alternate = GPIO_AF1_I2C1;
 80054c2:	187b      	adds	r3, r7, r1
 80054c4:	2201      	movs	r2, #1
 80054c6:	611a      	str	r2, [r3, #16]
    HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
 80054c8:	187b      	adds	r3, r7, r1
 80054ca:	4a0d      	ldr	r2, [pc, #52]	; (8005500 <HAL_I2C_MspInit+0x98>)
 80054cc:	0019      	movs	r1, r3
 80054ce:	0010      	movs	r0, r2
 80054d0:	f001 f934 	bl	800673c <HAL_GPIO_Init>

    /* Peripheral clock enable */
    __HAL_RCC_I2C1_CLK_ENABLE();
 80054d4:	4b09      	ldr	r3, [pc, #36]	; (80054fc <HAL_I2C_MspInit+0x94>)
 80054d6:	69da      	ldr	r2, [r3, #28]
 80054d8:	4b08      	ldr	r3, [pc, #32]	; (80054fc <HAL_I2C_MspInit+0x94>)
 80054da:	2180      	movs	r1, #128	; 0x80
 80054dc:	0389      	lsls	r1, r1, #14
 80054de:	430a      	orrs	r2, r1
 80054e0:	61da      	str	r2, [r3, #28]
 80054e2:	4b06      	ldr	r3, [pc, #24]	; (80054fc <HAL_I2C_MspInit+0x94>)
 80054e4:	69da      	ldr	r2, [r3, #28]
 80054e6:	2380      	movs	r3, #128	; 0x80
 80054e8:	039b      	lsls	r3, r3, #14
 80054ea:	4013      	ands	r3, r2
 80054ec:	60fb      	str	r3, [r7, #12]
 80054ee:	68fb      	ldr	r3, [r7, #12]
  /* USER CODE BEGIN I2C1_MspInit 1 */

  /* USER CODE END I2C1_MspInit 1 */
  }

}
 80054f0:	46c0      	nop			; (mov r8, r8)
 80054f2:	46bd      	mov	sp, r7
 80054f4:	b00b      	add	sp, #44	; 0x2c
 80054f6:	bd90      	pop	{r4, r7, pc}
 80054f8:	40005400 	.word	0x40005400
 80054fc:	40021000 	.word	0x40021000
 8005500:	48000400 	.word	0x48000400

08005504 <HAL_SPI_MspInit>:
* This function configures the hardware resources used in this example
* @param hspi: SPI handle pointer
* @retval None
*/
void HAL_SPI_MspInit(SPI_HandleTypeDef* hspi)
{
 8005504:	b590      	push	{r4, r7, lr}
 8005506:	b08b      	sub	sp, #44	; 0x2c
 8005508:	af00      	add	r7, sp, #0
 800550a:	6078      	str	r0, [r7, #4]
  GPIO_InitTypeDef GPIO_InitStruct = {0};
 800550c:	2414      	movs	r4, #20
 800550e:	193b      	adds	r3, r7, r4
 8005510:	0018      	movs	r0, r3
 8005512:	2314      	movs	r3, #20
 8005514:	001a      	movs	r2, r3
 8005516:	2100      	movs	r1, #0
 8005518:	f004 fbb2 	bl	8009c80 <memset>
  if(hspi->Instance==SPI1)
 800551c:	687b      	ldr	r3, [r7, #4]
 800551e:	681b      	ldr	r3, [r3, #0]
 8005520:	4a1c      	ldr	r2, [pc, #112]	; (8005594 <HAL_SPI_MspInit+0x90>)
 8005522:	4293      	cmp	r3, r2
 8005524:	d132      	bne.n	800558c <HAL_SPI_MspInit+0x88>
  {
  /* USER CODE BEGIN SPI1_MspInit 0 */

  /* USER CODE END SPI1_MspInit 0 */
    /* Peripheral clock enable */
    __HAL_RCC_SPI1_CLK_ENABLE();
 8005526:	4b1c      	ldr	r3, [pc, #112]	; (8005598 <HAL_SPI_MspInit+0x94>)
 8005528:	699a      	ldr	r2, [r3, #24]
 800552a:	4b1b      	ldr	r3, [pc, #108]	; (8005598 <HAL_SPI_MspInit+0x94>)
 800552c:	2180      	movs	r1, #128	; 0x80
 800552e:	0149      	lsls	r1, r1, #5
 8005530:	430a      	orrs	r2, r1
 8005532:	619a      	str	r2, [r3, #24]
 8005534:	4b18      	ldr	r3, [pc, #96]	; (8005598 <HAL_SPI_MspInit+0x94>)
 8005536:	699a      	ldr	r2, [r3, #24]
 8005538:	2380      	movs	r3, #128	; 0x80
 800553a:	015b      	lsls	r3, r3, #5
 800553c:	4013      	ands	r3, r2
 800553e:	613b      	str	r3, [r7, #16]
 8005540:	693b      	ldr	r3, [r7, #16]

    __HAL_RCC_GPIOA_CLK_ENABLE();
 8005542:	4b15      	ldr	r3, [pc, #84]	; (8005598 <HAL_SPI_MspInit+0x94>)
 8005544:	695a      	ldr	r2, [r3, #20]
 8005546:	4b14      	ldr	r3, [pc, #80]	; (8005598 <HAL_SPI_MspInit+0x94>)
 8005548:	2180      	movs	r1, #128	; 0x80
 800554a:	0289      	lsls	r1, r1, #10
 800554c:	430a      	orrs	r2, r1
 800554e:	615a      	str	r2, [r3, #20]
 8005550:	4b11      	ldr	r3, [pc, #68]	; (8005598 <HAL_SPI_MspInit+0x94>)
 8005552:	695a      	ldr	r2, [r3, #20]
 8005554:	2380      	movs	r3, #128	; 0x80
 8005556:	029b      	lsls	r3, r3, #10
 8005558:	4013      	ands	r3, r2
 800555a:	60fb      	str	r3, [r7, #12]
 800555c:	68fb      	ldr	r3, [r7, #12]
    /**SPI1 GPIO Configuration
    PA4     ------> SPI1_NSS
    PA5     ------> SPI1_SCK
    PA7     ------> SPI1_MOSI
    */
    GPIO_InitStruct.Pin = GPIO_PIN_4|GPIO_PIN_5|GPIO_PIN_7;
 800555e:	0021      	movs	r1, r4
 8005560:	187b      	adds	r3, r7, r1
 8005562:	22b0      	movs	r2, #176	; 0xb0
 8005564:	601a      	str	r2, [r3, #0]
    GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
 8005566:	187b      	adds	r3, r7, r1
 8005568:	2202      	movs	r2, #2
 800556a:	605a      	str	r2, [r3, #4]
    GPIO_InitStruct.Pull = GPIO_NOPULL;
 800556c:	187b      	adds	r3, r7, r1
 800556e:	2200      	movs	r2, #0
 8005570:	609a      	str	r2, [r3, #8]
    GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH;
 8005572:	187b      	adds	r3, r7, r1
 8005574:	2203      	movs	r2, #3
 8005576:	60da      	str	r2, [r3, #12]
    GPIO_InitStruct.Alternate = GPIO_AF0_SPI1;
 8005578:	187b      	adds	r3, r7, r1
 800557a:	2200      	movs	r2, #0
 800557c:	611a      	str	r2, [r3, #16]
    HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
 800557e:	187a      	adds	r2, r7, r1
 8005580:	2390      	movs	r3, #144	; 0x90
 8005582:	05db      	lsls	r3, r3, #23
 8005584:	0011      	movs	r1, r2
 8005586:	0018      	movs	r0, r3
 8005588:	f001 f8d8 	bl	800673c <HAL_GPIO_Init>
  /* USER CODE BEGIN SPI1_MspInit 1 */

  /* USER CODE END SPI1_MspInit 1 */
  }

}
 800558c:	46c0      	nop			; (mov r8, r8)
 800558e:	46bd      	mov	sp, r7
 8005590:	b00b      	add	sp, #44	; 0x2c
 8005592:	bd90      	pop	{r4, r7, pc}
 8005594:	40013000 	.word	0x40013000
 8005598:	40021000 	.word	0x40021000

0800559c <HAL_TIM_PWM_MspInit>:
* This function configures the hardware resources used in this example
* @param htim_pwm: TIM_PWM handle pointer
* @retval None
*/
void HAL_TIM_PWM_MspInit(TIM_HandleTypeDef* htim_pwm)
{
 800559c:	b580      	push	{r7, lr}
 800559e:	b084      	sub	sp, #16
 80055a0:	af00      	add	r7, sp, #0
 80055a2:	6078      	str	r0, [r7, #4]
  if(htim_pwm->Instance==TIM1)
 80055a4:	687b      	ldr	r3, [r7, #4]
 80055a6:	681b      	ldr	r3, [r3, #0]
 80055a8:	4a0a      	ldr	r2, [pc, #40]	; (80055d4 <HAL_TIM_PWM_MspInit+0x38>)
 80055aa:	4293      	cmp	r3, r2
 80055ac:	d10d      	bne.n	80055ca <HAL_TIM_PWM_MspInit+0x2e>
  {
  /* USER CODE BEGIN TIM1_MspInit 0 */

  /* USER CODE END TIM1_MspInit 0 */
    /* Peripheral clock enable */
    __HAL_RCC_TIM1_CLK_ENABLE();
 80055ae:	4b0a      	ldr	r3, [pc, #40]	; (80055d8 <HAL_TIM_PWM_MspInit+0x3c>)
 80055b0:	699a      	ldr	r2, [r3, #24]
 80055b2:	4b09      	ldr	r3, [pc, #36]	; (80055d8 <HAL_TIM_PWM_MspInit+0x3c>)
 80055b4:	2180      	movs	r1, #128	; 0x80
 80055b6:	0109      	lsls	r1, r1, #4
 80055b8:	430a      	orrs	r2, r1
 80055ba:	619a      	str	r2, [r3, #24]
 80055bc:	4b06      	ldr	r3, [pc, #24]	; (80055d8 <HAL_TIM_PWM_MspInit+0x3c>)
 80055be:	699a      	ldr	r2, [r3, #24]
 80055c0:	2380      	movs	r3, #128	; 0x80
 80055c2:	011b      	lsls	r3, r3, #4
 80055c4:	4013      	ands	r3, r2
 80055c6:	60fb      	str	r3, [r7, #12]
 80055c8:	68fb      	ldr	r3, [r7, #12]
  /* USER CODE BEGIN TIM1_MspInit 1 */

  /* USER CODE END TIM1_MspInit 1 */
  }

}
 80055ca:	46c0      	nop			; (mov r8, r8)
 80055cc:	46bd      	mov	sp, r7
 80055ce:	b004      	add	sp, #16
 80055d0:	bd80      	pop	{r7, pc}
 80055d2:	46c0      	nop			; (mov r8, r8)
 80055d4:	40012c00 	.word	0x40012c00
 80055d8:	40021000 	.word	0x40021000

080055dc <HAL_TIM_MspPostInit>:

void HAL_TIM_MspPostInit(TIM_HandleTypeDef* htim)
{
 80055dc:	b590      	push	{r4, r7, lr}
 80055de:	b089      	sub	sp, #36	; 0x24
 80055e0:	af00      	add	r7, sp, #0
 80055e2:	6078      	str	r0, [r7, #4]
  GPIO_InitTypeDef GPIO_InitStruct = {0};
 80055e4:	240c      	movs	r4, #12
 80055e6:	193b      	adds	r3, r7, r4
 80055e8:	0018      	movs	r0, r3
 80055ea:	2314      	movs	r3, #20
 80055ec:	001a      	movs	r2, r3
 80055ee:	2100      	movs	r1, #0
 80055f0:	f004 fb46 	bl	8009c80 <memset>
  if(htim->Instance==TIM1)
 80055f4:	687b      	ldr	r3, [r7, #4]
 80055f6:	681b      	ldr	r3, [r3, #0]
 80055f8:	4a16      	ldr	r2, [pc, #88]	; (8005654 <HAL_TIM_MspPostInit+0x78>)
 80055fa:	4293      	cmp	r3, r2
 80055fc:	d125      	bne.n	800564a <HAL_TIM_MspPostInit+0x6e>
  {
  /* USER CODE BEGIN TIM1_MspPostInit 0 */

  /* USER CODE END TIM1_MspPostInit 0 */

    __HAL_RCC_GPIOA_CLK_ENABLE();
 80055fe:	4b16      	ldr	r3, [pc, #88]	; (8005658 <HAL_TIM_MspPostInit+0x7c>)
 8005600:	695a      	ldr	r2, [r3, #20]
 8005602:	4b15      	ldr	r3, [pc, #84]	; (8005658 <HAL_TIM_MspPostInit+0x7c>)
 8005604:	2180      	movs	r1, #128	; 0x80
 8005606:	0289      	lsls	r1, r1, #10
 8005608:	430a      	orrs	r2, r1
 800560a:	615a      	str	r2, [r3, #20]
 800560c:	4b12      	ldr	r3, [pc, #72]	; (8005658 <HAL_TIM_MspPostInit+0x7c>)
 800560e:	695a      	ldr	r2, [r3, #20]
 8005610:	2380      	movs	r3, #128	; 0x80
 8005612:	029b      	lsls	r3, r3, #10
 8005614:	4013      	ands	r3, r2
 8005616:	60bb      	str	r3, [r7, #8]
 8005618:	68bb      	ldr	r3, [r7, #8]
    /**TIM1 GPIO Configuration
    PA8     ------> TIM1_CH1
    */
    GPIO_InitStruct.Pin = GPIO_PIN_8;
 800561a:	193b      	adds	r3, r7, r4
 800561c:	2280      	movs	r2, #128	; 0x80
 800561e:	0052      	lsls	r2, r2, #1
 8005620:	601a      	str	r2, [r3, #0]
    GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
 8005622:	0021      	movs	r1, r4
 8005624:	187b      	adds	r3, r7, r1
 8005626:	2202      	movs	r2, #2
 8005628:	605a      	str	r2, [r3, #4]
    GPIO_InitStruct.Pull = GPIO_NOPULL;
 800562a:	187b      	adds	r3, r7, r1
 800562c:	2200      	movs	r2, #0
 800562e:	609a      	str	r2, [r3, #8]
    GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
 8005630:	187b      	adds	r3, r7, r1
 8005632:	2200      	movs	r2, #0
 8005634:	60da      	str	r2, [r3, #12]
    GPIO_InitStruct.Alternate = GPIO_AF2_TIM1;
 8005636:	187b      	adds	r3, r7, r1
 8005638:	2202      	movs	r2, #2
 800563a:	611a      	str	r2, [r3, #16]
    HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
 800563c:	187a      	adds	r2, r7, r1
 800563e:	2390      	movs	r3, #144	; 0x90
 8005640:	05db      	lsls	r3, r3, #23
 8005642:	0011      	movs	r1, r2
 8005644:	0018      	movs	r0, r3
 8005646:	f001 f879 	bl	800673c <HAL_GPIO_Init>
  /* USER CODE BEGIN TIM1_MspPostInit 1 */

  /* USER CODE END TIM1_MspPostInit 1 */
  }

}
 800564a:	46c0      	nop			; (mov r8, r8)
 800564c:	46bd      	mov	sp, r7
 800564e:	b009      	add	sp, #36	; 0x24
 8005650:	bd90      	pop	{r4, r7, pc}
 8005652:	46c0      	nop			; (mov r8, r8)
 8005654:	40012c00 	.word	0x40012c00
 8005658:	40021000 	.word	0x40021000

0800565c <NMI_Handler>:
/******************************************************************************/
/**
  * @brief This function handles Non maskable interrupt.
  */
void NMI_Handler(void)
{
 800565c:	b580      	push	{r7, lr}
 800565e:	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)
 8005660:	e7fe      	b.n	8005660 <NMI_Handler+0x4>

08005662 <HardFault_Handler>:

/**
  * @brief This function handles Hard fault interrupt.
  */
void HardFault_Handler(void)
{
 8005662:	b580      	push	{r7, lr}
 8005664:	af00      	add	r7, sp, #0
  /* USER CODE BEGIN HardFault_IRQn 0 */

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

08005668 <SVC_Handler>:

/**
  * @brief This function handles System service call via SWI instruction.
  */
void SVC_Handler(void)
{
 8005668:	b580      	push	{r7, lr}
 800566a:	af00      	add	r7, sp, #0

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

  /* USER CODE END SVC_IRQn 1 */
}
 800566c:	46c0      	nop			; (mov r8, r8)
 800566e:	46bd      	mov	sp, r7
 8005670:	bd80      	pop	{r7, pc}

08005672 <PendSV_Handler>:

/**
  * @brief This function handles Pendable request for system service.
  */
void PendSV_Handler(void)
{
 8005672:	b580      	push	{r7, lr}
 8005674:	af00      	add	r7, sp, #0

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

  /* USER CODE END PendSV_IRQn 1 */
}
 8005676:	46c0      	nop			; (mov r8, r8)
 8005678:	46bd      	mov	sp, r7
 800567a:	bd80      	pop	{r7, pc}

0800567c <SysTick_Handler>:

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

  /* USER CODE END SysTick_IRQn 0 */
  HAL_IncTick();
 8005680:	f000 f956 	bl	8005930 <HAL_IncTick>
  /* USER CODE BEGIN SysTick_IRQn 1 */

  /* USER CODE END SysTick_IRQn 1 */
}
 8005684:	46c0      	nop			; (mov r8, r8)
 8005686:	46bd      	mov	sp, r7
 8005688:	bd80      	pop	{r7, pc}

0800568a <EXTI4_15_IRQHandler>:

/**
  * @brief This function handles EXTI line 4 to 15 interrupts.
  */
void EXTI4_15_IRQHandler(void)
{
 800568a:	b580      	push	{r7, lr}
 800568c:	af00      	add	r7, sp, #0
  /* USER CODE BEGIN EXTI4_15_IRQn 0 */

  /* USER CODE END EXTI4_15_IRQn 0 */
  HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_4);
 800568e:	2010      	movs	r0, #16
 8005690:	f001 fa06 	bl	8006aa0 <HAL_GPIO_EXTI_IRQHandler>
  HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_5);
 8005694:	2020      	movs	r0, #32
 8005696:	f001 fa03 	bl	8006aa0 <HAL_GPIO_EXTI_IRQHandler>
  HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_6);
 800569a:	2040      	movs	r0, #64	; 0x40
 800569c:	f001 fa00 	bl	8006aa0 <HAL_GPIO_EXTI_IRQHandler>
  HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_7);
 80056a0:	2080      	movs	r0, #128	; 0x80
 80056a2:	f001 f9fd 	bl	8006aa0 <HAL_GPIO_EXTI_IRQHandler>
  /* USER CODE BEGIN EXTI4_15_IRQn 1 */

  /* USER CODE END EXTI4_15_IRQn 1 */
}
 80056a6:	46c0      	nop			; (mov r8, r8)
 80056a8:	46bd      	mov	sp, r7
 80056aa:	bd80      	pop	{r7, pc}

080056ac <DMA1_Ch1_IRQHandler>:

/**
  * @brief This function handles DMA1 channel 1 interrupt.
  */
void DMA1_Ch1_IRQHandler(void)
{
 80056ac:	b580      	push	{r7, lr}
 80056ae:	af00      	add	r7, sp, #0
  /* USER CODE BEGIN DMA1_Ch1_IRQn 0 */

  /* USER CODE END DMA1_Ch1_IRQn 0 */
  HAL_DMA_IRQHandler(&hdma_adc);
 80056b0:	4b03      	ldr	r3, [pc, #12]	; (80056c0 <DMA1_Ch1_IRQHandler+0x14>)
 80056b2:	0018      	movs	r0, r3
 80056b4:	f000 ff2d 	bl	8006512 <HAL_DMA_IRQHandler>
  /* USER CODE BEGIN DMA1_Ch1_IRQn 1 */

  /* USER CODE END DMA1_Ch1_IRQn 1 */
}
 80056b8:	46c0      	nop			; (mov r8, r8)
 80056ba:	46bd      	mov	sp, r7
 80056bc:	bd80      	pop	{r7, pc}
 80056be:	46c0      	nop			; (mov r8, r8)
 80056c0:	20002250 	.word	0x20002250

080056c4 <_getpid>:
void initialise_monitor_handles()
{
}

int _getpid(void)
{
 80056c4:	b580      	push	{r7, lr}
 80056c6:	af00      	add	r7, sp, #0
	return 1;
 80056c8:	2301      	movs	r3, #1
}
 80056ca:	0018      	movs	r0, r3
 80056cc:	46bd      	mov	sp, r7
 80056ce:	bd80      	pop	{r7, pc}

080056d0 <_kill>:

int _kill(int pid, int sig)
{
 80056d0:	b580      	push	{r7, lr}
 80056d2:	b082      	sub	sp, #8
 80056d4:	af00      	add	r7, sp, #0
 80056d6:	6078      	str	r0, [r7, #4]
 80056d8:	6039      	str	r1, [r7, #0]
	errno = EINVAL;
 80056da:	f004 fa9d 	bl	8009c18 <__errno>
 80056de:	0003      	movs	r3, r0
 80056e0:	2216      	movs	r2, #22
 80056e2:	601a      	str	r2, [r3, #0]
	return -1;
 80056e4:	2301      	movs	r3, #1
 80056e6:	425b      	negs	r3, r3
}
 80056e8:	0018      	movs	r0, r3
 80056ea:	46bd      	mov	sp, r7
 80056ec:	b002      	add	sp, #8
 80056ee:	bd80      	pop	{r7, pc}

080056f0 <_exit>:

void _exit (int status)
{
 80056f0:	b580      	push	{r7, lr}
 80056f2:	b082      	sub	sp, #8
 80056f4:	af00      	add	r7, sp, #0
 80056f6:	6078      	str	r0, [r7, #4]
	_kill(status, -1);
 80056f8:	2301      	movs	r3, #1
 80056fa:	425a      	negs	r2, r3
 80056fc:	687b      	ldr	r3, [r7, #4]
 80056fe:	0011      	movs	r1, r2
 8005700:	0018      	movs	r0, r3
 8005702:	f7ff ffe5 	bl	80056d0 <_kill>
	while (1) {}		/* Make sure we hang here */
 8005706:	e7fe      	b.n	8005706 <_exit+0x16>

08005708 <_read>:
}

__attribute__((weak)) int _read(int file, char *ptr, int len)
{
 8005708:	b580      	push	{r7, lr}
 800570a:	b086      	sub	sp, #24
 800570c:	af00      	add	r7, sp, #0
 800570e:	60f8      	str	r0, [r7, #12]
 8005710:	60b9      	str	r1, [r7, #8]
 8005712:	607a      	str	r2, [r7, #4]
	int DataIdx;

	for (DataIdx = 0; DataIdx < len; DataIdx++)
 8005714:	2300      	movs	r3, #0
 8005716:	617b      	str	r3, [r7, #20]
 8005718:	e00a      	b.n	8005730 <_read+0x28>
	{
		*ptr++ = __io_getchar();
 800571a:	e000      	b.n	800571e <_read+0x16>
 800571c:	bf00      	nop
 800571e:	0001      	movs	r1, r0
 8005720:	68bb      	ldr	r3, [r7, #8]
 8005722:	1c5a      	adds	r2, r3, #1
 8005724:	60ba      	str	r2, [r7, #8]
 8005726:	b2ca      	uxtb	r2, r1
 8005728:	701a      	strb	r2, [r3, #0]
	for (DataIdx = 0; DataIdx < len; DataIdx++)
 800572a:	697b      	ldr	r3, [r7, #20]
 800572c:	3301      	adds	r3, #1
 800572e:	617b      	str	r3, [r7, #20]
 8005730:	697a      	ldr	r2, [r7, #20]
 8005732:	687b      	ldr	r3, [r7, #4]
 8005734:	429a      	cmp	r2, r3
 8005736:	dbf0      	blt.n	800571a <_read+0x12>
	}

return len;
 8005738:	687b      	ldr	r3, [r7, #4]
}
 800573a:	0018      	movs	r0, r3
 800573c:	46bd      	mov	sp, r7
 800573e:	b006      	add	sp, #24
 8005740:	bd80      	pop	{r7, pc}

08005742 <_write>:

__attribute__((weak)) int _write(int file, char *ptr, int len)
{
 8005742:	b580      	push	{r7, lr}
 8005744:	b086      	sub	sp, #24
 8005746:	af00      	add	r7, sp, #0
 8005748:	60f8      	str	r0, [r7, #12]
 800574a:	60b9      	str	r1, [r7, #8]
 800574c:	607a      	str	r2, [r7, #4]
	int DataIdx;

	for (DataIdx = 0; DataIdx < len; DataIdx++)
 800574e:	2300      	movs	r3, #0
 8005750:	617b      	str	r3, [r7, #20]
 8005752:	e009      	b.n	8005768 <_write+0x26>
	{
		__io_putchar(*ptr++);
 8005754:	68bb      	ldr	r3, [r7, #8]
 8005756:	1c5a      	adds	r2, r3, #1
 8005758:	60ba      	str	r2, [r7, #8]
 800575a:	781b      	ldrb	r3, [r3, #0]
 800575c:	0018      	movs	r0, r3
 800575e:	e000      	b.n	8005762 <_write+0x20>
 8005760:	bf00      	nop
	for (DataIdx = 0; DataIdx < len; DataIdx++)
 8005762:	697b      	ldr	r3, [r7, #20]
 8005764:	3301      	adds	r3, #1
 8005766:	617b      	str	r3, [r7, #20]
 8005768:	697a      	ldr	r2, [r7, #20]
 800576a:	687b      	ldr	r3, [r7, #4]
 800576c:	429a      	cmp	r2, r3
 800576e:	dbf1      	blt.n	8005754 <_write+0x12>
	}
	return len;
 8005770:	687b      	ldr	r3, [r7, #4]
}
 8005772:	0018      	movs	r0, r3
 8005774:	46bd      	mov	sp, r7
 8005776:	b006      	add	sp, #24
 8005778:	bd80      	pop	{r7, pc}

0800577a <_close>:

int _close(int file)
{
 800577a:	b580      	push	{r7, lr}
 800577c:	b082      	sub	sp, #8
 800577e:	af00      	add	r7, sp, #0
 8005780:	6078      	str	r0, [r7, #4]
	return -1;
 8005782:	2301      	movs	r3, #1
 8005784:	425b      	negs	r3, r3
}
 8005786:	0018      	movs	r0, r3
 8005788:	46bd      	mov	sp, r7
 800578a:	b002      	add	sp, #8
 800578c:	bd80      	pop	{r7, pc}

0800578e <_fstat>:


int _fstat(int file, struct stat *st)
{
 800578e:	b580      	push	{r7, lr}
 8005790:	b082      	sub	sp, #8
 8005792:	af00      	add	r7, sp, #0
 8005794:	6078      	str	r0, [r7, #4]
 8005796:	6039      	str	r1, [r7, #0]
	st->st_mode = S_IFCHR;
 8005798:	683b      	ldr	r3, [r7, #0]
 800579a:	2280      	movs	r2, #128	; 0x80
 800579c:	0192      	lsls	r2, r2, #6
 800579e:	605a      	str	r2, [r3, #4]
	return 0;
 80057a0:	2300      	movs	r3, #0
}
 80057a2:	0018      	movs	r0, r3
 80057a4:	46bd      	mov	sp, r7
 80057a6:	b002      	add	sp, #8
 80057a8:	bd80      	pop	{r7, pc}

080057aa <_isatty>:

int _isatty(int file)
{
 80057aa:	b580      	push	{r7, lr}
 80057ac:	b082      	sub	sp, #8
 80057ae:	af00      	add	r7, sp, #0
 80057b0:	6078      	str	r0, [r7, #4]
	return 1;
 80057b2:	2301      	movs	r3, #1
}
 80057b4:	0018      	movs	r0, r3
 80057b6:	46bd      	mov	sp, r7
 80057b8:	b002      	add	sp, #8
 80057ba:	bd80      	pop	{r7, pc}

080057bc <_lseek>:

int _lseek(int file, int ptr, int dir)
{
 80057bc:	b580      	push	{r7, lr}
 80057be:	b084      	sub	sp, #16
 80057c0:	af00      	add	r7, sp, #0
 80057c2:	60f8      	str	r0, [r7, #12]
 80057c4:	60b9      	str	r1, [r7, #8]
 80057c6:	607a      	str	r2, [r7, #4]
	return 0;
 80057c8:	2300      	movs	r3, #0
}
 80057ca:	0018      	movs	r0, r3
 80057cc:	46bd      	mov	sp, r7
 80057ce:	b004      	add	sp, #16
 80057d0:	bd80      	pop	{r7, pc}
	...

080057d4 <_sbrk>:
 *
 * @param incr Memory size
 * @return Pointer to allocated memory
 */
void *_sbrk(ptrdiff_t incr)
{
 80057d4:	b580      	push	{r7, lr}
 80057d6:	b086      	sub	sp, #24
 80057d8:	af00      	add	r7, sp, #0
 80057da:	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;
 80057dc:	4a14      	ldr	r2, [pc, #80]	; (8005830 <_sbrk+0x5c>)
 80057de:	4b15      	ldr	r3, [pc, #84]	; (8005834 <_sbrk+0x60>)
 80057e0:	1ad3      	subs	r3, r2, r3
 80057e2:	617b      	str	r3, [r7, #20]
  const uint8_t *max_heap = (uint8_t *)stack_limit;
 80057e4:	697b      	ldr	r3, [r7, #20]
 80057e6:	613b      	str	r3, [r7, #16]
  uint8_t *prev_heap_end;

  /* Initialize heap end at first call */
  if (NULL == __sbrk_heap_end)
 80057e8:	4b13      	ldr	r3, [pc, #76]	; (8005838 <_sbrk+0x64>)
 80057ea:	681b      	ldr	r3, [r3, #0]
 80057ec:	2b00      	cmp	r3, #0
 80057ee:	d102      	bne.n	80057f6 <_sbrk+0x22>
  {
    __sbrk_heap_end = &_end;
 80057f0:	4b11      	ldr	r3, [pc, #68]	; (8005838 <_sbrk+0x64>)
 80057f2:	4a12      	ldr	r2, [pc, #72]	; (800583c <_sbrk+0x68>)
 80057f4:	601a      	str	r2, [r3, #0]
  }

  /* Protect heap from growing into the reserved MSP stack */
  if (__sbrk_heap_end + incr > max_heap)
 80057f6:	4b10      	ldr	r3, [pc, #64]	; (8005838 <_sbrk+0x64>)
 80057f8:	681a      	ldr	r2, [r3, #0]
 80057fa:	687b      	ldr	r3, [r7, #4]
 80057fc:	18d3      	adds	r3, r2, r3
 80057fe:	693a      	ldr	r2, [r7, #16]
 8005800:	429a      	cmp	r2, r3
 8005802:	d207      	bcs.n	8005814 <_sbrk+0x40>
  {
    errno = ENOMEM;
 8005804:	f004 fa08 	bl	8009c18 <__errno>
 8005808:	0003      	movs	r3, r0
 800580a:	220c      	movs	r2, #12
 800580c:	601a      	str	r2, [r3, #0]
    return (void *)-1;
 800580e:	2301      	movs	r3, #1
 8005810:	425b      	negs	r3, r3
 8005812:	e009      	b.n	8005828 <_sbrk+0x54>
  }

  prev_heap_end = __sbrk_heap_end;
 8005814:	4b08      	ldr	r3, [pc, #32]	; (8005838 <_sbrk+0x64>)
 8005816:	681b      	ldr	r3, [r3, #0]
 8005818:	60fb      	str	r3, [r7, #12]
  __sbrk_heap_end += incr;
 800581a:	4b07      	ldr	r3, [pc, #28]	; (8005838 <_sbrk+0x64>)
 800581c:	681a      	ldr	r2, [r3, #0]
 800581e:	687b      	ldr	r3, [r7, #4]
 8005820:	18d2      	adds	r2, r2, r3
 8005822:	4b05      	ldr	r3, [pc, #20]	; (8005838 <_sbrk+0x64>)
 8005824:	601a      	str	r2, [r3, #0]

  return (void *)prev_heap_end;
 8005826:	68fb      	ldr	r3, [r7, #12]
}
 8005828:	0018      	movs	r0, r3
 800582a:	46bd      	mov	sp, r7
 800582c:	b006      	add	sp, #24
 800582e:	bd80      	pop	{r7, pc}
 8005830:	20008000 	.word	0x20008000
 8005834:	00000400 	.word	0x00000400
 8005838:	20002128 	.word	0x20002128
 800583c:	200022f0 	.word	0x200022f0

08005840 <SystemInit>:
  * @brief  Setup the microcontroller system
  * @param  None
  * @retval None
  */
void SystemInit(void)
{
 8005840:	b580      	push	{r7, lr}
 8005842:	af00      	add	r7, sp, #0
                         before branch to main program. This call is made inside
                         the "startup_stm32f0xx.s" file.
                         User can setups the default system clock (System clock source, PLL Multiplier
                         and Divider factors, AHB/APBx prescalers and Flash settings).
   */
}
 8005844:	46c0      	nop			; (mov r8, r8)
 8005846:	46bd      	mov	sp, r7
 8005848:	bd80      	pop	{r7, pc}
	...

0800584c <Reset_Handler>:

  .section .text.Reset_Handler
  .weak Reset_Handler
  .type Reset_Handler, %function
Reset_Handler:
  ldr   r0, =_estack
 800584c:	480d      	ldr	r0, [pc, #52]	; (8005884 <LoopForever+0x2>)
  mov   sp, r0          /* set stack pointer */
 800584e:	4685      	mov	sp, r0

/* Copy the data segment initializers from flash to SRAM */
  ldr r0, =_sdata
 8005850:	480d      	ldr	r0, [pc, #52]	; (8005888 <LoopForever+0x6>)
  ldr r1, =_edata
 8005852:	490e      	ldr	r1, [pc, #56]	; (800588c <LoopForever+0xa>)
  ldr r2, =_sidata
 8005854:	4a0e      	ldr	r2, [pc, #56]	; (8005890 <LoopForever+0xe>)
  movs r3, #0
 8005856:	2300      	movs	r3, #0
  b LoopCopyDataInit
 8005858:	e002      	b.n	8005860 <LoopCopyDataInit>

0800585a <CopyDataInit>:

CopyDataInit:
  ldr r4, [r2, r3]
 800585a:	58d4      	ldr	r4, [r2, r3]
  str r4, [r0, r3]
 800585c:	50c4      	str	r4, [r0, r3]
  adds r3, r3, #4
 800585e:	3304      	adds	r3, #4

08005860 <LoopCopyDataInit>:

LoopCopyDataInit:
  adds r4, r0, r3
 8005860:	18c4      	adds	r4, r0, r3
  cmp r4, r1
 8005862:	428c      	cmp	r4, r1
  bcc CopyDataInit
 8005864:	d3f9      	bcc.n	800585a <CopyDataInit>
  
/* Zero fill the bss segment. */
  ldr r2, =_sbss
 8005866:	4a0b      	ldr	r2, [pc, #44]	; (8005894 <LoopForever+0x12>)
  ldr r4, =_ebss
 8005868:	4c0b      	ldr	r4, [pc, #44]	; (8005898 <LoopForever+0x16>)
  movs r3, #0
 800586a:	2300      	movs	r3, #0
  b LoopFillZerobss
 800586c:	e001      	b.n	8005872 <LoopFillZerobss>

0800586e <FillZerobss>:

FillZerobss:
  str  r3, [r2]
 800586e:	6013      	str	r3, [r2, #0]
  adds r2, r2, #4
 8005870:	3204      	adds	r2, #4

08005872 <LoopFillZerobss>:

LoopFillZerobss:
  cmp r2, r4
 8005872:	42a2      	cmp	r2, r4
  bcc FillZerobss
 8005874:	d3fb      	bcc.n	800586e <FillZerobss>

/* Call the clock system intitialization function.*/
  bl  SystemInit
 8005876:	f7ff ffe3 	bl	8005840 <SystemInit>
/* Call static constructors */
  bl __libc_init_array
 800587a:	f004 f9d3 	bl	8009c24 <__libc_init_array>
/* Call the application's entry point.*/
  bl main
 800587e:	f7fe fad7 	bl	8003e30 <main>

08005882 <LoopForever>:

LoopForever:
    b LoopForever
 8005882:	e7fe      	b.n	8005882 <LoopForever>
  ldr   r0, =_estack
 8005884:	20008000 	.word	0x20008000
  ldr r0, =_sdata
 8005888:	20000000 	.word	0x20000000
  ldr r1, =_edata
 800588c:	200000f0 	.word	0x200000f0
  ldr r2, =_sidata
 8005890:	0800f5a0 	.word	0x0800f5a0
  ldr r2, =_sbss
 8005894:	200000f0 	.word	0x200000f0
  ldr r4, =_ebss
 8005898:	200022ec 	.word	0x200022ec

0800589c <ADC1_COMP_IRQHandler>:
 * @retval : None
*/
    .section .text.Default_Handler,"ax",%progbits
Default_Handler:
Infinite_Loop:
  b Infinite_Loop
 800589c:	e7fe      	b.n	800589c <ADC1_COMP_IRQHandler>
	...

080058a0 <HAL_Init>:
  *       In the default implementation,Systick is used as source of time base.
  *       The tick variable is incremented each 1ms in its ISR.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_Init(void)
{
 80058a0:	b580      	push	{r7, lr}
 80058a2:	af00      	add	r7, sp, #0
  /* Configure Flash prefetch */ 
#if (PREFETCH_ENABLE != 0)
  __HAL_FLASH_PREFETCH_BUFFER_ENABLE();
 80058a4:	4b07      	ldr	r3, [pc, #28]	; (80058c4 <HAL_Init+0x24>)
 80058a6:	681a      	ldr	r2, [r3, #0]
 80058a8:	4b06      	ldr	r3, [pc, #24]	; (80058c4 <HAL_Init+0x24>)
 80058aa:	2110      	movs	r1, #16
 80058ac:	430a      	orrs	r2, r1
 80058ae:	601a      	str	r2, [r3, #0]
#endif /* PREFETCH_ENABLE */

  /* Use systick as time base source and configure 1ms tick (default clock after Reset is HSI) */

  HAL_InitTick(TICK_INT_PRIORITY);
 80058b0:	2003      	movs	r0, #3
 80058b2:	f000 f809 	bl	80058c8 <HAL_InitTick>

  /* Init the low level hardware */
  HAL_MspInit();
 80058b6:	f7ff fd2f 	bl	8005318 <HAL_MspInit>

  /* Return function status */
  return HAL_OK;
 80058ba:	2300      	movs	r3, #0
}
 80058bc:	0018      	movs	r0, r3
 80058be:	46bd      	mov	sp, r7
 80058c0:	bd80      	pop	{r7, pc}
 80058c2:	46c0      	nop			; (mov r8, r8)
 80058c4:	40022000 	.word	0x40022000

080058c8 <HAL_InitTick>:
  *       implementation  in user file.
  * @param TickPriority Tick interrupt priority.
  * @retval HAL status
  */
__weak HAL_StatusTypeDef HAL_InitTick(uint32_t TickPriority)
{
 80058c8:	b590      	push	{r4, r7, lr}
 80058ca:	b083      	sub	sp, #12
 80058cc:	af00      	add	r7, sp, #0
 80058ce:	6078      	str	r0, [r7, #4]
  /*Configure the SysTick to have interrupt in 1ms time basis*/
  if (HAL_SYSTICK_Config(SystemCoreClock / (1000U / uwTickFreq)) > 0U)
 80058d0:	4b14      	ldr	r3, [pc, #80]	; (8005924 <HAL_InitTick+0x5c>)
 80058d2:	681c      	ldr	r4, [r3, #0]
 80058d4:	4b14      	ldr	r3, [pc, #80]	; (8005928 <HAL_InitTick+0x60>)
 80058d6:	781b      	ldrb	r3, [r3, #0]
 80058d8:	0019      	movs	r1, r3
 80058da:	23fa      	movs	r3, #250	; 0xfa
 80058dc:	0098      	lsls	r0, r3, #2
 80058de:	f7fa fc11 	bl	8000104 <__udivsi3>
 80058e2:	0003      	movs	r3, r0
 80058e4:	0019      	movs	r1, r3
 80058e6:	0020      	movs	r0, r4
 80058e8:	f7fa fc0c 	bl	8000104 <__udivsi3>
 80058ec:	0003      	movs	r3, r0
 80058ee:	0018      	movs	r0, r3
 80058f0:	f000 fd0f 	bl	8006312 <HAL_SYSTICK_Config>
 80058f4:	1e03      	subs	r3, r0, #0
 80058f6:	d001      	beq.n	80058fc <HAL_InitTick+0x34>
  {
    return HAL_ERROR;
 80058f8:	2301      	movs	r3, #1
 80058fa:	e00f      	b.n	800591c <HAL_InitTick+0x54>
  }

  /* Configure the SysTick IRQ priority */
  if (TickPriority < (1UL << __NVIC_PRIO_BITS))
 80058fc:	687b      	ldr	r3, [r7, #4]
 80058fe:	2b03      	cmp	r3, #3
 8005900:	d80b      	bhi.n	800591a <HAL_InitTick+0x52>
  {
    HAL_NVIC_SetPriority(SysTick_IRQn, TickPriority, 0U);
 8005902:	6879      	ldr	r1, [r7, #4]
 8005904:	2301      	movs	r3, #1
 8005906:	425b      	negs	r3, r3
 8005908:	2200      	movs	r2, #0
 800590a:	0018      	movs	r0, r3
 800590c:	f000 fcdc 	bl	80062c8 <HAL_NVIC_SetPriority>
    uwTickPrio = TickPriority;
 8005910:	4b06      	ldr	r3, [pc, #24]	; (800592c <HAL_InitTick+0x64>)
 8005912:	687a      	ldr	r2, [r7, #4]
 8005914:	601a      	str	r2, [r3, #0]
  {
    return HAL_ERROR;
  }

   /* Return function status */
  return HAL_OK;
 8005916:	2300      	movs	r3, #0
 8005918:	e000      	b.n	800591c <HAL_InitTick+0x54>
    return HAL_ERROR;
 800591a:	2301      	movs	r3, #1
}
 800591c:	0018      	movs	r0, r3
 800591e:	46bd      	mov	sp, r7
 8005920:	b003      	add	sp, #12
 8005922:	bd90      	pop	{r4, r7, pc}
 8005924:	2000007c 	.word	0x2000007c
 8005928:	20000084 	.word	0x20000084
 800592c:	20000080 	.word	0x20000080

08005930 <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)
{
 8005930:	b580      	push	{r7, lr}
 8005932:	af00      	add	r7, sp, #0
  uwTick += uwTickFreq;
 8005934:	4b05      	ldr	r3, [pc, #20]	; (800594c <HAL_IncTick+0x1c>)
 8005936:	781b      	ldrb	r3, [r3, #0]
 8005938:	001a      	movs	r2, r3
 800593a:	4b05      	ldr	r3, [pc, #20]	; (8005950 <HAL_IncTick+0x20>)
 800593c:	681b      	ldr	r3, [r3, #0]
 800593e:	18d2      	adds	r2, r2, r3
 8005940:	4b03      	ldr	r3, [pc, #12]	; (8005950 <HAL_IncTick+0x20>)
 8005942:	601a      	str	r2, [r3, #0]
}
 8005944:	46c0      	nop			; (mov r8, r8)
 8005946:	46bd      	mov	sp, r7
 8005948:	bd80      	pop	{r7, pc}
 800594a:	46c0      	nop			; (mov r8, r8)
 800594c:	20000084 	.word	0x20000084
 8005950:	200022d8 	.word	0x200022d8

08005954 <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)
{
 8005954:	b580      	push	{r7, lr}
 8005956:	af00      	add	r7, sp, #0
  return uwTick;
 8005958:	4b02      	ldr	r3, [pc, #8]	; (8005964 <HAL_GetTick+0x10>)
 800595a:	681b      	ldr	r3, [r3, #0]
}
 800595c:	0018      	movs	r0, r3
 800595e:	46bd      	mov	sp, r7
 8005960:	bd80      	pop	{r7, pc}
 8005962:	46c0      	nop			; (mov r8, r8)
 8005964:	200022d8 	.word	0x200022d8

08005968 <HAL_Delay>:
  *       implementations in user file.
  * @param Delay specifies the delay time length, in milliseconds.
  * @retval None
  */
__weak void HAL_Delay(uint32_t Delay)
{
 8005968:	b580      	push	{r7, lr}
 800596a:	b084      	sub	sp, #16
 800596c:	af00      	add	r7, sp, #0
 800596e:	6078      	str	r0, [r7, #4]
  uint32_t tickstart = HAL_GetTick();
 8005970:	f7ff fff0 	bl	8005954 <HAL_GetTick>
 8005974:	0003      	movs	r3, r0
 8005976:	60bb      	str	r3, [r7, #8]
  uint32_t wait = Delay;
 8005978:	687b      	ldr	r3, [r7, #4]
 800597a:	60fb      	str	r3, [r7, #12]
  
  /* Add a freq to guarantee minimum wait */
  if (wait < HAL_MAX_DELAY)
 800597c:	68fb      	ldr	r3, [r7, #12]
 800597e:	3301      	adds	r3, #1
 8005980:	d005      	beq.n	800598e <HAL_Delay+0x26>
  {
    wait += (uint32_t)(uwTickFreq);
 8005982:	4b0a      	ldr	r3, [pc, #40]	; (80059ac <HAL_Delay+0x44>)
 8005984:	781b      	ldrb	r3, [r3, #0]
 8005986:	001a      	movs	r2, r3
 8005988:	68fb      	ldr	r3, [r7, #12]
 800598a:	189b      	adds	r3, r3, r2
 800598c:	60fb      	str	r3, [r7, #12]
  }
  
  while((HAL_GetTick() - tickstart) < wait)
 800598e:	46c0      	nop			; (mov r8, r8)
 8005990:	f7ff ffe0 	bl	8005954 <HAL_GetTick>
 8005994:	0002      	movs	r2, r0
 8005996:	68bb      	ldr	r3, [r7, #8]
 8005998:	1ad3      	subs	r3, r2, r3
 800599a:	68fa      	ldr	r2, [r7, #12]
 800599c:	429a      	cmp	r2, r3
 800599e:	d8f7      	bhi.n	8005990 <HAL_Delay+0x28>
  {
  }
}
 80059a0:	46c0      	nop			; (mov r8, r8)
 80059a2:	46c0      	nop			; (mov r8, r8)
 80059a4:	46bd      	mov	sp, r7
 80059a6:	b004      	add	sp, #16
 80059a8:	bd80      	pop	{r7, pc}
 80059aa:	46c0      	nop			; (mov r8, r8)
 80059ac:	20000084 	.word	0x20000084

080059b0 <HAL_ADC_Init>:
  *         of structure "ADC_InitTypeDef".
  * @param  hadc ADC handle
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_ADC_Init(ADC_HandleTypeDef* hadc)
{
 80059b0:	b580      	push	{r7, lr}
 80059b2:	b084      	sub	sp, #16
 80059b4:	af00      	add	r7, sp, #0
 80059b6:	6078      	str	r0, [r7, #4]
  HAL_StatusTypeDef tmp_hal_status = HAL_OK;
 80059b8:	230f      	movs	r3, #15
 80059ba:	18fb      	adds	r3, r7, r3
 80059bc:	2200      	movs	r2, #0
 80059be:	701a      	strb	r2, [r3, #0]
  uint32_t tmpCFGR1 = 0U;
 80059c0:	2300      	movs	r3, #0
 80059c2:	60bb      	str	r3, [r7, #8]

  /* Check ADC handle */
  if(hadc == NULL)
 80059c4:	687b      	ldr	r3, [r7, #4]
 80059c6:	2b00      	cmp	r3, #0
 80059c8:	d101      	bne.n	80059ce <HAL_ADC_Init+0x1e>
  {
    return HAL_ERROR;
 80059ca:	2301      	movs	r3, #1
 80059cc:	e125      	b.n	8005c1a <HAL_ADC_Init+0x26a>
  /* Refer to header of this file for more details on clock enabling procedure*/
  
  /* Actions performed only if ADC is coming from state reset:                */
  /* - Initialization of ADC MSP                                              */
  /* - ADC voltage regulator enable                                           */
  if (hadc->State == HAL_ADC_STATE_RESET)
 80059ce:	687b      	ldr	r3, [r7, #4]
 80059d0:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 80059d2:	2b00      	cmp	r3, #0
 80059d4:	d10a      	bne.n	80059ec <HAL_ADC_Init+0x3c>
  {
    /* Initialize ADC error code */
    ADC_CLEAR_ERRORCODE(hadc);
 80059d6:	687b      	ldr	r3, [r7, #4]
 80059d8:	2200      	movs	r2, #0
 80059da:	63da      	str	r2, [r3, #60]	; 0x3c
    
    /* Allocate lock resource and initialize it */
    hadc->Lock = HAL_UNLOCKED;
 80059dc:	687b      	ldr	r3, [r7, #4]
 80059de:	2234      	movs	r2, #52	; 0x34
 80059e0:	2100      	movs	r1, #0
 80059e2:	5499      	strb	r1, [r3, r2]
    
    /* Init the low level hardware */
    hadc->MspInitCallback(hadc);
#else
    /* Init the low level hardware */
    HAL_ADC_MspInit(hadc);
 80059e4:	687b      	ldr	r3, [r7, #4]
 80059e6:	0018      	movs	r0, r3
 80059e8:	f7ff fcba 	bl	8005360 <HAL_ADC_MspInit>
  /* Configuration of ADC parameters if previous preliminary actions are      */ 
  /* correctly completed.                                                     */
  /* and if there is no conversion on going on regular group (ADC can be      */ 
  /* enabled anyway, in case of call of this function to update a parameter   */
  /* on the fly).                                                             */
  if (HAL_IS_BIT_CLR(hadc->State, HAL_ADC_STATE_ERROR_INTERNAL) &&
 80059ec:	687b      	ldr	r3, [r7, #4]
 80059ee:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 80059f0:	2210      	movs	r2, #16
 80059f2:	4013      	ands	r3, r2
 80059f4:	d000      	beq.n	80059f8 <HAL_ADC_Init+0x48>
 80059f6:	e103      	b.n	8005c00 <HAL_ADC_Init+0x250>
 80059f8:	230f      	movs	r3, #15
 80059fa:	18fb      	adds	r3, r7, r3
 80059fc:	781b      	ldrb	r3, [r3, #0]
 80059fe:	2b00      	cmp	r3, #0
 8005a00:	d000      	beq.n	8005a04 <HAL_ADC_Init+0x54>
 8005a02:	e0fd      	b.n	8005c00 <HAL_ADC_Init+0x250>
      (tmp_hal_status == HAL_OK)                                &&
      (ADC_IS_CONVERSION_ONGOING_REGULAR(hadc) == RESET)          )
 8005a04:	687b      	ldr	r3, [r7, #4]
 8005a06:	681b      	ldr	r3, [r3, #0]
 8005a08:	689b      	ldr	r3, [r3, #8]
 8005a0a:	2204      	movs	r2, #4
 8005a0c:	4013      	ands	r3, r2
      (tmp_hal_status == HAL_OK)                                &&
 8005a0e:	d000      	beq.n	8005a12 <HAL_ADC_Init+0x62>
 8005a10:	e0f6      	b.n	8005c00 <HAL_ADC_Init+0x250>
  {
    /* Set ADC state */
    ADC_STATE_CLR_SET(hadc->State,
 8005a12:	687b      	ldr	r3, [r7, #4]
 8005a14:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8005a16:	4a83      	ldr	r2, [pc, #524]	; (8005c24 <HAL_ADC_Init+0x274>)
 8005a18:	4013      	ands	r3, r2
 8005a1a:	2202      	movs	r2, #2
 8005a1c:	431a      	orrs	r2, r3
 8005a1e:	687b      	ldr	r3, [r7, #4]
 8005a20:	639a      	str	r2, [r3, #56]	; 0x38
    /* Parameters update conditioned to ADC state:                            */
    /* Parameters that can be updated only when ADC is disabled:              */
    /*  - ADC clock mode                                                      */
    /*  - ADC clock prescaler                                                 */
    /*  - ADC resolution                                                      */
    if (ADC_IS_ENABLE(hadc) == RESET)
 8005a22:	687b      	ldr	r3, [r7, #4]
 8005a24:	681b      	ldr	r3, [r3, #0]
 8005a26:	689b      	ldr	r3, [r3, #8]
 8005a28:	2203      	movs	r2, #3
 8005a2a:	4013      	ands	r3, r2
 8005a2c:	2b01      	cmp	r3, #1
 8005a2e:	d112      	bne.n	8005a56 <HAL_ADC_Init+0xa6>
 8005a30:	687b      	ldr	r3, [r7, #4]
 8005a32:	681b      	ldr	r3, [r3, #0]
 8005a34:	681b      	ldr	r3, [r3, #0]
 8005a36:	2201      	movs	r2, #1
 8005a38:	4013      	ands	r3, r2
 8005a3a:	2b01      	cmp	r3, #1
 8005a3c:	d009      	beq.n	8005a52 <HAL_ADC_Init+0xa2>
 8005a3e:	687b      	ldr	r3, [r7, #4]
 8005a40:	681b      	ldr	r3, [r3, #0]
 8005a42:	68da      	ldr	r2, [r3, #12]
 8005a44:	2380      	movs	r3, #128	; 0x80
 8005a46:	021b      	lsls	r3, r3, #8
 8005a48:	401a      	ands	r2, r3
 8005a4a:	2380      	movs	r3, #128	; 0x80
 8005a4c:	021b      	lsls	r3, r3, #8
 8005a4e:	429a      	cmp	r2, r3
 8005a50:	d101      	bne.n	8005a56 <HAL_ADC_Init+0xa6>
 8005a52:	2301      	movs	r3, #1
 8005a54:	e000      	b.n	8005a58 <HAL_ADC_Init+0xa8>
 8005a56:	2300      	movs	r3, #0
 8005a58:	2b00      	cmp	r3, #0
 8005a5a:	d116      	bne.n	8005a8a <HAL_ADC_Init+0xda>
      /* parameters):                                                         */
      /*   - internal measurement paths: Vbat, temperature sensor, Vref       */
      /*     (set into HAL_ADC_ConfigChannel() )                              */
     
      /* Configuration of ADC resolution                                      */
      MODIFY_REG(hadc->Instance->CFGR1,
 8005a5c:	687b      	ldr	r3, [r7, #4]
 8005a5e:	681b      	ldr	r3, [r3, #0]
 8005a60:	68db      	ldr	r3, [r3, #12]
 8005a62:	2218      	movs	r2, #24
 8005a64:	4393      	bics	r3, r2
 8005a66:	0019      	movs	r1, r3
 8005a68:	687b      	ldr	r3, [r7, #4]
 8005a6a:	689a      	ldr	r2, [r3, #8]
 8005a6c:	687b      	ldr	r3, [r7, #4]
 8005a6e:	681b      	ldr	r3, [r3, #0]
 8005a70:	430a      	orrs	r2, r1
 8005a72:	60da      	str	r2, [r3, #12]
                 ADC_CFGR1_RES        ,
                 hadc->Init.Resolution );
      
      /* Configuration of ADC clock mode: clock source AHB or HSI with        */
      /* selectable prescaler                                                 */
      MODIFY_REG(hadc->Instance->CFGR2    ,
 8005a74:	687b      	ldr	r3, [r7, #4]
 8005a76:	681b      	ldr	r3, [r3, #0]
 8005a78:	691b      	ldr	r3, [r3, #16]
 8005a7a:	009b      	lsls	r3, r3, #2
 8005a7c:	0899      	lsrs	r1, r3, #2
 8005a7e:	687b      	ldr	r3, [r7, #4]
 8005a80:	685a      	ldr	r2, [r3, #4]
 8005a82:	687b      	ldr	r3, [r7, #4]
 8005a84:	681b      	ldr	r3, [r3, #0]
 8005a86:	430a      	orrs	r2, r1
 8005a88:	611a      	str	r2, [r3, #16]
    /*  - external trigger polarity                                           */
    /*  - data alignment                                                      */
    /*  - resolution                                                          */
    /*  - scan direction                                                      */
    /*  - DMA continuous request                                              */
    hadc->Instance->CFGR1 &= ~( ADC_CFGR1_DISCEN  |
 8005a8a:	687b      	ldr	r3, [r7, #4]
 8005a8c:	681b      	ldr	r3, [r3, #0]
 8005a8e:	68da      	ldr	r2, [r3, #12]
 8005a90:	687b      	ldr	r3, [r7, #4]
 8005a92:	681b      	ldr	r3, [r3, #0]
 8005a94:	4964      	ldr	r1, [pc, #400]	; (8005c28 <HAL_ADC_Init+0x278>)
 8005a96:	400a      	ands	r2, r1
 8005a98:	60da      	str	r2, [r3, #12]
                                ADC_CFGR1_EXTEN   |
                                ADC_CFGR1_ALIGN   |
                                ADC_CFGR1_SCANDIR |
                                ADC_CFGR1_DMACFG   );

    tmpCFGR1 |= (ADC_CFGR1_AUTOWAIT((uint32_t)hadc->Init.LowPowerAutoWait)        |
 8005a9a:	687b      	ldr	r3, [r7, #4]
 8005a9c:	7e1b      	ldrb	r3, [r3, #24]
 8005a9e:	039a      	lsls	r2, r3, #14
                 ADC_CFGR1_AUTOOFF((uint32_t)hadc->Init.LowPowerAutoPowerOff)     |
 8005aa0:	687b      	ldr	r3, [r7, #4]
 8005aa2:	7e5b      	ldrb	r3, [r3, #25]
 8005aa4:	03db      	lsls	r3, r3, #15
    tmpCFGR1 |= (ADC_CFGR1_AUTOWAIT((uint32_t)hadc->Init.LowPowerAutoWait)        |
 8005aa6:	431a      	orrs	r2, r3
                 ADC_CFGR1_CONTINUOUS((uint32_t)hadc->Init.ContinuousConvMode)    |
 8005aa8:	687b      	ldr	r3, [r7, #4]
 8005aaa:	7e9b      	ldrb	r3, [r3, #26]
 8005aac:	035b      	lsls	r3, r3, #13
                 ADC_CFGR1_AUTOOFF((uint32_t)hadc->Init.LowPowerAutoPowerOff)     |
 8005aae:	431a      	orrs	r2, r3
                 ADC_CFGR1_OVERRUN(hadc->Init.Overrun)                            |
 8005ab0:	687b      	ldr	r3, [r7, #4]
 8005ab2:	6a9b      	ldr	r3, [r3, #40]	; 0x28
 8005ab4:	2b01      	cmp	r3, #1
 8005ab6:	d002      	beq.n	8005abe <HAL_ADC_Init+0x10e>
 8005ab8:	2380      	movs	r3, #128	; 0x80
 8005aba:	015b      	lsls	r3, r3, #5
 8005abc:	e000      	b.n	8005ac0 <HAL_ADC_Init+0x110>
 8005abe:	2300      	movs	r3, #0
                 ADC_CFGR1_CONTINUOUS((uint32_t)hadc->Init.ContinuousConvMode)    |
 8005ac0:	431a      	orrs	r2, r3
                 hadc->Init.DataAlign                                             |
 8005ac2:	687b      	ldr	r3, [r7, #4]
 8005ac4:	68db      	ldr	r3, [r3, #12]
                 ADC_CFGR1_OVERRUN(hadc->Init.Overrun)                            |
 8005ac6:	431a      	orrs	r2, r3
                 ADC_SCANDIR(hadc->Init.ScanConvMode)                             |
 8005ac8:	687b      	ldr	r3, [r7, #4]
 8005aca:	691b      	ldr	r3, [r3, #16]
 8005acc:	2b02      	cmp	r3, #2
 8005ace:	d101      	bne.n	8005ad4 <HAL_ADC_Init+0x124>
 8005ad0:	2304      	movs	r3, #4
 8005ad2:	e000      	b.n	8005ad6 <HAL_ADC_Init+0x126>
 8005ad4:	2300      	movs	r3, #0
                 hadc->Init.DataAlign                                             |
 8005ad6:	431a      	orrs	r2, r3
                 ADC_CFGR1_DMACONTREQ((uint32_t)hadc->Init.DMAContinuousRequests)  );
 8005ad8:	687b      	ldr	r3, [r7, #4]
 8005ada:	2124      	movs	r1, #36	; 0x24
 8005adc:	5c5b      	ldrb	r3, [r3, r1]
 8005ade:	005b      	lsls	r3, r3, #1
                 ADC_SCANDIR(hadc->Init.ScanConvMode)                             |
 8005ae0:	4313      	orrs	r3, r2
    tmpCFGR1 |= (ADC_CFGR1_AUTOWAIT((uint32_t)hadc->Init.LowPowerAutoWait)        |
 8005ae2:	68ba      	ldr	r2, [r7, #8]
 8005ae4:	4313      	orrs	r3, r2
 8005ae6:	60bb      	str	r3, [r7, #8]
    
    /* Enable discontinuous mode only if continuous mode is disabled */
    if (hadc->Init.DiscontinuousConvMode == ENABLE)
 8005ae8:	687b      	ldr	r3, [r7, #4]
 8005aea:	7edb      	ldrb	r3, [r3, #27]
 8005aec:	2b01      	cmp	r3, #1
 8005aee:	d115      	bne.n	8005b1c <HAL_ADC_Init+0x16c>
    {
      if (hadc->Init.ContinuousConvMode == DISABLE)
 8005af0:	687b      	ldr	r3, [r7, #4]
 8005af2:	7e9b      	ldrb	r3, [r3, #26]
 8005af4:	2b00      	cmp	r3, #0
 8005af6:	d105      	bne.n	8005b04 <HAL_ADC_Init+0x154>
      {
        /* Enable the selected ADC group regular discontinuous mode */
        tmpCFGR1 |= ADC_CFGR1_DISCEN;
 8005af8:	68bb      	ldr	r3, [r7, #8]
 8005afa:	2280      	movs	r2, #128	; 0x80
 8005afc:	0252      	lsls	r2, r2, #9
 8005afe:	4313      	orrs	r3, r2
 8005b00:	60bb      	str	r3, [r7, #8]
 8005b02:	e00b      	b.n	8005b1c <HAL_ADC_Init+0x16c>
        /* ADC regular group discontinuous was intended to be enabled,        */
        /* but ADC regular group modes continuous and sequencer discontinuous */
        /* cannot be enabled simultaneously.                                  */
        
        /* Update ADC state machine to error */
        SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_CONFIG);
 8005b04:	687b      	ldr	r3, [r7, #4]
 8005b06:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8005b08:	2220      	movs	r2, #32
 8005b0a:	431a      	orrs	r2, r3
 8005b0c:	687b      	ldr	r3, [r7, #4]
 8005b0e:	639a      	str	r2, [r3, #56]	; 0x38
        
        /* Set ADC error code to ADC IP internal error */
        SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_INTERNAL);
 8005b10:	687b      	ldr	r3, [r7, #4]
 8005b12:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8005b14:	2201      	movs	r2, #1
 8005b16:	431a      	orrs	r2, r3
 8005b18:	687b      	ldr	r3, [r7, #4]
 8005b1a:	63da      	str	r2, [r3, #60]	; 0x3c
    /* Enable external trigger if trigger selection is different of software  */
    /* start.                                                                 */
    /* Note: This configuration keeps the hardware feature of parameter       */
    /*       ExternalTrigConvEdge "trigger edge none" equivalent to           */
    /*       software start.                                                  */
    if (hadc->Init.ExternalTrigConv != ADC_SOFTWARE_START)
 8005b1c:	687b      	ldr	r3, [r7, #4]
 8005b1e:	69da      	ldr	r2, [r3, #28]
 8005b20:	23c2      	movs	r3, #194	; 0xc2
 8005b22:	33ff      	adds	r3, #255	; 0xff
 8005b24:	429a      	cmp	r2, r3
 8005b26:	d007      	beq.n	8005b38 <HAL_ADC_Init+0x188>
    {
      tmpCFGR1 |= ( hadc->Init.ExternalTrigConv    |
 8005b28:	687b      	ldr	r3, [r7, #4]
 8005b2a:	69da      	ldr	r2, [r3, #28]
                    hadc->Init.ExternalTrigConvEdge );
 8005b2c:	687b      	ldr	r3, [r7, #4]
 8005b2e:	6a1b      	ldr	r3, [r3, #32]
      tmpCFGR1 |= ( hadc->Init.ExternalTrigConv    |
 8005b30:	4313      	orrs	r3, r2
 8005b32:	68ba      	ldr	r2, [r7, #8]
 8005b34:	4313      	orrs	r3, r2
 8005b36:	60bb      	str	r3, [r7, #8]
    }
    
    /* Update ADC configuration register with previous settings */
    hadc->Instance->CFGR1 |= tmpCFGR1;
 8005b38:	687b      	ldr	r3, [r7, #4]
 8005b3a:	681b      	ldr	r3, [r3, #0]
 8005b3c:	68d9      	ldr	r1, [r3, #12]
 8005b3e:	687b      	ldr	r3, [r7, #4]
 8005b40:	681b      	ldr	r3, [r3, #0]
 8005b42:	68ba      	ldr	r2, [r7, #8]
 8005b44:	430a      	orrs	r2, r1
 8005b46:	60da      	str	r2, [r3, #12]
    /* Management of parameters "SamplingTimeCommon" and "SamplingTime"       */
    /* (obsolete): sampling time set in this function if parameter            */
    /*  "SamplingTimeCommon" has been set to a valid sampling time.           */
    /* Otherwise, sampling time is set into ADC channel initialization        */
    /* structure with parameter "SamplingTime" (obsolete).                    */
    if (IS_ADC_SAMPLE_TIME(hadc->Init.SamplingTimeCommon))
 8005b48:	687b      	ldr	r3, [r7, #4]
 8005b4a:	6ada      	ldr	r2, [r3, #44]	; 0x2c
 8005b4c:	2380      	movs	r3, #128	; 0x80
 8005b4e:	055b      	lsls	r3, r3, #21
 8005b50:	429a      	cmp	r2, r3
 8005b52:	d01b      	beq.n	8005b8c <HAL_ADC_Init+0x1dc>
 8005b54:	687b      	ldr	r3, [r7, #4]
 8005b56:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005b58:	2b01      	cmp	r3, #1
 8005b5a:	d017      	beq.n	8005b8c <HAL_ADC_Init+0x1dc>
 8005b5c:	687b      	ldr	r3, [r7, #4]
 8005b5e:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005b60:	2b02      	cmp	r3, #2
 8005b62:	d013      	beq.n	8005b8c <HAL_ADC_Init+0x1dc>
 8005b64:	687b      	ldr	r3, [r7, #4]
 8005b66:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005b68:	2b03      	cmp	r3, #3
 8005b6a:	d00f      	beq.n	8005b8c <HAL_ADC_Init+0x1dc>
 8005b6c:	687b      	ldr	r3, [r7, #4]
 8005b6e:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005b70:	2b04      	cmp	r3, #4
 8005b72:	d00b      	beq.n	8005b8c <HAL_ADC_Init+0x1dc>
 8005b74:	687b      	ldr	r3, [r7, #4]
 8005b76:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005b78:	2b05      	cmp	r3, #5
 8005b7a:	d007      	beq.n	8005b8c <HAL_ADC_Init+0x1dc>
 8005b7c:	687b      	ldr	r3, [r7, #4]
 8005b7e:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005b80:	2b06      	cmp	r3, #6
 8005b82:	d003      	beq.n	8005b8c <HAL_ADC_Init+0x1dc>
 8005b84:	687b      	ldr	r3, [r7, #4]
 8005b86:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005b88:	2b07      	cmp	r3, #7
 8005b8a:	d112      	bne.n	8005bb2 <HAL_ADC_Init+0x202>
    {
      /* Channel sampling time configuration */
      /* Clear the old sample time */
      hadc->Instance->SMPR &= ~(ADC_SMPR_SMP);
 8005b8c:	687b      	ldr	r3, [r7, #4]
 8005b8e:	681b      	ldr	r3, [r3, #0]
 8005b90:	695a      	ldr	r2, [r3, #20]
 8005b92:	687b      	ldr	r3, [r7, #4]
 8005b94:	681b      	ldr	r3, [r3, #0]
 8005b96:	2107      	movs	r1, #7
 8005b98:	438a      	bics	r2, r1
 8005b9a:	615a      	str	r2, [r3, #20]
      
      /* Set the new sample time */
      hadc->Instance->SMPR |= ADC_SMPR_SET(hadc->Init.SamplingTimeCommon);
 8005b9c:	687b      	ldr	r3, [r7, #4]
 8005b9e:	681b      	ldr	r3, [r3, #0]
 8005ba0:	6959      	ldr	r1, [r3, #20]
 8005ba2:	687b      	ldr	r3, [r7, #4]
 8005ba4:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005ba6:	2207      	movs	r2, #7
 8005ba8:	401a      	ands	r2, r3
 8005baa:	687b      	ldr	r3, [r7, #4]
 8005bac:	681b      	ldr	r3, [r3, #0]
 8005bae:	430a      	orrs	r2, r1
 8005bb0:	615a      	str	r2, [r3, #20]
    /* Check back that ADC registers have effectively been configured to      */
    /* ensure of no potential problem of ADC core IP clocking.                */
    /* Check through register CFGR1 (excluding analog watchdog configuration: */
    /* set into separate dedicated function, and bits of ADC resolution set   */
    /* out of temporary variable 'tmpCFGR1').                                 */
    if ((hadc->Instance->CFGR1 & ~(ADC_CFGR1_AWDCH | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL | ADC_CFGR1_RES))
 8005bb2:	687b      	ldr	r3, [r7, #4]
 8005bb4:	681b      	ldr	r3, [r3, #0]
 8005bb6:	68db      	ldr	r3, [r3, #12]
 8005bb8:	4a1c      	ldr	r2, [pc, #112]	; (8005c2c <HAL_ADC_Init+0x27c>)
 8005bba:	4013      	ands	r3, r2
 8005bbc:	68ba      	ldr	r2, [r7, #8]
 8005bbe:	429a      	cmp	r2, r3
 8005bc0:	d10b      	bne.n	8005bda <HAL_ADC_Init+0x22a>
         == tmpCFGR1)
    {
      /* Set ADC error code to none */
      ADC_CLEAR_ERRORCODE(hadc);
 8005bc2:	687b      	ldr	r3, [r7, #4]
 8005bc4:	2200      	movs	r2, #0
 8005bc6:	63da      	str	r2, [r3, #60]	; 0x3c
      
      /* Set the ADC state */
      ADC_STATE_CLR_SET(hadc->State,
 8005bc8:	687b      	ldr	r3, [r7, #4]
 8005bca:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8005bcc:	2203      	movs	r2, #3
 8005bce:	4393      	bics	r3, r2
 8005bd0:	2201      	movs	r2, #1
 8005bd2:	431a      	orrs	r2, r3
 8005bd4:	687b      	ldr	r3, [r7, #4]
 8005bd6:	639a      	str	r2, [r3, #56]	; 0x38
    if ((hadc->Instance->CFGR1 & ~(ADC_CFGR1_AWDCH | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL | ADC_CFGR1_RES))
 8005bd8:	e01c      	b.n	8005c14 <HAL_ADC_Init+0x264>
                        HAL_ADC_STATE_READY);
    }
    else
    {
      /* Update ADC state machine to error */
      ADC_STATE_CLR_SET(hadc->State,
 8005bda:	687b      	ldr	r3, [r7, #4]
 8005bdc:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8005bde:	2212      	movs	r2, #18
 8005be0:	4393      	bics	r3, r2
 8005be2:	2210      	movs	r2, #16
 8005be4:	431a      	orrs	r2, r3
 8005be6:	687b      	ldr	r3, [r7, #4]
 8005be8:	639a      	str	r2, [r3, #56]	; 0x38
                        HAL_ADC_STATE_BUSY_INTERNAL,
                        HAL_ADC_STATE_ERROR_INTERNAL);
      
      /* Set ADC error code to ADC IP internal error */
      SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_INTERNAL);
 8005bea:	687b      	ldr	r3, [r7, #4]
 8005bec:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8005bee:	2201      	movs	r2, #1
 8005bf0:	431a      	orrs	r2, r3
 8005bf2:	687b      	ldr	r3, [r7, #4]
 8005bf4:	63da      	str	r2, [r3, #60]	; 0x3c
      
      tmp_hal_status = HAL_ERROR;
 8005bf6:	230f      	movs	r3, #15
 8005bf8:	18fb      	adds	r3, r7, r3
 8005bfa:	2201      	movs	r2, #1
 8005bfc:	701a      	strb	r2, [r3, #0]
    if ((hadc->Instance->CFGR1 & ~(ADC_CFGR1_AWDCH | ADC_CFGR1_AWDEN | ADC_CFGR1_AWDSGL | ADC_CFGR1_RES))
 8005bfe:	e009      	b.n	8005c14 <HAL_ADC_Init+0x264>
  
  }
  else
  {
    /* Update ADC state machine to error */
    SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_INTERNAL);
 8005c00:	687b      	ldr	r3, [r7, #4]
 8005c02:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8005c04:	2210      	movs	r2, #16
 8005c06:	431a      	orrs	r2, r3
 8005c08:	687b      	ldr	r3, [r7, #4]
 8005c0a:	639a      	str	r2, [r3, #56]	; 0x38
        
    tmp_hal_status = HAL_ERROR;
 8005c0c:	230f      	movs	r3, #15
 8005c0e:	18fb      	adds	r3, r7, r3
 8005c10:	2201      	movs	r2, #1
 8005c12:	701a      	strb	r2, [r3, #0]
  }
  
  /* Return function status */
  return tmp_hal_status;
 8005c14:	230f      	movs	r3, #15
 8005c16:	18fb      	adds	r3, r7, r3
 8005c18:	781b      	ldrb	r3, [r3, #0]
}
 8005c1a:	0018      	movs	r0, r3
 8005c1c:	46bd      	mov	sp, r7
 8005c1e:	b004      	add	sp, #16
 8005c20:	bd80      	pop	{r7, pc}
 8005c22:	46c0      	nop			; (mov r8, r8)
 8005c24:	fffffefd 	.word	0xfffffefd
 8005c28:	fffe0219 	.word	0xfffe0219
 8005c2c:	833fffe7 	.word	0x833fffe7

08005c30 <HAL_ADC_Start_DMA>:
  * @param  pData The destination Buffer address.
  * @param  Length The length of data to be transferred from ADC peripheral to memory.
  * @retval None
  */
HAL_StatusTypeDef HAL_ADC_Start_DMA(ADC_HandleTypeDef* hadc, uint32_t* pData, uint32_t Length)
{
 8005c30:	b590      	push	{r4, r7, lr}
 8005c32:	b087      	sub	sp, #28
 8005c34:	af00      	add	r7, sp, #0
 8005c36:	60f8      	str	r0, [r7, #12]
 8005c38:	60b9      	str	r1, [r7, #8]
 8005c3a:	607a      	str	r2, [r7, #4]
  HAL_StatusTypeDef tmp_hal_status = HAL_OK;
 8005c3c:	2317      	movs	r3, #23
 8005c3e:	18fb      	adds	r3, r7, r3
 8005c40:	2200      	movs	r2, #0
 8005c42:	701a      	strb	r2, [r3, #0]
  
  /* Check the parameters */
  assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance));

  /* Perform ADC enable and conversion start if no conversion is on going */
  if (ADC_IS_CONVERSION_ONGOING_REGULAR(hadc) == RESET)
 8005c44:	68fb      	ldr	r3, [r7, #12]
 8005c46:	681b      	ldr	r3, [r3, #0]
 8005c48:	689b      	ldr	r3, [r3, #8]
 8005c4a:	2204      	movs	r2, #4
 8005c4c:	4013      	ands	r3, r2
 8005c4e:	d15e      	bne.n	8005d0e <HAL_ADC_Start_DMA+0xde>
  {
    /* Process locked */
    __HAL_LOCK(hadc);
 8005c50:	68fb      	ldr	r3, [r7, #12]
 8005c52:	2234      	movs	r2, #52	; 0x34
 8005c54:	5c9b      	ldrb	r3, [r3, r2]
 8005c56:	2b01      	cmp	r3, #1
 8005c58:	d101      	bne.n	8005c5e <HAL_ADC_Start_DMA+0x2e>
 8005c5a:	2302      	movs	r3, #2
 8005c5c:	e05e      	b.n	8005d1c <HAL_ADC_Start_DMA+0xec>
 8005c5e:	68fb      	ldr	r3, [r7, #12]
 8005c60:	2234      	movs	r2, #52	; 0x34
 8005c62:	2101      	movs	r1, #1
 8005c64:	5499      	strb	r1, [r3, r2]

    /* Enable the ADC peripheral */
    /* If low power mode AutoPowerOff is enabled, power-on/off phases are       */
    /* performed automatically by hardware.                                     */
    if (hadc->Init.LowPowerAutoPowerOff != ENABLE)
 8005c66:	68fb      	ldr	r3, [r7, #12]
 8005c68:	7e5b      	ldrb	r3, [r3, #25]
 8005c6a:	2b01      	cmp	r3, #1
 8005c6c:	d007      	beq.n	8005c7e <HAL_ADC_Start_DMA+0x4e>
    {
      tmp_hal_status = ADC_Enable(hadc);
 8005c6e:	2317      	movs	r3, #23
 8005c70:	18fc      	adds	r4, r7, r3
 8005c72:	68fb      	ldr	r3, [r7, #12]
 8005c74:	0018      	movs	r0, r3
 8005c76:	f000 f973 	bl	8005f60 <ADC_Enable>
 8005c7a:	0003      	movs	r3, r0
 8005c7c:	7023      	strb	r3, [r4, #0]
    }
    
    /* Start conversion if ADC is effectively enabled */
    if (tmp_hal_status == HAL_OK)
 8005c7e:	2317      	movs	r3, #23
 8005c80:	18fb      	adds	r3, r7, r3
 8005c82:	781b      	ldrb	r3, [r3, #0]
 8005c84:	2b00      	cmp	r3, #0
 8005c86:	d146      	bne.n	8005d16 <HAL_ADC_Start_DMA+0xe6>
    {
      /* Set ADC state                                                        */
      /* - Clear state bitfield related to regular group conversion results   */
      /* - Set state bitfield related to regular operation                    */
      ADC_STATE_CLR_SET(hadc->State,
 8005c88:	68fb      	ldr	r3, [r7, #12]
 8005c8a:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8005c8c:	4a25      	ldr	r2, [pc, #148]	; (8005d24 <HAL_ADC_Start_DMA+0xf4>)
 8005c8e:	4013      	ands	r3, r2
 8005c90:	2280      	movs	r2, #128	; 0x80
 8005c92:	0052      	lsls	r2, r2, #1
 8005c94:	431a      	orrs	r2, r3
 8005c96:	68fb      	ldr	r3, [r7, #12]
 8005c98:	639a      	str	r2, [r3, #56]	; 0x38
                        HAL_ADC_STATE_READY | HAL_ADC_STATE_REG_EOC | HAL_ADC_STATE_REG_OVR | HAL_ADC_STATE_REG_EOSMP,
                        HAL_ADC_STATE_REG_BUSY);
      
      /* Reset ADC all error code fields */
      ADC_CLEAR_ERRORCODE(hadc);
 8005c9a:	68fb      	ldr	r3, [r7, #12]
 8005c9c:	2200      	movs	r2, #0
 8005c9e:	63da      	str	r2, [r3, #60]	; 0x3c
      
      /* Process unlocked */
      /* Unlock before starting ADC conversions: in case of potential         */
      /* interruption, to let the process to ADC IRQ Handler.                 */
      __HAL_UNLOCK(hadc);
 8005ca0:	68fb      	ldr	r3, [r7, #12]
 8005ca2:	2234      	movs	r2, #52	; 0x34
 8005ca4:	2100      	movs	r1, #0
 8005ca6:	5499      	strb	r1, [r3, r2]

      /* Set the DMA transfer complete callback */
      hadc->DMA_Handle->XferCpltCallback = ADC_DMAConvCplt;
 8005ca8:	68fb      	ldr	r3, [r7, #12]
 8005caa:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8005cac:	4a1e      	ldr	r2, [pc, #120]	; (8005d28 <HAL_ADC_Start_DMA+0xf8>)
 8005cae:	629a      	str	r2, [r3, #40]	; 0x28

      /* Set the DMA half transfer complete callback */
      hadc->DMA_Handle->XferHalfCpltCallback = ADC_DMAHalfConvCplt;
 8005cb0:	68fb      	ldr	r3, [r7, #12]
 8005cb2:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8005cb4:	4a1d      	ldr	r2, [pc, #116]	; (8005d2c <HAL_ADC_Start_DMA+0xfc>)
 8005cb6:	62da      	str	r2, [r3, #44]	; 0x2c
      
      /* Set the DMA error callback */
      hadc->DMA_Handle->XferErrorCallback = ADC_DMAError;
 8005cb8:	68fb      	ldr	r3, [r7, #12]
 8005cba:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8005cbc:	4a1c      	ldr	r2, [pc, #112]	; (8005d30 <HAL_ADC_Start_DMA+0x100>)
 8005cbe:	631a      	str	r2, [r3, #48]	; 0x30
      /* start (in case of SW start):                                         */
      
      /* Clear regular group conversion flag and overrun flag */
      /* (To ensure of no unknown state from potential previous ADC           */
      /* operations)                                                          */
      __HAL_ADC_CLEAR_FLAG(hadc, (ADC_FLAG_EOC | ADC_FLAG_EOS | ADC_FLAG_OVR));
 8005cc0:	68fb      	ldr	r3, [r7, #12]
 8005cc2:	681b      	ldr	r3, [r3, #0]
 8005cc4:	221c      	movs	r2, #28
 8005cc6:	601a      	str	r2, [r3, #0]
      
      /* Enable ADC overrun interrupt */
      __HAL_ADC_ENABLE_IT(hadc, ADC_IT_OVR);
 8005cc8:	68fb      	ldr	r3, [r7, #12]
 8005cca:	681b      	ldr	r3, [r3, #0]
 8005ccc:	685a      	ldr	r2, [r3, #4]
 8005cce:	68fb      	ldr	r3, [r7, #12]
 8005cd0:	681b      	ldr	r3, [r3, #0]
 8005cd2:	2110      	movs	r1, #16
 8005cd4:	430a      	orrs	r2, r1
 8005cd6:	605a      	str	r2, [r3, #4]
      
      /* Enable ADC DMA mode */
      hadc->Instance->CFGR1 |= ADC_CFGR1_DMAEN;
 8005cd8:	68fb      	ldr	r3, [r7, #12]
 8005cda:	681b      	ldr	r3, [r3, #0]
 8005cdc:	68da      	ldr	r2, [r3, #12]
 8005cde:	68fb      	ldr	r3, [r7, #12]
 8005ce0:	681b      	ldr	r3, [r3, #0]
 8005ce2:	2101      	movs	r1, #1
 8005ce4:	430a      	orrs	r2, r1
 8005ce6:	60da      	str	r2, [r3, #12]
      
      /* Start the DMA channel */
      HAL_DMA_Start_IT(hadc->DMA_Handle, (uint32_t)&hadc->Instance->DR, (uint32_t)pData, Length);
 8005ce8:	68fb      	ldr	r3, [r7, #12]
 8005cea:	6b18      	ldr	r0, [r3, #48]	; 0x30
 8005cec:	68fb      	ldr	r3, [r7, #12]
 8005cee:	681b      	ldr	r3, [r3, #0]
 8005cf0:	3340      	adds	r3, #64	; 0x40
 8005cf2:	0019      	movs	r1, r3
 8005cf4:	68ba      	ldr	r2, [r7, #8]
 8005cf6:	687b      	ldr	r3, [r7, #4]
 8005cf8:	f000 fb60 	bl	80063bc <HAL_DMA_Start_IT>
           
      /* Enable conversion of regular group.                                  */
      /* If software start has been selected, conversion starts immediately.  */
      /* If external trigger has been selected, conversion will start at next */
      /* trigger event.                                                       */
      hadc->Instance->CR |= ADC_CR_ADSTART;
 8005cfc:	68fb      	ldr	r3, [r7, #12]
 8005cfe:	681b      	ldr	r3, [r3, #0]
 8005d00:	689a      	ldr	r2, [r3, #8]
 8005d02:	68fb      	ldr	r3, [r7, #12]
 8005d04:	681b      	ldr	r3, [r3, #0]
 8005d06:	2104      	movs	r1, #4
 8005d08:	430a      	orrs	r2, r1
 8005d0a:	609a      	str	r2, [r3, #8]
 8005d0c:	e003      	b.n	8005d16 <HAL_ADC_Start_DMA+0xe6>
    }
  }
  else
  {
    tmp_hal_status = HAL_BUSY;
 8005d0e:	2317      	movs	r3, #23
 8005d10:	18fb      	adds	r3, r7, r3
 8005d12:	2202      	movs	r2, #2
 8005d14:	701a      	strb	r2, [r3, #0]
  }
    
  /* Return function status */
  return tmp_hal_status;
 8005d16:	2317      	movs	r3, #23
 8005d18:	18fb      	adds	r3, r7, r3
 8005d1a:	781b      	ldrb	r3, [r3, #0]
}
 8005d1c:	0018      	movs	r0, r3
 8005d1e:	46bd      	mov	sp, r7
 8005d20:	b007      	add	sp, #28
 8005d22:	bd90      	pop	{r4, r7, pc}
 8005d24:	fffff0fe 	.word	0xfffff0fe
 8005d28:	08006069 	.word	0x08006069
 8005d2c:	0800611d 	.word	0x0800611d
 8005d30:	0800613b 	.word	0x0800613b

08005d34 <HAL_ADC_ErrorCallback>:
  *        (ADC conversion with interruption or transfer by DMA)
  * @param  hadc ADC handle
  * @retval None
  */
__weak void HAL_ADC_ErrorCallback(ADC_HandleTypeDef *hadc)
{
 8005d34:	b580      	push	{r7, lr}
 8005d36:	b082      	sub	sp, #8
 8005d38:	af00      	add	r7, sp, #0
 8005d3a:	6078      	str	r0, [r7, #4]
  UNUSED(hadc);

  /* NOTE : This function should not be modified. When the callback is needed,
            function HAL_ADC_ErrorCallback must be implemented in the user file.
  */
}
 8005d3c:	46c0      	nop			; (mov r8, r8)
 8005d3e:	46bd      	mov	sp, r7
 8005d40:	b002      	add	sp, #8
 8005d42:	bd80      	pop	{r7, pc}

08005d44 <HAL_ADC_ConfigChannel>:
  * @param  hadc ADC handle
  * @param  sConfig Structure of ADC channel for regular group.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_ADC_ConfigChannel(ADC_HandleTypeDef* hadc, ADC_ChannelConfTypeDef* sConfig)
{
 8005d44:	b580      	push	{r7, lr}
 8005d46:	b084      	sub	sp, #16
 8005d48:	af00      	add	r7, sp, #0
 8005d4a:	6078      	str	r0, [r7, #4]
 8005d4c:	6039      	str	r1, [r7, #0]
  HAL_StatusTypeDef tmp_hal_status = HAL_OK;
 8005d4e:	230f      	movs	r3, #15
 8005d50:	18fb      	adds	r3, r7, r3
 8005d52:	2200      	movs	r2, #0
 8005d54:	701a      	strb	r2, [r3, #0]
  __IO uint32_t wait_loop_index = 0U;
 8005d56:	2300      	movs	r3, #0
 8005d58:	60bb      	str	r3, [r7, #8]
  /* Check the parameters */
  assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance));
  assert_param(IS_ADC_CHANNEL(sConfig->Channel));
  assert_param(IS_ADC_RANK(sConfig->Rank));
  
  if (! IS_ADC_SAMPLE_TIME(hadc->Init.SamplingTimeCommon))
 8005d5a:	687b      	ldr	r3, [r7, #4]
 8005d5c:	6ada      	ldr	r2, [r3, #44]	; 0x2c
 8005d5e:	2380      	movs	r3, #128	; 0x80
 8005d60:	055b      	lsls	r3, r3, #21
 8005d62:	429a      	cmp	r2, r3
 8005d64:	d011      	beq.n	8005d8a <HAL_ADC_ConfigChannel+0x46>
 8005d66:	687b      	ldr	r3, [r7, #4]
 8005d68:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005d6a:	2b01      	cmp	r3, #1
 8005d6c:	d00d      	beq.n	8005d8a <HAL_ADC_ConfigChannel+0x46>
 8005d6e:	687b      	ldr	r3, [r7, #4]
 8005d70:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005d72:	2b02      	cmp	r3, #2
 8005d74:	d009      	beq.n	8005d8a <HAL_ADC_ConfigChannel+0x46>
 8005d76:	687b      	ldr	r3, [r7, #4]
 8005d78:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005d7a:	2b03      	cmp	r3, #3
 8005d7c:	d005      	beq.n	8005d8a <HAL_ADC_ConfigChannel+0x46>
 8005d7e:	687b      	ldr	r3, [r7, #4]
 8005d80:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005d82:	2b04      	cmp	r3, #4
 8005d84:	d001      	beq.n	8005d8a <HAL_ADC_ConfigChannel+0x46>
 8005d86:	687b      	ldr	r3, [r7, #4]
 8005d88:	6adb      	ldr	r3, [r3, #44]	; 0x2c
  {
    assert_param(IS_ADC_SAMPLE_TIME(sConfig->SamplingTime));
  }
  
  /* Process locked */
  __HAL_LOCK(hadc);
 8005d8a:	687b      	ldr	r3, [r7, #4]
 8005d8c:	2234      	movs	r2, #52	; 0x34
 8005d8e:	5c9b      	ldrb	r3, [r3, r2]
 8005d90:	2b01      	cmp	r3, #1
 8005d92:	d101      	bne.n	8005d98 <HAL_ADC_ConfigChannel+0x54>
 8005d94:	2302      	movs	r3, #2
 8005d96:	e0d0      	b.n	8005f3a <HAL_ADC_ConfigChannel+0x1f6>
 8005d98:	687b      	ldr	r3, [r7, #4]
 8005d9a:	2234      	movs	r2, #52	; 0x34
 8005d9c:	2101      	movs	r1, #1
 8005d9e:	5499      	strb	r1, [r3, r2]
  /* Parameters that can be updated when ADC is disabled or enabled without   */
  /* conversion on going on regular group:                                    */
  /*  - Channel number                                                        */
  /*  - Channel sampling time                                                 */
  /*  - Management of internal measurement channels: VrefInt/TempSensor/Vbat  */
  if (ADC_IS_CONVERSION_ONGOING_REGULAR(hadc) == RESET)
 8005da0:	687b      	ldr	r3, [r7, #4]
 8005da2:	681b      	ldr	r3, [r3, #0]
 8005da4:	689b      	ldr	r3, [r3, #8]
 8005da6:	2204      	movs	r2, #4
 8005da8:	4013      	ands	r3, r2
 8005daa:	d000      	beq.n	8005dae <HAL_ADC_ConfigChannel+0x6a>
 8005dac:	e0b4      	b.n	8005f18 <HAL_ADC_ConfigChannel+0x1d4>
  {
    /* Configure channel: depending on rank setting, add it or remove it from */
    /* ADC conversion sequencer.                                              */
    if (sConfig->Rank != ADC_RANK_NONE)
 8005dae:	683b      	ldr	r3, [r7, #0]
 8005db0:	685b      	ldr	r3, [r3, #4]
 8005db2:	4a64      	ldr	r2, [pc, #400]	; (8005f44 <HAL_ADC_ConfigChannel+0x200>)
 8005db4:	4293      	cmp	r3, r2
 8005db6:	d100      	bne.n	8005dba <HAL_ADC_ConfigChannel+0x76>
 8005db8:	e082      	b.n	8005ec0 <HAL_ADC_ConfigChannel+0x17c>
    {
      /* Regular sequence configuration */
      /* Set the channel selection register from the selected channel */
      hadc->Instance->CHSELR |= ADC_CHSELR_CHANNEL(sConfig->Channel);
 8005dba:	687b      	ldr	r3, [r7, #4]
 8005dbc:	681b      	ldr	r3, [r3, #0]
 8005dbe:	6a99      	ldr	r1, [r3, #40]	; 0x28
 8005dc0:	683b      	ldr	r3, [r7, #0]
 8005dc2:	681b      	ldr	r3, [r3, #0]
 8005dc4:	2201      	movs	r2, #1
 8005dc6:	409a      	lsls	r2, r3
 8005dc8:	687b      	ldr	r3, [r7, #4]
 8005dca:	681b      	ldr	r3, [r3, #0]
 8005dcc:	430a      	orrs	r2, r1
 8005dce:	629a      	str	r2, [r3, #40]	; 0x28
      /* Channel sampling time configuration */
      /* Management of parameters "SamplingTimeCommon" and "SamplingTime"     */
      /* (obsolete): sampling time set in this function with                  */
      /* parameter "SamplingTime" (obsolete) only if not already set into     */
      /* ADC initialization structure with parameter "SamplingTimeCommon".    */
      if (! IS_ADC_SAMPLE_TIME(hadc->Init.SamplingTimeCommon))
 8005dd0:	687b      	ldr	r3, [r7, #4]
 8005dd2:	6ada      	ldr	r2, [r3, #44]	; 0x2c
 8005dd4:	2380      	movs	r3, #128	; 0x80
 8005dd6:	055b      	lsls	r3, r3, #21
 8005dd8:	429a      	cmp	r2, r3
 8005dda:	d037      	beq.n	8005e4c <HAL_ADC_ConfigChannel+0x108>
 8005ddc:	687b      	ldr	r3, [r7, #4]
 8005dde:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005de0:	2b01      	cmp	r3, #1
 8005de2:	d033      	beq.n	8005e4c <HAL_ADC_ConfigChannel+0x108>
 8005de4:	687b      	ldr	r3, [r7, #4]
 8005de6:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005de8:	2b02      	cmp	r3, #2
 8005dea:	d02f      	beq.n	8005e4c <HAL_ADC_ConfigChannel+0x108>
 8005dec:	687b      	ldr	r3, [r7, #4]
 8005dee:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005df0:	2b03      	cmp	r3, #3
 8005df2:	d02b      	beq.n	8005e4c <HAL_ADC_ConfigChannel+0x108>
 8005df4:	687b      	ldr	r3, [r7, #4]
 8005df6:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005df8:	2b04      	cmp	r3, #4
 8005dfa:	d027      	beq.n	8005e4c <HAL_ADC_ConfigChannel+0x108>
 8005dfc:	687b      	ldr	r3, [r7, #4]
 8005dfe:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005e00:	2b05      	cmp	r3, #5
 8005e02:	d023      	beq.n	8005e4c <HAL_ADC_ConfigChannel+0x108>
 8005e04:	687b      	ldr	r3, [r7, #4]
 8005e06:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005e08:	2b06      	cmp	r3, #6
 8005e0a:	d01f      	beq.n	8005e4c <HAL_ADC_ConfigChannel+0x108>
 8005e0c:	687b      	ldr	r3, [r7, #4]
 8005e0e:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8005e10:	2b07      	cmp	r3, #7
 8005e12:	d01b      	beq.n	8005e4c <HAL_ADC_ConfigChannel+0x108>
      {
        /* Modify sampling time if needed (not needed in case of reoccurrence */
        /* for several channels programmed consecutively into the sequencer)  */
        if (sConfig->SamplingTime != ADC_GET_SAMPLINGTIME(hadc))
 8005e14:	683b      	ldr	r3, [r7, #0]
 8005e16:	689a      	ldr	r2, [r3, #8]
 8005e18:	687b      	ldr	r3, [r7, #4]
 8005e1a:	681b      	ldr	r3, [r3, #0]
 8005e1c:	695b      	ldr	r3, [r3, #20]
 8005e1e:	2107      	movs	r1, #7
 8005e20:	400b      	ands	r3, r1
 8005e22:	429a      	cmp	r2, r3
 8005e24:	d012      	beq.n	8005e4c <HAL_ADC_ConfigChannel+0x108>
        {
          /* Channel sampling time configuration */
          /* Clear the old sample time */
          hadc->Instance->SMPR &= ~(ADC_SMPR_SMP);
 8005e26:	687b      	ldr	r3, [r7, #4]
 8005e28:	681b      	ldr	r3, [r3, #0]
 8005e2a:	695a      	ldr	r2, [r3, #20]
 8005e2c:	687b      	ldr	r3, [r7, #4]
 8005e2e:	681b      	ldr	r3, [r3, #0]
 8005e30:	2107      	movs	r1, #7
 8005e32:	438a      	bics	r2, r1
 8005e34:	615a      	str	r2, [r3, #20]
          
          /* Set the new sample time */
          hadc->Instance->SMPR |= ADC_SMPR_SET(sConfig->SamplingTime);
 8005e36:	687b      	ldr	r3, [r7, #4]
 8005e38:	681b      	ldr	r3, [r3, #0]
 8005e3a:	6959      	ldr	r1, [r3, #20]
 8005e3c:	683b      	ldr	r3, [r7, #0]
 8005e3e:	689b      	ldr	r3, [r3, #8]
 8005e40:	2207      	movs	r2, #7
 8005e42:	401a      	ands	r2, r3
 8005e44:	687b      	ldr	r3, [r7, #4]
 8005e46:	681b      	ldr	r3, [r3, #0]
 8005e48:	430a      	orrs	r2, r1
 8005e4a:	615a      	str	r2, [r3, #20]
      /* internal measurement paths enable: If internal channel selected,     */
      /* enable dedicated internal buffers and path.                          */
      /* Note: these internal measurement paths can be disabled using         */
      /*       HAL_ADC_DeInit() or removing the channel from sequencer with   */
      /*       channel configuration parameter "Rank".                        */
      if(ADC_IS_CHANNEL_INTERNAL(sConfig->Channel))
 8005e4c:	683b      	ldr	r3, [r7, #0]
 8005e4e:	681b      	ldr	r3, [r3, #0]
 8005e50:	2b10      	cmp	r3, #16
 8005e52:	d007      	beq.n	8005e64 <HAL_ADC_ConfigChannel+0x120>
 8005e54:	683b      	ldr	r3, [r7, #0]
 8005e56:	681b      	ldr	r3, [r3, #0]
 8005e58:	2b11      	cmp	r3, #17
 8005e5a:	d003      	beq.n	8005e64 <HAL_ADC_ConfigChannel+0x120>
 8005e5c:	683b      	ldr	r3, [r7, #0]
 8005e5e:	681b      	ldr	r3, [r3, #0]
 8005e60:	2b12      	cmp	r3, #18
 8005e62:	d163      	bne.n	8005f2c <HAL_ADC_ConfigChannel+0x1e8>
      {
        /* If Channel_16 is selected, enable Temp. sensor measurement path. */
        /* If Channel_17 is selected, enable VREFINT measurement path. */
        /* If Channel_18 is selected, enable VBAT measurement path. */
        ADC->CCR |= ADC_CHANNEL_INTERNAL_PATH(sConfig->Channel);
 8005e64:	4b38      	ldr	r3, [pc, #224]	; (8005f48 <HAL_ADC_ConfigChannel+0x204>)
 8005e66:	6819      	ldr	r1, [r3, #0]
 8005e68:	683b      	ldr	r3, [r7, #0]
 8005e6a:	681b      	ldr	r3, [r3, #0]
 8005e6c:	2b10      	cmp	r3, #16
 8005e6e:	d009      	beq.n	8005e84 <HAL_ADC_ConfigChannel+0x140>
 8005e70:	683b      	ldr	r3, [r7, #0]
 8005e72:	681b      	ldr	r3, [r3, #0]
 8005e74:	2b11      	cmp	r3, #17
 8005e76:	d102      	bne.n	8005e7e <HAL_ADC_ConfigChannel+0x13a>
 8005e78:	2380      	movs	r3, #128	; 0x80
 8005e7a:	03db      	lsls	r3, r3, #15
 8005e7c:	e004      	b.n	8005e88 <HAL_ADC_ConfigChannel+0x144>
 8005e7e:	2380      	movs	r3, #128	; 0x80
 8005e80:	045b      	lsls	r3, r3, #17
 8005e82:	e001      	b.n	8005e88 <HAL_ADC_ConfigChannel+0x144>
 8005e84:	2380      	movs	r3, #128	; 0x80
 8005e86:	041b      	lsls	r3, r3, #16
 8005e88:	4a2f      	ldr	r2, [pc, #188]	; (8005f48 <HAL_ADC_ConfigChannel+0x204>)
 8005e8a:	430b      	orrs	r3, r1
 8005e8c:	6013      	str	r3, [r2, #0]
        
        /* If Temp. sensor is selected, wait for stabilization delay */
        if (sConfig->Channel == ADC_CHANNEL_TEMPSENSOR)
 8005e8e:	683b      	ldr	r3, [r7, #0]
 8005e90:	681b      	ldr	r3, [r3, #0]
 8005e92:	2b10      	cmp	r3, #16
 8005e94:	d14a      	bne.n	8005f2c <HAL_ADC_ConfigChannel+0x1e8>
        {
          /* Delay for temperature sensor stabilization time */
          /* Compute number of CPU cycles to wait for */
          wait_loop_index = (ADC_TEMPSENSOR_DELAY_US * (SystemCoreClock / 1000000U));
 8005e96:	4b2d      	ldr	r3, [pc, #180]	; (8005f4c <HAL_ADC_ConfigChannel+0x208>)
 8005e98:	681b      	ldr	r3, [r3, #0]
 8005e9a:	492d      	ldr	r1, [pc, #180]	; (8005f50 <HAL_ADC_ConfigChannel+0x20c>)
 8005e9c:	0018      	movs	r0, r3
 8005e9e:	f7fa f931 	bl	8000104 <__udivsi3>
 8005ea2:	0003      	movs	r3, r0
 8005ea4:	001a      	movs	r2, r3
 8005ea6:	0013      	movs	r3, r2
 8005ea8:	009b      	lsls	r3, r3, #2
 8005eaa:	189b      	adds	r3, r3, r2
 8005eac:	005b      	lsls	r3, r3, #1
 8005eae:	60bb      	str	r3, [r7, #8]
          while(wait_loop_index != 0U)
 8005eb0:	e002      	b.n	8005eb8 <HAL_ADC_ConfigChannel+0x174>
          {
            wait_loop_index--;
 8005eb2:	68bb      	ldr	r3, [r7, #8]
 8005eb4:	3b01      	subs	r3, #1
 8005eb6:	60bb      	str	r3, [r7, #8]
          while(wait_loop_index != 0U)
 8005eb8:	68bb      	ldr	r3, [r7, #8]
 8005eba:	2b00      	cmp	r3, #0
 8005ebc:	d1f9      	bne.n	8005eb2 <HAL_ADC_ConfigChannel+0x16e>
 8005ebe:	e035      	b.n	8005f2c <HAL_ADC_ConfigChannel+0x1e8>
    }
    else
    {
      /* Regular sequence configuration */
      /* Reset the channel selection register from the selected channel */
      hadc->Instance->CHSELR &= ~ADC_CHSELR_CHANNEL(sConfig->Channel);
 8005ec0:	687b      	ldr	r3, [r7, #4]
 8005ec2:	681b      	ldr	r3, [r3, #0]
 8005ec4:	6a9a      	ldr	r2, [r3, #40]	; 0x28
 8005ec6:	683b      	ldr	r3, [r7, #0]
 8005ec8:	681b      	ldr	r3, [r3, #0]
 8005eca:	2101      	movs	r1, #1
 8005ecc:	4099      	lsls	r1, r3
 8005ece:	000b      	movs	r3, r1
 8005ed0:	43d9      	mvns	r1, r3
 8005ed2:	687b      	ldr	r3, [r7, #4]
 8005ed4:	681b      	ldr	r3, [r3, #0]
 8005ed6:	400a      	ands	r2, r1
 8005ed8:	629a      	str	r2, [r3, #40]	; 0x28
      
      /* Management of internal measurement channels: VrefInt/TempSensor/Vbat */
      /* internal measurement paths disable: If internal channel selected,    */
      /* disable dedicated internal buffers and path.                         */
      if(ADC_IS_CHANNEL_INTERNAL(sConfig->Channel))
 8005eda:	683b      	ldr	r3, [r7, #0]
 8005edc:	681b      	ldr	r3, [r3, #0]
 8005ede:	2b10      	cmp	r3, #16
 8005ee0:	d007      	beq.n	8005ef2 <HAL_ADC_ConfigChannel+0x1ae>
 8005ee2:	683b      	ldr	r3, [r7, #0]
 8005ee4:	681b      	ldr	r3, [r3, #0]
 8005ee6:	2b11      	cmp	r3, #17
 8005ee8:	d003      	beq.n	8005ef2 <HAL_ADC_ConfigChannel+0x1ae>
 8005eea:	683b      	ldr	r3, [r7, #0]
 8005eec:	681b      	ldr	r3, [r3, #0]
 8005eee:	2b12      	cmp	r3, #18
 8005ef0:	d11c      	bne.n	8005f2c <HAL_ADC_ConfigChannel+0x1e8>
      {
        /* If Channel_16 is selected, disable Temp. sensor measurement path. */
        /* If Channel_17 is selected, disable VREFINT measurement path. */
        /* If Channel_18 is selected, disable VBAT measurement path. */
        ADC->CCR &= ~ADC_CHANNEL_INTERNAL_PATH(sConfig->Channel);
 8005ef2:	4b15      	ldr	r3, [pc, #84]	; (8005f48 <HAL_ADC_ConfigChannel+0x204>)
 8005ef4:	6819      	ldr	r1, [r3, #0]
 8005ef6:	683b      	ldr	r3, [r7, #0]
 8005ef8:	681b      	ldr	r3, [r3, #0]
 8005efa:	2b10      	cmp	r3, #16
 8005efc:	d007      	beq.n	8005f0e <HAL_ADC_ConfigChannel+0x1ca>
 8005efe:	683b      	ldr	r3, [r7, #0]
 8005f00:	681b      	ldr	r3, [r3, #0]
 8005f02:	2b11      	cmp	r3, #17
 8005f04:	d101      	bne.n	8005f0a <HAL_ADC_ConfigChannel+0x1c6>
 8005f06:	4b13      	ldr	r3, [pc, #76]	; (8005f54 <HAL_ADC_ConfigChannel+0x210>)
 8005f08:	e002      	b.n	8005f10 <HAL_ADC_ConfigChannel+0x1cc>
 8005f0a:	4b13      	ldr	r3, [pc, #76]	; (8005f58 <HAL_ADC_ConfigChannel+0x214>)
 8005f0c:	e000      	b.n	8005f10 <HAL_ADC_ConfigChannel+0x1cc>
 8005f0e:	4b13      	ldr	r3, [pc, #76]	; (8005f5c <HAL_ADC_ConfigChannel+0x218>)
 8005f10:	4a0d      	ldr	r2, [pc, #52]	; (8005f48 <HAL_ADC_ConfigChannel+0x204>)
 8005f12:	400b      	ands	r3, r1
 8005f14:	6013      	str	r3, [r2, #0]
 8005f16:	e009      	b.n	8005f2c <HAL_ADC_ConfigChannel+0x1e8>
  /* channel could be done on neither of the channel configuration structure  */
  /* parameters.                                                              */
  else
  {
    /* Update ADC state machine to error */
    SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_CONFIG);
 8005f18:	687b      	ldr	r3, [r7, #4]
 8005f1a:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8005f1c:	2220      	movs	r2, #32
 8005f1e:	431a      	orrs	r2, r3
 8005f20:	687b      	ldr	r3, [r7, #4]
 8005f22:	639a      	str	r2, [r3, #56]	; 0x38
    
    tmp_hal_status = HAL_ERROR;
 8005f24:	230f      	movs	r3, #15
 8005f26:	18fb      	adds	r3, r7, r3
 8005f28:	2201      	movs	r2, #1
 8005f2a:	701a      	strb	r2, [r3, #0]
  }
  
  /* Process unlocked */
  __HAL_UNLOCK(hadc);
 8005f2c:	687b      	ldr	r3, [r7, #4]
 8005f2e:	2234      	movs	r2, #52	; 0x34
 8005f30:	2100      	movs	r1, #0
 8005f32:	5499      	strb	r1, [r3, r2]
  
  /* Return function status */
  return tmp_hal_status;
 8005f34:	230f      	movs	r3, #15
 8005f36:	18fb      	adds	r3, r7, r3
 8005f38:	781b      	ldrb	r3, [r3, #0]
}
 8005f3a:	0018      	movs	r0, r3
 8005f3c:	46bd      	mov	sp, r7
 8005f3e:	b004      	add	sp, #16
 8005f40:	bd80      	pop	{r7, pc}
 8005f42:	46c0      	nop			; (mov r8, r8)
 8005f44:	00001001 	.word	0x00001001
 8005f48:	40012708 	.word	0x40012708
 8005f4c:	2000007c 	.word	0x2000007c
 8005f50:	000f4240 	.word	0x000f4240
 8005f54:	ffbfffff 	.word	0xffbfffff
 8005f58:	feffffff 	.word	0xfeffffff
 8005f5c:	ff7fffff 	.word	0xff7fffff

08005f60 <ADC_Enable>:
  *         "if (hadc->Init.LowPowerAutoPowerOff != ENABLE)".
  * @param  hadc ADC handle
  * @retval HAL status.
  */
static HAL_StatusTypeDef ADC_Enable(ADC_HandleTypeDef* hadc)
{
 8005f60:	b580      	push	{r7, lr}
 8005f62:	b084      	sub	sp, #16
 8005f64:	af00      	add	r7, sp, #0
 8005f66:	6078      	str	r0, [r7, #4]
  uint32_t tickstart = 0U;
 8005f68:	2300      	movs	r3, #0
 8005f6a:	60fb      	str	r3, [r7, #12]
  __IO uint32_t wait_loop_index = 0U;
 8005f6c:	2300      	movs	r3, #0
 8005f6e:	60bb      	str	r3, [r7, #8]
  
  /* ADC enable and wait for ADC ready (in case of ADC is disabled or         */
  /* enabling phase not yet completed: flag ADC ready not yet set).           */
  /* Timeout implemented to not be stuck if ADC cannot be enabled (possible   */
  /* causes: ADC clock not running, ...).                                     */
  if (ADC_IS_ENABLE(hadc) == RESET)
 8005f70:	687b      	ldr	r3, [r7, #4]
 8005f72:	681b      	ldr	r3, [r3, #0]
 8005f74:	689b      	ldr	r3, [r3, #8]
 8005f76:	2203      	movs	r2, #3
 8005f78:	4013      	ands	r3, r2
 8005f7a:	2b01      	cmp	r3, #1
 8005f7c:	d112      	bne.n	8005fa4 <ADC_Enable+0x44>
 8005f7e:	687b      	ldr	r3, [r7, #4]
 8005f80:	681b      	ldr	r3, [r3, #0]
 8005f82:	681b      	ldr	r3, [r3, #0]
 8005f84:	2201      	movs	r2, #1
 8005f86:	4013      	ands	r3, r2
 8005f88:	2b01      	cmp	r3, #1
 8005f8a:	d009      	beq.n	8005fa0 <ADC_Enable+0x40>
 8005f8c:	687b      	ldr	r3, [r7, #4]
 8005f8e:	681b      	ldr	r3, [r3, #0]
 8005f90:	68da      	ldr	r2, [r3, #12]
 8005f92:	2380      	movs	r3, #128	; 0x80
 8005f94:	021b      	lsls	r3, r3, #8
 8005f96:	401a      	ands	r2, r3
 8005f98:	2380      	movs	r3, #128	; 0x80
 8005f9a:	021b      	lsls	r3, r3, #8
 8005f9c:	429a      	cmp	r2, r3
 8005f9e:	d101      	bne.n	8005fa4 <ADC_Enable+0x44>
 8005fa0:	2301      	movs	r3, #1
 8005fa2:	e000      	b.n	8005fa6 <ADC_Enable+0x46>
 8005fa4:	2300      	movs	r3, #0
 8005fa6:	2b00      	cmp	r3, #0
 8005fa8:	d152      	bne.n	8006050 <ADC_Enable+0xf0>
  {
    /* Check if conditions to enable the ADC are fulfilled */
    if (ADC_ENABLING_CONDITIONS(hadc) == RESET)
 8005faa:	687b      	ldr	r3, [r7, #4]
 8005fac:	681b      	ldr	r3, [r3, #0]
 8005fae:	689b      	ldr	r3, [r3, #8]
 8005fb0:	4a2a      	ldr	r2, [pc, #168]	; (800605c <ADC_Enable+0xfc>)
 8005fb2:	4013      	ands	r3, r2
 8005fb4:	d00d      	beq.n	8005fd2 <ADC_Enable+0x72>
    {
      /* Update ADC state machine to error */
      SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_INTERNAL);
 8005fb6:	687b      	ldr	r3, [r7, #4]
 8005fb8:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8005fba:	2210      	movs	r2, #16
 8005fbc:	431a      	orrs	r2, r3
 8005fbe:	687b      	ldr	r3, [r7, #4]
 8005fc0:	639a      	str	r2, [r3, #56]	; 0x38
    
      /* Set ADC error code to ADC IP internal error */
      SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_INTERNAL);
 8005fc2:	687b      	ldr	r3, [r7, #4]
 8005fc4:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8005fc6:	2201      	movs	r2, #1
 8005fc8:	431a      	orrs	r2, r3
 8005fca:	687b      	ldr	r3, [r7, #4]
 8005fcc:	63da      	str	r2, [r3, #60]	; 0x3c
      
      return HAL_ERROR;
 8005fce:	2301      	movs	r3, #1
 8005fd0:	e03f      	b.n	8006052 <ADC_Enable+0xf2>
    }
    
    /* Enable the ADC peripheral */
    __HAL_ADC_ENABLE(hadc);
 8005fd2:	687b      	ldr	r3, [r7, #4]
 8005fd4:	681b      	ldr	r3, [r3, #0]
 8005fd6:	689a      	ldr	r2, [r3, #8]
 8005fd8:	687b      	ldr	r3, [r7, #4]
 8005fda:	681b      	ldr	r3, [r3, #0]
 8005fdc:	2101      	movs	r1, #1
 8005fde:	430a      	orrs	r2, r1
 8005fe0:	609a      	str	r2, [r3, #8]
    
    /* Delay for ADC stabilization time */
    /* Compute number of CPU cycles to wait for */
    wait_loop_index = (ADC_STAB_DELAY_US * (SystemCoreClock / 1000000U));
 8005fe2:	4b1f      	ldr	r3, [pc, #124]	; (8006060 <ADC_Enable+0x100>)
 8005fe4:	681b      	ldr	r3, [r3, #0]
 8005fe6:	491f      	ldr	r1, [pc, #124]	; (8006064 <ADC_Enable+0x104>)
 8005fe8:	0018      	movs	r0, r3
 8005fea:	f7fa f88b 	bl	8000104 <__udivsi3>
 8005fee:	0003      	movs	r3, r0
 8005ff0:	60bb      	str	r3, [r7, #8]
    while(wait_loop_index != 0U)
 8005ff2:	e002      	b.n	8005ffa <ADC_Enable+0x9a>
    {
      wait_loop_index--;
 8005ff4:	68bb      	ldr	r3, [r7, #8]
 8005ff6:	3b01      	subs	r3, #1
 8005ff8:	60bb      	str	r3, [r7, #8]
    while(wait_loop_index != 0U)
 8005ffa:	68bb      	ldr	r3, [r7, #8]
 8005ffc:	2b00      	cmp	r3, #0
 8005ffe:	d1f9      	bne.n	8005ff4 <ADC_Enable+0x94>
    }

    /* Get tick count */
    tickstart = HAL_GetTick();
 8006000:	f7ff fca8 	bl	8005954 <HAL_GetTick>
 8006004:	0003      	movs	r3, r0
 8006006:	60fb      	str	r3, [r7, #12]
    
    /* Wait for ADC effectively enabled */
    while(__HAL_ADC_GET_FLAG(hadc, ADC_FLAG_RDY) == RESET)
 8006008:	e01b      	b.n	8006042 <ADC_Enable+0xe2>
    {
      if((HAL_GetTick() - tickstart) > ADC_ENABLE_TIMEOUT)
 800600a:	f7ff fca3 	bl	8005954 <HAL_GetTick>
 800600e:	0002      	movs	r2, r0
 8006010:	68fb      	ldr	r3, [r7, #12]
 8006012:	1ad3      	subs	r3, r2, r3
 8006014:	2b02      	cmp	r3, #2
 8006016:	d914      	bls.n	8006042 <ADC_Enable+0xe2>
      {
        /* New check to avoid false timeout detection in case of preemption */
        if(__HAL_ADC_GET_FLAG(hadc, ADC_FLAG_RDY) == RESET)
 8006018:	687b      	ldr	r3, [r7, #4]
 800601a:	681b      	ldr	r3, [r3, #0]
 800601c:	681b      	ldr	r3, [r3, #0]
 800601e:	2201      	movs	r2, #1
 8006020:	4013      	ands	r3, r2
 8006022:	2b01      	cmp	r3, #1
 8006024:	d00d      	beq.n	8006042 <ADC_Enable+0xe2>
        {
          /* Update ADC state machine to error */
          SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_INTERNAL);
 8006026:	687b      	ldr	r3, [r7, #4]
 8006028:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 800602a:	2210      	movs	r2, #16
 800602c:	431a      	orrs	r2, r3
 800602e:	687b      	ldr	r3, [r7, #4]
 8006030:	639a      	str	r2, [r3, #56]	; 0x38

          /* Set ADC error code to ADC IP internal error */
          SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_INTERNAL);
 8006032:	687b      	ldr	r3, [r7, #4]
 8006034:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8006036:	2201      	movs	r2, #1
 8006038:	431a      	orrs	r2, r3
 800603a:	687b      	ldr	r3, [r7, #4]
 800603c:	63da      	str	r2, [r3, #60]	; 0x3c

          return HAL_ERROR;
 800603e:	2301      	movs	r3, #1
 8006040:	e007      	b.n	8006052 <ADC_Enable+0xf2>
    while(__HAL_ADC_GET_FLAG(hadc, ADC_FLAG_RDY) == RESET)
 8006042:	687b      	ldr	r3, [r7, #4]
 8006044:	681b      	ldr	r3, [r3, #0]
 8006046:	681b      	ldr	r3, [r3, #0]
 8006048:	2201      	movs	r2, #1
 800604a:	4013      	ands	r3, r2
 800604c:	2b01      	cmp	r3, #1
 800604e:	d1dc      	bne.n	800600a <ADC_Enable+0xaa>
      }
    }
  }
   
  /* Return HAL status */
  return HAL_OK;
 8006050:	2300      	movs	r3, #0
}
 8006052:	0018      	movs	r0, r3
 8006054:	46bd      	mov	sp, r7
 8006056:	b004      	add	sp, #16
 8006058:	bd80      	pop	{r7, pc}
 800605a:	46c0      	nop			; (mov r8, r8)
 800605c:	80000017 	.word	0x80000017
 8006060:	2000007c 	.word	0x2000007c
 8006064:	000f4240 	.word	0x000f4240

08006068 <ADC_DMAConvCplt>:
  * @brief  DMA transfer complete callback. 
  * @param  hdma pointer to DMA handle.
  * @retval None
  */
static void ADC_DMAConvCplt(DMA_HandleTypeDef *hdma)
{
 8006068:	b580      	push	{r7, lr}
 800606a:	b084      	sub	sp, #16
 800606c:	af00      	add	r7, sp, #0
 800606e:	6078      	str	r0, [r7, #4]
  /* Retrieve ADC handle corresponding to current DMA handle */
  ADC_HandleTypeDef* hadc = ( ADC_HandleTypeDef* )((DMA_HandleTypeDef* )hdma)->Parent;
 8006070:	687b      	ldr	r3, [r7, #4]
 8006072:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8006074:	60fb      	str	r3, [r7, #12]
  
  /* Update state machine on conversion status if not in error state */
  if (HAL_IS_BIT_CLR(hadc->State, HAL_ADC_STATE_ERROR_INTERNAL | HAL_ADC_STATE_ERROR_DMA))
 8006076:	68fb      	ldr	r3, [r7, #12]
 8006078:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 800607a:	2250      	movs	r2, #80	; 0x50
 800607c:	4013      	ands	r3, r2
 800607e:	d140      	bne.n	8006102 <ADC_DMAConvCplt+0x9a>
  {
    /* Set ADC state */
    SET_BIT(hadc->State, HAL_ADC_STATE_REG_EOC); 
 8006080:	68fb      	ldr	r3, [r7, #12]
 8006082:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8006084:	2280      	movs	r2, #128	; 0x80
 8006086:	0092      	lsls	r2, r2, #2
 8006088:	431a      	orrs	r2, r3
 800608a:	68fb      	ldr	r3, [r7, #12]
 800608c:	639a      	str	r2, [r3, #56]	; 0x38
    
    /* Determine whether any further conversion upcoming on group regular     */
    /* by external trigger, continuous mode or scan sequence on going.        */
    if(ADC_IS_SOFTWARE_START_REGULAR(hadc)        && 
 800608e:	68fb      	ldr	r3, [r7, #12]
 8006090:	681b      	ldr	r3, [r3, #0]
 8006092:	68da      	ldr	r2, [r3, #12]
 8006094:	23c0      	movs	r3, #192	; 0xc0
 8006096:	011b      	lsls	r3, r3, #4
 8006098:	4013      	ands	r3, r2
 800609a:	d12d      	bne.n	80060f8 <ADC_DMAConvCplt+0x90>
       (hadc->Init.ContinuousConvMode == DISABLE)   )
 800609c:	68fb      	ldr	r3, [r7, #12]
 800609e:	7e9b      	ldrb	r3, [r3, #26]
    if(ADC_IS_SOFTWARE_START_REGULAR(hadc)        && 
 80060a0:	2b00      	cmp	r3, #0
 80060a2:	d129      	bne.n	80060f8 <ADC_DMAConvCplt+0x90>
    {
      /* If End of Sequence is reached, disable interrupts */
      if( __HAL_ADC_GET_FLAG(hadc, ADC_FLAG_EOS) )
 80060a4:	68fb      	ldr	r3, [r7, #12]
 80060a6:	681b      	ldr	r3, [r3, #0]
 80060a8:	681b      	ldr	r3, [r3, #0]
 80060aa:	2208      	movs	r2, #8
 80060ac:	4013      	ands	r3, r2
 80060ae:	2b08      	cmp	r3, #8
 80060b0:	d122      	bne.n	80060f8 <ADC_DMAConvCplt+0x90>
      {
        /* Allowed to modify bits ADC_IT_EOC/ADC_IT_EOS only if bit           */
        /* ADSTART==0 (no conversion on going)                                */
        if (ADC_IS_CONVERSION_ONGOING_REGULAR(hadc) == RESET)
 80060b2:	68fb      	ldr	r3, [r7, #12]
 80060b4:	681b      	ldr	r3, [r3, #0]
 80060b6:	689b      	ldr	r3, [r3, #8]
 80060b8:	2204      	movs	r2, #4
 80060ba:	4013      	ands	r3, r2
 80060bc:	d110      	bne.n	80060e0 <ADC_DMAConvCplt+0x78>
        {
          /* Disable ADC end of single conversion interrupt on group regular */
          /* Note: Overrun interrupt was enabled with EOC interrupt in        */
          /* HAL_Start_IT(), but is not disabled here because can be used     */
          /* by overrun IRQ process below.                                    */
          __HAL_ADC_DISABLE_IT(hadc, ADC_IT_EOC | ADC_IT_EOS);
 80060be:	68fb      	ldr	r3, [r7, #12]
 80060c0:	681b      	ldr	r3, [r3, #0]
 80060c2:	685a      	ldr	r2, [r3, #4]
 80060c4:	68fb      	ldr	r3, [r7, #12]
 80060c6:	681b      	ldr	r3, [r3, #0]
 80060c8:	210c      	movs	r1, #12
 80060ca:	438a      	bics	r2, r1
 80060cc:	605a      	str	r2, [r3, #4]
          
          /* Set ADC state */
          ADC_STATE_CLR_SET(hadc->State,
 80060ce:	68fb      	ldr	r3, [r7, #12]
 80060d0:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 80060d2:	4a11      	ldr	r2, [pc, #68]	; (8006118 <ADC_DMAConvCplt+0xb0>)
 80060d4:	4013      	ands	r3, r2
 80060d6:	2201      	movs	r2, #1
 80060d8:	431a      	orrs	r2, r3
 80060da:	68fb      	ldr	r3, [r7, #12]
 80060dc:	639a      	str	r2, [r3, #56]	; 0x38
 80060de:	e00b      	b.n	80060f8 <ADC_DMAConvCplt+0x90>
                            HAL_ADC_STATE_READY);
        }
        else
        {
          /* Change ADC state to error state */
          SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_CONFIG);
 80060e0:	68fb      	ldr	r3, [r7, #12]
 80060e2:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 80060e4:	2220      	movs	r2, #32
 80060e6:	431a      	orrs	r2, r3
 80060e8:	68fb      	ldr	r3, [r7, #12]
 80060ea:	639a      	str	r2, [r3, #56]	; 0x38
          
          /* Set ADC error code to ADC IP internal error */
          SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_INTERNAL);
 80060ec:	68fb      	ldr	r3, [r7, #12]
 80060ee:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 80060f0:	2201      	movs	r2, #1
 80060f2:	431a      	orrs	r2, r3
 80060f4:	68fb      	ldr	r3, [r7, #12]
 80060f6:	63da      	str	r2, [r3, #60]	; 0x3c

    /* Conversion complete callback */
#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1)
    hadc->ConvCpltCallback(hadc);
#else
    HAL_ADC_ConvCpltCallback(hadc);
 80060f8:	68fb      	ldr	r3, [r7, #12]
 80060fa:	0018      	movs	r0, r3
 80060fc:	f7fe fb07 	bl	800470e <HAL_ADC_ConvCpltCallback>
  {
    /* Call DMA error callback */
    hadc->DMA_Handle->XferErrorCallback(hdma);
  }

}
 8006100:	e005      	b.n	800610e <ADC_DMAConvCplt+0xa6>
    hadc->DMA_Handle->XferErrorCallback(hdma);
 8006102:	68fb      	ldr	r3, [r7, #12]
 8006104:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8006106:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8006108:	687a      	ldr	r2, [r7, #4]
 800610a:	0010      	movs	r0, r2
 800610c:	4798      	blx	r3
}
 800610e:	46c0      	nop			; (mov r8, r8)
 8006110:	46bd      	mov	sp, r7
 8006112:	b004      	add	sp, #16
 8006114:	bd80      	pop	{r7, pc}
 8006116:	46c0      	nop			; (mov r8, r8)
 8006118:	fffffefe 	.word	0xfffffefe

0800611c <ADC_DMAHalfConvCplt>:
  * @brief  DMA half transfer complete callback. 
  * @param  hdma pointer to DMA handle.
  * @retval None
  */
static void ADC_DMAHalfConvCplt(DMA_HandleTypeDef *hdma)   
{
 800611c:	b580      	push	{r7, lr}
 800611e:	b084      	sub	sp, #16
 8006120:	af00      	add	r7, sp, #0
 8006122:	6078      	str	r0, [r7, #4]
  /* Retrieve ADC handle corresponding to current DMA handle */
  ADC_HandleTypeDef* hadc = ( ADC_HandleTypeDef* )((DMA_HandleTypeDef* )hdma)->Parent;
 8006124:	687b      	ldr	r3, [r7, #4]
 8006126:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8006128:	60fb      	str	r3, [r7, #12]
  
  /* Half conversion callback */
#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1)
    hadc->ConvHalfCpltCallback(hadc);
#else
  HAL_ADC_ConvHalfCpltCallback(hadc); 
 800612a:	68fb      	ldr	r3, [r7, #12]
 800612c:	0018      	movs	r0, r3
 800612e:	f7fe fae5 	bl	80046fc <HAL_ADC_ConvHalfCpltCallback>
#endif /* USE_HAL_ADC_REGISTER_CALLBACKS */
}
 8006132:	46c0      	nop			; (mov r8, r8)
 8006134:	46bd      	mov	sp, r7
 8006136:	b004      	add	sp, #16
 8006138:	bd80      	pop	{r7, pc}

0800613a <ADC_DMAError>:
  * @brief  DMA error callback 
  * @param  hdma pointer to DMA handle.
  * @retval None
  */
static void ADC_DMAError(DMA_HandleTypeDef *hdma)   
{
 800613a:	b580      	push	{r7, lr}
 800613c:	b084      	sub	sp, #16
 800613e:	af00      	add	r7, sp, #0
 8006140:	6078      	str	r0, [r7, #4]
  /* Retrieve ADC handle corresponding to current DMA handle */
  ADC_HandleTypeDef* hadc = ( ADC_HandleTypeDef* )((DMA_HandleTypeDef* )hdma)->Parent;
 8006142:	687b      	ldr	r3, [r7, #4]
 8006144:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8006146:	60fb      	str	r3, [r7, #12]
  
  /* Set ADC state */
  SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_DMA);
 8006148:	68fb      	ldr	r3, [r7, #12]
 800614a:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 800614c:	2240      	movs	r2, #64	; 0x40
 800614e:	431a      	orrs	r2, r3
 8006150:	68fb      	ldr	r3, [r7, #12]
 8006152:	639a      	str	r2, [r3, #56]	; 0x38
  
  /* Set ADC error code to DMA error */
  SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_DMA);
 8006154:	68fb      	ldr	r3, [r7, #12]
 8006156:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8006158:	2204      	movs	r2, #4
 800615a:	431a      	orrs	r2, r3
 800615c:	68fb      	ldr	r3, [r7, #12]
 800615e:	63da      	str	r2, [r3, #60]	; 0x3c
  
  /* Error callback */
#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1)
  hadc->ErrorCallback(hadc);
#else
  HAL_ADC_ErrorCallback(hadc); 
 8006160:	68fb      	ldr	r3, [r7, #12]
 8006162:	0018      	movs	r0, r3
 8006164:	f7ff fde6 	bl	8005d34 <HAL_ADC_ErrorCallback>
#endif /* USE_HAL_ADC_REGISTER_CALLBACKS */
}
 8006168:	46c0      	nop			; (mov r8, r8)
 800616a:	46bd      	mov	sp, r7
 800616c:	b004      	add	sp, #16
 800616e:	bd80      	pop	{r7, pc}

08006170 <__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)
{
 8006170:	b580      	push	{r7, lr}
 8006172:	b082      	sub	sp, #8
 8006174:	af00      	add	r7, sp, #0
 8006176:	0002      	movs	r2, r0
 8006178:	1dfb      	adds	r3, r7, #7
 800617a:	701a      	strb	r2, [r3, #0]
  if ((int32_t)(IRQn) >= 0)
 800617c:	1dfb      	adds	r3, r7, #7
 800617e:	781b      	ldrb	r3, [r3, #0]
 8006180:	2b7f      	cmp	r3, #127	; 0x7f
 8006182:	d809      	bhi.n	8006198 <__NVIC_EnableIRQ+0x28>
  {
    NVIC->ISER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL));
 8006184:	1dfb      	adds	r3, r7, #7
 8006186:	781b      	ldrb	r3, [r3, #0]
 8006188:	001a      	movs	r2, r3
 800618a:	231f      	movs	r3, #31
 800618c:	401a      	ands	r2, r3
 800618e:	4b04      	ldr	r3, [pc, #16]	; (80061a0 <__NVIC_EnableIRQ+0x30>)
 8006190:	2101      	movs	r1, #1
 8006192:	4091      	lsls	r1, r2
 8006194:	000a      	movs	r2, r1
 8006196:	601a      	str	r2, [r3, #0]
  }
}
 8006198:	46c0      	nop			; (mov r8, r8)
 800619a:	46bd      	mov	sp, r7
 800619c:	b002      	add	sp, #8
 800619e:	bd80      	pop	{r7, pc}
 80061a0:	e000e100 	.word	0xe000e100

080061a4 <__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)
{
 80061a4:	b590      	push	{r4, r7, lr}
 80061a6:	b083      	sub	sp, #12
 80061a8:	af00      	add	r7, sp, #0
 80061aa:	0002      	movs	r2, r0
 80061ac:	6039      	str	r1, [r7, #0]
 80061ae:	1dfb      	adds	r3, r7, #7
 80061b0:	701a      	strb	r2, [r3, #0]
  if ((int32_t)(IRQn) >= 0)
 80061b2:	1dfb      	adds	r3, r7, #7
 80061b4:	781b      	ldrb	r3, [r3, #0]
 80061b6:	2b7f      	cmp	r3, #127	; 0x7f
 80061b8:	d828      	bhi.n	800620c <__NVIC_SetPriority+0x68>
  {
    NVIC->IP[_IP_IDX(IRQn)]  = ((uint32_t)(NVIC->IP[_IP_IDX(IRQn)]  & ~(0xFFUL << _BIT_SHIFT(IRQn))) |
 80061ba:	4a2f      	ldr	r2, [pc, #188]	; (8006278 <__NVIC_SetPriority+0xd4>)
 80061bc:	1dfb      	adds	r3, r7, #7
 80061be:	781b      	ldrb	r3, [r3, #0]
 80061c0:	b25b      	sxtb	r3, r3
 80061c2:	089b      	lsrs	r3, r3, #2
 80061c4:	33c0      	adds	r3, #192	; 0xc0
 80061c6:	009b      	lsls	r3, r3, #2
 80061c8:	589b      	ldr	r3, [r3, r2]
 80061ca:	1dfa      	adds	r2, r7, #7
 80061cc:	7812      	ldrb	r2, [r2, #0]
 80061ce:	0011      	movs	r1, r2
 80061d0:	2203      	movs	r2, #3
 80061d2:	400a      	ands	r2, r1
 80061d4:	00d2      	lsls	r2, r2, #3
 80061d6:	21ff      	movs	r1, #255	; 0xff
 80061d8:	4091      	lsls	r1, r2
 80061da:	000a      	movs	r2, r1
 80061dc:	43d2      	mvns	r2, r2
 80061de:	401a      	ands	r2, r3
 80061e0:	0011      	movs	r1, r2
       (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn)));
 80061e2:	683b      	ldr	r3, [r7, #0]
 80061e4:	019b      	lsls	r3, r3, #6
 80061e6:	22ff      	movs	r2, #255	; 0xff
 80061e8:	401a      	ands	r2, r3
 80061ea:	1dfb      	adds	r3, r7, #7
 80061ec:	781b      	ldrb	r3, [r3, #0]
 80061ee:	0018      	movs	r0, r3
 80061f0:	2303      	movs	r3, #3
 80061f2:	4003      	ands	r3, r0
 80061f4:	00db      	lsls	r3, r3, #3
 80061f6:	409a      	lsls	r2, r3
    NVIC->IP[_IP_IDX(IRQn)]  = ((uint32_t)(NVIC->IP[_IP_IDX(IRQn)]  & ~(0xFFUL << _BIT_SHIFT(IRQn))) |
 80061f8:	481f      	ldr	r0, [pc, #124]	; (8006278 <__NVIC_SetPriority+0xd4>)
 80061fa:	1dfb      	adds	r3, r7, #7
 80061fc:	781b      	ldrb	r3, [r3, #0]
 80061fe:	b25b      	sxtb	r3, r3
 8006200:	089b      	lsrs	r3, r3, #2
 8006202:	430a      	orrs	r2, r1
 8006204:	33c0      	adds	r3, #192	; 0xc0
 8006206:	009b      	lsls	r3, r3, #2
 8006208:	501a      	str	r2, [r3, r0]
  else
  {
    SCB->SHP[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHP[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) |
       (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn)));
  }
}
 800620a:	e031      	b.n	8006270 <__NVIC_SetPriority+0xcc>
    SCB->SHP[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHP[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) |
 800620c:	4a1b      	ldr	r2, [pc, #108]	; (800627c <__NVIC_SetPriority+0xd8>)
 800620e:	1dfb      	adds	r3, r7, #7
 8006210:	781b      	ldrb	r3, [r3, #0]
 8006212:	0019      	movs	r1, r3
 8006214:	230f      	movs	r3, #15
 8006216:	400b      	ands	r3, r1
 8006218:	3b08      	subs	r3, #8
 800621a:	089b      	lsrs	r3, r3, #2
 800621c:	3306      	adds	r3, #6
 800621e:	009b      	lsls	r3, r3, #2
 8006220:	18d3      	adds	r3, r2, r3
 8006222:	3304      	adds	r3, #4
 8006224:	681b      	ldr	r3, [r3, #0]
 8006226:	1dfa      	adds	r2, r7, #7
 8006228:	7812      	ldrb	r2, [r2, #0]
 800622a:	0011      	movs	r1, r2
 800622c:	2203      	movs	r2, #3
 800622e:	400a      	ands	r2, r1
 8006230:	00d2      	lsls	r2, r2, #3
 8006232:	21ff      	movs	r1, #255	; 0xff
 8006234:	4091      	lsls	r1, r2
 8006236:	000a      	movs	r2, r1
 8006238:	43d2      	mvns	r2, r2
 800623a:	401a      	ands	r2, r3
 800623c:	0011      	movs	r1, r2
       (((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn)));
 800623e:	683b      	ldr	r3, [r7, #0]
 8006240:	019b      	lsls	r3, r3, #6
 8006242:	22ff      	movs	r2, #255	; 0xff
 8006244:	401a      	ands	r2, r3
 8006246:	1dfb      	adds	r3, r7, #7
 8006248:	781b      	ldrb	r3, [r3, #0]
 800624a:	0018      	movs	r0, r3
 800624c:	2303      	movs	r3, #3
 800624e:	4003      	ands	r3, r0
 8006250:	00db      	lsls	r3, r3, #3
 8006252:	409a      	lsls	r2, r3
    SCB->SHP[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHP[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) |
 8006254:	4809      	ldr	r0, [pc, #36]	; (800627c <__NVIC_SetPriority+0xd8>)
 8006256:	1dfb      	adds	r3, r7, #7
 8006258:	781b      	ldrb	r3, [r3, #0]
 800625a:	001c      	movs	r4, r3
 800625c:	230f      	movs	r3, #15
 800625e:	4023      	ands	r3, r4
 8006260:	3b08      	subs	r3, #8
 8006262:	089b      	lsrs	r3, r3, #2
 8006264:	430a      	orrs	r2, r1
 8006266:	3306      	adds	r3, #6
 8006268:	009b      	lsls	r3, r3, #2
 800626a:	18c3      	adds	r3, r0, r3
 800626c:	3304      	adds	r3, #4
 800626e:	601a      	str	r2, [r3, #0]
}
 8006270:	46c0      	nop			; (mov r8, r8)
 8006272:	46bd      	mov	sp, r7
 8006274:	b003      	add	sp, #12
 8006276:	bd90      	pop	{r4, r7, pc}
 8006278:	e000e100 	.word	0xe000e100
 800627c:	e000ed00 	.word	0xe000ed00

08006280 <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)
{
 8006280:	b580      	push	{r7, lr}
 8006282:	b082      	sub	sp, #8
 8006284:	af00      	add	r7, sp, #0
 8006286:	6078      	str	r0, [r7, #4]
  if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk)
 8006288:	687b      	ldr	r3, [r7, #4]
 800628a:	1e5a      	subs	r2, r3, #1
 800628c:	2380      	movs	r3, #128	; 0x80
 800628e:	045b      	lsls	r3, r3, #17
 8006290:	429a      	cmp	r2, r3
 8006292:	d301      	bcc.n	8006298 <SysTick_Config+0x18>
  {
    return (1UL);                                                   /* Reload value impossible */
 8006294:	2301      	movs	r3, #1
 8006296:	e010      	b.n	80062ba <SysTick_Config+0x3a>
  }

  SysTick->LOAD  = (uint32_t)(ticks - 1UL);                         /* set reload register */
 8006298:	4b0a      	ldr	r3, [pc, #40]	; (80062c4 <SysTick_Config+0x44>)
 800629a:	687a      	ldr	r2, [r7, #4]
 800629c:	3a01      	subs	r2, #1
 800629e:	605a      	str	r2, [r3, #4]
  NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */
 80062a0:	2301      	movs	r3, #1
 80062a2:	425b      	negs	r3, r3
 80062a4:	2103      	movs	r1, #3
 80062a6:	0018      	movs	r0, r3
 80062a8:	f7ff ff7c 	bl	80061a4 <__NVIC_SetPriority>
  SysTick->VAL   = 0UL;                                             /* Load the SysTick Counter Value */
 80062ac:	4b05      	ldr	r3, [pc, #20]	; (80062c4 <SysTick_Config+0x44>)
 80062ae:	2200      	movs	r2, #0
 80062b0:	609a      	str	r2, [r3, #8]
  SysTick->CTRL  = SysTick_CTRL_CLKSOURCE_Msk |
 80062b2:	4b04      	ldr	r3, [pc, #16]	; (80062c4 <SysTick_Config+0x44>)
 80062b4:	2207      	movs	r2, #7
 80062b6:	601a      	str	r2, [r3, #0]
                   SysTick_CTRL_TICKINT_Msk   |
                   SysTick_CTRL_ENABLE_Msk;                         /* Enable SysTick IRQ and SysTick Timer */
  return (0UL);                                                     /* Function successful */
 80062b8:	2300      	movs	r3, #0
}
 80062ba:	0018      	movs	r0, r3
 80062bc:	46bd      	mov	sp, r7
 80062be:	b002      	add	sp, #8
 80062c0:	bd80      	pop	{r7, pc}
 80062c2:	46c0      	nop			; (mov r8, r8)
 80062c4:	e000e010 	.word	0xe000e010

080062c8 <HAL_NVIC_SetPriority>:
  *         with stm32f0xx devices, this parameter is a dummy value and it is ignored, because 
  *         no subpriority supported in Cortex M0 based products.   
  * @retval None
  */
void HAL_NVIC_SetPriority(IRQn_Type IRQn, uint32_t PreemptPriority, uint32_t SubPriority)
{ 
 80062c8:	b580      	push	{r7, lr}
 80062ca:	b084      	sub	sp, #16
 80062cc:	af00      	add	r7, sp, #0
 80062ce:	60b9      	str	r1, [r7, #8]
 80062d0:	607a      	str	r2, [r7, #4]
 80062d2:	210f      	movs	r1, #15
 80062d4:	187b      	adds	r3, r7, r1
 80062d6:	1c02      	adds	r2, r0, #0
 80062d8:	701a      	strb	r2, [r3, #0]
  /* Check the parameters */
  assert_param(IS_NVIC_PREEMPTION_PRIORITY(PreemptPriority));
  NVIC_SetPriority(IRQn,PreemptPriority);
 80062da:	68ba      	ldr	r2, [r7, #8]
 80062dc:	187b      	adds	r3, r7, r1
 80062de:	781b      	ldrb	r3, [r3, #0]
 80062e0:	b25b      	sxtb	r3, r3
 80062e2:	0011      	movs	r1, r2
 80062e4:	0018      	movs	r0, r3
 80062e6:	f7ff ff5d 	bl	80061a4 <__NVIC_SetPriority>
}
 80062ea:	46c0      	nop			; (mov r8, r8)
 80062ec:	46bd      	mov	sp, r7
 80062ee:	b004      	add	sp, #16
 80062f0:	bd80      	pop	{r7, pc}

080062f2 <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 (stm32f0xxxx.h))
  * @retval None
  */
void HAL_NVIC_EnableIRQ(IRQn_Type IRQn)
{
 80062f2:	b580      	push	{r7, lr}
 80062f4:	b082      	sub	sp, #8
 80062f6:	af00      	add	r7, sp, #0
 80062f8:	0002      	movs	r2, r0
 80062fa:	1dfb      	adds	r3, r7, #7
 80062fc:	701a      	strb	r2, [r3, #0]
  /* Check the parameters */
  assert_param(IS_NVIC_DEVICE_IRQ(IRQn));
  
  /* Enable interrupt */
  NVIC_EnableIRQ(IRQn);
 80062fe:	1dfb      	adds	r3, r7, #7
 8006300:	781b      	ldrb	r3, [r3, #0]
 8006302:	b25b      	sxtb	r3, r3
 8006304:	0018      	movs	r0, r3
 8006306:	f7ff ff33 	bl	8006170 <__NVIC_EnableIRQ>
}
 800630a:	46c0      	nop			; (mov r8, r8)
 800630c:	46bd      	mov	sp, r7
 800630e:	b002      	add	sp, #8
 8006310:	bd80      	pop	{r7, pc}

08006312 <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)
{
 8006312:	b580      	push	{r7, lr}
 8006314:	b082      	sub	sp, #8
 8006316:	af00      	add	r7, sp, #0
 8006318:	6078      	str	r0, [r7, #4]
   return SysTick_Config(TicksNumb);
 800631a:	687b      	ldr	r3, [r7, #4]
 800631c:	0018      	movs	r0, r3
 800631e:	f7ff ffaf 	bl	8006280 <SysTick_Config>
 8006322:	0003      	movs	r3, r0
}
 8006324:	0018      	movs	r0, r3
 8006326:	46bd      	mov	sp, r7
 8006328:	b002      	add	sp, #8
 800632a:	bd80      	pop	{r7, pc}

0800632c <HAL_DMA_Init>:
  * @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_Init(DMA_HandleTypeDef *hdma)
{ 
 800632c:	b580      	push	{r7, lr}
 800632e:	b084      	sub	sp, #16
 8006330:	af00      	add	r7, sp, #0
 8006332:	6078      	str	r0, [r7, #4]
  uint32_t tmp = 0U;
 8006334:	2300      	movs	r3, #0
 8006336:	60fb      	str	r3, [r7, #12]
  
  /* Check the DMA handle allocation */
  if(NULL == hdma)
 8006338:	687b      	ldr	r3, [r7, #4]
 800633a:	2b00      	cmp	r3, #0
 800633c:	d101      	bne.n	8006342 <HAL_DMA_Init+0x16>
  {
    return HAL_ERROR;
 800633e:	2301      	movs	r3, #1
 8006340:	e036      	b.n	80063b0 <HAL_DMA_Init+0x84>
  assert_param(IS_DMA_MEMORY_DATA_SIZE(hdma->Init.MemDataAlignment));
  assert_param(IS_DMA_MODE(hdma->Init.Mode));
  assert_param(IS_DMA_PRIORITY(hdma->Init.Priority));
  
  /* Change DMA peripheral state */
  hdma->State = HAL_DMA_STATE_BUSY;
 8006342:	687b      	ldr	r3, [r7, #4]
 8006344:	2221      	movs	r2, #33	; 0x21
 8006346:	2102      	movs	r1, #2
 8006348:	5499      	strb	r1, [r3, r2]

  /* Get the CR register value */
  tmp = hdma->Instance->CCR;
 800634a:	687b      	ldr	r3, [r7, #4]
 800634c:	681b      	ldr	r3, [r3, #0]
 800634e:	681b      	ldr	r3, [r3, #0]
 8006350:	60fb      	str	r3, [r7, #12]
  
  /* Clear PL, MSIZE, PSIZE, MINC, PINC, CIRC, DIR bits */
  tmp &= ((uint32_t)~(DMA_CCR_PL    | DMA_CCR_MSIZE  | DMA_CCR_PSIZE  | \
 8006352:	68fb      	ldr	r3, [r7, #12]
 8006354:	4a18      	ldr	r2, [pc, #96]	; (80063b8 <HAL_DMA_Init+0x8c>)
 8006356:	4013      	ands	r3, r2
 8006358:	60fb      	str	r3, [r7, #12]
                      DMA_CCR_MINC  | DMA_CCR_PINC   | DMA_CCR_CIRC   | \
                      DMA_CCR_DIR));
  
  /* Prepare the DMA Channel configuration */
  tmp |=  hdma->Init.Direction        |
 800635a:	687b      	ldr	r3, [r7, #4]
 800635c:	685a      	ldr	r2, [r3, #4]
          hdma->Init.PeriphInc           | hdma->Init.MemInc           |
 800635e:	687b      	ldr	r3, [r7, #4]
 8006360:	689b      	ldr	r3, [r3, #8]
  tmp |=  hdma->Init.Direction        |
 8006362:	431a      	orrs	r2, r3
          hdma->Init.PeriphInc           | hdma->Init.MemInc           |
 8006364:	687b      	ldr	r3, [r7, #4]
 8006366:	68db      	ldr	r3, [r3, #12]
 8006368:	431a      	orrs	r2, r3
          hdma->Init.PeriphDataAlignment | hdma->Init.MemDataAlignment |
 800636a:	687b      	ldr	r3, [r7, #4]
 800636c:	691b      	ldr	r3, [r3, #16]
          hdma->Init.PeriphInc           | hdma->Init.MemInc           |
 800636e:	431a      	orrs	r2, r3
          hdma->Init.PeriphDataAlignment | hdma->Init.MemDataAlignment |
 8006370:	687b      	ldr	r3, [r7, #4]
 8006372:	695b      	ldr	r3, [r3, #20]
 8006374:	431a      	orrs	r2, r3
          hdma->Init.Mode                | hdma->Init.Priority;
 8006376:	687b      	ldr	r3, [r7, #4]
 8006378:	699b      	ldr	r3, [r3, #24]
          hdma->Init.PeriphDataAlignment | hdma->Init.MemDataAlignment |
 800637a:	431a      	orrs	r2, r3
          hdma->Init.Mode                | hdma->Init.Priority;
 800637c:	687b      	ldr	r3, [r7, #4]
 800637e:	69db      	ldr	r3, [r3, #28]
 8006380:	4313      	orrs	r3, r2
  tmp |=  hdma->Init.Direction        |
 8006382:	68fa      	ldr	r2, [r7, #12]
 8006384:	4313      	orrs	r3, r2
 8006386:	60fb      	str	r3, [r7, #12]

  /* Write to DMA Channel CR register */
  hdma->Instance->CCR = tmp;  
 8006388:	687b      	ldr	r3, [r7, #4]
 800638a:	681b      	ldr	r3, [r3, #0]
 800638c:	68fa      	ldr	r2, [r7, #12]
 800638e:	601a      	str	r2, [r3, #0]
  
  /* Initialize DmaBaseAddress and ChannelIndex parameters used 
     by HAL_DMA_IRQHandler() and HAL_DMA_PollForTransfer() */
  DMA_CalcBaseAndBitshift(hdma);
 8006390:	687b      	ldr	r3, [r7, #4]
 8006392:	0018      	movs	r0, r3
 8006394:	f000 f998 	bl	80066c8 <DMA_CalcBaseAndBitshift>
  
  /* Initialise the error code */
  hdma->ErrorCode = HAL_DMA_ERROR_NONE;
 8006398:	687b      	ldr	r3, [r7, #4]
 800639a:	2200      	movs	r2, #0
 800639c:	639a      	str	r2, [r3, #56]	; 0x38

  /* Initialize the DMA state*/
  hdma->State = HAL_DMA_STATE_READY;
 800639e:	687b      	ldr	r3, [r7, #4]
 80063a0:	2221      	movs	r2, #33	; 0x21
 80063a2:	2101      	movs	r1, #1
 80063a4:	5499      	strb	r1, [r3, r2]
  
  /* Allocate lock resource and initialize it */
  hdma->Lock = HAL_UNLOCKED;
 80063a6:	687b      	ldr	r3, [r7, #4]
 80063a8:	2220      	movs	r2, #32
 80063aa:	2100      	movs	r1, #0
 80063ac:	5499      	strb	r1, [r3, r2]
  
  return HAL_OK;
 80063ae:	2300      	movs	r3, #0
}  
 80063b0:	0018      	movs	r0, r3
 80063b2:	46bd      	mov	sp, r7
 80063b4:	b004      	add	sp, #16
 80063b6:	bd80      	pop	{r7, pc}
 80063b8:	ffffc00f 	.word	0xffffc00f

080063bc <HAL_DMA_Start_IT>:
  * @param  DstAddress The destination memory Buffer address
  * @param  DataLength The length of data to be transferred from source to destination
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_DMA_Start_IT(DMA_HandleTypeDef *hdma, uint32_t SrcAddress, uint32_t DstAddress, uint32_t DataLength)
{
 80063bc:	b580      	push	{r7, lr}
 80063be:	b086      	sub	sp, #24
 80063c0:	af00      	add	r7, sp, #0
 80063c2:	60f8      	str	r0, [r7, #12]
 80063c4:	60b9      	str	r1, [r7, #8]
 80063c6:	607a      	str	r2, [r7, #4]
 80063c8:	603b      	str	r3, [r7, #0]
	HAL_StatusTypeDef status = HAL_OK;
 80063ca:	2317      	movs	r3, #23
 80063cc:	18fb      	adds	r3, r7, r3
 80063ce:	2200      	movs	r2, #0
 80063d0:	701a      	strb	r2, [r3, #0]

  /* Check the parameters */
  assert_param(IS_DMA_BUFFER_SIZE(DataLength));
  
  /* Process locked */
  __HAL_LOCK(hdma);
 80063d2:	68fb      	ldr	r3, [r7, #12]
 80063d4:	2220      	movs	r2, #32
 80063d6:	5c9b      	ldrb	r3, [r3, r2]
 80063d8:	2b01      	cmp	r3, #1
 80063da:	d101      	bne.n	80063e0 <HAL_DMA_Start_IT+0x24>
 80063dc:	2302      	movs	r3, #2
 80063de:	e04f      	b.n	8006480 <HAL_DMA_Start_IT+0xc4>
 80063e0:	68fb      	ldr	r3, [r7, #12]
 80063e2:	2220      	movs	r2, #32
 80063e4:	2101      	movs	r1, #1
 80063e6:	5499      	strb	r1, [r3, r2]
  
  if(HAL_DMA_STATE_READY == hdma->State)
 80063e8:	68fb      	ldr	r3, [r7, #12]
 80063ea:	2221      	movs	r2, #33	; 0x21
 80063ec:	5c9b      	ldrb	r3, [r3, r2]
 80063ee:	b2db      	uxtb	r3, r3
 80063f0:	2b01      	cmp	r3, #1
 80063f2:	d13a      	bne.n	800646a <HAL_DMA_Start_IT+0xae>
  {
  	/* Change DMA peripheral state */  
  	hdma->State = HAL_DMA_STATE_BUSY;
 80063f4:	68fb      	ldr	r3, [r7, #12]
 80063f6:	2221      	movs	r2, #33	; 0x21
 80063f8:	2102      	movs	r1, #2
 80063fa:	5499      	strb	r1, [r3, r2]
  	
  	hdma->ErrorCode = HAL_DMA_ERROR_NONE;
 80063fc:	68fb      	ldr	r3, [r7, #12]
 80063fe:	2200      	movs	r2, #0
 8006400:	639a      	str	r2, [r3, #56]	; 0x38
  	
  	/* Disable the peripheral */
  	hdma->Instance->CCR &= ~DMA_CCR_EN;
 8006402:	68fb      	ldr	r3, [r7, #12]
 8006404:	681b      	ldr	r3, [r3, #0]
 8006406:	681a      	ldr	r2, [r3, #0]
 8006408:	68fb      	ldr	r3, [r7, #12]
 800640a:	681b      	ldr	r3, [r3, #0]
 800640c:	2101      	movs	r1, #1
 800640e:	438a      	bics	r2, r1
 8006410:	601a      	str	r2, [r3, #0]
  	
  	/* Configure the source, destination address and the data length */  
  	DMA_SetConfig(hdma, SrcAddress, DstAddress, DataLength);
 8006412:	683b      	ldr	r3, [r7, #0]
 8006414:	687a      	ldr	r2, [r7, #4]
 8006416:	68b9      	ldr	r1, [r7, #8]
 8006418:	68f8      	ldr	r0, [r7, #12]
 800641a:	f000 f928 	bl	800666e <DMA_SetConfig>
  	
  	/* Enable the transfer complete, & transfer error interrupts */
  	/* Half transfer interrupt is optional: enable it only if associated callback is available */
    if(NULL != hdma->XferHalfCpltCallback )
 800641e:	68fb      	ldr	r3, [r7, #12]
 8006420:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8006422:	2b00      	cmp	r3, #0
 8006424:	d008      	beq.n	8006438 <HAL_DMA_Start_IT+0x7c>
    {
      hdma->Instance->CCR |= (DMA_IT_TC | DMA_IT_HT | DMA_IT_TE);
 8006426:	68fb      	ldr	r3, [r7, #12]
 8006428:	681b      	ldr	r3, [r3, #0]
 800642a:	681a      	ldr	r2, [r3, #0]
 800642c:	68fb      	ldr	r3, [r7, #12]
 800642e:	681b      	ldr	r3, [r3, #0]
 8006430:	210e      	movs	r1, #14
 8006432:	430a      	orrs	r2, r1
 8006434:	601a      	str	r2, [r3, #0]
 8006436:	e00f      	b.n	8006458 <HAL_DMA_Start_IT+0x9c>
    }
  	else
  	{
  		hdma->Instance->CCR |= (DMA_IT_TC | DMA_IT_TE);
 8006438:	68fb      	ldr	r3, [r7, #12]
 800643a:	681b      	ldr	r3, [r3, #0]
 800643c:	681a      	ldr	r2, [r3, #0]
 800643e:	68fb      	ldr	r3, [r7, #12]
 8006440:	681b      	ldr	r3, [r3, #0]
 8006442:	210a      	movs	r1, #10
 8006444:	430a      	orrs	r2, r1
 8006446:	601a      	str	r2, [r3, #0]
  		hdma->Instance->CCR &= ~DMA_IT_HT;
 8006448:	68fb      	ldr	r3, [r7, #12]
 800644a:	681b      	ldr	r3, [r3, #0]
 800644c:	681a      	ldr	r2, [r3, #0]
 800644e:	68fb      	ldr	r3, [r7, #12]
 8006450:	681b      	ldr	r3, [r3, #0]
 8006452:	2104      	movs	r1, #4
 8006454:	438a      	bics	r2, r1
 8006456:	601a      	str	r2, [r3, #0]
  	}
  	
  	/* Enable the Peripheral */
  	hdma->Instance->CCR |= DMA_CCR_EN;
 8006458:	68fb      	ldr	r3, [r7, #12]
 800645a:	681b      	ldr	r3, [r3, #0]
 800645c:	681a      	ldr	r2, [r3, #0]
 800645e:	68fb      	ldr	r3, [r7, #12]
 8006460:	681b      	ldr	r3, [r3, #0]
 8006462:	2101      	movs	r1, #1
 8006464:	430a      	orrs	r2, r1
 8006466:	601a      	str	r2, [r3, #0]
 8006468:	e007      	b.n	800647a <HAL_DMA_Start_IT+0xbe>
  }
  else
  {
  	/* Process Unlocked */
    __HAL_UNLOCK(hdma); 
 800646a:	68fb      	ldr	r3, [r7, #12]
 800646c:	2220      	movs	r2, #32
 800646e:	2100      	movs	r1, #0
 8006470:	5499      	strb	r1, [r3, r2]
  
    /* Remain BUSY */
    status = HAL_BUSY;
 8006472:	2317      	movs	r3, #23
 8006474:	18fb      	adds	r3, r7, r3
 8006476:	2202      	movs	r2, #2
 8006478:	701a      	strb	r2, [r3, #0]
  }     
  
  return status;    
 800647a:	2317      	movs	r3, #23
 800647c:	18fb      	adds	r3, r7, r3
 800647e:	781b      	ldrb	r3, [r3, #0]
} 
 8006480:	0018      	movs	r0, r3
 8006482:	46bd      	mov	sp, r7
 8006484:	b006      	add	sp, #24
 8006486:	bd80      	pop	{r7, pc}

08006488 <HAL_DMA_Abort_IT>:
  * @param  hdma  pointer to a DMA_HandleTypeDef structure that contains
  *               the configuration information for the specified DMA Stream.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_DMA_Abort_IT(DMA_HandleTypeDef *hdma)
{  
 8006488:	b580      	push	{r7, lr}
 800648a:	b084      	sub	sp, #16
 800648c:	af00      	add	r7, sp, #0
 800648e:	6078      	str	r0, [r7, #4]
  HAL_StatusTypeDef status = HAL_OK;
 8006490:	210f      	movs	r1, #15
 8006492:	187b      	adds	r3, r7, r1
 8006494:	2200      	movs	r2, #0
 8006496:	701a      	strb	r2, [r3, #0]
  
  if(HAL_DMA_STATE_BUSY != hdma->State)
 8006498:	687b      	ldr	r3, [r7, #4]
 800649a:	2221      	movs	r2, #33	; 0x21
 800649c:	5c9b      	ldrb	r3, [r3, r2]
 800649e:	b2db      	uxtb	r3, r3
 80064a0:	2b02      	cmp	r3, #2
 80064a2:	d006      	beq.n	80064b2 <HAL_DMA_Abort_IT+0x2a>
  {
    /* no transfer ongoing */
    hdma->ErrorCode = HAL_DMA_ERROR_NO_XFER;
 80064a4:	687b      	ldr	r3, [r7, #4]
 80064a6:	2204      	movs	r2, #4
 80064a8:	639a      	str	r2, [r3, #56]	; 0x38
        
    status = HAL_ERROR;
 80064aa:	187b      	adds	r3, r7, r1
 80064ac:	2201      	movs	r2, #1
 80064ae:	701a      	strb	r2, [r3, #0]
 80064b0:	e028      	b.n	8006504 <HAL_DMA_Abort_IT+0x7c>
  }
  else
  { 
  
    /* Disable DMA IT */
    hdma->Instance->CCR &= ~(DMA_IT_TC | DMA_IT_HT | DMA_IT_TE);
 80064b2:	687b      	ldr	r3, [r7, #4]
 80064b4:	681b      	ldr	r3, [r3, #0]
 80064b6:	681a      	ldr	r2, [r3, #0]
 80064b8:	687b      	ldr	r3, [r7, #4]
 80064ba:	681b      	ldr	r3, [r3, #0]
 80064bc:	210e      	movs	r1, #14
 80064be:	438a      	bics	r2, r1
 80064c0:	601a      	str	r2, [r3, #0]
    
    /* Disable the channel */
    hdma->Instance->CCR &= ~DMA_CCR_EN;
 80064c2:	687b      	ldr	r3, [r7, #4]
 80064c4:	681b      	ldr	r3, [r3, #0]
 80064c6:	681a      	ldr	r2, [r3, #0]
 80064c8:	687b      	ldr	r3, [r7, #4]
 80064ca:	681b      	ldr	r3, [r3, #0]
 80064cc:	2101      	movs	r1, #1
 80064ce:	438a      	bics	r2, r1
 80064d0:	601a      	str	r2, [r3, #0]
    
    /* Clear all flags */
    hdma->DmaBaseAddress->IFCR = DMA_FLAG_GL1 << hdma->ChannelIndex;
 80064d2:	687b      	ldr	r3, [r7, #4]
 80064d4:	6c1a      	ldr	r2, [r3, #64]	; 0x40
 80064d6:	687b      	ldr	r3, [r7, #4]
 80064d8:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 80064da:	2101      	movs	r1, #1
 80064dc:	4091      	lsls	r1, r2
 80064de:	000a      	movs	r2, r1
 80064e0:	605a      	str	r2, [r3, #4]
    
    /* Change the DMA state */
    hdma->State = HAL_DMA_STATE_READY;
 80064e2:	687b      	ldr	r3, [r7, #4]
 80064e4:	2221      	movs	r2, #33	; 0x21
 80064e6:	2101      	movs	r1, #1
 80064e8:	5499      	strb	r1, [r3, r2]
    
    /* Process Unlocked */
    __HAL_UNLOCK(hdma);
 80064ea:	687b      	ldr	r3, [r7, #4]
 80064ec:	2220      	movs	r2, #32
 80064ee:	2100      	movs	r1, #0
 80064f0:	5499      	strb	r1, [r3, r2]
    
    /* Call User Abort callback */ 
    if(hdma->XferAbortCallback != NULL)
 80064f2:	687b      	ldr	r3, [r7, #4]
 80064f4:	6b5b      	ldr	r3, [r3, #52]	; 0x34
 80064f6:	2b00      	cmp	r3, #0
 80064f8:	d004      	beq.n	8006504 <HAL_DMA_Abort_IT+0x7c>
    {
      hdma->XferAbortCallback(hdma);
 80064fa:	687b      	ldr	r3, [r7, #4]
 80064fc:	6b5b      	ldr	r3, [r3, #52]	; 0x34
 80064fe:	687a      	ldr	r2, [r7, #4]
 8006500:	0010      	movs	r0, r2
 8006502:	4798      	blx	r3
    } 
  }
  return status;
 8006504:	230f      	movs	r3, #15
 8006506:	18fb      	adds	r3, r7, r3
 8006508:	781b      	ldrb	r3, [r3, #0]
}
 800650a:	0018      	movs	r0, r3
 800650c:	46bd      	mov	sp, r7
 800650e:	b004      	add	sp, #16
 8006510:	bd80      	pop	{r7, pc}

08006512 <HAL_DMA_IRQHandler>:
  * @param  hdma pointer to a DMA_HandleTypeDef structure that contains
  *               the configuration information for the specified DMA Channel.  
  * @retval None
  */
void HAL_DMA_IRQHandler(DMA_HandleTypeDef *hdma)
{
 8006512:	b580      	push	{r7, lr}
 8006514:	b084      	sub	sp, #16
 8006516:	af00      	add	r7, sp, #0
 8006518:	6078      	str	r0, [r7, #4]
	uint32_t flag_it = hdma->DmaBaseAddress->ISR;
 800651a:	687b      	ldr	r3, [r7, #4]
 800651c:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 800651e:	681b      	ldr	r3, [r3, #0]
 8006520:	60fb      	str	r3, [r7, #12]
  uint32_t source_it = hdma->Instance->CCR;
 8006522:	687b      	ldr	r3, [r7, #4]
 8006524:	681b      	ldr	r3, [r3, #0]
 8006526:	681b      	ldr	r3, [r3, #0]
 8006528:	60bb      	str	r3, [r7, #8]
          
  /* Half Transfer Complete Interrupt management ******************************/
  if ((RESET != (flag_it & (DMA_FLAG_HT1 << hdma->ChannelIndex))) && (RESET != (source_it & DMA_IT_HT)))
 800652a:	687b      	ldr	r3, [r7, #4]
 800652c:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 800652e:	2204      	movs	r2, #4
 8006530:	409a      	lsls	r2, r3
 8006532:	0013      	movs	r3, r2
 8006534:	68fa      	ldr	r2, [r7, #12]
 8006536:	4013      	ands	r3, r2
 8006538:	d024      	beq.n	8006584 <HAL_DMA_IRQHandler+0x72>
 800653a:	68bb      	ldr	r3, [r7, #8]
 800653c:	2204      	movs	r2, #4
 800653e:	4013      	ands	r3, r2
 8006540:	d020      	beq.n	8006584 <HAL_DMA_IRQHandler+0x72>
  {
  	/* Disable the half transfer interrupt if the DMA mode is not CIRCULAR */
  	if((hdma->Instance->CCR & DMA_CCR_CIRC) == 0U)
 8006542:	687b      	ldr	r3, [r7, #4]
 8006544:	681b      	ldr	r3, [r3, #0]
 8006546:	681b      	ldr	r3, [r3, #0]
 8006548:	2220      	movs	r2, #32
 800654a:	4013      	ands	r3, r2
 800654c:	d107      	bne.n	800655e <HAL_DMA_IRQHandler+0x4c>
  	{
  		/* Disable the half transfer interrupt */
  		hdma->Instance->CCR &= ~DMA_IT_HT;
 800654e:	687b      	ldr	r3, [r7, #4]
 8006550:	681b      	ldr	r3, [r3, #0]
 8006552:	681a      	ldr	r2, [r3, #0]
 8006554:	687b      	ldr	r3, [r7, #4]
 8006556:	681b      	ldr	r3, [r3, #0]
 8006558:	2104      	movs	r1, #4
 800655a:	438a      	bics	r2, r1
 800655c:	601a      	str	r2, [r3, #0]
  	}
  	
  	/* Clear the half transfer complete flag */
  	hdma->DmaBaseAddress->IFCR = DMA_FLAG_HT1 << hdma->ChannelIndex;
 800655e:	687b      	ldr	r3, [r7, #4]
 8006560:	6c1a      	ldr	r2, [r3, #64]	; 0x40
 8006562:	687b      	ldr	r3, [r7, #4]
 8006564:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8006566:	2104      	movs	r1, #4
 8006568:	4091      	lsls	r1, r2
 800656a:	000a      	movs	r2, r1
 800656c:	605a      	str	r2, [r3, #4]
  	
  	/* DMA peripheral state is not updated in Half Transfer */
  	/* State is updated only in Transfer Complete case */
  	
  	if(hdma->XferHalfCpltCallback != NULL)
 800656e:	687b      	ldr	r3, [r7, #4]
 8006570:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8006572:	2b00      	cmp	r3, #0
 8006574:	d100      	bne.n	8006578 <HAL_DMA_IRQHandler+0x66>
 8006576:	e06a      	b.n	800664e <HAL_DMA_IRQHandler+0x13c>
  	{
  		/* Half transfer callback */
  		hdma->XferHalfCpltCallback(hdma);
 8006578:	687b      	ldr	r3, [r7, #4]
 800657a:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 800657c:	687a      	ldr	r2, [r7, #4]
 800657e:	0010      	movs	r0, r2
 8006580:	4798      	blx	r3
  	if(hdma->XferHalfCpltCallback != NULL)
 8006582:	e064      	b.n	800664e <HAL_DMA_IRQHandler+0x13c>
  	}
  }
  
  /* Transfer Complete Interrupt management ***********************************/
  else if ((RESET != (flag_it & (DMA_FLAG_TC1 << hdma->ChannelIndex))) && (RESET != (source_it & DMA_IT_TC)))
 8006584:	687b      	ldr	r3, [r7, #4]
 8006586:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 8006588:	2202      	movs	r2, #2
 800658a:	409a      	lsls	r2, r3
 800658c:	0013      	movs	r3, r2
 800658e:	68fa      	ldr	r2, [r7, #12]
 8006590:	4013      	ands	r3, r2
 8006592:	d02b      	beq.n	80065ec <HAL_DMA_IRQHandler+0xda>
 8006594:	68bb      	ldr	r3, [r7, #8]
 8006596:	2202      	movs	r2, #2
 8006598:	4013      	ands	r3, r2
 800659a:	d027      	beq.n	80065ec <HAL_DMA_IRQHandler+0xda>
  {
  	if((hdma->Instance->CCR & DMA_CCR_CIRC) == 0U)
 800659c:	687b      	ldr	r3, [r7, #4]
 800659e:	681b      	ldr	r3, [r3, #0]
 80065a0:	681b      	ldr	r3, [r3, #0]
 80065a2:	2220      	movs	r2, #32
 80065a4:	4013      	ands	r3, r2
 80065a6:	d10b      	bne.n	80065c0 <HAL_DMA_IRQHandler+0xae>
  	{
  		/* Disable the transfer complete  & transfer error interrupts */
  		/* if the DMA mode is not CIRCULAR */
  		hdma->Instance->CCR &= ~(DMA_IT_TC | DMA_IT_TE);
 80065a8:	687b      	ldr	r3, [r7, #4]
 80065aa:	681b      	ldr	r3, [r3, #0]
 80065ac:	681a      	ldr	r2, [r3, #0]
 80065ae:	687b      	ldr	r3, [r7, #4]
 80065b0:	681b      	ldr	r3, [r3, #0]
 80065b2:	210a      	movs	r1, #10
 80065b4:	438a      	bics	r2, r1
 80065b6:	601a      	str	r2, [r3, #0]
  		
  		/* Change the DMA state */
  		hdma->State = HAL_DMA_STATE_READY;
 80065b8:	687b      	ldr	r3, [r7, #4]
 80065ba:	2221      	movs	r2, #33	; 0x21
 80065bc:	2101      	movs	r1, #1
 80065be:	5499      	strb	r1, [r3, r2]
  	}
  	
  	/* Clear the transfer complete flag */
  	hdma->DmaBaseAddress->IFCR = DMA_FLAG_TC1 << hdma->ChannelIndex;
 80065c0:	687b      	ldr	r3, [r7, #4]
 80065c2:	6c1a      	ldr	r2, [r3, #64]	; 0x40
 80065c4:	687b      	ldr	r3, [r7, #4]
 80065c6:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 80065c8:	2102      	movs	r1, #2
 80065ca:	4091      	lsls	r1, r2
 80065cc:	000a      	movs	r2, r1
 80065ce:	605a      	str	r2, [r3, #4]
  	
  	/* Process Unlocked */
  	__HAL_UNLOCK(hdma);
 80065d0:	687b      	ldr	r3, [r7, #4]
 80065d2:	2220      	movs	r2, #32
 80065d4:	2100      	movs	r1, #0
 80065d6:	5499      	strb	r1, [r3, r2]
  	
  	if(hdma->XferCpltCallback != NULL)
 80065d8:	687b      	ldr	r3, [r7, #4]
 80065da:	6a9b      	ldr	r3, [r3, #40]	; 0x28
 80065dc:	2b00      	cmp	r3, #0
 80065de:	d036      	beq.n	800664e <HAL_DMA_IRQHandler+0x13c>
  	{
  		/* Transfer complete callback */
  		hdma->XferCpltCallback(hdma);
 80065e0:	687b      	ldr	r3, [r7, #4]
 80065e2:	6a9b      	ldr	r3, [r3, #40]	; 0x28
 80065e4:	687a      	ldr	r2, [r7, #4]
 80065e6:	0010      	movs	r0, r2
 80065e8:	4798      	blx	r3
  	if(hdma->XferCpltCallback != NULL)
 80065ea:	e030      	b.n	800664e <HAL_DMA_IRQHandler+0x13c>
  	}
  }
  
  /* Transfer Error Interrupt management ***************************************/
  else if (( RESET != (flag_it & (DMA_FLAG_TE1 << hdma->ChannelIndex))) && (RESET != (source_it & DMA_IT_TE)))
 80065ec:	687b      	ldr	r3, [r7, #4]
 80065ee:	6c1b      	ldr	r3, [r3, #64]	; 0x40
 80065f0:	2208      	movs	r2, #8
 80065f2:	409a      	lsls	r2, r3
 80065f4:	0013      	movs	r3, r2
 80065f6:	68fa      	ldr	r2, [r7, #12]
 80065f8:	4013      	ands	r3, r2
 80065fa:	d028      	beq.n	800664e <HAL_DMA_IRQHandler+0x13c>
 80065fc:	68bb      	ldr	r3, [r7, #8]
 80065fe:	2208      	movs	r2, #8
 8006600:	4013      	ands	r3, r2
 8006602:	d024      	beq.n	800664e <HAL_DMA_IRQHandler+0x13c>
  {
  	/* When a DMA transfer error occurs */
    /* A hardware clear of its EN bits is performed */
    /* Then, disable all DMA interrupts */
    hdma->Instance->CCR &= ~(DMA_IT_TC | DMA_IT_HT | DMA_IT_TE);
 8006604:	687b      	ldr	r3, [r7, #4]
 8006606:	681b      	ldr	r3, [r3, #0]
 8006608:	681a      	ldr	r2, [r3, #0]
 800660a:	687b      	ldr	r3, [r7, #4]
 800660c:	681b      	ldr	r3, [r3, #0]
 800660e:	210e      	movs	r1, #14
 8006610:	438a      	bics	r2, r1
 8006612:	601a      	str	r2, [r3, #0]
    
    /* Clear all flags */
    hdma->DmaBaseAddress->IFCR = DMA_FLAG_GL1 << hdma->ChannelIndex;
 8006614:	687b      	ldr	r3, [r7, #4]
 8006616:	6c1a      	ldr	r2, [r3, #64]	; 0x40
 8006618:	687b      	ldr	r3, [r7, #4]
 800661a:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 800661c:	2101      	movs	r1, #1
 800661e:	4091      	lsls	r1, r2
 8006620:	000a      	movs	r2, r1
 8006622:	605a      	str	r2, [r3, #4]
    
    /* Update error code */
    hdma->ErrorCode = HAL_DMA_ERROR_TE;
 8006624:	687b      	ldr	r3, [r7, #4]
 8006626:	2201      	movs	r2, #1
 8006628:	639a      	str	r2, [r3, #56]	; 0x38
    
    /* Change the DMA state */
    hdma->State = HAL_DMA_STATE_READY;    
 800662a:	687b      	ldr	r3, [r7, #4]
 800662c:	2221      	movs	r2, #33	; 0x21
 800662e:	2101      	movs	r1, #1
 8006630:	5499      	strb	r1, [r3, r2]
    
    /* Process Unlocked */
    __HAL_UNLOCK(hdma); 
 8006632:	687b      	ldr	r3, [r7, #4]
 8006634:	2220      	movs	r2, #32
 8006636:	2100      	movs	r1, #0
 8006638:	5499      	strb	r1, [r3, r2]
    
    if(hdma->XferErrorCallback != NULL)
 800663a:	687b      	ldr	r3, [r7, #4]
 800663c:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 800663e:	2b00      	cmp	r3, #0
 8006640:	d005      	beq.n	800664e <HAL_DMA_IRQHandler+0x13c>
    {
    	/* Transfer error callback */
    	hdma->XferErrorCallback(hdma);
 8006642:	687b      	ldr	r3, [r7, #4]
 8006644:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8006646:	687a      	ldr	r2, [r7, #4]
 8006648:	0010      	movs	r0, r2
 800664a:	4798      	blx	r3
    }
   }
}  
 800664c:	e7ff      	b.n	800664e <HAL_DMA_IRQHandler+0x13c>
 800664e:	46c0      	nop			; (mov r8, r8)
 8006650:	46bd      	mov	sp, r7
 8006652:	b004      	add	sp, #16
 8006654:	bd80      	pop	{r7, pc}

08006656 <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)
{
 8006656:	b580      	push	{r7, lr}
 8006658:	b082      	sub	sp, #8
 800665a:	af00      	add	r7, sp, #0
 800665c:	6078      	str	r0, [r7, #4]
  return hdma->State;
 800665e:	687b      	ldr	r3, [r7, #4]
 8006660:	2221      	movs	r2, #33	; 0x21
 8006662:	5c9b      	ldrb	r3, [r3, r2]
 8006664:	b2db      	uxtb	r3, r3
}
 8006666:	0018      	movs	r0, r3
 8006668:	46bd      	mov	sp, r7
 800666a:	b002      	add	sp, #8
 800666c:	bd80      	pop	{r7, pc}

0800666e <DMA_SetConfig>:
  * @param  DstAddress The destination memory Buffer address
  * @param  DataLength The length of data to be transferred from source to destination
  * @retval HAL status
  */
static void DMA_SetConfig(DMA_HandleTypeDef *hdma, uint32_t SrcAddress, uint32_t DstAddress, uint32_t DataLength)
{
 800666e:	b580      	push	{r7, lr}
 8006670:	b084      	sub	sp, #16
 8006672:	af00      	add	r7, sp, #0
 8006674:	60f8      	str	r0, [r7, #12]
 8006676:	60b9      	str	r1, [r7, #8]
 8006678:	607a      	str	r2, [r7, #4]
 800667a:	603b      	str	r3, [r7, #0]
	/* Clear all flags */
  hdma->DmaBaseAddress->IFCR  = (DMA_FLAG_GL1 << hdma->ChannelIndex);
 800667c:	68fb      	ldr	r3, [r7, #12]
 800667e:	6c1a      	ldr	r2, [r3, #64]	; 0x40
 8006680:	68fb      	ldr	r3, [r7, #12]
 8006682:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8006684:	2101      	movs	r1, #1
 8006686:	4091      	lsls	r1, r2
 8006688:	000a      	movs	r2, r1
 800668a:	605a      	str	r2, [r3, #4]
  
  /* Configure DMA Channel data length */
  hdma->Instance->CNDTR = DataLength;
 800668c:	68fb      	ldr	r3, [r7, #12]
 800668e:	681b      	ldr	r3, [r3, #0]
 8006690:	683a      	ldr	r2, [r7, #0]
 8006692:	605a      	str	r2, [r3, #4]
  
  /* Memory to Peripheral */
  if((hdma->Init.Direction) == DMA_MEMORY_TO_PERIPH)
 8006694:	68fb      	ldr	r3, [r7, #12]
 8006696:	685b      	ldr	r3, [r3, #4]
 8006698:	2b10      	cmp	r3, #16
 800669a:	d108      	bne.n	80066ae <DMA_SetConfig+0x40>
  {   
    /* Configure DMA Channel destination address */
    hdma->Instance->CPAR = DstAddress;
 800669c:	68fb      	ldr	r3, [r7, #12]
 800669e:	681b      	ldr	r3, [r3, #0]
 80066a0:	687a      	ldr	r2, [r7, #4]
 80066a2:	609a      	str	r2, [r3, #8]
    
    /* Configure DMA Channel source address */
    hdma->Instance->CMAR = SrcAddress;
 80066a4:	68fb      	ldr	r3, [r7, #12]
 80066a6:	681b      	ldr	r3, [r3, #0]
 80066a8:	68ba      	ldr	r2, [r7, #8]
 80066aa:	60da      	str	r2, [r3, #12]
    hdma->Instance->CPAR = SrcAddress;
    
    /* Configure DMA Channel destination address */
    hdma->Instance->CMAR = DstAddress;
  }
}
 80066ac:	e007      	b.n	80066be <DMA_SetConfig+0x50>
    hdma->Instance->CPAR = SrcAddress;
 80066ae:	68fb      	ldr	r3, [r7, #12]
 80066b0:	681b      	ldr	r3, [r3, #0]
 80066b2:	68ba      	ldr	r2, [r7, #8]
 80066b4:	609a      	str	r2, [r3, #8]
    hdma->Instance->CMAR = DstAddress;
 80066b6:	68fb      	ldr	r3, [r7, #12]
 80066b8:	681b      	ldr	r3, [r3, #0]
 80066ba:	687a      	ldr	r2, [r7, #4]
 80066bc:	60da      	str	r2, [r3, #12]
}
 80066be:	46c0      	nop			; (mov r8, r8)
 80066c0:	46bd      	mov	sp, r7
 80066c2:	b004      	add	sp, #16
 80066c4:	bd80      	pop	{r7, pc}
	...

080066c8 <DMA_CalcBaseAndBitshift>:
  * @param  hdma       pointer to a DMA_HandleTypeDef structure that contains
  *                     the configuration information for the specified DMA Stream. 
  * @retval None
  */
static void DMA_CalcBaseAndBitshift(DMA_HandleTypeDef *hdma)
{
 80066c8:	b580      	push	{r7, lr}
 80066ca:	b082      	sub	sp, #8
 80066cc:	af00      	add	r7, sp, #0
 80066ce:	6078      	str	r0, [r7, #4]
#if defined (DMA2)
  /* calculation of the channel index */
  if ((uint32_t)(hdma->Instance) < (uint32_t)(DMA2_Channel1))
 80066d0:	687b      	ldr	r3, [r7, #4]
 80066d2:	681b      	ldr	r3, [r3, #0]
 80066d4:	001a      	movs	r2, r3
 80066d6:	4b14      	ldr	r3, [pc, #80]	; (8006728 <DMA_CalcBaseAndBitshift+0x60>)
 80066d8:	429a      	cmp	r2, r3
 80066da:	d810      	bhi.n	80066fe <DMA_CalcBaseAndBitshift+0x36>
  {
    /* DMA1 */
    hdma->ChannelIndex = (((uint32_t)hdma->Instance - (uint32_t)DMA1_Channel1) / ((uint32_t)DMA1_Channel2 - (uint32_t)DMA1_Channel1)) << 2U;
 80066dc:	687b      	ldr	r3, [r7, #4]
 80066de:	681b      	ldr	r3, [r3, #0]
 80066e0:	4a12      	ldr	r2, [pc, #72]	; (800672c <DMA_CalcBaseAndBitshift+0x64>)
 80066e2:	4694      	mov	ip, r2
 80066e4:	4463      	add	r3, ip
 80066e6:	2114      	movs	r1, #20
 80066e8:	0018      	movs	r0, r3
 80066ea:	f7f9 fd0b 	bl	8000104 <__udivsi3>
 80066ee:	0003      	movs	r3, r0
 80066f0:	009a      	lsls	r2, r3, #2
 80066f2:	687b      	ldr	r3, [r7, #4]
 80066f4:	641a      	str	r2, [r3, #64]	; 0x40
    hdma->DmaBaseAddress = DMA1;
 80066f6:	687b      	ldr	r3, [r7, #4]
 80066f8:	4a0d      	ldr	r2, [pc, #52]	; (8006730 <DMA_CalcBaseAndBitshift+0x68>)
 80066fa:	63da      	str	r2, [r3, #60]	; 0x3c
  /* calculation of the channel index */
  /* DMA1 */
  hdma->ChannelIndex = (((uint32_t)hdma->Instance - (uint32_t)DMA1_Channel1) / ((uint32_t)DMA1_Channel2 - (uint32_t)DMA1_Channel1)) << 2U;
  hdma->DmaBaseAddress = DMA1;
#endif
}
 80066fc:	e00f      	b.n	800671e <DMA_CalcBaseAndBitshift+0x56>
    hdma->ChannelIndex = (((uint32_t)hdma->Instance - (uint32_t)DMA2_Channel1) / ((uint32_t)DMA2_Channel2 - (uint32_t)DMA2_Channel1)) << 2U;
 80066fe:	687b      	ldr	r3, [r7, #4]
 8006700:	681b      	ldr	r3, [r3, #0]
 8006702:	4a0c      	ldr	r2, [pc, #48]	; (8006734 <DMA_CalcBaseAndBitshift+0x6c>)
 8006704:	4694      	mov	ip, r2
 8006706:	4463      	add	r3, ip
 8006708:	2114      	movs	r1, #20
 800670a:	0018      	movs	r0, r3
 800670c:	f7f9 fcfa 	bl	8000104 <__udivsi3>
 8006710:	0003      	movs	r3, r0
 8006712:	009a      	lsls	r2, r3, #2
 8006714:	687b      	ldr	r3, [r7, #4]
 8006716:	641a      	str	r2, [r3, #64]	; 0x40
    hdma->DmaBaseAddress = DMA2;
 8006718:	687b      	ldr	r3, [r7, #4]
 800671a:	4a07      	ldr	r2, [pc, #28]	; (8006738 <DMA_CalcBaseAndBitshift+0x70>)
 800671c:	63da      	str	r2, [r3, #60]	; 0x3c
}
 800671e:	46c0      	nop			; (mov r8, r8)
 8006720:	46bd      	mov	sp, r7
 8006722:	b002      	add	sp, #8
 8006724:	bd80      	pop	{r7, pc}
 8006726:	46c0      	nop			; (mov r8, r8)
 8006728:	40020407 	.word	0x40020407
 800672c:	bffdfff8 	.word	0xbffdfff8
 8006730:	40020000 	.word	0x40020000
 8006734:	bffdfbf8 	.word	0xbffdfbf8
 8006738:	40020400 	.word	0x40020400

0800673c <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)
{
 800673c:	b580      	push	{r7, lr}
 800673e:	b086      	sub	sp, #24
 8006740:	af00      	add	r7, sp, #0
 8006742:	6078      	str	r0, [r7, #4]
 8006744:	6039      	str	r1, [r7, #0]
  uint32_t position = 0x00u;
 8006746:	2300      	movs	r3, #0
 8006748:	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)
 800674a:	e155      	b.n	80069f8 <HAL_GPIO_Init+0x2bc>
  {
    /* Get current io position */
    iocurrent = (GPIO_Init->Pin) & (1uL << position);
 800674c:	683b      	ldr	r3, [r7, #0]
 800674e:	681b      	ldr	r3, [r3, #0]
 8006750:	2101      	movs	r1, #1
 8006752:	697a      	ldr	r2, [r7, #20]
 8006754:	4091      	lsls	r1, r2
 8006756:	000a      	movs	r2, r1
 8006758:	4013      	ands	r3, r2
 800675a:	60fb      	str	r3, [r7, #12]

    if (iocurrent != 0x00u)
 800675c:	68fb      	ldr	r3, [r7, #12]
 800675e:	2b00      	cmp	r3, #0
 8006760:	d100      	bne.n	8006764 <HAL_GPIO_Init+0x28>
 8006762:	e146      	b.n	80069f2 <HAL_GPIO_Init+0x2b6>
    {
      /*--------------------- GPIO Mode Configuration ------------------------*/
      /* In case of Output or Alternate function mode selection */
      if(((GPIO_Init->Mode & GPIO_MODE) == MODE_OUTPUT) ||
 8006764:	683b      	ldr	r3, [r7, #0]
 8006766:	685b      	ldr	r3, [r3, #4]
 8006768:	2203      	movs	r2, #3
 800676a:	4013      	ands	r3, r2
 800676c:	2b01      	cmp	r3, #1
 800676e:	d005      	beq.n	800677c <HAL_GPIO_Init+0x40>
         ((GPIO_Init->Mode & GPIO_MODE) == MODE_AF))
 8006770:	683b      	ldr	r3, [r7, #0]
 8006772:	685b      	ldr	r3, [r3, #4]
 8006774:	2203      	movs	r2, #3
 8006776:	4013      	ands	r3, r2
      if(((GPIO_Init->Mode & GPIO_MODE) == MODE_OUTPUT) ||
 8006778:	2b02      	cmp	r3, #2
 800677a:	d130      	bne.n	80067de <HAL_GPIO_Init+0xa2>
      {
        /* Check the Speed parameter */
        assert_param(IS_GPIO_SPEED(GPIO_Init->Speed));
        /* Configure the IO Speed */
        temp = GPIOx->OSPEEDR;
 800677c:	687b      	ldr	r3, [r7, #4]
 800677e:	689b      	ldr	r3, [r3, #8]
 8006780:	613b      	str	r3, [r7, #16]
        temp &= ~(GPIO_OSPEEDER_OSPEEDR0 << (position * 2u));
 8006782:	697b      	ldr	r3, [r7, #20]
 8006784:	005b      	lsls	r3, r3, #1
 8006786:	2203      	movs	r2, #3
 8006788:	409a      	lsls	r2, r3
 800678a:	0013      	movs	r3, r2
 800678c:	43da      	mvns	r2, r3
 800678e:	693b      	ldr	r3, [r7, #16]
 8006790:	4013      	ands	r3, r2
 8006792:	613b      	str	r3, [r7, #16]
        temp |= (GPIO_Init->Speed << (position * 2u));
 8006794:	683b      	ldr	r3, [r7, #0]
 8006796:	68da      	ldr	r2, [r3, #12]
 8006798:	697b      	ldr	r3, [r7, #20]
 800679a:	005b      	lsls	r3, r3, #1
 800679c:	409a      	lsls	r2, r3
 800679e:	0013      	movs	r3, r2
 80067a0:	693a      	ldr	r2, [r7, #16]
 80067a2:	4313      	orrs	r3, r2
 80067a4:	613b      	str	r3, [r7, #16]
        GPIOx->OSPEEDR = temp;
 80067a6:	687b      	ldr	r3, [r7, #4]
 80067a8:	693a      	ldr	r2, [r7, #16]
 80067aa:	609a      	str	r2, [r3, #8]

        /* Configure the IO Output Type */
        temp = GPIOx->OTYPER;
 80067ac:	687b      	ldr	r3, [r7, #4]
 80067ae:	685b      	ldr	r3, [r3, #4]
 80067b0:	613b      	str	r3, [r7, #16]
        temp &= ~(GPIO_OTYPER_OT_0 << position) ;
 80067b2:	2201      	movs	r2, #1
 80067b4:	697b      	ldr	r3, [r7, #20]
 80067b6:	409a      	lsls	r2, r3
 80067b8:	0013      	movs	r3, r2
 80067ba:	43da      	mvns	r2, r3
 80067bc:	693b      	ldr	r3, [r7, #16]
 80067be:	4013      	ands	r3, r2
 80067c0:	613b      	str	r3, [r7, #16]
        temp |= (((GPIO_Init->Mode & OUTPUT_TYPE) >> OUTPUT_TYPE_Pos) << position);
 80067c2:	683b      	ldr	r3, [r7, #0]
 80067c4:	685b      	ldr	r3, [r3, #4]
 80067c6:	091b      	lsrs	r3, r3, #4
 80067c8:	2201      	movs	r2, #1
 80067ca:	401a      	ands	r2, r3
 80067cc:	697b      	ldr	r3, [r7, #20]
 80067ce:	409a      	lsls	r2, r3
 80067d0:	0013      	movs	r3, r2
 80067d2:	693a      	ldr	r2, [r7, #16]
 80067d4:	4313      	orrs	r3, r2
 80067d6:	613b      	str	r3, [r7, #16]
        GPIOx->OTYPER = temp;
 80067d8:	687b      	ldr	r3, [r7, #4]
 80067da:	693a      	ldr	r2, [r7, #16]
 80067dc:	605a      	str	r2, [r3, #4]
      }
      
      if((GPIO_Init->Mode & GPIO_MODE) != MODE_ANALOG)
 80067de:	683b      	ldr	r3, [r7, #0]
 80067e0:	685b      	ldr	r3, [r3, #4]
 80067e2:	2203      	movs	r2, #3
 80067e4:	4013      	ands	r3, r2
 80067e6:	2b03      	cmp	r3, #3
 80067e8:	d017      	beq.n	800681a <HAL_GPIO_Init+0xde>
      {
        /* Check the Pull parameter */
        assert_param(IS_GPIO_PULL(GPIO_Init->Pull));

        /* Activate the Pull-up or Pull down resistor for the current IO */
        temp = GPIOx->PUPDR;
 80067ea:	687b      	ldr	r3, [r7, #4]
 80067ec:	68db      	ldr	r3, [r3, #12]
 80067ee:	613b      	str	r3, [r7, #16]
        temp &= ~(GPIO_PUPDR_PUPDR0 << (position * 2u));
 80067f0:	697b      	ldr	r3, [r7, #20]
 80067f2:	005b      	lsls	r3, r3, #1
 80067f4:	2203      	movs	r2, #3
 80067f6:	409a      	lsls	r2, r3
 80067f8:	0013      	movs	r3, r2
 80067fa:	43da      	mvns	r2, r3
 80067fc:	693b      	ldr	r3, [r7, #16]
 80067fe:	4013      	ands	r3, r2
 8006800:	613b      	str	r3, [r7, #16]
        temp |= ((GPIO_Init->Pull) << (position * 2u));
 8006802:	683b      	ldr	r3, [r7, #0]
 8006804:	689a      	ldr	r2, [r3, #8]
 8006806:	697b      	ldr	r3, [r7, #20]
 8006808:	005b      	lsls	r3, r3, #1
 800680a:	409a      	lsls	r2, r3
 800680c:	0013      	movs	r3, r2
 800680e:	693a      	ldr	r2, [r7, #16]
 8006810:	4313      	orrs	r3, r2
 8006812:	613b      	str	r3, [r7, #16]
        GPIOx->PUPDR = temp;
 8006814:	687b      	ldr	r3, [r7, #4]
 8006816:	693a      	ldr	r2, [r7, #16]
 8006818:	60da      	str	r2, [r3, #12]
      }

      /* In case of Alternate function mode selection */
      if((GPIO_Init->Mode & GPIO_MODE) == MODE_AF)
 800681a:	683b      	ldr	r3, [r7, #0]
 800681c:	685b      	ldr	r3, [r3, #4]
 800681e:	2203      	movs	r2, #3
 8006820:	4013      	ands	r3, r2
 8006822:	2b02      	cmp	r3, #2
 8006824:	d123      	bne.n	800686e <HAL_GPIO_Init+0x132>
        /* 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];
 8006826:	697b      	ldr	r3, [r7, #20]
 8006828:	08da      	lsrs	r2, r3, #3
 800682a:	687b      	ldr	r3, [r7, #4]
 800682c:	3208      	adds	r2, #8
 800682e:	0092      	lsls	r2, r2, #2
 8006830:	58d3      	ldr	r3, [r2, r3]
 8006832:	613b      	str	r3, [r7, #16]
        temp &= ~(0xFu << ((position & 0x07u) * 4u));
 8006834:	697b      	ldr	r3, [r7, #20]
 8006836:	2207      	movs	r2, #7
 8006838:	4013      	ands	r3, r2
 800683a:	009b      	lsls	r3, r3, #2
 800683c:	220f      	movs	r2, #15
 800683e:	409a      	lsls	r2, r3
 8006840:	0013      	movs	r3, r2
 8006842:	43da      	mvns	r2, r3
 8006844:	693b      	ldr	r3, [r7, #16]
 8006846:	4013      	ands	r3, r2
 8006848:	613b      	str	r3, [r7, #16]
        temp |= ((GPIO_Init->Alternate) << ((position & 0x07u) * 4u));
 800684a:	683b      	ldr	r3, [r7, #0]
 800684c:	691a      	ldr	r2, [r3, #16]
 800684e:	697b      	ldr	r3, [r7, #20]
 8006850:	2107      	movs	r1, #7
 8006852:	400b      	ands	r3, r1
 8006854:	009b      	lsls	r3, r3, #2
 8006856:	409a      	lsls	r2, r3
 8006858:	0013      	movs	r3, r2
 800685a:	693a      	ldr	r2, [r7, #16]
 800685c:	4313      	orrs	r3, r2
 800685e:	613b      	str	r3, [r7, #16]
        GPIOx->AFR[position >> 3u] = temp;
 8006860:	697b      	ldr	r3, [r7, #20]
 8006862:	08da      	lsrs	r2, r3, #3
 8006864:	687b      	ldr	r3, [r7, #4]
 8006866:	3208      	adds	r2, #8
 8006868:	0092      	lsls	r2, r2, #2
 800686a:	6939      	ldr	r1, [r7, #16]
 800686c:	50d1      	str	r1, [r2, r3]
      }

      /* Configure IO Direction mode (Input, Output, Alternate or Analog) */
      temp = GPIOx->MODER;
 800686e:	687b      	ldr	r3, [r7, #4]
 8006870:	681b      	ldr	r3, [r3, #0]
 8006872:	613b      	str	r3, [r7, #16]
      temp &= ~(GPIO_MODER_MODER0 << (position * 2u));
 8006874:	697b      	ldr	r3, [r7, #20]
 8006876:	005b      	lsls	r3, r3, #1
 8006878:	2203      	movs	r2, #3
 800687a:	409a      	lsls	r2, r3
 800687c:	0013      	movs	r3, r2
 800687e:	43da      	mvns	r2, r3
 8006880:	693b      	ldr	r3, [r7, #16]
 8006882:	4013      	ands	r3, r2
 8006884:	613b      	str	r3, [r7, #16]
      temp |= ((GPIO_Init->Mode & GPIO_MODE) << (position * 2u));
 8006886:	683b      	ldr	r3, [r7, #0]
 8006888:	685b      	ldr	r3, [r3, #4]
 800688a:	2203      	movs	r2, #3
 800688c:	401a      	ands	r2, r3
 800688e:	697b      	ldr	r3, [r7, #20]
 8006890:	005b      	lsls	r3, r3, #1
 8006892:	409a      	lsls	r2, r3
 8006894:	0013      	movs	r3, r2
 8006896:	693a      	ldr	r2, [r7, #16]
 8006898:	4313      	orrs	r3, r2
 800689a:	613b      	str	r3, [r7, #16]
      GPIOx->MODER = temp;
 800689c:	687b      	ldr	r3, [r7, #4]
 800689e:	693a      	ldr	r2, [r7, #16]
 80068a0:	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)
 80068a2:	683b      	ldr	r3, [r7, #0]
 80068a4:	685a      	ldr	r2, [r3, #4]
 80068a6:	23c0      	movs	r3, #192	; 0xc0
 80068a8:	029b      	lsls	r3, r3, #10
 80068aa:	4013      	ands	r3, r2
 80068ac:	d100      	bne.n	80068b0 <HAL_GPIO_Init+0x174>
 80068ae:	e0a0      	b.n	80069f2 <HAL_GPIO_Init+0x2b6>
      {
        /* Enable SYSCFG Clock */
        __HAL_RCC_SYSCFG_CLK_ENABLE();
 80068b0:	4b57      	ldr	r3, [pc, #348]	; (8006a10 <HAL_GPIO_Init+0x2d4>)
 80068b2:	699a      	ldr	r2, [r3, #24]
 80068b4:	4b56      	ldr	r3, [pc, #344]	; (8006a10 <HAL_GPIO_Init+0x2d4>)
 80068b6:	2101      	movs	r1, #1
 80068b8:	430a      	orrs	r2, r1
 80068ba:	619a      	str	r2, [r3, #24]
 80068bc:	4b54      	ldr	r3, [pc, #336]	; (8006a10 <HAL_GPIO_Init+0x2d4>)
 80068be:	699b      	ldr	r3, [r3, #24]
 80068c0:	2201      	movs	r2, #1
 80068c2:	4013      	ands	r3, r2
 80068c4:	60bb      	str	r3, [r7, #8]
 80068c6:	68bb      	ldr	r3, [r7, #8]

        temp = SYSCFG->EXTICR[position >> 2u];
 80068c8:	4a52      	ldr	r2, [pc, #328]	; (8006a14 <HAL_GPIO_Init+0x2d8>)
 80068ca:	697b      	ldr	r3, [r7, #20]
 80068cc:	089b      	lsrs	r3, r3, #2
 80068ce:	3302      	adds	r3, #2
 80068d0:	009b      	lsls	r3, r3, #2
 80068d2:	589b      	ldr	r3, [r3, r2]
 80068d4:	613b      	str	r3, [r7, #16]
        temp &= ~(0x0FuL << (4u * (position & 0x03u)));
 80068d6:	697b      	ldr	r3, [r7, #20]
 80068d8:	2203      	movs	r2, #3
 80068da:	4013      	ands	r3, r2
 80068dc:	009b      	lsls	r3, r3, #2
 80068de:	220f      	movs	r2, #15
 80068e0:	409a      	lsls	r2, r3
 80068e2:	0013      	movs	r3, r2
 80068e4:	43da      	mvns	r2, r3
 80068e6:	693b      	ldr	r3, [r7, #16]
 80068e8:	4013      	ands	r3, r2
 80068ea:	613b      	str	r3, [r7, #16]
        temp |= (GPIO_GET_INDEX(GPIOx) << (4u * (position & 0x03u)));
 80068ec:	687a      	ldr	r2, [r7, #4]
 80068ee:	2390      	movs	r3, #144	; 0x90
 80068f0:	05db      	lsls	r3, r3, #23
 80068f2:	429a      	cmp	r2, r3
 80068f4:	d019      	beq.n	800692a <HAL_GPIO_Init+0x1ee>
 80068f6:	687b      	ldr	r3, [r7, #4]
 80068f8:	4a47      	ldr	r2, [pc, #284]	; (8006a18 <HAL_GPIO_Init+0x2dc>)
 80068fa:	4293      	cmp	r3, r2
 80068fc:	d013      	beq.n	8006926 <HAL_GPIO_Init+0x1ea>
 80068fe:	687b      	ldr	r3, [r7, #4]
 8006900:	4a46      	ldr	r2, [pc, #280]	; (8006a1c <HAL_GPIO_Init+0x2e0>)
 8006902:	4293      	cmp	r3, r2
 8006904:	d00d      	beq.n	8006922 <HAL_GPIO_Init+0x1e6>
 8006906:	687b      	ldr	r3, [r7, #4]
 8006908:	4a45      	ldr	r2, [pc, #276]	; (8006a20 <HAL_GPIO_Init+0x2e4>)
 800690a:	4293      	cmp	r3, r2
 800690c:	d007      	beq.n	800691e <HAL_GPIO_Init+0x1e2>
 800690e:	687b      	ldr	r3, [r7, #4]
 8006910:	4a44      	ldr	r2, [pc, #272]	; (8006a24 <HAL_GPIO_Init+0x2e8>)
 8006912:	4293      	cmp	r3, r2
 8006914:	d101      	bne.n	800691a <HAL_GPIO_Init+0x1de>
 8006916:	2304      	movs	r3, #4
 8006918:	e008      	b.n	800692c <HAL_GPIO_Init+0x1f0>
 800691a:	2305      	movs	r3, #5
 800691c:	e006      	b.n	800692c <HAL_GPIO_Init+0x1f0>
 800691e:	2303      	movs	r3, #3
 8006920:	e004      	b.n	800692c <HAL_GPIO_Init+0x1f0>
 8006922:	2302      	movs	r3, #2
 8006924:	e002      	b.n	800692c <HAL_GPIO_Init+0x1f0>
 8006926:	2301      	movs	r3, #1
 8006928:	e000      	b.n	800692c <HAL_GPIO_Init+0x1f0>
 800692a:	2300      	movs	r3, #0
 800692c:	697a      	ldr	r2, [r7, #20]
 800692e:	2103      	movs	r1, #3
 8006930:	400a      	ands	r2, r1
 8006932:	0092      	lsls	r2, r2, #2
 8006934:	4093      	lsls	r3, r2
 8006936:	693a      	ldr	r2, [r7, #16]
 8006938:	4313      	orrs	r3, r2
 800693a:	613b      	str	r3, [r7, #16]
        SYSCFG->EXTICR[position >> 2u] = temp;
 800693c:	4935      	ldr	r1, [pc, #212]	; (8006a14 <HAL_GPIO_Init+0x2d8>)
 800693e:	697b      	ldr	r3, [r7, #20]
 8006940:	089b      	lsrs	r3, r3, #2
 8006942:	3302      	adds	r3, #2
 8006944:	009b      	lsls	r3, r3, #2
 8006946:	693a      	ldr	r2, [r7, #16]
 8006948:	505a      	str	r2, [r3, r1]

        /* Clear EXTI line configuration */
        temp = EXTI->IMR;
 800694a:	4b37      	ldr	r3, [pc, #220]	; (8006a28 <HAL_GPIO_Init+0x2ec>)
 800694c:	681b      	ldr	r3, [r3, #0]
 800694e:	613b      	str	r3, [r7, #16]
        temp &= ~(iocurrent);
 8006950:	68fb      	ldr	r3, [r7, #12]
 8006952:	43da      	mvns	r2, r3
 8006954:	693b      	ldr	r3, [r7, #16]
 8006956:	4013      	ands	r3, r2
 8006958:	613b      	str	r3, [r7, #16]
        if((GPIO_Init->Mode & EXTI_IT) != 0x00u)
 800695a:	683b      	ldr	r3, [r7, #0]
 800695c:	685a      	ldr	r2, [r3, #4]
 800695e:	2380      	movs	r3, #128	; 0x80
 8006960:	025b      	lsls	r3, r3, #9
 8006962:	4013      	ands	r3, r2
 8006964:	d003      	beq.n	800696e <HAL_GPIO_Init+0x232>
        {
          temp |= iocurrent;
 8006966:	693a      	ldr	r2, [r7, #16]
 8006968:	68fb      	ldr	r3, [r7, #12]
 800696a:	4313      	orrs	r3, r2
 800696c:	613b      	str	r3, [r7, #16]
        }
        EXTI->IMR = temp;
 800696e:	4b2e      	ldr	r3, [pc, #184]	; (8006a28 <HAL_GPIO_Init+0x2ec>)
 8006970:	693a      	ldr	r2, [r7, #16]
 8006972:	601a      	str	r2, [r3, #0]

        temp = EXTI->EMR;
 8006974:	4b2c      	ldr	r3, [pc, #176]	; (8006a28 <HAL_GPIO_Init+0x2ec>)
 8006976:	685b      	ldr	r3, [r3, #4]
 8006978:	613b      	str	r3, [r7, #16]
        temp &= ~(iocurrent);
 800697a:	68fb      	ldr	r3, [r7, #12]
 800697c:	43da      	mvns	r2, r3
 800697e:	693b      	ldr	r3, [r7, #16]
 8006980:	4013      	ands	r3, r2
 8006982:	613b      	str	r3, [r7, #16]
        if((GPIO_Init->Mode & EXTI_EVT) != 0x00u)
 8006984:	683b      	ldr	r3, [r7, #0]
 8006986:	685a      	ldr	r2, [r3, #4]
 8006988:	2380      	movs	r3, #128	; 0x80
 800698a:	029b      	lsls	r3, r3, #10
 800698c:	4013      	ands	r3, r2
 800698e:	d003      	beq.n	8006998 <HAL_GPIO_Init+0x25c>
        {
          temp |= iocurrent;
 8006990:	693a      	ldr	r2, [r7, #16]
 8006992:	68fb      	ldr	r3, [r7, #12]
 8006994:	4313      	orrs	r3, r2
 8006996:	613b      	str	r3, [r7, #16]
        }
        EXTI->EMR = temp;
 8006998:	4b23      	ldr	r3, [pc, #140]	; (8006a28 <HAL_GPIO_Init+0x2ec>)
 800699a:	693a      	ldr	r2, [r7, #16]
 800699c:	605a      	str	r2, [r3, #4]

        /* Clear Rising Falling edge configuration */
        temp = EXTI->RTSR;
 800699e:	4b22      	ldr	r3, [pc, #136]	; (8006a28 <HAL_GPIO_Init+0x2ec>)
 80069a0:	689b      	ldr	r3, [r3, #8]
 80069a2:	613b      	str	r3, [r7, #16]
        temp &= ~(iocurrent);
 80069a4:	68fb      	ldr	r3, [r7, #12]
 80069a6:	43da      	mvns	r2, r3
 80069a8:	693b      	ldr	r3, [r7, #16]
 80069aa:	4013      	ands	r3, r2
 80069ac:	613b      	str	r3, [r7, #16]
        if((GPIO_Init->Mode & TRIGGER_RISING) != 0x00u)
 80069ae:	683b      	ldr	r3, [r7, #0]
 80069b0:	685a      	ldr	r2, [r3, #4]
 80069b2:	2380      	movs	r3, #128	; 0x80
 80069b4:	035b      	lsls	r3, r3, #13
 80069b6:	4013      	ands	r3, r2
 80069b8:	d003      	beq.n	80069c2 <HAL_GPIO_Init+0x286>
        {
          temp |= iocurrent;
 80069ba:	693a      	ldr	r2, [r7, #16]
 80069bc:	68fb      	ldr	r3, [r7, #12]
 80069be:	4313      	orrs	r3, r2
 80069c0:	613b      	str	r3, [r7, #16]
        }
        EXTI->RTSR = temp;
 80069c2:	4b19      	ldr	r3, [pc, #100]	; (8006a28 <HAL_GPIO_Init+0x2ec>)
 80069c4:	693a      	ldr	r2, [r7, #16]
 80069c6:	609a      	str	r2, [r3, #8]

        temp = EXTI->FTSR;
 80069c8:	4b17      	ldr	r3, [pc, #92]	; (8006a28 <HAL_GPIO_Init+0x2ec>)
 80069ca:	68db      	ldr	r3, [r3, #12]
 80069cc:	613b      	str	r3, [r7, #16]
        temp &= ~(iocurrent);
 80069ce:	68fb      	ldr	r3, [r7, #12]
 80069d0:	43da      	mvns	r2, r3
 80069d2:	693b      	ldr	r3, [r7, #16]
 80069d4:	4013      	ands	r3, r2
 80069d6:	613b      	str	r3, [r7, #16]
        if((GPIO_Init->Mode & TRIGGER_FALLING) != 0x00u)
 80069d8:	683b      	ldr	r3, [r7, #0]
 80069da:	685a      	ldr	r2, [r3, #4]
 80069dc:	2380      	movs	r3, #128	; 0x80
 80069de:	039b      	lsls	r3, r3, #14
 80069e0:	4013      	ands	r3, r2
 80069e2:	d003      	beq.n	80069ec <HAL_GPIO_Init+0x2b0>
        {
          temp |= iocurrent;
 80069e4:	693a      	ldr	r2, [r7, #16]
 80069e6:	68fb      	ldr	r3, [r7, #12]
 80069e8:	4313      	orrs	r3, r2
 80069ea:	613b      	str	r3, [r7, #16]
        }
        EXTI->FTSR = temp;
 80069ec:	4b0e      	ldr	r3, [pc, #56]	; (8006a28 <HAL_GPIO_Init+0x2ec>)
 80069ee:	693a      	ldr	r2, [r7, #16]
 80069f0:	60da      	str	r2, [r3, #12]
      }
    }

    position++;
 80069f2:	697b      	ldr	r3, [r7, #20]
 80069f4:	3301      	adds	r3, #1
 80069f6:	617b      	str	r3, [r7, #20]
  while (((GPIO_Init->Pin) >> position) != 0x00u)
 80069f8:	683b      	ldr	r3, [r7, #0]
 80069fa:	681a      	ldr	r2, [r3, #0]
 80069fc:	697b      	ldr	r3, [r7, #20]
 80069fe:	40da      	lsrs	r2, r3
 8006a00:	1e13      	subs	r3, r2, #0
 8006a02:	d000      	beq.n	8006a06 <HAL_GPIO_Init+0x2ca>
 8006a04:	e6a2      	b.n	800674c <HAL_GPIO_Init+0x10>
  } 
}
 8006a06:	46c0      	nop			; (mov r8, r8)
 8006a08:	46c0      	nop			; (mov r8, r8)
 8006a0a:	46bd      	mov	sp, r7
 8006a0c:	b006      	add	sp, #24
 8006a0e:	bd80      	pop	{r7, pc}
 8006a10:	40021000 	.word	0x40021000
 8006a14:	40010000 	.word	0x40010000
 8006a18:	48000400 	.word	0x48000400
 8006a1c:	48000800 	.word	0x48000800
 8006a20:	48000c00 	.word	0x48000c00
 8006a24:	48001000 	.word	0x48001000
 8006a28:	40010400 	.word	0x40010400

08006a2c <HAL_GPIO_ReadPin>:
  * @param  GPIO_Pin specifies the port bit to read.
  *         This parameter can be GPIO_PIN_x where x can be (0..15).
  * @retval The input port pin value.
  */
GPIO_PinState HAL_GPIO_ReadPin(GPIO_TypeDef* GPIOx, uint16_t GPIO_Pin)
{
 8006a2c:	b580      	push	{r7, lr}
 8006a2e:	b084      	sub	sp, #16
 8006a30:	af00      	add	r7, sp, #0
 8006a32:	6078      	str	r0, [r7, #4]
 8006a34:	000a      	movs	r2, r1
 8006a36:	1cbb      	adds	r3, r7, #2
 8006a38:	801a      	strh	r2, [r3, #0]
  GPIO_PinState bitstatus;

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

  if ((GPIOx->IDR & GPIO_Pin) != (uint32_t)GPIO_PIN_RESET)
 8006a3a:	687b      	ldr	r3, [r7, #4]
 8006a3c:	691b      	ldr	r3, [r3, #16]
 8006a3e:	1cba      	adds	r2, r7, #2
 8006a40:	8812      	ldrh	r2, [r2, #0]
 8006a42:	4013      	ands	r3, r2
 8006a44:	d004      	beq.n	8006a50 <HAL_GPIO_ReadPin+0x24>
  {
    bitstatus = GPIO_PIN_SET;
 8006a46:	230f      	movs	r3, #15
 8006a48:	18fb      	adds	r3, r7, r3
 8006a4a:	2201      	movs	r2, #1
 8006a4c:	701a      	strb	r2, [r3, #0]
 8006a4e:	e003      	b.n	8006a58 <HAL_GPIO_ReadPin+0x2c>
  }
  else
  {
    bitstatus = GPIO_PIN_RESET;
 8006a50:	230f      	movs	r3, #15
 8006a52:	18fb      	adds	r3, r7, r3
 8006a54:	2200      	movs	r2, #0
 8006a56:	701a      	strb	r2, [r3, #0]
  }
  return bitstatus;
 8006a58:	230f      	movs	r3, #15
 8006a5a:	18fb      	adds	r3, r7, r3
 8006a5c:	781b      	ldrb	r3, [r3, #0]
  }
 8006a5e:	0018      	movs	r0, r3
 8006a60:	46bd      	mov	sp, r7
 8006a62:	b004      	add	sp, #16
 8006a64:	bd80      	pop	{r7, pc}

08006a66 <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)
{
 8006a66:	b580      	push	{r7, lr}
 8006a68:	b082      	sub	sp, #8
 8006a6a:	af00      	add	r7, sp, #0
 8006a6c:	6078      	str	r0, [r7, #4]
 8006a6e:	0008      	movs	r0, r1
 8006a70:	0011      	movs	r1, r2
 8006a72:	1cbb      	adds	r3, r7, #2
 8006a74:	1c02      	adds	r2, r0, #0
 8006a76:	801a      	strh	r2, [r3, #0]
 8006a78:	1c7b      	adds	r3, r7, #1
 8006a7a:	1c0a      	adds	r2, r1, #0
 8006a7c:	701a      	strb	r2, [r3, #0]
  /* Check the parameters */
  assert_param(IS_GPIO_PIN(GPIO_Pin));
  assert_param(IS_GPIO_PIN_ACTION(PinState));

  if (PinState != GPIO_PIN_RESET)
 8006a7e:	1c7b      	adds	r3, r7, #1
 8006a80:	781b      	ldrb	r3, [r3, #0]
 8006a82:	2b00      	cmp	r3, #0
 8006a84:	d004      	beq.n	8006a90 <HAL_GPIO_WritePin+0x2a>
  {
    GPIOx->BSRR = (uint32_t)GPIO_Pin;
 8006a86:	1cbb      	adds	r3, r7, #2
 8006a88:	881a      	ldrh	r2, [r3, #0]
 8006a8a:	687b      	ldr	r3, [r7, #4]
 8006a8c:	619a      	str	r2, [r3, #24]
  }
  else
  {
    GPIOx->BRR = (uint32_t)GPIO_Pin;
  }
}
 8006a8e:	e003      	b.n	8006a98 <HAL_GPIO_WritePin+0x32>
    GPIOx->BRR = (uint32_t)GPIO_Pin;
 8006a90:	1cbb      	adds	r3, r7, #2
 8006a92:	881a      	ldrh	r2, [r3, #0]
 8006a94:	687b      	ldr	r3, [r7, #4]
 8006a96:	629a      	str	r2, [r3, #40]	; 0x28
}
 8006a98:	46c0      	nop			; (mov r8, r8)
 8006a9a:	46bd      	mov	sp, r7
 8006a9c:	b002      	add	sp, #8
 8006a9e:	bd80      	pop	{r7, pc}

08006aa0 <HAL_GPIO_EXTI_IRQHandler>:
  * @brief  Handle EXTI interrupt request.
  * @param  GPIO_Pin Specifies the port pin connected to corresponding EXTI line.
  * @retval None
  */
void HAL_GPIO_EXTI_IRQHandler(uint16_t GPIO_Pin)
{
 8006aa0:	b580      	push	{r7, lr}
 8006aa2:	b082      	sub	sp, #8
 8006aa4:	af00      	add	r7, sp, #0
 8006aa6:	0002      	movs	r2, r0
 8006aa8:	1dbb      	adds	r3, r7, #6
 8006aaa:	801a      	strh	r2, [r3, #0]
  /* EXTI line interrupt detected */
  if(__HAL_GPIO_EXTI_GET_IT(GPIO_Pin) != 0x00u)
 8006aac:	4b09      	ldr	r3, [pc, #36]	; (8006ad4 <HAL_GPIO_EXTI_IRQHandler+0x34>)
 8006aae:	695b      	ldr	r3, [r3, #20]
 8006ab0:	1dba      	adds	r2, r7, #6
 8006ab2:	8812      	ldrh	r2, [r2, #0]
 8006ab4:	4013      	ands	r3, r2
 8006ab6:	d008      	beq.n	8006aca <HAL_GPIO_EXTI_IRQHandler+0x2a>
  { 
    __HAL_GPIO_EXTI_CLEAR_IT(GPIO_Pin);
 8006ab8:	4b06      	ldr	r3, [pc, #24]	; (8006ad4 <HAL_GPIO_EXTI_IRQHandler+0x34>)
 8006aba:	1dba      	adds	r2, r7, #6
 8006abc:	8812      	ldrh	r2, [r2, #0]
 8006abe:	615a      	str	r2, [r3, #20]
    HAL_GPIO_EXTI_Callback(GPIO_Pin);
 8006ac0:	1dbb      	adds	r3, r7, #6
 8006ac2:	881b      	ldrh	r3, [r3, #0]
 8006ac4:	0018      	movs	r0, r3
 8006ac6:	f7fd fdc1 	bl	800464c <HAL_GPIO_EXTI_Callback>
  }
}
 8006aca:	46c0      	nop			; (mov r8, r8)
 8006acc:	46bd      	mov	sp, r7
 8006ace:	b002      	add	sp, #8
 8006ad0:	bd80      	pop	{r7, pc}
 8006ad2:	46c0      	nop			; (mov r8, r8)
 8006ad4:	40010400 	.word	0x40010400

08006ad8 <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)
{
 8006ad8:	b580      	push	{r7, lr}
 8006ada:	b082      	sub	sp, #8
 8006adc:	af00      	add	r7, sp, #0
 8006ade:	6078      	str	r0, [r7, #4]
  /* Check the I2C handle allocation */
  if (hi2c == NULL)
 8006ae0:	687b      	ldr	r3, [r7, #4]
 8006ae2:	2b00      	cmp	r3, #0
 8006ae4:	d101      	bne.n	8006aea <HAL_I2C_Init+0x12>
  {
    return HAL_ERROR;
 8006ae6:	2301      	movs	r3, #1
 8006ae8:	e082      	b.n	8006bf0 <HAL_I2C_Init+0x118>
  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)
 8006aea:	687b      	ldr	r3, [r7, #4]
 8006aec:	2241      	movs	r2, #65	; 0x41
 8006aee:	5c9b      	ldrb	r3, [r3, r2]
 8006af0:	b2db      	uxtb	r3, r3
 8006af2:	2b00      	cmp	r3, #0
 8006af4:	d107      	bne.n	8006b06 <HAL_I2C_Init+0x2e>
  {
    /* Allocate lock resource and initialize it */
    hi2c->Lock = HAL_UNLOCKED;
 8006af6:	687b      	ldr	r3, [r7, #4]
 8006af8:	2240      	movs	r2, #64	; 0x40
 8006afa:	2100      	movs	r1, #0
 8006afc:	5499      	strb	r1, [r3, r2]

    /* 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);
 8006afe:	687b      	ldr	r3, [r7, #4]
 8006b00:	0018      	movs	r0, r3
 8006b02:	f7fe fcb1 	bl	8005468 <HAL_I2C_MspInit>
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
  }

  hi2c->State = HAL_I2C_STATE_BUSY;
 8006b06:	687b      	ldr	r3, [r7, #4]
 8006b08:	2241      	movs	r2, #65	; 0x41
 8006b0a:	2124      	movs	r1, #36	; 0x24
 8006b0c:	5499      	strb	r1, [r3, r2]

  /* Disable the selected I2C peripheral */
  __HAL_I2C_DISABLE(hi2c);
 8006b0e:	687b      	ldr	r3, [r7, #4]
 8006b10:	681b      	ldr	r3, [r3, #0]
 8006b12:	681a      	ldr	r2, [r3, #0]
 8006b14:	687b      	ldr	r3, [r7, #4]
 8006b16:	681b      	ldr	r3, [r3, #0]
 8006b18:	2101      	movs	r1, #1
 8006b1a:	438a      	bics	r2, r1
 8006b1c:	601a      	str	r2, [r3, #0]

  /*---------------------------- I2Cx TIMINGR Configuration ------------------*/
  /* Configure I2Cx: Frequency range */
  hi2c->Instance->TIMINGR = hi2c->Init.Timing & TIMING_CLEAR_MASK;
 8006b1e:	687b      	ldr	r3, [r7, #4]
 8006b20:	685a      	ldr	r2, [r3, #4]
 8006b22:	687b      	ldr	r3, [r7, #4]
 8006b24:	681b      	ldr	r3, [r3, #0]
 8006b26:	4934      	ldr	r1, [pc, #208]	; (8006bf8 <HAL_I2C_Init+0x120>)
 8006b28:	400a      	ands	r2, r1
 8006b2a:	611a      	str	r2, [r3, #16]

  /*---------------------------- I2Cx OAR1 Configuration ---------------------*/
  /* Disable Own Address1 before set the Own Address1 configuration */
  hi2c->Instance->OAR1 &= ~I2C_OAR1_OA1EN;
 8006b2c:	687b      	ldr	r3, [r7, #4]
 8006b2e:	681b      	ldr	r3, [r3, #0]
 8006b30:	689a      	ldr	r2, [r3, #8]
 8006b32:	687b      	ldr	r3, [r7, #4]
 8006b34:	681b      	ldr	r3, [r3, #0]
 8006b36:	4931      	ldr	r1, [pc, #196]	; (8006bfc <HAL_I2C_Init+0x124>)
 8006b38:	400a      	ands	r2, r1
 8006b3a:	609a      	str	r2, [r3, #8]

  /* Configure I2Cx: Own Address1 and ack own address1 mode */
  if (hi2c->Init.AddressingMode == I2C_ADDRESSINGMODE_7BIT)
 8006b3c:	687b      	ldr	r3, [r7, #4]
 8006b3e:	68db      	ldr	r3, [r3, #12]
 8006b40:	2b01      	cmp	r3, #1
 8006b42:	d108      	bne.n	8006b56 <HAL_I2C_Init+0x7e>
  {
    hi2c->Instance->OAR1 = (I2C_OAR1_OA1EN | hi2c->Init.OwnAddress1);
 8006b44:	687b      	ldr	r3, [r7, #4]
 8006b46:	689a      	ldr	r2, [r3, #8]
 8006b48:	687b      	ldr	r3, [r7, #4]
 8006b4a:	681b      	ldr	r3, [r3, #0]
 8006b4c:	2180      	movs	r1, #128	; 0x80
 8006b4e:	0209      	lsls	r1, r1, #8
 8006b50:	430a      	orrs	r2, r1
 8006b52:	609a      	str	r2, [r3, #8]
 8006b54:	e007      	b.n	8006b66 <HAL_I2C_Init+0x8e>
  }
  else /* I2C_ADDRESSINGMODE_10BIT */
  {
    hi2c->Instance->OAR1 = (I2C_OAR1_OA1EN | I2C_OAR1_OA1MODE | hi2c->Init.OwnAddress1);
 8006b56:	687b      	ldr	r3, [r7, #4]
 8006b58:	689a      	ldr	r2, [r3, #8]
 8006b5a:	687b      	ldr	r3, [r7, #4]
 8006b5c:	681b      	ldr	r3, [r3, #0]
 8006b5e:	2184      	movs	r1, #132	; 0x84
 8006b60:	0209      	lsls	r1, r1, #8
 8006b62:	430a      	orrs	r2, r1
 8006b64:	609a      	str	r2, [r3, #8]
  }

  /*---------------------------- I2Cx CR2 Configuration ----------------------*/
  /* Configure I2Cx: Addressing Master mode */
  if (hi2c->Init.AddressingMode == I2C_ADDRESSINGMODE_10BIT)
 8006b66:	687b      	ldr	r3, [r7, #4]
 8006b68:	68db      	ldr	r3, [r3, #12]
 8006b6a:	2b02      	cmp	r3, #2
 8006b6c:	d104      	bne.n	8006b78 <HAL_I2C_Init+0xa0>
  {
    hi2c->Instance->CR2 = (I2C_CR2_ADD10);
 8006b6e:	687b      	ldr	r3, [r7, #4]
 8006b70:	681b      	ldr	r3, [r3, #0]
 8006b72:	2280      	movs	r2, #128	; 0x80
 8006b74:	0112      	lsls	r2, r2, #4
 8006b76:	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);
 8006b78:	687b      	ldr	r3, [r7, #4]
 8006b7a:	681b      	ldr	r3, [r3, #0]
 8006b7c:	685a      	ldr	r2, [r3, #4]
 8006b7e:	687b      	ldr	r3, [r7, #4]
 8006b80:	681b      	ldr	r3, [r3, #0]
 8006b82:	491f      	ldr	r1, [pc, #124]	; (8006c00 <HAL_I2C_Init+0x128>)
 8006b84:	430a      	orrs	r2, r1
 8006b86:	605a      	str	r2, [r3, #4]

  /*---------------------------- I2Cx OAR2 Configuration ---------------------*/
  /* Disable Own Address2 before set the Own Address2 configuration */
  hi2c->Instance->OAR2 &= ~I2C_DUALADDRESS_ENABLE;
 8006b88:	687b      	ldr	r3, [r7, #4]
 8006b8a:	681b      	ldr	r3, [r3, #0]
 8006b8c:	68da      	ldr	r2, [r3, #12]
 8006b8e:	687b      	ldr	r3, [r7, #4]
 8006b90:	681b      	ldr	r3, [r3, #0]
 8006b92:	491a      	ldr	r1, [pc, #104]	; (8006bfc <HAL_I2C_Init+0x124>)
 8006b94:	400a      	ands	r2, r1
 8006b96:	60da      	str	r2, [r3, #12]

  /* Configure I2Cx: Dual mode and Own Address2 */
  hi2c->Instance->OAR2 = (hi2c->Init.DualAddressMode | hi2c->Init.OwnAddress2 | \
 8006b98:	687b      	ldr	r3, [r7, #4]
 8006b9a:	691a      	ldr	r2, [r3, #16]
 8006b9c:	687b      	ldr	r3, [r7, #4]
 8006b9e:	695b      	ldr	r3, [r3, #20]
 8006ba0:	431a      	orrs	r2, r3
 8006ba2:	0011      	movs	r1, r2
                          (hi2c->Init.OwnAddress2Masks << 8));
 8006ba4:	687b      	ldr	r3, [r7, #4]
 8006ba6:	699b      	ldr	r3, [r3, #24]
 8006ba8:	021a      	lsls	r2, r3, #8
  hi2c->Instance->OAR2 = (hi2c->Init.DualAddressMode | hi2c->Init.OwnAddress2 | \
 8006baa:	687b      	ldr	r3, [r7, #4]
 8006bac:	681b      	ldr	r3, [r3, #0]
 8006bae:	430a      	orrs	r2, r1
 8006bb0:	60da      	str	r2, [r3, #12]

  /*---------------------------- I2Cx CR1 Configuration ----------------------*/
  /* Configure I2Cx: Generalcall and NoStretch mode */
  hi2c->Instance->CR1 = (hi2c->Init.GeneralCallMode | hi2c->Init.NoStretchMode);
 8006bb2:	687b      	ldr	r3, [r7, #4]
 8006bb4:	69d9      	ldr	r1, [r3, #28]
 8006bb6:	687b      	ldr	r3, [r7, #4]
 8006bb8:	6a1a      	ldr	r2, [r3, #32]
 8006bba:	687b      	ldr	r3, [r7, #4]
 8006bbc:	681b      	ldr	r3, [r3, #0]
 8006bbe:	430a      	orrs	r2, r1
 8006bc0:	601a      	str	r2, [r3, #0]

  /* Enable the selected I2C peripheral */
  __HAL_I2C_ENABLE(hi2c);
 8006bc2:	687b      	ldr	r3, [r7, #4]
 8006bc4:	681b      	ldr	r3, [r3, #0]
 8006bc6:	681a      	ldr	r2, [r3, #0]
 8006bc8:	687b      	ldr	r3, [r7, #4]
 8006bca:	681b      	ldr	r3, [r3, #0]
 8006bcc:	2101      	movs	r1, #1
 8006bce:	430a      	orrs	r2, r1
 8006bd0:	601a      	str	r2, [r3, #0]

  hi2c->ErrorCode = HAL_I2C_ERROR_NONE;
 8006bd2:	687b      	ldr	r3, [r7, #4]
 8006bd4:	2200      	movs	r2, #0
 8006bd6:	645a      	str	r2, [r3, #68]	; 0x44
  hi2c->State = HAL_I2C_STATE_READY;
 8006bd8:	687b      	ldr	r3, [r7, #4]
 8006bda:	2241      	movs	r2, #65	; 0x41
 8006bdc:	2120      	movs	r1, #32
 8006bde:	5499      	strb	r1, [r3, r2]
  hi2c->PreviousState = I2C_STATE_NONE;
 8006be0:	687b      	ldr	r3, [r7, #4]
 8006be2:	2200      	movs	r2, #0
 8006be4:	631a      	str	r2, [r3, #48]	; 0x30
  hi2c->Mode = HAL_I2C_MODE_NONE;
 8006be6:	687b      	ldr	r3, [r7, #4]
 8006be8:	2242      	movs	r2, #66	; 0x42
 8006bea:	2100      	movs	r1, #0
 8006bec:	5499      	strb	r1, [r3, r2]

  return HAL_OK;
 8006bee:	2300      	movs	r3, #0
}
 8006bf0:	0018      	movs	r0, r3
 8006bf2:	46bd      	mov	sp, r7
 8006bf4:	b002      	add	sp, #8
 8006bf6:	bd80      	pop	{r7, pc}
 8006bf8:	f0ffffff 	.word	0xf0ffffff
 8006bfc:	ffff7fff 	.word	0xffff7fff
 8006c00:	02008000 	.word	0x02008000

08006c04 <HAL_I2C_Master_Receive_IT>:
  * @param  Size Amount of data to be sent
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_I2C_Master_Receive_IT(I2C_HandleTypeDef *hi2c, uint16_t DevAddress, uint8_t *pData,
                                            uint16_t Size)
{
 8006c04:	b590      	push	{r4, r7, lr}
 8006c06:	b089      	sub	sp, #36	; 0x24
 8006c08:	af02      	add	r7, sp, #8
 8006c0a:	60f8      	str	r0, [r7, #12]
 8006c0c:	0008      	movs	r0, r1
 8006c0e:	607a      	str	r2, [r7, #4]
 8006c10:	0019      	movs	r1, r3
 8006c12:	230a      	movs	r3, #10
 8006c14:	18fb      	adds	r3, r7, r3
 8006c16:	1c02      	adds	r2, r0, #0
 8006c18:	801a      	strh	r2, [r3, #0]
 8006c1a:	2308      	movs	r3, #8
 8006c1c:	18fb      	adds	r3, r7, r3
 8006c1e:	1c0a      	adds	r2, r1, #0
 8006c20:	801a      	strh	r2, [r3, #0]
  uint32_t xfermode;

  if (hi2c->State == HAL_I2C_STATE_READY)
 8006c22:	68fb      	ldr	r3, [r7, #12]
 8006c24:	2241      	movs	r2, #65	; 0x41
 8006c26:	5c9b      	ldrb	r3, [r3, r2]
 8006c28:	b2db      	uxtb	r3, r3
 8006c2a:	2b20      	cmp	r3, #32
 8006c2c:	d15b      	bne.n	8006ce6 <HAL_I2C_Master_Receive_IT+0xe2>
  {
    if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_BUSY) == SET)
 8006c2e:	68fb      	ldr	r3, [r7, #12]
 8006c30:	681b      	ldr	r3, [r3, #0]
 8006c32:	699a      	ldr	r2, [r3, #24]
 8006c34:	2380      	movs	r3, #128	; 0x80
 8006c36:	021b      	lsls	r3, r3, #8
 8006c38:	401a      	ands	r2, r3
 8006c3a:	2380      	movs	r3, #128	; 0x80
 8006c3c:	021b      	lsls	r3, r3, #8
 8006c3e:	429a      	cmp	r2, r3
 8006c40:	d101      	bne.n	8006c46 <HAL_I2C_Master_Receive_IT+0x42>
    {
      return HAL_BUSY;
 8006c42:	2302      	movs	r3, #2
 8006c44:	e050      	b.n	8006ce8 <HAL_I2C_Master_Receive_IT+0xe4>
    }

    /* Process Locked */
    __HAL_LOCK(hi2c);
 8006c46:	68fb      	ldr	r3, [r7, #12]
 8006c48:	2240      	movs	r2, #64	; 0x40
 8006c4a:	5c9b      	ldrb	r3, [r3, r2]
 8006c4c:	2b01      	cmp	r3, #1
 8006c4e:	d101      	bne.n	8006c54 <HAL_I2C_Master_Receive_IT+0x50>
 8006c50:	2302      	movs	r3, #2
 8006c52:	e049      	b.n	8006ce8 <HAL_I2C_Master_Receive_IT+0xe4>
 8006c54:	68fb      	ldr	r3, [r7, #12]
 8006c56:	2240      	movs	r2, #64	; 0x40
 8006c58:	2101      	movs	r1, #1
 8006c5a:	5499      	strb	r1, [r3, r2]

    hi2c->State       = HAL_I2C_STATE_BUSY_RX;
 8006c5c:	68fb      	ldr	r3, [r7, #12]
 8006c5e:	2241      	movs	r2, #65	; 0x41
 8006c60:	2122      	movs	r1, #34	; 0x22
 8006c62:	5499      	strb	r1, [r3, r2]
    hi2c->Mode        = HAL_I2C_MODE_MASTER;
 8006c64:	68fb      	ldr	r3, [r7, #12]
 8006c66:	2242      	movs	r2, #66	; 0x42
 8006c68:	2110      	movs	r1, #16
 8006c6a:	5499      	strb	r1, [r3, r2]
    hi2c->ErrorCode   = HAL_I2C_ERROR_NONE;
 8006c6c:	68fb      	ldr	r3, [r7, #12]
 8006c6e:	2200      	movs	r2, #0
 8006c70:	645a      	str	r2, [r3, #68]	; 0x44

    /* Prepare transfer parameters */
    hi2c->pBuffPtr    = pData;
 8006c72:	68fb      	ldr	r3, [r7, #12]
 8006c74:	687a      	ldr	r2, [r7, #4]
 8006c76:	625a      	str	r2, [r3, #36]	; 0x24
    hi2c->XferCount   = Size;
 8006c78:	68fb      	ldr	r3, [r7, #12]
 8006c7a:	2208      	movs	r2, #8
 8006c7c:	18ba      	adds	r2, r7, r2
 8006c7e:	8812      	ldrh	r2, [r2, #0]
 8006c80:	855a      	strh	r2, [r3, #42]	; 0x2a
    hi2c->XferOptions = I2C_NO_OPTION_FRAME;
 8006c82:	68fb      	ldr	r3, [r7, #12]
 8006c84:	4a1a      	ldr	r2, [pc, #104]	; (8006cf0 <HAL_I2C_Master_Receive_IT+0xec>)
 8006c86:	62da      	str	r2, [r3, #44]	; 0x2c
    hi2c->XferISR     = I2C_Master_ISR_IT;
 8006c88:	68fb      	ldr	r3, [r7, #12]
 8006c8a:	4a1a      	ldr	r2, [pc, #104]	; (8006cf4 <HAL_I2C_Master_Receive_IT+0xf0>)
 8006c8c:	635a      	str	r2, [r3, #52]	; 0x34

    if (hi2c->XferCount > MAX_NBYTE_SIZE)
 8006c8e:	68fb      	ldr	r3, [r7, #12]
 8006c90:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8006c92:	b29b      	uxth	r3, r3
 8006c94:	2bff      	cmp	r3, #255	; 0xff
 8006c96:	d906      	bls.n	8006ca6 <HAL_I2C_Master_Receive_IT+0xa2>
    {
      hi2c->XferSize = MAX_NBYTE_SIZE;
 8006c98:	68fb      	ldr	r3, [r7, #12]
 8006c9a:	22ff      	movs	r2, #255	; 0xff
 8006c9c:	851a      	strh	r2, [r3, #40]	; 0x28
      xfermode = I2C_RELOAD_MODE;
 8006c9e:	2380      	movs	r3, #128	; 0x80
 8006ca0:	045b      	lsls	r3, r3, #17
 8006ca2:	617b      	str	r3, [r7, #20]
 8006ca4:	e007      	b.n	8006cb6 <HAL_I2C_Master_Receive_IT+0xb2>
    }
    else
    {
      hi2c->XferSize = hi2c->XferCount;
 8006ca6:	68fb      	ldr	r3, [r7, #12]
 8006ca8:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8006caa:	b29a      	uxth	r2, r3
 8006cac:	68fb      	ldr	r3, [r7, #12]
 8006cae:	851a      	strh	r2, [r3, #40]	; 0x28
      xfermode = I2C_AUTOEND_MODE;
 8006cb0:	2380      	movs	r3, #128	; 0x80
 8006cb2:	049b      	lsls	r3, r3, #18
 8006cb4:	617b      	str	r3, [r7, #20]
    }

    /* Send Slave Address */
    /* Set NBYTES to write and reload if hi2c->XferCount > MAX_NBYTE_SIZE */
    I2C_TransferConfig(hi2c, DevAddress, (uint8_t)hi2c->XferSize, xfermode, I2C_GENERATE_START_READ);
 8006cb6:	68fb      	ldr	r3, [r7, #12]
 8006cb8:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8006cba:	b2da      	uxtb	r2, r3
 8006cbc:	697c      	ldr	r4, [r7, #20]
 8006cbe:	230a      	movs	r3, #10
 8006cc0:	18fb      	adds	r3, r7, r3
 8006cc2:	8819      	ldrh	r1, [r3, #0]
 8006cc4:	68f8      	ldr	r0, [r7, #12]
 8006cc6:	4b0c      	ldr	r3, [pc, #48]	; (8006cf8 <HAL_I2C_Master_Receive_IT+0xf4>)
 8006cc8:	9300      	str	r3, [sp, #0]
 8006cca:	0023      	movs	r3, r4
 8006ccc:	f001 f9a6 	bl	800801c <I2C_TransferConfig>

    /* Process Unlocked */
    __HAL_UNLOCK(hi2c);
 8006cd0:	68fb      	ldr	r3, [r7, #12]
 8006cd2:	2240      	movs	r2, #64	; 0x40
 8006cd4:	2100      	movs	r1, #0
 8006cd6:	5499      	strb	r1, [r3, r2]

    /* Enable ERR, TC, STOP, NACK, RXI interrupt */
    /* possible to enable all of these */
    /* I2C_IT_ERRI | I2C_IT_TCI | I2C_IT_STOPI | I2C_IT_NACKI |
      I2C_IT_ADDRI | I2C_IT_RXI | I2C_IT_TXI */
    I2C_Enable_IRQ(hi2c, I2C_XFER_RX_IT);
 8006cd8:	68fb      	ldr	r3, [r7, #12]
 8006cda:	2102      	movs	r1, #2
 8006cdc:	0018      	movs	r0, r3
 8006cde:	f001 f9d3 	bl	8008088 <I2C_Enable_IRQ>

    return HAL_OK;
 8006ce2:	2300      	movs	r3, #0
 8006ce4:	e000      	b.n	8006ce8 <HAL_I2C_Master_Receive_IT+0xe4>
  }
  else
  {
    return HAL_BUSY;
 8006ce6:	2302      	movs	r3, #2
  }
}
 8006ce8:	0018      	movs	r0, r3
 8006cea:	46bd      	mov	sp, r7
 8006cec:	b007      	add	sp, #28
 8006cee:	bd90      	pop	{r4, r7, pc}
 8006cf0:	ffff0000 	.word	0xffff0000
 8006cf4:	08006d9d 	.word	0x08006d9d
 8006cf8:	80002400 	.word	0x80002400

08006cfc <HAL_I2C_MasterTxCpltCallback>:
  * @param  hi2c Pointer to a I2C_HandleTypeDef structure that contains
  *                the configuration information for the specified I2C.
  * @retval None
  */
__weak void HAL_I2C_MasterTxCpltCallback(I2C_HandleTypeDef *hi2c)
{
 8006cfc:	b580      	push	{r7, lr}
 8006cfe:	b082      	sub	sp, #8
 8006d00:	af00      	add	r7, sp, #0
 8006d02:	6078      	str	r0, [r7, #4]
  UNUSED(hi2c);

  /* NOTE : This function should not be modified, when the callback is needed,
            the HAL_I2C_MasterTxCpltCallback could be implemented in the user file
   */
}
 8006d04:	46c0      	nop			; (mov r8, r8)
 8006d06:	46bd      	mov	sp, r7
 8006d08:	b002      	add	sp, #8
 8006d0a:	bd80      	pop	{r7, pc}

08006d0c <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)
{
 8006d0c:	b580      	push	{r7, lr}
 8006d0e:	b082      	sub	sp, #8
 8006d10:	af00      	add	r7, sp, #0
 8006d12:	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
   */
}
 8006d14:	46c0      	nop			; (mov r8, r8)
 8006d16:	46bd      	mov	sp, r7
 8006d18:	b002      	add	sp, #8
 8006d1a:	bd80      	pop	{r7, pc}

08006d1c <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)
{
 8006d1c:	b580      	push	{r7, lr}
 8006d1e:	b082      	sub	sp, #8
 8006d20:	af00      	add	r7, sp, #0
 8006d22:	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
   */
}
 8006d24:	46c0      	nop			; (mov r8, r8)
 8006d26:	46bd      	mov	sp, r7
 8006d28:	b002      	add	sp, #8
 8006d2a:	bd80      	pop	{r7, pc}

08006d2c <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)
{
 8006d2c:	b580      	push	{r7, lr}
 8006d2e:	b082      	sub	sp, #8
 8006d30:	af00      	add	r7, sp, #0
 8006d32:	6078      	str	r0, [r7, #4]
 8006d34:	0008      	movs	r0, r1
 8006d36:	0011      	movs	r1, r2
 8006d38:	1cfb      	adds	r3, r7, #3
 8006d3a:	1c02      	adds	r2, r0, #0
 8006d3c:	701a      	strb	r2, [r3, #0]
 8006d3e:	003b      	movs	r3, r7
 8006d40:	1c0a      	adds	r2, r1, #0
 8006d42:	801a      	strh	r2, [r3, #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
   */
}
 8006d44:	46c0      	nop			; (mov r8, r8)
 8006d46:	46bd      	mov	sp, r7
 8006d48:	b002      	add	sp, #8
 8006d4a:	bd80      	pop	{r7, pc}

08006d4c <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)
{
 8006d4c:	b580      	push	{r7, lr}
 8006d4e:	b082      	sub	sp, #8
 8006d50:	af00      	add	r7, sp, #0
 8006d52:	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
   */
}
 8006d54:	46c0      	nop			; (mov r8, r8)
 8006d56:	46bd      	mov	sp, r7
 8006d58:	b002      	add	sp, #8
 8006d5a:	bd80      	pop	{r7, pc}

08006d5c <HAL_I2C_MemTxCpltCallback>:
  * @param  hi2c Pointer to a I2C_HandleTypeDef structure that contains
  *                the configuration information for the specified I2C.
  * @retval None
  */
__weak void HAL_I2C_MemTxCpltCallback(I2C_HandleTypeDef *hi2c)
{
 8006d5c:	b580      	push	{r7, lr}
 8006d5e:	b082      	sub	sp, #8
 8006d60:	af00      	add	r7, sp, #0
 8006d62:	6078      	str	r0, [r7, #4]
  UNUSED(hi2c);

  /* NOTE : This function should not be modified, when the callback is needed,
            the HAL_I2C_MemTxCpltCallback could be implemented in the user file
   */
}
 8006d64:	46c0      	nop			; (mov r8, r8)
 8006d66:	46bd      	mov	sp, r7
 8006d68:	b002      	add	sp, #8
 8006d6a:	bd80      	pop	{r7, pc}

08006d6c <HAL_I2C_MemRxCpltCallback>:
  * @param  hi2c Pointer to a I2C_HandleTypeDef structure that contains
  *                the configuration information for the specified I2C.
  * @retval None
  */
__weak void HAL_I2C_MemRxCpltCallback(I2C_HandleTypeDef *hi2c)
{
 8006d6c:	b580      	push	{r7, lr}
 8006d6e:	b082      	sub	sp, #8
 8006d70:	af00      	add	r7, sp, #0
 8006d72:	6078      	str	r0, [r7, #4]
  UNUSED(hi2c);

  /* NOTE : This function should not be modified, when the callback is needed,
            the HAL_I2C_MemRxCpltCallback could be implemented in the user file
   */
}
 8006d74:	46c0      	nop			; (mov r8, r8)
 8006d76:	46bd      	mov	sp, r7
 8006d78:	b002      	add	sp, #8
 8006d7a:	bd80      	pop	{r7, pc}

08006d7c <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)
{
 8006d7c:	b580      	push	{r7, lr}
 8006d7e:	b082      	sub	sp, #8
 8006d80:	af00      	add	r7, sp, #0
 8006d82:	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
   */
}
 8006d84:	46c0      	nop			; (mov r8, r8)
 8006d86:	46bd      	mov	sp, r7
 8006d88:	b002      	add	sp, #8
 8006d8a:	bd80      	pop	{r7, pc}

08006d8c <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)
{
 8006d8c:	b580      	push	{r7, lr}
 8006d8e:	b082      	sub	sp, #8
 8006d90:	af00      	add	r7, sp, #0
 8006d92:	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
   */
}
 8006d94:	46c0      	nop			; (mov r8, r8)
 8006d96:	46bd      	mov	sp, r7
 8006d98:	b002      	add	sp, #8
 8006d9a:	bd80      	pop	{r7, pc}

08006d9c <I2C_Master_ISR_IT>:
  * @param  ITSources Interrupt sources enabled.
  * @retval HAL status
  */
static HAL_StatusTypeDef I2C_Master_ISR_IT(struct __I2C_HandleTypeDef *hi2c, uint32_t ITFlags,
                                           uint32_t ITSources)
{
 8006d9c:	b590      	push	{r4, r7, lr}
 8006d9e:	b089      	sub	sp, #36	; 0x24
 8006da0:	af02      	add	r7, sp, #8
 8006da2:	60f8      	str	r0, [r7, #12]
 8006da4:	60b9      	str	r1, [r7, #8]
 8006da6:	607a      	str	r2, [r7, #4]
  uint16_t devaddress;
  uint32_t tmpITFlags = ITFlags;
 8006da8:	68bb      	ldr	r3, [r7, #8]
 8006daa:	617b      	str	r3, [r7, #20]

  /* Process Locked */
  __HAL_LOCK(hi2c);
 8006dac:	68fb      	ldr	r3, [r7, #12]
 8006dae:	2240      	movs	r2, #64	; 0x40
 8006db0:	5c9b      	ldrb	r3, [r3, r2]
 8006db2:	2b01      	cmp	r3, #1
 8006db4:	d101      	bne.n	8006dba <I2C_Master_ISR_IT+0x1e>
 8006db6:	2302      	movs	r3, #2
 8006db8:	e12b      	b.n	8007012 <I2C_Master_ISR_IT+0x276>
 8006dba:	68fb      	ldr	r3, [r7, #12]
 8006dbc:	2240      	movs	r2, #64	; 0x40
 8006dbe:	2101      	movs	r1, #1
 8006dc0:	5499      	strb	r1, [r3, r2]

  if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_AF) != RESET) && \
 8006dc2:	697b      	ldr	r3, [r7, #20]
 8006dc4:	091b      	lsrs	r3, r3, #4
 8006dc6:	001a      	movs	r2, r3
 8006dc8:	2301      	movs	r3, #1
 8006dca:	4013      	ands	r3, r2
 8006dcc:	d014      	beq.n	8006df8 <I2C_Master_ISR_IT+0x5c>
      (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_NACKI) != RESET))
 8006dce:	687b      	ldr	r3, [r7, #4]
 8006dd0:	091b      	lsrs	r3, r3, #4
 8006dd2:	001a      	movs	r2, r3
 8006dd4:	2301      	movs	r3, #1
 8006dd6:	4013      	ands	r3, r2
  if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_AF) != RESET) && \
 8006dd8:	d00e      	beq.n	8006df8 <I2C_Master_ISR_IT+0x5c>
  {
    /* Clear NACK Flag */
    __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF);
 8006dda:	68fb      	ldr	r3, [r7, #12]
 8006ddc:	681b      	ldr	r3, [r3, #0]
 8006dde:	2210      	movs	r2, #16
 8006de0:	61da      	str	r2, [r3, #28]

    /* Set corresponding Error Code */
    /* No need to generate STOP, it is automatically done */
    /* Error callback will be send during stop flag treatment */
    hi2c->ErrorCode |= HAL_I2C_ERROR_AF;
 8006de2:	68fb      	ldr	r3, [r7, #12]
 8006de4:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8006de6:	2204      	movs	r2, #4
 8006de8:	431a      	orrs	r2, r3
 8006dea:	68fb      	ldr	r3, [r7, #12]
 8006dec:	645a      	str	r2, [r3, #68]	; 0x44

    /* Flush TX register */
    I2C_Flush_TXDR(hi2c);
 8006dee:	68fb      	ldr	r3, [r7, #12]
 8006df0:	0018      	movs	r0, r3
 8006df2:	f001 f8d2 	bl	8007f9a <I2C_Flush_TXDR>
 8006df6:	e0f5      	b.n	8006fe4 <I2C_Master_ISR_IT+0x248>
  }
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_RXNE) != RESET) && \
 8006df8:	697b      	ldr	r3, [r7, #20]
 8006dfa:	089b      	lsrs	r3, r3, #2
 8006dfc:	001a      	movs	r2, r3
 8006dfe:	2301      	movs	r3, #1
 8006e00:	4013      	ands	r3, r2
 8006e02:	d023      	beq.n	8006e4c <I2C_Master_ISR_IT+0xb0>
           (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_RXI) != RESET))
 8006e04:	687b      	ldr	r3, [r7, #4]
 8006e06:	089b      	lsrs	r3, r3, #2
 8006e08:	001a      	movs	r2, r3
 8006e0a:	2301      	movs	r3, #1
 8006e0c:	4013      	ands	r3, r2
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_RXNE) != RESET) && \
 8006e0e:	d01d      	beq.n	8006e4c <I2C_Master_ISR_IT+0xb0>
  {
    /* Remove RXNE flag on temporary variable as read done */
    tmpITFlags &= ~I2C_FLAG_RXNE;
 8006e10:	697b      	ldr	r3, [r7, #20]
 8006e12:	2204      	movs	r2, #4
 8006e14:	4393      	bics	r3, r2
 8006e16:	617b      	str	r3, [r7, #20]

    /* Read data from RXDR */
    *hi2c->pBuffPtr = (uint8_t)hi2c->Instance->RXDR;
 8006e18:	68fb      	ldr	r3, [r7, #12]
 8006e1a:	681b      	ldr	r3, [r3, #0]
 8006e1c:	6a5a      	ldr	r2, [r3, #36]	; 0x24
 8006e1e:	68fb      	ldr	r3, [r7, #12]
 8006e20:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8006e22:	b2d2      	uxtb	r2, r2
 8006e24:	701a      	strb	r2, [r3, #0]

    /* Increment Buffer pointer */
    hi2c->pBuffPtr++;
 8006e26:	68fb      	ldr	r3, [r7, #12]
 8006e28:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8006e2a:	1c5a      	adds	r2, r3, #1
 8006e2c:	68fb      	ldr	r3, [r7, #12]
 8006e2e:	625a      	str	r2, [r3, #36]	; 0x24

    hi2c->XferSize--;
 8006e30:	68fb      	ldr	r3, [r7, #12]
 8006e32:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8006e34:	3b01      	subs	r3, #1
 8006e36:	b29a      	uxth	r2, r3
 8006e38:	68fb      	ldr	r3, [r7, #12]
 8006e3a:	851a      	strh	r2, [r3, #40]	; 0x28
    hi2c->XferCount--;
 8006e3c:	68fb      	ldr	r3, [r7, #12]
 8006e3e:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8006e40:	b29b      	uxth	r3, r3
 8006e42:	3b01      	subs	r3, #1
 8006e44:	b29a      	uxth	r2, r3
 8006e46:	68fb      	ldr	r3, [r7, #12]
 8006e48:	855a      	strh	r2, [r3, #42]	; 0x2a
 8006e4a:	e0cb      	b.n	8006fe4 <I2C_Master_ISR_IT+0x248>
  }
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_TXIS) != RESET) && \
 8006e4c:	697b      	ldr	r3, [r7, #20]
 8006e4e:	085b      	lsrs	r3, r3, #1
 8006e50:	001a      	movs	r2, r3
 8006e52:	2301      	movs	r3, #1
 8006e54:	4013      	ands	r3, r2
 8006e56:	d01e      	beq.n	8006e96 <I2C_Master_ISR_IT+0xfa>
           (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_TXI) != RESET))
 8006e58:	687b      	ldr	r3, [r7, #4]
 8006e5a:	085b      	lsrs	r3, r3, #1
 8006e5c:	001a      	movs	r2, r3
 8006e5e:	2301      	movs	r3, #1
 8006e60:	4013      	ands	r3, r2
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_TXIS) != RESET) && \
 8006e62:	d018      	beq.n	8006e96 <I2C_Master_ISR_IT+0xfa>
  {
    /* Write data to TXDR */
    hi2c->Instance->TXDR = *hi2c->pBuffPtr;
 8006e64:	68fb      	ldr	r3, [r7, #12]
 8006e66:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8006e68:	781a      	ldrb	r2, [r3, #0]
 8006e6a:	68fb      	ldr	r3, [r7, #12]
 8006e6c:	681b      	ldr	r3, [r3, #0]
 8006e6e:	629a      	str	r2, [r3, #40]	; 0x28

    /* Increment Buffer pointer */
    hi2c->pBuffPtr++;
 8006e70:	68fb      	ldr	r3, [r7, #12]
 8006e72:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8006e74:	1c5a      	adds	r2, r3, #1
 8006e76:	68fb      	ldr	r3, [r7, #12]
 8006e78:	625a      	str	r2, [r3, #36]	; 0x24

    hi2c->XferSize--;
 8006e7a:	68fb      	ldr	r3, [r7, #12]
 8006e7c:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8006e7e:	3b01      	subs	r3, #1
 8006e80:	b29a      	uxth	r2, r3
 8006e82:	68fb      	ldr	r3, [r7, #12]
 8006e84:	851a      	strh	r2, [r3, #40]	; 0x28
    hi2c->XferCount--;
 8006e86:	68fb      	ldr	r3, [r7, #12]
 8006e88:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8006e8a:	b29b      	uxth	r3, r3
 8006e8c:	3b01      	subs	r3, #1
 8006e8e:	b29a      	uxth	r2, r3
 8006e90:	68fb      	ldr	r3, [r7, #12]
 8006e92:	855a      	strh	r2, [r3, #42]	; 0x2a
 8006e94:	e0a6      	b.n	8006fe4 <I2C_Master_ISR_IT+0x248>
  }
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_TCR) != RESET) && \
 8006e96:	697b      	ldr	r3, [r7, #20]
 8006e98:	09db      	lsrs	r3, r3, #7
 8006e9a:	001a      	movs	r2, r3
 8006e9c:	2301      	movs	r3, #1
 8006e9e:	4013      	ands	r3, r2
 8006ea0:	d100      	bne.n	8006ea4 <I2C_Master_ISR_IT+0x108>
 8006ea2:	e06b      	b.n	8006f7c <I2C_Master_ISR_IT+0x1e0>
           (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_TCI) != RESET))
 8006ea4:	687b      	ldr	r3, [r7, #4]
 8006ea6:	099b      	lsrs	r3, r3, #6
 8006ea8:	001a      	movs	r2, r3
 8006eaa:	2301      	movs	r3, #1
 8006eac:	4013      	ands	r3, r2
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_TCR) != RESET) && \
 8006eae:	d065      	beq.n	8006f7c <I2C_Master_ISR_IT+0x1e0>
  {
    if ((hi2c->XferCount != 0U) && (hi2c->XferSize == 0U))
 8006eb0:	68fb      	ldr	r3, [r7, #12]
 8006eb2:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8006eb4:	b29b      	uxth	r3, r3
 8006eb6:	2b00      	cmp	r3, #0
 8006eb8:	d04a      	beq.n	8006f50 <I2C_Master_ISR_IT+0x1b4>
 8006eba:	68fb      	ldr	r3, [r7, #12]
 8006ebc:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8006ebe:	2b00      	cmp	r3, #0
 8006ec0:	d146      	bne.n	8006f50 <I2C_Master_ISR_IT+0x1b4>
    {
      devaddress = (uint16_t)(hi2c->Instance->CR2 & I2C_CR2_SADD);
 8006ec2:	68fb      	ldr	r3, [r7, #12]
 8006ec4:	681b      	ldr	r3, [r3, #0]
 8006ec6:	685b      	ldr	r3, [r3, #4]
 8006ec8:	b29a      	uxth	r2, r3
 8006eca:	2112      	movs	r1, #18
 8006ecc:	187b      	adds	r3, r7, r1
 8006ece:	0592      	lsls	r2, r2, #22
 8006ed0:	0d92      	lsrs	r2, r2, #22
 8006ed2:	801a      	strh	r2, [r3, #0]

      if (hi2c->XferCount > MAX_NBYTE_SIZE)
 8006ed4:	68fb      	ldr	r3, [r7, #12]
 8006ed6:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8006ed8:	b29b      	uxth	r3, r3
 8006eda:	2bff      	cmp	r3, #255	; 0xff
 8006edc:	d910      	bls.n	8006f00 <I2C_Master_ISR_IT+0x164>
      {
        hi2c->XferSize = MAX_NBYTE_SIZE;
 8006ede:	68fb      	ldr	r3, [r7, #12]
 8006ee0:	22ff      	movs	r2, #255	; 0xff
 8006ee2:	851a      	strh	r2, [r3, #40]	; 0x28
        I2C_TransferConfig(hi2c, devaddress, (uint8_t)hi2c->XferSize, I2C_RELOAD_MODE, I2C_NO_STARTSTOP);
 8006ee4:	68fb      	ldr	r3, [r7, #12]
 8006ee6:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8006ee8:	b2da      	uxtb	r2, r3
 8006eea:	2380      	movs	r3, #128	; 0x80
 8006eec:	045c      	lsls	r4, r3, #17
 8006eee:	187b      	adds	r3, r7, r1
 8006ef0:	8819      	ldrh	r1, [r3, #0]
 8006ef2:	68f8      	ldr	r0, [r7, #12]
 8006ef4:	2300      	movs	r3, #0
 8006ef6:	9300      	str	r3, [sp, #0]
 8006ef8:	0023      	movs	r3, r4
 8006efa:	f001 f88f 	bl	800801c <I2C_TransferConfig>
      if (hi2c->XferCount > MAX_NBYTE_SIZE)
 8006efe:	e03c      	b.n	8006f7a <I2C_Master_ISR_IT+0x1de>
      }
      else
      {
        hi2c->XferSize = hi2c->XferCount;
 8006f00:	68fb      	ldr	r3, [r7, #12]
 8006f02:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8006f04:	b29a      	uxth	r2, r3
 8006f06:	68fb      	ldr	r3, [r7, #12]
 8006f08:	851a      	strh	r2, [r3, #40]	; 0x28
        if (hi2c->XferOptions != I2C_NO_OPTION_FRAME)
 8006f0a:	68fb      	ldr	r3, [r7, #12]
 8006f0c:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8006f0e:	4a43      	ldr	r2, [pc, #268]	; (800701c <I2C_Master_ISR_IT+0x280>)
 8006f10:	4293      	cmp	r3, r2
 8006f12:	d00e      	beq.n	8006f32 <I2C_Master_ISR_IT+0x196>
        {
          I2C_TransferConfig(hi2c, devaddress, (uint8_t)hi2c->XferSize,
 8006f14:	68fb      	ldr	r3, [r7, #12]
 8006f16:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8006f18:	b2da      	uxtb	r2, r3
 8006f1a:	68fb      	ldr	r3, [r7, #12]
 8006f1c:	6adc      	ldr	r4, [r3, #44]	; 0x2c
 8006f1e:	2312      	movs	r3, #18
 8006f20:	18fb      	adds	r3, r7, r3
 8006f22:	8819      	ldrh	r1, [r3, #0]
 8006f24:	68f8      	ldr	r0, [r7, #12]
 8006f26:	2300      	movs	r3, #0
 8006f28:	9300      	str	r3, [sp, #0]
 8006f2a:	0023      	movs	r3, r4
 8006f2c:	f001 f876 	bl	800801c <I2C_TransferConfig>
      if (hi2c->XferCount > MAX_NBYTE_SIZE)
 8006f30:	e023      	b.n	8006f7a <I2C_Master_ISR_IT+0x1de>
                             hi2c->XferOptions, I2C_NO_STARTSTOP);
        }
        else
        {
          I2C_TransferConfig(hi2c, devaddress, (uint8_t)hi2c->XferSize,
 8006f32:	68fb      	ldr	r3, [r7, #12]
 8006f34:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8006f36:	b2da      	uxtb	r2, r3
 8006f38:	2380      	movs	r3, #128	; 0x80
 8006f3a:	049c      	lsls	r4, r3, #18
 8006f3c:	2312      	movs	r3, #18
 8006f3e:	18fb      	adds	r3, r7, r3
 8006f40:	8819      	ldrh	r1, [r3, #0]
 8006f42:	68f8      	ldr	r0, [r7, #12]
 8006f44:	2300      	movs	r3, #0
 8006f46:	9300      	str	r3, [sp, #0]
 8006f48:	0023      	movs	r3, r4
 8006f4a:	f001 f867 	bl	800801c <I2C_TransferConfig>
      if (hi2c->XferCount > MAX_NBYTE_SIZE)
 8006f4e:	e014      	b.n	8006f7a <I2C_Master_ISR_IT+0x1de>
      }
    }
    else
    {
      /* Call TxCpltCallback() if no stop mode is set */
      if (I2C_GET_STOP_MODE(hi2c) != I2C_AUTOEND_MODE)
 8006f50:	68fb      	ldr	r3, [r7, #12]
 8006f52:	681b      	ldr	r3, [r3, #0]
 8006f54:	685a      	ldr	r2, [r3, #4]
 8006f56:	2380      	movs	r3, #128	; 0x80
 8006f58:	049b      	lsls	r3, r3, #18
 8006f5a:	401a      	ands	r2, r3
 8006f5c:	2380      	movs	r3, #128	; 0x80
 8006f5e:	049b      	lsls	r3, r3, #18
 8006f60:	429a      	cmp	r2, r3
 8006f62:	d004      	beq.n	8006f6e <I2C_Master_ISR_IT+0x1d2>
      {
        /* Call I2C Master Sequential complete process */
        I2C_ITMasterSeqCplt(hi2c);
 8006f64:	68fb      	ldr	r3, [r7, #12]
 8006f66:	0018      	movs	r0, r3
 8006f68:	f000 fc14 	bl	8007794 <I2C_ITMasterSeqCplt>
    if ((hi2c->XferCount != 0U) && (hi2c->XferSize == 0U))
 8006f6c:	e03a      	b.n	8006fe4 <I2C_Master_ISR_IT+0x248>
      }
      else
      {
        /* Wrong size Status regarding TCR flag event */
        /* Call the corresponding callback to inform upper layer of End of Transfer */
        I2C_ITError(hi2c, HAL_I2C_ERROR_SIZE);
 8006f6e:	68fb      	ldr	r3, [r7, #12]
 8006f70:	2140      	movs	r1, #64	; 0x40
 8006f72:	0018      	movs	r0, r3
 8006f74:	f000 ff06 	bl	8007d84 <I2C_ITError>
    if ((hi2c->XferCount != 0U) && (hi2c->XferSize == 0U))
 8006f78:	e034      	b.n	8006fe4 <I2C_Master_ISR_IT+0x248>
 8006f7a:	e033      	b.n	8006fe4 <I2C_Master_ISR_IT+0x248>
      }
    }
  }
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_TC) != RESET) && \
 8006f7c:	697b      	ldr	r3, [r7, #20]
 8006f7e:	099b      	lsrs	r3, r3, #6
 8006f80:	001a      	movs	r2, r3
 8006f82:	2301      	movs	r3, #1
 8006f84:	4013      	ands	r3, r2
 8006f86:	d02d      	beq.n	8006fe4 <I2C_Master_ISR_IT+0x248>
           (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_TCI) != RESET))
 8006f88:	687b      	ldr	r3, [r7, #4]
 8006f8a:	099b      	lsrs	r3, r3, #6
 8006f8c:	001a      	movs	r2, r3
 8006f8e:	2301      	movs	r3, #1
 8006f90:	4013      	ands	r3, r2
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_TC) != RESET) && \
 8006f92:	d027      	beq.n	8006fe4 <I2C_Master_ISR_IT+0x248>
  {
    if (hi2c->XferCount == 0U)
 8006f94:	68fb      	ldr	r3, [r7, #12]
 8006f96:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8006f98:	b29b      	uxth	r3, r3
 8006f9a:	2b00      	cmp	r3, #0
 8006f9c:	d11d      	bne.n	8006fda <I2C_Master_ISR_IT+0x23e>
    {
      if (I2C_GET_STOP_MODE(hi2c) != I2C_AUTOEND_MODE)
 8006f9e:	68fb      	ldr	r3, [r7, #12]
 8006fa0:	681b      	ldr	r3, [r3, #0]
 8006fa2:	685a      	ldr	r2, [r3, #4]
 8006fa4:	2380      	movs	r3, #128	; 0x80
 8006fa6:	049b      	lsls	r3, r3, #18
 8006fa8:	401a      	ands	r2, r3
 8006faa:	2380      	movs	r3, #128	; 0x80
 8006fac:	049b      	lsls	r3, r3, #18
 8006fae:	429a      	cmp	r2, r3
 8006fb0:	d018      	beq.n	8006fe4 <I2C_Master_ISR_IT+0x248>
      {
        /* Generate a stop condition in case of no transfer option */
        if (hi2c->XferOptions == I2C_NO_OPTION_FRAME)
 8006fb2:	68fb      	ldr	r3, [r7, #12]
 8006fb4:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8006fb6:	4a19      	ldr	r2, [pc, #100]	; (800701c <I2C_Master_ISR_IT+0x280>)
 8006fb8:	4293      	cmp	r3, r2
 8006fba:	d109      	bne.n	8006fd0 <I2C_Master_ISR_IT+0x234>
        {
          /* Generate Stop */
          hi2c->Instance->CR2 |= I2C_CR2_STOP;
 8006fbc:	68fb      	ldr	r3, [r7, #12]
 8006fbe:	681b      	ldr	r3, [r3, #0]
 8006fc0:	685a      	ldr	r2, [r3, #4]
 8006fc2:	68fb      	ldr	r3, [r7, #12]
 8006fc4:	681b      	ldr	r3, [r3, #0]
 8006fc6:	2180      	movs	r1, #128	; 0x80
 8006fc8:	01c9      	lsls	r1, r1, #7
 8006fca:	430a      	orrs	r2, r1
 8006fcc:	605a      	str	r2, [r3, #4]
 8006fce:	e009      	b.n	8006fe4 <I2C_Master_ISR_IT+0x248>
        }
        else
        {
          /* Call I2C Master Sequential complete process */
          I2C_ITMasterSeqCplt(hi2c);
 8006fd0:	68fb      	ldr	r3, [r7, #12]
 8006fd2:	0018      	movs	r0, r3
 8006fd4:	f000 fbde 	bl	8007794 <I2C_ITMasterSeqCplt>
 8006fd8:	e004      	b.n	8006fe4 <I2C_Master_ISR_IT+0x248>
    }
    else
    {
      /* Wrong size Status regarding TC flag event */
      /* Call the corresponding callback to inform upper layer of End of Transfer */
      I2C_ITError(hi2c, HAL_I2C_ERROR_SIZE);
 8006fda:	68fb      	ldr	r3, [r7, #12]
 8006fdc:	2140      	movs	r1, #64	; 0x40
 8006fde:	0018      	movs	r0, r3
 8006fe0:	f000 fed0 	bl	8007d84 <I2C_ITError>
  else
  {
    /* Nothing to do */
  }

  if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_STOPF) != RESET) && \
 8006fe4:	697b      	ldr	r3, [r7, #20]
 8006fe6:	095b      	lsrs	r3, r3, #5
 8006fe8:	001a      	movs	r2, r3
 8006fea:	2301      	movs	r3, #1
 8006fec:	4013      	ands	r3, r2
 8006fee:	d00b      	beq.n	8007008 <I2C_Master_ISR_IT+0x26c>
      (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_STOPI) != RESET))
 8006ff0:	687b      	ldr	r3, [r7, #4]
 8006ff2:	095b      	lsrs	r3, r3, #5
 8006ff4:	001a      	movs	r2, r3
 8006ff6:	2301      	movs	r3, #1
 8006ff8:	4013      	ands	r3, r2
  if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_STOPF) != RESET) && \
 8006ffa:	d005      	beq.n	8007008 <I2C_Master_ISR_IT+0x26c>
  {
    /* Call I2C Master complete process */
    I2C_ITMasterCplt(hi2c, tmpITFlags);
 8006ffc:	697a      	ldr	r2, [r7, #20]
 8006ffe:	68fb      	ldr	r3, [r7, #12]
 8007000:	0011      	movs	r1, r2
 8007002:	0018      	movs	r0, r3
 8007004:	f000 fc6e 	bl	80078e4 <I2C_ITMasterCplt>
  }

  /* Process Unlocked */
  __HAL_UNLOCK(hi2c);
 8007008:	68fb      	ldr	r3, [r7, #12]
 800700a:	2240      	movs	r2, #64	; 0x40
 800700c:	2100      	movs	r1, #0
 800700e:	5499      	strb	r1, [r3, r2]

  return HAL_OK;
 8007010:	2300      	movs	r3, #0
}
 8007012:	0018      	movs	r0, r3
 8007014:	46bd      	mov	sp, r7
 8007016:	b007      	add	sp, #28
 8007018:	bd90      	pop	{r4, r7, pc}
 800701a:	46c0      	nop			; (mov r8, r8)
 800701c:	ffff0000 	.word	0xffff0000

08007020 <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)
{
 8007020:	b580      	push	{r7, lr}
 8007022:	b086      	sub	sp, #24
 8007024:	af00      	add	r7, sp, #0
 8007026:	60f8      	str	r0, [r7, #12]
 8007028:	60b9      	str	r1, [r7, #8]
 800702a:	607a      	str	r2, [r7, #4]
  uint32_t tmpoptions = hi2c->XferOptions;
 800702c:	68fb      	ldr	r3, [r7, #12]
 800702e:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8007030:	617b      	str	r3, [r7, #20]
  uint32_t tmpITFlags = ITFlags;
 8007032:	68bb      	ldr	r3, [r7, #8]
 8007034:	613b      	str	r3, [r7, #16]

  /* Process locked */
  __HAL_LOCK(hi2c);
 8007036:	68fb      	ldr	r3, [r7, #12]
 8007038:	2240      	movs	r2, #64	; 0x40
 800703a:	5c9b      	ldrb	r3, [r3, r2]
 800703c:	2b01      	cmp	r3, #1
 800703e:	d101      	bne.n	8007044 <I2C_Slave_ISR_IT+0x24>
 8007040:	2302      	movs	r3, #2
 8007042:	e0fa      	b.n	800723a <I2C_Slave_ISR_IT+0x21a>
 8007044:	68fb      	ldr	r3, [r7, #12]
 8007046:	2240      	movs	r2, #64	; 0x40
 8007048:	2101      	movs	r1, #1
 800704a:	5499      	strb	r1, [r3, r2]

  /* Check if STOPF is set */
  if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_STOPF) != RESET) && \
 800704c:	693b      	ldr	r3, [r7, #16]
 800704e:	095b      	lsrs	r3, r3, #5
 8007050:	001a      	movs	r2, r3
 8007052:	2301      	movs	r3, #1
 8007054:	4013      	ands	r3, r2
 8007056:	d00b      	beq.n	8007070 <I2C_Slave_ISR_IT+0x50>
      (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_STOPI) != RESET))
 8007058:	687b      	ldr	r3, [r7, #4]
 800705a:	095b      	lsrs	r3, r3, #5
 800705c:	001a      	movs	r2, r3
 800705e:	2301      	movs	r3, #1
 8007060:	4013      	ands	r3, r2
  if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_STOPF) != RESET) && \
 8007062:	d005      	beq.n	8007070 <I2C_Slave_ISR_IT+0x50>
  {
    /* Call I2C Slave complete process */
    I2C_ITSlaveCplt(hi2c, tmpITFlags);
 8007064:	693a      	ldr	r2, [r7, #16]
 8007066:	68fb      	ldr	r3, [r7, #12]
 8007068:	0011      	movs	r1, r2
 800706a:	0018      	movs	r0, r3
 800706c:	f000 fd0c 	bl	8007a88 <I2C_ITSlaveCplt>
  }

  if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_AF) != RESET) && \
 8007070:	693b      	ldr	r3, [r7, #16]
 8007072:	091b      	lsrs	r3, r3, #4
 8007074:	001a      	movs	r2, r3
 8007076:	2301      	movs	r3, #1
 8007078:	4013      	ands	r3, r2
 800707a:	d054      	beq.n	8007126 <I2C_Slave_ISR_IT+0x106>
      (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_NACKI) != RESET))
 800707c:	687b      	ldr	r3, [r7, #4]
 800707e:	091b      	lsrs	r3, r3, #4
 8007080:	001a      	movs	r2, r3
 8007082:	2301      	movs	r3, #1
 8007084:	4013      	ands	r3, r2
  if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_AF) != RESET) && \
 8007086:	d04e      	beq.n	8007126 <I2C_Slave_ISR_IT+0x106>
  {
    /* 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)
 8007088:	68fb      	ldr	r3, [r7, #12]
 800708a:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 800708c:	b29b      	uxth	r3, r3
 800708e:	2b00      	cmp	r3, #0
 8007090:	d12d      	bne.n	80070ee <I2C_Slave_ISR_IT+0xce>
    {
      if ((hi2c->State == HAL_I2C_STATE_LISTEN) && (tmpoptions == I2C_FIRST_AND_LAST_FRAME))
 8007092:	68fb      	ldr	r3, [r7, #12]
 8007094:	2241      	movs	r2, #65	; 0x41
 8007096:	5c9b      	ldrb	r3, [r3, r2]
 8007098:	b2db      	uxtb	r3, r3
 800709a:	2b28      	cmp	r3, #40	; 0x28
 800709c:	d10b      	bne.n	80070b6 <I2C_Slave_ISR_IT+0x96>
 800709e:	697a      	ldr	r2, [r7, #20]
 80070a0:	2380      	movs	r3, #128	; 0x80
 80070a2:	049b      	lsls	r3, r3, #18
 80070a4:	429a      	cmp	r2, r3
 80070a6:	d106      	bne.n	80070b6 <I2C_Slave_ISR_IT+0x96>
        /* 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);
 80070a8:	693a      	ldr	r2, [r7, #16]
 80070aa:	68fb      	ldr	r3, [r7, #12]
 80070ac:	0011      	movs	r1, r2
 80070ae:	0018      	movs	r0, r3
 80070b0:	f000 fe0e 	bl	8007cd0 <I2C_ITListenCplt>
 80070b4:	e036      	b.n	8007124 <I2C_Slave_ISR_IT+0x104>
      }
      else if ((hi2c->State == HAL_I2C_STATE_BUSY_TX_LISTEN) && (tmpoptions != I2C_NO_OPTION_FRAME))
 80070b6:	68fb      	ldr	r3, [r7, #12]
 80070b8:	2241      	movs	r2, #65	; 0x41
 80070ba:	5c9b      	ldrb	r3, [r3, r2]
 80070bc:	b2db      	uxtb	r3, r3
 80070be:	2b29      	cmp	r3, #41	; 0x29
 80070c0:	d110      	bne.n	80070e4 <I2C_Slave_ISR_IT+0xc4>
 80070c2:	697b      	ldr	r3, [r7, #20]
 80070c4:	4a5f      	ldr	r2, [pc, #380]	; (8007244 <I2C_Slave_ISR_IT+0x224>)
 80070c6:	4293      	cmp	r3, r2
 80070c8:	d00c      	beq.n	80070e4 <I2C_Slave_ISR_IT+0xc4>
      {
        /* Clear NACK Flag */
        __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF);
 80070ca:	68fb      	ldr	r3, [r7, #12]
 80070cc:	681b      	ldr	r3, [r3, #0]
 80070ce:	2210      	movs	r2, #16
 80070d0:	61da      	str	r2, [r3, #28]

        /* Flush TX register */
        I2C_Flush_TXDR(hi2c);
 80070d2:	68fb      	ldr	r3, [r7, #12]
 80070d4:	0018      	movs	r0, r3
 80070d6:	f000 ff60 	bl	8007f9a <I2C_Flush_TXDR>

        /* Last Byte is Transmitted */
        /* Call I2C Slave Sequential complete process */
        I2C_ITSlaveSeqCplt(hi2c);
 80070da:	68fb      	ldr	r3, [r7, #12]
 80070dc:	0018      	movs	r0, r3
 80070de:	f000 fb9b 	bl	8007818 <I2C_ITSlaveSeqCplt>
 80070e2:	e01f      	b.n	8007124 <I2C_Slave_ISR_IT+0x104>
      }
      else
      {
        /* Clear NACK Flag */
        __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF);
 80070e4:	68fb      	ldr	r3, [r7, #12]
 80070e6:	681b      	ldr	r3, [r3, #0]
 80070e8:	2210      	movs	r2, #16
 80070ea:	61da      	str	r2, [r3, #28]
    if (hi2c->XferCount == 0U)
 80070ec:	e09d      	b.n	800722a <I2C_Slave_ISR_IT+0x20a>
    }
    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);
 80070ee:	68fb      	ldr	r3, [r7, #12]
 80070f0:	681b      	ldr	r3, [r3, #0]
 80070f2:	2210      	movs	r2, #16
 80070f4:	61da      	str	r2, [r3, #28]

      /* Set ErrorCode corresponding to a Non-Acknowledge */
      hi2c->ErrorCode |= HAL_I2C_ERROR_AF;
 80070f6:	68fb      	ldr	r3, [r7, #12]
 80070f8:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 80070fa:	2204      	movs	r2, #4
 80070fc:	431a      	orrs	r2, r3
 80070fe:	68fb      	ldr	r3, [r7, #12]
 8007100:	645a      	str	r2, [r3, #68]	; 0x44

      if ((tmpoptions == I2C_FIRST_FRAME) || (tmpoptions == I2C_NEXT_FRAME))
 8007102:	697b      	ldr	r3, [r7, #20]
 8007104:	2b00      	cmp	r3, #0
 8007106:	d005      	beq.n	8007114 <I2C_Slave_ISR_IT+0xf4>
 8007108:	697a      	ldr	r2, [r7, #20]
 800710a:	2380      	movs	r3, #128	; 0x80
 800710c:	045b      	lsls	r3, r3, #17
 800710e:	429a      	cmp	r2, r3
 8007110:	d000      	beq.n	8007114 <I2C_Slave_ISR_IT+0xf4>
 8007112:	e08a      	b.n	800722a <I2C_Slave_ISR_IT+0x20a>
      {
        /* Call the corresponding callback to inform upper layer of End of Transfer */
        I2C_ITError(hi2c, hi2c->ErrorCode);
 8007114:	68fb      	ldr	r3, [r7, #12]
 8007116:	6c5a      	ldr	r2, [r3, #68]	; 0x44
 8007118:	68fb      	ldr	r3, [r7, #12]
 800711a:	0011      	movs	r1, r2
 800711c:	0018      	movs	r0, r3
 800711e:	f000 fe31 	bl	8007d84 <I2C_ITError>
    if (hi2c->XferCount == 0U)
 8007122:	e082      	b.n	800722a <I2C_Slave_ISR_IT+0x20a>
 8007124:	e081      	b.n	800722a <I2C_Slave_ISR_IT+0x20a>
      }
    }
  }
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_RXNE) != RESET) && \
 8007126:	693b      	ldr	r3, [r7, #16]
 8007128:	089b      	lsrs	r3, r3, #2
 800712a:	001a      	movs	r2, r3
 800712c:	2301      	movs	r3, #1
 800712e:	4013      	ands	r3, r2
 8007130:	d031      	beq.n	8007196 <I2C_Slave_ISR_IT+0x176>
           (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_RXI) != RESET))
 8007132:	687b      	ldr	r3, [r7, #4]
 8007134:	089b      	lsrs	r3, r3, #2
 8007136:	001a      	movs	r2, r3
 8007138:	2301      	movs	r3, #1
 800713a:	4013      	ands	r3, r2
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_RXNE) != RESET) && \
 800713c:	d02b      	beq.n	8007196 <I2C_Slave_ISR_IT+0x176>
  {
    if (hi2c->XferCount > 0U)
 800713e:	68fb      	ldr	r3, [r7, #12]
 8007140:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8007142:	b29b      	uxth	r3, r3
 8007144:	2b00      	cmp	r3, #0
 8007146:	d018      	beq.n	800717a <I2C_Slave_ISR_IT+0x15a>
    {
      /* Read data from RXDR */
      *hi2c->pBuffPtr = (uint8_t)hi2c->Instance->RXDR;
 8007148:	68fb      	ldr	r3, [r7, #12]
 800714a:	681b      	ldr	r3, [r3, #0]
 800714c:	6a5a      	ldr	r2, [r3, #36]	; 0x24
 800714e:	68fb      	ldr	r3, [r7, #12]
 8007150:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8007152:	b2d2      	uxtb	r2, r2
 8007154:	701a      	strb	r2, [r3, #0]

      /* Increment Buffer pointer */
      hi2c->pBuffPtr++;
 8007156:	68fb      	ldr	r3, [r7, #12]
 8007158:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 800715a:	1c5a      	adds	r2, r3, #1
 800715c:	68fb      	ldr	r3, [r7, #12]
 800715e:	625a      	str	r2, [r3, #36]	; 0x24

      hi2c->XferSize--;
 8007160:	68fb      	ldr	r3, [r7, #12]
 8007162:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8007164:	3b01      	subs	r3, #1
 8007166:	b29a      	uxth	r2, r3
 8007168:	68fb      	ldr	r3, [r7, #12]
 800716a:	851a      	strh	r2, [r3, #40]	; 0x28
      hi2c->XferCount--;
 800716c:	68fb      	ldr	r3, [r7, #12]
 800716e:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8007170:	b29b      	uxth	r3, r3
 8007172:	3b01      	subs	r3, #1
 8007174:	b29a      	uxth	r2, r3
 8007176:	68fb      	ldr	r3, [r7, #12]
 8007178:	855a      	strh	r2, [r3, #42]	; 0x2a
    }

    if ((hi2c->XferCount == 0U) && \
 800717a:	68fb      	ldr	r3, [r7, #12]
 800717c:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 800717e:	b29b      	uxth	r3, r3
 8007180:	2b00      	cmp	r3, #0
 8007182:	d154      	bne.n	800722e <I2C_Slave_ISR_IT+0x20e>
 8007184:	697b      	ldr	r3, [r7, #20]
 8007186:	4a2f      	ldr	r2, [pc, #188]	; (8007244 <I2C_Slave_ISR_IT+0x224>)
 8007188:	4293      	cmp	r3, r2
 800718a:	d050      	beq.n	800722e <I2C_Slave_ISR_IT+0x20e>
        (tmpoptions != I2C_NO_OPTION_FRAME))
    {
      /* Call I2C Slave Sequential complete process */
      I2C_ITSlaveSeqCplt(hi2c);
 800718c:	68fb      	ldr	r3, [r7, #12]
 800718e:	0018      	movs	r0, r3
 8007190:	f000 fb42 	bl	8007818 <I2C_ITSlaveSeqCplt>
    if ((hi2c->XferCount == 0U) && \
 8007194:	e04b      	b.n	800722e <I2C_Slave_ISR_IT+0x20e>
    }
  }
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_ADDR) != RESET) && \
 8007196:	693b      	ldr	r3, [r7, #16]
 8007198:	08db      	lsrs	r3, r3, #3
 800719a:	001a      	movs	r2, r3
 800719c:	2301      	movs	r3, #1
 800719e:	4013      	ands	r3, r2
 80071a0:	d00c      	beq.n	80071bc <I2C_Slave_ISR_IT+0x19c>
           (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_ADDRI) != RESET))
 80071a2:	687b      	ldr	r3, [r7, #4]
 80071a4:	08db      	lsrs	r3, r3, #3
 80071a6:	001a      	movs	r2, r3
 80071a8:	2301      	movs	r3, #1
 80071aa:	4013      	ands	r3, r2
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_ADDR) != RESET) && \
 80071ac:	d006      	beq.n	80071bc <I2C_Slave_ISR_IT+0x19c>
  {
    I2C_ITAddrCplt(hi2c, tmpITFlags);
 80071ae:	693a      	ldr	r2, [r7, #16]
 80071b0:	68fb      	ldr	r3, [r7, #12]
 80071b2:	0011      	movs	r1, r2
 80071b4:	0018      	movs	r0, r3
 80071b6:	f000 fa49 	bl	800764c <I2C_ITAddrCplt>
 80071ba:	e039      	b.n	8007230 <I2C_Slave_ISR_IT+0x210>
  }
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_TXIS) != RESET) && \
 80071bc:	693b      	ldr	r3, [r7, #16]
 80071be:	085b      	lsrs	r3, r3, #1
 80071c0:	001a      	movs	r2, r3
 80071c2:	2301      	movs	r3, #1
 80071c4:	4013      	ands	r3, r2
 80071c6:	d033      	beq.n	8007230 <I2C_Slave_ISR_IT+0x210>
           (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_TXI) != RESET))
 80071c8:	687b      	ldr	r3, [r7, #4]
 80071ca:	085b      	lsrs	r3, r3, #1
 80071cc:	001a      	movs	r2, r3
 80071ce:	2301      	movs	r3, #1
 80071d0:	4013      	ands	r3, r2
  else if ((I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_TXIS) != RESET) && \
 80071d2:	d02d      	beq.n	8007230 <I2C_Slave_ISR_IT+0x210>
  {
    /* 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)
 80071d4:	68fb      	ldr	r3, [r7, #12]
 80071d6:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 80071d8:	b29b      	uxth	r3, r3
 80071da:	2b00      	cmp	r3, #0
 80071dc:	d018      	beq.n	8007210 <I2C_Slave_ISR_IT+0x1f0>
    {
      /* Write data to TXDR */
      hi2c->Instance->TXDR = *hi2c->pBuffPtr;
 80071de:	68fb      	ldr	r3, [r7, #12]
 80071e0:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 80071e2:	781a      	ldrb	r2, [r3, #0]
 80071e4:	68fb      	ldr	r3, [r7, #12]
 80071e6:	681b      	ldr	r3, [r3, #0]
 80071e8:	629a      	str	r2, [r3, #40]	; 0x28

      /* Increment Buffer pointer */
      hi2c->pBuffPtr++;
 80071ea:	68fb      	ldr	r3, [r7, #12]
 80071ec:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 80071ee:	1c5a      	adds	r2, r3, #1
 80071f0:	68fb      	ldr	r3, [r7, #12]
 80071f2:	625a      	str	r2, [r3, #36]	; 0x24

      hi2c->XferCount--;
 80071f4:	68fb      	ldr	r3, [r7, #12]
 80071f6:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 80071f8:	b29b      	uxth	r3, r3
 80071fa:	3b01      	subs	r3, #1
 80071fc:	b29a      	uxth	r2, r3
 80071fe:	68fb      	ldr	r3, [r7, #12]
 8007200:	855a      	strh	r2, [r3, #42]	; 0x2a
      hi2c->XferSize--;
 8007202:	68fb      	ldr	r3, [r7, #12]
 8007204:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8007206:	3b01      	subs	r3, #1
 8007208:	b29a      	uxth	r2, r3
 800720a:	68fb      	ldr	r3, [r7, #12]
 800720c:	851a      	strh	r2, [r3, #40]	; 0x28
 800720e:	e00f      	b.n	8007230 <I2C_Slave_ISR_IT+0x210>
    }
    else
    {
      if ((tmpoptions == I2C_NEXT_FRAME) || (tmpoptions == I2C_FIRST_FRAME))
 8007210:	697a      	ldr	r2, [r7, #20]
 8007212:	2380      	movs	r3, #128	; 0x80
 8007214:	045b      	lsls	r3, r3, #17
 8007216:	429a      	cmp	r2, r3
 8007218:	d002      	beq.n	8007220 <I2C_Slave_ISR_IT+0x200>
 800721a:	697b      	ldr	r3, [r7, #20]
 800721c:	2b00      	cmp	r3, #0
 800721e:	d107      	bne.n	8007230 <I2C_Slave_ISR_IT+0x210>
      {
        /* Last Byte is Transmitted */
        /* Call I2C Slave Sequential complete process */
        I2C_ITSlaveSeqCplt(hi2c);
 8007220:	68fb      	ldr	r3, [r7, #12]
 8007222:	0018      	movs	r0, r3
 8007224:	f000 faf8 	bl	8007818 <I2C_ITSlaveSeqCplt>
 8007228:	e002      	b.n	8007230 <I2C_Slave_ISR_IT+0x210>
    if (hi2c->XferCount == 0U)
 800722a:	46c0      	nop			; (mov r8, r8)
 800722c:	e000      	b.n	8007230 <I2C_Slave_ISR_IT+0x210>
    if ((hi2c->XferCount == 0U) && \
 800722e:	46c0      	nop			; (mov r8, r8)
  {
    /* Nothing to do */
  }

  /* Process Unlocked */
  __HAL_UNLOCK(hi2c);
 8007230:	68fb      	ldr	r3, [r7, #12]
 8007232:	2240      	movs	r2, #64	; 0x40
 8007234:	2100      	movs	r1, #0
 8007236:	5499      	strb	r1, [r3, r2]

  return HAL_OK;
 8007238:	2300      	movs	r3, #0
}
 800723a:	0018      	movs	r0, r3
 800723c:	46bd      	mov	sp, r7
 800723e:	b006      	add	sp, #24
 8007240:	bd80      	pop	{r7, pc}
 8007242:	46c0      	nop			; (mov r8, r8)
 8007244:	ffff0000 	.word	0xffff0000

08007248 <I2C_Master_ISR_DMA>:
  * @param  ITSources Interrupt sources enabled.
  * @retval HAL status
  */
static HAL_StatusTypeDef I2C_Master_ISR_DMA(struct __I2C_HandleTypeDef *hi2c, uint32_t ITFlags,
                                            uint32_t ITSources)
{
 8007248:	b590      	push	{r4, r7, lr}
 800724a:	b089      	sub	sp, #36	; 0x24
 800724c:	af02      	add	r7, sp, #8
 800724e:	60f8      	str	r0, [r7, #12]
 8007250:	60b9      	str	r1, [r7, #8]
 8007252:	607a      	str	r2, [r7, #4]
  uint16_t devaddress;
  uint32_t xfermode;

  /* Process Locked */
  __HAL_LOCK(hi2c);
 8007254:	68fb      	ldr	r3, [r7, #12]
 8007256:	2240      	movs	r2, #64	; 0x40
 8007258:	5c9b      	ldrb	r3, [r3, r2]
 800725a:	2b01      	cmp	r3, #1
 800725c:	d101      	bne.n	8007262 <I2C_Master_ISR_DMA+0x1a>
 800725e:	2302      	movs	r3, #2
 8007260:	e0f7      	b.n	8007452 <I2C_Master_ISR_DMA+0x20a>
 8007262:	68fb      	ldr	r3, [r7, #12]
 8007264:	2240      	movs	r2, #64	; 0x40
 8007266:	2101      	movs	r1, #1
 8007268:	5499      	strb	r1, [r3, r2]

  if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_AF) != RESET) && \
 800726a:	68bb      	ldr	r3, [r7, #8]
 800726c:	091b      	lsrs	r3, r3, #4
 800726e:	001a      	movs	r2, r3
 8007270:	2301      	movs	r3, #1
 8007272:	4013      	ands	r3, r2
 8007274:	d019      	beq.n	80072aa <I2C_Master_ISR_DMA+0x62>
      (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_NACKI) != RESET))
 8007276:	687b      	ldr	r3, [r7, #4]
 8007278:	091b      	lsrs	r3, r3, #4
 800727a:	001a      	movs	r2, r3
 800727c:	2301      	movs	r3, #1
 800727e:	4013      	ands	r3, r2
  if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_AF) != RESET) && \
 8007280:	d013      	beq.n	80072aa <I2C_Master_ISR_DMA+0x62>
  {
    /* Clear NACK Flag */
    __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF);
 8007282:	68fb      	ldr	r3, [r7, #12]
 8007284:	681b      	ldr	r3, [r3, #0]
 8007286:	2210      	movs	r2, #16
 8007288:	61da      	str	r2, [r3, #28]

    /* Set corresponding Error Code */
    hi2c->ErrorCode |= HAL_I2C_ERROR_AF;
 800728a:	68fb      	ldr	r3, [r7, #12]
 800728c:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 800728e:	2204      	movs	r2, #4
 8007290:	431a      	orrs	r2, r3
 8007292:	68fb      	ldr	r3, [r7, #12]
 8007294:	645a      	str	r2, [r3, #68]	; 0x44

    /* No need to generate STOP, it is automatically done */
    /* But enable STOP interrupt, to treat it */
    /* Error callback will be send during stop flag treatment */
    I2C_Enable_IRQ(hi2c, I2C_XFER_CPLT_IT);
 8007296:	68fb      	ldr	r3, [r7, #12]
 8007298:	2120      	movs	r1, #32
 800729a:	0018      	movs	r0, r3
 800729c:	f000 fef4 	bl	8008088 <I2C_Enable_IRQ>

    /* Flush TX register */
    I2C_Flush_TXDR(hi2c);
 80072a0:	68fb      	ldr	r3, [r7, #12]
 80072a2:	0018      	movs	r0, r3
 80072a4:	f000 fe79 	bl	8007f9a <I2C_Flush_TXDR>
 80072a8:	e0ce      	b.n	8007448 <I2C_Master_ISR_DMA+0x200>
  }
  else if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_TCR) != RESET) && \
 80072aa:	68bb      	ldr	r3, [r7, #8]
 80072ac:	09db      	lsrs	r3, r3, #7
 80072ae:	001a      	movs	r2, r3
 80072b0:	2301      	movs	r3, #1
 80072b2:	4013      	ands	r3, r2
 80072b4:	d100      	bne.n	80072b8 <I2C_Master_ISR_DMA+0x70>
 80072b6:	e07e      	b.n	80073b6 <I2C_Master_ISR_DMA+0x16e>
           (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_TCI) != RESET))
 80072b8:	687b      	ldr	r3, [r7, #4]
 80072ba:	099b      	lsrs	r3, r3, #6
 80072bc:	001a      	movs	r2, r3
 80072be:	2301      	movs	r3, #1
 80072c0:	4013      	ands	r3, r2
  else if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_TCR) != RESET) && \
 80072c2:	d100      	bne.n	80072c6 <I2C_Master_ISR_DMA+0x7e>
 80072c4:	e077      	b.n	80073b6 <I2C_Master_ISR_DMA+0x16e>
  {
    /* Disable TC interrupt */
    __HAL_I2C_DISABLE_IT(hi2c, I2C_IT_TCI);
 80072c6:	68fb      	ldr	r3, [r7, #12]
 80072c8:	681b      	ldr	r3, [r3, #0]
 80072ca:	681a      	ldr	r2, [r3, #0]
 80072cc:	68fb      	ldr	r3, [r7, #12]
 80072ce:	681b      	ldr	r3, [r3, #0]
 80072d0:	2140      	movs	r1, #64	; 0x40
 80072d2:	438a      	bics	r2, r1
 80072d4:	601a      	str	r2, [r3, #0]

    if (hi2c->XferCount != 0U)
 80072d6:	68fb      	ldr	r3, [r7, #12]
 80072d8:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 80072da:	b29b      	uxth	r3, r3
 80072dc:	2b00      	cmp	r3, #0
 80072de:	d055      	beq.n	800738c <I2C_Master_ISR_DMA+0x144>
    {
      /* Recover Slave address */
      devaddress = (uint16_t)(hi2c->Instance->CR2 & I2C_CR2_SADD);
 80072e0:	68fb      	ldr	r3, [r7, #12]
 80072e2:	681b      	ldr	r3, [r3, #0]
 80072e4:	685b      	ldr	r3, [r3, #4]
 80072e6:	b29a      	uxth	r2, r3
 80072e8:	2312      	movs	r3, #18
 80072ea:	18fb      	adds	r3, r7, r3
 80072ec:	0592      	lsls	r2, r2, #22
 80072ee:	0d92      	lsrs	r2, r2, #22
 80072f0:	801a      	strh	r2, [r3, #0]

      /* Prepare the new XferSize to transfer */
      if (hi2c->XferCount > MAX_NBYTE_SIZE)
 80072f2:	68fb      	ldr	r3, [r7, #12]
 80072f4:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 80072f6:	b29b      	uxth	r3, r3
 80072f8:	2bff      	cmp	r3, #255	; 0xff
 80072fa:	d906      	bls.n	800730a <I2C_Master_ISR_DMA+0xc2>
      {
        hi2c->XferSize = MAX_NBYTE_SIZE;
 80072fc:	68fb      	ldr	r3, [r7, #12]
 80072fe:	22ff      	movs	r2, #255	; 0xff
 8007300:	851a      	strh	r2, [r3, #40]	; 0x28
        xfermode = I2C_RELOAD_MODE;
 8007302:	2380      	movs	r3, #128	; 0x80
 8007304:	045b      	lsls	r3, r3, #17
 8007306:	617b      	str	r3, [r7, #20]
 8007308:	e010      	b.n	800732c <I2C_Master_ISR_DMA+0xe4>
      }
      else
      {
        hi2c->XferSize = hi2c->XferCount;
 800730a:	68fb      	ldr	r3, [r7, #12]
 800730c:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 800730e:	b29a      	uxth	r2, r3
 8007310:	68fb      	ldr	r3, [r7, #12]
 8007312:	851a      	strh	r2, [r3, #40]	; 0x28
        if (hi2c->XferOptions != I2C_NO_OPTION_FRAME)
 8007314:	68fb      	ldr	r3, [r7, #12]
 8007316:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8007318:	4a50      	ldr	r2, [pc, #320]	; (800745c <I2C_Master_ISR_DMA+0x214>)
 800731a:	4293      	cmp	r3, r2
 800731c:	d003      	beq.n	8007326 <I2C_Master_ISR_DMA+0xde>
        {
          xfermode = hi2c->XferOptions;
 800731e:	68fb      	ldr	r3, [r7, #12]
 8007320:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8007322:	617b      	str	r3, [r7, #20]
 8007324:	e002      	b.n	800732c <I2C_Master_ISR_DMA+0xe4>
        }
        else
        {
          xfermode = I2C_AUTOEND_MODE;
 8007326:	2380      	movs	r3, #128	; 0x80
 8007328:	049b      	lsls	r3, r3, #18
 800732a:	617b      	str	r3, [r7, #20]
        }
      }

      /* Set the new XferSize in Nbytes register */
      I2C_TransferConfig(hi2c, devaddress, (uint8_t)hi2c->XferSize, xfermode, I2C_NO_STARTSTOP);
 800732c:	68fb      	ldr	r3, [r7, #12]
 800732e:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8007330:	b2da      	uxtb	r2, r3
 8007332:	697c      	ldr	r4, [r7, #20]
 8007334:	2312      	movs	r3, #18
 8007336:	18fb      	adds	r3, r7, r3
 8007338:	8819      	ldrh	r1, [r3, #0]
 800733a:	68f8      	ldr	r0, [r7, #12]
 800733c:	2300      	movs	r3, #0
 800733e:	9300      	str	r3, [sp, #0]
 8007340:	0023      	movs	r3, r4
 8007342:	f000 fe6b 	bl	800801c <I2C_TransferConfig>

      /* Update XferCount value */
      hi2c->XferCount -= hi2c->XferSize;
 8007346:	68fb      	ldr	r3, [r7, #12]
 8007348:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 800734a:	b29a      	uxth	r2, r3
 800734c:	68fb      	ldr	r3, [r7, #12]
 800734e:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8007350:	1ad3      	subs	r3, r2, r3
 8007352:	b29a      	uxth	r2, r3
 8007354:	68fb      	ldr	r3, [r7, #12]
 8007356:	855a      	strh	r2, [r3, #42]	; 0x2a

      /* Enable DMA Request */
      if (hi2c->State == HAL_I2C_STATE_BUSY_RX)
 8007358:	68fb      	ldr	r3, [r7, #12]
 800735a:	2241      	movs	r2, #65	; 0x41
 800735c:	5c9b      	ldrb	r3, [r3, r2]
 800735e:	b2db      	uxtb	r3, r3
 8007360:	2b22      	cmp	r3, #34	; 0x22
 8007362:	d109      	bne.n	8007378 <I2C_Master_ISR_DMA+0x130>
      {
        hi2c->Instance->CR1 |= I2C_CR1_RXDMAEN;
 8007364:	68fb      	ldr	r3, [r7, #12]
 8007366:	681b      	ldr	r3, [r3, #0]
 8007368:	681a      	ldr	r2, [r3, #0]
 800736a:	68fb      	ldr	r3, [r7, #12]
 800736c:	681b      	ldr	r3, [r3, #0]
 800736e:	2180      	movs	r1, #128	; 0x80
 8007370:	0209      	lsls	r1, r1, #8
 8007372:	430a      	orrs	r2, r1
 8007374:	601a      	str	r2, [r3, #0]
    if (hi2c->XferCount != 0U)
 8007376:	e067      	b.n	8007448 <I2C_Master_ISR_DMA+0x200>
      }
      else
      {
        hi2c->Instance->CR1 |= I2C_CR1_TXDMAEN;
 8007378:	68fb      	ldr	r3, [r7, #12]
 800737a:	681b      	ldr	r3, [r3, #0]
 800737c:	681a      	ldr	r2, [r3, #0]
 800737e:	68fb      	ldr	r3, [r7, #12]
 8007380:	681b      	ldr	r3, [r3, #0]
 8007382:	2180      	movs	r1, #128	; 0x80
 8007384:	01c9      	lsls	r1, r1, #7
 8007386:	430a      	orrs	r2, r1
 8007388:	601a      	str	r2, [r3, #0]
    if (hi2c->XferCount != 0U)
 800738a:	e05d      	b.n	8007448 <I2C_Master_ISR_DMA+0x200>
      }
    }
    else
    {
      /* Call TxCpltCallback() if no stop mode is set */
      if (I2C_GET_STOP_MODE(hi2c) != I2C_AUTOEND_MODE)
 800738c:	68fb      	ldr	r3, [r7, #12]
 800738e:	681b      	ldr	r3, [r3, #0]
 8007390:	685a      	ldr	r2, [r3, #4]
 8007392:	2380      	movs	r3, #128	; 0x80
 8007394:	049b      	lsls	r3, r3, #18
 8007396:	401a      	ands	r2, r3
 8007398:	2380      	movs	r3, #128	; 0x80
 800739a:	049b      	lsls	r3, r3, #18
 800739c:	429a      	cmp	r2, r3
 800739e:	d004      	beq.n	80073aa <I2C_Master_ISR_DMA+0x162>
      {
        /* Call I2C Master Sequential complete process */
        I2C_ITMasterSeqCplt(hi2c);
 80073a0:	68fb      	ldr	r3, [r7, #12]
 80073a2:	0018      	movs	r0, r3
 80073a4:	f000 f9f6 	bl	8007794 <I2C_ITMasterSeqCplt>
    if (hi2c->XferCount != 0U)
 80073a8:	e04e      	b.n	8007448 <I2C_Master_ISR_DMA+0x200>
      }
      else
      {
        /* Wrong size Status regarding TCR flag event */
        /* Call the corresponding callback to inform upper layer of End of Transfer */
        I2C_ITError(hi2c, HAL_I2C_ERROR_SIZE);
 80073aa:	68fb      	ldr	r3, [r7, #12]
 80073ac:	2140      	movs	r1, #64	; 0x40
 80073ae:	0018      	movs	r0, r3
 80073b0:	f000 fce8 	bl	8007d84 <I2C_ITError>
    if (hi2c->XferCount != 0U)
 80073b4:	e048      	b.n	8007448 <I2C_Master_ISR_DMA+0x200>
      }
    }
  }
  else if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_TC) != RESET) && \
 80073b6:	68bb      	ldr	r3, [r7, #8]
 80073b8:	099b      	lsrs	r3, r3, #6
 80073ba:	001a      	movs	r2, r3
 80073bc:	2301      	movs	r3, #1
 80073be:	4013      	ands	r3, r2
 80073c0:	d02e      	beq.n	8007420 <I2C_Master_ISR_DMA+0x1d8>
           (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_TCI) != RESET))
 80073c2:	687b      	ldr	r3, [r7, #4]
 80073c4:	099b      	lsrs	r3, r3, #6
 80073c6:	001a      	movs	r2, r3
 80073c8:	2301      	movs	r3, #1
 80073ca:	4013      	ands	r3, r2
  else if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_TC) != RESET) && \
 80073cc:	d028      	beq.n	8007420 <I2C_Master_ISR_DMA+0x1d8>
  {
    if (hi2c->XferCount == 0U)
 80073ce:	68fb      	ldr	r3, [r7, #12]
 80073d0:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 80073d2:	b29b      	uxth	r3, r3
 80073d4:	2b00      	cmp	r3, #0
 80073d6:	d11d      	bne.n	8007414 <I2C_Master_ISR_DMA+0x1cc>
    {
      if (I2C_GET_STOP_MODE(hi2c) != I2C_AUTOEND_MODE)
 80073d8:	68fb      	ldr	r3, [r7, #12]
 80073da:	681b      	ldr	r3, [r3, #0]
 80073dc:	685a      	ldr	r2, [r3, #4]
 80073de:	2380      	movs	r3, #128	; 0x80
 80073e0:	049b      	lsls	r3, r3, #18
 80073e2:	401a      	ands	r2, r3
 80073e4:	2380      	movs	r3, #128	; 0x80
 80073e6:	049b      	lsls	r3, r3, #18
 80073e8:	429a      	cmp	r2, r3
 80073ea:	d02c      	beq.n	8007446 <I2C_Master_ISR_DMA+0x1fe>
      {
        /* Generate a stop condition in case of no transfer option */
        if (hi2c->XferOptions == I2C_NO_OPTION_FRAME)
 80073ec:	68fb      	ldr	r3, [r7, #12]
 80073ee:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 80073f0:	4a1a      	ldr	r2, [pc, #104]	; (800745c <I2C_Master_ISR_DMA+0x214>)
 80073f2:	4293      	cmp	r3, r2
 80073f4:	d109      	bne.n	800740a <I2C_Master_ISR_DMA+0x1c2>
        {
          /* Generate Stop */
          hi2c->Instance->CR2 |= I2C_CR2_STOP;
 80073f6:	68fb      	ldr	r3, [r7, #12]
 80073f8:	681b      	ldr	r3, [r3, #0]
 80073fa:	685a      	ldr	r2, [r3, #4]
 80073fc:	68fb      	ldr	r3, [r7, #12]
 80073fe:	681b      	ldr	r3, [r3, #0]
 8007400:	2180      	movs	r1, #128	; 0x80
 8007402:	01c9      	lsls	r1, r1, #7
 8007404:	430a      	orrs	r2, r1
 8007406:	605a      	str	r2, [r3, #4]
    if (hi2c->XferCount == 0U)
 8007408:	e01d      	b.n	8007446 <I2C_Master_ISR_DMA+0x1fe>
        }
        else
        {
          /* Call I2C Master Sequential complete process */
          I2C_ITMasterSeqCplt(hi2c);
 800740a:	68fb      	ldr	r3, [r7, #12]
 800740c:	0018      	movs	r0, r3
 800740e:	f000 f9c1 	bl	8007794 <I2C_ITMasterSeqCplt>
    if (hi2c->XferCount == 0U)
 8007412:	e018      	b.n	8007446 <I2C_Master_ISR_DMA+0x1fe>
    }
    else
    {
      /* Wrong size Status regarding TC flag event */
      /* Call the corresponding callback to inform upper layer of End of Transfer */
      I2C_ITError(hi2c, HAL_I2C_ERROR_SIZE);
 8007414:	68fb      	ldr	r3, [r7, #12]
 8007416:	2140      	movs	r1, #64	; 0x40
 8007418:	0018      	movs	r0, r3
 800741a:	f000 fcb3 	bl	8007d84 <I2C_ITError>
    if (hi2c->XferCount == 0U)
 800741e:	e012      	b.n	8007446 <I2C_Master_ISR_DMA+0x1fe>
    }
  }
  else if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_STOPF) != RESET) && \
 8007420:	68bb      	ldr	r3, [r7, #8]
 8007422:	095b      	lsrs	r3, r3, #5
 8007424:	001a      	movs	r2, r3
 8007426:	2301      	movs	r3, #1
 8007428:	4013      	ands	r3, r2
 800742a:	d00d      	beq.n	8007448 <I2C_Master_ISR_DMA+0x200>
           (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_STOPI) != RESET))
 800742c:	687b      	ldr	r3, [r7, #4]
 800742e:	095b      	lsrs	r3, r3, #5
 8007430:	001a      	movs	r2, r3
 8007432:	2301      	movs	r3, #1
 8007434:	4013      	ands	r3, r2
  else if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_STOPF) != RESET) && \
 8007436:	d007      	beq.n	8007448 <I2C_Master_ISR_DMA+0x200>
  {
    /* Call I2C Master complete process */
    I2C_ITMasterCplt(hi2c, ITFlags);
 8007438:	68ba      	ldr	r2, [r7, #8]
 800743a:	68fb      	ldr	r3, [r7, #12]
 800743c:	0011      	movs	r1, r2
 800743e:	0018      	movs	r0, r3
 8007440:	f000 fa50 	bl	80078e4 <I2C_ITMasterCplt>
 8007444:	e000      	b.n	8007448 <I2C_Master_ISR_DMA+0x200>
    if (hi2c->XferCount == 0U)
 8007446:	46c0      	nop			; (mov r8, r8)
  {
    /* Nothing to do */
  }

  /* Process Unlocked */
  __HAL_UNLOCK(hi2c);
 8007448:	68fb      	ldr	r3, [r7, #12]
 800744a:	2240      	movs	r2, #64	; 0x40
 800744c:	2100      	movs	r1, #0
 800744e:	5499      	strb	r1, [r3, r2]

  return HAL_OK;
 8007450:	2300      	movs	r3, #0
}
 8007452:	0018      	movs	r0, r3
 8007454:	46bd      	mov	sp, r7
 8007456:	b007      	add	sp, #28
 8007458:	bd90      	pop	{r4, r7, pc}
 800745a:	46c0      	nop			; (mov r8, r8)
 800745c:	ffff0000 	.word	0xffff0000

08007460 <I2C_Slave_ISR_DMA>:
  * @param  ITSources Interrupt sources enabled.
  * @retval HAL status
  */
static HAL_StatusTypeDef I2C_Slave_ISR_DMA(struct __I2C_HandleTypeDef *hi2c, uint32_t ITFlags,
                                           uint32_t ITSources)
{
 8007460:	b580      	push	{r7, lr}
 8007462:	b088      	sub	sp, #32
 8007464:	af00      	add	r7, sp, #0
 8007466:	60f8      	str	r0, [r7, #12]
 8007468:	60b9      	str	r1, [r7, #8]
 800746a:	607a      	str	r2, [r7, #4]
  uint32_t tmpoptions = hi2c->XferOptions;
 800746c:	68fb      	ldr	r3, [r7, #12]
 800746e:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8007470:	61bb      	str	r3, [r7, #24]
  uint32_t treatdmanack = 0U;
 8007472:	2300      	movs	r3, #0
 8007474:	61fb      	str	r3, [r7, #28]
  HAL_I2C_StateTypeDef tmpstate;

  /* Process locked */
  __HAL_LOCK(hi2c);
 8007476:	68fb      	ldr	r3, [r7, #12]
 8007478:	2240      	movs	r2, #64	; 0x40
 800747a:	5c9b      	ldrb	r3, [r3, r2]
 800747c:	2b01      	cmp	r3, #1
 800747e:	d101      	bne.n	8007484 <I2C_Slave_ISR_DMA+0x24>
 8007480:	2302      	movs	r3, #2
 8007482:	e0dd      	b.n	8007640 <I2C_Slave_ISR_DMA+0x1e0>
 8007484:	68fb      	ldr	r3, [r7, #12]
 8007486:	2240      	movs	r2, #64	; 0x40
 8007488:	2101      	movs	r1, #1
 800748a:	5499      	strb	r1, [r3, r2]

  /* Check if STOPF is set */
  if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_STOPF) != RESET) && \
 800748c:	68bb      	ldr	r3, [r7, #8]
 800748e:	095b      	lsrs	r3, r3, #5
 8007490:	001a      	movs	r2, r3
 8007492:	2301      	movs	r3, #1
 8007494:	4013      	ands	r3, r2
 8007496:	d00b      	beq.n	80074b0 <I2C_Slave_ISR_DMA+0x50>
      (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_STOPI) != RESET))
 8007498:	687b      	ldr	r3, [r7, #4]
 800749a:	095b      	lsrs	r3, r3, #5
 800749c:	001a      	movs	r2, r3
 800749e:	2301      	movs	r3, #1
 80074a0:	4013      	ands	r3, r2
  if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_STOPF) != RESET) && \
 80074a2:	d005      	beq.n	80074b0 <I2C_Slave_ISR_DMA+0x50>
  {
    /* Call I2C Slave complete process */
    I2C_ITSlaveCplt(hi2c, ITFlags);
 80074a4:	68ba      	ldr	r2, [r7, #8]
 80074a6:	68fb      	ldr	r3, [r7, #12]
 80074a8:	0011      	movs	r1, r2
 80074aa:	0018      	movs	r0, r3
 80074ac:	f000 faec 	bl	8007a88 <I2C_ITSlaveCplt>
  }

  if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_AF) != RESET) && \
 80074b0:	68bb      	ldr	r3, [r7, #8]
 80074b2:	091b      	lsrs	r3, r3, #4
 80074b4:	001a      	movs	r2, r3
 80074b6:	2301      	movs	r3, #1
 80074b8:	4013      	ands	r3, r2
 80074ba:	d100      	bne.n	80074be <I2C_Slave_ISR_DMA+0x5e>
 80074bc:	e0a9      	b.n	8007612 <I2C_Slave_ISR_DMA+0x1b2>
      (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_NACKI) != RESET))
 80074be:	687b      	ldr	r3, [r7, #4]
 80074c0:	091b      	lsrs	r3, r3, #4
 80074c2:	001a      	movs	r2, r3
 80074c4:	2301      	movs	r3, #1
 80074c6:	4013      	ands	r3, r2
  if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_AF) != RESET) && \
 80074c8:	d100      	bne.n	80074cc <I2C_Slave_ISR_DMA+0x6c>
 80074ca:	e0a2      	b.n	8007612 <I2C_Slave_ISR_DMA+0x1b2>
  {
    /* 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 ((I2C_CHECK_IT_SOURCE(ITSources, I2C_CR1_TXDMAEN) != RESET) ||
 80074cc:	687b      	ldr	r3, [r7, #4]
 80074ce:	0b9b      	lsrs	r3, r3, #14
 80074d0:	001a      	movs	r2, r3
 80074d2:	2301      	movs	r3, #1
 80074d4:	4013      	ands	r3, r2
 80074d6:	d106      	bne.n	80074e6 <I2C_Slave_ISR_DMA+0x86>
        (I2C_CHECK_IT_SOURCE(ITSources, I2C_CR1_RXDMAEN) != RESET))
 80074d8:	687b      	ldr	r3, [r7, #4]
 80074da:	0bdb      	lsrs	r3, r3, #15
 80074dc:	001a      	movs	r2, r3
 80074de:	2301      	movs	r3, #1
 80074e0:	4013      	ands	r3, r2
    if ((I2C_CHECK_IT_SOURCE(ITSources, I2C_CR1_TXDMAEN) != RESET) ||
 80074e2:	d100      	bne.n	80074e6 <I2C_Slave_ISR_DMA+0x86>
 80074e4:	e08e      	b.n	8007604 <I2C_Slave_ISR_DMA+0x1a4>
    {
      /* Split check of hdmarx, for MISRA compliance */
      if (hi2c->hdmarx != NULL)
 80074e6:	68fb      	ldr	r3, [r7, #12]
 80074e8:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 80074ea:	2b00      	cmp	r3, #0
 80074ec:	d00d      	beq.n	800750a <I2C_Slave_ISR_DMA+0xaa>
      {
        if (I2C_CHECK_IT_SOURCE(ITSources, I2C_CR1_RXDMAEN) != RESET)
 80074ee:	687b      	ldr	r3, [r7, #4]
 80074f0:	0bdb      	lsrs	r3, r3, #15
 80074f2:	001a      	movs	r2, r3
 80074f4:	2301      	movs	r3, #1
 80074f6:	4013      	ands	r3, r2
 80074f8:	d007      	beq.n	800750a <I2C_Slave_ISR_DMA+0xaa>
        {
          if (__HAL_DMA_GET_COUNTER(hi2c->hdmarx) == 0U)
 80074fa:	68fb      	ldr	r3, [r7, #12]
 80074fc:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 80074fe:	681b      	ldr	r3, [r3, #0]
 8007500:	685b      	ldr	r3, [r3, #4]
 8007502:	2b00      	cmp	r3, #0
 8007504:	d101      	bne.n	800750a <I2C_Slave_ISR_DMA+0xaa>
          {
            treatdmanack = 1U;
 8007506:	2301      	movs	r3, #1
 8007508:	61fb      	str	r3, [r7, #28]
          }
        }
      }

      /* Split check of hdmatx, for MISRA compliance  */
      if (hi2c->hdmatx != NULL)
 800750a:	68fb      	ldr	r3, [r7, #12]
 800750c:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 800750e:	2b00      	cmp	r3, #0
 8007510:	d00d      	beq.n	800752e <I2C_Slave_ISR_DMA+0xce>
      {
        if (I2C_CHECK_IT_SOURCE(ITSources, I2C_CR1_TXDMAEN) != RESET)
 8007512:	687b      	ldr	r3, [r7, #4]
 8007514:	0b9b      	lsrs	r3, r3, #14
 8007516:	001a      	movs	r2, r3
 8007518:	2301      	movs	r3, #1
 800751a:	4013      	ands	r3, r2
 800751c:	d007      	beq.n	800752e <I2C_Slave_ISR_DMA+0xce>
        {
          if (__HAL_DMA_GET_COUNTER(hi2c->hdmatx) == 0U)
 800751e:	68fb      	ldr	r3, [r7, #12]
 8007520:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8007522:	681b      	ldr	r3, [r3, #0]
 8007524:	685b      	ldr	r3, [r3, #4]
 8007526:	2b00      	cmp	r3, #0
 8007528:	d101      	bne.n	800752e <I2C_Slave_ISR_DMA+0xce>
          {
            treatdmanack = 1U;
 800752a:	2301      	movs	r3, #1
 800752c:	61fb      	str	r3, [r7, #28]
          }
        }
      }

      if (treatdmanack == 1U)
 800752e:	69fb      	ldr	r3, [r7, #28]
 8007530:	2b01      	cmp	r3, #1
 8007532:	d12d      	bne.n	8007590 <I2C_Slave_ISR_DMA+0x130>
      {
        if ((hi2c->State == HAL_I2C_STATE_LISTEN) && (tmpoptions == I2C_FIRST_AND_LAST_FRAME))
 8007534:	68fb      	ldr	r3, [r7, #12]
 8007536:	2241      	movs	r2, #65	; 0x41
 8007538:	5c9b      	ldrb	r3, [r3, r2]
 800753a:	b2db      	uxtb	r3, r3
 800753c:	2b28      	cmp	r3, #40	; 0x28
 800753e:	d10b      	bne.n	8007558 <I2C_Slave_ISR_DMA+0xf8>
 8007540:	69ba      	ldr	r2, [r7, #24]
 8007542:	2380      	movs	r3, #128	; 0x80
 8007544:	049b      	lsls	r3, r3, #18
 8007546:	429a      	cmp	r2, r3
 8007548:	d106      	bne.n	8007558 <I2C_Slave_ISR_DMA+0xf8>
          /* 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, ITFlags);
 800754a:	68ba      	ldr	r2, [r7, #8]
 800754c:	68fb      	ldr	r3, [r7, #12]
 800754e:	0011      	movs	r1, r2
 8007550:	0018      	movs	r0, r3
 8007552:	f000 fbbd 	bl	8007cd0 <I2C_ITListenCplt>
 8007556:	e054      	b.n	8007602 <I2C_Slave_ISR_DMA+0x1a2>
        }
        else if ((hi2c->State == HAL_I2C_STATE_BUSY_TX_LISTEN) && (tmpoptions != I2C_NO_OPTION_FRAME))
 8007558:	68fb      	ldr	r3, [r7, #12]
 800755a:	2241      	movs	r2, #65	; 0x41
 800755c:	5c9b      	ldrb	r3, [r3, r2]
 800755e:	b2db      	uxtb	r3, r3
 8007560:	2b29      	cmp	r3, #41	; 0x29
 8007562:	d110      	bne.n	8007586 <I2C_Slave_ISR_DMA+0x126>
 8007564:	69bb      	ldr	r3, [r7, #24]
 8007566:	4a38      	ldr	r2, [pc, #224]	; (8007648 <I2C_Slave_ISR_DMA+0x1e8>)
 8007568:	4293      	cmp	r3, r2
 800756a:	d00c      	beq.n	8007586 <I2C_Slave_ISR_DMA+0x126>
        {
          /* Clear NACK Flag */
          __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF);
 800756c:	68fb      	ldr	r3, [r7, #12]
 800756e:	681b      	ldr	r3, [r3, #0]
 8007570:	2210      	movs	r2, #16
 8007572:	61da      	str	r2, [r3, #28]

          /* Flush TX register */
          I2C_Flush_TXDR(hi2c);
 8007574:	68fb      	ldr	r3, [r7, #12]
 8007576:	0018      	movs	r0, r3
 8007578:	f000 fd0f 	bl	8007f9a <I2C_Flush_TXDR>

          /* Last Byte is Transmitted */
          /* Call I2C Slave Sequential complete process */
          I2C_ITSlaveSeqCplt(hi2c);
 800757c:	68fb      	ldr	r3, [r7, #12]
 800757e:	0018      	movs	r0, r3
 8007580:	f000 f94a 	bl	8007818 <I2C_ITSlaveSeqCplt>
 8007584:	e03d      	b.n	8007602 <I2C_Slave_ISR_DMA+0x1a2>
        }
        else
        {
          /* Clear NACK Flag */
          __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF);
 8007586:	68fb      	ldr	r3, [r7, #12]
 8007588:	681b      	ldr	r3, [r3, #0]
 800758a:	2210      	movs	r2, #16
 800758c:	61da      	str	r2, [r3, #28]
      if (treatdmanack == 1U)
 800758e:	e03e      	b.n	800760e <I2C_Slave_ISR_DMA+0x1ae>
      }
      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);
 8007590:	68fb      	ldr	r3, [r7, #12]
 8007592:	681b      	ldr	r3, [r3, #0]
 8007594:	2210      	movs	r2, #16
 8007596:	61da      	str	r2, [r3, #28]

        /* Set ErrorCode corresponding to a Non-Acknowledge */
        hi2c->ErrorCode |= HAL_I2C_ERROR_AF;
 8007598:	68fb      	ldr	r3, [r7, #12]
 800759a:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 800759c:	2204      	movs	r2, #4
 800759e:	431a      	orrs	r2, r3
 80075a0:	68fb      	ldr	r3, [r7, #12]
 80075a2:	645a      	str	r2, [r3, #68]	; 0x44

        /* Store current hi2c->State, solve MISRA2012-Rule-13.5 */
        tmpstate = hi2c->State;
 80075a4:	2317      	movs	r3, #23
 80075a6:	18fb      	adds	r3, r7, r3
 80075a8:	68fa      	ldr	r2, [r7, #12]
 80075aa:	2141      	movs	r1, #65	; 0x41
 80075ac:	5c52      	ldrb	r2, [r2, r1]
 80075ae:	701a      	strb	r2, [r3, #0]

        if ((tmpoptions == I2C_FIRST_FRAME) || (tmpoptions == I2C_NEXT_FRAME))
 80075b0:	69bb      	ldr	r3, [r7, #24]
 80075b2:	2b00      	cmp	r3, #0
 80075b4:	d004      	beq.n	80075c0 <I2C_Slave_ISR_DMA+0x160>
 80075b6:	69ba      	ldr	r2, [r7, #24]
 80075b8:	2380      	movs	r3, #128	; 0x80
 80075ba:	045b      	lsls	r3, r3, #17
 80075bc:	429a      	cmp	r2, r3
 80075be:	d126      	bne.n	800760e <I2C_Slave_ISR_DMA+0x1ae>
        {
          if ((tmpstate == HAL_I2C_STATE_BUSY_TX) || (tmpstate == HAL_I2C_STATE_BUSY_TX_LISTEN))
 80075c0:	2217      	movs	r2, #23
 80075c2:	18bb      	adds	r3, r7, r2
 80075c4:	781b      	ldrb	r3, [r3, #0]
 80075c6:	2b21      	cmp	r3, #33	; 0x21
 80075c8:	d003      	beq.n	80075d2 <I2C_Slave_ISR_DMA+0x172>
 80075ca:	18bb      	adds	r3, r7, r2
 80075cc:	781b      	ldrb	r3, [r3, #0]
 80075ce:	2b29      	cmp	r3, #41	; 0x29
 80075d0:	d103      	bne.n	80075da <I2C_Slave_ISR_DMA+0x17a>
          {
            hi2c->PreviousState = I2C_STATE_SLAVE_BUSY_TX;
 80075d2:	68fb      	ldr	r3, [r7, #12]
 80075d4:	2221      	movs	r2, #33	; 0x21
 80075d6:	631a      	str	r2, [r3, #48]	; 0x30
 80075d8:	e00b      	b.n	80075f2 <I2C_Slave_ISR_DMA+0x192>
          }
          else if ((tmpstate == HAL_I2C_STATE_BUSY_RX) || (tmpstate == HAL_I2C_STATE_BUSY_RX_LISTEN))
 80075da:	2217      	movs	r2, #23
 80075dc:	18bb      	adds	r3, r7, r2
 80075de:	781b      	ldrb	r3, [r3, #0]
 80075e0:	2b22      	cmp	r3, #34	; 0x22
 80075e2:	d003      	beq.n	80075ec <I2C_Slave_ISR_DMA+0x18c>
 80075e4:	18bb      	adds	r3, r7, r2
 80075e6:	781b      	ldrb	r3, [r3, #0]
 80075e8:	2b2a      	cmp	r3, #42	; 0x2a
 80075ea:	d102      	bne.n	80075f2 <I2C_Slave_ISR_DMA+0x192>
          {
            hi2c->PreviousState = I2C_STATE_SLAVE_BUSY_RX;
 80075ec:	68fb      	ldr	r3, [r7, #12]
 80075ee:	2222      	movs	r2, #34	; 0x22
 80075f0:	631a      	str	r2, [r3, #48]	; 0x30
          {
            /* Do nothing */
          }

          /* Call the corresponding callback to inform upper layer of End of Transfer */
          I2C_ITError(hi2c, hi2c->ErrorCode);
 80075f2:	68fb      	ldr	r3, [r7, #12]
 80075f4:	6c5a      	ldr	r2, [r3, #68]	; 0x44
 80075f6:	68fb      	ldr	r3, [r7, #12]
 80075f8:	0011      	movs	r1, r2
 80075fa:	0018      	movs	r0, r3
 80075fc:	f000 fbc2 	bl	8007d84 <I2C_ITError>
      if (treatdmanack == 1U)
 8007600:	e005      	b.n	800760e <I2C_Slave_ISR_DMA+0x1ae>
 8007602:	e004      	b.n	800760e <I2C_Slave_ISR_DMA+0x1ae>
      }
    }
    else
    {
      /* Only Clear NACK Flag, no DMA treatment is pending */
      __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF);
 8007604:	68fb      	ldr	r3, [r7, #12]
 8007606:	681b      	ldr	r3, [r3, #0]
 8007608:	2210      	movs	r2, #16
 800760a:	61da      	str	r2, [r3, #28]
    if ((I2C_CHECK_IT_SOURCE(ITSources, I2C_CR1_TXDMAEN) != RESET) ||
 800760c:	e013      	b.n	8007636 <I2C_Slave_ISR_DMA+0x1d6>
      if (treatdmanack == 1U)
 800760e:	46c0      	nop			; (mov r8, r8)
    if ((I2C_CHECK_IT_SOURCE(ITSources, I2C_CR1_TXDMAEN) != RESET) ||
 8007610:	e011      	b.n	8007636 <I2C_Slave_ISR_DMA+0x1d6>
    }
  }
  else if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_ADDR) != RESET) && \
 8007612:	68bb      	ldr	r3, [r7, #8]
 8007614:	08db      	lsrs	r3, r3, #3
 8007616:	001a      	movs	r2, r3
 8007618:	2301      	movs	r3, #1
 800761a:	4013      	ands	r3, r2
 800761c:	d00b      	beq.n	8007636 <I2C_Slave_ISR_DMA+0x1d6>
           (I2C_CHECK_IT_SOURCE(ITSources, I2C_IT_ADDRI) != RESET))
 800761e:	687b      	ldr	r3, [r7, #4]
 8007620:	08db      	lsrs	r3, r3, #3
 8007622:	001a      	movs	r2, r3
 8007624:	2301      	movs	r3, #1
 8007626:	4013      	ands	r3, r2
  else if ((I2C_CHECK_FLAG(ITFlags, I2C_FLAG_ADDR) != RESET) && \
 8007628:	d005      	beq.n	8007636 <I2C_Slave_ISR_DMA+0x1d6>
  {
    I2C_ITAddrCplt(hi2c, ITFlags);
 800762a:	68ba      	ldr	r2, [r7, #8]
 800762c:	68fb      	ldr	r3, [r7, #12]
 800762e:	0011      	movs	r1, r2
 8007630:	0018      	movs	r0, r3
 8007632:	f000 f80b 	bl	800764c <I2C_ITAddrCplt>
  {
    /* Nothing to do */
  }

  /* Process Unlocked */
  __HAL_UNLOCK(hi2c);
 8007636:	68fb      	ldr	r3, [r7, #12]
 8007638:	2240      	movs	r2, #64	; 0x40
 800763a:	2100      	movs	r1, #0
 800763c:	5499      	strb	r1, [r3, r2]

  return HAL_OK;
 800763e:	2300      	movs	r3, #0
}
 8007640:	0018      	movs	r0, r3
 8007642:	46bd      	mov	sp, r7
 8007644:	b008      	add	sp, #32
 8007646:	bd80      	pop	{r7, pc}
 8007648:	ffff0000 	.word	0xffff0000

0800764c <I2C_ITAddrCplt>:
  * @param  hi2c I2C handle.
  * @param  ITFlags Interrupt flags to handle.
  * @retval None
  */
static void I2C_ITAddrCplt(I2C_HandleTypeDef *hi2c, uint32_t ITFlags)
{
 800764c:	b5b0      	push	{r4, r5, r7, lr}
 800764e:	b084      	sub	sp, #16
 8007650:	af00      	add	r7, sp, #0
 8007652:	6078      	str	r0, [r7, #4]
 8007654:	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)
 8007656:	687b      	ldr	r3, [r7, #4]
 8007658:	2241      	movs	r2, #65	; 0x41
 800765a:	5c9b      	ldrb	r3, [r3, r2]
 800765c:	b2db      	uxtb	r3, r3
 800765e:	001a      	movs	r2, r3
 8007660:	2328      	movs	r3, #40	; 0x28
 8007662:	4013      	ands	r3, r2
 8007664:	2b28      	cmp	r3, #40	; 0x28
 8007666:	d000      	beq.n	800766a <I2C_ITAddrCplt+0x1e>
 8007668:	e088      	b.n	800777c <I2C_ITAddrCplt+0x130>
  {
    transferdirection = I2C_GET_DIR(hi2c);
 800766a:	687b      	ldr	r3, [r7, #4]
 800766c:	681b      	ldr	r3, [r3, #0]
 800766e:	699b      	ldr	r3, [r3, #24]
 8007670:	0c1b      	lsrs	r3, r3, #16
 8007672:	b2da      	uxtb	r2, r3
 8007674:	250f      	movs	r5, #15
 8007676:	197b      	adds	r3, r7, r5
 8007678:	2101      	movs	r1, #1
 800767a:	400a      	ands	r2, r1
 800767c:	701a      	strb	r2, [r3, #0]
    slaveaddrcode     = I2C_GET_ADDR_MATCH(hi2c);
 800767e:	687b      	ldr	r3, [r7, #4]
 8007680:	681b      	ldr	r3, [r3, #0]
 8007682:	699b      	ldr	r3, [r3, #24]
 8007684:	0c1b      	lsrs	r3, r3, #16
 8007686:	b29a      	uxth	r2, r3
 8007688:	200c      	movs	r0, #12
 800768a:	183b      	adds	r3, r7, r0
 800768c:	21fe      	movs	r1, #254	; 0xfe
 800768e:	400a      	ands	r2, r1
 8007690:	801a      	strh	r2, [r3, #0]
    ownadd1code       = I2C_GET_OWN_ADDRESS1(hi2c);
 8007692:	687b      	ldr	r3, [r7, #4]
 8007694:	681b      	ldr	r3, [r3, #0]
 8007696:	689b      	ldr	r3, [r3, #8]
 8007698:	b29a      	uxth	r2, r3
 800769a:	240a      	movs	r4, #10
 800769c:	193b      	adds	r3, r7, r4
 800769e:	0592      	lsls	r2, r2, #22
 80076a0:	0d92      	lsrs	r2, r2, #22
 80076a2:	801a      	strh	r2, [r3, #0]
    ownadd2code       = I2C_GET_OWN_ADDRESS2(hi2c);
 80076a4:	687b      	ldr	r3, [r7, #4]
 80076a6:	681b      	ldr	r3, [r3, #0]
 80076a8:	68db      	ldr	r3, [r3, #12]
 80076aa:	b29a      	uxth	r2, r3
 80076ac:	2308      	movs	r3, #8
 80076ae:	18fb      	adds	r3, r7, r3
 80076b0:	21fe      	movs	r1, #254	; 0xfe
 80076b2:	400a      	ands	r2, r1
 80076b4:	801a      	strh	r2, [r3, #0]

    /* If 10bits addressing mode is selected */
    if (hi2c->Init.AddressingMode == I2C_ADDRESSINGMODE_10BIT)
 80076b6:	687b      	ldr	r3, [r7, #4]
 80076b8:	68db      	ldr	r3, [r3, #12]
 80076ba:	2b02      	cmp	r3, #2
 80076bc:	d148      	bne.n	8007750 <I2C_ITAddrCplt+0x104>
    {
      if ((slaveaddrcode & SLAVE_ADDR_MSK) == ((ownadd1code >> SLAVE_ADDR_SHIFT) & SLAVE_ADDR_MSK))
 80076be:	0021      	movs	r1, r4
 80076c0:	187b      	adds	r3, r7, r1
 80076c2:	881b      	ldrh	r3, [r3, #0]
 80076c4:	09db      	lsrs	r3, r3, #7
 80076c6:	b29a      	uxth	r2, r3
 80076c8:	183b      	adds	r3, r7, r0
 80076ca:	881b      	ldrh	r3, [r3, #0]
 80076cc:	4053      	eors	r3, r2
 80076ce:	b29b      	uxth	r3, r3
 80076d0:	001a      	movs	r2, r3
 80076d2:	2306      	movs	r3, #6
 80076d4:	4013      	ands	r3, r2
 80076d6:	d120      	bne.n	800771a <I2C_ITAddrCplt+0xce>
      {
        slaveaddrcode = ownadd1code;
 80076d8:	183b      	adds	r3, r7, r0
 80076da:	187a      	adds	r2, r7, r1
 80076dc:	8812      	ldrh	r2, [r2, #0]
 80076de:	801a      	strh	r2, [r3, #0]
        hi2c->AddrEventCount++;
 80076e0:	687b      	ldr	r3, [r7, #4]
 80076e2:	6c9b      	ldr	r3, [r3, #72]	; 0x48
 80076e4:	1c5a      	adds	r2, r3, #1
 80076e6:	687b      	ldr	r3, [r7, #4]
 80076e8:	649a      	str	r2, [r3, #72]	; 0x48
        if (hi2c->AddrEventCount == 2U)
 80076ea:	687b      	ldr	r3, [r7, #4]
 80076ec:	6c9b      	ldr	r3, [r3, #72]	; 0x48
 80076ee:	2b02      	cmp	r3, #2
 80076f0:	d14c      	bne.n	800778c <I2C_ITAddrCplt+0x140>
        {
          /* Reset Address Event counter */
          hi2c->AddrEventCount = 0U;
 80076f2:	687b      	ldr	r3, [r7, #4]
 80076f4:	2200      	movs	r2, #0
 80076f6:	649a      	str	r2, [r3, #72]	; 0x48

          /* Clear ADDR flag */
          __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_ADDR);
 80076f8:	687b      	ldr	r3, [r7, #4]
 80076fa:	681b      	ldr	r3, [r3, #0]
 80076fc:	2208      	movs	r2, #8
 80076fe:	61da      	str	r2, [r3, #28]

          /* Process Unlocked */
          __HAL_UNLOCK(hi2c);
 8007700:	687b      	ldr	r3, [r7, #4]
 8007702:	2240      	movs	r2, #64	; 0x40
 8007704:	2100      	movs	r1, #0
 8007706:	5499      	strb	r1, [r3, r2]

          /* Call Slave Addr callback */
#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1)
          hi2c->AddrCallback(hi2c, transferdirection, slaveaddrcode);
#else
          HAL_I2C_AddrCallback(hi2c, transferdirection, slaveaddrcode);
 8007708:	183b      	adds	r3, r7, r0
 800770a:	881a      	ldrh	r2, [r3, #0]
 800770c:	197b      	adds	r3, r7, r5
 800770e:	7819      	ldrb	r1, [r3, #0]
 8007710:	687b      	ldr	r3, [r7, #4]
 8007712:	0018      	movs	r0, r3
 8007714:	f7ff fb0a 	bl	8006d2c <HAL_I2C_AddrCallback>
    __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_ADDR);

    /* Process Unlocked */
    __HAL_UNLOCK(hi2c);
  }
}
 8007718:	e038      	b.n	800778c <I2C_ITAddrCplt+0x140>
        slaveaddrcode = ownadd2code;
 800771a:	240c      	movs	r4, #12
 800771c:	193b      	adds	r3, r7, r4
 800771e:	2208      	movs	r2, #8
 8007720:	18ba      	adds	r2, r7, r2
 8007722:	8812      	ldrh	r2, [r2, #0]
 8007724:	801a      	strh	r2, [r3, #0]
        I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT);
 8007726:	2380      	movs	r3, #128	; 0x80
 8007728:	021a      	lsls	r2, r3, #8
 800772a:	687b      	ldr	r3, [r7, #4]
 800772c:	0011      	movs	r1, r2
 800772e:	0018      	movs	r0, r3
 8007730:	f000 fd12 	bl	8008158 <I2C_Disable_IRQ>
        __HAL_UNLOCK(hi2c);
 8007734:	687b      	ldr	r3, [r7, #4]
 8007736:	2240      	movs	r2, #64	; 0x40
 8007738:	2100      	movs	r1, #0
 800773a:	5499      	strb	r1, [r3, r2]
        HAL_I2C_AddrCallback(hi2c, transferdirection, slaveaddrcode);
 800773c:	193b      	adds	r3, r7, r4
 800773e:	881a      	ldrh	r2, [r3, #0]
 8007740:	230f      	movs	r3, #15
 8007742:	18fb      	adds	r3, r7, r3
 8007744:	7819      	ldrb	r1, [r3, #0]
 8007746:	687b      	ldr	r3, [r7, #4]
 8007748:	0018      	movs	r0, r3
 800774a:	f7ff faef 	bl	8006d2c <HAL_I2C_AddrCallback>
}
 800774e:	e01d      	b.n	800778c <I2C_ITAddrCplt+0x140>
      I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT);
 8007750:	2380      	movs	r3, #128	; 0x80
 8007752:	021a      	lsls	r2, r3, #8
 8007754:	687b      	ldr	r3, [r7, #4]
 8007756:	0011      	movs	r1, r2
 8007758:	0018      	movs	r0, r3
 800775a:	f000 fcfd 	bl	8008158 <I2C_Disable_IRQ>
      __HAL_UNLOCK(hi2c);
 800775e:	687b      	ldr	r3, [r7, #4]
 8007760:	2240      	movs	r2, #64	; 0x40
 8007762:	2100      	movs	r1, #0
 8007764:	5499      	strb	r1, [r3, r2]
      HAL_I2C_AddrCallback(hi2c, transferdirection, slaveaddrcode);
 8007766:	230c      	movs	r3, #12
 8007768:	18fb      	adds	r3, r7, r3
 800776a:	881a      	ldrh	r2, [r3, #0]
 800776c:	230f      	movs	r3, #15
 800776e:	18fb      	adds	r3, r7, r3
 8007770:	7819      	ldrb	r1, [r3, #0]
 8007772:	687b      	ldr	r3, [r7, #4]
 8007774:	0018      	movs	r0, r3
 8007776:	f7ff fad9 	bl	8006d2c <HAL_I2C_AddrCallback>
}
 800777a:	e007      	b.n	800778c <I2C_ITAddrCplt+0x140>
    __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_ADDR);
 800777c:	687b      	ldr	r3, [r7, #4]
 800777e:	681b      	ldr	r3, [r3, #0]
 8007780:	2208      	movs	r2, #8
 8007782:	61da      	str	r2, [r3, #28]
    __HAL_UNLOCK(hi2c);
 8007784:	687b      	ldr	r3, [r7, #4]
 8007786:	2240      	movs	r2, #64	; 0x40
 8007788:	2100      	movs	r1, #0
 800778a:	5499      	strb	r1, [r3, r2]
}
 800778c:	46c0      	nop			; (mov r8, r8)
 800778e:	46bd      	mov	sp, r7
 8007790:	b004      	add	sp, #16
 8007792:	bdb0      	pop	{r4, r5, r7, pc}

08007794 <I2C_ITMasterSeqCplt>:
  * @brief  I2C Master sequential complete process.
  * @param  hi2c I2C handle.
  * @retval None
  */
static void I2C_ITMasterSeqCplt(I2C_HandleTypeDef *hi2c)
{
 8007794:	b580      	push	{r7, lr}
 8007796:	b082      	sub	sp, #8
 8007798:	af00      	add	r7, sp, #0
 800779a:	6078      	str	r0, [r7, #4]
  /* Reset I2C handle mode */
  hi2c->Mode = HAL_I2C_MODE_NONE;
 800779c:	687b      	ldr	r3, [r7, #4]
 800779e:	2242      	movs	r2, #66	; 0x42
 80077a0:	2100      	movs	r1, #0
 80077a2:	5499      	strb	r1, [r3, r2]

  /* No Generate Stop, to permit restart mode */
  /* The stop will be done at the end of transfer, when I2C_AUTOEND_MODE enable */
  if (hi2c->State == HAL_I2C_STATE_BUSY_TX)
 80077a4:	687b      	ldr	r3, [r7, #4]
 80077a6:	2241      	movs	r2, #65	; 0x41
 80077a8:	5c9b      	ldrb	r3, [r3, r2]
 80077aa:	b2db      	uxtb	r3, r3
 80077ac:	2b21      	cmp	r3, #33	; 0x21
 80077ae:	d117      	bne.n	80077e0 <I2C_ITMasterSeqCplt+0x4c>
  {
    hi2c->State         = HAL_I2C_STATE_READY;
 80077b0:	687b      	ldr	r3, [r7, #4]
 80077b2:	2241      	movs	r2, #65	; 0x41
 80077b4:	2120      	movs	r1, #32
 80077b6:	5499      	strb	r1, [r3, r2]
    hi2c->PreviousState = I2C_STATE_MASTER_BUSY_TX;
 80077b8:	687b      	ldr	r3, [r7, #4]
 80077ba:	2211      	movs	r2, #17
 80077bc:	631a      	str	r2, [r3, #48]	; 0x30
    hi2c->XferISR       = NULL;
 80077be:	687b      	ldr	r3, [r7, #4]
 80077c0:	2200      	movs	r2, #0
 80077c2:	635a      	str	r2, [r3, #52]	; 0x34

    /* Disable Interrupts */
    I2C_Disable_IRQ(hi2c, I2C_XFER_TX_IT);
 80077c4:	687b      	ldr	r3, [r7, #4]
 80077c6:	2101      	movs	r1, #1
 80077c8:	0018      	movs	r0, r3
 80077ca:	f000 fcc5 	bl	8008158 <I2C_Disable_IRQ>

    /* Process Unlocked */
    __HAL_UNLOCK(hi2c);
 80077ce:	687b      	ldr	r3, [r7, #4]
 80077d0:	2240      	movs	r2, #64	; 0x40
 80077d2:	2100      	movs	r1, #0
 80077d4:	5499      	strb	r1, [r3, r2]

    /* Call the corresponding callback to inform upper layer of End of Transfer */
#if (USE_HAL_I2C_REGISTER_CALLBACKS == 1)
    hi2c->MasterTxCpltCallback(hi2c);
#else
    HAL_I2C_MasterTxCpltCallback(hi2c);
 80077d6:	687b      	ldr	r3, [r7, #4]
 80077d8:	0018      	movs	r0, r3
 80077da:	f7ff fa8f 	bl	8006cfc <HAL_I2C_MasterTxCpltCallback>
    hi2c->MasterRxCpltCallback(hi2c);
#else
    HAL_I2C_MasterRxCpltCallback(hi2c);
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
  }
}
 80077de:	e016      	b.n	800780e <I2C_ITMasterSeqCplt+0x7a>
    hi2c->State         = HAL_I2C_STATE_READY;
 80077e0:	687b      	ldr	r3, [r7, #4]
 80077e2:	2241      	movs	r2, #65	; 0x41
 80077e4:	2120      	movs	r1, #32
 80077e6:	5499      	strb	r1, [r3, r2]
    hi2c->PreviousState = I2C_STATE_MASTER_BUSY_RX;
 80077e8:	687b      	ldr	r3, [r7, #4]
 80077ea:	2212      	movs	r2, #18
 80077ec:	631a      	str	r2, [r3, #48]	; 0x30
    hi2c->XferISR       = NULL;
 80077ee:	687b      	ldr	r3, [r7, #4]
 80077f0:	2200      	movs	r2, #0
 80077f2:	635a      	str	r2, [r3, #52]	; 0x34
    I2C_Disable_IRQ(hi2c, I2C_XFER_RX_IT);
 80077f4:	687b      	ldr	r3, [r7, #4]
 80077f6:	2102      	movs	r1, #2
 80077f8:	0018      	movs	r0, r3
 80077fa:	f000 fcad 	bl	8008158 <I2C_Disable_IRQ>
    __HAL_UNLOCK(hi2c);
 80077fe:	687b      	ldr	r3, [r7, #4]
 8007800:	2240      	movs	r2, #64	; 0x40
 8007802:	2100      	movs	r1, #0
 8007804:	5499      	strb	r1, [r3, r2]
    HAL_I2C_MasterRxCpltCallback(hi2c);
 8007806:	687b      	ldr	r3, [r7, #4]
 8007808:	0018      	movs	r0, r3
 800780a:	f7fc ff99 	bl	8004740 <HAL_I2C_MasterRxCpltCallback>
}
 800780e:	46c0      	nop			; (mov r8, r8)
 8007810:	46bd      	mov	sp, r7
 8007812:	b002      	add	sp, #8
 8007814:	bd80      	pop	{r7, pc}
	...

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

  /* Reset I2C handle mode */
  hi2c->Mode = HAL_I2C_MODE_NONE;
 8007828:	687b      	ldr	r3, [r7, #4]
 800782a:	2242      	movs	r2, #66	; 0x42
 800782c:	2100      	movs	r1, #0
 800782e:	5499      	strb	r1, [r3, r2]

  /* If a DMA is ongoing, Update handle size context */
  if (I2C_CHECK_IT_SOURCE(tmpcr1value, I2C_CR1_TXDMAEN) != RESET)
 8007830:	68fb      	ldr	r3, [r7, #12]
 8007832:	0b9b      	lsrs	r3, r3, #14
 8007834:	001a      	movs	r2, r3
 8007836:	2301      	movs	r3, #1
 8007838:	4013      	ands	r3, r2
 800783a:	d008      	beq.n	800784e <I2C_ITSlaveSeqCplt+0x36>
  {
    /* Disable DMA Request */
    hi2c->Instance->CR1 &= ~I2C_CR1_TXDMAEN;
 800783c:	687b      	ldr	r3, [r7, #4]
 800783e:	681b      	ldr	r3, [r3, #0]
 8007840:	681a      	ldr	r2, [r3, #0]
 8007842:	687b      	ldr	r3, [r7, #4]
 8007844:	681b      	ldr	r3, [r3, #0]
 8007846:	4925      	ldr	r1, [pc, #148]	; (80078dc <I2C_ITSlaveSeqCplt+0xc4>)
 8007848:	400a      	ands	r2, r1
 800784a:	601a      	str	r2, [r3, #0]
 800784c:	e00d      	b.n	800786a <I2C_ITSlaveSeqCplt+0x52>
  }
  else if (I2C_CHECK_IT_SOURCE(tmpcr1value, I2C_CR1_RXDMAEN) != RESET)
 800784e:	68fb      	ldr	r3, [r7, #12]
 8007850:	0bdb      	lsrs	r3, r3, #15
 8007852:	001a      	movs	r2, r3
 8007854:	2301      	movs	r3, #1
 8007856:	4013      	ands	r3, r2
 8007858:	d007      	beq.n	800786a <I2C_ITSlaveSeqCplt+0x52>
  {
    /* Disable DMA Request */
    hi2c->Instance->CR1 &= ~I2C_CR1_RXDMAEN;
 800785a:	687b      	ldr	r3, [r7, #4]
 800785c:	681b      	ldr	r3, [r3, #0]
 800785e:	681a      	ldr	r2, [r3, #0]
 8007860:	687b      	ldr	r3, [r7, #4]
 8007862:	681b      	ldr	r3, [r3, #0]
 8007864:	491e      	ldr	r1, [pc, #120]	; (80078e0 <I2C_ITSlaveSeqCplt+0xc8>)
 8007866:	400a      	ands	r2, r1
 8007868:	601a      	str	r2, [r3, #0]
  else
  {
    /* Do nothing */
  }

  if (hi2c->State == HAL_I2C_STATE_BUSY_TX_LISTEN)
 800786a:	687b      	ldr	r3, [r7, #4]
 800786c:	2241      	movs	r2, #65	; 0x41
 800786e:	5c9b      	ldrb	r3, [r3, r2]
 8007870:	b2db      	uxtb	r3, r3
 8007872:	2b29      	cmp	r3, #41	; 0x29
 8007874:	d114      	bne.n	80078a0 <I2C_ITSlaveSeqCplt+0x88>
  {
    /* Remove HAL_I2C_STATE_SLAVE_BUSY_TX, keep only HAL_I2C_STATE_LISTEN */
    hi2c->State         = HAL_I2C_STATE_LISTEN;
 8007876:	687b      	ldr	r3, [r7, #4]
 8007878:	2241      	movs	r2, #65	; 0x41
 800787a:	2128      	movs	r1, #40	; 0x28
 800787c:	5499      	strb	r1, [r3, r2]
    hi2c->PreviousState = I2C_STATE_SLAVE_BUSY_TX;
 800787e:	687b      	ldr	r3, [r7, #4]
 8007880:	2221      	movs	r2, #33	; 0x21
 8007882:	631a      	str	r2, [r3, #48]	; 0x30

    /* Disable Interrupts */
    I2C_Disable_IRQ(hi2c, I2C_XFER_TX_IT);
 8007884:	687b      	ldr	r3, [r7, #4]
 8007886:	2101      	movs	r1, #1
 8007888:	0018      	movs	r0, r3
 800788a:	f000 fc65 	bl	8008158 <I2C_Disable_IRQ>

    /* Process Unlocked */
    __HAL_UNLOCK(hi2c);
 800788e:	687b      	ldr	r3, [r7, #4]
 8007890:	2240      	movs	r2, #64	; 0x40
 8007892:	2100      	movs	r1, #0
 8007894:	5499      	strb	r1, [r3, r2]

    /* 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);
 8007896:	687b      	ldr	r3, [r7, #4]
 8007898:	0018      	movs	r0, r3
 800789a:	f7ff fa37 	bl	8006d0c <HAL_I2C_SlaveTxCpltCallback>
  }
  else
  {
    /* Nothing to do */
  }
}
 800789e:	e019      	b.n	80078d4 <I2C_ITSlaveSeqCplt+0xbc>
  else if (hi2c->State == HAL_I2C_STATE_BUSY_RX_LISTEN)
 80078a0:	687b      	ldr	r3, [r7, #4]
 80078a2:	2241      	movs	r2, #65	; 0x41
 80078a4:	5c9b      	ldrb	r3, [r3, r2]
 80078a6:	b2db      	uxtb	r3, r3
 80078a8:	2b2a      	cmp	r3, #42	; 0x2a
 80078aa:	d113      	bne.n	80078d4 <I2C_ITSlaveSeqCplt+0xbc>
    hi2c->State         = HAL_I2C_STATE_LISTEN;
 80078ac:	687b      	ldr	r3, [r7, #4]
 80078ae:	2241      	movs	r2, #65	; 0x41
 80078b0:	2128      	movs	r1, #40	; 0x28
 80078b2:	5499      	strb	r1, [r3, r2]
    hi2c->PreviousState = I2C_STATE_SLAVE_BUSY_RX;
 80078b4:	687b      	ldr	r3, [r7, #4]
 80078b6:	2222      	movs	r2, #34	; 0x22
 80078b8:	631a      	str	r2, [r3, #48]	; 0x30
    I2C_Disable_IRQ(hi2c, I2C_XFER_RX_IT);
 80078ba:	687b      	ldr	r3, [r7, #4]
 80078bc:	2102      	movs	r1, #2
 80078be:	0018      	movs	r0, r3
 80078c0:	f000 fc4a 	bl	8008158 <I2C_Disable_IRQ>
    __HAL_UNLOCK(hi2c);
 80078c4:	687b      	ldr	r3, [r7, #4]
 80078c6:	2240      	movs	r2, #64	; 0x40
 80078c8:	2100      	movs	r1, #0
 80078ca:	5499      	strb	r1, [r3, r2]
    HAL_I2C_SlaveRxCpltCallback(hi2c);
 80078cc:	687b      	ldr	r3, [r7, #4]
 80078ce:	0018      	movs	r0, r3
 80078d0:	f7ff fa24 	bl	8006d1c <HAL_I2C_SlaveRxCpltCallback>
}
 80078d4:	46c0      	nop			; (mov r8, r8)
 80078d6:	46bd      	mov	sp, r7
 80078d8:	b004      	add	sp, #16
 80078da:	bd80      	pop	{r7, pc}
 80078dc:	ffffbfff 	.word	0xffffbfff
 80078e0:	ffff7fff 	.word	0xffff7fff

080078e4 <I2C_ITMasterCplt>:
  * @param  hi2c I2C handle.
  * @param  ITFlags Interrupt flags to handle.
  * @retval None
  */
static void I2C_ITMasterCplt(I2C_HandleTypeDef *hi2c, uint32_t ITFlags)
{
 80078e4:	b580      	push	{r7, lr}
 80078e6:	b086      	sub	sp, #24
 80078e8:	af00      	add	r7, sp, #0
 80078ea:	6078      	str	r0, [r7, #4]
 80078ec:	6039      	str	r1, [r7, #0]
  uint32_t tmperror;
  uint32_t tmpITFlags = ITFlags;
 80078ee:	683b      	ldr	r3, [r7, #0]
 80078f0:	617b      	str	r3, [r7, #20]
  __IO uint32_t tmpreg;

  /* Clear STOP Flag */
  __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF);
 80078f2:	687b      	ldr	r3, [r7, #4]
 80078f4:	681b      	ldr	r3, [r3, #0]
 80078f6:	2220      	movs	r2, #32
 80078f8:	61da      	str	r2, [r3, #28]

  /* Disable Interrupts and Store Previous state */
  if (hi2c->State == HAL_I2C_STATE_BUSY_TX)
 80078fa:	687b      	ldr	r3, [r7, #4]
 80078fc:	2241      	movs	r2, #65	; 0x41
 80078fe:	5c9b      	ldrb	r3, [r3, r2]
 8007900:	b2db      	uxtb	r3, r3
 8007902:	2b21      	cmp	r3, #33	; 0x21
 8007904:	d108      	bne.n	8007918 <I2C_ITMasterCplt+0x34>
  {
    I2C_Disable_IRQ(hi2c, I2C_XFER_TX_IT);
 8007906:	687b      	ldr	r3, [r7, #4]
 8007908:	2101      	movs	r1, #1
 800790a:	0018      	movs	r0, r3
 800790c:	f000 fc24 	bl	8008158 <I2C_Disable_IRQ>
    hi2c->PreviousState = I2C_STATE_MASTER_BUSY_TX;
 8007910:	687b      	ldr	r3, [r7, #4]
 8007912:	2211      	movs	r2, #17
 8007914:	631a      	str	r2, [r3, #48]	; 0x30
 8007916:	e00d      	b.n	8007934 <I2C_ITMasterCplt+0x50>
  }
  else if (hi2c->State == HAL_I2C_STATE_BUSY_RX)
 8007918:	687b      	ldr	r3, [r7, #4]
 800791a:	2241      	movs	r2, #65	; 0x41
 800791c:	5c9b      	ldrb	r3, [r3, r2]
 800791e:	b2db      	uxtb	r3, r3
 8007920:	2b22      	cmp	r3, #34	; 0x22
 8007922:	d107      	bne.n	8007934 <I2C_ITMasterCplt+0x50>
  {
    I2C_Disable_IRQ(hi2c, I2C_XFER_RX_IT);
 8007924:	687b      	ldr	r3, [r7, #4]
 8007926:	2102      	movs	r1, #2
 8007928:	0018      	movs	r0, r3
 800792a:	f000 fc15 	bl	8008158 <I2C_Disable_IRQ>
    hi2c->PreviousState = I2C_STATE_MASTER_BUSY_RX;
 800792e:	687b      	ldr	r3, [r7, #4]
 8007930:	2212      	movs	r2, #18
 8007932:	631a      	str	r2, [r3, #48]	; 0x30
  {
    /* Do nothing */
  }

  /* Clear Configuration Register 2 */
  I2C_RESET_CR2(hi2c);
 8007934:	687b      	ldr	r3, [r7, #4]
 8007936:	681b      	ldr	r3, [r3, #0]
 8007938:	685a      	ldr	r2, [r3, #4]
 800793a:	687b      	ldr	r3, [r7, #4]
 800793c:	681b      	ldr	r3, [r3, #0]
 800793e:	4950      	ldr	r1, [pc, #320]	; (8007a80 <I2C_ITMasterCplt+0x19c>)
 8007940:	400a      	ands	r2, r1
 8007942:	605a      	str	r2, [r3, #4]

  /* Reset handle parameters */
  hi2c->XferISR       = NULL;
 8007944:	687b      	ldr	r3, [r7, #4]
 8007946:	2200      	movs	r2, #0
 8007948:	635a      	str	r2, [r3, #52]	; 0x34
  hi2c->XferOptions   = I2C_NO_OPTION_FRAME;
 800794a:	687b      	ldr	r3, [r7, #4]
 800794c:	4a4d      	ldr	r2, [pc, #308]	; (8007a84 <I2C_ITMasterCplt+0x1a0>)
 800794e:	62da      	str	r2, [r3, #44]	; 0x2c

  if (I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_AF) != RESET)
 8007950:	697b      	ldr	r3, [r7, #20]
 8007952:	091b      	lsrs	r3, r3, #4
 8007954:	001a      	movs	r2, r3
 8007956:	2301      	movs	r3, #1
 8007958:	4013      	ands	r3, r2
 800795a:	d009      	beq.n	8007970 <I2C_ITMasterCplt+0x8c>
  {
    /* Clear NACK Flag */
    __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF);
 800795c:	687b      	ldr	r3, [r7, #4]
 800795e:	681b      	ldr	r3, [r3, #0]
 8007960:	2210      	movs	r2, #16
 8007962:	61da      	str	r2, [r3, #28]

    /* Set acknowledge error code */
    hi2c->ErrorCode |= HAL_I2C_ERROR_AF;
 8007964:	687b      	ldr	r3, [r7, #4]
 8007966:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8007968:	2204      	movs	r2, #4
 800796a:	431a      	orrs	r2, r3
 800796c:	687b      	ldr	r3, [r7, #4]
 800796e:	645a      	str	r2, [r3, #68]	; 0x44
  }

  /* Fetch Last receive data if any */
  if ((hi2c->State == HAL_I2C_STATE_ABORT) && (I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_RXNE) != RESET))
 8007970:	687b      	ldr	r3, [r7, #4]
 8007972:	2241      	movs	r2, #65	; 0x41
 8007974:	5c9b      	ldrb	r3, [r3, r2]
 8007976:	b2db      	uxtb	r3, r3
 8007978:	2b60      	cmp	r3, #96	; 0x60
 800797a:	d10b      	bne.n	8007994 <I2C_ITMasterCplt+0xb0>
 800797c:	697b      	ldr	r3, [r7, #20]
 800797e:	089b      	lsrs	r3, r3, #2
 8007980:	001a      	movs	r2, r3
 8007982:	2301      	movs	r3, #1
 8007984:	4013      	ands	r3, r2
 8007986:	d005      	beq.n	8007994 <I2C_ITMasterCplt+0xb0>
  {
    /* Read data from RXDR */
    tmpreg = (uint8_t)hi2c->Instance->RXDR;
 8007988:	687b      	ldr	r3, [r7, #4]
 800798a:	681b      	ldr	r3, [r3, #0]
 800798c:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 800798e:	b2db      	uxtb	r3, r3
 8007990:	60fb      	str	r3, [r7, #12]
    UNUSED(tmpreg);
 8007992:	68fb      	ldr	r3, [r7, #12]
  }

  /* Flush TX register */
  I2C_Flush_TXDR(hi2c);
 8007994:	687b      	ldr	r3, [r7, #4]
 8007996:	0018      	movs	r0, r3
 8007998:	f000 faff 	bl	8007f9a <I2C_Flush_TXDR>

  /* Store current volatile hi2c->ErrorCode, misra rule */
  tmperror = hi2c->ErrorCode;
 800799c:	687b      	ldr	r3, [r7, #4]
 800799e:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 80079a0:	613b      	str	r3, [r7, #16]

  /* Call the corresponding callback to inform upper layer of End of Transfer */
  if ((hi2c->State == HAL_I2C_STATE_ABORT) || (tmperror != HAL_I2C_ERROR_NONE))
 80079a2:	687b      	ldr	r3, [r7, #4]
 80079a4:	2241      	movs	r2, #65	; 0x41
 80079a6:	5c9b      	ldrb	r3, [r3, r2]
 80079a8:	b2db      	uxtb	r3, r3
 80079aa:	2b60      	cmp	r3, #96	; 0x60
 80079ac:	d002      	beq.n	80079b4 <I2C_ITMasterCplt+0xd0>
 80079ae:	693b      	ldr	r3, [r7, #16]
 80079b0:	2b00      	cmp	r3, #0
 80079b2:	d007      	beq.n	80079c4 <I2C_ITMasterCplt+0xe0>
  {
    /* Call the corresponding callback to inform upper layer of End of Transfer */
    I2C_ITError(hi2c, hi2c->ErrorCode);
 80079b4:	687b      	ldr	r3, [r7, #4]
 80079b6:	6c5a      	ldr	r2, [r3, #68]	; 0x44
 80079b8:	687b      	ldr	r3, [r7, #4]
 80079ba:	0011      	movs	r1, r2
 80079bc:	0018      	movs	r0, r3
 80079be:	f000 f9e1 	bl	8007d84 <I2C_ITError>
  }
  else
  {
    /* Nothing to do */
  }
}
 80079c2:	e058      	b.n	8007a76 <I2C_ITMasterCplt+0x192>
  else if (hi2c->State == HAL_I2C_STATE_BUSY_TX)
 80079c4:	687b      	ldr	r3, [r7, #4]
 80079c6:	2241      	movs	r2, #65	; 0x41
 80079c8:	5c9b      	ldrb	r3, [r3, r2]
 80079ca:	b2db      	uxtb	r3, r3
 80079cc:	2b21      	cmp	r3, #33	; 0x21
 80079ce:	d126      	bne.n	8007a1e <I2C_ITMasterCplt+0x13a>
    hi2c->State = HAL_I2C_STATE_READY;
 80079d0:	687b      	ldr	r3, [r7, #4]
 80079d2:	2241      	movs	r2, #65	; 0x41
 80079d4:	2120      	movs	r1, #32
 80079d6:	5499      	strb	r1, [r3, r2]
    hi2c->PreviousState = I2C_STATE_NONE;
 80079d8:	687b      	ldr	r3, [r7, #4]
 80079da:	2200      	movs	r2, #0
 80079dc:	631a      	str	r2, [r3, #48]	; 0x30
    if (hi2c->Mode == HAL_I2C_MODE_MEM)
 80079de:	687b      	ldr	r3, [r7, #4]
 80079e0:	2242      	movs	r2, #66	; 0x42
 80079e2:	5c9b      	ldrb	r3, [r3, r2]
 80079e4:	b2db      	uxtb	r3, r3
 80079e6:	2b40      	cmp	r3, #64	; 0x40
 80079e8:	d10c      	bne.n	8007a04 <I2C_ITMasterCplt+0x120>
      hi2c->Mode = HAL_I2C_MODE_NONE;
 80079ea:	687b      	ldr	r3, [r7, #4]
 80079ec:	2242      	movs	r2, #66	; 0x42
 80079ee:	2100      	movs	r1, #0
 80079f0:	5499      	strb	r1, [r3, r2]
      __HAL_UNLOCK(hi2c);
 80079f2:	687b      	ldr	r3, [r7, #4]
 80079f4:	2240      	movs	r2, #64	; 0x40
 80079f6:	2100      	movs	r1, #0
 80079f8:	5499      	strb	r1, [r3, r2]
      HAL_I2C_MemTxCpltCallback(hi2c);
 80079fa:	687b      	ldr	r3, [r7, #4]
 80079fc:	0018      	movs	r0, r3
 80079fe:	f7ff f9ad 	bl	8006d5c <HAL_I2C_MemTxCpltCallback>
}
 8007a02:	e038      	b.n	8007a76 <I2C_ITMasterCplt+0x192>
      hi2c->Mode = HAL_I2C_MODE_NONE;
 8007a04:	687b      	ldr	r3, [r7, #4]
 8007a06:	2242      	movs	r2, #66	; 0x42
 8007a08:	2100      	movs	r1, #0
 8007a0a:	5499      	strb	r1, [r3, r2]
      __HAL_UNLOCK(hi2c);
 8007a0c:	687b      	ldr	r3, [r7, #4]
 8007a0e:	2240      	movs	r2, #64	; 0x40
 8007a10:	2100      	movs	r1, #0
 8007a12:	5499      	strb	r1, [r3, r2]
      HAL_I2C_MasterTxCpltCallback(hi2c);
 8007a14:	687b      	ldr	r3, [r7, #4]
 8007a16:	0018      	movs	r0, r3
 8007a18:	f7ff f970 	bl	8006cfc <HAL_I2C_MasterTxCpltCallback>
}
 8007a1c:	e02b      	b.n	8007a76 <I2C_ITMasterCplt+0x192>
  else if (hi2c->State == HAL_I2C_STATE_BUSY_RX)
 8007a1e:	687b      	ldr	r3, [r7, #4]
 8007a20:	2241      	movs	r2, #65	; 0x41
 8007a22:	5c9b      	ldrb	r3, [r3, r2]
 8007a24:	b2db      	uxtb	r3, r3
 8007a26:	2b22      	cmp	r3, #34	; 0x22
 8007a28:	d125      	bne.n	8007a76 <I2C_ITMasterCplt+0x192>
    hi2c->State = HAL_I2C_STATE_READY;
 8007a2a:	687b      	ldr	r3, [r7, #4]
 8007a2c:	2241      	movs	r2, #65	; 0x41
 8007a2e:	2120      	movs	r1, #32
 8007a30:	5499      	strb	r1, [r3, r2]
    hi2c->PreviousState = I2C_STATE_NONE;
 8007a32:	687b      	ldr	r3, [r7, #4]
 8007a34:	2200      	movs	r2, #0
 8007a36:	631a      	str	r2, [r3, #48]	; 0x30
    if (hi2c->Mode == HAL_I2C_MODE_MEM)
 8007a38:	687b      	ldr	r3, [r7, #4]
 8007a3a:	2242      	movs	r2, #66	; 0x42
 8007a3c:	5c9b      	ldrb	r3, [r3, r2]
 8007a3e:	b2db      	uxtb	r3, r3
 8007a40:	2b40      	cmp	r3, #64	; 0x40
 8007a42:	d10c      	bne.n	8007a5e <I2C_ITMasterCplt+0x17a>
      hi2c->Mode = HAL_I2C_MODE_NONE;
 8007a44:	687b      	ldr	r3, [r7, #4]
 8007a46:	2242      	movs	r2, #66	; 0x42
 8007a48:	2100      	movs	r1, #0
 8007a4a:	5499      	strb	r1, [r3, r2]
      __HAL_UNLOCK(hi2c);
 8007a4c:	687b      	ldr	r3, [r7, #4]
 8007a4e:	2240      	movs	r2, #64	; 0x40
 8007a50:	2100      	movs	r1, #0
 8007a52:	5499      	strb	r1, [r3, r2]
      HAL_I2C_MemRxCpltCallback(hi2c);
 8007a54:	687b      	ldr	r3, [r7, #4]
 8007a56:	0018      	movs	r0, r3
 8007a58:	f7ff f988 	bl	8006d6c <HAL_I2C_MemRxCpltCallback>
}
 8007a5c:	e00b      	b.n	8007a76 <I2C_ITMasterCplt+0x192>
      hi2c->Mode = HAL_I2C_MODE_NONE;
 8007a5e:	687b      	ldr	r3, [r7, #4]
 8007a60:	2242      	movs	r2, #66	; 0x42
 8007a62:	2100      	movs	r1, #0
 8007a64:	5499      	strb	r1, [r3, r2]
      __HAL_UNLOCK(hi2c);
 8007a66:	687b      	ldr	r3, [r7, #4]
 8007a68:	2240      	movs	r2, #64	; 0x40
 8007a6a:	2100      	movs	r1, #0
 8007a6c:	5499      	strb	r1, [r3, r2]
      HAL_I2C_MasterRxCpltCallback(hi2c);
 8007a6e:	687b      	ldr	r3, [r7, #4]
 8007a70:	0018      	movs	r0, r3
 8007a72:	f7fc fe65 	bl	8004740 <HAL_I2C_MasterRxCpltCallback>
}
 8007a76:	46c0      	nop			; (mov r8, r8)
 8007a78:	46bd      	mov	sp, r7
 8007a7a:	b006      	add	sp, #24
 8007a7c:	bd80      	pop	{r7, pc}
 8007a7e:	46c0      	nop			; (mov r8, r8)
 8007a80:	fe00e800 	.word	0xfe00e800
 8007a84:	ffff0000 	.word	0xffff0000

08007a88 <I2C_ITSlaveCplt>:
  * @param  hi2c I2C handle.
  * @param  ITFlags Interrupt flags to handle.
  * @retval None
  */
static void I2C_ITSlaveCplt(I2C_HandleTypeDef *hi2c, uint32_t ITFlags)
{
 8007a88:	b580      	push	{r7, lr}
 8007a8a:	b086      	sub	sp, #24
 8007a8c:	af00      	add	r7, sp, #0
 8007a8e:	6078      	str	r0, [r7, #4]
 8007a90:	6039      	str	r1, [r7, #0]
  uint32_t tmpcr1value = READ_REG(hi2c->Instance->CR1);
 8007a92:	687b      	ldr	r3, [r7, #4]
 8007a94:	681b      	ldr	r3, [r3, #0]
 8007a96:	681b      	ldr	r3, [r3, #0]
 8007a98:	613b      	str	r3, [r7, #16]
  uint32_t tmpITFlags = ITFlags;
 8007a9a:	683b      	ldr	r3, [r7, #0]
 8007a9c:	617b      	str	r3, [r7, #20]
  HAL_I2C_StateTypeDef tmpstate = hi2c->State;
 8007a9e:	200f      	movs	r0, #15
 8007aa0:	183b      	adds	r3, r7, r0
 8007aa2:	687a      	ldr	r2, [r7, #4]
 8007aa4:	2141      	movs	r1, #65	; 0x41
 8007aa6:	5c52      	ldrb	r2, [r2, r1]
 8007aa8:	701a      	strb	r2, [r3, #0]

  /* Clear STOP Flag */
  __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_STOPF);
 8007aaa:	687b      	ldr	r3, [r7, #4]
 8007aac:	681b      	ldr	r3, [r3, #0]
 8007aae:	2220      	movs	r2, #32
 8007ab0:	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))
 8007ab2:	183b      	adds	r3, r7, r0
 8007ab4:	781b      	ldrb	r3, [r3, #0]
 8007ab6:	2b21      	cmp	r3, #33	; 0x21
 8007ab8:	d003      	beq.n	8007ac2 <I2C_ITSlaveCplt+0x3a>
 8007aba:	183b      	adds	r3, r7, r0
 8007abc:	781b      	ldrb	r3, [r3, #0]
 8007abe:	2b29      	cmp	r3, #41	; 0x29
 8007ac0:	d109      	bne.n	8007ad6 <I2C_ITSlaveCplt+0x4e>
  {
    I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT | I2C_XFER_TX_IT);
 8007ac2:	4a7d      	ldr	r2, [pc, #500]	; (8007cb8 <I2C_ITSlaveCplt+0x230>)
 8007ac4:	687b      	ldr	r3, [r7, #4]
 8007ac6:	0011      	movs	r1, r2
 8007ac8:	0018      	movs	r0, r3
 8007aca:	f000 fb45 	bl	8008158 <I2C_Disable_IRQ>
    hi2c->PreviousState = I2C_STATE_SLAVE_BUSY_TX;
 8007ace:	687b      	ldr	r3, [r7, #4]
 8007ad0:	2221      	movs	r2, #33	; 0x21
 8007ad2:	631a      	str	r2, [r3, #48]	; 0x30
 8007ad4:	e011      	b.n	8007afa <I2C_ITSlaveCplt+0x72>
  }
  else if ((tmpstate == HAL_I2C_STATE_BUSY_RX) || (tmpstate == HAL_I2C_STATE_BUSY_RX_LISTEN))
 8007ad6:	220f      	movs	r2, #15
 8007ad8:	18bb      	adds	r3, r7, r2
 8007ada:	781b      	ldrb	r3, [r3, #0]
 8007adc:	2b22      	cmp	r3, #34	; 0x22
 8007ade:	d003      	beq.n	8007ae8 <I2C_ITSlaveCplt+0x60>
 8007ae0:	18bb      	adds	r3, r7, r2
 8007ae2:	781b      	ldrb	r3, [r3, #0]
 8007ae4:	2b2a      	cmp	r3, #42	; 0x2a
 8007ae6:	d108      	bne.n	8007afa <I2C_ITSlaveCplt+0x72>
  {
    I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT | I2C_XFER_RX_IT);
 8007ae8:	4a74      	ldr	r2, [pc, #464]	; (8007cbc <I2C_ITSlaveCplt+0x234>)
 8007aea:	687b      	ldr	r3, [r7, #4]
 8007aec:	0011      	movs	r1, r2
 8007aee:	0018      	movs	r0, r3
 8007af0:	f000 fb32 	bl	8008158 <I2C_Disable_IRQ>
    hi2c->PreviousState = I2C_STATE_SLAVE_BUSY_RX;
 8007af4:	687b      	ldr	r3, [r7, #4]
 8007af6:	2222      	movs	r2, #34	; 0x22
 8007af8:	631a      	str	r2, [r3, #48]	; 0x30
  {
    /* Do nothing */
  }

  /* Disable Address Acknowledge */
  hi2c->Instance->CR2 |= I2C_CR2_NACK;
 8007afa:	687b      	ldr	r3, [r7, #4]
 8007afc:	681b      	ldr	r3, [r3, #0]
 8007afe:	685a      	ldr	r2, [r3, #4]
 8007b00:	687b      	ldr	r3, [r7, #4]
 8007b02:	681b      	ldr	r3, [r3, #0]
 8007b04:	2180      	movs	r1, #128	; 0x80
 8007b06:	0209      	lsls	r1, r1, #8
 8007b08:	430a      	orrs	r2, r1
 8007b0a:	605a      	str	r2, [r3, #4]

  /* Clear Configuration Register 2 */
  I2C_RESET_CR2(hi2c);
 8007b0c:	687b      	ldr	r3, [r7, #4]
 8007b0e:	681b      	ldr	r3, [r3, #0]
 8007b10:	685a      	ldr	r2, [r3, #4]
 8007b12:	687b      	ldr	r3, [r7, #4]
 8007b14:	681b      	ldr	r3, [r3, #0]
 8007b16:	496a      	ldr	r1, [pc, #424]	; (8007cc0 <I2C_ITSlaveCplt+0x238>)
 8007b18:	400a      	ands	r2, r1
 8007b1a:	605a      	str	r2, [r3, #4]

  /* Flush TX register */
  I2C_Flush_TXDR(hi2c);
 8007b1c:	687b      	ldr	r3, [r7, #4]
 8007b1e:	0018      	movs	r0, r3
 8007b20:	f000 fa3b 	bl	8007f9a <I2C_Flush_TXDR>

  /* If a DMA is ongoing, Update handle size context */
  if (I2C_CHECK_IT_SOURCE(tmpcr1value, I2C_CR1_TXDMAEN) != RESET)
 8007b24:	693b      	ldr	r3, [r7, #16]
 8007b26:	0b9b      	lsrs	r3, r3, #14
 8007b28:	001a      	movs	r2, r3
 8007b2a:	2301      	movs	r3, #1
 8007b2c:	4013      	ands	r3, r2
 8007b2e:	d013      	beq.n	8007b58 <I2C_ITSlaveCplt+0xd0>
  {
    /* Disable DMA Request */
    hi2c->Instance->CR1 &= ~I2C_CR1_TXDMAEN;
 8007b30:	687b      	ldr	r3, [r7, #4]
 8007b32:	681b      	ldr	r3, [r3, #0]
 8007b34:	681a      	ldr	r2, [r3, #0]
 8007b36:	687b      	ldr	r3, [r7, #4]
 8007b38:	681b      	ldr	r3, [r3, #0]
 8007b3a:	4962      	ldr	r1, [pc, #392]	; (8007cc4 <I2C_ITSlaveCplt+0x23c>)
 8007b3c:	400a      	ands	r2, r1
 8007b3e:	601a      	str	r2, [r3, #0]

    if (hi2c->hdmatx != NULL)
 8007b40:	687b      	ldr	r3, [r7, #4]
 8007b42:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8007b44:	2b00      	cmp	r3, #0
 8007b46:	d020      	beq.n	8007b8a <I2C_ITSlaveCplt+0x102>
    {
      hi2c->XferCount = (uint16_t)__HAL_DMA_GET_COUNTER(hi2c->hdmatx);
 8007b48:	687b      	ldr	r3, [r7, #4]
 8007b4a:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8007b4c:	681b      	ldr	r3, [r3, #0]
 8007b4e:	685b      	ldr	r3, [r3, #4]
 8007b50:	b29a      	uxth	r2, r3
 8007b52:	687b      	ldr	r3, [r7, #4]
 8007b54:	855a      	strh	r2, [r3, #42]	; 0x2a
 8007b56:	e018      	b.n	8007b8a <I2C_ITSlaveCplt+0x102>
    }
  }
  else if (I2C_CHECK_IT_SOURCE(tmpcr1value, I2C_CR1_RXDMAEN) != RESET)
 8007b58:	693b      	ldr	r3, [r7, #16]
 8007b5a:	0bdb      	lsrs	r3, r3, #15
 8007b5c:	001a      	movs	r2, r3
 8007b5e:	2301      	movs	r3, #1
 8007b60:	4013      	ands	r3, r2
 8007b62:	d012      	beq.n	8007b8a <I2C_ITSlaveCplt+0x102>
  {
    /* Disable DMA Request */
    hi2c->Instance->CR1 &= ~I2C_CR1_RXDMAEN;
 8007b64:	687b      	ldr	r3, [r7, #4]
 8007b66:	681b      	ldr	r3, [r3, #0]
 8007b68:	681a      	ldr	r2, [r3, #0]
 8007b6a:	687b      	ldr	r3, [r7, #4]
 8007b6c:	681b      	ldr	r3, [r3, #0]
 8007b6e:	4956      	ldr	r1, [pc, #344]	; (8007cc8 <I2C_ITSlaveCplt+0x240>)
 8007b70:	400a      	ands	r2, r1
 8007b72:	601a      	str	r2, [r3, #0]

    if (hi2c->hdmarx != NULL)
 8007b74:	687b      	ldr	r3, [r7, #4]
 8007b76:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8007b78:	2b00      	cmp	r3, #0
 8007b7a:	d006      	beq.n	8007b8a <I2C_ITSlaveCplt+0x102>
    {
      hi2c->XferCount = (uint16_t)__HAL_DMA_GET_COUNTER(hi2c->hdmarx);
 8007b7c:	687b      	ldr	r3, [r7, #4]
 8007b7e:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8007b80:	681b      	ldr	r3, [r3, #0]
 8007b82:	685b      	ldr	r3, [r3, #4]
 8007b84:	b29a      	uxth	r2, r3
 8007b86:	687b      	ldr	r3, [r7, #4]
 8007b88:	855a      	strh	r2, [r3, #42]	; 0x2a
  {
    /* Do nothing */
  }

  /* Store Last receive data if any */
  if (I2C_CHECK_FLAG(tmpITFlags, I2C_FLAG_RXNE) != RESET)
 8007b8a:	697b      	ldr	r3, [r7, #20]
 8007b8c:	089b      	lsrs	r3, r3, #2
 8007b8e:	001a      	movs	r2, r3
 8007b90:	2301      	movs	r3, #1
 8007b92:	4013      	ands	r3, r2
 8007b94:	d020      	beq.n	8007bd8 <I2C_ITSlaveCplt+0x150>
  {
    /* Remove RXNE flag on temporary variable as read done */
    tmpITFlags &= ~I2C_FLAG_RXNE;
 8007b96:	697b      	ldr	r3, [r7, #20]
 8007b98:	2204      	movs	r2, #4
 8007b9a:	4393      	bics	r3, r2
 8007b9c:	617b      	str	r3, [r7, #20]

    /* Read data from RXDR */
    *hi2c->pBuffPtr = (uint8_t)hi2c->Instance->RXDR;
 8007b9e:	687b      	ldr	r3, [r7, #4]
 8007ba0:	681b      	ldr	r3, [r3, #0]
 8007ba2:	6a5a      	ldr	r2, [r3, #36]	; 0x24
 8007ba4:	687b      	ldr	r3, [r7, #4]
 8007ba6:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8007ba8:	b2d2      	uxtb	r2, r2
 8007baa:	701a      	strb	r2, [r3, #0]

    /* Increment Buffer pointer */
    hi2c->pBuffPtr++;
 8007bac:	687b      	ldr	r3, [r7, #4]
 8007bae:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8007bb0:	1c5a      	adds	r2, r3, #1
 8007bb2:	687b      	ldr	r3, [r7, #4]
 8007bb4:	625a      	str	r2, [r3, #36]	; 0x24

    if ((hi2c->XferSize > 0U))
 8007bb6:	687b      	ldr	r3, [r7, #4]
 8007bb8:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8007bba:	2b00      	cmp	r3, #0
 8007bbc:	d00c      	beq.n	8007bd8 <I2C_ITSlaveCplt+0x150>
    {
      hi2c->XferSize--;
 8007bbe:	687b      	ldr	r3, [r7, #4]
 8007bc0:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8007bc2:	3b01      	subs	r3, #1
 8007bc4:	b29a      	uxth	r2, r3
 8007bc6:	687b      	ldr	r3, [r7, #4]
 8007bc8:	851a      	strh	r2, [r3, #40]	; 0x28
      hi2c->XferCount--;
 8007bca:	687b      	ldr	r3, [r7, #4]
 8007bcc:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8007bce:	b29b      	uxth	r3, r3
 8007bd0:	3b01      	subs	r3, #1
 8007bd2:	b29a      	uxth	r2, r3
 8007bd4:	687b      	ldr	r3, [r7, #4]
 8007bd6:	855a      	strh	r2, [r3, #42]	; 0x2a
    }
  }

  /* All data are not transferred, so set error code accordingly */
  if (hi2c->XferCount != 0U)
 8007bd8:	687b      	ldr	r3, [r7, #4]
 8007bda:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8007bdc:	b29b      	uxth	r3, r3
 8007bde:	2b00      	cmp	r3, #0
 8007be0:	d005      	beq.n	8007bee <I2C_ITSlaveCplt+0x166>
  {
    /* Set ErrorCode corresponding to a Non-Acknowledge */
    hi2c->ErrorCode |= HAL_I2C_ERROR_AF;
 8007be2:	687b      	ldr	r3, [r7, #4]
 8007be4:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8007be6:	2204      	movs	r2, #4
 8007be8:	431a      	orrs	r2, r3
 8007bea:	687b      	ldr	r3, [r7, #4]
 8007bec:	645a      	str	r2, [r3, #68]	; 0x44
  }

  hi2c->Mode = HAL_I2C_MODE_NONE;
 8007bee:	687b      	ldr	r3, [r7, #4]
 8007bf0:	2242      	movs	r2, #66	; 0x42
 8007bf2:	2100      	movs	r1, #0
 8007bf4:	5499      	strb	r1, [r3, r2]
  hi2c->XferISR = NULL;
 8007bf6:	687b      	ldr	r3, [r7, #4]
 8007bf8:	2200      	movs	r2, #0
 8007bfa:	635a      	str	r2, [r3, #52]	; 0x34

  if (hi2c->ErrorCode != HAL_I2C_ERROR_NONE)
 8007bfc:	687b      	ldr	r3, [r7, #4]
 8007bfe:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8007c00:	2b00      	cmp	r3, #0
 8007c02:	d013      	beq.n	8007c2c <I2C_ITSlaveCplt+0x1a4>
  {
    /* Call the corresponding callback to inform upper layer of End of Transfer */
    I2C_ITError(hi2c, hi2c->ErrorCode);
 8007c04:	687b      	ldr	r3, [r7, #4]
 8007c06:	6c5a      	ldr	r2, [r3, #68]	; 0x44
 8007c08:	687b      	ldr	r3, [r7, #4]
 8007c0a:	0011      	movs	r1, r2
 8007c0c:	0018      	movs	r0, r3
 8007c0e:	f000 f8b9 	bl	8007d84 <I2C_ITError>

    /* Call the Listen Complete callback, to inform upper layer of the end of Listen usecase */
    if (hi2c->State == HAL_I2C_STATE_LISTEN)
 8007c12:	687b      	ldr	r3, [r7, #4]
 8007c14:	2241      	movs	r2, #65	; 0x41
 8007c16:	5c9b      	ldrb	r3, [r3, r2]
 8007c18:	b2db      	uxtb	r3, r3
 8007c1a:	2b28      	cmp	r3, #40	; 0x28
 8007c1c:	d147      	bne.n	8007cae <I2C_ITSlaveCplt+0x226>
    {
      /* Call I2C Listen complete process */
      I2C_ITListenCplt(hi2c, tmpITFlags);
 8007c1e:	697a      	ldr	r2, [r7, #20]
 8007c20:	687b      	ldr	r3, [r7, #4]
 8007c22:	0011      	movs	r1, r2
 8007c24:	0018      	movs	r0, r3
 8007c26:	f000 f853 	bl	8007cd0 <I2C_ITListenCplt>
    hi2c->SlaveTxCpltCallback(hi2c);
#else
    HAL_I2C_SlaveTxCpltCallback(hi2c);
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
  }
}
 8007c2a:	e040      	b.n	8007cae <I2C_ITSlaveCplt+0x226>
  else if (hi2c->XferOptions != I2C_NO_OPTION_FRAME)
 8007c2c:	687b      	ldr	r3, [r7, #4]
 8007c2e:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8007c30:	4a26      	ldr	r2, [pc, #152]	; (8007ccc <I2C_ITSlaveCplt+0x244>)
 8007c32:	4293      	cmp	r3, r2
 8007c34:	d016      	beq.n	8007c64 <I2C_ITSlaveCplt+0x1dc>
    I2C_ITSlaveSeqCplt(hi2c);
 8007c36:	687b      	ldr	r3, [r7, #4]
 8007c38:	0018      	movs	r0, r3
 8007c3a:	f7ff fded 	bl	8007818 <I2C_ITSlaveSeqCplt>
    hi2c->XferOptions = I2C_NO_OPTION_FRAME;
 8007c3e:	687b      	ldr	r3, [r7, #4]
 8007c40:	4a22      	ldr	r2, [pc, #136]	; (8007ccc <I2C_ITSlaveCplt+0x244>)
 8007c42:	62da      	str	r2, [r3, #44]	; 0x2c
    hi2c->State = HAL_I2C_STATE_READY;
 8007c44:	687b      	ldr	r3, [r7, #4]
 8007c46:	2241      	movs	r2, #65	; 0x41
 8007c48:	2120      	movs	r1, #32
 8007c4a:	5499      	strb	r1, [r3, r2]
    hi2c->PreviousState = I2C_STATE_NONE;
 8007c4c:	687b      	ldr	r3, [r7, #4]
 8007c4e:	2200      	movs	r2, #0
 8007c50:	631a      	str	r2, [r3, #48]	; 0x30
    __HAL_UNLOCK(hi2c);
 8007c52:	687b      	ldr	r3, [r7, #4]
 8007c54:	2240      	movs	r2, #64	; 0x40
 8007c56:	2100      	movs	r1, #0
 8007c58:	5499      	strb	r1, [r3, r2]
    HAL_I2C_ListenCpltCallback(hi2c);
 8007c5a:	687b      	ldr	r3, [r7, #4]
 8007c5c:	0018      	movs	r0, r3
 8007c5e:	f7ff f875 	bl	8006d4c <HAL_I2C_ListenCpltCallback>
}
 8007c62:	e024      	b.n	8007cae <I2C_ITSlaveCplt+0x226>
  else if (hi2c->State == HAL_I2C_STATE_BUSY_RX)
 8007c64:	687b      	ldr	r3, [r7, #4]
 8007c66:	2241      	movs	r2, #65	; 0x41
 8007c68:	5c9b      	ldrb	r3, [r3, r2]
 8007c6a:	b2db      	uxtb	r3, r3
 8007c6c:	2b22      	cmp	r3, #34	; 0x22
 8007c6e:	d10f      	bne.n	8007c90 <I2C_ITSlaveCplt+0x208>
    hi2c->State = HAL_I2C_STATE_READY;
 8007c70:	687b      	ldr	r3, [r7, #4]
 8007c72:	2241      	movs	r2, #65	; 0x41
 8007c74:	2120      	movs	r1, #32
 8007c76:	5499      	strb	r1, [r3, r2]
    hi2c->PreviousState = I2C_STATE_NONE;
 8007c78:	687b      	ldr	r3, [r7, #4]
 8007c7a:	2200      	movs	r2, #0
 8007c7c:	631a      	str	r2, [r3, #48]	; 0x30
    __HAL_UNLOCK(hi2c);
 8007c7e:	687b      	ldr	r3, [r7, #4]
 8007c80:	2240      	movs	r2, #64	; 0x40
 8007c82:	2100      	movs	r1, #0
 8007c84:	5499      	strb	r1, [r3, r2]
    HAL_I2C_SlaveRxCpltCallback(hi2c);
 8007c86:	687b      	ldr	r3, [r7, #4]
 8007c88:	0018      	movs	r0, r3
 8007c8a:	f7ff f847 	bl	8006d1c <HAL_I2C_SlaveRxCpltCallback>
}
 8007c8e:	e00e      	b.n	8007cae <I2C_ITSlaveCplt+0x226>
    hi2c->State = HAL_I2C_STATE_READY;
 8007c90:	687b      	ldr	r3, [r7, #4]
 8007c92:	2241      	movs	r2, #65	; 0x41
 8007c94:	2120      	movs	r1, #32
 8007c96:	5499      	strb	r1, [r3, r2]
    hi2c->PreviousState = I2C_STATE_NONE;
 8007c98:	687b      	ldr	r3, [r7, #4]
 8007c9a:	2200      	movs	r2, #0
 8007c9c:	631a      	str	r2, [r3, #48]	; 0x30
    __HAL_UNLOCK(hi2c);
 8007c9e:	687b      	ldr	r3, [r7, #4]
 8007ca0:	2240      	movs	r2, #64	; 0x40
 8007ca2:	2100      	movs	r1, #0
 8007ca4:	5499      	strb	r1, [r3, r2]
    HAL_I2C_SlaveTxCpltCallback(hi2c);
 8007ca6:	687b      	ldr	r3, [r7, #4]
 8007ca8:	0018      	movs	r0, r3
 8007caa:	f7ff f82f 	bl	8006d0c <HAL_I2C_SlaveTxCpltCallback>
}
 8007cae:	46c0      	nop			; (mov r8, r8)
 8007cb0:	46bd      	mov	sp, r7
 8007cb2:	b006      	add	sp, #24
 8007cb4:	bd80      	pop	{r7, pc}
 8007cb6:	46c0      	nop			; (mov r8, r8)
 8007cb8:	00008001 	.word	0x00008001
 8007cbc:	00008002 	.word	0x00008002
 8007cc0:	fe00e800 	.word	0xfe00e800
 8007cc4:	ffffbfff 	.word	0xffffbfff
 8007cc8:	ffff7fff 	.word	0xffff7fff
 8007ccc:	ffff0000 	.word	0xffff0000

08007cd0 <I2C_ITListenCplt>:
  * @param  hi2c I2C handle.
  * @param  ITFlags Interrupt flags to handle.
  * @retval None
  */
static void I2C_ITListenCplt(I2C_HandleTypeDef *hi2c, uint32_t ITFlags)
{
 8007cd0:	b580      	push	{r7, lr}
 8007cd2:	b082      	sub	sp, #8
 8007cd4:	af00      	add	r7, sp, #0
 8007cd6:	6078      	str	r0, [r7, #4]
 8007cd8:	6039      	str	r1, [r7, #0]
  /* Reset handle parameters */
  hi2c->XferOptions = I2C_NO_OPTION_FRAME;
 8007cda:	687b      	ldr	r3, [r7, #4]
 8007cdc:	4a27      	ldr	r2, [pc, #156]	; (8007d7c <I2C_ITListenCplt+0xac>)
 8007cde:	62da      	str	r2, [r3, #44]	; 0x2c
  hi2c->PreviousState = I2C_STATE_NONE;
 8007ce0:	687b      	ldr	r3, [r7, #4]
 8007ce2:	2200      	movs	r2, #0
 8007ce4:	631a      	str	r2, [r3, #48]	; 0x30
  hi2c->State = HAL_I2C_STATE_READY;
 8007ce6:	687b      	ldr	r3, [r7, #4]
 8007ce8:	2241      	movs	r2, #65	; 0x41
 8007cea:	2120      	movs	r1, #32
 8007cec:	5499      	strb	r1, [r3, r2]
  hi2c->Mode = HAL_I2C_MODE_NONE;
 8007cee:	687b      	ldr	r3, [r7, #4]
 8007cf0:	2242      	movs	r2, #66	; 0x42
 8007cf2:	2100      	movs	r1, #0
 8007cf4:	5499      	strb	r1, [r3, r2]
  hi2c->XferISR = NULL;
 8007cf6:	687b      	ldr	r3, [r7, #4]
 8007cf8:	2200      	movs	r2, #0
 8007cfa:	635a      	str	r2, [r3, #52]	; 0x34

  /* Store Last receive data if any */
  if (I2C_CHECK_FLAG(ITFlags, I2C_FLAG_RXNE) != RESET)
 8007cfc:	683b      	ldr	r3, [r7, #0]
 8007cfe:	089b      	lsrs	r3, r3, #2
 8007d00:	001a      	movs	r2, r3
 8007d02:	2301      	movs	r3, #1
 8007d04:	4013      	ands	r3, r2
 8007d06:	d022      	beq.n	8007d4e <I2C_ITListenCplt+0x7e>
  {
    /* Read data from RXDR */
    *hi2c->pBuffPtr = (uint8_t)hi2c->Instance->RXDR;
 8007d08:	687b      	ldr	r3, [r7, #4]
 8007d0a:	681b      	ldr	r3, [r3, #0]
 8007d0c:	6a5a      	ldr	r2, [r3, #36]	; 0x24
 8007d0e:	687b      	ldr	r3, [r7, #4]
 8007d10:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8007d12:	b2d2      	uxtb	r2, r2
 8007d14:	701a      	strb	r2, [r3, #0]

    /* Increment Buffer pointer */
    hi2c->pBuffPtr++;
 8007d16:	687b      	ldr	r3, [r7, #4]
 8007d18:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8007d1a:	1c5a      	adds	r2, r3, #1
 8007d1c:	687b      	ldr	r3, [r7, #4]
 8007d1e:	625a      	str	r2, [r3, #36]	; 0x24

    if ((hi2c->XferSize > 0U))
 8007d20:	687b      	ldr	r3, [r7, #4]
 8007d22:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8007d24:	2b00      	cmp	r3, #0
 8007d26:	d012      	beq.n	8007d4e <I2C_ITListenCplt+0x7e>
    {
      hi2c->XferSize--;
 8007d28:	687b      	ldr	r3, [r7, #4]
 8007d2a:	8d1b      	ldrh	r3, [r3, #40]	; 0x28
 8007d2c:	3b01      	subs	r3, #1
 8007d2e:	b29a      	uxth	r2, r3
 8007d30:	687b      	ldr	r3, [r7, #4]
 8007d32:	851a      	strh	r2, [r3, #40]	; 0x28
      hi2c->XferCount--;
 8007d34:	687b      	ldr	r3, [r7, #4]
 8007d36:	8d5b      	ldrh	r3, [r3, #42]	; 0x2a
 8007d38:	b29b      	uxth	r3, r3
 8007d3a:	3b01      	subs	r3, #1
 8007d3c:	b29a      	uxth	r2, r3
 8007d3e:	687b      	ldr	r3, [r7, #4]
 8007d40:	855a      	strh	r2, [r3, #42]	; 0x2a

      /* Set ErrorCode corresponding to a Non-Acknowledge */
      hi2c->ErrorCode |= HAL_I2C_ERROR_AF;
 8007d42:	687b      	ldr	r3, [r7, #4]
 8007d44:	6c5b      	ldr	r3, [r3, #68]	; 0x44
 8007d46:	2204      	movs	r2, #4
 8007d48:	431a      	orrs	r2, r3
 8007d4a:	687b      	ldr	r3, [r7, #4]
 8007d4c:	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);
 8007d4e:	4a0c      	ldr	r2, [pc, #48]	; (8007d80 <I2C_ITListenCplt+0xb0>)
 8007d50:	687b      	ldr	r3, [r7, #4]
 8007d52:	0011      	movs	r1, r2
 8007d54:	0018      	movs	r0, r3
 8007d56:	f000 f9ff 	bl	8008158 <I2C_Disable_IRQ>

  /* Clear NACK Flag */
  __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_AF);
 8007d5a:	687b      	ldr	r3, [r7, #4]
 8007d5c:	681b      	ldr	r3, [r3, #0]
 8007d5e:	2210      	movs	r2, #16
 8007d60:	61da      	str	r2, [r3, #28]

  /* Process Unlocked */
  __HAL_UNLOCK(hi2c);
 8007d62:	687b      	ldr	r3, [r7, #4]
 8007d64:	2240      	movs	r2, #64	; 0x40
 8007d66:	2100      	movs	r1, #0
 8007d68:	5499      	strb	r1, [r3, r2]

  /* 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);
 8007d6a:	687b      	ldr	r3, [r7, #4]
 8007d6c:	0018      	movs	r0, r3
 8007d6e:	f7fe ffed 	bl	8006d4c <HAL_I2C_ListenCpltCallback>
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
}
 8007d72:	46c0      	nop			; (mov r8, r8)
 8007d74:	46bd      	mov	sp, r7
 8007d76:	b002      	add	sp, #8
 8007d78:	bd80      	pop	{r7, pc}
 8007d7a:	46c0      	nop			; (mov r8, r8)
 8007d7c:	ffff0000 	.word	0xffff0000
 8007d80:	00008003 	.word	0x00008003

08007d84 <I2C_ITError>:
  * @param  hi2c I2C handle.
  * @param  ErrorCode Error code to handle.
  * @retval None
  */
static void I2C_ITError(I2C_HandleTypeDef *hi2c, uint32_t ErrorCode)
{
 8007d84:	b580      	push	{r7, lr}
 8007d86:	b084      	sub	sp, #16
 8007d88:	af00      	add	r7, sp, #0
 8007d8a:	6078      	str	r0, [r7, #4]
 8007d8c:	6039      	str	r1, [r7, #0]
  HAL_I2C_StateTypeDef tmpstate = hi2c->State;
 8007d8e:	200f      	movs	r0, #15
 8007d90:	183b      	adds	r3, r7, r0
 8007d92:	687a      	ldr	r2, [r7, #4]
 8007d94:	2141      	movs	r1, #65	; 0x41
 8007d96:	5c52      	ldrb	r2, [r2, r1]
 8007d98:	701a      	strb	r2, [r3, #0]
  uint32_t tmppreviousstate;

  /* Reset handle parameters */
  hi2c->Mode          = HAL_I2C_MODE_NONE;
 8007d9a:	687b      	ldr	r3, [r7, #4]
 8007d9c:	2242      	movs	r2, #66	; 0x42
 8007d9e:	2100      	movs	r1, #0
 8007da0:	5499      	strb	r1, [r3, r2]
  hi2c->XferOptions   = I2C_NO_OPTION_FRAME;
 8007da2:	687b      	ldr	r3, [r7, #4]
 8007da4:	4a62      	ldr	r2, [pc, #392]	; (8007f30 <I2C_ITError+0x1ac>)
 8007da6:	62da      	str	r2, [r3, #44]	; 0x2c
  hi2c->XferCount     = 0U;
 8007da8:	687b      	ldr	r3, [r7, #4]
 8007daa:	2200      	movs	r2, #0
 8007dac:	855a      	strh	r2, [r3, #42]	; 0x2a

  /* Set new error code */
  hi2c->ErrorCode |= ErrorCode;
 8007dae:	687b      	ldr	r3, [r7, #4]
 8007db0:	6c5a      	ldr	r2, [r3, #68]	; 0x44
 8007db2:	683b      	ldr	r3, [r7, #0]
 8007db4:	431a      	orrs	r2, r3
 8007db6:	687b      	ldr	r3, [r7, #4]
 8007db8:	645a      	str	r2, [r3, #68]	; 0x44

  /* Disable Interrupts */
  if ((tmpstate == HAL_I2C_STATE_LISTEN)         ||
 8007dba:	183b      	adds	r3, r7, r0
 8007dbc:	781b      	ldrb	r3, [r3, #0]
 8007dbe:	2b28      	cmp	r3, #40	; 0x28
 8007dc0:	d007      	beq.n	8007dd2 <I2C_ITError+0x4e>
 8007dc2:	183b      	adds	r3, r7, r0
 8007dc4:	781b      	ldrb	r3, [r3, #0]
 8007dc6:	2b29      	cmp	r3, #41	; 0x29
 8007dc8:	d003      	beq.n	8007dd2 <I2C_ITError+0x4e>
      (tmpstate == HAL_I2C_STATE_BUSY_TX_LISTEN) ||
 8007dca:	183b      	adds	r3, r7, r0
 8007dcc:	781b      	ldrb	r3, [r3, #0]
 8007dce:	2b2a      	cmp	r3, #42	; 0x2a
 8007dd0:	d10c      	bne.n	8007dec <I2C_ITError+0x68>
      (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);
 8007dd2:	687b      	ldr	r3, [r7, #4]
 8007dd4:	2103      	movs	r1, #3
 8007dd6:	0018      	movs	r0, r3
 8007dd8:	f000 f9be 	bl	8008158 <I2C_Disable_IRQ>

    /* keep HAL_I2C_STATE_LISTEN if set */
    hi2c->State         = HAL_I2C_STATE_LISTEN;
 8007ddc:	687b      	ldr	r3, [r7, #4]
 8007dde:	2241      	movs	r2, #65	; 0x41
 8007de0:	2128      	movs	r1, #40	; 0x28
 8007de2:	5499      	strb	r1, [r3, r2]
    hi2c->XferISR       = I2C_Slave_ISR_IT;
 8007de4:	687b      	ldr	r3, [r7, #4]
 8007de6:	4a53      	ldr	r2, [pc, #332]	; (8007f34 <I2C_ITError+0x1b0>)
 8007de8:	635a      	str	r2, [r3, #52]	; 0x34
 8007dea:	e012      	b.n	8007e12 <I2C_ITError+0x8e>
  }
  else
  {
    /* Disable all interrupts */
    I2C_Disable_IRQ(hi2c, I2C_XFER_LISTEN_IT | I2C_XFER_RX_IT | I2C_XFER_TX_IT);
 8007dec:	4a52      	ldr	r2, [pc, #328]	; (8007f38 <I2C_ITError+0x1b4>)
 8007dee:	687b      	ldr	r3, [r7, #4]
 8007df0:	0011      	movs	r1, r2
 8007df2:	0018      	movs	r0, r3
 8007df4:	f000 f9b0 	bl	8008158 <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)
 8007df8:	687b      	ldr	r3, [r7, #4]
 8007dfa:	2241      	movs	r2, #65	; 0x41
 8007dfc:	5c9b      	ldrb	r3, [r3, r2]
 8007dfe:	b2db      	uxtb	r3, r3
 8007e00:	2b60      	cmp	r3, #96	; 0x60
 8007e02:	d003      	beq.n	8007e0c <I2C_ITError+0x88>
    {
      /* Set HAL_I2C_STATE_READY */
      hi2c->State         = HAL_I2C_STATE_READY;
 8007e04:	687b      	ldr	r3, [r7, #4]
 8007e06:	2241      	movs	r2, #65	; 0x41
 8007e08:	2120      	movs	r1, #32
 8007e0a:	5499      	strb	r1, [r3, r2]
    }
    hi2c->XferISR       = NULL;
 8007e0c:	687b      	ldr	r3, [r7, #4]
 8007e0e:	2200      	movs	r2, #0
 8007e10:	635a      	str	r2, [r3, #52]	; 0x34
  }

  /* Abort DMA TX transfer if any */
  tmppreviousstate = hi2c->PreviousState;
 8007e12:	687b      	ldr	r3, [r7, #4]
 8007e14:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8007e16:	60bb      	str	r3, [r7, #8]
  if ((hi2c->hdmatx != NULL) && ((tmppreviousstate == I2C_STATE_MASTER_BUSY_TX) || \
 8007e18:	687b      	ldr	r3, [r7, #4]
 8007e1a:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8007e1c:	2b00      	cmp	r3, #0
 8007e1e:	d03b      	beq.n	8007e98 <I2C_ITError+0x114>
 8007e20:	68bb      	ldr	r3, [r7, #8]
 8007e22:	2b11      	cmp	r3, #17
 8007e24:	d002      	beq.n	8007e2c <I2C_ITError+0xa8>
 8007e26:	68bb      	ldr	r3, [r7, #8]
 8007e28:	2b21      	cmp	r3, #33	; 0x21
 8007e2a:	d135      	bne.n	8007e98 <I2C_ITError+0x114>
                                 (tmppreviousstate == I2C_STATE_SLAVE_BUSY_TX)))
  {
    if ((hi2c->Instance->CR1 & I2C_CR1_TXDMAEN) == I2C_CR1_TXDMAEN)
 8007e2c:	687b      	ldr	r3, [r7, #4]
 8007e2e:	681b      	ldr	r3, [r3, #0]
 8007e30:	681a      	ldr	r2, [r3, #0]
 8007e32:	2380      	movs	r3, #128	; 0x80
 8007e34:	01db      	lsls	r3, r3, #7
 8007e36:	401a      	ands	r2, r3
 8007e38:	2380      	movs	r3, #128	; 0x80
 8007e3a:	01db      	lsls	r3, r3, #7
 8007e3c:	429a      	cmp	r2, r3
 8007e3e:	d107      	bne.n	8007e50 <I2C_ITError+0xcc>
    {
      hi2c->Instance->CR1 &= ~I2C_CR1_TXDMAEN;
 8007e40:	687b      	ldr	r3, [r7, #4]
 8007e42:	681b      	ldr	r3, [r3, #0]
 8007e44:	681a      	ldr	r2, [r3, #0]
 8007e46:	687b      	ldr	r3, [r7, #4]
 8007e48:	681b      	ldr	r3, [r3, #0]
 8007e4a:	493c      	ldr	r1, [pc, #240]	; (8007f3c <I2C_ITError+0x1b8>)
 8007e4c:	400a      	ands	r2, r1
 8007e4e:	601a      	str	r2, [r3, #0]
    }

    if (HAL_DMA_GetState(hi2c->hdmatx) != HAL_DMA_STATE_READY)
 8007e50:	687b      	ldr	r3, [r7, #4]
 8007e52:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8007e54:	0018      	movs	r0, r3
 8007e56:	f7fe fbfe 	bl	8006656 <HAL_DMA_GetState>
 8007e5a:	0003      	movs	r3, r0
 8007e5c:	2b01      	cmp	r3, #1
 8007e5e:	d016      	beq.n	8007e8e <I2C_ITError+0x10a>
    {
      /* Set the I2C DMA Abort callback :
       will lead to call HAL_I2C_ErrorCallback() at end of DMA abort procedure */
      hi2c->hdmatx->XferAbortCallback = I2C_DMAAbort;
 8007e60:	687b      	ldr	r3, [r7, #4]
 8007e62:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8007e64:	4a36      	ldr	r2, [pc, #216]	; (8007f40 <I2C_ITError+0x1bc>)
 8007e66:	635a      	str	r2, [r3, #52]	; 0x34

      /* Process Unlocked */
      __HAL_UNLOCK(hi2c);
 8007e68:	687b      	ldr	r3, [r7, #4]
 8007e6a:	2240      	movs	r2, #64	; 0x40
 8007e6c:	2100      	movs	r1, #0
 8007e6e:	5499      	strb	r1, [r3, r2]

      /* Abort DMA TX */
      if (HAL_DMA_Abort_IT(hi2c->hdmatx) != HAL_OK)
 8007e70:	687b      	ldr	r3, [r7, #4]
 8007e72:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8007e74:	0018      	movs	r0, r3
 8007e76:	f7fe fb07 	bl	8006488 <HAL_DMA_Abort_IT>
 8007e7a:	1e03      	subs	r3, r0, #0
 8007e7c:	d051      	beq.n	8007f22 <I2C_ITError+0x19e>
      {
        /* Call Directly XferAbortCallback function in case of error */
        hi2c->hdmatx->XferAbortCallback(hi2c->hdmatx);
 8007e7e:	687b      	ldr	r3, [r7, #4]
 8007e80:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8007e82:	6b5a      	ldr	r2, [r3, #52]	; 0x34
 8007e84:	687b      	ldr	r3, [r7, #4]
 8007e86:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8007e88:	0018      	movs	r0, r3
 8007e8a:	4790      	blx	r2
    if (HAL_DMA_GetState(hi2c->hdmatx) != HAL_DMA_STATE_READY)
 8007e8c:	e049      	b.n	8007f22 <I2C_ITError+0x19e>
      }
    }
    else
    {
      I2C_TreatErrorCallback(hi2c);
 8007e8e:	687b      	ldr	r3, [r7, #4]
 8007e90:	0018      	movs	r0, r3
 8007e92:	f000 f859 	bl	8007f48 <I2C_TreatErrorCallback>
    if (HAL_DMA_GetState(hi2c->hdmatx) != HAL_DMA_STATE_READY)
 8007e96:	e044      	b.n	8007f22 <I2C_ITError+0x19e>
    }
  }
  /* Abort DMA RX transfer if any */
  else if ((hi2c->hdmarx != NULL) && ((tmppreviousstate == I2C_STATE_MASTER_BUSY_RX) || \
 8007e98:	687b      	ldr	r3, [r7, #4]
 8007e9a:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8007e9c:	2b00      	cmp	r3, #0
 8007e9e:	d03b      	beq.n	8007f18 <I2C_ITError+0x194>
 8007ea0:	68bb      	ldr	r3, [r7, #8]
 8007ea2:	2b12      	cmp	r3, #18
 8007ea4:	d002      	beq.n	8007eac <I2C_ITError+0x128>
 8007ea6:	68bb      	ldr	r3, [r7, #8]
 8007ea8:	2b22      	cmp	r3, #34	; 0x22
 8007eaa:	d135      	bne.n	8007f18 <I2C_ITError+0x194>
                                      (tmppreviousstate == I2C_STATE_SLAVE_BUSY_RX)))
  {
    if ((hi2c->Instance->CR1 & I2C_CR1_RXDMAEN) == I2C_CR1_RXDMAEN)
 8007eac:	687b      	ldr	r3, [r7, #4]
 8007eae:	681b      	ldr	r3, [r3, #0]
 8007eb0:	681a      	ldr	r2, [r3, #0]
 8007eb2:	2380      	movs	r3, #128	; 0x80
 8007eb4:	021b      	lsls	r3, r3, #8
 8007eb6:	401a      	ands	r2, r3
 8007eb8:	2380      	movs	r3, #128	; 0x80
 8007eba:	021b      	lsls	r3, r3, #8
 8007ebc:	429a      	cmp	r2, r3
 8007ebe:	d107      	bne.n	8007ed0 <I2C_ITError+0x14c>
    {
      hi2c->Instance->CR1 &= ~I2C_CR1_RXDMAEN;
 8007ec0:	687b      	ldr	r3, [r7, #4]
 8007ec2:	681b      	ldr	r3, [r3, #0]
 8007ec4:	681a      	ldr	r2, [r3, #0]
 8007ec6:	687b      	ldr	r3, [r7, #4]
 8007ec8:	681b      	ldr	r3, [r3, #0]
 8007eca:	491e      	ldr	r1, [pc, #120]	; (8007f44 <I2C_ITError+0x1c0>)
 8007ecc:	400a      	ands	r2, r1
 8007ece:	601a      	str	r2, [r3, #0]
    }

    if (HAL_DMA_GetState(hi2c->hdmarx) != HAL_DMA_STATE_READY)
 8007ed0:	687b      	ldr	r3, [r7, #4]
 8007ed2:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8007ed4:	0018      	movs	r0, r3
 8007ed6:	f7fe fbbe 	bl	8006656 <HAL_DMA_GetState>
 8007eda:	0003      	movs	r3, r0
 8007edc:	2b01      	cmp	r3, #1
 8007ede:	d016      	beq.n	8007f0e <I2C_ITError+0x18a>
    {
      /* Set the I2C DMA Abort callback :
        will lead to call HAL_I2C_ErrorCallback() at end of DMA abort procedure */
      hi2c->hdmarx->XferAbortCallback = I2C_DMAAbort;
 8007ee0:	687b      	ldr	r3, [r7, #4]
 8007ee2:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8007ee4:	4a16      	ldr	r2, [pc, #88]	; (8007f40 <I2C_ITError+0x1bc>)
 8007ee6:	635a      	str	r2, [r3, #52]	; 0x34

      /* Process Unlocked */
      __HAL_UNLOCK(hi2c);
 8007ee8:	687b      	ldr	r3, [r7, #4]
 8007eea:	2240      	movs	r2, #64	; 0x40
 8007eec:	2100      	movs	r1, #0
 8007eee:	5499      	strb	r1, [r3, r2]

      /* Abort DMA RX */
      if (HAL_DMA_Abort_IT(hi2c->hdmarx) != HAL_OK)
 8007ef0:	687b      	ldr	r3, [r7, #4]
 8007ef2:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8007ef4:	0018      	movs	r0, r3
 8007ef6:	f7fe fac7 	bl	8006488 <HAL_DMA_Abort_IT>
 8007efa:	1e03      	subs	r3, r0, #0
 8007efc:	d013      	beq.n	8007f26 <I2C_ITError+0x1a2>
      {
        /* Call Directly hi2c->hdmarx->XferAbortCallback function in case of error */
        hi2c->hdmarx->XferAbortCallback(hi2c->hdmarx);
 8007efe:	687b      	ldr	r3, [r7, #4]
 8007f00:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8007f02:	6b5a      	ldr	r2, [r3, #52]	; 0x34
 8007f04:	687b      	ldr	r3, [r7, #4]
 8007f06:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8007f08:	0018      	movs	r0, r3
 8007f0a:	4790      	blx	r2
    if (HAL_DMA_GetState(hi2c->hdmarx) != HAL_DMA_STATE_READY)
 8007f0c:	e00b      	b.n	8007f26 <I2C_ITError+0x1a2>
      }
    }
    else
    {
      I2C_TreatErrorCallback(hi2c);
 8007f0e:	687b      	ldr	r3, [r7, #4]
 8007f10:	0018      	movs	r0, r3
 8007f12:	f000 f819 	bl	8007f48 <I2C_TreatErrorCallback>
    if (HAL_DMA_GetState(hi2c->hdmarx) != HAL_DMA_STATE_READY)
 8007f16:	e006      	b.n	8007f26 <I2C_ITError+0x1a2>
    }
  }
  else
  {
    I2C_TreatErrorCallback(hi2c);
 8007f18:	687b      	ldr	r3, [r7, #4]
 8007f1a:	0018      	movs	r0, r3
 8007f1c:	f000 f814 	bl	8007f48 <I2C_TreatErrorCallback>
  }
}
 8007f20:	e002      	b.n	8007f28 <I2C_ITError+0x1a4>
    if (HAL_DMA_GetState(hi2c->hdmatx) != HAL_DMA_STATE_READY)
 8007f22:	46c0      	nop			; (mov r8, r8)
 8007f24:	e000      	b.n	8007f28 <I2C_ITError+0x1a4>
    if (HAL_DMA_GetState(hi2c->hdmarx) != HAL_DMA_STATE_READY)
 8007f26:	46c0      	nop			; (mov r8, r8)
}
 8007f28:	46c0      	nop			; (mov r8, r8)
 8007f2a:	46bd      	mov	sp, r7
 8007f2c:	b004      	add	sp, #16
 8007f2e:	bd80      	pop	{r7, pc}
 8007f30:	ffff0000 	.word	0xffff0000
 8007f34:	08007021 	.word	0x08007021
 8007f38:	00008003 	.word	0x00008003
 8007f3c:	ffffbfff 	.word	0xffffbfff
 8007f40:	08007fdf 	.word	0x08007fdf
 8007f44:	ffff7fff 	.word	0xffff7fff

08007f48 <I2C_TreatErrorCallback>:
  * @brief  I2C Error callback treatment.
  * @param  hi2c I2C handle.
  * @retval None
  */
static void I2C_TreatErrorCallback(I2C_HandleTypeDef *hi2c)
{
 8007f48:	b580      	push	{r7, lr}
 8007f4a:	b082      	sub	sp, #8
 8007f4c:	af00      	add	r7, sp, #0
 8007f4e:	6078      	str	r0, [r7, #4]
  if (hi2c->State == HAL_I2C_STATE_ABORT)
 8007f50:	687b      	ldr	r3, [r7, #4]
 8007f52:	2241      	movs	r2, #65	; 0x41
 8007f54:	5c9b      	ldrb	r3, [r3, r2]
 8007f56:	b2db      	uxtb	r3, r3
 8007f58:	2b60      	cmp	r3, #96	; 0x60
 8007f5a:	d10f      	bne.n	8007f7c <I2C_TreatErrorCallback+0x34>
  {
    hi2c->State = HAL_I2C_STATE_READY;
 8007f5c:	687b      	ldr	r3, [r7, #4]
 8007f5e:	2241      	movs	r2, #65	; 0x41
 8007f60:	2120      	movs	r1, #32
 8007f62:	5499      	strb	r1, [r3, r2]
    hi2c->PreviousState = I2C_STATE_NONE;
 8007f64:	687b      	ldr	r3, [r7, #4]
 8007f66:	2200      	movs	r2, #0
 8007f68:	631a      	str	r2, [r3, #48]	; 0x30

    /* Process Unlocked */
    __HAL_UNLOCK(hi2c);
 8007f6a:	687b      	ldr	r3, [r7, #4]
 8007f6c:	2240      	movs	r2, #64	; 0x40
 8007f6e:	2100      	movs	r1, #0
 8007f70:	5499      	strb	r1, [r3, r2]

    /* 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);
 8007f72:	687b      	ldr	r3, [r7, #4]
 8007f74:	0018      	movs	r0, r3
 8007f76:	f7fe ff09 	bl	8006d8c <HAL_I2C_AbortCpltCallback>
    hi2c->ErrorCallback(hi2c);
#else
    HAL_I2C_ErrorCallback(hi2c);
#endif /* USE_HAL_I2C_REGISTER_CALLBACKS */
  }
}
 8007f7a:	e00a      	b.n	8007f92 <I2C_TreatErrorCallback+0x4a>
    hi2c->PreviousState = I2C_STATE_NONE;
 8007f7c:	687b      	ldr	r3, [r7, #4]
 8007f7e:	2200      	movs	r2, #0
 8007f80:	631a      	str	r2, [r3, #48]	; 0x30
    __HAL_UNLOCK(hi2c);
 8007f82:	687b      	ldr	r3, [r7, #4]
 8007f84:	2240      	movs	r2, #64	; 0x40
 8007f86:	2100      	movs	r1, #0
 8007f88:	5499      	strb	r1, [r3, r2]
    HAL_I2C_ErrorCallback(hi2c);
 8007f8a:	687b      	ldr	r3, [r7, #4]
 8007f8c:	0018      	movs	r0, r3
 8007f8e:	f7fe fef5 	bl	8006d7c <HAL_I2C_ErrorCallback>
}
 8007f92:	46c0      	nop			; (mov r8, r8)
 8007f94:	46bd      	mov	sp, r7
 8007f96:	b002      	add	sp, #8
 8007f98:	bd80      	pop	{r7, pc}

08007f9a <I2C_Flush_TXDR>:
  * @brief  I2C Tx data register flush process.
  * @param  hi2c I2C handle.
  * @retval None
  */
static void I2C_Flush_TXDR(I2C_HandleTypeDef *hi2c)
{
 8007f9a:	b580      	push	{r7, lr}
 8007f9c:	b082      	sub	sp, #8
 8007f9e:	af00      	add	r7, sp, #0
 8007fa0:	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)
 8007fa2:	687b      	ldr	r3, [r7, #4]
 8007fa4:	681b      	ldr	r3, [r3, #0]
 8007fa6:	699b      	ldr	r3, [r3, #24]
 8007fa8:	2202      	movs	r2, #2
 8007faa:	4013      	ands	r3, r2
 8007fac:	2b02      	cmp	r3, #2
 8007fae:	d103      	bne.n	8007fb8 <I2C_Flush_TXDR+0x1e>
  {
    hi2c->Instance->TXDR = 0x00U;
 8007fb0:	687b      	ldr	r3, [r7, #4]
 8007fb2:	681b      	ldr	r3, [r3, #0]
 8007fb4:	2200      	movs	r2, #0
 8007fb6:	629a      	str	r2, [r3, #40]	; 0x28
  }

  /* Flush TX register if not empty */
  if (__HAL_I2C_GET_FLAG(hi2c, I2C_FLAG_TXE) == RESET)
 8007fb8:	687b      	ldr	r3, [r7, #4]
 8007fba:	681b      	ldr	r3, [r3, #0]
 8007fbc:	699b      	ldr	r3, [r3, #24]
 8007fbe:	2201      	movs	r2, #1
 8007fc0:	4013      	ands	r3, r2
 8007fc2:	2b01      	cmp	r3, #1
 8007fc4:	d007      	beq.n	8007fd6 <I2C_Flush_TXDR+0x3c>
  {
    __HAL_I2C_CLEAR_FLAG(hi2c, I2C_FLAG_TXE);
 8007fc6:	687b      	ldr	r3, [r7, #4]
 8007fc8:	681b      	ldr	r3, [r3, #0]
 8007fca:	699a      	ldr	r2, [r3, #24]
 8007fcc:	687b      	ldr	r3, [r7, #4]
 8007fce:	681b      	ldr	r3, [r3, #0]
 8007fd0:	2101      	movs	r1, #1
 8007fd2:	430a      	orrs	r2, r1
 8007fd4:	619a      	str	r2, [r3, #24]
  }
}
 8007fd6:	46c0      	nop			; (mov r8, r8)
 8007fd8:	46bd      	mov	sp, r7
 8007fda:	b002      	add	sp, #8
 8007fdc:	bd80      	pop	{r7, pc}

08007fde <I2C_DMAAbort>:
  *        (To be called at end of DMA Abort procedure).
  * @param hdma DMA handle.
  * @retval None
  */
static void I2C_DMAAbort(DMA_HandleTypeDef *hdma)
{
 8007fde:	b580      	push	{r7, lr}
 8007fe0:	b084      	sub	sp, #16
 8007fe2:	af00      	add	r7, sp, #0
 8007fe4:	6078      	str	r0, [r7, #4]
  /* Derogation MISRAC2012-Rule-11.5 */
  I2C_HandleTypeDef *hi2c = (I2C_HandleTypeDef *)(((DMA_HandleTypeDef *)hdma)->Parent);
 8007fe6:	687b      	ldr	r3, [r7, #4]
 8007fe8:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8007fea:	60fb      	str	r3, [r7, #12]

  /* Reset AbortCpltCallback */
  if (hi2c->hdmatx != NULL)
 8007fec:	68fb      	ldr	r3, [r7, #12]
 8007fee:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8007ff0:	2b00      	cmp	r3, #0
 8007ff2:	d003      	beq.n	8007ffc <I2C_DMAAbort+0x1e>
  {
    hi2c->hdmatx->XferAbortCallback = NULL;
 8007ff4:	68fb      	ldr	r3, [r7, #12]
 8007ff6:	6b9b      	ldr	r3, [r3, #56]	; 0x38
 8007ff8:	2200      	movs	r2, #0
 8007ffa:	635a      	str	r2, [r3, #52]	; 0x34
  }
  if (hi2c->hdmarx != NULL)
 8007ffc:	68fb      	ldr	r3, [r7, #12]
 8007ffe:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8008000:	2b00      	cmp	r3, #0
 8008002:	d003      	beq.n	800800c <I2C_DMAAbort+0x2e>
  {
    hi2c->hdmarx->XferAbortCallback = NULL;
 8008004:	68fb      	ldr	r3, [r7, #12]
 8008006:	6bdb      	ldr	r3, [r3, #60]	; 0x3c
 8008008:	2200      	movs	r2, #0
 800800a:	635a      	str	r2, [r3, #52]	; 0x34
  }

  I2C_TreatErrorCallback(hi2c);
 800800c:	68fb      	ldr	r3, [r7, #12]
 800800e:	0018      	movs	r0, r3
 8008010:	f7ff ff9a 	bl	8007f48 <I2C_TreatErrorCallback>
}
 8008014:	46c0      	nop			; (mov r8, r8)
 8008016:	46bd      	mov	sp, r7
 8008018:	b004      	add	sp, #16
 800801a:	bd80      	pop	{r7, pc}

0800801c <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)
{
 800801c:	b590      	push	{r4, r7, lr}
 800801e:	b085      	sub	sp, #20
 8008020:	af00      	add	r7, sp, #0
 8008022:	60f8      	str	r0, [r7, #12]
 8008024:	0008      	movs	r0, r1
 8008026:	0011      	movs	r1, r2
 8008028:	607b      	str	r3, [r7, #4]
 800802a:	240a      	movs	r4, #10
 800802c:	193b      	adds	r3, r7, r4
 800802e:	1c02      	adds	r2, r0, #0
 8008030:	801a      	strh	r2, [r3, #0]
 8008032:	2009      	movs	r0, #9
 8008034:	183b      	adds	r3, r7, r0
 8008036:	1c0a      	adds	r2, r1, #0
 8008038:	701a      	strb	r2, [r3, #0]
  assert_param(IS_I2C_ALL_INSTANCE(hi2c->Instance));
  assert_param(IS_TRANSFER_MODE(Mode));
  assert_param(IS_TRANSFER_REQUEST(Request));

  /* update CR2 register */
  MODIFY_REG(hi2c->Instance->CR2,
 800803a:	68fb      	ldr	r3, [r7, #12]
 800803c:	681b      	ldr	r3, [r3, #0]
 800803e:	685b      	ldr	r3, [r3, #4]
 8008040:	6a3a      	ldr	r2, [r7, #32]
 8008042:	0d51      	lsrs	r1, r2, #21
 8008044:	2280      	movs	r2, #128	; 0x80
 8008046:	00d2      	lsls	r2, r2, #3
 8008048:	400a      	ands	r2, r1
 800804a:	490e      	ldr	r1, [pc, #56]	; (8008084 <I2C_TransferConfig+0x68>)
 800804c:	430a      	orrs	r2, r1
 800804e:	43d2      	mvns	r2, r2
 8008050:	401a      	ands	r2, r3
 8008052:	0011      	movs	r1, r2
 8008054:	193b      	adds	r3, r7, r4
 8008056:	881b      	ldrh	r3, [r3, #0]
 8008058:	059b      	lsls	r3, r3, #22
 800805a:	0d9a      	lsrs	r2, r3, #22
 800805c:	183b      	adds	r3, r7, r0
 800805e:	781b      	ldrb	r3, [r3, #0]
 8008060:	0418      	lsls	r0, r3, #16
 8008062:	23ff      	movs	r3, #255	; 0xff
 8008064:	041b      	lsls	r3, r3, #16
 8008066:	4003      	ands	r3, r0
 8008068:	431a      	orrs	r2, r3
 800806a:	687b      	ldr	r3, [r7, #4]
 800806c:	431a      	orrs	r2, r3
 800806e:	6a3b      	ldr	r3, [r7, #32]
 8008070:	431a      	orrs	r2, r3
 8008072:	68fb      	ldr	r3, [r7, #12]
 8008074:	681b      	ldr	r3, [r3, #0]
 8008076:	430a      	orrs	r2, r1
 8008078:	605a      	str	r2, [r3, #4]
               (I2C_CR2_RD_WRN & (uint32_t)(Request >> (31U - I2C_CR2_RD_WRN_Pos))) | \
               I2C_CR2_START | I2C_CR2_STOP)), \
             (uint32_t)(((uint32_t)DevAddress & I2C_CR2_SADD) | \
                        (((uint32_t)Size << I2C_CR2_NBYTES_Pos) & I2C_CR2_NBYTES) | \
                        (uint32_t)Mode | (uint32_t)Request));
}
 800807a:	46c0      	nop			; (mov r8, r8)
 800807c:	46bd      	mov	sp, r7
 800807e:	b005      	add	sp, #20
 8008080:	bd90      	pop	{r4, r7, pc}
 8008082:	46c0      	nop			; (mov r8, r8)
 8008084:	03ff63ff 	.word	0x03ff63ff

08008088 <I2C_Enable_IRQ>:
  *                the configuration information for the specified I2C.
  * @param  InterruptRequest Value of @ref I2C_Interrupt_configuration_definition.
  * @retval None
  */
static void I2C_Enable_IRQ(I2C_HandleTypeDef *hi2c, uint16_t InterruptRequest)
{
 8008088:	b580      	push	{r7, lr}
 800808a:	b084      	sub	sp, #16
 800808c:	af00      	add	r7, sp, #0
 800808e:	6078      	str	r0, [r7, #4]
 8008090:	000a      	movs	r2, r1
 8008092:	1cbb      	adds	r3, r7, #2
 8008094:	801a      	strh	r2, [r3, #0]
  uint32_t tmpisr = 0U;
 8008096:	2300      	movs	r3, #0
 8008098:	60fb      	str	r3, [r7, #12]

  if ((hi2c->XferISR == I2C_Master_ISR_DMA) || \
 800809a:	687b      	ldr	r3, [r7, #4]
 800809c:	6b5a      	ldr	r2, [r3, #52]	; 0x34
 800809e:	4b2c      	ldr	r3, [pc, #176]	; (8008150 <I2C_Enable_IRQ+0xc8>)
 80080a0:	429a      	cmp	r2, r3
 80080a2:	d004      	beq.n	80080ae <I2C_Enable_IRQ+0x26>
      (hi2c->XferISR == I2C_Slave_ISR_DMA))
 80080a4:	687b      	ldr	r3, [r7, #4]
 80080a6:	6b5a      	ldr	r2, [r3, #52]	; 0x34
  if ((hi2c->XferISR == I2C_Master_ISR_DMA) || \
 80080a8:	4b2a      	ldr	r3, [pc, #168]	; (8008154 <I2C_Enable_IRQ+0xcc>)
 80080aa:	429a      	cmp	r2, r3
 80080ac:	d121      	bne.n	80080f2 <I2C_Enable_IRQ+0x6a>
  {
    if ((InterruptRequest & I2C_XFER_LISTEN_IT) == I2C_XFER_LISTEN_IT)
 80080ae:	1cbb      	adds	r3, r7, #2
 80080b0:	2200      	movs	r2, #0
 80080b2:	5e9b      	ldrsh	r3, [r3, r2]
 80080b4:	2b00      	cmp	r3, #0
 80080b6:	da03      	bge.n	80080c0 <I2C_Enable_IRQ+0x38>
    {
      /* Enable ERR, STOP, NACK and ADDR interrupts */
      tmpisr |= I2C_IT_ADDRI | I2C_IT_STOPI | I2C_IT_NACKI | I2C_IT_ERRI;
 80080b8:	68fb      	ldr	r3, [r7, #12]
 80080ba:	22b8      	movs	r2, #184	; 0xb8
 80080bc:	4313      	orrs	r3, r2
 80080be:	60fb      	str	r3, [r7, #12]
    }

    if (InterruptRequest == I2C_XFER_ERROR_IT)
 80080c0:	1cbb      	adds	r3, r7, #2
 80080c2:	881b      	ldrh	r3, [r3, #0]
 80080c4:	2b10      	cmp	r3, #16
 80080c6:	d103      	bne.n	80080d0 <I2C_Enable_IRQ+0x48>
    {
      /* Enable ERR and NACK interrupts */
      tmpisr |= I2C_IT_ERRI | I2C_IT_NACKI;
 80080c8:	68fb      	ldr	r3, [r7, #12]
 80080ca:	2290      	movs	r2, #144	; 0x90
 80080cc:	4313      	orrs	r3, r2
 80080ce:	60fb      	str	r3, [r7, #12]
    }

    if (InterruptRequest == I2C_XFER_CPLT_IT)
 80080d0:	1cbb      	adds	r3, r7, #2
 80080d2:	881b      	ldrh	r3, [r3, #0]
 80080d4:	2b20      	cmp	r3, #32
 80080d6:	d103      	bne.n	80080e0 <I2C_Enable_IRQ+0x58>
    {
      /* Enable STOP interrupts */
      tmpisr |= (I2C_IT_STOPI | I2C_IT_TCI);
 80080d8:	68fb      	ldr	r3, [r7, #12]
 80080da:	2260      	movs	r2, #96	; 0x60
 80080dc:	4313      	orrs	r3, r2
 80080de:	60fb      	str	r3, [r7, #12]
    }

    if (InterruptRequest == I2C_XFER_RELOAD_IT)
 80080e0:	1cbb      	adds	r3, r7, #2
 80080e2:	881b      	ldrh	r3, [r3, #0]
 80080e4:	2b40      	cmp	r3, #64	; 0x40
 80080e6:	d127      	bne.n	8008138 <I2C_Enable_IRQ+0xb0>
    {
      /* Enable TC interrupts */
      tmpisr |= I2C_IT_TCI;
 80080e8:	68fb      	ldr	r3, [r7, #12]
 80080ea:	2240      	movs	r2, #64	; 0x40
 80080ec:	4313      	orrs	r3, r2
 80080ee:	60fb      	str	r3, [r7, #12]
    if (InterruptRequest == I2C_XFER_RELOAD_IT)
 80080f0:	e022      	b.n	8008138 <I2C_Enable_IRQ+0xb0>
    }
  }
  else
  {
    if ((InterruptRequest & I2C_XFER_LISTEN_IT) == I2C_XFER_LISTEN_IT)
 80080f2:	1cbb      	adds	r3, r7, #2
 80080f4:	2200      	movs	r2, #0
 80080f6:	5e9b      	ldrsh	r3, [r3, r2]
 80080f8:	2b00      	cmp	r3, #0
 80080fa:	da03      	bge.n	8008104 <I2C_Enable_IRQ+0x7c>
    {
      /* Enable ERR, STOP, NACK, and ADDR interrupts */
      tmpisr |= I2C_IT_ADDRI | I2C_IT_STOPI | I2C_IT_NACKI | I2C_IT_ERRI;
 80080fc:	68fb      	ldr	r3, [r7, #12]
 80080fe:	22b8      	movs	r2, #184	; 0xb8
 8008100:	4313      	orrs	r3, r2
 8008102:	60fb      	str	r3, [r7, #12]
    }

    if ((InterruptRequest & I2C_XFER_TX_IT) == I2C_XFER_TX_IT)
 8008104:	1cbb      	adds	r3, r7, #2
 8008106:	881b      	ldrh	r3, [r3, #0]
 8008108:	2201      	movs	r2, #1
 800810a:	4013      	ands	r3, r2
 800810c:	d003      	beq.n	8008116 <I2C_Enable_IRQ+0x8e>
    {
      /* Enable ERR, TC, STOP, NACK and RXI interrupts */
      tmpisr |= I2C_IT_ERRI | I2C_IT_TCI | I2C_IT_STOPI | I2C_IT_NACKI | I2C_IT_TXI;
 800810e:	68fb      	ldr	r3, [r7, #12]
 8008110:	22f2      	movs	r2, #242	; 0xf2
 8008112:	4313      	orrs	r3, r2
 8008114:	60fb      	str	r3, [r7, #12]
    }

    if ((InterruptRequest & I2C_XFER_RX_IT) == I2C_XFER_RX_IT)
 8008116:	1cbb      	adds	r3, r7, #2
 8008118:	881b      	ldrh	r3, [r3, #0]
 800811a:	2202      	movs	r2, #2
 800811c:	4013      	ands	r3, r2
 800811e:	d003      	beq.n	8008128 <I2C_Enable_IRQ+0xa0>
    {
      /* Enable ERR, TC, STOP, NACK and TXI interrupts */
      tmpisr |= I2C_IT_ERRI | I2C_IT_TCI | I2C_IT_STOPI | I2C_IT_NACKI | I2C_IT_RXI;
 8008120:	68fb      	ldr	r3, [r7, #12]
 8008122:	22f4      	movs	r2, #244	; 0xf4
 8008124:	4313      	orrs	r3, r2
 8008126:	60fb      	str	r3, [r7, #12]
    }

    if (InterruptRequest == I2C_XFER_CPLT_IT)
 8008128:	1cbb      	adds	r3, r7, #2
 800812a:	881b      	ldrh	r3, [r3, #0]
 800812c:	2b20      	cmp	r3, #32
 800812e:	d103      	bne.n	8008138 <I2C_Enable_IRQ+0xb0>
    {
      /* Enable STOP interrupts */
      tmpisr |= I2C_IT_STOPI;
 8008130:	68fb      	ldr	r3, [r7, #12]
 8008132:	2220      	movs	r2, #32
 8008134:	4313      	orrs	r3, r2
 8008136:	60fb      	str	r3, [r7, #12]
  }

  /* Enable interrupts only at the end */
  /* to avoid the risk of I2C interrupt handle execution before */
  /* all interrupts requested done */
  __HAL_I2C_ENABLE_IT(hi2c, tmpisr);
 8008138:	687b      	ldr	r3, [r7, #4]
 800813a:	681b      	ldr	r3, [r3, #0]
 800813c:	6819      	ldr	r1, [r3, #0]
 800813e:	687b      	ldr	r3, [r7, #4]
 8008140:	681b      	ldr	r3, [r3, #0]
 8008142:	68fa      	ldr	r2, [r7, #12]
 8008144:	430a      	orrs	r2, r1
 8008146:	601a      	str	r2, [r3, #0]
}
 8008148:	46c0      	nop			; (mov r8, r8)
 800814a:	46bd      	mov	sp, r7
 800814c:	b004      	add	sp, #16
 800814e:	bd80      	pop	{r7, pc}
 8008150:	08007249 	.word	0x08007249
 8008154:	08007461 	.word	0x08007461

08008158 <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)
{
 8008158:	b580      	push	{r7, lr}
 800815a:	b084      	sub	sp, #16
 800815c:	af00      	add	r7, sp, #0
 800815e:	6078      	str	r0, [r7, #4]
 8008160:	000a      	movs	r2, r1
 8008162:	1cbb      	adds	r3, r7, #2
 8008164:	801a      	strh	r2, [r3, #0]
  uint32_t tmpisr = 0U;
 8008166:	2300      	movs	r3, #0
 8008168:	60fb      	str	r3, [r7, #12]

  if ((InterruptRequest & I2C_XFER_TX_IT) == I2C_XFER_TX_IT)
 800816a:	1cbb      	adds	r3, r7, #2
 800816c:	881b      	ldrh	r3, [r3, #0]
 800816e:	2201      	movs	r2, #1
 8008170:	4013      	ands	r3, r2
 8008172:	d010      	beq.n	8008196 <I2C_Disable_IRQ+0x3e>
  {
    /* Disable TC and TXI interrupts */
    tmpisr |= I2C_IT_TCI | I2C_IT_TXI;
 8008174:	68fb      	ldr	r3, [r7, #12]
 8008176:	2242      	movs	r2, #66	; 0x42
 8008178:	4313      	orrs	r3, r2
 800817a:	60fb      	str	r3, [r7, #12]

    if (((uint32_t)hi2c->State & (uint32_t)HAL_I2C_STATE_LISTEN) != (uint32_t)HAL_I2C_STATE_LISTEN)
 800817c:	687b      	ldr	r3, [r7, #4]
 800817e:	2241      	movs	r2, #65	; 0x41
 8008180:	5c9b      	ldrb	r3, [r3, r2]
 8008182:	b2db      	uxtb	r3, r3
 8008184:	001a      	movs	r2, r3
 8008186:	2328      	movs	r3, #40	; 0x28
 8008188:	4013      	ands	r3, r2
 800818a:	2b28      	cmp	r3, #40	; 0x28
 800818c:	d003      	beq.n	8008196 <I2C_Disable_IRQ+0x3e>
    {
      /* Disable NACK and STOP interrupts */
      tmpisr |= I2C_IT_STOPI | I2C_IT_NACKI | I2C_IT_ERRI;
 800818e:	68fb      	ldr	r3, [r7, #12]
 8008190:	22b0      	movs	r2, #176	; 0xb0
 8008192:	4313      	orrs	r3, r2
 8008194:	60fb      	str	r3, [r7, #12]
    }
  }

  if ((InterruptRequest & I2C_XFER_RX_IT) == I2C_XFER_RX_IT)
 8008196:	1cbb      	adds	r3, r7, #2
 8008198:	881b      	ldrh	r3, [r3, #0]
 800819a:	2202      	movs	r2, #2
 800819c:	4013      	ands	r3, r2
 800819e:	d010      	beq.n	80081c2 <I2C_Disable_IRQ+0x6a>
  {
    /* Disable TC and RXI interrupts */
    tmpisr |= I2C_IT_TCI | I2C_IT_RXI;
 80081a0:	68fb      	ldr	r3, [r7, #12]
 80081a2:	2244      	movs	r2, #68	; 0x44
 80081a4:	4313      	orrs	r3, r2
 80081a6:	60fb      	str	r3, [r7, #12]

    if (((uint32_t)hi2c->State & (uint32_t)HAL_I2C_STATE_LISTEN) != (uint32_t)HAL_I2C_STATE_LISTEN)
 80081a8:	687b      	ldr	r3, [r7, #4]
 80081aa:	2241      	movs	r2, #65	; 0x41
 80081ac:	5c9b      	ldrb	r3, [r3, r2]
 80081ae:	b2db      	uxtb	r3, r3
 80081b0:	001a      	movs	r2, r3
 80081b2:	2328      	movs	r3, #40	; 0x28
 80081b4:	4013      	ands	r3, r2
 80081b6:	2b28      	cmp	r3, #40	; 0x28
 80081b8:	d003      	beq.n	80081c2 <I2C_Disable_IRQ+0x6a>
    {
      /* Disable NACK and STOP interrupts */
      tmpisr |= I2C_IT_STOPI | I2C_IT_NACKI | I2C_IT_ERRI;
 80081ba:	68fb      	ldr	r3, [r7, #12]
 80081bc:	22b0      	movs	r2, #176	; 0xb0
 80081be:	4313      	orrs	r3, r2
 80081c0:	60fb      	str	r3, [r7, #12]
    }
  }

  if ((InterruptRequest & I2C_XFER_LISTEN_IT) == I2C_XFER_LISTEN_IT)
 80081c2:	1cbb      	adds	r3, r7, #2
 80081c4:	2200      	movs	r2, #0
 80081c6:	5e9b      	ldrsh	r3, [r3, r2]
 80081c8:	2b00      	cmp	r3, #0
 80081ca:	da03      	bge.n	80081d4 <I2C_Disable_IRQ+0x7c>
  {
    /* Disable ADDR, NACK and STOP interrupts */
    tmpisr |= I2C_IT_ADDRI | I2C_IT_STOPI | I2C_IT_NACKI | I2C_IT_ERRI;
 80081cc:	68fb      	ldr	r3, [r7, #12]
 80081ce:	22b8      	movs	r2, #184	; 0xb8
 80081d0:	4313      	orrs	r3, r2
 80081d2:	60fb      	str	r3, [r7, #12]
  }

  if (InterruptRequest == I2C_XFER_ERROR_IT)
 80081d4:	1cbb      	adds	r3, r7, #2
 80081d6:	881b      	ldrh	r3, [r3, #0]
 80081d8:	2b10      	cmp	r3, #16
 80081da:	d103      	bne.n	80081e4 <I2C_Disable_IRQ+0x8c>
  {
    /* Enable ERR and NACK interrupts */
    tmpisr |= I2C_IT_ERRI | I2C_IT_NACKI;
 80081dc:	68fb      	ldr	r3, [r7, #12]
 80081de:	2290      	movs	r2, #144	; 0x90
 80081e0:	4313      	orrs	r3, r2
 80081e2:	60fb      	str	r3, [r7, #12]
  }

  if (InterruptRequest == I2C_XFER_CPLT_IT)
 80081e4:	1cbb      	adds	r3, r7, #2
 80081e6:	881b      	ldrh	r3, [r3, #0]
 80081e8:	2b20      	cmp	r3, #32
 80081ea:	d103      	bne.n	80081f4 <I2C_Disable_IRQ+0x9c>
  {
    /* Enable STOP interrupts */
    tmpisr |= I2C_IT_STOPI;
 80081ec:	68fb      	ldr	r3, [r7, #12]
 80081ee:	2220      	movs	r2, #32
 80081f0:	4313      	orrs	r3, r2
 80081f2:	60fb      	str	r3, [r7, #12]
  }

  if (InterruptRequest == I2C_XFER_RELOAD_IT)
 80081f4:	1cbb      	adds	r3, r7, #2
 80081f6:	881b      	ldrh	r3, [r3, #0]
 80081f8:	2b40      	cmp	r3, #64	; 0x40
 80081fa:	d103      	bne.n	8008204 <I2C_Disable_IRQ+0xac>
  {
    /* Enable TC interrupts */
    tmpisr |= I2C_IT_TCI;
 80081fc:	68fb      	ldr	r3, [r7, #12]
 80081fe:	2240      	movs	r2, #64	; 0x40
 8008200:	4313      	orrs	r3, r2
 8008202:	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);
 8008204:	687b      	ldr	r3, [r7, #4]
 8008206:	681b      	ldr	r3, [r3, #0]
 8008208:	681a      	ldr	r2, [r3, #0]
 800820a:	68fb      	ldr	r3, [r7, #12]
 800820c:	43d9      	mvns	r1, r3
 800820e:	687b      	ldr	r3, [r7, #4]
 8008210:	681b      	ldr	r3, [r3, #0]
 8008212:	400a      	ands	r2, r1
 8008214:	601a      	str	r2, [r3, #0]
}
 8008216:	46c0      	nop			; (mov r8, r8)
 8008218:	46bd      	mov	sp, r7
 800821a:	b004      	add	sp, #16
 800821c:	bd80      	pop	{r7, pc}
	...

08008220 <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)
{
 8008220:	b580      	push	{r7, lr}
 8008222:	b082      	sub	sp, #8
 8008224:	af00      	add	r7, sp, #0
 8008226:	6078      	str	r0, [r7, #4]
 8008228:	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)
 800822a:	687b      	ldr	r3, [r7, #4]
 800822c:	2241      	movs	r2, #65	; 0x41
 800822e:	5c9b      	ldrb	r3, [r3, r2]
 8008230:	b2db      	uxtb	r3, r3
 8008232:	2b20      	cmp	r3, #32
 8008234:	d138      	bne.n	80082a8 <HAL_I2CEx_ConfigAnalogFilter+0x88>
  {
    /* Process Locked */
    __HAL_LOCK(hi2c);
 8008236:	687b      	ldr	r3, [r7, #4]
 8008238:	2240      	movs	r2, #64	; 0x40
 800823a:	5c9b      	ldrb	r3, [r3, r2]
 800823c:	2b01      	cmp	r3, #1
 800823e:	d101      	bne.n	8008244 <HAL_I2CEx_ConfigAnalogFilter+0x24>
 8008240:	2302      	movs	r3, #2
 8008242:	e032      	b.n	80082aa <HAL_I2CEx_ConfigAnalogFilter+0x8a>
 8008244:	687b      	ldr	r3, [r7, #4]
 8008246:	2240      	movs	r2, #64	; 0x40
 8008248:	2101      	movs	r1, #1
 800824a:	5499      	strb	r1, [r3, r2]

    hi2c->State = HAL_I2C_STATE_BUSY;
 800824c:	687b      	ldr	r3, [r7, #4]
 800824e:	2241      	movs	r2, #65	; 0x41
 8008250:	2124      	movs	r1, #36	; 0x24
 8008252:	5499      	strb	r1, [r3, r2]

    /* Disable the selected I2C peripheral */
    __HAL_I2C_DISABLE(hi2c);
 8008254:	687b      	ldr	r3, [r7, #4]
 8008256:	681b      	ldr	r3, [r3, #0]
 8008258:	681a      	ldr	r2, [r3, #0]
 800825a:	687b      	ldr	r3, [r7, #4]
 800825c:	681b      	ldr	r3, [r3, #0]
 800825e:	2101      	movs	r1, #1
 8008260:	438a      	bics	r2, r1
 8008262:	601a      	str	r2, [r3, #0]

    /* Reset I2Cx ANOFF bit */
    hi2c->Instance->CR1 &= ~(I2C_CR1_ANFOFF);
 8008264:	687b      	ldr	r3, [r7, #4]
 8008266:	681b      	ldr	r3, [r3, #0]
 8008268:	681a      	ldr	r2, [r3, #0]
 800826a:	687b      	ldr	r3, [r7, #4]
 800826c:	681b      	ldr	r3, [r3, #0]
 800826e:	4911      	ldr	r1, [pc, #68]	; (80082b4 <HAL_I2CEx_ConfigAnalogFilter+0x94>)
 8008270:	400a      	ands	r2, r1
 8008272:	601a      	str	r2, [r3, #0]

    /* Set analog filter bit*/
    hi2c->Instance->CR1 |= AnalogFilter;
 8008274:	687b      	ldr	r3, [r7, #4]
 8008276:	681b      	ldr	r3, [r3, #0]
 8008278:	6819      	ldr	r1, [r3, #0]
 800827a:	687b      	ldr	r3, [r7, #4]
 800827c:	681b      	ldr	r3, [r3, #0]
 800827e:	683a      	ldr	r2, [r7, #0]
 8008280:	430a      	orrs	r2, r1
 8008282:	601a      	str	r2, [r3, #0]

    __HAL_I2C_ENABLE(hi2c);
 8008284:	687b      	ldr	r3, [r7, #4]
 8008286:	681b      	ldr	r3, [r3, #0]
 8008288:	681a      	ldr	r2, [r3, #0]
 800828a:	687b      	ldr	r3, [r7, #4]
 800828c:	681b      	ldr	r3, [r3, #0]
 800828e:	2101      	movs	r1, #1
 8008290:	430a      	orrs	r2, r1
 8008292:	601a      	str	r2, [r3, #0]

    hi2c->State = HAL_I2C_STATE_READY;
 8008294:	687b      	ldr	r3, [r7, #4]
 8008296:	2241      	movs	r2, #65	; 0x41
 8008298:	2120      	movs	r1, #32
 800829a:	5499      	strb	r1, [r3, r2]

    /* Process Unlocked */
    __HAL_UNLOCK(hi2c);
 800829c:	687b      	ldr	r3, [r7, #4]
 800829e:	2240      	movs	r2, #64	; 0x40
 80082a0:	2100      	movs	r1, #0
 80082a2:	5499      	strb	r1, [r3, r2]

    return HAL_OK;
 80082a4:	2300      	movs	r3, #0
 80082a6:	e000      	b.n	80082aa <HAL_I2CEx_ConfigAnalogFilter+0x8a>
  }
  else
  {
    return HAL_BUSY;
 80082a8:	2302      	movs	r3, #2
  }
}
 80082aa:	0018      	movs	r0, r3
 80082ac:	46bd      	mov	sp, r7
 80082ae:	b002      	add	sp, #8
 80082b0:	bd80      	pop	{r7, pc}
 80082b2:	46c0      	nop			; (mov r8, r8)
 80082b4:	ffffefff 	.word	0xffffefff

080082b8 <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)
{
 80082b8:	b580      	push	{r7, lr}
 80082ba:	b084      	sub	sp, #16
 80082bc:	af00      	add	r7, sp, #0
 80082be:	6078      	str	r0, [r7, #4]
 80082c0:	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)
 80082c2:	687b      	ldr	r3, [r7, #4]
 80082c4:	2241      	movs	r2, #65	; 0x41
 80082c6:	5c9b      	ldrb	r3, [r3, r2]
 80082c8:	b2db      	uxtb	r3, r3
 80082ca:	2b20      	cmp	r3, #32
 80082cc:	d139      	bne.n	8008342 <HAL_I2CEx_ConfigDigitalFilter+0x8a>
  {
    /* Process Locked */
    __HAL_LOCK(hi2c);
 80082ce:	687b      	ldr	r3, [r7, #4]
 80082d0:	2240      	movs	r2, #64	; 0x40
 80082d2:	5c9b      	ldrb	r3, [r3, r2]
 80082d4:	2b01      	cmp	r3, #1
 80082d6:	d101      	bne.n	80082dc <HAL_I2CEx_ConfigDigitalFilter+0x24>
 80082d8:	2302      	movs	r3, #2
 80082da:	e033      	b.n	8008344 <HAL_I2CEx_ConfigDigitalFilter+0x8c>
 80082dc:	687b      	ldr	r3, [r7, #4]
 80082de:	2240      	movs	r2, #64	; 0x40
 80082e0:	2101      	movs	r1, #1
 80082e2:	5499      	strb	r1, [r3, r2]

    hi2c->State = HAL_I2C_STATE_BUSY;
 80082e4:	687b      	ldr	r3, [r7, #4]
 80082e6:	2241      	movs	r2, #65	; 0x41
 80082e8:	2124      	movs	r1, #36	; 0x24
 80082ea:	5499      	strb	r1, [r3, r2]

    /* Disable the selected I2C peripheral */
    __HAL_I2C_DISABLE(hi2c);
 80082ec:	687b      	ldr	r3, [r7, #4]
 80082ee:	681b      	ldr	r3, [r3, #0]
 80082f0:	681a      	ldr	r2, [r3, #0]
 80082f2:	687b      	ldr	r3, [r7, #4]
 80082f4:	681b      	ldr	r3, [r3, #0]
 80082f6:	2101      	movs	r1, #1
 80082f8:	438a      	bics	r2, r1
 80082fa:	601a      	str	r2, [r3, #0]

    /* Get the old register value */
    tmpreg = hi2c->Instance->CR1;
 80082fc:	687b      	ldr	r3, [r7, #4]
 80082fe:	681b      	ldr	r3, [r3, #0]
 8008300:	681b      	ldr	r3, [r3, #0]
 8008302:	60fb      	str	r3, [r7, #12]

    /* Reset I2Cx DNF bits [11:8] */
    tmpreg &= ~(I2C_CR1_DNF);
 8008304:	68fb      	ldr	r3, [r7, #12]
 8008306:	4a11      	ldr	r2, [pc, #68]	; (800834c <HAL_I2CEx_ConfigDigitalFilter+0x94>)
 8008308:	4013      	ands	r3, r2
 800830a:	60fb      	str	r3, [r7, #12]

    /* Set I2Cx DNF coefficient */
    tmpreg |= DigitalFilter << 8U;
 800830c:	683b      	ldr	r3, [r7, #0]
 800830e:	021b      	lsls	r3, r3, #8
 8008310:	68fa      	ldr	r2, [r7, #12]
 8008312:	4313      	orrs	r3, r2
 8008314:	60fb      	str	r3, [r7, #12]

    /* Store the new register value */
    hi2c->Instance->CR1 = tmpreg;
 8008316:	687b      	ldr	r3, [r7, #4]
 8008318:	681b      	ldr	r3, [r3, #0]
 800831a:	68fa      	ldr	r2, [r7, #12]
 800831c:	601a      	str	r2, [r3, #0]

    __HAL_I2C_ENABLE(hi2c);
 800831e:	687b      	ldr	r3, [r7, #4]
 8008320:	681b      	ldr	r3, [r3, #0]
 8008322:	681a      	ldr	r2, [r3, #0]
 8008324:	687b      	ldr	r3, [r7, #4]
 8008326:	681b      	ldr	r3, [r3, #0]
 8008328:	2101      	movs	r1, #1
 800832a:	430a      	orrs	r2, r1
 800832c:	601a      	str	r2, [r3, #0]

    hi2c->State = HAL_I2C_STATE_READY;
 800832e:	687b      	ldr	r3, [r7, #4]
 8008330:	2241      	movs	r2, #65	; 0x41
 8008332:	2120      	movs	r1, #32
 8008334:	5499      	strb	r1, [r3, r2]

    /* Process Unlocked */
    __HAL_UNLOCK(hi2c);
 8008336:	687b      	ldr	r3, [r7, #4]
 8008338:	2240      	movs	r2, #64	; 0x40
 800833a:	2100      	movs	r1, #0
 800833c:	5499      	strb	r1, [r3, r2]

    return HAL_OK;
 800833e:	2300      	movs	r3, #0
 8008340:	e000      	b.n	8008344 <HAL_I2CEx_ConfigDigitalFilter+0x8c>
  }
  else
  {
    return HAL_BUSY;
 8008342:	2302      	movs	r3, #2
  }
}
 8008344:	0018      	movs	r0, r3
 8008346:	46bd      	mov	sp, r7
 8008348:	b004      	add	sp, #16
 800834a:	bd80      	pop	{r7, pc}
 800834c:	fffff0ff 	.word	0xfffff0ff

08008350 <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)
{
 8008350:	b580      	push	{r7, lr}
 8008352:	b088      	sub	sp, #32
 8008354:	af00      	add	r7, sp, #0
 8008356:	6078      	str	r0, [r7, #4]
  uint32_t tickstart;
  uint32_t pll_config;
  uint32_t pll_config2;

  /* Check Null pointer */
  if(RCC_OscInitStruct == NULL)
 8008358:	687b      	ldr	r3, [r7, #4]
 800835a:	2b00      	cmp	r3, #0
 800835c:	d102      	bne.n	8008364 <HAL_RCC_OscConfig+0x14>
  {
    return HAL_ERROR;
 800835e:	2301      	movs	r3, #1
 8008360:	f000 fb76 	bl	8008a50 <HAL_RCC_OscConfig+0x700>

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

  /*------------------------------- HSE Configuration ------------------------*/ 
  if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_HSE) == RCC_OSCILLATORTYPE_HSE)
 8008364:	687b      	ldr	r3, [r7, #4]
 8008366:	681b      	ldr	r3, [r3, #0]
 8008368:	2201      	movs	r2, #1
 800836a:	4013      	ands	r3, r2
 800836c:	d100      	bne.n	8008370 <HAL_RCC_OscConfig+0x20>
 800836e:	e08e      	b.n	800848e <HAL_RCC_OscConfig+0x13e>
  {
    /* 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((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_HSE) 
 8008370:	4bc5      	ldr	r3, [pc, #788]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 8008372:	685b      	ldr	r3, [r3, #4]
 8008374:	220c      	movs	r2, #12
 8008376:	4013      	ands	r3, r2
 8008378:	2b04      	cmp	r3, #4
 800837a:	d00e      	beq.n	800839a <HAL_RCC_OscConfig+0x4a>
       || ((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_PLLCLK) && (__HAL_RCC_GET_PLL_OSCSOURCE() == RCC_PLLSOURCE_HSE)))
 800837c:	4bc2      	ldr	r3, [pc, #776]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 800837e:	685b      	ldr	r3, [r3, #4]
 8008380:	220c      	movs	r2, #12
 8008382:	4013      	ands	r3, r2
 8008384:	2b08      	cmp	r3, #8
 8008386:	d117      	bne.n	80083b8 <HAL_RCC_OscConfig+0x68>
 8008388:	4bbf      	ldr	r3, [pc, #764]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 800838a:	685a      	ldr	r2, [r3, #4]
 800838c:	23c0      	movs	r3, #192	; 0xc0
 800838e:	025b      	lsls	r3, r3, #9
 8008390:	401a      	ands	r2, r3
 8008392:	2380      	movs	r3, #128	; 0x80
 8008394:	025b      	lsls	r3, r3, #9
 8008396:	429a      	cmp	r2, r3
 8008398:	d10e      	bne.n	80083b8 <HAL_RCC_OscConfig+0x68>
    {
      if((__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) != RESET) && (RCC_OscInitStruct->HSEState == RCC_HSE_OFF))
 800839a:	4bbb      	ldr	r3, [pc, #748]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 800839c:	681a      	ldr	r2, [r3, #0]
 800839e:	2380      	movs	r3, #128	; 0x80
 80083a0:	029b      	lsls	r3, r3, #10
 80083a2:	4013      	ands	r3, r2
 80083a4:	d100      	bne.n	80083a8 <HAL_RCC_OscConfig+0x58>
 80083a6:	e071      	b.n	800848c <HAL_RCC_OscConfig+0x13c>
 80083a8:	687b      	ldr	r3, [r7, #4]
 80083aa:	685b      	ldr	r3, [r3, #4]
 80083ac:	2b00      	cmp	r3, #0
 80083ae:	d000      	beq.n	80083b2 <HAL_RCC_OscConfig+0x62>
 80083b0:	e06c      	b.n	800848c <HAL_RCC_OscConfig+0x13c>
      {
        return HAL_ERROR;
 80083b2:	2301      	movs	r3, #1
 80083b4:	f000 fb4c 	bl	8008a50 <HAL_RCC_OscConfig+0x700>
      }
    }
    else
    {
      /* Set the new HSE configuration ---------------------------------------*/
      __HAL_RCC_HSE_CONFIG(RCC_OscInitStruct->HSEState);
 80083b8:	687b      	ldr	r3, [r7, #4]
 80083ba:	685b      	ldr	r3, [r3, #4]
 80083bc:	2b01      	cmp	r3, #1
 80083be:	d107      	bne.n	80083d0 <HAL_RCC_OscConfig+0x80>
 80083c0:	4bb1      	ldr	r3, [pc, #708]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 80083c2:	681a      	ldr	r2, [r3, #0]
 80083c4:	4bb0      	ldr	r3, [pc, #704]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 80083c6:	2180      	movs	r1, #128	; 0x80
 80083c8:	0249      	lsls	r1, r1, #9
 80083ca:	430a      	orrs	r2, r1
 80083cc:	601a      	str	r2, [r3, #0]
 80083ce:	e02f      	b.n	8008430 <HAL_RCC_OscConfig+0xe0>
 80083d0:	687b      	ldr	r3, [r7, #4]
 80083d2:	685b      	ldr	r3, [r3, #4]
 80083d4:	2b00      	cmp	r3, #0
 80083d6:	d10c      	bne.n	80083f2 <HAL_RCC_OscConfig+0xa2>
 80083d8:	4bab      	ldr	r3, [pc, #684]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 80083da:	681a      	ldr	r2, [r3, #0]
 80083dc:	4baa      	ldr	r3, [pc, #680]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 80083de:	49ab      	ldr	r1, [pc, #684]	; (800868c <HAL_RCC_OscConfig+0x33c>)
 80083e0:	400a      	ands	r2, r1
 80083e2:	601a      	str	r2, [r3, #0]
 80083e4:	4ba8      	ldr	r3, [pc, #672]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 80083e6:	681a      	ldr	r2, [r3, #0]
 80083e8:	4ba7      	ldr	r3, [pc, #668]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 80083ea:	49a9      	ldr	r1, [pc, #676]	; (8008690 <HAL_RCC_OscConfig+0x340>)
 80083ec:	400a      	ands	r2, r1
 80083ee:	601a      	str	r2, [r3, #0]
 80083f0:	e01e      	b.n	8008430 <HAL_RCC_OscConfig+0xe0>
 80083f2:	687b      	ldr	r3, [r7, #4]
 80083f4:	685b      	ldr	r3, [r3, #4]
 80083f6:	2b05      	cmp	r3, #5
 80083f8:	d10e      	bne.n	8008418 <HAL_RCC_OscConfig+0xc8>
 80083fa:	4ba3      	ldr	r3, [pc, #652]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 80083fc:	681a      	ldr	r2, [r3, #0]
 80083fe:	4ba2      	ldr	r3, [pc, #648]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 8008400:	2180      	movs	r1, #128	; 0x80
 8008402:	02c9      	lsls	r1, r1, #11
 8008404:	430a      	orrs	r2, r1
 8008406:	601a      	str	r2, [r3, #0]
 8008408:	4b9f      	ldr	r3, [pc, #636]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 800840a:	681a      	ldr	r2, [r3, #0]
 800840c:	4b9e      	ldr	r3, [pc, #632]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 800840e:	2180      	movs	r1, #128	; 0x80
 8008410:	0249      	lsls	r1, r1, #9
 8008412:	430a      	orrs	r2, r1
 8008414:	601a      	str	r2, [r3, #0]
 8008416:	e00b      	b.n	8008430 <HAL_RCC_OscConfig+0xe0>
 8008418:	4b9b      	ldr	r3, [pc, #620]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 800841a:	681a      	ldr	r2, [r3, #0]
 800841c:	4b9a      	ldr	r3, [pc, #616]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 800841e:	499b      	ldr	r1, [pc, #620]	; (800868c <HAL_RCC_OscConfig+0x33c>)
 8008420:	400a      	ands	r2, r1
 8008422:	601a      	str	r2, [r3, #0]
 8008424:	4b98      	ldr	r3, [pc, #608]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 8008426:	681a      	ldr	r2, [r3, #0]
 8008428:	4b97      	ldr	r3, [pc, #604]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 800842a:	4999      	ldr	r1, [pc, #612]	; (8008690 <HAL_RCC_OscConfig+0x340>)
 800842c:	400a      	ands	r2, r1
 800842e:	601a      	str	r2, [r3, #0]
      

       /* Check the HSE State */
      if(RCC_OscInitStruct->HSEState != RCC_HSE_OFF)
 8008430:	687b      	ldr	r3, [r7, #4]
 8008432:	685b      	ldr	r3, [r3, #4]
 8008434:	2b00      	cmp	r3, #0
 8008436:	d014      	beq.n	8008462 <HAL_RCC_OscConfig+0x112>
      {
        /* Get Start Tick */
        tickstart = HAL_GetTick();
 8008438:	f7fd fa8c 	bl	8005954 <HAL_GetTick>
 800843c:	0003      	movs	r3, r0
 800843e:	61bb      	str	r3, [r7, #24]
        
        /* Wait till HSE is ready */
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) == RESET)
 8008440:	e008      	b.n	8008454 <HAL_RCC_OscConfig+0x104>
        {
          if((HAL_GetTick() - tickstart ) > HSE_TIMEOUT_VALUE)
 8008442:	f7fd fa87 	bl	8005954 <HAL_GetTick>
 8008446:	0002      	movs	r2, r0
 8008448:	69bb      	ldr	r3, [r7, #24]
 800844a:	1ad3      	subs	r3, r2, r3
 800844c:	2b64      	cmp	r3, #100	; 0x64
 800844e:	d901      	bls.n	8008454 <HAL_RCC_OscConfig+0x104>
          {
            return HAL_TIMEOUT;
 8008450:	2303      	movs	r3, #3
 8008452:	e2fd      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) == RESET)
 8008454:	4b8c      	ldr	r3, [pc, #560]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 8008456:	681a      	ldr	r2, [r3, #0]
 8008458:	2380      	movs	r3, #128	; 0x80
 800845a:	029b      	lsls	r3, r3, #10
 800845c:	4013      	ands	r3, r2
 800845e:	d0f0      	beq.n	8008442 <HAL_RCC_OscConfig+0xf2>
 8008460:	e015      	b.n	800848e <HAL_RCC_OscConfig+0x13e>
        }
      }
      else
      {
        /* Get Start Tick */
        tickstart = HAL_GetTick();
 8008462:	f7fd fa77 	bl	8005954 <HAL_GetTick>
 8008466:	0003      	movs	r3, r0
 8008468:	61bb      	str	r3, [r7, #24]
        
        /* Wait till HSE is disabled */
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) != RESET)
 800846a:	e008      	b.n	800847e <HAL_RCC_OscConfig+0x12e>
        {
           if((HAL_GetTick() - tickstart ) > HSE_TIMEOUT_VALUE)
 800846c:	f7fd fa72 	bl	8005954 <HAL_GetTick>
 8008470:	0002      	movs	r2, r0
 8008472:	69bb      	ldr	r3, [r7, #24]
 8008474:	1ad3      	subs	r3, r2, r3
 8008476:	2b64      	cmp	r3, #100	; 0x64
 8008478:	d901      	bls.n	800847e <HAL_RCC_OscConfig+0x12e>
          {
            return HAL_TIMEOUT;
 800847a:	2303      	movs	r3, #3
 800847c:	e2e8      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) != RESET)
 800847e:	4b82      	ldr	r3, [pc, #520]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 8008480:	681a      	ldr	r2, [r3, #0]
 8008482:	2380      	movs	r3, #128	; 0x80
 8008484:	029b      	lsls	r3, r3, #10
 8008486:	4013      	ands	r3, r2
 8008488:	d1f0      	bne.n	800846c <HAL_RCC_OscConfig+0x11c>
 800848a:	e000      	b.n	800848e <HAL_RCC_OscConfig+0x13e>
      if((__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) != RESET) && (RCC_OscInitStruct->HSEState == RCC_HSE_OFF))
 800848c:	46c0      	nop			; (mov r8, r8)
        }
      }
    }
  }
  /*----------------------------- HSI Configuration --------------------------*/ 
  if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_HSI) == RCC_OSCILLATORTYPE_HSI)
 800848e:	687b      	ldr	r3, [r7, #4]
 8008490:	681b      	ldr	r3, [r3, #0]
 8008492:	2202      	movs	r2, #2
 8008494:	4013      	ands	r3, r2
 8008496:	d100      	bne.n	800849a <HAL_RCC_OscConfig+0x14a>
 8008498:	e06c      	b.n	8008574 <HAL_RCC_OscConfig+0x224>
    /* Check the parameters */
    assert_param(IS_RCC_HSI(RCC_OscInitStruct->HSIState));
    assert_param(IS_RCC_CALIBRATION_VALUE(RCC_OscInitStruct->HSICalibrationValue));
    
    /* Check if HSI is used as system clock or as PLL source when PLL is selected as system clock */ 
    if((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_HSI) 
 800849a:	4b7b      	ldr	r3, [pc, #492]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 800849c:	685b      	ldr	r3, [r3, #4]
 800849e:	220c      	movs	r2, #12
 80084a0:	4013      	ands	r3, r2
 80084a2:	d00e      	beq.n	80084c2 <HAL_RCC_OscConfig+0x172>
       || ((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_PLLCLK) && (__HAL_RCC_GET_PLL_OSCSOURCE() == RCC_PLLSOURCE_HSI)))
 80084a4:	4b78      	ldr	r3, [pc, #480]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 80084a6:	685b      	ldr	r3, [r3, #4]
 80084a8:	220c      	movs	r2, #12
 80084aa:	4013      	ands	r3, r2
 80084ac:	2b08      	cmp	r3, #8
 80084ae:	d11f      	bne.n	80084f0 <HAL_RCC_OscConfig+0x1a0>
 80084b0:	4b75      	ldr	r3, [pc, #468]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 80084b2:	685a      	ldr	r2, [r3, #4]
 80084b4:	23c0      	movs	r3, #192	; 0xc0
 80084b6:	025b      	lsls	r3, r3, #9
 80084b8:	401a      	ands	r2, r3
 80084ba:	2380      	movs	r3, #128	; 0x80
 80084bc:	021b      	lsls	r3, r3, #8
 80084be:	429a      	cmp	r2, r3
 80084c0:	d116      	bne.n	80084f0 <HAL_RCC_OscConfig+0x1a0>
    {
      /* When HSI is used as system clock it will not disabled */
      if((__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) != RESET) && (RCC_OscInitStruct->HSIState != RCC_HSI_ON))
 80084c2:	4b71      	ldr	r3, [pc, #452]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 80084c4:	681b      	ldr	r3, [r3, #0]
 80084c6:	2202      	movs	r2, #2
 80084c8:	4013      	ands	r3, r2
 80084ca:	d005      	beq.n	80084d8 <HAL_RCC_OscConfig+0x188>
 80084cc:	687b      	ldr	r3, [r7, #4]
 80084ce:	68db      	ldr	r3, [r3, #12]
 80084d0:	2b01      	cmp	r3, #1
 80084d2:	d001      	beq.n	80084d8 <HAL_RCC_OscConfig+0x188>
      {
        return HAL_ERROR;
 80084d4:	2301      	movs	r3, #1
 80084d6:	e2bb      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
      }
      /* Otherwise, just the calibration is allowed */
      else
      {
        /* Adjusts the Internal High Speed oscillator (HSI) calibration value.*/
        __HAL_RCC_HSI_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->HSICalibrationValue);
 80084d8:	4b6b      	ldr	r3, [pc, #428]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 80084da:	681b      	ldr	r3, [r3, #0]
 80084dc:	22f8      	movs	r2, #248	; 0xf8
 80084de:	4393      	bics	r3, r2
 80084e0:	0019      	movs	r1, r3
 80084e2:	687b      	ldr	r3, [r7, #4]
 80084e4:	691b      	ldr	r3, [r3, #16]
 80084e6:	00da      	lsls	r2, r3, #3
 80084e8:	4b67      	ldr	r3, [pc, #412]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 80084ea:	430a      	orrs	r2, r1
 80084ec:	601a      	str	r2, [r3, #0]
      if((__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) != RESET) && (RCC_OscInitStruct->HSIState != RCC_HSI_ON))
 80084ee:	e041      	b.n	8008574 <HAL_RCC_OscConfig+0x224>
      }
    }
    else
    {
      /* Check the HSI State */
      if(RCC_OscInitStruct->HSIState != RCC_HSI_OFF)
 80084f0:	687b      	ldr	r3, [r7, #4]
 80084f2:	68db      	ldr	r3, [r3, #12]
 80084f4:	2b00      	cmp	r3, #0
 80084f6:	d024      	beq.n	8008542 <HAL_RCC_OscConfig+0x1f2>
      {
       /* Enable the Internal High Speed oscillator (HSI). */
        __HAL_RCC_HSI_ENABLE();
 80084f8:	4b63      	ldr	r3, [pc, #396]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 80084fa:	681a      	ldr	r2, [r3, #0]
 80084fc:	4b62      	ldr	r3, [pc, #392]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 80084fe:	2101      	movs	r1, #1
 8008500:	430a      	orrs	r2, r1
 8008502:	601a      	str	r2, [r3, #0]
        
        /* Get Start Tick */
        tickstart = HAL_GetTick();
 8008504:	f7fd fa26 	bl	8005954 <HAL_GetTick>
 8008508:	0003      	movs	r3, r0
 800850a:	61bb      	str	r3, [r7, #24]
        
        /* Wait till HSI is ready */
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) == RESET)
 800850c:	e008      	b.n	8008520 <HAL_RCC_OscConfig+0x1d0>
        {
          if((HAL_GetTick() - tickstart ) > HSI_TIMEOUT_VALUE)
 800850e:	f7fd fa21 	bl	8005954 <HAL_GetTick>
 8008512:	0002      	movs	r2, r0
 8008514:	69bb      	ldr	r3, [r7, #24]
 8008516:	1ad3      	subs	r3, r2, r3
 8008518:	2b02      	cmp	r3, #2
 800851a:	d901      	bls.n	8008520 <HAL_RCC_OscConfig+0x1d0>
          {
            return HAL_TIMEOUT;
 800851c:	2303      	movs	r3, #3
 800851e:	e297      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) == RESET)
 8008520:	4b59      	ldr	r3, [pc, #356]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 8008522:	681b      	ldr	r3, [r3, #0]
 8008524:	2202      	movs	r2, #2
 8008526:	4013      	ands	r3, r2
 8008528:	d0f1      	beq.n	800850e <HAL_RCC_OscConfig+0x1be>
          }
        }
                
        /* Adjusts the Internal High Speed oscillator (HSI) calibration value.*/
        __HAL_RCC_HSI_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->HSICalibrationValue);
 800852a:	4b57      	ldr	r3, [pc, #348]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 800852c:	681b      	ldr	r3, [r3, #0]
 800852e:	22f8      	movs	r2, #248	; 0xf8
 8008530:	4393      	bics	r3, r2
 8008532:	0019      	movs	r1, r3
 8008534:	687b      	ldr	r3, [r7, #4]
 8008536:	691b      	ldr	r3, [r3, #16]
 8008538:	00da      	lsls	r2, r3, #3
 800853a:	4b53      	ldr	r3, [pc, #332]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 800853c:	430a      	orrs	r2, r1
 800853e:	601a      	str	r2, [r3, #0]
 8008540:	e018      	b.n	8008574 <HAL_RCC_OscConfig+0x224>
      }
      else
      {
        /* Disable the Internal High Speed oscillator (HSI). */
        __HAL_RCC_HSI_DISABLE();
 8008542:	4b51      	ldr	r3, [pc, #324]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 8008544:	681a      	ldr	r2, [r3, #0]
 8008546:	4b50      	ldr	r3, [pc, #320]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 8008548:	2101      	movs	r1, #1
 800854a:	438a      	bics	r2, r1
 800854c:	601a      	str	r2, [r3, #0]
        
        /* Get Start Tick */
        tickstart = HAL_GetTick();
 800854e:	f7fd fa01 	bl	8005954 <HAL_GetTick>
 8008552:	0003      	movs	r3, r0
 8008554:	61bb      	str	r3, [r7, #24]
        
        /* Wait till HSI is disabled */
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) != RESET)
 8008556:	e008      	b.n	800856a <HAL_RCC_OscConfig+0x21a>
        {
          if((HAL_GetTick() - tickstart ) > HSI_TIMEOUT_VALUE)
 8008558:	f7fd f9fc 	bl	8005954 <HAL_GetTick>
 800855c:	0002      	movs	r2, r0
 800855e:	69bb      	ldr	r3, [r7, #24]
 8008560:	1ad3      	subs	r3, r2, r3
 8008562:	2b02      	cmp	r3, #2
 8008564:	d901      	bls.n	800856a <HAL_RCC_OscConfig+0x21a>
          {
            return HAL_TIMEOUT;
 8008566:	2303      	movs	r3, #3
 8008568:	e272      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) != RESET)
 800856a:	4b47      	ldr	r3, [pc, #284]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 800856c:	681b      	ldr	r3, [r3, #0]
 800856e:	2202      	movs	r2, #2
 8008570:	4013      	ands	r3, r2
 8008572:	d1f1      	bne.n	8008558 <HAL_RCC_OscConfig+0x208>
        }
      }
    }
  }
  /*------------------------------ LSI Configuration -------------------------*/ 
  if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_LSI) == RCC_OSCILLATORTYPE_LSI)
 8008574:	687b      	ldr	r3, [r7, #4]
 8008576:	681b      	ldr	r3, [r3, #0]
 8008578:	2208      	movs	r2, #8
 800857a:	4013      	ands	r3, r2
 800857c:	d036      	beq.n	80085ec <HAL_RCC_OscConfig+0x29c>
  {
    /* Check the parameters */
    assert_param(IS_RCC_LSI(RCC_OscInitStruct->LSIState));
    
    /* Check the LSI State */
    if(RCC_OscInitStruct->LSIState != RCC_LSI_OFF)
 800857e:	687b      	ldr	r3, [r7, #4]
 8008580:	69db      	ldr	r3, [r3, #28]
 8008582:	2b00      	cmp	r3, #0
 8008584:	d019      	beq.n	80085ba <HAL_RCC_OscConfig+0x26a>
    {
      /* Enable the Internal Low Speed oscillator (LSI). */
      __HAL_RCC_LSI_ENABLE();
 8008586:	4b40      	ldr	r3, [pc, #256]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 8008588:	6a5a      	ldr	r2, [r3, #36]	; 0x24
 800858a:	4b3f      	ldr	r3, [pc, #252]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 800858c:	2101      	movs	r1, #1
 800858e:	430a      	orrs	r2, r1
 8008590:	625a      	str	r2, [r3, #36]	; 0x24
      
      /* Get Start Tick */
      tickstart = HAL_GetTick();
 8008592:	f7fd f9df 	bl	8005954 <HAL_GetTick>
 8008596:	0003      	movs	r3, r0
 8008598:	61bb      	str	r3, [r7, #24]
      
      /* Wait till LSI is ready */  
      while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSIRDY) == RESET)
 800859a:	e008      	b.n	80085ae <HAL_RCC_OscConfig+0x25e>
      {
        if((HAL_GetTick() - tickstart ) > LSI_TIMEOUT_VALUE)
 800859c:	f7fd f9da 	bl	8005954 <HAL_GetTick>
 80085a0:	0002      	movs	r2, r0
 80085a2:	69bb      	ldr	r3, [r7, #24]
 80085a4:	1ad3      	subs	r3, r2, r3
 80085a6:	2b02      	cmp	r3, #2
 80085a8:	d901      	bls.n	80085ae <HAL_RCC_OscConfig+0x25e>
        {
          return HAL_TIMEOUT;
 80085aa:	2303      	movs	r3, #3
 80085ac:	e250      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
      while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSIRDY) == RESET)
 80085ae:	4b36      	ldr	r3, [pc, #216]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 80085b0:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 80085b2:	2202      	movs	r2, #2
 80085b4:	4013      	ands	r3, r2
 80085b6:	d0f1      	beq.n	800859c <HAL_RCC_OscConfig+0x24c>
 80085b8:	e018      	b.n	80085ec <HAL_RCC_OscConfig+0x29c>
      }
    }
    else
    {
      /* Disable the Internal Low Speed oscillator (LSI). */
      __HAL_RCC_LSI_DISABLE();
 80085ba:	4b33      	ldr	r3, [pc, #204]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 80085bc:	6a5a      	ldr	r2, [r3, #36]	; 0x24
 80085be:	4b32      	ldr	r3, [pc, #200]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 80085c0:	2101      	movs	r1, #1
 80085c2:	438a      	bics	r2, r1
 80085c4:	625a      	str	r2, [r3, #36]	; 0x24
      
      /* Get Start Tick */
      tickstart = HAL_GetTick();
 80085c6:	f7fd f9c5 	bl	8005954 <HAL_GetTick>
 80085ca:	0003      	movs	r3, r0
 80085cc:	61bb      	str	r3, [r7, #24]
      
      /* Wait till LSI is disabled */  
      while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSIRDY) != RESET)
 80085ce:	e008      	b.n	80085e2 <HAL_RCC_OscConfig+0x292>
      {
        if((HAL_GetTick() - tickstart ) > LSI_TIMEOUT_VALUE)
 80085d0:	f7fd f9c0 	bl	8005954 <HAL_GetTick>
 80085d4:	0002      	movs	r2, r0
 80085d6:	69bb      	ldr	r3, [r7, #24]
 80085d8:	1ad3      	subs	r3, r2, r3
 80085da:	2b02      	cmp	r3, #2
 80085dc:	d901      	bls.n	80085e2 <HAL_RCC_OscConfig+0x292>
        {
          return HAL_TIMEOUT;
 80085de:	2303      	movs	r3, #3
 80085e0:	e236      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
      while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSIRDY) != RESET)
 80085e2:	4b29      	ldr	r3, [pc, #164]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 80085e4:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 80085e6:	2202      	movs	r2, #2
 80085e8:	4013      	ands	r3, r2
 80085ea:	d1f1      	bne.n	80085d0 <HAL_RCC_OscConfig+0x280>
        }
      }
    }
  }
  /*------------------------------ LSE Configuration -------------------------*/ 
  if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_LSE) == RCC_OSCILLATORTYPE_LSE)
 80085ec:	687b      	ldr	r3, [r7, #4]
 80085ee:	681b      	ldr	r3, [r3, #0]
 80085f0:	2204      	movs	r2, #4
 80085f2:	4013      	ands	r3, r2
 80085f4:	d100      	bne.n	80085f8 <HAL_RCC_OscConfig+0x2a8>
 80085f6:	e0b5      	b.n	8008764 <HAL_RCC_OscConfig+0x414>
  {
    FlagStatus       pwrclkchanged = RESET;
 80085f8:	201f      	movs	r0, #31
 80085fa:	183b      	adds	r3, r7, r0
 80085fc:	2200      	movs	r2, #0
 80085fe:	701a      	strb	r2, [r3, #0]
    /* Check the parameters */
    assert_param(IS_RCC_LSE(RCC_OscInitStruct->LSEState));

    /* Update LSE configuration in Backup Domain control register    */
    /* Requires to enable write access to Backup Domain of necessary */
    if(__HAL_RCC_PWR_IS_CLK_DISABLED())
 8008600:	4b21      	ldr	r3, [pc, #132]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 8008602:	69da      	ldr	r2, [r3, #28]
 8008604:	2380      	movs	r3, #128	; 0x80
 8008606:	055b      	lsls	r3, r3, #21
 8008608:	4013      	ands	r3, r2
 800860a:	d110      	bne.n	800862e <HAL_RCC_OscConfig+0x2de>
    {
      __HAL_RCC_PWR_CLK_ENABLE();
 800860c:	4b1e      	ldr	r3, [pc, #120]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 800860e:	69da      	ldr	r2, [r3, #28]
 8008610:	4b1d      	ldr	r3, [pc, #116]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 8008612:	2180      	movs	r1, #128	; 0x80
 8008614:	0549      	lsls	r1, r1, #21
 8008616:	430a      	orrs	r2, r1
 8008618:	61da      	str	r2, [r3, #28]
 800861a:	4b1b      	ldr	r3, [pc, #108]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 800861c:	69da      	ldr	r2, [r3, #28]
 800861e:	2380      	movs	r3, #128	; 0x80
 8008620:	055b      	lsls	r3, r3, #21
 8008622:	4013      	ands	r3, r2
 8008624:	60fb      	str	r3, [r7, #12]
 8008626:	68fb      	ldr	r3, [r7, #12]
      pwrclkchanged = SET;
 8008628:	183b      	adds	r3, r7, r0
 800862a:	2201      	movs	r2, #1
 800862c:	701a      	strb	r2, [r3, #0]
    }
    
    if(HAL_IS_BIT_CLR(PWR->CR, PWR_CR_DBP))
 800862e:	4b19      	ldr	r3, [pc, #100]	; (8008694 <HAL_RCC_OscConfig+0x344>)
 8008630:	681a      	ldr	r2, [r3, #0]
 8008632:	2380      	movs	r3, #128	; 0x80
 8008634:	005b      	lsls	r3, r3, #1
 8008636:	4013      	ands	r3, r2
 8008638:	d11a      	bne.n	8008670 <HAL_RCC_OscConfig+0x320>
    {
      /* Enable write access to Backup domain */
      SET_BIT(PWR->CR, PWR_CR_DBP);
 800863a:	4b16      	ldr	r3, [pc, #88]	; (8008694 <HAL_RCC_OscConfig+0x344>)
 800863c:	681a      	ldr	r2, [r3, #0]
 800863e:	4b15      	ldr	r3, [pc, #84]	; (8008694 <HAL_RCC_OscConfig+0x344>)
 8008640:	2180      	movs	r1, #128	; 0x80
 8008642:	0049      	lsls	r1, r1, #1
 8008644:	430a      	orrs	r2, r1
 8008646:	601a      	str	r2, [r3, #0]
      
      /* Wait for Backup domain Write protection disable */
      tickstart = HAL_GetTick();
 8008648:	f7fd f984 	bl	8005954 <HAL_GetTick>
 800864c:	0003      	movs	r3, r0
 800864e:	61bb      	str	r3, [r7, #24]

      while(HAL_IS_BIT_CLR(PWR->CR, PWR_CR_DBP))
 8008650:	e008      	b.n	8008664 <HAL_RCC_OscConfig+0x314>
      {
        if((HAL_GetTick() - tickstart) > RCC_DBP_TIMEOUT_VALUE)
 8008652:	f7fd f97f 	bl	8005954 <HAL_GetTick>
 8008656:	0002      	movs	r2, r0
 8008658:	69bb      	ldr	r3, [r7, #24]
 800865a:	1ad3      	subs	r3, r2, r3
 800865c:	2b64      	cmp	r3, #100	; 0x64
 800865e:	d901      	bls.n	8008664 <HAL_RCC_OscConfig+0x314>
        {
          return HAL_TIMEOUT;
 8008660:	2303      	movs	r3, #3
 8008662:	e1f5      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
      while(HAL_IS_BIT_CLR(PWR->CR, PWR_CR_DBP))
 8008664:	4b0b      	ldr	r3, [pc, #44]	; (8008694 <HAL_RCC_OscConfig+0x344>)
 8008666:	681a      	ldr	r2, [r3, #0]
 8008668:	2380      	movs	r3, #128	; 0x80
 800866a:	005b      	lsls	r3, r3, #1
 800866c:	4013      	ands	r3, r2
 800866e:	d0f0      	beq.n	8008652 <HAL_RCC_OscConfig+0x302>
        }
      }
    }

    /* Set the new LSE configuration -----------------------------------------*/
    __HAL_RCC_LSE_CONFIG(RCC_OscInitStruct->LSEState);
 8008670:	687b      	ldr	r3, [r7, #4]
 8008672:	689b      	ldr	r3, [r3, #8]
 8008674:	2b01      	cmp	r3, #1
 8008676:	d10f      	bne.n	8008698 <HAL_RCC_OscConfig+0x348>
 8008678:	4b03      	ldr	r3, [pc, #12]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 800867a:	6a1a      	ldr	r2, [r3, #32]
 800867c:	4b02      	ldr	r3, [pc, #8]	; (8008688 <HAL_RCC_OscConfig+0x338>)
 800867e:	2101      	movs	r1, #1
 8008680:	430a      	orrs	r2, r1
 8008682:	621a      	str	r2, [r3, #32]
 8008684:	e036      	b.n	80086f4 <HAL_RCC_OscConfig+0x3a4>
 8008686:	46c0      	nop			; (mov r8, r8)
 8008688:	40021000 	.word	0x40021000
 800868c:	fffeffff 	.word	0xfffeffff
 8008690:	fffbffff 	.word	0xfffbffff
 8008694:	40007000 	.word	0x40007000
 8008698:	687b      	ldr	r3, [r7, #4]
 800869a:	689b      	ldr	r3, [r3, #8]
 800869c:	2b00      	cmp	r3, #0
 800869e:	d10c      	bne.n	80086ba <HAL_RCC_OscConfig+0x36a>
 80086a0:	4bca      	ldr	r3, [pc, #808]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80086a2:	6a1a      	ldr	r2, [r3, #32]
 80086a4:	4bc9      	ldr	r3, [pc, #804]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80086a6:	2101      	movs	r1, #1
 80086a8:	438a      	bics	r2, r1
 80086aa:	621a      	str	r2, [r3, #32]
 80086ac:	4bc7      	ldr	r3, [pc, #796]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80086ae:	6a1a      	ldr	r2, [r3, #32]
 80086b0:	4bc6      	ldr	r3, [pc, #792]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80086b2:	2104      	movs	r1, #4
 80086b4:	438a      	bics	r2, r1
 80086b6:	621a      	str	r2, [r3, #32]
 80086b8:	e01c      	b.n	80086f4 <HAL_RCC_OscConfig+0x3a4>
 80086ba:	687b      	ldr	r3, [r7, #4]
 80086bc:	689b      	ldr	r3, [r3, #8]
 80086be:	2b05      	cmp	r3, #5
 80086c0:	d10c      	bne.n	80086dc <HAL_RCC_OscConfig+0x38c>
 80086c2:	4bc2      	ldr	r3, [pc, #776]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80086c4:	6a1a      	ldr	r2, [r3, #32]
 80086c6:	4bc1      	ldr	r3, [pc, #772]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80086c8:	2104      	movs	r1, #4
 80086ca:	430a      	orrs	r2, r1
 80086cc:	621a      	str	r2, [r3, #32]
 80086ce:	4bbf      	ldr	r3, [pc, #764]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80086d0:	6a1a      	ldr	r2, [r3, #32]
 80086d2:	4bbe      	ldr	r3, [pc, #760]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80086d4:	2101      	movs	r1, #1
 80086d6:	430a      	orrs	r2, r1
 80086d8:	621a      	str	r2, [r3, #32]
 80086da:	e00b      	b.n	80086f4 <HAL_RCC_OscConfig+0x3a4>
 80086dc:	4bbb      	ldr	r3, [pc, #748]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80086de:	6a1a      	ldr	r2, [r3, #32]
 80086e0:	4bba      	ldr	r3, [pc, #744]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80086e2:	2101      	movs	r1, #1
 80086e4:	438a      	bics	r2, r1
 80086e6:	621a      	str	r2, [r3, #32]
 80086e8:	4bb8      	ldr	r3, [pc, #736]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80086ea:	6a1a      	ldr	r2, [r3, #32]
 80086ec:	4bb7      	ldr	r3, [pc, #732]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80086ee:	2104      	movs	r1, #4
 80086f0:	438a      	bics	r2, r1
 80086f2:	621a      	str	r2, [r3, #32]
    /* Check the LSE State */
    if(RCC_OscInitStruct->LSEState != RCC_LSE_OFF)
 80086f4:	687b      	ldr	r3, [r7, #4]
 80086f6:	689b      	ldr	r3, [r3, #8]
 80086f8:	2b00      	cmp	r3, #0
 80086fa:	d014      	beq.n	8008726 <HAL_RCC_OscConfig+0x3d6>
    {
      /* Get Start Tick */
      tickstart = HAL_GetTick();
 80086fc:	f7fd f92a 	bl	8005954 <HAL_GetTick>
 8008700:	0003      	movs	r3, r0
 8008702:	61bb      	str	r3, [r7, #24]
      
      /* Wait till LSE is ready */  
      while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) == RESET)
 8008704:	e009      	b.n	800871a <HAL_RCC_OscConfig+0x3ca>
      {
        if((HAL_GetTick() - tickstart ) > RCC_LSE_TIMEOUT_VALUE)
 8008706:	f7fd f925 	bl	8005954 <HAL_GetTick>
 800870a:	0002      	movs	r2, r0
 800870c:	69bb      	ldr	r3, [r7, #24]
 800870e:	1ad3      	subs	r3, r2, r3
 8008710:	4aaf      	ldr	r2, [pc, #700]	; (80089d0 <HAL_RCC_OscConfig+0x680>)
 8008712:	4293      	cmp	r3, r2
 8008714:	d901      	bls.n	800871a <HAL_RCC_OscConfig+0x3ca>
        {
          return HAL_TIMEOUT;
 8008716:	2303      	movs	r3, #3
 8008718:	e19a      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
      while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) == RESET)
 800871a:	4bac      	ldr	r3, [pc, #688]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 800871c:	6a1b      	ldr	r3, [r3, #32]
 800871e:	2202      	movs	r2, #2
 8008720:	4013      	ands	r3, r2
 8008722:	d0f0      	beq.n	8008706 <HAL_RCC_OscConfig+0x3b6>
 8008724:	e013      	b.n	800874e <HAL_RCC_OscConfig+0x3fe>
      }
    }
    else
    {
      /* Get Start Tick */
      tickstart = HAL_GetTick();
 8008726:	f7fd f915 	bl	8005954 <HAL_GetTick>
 800872a:	0003      	movs	r3, r0
 800872c:	61bb      	str	r3, [r7, #24]
      
      /* Wait till LSE is disabled */  
      while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) != RESET)
 800872e:	e009      	b.n	8008744 <HAL_RCC_OscConfig+0x3f4>
      {
        if((HAL_GetTick() - tickstart ) > RCC_LSE_TIMEOUT_VALUE)
 8008730:	f7fd f910 	bl	8005954 <HAL_GetTick>
 8008734:	0002      	movs	r2, r0
 8008736:	69bb      	ldr	r3, [r7, #24]
 8008738:	1ad3      	subs	r3, r2, r3
 800873a:	4aa5      	ldr	r2, [pc, #660]	; (80089d0 <HAL_RCC_OscConfig+0x680>)
 800873c:	4293      	cmp	r3, r2
 800873e:	d901      	bls.n	8008744 <HAL_RCC_OscConfig+0x3f4>
        {
          return HAL_TIMEOUT;
 8008740:	2303      	movs	r3, #3
 8008742:	e185      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
      while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) != RESET)
 8008744:	4ba1      	ldr	r3, [pc, #644]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 8008746:	6a1b      	ldr	r3, [r3, #32]
 8008748:	2202      	movs	r2, #2
 800874a:	4013      	ands	r3, r2
 800874c:	d1f0      	bne.n	8008730 <HAL_RCC_OscConfig+0x3e0>
        }
      }
    }

    /* Require to disable power clock if necessary */
    if(pwrclkchanged == SET)
 800874e:	231f      	movs	r3, #31
 8008750:	18fb      	adds	r3, r7, r3
 8008752:	781b      	ldrb	r3, [r3, #0]
 8008754:	2b01      	cmp	r3, #1
 8008756:	d105      	bne.n	8008764 <HAL_RCC_OscConfig+0x414>
    {
      __HAL_RCC_PWR_CLK_DISABLE();
 8008758:	4b9c      	ldr	r3, [pc, #624]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 800875a:	69da      	ldr	r2, [r3, #28]
 800875c:	4b9b      	ldr	r3, [pc, #620]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 800875e:	499d      	ldr	r1, [pc, #628]	; (80089d4 <HAL_RCC_OscConfig+0x684>)
 8008760:	400a      	ands	r2, r1
 8008762:	61da      	str	r2, [r3, #28]
    }
  }

  /*----------------------------- HSI14 Configuration --------------------------*/
  if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_HSI14) == RCC_OSCILLATORTYPE_HSI14)
 8008764:	687b      	ldr	r3, [r7, #4]
 8008766:	681b      	ldr	r3, [r3, #0]
 8008768:	2210      	movs	r2, #16
 800876a:	4013      	ands	r3, r2
 800876c:	d063      	beq.n	8008836 <HAL_RCC_OscConfig+0x4e6>
    /* Check the parameters */
    assert_param(IS_RCC_HSI14(RCC_OscInitStruct->HSI14State));
    assert_param(IS_RCC_CALIBRATION_VALUE(RCC_OscInitStruct->HSI14CalibrationValue));

    /* Check the HSI14 State */
    if(RCC_OscInitStruct->HSI14State == RCC_HSI14_ON)
 800876e:	687b      	ldr	r3, [r7, #4]
 8008770:	695b      	ldr	r3, [r3, #20]
 8008772:	2b01      	cmp	r3, #1
 8008774:	d12a      	bne.n	80087cc <HAL_RCC_OscConfig+0x47c>
    {
      /* Disable ADC control of the Internal High Speed oscillator HSI14 */
      __HAL_RCC_HSI14ADC_DISABLE();
 8008776:	4b95      	ldr	r3, [pc, #596]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 8008778:	6b5a      	ldr	r2, [r3, #52]	; 0x34
 800877a:	4b94      	ldr	r3, [pc, #592]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 800877c:	2104      	movs	r1, #4
 800877e:	430a      	orrs	r2, r1
 8008780:	635a      	str	r2, [r3, #52]	; 0x34

      /* Enable the Internal High Speed oscillator (HSI). */
      __HAL_RCC_HSI14_ENABLE();
 8008782:	4b92      	ldr	r3, [pc, #584]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 8008784:	6b5a      	ldr	r2, [r3, #52]	; 0x34
 8008786:	4b91      	ldr	r3, [pc, #580]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 8008788:	2101      	movs	r1, #1
 800878a:	430a      	orrs	r2, r1
 800878c:	635a      	str	r2, [r3, #52]	; 0x34

      /* Get Start Tick */
      tickstart = HAL_GetTick();
 800878e:	f7fd f8e1 	bl	8005954 <HAL_GetTick>
 8008792:	0003      	movs	r3, r0
 8008794:	61bb      	str	r3, [r7, #24]
      
      /* Wait till HSI is ready */  
      while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSI14RDY) == RESET)
 8008796:	e008      	b.n	80087aa <HAL_RCC_OscConfig+0x45a>
      {
        if((HAL_GetTick() - tickstart) > HSI14_TIMEOUT_VALUE)
 8008798:	f7fd f8dc 	bl	8005954 <HAL_GetTick>
 800879c:	0002      	movs	r2, r0
 800879e:	69bb      	ldr	r3, [r7, #24]
 80087a0:	1ad3      	subs	r3, r2, r3
 80087a2:	2b02      	cmp	r3, #2
 80087a4:	d901      	bls.n	80087aa <HAL_RCC_OscConfig+0x45a>
        {
          return HAL_TIMEOUT;
 80087a6:	2303      	movs	r3, #3
 80087a8:	e152      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
      while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSI14RDY) == RESET)
 80087aa:	4b88      	ldr	r3, [pc, #544]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80087ac:	6b5b      	ldr	r3, [r3, #52]	; 0x34
 80087ae:	2202      	movs	r2, #2
 80087b0:	4013      	ands	r3, r2
 80087b2:	d0f1      	beq.n	8008798 <HAL_RCC_OscConfig+0x448>
        }      
      } 

      /* Adjusts the Internal High Speed oscillator 14Mhz (HSI14) calibration value. */
      __HAL_RCC_HSI14_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->HSI14CalibrationValue);
 80087b4:	4b85      	ldr	r3, [pc, #532]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80087b6:	6b5b      	ldr	r3, [r3, #52]	; 0x34
 80087b8:	22f8      	movs	r2, #248	; 0xf8
 80087ba:	4393      	bics	r3, r2
 80087bc:	0019      	movs	r1, r3
 80087be:	687b      	ldr	r3, [r7, #4]
 80087c0:	699b      	ldr	r3, [r3, #24]
 80087c2:	00da      	lsls	r2, r3, #3
 80087c4:	4b81      	ldr	r3, [pc, #516]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80087c6:	430a      	orrs	r2, r1
 80087c8:	635a      	str	r2, [r3, #52]	; 0x34
 80087ca:	e034      	b.n	8008836 <HAL_RCC_OscConfig+0x4e6>
    }
    else if(RCC_OscInitStruct->HSI14State == RCC_HSI14_ADC_CONTROL)
 80087cc:	687b      	ldr	r3, [r7, #4]
 80087ce:	695b      	ldr	r3, [r3, #20]
 80087d0:	3305      	adds	r3, #5
 80087d2:	d111      	bne.n	80087f8 <HAL_RCC_OscConfig+0x4a8>
    {
      /* Enable ADC control of the Internal High Speed oscillator HSI14 */
      __HAL_RCC_HSI14ADC_ENABLE();
 80087d4:	4b7d      	ldr	r3, [pc, #500]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80087d6:	6b5a      	ldr	r2, [r3, #52]	; 0x34
 80087d8:	4b7c      	ldr	r3, [pc, #496]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80087da:	2104      	movs	r1, #4
 80087dc:	438a      	bics	r2, r1
 80087de:	635a      	str	r2, [r3, #52]	; 0x34

      /* Adjusts the Internal High Speed oscillator 14Mhz (HSI14) calibration value. */
      __HAL_RCC_HSI14_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->HSI14CalibrationValue);
 80087e0:	4b7a      	ldr	r3, [pc, #488]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80087e2:	6b5b      	ldr	r3, [r3, #52]	; 0x34
 80087e4:	22f8      	movs	r2, #248	; 0xf8
 80087e6:	4393      	bics	r3, r2
 80087e8:	0019      	movs	r1, r3
 80087ea:	687b      	ldr	r3, [r7, #4]
 80087ec:	699b      	ldr	r3, [r3, #24]
 80087ee:	00da      	lsls	r2, r3, #3
 80087f0:	4b76      	ldr	r3, [pc, #472]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80087f2:	430a      	orrs	r2, r1
 80087f4:	635a      	str	r2, [r3, #52]	; 0x34
 80087f6:	e01e      	b.n	8008836 <HAL_RCC_OscConfig+0x4e6>
    }
    else
    {
      /* Disable ADC control of the Internal High Speed oscillator HSI14 */
      __HAL_RCC_HSI14ADC_DISABLE();
 80087f8:	4b74      	ldr	r3, [pc, #464]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80087fa:	6b5a      	ldr	r2, [r3, #52]	; 0x34
 80087fc:	4b73      	ldr	r3, [pc, #460]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80087fe:	2104      	movs	r1, #4
 8008800:	430a      	orrs	r2, r1
 8008802:	635a      	str	r2, [r3, #52]	; 0x34

      /* Disable the Internal High Speed oscillator (HSI). */
      __HAL_RCC_HSI14_DISABLE();
 8008804:	4b71      	ldr	r3, [pc, #452]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 8008806:	6b5a      	ldr	r2, [r3, #52]	; 0x34
 8008808:	4b70      	ldr	r3, [pc, #448]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 800880a:	2101      	movs	r1, #1
 800880c:	438a      	bics	r2, r1
 800880e:	635a      	str	r2, [r3, #52]	; 0x34

      /* Get Start Tick */
      tickstart = HAL_GetTick();
 8008810:	f7fd f8a0 	bl	8005954 <HAL_GetTick>
 8008814:	0003      	movs	r3, r0
 8008816:	61bb      	str	r3, [r7, #24]
      
      /* Wait till HSI is ready */  
      while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSI14RDY) != RESET)
 8008818:	e008      	b.n	800882c <HAL_RCC_OscConfig+0x4dc>
      {
        if((HAL_GetTick() - tickstart) > HSI14_TIMEOUT_VALUE)
 800881a:	f7fd f89b 	bl	8005954 <HAL_GetTick>
 800881e:	0002      	movs	r2, r0
 8008820:	69bb      	ldr	r3, [r7, #24]
 8008822:	1ad3      	subs	r3, r2, r3
 8008824:	2b02      	cmp	r3, #2
 8008826:	d901      	bls.n	800882c <HAL_RCC_OscConfig+0x4dc>
        {
          return HAL_TIMEOUT;
 8008828:	2303      	movs	r3, #3
 800882a:	e111      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
      while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSI14RDY) != RESET)
 800882c:	4b67      	ldr	r3, [pc, #412]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 800882e:	6b5b      	ldr	r3, [r3, #52]	; 0x34
 8008830:	2202      	movs	r2, #2
 8008832:	4013      	ands	r3, r2
 8008834:	d1f1      	bne.n	800881a <HAL_RCC_OscConfig+0x4ca>
    }
  }

#if defined(RCC_HSI48_SUPPORT)
  /*----------------------------- HSI48 Configuration --------------------------*/
  if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_HSI48) == RCC_OSCILLATORTYPE_HSI48)
 8008836:	687b      	ldr	r3, [r7, #4]
 8008838:	681b      	ldr	r3, [r3, #0]
 800883a:	2220      	movs	r2, #32
 800883c:	4013      	ands	r3, r2
 800883e:	d05c      	beq.n	80088fa <HAL_RCC_OscConfig+0x5aa>
  {
    /* Check the parameters */
    assert_param(IS_RCC_HSI48(RCC_OscInitStruct->HSI48State));

    /* When the HSI48 is used as system clock it is not allowed to be disabled */
    if((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_HSI48) ||
 8008840:	4b62      	ldr	r3, [pc, #392]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 8008842:	685b      	ldr	r3, [r3, #4]
 8008844:	220c      	movs	r2, #12
 8008846:	4013      	ands	r3, r2
 8008848:	2b0c      	cmp	r3, #12
 800884a:	d00e      	beq.n	800886a <HAL_RCC_OscConfig+0x51a>
       ((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_PLLCLK) && (__HAL_RCC_GET_PLL_OSCSOURCE() == RCC_PLLSOURCE_HSI48)))
 800884c:	4b5f      	ldr	r3, [pc, #380]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 800884e:	685b      	ldr	r3, [r3, #4]
 8008850:	220c      	movs	r2, #12
 8008852:	4013      	ands	r3, r2
    if((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_HSI48) ||
 8008854:	2b08      	cmp	r3, #8
 8008856:	d114      	bne.n	8008882 <HAL_RCC_OscConfig+0x532>
       ((__HAL_RCC_GET_SYSCLK_SOURCE() == RCC_SYSCLKSOURCE_STATUS_PLLCLK) && (__HAL_RCC_GET_PLL_OSCSOURCE() == RCC_PLLSOURCE_HSI48)))
 8008858:	4b5c      	ldr	r3, [pc, #368]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 800885a:	685a      	ldr	r2, [r3, #4]
 800885c:	23c0      	movs	r3, #192	; 0xc0
 800885e:	025b      	lsls	r3, r3, #9
 8008860:	401a      	ands	r2, r3
 8008862:	23c0      	movs	r3, #192	; 0xc0
 8008864:	025b      	lsls	r3, r3, #9
 8008866:	429a      	cmp	r2, r3
 8008868:	d10b      	bne.n	8008882 <HAL_RCC_OscConfig+0x532>
    {
      if((__HAL_RCC_GET_FLAG(RCC_FLAG_HSI48RDY) != RESET) && (RCC_OscInitStruct->HSI48State != RCC_HSI48_ON))
 800886a:	4b58      	ldr	r3, [pc, #352]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 800886c:	6b5a      	ldr	r2, [r3, #52]	; 0x34
 800886e:	2380      	movs	r3, #128	; 0x80
 8008870:	025b      	lsls	r3, r3, #9
 8008872:	4013      	ands	r3, r2
 8008874:	d040      	beq.n	80088f8 <HAL_RCC_OscConfig+0x5a8>
 8008876:	687b      	ldr	r3, [r7, #4]
 8008878:	6a1b      	ldr	r3, [r3, #32]
 800887a:	2b01      	cmp	r3, #1
 800887c:	d03c      	beq.n	80088f8 <HAL_RCC_OscConfig+0x5a8>
      {
        return HAL_ERROR;
 800887e:	2301      	movs	r3, #1
 8008880:	e0e6      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
      }
    }
    else
    {
      /* Check the HSI48 State */
      if(RCC_OscInitStruct->HSI48State != RCC_HSI48_OFF)
 8008882:	687b      	ldr	r3, [r7, #4]
 8008884:	6a1b      	ldr	r3, [r3, #32]
 8008886:	2b00      	cmp	r3, #0
 8008888:	d01b      	beq.n	80088c2 <HAL_RCC_OscConfig+0x572>
      {
        /* Enable the Internal High Speed oscillator (HSI48). */
        __HAL_RCC_HSI48_ENABLE();
 800888a:	4b50      	ldr	r3, [pc, #320]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 800888c:	6b5a      	ldr	r2, [r3, #52]	; 0x34
 800888e:	4b4f      	ldr	r3, [pc, #316]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 8008890:	2180      	movs	r1, #128	; 0x80
 8008892:	0249      	lsls	r1, r1, #9
 8008894:	430a      	orrs	r2, r1
 8008896:	635a      	str	r2, [r3, #52]	; 0x34

        /* Get Start Tick */
        tickstart = HAL_GetTick();
 8008898:	f7fd f85c 	bl	8005954 <HAL_GetTick>
 800889c:	0003      	movs	r3, r0
 800889e:	61bb      	str	r3, [r7, #24]
      
        /* Wait till HSI48 is ready */  
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSI48RDY) == RESET)
 80088a0:	e008      	b.n	80088b4 <HAL_RCC_OscConfig+0x564>
        {
          if((HAL_GetTick() - tickstart) > HSI48_TIMEOUT_VALUE)
 80088a2:	f7fd f857 	bl	8005954 <HAL_GetTick>
 80088a6:	0002      	movs	r2, r0
 80088a8:	69bb      	ldr	r3, [r7, #24]
 80088aa:	1ad3      	subs	r3, r2, r3
 80088ac:	2b02      	cmp	r3, #2
 80088ae:	d901      	bls.n	80088b4 <HAL_RCC_OscConfig+0x564>
          {
            return HAL_TIMEOUT;
 80088b0:	2303      	movs	r3, #3
 80088b2:	e0cd      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSI48RDY) == RESET)
 80088b4:	4b45      	ldr	r3, [pc, #276]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80088b6:	6b5a      	ldr	r2, [r3, #52]	; 0x34
 80088b8:	2380      	movs	r3, #128	; 0x80
 80088ba:	025b      	lsls	r3, r3, #9
 80088bc:	4013      	ands	r3, r2
 80088be:	d0f0      	beq.n	80088a2 <HAL_RCC_OscConfig+0x552>
 80088c0:	e01b      	b.n	80088fa <HAL_RCC_OscConfig+0x5aa>
        } 
      }
      else
      {
        /* Disable the Internal High Speed oscillator (HSI48). */
        __HAL_RCC_HSI48_DISABLE();
 80088c2:	4b42      	ldr	r3, [pc, #264]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80088c4:	6b5a      	ldr	r2, [r3, #52]	; 0x34
 80088c6:	4b41      	ldr	r3, [pc, #260]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80088c8:	4943      	ldr	r1, [pc, #268]	; (80089d8 <HAL_RCC_OscConfig+0x688>)
 80088ca:	400a      	ands	r2, r1
 80088cc:	635a      	str	r2, [r3, #52]	; 0x34

        /* Get Start Tick */
        tickstart = HAL_GetTick();
 80088ce:	f7fd f841 	bl	8005954 <HAL_GetTick>
 80088d2:	0003      	movs	r3, r0
 80088d4:	61bb      	str	r3, [r7, #24]
      
        /* Wait till HSI48 is ready */  
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSI48RDY) != RESET)
 80088d6:	e008      	b.n	80088ea <HAL_RCC_OscConfig+0x59a>
        {
          if((HAL_GetTick() - tickstart) > HSI48_TIMEOUT_VALUE)
 80088d8:	f7fd f83c 	bl	8005954 <HAL_GetTick>
 80088dc:	0002      	movs	r2, r0
 80088de:	69bb      	ldr	r3, [r7, #24]
 80088e0:	1ad3      	subs	r3, r2, r3
 80088e2:	2b02      	cmp	r3, #2
 80088e4:	d901      	bls.n	80088ea <HAL_RCC_OscConfig+0x59a>
          {
            return HAL_TIMEOUT;
 80088e6:	2303      	movs	r3, #3
 80088e8:	e0b2      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSI48RDY) != RESET)
 80088ea:	4b38      	ldr	r3, [pc, #224]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80088ec:	6b5a      	ldr	r2, [r3, #52]	; 0x34
 80088ee:	2380      	movs	r3, #128	; 0x80
 80088f0:	025b      	lsls	r3, r3, #9
 80088f2:	4013      	ands	r3, r2
 80088f4:	d1f0      	bne.n	80088d8 <HAL_RCC_OscConfig+0x588>
 80088f6:	e000      	b.n	80088fa <HAL_RCC_OscConfig+0x5aa>
      if((__HAL_RCC_GET_FLAG(RCC_FLAG_HSI48RDY) != RESET) && (RCC_OscInitStruct->HSI48State != RCC_HSI48_ON))
 80088f8:	46c0      	nop			; (mov r8, r8)
#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)
 80088fa:	687b      	ldr	r3, [r7, #4]
 80088fc:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 80088fe:	2b00      	cmp	r3, #0
 8008900:	d100      	bne.n	8008904 <HAL_RCC_OscConfig+0x5b4>
 8008902:	e0a4      	b.n	8008a4e <HAL_RCC_OscConfig+0x6fe>
  {
    /* Check if the PLL is used as system clock or not */
    if(__HAL_RCC_GET_SYSCLK_SOURCE() != RCC_SYSCLKSOURCE_STATUS_PLLCLK)
 8008904:	4b31      	ldr	r3, [pc, #196]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 8008906:	685b      	ldr	r3, [r3, #4]
 8008908:	220c      	movs	r2, #12
 800890a:	4013      	ands	r3, r2
 800890c:	2b08      	cmp	r3, #8
 800890e:	d100      	bne.n	8008912 <HAL_RCC_OscConfig+0x5c2>
 8008910:	e078      	b.n	8008a04 <HAL_RCC_OscConfig+0x6b4>
    { 
      if((RCC_OscInitStruct->PLL.PLLState) == RCC_PLL_ON)
 8008912:	687b      	ldr	r3, [r7, #4]
 8008914:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8008916:	2b02      	cmp	r3, #2
 8008918:	d14c      	bne.n	80089b4 <HAL_RCC_OscConfig+0x664>
        assert_param(IS_RCC_PLLSOURCE(RCC_OscInitStruct->PLL.PLLSource));
        assert_param(IS_RCC_PLL_MUL(RCC_OscInitStruct->PLL.PLLMUL));
        assert_param(IS_RCC_PREDIV(RCC_OscInitStruct->PLL.PREDIV));
  
        /* Disable the main PLL. */
        __HAL_RCC_PLL_DISABLE();
 800891a:	4b2c      	ldr	r3, [pc, #176]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 800891c:	681a      	ldr	r2, [r3, #0]
 800891e:	4b2b      	ldr	r3, [pc, #172]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 8008920:	492e      	ldr	r1, [pc, #184]	; (80089dc <HAL_RCC_OscConfig+0x68c>)
 8008922:	400a      	ands	r2, r1
 8008924:	601a      	str	r2, [r3, #0]
        
        /* Get Start Tick */
        tickstart = HAL_GetTick();
 8008926:	f7fd f815 	bl	8005954 <HAL_GetTick>
 800892a:	0003      	movs	r3, r0
 800892c:	61bb      	str	r3, [r7, #24]
        
        /* Wait till PLL is disabled */
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY)  != RESET)
 800892e:	e008      	b.n	8008942 <HAL_RCC_OscConfig+0x5f2>
        {
          if((HAL_GetTick() - tickstart ) > PLL_TIMEOUT_VALUE)
 8008930:	f7fd f810 	bl	8005954 <HAL_GetTick>
 8008934:	0002      	movs	r2, r0
 8008936:	69bb      	ldr	r3, [r7, #24]
 8008938:	1ad3      	subs	r3, r2, r3
 800893a:	2b02      	cmp	r3, #2
 800893c:	d901      	bls.n	8008942 <HAL_RCC_OscConfig+0x5f2>
          {
            return HAL_TIMEOUT;
 800893e:	2303      	movs	r3, #3
 8008940:	e086      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY)  != RESET)
 8008942:	4b22      	ldr	r3, [pc, #136]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 8008944:	681a      	ldr	r2, [r3, #0]
 8008946:	2380      	movs	r3, #128	; 0x80
 8008948:	049b      	lsls	r3, r3, #18
 800894a:	4013      	ands	r3, r2
 800894c:	d1f0      	bne.n	8008930 <HAL_RCC_OscConfig+0x5e0>
          }
        }

        /* Configure the main PLL clock source, predivider and multiplication factor. */
        __HAL_RCC_PLL_CONFIG(RCC_OscInitStruct->PLL.PLLSource,
 800894e:	4b1f      	ldr	r3, [pc, #124]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 8008950:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8008952:	220f      	movs	r2, #15
 8008954:	4393      	bics	r3, r2
 8008956:	0019      	movs	r1, r3
 8008958:	687b      	ldr	r3, [r7, #4]
 800895a:	6b1a      	ldr	r2, [r3, #48]	; 0x30
 800895c:	4b1b      	ldr	r3, [pc, #108]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 800895e:	430a      	orrs	r2, r1
 8008960:	62da      	str	r2, [r3, #44]	; 0x2c
 8008962:	4b1a      	ldr	r3, [pc, #104]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 8008964:	685b      	ldr	r3, [r3, #4]
 8008966:	4a1e      	ldr	r2, [pc, #120]	; (80089e0 <HAL_RCC_OscConfig+0x690>)
 8008968:	4013      	ands	r3, r2
 800896a:	0019      	movs	r1, r3
 800896c:	687b      	ldr	r3, [r7, #4]
 800896e:	6ada      	ldr	r2, [r3, #44]	; 0x2c
 8008970:	687b      	ldr	r3, [r7, #4]
 8008972:	6a9b      	ldr	r3, [r3, #40]	; 0x28
 8008974:	431a      	orrs	r2, r3
 8008976:	4b15      	ldr	r3, [pc, #84]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 8008978:	430a      	orrs	r2, r1
 800897a:	605a      	str	r2, [r3, #4]
                             RCC_OscInitStruct->PLL.PREDIV,
                             RCC_OscInitStruct->PLL.PLLMUL);
        /* Enable the main PLL. */
        __HAL_RCC_PLL_ENABLE();
 800897c:	4b13      	ldr	r3, [pc, #76]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 800897e:	681a      	ldr	r2, [r3, #0]
 8008980:	4b12      	ldr	r3, [pc, #72]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 8008982:	2180      	movs	r1, #128	; 0x80
 8008984:	0449      	lsls	r1, r1, #17
 8008986:	430a      	orrs	r2, r1
 8008988:	601a      	str	r2, [r3, #0]
        
        /* Get Start Tick */
        tickstart = HAL_GetTick();
 800898a:	f7fc ffe3 	bl	8005954 <HAL_GetTick>
 800898e:	0003      	movs	r3, r0
 8008990:	61bb      	str	r3, [r7, #24]
        
        /* Wait till PLL is ready */
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY)  == RESET)
 8008992:	e008      	b.n	80089a6 <HAL_RCC_OscConfig+0x656>
        {
          if((HAL_GetTick() - tickstart ) > PLL_TIMEOUT_VALUE)
 8008994:	f7fc ffde 	bl	8005954 <HAL_GetTick>
 8008998:	0002      	movs	r2, r0
 800899a:	69bb      	ldr	r3, [r7, #24]
 800899c:	1ad3      	subs	r3, r2, r3
 800899e:	2b02      	cmp	r3, #2
 80089a0:	d901      	bls.n	80089a6 <HAL_RCC_OscConfig+0x656>
          {
            return HAL_TIMEOUT;
 80089a2:	2303      	movs	r3, #3
 80089a4:	e054      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY)  == RESET)
 80089a6:	4b09      	ldr	r3, [pc, #36]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80089a8:	681a      	ldr	r2, [r3, #0]
 80089aa:	2380      	movs	r3, #128	; 0x80
 80089ac:	049b      	lsls	r3, r3, #18
 80089ae:	4013      	ands	r3, r2
 80089b0:	d0f0      	beq.n	8008994 <HAL_RCC_OscConfig+0x644>
 80089b2:	e04c      	b.n	8008a4e <HAL_RCC_OscConfig+0x6fe>
        }
      }
      else
      {
        /* Disable the main PLL. */
        __HAL_RCC_PLL_DISABLE();
 80089b4:	4b05      	ldr	r3, [pc, #20]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80089b6:	681a      	ldr	r2, [r3, #0]
 80089b8:	4b04      	ldr	r3, [pc, #16]	; (80089cc <HAL_RCC_OscConfig+0x67c>)
 80089ba:	4908      	ldr	r1, [pc, #32]	; (80089dc <HAL_RCC_OscConfig+0x68c>)
 80089bc:	400a      	ands	r2, r1
 80089be:	601a      	str	r2, [r3, #0]
 
        /* Get Start Tick */
        tickstart = HAL_GetTick();
 80089c0:	f7fc ffc8 	bl	8005954 <HAL_GetTick>
 80089c4:	0003      	movs	r3, r0
 80089c6:	61bb      	str	r3, [r7, #24]
        
        /* Wait till PLL is disabled */  
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY)  != RESET)
 80089c8:	e015      	b.n	80089f6 <HAL_RCC_OscConfig+0x6a6>
 80089ca:	46c0      	nop			; (mov r8, r8)
 80089cc:	40021000 	.word	0x40021000
 80089d0:	00001388 	.word	0x00001388
 80089d4:	efffffff 	.word	0xefffffff
 80089d8:	fffeffff 	.word	0xfffeffff
 80089dc:	feffffff 	.word	0xfeffffff
 80089e0:	ffc27fff 	.word	0xffc27fff
        {
          if((HAL_GetTick() - tickstart ) > PLL_TIMEOUT_VALUE)
 80089e4:	f7fc ffb6 	bl	8005954 <HAL_GetTick>
 80089e8:	0002      	movs	r2, r0
 80089ea:	69bb      	ldr	r3, [r7, #24]
 80089ec:	1ad3      	subs	r3, r2, r3
 80089ee:	2b02      	cmp	r3, #2
 80089f0:	d901      	bls.n	80089f6 <HAL_RCC_OscConfig+0x6a6>
          {
            return HAL_TIMEOUT;
 80089f2:	2303      	movs	r3, #3
 80089f4:	e02c      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY)  != RESET)
 80089f6:	4b18      	ldr	r3, [pc, #96]	; (8008a58 <HAL_RCC_OscConfig+0x708>)
 80089f8:	681a      	ldr	r2, [r3, #0]
 80089fa:	2380      	movs	r3, #128	; 0x80
 80089fc:	049b      	lsls	r3, r3, #18
 80089fe:	4013      	ands	r3, r2
 8008a00:	d1f0      	bne.n	80089e4 <HAL_RCC_OscConfig+0x694>
 8008a02:	e024      	b.n	8008a4e <HAL_RCC_OscConfig+0x6fe>
      }
    }
    else
    {
      /* Check if there is a request to disable the PLL used as System clock source */
      if((RCC_OscInitStruct->PLL.PLLState) == RCC_PLL_OFF)
 8008a04:	687b      	ldr	r3, [r7, #4]
 8008a06:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8008a08:	2b01      	cmp	r3, #1
 8008a0a:	d101      	bne.n	8008a10 <HAL_RCC_OscConfig+0x6c0>
      {
        return HAL_ERROR;
 8008a0c:	2301      	movs	r3, #1
 8008a0e:	e01f      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
      }
      else
      {
        /* Do not return HAL_ERROR if request repeats the current configuration */
        pll_config  = RCC->CFGR;
 8008a10:	4b11      	ldr	r3, [pc, #68]	; (8008a58 <HAL_RCC_OscConfig+0x708>)
 8008a12:	685b      	ldr	r3, [r3, #4]
 8008a14:	617b      	str	r3, [r7, #20]
        pll_config2 = RCC->CFGR2;
 8008a16:	4b10      	ldr	r3, [pc, #64]	; (8008a58 <HAL_RCC_OscConfig+0x708>)
 8008a18:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8008a1a:	613b      	str	r3, [r7, #16]
        if((READ_BIT(pll_config,  RCC_CFGR_PLLSRC)  != RCC_OscInitStruct->PLL.PLLSource) ||
 8008a1c:	697a      	ldr	r2, [r7, #20]
 8008a1e:	23c0      	movs	r3, #192	; 0xc0
 8008a20:	025b      	lsls	r3, r3, #9
 8008a22:	401a      	ands	r2, r3
 8008a24:	687b      	ldr	r3, [r7, #4]
 8008a26:	6a9b      	ldr	r3, [r3, #40]	; 0x28
 8008a28:	429a      	cmp	r2, r3
 8008a2a:	d10e      	bne.n	8008a4a <HAL_RCC_OscConfig+0x6fa>
           (READ_BIT(pll_config2, RCC_CFGR2_PREDIV) != RCC_OscInitStruct->PLL.PREDIV)    ||
 8008a2c:	693b      	ldr	r3, [r7, #16]
 8008a2e:	220f      	movs	r2, #15
 8008a30:	401a      	ands	r2, r3
 8008a32:	687b      	ldr	r3, [r7, #4]
 8008a34:	6b1b      	ldr	r3, [r3, #48]	; 0x30
        if((READ_BIT(pll_config,  RCC_CFGR_PLLSRC)  != RCC_OscInitStruct->PLL.PLLSource) ||
 8008a36:	429a      	cmp	r2, r3
 8008a38:	d107      	bne.n	8008a4a <HAL_RCC_OscConfig+0x6fa>
           (READ_BIT(pll_config,  RCC_CFGR_PLLMUL)  != RCC_OscInitStruct->PLL.PLLMUL))
 8008a3a:	697a      	ldr	r2, [r7, #20]
 8008a3c:	23f0      	movs	r3, #240	; 0xf0
 8008a3e:	039b      	lsls	r3, r3, #14
 8008a40:	401a      	ands	r2, r3
 8008a42:	687b      	ldr	r3, [r7, #4]
 8008a44:	6adb      	ldr	r3, [r3, #44]	; 0x2c
           (READ_BIT(pll_config2, RCC_CFGR2_PREDIV) != RCC_OscInitStruct->PLL.PREDIV)    ||
 8008a46:	429a      	cmp	r2, r3
 8008a48:	d001      	beq.n	8008a4e <HAL_RCC_OscConfig+0x6fe>
        {
          return HAL_ERROR;
 8008a4a:	2301      	movs	r3, #1
 8008a4c:	e000      	b.n	8008a50 <HAL_RCC_OscConfig+0x700>
        }
      }
    }
  }

  return HAL_OK;
 8008a4e:	2300      	movs	r3, #0
}
 8008a50:	0018      	movs	r0, r3
 8008a52:	46bd      	mov	sp, r7
 8008a54:	b008      	add	sp, #32
 8008a56:	bd80      	pop	{r7, pc}
 8008a58:	40021000 	.word	0x40021000

08008a5c <HAL_RCC_ClockConfig>:
  *         You can use @ref HAL_RCC_GetClockConfig() function to know which clock is
  *         currently used as system clock source.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_RCC_ClockConfig(RCC_ClkInitTypeDef  *RCC_ClkInitStruct, uint32_t FLatency)
{
 8008a5c:	b580      	push	{r7, lr}
 8008a5e:	b084      	sub	sp, #16
 8008a60:	af00      	add	r7, sp, #0
 8008a62:	6078      	str	r0, [r7, #4]
 8008a64:	6039      	str	r1, [r7, #0]
  uint32_t tickstart;

  /* Check Null pointer */
  if(RCC_ClkInitStruct == NULL)
 8008a66:	687b      	ldr	r3, [r7, #4]
 8008a68:	2b00      	cmp	r3, #0
 8008a6a:	d101      	bne.n	8008a70 <HAL_RCC_ClockConfig+0x14>
  {
    return HAL_ERROR;
 8008a6c:	2301      	movs	r3, #1
 8008a6e:	e0bf      	b.n	8008bf0 <HAL_RCC_ClockConfig+0x194>
  /* 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) of the device. */

  /* Increasing the number of wait states because of higher CPU frequency */
  if(FLatency > __HAL_FLASH_GET_LATENCY())
 8008a70:	4b61      	ldr	r3, [pc, #388]	; (8008bf8 <HAL_RCC_ClockConfig+0x19c>)
 8008a72:	681b      	ldr	r3, [r3, #0]
 8008a74:	2201      	movs	r2, #1
 8008a76:	4013      	ands	r3, r2
 8008a78:	683a      	ldr	r2, [r7, #0]
 8008a7a:	429a      	cmp	r2, r3
 8008a7c:	d911      	bls.n	8008aa2 <HAL_RCC_ClockConfig+0x46>
  {    
    /* Program the new number of wait states to the LATENCY bits in the FLASH_ACR register */
    __HAL_FLASH_SET_LATENCY(FLatency);
 8008a7e:	4b5e      	ldr	r3, [pc, #376]	; (8008bf8 <HAL_RCC_ClockConfig+0x19c>)
 8008a80:	681b      	ldr	r3, [r3, #0]
 8008a82:	2201      	movs	r2, #1
 8008a84:	4393      	bics	r3, r2
 8008a86:	0019      	movs	r1, r3
 8008a88:	4b5b      	ldr	r3, [pc, #364]	; (8008bf8 <HAL_RCC_ClockConfig+0x19c>)
 8008a8a:	683a      	ldr	r2, [r7, #0]
 8008a8c:	430a      	orrs	r2, r1
 8008a8e:	601a      	str	r2, [r3, #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)
 8008a90:	4b59      	ldr	r3, [pc, #356]	; (8008bf8 <HAL_RCC_ClockConfig+0x19c>)
 8008a92:	681b      	ldr	r3, [r3, #0]
 8008a94:	2201      	movs	r2, #1
 8008a96:	4013      	ands	r3, r2
 8008a98:	683a      	ldr	r2, [r7, #0]
 8008a9a:	429a      	cmp	r2, r3
 8008a9c:	d001      	beq.n	8008aa2 <HAL_RCC_ClockConfig+0x46>
    {
      return HAL_ERROR;
 8008a9e:	2301      	movs	r3, #1
 8008aa0:	e0a6      	b.n	8008bf0 <HAL_RCC_ClockConfig+0x194>
    }
  }

  /*-------------------------- HCLK Configuration --------------------------*/
  if(((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_HCLK) == RCC_CLOCKTYPE_HCLK)
 8008aa2:	687b      	ldr	r3, [r7, #4]
 8008aa4:	681b      	ldr	r3, [r3, #0]
 8008aa6:	2202      	movs	r2, #2
 8008aa8:	4013      	ands	r3, r2
 8008aaa:	d015      	beq.n	8008ad8 <HAL_RCC_ClockConfig+0x7c>
  {
    /* Set the highest APB divider in order to ensure that we do not go through
       a non-spec phase whatever we decrease or increase HCLK. */
    if(((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_PCLK1) == RCC_CLOCKTYPE_PCLK1)
 8008aac:	687b      	ldr	r3, [r7, #4]
 8008aae:	681b      	ldr	r3, [r3, #0]
 8008ab0:	2204      	movs	r2, #4
 8008ab2:	4013      	ands	r3, r2
 8008ab4:	d006      	beq.n	8008ac4 <HAL_RCC_ClockConfig+0x68>
    {
      MODIFY_REG(RCC->CFGR, RCC_CFGR_PPRE, RCC_HCLK_DIV16);
 8008ab6:	4b51      	ldr	r3, [pc, #324]	; (8008bfc <HAL_RCC_ClockConfig+0x1a0>)
 8008ab8:	685a      	ldr	r2, [r3, #4]
 8008aba:	4b50      	ldr	r3, [pc, #320]	; (8008bfc <HAL_RCC_ClockConfig+0x1a0>)
 8008abc:	21e0      	movs	r1, #224	; 0xe0
 8008abe:	00c9      	lsls	r1, r1, #3
 8008ac0:	430a      	orrs	r2, r1
 8008ac2:	605a      	str	r2, [r3, #4]
    }

    /* Set the new HCLK clock divider */
    assert_param(IS_RCC_HCLK(RCC_ClkInitStruct->AHBCLKDivider));
    MODIFY_REG(RCC->CFGR, RCC_CFGR_HPRE, RCC_ClkInitStruct->AHBCLKDivider);
 8008ac4:	4b4d      	ldr	r3, [pc, #308]	; (8008bfc <HAL_RCC_ClockConfig+0x1a0>)
 8008ac6:	685b      	ldr	r3, [r3, #4]
 8008ac8:	22f0      	movs	r2, #240	; 0xf0
 8008aca:	4393      	bics	r3, r2
 8008acc:	0019      	movs	r1, r3
 8008ace:	687b      	ldr	r3, [r7, #4]
 8008ad0:	689a      	ldr	r2, [r3, #8]
 8008ad2:	4b4a      	ldr	r3, [pc, #296]	; (8008bfc <HAL_RCC_ClockConfig+0x1a0>)
 8008ad4:	430a      	orrs	r2, r1
 8008ad6:	605a      	str	r2, [r3, #4]
  }

  /*------------------------- SYSCLK Configuration ---------------------------*/ 
  if(((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_SYSCLK) == RCC_CLOCKTYPE_SYSCLK)
 8008ad8:	687b      	ldr	r3, [r7, #4]
 8008ada:	681b      	ldr	r3, [r3, #0]
 8008adc:	2201      	movs	r2, #1
 8008ade:	4013      	ands	r3, r2
 8008ae0:	d04c      	beq.n	8008b7c <HAL_RCC_ClockConfig+0x120>
  {
    assert_param(IS_RCC_SYSCLKSOURCE(RCC_ClkInitStruct->SYSCLKSource));
    
    /* HSE is selected as System Clock Source */
    if(RCC_ClkInitStruct->SYSCLKSource == RCC_SYSCLKSOURCE_HSE)
 8008ae2:	687b      	ldr	r3, [r7, #4]
 8008ae4:	685b      	ldr	r3, [r3, #4]
 8008ae6:	2b01      	cmp	r3, #1
 8008ae8:	d107      	bne.n	8008afa <HAL_RCC_ClockConfig+0x9e>
    {
      /* Check the HSE ready flag */  
      if(__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) == RESET)
 8008aea:	4b44      	ldr	r3, [pc, #272]	; (8008bfc <HAL_RCC_ClockConfig+0x1a0>)
 8008aec:	681a      	ldr	r2, [r3, #0]
 8008aee:	2380      	movs	r3, #128	; 0x80
 8008af0:	029b      	lsls	r3, r3, #10
 8008af2:	4013      	ands	r3, r2
 8008af4:	d120      	bne.n	8008b38 <HAL_RCC_ClockConfig+0xdc>
      {
        return HAL_ERROR;
 8008af6:	2301      	movs	r3, #1
 8008af8:	e07a      	b.n	8008bf0 <HAL_RCC_ClockConfig+0x194>
      }
    }
    /* PLL is selected as System Clock Source */
    else if(RCC_ClkInitStruct->SYSCLKSource == RCC_SYSCLKSOURCE_PLLCLK)
 8008afa:	687b      	ldr	r3, [r7, #4]
 8008afc:	685b      	ldr	r3, [r3, #4]
 8008afe:	2b02      	cmp	r3, #2
 8008b00:	d107      	bne.n	8008b12 <HAL_RCC_ClockConfig+0xb6>
    {
      /* Check the PLL ready flag */  
      if(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) == RESET)
 8008b02:	4b3e      	ldr	r3, [pc, #248]	; (8008bfc <HAL_RCC_ClockConfig+0x1a0>)
 8008b04:	681a      	ldr	r2, [r3, #0]
 8008b06:	2380      	movs	r3, #128	; 0x80
 8008b08:	049b      	lsls	r3, r3, #18
 8008b0a:	4013      	ands	r3, r2
 8008b0c:	d114      	bne.n	8008b38 <HAL_RCC_ClockConfig+0xdc>
      {
        return HAL_ERROR;
 8008b0e:	2301      	movs	r3, #1
 8008b10:	e06e      	b.n	8008bf0 <HAL_RCC_ClockConfig+0x194>
      }
    }
#if defined(RCC_CFGR_SWS_HSI48)
    /* HSI48 is selected as System Clock Source */
    else if(RCC_ClkInitStruct->SYSCLKSource == RCC_SYSCLKSOURCE_HSI48)
 8008b12:	687b      	ldr	r3, [r7, #4]
 8008b14:	685b      	ldr	r3, [r3, #4]
 8008b16:	2b03      	cmp	r3, #3
 8008b18:	d107      	bne.n	8008b2a <HAL_RCC_ClockConfig+0xce>
    {
      /* Check the HSI48 ready flag */
      if(__HAL_RCC_GET_FLAG(RCC_FLAG_HSI48RDY) == RESET)
 8008b1a:	4b38      	ldr	r3, [pc, #224]	; (8008bfc <HAL_RCC_ClockConfig+0x1a0>)
 8008b1c:	6b5a      	ldr	r2, [r3, #52]	; 0x34
 8008b1e:	2380      	movs	r3, #128	; 0x80
 8008b20:	025b      	lsls	r3, r3, #9
 8008b22:	4013      	ands	r3, r2
 8008b24:	d108      	bne.n	8008b38 <HAL_RCC_ClockConfig+0xdc>
      {
        return HAL_ERROR;
 8008b26:	2301      	movs	r3, #1
 8008b28:	e062      	b.n	8008bf0 <HAL_RCC_ClockConfig+0x194>
#endif /* RCC_CFGR_SWS_HSI48 */
    /* HSI is selected as System Clock Source */
    else
    {
      /* Check the HSI ready flag */  
      if(__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) == RESET)
 8008b2a:	4b34      	ldr	r3, [pc, #208]	; (8008bfc <HAL_RCC_ClockConfig+0x1a0>)
 8008b2c:	681b      	ldr	r3, [r3, #0]
 8008b2e:	2202      	movs	r2, #2
 8008b30:	4013      	ands	r3, r2
 8008b32:	d101      	bne.n	8008b38 <HAL_RCC_ClockConfig+0xdc>
      {
        return HAL_ERROR;
 8008b34:	2301      	movs	r3, #1
 8008b36:	e05b      	b.n	8008bf0 <HAL_RCC_ClockConfig+0x194>
      }
    }
    __HAL_RCC_SYSCLK_CONFIG(RCC_ClkInitStruct->SYSCLKSource);
 8008b38:	4b30      	ldr	r3, [pc, #192]	; (8008bfc <HAL_RCC_ClockConfig+0x1a0>)
 8008b3a:	685b      	ldr	r3, [r3, #4]
 8008b3c:	2203      	movs	r2, #3
 8008b3e:	4393      	bics	r3, r2
 8008b40:	0019      	movs	r1, r3
 8008b42:	687b      	ldr	r3, [r7, #4]
 8008b44:	685a      	ldr	r2, [r3, #4]
 8008b46:	4b2d      	ldr	r3, [pc, #180]	; (8008bfc <HAL_RCC_ClockConfig+0x1a0>)
 8008b48:	430a      	orrs	r2, r1
 8008b4a:	605a      	str	r2, [r3, #4]

    /* Get Start Tick */
    tickstart = HAL_GetTick();
 8008b4c:	f7fc ff02 	bl	8005954 <HAL_GetTick>
 8008b50:	0003      	movs	r3, r0
 8008b52:	60fb      	str	r3, [r7, #12]
    
    while (__HAL_RCC_GET_SYSCLK_SOURCE() != (RCC_ClkInitStruct->SYSCLKSource << RCC_CFGR_SWS_Pos))
 8008b54:	e009      	b.n	8008b6a <HAL_RCC_ClockConfig+0x10e>
    {
      if((HAL_GetTick() - tickstart ) > CLOCKSWITCH_TIMEOUT_VALUE)
 8008b56:	f7fc fefd 	bl	8005954 <HAL_GetTick>
 8008b5a:	0002      	movs	r2, r0
 8008b5c:	68fb      	ldr	r3, [r7, #12]
 8008b5e:	1ad3      	subs	r3, r2, r3
 8008b60:	4a27      	ldr	r2, [pc, #156]	; (8008c00 <HAL_RCC_ClockConfig+0x1a4>)
 8008b62:	4293      	cmp	r3, r2
 8008b64:	d901      	bls.n	8008b6a <HAL_RCC_ClockConfig+0x10e>
      {
        return HAL_TIMEOUT;
 8008b66:	2303      	movs	r3, #3
 8008b68:	e042      	b.n	8008bf0 <HAL_RCC_ClockConfig+0x194>
    while (__HAL_RCC_GET_SYSCLK_SOURCE() != (RCC_ClkInitStruct->SYSCLKSource << RCC_CFGR_SWS_Pos))
 8008b6a:	4b24      	ldr	r3, [pc, #144]	; (8008bfc <HAL_RCC_ClockConfig+0x1a0>)
 8008b6c:	685b      	ldr	r3, [r3, #4]
 8008b6e:	220c      	movs	r2, #12
 8008b70:	401a      	ands	r2, r3
 8008b72:	687b      	ldr	r3, [r7, #4]
 8008b74:	685b      	ldr	r3, [r3, #4]
 8008b76:	009b      	lsls	r3, r3, #2
 8008b78:	429a      	cmp	r2, r3
 8008b7a:	d1ec      	bne.n	8008b56 <HAL_RCC_ClockConfig+0xfa>
      }
    }
  }

  /* Decreasing the number of wait states because of lower CPU frequency */
  if(FLatency < __HAL_FLASH_GET_LATENCY())
 8008b7c:	4b1e      	ldr	r3, [pc, #120]	; (8008bf8 <HAL_RCC_ClockConfig+0x19c>)
 8008b7e:	681b      	ldr	r3, [r3, #0]
 8008b80:	2201      	movs	r2, #1
 8008b82:	4013      	ands	r3, r2
 8008b84:	683a      	ldr	r2, [r7, #0]
 8008b86:	429a      	cmp	r2, r3
 8008b88:	d211      	bcs.n	8008bae <HAL_RCC_ClockConfig+0x152>
  {    
    /* Program the new number of wait states to the LATENCY bits in the FLASH_ACR register */
    __HAL_FLASH_SET_LATENCY(FLatency);
 8008b8a:	4b1b      	ldr	r3, [pc, #108]	; (8008bf8 <HAL_RCC_ClockConfig+0x19c>)
 8008b8c:	681b      	ldr	r3, [r3, #0]
 8008b8e:	2201      	movs	r2, #1
 8008b90:	4393      	bics	r3, r2
 8008b92:	0019      	movs	r1, r3
 8008b94:	4b18      	ldr	r3, [pc, #96]	; (8008bf8 <HAL_RCC_ClockConfig+0x19c>)
 8008b96:	683a      	ldr	r2, [r7, #0]
 8008b98:	430a      	orrs	r2, r1
 8008b9a:	601a      	str	r2, [r3, #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)
 8008b9c:	4b16      	ldr	r3, [pc, #88]	; (8008bf8 <HAL_RCC_ClockConfig+0x19c>)
 8008b9e:	681b      	ldr	r3, [r3, #0]
 8008ba0:	2201      	movs	r2, #1
 8008ba2:	4013      	ands	r3, r2
 8008ba4:	683a      	ldr	r2, [r7, #0]
 8008ba6:	429a      	cmp	r2, r3
 8008ba8:	d001      	beq.n	8008bae <HAL_RCC_ClockConfig+0x152>
    {
      return HAL_ERROR;
 8008baa:	2301      	movs	r3, #1
 8008bac:	e020      	b.n	8008bf0 <HAL_RCC_ClockConfig+0x194>
    }
  }    

  /*-------------------------- PCLK1 Configuration ---------------------------*/ 
  if(((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_PCLK1) == RCC_CLOCKTYPE_PCLK1)
 8008bae:	687b      	ldr	r3, [r7, #4]
 8008bb0:	681b      	ldr	r3, [r3, #0]
 8008bb2:	2204      	movs	r2, #4
 8008bb4:	4013      	ands	r3, r2
 8008bb6:	d009      	beq.n	8008bcc <HAL_RCC_ClockConfig+0x170>
  {
    assert_param(IS_RCC_PCLK(RCC_ClkInitStruct->APB1CLKDivider));
    MODIFY_REG(RCC->CFGR, RCC_CFGR_PPRE, RCC_ClkInitStruct->APB1CLKDivider);
 8008bb8:	4b10      	ldr	r3, [pc, #64]	; (8008bfc <HAL_RCC_ClockConfig+0x1a0>)
 8008bba:	685b      	ldr	r3, [r3, #4]
 8008bbc:	4a11      	ldr	r2, [pc, #68]	; (8008c04 <HAL_RCC_ClockConfig+0x1a8>)
 8008bbe:	4013      	ands	r3, r2
 8008bc0:	0019      	movs	r1, r3
 8008bc2:	687b      	ldr	r3, [r7, #4]
 8008bc4:	68da      	ldr	r2, [r3, #12]
 8008bc6:	4b0d      	ldr	r3, [pc, #52]	; (8008bfc <HAL_RCC_ClockConfig+0x1a0>)
 8008bc8:	430a      	orrs	r2, r1
 8008bca:	605a      	str	r2, [r3, #4]
  }
  
  /* Update the SystemCoreClock global variable */
  SystemCoreClock = HAL_RCC_GetSysClockFreq() >> AHBPrescTable[(RCC->CFGR & RCC_CFGR_HPRE)>> RCC_CFGR_HPRE_BITNUMBER];
 8008bcc:	f000 f820 	bl	8008c10 <HAL_RCC_GetSysClockFreq>
 8008bd0:	0001      	movs	r1, r0
 8008bd2:	4b0a      	ldr	r3, [pc, #40]	; (8008bfc <HAL_RCC_ClockConfig+0x1a0>)
 8008bd4:	685b      	ldr	r3, [r3, #4]
 8008bd6:	091b      	lsrs	r3, r3, #4
 8008bd8:	220f      	movs	r2, #15
 8008bda:	4013      	ands	r3, r2
 8008bdc:	4a0a      	ldr	r2, [pc, #40]	; (8008c08 <HAL_RCC_ClockConfig+0x1ac>)
 8008bde:	5cd3      	ldrb	r3, [r2, r3]
 8008be0:	000a      	movs	r2, r1
 8008be2:	40da      	lsrs	r2, r3
 8008be4:	4b09      	ldr	r3, [pc, #36]	; (8008c0c <HAL_RCC_ClockConfig+0x1b0>)
 8008be6:	601a      	str	r2, [r3, #0]

  /* Configure the source of time base considering new system clocks settings*/
  HAL_InitTick (TICK_INT_PRIORITY);
 8008be8:	2003      	movs	r0, #3
 8008bea:	f7fc fe6d 	bl	80058c8 <HAL_InitTick>
  
  return HAL_OK;
 8008bee:	2300      	movs	r3, #0
}
 8008bf0:	0018      	movs	r0, r3
 8008bf2:	46bd      	mov	sp, r7
 8008bf4:	b004      	add	sp, #16
 8008bf6:	bd80      	pop	{r7, pc}
 8008bf8:	40022000 	.word	0x40022000
 8008bfc:	40021000 	.word	0x40021000
 8008c00:	00001388 	.word	0x00001388
 8008c04:	fffff8ff 	.word	0xfffff8ff
 8008c08:	0800f0a4 	.word	0x0800f0a4
 8008c0c:	2000007c 	.word	0x2000007c

08008c10 <HAL_RCC_GetSysClockFreq>:
  *         right SYSCLK value. Otherwise, any configuration based on this function will be incorrect.
  *         
  * @retval SYSCLK frequency
  */
uint32_t HAL_RCC_GetSysClockFreq(void)
{
 8008c10:	b590      	push	{r4, r7, lr}
 8008c12:	b08f      	sub	sp, #60	; 0x3c
 8008c14:	af00      	add	r7, sp, #0
  const uint8_t aPLLMULFactorTable[16] = { 2U,  3U,  4U,  5U,  6U,  7U,  8U,  9U,
 8008c16:	2314      	movs	r3, #20
 8008c18:	18fb      	adds	r3, r7, r3
 8008c1a:	4a38      	ldr	r2, [pc, #224]	; (8008cfc <HAL_RCC_GetSysClockFreq+0xec>)
 8008c1c:	ca13      	ldmia	r2!, {r0, r1, r4}
 8008c1e:	c313      	stmia	r3!, {r0, r1, r4}
 8008c20:	6812      	ldr	r2, [r2, #0]
 8008c22:	601a      	str	r2, [r3, #0]
                                         10U, 11U, 12U, 13U, 14U, 15U, 16U, 16U};
  const uint8_t aPredivFactorTable[16] = { 1U, 2U,  3U,  4U,  5U,  6U,  7U,  8U,
 8008c24:	1d3b      	adds	r3, r7, #4
 8008c26:	4a36      	ldr	r2, [pc, #216]	; (8008d00 <HAL_RCC_GetSysClockFreq+0xf0>)
 8008c28:	ca13      	ldmia	r2!, {r0, r1, r4}
 8008c2a:	c313      	stmia	r3!, {r0, r1, r4}
 8008c2c:	6812      	ldr	r2, [r2, #0]
 8008c2e:	601a      	str	r2, [r3, #0]
                                           9U,10U, 11U, 12U, 13U, 14U, 15U, 16U};

  uint32_t tmpreg = 0U, prediv = 0U, pllclk = 0U, pllmul = 0U;
 8008c30:	2300      	movs	r3, #0
 8008c32:	62fb      	str	r3, [r7, #44]	; 0x2c
 8008c34:	2300      	movs	r3, #0
 8008c36:	62bb      	str	r3, [r7, #40]	; 0x28
 8008c38:	2300      	movs	r3, #0
 8008c3a:	637b      	str	r3, [r7, #52]	; 0x34
 8008c3c:	2300      	movs	r3, #0
 8008c3e:	627b      	str	r3, [r7, #36]	; 0x24
  uint32_t sysclockfreq = 0U;
 8008c40:	2300      	movs	r3, #0
 8008c42:	633b      	str	r3, [r7, #48]	; 0x30
  
  tmpreg = RCC->CFGR;
 8008c44:	4b2f      	ldr	r3, [pc, #188]	; (8008d04 <HAL_RCC_GetSysClockFreq+0xf4>)
 8008c46:	685b      	ldr	r3, [r3, #4]
 8008c48:	62fb      	str	r3, [r7, #44]	; 0x2c
  
  /* Get SYSCLK source -------------------------------------------------------*/
  switch (tmpreg & RCC_CFGR_SWS)
 8008c4a:	6afb      	ldr	r3, [r7, #44]	; 0x2c
 8008c4c:	220c      	movs	r2, #12
 8008c4e:	4013      	ands	r3, r2
 8008c50:	2b0c      	cmp	r3, #12
 8008c52:	d047      	beq.n	8008ce4 <HAL_RCC_GetSysClockFreq+0xd4>
 8008c54:	d849      	bhi.n	8008cea <HAL_RCC_GetSysClockFreq+0xda>
 8008c56:	2b04      	cmp	r3, #4
 8008c58:	d002      	beq.n	8008c60 <HAL_RCC_GetSysClockFreq+0x50>
 8008c5a:	2b08      	cmp	r3, #8
 8008c5c:	d003      	beq.n	8008c66 <HAL_RCC_GetSysClockFreq+0x56>
 8008c5e:	e044      	b.n	8008cea <HAL_RCC_GetSysClockFreq+0xda>
  {
    case RCC_SYSCLKSOURCE_STATUS_HSE:  /* HSE used as system clock */
    {
      sysclockfreq = HSE_VALUE;
 8008c60:	4b29      	ldr	r3, [pc, #164]	; (8008d08 <HAL_RCC_GetSysClockFreq+0xf8>)
 8008c62:	633b      	str	r3, [r7, #48]	; 0x30
      break;
 8008c64:	e044      	b.n	8008cf0 <HAL_RCC_GetSysClockFreq+0xe0>
    }
    case RCC_SYSCLKSOURCE_STATUS_PLLCLK:  /* PLL used as system clock */
    {
      pllmul = aPLLMULFactorTable[(uint32_t)(tmpreg & RCC_CFGR_PLLMUL) >> RCC_CFGR_PLLMUL_BITNUMBER];
 8008c66:	6afb      	ldr	r3, [r7, #44]	; 0x2c
 8008c68:	0c9b      	lsrs	r3, r3, #18
 8008c6a:	220f      	movs	r2, #15
 8008c6c:	4013      	ands	r3, r2
 8008c6e:	2214      	movs	r2, #20
 8008c70:	18ba      	adds	r2, r7, r2
 8008c72:	5cd3      	ldrb	r3, [r2, r3]
 8008c74:	627b      	str	r3, [r7, #36]	; 0x24
      prediv = aPredivFactorTable[(uint32_t)(RCC->CFGR2 & RCC_CFGR2_PREDIV) >> RCC_CFGR2_PREDIV_BITNUMBER];
 8008c76:	4b23      	ldr	r3, [pc, #140]	; (8008d04 <HAL_RCC_GetSysClockFreq+0xf4>)
 8008c78:	6adb      	ldr	r3, [r3, #44]	; 0x2c
 8008c7a:	220f      	movs	r2, #15
 8008c7c:	4013      	ands	r3, r2
 8008c7e:	1d3a      	adds	r2, r7, #4
 8008c80:	5cd3      	ldrb	r3, [r2, r3]
 8008c82:	62bb      	str	r3, [r7, #40]	; 0x28
      if ((tmpreg & RCC_CFGR_PLLSRC) == RCC_PLLSOURCE_HSE)
 8008c84:	6afa      	ldr	r2, [r7, #44]	; 0x2c
 8008c86:	23c0      	movs	r3, #192	; 0xc0
 8008c88:	025b      	lsls	r3, r3, #9
 8008c8a:	401a      	ands	r2, r3
 8008c8c:	2380      	movs	r3, #128	; 0x80
 8008c8e:	025b      	lsls	r3, r3, #9
 8008c90:	429a      	cmp	r2, r3
 8008c92:	d109      	bne.n	8008ca8 <HAL_RCC_GetSysClockFreq+0x98>
      {
        /* HSE used as PLL clock source : PLLCLK = HSE/PREDIV * PLLMUL */
        pllclk = (uint32_t)((uint64_t) HSE_VALUE / (uint64_t) (prediv)) * ((uint64_t) pllmul);
 8008c94:	6ab9      	ldr	r1, [r7, #40]	; 0x28
 8008c96:	481c      	ldr	r0, [pc, #112]	; (8008d08 <HAL_RCC_GetSysClockFreq+0xf8>)
 8008c98:	f7f7 fa34 	bl	8000104 <__udivsi3>
 8008c9c:	0003      	movs	r3, r0
 8008c9e:	001a      	movs	r2, r3
 8008ca0:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 8008ca2:	4353      	muls	r3, r2
 8008ca4:	637b      	str	r3, [r7, #52]	; 0x34
 8008ca6:	e01a      	b.n	8008cde <HAL_RCC_GetSysClockFreq+0xce>
      }
#if defined(RCC_CFGR_PLLSRC_HSI48_PREDIV)
      else if ((tmpreg & RCC_CFGR_PLLSRC) == RCC_PLLSOURCE_HSI48)
 8008ca8:	6afa      	ldr	r2, [r7, #44]	; 0x2c
 8008caa:	23c0      	movs	r3, #192	; 0xc0
 8008cac:	025b      	lsls	r3, r3, #9
 8008cae:	401a      	ands	r2, r3
 8008cb0:	23c0      	movs	r3, #192	; 0xc0
 8008cb2:	025b      	lsls	r3, r3, #9
 8008cb4:	429a      	cmp	r2, r3
 8008cb6:	d109      	bne.n	8008ccc <HAL_RCC_GetSysClockFreq+0xbc>
      {
        /* HSI48 used as PLL clock source : PLLCLK = HSI48/PREDIV * PLLMUL */
        pllclk = (uint32_t)((uint64_t) HSI48_VALUE / (uint64_t) (prediv)) * ((uint64_t) pllmul);
 8008cb8:	6ab9      	ldr	r1, [r7, #40]	; 0x28
 8008cba:	4814      	ldr	r0, [pc, #80]	; (8008d0c <HAL_RCC_GetSysClockFreq+0xfc>)
 8008cbc:	f7f7 fa22 	bl	8000104 <__udivsi3>
 8008cc0:	0003      	movs	r3, r0
 8008cc2:	001a      	movs	r2, r3
 8008cc4:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 8008cc6:	4353      	muls	r3, r2
 8008cc8:	637b      	str	r3, [r7, #52]	; 0x34
 8008cca:	e008      	b.n	8008cde <HAL_RCC_GetSysClockFreq+0xce>
#endif /* RCC_CFGR_PLLSRC_HSI48_PREDIV */
      else
      {
#if  (defined(STM32F042x6) || defined(STM32F048xx) || defined(STM32F070x6) || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx) || defined(STM32F070xB) || defined(STM32F091xC) || defined(STM32F098xx) || defined(STM32F030xC))
        /* HSI used as PLL clock source : PLLCLK = HSI/PREDIV * PLLMUL */
        pllclk = (uint32_t)((uint64_t) HSI_VALUE / (uint64_t) (prediv)) * ((uint64_t) pllmul);
 8008ccc:	6ab9      	ldr	r1, [r7, #40]	; 0x28
 8008cce:	480e      	ldr	r0, [pc, #56]	; (8008d08 <HAL_RCC_GetSysClockFreq+0xf8>)
 8008cd0:	f7f7 fa18 	bl	8000104 <__udivsi3>
 8008cd4:	0003      	movs	r3, r0
 8008cd6:	001a      	movs	r2, r3
 8008cd8:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 8008cda:	4353      	muls	r3, r2
 8008cdc:	637b      	str	r3, [r7, #52]	; 0x34
#else
        /* HSI used as PLL clock source : PLLCLK = HSI/2 * PLLMUL */
        pllclk = (uint32_t)((uint64_t) (HSI_VALUE >> 1U) * ((uint64_t) pllmul));
#endif
      }
      sysclockfreq = pllclk;
 8008cde:	6b7b      	ldr	r3, [r7, #52]	; 0x34
 8008ce0:	633b      	str	r3, [r7, #48]	; 0x30
      break;
 8008ce2:	e005      	b.n	8008cf0 <HAL_RCC_GetSysClockFreq+0xe0>
    }
#if defined(RCC_CFGR_SWS_HSI48)
    case RCC_SYSCLKSOURCE_STATUS_HSI48:    /* HSI48 used as system clock source */
    {
      sysclockfreq = HSI48_VALUE;
 8008ce4:	4b09      	ldr	r3, [pc, #36]	; (8008d0c <HAL_RCC_GetSysClockFreq+0xfc>)
 8008ce6:	633b      	str	r3, [r7, #48]	; 0x30
      break;
 8008ce8:	e002      	b.n	8008cf0 <HAL_RCC_GetSysClockFreq+0xe0>
    }
#endif /* RCC_CFGR_SWS_HSI48 */
    case RCC_SYSCLKSOURCE_STATUS_HSI:  /* HSI used as system clock source */
    default: /* HSI used as system clock */
    {
      sysclockfreq = HSI_VALUE;
 8008cea:	4b07      	ldr	r3, [pc, #28]	; (8008d08 <HAL_RCC_GetSysClockFreq+0xf8>)
 8008cec:	633b      	str	r3, [r7, #48]	; 0x30
      break;
 8008cee:	46c0      	nop			; (mov r8, r8)
    }
  }
  return sysclockfreq;
 8008cf0:	6b3b      	ldr	r3, [r7, #48]	; 0x30
}
 8008cf2:	0018      	movs	r0, r3
 8008cf4:	46bd      	mov	sp, r7
 8008cf6:	b00f      	add	sp, #60	; 0x3c
 8008cf8:	bd90      	pop	{r4, r7, pc}
 8008cfa:	46c0      	nop			; (mov r8, r8)
 8008cfc:	0800e4e0 	.word	0x0800e4e0
 8008d00:	0800e4f0 	.word	0x0800e4f0
 8008d04:	40021000 	.word	0x40021000
 8008d08:	007a1200 	.word	0x007a1200
 8008d0c:	02dc6c00 	.word	0x02dc6c00

08008d10 <HAL_RCCEx_PeriphCLKConfig>:
  *         the backup registers) and RCC_BDCR register are set to their reset values.
  *
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_RCCEx_PeriphCLKConfig(RCC_PeriphCLKInitTypeDef  *PeriphClkInit)
{
 8008d10:	b580      	push	{r7, lr}
 8008d12:	b086      	sub	sp, #24
 8008d14:	af00      	add	r7, sp, #0
 8008d16:	6078      	str	r0, [r7, #4]
  uint32_t tickstart = 0U;
 8008d18:	2300      	movs	r3, #0
 8008d1a:	613b      	str	r3, [r7, #16]
  uint32_t temp_reg = 0U;
 8008d1c:	2300      	movs	r3, #0
 8008d1e:	60fb      	str	r3, [r7, #12]

  /* Check the parameters */
  assert_param(IS_RCC_PERIPHCLOCK(PeriphClkInit->PeriphClockSelection));
  
  /*---------------------------- RTC configuration -------------------------------*/
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_RTC) == (RCC_PERIPHCLK_RTC))
 8008d20:	687b      	ldr	r3, [r7, #4]
 8008d22:	681a      	ldr	r2, [r3, #0]
 8008d24:	2380      	movs	r3, #128	; 0x80
 8008d26:	025b      	lsls	r3, r3, #9
 8008d28:	4013      	ands	r3, r2
 8008d2a:	d100      	bne.n	8008d2e <HAL_RCCEx_PeriphCLKConfig+0x1e>
 8008d2c:	e08e      	b.n	8008e4c <HAL_RCCEx_PeriphCLKConfig+0x13c>
  {
    /* check for RTC Parameters used to output RTCCLK */
    assert_param(IS_RCC_RTCCLKSOURCE(PeriphClkInit->RTCClockSelection));
    
    FlagStatus       pwrclkchanged = RESET;
 8008d2e:	2017      	movs	r0, #23
 8008d30:	183b      	adds	r3, r7, r0
 8008d32:	2200      	movs	r2, #0
 8008d34:	701a      	strb	r2, [r3, #0]

    /* As soon as function is called to change RTC clock source, activation of the 
       power domain is done. */
    /* Requires to enable write access to Backup Domain of necessary */
    if(__HAL_RCC_PWR_IS_CLK_DISABLED())
 8008d36:	4b6e      	ldr	r3, [pc, #440]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008d38:	69da      	ldr	r2, [r3, #28]
 8008d3a:	2380      	movs	r3, #128	; 0x80
 8008d3c:	055b      	lsls	r3, r3, #21
 8008d3e:	4013      	ands	r3, r2
 8008d40:	d110      	bne.n	8008d64 <HAL_RCCEx_PeriphCLKConfig+0x54>
    {
    __HAL_RCC_PWR_CLK_ENABLE();
 8008d42:	4b6b      	ldr	r3, [pc, #428]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008d44:	69da      	ldr	r2, [r3, #28]
 8008d46:	4b6a      	ldr	r3, [pc, #424]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008d48:	2180      	movs	r1, #128	; 0x80
 8008d4a:	0549      	lsls	r1, r1, #21
 8008d4c:	430a      	orrs	r2, r1
 8008d4e:	61da      	str	r2, [r3, #28]
 8008d50:	4b67      	ldr	r3, [pc, #412]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008d52:	69da      	ldr	r2, [r3, #28]
 8008d54:	2380      	movs	r3, #128	; 0x80
 8008d56:	055b      	lsls	r3, r3, #21
 8008d58:	4013      	ands	r3, r2
 8008d5a:	60bb      	str	r3, [r7, #8]
 8008d5c:	68bb      	ldr	r3, [r7, #8]
      pwrclkchanged = SET;
 8008d5e:	183b      	adds	r3, r7, r0
 8008d60:	2201      	movs	r2, #1
 8008d62:	701a      	strb	r2, [r3, #0]
    }
    
    if(HAL_IS_BIT_CLR(PWR->CR, PWR_CR_DBP))
 8008d64:	4b63      	ldr	r3, [pc, #396]	; (8008ef4 <HAL_RCCEx_PeriphCLKConfig+0x1e4>)
 8008d66:	681a      	ldr	r2, [r3, #0]
 8008d68:	2380      	movs	r3, #128	; 0x80
 8008d6a:	005b      	lsls	r3, r3, #1
 8008d6c:	4013      	ands	r3, r2
 8008d6e:	d11a      	bne.n	8008da6 <HAL_RCCEx_PeriphCLKConfig+0x96>
    {
      /* Enable write access to Backup domain */
      SET_BIT(PWR->CR, PWR_CR_DBP);
 8008d70:	4b60      	ldr	r3, [pc, #384]	; (8008ef4 <HAL_RCCEx_PeriphCLKConfig+0x1e4>)
 8008d72:	681a      	ldr	r2, [r3, #0]
 8008d74:	4b5f      	ldr	r3, [pc, #380]	; (8008ef4 <HAL_RCCEx_PeriphCLKConfig+0x1e4>)
 8008d76:	2180      	movs	r1, #128	; 0x80
 8008d78:	0049      	lsls	r1, r1, #1
 8008d7a:	430a      	orrs	r2, r1
 8008d7c:	601a      	str	r2, [r3, #0]
      
      /* Wait for Backup domain Write protection disable */
      tickstart = HAL_GetTick();
 8008d7e:	f7fc fde9 	bl	8005954 <HAL_GetTick>
 8008d82:	0003      	movs	r3, r0
 8008d84:	613b      	str	r3, [r7, #16]
      
      while(HAL_IS_BIT_CLR(PWR->CR, PWR_CR_DBP))
 8008d86:	e008      	b.n	8008d9a <HAL_RCCEx_PeriphCLKConfig+0x8a>
      {
        if((HAL_GetTick() - tickstart) > RCC_DBP_TIMEOUT_VALUE)
 8008d88:	f7fc fde4 	bl	8005954 <HAL_GetTick>
 8008d8c:	0002      	movs	r2, r0
 8008d8e:	693b      	ldr	r3, [r7, #16]
 8008d90:	1ad3      	subs	r3, r2, r3
 8008d92:	2b64      	cmp	r3, #100	; 0x64
 8008d94:	d901      	bls.n	8008d9a <HAL_RCCEx_PeriphCLKConfig+0x8a>
        {
          return HAL_TIMEOUT;
 8008d96:	2303      	movs	r3, #3
 8008d98:	e0a6      	b.n	8008ee8 <HAL_RCCEx_PeriphCLKConfig+0x1d8>
      while(HAL_IS_BIT_CLR(PWR->CR, PWR_CR_DBP))
 8008d9a:	4b56      	ldr	r3, [pc, #344]	; (8008ef4 <HAL_RCCEx_PeriphCLKConfig+0x1e4>)
 8008d9c:	681a      	ldr	r2, [r3, #0]
 8008d9e:	2380      	movs	r3, #128	; 0x80
 8008da0:	005b      	lsls	r3, r3, #1
 8008da2:	4013      	ands	r3, r2
 8008da4:	d0f0      	beq.n	8008d88 <HAL_RCCEx_PeriphCLKConfig+0x78>
        }
      }
    }
    
    /* Reset the Backup domain only if the RTC Clock source selection is modified from reset value */ 
    temp_reg = (RCC->BDCR & RCC_BDCR_RTCSEL);
 8008da6:	4b52      	ldr	r3, [pc, #328]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008da8:	6a1a      	ldr	r2, [r3, #32]
 8008daa:	23c0      	movs	r3, #192	; 0xc0
 8008dac:	009b      	lsls	r3, r3, #2
 8008dae:	4013      	ands	r3, r2
 8008db0:	60fb      	str	r3, [r7, #12]
    if((temp_reg != 0x00000000U) && (temp_reg != (PeriphClkInit->RTCClockSelection & RCC_BDCR_RTCSEL)))
 8008db2:	68fb      	ldr	r3, [r7, #12]
 8008db4:	2b00      	cmp	r3, #0
 8008db6:	d034      	beq.n	8008e22 <HAL_RCCEx_PeriphCLKConfig+0x112>
 8008db8:	687b      	ldr	r3, [r7, #4]
 8008dba:	685a      	ldr	r2, [r3, #4]
 8008dbc:	23c0      	movs	r3, #192	; 0xc0
 8008dbe:	009b      	lsls	r3, r3, #2
 8008dc0:	4013      	ands	r3, r2
 8008dc2:	68fa      	ldr	r2, [r7, #12]
 8008dc4:	429a      	cmp	r2, r3
 8008dc6:	d02c      	beq.n	8008e22 <HAL_RCCEx_PeriphCLKConfig+0x112>
    {
      /* Store the content of BDCR register before the reset of Backup Domain */
      temp_reg = (RCC->BDCR & ~(RCC_BDCR_RTCSEL));
 8008dc8:	4b49      	ldr	r3, [pc, #292]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008dca:	6a1b      	ldr	r3, [r3, #32]
 8008dcc:	4a4a      	ldr	r2, [pc, #296]	; (8008ef8 <HAL_RCCEx_PeriphCLKConfig+0x1e8>)
 8008dce:	4013      	ands	r3, r2
 8008dd0:	60fb      	str	r3, [r7, #12]
      /* RTC Clock selection can be changed only if the Backup Domain is reset */
      __HAL_RCC_BACKUPRESET_FORCE();
 8008dd2:	4b47      	ldr	r3, [pc, #284]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008dd4:	6a1a      	ldr	r2, [r3, #32]
 8008dd6:	4b46      	ldr	r3, [pc, #280]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008dd8:	2180      	movs	r1, #128	; 0x80
 8008dda:	0249      	lsls	r1, r1, #9
 8008ddc:	430a      	orrs	r2, r1
 8008dde:	621a      	str	r2, [r3, #32]
      __HAL_RCC_BACKUPRESET_RELEASE();
 8008de0:	4b43      	ldr	r3, [pc, #268]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008de2:	6a1a      	ldr	r2, [r3, #32]
 8008de4:	4b42      	ldr	r3, [pc, #264]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008de6:	4945      	ldr	r1, [pc, #276]	; (8008efc <HAL_RCCEx_PeriphCLKConfig+0x1ec>)
 8008de8:	400a      	ands	r2, r1
 8008dea:	621a      	str	r2, [r3, #32]
      /* Restore the Content of BDCR register */
      RCC->BDCR = temp_reg;
 8008dec:	4b40      	ldr	r3, [pc, #256]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008dee:	68fa      	ldr	r2, [r7, #12]
 8008df0:	621a      	str	r2, [r3, #32]
      
      /* Wait for LSERDY if LSE was enabled */
      if (HAL_IS_BIT_SET(temp_reg, RCC_BDCR_LSEON))
 8008df2:	68fb      	ldr	r3, [r7, #12]
 8008df4:	2201      	movs	r2, #1
 8008df6:	4013      	ands	r3, r2
 8008df8:	d013      	beq.n	8008e22 <HAL_RCCEx_PeriphCLKConfig+0x112>
      {
        /* Get Start Tick */
        tickstart = HAL_GetTick();
 8008dfa:	f7fc fdab 	bl	8005954 <HAL_GetTick>
 8008dfe:	0003      	movs	r3, r0
 8008e00:	613b      	str	r3, [r7, #16]
        
        /* Wait till LSE is ready */  
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) == RESET)
 8008e02:	e009      	b.n	8008e18 <HAL_RCCEx_PeriphCLKConfig+0x108>
        {
          if((HAL_GetTick() - tickstart) > RCC_LSE_TIMEOUT_VALUE)
 8008e04:	f7fc fda6 	bl	8005954 <HAL_GetTick>
 8008e08:	0002      	movs	r2, r0
 8008e0a:	693b      	ldr	r3, [r7, #16]
 8008e0c:	1ad3      	subs	r3, r2, r3
 8008e0e:	4a3c      	ldr	r2, [pc, #240]	; (8008f00 <HAL_RCCEx_PeriphCLKConfig+0x1f0>)
 8008e10:	4293      	cmp	r3, r2
 8008e12:	d901      	bls.n	8008e18 <HAL_RCCEx_PeriphCLKConfig+0x108>
          {
            return HAL_TIMEOUT;
 8008e14:	2303      	movs	r3, #3
 8008e16:	e067      	b.n	8008ee8 <HAL_RCCEx_PeriphCLKConfig+0x1d8>
        while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) == RESET)
 8008e18:	4b35      	ldr	r3, [pc, #212]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008e1a:	6a1b      	ldr	r3, [r3, #32]
 8008e1c:	2202      	movs	r2, #2
 8008e1e:	4013      	ands	r3, r2
 8008e20:	d0f0      	beq.n	8008e04 <HAL_RCCEx_PeriphCLKConfig+0xf4>
          }
        }
      }
    }
    __HAL_RCC_RTC_CONFIG(PeriphClkInit->RTCClockSelection);
 8008e22:	4b33      	ldr	r3, [pc, #204]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008e24:	6a1b      	ldr	r3, [r3, #32]
 8008e26:	4a34      	ldr	r2, [pc, #208]	; (8008ef8 <HAL_RCCEx_PeriphCLKConfig+0x1e8>)
 8008e28:	4013      	ands	r3, r2
 8008e2a:	0019      	movs	r1, r3
 8008e2c:	687b      	ldr	r3, [r7, #4]
 8008e2e:	685a      	ldr	r2, [r3, #4]
 8008e30:	4b2f      	ldr	r3, [pc, #188]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008e32:	430a      	orrs	r2, r1
 8008e34:	621a      	str	r2, [r3, #32]

    /* Require to disable power clock if necessary */
    if(pwrclkchanged == SET)
 8008e36:	2317      	movs	r3, #23
 8008e38:	18fb      	adds	r3, r7, r3
 8008e3a:	781b      	ldrb	r3, [r3, #0]
 8008e3c:	2b01      	cmp	r3, #1
 8008e3e:	d105      	bne.n	8008e4c <HAL_RCCEx_PeriphCLKConfig+0x13c>
    {
      __HAL_RCC_PWR_CLK_DISABLE();
 8008e40:	4b2b      	ldr	r3, [pc, #172]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008e42:	69da      	ldr	r2, [r3, #28]
 8008e44:	4b2a      	ldr	r3, [pc, #168]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008e46:	492f      	ldr	r1, [pc, #188]	; (8008f04 <HAL_RCCEx_PeriphCLKConfig+0x1f4>)
 8008e48:	400a      	ands	r2, r1
 8008e4a:	61da      	str	r2, [r3, #28]
    }
  }

  /*------------------------------- USART1 Configuration ------------------------*/ 
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_USART1) == RCC_PERIPHCLK_USART1)
 8008e4c:	687b      	ldr	r3, [r7, #4]
 8008e4e:	681b      	ldr	r3, [r3, #0]
 8008e50:	2201      	movs	r2, #1
 8008e52:	4013      	ands	r3, r2
 8008e54:	d009      	beq.n	8008e6a <HAL_RCCEx_PeriphCLKConfig+0x15a>
  {
    /* Check the parameters */
    assert_param(IS_RCC_USART1CLKSOURCE(PeriphClkInit->Usart1ClockSelection));
    
    /* Configure the USART1 clock source */
    __HAL_RCC_USART1_CONFIG(PeriphClkInit->Usart1ClockSelection);
 8008e56:	4b26      	ldr	r3, [pc, #152]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008e58:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8008e5a:	2203      	movs	r2, #3
 8008e5c:	4393      	bics	r3, r2
 8008e5e:	0019      	movs	r1, r3
 8008e60:	687b      	ldr	r3, [r7, #4]
 8008e62:	689a      	ldr	r2, [r3, #8]
 8008e64:	4b22      	ldr	r3, [pc, #136]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008e66:	430a      	orrs	r2, r1
 8008e68:	631a      	str	r2, [r3, #48]	; 0x30
  }
  
#if defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\
 || defined(STM32F091xC) || defined(STM32F098xx)
  /*----------------------------- USART2 Configuration --------------------------*/ 
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_USART2) == RCC_PERIPHCLK_USART2)
 8008e6a:	687b      	ldr	r3, [r7, #4]
 8008e6c:	681b      	ldr	r3, [r3, #0]
 8008e6e:	2202      	movs	r2, #2
 8008e70:	4013      	ands	r3, r2
 8008e72:	d009      	beq.n	8008e88 <HAL_RCCEx_PeriphCLKConfig+0x178>
  {
    /* Check the parameters */
    assert_param(IS_RCC_USART2CLKSOURCE(PeriphClkInit->Usart2ClockSelection));
    
    /* Configure the USART2 clock source */
    __HAL_RCC_USART2_CONFIG(PeriphClkInit->Usart2ClockSelection);
 8008e74:	4b1e      	ldr	r3, [pc, #120]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008e76:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8008e78:	4a23      	ldr	r2, [pc, #140]	; (8008f08 <HAL_RCCEx_PeriphCLKConfig+0x1f8>)
 8008e7a:	4013      	ands	r3, r2
 8008e7c:	0019      	movs	r1, r3
 8008e7e:	687b      	ldr	r3, [r7, #4]
 8008e80:	68da      	ldr	r2, [r3, #12]
 8008e82:	4b1b      	ldr	r3, [pc, #108]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008e84:	430a      	orrs	r2, r1
 8008e86:	631a      	str	r2, [r3, #48]	; 0x30
#endif /* STM32F071xB || STM32F072xB || STM32F078xx || */
       /* STM32F091xC || STM32F098xx */

#if defined(STM32F091xC) || defined(STM32F098xx)
  /*----------------------------- USART3 Configuration --------------------------*/ 
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_USART3) == RCC_PERIPHCLK_USART3)
 8008e88:	687b      	ldr	r3, [r7, #4]
 8008e8a:	681a      	ldr	r2, [r3, #0]
 8008e8c:	2380      	movs	r3, #128	; 0x80
 8008e8e:	02db      	lsls	r3, r3, #11
 8008e90:	4013      	ands	r3, r2
 8008e92:	d009      	beq.n	8008ea8 <HAL_RCCEx_PeriphCLKConfig+0x198>
  {
    /* Check the parameters */
    assert_param(IS_RCC_USART3CLKSOURCE(PeriphClkInit->Usart3ClockSelection));
    
    /* Configure the USART3 clock source */
    __HAL_RCC_USART3_CONFIG(PeriphClkInit->Usart3ClockSelection);
 8008e94:	4b16      	ldr	r3, [pc, #88]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008e96:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8008e98:	4a1c      	ldr	r2, [pc, #112]	; (8008f0c <HAL_RCCEx_PeriphCLKConfig+0x1fc>)
 8008e9a:	4013      	ands	r3, r2
 8008e9c:	0019      	movs	r1, r3
 8008e9e:	687b      	ldr	r3, [r7, #4]
 8008ea0:	691a      	ldr	r2, [r3, #16]
 8008ea2:	4b13      	ldr	r3, [pc, #76]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008ea4:	430a      	orrs	r2, r1
 8008ea6:	631a      	str	r2, [r3, #48]	; 0x30
  }
#endif /* STM32F091xC || STM32F098xx */  

  /*------------------------------ I2C1 Configuration ------------------------*/ 
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_I2C1) == RCC_PERIPHCLK_I2C1)
 8008ea8:	687b      	ldr	r3, [r7, #4]
 8008eaa:	681b      	ldr	r3, [r3, #0]
 8008eac:	2220      	movs	r2, #32
 8008eae:	4013      	ands	r3, r2
 8008eb0:	d009      	beq.n	8008ec6 <HAL_RCCEx_PeriphCLKConfig+0x1b6>
  {
    /* Check the parameters */
    assert_param(IS_RCC_I2C1CLKSOURCE(PeriphClkInit->I2c1ClockSelection));
    
    /* Configure the I2C1 clock source */
    __HAL_RCC_I2C1_CONFIG(PeriphClkInit->I2c1ClockSelection);
 8008eb2:	4b0f      	ldr	r3, [pc, #60]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008eb4:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8008eb6:	2210      	movs	r2, #16
 8008eb8:	4393      	bics	r3, r2
 8008eba:	0019      	movs	r1, r3
 8008ebc:	687b      	ldr	r3, [r7, #4]
 8008ebe:	695a      	ldr	r2, [r3, #20]
 8008ec0:	4b0b      	ldr	r3, [pc, #44]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008ec2:	430a      	orrs	r2, r1
 8008ec4:	631a      	str	r2, [r3, #48]	; 0x30
#if defined(STM32F042x6) || defined(STM32F048xx)\
 || defined(STM32F051x8) || defined(STM32F058xx)\
 || defined(STM32F071xB) || defined(STM32F072xB) || defined(STM32F078xx)\
 || defined(STM32F091xC) || defined(STM32F098xx)
  /*------------------------------ CEC clock Configuration -------------------*/ 
  if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_CEC) == RCC_PERIPHCLK_CEC)
 8008ec6:	687b      	ldr	r3, [r7, #4]
 8008ec8:	681a      	ldr	r2, [r3, #0]
 8008eca:	2380      	movs	r3, #128	; 0x80
 8008ecc:	00db      	lsls	r3, r3, #3
 8008ece:	4013      	ands	r3, r2
 8008ed0:	d009      	beq.n	8008ee6 <HAL_RCCEx_PeriphCLKConfig+0x1d6>
  {
    /* Check the parameters */
    assert_param(IS_RCC_CECCLKSOURCE(PeriphClkInit->CecClockSelection));
    
    /* Configure the CEC clock source */
    __HAL_RCC_CEC_CONFIG(PeriphClkInit->CecClockSelection);
 8008ed2:	4b07      	ldr	r3, [pc, #28]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008ed4:	6b1b      	ldr	r3, [r3, #48]	; 0x30
 8008ed6:	2240      	movs	r2, #64	; 0x40
 8008ed8:	4393      	bics	r3, r2
 8008eda:	0019      	movs	r1, r3
 8008edc:	687b      	ldr	r3, [r7, #4]
 8008ede:	699a      	ldr	r2, [r3, #24]
 8008ee0:	4b03      	ldr	r3, [pc, #12]	; (8008ef0 <HAL_RCCEx_PeriphCLKConfig+0x1e0>)
 8008ee2:	430a      	orrs	r2, r1
 8008ee4:	631a      	str	r2, [r3, #48]	; 0x30
#endif /* STM32F042x6 || STM32F048xx ||                */
       /* STM32F051x8 || STM32F058xx ||                */
       /* STM32F071xB || STM32F072xB || STM32F078xx || */
       /* STM32F091xC || STM32F098xx */
  
  return HAL_OK;
 8008ee6:	2300      	movs	r3, #0
}
 8008ee8:	0018      	movs	r0, r3
 8008eea:	46bd      	mov	sp, r7
 8008eec:	b006      	add	sp, #24
 8008eee:	bd80      	pop	{r7, pc}
 8008ef0:	40021000 	.word	0x40021000
 8008ef4:	40007000 	.word	0x40007000
 8008ef8:	fffffcff 	.word	0xfffffcff
 8008efc:	fffeffff 	.word	0xfffeffff
 8008f00:	00001388 	.word	0x00001388
 8008f04:	efffffff 	.word	0xefffffff
 8008f08:	fffcffff 	.word	0xfffcffff
 8008f0c:	fff3ffff 	.word	0xfff3ffff

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

  /* Check the SPI handle allocation */
  if (hspi == NULL)
 8008f18:	687b      	ldr	r3, [r7, #4]
 8008f1a:	2b00      	cmp	r3, #0
 8008f1c:	d101      	bne.n	8008f22 <HAL_SPI_Init+0x12>
  {
    return HAL_ERROR;
 8008f1e:	2301      	movs	r3, #1
 8008f20:	e0a8      	b.n	8009074 <HAL_SPI_Init+0x164>
  assert_param(IS_SPI_NSS(hspi->Init.NSS));
  assert_param(IS_SPI_NSSP(hspi->Init.NSSPMode));
  assert_param(IS_SPI_BAUDRATE_PRESCALER(hspi->Init.BaudRatePrescaler));
  assert_param(IS_SPI_FIRST_BIT(hspi->Init.FirstBit));
  assert_param(IS_SPI_TIMODE(hspi->Init.TIMode));
  if (hspi->Init.TIMode == SPI_TIMODE_DISABLE)
 8008f22:	687b      	ldr	r3, [r7, #4]
 8008f24:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8008f26:	2b00      	cmp	r3, #0
 8008f28:	d109      	bne.n	8008f3e <HAL_SPI_Init+0x2e>
  {
    assert_param(IS_SPI_CPOL(hspi->Init.CLKPolarity));
    assert_param(IS_SPI_CPHA(hspi->Init.CLKPhase));

    if (hspi->Init.Mode == SPI_MODE_MASTER)
 8008f2a:	687b      	ldr	r3, [r7, #4]
 8008f2c:	685a      	ldr	r2, [r3, #4]
 8008f2e:	2382      	movs	r3, #130	; 0x82
 8008f30:	005b      	lsls	r3, r3, #1
 8008f32:	429a      	cmp	r2, r3
 8008f34:	d009      	beq.n	8008f4a <HAL_SPI_Init+0x3a>
      assert_param(IS_SPI_BAUDRATE_PRESCALER(hspi->Init.BaudRatePrescaler));
    }
    else
    {
      /* Baudrate prescaler not use in Motoraola Slave mode. force to default value */
      hspi->Init.BaudRatePrescaler = SPI_BAUDRATEPRESCALER_2;
 8008f36:	687b      	ldr	r3, [r7, #4]
 8008f38:	2200      	movs	r2, #0
 8008f3a:	61da      	str	r2, [r3, #28]
 8008f3c:	e005      	b.n	8008f4a <HAL_SPI_Init+0x3a>
  else
  {
    assert_param(IS_SPI_BAUDRATE_PRESCALER(hspi->Init.BaudRatePrescaler));

    /* Force polarity and phase to TI protocaol requirements */
    hspi->Init.CLKPolarity = SPI_POLARITY_LOW;
 8008f3e:	687b      	ldr	r3, [r7, #4]
 8008f40:	2200      	movs	r2, #0
 8008f42:	611a      	str	r2, [r3, #16]
    hspi->Init.CLKPhase    = SPI_PHASE_1EDGE;
 8008f44:	687b      	ldr	r3, [r7, #4]
 8008f46:	2200      	movs	r2, #0
 8008f48:	615a      	str	r2, [r3, #20]
  {
    assert_param(IS_SPI_CRC_POLYNOMIAL(hspi->Init.CRCPolynomial));
    assert_param(IS_SPI_CRC_LENGTH(hspi->Init.CRCLength));
  }
#else
  hspi->Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;
 8008f4a:	687b      	ldr	r3, [r7, #4]
 8008f4c:	2200      	movs	r2, #0
 8008f4e:	629a      	str	r2, [r3, #40]	; 0x28
#endif /* USE_SPI_CRC */

  if (hspi->State == HAL_SPI_STATE_RESET)
 8008f50:	687b      	ldr	r3, [r7, #4]
 8008f52:	225d      	movs	r2, #93	; 0x5d
 8008f54:	5c9b      	ldrb	r3, [r3, r2]
 8008f56:	b2db      	uxtb	r3, r3
 8008f58:	2b00      	cmp	r3, #0
 8008f5a:	d107      	bne.n	8008f6c <HAL_SPI_Init+0x5c>
  {
    /* Allocate lock resource and initialize it */
    hspi->Lock = HAL_UNLOCKED;
 8008f5c:	687b      	ldr	r3, [r7, #4]
 8008f5e:	225c      	movs	r2, #92	; 0x5c
 8008f60:	2100      	movs	r1, #0
 8008f62:	5499      	strb	r1, [r3, r2]

    /* Init the low level hardware : GPIO, CLOCK, NVIC... */
    hspi->MspInitCallback(hspi);
#else
    /* Init the low level hardware : GPIO, CLOCK, NVIC... */
    HAL_SPI_MspInit(hspi);
 8008f64:	687b      	ldr	r3, [r7, #4]
 8008f66:	0018      	movs	r0, r3
 8008f68:	f7fc facc 	bl	8005504 <HAL_SPI_MspInit>
#endif /* USE_HAL_SPI_REGISTER_CALLBACKS */
  }

  hspi->State = HAL_SPI_STATE_BUSY;
 8008f6c:	687b      	ldr	r3, [r7, #4]
 8008f6e:	225d      	movs	r2, #93	; 0x5d
 8008f70:	2102      	movs	r1, #2
 8008f72:	5499      	strb	r1, [r3, r2]

  /* Disable the selected SPI peripheral */
  __HAL_SPI_DISABLE(hspi);
 8008f74:	687b      	ldr	r3, [r7, #4]
 8008f76:	681b      	ldr	r3, [r3, #0]
 8008f78:	681a      	ldr	r2, [r3, #0]
 8008f7a:	687b      	ldr	r3, [r7, #4]
 8008f7c:	681b      	ldr	r3, [r3, #0]
 8008f7e:	2140      	movs	r1, #64	; 0x40
 8008f80:	438a      	bics	r2, r1
 8008f82:	601a      	str	r2, [r3, #0]

  /* Align by default the rs fifo threshold on the data size */
  if (hspi->Init.DataSize > SPI_DATASIZE_8BIT)
 8008f84:	687b      	ldr	r3, [r7, #4]
 8008f86:	68da      	ldr	r2, [r3, #12]
 8008f88:	23e0      	movs	r3, #224	; 0xe0
 8008f8a:	00db      	lsls	r3, r3, #3
 8008f8c:	429a      	cmp	r2, r3
 8008f8e:	d902      	bls.n	8008f96 <HAL_SPI_Init+0x86>
  {
    frxth = SPI_RXFIFO_THRESHOLD_HF;
 8008f90:	2300      	movs	r3, #0
 8008f92:	60fb      	str	r3, [r7, #12]
 8008f94:	e002      	b.n	8008f9c <HAL_SPI_Init+0x8c>
  }
  else
  {
    frxth = SPI_RXFIFO_THRESHOLD_QF;
 8008f96:	2380      	movs	r3, #128	; 0x80
 8008f98:	015b      	lsls	r3, r3, #5
 8008f9a:	60fb      	str	r3, [r7, #12]
  }

  /* CRC calculation is valid only for 16Bit and 8 Bit */
  if ((hspi->Init.DataSize != SPI_DATASIZE_16BIT) && (hspi->Init.DataSize != SPI_DATASIZE_8BIT))
 8008f9c:	687b      	ldr	r3, [r7, #4]
 8008f9e:	68da      	ldr	r2, [r3, #12]
 8008fa0:	23f0      	movs	r3, #240	; 0xf0
 8008fa2:	011b      	lsls	r3, r3, #4
 8008fa4:	429a      	cmp	r2, r3
 8008fa6:	d008      	beq.n	8008fba <HAL_SPI_Init+0xaa>
 8008fa8:	687b      	ldr	r3, [r7, #4]
 8008faa:	68da      	ldr	r2, [r3, #12]
 8008fac:	23e0      	movs	r3, #224	; 0xe0
 8008fae:	00db      	lsls	r3, r3, #3
 8008fb0:	429a      	cmp	r2, r3
 8008fb2:	d002      	beq.n	8008fba <HAL_SPI_Init+0xaa>
  {
    /* CRC must be disabled */
    hspi->Init.CRCCalculation = SPI_CRCCALCULATION_DISABLE;
 8008fb4:	687b      	ldr	r3, [r7, #4]
 8008fb6:	2200      	movs	r2, #0
 8008fb8:	629a      	str	r2, [r3, #40]	; 0x28
  }

  /*----------------------- SPIx CR1 & CR2 Configuration ---------------------*/
  /* Configure : SPI Mode, Communication Mode, Clock polarity and phase, NSS management,
  Communication speed, First bit and CRC calculation state */
  WRITE_REG(hspi->Instance->CR1, ((hspi->Init.Mode & (SPI_CR1_MSTR | SPI_CR1_SSI)) |
 8008fba:	687b      	ldr	r3, [r7, #4]
 8008fbc:	685a      	ldr	r2, [r3, #4]
 8008fbe:	2382      	movs	r3, #130	; 0x82
 8008fc0:	005b      	lsls	r3, r3, #1
 8008fc2:	401a      	ands	r2, r3
 8008fc4:	687b      	ldr	r3, [r7, #4]
 8008fc6:	6899      	ldr	r1, [r3, #8]
 8008fc8:	2384      	movs	r3, #132	; 0x84
 8008fca:	021b      	lsls	r3, r3, #8
 8008fcc:	400b      	ands	r3, r1
 8008fce:	431a      	orrs	r2, r3
 8008fd0:	687b      	ldr	r3, [r7, #4]
 8008fd2:	691b      	ldr	r3, [r3, #16]
 8008fd4:	2102      	movs	r1, #2
 8008fd6:	400b      	ands	r3, r1
 8008fd8:	431a      	orrs	r2, r3
 8008fda:	687b      	ldr	r3, [r7, #4]
 8008fdc:	695b      	ldr	r3, [r3, #20]
 8008fde:	2101      	movs	r1, #1
 8008fe0:	400b      	ands	r3, r1
 8008fe2:	431a      	orrs	r2, r3
 8008fe4:	687b      	ldr	r3, [r7, #4]
 8008fe6:	6999      	ldr	r1, [r3, #24]
 8008fe8:	2380      	movs	r3, #128	; 0x80
 8008fea:	009b      	lsls	r3, r3, #2
 8008fec:	400b      	ands	r3, r1
 8008fee:	431a      	orrs	r2, r3
 8008ff0:	687b      	ldr	r3, [r7, #4]
 8008ff2:	69db      	ldr	r3, [r3, #28]
 8008ff4:	2138      	movs	r1, #56	; 0x38
 8008ff6:	400b      	ands	r3, r1
 8008ff8:	431a      	orrs	r2, r3
 8008ffa:	687b      	ldr	r3, [r7, #4]
 8008ffc:	6a1b      	ldr	r3, [r3, #32]
 8008ffe:	2180      	movs	r1, #128	; 0x80
 8009000:	400b      	ands	r3, r1
 8009002:	431a      	orrs	r2, r3
 8009004:	0011      	movs	r1, r2
 8009006:	687b      	ldr	r3, [r7, #4]
 8009008:	6a9a      	ldr	r2, [r3, #40]	; 0x28
 800900a:	2380      	movs	r3, #128	; 0x80
 800900c:	019b      	lsls	r3, r3, #6
 800900e:	401a      	ands	r2, r3
 8009010:	687b      	ldr	r3, [r7, #4]
 8009012:	681b      	ldr	r3, [r3, #0]
 8009014:	430a      	orrs	r2, r1
 8009016:	601a      	str	r2, [r3, #0]
    }
  }
#endif /* USE_SPI_CRC */

  /* Configure : NSS management, TI Mode, NSS Pulse, Data size and Rx Fifo threshold */
  WRITE_REG(hspi->Instance->CR2, (((hspi->Init.NSS >> 16U) & SPI_CR2_SSOE) |
 8009018:	687b      	ldr	r3, [r7, #4]
 800901a:	699b      	ldr	r3, [r3, #24]
 800901c:	0c1b      	lsrs	r3, r3, #16
 800901e:	2204      	movs	r2, #4
 8009020:	401a      	ands	r2, r3
 8009022:	687b      	ldr	r3, [r7, #4]
 8009024:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 8009026:	2110      	movs	r1, #16
 8009028:	400b      	ands	r3, r1
 800902a:	431a      	orrs	r2, r3
 800902c:	687b      	ldr	r3, [r7, #4]
 800902e:	6b5b      	ldr	r3, [r3, #52]	; 0x34
 8009030:	2108      	movs	r1, #8
 8009032:	400b      	ands	r3, r1
 8009034:	431a      	orrs	r2, r3
 8009036:	687b      	ldr	r3, [r7, #4]
 8009038:	68d9      	ldr	r1, [r3, #12]
 800903a:	23f0      	movs	r3, #240	; 0xf0
 800903c:	011b      	lsls	r3, r3, #4
 800903e:	400b      	ands	r3, r1
 8009040:	431a      	orrs	r2, r3
 8009042:	0011      	movs	r1, r2
 8009044:	68fa      	ldr	r2, [r7, #12]
 8009046:	2380      	movs	r3, #128	; 0x80
 8009048:	015b      	lsls	r3, r3, #5
 800904a:	401a      	ands	r2, r3
 800904c:	687b      	ldr	r3, [r7, #4]
 800904e:	681b      	ldr	r3, [r3, #0]
 8009050:	430a      	orrs	r2, r1
 8009052:	605a      	str	r2, [r3, #4]
  }
#endif /* USE_SPI_CRC */

#if defined(SPI_I2SCFGR_I2SMOD)
  /* Activate the SPI mode (Make sure that I2SMOD bit in I2SCFGR register is reset) */
  CLEAR_BIT(hspi->Instance->I2SCFGR, SPI_I2SCFGR_I2SMOD);
 8009054:	687b      	ldr	r3, [r7, #4]
 8009056:	681b      	ldr	r3, [r3, #0]
 8009058:	69da      	ldr	r2, [r3, #28]
 800905a:	687b      	ldr	r3, [r7, #4]
 800905c:	681b      	ldr	r3, [r3, #0]
 800905e:	4907      	ldr	r1, [pc, #28]	; (800907c <HAL_SPI_Init+0x16c>)
 8009060:	400a      	ands	r2, r1
 8009062:	61da      	str	r2, [r3, #28]
#endif /* SPI_I2SCFGR_I2SMOD */

  hspi->ErrorCode = HAL_SPI_ERROR_NONE;
 8009064:	687b      	ldr	r3, [r7, #4]
 8009066:	2200      	movs	r2, #0
 8009068:	661a      	str	r2, [r3, #96]	; 0x60
  hspi->State     = HAL_SPI_STATE_READY;
 800906a:	687b      	ldr	r3, [r7, #4]
 800906c:	225d      	movs	r2, #93	; 0x5d
 800906e:	2101      	movs	r1, #1
 8009070:	5499      	strb	r1, [r3, r2]

  return HAL_OK;
 8009072:	2300      	movs	r3, #0
}
 8009074:	0018      	movs	r0, r3
 8009076:	46bd      	mov	sp, r7
 8009078:	b004      	add	sp, #16
 800907a:	bd80      	pop	{r7, pc}
 800907c:	fffff7ff 	.word	0xfffff7ff

08009080 <HAL_TIM_PWM_Init>:
  *         Ex: call @ref HAL_TIM_PWM_DeInit() before HAL_TIM_PWM_Init()
  * @param  htim TIM PWM handle
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_TIM_PWM_Init(TIM_HandleTypeDef *htim)
{
 8009080:	b580      	push	{r7, lr}
 8009082:	b082      	sub	sp, #8
 8009084:	af00      	add	r7, sp, #0
 8009086:	6078      	str	r0, [r7, #4]
  /* Check the TIM handle allocation */
  if (htim == NULL)
 8009088:	687b      	ldr	r3, [r7, #4]
 800908a:	2b00      	cmp	r3, #0
 800908c:	d101      	bne.n	8009092 <HAL_TIM_PWM_Init+0x12>
  {
    return HAL_ERROR;
 800908e:	2301      	movs	r3, #1
 8009090:	e042      	b.n	8009118 <HAL_TIM_PWM_Init+0x98>
  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)
 8009092:	687b      	ldr	r3, [r7, #4]
 8009094:	223d      	movs	r2, #61	; 0x3d
 8009096:	5c9b      	ldrb	r3, [r3, r2]
 8009098:	b2db      	uxtb	r3, r3
 800909a:	2b00      	cmp	r3, #0
 800909c:	d107      	bne.n	80090ae <HAL_TIM_PWM_Init+0x2e>
  {
    /* Allocate lock resource and initialize it */
    htim->Lock = HAL_UNLOCKED;
 800909e:	687b      	ldr	r3, [r7, #4]
 80090a0:	223c      	movs	r2, #60	; 0x3c
 80090a2:	2100      	movs	r1, #0
 80090a4:	5499      	strb	r1, [r3, r2]
    }
    /* Init the low level hardware : GPIO, CLOCK, NVIC */
    htim->PWM_MspInitCallback(htim);
#else
    /* Init the low level hardware : GPIO, CLOCK, NVIC and DMA */
    HAL_TIM_PWM_MspInit(htim);
 80090a6:	687b      	ldr	r3, [r7, #4]
 80090a8:	0018      	movs	r0, r3
 80090aa:	f7fc fa77 	bl	800559c <HAL_TIM_PWM_MspInit>
#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */
  }

  /* Set the TIM state */
  htim->State = HAL_TIM_STATE_BUSY;
 80090ae:	687b      	ldr	r3, [r7, #4]
 80090b0:	223d      	movs	r2, #61	; 0x3d
 80090b2:	2102      	movs	r1, #2
 80090b4:	5499      	strb	r1, [r3, r2]

  /* Init the base time for the PWM */
  TIM_Base_SetConfig(htim->Instance, &htim->Init);
 80090b6:	687b      	ldr	r3, [r7, #4]
 80090b8:	681a      	ldr	r2, [r3, #0]
 80090ba:	687b      	ldr	r3, [r7, #4]
 80090bc:	3304      	adds	r3, #4
 80090be:	0019      	movs	r1, r3
 80090c0:	0010      	movs	r0, r2
 80090c2:	f000 fa27 	bl	8009514 <TIM_Base_SetConfig>

  /* Initialize the DMA burst operation state */
  htim->DMABurstState = HAL_DMA_BURST_STATE_READY;
 80090c6:	687b      	ldr	r3, [r7, #4]
 80090c8:	2246      	movs	r2, #70	; 0x46
 80090ca:	2101      	movs	r1, #1
 80090cc:	5499      	strb	r1, [r3, r2]

  /* Initialize the TIM channels state */
  TIM_CHANNEL_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_READY);
 80090ce:	687b      	ldr	r3, [r7, #4]
 80090d0:	223e      	movs	r2, #62	; 0x3e
 80090d2:	2101      	movs	r1, #1
 80090d4:	5499      	strb	r1, [r3, r2]
 80090d6:	687b      	ldr	r3, [r7, #4]
 80090d8:	223f      	movs	r2, #63	; 0x3f
 80090da:	2101      	movs	r1, #1
 80090dc:	5499      	strb	r1, [r3, r2]
 80090de:	687b      	ldr	r3, [r7, #4]
 80090e0:	2240      	movs	r2, #64	; 0x40
 80090e2:	2101      	movs	r1, #1
 80090e4:	5499      	strb	r1, [r3, r2]
 80090e6:	687b      	ldr	r3, [r7, #4]
 80090e8:	2241      	movs	r2, #65	; 0x41
 80090ea:	2101      	movs	r1, #1
 80090ec:	5499      	strb	r1, [r3, r2]
  TIM_CHANNEL_N_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_READY);
 80090ee:	687b      	ldr	r3, [r7, #4]
 80090f0:	2242      	movs	r2, #66	; 0x42
 80090f2:	2101      	movs	r1, #1
 80090f4:	5499      	strb	r1, [r3, r2]
 80090f6:	687b      	ldr	r3, [r7, #4]
 80090f8:	2243      	movs	r2, #67	; 0x43
 80090fa:	2101      	movs	r1, #1
 80090fc:	5499      	strb	r1, [r3, r2]
 80090fe:	687b      	ldr	r3, [r7, #4]
 8009100:	2244      	movs	r2, #68	; 0x44
 8009102:	2101      	movs	r1, #1
 8009104:	5499      	strb	r1, [r3, r2]
 8009106:	687b      	ldr	r3, [r7, #4]
 8009108:	2245      	movs	r2, #69	; 0x45
 800910a:	2101      	movs	r1, #1
 800910c:	5499      	strb	r1, [r3, r2]

  /* Initialize the TIM state*/
  htim->State = HAL_TIM_STATE_READY;
 800910e:	687b      	ldr	r3, [r7, #4]
 8009110:	223d      	movs	r2, #61	; 0x3d
 8009112:	2101      	movs	r1, #1
 8009114:	5499      	strb	r1, [r3, r2]

  return HAL_OK;
 8009116:	2300      	movs	r3, #0
}
 8009118:	0018      	movs	r0, r3
 800911a:	46bd      	mov	sp, r7
 800911c:	b002      	add	sp, #8
 800911e:	bd80      	pop	{r7, pc}

08009120 <HAL_TIM_PWM_Start>:
  *            @arg TIM_CHANNEL_3: TIM Channel 3 selected
  *            @arg TIM_CHANNEL_4: TIM Channel 4 selected
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_TIM_PWM_Start(TIM_HandleTypeDef *htim, uint32_t Channel)
{
 8009120:	b580      	push	{r7, lr}
 8009122:	b084      	sub	sp, #16
 8009124:	af00      	add	r7, sp, #0
 8009126:	6078      	str	r0, [r7, #4]
 8009128:	6039      	str	r1, [r7, #0]

  /* Check the parameters */
  assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel));

  /* Check the TIM channel state */
  if (TIM_CHANNEL_STATE_GET(htim, Channel) != HAL_TIM_CHANNEL_STATE_READY)
 800912a:	683b      	ldr	r3, [r7, #0]
 800912c:	2b00      	cmp	r3, #0
 800912e:	d108      	bne.n	8009142 <HAL_TIM_PWM_Start+0x22>
 8009130:	687b      	ldr	r3, [r7, #4]
 8009132:	223e      	movs	r2, #62	; 0x3e
 8009134:	5c9b      	ldrb	r3, [r3, r2]
 8009136:	b2db      	uxtb	r3, r3
 8009138:	3b01      	subs	r3, #1
 800913a:	1e5a      	subs	r2, r3, #1
 800913c:	4193      	sbcs	r3, r2
 800913e:	b2db      	uxtb	r3, r3
 8009140:	e01f      	b.n	8009182 <HAL_TIM_PWM_Start+0x62>
 8009142:	683b      	ldr	r3, [r7, #0]
 8009144:	2b04      	cmp	r3, #4
 8009146:	d108      	bne.n	800915a <HAL_TIM_PWM_Start+0x3a>
 8009148:	687b      	ldr	r3, [r7, #4]
 800914a:	223f      	movs	r2, #63	; 0x3f
 800914c:	5c9b      	ldrb	r3, [r3, r2]
 800914e:	b2db      	uxtb	r3, r3
 8009150:	3b01      	subs	r3, #1
 8009152:	1e5a      	subs	r2, r3, #1
 8009154:	4193      	sbcs	r3, r2
 8009156:	b2db      	uxtb	r3, r3
 8009158:	e013      	b.n	8009182 <HAL_TIM_PWM_Start+0x62>
 800915a:	683b      	ldr	r3, [r7, #0]
 800915c:	2b08      	cmp	r3, #8
 800915e:	d108      	bne.n	8009172 <HAL_TIM_PWM_Start+0x52>
 8009160:	687b      	ldr	r3, [r7, #4]
 8009162:	2240      	movs	r2, #64	; 0x40
 8009164:	5c9b      	ldrb	r3, [r3, r2]
 8009166:	b2db      	uxtb	r3, r3
 8009168:	3b01      	subs	r3, #1
 800916a:	1e5a      	subs	r2, r3, #1
 800916c:	4193      	sbcs	r3, r2
 800916e:	b2db      	uxtb	r3, r3
 8009170:	e007      	b.n	8009182 <HAL_TIM_PWM_Start+0x62>
 8009172:	687b      	ldr	r3, [r7, #4]
 8009174:	2241      	movs	r2, #65	; 0x41
 8009176:	5c9b      	ldrb	r3, [r3, r2]
 8009178:	b2db      	uxtb	r3, r3
 800917a:	3b01      	subs	r3, #1
 800917c:	1e5a      	subs	r2, r3, #1
 800917e:	4193      	sbcs	r3, r2
 8009180:	b2db      	uxtb	r3, r3
 8009182:	2b00      	cmp	r3, #0
 8009184:	d001      	beq.n	800918a <HAL_TIM_PWM_Start+0x6a>
  {
    return HAL_ERROR;
 8009186:	2301      	movs	r3, #1
 8009188:	e074      	b.n	8009274 <HAL_TIM_PWM_Start+0x154>
  }

  /* Set the TIM channel state */
  TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_BUSY);
 800918a:	683b      	ldr	r3, [r7, #0]
 800918c:	2b00      	cmp	r3, #0
 800918e:	d104      	bne.n	800919a <HAL_TIM_PWM_Start+0x7a>
 8009190:	687b      	ldr	r3, [r7, #4]
 8009192:	223e      	movs	r2, #62	; 0x3e
 8009194:	2102      	movs	r1, #2
 8009196:	5499      	strb	r1, [r3, r2]
 8009198:	e013      	b.n	80091c2 <HAL_TIM_PWM_Start+0xa2>
 800919a:	683b      	ldr	r3, [r7, #0]
 800919c:	2b04      	cmp	r3, #4
 800919e:	d104      	bne.n	80091aa <HAL_TIM_PWM_Start+0x8a>
 80091a0:	687b      	ldr	r3, [r7, #4]
 80091a2:	223f      	movs	r2, #63	; 0x3f
 80091a4:	2102      	movs	r1, #2
 80091a6:	5499      	strb	r1, [r3, r2]
 80091a8:	e00b      	b.n	80091c2 <HAL_TIM_PWM_Start+0xa2>
 80091aa:	683b      	ldr	r3, [r7, #0]
 80091ac:	2b08      	cmp	r3, #8
 80091ae:	d104      	bne.n	80091ba <HAL_TIM_PWM_Start+0x9a>
 80091b0:	687b      	ldr	r3, [r7, #4]
 80091b2:	2240      	movs	r2, #64	; 0x40
 80091b4:	2102      	movs	r1, #2
 80091b6:	5499      	strb	r1, [r3, r2]
 80091b8:	e003      	b.n	80091c2 <HAL_TIM_PWM_Start+0xa2>
 80091ba:	687b      	ldr	r3, [r7, #4]
 80091bc:	2241      	movs	r2, #65	; 0x41
 80091be:	2102      	movs	r1, #2
 80091c0:	5499      	strb	r1, [r3, r2]

  /* Enable the Capture compare channel */
  TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_ENABLE);
 80091c2:	687b      	ldr	r3, [r7, #4]
 80091c4:	681b      	ldr	r3, [r3, #0]
 80091c6:	6839      	ldr	r1, [r7, #0]
 80091c8:	2201      	movs	r2, #1
 80091ca:	0018      	movs	r0, r3
 80091cc:	f000 fc1e 	bl	8009a0c <TIM_CCxChannelCmd>

  if (IS_TIM_BREAK_INSTANCE(htim->Instance) != RESET)
 80091d0:	687b      	ldr	r3, [r7, #4]
 80091d2:	681b      	ldr	r3, [r3, #0]
 80091d4:	4a29      	ldr	r2, [pc, #164]	; (800927c <HAL_TIM_PWM_Start+0x15c>)
 80091d6:	4293      	cmp	r3, r2
 80091d8:	d00e      	beq.n	80091f8 <HAL_TIM_PWM_Start+0xd8>
 80091da:	687b      	ldr	r3, [r7, #4]
 80091dc:	681b      	ldr	r3, [r3, #0]
 80091de:	4a28      	ldr	r2, [pc, #160]	; (8009280 <HAL_TIM_PWM_Start+0x160>)
 80091e0:	4293      	cmp	r3, r2
 80091e2:	d009      	beq.n	80091f8 <HAL_TIM_PWM_Start+0xd8>
 80091e4:	687b      	ldr	r3, [r7, #4]
 80091e6:	681b      	ldr	r3, [r3, #0]
 80091e8:	4a26      	ldr	r2, [pc, #152]	; (8009284 <HAL_TIM_PWM_Start+0x164>)
 80091ea:	4293      	cmp	r3, r2
 80091ec:	d004      	beq.n	80091f8 <HAL_TIM_PWM_Start+0xd8>
 80091ee:	687b      	ldr	r3, [r7, #4]
 80091f0:	681b      	ldr	r3, [r3, #0]
 80091f2:	4a25      	ldr	r2, [pc, #148]	; (8009288 <HAL_TIM_PWM_Start+0x168>)
 80091f4:	4293      	cmp	r3, r2
 80091f6:	d101      	bne.n	80091fc <HAL_TIM_PWM_Start+0xdc>
 80091f8:	2301      	movs	r3, #1
 80091fa:	e000      	b.n	80091fe <HAL_TIM_PWM_Start+0xde>
 80091fc:	2300      	movs	r3, #0
 80091fe:	2b00      	cmp	r3, #0
 8009200:	d008      	beq.n	8009214 <HAL_TIM_PWM_Start+0xf4>
  {
    /* Enable the main output */
    __HAL_TIM_MOE_ENABLE(htim);
 8009202:	687b      	ldr	r3, [r7, #4]
 8009204:	681b      	ldr	r3, [r3, #0]
 8009206:	6c5a      	ldr	r2, [r3, #68]	; 0x44
 8009208:	687b      	ldr	r3, [r7, #4]
 800920a:	681b      	ldr	r3, [r3, #0]
 800920c:	2180      	movs	r1, #128	; 0x80
 800920e:	0209      	lsls	r1, r1, #8
 8009210:	430a      	orrs	r2, r1
 8009212:	645a      	str	r2, [r3, #68]	; 0x44
  }

  /* Enable the Peripheral, except in trigger mode where enable is automatically done with trigger */
  if (IS_TIM_SLAVE_INSTANCE(htim->Instance))
 8009214:	687b      	ldr	r3, [r7, #4]
 8009216:	681b      	ldr	r3, [r3, #0]
 8009218:	4a18      	ldr	r2, [pc, #96]	; (800927c <HAL_TIM_PWM_Start+0x15c>)
 800921a:	4293      	cmp	r3, r2
 800921c:	d00f      	beq.n	800923e <HAL_TIM_PWM_Start+0x11e>
 800921e:	687b      	ldr	r3, [r7, #4]
 8009220:	681a      	ldr	r2, [r3, #0]
 8009222:	2380      	movs	r3, #128	; 0x80
 8009224:	05db      	lsls	r3, r3, #23
 8009226:	429a      	cmp	r2, r3
 8009228:	d009      	beq.n	800923e <HAL_TIM_PWM_Start+0x11e>
 800922a:	687b      	ldr	r3, [r7, #4]
 800922c:	681b      	ldr	r3, [r3, #0]
 800922e:	4a17      	ldr	r2, [pc, #92]	; (800928c <HAL_TIM_PWM_Start+0x16c>)
 8009230:	4293      	cmp	r3, r2
 8009232:	d004      	beq.n	800923e <HAL_TIM_PWM_Start+0x11e>
 8009234:	687b      	ldr	r3, [r7, #4]
 8009236:	681b      	ldr	r3, [r3, #0]
 8009238:	4a11      	ldr	r2, [pc, #68]	; (8009280 <HAL_TIM_PWM_Start+0x160>)
 800923a:	4293      	cmp	r3, r2
 800923c:	d111      	bne.n	8009262 <HAL_TIM_PWM_Start+0x142>
  {
    tmpsmcr = htim->Instance->SMCR & TIM_SMCR_SMS;
 800923e:	687b      	ldr	r3, [r7, #4]
 8009240:	681b      	ldr	r3, [r3, #0]
 8009242:	689b      	ldr	r3, [r3, #8]
 8009244:	2207      	movs	r2, #7
 8009246:	4013      	ands	r3, r2
 8009248:	60fb      	str	r3, [r7, #12]
    if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
 800924a:	68fb      	ldr	r3, [r7, #12]
 800924c:	2b06      	cmp	r3, #6
 800924e:	d010      	beq.n	8009272 <HAL_TIM_PWM_Start+0x152>
    {
      __HAL_TIM_ENABLE(htim);
 8009250:	687b      	ldr	r3, [r7, #4]
 8009252:	681b      	ldr	r3, [r3, #0]
 8009254:	681a      	ldr	r2, [r3, #0]
 8009256:	687b      	ldr	r3, [r7, #4]
 8009258:	681b      	ldr	r3, [r3, #0]
 800925a:	2101      	movs	r1, #1
 800925c:	430a      	orrs	r2, r1
 800925e:	601a      	str	r2, [r3, #0]
    if (!IS_TIM_SLAVEMODE_TRIGGER_ENABLED(tmpsmcr))
 8009260:	e007      	b.n	8009272 <HAL_TIM_PWM_Start+0x152>
    }
  }
  else
  {
    __HAL_TIM_ENABLE(htim);
 8009262:	687b      	ldr	r3, [r7, #4]
 8009264:	681b      	ldr	r3, [r3, #0]
 8009266:	681a      	ldr	r2, [r3, #0]
 8009268:	687b      	ldr	r3, [r7, #4]
 800926a:	681b      	ldr	r3, [r3, #0]
 800926c:	2101      	movs	r1, #1
 800926e:	430a      	orrs	r2, r1
 8009270:	601a      	str	r2, [r3, #0]
  }

  /* Return function status */
  return HAL_OK;
 8009272:	2300      	movs	r3, #0
}
 8009274:	0018      	movs	r0, r3
 8009276:	46bd      	mov	sp, r7
 8009278:	b004      	add	sp, #16
 800927a:	bd80      	pop	{r7, pc}
 800927c:	40012c00 	.word	0x40012c00
 8009280:	40014000 	.word	0x40014000
 8009284:	40014400 	.word	0x40014400
 8009288:	40014800 	.word	0x40014800
 800928c:	40000400 	.word	0x40000400

08009290 <HAL_TIM_PWM_Stop>:
  *            @arg TIM_CHANNEL_3: TIM Channel 3 selected
  *            @arg TIM_CHANNEL_4: TIM Channel 4 selected
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_TIM_PWM_Stop(TIM_HandleTypeDef *htim, uint32_t Channel)
{
 8009290:	b580      	push	{r7, lr}
 8009292:	b082      	sub	sp, #8
 8009294:	af00      	add	r7, sp, #0
 8009296:	6078      	str	r0, [r7, #4]
 8009298:	6039      	str	r1, [r7, #0]
  /* Check the parameters */
  assert_param(IS_TIM_CCX_INSTANCE(htim->Instance, Channel));

  /* Disable the Capture compare channel */
  TIM_CCxChannelCmd(htim->Instance, Channel, TIM_CCx_DISABLE);
 800929a:	687b      	ldr	r3, [r7, #4]
 800929c:	681b      	ldr	r3, [r3, #0]
 800929e:	6839      	ldr	r1, [r7, #0]
 80092a0:	2200      	movs	r2, #0
 80092a2:	0018      	movs	r0, r3
 80092a4:	f000 fbb2 	bl	8009a0c <TIM_CCxChannelCmd>

  if (IS_TIM_BREAK_INSTANCE(htim->Instance) != RESET)
 80092a8:	687b      	ldr	r3, [r7, #4]
 80092aa:	681b      	ldr	r3, [r3, #0]
 80092ac:	4a2f      	ldr	r2, [pc, #188]	; (800936c <HAL_TIM_PWM_Stop+0xdc>)
 80092ae:	4293      	cmp	r3, r2
 80092b0:	d00e      	beq.n	80092d0 <HAL_TIM_PWM_Stop+0x40>
 80092b2:	687b      	ldr	r3, [r7, #4]
 80092b4:	681b      	ldr	r3, [r3, #0]
 80092b6:	4a2e      	ldr	r2, [pc, #184]	; (8009370 <HAL_TIM_PWM_Stop+0xe0>)
 80092b8:	4293      	cmp	r3, r2
 80092ba:	d009      	beq.n	80092d0 <HAL_TIM_PWM_Stop+0x40>
 80092bc:	687b      	ldr	r3, [r7, #4]
 80092be:	681b      	ldr	r3, [r3, #0]
 80092c0:	4a2c      	ldr	r2, [pc, #176]	; (8009374 <HAL_TIM_PWM_Stop+0xe4>)
 80092c2:	4293      	cmp	r3, r2
 80092c4:	d004      	beq.n	80092d0 <HAL_TIM_PWM_Stop+0x40>
 80092c6:	687b      	ldr	r3, [r7, #4]
 80092c8:	681b      	ldr	r3, [r3, #0]
 80092ca:	4a2b      	ldr	r2, [pc, #172]	; (8009378 <HAL_TIM_PWM_Stop+0xe8>)
 80092cc:	4293      	cmp	r3, r2
 80092ce:	d101      	bne.n	80092d4 <HAL_TIM_PWM_Stop+0x44>
 80092d0:	2301      	movs	r3, #1
 80092d2:	e000      	b.n	80092d6 <HAL_TIM_PWM_Stop+0x46>
 80092d4:	2300      	movs	r3, #0
 80092d6:	2b00      	cmp	r3, #0
 80092d8:	d013      	beq.n	8009302 <HAL_TIM_PWM_Stop+0x72>
  {
    /* Disable the Main Output */
    __HAL_TIM_MOE_DISABLE(htim);
 80092da:	687b      	ldr	r3, [r7, #4]
 80092dc:	681b      	ldr	r3, [r3, #0]
 80092de:	6a1b      	ldr	r3, [r3, #32]
 80092e0:	4a26      	ldr	r2, [pc, #152]	; (800937c <HAL_TIM_PWM_Stop+0xec>)
 80092e2:	4013      	ands	r3, r2
 80092e4:	d10d      	bne.n	8009302 <HAL_TIM_PWM_Stop+0x72>
 80092e6:	687b      	ldr	r3, [r7, #4]
 80092e8:	681b      	ldr	r3, [r3, #0]
 80092ea:	6a1b      	ldr	r3, [r3, #32]
 80092ec:	4a24      	ldr	r2, [pc, #144]	; (8009380 <HAL_TIM_PWM_Stop+0xf0>)
 80092ee:	4013      	ands	r3, r2
 80092f0:	d107      	bne.n	8009302 <HAL_TIM_PWM_Stop+0x72>
 80092f2:	687b      	ldr	r3, [r7, #4]
 80092f4:	681b      	ldr	r3, [r3, #0]
 80092f6:	6c5a      	ldr	r2, [r3, #68]	; 0x44
 80092f8:	687b      	ldr	r3, [r7, #4]
 80092fa:	681b      	ldr	r3, [r3, #0]
 80092fc:	4921      	ldr	r1, [pc, #132]	; (8009384 <HAL_TIM_PWM_Stop+0xf4>)
 80092fe:	400a      	ands	r2, r1
 8009300:	645a      	str	r2, [r3, #68]	; 0x44
  }

  /* Disable the Peripheral */
  __HAL_TIM_DISABLE(htim);
 8009302:	687b      	ldr	r3, [r7, #4]
 8009304:	681b      	ldr	r3, [r3, #0]
 8009306:	6a1b      	ldr	r3, [r3, #32]
 8009308:	4a1c      	ldr	r2, [pc, #112]	; (800937c <HAL_TIM_PWM_Stop+0xec>)
 800930a:	4013      	ands	r3, r2
 800930c:	d10d      	bne.n	800932a <HAL_TIM_PWM_Stop+0x9a>
 800930e:	687b      	ldr	r3, [r7, #4]
 8009310:	681b      	ldr	r3, [r3, #0]
 8009312:	6a1b      	ldr	r3, [r3, #32]
 8009314:	4a1a      	ldr	r2, [pc, #104]	; (8009380 <HAL_TIM_PWM_Stop+0xf0>)
 8009316:	4013      	ands	r3, r2
 8009318:	d107      	bne.n	800932a <HAL_TIM_PWM_Stop+0x9a>
 800931a:	687b      	ldr	r3, [r7, #4]
 800931c:	681b      	ldr	r3, [r3, #0]
 800931e:	681a      	ldr	r2, [r3, #0]
 8009320:	687b      	ldr	r3, [r7, #4]
 8009322:	681b      	ldr	r3, [r3, #0]
 8009324:	2101      	movs	r1, #1
 8009326:	438a      	bics	r2, r1
 8009328:	601a      	str	r2, [r3, #0]

  /* Set the TIM channel state */
  TIM_CHANNEL_STATE_SET(htim, Channel, HAL_TIM_CHANNEL_STATE_READY);
 800932a:	683b      	ldr	r3, [r7, #0]
 800932c:	2b00      	cmp	r3, #0
 800932e:	d104      	bne.n	800933a <HAL_TIM_PWM_Stop+0xaa>
 8009330:	687b      	ldr	r3, [r7, #4]
 8009332:	223e      	movs	r2, #62	; 0x3e
 8009334:	2101      	movs	r1, #1
 8009336:	5499      	strb	r1, [r3, r2]
 8009338:	e013      	b.n	8009362 <HAL_TIM_PWM_Stop+0xd2>
 800933a:	683b      	ldr	r3, [r7, #0]
 800933c:	2b04      	cmp	r3, #4
 800933e:	d104      	bne.n	800934a <HAL_TIM_PWM_Stop+0xba>
 8009340:	687b      	ldr	r3, [r7, #4]
 8009342:	223f      	movs	r2, #63	; 0x3f
 8009344:	2101      	movs	r1, #1
 8009346:	5499      	strb	r1, [r3, r2]
 8009348:	e00b      	b.n	8009362 <HAL_TIM_PWM_Stop+0xd2>
 800934a:	683b      	ldr	r3, [r7, #0]
 800934c:	2b08      	cmp	r3, #8
 800934e:	d104      	bne.n	800935a <HAL_TIM_PWM_Stop+0xca>
 8009350:	687b      	ldr	r3, [r7, #4]
 8009352:	2240      	movs	r2, #64	; 0x40
 8009354:	2101      	movs	r1, #1
 8009356:	5499      	strb	r1, [r3, r2]
 8009358:	e003      	b.n	8009362 <HAL_TIM_PWM_Stop+0xd2>
 800935a:	687b      	ldr	r3, [r7, #4]
 800935c:	2241      	movs	r2, #65	; 0x41
 800935e:	2101      	movs	r1, #1
 8009360:	5499      	strb	r1, [r3, r2]

  /* Return function status */
  return HAL_OK;
 8009362:	2300      	movs	r3, #0
}
 8009364:	0018      	movs	r0, r3
 8009366:	46bd      	mov	sp, r7
 8009368:	b002      	add	sp, #8
 800936a:	bd80      	pop	{r7, pc}
 800936c:	40012c00 	.word	0x40012c00
 8009370:	40014000 	.word	0x40014000
 8009374:	40014400 	.word	0x40014400
 8009378:	40014800 	.word	0x40014800
 800937c:	00001111 	.word	0x00001111
 8009380:	00000444 	.word	0x00000444
 8009384:	ffff7fff 	.word	0xffff7fff

08009388 <HAL_TIM_PWM_ConfigChannel>:
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_TIM_PWM_ConfigChannel(TIM_HandleTypeDef *htim,
                                            TIM_OC_InitTypeDef *sConfig,
                                            uint32_t Channel)
{
 8009388:	b580      	push	{r7, lr}
 800938a:	b086      	sub	sp, #24
 800938c:	af00      	add	r7, sp, #0
 800938e:	60f8      	str	r0, [r7, #12]
 8009390:	60b9      	str	r1, [r7, #8]
 8009392:	607a      	str	r2, [r7, #4]
  HAL_StatusTypeDef status = HAL_OK;
 8009394:	2317      	movs	r3, #23
 8009396:	18fb      	adds	r3, r7, r3
 8009398:	2200      	movs	r2, #0
 800939a:	701a      	strb	r2, [r3, #0]
  assert_param(IS_TIM_PWM_MODE(sConfig->OCMode));
  assert_param(IS_TIM_OC_POLARITY(sConfig->OCPolarity));
  assert_param(IS_TIM_FAST_STATE(sConfig->OCFastMode));

  /* Process Locked */
  __HAL_LOCK(htim);
 800939c:	68fb      	ldr	r3, [r7, #12]
 800939e:	223c      	movs	r2, #60	; 0x3c
 80093a0:	5c9b      	ldrb	r3, [r3, r2]
 80093a2:	2b01      	cmp	r3, #1
 80093a4:	d101      	bne.n	80093aa <HAL_TIM_PWM_ConfigChannel+0x22>
 80093a6:	2302      	movs	r3, #2
 80093a8:	e0ad      	b.n	8009506 <HAL_TIM_PWM_ConfigChannel+0x17e>
 80093aa:	68fb      	ldr	r3, [r7, #12]
 80093ac:	223c      	movs	r2, #60	; 0x3c
 80093ae:	2101      	movs	r1, #1
 80093b0:	5499      	strb	r1, [r3, r2]

  switch (Channel)
 80093b2:	687b      	ldr	r3, [r7, #4]
 80093b4:	2b0c      	cmp	r3, #12
 80093b6:	d100      	bne.n	80093ba <HAL_TIM_PWM_ConfigChannel+0x32>
 80093b8:	e076      	b.n	80094a8 <HAL_TIM_PWM_ConfigChannel+0x120>
 80093ba:	687b      	ldr	r3, [r7, #4]
 80093bc:	2b0c      	cmp	r3, #12
 80093be:	d900      	bls.n	80093c2 <HAL_TIM_PWM_ConfigChannel+0x3a>
 80093c0:	e095      	b.n	80094ee <HAL_TIM_PWM_ConfigChannel+0x166>
 80093c2:	687b      	ldr	r3, [r7, #4]
 80093c4:	2b08      	cmp	r3, #8
 80093c6:	d04e      	beq.n	8009466 <HAL_TIM_PWM_ConfigChannel+0xde>
 80093c8:	687b      	ldr	r3, [r7, #4]
 80093ca:	2b08      	cmp	r3, #8
 80093cc:	d900      	bls.n	80093d0 <HAL_TIM_PWM_ConfigChannel+0x48>
 80093ce:	e08e      	b.n	80094ee <HAL_TIM_PWM_ConfigChannel+0x166>
 80093d0:	687b      	ldr	r3, [r7, #4]
 80093d2:	2b00      	cmp	r3, #0
 80093d4:	d003      	beq.n	80093de <HAL_TIM_PWM_ConfigChannel+0x56>
 80093d6:	687b      	ldr	r3, [r7, #4]
 80093d8:	2b04      	cmp	r3, #4
 80093da:	d021      	beq.n	8009420 <HAL_TIM_PWM_ConfigChannel+0x98>
 80093dc:	e087      	b.n	80094ee <HAL_TIM_PWM_ConfigChannel+0x166>
    {
      /* Check the parameters */
      assert_param(IS_TIM_CC1_INSTANCE(htim->Instance));

      /* Configure the Channel 1 in PWM mode */
      TIM_OC1_SetConfig(htim->Instance, sConfig);
 80093de:	68fb      	ldr	r3, [r7, #12]
 80093e0:	681b      	ldr	r3, [r3, #0]
 80093e2:	68ba      	ldr	r2, [r7, #8]
 80093e4:	0011      	movs	r1, r2
 80093e6:	0018      	movs	r0, r3
 80093e8:	f000 f914 	bl	8009614 <TIM_OC1_SetConfig>

      /* Set the Preload enable bit for channel1 */
      htim->Instance->CCMR1 |= TIM_CCMR1_OC1PE;
 80093ec:	68fb      	ldr	r3, [r7, #12]
 80093ee:	681b      	ldr	r3, [r3, #0]
 80093f0:	699a      	ldr	r2, [r3, #24]
 80093f2:	68fb      	ldr	r3, [r7, #12]
 80093f4:	681b      	ldr	r3, [r3, #0]
 80093f6:	2108      	movs	r1, #8
 80093f8:	430a      	orrs	r2, r1
 80093fa:	619a      	str	r2, [r3, #24]

      /* Configure the Output Fast mode */
      htim->Instance->CCMR1 &= ~TIM_CCMR1_OC1FE;
 80093fc:	68fb      	ldr	r3, [r7, #12]
 80093fe:	681b      	ldr	r3, [r3, #0]
 8009400:	699a      	ldr	r2, [r3, #24]
 8009402:	68fb      	ldr	r3, [r7, #12]
 8009404:	681b      	ldr	r3, [r3, #0]
 8009406:	2104      	movs	r1, #4
 8009408:	438a      	bics	r2, r1
 800940a:	619a      	str	r2, [r3, #24]
      htim->Instance->CCMR1 |= sConfig->OCFastMode;
 800940c:	68fb      	ldr	r3, [r7, #12]
 800940e:	681b      	ldr	r3, [r3, #0]
 8009410:	6999      	ldr	r1, [r3, #24]
 8009412:	68bb      	ldr	r3, [r7, #8]
 8009414:	691a      	ldr	r2, [r3, #16]
 8009416:	68fb      	ldr	r3, [r7, #12]
 8009418:	681b      	ldr	r3, [r3, #0]
 800941a:	430a      	orrs	r2, r1
 800941c:	619a      	str	r2, [r3, #24]
      break;
 800941e:	e06b      	b.n	80094f8 <HAL_TIM_PWM_ConfigChannel+0x170>
    {
      /* Check the parameters */
      assert_param(IS_TIM_CC2_INSTANCE(htim->Instance));

      /* Configure the Channel 2 in PWM mode */
      TIM_OC2_SetConfig(htim->Instance, sConfig);
 8009420:	68fb      	ldr	r3, [r7, #12]
 8009422:	681b      	ldr	r3, [r3, #0]
 8009424:	68ba      	ldr	r2, [r7, #8]
 8009426:	0011      	movs	r1, r2
 8009428:	0018      	movs	r0, r3
 800942a:	f000 f97b 	bl	8009724 <TIM_OC2_SetConfig>

      /* Set the Preload enable bit for channel2 */
      htim->Instance->CCMR1 |= TIM_CCMR1_OC2PE;
 800942e:	68fb      	ldr	r3, [r7, #12]
 8009430:	681b      	ldr	r3, [r3, #0]
 8009432:	699a      	ldr	r2, [r3, #24]
 8009434:	68fb      	ldr	r3, [r7, #12]
 8009436:	681b      	ldr	r3, [r3, #0]
 8009438:	2180      	movs	r1, #128	; 0x80
 800943a:	0109      	lsls	r1, r1, #4
 800943c:	430a      	orrs	r2, r1
 800943e:	619a      	str	r2, [r3, #24]

      /* Configure the Output Fast mode */
      htim->Instance->CCMR1 &= ~TIM_CCMR1_OC2FE;
 8009440:	68fb      	ldr	r3, [r7, #12]
 8009442:	681b      	ldr	r3, [r3, #0]
 8009444:	699a      	ldr	r2, [r3, #24]
 8009446:	68fb      	ldr	r3, [r7, #12]
 8009448:	681b      	ldr	r3, [r3, #0]
 800944a:	4931      	ldr	r1, [pc, #196]	; (8009510 <HAL_TIM_PWM_ConfigChannel+0x188>)
 800944c:	400a      	ands	r2, r1
 800944e:	619a      	str	r2, [r3, #24]
      htim->Instance->CCMR1 |= sConfig->OCFastMode << 8U;
 8009450:	68fb      	ldr	r3, [r7, #12]
 8009452:	681b      	ldr	r3, [r3, #0]
 8009454:	6999      	ldr	r1, [r3, #24]
 8009456:	68bb      	ldr	r3, [r7, #8]
 8009458:	691b      	ldr	r3, [r3, #16]
 800945a:	021a      	lsls	r2, r3, #8
 800945c:	68fb      	ldr	r3, [r7, #12]
 800945e:	681b      	ldr	r3, [r3, #0]
 8009460:	430a      	orrs	r2, r1
 8009462:	619a      	str	r2, [r3, #24]
      break;
 8009464:	e048      	b.n	80094f8 <HAL_TIM_PWM_ConfigChannel+0x170>
    {
      /* Check the parameters */
      assert_param(IS_TIM_CC3_INSTANCE(htim->Instance));

      /* Configure the Channel 3 in PWM mode */
      TIM_OC3_SetConfig(htim->Instance, sConfig);
 8009466:	68fb      	ldr	r3, [r7, #12]
 8009468:	681b      	ldr	r3, [r3, #0]
 800946a:	68ba      	ldr	r2, [r7, #8]
 800946c:	0011      	movs	r1, r2
 800946e:	0018      	movs	r0, r3
 8009470:	f000 f9dc 	bl	800982c <TIM_OC3_SetConfig>

      /* Set the Preload enable bit for channel3 */
      htim->Instance->CCMR2 |= TIM_CCMR2_OC3PE;
 8009474:	68fb      	ldr	r3, [r7, #12]
 8009476:	681b      	ldr	r3, [r3, #0]
 8009478:	69da      	ldr	r2, [r3, #28]
 800947a:	68fb      	ldr	r3, [r7, #12]
 800947c:	681b      	ldr	r3, [r3, #0]
 800947e:	2108      	movs	r1, #8
 8009480:	430a      	orrs	r2, r1
 8009482:	61da      	str	r2, [r3, #28]

      /* Configure the Output Fast mode */
      htim->Instance->CCMR2 &= ~TIM_CCMR2_OC3FE;
 8009484:	68fb      	ldr	r3, [r7, #12]
 8009486:	681b      	ldr	r3, [r3, #0]
 8009488:	69da      	ldr	r2, [r3, #28]
 800948a:	68fb      	ldr	r3, [r7, #12]
 800948c:	681b      	ldr	r3, [r3, #0]
 800948e:	2104      	movs	r1, #4
 8009490:	438a      	bics	r2, r1
 8009492:	61da      	str	r2, [r3, #28]
      htim->Instance->CCMR2 |= sConfig->OCFastMode;
 8009494:	68fb      	ldr	r3, [r7, #12]
 8009496:	681b      	ldr	r3, [r3, #0]
 8009498:	69d9      	ldr	r1, [r3, #28]
 800949a:	68bb      	ldr	r3, [r7, #8]
 800949c:	691a      	ldr	r2, [r3, #16]
 800949e:	68fb      	ldr	r3, [r7, #12]
 80094a0:	681b      	ldr	r3, [r3, #0]
 80094a2:	430a      	orrs	r2, r1
 80094a4:	61da      	str	r2, [r3, #28]
      break;
 80094a6:	e027      	b.n	80094f8 <HAL_TIM_PWM_ConfigChannel+0x170>
    {
      /* Check the parameters */
      assert_param(IS_TIM_CC4_INSTANCE(htim->Instance));

      /* Configure the Channel 4 in PWM mode */
      TIM_OC4_SetConfig(htim->Instance, sConfig);
 80094a8:	68fb      	ldr	r3, [r7, #12]
 80094aa:	681b      	ldr	r3, [r3, #0]
 80094ac:	68ba      	ldr	r2, [r7, #8]
 80094ae:	0011      	movs	r1, r2
 80094b0:	0018      	movs	r0, r3
 80094b2:	f000 fa41 	bl	8009938 <TIM_OC4_SetConfig>

      /* Set the Preload enable bit for channel4 */
      htim->Instance->CCMR2 |= TIM_CCMR2_OC4PE;
 80094b6:	68fb      	ldr	r3, [r7, #12]
 80094b8:	681b      	ldr	r3, [r3, #0]
 80094ba:	69da      	ldr	r2, [r3, #28]
 80094bc:	68fb      	ldr	r3, [r7, #12]
 80094be:	681b      	ldr	r3, [r3, #0]
 80094c0:	2180      	movs	r1, #128	; 0x80
 80094c2:	0109      	lsls	r1, r1, #4
 80094c4:	430a      	orrs	r2, r1
 80094c6:	61da      	str	r2, [r3, #28]

      /* Configure the Output Fast mode */
      htim->Instance->CCMR2 &= ~TIM_CCMR2_OC4FE;
 80094c8:	68fb      	ldr	r3, [r7, #12]
 80094ca:	681b      	ldr	r3, [r3, #0]
 80094cc:	69da      	ldr	r2, [r3, #28]
 80094ce:	68fb      	ldr	r3, [r7, #12]
 80094d0:	681b      	ldr	r3, [r3, #0]
 80094d2:	490f      	ldr	r1, [pc, #60]	; (8009510 <HAL_TIM_PWM_ConfigChannel+0x188>)
 80094d4:	400a      	ands	r2, r1
 80094d6:	61da      	str	r2, [r3, #28]
      htim->Instance->CCMR2 |= sConfig->OCFastMode << 8U;
 80094d8:	68fb      	ldr	r3, [r7, #12]
 80094da:	681b      	ldr	r3, [r3, #0]
 80094dc:	69d9      	ldr	r1, [r3, #28]
 80094de:	68bb      	ldr	r3, [r7, #8]
 80094e0:	691b      	ldr	r3, [r3, #16]
 80094e2:	021a      	lsls	r2, r3, #8
 80094e4:	68fb      	ldr	r3, [r7, #12]
 80094e6:	681b      	ldr	r3, [r3, #0]
 80094e8:	430a      	orrs	r2, r1
 80094ea:	61da      	str	r2, [r3, #28]
      break;
 80094ec:	e004      	b.n	80094f8 <HAL_TIM_PWM_ConfigChannel+0x170>
    }

    default:
      status = HAL_ERROR;
 80094ee:	2317      	movs	r3, #23
 80094f0:	18fb      	adds	r3, r7, r3
 80094f2:	2201      	movs	r2, #1
 80094f4:	701a      	strb	r2, [r3, #0]
      break;
 80094f6:	46c0      	nop			; (mov r8, r8)
  }

  __HAL_UNLOCK(htim);
 80094f8:	68fb      	ldr	r3, [r7, #12]
 80094fa:	223c      	movs	r2, #60	; 0x3c
 80094fc:	2100      	movs	r1, #0
 80094fe:	5499      	strb	r1, [r3, r2]

  return status;
 8009500:	2317      	movs	r3, #23
 8009502:	18fb      	adds	r3, r7, r3
 8009504:	781b      	ldrb	r3, [r3, #0]
}
 8009506:	0018      	movs	r0, r3
 8009508:	46bd      	mov	sp, r7
 800950a:	b006      	add	sp, #24
 800950c:	bd80      	pop	{r7, pc}
 800950e:	46c0      	nop			; (mov r8, r8)
 8009510:	fffffbff 	.word	0xfffffbff

08009514 <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)
{
 8009514:	b580      	push	{r7, lr}
 8009516:	b084      	sub	sp, #16
 8009518:	af00      	add	r7, sp, #0
 800951a:	6078      	str	r0, [r7, #4]
 800951c:	6039      	str	r1, [r7, #0]
  uint32_t tmpcr1;
  tmpcr1 = TIMx->CR1;
 800951e:	687b      	ldr	r3, [r7, #4]
 8009520:	681b      	ldr	r3, [r3, #0]
 8009522:	60fb      	str	r3, [r7, #12]

  /* Set TIM Time Base Unit parameters ---------------------------------------*/
  if (IS_TIM_COUNTER_MODE_SELECT_INSTANCE(TIMx))
 8009524:	687b      	ldr	r3, [r7, #4]
 8009526:	4a34      	ldr	r2, [pc, #208]	; (80095f8 <TIM_Base_SetConfig+0xe4>)
 8009528:	4293      	cmp	r3, r2
 800952a:	d008      	beq.n	800953e <TIM_Base_SetConfig+0x2a>
 800952c:	687a      	ldr	r2, [r7, #4]
 800952e:	2380      	movs	r3, #128	; 0x80
 8009530:	05db      	lsls	r3, r3, #23
 8009532:	429a      	cmp	r2, r3
 8009534:	d003      	beq.n	800953e <TIM_Base_SetConfig+0x2a>
 8009536:	687b      	ldr	r3, [r7, #4]
 8009538:	4a30      	ldr	r2, [pc, #192]	; (80095fc <TIM_Base_SetConfig+0xe8>)
 800953a:	4293      	cmp	r3, r2
 800953c:	d108      	bne.n	8009550 <TIM_Base_SetConfig+0x3c>
  {
    /* Select the Counter Mode */
    tmpcr1 &= ~(TIM_CR1_DIR | TIM_CR1_CMS);
 800953e:	68fb      	ldr	r3, [r7, #12]
 8009540:	2270      	movs	r2, #112	; 0x70
 8009542:	4393      	bics	r3, r2
 8009544:	60fb      	str	r3, [r7, #12]
    tmpcr1 |= Structure->CounterMode;
 8009546:	683b      	ldr	r3, [r7, #0]
 8009548:	685b      	ldr	r3, [r3, #4]
 800954a:	68fa      	ldr	r2, [r7, #12]
 800954c:	4313      	orrs	r3, r2
 800954e:	60fb      	str	r3, [r7, #12]
  }

  if (IS_TIM_CLOCK_DIVISION_INSTANCE(TIMx))
 8009550:	687b      	ldr	r3, [r7, #4]
 8009552:	4a29      	ldr	r2, [pc, #164]	; (80095f8 <TIM_Base_SetConfig+0xe4>)
 8009554:	4293      	cmp	r3, r2
 8009556:	d018      	beq.n	800958a <TIM_Base_SetConfig+0x76>
 8009558:	687a      	ldr	r2, [r7, #4]
 800955a:	2380      	movs	r3, #128	; 0x80
 800955c:	05db      	lsls	r3, r3, #23
 800955e:	429a      	cmp	r2, r3
 8009560:	d013      	beq.n	800958a <TIM_Base_SetConfig+0x76>
 8009562:	687b      	ldr	r3, [r7, #4]
 8009564:	4a25      	ldr	r2, [pc, #148]	; (80095fc <TIM_Base_SetConfig+0xe8>)
 8009566:	4293      	cmp	r3, r2
 8009568:	d00f      	beq.n	800958a <TIM_Base_SetConfig+0x76>
 800956a:	687b      	ldr	r3, [r7, #4]
 800956c:	4a24      	ldr	r2, [pc, #144]	; (8009600 <TIM_Base_SetConfig+0xec>)
 800956e:	4293      	cmp	r3, r2
 8009570:	d00b      	beq.n	800958a <TIM_Base_SetConfig+0x76>
 8009572:	687b      	ldr	r3, [r7, #4]
 8009574:	4a23      	ldr	r2, [pc, #140]	; (8009604 <TIM_Base_SetConfig+0xf0>)
 8009576:	4293      	cmp	r3, r2
 8009578:	d007      	beq.n	800958a <TIM_Base_SetConfig+0x76>
 800957a:	687b      	ldr	r3, [r7, #4]
 800957c:	4a22      	ldr	r2, [pc, #136]	; (8009608 <TIM_Base_SetConfig+0xf4>)
 800957e:	4293      	cmp	r3, r2
 8009580:	d003      	beq.n	800958a <TIM_Base_SetConfig+0x76>
 8009582:	687b      	ldr	r3, [r7, #4]
 8009584:	4a21      	ldr	r2, [pc, #132]	; (800960c <TIM_Base_SetConfig+0xf8>)
 8009586:	4293      	cmp	r3, r2
 8009588:	d108      	bne.n	800959c <TIM_Base_SetConfig+0x88>
  {
    /* Set the clock division */
    tmpcr1 &= ~TIM_CR1_CKD;
 800958a:	68fb      	ldr	r3, [r7, #12]
 800958c:	4a20      	ldr	r2, [pc, #128]	; (8009610 <TIM_Base_SetConfig+0xfc>)
 800958e:	4013      	ands	r3, r2
 8009590:	60fb      	str	r3, [r7, #12]
    tmpcr1 |= (uint32_t)Structure->ClockDivision;
 8009592:	683b      	ldr	r3, [r7, #0]
 8009594:	68db      	ldr	r3, [r3, #12]
 8009596:	68fa      	ldr	r2, [r7, #12]
 8009598:	4313      	orrs	r3, r2
 800959a:	60fb      	str	r3, [r7, #12]
  }

  /* Set the auto-reload preload */
  MODIFY_REG(tmpcr1, TIM_CR1_ARPE, Structure->AutoReloadPreload);
 800959c:	68fb      	ldr	r3, [r7, #12]
 800959e:	2280      	movs	r2, #128	; 0x80
 80095a0:	4393      	bics	r3, r2
 80095a2:	001a      	movs	r2, r3
 80095a4:	683b      	ldr	r3, [r7, #0]
 80095a6:	695b      	ldr	r3, [r3, #20]
 80095a8:	4313      	orrs	r3, r2
 80095aa:	60fb      	str	r3, [r7, #12]

  TIMx->CR1 = tmpcr1;
 80095ac:	687b      	ldr	r3, [r7, #4]
 80095ae:	68fa      	ldr	r2, [r7, #12]
 80095b0:	601a      	str	r2, [r3, #0]

  /* Set the Autoreload value */
  TIMx->ARR = (uint32_t)Structure->Period ;
 80095b2:	683b      	ldr	r3, [r7, #0]
 80095b4:	689a      	ldr	r2, [r3, #8]
 80095b6:	687b      	ldr	r3, [r7, #4]
 80095b8:	62da      	str	r2, [r3, #44]	; 0x2c

  /* Set the Prescaler value */
  TIMx->PSC = Structure->Prescaler;
 80095ba:	683b      	ldr	r3, [r7, #0]
 80095bc:	681a      	ldr	r2, [r3, #0]
 80095be:	687b      	ldr	r3, [r7, #4]
 80095c0:	629a      	str	r2, [r3, #40]	; 0x28

  if (IS_TIM_REPETITION_COUNTER_INSTANCE(TIMx))
 80095c2:	687b      	ldr	r3, [r7, #4]
 80095c4:	4a0c      	ldr	r2, [pc, #48]	; (80095f8 <TIM_Base_SetConfig+0xe4>)
 80095c6:	4293      	cmp	r3, r2
 80095c8:	d00b      	beq.n	80095e2 <TIM_Base_SetConfig+0xce>
 80095ca:	687b      	ldr	r3, [r7, #4]
 80095cc:	4a0d      	ldr	r2, [pc, #52]	; (8009604 <TIM_Base_SetConfig+0xf0>)
 80095ce:	4293      	cmp	r3, r2
 80095d0:	d007      	beq.n	80095e2 <TIM_Base_SetConfig+0xce>
 80095d2:	687b      	ldr	r3, [r7, #4]
 80095d4:	4a0c      	ldr	r2, [pc, #48]	; (8009608 <TIM_Base_SetConfig+0xf4>)
 80095d6:	4293      	cmp	r3, r2
 80095d8:	d003      	beq.n	80095e2 <TIM_Base_SetConfig+0xce>
 80095da:	687b      	ldr	r3, [r7, #4]
 80095dc:	4a0b      	ldr	r2, [pc, #44]	; (800960c <TIM_Base_SetConfig+0xf8>)
 80095de:	4293      	cmp	r3, r2
 80095e0:	d103      	bne.n	80095ea <TIM_Base_SetConfig+0xd6>
  {
    /* Set the Repetition Counter value */
    TIMx->RCR = Structure->RepetitionCounter;
 80095e2:	683b      	ldr	r3, [r7, #0]
 80095e4:	691a      	ldr	r2, [r3, #16]
 80095e6:	687b      	ldr	r3, [r7, #4]
 80095e8:	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;
 80095ea:	687b      	ldr	r3, [r7, #4]
 80095ec:	2201      	movs	r2, #1
 80095ee:	615a      	str	r2, [r3, #20]
}
 80095f0:	46c0      	nop			; (mov r8, r8)
 80095f2:	46bd      	mov	sp, r7
 80095f4:	b004      	add	sp, #16
 80095f6:	bd80      	pop	{r7, pc}
 80095f8:	40012c00 	.word	0x40012c00
 80095fc:	40000400 	.word	0x40000400
 8009600:	40002000 	.word	0x40002000
 8009604:	40014000 	.word	0x40014000
 8009608:	40014400 	.word	0x40014400
 800960c:	40014800 	.word	0x40014800
 8009610:	fffffcff 	.word	0xfffffcff

08009614 <TIM_OC1_SetConfig>:
  * @param  TIMx to select the TIM peripheral
  * @param  OC_Config The output configuration structure
  * @retval None
  */
static void TIM_OC1_SetConfig(TIM_TypeDef *TIMx, TIM_OC_InitTypeDef *OC_Config)
{
 8009614:	b580      	push	{r7, lr}
 8009616:	b086      	sub	sp, #24
 8009618:	af00      	add	r7, sp, #0
 800961a:	6078      	str	r0, [r7, #4]
 800961c:	6039      	str	r1, [r7, #0]
  uint32_t tmpccmrx;
  uint32_t tmpccer;
  uint32_t tmpcr2;

  /* Disable the Channel 1: Reset the CC1E Bit */
  TIMx->CCER &= ~TIM_CCER_CC1E;
 800961e:	687b      	ldr	r3, [r7, #4]
 8009620:	6a1b      	ldr	r3, [r3, #32]
 8009622:	2201      	movs	r2, #1
 8009624:	4393      	bics	r3, r2
 8009626:	001a      	movs	r2, r3
 8009628:	687b      	ldr	r3, [r7, #4]
 800962a:	621a      	str	r2, [r3, #32]

  /* Get the TIMx CCER register value */
  tmpccer = TIMx->CCER;
 800962c:	687b      	ldr	r3, [r7, #4]
 800962e:	6a1b      	ldr	r3, [r3, #32]
 8009630:	617b      	str	r3, [r7, #20]
  /* Get the TIMx CR2 register value */
  tmpcr2 =  TIMx->CR2;
 8009632:	687b      	ldr	r3, [r7, #4]
 8009634:	685b      	ldr	r3, [r3, #4]
 8009636:	613b      	str	r3, [r7, #16]

  /* Get the TIMx CCMR1 register value */
  tmpccmrx = TIMx->CCMR1;
 8009638:	687b      	ldr	r3, [r7, #4]
 800963a:	699b      	ldr	r3, [r3, #24]
 800963c:	60fb      	str	r3, [r7, #12]

  /* Reset the Output Compare Mode Bits */
  tmpccmrx &= ~TIM_CCMR1_OC1M;
 800963e:	68fb      	ldr	r3, [r7, #12]
 8009640:	2270      	movs	r2, #112	; 0x70
 8009642:	4393      	bics	r3, r2
 8009644:	60fb      	str	r3, [r7, #12]
  tmpccmrx &= ~TIM_CCMR1_CC1S;
 8009646:	68fb      	ldr	r3, [r7, #12]
 8009648:	2203      	movs	r2, #3
 800964a:	4393      	bics	r3, r2
 800964c:	60fb      	str	r3, [r7, #12]
  /* Select the Output Compare Mode */
  tmpccmrx |= OC_Config->OCMode;
 800964e:	683b      	ldr	r3, [r7, #0]
 8009650:	681b      	ldr	r3, [r3, #0]
 8009652:	68fa      	ldr	r2, [r7, #12]
 8009654:	4313      	orrs	r3, r2
 8009656:	60fb      	str	r3, [r7, #12]

  /* Reset the Output Polarity level */
  tmpccer &= ~TIM_CCER_CC1P;
 8009658:	697b      	ldr	r3, [r7, #20]
 800965a:	2202      	movs	r2, #2
 800965c:	4393      	bics	r3, r2
 800965e:	617b      	str	r3, [r7, #20]
  /* Set the Output Compare Polarity */
  tmpccer |= OC_Config->OCPolarity;
 8009660:	683b      	ldr	r3, [r7, #0]
 8009662:	689b      	ldr	r3, [r3, #8]
 8009664:	697a      	ldr	r2, [r7, #20]
 8009666:	4313      	orrs	r3, r2
 8009668:	617b      	str	r3, [r7, #20]

  if (IS_TIM_CCXN_INSTANCE(TIMx, TIM_CHANNEL_1))
 800966a:	687b      	ldr	r3, [r7, #4]
 800966c:	4a27      	ldr	r2, [pc, #156]	; (800970c <TIM_OC1_SetConfig+0xf8>)
 800966e:	4293      	cmp	r3, r2
 8009670:	d00b      	beq.n	800968a <TIM_OC1_SetConfig+0x76>
 8009672:	687b      	ldr	r3, [r7, #4]
 8009674:	4a26      	ldr	r2, [pc, #152]	; (8009710 <TIM_OC1_SetConfig+0xfc>)
 8009676:	4293      	cmp	r3, r2
 8009678:	d007      	beq.n	800968a <TIM_OC1_SetConfig+0x76>
 800967a:	687b      	ldr	r3, [r7, #4]
 800967c:	4a25      	ldr	r2, [pc, #148]	; (8009714 <TIM_OC1_SetConfig+0x100>)
 800967e:	4293      	cmp	r3, r2
 8009680:	d003      	beq.n	800968a <TIM_OC1_SetConfig+0x76>
 8009682:	687b      	ldr	r3, [r7, #4]
 8009684:	4a24      	ldr	r2, [pc, #144]	; (8009718 <TIM_OC1_SetConfig+0x104>)
 8009686:	4293      	cmp	r3, r2
 8009688:	d10c      	bne.n	80096a4 <TIM_OC1_SetConfig+0x90>
  {
    /* Check parameters */
    assert_param(IS_TIM_OCN_POLARITY(OC_Config->OCNPolarity));

    /* Reset the Output N Polarity level */
    tmpccer &= ~TIM_CCER_CC1NP;
 800968a:	697b      	ldr	r3, [r7, #20]
 800968c:	2208      	movs	r2, #8
 800968e:	4393      	bics	r3, r2
 8009690:	617b      	str	r3, [r7, #20]
    /* Set the Output N Polarity */
    tmpccer |= OC_Config->OCNPolarity;
 8009692:	683b      	ldr	r3, [r7, #0]
 8009694:	68db      	ldr	r3, [r3, #12]
 8009696:	697a      	ldr	r2, [r7, #20]
 8009698:	4313      	orrs	r3, r2
 800969a:	617b      	str	r3, [r7, #20]
    /* Reset the Output N State */
    tmpccer &= ~TIM_CCER_CC1NE;
 800969c:	697b      	ldr	r3, [r7, #20]
 800969e:	2204      	movs	r2, #4
 80096a0:	4393      	bics	r3, r2
 80096a2:	617b      	str	r3, [r7, #20]
  }

  if (IS_TIM_BREAK_INSTANCE(TIMx))
 80096a4:	687b      	ldr	r3, [r7, #4]
 80096a6:	4a19      	ldr	r2, [pc, #100]	; (800970c <TIM_OC1_SetConfig+0xf8>)
 80096a8:	4293      	cmp	r3, r2
 80096aa:	d00b      	beq.n	80096c4 <TIM_OC1_SetConfig+0xb0>
 80096ac:	687b      	ldr	r3, [r7, #4]
 80096ae:	4a18      	ldr	r2, [pc, #96]	; (8009710 <TIM_OC1_SetConfig+0xfc>)
 80096b0:	4293      	cmp	r3, r2
 80096b2:	d007      	beq.n	80096c4 <TIM_OC1_SetConfig+0xb0>
 80096b4:	687b      	ldr	r3, [r7, #4]
 80096b6:	4a17      	ldr	r2, [pc, #92]	; (8009714 <TIM_OC1_SetConfig+0x100>)
 80096b8:	4293      	cmp	r3, r2
 80096ba:	d003      	beq.n	80096c4 <TIM_OC1_SetConfig+0xb0>
 80096bc:	687b      	ldr	r3, [r7, #4]
 80096be:	4a16      	ldr	r2, [pc, #88]	; (8009718 <TIM_OC1_SetConfig+0x104>)
 80096c0:	4293      	cmp	r3, r2
 80096c2:	d111      	bne.n	80096e8 <TIM_OC1_SetConfig+0xd4>
    /* Check parameters */
    assert_param(IS_TIM_OCNIDLE_STATE(OC_Config->OCNIdleState));
    assert_param(IS_TIM_OCIDLE_STATE(OC_Config->OCIdleState));

    /* Reset the Output Compare and Output Compare N IDLE State */
    tmpcr2 &= ~TIM_CR2_OIS1;
 80096c4:	693b      	ldr	r3, [r7, #16]
 80096c6:	4a15      	ldr	r2, [pc, #84]	; (800971c <TIM_OC1_SetConfig+0x108>)
 80096c8:	4013      	ands	r3, r2
 80096ca:	613b      	str	r3, [r7, #16]
    tmpcr2 &= ~TIM_CR2_OIS1N;
 80096cc:	693b      	ldr	r3, [r7, #16]
 80096ce:	4a14      	ldr	r2, [pc, #80]	; (8009720 <TIM_OC1_SetConfig+0x10c>)
 80096d0:	4013      	ands	r3, r2
 80096d2:	613b      	str	r3, [r7, #16]
    /* Set the Output Idle state */
    tmpcr2 |= OC_Config->OCIdleState;
 80096d4:	683b      	ldr	r3, [r7, #0]
 80096d6:	695b      	ldr	r3, [r3, #20]
 80096d8:	693a      	ldr	r2, [r7, #16]
 80096da:	4313      	orrs	r3, r2
 80096dc:	613b      	str	r3, [r7, #16]
    /* Set the Output N Idle state */
    tmpcr2 |= OC_Config->OCNIdleState;
 80096de:	683b      	ldr	r3, [r7, #0]
 80096e0:	699b      	ldr	r3, [r3, #24]
 80096e2:	693a      	ldr	r2, [r7, #16]
 80096e4:	4313      	orrs	r3, r2
 80096e6:	613b      	str	r3, [r7, #16]
  }

  /* Write to TIMx CR2 */
  TIMx->CR2 = tmpcr2;
 80096e8:	687b      	ldr	r3, [r7, #4]
 80096ea:	693a      	ldr	r2, [r7, #16]
 80096ec:	605a      	str	r2, [r3, #4]

  /* Write to TIMx CCMR1 */
  TIMx->CCMR1 = tmpccmrx;
 80096ee:	687b      	ldr	r3, [r7, #4]
 80096f0:	68fa      	ldr	r2, [r7, #12]
 80096f2:	619a      	str	r2, [r3, #24]

  /* Set the Capture Compare Register value */
  TIMx->CCR1 = OC_Config->Pulse;
 80096f4:	683b      	ldr	r3, [r7, #0]
 80096f6:	685a      	ldr	r2, [r3, #4]
 80096f8:	687b      	ldr	r3, [r7, #4]
 80096fa:	635a      	str	r2, [r3, #52]	; 0x34

  /* Write to TIMx CCER */
  TIMx->CCER = tmpccer;
 80096fc:	687b      	ldr	r3, [r7, #4]
 80096fe:	697a      	ldr	r2, [r7, #20]
 8009700:	621a      	str	r2, [r3, #32]
}
 8009702:	46c0      	nop			; (mov r8, r8)
 8009704:	46bd      	mov	sp, r7
 8009706:	b006      	add	sp, #24
 8009708:	bd80      	pop	{r7, pc}
 800970a:	46c0      	nop			; (mov r8, r8)
 800970c:	40012c00 	.word	0x40012c00
 8009710:	40014000 	.word	0x40014000
 8009714:	40014400 	.word	0x40014400
 8009718:	40014800 	.word	0x40014800
 800971c:	fffffeff 	.word	0xfffffeff
 8009720:	fffffdff 	.word	0xfffffdff

08009724 <TIM_OC2_SetConfig>:
  * @param  TIMx to select the TIM peripheral
  * @param  OC_Config The output configuration structure
  * @retval None
  */
void TIM_OC2_SetConfig(TIM_TypeDef *TIMx, TIM_OC_InitTypeDef *OC_Config)
{
 8009724:	b580      	push	{r7, lr}
 8009726:	b086      	sub	sp, #24
 8009728:	af00      	add	r7, sp, #0
 800972a:	6078      	str	r0, [r7, #4]
 800972c:	6039      	str	r1, [r7, #0]
  uint32_t tmpccmrx;
  uint32_t tmpccer;
  uint32_t tmpcr2;

  /* Disable the Channel 2: Reset the CC2E Bit */
  TIMx->CCER &= ~TIM_CCER_CC2E;
 800972e:	687b      	ldr	r3, [r7, #4]
 8009730:	6a1b      	ldr	r3, [r3, #32]
 8009732:	2210      	movs	r2, #16
 8009734:	4393      	bics	r3, r2
 8009736:	001a      	movs	r2, r3
 8009738:	687b      	ldr	r3, [r7, #4]
 800973a:	621a      	str	r2, [r3, #32]

  /* Get the TIMx CCER register value */
  tmpccer = TIMx->CCER;
 800973c:	687b      	ldr	r3, [r7, #4]
 800973e:	6a1b      	ldr	r3, [r3, #32]
 8009740:	617b      	str	r3, [r7, #20]
  /* Get the TIMx CR2 register value */
  tmpcr2 =  TIMx->CR2;
 8009742:	687b      	ldr	r3, [r7, #4]
 8009744:	685b      	ldr	r3, [r3, #4]
 8009746:	613b      	str	r3, [r7, #16]

  /* Get the TIMx CCMR1 register value */
  tmpccmrx = TIMx->CCMR1;
 8009748:	687b      	ldr	r3, [r7, #4]
 800974a:	699b      	ldr	r3, [r3, #24]
 800974c:	60fb      	str	r3, [r7, #12]

  /* Reset the Output Compare mode and Capture/Compare selection Bits */
  tmpccmrx &= ~TIM_CCMR1_OC2M;
 800974e:	68fb      	ldr	r3, [r7, #12]
 8009750:	4a2e      	ldr	r2, [pc, #184]	; (800980c <TIM_OC2_SetConfig+0xe8>)
 8009752:	4013      	ands	r3, r2
 8009754:	60fb      	str	r3, [r7, #12]
  tmpccmrx &= ~TIM_CCMR1_CC2S;
 8009756:	68fb      	ldr	r3, [r7, #12]
 8009758:	4a2d      	ldr	r2, [pc, #180]	; (8009810 <TIM_OC2_SetConfig+0xec>)
 800975a:	4013      	ands	r3, r2
 800975c:	60fb      	str	r3, [r7, #12]

  /* Select the Output Compare Mode */
  tmpccmrx |= (OC_Config->OCMode << 8U);
 800975e:	683b      	ldr	r3, [r7, #0]
 8009760:	681b      	ldr	r3, [r3, #0]
 8009762:	021b      	lsls	r3, r3, #8
 8009764:	68fa      	ldr	r2, [r7, #12]
 8009766:	4313      	orrs	r3, r2
 8009768:	60fb      	str	r3, [r7, #12]

  /* Reset the Output Polarity level */
  tmpccer &= ~TIM_CCER_CC2P;
 800976a:	697b      	ldr	r3, [r7, #20]
 800976c:	2220      	movs	r2, #32
 800976e:	4393      	bics	r3, r2
 8009770:	617b      	str	r3, [r7, #20]
  /* Set the Output Compare Polarity */
  tmpccer |= (OC_Config->OCPolarity << 4U);
 8009772:	683b      	ldr	r3, [r7, #0]
 8009774:	689b      	ldr	r3, [r3, #8]
 8009776:	011b      	lsls	r3, r3, #4
 8009778:	697a      	ldr	r2, [r7, #20]
 800977a:	4313      	orrs	r3, r2
 800977c:	617b      	str	r3, [r7, #20]

  if (IS_TIM_CCXN_INSTANCE(TIMx, TIM_CHANNEL_2))
 800977e:	687b      	ldr	r3, [r7, #4]
 8009780:	4a24      	ldr	r2, [pc, #144]	; (8009814 <TIM_OC2_SetConfig+0xf0>)
 8009782:	4293      	cmp	r3, r2
 8009784:	d10d      	bne.n	80097a2 <TIM_OC2_SetConfig+0x7e>
  {
    assert_param(IS_TIM_OCN_POLARITY(OC_Config->OCNPolarity));

    /* Reset the Output N Polarity level */
    tmpccer &= ~TIM_CCER_CC2NP;
 8009786:	697b      	ldr	r3, [r7, #20]
 8009788:	2280      	movs	r2, #128	; 0x80
 800978a:	4393      	bics	r3, r2
 800978c:	617b      	str	r3, [r7, #20]
    /* Set the Output N Polarity */
    tmpccer |= (OC_Config->OCNPolarity << 4U);
 800978e:	683b      	ldr	r3, [r7, #0]
 8009790:	68db      	ldr	r3, [r3, #12]
 8009792:	011b      	lsls	r3, r3, #4
 8009794:	697a      	ldr	r2, [r7, #20]
 8009796:	4313      	orrs	r3, r2
 8009798:	617b      	str	r3, [r7, #20]
    /* Reset the Output N State */
    tmpccer &= ~TIM_CCER_CC2NE;
 800979a:	697b      	ldr	r3, [r7, #20]
 800979c:	2240      	movs	r2, #64	; 0x40
 800979e:	4393      	bics	r3, r2
 80097a0:	617b      	str	r3, [r7, #20]

  }

  if (IS_TIM_BREAK_INSTANCE(TIMx))
 80097a2:	687b      	ldr	r3, [r7, #4]
 80097a4:	4a1b      	ldr	r2, [pc, #108]	; (8009814 <TIM_OC2_SetConfig+0xf0>)
 80097a6:	4293      	cmp	r3, r2
 80097a8:	d00b      	beq.n	80097c2 <TIM_OC2_SetConfig+0x9e>
 80097aa:	687b      	ldr	r3, [r7, #4]
 80097ac:	4a1a      	ldr	r2, [pc, #104]	; (8009818 <TIM_OC2_SetConfig+0xf4>)
 80097ae:	4293      	cmp	r3, r2
 80097b0:	d007      	beq.n	80097c2 <TIM_OC2_SetConfig+0x9e>
 80097b2:	687b      	ldr	r3, [r7, #4]
 80097b4:	4a19      	ldr	r2, [pc, #100]	; (800981c <TIM_OC2_SetConfig+0xf8>)
 80097b6:	4293      	cmp	r3, r2
 80097b8:	d003      	beq.n	80097c2 <TIM_OC2_SetConfig+0x9e>
 80097ba:	687b      	ldr	r3, [r7, #4]
 80097bc:	4a18      	ldr	r2, [pc, #96]	; (8009820 <TIM_OC2_SetConfig+0xfc>)
 80097be:	4293      	cmp	r3, r2
 80097c0:	d113      	bne.n	80097ea <TIM_OC2_SetConfig+0xc6>
    /* Check parameters */
    assert_param(IS_TIM_OCNIDLE_STATE(OC_Config->OCNIdleState));
    assert_param(IS_TIM_OCIDLE_STATE(OC_Config->OCIdleState));

    /* Reset the Output Compare and Output Compare N IDLE State */
    tmpcr2 &= ~TIM_CR2_OIS2;
 80097c2:	693b      	ldr	r3, [r7, #16]
 80097c4:	4a17      	ldr	r2, [pc, #92]	; (8009824 <TIM_OC2_SetConfig+0x100>)
 80097c6:	4013      	ands	r3, r2
 80097c8:	613b      	str	r3, [r7, #16]
    tmpcr2 &= ~TIM_CR2_OIS2N;
 80097ca:	693b      	ldr	r3, [r7, #16]
 80097cc:	4a16      	ldr	r2, [pc, #88]	; (8009828 <TIM_OC2_SetConfig+0x104>)
 80097ce:	4013      	ands	r3, r2
 80097d0:	613b      	str	r3, [r7, #16]
    /* Set the Output Idle state */
    tmpcr2 |= (OC_Config->OCIdleState << 2U);
 80097d2:	683b      	ldr	r3, [r7, #0]
 80097d4:	695b      	ldr	r3, [r3, #20]
 80097d6:	009b      	lsls	r3, r3, #2
 80097d8:	693a      	ldr	r2, [r7, #16]
 80097da:	4313      	orrs	r3, r2
 80097dc:	613b      	str	r3, [r7, #16]
    /* Set the Output N Idle state */
    tmpcr2 |= (OC_Config->OCNIdleState << 2U);
 80097de:	683b      	ldr	r3, [r7, #0]
 80097e0:	699b      	ldr	r3, [r3, #24]
 80097e2:	009b      	lsls	r3, r3, #2
 80097e4:	693a      	ldr	r2, [r7, #16]
 80097e6:	4313      	orrs	r3, r2
 80097e8:	613b      	str	r3, [r7, #16]
  }

  /* Write to TIMx CR2 */
  TIMx->CR2 = tmpcr2;
 80097ea:	687b      	ldr	r3, [r7, #4]
 80097ec:	693a      	ldr	r2, [r7, #16]
 80097ee:	605a      	str	r2, [r3, #4]

  /* Write to TIMx CCMR1 */
  TIMx->CCMR1 = tmpccmrx;
 80097f0:	687b      	ldr	r3, [r7, #4]
 80097f2:	68fa      	ldr	r2, [r7, #12]
 80097f4:	619a      	str	r2, [r3, #24]

  /* Set the Capture Compare Register value */
  TIMx->CCR2 = OC_Config->Pulse;
 80097f6:	683b      	ldr	r3, [r7, #0]
 80097f8:	685a      	ldr	r2, [r3, #4]
 80097fa:	687b      	ldr	r3, [r7, #4]
 80097fc:	639a      	str	r2, [r3, #56]	; 0x38

  /* Write to TIMx CCER */
  TIMx->CCER = tmpccer;
 80097fe:	687b      	ldr	r3, [r7, #4]
 8009800:	697a      	ldr	r2, [r7, #20]
 8009802:	621a      	str	r2, [r3, #32]
}
 8009804:	46c0      	nop			; (mov r8, r8)
 8009806:	46bd      	mov	sp, r7
 8009808:	b006      	add	sp, #24
 800980a:	bd80      	pop	{r7, pc}
 800980c:	ffff8fff 	.word	0xffff8fff
 8009810:	fffffcff 	.word	0xfffffcff
 8009814:	40012c00 	.word	0x40012c00
 8009818:	40014000 	.word	0x40014000
 800981c:	40014400 	.word	0x40014400
 8009820:	40014800 	.word	0x40014800
 8009824:	fffffbff 	.word	0xfffffbff
 8009828:	fffff7ff 	.word	0xfffff7ff

0800982c <TIM_OC3_SetConfig>:
  * @param  TIMx to select the TIM peripheral
  * @param  OC_Config The output configuration structure
  * @retval None
  */
static void TIM_OC3_SetConfig(TIM_TypeDef *TIMx, TIM_OC_InitTypeDef *OC_Config)
{
 800982c:	b580      	push	{r7, lr}
 800982e:	b086      	sub	sp, #24
 8009830:	af00      	add	r7, sp, #0
 8009832:	6078      	str	r0, [r7, #4]
 8009834:	6039      	str	r1, [r7, #0]
  uint32_t tmpccmrx;
  uint32_t tmpccer;
  uint32_t tmpcr2;

  /* Disable the Channel 3: Reset the CC2E Bit */
  TIMx->CCER &= ~TIM_CCER_CC3E;
 8009836:	687b      	ldr	r3, [r7, #4]
 8009838:	6a1b      	ldr	r3, [r3, #32]
 800983a:	4a35      	ldr	r2, [pc, #212]	; (8009910 <TIM_OC3_SetConfig+0xe4>)
 800983c:	401a      	ands	r2, r3
 800983e:	687b      	ldr	r3, [r7, #4]
 8009840:	621a      	str	r2, [r3, #32]

  /* Get the TIMx CCER register value */
  tmpccer = TIMx->CCER;
 8009842:	687b      	ldr	r3, [r7, #4]
 8009844:	6a1b      	ldr	r3, [r3, #32]
 8009846:	617b      	str	r3, [r7, #20]
  /* Get the TIMx CR2 register value */
  tmpcr2 =  TIMx->CR2;
 8009848:	687b      	ldr	r3, [r7, #4]
 800984a:	685b      	ldr	r3, [r3, #4]
 800984c:	613b      	str	r3, [r7, #16]

  /* Get the TIMx CCMR2 register value */
  tmpccmrx = TIMx->CCMR2;
 800984e:	687b      	ldr	r3, [r7, #4]
 8009850:	69db      	ldr	r3, [r3, #28]
 8009852:	60fb      	str	r3, [r7, #12]

  /* Reset the Output Compare mode and Capture/Compare selection Bits */
  tmpccmrx &= ~TIM_CCMR2_OC3M;
 8009854:	68fb      	ldr	r3, [r7, #12]
 8009856:	2270      	movs	r2, #112	; 0x70
 8009858:	4393      	bics	r3, r2
 800985a:	60fb      	str	r3, [r7, #12]
  tmpccmrx &= ~TIM_CCMR2_CC3S;
 800985c:	68fb      	ldr	r3, [r7, #12]
 800985e:	2203      	movs	r2, #3
 8009860:	4393      	bics	r3, r2
 8009862:	60fb      	str	r3, [r7, #12]
  /* Select the Output Compare Mode */
  tmpccmrx |= OC_Config->OCMode;
 8009864:	683b      	ldr	r3, [r7, #0]
 8009866:	681b      	ldr	r3, [r3, #0]
 8009868:	68fa      	ldr	r2, [r7, #12]
 800986a:	4313      	orrs	r3, r2
 800986c:	60fb      	str	r3, [r7, #12]

  /* Reset the Output Polarity level */
  tmpccer &= ~TIM_CCER_CC3P;
 800986e:	697b      	ldr	r3, [r7, #20]
 8009870:	4a28      	ldr	r2, [pc, #160]	; (8009914 <TIM_OC3_SetConfig+0xe8>)
 8009872:	4013      	ands	r3, r2
 8009874:	617b      	str	r3, [r7, #20]
  /* Set the Output Compare Polarity */
  tmpccer |= (OC_Config->OCPolarity << 8U);
 8009876:	683b      	ldr	r3, [r7, #0]
 8009878:	689b      	ldr	r3, [r3, #8]
 800987a:	021b      	lsls	r3, r3, #8
 800987c:	697a      	ldr	r2, [r7, #20]
 800987e:	4313      	orrs	r3, r2
 8009880:	617b      	str	r3, [r7, #20]

  if (IS_TIM_CCXN_INSTANCE(TIMx, TIM_CHANNEL_3))
 8009882:	687b      	ldr	r3, [r7, #4]
 8009884:	4a24      	ldr	r2, [pc, #144]	; (8009918 <TIM_OC3_SetConfig+0xec>)
 8009886:	4293      	cmp	r3, r2
 8009888:	d10d      	bne.n	80098a6 <TIM_OC3_SetConfig+0x7a>
  {
    assert_param(IS_TIM_OCN_POLARITY(OC_Config->OCNPolarity));

    /* Reset the Output N Polarity level */
    tmpccer &= ~TIM_CCER_CC3NP;
 800988a:	697b      	ldr	r3, [r7, #20]
 800988c:	4a23      	ldr	r2, [pc, #140]	; (800991c <TIM_OC3_SetConfig+0xf0>)
 800988e:	4013      	ands	r3, r2
 8009890:	617b      	str	r3, [r7, #20]
    /* Set the Output N Polarity */
    tmpccer |= (OC_Config->OCNPolarity << 8U);
 8009892:	683b      	ldr	r3, [r7, #0]
 8009894:	68db      	ldr	r3, [r3, #12]
 8009896:	021b      	lsls	r3, r3, #8
 8009898:	697a      	ldr	r2, [r7, #20]
 800989a:	4313      	orrs	r3, r2
 800989c:	617b      	str	r3, [r7, #20]
    /* Reset the Output N State */
    tmpccer &= ~TIM_CCER_CC3NE;
 800989e:	697b      	ldr	r3, [r7, #20]
 80098a0:	4a1f      	ldr	r2, [pc, #124]	; (8009920 <TIM_OC3_SetConfig+0xf4>)
 80098a2:	4013      	ands	r3, r2
 80098a4:	617b      	str	r3, [r7, #20]
  }

  if (IS_TIM_BREAK_INSTANCE(TIMx))
 80098a6:	687b      	ldr	r3, [r7, #4]
 80098a8:	4a1b      	ldr	r2, [pc, #108]	; (8009918 <TIM_OC3_SetConfig+0xec>)
 80098aa:	4293      	cmp	r3, r2
 80098ac:	d00b      	beq.n	80098c6 <TIM_OC3_SetConfig+0x9a>
 80098ae:	687b      	ldr	r3, [r7, #4]
 80098b0:	4a1c      	ldr	r2, [pc, #112]	; (8009924 <TIM_OC3_SetConfig+0xf8>)
 80098b2:	4293      	cmp	r3, r2
 80098b4:	d007      	beq.n	80098c6 <TIM_OC3_SetConfig+0x9a>
 80098b6:	687b      	ldr	r3, [r7, #4]
 80098b8:	4a1b      	ldr	r2, [pc, #108]	; (8009928 <TIM_OC3_SetConfig+0xfc>)
 80098ba:	4293      	cmp	r3, r2
 80098bc:	d003      	beq.n	80098c6 <TIM_OC3_SetConfig+0x9a>
 80098be:	687b      	ldr	r3, [r7, #4]
 80098c0:	4a1a      	ldr	r2, [pc, #104]	; (800992c <TIM_OC3_SetConfig+0x100>)
 80098c2:	4293      	cmp	r3, r2
 80098c4:	d113      	bne.n	80098ee <TIM_OC3_SetConfig+0xc2>
    /* Check parameters */
    assert_param(IS_TIM_OCNIDLE_STATE(OC_Config->OCNIdleState));
    assert_param(IS_TIM_OCIDLE_STATE(OC_Config->OCIdleState));

    /* Reset the Output Compare and Output Compare N IDLE State */
    tmpcr2 &= ~TIM_CR2_OIS3;
 80098c6:	693b      	ldr	r3, [r7, #16]
 80098c8:	4a19      	ldr	r2, [pc, #100]	; (8009930 <TIM_OC3_SetConfig+0x104>)
 80098ca:	4013      	ands	r3, r2
 80098cc:	613b      	str	r3, [r7, #16]
    tmpcr2 &= ~TIM_CR2_OIS3N;
 80098ce:	693b      	ldr	r3, [r7, #16]
 80098d0:	4a18      	ldr	r2, [pc, #96]	; (8009934 <TIM_OC3_SetConfig+0x108>)
 80098d2:	4013      	ands	r3, r2
 80098d4:	613b      	str	r3, [r7, #16]
    /* Set the Output Idle state */
    tmpcr2 |= (OC_Config->OCIdleState << 4U);
 80098d6:	683b      	ldr	r3, [r7, #0]
 80098d8:	695b      	ldr	r3, [r3, #20]
 80098da:	011b      	lsls	r3, r3, #4
 80098dc:	693a      	ldr	r2, [r7, #16]
 80098de:	4313      	orrs	r3, r2
 80098e0:	613b      	str	r3, [r7, #16]
    /* Set the Output N Idle state */
    tmpcr2 |= (OC_Config->OCNIdleState << 4U);
 80098e2:	683b      	ldr	r3, [r7, #0]
 80098e4:	699b      	ldr	r3, [r3, #24]
 80098e6:	011b      	lsls	r3, r3, #4
 80098e8:	693a      	ldr	r2, [r7, #16]
 80098ea:	4313      	orrs	r3, r2
 80098ec:	613b      	str	r3, [r7, #16]
  }

  /* Write to TIMx CR2 */
  TIMx->CR2 = tmpcr2;
 80098ee:	687b      	ldr	r3, [r7, #4]
 80098f0:	693a      	ldr	r2, [r7, #16]
 80098f2:	605a      	str	r2, [r3, #4]

  /* Write to TIMx CCMR2 */
  TIMx->CCMR2 = tmpccmrx;
 80098f4:	687b      	ldr	r3, [r7, #4]
 80098f6:	68fa      	ldr	r2, [r7, #12]
 80098f8:	61da      	str	r2, [r3, #28]

  /* Set the Capture Compare Register value */
  TIMx->CCR3 = OC_Config->Pulse;
 80098fa:	683b      	ldr	r3, [r7, #0]
 80098fc:	685a      	ldr	r2, [r3, #4]
 80098fe:	687b      	ldr	r3, [r7, #4]
 8009900:	63da      	str	r2, [r3, #60]	; 0x3c

  /* Write to TIMx CCER */
  TIMx->CCER = tmpccer;
 8009902:	687b      	ldr	r3, [r7, #4]
 8009904:	697a      	ldr	r2, [r7, #20]
 8009906:	621a      	str	r2, [r3, #32]
}
 8009908:	46c0      	nop			; (mov r8, r8)
 800990a:	46bd      	mov	sp, r7
 800990c:	b006      	add	sp, #24
 800990e:	bd80      	pop	{r7, pc}
 8009910:	fffffeff 	.word	0xfffffeff
 8009914:	fffffdff 	.word	0xfffffdff
 8009918:	40012c00 	.word	0x40012c00
 800991c:	fffff7ff 	.word	0xfffff7ff
 8009920:	fffffbff 	.word	0xfffffbff
 8009924:	40014000 	.word	0x40014000
 8009928:	40014400 	.word	0x40014400
 800992c:	40014800 	.word	0x40014800
 8009930:	ffffefff 	.word	0xffffefff
 8009934:	ffffdfff 	.word	0xffffdfff

08009938 <TIM_OC4_SetConfig>:
  * @param  TIMx to select the TIM peripheral
  * @param  OC_Config The output configuration structure
  * @retval None
  */
static void TIM_OC4_SetConfig(TIM_TypeDef *TIMx, TIM_OC_InitTypeDef *OC_Config)
{
 8009938:	b580      	push	{r7, lr}
 800993a:	b086      	sub	sp, #24
 800993c:	af00      	add	r7, sp, #0
 800993e:	6078      	str	r0, [r7, #4]
 8009940:	6039      	str	r1, [r7, #0]
  uint32_t tmpccmrx;
  uint32_t tmpccer;
  uint32_t tmpcr2;

  /* Disable the Channel 4: Reset the CC4E Bit */
  TIMx->CCER &= ~TIM_CCER_CC4E;
 8009942:	687b      	ldr	r3, [r7, #4]
 8009944:	6a1b      	ldr	r3, [r3, #32]
 8009946:	4a28      	ldr	r2, [pc, #160]	; (80099e8 <TIM_OC4_SetConfig+0xb0>)
 8009948:	401a      	ands	r2, r3
 800994a:	687b      	ldr	r3, [r7, #4]
 800994c:	621a      	str	r2, [r3, #32]

  /* Get the TIMx CCER register value */
  tmpccer = TIMx->CCER;
 800994e:	687b      	ldr	r3, [r7, #4]
 8009950:	6a1b      	ldr	r3, [r3, #32]
 8009952:	613b      	str	r3, [r7, #16]
  /* Get the TIMx CR2 register value */
  tmpcr2 =  TIMx->CR2;
 8009954:	687b      	ldr	r3, [r7, #4]
 8009956:	685b      	ldr	r3, [r3, #4]
 8009958:	617b      	str	r3, [r7, #20]

  /* Get the TIMx CCMR2 register value */
  tmpccmrx = TIMx->CCMR2;
 800995a:	687b      	ldr	r3, [r7, #4]
 800995c:	69db      	ldr	r3, [r3, #28]
 800995e:	60fb      	str	r3, [r7, #12]

  /* Reset the Output Compare mode and Capture/Compare selection Bits */
  tmpccmrx &= ~TIM_CCMR2_OC4M;
 8009960:	68fb      	ldr	r3, [r7, #12]
 8009962:	4a22      	ldr	r2, [pc, #136]	; (80099ec <TIM_OC4_SetConfig+0xb4>)
 8009964:	4013      	ands	r3, r2
 8009966:	60fb      	str	r3, [r7, #12]
  tmpccmrx &= ~TIM_CCMR2_CC4S;
 8009968:	68fb      	ldr	r3, [r7, #12]
 800996a:	4a21      	ldr	r2, [pc, #132]	; (80099f0 <TIM_OC4_SetConfig+0xb8>)
 800996c:	4013      	ands	r3, r2
 800996e:	60fb      	str	r3, [r7, #12]

  /* Select the Output Compare Mode */
  tmpccmrx |= (OC_Config->OCMode << 8U);
 8009970:	683b      	ldr	r3, [r7, #0]
 8009972:	681b      	ldr	r3, [r3, #0]
 8009974:	021b      	lsls	r3, r3, #8
 8009976:	68fa      	ldr	r2, [r7, #12]
 8009978:	4313      	orrs	r3, r2
 800997a:	60fb      	str	r3, [r7, #12]

  /* Reset the Output Polarity level */
  tmpccer &= ~TIM_CCER_CC4P;
 800997c:	693b      	ldr	r3, [r7, #16]
 800997e:	4a1d      	ldr	r2, [pc, #116]	; (80099f4 <TIM_OC4_SetConfig+0xbc>)
 8009980:	4013      	ands	r3, r2
 8009982:	613b      	str	r3, [r7, #16]
  /* Set the Output Compare Polarity */
  tmpccer |= (OC_Config->OCPolarity << 12U);
 8009984:	683b      	ldr	r3, [r7, #0]
 8009986:	689b      	ldr	r3, [r3, #8]
 8009988:	031b      	lsls	r3, r3, #12
 800998a:	693a      	ldr	r2, [r7, #16]
 800998c:	4313      	orrs	r3, r2
 800998e:	613b      	str	r3, [r7, #16]

  if (IS_TIM_BREAK_INSTANCE(TIMx))
 8009990:	687b      	ldr	r3, [r7, #4]
 8009992:	4a19      	ldr	r2, [pc, #100]	; (80099f8 <TIM_OC4_SetConfig+0xc0>)
 8009994:	4293      	cmp	r3, r2
 8009996:	d00b      	beq.n	80099b0 <TIM_OC4_SetConfig+0x78>
 8009998:	687b      	ldr	r3, [r7, #4]
 800999a:	4a18      	ldr	r2, [pc, #96]	; (80099fc <TIM_OC4_SetConfig+0xc4>)
 800999c:	4293      	cmp	r3, r2
 800999e:	d007      	beq.n	80099b0 <TIM_OC4_SetConfig+0x78>
 80099a0:	687b      	ldr	r3, [r7, #4]
 80099a2:	4a17      	ldr	r2, [pc, #92]	; (8009a00 <TIM_OC4_SetConfig+0xc8>)
 80099a4:	4293      	cmp	r3, r2
 80099a6:	d003      	beq.n	80099b0 <TIM_OC4_SetConfig+0x78>
 80099a8:	687b      	ldr	r3, [r7, #4]
 80099aa:	4a16      	ldr	r2, [pc, #88]	; (8009a04 <TIM_OC4_SetConfig+0xcc>)
 80099ac:	4293      	cmp	r3, r2
 80099ae:	d109      	bne.n	80099c4 <TIM_OC4_SetConfig+0x8c>
  {
    /* Check parameters */
    assert_param(IS_TIM_OCIDLE_STATE(OC_Config->OCIdleState));

    /* Reset the Output Compare IDLE State */
    tmpcr2 &= ~TIM_CR2_OIS4;
 80099b0:	697b      	ldr	r3, [r7, #20]
 80099b2:	4a15      	ldr	r2, [pc, #84]	; (8009a08 <TIM_OC4_SetConfig+0xd0>)
 80099b4:	4013      	ands	r3, r2
 80099b6:	617b      	str	r3, [r7, #20]

    /* Set the Output Idle state */
    tmpcr2 |= (OC_Config->OCIdleState << 6U);
 80099b8:	683b      	ldr	r3, [r7, #0]
 80099ba:	695b      	ldr	r3, [r3, #20]
 80099bc:	019b      	lsls	r3, r3, #6
 80099be:	697a      	ldr	r2, [r7, #20]
 80099c0:	4313      	orrs	r3, r2
 80099c2:	617b      	str	r3, [r7, #20]
  }

  /* Write to TIMx CR2 */
  TIMx->CR2 = tmpcr2;
 80099c4:	687b      	ldr	r3, [r7, #4]
 80099c6:	697a      	ldr	r2, [r7, #20]
 80099c8:	605a      	str	r2, [r3, #4]

  /* Write to TIMx CCMR2 */
  TIMx->CCMR2 = tmpccmrx;
 80099ca:	687b      	ldr	r3, [r7, #4]
 80099cc:	68fa      	ldr	r2, [r7, #12]
 80099ce:	61da      	str	r2, [r3, #28]

  /* Set the Capture Compare Register value */
  TIMx->CCR4 = OC_Config->Pulse;
 80099d0:	683b      	ldr	r3, [r7, #0]
 80099d2:	685a      	ldr	r2, [r3, #4]
 80099d4:	687b      	ldr	r3, [r7, #4]
 80099d6:	641a      	str	r2, [r3, #64]	; 0x40

  /* Write to TIMx CCER */
  TIMx->CCER = tmpccer;
 80099d8:	687b      	ldr	r3, [r7, #4]
 80099da:	693a      	ldr	r2, [r7, #16]
 80099dc:	621a      	str	r2, [r3, #32]
}
 80099de:	46c0      	nop			; (mov r8, r8)
 80099e0:	46bd      	mov	sp, r7
 80099e2:	b006      	add	sp, #24
 80099e4:	bd80      	pop	{r7, pc}
 80099e6:	46c0      	nop			; (mov r8, r8)
 80099e8:	ffffefff 	.word	0xffffefff
 80099ec:	ffff8fff 	.word	0xffff8fff
 80099f0:	fffffcff 	.word	0xfffffcff
 80099f4:	ffffdfff 	.word	0xffffdfff
 80099f8:	40012c00 	.word	0x40012c00
 80099fc:	40014000 	.word	0x40014000
 8009a00:	40014400 	.word	0x40014400
 8009a04:	40014800 	.word	0x40014800
 8009a08:	ffffbfff 	.word	0xffffbfff

08009a0c <TIM_CCxChannelCmd>:
  * @param  ChannelState specifies the TIM Channel CCxE bit new state.
  *          This parameter can be: TIM_CCx_ENABLE or TIM_CCx_DISABLE.
  * @retval None
  */
void TIM_CCxChannelCmd(TIM_TypeDef *TIMx, uint32_t Channel, uint32_t ChannelState)
{
 8009a0c:	b580      	push	{r7, lr}
 8009a0e:	b086      	sub	sp, #24
 8009a10:	af00      	add	r7, sp, #0
 8009a12:	60f8      	str	r0, [r7, #12]
 8009a14:	60b9      	str	r1, [r7, #8]
 8009a16:	607a      	str	r2, [r7, #4]

  /* Check the parameters */
  assert_param(IS_TIM_CC1_INSTANCE(TIMx));
  assert_param(IS_TIM_CHANNELS(Channel));

  tmp = TIM_CCER_CC1E << (Channel & 0x1FU); /* 0x1FU = 31 bits max shift */
 8009a18:	68bb      	ldr	r3, [r7, #8]
 8009a1a:	221f      	movs	r2, #31
 8009a1c:	4013      	ands	r3, r2
 8009a1e:	2201      	movs	r2, #1
 8009a20:	409a      	lsls	r2, r3
 8009a22:	0013      	movs	r3, r2
 8009a24:	617b      	str	r3, [r7, #20]

  /* Reset the CCxE Bit */
  TIMx->CCER &= ~tmp;
 8009a26:	68fb      	ldr	r3, [r7, #12]
 8009a28:	6a1b      	ldr	r3, [r3, #32]
 8009a2a:	697a      	ldr	r2, [r7, #20]
 8009a2c:	43d2      	mvns	r2, r2
 8009a2e:	401a      	ands	r2, r3
 8009a30:	68fb      	ldr	r3, [r7, #12]
 8009a32:	621a      	str	r2, [r3, #32]

  /* Set or reset the CCxE Bit */
  TIMx->CCER |= (uint32_t)(ChannelState << (Channel & 0x1FU)); /* 0x1FU = 31 bits max shift */
 8009a34:	68fb      	ldr	r3, [r7, #12]
 8009a36:	6a1a      	ldr	r2, [r3, #32]
 8009a38:	68bb      	ldr	r3, [r7, #8]
 8009a3a:	211f      	movs	r1, #31
 8009a3c:	400b      	ands	r3, r1
 8009a3e:	6879      	ldr	r1, [r7, #4]
 8009a40:	4099      	lsls	r1, r3
 8009a42:	000b      	movs	r3, r1
 8009a44:	431a      	orrs	r2, r3
 8009a46:	68fb      	ldr	r3, [r7, #12]
 8009a48:	621a      	str	r2, [r3, #32]
}
 8009a4a:	46c0      	nop			; (mov r8, r8)
 8009a4c:	46bd      	mov	sp, r7
 8009a4e:	b006      	add	sp, #24
 8009a50:	bd80      	pop	{r7, pc}
	...

08009a54 <HAL_TIMEx_MasterConfigSynchronization>:
  *         mode.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_TIMEx_MasterConfigSynchronization(TIM_HandleTypeDef *htim,
                                                        TIM_MasterConfigTypeDef *sMasterConfig)
{
 8009a54:	b580      	push	{r7, lr}
 8009a56:	b084      	sub	sp, #16
 8009a58:	af00      	add	r7, sp, #0
 8009a5a:	6078      	str	r0, [r7, #4]
 8009a5c:	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);
 8009a5e:	687b      	ldr	r3, [r7, #4]
 8009a60:	223c      	movs	r2, #60	; 0x3c
 8009a62:	5c9b      	ldrb	r3, [r3, r2]
 8009a64:	2b01      	cmp	r3, #1
 8009a66:	d101      	bne.n	8009a6c <HAL_TIMEx_MasterConfigSynchronization+0x18>
 8009a68:	2302      	movs	r3, #2
 8009a6a:	e047      	b.n	8009afc <HAL_TIMEx_MasterConfigSynchronization+0xa8>
 8009a6c:	687b      	ldr	r3, [r7, #4]
 8009a6e:	223c      	movs	r2, #60	; 0x3c
 8009a70:	2101      	movs	r1, #1
 8009a72:	5499      	strb	r1, [r3, r2]

  /* Change the handler state */
  htim->State = HAL_TIM_STATE_BUSY;
 8009a74:	687b      	ldr	r3, [r7, #4]
 8009a76:	223d      	movs	r2, #61	; 0x3d
 8009a78:	2102      	movs	r1, #2
 8009a7a:	5499      	strb	r1, [r3, r2]

  /* Get the TIMx CR2 register value */
  tmpcr2 = htim->Instance->CR2;
 8009a7c:	687b      	ldr	r3, [r7, #4]
 8009a7e:	681b      	ldr	r3, [r3, #0]
 8009a80:	685b      	ldr	r3, [r3, #4]
 8009a82:	60fb      	str	r3, [r7, #12]

  /* Get the TIMx SMCR register value */
  tmpsmcr = htim->Instance->SMCR;
 8009a84:	687b      	ldr	r3, [r7, #4]
 8009a86:	681b      	ldr	r3, [r3, #0]
 8009a88:	689b      	ldr	r3, [r3, #8]
 8009a8a:	60bb      	str	r3, [r7, #8]

  /* Reset the MMS Bits */
  tmpcr2 &= ~TIM_CR2_MMS;
 8009a8c:	68fb      	ldr	r3, [r7, #12]
 8009a8e:	2270      	movs	r2, #112	; 0x70
 8009a90:	4393      	bics	r3, r2
 8009a92:	60fb      	str	r3, [r7, #12]
  /* Select the TRGO source */
  tmpcr2 |=  sMasterConfig->MasterOutputTrigger;
 8009a94:	683b      	ldr	r3, [r7, #0]
 8009a96:	681b      	ldr	r3, [r3, #0]
 8009a98:	68fa      	ldr	r2, [r7, #12]
 8009a9a:	4313      	orrs	r3, r2
 8009a9c:	60fb      	str	r3, [r7, #12]

  /* Update TIMx CR2 */
  htim->Instance->CR2 = tmpcr2;
 8009a9e:	687b      	ldr	r3, [r7, #4]
 8009aa0:	681b      	ldr	r3, [r3, #0]
 8009aa2:	68fa      	ldr	r2, [r7, #12]
 8009aa4:	605a      	str	r2, [r3, #4]

  if (IS_TIM_SLAVE_INSTANCE(htim->Instance))
 8009aa6:	687b      	ldr	r3, [r7, #4]
 8009aa8:	681b      	ldr	r3, [r3, #0]
 8009aaa:	4a16      	ldr	r2, [pc, #88]	; (8009b04 <HAL_TIMEx_MasterConfigSynchronization+0xb0>)
 8009aac:	4293      	cmp	r3, r2
 8009aae:	d00f      	beq.n	8009ad0 <HAL_TIMEx_MasterConfigSynchronization+0x7c>
 8009ab0:	687b      	ldr	r3, [r7, #4]
 8009ab2:	681a      	ldr	r2, [r3, #0]
 8009ab4:	2380      	movs	r3, #128	; 0x80
 8009ab6:	05db      	lsls	r3, r3, #23
 8009ab8:	429a      	cmp	r2, r3
 8009aba:	d009      	beq.n	8009ad0 <HAL_TIMEx_MasterConfigSynchronization+0x7c>
 8009abc:	687b      	ldr	r3, [r7, #4]
 8009abe:	681b      	ldr	r3, [r3, #0]
 8009ac0:	4a11      	ldr	r2, [pc, #68]	; (8009b08 <HAL_TIMEx_MasterConfigSynchronization+0xb4>)
 8009ac2:	4293      	cmp	r3, r2
 8009ac4:	d004      	beq.n	8009ad0 <HAL_TIMEx_MasterConfigSynchronization+0x7c>
 8009ac6:	687b      	ldr	r3, [r7, #4]
 8009ac8:	681b      	ldr	r3, [r3, #0]
 8009aca:	4a10      	ldr	r2, [pc, #64]	; (8009b0c <HAL_TIMEx_MasterConfigSynchronization+0xb8>)
 8009acc:	4293      	cmp	r3, r2
 8009ace:	d10c      	bne.n	8009aea <HAL_TIMEx_MasterConfigSynchronization+0x96>
  {
    /* Reset the MSM Bit */
    tmpsmcr &= ~TIM_SMCR_MSM;
 8009ad0:	68bb      	ldr	r3, [r7, #8]
 8009ad2:	2280      	movs	r2, #128	; 0x80
 8009ad4:	4393      	bics	r3, r2
 8009ad6:	60bb      	str	r3, [r7, #8]
    /* Set master mode */
    tmpsmcr |= sMasterConfig->MasterSlaveMode;
 8009ad8:	683b      	ldr	r3, [r7, #0]
 8009ada:	685b      	ldr	r3, [r3, #4]
 8009adc:	68ba      	ldr	r2, [r7, #8]
 8009ade:	4313      	orrs	r3, r2
 8009ae0:	60bb      	str	r3, [r7, #8]

    /* Update TIMx SMCR */
    htim->Instance->SMCR = tmpsmcr;
 8009ae2:	687b      	ldr	r3, [r7, #4]
 8009ae4:	681b      	ldr	r3, [r3, #0]
 8009ae6:	68ba      	ldr	r2, [r7, #8]
 8009ae8:	609a      	str	r2, [r3, #8]
  }

  /* Change the htim state */
  htim->State = HAL_TIM_STATE_READY;
 8009aea:	687b      	ldr	r3, [r7, #4]
 8009aec:	223d      	movs	r2, #61	; 0x3d
 8009aee:	2101      	movs	r1, #1
 8009af0:	5499      	strb	r1, [r3, r2]

  __HAL_UNLOCK(htim);
 8009af2:	687b      	ldr	r3, [r7, #4]
 8009af4:	223c      	movs	r2, #60	; 0x3c
 8009af6:	2100      	movs	r1, #0
 8009af8:	5499      	strb	r1, [r3, r2]

  return HAL_OK;
 8009afa:	2300      	movs	r3, #0
}
 8009afc:	0018      	movs	r0, r3
 8009afe:	46bd      	mov	sp, r7
 8009b00:	b004      	add	sp, #16
 8009b02:	bd80      	pop	{r7, pc}
 8009b04:	40012c00 	.word	0x40012c00
 8009b08:	40000400 	.word	0x40000400
 8009b0c:	40014000 	.word	0x40014000

08009b10 <HAL_TIMEx_ConfigBreakDeadTime>:
  *         interrupt can be enabled by calling the @ref __HAL_TIM_ENABLE_IT macro.
  * @retval HAL status
  */
HAL_StatusTypeDef HAL_TIMEx_ConfigBreakDeadTime(TIM_HandleTypeDef *htim,
                                                TIM_BreakDeadTimeConfigTypeDef *sBreakDeadTimeConfig)
{
 8009b10:	b580      	push	{r7, lr}
 8009b12:	b084      	sub	sp, #16
 8009b14:	af00      	add	r7, sp, #0
 8009b16:	6078      	str	r0, [r7, #4]
 8009b18:	6039      	str	r1, [r7, #0]
  /* Keep this variable initialized to 0 as it is used to configure BDTR register */
  uint32_t tmpbdtr = 0U;
 8009b1a:	2300      	movs	r3, #0
 8009b1c:	60fb      	str	r3, [r7, #12]
  assert_param(IS_TIM_BREAK_STATE(sBreakDeadTimeConfig->BreakState));
  assert_param(IS_TIM_BREAK_POLARITY(sBreakDeadTimeConfig->BreakPolarity));
  assert_param(IS_TIM_AUTOMATIC_OUTPUT_STATE(sBreakDeadTimeConfig->AutomaticOutput));

  /* Check input state */
  __HAL_LOCK(htim);
 8009b1e:	687b      	ldr	r3, [r7, #4]
 8009b20:	223c      	movs	r2, #60	; 0x3c
 8009b22:	5c9b      	ldrb	r3, [r3, r2]
 8009b24:	2b01      	cmp	r3, #1
 8009b26:	d101      	bne.n	8009b2c <HAL_TIMEx_ConfigBreakDeadTime+0x1c>
 8009b28:	2302      	movs	r3, #2
 8009b2a:	e03e      	b.n	8009baa <HAL_TIMEx_ConfigBreakDeadTime+0x9a>
 8009b2c:	687b      	ldr	r3, [r7, #4]
 8009b2e:	223c      	movs	r2, #60	; 0x3c
 8009b30:	2101      	movs	r1, #1
 8009b32:	5499      	strb	r1, [r3, r2]

  /* Set the Lock level, the Break enable Bit and the Polarity, the OSSR State,
     the OSSI State, the dead time value and the Automatic Output Enable Bit */

  /* Set the BDTR bits */
  MODIFY_REG(tmpbdtr, TIM_BDTR_DTG, sBreakDeadTimeConfig->DeadTime);
 8009b34:	68fb      	ldr	r3, [r7, #12]
 8009b36:	22ff      	movs	r2, #255	; 0xff
 8009b38:	4393      	bics	r3, r2
 8009b3a:	001a      	movs	r2, r3
 8009b3c:	683b      	ldr	r3, [r7, #0]
 8009b3e:	68db      	ldr	r3, [r3, #12]
 8009b40:	4313      	orrs	r3, r2
 8009b42:	60fb      	str	r3, [r7, #12]
  MODIFY_REG(tmpbdtr, TIM_BDTR_LOCK, sBreakDeadTimeConfig->LockLevel);
 8009b44:	68fb      	ldr	r3, [r7, #12]
 8009b46:	4a1b      	ldr	r2, [pc, #108]	; (8009bb4 <HAL_TIMEx_ConfigBreakDeadTime+0xa4>)
 8009b48:	401a      	ands	r2, r3
 8009b4a:	683b      	ldr	r3, [r7, #0]
 8009b4c:	689b      	ldr	r3, [r3, #8]
 8009b4e:	4313      	orrs	r3, r2
 8009b50:	60fb      	str	r3, [r7, #12]
  MODIFY_REG(tmpbdtr, TIM_BDTR_OSSI, sBreakDeadTimeConfig->OffStateIDLEMode);
 8009b52:	68fb      	ldr	r3, [r7, #12]
 8009b54:	4a18      	ldr	r2, [pc, #96]	; (8009bb8 <HAL_TIMEx_ConfigBreakDeadTime+0xa8>)
 8009b56:	401a      	ands	r2, r3
 8009b58:	683b      	ldr	r3, [r7, #0]
 8009b5a:	685b      	ldr	r3, [r3, #4]
 8009b5c:	4313      	orrs	r3, r2
 8009b5e:	60fb      	str	r3, [r7, #12]
  MODIFY_REG(tmpbdtr, TIM_BDTR_OSSR, sBreakDeadTimeConfig->OffStateRunMode);
 8009b60:	68fb      	ldr	r3, [r7, #12]
 8009b62:	4a16      	ldr	r2, [pc, #88]	; (8009bbc <HAL_TIMEx_ConfigBreakDeadTime+0xac>)
 8009b64:	401a      	ands	r2, r3
 8009b66:	683b      	ldr	r3, [r7, #0]
 8009b68:	681b      	ldr	r3, [r3, #0]
 8009b6a:	4313      	orrs	r3, r2
 8009b6c:	60fb      	str	r3, [r7, #12]
  MODIFY_REG(tmpbdtr, TIM_BDTR_BKE, sBreakDeadTimeConfig->BreakState);
 8009b6e:	68fb      	ldr	r3, [r7, #12]
 8009b70:	4a13      	ldr	r2, [pc, #76]	; (8009bc0 <HAL_TIMEx_ConfigBreakDeadTime+0xb0>)
 8009b72:	401a      	ands	r2, r3
 8009b74:	683b      	ldr	r3, [r7, #0]
 8009b76:	691b      	ldr	r3, [r3, #16]
 8009b78:	4313      	orrs	r3, r2
 8009b7a:	60fb      	str	r3, [r7, #12]
  MODIFY_REG(tmpbdtr, TIM_BDTR_BKP, sBreakDeadTimeConfig->BreakPolarity);
 8009b7c:	68fb      	ldr	r3, [r7, #12]
 8009b7e:	4a11      	ldr	r2, [pc, #68]	; (8009bc4 <HAL_TIMEx_ConfigBreakDeadTime+0xb4>)
 8009b80:	401a      	ands	r2, r3
 8009b82:	683b      	ldr	r3, [r7, #0]
 8009b84:	695b      	ldr	r3, [r3, #20]
 8009b86:	4313      	orrs	r3, r2
 8009b88:	60fb      	str	r3, [r7, #12]
  MODIFY_REG(tmpbdtr, TIM_BDTR_AOE, sBreakDeadTimeConfig->AutomaticOutput);
 8009b8a:	68fb      	ldr	r3, [r7, #12]
 8009b8c:	4a0e      	ldr	r2, [pc, #56]	; (8009bc8 <HAL_TIMEx_ConfigBreakDeadTime+0xb8>)
 8009b8e:	401a      	ands	r2, r3
 8009b90:	683b      	ldr	r3, [r7, #0]
 8009b92:	69db      	ldr	r3, [r3, #28]
 8009b94:	4313      	orrs	r3, r2
 8009b96:	60fb      	str	r3, [r7, #12]


  /* Set TIMx_BDTR */
  htim->Instance->BDTR = tmpbdtr;
 8009b98:	687b      	ldr	r3, [r7, #4]
 8009b9a:	681b      	ldr	r3, [r3, #0]
 8009b9c:	68fa      	ldr	r2, [r7, #12]
 8009b9e:	645a      	str	r2, [r3, #68]	; 0x44

  __HAL_UNLOCK(htim);
 8009ba0:	687b      	ldr	r3, [r7, #4]
 8009ba2:	223c      	movs	r2, #60	; 0x3c
 8009ba4:	2100      	movs	r1, #0
 8009ba6:	5499      	strb	r1, [r3, r2]

  return HAL_OK;
 8009ba8:	2300      	movs	r3, #0
}
 8009baa:	0018      	movs	r0, r3
 8009bac:	46bd      	mov	sp, r7
 8009bae:	b004      	add	sp, #16
 8009bb0:	bd80      	pop	{r7, pc}
 8009bb2:	46c0      	nop			; (mov r8, r8)
 8009bb4:	fffffcff 	.word	0xfffffcff
 8009bb8:	fffffbff 	.word	0xfffffbff
 8009bbc:	fffff7ff 	.word	0xfffff7ff
 8009bc0:	ffffefff 	.word	0xffffefff
 8009bc4:	ffffdfff 	.word	0xffffdfff
 8009bc8:	ffffbfff 	.word	0xffffbfff

08009bcc <gcvt>:
 8009bcc:	b5f0      	push	{r4, r5, r6, r7, lr}
 8009bce:	001c      	movs	r4, r3
 8009bd0:	0015      	movs	r5, r2
 8009bd2:	2300      	movs	r3, #0
 8009bd4:	2200      	movs	r2, #0
 8009bd6:	b085      	sub	sp, #20
 8009bd8:	0006      	movs	r6, r0
 8009bda:	000f      	movs	r7, r1
 8009bdc:	f7f9 f8c6 	bl	8002d6c <__aeabi_dcmplt>
 8009be0:	0023      	movs	r3, r4
 8009be2:	2800      	cmp	r0, #0
 8009be4:	d003      	beq.n	8009bee <gcvt+0x22>
 8009be6:	232d      	movs	r3, #45	; 0x2d
 8009be8:	3d01      	subs	r5, #1
 8009bea:	7023      	strb	r3, [r4, #0]
 8009bec:	1c63      	adds	r3, r4, #1
 8009bee:	2200      	movs	r2, #0
 8009bf0:	4908      	ldr	r1, [pc, #32]	; (8009c14 <gcvt+0x48>)
 8009bf2:	9203      	str	r2, [sp, #12]
 8009bf4:	3267      	adds	r2, #103	; 0x67
 8009bf6:	9202      	str	r2, [sp, #8]
 8009bf8:	9301      	str	r3, [sp, #4]
 8009bfa:	9500      	str	r5, [sp, #0]
 8009bfc:	003b      	movs	r3, r7
 8009bfe:	0032      	movs	r2, r6
 8009c00:	6808      	ldr	r0, [r1, #0]
 8009c02:	f000 f99f 	bl	8009f44 <_gcvt>
 8009c06:	1e43      	subs	r3, r0, #1
 8009c08:	4198      	sbcs	r0, r3
 8009c0a:	4240      	negs	r0, r0
 8009c0c:	4004      	ands	r4, r0
 8009c0e:	0020      	movs	r0, r4
 8009c10:	b005      	add	sp, #20
 8009c12:	bdf0      	pop	{r4, r5, r6, r7, pc}
 8009c14:	20000088 	.word	0x20000088

08009c18 <__errno>:
 8009c18:	4b01      	ldr	r3, [pc, #4]	; (8009c20 <__errno+0x8>)
 8009c1a:	6818      	ldr	r0, [r3, #0]
 8009c1c:	4770      	bx	lr
 8009c1e:	46c0      	nop			; (mov r8, r8)
 8009c20:	20000088 	.word	0x20000088

08009c24 <__libc_init_array>:
 8009c24:	b570      	push	{r4, r5, r6, lr}
 8009c26:	2600      	movs	r6, #0
 8009c28:	4d0c      	ldr	r5, [pc, #48]	; (8009c5c <__libc_init_array+0x38>)
 8009c2a:	4c0d      	ldr	r4, [pc, #52]	; (8009c60 <__libc_init_array+0x3c>)
 8009c2c:	1b64      	subs	r4, r4, r5
 8009c2e:	10a4      	asrs	r4, r4, #2
 8009c30:	42a6      	cmp	r6, r4
 8009c32:	d109      	bne.n	8009c48 <__libc_init_array+0x24>
 8009c34:	2600      	movs	r6, #0
 8009c36:	f004 fb83 	bl	800e340 <_init>
 8009c3a:	4d0a      	ldr	r5, [pc, #40]	; (8009c64 <__libc_init_array+0x40>)
 8009c3c:	4c0a      	ldr	r4, [pc, #40]	; (8009c68 <__libc_init_array+0x44>)
 8009c3e:	1b64      	subs	r4, r4, r5
 8009c40:	10a4      	asrs	r4, r4, #2
 8009c42:	42a6      	cmp	r6, r4
 8009c44:	d105      	bne.n	8009c52 <__libc_init_array+0x2e>
 8009c46:	bd70      	pop	{r4, r5, r6, pc}
 8009c48:	00b3      	lsls	r3, r6, #2
 8009c4a:	58eb      	ldr	r3, [r5, r3]
 8009c4c:	4798      	blx	r3
 8009c4e:	3601      	adds	r6, #1
 8009c50:	e7ee      	b.n	8009c30 <__libc_init_array+0xc>
 8009c52:	00b3      	lsls	r3, r6, #2
 8009c54:	58eb      	ldr	r3, [r5, r3]
 8009c56:	4798      	blx	r3
 8009c58:	3601      	adds	r6, #1
 8009c5a:	e7f2      	b.n	8009c42 <__libc_init_array+0x1e>
 8009c5c:	0800f598 	.word	0x0800f598
 8009c60:	0800f598 	.word	0x0800f598
 8009c64:	0800f598 	.word	0x0800f598
 8009c68:	0800f59c 	.word	0x0800f59c

08009c6c <malloc>:
 8009c6c:	b510      	push	{r4, lr}
 8009c6e:	4b03      	ldr	r3, [pc, #12]	; (8009c7c <malloc+0x10>)
 8009c70:	0001      	movs	r1, r0
 8009c72:	6818      	ldr	r0, [r3, #0]
 8009c74:	f000 f856 	bl	8009d24 <_malloc_r>
 8009c78:	bd10      	pop	{r4, pc}
 8009c7a:	46c0      	nop			; (mov r8, r8)
 8009c7c:	20000088 	.word	0x20000088

08009c80 <memset>:
 8009c80:	0003      	movs	r3, r0
 8009c82:	1882      	adds	r2, r0, r2
 8009c84:	4293      	cmp	r3, r2
 8009c86:	d100      	bne.n	8009c8a <memset+0xa>
 8009c88:	4770      	bx	lr
 8009c8a:	7019      	strb	r1, [r3, #0]
 8009c8c:	3301      	adds	r3, #1
 8009c8e:	e7f9      	b.n	8009c84 <memset+0x4>

08009c90 <_free_r>:
 8009c90:	b570      	push	{r4, r5, r6, lr}
 8009c92:	0005      	movs	r5, r0
 8009c94:	2900      	cmp	r1, #0
 8009c96:	d010      	beq.n	8009cba <_free_r+0x2a>
 8009c98:	1f0c      	subs	r4, r1, #4
 8009c9a:	6823      	ldr	r3, [r4, #0]
 8009c9c:	2b00      	cmp	r3, #0
 8009c9e:	da00      	bge.n	8009ca2 <_free_r+0x12>
 8009ca0:	18e4      	adds	r4, r4, r3
 8009ca2:	0028      	movs	r0, r5
 8009ca4:	f000 fa2a 	bl	800a0fc <__malloc_lock>
 8009ca8:	4a1d      	ldr	r2, [pc, #116]	; (8009d20 <_free_r+0x90>)
 8009caa:	6813      	ldr	r3, [r2, #0]
 8009cac:	2b00      	cmp	r3, #0
 8009cae:	d105      	bne.n	8009cbc <_free_r+0x2c>
 8009cb0:	6063      	str	r3, [r4, #4]
 8009cb2:	6014      	str	r4, [r2, #0]
 8009cb4:	0028      	movs	r0, r5
 8009cb6:	f000 fa29 	bl	800a10c <__malloc_unlock>
 8009cba:	bd70      	pop	{r4, r5, r6, pc}
 8009cbc:	42a3      	cmp	r3, r4
 8009cbe:	d908      	bls.n	8009cd2 <_free_r+0x42>
 8009cc0:	6821      	ldr	r1, [r4, #0]
 8009cc2:	1860      	adds	r0, r4, r1
 8009cc4:	4283      	cmp	r3, r0
 8009cc6:	d1f3      	bne.n	8009cb0 <_free_r+0x20>
 8009cc8:	6818      	ldr	r0, [r3, #0]
 8009cca:	685b      	ldr	r3, [r3, #4]
 8009ccc:	1841      	adds	r1, r0, r1
 8009cce:	6021      	str	r1, [r4, #0]
 8009cd0:	e7ee      	b.n	8009cb0 <_free_r+0x20>
 8009cd2:	001a      	movs	r2, r3
 8009cd4:	685b      	ldr	r3, [r3, #4]
 8009cd6:	2b00      	cmp	r3, #0
 8009cd8:	d001      	beq.n	8009cde <_free_r+0x4e>
 8009cda:	42a3      	cmp	r3, r4
 8009cdc:	d9f9      	bls.n	8009cd2 <_free_r+0x42>
 8009cde:	6811      	ldr	r1, [r2, #0]
 8009ce0:	1850      	adds	r0, r2, r1
 8009ce2:	42a0      	cmp	r0, r4
 8009ce4:	d10b      	bne.n	8009cfe <_free_r+0x6e>
 8009ce6:	6820      	ldr	r0, [r4, #0]
 8009ce8:	1809      	adds	r1, r1, r0
 8009cea:	1850      	adds	r0, r2, r1
 8009cec:	6011      	str	r1, [r2, #0]
 8009cee:	4283      	cmp	r3, r0
 8009cf0:	d1e0      	bne.n	8009cb4 <_free_r+0x24>
 8009cf2:	6818      	ldr	r0, [r3, #0]
 8009cf4:	685b      	ldr	r3, [r3, #4]
 8009cf6:	1841      	adds	r1, r0, r1
 8009cf8:	6011      	str	r1, [r2, #0]
 8009cfa:	6053      	str	r3, [r2, #4]
 8009cfc:	e7da      	b.n	8009cb4 <_free_r+0x24>
 8009cfe:	42a0      	cmp	r0, r4
 8009d00:	d902      	bls.n	8009d08 <_free_r+0x78>
 8009d02:	230c      	movs	r3, #12
 8009d04:	602b      	str	r3, [r5, #0]
 8009d06:	e7d5      	b.n	8009cb4 <_free_r+0x24>
 8009d08:	6821      	ldr	r1, [r4, #0]
 8009d0a:	1860      	adds	r0, r4, r1
 8009d0c:	4283      	cmp	r3, r0
 8009d0e:	d103      	bne.n	8009d18 <_free_r+0x88>
 8009d10:	6818      	ldr	r0, [r3, #0]
 8009d12:	685b      	ldr	r3, [r3, #4]
 8009d14:	1841      	adds	r1, r0, r1
 8009d16:	6021      	str	r1, [r4, #0]
 8009d18:	6063      	str	r3, [r4, #4]
 8009d1a:	6054      	str	r4, [r2, #4]
 8009d1c:	e7ca      	b.n	8009cb4 <_free_r+0x24>
 8009d1e:	46c0      	nop			; (mov r8, r8)
 8009d20:	2000212c 	.word	0x2000212c

08009d24 <_malloc_r>:
 8009d24:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 8009d26:	2303      	movs	r3, #3
 8009d28:	1ccd      	adds	r5, r1, #3
 8009d2a:	439d      	bics	r5, r3
 8009d2c:	3508      	adds	r5, #8
 8009d2e:	0006      	movs	r6, r0
 8009d30:	2d0c      	cmp	r5, #12
 8009d32:	d21f      	bcs.n	8009d74 <_malloc_r+0x50>
 8009d34:	250c      	movs	r5, #12
 8009d36:	42a9      	cmp	r1, r5
 8009d38:	d81e      	bhi.n	8009d78 <_malloc_r+0x54>
 8009d3a:	0030      	movs	r0, r6
 8009d3c:	f000 f9de 	bl	800a0fc <__malloc_lock>
 8009d40:	4925      	ldr	r1, [pc, #148]	; (8009dd8 <_malloc_r+0xb4>)
 8009d42:	680a      	ldr	r2, [r1, #0]
 8009d44:	0014      	movs	r4, r2
 8009d46:	2c00      	cmp	r4, #0
 8009d48:	d11a      	bne.n	8009d80 <_malloc_r+0x5c>
 8009d4a:	4f24      	ldr	r7, [pc, #144]	; (8009ddc <_malloc_r+0xb8>)
 8009d4c:	683b      	ldr	r3, [r7, #0]
 8009d4e:	2b00      	cmp	r3, #0
 8009d50:	d104      	bne.n	8009d5c <_malloc_r+0x38>
 8009d52:	0021      	movs	r1, r4
 8009d54:	0030      	movs	r0, r6
 8009d56:	f000 f843 	bl	8009de0 <_sbrk_r>
 8009d5a:	6038      	str	r0, [r7, #0]
 8009d5c:	0029      	movs	r1, r5
 8009d5e:	0030      	movs	r0, r6
 8009d60:	f000 f83e 	bl	8009de0 <_sbrk_r>
 8009d64:	1c43      	adds	r3, r0, #1
 8009d66:	d12b      	bne.n	8009dc0 <_malloc_r+0x9c>
 8009d68:	230c      	movs	r3, #12
 8009d6a:	0030      	movs	r0, r6
 8009d6c:	6033      	str	r3, [r6, #0]
 8009d6e:	f000 f9cd 	bl	800a10c <__malloc_unlock>
 8009d72:	e003      	b.n	8009d7c <_malloc_r+0x58>
 8009d74:	2d00      	cmp	r5, #0
 8009d76:	dade      	bge.n	8009d36 <_malloc_r+0x12>
 8009d78:	230c      	movs	r3, #12
 8009d7a:	6033      	str	r3, [r6, #0]
 8009d7c:	2000      	movs	r0, #0
 8009d7e:	bdf8      	pop	{r3, r4, r5, r6, r7, pc}
 8009d80:	6823      	ldr	r3, [r4, #0]
 8009d82:	1b5b      	subs	r3, r3, r5
 8009d84:	d419      	bmi.n	8009dba <_malloc_r+0x96>
 8009d86:	2b0b      	cmp	r3, #11
 8009d88:	d903      	bls.n	8009d92 <_malloc_r+0x6e>
 8009d8a:	6023      	str	r3, [r4, #0]
 8009d8c:	18e4      	adds	r4, r4, r3
 8009d8e:	6025      	str	r5, [r4, #0]
 8009d90:	e003      	b.n	8009d9a <_malloc_r+0x76>
 8009d92:	6863      	ldr	r3, [r4, #4]
 8009d94:	42a2      	cmp	r2, r4
 8009d96:	d10e      	bne.n	8009db6 <_malloc_r+0x92>
 8009d98:	600b      	str	r3, [r1, #0]
 8009d9a:	0030      	movs	r0, r6
 8009d9c:	f000 f9b6 	bl	800a10c <__malloc_unlock>
 8009da0:	0020      	movs	r0, r4
 8009da2:	2207      	movs	r2, #7
 8009da4:	300b      	adds	r0, #11
 8009da6:	1d23      	adds	r3, r4, #4
 8009da8:	4390      	bics	r0, r2
 8009daa:	1ac2      	subs	r2, r0, r3
 8009dac:	4298      	cmp	r0, r3
 8009dae:	d0e6      	beq.n	8009d7e <_malloc_r+0x5a>
 8009db0:	1a1b      	subs	r3, r3, r0
 8009db2:	50a3      	str	r3, [r4, r2]
 8009db4:	e7e3      	b.n	8009d7e <_malloc_r+0x5a>
 8009db6:	6053      	str	r3, [r2, #4]
 8009db8:	e7ef      	b.n	8009d9a <_malloc_r+0x76>
 8009dba:	0022      	movs	r2, r4
 8009dbc:	6864      	ldr	r4, [r4, #4]
 8009dbe:	e7c2      	b.n	8009d46 <_malloc_r+0x22>
 8009dc0:	2303      	movs	r3, #3
 8009dc2:	1cc4      	adds	r4, r0, #3
 8009dc4:	439c      	bics	r4, r3
 8009dc6:	42a0      	cmp	r0, r4
 8009dc8:	d0e1      	beq.n	8009d8e <_malloc_r+0x6a>
 8009dca:	1a21      	subs	r1, r4, r0
 8009dcc:	0030      	movs	r0, r6
 8009dce:	f000 f807 	bl	8009de0 <_sbrk_r>
 8009dd2:	1c43      	adds	r3, r0, #1
 8009dd4:	d1db      	bne.n	8009d8e <_malloc_r+0x6a>
 8009dd6:	e7c7      	b.n	8009d68 <_malloc_r+0x44>
 8009dd8:	2000212c 	.word	0x2000212c
 8009ddc:	20002130 	.word	0x20002130

08009de0 <_sbrk_r>:
 8009de0:	2300      	movs	r3, #0
 8009de2:	b570      	push	{r4, r5, r6, lr}
 8009de4:	4d06      	ldr	r5, [pc, #24]	; (8009e00 <_sbrk_r+0x20>)
 8009de6:	0004      	movs	r4, r0
 8009de8:	0008      	movs	r0, r1
 8009dea:	602b      	str	r3, [r5, #0]
 8009dec:	f7fb fcf2 	bl	80057d4 <_sbrk>
 8009df0:	1c43      	adds	r3, r0, #1
 8009df2:	d103      	bne.n	8009dfc <_sbrk_r+0x1c>
 8009df4:	682b      	ldr	r3, [r5, #0]
 8009df6:	2b00      	cmp	r3, #0
 8009df8:	d000      	beq.n	8009dfc <_sbrk_r+0x1c>
 8009dfa:	6023      	str	r3, [r4, #0]
 8009dfc:	bd70      	pop	{r4, r5, r6, pc}
 8009dfe:	46c0      	nop			; (mov r8, r8)
 8009e00:	200022dc 	.word	0x200022dc

08009e04 <__assert_func>:
 8009e04:	b530      	push	{r4, r5, lr}
 8009e06:	0014      	movs	r4, r2
 8009e08:	001a      	movs	r2, r3
 8009e0a:	4b09      	ldr	r3, [pc, #36]	; (8009e30 <__assert_func+0x2c>)
 8009e0c:	0005      	movs	r5, r0
 8009e0e:	681b      	ldr	r3, [r3, #0]
 8009e10:	b085      	sub	sp, #20
 8009e12:	68d8      	ldr	r0, [r3, #12]
 8009e14:	4b07      	ldr	r3, [pc, #28]	; (8009e34 <__assert_func+0x30>)
 8009e16:	2c00      	cmp	r4, #0
 8009e18:	d101      	bne.n	8009e1e <__assert_func+0x1a>
 8009e1a:	4b07      	ldr	r3, [pc, #28]	; (8009e38 <__assert_func+0x34>)
 8009e1c:	001c      	movs	r4, r3
 8009e1e:	9301      	str	r3, [sp, #4]
 8009e20:	9100      	str	r1, [sp, #0]
 8009e22:	002b      	movs	r3, r5
 8009e24:	4905      	ldr	r1, [pc, #20]	; (8009e3c <__assert_func+0x38>)
 8009e26:	9402      	str	r4, [sp, #8]
 8009e28:	f000 f958 	bl	800a0dc <fiprintf>
 8009e2c:	f001 f8f6 	bl	800b01c <abort>
 8009e30:	20000088 	.word	0x20000088
 8009e34:	0800f0b8 	.word	0x0800f0b8
 8009e38:	0800f0f3 	.word	0x0800f0f3
 8009e3c:	0800f0c5 	.word	0x0800f0c5

08009e40 <print_e>:
 8009e40:	b5f0      	push	{r4, r5, r6, r7, lr}
 8009e42:	b08b      	sub	sp, #44	; 0x2c
 8009e44:	000f      	movs	r7, r1
 8009e46:	a910      	add	r1, sp, #64	; 0x40
 8009e48:	c920      	ldmia	r1!, {r5}
 8009e4a:	780e      	ldrb	r6, [r1, #0]
 8009e4c:	a908      	add	r1, sp, #32
 8009e4e:	9104      	str	r1, [sp, #16]
 8009e50:	a907      	add	r1, sp, #28
 8009e52:	9103      	str	r1, [sp, #12]
 8009e54:	a909      	add	r1, sp, #36	; 0x24
 8009e56:	9102      	str	r1, [sp, #8]
 8009e58:	1c69      	adds	r1, r5, #1
 8009e5a:	9101      	str	r1, [sp, #4]
 8009e5c:	2102      	movs	r1, #2
 8009e5e:	9100      	str	r1, [sp, #0]
 8009e60:	f001 f96e 	bl	800b140 <_dtoa_r>
 8009e64:	9a09      	ldr	r2, [sp, #36]	; 0x24
 8009e66:	4b36      	ldr	r3, [pc, #216]	; (8009f40 <print_e+0x100>)
 8009e68:	0001      	movs	r1, r0
 8009e6a:	429a      	cmp	r2, r3
 8009e6c:	d104      	bne.n	8009e78 <print_e+0x38>
 8009e6e:	0038      	movs	r0, r7
 8009e70:	f000 fffe 	bl	800ae70 <strcpy>
 8009e74:	b00b      	add	sp, #44	; 0x2c
 8009e76:	bdf0      	pop	{r4, r5, r6, r7, pc}
 8009e78:	7801      	ldrb	r1, [r0, #0]
 8009e7a:	1c43      	adds	r3, r0, #1
 8009e7c:	1c7c      	adds	r4, r7, #1
 8009e7e:	7039      	strb	r1, [r7, #0]
 8009e80:	2d00      	cmp	r5, #0
 8009e82:	dd01      	ble.n	8009e88 <print_e+0x48>
 8009e84:	2101      	movs	r1, #1
 8009e86:	9112      	str	r1, [sp, #72]	; 0x48
 8009e88:	212e      	movs	r1, #46	; 0x2e
 8009e8a:	7818      	ldrb	r0, [r3, #0]
 8009e8c:	2800      	cmp	r0, #0
 8009e8e:	d001      	beq.n	8009e94 <print_e+0x54>
 8009e90:	2d00      	cmp	r5, #0
 8009e92:	dc35      	bgt.n	8009f00 <print_e+0xc0>
 8009e94:	2e67      	cmp	r6, #103	; 0x67
 8009e96:	d04b      	beq.n	8009f30 <print_e+0xf0>
 8009e98:	2e47      	cmp	r6, #71	; 0x47
 8009e9a:	d04b      	beq.n	8009f34 <print_e+0xf4>
 8009e9c:	232e      	movs	r3, #46	; 0x2e
 8009e9e:	2130      	movs	r1, #48	; 0x30
 8009ea0:	2d00      	cmp	r5, #0
 8009ea2:	dc3a      	bgt.n	8009f1a <print_e+0xda>
 8009ea4:	1e53      	subs	r3, r2, #1
 8009ea6:	7026      	strb	r6, [r4, #0]
 8009ea8:	9309      	str	r3, [sp, #36]	; 0x24
 8009eaa:	1ca5      	adds	r5, r4, #2
 8009eac:	2b00      	cmp	r3, #0
 8009eae:	da43      	bge.n	8009f38 <print_e+0xf8>
 8009eb0:	232d      	movs	r3, #45	; 0x2d
 8009eb2:	7063      	strb	r3, [r4, #1]
 8009eb4:	3b2c      	subs	r3, #44	; 0x2c
 8009eb6:	1a9b      	subs	r3, r3, r2
 8009eb8:	9309      	str	r3, [sp, #36]	; 0x24
 8009eba:	9e09      	ldr	r6, [sp, #36]	; 0x24
 8009ebc:	2e63      	cmp	r6, #99	; 0x63
 8009ebe:	dd0d      	ble.n	8009edc <print_e+0x9c>
 8009ec0:	2164      	movs	r1, #100	; 0x64
 8009ec2:	0030      	movs	r0, r6
 8009ec4:	f7f6 f9a8 	bl	8000218 <__divsi3>
 8009ec8:	0003      	movs	r3, r0
 8009eca:	0002      	movs	r2, r0
 8009ecc:	2064      	movs	r0, #100	; 0x64
 8009ece:	4240      	negs	r0, r0
 8009ed0:	4358      	muls	r0, r3
 8009ed2:	3230      	adds	r2, #48	; 0x30
 8009ed4:	1980      	adds	r0, r0, r6
 8009ed6:	1ce5      	adds	r5, r4, #3
 8009ed8:	70a2      	strb	r2, [r4, #2]
 8009eda:	9009      	str	r0, [sp, #36]	; 0x24
 8009edc:	9c09      	ldr	r4, [sp, #36]	; 0x24
 8009ede:	210a      	movs	r1, #10
 8009ee0:	0020      	movs	r0, r4
 8009ee2:	f7f6 f999 	bl	8000218 <__divsi3>
 8009ee6:	0003      	movs	r3, r0
 8009ee8:	0002      	movs	r2, r0
 8009eea:	200a      	movs	r0, #10
 8009eec:	4240      	negs	r0, r0
 8009eee:	4358      	muls	r0, r3
 8009ef0:	2300      	movs	r3, #0
 8009ef2:	1900      	adds	r0, r0, r4
 8009ef4:	3230      	adds	r2, #48	; 0x30
 8009ef6:	3030      	adds	r0, #48	; 0x30
 8009ef8:	702a      	strb	r2, [r5, #0]
 8009efa:	7068      	strb	r0, [r5, #1]
 8009efc:	70ab      	strb	r3, [r5, #2]
 8009efe:	e7b9      	b.n	8009e74 <print_e+0x34>
 8009f00:	9812      	ldr	r0, [sp, #72]	; 0x48
 8009f02:	2800      	cmp	r0, #0
 8009f04:	d001      	beq.n	8009f0a <print_e+0xca>
 8009f06:	7021      	strb	r1, [r4, #0]
 8009f08:	3401      	adds	r4, #1
 8009f0a:	7818      	ldrb	r0, [r3, #0]
 8009f0c:	3d01      	subs	r5, #1
 8009f0e:	7020      	strb	r0, [r4, #0]
 8009f10:	2000      	movs	r0, #0
 8009f12:	3301      	adds	r3, #1
 8009f14:	3401      	adds	r4, #1
 8009f16:	9012      	str	r0, [sp, #72]	; 0x48
 8009f18:	e7b7      	b.n	8009e8a <print_e+0x4a>
 8009f1a:	9812      	ldr	r0, [sp, #72]	; 0x48
 8009f1c:	2800      	cmp	r0, #0
 8009f1e:	d001      	beq.n	8009f24 <print_e+0xe4>
 8009f20:	7023      	strb	r3, [r4, #0]
 8009f22:	3401      	adds	r4, #1
 8009f24:	2000      	movs	r0, #0
 8009f26:	7021      	strb	r1, [r4, #0]
 8009f28:	3d01      	subs	r5, #1
 8009f2a:	3401      	adds	r4, #1
 8009f2c:	9012      	str	r0, [sp, #72]	; 0x48
 8009f2e:	e7b7      	b.n	8009ea0 <print_e+0x60>
 8009f30:	2665      	movs	r6, #101	; 0x65
 8009f32:	e7b7      	b.n	8009ea4 <print_e+0x64>
 8009f34:	2645      	movs	r6, #69	; 0x45
 8009f36:	e7b5      	b.n	8009ea4 <print_e+0x64>
 8009f38:	232b      	movs	r3, #43	; 0x2b
 8009f3a:	7063      	strb	r3, [r4, #1]
 8009f3c:	e7bd      	b.n	8009eba <print_e+0x7a>
 8009f3e:	46c0      	nop			; (mov r8, r8)
 8009f40:	0000270f 	.word	0x0000270f

08009f44 <_gcvt>:
 8009f44:	b5f0      	push	{r4, r5, r6, r7, lr}
 8009f46:	0016      	movs	r6, r2
 8009f48:	001d      	movs	r5, r3
 8009f4a:	b08d      	sub	sp, #52	; 0x34
 8009f4c:	ab14      	add	r3, sp, #80	; 0x50
 8009f4e:	781b      	ldrb	r3, [r3, #0]
 8009f50:	0007      	movs	r7, r0
 8009f52:	9307      	str	r3, [sp, #28]
 8009f54:	2200      	movs	r2, #0
 8009f56:	2300      	movs	r3, #0
 8009f58:	0030      	movs	r0, r6
 8009f5a:	0029      	movs	r1, r5
 8009f5c:	9c13      	ldr	r4, [sp, #76]	; 0x4c
 8009f5e:	f7f8 ff05 	bl	8002d6c <__aeabi_dcmplt>
 8009f62:	2800      	cmp	r0, #0
 8009f64:	d002      	beq.n	8009f6c <_gcvt+0x28>
 8009f66:	2380      	movs	r3, #128	; 0x80
 8009f68:	061b      	lsls	r3, r3, #24
 8009f6a:	18ed      	adds	r5, r5, r3
 8009f6c:	2200      	movs	r2, #0
 8009f6e:	2300      	movs	r3, #0
 8009f70:	0030      	movs	r0, r6
 8009f72:	0029      	movs	r1, r5
 8009f74:	f7f8 fef4 	bl	8002d60 <__aeabi_dcmpeq>
 8009f78:	2800      	cmp	r0, #0
 8009f7a:	d006      	beq.n	8009f8a <_gcvt+0x46>
 8009f7c:	2330      	movs	r3, #48	; 0x30
 8009f7e:	7023      	strb	r3, [r4, #0]
 8009f80:	2300      	movs	r3, #0
 8009f82:	7063      	strb	r3, [r4, #1]
 8009f84:	0020      	movs	r0, r4
 8009f86:	b00d      	add	sp, #52	; 0x34
 8009f88:	bdf0      	pop	{r4, r5, r6, r7, pc}
 8009f8a:	0030      	movs	r0, r6
 8009f8c:	0029      	movs	r1, r5
 8009f8e:	4a50      	ldr	r2, [pc, #320]	; (800a0d0 <_gcvt+0x18c>)
 8009f90:	4b50      	ldr	r3, [pc, #320]	; (800a0d4 <_gcvt+0x190>)
 8009f92:	f7f8 fef5 	bl	8002d80 <__aeabi_dcmple>
 8009f96:	2800      	cmp	r0, #0
 8009f98:	d00d      	beq.n	8009fb6 <_gcvt+0x72>
 8009f9a:	9b15      	ldr	r3, [sp, #84]	; 0x54
 8009f9c:	0032      	movs	r2, r6
 8009f9e:	9302      	str	r3, [sp, #8]
 8009fa0:	9b07      	ldr	r3, [sp, #28]
 8009fa2:	0021      	movs	r1, r4
 8009fa4:	9301      	str	r3, [sp, #4]
 8009fa6:	9b12      	ldr	r3, [sp, #72]	; 0x48
 8009fa8:	0038      	movs	r0, r7
 8009faa:	3b01      	subs	r3, #1
 8009fac:	9300      	str	r3, [sp, #0]
 8009fae:	002b      	movs	r3, r5
 8009fb0:	f7ff ff46 	bl	8009e40 <print_e>
 8009fb4:	e7e6      	b.n	8009f84 <_gcvt+0x40>
 8009fb6:	9812      	ldr	r0, [sp, #72]	; 0x48
 8009fb8:	f000 fc4e 	bl	800a858 <_mprec_log10>
 8009fbc:	0032      	movs	r2, r6
 8009fbe:	002b      	movs	r3, r5
 8009fc0:	f7f8 fede 	bl	8002d80 <__aeabi_dcmple>
 8009fc4:	2800      	cmp	r0, #0
 8009fc6:	d1e8      	bne.n	8009f9a <_gcvt+0x56>
 8009fc8:	ab0b      	add	r3, sp, #44	; 0x2c
 8009fca:	9304      	str	r3, [sp, #16]
 8009fcc:	ab0a      	add	r3, sp, #40	; 0x28
 8009fce:	9303      	str	r3, [sp, #12]
 8009fd0:	ab09      	add	r3, sp, #36	; 0x24
 8009fd2:	9302      	str	r3, [sp, #8]
 8009fd4:	9b12      	ldr	r3, [sp, #72]	; 0x48
 8009fd6:	0032      	movs	r2, r6
 8009fd8:	9301      	str	r3, [sp, #4]
 8009fda:	2302      	movs	r3, #2
 8009fdc:	0038      	movs	r0, r7
 8009fde:	9300      	str	r3, [sp, #0]
 8009fe0:	002b      	movs	r3, r5
 8009fe2:	f001 f8ad 	bl	800b140 <_dtoa_r>
 8009fe6:	4b3c      	ldr	r3, [pc, #240]	; (800a0d8 <_gcvt+0x194>)
 8009fe8:	9a09      	ldr	r2, [sp, #36]	; 0x24
 8009fea:	0001      	movs	r1, r0
 8009fec:	0020      	movs	r0, r4
 8009fee:	429a      	cmp	r2, r3
 8009ff0:	d00d      	beq.n	800a00e <_gcvt+0xca>
 8009ff2:	9b12      	ldr	r3, [sp, #72]	; 0x48
 8009ff4:	18e2      	adds	r2, r4, r3
 8009ff6:	780e      	ldrb	r6, [r1, #0]
 8009ff8:	9d09      	ldr	r5, [sp, #36]	; 0x24
 8009ffa:	1a13      	subs	r3, r2, r0
 8009ffc:	2e00      	cmp	r6, #0
 8009ffe:	d002      	beq.n	800a006 <_gcvt+0xc2>
 800a000:	2d00      	cmp	r5, #0
 800a002:	dc07      	bgt.n	800a014 <_gcvt+0xd0>
 800a004:	2600      	movs	r6, #0
 800a006:	2201      	movs	r2, #1
 800a008:	2730      	movs	r7, #48	; 0x30
 800a00a:	4694      	mov	ip, r2
 800a00c:	e00f      	b.n	800a02e <_gcvt+0xea>
 800a00e:	f000 ff2f 	bl	800ae70 <strcpy>
 800a012:	e7b7      	b.n	8009f84 <_gcvt+0x40>
 800a014:	3d01      	subs	r5, #1
 800a016:	7006      	strb	r6, [r0, #0]
 800a018:	3101      	adds	r1, #1
 800a01a:	9509      	str	r5, [sp, #36]	; 0x24
 800a01c:	3001      	adds	r0, #1
 800a01e:	e7ea      	b.n	8009ff6 <_gcvt+0xb2>
 800a020:	2b00      	cmp	r3, #0
 800a022:	dd07      	ble.n	800a034 <_gcvt+0xf0>
 800a024:	4666      	mov	r6, ip
 800a026:	7007      	strb	r7, [r0, #0]
 800a028:	3d01      	subs	r5, #1
 800a02a:	3b01      	subs	r3, #1
 800a02c:	3001      	adds	r0, #1
 800a02e:	0002      	movs	r2, r0
 800a030:	2d00      	cmp	r5, #0
 800a032:	dcf5      	bgt.n	800a020 <_gcvt+0xdc>
 800a034:	2e00      	cmp	r6, #0
 800a036:	d000      	beq.n	800a03a <_gcvt+0xf6>
 800a038:	9509      	str	r5, [sp, #36]	; 0x24
 800a03a:	9d15      	ldr	r5, [sp, #84]	; 0x54
 800a03c:	2d00      	cmp	r5, #0
 800a03e:	d102      	bne.n	800a046 <_gcvt+0x102>
 800a040:	780d      	ldrb	r5, [r1, #0]
 800a042:	2d00      	cmp	r5, #0
 800a044:	d029      	beq.n	800a09a <_gcvt+0x156>
 800a046:	4284      	cmp	r4, r0
 800a048:	d102      	bne.n	800a050 <_gcvt+0x10c>
 800a04a:	2230      	movs	r2, #48	; 0x30
 800a04c:	7022      	strb	r2, [r4, #0]
 800a04e:	1c62      	adds	r2, r4, #1
 800a050:	202e      	movs	r0, #46	; 0x2e
 800a052:	7010      	strb	r0, [r2, #0]
 800a054:	9809      	ldr	r0, [sp, #36]	; 0x24
 800a056:	0015      	movs	r5, r2
 800a058:	1a87      	subs	r7, r0, r2
 800a05a:	9707      	str	r7, [sp, #28]
 800a05c:	2701      	movs	r7, #1
 800a05e:	2600      	movs	r6, #0
 800a060:	46bc      	mov	ip, r7
 800a062:	9f07      	ldr	r7, [sp, #28]
 800a064:	42ef      	cmn	r7, r5
 800a066:	d41b      	bmi.n	800a0a0 <_gcvt+0x15c>
 800a068:	2500      	movs	r5, #0
 800a06a:	4247      	negs	r7, r0
 800a06c:	42a8      	cmp	r0, r5
 800a06e:	dc00      	bgt.n	800a072 <_gcvt+0x12e>
 800a070:	003d      	movs	r5, r7
 800a072:	3501      	adds	r5, #1
 800a074:	1952      	adds	r2, r2, r5
 800a076:	2500      	movs	r5, #0
 800a078:	42a8      	cmp	r0, r5
 800a07a:	dc00      	bgt.n	800a07e <_gcvt+0x13a>
 800a07c:	003d      	movs	r5, r7
 800a07e:	1945      	adds	r5, r0, r5
 800a080:	2e00      	cmp	r6, #0
 800a082:	d000      	beq.n	800a086 <_gcvt+0x142>
 800a084:	9509      	str	r5, [sp, #36]	; 0x24
 800a086:	0010      	movs	r0, r2
 800a088:	780d      	ldrb	r5, [r1, #0]
 800a08a:	0002      	movs	r2, r0
 800a08c:	2d00      	cmp	r5, #0
 800a08e:	d001      	beq.n	800a094 <_gcvt+0x150>
 800a090:	2b00      	cmp	r3, #0
 800a092:	dc0a      	bgt.n	800a0aa <_gcvt+0x166>
 800a094:	9915      	ldr	r1, [sp, #84]	; 0x54
 800a096:	2900      	cmp	r1, #0
 800a098:	d116      	bne.n	800a0c8 <_gcvt+0x184>
 800a09a:	2300      	movs	r3, #0
 800a09c:	7013      	strb	r3, [r2, #0]
 800a09e:	e771      	b.n	8009f84 <_gcvt+0x40>
 800a0a0:	2630      	movs	r6, #48	; 0x30
 800a0a2:	3501      	adds	r5, #1
 800a0a4:	702e      	strb	r6, [r5, #0]
 800a0a6:	4666      	mov	r6, ip
 800a0a8:	e7db      	b.n	800a062 <_gcvt+0x11e>
 800a0aa:	7005      	strb	r5, [r0, #0]
 800a0ac:	3101      	adds	r1, #1
 800a0ae:	3b01      	subs	r3, #1
 800a0b0:	3001      	adds	r0, #1
 800a0b2:	e7e9      	b.n	800a088 <_gcvt+0x144>
 800a0b4:	7016      	strb	r6, [r2, #0]
 800a0b6:	3201      	adds	r2, #1
 800a0b8:	1aa9      	subs	r1, r5, r2
 800a0ba:	2900      	cmp	r1, #0
 800a0bc:	dcfa      	bgt.n	800a0b4 <_gcvt+0x170>
 800a0be:	43da      	mvns	r2, r3
 800a0c0:	17d2      	asrs	r2, r2, #31
 800a0c2:	401a      	ands	r2, r3
 800a0c4:	1882      	adds	r2, r0, r2
 800a0c6:	e7e8      	b.n	800a09a <_gcvt+0x156>
 800a0c8:	0002      	movs	r2, r0
 800a0ca:	2630      	movs	r6, #48	; 0x30
 800a0cc:	181d      	adds	r5, r3, r0
 800a0ce:	e7f3      	b.n	800a0b8 <_gcvt+0x174>
 800a0d0:	eb1c432d 	.word	0xeb1c432d
 800a0d4:	3f1a36e2 	.word	0x3f1a36e2
 800a0d8:	0000270f 	.word	0x0000270f

0800a0dc <fiprintf>:
 800a0dc:	b40e      	push	{r1, r2, r3}
 800a0de:	b503      	push	{r0, r1, lr}
 800a0e0:	0001      	movs	r1, r0
 800a0e2:	ab03      	add	r3, sp, #12
 800a0e4:	4804      	ldr	r0, [pc, #16]	; (800a0f8 <fiprintf+0x1c>)
 800a0e6:	cb04      	ldmia	r3!, {r2}
 800a0e8:	6800      	ldr	r0, [r0, #0]
 800a0ea:	9301      	str	r3, [sp, #4]
 800a0ec:	f000 fc04 	bl	800a8f8 <_vfiprintf_r>
 800a0f0:	b002      	add	sp, #8
 800a0f2:	bc08      	pop	{r3}
 800a0f4:	b003      	add	sp, #12
 800a0f6:	4718      	bx	r3
 800a0f8:	20000088 	.word	0x20000088

0800a0fc <__malloc_lock>:
 800a0fc:	b510      	push	{r4, lr}
 800a0fe:	4802      	ldr	r0, [pc, #8]	; (800a108 <__malloc_lock+0xc>)
 800a100:	f002 f80b 	bl	800c11a <__retarget_lock_acquire_recursive>
 800a104:	bd10      	pop	{r4, pc}
 800a106:	46c0      	nop			; (mov r8, r8)
 800a108:	200022e4 	.word	0x200022e4

0800a10c <__malloc_unlock>:
 800a10c:	b510      	push	{r4, lr}
 800a10e:	4802      	ldr	r0, [pc, #8]	; (800a118 <__malloc_unlock+0xc>)
 800a110:	f002 f804 	bl	800c11c <__retarget_lock_release_recursive>
 800a114:	bd10      	pop	{r4, pc}
 800a116:	46c0      	nop			; (mov r8, r8)
 800a118:	200022e4 	.word	0x200022e4

0800a11c <_Balloc>:
 800a11c:	b570      	push	{r4, r5, r6, lr}
 800a11e:	6a45      	ldr	r5, [r0, #36]	; 0x24
 800a120:	0006      	movs	r6, r0
 800a122:	000c      	movs	r4, r1
 800a124:	2d00      	cmp	r5, #0
 800a126:	d10e      	bne.n	800a146 <_Balloc+0x2a>
 800a128:	2010      	movs	r0, #16
 800a12a:	f7ff fd9f 	bl	8009c6c <malloc>
 800a12e:	1e02      	subs	r2, r0, #0
 800a130:	6270      	str	r0, [r6, #36]	; 0x24
 800a132:	d104      	bne.n	800a13e <_Balloc+0x22>
 800a134:	2166      	movs	r1, #102	; 0x66
 800a136:	4b19      	ldr	r3, [pc, #100]	; (800a19c <_Balloc+0x80>)
 800a138:	4819      	ldr	r0, [pc, #100]	; (800a1a0 <_Balloc+0x84>)
 800a13a:	f7ff fe63 	bl	8009e04 <__assert_func>
 800a13e:	6045      	str	r5, [r0, #4]
 800a140:	6085      	str	r5, [r0, #8]
 800a142:	6005      	str	r5, [r0, #0]
 800a144:	60c5      	str	r5, [r0, #12]
 800a146:	6a75      	ldr	r5, [r6, #36]	; 0x24
 800a148:	68eb      	ldr	r3, [r5, #12]
 800a14a:	2b00      	cmp	r3, #0
 800a14c:	d013      	beq.n	800a176 <_Balloc+0x5a>
 800a14e:	6a73      	ldr	r3, [r6, #36]	; 0x24
 800a150:	00a2      	lsls	r2, r4, #2
 800a152:	68db      	ldr	r3, [r3, #12]
 800a154:	189b      	adds	r3, r3, r2
 800a156:	6818      	ldr	r0, [r3, #0]
 800a158:	2800      	cmp	r0, #0
 800a15a:	d118      	bne.n	800a18e <_Balloc+0x72>
 800a15c:	2101      	movs	r1, #1
 800a15e:	000d      	movs	r5, r1
 800a160:	40a5      	lsls	r5, r4
 800a162:	1d6a      	adds	r2, r5, #5
 800a164:	0030      	movs	r0, r6
 800a166:	0092      	lsls	r2, r2, #2
 800a168:	f000 fb90 	bl	800a88c <_calloc_r>
 800a16c:	2800      	cmp	r0, #0
 800a16e:	d00c      	beq.n	800a18a <_Balloc+0x6e>
 800a170:	6044      	str	r4, [r0, #4]
 800a172:	6085      	str	r5, [r0, #8]
 800a174:	e00d      	b.n	800a192 <_Balloc+0x76>
 800a176:	2221      	movs	r2, #33	; 0x21
 800a178:	2104      	movs	r1, #4
 800a17a:	0030      	movs	r0, r6
 800a17c:	f000 fb86 	bl	800a88c <_calloc_r>
 800a180:	6a73      	ldr	r3, [r6, #36]	; 0x24
 800a182:	60e8      	str	r0, [r5, #12]
 800a184:	68db      	ldr	r3, [r3, #12]
 800a186:	2b00      	cmp	r3, #0
 800a188:	d1e1      	bne.n	800a14e <_Balloc+0x32>
 800a18a:	2000      	movs	r0, #0
 800a18c:	bd70      	pop	{r4, r5, r6, pc}
 800a18e:	6802      	ldr	r2, [r0, #0]
 800a190:	601a      	str	r2, [r3, #0]
 800a192:	2300      	movs	r3, #0
 800a194:	6103      	str	r3, [r0, #16]
 800a196:	60c3      	str	r3, [r0, #12]
 800a198:	e7f8      	b.n	800a18c <_Balloc+0x70>
 800a19a:	46c0      	nop			; (mov r8, r8)
 800a19c:	0800f0f4 	.word	0x0800f0f4
 800a1a0:	0800f10b 	.word	0x0800f10b

0800a1a4 <_Bfree>:
 800a1a4:	b570      	push	{r4, r5, r6, lr}
 800a1a6:	6a46      	ldr	r6, [r0, #36]	; 0x24
 800a1a8:	0005      	movs	r5, r0
 800a1aa:	000c      	movs	r4, r1
 800a1ac:	2e00      	cmp	r6, #0
 800a1ae:	d10e      	bne.n	800a1ce <_Bfree+0x2a>
 800a1b0:	2010      	movs	r0, #16
 800a1b2:	f7ff fd5b 	bl	8009c6c <malloc>
 800a1b6:	1e02      	subs	r2, r0, #0
 800a1b8:	6268      	str	r0, [r5, #36]	; 0x24
 800a1ba:	d104      	bne.n	800a1c6 <_Bfree+0x22>
 800a1bc:	218a      	movs	r1, #138	; 0x8a
 800a1be:	4b09      	ldr	r3, [pc, #36]	; (800a1e4 <_Bfree+0x40>)
 800a1c0:	4809      	ldr	r0, [pc, #36]	; (800a1e8 <_Bfree+0x44>)
 800a1c2:	f7ff fe1f 	bl	8009e04 <__assert_func>
 800a1c6:	6046      	str	r6, [r0, #4]
 800a1c8:	6086      	str	r6, [r0, #8]
 800a1ca:	6006      	str	r6, [r0, #0]
 800a1cc:	60c6      	str	r6, [r0, #12]
 800a1ce:	2c00      	cmp	r4, #0
 800a1d0:	d007      	beq.n	800a1e2 <_Bfree+0x3e>
 800a1d2:	6a6b      	ldr	r3, [r5, #36]	; 0x24
 800a1d4:	6862      	ldr	r2, [r4, #4]
 800a1d6:	68db      	ldr	r3, [r3, #12]
 800a1d8:	0092      	lsls	r2, r2, #2
 800a1da:	189b      	adds	r3, r3, r2
 800a1dc:	681a      	ldr	r2, [r3, #0]
 800a1de:	6022      	str	r2, [r4, #0]
 800a1e0:	601c      	str	r4, [r3, #0]
 800a1e2:	bd70      	pop	{r4, r5, r6, pc}
 800a1e4:	0800f0f4 	.word	0x0800f0f4
 800a1e8:	0800f10b 	.word	0x0800f10b

0800a1ec <__multadd>:
 800a1ec:	b5f7      	push	{r0, r1, r2, r4, r5, r6, r7, lr}
 800a1ee:	000e      	movs	r6, r1
 800a1f0:	9001      	str	r0, [sp, #4]
 800a1f2:	000c      	movs	r4, r1
 800a1f4:	001d      	movs	r5, r3
 800a1f6:	2000      	movs	r0, #0
 800a1f8:	690f      	ldr	r7, [r1, #16]
 800a1fa:	3614      	adds	r6, #20
 800a1fc:	6833      	ldr	r3, [r6, #0]
 800a1fe:	3001      	adds	r0, #1
 800a200:	b299      	uxth	r1, r3
 800a202:	4351      	muls	r1, r2
 800a204:	0c1b      	lsrs	r3, r3, #16
 800a206:	4353      	muls	r3, r2
 800a208:	1949      	adds	r1, r1, r5
 800a20a:	0c0d      	lsrs	r5, r1, #16
 800a20c:	195b      	adds	r3, r3, r5
 800a20e:	0c1d      	lsrs	r5, r3, #16
 800a210:	b289      	uxth	r1, r1
 800a212:	041b      	lsls	r3, r3, #16
 800a214:	185b      	adds	r3, r3, r1
 800a216:	c608      	stmia	r6!, {r3}
 800a218:	4287      	cmp	r7, r0
 800a21a:	dcef      	bgt.n	800a1fc <__multadd+0x10>
 800a21c:	2d00      	cmp	r5, #0
 800a21e:	d022      	beq.n	800a266 <__multadd+0x7a>
 800a220:	68a3      	ldr	r3, [r4, #8]
 800a222:	42bb      	cmp	r3, r7
 800a224:	dc19      	bgt.n	800a25a <__multadd+0x6e>
 800a226:	6863      	ldr	r3, [r4, #4]
 800a228:	9801      	ldr	r0, [sp, #4]
 800a22a:	1c59      	adds	r1, r3, #1
 800a22c:	f7ff ff76 	bl	800a11c <_Balloc>
 800a230:	1e06      	subs	r6, r0, #0
 800a232:	d105      	bne.n	800a240 <__multadd+0x54>
 800a234:	0002      	movs	r2, r0
 800a236:	21b5      	movs	r1, #181	; 0xb5
 800a238:	4b0c      	ldr	r3, [pc, #48]	; (800a26c <__multadd+0x80>)
 800a23a:	480d      	ldr	r0, [pc, #52]	; (800a270 <__multadd+0x84>)
 800a23c:	f7ff fde2 	bl	8009e04 <__assert_func>
 800a240:	0021      	movs	r1, r4
 800a242:	6923      	ldr	r3, [r4, #16]
 800a244:	310c      	adds	r1, #12
 800a246:	1c9a      	adds	r2, r3, #2
 800a248:	0092      	lsls	r2, r2, #2
 800a24a:	300c      	adds	r0, #12
 800a24c:	f001 ffdf 	bl	800c20e <memcpy>
 800a250:	0021      	movs	r1, r4
 800a252:	9801      	ldr	r0, [sp, #4]
 800a254:	f7ff ffa6 	bl	800a1a4 <_Bfree>
 800a258:	0034      	movs	r4, r6
 800a25a:	1d3b      	adds	r3, r7, #4
 800a25c:	009b      	lsls	r3, r3, #2
 800a25e:	18e3      	adds	r3, r4, r3
 800a260:	605d      	str	r5, [r3, #4]
 800a262:	1c7b      	adds	r3, r7, #1
 800a264:	6123      	str	r3, [r4, #16]
 800a266:	0020      	movs	r0, r4
 800a268:	bdfe      	pop	{r1, r2, r3, r4, r5, r6, r7, pc}
 800a26a:	46c0      	nop			; (mov r8, r8)
 800a26c:	0800f16b 	.word	0x0800f16b
 800a270:	0800f10b 	.word	0x0800f10b

0800a274 <__hi0bits>:
 800a274:	0003      	movs	r3, r0
 800a276:	0c02      	lsrs	r2, r0, #16
 800a278:	2000      	movs	r0, #0
 800a27a:	4282      	cmp	r2, r0
 800a27c:	d101      	bne.n	800a282 <__hi0bits+0xe>
 800a27e:	041b      	lsls	r3, r3, #16
 800a280:	3010      	adds	r0, #16
 800a282:	0e1a      	lsrs	r2, r3, #24
 800a284:	d101      	bne.n	800a28a <__hi0bits+0x16>
 800a286:	3008      	adds	r0, #8
 800a288:	021b      	lsls	r3, r3, #8
 800a28a:	0f1a      	lsrs	r2, r3, #28
 800a28c:	d101      	bne.n	800a292 <__hi0bits+0x1e>
 800a28e:	3004      	adds	r0, #4
 800a290:	011b      	lsls	r3, r3, #4
 800a292:	0f9a      	lsrs	r2, r3, #30
 800a294:	d101      	bne.n	800a29a <__hi0bits+0x26>
 800a296:	3002      	adds	r0, #2
 800a298:	009b      	lsls	r3, r3, #2
 800a29a:	2b00      	cmp	r3, #0
 800a29c:	db03      	blt.n	800a2a6 <__hi0bits+0x32>
 800a29e:	3001      	adds	r0, #1
 800a2a0:	005b      	lsls	r3, r3, #1
 800a2a2:	d400      	bmi.n	800a2a6 <__hi0bits+0x32>
 800a2a4:	2020      	movs	r0, #32
 800a2a6:	4770      	bx	lr

0800a2a8 <__lo0bits>:
 800a2a8:	6803      	ldr	r3, [r0, #0]
 800a2aa:	0002      	movs	r2, r0
 800a2ac:	2107      	movs	r1, #7
 800a2ae:	0018      	movs	r0, r3
 800a2b0:	4008      	ands	r0, r1
 800a2b2:	420b      	tst	r3, r1
 800a2b4:	d00d      	beq.n	800a2d2 <__lo0bits+0x2a>
 800a2b6:	3906      	subs	r1, #6
 800a2b8:	2000      	movs	r0, #0
 800a2ba:	420b      	tst	r3, r1
 800a2bc:	d105      	bne.n	800a2ca <__lo0bits+0x22>
 800a2be:	3002      	adds	r0, #2
 800a2c0:	4203      	tst	r3, r0
 800a2c2:	d003      	beq.n	800a2cc <__lo0bits+0x24>
 800a2c4:	40cb      	lsrs	r3, r1
 800a2c6:	0008      	movs	r0, r1
 800a2c8:	6013      	str	r3, [r2, #0]
 800a2ca:	4770      	bx	lr
 800a2cc:	089b      	lsrs	r3, r3, #2
 800a2ce:	6013      	str	r3, [r2, #0]
 800a2d0:	e7fb      	b.n	800a2ca <__lo0bits+0x22>
 800a2d2:	b299      	uxth	r1, r3
 800a2d4:	2900      	cmp	r1, #0
 800a2d6:	d101      	bne.n	800a2dc <__lo0bits+0x34>
 800a2d8:	2010      	movs	r0, #16
 800a2da:	0c1b      	lsrs	r3, r3, #16
 800a2dc:	b2d9      	uxtb	r1, r3
 800a2de:	2900      	cmp	r1, #0
 800a2e0:	d101      	bne.n	800a2e6 <__lo0bits+0x3e>
 800a2e2:	3008      	adds	r0, #8
 800a2e4:	0a1b      	lsrs	r3, r3, #8
 800a2e6:	0719      	lsls	r1, r3, #28
 800a2e8:	d101      	bne.n	800a2ee <__lo0bits+0x46>
 800a2ea:	3004      	adds	r0, #4
 800a2ec:	091b      	lsrs	r3, r3, #4
 800a2ee:	0799      	lsls	r1, r3, #30
 800a2f0:	d101      	bne.n	800a2f6 <__lo0bits+0x4e>
 800a2f2:	3002      	adds	r0, #2
 800a2f4:	089b      	lsrs	r3, r3, #2
 800a2f6:	07d9      	lsls	r1, r3, #31
 800a2f8:	d4e9      	bmi.n	800a2ce <__lo0bits+0x26>
 800a2fa:	3001      	adds	r0, #1
 800a2fc:	085b      	lsrs	r3, r3, #1
 800a2fe:	d1e6      	bne.n	800a2ce <__lo0bits+0x26>
 800a300:	2020      	movs	r0, #32
 800a302:	e7e2      	b.n	800a2ca <__lo0bits+0x22>

0800a304 <__i2b>:
 800a304:	b510      	push	{r4, lr}
 800a306:	000c      	movs	r4, r1
 800a308:	2101      	movs	r1, #1
 800a30a:	f7ff ff07 	bl	800a11c <_Balloc>
 800a30e:	2800      	cmp	r0, #0
 800a310:	d106      	bne.n	800a320 <__i2b+0x1c>
 800a312:	21a0      	movs	r1, #160	; 0xa0
 800a314:	0002      	movs	r2, r0
 800a316:	4b04      	ldr	r3, [pc, #16]	; (800a328 <__i2b+0x24>)
 800a318:	4804      	ldr	r0, [pc, #16]	; (800a32c <__i2b+0x28>)
 800a31a:	0049      	lsls	r1, r1, #1
 800a31c:	f7ff fd72 	bl	8009e04 <__assert_func>
 800a320:	2301      	movs	r3, #1
 800a322:	6144      	str	r4, [r0, #20]
 800a324:	6103      	str	r3, [r0, #16]
 800a326:	bd10      	pop	{r4, pc}
 800a328:	0800f16b 	.word	0x0800f16b
 800a32c:	0800f10b 	.word	0x0800f10b

0800a330 <__multiply>:
 800a330:	b5f0      	push	{r4, r5, r6, r7, lr}
 800a332:	690b      	ldr	r3, [r1, #16]
 800a334:	0014      	movs	r4, r2
 800a336:	6912      	ldr	r2, [r2, #16]
 800a338:	000d      	movs	r5, r1
 800a33a:	b089      	sub	sp, #36	; 0x24
 800a33c:	4293      	cmp	r3, r2
 800a33e:	da01      	bge.n	800a344 <__multiply+0x14>
 800a340:	0025      	movs	r5, r4
 800a342:	000c      	movs	r4, r1
 800a344:	692f      	ldr	r7, [r5, #16]
 800a346:	6926      	ldr	r6, [r4, #16]
 800a348:	6869      	ldr	r1, [r5, #4]
 800a34a:	19bb      	adds	r3, r7, r6
 800a34c:	9302      	str	r3, [sp, #8]
 800a34e:	68ab      	ldr	r3, [r5, #8]
 800a350:	19ba      	adds	r2, r7, r6
 800a352:	4293      	cmp	r3, r2
 800a354:	da00      	bge.n	800a358 <__multiply+0x28>
 800a356:	3101      	adds	r1, #1
 800a358:	f7ff fee0 	bl	800a11c <_Balloc>
 800a35c:	9001      	str	r0, [sp, #4]
 800a35e:	2800      	cmp	r0, #0
 800a360:	d106      	bne.n	800a370 <__multiply+0x40>
 800a362:	215e      	movs	r1, #94	; 0x5e
 800a364:	0002      	movs	r2, r0
 800a366:	4b48      	ldr	r3, [pc, #288]	; (800a488 <__multiply+0x158>)
 800a368:	4848      	ldr	r0, [pc, #288]	; (800a48c <__multiply+0x15c>)
 800a36a:	31ff      	adds	r1, #255	; 0xff
 800a36c:	f7ff fd4a 	bl	8009e04 <__assert_func>
 800a370:	9b01      	ldr	r3, [sp, #4]
 800a372:	2200      	movs	r2, #0
 800a374:	3314      	adds	r3, #20
 800a376:	469c      	mov	ip, r3
 800a378:	19bb      	adds	r3, r7, r6
 800a37a:	009b      	lsls	r3, r3, #2
 800a37c:	4463      	add	r3, ip
 800a37e:	9303      	str	r3, [sp, #12]
 800a380:	4663      	mov	r3, ip
 800a382:	9903      	ldr	r1, [sp, #12]
 800a384:	428b      	cmp	r3, r1
 800a386:	d32c      	bcc.n	800a3e2 <__multiply+0xb2>
 800a388:	002b      	movs	r3, r5
 800a38a:	0022      	movs	r2, r4
 800a38c:	3314      	adds	r3, #20
 800a38e:	00bf      	lsls	r7, r7, #2
 800a390:	3214      	adds	r2, #20
 800a392:	9306      	str	r3, [sp, #24]
 800a394:	00b6      	lsls	r6, r6, #2
 800a396:	19db      	adds	r3, r3, r7
 800a398:	9304      	str	r3, [sp, #16]
 800a39a:	1993      	adds	r3, r2, r6
 800a39c:	9307      	str	r3, [sp, #28]
 800a39e:	2304      	movs	r3, #4
 800a3a0:	9305      	str	r3, [sp, #20]
 800a3a2:	002b      	movs	r3, r5
 800a3a4:	9904      	ldr	r1, [sp, #16]
 800a3a6:	3315      	adds	r3, #21
 800a3a8:	9200      	str	r2, [sp, #0]
 800a3aa:	4299      	cmp	r1, r3
 800a3ac:	d305      	bcc.n	800a3ba <__multiply+0x8a>
 800a3ae:	1b4b      	subs	r3, r1, r5
 800a3b0:	3b15      	subs	r3, #21
 800a3b2:	089b      	lsrs	r3, r3, #2
 800a3b4:	3301      	adds	r3, #1
 800a3b6:	009b      	lsls	r3, r3, #2
 800a3b8:	9305      	str	r3, [sp, #20]
 800a3ba:	9b07      	ldr	r3, [sp, #28]
 800a3bc:	9a00      	ldr	r2, [sp, #0]
 800a3be:	429a      	cmp	r2, r3
 800a3c0:	d311      	bcc.n	800a3e6 <__multiply+0xb6>
 800a3c2:	9b02      	ldr	r3, [sp, #8]
 800a3c4:	2b00      	cmp	r3, #0
 800a3c6:	dd06      	ble.n	800a3d6 <__multiply+0xa6>
 800a3c8:	9b03      	ldr	r3, [sp, #12]
 800a3ca:	3b04      	subs	r3, #4
 800a3cc:	9303      	str	r3, [sp, #12]
 800a3ce:	681b      	ldr	r3, [r3, #0]
 800a3d0:	9300      	str	r3, [sp, #0]
 800a3d2:	2b00      	cmp	r3, #0
 800a3d4:	d054      	beq.n	800a480 <__multiply+0x150>
 800a3d6:	9b01      	ldr	r3, [sp, #4]
 800a3d8:	9a02      	ldr	r2, [sp, #8]
 800a3da:	0018      	movs	r0, r3
 800a3dc:	611a      	str	r2, [r3, #16]
 800a3de:	b009      	add	sp, #36	; 0x24
 800a3e0:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800a3e2:	c304      	stmia	r3!, {r2}
 800a3e4:	e7cd      	b.n	800a382 <__multiply+0x52>
 800a3e6:	9b00      	ldr	r3, [sp, #0]
 800a3e8:	681b      	ldr	r3, [r3, #0]
 800a3ea:	b298      	uxth	r0, r3
 800a3ec:	2800      	cmp	r0, #0
 800a3ee:	d01c      	beq.n	800a42a <__multiply+0xfa>
 800a3f0:	4667      	mov	r7, ip
 800a3f2:	2400      	movs	r4, #0
 800a3f4:	9e06      	ldr	r6, [sp, #24]
 800a3f6:	ce02      	ldmia	r6!, {r1}
 800a3f8:	683a      	ldr	r2, [r7, #0]
 800a3fa:	b28b      	uxth	r3, r1
 800a3fc:	4343      	muls	r3, r0
 800a3fe:	0c09      	lsrs	r1, r1, #16
 800a400:	4341      	muls	r1, r0
 800a402:	b292      	uxth	r2, r2
 800a404:	189b      	adds	r3, r3, r2
 800a406:	191b      	adds	r3, r3, r4
 800a408:	000c      	movs	r4, r1
 800a40a:	683a      	ldr	r2, [r7, #0]
 800a40c:	0c11      	lsrs	r1, r2, #16
 800a40e:	1861      	adds	r1, r4, r1
 800a410:	0c1c      	lsrs	r4, r3, #16
 800a412:	1909      	adds	r1, r1, r4
 800a414:	0c0c      	lsrs	r4, r1, #16
 800a416:	b29b      	uxth	r3, r3
 800a418:	0409      	lsls	r1, r1, #16
 800a41a:	430b      	orrs	r3, r1
 800a41c:	c708      	stmia	r7!, {r3}
 800a41e:	9b04      	ldr	r3, [sp, #16]
 800a420:	42b3      	cmp	r3, r6
 800a422:	d8e8      	bhi.n	800a3f6 <__multiply+0xc6>
 800a424:	4663      	mov	r3, ip
 800a426:	9a05      	ldr	r2, [sp, #20]
 800a428:	509c      	str	r4, [r3, r2]
 800a42a:	9b00      	ldr	r3, [sp, #0]
 800a42c:	681b      	ldr	r3, [r3, #0]
 800a42e:	0c1e      	lsrs	r6, r3, #16
 800a430:	d020      	beq.n	800a474 <__multiply+0x144>
 800a432:	4663      	mov	r3, ip
 800a434:	002c      	movs	r4, r5
 800a436:	4660      	mov	r0, ip
 800a438:	2700      	movs	r7, #0
 800a43a:	681b      	ldr	r3, [r3, #0]
 800a43c:	3414      	adds	r4, #20
 800a43e:	6822      	ldr	r2, [r4, #0]
 800a440:	b29b      	uxth	r3, r3
 800a442:	b291      	uxth	r1, r2
 800a444:	4371      	muls	r1, r6
 800a446:	6802      	ldr	r2, [r0, #0]
 800a448:	0c12      	lsrs	r2, r2, #16
 800a44a:	1889      	adds	r1, r1, r2
 800a44c:	19cf      	adds	r7, r1, r7
 800a44e:	0439      	lsls	r1, r7, #16
 800a450:	430b      	orrs	r3, r1
 800a452:	6003      	str	r3, [r0, #0]
 800a454:	cc02      	ldmia	r4!, {r1}
 800a456:	6843      	ldr	r3, [r0, #4]
 800a458:	0c09      	lsrs	r1, r1, #16
 800a45a:	4371      	muls	r1, r6
 800a45c:	b29b      	uxth	r3, r3
 800a45e:	0c3f      	lsrs	r7, r7, #16
 800a460:	18cb      	adds	r3, r1, r3
 800a462:	9a04      	ldr	r2, [sp, #16]
 800a464:	19db      	adds	r3, r3, r7
 800a466:	0c1f      	lsrs	r7, r3, #16
 800a468:	3004      	adds	r0, #4
 800a46a:	42a2      	cmp	r2, r4
 800a46c:	d8e7      	bhi.n	800a43e <__multiply+0x10e>
 800a46e:	4662      	mov	r2, ip
 800a470:	9905      	ldr	r1, [sp, #20]
 800a472:	5053      	str	r3, [r2, r1]
 800a474:	9b00      	ldr	r3, [sp, #0]
 800a476:	3304      	adds	r3, #4
 800a478:	9300      	str	r3, [sp, #0]
 800a47a:	2304      	movs	r3, #4
 800a47c:	449c      	add	ip, r3
 800a47e:	e79c      	b.n	800a3ba <__multiply+0x8a>
 800a480:	9b02      	ldr	r3, [sp, #8]
 800a482:	3b01      	subs	r3, #1
 800a484:	9302      	str	r3, [sp, #8]
 800a486:	e79c      	b.n	800a3c2 <__multiply+0x92>
 800a488:	0800f16b 	.word	0x0800f16b
 800a48c:	0800f10b 	.word	0x0800f10b

0800a490 <__pow5mult>:
 800a490:	b5f7      	push	{r0, r1, r2, r4, r5, r6, r7, lr}
 800a492:	2303      	movs	r3, #3
 800a494:	0015      	movs	r5, r2
 800a496:	0007      	movs	r7, r0
 800a498:	000e      	movs	r6, r1
 800a49a:	401a      	ands	r2, r3
 800a49c:	421d      	tst	r5, r3
 800a49e:	d008      	beq.n	800a4b2 <__pow5mult+0x22>
 800a4a0:	4925      	ldr	r1, [pc, #148]	; (800a538 <__pow5mult+0xa8>)
 800a4a2:	3a01      	subs	r2, #1
 800a4a4:	0092      	lsls	r2, r2, #2
 800a4a6:	5852      	ldr	r2, [r2, r1]
 800a4a8:	2300      	movs	r3, #0
 800a4aa:	0031      	movs	r1, r6
 800a4ac:	f7ff fe9e 	bl	800a1ec <__multadd>
 800a4b0:	0006      	movs	r6, r0
 800a4b2:	10ad      	asrs	r5, r5, #2
 800a4b4:	d03d      	beq.n	800a532 <__pow5mult+0xa2>
 800a4b6:	6a7c      	ldr	r4, [r7, #36]	; 0x24
 800a4b8:	2c00      	cmp	r4, #0
 800a4ba:	d10f      	bne.n	800a4dc <__pow5mult+0x4c>
 800a4bc:	2010      	movs	r0, #16
 800a4be:	f7ff fbd5 	bl	8009c6c <malloc>
 800a4c2:	1e02      	subs	r2, r0, #0
 800a4c4:	6278      	str	r0, [r7, #36]	; 0x24
 800a4c6:	d105      	bne.n	800a4d4 <__pow5mult+0x44>
 800a4c8:	21d7      	movs	r1, #215	; 0xd7
 800a4ca:	4b1c      	ldr	r3, [pc, #112]	; (800a53c <__pow5mult+0xac>)
 800a4cc:	481c      	ldr	r0, [pc, #112]	; (800a540 <__pow5mult+0xb0>)
 800a4ce:	0049      	lsls	r1, r1, #1
 800a4d0:	f7ff fc98 	bl	8009e04 <__assert_func>
 800a4d4:	6044      	str	r4, [r0, #4]
 800a4d6:	6084      	str	r4, [r0, #8]
 800a4d8:	6004      	str	r4, [r0, #0]
 800a4da:	60c4      	str	r4, [r0, #12]
 800a4dc:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 800a4de:	689c      	ldr	r4, [r3, #8]
 800a4e0:	9301      	str	r3, [sp, #4]
 800a4e2:	2c00      	cmp	r4, #0
 800a4e4:	d108      	bne.n	800a4f8 <__pow5mult+0x68>
 800a4e6:	0038      	movs	r0, r7
 800a4e8:	4916      	ldr	r1, [pc, #88]	; (800a544 <__pow5mult+0xb4>)
 800a4ea:	f7ff ff0b 	bl	800a304 <__i2b>
 800a4ee:	9b01      	ldr	r3, [sp, #4]
 800a4f0:	0004      	movs	r4, r0
 800a4f2:	6098      	str	r0, [r3, #8]
 800a4f4:	2300      	movs	r3, #0
 800a4f6:	6003      	str	r3, [r0, #0]
 800a4f8:	2301      	movs	r3, #1
 800a4fa:	421d      	tst	r5, r3
 800a4fc:	d00a      	beq.n	800a514 <__pow5mult+0x84>
 800a4fe:	0031      	movs	r1, r6
 800a500:	0022      	movs	r2, r4
 800a502:	0038      	movs	r0, r7
 800a504:	f7ff ff14 	bl	800a330 <__multiply>
 800a508:	0031      	movs	r1, r6
 800a50a:	9001      	str	r0, [sp, #4]
 800a50c:	0038      	movs	r0, r7
 800a50e:	f7ff fe49 	bl	800a1a4 <_Bfree>
 800a512:	9e01      	ldr	r6, [sp, #4]
 800a514:	106d      	asrs	r5, r5, #1
 800a516:	d00c      	beq.n	800a532 <__pow5mult+0xa2>
 800a518:	6820      	ldr	r0, [r4, #0]
 800a51a:	2800      	cmp	r0, #0
 800a51c:	d107      	bne.n	800a52e <__pow5mult+0x9e>
 800a51e:	0022      	movs	r2, r4
 800a520:	0021      	movs	r1, r4
 800a522:	0038      	movs	r0, r7
 800a524:	f7ff ff04 	bl	800a330 <__multiply>
 800a528:	2300      	movs	r3, #0
 800a52a:	6020      	str	r0, [r4, #0]
 800a52c:	6003      	str	r3, [r0, #0]
 800a52e:	0004      	movs	r4, r0
 800a530:	e7e2      	b.n	800a4f8 <__pow5mult+0x68>
 800a532:	0030      	movs	r0, r6
 800a534:	bdfe      	pop	{r1, r2, r3, r4, r5, r6, r7, pc}
 800a536:	46c0      	nop			; (mov r8, r8)
 800a538:	0800f270 	.word	0x0800f270
 800a53c:	0800f0f4 	.word	0x0800f0f4
 800a540:	0800f10b 	.word	0x0800f10b
 800a544:	00000271 	.word	0x00000271

0800a548 <__lshift>:
 800a548:	b5f0      	push	{r4, r5, r6, r7, lr}
 800a54a:	000c      	movs	r4, r1
 800a54c:	0017      	movs	r7, r2
 800a54e:	6923      	ldr	r3, [r4, #16]
 800a550:	1155      	asrs	r5, r2, #5
 800a552:	b087      	sub	sp, #28
 800a554:	18eb      	adds	r3, r5, r3
 800a556:	9302      	str	r3, [sp, #8]
 800a558:	3301      	adds	r3, #1
 800a55a:	9301      	str	r3, [sp, #4]
 800a55c:	6849      	ldr	r1, [r1, #4]
 800a55e:	68a3      	ldr	r3, [r4, #8]
 800a560:	9004      	str	r0, [sp, #16]
 800a562:	9a01      	ldr	r2, [sp, #4]
 800a564:	4293      	cmp	r3, r2
 800a566:	db11      	blt.n	800a58c <__lshift+0x44>
 800a568:	9804      	ldr	r0, [sp, #16]
 800a56a:	f7ff fdd7 	bl	800a11c <_Balloc>
 800a56e:	0002      	movs	r2, r0
 800a570:	2300      	movs	r3, #0
 800a572:	3214      	adds	r2, #20
 800a574:	0006      	movs	r6, r0
 800a576:	0011      	movs	r1, r2
 800a578:	9203      	str	r2, [sp, #12]
 800a57a:	4298      	cmp	r0, r3
 800a57c:	d10d      	bne.n	800a59a <__lshift+0x52>
 800a57e:	21da      	movs	r1, #218	; 0xda
 800a580:	0002      	movs	r2, r0
 800a582:	4b27      	ldr	r3, [pc, #156]	; (800a620 <__lshift+0xd8>)
 800a584:	4827      	ldr	r0, [pc, #156]	; (800a624 <__lshift+0xdc>)
 800a586:	31ff      	adds	r1, #255	; 0xff
 800a588:	f7ff fc3c 	bl	8009e04 <__assert_func>
 800a58c:	3101      	adds	r1, #1
 800a58e:	005b      	lsls	r3, r3, #1
 800a590:	e7e7      	b.n	800a562 <__lshift+0x1a>
 800a592:	2200      	movs	r2, #0
 800a594:	0098      	lsls	r0, r3, #2
 800a596:	500a      	str	r2, [r1, r0]
 800a598:	3301      	adds	r3, #1
 800a59a:	42ab      	cmp	r3, r5
 800a59c:	dbf9      	blt.n	800a592 <__lshift+0x4a>
 800a59e:	43eb      	mvns	r3, r5
 800a5a0:	17db      	asrs	r3, r3, #31
 800a5a2:	401d      	ands	r5, r3
 800a5a4:	9b03      	ldr	r3, [sp, #12]
 800a5a6:	00ad      	lsls	r5, r5, #2
 800a5a8:	211f      	movs	r1, #31
 800a5aa:	0038      	movs	r0, r7
 800a5ac:	195d      	adds	r5, r3, r5
 800a5ae:	0023      	movs	r3, r4
 800a5b0:	6922      	ldr	r2, [r4, #16]
 800a5b2:	3314      	adds	r3, #20
 800a5b4:	0092      	lsls	r2, r2, #2
 800a5b6:	4008      	ands	r0, r1
 800a5b8:	4684      	mov	ip, r0
 800a5ba:	189a      	adds	r2, r3, r2
 800a5bc:	420f      	tst	r7, r1
 800a5be:	d02a      	beq.n	800a616 <__lshift+0xce>
 800a5c0:	3101      	adds	r1, #1
 800a5c2:	1a09      	subs	r1, r1, r0
 800a5c4:	9105      	str	r1, [sp, #20]
 800a5c6:	2100      	movs	r1, #0
 800a5c8:	9503      	str	r5, [sp, #12]
 800a5ca:	4667      	mov	r7, ip
 800a5cc:	6818      	ldr	r0, [r3, #0]
 800a5ce:	40b8      	lsls	r0, r7
 800a5d0:	4301      	orrs	r1, r0
 800a5d2:	9803      	ldr	r0, [sp, #12]
 800a5d4:	c002      	stmia	r0!, {r1}
 800a5d6:	cb02      	ldmia	r3!, {r1}
 800a5d8:	9003      	str	r0, [sp, #12]
 800a5da:	9805      	ldr	r0, [sp, #20]
 800a5dc:	40c1      	lsrs	r1, r0
 800a5de:	429a      	cmp	r2, r3
 800a5e0:	d8f3      	bhi.n	800a5ca <__lshift+0x82>
 800a5e2:	0020      	movs	r0, r4
 800a5e4:	3015      	adds	r0, #21
 800a5e6:	2304      	movs	r3, #4
 800a5e8:	4282      	cmp	r2, r0
 800a5ea:	d304      	bcc.n	800a5f6 <__lshift+0xae>
 800a5ec:	1b13      	subs	r3, r2, r4
 800a5ee:	3b15      	subs	r3, #21
 800a5f0:	089b      	lsrs	r3, r3, #2
 800a5f2:	3301      	adds	r3, #1
 800a5f4:	009b      	lsls	r3, r3, #2
 800a5f6:	50e9      	str	r1, [r5, r3]
 800a5f8:	2900      	cmp	r1, #0
 800a5fa:	d002      	beq.n	800a602 <__lshift+0xba>
 800a5fc:	9b02      	ldr	r3, [sp, #8]
 800a5fe:	3302      	adds	r3, #2
 800a600:	9301      	str	r3, [sp, #4]
 800a602:	9b01      	ldr	r3, [sp, #4]
 800a604:	9804      	ldr	r0, [sp, #16]
 800a606:	3b01      	subs	r3, #1
 800a608:	0021      	movs	r1, r4
 800a60a:	6133      	str	r3, [r6, #16]
 800a60c:	f7ff fdca 	bl	800a1a4 <_Bfree>
 800a610:	0030      	movs	r0, r6
 800a612:	b007      	add	sp, #28
 800a614:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800a616:	cb02      	ldmia	r3!, {r1}
 800a618:	c502      	stmia	r5!, {r1}
 800a61a:	429a      	cmp	r2, r3
 800a61c:	d8fb      	bhi.n	800a616 <__lshift+0xce>
 800a61e:	e7f0      	b.n	800a602 <__lshift+0xba>
 800a620:	0800f16b 	.word	0x0800f16b
 800a624:	0800f10b 	.word	0x0800f10b

0800a628 <__mcmp>:
 800a628:	6902      	ldr	r2, [r0, #16]
 800a62a:	690b      	ldr	r3, [r1, #16]
 800a62c:	b530      	push	{r4, r5, lr}
 800a62e:	0004      	movs	r4, r0
 800a630:	1ad0      	subs	r0, r2, r3
 800a632:	429a      	cmp	r2, r3
 800a634:	d10d      	bne.n	800a652 <__mcmp+0x2a>
 800a636:	009b      	lsls	r3, r3, #2
 800a638:	3414      	adds	r4, #20
 800a63a:	3114      	adds	r1, #20
 800a63c:	18e2      	adds	r2, r4, r3
 800a63e:	18c9      	adds	r1, r1, r3
 800a640:	3a04      	subs	r2, #4
 800a642:	3904      	subs	r1, #4
 800a644:	6815      	ldr	r5, [r2, #0]
 800a646:	680b      	ldr	r3, [r1, #0]
 800a648:	429d      	cmp	r5, r3
 800a64a:	d003      	beq.n	800a654 <__mcmp+0x2c>
 800a64c:	2001      	movs	r0, #1
 800a64e:	429d      	cmp	r5, r3
 800a650:	d303      	bcc.n	800a65a <__mcmp+0x32>
 800a652:	bd30      	pop	{r4, r5, pc}
 800a654:	4294      	cmp	r4, r2
 800a656:	d3f3      	bcc.n	800a640 <__mcmp+0x18>
 800a658:	e7fb      	b.n	800a652 <__mcmp+0x2a>
 800a65a:	4240      	negs	r0, r0
 800a65c:	e7f9      	b.n	800a652 <__mcmp+0x2a>
	...

0800a660 <__mdiff>:
 800a660:	b5f0      	push	{r4, r5, r6, r7, lr}
 800a662:	000e      	movs	r6, r1
 800a664:	0007      	movs	r7, r0
 800a666:	0011      	movs	r1, r2
 800a668:	0030      	movs	r0, r6
 800a66a:	b087      	sub	sp, #28
 800a66c:	0014      	movs	r4, r2
 800a66e:	f7ff ffdb 	bl	800a628 <__mcmp>
 800a672:	1e05      	subs	r5, r0, #0
 800a674:	d110      	bne.n	800a698 <__mdiff+0x38>
 800a676:	0001      	movs	r1, r0
 800a678:	0038      	movs	r0, r7
 800a67a:	f7ff fd4f 	bl	800a11c <_Balloc>
 800a67e:	1e02      	subs	r2, r0, #0
 800a680:	d104      	bne.n	800a68c <__mdiff+0x2c>
 800a682:	4b40      	ldr	r3, [pc, #256]	; (800a784 <__mdiff+0x124>)
 800a684:	4940      	ldr	r1, [pc, #256]	; (800a788 <__mdiff+0x128>)
 800a686:	4841      	ldr	r0, [pc, #260]	; (800a78c <__mdiff+0x12c>)
 800a688:	f7ff fbbc 	bl	8009e04 <__assert_func>
 800a68c:	2301      	movs	r3, #1
 800a68e:	6145      	str	r5, [r0, #20]
 800a690:	6103      	str	r3, [r0, #16]
 800a692:	0010      	movs	r0, r2
 800a694:	b007      	add	sp, #28
 800a696:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800a698:	2301      	movs	r3, #1
 800a69a:	9301      	str	r3, [sp, #4]
 800a69c:	2800      	cmp	r0, #0
 800a69e:	db04      	blt.n	800a6aa <__mdiff+0x4a>
 800a6a0:	0023      	movs	r3, r4
 800a6a2:	0034      	movs	r4, r6
 800a6a4:	001e      	movs	r6, r3
 800a6a6:	2300      	movs	r3, #0
 800a6a8:	9301      	str	r3, [sp, #4]
 800a6aa:	0038      	movs	r0, r7
 800a6ac:	6861      	ldr	r1, [r4, #4]
 800a6ae:	f7ff fd35 	bl	800a11c <_Balloc>
 800a6b2:	1e02      	subs	r2, r0, #0
 800a6b4:	d103      	bne.n	800a6be <__mdiff+0x5e>
 800a6b6:	2190      	movs	r1, #144	; 0x90
 800a6b8:	4b32      	ldr	r3, [pc, #200]	; (800a784 <__mdiff+0x124>)
 800a6ba:	0089      	lsls	r1, r1, #2
 800a6bc:	e7e3      	b.n	800a686 <__mdiff+0x26>
 800a6be:	9b01      	ldr	r3, [sp, #4]
 800a6c0:	2700      	movs	r7, #0
 800a6c2:	60c3      	str	r3, [r0, #12]
 800a6c4:	6920      	ldr	r0, [r4, #16]
 800a6c6:	3414      	adds	r4, #20
 800a6c8:	9401      	str	r4, [sp, #4]
 800a6ca:	9b01      	ldr	r3, [sp, #4]
 800a6cc:	0084      	lsls	r4, r0, #2
 800a6ce:	191b      	adds	r3, r3, r4
 800a6d0:	0034      	movs	r4, r6
 800a6d2:	9302      	str	r3, [sp, #8]
 800a6d4:	6933      	ldr	r3, [r6, #16]
 800a6d6:	3414      	adds	r4, #20
 800a6d8:	0099      	lsls	r1, r3, #2
 800a6da:	1863      	adds	r3, r4, r1
 800a6dc:	9303      	str	r3, [sp, #12]
 800a6de:	0013      	movs	r3, r2
 800a6e0:	3314      	adds	r3, #20
 800a6e2:	469c      	mov	ip, r3
 800a6e4:	9305      	str	r3, [sp, #20]
 800a6e6:	9b01      	ldr	r3, [sp, #4]
 800a6e8:	9304      	str	r3, [sp, #16]
 800a6ea:	9b04      	ldr	r3, [sp, #16]
 800a6ec:	cc02      	ldmia	r4!, {r1}
 800a6ee:	cb20      	ldmia	r3!, {r5}
 800a6f0:	9304      	str	r3, [sp, #16]
 800a6f2:	b2ab      	uxth	r3, r5
 800a6f4:	19df      	adds	r7, r3, r7
 800a6f6:	b28b      	uxth	r3, r1
 800a6f8:	1afb      	subs	r3, r7, r3
 800a6fa:	0c2d      	lsrs	r5, r5, #16
 800a6fc:	0c09      	lsrs	r1, r1, #16
 800a6fe:	1a69      	subs	r1, r5, r1
 800a700:	141d      	asrs	r5, r3, #16
 800a702:	1949      	adds	r1, r1, r5
 800a704:	140f      	asrs	r7, r1, #16
 800a706:	b29b      	uxth	r3, r3
 800a708:	0409      	lsls	r1, r1, #16
 800a70a:	430b      	orrs	r3, r1
 800a70c:	4661      	mov	r1, ip
 800a70e:	c108      	stmia	r1!, {r3}
 800a710:	9b03      	ldr	r3, [sp, #12]
 800a712:	468c      	mov	ip, r1
 800a714:	42a3      	cmp	r3, r4
 800a716:	d8e8      	bhi.n	800a6ea <__mdiff+0x8a>
 800a718:	0031      	movs	r1, r6
 800a71a:	9c03      	ldr	r4, [sp, #12]
 800a71c:	3115      	adds	r1, #21
 800a71e:	2304      	movs	r3, #4
 800a720:	428c      	cmp	r4, r1
 800a722:	d304      	bcc.n	800a72e <__mdiff+0xce>
 800a724:	1ba3      	subs	r3, r4, r6
 800a726:	3b15      	subs	r3, #21
 800a728:	089b      	lsrs	r3, r3, #2
 800a72a:	3301      	adds	r3, #1
 800a72c:	009b      	lsls	r3, r3, #2
 800a72e:	9901      	ldr	r1, [sp, #4]
 800a730:	18cc      	adds	r4, r1, r3
 800a732:	9905      	ldr	r1, [sp, #20]
 800a734:	0026      	movs	r6, r4
 800a736:	18cb      	adds	r3, r1, r3
 800a738:	469c      	mov	ip, r3
 800a73a:	9902      	ldr	r1, [sp, #8]
 800a73c:	428e      	cmp	r6, r1
 800a73e:	d310      	bcc.n	800a762 <__mdiff+0x102>
 800a740:	9e02      	ldr	r6, [sp, #8]
 800a742:	1ee5      	subs	r5, r4, #3
 800a744:	2100      	movs	r1, #0
 800a746:	42ae      	cmp	r6, r5
 800a748:	d304      	bcc.n	800a754 <__mdiff+0xf4>
 800a74a:	0031      	movs	r1, r6
 800a74c:	3103      	adds	r1, #3
 800a74e:	1b09      	subs	r1, r1, r4
 800a750:	0889      	lsrs	r1, r1, #2
 800a752:	0089      	lsls	r1, r1, #2
 800a754:	185b      	adds	r3, r3, r1
 800a756:	3b04      	subs	r3, #4
 800a758:	6819      	ldr	r1, [r3, #0]
 800a75a:	2900      	cmp	r1, #0
 800a75c:	d00f      	beq.n	800a77e <__mdiff+0x11e>
 800a75e:	6110      	str	r0, [r2, #16]
 800a760:	e797      	b.n	800a692 <__mdiff+0x32>
 800a762:	ce02      	ldmia	r6!, {r1}
 800a764:	b28d      	uxth	r5, r1
 800a766:	19ed      	adds	r5, r5, r7
 800a768:	0c0f      	lsrs	r7, r1, #16
 800a76a:	1429      	asrs	r1, r5, #16
 800a76c:	1879      	adds	r1, r7, r1
 800a76e:	140f      	asrs	r7, r1, #16
 800a770:	b2ad      	uxth	r5, r5
 800a772:	0409      	lsls	r1, r1, #16
 800a774:	430d      	orrs	r5, r1
 800a776:	4661      	mov	r1, ip
 800a778:	c120      	stmia	r1!, {r5}
 800a77a:	468c      	mov	ip, r1
 800a77c:	e7dd      	b.n	800a73a <__mdiff+0xda>
 800a77e:	3801      	subs	r0, #1
 800a780:	e7e9      	b.n	800a756 <__mdiff+0xf6>
 800a782:	46c0      	nop			; (mov r8, r8)
 800a784:	0800f16b 	.word	0x0800f16b
 800a788:	00000232 	.word	0x00000232
 800a78c:	0800f10b 	.word	0x0800f10b

0800a790 <__d2b>:
 800a790:	b5f7      	push	{r0, r1, r2, r4, r5, r6, r7, lr}
 800a792:	2101      	movs	r1, #1
 800a794:	0014      	movs	r4, r2
 800a796:	001e      	movs	r6, r3
 800a798:	9f08      	ldr	r7, [sp, #32]
 800a79a:	f7ff fcbf 	bl	800a11c <_Balloc>
 800a79e:	1e05      	subs	r5, r0, #0
 800a7a0:	d105      	bne.n	800a7ae <__d2b+0x1e>
 800a7a2:	0002      	movs	r2, r0
 800a7a4:	4b26      	ldr	r3, [pc, #152]	; (800a840 <__d2b+0xb0>)
 800a7a6:	4927      	ldr	r1, [pc, #156]	; (800a844 <__d2b+0xb4>)
 800a7a8:	4827      	ldr	r0, [pc, #156]	; (800a848 <__d2b+0xb8>)
 800a7aa:	f7ff fb2b 	bl	8009e04 <__assert_func>
 800a7ae:	0333      	lsls	r3, r6, #12
 800a7b0:	0076      	lsls	r6, r6, #1
 800a7b2:	0b1b      	lsrs	r3, r3, #12
 800a7b4:	0d76      	lsrs	r6, r6, #21
 800a7b6:	d124      	bne.n	800a802 <__d2b+0x72>
 800a7b8:	9301      	str	r3, [sp, #4]
 800a7ba:	2c00      	cmp	r4, #0
 800a7bc:	d027      	beq.n	800a80e <__d2b+0x7e>
 800a7be:	4668      	mov	r0, sp
 800a7c0:	9400      	str	r4, [sp, #0]
 800a7c2:	f7ff fd71 	bl	800a2a8 <__lo0bits>
 800a7c6:	9c00      	ldr	r4, [sp, #0]
 800a7c8:	2800      	cmp	r0, #0
 800a7ca:	d01e      	beq.n	800a80a <__d2b+0x7a>
 800a7cc:	9b01      	ldr	r3, [sp, #4]
 800a7ce:	2120      	movs	r1, #32
 800a7d0:	001a      	movs	r2, r3
 800a7d2:	1a09      	subs	r1, r1, r0
 800a7d4:	408a      	lsls	r2, r1
 800a7d6:	40c3      	lsrs	r3, r0
 800a7d8:	4322      	orrs	r2, r4
 800a7da:	616a      	str	r2, [r5, #20]
 800a7dc:	9301      	str	r3, [sp, #4]
 800a7de:	9c01      	ldr	r4, [sp, #4]
 800a7e0:	61ac      	str	r4, [r5, #24]
 800a7e2:	1e63      	subs	r3, r4, #1
 800a7e4:	419c      	sbcs	r4, r3
 800a7e6:	3401      	adds	r4, #1
 800a7e8:	612c      	str	r4, [r5, #16]
 800a7ea:	2e00      	cmp	r6, #0
 800a7ec:	d018      	beq.n	800a820 <__d2b+0x90>
 800a7ee:	4b17      	ldr	r3, [pc, #92]	; (800a84c <__d2b+0xbc>)
 800a7f0:	18f6      	adds	r6, r6, r3
 800a7f2:	2335      	movs	r3, #53	; 0x35
 800a7f4:	1836      	adds	r6, r6, r0
 800a7f6:	1a18      	subs	r0, r3, r0
 800a7f8:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800a7fa:	603e      	str	r6, [r7, #0]
 800a7fc:	6018      	str	r0, [r3, #0]
 800a7fe:	0028      	movs	r0, r5
 800a800:	bdfe      	pop	{r1, r2, r3, r4, r5, r6, r7, pc}
 800a802:	2280      	movs	r2, #128	; 0x80
 800a804:	0352      	lsls	r2, r2, #13
 800a806:	4313      	orrs	r3, r2
 800a808:	e7d6      	b.n	800a7b8 <__d2b+0x28>
 800a80a:	616c      	str	r4, [r5, #20]
 800a80c:	e7e7      	b.n	800a7de <__d2b+0x4e>
 800a80e:	a801      	add	r0, sp, #4
 800a810:	f7ff fd4a 	bl	800a2a8 <__lo0bits>
 800a814:	2401      	movs	r4, #1
 800a816:	9b01      	ldr	r3, [sp, #4]
 800a818:	612c      	str	r4, [r5, #16]
 800a81a:	616b      	str	r3, [r5, #20]
 800a81c:	3020      	adds	r0, #32
 800a81e:	e7e4      	b.n	800a7ea <__d2b+0x5a>
 800a820:	4b0b      	ldr	r3, [pc, #44]	; (800a850 <__d2b+0xc0>)
 800a822:	18c0      	adds	r0, r0, r3
 800a824:	4b0b      	ldr	r3, [pc, #44]	; (800a854 <__d2b+0xc4>)
 800a826:	6038      	str	r0, [r7, #0]
 800a828:	18e3      	adds	r3, r4, r3
 800a82a:	009b      	lsls	r3, r3, #2
 800a82c:	18eb      	adds	r3, r5, r3
 800a82e:	6958      	ldr	r0, [r3, #20]
 800a830:	f7ff fd20 	bl	800a274 <__hi0bits>
 800a834:	0164      	lsls	r4, r4, #5
 800a836:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800a838:	1a24      	subs	r4, r4, r0
 800a83a:	601c      	str	r4, [r3, #0]
 800a83c:	e7df      	b.n	800a7fe <__d2b+0x6e>
 800a83e:	46c0      	nop			; (mov r8, r8)
 800a840:	0800f16b 	.word	0x0800f16b
 800a844:	0000030a 	.word	0x0000030a
 800a848:	0800f10b 	.word	0x0800f10b
 800a84c:	fffffbcd 	.word	0xfffffbcd
 800a850:	fffffbce 	.word	0xfffffbce
 800a854:	3fffffff 	.word	0x3fffffff

0800a858 <_mprec_log10>:
 800a858:	b510      	push	{r4, lr}
 800a85a:	0004      	movs	r4, r0
 800a85c:	2817      	cmp	r0, #23
 800a85e:	dc05      	bgt.n	800a86c <_mprec_log10+0x14>
 800a860:	4b07      	ldr	r3, [pc, #28]	; (800a880 <_mprec_log10+0x28>)
 800a862:	00c4      	lsls	r4, r0, #3
 800a864:	191c      	adds	r4, r3, r4
 800a866:	6820      	ldr	r0, [r4, #0]
 800a868:	6861      	ldr	r1, [r4, #4]
 800a86a:	bd10      	pop	{r4, pc}
 800a86c:	2000      	movs	r0, #0
 800a86e:	4905      	ldr	r1, [pc, #20]	; (800a884 <_mprec_log10+0x2c>)
 800a870:	2200      	movs	r2, #0
 800a872:	4b05      	ldr	r3, [pc, #20]	; (800a888 <_mprec_log10+0x30>)
 800a874:	3c01      	subs	r4, #1
 800a876:	f7f7 fb2f 	bl	8001ed8 <__aeabi_dmul>
 800a87a:	2c00      	cmp	r4, #0
 800a87c:	d1f8      	bne.n	800a870 <_mprec_log10+0x18>
 800a87e:	e7f4      	b.n	800a86a <_mprec_log10+0x12>
 800a880:	0800f1a8 	.word	0x0800f1a8
 800a884:	3ff00000 	.word	0x3ff00000
 800a888:	40240000 	.word	0x40240000

0800a88c <_calloc_r>:
 800a88c:	434a      	muls	r2, r1
 800a88e:	b570      	push	{r4, r5, r6, lr}
 800a890:	0011      	movs	r1, r2
 800a892:	0015      	movs	r5, r2
 800a894:	f7ff fa46 	bl	8009d24 <_malloc_r>
 800a898:	1e04      	subs	r4, r0, #0
 800a89a:	d003      	beq.n	800a8a4 <_calloc_r+0x18>
 800a89c:	002a      	movs	r2, r5
 800a89e:	2100      	movs	r1, #0
 800a8a0:	f7ff f9ee 	bl	8009c80 <memset>
 800a8a4:	0020      	movs	r0, r4
 800a8a6:	bd70      	pop	{r4, r5, r6, pc}

0800a8a8 <__sfputc_r>:
 800a8a8:	6893      	ldr	r3, [r2, #8]
 800a8aa:	b510      	push	{r4, lr}
 800a8ac:	3b01      	subs	r3, #1
 800a8ae:	6093      	str	r3, [r2, #8]
 800a8b0:	2b00      	cmp	r3, #0
 800a8b2:	da04      	bge.n	800a8be <__sfputc_r+0x16>
 800a8b4:	6994      	ldr	r4, [r2, #24]
 800a8b6:	42a3      	cmp	r3, r4
 800a8b8:	db07      	blt.n	800a8ca <__sfputc_r+0x22>
 800a8ba:	290a      	cmp	r1, #10
 800a8bc:	d005      	beq.n	800a8ca <__sfputc_r+0x22>
 800a8be:	6813      	ldr	r3, [r2, #0]
 800a8c0:	1c58      	adds	r0, r3, #1
 800a8c2:	6010      	str	r0, [r2, #0]
 800a8c4:	7019      	strb	r1, [r3, #0]
 800a8c6:	0008      	movs	r0, r1
 800a8c8:	bd10      	pop	{r4, pc}
 800a8ca:	f000 fad9 	bl	800ae80 <__swbuf_r>
 800a8ce:	0001      	movs	r1, r0
 800a8d0:	e7f9      	b.n	800a8c6 <__sfputc_r+0x1e>

0800a8d2 <__sfputs_r>:
 800a8d2:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 800a8d4:	0006      	movs	r6, r0
 800a8d6:	000f      	movs	r7, r1
 800a8d8:	0014      	movs	r4, r2
 800a8da:	18d5      	adds	r5, r2, r3
 800a8dc:	42ac      	cmp	r4, r5
 800a8de:	d101      	bne.n	800a8e4 <__sfputs_r+0x12>
 800a8e0:	2000      	movs	r0, #0
 800a8e2:	e007      	b.n	800a8f4 <__sfputs_r+0x22>
 800a8e4:	7821      	ldrb	r1, [r4, #0]
 800a8e6:	003a      	movs	r2, r7
 800a8e8:	0030      	movs	r0, r6
 800a8ea:	f7ff ffdd 	bl	800a8a8 <__sfputc_r>
 800a8ee:	3401      	adds	r4, #1
 800a8f0:	1c43      	adds	r3, r0, #1
 800a8f2:	d1f3      	bne.n	800a8dc <__sfputs_r+0xa>
 800a8f4:	bdf8      	pop	{r3, r4, r5, r6, r7, pc}
	...

0800a8f8 <_vfiprintf_r>:
 800a8f8:	b5f0      	push	{r4, r5, r6, r7, lr}
 800a8fa:	b0a1      	sub	sp, #132	; 0x84
 800a8fc:	0006      	movs	r6, r0
 800a8fe:	000c      	movs	r4, r1
 800a900:	001f      	movs	r7, r3
 800a902:	9203      	str	r2, [sp, #12]
 800a904:	2800      	cmp	r0, #0
 800a906:	d004      	beq.n	800a912 <_vfiprintf_r+0x1a>
 800a908:	6983      	ldr	r3, [r0, #24]
 800a90a:	2b00      	cmp	r3, #0
 800a90c:	d101      	bne.n	800a912 <_vfiprintf_r+0x1a>
 800a90e:	f001 fb63 	bl	800bfd8 <__sinit>
 800a912:	4b8e      	ldr	r3, [pc, #568]	; (800ab4c <_vfiprintf_r+0x254>)
 800a914:	429c      	cmp	r4, r3
 800a916:	d11c      	bne.n	800a952 <_vfiprintf_r+0x5a>
 800a918:	6874      	ldr	r4, [r6, #4]
 800a91a:	6e63      	ldr	r3, [r4, #100]	; 0x64
 800a91c:	07db      	lsls	r3, r3, #31
 800a91e:	d405      	bmi.n	800a92c <_vfiprintf_r+0x34>
 800a920:	89a3      	ldrh	r3, [r4, #12]
 800a922:	059b      	lsls	r3, r3, #22
 800a924:	d402      	bmi.n	800a92c <_vfiprintf_r+0x34>
 800a926:	6da0      	ldr	r0, [r4, #88]	; 0x58
 800a928:	f001 fbf7 	bl	800c11a <__retarget_lock_acquire_recursive>
 800a92c:	89a3      	ldrh	r3, [r4, #12]
 800a92e:	071b      	lsls	r3, r3, #28
 800a930:	d502      	bpl.n	800a938 <_vfiprintf_r+0x40>
 800a932:	6923      	ldr	r3, [r4, #16]
 800a934:	2b00      	cmp	r3, #0
 800a936:	d11d      	bne.n	800a974 <_vfiprintf_r+0x7c>
 800a938:	0021      	movs	r1, r4
 800a93a:	0030      	movs	r0, r6
 800a93c:	f000 faf6 	bl	800af2c <__swsetup_r>
 800a940:	2800      	cmp	r0, #0
 800a942:	d017      	beq.n	800a974 <_vfiprintf_r+0x7c>
 800a944:	6e63      	ldr	r3, [r4, #100]	; 0x64
 800a946:	07db      	lsls	r3, r3, #31
 800a948:	d50d      	bpl.n	800a966 <_vfiprintf_r+0x6e>
 800a94a:	2001      	movs	r0, #1
 800a94c:	4240      	negs	r0, r0
 800a94e:	b021      	add	sp, #132	; 0x84
 800a950:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800a952:	4b7f      	ldr	r3, [pc, #508]	; (800ab50 <_vfiprintf_r+0x258>)
 800a954:	429c      	cmp	r4, r3
 800a956:	d101      	bne.n	800a95c <_vfiprintf_r+0x64>
 800a958:	68b4      	ldr	r4, [r6, #8]
 800a95a:	e7de      	b.n	800a91a <_vfiprintf_r+0x22>
 800a95c:	4b7d      	ldr	r3, [pc, #500]	; (800ab54 <_vfiprintf_r+0x25c>)
 800a95e:	429c      	cmp	r4, r3
 800a960:	d1db      	bne.n	800a91a <_vfiprintf_r+0x22>
 800a962:	68f4      	ldr	r4, [r6, #12]
 800a964:	e7d9      	b.n	800a91a <_vfiprintf_r+0x22>
 800a966:	89a3      	ldrh	r3, [r4, #12]
 800a968:	059b      	lsls	r3, r3, #22
 800a96a:	d4ee      	bmi.n	800a94a <_vfiprintf_r+0x52>
 800a96c:	6da0      	ldr	r0, [r4, #88]	; 0x58
 800a96e:	f001 fbd5 	bl	800c11c <__retarget_lock_release_recursive>
 800a972:	e7ea      	b.n	800a94a <_vfiprintf_r+0x52>
 800a974:	2300      	movs	r3, #0
 800a976:	ad08      	add	r5, sp, #32
 800a978:	616b      	str	r3, [r5, #20]
 800a97a:	3320      	adds	r3, #32
 800a97c:	766b      	strb	r3, [r5, #25]
 800a97e:	3310      	adds	r3, #16
 800a980:	76ab      	strb	r3, [r5, #26]
 800a982:	9707      	str	r7, [sp, #28]
 800a984:	9f03      	ldr	r7, [sp, #12]
 800a986:	783b      	ldrb	r3, [r7, #0]
 800a988:	2b00      	cmp	r3, #0
 800a98a:	d001      	beq.n	800a990 <_vfiprintf_r+0x98>
 800a98c:	2b25      	cmp	r3, #37	; 0x25
 800a98e:	d14e      	bne.n	800aa2e <_vfiprintf_r+0x136>
 800a990:	9b03      	ldr	r3, [sp, #12]
 800a992:	1afb      	subs	r3, r7, r3
 800a994:	9305      	str	r3, [sp, #20]
 800a996:	9b03      	ldr	r3, [sp, #12]
 800a998:	429f      	cmp	r7, r3
 800a99a:	d00d      	beq.n	800a9b8 <_vfiprintf_r+0xc0>
 800a99c:	9b05      	ldr	r3, [sp, #20]
 800a99e:	0021      	movs	r1, r4
 800a9a0:	0030      	movs	r0, r6
 800a9a2:	9a03      	ldr	r2, [sp, #12]
 800a9a4:	f7ff ff95 	bl	800a8d2 <__sfputs_r>
 800a9a8:	1c43      	adds	r3, r0, #1
 800a9aa:	d100      	bne.n	800a9ae <_vfiprintf_r+0xb6>
 800a9ac:	e0b5      	b.n	800ab1a <_vfiprintf_r+0x222>
 800a9ae:	696a      	ldr	r2, [r5, #20]
 800a9b0:	9b05      	ldr	r3, [sp, #20]
 800a9b2:	4694      	mov	ip, r2
 800a9b4:	4463      	add	r3, ip
 800a9b6:	616b      	str	r3, [r5, #20]
 800a9b8:	783b      	ldrb	r3, [r7, #0]
 800a9ba:	2b00      	cmp	r3, #0
 800a9bc:	d100      	bne.n	800a9c0 <_vfiprintf_r+0xc8>
 800a9be:	e0ac      	b.n	800ab1a <_vfiprintf_r+0x222>
 800a9c0:	2201      	movs	r2, #1
 800a9c2:	1c7b      	adds	r3, r7, #1
 800a9c4:	9303      	str	r3, [sp, #12]
 800a9c6:	2300      	movs	r3, #0
 800a9c8:	4252      	negs	r2, r2
 800a9ca:	606a      	str	r2, [r5, #4]
 800a9cc:	a904      	add	r1, sp, #16
 800a9ce:	3254      	adds	r2, #84	; 0x54
 800a9d0:	1852      	adds	r2, r2, r1
 800a9d2:	602b      	str	r3, [r5, #0]
 800a9d4:	60eb      	str	r3, [r5, #12]
 800a9d6:	60ab      	str	r3, [r5, #8]
 800a9d8:	7013      	strb	r3, [r2, #0]
 800a9da:	65ab      	str	r3, [r5, #88]	; 0x58
 800a9dc:	9b03      	ldr	r3, [sp, #12]
 800a9de:	2205      	movs	r2, #5
 800a9e0:	7819      	ldrb	r1, [r3, #0]
 800a9e2:	485d      	ldr	r0, [pc, #372]	; (800ab58 <_vfiprintf_r+0x260>)
 800a9e4:	f001 fc08 	bl	800c1f8 <memchr>
 800a9e8:	9b03      	ldr	r3, [sp, #12]
 800a9ea:	1c5f      	adds	r7, r3, #1
 800a9ec:	2800      	cmp	r0, #0
 800a9ee:	d120      	bne.n	800aa32 <_vfiprintf_r+0x13a>
 800a9f0:	682a      	ldr	r2, [r5, #0]
 800a9f2:	06d3      	lsls	r3, r2, #27
 800a9f4:	d504      	bpl.n	800aa00 <_vfiprintf_r+0x108>
 800a9f6:	2353      	movs	r3, #83	; 0x53
 800a9f8:	a904      	add	r1, sp, #16
 800a9fa:	185b      	adds	r3, r3, r1
 800a9fc:	2120      	movs	r1, #32
 800a9fe:	7019      	strb	r1, [r3, #0]
 800aa00:	0713      	lsls	r3, r2, #28
 800aa02:	d504      	bpl.n	800aa0e <_vfiprintf_r+0x116>
 800aa04:	2353      	movs	r3, #83	; 0x53
 800aa06:	a904      	add	r1, sp, #16
 800aa08:	185b      	adds	r3, r3, r1
 800aa0a:	212b      	movs	r1, #43	; 0x2b
 800aa0c:	7019      	strb	r1, [r3, #0]
 800aa0e:	9b03      	ldr	r3, [sp, #12]
 800aa10:	781b      	ldrb	r3, [r3, #0]
 800aa12:	2b2a      	cmp	r3, #42	; 0x2a
 800aa14:	d016      	beq.n	800aa44 <_vfiprintf_r+0x14c>
 800aa16:	2100      	movs	r1, #0
 800aa18:	68eb      	ldr	r3, [r5, #12]
 800aa1a:	9f03      	ldr	r7, [sp, #12]
 800aa1c:	783a      	ldrb	r2, [r7, #0]
 800aa1e:	1c78      	adds	r0, r7, #1
 800aa20:	3a30      	subs	r2, #48	; 0x30
 800aa22:	4684      	mov	ip, r0
 800aa24:	2a09      	cmp	r2, #9
 800aa26:	d94f      	bls.n	800aac8 <_vfiprintf_r+0x1d0>
 800aa28:	2900      	cmp	r1, #0
 800aa2a:	d111      	bne.n	800aa50 <_vfiprintf_r+0x158>
 800aa2c:	e017      	b.n	800aa5e <_vfiprintf_r+0x166>
 800aa2e:	3701      	adds	r7, #1
 800aa30:	e7a9      	b.n	800a986 <_vfiprintf_r+0x8e>
 800aa32:	4b49      	ldr	r3, [pc, #292]	; (800ab58 <_vfiprintf_r+0x260>)
 800aa34:	682a      	ldr	r2, [r5, #0]
 800aa36:	1ac0      	subs	r0, r0, r3
 800aa38:	2301      	movs	r3, #1
 800aa3a:	4083      	lsls	r3, r0
 800aa3c:	4313      	orrs	r3, r2
 800aa3e:	602b      	str	r3, [r5, #0]
 800aa40:	9703      	str	r7, [sp, #12]
 800aa42:	e7cb      	b.n	800a9dc <_vfiprintf_r+0xe4>
 800aa44:	9b07      	ldr	r3, [sp, #28]
 800aa46:	1d19      	adds	r1, r3, #4
 800aa48:	681b      	ldr	r3, [r3, #0]
 800aa4a:	9107      	str	r1, [sp, #28]
 800aa4c:	2b00      	cmp	r3, #0
 800aa4e:	db01      	blt.n	800aa54 <_vfiprintf_r+0x15c>
 800aa50:	930b      	str	r3, [sp, #44]	; 0x2c
 800aa52:	e004      	b.n	800aa5e <_vfiprintf_r+0x166>
 800aa54:	425b      	negs	r3, r3
 800aa56:	60eb      	str	r3, [r5, #12]
 800aa58:	2302      	movs	r3, #2
 800aa5a:	4313      	orrs	r3, r2
 800aa5c:	602b      	str	r3, [r5, #0]
 800aa5e:	783b      	ldrb	r3, [r7, #0]
 800aa60:	2b2e      	cmp	r3, #46	; 0x2e
 800aa62:	d10a      	bne.n	800aa7a <_vfiprintf_r+0x182>
 800aa64:	787b      	ldrb	r3, [r7, #1]
 800aa66:	2b2a      	cmp	r3, #42	; 0x2a
 800aa68:	d137      	bne.n	800aada <_vfiprintf_r+0x1e2>
 800aa6a:	9b07      	ldr	r3, [sp, #28]
 800aa6c:	3702      	adds	r7, #2
 800aa6e:	1d1a      	adds	r2, r3, #4
 800aa70:	681b      	ldr	r3, [r3, #0]
 800aa72:	9207      	str	r2, [sp, #28]
 800aa74:	2b00      	cmp	r3, #0
 800aa76:	db2d      	blt.n	800aad4 <_vfiprintf_r+0x1dc>
 800aa78:	9309      	str	r3, [sp, #36]	; 0x24
 800aa7a:	2203      	movs	r2, #3
 800aa7c:	7839      	ldrb	r1, [r7, #0]
 800aa7e:	4837      	ldr	r0, [pc, #220]	; (800ab5c <_vfiprintf_r+0x264>)
 800aa80:	f001 fbba 	bl	800c1f8 <memchr>
 800aa84:	2800      	cmp	r0, #0
 800aa86:	d007      	beq.n	800aa98 <_vfiprintf_r+0x1a0>
 800aa88:	4b34      	ldr	r3, [pc, #208]	; (800ab5c <_vfiprintf_r+0x264>)
 800aa8a:	682a      	ldr	r2, [r5, #0]
 800aa8c:	1ac0      	subs	r0, r0, r3
 800aa8e:	2340      	movs	r3, #64	; 0x40
 800aa90:	4083      	lsls	r3, r0
 800aa92:	4313      	orrs	r3, r2
 800aa94:	3701      	adds	r7, #1
 800aa96:	602b      	str	r3, [r5, #0]
 800aa98:	7839      	ldrb	r1, [r7, #0]
 800aa9a:	1c7b      	adds	r3, r7, #1
 800aa9c:	2206      	movs	r2, #6
 800aa9e:	4830      	ldr	r0, [pc, #192]	; (800ab60 <_vfiprintf_r+0x268>)
 800aaa0:	9303      	str	r3, [sp, #12]
 800aaa2:	7629      	strb	r1, [r5, #24]
 800aaa4:	f001 fba8 	bl	800c1f8 <memchr>
 800aaa8:	2800      	cmp	r0, #0
 800aaaa:	d045      	beq.n	800ab38 <_vfiprintf_r+0x240>
 800aaac:	4b2d      	ldr	r3, [pc, #180]	; (800ab64 <_vfiprintf_r+0x26c>)
 800aaae:	2b00      	cmp	r3, #0
 800aab0:	d127      	bne.n	800ab02 <_vfiprintf_r+0x20a>
 800aab2:	2207      	movs	r2, #7
 800aab4:	9b07      	ldr	r3, [sp, #28]
 800aab6:	3307      	adds	r3, #7
 800aab8:	4393      	bics	r3, r2
 800aaba:	3308      	adds	r3, #8
 800aabc:	9307      	str	r3, [sp, #28]
 800aabe:	696b      	ldr	r3, [r5, #20]
 800aac0:	9a04      	ldr	r2, [sp, #16]
 800aac2:	189b      	adds	r3, r3, r2
 800aac4:	616b      	str	r3, [r5, #20]
 800aac6:	e75d      	b.n	800a984 <_vfiprintf_r+0x8c>
 800aac8:	210a      	movs	r1, #10
 800aaca:	434b      	muls	r3, r1
 800aacc:	4667      	mov	r7, ip
 800aace:	189b      	adds	r3, r3, r2
 800aad0:	3909      	subs	r1, #9
 800aad2:	e7a3      	b.n	800aa1c <_vfiprintf_r+0x124>
 800aad4:	2301      	movs	r3, #1
 800aad6:	425b      	negs	r3, r3
 800aad8:	e7ce      	b.n	800aa78 <_vfiprintf_r+0x180>
 800aada:	2300      	movs	r3, #0
 800aadc:	001a      	movs	r2, r3
 800aade:	3701      	adds	r7, #1
 800aae0:	606b      	str	r3, [r5, #4]
 800aae2:	7839      	ldrb	r1, [r7, #0]
 800aae4:	1c78      	adds	r0, r7, #1
 800aae6:	3930      	subs	r1, #48	; 0x30
 800aae8:	4684      	mov	ip, r0
 800aaea:	2909      	cmp	r1, #9
 800aaec:	d903      	bls.n	800aaf6 <_vfiprintf_r+0x1fe>
 800aaee:	2b00      	cmp	r3, #0
 800aaf0:	d0c3      	beq.n	800aa7a <_vfiprintf_r+0x182>
 800aaf2:	9209      	str	r2, [sp, #36]	; 0x24
 800aaf4:	e7c1      	b.n	800aa7a <_vfiprintf_r+0x182>
 800aaf6:	230a      	movs	r3, #10
 800aaf8:	435a      	muls	r2, r3
 800aafa:	4667      	mov	r7, ip
 800aafc:	1852      	adds	r2, r2, r1
 800aafe:	3b09      	subs	r3, #9
 800ab00:	e7ef      	b.n	800aae2 <_vfiprintf_r+0x1ea>
 800ab02:	ab07      	add	r3, sp, #28
 800ab04:	9300      	str	r3, [sp, #0]
 800ab06:	0022      	movs	r2, r4
 800ab08:	0029      	movs	r1, r5
 800ab0a:	0030      	movs	r0, r6
 800ab0c:	4b16      	ldr	r3, [pc, #88]	; (800ab68 <_vfiprintf_r+0x270>)
 800ab0e:	e000      	b.n	800ab12 <_vfiprintf_r+0x21a>
 800ab10:	bf00      	nop
 800ab12:	9004      	str	r0, [sp, #16]
 800ab14:	9b04      	ldr	r3, [sp, #16]
 800ab16:	3301      	adds	r3, #1
 800ab18:	d1d1      	bne.n	800aabe <_vfiprintf_r+0x1c6>
 800ab1a:	6e63      	ldr	r3, [r4, #100]	; 0x64
 800ab1c:	07db      	lsls	r3, r3, #31
 800ab1e:	d405      	bmi.n	800ab2c <_vfiprintf_r+0x234>
 800ab20:	89a3      	ldrh	r3, [r4, #12]
 800ab22:	059b      	lsls	r3, r3, #22
 800ab24:	d402      	bmi.n	800ab2c <_vfiprintf_r+0x234>
 800ab26:	6da0      	ldr	r0, [r4, #88]	; 0x58
 800ab28:	f001 faf8 	bl	800c11c <__retarget_lock_release_recursive>
 800ab2c:	89a3      	ldrh	r3, [r4, #12]
 800ab2e:	065b      	lsls	r3, r3, #25
 800ab30:	d500      	bpl.n	800ab34 <_vfiprintf_r+0x23c>
 800ab32:	e70a      	b.n	800a94a <_vfiprintf_r+0x52>
 800ab34:	980d      	ldr	r0, [sp, #52]	; 0x34
 800ab36:	e70a      	b.n	800a94e <_vfiprintf_r+0x56>
 800ab38:	ab07      	add	r3, sp, #28
 800ab3a:	9300      	str	r3, [sp, #0]
 800ab3c:	0022      	movs	r2, r4
 800ab3e:	0029      	movs	r1, r5
 800ab40:	0030      	movs	r0, r6
 800ab42:	4b09      	ldr	r3, [pc, #36]	; (800ab68 <_vfiprintf_r+0x270>)
 800ab44:	f000 f882 	bl	800ac4c <_printf_i>
 800ab48:	e7e3      	b.n	800ab12 <_vfiprintf_r+0x21a>
 800ab4a:	46c0      	nop			; (mov r8, r8)
 800ab4c:	0800f340 	.word	0x0800f340
 800ab50:	0800f360 	.word	0x0800f360
 800ab54:	0800f320 	.word	0x0800f320
 800ab58:	0800f27c 	.word	0x0800f27c
 800ab5c:	0800f282 	.word	0x0800f282
 800ab60:	0800f286 	.word	0x0800f286
 800ab64:	00000000 	.word	0x00000000
 800ab68:	0800a8d3 	.word	0x0800a8d3

0800ab6c <_printf_common>:
 800ab6c:	b5f7      	push	{r0, r1, r2, r4, r5, r6, r7, lr}
 800ab6e:	0015      	movs	r5, r2
 800ab70:	9301      	str	r3, [sp, #4]
 800ab72:	688a      	ldr	r2, [r1, #8]
 800ab74:	690b      	ldr	r3, [r1, #16]
 800ab76:	000c      	movs	r4, r1
 800ab78:	9000      	str	r0, [sp, #0]
 800ab7a:	4293      	cmp	r3, r2
 800ab7c:	da00      	bge.n	800ab80 <_printf_common+0x14>
 800ab7e:	0013      	movs	r3, r2
 800ab80:	0022      	movs	r2, r4
 800ab82:	602b      	str	r3, [r5, #0]
 800ab84:	3243      	adds	r2, #67	; 0x43
 800ab86:	7812      	ldrb	r2, [r2, #0]
 800ab88:	2a00      	cmp	r2, #0
 800ab8a:	d001      	beq.n	800ab90 <_printf_common+0x24>
 800ab8c:	3301      	adds	r3, #1
 800ab8e:	602b      	str	r3, [r5, #0]
 800ab90:	6823      	ldr	r3, [r4, #0]
 800ab92:	069b      	lsls	r3, r3, #26
 800ab94:	d502      	bpl.n	800ab9c <_printf_common+0x30>
 800ab96:	682b      	ldr	r3, [r5, #0]
 800ab98:	3302      	adds	r3, #2
 800ab9a:	602b      	str	r3, [r5, #0]
 800ab9c:	6822      	ldr	r2, [r4, #0]
 800ab9e:	2306      	movs	r3, #6
 800aba0:	0017      	movs	r7, r2
 800aba2:	401f      	ands	r7, r3
 800aba4:	421a      	tst	r2, r3
 800aba6:	d027      	beq.n	800abf8 <_printf_common+0x8c>
 800aba8:	0023      	movs	r3, r4
 800abaa:	3343      	adds	r3, #67	; 0x43
 800abac:	781b      	ldrb	r3, [r3, #0]
 800abae:	1e5a      	subs	r2, r3, #1
 800abb0:	4193      	sbcs	r3, r2
 800abb2:	6822      	ldr	r2, [r4, #0]
 800abb4:	0692      	lsls	r2, r2, #26
 800abb6:	d430      	bmi.n	800ac1a <_printf_common+0xae>
 800abb8:	0022      	movs	r2, r4
 800abba:	9901      	ldr	r1, [sp, #4]
 800abbc:	9800      	ldr	r0, [sp, #0]
 800abbe:	9e08      	ldr	r6, [sp, #32]
 800abc0:	3243      	adds	r2, #67	; 0x43
 800abc2:	47b0      	blx	r6
 800abc4:	1c43      	adds	r3, r0, #1
 800abc6:	d025      	beq.n	800ac14 <_printf_common+0xa8>
 800abc8:	2306      	movs	r3, #6
 800abca:	6820      	ldr	r0, [r4, #0]
 800abcc:	682a      	ldr	r2, [r5, #0]
 800abce:	68e1      	ldr	r1, [r4, #12]
 800abd0:	2500      	movs	r5, #0
 800abd2:	4003      	ands	r3, r0
 800abd4:	2b04      	cmp	r3, #4
 800abd6:	d103      	bne.n	800abe0 <_printf_common+0x74>
 800abd8:	1a8d      	subs	r5, r1, r2
 800abda:	43eb      	mvns	r3, r5
 800abdc:	17db      	asrs	r3, r3, #31
 800abde:	401d      	ands	r5, r3
 800abe0:	68a3      	ldr	r3, [r4, #8]
 800abe2:	6922      	ldr	r2, [r4, #16]
 800abe4:	4293      	cmp	r3, r2
 800abe6:	dd01      	ble.n	800abec <_printf_common+0x80>
 800abe8:	1a9b      	subs	r3, r3, r2
 800abea:	18ed      	adds	r5, r5, r3
 800abec:	2700      	movs	r7, #0
 800abee:	42bd      	cmp	r5, r7
 800abf0:	d120      	bne.n	800ac34 <_printf_common+0xc8>
 800abf2:	2000      	movs	r0, #0
 800abf4:	e010      	b.n	800ac18 <_printf_common+0xac>
 800abf6:	3701      	adds	r7, #1
 800abf8:	68e3      	ldr	r3, [r4, #12]
 800abfa:	682a      	ldr	r2, [r5, #0]
 800abfc:	1a9b      	subs	r3, r3, r2
 800abfe:	42bb      	cmp	r3, r7
 800ac00:	ddd2      	ble.n	800aba8 <_printf_common+0x3c>
 800ac02:	0022      	movs	r2, r4
 800ac04:	2301      	movs	r3, #1
 800ac06:	9901      	ldr	r1, [sp, #4]
 800ac08:	9800      	ldr	r0, [sp, #0]
 800ac0a:	9e08      	ldr	r6, [sp, #32]
 800ac0c:	3219      	adds	r2, #25
 800ac0e:	47b0      	blx	r6
 800ac10:	1c43      	adds	r3, r0, #1
 800ac12:	d1f0      	bne.n	800abf6 <_printf_common+0x8a>
 800ac14:	2001      	movs	r0, #1
 800ac16:	4240      	negs	r0, r0
 800ac18:	bdfe      	pop	{r1, r2, r3, r4, r5, r6, r7, pc}
 800ac1a:	2030      	movs	r0, #48	; 0x30
 800ac1c:	18e1      	adds	r1, r4, r3
 800ac1e:	3143      	adds	r1, #67	; 0x43
 800ac20:	7008      	strb	r0, [r1, #0]
 800ac22:	0021      	movs	r1, r4
 800ac24:	1c5a      	adds	r2, r3, #1
 800ac26:	3145      	adds	r1, #69	; 0x45
 800ac28:	7809      	ldrb	r1, [r1, #0]
 800ac2a:	18a2      	adds	r2, r4, r2
 800ac2c:	3243      	adds	r2, #67	; 0x43
 800ac2e:	3302      	adds	r3, #2
 800ac30:	7011      	strb	r1, [r2, #0]
 800ac32:	e7c1      	b.n	800abb8 <_printf_common+0x4c>
 800ac34:	0022      	movs	r2, r4
 800ac36:	2301      	movs	r3, #1
 800ac38:	9901      	ldr	r1, [sp, #4]
 800ac3a:	9800      	ldr	r0, [sp, #0]
 800ac3c:	9e08      	ldr	r6, [sp, #32]
 800ac3e:	321a      	adds	r2, #26
 800ac40:	47b0      	blx	r6
 800ac42:	1c43      	adds	r3, r0, #1
 800ac44:	d0e6      	beq.n	800ac14 <_printf_common+0xa8>
 800ac46:	3701      	adds	r7, #1
 800ac48:	e7d1      	b.n	800abee <_printf_common+0x82>
	...

0800ac4c <_printf_i>:
 800ac4c:	b5f0      	push	{r4, r5, r6, r7, lr}
 800ac4e:	b08b      	sub	sp, #44	; 0x2c
 800ac50:	9206      	str	r2, [sp, #24]
 800ac52:	000a      	movs	r2, r1
 800ac54:	3243      	adds	r2, #67	; 0x43
 800ac56:	9307      	str	r3, [sp, #28]
 800ac58:	9005      	str	r0, [sp, #20]
 800ac5a:	9204      	str	r2, [sp, #16]
 800ac5c:	7e0a      	ldrb	r2, [r1, #24]
 800ac5e:	000c      	movs	r4, r1
 800ac60:	9b10      	ldr	r3, [sp, #64]	; 0x40
 800ac62:	2a78      	cmp	r2, #120	; 0x78
 800ac64:	d806      	bhi.n	800ac74 <_printf_i+0x28>
 800ac66:	2a62      	cmp	r2, #98	; 0x62
 800ac68:	d808      	bhi.n	800ac7c <_printf_i+0x30>
 800ac6a:	2a00      	cmp	r2, #0
 800ac6c:	d100      	bne.n	800ac70 <_printf_i+0x24>
 800ac6e:	e0c0      	b.n	800adf2 <_printf_i+0x1a6>
 800ac70:	2a58      	cmp	r2, #88	; 0x58
 800ac72:	d052      	beq.n	800ad1a <_printf_i+0xce>
 800ac74:	0026      	movs	r6, r4
 800ac76:	3642      	adds	r6, #66	; 0x42
 800ac78:	7032      	strb	r2, [r6, #0]
 800ac7a:	e022      	b.n	800acc2 <_printf_i+0x76>
 800ac7c:	0010      	movs	r0, r2
 800ac7e:	3863      	subs	r0, #99	; 0x63
 800ac80:	2815      	cmp	r0, #21
 800ac82:	d8f7      	bhi.n	800ac74 <_printf_i+0x28>
 800ac84:	f7f8 f9e0 	bl	8003048 <__gnu_thumb1_case_shi>
 800ac88:	001f0016 	.word	0x001f0016
 800ac8c:	fff6fff6 	.word	0xfff6fff6
 800ac90:	fff6fff6 	.word	0xfff6fff6
 800ac94:	fff6001f 	.word	0xfff6001f
 800ac98:	fff6fff6 	.word	0xfff6fff6
 800ac9c:	00a8fff6 	.word	0x00a8fff6
 800aca0:	009a0036 	.word	0x009a0036
 800aca4:	fff6fff6 	.word	0xfff6fff6
 800aca8:	fff600b9 	.word	0xfff600b9
 800acac:	fff60036 	.word	0xfff60036
 800acb0:	009efff6 	.word	0x009efff6
 800acb4:	0026      	movs	r6, r4
 800acb6:	681a      	ldr	r2, [r3, #0]
 800acb8:	3642      	adds	r6, #66	; 0x42
 800acba:	1d11      	adds	r1, r2, #4
 800acbc:	6019      	str	r1, [r3, #0]
 800acbe:	6813      	ldr	r3, [r2, #0]
 800acc0:	7033      	strb	r3, [r6, #0]
 800acc2:	2301      	movs	r3, #1
 800acc4:	e0a7      	b.n	800ae16 <_printf_i+0x1ca>
 800acc6:	6808      	ldr	r0, [r1, #0]
 800acc8:	6819      	ldr	r1, [r3, #0]
 800acca:	1d0a      	adds	r2, r1, #4
 800accc:	0605      	lsls	r5, r0, #24
 800acce:	d50b      	bpl.n	800ace8 <_printf_i+0x9c>
 800acd0:	680d      	ldr	r5, [r1, #0]
 800acd2:	601a      	str	r2, [r3, #0]
 800acd4:	2d00      	cmp	r5, #0
 800acd6:	da03      	bge.n	800ace0 <_printf_i+0x94>
 800acd8:	232d      	movs	r3, #45	; 0x2d
 800acda:	9a04      	ldr	r2, [sp, #16]
 800acdc:	426d      	negs	r5, r5
 800acde:	7013      	strb	r3, [r2, #0]
 800ace0:	4b61      	ldr	r3, [pc, #388]	; (800ae68 <_printf_i+0x21c>)
 800ace2:	270a      	movs	r7, #10
 800ace4:	9303      	str	r3, [sp, #12]
 800ace6:	e032      	b.n	800ad4e <_printf_i+0x102>
 800ace8:	680d      	ldr	r5, [r1, #0]
 800acea:	601a      	str	r2, [r3, #0]
 800acec:	0641      	lsls	r1, r0, #25
 800acee:	d5f1      	bpl.n	800acd4 <_printf_i+0x88>
 800acf0:	b22d      	sxth	r5, r5
 800acf2:	e7ef      	b.n	800acd4 <_printf_i+0x88>
 800acf4:	680d      	ldr	r5, [r1, #0]
 800acf6:	6819      	ldr	r1, [r3, #0]
 800acf8:	1d08      	adds	r0, r1, #4
 800acfa:	6018      	str	r0, [r3, #0]
 800acfc:	062e      	lsls	r6, r5, #24
 800acfe:	d501      	bpl.n	800ad04 <_printf_i+0xb8>
 800ad00:	680d      	ldr	r5, [r1, #0]
 800ad02:	e003      	b.n	800ad0c <_printf_i+0xc0>
 800ad04:	066d      	lsls	r5, r5, #25
 800ad06:	d5fb      	bpl.n	800ad00 <_printf_i+0xb4>
 800ad08:	680d      	ldr	r5, [r1, #0]
 800ad0a:	b2ad      	uxth	r5, r5
 800ad0c:	4b56      	ldr	r3, [pc, #344]	; (800ae68 <_printf_i+0x21c>)
 800ad0e:	270a      	movs	r7, #10
 800ad10:	9303      	str	r3, [sp, #12]
 800ad12:	2a6f      	cmp	r2, #111	; 0x6f
 800ad14:	d117      	bne.n	800ad46 <_printf_i+0xfa>
 800ad16:	2708      	movs	r7, #8
 800ad18:	e015      	b.n	800ad46 <_printf_i+0xfa>
 800ad1a:	3145      	adds	r1, #69	; 0x45
 800ad1c:	700a      	strb	r2, [r1, #0]
 800ad1e:	4a52      	ldr	r2, [pc, #328]	; (800ae68 <_printf_i+0x21c>)
 800ad20:	9203      	str	r2, [sp, #12]
 800ad22:	681a      	ldr	r2, [r3, #0]
 800ad24:	6821      	ldr	r1, [r4, #0]
 800ad26:	ca20      	ldmia	r2!, {r5}
 800ad28:	601a      	str	r2, [r3, #0]
 800ad2a:	0608      	lsls	r0, r1, #24
 800ad2c:	d550      	bpl.n	800add0 <_printf_i+0x184>
 800ad2e:	07cb      	lsls	r3, r1, #31
 800ad30:	d502      	bpl.n	800ad38 <_printf_i+0xec>
 800ad32:	2320      	movs	r3, #32
 800ad34:	4319      	orrs	r1, r3
 800ad36:	6021      	str	r1, [r4, #0]
 800ad38:	2710      	movs	r7, #16
 800ad3a:	2d00      	cmp	r5, #0
 800ad3c:	d103      	bne.n	800ad46 <_printf_i+0xfa>
 800ad3e:	2320      	movs	r3, #32
 800ad40:	6822      	ldr	r2, [r4, #0]
 800ad42:	439a      	bics	r2, r3
 800ad44:	6022      	str	r2, [r4, #0]
 800ad46:	0023      	movs	r3, r4
 800ad48:	2200      	movs	r2, #0
 800ad4a:	3343      	adds	r3, #67	; 0x43
 800ad4c:	701a      	strb	r2, [r3, #0]
 800ad4e:	6863      	ldr	r3, [r4, #4]
 800ad50:	60a3      	str	r3, [r4, #8]
 800ad52:	2b00      	cmp	r3, #0
 800ad54:	db03      	blt.n	800ad5e <_printf_i+0x112>
 800ad56:	2204      	movs	r2, #4
 800ad58:	6821      	ldr	r1, [r4, #0]
 800ad5a:	4391      	bics	r1, r2
 800ad5c:	6021      	str	r1, [r4, #0]
 800ad5e:	2d00      	cmp	r5, #0
 800ad60:	d102      	bne.n	800ad68 <_printf_i+0x11c>
 800ad62:	9e04      	ldr	r6, [sp, #16]
 800ad64:	2b00      	cmp	r3, #0
 800ad66:	d00c      	beq.n	800ad82 <_printf_i+0x136>
 800ad68:	9e04      	ldr	r6, [sp, #16]
 800ad6a:	0028      	movs	r0, r5
 800ad6c:	0039      	movs	r1, r7
 800ad6e:	f7f5 fa4f 	bl	8000210 <__aeabi_uidivmod>
 800ad72:	9b03      	ldr	r3, [sp, #12]
 800ad74:	3e01      	subs	r6, #1
 800ad76:	5c5b      	ldrb	r3, [r3, r1]
 800ad78:	7033      	strb	r3, [r6, #0]
 800ad7a:	002b      	movs	r3, r5
 800ad7c:	0005      	movs	r5, r0
 800ad7e:	429f      	cmp	r7, r3
 800ad80:	d9f3      	bls.n	800ad6a <_printf_i+0x11e>
 800ad82:	2f08      	cmp	r7, #8
 800ad84:	d109      	bne.n	800ad9a <_printf_i+0x14e>
 800ad86:	6823      	ldr	r3, [r4, #0]
 800ad88:	07db      	lsls	r3, r3, #31
 800ad8a:	d506      	bpl.n	800ad9a <_printf_i+0x14e>
 800ad8c:	6863      	ldr	r3, [r4, #4]
 800ad8e:	6922      	ldr	r2, [r4, #16]
 800ad90:	4293      	cmp	r3, r2
 800ad92:	dc02      	bgt.n	800ad9a <_printf_i+0x14e>
 800ad94:	2330      	movs	r3, #48	; 0x30
 800ad96:	3e01      	subs	r6, #1
 800ad98:	7033      	strb	r3, [r6, #0]
 800ad9a:	9b04      	ldr	r3, [sp, #16]
 800ad9c:	1b9b      	subs	r3, r3, r6
 800ad9e:	6123      	str	r3, [r4, #16]
 800ada0:	9b07      	ldr	r3, [sp, #28]
 800ada2:	0021      	movs	r1, r4
 800ada4:	9300      	str	r3, [sp, #0]
 800ada6:	9805      	ldr	r0, [sp, #20]
 800ada8:	9b06      	ldr	r3, [sp, #24]
 800adaa:	aa09      	add	r2, sp, #36	; 0x24
 800adac:	f7ff fede 	bl	800ab6c <_printf_common>
 800adb0:	1c43      	adds	r3, r0, #1
 800adb2:	d135      	bne.n	800ae20 <_printf_i+0x1d4>
 800adb4:	2001      	movs	r0, #1
 800adb6:	4240      	negs	r0, r0
 800adb8:	b00b      	add	sp, #44	; 0x2c
 800adba:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800adbc:	2220      	movs	r2, #32
 800adbe:	6809      	ldr	r1, [r1, #0]
 800adc0:	430a      	orrs	r2, r1
 800adc2:	6022      	str	r2, [r4, #0]
 800adc4:	0022      	movs	r2, r4
 800adc6:	2178      	movs	r1, #120	; 0x78
 800adc8:	3245      	adds	r2, #69	; 0x45
 800adca:	7011      	strb	r1, [r2, #0]
 800adcc:	4a27      	ldr	r2, [pc, #156]	; (800ae6c <_printf_i+0x220>)
 800adce:	e7a7      	b.n	800ad20 <_printf_i+0xd4>
 800add0:	0648      	lsls	r0, r1, #25
 800add2:	d5ac      	bpl.n	800ad2e <_printf_i+0xe2>
 800add4:	b2ad      	uxth	r5, r5
 800add6:	e7aa      	b.n	800ad2e <_printf_i+0xe2>
 800add8:	681a      	ldr	r2, [r3, #0]
 800adda:	680d      	ldr	r5, [r1, #0]
 800addc:	1d10      	adds	r0, r2, #4
 800adde:	6949      	ldr	r1, [r1, #20]
 800ade0:	6018      	str	r0, [r3, #0]
 800ade2:	6813      	ldr	r3, [r2, #0]
 800ade4:	062e      	lsls	r6, r5, #24
 800ade6:	d501      	bpl.n	800adec <_printf_i+0x1a0>
 800ade8:	6019      	str	r1, [r3, #0]
 800adea:	e002      	b.n	800adf2 <_printf_i+0x1a6>
 800adec:	066d      	lsls	r5, r5, #25
 800adee:	d5fb      	bpl.n	800ade8 <_printf_i+0x19c>
 800adf0:	8019      	strh	r1, [r3, #0]
 800adf2:	2300      	movs	r3, #0
 800adf4:	9e04      	ldr	r6, [sp, #16]
 800adf6:	6123      	str	r3, [r4, #16]
 800adf8:	e7d2      	b.n	800ada0 <_printf_i+0x154>
 800adfa:	681a      	ldr	r2, [r3, #0]
 800adfc:	1d11      	adds	r1, r2, #4
 800adfe:	6019      	str	r1, [r3, #0]
 800ae00:	6816      	ldr	r6, [r2, #0]
 800ae02:	2100      	movs	r1, #0
 800ae04:	0030      	movs	r0, r6
 800ae06:	6862      	ldr	r2, [r4, #4]
 800ae08:	f001 f9f6 	bl	800c1f8 <memchr>
 800ae0c:	2800      	cmp	r0, #0
 800ae0e:	d001      	beq.n	800ae14 <_printf_i+0x1c8>
 800ae10:	1b80      	subs	r0, r0, r6
 800ae12:	6060      	str	r0, [r4, #4]
 800ae14:	6863      	ldr	r3, [r4, #4]
 800ae16:	6123      	str	r3, [r4, #16]
 800ae18:	2300      	movs	r3, #0
 800ae1a:	9a04      	ldr	r2, [sp, #16]
 800ae1c:	7013      	strb	r3, [r2, #0]
 800ae1e:	e7bf      	b.n	800ada0 <_printf_i+0x154>
 800ae20:	6923      	ldr	r3, [r4, #16]
 800ae22:	0032      	movs	r2, r6
 800ae24:	9906      	ldr	r1, [sp, #24]
 800ae26:	9805      	ldr	r0, [sp, #20]
 800ae28:	9d07      	ldr	r5, [sp, #28]
 800ae2a:	47a8      	blx	r5
 800ae2c:	1c43      	adds	r3, r0, #1
 800ae2e:	d0c1      	beq.n	800adb4 <_printf_i+0x168>
 800ae30:	6823      	ldr	r3, [r4, #0]
 800ae32:	079b      	lsls	r3, r3, #30
 800ae34:	d415      	bmi.n	800ae62 <_printf_i+0x216>
 800ae36:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800ae38:	68e0      	ldr	r0, [r4, #12]
 800ae3a:	4298      	cmp	r0, r3
 800ae3c:	dabc      	bge.n	800adb8 <_printf_i+0x16c>
 800ae3e:	0018      	movs	r0, r3
 800ae40:	e7ba      	b.n	800adb8 <_printf_i+0x16c>
 800ae42:	0022      	movs	r2, r4
 800ae44:	2301      	movs	r3, #1
 800ae46:	9906      	ldr	r1, [sp, #24]
 800ae48:	9805      	ldr	r0, [sp, #20]
 800ae4a:	9e07      	ldr	r6, [sp, #28]
 800ae4c:	3219      	adds	r2, #25
 800ae4e:	47b0      	blx	r6
 800ae50:	1c43      	adds	r3, r0, #1
 800ae52:	d0af      	beq.n	800adb4 <_printf_i+0x168>
 800ae54:	3501      	adds	r5, #1
 800ae56:	68e3      	ldr	r3, [r4, #12]
 800ae58:	9a09      	ldr	r2, [sp, #36]	; 0x24
 800ae5a:	1a9b      	subs	r3, r3, r2
 800ae5c:	42ab      	cmp	r3, r5
 800ae5e:	dcf0      	bgt.n	800ae42 <_printf_i+0x1f6>
 800ae60:	e7e9      	b.n	800ae36 <_printf_i+0x1ea>
 800ae62:	2500      	movs	r5, #0
 800ae64:	e7f7      	b.n	800ae56 <_printf_i+0x20a>
 800ae66:	46c0      	nop			; (mov r8, r8)
 800ae68:	0800f28d 	.word	0x0800f28d
 800ae6c:	0800f29e 	.word	0x0800f29e

0800ae70 <strcpy>:
 800ae70:	0003      	movs	r3, r0
 800ae72:	780a      	ldrb	r2, [r1, #0]
 800ae74:	3101      	adds	r1, #1
 800ae76:	701a      	strb	r2, [r3, #0]
 800ae78:	3301      	adds	r3, #1
 800ae7a:	2a00      	cmp	r2, #0
 800ae7c:	d1f9      	bne.n	800ae72 <strcpy+0x2>
 800ae7e:	4770      	bx	lr

0800ae80 <__swbuf_r>:
 800ae80:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 800ae82:	0005      	movs	r5, r0
 800ae84:	000e      	movs	r6, r1
 800ae86:	0014      	movs	r4, r2
 800ae88:	2800      	cmp	r0, #0
 800ae8a:	d004      	beq.n	800ae96 <__swbuf_r+0x16>
 800ae8c:	6983      	ldr	r3, [r0, #24]
 800ae8e:	2b00      	cmp	r3, #0
 800ae90:	d101      	bne.n	800ae96 <__swbuf_r+0x16>
 800ae92:	f001 f8a1 	bl	800bfd8 <__sinit>
 800ae96:	4b22      	ldr	r3, [pc, #136]	; (800af20 <__swbuf_r+0xa0>)
 800ae98:	429c      	cmp	r4, r3
 800ae9a:	d12e      	bne.n	800aefa <__swbuf_r+0x7a>
 800ae9c:	686c      	ldr	r4, [r5, #4]
 800ae9e:	69a3      	ldr	r3, [r4, #24]
 800aea0:	60a3      	str	r3, [r4, #8]
 800aea2:	89a3      	ldrh	r3, [r4, #12]
 800aea4:	071b      	lsls	r3, r3, #28
 800aea6:	d532      	bpl.n	800af0e <__swbuf_r+0x8e>
 800aea8:	6923      	ldr	r3, [r4, #16]
 800aeaa:	2b00      	cmp	r3, #0
 800aeac:	d02f      	beq.n	800af0e <__swbuf_r+0x8e>
 800aeae:	6823      	ldr	r3, [r4, #0]
 800aeb0:	6922      	ldr	r2, [r4, #16]
 800aeb2:	b2f7      	uxtb	r7, r6
 800aeb4:	1a98      	subs	r0, r3, r2
 800aeb6:	6963      	ldr	r3, [r4, #20]
 800aeb8:	b2f6      	uxtb	r6, r6
 800aeba:	4283      	cmp	r3, r0
 800aebc:	dc05      	bgt.n	800aeca <__swbuf_r+0x4a>
 800aebe:	0021      	movs	r1, r4
 800aec0:	0028      	movs	r0, r5
 800aec2:	f000 ffe7 	bl	800be94 <_fflush_r>
 800aec6:	2800      	cmp	r0, #0
 800aec8:	d127      	bne.n	800af1a <__swbuf_r+0x9a>
 800aeca:	68a3      	ldr	r3, [r4, #8]
 800aecc:	3001      	adds	r0, #1
 800aece:	3b01      	subs	r3, #1
 800aed0:	60a3      	str	r3, [r4, #8]
 800aed2:	6823      	ldr	r3, [r4, #0]
 800aed4:	1c5a      	adds	r2, r3, #1
 800aed6:	6022      	str	r2, [r4, #0]
 800aed8:	701f      	strb	r7, [r3, #0]
 800aeda:	6963      	ldr	r3, [r4, #20]
 800aedc:	4283      	cmp	r3, r0
 800aede:	d004      	beq.n	800aeea <__swbuf_r+0x6a>
 800aee0:	89a3      	ldrh	r3, [r4, #12]
 800aee2:	07db      	lsls	r3, r3, #31
 800aee4:	d507      	bpl.n	800aef6 <__swbuf_r+0x76>
 800aee6:	2e0a      	cmp	r6, #10
 800aee8:	d105      	bne.n	800aef6 <__swbuf_r+0x76>
 800aeea:	0021      	movs	r1, r4
 800aeec:	0028      	movs	r0, r5
 800aeee:	f000 ffd1 	bl	800be94 <_fflush_r>
 800aef2:	2800      	cmp	r0, #0
 800aef4:	d111      	bne.n	800af1a <__swbuf_r+0x9a>
 800aef6:	0030      	movs	r0, r6
 800aef8:	bdf8      	pop	{r3, r4, r5, r6, r7, pc}
 800aefa:	4b0a      	ldr	r3, [pc, #40]	; (800af24 <__swbuf_r+0xa4>)
 800aefc:	429c      	cmp	r4, r3
 800aefe:	d101      	bne.n	800af04 <__swbuf_r+0x84>
 800af00:	68ac      	ldr	r4, [r5, #8]
 800af02:	e7cc      	b.n	800ae9e <__swbuf_r+0x1e>
 800af04:	4b08      	ldr	r3, [pc, #32]	; (800af28 <__swbuf_r+0xa8>)
 800af06:	429c      	cmp	r4, r3
 800af08:	d1c9      	bne.n	800ae9e <__swbuf_r+0x1e>
 800af0a:	68ec      	ldr	r4, [r5, #12]
 800af0c:	e7c7      	b.n	800ae9e <__swbuf_r+0x1e>
 800af0e:	0021      	movs	r1, r4
 800af10:	0028      	movs	r0, r5
 800af12:	f000 f80b 	bl	800af2c <__swsetup_r>
 800af16:	2800      	cmp	r0, #0
 800af18:	d0c9      	beq.n	800aeae <__swbuf_r+0x2e>
 800af1a:	2601      	movs	r6, #1
 800af1c:	4276      	negs	r6, r6
 800af1e:	e7ea      	b.n	800aef6 <__swbuf_r+0x76>
 800af20:	0800f340 	.word	0x0800f340
 800af24:	0800f360 	.word	0x0800f360
 800af28:	0800f320 	.word	0x0800f320

0800af2c <__swsetup_r>:
 800af2c:	4b37      	ldr	r3, [pc, #220]	; (800b00c <__swsetup_r+0xe0>)
 800af2e:	b570      	push	{r4, r5, r6, lr}
 800af30:	681d      	ldr	r5, [r3, #0]
 800af32:	0006      	movs	r6, r0
 800af34:	000c      	movs	r4, r1
 800af36:	2d00      	cmp	r5, #0
 800af38:	d005      	beq.n	800af46 <__swsetup_r+0x1a>
 800af3a:	69ab      	ldr	r3, [r5, #24]
 800af3c:	2b00      	cmp	r3, #0
 800af3e:	d102      	bne.n	800af46 <__swsetup_r+0x1a>
 800af40:	0028      	movs	r0, r5
 800af42:	f001 f849 	bl	800bfd8 <__sinit>
 800af46:	4b32      	ldr	r3, [pc, #200]	; (800b010 <__swsetup_r+0xe4>)
 800af48:	429c      	cmp	r4, r3
 800af4a:	d10f      	bne.n	800af6c <__swsetup_r+0x40>
 800af4c:	686c      	ldr	r4, [r5, #4]
 800af4e:	230c      	movs	r3, #12
 800af50:	5ee2      	ldrsh	r2, [r4, r3]
 800af52:	b293      	uxth	r3, r2
 800af54:	0711      	lsls	r1, r2, #28
 800af56:	d42d      	bmi.n	800afb4 <__swsetup_r+0x88>
 800af58:	06d9      	lsls	r1, r3, #27
 800af5a:	d411      	bmi.n	800af80 <__swsetup_r+0x54>
 800af5c:	2309      	movs	r3, #9
 800af5e:	2001      	movs	r0, #1
 800af60:	6033      	str	r3, [r6, #0]
 800af62:	3337      	adds	r3, #55	; 0x37
 800af64:	4313      	orrs	r3, r2
 800af66:	81a3      	strh	r3, [r4, #12]
 800af68:	4240      	negs	r0, r0
 800af6a:	bd70      	pop	{r4, r5, r6, pc}
 800af6c:	4b29      	ldr	r3, [pc, #164]	; (800b014 <__swsetup_r+0xe8>)
 800af6e:	429c      	cmp	r4, r3
 800af70:	d101      	bne.n	800af76 <__swsetup_r+0x4a>
 800af72:	68ac      	ldr	r4, [r5, #8]
 800af74:	e7eb      	b.n	800af4e <__swsetup_r+0x22>
 800af76:	4b28      	ldr	r3, [pc, #160]	; (800b018 <__swsetup_r+0xec>)
 800af78:	429c      	cmp	r4, r3
 800af7a:	d1e8      	bne.n	800af4e <__swsetup_r+0x22>
 800af7c:	68ec      	ldr	r4, [r5, #12]
 800af7e:	e7e6      	b.n	800af4e <__swsetup_r+0x22>
 800af80:	075b      	lsls	r3, r3, #29
 800af82:	d513      	bpl.n	800afac <__swsetup_r+0x80>
 800af84:	6b61      	ldr	r1, [r4, #52]	; 0x34
 800af86:	2900      	cmp	r1, #0
 800af88:	d008      	beq.n	800af9c <__swsetup_r+0x70>
 800af8a:	0023      	movs	r3, r4
 800af8c:	3344      	adds	r3, #68	; 0x44
 800af8e:	4299      	cmp	r1, r3
 800af90:	d002      	beq.n	800af98 <__swsetup_r+0x6c>
 800af92:	0030      	movs	r0, r6
 800af94:	f7fe fe7c 	bl	8009c90 <_free_r>
 800af98:	2300      	movs	r3, #0
 800af9a:	6363      	str	r3, [r4, #52]	; 0x34
 800af9c:	2224      	movs	r2, #36	; 0x24
 800af9e:	89a3      	ldrh	r3, [r4, #12]
 800afa0:	4393      	bics	r3, r2
 800afa2:	81a3      	strh	r3, [r4, #12]
 800afa4:	2300      	movs	r3, #0
 800afa6:	6063      	str	r3, [r4, #4]
 800afa8:	6923      	ldr	r3, [r4, #16]
 800afaa:	6023      	str	r3, [r4, #0]
 800afac:	2308      	movs	r3, #8
 800afae:	89a2      	ldrh	r2, [r4, #12]
 800afb0:	4313      	orrs	r3, r2
 800afb2:	81a3      	strh	r3, [r4, #12]
 800afb4:	6923      	ldr	r3, [r4, #16]
 800afb6:	2b00      	cmp	r3, #0
 800afb8:	d10b      	bne.n	800afd2 <__swsetup_r+0xa6>
 800afba:	21a0      	movs	r1, #160	; 0xa0
 800afbc:	2280      	movs	r2, #128	; 0x80
 800afbe:	89a3      	ldrh	r3, [r4, #12]
 800afc0:	0089      	lsls	r1, r1, #2
 800afc2:	0092      	lsls	r2, r2, #2
 800afc4:	400b      	ands	r3, r1
 800afc6:	4293      	cmp	r3, r2
 800afc8:	d003      	beq.n	800afd2 <__swsetup_r+0xa6>
 800afca:	0021      	movs	r1, r4
 800afcc:	0030      	movs	r0, r6
 800afce:	f001 f8cf 	bl	800c170 <__smakebuf_r>
 800afd2:	220c      	movs	r2, #12
 800afd4:	5ea3      	ldrsh	r3, [r4, r2]
 800afd6:	2001      	movs	r0, #1
 800afd8:	001a      	movs	r2, r3
 800afda:	b299      	uxth	r1, r3
 800afdc:	4002      	ands	r2, r0
 800afde:	4203      	tst	r3, r0
 800afe0:	d00f      	beq.n	800b002 <__swsetup_r+0xd6>
 800afe2:	2200      	movs	r2, #0
 800afe4:	60a2      	str	r2, [r4, #8]
 800afe6:	6962      	ldr	r2, [r4, #20]
 800afe8:	4252      	negs	r2, r2
 800afea:	61a2      	str	r2, [r4, #24]
 800afec:	2000      	movs	r0, #0
 800afee:	6922      	ldr	r2, [r4, #16]
 800aff0:	4282      	cmp	r2, r0
 800aff2:	d1ba      	bne.n	800af6a <__swsetup_r+0x3e>
 800aff4:	060a      	lsls	r2, r1, #24
 800aff6:	d5b8      	bpl.n	800af6a <__swsetup_r+0x3e>
 800aff8:	2240      	movs	r2, #64	; 0x40
 800affa:	4313      	orrs	r3, r2
 800affc:	81a3      	strh	r3, [r4, #12]
 800affe:	3801      	subs	r0, #1
 800b000:	e7b3      	b.n	800af6a <__swsetup_r+0x3e>
 800b002:	0788      	lsls	r0, r1, #30
 800b004:	d400      	bmi.n	800b008 <__swsetup_r+0xdc>
 800b006:	6962      	ldr	r2, [r4, #20]
 800b008:	60a2      	str	r2, [r4, #8]
 800b00a:	e7ef      	b.n	800afec <__swsetup_r+0xc0>
 800b00c:	20000088 	.word	0x20000088
 800b010:	0800f340 	.word	0x0800f340
 800b014:	0800f360 	.word	0x0800f360
 800b018:	0800f320 	.word	0x0800f320

0800b01c <abort>:
 800b01c:	2006      	movs	r0, #6
 800b01e:	b510      	push	{r4, lr}
 800b020:	f001 f928 	bl	800c274 <raise>
 800b024:	2001      	movs	r0, #1
 800b026:	f7fa fb63 	bl	80056f0 <_exit>

0800b02a <quorem>:
 800b02a:	b5f0      	push	{r4, r5, r6, r7, lr}
 800b02c:	0006      	movs	r6, r0
 800b02e:	690d      	ldr	r5, [r1, #16]
 800b030:	6933      	ldr	r3, [r6, #16]
 800b032:	b087      	sub	sp, #28
 800b034:	2000      	movs	r0, #0
 800b036:	9102      	str	r1, [sp, #8]
 800b038:	42ab      	cmp	r3, r5
 800b03a:	db6b      	blt.n	800b114 <quorem+0xea>
 800b03c:	000b      	movs	r3, r1
 800b03e:	3d01      	subs	r5, #1
 800b040:	00ac      	lsls	r4, r5, #2
 800b042:	3314      	adds	r3, #20
 800b044:	9305      	str	r3, [sp, #20]
 800b046:	191b      	adds	r3, r3, r4
 800b048:	9303      	str	r3, [sp, #12]
 800b04a:	0033      	movs	r3, r6
 800b04c:	3314      	adds	r3, #20
 800b04e:	9301      	str	r3, [sp, #4]
 800b050:	191c      	adds	r4, r3, r4
 800b052:	9b03      	ldr	r3, [sp, #12]
 800b054:	6827      	ldr	r7, [r4, #0]
 800b056:	681b      	ldr	r3, [r3, #0]
 800b058:	0038      	movs	r0, r7
 800b05a:	9300      	str	r3, [sp, #0]
 800b05c:	3301      	adds	r3, #1
 800b05e:	0019      	movs	r1, r3
 800b060:	9304      	str	r3, [sp, #16]
 800b062:	f7f5 f84f 	bl	8000104 <__udivsi3>
 800b066:	9b04      	ldr	r3, [sp, #16]
 800b068:	9000      	str	r0, [sp, #0]
 800b06a:	429f      	cmp	r7, r3
 800b06c:	d329      	bcc.n	800b0c2 <quorem+0x98>
 800b06e:	2300      	movs	r3, #0
 800b070:	469c      	mov	ip, r3
 800b072:	9801      	ldr	r0, [sp, #4]
 800b074:	9f05      	ldr	r7, [sp, #20]
 800b076:	9304      	str	r3, [sp, #16]
 800b078:	cf08      	ldmia	r7!, {r3}
 800b07a:	9a00      	ldr	r2, [sp, #0]
 800b07c:	b299      	uxth	r1, r3
 800b07e:	4351      	muls	r1, r2
 800b080:	0c1b      	lsrs	r3, r3, #16
 800b082:	4353      	muls	r3, r2
 800b084:	4461      	add	r1, ip
 800b086:	0c0a      	lsrs	r2, r1, #16
 800b088:	189b      	adds	r3, r3, r2
 800b08a:	0c1a      	lsrs	r2, r3, #16
 800b08c:	9305      	str	r3, [sp, #20]
 800b08e:	6803      	ldr	r3, [r0, #0]
 800b090:	4694      	mov	ip, r2
 800b092:	b29a      	uxth	r2, r3
 800b094:	9b04      	ldr	r3, [sp, #16]
 800b096:	b289      	uxth	r1, r1
 800b098:	18d2      	adds	r2, r2, r3
 800b09a:	6803      	ldr	r3, [r0, #0]
 800b09c:	1a52      	subs	r2, r2, r1
 800b09e:	0c19      	lsrs	r1, r3, #16
 800b0a0:	466b      	mov	r3, sp
 800b0a2:	8a9b      	ldrh	r3, [r3, #20]
 800b0a4:	1acb      	subs	r3, r1, r3
 800b0a6:	1411      	asrs	r1, r2, #16
 800b0a8:	185b      	adds	r3, r3, r1
 800b0aa:	1419      	asrs	r1, r3, #16
 800b0ac:	b292      	uxth	r2, r2
 800b0ae:	041b      	lsls	r3, r3, #16
 800b0b0:	431a      	orrs	r2, r3
 800b0b2:	9b03      	ldr	r3, [sp, #12]
 800b0b4:	9104      	str	r1, [sp, #16]
 800b0b6:	c004      	stmia	r0!, {r2}
 800b0b8:	42bb      	cmp	r3, r7
 800b0ba:	d2dd      	bcs.n	800b078 <quorem+0x4e>
 800b0bc:	6823      	ldr	r3, [r4, #0]
 800b0be:	2b00      	cmp	r3, #0
 800b0c0:	d02e      	beq.n	800b120 <quorem+0xf6>
 800b0c2:	0030      	movs	r0, r6
 800b0c4:	9902      	ldr	r1, [sp, #8]
 800b0c6:	f7ff faaf 	bl	800a628 <__mcmp>
 800b0ca:	2800      	cmp	r0, #0
 800b0cc:	db21      	blt.n	800b112 <quorem+0xe8>
 800b0ce:	0030      	movs	r0, r6
 800b0d0:	2400      	movs	r4, #0
 800b0d2:	9b00      	ldr	r3, [sp, #0]
 800b0d4:	9902      	ldr	r1, [sp, #8]
 800b0d6:	3301      	adds	r3, #1
 800b0d8:	9300      	str	r3, [sp, #0]
 800b0da:	3014      	adds	r0, #20
 800b0dc:	3114      	adds	r1, #20
 800b0de:	6802      	ldr	r2, [r0, #0]
 800b0e0:	c908      	ldmia	r1!, {r3}
 800b0e2:	b292      	uxth	r2, r2
 800b0e4:	1914      	adds	r4, r2, r4
 800b0e6:	b29a      	uxth	r2, r3
 800b0e8:	1aa2      	subs	r2, r4, r2
 800b0ea:	6804      	ldr	r4, [r0, #0]
 800b0ec:	0c1b      	lsrs	r3, r3, #16
 800b0ee:	0c24      	lsrs	r4, r4, #16
 800b0f0:	1ae3      	subs	r3, r4, r3
 800b0f2:	1414      	asrs	r4, r2, #16
 800b0f4:	191b      	adds	r3, r3, r4
 800b0f6:	141c      	asrs	r4, r3, #16
 800b0f8:	b292      	uxth	r2, r2
 800b0fa:	041b      	lsls	r3, r3, #16
 800b0fc:	4313      	orrs	r3, r2
 800b0fe:	c008      	stmia	r0!, {r3}
 800b100:	9b03      	ldr	r3, [sp, #12]
 800b102:	428b      	cmp	r3, r1
 800b104:	d2eb      	bcs.n	800b0de <quorem+0xb4>
 800b106:	9a01      	ldr	r2, [sp, #4]
 800b108:	00ab      	lsls	r3, r5, #2
 800b10a:	18d3      	adds	r3, r2, r3
 800b10c:	681a      	ldr	r2, [r3, #0]
 800b10e:	2a00      	cmp	r2, #0
 800b110:	d010      	beq.n	800b134 <quorem+0x10a>
 800b112:	9800      	ldr	r0, [sp, #0]
 800b114:	b007      	add	sp, #28
 800b116:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800b118:	6823      	ldr	r3, [r4, #0]
 800b11a:	2b00      	cmp	r3, #0
 800b11c:	d104      	bne.n	800b128 <quorem+0xfe>
 800b11e:	3d01      	subs	r5, #1
 800b120:	9b01      	ldr	r3, [sp, #4]
 800b122:	3c04      	subs	r4, #4
 800b124:	42a3      	cmp	r3, r4
 800b126:	d3f7      	bcc.n	800b118 <quorem+0xee>
 800b128:	6135      	str	r5, [r6, #16]
 800b12a:	e7ca      	b.n	800b0c2 <quorem+0x98>
 800b12c:	681a      	ldr	r2, [r3, #0]
 800b12e:	2a00      	cmp	r2, #0
 800b130:	d104      	bne.n	800b13c <quorem+0x112>
 800b132:	3d01      	subs	r5, #1
 800b134:	9a01      	ldr	r2, [sp, #4]
 800b136:	3b04      	subs	r3, #4
 800b138:	429a      	cmp	r2, r3
 800b13a:	d3f7      	bcc.n	800b12c <quorem+0x102>
 800b13c:	6135      	str	r5, [r6, #16]
 800b13e:	e7e8      	b.n	800b112 <quorem+0xe8>

0800b140 <_dtoa_r>:
 800b140:	b5f0      	push	{r4, r5, r6, r7, lr}
 800b142:	b09d      	sub	sp, #116	; 0x74
 800b144:	9202      	str	r2, [sp, #8]
 800b146:	9303      	str	r3, [sp, #12]
 800b148:	9b02      	ldr	r3, [sp, #8]
 800b14a:	9c03      	ldr	r4, [sp, #12]
 800b14c:	930a      	str	r3, [sp, #40]	; 0x28
 800b14e:	940b      	str	r4, [sp, #44]	; 0x2c
 800b150:	6a44      	ldr	r4, [r0, #36]	; 0x24
 800b152:	0007      	movs	r7, r0
 800b154:	9d25      	ldr	r5, [sp, #148]	; 0x94
 800b156:	2c00      	cmp	r4, #0
 800b158:	d10e      	bne.n	800b178 <_dtoa_r+0x38>
 800b15a:	2010      	movs	r0, #16
 800b15c:	f7fe fd86 	bl	8009c6c <malloc>
 800b160:	1e02      	subs	r2, r0, #0
 800b162:	6278      	str	r0, [r7, #36]	; 0x24
 800b164:	d104      	bne.n	800b170 <_dtoa_r+0x30>
 800b166:	21ea      	movs	r1, #234	; 0xea
 800b168:	4bc0      	ldr	r3, [pc, #768]	; (800b46c <_dtoa_r+0x32c>)
 800b16a:	48c1      	ldr	r0, [pc, #772]	; (800b470 <_dtoa_r+0x330>)
 800b16c:	f7fe fe4a 	bl	8009e04 <__assert_func>
 800b170:	6044      	str	r4, [r0, #4]
 800b172:	6084      	str	r4, [r0, #8]
 800b174:	6004      	str	r4, [r0, #0]
 800b176:	60c4      	str	r4, [r0, #12]
 800b178:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 800b17a:	6819      	ldr	r1, [r3, #0]
 800b17c:	2900      	cmp	r1, #0
 800b17e:	d00a      	beq.n	800b196 <_dtoa_r+0x56>
 800b180:	685a      	ldr	r2, [r3, #4]
 800b182:	2301      	movs	r3, #1
 800b184:	4093      	lsls	r3, r2
 800b186:	604a      	str	r2, [r1, #4]
 800b188:	608b      	str	r3, [r1, #8]
 800b18a:	0038      	movs	r0, r7
 800b18c:	f7ff f80a 	bl	800a1a4 <_Bfree>
 800b190:	2200      	movs	r2, #0
 800b192:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 800b194:	601a      	str	r2, [r3, #0]
 800b196:	9b03      	ldr	r3, [sp, #12]
 800b198:	2b00      	cmp	r3, #0
 800b19a:	da21      	bge.n	800b1e0 <_dtoa_r+0xa0>
 800b19c:	2301      	movs	r3, #1
 800b19e:	602b      	str	r3, [r5, #0]
 800b1a0:	9b03      	ldr	r3, [sp, #12]
 800b1a2:	005b      	lsls	r3, r3, #1
 800b1a4:	085b      	lsrs	r3, r3, #1
 800b1a6:	930b      	str	r3, [sp, #44]	; 0x2c
 800b1a8:	9d0b      	ldr	r5, [sp, #44]	; 0x2c
 800b1aa:	4bb2      	ldr	r3, [pc, #712]	; (800b474 <_dtoa_r+0x334>)
 800b1ac:	002a      	movs	r2, r5
 800b1ae:	9318      	str	r3, [sp, #96]	; 0x60
 800b1b0:	401a      	ands	r2, r3
 800b1b2:	429a      	cmp	r2, r3
 800b1b4:	d117      	bne.n	800b1e6 <_dtoa_r+0xa6>
 800b1b6:	4bb0      	ldr	r3, [pc, #704]	; (800b478 <_dtoa_r+0x338>)
 800b1b8:	9a24      	ldr	r2, [sp, #144]	; 0x90
 800b1ba:	0328      	lsls	r0, r5, #12
 800b1bc:	6013      	str	r3, [r2, #0]
 800b1be:	9b02      	ldr	r3, [sp, #8]
 800b1c0:	0b00      	lsrs	r0, r0, #12
 800b1c2:	4318      	orrs	r0, r3
 800b1c4:	d101      	bne.n	800b1ca <_dtoa_r+0x8a>
 800b1c6:	f000 fdc3 	bl	800bd50 <_dtoa_r+0xc10>
 800b1ca:	48ac      	ldr	r0, [pc, #688]	; (800b47c <_dtoa_r+0x33c>)
 800b1cc:	9b26      	ldr	r3, [sp, #152]	; 0x98
 800b1ce:	9005      	str	r0, [sp, #20]
 800b1d0:	2b00      	cmp	r3, #0
 800b1d2:	d002      	beq.n	800b1da <_dtoa_r+0x9a>
 800b1d4:	4baa      	ldr	r3, [pc, #680]	; (800b480 <_dtoa_r+0x340>)
 800b1d6:	9a26      	ldr	r2, [sp, #152]	; 0x98
 800b1d8:	6013      	str	r3, [r2, #0]
 800b1da:	9805      	ldr	r0, [sp, #20]
 800b1dc:	b01d      	add	sp, #116	; 0x74
 800b1de:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800b1e0:	2300      	movs	r3, #0
 800b1e2:	602b      	str	r3, [r5, #0]
 800b1e4:	e7e0      	b.n	800b1a8 <_dtoa_r+0x68>
 800b1e6:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 800b1e8:	9c0b      	ldr	r4, [sp, #44]	; 0x2c
 800b1ea:	9312      	str	r3, [sp, #72]	; 0x48
 800b1ec:	9413      	str	r4, [sp, #76]	; 0x4c
 800b1ee:	9812      	ldr	r0, [sp, #72]	; 0x48
 800b1f0:	9913      	ldr	r1, [sp, #76]	; 0x4c
 800b1f2:	2200      	movs	r2, #0
 800b1f4:	2300      	movs	r3, #0
 800b1f6:	f7f7 fdb3 	bl	8002d60 <__aeabi_dcmpeq>
 800b1fa:	1e04      	subs	r4, r0, #0
 800b1fc:	d00b      	beq.n	800b216 <_dtoa_r+0xd6>
 800b1fe:	2301      	movs	r3, #1
 800b200:	9a24      	ldr	r2, [sp, #144]	; 0x90
 800b202:	6013      	str	r3, [r2, #0]
 800b204:	4b9f      	ldr	r3, [pc, #636]	; (800b484 <_dtoa_r+0x344>)
 800b206:	9a26      	ldr	r2, [sp, #152]	; 0x98
 800b208:	9305      	str	r3, [sp, #20]
 800b20a:	2a00      	cmp	r2, #0
 800b20c:	d0e5      	beq.n	800b1da <_dtoa_r+0x9a>
 800b20e:	4a9e      	ldr	r2, [pc, #632]	; (800b488 <_dtoa_r+0x348>)
 800b210:	9926      	ldr	r1, [sp, #152]	; 0x98
 800b212:	600a      	str	r2, [r1, #0]
 800b214:	e7e1      	b.n	800b1da <_dtoa_r+0x9a>
 800b216:	ab1a      	add	r3, sp, #104	; 0x68
 800b218:	9301      	str	r3, [sp, #4]
 800b21a:	ab1b      	add	r3, sp, #108	; 0x6c
 800b21c:	9300      	str	r3, [sp, #0]
 800b21e:	0038      	movs	r0, r7
 800b220:	9a12      	ldr	r2, [sp, #72]	; 0x48
 800b222:	9b13      	ldr	r3, [sp, #76]	; 0x4c
 800b224:	f7ff fab4 	bl	800a790 <__d2b>
 800b228:	006e      	lsls	r6, r5, #1
 800b22a:	9004      	str	r0, [sp, #16]
 800b22c:	0d76      	lsrs	r6, r6, #21
 800b22e:	d100      	bne.n	800b232 <_dtoa_r+0xf2>
 800b230:	e07c      	b.n	800b32c <_dtoa_r+0x1ec>
 800b232:	9812      	ldr	r0, [sp, #72]	; 0x48
 800b234:	9913      	ldr	r1, [sp, #76]	; 0x4c
 800b236:	9b13      	ldr	r3, [sp, #76]	; 0x4c
 800b238:	4a94      	ldr	r2, [pc, #592]	; (800b48c <_dtoa_r+0x34c>)
 800b23a:	031b      	lsls	r3, r3, #12
 800b23c:	0b1b      	lsrs	r3, r3, #12
 800b23e:	431a      	orrs	r2, r3
 800b240:	0011      	movs	r1, r2
 800b242:	4b93      	ldr	r3, [pc, #588]	; (800b490 <_dtoa_r+0x350>)
 800b244:	9416      	str	r4, [sp, #88]	; 0x58
 800b246:	18f6      	adds	r6, r6, r3
 800b248:	2200      	movs	r2, #0
 800b24a:	4b92      	ldr	r3, [pc, #584]	; (800b494 <_dtoa_r+0x354>)
 800b24c:	f7f7 f8b0 	bl	80023b0 <__aeabi_dsub>
 800b250:	4a91      	ldr	r2, [pc, #580]	; (800b498 <_dtoa_r+0x358>)
 800b252:	4b92      	ldr	r3, [pc, #584]	; (800b49c <_dtoa_r+0x35c>)
 800b254:	f7f6 fe40 	bl	8001ed8 <__aeabi_dmul>
 800b258:	4a91      	ldr	r2, [pc, #580]	; (800b4a0 <_dtoa_r+0x360>)
 800b25a:	4b92      	ldr	r3, [pc, #584]	; (800b4a4 <_dtoa_r+0x364>)
 800b25c:	f7f5 ffea 	bl	8001234 <__aeabi_dadd>
 800b260:	0004      	movs	r4, r0
 800b262:	0030      	movs	r0, r6
 800b264:	000d      	movs	r5, r1
 800b266:	f7f7 fc6b 	bl	8002b40 <__aeabi_i2d>
 800b26a:	4a8f      	ldr	r2, [pc, #572]	; (800b4a8 <_dtoa_r+0x368>)
 800b26c:	4b8f      	ldr	r3, [pc, #572]	; (800b4ac <_dtoa_r+0x36c>)
 800b26e:	f7f6 fe33 	bl	8001ed8 <__aeabi_dmul>
 800b272:	0002      	movs	r2, r0
 800b274:	000b      	movs	r3, r1
 800b276:	0020      	movs	r0, r4
 800b278:	0029      	movs	r1, r5
 800b27a:	f7f5 ffdb 	bl	8001234 <__aeabi_dadd>
 800b27e:	0004      	movs	r4, r0
 800b280:	000d      	movs	r5, r1
 800b282:	f7f7 fc27 	bl	8002ad4 <__aeabi_d2iz>
 800b286:	2200      	movs	r2, #0
 800b288:	9002      	str	r0, [sp, #8]
 800b28a:	2300      	movs	r3, #0
 800b28c:	0020      	movs	r0, r4
 800b28e:	0029      	movs	r1, r5
 800b290:	f7f7 fd6c 	bl	8002d6c <__aeabi_dcmplt>
 800b294:	2800      	cmp	r0, #0
 800b296:	d00b      	beq.n	800b2b0 <_dtoa_r+0x170>
 800b298:	9802      	ldr	r0, [sp, #8]
 800b29a:	f7f7 fc51 	bl	8002b40 <__aeabi_i2d>
 800b29e:	002b      	movs	r3, r5
 800b2a0:	0022      	movs	r2, r4
 800b2a2:	f7f7 fd5d 	bl	8002d60 <__aeabi_dcmpeq>
 800b2a6:	4243      	negs	r3, r0
 800b2a8:	4158      	adcs	r0, r3
 800b2aa:	9b02      	ldr	r3, [sp, #8]
 800b2ac:	1a1b      	subs	r3, r3, r0
 800b2ae:	9302      	str	r3, [sp, #8]
 800b2b0:	2301      	movs	r3, #1
 800b2b2:	9315      	str	r3, [sp, #84]	; 0x54
 800b2b4:	9b02      	ldr	r3, [sp, #8]
 800b2b6:	2b16      	cmp	r3, #22
 800b2b8:	d80f      	bhi.n	800b2da <_dtoa_r+0x19a>
 800b2ba:	9812      	ldr	r0, [sp, #72]	; 0x48
 800b2bc:	9913      	ldr	r1, [sp, #76]	; 0x4c
 800b2be:	00da      	lsls	r2, r3, #3
 800b2c0:	4b7b      	ldr	r3, [pc, #492]	; (800b4b0 <_dtoa_r+0x370>)
 800b2c2:	189b      	adds	r3, r3, r2
 800b2c4:	681a      	ldr	r2, [r3, #0]
 800b2c6:	685b      	ldr	r3, [r3, #4]
 800b2c8:	f7f7 fd50 	bl	8002d6c <__aeabi_dcmplt>
 800b2cc:	2800      	cmp	r0, #0
 800b2ce:	d049      	beq.n	800b364 <_dtoa_r+0x224>
 800b2d0:	9b02      	ldr	r3, [sp, #8]
 800b2d2:	3b01      	subs	r3, #1
 800b2d4:	9302      	str	r3, [sp, #8]
 800b2d6:	2300      	movs	r3, #0
 800b2d8:	9315      	str	r3, [sp, #84]	; 0x54
 800b2da:	9b1a      	ldr	r3, [sp, #104]	; 0x68
 800b2dc:	1b9e      	subs	r6, r3, r6
 800b2de:	2300      	movs	r3, #0
 800b2e0:	9308      	str	r3, [sp, #32]
 800b2e2:	0033      	movs	r3, r6
 800b2e4:	3b01      	subs	r3, #1
 800b2e6:	930d      	str	r3, [sp, #52]	; 0x34
 800b2e8:	d504      	bpl.n	800b2f4 <_dtoa_r+0x1b4>
 800b2ea:	2301      	movs	r3, #1
 800b2ec:	1b9b      	subs	r3, r3, r6
 800b2ee:	9308      	str	r3, [sp, #32]
 800b2f0:	2300      	movs	r3, #0
 800b2f2:	930d      	str	r3, [sp, #52]	; 0x34
 800b2f4:	9b02      	ldr	r3, [sp, #8]
 800b2f6:	2b00      	cmp	r3, #0
 800b2f8:	db36      	blt.n	800b368 <_dtoa_r+0x228>
 800b2fa:	9a02      	ldr	r2, [sp, #8]
 800b2fc:	9b0d      	ldr	r3, [sp, #52]	; 0x34
 800b2fe:	4694      	mov	ip, r2
 800b300:	4463      	add	r3, ip
 800b302:	930d      	str	r3, [sp, #52]	; 0x34
 800b304:	2300      	movs	r3, #0
 800b306:	9214      	str	r2, [sp, #80]	; 0x50
 800b308:	930e      	str	r3, [sp, #56]	; 0x38
 800b30a:	9b22      	ldr	r3, [sp, #136]	; 0x88
 800b30c:	2401      	movs	r4, #1
 800b30e:	2b09      	cmp	r3, #9
 800b310:	d862      	bhi.n	800b3d8 <_dtoa_r+0x298>
 800b312:	2b05      	cmp	r3, #5
 800b314:	dd02      	ble.n	800b31c <_dtoa_r+0x1dc>
 800b316:	2400      	movs	r4, #0
 800b318:	3b04      	subs	r3, #4
 800b31a:	9322      	str	r3, [sp, #136]	; 0x88
 800b31c:	9b22      	ldr	r3, [sp, #136]	; 0x88
 800b31e:	1e98      	subs	r0, r3, #2
 800b320:	2803      	cmp	r0, #3
 800b322:	d862      	bhi.n	800b3ea <_dtoa_r+0x2aa>
 800b324:	f7f7 fe86 	bl	8003034 <__gnu_thumb1_case_uqi>
 800b328:	56343629 	.word	0x56343629
 800b32c:	9b1a      	ldr	r3, [sp, #104]	; 0x68
 800b32e:	9a1b      	ldr	r2, [sp, #108]	; 0x6c
 800b330:	189e      	adds	r6, r3, r2
 800b332:	4b60      	ldr	r3, [pc, #384]	; (800b4b4 <_dtoa_r+0x374>)
 800b334:	18f2      	adds	r2, r6, r3
 800b336:	2a20      	cmp	r2, #32
 800b338:	dd0f      	ble.n	800b35a <_dtoa_r+0x21a>
 800b33a:	2340      	movs	r3, #64	; 0x40
 800b33c:	1a9b      	subs	r3, r3, r2
 800b33e:	409d      	lsls	r5, r3
 800b340:	4b5d      	ldr	r3, [pc, #372]	; (800b4b8 <_dtoa_r+0x378>)
 800b342:	9802      	ldr	r0, [sp, #8]
 800b344:	18f3      	adds	r3, r6, r3
 800b346:	40d8      	lsrs	r0, r3
 800b348:	4328      	orrs	r0, r5
 800b34a:	f7f7 fe87 	bl	800305c <__aeabi_ui2d>
 800b34e:	2301      	movs	r3, #1
 800b350:	4c5a      	ldr	r4, [pc, #360]	; (800b4bc <_dtoa_r+0x37c>)
 800b352:	3e01      	subs	r6, #1
 800b354:	1909      	adds	r1, r1, r4
 800b356:	9316      	str	r3, [sp, #88]	; 0x58
 800b358:	e776      	b.n	800b248 <_dtoa_r+0x108>
 800b35a:	2320      	movs	r3, #32
 800b35c:	9802      	ldr	r0, [sp, #8]
 800b35e:	1a9b      	subs	r3, r3, r2
 800b360:	4098      	lsls	r0, r3
 800b362:	e7f2      	b.n	800b34a <_dtoa_r+0x20a>
 800b364:	9015      	str	r0, [sp, #84]	; 0x54
 800b366:	e7b8      	b.n	800b2da <_dtoa_r+0x19a>
 800b368:	9b08      	ldr	r3, [sp, #32]
 800b36a:	9a02      	ldr	r2, [sp, #8]
 800b36c:	1a9b      	subs	r3, r3, r2
 800b36e:	9308      	str	r3, [sp, #32]
 800b370:	4253      	negs	r3, r2
 800b372:	930e      	str	r3, [sp, #56]	; 0x38
 800b374:	2300      	movs	r3, #0
 800b376:	9314      	str	r3, [sp, #80]	; 0x50
 800b378:	e7c7      	b.n	800b30a <_dtoa_r+0x1ca>
 800b37a:	2300      	movs	r3, #0
 800b37c:	930f      	str	r3, [sp, #60]	; 0x3c
 800b37e:	9b23      	ldr	r3, [sp, #140]	; 0x8c
 800b380:	2b00      	cmp	r3, #0
 800b382:	dc36      	bgt.n	800b3f2 <_dtoa_r+0x2b2>
 800b384:	2301      	movs	r3, #1
 800b386:	001a      	movs	r2, r3
 800b388:	930c      	str	r3, [sp, #48]	; 0x30
 800b38a:	9306      	str	r3, [sp, #24]
 800b38c:	9223      	str	r2, [sp, #140]	; 0x8c
 800b38e:	e00d      	b.n	800b3ac <_dtoa_r+0x26c>
 800b390:	2301      	movs	r3, #1
 800b392:	e7f3      	b.n	800b37c <_dtoa_r+0x23c>
 800b394:	2300      	movs	r3, #0
 800b396:	9a23      	ldr	r2, [sp, #140]	; 0x8c
 800b398:	930f      	str	r3, [sp, #60]	; 0x3c
 800b39a:	4694      	mov	ip, r2
 800b39c:	9b02      	ldr	r3, [sp, #8]
 800b39e:	4463      	add	r3, ip
 800b3a0:	930c      	str	r3, [sp, #48]	; 0x30
 800b3a2:	3301      	adds	r3, #1
 800b3a4:	9306      	str	r3, [sp, #24]
 800b3a6:	2b00      	cmp	r3, #0
 800b3a8:	dc00      	bgt.n	800b3ac <_dtoa_r+0x26c>
 800b3aa:	2301      	movs	r3, #1
 800b3ac:	2200      	movs	r2, #0
 800b3ae:	6a78      	ldr	r0, [r7, #36]	; 0x24
 800b3b0:	6042      	str	r2, [r0, #4]
 800b3b2:	3204      	adds	r2, #4
 800b3b4:	0015      	movs	r5, r2
 800b3b6:	3514      	adds	r5, #20
 800b3b8:	6841      	ldr	r1, [r0, #4]
 800b3ba:	429d      	cmp	r5, r3
 800b3bc:	d91d      	bls.n	800b3fa <_dtoa_r+0x2ba>
 800b3be:	0038      	movs	r0, r7
 800b3c0:	f7fe feac 	bl	800a11c <_Balloc>
 800b3c4:	9005      	str	r0, [sp, #20]
 800b3c6:	2800      	cmp	r0, #0
 800b3c8:	d11b      	bne.n	800b402 <_dtoa_r+0x2c2>
 800b3ca:	21d5      	movs	r1, #213	; 0xd5
 800b3cc:	0002      	movs	r2, r0
 800b3ce:	4b3c      	ldr	r3, [pc, #240]	; (800b4c0 <_dtoa_r+0x380>)
 800b3d0:	0049      	lsls	r1, r1, #1
 800b3d2:	e6ca      	b.n	800b16a <_dtoa_r+0x2a>
 800b3d4:	2301      	movs	r3, #1
 800b3d6:	e7de      	b.n	800b396 <_dtoa_r+0x256>
 800b3d8:	2300      	movs	r3, #0
 800b3da:	940f      	str	r4, [sp, #60]	; 0x3c
 800b3dc:	9322      	str	r3, [sp, #136]	; 0x88
 800b3de:	3b01      	subs	r3, #1
 800b3e0:	930c      	str	r3, [sp, #48]	; 0x30
 800b3e2:	9306      	str	r3, [sp, #24]
 800b3e4:	2200      	movs	r2, #0
 800b3e6:	3313      	adds	r3, #19
 800b3e8:	e7d0      	b.n	800b38c <_dtoa_r+0x24c>
 800b3ea:	2301      	movs	r3, #1
 800b3ec:	930f      	str	r3, [sp, #60]	; 0x3c
 800b3ee:	3b02      	subs	r3, #2
 800b3f0:	e7f6      	b.n	800b3e0 <_dtoa_r+0x2a0>
 800b3f2:	9b23      	ldr	r3, [sp, #140]	; 0x8c
 800b3f4:	930c      	str	r3, [sp, #48]	; 0x30
 800b3f6:	9306      	str	r3, [sp, #24]
 800b3f8:	e7d8      	b.n	800b3ac <_dtoa_r+0x26c>
 800b3fa:	3101      	adds	r1, #1
 800b3fc:	6041      	str	r1, [r0, #4]
 800b3fe:	0052      	lsls	r2, r2, #1
 800b400:	e7d8      	b.n	800b3b4 <_dtoa_r+0x274>
 800b402:	6a7b      	ldr	r3, [r7, #36]	; 0x24
 800b404:	9a05      	ldr	r2, [sp, #20]
 800b406:	601a      	str	r2, [r3, #0]
 800b408:	9b06      	ldr	r3, [sp, #24]
 800b40a:	2b0e      	cmp	r3, #14
 800b40c:	d900      	bls.n	800b410 <_dtoa_r+0x2d0>
 800b40e:	e0eb      	b.n	800b5e8 <_dtoa_r+0x4a8>
 800b410:	2c00      	cmp	r4, #0
 800b412:	d100      	bne.n	800b416 <_dtoa_r+0x2d6>
 800b414:	e0e8      	b.n	800b5e8 <_dtoa_r+0x4a8>
 800b416:	9b02      	ldr	r3, [sp, #8]
 800b418:	2b00      	cmp	r3, #0
 800b41a:	dd68      	ble.n	800b4ee <_dtoa_r+0x3ae>
 800b41c:	001a      	movs	r2, r3
 800b41e:	210f      	movs	r1, #15
 800b420:	4b23      	ldr	r3, [pc, #140]	; (800b4b0 <_dtoa_r+0x370>)
 800b422:	400a      	ands	r2, r1
 800b424:	00d2      	lsls	r2, r2, #3
 800b426:	189b      	adds	r3, r3, r2
 800b428:	681d      	ldr	r5, [r3, #0]
 800b42a:	685e      	ldr	r6, [r3, #4]
 800b42c:	9b02      	ldr	r3, [sp, #8]
 800b42e:	111c      	asrs	r4, r3, #4
 800b430:	2302      	movs	r3, #2
 800b432:	9310      	str	r3, [sp, #64]	; 0x40
 800b434:	9b02      	ldr	r3, [sp, #8]
 800b436:	05db      	lsls	r3, r3, #23
 800b438:	d50b      	bpl.n	800b452 <_dtoa_r+0x312>
 800b43a:	4b22      	ldr	r3, [pc, #136]	; (800b4c4 <_dtoa_r+0x384>)
 800b43c:	400c      	ands	r4, r1
 800b43e:	6a1a      	ldr	r2, [r3, #32]
 800b440:	6a5b      	ldr	r3, [r3, #36]	; 0x24
 800b442:	9812      	ldr	r0, [sp, #72]	; 0x48
 800b444:	9913      	ldr	r1, [sp, #76]	; 0x4c
 800b446:	f7f6 fa5f 	bl	8001908 <__aeabi_ddiv>
 800b44a:	2303      	movs	r3, #3
 800b44c:	900a      	str	r0, [sp, #40]	; 0x28
 800b44e:	910b      	str	r1, [sp, #44]	; 0x2c
 800b450:	9310      	str	r3, [sp, #64]	; 0x40
 800b452:	4b1c      	ldr	r3, [pc, #112]	; (800b4c4 <_dtoa_r+0x384>)
 800b454:	9307      	str	r3, [sp, #28]
 800b456:	2c00      	cmp	r4, #0
 800b458:	d136      	bne.n	800b4c8 <_dtoa_r+0x388>
 800b45a:	980a      	ldr	r0, [sp, #40]	; 0x28
 800b45c:	990b      	ldr	r1, [sp, #44]	; 0x2c
 800b45e:	002a      	movs	r2, r5
 800b460:	0033      	movs	r3, r6
 800b462:	f7f6 fa51 	bl	8001908 <__aeabi_ddiv>
 800b466:	900a      	str	r0, [sp, #40]	; 0x28
 800b468:	910b      	str	r1, [sp, #44]	; 0x2c
 800b46a:	e05c      	b.n	800b526 <_dtoa_r+0x3e6>
 800b46c:	0800f0f4 	.word	0x0800f0f4
 800b470:	0800f2be 	.word	0x0800f2be
 800b474:	7ff00000 	.word	0x7ff00000
 800b478:	0000270f 	.word	0x0000270f
 800b47c:	0800f2b8 	.word	0x0800f2b8
 800b480:	0800f2bb 	.word	0x0800f2bb
 800b484:	0800f2bc 	.word	0x0800f2bc
 800b488:	0800f2bd 	.word	0x0800f2bd
 800b48c:	3ff00000 	.word	0x3ff00000
 800b490:	fffffc01 	.word	0xfffffc01
 800b494:	3ff80000 	.word	0x3ff80000
 800b498:	636f4361 	.word	0x636f4361
 800b49c:	3fd287a7 	.word	0x3fd287a7
 800b4a0:	8b60c8b3 	.word	0x8b60c8b3
 800b4a4:	3fc68a28 	.word	0x3fc68a28
 800b4a8:	509f79fb 	.word	0x509f79fb
 800b4ac:	3fd34413 	.word	0x3fd34413
 800b4b0:	0800f1a8 	.word	0x0800f1a8
 800b4b4:	00000432 	.word	0x00000432
 800b4b8:	00000412 	.word	0x00000412
 800b4bc:	fe100000 	.word	0xfe100000
 800b4c0:	0800f16b 	.word	0x0800f16b
 800b4c4:	0800f180 	.word	0x0800f180
 800b4c8:	2301      	movs	r3, #1
 800b4ca:	421c      	tst	r4, r3
 800b4cc:	d00b      	beq.n	800b4e6 <_dtoa_r+0x3a6>
 800b4ce:	9b10      	ldr	r3, [sp, #64]	; 0x40
 800b4d0:	0028      	movs	r0, r5
 800b4d2:	3301      	adds	r3, #1
 800b4d4:	9310      	str	r3, [sp, #64]	; 0x40
 800b4d6:	9b07      	ldr	r3, [sp, #28]
 800b4d8:	0031      	movs	r1, r6
 800b4da:	681a      	ldr	r2, [r3, #0]
 800b4dc:	685b      	ldr	r3, [r3, #4]
 800b4de:	f7f6 fcfb 	bl	8001ed8 <__aeabi_dmul>
 800b4e2:	0005      	movs	r5, r0
 800b4e4:	000e      	movs	r6, r1
 800b4e6:	9b07      	ldr	r3, [sp, #28]
 800b4e8:	1064      	asrs	r4, r4, #1
 800b4ea:	3308      	adds	r3, #8
 800b4ec:	e7b2      	b.n	800b454 <_dtoa_r+0x314>
 800b4ee:	2302      	movs	r3, #2
 800b4f0:	9310      	str	r3, [sp, #64]	; 0x40
 800b4f2:	9b02      	ldr	r3, [sp, #8]
 800b4f4:	2b00      	cmp	r3, #0
 800b4f6:	d016      	beq.n	800b526 <_dtoa_r+0x3e6>
 800b4f8:	9812      	ldr	r0, [sp, #72]	; 0x48
 800b4fa:	9913      	ldr	r1, [sp, #76]	; 0x4c
 800b4fc:	425c      	negs	r4, r3
 800b4fe:	230f      	movs	r3, #15
 800b500:	4ab5      	ldr	r2, [pc, #724]	; (800b7d8 <_dtoa_r+0x698>)
 800b502:	4023      	ands	r3, r4
 800b504:	00db      	lsls	r3, r3, #3
 800b506:	18d3      	adds	r3, r2, r3
 800b508:	681a      	ldr	r2, [r3, #0]
 800b50a:	685b      	ldr	r3, [r3, #4]
 800b50c:	f7f6 fce4 	bl	8001ed8 <__aeabi_dmul>
 800b510:	2601      	movs	r6, #1
 800b512:	2300      	movs	r3, #0
 800b514:	900a      	str	r0, [sp, #40]	; 0x28
 800b516:	910b      	str	r1, [sp, #44]	; 0x2c
 800b518:	4db0      	ldr	r5, [pc, #704]	; (800b7dc <_dtoa_r+0x69c>)
 800b51a:	1124      	asrs	r4, r4, #4
 800b51c:	2c00      	cmp	r4, #0
 800b51e:	d000      	beq.n	800b522 <_dtoa_r+0x3e2>
 800b520:	e094      	b.n	800b64c <_dtoa_r+0x50c>
 800b522:	2b00      	cmp	r3, #0
 800b524:	d19f      	bne.n	800b466 <_dtoa_r+0x326>
 800b526:	9b15      	ldr	r3, [sp, #84]	; 0x54
 800b528:	2b00      	cmp	r3, #0
 800b52a:	d100      	bne.n	800b52e <_dtoa_r+0x3ee>
 800b52c:	e09b      	b.n	800b666 <_dtoa_r+0x526>
 800b52e:	9c0a      	ldr	r4, [sp, #40]	; 0x28
 800b530:	9d0b      	ldr	r5, [sp, #44]	; 0x2c
 800b532:	2200      	movs	r2, #0
 800b534:	0020      	movs	r0, r4
 800b536:	0029      	movs	r1, r5
 800b538:	4ba9      	ldr	r3, [pc, #676]	; (800b7e0 <_dtoa_r+0x6a0>)
 800b53a:	f7f7 fc17 	bl	8002d6c <__aeabi_dcmplt>
 800b53e:	2800      	cmp	r0, #0
 800b540:	d100      	bne.n	800b544 <_dtoa_r+0x404>
 800b542:	e090      	b.n	800b666 <_dtoa_r+0x526>
 800b544:	9b06      	ldr	r3, [sp, #24]
 800b546:	2b00      	cmp	r3, #0
 800b548:	d100      	bne.n	800b54c <_dtoa_r+0x40c>
 800b54a:	e08c      	b.n	800b666 <_dtoa_r+0x526>
 800b54c:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 800b54e:	2b00      	cmp	r3, #0
 800b550:	dd46      	ble.n	800b5e0 <_dtoa_r+0x4a0>
 800b552:	9b02      	ldr	r3, [sp, #8]
 800b554:	2200      	movs	r2, #0
 800b556:	0020      	movs	r0, r4
 800b558:	0029      	movs	r1, r5
 800b55a:	1e5e      	subs	r6, r3, #1
 800b55c:	4ba1      	ldr	r3, [pc, #644]	; (800b7e4 <_dtoa_r+0x6a4>)
 800b55e:	f7f6 fcbb 	bl	8001ed8 <__aeabi_dmul>
 800b562:	9b10      	ldr	r3, [sp, #64]	; 0x40
 800b564:	900a      	str	r0, [sp, #40]	; 0x28
 800b566:	910b      	str	r1, [sp, #44]	; 0x2c
 800b568:	3301      	adds	r3, #1
 800b56a:	9310      	str	r3, [sp, #64]	; 0x40
 800b56c:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 800b56e:	9810      	ldr	r0, [sp, #64]	; 0x40
 800b570:	9c0a      	ldr	r4, [sp, #40]	; 0x28
 800b572:	9d0b      	ldr	r5, [sp, #44]	; 0x2c
 800b574:	9307      	str	r3, [sp, #28]
 800b576:	f7f7 fae3 	bl	8002b40 <__aeabi_i2d>
 800b57a:	0022      	movs	r2, r4
 800b57c:	002b      	movs	r3, r5
 800b57e:	f7f6 fcab 	bl	8001ed8 <__aeabi_dmul>
 800b582:	2200      	movs	r2, #0
 800b584:	4b98      	ldr	r3, [pc, #608]	; (800b7e8 <_dtoa_r+0x6a8>)
 800b586:	f7f5 fe55 	bl	8001234 <__aeabi_dadd>
 800b58a:	9010      	str	r0, [sp, #64]	; 0x40
 800b58c:	9111      	str	r1, [sp, #68]	; 0x44
 800b58e:	9a10      	ldr	r2, [sp, #64]	; 0x40
 800b590:	9b11      	ldr	r3, [sp, #68]	; 0x44
 800b592:	920a      	str	r2, [sp, #40]	; 0x28
 800b594:	930b      	str	r3, [sp, #44]	; 0x2c
 800b596:	4a95      	ldr	r2, [pc, #596]	; (800b7ec <_dtoa_r+0x6ac>)
 800b598:	9b11      	ldr	r3, [sp, #68]	; 0x44
 800b59a:	4694      	mov	ip, r2
 800b59c:	4463      	add	r3, ip
 800b59e:	9317      	str	r3, [sp, #92]	; 0x5c
 800b5a0:	930b      	str	r3, [sp, #44]	; 0x2c
 800b5a2:	9b07      	ldr	r3, [sp, #28]
 800b5a4:	2b00      	cmp	r3, #0
 800b5a6:	d161      	bne.n	800b66c <_dtoa_r+0x52c>
 800b5a8:	2200      	movs	r2, #0
 800b5aa:	0020      	movs	r0, r4
 800b5ac:	0029      	movs	r1, r5
 800b5ae:	4b90      	ldr	r3, [pc, #576]	; (800b7f0 <_dtoa_r+0x6b0>)
 800b5b0:	f7f6 fefe 	bl	80023b0 <__aeabi_dsub>
 800b5b4:	9a0a      	ldr	r2, [sp, #40]	; 0x28
 800b5b6:	9b17      	ldr	r3, [sp, #92]	; 0x5c
 800b5b8:	0004      	movs	r4, r0
 800b5ba:	000d      	movs	r5, r1
 800b5bc:	f7f7 fbea 	bl	8002d94 <__aeabi_dcmpgt>
 800b5c0:	2800      	cmp	r0, #0
 800b5c2:	d000      	beq.n	800b5c6 <_dtoa_r+0x486>
 800b5c4:	e2b5      	b.n	800bb32 <_dtoa_r+0x9f2>
 800b5c6:	488b      	ldr	r0, [pc, #556]	; (800b7f4 <_dtoa_r+0x6b4>)
 800b5c8:	9911      	ldr	r1, [sp, #68]	; 0x44
 800b5ca:	4684      	mov	ip, r0
 800b5cc:	4461      	add	r1, ip
 800b5ce:	000b      	movs	r3, r1
 800b5d0:	0020      	movs	r0, r4
 800b5d2:	0029      	movs	r1, r5
 800b5d4:	9a0a      	ldr	r2, [sp, #40]	; 0x28
 800b5d6:	f7f7 fbc9 	bl	8002d6c <__aeabi_dcmplt>
 800b5da:	2800      	cmp	r0, #0
 800b5dc:	d000      	beq.n	800b5e0 <_dtoa_r+0x4a0>
 800b5de:	e2a5      	b.n	800bb2c <_dtoa_r+0x9ec>
 800b5e0:	9b12      	ldr	r3, [sp, #72]	; 0x48
 800b5e2:	9c13      	ldr	r4, [sp, #76]	; 0x4c
 800b5e4:	930a      	str	r3, [sp, #40]	; 0x28
 800b5e6:	940b      	str	r4, [sp, #44]	; 0x2c
 800b5e8:	9b1b      	ldr	r3, [sp, #108]	; 0x6c
 800b5ea:	2b00      	cmp	r3, #0
 800b5ec:	da00      	bge.n	800b5f0 <_dtoa_r+0x4b0>
 800b5ee:	e171      	b.n	800b8d4 <_dtoa_r+0x794>
 800b5f0:	9a02      	ldr	r2, [sp, #8]
 800b5f2:	2a0e      	cmp	r2, #14
 800b5f4:	dd00      	ble.n	800b5f8 <_dtoa_r+0x4b8>
 800b5f6:	e16d      	b.n	800b8d4 <_dtoa_r+0x794>
 800b5f8:	4b77      	ldr	r3, [pc, #476]	; (800b7d8 <_dtoa_r+0x698>)
 800b5fa:	00d2      	lsls	r2, r2, #3
 800b5fc:	189b      	adds	r3, r3, r2
 800b5fe:	685c      	ldr	r4, [r3, #4]
 800b600:	681b      	ldr	r3, [r3, #0]
 800b602:	9308      	str	r3, [sp, #32]
 800b604:	9409      	str	r4, [sp, #36]	; 0x24
 800b606:	9b23      	ldr	r3, [sp, #140]	; 0x8c
 800b608:	2b00      	cmp	r3, #0
 800b60a:	db00      	blt.n	800b60e <_dtoa_r+0x4ce>
 800b60c:	e0f6      	b.n	800b7fc <_dtoa_r+0x6bc>
 800b60e:	9b06      	ldr	r3, [sp, #24]
 800b610:	2b00      	cmp	r3, #0
 800b612:	dd00      	ble.n	800b616 <_dtoa_r+0x4d6>
 800b614:	e0f2      	b.n	800b7fc <_dtoa_r+0x6bc>
 800b616:	d000      	beq.n	800b61a <_dtoa_r+0x4da>
 800b618:	e288      	b.n	800bb2c <_dtoa_r+0x9ec>
 800b61a:	9808      	ldr	r0, [sp, #32]
 800b61c:	9909      	ldr	r1, [sp, #36]	; 0x24
 800b61e:	2200      	movs	r2, #0
 800b620:	4b73      	ldr	r3, [pc, #460]	; (800b7f0 <_dtoa_r+0x6b0>)
 800b622:	f7f6 fc59 	bl	8001ed8 <__aeabi_dmul>
 800b626:	9a0a      	ldr	r2, [sp, #40]	; 0x28
 800b628:	9b0b      	ldr	r3, [sp, #44]	; 0x2c
 800b62a:	f7f7 fbbd 	bl	8002da8 <__aeabi_dcmpge>
 800b62e:	9e06      	ldr	r6, [sp, #24]
 800b630:	0035      	movs	r5, r6
 800b632:	2800      	cmp	r0, #0
 800b634:	d000      	beq.n	800b638 <_dtoa_r+0x4f8>
 800b636:	e25f      	b.n	800baf8 <_dtoa_r+0x9b8>
 800b638:	9b05      	ldr	r3, [sp, #20]
 800b63a:	9a05      	ldr	r2, [sp, #20]
 800b63c:	3301      	adds	r3, #1
 800b63e:	9307      	str	r3, [sp, #28]
 800b640:	2331      	movs	r3, #49	; 0x31
 800b642:	7013      	strb	r3, [r2, #0]
 800b644:	9b02      	ldr	r3, [sp, #8]
 800b646:	3301      	adds	r3, #1
 800b648:	9302      	str	r3, [sp, #8]
 800b64a:	e25a      	b.n	800bb02 <_dtoa_r+0x9c2>
 800b64c:	4234      	tst	r4, r6
 800b64e:	d007      	beq.n	800b660 <_dtoa_r+0x520>
 800b650:	9b10      	ldr	r3, [sp, #64]	; 0x40
 800b652:	3301      	adds	r3, #1
 800b654:	9310      	str	r3, [sp, #64]	; 0x40
 800b656:	682a      	ldr	r2, [r5, #0]
 800b658:	686b      	ldr	r3, [r5, #4]
 800b65a:	f7f6 fc3d 	bl	8001ed8 <__aeabi_dmul>
 800b65e:	0033      	movs	r3, r6
 800b660:	1064      	asrs	r4, r4, #1
 800b662:	3508      	adds	r5, #8
 800b664:	e75a      	b.n	800b51c <_dtoa_r+0x3dc>
 800b666:	9e02      	ldr	r6, [sp, #8]
 800b668:	9b06      	ldr	r3, [sp, #24]
 800b66a:	e780      	b.n	800b56e <_dtoa_r+0x42e>
 800b66c:	9b07      	ldr	r3, [sp, #28]
 800b66e:	990f      	ldr	r1, [sp, #60]	; 0x3c
 800b670:	1e5a      	subs	r2, r3, #1
 800b672:	4b59      	ldr	r3, [pc, #356]	; (800b7d8 <_dtoa_r+0x698>)
 800b674:	00d2      	lsls	r2, r2, #3
 800b676:	189b      	adds	r3, r3, r2
 800b678:	681a      	ldr	r2, [r3, #0]
 800b67a:	685b      	ldr	r3, [r3, #4]
 800b67c:	2900      	cmp	r1, #0
 800b67e:	d051      	beq.n	800b724 <_dtoa_r+0x5e4>
 800b680:	2000      	movs	r0, #0
 800b682:	495d      	ldr	r1, [pc, #372]	; (800b7f8 <_dtoa_r+0x6b8>)
 800b684:	f7f6 f940 	bl	8001908 <__aeabi_ddiv>
 800b688:	9a0a      	ldr	r2, [sp, #40]	; 0x28
 800b68a:	9b0b      	ldr	r3, [sp, #44]	; 0x2c
 800b68c:	f7f6 fe90 	bl	80023b0 <__aeabi_dsub>
 800b690:	9a05      	ldr	r2, [sp, #20]
 800b692:	9b05      	ldr	r3, [sp, #20]
 800b694:	4694      	mov	ip, r2
 800b696:	9310      	str	r3, [sp, #64]	; 0x40
 800b698:	9b07      	ldr	r3, [sp, #28]
 800b69a:	900a      	str	r0, [sp, #40]	; 0x28
 800b69c:	910b      	str	r1, [sp, #44]	; 0x2c
 800b69e:	4463      	add	r3, ip
 800b6a0:	9319      	str	r3, [sp, #100]	; 0x64
 800b6a2:	0029      	movs	r1, r5
 800b6a4:	0020      	movs	r0, r4
 800b6a6:	f7f7 fa15 	bl	8002ad4 <__aeabi_d2iz>
 800b6aa:	9017      	str	r0, [sp, #92]	; 0x5c
 800b6ac:	f7f7 fa48 	bl	8002b40 <__aeabi_i2d>
 800b6b0:	0002      	movs	r2, r0
 800b6b2:	000b      	movs	r3, r1
 800b6b4:	0020      	movs	r0, r4
 800b6b6:	0029      	movs	r1, r5
 800b6b8:	f7f6 fe7a 	bl	80023b0 <__aeabi_dsub>
 800b6bc:	9b10      	ldr	r3, [sp, #64]	; 0x40
 800b6be:	9a10      	ldr	r2, [sp, #64]	; 0x40
 800b6c0:	3301      	adds	r3, #1
 800b6c2:	9307      	str	r3, [sp, #28]
 800b6c4:	9b17      	ldr	r3, [sp, #92]	; 0x5c
 800b6c6:	0004      	movs	r4, r0
 800b6c8:	3330      	adds	r3, #48	; 0x30
 800b6ca:	7013      	strb	r3, [r2, #0]
 800b6cc:	9a0a      	ldr	r2, [sp, #40]	; 0x28
 800b6ce:	9b0b      	ldr	r3, [sp, #44]	; 0x2c
 800b6d0:	000d      	movs	r5, r1
 800b6d2:	f7f7 fb4b 	bl	8002d6c <__aeabi_dcmplt>
 800b6d6:	2800      	cmp	r0, #0
 800b6d8:	d175      	bne.n	800b7c6 <_dtoa_r+0x686>
 800b6da:	0022      	movs	r2, r4
 800b6dc:	002b      	movs	r3, r5
 800b6de:	2000      	movs	r0, #0
 800b6e0:	493f      	ldr	r1, [pc, #252]	; (800b7e0 <_dtoa_r+0x6a0>)
 800b6e2:	f7f6 fe65 	bl	80023b0 <__aeabi_dsub>
 800b6e6:	9a0a      	ldr	r2, [sp, #40]	; 0x28
 800b6e8:	9b0b      	ldr	r3, [sp, #44]	; 0x2c
 800b6ea:	f7f7 fb3f 	bl	8002d6c <__aeabi_dcmplt>
 800b6ee:	2800      	cmp	r0, #0
 800b6f0:	d000      	beq.n	800b6f4 <_dtoa_r+0x5b4>
 800b6f2:	e0d1      	b.n	800b898 <_dtoa_r+0x758>
 800b6f4:	9b19      	ldr	r3, [sp, #100]	; 0x64
 800b6f6:	9a07      	ldr	r2, [sp, #28]
 800b6f8:	4293      	cmp	r3, r2
 800b6fa:	d100      	bne.n	800b6fe <_dtoa_r+0x5be>
 800b6fc:	e770      	b.n	800b5e0 <_dtoa_r+0x4a0>
 800b6fe:	980a      	ldr	r0, [sp, #40]	; 0x28
 800b700:	990b      	ldr	r1, [sp, #44]	; 0x2c
 800b702:	2200      	movs	r2, #0
 800b704:	4b37      	ldr	r3, [pc, #220]	; (800b7e4 <_dtoa_r+0x6a4>)
 800b706:	f7f6 fbe7 	bl	8001ed8 <__aeabi_dmul>
 800b70a:	4b36      	ldr	r3, [pc, #216]	; (800b7e4 <_dtoa_r+0x6a4>)
 800b70c:	900a      	str	r0, [sp, #40]	; 0x28
 800b70e:	910b      	str	r1, [sp, #44]	; 0x2c
 800b710:	2200      	movs	r2, #0
 800b712:	0020      	movs	r0, r4
 800b714:	0029      	movs	r1, r5
 800b716:	f7f6 fbdf 	bl	8001ed8 <__aeabi_dmul>
 800b71a:	9b07      	ldr	r3, [sp, #28]
 800b71c:	0004      	movs	r4, r0
 800b71e:	000d      	movs	r5, r1
 800b720:	9310      	str	r3, [sp, #64]	; 0x40
 800b722:	e7be      	b.n	800b6a2 <_dtoa_r+0x562>
 800b724:	980a      	ldr	r0, [sp, #40]	; 0x28
 800b726:	990b      	ldr	r1, [sp, #44]	; 0x2c
 800b728:	f7f6 fbd6 	bl	8001ed8 <__aeabi_dmul>
 800b72c:	9a05      	ldr	r2, [sp, #20]
 800b72e:	9b05      	ldr	r3, [sp, #20]
 800b730:	4694      	mov	ip, r2
 800b732:	930a      	str	r3, [sp, #40]	; 0x28
 800b734:	9b07      	ldr	r3, [sp, #28]
 800b736:	9010      	str	r0, [sp, #64]	; 0x40
 800b738:	9111      	str	r1, [sp, #68]	; 0x44
 800b73a:	4463      	add	r3, ip
 800b73c:	9319      	str	r3, [sp, #100]	; 0x64
 800b73e:	0029      	movs	r1, r5
 800b740:	0020      	movs	r0, r4
 800b742:	f7f7 f9c7 	bl	8002ad4 <__aeabi_d2iz>
 800b746:	9017      	str	r0, [sp, #92]	; 0x5c
 800b748:	f7f7 f9fa 	bl	8002b40 <__aeabi_i2d>
 800b74c:	0002      	movs	r2, r0
 800b74e:	000b      	movs	r3, r1
 800b750:	0020      	movs	r0, r4
 800b752:	0029      	movs	r1, r5
 800b754:	f7f6 fe2c 	bl	80023b0 <__aeabi_dsub>
 800b758:	9b17      	ldr	r3, [sp, #92]	; 0x5c
 800b75a:	9a0a      	ldr	r2, [sp, #40]	; 0x28
 800b75c:	3330      	adds	r3, #48	; 0x30
 800b75e:	7013      	strb	r3, [r2, #0]
 800b760:	0013      	movs	r3, r2
 800b762:	9a19      	ldr	r2, [sp, #100]	; 0x64
 800b764:	3301      	adds	r3, #1
 800b766:	0004      	movs	r4, r0
 800b768:	000d      	movs	r5, r1
 800b76a:	930a      	str	r3, [sp, #40]	; 0x28
 800b76c:	4293      	cmp	r3, r2
 800b76e:	d12c      	bne.n	800b7ca <_dtoa_r+0x68a>
 800b770:	9810      	ldr	r0, [sp, #64]	; 0x40
 800b772:	9911      	ldr	r1, [sp, #68]	; 0x44
 800b774:	9a05      	ldr	r2, [sp, #20]
 800b776:	9b07      	ldr	r3, [sp, #28]
 800b778:	4694      	mov	ip, r2
 800b77a:	4463      	add	r3, ip
 800b77c:	2200      	movs	r2, #0
 800b77e:	9307      	str	r3, [sp, #28]
 800b780:	4b1d      	ldr	r3, [pc, #116]	; (800b7f8 <_dtoa_r+0x6b8>)
 800b782:	f7f5 fd57 	bl	8001234 <__aeabi_dadd>
 800b786:	0002      	movs	r2, r0
 800b788:	000b      	movs	r3, r1
 800b78a:	0020      	movs	r0, r4
 800b78c:	0029      	movs	r1, r5
 800b78e:	f7f7 fb01 	bl	8002d94 <__aeabi_dcmpgt>
 800b792:	2800      	cmp	r0, #0
 800b794:	d000      	beq.n	800b798 <_dtoa_r+0x658>
 800b796:	e07f      	b.n	800b898 <_dtoa_r+0x758>
 800b798:	9a10      	ldr	r2, [sp, #64]	; 0x40
 800b79a:	9b11      	ldr	r3, [sp, #68]	; 0x44
 800b79c:	2000      	movs	r0, #0
 800b79e:	4916      	ldr	r1, [pc, #88]	; (800b7f8 <_dtoa_r+0x6b8>)
 800b7a0:	f7f6 fe06 	bl	80023b0 <__aeabi_dsub>
 800b7a4:	0002      	movs	r2, r0
 800b7a6:	000b      	movs	r3, r1
 800b7a8:	0020      	movs	r0, r4
 800b7aa:	0029      	movs	r1, r5
 800b7ac:	f7f7 fade 	bl	8002d6c <__aeabi_dcmplt>
 800b7b0:	2800      	cmp	r0, #0
 800b7b2:	d100      	bne.n	800b7b6 <_dtoa_r+0x676>
 800b7b4:	e714      	b.n	800b5e0 <_dtoa_r+0x4a0>
 800b7b6:	9b07      	ldr	r3, [sp, #28]
 800b7b8:	001a      	movs	r2, r3
 800b7ba:	3a01      	subs	r2, #1
 800b7bc:	9207      	str	r2, [sp, #28]
 800b7be:	7812      	ldrb	r2, [r2, #0]
 800b7c0:	2a30      	cmp	r2, #48	; 0x30
 800b7c2:	d0f8      	beq.n	800b7b6 <_dtoa_r+0x676>
 800b7c4:	9307      	str	r3, [sp, #28]
 800b7c6:	9602      	str	r6, [sp, #8]
 800b7c8:	e054      	b.n	800b874 <_dtoa_r+0x734>
 800b7ca:	2200      	movs	r2, #0
 800b7cc:	4b05      	ldr	r3, [pc, #20]	; (800b7e4 <_dtoa_r+0x6a4>)
 800b7ce:	f7f6 fb83 	bl	8001ed8 <__aeabi_dmul>
 800b7d2:	0004      	movs	r4, r0
 800b7d4:	000d      	movs	r5, r1
 800b7d6:	e7b2      	b.n	800b73e <_dtoa_r+0x5fe>
 800b7d8:	0800f1a8 	.word	0x0800f1a8
 800b7dc:	0800f180 	.word	0x0800f180
 800b7e0:	3ff00000 	.word	0x3ff00000
 800b7e4:	40240000 	.word	0x40240000
 800b7e8:	401c0000 	.word	0x401c0000
 800b7ec:	fcc00000 	.word	0xfcc00000
 800b7f0:	40140000 	.word	0x40140000
 800b7f4:	7cc00000 	.word	0x7cc00000
 800b7f8:	3fe00000 	.word	0x3fe00000
 800b7fc:	9b06      	ldr	r3, [sp, #24]
 800b7fe:	9e05      	ldr	r6, [sp, #20]
 800b800:	3b01      	subs	r3, #1
 800b802:	199b      	adds	r3, r3, r6
 800b804:	9c0a      	ldr	r4, [sp, #40]	; 0x28
 800b806:	9d0b      	ldr	r5, [sp, #44]	; 0x2c
 800b808:	930a      	str	r3, [sp, #40]	; 0x28
 800b80a:	9a08      	ldr	r2, [sp, #32]
 800b80c:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800b80e:	0020      	movs	r0, r4
 800b810:	0029      	movs	r1, r5
 800b812:	f7f6 f879 	bl	8001908 <__aeabi_ddiv>
 800b816:	f7f7 f95d 	bl	8002ad4 <__aeabi_d2iz>
 800b81a:	9006      	str	r0, [sp, #24]
 800b81c:	f7f7 f990 	bl	8002b40 <__aeabi_i2d>
 800b820:	9a08      	ldr	r2, [sp, #32]
 800b822:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800b824:	f7f6 fb58 	bl	8001ed8 <__aeabi_dmul>
 800b828:	0002      	movs	r2, r0
 800b82a:	000b      	movs	r3, r1
 800b82c:	0020      	movs	r0, r4
 800b82e:	0029      	movs	r1, r5
 800b830:	f7f6 fdbe 	bl	80023b0 <__aeabi_dsub>
 800b834:	0033      	movs	r3, r6
 800b836:	9a06      	ldr	r2, [sp, #24]
 800b838:	3601      	adds	r6, #1
 800b83a:	3230      	adds	r2, #48	; 0x30
 800b83c:	701a      	strb	r2, [r3, #0]
 800b83e:	9a0a      	ldr	r2, [sp, #40]	; 0x28
 800b840:	9607      	str	r6, [sp, #28]
 800b842:	429a      	cmp	r2, r3
 800b844:	d139      	bne.n	800b8ba <_dtoa_r+0x77a>
 800b846:	0002      	movs	r2, r0
 800b848:	000b      	movs	r3, r1
 800b84a:	f7f5 fcf3 	bl	8001234 <__aeabi_dadd>
 800b84e:	9a08      	ldr	r2, [sp, #32]
 800b850:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800b852:	0004      	movs	r4, r0
 800b854:	000d      	movs	r5, r1
 800b856:	f7f7 fa9d 	bl	8002d94 <__aeabi_dcmpgt>
 800b85a:	2800      	cmp	r0, #0
 800b85c:	d11b      	bne.n	800b896 <_dtoa_r+0x756>
 800b85e:	9a08      	ldr	r2, [sp, #32]
 800b860:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800b862:	0020      	movs	r0, r4
 800b864:	0029      	movs	r1, r5
 800b866:	f7f7 fa7b 	bl	8002d60 <__aeabi_dcmpeq>
 800b86a:	2800      	cmp	r0, #0
 800b86c:	d002      	beq.n	800b874 <_dtoa_r+0x734>
 800b86e:	9b06      	ldr	r3, [sp, #24]
 800b870:	07db      	lsls	r3, r3, #31
 800b872:	d410      	bmi.n	800b896 <_dtoa_r+0x756>
 800b874:	0038      	movs	r0, r7
 800b876:	9904      	ldr	r1, [sp, #16]
 800b878:	f7fe fc94 	bl	800a1a4 <_Bfree>
 800b87c:	2300      	movs	r3, #0
 800b87e:	9a07      	ldr	r2, [sp, #28]
 800b880:	9802      	ldr	r0, [sp, #8]
 800b882:	7013      	strb	r3, [r2, #0]
 800b884:	9b24      	ldr	r3, [sp, #144]	; 0x90
 800b886:	3001      	adds	r0, #1
 800b888:	6018      	str	r0, [r3, #0]
 800b88a:	9b26      	ldr	r3, [sp, #152]	; 0x98
 800b88c:	2b00      	cmp	r3, #0
 800b88e:	d100      	bne.n	800b892 <_dtoa_r+0x752>
 800b890:	e4a3      	b.n	800b1da <_dtoa_r+0x9a>
 800b892:	601a      	str	r2, [r3, #0]
 800b894:	e4a1      	b.n	800b1da <_dtoa_r+0x9a>
 800b896:	9e02      	ldr	r6, [sp, #8]
 800b898:	9b07      	ldr	r3, [sp, #28]
 800b89a:	9307      	str	r3, [sp, #28]
 800b89c:	3b01      	subs	r3, #1
 800b89e:	781a      	ldrb	r2, [r3, #0]
 800b8a0:	2a39      	cmp	r2, #57	; 0x39
 800b8a2:	d106      	bne.n	800b8b2 <_dtoa_r+0x772>
 800b8a4:	9a05      	ldr	r2, [sp, #20]
 800b8a6:	429a      	cmp	r2, r3
 800b8a8:	d1f7      	bne.n	800b89a <_dtoa_r+0x75a>
 800b8aa:	2230      	movs	r2, #48	; 0x30
 800b8ac:	9905      	ldr	r1, [sp, #20]
 800b8ae:	3601      	adds	r6, #1
 800b8b0:	700a      	strb	r2, [r1, #0]
 800b8b2:	781a      	ldrb	r2, [r3, #0]
 800b8b4:	3201      	adds	r2, #1
 800b8b6:	701a      	strb	r2, [r3, #0]
 800b8b8:	e785      	b.n	800b7c6 <_dtoa_r+0x686>
 800b8ba:	2200      	movs	r2, #0
 800b8bc:	4bad      	ldr	r3, [pc, #692]	; (800bb74 <_dtoa_r+0xa34>)
 800b8be:	f7f6 fb0b 	bl	8001ed8 <__aeabi_dmul>
 800b8c2:	2200      	movs	r2, #0
 800b8c4:	2300      	movs	r3, #0
 800b8c6:	0004      	movs	r4, r0
 800b8c8:	000d      	movs	r5, r1
 800b8ca:	f7f7 fa49 	bl	8002d60 <__aeabi_dcmpeq>
 800b8ce:	2800      	cmp	r0, #0
 800b8d0:	d09b      	beq.n	800b80a <_dtoa_r+0x6ca>
 800b8d2:	e7cf      	b.n	800b874 <_dtoa_r+0x734>
 800b8d4:	9a0f      	ldr	r2, [sp, #60]	; 0x3c
 800b8d6:	2a00      	cmp	r2, #0
 800b8d8:	d100      	bne.n	800b8dc <_dtoa_r+0x79c>
 800b8da:	e082      	b.n	800b9e2 <_dtoa_r+0x8a2>
 800b8dc:	9a22      	ldr	r2, [sp, #136]	; 0x88
 800b8de:	2a01      	cmp	r2, #1
 800b8e0:	dc66      	bgt.n	800b9b0 <_dtoa_r+0x870>
 800b8e2:	9a16      	ldr	r2, [sp, #88]	; 0x58
 800b8e4:	2a00      	cmp	r2, #0
 800b8e6:	d05f      	beq.n	800b9a8 <_dtoa_r+0x868>
 800b8e8:	4aa3      	ldr	r2, [pc, #652]	; (800bb78 <_dtoa_r+0xa38>)
 800b8ea:	189b      	adds	r3, r3, r2
 800b8ec:	9e0e      	ldr	r6, [sp, #56]	; 0x38
 800b8ee:	9c08      	ldr	r4, [sp, #32]
 800b8f0:	9a08      	ldr	r2, [sp, #32]
 800b8f2:	2101      	movs	r1, #1
 800b8f4:	18d2      	adds	r2, r2, r3
 800b8f6:	9208      	str	r2, [sp, #32]
 800b8f8:	9a0d      	ldr	r2, [sp, #52]	; 0x34
 800b8fa:	0038      	movs	r0, r7
 800b8fc:	18d3      	adds	r3, r2, r3
 800b8fe:	930d      	str	r3, [sp, #52]	; 0x34
 800b900:	f7fe fd00 	bl	800a304 <__i2b>
 800b904:	0005      	movs	r5, r0
 800b906:	2c00      	cmp	r4, #0
 800b908:	dd0e      	ble.n	800b928 <_dtoa_r+0x7e8>
 800b90a:	9b0d      	ldr	r3, [sp, #52]	; 0x34
 800b90c:	2b00      	cmp	r3, #0
 800b90e:	dd0b      	ble.n	800b928 <_dtoa_r+0x7e8>
 800b910:	9a0d      	ldr	r2, [sp, #52]	; 0x34
 800b912:	0023      	movs	r3, r4
 800b914:	4294      	cmp	r4, r2
 800b916:	dd00      	ble.n	800b91a <_dtoa_r+0x7da>
 800b918:	0013      	movs	r3, r2
 800b91a:	9a08      	ldr	r2, [sp, #32]
 800b91c:	1ae4      	subs	r4, r4, r3
 800b91e:	1ad2      	subs	r2, r2, r3
 800b920:	9208      	str	r2, [sp, #32]
 800b922:	9a0d      	ldr	r2, [sp, #52]	; 0x34
 800b924:	1ad3      	subs	r3, r2, r3
 800b926:	930d      	str	r3, [sp, #52]	; 0x34
 800b928:	9b0e      	ldr	r3, [sp, #56]	; 0x38
 800b92a:	2b00      	cmp	r3, #0
 800b92c:	d01f      	beq.n	800b96e <_dtoa_r+0x82e>
 800b92e:	9b0f      	ldr	r3, [sp, #60]	; 0x3c
 800b930:	2b00      	cmp	r3, #0
 800b932:	d05a      	beq.n	800b9ea <_dtoa_r+0x8aa>
 800b934:	2e00      	cmp	r6, #0
 800b936:	dd11      	ble.n	800b95c <_dtoa_r+0x81c>
 800b938:	0029      	movs	r1, r5
 800b93a:	0032      	movs	r2, r6
 800b93c:	0038      	movs	r0, r7
 800b93e:	f7fe fda7 	bl	800a490 <__pow5mult>
 800b942:	9a04      	ldr	r2, [sp, #16]
 800b944:	0001      	movs	r1, r0
 800b946:	0005      	movs	r5, r0
 800b948:	0038      	movs	r0, r7
 800b94a:	f7fe fcf1 	bl	800a330 <__multiply>
 800b94e:	9904      	ldr	r1, [sp, #16]
 800b950:	9007      	str	r0, [sp, #28]
 800b952:	0038      	movs	r0, r7
 800b954:	f7fe fc26 	bl	800a1a4 <_Bfree>
 800b958:	9b07      	ldr	r3, [sp, #28]
 800b95a:	9304      	str	r3, [sp, #16]
 800b95c:	9b0e      	ldr	r3, [sp, #56]	; 0x38
 800b95e:	1b9a      	subs	r2, r3, r6
 800b960:	42b3      	cmp	r3, r6
 800b962:	d004      	beq.n	800b96e <_dtoa_r+0x82e>
 800b964:	0038      	movs	r0, r7
 800b966:	9904      	ldr	r1, [sp, #16]
 800b968:	f7fe fd92 	bl	800a490 <__pow5mult>
 800b96c:	9004      	str	r0, [sp, #16]
 800b96e:	2101      	movs	r1, #1
 800b970:	0038      	movs	r0, r7
 800b972:	f7fe fcc7 	bl	800a304 <__i2b>
 800b976:	9b14      	ldr	r3, [sp, #80]	; 0x50
 800b978:	0006      	movs	r6, r0
 800b97a:	2b00      	cmp	r3, #0
 800b97c:	dd37      	ble.n	800b9ee <_dtoa_r+0x8ae>
 800b97e:	001a      	movs	r2, r3
 800b980:	0001      	movs	r1, r0
 800b982:	0038      	movs	r0, r7
 800b984:	f7fe fd84 	bl	800a490 <__pow5mult>
 800b988:	9b22      	ldr	r3, [sp, #136]	; 0x88
 800b98a:	0006      	movs	r6, r0
 800b98c:	2b01      	cmp	r3, #1
 800b98e:	dd33      	ble.n	800b9f8 <_dtoa_r+0x8b8>
 800b990:	2300      	movs	r3, #0
 800b992:	9307      	str	r3, [sp, #28]
 800b994:	6933      	ldr	r3, [r6, #16]
 800b996:	3303      	adds	r3, #3
 800b998:	009b      	lsls	r3, r3, #2
 800b99a:	18f3      	adds	r3, r6, r3
 800b99c:	6858      	ldr	r0, [r3, #4]
 800b99e:	f7fe fc69 	bl	800a274 <__hi0bits>
 800b9a2:	2320      	movs	r3, #32
 800b9a4:	1a18      	subs	r0, r3, r0
 800b9a6:	e03f      	b.n	800ba28 <_dtoa_r+0x8e8>
 800b9a8:	2336      	movs	r3, #54	; 0x36
 800b9aa:	9a1a      	ldr	r2, [sp, #104]	; 0x68
 800b9ac:	1a9b      	subs	r3, r3, r2
 800b9ae:	e79d      	b.n	800b8ec <_dtoa_r+0x7ac>
 800b9b0:	9b06      	ldr	r3, [sp, #24]
 800b9b2:	1e5e      	subs	r6, r3, #1
 800b9b4:	9b0e      	ldr	r3, [sp, #56]	; 0x38
 800b9b6:	42b3      	cmp	r3, r6
 800b9b8:	db08      	blt.n	800b9cc <_dtoa_r+0x88c>
 800b9ba:	1b9e      	subs	r6, r3, r6
 800b9bc:	9b06      	ldr	r3, [sp, #24]
 800b9be:	2b00      	cmp	r3, #0
 800b9c0:	da0c      	bge.n	800b9dc <_dtoa_r+0x89c>
 800b9c2:	9b08      	ldr	r3, [sp, #32]
 800b9c4:	9a06      	ldr	r2, [sp, #24]
 800b9c6:	1a9c      	subs	r4, r3, r2
 800b9c8:	2300      	movs	r3, #0
 800b9ca:	e791      	b.n	800b8f0 <_dtoa_r+0x7b0>
 800b9cc:	9b0e      	ldr	r3, [sp, #56]	; 0x38
 800b9ce:	9a14      	ldr	r2, [sp, #80]	; 0x50
 800b9d0:	1af3      	subs	r3, r6, r3
 800b9d2:	18d3      	adds	r3, r2, r3
 800b9d4:	960e      	str	r6, [sp, #56]	; 0x38
 800b9d6:	9314      	str	r3, [sp, #80]	; 0x50
 800b9d8:	2600      	movs	r6, #0
 800b9da:	e7ef      	b.n	800b9bc <_dtoa_r+0x87c>
 800b9dc:	9c08      	ldr	r4, [sp, #32]
 800b9de:	9b06      	ldr	r3, [sp, #24]
 800b9e0:	e786      	b.n	800b8f0 <_dtoa_r+0x7b0>
 800b9e2:	9e0e      	ldr	r6, [sp, #56]	; 0x38
 800b9e4:	9c08      	ldr	r4, [sp, #32]
 800b9e6:	9d0f      	ldr	r5, [sp, #60]	; 0x3c
 800b9e8:	e78d      	b.n	800b906 <_dtoa_r+0x7c6>
 800b9ea:	9a0e      	ldr	r2, [sp, #56]	; 0x38
 800b9ec:	e7ba      	b.n	800b964 <_dtoa_r+0x824>
 800b9ee:	2300      	movs	r3, #0
 800b9f0:	9307      	str	r3, [sp, #28]
 800b9f2:	9b22      	ldr	r3, [sp, #136]	; 0x88
 800b9f4:	2b01      	cmp	r3, #1
 800b9f6:	dc13      	bgt.n	800ba20 <_dtoa_r+0x8e0>
 800b9f8:	2300      	movs	r3, #0
 800b9fa:	9307      	str	r3, [sp, #28]
 800b9fc:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 800b9fe:	2b00      	cmp	r3, #0
 800ba00:	d10e      	bne.n	800ba20 <_dtoa_r+0x8e0>
 800ba02:	9b0b      	ldr	r3, [sp, #44]	; 0x2c
 800ba04:	031b      	lsls	r3, r3, #12
 800ba06:	d10b      	bne.n	800ba20 <_dtoa_r+0x8e0>
 800ba08:	9b18      	ldr	r3, [sp, #96]	; 0x60
 800ba0a:	9a0b      	ldr	r2, [sp, #44]	; 0x2c
 800ba0c:	4213      	tst	r3, r2
 800ba0e:	d007      	beq.n	800ba20 <_dtoa_r+0x8e0>
 800ba10:	9b08      	ldr	r3, [sp, #32]
 800ba12:	3301      	adds	r3, #1
 800ba14:	9308      	str	r3, [sp, #32]
 800ba16:	9b0d      	ldr	r3, [sp, #52]	; 0x34
 800ba18:	3301      	adds	r3, #1
 800ba1a:	930d      	str	r3, [sp, #52]	; 0x34
 800ba1c:	2301      	movs	r3, #1
 800ba1e:	9307      	str	r3, [sp, #28]
 800ba20:	9b14      	ldr	r3, [sp, #80]	; 0x50
 800ba22:	2001      	movs	r0, #1
 800ba24:	2b00      	cmp	r3, #0
 800ba26:	d1b5      	bne.n	800b994 <_dtoa_r+0x854>
 800ba28:	9b0d      	ldr	r3, [sp, #52]	; 0x34
 800ba2a:	221f      	movs	r2, #31
 800ba2c:	1818      	adds	r0, r3, r0
 800ba2e:	0003      	movs	r3, r0
 800ba30:	4013      	ands	r3, r2
 800ba32:	4210      	tst	r0, r2
 800ba34:	d046      	beq.n	800bac4 <_dtoa_r+0x984>
 800ba36:	3201      	adds	r2, #1
 800ba38:	1ad2      	subs	r2, r2, r3
 800ba3a:	2a04      	cmp	r2, #4
 800ba3c:	dd3f      	ble.n	800babe <_dtoa_r+0x97e>
 800ba3e:	221c      	movs	r2, #28
 800ba40:	1ad3      	subs	r3, r2, r3
 800ba42:	9a08      	ldr	r2, [sp, #32]
 800ba44:	18e4      	adds	r4, r4, r3
 800ba46:	18d2      	adds	r2, r2, r3
 800ba48:	9208      	str	r2, [sp, #32]
 800ba4a:	9a0d      	ldr	r2, [sp, #52]	; 0x34
 800ba4c:	18d3      	adds	r3, r2, r3
 800ba4e:	930d      	str	r3, [sp, #52]	; 0x34
 800ba50:	9b08      	ldr	r3, [sp, #32]
 800ba52:	2b00      	cmp	r3, #0
 800ba54:	dd05      	ble.n	800ba62 <_dtoa_r+0x922>
 800ba56:	001a      	movs	r2, r3
 800ba58:	0038      	movs	r0, r7
 800ba5a:	9904      	ldr	r1, [sp, #16]
 800ba5c:	f7fe fd74 	bl	800a548 <__lshift>
 800ba60:	9004      	str	r0, [sp, #16]
 800ba62:	9b0d      	ldr	r3, [sp, #52]	; 0x34
 800ba64:	2b00      	cmp	r3, #0
 800ba66:	dd05      	ble.n	800ba74 <_dtoa_r+0x934>
 800ba68:	0031      	movs	r1, r6
 800ba6a:	001a      	movs	r2, r3
 800ba6c:	0038      	movs	r0, r7
 800ba6e:	f7fe fd6b 	bl	800a548 <__lshift>
 800ba72:	0006      	movs	r6, r0
 800ba74:	9b15      	ldr	r3, [sp, #84]	; 0x54
 800ba76:	2b00      	cmp	r3, #0
 800ba78:	d026      	beq.n	800bac8 <_dtoa_r+0x988>
 800ba7a:	0031      	movs	r1, r6
 800ba7c:	9804      	ldr	r0, [sp, #16]
 800ba7e:	f7fe fdd3 	bl	800a628 <__mcmp>
 800ba82:	2800      	cmp	r0, #0
 800ba84:	da20      	bge.n	800bac8 <_dtoa_r+0x988>
 800ba86:	9b02      	ldr	r3, [sp, #8]
 800ba88:	220a      	movs	r2, #10
 800ba8a:	3b01      	subs	r3, #1
 800ba8c:	9302      	str	r3, [sp, #8]
 800ba8e:	0038      	movs	r0, r7
 800ba90:	2300      	movs	r3, #0
 800ba92:	9904      	ldr	r1, [sp, #16]
 800ba94:	f7fe fbaa 	bl	800a1ec <__multadd>
 800ba98:	9b0f      	ldr	r3, [sp, #60]	; 0x3c
 800ba9a:	9004      	str	r0, [sp, #16]
 800ba9c:	2b00      	cmp	r3, #0
 800ba9e:	d100      	bne.n	800baa2 <_dtoa_r+0x962>
 800baa0:	e160      	b.n	800bd64 <_dtoa_r+0xc24>
 800baa2:	2300      	movs	r3, #0
 800baa4:	0029      	movs	r1, r5
 800baa6:	220a      	movs	r2, #10
 800baa8:	0038      	movs	r0, r7
 800baaa:	f7fe fb9f 	bl	800a1ec <__multadd>
 800baae:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 800bab0:	0005      	movs	r5, r0
 800bab2:	2b00      	cmp	r3, #0
 800bab4:	dc47      	bgt.n	800bb46 <_dtoa_r+0xa06>
 800bab6:	9b22      	ldr	r3, [sp, #136]	; 0x88
 800bab8:	2b02      	cmp	r3, #2
 800baba:	dc0d      	bgt.n	800bad8 <_dtoa_r+0x998>
 800babc:	e043      	b.n	800bb46 <_dtoa_r+0xa06>
 800babe:	2a04      	cmp	r2, #4
 800bac0:	d0c6      	beq.n	800ba50 <_dtoa_r+0x910>
 800bac2:	0013      	movs	r3, r2
 800bac4:	331c      	adds	r3, #28
 800bac6:	e7bc      	b.n	800ba42 <_dtoa_r+0x902>
 800bac8:	9b06      	ldr	r3, [sp, #24]
 800baca:	2b00      	cmp	r3, #0
 800bacc:	dc35      	bgt.n	800bb3a <_dtoa_r+0x9fa>
 800bace:	9b22      	ldr	r3, [sp, #136]	; 0x88
 800bad0:	2b02      	cmp	r3, #2
 800bad2:	dd32      	ble.n	800bb3a <_dtoa_r+0x9fa>
 800bad4:	9b06      	ldr	r3, [sp, #24]
 800bad6:	930c      	str	r3, [sp, #48]	; 0x30
 800bad8:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 800bada:	2b00      	cmp	r3, #0
 800badc:	d10c      	bne.n	800baf8 <_dtoa_r+0x9b8>
 800bade:	0031      	movs	r1, r6
 800bae0:	2205      	movs	r2, #5
 800bae2:	0038      	movs	r0, r7
 800bae4:	f7fe fb82 	bl	800a1ec <__multadd>
 800bae8:	0006      	movs	r6, r0
 800baea:	0001      	movs	r1, r0
 800baec:	9804      	ldr	r0, [sp, #16]
 800baee:	f7fe fd9b 	bl	800a628 <__mcmp>
 800baf2:	2800      	cmp	r0, #0
 800baf4:	dd00      	ble.n	800baf8 <_dtoa_r+0x9b8>
 800baf6:	e59f      	b.n	800b638 <_dtoa_r+0x4f8>
 800baf8:	9b23      	ldr	r3, [sp, #140]	; 0x8c
 800bafa:	43db      	mvns	r3, r3
 800bafc:	9302      	str	r3, [sp, #8]
 800bafe:	9b05      	ldr	r3, [sp, #20]
 800bb00:	9307      	str	r3, [sp, #28]
 800bb02:	2400      	movs	r4, #0
 800bb04:	0031      	movs	r1, r6
 800bb06:	0038      	movs	r0, r7
 800bb08:	f7fe fb4c 	bl	800a1a4 <_Bfree>
 800bb0c:	2d00      	cmp	r5, #0
 800bb0e:	d100      	bne.n	800bb12 <_dtoa_r+0x9d2>
 800bb10:	e6b0      	b.n	800b874 <_dtoa_r+0x734>
 800bb12:	2c00      	cmp	r4, #0
 800bb14:	d005      	beq.n	800bb22 <_dtoa_r+0x9e2>
 800bb16:	42ac      	cmp	r4, r5
 800bb18:	d003      	beq.n	800bb22 <_dtoa_r+0x9e2>
 800bb1a:	0021      	movs	r1, r4
 800bb1c:	0038      	movs	r0, r7
 800bb1e:	f7fe fb41 	bl	800a1a4 <_Bfree>
 800bb22:	0029      	movs	r1, r5
 800bb24:	0038      	movs	r0, r7
 800bb26:	f7fe fb3d 	bl	800a1a4 <_Bfree>
 800bb2a:	e6a3      	b.n	800b874 <_dtoa_r+0x734>
 800bb2c:	2600      	movs	r6, #0
 800bb2e:	0035      	movs	r5, r6
 800bb30:	e7e2      	b.n	800baf8 <_dtoa_r+0x9b8>
 800bb32:	9602      	str	r6, [sp, #8]
 800bb34:	9e07      	ldr	r6, [sp, #28]
 800bb36:	0035      	movs	r5, r6
 800bb38:	e57e      	b.n	800b638 <_dtoa_r+0x4f8>
 800bb3a:	9b0f      	ldr	r3, [sp, #60]	; 0x3c
 800bb3c:	2b00      	cmp	r3, #0
 800bb3e:	d100      	bne.n	800bb42 <_dtoa_r+0xa02>
 800bb40:	e0c8      	b.n	800bcd4 <_dtoa_r+0xb94>
 800bb42:	9b06      	ldr	r3, [sp, #24]
 800bb44:	930c      	str	r3, [sp, #48]	; 0x30
 800bb46:	2c00      	cmp	r4, #0
 800bb48:	dd05      	ble.n	800bb56 <_dtoa_r+0xa16>
 800bb4a:	0029      	movs	r1, r5
 800bb4c:	0022      	movs	r2, r4
 800bb4e:	0038      	movs	r0, r7
 800bb50:	f7fe fcfa 	bl	800a548 <__lshift>
 800bb54:	0005      	movs	r5, r0
 800bb56:	9b07      	ldr	r3, [sp, #28]
 800bb58:	0028      	movs	r0, r5
 800bb5a:	2b00      	cmp	r3, #0
 800bb5c:	d01f      	beq.n	800bb9e <_dtoa_r+0xa5e>
 800bb5e:	0038      	movs	r0, r7
 800bb60:	6869      	ldr	r1, [r5, #4]
 800bb62:	f7fe fadb 	bl	800a11c <_Balloc>
 800bb66:	1e04      	subs	r4, r0, #0
 800bb68:	d10c      	bne.n	800bb84 <_dtoa_r+0xa44>
 800bb6a:	0002      	movs	r2, r0
 800bb6c:	4b03      	ldr	r3, [pc, #12]	; (800bb7c <_dtoa_r+0xa3c>)
 800bb6e:	4904      	ldr	r1, [pc, #16]	; (800bb80 <_dtoa_r+0xa40>)
 800bb70:	f7ff fafb 	bl	800b16a <_dtoa_r+0x2a>
 800bb74:	40240000 	.word	0x40240000
 800bb78:	00000433 	.word	0x00000433
 800bb7c:	0800f16b 	.word	0x0800f16b
 800bb80:	000002ea 	.word	0x000002ea
 800bb84:	0029      	movs	r1, r5
 800bb86:	692b      	ldr	r3, [r5, #16]
 800bb88:	310c      	adds	r1, #12
 800bb8a:	1c9a      	adds	r2, r3, #2
 800bb8c:	0092      	lsls	r2, r2, #2
 800bb8e:	300c      	adds	r0, #12
 800bb90:	f000 fb3d 	bl	800c20e <memcpy>
 800bb94:	2201      	movs	r2, #1
 800bb96:	0021      	movs	r1, r4
 800bb98:	0038      	movs	r0, r7
 800bb9a:	f7fe fcd5 	bl	800a548 <__lshift>
 800bb9e:	002c      	movs	r4, r5
 800bba0:	0005      	movs	r5, r0
 800bba2:	9b05      	ldr	r3, [sp, #20]
 800bba4:	9308      	str	r3, [sp, #32]
 800bba6:	0031      	movs	r1, r6
 800bba8:	9804      	ldr	r0, [sp, #16]
 800bbaa:	f7ff fa3e 	bl	800b02a <quorem>
 800bbae:	0003      	movs	r3, r0
 800bbb0:	0021      	movs	r1, r4
 800bbb2:	3330      	adds	r3, #48	; 0x30
 800bbb4:	900e      	str	r0, [sp, #56]	; 0x38
 800bbb6:	9804      	ldr	r0, [sp, #16]
 800bbb8:	9306      	str	r3, [sp, #24]
 800bbba:	f7fe fd35 	bl	800a628 <__mcmp>
 800bbbe:	002a      	movs	r2, r5
 800bbc0:	900f      	str	r0, [sp, #60]	; 0x3c
 800bbc2:	0031      	movs	r1, r6
 800bbc4:	0038      	movs	r0, r7
 800bbc6:	f7fe fd4b 	bl	800a660 <__mdiff>
 800bbca:	68c3      	ldr	r3, [r0, #12]
 800bbcc:	9007      	str	r0, [sp, #28]
 800bbce:	9310      	str	r3, [sp, #64]	; 0x40
 800bbd0:	2301      	movs	r3, #1
 800bbd2:	930d      	str	r3, [sp, #52]	; 0x34
 800bbd4:	9b10      	ldr	r3, [sp, #64]	; 0x40
 800bbd6:	2b00      	cmp	r3, #0
 800bbd8:	d104      	bne.n	800bbe4 <_dtoa_r+0xaa4>
 800bbda:	0001      	movs	r1, r0
 800bbdc:	9804      	ldr	r0, [sp, #16]
 800bbde:	f7fe fd23 	bl	800a628 <__mcmp>
 800bbe2:	900d      	str	r0, [sp, #52]	; 0x34
 800bbe4:	0038      	movs	r0, r7
 800bbe6:	9907      	ldr	r1, [sp, #28]
 800bbe8:	f7fe fadc 	bl	800a1a4 <_Bfree>
 800bbec:	2301      	movs	r3, #1
 800bbee:	980a      	ldr	r0, [sp, #40]	; 0x28
 800bbf0:	9a0d      	ldr	r2, [sp, #52]	; 0x34
 800bbf2:	4018      	ands	r0, r3
 800bbf4:	9b08      	ldr	r3, [sp, #32]
 800bbf6:	3301      	adds	r3, #1
 800bbf8:	9307      	str	r3, [sp, #28]
 800bbfa:	9b22      	ldr	r3, [sp, #136]	; 0x88
 800bbfc:	4313      	orrs	r3, r2
 800bbfe:	4303      	orrs	r3, r0
 800bc00:	d10c      	bne.n	800bc1c <_dtoa_r+0xadc>
 800bc02:	9b06      	ldr	r3, [sp, #24]
 800bc04:	2b39      	cmp	r3, #57	; 0x39
 800bc06:	d025      	beq.n	800bc54 <_dtoa_r+0xb14>
 800bc08:	9b0f      	ldr	r3, [sp, #60]	; 0x3c
 800bc0a:	2b00      	cmp	r3, #0
 800bc0c:	dd02      	ble.n	800bc14 <_dtoa_r+0xad4>
 800bc0e:	9b0e      	ldr	r3, [sp, #56]	; 0x38
 800bc10:	3331      	adds	r3, #49	; 0x31
 800bc12:	9306      	str	r3, [sp, #24]
 800bc14:	9b08      	ldr	r3, [sp, #32]
 800bc16:	9a06      	ldr	r2, [sp, #24]
 800bc18:	701a      	strb	r2, [r3, #0]
 800bc1a:	e773      	b.n	800bb04 <_dtoa_r+0x9c4>
 800bc1c:	9b0f      	ldr	r3, [sp, #60]	; 0x3c
 800bc1e:	2b00      	cmp	r3, #0
 800bc20:	db03      	blt.n	800bc2a <_dtoa_r+0xaea>
 800bc22:	9a22      	ldr	r2, [sp, #136]	; 0x88
 800bc24:	4313      	orrs	r3, r2
 800bc26:	4303      	orrs	r3, r0
 800bc28:	d11f      	bne.n	800bc6a <_dtoa_r+0xb2a>
 800bc2a:	9b0d      	ldr	r3, [sp, #52]	; 0x34
 800bc2c:	2b00      	cmp	r3, #0
 800bc2e:	ddf1      	ble.n	800bc14 <_dtoa_r+0xad4>
 800bc30:	9904      	ldr	r1, [sp, #16]
 800bc32:	2201      	movs	r2, #1
 800bc34:	0038      	movs	r0, r7
 800bc36:	f7fe fc87 	bl	800a548 <__lshift>
 800bc3a:	0031      	movs	r1, r6
 800bc3c:	9004      	str	r0, [sp, #16]
 800bc3e:	f7fe fcf3 	bl	800a628 <__mcmp>
 800bc42:	2800      	cmp	r0, #0
 800bc44:	dc03      	bgt.n	800bc4e <_dtoa_r+0xb0e>
 800bc46:	d1e5      	bne.n	800bc14 <_dtoa_r+0xad4>
 800bc48:	9b06      	ldr	r3, [sp, #24]
 800bc4a:	07db      	lsls	r3, r3, #31
 800bc4c:	d5e2      	bpl.n	800bc14 <_dtoa_r+0xad4>
 800bc4e:	9b06      	ldr	r3, [sp, #24]
 800bc50:	2b39      	cmp	r3, #57	; 0x39
 800bc52:	d1dc      	bne.n	800bc0e <_dtoa_r+0xace>
 800bc54:	2339      	movs	r3, #57	; 0x39
 800bc56:	9a08      	ldr	r2, [sp, #32]
 800bc58:	7013      	strb	r3, [r2, #0]
 800bc5a:	9b07      	ldr	r3, [sp, #28]
 800bc5c:	9307      	str	r3, [sp, #28]
 800bc5e:	3b01      	subs	r3, #1
 800bc60:	781a      	ldrb	r2, [r3, #0]
 800bc62:	2a39      	cmp	r2, #57	; 0x39
 800bc64:	d06c      	beq.n	800bd40 <_dtoa_r+0xc00>
 800bc66:	3201      	adds	r2, #1
 800bc68:	e7d6      	b.n	800bc18 <_dtoa_r+0xad8>
 800bc6a:	9b0d      	ldr	r3, [sp, #52]	; 0x34
 800bc6c:	2b00      	cmp	r3, #0
 800bc6e:	dd07      	ble.n	800bc80 <_dtoa_r+0xb40>
 800bc70:	9b06      	ldr	r3, [sp, #24]
 800bc72:	2b39      	cmp	r3, #57	; 0x39
 800bc74:	d0ee      	beq.n	800bc54 <_dtoa_r+0xb14>
 800bc76:	9b06      	ldr	r3, [sp, #24]
 800bc78:	9a08      	ldr	r2, [sp, #32]
 800bc7a:	3301      	adds	r3, #1
 800bc7c:	7013      	strb	r3, [r2, #0]
 800bc7e:	e741      	b.n	800bb04 <_dtoa_r+0x9c4>
 800bc80:	9b08      	ldr	r3, [sp, #32]
 800bc82:	9a06      	ldr	r2, [sp, #24]
 800bc84:	701a      	strb	r2, [r3, #0]
 800bc86:	2301      	movs	r3, #1
 800bc88:	9a05      	ldr	r2, [sp, #20]
 800bc8a:	1a9b      	subs	r3, r3, r2
 800bc8c:	9a08      	ldr	r2, [sp, #32]
 800bc8e:	189b      	adds	r3, r3, r2
 800bc90:	9a0c      	ldr	r2, [sp, #48]	; 0x30
 800bc92:	429a      	cmp	r2, r3
 800bc94:	d03e      	beq.n	800bd14 <_dtoa_r+0xbd4>
 800bc96:	2300      	movs	r3, #0
 800bc98:	220a      	movs	r2, #10
 800bc9a:	9904      	ldr	r1, [sp, #16]
 800bc9c:	0038      	movs	r0, r7
 800bc9e:	f7fe faa5 	bl	800a1ec <__multadd>
 800bca2:	2300      	movs	r3, #0
 800bca4:	9004      	str	r0, [sp, #16]
 800bca6:	220a      	movs	r2, #10
 800bca8:	0021      	movs	r1, r4
 800bcaa:	0038      	movs	r0, r7
 800bcac:	42ac      	cmp	r4, r5
 800bcae:	d106      	bne.n	800bcbe <_dtoa_r+0xb7e>
 800bcb0:	f7fe fa9c 	bl	800a1ec <__multadd>
 800bcb4:	0004      	movs	r4, r0
 800bcb6:	0005      	movs	r5, r0
 800bcb8:	9b07      	ldr	r3, [sp, #28]
 800bcba:	9308      	str	r3, [sp, #32]
 800bcbc:	e773      	b.n	800bba6 <_dtoa_r+0xa66>
 800bcbe:	f7fe fa95 	bl	800a1ec <__multadd>
 800bcc2:	0029      	movs	r1, r5
 800bcc4:	0004      	movs	r4, r0
 800bcc6:	2300      	movs	r3, #0
 800bcc8:	220a      	movs	r2, #10
 800bcca:	0038      	movs	r0, r7
 800bccc:	f7fe fa8e 	bl	800a1ec <__multadd>
 800bcd0:	0005      	movs	r5, r0
 800bcd2:	e7f1      	b.n	800bcb8 <_dtoa_r+0xb78>
 800bcd4:	9b06      	ldr	r3, [sp, #24]
 800bcd6:	930c      	str	r3, [sp, #48]	; 0x30
 800bcd8:	2400      	movs	r4, #0
 800bcda:	0031      	movs	r1, r6
 800bcdc:	9804      	ldr	r0, [sp, #16]
 800bcde:	f7ff f9a4 	bl	800b02a <quorem>
 800bce2:	9b05      	ldr	r3, [sp, #20]
 800bce4:	3030      	adds	r0, #48	; 0x30
 800bce6:	5518      	strb	r0, [r3, r4]
 800bce8:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 800bcea:	3401      	adds	r4, #1
 800bcec:	9006      	str	r0, [sp, #24]
 800bcee:	42a3      	cmp	r3, r4
 800bcf0:	dd07      	ble.n	800bd02 <_dtoa_r+0xbc2>
 800bcf2:	2300      	movs	r3, #0
 800bcf4:	220a      	movs	r2, #10
 800bcf6:	0038      	movs	r0, r7
 800bcf8:	9904      	ldr	r1, [sp, #16]
 800bcfa:	f7fe fa77 	bl	800a1ec <__multadd>
 800bcfe:	9004      	str	r0, [sp, #16]
 800bd00:	e7eb      	b.n	800bcda <_dtoa_r+0xb9a>
 800bd02:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 800bd04:	2001      	movs	r0, #1
 800bd06:	2b00      	cmp	r3, #0
 800bd08:	dd00      	ble.n	800bd0c <_dtoa_r+0xbcc>
 800bd0a:	0018      	movs	r0, r3
 800bd0c:	2400      	movs	r4, #0
 800bd0e:	9b05      	ldr	r3, [sp, #20]
 800bd10:	181b      	adds	r3, r3, r0
 800bd12:	9307      	str	r3, [sp, #28]
 800bd14:	9904      	ldr	r1, [sp, #16]
 800bd16:	2201      	movs	r2, #1
 800bd18:	0038      	movs	r0, r7
 800bd1a:	f7fe fc15 	bl	800a548 <__lshift>
 800bd1e:	0031      	movs	r1, r6
 800bd20:	9004      	str	r0, [sp, #16]
 800bd22:	f7fe fc81 	bl	800a628 <__mcmp>
 800bd26:	2800      	cmp	r0, #0
 800bd28:	dc97      	bgt.n	800bc5a <_dtoa_r+0xb1a>
 800bd2a:	d102      	bne.n	800bd32 <_dtoa_r+0xbf2>
 800bd2c:	9b06      	ldr	r3, [sp, #24]
 800bd2e:	07db      	lsls	r3, r3, #31
 800bd30:	d493      	bmi.n	800bc5a <_dtoa_r+0xb1a>
 800bd32:	9b07      	ldr	r3, [sp, #28]
 800bd34:	9307      	str	r3, [sp, #28]
 800bd36:	3b01      	subs	r3, #1
 800bd38:	781a      	ldrb	r2, [r3, #0]
 800bd3a:	2a30      	cmp	r2, #48	; 0x30
 800bd3c:	d0fa      	beq.n	800bd34 <_dtoa_r+0xbf4>
 800bd3e:	e6e1      	b.n	800bb04 <_dtoa_r+0x9c4>
 800bd40:	9a05      	ldr	r2, [sp, #20]
 800bd42:	429a      	cmp	r2, r3
 800bd44:	d18a      	bne.n	800bc5c <_dtoa_r+0xb1c>
 800bd46:	9b02      	ldr	r3, [sp, #8]
 800bd48:	3301      	adds	r3, #1
 800bd4a:	9302      	str	r3, [sp, #8]
 800bd4c:	2331      	movs	r3, #49	; 0x31
 800bd4e:	e795      	b.n	800bc7c <_dtoa_r+0xb3c>
 800bd50:	4b08      	ldr	r3, [pc, #32]	; (800bd74 <_dtoa_r+0xc34>)
 800bd52:	9a26      	ldr	r2, [sp, #152]	; 0x98
 800bd54:	9305      	str	r3, [sp, #20]
 800bd56:	4b08      	ldr	r3, [pc, #32]	; (800bd78 <_dtoa_r+0xc38>)
 800bd58:	2a00      	cmp	r2, #0
 800bd5a:	d001      	beq.n	800bd60 <_dtoa_r+0xc20>
 800bd5c:	f7ff fa3b 	bl	800b1d6 <_dtoa_r+0x96>
 800bd60:	f7ff fa3b 	bl	800b1da <_dtoa_r+0x9a>
 800bd64:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 800bd66:	2b00      	cmp	r3, #0
 800bd68:	dcb6      	bgt.n	800bcd8 <_dtoa_r+0xb98>
 800bd6a:	9b22      	ldr	r3, [sp, #136]	; 0x88
 800bd6c:	2b02      	cmp	r3, #2
 800bd6e:	dd00      	ble.n	800bd72 <_dtoa_r+0xc32>
 800bd70:	e6b2      	b.n	800bad8 <_dtoa_r+0x998>
 800bd72:	e7b1      	b.n	800bcd8 <_dtoa_r+0xb98>
 800bd74:	0800f2af 	.word	0x0800f2af
 800bd78:	0800f2b7 	.word	0x0800f2b7

0800bd7c <__sflush_r>:
 800bd7c:	b5f7      	push	{r0, r1, r2, r4, r5, r6, r7, lr}
 800bd7e:	898b      	ldrh	r3, [r1, #12]
 800bd80:	0005      	movs	r5, r0
 800bd82:	000c      	movs	r4, r1
 800bd84:	071a      	lsls	r2, r3, #28
 800bd86:	d45f      	bmi.n	800be48 <__sflush_r+0xcc>
 800bd88:	684a      	ldr	r2, [r1, #4]
 800bd8a:	2a00      	cmp	r2, #0
 800bd8c:	dc04      	bgt.n	800bd98 <__sflush_r+0x1c>
 800bd8e:	6c0a      	ldr	r2, [r1, #64]	; 0x40
 800bd90:	2a00      	cmp	r2, #0
 800bd92:	dc01      	bgt.n	800bd98 <__sflush_r+0x1c>
 800bd94:	2000      	movs	r0, #0
 800bd96:	bdfe      	pop	{r1, r2, r3, r4, r5, r6, r7, pc}
 800bd98:	6ae7      	ldr	r7, [r4, #44]	; 0x2c
 800bd9a:	2f00      	cmp	r7, #0
 800bd9c:	d0fa      	beq.n	800bd94 <__sflush_r+0x18>
 800bd9e:	2200      	movs	r2, #0
 800bda0:	2180      	movs	r1, #128	; 0x80
 800bda2:	682e      	ldr	r6, [r5, #0]
 800bda4:	602a      	str	r2, [r5, #0]
 800bda6:	001a      	movs	r2, r3
 800bda8:	0149      	lsls	r1, r1, #5
 800bdaa:	400a      	ands	r2, r1
 800bdac:	420b      	tst	r3, r1
 800bdae:	d034      	beq.n	800be1a <__sflush_r+0x9e>
 800bdb0:	6d60      	ldr	r0, [r4, #84]	; 0x54
 800bdb2:	89a3      	ldrh	r3, [r4, #12]
 800bdb4:	075b      	lsls	r3, r3, #29
 800bdb6:	d506      	bpl.n	800bdc6 <__sflush_r+0x4a>
 800bdb8:	6863      	ldr	r3, [r4, #4]
 800bdba:	1ac0      	subs	r0, r0, r3
 800bdbc:	6b63      	ldr	r3, [r4, #52]	; 0x34
 800bdbe:	2b00      	cmp	r3, #0
 800bdc0:	d001      	beq.n	800bdc6 <__sflush_r+0x4a>
 800bdc2:	6c23      	ldr	r3, [r4, #64]	; 0x40
 800bdc4:	1ac0      	subs	r0, r0, r3
 800bdc6:	0002      	movs	r2, r0
 800bdc8:	6a21      	ldr	r1, [r4, #32]
 800bdca:	2300      	movs	r3, #0
 800bdcc:	0028      	movs	r0, r5
 800bdce:	6ae7      	ldr	r7, [r4, #44]	; 0x2c
 800bdd0:	47b8      	blx	r7
 800bdd2:	89a1      	ldrh	r1, [r4, #12]
 800bdd4:	1c43      	adds	r3, r0, #1
 800bdd6:	d106      	bne.n	800bde6 <__sflush_r+0x6a>
 800bdd8:	682b      	ldr	r3, [r5, #0]
 800bdda:	2b1d      	cmp	r3, #29
 800bddc:	d831      	bhi.n	800be42 <__sflush_r+0xc6>
 800bdde:	4a2c      	ldr	r2, [pc, #176]	; (800be90 <__sflush_r+0x114>)
 800bde0:	40da      	lsrs	r2, r3
 800bde2:	07d3      	lsls	r3, r2, #31
 800bde4:	d52d      	bpl.n	800be42 <__sflush_r+0xc6>
 800bde6:	2300      	movs	r3, #0
 800bde8:	6063      	str	r3, [r4, #4]
 800bdea:	6923      	ldr	r3, [r4, #16]
 800bdec:	6023      	str	r3, [r4, #0]
 800bdee:	04cb      	lsls	r3, r1, #19
 800bdf0:	d505      	bpl.n	800bdfe <__sflush_r+0x82>
 800bdf2:	1c43      	adds	r3, r0, #1
 800bdf4:	d102      	bne.n	800bdfc <__sflush_r+0x80>
 800bdf6:	682b      	ldr	r3, [r5, #0]
 800bdf8:	2b00      	cmp	r3, #0
 800bdfa:	d100      	bne.n	800bdfe <__sflush_r+0x82>
 800bdfc:	6560      	str	r0, [r4, #84]	; 0x54
 800bdfe:	6b61      	ldr	r1, [r4, #52]	; 0x34
 800be00:	602e      	str	r6, [r5, #0]
 800be02:	2900      	cmp	r1, #0
 800be04:	d0c6      	beq.n	800bd94 <__sflush_r+0x18>
 800be06:	0023      	movs	r3, r4
 800be08:	3344      	adds	r3, #68	; 0x44
 800be0a:	4299      	cmp	r1, r3
 800be0c:	d002      	beq.n	800be14 <__sflush_r+0x98>
 800be0e:	0028      	movs	r0, r5
 800be10:	f7fd ff3e 	bl	8009c90 <_free_r>
 800be14:	2000      	movs	r0, #0
 800be16:	6360      	str	r0, [r4, #52]	; 0x34
 800be18:	e7bd      	b.n	800bd96 <__sflush_r+0x1a>
 800be1a:	2301      	movs	r3, #1
 800be1c:	0028      	movs	r0, r5
 800be1e:	6a21      	ldr	r1, [r4, #32]
 800be20:	47b8      	blx	r7
 800be22:	1c43      	adds	r3, r0, #1
 800be24:	d1c5      	bne.n	800bdb2 <__sflush_r+0x36>
 800be26:	682b      	ldr	r3, [r5, #0]
 800be28:	2b00      	cmp	r3, #0
 800be2a:	d0c2      	beq.n	800bdb2 <__sflush_r+0x36>
 800be2c:	2b1d      	cmp	r3, #29
 800be2e:	d001      	beq.n	800be34 <__sflush_r+0xb8>
 800be30:	2b16      	cmp	r3, #22
 800be32:	d101      	bne.n	800be38 <__sflush_r+0xbc>
 800be34:	602e      	str	r6, [r5, #0]
 800be36:	e7ad      	b.n	800bd94 <__sflush_r+0x18>
 800be38:	2340      	movs	r3, #64	; 0x40
 800be3a:	89a2      	ldrh	r2, [r4, #12]
 800be3c:	4313      	orrs	r3, r2
 800be3e:	81a3      	strh	r3, [r4, #12]
 800be40:	e7a9      	b.n	800bd96 <__sflush_r+0x1a>
 800be42:	2340      	movs	r3, #64	; 0x40
 800be44:	430b      	orrs	r3, r1
 800be46:	e7fa      	b.n	800be3e <__sflush_r+0xc2>
 800be48:	690f      	ldr	r7, [r1, #16]
 800be4a:	2f00      	cmp	r7, #0
 800be4c:	d0a2      	beq.n	800bd94 <__sflush_r+0x18>
 800be4e:	680a      	ldr	r2, [r1, #0]
 800be50:	600f      	str	r7, [r1, #0]
 800be52:	1bd2      	subs	r2, r2, r7
 800be54:	9201      	str	r2, [sp, #4]
 800be56:	2200      	movs	r2, #0
 800be58:	079b      	lsls	r3, r3, #30
 800be5a:	d100      	bne.n	800be5e <__sflush_r+0xe2>
 800be5c:	694a      	ldr	r2, [r1, #20]
 800be5e:	60a2      	str	r2, [r4, #8]
 800be60:	9b01      	ldr	r3, [sp, #4]
 800be62:	2b00      	cmp	r3, #0
 800be64:	dc00      	bgt.n	800be68 <__sflush_r+0xec>
 800be66:	e795      	b.n	800bd94 <__sflush_r+0x18>
 800be68:	003a      	movs	r2, r7
 800be6a:	0028      	movs	r0, r5
 800be6c:	9b01      	ldr	r3, [sp, #4]
 800be6e:	6a21      	ldr	r1, [r4, #32]
 800be70:	6aa6      	ldr	r6, [r4, #40]	; 0x28
 800be72:	47b0      	blx	r6
 800be74:	2800      	cmp	r0, #0
 800be76:	dc06      	bgt.n	800be86 <__sflush_r+0x10a>
 800be78:	2340      	movs	r3, #64	; 0x40
 800be7a:	2001      	movs	r0, #1
 800be7c:	89a2      	ldrh	r2, [r4, #12]
 800be7e:	4240      	negs	r0, r0
 800be80:	4313      	orrs	r3, r2
 800be82:	81a3      	strh	r3, [r4, #12]
 800be84:	e787      	b.n	800bd96 <__sflush_r+0x1a>
 800be86:	9b01      	ldr	r3, [sp, #4]
 800be88:	183f      	adds	r7, r7, r0
 800be8a:	1a1b      	subs	r3, r3, r0
 800be8c:	9301      	str	r3, [sp, #4]
 800be8e:	e7e7      	b.n	800be60 <__sflush_r+0xe4>
 800be90:	20400001 	.word	0x20400001

0800be94 <_fflush_r>:
 800be94:	690b      	ldr	r3, [r1, #16]
 800be96:	b570      	push	{r4, r5, r6, lr}
 800be98:	0005      	movs	r5, r0
 800be9a:	000c      	movs	r4, r1
 800be9c:	2b00      	cmp	r3, #0
 800be9e:	d102      	bne.n	800bea6 <_fflush_r+0x12>
 800bea0:	2500      	movs	r5, #0
 800bea2:	0028      	movs	r0, r5
 800bea4:	bd70      	pop	{r4, r5, r6, pc}
 800bea6:	2800      	cmp	r0, #0
 800bea8:	d004      	beq.n	800beb4 <_fflush_r+0x20>
 800beaa:	6983      	ldr	r3, [r0, #24]
 800beac:	2b00      	cmp	r3, #0
 800beae:	d101      	bne.n	800beb4 <_fflush_r+0x20>
 800beb0:	f000 f892 	bl	800bfd8 <__sinit>
 800beb4:	4b14      	ldr	r3, [pc, #80]	; (800bf08 <_fflush_r+0x74>)
 800beb6:	429c      	cmp	r4, r3
 800beb8:	d11b      	bne.n	800bef2 <_fflush_r+0x5e>
 800beba:	686c      	ldr	r4, [r5, #4]
 800bebc:	220c      	movs	r2, #12
 800bebe:	5ea3      	ldrsh	r3, [r4, r2]
 800bec0:	2b00      	cmp	r3, #0
 800bec2:	d0ed      	beq.n	800bea0 <_fflush_r+0xc>
 800bec4:	6e62      	ldr	r2, [r4, #100]	; 0x64
 800bec6:	07d2      	lsls	r2, r2, #31
 800bec8:	d404      	bmi.n	800bed4 <_fflush_r+0x40>
 800beca:	059b      	lsls	r3, r3, #22
 800becc:	d402      	bmi.n	800bed4 <_fflush_r+0x40>
 800bece:	6da0      	ldr	r0, [r4, #88]	; 0x58
 800bed0:	f000 f923 	bl	800c11a <__retarget_lock_acquire_recursive>
 800bed4:	0028      	movs	r0, r5
 800bed6:	0021      	movs	r1, r4
 800bed8:	f7ff ff50 	bl	800bd7c <__sflush_r>
 800bedc:	6e63      	ldr	r3, [r4, #100]	; 0x64
 800bede:	0005      	movs	r5, r0
 800bee0:	07db      	lsls	r3, r3, #31
 800bee2:	d4de      	bmi.n	800bea2 <_fflush_r+0xe>
 800bee4:	89a3      	ldrh	r3, [r4, #12]
 800bee6:	059b      	lsls	r3, r3, #22
 800bee8:	d4db      	bmi.n	800bea2 <_fflush_r+0xe>
 800beea:	6da0      	ldr	r0, [r4, #88]	; 0x58
 800beec:	f000 f916 	bl	800c11c <__retarget_lock_release_recursive>
 800bef0:	e7d7      	b.n	800bea2 <_fflush_r+0xe>
 800bef2:	4b06      	ldr	r3, [pc, #24]	; (800bf0c <_fflush_r+0x78>)
 800bef4:	429c      	cmp	r4, r3
 800bef6:	d101      	bne.n	800befc <_fflush_r+0x68>
 800bef8:	68ac      	ldr	r4, [r5, #8]
 800befa:	e7df      	b.n	800bebc <_fflush_r+0x28>
 800befc:	4b04      	ldr	r3, [pc, #16]	; (800bf10 <_fflush_r+0x7c>)
 800befe:	429c      	cmp	r4, r3
 800bf00:	d1dc      	bne.n	800bebc <_fflush_r+0x28>
 800bf02:	68ec      	ldr	r4, [r5, #12]
 800bf04:	e7da      	b.n	800bebc <_fflush_r+0x28>
 800bf06:	46c0      	nop			; (mov r8, r8)
 800bf08:	0800f340 	.word	0x0800f340
 800bf0c:	0800f360 	.word	0x0800f360
 800bf10:	0800f320 	.word	0x0800f320

0800bf14 <std>:
 800bf14:	2300      	movs	r3, #0
 800bf16:	b510      	push	{r4, lr}
 800bf18:	0004      	movs	r4, r0
 800bf1a:	6003      	str	r3, [r0, #0]
 800bf1c:	6043      	str	r3, [r0, #4]
 800bf1e:	6083      	str	r3, [r0, #8]
 800bf20:	8181      	strh	r1, [r0, #12]
 800bf22:	6643      	str	r3, [r0, #100]	; 0x64
 800bf24:	0019      	movs	r1, r3
 800bf26:	81c2      	strh	r2, [r0, #14]
 800bf28:	6103      	str	r3, [r0, #16]
 800bf2a:	6143      	str	r3, [r0, #20]
 800bf2c:	6183      	str	r3, [r0, #24]
 800bf2e:	2208      	movs	r2, #8
 800bf30:	305c      	adds	r0, #92	; 0x5c
 800bf32:	f7fd fea5 	bl	8009c80 <memset>
 800bf36:	4b05      	ldr	r3, [pc, #20]	; (800bf4c <std+0x38>)
 800bf38:	6263      	str	r3, [r4, #36]	; 0x24
 800bf3a:	4b05      	ldr	r3, [pc, #20]	; (800bf50 <std+0x3c>)
 800bf3c:	6224      	str	r4, [r4, #32]
 800bf3e:	62a3      	str	r3, [r4, #40]	; 0x28
 800bf40:	4b04      	ldr	r3, [pc, #16]	; (800bf54 <std+0x40>)
 800bf42:	62e3      	str	r3, [r4, #44]	; 0x2c
 800bf44:	4b04      	ldr	r3, [pc, #16]	; (800bf58 <std+0x44>)
 800bf46:	6323      	str	r3, [r4, #48]	; 0x30
 800bf48:	bd10      	pop	{r4, pc}
 800bf4a:	46c0      	nop			; (mov r8, r8)
 800bf4c:	0800c2b5 	.word	0x0800c2b5
 800bf50:	0800c2dd 	.word	0x0800c2dd
 800bf54:	0800c315 	.word	0x0800c315
 800bf58:	0800c341 	.word	0x0800c341

0800bf5c <_cleanup_r>:
 800bf5c:	b510      	push	{r4, lr}
 800bf5e:	4902      	ldr	r1, [pc, #8]	; (800bf68 <_cleanup_r+0xc>)
 800bf60:	f000 f8ba 	bl	800c0d8 <_fwalk_reent>
 800bf64:	bd10      	pop	{r4, pc}
 800bf66:	46c0      	nop			; (mov r8, r8)
 800bf68:	0800be95 	.word	0x0800be95

0800bf6c <__sfmoreglue>:
 800bf6c:	b570      	push	{r4, r5, r6, lr}
 800bf6e:	2568      	movs	r5, #104	; 0x68
 800bf70:	1e4a      	subs	r2, r1, #1
 800bf72:	4355      	muls	r5, r2
 800bf74:	000e      	movs	r6, r1
 800bf76:	0029      	movs	r1, r5
 800bf78:	3174      	adds	r1, #116	; 0x74
 800bf7a:	f7fd fed3 	bl	8009d24 <_malloc_r>
 800bf7e:	1e04      	subs	r4, r0, #0
 800bf80:	d008      	beq.n	800bf94 <__sfmoreglue+0x28>
 800bf82:	2100      	movs	r1, #0
 800bf84:	002a      	movs	r2, r5
 800bf86:	6001      	str	r1, [r0, #0]
 800bf88:	6046      	str	r6, [r0, #4]
 800bf8a:	300c      	adds	r0, #12
 800bf8c:	60a0      	str	r0, [r4, #8]
 800bf8e:	3268      	adds	r2, #104	; 0x68
 800bf90:	f7fd fe76 	bl	8009c80 <memset>
 800bf94:	0020      	movs	r0, r4
 800bf96:	bd70      	pop	{r4, r5, r6, pc}

0800bf98 <__sfp_lock_acquire>:
 800bf98:	b510      	push	{r4, lr}
 800bf9a:	4802      	ldr	r0, [pc, #8]	; (800bfa4 <__sfp_lock_acquire+0xc>)
 800bf9c:	f000 f8bd 	bl	800c11a <__retarget_lock_acquire_recursive>
 800bfa0:	bd10      	pop	{r4, pc}
 800bfa2:	46c0      	nop			; (mov r8, r8)
 800bfa4:	200022e8 	.word	0x200022e8

0800bfa8 <__sfp_lock_release>:
 800bfa8:	b510      	push	{r4, lr}
 800bfaa:	4802      	ldr	r0, [pc, #8]	; (800bfb4 <__sfp_lock_release+0xc>)
 800bfac:	f000 f8b6 	bl	800c11c <__retarget_lock_release_recursive>
 800bfb0:	bd10      	pop	{r4, pc}
 800bfb2:	46c0      	nop			; (mov r8, r8)
 800bfb4:	200022e8 	.word	0x200022e8

0800bfb8 <__sinit_lock_acquire>:
 800bfb8:	b510      	push	{r4, lr}
 800bfba:	4802      	ldr	r0, [pc, #8]	; (800bfc4 <__sinit_lock_acquire+0xc>)
 800bfbc:	f000 f8ad 	bl	800c11a <__retarget_lock_acquire_recursive>
 800bfc0:	bd10      	pop	{r4, pc}
 800bfc2:	46c0      	nop			; (mov r8, r8)
 800bfc4:	200022e3 	.word	0x200022e3

0800bfc8 <__sinit_lock_release>:
 800bfc8:	b510      	push	{r4, lr}
 800bfca:	4802      	ldr	r0, [pc, #8]	; (800bfd4 <__sinit_lock_release+0xc>)
 800bfcc:	f000 f8a6 	bl	800c11c <__retarget_lock_release_recursive>
 800bfd0:	bd10      	pop	{r4, pc}
 800bfd2:	46c0      	nop			; (mov r8, r8)
 800bfd4:	200022e3 	.word	0x200022e3

0800bfd8 <__sinit>:
 800bfd8:	b513      	push	{r0, r1, r4, lr}
 800bfda:	0004      	movs	r4, r0
 800bfdc:	f7ff ffec 	bl	800bfb8 <__sinit_lock_acquire>
 800bfe0:	69a3      	ldr	r3, [r4, #24]
 800bfe2:	2b00      	cmp	r3, #0
 800bfe4:	d002      	beq.n	800bfec <__sinit+0x14>
 800bfe6:	f7ff ffef 	bl	800bfc8 <__sinit_lock_release>
 800bfea:	bd13      	pop	{r0, r1, r4, pc}
 800bfec:	64a3      	str	r3, [r4, #72]	; 0x48
 800bfee:	64e3      	str	r3, [r4, #76]	; 0x4c
 800bff0:	6523      	str	r3, [r4, #80]	; 0x50
 800bff2:	4b13      	ldr	r3, [pc, #76]	; (800c040 <__sinit+0x68>)
 800bff4:	4a13      	ldr	r2, [pc, #76]	; (800c044 <__sinit+0x6c>)
 800bff6:	681b      	ldr	r3, [r3, #0]
 800bff8:	62a2      	str	r2, [r4, #40]	; 0x28
 800bffa:	9301      	str	r3, [sp, #4]
 800bffc:	42a3      	cmp	r3, r4
 800bffe:	d101      	bne.n	800c004 <__sinit+0x2c>
 800c000:	2301      	movs	r3, #1
 800c002:	61a3      	str	r3, [r4, #24]
 800c004:	0020      	movs	r0, r4
 800c006:	f000 f81f 	bl	800c048 <__sfp>
 800c00a:	6060      	str	r0, [r4, #4]
 800c00c:	0020      	movs	r0, r4
 800c00e:	f000 f81b 	bl	800c048 <__sfp>
 800c012:	60a0      	str	r0, [r4, #8]
 800c014:	0020      	movs	r0, r4
 800c016:	f000 f817 	bl	800c048 <__sfp>
 800c01a:	2200      	movs	r2, #0
 800c01c:	2104      	movs	r1, #4
 800c01e:	60e0      	str	r0, [r4, #12]
 800c020:	6860      	ldr	r0, [r4, #4]
 800c022:	f7ff ff77 	bl	800bf14 <std>
 800c026:	2201      	movs	r2, #1
 800c028:	2109      	movs	r1, #9
 800c02a:	68a0      	ldr	r0, [r4, #8]
 800c02c:	f7ff ff72 	bl	800bf14 <std>
 800c030:	2202      	movs	r2, #2
 800c032:	2112      	movs	r1, #18
 800c034:	68e0      	ldr	r0, [r4, #12]
 800c036:	f7ff ff6d 	bl	800bf14 <std>
 800c03a:	2301      	movs	r3, #1
 800c03c:	61a3      	str	r3, [r4, #24]
 800c03e:	e7d2      	b.n	800bfe6 <__sinit+0xe>
 800c040:	0800f0b4 	.word	0x0800f0b4
 800c044:	0800bf5d 	.word	0x0800bf5d

0800c048 <__sfp>:
 800c048:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 800c04a:	0007      	movs	r7, r0
 800c04c:	f7ff ffa4 	bl	800bf98 <__sfp_lock_acquire>
 800c050:	4b1f      	ldr	r3, [pc, #124]	; (800c0d0 <__sfp+0x88>)
 800c052:	681e      	ldr	r6, [r3, #0]
 800c054:	69b3      	ldr	r3, [r6, #24]
 800c056:	2b00      	cmp	r3, #0
 800c058:	d102      	bne.n	800c060 <__sfp+0x18>
 800c05a:	0030      	movs	r0, r6
 800c05c:	f7ff ffbc 	bl	800bfd8 <__sinit>
 800c060:	3648      	adds	r6, #72	; 0x48
 800c062:	68b4      	ldr	r4, [r6, #8]
 800c064:	6873      	ldr	r3, [r6, #4]
 800c066:	3b01      	subs	r3, #1
 800c068:	d504      	bpl.n	800c074 <__sfp+0x2c>
 800c06a:	6833      	ldr	r3, [r6, #0]
 800c06c:	2b00      	cmp	r3, #0
 800c06e:	d022      	beq.n	800c0b6 <__sfp+0x6e>
 800c070:	6836      	ldr	r6, [r6, #0]
 800c072:	e7f6      	b.n	800c062 <__sfp+0x1a>
 800c074:	220c      	movs	r2, #12
 800c076:	5ea5      	ldrsh	r5, [r4, r2]
 800c078:	2d00      	cmp	r5, #0
 800c07a:	d11a      	bne.n	800c0b2 <__sfp+0x6a>
 800c07c:	0020      	movs	r0, r4
 800c07e:	4b15      	ldr	r3, [pc, #84]	; (800c0d4 <__sfp+0x8c>)
 800c080:	3058      	adds	r0, #88	; 0x58
 800c082:	60e3      	str	r3, [r4, #12]
 800c084:	6665      	str	r5, [r4, #100]	; 0x64
 800c086:	f000 f847 	bl	800c118 <__retarget_lock_init_recursive>
 800c08a:	f7ff ff8d 	bl	800bfa8 <__sfp_lock_release>
 800c08e:	0020      	movs	r0, r4
 800c090:	2208      	movs	r2, #8
 800c092:	0029      	movs	r1, r5
 800c094:	6025      	str	r5, [r4, #0]
 800c096:	60a5      	str	r5, [r4, #8]
 800c098:	6065      	str	r5, [r4, #4]
 800c09a:	6125      	str	r5, [r4, #16]
 800c09c:	6165      	str	r5, [r4, #20]
 800c09e:	61a5      	str	r5, [r4, #24]
 800c0a0:	305c      	adds	r0, #92	; 0x5c
 800c0a2:	f7fd fded 	bl	8009c80 <memset>
 800c0a6:	6365      	str	r5, [r4, #52]	; 0x34
 800c0a8:	63a5      	str	r5, [r4, #56]	; 0x38
 800c0aa:	64a5      	str	r5, [r4, #72]	; 0x48
 800c0ac:	64e5      	str	r5, [r4, #76]	; 0x4c
 800c0ae:	0020      	movs	r0, r4
 800c0b0:	bdf8      	pop	{r3, r4, r5, r6, r7, pc}
 800c0b2:	3468      	adds	r4, #104	; 0x68
 800c0b4:	e7d7      	b.n	800c066 <__sfp+0x1e>
 800c0b6:	2104      	movs	r1, #4
 800c0b8:	0038      	movs	r0, r7
 800c0ba:	f7ff ff57 	bl	800bf6c <__sfmoreglue>
 800c0be:	1e04      	subs	r4, r0, #0
 800c0c0:	6030      	str	r0, [r6, #0]
 800c0c2:	d1d5      	bne.n	800c070 <__sfp+0x28>
 800c0c4:	f7ff ff70 	bl	800bfa8 <__sfp_lock_release>
 800c0c8:	230c      	movs	r3, #12
 800c0ca:	603b      	str	r3, [r7, #0]
 800c0cc:	e7ef      	b.n	800c0ae <__sfp+0x66>
 800c0ce:	46c0      	nop			; (mov r8, r8)
 800c0d0:	0800f0b4 	.word	0x0800f0b4
 800c0d4:	ffff0001 	.word	0xffff0001

0800c0d8 <_fwalk_reent>:
 800c0d8:	b5f7      	push	{r0, r1, r2, r4, r5, r6, r7, lr}
 800c0da:	0004      	movs	r4, r0
 800c0dc:	0006      	movs	r6, r0
 800c0de:	2700      	movs	r7, #0
 800c0e0:	9101      	str	r1, [sp, #4]
 800c0e2:	3448      	adds	r4, #72	; 0x48
 800c0e4:	6863      	ldr	r3, [r4, #4]
 800c0e6:	68a5      	ldr	r5, [r4, #8]
 800c0e8:	9300      	str	r3, [sp, #0]
 800c0ea:	9b00      	ldr	r3, [sp, #0]
 800c0ec:	3b01      	subs	r3, #1
 800c0ee:	9300      	str	r3, [sp, #0]
 800c0f0:	d504      	bpl.n	800c0fc <_fwalk_reent+0x24>
 800c0f2:	6824      	ldr	r4, [r4, #0]
 800c0f4:	2c00      	cmp	r4, #0
 800c0f6:	d1f5      	bne.n	800c0e4 <_fwalk_reent+0xc>
 800c0f8:	0038      	movs	r0, r7
 800c0fa:	bdfe      	pop	{r1, r2, r3, r4, r5, r6, r7, pc}
 800c0fc:	89ab      	ldrh	r3, [r5, #12]
 800c0fe:	2b01      	cmp	r3, #1
 800c100:	d908      	bls.n	800c114 <_fwalk_reent+0x3c>
 800c102:	220e      	movs	r2, #14
 800c104:	5eab      	ldrsh	r3, [r5, r2]
 800c106:	3301      	adds	r3, #1
 800c108:	d004      	beq.n	800c114 <_fwalk_reent+0x3c>
 800c10a:	0029      	movs	r1, r5
 800c10c:	0030      	movs	r0, r6
 800c10e:	9b01      	ldr	r3, [sp, #4]
 800c110:	4798      	blx	r3
 800c112:	4307      	orrs	r7, r0
 800c114:	3568      	adds	r5, #104	; 0x68
 800c116:	e7e8      	b.n	800c0ea <_fwalk_reent+0x12>

0800c118 <__retarget_lock_init_recursive>:
 800c118:	4770      	bx	lr

0800c11a <__retarget_lock_acquire_recursive>:
 800c11a:	4770      	bx	lr

0800c11c <__retarget_lock_release_recursive>:
 800c11c:	4770      	bx	lr
	...

0800c120 <__swhatbuf_r>:
 800c120:	b570      	push	{r4, r5, r6, lr}
 800c122:	000e      	movs	r6, r1
 800c124:	001d      	movs	r5, r3
 800c126:	230e      	movs	r3, #14
 800c128:	5ec9      	ldrsh	r1, [r1, r3]
 800c12a:	0014      	movs	r4, r2
 800c12c:	b096      	sub	sp, #88	; 0x58
 800c12e:	2900      	cmp	r1, #0
 800c130:	da07      	bge.n	800c142 <__swhatbuf_r+0x22>
 800c132:	2300      	movs	r3, #0
 800c134:	602b      	str	r3, [r5, #0]
 800c136:	89b3      	ldrh	r3, [r6, #12]
 800c138:	061b      	lsls	r3, r3, #24
 800c13a:	d411      	bmi.n	800c160 <__swhatbuf_r+0x40>
 800c13c:	2380      	movs	r3, #128	; 0x80
 800c13e:	00db      	lsls	r3, r3, #3
 800c140:	e00f      	b.n	800c162 <__swhatbuf_r+0x42>
 800c142:	466a      	mov	r2, sp
 800c144:	f000 f928 	bl	800c398 <_fstat_r>
 800c148:	2800      	cmp	r0, #0
 800c14a:	dbf2      	blt.n	800c132 <__swhatbuf_r+0x12>
 800c14c:	23f0      	movs	r3, #240	; 0xf0
 800c14e:	9901      	ldr	r1, [sp, #4]
 800c150:	021b      	lsls	r3, r3, #8
 800c152:	4019      	ands	r1, r3
 800c154:	4b05      	ldr	r3, [pc, #20]	; (800c16c <__swhatbuf_r+0x4c>)
 800c156:	18c9      	adds	r1, r1, r3
 800c158:	424b      	negs	r3, r1
 800c15a:	4159      	adcs	r1, r3
 800c15c:	6029      	str	r1, [r5, #0]
 800c15e:	e7ed      	b.n	800c13c <__swhatbuf_r+0x1c>
 800c160:	2340      	movs	r3, #64	; 0x40
 800c162:	2000      	movs	r0, #0
 800c164:	6023      	str	r3, [r4, #0]
 800c166:	b016      	add	sp, #88	; 0x58
 800c168:	bd70      	pop	{r4, r5, r6, pc}
 800c16a:	46c0      	nop			; (mov r8, r8)
 800c16c:	ffffe000 	.word	0xffffe000

0800c170 <__smakebuf_r>:
 800c170:	b5f7      	push	{r0, r1, r2, r4, r5, r6, r7, lr}
 800c172:	2602      	movs	r6, #2
 800c174:	898b      	ldrh	r3, [r1, #12]
 800c176:	0005      	movs	r5, r0
 800c178:	000c      	movs	r4, r1
 800c17a:	4233      	tst	r3, r6
 800c17c:	d006      	beq.n	800c18c <__smakebuf_r+0x1c>
 800c17e:	0023      	movs	r3, r4
 800c180:	3347      	adds	r3, #71	; 0x47
 800c182:	6023      	str	r3, [r4, #0]
 800c184:	6123      	str	r3, [r4, #16]
 800c186:	2301      	movs	r3, #1
 800c188:	6163      	str	r3, [r4, #20]
 800c18a:	bdf7      	pop	{r0, r1, r2, r4, r5, r6, r7, pc}
 800c18c:	466a      	mov	r2, sp
 800c18e:	ab01      	add	r3, sp, #4
 800c190:	f7ff ffc6 	bl	800c120 <__swhatbuf_r>
 800c194:	9900      	ldr	r1, [sp, #0]
 800c196:	0007      	movs	r7, r0
 800c198:	0028      	movs	r0, r5
 800c19a:	f7fd fdc3 	bl	8009d24 <_malloc_r>
 800c19e:	2800      	cmp	r0, #0
 800c1a0:	d108      	bne.n	800c1b4 <__smakebuf_r+0x44>
 800c1a2:	220c      	movs	r2, #12
 800c1a4:	5ea3      	ldrsh	r3, [r4, r2]
 800c1a6:	059a      	lsls	r2, r3, #22
 800c1a8:	d4ef      	bmi.n	800c18a <__smakebuf_r+0x1a>
 800c1aa:	2203      	movs	r2, #3
 800c1ac:	4393      	bics	r3, r2
 800c1ae:	431e      	orrs	r6, r3
 800c1b0:	81a6      	strh	r6, [r4, #12]
 800c1b2:	e7e4      	b.n	800c17e <__smakebuf_r+0xe>
 800c1b4:	4b0f      	ldr	r3, [pc, #60]	; (800c1f4 <__smakebuf_r+0x84>)
 800c1b6:	62ab      	str	r3, [r5, #40]	; 0x28
 800c1b8:	2380      	movs	r3, #128	; 0x80
 800c1ba:	89a2      	ldrh	r2, [r4, #12]
 800c1bc:	6020      	str	r0, [r4, #0]
 800c1be:	4313      	orrs	r3, r2
 800c1c0:	81a3      	strh	r3, [r4, #12]
 800c1c2:	9b00      	ldr	r3, [sp, #0]
 800c1c4:	6120      	str	r0, [r4, #16]
 800c1c6:	6163      	str	r3, [r4, #20]
 800c1c8:	9b01      	ldr	r3, [sp, #4]
 800c1ca:	2b00      	cmp	r3, #0
 800c1cc:	d00d      	beq.n	800c1ea <__smakebuf_r+0x7a>
 800c1ce:	0028      	movs	r0, r5
 800c1d0:	230e      	movs	r3, #14
 800c1d2:	5ee1      	ldrsh	r1, [r4, r3]
 800c1d4:	f000 f8f2 	bl	800c3bc <_isatty_r>
 800c1d8:	2800      	cmp	r0, #0
 800c1da:	d006      	beq.n	800c1ea <__smakebuf_r+0x7a>
 800c1dc:	2203      	movs	r2, #3
 800c1de:	89a3      	ldrh	r3, [r4, #12]
 800c1e0:	4393      	bics	r3, r2
 800c1e2:	001a      	movs	r2, r3
 800c1e4:	2301      	movs	r3, #1
 800c1e6:	4313      	orrs	r3, r2
 800c1e8:	81a3      	strh	r3, [r4, #12]
 800c1ea:	89a0      	ldrh	r0, [r4, #12]
 800c1ec:	4307      	orrs	r7, r0
 800c1ee:	81a7      	strh	r7, [r4, #12]
 800c1f0:	e7cb      	b.n	800c18a <__smakebuf_r+0x1a>
 800c1f2:	46c0      	nop			; (mov r8, r8)
 800c1f4:	0800bf5d 	.word	0x0800bf5d

0800c1f8 <memchr>:
 800c1f8:	b2c9      	uxtb	r1, r1
 800c1fa:	1882      	adds	r2, r0, r2
 800c1fc:	4290      	cmp	r0, r2
 800c1fe:	d101      	bne.n	800c204 <memchr+0xc>
 800c200:	2000      	movs	r0, #0
 800c202:	4770      	bx	lr
 800c204:	7803      	ldrb	r3, [r0, #0]
 800c206:	428b      	cmp	r3, r1
 800c208:	d0fb      	beq.n	800c202 <memchr+0xa>
 800c20a:	3001      	adds	r0, #1
 800c20c:	e7f6      	b.n	800c1fc <memchr+0x4>

0800c20e <memcpy>:
 800c20e:	2300      	movs	r3, #0
 800c210:	b510      	push	{r4, lr}
 800c212:	429a      	cmp	r2, r3
 800c214:	d100      	bne.n	800c218 <memcpy+0xa>
 800c216:	bd10      	pop	{r4, pc}
 800c218:	5ccc      	ldrb	r4, [r1, r3]
 800c21a:	54c4      	strb	r4, [r0, r3]
 800c21c:	3301      	adds	r3, #1
 800c21e:	e7f8      	b.n	800c212 <memcpy+0x4>

0800c220 <_raise_r>:
 800c220:	b570      	push	{r4, r5, r6, lr}
 800c222:	0004      	movs	r4, r0
 800c224:	000d      	movs	r5, r1
 800c226:	291f      	cmp	r1, #31
 800c228:	d904      	bls.n	800c234 <_raise_r+0x14>
 800c22a:	2316      	movs	r3, #22
 800c22c:	6003      	str	r3, [r0, #0]
 800c22e:	2001      	movs	r0, #1
 800c230:	4240      	negs	r0, r0
 800c232:	bd70      	pop	{r4, r5, r6, pc}
 800c234:	6c43      	ldr	r3, [r0, #68]	; 0x44
 800c236:	2b00      	cmp	r3, #0
 800c238:	d004      	beq.n	800c244 <_raise_r+0x24>
 800c23a:	008a      	lsls	r2, r1, #2
 800c23c:	189b      	adds	r3, r3, r2
 800c23e:	681a      	ldr	r2, [r3, #0]
 800c240:	2a00      	cmp	r2, #0
 800c242:	d108      	bne.n	800c256 <_raise_r+0x36>
 800c244:	0020      	movs	r0, r4
 800c246:	f000 f831 	bl	800c2ac <_getpid_r>
 800c24a:	002a      	movs	r2, r5
 800c24c:	0001      	movs	r1, r0
 800c24e:	0020      	movs	r0, r4
 800c250:	f000 f81a 	bl	800c288 <_kill_r>
 800c254:	e7ed      	b.n	800c232 <_raise_r+0x12>
 800c256:	2000      	movs	r0, #0
 800c258:	2a01      	cmp	r2, #1
 800c25a:	d0ea      	beq.n	800c232 <_raise_r+0x12>
 800c25c:	1c51      	adds	r1, r2, #1
 800c25e:	d103      	bne.n	800c268 <_raise_r+0x48>
 800c260:	2316      	movs	r3, #22
 800c262:	3001      	adds	r0, #1
 800c264:	6023      	str	r3, [r4, #0]
 800c266:	e7e4      	b.n	800c232 <_raise_r+0x12>
 800c268:	2400      	movs	r4, #0
 800c26a:	0028      	movs	r0, r5
 800c26c:	601c      	str	r4, [r3, #0]
 800c26e:	4790      	blx	r2
 800c270:	0020      	movs	r0, r4
 800c272:	e7de      	b.n	800c232 <_raise_r+0x12>

0800c274 <raise>:
 800c274:	b510      	push	{r4, lr}
 800c276:	4b03      	ldr	r3, [pc, #12]	; (800c284 <raise+0x10>)
 800c278:	0001      	movs	r1, r0
 800c27a:	6818      	ldr	r0, [r3, #0]
 800c27c:	f7ff ffd0 	bl	800c220 <_raise_r>
 800c280:	bd10      	pop	{r4, pc}
 800c282:	46c0      	nop			; (mov r8, r8)
 800c284:	20000088 	.word	0x20000088

0800c288 <_kill_r>:
 800c288:	2300      	movs	r3, #0
 800c28a:	b570      	push	{r4, r5, r6, lr}
 800c28c:	4d06      	ldr	r5, [pc, #24]	; (800c2a8 <_kill_r+0x20>)
 800c28e:	0004      	movs	r4, r0
 800c290:	0008      	movs	r0, r1
 800c292:	0011      	movs	r1, r2
 800c294:	602b      	str	r3, [r5, #0]
 800c296:	f7f9 fa1b 	bl	80056d0 <_kill>
 800c29a:	1c43      	adds	r3, r0, #1
 800c29c:	d103      	bne.n	800c2a6 <_kill_r+0x1e>
 800c29e:	682b      	ldr	r3, [r5, #0]
 800c2a0:	2b00      	cmp	r3, #0
 800c2a2:	d000      	beq.n	800c2a6 <_kill_r+0x1e>
 800c2a4:	6023      	str	r3, [r4, #0]
 800c2a6:	bd70      	pop	{r4, r5, r6, pc}
 800c2a8:	200022dc 	.word	0x200022dc

0800c2ac <_getpid_r>:
 800c2ac:	b510      	push	{r4, lr}
 800c2ae:	f7f9 fa09 	bl	80056c4 <_getpid>
 800c2b2:	bd10      	pop	{r4, pc}

0800c2b4 <__sread>:
 800c2b4:	b570      	push	{r4, r5, r6, lr}
 800c2b6:	000c      	movs	r4, r1
 800c2b8:	250e      	movs	r5, #14
 800c2ba:	5f49      	ldrsh	r1, [r1, r5]
 800c2bc:	f000 f8a4 	bl	800c408 <_read_r>
 800c2c0:	2800      	cmp	r0, #0
 800c2c2:	db03      	blt.n	800c2cc <__sread+0x18>
 800c2c4:	6d63      	ldr	r3, [r4, #84]	; 0x54
 800c2c6:	181b      	adds	r3, r3, r0
 800c2c8:	6563      	str	r3, [r4, #84]	; 0x54
 800c2ca:	bd70      	pop	{r4, r5, r6, pc}
 800c2cc:	89a3      	ldrh	r3, [r4, #12]
 800c2ce:	4a02      	ldr	r2, [pc, #8]	; (800c2d8 <__sread+0x24>)
 800c2d0:	4013      	ands	r3, r2
 800c2d2:	81a3      	strh	r3, [r4, #12]
 800c2d4:	e7f9      	b.n	800c2ca <__sread+0x16>
 800c2d6:	46c0      	nop			; (mov r8, r8)
 800c2d8:	ffffefff 	.word	0xffffefff

0800c2dc <__swrite>:
 800c2dc:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 800c2de:	001f      	movs	r7, r3
 800c2e0:	898b      	ldrh	r3, [r1, #12]
 800c2e2:	0005      	movs	r5, r0
 800c2e4:	000c      	movs	r4, r1
 800c2e6:	0016      	movs	r6, r2
 800c2e8:	05db      	lsls	r3, r3, #23
 800c2ea:	d505      	bpl.n	800c2f8 <__swrite+0x1c>
 800c2ec:	230e      	movs	r3, #14
 800c2ee:	5ec9      	ldrsh	r1, [r1, r3]
 800c2f0:	2200      	movs	r2, #0
 800c2f2:	2302      	movs	r3, #2
 800c2f4:	f000 f874 	bl	800c3e0 <_lseek_r>
 800c2f8:	89a3      	ldrh	r3, [r4, #12]
 800c2fa:	4a05      	ldr	r2, [pc, #20]	; (800c310 <__swrite+0x34>)
 800c2fc:	0028      	movs	r0, r5
 800c2fe:	4013      	ands	r3, r2
 800c300:	81a3      	strh	r3, [r4, #12]
 800c302:	0032      	movs	r2, r6
 800c304:	230e      	movs	r3, #14
 800c306:	5ee1      	ldrsh	r1, [r4, r3]
 800c308:	003b      	movs	r3, r7
 800c30a:	f000 f81f 	bl	800c34c <_write_r>
 800c30e:	bdf8      	pop	{r3, r4, r5, r6, r7, pc}
 800c310:	ffffefff 	.word	0xffffefff

0800c314 <__sseek>:
 800c314:	b570      	push	{r4, r5, r6, lr}
 800c316:	000c      	movs	r4, r1
 800c318:	250e      	movs	r5, #14
 800c31a:	5f49      	ldrsh	r1, [r1, r5]
 800c31c:	f000 f860 	bl	800c3e0 <_lseek_r>
 800c320:	89a3      	ldrh	r3, [r4, #12]
 800c322:	1c42      	adds	r2, r0, #1
 800c324:	d103      	bne.n	800c32e <__sseek+0x1a>
 800c326:	4a05      	ldr	r2, [pc, #20]	; (800c33c <__sseek+0x28>)
 800c328:	4013      	ands	r3, r2
 800c32a:	81a3      	strh	r3, [r4, #12]
 800c32c:	bd70      	pop	{r4, r5, r6, pc}
 800c32e:	2280      	movs	r2, #128	; 0x80
 800c330:	0152      	lsls	r2, r2, #5
 800c332:	4313      	orrs	r3, r2
 800c334:	81a3      	strh	r3, [r4, #12]
 800c336:	6560      	str	r0, [r4, #84]	; 0x54
 800c338:	e7f8      	b.n	800c32c <__sseek+0x18>
 800c33a:	46c0      	nop			; (mov r8, r8)
 800c33c:	ffffefff 	.word	0xffffefff

0800c340 <__sclose>:
 800c340:	b510      	push	{r4, lr}
 800c342:	230e      	movs	r3, #14
 800c344:	5ec9      	ldrsh	r1, [r1, r3]
 800c346:	f000 f815 	bl	800c374 <_close_r>
 800c34a:	bd10      	pop	{r4, pc}

0800c34c <_write_r>:
 800c34c:	b570      	push	{r4, r5, r6, lr}
 800c34e:	0004      	movs	r4, r0
 800c350:	0008      	movs	r0, r1
 800c352:	0011      	movs	r1, r2
 800c354:	001a      	movs	r2, r3
 800c356:	2300      	movs	r3, #0
 800c358:	4d05      	ldr	r5, [pc, #20]	; (800c370 <_write_r+0x24>)
 800c35a:	602b      	str	r3, [r5, #0]
 800c35c:	f7f9 f9f1 	bl	8005742 <_write>
 800c360:	1c43      	adds	r3, r0, #1
 800c362:	d103      	bne.n	800c36c <_write_r+0x20>
 800c364:	682b      	ldr	r3, [r5, #0]
 800c366:	2b00      	cmp	r3, #0
 800c368:	d000      	beq.n	800c36c <_write_r+0x20>
 800c36a:	6023      	str	r3, [r4, #0]
 800c36c:	bd70      	pop	{r4, r5, r6, pc}
 800c36e:	46c0      	nop			; (mov r8, r8)
 800c370:	200022dc 	.word	0x200022dc

0800c374 <_close_r>:
 800c374:	2300      	movs	r3, #0
 800c376:	b570      	push	{r4, r5, r6, lr}
 800c378:	4d06      	ldr	r5, [pc, #24]	; (800c394 <_close_r+0x20>)
 800c37a:	0004      	movs	r4, r0
 800c37c:	0008      	movs	r0, r1
 800c37e:	602b      	str	r3, [r5, #0]
 800c380:	f7f9 f9fb 	bl	800577a <_close>
 800c384:	1c43      	adds	r3, r0, #1
 800c386:	d103      	bne.n	800c390 <_close_r+0x1c>
 800c388:	682b      	ldr	r3, [r5, #0]
 800c38a:	2b00      	cmp	r3, #0
 800c38c:	d000      	beq.n	800c390 <_close_r+0x1c>
 800c38e:	6023      	str	r3, [r4, #0]
 800c390:	bd70      	pop	{r4, r5, r6, pc}
 800c392:	46c0      	nop			; (mov r8, r8)
 800c394:	200022dc 	.word	0x200022dc

0800c398 <_fstat_r>:
 800c398:	2300      	movs	r3, #0
 800c39a:	b570      	push	{r4, r5, r6, lr}
 800c39c:	4d06      	ldr	r5, [pc, #24]	; (800c3b8 <_fstat_r+0x20>)
 800c39e:	0004      	movs	r4, r0
 800c3a0:	0008      	movs	r0, r1
 800c3a2:	0011      	movs	r1, r2
 800c3a4:	602b      	str	r3, [r5, #0]
 800c3a6:	f7f9 f9f2 	bl	800578e <_fstat>
 800c3aa:	1c43      	adds	r3, r0, #1
 800c3ac:	d103      	bne.n	800c3b6 <_fstat_r+0x1e>
 800c3ae:	682b      	ldr	r3, [r5, #0]
 800c3b0:	2b00      	cmp	r3, #0
 800c3b2:	d000      	beq.n	800c3b6 <_fstat_r+0x1e>
 800c3b4:	6023      	str	r3, [r4, #0]
 800c3b6:	bd70      	pop	{r4, r5, r6, pc}
 800c3b8:	200022dc 	.word	0x200022dc

0800c3bc <_isatty_r>:
 800c3bc:	2300      	movs	r3, #0
 800c3be:	b570      	push	{r4, r5, r6, lr}
 800c3c0:	4d06      	ldr	r5, [pc, #24]	; (800c3dc <_isatty_r+0x20>)
 800c3c2:	0004      	movs	r4, r0
 800c3c4:	0008      	movs	r0, r1
 800c3c6:	602b      	str	r3, [r5, #0]
 800c3c8:	f7f9 f9ef 	bl	80057aa <_isatty>
 800c3cc:	1c43      	adds	r3, r0, #1
 800c3ce:	d103      	bne.n	800c3d8 <_isatty_r+0x1c>
 800c3d0:	682b      	ldr	r3, [r5, #0]
 800c3d2:	2b00      	cmp	r3, #0
 800c3d4:	d000      	beq.n	800c3d8 <_isatty_r+0x1c>
 800c3d6:	6023      	str	r3, [r4, #0]
 800c3d8:	bd70      	pop	{r4, r5, r6, pc}
 800c3da:	46c0      	nop			; (mov r8, r8)
 800c3dc:	200022dc 	.word	0x200022dc

0800c3e0 <_lseek_r>:
 800c3e0:	b570      	push	{r4, r5, r6, lr}
 800c3e2:	0004      	movs	r4, r0
 800c3e4:	0008      	movs	r0, r1
 800c3e6:	0011      	movs	r1, r2
 800c3e8:	001a      	movs	r2, r3
 800c3ea:	2300      	movs	r3, #0
 800c3ec:	4d05      	ldr	r5, [pc, #20]	; (800c404 <_lseek_r+0x24>)
 800c3ee:	602b      	str	r3, [r5, #0]
 800c3f0:	f7f9 f9e4 	bl	80057bc <_lseek>
 800c3f4:	1c43      	adds	r3, r0, #1
 800c3f6:	d103      	bne.n	800c400 <_lseek_r+0x20>
 800c3f8:	682b      	ldr	r3, [r5, #0]
 800c3fa:	2b00      	cmp	r3, #0
 800c3fc:	d000      	beq.n	800c400 <_lseek_r+0x20>
 800c3fe:	6023      	str	r3, [r4, #0]
 800c400:	bd70      	pop	{r4, r5, r6, pc}
 800c402:	46c0      	nop			; (mov r8, r8)
 800c404:	200022dc 	.word	0x200022dc

0800c408 <_read_r>:
 800c408:	b570      	push	{r4, r5, r6, lr}
 800c40a:	0004      	movs	r4, r0
 800c40c:	0008      	movs	r0, r1
 800c40e:	0011      	movs	r1, r2
 800c410:	001a      	movs	r2, r3
 800c412:	2300      	movs	r3, #0
 800c414:	4d05      	ldr	r5, [pc, #20]	; (800c42c <_read_r+0x24>)
 800c416:	602b      	str	r3, [r5, #0]
 800c418:	f7f9 f976 	bl	8005708 <_read>
 800c41c:	1c43      	adds	r3, r0, #1
 800c41e:	d103      	bne.n	800c428 <_read_r+0x20>
 800c420:	682b      	ldr	r3, [r5, #0]
 800c422:	2b00      	cmp	r3, #0
 800c424:	d000      	beq.n	800c428 <_read_r+0x20>
 800c426:	6023      	str	r3, [r4, #0]
 800c428:	bd70      	pop	{r4, r5, r6, pc}
 800c42a:	46c0      	nop			; (mov r8, r8)
 800c42c:	200022dc 	.word	0x200022dc

0800c430 <cos>:
 800c430:	b5f0      	push	{r4, r5, r6, r7, lr}
 800c432:	4a1e      	ldr	r2, [pc, #120]	; (800c4ac <cos+0x7c>)
 800c434:	004b      	lsls	r3, r1, #1
 800c436:	b087      	sub	sp, #28
 800c438:	085b      	lsrs	r3, r3, #1
 800c43a:	4293      	cmp	r3, r2
 800c43c:	dc04      	bgt.n	800c448 <cos+0x18>
 800c43e:	2200      	movs	r2, #0
 800c440:	2300      	movs	r3, #0
 800c442:	f001 f903 	bl	800d64c <__kernel_cos>
 800c446:	e006      	b.n	800c456 <cos+0x26>
 800c448:	4a19      	ldr	r2, [pc, #100]	; (800c4b0 <cos+0x80>)
 800c44a:	4293      	cmp	r3, r2
 800c44c:	dd05      	ble.n	800c45a <cos+0x2a>
 800c44e:	0002      	movs	r2, r0
 800c450:	000b      	movs	r3, r1
 800c452:	f7f5 ffad 	bl	80023b0 <__aeabi_dsub>
 800c456:	b007      	add	sp, #28
 800c458:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800c45a:	aa02      	add	r2, sp, #8
 800c45c:	f000 fe56 	bl	800d10c <__ieee754_rem_pio2>
 800c460:	9c04      	ldr	r4, [sp, #16]
 800c462:	9d05      	ldr	r5, [sp, #20]
 800c464:	2303      	movs	r3, #3
 800c466:	4003      	ands	r3, r0
 800c468:	2b01      	cmp	r3, #1
 800c46a:	d008      	beq.n	800c47e <cos+0x4e>
 800c46c:	9802      	ldr	r0, [sp, #8]
 800c46e:	9903      	ldr	r1, [sp, #12]
 800c470:	2b02      	cmp	r3, #2
 800c472:	d00f      	beq.n	800c494 <cos+0x64>
 800c474:	2b00      	cmp	r3, #0
 800c476:	d112      	bne.n	800c49e <cos+0x6e>
 800c478:	0022      	movs	r2, r4
 800c47a:	002b      	movs	r3, r5
 800c47c:	e7e1      	b.n	800c442 <cos+0x12>
 800c47e:	9300      	str	r3, [sp, #0]
 800c480:	0022      	movs	r2, r4
 800c482:	9802      	ldr	r0, [sp, #8]
 800c484:	9903      	ldr	r1, [sp, #12]
 800c486:	002b      	movs	r3, r5
 800c488:	f001 fd16 	bl	800deb8 <__kernel_sin>
 800c48c:	2380      	movs	r3, #128	; 0x80
 800c48e:	061b      	lsls	r3, r3, #24
 800c490:	18c9      	adds	r1, r1, r3
 800c492:	e7e0      	b.n	800c456 <cos+0x26>
 800c494:	0022      	movs	r2, r4
 800c496:	002b      	movs	r3, r5
 800c498:	f001 f8d8 	bl	800d64c <__kernel_cos>
 800c49c:	e7f6      	b.n	800c48c <cos+0x5c>
 800c49e:	2301      	movs	r3, #1
 800c4a0:	0022      	movs	r2, r4
 800c4a2:	9300      	str	r3, [sp, #0]
 800c4a4:	002b      	movs	r3, r5
 800c4a6:	f001 fd07 	bl	800deb8 <__kernel_sin>
 800c4aa:	e7d4      	b.n	800c456 <cos+0x26>
 800c4ac:	3fe921fb 	.word	0x3fe921fb
 800c4b0:	7fefffff 	.word	0x7fefffff

0800c4b4 <sin>:
 800c4b4:	b5f0      	push	{r4, r5, r6, r7, lr}
 800c4b6:	4a20      	ldr	r2, [pc, #128]	; (800c538 <sin+0x84>)
 800c4b8:	004b      	lsls	r3, r1, #1
 800c4ba:	b087      	sub	sp, #28
 800c4bc:	085b      	lsrs	r3, r3, #1
 800c4be:	4293      	cmp	r3, r2
 800c4c0:	dc06      	bgt.n	800c4d0 <sin+0x1c>
 800c4c2:	2300      	movs	r3, #0
 800c4c4:	2200      	movs	r2, #0
 800c4c6:	9300      	str	r3, [sp, #0]
 800c4c8:	2300      	movs	r3, #0
 800c4ca:	f001 fcf5 	bl	800deb8 <__kernel_sin>
 800c4ce:	e006      	b.n	800c4de <sin+0x2a>
 800c4d0:	4a1a      	ldr	r2, [pc, #104]	; (800c53c <sin+0x88>)
 800c4d2:	4293      	cmp	r3, r2
 800c4d4:	dd05      	ble.n	800c4e2 <sin+0x2e>
 800c4d6:	0002      	movs	r2, r0
 800c4d8:	000b      	movs	r3, r1
 800c4da:	f7f5 ff69 	bl	80023b0 <__aeabi_dsub>
 800c4de:	b007      	add	sp, #28
 800c4e0:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800c4e2:	aa02      	add	r2, sp, #8
 800c4e4:	f000 fe12 	bl	800d10c <__ieee754_rem_pio2>
 800c4e8:	9c04      	ldr	r4, [sp, #16]
 800c4ea:	9d05      	ldr	r5, [sp, #20]
 800c4ec:	2303      	movs	r3, #3
 800c4ee:	4003      	ands	r3, r0
 800c4f0:	2b01      	cmp	r3, #1
 800c4f2:	d00a      	beq.n	800c50a <sin+0x56>
 800c4f4:	9802      	ldr	r0, [sp, #8]
 800c4f6:	9903      	ldr	r1, [sp, #12]
 800c4f8:	2b02      	cmp	r3, #2
 800c4fa:	d00d      	beq.n	800c518 <sin+0x64>
 800c4fc:	2b00      	cmp	r3, #0
 800c4fe:	d115      	bne.n	800c52c <sin+0x78>
 800c500:	3301      	adds	r3, #1
 800c502:	9300      	str	r3, [sp, #0]
 800c504:	0022      	movs	r2, r4
 800c506:	002b      	movs	r3, r5
 800c508:	e7df      	b.n	800c4ca <sin+0x16>
 800c50a:	0022      	movs	r2, r4
 800c50c:	9802      	ldr	r0, [sp, #8]
 800c50e:	9903      	ldr	r1, [sp, #12]
 800c510:	002b      	movs	r3, r5
 800c512:	f001 f89b 	bl	800d64c <__kernel_cos>
 800c516:	e7e2      	b.n	800c4de <sin+0x2a>
 800c518:	2301      	movs	r3, #1
 800c51a:	0022      	movs	r2, r4
 800c51c:	9300      	str	r3, [sp, #0]
 800c51e:	002b      	movs	r3, r5
 800c520:	f001 fcca 	bl	800deb8 <__kernel_sin>
 800c524:	2380      	movs	r3, #128	; 0x80
 800c526:	061b      	lsls	r3, r3, #24
 800c528:	18c9      	adds	r1, r1, r3
 800c52a:	e7d8      	b.n	800c4de <sin+0x2a>
 800c52c:	0022      	movs	r2, r4
 800c52e:	002b      	movs	r3, r5
 800c530:	f001 f88c 	bl	800d64c <__kernel_cos>
 800c534:	e7f6      	b.n	800c524 <sin+0x70>
 800c536:	46c0      	nop			; (mov r8, r8)
 800c538:	3fe921fb 	.word	0x3fe921fb
 800c53c:	7fefffff 	.word	0x7fefffff

0800c540 <pow>:
 800c540:	b5f7      	push	{r0, r1, r2, r4, r5, r6, r7, lr}
 800c542:	001d      	movs	r5, r3
 800c544:	0014      	movs	r4, r2
 800c546:	9000      	str	r0, [sp, #0]
 800c548:	9101      	str	r1, [sp, #4]
 800c54a:	f000 f8df 	bl	800c70c <__ieee754_pow>
 800c54e:	4b54      	ldr	r3, [pc, #336]	; (800c6a0 <pow+0x160>)
 800c550:	0006      	movs	r6, r0
 800c552:	781b      	ldrb	r3, [r3, #0]
 800c554:	000f      	movs	r7, r1
 800c556:	b25b      	sxtb	r3, r3
 800c558:	3301      	adds	r3, #1
 800c55a:	d018      	beq.n	800c58e <pow+0x4e>
 800c55c:	0022      	movs	r2, r4
 800c55e:	002b      	movs	r3, r5
 800c560:	0020      	movs	r0, r4
 800c562:	0029      	movs	r1, r5
 800c564:	f7f6 fda0 	bl	80030a8 <__aeabi_dcmpun>
 800c568:	2800      	cmp	r0, #0
 800c56a:	d110      	bne.n	800c58e <pow+0x4e>
 800c56c:	9a00      	ldr	r2, [sp, #0]
 800c56e:	9b01      	ldr	r3, [sp, #4]
 800c570:	0010      	movs	r0, r2
 800c572:	0019      	movs	r1, r3
 800c574:	f7f6 fd98 	bl	80030a8 <__aeabi_dcmpun>
 800c578:	2200      	movs	r2, #0
 800c57a:	2300      	movs	r3, #0
 800c57c:	2800      	cmp	r0, #0
 800c57e:	d00a      	beq.n	800c596 <pow+0x56>
 800c580:	0020      	movs	r0, r4
 800c582:	0029      	movs	r1, r5
 800c584:	f7f6 fbec 	bl	8002d60 <__aeabi_dcmpeq>
 800c588:	2800      	cmp	r0, #0
 800c58a:	d000      	beq.n	800c58e <pow+0x4e>
 800c58c:	e084      	b.n	800c698 <pow+0x158>
 800c58e:	0030      	movs	r0, r6
 800c590:	0039      	movs	r1, r7
 800c592:	b003      	add	sp, #12
 800c594:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800c596:	9800      	ldr	r0, [sp, #0]
 800c598:	9901      	ldr	r1, [sp, #4]
 800c59a:	f7f6 fbe1 	bl	8002d60 <__aeabi_dcmpeq>
 800c59e:	2800      	cmp	r0, #0
 800c5a0:	d01c      	beq.n	800c5dc <pow+0x9c>
 800c5a2:	2200      	movs	r2, #0
 800c5a4:	2300      	movs	r3, #0
 800c5a6:	0020      	movs	r0, r4
 800c5a8:	0029      	movs	r1, r5
 800c5aa:	f7f6 fbd9 	bl	8002d60 <__aeabi_dcmpeq>
 800c5ae:	2800      	cmp	r0, #0
 800c5b0:	d172      	bne.n	800c698 <pow+0x158>
 800c5b2:	0020      	movs	r0, r4
 800c5b4:	0029      	movs	r1, r5
 800c5b6:	f001 fd2f 	bl	800e018 <finite>
 800c5ba:	2800      	cmp	r0, #0
 800c5bc:	d0e7      	beq.n	800c58e <pow+0x4e>
 800c5be:	2200      	movs	r2, #0
 800c5c0:	2300      	movs	r3, #0
 800c5c2:	0020      	movs	r0, r4
 800c5c4:	0029      	movs	r1, r5
 800c5c6:	f7f6 fbd1 	bl	8002d6c <__aeabi_dcmplt>
 800c5ca:	2800      	cmp	r0, #0
 800c5cc:	d0df      	beq.n	800c58e <pow+0x4e>
 800c5ce:	f7fd fb23 	bl	8009c18 <__errno>
 800c5d2:	2321      	movs	r3, #33	; 0x21
 800c5d4:	2600      	movs	r6, #0
 800c5d6:	6003      	str	r3, [r0, #0]
 800c5d8:	4f32      	ldr	r7, [pc, #200]	; (800c6a4 <pow+0x164>)
 800c5da:	e7d8      	b.n	800c58e <pow+0x4e>
 800c5dc:	0030      	movs	r0, r6
 800c5de:	0039      	movs	r1, r7
 800c5e0:	f001 fd1a 	bl	800e018 <finite>
 800c5e4:	2800      	cmp	r0, #0
 800c5e6:	d139      	bne.n	800c65c <pow+0x11c>
 800c5e8:	9800      	ldr	r0, [sp, #0]
 800c5ea:	9901      	ldr	r1, [sp, #4]
 800c5ec:	f001 fd14 	bl	800e018 <finite>
 800c5f0:	2800      	cmp	r0, #0
 800c5f2:	d033      	beq.n	800c65c <pow+0x11c>
 800c5f4:	0020      	movs	r0, r4
 800c5f6:	0029      	movs	r1, r5
 800c5f8:	f001 fd0e 	bl	800e018 <finite>
 800c5fc:	2800      	cmp	r0, #0
 800c5fe:	d02d      	beq.n	800c65c <pow+0x11c>
 800c600:	0032      	movs	r2, r6
 800c602:	003b      	movs	r3, r7
 800c604:	0030      	movs	r0, r6
 800c606:	0039      	movs	r1, r7
 800c608:	f7f6 fd4e 	bl	80030a8 <__aeabi_dcmpun>
 800c60c:	2800      	cmp	r0, #0
 800c60e:	d00c      	beq.n	800c62a <pow+0xea>
 800c610:	f7fd fb02 	bl	8009c18 <__errno>
 800c614:	2321      	movs	r3, #33	; 0x21
 800c616:	2200      	movs	r2, #0
 800c618:	6003      	str	r3, [r0, #0]
 800c61a:	2300      	movs	r3, #0
 800c61c:	0010      	movs	r0, r2
 800c61e:	0019      	movs	r1, r3
 800c620:	f7f5 f972 	bl	8001908 <__aeabi_ddiv>
 800c624:	0006      	movs	r6, r0
 800c626:	000f      	movs	r7, r1
 800c628:	e7b1      	b.n	800c58e <pow+0x4e>
 800c62a:	f7fd faf5 	bl	8009c18 <__errno>
 800c62e:	2322      	movs	r3, #34	; 0x22
 800c630:	2200      	movs	r2, #0
 800c632:	6003      	str	r3, [r0, #0]
 800c634:	2300      	movs	r3, #0
 800c636:	9800      	ldr	r0, [sp, #0]
 800c638:	9901      	ldr	r1, [sp, #4]
 800c63a:	f7f6 fb97 	bl	8002d6c <__aeabi_dcmplt>
 800c63e:	2600      	movs	r6, #0
 800c640:	2800      	cmp	r0, #0
 800c642:	d009      	beq.n	800c658 <pow+0x118>
 800c644:	0020      	movs	r0, r4
 800c646:	0029      	movs	r1, r5
 800c648:	f001 fd7e 	bl	800e148 <rint>
 800c64c:	0022      	movs	r2, r4
 800c64e:	002b      	movs	r3, r5
 800c650:	f7f6 fb86 	bl	8002d60 <__aeabi_dcmpeq>
 800c654:	2800      	cmp	r0, #0
 800c656:	d0bf      	beq.n	800c5d8 <pow+0x98>
 800c658:	4f13      	ldr	r7, [pc, #76]	; (800c6a8 <pow+0x168>)
 800c65a:	e798      	b.n	800c58e <pow+0x4e>
 800c65c:	2200      	movs	r2, #0
 800c65e:	2300      	movs	r3, #0
 800c660:	0030      	movs	r0, r6
 800c662:	0039      	movs	r1, r7
 800c664:	f7f6 fb7c 	bl	8002d60 <__aeabi_dcmpeq>
 800c668:	2800      	cmp	r0, #0
 800c66a:	d100      	bne.n	800c66e <pow+0x12e>
 800c66c:	e78f      	b.n	800c58e <pow+0x4e>
 800c66e:	9800      	ldr	r0, [sp, #0]
 800c670:	9901      	ldr	r1, [sp, #4]
 800c672:	f001 fcd1 	bl	800e018 <finite>
 800c676:	2800      	cmp	r0, #0
 800c678:	d100      	bne.n	800c67c <pow+0x13c>
 800c67a:	e788      	b.n	800c58e <pow+0x4e>
 800c67c:	0020      	movs	r0, r4
 800c67e:	0029      	movs	r1, r5
 800c680:	f001 fcca 	bl	800e018 <finite>
 800c684:	2800      	cmp	r0, #0
 800c686:	d100      	bne.n	800c68a <pow+0x14a>
 800c688:	e781      	b.n	800c58e <pow+0x4e>
 800c68a:	f7fd fac5 	bl	8009c18 <__errno>
 800c68e:	2322      	movs	r3, #34	; 0x22
 800c690:	2600      	movs	r6, #0
 800c692:	2700      	movs	r7, #0
 800c694:	6003      	str	r3, [r0, #0]
 800c696:	e77a      	b.n	800c58e <pow+0x4e>
 800c698:	2600      	movs	r6, #0
 800c69a:	4f04      	ldr	r7, [pc, #16]	; (800c6ac <pow+0x16c>)
 800c69c:	e777      	b.n	800c58e <pow+0x4e>
 800c69e:	46c0      	nop			; (mov r8, r8)
 800c6a0:	200000ec 	.word	0x200000ec
 800c6a4:	fff00000 	.word	0xfff00000
 800c6a8:	7ff00000 	.word	0x7ff00000
 800c6ac:	3ff00000 	.word	0x3ff00000

0800c6b0 <sqrt>:
 800c6b0:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 800c6b2:	0004      	movs	r4, r0
 800c6b4:	000d      	movs	r5, r1
 800c6b6:	f000 ff15 	bl	800d4e4 <__ieee754_sqrt>
 800c6ba:	4b13      	ldr	r3, [pc, #76]	; (800c708 <sqrt+0x58>)
 800c6bc:	0006      	movs	r6, r0
 800c6be:	781b      	ldrb	r3, [r3, #0]
 800c6c0:	000f      	movs	r7, r1
 800c6c2:	b25b      	sxtb	r3, r3
 800c6c4:	3301      	adds	r3, #1
 800c6c6:	d01b      	beq.n	800c700 <sqrt+0x50>
 800c6c8:	0022      	movs	r2, r4
 800c6ca:	002b      	movs	r3, r5
 800c6cc:	0020      	movs	r0, r4
 800c6ce:	0029      	movs	r1, r5
 800c6d0:	f7f6 fcea 	bl	80030a8 <__aeabi_dcmpun>
 800c6d4:	2800      	cmp	r0, #0
 800c6d6:	d113      	bne.n	800c700 <sqrt+0x50>
 800c6d8:	2200      	movs	r2, #0
 800c6da:	2300      	movs	r3, #0
 800c6dc:	0020      	movs	r0, r4
 800c6de:	0029      	movs	r1, r5
 800c6e0:	f7f6 fb44 	bl	8002d6c <__aeabi_dcmplt>
 800c6e4:	2800      	cmp	r0, #0
 800c6e6:	d00b      	beq.n	800c700 <sqrt+0x50>
 800c6e8:	f7fd fa96 	bl	8009c18 <__errno>
 800c6ec:	2321      	movs	r3, #33	; 0x21
 800c6ee:	2200      	movs	r2, #0
 800c6f0:	6003      	str	r3, [r0, #0]
 800c6f2:	2300      	movs	r3, #0
 800c6f4:	0010      	movs	r0, r2
 800c6f6:	0019      	movs	r1, r3
 800c6f8:	f7f5 f906 	bl	8001908 <__aeabi_ddiv>
 800c6fc:	0006      	movs	r6, r0
 800c6fe:	000f      	movs	r7, r1
 800c700:	0030      	movs	r0, r6
 800c702:	0039      	movs	r1, r7
 800c704:	bdf8      	pop	{r3, r4, r5, r6, r7, pc}
 800c706:	46c0      	nop			; (mov r8, r8)
 800c708:	200000ec 	.word	0x200000ec

0800c70c <__ieee754_pow>:
 800c70c:	b5f0      	push	{r4, r5, r6, r7, lr}
 800c70e:	b095      	sub	sp, #84	; 0x54
 800c710:	9202      	str	r2, [sp, #8]
 800c712:	9303      	str	r3, [sp, #12]
 800c714:	9b03      	ldr	r3, [sp, #12]
 800c716:	9a03      	ldr	r2, [sp, #12]
 800c718:	9304      	str	r3, [sp, #16]
 800c71a:	9b02      	ldr	r3, [sp, #8]
 800c71c:	0055      	lsls	r5, r2, #1
 800c71e:	001a      	movs	r2, r3
 800c720:	086d      	lsrs	r5, r5, #1
 800c722:	0007      	movs	r7, r0
 800c724:	000e      	movs	r6, r1
 800c726:	432a      	orrs	r2, r5
 800c728:	d101      	bne.n	800c72e <__ieee754_pow+0x22>
 800c72a:	f000 fcb6 	bl	800d09a <__ieee754_pow+0x98e>
 800c72e:	4a82      	ldr	r2, [pc, #520]	; (800c938 <__ieee754_pow+0x22c>)
 800c730:	004c      	lsls	r4, r1, #1
 800c732:	9108      	str	r1, [sp, #32]
 800c734:	9000      	str	r0, [sp, #0]
 800c736:	0864      	lsrs	r4, r4, #1
 800c738:	4294      	cmp	r4, r2
 800c73a:	dc0d      	bgt.n	800c758 <__ieee754_pow+0x4c>
 800c73c:	d104      	bne.n	800c748 <__ieee754_pow+0x3c>
 800c73e:	2800      	cmp	r0, #0
 800c740:	d110      	bne.n	800c764 <__ieee754_pow+0x58>
 800c742:	42a5      	cmp	r5, r4
 800c744:	dd03      	ble.n	800c74e <__ieee754_pow+0x42>
 800c746:	e00d      	b.n	800c764 <__ieee754_pow+0x58>
 800c748:	4a7b      	ldr	r2, [pc, #492]	; (800c938 <__ieee754_pow+0x22c>)
 800c74a:	4295      	cmp	r5, r2
 800c74c:	dc04      	bgt.n	800c758 <__ieee754_pow+0x4c>
 800c74e:	4a7a      	ldr	r2, [pc, #488]	; (800c938 <__ieee754_pow+0x22c>)
 800c750:	4295      	cmp	r5, r2
 800c752:	d10d      	bne.n	800c770 <__ieee754_pow+0x64>
 800c754:	2b00      	cmp	r3, #0
 800c756:	d00b      	beq.n	800c770 <__ieee754_pow+0x64>
 800c758:	4b78      	ldr	r3, [pc, #480]	; (800c93c <__ieee754_pow+0x230>)
 800c75a:	18e4      	adds	r4, r4, r3
 800c75c:	4327      	orrs	r7, r4
 800c75e:	d101      	bne.n	800c764 <__ieee754_pow+0x58>
 800c760:	f000 fc9b 	bl	800d09a <__ieee754_pow+0x98e>
 800c764:	4876      	ldr	r0, [pc, #472]	; (800c940 <__ieee754_pow+0x234>)
 800c766:	f001 fce9 	bl	800e13c <nan>
 800c76a:	9000      	str	r0, [sp, #0]
 800c76c:	9101      	str	r1, [sp, #4]
 800c76e:	e092      	b.n	800c896 <__ieee754_pow+0x18a>
 800c770:	2200      	movs	r2, #0
 800c772:	9206      	str	r2, [sp, #24]
 800c774:	2e00      	cmp	r6, #0
 800c776:	da69      	bge.n	800c84c <__ieee754_pow+0x140>
 800c778:	4a72      	ldr	r2, [pc, #456]	; (800c944 <__ieee754_pow+0x238>)
 800c77a:	4295      	cmp	r5, r2
 800c77c:	dc64      	bgt.n	800c848 <__ieee754_pow+0x13c>
 800c77e:	4a72      	ldr	r2, [pc, #456]	; (800c948 <__ieee754_pow+0x23c>)
 800c780:	4295      	cmp	r5, r2
 800c782:	dd11      	ble.n	800c7a8 <__ieee754_pow+0x9c>
 800c784:	4971      	ldr	r1, [pc, #452]	; (800c94c <__ieee754_pow+0x240>)
 800c786:	152a      	asrs	r2, r5, #20
 800c788:	1852      	adds	r2, r2, r1
 800c78a:	2a14      	cmp	r2, #20
 800c78c:	dd3c      	ble.n	800c808 <__ieee754_pow+0xfc>
 800c78e:	2134      	movs	r1, #52	; 0x34
 800c790:	1a8a      	subs	r2, r1, r2
 800c792:	9902      	ldr	r1, [sp, #8]
 800c794:	40d1      	lsrs	r1, r2
 800c796:	0008      	movs	r0, r1
 800c798:	4090      	lsls	r0, r2
 800c79a:	4298      	cmp	r0, r3
 800c79c:	d104      	bne.n	800c7a8 <__ieee754_pow+0x9c>
 800c79e:	2201      	movs	r2, #1
 800c7a0:	4011      	ands	r1, r2
 800c7a2:	1892      	adds	r2, r2, r2
 800c7a4:	1a52      	subs	r2, r2, r1
 800c7a6:	9206      	str	r2, [sp, #24]
 800c7a8:	2b00      	cmp	r3, #0
 800c7aa:	d03c      	beq.n	800c826 <__ieee754_pow+0x11a>
 800c7ac:	0038      	movs	r0, r7
 800c7ae:	0031      	movs	r1, r6
 800c7b0:	f001 fc2e 	bl	800e010 <fabs>
 800c7b4:	9000      	str	r0, [sp, #0]
 800c7b6:	9101      	str	r1, [sp, #4]
 800c7b8:	2f00      	cmp	r7, #0
 800c7ba:	d000      	beq.n	800c7be <__ieee754_pow+0xb2>
 800c7bc:	e094      	b.n	800c8e8 <__ieee754_pow+0x1dc>
 800c7be:	2c00      	cmp	r4, #0
 800c7c0:	d005      	beq.n	800c7ce <__ieee754_pow+0xc2>
 800c7c2:	4a63      	ldr	r2, [pc, #396]	; (800c950 <__ieee754_pow+0x244>)
 800c7c4:	00b3      	lsls	r3, r6, #2
 800c7c6:	089b      	lsrs	r3, r3, #2
 800c7c8:	4293      	cmp	r3, r2
 800c7ca:	d000      	beq.n	800c7ce <__ieee754_pow+0xc2>
 800c7cc:	e08c      	b.n	800c8e8 <__ieee754_pow+0x1dc>
 800c7ce:	9b04      	ldr	r3, [sp, #16]
 800c7d0:	2b00      	cmp	r3, #0
 800c7d2:	da07      	bge.n	800c7e4 <__ieee754_pow+0xd8>
 800c7d4:	9a00      	ldr	r2, [sp, #0]
 800c7d6:	9b01      	ldr	r3, [sp, #4]
 800c7d8:	2000      	movs	r0, #0
 800c7da:	495d      	ldr	r1, [pc, #372]	; (800c950 <__ieee754_pow+0x244>)
 800c7dc:	f7f5 f894 	bl	8001908 <__aeabi_ddiv>
 800c7e0:	9000      	str	r0, [sp, #0]
 800c7e2:	9101      	str	r1, [sp, #4]
 800c7e4:	9b08      	ldr	r3, [sp, #32]
 800c7e6:	2b00      	cmp	r3, #0
 800c7e8:	da55      	bge.n	800c896 <__ieee754_pow+0x18a>
 800c7ea:	4b54      	ldr	r3, [pc, #336]	; (800c93c <__ieee754_pow+0x230>)
 800c7ec:	18e4      	adds	r4, r4, r3
 800c7ee:	9b06      	ldr	r3, [sp, #24]
 800c7f0:	431c      	orrs	r4, r3
 800c7f2:	d000      	beq.n	800c7f6 <__ieee754_pow+0xea>
 800c7f4:	e06c      	b.n	800c8d0 <__ieee754_pow+0x1c4>
 800c7f6:	9a00      	ldr	r2, [sp, #0]
 800c7f8:	9b01      	ldr	r3, [sp, #4]
 800c7fa:	0010      	movs	r0, r2
 800c7fc:	0019      	movs	r1, r3
 800c7fe:	f7f5 fdd7 	bl	80023b0 <__aeabi_dsub>
 800c802:	0002      	movs	r2, r0
 800c804:	000b      	movs	r3, r1
 800c806:	e01c      	b.n	800c842 <__ieee754_pow+0x136>
 800c808:	2b00      	cmp	r3, #0
 800c80a:	d1cf      	bne.n	800c7ac <__ieee754_pow+0xa0>
 800c80c:	3314      	adds	r3, #20
 800c80e:	1a9a      	subs	r2, r3, r2
 800c810:	002b      	movs	r3, r5
 800c812:	4113      	asrs	r3, r2
 800c814:	0019      	movs	r1, r3
 800c816:	4091      	lsls	r1, r2
 800c818:	42a9      	cmp	r1, r5
 800c81a:	d104      	bne.n	800c826 <__ieee754_pow+0x11a>
 800c81c:	2201      	movs	r2, #1
 800c81e:	4013      	ands	r3, r2
 800c820:	1892      	adds	r2, r2, r2
 800c822:	1ad3      	subs	r3, r2, r3
 800c824:	9306      	str	r3, [sp, #24]
 800c826:	4b4a      	ldr	r3, [pc, #296]	; (800c950 <__ieee754_pow+0x244>)
 800c828:	429d      	cmp	r5, r3
 800c82a:	d138      	bne.n	800c89e <__ieee754_pow+0x192>
 800c82c:	0038      	movs	r0, r7
 800c82e:	0031      	movs	r1, r6
 800c830:	9b04      	ldr	r3, [sp, #16]
 800c832:	9000      	str	r0, [sp, #0]
 800c834:	9101      	str	r1, [sp, #4]
 800c836:	2b00      	cmp	r3, #0
 800c838:	da2d      	bge.n	800c896 <__ieee754_pow+0x18a>
 800c83a:	003a      	movs	r2, r7
 800c83c:	0033      	movs	r3, r6
 800c83e:	2000      	movs	r0, #0
 800c840:	4943      	ldr	r1, [pc, #268]	; (800c950 <__ieee754_pow+0x244>)
 800c842:	f7f5 f861 	bl	8001908 <__aeabi_ddiv>
 800c846:	e790      	b.n	800c76a <__ieee754_pow+0x5e>
 800c848:	2202      	movs	r2, #2
 800c84a:	9206      	str	r2, [sp, #24]
 800c84c:	2b00      	cmp	r3, #0
 800c84e:	d1ad      	bne.n	800c7ac <__ieee754_pow+0xa0>
 800c850:	4b39      	ldr	r3, [pc, #228]	; (800c938 <__ieee754_pow+0x22c>)
 800c852:	429d      	cmp	r5, r3
 800c854:	d1e7      	bne.n	800c826 <__ieee754_pow+0x11a>
 800c856:	4b39      	ldr	r3, [pc, #228]	; (800c93c <__ieee754_pow+0x230>)
 800c858:	18e3      	adds	r3, r4, r3
 800c85a:	431f      	orrs	r7, r3
 800c85c:	d101      	bne.n	800c862 <__ieee754_pow+0x156>
 800c85e:	f000 fc1c 	bl	800d09a <__ieee754_pow+0x98e>
 800c862:	4b39      	ldr	r3, [pc, #228]	; (800c948 <__ieee754_pow+0x23c>)
 800c864:	429c      	cmp	r4, r3
 800c866:	dd0b      	ble.n	800c880 <__ieee754_pow+0x174>
 800c868:	9b02      	ldr	r3, [sp, #8]
 800c86a:	9c03      	ldr	r4, [sp, #12]
 800c86c:	9300      	str	r3, [sp, #0]
 800c86e:	9401      	str	r4, [sp, #4]
 800c870:	9b04      	ldr	r3, [sp, #16]
 800c872:	2b00      	cmp	r3, #0
 800c874:	da0f      	bge.n	800c896 <__ieee754_pow+0x18a>
 800c876:	2300      	movs	r3, #0
 800c878:	2400      	movs	r4, #0
 800c87a:	9300      	str	r3, [sp, #0]
 800c87c:	9401      	str	r4, [sp, #4]
 800c87e:	e00a      	b.n	800c896 <__ieee754_pow+0x18a>
 800c880:	9b04      	ldr	r3, [sp, #16]
 800c882:	2b00      	cmp	r3, #0
 800c884:	daf7      	bge.n	800c876 <__ieee754_pow+0x16a>
 800c886:	2280      	movs	r2, #128	; 0x80
 800c888:	0612      	lsls	r2, r2, #24
 800c88a:	4694      	mov	ip, r2
 800c88c:	9b02      	ldr	r3, [sp, #8]
 800c88e:	9300      	str	r3, [sp, #0]
 800c890:	9b03      	ldr	r3, [sp, #12]
 800c892:	4463      	add	r3, ip
 800c894:	9301      	str	r3, [sp, #4]
 800c896:	9800      	ldr	r0, [sp, #0]
 800c898:	9901      	ldr	r1, [sp, #4]
 800c89a:	b015      	add	sp, #84	; 0x54
 800c89c:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800c89e:	2380      	movs	r3, #128	; 0x80
 800c8a0:	9a04      	ldr	r2, [sp, #16]
 800c8a2:	05db      	lsls	r3, r3, #23
 800c8a4:	429a      	cmp	r2, r3
 800c8a6:	d106      	bne.n	800c8b6 <__ieee754_pow+0x1aa>
 800c8a8:	003a      	movs	r2, r7
 800c8aa:	0033      	movs	r3, r6
 800c8ac:	0038      	movs	r0, r7
 800c8ae:	0031      	movs	r1, r6
 800c8b0:	f7f5 fb12 	bl	8001ed8 <__aeabi_dmul>
 800c8b4:	e759      	b.n	800c76a <__ieee754_pow+0x5e>
 800c8b6:	4b27      	ldr	r3, [pc, #156]	; (800c954 <__ieee754_pow+0x248>)
 800c8b8:	9a04      	ldr	r2, [sp, #16]
 800c8ba:	429a      	cmp	r2, r3
 800c8bc:	d000      	beq.n	800c8c0 <__ieee754_pow+0x1b4>
 800c8be:	e775      	b.n	800c7ac <__ieee754_pow+0xa0>
 800c8c0:	2e00      	cmp	r6, #0
 800c8c2:	da00      	bge.n	800c8c6 <__ieee754_pow+0x1ba>
 800c8c4:	e772      	b.n	800c7ac <__ieee754_pow+0xa0>
 800c8c6:	0038      	movs	r0, r7
 800c8c8:	0031      	movs	r1, r6
 800c8ca:	f000 fe0b 	bl	800d4e4 <__ieee754_sqrt>
 800c8ce:	e74c      	b.n	800c76a <__ieee754_pow+0x5e>
 800c8d0:	9b06      	ldr	r3, [sp, #24]
 800c8d2:	2b01      	cmp	r3, #1
 800c8d4:	d1df      	bne.n	800c896 <__ieee754_pow+0x18a>
 800c8d6:	9800      	ldr	r0, [sp, #0]
 800c8d8:	2180      	movs	r1, #128	; 0x80
 800c8da:	0002      	movs	r2, r0
 800c8dc:	9801      	ldr	r0, [sp, #4]
 800c8de:	0609      	lsls	r1, r1, #24
 800c8e0:	1843      	adds	r3, r0, r1
 800c8e2:	9200      	str	r2, [sp, #0]
 800c8e4:	9301      	str	r3, [sp, #4]
 800c8e6:	e7d6      	b.n	800c896 <__ieee754_pow+0x18a>
 800c8e8:	0ff3      	lsrs	r3, r6, #31
 800c8ea:	3b01      	subs	r3, #1
 800c8ec:	9310      	str	r3, [sp, #64]	; 0x40
 800c8ee:	9a10      	ldr	r2, [sp, #64]	; 0x40
 800c8f0:	9b06      	ldr	r3, [sp, #24]
 800c8f2:	4313      	orrs	r3, r2
 800c8f4:	d104      	bne.n	800c900 <__ieee754_pow+0x1f4>
 800c8f6:	003a      	movs	r2, r7
 800c8f8:	0033      	movs	r3, r6
 800c8fa:	0038      	movs	r0, r7
 800c8fc:	0031      	movs	r1, r6
 800c8fe:	e77e      	b.n	800c7fe <__ieee754_pow+0xf2>
 800c900:	4b15      	ldr	r3, [pc, #84]	; (800c958 <__ieee754_pow+0x24c>)
 800c902:	429d      	cmp	r5, r3
 800c904:	dc00      	bgt.n	800c908 <__ieee754_pow+0x1fc>
 800c906:	e0f5      	b.n	800caf4 <__ieee754_pow+0x3e8>
 800c908:	4b14      	ldr	r3, [pc, #80]	; (800c95c <__ieee754_pow+0x250>)
 800c90a:	429d      	cmp	r5, r3
 800c90c:	dd0a      	ble.n	800c924 <__ieee754_pow+0x218>
 800c90e:	4b0e      	ldr	r3, [pc, #56]	; (800c948 <__ieee754_pow+0x23c>)
 800c910:	429c      	cmp	r4, r3
 800c912:	dc0d      	bgt.n	800c930 <__ieee754_pow+0x224>
 800c914:	9b04      	ldr	r3, [sp, #16]
 800c916:	2b00      	cmp	r3, #0
 800c918:	daad      	bge.n	800c876 <__ieee754_pow+0x16a>
 800c91a:	4a11      	ldr	r2, [pc, #68]	; (800c960 <__ieee754_pow+0x254>)
 800c91c:	4b11      	ldr	r3, [pc, #68]	; (800c964 <__ieee754_pow+0x258>)
 800c91e:	0010      	movs	r0, r2
 800c920:	0019      	movs	r1, r3
 800c922:	e7c5      	b.n	800c8b0 <__ieee754_pow+0x1a4>
 800c924:	4b10      	ldr	r3, [pc, #64]	; (800c968 <__ieee754_pow+0x25c>)
 800c926:	429c      	cmp	r4, r3
 800c928:	ddf4      	ble.n	800c914 <__ieee754_pow+0x208>
 800c92a:	4b09      	ldr	r3, [pc, #36]	; (800c950 <__ieee754_pow+0x244>)
 800c92c:	429c      	cmp	r4, r3
 800c92e:	dd1d      	ble.n	800c96c <__ieee754_pow+0x260>
 800c930:	9b04      	ldr	r3, [sp, #16]
 800c932:	2b00      	cmp	r3, #0
 800c934:	dcf1      	bgt.n	800c91a <__ieee754_pow+0x20e>
 800c936:	e79e      	b.n	800c876 <__ieee754_pow+0x16a>
 800c938:	7ff00000 	.word	0x7ff00000
 800c93c:	c0100000 	.word	0xc0100000
 800c940:	0800f0f3 	.word	0x0800f0f3
 800c944:	433fffff 	.word	0x433fffff
 800c948:	3fefffff 	.word	0x3fefffff
 800c94c:	fffffc01 	.word	0xfffffc01
 800c950:	3ff00000 	.word	0x3ff00000
 800c954:	3fe00000 	.word	0x3fe00000
 800c958:	41e00000 	.word	0x41e00000
 800c95c:	43f00000 	.word	0x43f00000
 800c960:	8800759c 	.word	0x8800759c
 800c964:	7e37e43c 	.word	0x7e37e43c
 800c968:	3feffffe 	.word	0x3feffffe
 800c96c:	2200      	movs	r2, #0
 800c96e:	9800      	ldr	r0, [sp, #0]
 800c970:	9901      	ldr	r1, [sp, #4]
 800c972:	4b52      	ldr	r3, [pc, #328]	; (800cabc <__ieee754_pow+0x3b0>)
 800c974:	f7f5 fd1c 	bl	80023b0 <__aeabi_dsub>
 800c978:	22c0      	movs	r2, #192	; 0xc0
 800c97a:	4b51      	ldr	r3, [pc, #324]	; (800cac0 <__ieee754_pow+0x3b4>)
 800c97c:	05d2      	lsls	r2, r2, #23
 800c97e:	0004      	movs	r4, r0
 800c980:	000d      	movs	r5, r1
 800c982:	f7f5 faa9 	bl	8001ed8 <__aeabi_dmul>
 800c986:	4a4f      	ldr	r2, [pc, #316]	; (800cac4 <__ieee754_pow+0x3b8>)
 800c988:	9000      	str	r0, [sp, #0]
 800c98a:	9101      	str	r1, [sp, #4]
 800c98c:	4b4e      	ldr	r3, [pc, #312]	; (800cac8 <__ieee754_pow+0x3bc>)
 800c98e:	0020      	movs	r0, r4
 800c990:	0029      	movs	r1, r5
 800c992:	f7f5 faa1 	bl	8001ed8 <__aeabi_dmul>
 800c996:	2200      	movs	r2, #0
 800c998:	9004      	str	r0, [sp, #16]
 800c99a:	9105      	str	r1, [sp, #20]
 800c99c:	4b4b      	ldr	r3, [pc, #300]	; (800cacc <__ieee754_pow+0x3c0>)
 800c99e:	0020      	movs	r0, r4
 800c9a0:	0029      	movs	r1, r5
 800c9a2:	f7f5 fa99 	bl	8001ed8 <__aeabi_dmul>
 800c9a6:	0002      	movs	r2, r0
 800c9a8:	000b      	movs	r3, r1
 800c9aa:	4849      	ldr	r0, [pc, #292]	; (800cad0 <__ieee754_pow+0x3c4>)
 800c9ac:	4949      	ldr	r1, [pc, #292]	; (800cad4 <__ieee754_pow+0x3c8>)
 800c9ae:	f7f5 fcff 	bl	80023b0 <__aeabi_dsub>
 800c9b2:	0022      	movs	r2, r4
 800c9b4:	002b      	movs	r3, r5
 800c9b6:	f7f5 fa8f 	bl	8001ed8 <__aeabi_dmul>
 800c9ba:	0002      	movs	r2, r0
 800c9bc:	000b      	movs	r3, r1
 800c9be:	2000      	movs	r0, #0
 800c9c0:	4945      	ldr	r1, [pc, #276]	; (800cad8 <__ieee754_pow+0x3cc>)
 800c9c2:	f7f5 fcf5 	bl	80023b0 <__aeabi_dsub>
 800c9c6:	0022      	movs	r2, r4
 800c9c8:	0006      	movs	r6, r0
 800c9ca:	000f      	movs	r7, r1
 800c9cc:	002b      	movs	r3, r5
 800c9ce:	0020      	movs	r0, r4
 800c9d0:	0029      	movs	r1, r5
 800c9d2:	f7f5 fa81 	bl	8001ed8 <__aeabi_dmul>
 800c9d6:	0002      	movs	r2, r0
 800c9d8:	000b      	movs	r3, r1
 800c9da:	0030      	movs	r0, r6
 800c9dc:	0039      	movs	r1, r7
 800c9de:	f7f5 fa7b 	bl	8001ed8 <__aeabi_dmul>
 800c9e2:	4a3e      	ldr	r2, [pc, #248]	; (800cadc <__ieee754_pow+0x3d0>)
 800c9e4:	4b36      	ldr	r3, [pc, #216]	; (800cac0 <__ieee754_pow+0x3b4>)
 800c9e6:	f7f5 fa77 	bl	8001ed8 <__aeabi_dmul>
 800c9ea:	0002      	movs	r2, r0
 800c9ec:	000b      	movs	r3, r1
 800c9ee:	9804      	ldr	r0, [sp, #16]
 800c9f0:	9905      	ldr	r1, [sp, #20]
 800c9f2:	f7f5 fcdd 	bl	80023b0 <__aeabi_dsub>
 800c9f6:	0002      	movs	r2, r0
 800c9f8:	000b      	movs	r3, r1
 800c9fa:	0004      	movs	r4, r0
 800c9fc:	000d      	movs	r5, r1
 800c9fe:	9800      	ldr	r0, [sp, #0]
 800ca00:	9901      	ldr	r1, [sp, #4]
 800ca02:	f7f4 fc17 	bl	8001234 <__aeabi_dadd>
 800ca06:	9a00      	ldr	r2, [sp, #0]
 800ca08:	9b01      	ldr	r3, [sp, #4]
 800ca0a:	2000      	movs	r0, #0
 800ca0c:	000f      	movs	r7, r1
 800ca0e:	0006      	movs	r6, r0
 800ca10:	f7f5 fcce 	bl	80023b0 <__aeabi_dsub>
 800ca14:	0002      	movs	r2, r0
 800ca16:	000b      	movs	r3, r1
 800ca18:	0020      	movs	r0, r4
 800ca1a:	0029      	movs	r1, r5
 800ca1c:	f7f5 fcc8 	bl	80023b0 <__aeabi_dsub>
 800ca20:	9b06      	ldr	r3, [sp, #24]
 800ca22:	9a10      	ldr	r2, [sp, #64]	; 0x40
 800ca24:	3b01      	subs	r3, #1
 800ca26:	9004      	str	r0, [sp, #16]
 800ca28:	9105      	str	r1, [sp, #20]
 800ca2a:	4313      	orrs	r3, r2
 800ca2c:	d000      	beq.n	800ca30 <__ieee754_pow+0x324>
 800ca2e:	e1e0      	b.n	800cdf2 <__ieee754_pow+0x6e6>
 800ca30:	2300      	movs	r3, #0
 800ca32:	4c2b      	ldr	r4, [pc, #172]	; (800cae0 <__ieee754_pow+0x3d4>)
 800ca34:	9300      	str	r3, [sp, #0]
 800ca36:	9401      	str	r4, [sp, #4]
 800ca38:	9c02      	ldr	r4, [sp, #8]
 800ca3a:	9d03      	ldr	r5, [sp, #12]
 800ca3c:	9802      	ldr	r0, [sp, #8]
 800ca3e:	9903      	ldr	r1, [sp, #12]
 800ca40:	2400      	movs	r4, #0
 800ca42:	002b      	movs	r3, r5
 800ca44:	0022      	movs	r2, r4
 800ca46:	f7f5 fcb3 	bl	80023b0 <__aeabi_dsub>
 800ca4a:	0032      	movs	r2, r6
 800ca4c:	003b      	movs	r3, r7
 800ca4e:	f7f5 fa43 	bl	8001ed8 <__aeabi_dmul>
 800ca52:	9a02      	ldr	r2, [sp, #8]
 800ca54:	9b03      	ldr	r3, [sp, #12]
 800ca56:	9006      	str	r0, [sp, #24]
 800ca58:	9107      	str	r1, [sp, #28]
 800ca5a:	9804      	ldr	r0, [sp, #16]
 800ca5c:	9905      	ldr	r1, [sp, #20]
 800ca5e:	f7f5 fa3b 	bl	8001ed8 <__aeabi_dmul>
 800ca62:	0002      	movs	r2, r0
 800ca64:	000b      	movs	r3, r1
 800ca66:	9806      	ldr	r0, [sp, #24]
 800ca68:	9907      	ldr	r1, [sp, #28]
 800ca6a:	f7f4 fbe3 	bl	8001234 <__aeabi_dadd>
 800ca6e:	0022      	movs	r2, r4
 800ca70:	002b      	movs	r3, r5
 800ca72:	9004      	str	r0, [sp, #16]
 800ca74:	9105      	str	r1, [sp, #20]
 800ca76:	0030      	movs	r0, r6
 800ca78:	0039      	movs	r1, r7
 800ca7a:	f7f5 fa2d 	bl	8001ed8 <__aeabi_dmul>
 800ca7e:	0006      	movs	r6, r0
 800ca80:	000f      	movs	r7, r1
 800ca82:	000b      	movs	r3, r1
 800ca84:	0002      	movs	r2, r0
 800ca86:	9804      	ldr	r0, [sp, #16]
 800ca88:	9905      	ldr	r1, [sp, #20]
 800ca8a:	9606      	str	r6, [sp, #24]
 800ca8c:	9707      	str	r7, [sp, #28]
 800ca8e:	f7f4 fbd1 	bl	8001234 <__aeabi_dadd>
 800ca92:	4b14      	ldr	r3, [pc, #80]	; (800cae4 <__ieee754_pow+0x3d8>)
 800ca94:	0005      	movs	r5, r0
 800ca96:	000c      	movs	r4, r1
 800ca98:	9108      	str	r1, [sp, #32]
 800ca9a:	4299      	cmp	r1, r3
 800ca9c:	dc00      	bgt.n	800caa0 <__ieee754_pow+0x394>
 800ca9e:	e2da      	b.n	800d056 <__ieee754_pow+0x94a>
 800caa0:	4b11      	ldr	r3, [pc, #68]	; (800cae8 <__ieee754_pow+0x3dc>)
 800caa2:	18cb      	adds	r3, r1, r3
 800caa4:	4303      	orrs	r3, r0
 800caa6:	d100      	bne.n	800caaa <__ieee754_pow+0x39e>
 800caa8:	e1dc      	b.n	800ce64 <__ieee754_pow+0x758>
 800caaa:	9800      	ldr	r0, [sp, #0]
 800caac:	9901      	ldr	r1, [sp, #4]
 800caae:	4a0f      	ldr	r2, [pc, #60]	; (800caec <__ieee754_pow+0x3e0>)
 800cab0:	4b0f      	ldr	r3, [pc, #60]	; (800caf0 <__ieee754_pow+0x3e4>)
 800cab2:	f7f5 fa11 	bl	8001ed8 <__aeabi_dmul>
 800cab6:	4a0d      	ldr	r2, [pc, #52]	; (800caec <__ieee754_pow+0x3e0>)
 800cab8:	4b0d      	ldr	r3, [pc, #52]	; (800caf0 <__ieee754_pow+0x3e4>)
 800caba:	e6f9      	b.n	800c8b0 <__ieee754_pow+0x1a4>
 800cabc:	3ff00000 	.word	0x3ff00000
 800cac0:	3ff71547 	.word	0x3ff71547
 800cac4:	f85ddf44 	.word	0xf85ddf44
 800cac8:	3e54ae0b 	.word	0x3e54ae0b
 800cacc:	3fd00000 	.word	0x3fd00000
 800cad0:	55555555 	.word	0x55555555
 800cad4:	3fd55555 	.word	0x3fd55555
 800cad8:	3fe00000 	.word	0x3fe00000
 800cadc:	652b82fe 	.word	0x652b82fe
 800cae0:	bff00000 	.word	0xbff00000
 800cae4:	408fffff 	.word	0x408fffff
 800cae8:	bf700000 	.word	0xbf700000
 800caec:	8800759c 	.word	0x8800759c
 800caf0:	7e37e43c 	.word	0x7e37e43c
 800caf4:	4bc0      	ldr	r3, [pc, #768]	; (800cdf8 <__ieee754_pow+0x6ec>)
 800caf6:	2200      	movs	r2, #0
 800caf8:	4233      	tst	r3, r6
 800cafa:	d10a      	bne.n	800cb12 <__ieee754_pow+0x406>
 800cafc:	9800      	ldr	r0, [sp, #0]
 800cafe:	9901      	ldr	r1, [sp, #4]
 800cb00:	2200      	movs	r2, #0
 800cb02:	4bbe      	ldr	r3, [pc, #760]	; (800cdfc <__ieee754_pow+0x6f0>)
 800cb04:	f7f5 f9e8 	bl	8001ed8 <__aeabi_dmul>
 800cb08:	2235      	movs	r2, #53	; 0x35
 800cb0a:	9000      	str	r0, [sp, #0]
 800cb0c:	9101      	str	r1, [sp, #4]
 800cb0e:	9c01      	ldr	r4, [sp, #4]
 800cb10:	4252      	negs	r2, r2
 800cb12:	49bb      	ldr	r1, [pc, #748]	; (800ce00 <__ieee754_pow+0x6f4>)
 800cb14:	1523      	asrs	r3, r4, #20
 800cb16:	185b      	adds	r3, r3, r1
 800cb18:	189b      	adds	r3, r3, r2
 800cb1a:	0324      	lsls	r4, r4, #12
 800cb1c:	4db9      	ldr	r5, [pc, #740]	; (800ce04 <__ieee754_pow+0x6f8>)
 800cb1e:	930d      	str	r3, [sp, #52]	; 0x34
 800cb20:	4bb9      	ldr	r3, [pc, #740]	; (800ce08 <__ieee754_pow+0x6fc>)
 800cb22:	0b22      	lsrs	r2, r4, #12
 800cb24:	4315      	orrs	r5, r2
 800cb26:	2400      	movs	r4, #0
 800cb28:	429a      	cmp	r2, r3
 800cb2a:	dd09      	ble.n	800cb40 <__ieee754_pow+0x434>
 800cb2c:	4bb7      	ldr	r3, [pc, #732]	; (800ce0c <__ieee754_pow+0x700>)
 800cb2e:	3401      	adds	r4, #1
 800cb30:	429a      	cmp	r2, r3
 800cb32:	dd05      	ble.n	800cb40 <__ieee754_pow+0x434>
 800cb34:	9b0d      	ldr	r3, [sp, #52]	; 0x34
 800cb36:	191b      	adds	r3, r3, r4
 800cb38:	2400      	movs	r4, #0
 800cb3a:	930d      	str	r3, [sp, #52]	; 0x34
 800cb3c:	4bb4      	ldr	r3, [pc, #720]	; (800ce10 <__ieee754_pow+0x704>)
 800cb3e:	18ed      	adds	r5, r5, r3
 800cb40:	9800      	ldr	r0, [sp, #0]
 800cb42:	9901      	ldr	r1, [sp, #4]
 800cb44:	0029      	movs	r1, r5
 800cb46:	00e3      	lsls	r3, r4, #3
 800cb48:	9311      	str	r3, [sp, #68]	; 0x44
 800cb4a:	4bb2      	ldr	r3, [pc, #712]	; (800ce14 <__ieee754_pow+0x708>)
 800cb4c:	00e2      	lsls	r2, r4, #3
 800cb4e:	189b      	adds	r3, r3, r2
 800cb50:	681a      	ldr	r2, [r3, #0]
 800cb52:	685b      	ldr	r3, [r3, #4]
 800cb54:	900e      	str	r0, [sp, #56]	; 0x38
 800cb56:	910f      	str	r1, [sp, #60]	; 0x3c
 800cb58:	920a      	str	r2, [sp, #40]	; 0x28
 800cb5a:	930b      	str	r3, [sp, #44]	; 0x2c
 800cb5c:	f7f5 fc28 	bl	80023b0 <__aeabi_dsub>
 800cb60:	9a0e      	ldr	r2, [sp, #56]	; 0x38
 800cb62:	9b0f      	ldr	r3, [sp, #60]	; 0x3c
 800cb64:	0006      	movs	r6, r0
 800cb66:	000f      	movs	r7, r1
 800cb68:	980a      	ldr	r0, [sp, #40]	; 0x28
 800cb6a:	990b      	ldr	r1, [sp, #44]	; 0x2c
 800cb6c:	f7f4 fb62 	bl	8001234 <__aeabi_dadd>
 800cb70:	0002      	movs	r2, r0
 800cb72:	000b      	movs	r3, r1
 800cb74:	2000      	movs	r0, #0
 800cb76:	49a3      	ldr	r1, [pc, #652]	; (800ce04 <__ieee754_pow+0x6f8>)
 800cb78:	f7f4 fec6 	bl	8001908 <__aeabi_ddiv>
 800cb7c:	0002      	movs	r2, r0
 800cb7e:	000b      	movs	r3, r1
 800cb80:	9012      	str	r0, [sp, #72]	; 0x48
 800cb82:	9113      	str	r1, [sp, #76]	; 0x4c
 800cb84:	0030      	movs	r0, r6
 800cb86:	0039      	movs	r1, r7
 800cb88:	f7f5 f9a6 	bl	8001ed8 <__aeabi_dmul>
 800cb8c:	9008      	str	r0, [sp, #32]
 800cb8e:	9109      	str	r1, [sp, #36]	; 0x24
 800cb90:	9a08      	ldr	r2, [sp, #32]
 800cb92:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800cb94:	2180      	movs	r1, #128	; 0x80
 800cb96:	9204      	str	r2, [sp, #16]
 800cb98:	9305      	str	r3, [sp, #20]
 800cb9a:	2300      	movs	r3, #0
 800cb9c:	0589      	lsls	r1, r1, #22
 800cb9e:	106d      	asrs	r5, r5, #1
 800cba0:	430d      	orrs	r5, r1
 800cba2:	2180      	movs	r1, #128	; 0x80
 800cba4:	9304      	str	r3, [sp, #16]
 800cba6:	9a04      	ldr	r2, [sp, #16]
 800cba8:	9b05      	ldr	r3, [sp, #20]
 800cbaa:	9200      	str	r2, [sp, #0]
 800cbac:	9301      	str	r3, [sp, #4]
 800cbae:	2200      	movs	r2, #0
 800cbb0:	0309      	lsls	r1, r1, #12
 800cbb2:	186d      	adds	r5, r5, r1
 800cbb4:	04a1      	lsls	r1, r4, #18
 800cbb6:	186b      	adds	r3, r5, r1
 800cbb8:	9800      	ldr	r0, [sp, #0]
 800cbba:	9901      	ldr	r1, [sp, #4]
 800cbbc:	0014      	movs	r4, r2
 800cbbe:	001d      	movs	r5, r3
 800cbc0:	f7f5 f98a 	bl	8001ed8 <__aeabi_dmul>
 800cbc4:	0002      	movs	r2, r0
 800cbc6:	000b      	movs	r3, r1
 800cbc8:	0030      	movs	r0, r6
 800cbca:	0039      	movs	r1, r7
 800cbcc:	f7f5 fbf0 	bl	80023b0 <__aeabi_dsub>
 800cbd0:	9a0a      	ldr	r2, [sp, #40]	; 0x28
 800cbd2:	9b0b      	ldr	r3, [sp, #44]	; 0x2c
 800cbd4:	0006      	movs	r6, r0
 800cbd6:	000f      	movs	r7, r1
 800cbd8:	0020      	movs	r0, r4
 800cbda:	0029      	movs	r1, r5
 800cbdc:	f7f5 fbe8 	bl	80023b0 <__aeabi_dsub>
 800cbe0:	0002      	movs	r2, r0
 800cbe2:	000b      	movs	r3, r1
 800cbe4:	980e      	ldr	r0, [sp, #56]	; 0x38
 800cbe6:	990f      	ldr	r1, [sp, #60]	; 0x3c
 800cbe8:	f7f5 fbe2 	bl	80023b0 <__aeabi_dsub>
 800cbec:	9a00      	ldr	r2, [sp, #0]
 800cbee:	9b01      	ldr	r3, [sp, #4]
 800cbf0:	f7f5 f972 	bl	8001ed8 <__aeabi_dmul>
 800cbf4:	0002      	movs	r2, r0
 800cbf6:	000b      	movs	r3, r1
 800cbf8:	0030      	movs	r0, r6
 800cbfa:	0039      	movs	r1, r7
 800cbfc:	f7f5 fbd8 	bl	80023b0 <__aeabi_dsub>
 800cc00:	9a12      	ldr	r2, [sp, #72]	; 0x48
 800cc02:	9b13      	ldr	r3, [sp, #76]	; 0x4c
 800cc04:	f7f5 f968 	bl	8001ed8 <__aeabi_dmul>
 800cc08:	9a08      	ldr	r2, [sp, #32]
 800cc0a:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800cc0c:	900a      	str	r0, [sp, #40]	; 0x28
 800cc0e:	910b      	str	r1, [sp, #44]	; 0x2c
 800cc10:	0010      	movs	r0, r2
 800cc12:	0019      	movs	r1, r3
 800cc14:	f7f5 f960 	bl	8001ed8 <__aeabi_dmul>
 800cc18:	0006      	movs	r6, r0
 800cc1a:	000f      	movs	r7, r1
 800cc1c:	4a7e      	ldr	r2, [pc, #504]	; (800ce18 <__ieee754_pow+0x70c>)
 800cc1e:	4b7f      	ldr	r3, [pc, #508]	; (800ce1c <__ieee754_pow+0x710>)
 800cc20:	f7f5 f95a 	bl	8001ed8 <__aeabi_dmul>
 800cc24:	4a7e      	ldr	r2, [pc, #504]	; (800ce20 <__ieee754_pow+0x714>)
 800cc26:	4b7f      	ldr	r3, [pc, #508]	; (800ce24 <__ieee754_pow+0x718>)
 800cc28:	f7f4 fb04 	bl	8001234 <__aeabi_dadd>
 800cc2c:	0032      	movs	r2, r6
 800cc2e:	003b      	movs	r3, r7
 800cc30:	f7f5 f952 	bl	8001ed8 <__aeabi_dmul>
 800cc34:	4a7c      	ldr	r2, [pc, #496]	; (800ce28 <__ieee754_pow+0x71c>)
 800cc36:	4b7d      	ldr	r3, [pc, #500]	; (800ce2c <__ieee754_pow+0x720>)
 800cc38:	f7f4 fafc 	bl	8001234 <__aeabi_dadd>
 800cc3c:	0032      	movs	r2, r6
 800cc3e:	003b      	movs	r3, r7
 800cc40:	f7f5 f94a 	bl	8001ed8 <__aeabi_dmul>
 800cc44:	4a7a      	ldr	r2, [pc, #488]	; (800ce30 <__ieee754_pow+0x724>)
 800cc46:	4b7b      	ldr	r3, [pc, #492]	; (800ce34 <__ieee754_pow+0x728>)
 800cc48:	f7f4 faf4 	bl	8001234 <__aeabi_dadd>
 800cc4c:	0032      	movs	r2, r6
 800cc4e:	003b      	movs	r3, r7
 800cc50:	f7f5 f942 	bl	8001ed8 <__aeabi_dmul>
 800cc54:	4a78      	ldr	r2, [pc, #480]	; (800ce38 <__ieee754_pow+0x72c>)
 800cc56:	4b79      	ldr	r3, [pc, #484]	; (800ce3c <__ieee754_pow+0x730>)
 800cc58:	f7f4 faec 	bl	8001234 <__aeabi_dadd>
 800cc5c:	0032      	movs	r2, r6
 800cc5e:	003b      	movs	r3, r7
 800cc60:	f7f5 f93a 	bl	8001ed8 <__aeabi_dmul>
 800cc64:	4a76      	ldr	r2, [pc, #472]	; (800ce40 <__ieee754_pow+0x734>)
 800cc66:	4b77      	ldr	r3, [pc, #476]	; (800ce44 <__ieee754_pow+0x738>)
 800cc68:	f7f4 fae4 	bl	8001234 <__aeabi_dadd>
 800cc6c:	0032      	movs	r2, r6
 800cc6e:	0004      	movs	r4, r0
 800cc70:	000d      	movs	r5, r1
 800cc72:	003b      	movs	r3, r7
 800cc74:	0030      	movs	r0, r6
 800cc76:	0039      	movs	r1, r7
 800cc78:	f7f5 f92e 	bl	8001ed8 <__aeabi_dmul>
 800cc7c:	0002      	movs	r2, r0
 800cc7e:	000b      	movs	r3, r1
 800cc80:	0020      	movs	r0, r4
 800cc82:	0029      	movs	r1, r5
 800cc84:	f7f5 f928 	bl	8001ed8 <__aeabi_dmul>
 800cc88:	9a00      	ldr	r2, [sp, #0]
 800cc8a:	9b01      	ldr	r3, [sp, #4]
 800cc8c:	0004      	movs	r4, r0
 800cc8e:	000d      	movs	r5, r1
 800cc90:	9808      	ldr	r0, [sp, #32]
 800cc92:	9909      	ldr	r1, [sp, #36]	; 0x24
 800cc94:	f7f4 face 	bl	8001234 <__aeabi_dadd>
 800cc98:	9a0a      	ldr	r2, [sp, #40]	; 0x28
 800cc9a:	9b0b      	ldr	r3, [sp, #44]	; 0x2c
 800cc9c:	f7f5 f91c 	bl	8001ed8 <__aeabi_dmul>
 800cca0:	0022      	movs	r2, r4
 800cca2:	002b      	movs	r3, r5
 800cca4:	f7f4 fac6 	bl	8001234 <__aeabi_dadd>
 800cca8:	9a00      	ldr	r2, [sp, #0]
 800ccaa:	9b01      	ldr	r3, [sp, #4]
 800ccac:	900e      	str	r0, [sp, #56]	; 0x38
 800ccae:	910f      	str	r1, [sp, #60]	; 0x3c
 800ccb0:	0010      	movs	r0, r2
 800ccb2:	0019      	movs	r1, r3
 800ccb4:	f7f5 f910 	bl	8001ed8 <__aeabi_dmul>
 800ccb8:	2200      	movs	r2, #0
 800ccba:	4b63      	ldr	r3, [pc, #396]	; (800ce48 <__ieee754_pow+0x73c>)
 800ccbc:	0004      	movs	r4, r0
 800ccbe:	000d      	movs	r5, r1
 800ccc0:	f7f4 fab8 	bl	8001234 <__aeabi_dadd>
 800ccc4:	9a0e      	ldr	r2, [sp, #56]	; 0x38
 800ccc6:	9b0f      	ldr	r3, [sp, #60]	; 0x3c
 800ccc8:	f7f4 fab4 	bl	8001234 <__aeabi_dadd>
 800cccc:	9e04      	ldr	r6, [sp, #16]
 800ccce:	000f      	movs	r7, r1
 800ccd0:	0032      	movs	r2, r6
 800ccd2:	000b      	movs	r3, r1
 800ccd4:	9800      	ldr	r0, [sp, #0]
 800ccd6:	9901      	ldr	r1, [sp, #4]
 800ccd8:	f7f5 f8fe 	bl	8001ed8 <__aeabi_dmul>
 800ccdc:	2200      	movs	r2, #0
 800ccde:	9000      	str	r0, [sp, #0]
 800cce0:	9101      	str	r1, [sp, #4]
 800cce2:	4b59      	ldr	r3, [pc, #356]	; (800ce48 <__ieee754_pow+0x73c>)
 800cce4:	0030      	movs	r0, r6
 800cce6:	0039      	movs	r1, r7
 800cce8:	f7f5 fb62 	bl	80023b0 <__aeabi_dsub>
 800ccec:	0022      	movs	r2, r4
 800ccee:	002b      	movs	r3, r5
 800ccf0:	f7f5 fb5e 	bl	80023b0 <__aeabi_dsub>
 800ccf4:	0002      	movs	r2, r0
 800ccf6:	000b      	movs	r3, r1
 800ccf8:	980e      	ldr	r0, [sp, #56]	; 0x38
 800ccfa:	990f      	ldr	r1, [sp, #60]	; 0x3c
 800ccfc:	f7f5 fb58 	bl	80023b0 <__aeabi_dsub>
 800cd00:	9a08      	ldr	r2, [sp, #32]
 800cd02:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800cd04:	f7f5 f8e8 	bl	8001ed8 <__aeabi_dmul>
 800cd08:	0032      	movs	r2, r6
 800cd0a:	0004      	movs	r4, r0
 800cd0c:	000d      	movs	r5, r1
 800cd0e:	980a      	ldr	r0, [sp, #40]	; 0x28
 800cd10:	990b      	ldr	r1, [sp, #44]	; 0x2c
 800cd12:	003b      	movs	r3, r7
 800cd14:	f7f5 f8e0 	bl	8001ed8 <__aeabi_dmul>
 800cd18:	0002      	movs	r2, r0
 800cd1a:	000b      	movs	r3, r1
 800cd1c:	0020      	movs	r0, r4
 800cd1e:	0029      	movs	r1, r5
 800cd20:	f7f4 fa88 	bl	8001234 <__aeabi_dadd>
 800cd24:	0004      	movs	r4, r0
 800cd26:	000d      	movs	r5, r1
 800cd28:	0002      	movs	r2, r0
 800cd2a:	000b      	movs	r3, r1
 800cd2c:	9800      	ldr	r0, [sp, #0]
 800cd2e:	9901      	ldr	r1, [sp, #4]
 800cd30:	f7f4 fa80 	bl	8001234 <__aeabi_dadd>
 800cd34:	22e0      	movs	r2, #224	; 0xe0
 800cd36:	9e04      	ldr	r6, [sp, #16]
 800cd38:	4b44      	ldr	r3, [pc, #272]	; (800ce4c <__ieee754_pow+0x740>)
 800cd3a:	0030      	movs	r0, r6
 800cd3c:	0612      	lsls	r2, r2, #24
 800cd3e:	000f      	movs	r7, r1
 800cd40:	f7f5 f8ca 	bl	8001ed8 <__aeabi_dmul>
 800cd44:	9008      	str	r0, [sp, #32]
 800cd46:	9109      	str	r1, [sp, #36]	; 0x24
 800cd48:	9a00      	ldr	r2, [sp, #0]
 800cd4a:	9b01      	ldr	r3, [sp, #4]
 800cd4c:	0030      	movs	r0, r6
 800cd4e:	0039      	movs	r1, r7
 800cd50:	f7f5 fb2e 	bl	80023b0 <__aeabi_dsub>
 800cd54:	0002      	movs	r2, r0
 800cd56:	000b      	movs	r3, r1
 800cd58:	0020      	movs	r0, r4
 800cd5a:	0029      	movs	r1, r5
 800cd5c:	f7f5 fb28 	bl	80023b0 <__aeabi_dsub>
 800cd60:	4a3b      	ldr	r2, [pc, #236]	; (800ce50 <__ieee754_pow+0x744>)
 800cd62:	4b3a      	ldr	r3, [pc, #232]	; (800ce4c <__ieee754_pow+0x740>)
 800cd64:	f7f5 f8b8 	bl	8001ed8 <__aeabi_dmul>
 800cd68:	4a3a      	ldr	r2, [pc, #232]	; (800ce54 <__ieee754_pow+0x748>)
 800cd6a:	0004      	movs	r4, r0
 800cd6c:	000d      	movs	r5, r1
 800cd6e:	0030      	movs	r0, r6
 800cd70:	0039      	movs	r1, r7
 800cd72:	4b39      	ldr	r3, [pc, #228]	; (800ce58 <__ieee754_pow+0x74c>)
 800cd74:	f7f5 f8b0 	bl	8001ed8 <__aeabi_dmul>
 800cd78:	0002      	movs	r2, r0
 800cd7a:	000b      	movs	r3, r1
 800cd7c:	0020      	movs	r0, r4
 800cd7e:	0029      	movs	r1, r5
 800cd80:	f7f4 fa58 	bl	8001234 <__aeabi_dadd>
 800cd84:	9a11      	ldr	r2, [sp, #68]	; 0x44
 800cd86:	4b35      	ldr	r3, [pc, #212]	; (800ce5c <__ieee754_pow+0x750>)
 800cd88:	189b      	adds	r3, r3, r2
 800cd8a:	681a      	ldr	r2, [r3, #0]
 800cd8c:	685b      	ldr	r3, [r3, #4]
 800cd8e:	f7f4 fa51 	bl	8001234 <__aeabi_dadd>
 800cd92:	900a      	str	r0, [sp, #40]	; 0x28
 800cd94:	910b      	str	r1, [sp, #44]	; 0x2c
 800cd96:	980d      	ldr	r0, [sp, #52]	; 0x34
 800cd98:	f7f5 fed2 	bl	8002b40 <__aeabi_i2d>
 800cd9c:	0004      	movs	r4, r0
 800cd9e:	000d      	movs	r5, r1
 800cda0:	9808      	ldr	r0, [sp, #32]
 800cda2:	9909      	ldr	r1, [sp, #36]	; 0x24
 800cda4:	9a11      	ldr	r2, [sp, #68]	; 0x44
 800cda6:	4b2e      	ldr	r3, [pc, #184]	; (800ce60 <__ieee754_pow+0x754>)
 800cda8:	189b      	adds	r3, r3, r2
 800cdaa:	681a      	ldr	r2, [r3, #0]
 800cdac:	685b      	ldr	r3, [r3, #4]
 800cdae:	9200      	str	r2, [sp, #0]
 800cdb0:	9301      	str	r3, [sp, #4]
 800cdb2:	9a0a      	ldr	r2, [sp, #40]	; 0x28
 800cdb4:	9b0b      	ldr	r3, [sp, #44]	; 0x2c
 800cdb6:	f7f4 fa3d 	bl	8001234 <__aeabi_dadd>
 800cdba:	9a00      	ldr	r2, [sp, #0]
 800cdbc:	9b01      	ldr	r3, [sp, #4]
 800cdbe:	f7f4 fa39 	bl	8001234 <__aeabi_dadd>
 800cdc2:	0022      	movs	r2, r4
 800cdc4:	002b      	movs	r3, r5
 800cdc6:	f7f4 fa35 	bl	8001234 <__aeabi_dadd>
 800cdca:	9804      	ldr	r0, [sp, #16]
 800cdcc:	0022      	movs	r2, r4
 800cdce:	002b      	movs	r3, r5
 800cdd0:	0006      	movs	r6, r0
 800cdd2:	000f      	movs	r7, r1
 800cdd4:	f7f5 faec 	bl	80023b0 <__aeabi_dsub>
 800cdd8:	9a00      	ldr	r2, [sp, #0]
 800cdda:	9b01      	ldr	r3, [sp, #4]
 800cddc:	f7f5 fae8 	bl	80023b0 <__aeabi_dsub>
 800cde0:	9a08      	ldr	r2, [sp, #32]
 800cde2:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800cde4:	f7f5 fae4 	bl	80023b0 <__aeabi_dsub>
 800cde8:	0002      	movs	r2, r0
 800cdea:	000b      	movs	r3, r1
 800cdec:	980a      	ldr	r0, [sp, #40]	; 0x28
 800cdee:	990b      	ldr	r1, [sp, #44]	; 0x2c
 800cdf0:	e614      	b.n	800ca1c <__ieee754_pow+0x310>
 800cdf2:	2300      	movs	r3, #0
 800cdf4:	4c03      	ldr	r4, [pc, #12]	; (800ce04 <__ieee754_pow+0x6f8>)
 800cdf6:	e61d      	b.n	800ca34 <__ieee754_pow+0x328>
 800cdf8:	7ff00000 	.word	0x7ff00000
 800cdfc:	43400000 	.word	0x43400000
 800ce00:	fffffc01 	.word	0xfffffc01
 800ce04:	3ff00000 	.word	0x3ff00000
 800ce08:	0003988e 	.word	0x0003988e
 800ce0c:	000bb679 	.word	0x000bb679
 800ce10:	fff00000 	.word	0xfff00000
 800ce14:	0800f380 	.word	0x0800f380
 800ce18:	4a454eef 	.word	0x4a454eef
 800ce1c:	3fca7e28 	.word	0x3fca7e28
 800ce20:	93c9db65 	.word	0x93c9db65
 800ce24:	3fcd864a 	.word	0x3fcd864a
 800ce28:	a91d4101 	.word	0xa91d4101
 800ce2c:	3fd17460 	.word	0x3fd17460
 800ce30:	518f264d 	.word	0x518f264d
 800ce34:	3fd55555 	.word	0x3fd55555
 800ce38:	db6fabff 	.word	0xdb6fabff
 800ce3c:	3fdb6db6 	.word	0x3fdb6db6
 800ce40:	33333303 	.word	0x33333303
 800ce44:	3fe33333 	.word	0x3fe33333
 800ce48:	40080000 	.word	0x40080000
 800ce4c:	3feec709 	.word	0x3feec709
 800ce50:	dc3a03fd 	.word	0xdc3a03fd
 800ce54:	145b01f5 	.word	0x145b01f5
 800ce58:	be3e2fe0 	.word	0xbe3e2fe0
 800ce5c:	0800f3a0 	.word	0x0800f3a0
 800ce60:	0800f390 	.word	0x0800f390
 800ce64:	4a8f      	ldr	r2, [pc, #572]	; (800d0a4 <__ieee754_pow+0x998>)
 800ce66:	4b90      	ldr	r3, [pc, #576]	; (800d0a8 <__ieee754_pow+0x99c>)
 800ce68:	9804      	ldr	r0, [sp, #16]
 800ce6a:	9905      	ldr	r1, [sp, #20]
 800ce6c:	f7f4 f9e2 	bl	8001234 <__aeabi_dadd>
 800ce70:	0032      	movs	r2, r6
 800ce72:	9002      	str	r0, [sp, #8]
 800ce74:	9103      	str	r1, [sp, #12]
 800ce76:	003b      	movs	r3, r7
 800ce78:	0028      	movs	r0, r5
 800ce7a:	0021      	movs	r1, r4
 800ce7c:	f7f5 fa98 	bl	80023b0 <__aeabi_dsub>
 800ce80:	0002      	movs	r2, r0
 800ce82:	000b      	movs	r3, r1
 800ce84:	9802      	ldr	r0, [sp, #8]
 800ce86:	9903      	ldr	r1, [sp, #12]
 800ce88:	f7f5 ff84 	bl	8002d94 <__aeabi_dcmpgt>
 800ce8c:	2800      	cmp	r0, #0
 800ce8e:	d000      	beq.n	800ce92 <__ieee754_pow+0x786>
 800ce90:	e60b      	b.n	800caaa <__ieee754_pow+0x39e>
 800ce92:	2100      	movs	r1, #0
 800ce94:	4a85      	ldr	r2, [pc, #532]	; (800d0ac <__ieee754_pow+0x9a0>)
 800ce96:	0063      	lsls	r3, r4, #1
 800ce98:	085b      	lsrs	r3, r3, #1
 800ce9a:	9102      	str	r1, [sp, #8]
 800ce9c:	4293      	cmp	r3, r2
 800ce9e:	dd25      	ble.n	800ceec <__ieee754_pow+0x7e0>
 800cea0:	4a83      	ldr	r2, [pc, #524]	; (800d0b0 <__ieee754_pow+0x9a4>)
 800cea2:	151b      	asrs	r3, r3, #20
 800cea4:	189b      	adds	r3, r3, r2
 800cea6:	2280      	movs	r2, #128	; 0x80
 800cea8:	0352      	lsls	r2, r2, #13
 800ceaa:	4694      	mov	ip, r2
 800ceac:	411a      	asrs	r2, r3
 800ceae:	1914      	adds	r4, r2, r4
 800ceb0:	4b80      	ldr	r3, [pc, #512]	; (800d0b4 <__ieee754_pow+0x9a8>)
 800ceb2:	0060      	lsls	r0, r4, #1
 800ceb4:	4d80      	ldr	r5, [pc, #512]	; (800d0b8 <__ieee754_pow+0x9ac>)
 800ceb6:	0d40      	lsrs	r0, r0, #21
 800ceb8:	18c0      	adds	r0, r0, r3
 800ceba:	4105      	asrs	r5, r0
 800cebc:	0021      	movs	r1, r4
 800cebe:	43a9      	bics	r1, r5
 800cec0:	000b      	movs	r3, r1
 800cec2:	4661      	mov	r1, ip
 800cec4:	0324      	lsls	r4, r4, #12
 800cec6:	0b24      	lsrs	r4, r4, #12
 800cec8:	4321      	orrs	r1, r4
 800ceca:	2414      	movs	r4, #20
 800cecc:	1a20      	subs	r0, r4, r0
 800cece:	4101      	asrs	r1, r0
 800ced0:	9102      	str	r1, [sp, #8]
 800ced2:	9908      	ldr	r1, [sp, #32]
 800ced4:	2200      	movs	r2, #0
 800ced6:	2900      	cmp	r1, #0
 800ced8:	da02      	bge.n	800cee0 <__ieee754_pow+0x7d4>
 800ceda:	9902      	ldr	r1, [sp, #8]
 800cedc:	4249      	negs	r1, r1
 800cede:	9102      	str	r1, [sp, #8]
 800cee0:	0030      	movs	r0, r6
 800cee2:	0039      	movs	r1, r7
 800cee4:	f7f5 fa64 	bl	80023b0 <__aeabi_dsub>
 800cee8:	9006      	str	r0, [sp, #24]
 800ceea:	9107      	str	r1, [sp, #28]
 800ceec:	9a04      	ldr	r2, [sp, #16]
 800ceee:	9b05      	ldr	r3, [sp, #20]
 800cef0:	9806      	ldr	r0, [sp, #24]
 800cef2:	9907      	ldr	r1, [sp, #28]
 800cef4:	2600      	movs	r6, #0
 800cef6:	f7f4 f99d 	bl	8001234 <__aeabi_dadd>
 800cefa:	2200      	movs	r2, #0
 800cefc:	0030      	movs	r0, r6
 800cefe:	4b6f      	ldr	r3, [pc, #444]	; (800d0bc <__ieee754_pow+0x9b0>)
 800cf00:	000f      	movs	r7, r1
 800cf02:	f7f4 ffe9 	bl	8001ed8 <__aeabi_dmul>
 800cf06:	9a06      	ldr	r2, [sp, #24]
 800cf08:	9b07      	ldr	r3, [sp, #28]
 800cf0a:	9008      	str	r0, [sp, #32]
 800cf0c:	9109      	str	r1, [sp, #36]	; 0x24
 800cf0e:	0030      	movs	r0, r6
 800cf10:	0039      	movs	r1, r7
 800cf12:	f7f5 fa4d 	bl	80023b0 <__aeabi_dsub>
 800cf16:	0002      	movs	r2, r0
 800cf18:	000b      	movs	r3, r1
 800cf1a:	9804      	ldr	r0, [sp, #16]
 800cf1c:	9905      	ldr	r1, [sp, #20]
 800cf1e:	f7f5 fa47 	bl	80023b0 <__aeabi_dsub>
 800cf22:	4a67      	ldr	r2, [pc, #412]	; (800d0c0 <__ieee754_pow+0x9b4>)
 800cf24:	4b67      	ldr	r3, [pc, #412]	; (800d0c4 <__ieee754_pow+0x9b8>)
 800cf26:	f7f4 ffd7 	bl	8001ed8 <__aeabi_dmul>
 800cf2a:	4a67      	ldr	r2, [pc, #412]	; (800d0c8 <__ieee754_pow+0x9bc>)
 800cf2c:	0004      	movs	r4, r0
 800cf2e:	000d      	movs	r5, r1
 800cf30:	0030      	movs	r0, r6
 800cf32:	0039      	movs	r1, r7
 800cf34:	4b65      	ldr	r3, [pc, #404]	; (800d0cc <__ieee754_pow+0x9c0>)
 800cf36:	f7f4 ffcf 	bl	8001ed8 <__aeabi_dmul>
 800cf3a:	0002      	movs	r2, r0
 800cf3c:	000b      	movs	r3, r1
 800cf3e:	0020      	movs	r0, r4
 800cf40:	0029      	movs	r1, r5
 800cf42:	f7f4 f977 	bl	8001234 <__aeabi_dadd>
 800cf46:	0004      	movs	r4, r0
 800cf48:	000d      	movs	r5, r1
 800cf4a:	0002      	movs	r2, r0
 800cf4c:	000b      	movs	r3, r1
 800cf4e:	9808      	ldr	r0, [sp, #32]
 800cf50:	9909      	ldr	r1, [sp, #36]	; 0x24
 800cf52:	f7f4 f96f 	bl	8001234 <__aeabi_dadd>
 800cf56:	9a08      	ldr	r2, [sp, #32]
 800cf58:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800cf5a:	0006      	movs	r6, r0
 800cf5c:	000f      	movs	r7, r1
 800cf5e:	f7f5 fa27 	bl	80023b0 <__aeabi_dsub>
 800cf62:	0002      	movs	r2, r0
 800cf64:	000b      	movs	r3, r1
 800cf66:	0020      	movs	r0, r4
 800cf68:	0029      	movs	r1, r5
 800cf6a:	f7f5 fa21 	bl	80023b0 <__aeabi_dsub>
 800cf6e:	0032      	movs	r2, r6
 800cf70:	9004      	str	r0, [sp, #16]
 800cf72:	9105      	str	r1, [sp, #20]
 800cf74:	003b      	movs	r3, r7
 800cf76:	0030      	movs	r0, r6
 800cf78:	0039      	movs	r1, r7
 800cf7a:	f7f4 ffad 	bl	8001ed8 <__aeabi_dmul>
 800cf7e:	0004      	movs	r4, r0
 800cf80:	000d      	movs	r5, r1
 800cf82:	4a53      	ldr	r2, [pc, #332]	; (800d0d0 <__ieee754_pow+0x9c4>)
 800cf84:	4b53      	ldr	r3, [pc, #332]	; (800d0d4 <__ieee754_pow+0x9c8>)
 800cf86:	f7f4 ffa7 	bl	8001ed8 <__aeabi_dmul>
 800cf8a:	4a53      	ldr	r2, [pc, #332]	; (800d0d8 <__ieee754_pow+0x9cc>)
 800cf8c:	4b53      	ldr	r3, [pc, #332]	; (800d0dc <__ieee754_pow+0x9d0>)
 800cf8e:	f7f5 fa0f 	bl	80023b0 <__aeabi_dsub>
 800cf92:	0022      	movs	r2, r4
 800cf94:	002b      	movs	r3, r5
 800cf96:	f7f4 ff9f 	bl	8001ed8 <__aeabi_dmul>
 800cf9a:	4a51      	ldr	r2, [pc, #324]	; (800d0e0 <__ieee754_pow+0x9d4>)
 800cf9c:	4b51      	ldr	r3, [pc, #324]	; (800d0e4 <__ieee754_pow+0x9d8>)
 800cf9e:	f7f4 f949 	bl	8001234 <__aeabi_dadd>
 800cfa2:	0022      	movs	r2, r4
 800cfa4:	002b      	movs	r3, r5
 800cfa6:	f7f4 ff97 	bl	8001ed8 <__aeabi_dmul>
 800cfaa:	4a4f      	ldr	r2, [pc, #316]	; (800d0e8 <__ieee754_pow+0x9dc>)
 800cfac:	4b4f      	ldr	r3, [pc, #316]	; (800d0ec <__ieee754_pow+0x9e0>)
 800cfae:	f7f5 f9ff 	bl	80023b0 <__aeabi_dsub>
 800cfb2:	0022      	movs	r2, r4
 800cfb4:	002b      	movs	r3, r5
 800cfb6:	f7f4 ff8f 	bl	8001ed8 <__aeabi_dmul>
 800cfba:	4a4d      	ldr	r2, [pc, #308]	; (800d0f0 <__ieee754_pow+0x9e4>)
 800cfbc:	4b4d      	ldr	r3, [pc, #308]	; (800d0f4 <__ieee754_pow+0x9e8>)
 800cfbe:	f7f4 f939 	bl	8001234 <__aeabi_dadd>
 800cfc2:	0022      	movs	r2, r4
 800cfc4:	002b      	movs	r3, r5
 800cfc6:	f7f4 ff87 	bl	8001ed8 <__aeabi_dmul>
 800cfca:	0002      	movs	r2, r0
 800cfcc:	000b      	movs	r3, r1
 800cfce:	0030      	movs	r0, r6
 800cfd0:	0039      	movs	r1, r7
 800cfd2:	f7f5 f9ed 	bl	80023b0 <__aeabi_dsub>
 800cfd6:	0004      	movs	r4, r0
 800cfd8:	000d      	movs	r5, r1
 800cfda:	0002      	movs	r2, r0
 800cfdc:	000b      	movs	r3, r1
 800cfde:	0030      	movs	r0, r6
 800cfe0:	0039      	movs	r1, r7
 800cfe2:	f7f4 ff79 	bl	8001ed8 <__aeabi_dmul>
 800cfe6:	2380      	movs	r3, #128	; 0x80
 800cfe8:	9006      	str	r0, [sp, #24]
 800cfea:	9107      	str	r1, [sp, #28]
 800cfec:	2200      	movs	r2, #0
 800cfee:	0020      	movs	r0, r4
 800cff0:	0029      	movs	r1, r5
 800cff2:	05db      	lsls	r3, r3, #23
 800cff4:	f7f5 f9dc 	bl	80023b0 <__aeabi_dsub>
 800cff8:	0002      	movs	r2, r0
 800cffa:	000b      	movs	r3, r1
 800cffc:	9806      	ldr	r0, [sp, #24]
 800cffe:	9907      	ldr	r1, [sp, #28]
 800d000:	f7f4 fc82 	bl	8001908 <__aeabi_ddiv>
 800d004:	9a04      	ldr	r2, [sp, #16]
 800d006:	9b05      	ldr	r3, [sp, #20]
 800d008:	0004      	movs	r4, r0
 800d00a:	000d      	movs	r5, r1
 800d00c:	0030      	movs	r0, r6
 800d00e:	0039      	movs	r1, r7
 800d010:	f7f4 ff62 	bl	8001ed8 <__aeabi_dmul>
 800d014:	9a04      	ldr	r2, [sp, #16]
 800d016:	9b05      	ldr	r3, [sp, #20]
 800d018:	f7f4 f90c 	bl	8001234 <__aeabi_dadd>
 800d01c:	0002      	movs	r2, r0
 800d01e:	000b      	movs	r3, r1
 800d020:	0020      	movs	r0, r4
 800d022:	0029      	movs	r1, r5
 800d024:	f7f5 f9c4 	bl	80023b0 <__aeabi_dsub>
 800d028:	0032      	movs	r2, r6
 800d02a:	003b      	movs	r3, r7
 800d02c:	f7f5 f9c0 	bl	80023b0 <__aeabi_dsub>
 800d030:	0002      	movs	r2, r0
 800d032:	000b      	movs	r3, r1
 800d034:	2000      	movs	r0, #0
 800d036:	4930      	ldr	r1, [pc, #192]	; (800d0f8 <__ieee754_pow+0x9ec>)
 800d038:	f7f5 f9ba 	bl	80023b0 <__aeabi_dsub>
 800d03c:	9b02      	ldr	r3, [sp, #8]
 800d03e:	051b      	lsls	r3, r3, #20
 800d040:	185b      	adds	r3, r3, r1
 800d042:	151a      	asrs	r2, r3, #20
 800d044:	2a00      	cmp	r2, #0
 800d046:	dc26      	bgt.n	800d096 <__ieee754_pow+0x98a>
 800d048:	9a02      	ldr	r2, [sp, #8]
 800d04a:	f001 f905 	bl	800e258 <scalbn>
 800d04e:	9a00      	ldr	r2, [sp, #0]
 800d050:	9b01      	ldr	r3, [sp, #4]
 800d052:	f7ff fc2d 	bl	800c8b0 <__ieee754_pow+0x1a4>
 800d056:	4a29      	ldr	r2, [pc, #164]	; (800d0fc <__ieee754_pow+0x9f0>)
 800d058:	004b      	lsls	r3, r1, #1
 800d05a:	085b      	lsrs	r3, r3, #1
 800d05c:	4293      	cmp	r3, r2
 800d05e:	dc00      	bgt.n	800d062 <__ieee754_pow+0x956>
 800d060:	e717      	b.n	800ce92 <__ieee754_pow+0x786>
 800d062:	4b27      	ldr	r3, [pc, #156]	; (800d100 <__ieee754_pow+0x9f4>)
 800d064:	18cb      	adds	r3, r1, r3
 800d066:	4303      	orrs	r3, r0
 800d068:	d009      	beq.n	800d07e <__ieee754_pow+0x972>
 800d06a:	9800      	ldr	r0, [sp, #0]
 800d06c:	9901      	ldr	r1, [sp, #4]
 800d06e:	4a25      	ldr	r2, [pc, #148]	; (800d104 <__ieee754_pow+0x9f8>)
 800d070:	4b25      	ldr	r3, [pc, #148]	; (800d108 <__ieee754_pow+0x9fc>)
 800d072:	f7f4 ff31 	bl	8001ed8 <__aeabi_dmul>
 800d076:	4a23      	ldr	r2, [pc, #140]	; (800d104 <__ieee754_pow+0x9f8>)
 800d078:	4b23      	ldr	r3, [pc, #140]	; (800d108 <__ieee754_pow+0x9fc>)
 800d07a:	f7ff fc19 	bl	800c8b0 <__ieee754_pow+0x1a4>
 800d07e:	0032      	movs	r2, r6
 800d080:	003b      	movs	r3, r7
 800d082:	f7f5 f995 	bl	80023b0 <__aeabi_dsub>
 800d086:	9a04      	ldr	r2, [sp, #16]
 800d088:	9b05      	ldr	r3, [sp, #20]
 800d08a:	f7f5 fe8d 	bl	8002da8 <__aeabi_dcmpge>
 800d08e:	2800      	cmp	r0, #0
 800d090:	d100      	bne.n	800d094 <__ieee754_pow+0x988>
 800d092:	e6fe      	b.n	800ce92 <__ieee754_pow+0x786>
 800d094:	e7e9      	b.n	800d06a <__ieee754_pow+0x95e>
 800d096:	0019      	movs	r1, r3
 800d098:	e7d9      	b.n	800d04e <__ieee754_pow+0x942>
 800d09a:	2300      	movs	r3, #0
 800d09c:	4c16      	ldr	r4, [pc, #88]	; (800d0f8 <__ieee754_pow+0x9ec>)
 800d09e:	f7ff fbec 	bl	800c87a <__ieee754_pow+0x16e>
 800d0a2:	46c0      	nop			; (mov r8, r8)
 800d0a4:	652b82fe 	.word	0x652b82fe
 800d0a8:	3c971547 	.word	0x3c971547
 800d0ac:	3fe00000 	.word	0x3fe00000
 800d0b0:	fffffc02 	.word	0xfffffc02
 800d0b4:	fffffc01 	.word	0xfffffc01
 800d0b8:	000fffff 	.word	0x000fffff
 800d0bc:	3fe62e43 	.word	0x3fe62e43
 800d0c0:	fefa39ef 	.word	0xfefa39ef
 800d0c4:	3fe62e42 	.word	0x3fe62e42
 800d0c8:	0ca86c39 	.word	0x0ca86c39
 800d0cc:	be205c61 	.word	0xbe205c61
 800d0d0:	72bea4d0 	.word	0x72bea4d0
 800d0d4:	3e663769 	.word	0x3e663769
 800d0d8:	c5d26bf1 	.word	0xc5d26bf1
 800d0dc:	3ebbbd41 	.word	0x3ebbbd41
 800d0e0:	af25de2c 	.word	0xaf25de2c
 800d0e4:	3f11566a 	.word	0x3f11566a
 800d0e8:	16bebd93 	.word	0x16bebd93
 800d0ec:	3f66c16c 	.word	0x3f66c16c
 800d0f0:	5555553e 	.word	0x5555553e
 800d0f4:	3fc55555 	.word	0x3fc55555
 800d0f8:	3ff00000 	.word	0x3ff00000
 800d0fc:	4090cbff 	.word	0x4090cbff
 800d100:	3f6f3400 	.word	0x3f6f3400
 800d104:	c2f8f359 	.word	0xc2f8f359
 800d108:	01a56e1f 	.word	0x01a56e1f

0800d10c <__ieee754_rem_pio2>:
 800d10c:	b5f0      	push	{r4, r5, r6, r7, lr}
 800d10e:	004b      	lsls	r3, r1, #1
 800d110:	b091      	sub	sp, #68	; 0x44
 800d112:	085b      	lsrs	r3, r3, #1
 800d114:	9302      	str	r3, [sp, #8]
 800d116:	0017      	movs	r7, r2
 800d118:	4bb6      	ldr	r3, [pc, #728]	; (800d3f4 <__ieee754_rem_pio2+0x2e8>)
 800d11a:	9a02      	ldr	r2, [sp, #8]
 800d11c:	0004      	movs	r4, r0
 800d11e:	000d      	movs	r5, r1
 800d120:	9109      	str	r1, [sp, #36]	; 0x24
 800d122:	429a      	cmp	r2, r3
 800d124:	dc09      	bgt.n	800d13a <__ieee754_rem_pio2+0x2e>
 800d126:	0002      	movs	r2, r0
 800d128:	000b      	movs	r3, r1
 800d12a:	603a      	str	r2, [r7, #0]
 800d12c:	607b      	str	r3, [r7, #4]
 800d12e:	2200      	movs	r2, #0
 800d130:	2300      	movs	r3, #0
 800d132:	60ba      	str	r2, [r7, #8]
 800d134:	60fb      	str	r3, [r7, #12]
 800d136:	2600      	movs	r6, #0
 800d138:	e025      	b.n	800d186 <__ieee754_rem_pio2+0x7a>
 800d13a:	4baf      	ldr	r3, [pc, #700]	; (800d3f8 <__ieee754_rem_pio2+0x2ec>)
 800d13c:	9a02      	ldr	r2, [sp, #8]
 800d13e:	429a      	cmp	r2, r3
 800d140:	dd00      	ble.n	800d144 <__ieee754_rem_pio2+0x38>
 800d142:	e06e      	b.n	800d222 <__ieee754_rem_pio2+0x116>
 800d144:	4ead      	ldr	r6, [pc, #692]	; (800d3fc <__ieee754_rem_pio2+0x2f0>)
 800d146:	4aae      	ldr	r2, [pc, #696]	; (800d400 <__ieee754_rem_pio2+0x2f4>)
 800d148:	2d00      	cmp	r5, #0
 800d14a:	dd35      	ble.n	800d1b8 <__ieee754_rem_pio2+0xac>
 800d14c:	0020      	movs	r0, r4
 800d14e:	0029      	movs	r1, r5
 800d150:	4baa      	ldr	r3, [pc, #680]	; (800d3fc <__ieee754_rem_pio2+0x2f0>)
 800d152:	f7f5 f92d 	bl	80023b0 <__aeabi_dsub>
 800d156:	9b02      	ldr	r3, [sp, #8]
 800d158:	0004      	movs	r4, r0
 800d15a:	000d      	movs	r5, r1
 800d15c:	42b3      	cmp	r3, r6
 800d15e:	d015      	beq.n	800d18c <__ieee754_rem_pio2+0x80>
 800d160:	4aa8      	ldr	r2, [pc, #672]	; (800d404 <__ieee754_rem_pio2+0x2f8>)
 800d162:	4ba9      	ldr	r3, [pc, #676]	; (800d408 <__ieee754_rem_pio2+0x2fc>)
 800d164:	f7f5 f924 	bl	80023b0 <__aeabi_dsub>
 800d168:	0002      	movs	r2, r0
 800d16a:	000b      	movs	r3, r1
 800d16c:	0020      	movs	r0, r4
 800d16e:	603a      	str	r2, [r7, #0]
 800d170:	607b      	str	r3, [r7, #4]
 800d172:	0029      	movs	r1, r5
 800d174:	f7f5 f91c 	bl	80023b0 <__aeabi_dsub>
 800d178:	4aa2      	ldr	r2, [pc, #648]	; (800d404 <__ieee754_rem_pio2+0x2f8>)
 800d17a:	4ba3      	ldr	r3, [pc, #652]	; (800d408 <__ieee754_rem_pio2+0x2fc>)
 800d17c:	f7f5 f918 	bl	80023b0 <__aeabi_dsub>
 800d180:	2601      	movs	r6, #1
 800d182:	60b8      	str	r0, [r7, #8]
 800d184:	60f9      	str	r1, [r7, #12]
 800d186:	0030      	movs	r0, r6
 800d188:	b011      	add	sp, #68	; 0x44
 800d18a:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800d18c:	22d3      	movs	r2, #211	; 0xd3
 800d18e:	4b9e      	ldr	r3, [pc, #632]	; (800d408 <__ieee754_rem_pio2+0x2fc>)
 800d190:	0552      	lsls	r2, r2, #21
 800d192:	f7f5 f90d 	bl	80023b0 <__aeabi_dsub>
 800d196:	4a9d      	ldr	r2, [pc, #628]	; (800d40c <__ieee754_rem_pio2+0x300>)
 800d198:	4b9d      	ldr	r3, [pc, #628]	; (800d410 <__ieee754_rem_pio2+0x304>)
 800d19a:	0004      	movs	r4, r0
 800d19c:	000d      	movs	r5, r1
 800d19e:	f7f5 f907 	bl	80023b0 <__aeabi_dsub>
 800d1a2:	0002      	movs	r2, r0
 800d1a4:	000b      	movs	r3, r1
 800d1a6:	0020      	movs	r0, r4
 800d1a8:	603a      	str	r2, [r7, #0]
 800d1aa:	607b      	str	r3, [r7, #4]
 800d1ac:	0029      	movs	r1, r5
 800d1ae:	f7f5 f8ff 	bl	80023b0 <__aeabi_dsub>
 800d1b2:	4a96      	ldr	r2, [pc, #600]	; (800d40c <__ieee754_rem_pio2+0x300>)
 800d1b4:	4b96      	ldr	r3, [pc, #600]	; (800d410 <__ieee754_rem_pio2+0x304>)
 800d1b6:	e7e1      	b.n	800d17c <__ieee754_rem_pio2+0x70>
 800d1b8:	0020      	movs	r0, r4
 800d1ba:	0029      	movs	r1, r5
 800d1bc:	4b8f      	ldr	r3, [pc, #572]	; (800d3fc <__ieee754_rem_pio2+0x2f0>)
 800d1be:	f7f4 f839 	bl	8001234 <__aeabi_dadd>
 800d1c2:	9b02      	ldr	r3, [sp, #8]
 800d1c4:	0004      	movs	r4, r0
 800d1c6:	000d      	movs	r5, r1
 800d1c8:	42b3      	cmp	r3, r6
 800d1ca:	d014      	beq.n	800d1f6 <__ieee754_rem_pio2+0xea>
 800d1cc:	4a8d      	ldr	r2, [pc, #564]	; (800d404 <__ieee754_rem_pio2+0x2f8>)
 800d1ce:	4b8e      	ldr	r3, [pc, #568]	; (800d408 <__ieee754_rem_pio2+0x2fc>)
 800d1d0:	f7f4 f830 	bl	8001234 <__aeabi_dadd>
 800d1d4:	0002      	movs	r2, r0
 800d1d6:	000b      	movs	r3, r1
 800d1d8:	0020      	movs	r0, r4
 800d1da:	603a      	str	r2, [r7, #0]
 800d1dc:	607b      	str	r3, [r7, #4]
 800d1de:	0029      	movs	r1, r5
 800d1e0:	f7f5 f8e6 	bl	80023b0 <__aeabi_dsub>
 800d1e4:	4a87      	ldr	r2, [pc, #540]	; (800d404 <__ieee754_rem_pio2+0x2f8>)
 800d1e6:	4b88      	ldr	r3, [pc, #544]	; (800d408 <__ieee754_rem_pio2+0x2fc>)
 800d1e8:	f7f4 f824 	bl	8001234 <__aeabi_dadd>
 800d1ec:	2601      	movs	r6, #1
 800d1ee:	60b8      	str	r0, [r7, #8]
 800d1f0:	60f9      	str	r1, [r7, #12]
 800d1f2:	4276      	negs	r6, r6
 800d1f4:	e7c7      	b.n	800d186 <__ieee754_rem_pio2+0x7a>
 800d1f6:	22d3      	movs	r2, #211	; 0xd3
 800d1f8:	4b83      	ldr	r3, [pc, #524]	; (800d408 <__ieee754_rem_pio2+0x2fc>)
 800d1fa:	0552      	lsls	r2, r2, #21
 800d1fc:	f7f4 f81a 	bl	8001234 <__aeabi_dadd>
 800d200:	4a82      	ldr	r2, [pc, #520]	; (800d40c <__ieee754_rem_pio2+0x300>)
 800d202:	4b83      	ldr	r3, [pc, #524]	; (800d410 <__ieee754_rem_pio2+0x304>)
 800d204:	0004      	movs	r4, r0
 800d206:	000d      	movs	r5, r1
 800d208:	f7f4 f814 	bl	8001234 <__aeabi_dadd>
 800d20c:	0002      	movs	r2, r0
 800d20e:	000b      	movs	r3, r1
 800d210:	0020      	movs	r0, r4
 800d212:	603a      	str	r2, [r7, #0]
 800d214:	607b      	str	r3, [r7, #4]
 800d216:	0029      	movs	r1, r5
 800d218:	f7f5 f8ca 	bl	80023b0 <__aeabi_dsub>
 800d21c:	4a7b      	ldr	r2, [pc, #492]	; (800d40c <__ieee754_rem_pio2+0x300>)
 800d21e:	4b7c      	ldr	r3, [pc, #496]	; (800d410 <__ieee754_rem_pio2+0x304>)
 800d220:	e7e2      	b.n	800d1e8 <__ieee754_rem_pio2+0xdc>
 800d222:	4b7c      	ldr	r3, [pc, #496]	; (800d414 <__ieee754_rem_pio2+0x308>)
 800d224:	9a02      	ldr	r2, [sp, #8]
 800d226:	429a      	cmp	r2, r3
 800d228:	dd00      	ble.n	800d22c <__ieee754_rem_pio2+0x120>
 800d22a:	e0d3      	b.n	800d3d4 <__ieee754_rem_pio2+0x2c8>
 800d22c:	0020      	movs	r0, r4
 800d22e:	0029      	movs	r1, r5
 800d230:	f000 feee 	bl	800e010 <fabs>
 800d234:	4a78      	ldr	r2, [pc, #480]	; (800d418 <__ieee754_rem_pio2+0x30c>)
 800d236:	4b79      	ldr	r3, [pc, #484]	; (800d41c <__ieee754_rem_pio2+0x310>)
 800d238:	0004      	movs	r4, r0
 800d23a:	000d      	movs	r5, r1
 800d23c:	f7f4 fe4c 	bl	8001ed8 <__aeabi_dmul>
 800d240:	2200      	movs	r2, #0
 800d242:	4b77      	ldr	r3, [pc, #476]	; (800d420 <__ieee754_rem_pio2+0x314>)
 800d244:	f7f3 fff6 	bl	8001234 <__aeabi_dadd>
 800d248:	f7f5 fc44 	bl	8002ad4 <__aeabi_d2iz>
 800d24c:	0006      	movs	r6, r0
 800d24e:	f7f5 fc77 	bl	8002b40 <__aeabi_i2d>
 800d252:	4a6b      	ldr	r2, [pc, #428]	; (800d400 <__ieee754_rem_pio2+0x2f4>)
 800d254:	4b69      	ldr	r3, [pc, #420]	; (800d3fc <__ieee754_rem_pio2+0x2f0>)
 800d256:	9006      	str	r0, [sp, #24]
 800d258:	9107      	str	r1, [sp, #28]
 800d25a:	f7f4 fe3d 	bl	8001ed8 <__aeabi_dmul>
 800d25e:	0002      	movs	r2, r0
 800d260:	000b      	movs	r3, r1
 800d262:	0020      	movs	r0, r4
 800d264:	0029      	movs	r1, r5
 800d266:	f7f5 f8a3 	bl	80023b0 <__aeabi_dsub>
 800d26a:	4a66      	ldr	r2, [pc, #408]	; (800d404 <__ieee754_rem_pio2+0x2f8>)
 800d26c:	9004      	str	r0, [sp, #16]
 800d26e:	9105      	str	r1, [sp, #20]
 800d270:	9806      	ldr	r0, [sp, #24]
 800d272:	9907      	ldr	r1, [sp, #28]
 800d274:	4b64      	ldr	r3, [pc, #400]	; (800d408 <__ieee754_rem_pio2+0x2fc>)
 800d276:	f7f4 fe2f 	bl	8001ed8 <__aeabi_dmul>
 800d27a:	0004      	movs	r4, r0
 800d27c:	000d      	movs	r5, r1
 800d27e:	2e1f      	cmp	r6, #31
 800d280:	dc0f      	bgt.n	800d2a2 <__ieee754_rem_pio2+0x196>
 800d282:	4a68      	ldr	r2, [pc, #416]	; (800d424 <__ieee754_rem_pio2+0x318>)
 800d284:	1e73      	subs	r3, r6, #1
 800d286:	009b      	lsls	r3, r3, #2
 800d288:	589b      	ldr	r3, [r3, r2]
 800d28a:	9a02      	ldr	r2, [sp, #8]
 800d28c:	4293      	cmp	r3, r2
 800d28e:	d008      	beq.n	800d2a2 <__ieee754_rem_pio2+0x196>
 800d290:	9804      	ldr	r0, [sp, #16]
 800d292:	9905      	ldr	r1, [sp, #20]
 800d294:	0022      	movs	r2, r4
 800d296:	002b      	movs	r3, r5
 800d298:	f7f5 f88a 	bl	80023b0 <__aeabi_dsub>
 800d29c:	6038      	str	r0, [r7, #0]
 800d29e:	6079      	str	r1, [r7, #4]
 800d2a0:	e012      	b.n	800d2c8 <__ieee754_rem_pio2+0x1bc>
 800d2a2:	0022      	movs	r2, r4
 800d2a4:	9804      	ldr	r0, [sp, #16]
 800d2a6:	9905      	ldr	r1, [sp, #20]
 800d2a8:	002b      	movs	r3, r5
 800d2aa:	f7f5 f881 	bl	80023b0 <__aeabi_dsub>
 800d2ae:	9b02      	ldr	r3, [sp, #8]
 800d2b0:	151b      	asrs	r3, r3, #20
 800d2b2:	9308      	str	r3, [sp, #32]
 800d2b4:	9a08      	ldr	r2, [sp, #32]
 800d2b6:	004b      	lsls	r3, r1, #1
 800d2b8:	0d5b      	lsrs	r3, r3, #21
 800d2ba:	1ad3      	subs	r3, r2, r3
 800d2bc:	2b10      	cmp	r3, #16
 800d2be:	dc21      	bgt.n	800d304 <__ieee754_rem_pio2+0x1f8>
 800d2c0:	0002      	movs	r2, r0
 800d2c2:	000b      	movs	r3, r1
 800d2c4:	603a      	str	r2, [r7, #0]
 800d2c6:	607b      	str	r3, [r7, #4]
 800d2c8:	9804      	ldr	r0, [sp, #16]
 800d2ca:	9905      	ldr	r1, [sp, #20]
 800d2cc:	687b      	ldr	r3, [r7, #4]
 800d2ce:	683a      	ldr	r2, [r7, #0]
 800d2d0:	9302      	str	r3, [sp, #8]
 800d2d2:	9b02      	ldr	r3, [sp, #8]
 800d2d4:	f7f5 f86c 	bl	80023b0 <__aeabi_dsub>
 800d2d8:	0022      	movs	r2, r4
 800d2da:	002b      	movs	r3, r5
 800d2dc:	f7f5 f868 	bl	80023b0 <__aeabi_dsub>
 800d2e0:	000b      	movs	r3, r1
 800d2e2:	0002      	movs	r2, r0
 800d2e4:	60ba      	str	r2, [r7, #8]
 800d2e6:	60fb      	str	r3, [r7, #12]
 800d2e8:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800d2ea:	2b00      	cmp	r3, #0
 800d2ec:	db00      	blt.n	800d2f0 <__ieee754_rem_pio2+0x1e4>
 800d2ee:	e74a      	b.n	800d186 <__ieee754_rem_pio2+0x7a>
 800d2f0:	2280      	movs	r2, #128	; 0x80
 800d2f2:	0612      	lsls	r2, r2, #24
 800d2f4:	4694      	mov	ip, r2
 800d2f6:	9b02      	ldr	r3, [sp, #8]
 800d2f8:	1889      	adds	r1, r1, r2
 800d2fa:	4463      	add	r3, ip
 800d2fc:	607b      	str	r3, [r7, #4]
 800d2fe:	60b8      	str	r0, [r7, #8]
 800d300:	60f9      	str	r1, [r7, #12]
 800d302:	e776      	b.n	800d1f2 <__ieee754_rem_pio2+0xe6>
 800d304:	22d3      	movs	r2, #211	; 0xd3
 800d306:	9806      	ldr	r0, [sp, #24]
 800d308:	9907      	ldr	r1, [sp, #28]
 800d30a:	4b3f      	ldr	r3, [pc, #252]	; (800d408 <__ieee754_rem_pio2+0x2fc>)
 800d30c:	0552      	lsls	r2, r2, #21
 800d30e:	f7f4 fde3 	bl	8001ed8 <__aeabi_dmul>
 800d312:	0004      	movs	r4, r0
 800d314:	000d      	movs	r5, r1
 800d316:	0002      	movs	r2, r0
 800d318:	000b      	movs	r3, r1
 800d31a:	9804      	ldr	r0, [sp, #16]
 800d31c:	9905      	ldr	r1, [sp, #20]
 800d31e:	f7f5 f847 	bl	80023b0 <__aeabi_dsub>
 800d322:	0002      	movs	r2, r0
 800d324:	000b      	movs	r3, r1
 800d326:	9002      	str	r0, [sp, #8]
 800d328:	9103      	str	r1, [sp, #12]
 800d32a:	9804      	ldr	r0, [sp, #16]
 800d32c:	9905      	ldr	r1, [sp, #20]
 800d32e:	f7f5 f83f 	bl	80023b0 <__aeabi_dsub>
 800d332:	0022      	movs	r2, r4
 800d334:	002b      	movs	r3, r5
 800d336:	f7f5 f83b 	bl	80023b0 <__aeabi_dsub>
 800d33a:	0004      	movs	r4, r0
 800d33c:	000d      	movs	r5, r1
 800d33e:	9806      	ldr	r0, [sp, #24]
 800d340:	9907      	ldr	r1, [sp, #28]
 800d342:	4a32      	ldr	r2, [pc, #200]	; (800d40c <__ieee754_rem_pio2+0x300>)
 800d344:	4b32      	ldr	r3, [pc, #200]	; (800d410 <__ieee754_rem_pio2+0x304>)
 800d346:	f7f4 fdc7 	bl	8001ed8 <__aeabi_dmul>
 800d34a:	0022      	movs	r2, r4
 800d34c:	002b      	movs	r3, r5
 800d34e:	f7f5 f82f 	bl	80023b0 <__aeabi_dsub>
 800d352:	0002      	movs	r2, r0
 800d354:	000b      	movs	r3, r1
 800d356:	0004      	movs	r4, r0
 800d358:	000d      	movs	r5, r1
 800d35a:	9802      	ldr	r0, [sp, #8]
 800d35c:	9903      	ldr	r1, [sp, #12]
 800d35e:	f7f5 f827 	bl	80023b0 <__aeabi_dsub>
 800d362:	9a08      	ldr	r2, [sp, #32]
 800d364:	004b      	lsls	r3, r1, #1
 800d366:	0d5b      	lsrs	r3, r3, #21
 800d368:	1ad3      	subs	r3, r2, r3
 800d36a:	2b31      	cmp	r3, #49	; 0x31
 800d36c:	dc08      	bgt.n	800d380 <__ieee754_rem_pio2+0x274>
 800d36e:	0002      	movs	r2, r0
 800d370:	000b      	movs	r3, r1
 800d372:	603a      	str	r2, [r7, #0]
 800d374:	607b      	str	r3, [r7, #4]
 800d376:	9a02      	ldr	r2, [sp, #8]
 800d378:	9b03      	ldr	r3, [sp, #12]
 800d37a:	9204      	str	r2, [sp, #16]
 800d37c:	9305      	str	r3, [sp, #20]
 800d37e:	e7a3      	b.n	800d2c8 <__ieee754_rem_pio2+0x1bc>
 800d380:	22b8      	movs	r2, #184	; 0xb8
 800d382:	9806      	ldr	r0, [sp, #24]
 800d384:	9907      	ldr	r1, [sp, #28]
 800d386:	4b22      	ldr	r3, [pc, #136]	; (800d410 <__ieee754_rem_pio2+0x304>)
 800d388:	0592      	lsls	r2, r2, #22
 800d38a:	f7f4 fda5 	bl	8001ed8 <__aeabi_dmul>
 800d38e:	0004      	movs	r4, r0
 800d390:	000d      	movs	r5, r1
 800d392:	0002      	movs	r2, r0
 800d394:	000b      	movs	r3, r1
 800d396:	9802      	ldr	r0, [sp, #8]
 800d398:	9903      	ldr	r1, [sp, #12]
 800d39a:	f7f5 f809 	bl	80023b0 <__aeabi_dsub>
 800d39e:	0002      	movs	r2, r0
 800d3a0:	000b      	movs	r3, r1
 800d3a2:	9004      	str	r0, [sp, #16]
 800d3a4:	9105      	str	r1, [sp, #20]
 800d3a6:	9802      	ldr	r0, [sp, #8]
 800d3a8:	9903      	ldr	r1, [sp, #12]
 800d3aa:	f7f5 f801 	bl	80023b0 <__aeabi_dsub>
 800d3ae:	0022      	movs	r2, r4
 800d3b0:	002b      	movs	r3, r5
 800d3b2:	f7f4 fffd 	bl	80023b0 <__aeabi_dsub>
 800d3b6:	0004      	movs	r4, r0
 800d3b8:	000d      	movs	r5, r1
 800d3ba:	9806      	ldr	r0, [sp, #24]
 800d3bc:	9907      	ldr	r1, [sp, #28]
 800d3be:	4a1a      	ldr	r2, [pc, #104]	; (800d428 <__ieee754_rem_pio2+0x31c>)
 800d3c0:	4b1a      	ldr	r3, [pc, #104]	; (800d42c <__ieee754_rem_pio2+0x320>)
 800d3c2:	f7f4 fd89 	bl	8001ed8 <__aeabi_dmul>
 800d3c6:	0022      	movs	r2, r4
 800d3c8:	002b      	movs	r3, r5
 800d3ca:	f7f4 fff1 	bl	80023b0 <__aeabi_dsub>
 800d3ce:	0004      	movs	r4, r0
 800d3d0:	000d      	movs	r5, r1
 800d3d2:	e75d      	b.n	800d290 <__ieee754_rem_pio2+0x184>
 800d3d4:	4b16      	ldr	r3, [pc, #88]	; (800d430 <__ieee754_rem_pio2+0x324>)
 800d3d6:	9a02      	ldr	r2, [sp, #8]
 800d3d8:	429a      	cmp	r2, r3
 800d3da:	dd2b      	ble.n	800d434 <__ieee754_rem_pio2+0x328>
 800d3dc:	0022      	movs	r2, r4
 800d3de:	002b      	movs	r3, r5
 800d3e0:	0020      	movs	r0, r4
 800d3e2:	0029      	movs	r1, r5
 800d3e4:	f7f4 ffe4 	bl	80023b0 <__aeabi_dsub>
 800d3e8:	60b8      	str	r0, [r7, #8]
 800d3ea:	60f9      	str	r1, [r7, #12]
 800d3ec:	6038      	str	r0, [r7, #0]
 800d3ee:	6079      	str	r1, [r7, #4]
 800d3f0:	e6a1      	b.n	800d136 <__ieee754_rem_pio2+0x2a>
 800d3f2:	46c0      	nop			; (mov r8, r8)
 800d3f4:	3fe921fb 	.word	0x3fe921fb
 800d3f8:	4002d97b 	.word	0x4002d97b
 800d3fc:	3ff921fb 	.word	0x3ff921fb
 800d400:	54400000 	.word	0x54400000
 800d404:	1a626331 	.word	0x1a626331
 800d408:	3dd0b461 	.word	0x3dd0b461
 800d40c:	2e037073 	.word	0x2e037073
 800d410:	3ba3198a 	.word	0x3ba3198a
 800d414:	413921fb 	.word	0x413921fb
 800d418:	6dc9c883 	.word	0x6dc9c883
 800d41c:	3fe45f30 	.word	0x3fe45f30
 800d420:	3fe00000 	.word	0x3fe00000
 800d424:	0800f3b0 	.word	0x0800f3b0
 800d428:	252049c1 	.word	0x252049c1
 800d42c:	397b839a 	.word	0x397b839a
 800d430:	7fefffff 	.word	0x7fefffff
 800d434:	9a02      	ldr	r2, [sp, #8]
 800d436:	0020      	movs	r0, r4
 800d438:	1516      	asrs	r6, r2, #20
 800d43a:	4a27      	ldr	r2, [pc, #156]	; (800d4d8 <__ieee754_rem_pio2+0x3cc>)
 800d43c:	18b6      	adds	r6, r6, r2
 800d43e:	9a02      	ldr	r2, [sp, #8]
 800d440:	0533      	lsls	r3, r6, #20
 800d442:	1ad5      	subs	r5, r2, r3
 800d444:	0029      	movs	r1, r5
 800d446:	f7f5 fb45 	bl	8002ad4 <__aeabi_d2iz>
 800d44a:	f7f5 fb79 	bl	8002b40 <__aeabi_i2d>
 800d44e:	0002      	movs	r2, r0
 800d450:	000b      	movs	r3, r1
 800d452:	0020      	movs	r0, r4
 800d454:	0029      	movs	r1, r5
 800d456:	920a      	str	r2, [sp, #40]	; 0x28
 800d458:	930b      	str	r3, [sp, #44]	; 0x2c
 800d45a:	f7f4 ffa9 	bl	80023b0 <__aeabi_dsub>
 800d45e:	2200      	movs	r2, #0
 800d460:	4b1e      	ldr	r3, [pc, #120]	; (800d4dc <__ieee754_rem_pio2+0x3d0>)
 800d462:	f7f4 fd39 	bl	8001ed8 <__aeabi_dmul>
 800d466:	000d      	movs	r5, r1
 800d468:	0004      	movs	r4, r0
 800d46a:	f7f5 fb33 	bl	8002ad4 <__aeabi_d2iz>
 800d46e:	f7f5 fb67 	bl	8002b40 <__aeabi_i2d>
 800d472:	0002      	movs	r2, r0
 800d474:	000b      	movs	r3, r1
 800d476:	0020      	movs	r0, r4
 800d478:	0029      	movs	r1, r5
 800d47a:	920c      	str	r2, [sp, #48]	; 0x30
 800d47c:	930d      	str	r3, [sp, #52]	; 0x34
 800d47e:	f7f4 ff97 	bl	80023b0 <__aeabi_dsub>
 800d482:	2200      	movs	r2, #0
 800d484:	4b15      	ldr	r3, [pc, #84]	; (800d4dc <__ieee754_rem_pio2+0x3d0>)
 800d486:	f7f4 fd27 	bl	8001ed8 <__aeabi_dmul>
 800d48a:	2503      	movs	r5, #3
 800d48c:	900e      	str	r0, [sp, #56]	; 0x38
 800d48e:	910f      	str	r1, [sp, #60]	; 0x3c
 800d490:	ac0a      	add	r4, sp, #40	; 0x28
 800d492:	2200      	movs	r2, #0
 800d494:	6920      	ldr	r0, [r4, #16]
 800d496:	6961      	ldr	r1, [r4, #20]
 800d498:	2300      	movs	r3, #0
 800d49a:	9502      	str	r5, [sp, #8]
 800d49c:	3c08      	subs	r4, #8
 800d49e:	3d01      	subs	r5, #1
 800d4a0:	f7f5 fc5e 	bl	8002d60 <__aeabi_dcmpeq>
 800d4a4:	2800      	cmp	r0, #0
 800d4a6:	d1f4      	bne.n	800d492 <__ieee754_rem_pio2+0x386>
 800d4a8:	4b0d      	ldr	r3, [pc, #52]	; (800d4e0 <__ieee754_rem_pio2+0x3d4>)
 800d4aa:	0032      	movs	r2, r6
 800d4ac:	9301      	str	r3, [sp, #4]
 800d4ae:	2302      	movs	r3, #2
 800d4b0:	0039      	movs	r1, r7
 800d4b2:	9300      	str	r3, [sp, #0]
 800d4b4:	a80a      	add	r0, sp, #40	; 0x28
 800d4b6:	9b02      	ldr	r3, [sp, #8]
 800d4b8:	f000 f988 	bl	800d7cc <__kernel_rem_pio2>
 800d4bc:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800d4be:	0006      	movs	r6, r0
 800d4c0:	2b00      	cmp	r3, #0
 800d4c2:	db00      	blt.n	800d4c6 <__ieee754_rem_pio2+0x3ba>
 800d4c4:	e65f      	b.n	800d186 <__ieee754_rem_pio2+0x7a>
 800d4c6:	2280      	movs	r2, #128	; 0x80
 800d4c8:	687b      	ldr	r3, [r7, #4]
 800d4ca:	0612      	lsls	r2, r2, #24
 800d4cc:	189b      	adds	r3, r3, r2
 800d4ce:	607b      	str	r3, [r7, #4]
 800d4d0:	68fb      	ldr	r3, [r7, #12]
 800d4d2:	189b      	adds	r3, r3, r2
 800d4d4:	60fb      	str	r3, [r7, #12]
 800d4d6:	e68c      	b.n	800d1f2 <__ieee754_rem_pio2+0xe6>
 800d4d8:	fffffbea 	.word	0xfffffbea
 800d4dc:	41700000 	.word	0x41700000
 800d4e0:	0800f430 	.word	0x0800f430

0800d4e4 <__ieee754_sqrt>:
 800d4e4:	4b56      	ldr	r3, [pc, #344]	; (800d640 <__ieee754_sqrt+0x15c>)
 800d4e6:	b5f0      	push	{r4, r5, r6, r7, lr}
 800d4e8:	0002      	movs	r2, r0
 800d4ea:	0005      	movs	r5, r0
 800d4ec:	0018      	movs	r0, r3
 800d4ee:	000c      	movs	r4, r1
 800d4f0:	b085      	sub	sp, #20
 800d4f2:	4008      	ands	r0, r1
 800d4f4:	4298      	cmp	r0, r3
 800d4f6:	d10f      	bne.n	800d518 <__ieee754_sqrt+0x34>
 800d4f8:	000b      	movs	r3, r1
 800d4fa:	0028      	movs	r0, r5
 800d4fc:	f7f4 fcec 	bl	8001ed8 <__aeabi_dmul>
 800d500:	0002      	movs	r2, r0
 800d502:	000b      	movs	r3, r1
 800d504:	0028      	movs	r0, r5
 800d506:	0021      	movs	r1, r4
 800d508:	f7f3 fe94 	bl	8001234 <__aeabi_dadd>
 800d50c:	0005      	movs	r5, r0
 800d50e:	000c      	movs	r4, r1
 800d510:	0028      	movs	r0, r5
 800d512:	0021      	movs	r1, r4
 800d514:	b005      	add	sp, #20
 800d516:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800d518:	2900      	cmp	r1, #0
 800d51a:	dc10      	bgt.n	800d53e <__ieee754_sqrt+0x5a>
 800d51c:	004b      	lsls	r3, r1, #1
 800d51e:	085b      	lsrs	r3, r3, #1
 800d520:	432b      	orrs	r3, r5
 800d522:	d0f5      	beq.n	800d510 <__ieee754_sqrt+0x2c>
 800d524:	2000      	movs	r0, #0
 800d526:	4281      	cmp	r1, r0
 800d528:	d100      	bne.n	800d52c <__ieee754_sqrt+0x48>
 800d52a:	e080      	b.n	800d62e <__ieee754_sqrt+0x14a>
 800d52c:	000b      	movs	r3, r1
 800d52e:	0028      	movs	r0, r5
 800d530:	f7f4 ff3e 	bl	80023b0 <__aeabi_dsub>
 800d534:	0002      	movs	r2, r0
 800d536:	000b      	movs	r3, r1
 800d538:	f7f4 f9e6 	bl	8001908 <__aeabi_ddiv>
 800d53c:	e7e6      	b.n	800d50c <__ieee754_sqrt+0x28>
 800d53e:	1508      	asrs	r0, r1, #20
 800d540:	d075      	beq.n	800d62e <__ieee754_sqrt+0x14a>
 800d542:	4b40      	ldr	r3, [pc, #256]	; (800d644 <__ieee754_sqrt+0x160>)
 800d544:	0309      	lsls	r1, r1, #12
 800d546:	18c4      	adds	r4, r0, r3
 800d548:	2380      	movs	r3, #128	; 0x80
 800d54a:	0b09      	lsrs	r1, r1, #12
 800d54c:	035b      	lsls	r3, r3, #13
 800d54e:	4319      	orrs	r1, r3
 800d550:	07c3      	lsls	r3, r0, #31
 800d552:	d403      	bmi.n	800d55c <__ieee754_sqrt+0x78>
 800d554:	0fd3      	lsrs	r3, r2, #31
 800d556:	0049      	lsls	r1, r1, #1
 800d558:	18c9      	adds	r1, r1, r3
 800d55a:	0052      	lsls	r2, r2, #1
 800d55c:	1063      	asrs	r3, r4, #1
 800d55e:	2400      	movs	r4, #0
 800d560:	0049      	lsls	r1, r1, #1
 800d562:	9303      	str	r3, [sp, #12]
 800d564:	0fd3      	lsrs	r3, r2, #31
 800d566:	18cb      	adds	r3, r1, r3
 800d568:	2180      	movs	r1, #128	; 0x80
 800d56a:	2516      	movs	r5, #22
 800d56c:	0020      	movs	r0, r4
 800d56e:	0052      	lsls	r2, r2, #1
 800d570:	0389      	lsls	r1, r1, #14
 800d572:	1846      	adds	r6, r0, r1
 800d574:	429e      	cmp	r6, r3
 800d576:	dc02      	bgt.n	800d57e <__ieee754_sqrt+0x9a>
 800d578:	1870      	adds	r0, r6, r1
 800d57a:	1b9b      	subs	r3, r3, r6
 800d57c:	1864      	adds	r4, r4, r1
 800d57e:	0fd6      	lsrs	r6, r2, #31
 800d580:	005b      	lsls	r3, r3, #1
 800d582:	3d01      	subs	r5, #1
 800d584:	18f3      	adds	r3, r6, r3
 800d586:	0052      	lsls	r2, r2, #1
 800d588:	0849      	lsrs	r1, r1, #1
 800d58a:	2d00      	cmp	r5, #0
 800d58c:	d1f1      	bne.n	800d572 <__ieee754_sqrt+0x8e>
 800d58e:	2620      	movs	r6, #32
 800d590:	2780      	movs	r7, #128	; 0x80
 800d592:	0029      	movs	r1, r5
 800d594:	9601      	str	r6, [sp, #4]
 800d596:	063f      	lsls	r7, r7, #24
 800d598:	197e      	adds	r6, r7, r5
 800d59a:	46b4      	mov	ip, r6
 800d59c:	4283      	cmp	r3, r0
 800d59e:	dc02      	bgt.n	800d5a6 <__ieee754_sqrt+0xc2>
 800d5a0:	d114      	bne.n	800d5cc <__ieee754_sqrt+0xe8>
 800d5a2:	4296      	cmp	r6, r2
 800d5a4:	d812      	bhi.n	800d5cc <__ieee754_sqrt+0xe8>
 800d5a6:	4665      	mov	r5, ip
 800d5a8:	4666      	mov	r6, ip
 800d5aa:	19ed      	adds	r5, r5, r7
 800d5ac:	9002      	str	r0, [sp, #8]
 800d5ae:	2e00      	cmp	r6, #0
 800d5b0:	da03      	bge.n	800d5ba <__ieee754_sqrt+0xd6>
 800d5b2:	43ee      	mvns	r6, r5
 800d5b4:	0ff6      	lsrs	r6, r6, #31
 800d5b6:	1986      	adds	r6, r0, r6
 800d5b8:	9602      	str	r6, [sp, #8]
 800d5ba:	1a1b      	subs	r3, r3, r0
 800d5bc:	4562      	cmp	r2, ip
 800d5be:	4180      	sbcs	r0, r0
 800d5c0:	4240      	negs	r0, r0
 800d5c2:	1a1b      	subs	r3, r3, r0
 800d5c4:	4660      	mov	r0, ip
 800d5c6:	1a12      	subs	r2, r2, r0
 800d5c8:	9802      	ldr	r0, [sp, #8]
 800d5ca:	19c9      	adds	r1, r1, r7
 800d5cc:	0fd6      	lsrs	r6, r2, #31
 800d5ce:	005b      	lsls	r3, r3, #1
 800d5d0:	18f3      	adds	r3, r6, r3
 800d5d2:	9e01      	ldr	r6, [sp, #4]
 800d5d4:	0052      	lsls	r2, r2, #1
 800d5d6:	3e01      	subs	r6, #1
 800d5d8:	087f      	lsrs	r7, r7, #1
 800d5da:	9601      	str	r6, [sp, #4]
 800d5dc:	2e00      	cmp	r6, #0
 800d5de:	d1db      	bne.n	800d598 <__ieee754_sqrt+0xb4>
 800d5e0:	4313      	orrs	r3, r2
 800d5e2:	d003      	beq.n	800d5ec <__ieee754_sqrt+0x108>
 800d5e4:	1c4b      	adds	r3, r1, #1
 800d5e6:	d127      	bne.n	800d638 <__ieee754_sqrt+0x154>
 800d5e8:	0031      	movs	r1, r6
 800d5ea:	3401      	adds	r4, #1
 800d5ec:	4b16      	ldr	r3, [pc, #88]	; (800d648 <__ieee754_sqrt+0x164>)
 800d5ee:	1060      	asrs	r0, r4, #1
 800d5f0:	18c0      	adds	r0, r0, r3
 800d5f2:	0849      	lsrs	r1, r1, #1
 800d5f4:	07e3      	lsls	r3, r4, #31
 800d5f6:	d502      	bpl.n	800d5fe <__ieee754_sqrt+0x11a>
 800d5f8:	2380      	movs	r3, #128	; 0x80
 800d5fa:	061b      	lsls	r3, r3, #24
 800d5fc:	4319      	orrs	r1, r3
 800d5fe:	9b03      	ldr	r3, [sp, #12]
 800d600:	000d      	movs	r5, r1
 800d602:	051c      	lsls	r4, r3, #20
 800d604:	1823      	adds	r3, r4, r0
 800d606:	001c      	movs	r4, r3
 800d608:	e782      	b.n	800d510 <__ieee754_sqrt+0x2c>
 800d60a:	0ad1      	lsrs	r1, r2, #11
 800d60c:	3b15      	subs	r3, #21
 800d60e:	0552      	lsls	r2, r2, #21
 800d610:	2900      	cmp	r1, #0
 800d612:	d0fa      	beq.n	800d60a <__ieee754_sqrt+0x126>
 800d614:	2480      	movs	r4, #128	; 0x80
 800d616:	0364      	lsls	r4, r4, #13
 800d618:	4221      	tst	r1, r4
 800d61a:	d00a      	beq.n	800d632 <__ieee754_sqrt+0x14e>
 800d61c:	2420      	movs	r4, #32
 800d61e:	0016      	movs	r6, r2
 800d620:	1a24      	subs	r4, r4, r0
 800d622:	40e6      	lsrs	r6, r4
 800d624:	1e45      	subs	r5, r0, #1
 800d626:	4082      	lsls	r2, r0
 800d628:	4331      	orrs	r1, r6
 800d62a:	1b58      	subs	r0, r3, r5
 800d62c:	e789      	b.n	800d542 <__ieee754_sqrt+0x5e>
 800d62e:	2300      	movs	r3, #0
 800d630:	e7ee      	b.n	800d610 <__ieee754_sqrt+0x12c>
 800d632:	0049      	lsls	r1, r1, #1
 800d634:	3001      	adds	r0, #1
 800d636:	e7ef      	b.n	800d618 <__ieee754_sqrt+0x134>
 800d638:	2301      	movs	r3, #1
 800d63a:	3101      	adds	r1, #1
 800d63c:	4399      	bics	r1, r3
 800d63e:	e7d5      	b.n	800d5ec <__ieee754_sqrt+0x108>
 800d640:	7ff00000 	.word	0x7ff00000
 800d644:	fffffc01 	.word	0xfffffc01
 800d648:	3fe00000 	.word	0x3fe00000

0800d64c <__kernel_cos>:
 800d64c:	b5f0      	push	{r4, r5, r6, r7, lr}
 800d64e:	b087      	sub	sp, #28
 800d650:	9204      	str	r2, [sp, #16]
 800d652:	9305      	str	r3, [sp, #20]
 800d654:	004b      	lsls	r3, r1, #1
 800d656:	085b      	lsrs	r3, r3, #1
 800d658:	9300      	str	r3, [sp, #0]
 800d65a:	23f9      	movs	r3, #249	; 0xf9
 800d65c:	9a00      	ldr	r2, [sp, #0]
 800d65e:	0007      	movs	r7, r0
 800d660:	000e      	movs	r6, r1
 800d662:	059b      	lsls	r3, r3, #22
 800d664:	429a      	cmp	r2, r3
 800d666:	da04      	bge.n	800d672 <__kernel_cos+0x26>
 800d668:	f7f5 fa34 	bl	8002ad4 <__aeabi_d2iz>
 800d66c:	2800      	cmp	r0, #0
 800d66e:	d100      	bne.n	800d672 <__kernel_cos+0x26>
 800d670:	e084      	b.n	800d77c <__kernel_cos+0x130>
 800d672:	003a      	movs	r2, r7
 800d674:	0033      	movs	r3, r6
 800d676:	0038      	movs	r0, r7
 800d678:	0031      	movs	r1, r6
 800d67a:	f7f4 fc2d 	bl	8001ed8 <__aeabi_dmul>
 800d67e:	2200      	movs	r2, #0
 800d680:	4b40      	ldr	r3, [pc, #256]	; (800d784 <__kernel_cos+0x138>)
 800d682:	0004      	movs	r4, r0
 800d684:	000d      	movs	r5, r1
 800d686:	f7f4 fc27 	bl	8001ed8 <__aeabi_dmul>
 800d68a:	4a3f      	ldr	r2, [pc, #252]	; (800d788 <__kernel_cos+0x13c>)
 800d68c:	9002      	str	r0, [sp, #8]
 800d68e:	9103      	str	r1, [sp, #12]
 800d690:	4b3e      	ldr	r3, [pc, #248]	; (800d78c <__kernel_cos+0x140>)
 800d692:	0020      	movs	r0, r4
 800d694:	0029      	movs	r1, r5
 800d696:	f7f4 fc1f 	bl	8001ed8 <__aeabi_dmul>
 800d69a:	4a3d      	ldr	r2, [pc, #244]	; (800d790 <__kernel_cos+0x144>)
 800d69c:	4b3d      	ldr	r3, [pc, #244]	; (800d794 <__kernel_cos+0x148>)
 800d69e:	f7f3 fdc9 	bl	8001234 <__aeabi_dadd>
 800d6a2:	0022      	movs	r2, r4
 800d6a4:	002b      	movs	r3, r5
 800d6a6:	f7f4 fc17 	bl	8001ed8 <__aeabi_dmul>
 800d6aa:	4a3b      	ldr	r2, [pc, #236]	; (800d798 <__kernel_cos+0x14c>)
 800d6ac:	4b3b      	ldr	r3, [pc, #236]	; (800d79c <__kernel_cos+0x150>)
 800d6ae:	f7f4 fe7f 	bl	80023b0 <__aeabi_dsub>
 800d6b2:	0022      	movs	r2, r4
 800d6b4:	002b      	movs	r3, r5
 800d6b6:	f7f4 fc0f 	bl	8001ed8 <__aeabi_dmul>
 800d6ba:	4a39      	ldr	r2, [pc, #228]	; (800d7a0 <__kernel_cos+0x154>)
 800d6bc:	4b39      	ldr	r3, [pc, #228]	; (800d7a4 <__kernel_cos+0x158>)
 800d6be:	f7f3 fdb9 	bl	8001234 <__aeabi_dadd>
 800d6c2:	0022      	movs	r2, r4
 800d6c4:	002b      	movs	r3, r5
 800d6c6:	f7f4 fc07 	bl	8001ed8 <__aeabi_dmul>
 800d6ca:	4a37      	ldr	r2, [pc, #220]	; (800d7a8 <__kernel_cos+0x15c>)
 800d6cc:	4b37      	ldr	r3, [pc, #220]	; (800d7ac <__kernel_cos+0x160>)
 800d6ce:	f7f4 fe6f 	bl	80023b0 <__aeabi_dsub>
 800d6d2:	0022      	movs	r2, r4
 800d6d4:	002b      	movs	r3, r5
 800d6d6:	f7f4 fbff 	bl	8001ed8 <__aeabi_dmul>
 800d6da:	4a35      	ldr	r2, [pc, #212]	; (800d7b0 <__kernel_cos+0x164>)
 800d6dc:	4b35      	ldr	r3, [pc, #212]	; (800d7b4 <__kernel_cos+0x168>)
 800d6de:	f7f3 fda9 	bl	8001234 <__aeabi_dadd>
 800d6e2:	0022      	movs	r2, r4
 800d6e4:	002b      	movs	r3, r5
 800d6e6:	f7f4 fbf7 	bl	8001ed8 <__aeabi_dmul>
 800d6ea:	0022      	movs	r2, r4
 800d6ec:	002b      	movs	r3, r5
 800d6ee:	f7f4 fbf3 	bl	8001ed8 <__aeabi_dmul>
 800d6f2:	9a04      	ldr	r2, [sp, #16]
 800d6f4:	9b05      	ldr	r3, [sp, #20]
 800d6f6:	0004      	movs	r4, r0
 800d6f8:	000d      	movs	r5, r1
 800d6fa:	0038      	movs	r0, r7
 800d6fc:	0031      	movs	r1, r6
 800d6fe:	f7f4 fbeb 	bl	8001ed8 <__aeabi_dmul>
 800d702:	0002      	movs	r2, r0
 800d704:	000b      	movs	r3, r1
 800d706:	0020      	movs	r0, r4
 800d708:	0029      	movs	r1, r5
 800d70a:	f7f4 fe51 	bl	80023b0 <__aeabi_dsub>
 800d70e:	4b2a      	ldr	r3, [pc, #168]	; (800d7b8 <__kernel_cos+0x16c>)
 800d710:	9a00      	ldr	r2, [sp, #0]
 800d712:	0004      	movs	r4, r0
 800d714:	000d      	movs	r5, r1
 800d716:	429a      	cmp	r2, r3
 800d718:	dc0d      	bgt.n	800d736 <__kernel_cos+0xea>
 800d71a:	0002      	movs	r2, r0
 800d71c:	000b      	movs	r3, r1
 800d71e:	9802      	ldr	r0, [sp, #8]
 800d720:	9903      	ldr	r1, [sp, #12]
 800d722:	f7f4 fe45 	bl	80023b0 <__aeabi_dsub>
 800d726:	0002      	movs	r2, r0
 800d728:	2000      	movs	r0, #0
 800d72a:	000b      	movs	r3, r1
 800d72c:	4923      	ldr	r1, [pc, #140]	; (800d7bc <__kernel_cos+0x170>)
 800d72e:	f7f4 fe3f 	bl	80023b0 <__aeabi_dsub>
 800d732:	b007      	add	sp, #28
 800d734:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800d736:	4b22      	ldr	r3, [pc, #136]	; (800d7c0 <__kernel_cos+0x174>)
 800d738:	9a00      	ldr	r2, [sp, #0]
 800d73a:	2600      	movs	r6, #0
 800d73c:	429a      	cmp	r2, r3
 800d73e:	dc1b      	bgt.n	800d778 <__kernel_cos+0x12c>
 800d740:	0013      	movs	r3, r2
 800d742:	4a20      	ldr	r2, [pc, #128]	; (800d7c4 <__kernel_cos+0x178>)
 800d744:	4694      	mov	ip, r2
 800d746:	4463      	add	r3, ip
 800d748:	001f      	movs	r7, r3
 800d74a:	0032      	movs	r2, r6
 800d74c:	003b      	movs	r3, r7
 800d74e:	2000      	movs	r0, #0
 800d750:	491a      	ldr	r1, [pc, #104]	; (800d7bc <__kernel_cos+0x170>)
 800d752:	f7f4 fe2d 	bl	80023b0 <__aeabi_dsub>
 800d756:	0032      	movs	r2, r6
 800d758:	003b      	movs	r3, r7
 800d75a:	9000      	str	r0, [sp, #0]
 800d75c:	9101      	str	r1, [sp, #4]
 800d75e:	9802      	ldr	r0, [sp, #8]
 800d760:	9903      	ldr	r1, [sp, #12]
 800d762:	f7f4 fe25 	bl	80023b0 <__aeabi_dsub>
 800d766:	0022      	movs	r2, r4
 800d768:	002b      	movs	r3, r5
 800d76a:	f7f4 fe21 	bl	80023b0 <__aeabi_dsub>
 800d76e:	0002      	movs	r2, r0
 800d770:	000b      	movs	r3, r1
 800d772:	9800      	ldr	r0, [sp, #0]
 800d774:	9901      	ldr	r1, [sp, #4]
 800d776:	e7da      	b.n	800d72e <__kernel_cos+0xe2>
 800d778:	4f13      	ldr	r7, [pc, #76]	; (800d7c8 <__kernel_cos+0x17c>)
 800d77a:	e7e6      	b.n	800d74a <__kernel_cos+0xfe>
 800d77c:	2000      	movs	r0, #0
 800d77e:	490f      	ldr	r1, [pc, #60]	; (800d7bc <__kernel_cos+0x170>)
 800d780:	e7d7      	b.n	800d732 <__kernel_cos+0xe6>
 800d782:	46c0      	nop			; (mov r8, r8)
 800d784:	3fe00000 	.word	0x3fe00000
 800d788:	be8838d4 	.word	0xbe8838d4
 800d78c:	bda8fae9 	.word	0xbda8fae9
 800d790:	bdb4b1c4 	.word	0xbdb4b1c4
 800d794:	3e21ee9e 	.word	0x3e21ee9e
 800d798:	809c52ad 	.word	0x809c52ad
 800d79c:	3e927e4f 	.word	0x3e927e4f
 800d7a0:	19cb1590 	.word	0x19cb1590
 800d7a4:	3efa01a0 	.word	0x3efa01a0
 800d7a8:	16c15177 	.word	0x16c15177
 800d7ac:	3f56c16c 	.word	0x3f56c16c
 800d7b0:	5555554c 	.word	0x5555554c
 800d7b4:	3fa55555 	.word	0x3fa55555
 800d7b8:	3fd33332 	.word	0x3fd33332
 800d7bc:	3ff00000 	.word	0x3ff00000
 800d7c0:	3fe90000 	.word	0x3fe90000
 800d7c4:	ffe00000 	.word	0xffe00000
 800d7c8:	3fd20000 	.word	0x3fd20000

0800d7cc <__kernel_rem_pio2>:
 800d7cc:	b5f0      	push	{r4, r5, r6, r7, lr}
 800d7ce:	4cd0      	ldr	r4, [pc, #832]	; (800db10 <__kernel_rem_pio2+0x344>)
 800d7d0:	44a5      	add	sp, r4
 800d7d2:	930d      	str	r3, [sp, #52]	; 0x34
 800d7d4:	9ba4      	ldr	r3, [sp, #656]	; 0x290
 800d7d6:	0014      	movs	r4, r2
 800d7d8:	009a      	lsls	r2, r3, #2
 800d7da:	4bce      	ldr	r3, [pc, #824]	; (800db14 <__kernel_rem_pio2+0x348>)
 800d7dc:	900e      	str	r0, [sp, #56]	; 0x38
 800d7de:	58d3      	ldr	r3, [r2, r3]
 800d7e0:	9107      	str	r1, [sp, #28]
 800d7e2:	9308      	str	r3, [sp, #32]
 800d7e4:	9b0d      	ldr	r3, [sp, #52]	; 0x34
 800d7e6:	3b01      	subs	r3, #1
 800d7e8:	930c      	str	r3, [sp, #48]	; 0x30
 800d7ea:	2300      	movs	r3, #0
 800d7ec:	9300      	str	r3, [sp, #0]
 800d7ee:	0023      	movs	r3, r4
 800d7f0:	3314      	adds	r3, #20
 800d7f2:	db04      	blt.n	800d7fe <__kernel_rem_pio2+0x32>
 800d7f4:	2118      	movs	r1, #24
 800d7f6:	1ee0      	subs	r0, r4, #3
 800d7f8:	f7f2 fd0e 	bl	8000218 <__divsi3>
 800d7fc:	9000      	str	r0, [sp, #0]
 800d7fe:	2218      	movs	r2, #24
 800d800:	9b00      	ldr	r3, [sp, #0]
 800d802:	4252      	negs	r2, r2
 800d804:	3301      	adds	r3, #1
 800d806:	435a      	muls	r2, r3
 800d808:	1913      	adds	r3, r2, r4
 800d80a:	9302      	str	r3, [sp, #8]
 800d80c:	9a0c      	ldr	r2, [sp, #48]	; 0x30
 800d80e:	9b00      	ldr	r3, [sp, #0]
 800d810:	ae26      	add	r6, sp, #152	; 0x98
 800d812:	1a9d      	subs	r5, r3, r2
 800d814:	002c      	movs	r4, r5
 800d816:	9b08      	ldr	r3, [sp, #32]
 800d818:	189f      	adds	r7, r3, r2
 800d81a:	1b63      	subs	r3, r4, r5
 800d81c:	429f      	cmp	r7, r3
 800d81e:	da17      	bge.n	800d850 <__kernel_rem_pio2+0x84>
 800d820:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 800d822:	9a0d      	ldr	r2, [sp, #52]	; 0x34
 800d824:	9304      	str	r3, [sp, #16]
 800d826:	ab76      	add	r3, sp, #472	; 0x1d8
 800d828:	930a      	str	r3, [sp, #40]	; 0x28
 800d82a:	2301      	movs	r3, #1
 800d82c:	1a9b      	subs	r3, r3, r2
 800d82e:	930b      	str	r3, [sp, #44]	; 0x2c
 800d830:	ab28      	add	r3, sp, #160	; 0xa0
 800d832:	930f      	str	r3, [sp, #60]	; 0x3c
 800d834:	9a04      	ldr	r2, [sp, #16]
 800d836:	9b0b      	ldr	r3, [sp, #44]	; 0x2c
 800d838:	189b      	adds	r3, r3, r2
 800d83a:	9a08      	ldr	r2, [sp, #32]
 800d83c:	429a      	cmp	r2, r3
 800d83e:	db31      	blt.n	800d8a4 <__kernel_rem_pio2+0xd8>
 800d840:	9b04      	ldr	r3, [sp, #16]
 800d842:	2400      	movs	r4, #0
 800d844:	00de      	lsls	r6, r3, #3
 800d846:	9b0f      	ldr	r3, [sp, #60]	; 0x3c
 800d848:	2500      	movs	r5, #0
 800d84a:	2700      	movs	r7, #0
 800d84c:	199e      	adds	r6, r3, r6
 800d84e:	e01e      	b.n	800d88e <__kernel_rem_pio2+0xc2>
 800d850:	2c00      	cmp	r4, #0
 800d852:	db07      	blt.n	800d864 <__kernel_rem_pio2+0x98>
 800d854:	9aa5      	ldr	r2, [sp, #660]	; 0x294
 800d856:	00a3      	lsls	r3, r4, #2
 800d858:	58d0      	ldr	r0, [r2, r3]
 800d85a:	f7f5 f971 	bl	8002b40 <__aeabi_i2d>
 800d85e:	c603      	stmia	r6!, {r0, r1}
 800d860:	3401      	adds	r4, #1
 800d862:	e7da      	b.n	800d81a <__kernel_rem_pio2+0x4e>
 800d864:	2000      	movs	r0, #0
 800d866:	2100      	movs	r1, #0
 800d868:	e7f9      	b.n	800d85e <__kernel_rem_pio2+0x92>
 800d86a:	9b0e      	ldr	r3, [sp, #56]	; 0x38
 800d86c:	00f9      	lsls	r1, r7, #3
 800d86e:	1859      	adds	r1, r3, r1
 800d870:	6808      	ldr	r0, [r1, #0]
 800d872:	6849      	ldr	r1, [r1, #4]
 800d874:	6832      	ldr	r2, [r6, #0]
 800d876:	6873      	ldr	r3, [r6, #4]
 800d878:	f7f4 fb2e 	bl	8001ed8 <__aeabi_dmul>
 800d87c:	0002      	movs	r2, r0
 800d87e:	000b      	movs	r3, r1
 800d880:	0020      	movs	r0, r4
 800d882:	0029      	movs	r1, r5
 800d884:	f7f3 fcd6 	bl	8001234 <__aeabi_dadd>
 800d888:	0004      	movs	r4, r0
 800d88a:	000d      	movs	r5, r1
 800d88c:	3701      	adds	r7, #1
 800d88e:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 800d890:	3e08      	subs	r6, #8
 800d892:	429f      	cmp	r7, r3
 800d894:	dde9      	ble.n	800d86a <__kernel_rem_pio2+0x9e>
 800d896:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 800d898:	c330      	stmia	r3!, {r4, r5}
 800d89a:	930a      	str	r3, [sp, #40]	; 0x28
 800d89c:	9b04      	ldr	r3, [sp, #16]
 800d89e:	3301      	adds	r3, #1
 800d8a0:	9304      	str	r3, [sp, #16]
 800d8a2:	e7c7      	b.n	800d834 <__kernel_rem_pio2+0x68>
 800d8a4:	9b08      	ldr	r3, [sp, #32]
 800d8a6:	aa12      	add	r2, sp, #72	; 0x48
 800d8a8:	009b      	lsls	r3, r3, #2
 800d8aa:	189b      	adds	r3, r3, r2
 800d8ac:	9310      	str	r3, [sp, #64]	; 0x40
 800d8ae:	9b00      	ldr	r3, [sp, #0]
 800d8b0:	0098      	lsls	r0, r3, #2
 800d8b2:	9ba5      	ldr	r3, [sp, #660]	; 0x294
 800d8b4:	181b      	adds	r3, r3, r0
 800d8b6:	930f      	str	r3, [sp, #60]	; 0x3c
 800d8b8:	9b08      	ldr	r3, [sp, #32]
 800d8ba:	9304      	str	r3, [sp, #16]
 800d8bc:	9b04      	ldr	r3, [sp, #16]
 800d8be:	aa76      	add	r2, sp, #472	; 0x1d8
 800d8c0:	00db      	lsls	r3, r3, #3
 800d8c2:	18d3      	adds	r3, r2, r3
 800d8c4:	681c      	ldr	r4, [r3, #0]
 800d8c6:	685d      	ldr	r5, [r3, #4]
 800d8c8:	ab12      	add	r3, sp, #72	; 0x48
 800d8ca:	9300      	str	r3, [sp, #0]
 800d8cc:	930b      	str	r3, [sp, #44]	; 0x2c
 800d8ce:	9b04      	ldr	r3, [sp, #16]
 800d8d0:	9211      	str	r2, [sp, #68]	; 0x44
 800d8d2:	930a      	str	r3, [sp, #40]	; 0x28
 800d8d4:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 800d8d6:	2b00      	cmp	r3, #0
 800d8d8:	dc74      	bgt.n	800d9c4 <__kernel_rem_pio2+0x1f8>
 800d8da:	0020      	movs	r0, r4
 800d8dc:	0029      	movs	r1, r5
 800d8de:	9a02      	ldr	r2, [sp, #8]
 800d8e0:	f000 fcba 	bl	800e258 <scalbn>
 800d8e4:	23ff      	movs	r3, #255	; 0xff
 800d8e6:	2200      	movs	r2, #0
 800d8e8:	059b      	lsls	r3, r3, #22
 800d8ea:	0004      	movs	r4, r0
 800d8ec:	000d      	movs	r5, r1
 800d8ee:	f7f4 faf3 	bl	8001ed8 <__aeabi_dmul>
 800d8f2:	f000 fb99 	bl	800e028 <floor>
 800d8f6:	2200      	movs	r2, #0
 800d8f8:	4b87      	ldr	r3, [pc, #540]	; (800db18 <__kernel_rem_pio2+0x34c>)
 800d8fa:	f7f4 faed 	bl	8001ed8 <__aeabi_dmul>
 800d8fe:	0002      	movs	r2, r0
 800d900:	000b      	movs	r3, r1
 800d902:	0020      	movs	r0, r4
 800d904:	0029      	movs	r1, r5
 800d906:	f7f4 fd53 	bl	80023b0 <__aeabi_dsub>
 800d90a:	000d      	movs	r5, r1
 800d90c:	0004      	movs	r4, r0
 800d90e:	f7f5 f8e1 	bl	8002ad4 <__aeabi_d2iz>
 800d912:	900b      	str	r0, [sp, #44]	; 0x2c
 800d914:	f7f5 f914 	bl	8002b40 <__aeabi_i2d>
 800d918:	000b      	movs	r3, r1
 800d91a:	0002      	movs	r2, r0
 800d91c:	0029      	movs	r1, r5
 800d91e:	0020      	movs	r0, r4
 800d920:	f7f4 fd46 	bl	80023b0 <__aeabi_dsub>
 800d924:	9b02      	ldr	r3, [sp, #8]
 800d926:	0006      	movs	r6, r0
 800d928:	000f      	movs	r7, r1
 800d92a:	2b00      	cmp	r3, #0
 800d92c:	dd74      	ble.n	800da18 <__kernel_rem_pio2+0x24c>
 800d92e:	2118      	movs	r1, #24
 800d930:	9b04      	ldr	r3, [sp, #16]
 800d932:	aa12      	add	r2, sp, #72	; 0x48
 800d934:	3b01      	subs	r3, #1
 800d936:	009b      	lsls	r3, r3, #2
 800d938:	589a      	ldr	r2, [r3, r2]
 800d93a:	9802      	ldr	r0, [sp, #8]
 800d93c:	9c0b      	ldr	r4, [sp, #44]	; 0x2c
 800d93e:	1a09      	subs	r1, r1, r0
 800d940:	0010      	movs	r0, r2
 800d942:	4108      	asrs	r0, r1
 800d944:	1824      	adds	r4, r4, r0
 800d946:	4088      	lsls	r0, r1
 800d948:	a912      	add	r1, sp, #72	; 0x48
 800d94a:	1a12      	subs	r2, r2, r0
 800d94c:	505a      	str	r2, [r3, r1]
 800d94e:	2317      	movs	r3, #23
 800d950:	9902      	ldr	r1, [sp, #8]
 800d952:	940b      	str	r4, [sp, #44]	; 0x2c
 800d954:	1a5b      	subs	r3, r3, r1
 800d956:	411a      	asrs	r2, r3
 800d958:	920a      	str	r2, [sp, #40]	; 0x28
 800d95a:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 800d95c:	2b00      	cmp	r3, #0
 800d95e:	dd6d      	ble.n	800da3c <__kernel_rem_pio2+0x270>
 800d960:	2200      	movs	r2, #0
 800d962:	9b0b      	ldr	r3, [sp, #44]	; 0x2c
 800d964:	2080      	movs	r0, #128	; 0x80
 800d966:	3301      	adds	r3, #1
 800d968:	930b      	str	r3, [sp, #44]	; 0x2c
 800d96a:	4b6c      	ldr	r3, [pc, #432]	; (800db1c <__kernel_rem_pio2+0x350>)
 800d96c:	0014      	movs	r4, r2
 800d96e:	469c      	mov	ip, r3
 800d970:	2501      	movs	r5, #1
 800d972:	0440      	lsls	r0, r0, #17
 800d974:	9b04      	ldr	r3, [sp, #16]
 800d976:	4293      	cmp	r3, r2
 800d978:	dd00      	ble.n	800d97c <__kernel_rem_pio2+0x1b0>
 800d97a:	e098      	b.n	800daae <__kernel_rem_pio2+0x2e2>
 800d97c:	9b02      	ldr	r3, [sp, #8]
 800d97e:	2b00      	cmp	r3, #0
 800d980:	dd05      	ble.n	800d98e <__kernel_rem_pio2+0x1c2>
 800d982:	2b01      	cmp	r3, #1
 800d984:	d100      	bne.n	800d988 <__kernel_rem_pio2+0x1bc>
 800d986:	e0a8      	b.n	800dada <__kernel_rem_pio2+0x30e>
 800d988:	2b02      	cmp	r3, #2
 800d98a:	d100      	bne.n	800d98e <__kernel_rem_pio2+0x1c2>
 800d98c:	e0b0      	b.n	800daf0 <__kernel_rem_pio2+0x324>
 800d98e:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 800d990:	2b02      	cmp	r3, #2
 800d992:	d153      	bne.n	800da3c <__kernel_rem_pio2+0x270>
 800d994:	0032      	movs	r2, r6
 800d996:	003b      	movs	r3, r7
 800d998:	2000      	movs	r0, #0
 800d99a:	4961      	ldr	r1, [pc, #388]	; (800db20 <__kernel_rem_pio2+0x354>)
 800d99c:	f7f4 fd08 	bl	80023b0 <__aeabi_dsub>
 800d9a0:	0006      	movs	r6, r0
 800d9a2:	000f      	movs	r7, r1
 800d9a4:	2c00      	cmp	r4, #0
 800d9a6:	d049      	beq.n	800da3c <__kernel_rem_pio2+0x270>
 800d9a8:	9a02      	ldr	r2, [sp, #8]
 800d9aa:	2000      	movs	r0, #0
 800d9ac:	495c      	ldr	r1, [pc, #368]	; (800db20 <__kernel_rem_pio2+0x354>)
 800d9ae:	f000 fc53 	bl	800e258 <scalbn>
 800d9b2:	0002      	movs	r2, r0
 800d9b4:	000b      	movs	r3, r1
 800d9b6:	0030      	movs	r0, r6
 800d9b8:	0039      	movs	r1, r7
 800d9ba:	f7f4 fcf9 	bl	80023b0 <__aeabi_dsub>
 800d9be:	0006      	movs	r6, r0
 800d9c0:	000f      	movs	r7, r1
 800d9c2:	e03b      	b.n	800da3c <__kernel_rem_pio2+0x270>
 800d9c4:	2200      	movs	r2, #0
 800d9c6:	4b57      	ldr	r3, [pc, #348]	; (800db24 <__kernel_rem_pio2+0x358>)
 800d9c8:	0020      	movs	r0, r4
 800d9ca:	0029      	movs	r1, r5
 800d9cc:	f7f4 fa84 	bl	8001ed8 <__aeabi_dmul>
 800d9d0:	f7f5 f880 	bl	8002ad4 <__aeabi_d2iz>
 800d9d4:	f7f5 f8b4 	bl	8002b40 <__aeabi_i2d>
 800d9d8:	2200      	movs	r2, #0
 800d9da:	4b53      	ldr	r3, [pc, #332]	; (800db28 <__kernel_rem_pio2+0x35c>)
 800d9dc:	0006      	movs	r6, r0
 800d9de:	000f      	movs	r7, r1
 800d9e0:	f7f4 fa7a 	bl	8001ed8 <__aeabi_dmul>
 800d9e4:	0002      	movs	r2, r0
 800d9e6:	000b      	movs	r3, r1
 800d9e8:	0020      	movs	r0, r4
 800d9ea:	0029      	movs	r1, r5
 800d9ec:	f7f4 fce0 	bl	80023b0 <__aeabi_dsub>
 800d9f0:	f7f5 f870 	bl	8002ad4 <__aeabi_d2iz>
 800d9f4:	9b0b      	ldr	r3, [sp, #44]	; 0x2c
 800d9f6:	9a11      	ldr	r2, [sp, #68]	; 0x44
 800d9f8:	c301      	stmia	r3!, {r0}
 800d9fa:	930b      	str	r3, [sp, #44]	; 0x2c
 800d9fc:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 800d9fe:	0030      	movs	r0, r6
 800da00:	3b01      	subs	r3, #1
 800da02:	930a      	str	r3, [sp, #40]	; 0x28
 800da04:	00db      	lsls	r3, r3, #3
 800da06:	18d3      	adds	r3, r2, r3
 800da08:	0039      	movs	r1, r7
 800da0a:	681a      	ldr	r2, [r3, #0]
 800da0c:	685b      	ldr	r3, [r3, #4]
 800da0e:	f7f3 fc11 	bl	8001234 <__aeabi_dadd>
 800da12:	0004      	movs	r4, r0
 800da14:	000d      	movs	r5, r1
 800da16:	e75d      	b.n	800d8d4 <__kernel_rem_pio2+0x108>
 800da18:	9b02      	ldr	r3, [sp, #8]
 800da1a:	2b00      	cmp	r3, #0
 800da1c:	d107      	bne.n	800da2e <__kernel_rem_pio2+0x262>
 800da1e:	9b04      	ldr	r3, [sp, #16]
 800da20:	aa12      	add	r2, sp, #72	; 0x48
 800da22:	3b01      	subs	r3, #1
 800da24:	009b      	lsls	r3, r3, #2
 800da26:	5898      	ldr	r0, [r3, r2]
 800da28:	15c3      	asrs	r3, r0, #23
 800da2a:	930a      	str	r3, [sp, #40]	; 0x28
 800da2c:	e795      	b.n	800d95a <__kernel_rem_pio2+0x18e>
 800da2e:	2200      	movs	r2, #0
 800da30:	4b3e      	ldr	r3, [pc, #248]	; (800db2c <__kernel_rem_pio2+0x360>)
 800da32:	f7f5 f9b9 	bl	8002da8 <__aeabi_dcmpge>
 800da36:	2800      	cmp	r0, #0
 800da38:	d136      	bne.n	800daa8 <__kernel_rem_pio2+0x2dc>
 800da3a:	900a      	str	r0, [sp, #40]	; 0x28
 800da3c:	2200      	movs	r2, #0
 800da3e:	2300      	movs	r3, #0
 800da40:	0030      	movs	r0, r6
 800da42:	0039      	movs	r1, r7
 800da44:	f7f5 f98c 	bl	8002d60 <__aeabi_dcmpeq>
 800da48:	2800      	cmp	r0, #0
 800da4a:	d100      	bne.n	800da4e <__kernel_rem_pio2+0x282>
 800da4c:	e0b9      	b.n	800dbc2 <__kernel_rem_pio2+0x3f6>
 800da4e:	2200      	movs	r2, #0
 800da50:	9b04      	ldr	r3, [sp, #16]
 800da52:	3b01      	subs	r3, #1
 800da54:	9300      	str	r3, [sp, #0]
 800da56:	9908      	ldr	r1, [sp, #32]
 800da58:	428b      	cmp	r3, r1
 800da5a:	da52      	bge.n	800db02 <__kernel_rem_pio2+0x336>
 800da5c:	2a00      	cmp	r2, #0
 800da5e:	d100      	bne.n	800da62 <__kernel_rem_pio2+0x296>
 800da60:	e095      	b.n	800db8e <__kernel_rem_pio2+0x3c2>
 800da62:	9b02      	ldr	r3, [sp, #8]
 800da64:	aa12      	add	r2, sp, #72	; 0x48
 800da66:	3b18      	subs	r3, #24
 800da68:	9302      	str	r3, [sp, #8]
 800da6a:	9b00      	ldr	r3, [sp, #0]
 800da6c:	009b      	lsls	r3, r3, #2
 800da6e:	589b      	ldr	r3, [r3, r2]
 800da70:	2b00      	cmp	r3, #0
 800da72:	d100      	bne.n	800da76 <__kernel_rem_pio2+0x2aa>
 800da74:	e0a1      	b.n	800dbba <__kernel_rem_pio2+0x3ee>
 800da76:	2000      	movs	r0, #0
 800da78:	9a02      	ldr	r2, [sp, #8]
 800da7a:	4929      	ldr	r1, [pc, #164]	; (800db20 <__kernel_rem_pio2+0x354>)
 800da7c:	f000 fbec 	bl	800e258 <scalbn>
 800da80:	0006      	movs	r6, r0
 800da82:	000f      	movs	r7, r1
 800da84:	9c00      	ldr	r4, [sp, #0]
 800da86:	2c00      	cmp	r4, #0
 800da88:	db00      	blt.n	800da8c <__kernel_rem_pio2+0x2c0>
 800da8a:	e0d9      	b.n	800dc40 <__kernel_rem_pio2+0x474>
 800da8c:	2600      	movs	r6, #0
 800da8e:	9d00      	ldr	r5, [sp, #0]
 800da90:	2d00      	cmp	r5, #0
 800da92:	da00      	bge.n	800da96 <__kernel_rem_pio2+0x2ca>
 800da94:	e10c      	b.n	800dcb0 <__kernel_rem_pio2+0x4e4>
 800da96:	ab76      	add	r3, sp, #472	; 0x1d8
 800da98:	00ef      	lsls	r7, r5, #3
 800da9a:	2400      	movs	r4, #0
 800da9c:	18ff      	adds	r7, r7, r3
 800da9e:	2300      	movs	r3, #0
 800daa0:	9302      	str	r3, [sp, #8]
 800daa2:	9403      	str	r4, [sp, #12]
 800daa4:	2400      	movs	r4, #0
 800daa6:	e0f4      	b.n	800dc92 <__kernel_rem_pio2+0x4c6>
 800daa8:	2302      	movs	r3, #2
 800daaa:	930a      	str	r3, [sp, #40]	; 0x28
 800daac:	e758      	b.n	800d960 <__kernel_rem_pio2+0x194>
 800daae:	9b00      	ldr	r3, [sp, #0]
 800dab0:	681b      	ldr	r3, [r3, #0]
 800dab2:	2c00      	cmp	r4, #0
 800dab4:	d10b      	bne.n	800dace <__kernel_rem_pio2+0x302>
 800dab6:	2b00      	cmp	r3, #0
 800dab8:	d003      	beq.n	800dac2 <__kernel_rem_pio2+0x2f6>
 800daba:	9c00      	ldr	r4, [sp, #0]
 800dabc:	1ac3      	subs	r3, r0, r3
 800dabe:	6023      	str	r3, [r4, #0]
 800dac0:	002b      	movs	r3, r5
 800dac2:	9c00      	ldr	r4, [sp, #0]
 800dac4:	3201      	adds	r2, #1
 800dac6:	3404      	adds	r4, #4
 800dac8:	9400      	str	r4, [sp, #0]
 800daca:	001c      	movs	r4, r3
 800dacc:	e752      	b.n	800d974 <__kernel_rem_pio2+0x1a8>
 800dace:	4661      	mov	r1, ip
 800dad0:	1acb      	subs	r3, r1, r3
 800dad2:	9900      	ldr	r1, [sp, #0]
 800dad4:	600b      	str	r3, [r1, #0]
 800dad6:	0023      	movs	r3, r4
 800dad8:	e7f3      	b.n	800dac2 <__kernel_rem_pio2+0x2f6>
 800dada:	9b04      	ldr	r3, [sp, #16]
 800dadc:	aa12      	add	r2, sp, #72	; 0x48
 800dade:	3b01      	subs	r3, #1
 800dae0:	009b      	lsls	r3, r3, #2
 800dae2:	589a      	ldr	r2, [r3, r2]
 800dae4:	9200      	str	r2, [sp, #0]
 800dae6:	0252      	lsls	r2, r2, #9
 800dae8:	0a52      	lsrs	r2, r2, #9
 800daea:	a912      	add	r1, sp, #72	; 0x48
 800daec:	505a      	str	r2, [r3, r1]
 800daee:	e74e      	b.n	800d98e <__kernel_rem_pio2+0x1c2>
 800daf0:	9b04      	ldr	r3, [sp, #16]
 800daf2:	aa12      	add	r2, sp, #72	; 0x48
 800daf4:	3b01      	subs	r3, #1
 800daf6:	009b      	lsls	r3, r3, #2
 800daf8:	589a      	ldr	r2, [r3, r2]
 800dafa:	9200      	str	r2, [sp, #0]
 800dafc:	0292      	lsls	r2, r2, #10
 800dafe:	0a92      	lsrs	r2, r2, #10
 800db00:	e7f3      	b.n	800daea <__kernel_rem_pio2+0x31e>
 800db02:	0099      	lsls	r1, r3, #2
 800db04:	a812      	add	r0, sp, #72	; 0x48
 800db06:	5809      	ldr	r1, [r1, r0]
 800db08:	3b01      	subs	r3, #1
 800db0a:	430a      	orrs	r2, r1
 800db0c:	e7a3      	b.n	800da56 <__kernel_rem_pio2+0x28a>
 800db0e:	46c0      	nop			; (mov r8, r8)
 800db10:	fffffd84 	.word	0xfffffd84
 800db14:	0800f578 	.word	0x0800f578
 800db18:	40200000 	.word	0x40200000
 800db1c:	00ffffff 	.word	0x00ffffff
 800db20:	3ff00000 	.word	0x3ff00000
 800db24:	3e700000 	.word	0x3e700000
 800db28:	41700000 	.word	0x41700000
 800db2c:	3fe00000 	.word	0x3fe00000
 800db30:	3301      	adds	r3, #1
 800db32:	9910      	ldr	r1, [sp, #64]	; 0x40
 800db34:	009a      	lsls	r2, r3, #2
 800db36:	4252      	negs	r2, r2
 800db38:	588a      	ldr	r2, [r1, r2]
 800db3a:	2a00      	cmp	r2, #0
 800db3c:	d0f8      	beq.n	800db30 <__kernel_rem_pio2+0x364>
 800db3e:	9a04      	ldr	r2, [sp, #16]
 800db40:	990d      	ldr	r1, [sp, #52]	; 0x34
 800db42:	1c57      	adds	r7, r2, #1
 800db44:	1854      	adds	r4, r2, r1
 800db46:	00e4      	lsls	r4, r4, #3
 800db48:	aa26      	add	r2, sp, #152	; 0x98
 800db4a:	1914      	adds	r4, r2, r4
 800db4c:	9a04      	ldr	r2, [sp, #16]
 800db4e:	18d3      	adds	r3, r2, r3
 800db50:	9304      	str	r3, [sp, #16]
 800db52:	9b04      	ldr	r3, [sp, #16]
 800db54:	42bb      	cmp	r3, r7
 800db56:	da00      	bge.n	800db5a <__kernel_rem_pio2+0x38e>
 800db58:	e6b0      	b.n	800d8bc <__kernel_rem_pio2+0xf0>
 800db5a:	9a0f      	ldr	r2, [sp, #60]	; 0x3c
 800db5c:	00bb      	lsls	r3, r7, #2
 800db5e:	58d0      	ldr	r0, [r2, r3]
 800db60:	f7f4 ffee 	bl	8002b40 <__aeabi_i2d>
 800db64:	2200      	movs	r2, #0
 800db66:	2300      	movs	r3, #0
 800db68:	0026      	movs	r6, r4
 800db6a:	2500      	movs	r5, #0
 800db6c:	6020      	str	r0, [r4, #0]
 800db6e:	6061      	str	r1, [r4, #4]
 800db70:	9200      	str	r2, [sp, #0]
 800db72:	9301      	str	r3, [sp, #4]
 800db74:	9b0c      	ldr	r3, [sp, #48]	; 0x30
 800db76:	429d      	cmp	r5, r3
 800db78:	dd0b      	ble.n	800db92 <__kernel_rem_pio2+0x3c6>
 800db7a:	00fb      	lsls	r3, r7, #3
 800db7c:	aa76      	add	r2, sp, #472	; 0x1d8
 800db7e:	18d3      	adds	r3, r2, r3
 800db80:	3701      	adds	r7, #1
 800db82:	9900      	ldr	r1, [sp, #0]
 800db84:	9a01      	ldr	r2, [sp, #4]
 800db86:	3408      	adds	r4, #8
 800db88:	6019      	str	r1, [r3, #0]
 800db8a:	605a      	str	r2, [r3, #4]
 800db8c:	e7e1      	b.n	800db52 <__kernel_rem_pio2+0x386>
 800db8e:	2301      	movs	r3, #1
 800db90:	e7cf      	b.n	800db32 <__kernel_rem_pio2+0x366>
 800db92:	9b0e      	ldr	r3, [sp, #56]	; 0x38
 800db94:	00e9      	lsls	r1, r5, #3
 800db96:	1859      	adds	r1, r3, r1
 800db98:	6808      	ldr	r0, [r1, #0]
 800db9a:	6849      	ldr	r1, [r1, #4]
 800db9c:	6832      	ldr	r2, [r6, #0]
 800db9e:	6873      	ldr	r3, [r6, #4]
 800dba0:	f7f4 f99a 	bl	8001ed8 <__aeabi_dmul>
 800dba4:	0002      	movs	r2, r0
 800dba6:	000b      	movs	r3, r1
 800dba8:	9800      	ldr	r0, [sp, #0]
 800dbaa:	9901      	ldr	r1, [sp, #4]
 800dbac:	f7f3 fb42 	bl	8001234 <__aeabi_dadd>
 800dbb0:	3501      	adds	r5, #1
 800dbb2:	9000      	str	r0, [sp, #0]
 800dbb4:	9101      	str	r1, [sp, #4]
 800dbb6:	3e08      	subs	r6, #8
 800dbb8:	e7dc      	b.n	800db74 <__kernel_rem_pio2+0x3a8>
 800dbba:	9b00      	ldr	r3, [sp, #0]
 800dbbc:	3b01      	subs	r3, #1
 800dbbe:	9300      	str	r3, [sp, #0]
 800dbc0:	e74f      	b.n	800da62 <__kernel_rem_pio2+0x296>
 800dbc2:	9b02      	ldr	r3, [sp, #8]
 800dbc4:	0030      	movs	r0, r6
 800dbc6:	425a      	negs	r2, r3
 800dbc8:	0039      	movs	r1, r7
 800dbca:	f000 fb45 	bl	800e258 <scalbn>
 800dbce:	2200      	movs	r2, #0
 800dbd0:	4bb6      	ldr	r3, [pc, #728]	; (800deac <__kernel_rem_pio2+0x6e0>)
 800dbd2:	0004      	movs	r4, r0
 800dbd4:	000d      	movs	r5, r1
 800dbd6:	f7f5 f8e7 	bl	8002da8 <__aeabi_dcmpge>
 800dbda:	2800      	cmp	r0, #0
 800dbdc:	d025      	beq.n	800dc2a <__kernel_rem_pio2+0x45e>
 800dbde:	2200      	movs	r2, #0
 800dbe0:	4bb3      	ldr	r3, [pc, #716]	; (800deb0 <__kernel_rem_pio2+0x6e4>)
 800dbe2:	0020      	movs	r0, r4
 800dbe4:	0029      	movs	r1, r5
 800dbe6:	f7f4 f977 	bl	8001ed8 <__aeabi_dmul>
 800dbea:	f7f4 ff73 	bl	8002ad4 <__aeabi_d2iz>
 800dbee:	9b04      	ldr	r3, [sp, #16]
 800dbf0:	0006      	movs	r6, r0
 800dbf2:	009f      	lsls	r7, r3, #2
 800dbf4:	f7f4 ffa4 	bl	8002b40 <__aeabi_i2d>
 800dbf8:	2200      	movs	r2, #0
 800dbfa:	4bac      	ldr	r3, [pc, #688]	; (800deac <__kernel_rem_pio2+0x6e0>)
 800dbfc:	f7f4 f96c 	bl	8001ed8 <__aeabi_dmul>
 800dc00:	0002      	movs	r2, r0
 800dc02:	000b      	movs	r3, r1
 800dc04:	0020      	movs	r0, r4
 800dc06:	0029      	movs	r1, r5
 800dc08:	f7f4 fbd2 	bl	80023b0 <__aeabi_dsub>
 800dc0c:	f7f4 ff62 	bl	8002ad4 <__aeabi_d2iz>
 800dc10:	ab12      	add	r3, sp, #72	; 0x48
 800dc12:	51d8      	str	r0, [r3, r7]
 800dc14:	9b04      	ldr	r3, [sp, #16]
 800dc16:	aa12      	add	r2, sp, #72	; 0x48
 800dc18:	3301      	adds	r3, #1
 800dc1a:	9300      	str	r3, [sp, #0]
 800dc1c:	9b02      	ldr	r3, [sp, #8]
 800dc1e:	3318      	adds	r3, #24
 800dc20:	9302      	str	r3, [sp, #8]
 800dc22:	9b00      	ldr	r3, [sp, #0]
 800dc24:	009b      	lsls	r3, r3, #2
 800dc26:	509e      	str	r6, [r3, r2]
 800dc28:	e725      	b.n	800da76 <__kernel_rem_pio2+0x2aa>
 800dc2a:	9b04      	ldr	r3, [sp, #16]
 800dc2c:	0020      	movs	r0, r4
 800dc2e:	0029      	movs	r1, r5
 800dc30:	009e      	lsls	r6, r3, #2
 800dc32:	f7f4 ff4f 	bl	8002ad4 <__aeabi_d2iz>
 800dc36:	ab12      	add	r3, sp, #72	; 0x48
 800dc38:	5198      	str	r0, [r3, r6]
 800dc3a:	9b04      	ldr	r3, [sp, #16]
 800dc3c:	9300      	str	r3, [sp, #0]
 800dc3e:	e71a      	b.n	800da76 <__kernel_rem_pio2+0x2aa>
 800dc40:	00e5      	lsls	r5, r4, #3
 800dc42:	ab76      	add	r3, sp, #472	; 0x1d8
 800dc44:	aa12      	add	r2, sp, #72	; 0x48
 800dc46:	195d      	adds	r5, r3, r5
 800dc48:	00a3      	lsls	r3, r4, #2
 800dc4a:	5898      	ldr	r0, [r3, r2]
 800dc4c:	f7f4 ff78 	bl	8002b40 <__aeabi_i2d>
 800dc50:	0032      	movs	r2, r6
 800dc52:	003b      	movs	r3, r7
 800dc54:	f7f4 f940 	bl	8001ed8 <__aeabi_dmul>
 800dc58:	2200      	movs	r2, #0
 800dc5a:	6028      	str	r0, [r5, #0]
 800dc5c:	6069      	str	r1, [r5, #4]
 800dc5e:	4b94      	ldr	r3, [pc, #592]	; (800deb0 <__kernel_rem_pio2+0x6e4>)
 800dc60:	0030      	movs	r0, r6
 800dc62:	0039      	movs	r1, r7
 800dc64:	f7f4 f938 	bl	8001ed8 <__aeabi_dmul>
 800dc68:	3c01      	subs	r4, #1
 800dc6a:	0006      	movs	r6, r0
 800dc6c:	000f      	movs	r7, r1
 800dc6e:	e70a      	b.n	800da86 <__kernel_rem_pio2+0x2ba>
 800dc70:	4b90      	ldr	r3, [pc, #576]	; (800deb4 <__kernel_rem_pio2+0x6e8>)
 800dc72:	00e1      	lsls	r1, r4, #3
 800dc74:	1859      	adds	r1, r3, r1
 800dc76:	6808      	ldr	r0, [r1, #0]
 800dc78:	6849      	ldr	r1, [r1, #4]
 800dc7a:	cf0c      	ldmia	r7!, {r2, r3}
 800dc7c:	f7f4 f92c 	bl	8001ed8 <__aeabi_dmul>
 800dc80:	0002      	movs	r2, r0
 800dc82:	000b      	movs	r3, r1
 800dc84:	9802      	ldr	r0, [sp, #8]
 800dc86:	9903      	ldr	r1, [sp, #12]
 800dc88:	f7f3 fad4 	bl	8001234 <__aeabi_dadd>
 800dc8c:	9002      	str	r0, [sp, #8]
 800dc8e:	9103      	str	r1, [sp, #12]
 800dc90:	3401      	adds	r4, #1
 800dc92:	9b08      	ldr	r3, [sp, #32]
 800dc94:	429c      	cmp	r4, r3
 800dc96:	dc01      	bgt.n	800dc9c <__kernel_rem_pio2+0x4d0>
 800dc98:	42a6      	cmp	r6, r4
 800dc9a:	dae9      	bge.n	800dc70 <__kernel_rem_pio2+0x4a4>
 800dc9c:	00f3      	lsls	r3, r6, #3
 800dc9e:	aa4e      	add	r2, sp, #312	; 0x138
 800dca0:	18d3      	adds	r3, r2, r3
 800dca2:	3d01      	subs	r5, #1
 800dca4:	9902      	ldr	r1, [sp, #8]
 800dca6:	9a03      	ldr	r2, [sp, #12]
 800dca8:	3601      	adds	r6, #1
 800dcaa:	6019      	str	r1, [r3, #0]
 800dcac:	605a      	str	r2, [r3, #4]
 800dcae:	e6ef      	b.n	800da90 <__kernel_rem_pio2+0x2c4>
 800dcb0:	9ba4      	ldr	r3, [sp, #656]	; 0x290
 800dcb2:	2b02      	cmp	r3, #2
 800dcb4:	dc0b      	bgt.n	800dcce <__kernel_rem_pio2+0x502>
 800dcb6:	2b00      	cmp	r3, #0
 800dcb8:	dd00      	ble.n	800dcbc <__kernel_rem_pio2+0x4f0>
 800dcba:	e08a      	b.n	800ddd2 <__kernel_rem_pio2+0x606>
 800dcbc:	d055      	beq.n	800dd6a <__kernel_rem_pio2+0x59e>
 800dcbe:	2007      	movs	r0, #7
 800dcc0:	9b0b      	ldr	r3, [sp, #44]	; 0x2c
 800dcc2:	4003      	ands	r3, r0
 800dcc4:	0018      	movs	r0, r3
 800dcc6:	239f      	movs	r3, #159	; 0x9f
 800dcc8:	009b      	lsls	r3, r3, #2
 800dcca:	449d      	add	sp, r3
 800dccc:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800dcce:	9ba4      	ldr	r3, [sp, #656]	; 0x290
 800dcd0:	2b03      	cmp	r3, #3
 800dcd2:	d1f4      	bne.n	800dcbe <__kernel_rem_pio2+0x4f2>
 800dcd4:	9b00      	ldr	r3, [sp, #0]
 800dcd6:	00dc      	lsls	r4, r3, #3
 800dcd8:	ab4e      	add	r3, sp, #312	; 0x138
 800dcda:	191c      	adds	r4, r3, r4
 800dcdc:	0025      	movs	r5, r4
 800dcde:	9b00      	ldr	r3, [sp, #0]
 800dce0:	9302      	str	r3, [sp, #8]
 800dce2:	9b02      	ldr	r3, [sp, #8]
 800dce4:	3d08      	subs	r5, #8
 800dce6:	2b00      	cmp	r3, #0
 800dce8:	dd00      	ble.n	800dcec <__kernel_rem_pio2+0x520>
 800dcea:	e083      	b.n	800ddf4 <__kernel_rem_pio2+0x628>
 800dcec:	9d00      	ldr	r5, [sp, #0]
 800dcee:	3c08      	subs	r4, #8
 800dcf0:	2d01      	cmp	r5, #1
 800dcf2:	dd00      	ble.n	800dcf6 <__kernel_rem_pio2+0x52a>
 800dcf4:	e0a0      	b.n	800de38 <__kernel_rem_pio2+0x66c>
 800dcf6:	2400      	movs	r4, #0
 800dcf8:	0021      	movs	r1, r4
 800dcfa:	9b00      	ldr	r3, [sp, #0]
 800dcfc:	2b01      	cmp	r3, #1
 800dcfe:	dd00      	ble.n	800dd02 <__kernel_rem_pio2+0x536>
 800dd00:	e0b8      	b.n	800de74 <__kernel_rem_pio2+0x6a8>
 800dd02:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 800dd04:	9f4e      	ldr	r7, [sp, #312]	; 0x138
 800dd06:	9e4f      	ldr	r6, [sp, #316]	; 0x13c
 800dd08:	9d50      	ldr	r5, [sp, #320]	; 0x140
 800dd0a:	9851      	ldr	r0, [sp, #324]	; 0x144
 800dd0c:	2b00      	cmp	r3, #0
 800dd0e:	d000      	beq.n	800dd12 <__kernel_rem_pio2+0x546>
 800dd10:	e0be      	b.n	800de90 <__kernel_rem_pio2+0x6c4>
 800dd12:	0033      	movs	r3, r6
 800dd14:	003a      	movs	r2, r7
 800dd16:	9e07      	ldr	r6, [sp, #28]
 800dd18:	6032      	str	r2, [r6, #0]
 800dd1a:	6073      	str	r3, [r6, #4]
 800dd1c:	002a      	movs	r2, r5
 800dd1e:	0003      	movs	r3, r0
 800dd20:	60b2      	str	r2, [r6, #8]
 800dd22:	60f3      	str	r3, [r6, #12]
 800dd24:	0022      	movs	r2, r4
 800dd26:	000b      	movs	r3, r1
 800dd28:	6132      	str	r2, [r6, #16]
 800dd2a:	6173      	str	r3, [r6, #20]
 800dd2c:	e7c7      	b.n	800dcbe <__kernel_rem_pio2+0x4f2>
 800dd2e:	9b00      	ldr	r3, [sp, #0]
 800dd30:	aa4e      	add	r2, sp, #312	; 0x138
 800dd32:	00db      	lsls	r3, r3, #3
 800dd34:	18d3      	adds	r3, r2, r3
 800dd36:	0028      	movs	r0, r5
 800dd38:	681a      	ldr	r2, [r3, #0]
 800dd3a:	685b      	ldr	r3, [r3, #4]
 800dd3c:	0021      	movs	r1, r4
 800dd3e:	f7f3 fa79 	bl	8001234 <__aeabi_dadd>
 800dd42:	0005      	movs	r5, r0
 800dd44:	000c      	movs	r4, r1
 800dd46:	9b00      	ldr	r3, [sp, #0]
 800dd48:	3b01      	subs	r3, #1
 800dd4a:	9300      	str	r3, [sp, #0]
 800dd4c:	9b00      	ldr	r3, [sp, #0]
 800dd4e:	2b00      	cmp	r3, #0
 800dd50:	daed      	bge.n	800dd2e <__kernel_rem_pio2+0x562>
 800dd52:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 800dd54:	2b00      	cmp	r3, #0
 800dd56:	d002      	beq.n	800dd5e <__kernel_rem_pio2+0x592>
 800dd58:	2380      	movs	r3, #128	; 0x80
 800dd5a:	061b      	lsls	r3, r3, #24
 800dd5c:	18e4      	adds	r4, r4, r3
 800dd5e:	002a      	movs	r2, r5
 800dd60:	0023      	movs	r3, r4
 800dd62:	9907      	ldr	r1, [sp, #28]
 800dd64:	600a      	str	r2, [r1, #0]
 800dd66:	604b      	str	r3, [r1, #4]
 800dd68:	e7a9      	b.n	800dcbe <__kernel_rem_pio2+0x4f2>
 800dd6a:	9da4      	ldr	r5, [sp, #656]	; 0x290
 800dd6c:	002c      	movs	r4, r5
 800dd6e:	e7ed      	b.n	800dd4c <__kernel_rem_pio2+0x580>
 800dd70:	00e3      	lsls	r3, r4, #3
 800dd72:	aa4e      	add	r2, sp, #312	; 0x138
 800dd74:	18d3      	adds	r3, r2, r3
 800dd76:	0030      	movs	r0, r6
 800dd78:	681a      	ldr	r2, [r3, #0]
 800dd7a:	685b      	ldr	r3, [r3, #4]
 800dd7c:	0029      	movs	r1, r5
 800dd7e:	f7f3 fa59 	bl	8001234 <__aeabi_dadd>
 800dd82:	0006      	movs	r6, r0
 800dd84:	000d      	movs	r5, r1
 800dd86:	3c01      	subs	r4, #1
 800dd88:	2c00      	cmp	r4, #0
 800dd8a:	daf1      	bge.n	800dd70 <__kernel_rem_pio2+0x5a4>
 800dd8c:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 800dd8e:	0029      	movs	r1, r5
 800dd90:	2b00      	cmp	r3, #0
 800dd92:	d002      	beq.n	800dd9a <__kernel_rem_pio2+0x5ce>
 800dd94:	2380      	movs	r3, #128	; 0x80
 800dd96:	061b      	lsls	r3, r3, #24
 800dd98:	18e9      	adds	r1, r5, r3
 800dd9a:	0032      	movs	r2, r6
 800dd9c:	000b      	movs	r3, r1
 800dd9e:	9907      	ldr	r1, [sp, #28]
 800dda0:	2401      	movs	r4, #1
 800dda2:	600a      	str	r2, [r1, #0]
 800dda4:	604b      	str	r3, [r1, #4]
 800dda6:	984e      	ldr	r0, [sp, #312]	; 0x138
 800dda8:	994f      	ldr	r1, [sp, #316]	; 0x13c
 800ddaa:	002b      	movs	r3, r5
 800ddac:	f7f4 fb00 	bl	80023b0 <__aeabi_dsub>
 800ddb0:	0006      	movs	r6, r0
 800ddb2:	000d      	movs	r5, r1
 800ddb4:	9b00      	ldr	r3, [sp, #0]
 800ddb6:	42a3      	cmp	r3, r4
 800ddb8:	da0f      	bge.n	800ddda <__kernel_rem_pio2+0x60e>
 800ddba:	9b0a      	ldr	r3, [sp, #40]	; 0x28
 800ddbc:	2b00      	cmp	r3, #0
 800ddbe:	d002      	beq.n	800ddc6 <__kernel_rem_pio2+0x5fa>
 800ddc0:	2380      	movs	r3, #128	; 0x80
 800ddc2:	061b      	lsls	r3, r3, #24
 800ddc4:	18ed      	adds	r5, r5, r3
 800ddc6:	0032      	movs	r2, r6
 800ddc8:	002b      	movs	r3, r5
 800ddca:	9907      	ldr	r1, [sp, #28]
 800ddcc:	608a      	str	r2, [r1, #8]
 800ddce:	60cb      	str	r3, [r1, #12]
 800ddd0:	e775      	b.n	800dcbe <__kernel_rem_pio2+0x4f2>
 800ddd2:	2600      	movs	r6, #0
 800ddd4:	9c00      	ldr	r4, [sp, #0]
 800ddd6:	0035      	movs	r5, r6
 800ddd8:	e7d6      	b.n	800dd88 <__kernel_rem_pio2+0x5bc>
 800ddda:	00e3      	lsls	r3, r4, #3
 800dddc:	aa4e      	add	r2, sp, #312	; 0x138
 800ddde:	18d3      	adds	r3, r2, r3
 800dde0:	0030      	movs	r0, r6
 800dde2:	681a      	ldr	r2, [r3, #0]
 800dde4:	685b      	ldr	r3, [r3, #4]
 800dde6:	0029      	movs	r1, r5
 800dde8:	f7f3 fa24 	bl	8001234 <__aeabi_dadd>
 800ddec:	3401      	adds	r4, #1
 800ddee:	0006      	movs	r6, r0
 800ddf0:	000d      	movs	r5, r1
 800ddf2:	e7df      	b.n	800ddb4 <__kernel_rem_pio2+0x5e8>
 800ddf4:	9b02      	ldr	r3, [sp, #8]
 800ddf6:	68ae      	ldr	r6, [r5, #8]
 800ddf8:	68ef      	ldr	r7, [r5, #12]
 800ddfa:	3b01      	subs	r3, #1
 800ddfc:	9302      	str	r3, [sp, #8]
 800ddfe:	682a      	ldr	r2, [r5, #0]
 800de00:	686b      	ldr	r3, [r5, #4]
 800de02:	9204      	str	r2, [sp, #16]
 800de04:	9305      	str	r3, [sp, #20]
 800de06:	9804      	ldr	r0, [sp, #16]
 800de08:	9905      	ldr	r1, [sp, #20]
 800de0a:	0032      	movs	r2, r6
 800de0c:	003b      	movs	r3, r7
 800de0e:	f7f3 fa11 	bl	8001234 <__aeabi_dadd>
 800de12:	0002      	movs	r2, r0
 800de14:	000b      	movs	r3, r1
 800de16:	9008      	str	r0, [sp, #32]
 800de18:	9109      	str	r1, [sp, #36]	; 0x24
 800de1a:	9804      	ldr	r0, [sp, #16]
 800de1c:	9905      	ldr	r1, [sp, #20]
 800de1e:	f7f4 fac7 	bl	80023b0 <__aeabi_dsub>
 800de22:	0032      	movs	r2, r6
 800de24:	003b      	movs	r3, r7
 800de26:	f7f3 fa05 	bl	8001234 <__aeabi_dadd>
 800de2a:	9a08      	ldr	r2, [sp, #32]
 800de2c:	9b09      	ldr	r3, [sp, #36]	; 0x24
 800de2e:	60a8      	str	r0, [r5, #8]
 800de30:	60e9      	str	r1, [r5, #12]
 800de32:	602a      	str	r2, [r5, #0]
 800de34:	606b      	str	r3, [r5, #4]
 800de36:	e754      	b.n	800dce2 <__kernel_rem_pio2+0x516>
 800de38:	6826      	ldr	r6, [r4, #0]
 800de3a:	6867      	ldr	r7, [r4, #4]
 800de3c:	68a2      	ldr	r2, [r4, #8]
 800de3e:	68e3      	ldr	r3, [r4, #12]
 800de40:	0030      	movs	r0, r6
 800de42:	0039      	movs	r1, r7
 800de44:	9202      	str	r2, [sp, #8]
 800de46:	9303      	str	r3, [sp, #12]
 800de48:	f7f3 f9f4 	bl	8001234 <__aeabi_dadd>
 800de4c:	0002      	movs	r2, r0
 800de4e:	000b      	movs	r3, r1
 800de50:	9004      	str	r0, [sp, #16]
 800de52:	9105      	str	r1, [sp, #20]
 800de54:	0030      	movs	r0, r6
 800de56:	0039      	movs	r1, r7
 800de58:	f7f4 faaa 	bl	80023b0 <__aeabi_dsub>
 800de5c:	9a02      	ldr	r2, [sp, #8]
 800de5e:	9b03      	ldr	r3, [sp, #12]
 800de60:	f7f3 f9e8 	bl	8001234 <__aeabi_dadd>
 800de64:	9a04      	ldr	r2, [sp, #16]
 800de66:	9b05      	ldr	r3, [sp, #20]
 800de68:	60a0      	str	r0, [r4, #8]
 800de6a:	60e1      	str	r1, [r4, #12]
 800de6c:	6022      	str	r2, [r4, #0]
 800de6e:	6063      	str	r3, [r4, #4]
 800de70:	3d01      	subs	r5, #1
 800de72:	e73c      	b.n	800dcee <__kernel_rem_pio2+0x522>
 800de74:	9b00      	ldr	r3, [sp, #0]
 800de76:	aa4e      	add	r2, sp, #312	; 0x138
 800de78:	00db      	lsls	r3, r3, #3
 800de7a:	18d3      	adds	r3, r2, r3
 800de7c:	0020      	movs	r0, r4
 800de7e:	681a      	ldr	r2, [r3, #0]
 800de80:	685b      	ldr	r3, [r3, #4]
 800de82:	f7f3 f9d7 	bl	8001234 <__aeabi_dadd>
 800de86:	9b00      	ldr	r3, [sp, #0]
 800de88:	0004      	movs	r4, r0
 800de8a:	3b01      	subs	r3, #1
 800de8c:	9300      	str	r3, [sp, #0]
 800de8e:	e734      	b.n	800dcfa <__kernel_rem_pio2+0x52e>
 800de90:	9b07      	ldr	r3, [sp, #28]
 800de92:	9a07      	ldr	r2, [sp, #28]
 800de94:	601f      	str	r7, [r3, #0]
 800de96:	2380      	movs	r3, #128	; 0x80
 800de98:	061b      	lsls	r3, r3, #24
 800de9a:	18f6      	adds	r6, r6, r3
 800de9c:	18c0      	adds	r0, r0, r3
 800de9e:	18c9      	adds	r1, r1, r3
 800dea0:	6056      	str	r6, [r2, #4]
 800dea2:	6095      	str	r5, [r2, #8]
 800dea4:	60d0      	str	r0, [r2, #12]
 800dea6:	6114      	str	r4, [r2, #16]
 800dea8:	6151      	str	r1, [r2, #20]
 800deaa:	e708      	b.n	800dcbe <__kernel_rem_pio2+0x4f2>
 800deac:	41700000 	.word	0x41700000
 800deb0:	3e700000 	.word	0x3e700000
 800deb4:	0800f538 	.word	0x0800f538

0800deb8 <__kernel_sin>:
 800deb8:	b5f0      	push	{r4, r5, r6, r7, lr}
 800deba:	b089      	sub	sp, #36	; 0x24
 800debc:	9202      	str	r2, [sp, #8]
 800debe:	9303      	str	r3, [sp, #12]
 800dec0:	22f9      	movs	r2, #249	; 0xf9
 800dec2:	004b      	lsls	r3, r1, #1
 800dec4:	0007      	movs	r7, r0
 800dec6:	000e      	movs	r6, r1
 800dec8:	085b      	lsrs	r3, r3, #1
 800deca:	0592      	lsls	r2, r2, #22
 800decc:	4293      	cmp	r3, r2
 800dece:	da03      	bge.n	800ded8 <__kernel_sin+0x20>
 800ded0:	f7f4 fe00 	bl	8002ad4 <__aeabi_d2iz>
 800ded4:	2800      	cmp	r0, #0
 800ded6:	d04c      	beq.n	800df72 <__kernel_sin+0xba>
 800ded8:	003a      	movs	r2, r7
 800deda:	0033      	movs	r3, r6
 800dedc:	0038      	movs	r0, r7
 800dede:	0031      	movs	r1, r6
 800dee0:	f7f3 fffa 	bl	8001ed8 <__aeabi_dmul>
 800dee4:	0004      	movs	r4, r0
 800dee6:	000d      	movs	r5, r1
 800dee8:	0002      	movs	r2, r0
 800deea:	000b      	movs	r3, r1
 800deec:	0038      	movs	r0, r7
 800deee:	0031      	movs	r1, r6
 800def0:	f7f3 fff2 	bl	8001ed8 <__aeabi_dmul>
 800def4:	4a39      	ldr	r2, [pc, #228]	; (800dfdc <__kernel_sin+0x124>)
 800def6:	9000      	str	r0, [sp, #0]
 800def8:	9101      	str	r1, [sp, #4]
 800defa:	4b39      	ldr	r3, [pc, #228]	; (800dfe0 <__kernel_sin+0x128>)
 800defc:	0020      	movs	r0, r4
 800defe:	0029      	movs	r1, r5
 800df00:	f7f3 ffea 	bl	8001ed8 <__aeabi_dmul>
 800df04:	4a37      	ldr	r2, [pc, #220]	; (800dfe4 <__kernel_sin+0x12c>)
 800df06:	4b38      	ldr	r3, [pc, #224]	; (800dfe8 <__kernel_sin+0x130>)
 800df08:	f7f4 fa52 	bl	80023b0 <__aeabi_dsub>
 800df0c:	0022      	movs	r2, r4
 800df0e:	002b      	movs	r3, r5
 800df10:	f7f3 ffe2 	bl	8001ed8 <__aeabi_dmul>
 800df14:	4a35      	ldr	r2, [pc, #212]	; (800dfec <__kernel_sin+0x134>)
 800df16:	4b36      	ldr	r3, [pc, #216]	; (800dff0 <__kernel_sin+0x138>)
 800df18:	f7f3 f98c 	bl	8001234 <__aeabi_dadd>
 800df1c:	0022      	movs	r2, r4
 800df1e:	002b      	movs	r3, r5
 800df20:	f7f3 ffda 	bl	8001ed8 <__aeabi_dmul>
 800df24:	4a33      	ldr	r2, [pc, #204]	; (800dff4 <__kernel_sin+0x13c>)
 800df26:	4b34      	ldr	r3, [pc, #208]	; (800dff8 <__kernel_sin+0x140>)
 800df28:	f7f4 fa42 	bl	80023b0 <__aeabi_dsub>
 800df2c:	0022      	movs	r2, r4
 800df2e:	002b      	movs	r3, r5
 800df30:	f7f3 ffd2 	bl	8001ed8 <__aeabi_dmul>
 800df34:	4b31      	ldr	r3, [pc, #196]	; (800dffc <__kernel_sin+0x144>)
 800df36:	4a32      	ldr	r2, [pc, #200]	; (800e000 <__kernel_sin+0x148>)
 800df38:	f7f3 f97c 	bl	8001234 <__aeabi_dadd>
 800df3c:	9b0e      	ldr	r3, [sp, #56]	; 0x38
 800df3e:	9004      	str	r0, [sp, #16]
 800df40:	9105      	str	r1, [sp, #20]
 800df42:	2b00      	cmp	r3, #0
 800df44:	d119      	bne.n	800df7a <__kernel_sin+0xc2>
 800df46:	0002      	movs	r2, r0
 800df48:	000b      	movs	r3, r1
 800df4a:	0020      	movs	r0, r4
 800df4c:	0029      	movs	r1, r5
 800df4e:	f7f3 ffc3 	bl	8001ed8 <__aeabi_dmul>
 800df52:	4a2c      	ldr	r2, [pc, #176]	; (800e004 <__kernel_sin+0x14c>)
 800df54:	4b2c      	ldr	r3, [pc, #176]	; (800e008 <__kernel_sin+0x150>)
 800df56:	f7f4 fa2b 	bl	80023b0 <__aeabi_dsub>
 800df5a:	9a00      	ldr	r2, [sp, #0]
 800df5c:	9b01      	ldr	r3, [sp, #4]
 800df5e:	f7f3 ffbb 	bl	8001ed8 <__aeabi_dmul>
 800df62:	0002      	movs	r2, r0
 800df64:	000b      	movs	r3, r1
 800df66:	0038      	movs	r0, r7
 800df68:	0031      	movs	r1, r6
 800df6a:	f7f3 f963 	bl	8001234 <__aeabi_dadd>
 800df6e:	0007      	movs	r7, r0
 800df70:	000e      	movs	r6, r1
 800df72:	0038      	movs	r0, r7
 800df74:	0031      	movs	r1, r6
 800df76:	b009      	add	sp, #36	; 0x24
 800df78:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800df7a:	2200      	movs	r2, #0
 800df7c:	9802      	ldr	r0, [sp, #8]
 800df7e:	9903      	ldr	r1, [sp, #12]
 800df80:	4b22      	ldr	r3, [pc, #136]	; (800e00c <__kernel_sin+0x154>)
 800df82:	f7f3 ffa9 	bl	8001ed8 <__aeabi_dmul>
 800df86:	9a04      	ldr	r2, [sp, #16]
 800df88:	9b05      	ldr	r3, [sp, #20]
 800df8a:	9006      	str	r0, [sp, #24]
 800df8c:	9107      	str	r1, [sp, #28]
 800df8e:	9800      	ldr	r0, [sp, #0]
 800df90:	9901      	ldr	r1, [sp, #4]
 800df92:	f7f3 ffa1 	bl	8001ed8 <__aeabi_dmul>
 800df96:	0002      	movs	r2, r0
 800df98:	000b      	movs	r3, r1
 800df9a:	9806      	ldr	r0, [sp, #24]
 800df9c:	9907      	ldr	r1, [sp, #28]
 800df9e:	f7f4 fa07 	bl	80023b0 <__aeabi_dsub>
 800dfa2:	0022      	movs	r2, r4
 800dfa4:	002b      	movs	r3, r5
 800dfa6:	f7f3 ff97 	bl	8001ed8 <__aeabi_dmul>
 800dfaa:	9a02      	ldr	r2, [sp, #8]
 800dfac:	9b03      	ldr	r3, [sp, #12]
 800dfae:	f7f4 f9ff 	bl	80023b0 <__aeabi_dsub>
 800dfb2:	4a14      	ldr	r2, [pc, #80]	; (800e004 <__kernel_sin+0x14c>)
 800dfb4:	0004      	movs	r4, r0
 800dfb6:	000d      	movs	r5, r1
 800dfb8:	9800      	ldr	r0, [sp, #0]
 800dfba:	9901      	ldr	r1, [sp, #4]
 800dfbc:	4b12      	ldr	r3, [pc, #72]	; (800e008 <__kernel_sin+0x150>)
 800dfbe:	f7f3 ff8b 	bl	8001ed8 <__aeabi_dmul>
 800dfc2:	0002      	movs	r2, r0
 800dfc4:	000b      	movs	r3, r1
 800dfc6:	0020      	movs	r0, r4
 800dfc8:	0029      	movs	r1, r5
 800dfca:	f7f3 f933 	bl	8001234 <__aeabi_dadd>
 800dfce:	0002      	movs	r2, r0
 800dfd0:	000b      	movs	r3, r1
 800dfd2:	0038      	movs	r0, r7
 800dfd4:	0031      	movs	r1, r6
 800dfd6:	f7f4 f9eb 	bl	80023b0 <__aeabi_dsub>
 800dfda:	e7c8      	b.n	800df6e <__kernel_sin+0xb6>
 800dfdc:	5acfd57c 	.word	0x5acfd57c
 800dfe0:	3de5d93a 	.word	0x3de5d93a
 800dfe4:	8a2b9ceb 	.word	0x8a2b9ceb
 800dfe8:	3e5ae5e6 	.word	0x3e5ae5e6
 800dfec:	57b1fe7d 	.word	0x57b1fe7d
 800dff0:	3ec71de3 	.word	0x3ec71de3
 800dff4:	19c161d5 	.word	0x19c161d5
 800dff8:	3f2a01a0 	.word	0x3f2a01a0
 800dffc:	3f811111 	.word	0x3f811111
 800e000:	1110f8a6 	.word	0x1110f8a6
 800e004:	55555549 	.word	0x55555549
 800e008:	3fc55555 	.word	0x3fc55555
 800e00c:	3fe00000 	.word	0x3fe00000

0800e010 <fabs>:
 800e010:	004b      	lsls	r3, r1, #1
 800e012:	0859      	lsrs	r1, r3, #1
 800e014:	4770      	bx	lr
	...

0800e018 <finite>:
 800e018:	4b02      	ldr	r3, [pc, #8]	; (800e024 <finite+0xc>)
 800e01a:	0048      	lsls	r0, r1, #1
 800e01c:	0840      	lsrs	r0, r0, #1
 800e01e:	18c0      	adds	r0, r0, r3
 800e020:	0fc0      	lsrs	r0, r0, #31
 800e022:	4770      	bx	lr
 800e024:	80100000 	.word	0x80100000

0800e028 <floor>:
 800e028:	b5f7      	push	{r0, r1, r2, r4, r5, r6, r7, lr}
 800e02a:	004b      	lsls	r3, r1, #1
 800e02c:	4a3d      	ldr	r2, [pc, #244]	; (800e124 <floor+0xfc>)
 800e02e:	0d5b      	lsrs	r3, r3, #21
 800e030:	189f      	adds	r7, r3, r2
 800e032:	4684      	mov	ip, r0
 800e034:	000e      	movs	r6, r1
 800e036:	000d      	movs	r5, r1
 800e038:	0004      	movs	r4, r0
 800e03a:	9001      	str	r0, [sp, #4]
 800e03c:	2f13      	cmp	r7, #19
 800e03e:	dc34      	bgt.n	800e0aa <floor+0x82>
 800e040:	2f00      	cmp	r7, #0
 800e042:	da16      	bge.n	800e072 <floor+0x4a>
 800e044:	4a38      	ldr	r2, [pc, #224]	; (800e128 <floor+0x100>)
 800e046:	4b39      	ldr	r3, [pc, #228]	; (800e12c <floor+0x104>)
 800e048:	4660      	mov	r0, ip
 800e04a:	0031      	movs	r1, r6
 800e04c:	f7f3 f8f2 	bl	8001234 <__aeabi_dadd>
 800e050:	2200      	movs	r2, #0
 800e052:	2300      	movs	r3, #0
 800e054:	f7f4 fe9e 	bl	8002d94 <__aeabi_dcmpgt>
 800e058:	2800      	cmp	r0, #0
 800e05a:	d007      	beq.n	800e06c <floor+0x44>
 800e05c:	2e00      	cmp	r6, #0
 800e05e:	da5d      	bge.n	800e11c <floor+0xf4>
 800e060:	0073      	lsls	r3, r6, #1
 800e062:	085b      	lsrs	r3, r3, #1
 800e064:	431c      	orrs	r4, r3
 800e066:	d001      	beq.n	800e06c <floor+0x44>
 800e068:	2400      	movs	r4, #0
 800e06a:	4d31      	ldr	r5, [pc, #196]	; (800e130 <floor+0x108>)
 800e06c:	46a4      	mov	ip, r4
 800e06e:	002e      	movs	r6, r5
 800e070:	e029      	b.n	800e0c6 <floor+0x9e>
 800e072:	4b30      	ldr	r3, [pc, #192]	; (800e134 <floor+0x10c>)
 800e074:	413b      	asrs	r3, r7
 800e076:	9300      	str	r3, [sp, #0]
 800e078:	400b      	ands	r3, r1
 800e07a:	4303      	orrs	r3, r0
 800e07c:	d023      	beq.n	800e0c6 <floor+0x9e>
 800e07e:	4a2a      	ldr	r2, [pc, #168]	; (800e128 <floor+0x100>)
 800e080:	4b2a      	ldr	r3, [pc, #168]	; (800e12c <floor+0x104>)
 800e082:	4660      	mov	r0, ip
 800e084:	0031      	movs	r1, r6
 800e086:	f7f3 f8d5 	bl	8001234 <__aeabi_dadd>
 800e08a:	2200      	movs	r2, #0
 800e08c:	2300      	movs	r3, #0
 800e08e:	f7f4 fe81 	bl	8002d94 <__aeabi_dcmpgt>
 800e092:	2800      	cmp	r0, #0
 800e094:	d0ea      	beq.n	800e06c <floor+0x44>
 800e096:	2e00      	cmp	r6, #0
 800e098:	da03      	bge.n	800e0a2 <floor+0x7a>
 800e09a:	2380      	movs	r3, #128	; 0x80
 800e09c:	035b      	lsls	r3, r3, #13
 800e09e:	413b      	asrs	r3, r7
 800e0a0:	18f5      	adds	r5, r6, r3
 800e0a2:	9b00      	ldr	r3, [sp, #0]
 800e0a4:	2400      	movs	r4, #0
 800e0a6:	439d      	bics	r5, r3
 800e0a8:	e7e0      	b.n	800e06c <floor+0x44>
 800e0aa:	2f33      	cmp	r7, #51	; 0x33
 800e0ac:	dd0f      	ble.n	800e0ce <floor+0xa6>
 800e0ae:	2380      	movs	r3, #128	; 0x80
 800e0b0:	00db      	lsls	r3, r3, #3
 800e0b2:	429f      	cmp	r7, r3
 800e0b4:	d107      	bne.n	800e0c6 <floor+0x9e>
 800e0b6:	0002      	movs	r2, r0
 800e0b8:	000b      	movs	r3, r1
 800e0ba:	4660      	mov	r0, ip
 800e0bc:	0031      	movs	r1, r6
 800e0be:	f7f3 f8b9 	bl	8001234 <__aeabi_dadd>
 800e0c2:	4684      	mov	ip, r0
 800e0c4:	000e      	movs	r6, r1
 800e0c6:	4660      	mov	r0, ip
 800e0c8:	0031      	movs	r1, r6
 800e0ca:	b003      	add	sp, #12
 800e0cc:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800e0ce:	4a1a      	ldr	r2, [pc, #104]	; (800e138 <floor+0x110>)
 800e0d0:	189b      	adds	r3, r3, r2
 800e0d2:	2201      	movs	r2, #1
 800e0d4:	4252      	negs	r2, r2
 800e0d6:	40da      	lsrs	r2, r3
 800e0d8:	9200      	str	r2, [sp, #0]
 800e0da:	4210      	tst	r0, r2
 800e0dc:	d0f3      	beq.n	800e0c6 <floor+0x9e>
 800e0de:	4a12      	ldr	r2, [pc, #72]	; (800e128 <floor+0x100>)
 800e0e0:	4b12      	ldr	r3, [pc, #72]	; (800e12c <floor+0x104>)
 800e0e2:	4660      	mov	r0, ip
 800e0e4:	0031      	movs	r1, r6
 800e0e6:	f7f3 f8a5 	bl	8001234 <__aeabi_dadd>
 800e0ea:	2200      	movs	r2, #0
 800e0ec:	2300      	movs	r3, #0
 800e0ee:	f7f4 fe51 	bl	8002d94 <__aeabi_dcmpgt>
 800e0f2:	2800      	cmp	r0, #0
 800e0f4:	d0ba      	beq.n	800e06c <floor+0x44>
 800e0f6:	2e00      	cmp	r6, #0
 800e0f8:	da02      	bge.n	800e100 <floor+0xd8>
 800e0fa:	2f14      	cmp	r7, #20
 800e0fc:	d103      	bne.n	800e106 <floor+0xde>
 800e0fe:	3501      	adds	r5, #1
 800e100:	9b00      	ldr	r3, [sp, #0]
 800e102:	439c      	bics	r4, r3
 800e104:	e7b2      	b.n	800e06c <floor+0x44>
 800e106:	2334      	movs	r3, #52	; 0x34
 800e108:	1bdf      	subs	r7, r3, r7
 800e10a:	3b33      	subs	r3, #51	; 0x33
 800e10c:	40bb      	lsls	r3, r7
 800e10e:	18e4      	adds	r4, r4, r3
 800e110:	9b01      	ldr	r3, [sp, #4]
 800e112:	429c      	cmp	r4, r3
 800e114:	419b      	sbcs	r3, r3
 800e116:	425b      	negs	r3, r3
 800e118:	18f5      	adds	r5, r6, r3
 800e11a:	e7f1      	b.n	800e100 <floor+0xd8>
 800e11c:	2400      	movs	r4, #0
 800e11e:	0025      	movs	r5, r4
 800e120:	e7a4      	b.n	800e06c <floor+0x44>
 800e122:	46c0      	nop			; (mov r8, r8)
 800e124:	fffffc01 	.word	0xfffffc01
 800e128:	8800759c 	.word	0x8800759c
 800e12c:	7e37e43c 	.word	0x7e37e43c
 800e130:	bff00000 	.word	0xbff00000
 800e134:	000fffff 	.word	0x000fffff
 800e138:	fffffbed 	.word	0xfffffbed

0800e13c <nan>:
 800e13c:	2000      	movs	r0, #0
 800e13e:	4901      	ldr	r1, [pc, #4]	; (800e144 <nan+0x8>)
 800e140:	4770      	bx	lr
 800e142:	46c0      	nop			; (mov r8, r8)
 800e144:	7ff80000 	.word	0x7ff80000

0800e148 <rint>:
 800e148:	b5f0      	push	{r4, r5, r6, r7, lr}
 800e14a:	004a      	lsls	r2, r1, #1
 800e14c:	4e3e      	ldr	r6, [pc, #248]	; (800e248 <rint+0x100>)
 800e14e:	0d52      	lsrs	r2, r2, #21
 800e150:	b085      	sub	sp, #20
 800e152:	1996      	adds	r6, r2, r6
 800e154:	000d      	movs	r5, r1
 800e156:	0003      	movs	r3, r0
 800e158:	9101      	str	r1, [sp, #4]
 800e15a:	0fcc      	lsrs	r4, r1, #31
 800e15c:	2e13      	cmp	r6, #19
 800e15e:	dc57      	bgt.n	800e210 <rint+0xc8>
 800e160:	2e00      	cmp	r6, #0
 800e162:	da2a      	bge.n	800e1ba <rint+0x72>
 800e164:	004a      	lsls	r2, r1, #1
 800e166:	0852      	lsrs	r2, r2, #1
 800e168:	4302      	orrs	r2, r0
 800e16a:	d024      	beq.n	800e1b6 <rint+0x6e>
 800e16c:	030a      	lsls	r2, r1, #12
 800e16e:	0b12      	lsrs	r2, r2, #12
 800e170:	4302      	orrs	r2, r0
 800e172:	4253      	negs	r3, r2
 800e174:	4313      	orrs	r3, r2
 800e176:	2280      	movs	r2, #128	; 0x80
 800e178:	0c4d      	lsrs	r5, r1, #17
 800e17a:	0312      	lsls	r2, r2, #12
 800e17c:	0b1b      	lsrs	r3, r3, #12
 800e17e:	4013      	ands	r3, r2
 800e180:	046d      	lsls	r5, r5, #17
 800e182:	432b      	orrs	r3, r5
 800e184:	0019      	movs	r1, r3
 800e186:	4b31      	ldr	r3, [pc, #196]	; (800e24c <rint+0x104>)
 800e188:	00e2      	lsls	r2, r4, #3
 800e18a:	189b      	adds	r3, r3, r2
 800e18c:	681e      	ldr	r6, [r3, #0]
 800e18e:	685f      	ldr	r7, [r3, #4]
 800e190:	0002      	movs	r2, r0
 800e192:	000b      	movs	r3, r1
 800e194:	0030      	movs	r0, r6
 800e196:	0039      	movs	r1, r7
 800e198:	f7f3 f84c 	bl	8001234 <__aeabi_dadd>
 800e19c:	9002      	str	r0, [sp, #8]
 800e19e:	9103      	str	r1, [sp, #12]
 800e1a0:	9802      	ldr	r0, [sp, #8]
 800e1a2:	9903      	ldr	r1, [sp, #12]
 800e1a4:	003b      	movs	r3, r7
 800e1a6:	0032      	movs	r2, r6
 800e1a8:	f7f4 f902 	bl	80023b0 <__aeabi_dsub>
 800e1ac:	004b      	lsls	r3, r1, #1
 800e1ae:	085b      	lsrs	r3, r3, #1
 800e1b0:	07e4      	lsls	r4, r4, #31
 800e1b2:	4323      	orrs	r3, r4
 800e1b4:	0019      	movs	r1, r3
 800e1b6:	b005      	add	sp, #20
 800e1b8:	bdf0      	pop	{r4, r5, r6, r7, pc}
 800e1ba:	4a25      	ldr	r2, [pc, #148]	; (800e250 <rint+0x108>)
 800e1bc:	4132      	asrs	r2, r6
 800e1be:	0017      	movs	r7, r2
 800e1c0:	400f      	ands	r7, r1
 800e1c2:	4307      	orrs	r7, r0
 800e1c4:	d0f7      	beq.n	800e1b6 <rint+0x6e>
 800e1c6:	0852      	lsrs	r2, r2, #1
 800e1c8:	0011      	movs	r1, r2
 800e1ca:	4029      	ands	r1, r5
 800e1cc:	430b      	orrs	r3, r1
 800e1ce:	d00a      	beq.n	800e1e6 <rint+0x9e>
 800e1d0:	2300      	movs	r3, #0
 800e1d2:	2e13      	cmp	r6, #19
 800e1d4:	d101      	bne.n	800e1da <rint+0x92>
 800e1d6:	2380      	movs	r3, #128	; 0x80
 800e1d8:	061b      	lsls	r3, r3, #24
 800e1da:	2780      	movs	r7, #128	; 0x80
 800e1dc:	02ff      	lsls	r7, r7, #11
 800e1de:	4137      	asrs	r7, r6
 800e1e0:	4395      	bics	r5, r2
 800e1e2:	432f      	orrs	r7, r5
 800e1e4:	9701      	str	r7, [sp, #4]
 800e1e6:	9901      	ldr	r1, [sp, #4]
 800e1e8:	001a      	movs	r2, r3
 800e1ea:	000b      	movs	r3, r1
 800e1ec:	4917      	ldr	r1, [pc, #92]	; (800e24c <rint+0x104>)
 800e1ee:	00e4      	lsls	r4, r4, #3
 800e1f0:	190c      	adds	r4, r1, r4
 800e1f2:	6865      	ldr	r5, [r4, #4]
 800e1f4:	6824      	ldr	r4, [r4, #0]
 800e1f6:	0020      	movs	r0, r4
 800e1f8:	0029      	movs	r1, r5
 800e1fa:	f7f3 f81b 	bl	8001234 <__aeabi_dadd>
 800e1fe:	9002      	str	r0, [sp, #8]
 800e200:	9103      	str	r1, [sp, #12]
 800e202:	9802      	ldr	r0, [sp, #8]
 800e204:	9903      	ldr	r1, [sp, #12]
 800e206:	0022      	movs	r2, r4
 800e208:	002b      	movs	r3, r5
 800e20a:	f7f4 f8d1 	bl	80023b0 <__aeabi_dsub>
 800e20e:	e7d2      	b.n	800e1b6 <rint+0x6e>
 800e210:	2e33      	cmp	r6, #51	; 0x33
 800e212:	dd08      	ble.n	800e226 <rint+0xde>
 800e214:	2380      	movs	r3, #128	; 0x80
 800e216:	00db      	lsls	r3, r3, #3
 800e218:	429e      	cmp	r6, r3
 800e21a:	d1cc      	bne.n	800e1b6 <rint+0x6e>
 800e21c:	0002      	movs	r2, r0
 800e21e:	000b      	movs	r3, r1
 800e220:	f7f3 f808 	bl	8001234 <__aeabi_dadd>
 800e224:	e7c7      	b.n	800e1b6 <rint+0x6e>
 800e226:	2601      	movs	r6, #1
 800e228:	4d0a      	ldr	r5, [pc, #40]	; (800e254 <rint+0x10c>)
 800e22a:	4276      	negs	r6, r6
 800e22c:	1952      	adds	r2, r2, r5
 800e22e:	40d6      	lsrs	r6, r2
 800e230:	4206      	tst	r6, r0
 800e232:	d0c0      	beq.n	800e1b6 <rint+0x6e>
 800e234:	0876      	lsrs	r6, r6, #1
 800e236:	4206      	tst	r6, r0
 800e238:	d0d5      	beq.n	800e1e6 <rint+0x9e>
 800e23a:	2180      	movs	r1, #128	; 0x80
 800e23c:	05c9      	lsls	r1, r1, #23
 800e23e:	4111      	asrs	r1, r2
 800e240:	43b3      	bics	r3, r6
 800e242:	430b      	orrs	r3, r1
 800e244:	e7cf      	b.n	800e1e6 <rint+0x9e>
 800e246:	46c0      	nop			; (mov r8, r8)
 800e248:	fffffc01 	.word	0xfffffc01
 800e24c:	0800f588 	.word	0x0800f588
 800e250:	000fffff 	.word	0x000fffff
 800e254:	fffffbed 	.word	0xfffffbed

0800e258 <scalbn>:
 800e258:	004b      	lsls	r3, r1, #1
 800e25a:	b570      	push	{r4, r5, r6, lr}
 800e25c:	0d5b      	lsrs	r3, r3, #21
 800e25e:	0014      	movs	r4, r2
 800e260:	000a      	movs	r2, r1
 800e262:	2b00      	cmp	r3, #0
 800e264:	d10d      	bne.n	800e282 <scalbn+0x2a>
 800e266:	004b      	lsls	r3, r1, #1
 800e268:	085b      	lsrs	r3, r3, #1
 800e26a:	4303      	orrs	r3, r0
 800e26c:	d010      	beq.n	800e290 <scalbn+0x38>
 800e26e:	4b27      	ldr	r3, [pc, #156]	; (800e30c <scalbn+0xb4>)
 800e270:	2200      	movs	r2, #0
 800e272:	f7f3 fe31 	bl	8001ed8 <__aeabi_dmul>
 800e276:	4b26      	ldr	r3, [pc, #152]	; (800e310 <scalbn+0xb8>)
 800e278:	429c      	cmp	r4, r3
 800e27a:	da0a      	bge.n	800e292 <scalbn+0x3a>
 800e27c:	4a25      	ldr	r2, [pc, #148]	; (800e314 <scalbn+0xbc>)
 800e27e:	4b26      	ldr	r3, [pc, #152]	; (800e318 <scalbn+0xc0>)
 800e280:	e019      	b.n	800e2b6 <scalbn+0x5e>
 800e282:	4d26      	ldr	r5, [pc, #152]	; (800e31c <scalbn+0xc4>)
 800e284:	42ab      	cmp	r3, r5
 800e286:	d108      	bne.n	800e29a <scalbn+0x42>
 800e288:	0002      	movs	r2, r0
 800e28a:	000b      	movs	r3, r1
 800e28c:	f7f2 ffd2 	bl	8001234 <__aeabi_dadd>
 800e290:	bd70      	pop	{r4, r5, r6, pc}
 800e292:	000a      	movs	r2, r1
 800e294:	004b      	lsls	r3, r1, #1
 800e296:	0d5b      	lsrs	r3, r3, #21
 800e298:	3b36      	subs	r3, #54	; 0x36
 800e29a:	4d21      	ldr	r5, [pc, #132]	; (800e320 <scalbn+0xc8>)
 800e29c:	18e3      	adds	r3, r4, r3
 800e29e:	42ab      	cmp	r3, r5
 800e2a0:	dd0c      	ble.n	800e2bc <scalbn+0x64>
 800e2a2:	4c20      	ldr	r4, [pc, #128]	; (800e324 <scalbn+0xcc>)
 800e2a4:	4d20      	ldr	r5, [pc, #128]	; (800e328 <scalbn+0xd0>)
 800e2a6:	2900      	cmp	r1, #0
 800e2a8:	da01      	bge.n	800e2ae <scalbn+0x56>
 800e2aa:	4c1e      	ldr	r4, [pc, #120]	; (800e324 <scalbn+0xcc>)
 800e2ac:	4d1f      	ldr	r5, [pc, #124]	; (800e32c <scalbn+0xd4>)
 800e2ae:	0020      	movs	r0, r4
 800e2b0:	0029      	movs	r1, r5
 800e2b2:	4a1c      	ldr	r2, [pc, #112]	; (800e324 <scalbn+0xcc>)
 800e2b4:	4b1c      	ldr	r3, [pc, #112]	; (800e328 <scalbn+0xd0>)
 800e2b6:	f7f3 fe0f 	bl	8001ed8 <__aeabi_dmul>
 800e2ba:	e7e9      	b.n	800e290 <scalbn+0x38>
 800e2bc:	2b00      	cmp	r3, #0
 800e2be:	dd05      	ble.n	800e2cc <scalbn+0x74>
 800e2c0:	4c1b      	ldr	r4, [pc, #108]	; (800e330 <scalbn+0xd8>)
 800e2c2:	051b      	lsls	r3, r3, #20
 800e2c4:	4022      	ands	r2, r4
 800e2c6:	431a      	orrs	r2, r3
 800e2c8:	0011      	movs	r1, r2
 800e2ca:	e7e1      	b.n	800e290 <scalbn+0x38>
 800e2cc:	001d      	movs	r5, r3
 800e2ce:	3535      	adds	r5, #53	; 0x35
 800e2d0:	da13      	bge.n	800e2fa <scalbn+0xa2>
 800e2d2:	4a18      	ldr	r2, [pc, #96]	; (800e334 <scalbn+0xdc>)
 800e2d4:	0fcb      	lsrs	r3, r1, #31
 800e2d6:	4294      	cmp	r4, r2
 800e2d8:	dd08      	ble.n	800e2ec <scalbn+0x94>
 800e2da:	4812      	ldr	r0, [pc, #72]	; (800e324 <scalbn+0xcc>)
 800e2dc:	4912      	ldr	r1, [pc, #72]	; (800e328 <scalbn+0xd0>)
 800e2de:	2b00      	cmp	r3, #0
 800e2e0:	d001      	beq.n	800e2e6 <scalbn+0x8e>
 800e2e2:	4810      	ldr	r0, [pc, #64]	; (800e324 <scalbn+0xcc>)
 800e2e4:	4911      	ldr	r1, [pc, #68]	; (800e32c <scalbn+0xd4>)
 800e2e6:	4a0f      	ldr	r2, [pc, #60]	; (800e324 <scalbn+0xcc>)
 800e2e8:	4b0f      	ldr	r3, [pc, #60]	; (800e328 <scalbn+0xd0>)
 800e2ea:	e7e4      	b.n	800e2b6 <scalbn+0x5e>
 800e2ec:	4809      	ldr	r0, [pc, #36]	; (800e314 <scalbn+0xbc>)
 800e2ee:	490a      	ldr	r1, [pc, #40]	; (800e318 <scalbn+0xc0>)
 800e2f0:	2b00      	cmp	r3, #0
 800e2f2:	d0c3      	beq.n	800e27c <scalbn+0x24>
 800e2f4:	4807      	ldr	r0, [pc, #28]	; (800e314 <scalbn+0xbc>)
 800e2f6:	4910      	ldr	r1, [pc, #64]	; (800e338 <scalbn+0xe0>)
 800e2f8:	e7c0      	b.n	800e27c <scalbn+0x24>
 800e2fa:	4c0d      	ldr	r4, [pc, #52]	; (800e330 <scalbn+0xd8>)
 800e2fc:	3336      	adds	r3, #54	; 0x36
 800e2fe:	4022      	ands	r2, r4
 800e300:	051b      	lsls	r3, r3, #20
 800e302:	4313      	orrs	r3, r2
 800e304:	0019      	movs	r1, r3
 800e306:	2200      	movs	r2, #0
 800e308:	4b0c      	ldr	r3, [pc, #48]	; (800e33c <scalbn+0xe4>)
 800e30a:	e7d4      	b.n	800e2b6 <scalbn+0x5e>
 800e30c:	43500000 	.word	0x43500000
 800e310:	ffff3cb0 	.word	0xffff3cb0
 800e314:	c2f8f359 	.word	0xc2f8f359
 800e318:	01a56e1f 	.word	0x01a56e1f
 800e31c:	000007ff 	.word	0x000007ff
 800e320:	000007fe 	.word	0x000007fe
 800e324:	8800759c 	.word	0x8800759c
 800e328:	7e37e43c 	.word	0x7e37e43c
 800e32c:	fe37e43c 	.word	0xfe37e43c
 800e330:	800fffff 	.word	0x800fffff
 800e334:	0000c350 	.word	0x0000c350
 800e338:	81a56e1f 	.word	0x81a56e1f
 800e33c:	3c900000 	.word	0x3c900000

0800e340 <_init>:
 800e340:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 800e342:	46c0      	nop			; (mov r8, r8)
 800e344:	bcf8      	pop	{r3, r4, r5, r6, r7}
 800e346:	bc08      	pop	{r3}
 800e348:	469e      	mov	lr, r3
 800e34a:	4770      	bx	lr

0800e34c <_fini>:
 800e34c:	b5f8      	push	{r3, r4, r5, r6, r7, lr}
 800e34e:	46c0      	nop			; (mov r8, r8)
 800e350:	bcf8      	pop	{r3, r4, r5, r6, r7}
 800e352:	bc08      	pop	{r3}
 800e354:	469e      	mov	lr, r3
 800e356:	4770      	bx	lr
