mirror of
https://github.com/yoboujon/dumber.git
synced 2025-06-09 06:10:49 +02:00
22798 lines
854 KiB
Text
22798 lines
854 KiB
Text
|
|
Dumber3.elf: file format elf32-littlearm
|
|
|
|
Sections:
|
|
Idx Name Size VMA LMA File off Algn
|
|
0 .isr_vector 000000c0 08000000 08000000 00010000 2**0
|
|
CONTENTS, ALLOC, LOAD, READONLY, DATA
|
|
1 .text 00007728 080000c0 080000c0 000100c0 2**4
|
|
CONTENTS, ALLOC, LOAD, READONLY, CODE
|
|
2 .rodata 00000130 080077e8 080077e8 000177e8 2**2
|
|
CONTENTS, ALLOC, LOAD, READONLY, DATA
|
|
3 .ARM.extab 00000000 08007918 08007918 00020010 2**0
|
|
CONTENTS
|
|
4 .ARM 00000008 08007918 08007918 00017918 2**2
|
|
CONTENTS, ALLOC, LOAD, READONLY, DATA
|
|
5 .preinit_array 00000000 08007920 08007920 00020010 2**0
|
|
CONTENTS, ALLOC, LOAD, DATA
|
|
6 .init_array 00000004 08007920 08007920 00017920 2**2
|
|
CONTENTS, ALLOC, LOAD, DATA
|
|
7 .fini_array 00000004 08007924 08007924 00017924 2**2
|
|
CONTENTS, ALLOC, LOAD, DATA
|
|
8 .data 00000010 20000000 08007928 00020000 2**2
|
|
CONTENTS, ALLOC, LOAD, DATA
|
|
9 .bss 0000199c 20000010 08007938 00020010 2**2
|
|
ALLOC
|
|
10 ._user_heap_stack 00000604 200019ac 08007938 000219ac 2**0
|
|
ALLOC
|
|
11 .ARM.attributes 00000028 00000000 00000000 00020010 2**0
|
|
CONTENTS, READONLY
|
|
12 .debug_info 0001c98c 00000000 00000000 00020038 2**0
|
|
CONTENTS, READONLY, DEBUGGING, OCTETS
|
|
13 .debug_abbrev 00003b25 00000000 00000000 0003c9c4 2**0
|
|
CONTENTS, READONLY, DEBUGGING, OCTETS
|
|
14 .debug_aranges 00001650 00000000 00000000 000404f0 2**3
|
|
CONTENTS, READONLY, DEBUGGING, OCTETS
|
|
15 .debug_ranges 000014d8 00000000 00000000 00041b40 2**3
|
|
CONTENTS, READONLY, DEBUGGING, OCTETS
|
|
16 .debug_macro 00013dc2 00000000 00000000 00043018 2**0
|
|
CONTENTS, READONLY, DEBUGGING, OCTETS
|
|
17 .debug_line 00019121 00000000 00000000 00056dda 2**0
|
|
CONTENTS, READONLY, DEBUGGING, OCTETS
|
|
18 .debug_str 0007a4cb 00000000 00000000 0006fefb 2**0
|
|
CONTENTS, READONLY, DEBUGGING, OCTETS
|
|
19 .comment 00000053 00000000 00000000 000ea3c6 2**0
|
|
CONTENTS, READONLY
|
|
20 .debug_frame 00005064 00000000 00000000 000ea41c 2**2
|
|
CONTENTS, READONLY, DEBUGGING, OCTETS
|
|
|
|
Disassembly of section .text:
|
|
|
|
080000c0 <__do_global_dtors_aux>:
|
|
80000c0: b510 push {r4, lr}
|
|
80000c2: 4c06 ldr r4, [pc, #24] ; (80000dc <__do_global_dtors_aux+0x1c>)
|
|
80000c4: 7823 ldrb r3, [r4, #0]
|
|
80000c6: 2b00 cmp r3, #0
|
|
80000c8: d107 bne.n 80000da <__do_global_dtors_aux+0x1a>
|
|
80000ca: 4b05 ldr r3, [pc, #20] ; (80000e0 <__do_global_dtors_aux+0x20>)
|
|
80000cc: 2b00 cmp r3, #0
|
|
80000ce: d002 beq.n 80000d6 <__do_global_dtors_aux+0x16>
|
|
80000d0: 4804 ldr r0, [pc, #16] ; (80000e4 <__do_global_dtors_aux+0x24>)
|
|
80000d2: e000 b.n 80000d6 <__do_global_dtors_aux+0x16>
|
|
80000d4: bf00 nop
|
|
80000d6: 2301 movs r3, #1
|
|
80000d8: 7023 strb r3, [r4, #0]
|
|
80000da: bd10 pop {r4, pc}
|
|
80000dc: 20000010 .word 0x20000010
|
|
80000e0: 00000000 .word 0x00000000
|
|
80000e4: 080077d0 .word 0x080077d0
|
|
|
|
080000e8 <frame_dummy>:
|
|
80000e8: 4b04 ldr r3, [pc, #16] ; (80000fc <frame_dummy+0x14>)
|
|
80000ea: b510 push {r4, lr}
|
|
80000ec: 2b00 cmp r3, #0
|
|
80000ee: d003 beq.n 80000f8 <frame_dummy+0x10>
|
|
80000f0: 4903 ldr r1, [pc, #12] ; (8000100 <frame_dummy+0x18>)
|
|
80000f2: 4804 ldr r0, [pc, #16] ; (8000104 <frame_dummy+0x1c>)
|
|
80000f4: e000 b.n 80000f8 <frame_dummy+0x10>
|
|
80000f6: bf00 nop
|
|
80000f8: bd10 pop {r4, pc}
|
|
80000fa: 46c0 nop ; (mov r8, r8)
|
|
80000fc: 00000000 .word 0x00000000
|
|
8000100: 20000014 .word 0x20000014
|
|
8000104: 080077d0 .word 0x080077d0
|
|
|
|
08000108 <__udivsi3>:
|
|
8000108: 2200 movs r2, #0
|
|
800010a: 0843 lsrs r3, r0, #1
|
|
800010c: 428b cmp r3, r1
|
|
800010e: d374 bcc.n 80001fa <__udivsi3+0xf2>
|
|
8000110: 0903 lsrs r3, r0, #4
|
|
8000112: 428b cmp r3, r1
|
|
8000114: d35f bcc.n 80001d6 <__udivsi3+0xce>
|
|
8000116: 0a03 lsrs r3, r0, #8
|
|
8000118: 428b cmp r3, r1
|
|
800011a: d344 bcc.n 80001a6 <__udivsi3+0x9e>
|
|
800011c: 0b03 lsrs r3, r0, #12
|
|
800011e: 428b cmp r3, r1
|
|
8000120: d328 bcc.n 8000174 <__udivsi3+0x6c>
|
|
8000122: 0c03 lsrs r3, r0, #16
|
|
8000124: 428b cmp r3, r1
|
|
8000126: d30d bcc.n 8000144 <__udivsi3+0x3c>
|
|
8000128: 22ff movs r2, #255 ; 0xff
|
|
800012a: 0209 lsls r1, r1, #8
|
|
800012c: ba12 rev r2, r2
|
|
800012e: 0c03 lsrs r3, r0, #16
|
|
8000130: 428b cmp r3, r1
|
|
8000132: d302 bcc.n 800013a <__udivsi3+0x32>
|
|
8000134: 1212 asrs r2, r2, #8
|
|
8000136: 0209 lsls r1, r1, #8
|
|
8000138: d065 beq.n 8000206 <__udivsi3+0xfe>
|
|
800013a: 0b03 lsrs r3, r0, #12
|
|
800013c: 428b cmp r3, r1
|
|
800013e: d319 bcc.n 8000174 <__udivsi3+0x6c>
|
|
8000140: e000 b.n 8000144 <__udivsi3+0x3c>
|
|
8000142: 0a09 lsrs r1, r1, #8
|
|
8000144: 0bc3 lsrs r3, r0, #15
|
|
8000146: 428b cmp r3, r1
|
|
8000148: d301 bcc.n 800014e <__udivsi3+0x46>
|
|
800014a: 03cb lsls r3, r1, #15
|
|
800014c: 1ac0 subs r0, r0, r3
|
|
800014e: 4152 adcs r2, r2
|
|
8000150: 0b83 lsrs r3, r0, #14
|
|
8000152: 428b cmp r3, r1
|
|
8000154: d301 bcc.n 800015a <__udivsi3+0x52>
|
|
8000156: 038b lsls r3, r1, #14
|
|
8000158: 1ac0 subs r0, r0, r3
|
|
800015a: 4152 adcs r2, r2
|
|
800015c: 0b43 lsrs r3, r0, #13
|
|
800015e: 428b cmp r3, r1
|
|
8000160: d301 bcc.n 8000166 <__udivsi3+0x5e>
|
|
8000162: 034b lsls r3, r1, #13
|
|
8000164: 1ac0 subs r0, r0, r3
|
|
8000166: 4152 adcs r2, r2
|
|
8000168: 0b03 lsrs r3, r0, #12
|
|
800016a: 428b cmp r3, r1
|
|
800016c: d301 bcc.n 8000172 <__udivsi3+0x6a>
|
|
800016e: 030b lsls r3, r1, #12
|
|
8000170: 1ac0 subs r0, r0, r3
|
|
8000172: 4152 adcs r2, r2
|
|
8000174: 0ac3 lsrs r3, r0, #11
|
|
8000176: 428b cmp r3, r1
|
|
8000178: d301 bcc.n 800017e <__udivsi3+0x76>
|
|
800017a: 02cb lsls r3, r1, #11
|
|
800017c: 1ac0 subs r0, r0, r3
|
|
800017e: 4152 adcs r2, r2
|
|
8000180: 0a83 lsrs r3, r0, #10
|
|
8000182: 428b cmp r3, r1
|
|
8000184: d301 bcc.n 800018a <__udivsi3+0x82>
|
|
8000186: 028b lsls r3, r1, #10
|
|
8000188: 1ac0 subs r0, r0, r3
|
|
800018a: 4152 adcs r2, r2
|
|
800018c: 0a43 lsrs r3, r0, #9
|
|
800018e: 428b cmp r3, r1
|
|
8000190: d301 bcc.n 8000196 <__udivsi3+0x8e>
|
|
8000192: 024b lsls r3, r1, #9
|
|
8000194: 1ac0 subs r0, r0, r3
|
|
8000196: 4152 adcs r2, r2
|
|
8000198: 0a03 lsrs r3, r0, #8
|
|
800019a: 428b cmp r3, r1
|
|
800019c: d301 bcc.n 80001a2 <__udivsi3+0x9a>
|
|
800019e: 020b lsls r3, r1, #8
|
|
80001a0: 1ac0 subs r0, r0, r3
|
|
80001a2: 4152 adcs r2, r2
|
|
80001a4: d2cd bcs.n 8000142 <__udivsi3+0x3a>
|
|
80001a6: 09c3 lsrs r3, r0, #7
|
|
80001a8: 428b cmp r3, r1
|
|
80001aa: d301 bcc.n 80001b0 <__udivsi3+0xa8>
|
|
80001ac: 01cb lsls r3, r1, #7
|
|
80001ae: 1ac0 subs r0, r0, r3
|
|
80001b0: 4152 adcs r2, r2
|
|
80001b2: 0983 lsrs r3, r0, #6
|
|
80001b4: 428b cmp r3, r1
|
|
80001b6: d301 bcc.n 80001bc <__udivsi3+0xb4>
|
|
80001b8: 018b lsls r3, r1, #6
|
|
80001ba: 1ac0 subs r0, r0, r3
|
|
80001bc: 4152 adcs r2, r2
|
|
80001be: 0943 lsrs r3, r0, #5
|
|
80001c0: 428b cmp r3, r1
|
|
80001c2: d301 bcc.n 80001c8 <__udivsi3+0xc0>
|
|
80001c4: 014b lsls r3, r1, #5
|
|
80001c6: 1ac0 subs r0, r0, r3
|
|
80001c8: 4152 adcs r2, r2
|
|
80001ca: 0903 lsrs r3, r0, #4
|
|
80001cc: 428b cmp r3, r1
|
|
80001ce: d301 bcc.n 80001d4 <__udivsi3+0xcc>
|
|
80001d0: 010b lsls r3, r1, #4
|
|
80001d2: 1ac0 subs r0, r0, r3
|
|
80001d4: 4152 adcs r2, r2
|
|
80001d6: 08c3 lsrs r3, r0, #3
|
|
80001d8: 428b cmp r3, r1
|
|
80001da: d301 bcc.n 80001e0 <__udivsi3+0xd8>
|
|
80001dc: 00cb lsls r3, r1, #3
|
|
80001de: 1ac0 subs r0, r0, r3
|
|
80001e0: 4152 adcs r2, r2
|
|
80001e2: 0883 lsrs r3, r0, #2
|
|
80001e4: 428b cmp r3, r1
|
|
80001e6: d301 bcc.n 80001ec <__udivsi3+0xe4>
|
|
80001e8: 008b lsls r3, r1, #2
|
|
80001ea: 1ac0 subs r0, r0, r3
|
|
80001ec: 4152 adcs r2, r2
|
|
80001ee: 0843 lsrs r3, r0, #1
|
|
80001f0: 428b cmp r3, r1
|
|
80001f2: d301 bcc.n 80001f8 <__udivsi3+0xf0>
|
|
80001f4: 004b lsls r3, r1, #1
|
|
80001f6: 1ac0 subs r0, r0, r3
|
|
80001f8: 4152 adcs r2, r2
|
|
80001fa: 1a41 subs r1, r0, r1
|
|
80001fc: d200 bcs.n 8000200 <__udivsi3+0xf8>
|
|
80001fe: 4601 mov r1, r0
|
|
8000200: 4152 adcs r2, r2
|
|
8000202: 4610 mov r0, r2
|
|
8000204: 4770 bx lr
|
|
8000206: e7ff b.n 8000208 <__udivsi3+0x100>
|
|
8000208: b501 push {r0, lr}
|
|
800020a: 2000 movs r0, #0
|
|
800020c: f000 f806 bl 800021c <__aeabi_idiv0>
|
|
8000210: bd02 pop {r1, pc}
|
|
8000212: 46c0 nop ; (mov r8, r8)
|
|
|
|
08000214 <__aeabi_uidivmod>:
|
|
8000214: 2900 cmp r1, #0
|
|
8000216: d0f7 beq.n 8000208 <__udivsi3+0x100>
|
|
8000218: e776 b.n 8000108 <__udivsi3>
|
|
800021a: 4770 bx lr
|
|
|
|
0800021c <__aeabi_idiv0>:
|
|
800021c: 4770 bx lr
|
|
800021e: 46c0 nop ; (mov r8, r8)
|
|
|
|
08000220 <__aeabi_uldivmod>:
|
|
8000220: 2b00 cmp r3, #0
|
|
8000222: d111 bne.n 8000248 <__aeabi_uldivmod+0x28>
|
|
8000224: 2a00 cmp r2, #0
|
|
8000226: d10f bne.n 8000248 <__aeabi_uldivmod+0x28>
|
|
8000228: 2900 cmp r1, #0
|
|
800022a: d100 bne.n 800022e <__aeabi_uldivmod+0xe>
|
|
800022c: 2800 cmp r0, #0
|
|
800022e: d002 beq.n 8000236 <__aeabi_uldivmod+0x16>
|
|
8000230: 2100 movs r1, #0
|
|
8000232: 43c9 mvns r1, r1
|
|
8000234: 1c08 adds r0, r1, #0
|
|
8000236: b407 push {r0, r1, r2}
|
|
8000238: 4802 ldr r0, [pc, #8] ; (8000244 <__aeabi_uldivmod+0x24>)
|
|
800023a: a102 add r1, pc, #8 ; (adr r1, 8000244 <__aeabi_uldivmod+0x24>)
|
|
800023c: 1840 adds r0, r0, r1
|
|
800023e: 9002 str r0, [sp, #8]
|
|
8000240: bd03 pop {r0, r1, pc}
|
|
8000242: 46c0 nop ; (mov r8, r8)
|
|
8000244: ffffffd9 .word 0xffffffd9
|
|
8000248: b403 push {r0, r1}
|
|
800024a: 4668 mov r0, sp
|
|
800024c: b501 push {r0, lr}
|
|
800024e: 9802 ldr r0, [sp, #8]
|
|
8000250: f000 f82e bl 80002b0 <__udivmoddi4>
|
|
8000254: 9b01 ldr r3, [sp, #4]
|
|
8000256: 469e mov lr, r3
|
|
8000258: b002 add sp, #8
|
|
800025a: bc0c pop {r2, r3}
|
|
800025c: 4770 bx lr
|
|
800025e: 46c0 nop ; (mov r8, r8)
|
|
|
|
08000260 <__aeabi_lmul>:
|
|
8000260: b5f0 push {r4, r5, r6, r7, lr}
|
|
8000262: 0415 lsls r5, r2, #16
|
|
8000264: 0c2d lsrs r5, r5, #16
|
|
8000266: 000f movs r7, r1
|
|
8000268: 0001 movs r1, r0
|
|
800026a: 002e movs r6, r5
|
|
800026c: 46c6 mov lr, r8
|
|
800026e: 4684 mov ip, r0
|
|
8000270: 0400 lsls r0, r0, #16
|
|
8000272: 0c14 lsrs r4, r2, #16
|
|
8000274: 0c00 lsrs r0, r0, #16
|
|
8000276: 0c09 lsrs r1, r1, #16
|
|
8000278: 4346 muls r6, r0
|
|
800027a: 434d muls r5, r1
|
|
800027c: 4360 muls r0, r4
|
|
800027e: 4361 muls r1, r4
|
|
8000280: 1940 adds r0, r0, r5
|
|
8000282: 0c34 lsrs r4, r6, #16
|
|
8000284: 1824 adds r4, r4, r0
|
|
8000286: b500 push {lr}
|
|
8000288: 42a5 cmp r5, r4
|
|
800028a: d903 bls.n 8000294 <__aeabi_lmul+0x34>
|
|
800028c: 2080 movs r0, #128 ; 0x80
|
|
800028e: 0240 lsls r0, r0, #9
|
|
8000290: 4680 mov r8, r0
|
|
8000292: 4441 add r1, r8
|
|
8000294: 0c25 lsrs r5, r4, #16
|
|
8000296: 186d adds r5, r5, r1
|
|
8000298: 4661 mov r1, ip
|
|
800029a: 4359 muls r1, r3
|
|
800029c: 437a muls r2, r7
|
|
800029e: 0430 lsls r0, r6, #16
|
|
80002a0: 1949 adds r1, r1, r5
|
|
80002a2: 0424 lsls r4, r4, #16
|
|
80002a4: 0c00 lsrs r0, r0, #16
|
|
80002a6: 1820 adds r0, r4, r0
|
|
80002a8: 1889 adds r1, r1, r2
|
|
80002aa: bc80 pop {r7}
|
|
80002ac: 46b8 mov r8, r7
|
|
80002ae: bdf0 pop {r4, r5, r6, r7, pc}
|
|
|
|
080002b0 <__udivmoddi4>:
|
|
80002b0: b5f0 push {r4, r5, r6, r7, lr}
|
|
80002b2: 4657 mov r7, sl
|
|
80002b4: 464e mov r6, r9
|
|
80002b6: 4645 mov r5, r8
|
|
80002b8: 46de mov lr, fp
|
|
80002ba: b5e0 push {r5, r6, r7, lr}
|
|
80002bc: 0004 movs r4, r0
|
|
80002be: 000d movs r5, r1
|
|
80002c0: 4692 mov sl, r2
|
|
80002c2: 4699 mov r9, r3
|
|
80002c4: b083 sub sp, #12
|
|
80002c6: 428b cmp r3, r1
|
|
80002c8: d830 bhi.n 800032c <__udivmoddi4+0x7c>
|
|
80002ca: d02d beq.n 8000328 <__udivmoddi4+0x78>
|
|
80002cc: 4649 mov r1, r9
|
|
80002ce: 4650 mov r0, sl
|
|
80002d0: f000 f8ba bl 8000448 <__clzdi2>
|
|
80002d4: 0029 movs r1, r5
|
|
80002d6: 0006 movs r6, r0
|
|
80002d8: 0020 movs r0, r4
|
|
80002da: f000 f8b5 bl 8000448 <__clzdi2>
|
|
80002de: 1a33 subs r3, r6, r0
|
|
80002e0: 4698 mov r8, r3
|
|
80002e2: 3b20 subs r3, #32
|
|
80002e4: 469b mov fp, r3
|
|
80002e6: d433 bmi.n 8000350 <__udivmoddi4+0xa0>
|
|
80002e8: 465a mov r2, fp
|
|
80002ea: 4653 mov r3, sl
|
|
80002ec: 4093 lsls r3, r2
|
|
80002ee: 4642 mov r2, r8
|
|
80002f0: 001f movs r7, r3
|
|
80002f2: 4653 mov r3, sl
|
|
80002f4: 4093 lsls r3, r2
|
|
80002f6: 001e movs r6, r3
|
|
80002f8: 42af cmp r7, r5
|
|
80002fa: d83a bhi.n 8000372 <__udivmoddi4+0xc2>
|
|
80002fc: 42af cmp r7, r5
|
|
80002fe: d100 bne.n 8000302 <__udivmoddi4+0x52>
|
|
8000300: e078 b.n 80003f4 <__udivmoddi4+0x144>
|
|
8000302: 465b mov r3, fp
|
|
8000304: 1ba4 subs r4, r4, r6
|
|
8000306: 41bd sbcs r5, r7
|
|
8000308: 2b00 cmp r3, #0
|
|
800030a: da00 bge.n 800030e <__udivmoddi4+0x5e>
|
|
800030c: e075 b.n 80003fa <__udivmoddi4+0x14a>
|
|
800030e: 2200 movs r2, #0
|
|
8000310: 2300 movs r3, #0
|
|
8000312: 9200 str r2, [sp, #0]
|
|
8000314: 9301 str r3, [sp, #4]
|
|
8000316: 2301 movs r3, #1
|
|
8000318: 465a mov r2, fp
|
|
800031a: 4093 lsls r3, r2
|
|
800031c: 9301 str r3, [sp, #4]
|
|
800031e: 2301 movs r3, #1
|
|
8000320: 4642 mov r2, r8
|
|
8000322: 4093 lsls r3, r2
|
|
8000324: 9300 str r3, [sp, #0]
|
|
8000326: e028 b.n 800037a <__udivmoddi4+0xca>
|
|
8000328: 4282 cmp r2, r0
|
|
800032a: d9cf bls.n 80002cc <__udivmoddi4+0x1c>
|
|
800032c: 2200 movs r2, #0
|
|
800032e: 2300 movs r3, #0
|
|
8000330: 9200 str r2, [sp, #0]
|
|
8000332: 9301 str r3, [sp, #4]
|
|
8000334: 9b0c ldr r3, [sp, #48] ; 0x30
|
|
8000336: 2b00 cmp r3, #0
|
|
8000338: d001 beq.n 800033e <__udivmoddi4+0x8e>
|
|
800033a: 601c str r4, [r3, #0]
|
|
800033c: 605d str r5, [r3, #4]
|
|
800033e: 9800 ldr r0, [sp, #0]
|
|
8000340: 9901 ldr r1, [sp, #4]
|
|
8000342: b003 add sp, #12
|
|
8000344: bcf0 pop {r4, r5, r6, r7}
|
|
8000346: 46bb mov fp, r7
|
|
8000348: 46b2 mov sl, r6
|
|
800034a: 46a9 mov r9, r5
|
|
800034c: 46a0 mov r8, r4
|
|
800034e: bdf0 pop {r4, r5, r6, r7, pc}
|
|
8000350: 4642 mov r2, r8
|
|
8000352: 2320 movs r3, #32
|
|
8000354: 1a9b subs r3, r3, r2
|
|
8000356: 4652 mov r2, sl
|
|
8000358: 40da lsrs r2, r3
|
|
800035a: 4641 mov r1, r8
|
|
800035c: 0013 movs r3, r2
|
|
800035e: 464a mov r2, r9
|
|
8000360: 408a lsls r2, r1
|
|
8000362: 0017 movs r7, r2
|
|
8000364: 4642 mov r2, r8
|
|
8000366: 431f orrs r7, r3
|
|
8000368: 4653 mov r3, sl
|
|
800036a: 4093 lsls r3, r2
|
|
800036c: 001e movs r6, r3
|
|
800036e: 42af cmp r7, r5
|
|
8000370: d9c4 bls.n 80002fc <__udivmoddi4+0x4c>
|
|
8000372: 2200 movs r2, #0
|
|
8000374: 2300 movs r3, #0
|
|
8000376: 9200 str r2, [sp, #0]
|
|
8000378: 9301 str r3, [sp, #4]
|
|
800037a: 4643 mov r3, r8
|
|
800037c: 2b00 cmp r3, #0
|
|
800037e: d0d9 beq.n 8000334 <__udivmoddi4+0x84>
|
|
8000380: 07fb lsls r3, r7, #31
|
|
8000382: 0872 lsrs r2, r6, #1
|
|
8000384: 431a orrs r2, r3
|
|
8000386: 4646 mov r6, r8
|
|
8000388: 087b lsrs r3, r7, #1
|
|
800038a: e00e b.n 80003aa <__udivmoddi4+0xfa>
|
|
800038c: 42ab cmp r3, r5
|
|
800038e: d101 bne.n 8000394 <__udivmoddi4+0xe4>
|
|
8000390: 42a2 cmp r2, r4
|
|
8000392: d80c bhi.n 80003ae <__udivmoddi4+0xfe>
|
|
8000394: 1aa4 subs r4, r4, r2
|
|
8000396: 419d sbcs r5, r3
|
|
8000398: 2001 movs r0, #1
|
|
800039a: 1924 adds r4, r4, r4
|
|
800039c: 416d adcs r5, r5
|
|
800039e: 2100 movs r1, #0
|
|
80003a0: 3e01 subs r6, #1
|
|
80003a2: 1824 adds r4, r4, r0
|
|
80003a4: 414d adcs r5, r1
|
|
80003a6: 2e00 cmp r6, #0
|
|
80003a8: d006 beq.n 80003b8 <__udivmoddi4+0x108>
|
|
80003aa: 42ab cmp r3, r5
|
|
80003ac: d9ee bls.n 800038c <__udivmoddi4+0xdc>
|
|
80003ae: 3e01 subs r6, #1
|
|
80003b0: 1924 adds r4, r4, r4
|
|
80003b2: 416d adcs r5, r5
|
|
80003b4: 2e00 cmp r6, #0
|
|
80003b6: d1f8 bne.n 80003aa <__udivmoddi4+0xfa>
|
|
80003b8: 9800 ldr r0, [sp, #0]
|
|
80003ba: 9901 ldr r1, [sp, #4]
|
|
80003bc: 465b mov r3, fp
|
|
80003be: 1900 adds r0, r0, r4
|
|
80003c0: 4169 adcs r1, r5
|
|
80003c2: 2b00 cmp r3, #0
|
|
80003c4: db24 blt.n 8000410 <__udivmoddi4+0x160>
|
|
80003c6: 002b movs r3, r5
|
|
80003c8: 465a mov r2, fp
|
|
80003ca: 4644 mov r4, r8
|
|
80003cc: 40d3 lsrs r3, r2
|
|
80003ce: 002a movs r2, r5
|
|
80003d0: 40e2 lsrs r2, r4
|
|
80003d2: 001c movs r4, r3
|
|
80003d4: 465b mov r3, fp
|
|
80003d6: 0015 movs r5, r2
|
|
80003d8: 2b00 cmp r3, #0
|
|
80003da: db2a blt.n 8000432 <__udivmoddi4+0x182>
|
|
80003dc: 0026 movs r6, r4
|
|
80003de: 409e lsls r6, r3
|
|
80003e0: 0033 movs r3, r6
|
|
80003e2: 0026 movs r6, r4
|
|
80003e4: 4647 mov r7, r8
|
|
80003e6: 40be lsls r6, r7
|
|
80003e8: 0032 movs r2, r6
|
|
80003ea: 1a80 subs r0, r0, r2
|
|
80003ec: 4199 sbcs r1, r3
|
|
80003ee: 9000 str r0, [sp, #0]
|
|
80003f0: 9101 str r1, [sp, #4]
|
|
80003f2: e79f b.n 8000334 <__udivmoddi4+0x84>
|
|
80003f4: 42a3 cmp r3, r4
|
|
80003f6: d8bc bhi.n 8000372 <__udivmoddi4+0xc2>
|
|
80003f8: e783 b.n 8000302 <__udivmoddi4+0x52>
|
|
80003fa: 4642 mov r2, r8
|
|
80003fc: 2320 movs r3, #32
|
|
80003fe: 2100 movs r1, #0
|
|
8000400: 1a9b subs r3, r3, r2
|
|
8000402: 2200 movs r2, #0
|
|
8000404: 9100 str r1, [sp, #0]
|
|
8000406: 9201 str r2, [sp, #4]
|
|
8000408: 2201 movs r2, #1
|
|
800040a: 40da lsrs r2, r3
|
|
800040c: 9201 str r2, [sp, #4]
|
|
800040e: e786 b.n 800031e <__udivmoddi4+0x6e>
|
|
8000410: 4642 mov r2, r8
|
|
8000412: 2320 movs r3, #32
|
|
8000414: 1a9b subs r3, r3, r2
|
|
8000416: 002a movs r2, r5
|
|
8000418: 4646 mov r6, r8
|
|
800041a: 409a lsls r2, r3
|
|
800041c: 0023 movs r3, r4
|
|
800041e: 40f3 lsrs r3, r6
|
|
8000420: 4644 mov r4, r8
|
|
8000422: 4313 orrs r3, r2
|
|
8000424: 002a movs r2, r5
|
|
8000426: 40e2 lsrs r2, r4
|
|
8000428: 001c movs r4, r3
|
|
800042a: 465b mov r3, fp
|
|
800042c: 0015 movs r5, r2
|
|
800042e: 2b00 cmp r3, #0
|
|
8000430: dad4 bge.n 80003dc <__udivmoddi4+0x12c>
|
|
8000432: 4642 mov r2, r8
|
|
8000434: 002f movs r7, r5
|
|
8000436: 2320 movs r3, #32
|
|
8000438: 0026 movs r6, r4
|
|
800043a: 4097 lsls r7, r2
|
|
800043c: 1a9b subs r3, r3, r2
|
|
800043e: 40de lsrs r6, r3
|
|
8000440: 003b movs r3, r7
|
|
8000442: 4333 orrs r3, r6
|
|
8000444: e7cd b.n 80003e2 <__udivmoddi4+0x132>
|
|
8000446: 46c0 nop ; (mov r8, r8)
|
|
|
|
08000448 <__clzdi2>:
|
|
8000448: b510 push {r4, lr}
|
|
800044a: 2900 cmp r1, #0
|
|
800044c: d103 bne.n 8000456 <__clzdi2+0xe>
|
|
800044e: f000 f807 bl 8000460 <__clzsi2>
|
|
8000452: 3020 adds r0, #32
|
|
8000454: e002 b.n 800045c <__clzdi2+0x14>
|
|
8000456: 1c08 adds r0, r1, #0
|
|
8000458: f000 f802 bl 8000460 <__clzsi2>
|
|
800045c: bd10 pop {r4, pc}
|
|
800045e: 46c0 nop ; (mov r8, r8)
|
|
|
|
08000460 <__clzsi2>:
|
|
8000460: 211c movs r1, #28
|
|
8000462: 2301 movs r3, #1
|
|
8000464: 041b lsls r3, r3, #16
|
|
8000466: 4298 cmp r0, r3
|
|
8000468: d301 bcc.n 800046e <__clzsi2+0xe>
|
|
800046a: 0c00 lsrs r0, r0, #16
|
|
800046c: 3910 subs r1, #16
|
|
800046e: 0a1b lsrs r3, r3, #8
|
|
8000470: 4298 cmp r0, r3
|
|
8000472: d301 bcc.n 8000478 <__clzsi2+0x18>
|
|
8000474: 0a00 lsrs r0, r0, #8
|
|
8000476: 3908 subs r1, #8
|
|
8000478: 091b lsrs r3, r3, #4
|
|
800047a: 4298 cmp r0, r3
|
|
800047c: d301 bcc.n 8000482 <__clzsi2+0x22>
|
|
800047e: 0900 lsrs r0, r0, #4
|
|
8000480: 3904 subs r1, #4
|
|
8000482: a202 add r2, pc, #8 ; (adr r2, 800048c <__clzsi2+0x2c>)
|
|
8000484: 5c10 ldrb r0, [r2, r0]
|
|
8000486: 1840 adds r0, r0, r1
|
|
8000488: 4770 bx lr
|
|
800048a: 46c0 nop ; (mov r8, r8)
|
|
800048c: 02020304 .word 0x02020304
|
|
8000490: 01010101 .word 0x01010101
|
|
...
|
|
|
|
0800049c <PreSleepProcessing>:
|
|
|
|
/* USER CODE END FunctionPrototypes */
|
|
|
|
/* USER CODE BEGIN PREPOSTSLEEP */
|
|
__weak void PreSleepProcessing(uint32_t *ulExpectedIdleTime)
|
|
{
|
|
800049c: b580 push {r7, lr}
|
|
800049e: b082 sub sp, #8
|
|
80004a0: af00 add r7, sp, #0
|
|
80004a2: 6078 str r0, [r7, #4]
|
|
/* place for user code */
|
|
}
|
|
80004a4: 46c0 nop ; (mov r8, r8)
|
|
80004a6: 46bd mov sp, r7
|
|
80004a8: b002 add sp, #8
|
|
80004aa: bd80 pop {r7, pc}
|
|
|
|
080004ac <PostSleepProcessing>:
|
|
|
|
__weak void PostSleepProcessing(uint32_t *ulExpectedIdleTime)
|
|
{
|
|
80004ac: b580 push {r7, lr}
|
|
80004ae: b082 sub sp, #8
|
|
80004b0: af00 add r7, sp, #0
|
|
80004b2: 6078 str r0, [r7, #4]
|
|
/* place for user code */
|
|
}
|
|
80004b4: 46c0 nop ; (mov r8, r8)
|
|
80004b6: 46bd mov sp, r7
|
|
80004b8: b002 add sp, #8
|
|
80004ba: bd80 pop {r7, pc}
|
|
|
|
080004bc <LEDS_Init>:
|
|
StackType_t xStackLeds[ STACK_SIZE ];
|
|
TaskHandle_t xHandleLeds = NULL;
|
|
|
|
void LEDS_AnimationThread(void* params);
|
|
|
|
void LEDS_Init(void) {
|
|
80004bc: b580 push {r7, lr}
|
|
80004be: b084 sub sp, #16
|
|
80004c0: af04 add r7, sp, #16
|
|
LEDS_EteintVerte();
|
|
80004c2: 2380 movs r3, #128 ; 0x80
|
|
80004c4: 01db lsls r3, r3, #7
|
|
80004c6: 4816 ldr r0, [pc, #88] ; (8000520 <LEDS_Init+0x64>)
|
|
80004c8: 2200 movs r2, #0
|
|
80004ca: 0019 movs r1, r3
|
|
80004cc: f002 f818 bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_EteintJaune();
|
|
80004d0: 2380 movs r3, #128 ; 0x80
|
|
80004d2: 019b lsls r3, r3, #6
|
|
80004d4: 4812 ldr r0, [pc, #72] ; (8000520 <LEDS_Init+0x64>)
|
|
80004d6: 2200 movs r2, #0
|
|
80004d8: 0019 movs r1, r3
|
|
80004da: f002 f811 bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_EteintRouge();
|
|
80004de: 2380 movs r3, #128 ; 0x80
|
|
80004e0: 015b lsls r3, r3, #5
|
|
80004e2: 480f ldr r0, [pc, #60] ; (8000520 <LEDS_Init+0x64>)
|
|
80004e4: 2200 movs r2, #0
|
|
80004e6: 0019 movs r1, r3
|
|
80004e8: f002 f80a bl 8002500 <HAL_GPIO_WritePin>
|
|
|
|
LEDS_Animation=leds_off;
|
|
80004ec: 4b0d ldr r3, [pc, #52] ; (8000524 <LEDS_Init+0x68>)
|
|
80004ee: 2200 movs r2, #0
|
|
80004f0: 701a strb r2, [r3, #0]
|
|
|
|
/* Mailbox is created in messages.c */
|
|
|
|
/* Create the task without using any dynamic memory allocation. */
|
|
xHandleLeds = xTaskCreateStatic(
|
|
80004f2: 490d ldr r1, [pc, #52] ; (8000528 <LEDS_Init+0x6c>)
|
|
80004f4: 480d ldr r0, [pc, #52] ; (800052c <LEDS_Init+0x70>)
|
|
80004f6: 4b0e ldr r3, [pc, #56] ; (8000530 <LEDS_Init+0x74>)
|
|
80004f8: 9302 str r3, [sp, #8]
|
|
80004fa: 4b0e ldr r3, [pc, #56] ; (8000534 <LEDS_Init+0x78>)
|
|
80004fc: 9301 str r3, [sp, #4]
|
|
80004fe: 2333 movs r3, #51 ; 0x33
|
|
8000500: 9300 str r3, [sp, #0]
|
|
8000502: 2300 movs r3, #0
|
|
8000504: 2264 movs r2, #100 ; 0x64
|
|
8000506: f005 fae4 bl 8005ad2 <xTaskCreateStatic>
|
|
800050a: 0002 movs r2, r0
|
|
800050c: 4b0a ldr r3, [pc, #40] ; (8000538 <LEDS_Init+0x7c>)
|
|
800050e: 601a str r2, [r3, #0]
|
|
STACK_SIZE, /* Number of indexes in the xStack array. */
|
|
NULL, /* Parameter passed into the task. */
|
|
PriorityLeds,/* Priority at which the task is created. */
|
|
xStackLeds, /* Array to use as the task's stack. */
|
|
&xTaskLeds); /* Variable to hold the task's data structure. */
|
|
vTaskResume(xHandleLeds);
|
|
8000510: 4b09 ldr r3, [pc, #36] ; (8000538 <LEDS_Init+0x7c>)
|
|
8000512: 681b ldr r3, [r3, #0]
|
|
8000514: 0018 movs r0, r3
|
|
8000516: f005 fcaf bl 8005e78 <vTaskResume>
|
|
}
|
|
800051a: 46c0 nop ; (mov r8, r8)
|
|
800051c: 46bd mov sp, r7
|
|
800051e: bd80 pop {r7, pc}
|
|
8000520: 50000400 .word 0x50000400
|
|
8000524: 2000153c .word 0x2000153c
|
|
8000528: 080077e8 .word 0x080077e8
|
|
800052c: 0800053d .word 0x0800053d
|
|
8000530: 200016d4 .word 0x200016d4
|
|
8000534: 20001540 .word 0x20001540
|
|
8000538: 2000002c .word 0x2000002c
|
|
|
|
0800053c <LEDS_AnimationThread>:
|
|
|
|
void LEDS_RegleAnimation(LEDS_State etat) {
|
|
LEDS_Animation=etat;
|
|
}
|
|
|
|
void LEDS_AnimationThread(void* params) {
|
|
800053c: b5b0 push {r4, r5, r7, lr}
|
|
800053e: b086 sub sp, #24
|
|
8000540: af00 add r7, sp, #0
|
|
8000542: 6078 str r0, [r7, #4]
|
|
MESSAGE_Typedef msg;
|
|
uint8_t cnt=0;
|
|
8000544: 2317 movs r3, #23
|
|
8000546: 18fb adds r3, r7, r3
|
|
8000548: 2200 movs r2, #0
|
|
800054a: 701a strb r2, [r3, #0]
|
|
|
|
while (1) {
|
|
vTaskDelay(pdMS_TO_TICKS(100));
|
|
800054c: 200a movs r0, #10
|
|
800054e: f005 fc47 bl 8005de0 <vTaskDelay>
|
|
|
|
msg = MESSAGE_ReadMailboxNoDelay(LEDS_Mailbox);
|
|
8000552: 4bdc ldr r3, [pc, #880] ; (80008c4 <LEDS_AnimationThread+0x388>)
|
|
8000554: 681a ldr r2, [r3, #0]
|
|
8000556: 2408 movs r4, #8
|
|
8000558: 193b adds r3, r7, r4
|
|
800055a: 0011 movs r1, r2
|
|
800055c: 0018 movs r0, r3
|
|
800055e: f000 fda7 bl 80010b0 <MESSAGE_ReadMailboxNoDelay>
|
|
|
|
cnt++;
|
|
8000562: 2517 movs r5, #23
|
|
8000564: 197b adds r3, r7, r5
|
|
8000566: 781a ldrb r2, [r3, #0]
|
|
8000568: 197b adds r3, r7, r5
|
|
800056a: 3201 adds r2, #1
|
|
800056c: 701a strb r2, [r3, #0]
|
|
|
|
if (msg.id == MSG_ID_LED_ETAT) { // Si c'est bien un message de changemnet d'etat LEDS
|
|
800056e: 193b adds r3, r7, r4
|
|
8000570: 881b ldrh r3, [r3, #0]
|
|
8000572: 2b00 cmp r3, #0
|
|
8000574: d126 bne.n 80005c4 <LEDS_AnimationThread+0x88>
|
|
LEDS_Animation = *((LEDS_State*)msg.data);
|
|
8000576: 193b adds r3, r7, r4
|
|
8000578: 689b ldr r3, [r3, #8]
|
|
800057a: 781a ldrb r2, [r3, #0]
|
|
800057c: 4bd2 ldr r3, [pc, #840] ; (80008c8 <LEDS_AnimationThread+0x38c>)
|
|
800057e: 701a strb r2, [r3, #0]
|
|
|
|
if (LEDS_Animation != LEDS_AnimationAncien) { // si le nouvel etat est different de l'ancien
|
|
8000580: 4bd1 ldr r3, [pc, #836] ; (80008c8 <LEDS_AnimationThread+0x38c>)
|
|
8000582: 781a ldrb r2, [r3, #0]
|
|
8000584: 4bd1 ldr r3, [pc, #836] ; (80008cc <LEDS_AnimationThread+0x390>)
|
|
8000586: 781b ldrb r3, [r3, #0]
|
|
8000588: 429a cmp r2, r3
|
|
800058a: d01b beq.n 80005c4 <LEDS_AnimationThread+0x88>
|
|
// dans ce cas, on eteint les leds pour repartir sur une base saine
|
|
LEDS_AnimationAncien = LEDS_Animation;
|
|
800058c: 4bce ldr r3, [pc, #824] ; (80008c8 <LEDS_AnimationThread+0x38c>)
|
|
800058e: 781a ldrb r2, [r3, #0]
|
|
8000590: 4bce ldr r3, [pc, #824] ; (80008cc <LEDS_AnimationThread+0x390>)
|
|
8000592: 701a strb r2, [r3, #0]
|
|
|
|
LEDS_EteintVerte();
|
|
8000594: 2380 movs r3, #128 ; 0x80
|
|
8000596: 01db lsls r3, r3, #7
|
|
8000598: 48cd ldr r0, [pc, #820] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
800059a: 2200 movs r2, #0
|
|
800059c: 0019 movs r1, r3
|
|
800059e: f001 ffaf bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_EteintJaune();
|
|
80005a2: 2380 movs r3, #128 ; 0x80
|
|
80005a4: 019b lsls r3, r3, #6
|
|
80005a6: 48ca ldr r0, [pc, #808] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
80005a8: 2200 movs r2, #0
|
|
80005aa: 0019 movs r1, r3
|
|
80005ac: f001 ffa8 bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_EteintRouge();
|
|
80005b0: 2380 movs r3, #128 ; 0x80
|
|
80005b2: 015b lsls r3, r3, #5
|
|
80005b4: 48c6 ldr r0, [pc, #792] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
80005b6: 2200 movs r2, #0
|
|
80005b8: 0019 movs r1, r3
|
|
80005ba: f001 ffa1 bl 8002500 <HAL_GPIO_WritePin>
|
|
cnt=0;
|
|
80005be: 197b adds r3, r7, r5
|
|
80005c0: 2200 movs r2, #0
|
|
80005c2: 701a strb r2, [r3, #0]
|
|
}
|
|
}
|
|
|
|
switch (LEDS_Animation) {
|
|
80005c4: 4bc0 ldr r3, [pc, #768] ; (80008c8 <LEDS_AnimationThread+0x38c>)
|
|
80005c6: 781b ldrb r3, [r3, #0]
|
|
80005c8: 2b10 cmp r3, #16
|
|
80005ca: d900 bls.n 80005ce <LEDS_AnimationThread+0x92>
|
|
80005cc: e1ec b.n 80009a8 <LEDS_AnimationThread+0x46c>
|
|
80005ce: 009a lsls r2, r3, #2
|
|
80005d0: 4bc0 ldr r3, [pc, #768] ; (80008d4 <LEDS_AnimationThread+0x398>)
|
|
80005d2: 18d3 adds r3, r2, r3
|
|
80005d4: 681b ldr r3, [r3, #0]
|
|
80005d6: 469f mov pc, r3
|
|
case leds_off:
|
|
LEDS_EteintVerte();
|
|
80005d8: 2380 movs r3, #128 ; 0x80
|
|
80005da: 01db lsls r3, r3, #7
|
|
80005dc: 48bc ldr r0, [pc, #752] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
80005de: 2200 movs r2, #0
|
|
80005e0: 0019 movs r1, r3
|
|
80005e2: f001 ff8d bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_EteintJaune();
|
|
80005e6: 2380 movs r3, #128 ; 0x80
|
|
80005e8: 019b lsls r3, r3, #6
|
|
80005ea: 48b9 ldr r0, [pc, #740] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
80005ec: 2200 movs r2, #0
|
|
80005ee: 0019 movs r1, r3
|
|
80005f0: f001 ff86 bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_EteintRouge();
|
|
80005f4: 2380 movs r3, #128 ; 0x80
|
|
80005f6: 015b lsls r3, r3, #5
|
|
80005f8: 48b5 ldr r0, [pc, #724] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
80005fa: 2200 movs r2, #0
|
|
80005fc: 0019 movs r1, r3
|
|
80005fe: f001 ff7f bl 8002500 <HAL_GPIO_WritePin>
|
|
break;
|
|
8000602: e1d2 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
case leds_idle:
|
|
if (cnt<5)
|
|
8000604: 2317 movs r3, #23
|
|
8000606: 18fb adds r3, r7, r3
|
|
8000608: 781b ldrb r3, [r3, #0]
|
|
800060a: 2b04 cmp r3, #4
|
|
800060c: d807 bhi.n 800061e <LEDS_AnimationThread+0xe2>
|
|
LEDS_AllumeVerte();
|
|
800060e: 2380 movs r3, #128 ; 0x80
|
|
8000610: 01db lsls r3, r3, #7
|
|
8000612: 48af ldr r0, [pc, #700] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
8000614: 2201 movs r2, #1
|
|
8000616: 0019 movs r1, r3
|
|
8000618: f001 ff72 bl 8002500 <HAL_GPIO_WritePin>
|
|
else if (cnt<10)
|
|
LEDS_EteintVerte();
|
|
else
|
|
cnt=0;
|
|
break;
|
|
800061c: e1c5 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
else if (cnt<10)
|
|
800061e: 2317 movs r3, #23
|
|
8000620: 18fb adds r3, r7, r3
|
|
8000622: 781b ldrb r3, [r3, #0]
|
|
8000624: 2b09 cmp r3, #9
|
|
8000626: d807 bhi.n 8000638 <LEDS_AnimationThread+0xfc>
|
|
LEDS_EteintVerte();
|
|
8000628: 2380 movs r3, #128 ; 0x80
|
|
800062a: 01db lsls r3, r3, #7
|
|
800062c: 48a8 ldr r0, [pc, #672] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
800062e: 2200 movs r2, #0
|
|
8000630: 0019 movs r1, r3
|
|
8000632: f001 ff65 bl 8002500 <HAL_GPIO_WritePin>
|
|
break;
|
|
8000636: e1b8 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
cnt=0;
|
|
8000638: 2317 movs r3, #23
|
|
800063a: 18fb adds r3, r7, r3
|
|
800063c: 2200 movs r2, #0
|
|
800063e: 701a strb r2, [r3, #0]
|
|
break;
|
|
8000640: e1b3 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
case leds_connecte:
|
|
LEDS_AllumeVerte();
|
|
8000642: 2380 movs r3, #128 ; 0x80
|
|
8000644: 01db lsls r3, r3, #7
|
|
8000646: 48a2 ldr r0, [pc, #648] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
8000648: 2201 movs r2, #1
|
|
800064a: 0019 movs r1, r3
|
|
800064c: f001 ff58 bl 8002500 <HAL_GPIO_WritePin>
|
|
break;
|
|
8000650: e1ab b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
case leds_watchdog_expire:
|
|
if (cnt<5)
|
|
8000652: 2317 movs r3, #23
|
|
8000654: 18fb adds r3, r7, r3
|
|
8000656: 781b ldrb r3, [r3, #0]
|
|
8000658: 2b04 cmp r3, #4
|
|
800065a: d807 bhi.n 800066c <LEDS_AnimationThread+0x130>
|
|
LEDS_AllumeRouge();
|
|
800065c: 2380 movs r3, #128 ; 0x80
|
|
800065e: 015b lsls r3, r3, #5
|
|
8000660: 489b ldr r0, [pc, #620] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
8000662: 2201 movs r2, #1
|
|
8000664: 0019 movs r1, r3
|
|
8000666: f001 ff4b bl 8002500 <HAL_GPIO_WritePin>
|
|
else if (cnt<10)
|
|
LEDS_EteintRouge();
|
|
else
|
|
cnt=0;
|
|
break;
|
|
800066a: e19e b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
else if (cnt<10)
|
|
800066c: 2317 movs r3, #23
|
|
800066e: 18fb adds r3, r7, r3
|
|
8000670: 781b ldrb r3, [r3, #0]
|
|
8000672: 2b09 cmp r3, #9
|
|
8000674: d807 bhi.n 8000686 <LEDS_AnimationThread+0x14a>
|
|
LEDS_EteintRouge();
|
|
8000676: 2380 movs r3, #128 ; 0x80
|
|
8000678: 015b lsls r3, r3, #5
|
|
800067a: 4895 ldr r0, [pc, #596] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
800067c: 2200 movs r2, #0
|
|
800067e: 0019 movs r1, r3
|
|
8000680: f001 ff3e bl 8002500 <HAL_GPIO_WritePin>
|
|
break;
|
|
8000684: e191 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
cnt=0;
|
|
8000686: 2317 movs r3, #23
|
|
8000688: 18fb adds r3, r7, r3
|
|
800068a: 2200 movs r2, #0
|
|
800068c: 701a strb r2, [r3, #0]
|
|
break;
|
|
800068e: e18c b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
case leds_niveau_bat_0:
|
|
if (!(cnt%2))
|
|
8000690: 2317 movs r3, #23
|
|
8000692: 18fb adds r3, r7, r3
|
|
8000694: 781b ldrb r3, [r3, #0]
|
|
8000696: 2201 movs r2, #1
|
|
8000698: 4013 ands r3, r2
|
|
800069a: b2db uxtb r3, r3
|
|
800069c: 2b00 cmp r3, #0
|
|
800069e: d107 bne.n 80006b0 <LEDS_AnimationThread+0x174>
|
|
LEDS_AllumeRouge();
|
|
80006a0: 2380 movs r3, #128 ; 0x80
|
|
80006a2: 015b lsls r3, r3, #5
|
|
80006a4: 488a ldr r0, [pc, #552] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
80006a6: 2201 movs r2, #1
|
|
80006a8: 0019 movs r1, r3
|
|
80006aa: f001 ff29 bl 8002500 <HAL_GPIO_WritePin>
|
|
else
|
|
LEDS_EteintRouge();
|
|
break;
|
|
80006ae: e17c b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
LEDS_EteintRouge();
|
|
80006b0: 2380 movs r3, #128 ; 0x80
|
|
80006b2: 015b lsls r3, r3, #5
|
|
80006b4: 4886 ldr r0, [pc, #536] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
80006b6: 2200 movs r2, #0
|
|
80006b8: 0019 movs r1, r3
|
|
80006ba: f001 ff21 bl 8002500 <HAL_GPIO_WritePin>
|
|
break;
|
|
80006be: e174 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
case leds_niveau_bat_1:
|
|
LEDS_AllumeRouge();
|
|
80006c0: 2380 movs r3, #128 ; 0x80
|
|
80006c2: 015b lsls r3, r3, #5
|
|
80006c4: 4882 ldr r0, [pc, #520] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
80006c6: 2201 movs r2, #1
|
|
80006c8: 0019 movs r1, r3
|
|
80006ca: f001 ff19 bl 8002500 <HAL_GPIO_WritePin>
|
|
break;
|
|
80006ce: e16c b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
case leds_niveau_bat_2:
|
|
LEDS_AllumeRouge();
|
|
80006d0: 2380 movs r3, #128 ; 0x80
|
|
80006d2: 015b lsls r3, r3, #5
|
|
80006d4: 487e ldr r0, [pc, #504] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
80006d6: 2201 movs r2, #1
|
|
80006d8: 0019 movs r1, r3
|
|
80006da: f001 ff11 bl 8002500 <HAL_GPIO_WritePin>
|
|
|
|
if (cnt<3)
|
|
80006de: 2317 movs r3, #23
|
|
80006e0: 18fb adds r3, r7, r3
|
|
80006e2: 781b ldrb r3, [r3, #0]
|
|
80006e4: 2b02 cmp r3, #2
|
|
80006e6: d807 bhi.n 80006f8 <LEDS_AnimationThread+0x1bc>
|
|
LEDS_AllumeJaune();
|
|
80006e8: 2380 movs r3, #128 ; 0x80
|
|
80006ea: 019b lsls r3, r3, #6
|
|
80006ec: 4878 ldr r0, [pc, #480] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
80006ee: 2201 movs r2, #1
|
|
80006f0: 0019 movs r1, r3
|
|
80006f2: f001 ff05 bl 8002500 <HAL_GPIO_WritePin>
|
|
else if (cnt<6)
|
|
LEDS_EteintJaune();
|
|
else
|
|
cnt=0;
|
|
break;
|
|
80006f6: e158 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
else if (cnt<6)
|
|
80006f8: 2317 movs r3, #23
|
|
80006fa: 18fb adds r3, r7, r3
|
|
80006fc: 781b ldrb r3, [r3, #0]
|
|
80006fe: 2b05 cmp r3, #5
|
|
8000700: d807 bhi.n 8000712 <LEDS_AnimationThread+0x1d6>
|
|
LEDS_EteintJaune();
|
|
8000702: 2380 movs r3, #128 ; 0x80
|
|
8000704: 019b lsls r3, r3, #6
|
|
8000706: 4872 ldr r0, [pc, #456] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
8000708: 2200 movs r2, #0
|
|
800070a: 0019 movs r1, r3
|
|
800070c: f001 fef8 bl 8002500 <HAL_GPIO_WritePin>
|
|
break;
|
|
8000710: e14b b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
cnt=0;
|
|
8000712: 2317 movs r3, #23
|
|
8000714: 18fb adds r3, r7, r3
|
|
8000716: 2200 movs r2, #0
|
|
8000718: 701a strb r2, [r3, #0]
|
|
break;
|
|
800071a: e146 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
case leds_niveau_bat_3:
|
|
LEDS_AllumeRouge();
|
|
800071c: 2380 movs r3, #128 ; 0x80
|
|
800071e: 015b lsls r3, r3, #5
|
|
8000720: 486b ldr r0, [pc, #428] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
8000722: 2201 movs r2, #1
|
|
8000724: 0019 movs r1, r3
|
|
8000726: f001 feeb bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_AllumeJaune();
|
|
800072a: 2380 movs r3, #128 ; 0x80
|
|
800072c: 019b lsls r3, r3, #6
|
|
800072e: 4868 ldr r0, [pc, #416] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
8000730: 2201 movs r2, #1
|
|
8000732: 0019 movs r1, r3
|
|
8000734: f001 fee4 bl 8002500 <HAL_GPIO_WritePin>
|
|
break;
|
|
8000738: e137 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
case leds_niveau_bat_4:
|
|
LEDS_AllumeRouge();
|
|
800073a: 2380 movs r3, #128 ; 0x80
|
|
800073c: 015b lsls r3, r3, #5
|
|
800073e: 4864 ldr r0, [pc, #400] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
8000740: 2201 movs r2, #1
|
|
8000742: 0019 movs r1, r3
|
|
8000744: f001 fedc bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_AllumeJaune();
|
|
8000748: 2380 movs r3, #128 ; 0x80
|
|
800074a: 019b lsls r3, r3, #6
|
|
800074c: 4860 ldr r0, [pc, #384] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
800074e: 2201 movs r2, #1
|
|
8000750: 0019 movs r1, r3
|
|
8000752: f001 fed5 bl 8002500 <HAL_GPIO_WritePin>
|
|
|
|
if (cnt<3)
|
|
8000756: 2317 movs r3, #23
|
|
8000758: 18fb adds r3, r7, r3
|
|
800075a: 781b ldrb r3, [r3, #0]
|
|
800075c: 2b02 cmp r3, #2
|
|
800075e: d807 bhi.n 8000770 <LEDS_AnimationThread+0x234>
|
|
LEDS_AllumeVerte();
|
|
8000760: 2380 movs r3, #128 ; 0x80
|
|
8000762: 01db lsls r3, r3, #7
|
|
8000764: 485a ldr r0, [pc, #360] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
8000766: 2201 movs r2, #1
|
|
8000768: 0019 movs r1, r3
|
|
800076a: f001 fec9 bl 8002500 <HAL_GPIO_WritePin>
|
|
else if (cnt<6)
|
|
LEDS_EteintVerte();
|
|
else
|
|
cnt=0;
|
|
break;
|
|
800076e: e11c b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
else if (cnt<6)
|
|
8000770: 2317 movs r3, #23
|
|
8000772: 18fb adds r3, r7, r3
|
|
8000774: 781b ldrb r3, [r3, #0]
|
|
8000776: 2b05 cmp r3, #5
|
|
8000778: d807 bhi.n 800078a <LEDS_AnimationThread+0x24e>
|
|
LEDS_EteintVerte();
|
|
800077a: 2380 movs r3, #128 ; 0x80
|
|
800077c: 01db lsls r3, r3, #7
|
|
800077e: 4854 ldr r0, [pc, #336] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
8000780: 2200 movs r2, #0
|
|
8000782: 0019 movs r1, r3
|
|
8000784: f001 febc bl 8002500 <HAL_GPIO_WritePin>
|
|
break;
|
|
8000788: e10f b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
cnt=0;
|
|
800078a: 2317 movs r3, #23
|
|
800078c: 18fb adds r3, r7, r3
|
|
800078e: 2200 movs r2, #0
|
|
8000790: 701a strb r2, [r3, #0]
|
|
break;
|
|
8000792: e10a b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
case leds_niveau_bat_5:
|
|
LEDS_AllumeRouge();
|
|
8000794: 2380 movs r3, #128 ; 0x80
|
|
8000796: 015b lsls r3, r3, #5
|
|
8000798: 484d ldr r0, [pc, #308] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
800079a: 2201 movs r2, #1
|
|
800079c: 0019 movs r1, r3
|
|
800079e: f001 feaf bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_AllumeJaune();
|
|
80007a2: 2380 movs r3, #128 ; 0x80
|
|
80007a4: 019b lsls r3, r3, #6
|
|
80007a6: 484a ldr r0, [pc, #296] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
80007a8: 2201 movs r2, #1
|
|
80007aa: 0019 movs r1, r3
|
|
80007ac: f001 fea8 bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_AllumeVerte();
|
|
80007b0: 2380 movs r3, #128 ; 0x80
|
|
80007b2: 01db lsls r3, r3, #7
|
|
80007b4: 4846 ldr r0, [pc, #280] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
80007b6: 2201 movs r2, #1
|
|
80007b8: 0019 movs r1, r3
|
|
80007ba: f001 fea1 bl 8002500 <HAL_GPIO_WritePin>
|
|
break;
|
|
80007be: e0f4 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
case leds_charge_bat_0:
|
|
case leds_charge_bat_1:
|
|
if (cnt<3)
|
|
80007c0: 2317 movs r3, #23
|
|
80007c2: 18fb adds r3, r7, r3
|
|
80007c4: 781b ldrb r3, [r3, #0]
|
|
80007c6: 2b02 cmp r3, #2
|
|
80007c8: d807 bhi.n 80007da <LEDS_AnimationThread+0x29e>
|
|
LEDS_AllumeRouge();
|
|
80007ca: 2380 movs r3, #128 ; 0x80
|
|
80007cc: 015b lsls r3, r3, #5
|
|
80007ce: 4840 ldr r0, [pc, #256] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
80007d0: 2201 movs r2, #1
|
|
80007d2: 0019 movs r1, r3
|
|
80007d4: f001 fe94 bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_EteintVerte();
|
|
LEDS_EteintJaune();
|
|
LEDS_EteintRouge();
|
|
} else
|
|
cnt=0;
|
|
break;
|
|
80007d8: e0e7 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
else if (cnt<6)
|
|
80007da: 2317 movs r3, #23
|
|
80007dc: 18fb adds r3, r7, r3
|
|
80007de: 781b ldrb r3, [r3, #0]
|
|
80007e0: 2b05 cmp r3, #5
|
|
80007e2: d807 bhi.n 80007f4 <LEDS_AnimationThread+0x2b8>
|
|
LEDS_AllumeJaune();
|
|
80007e4: 2380 movs r3, #128 ; 0x80
|
|
80007e6: 019b lsls r3, r3, #6
|
|
80007e8: 4839 ldr r0, [pc, #228] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
80007ea: 2201 movs r2, #1
|
|
80007ec: 0019 movs r1, r3
|
|
80007ee: f001 fe87 bl 8002500 <HAL_GPIO_WritePin>
|
|
break;
|
|
80007f2: e0da b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
else if (cnt<9)
|
|
80007f4: 2317 movs r3, #23
|
|
80007f6: 18fb adds r3, r7, r3
|
|
80007f8: 781b ldrb r3, [r3, #0]
|
|
80007fa: 2b08 cmp r3, #8
|
|
80007fc: d807 bhi.n 800080e <LEDS_AnimationThread+0x2d2>
|
|
LEDS_AllumeVerte();
|
|
80007fe: 2380 movs r3, #128 ; 0x80
|
|
8000800: 01db lsls r3, r3, #7
|
|
8000802: 4833 ldr r0, [pc, #204] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
8000804: 2201 movs r2, #1
|
|
8000806: 0019 movs r1, r3
|
|
8000808: f001 fe7a bl 8002500 <HAL_GPIO_WritePin>
|
|
break;
|
|
800080c: e0cd b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
else if (cnt<12){
|
|
800080e: 2317 movs r3, #23
|
|
8000810: 18fb adds r3, r7, r3
|
|
8000812: 781b ldrb r3, [r3, #0]
|
|
8000814: 2b0b cmp r3, #11
|
|
8000816: d815 bhi.n 8000844 <LEDS_AnimationThread+0x308>
|
|
LEDS_EteintVerte();
|
|
8000818: 2380 movs r3, #128 ; 0x80
|
|
800081a: 01db lsls r3, r3, #7
|
|
800081c: 482c ldr r0, [pc, #176] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
800081e: 2200 movs r2, #0
|
|
8000820: 0019 movs r1, r3
|
|
8000822: f001 fe6d bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_EteintJaune();
|
|
8000826: 2380 movs r3, #128 ; 0x80
|
|
8000828: 019b lsls r3, r3, #6
|
|
800082a: 4829 ldr r0, [pc, #164] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
800082c: 2200 movs r2, #0
|
|
800082e: 0019 movs r1, r3
|
|
8000830: f001 fe66 bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_EteintRouge();
|
|
8000834: 2380 movs r3, #128 ; 0x80
|
|
8000836: 015b lsls r3, r3, #5
|
|
8000838: 4825 ldr r0, [pc, #148] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
800083a: 2200 movs r2, #0
|
|
800083c: 0019 movs r1, r3
|
|
800083e: f001 fe5f bl 8002500 <HAL_GPIO_WritePin>
|
|
break;
|
|
8000842: e0b2 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
cnt=0;
|
|
8000844: 2317 movs r3, #23
|
|
8000846: 18fb adds r3, r7, r3
|
|
8000848: 2200 movs r2, #0
|
|
800084a: 701a strb r2, [r3, #0]
|
|
break;
|
|
800084c: e0ad b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
case leds_charge_bat_2:
|
|
case leds_charge_bat_3:
|
|
LEDS_AllumeRouge();
|
|
800084e: 2380 movs r3, #128 ; 0x80
|
|
8000850: 015b lsls r3, r3, #5
|
|
8000852: 481f ldr r0, [pc, #124] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
8000854: 2201 movs r2, #1
|
|
8000856: 0019 movs r1, r3
|
|
8000858: f001 fe52 bl 8002500 <HAL_GPIO_WritePin>
|
|
if (cnt<3)
|
|
800085c: 2317 movs r3, #23
|
|
800085e: 18fb adds r3, r7, r3
|
|
8000860: 781b ldrb r3, [r3, #0]
|
|
8000862: 2b02 cmp r3, #2
|
|
8000864: d807 bhi.n 8000876 <LEDS_AnimationThread+0x33a>
|
|
LEDS_AllumeJaune();
|
|
8000866: 2380 movs r3, #128 ; 0x80
|
|
8000868: 019b lsls r3, r3, #6
|
|
800086a: 4819 ldr r0, [pc, #100] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
800086c: 2201 movs r2, #1
|
|
800086e: 0019 movs r1, r3
|
|
8000870: f001 fe46 bl 8002500 <HAL_GPIO_WritePin>
|
|
else if (cnt <9){
|
|
LEDS_EteintVerte();
|
|
LEDS_EteintJaune();
|
|
} else
|
|
cnt=0;
|
|
break;
|
|
8000874: e099 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
else if (cnt<6)
|
|
8000876: 2317 movs r3, #23
|
|
8000878: 18fb adds r3, r7, r3
|
|
800087a: 781b ldrb r3, [r3, #0]
|
|
800087c: 2b05 cmp r3, #5
|
|
800087e: d807 bhi.n 8000890 <LEDS_AnimationThread+0x354>
|
|
LEDS_AllumeVerte();
|
|
8000880: 2380 movs r3, #128 ; 0x80
|
|
8000882: 01db lsls r3, r3, #7
|
|
8000884: 4812 ldr r0, [pc, #72] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
8000886: 2201 movs r2, #1
|
|
8000888: 0019 movs r1, r3
|
|
800088a: f001 fe39 bl 8002500 <HAL_GPIO_WritePin>
|
|
break;
|
|
800088e: e08c b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
else if (cnt <9){
|
|
8000890: 2317 movs r3, #23
|
|
8000892: 18fb adds r3, r7, r3
|
|
8000894: 781b ldrb r3, [r3, #0]
|
|
8000896: 2b08 cmp r3, #8
|
|
8000898: d80e bhi.n 80008b8 <LEDS_AnimationThread+0x37c>
|
|
LEDS_EteintVerte();
|
|
800089a: 2380 movs r3, #128 ; 0x80
|
|
800089c: 01db lsls r3, r3, #7
|
|
800089e: 480c ldr r0, [pc, #48] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
80008a0: 2200 movs r2, #0
|
|
80008a2: 0019 movs r1, r3
|
|
80008a4: f001 fe2c bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_EteintJaune();
|
|
80008a8: 2380 movs r3, #128 ; 0x80
|
|
80008aa: 019b lsls r3, r3, #6
|
|
80008ac: 4808 ldr r0, [pc, #32] ; (80008d0 <LEDS_AnimationThread+0x394>)
|
|
80008ae: 2200 movs r2, #0
|
|
80008b0: 0019 movs r1, r3
|
|
80008b2: f001 fe25 bl 8002500 <HAL_GPIO_WritePin>
|
|
break;
|
|
80008b6: e078 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
cnt=0;
|
|
80008b8: 2317 movs r3, #23
|
|
80008ba: 18fb adds r3, r7, r3
|
|
80008bc: 2200 movs r2, #0
|
|
80008be: 701a strb r2, [r3, #0]
|
|
break;
|
|
80008c0: e073 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
80008c2: 46c0 nop ; (mov r8, r8)
|
|
80008c4: 20001964 .word 0x20001964
|
|
80008c8: 2000153c .word 0x2000153c
|
|
80008cc: 200016d0 .word 0x200016d0
|
|
80008d0: 50000400 .word 0x50000400
|
|
80008d4: 0800781c .word 0x0800781c
|
|
case leds_charge_bat_4:
|
|
case leds_charge_bat_5:
|
|
LEDS_AllumeRouge();
|
|
80008d8: 2380 movs r3, #128 ; 0x80
|
|
80008da: 015b lsls r3, r3, #5
|
|
80008dc: 4833 ldr r0, [pc, #204] ; (80009ac <LEDS_AnimationThread+0x470>)
|
|
80008de: 2201 movs r2, #1
|
|
80008e0: 0019 movs r1, r3
|
|
80008e2: f001 fe0d bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_AllumeJaune();
|
|
80008e6: 2380 movs r3, #128 ; 0x80
|
|
80008e8: 019b lsls r3, r3, #6
|
|
80008ea: 4830 ldr r0, [pc, #192] ; (80009ac <LEDS_AnimationThread+0x470>)
|
|
80008ec: 2201 movs r2, #1
|
|
80008ee: 0019 movs r1, r3
|
|
80008f0: f001 fe06 bl 8002500 <HAL_GPIO_WritePin>
|
|
|
|
if (cnt<3)
|
|
80008f4: 2317 movs r3, #23
|
|
80008f6: 18fb adds r3, r7, r3
|
|
80008f8: 781b ldrb r3, [r3, #0]
|
|
80008fa: 2b02 cmp r3, #2
|
|
80008fc: d807 bhi.n 800090e <LEDS_AnimationThread+0x3d2>
|
|
LEDS_AllumeVerte();
|
|
80008fe: 2380 movs r3, #128 ; 0x80
|
|
8000900: 01db lsls r3, r3, #7
|
|
8000902: 482a ldr r0, [pc, #168] ; (80009ac <LEDS_AnimationThread+0x470>)
|
|
8000904: 2201 movs r2, #1
|
|
8000906: 0019 movs r1, r3
|
|
8000908: f001 fdfa bl 8002500 <HAL_GPIO_WritePin>
|
|
else if (cnt<6)
|
|
LEDS_EteintVerte();
|
|
else
|
|
cnt=0;
|
|
break;
|
|
800090c: e04d b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
else if (cnt<6)
|
|
800090e: 2317 movs r3, #23
|
|
8000910: 18fb adds r3, r7, r3
|
|
8000912: 781b ldrb r3, [r3, #0]
|
|
8000914: 2b05 cmp r3, #5
|
|
8000916: d807 bhi.n 8000928 <LEDS_AnimationThread+0x3ec>
|
|
LEDS_EteintVerte();
|
|
8000918: 2380 movs r3, #128 ; 0x80
|
|
800091a: 01db lsls r3, r3, #7
|
|
800091c: 4823 ldr r0, [pc, #140] ; (80009ac <LEDS_AnimationThread+0x470>)
|
|
800091e: 2200 movs r2, #0
|
|
8000920: 0019 movs r1, r3
|
|
8000922: f001 fded bl 8002500 <HAL_GPIO_WritePin>
|
|
break;
|
|
8000926: e040 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
cnt=0;
|
|
8000928: 2317 movs r3, #23
|
|
800092a: 18fb adds r3, r7, r3
|
|
800092c: 2200 movs r2, #0
|
|
800092e: 701a strb r2, [r3, #0]
|
|
break;
|
|
8000930: e03b b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
case leds_erreur:
|
|
if (cnt<5) {
|
|
8000932: 2317 movs r3, #23
|
|
8000934: 18fb adds r3, r7, r3
|
|
8000936: 781b ldrb r3, [r3, #0]
|
|
8000938: 2b04 cmp r3, #4
|
|
800093a: d815 bhi.n 8000968 <LEDS_AnimationThread+0x42c>
|
|
LEDS_AllumeRouge();
|
|
800093c: 2380 movs r3, #128 ; 0x80
|
|
800093e: 015b lsls r3, r3, #5
|
|
8000940: 481a ldr r0, [pc, #104] ; (80009ac <LEDS_AnimationThread+0x470>)
|
|
8000942: 2201 movs r2, #1
|
|
8000944: 0019 movs r1, r3
|
|
8000946: f001 fddb bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_AllumeJaune();
|
|
800094a: 2380 movs r3, #128 ; 0x80
|
|
800094c: 019b lsls r3, r3, #6
|
|
800094e: 4817 ldr r0, [pc, #92] ; (80009ac <LEDS_AnimationThread+0x470>)
|
|
8000950: 2201 movs r2, #1
|
|
8000952: 0019 movs r1, r3
|
|
8000954: f001 fdd4 bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_AllumeVerte();
|
|
8000958: 2380 movs r3, #128 ; 0x80
|
|
800095a: 01db lsls r3, r3, #7
|
|
800095c: 4813 ldr r0, [pc, #76] ; (80009ac <LEDS_AnimationThread+0x470>)
|
|
800095e: 2201 movs r2, #1
|
|
8000960: 0019 movs r1, r3
|
|
8000962: f001 fdcd bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_EteintJaune();
|
|
LEDS_EteintVerte();
|
|
}
|
|
else
|
|
cnt=0;
|
|
break;
|
|
8000966: e020 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
else if (cnt<10) {
|
|
8000968: 2317 movs r3, #23
|
|
800096a: 18fb adds r3, r7, r3
|
|
800096c: 781b ldrb r3, [r3, #0]
|
|
800096e: 2b09 cmp r3, #9
|
|
8000970: d815 bhi.n 800099e <LEDS_AnimationThread+0x462>
|
|
LEDS_EteintRouge();
|
|
8000972: 2380 movs r3, #128 ; 0x80
|
|
8000974: 015b lsls r3, r3, #5
|
|
8000976: 480d ldr r0, [pc, #52] ; (80009ac <LEDS_AnimationThread+0x470>)
|
|
8000978: 2200 movs r2, #0
|
|
800097a: 0019 movs r1, r3
|
|
800097c: f001 fdc0 bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_EteintJaune();
|
|
8000980: 2380 movs r3, #128 ; 0x80
|
|
8000982: 019b lsls r3, r3, #6
|
|
8000984: 4809 ldr r0, [pc, #36] ; (80009ac <LEDS_AnimationThread+0x470>)
|
|
8000986: 2200 movs r2, #0
|
|
8000988: 0019 movs r1, r3
|
|
800098a: f001 fdb9 bl 8002500 <HAL_GPIO_WritePin>
|
|
LEDS_EteintVerte();
|
|
800098e: 2380 movs r3, #128 ; 0x80
|
|
8000990: 01db lsls r3, r3, #7
|
|
8000992: 4806 ldr r0, [pc, #24] ; (80009ac <LEDS_AnimationThread+0x470>)
|
|
8000994: 2200 movs r2, #0
|
|
8000996: 0019 movs r1, r3
|
|
8000998: f001 fdb2 bl 8002500 <HAL_GPIO_WritePin>
|
|
break;
|
|
800099c: e005 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
cnt=0;
|
|
800099e: 2317 movs r3, #23
|
|
80009a0: 18fb adds r3, r7, r3
|
|
80009a2: 2200 movs r2, #0
|
|
80009a4: 701a strb r2, [r3, #0]
|
|
break;
|
|
80009a6: e000 b.n 80009aa <LEDS_AnimationThread+0x46e>
|
|
default:
|
|
break;
|
|
80009a8: 46c0 nop ; (mov r8, r8)
|
|
vTaskDelay(pdMS_TO_TICKS(100));
|
|
80009aa: e5cf b.n 800054c <LEDS_AnimationThread+0x10>
|
|
80009ac: 50000400 .word 0x50000400
|
|
|
|
080009b0 <main>:
|
|
/**
|
|
* @brief The application entry point.
|
|
* @retval int
|
|
*/
|
|
int main(void)
|
|
{
|
|
80009b0: b580 push {r7, lr}
|
|
80009b2: af00 add r7, sp, #0
|
|
/* USER CODE END 1 */
|
|
|
|
/* MCU Configuration--------------------------------------------------------*/
|
|
|
|
/* Reset of all peripherals, Initializes the Flash interface and the Systick. */
|
|
HAL_Init();
|
|
80009b4: f000 fe8a bl 80016cc <HAL_Init>
|
|
/* USER CODE BEGIN Init */
|
|
|
|
/* USER CODE END Init */
|
|
|
|
/* Configure the system clock */
|
|
SystemClock_Config();
|
|
80009b8: f000 f826 bl 8000a08 <SystemClock_Config>
|
|
/* USER CODE BEGIN SysInit */
|
|
|
|
/* USER CODE END SysInit */
|
|
|
|
/* Initialize all configured peripherals */
|
|
MX_GPIO_Init();
|
|
80009bc: f000 fa78 bl 8000eb0 <MX_GPIO_Init>
|
|
MX_DMA_Init();
|
|
80009c0: f000 fa58 bl 8000e74 <MX_DMA_Init>
|
|
MX_LPTIM1_Init();
|
|
80009c4: f000 f8f8 bl 8000bb8 <MX_LPTIM1_Init>
|
|
MX_LPUART1_UART_Init();
|
|
80009c8: f000 f926 bl 8000c18 <MX_LPUART1_UART_Init>
|
|
MX_TIM2_Init();
|
|
80009cc: f000 f952 bl 8000c74 <MX_TIM2_Init>
|
|
MX_TIM21_Init();
|
|
80009d0: f000 f9ec bl 8000dac <MX_TIM21_Init>
|
|
MX_ADC_Init();
|
|
80009d4: f000 f88c bl 8000af0 <MX_ADC_Init>
|
|
/* USER CODE BEGIN 2 */
|
|
/* Init des messages box */
|
|
MESSAGE_Init();
|
|
80009d8: f000 fb32 bl 8001040 <MESSAGE_Init>
|
|
|
|
LEDS_Init();
|
|
80009dc: f7ff fd6e bl 80004bc <LEDS_Init>
|
|
/*MOTEURS_Init();
|
|
MOTEURS_Test();*/
|
|
/* USER CODE END 2 */
|
|
|
|
/* Init scheduler */
|
|
osKernelInitialize();
|
|
80009e0: f004 fa3c bl 8004e5c <osKernelInitialize>
|
|
/* add queues, ... */
|
|
/* USER CODE END RTOS_QUEUES */
|
|
|
|
/* Create the thread(s) */
|
|
/* creation of defaultTask */
|
|
defaultTaskHandle = osThreadNew(StartDefaultTask, NULL, &defaultTask_attributes);
|
|
80009e4: 4a05 ldr r2, [pc, #20] ; (80009fc <main+0x4c>)
|
|
80009e6: 4b06 ldr r3, [pc, #24] ; (8000a00 <main+0x50>)
|
|
80009e8: 2100 movs r1, #0
|
|
80009ea: 0018 movs r0, r3
|
|
80009ec: f004 fa92 bl 8004f14 <osThreadNew>
|
|
80009f0: 0002 movs r2, r0
|
|
80009f2: 4b04 ldr r3, [pc, #16] ; (8000a04 <main+0x54>)
|
|
80009f4: 601a str r2, [r3, #0]
|
|
/* USER CODE BEGIN RTOS_EVENTS */
|
|
/* add events, ... */
|
|
/* USER CODE END RTOS_EVENTS */
|
|
|
|
/* Start scheduler */
|
|
osKernelStart();
|
|
80009f6: f004 fa5d bl 8004eb4 <osKernelStart>
|
|
|
|
/* We should never get here as control is now taken by the scheduler */
|
|
/* Infinite loop */
|
|
/* USER CODE BEGIN WHILE */
|
|
while (1)
|
|
80009fa: e7fe b.n 80009fa <main+0x4a>
|
|
80009fc: 08007860 .word 0x08007860
|
|
8000a00: 08000fe1 .word 0x08000fe1
|
|
8000a04: 20001730 .word 0x20001730
|
|
|
|
08000a08 <SystemClock_Config>:
|
|
/**
|
|
* @brief System Clock Configuration
|
|
* @retval None
|
|
*/
|
|
void SystemClock_Config(void)
|
|
{
|
|
8000a08: b590 push {r4, r7, lr}
|
|
8000a0a: b099 sub sp, #100 ; 0x64
|
|
8000a0c: af00 add r7, sp, #0
|
|
RCC_OscInitTypeDef RCC_OscInitStruct = {0};
|
|
8000a0e: 242c movs r4, #44 ; 0x2c
|
|
8000a10: 193b adds r3, r7, r4
|
|
8000a12: 0018 movs r0, r3
|
|
8000a14: 2334 movs r3, #52 ; 0x34
|
|
8000a16: 001a movs r2, r3
|
|
8000a18: 2100 movs r1, #0
|
|
8000a1a: f006 fed0 bl 80077be <memset>
|
|
RCC_ClkInitTypeDef RCC_ClkInitStruct = {0};
|
|
8000a1e: 2318 movs r3, #24
|
|
8000a20: 18fb adds r3, r7, r3
|
|
8000a22: 0018 movs r0, r3
|
|
8000a24: 2314 movs r3, #20
|
|
8000a26: 001a movs r2, r3
|
|
8000a28: 2100 movs r1, #0
|
|
8000a2a: f006 fec8 bl 80077be <memset>
|
|
RCC_PeriphCLKInitTypeDef PeriphClkInit = {0};
|
|
8000a2e: 003b movs r3, r7
|
|
8000a30: 0018 movs r0, r3
|
|
8000a32: 2318 movs r3, #24
|
|
8000a34: 001a movs r2, r3
|
|
8000a36: 2100 movs r1, #0
|
|
8000a38: f006 fec1 bl 80077be <memset>
|
|
|
|
/** Configure the main internal regulator output voltage
|
|
*/
|
|
__HAL_PWR_VOLTAGESCALING_CONFIG(PWR_REGULATOR_VOLTAGE_SCALE1);
|
|
8000a3c: 4b2a ldr r3, [pc, #168] ; (8000ae8 <SystemClock_Config+0xe0>)
|
|
8000a3e: 681b ldr r3, [r3, #0]
|
|
8000a40: 4a2a ldr r2, [pc, #168] ; (8000aec <SystemClock_Config+0xe4>)
|
|
8000a42: 401a ands r2, r3
|
|
8000a44: 4b28 ldr r3, [pc, #160] ; (8000ae8 <SystemClock_Config+0xe0>)
|
|
8000a46: 2180 movs r1, #128 ; 0x80
|
|
8000a48: 0109 lsls r1, r1, #4
|
|
8000a4a: 430a orrs r2, r1
|
|
8000a4c: 601a str r2, [r3, #0]
|
|
/** Initializes the RCC Oscillators according to the specified parameters
|
|
* in the RCC_OscInitTypeDef structure.
|
|
*/
|
|
RCC_OscInitStruct.OscillatorType = RCC_OSCILLATORTYPE_HSI;
|
|
8000a4e: 0021 movs r1, r4
|
|
8000a50: 187b adds r3, r7, r1
|
|
8000a52: 2202 movs r2, #2
|
|
8000a54: 601a str r2, [r3, #0]
|
|
RCC_OscInitStruct.HSIState = RCC_HSI_DIV4;
|
|
8000a56: 187b adds r3, r7, r1
|
|
8000a58: 2209 movs r2, #9
|
|
8000a5a: 60da str r2, [r3, #12]
|
|
RCC_OscInitStruct.HSICalibrationValue = RCC_HSICALIBRATION_DEFAULT;
|
|
8000a5c: 187b adds r3, r7, r1
|
|
8000a5e: 2210 movs r2, #16
|
|
8000a60: 611a str r2, [r3, #16]
|
|
RCC_OscInitStruct.PLL.PLLState = RCC_PLL_ON;
|
|
8000a62: 187b adds r3, r7, r1
|
|
8000a64: 2202 movs r2, #2
|
|
8000a66: 625a str r2, [r3, #36] ; 0x24
|
|
RCC_OscInitStruct.PLL.PLLSource = RCC_PLLSOURCE_HSI;
|
|
8000a68: 187b adds r3, r7, r1
|
|
8000a6a: 2200 movs r2, #0
|
|
8000a6c: 629a str r2, [r3, #40] ; 0x28
|
|
RCC_OscInitStruct.PLL.PLLMUL = RCC_PLLMUL_3;
|
|
8000a6e: 187b adds r3, r7, r1
|
|
8000a70: 2200 movs r2, #0
|
|
8000a72: 62da str r2, [r3, #44] ; 0x2c
|
|
RCC_OscInitStruct.PLL.PLLDIV = RCC_PLLDIV_2;
|
|
8000a74: 187b adds r3, r7, r1
|
|
8000a76: 2280 movs r2, #128 ; 0x80
|
|
8000a78: 03d2 lsls r2, r2, #15
|
|
8000a7a: 631a str r2, [r3, #48] ; 0x30
|
|
if (HAL_RCC_OscConfig(&RCC_OscInitStruct) != HAL_OK)
|
|
8000a7c: 187b adds r3, r7, r1
|
|
8000a7e: 0018 movs r0, r3
|
|
8000a80: f001 fe0e bl 80026a0 <HAL_RCC_OscConfig>
|
|
8000a84: 1e03 subs r3, r0, #0
|
|
8000a86: d001 beq.n 8000a8c <SystemClock_Config+0x84>
|
|
{
|
|
Error_Handler();
|
|
8000a88: f000 fad4 bl 8001034 <Error_Handler>
|
|
}
|
|
/** Initializes the CPU, AHB and APB buses clocks
|
|
*/
|
|
RCC_ClkInitStruct.ClockType = RCC_CLOCKTYPE_HCLK|RCC_CLOCKTYPE_SYSCLK
|
|
8000a8c: 2118 movs r1, #24
|
|
8000a8e: 187b adds r3, r7, r1
|
|
8000a90: 220f movs r2, #15
|
|
8000a92: 601a str r2, [r3, #0]
|
|
|RCC_CLOCKTYPE_PCLK1|RCC_CLOCKTYPE_PCLK2;
|
|
RCC_ClkInitStruct.SYSCLKSource = RCC_SYSCLKSOURCE_PLLCLK;
|
|
8000a94: 187b adds r3, r7, r1
|
|
8000a96: 2203 movs r2, #3
|
|
8000a98: 605a str r2, [r3, #4]
|
|
RCC_ClkInitStruct.AHBCLKDivider = RCC_SYSCLK_DIV1;
|
|
8000a9a: 187b adds r3, r7, r1
|
|
8000a9c: 2200 movs r2, #0
|
|
8000a9e: 609a str r2, [r3, #8]
|
|
RCC_ClkInitStruct.APB1CLKDivider = RCC_HCLK_DIV1;
|
|
8000aa0: 187b adds r3, r7, r1
|
|
8000aa2: 2200 movs r2, #0
|
|
8000aa4: 60da str r2, [r3, #12]
|
|
RCC_ClkInitStruct.APB2CLKDivider = RCC_HCLK_DIV1;
|
|
8000aa6: 187b adds r3, r7, r1
|
|
8000aa8: 2200 movs r2, #0
|
|
8000aaa: 611a str r2, [r3, #16]
|
|
|
|
if (HAL_RCC_ClockConfig(&RCC_ClkInitStruct, FLASH_LATENCY_0) != HAL_OK)
|
|
8000aac: 187b adds r3, r7, r1
|
|
8000aae: 2100 movs r1, #0
|
|
8000ab0: 0018 movs r0, r3
|
|
8000ab2: f002 f971 bl 8002d98 <HAL_RCC_ClockConfig>
|
|
8000ab6: 1e03 subs r3, r0, #0
|
|
8000ab8: d001 beq.n 8000abe <SystemClock_Config+0xb6>
|
|
{
|
|
Error_Handler();
|
|
8000aba: f000 fabb bl 8001034 <Error_Handler>
|
|
}
|
|
PeriphClkInit.PeriphClockSelection = RCC_PERIPHCLK_LPUART1|RCC_PERIPHCLK_LPTIM1;
|
|
8000abe: 003b movs r3, r7
|
|
8000ac0: 2284 movs r2, #132 ; 0x84
|
|
8000ac2: 601a str r2, [r3, #0]
|
|
PeriphClkInit.Lpuart1ClockSelection = RCC_LPUART1CLKSOURCE_PCLK1;
|
|
8000ac4: 003b movs r3, r7
|
|
8000ac6: 2200 movs r2, #0
|
|
8000ac8: 60da str r2, [r3, #12]
|
|
PeriphClkInit.LptimClockSelection = RCC_LPTIM1CLKSOURCE_PCLK;
|
|
8000aca: 003b movs r3, r7
|
|
8000acc: 2200 movs r2, #0
|
|
8000ace: 615a str r2, [r3, #20]
|
|
|
|
if (HAL_RCCEx_PeriphCLKConfig(&PeriphClkInit) != HAL_OK)
|
|
8000ad0: 003b movs r3, r7
|
|
8000ad2: 0018 movs r0, r3
|
|
8000ad4: f002 fb84 bl 80031e0 <HAL_RCCEx_PeriphCLKConfig>
|
|
8000ad8: 1e03 subs r3, r0, #0
|
|
8000ada: d001 beq.n 8000ae0 <SystemClock_Config+0xd8>
|
|
{
|
|
Error_Handler();
|
|
8000adc: f000 faaa bl 8001034 <Error_Handler>
|
|
}
|
|
}
|
|
8000ae0: 46c0 nop ; (mov r8, r8)
|
|
8000ae2: 46bd mov sp, r7
|
|
8000ae4: b019 add sp, #100 ; 0x64
|
|
8000ae6: bd90 pop {r4, r7, pc}
|
|
8000ae8: 40007000 .word 0x40007000
|
|
8000aec: ffffe7ff .word 0xffffe7ff
|
|
|
|
08000af0 <MX_ADC_Init>:
|
|
* @brief ADC Initialization Function
|
|
* @param None
|
|
* @retval None
|
|
*/
|
|
static void MX_ADC_Init(void)
|
|
{
|
|
8000af0: b580 push {r7, lr}
|
|
8000af2: b082 sub sp, #8
|
|
8000af4: af00 add r7, sp, #0
|
|
|
|
/* USER CODE BEGIN ADC_Init 0 */
|
|
|
|
/* USER CODE END ADC_Init 0 */
|
|
|
|
ADC_ChannelConfTypeDef sConfig = {0};
|
|
8000af6: 003b movs r3, r7
|
|
8000af8: 0018 movs r0, r3
|
|
8000afa: 2308 movs r3, #8
|
|
8000afc: 001a movs r2, r3
|
|
8000afe: 2100 movs r1, #0
|
|
8000b00: f006 fe5d bl 80077be <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;
|
|
8000b04: 4b2a ldr r3, [pc, #168] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b06: 4a2b ldr r2, [pc, #172] ; (8000bb4 <MX_ADC_Init+0xc4>)
|
|
8000b08: 601a str r2, [r3, #0]
|
|
hadc.Init.OversamplingMode = DISABLE;
|
|
8000b0a: 4b29 ldr r3, [pc, #164] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b0c: 2200 movs r2, #0
|
|
8000b0e: 63da str r2, [r3, #60] ; 0x3c
|
|
hadc.Init.ClockPrescaler = ADC_CLOCK_SYNC_PCLK_DIV1;
|
|
8000b10: 4b27 ldr r3, [pc, #156] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b12: 22c0 movs r2, #192 ; 0xc0
|
|
8000b14: 0612 lsls r2, r2, #24
|
|
8000b16: 605a str r2, [r3, #4]
|
|
hadc.Init.Resolution = ADC_RESOLUTION_8B;
|
|
8000b18: 4b25 ldr r3, [pc, #148] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b1a: 2210 movs r2, #16
|
|
8000b1c: 609a str r2, [r3, #8]
|
|
hadc.Init.SamplingTime = ADC_SAMPLETIME_160CYCLES_5;
|
|
8000b1e: 4b24 ldr r3, [pc, #144] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b20: 2207 movs r2, #7
|
|
8000b22: 639a str r2, [r3, #56] ; 0x38
|
|
hadc.Init.ScanConvMode = ADC_SCAN_DIRECTION_FORWARD;
|
|
8000b24: 4b22 ldr r3, [pc, #136] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b26: 2201 movs r2, #1
|
|
8000b28: 611a str r2, [r3, #16]
|
|
hadc.Init.DataAlign = ADC_DATAALIGN_RIGHT;
|
|
8000b2a: 4b21 ldr r3, [pc, #132] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b2c: 2200 movs r2, #0
|
|
8000b2e: 60da str r2, [r3, #12]
|
|
hadc.Init.ContinuousConvMode = DISABLE;
|
|
8000b30: 4b1f ldr r3, [pc, #124] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b32: 2220 movs r2, #32
|
|
8000b34: 2100 movs r1, #0
|
|
8000b36: 5499 strb r1, [r3, r2]
|
|
hadc.Init.DiscontinuousConvMode = DISABLE;
|
|
8000b38: 4b1d ldr r3, [pc, #116] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b3a: 2221 movs r2, #33 ; 0x21
|
|
8000b3c: 2100 movs r1, #0
|
|
8000b3e: 5499 strb r1, [r3, r2]
|
|
hadc.Init.ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;
|
|
8000b40: 4b1b ldr r3, [pc, #108] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b42: 2200 movs r2, #0
|
|
8000b44: 629a str r2, [r3, #40] ; 0x28
|
|
hadc.Init.ExternalTrigConv = ADC_SOFTWARE_START;
|
|
8000b46: 4b1a ldr r3, [pc, #104] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b48: 22c2 movs r2, #194 ; 0xc2
|
|
8000b4a: 32ff adds r2, #255 ; 0xff
|
|
8000b4c: 625a str r2, [r3, #36] ; 0x24
|
|
hadc.Init.DMAContinuousRequests = DISABLE;
|
|
8000b4e: 4b18 ldr r3, [pc, #96] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b50: 222c movs r2, #44 ; 0x2c
|
|
8000b52: 2100 movs r1, #0
|
|
8000b54: 5499 strb r1, [r3, r2]
|
|
hadc.Init.EOCSelection = ADC_EOC_SINGLE_CONV;
|
|
8000b56: 4b16 ldr r3, [pc, #88] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b58: 2204 movs r2, #4
|
|
8000b5a: 615a str r2, [r3, #20]
|
|
hadc.Init.Overrun = ADC_OVR_DATA_PRESERVED;
|
|
8000b5c: 4b14 ldr r3, [pc, #80] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b5e: 2200 movs r2, #0
|
|
8000b60: 631a str r2, [r3, #48] ; 0x30
|
|
hadc.Init.LowPowerAutoWait = DISABLE;
|
|
8000b62: 4b13 ldr r3, [pc, #76] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b64: 2200 movs r2, #0
|
|
8000b66: 619a str r2, [r3, #24]
|
|
hadc.Init.LowPowerFrequencyMode = DISABLE;
|
|
8000b68: 4b11 ldr r3, [pc, #68] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b6a: 2200 movs r2, #0
|
|
8000b6c: 635a str r2, [r3, #52] ; 0x34
|
|
hadc.Init.LowPowerAutoPowerOff = DISABLE;
|
|
8000b6e: 4b10 ldr r3, [pc, #64] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b70: 2200 movs r2, #0
|
|
8000b72: 61da str r2, [r3, #28]
|
|
if (HAL_ADC_Init(&hadc) != HAL_OK)
|
|
8000b74: 4b0e ldr r3, [pc, #56] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b76: 0018 movs r0, r3
|
|
8000b78: f000 fe18 bl 80017ac <HAL_ADC_Init>
|
|
8000b7c: 1e03 subs r3, r0, #0
|
|
8000b7e: d001 beq.n 8000b84 <MX_ADC_Init+0x94>
|
|
{
|
|
Error_Handler();
|
|
8000b80: f000 fa58 bl 8001034 <Error_Handler>
|
|
}
|
|
/** Configure for the selected ADC regular channel to be converted.
|
|
*/
|
|
sConfig.Channel = ADC_CHANNEL_0;
|
|
8000b84: 003b movs r3, r7
|
|
8000b86: 2201 movs r2, #1
|
|
8000b88: 601a str r2, [r3, #0]
|
|
sConfig.Rank = ADC_RANK_CHANNEL_NUMBER;
|
|
8000b8a: 003b movs r3, r7
|
|
8000b8c: 2280 movs r2, #128 ; 0x80
|
|
8000b8e: 0152 lsls r2, r2, #5
|
|
8000b90: 605a str r2, [r3, #4]
|
|
if (HAL_ADC_ConfigChannel(&hadc, &sConfig) != HAL_OK)
|
|
8000b92: 003a movs r2, r7
|
|
8000b94: 4b06 ldr r3, [pc, #24] ; (8000bb0 <MX_ADC_Init+0xc0>)
|
|
8000b96: 0011 movs r1, r2
|
|
8000b98: 0018 movs r0, r3
|
|
8000b9a: f001 f84f bl 8001c3c <HAL_ADC_ConfigChannel>
|
|
8000b9e: 1e03 subs r3, r0, #0
|
|
8000ba0: d001 beq.n 8000ba6 <MX_ADC_Init+0xb6>
|
|
{
|
|
Error_Handler();
|
|
8000ba2: f000 fa47 bl 8001034 <Error_Handler>
|
|
}
|
|
/* USER CODE BEGIN ADC_Init 2 */
|
|
|
|
/* USER CODE END ADC_Init 2 */
|
|
|
|
}
|
|
8000ba6: 46c0 nop ; (mov r8, r8)
|
|
8000ba8: 46bd mov sp, r7
|
|
8000baa: b002 add sp, #8
|
|
8000bac: bd80 pop {r7, pc}
|
|
8000bae: 46c0 nop ; (mov r8, r8)
|
|
8000bb0: 200018b8 .word 0x200018b8
|
|
8000bb4: 40012400 .word 0x40012400
|
|
|
|
08000bb8 <MX_LPTIM1_Init>:
|
|
* @brief LPTIM1 Initialization Function
|
|
* @param None
|
|
* @retval None
|
|
*/
|
|
static void MX_LPTIM1_Init(void)
|
|
{
|
|
8000bb8: b580 push {r7, lr}
|
|
8000bba: af00 add r7, sp, #0
|
|
/* USER CODE END LPTIM1_Init 0 */
|
|
|
|
/* USER CODE BEGIN LPTIM1_Init 1 */
|
|
|
|
/* USER CODE END LPTIM1_Init 1 */
|
|
hlptim1.Instance = LPTIM1;
|
|
8000bbc: 4b13 ldr r3, [pc, #76] ; (8000c0c <MX_LPTIM1_Init+0x54>)
|
|
8000bbe: 4a14 ldr r2, [pc, #80] ; (8000c10 <MX_LPTIM1_Init+0x58>)
|
|
8000bc0: 601a str r2, [r3, #0]
|
|
hlptim1.Init.Clock.Source = LPTIM_CLOCKSOURCE_APBCLOCK_LPOSC;
|
|
8000bc2: 4b12 ldr r3, [pc, #72] ; (8000c0c <MX_LPTIM1_Init+0x54>)
|
|
8000bc4: 2200 movs r2, #0
|
|
8000bc6: 605a str r2, [r3, #4]
|
|
hlptim1.Init.Clock.Prescaler = LPTIM_PRESCALER_DIV1;
|
|
8000bc8: 4b10 ldr r3, [pc, #64] ; (8000c0c <MX_LPTIM1_Init+0x54>)
|
|
8000bca: 2200 movs r2, #0
|
|
8000bcc: 609a str r2, [r3, #8]
|
|
hlptim1.Init.UltraLowPowerClock.Polarity = LPTIM_CLOCKPOLARITY_RISING;
|
|
8000bce: 4b0f ldr r3, [pc, #60] ; (8000c0c <MX_LPTIM1_Init+0x54>)
|
|
8000bd0: 2200 movs r2, #0
|
|
8000bd2: 60da str r2, [r3, #12]
|
|
hlptim1.Init.UltraLowPowerClock.SampleTime = LPTIM_CLOCKSAMPLETIME_DIRECTTRANSITION;
|
|
8000bd4: 4b0d ldr r3, [pc, #52] ; (8000c0c <MX_LPTIM1_Init+0x54>)
|
|
8000bd6: 2200 movs r2, #0
|
|
8000bd8: 611a str r2, [r3, #16]
|
|
hlptim1.Init.Trigger.Source = LPTIM_TRIGSOURCE_SOFTWARE;
|
|
8000bda: 4b0c ldr r3, [pc, #48] ; (8000c0c <MX_LPTIM1_Init+0x54>)
|
|
8000bdc: 4a0d ldr r2, [pc, #52] ; (8000c14 <MX_LPTIM1_Init+0x5c>)
|
|
8000bde: 615a str r2, [r3, #20]
|
|
hlptim1.Init.OutputPolarity = LPTIM_OUTPUTPOLARITY_HIGH;
|
|
8000be0: 4b0a ldr r3, [pc, #40] ; (8000c0c <MX_LPTIM1_Init+0x54>)
|
|
8000be2: 2200 movs r2, #0
|
|
8000be4: 621a str r2, [r3, #32]
|
|
hlptim1.Init.UpdateMode = LPTIM_UPDATE_IMMEDIATE;
|
|
8000be6: 4b09 ldr r3, [pc, #36] ; (8000c0c <MX_LPTIM1_Init+0x54>)
|
|
8000be8: 2200 movs r2, #0
|
|
8000bea: 625a str r2, [r3, #36] ; 0x24
|
|
hlptim1.Init.CounterSource = LPTIM_COUNTERSOURCE_EXTERNAL;
|
|
8000bec: 4b07 ldr r3, [pc, #28] ; (8000c0c <MX_LPTIM1_Init+0x54>)
|
|
8000bee: 2280 movs r2, #128 ; 0x80
|
|
8000bf0: 0412 lsls r2, r2, #16
|
|
8000bf2: 629a str r2, [r3, #40] ; 0x28
|
|
if (HAL_LPTIM_Init(&hlptim1) != HAL_OK)
|
|
8000bf4: 4b05 ldr r3, [pc, #20] ; (8000c0c <MX_LPTIM1_Init+0x54>)
|
|
8000bf6: 0018 movs r0, r3
|
|
8000bf8: f001 fcc6 bl 8002588 <HAL_LPTIM_Init>
|
|
8000bfc: 1e03 subs r3, r0, #0
|
|
8000bfe: d001 beq.n 8000c04 <MX_LPTIM1_Init+0x4c>
|
|
{
|
|
Error_Handler();
|
|
8000c00: f000 fa18 bl 8001034 <Error_Handler>
|
|
}
|
|
/* USER CODE BEGIN LPTIM1_Init 2 */
|
|
|
|
/* USER CODE END LPTIM1_Init 2 */
|
|
|
|
}
|
|
8000c04: 46c0 nop ; (mov r8, r8)
|
|
8000c06: 46bd mov sp, r7
|
|
8000c08: bd80 pop {r7, pc}
|
|
8000c0a: 46c0 nop ; (mov r8, r8)
|
|
8000c0c: 200017b8 .word 0x200017b8
|
|
8000c10: 40007c00 .word 0x40007c00
|
|
8000c14: 0000ffff .word 0x0000ffff
|
|
|
|
08000c18 <MX_LPUART1_UART_Init>:
|
|
* @brief LPUART1 Initialization Function
|
|
* @param None
|
|
* @retval None
|
|
*/
|
|
static void MX_LPUART1_UART_Init(void)
|
|
{
|
|
8000c18: b580 push {r7, lr}
|
|
8000c1a: af00 add r7, sp, #0
|
|
/* USER CODE END LPUART1_Init 0 */
|
|
|
|
/* USER CODE BEGIN LPUART1_Init 1 */
|
|
|
|
/* USER CODE END LPUART1_Init 1 */
|
|
hlpuart1.Instance = LPUART1;
|
|
8000c1c: 4b13 ldr r3, [pc, #76] ; (8000c6c <MX_LPUART1_UART_Init+0x54>)
|
|
8000c1e: 4a14 ldr r2, [pc, #80] ; (8000c70 <MX_LPUART1_UART_Init+0x58>)
|
|
8000c20: 601a str r2, [r3, #0]
|
|
hlpuart1.Init.BaudRate = 9600;
|
|
8000c22: 4b12 ldr r3, [pc, #72] ; (8000c6c <MX_LPUART1_UART_Init+0x54>)
|
|
8000c24: 2296 movs r2, #150 ; 0x96
|
|
8000c26: 0192 lsls r2, r2, #6
|
|
8000c28: 605a str r2, [r3, #4]
|
|
hlpuart1.Init.WordLength = UART_WORDLENGTH_8B;
|
|
8000c2a: 4b10 ldr r3, [pc, #64] ; (8000c6c <MX_LPUART1_UART_Init+0x54>)
|
|
8000c2c: 2200 movs r2, #0
|
|
8000c2e: 609a str r2, [r3, #8]
|
|
hlpuart1.Init.StopBits = UART_STOPBITS_1;
|
|
8000c30: 4b0e ldr r3, [pc, #56] ; (8000c6c <MX_LPUART1_UART_Init+0x54>)
|
|
8000c32: 2200 movs r2, #0
|
|
8000c34: 60da str r2, [r3, #12]
|
|
hlpuart1.Init.Parity = UART_PARITY_NONE;
|
|
8000c36: 4b0d ldr r3, [pc, #52] ; (8000c6c <MX_LPUART1_UART_Init+0x54>)
|
|
8000c38: 2200 movs r2, #0
|
|
8000c3a: 611a str r2, [r3, #16]
|
|
hlpuart1.Init.Mode = UART_MODE_TX_RX;
|
|
8000c3c: 4b0b ldr r3, [pc, #44] ; (8000c6c <MX_LPUART1_UART_Init+0x54>)
|
|
8000c3e: 220c movs r2, #12
|
|
8000c40: 615a str r2, [r3, #20]
|
|
hlpuart1.Init.HwFlowCtl = UART_HWCONTROL_NONE;
|
|
8000c42: 4b0a ldr r3, [pc, #40] ; (8000c6c <MX_LPUART1_UART_Init+0x54>)
|
|
8000c44: 2200 movs r2, #0
|
|
8000c46: 619a str r2, [r3, #24]
|
|
hlpuart1.Init.OneBitSampling = UART_ONE_BIT_SAMPLE_DISABLE;
|
|
8000c48: 4b08 ldr r3, [pc, #32] ; (8000c6c <MX_LPUART1_UART_Init+0x54>)
|
|
8000c4a: 2200 movs r2, #0
|
|
8000c4c: 621a str r2, [r3, #32]
|
|
hlpuart1.AdvancedInit.AdvFeatureInit = UART_ADVFEATURE_NO_INIT;
|
|
8000c4e: 4b07 ldr r3, [pc, #28] ; (8000c6c <MX_LPUART1_UART_Init+0x54>)
|
|
8000c50: 2200 movs r2, #0
|
|
8000c52: 625a str r2, [r3, #36] ; 0x24
|
|
if (HAL_UART_Init(&hlpuart1) != HAL_OK)
|
|
8000c54: 4b05 ldr r3, [pc, #20] ; (8000c6c <MX_LPUART1_UART_Init+0x54>)
|
|
8000c56: 0018 movs r0, r3
|
|
8000c58: f003 f8e2 bl 8003e20 <HAL_UART_Init>
|
|
8000c5c: 1e03 subs r3, r0, #0
|
|
8000c5e: d001 beq.n 8000c64 <MX_LPUART1_UART_Init+0x4c>
|
|
{
|
|
Error_Handler();
|
|
8000c60: f000 f9e8 bl 8001034 <Error_Handler>
|
|
}
|
|
/* USER CODE BEGIN LPUART1_Init 2 */
|
|
|
|
/* USER CODE END LPUART1_Init 2 */
|
|
|
|
}
|
|
8000c64: 46c0 nop ; (mov r8, r8)
|
|
8000c66: 46bd mov sp, r7
|
|
8000c68: bd80 pop {r7, pc}
|
|
8000c6a: 46c0 nop ; (mov r8, r8)
|
|
8000c6c: 20001734 .word 0x20001734
|
|
8000c70: 40004800 .word 0x40004800
|
|
|
|
08000c74 <MX_TIM2_Init>:
|
|
* @brief TIM2 Initialization Function
|
|
* @param None
|
|
* @retval None
|
|
*/
|
|
static void MX_TIM2_Init(void)
|
|
{
|
|
8000c74: b580 push {r7, lr}
|
|
8000c76: b08a sub sp, #40 ; 0x28
|
|
8000c78: af00 add r7, sp, #0
|
|
|
|
/* USER CODE BEGIN TIM2_Init 0 */
|
|
|
|
/* USER CODE END TIM2_Init 0 */
|
|
|
|
TIM_ClockConfigTypeDef sClockSourceConfig = {0};
|
|
8000c7a: 2318 movs r3, #24
|
|
8000c7c: 18fb adds r3, r7, r3
|
|
8000c7e: 0018 movs r0, r3
|
|
8000c80: 2310 movs r3, #16
|
|
8000c82: 001a movs r2, r3
|
|
8000c84: 2100 movs r1, #0
|
|
8000c86: f006 fd9a bl 80077be <memset>
|
|
TIM_MasterConfigTypeDef sMasterConfig = {0};
|
|
8000c8a: 2310 movs r3, #16
|
|
8000c8c: 18fb adds r3, r7, r3
|
|
8000c8e: 0018 movs r0, r3
|
|
8000c90: 2308 movs r3, #8
|
|
8000c92: 001a movs r2, r3
|
|
8000c94: 2100 movs r1, #0
|
|
8000c96: f006 fd92 bl 80077be <memset>
|
|
TIM_OC_InitTypeDef sConfigOC = {0};
|
|
8000c9a: 003b movs r3, r7
|
|
8000c9c: 0018 movs r0, r3
|
|
8000c9e: 2310 movs r3, #16
|
|
8000ca0: 001a movs r2, r3
|
|
8000ca2: 2100 movs r1, #0
|
|
8000ca4: f006 fd8b bl 80077be <memset>
|
|
|
|
/* USER CODE BEGIN TIM2_Init 1 */
|
|
|
|
/* USER CODE END TIM2_Init 1 */
|
|
htim2.Instance = TIM2;
|
|
8000ca8: 4b3f ldr r3, [pc, #252] ; (8000da8 <MX_TIM2_Init+0x134>)
|
|
8000caa: 2280 movs r2, #128 ; 0x80
|
|
8000cac: 05d2 lsls r2, r2, #23
|
|
8000cae: 601a str r2, [r3, #0]
|
|
htim2.Init.Prescaler = 0;
|
|
8000cb0: 4b3d ldr r3, [pc, #244] ; (8000da8 <MX_TIM2_Init+0x134>)
|
|
8000cb2: 2200 movs r2, #0
|
|
8000cb4: 605a str r2, [r3, #4]
|
|
htim2.Init.CounterMode = TIM_COUNTERMODE_UP;
|
|
8000cb6: 4b3c ldr r3, [pc, #240] ; (8000da8 <MX_TIM2_Init+0x134>)
|
|
8000cb8: 2200 movs r2, #0
|
|
8000cba: 609a str r2, [r3, #8]
|
|
htim2.Init.Period = 255;
|
|
8000cbc: 4b3a ldr r3, [pc, #232] ; (8000da8 <MX_TIM2_Init+0x134>)
|
|
8000cbe: 22ff movs r2, #255 ; 0xff
|
|
8000cc0: 60da str r2, [r3, #12]
|
|
htim2.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
|
|
8000cc2: 4b39 ldr r3, [pc, #228] ; (8000da8 <MX_TIM2_Init+0x134>)
|
|
8000cc4: 2200 movs r2, #0
|
|
8000cc6: 611a str r2, [r3, #16]
|
|
htim2.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
|
|
8000cc8: 4b37 ldr r3, [pc, #220] ; (8000da8 <MX_TIM2_Init+0x134>)
|
|
8000cca: 2200 movs r2, #0
|
|
8000ccc: 615a str r2, [r3, #20]
|
|
if (HAL_TIM_Base_Init(&htim2) != HAL_OK)
|
|
8000cce: 4b36 ldr r3, [pc, #216] ; (8000da8 <MX_TIM2_Init+0x134>)
|
|
8000cd0: 0018 movs r0, r3
|
|
8000cd2: f002 fbab bl 800342c <HAL_TIM_Base_Init>
|
|
8000cd6: 1e03 subs r3, r0, #0
|
|
8000cd8: d001 beq.n 8000cde <MX_TIM2_Init+0x6a>
|
|
{
|
|
Error_Handler();
|
|
8000cda: f000 f9ab bl 8001034 <Error_Handler>
|
|
}
|
|
sClockSourceConfig.ClockSource = TIM_CLOCKSOURCE_INTERNAL;
|
|
8000cde: 2118 movs r1, #24
|
|
8000ce0: 187b adds r3, r7, r1
|
|
8000ce2: 2280 movs r2, #128 ; 0x80
|
|
8000ce4: 0152 lsls r2, r2, #5
|
|
8000ce6: 601a str r2, [r3, #0]
|
|
if (HAL_TIM_ConfigClockSource(&htim2, &sClockSourceConfig) != HAL_OK)
|
|
8000ce8: 187a adds r2, r7, r1
|
|
8000cea: 4b2f ldr r3, [pc, #188] ; (8000da8 <MX_TIM2_Init+0x134>)
|
|
8000cec: 0011 movs r1, r2
|
|
8000cee: 0018 movs r0, r3
|
|
8000cf0: f002 fd8a bl 8003808 <HAL_TIM_ConfigClockSource>
|
|
8000cf4: 1e03 subs r3, r0, #0
|
|
8000cf6: d001 beq.n 8000cfc <MX_TIM2_Init+0x88>
|
|
{
|
|
Error_Handler();
|
|
8000cf8: f000 f99c bl 8001034 <Error_Handler>
|
|
}
|
|
if (HAL_TIM_PWM_Init(&htim2) != HAL_OK)
|
|
8000cfc: 4b2a ldr r3, [pc, #168] ; (8000da8 <MX_TIM2_Init+0x134>)
|
|
8000cfe: 0018 movs r0, r3
|
|
8000d00: f002 fbd4 bl 80034ac <HAL_TIM_PWM_Init>
|
|
8000d04: 1e03 subs r3, r0, #0
|
|
8000d06: d001 beq.n 8000d0c <MX_TIM2_Init+0x98>
|
|
{
|
|
Error_Handler();
|
|
8000d08: f000 f994 bl 8001034 <Error_Handler>
|
|
}
|
|
sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
|
|
8000d0c: 2110 movs r1, #16
|
|
8000d0e: 187b adds r3, r7, r1
|
|
8000d10: 2200 movs r2, #0
|
|
8000d12: 601a str r2, [r3, #0]
|
|
sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
|
|
8000d14: 187b adds r3, r7, r1
|
|
8000d16: 2200 movs r2, #0
|
|
8000d18: 605a str r2, [r3, #4]
|
|
if (HAL_TIMEx_MasterConfigSynchronization(&htim2, &sMasterConfig) != HAL_OK)
|
|
8000d1a: 187a adds r2, r7, r1
|
|
8000d1c: 4b22 ldr r3, [pc, #136] ; (8000da8 <MX_TIM2_Init+0x134>)
|
|
8000d1e: 0011 movs r1, r2
|
|
8000d20: 0018 movs r0, r3
|
|
8000d22: f003 f82d bl 8003d80 <HAL_TIMEx_MasterConfigSynchronization>
|
|
8000d26: 1e03 subs r3, r0, #0
|
|
8000d28: d001 beq.n 8000d2e <MX_TIM2_Init+0xba>
|
|
{
|
|
Error_Handler();
|
|
8000d2a: f000 f983 bl 8001034 <Error_Handler>
|
|
}
|
|
sConfigOC.OCMode = TIM_OCMODE_PWM1;
|
|
8000d2e: 003b movs r3, r7
|
|
8000d30: 2260 movs r2, #96 ; 0x60
|
|
8000d32: 601a str r2, [r3, #0]
|
|
sConfigOC.Pulse = 0;
|
|
8000d34: 003b movs r3, r7
|
|
8000d36: 2200 movs r2, #0
|
|
8000d38: 605a str r2, [r3, #4]
|
|
sConfigOC.OCPolarity = TIM_OCPOLARITY_HIGH;
|
|
8000d3a: 003b movs r3, r7
|
|
8000d3c: 2200 movs r2, #0
|
|
8000d3e: 609a str r2, [r3, #8]
|
|
sConfigOC.OCFastMode = TIM_OCFAST_DISABLE;
|
|
8000d40: 003b movs r3, r7
|
|
8000d42: 2200 movs r2, #0
|
|
8000d44: 60da str r2, [r3, #12]
|
|
if (HAL_TIM_PWM_ConfigChannel(&htim2, &sConfigOC, TIM_CHANNEL_1) != HAL_OK)
|
|
8000d46: 0039 movs r1, r7
|
|
8000d48: 4b17 ldr r3, [pc, #92] ; (8000da8 <MX_TIM2_Init+0x134>)
|
|
8000d4a: 2200 movs r2, #0
|
|
8000d4c: 0018 movs r0, r3
|
|
8000d4e: f002 fc95 bl 800367c <HAL_TIM_PWM_ConfigChannel>
|
|
8000d52: 1e03 subs r3, r0, #0
|
|
8000d54: d001 beq.n 8000d5a <MX_TIM2_Init+0xe6>
|
|
{
|
|
Error_Handler();
|
|
8000d56: f000 f96d bl 8001034 <Error_Handler>
|
|
}
|
|
if (HAL_TIM_PWM_ConfigChannel(&htim2, &sConfigOC, TIM_CHANNEL_2) != HAL_OK)
|
|
8000d5a: 0039 movs r1, r7
|
|
8000d5c: 4b12 ldr r3, [pc, #72] ; (8000da8 <MX_TIM2_Init+0x134>)
|
|
8000d5e: 2204 movs r2, #4
|
|
8000d60: 0018 movs r0, r3
|
|
8000d62: f002 fc8b bl 800367c <HAL_TIM_PWM_ConfigChannel>
|
|
8000d66: 1e03 subs r3, r0, #0
|
|
8000d68: d001 beq.n 8000d6e <MX_TIM2_Init+0xfa>
|
|
{
|
|
Error_Handler();
|
|
8000d6a: f000 f963 bl 8001034 <Error_Handler>
|
|
}
|
|
if (HAL_TIM_PWM_ConfigChannel(&htim2, &sConfigOC, TIM_CHANNEL_3) != HAL_OK)
|
|
8000d6e: 0039 movs r1, r7
|
|
8000d70: 4b0d ldr r3, [pc, #52] ; (8000da8 <MX_TIM2_Init+0x134>)
|
|
8000d72: 2208 movs r2, #8
|
|
8000d74: 0018 movs r0, r3
|
|
8000d76: f002 fc81 bl 800367c <HAL_TIM_PWM_ConfigChannel>
|
|
8000d7a: 1e03 subs r3, r0, #0
|
|
8000d7c: d001 beq.n 8000d82 <MX_TIM2_Init+0x10e>
|
|
{
|
|
Error_Handler();
|
|
8000d7e: f000 f959 bl 8001034 <Error_Handler>
|
|
}
|
|
if (HAL_TIM_PWM_ConfigChannel(&htim2, &sConfigOC, TIM_CHANNEL_4) != HAL_OK)
|
|
8000d82: 0039 movs r1, r7
|
|
8000d84: 4b08 ldr r3, [pc, #32] ; (8000da8 <MX_TIM2_Init+0x134>)
|
|
8000d86: 220c movs r2, #12
|
|
8000d88: 0018 movs r0, r3
|
|
8000d8a: f002 fc77 bl 800367c <HAL_TIM_PWM_ConfigChannel>
|
|
8000d8e: 1e03 subs r3, r0, #0
|
|
8000d90: d001 beq.n 8000d96 <MX_TIM2_Init+0x122>
|
|
{
|
|
Error_Handler();
|
|
8000d92: f000 f94f bl 8001034 <Error_Handler>
|
|
}
|
|
/* USER CODE BEGIN TIM2_Init 2 */
|
|
|
|
/* USER CODE END TIM2_Init 2 */
|
|
HAL_TIM_MspPostInit(&htim2);
|
|
8000d96: 4b04 ldr r3, [pc, #16] ; (8000da8 <MX_TIM2_Init+0x134>)
|
|
8000d98: 0018 movs r0, r3
|
|
8000d9a: f000 fb93 bl 80014c4 <HAL_TIM_MspPostInit>
|
|
|
|
}
|
|
8000d9e: 46c0 nop ; (mov r8, r8)
|
|
8000da0: 46bd mov sp, r7
|
|
8000da2: b00a add sp, #40 ; 0x28
|
|
8000da4: bd80 pop {r7, pc}
|
|
8000da6: 46c0 nop ; (mov r8, r8)
|
|
8000da8: 20001878 .word 0x20001878
|
|
|
|
08000dac <MX_TIM21_Init>:
|
|
* @brief TIM21 Initialization Function
|
|
* @param None
|
|
* @retval None
|
|
*/
|
|
static void MX_TIM21_Init(void)
|
|
{
|
|
8000dac: b590 push {r4, r7, lr}
|
|
8000dae: b08d sub sp, #52 ; 0x34
|
|
8000db0: af00 add r7, sp, #0
|
|
|
|
/* USER CODE BEGIN TIM21_Init 0 */
|
|
|
|
/* USER CODE END TIM21_Init 0 */
|
|
|
|
TIM_Encoder_InitTypeDef sConfig = {0};
|
|
8000db2: 240c movs r4, #12
|
|
8000db4: 193b adds r3, r7, r4
|
|
8000db6: 0018 movs r0, r3
|
|
8000db8: 2324 movs r3, #36 ; 0x24
|
|
8000dba: 001a movs r2, r3
|
|
8000dbc: 2100 movs r1, #0
|
|
8000dbe: f006 fcfe bl 80077be <memset>
|
|
TIM_MasterConfigTypeDef sMasterConfig = {0};
|
|
8000dc2: 1d3b adds r3, r7, #4
|
|
8000dc4: 0018 movs r0, r3
|
|
8000dc6: 2308 movs r3, #8
|
|
8000dc8: 001a movs r2, r3
|
|
8000dca: 2100 movs r1, #0
|
|
8000dcc: f006 fcf7 bl 80077be <memset>
|
|
|
|
/* USER CODE BEGIN TIM21_Init 1 */
|
|
|
|
/* USER CODE END TIM21_Init 1 */
|
|
htim21.Instance = TIM21;
|
|
8000dd0: 4b25 ldr r3, [pc, #148] ; (8000e68 <MX_TIM21_Init+0xbc>)
|
|
8000dd2: 4a26 ldr r2, [pc, #152] ; (8000e6c <MX_TIM21_Init+0xc0>)
|
|
8000dd4: 601a str r2, [r3, #0]
|
|
htim21.Init.Prescaler = 0;
|
|
8000dd6: 4b24 ldr r3, [pc, #144] ; (8000e68 <MX_TIM21_Init+0xbc>)
|
|
8000dd8: 2200 movs r2, #0
|
|
8000dda: 605a str r2, [r3, #4]
|
|
htim21.Init.CounterMode = TIM_COUNTERMODE_UP;
|
|
8000ddc: 4b22 ldr r3, [pc, #136] ; (8000e68 <MX_TIM21_Init+0xbc>)
|
|
8000dde: 2200 movs r2, #0
|
|
8000de0: 609a str r2, [r3, #8]
|
|
htim21.Init.Period = 65535;
|
|
8000de2: 4b21 ldr r3, [pc, #132] ; (8000e68 <MX_TIM21_Init+0xbc>)
|
|
8000de4: 4a22 ldr r2, [pc, #136] ; (8000e70 <MX_TIM21_Init+0xc4>)
|
|
8000de6: 60da str r2, [r3, #12]
|
|
htim21.Init.ClockDivision = TIM_CLOCKDIVISION_DIV1;
|
|
8000de8: 4b1f ldr r3, [pc, #124] ; (8000e68 <MX_TIM21_Init+0xbc>)
|
|
8000dea: 2200 movs r2, #0
|
|
8000dec: 611a str r2, [r3, #16]
|
|
htim21.Init.AutoReloadPreload = TIM_AUTORELOAD_PRELOAD_DISABLE;
|
|
8000dee: 4b1e ldr r3, [pc, #120] ; (8000e68 <MX_TIM21_Init+0xbc>)
|
|
8000df0: 2200 movs r2, #0
|
|
8000df2: 615a str r2, [r3, #20]
|
|
sConfig.EncoderMode = TIM_ENCODERMODE_TI1;
|
|
8000df4: 0021 movs r1, r4
|
|
8000df6: 187b adds r3, r7, r1
|
|
8000df8: 2201 movs r2, #1
|
|
8000dfa: 601a str r2, [r3, #0]
|
|
sConfig.IC1Polarity = TIM_ICPOLARITY_RISING;
|
|
8000dfc: 187b adds r3, r7, r1
|
|
8000dfe: 2200 movs r2, #0
|
|
8000e00: 605a str r2, [r3, #4]
|
|
sConfig.IC1Selection = TIM_ICSELECTION_DIRECTTI;
|
|
8000e02: 187b adds r3, r7, r1
|
|
8000e04: 2201 movs r2, #1
|
|
8000e06: 609a str r2, [r3, #8]
|
|
sConfig.IC1Prescaler = TIM_ICPSC_DIV1;
|
|
8000e08: 187b adds r3, r7, r1
|
|
8000e0a: 2200 movs r2, #0
|
|
8000e0c: 60da str r2, [r3, #12]
|
|
sConfig.IC1Filter = 0;
|
|
8000e0e: 187b adds r3, r7, r1
|
|
8000e10: 2200 movs r2, #0
|
|
8000e12: 611a str r2, [r3, #16]
|
|
sConfig.IC2Polarity = TIM_ICPOLARITY_RISING;
|
|
8000e14: 187b adds r3, r7, r1
|
|
8000e16: 2200 movs r2, #0
|
|
8000e18: 615a str r2, [r3, #20]
|
|
sConfig.IC2Selection = TIM_ICSELECTION_DIRECTTI;
|
|
8000e1a: 187b adds r3, r7, r1
|
|
8000e1c: 2201 movs r2, #1
|
|
8000e1e: 619a str r2, [r3, #24]
|
|
sConfig.IC2Prescaler = TIM_ICPSC_DIV1;
|
|
8000e20: 187b adds r3, r7, r1
|
|
8000e22: 2200 movs r2, #0
|
|
8000e24: 61da str r2, [r3, #28]
|
|
sConfig.IC2Filter = 0;
|
|
8000e26: 187b adds r3, r7, r1
|
|
8000e28: 2200 movs r2, #0
|
|
8000e2a: 621a str r2, [r3, #32]
|
|
if (HAL_TIM_Encoder_Init(&htim21, &sConfig) != HAL_OK)
|
|
8000e2c: 187a adds r2, r7, r1
|
|
8000e2e: 4b0e ldr r3, [pc, #56] ; (8000e68 <MX_TIM21_Init+0xbc>)
|
|
8000e30: 0011 movs r1, r2
|
|
8000e32: 0018 movs r0, r3
|
|
8000e34: f002 fb82 bl 800353c <HAL_TIM_Encoder_Init>
|
|
8000e38: 1e03 subs r3, r0, #0
|
|
8000e3a: d001 beq.n 8000e40 <MX_TIM21_Init+0x94>
|
|
{
|
|
Error_Handler();
|
|
8000e3c: f000 f8fa bl 8001034 <Error_Handler>
|
|
}
|
|
sMasterConfig.MasterOutputTrigger = TIM_TRGO_RESET;
|
|
8000e40: 1d3b adds r3, r7, #4
|
|
8000e42: 2200 movs r2, #0
|
|
8000e44: 601a str r2, [r3, #0]
|
|
sMasterConfig.MasterSlaveMode = TIM_MASTERSLAVEMODE_DISABLE;
|
|
8000e46: 1d3b adds r3, r7, #4
|
|
8000e48: 2200 movs r2, #0
|
|
8000e4a: 605a str r2, [r3, #4]
|
|
if (HAL_TIMEx_MasterConfigSynchronization(&htim21, &sMasterConfig) != HAL_OK)
|
|
8000e4c: 1d3a adds r2, r7, #4
|
|
8000e4e: 4b06 ldr r3, [pc, #24] ; (8000e68 <MX_TIM21_Init+0xbc>)
|
|
8000e50: 0011 movs r1, r2
|
|
8000e52: 0018 movs r0, r3
|
|
8000e54: f002 ff94 bl 8003d80 <HAL_TIMEx_MasterConfigSynchronization>
|
|
8000e58: 1e03 subs r3, r0, #0
|
|
8000e5a: d001 beq.n 8000e60 <MX_TIM21_Init+0xb4>
|
|
{
|
|
Error_Handler();
|
|
8000e5c: f000 f8ea bl 8001034 <Error_Handler>
|
|
}
|
|
/* USER CODE BEGIN TIM21_Init 2 */
|
|
|
|
/* USER CODE END TIM21_Init 2 */
|
|
|
|
}
|
|
8000e60: 46c0 nop ; (mov r8, r8)
|
|
8000e62: 46bd mov sp, r7
|
|
8000e64: b00d add sp, #52 ; 0x34
|
|
8000e66: bd90 pop {r4, r7, pc}
|
|
8000e68: 20001914 .word 0x20001914
|
|
8000e6c: 40010800 .word 0x40010800
|
|
8000e70: 0000ffff .word 0x0000ffff
|
|
|
|
08000e74 <MX_DMA_Init>:
|
|
|
|
/**
|
|
* Enable DMA controller clock
|
|
*/
|
|
static void MX_DMA_Init(void)
|
|
{
|
|
8000e74: b580 push {r7, lr}
|
|
8000e76: b082 sub sp, #8
|
|
8000e78: af00 add r7, sp, #0
|
|
|
|
/* DMA controller clock enable */
|
|
__HAL_RCC_DMA1_CLK_ENABLE();
|
|
8000e7a: 4b0c ldr r3, [pc, #48] ; (8000eac <MX_DMA_Init+0x38>)
|
|
8000e7c: 6b1a ldr r2, [r3, #48] ; 0x30
|
|
8000e7e: 4b0b ldr r3, [pc, #44] ; (8000eac <MX_DMA_Init+0x38>)
|
|
8000e80: 2101 movs r1, #1
|
|
8000e82: 430a orrs r2, r1
|
|
8000e84: 631a str r2, [r3, #48] ; 0x30
|
|
8000e86: 4b09 ldr r3, [pc, #36] ; (8000eac <MX_DMA_Init+0x38>)
|
|
8000e88: 6b1b ldr r3, [r3, #48] ; 0x30
|
|
8000e8a: 2201 movs r2, #1
|
|
8000e8c: 4013 ands r3, r2
|
|
8000e8e: 607b str r3, [r7, #4]
|
|
8000e90: 687b ldr r3, [r7, #4]
|
|
|
|
/* DMA interrupt init */
|
|
/* DMA1_Channel2_3_IRQn interrupt configuration */
|
|
HAL_NVIC_SetPriority(DMA1_Channel2_3_IRQn, 3, 0);
|
|
8000e92: 2200 movs r2, #0
|
|
8000e94: 2103 movs r1, #3
|
|
8000e96: 200a movs r0, #10
|
|
8000e98: f000 ffe4 bl 8001e64 <HAL_NVIC_SetPriority>
|
|
HAL_NVIC_EnableIRQ(DMA1_Channel2_3_IRQn);
|
|
8000e9c: 200a movs r0, #10
|
|
8000e9e: f000 fff6 bl 8001e8e <HAL_NVIC_EnableIRQ>
|
|
|
|
}
|
|
8000ea2: 46c0 nop ; (mov r8, r8)
|
|
8000ea4: 46bd mov sp, r7
|
|
8000ea6: b002 add sp, #8
|
|
8000ea8: bd80 pop {r7, pc}
|
|
8000eaa: 46c0 nop ; (mov r8, r8)
|
|
8000eac: 40021000 .word 0x40021000
|
|
|
|
08000eb0 <MX_GPIO_Init>:
|
|
* @brief GPIO Initialization Function
|
|
* @param None
|
|
* @retval None
|
|
*/
|
|
static void MX_GPIO_Init(void)
|
|
{
|
|
8000eb0: b590 push {r4, r7, lr}
|
|
8000eb2: b089 sub sp, #36 ; 0x24
|
|
8000eb4: af00 add r7, sp, #0
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
8000eb6: 240c movs r4, #12
|
|
8000eb8: 193b adds r3, r7, r4
|
|
8000eba: 0018 movs r0, r3
|
|
8000ebc: 2314 movs r3, #20
|
|
8000ebe: 001a movs r2, r3
|
|
8000ec0: 2100 movs r1, #0
|
|
8000ec2: f006 fc7c bl 80077be <memset>
|
|
|
|
/* GPIO Ports Clock Enable */
|
|
__HAL_RCC_GPIOC_CLK_ENABLE();
|
|
8000ec6: 4b44 ldr r3, [pc, #272] ; (8000fd8 <MX_GPIO_Init+0x128>)
|
|
8000ec8: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8000eca: 4b43 ldr r3, [pc, #268] ; (8000fd8 <MX_GPIO_Init+0x128>)
|
|
8000ecc: 2104 movs r1, #4
|
|
8000ece: 430a orrs r2, r1
|
|
8000ed0: 62da str r2, [r3, #44] ; 0x2c
|
|
8000ed2: 4b41 ldr r3, [pc, #260] ; (8000fd8 <MX_GPIO_Init+0x128>)
|
|
8000ed4: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
8000ed6: 2204 movs r2, #4
|
|
8000ed8: 4013 ands r3, r2
|
|
8000eda: 60bb str r3, [r7, #8]
|
|
8000edc: 68bb ldr r3, [r7, #8]
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
8000ede: 4b3e ldr r3, [pc, #248] ; (8000fd8 <MX_GPIO_Init+0x128>)
|
|
8000ee0: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8000ee2: 4b3d ldr r3, [pc, #244] ; (8000fd8 <MX_GPIO_Init+0x128>)
|
|
8000ee4: 2101 movs r1, #1
|
|
8000ee6: 430a orrs r2, r1
|
|
8000ee8: 62da str r2, [r3, #44] ; 0x2c
|
|
8000eea: 4b3b ldr r3, [pc, #236] ; (8000fd8 <MX_GPIO_Init+0x128>)
|
|
8000eec: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
8000eee: 2201 movs r2, #1
|
|
8000ef0: 4013 ands r3, r2
|
|
8000ef2: 607b str r3, [r7, #4]
|
|
8000ef4: 687b ldr r3, [r7, #4]
|
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
8000ef6: 4b38 ldr r3, [pc, #224] ; (8000fd8 <MX_GPIO_Init+0x128>)
|
|
8000ef8: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8000efa: 4b37 ldr r3, [pc, #220] ; (8000fd8 <MX_GPIO_Init+0x128>)
|
|
8000efc: 2102 movs r1, #2
|
|
8000efe: 430a orrs r2, r1
|
|
8000f00: 62da str r2, [r3, #44] ; 0x2c
|
|
8000f02: 4b35 ldr r3, [pc, #212] ; (8000fd8 <MX_GPIO_Init+0x128>)
|
|
8000f04: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
8000f06: 2202 movs r2, #2
|
|
8000f08: 4013 ands r3, r2
|
|
8000f0a: 603b str r3, [r7, #0]
|
|
8000f0c: 683b ldr r3, [r7, #0]
|
|
|
|
/*Configure GPIO pin Output Level */
|
|
HAL_GPIO_WritePin(GPIOB, LED_ROUGE_Pin|LED_ORANGE_Pin|LED_VERTE_Pin|SHUTDOWN_ENCODERS_Pin
|
|
8000f0e: 23f1 movs r3, #241 ; 0xf1
|
|
8000f10: 021b lsls r3, r3, #8
|
|
8000f12: 4832 ldr r0, [pc, #200] ; (8000fdc <MX_GPIO_Init+0x12c>)
|
|
8000f14: 2200 movs r2, #0
|
|
8000f16: 0019 movs r1, r3
|
|
8000f18: f001 faf2 bl 8002500 <HAL_GPIO_WritePin>
|
|
|SHUTDOWN_5V_Pin, GPIO_PIN_RESET);
|
|
|
|
/*Configure GPIO pin Output Level */
|
|
HAL_GPIO_WritePin(SHUTDOWN_GPIO_Port, SHUTDOWN_Pin, GPIO_PIN_SET);
|
|
8000f1c: 2380 movs r3, #128 ; 0x80
|
|
8000f1e: 009b lsls r3, r3, #2
|
|
8000f20: 482e ldr r0, [pc, #184] ; (8000fdc <MX_GPIO_Init+0x12c>)
|
|
8000f22: 2201 movs r2, #1
|
|
8000f24: 0019 movs r1, r3
|
|
8000f26: f001 faeb bl 8002500 <HAL_GPIO_WritePin>
|
|
|
|
/*Configure GPIO pins : LED_ROUGE_Pin LED_ORANGE_Pin LED_VERTE_Pin */
|
|
GPIO_InitStruct.Pin = LED_ROUGE_Pin|LED_ORANGE_Pin|LED_VERTE_Pin;
|
|
8000f2a: 193b adds r3, r7, r4
|
|
8000f2c: 22e0 movs r2, #224 ; 0xe0
|
|
8000f2e: 01d2 lsls r2, r2, #7
|
|
8000f30: 601a str r2, [r3, #0]
|
|
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
|
8000f32: 193b adds r3, r7, r4
|
|
8000f34: 2201 movs r2, #1
|
|
8000f36: 605a str r2, [r3, #4]
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
8000f38: 193b adds r3, r7, r4
|
|
8000f3a: 2200 movs r2, #0
|
|
8000f3c: 609a str r2, [r3, #8]
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
|
8000f3e: 193b adds r3, r7, r4
|
|
8000f40: 2203 movs r2, #3
|
|
8000f42: 60da str r2, [r3, #12]
|
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
8000f44: 193b adds r3, r7, r4
|
|
8000f46: 4a25 ldr r2, [pc, #148] ; (8000fdc <MX_GPIO_Init+0x12c>)
|
|
8000f48: 0019 movs r1, r3
|
|
8000f4a: 0010 movs r0, r2
|
|
8000f4c: f001 f96a bl 8002224 <HAL_GPIO_Init>
|
|
|
|
/*Configure GPIO pins : SHUTDOWN_ENCODERS_Pin SHUTDOWN_5V_Pin SHUTDOWN_Pin */
|
|
GPIO_InitStruct.Pin = SHUTDOWN_ENCODERS_Pin|SHUTDOWN_5V_Pin|SHUTDOWN_Pin;
|
|
8000f50: 0021 movs r1, r4
|
|
8000f52: 187b adds r3, r7, r1
|
|
8000f54: 2283 movs r2, #131 ; 0x83
|
|
8000f56: 0212 lsls r2, r2, #8
|
|
8000f58: 601a str r2, [r3, #0]
|
|
GPIO_InitStruct.Mode = GPIO_MODE_OUTPUT_PP;
|
|
8000f5a: 000c movs r4, r1
|
|
8000f5c: 193b adds r3, r7, r4
|
|
8000f5e: 2201 movs r2, #1
|
|
8000f60: 605a str r2, [r3, #4]
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
8000f62: 193b adds r3, r7, r4
|
|
8000f64: 2200 movs r2, #0
|
|
8000f66: 609a str r2, [r3, #8]
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
8000f68: 193b adds r3, r7, r4
|
|
8000f6a: 2200 movs r2, #0
|
|
8000f6c: 60da str r2, [r3, #12]
|
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
8000f6e: 193b adds r3, r7, r4
|
|
8000f70: 4a1a ldr r2, [pc, #104] ; (8000fdc <MX_GPIO_Init+0x12c>)
|
|
8000f72: 0019 movs r1, r3
|
|
8000f74: 0010 movs r0, r2
|
|
8000f76: f001 f955 bl 8002224 <HAL_GPIO_Init>
|
|
|
|
/*Configure GPIO pins : BUTTON_SENSE_Pin USB_SENSE_Pin */
|
|
GPIO_InitStruct.Pin = BUTTON_SENSE_Pin|USB_SENSE_Pin;
|
|
8000f7a: 0021 movs r1, r4
|
|
8000f7c: 187b adds r3, r7, r1
|
|
8000f7e: 2218 movs r2, #24
|
|
8000f80: 601a str r2, [r3, #0]
|
|
GPIO_InitStruct.Mode = GPIO_MODE_IT_RISING;
|
|
8000f82: 187b adds r3, r7, r1
|
|
8000f84: 2288 movs r2, #136 ; 0x88
|
|
8000f86: 0352 lsls r2, r2, #13
|
|
8000f88: 605a str r2, [r3, #4]
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
8000f8a: 187b adds r3, r7, r1
|
|
8000f8c: 2200 movs r2, #0
|
|
8000f8e: 609a str r2, [r3, #8]
|
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
8000f90: 000c movs r4, r1
|
|
8000f92: 187b adds r3, r7, r1
|
|
8000f94: 4a11 ldr r2, [pc, #68] ; (8000fdc <MX_GPIO_Init+0x12c>)
|
|
8000f96: 0019 movs r1, r3
|
|
8000f98: 0010 movs r0, r2
|
|
8000f9a: f001 f943 bl 8002224 <HAL_GPIO_Init>
|
|
|
|
/*Configure GPIO pins : CHARGER_ST2_Pin CHARGER_ST1_Pin */
|
|
GPIO_InitStruct.Pin = CHARGER_ST2_Pin|CHARGER_ST1_Pin;
|
|
8000f9e: 0021 movs r1, r4
|
|
8000fa0: 187b adds r3, r7, r1
|
|
8000fa2: 22c0 movs r2, #192 ; 0xc0
|
|
8000fa4: 601a str r2, [r3, #0]
|
|
GPIO_InitStruct.Mode = GPIO_MODE_INPUT;
|
|
8000fa6: 187b adds r3, r7, r1
|
|
8000fa8: 2200 movs r2, #0
|
|
8000faa: 605a str r2, [r3, #4]
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
8000fac: 187b adds r3, r7, r1
|
|
8000fae: 2200 movs r2, #0
|
|
8000fb0: 609a str r2, [r3, #8]
|
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
8000fb2: 187b adds r3, r7, r1
|
|
8000fb4: 4a09 ldr r2, [pc, #36] ; (8000fdc <MX_GPIO_Init+0x12c>)
|
|
8000fb6: 0019 movs r1, r3
|
|
8000fb8: 0010 movs r0, r2
|
|
8000fba: f001 f933 bl 8002224 <HAL_GPIO_Init>
|
|
|
|
/* EXTI interrupt init*/
|
|
HAL_NVIC_SetPriority(EXTI2_3_IRQn, 3, 0);
|
|
8000fbe: 2200 movs r2, #0
|
|
8000fc0: 2103 movs r1, #3
|
|
8000fc2: 2006 movs r0, #6
|
|
8000fc4: f000 ff4e bl 8001e64 <HAL_NVIC_SetPriority>
|
|
HAL_NVIC_EnableIRQ(EXTI2_3_IRQn);
|
|
8000fc8: 2006 movs r0, #6
|
|
8000fca: f000 ff60 bl 8001e8e <HAL_NVIC_EnableIRQ>
|
|
}
|
|
8000fce: 46c0 nop ; (mov r8, r8)
|
|
8000fd0: 46bd mov sp, r7
|
|
8000fd2: b009 add sp, #36 ; 0x24
|
|
8000fd4: bd90 pop {r4, r7, pc}
|
|
8000fd6: 46c0 nop ; (mov r8, r8)
|
|
8000fd8: 40021000 .word 0x40021000
|
|
8000fdc: 50000400 .word 0x50000400
|
|
|
|
08000fe0 <StartDefaultTask>:
|
|
* @param argument: Not used
|
|
* @retval None
|
|
*/
|
|
/* USER CODE END Header_StartDefaultTask */
|
|
void StartDefaultTask(void *argument)
|
|
{
|
|
8000fe0: b590 push {r4, r7, lr}
|
|
8000fe2: b085 sub sp, #20
|
|
8000fe4: af00 add r7, sp, #0
|
|
8000fe6: 6078 str r0, [r7, #4]
|
|
/* USER CODE BEGIN 5 */
|
|
LEDS_State state = leds_off;
|
|
8000fe8: 230f movs r3, #15
|
|
8000fea: 18fb adds r3, r7, r3
|
|
8000fec: 2200 movs r2, #0
|
|
8000fee: 701a strb r2, [r3, #0]
|
|
|
|
/* Infinite loop */
|
|
for(;;)
|
|
{
|
|
state++;
|
|
8000ff0: 210f movs r1, #15
|
|
8000ff2: 187b adds r3, r7, r1
|
|
8000ff4: 781b ldrb r3, [r3, #0]
|
|
8000ff6: 3301 adds r3, #1
|
|
8000ff8: b2da uxtb r2, r3
|
|
8000ffa: 187b adds r3, r7, r1
|
|
8000ffc: 701a strb r2, [r3, #0]
|
|
MESSAGE_SendMailbox(LEDS_Mailbox, MSG_ID_LED_ETAT, SEQUENCEUR_Mailbox, (void*)&state);
|
|
8000ffe: 4b0b ldr r3, [pc, #44] ; (800102c <StartDefaultTask+0x4c>)
|
|
8001000: 6818 ldr r0, [r3, #0]
|
|
8001002: 4b0b ldr r3, [pc, #44] ; (8001030 <StartDefaultTask+0x50>)
|
|
8001004: 681a ldr r2, [r3, #0]
|
|
8001006: 000c movs r4, r1
|
|
8001008: 187b adds r3, r7, r1
|
|
800100a: 2100 movs r1, #0
|
|
800100c: f000 f872 bl 80010f4 <MESSAGE_SendMailbox>
|
|
|
|
if (state>leds_erreur)
|
|
8001010: 0021 movs r1, r4
|
|
8001012: 187b adds r3, r7, r1
|
|
8001014: 781b ldrb r3, [r3, #0]
|
|
8001016: 2b10 cmp r3, #16
|
|
8001018: d902 bls.n 8001020 <StartDefaultTask+0x40>
|
|
state = leds_off;
|
|
800101a: 187b adds r3, r7, r1
|
|
800101c: 2200 movs r2, #0
|
|
800101e: 701a strb r2, [r3, #0]
|
|
|
|
vTaskDelay(pdMS_TO_TICKS(5000));
|
|
8001020: 23fa movs r3, #250 ; 0xfa
|
|
8001022: 005b lsls r3, r3, #1
|
|
8001024: 0018 movs r0, r3
|
|
8001026: f004 fedb bl 8005de0 <vTaskDelay>
|
|
state++;
|
|
800102a: e7e1 b.n 8000ff0 <StartDefaultTask+0x10>
|
|
800102c: 20001964 .word 0x20001964
|
|
8001030: 20001960 .word 0x20001960
|
|
|
|
08001034 <Error_Handler>:
|
|
/**
|
|
* @brief This function is executed in case of error occurrence.
|
|
* @retval None
|
|
*/
|
|
void Error_Handler(void)
|
|
{
|
|
8001034: b580 push {r7, lr}
|
|
8001036: 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");
|
|
8001038: b672 cpsid i
|
|
}
|
|
800103a: 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)
|
|
800103c: e7fe b.n 800103c <Error_Handler+0x8>
|
|
...
|
|
|
|
08001040 <MESSAGE_Init>:
|
|
QueueHandle_t MOTEURS_Mailbox;
|
|
QueueHandle_t SEQUENCEUR_Mailbox;
|
|
QueueHandle_t BATTERIE_Mailbox;
|
|
QueueHandle_t XBEE_Mailbox;
|
|
|
|
void MESSAGE_Init(void) {
|
|
8001040: b580 push {r7, lr}
|
|
8001042: af00 add r7, sp, #0
|
|
LEDS_Mailbox = xQueueCreate(QUEUE_SIZE, sizeof(MESSAGE_Typedef));
|
|
8001044: 2200 movs r2, #0
|
|
8001046: 210c movs r1, #12
|
|
8001048: 2005 movs r0, #5
|
|
800104a: f004 f980 bl 800534e <xQueueGenericCreate>
|
|
800104e: 0002 movs r2, r0
|
|
8001050: 4b12 ldr r3, [pc, #72] ; (800109c <MESSAGE_Init+0x5c>)
|
|
8001052: 601a str r2, [r3, #0]
|
|
MOTEURS_Mailbox = xQueueCreate(QUEUE_SIZE, sizeof(MESSAGE_Typedef));
|
|
8001054: 2200 movs r2, #0
|
|
8001056: 210c movs r1, #12
|
|
8001058: 2005 movs r0, #5
|
|
800105a: f004 f978 bl 800534e <xQueueGenericCreate>
|
|
800105e: 0002 movs r2, r0
|
|
8001060: 4b0f ldr r3, [pc, #60] ; (80010a0 <MESSAGE_Init+0x60>)
|
|
8001062: 601a str r2, [r3, #0]
|
|
SEQUENCEUR_Mailbox = xQueueCreate(QUEUE_SIZE, sizeof(MESSAGE_Typedef));
|
|
8001064: 2200 movs r2, #0
|
|
8001066: 210c movs r1, #12
|
|
8001068: 2005 movs r0, #5
|
|
800106a: f004 f970 bl 800534e <xQueueGenericCreate>
|
|
800106e: 0002 movs r2, r0
|
|
8001070: 4b0c ldr r3, [pc, #48] ; (80010a4 <MESSAGE_Init+0x64>)
|
|
8001072: 601a str r2, [r3, #0]
|
|
BATTERIE_Mailbox = xQueueCreate(QUEUE_SIZE, sizeof(MESSAGE_Typedef));
|
|
8001074: 2200 movs r2, #0
|
|
8001076: 210c movs r1, #12
|
|
8001078: 2005 movs r0, #5
|
|
800107a: f004 f968 bl 800534e <xQueueGenericCreate>
|
|
800107e: 0002 movs r2, r0
|
|
8001080: 4b09 ldr r3, [pc, #36] ; (80010a8 <MESSAGE_Init+0x68>)
|
|
8001082: 601a str r2, [r3, #0]
|
|
XBEE_Mailbox = xQueueCreate(QUEUE_SIZE, sizeof(MESSAGE_Typedef));
|
|
8001084: 2200 movs r2, #0
|
|
8001086: 210c movs r1, #12
|
|
8001088: 2005 movs r0, #5
|
|
800108a: f004 f960 bl 800534e <xQueueGenericCreate>
|
|
800108e: 0002 movs r2, r0
|
|
8001090: 4b06 ldr r3, [pc, #24] ; (80010ac <MESSAGE_Init+0x6c>)
|
|
8001092: 601a str r2, [r3, #0]
|
|
}
|
|
8001094: 46c0 nop ; (mov r8, r8)
|
|
8001096: 46bd mov sp, r7
|
|
8001098: bd80 pop {r7, pc}
|
|
800109a: 46c0 nop ; (mov r8, r8)
|
|
800109c: 20001964 .word 0x20001964
|
|
80010a0: 20001958 .word 0x20001958
|
|
80010a4: 20001960 .word 0x20001960
|
|
80010a8: 2000195c .word 0x2000195c
|
|
80010ac: 20001954 .word 0x20001954
|
|
|
|
080010b0 <MESSAGE_ReadMailboxNoDelay>:
|
|
}
|
|
|
|
return msg;
|
|
}
|
|
|
|
MESSAGE_Typedef MESSAGE_ReadMailboxNoDelay(QueueHandle_t mbx) {
|
|
80010b0: b590 push {r4, r7, lr}
|
|
80010b2: b087 sub sp, #28
|
|
80010b4: af00 add r7, sp, #0
|
|
80010b6: 6078 str r0, [r7, #4]
|
|
80010b8: 6039 str r1, [r7, #0]
|
|
MESSAGE_Typedef msg= {0};
|
|
80010ba: 240c movs r4, #12
|
|
80010bc: 193b adds r3, r7, r4
|
|
80010be: 0018 movs r0, r3
|
|
80010c0: 230c movs r3, #12
|
|
80010c2: 001a movs r2, r3
|
|
80010c4: 2100 movs r1, #0
|
|
80010c6: f006 fb7a bl 80077be <memset>
|
|
|
|
if (!xQueueReceive(mbx, &msg, 0)) // Pas de message dans la mailbox
|
|
80010ca: 1939 adds r1, r7, r4
|
|
80010cc: 683b ldr r3, [r7, #0]
|
|
80010ce: 2200 movs r2, #0
|
|
80010d0: 0018 movs r0, r3
|
|
80010d2: f004 fad0 bl 8005676 <xQueueReceive>
|
|
80010d6: 1e03 subs r3, r0, #0
|
|
80010d8: d103 bne.n 80010e2 <MESSAGE_ReadMailboxNoDelay+0x32>
|
|
msg.id=MSG_ID_NO_MESSAGE;
|
|
80010da: 193b adds r3, r7, r4
|
|
80010dc: 2201 movs r2, #1
|
|
80010de: 4252 negs r2, r2
|
|
80010e0: 801a strh r2, [r3, #0]
|
|
|
|
return msg;
|
|
80010e2: 687b ldr r3, [r7, #4]
|
|
80010e4: 220c movs r2, #12
|
|
80010e6: 18ba adds r2, r7, r2
|
|
80010e8: ca13 ldmia r2!, {r0, r1, r4}
|
|
80010ea: c313 stmia r3!, {r0, r1, r4}
|
|
}
|
|
80010ec: 6878 ldr r0, [r7, #4]
|
|
80010ee: 46bd mov sp, r7
|
|
80010f0: b007 add sp, #28
|
|
80010f2: bd90 pop {r4, r7, pc}
|
|
|
|
080010f4 <MESSAGE_SendMailbox>:
|
|
|
|
void MESSAGE_SendMailbox(QueueHandle_t mbx_dest, uint16_t id, QueueHandle_t mbx_sender, void *data){
|
|
80010f4: b580 push {r7, lr}
|
|
80010f6: b088 sub sp, #32
|
|
80010f8: af00 add r7, sp, #0
|
|
80010fa: 60f8 str r0, [r7, #12]
|
|
80010fc: 607a str r2, [r7, #4]
|
|
80010fe: 603b str r3, [r7, #0]
|
|
8001100: 200a movs r0, #10
|
|
8001102: 183b adds r3, r7, r0
|
|
8001104: 1c0a adds r2, r1, #0
|
|
8001106: 801a strh r2, [r3, #0]
|
|
MESSAGE_Typedef msg;
|
|
|
|
msg.id=id;
|
|
8001108: 2114 movs r1, #20
|
|
800110a: 187b adds r3, r7, r1
|
|
800110c: 183a adds r2, r7, r0
|
|
800110e: 8812 ldrh r2, [r2, #0]
|
|
8001110: 801a strh r2, [r3, #0]
|
|
msg.sender = &mbx_sender;
|
|
8001112: 187b adds r3, r7, r1
|
|
8001114: 1d3a adds r2, r7, #4
|
|
8001116: 605a str r2, [r3, #4]
|
|
msg.data=data;
|
|
8001118: 187b adds r3, r7, r1
|
|
800111a: 683a ldr r2, [r7, #0]
|
|
800111c: 609a str r2, [r3, #8]
|
|
|
|
if (!xQueueSend(mbx_dest, &msg, 0)) { // envoi sans attendre
|
|
800111e: 1879 adds r1, r7, r1
|
|
8001120: 68f8 ldr r0, [r7, #12]
|
|
8001122: 2300 movs r3, #0
|
|
8001124: 2200 movs r2, #0
|
|
8001126: f004 f971 bl 800540c <xQueueGenericSend>
|
|
//printf("Failed to send data, Queue full.\r\n");
|
|
}
|
|
}
|
|
800112a: 46c0 nop ; (mov r8, r8)
|
|
800112c: 46bd mov sp, r7
|
|
800112e: b008 add sp, #32
|
|
8001130: bd80 pop {r7, pc}
|
|
...
|
|
|
|
08001134 <HAL_MspInit>:
|
|
void HAL_TIM_MspPostInit(TIM_HandleTypeDef *htim);
|
|
/**
|
|
* Initializes the Global MSP.
|
|
*/
|
|
void HAL_MspInit(void)
|
|
{
|
|
8001134: b580 push {r7, lr}
|
|
8001136: af00 add r7, sp, #0
|
|
/* USER CODE BEGIN MspInit 0 */
|
|
|
|
/* USER CODE END MspInit 0 */
|
|
|
|
__HAL_RCC_SYSCFG_CLK_ENABLE();
|
|
8001138: 4b0b ldr r3, [pc, #44] ; (8001168 <HAL_MspInit+0x34>)
|
|
800113a: 6b5a ldr r2, [r3, #52] ; 0x34
|
|
800113c: 4b0a ldr r3, [pc, #40] ; (8001168 <HAL_MspInit+0x34>)
|
|
800113e: 2101 movs r1, #1
|
|
8001140: 430a orrs r2, r1
|
|
8001142: 635a str r2, [r3, #52] ; 0x34
|
|
__HAL_RCC_PWR_CLK_ENABLE();
|
|
8001144: 4b08 ldr r3, [pc, #32] ; (8001168 <HAL_MspInit+0x34>)
|
|
8001146: 6b9a ldr r2, [r3, #56] ; 0x38
|
|
8001148: 4b07 ldr r3, [pc, #28] ; (8001168 <HAL_MspInit+0x34>)
|
|
800114a: 2180 movs r1, #128 ; 0x80
|
|
800114c: 0549 lsls r1, r1, #21
|
|
800114e: 430a orrs r2, r1
|
|
8001150: 639a str r2, [r3, #56] ; 0x38
|
|
|
|
/* System interrupt init*/
|
|
/* PendSV_IRQn interrupt configuration */
|
|
HAL_NVIC_SetPriority(PendSV_IRQn, 3, 0);
|
|
8001152: 2302 movs r3, #2
|
|
8001154: 425b negs r3, r3
|
|
8001156: 2200 movs r2, #0
|
|
8001158: 2103 movs r1, #3
|
|
800115a: 0018 movs r0, r3
|
|
800115c: f000 fe82 bl 8001e64 <HAL_NVIC_SetPriority>
|
|
|
|
/* USER CODE BEGIN MspInit 1 */
|
|
|
|
/* USER CODE END MspInit 1 */
|
|
}
|
|
8001160: 46c0 nop ; (mov r8, r8)
|
|
8001162: 46bd mov sp, r7
|
|
8001164: bd80 pop {r7, pc}
|
|
8001166: 46c0 nop ; (mov r8, r8)
|
|
8001168: 40021000 .word 0x40021000
|
|
|
|
0800116c <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)
|
|
{
|
|
800116c: b590 push {r4, r7, lr}
|
|
800116e: b089 sub sp, #36 ; 0x24
|
|
8001170: af00 add r7, sp, #0
|
|
8001172: 6078 str r0, [r7, #4]
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
8001174: 240c movs r4, #12
|
|
8001176: 193b adds r3, r7, r4
|
|
8001178: 0018 movs r0, r3
|
|
800117a: 2314 movs r3, #20
|
|
800117c: 001a movs r2, r3
|
|
800117e: 2100 movs r1, #0
|
|
8001180: f006 fb1d bl 80077be <memset>
|
|
if(hadc->Instance==ADC1)
|
|
8001184: 687b ldr r3, [r7, #4]
|
|
8001186: 681b ldr r3, [r3, #0]
|
|
8001188: 4a18 ldr r2, [pc, #96] ; (80011ec <HAL_ADC_MspInit+0x80>)
|
|
800118a: 4293 cmp r3, r2
|
|
800118c: d12a bne.n 80011e4 <HAL_ADC_MspInit+0x78>
|
|
{
|
|
/* USER CODE BEGIN ADC1_MspInit 0 */
|
|
|
|
/* USER CODE END ADC1_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_ADC1_CLK_ENABLE();
|
|
800118e: 4b18 ldr r3, [pc, #96] ; (80011f0 <HAL_ADC_MspInit+0x84>)
|
|
8001190: 6b5a ldr r2, [r3, #52] ; 0x34
|
|
8001192: 4b17 ldr r3, [pc, #92] ; (80011f0 <HAL_ADC_MspInit+0x84>)
|
|
8001194: 2180 movs r1, #128 ; 0x80
|
|
8001196: 0089 lsls r1, r1, #2
|
|
8001198: 430a orrs r2, r1
|
|
800119a: 635a str r2, [r3, #52] ; 0x34
|
|
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
800119c: 4b14 ldr r3, [pc, #80] ; (80011f0 <HAL_ADC_MspInit+0x84>)
|
|
800119e: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
80011a0: 4b13 ldr r3, [pc, #76] ; (80011f0 <HAL_ADC_MspInit+0x84>)
|
|
80011a2: 2101 movs r1, #1
|
|
80011a4: 430a orrs r2, r1
|
|
80011a6: 62da str r2, [r3, #44] ; 0x2c
|
|
80011a8: 4b11 ldr r3, [pc, #68] ; (80011f0 <HAL_ADC_MspInit+0x84>)
|
|
80011aa: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
80011ac: 2201 movs r2, #1
|
|
80011ae: 4013 ands r3, r2
|
|
80011b0: 60bb str r3, [r7, #8]
|
|
80011b2: 68bb ldr r3, [r7, #8]
|
|
/**ADC GPIO Configuration
|
|
PA0 ------> ADC_IN0
|
|
*/
|
|
GPIO_InitStruct.Pin = BATTERY_SENSE_Pin;
|
|
80011b4: 193b adds r3, r7, r4
|
|
80011b6: 2201 movs r2, #1
|
|
80011b8: 601a str r2, [r3, #0]
|
|
GPIO_InitStruct.Mode = GPIO_MODE_ANALOG;
|
|
80011ba: 193b adds r3, r7, r4
|
|
80011bc: 2203 movs r2, #3
|
|
80011be: 605a str r2, [r3, #4]
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
80011c0: 193b adds r3, r7, r4
|
|
80011c2: 2200 movs r2, #0
|
|
80011c4: 609a str r2, [r3, #8]
|
|
HAL_GPIO_Init(BATTERY_SENSE_GPIO_Port, &GPIO_InitStruct);
|
|
80011c6: 193a adds r2, r7, r4
|
|
80011c8: 23a0 movs r3, #160 ; 0xa0
|
|
80011ca: 05db lsls r3, r3, #23
|
|
80011cc: 0011 movs r1, r2
|
|
80011ce: 0018 movs r0, r3
|
|
80011d0: f001 f828 bl 8002224 <HAL_GPIO_Init>
|
|
|
|
/* ADC1 interrupt Init */
|
|
HAL_NVIC_SetPriority(ADC1_IRQn, 3, 0);
|
|
80011d4: 2200 movs r2, #0
|
|
80011d6: 2103 movs r1, #3
|
|
80011d8: 200c movs r0, #12
|
|
80011da: f000 fe43 bl 8001e64 <HAL_NVIC_SetPriority>
|
|
HAL_NVIC_EnableIRQ(ADC1_IRQn);
|
|
80011de: 200c movs r0, #12
|
|
80011e0: f000 fe55 bl 8001e8e <HAL_NVIC_EnableIRQ>
|
|
/* USER CODE BEGIN ADC1_MspInit 1 */
|
|
|
|
/* USER CODE END ADC1_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
80011e4: 46c0 nop ; (mov r8, r8)
|
|
80011e6: 46bd mov sp, r7
|
|
80011e8: b009 add sp, #36 ; 0x24
|
|
80011ea: bd90 pop {r4, r7, pc}
|
|
80011ec: 40012400 .word 0x40012400
|
|
80011f0: 40021000 .word 0x40021000
|
|
|
|
080011f4 <HAL_LPTIM_MspInit>:
|
|
* This function configures the hardware resources used in this example
|
|
* @param hlptim: LPTIM handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_LPTIM_MspInit(LPTIM_HandleTypeDef* hlptim)
|
|
{
|
|
80011f4: b590 push {r4, r7, lr}
|
|
80011f6: b08b sub sp, #44 ; 0x2c
|
|
80011f8: af00 add r7, sp, #0
|
|
80011fa: 6078 str r0, [r7, #4]
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
80011fc: 2414 movs r4, #20
|
|
80011fe: 193b adds r3, r7, r4
|
|
8001200: 0018 movs r0, r3
|
|
8001202: 2314 movs r3, #20
|
|
8001204: 001a movs r2, r3
|
|
8001206: 2100 movs r1, #0
|
|
8001208: f006 fad9 bl 80077be <memset>
|
|
if(hlptim->Instance==LPTIM1)
|
|
800120c: 687b ldr r3, [r7, #4]
|
|
800120e: 681b ldr r3, [r3, #0]
|
|
8001210: 4a28 ldr r2, [pc, #160] ; (80012b4 <HAL_LPTIM_MspInit+0xc0>)
|
|
8001212: 4293 cmp r3, r2
|
|
8001214: d14a bne.n 80012ac <HAL_LPTIM_MspInit+0xb8>
|
|
{
|
|
/* USER CODE BEGIN LPTIM1_MspInit 0 */
|
|
|
|
/* USER CODE END LPTIM1_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_LPTIM1_CLK_ENABLE();
|
|
8001216: 4b28 ldr r3, [pc, #160] ; (80012b8 <HAL_LPTIM_MspInit+0xc4>)
|
|
8001218: 6b9a ldr r2, [r3, #56] ; 0x38
|
|
800121a: 4b27 ldr r3, [pc, #156] ; (80012b8 <HAL_LPTIM_MspInit+0xc4>)
|
|
800121c: 2180 movs r1, #128 ; 0x80
|
|
800121e: 0609 lsls r1, r1, #24
|
|
8001220: 430a orrs r2, r1
|
|
8001222: 639a str r2, [r3, #56] ; 0x38
|
|
|
|
__HAL_RCC_GPIOC_CLK_ENABLE();
|
|
8001224: 4b24 ldr r3, [pc, #144] ; (80012b8 <HAL_LPTIM_MspInit+0xc4>)
|
|
8001226: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8001228: 4b23 ldr r3, [pc, #140] ; (80012b8 <HAL_LPTIM_MspInit+0xc4>)
|
|
800122a: 2104 movs r1, #4
|
|
800122c: 430a orrs r2, r1
|
|
800122e: 62da str r2, [r3, #44] ; 0x2c
|
|
8001230: 4b21 ldr r3, [pc, #132] ; (80012b8 <HAL_LPTIM_MspInit+0xc4>)
|
|
8001232: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
8001234: 2204 movs r2, #4
|
|
8001236: 4013 ands r3, r2
|
|
8001238: 613b str r3, [r7, #16]
|
|
800123a: 693b ldr r3, [r7, #16]
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
800123c: 4b1e ldr r3, [pc, #120] ; (80012b8 <HAL_LPTIM_MspInit+0xc4>)
|
|
800123e: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8001240: 4b1d ldr r3, [pc, #116] ; (80012b8 <HAL_LPTIM_MspInit+0xc4>)
|
|
8001242: 2101 movs r1, #1
|
|
8001244: 430a orrs r2, r1
|
|
8001246: 62da str r2, [r3, #44] ; 0x2c
|
|
8001248: 4b1b ldr r3, [pc, #108] ; (80012b8 <HAL_LPTIM_MspInit+0xc4>)
|
|
800124a: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
800124c: 2201 movs r2, #1
|
|
800124e: 4013 ands r3, r2
|
|
8001250: 60fb str r3, [r7, #12]
|
|
8001252: 68fb ldr r3, [r7, #12]
|
|
/**LPTIM1 GPIO Configuration
|
|
PC0 ------> LPTIM1_IN1
|
|
PA5 ------> LPTIM1_IN2
|
|
*/
|
|
GPIO_InitStruct.Pin = ENC_PHA_GAUCHE_Pin;
|
|
8001254: 193b adds r3, r7, r4
|
|
8001256: 2201 movs r2, #1
|
|
8001258: 601a str r2, [r3, #0]
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
800125a: 193b adds r3, r7, r4
|
|
800125c: 2202 movs r2, #2
|
|
800125e: 605a str r2, [r3, #4]
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
8001260: 193b adds r3, r7, r4
|
|
8001262: 2200 movs r2, #0
|
|
8001264: 609a str r2, [r3, #8]
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
8001266: 193b adds r3, r7, r4
|
|
8001268: 2200 movs r2, #0
|
|
800126a: 60da str r2, [r3, #12]
|
|
GPIO_InitStruct.Alternate = GPIO_AF0_LPTIM1;
|
|
800126c: 193b adds r3, r7, r4
|
|
800126e: 2200 movs r2, #0
|
|
8001270: 611a str r2, [r3, #16]
|
|
HAL_GPIO_Init(ENC_PHA_GAUCHE_GPIO_Port, &GPIO_InitStruct);
|
|
8001272: 193b adds r3, r7, r4
|
|
8001274: 4a11 ldr r2, [pc, #68] ; (80012bc <HAL_LPTIM_MspInit+0xc8>)
|
|
8001276: 0019 movs r1, r3
|
|
8001278: 0010 movs r0, r2
|
|
800127a: f000 ffd3 bl 8002224 <HAL_GPIO_Init>
|
|
|
|
GPIO_InitStruct.Pin = ENC_PHB_GAUCHE_Pin;
|
|
800127e: 0021 movs r1, r4
|
|
8001280: 187b adds r3, r7, r1
|
|
8001282: 2220 movs r2, #32
|
|
8001284: 601a str r2, [r3, #0]
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
8001286: 187b adds r3, r7, r1
|
|
8001288: 2202 movs r2, #2
|
|
800128a: 605a str r2, [r3, #4]
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
800128c: 187b adds r3, r7, r1
|
|
800128e: 2200 movs r2, #0
|
|
8001290: 609a str r2, [r3, #8]
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
8001292: 187b adds r3, r7, r1
|
|
8001294: 2200 movs r2, #0
|
|
8001296: 60da str r2, [r3, #12]
|
|
GPIO_InitStruct.Alternate = GPIO_AF1_LPTIM1;
|
|
8001298: 187b adds r3, r7, r1
|
|
800129a: 2201 movs r2, #1
|
|
800129c: 611a str r2, [r3, #16]
|
|
HAL_GPIO_Init(ENC_PHB_GAUCHE_GPIO_Port, &GPIO_InitStruct);
|
|
800129e: 187a adds r2, r7, r1
|
|
80012a0: 23a0 movs r3, #160 ; 0xa0
|
|
80012a2: 05db lsls r3, r3, #23
|
|
80012a4: 0011 movs r1, r2
|
|
80012a6: 0018 movs r0, r3
|
|
80012a8: f000 ffbc bl 8002224 <HAL_GPIO_Init>
|
|
/* USER CODE BEGIN LPTIM1_MspInit 1 */
|
|
|
|
/* USER CODE END LPTIM1_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
80012ac: 46c0 nop ; (mov r8, r8)
|
|
80012ae: 46bd mov sp, r7
|
|
80012b0: b00b add sp, #44 ; 0x2c
|
|
80012b2: bd90 pop {r4, r7, pc}
|
|
80012b4: 40007c00 .word 0x40007c00
|
|
80012b8: 40021000 .word 0x40021000
|
|
80012bc: 50000800 .word 0x50000800
|
|
|
|
080012c0 <HAL_UART_MspInit>:
|
|
* This function configures the hardware resources used in this example
|
|
* @param huart: UART handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_UART_MspInit(UART_HandleTypeDef* huart)
|
|
{
|
|
80012c0: b590 push {r4, r7, lr}
|
|
80012c2: b089 sub sp, #36 ; 0x24
|
|
80012c4: af00 add r7, sp, #0
|
|
80012c6: 6078 str r0, [r7, #4]
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
80012c8: 240c movs r4, #12
|
|
80012ca: 193b adds r3, r7, r4
|
|
80012cc: 0018 movs r0, r3
|
|
80012ce: 2314 movs r3, #20
|
|
80012d0: 001a movs r2, r3
|
|
80012d2: 2100 movs r1, #0
|
|
80012d4: f006 fa73 bl 80077be <memset>
|
|
if(huart->Instance==LPUART1)
|
|
80012d8: 687b ldr r3, [r7, #4]
|
|
80012da: 681b ldr r3, [r3, #0]
|
|
80012dc: 4a46 ldr r2, [pc, #280] ; (80013f8 <HAL_UART_MspInit+0x138>)
|
|
80012de: 4293 cmp r3, r2
|
|
80012e0: d000 beq.n 80012e4 <HAL_UART_MspInit+0x24>
|
|
80012e2: e085 b.n 80013f0 <HAL_UART_MspInit+0x130>
|
|
{
|
|
/* USER CODE BEGIN LPUART1_MspInit 0 */
|
|
|
|
/* USER CODE END LPUART1_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_LPUART1_CLK_ENABLE();
|
|
80012e4: 4b45 ldr r3, [pc, #276] ; (80013fc <HAL_UART_MspInit+0x13c>)
|
|
80012e6: 6b9a ldr r2, [r3, #56] ; 0x38
|
|
80012e8: 4b44 ldr r3, [pc, #272] ; (80013fc <HAL_UART_MspInit+0x13c>)
|
|
80012ea: 2180 movs r1, #128 ; 0x80
|
|
80012ec: 02c9 lsls r1, r1, #11
|
|
80012ee: 430a orrs r2, r1
|
|
80012f0: 639a str r2, [r3, #56] ; 0x38
|
|
|
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
80012f2: 4b42 ldr r3, [pc, #264] ; (80013fc <HAL_UART_MspInit+0x13c>)
|
|
80012f4: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
80012f6: 4b41 ldr r3, [pc, #260] ; (80013fc <HAL_UART_MspInit+0x13c>)
|
|
80012f8: 2102 movs r1, #2
|
|
80012fa: 430a orrs r2, r1
|
|
80012fc: 62da str r2, [r3, #44] ; 0x2c
|
|
80012fe: 4b3f ldr r3, [pc, #252] ; (80013fc <HAL_UART_MspInit+0x13c>)
|
|
8001300: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
8001302: 2202 movs r2, #2
|
|
8001304: 4013 ands r3, r2
|
|
8001306: 60bb str r3, [r7, #8]
|
|
8001308: 68bb ldr r3, [r7, #8]
|
|
/**LPUART1 GPIO Configuration
|
|
PB10 ------> LPUART1_TX
|
|
PB11 ------> LPUART1_RX
|
|
*/
|
|
GPIO_InitStruct.Pin = GPIO_PIN_10|GPIO_PIN_11;
|
|
800130a: 193b adds r3, r7, r4
|
|
800130c: 22c0 movs r2, #192 ; 0xc0
|
|
800130e: 0112 lsls r2, r2, #4
|
|
8001310: 601a str r2, [r3, #0]
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
8001312: 0021 movs r1, r4
|
|
8001314: 187b adds r3, r7, r1
|
|
8001316: 2202 movs r2, #2
|
|
8001318: 605a str r2, [r3, #4]
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
800131a: 187b adds r3, r7, r1
|
|
800131c: 2200 movs r2, #0
|
|
800131e: 609a str r2, [r3, #8]
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_VERY_HIGH;
|
|
8001320: 187b adds r3, r7, r1
|
|
8001322: 2203 movs r2, #3
|
|
8001324: 60da str r2, [r3, #12]
|
|
GPIO_InitStruct.Alternate = GPIO_AF6_LPUART1;
|
|
8001326: 187b adds r3, r7, r1
|
|
8001328: 2206 movs r2, #6
|
|
800132a: 611a str r2, [r3, #16]
|
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
800132c: 187b adds r3, r7, r1
|
|
800132e: 4a34 ldr r2, [pc, #208] ; (8001400 <HAL_UART_MspInit+0x140>)
|
|
8001330: 0019 movs r1, r3
|
|
8001332: 0010 movs r0, r2
|
|
8001334: f000 ff76 bl 8002224 <HAL_GPIO_Init>
|
|
|
|
/* LPUART1 DMA Init */
|
|
/* LPUART1_RX Init */
|
|
hdma_lpuart1_rx.Instance = DMA1_Channel3;
|
|
8001338: 4b32 ldr r3, [pc, #200] ; (8001404 <HAL_UART_MspInit+0x144>)
|
|
800133a: 4a33 ldr r2, [pc, #204] ; (8001408 <HAL_UART_MspInit+0x148>)
|
|
800133c: 601a str r2, [r3, #0]
|
|
hdma_lpuart1_rx.Init.Request = DMA_REQUEST_5;
|
|
800133e: 4b31 ldr r3, [pc, #196] ; (8001404 <HAL_UART_MspInit+0x144>)
|
|
8001340: 2205 movs r2, #5
|
|
8001342: 605a str r2, [r3, #4]
|
|
hdma_lpuart1_rx.Init.Direction = DMA_PERIPH_TO_MEMORY;
|
|
8001344: 4b2f ldr r3, [pc, #188] ; (8001404 <HAL_UART_MspInit+0x144>)
|
|
8001346: 2200 movs r2, #0
|
|
8001348: 609a str r2, [r3, #8]
|
|
hdma_lpuart1_rx.Init.PeriphInc = DMA_PINC_DISABLE;
|
|
800134a: 4b2e ldr r3, [pc, #184] ; (8001404 <HAL_UART_MspInit+0x144>)
|
|
800134c: 2200 movs r2, #0
|
|
800134e: 60da str r2, [r3, #12]
|
|
hdma_lpuart1_rx.Init.MemInc = DMA_MINC_ENABLE;
|
|
8001350: 4b2c ldr r3, [pc, #176] ; (8001404 <HAL_UART_MspInit+0x144>)
|
|
8001352: 2280 movs r2, #128 ; 0x80
|
|
8001354: 611a str r2, [r3, #16]
|
|
hdma_lpuart1_rx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
|
|
8001356: 4b2b ldr r3, [pc, #172] ; (8001404 <HAL_UART_MspInit+0x144>)
|
|
8001358: 2200 movs r2, #0
|
|
800135a: 615a str r2, [r3, #20]
|
|
hdma_lpuart1_rx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
|
|
800135c: 4b29 ldr r3, [pc, #164] ; (8001404 <HAL_UART_MspInit+0x144>)
|
|
800135e: 2200 movs r2, #0
|
|
8001360: 619a str r2, [r3, #24]
|
|
hdma_lpuart1_rx.Init.Mode = DMA_NORMAL;
|
|
8001362: 4b28 ldr r3, [pc, #160] ; (8001404 <HAL_UART_MspInit+0x144>)
|
|
8001364: 2200 movs r2, #0
|
|
8001366: 61da str r2, [r3, #28]
|
|
hdma_lpuart1_rx.Init.Priority = DMA_PRIORITY_HIGH;
|
|
8001368: 4b26 ldr r3, [pc, #152] ; (8001404 <HAL_UART_MspInit+0x144>)
|
|
800136a: 2280 movs r2, #128 ; 0x80
|
|
800136c: 0192 lsls r2, r2, #6
|
|
800136e: 621a str r2, [r3, #32]
|
|
if (HAL_DMA_Init(&hdma_lpuart1_rx) != HAL_OK)
|
|
8001370: 4b24 ldr r3, [pc, #144] ; (8001404 <HAL_UART_MspInit+0x144>)
|
|
8001372: 0018 movs r0, r3
|
|
8001374: f000 fda8 bl 8001ec8 <HAL_DMA_Init>
|
|
8001378: 1e03 subs r3, r0, #0
|
|
800137a: d001 beq.n 8001380 <HAL_UART_MspInit+0xc0>
|
|
{
|
|
Error_Handler();
|
|
800137c: f7ff fe5a bl 8001034 <Error_Handler>
|
|
}
|
|
|
|
__HAL_LINKDMA(huart,hdmarx,hdma_lpuart1_rx);
|
|
8001380: 687b ldr r3, [r7, #4]
|
|
8001382: 4a20 ldr r2, [pc, #128] ; (8001404 <HAL_UART_MspInit+0x144>)
|
|
8001384: 671a str r2, [r3, #112] ; 0x70
|
|
8001386: 4b1f ldr r3, [pc, #124] ; (8001404 <HAL_UART_MspInit+0x144>)
|
|
8001388: 687a ldr r2, [r7, #4]
|
|
800138a: 629a str r2, [r3, #40] ; 0x28
|
|
|
|
/* LPUART1_TX Init */
|
|
hdma_lpuart1_tx.Instance = DMA1_Channel2;
|
|
800138c: 4b1f ldr r3, [pc, #124] ; (800140c <HAL_UART_MspInit+0x14c>)
|
|
800138e: 4a20 ldr r2, [pc, #128] ; (8001410 <HAL_UART_MspInit+0x150>)
|
|
8001390: 601a str r2, [r3, #0]
|
|
hdma_lpuart1_tx.Init.Request = DMA_REQUEST_5;
|
|
8001392: 4b1e ldr r3, [pc, #120] ; (800140c <HAL_UART_MspInit+0x14c>)
|
|
8001394: 2205 movs r2, #5
|
|
8001396: 605a str r2, [r3, #4]
|
|
hdma_lpuart1_tx.Init.Direction = DMA_MEMORY_TO_PERIPH;
|
|
8001398: 4b1c ldr r3, [pc, #112] ; (800140c <HAL_UART_MspInit+0x14c>)
|
|
800139a: 2210 movs r2, #16
|
|
800139c: 609a str r2, [r3, #8]
|
|
hdma_lpuart1_tx.Init.PeriphInc = DMA_PINC_DISABLE;
|
|
800139e: 4b1b ldr r3, [pc, #108] ; (800140c <HAL_UART_MspInit+0x14c>)
|
|
80013a0: 2200 movs r2, #0
|
|
80013a2: 60da str r2, [r3, #12]
|
|
hdma_lpuart1_tx.Init.MemInc = DMA_MINC_ENABLE;
|
|
80013a4: 4b19 ldr r3, [pc, #100] ; (800140c <HAL_UART_MspInit+0x14c>)
|
|
80013a6: 2280 movs r2, #128 ; 0x80
|
|
80013a8: 611a str r2, [r3, #16]
|
|
hdma_lpuart1_tx.Init.PeriphDataAlignment = DMA_PDATAALIGN_BYTE;
|
|
80013aa: 4b18 ldr r3, [pc, #96] ; (800140c <HAL_UART_MspInit+0x14c>)
|
|
80013ac: 2200 movs r2, #0
|
|
80013ae: 615a str r2, [r3, #20]
|
|
hdma_lpuart1_tx.Init.MemDataAlignment = DMA_MDATAALIGN_BYTE;
|
|
80013b0: 4b16 ldr r3, [pc, #88] ; (800140c <HAL_UART_MspInit+0x14c>)
|
|
80013b2: 2200 movs r2, #0
|
|
80013b4: 619a str r2, [r3, #24]
|
|
hdma_lpuart1_tx.Init.Mode = DMA_NORMAL;
|
|
80013b6: 4b15 ldr r3, [pc, #84] ; (800140c <HAL_UART_MspInit+0x14c>)
|
|
80013b8: 2200 movs r2, #0
|
|
80013ba: 61da str r2, [r3, #28]
|
|
hdma_lpuart1_tx.Init.Priority = DMA_PRIORITY_HIGH;
|
|
80013bc: 4b13 ldr r3, [pc, #76] ; (800140c <HAL_UART_MspInit+0x14c>)
|
|
80013be: 2280 movs r2, #128 ; 0x80
|
|
80013c0: 0192 lsls r2, r2, #6
|
|
80013c2: 621a str r2, [r3, #32]
|
|
if (HAL_DMA_Init(&hdma_lpuart1_tx) != HAL_OK)
|
|
80013c4: 4b11 ldr r3, [pc, #68] ; (800140c <HAL_UART_MspInit+0x14c>)
|
|
80013c6: 0018 movs r0, r3
|
|
80013c8: f000 fd7e bl 8001ec8 <HAL_DMA_Init>
|
|
80013cc: 1e03 subs r3, r0, #0
|
|
80013ce: d001 beq.n 80013d4 <HAL_UART_MspInit+0x114>
|
|
{
|
|
Error_Handler();
|
|
80013d0: f7ff fe30 bl 8001034 <Error_Handler>
|
|
}
|
|
|
|
__HAL_LINKDMA(huart,hdmatx,hdma_lpuart1_tx);
|
|
80013d4: 687b ldr r3, [r7, #4]
|
|
80013d6: 4a0d ldr r2, [pc, #52] ; (800140c <HAL_UART_MspInit+0x14c>)
|
|
80013d8: 66da str r2, [r3, #108] ; 0x6c
|
|
80013da: 4b0c ldr r3, [pc, #48] ; (800140c <HAL_UART_MspInit+0x14c>)
|
|
80013dc: 687a ldr r2, [r7, #4]
|
|
80013de: 629a str r2, [r3, #40] ; 0x28
|
|
|
|
/* LPUART1 interrupt Init */
|
|
HAL_NVIC_SetPriority(LPUART1_IRQn, 3, 0);
|
|
80013e0: 2200 movs r2, #0
|
|
80013e2: 2103 movs r1, #3
|
|
80013e4: 201d movs r0, #29
|
|
80013e6: f000 fd3d bl 8001e64 <HAL_NVIC_SetPriority>
|
|
HAL_NVIC_EnableIRQ(LPUART1_IRQn);
|
|
80013ea: 201d movs r0, #29
|
|
80013ec: f000 fd4f bl 8001e8e <HAL_NVIC_EnableIRQ>
|
|
/* USER CODE BEGIN LPUART1_MspInit 1 */
|
|
|
|
/* USER CODE END LPUART1_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
80013f0: 46c0 nop ; (mov r8, r8)
|
|
80013f2: 46bd mov sp, r7
|
|
80013f4: b009 add sp, #36 ; 0x24
|
|
80013f6: bd90 pop {r4, r7, pc}
|
|
80013f8: 40004800 .word 0x40004800
|
|
80013fc: 40021000 .word 0x40021000
|
|
8001400: 50000400 .word 0x50000400
|
|
8001404: 20001830 .word 0x20001830
|
|
8001408: 40020030 .word 0x40020030
|
|
800140c: 200017e8 .word 0x200017e8
|
|
8001410: 4002001c .word 0x4002001c
|
|
|
|
08001414 <HAL_TIM_Base_MspInit>:
|
|
* This function configures the hardware resources used in this example
|
|
* @param htim_base: TIM_Base handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_TIM_Base_MspInit(TIM_HandleTypeDef* htim_base)
|
|
{
|
|
8001414: b580 push {r7, lr}
|
|
8001416: b082 sub sp, #8
|
|
8001418: af00 add r7, sp, #0
|
|
800141a: 6078 str r0, [r7, #4]
|
|
if(htim_base->Instance==TIM2)
|
|
800141c: 687b ldr r3, [r7, #4]
|
|
800141e: 681a ldr r2, [r3, #0]
|
|
8001420: 2380 movs r3, #128 ; 0x80
|
|
8001422: 05db lsls r3, r3, #23
|
|
8001424: 429a cmp r2, r3
|
|
8001426: d105 bne.n 8001434 <HAL_TIM_Base_MspInit+0x20>
|
|
{
|
|
/* USER CODE BEGIN TIM2_MspInit 0 */
|
|
|
|
/* USER CODE END TIM2_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_TIM2_CLK_ENABLE();
|
|
8001428: 4b04 ldr r3, [pc, #16] ; (800143c <HAL_TIM_Base_MspInit+0x28>)
|
|
800142a: 6b9a ldr r2, [r3, #56] ; 0x38
|
|
800142c: 4b03 ldr r3, [pc, #12] ; (800143c <HAL_TIM_Base_MspInit+0x28>)
|
|
800142e: 2101 movs r1, #1
|
|
8001430: 430a orrs r2, r1
|
|
8001432: 639a str r2, [r3, #56] ; 0x38
|
|
/* USER CODE BEGIN TIM2_MspInit 1 */
|
|
|
|
/* USER CODE END TIM2_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
8001434: 46c0 nop ; (mov r8, r8)
|
|
8001436: 46bd mov sp, r7
|
|
8001438: b002 add sp, #8
|
|
800143a: bd80 pop {r7, pc}
|
|
800143c: 40021000 .word 0x40021000
|
|
|
|
08001440 <HAL_TIM_Encoder_MspInit>:
|
|
* This function configures the hardware resources used in this example
|
|
* @param htim_encoder: TIM_Encoder handle pointer
|
|
* @retval None
|
|
*/
|
|
void HAL_TIM_Encoder_MspInit(TIM_HandleTypeDef* htim_encoder)
|
|
{
|
|
8001440: b590 push {r4, r7, lr}
|
|
8001442: b089 sub sp, #36 ; 0x24
|
|
8001444: af00 add r7, sp, #0
|
|
8001446: 6078 str r0, [r7, #4]
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
8001448: 240c movs r4, #12
|
|
800144a: 193b adds r3, r7, r4
|
|
800144c: 0018 movs r0, r3
|
|
800144e: 2314 movs r3, #20
|
|
8001450: 001a movs r2, r3
|
|
8001452: 2100 movs r1, #0
|
|
8001454: f006 f9b3 bl 80077be <memset>
|
|
if(htim_encoder->Instance==TIM21)
|
|
8001458: 687b ldr r3, [r7, #4]
|
|
800145a: 681b ldr r3, [r3, #0]
|
|
800145c: 4a17 ldr r2, [pc, #92] ; (80014bc <HAL_TIM_Encoder_MspInit+0x7c>)
|
|
800145e: 4293 cmp r3, r2
|
|
8001460: d128 bne.n 80014b4 <HAL_TIM_Encoder_MspInit+0x74>
|
|
{
|
|
/* USER CODE BEGIN TIM21_MspInit 0 */
|
|
|
|
/* USER CODE END TIM21_MspInit 0 */
|
|
/* Peripheral clock enable */
|
|
__HAL_RCC_TIM21_CLK_ENABLE();
|
|
8001462: 4b17 ldr r3, [pc, #92] ; (80014c0 <HAL_TIM_Encoder_MspInit+0x80>)
|
|
8001464: 6b5a ldr r2, [r3, #52] ; 0x34
|
|
8001466: 4b16 ldr r3, [pc, #88] ; (80014c0 <HAL_TIM_Encoder_MspInit+0x80>)
|
|
8001468: 2104 movs r1, #4
|
|
800146a: 430a orrs r2, r1
|
|
800146c: 635a str r2, [r3, #52] ; 0x34
|
|
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
800146e: 4b14 ldr r3, [pc, #80] ; (80014c0 <HAL_TIM_Encoder_MspInit+0x80>)
|
|
8001470: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8001472: 4b13 ldr r3, [pc, #76] ; (80014c0 <HAL_TIM_Encoder_MspInit+0x80>)
|
|
8001474: 2101 movs r1, #1
|
|
8001476: 430a orrs r2, r1
|
|
8001478: 62da str r2, [r3, #44] ; 0x2c
|
|
800147a: 4b11 ldr r3, [pc, #68] ; (80014c0 <HAL_TIM_Encoder_MspInit+0x80>)
|
|
800147c: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
800147e: 2201 movs r2, #1
|
|
8001480: 4013 ands r3, r2
|
|
8001482: 60bb str r3, [r7, #8]
|
|
8001484: 68bb ldr r3, [r7, #8]
|
|
/**TIM21 GPIO Configuration
|
|
PA2 ------> TIM21_CH1
|
|
PA3 ------> TIM21_CH2
|
|
*/
|
|
GPIO_InitStruct.Pin = ENC_PHA_DROIT_Pin|ENC_PHB_DROIT_Pin;
|
|
8001486: 0021 movs r1, r4
|
|
8001488: 187b adds r3, r7, r1
|
|
800148a: 220c movs r2, #12
|
|
800148c: 601a str r2, [r3, #0]
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
800148e: 187b adds r3, r7, r1
|
|
8001490: 2202 movs r2, #2
|
|
8001492: 605a str r2, [r3, #4]
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
8001494: 187b adds r3, r7, r1
|
|
8001496: 2200 movs r2, #0
|
|
8001498: 609a str r2, [r3, #8]
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
800149a: 187b adds r3, r7, r1
|
|
800149c: 2200 movs r2, #0
|
|
800149e: 60da str r2, [r3, #12]
|
|
GPIO_InitStruct.Alternate = GPIO_AF0_TIM21;
|
|
80014a0: 187b adds r3, r7, r1
|
|
80014a2: 2200 movs r2, #0
|
|
80014a4: 611a str r2, [r3, #16]
|
|
HAL_GPIO_Init(GPIOA, &GPIO_InitStruct);
|
|
80014a6: 187a adds r2, r7, r1
|
|
80014a8: 23a0 movs r3, #160 ; 0xa0
|
|
80014aa: 05db lsls r3, r3, #23
|
|
80014ac: 0011 movs r1, r2
|
|
80014ae: 0018 movs r0, r3
|
|
80014b0: f000 feb8 bl 8002224 <HAL_GPIO_Init>
|
|
/* USER CODE BEGIN TIM21_MspInit 1 */
|
|
|
|
/* USER CODE END TIM21_MspInit 1 */
|
|
}
|
|
|
|
}
|
|
80014b4: 46c0 nop ; (mov r8, r8)
|
|
80014b6: 46bd mov sp, r7
|
|
80014b8: b009 add sp, #36 ; 0x24
|
|
80014ba: bd90 pop {r4, r7, pc}
|
|
80014bc: 40010800 .word 0x40010800
|
|
80014c0: 40021000 .word 0x40021000
|
|
|
|
080014c4 <HAL_TIM_MspPostInit>:
|
|
|
|
void HAL_TIM_MspPostInit(TIM_HandleTypeDef* htim)
|
|
{
|
|
80014c4: b590 push {r4, r7, lr}
|
|
80014c6: b08b sub sp, #44 ; 0x2c
|
|
80014c8: af00 add r7, sp, #0
|
|
80014ca: 6078 str r0, [r7, #4]
|
|
GPIO_InitTypeDef GPIO_InitStruct = {0};
|
|
80014cc: 2414 movs r4, #20
|
|
80014ce: 193b adds r3, r7, r4
|
|
80014d0: 0018 movs r0, r3
|
|
80014d2: 2314 movs r3, #20
|
|
80014d4: 001a movs r2, r3
|
|
80014d6: 2100 movs r1, #0
|
|
80014d8: f006 f971 bl 80077be <memset>
|
|
if(htim->Instance==TIM2)
|
|
80014dc: 687b ldr r3, [r7, #4]
|
|
80014de: 681a ldr r2, [r3, #0]
|
|
80014e0: 2380 movs r3, #128 ; 0x80
|
|
80014e2: 05db lsls r3, r3, #23
|
|
80014e4: 429a cmp r2, r3
|
|
80014e6: d15a bne.n 800159e <HAL_TIM_MspPostInit+0xda>
|
|
{
|
|
/* USER CODE BEGIN TIM2_MspPostInit 0 */
|
|
|
|
/* USER CODE END TIM2_MspPostInit 0 */
|
|
|
|
__HAL_RCC_GPIOA_CLK_ENABLE();
|
|
80014e8: 4b2f ldr r3, [pc, #188] ; (80015a8 <HAL_TIM_MspPostInit+0xe4>)
|
|
80014ea: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
80014ec: 4b2e ldr r3, [pc, #184] ; (80015a8 <HAL_TIM_MspPostInit+0xe4>)
|
|
80014ee: 2101 movs r1, #1
|
|
80014f0: 430a orrs r2, r1
|
|
80014f2: 62da str r2, [r3, #44] ; 0x2c
|
|
80014f4: 4b2c ldr r3, [pc, #176] ; (80015a8 <HAL_TIM_MspPostInit+0xe4>)
|
|
80014f6: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
80014f8: 2201 movs r2, #1
|
|
80014fa: 4013 ands r3, r2
|
|
80014fc: 613b str r3, [r7, #16]
|
|
80014fe: 693b ldr r3, [r7, #16]
|
|
__HAL_RCC_GPIOB_CLK_ENABLE();
|
|
8001500: 4b29 ldr r3, [pc, #164] ; (80015a8 <HAL_TIM_MspPostInit+0xe4>)
|
|
8001502: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8001504: 4b28 ldr r3, [pc, #160] ; (80015a8 <HAL_TIM_MspPostInit+0xe4>)
|
|
8001506: 2102 movs r1, #2
|
|
8001508: 430a orrs r2, r1
|
|
800150a: 62da str r2, [r3, #44] ; 0x2c
|
|
800150c: 4b26 ldr r3, [pc, #152] ; (80015a8 <HAL_TIM_MspPostInit+0xe4>)
|
|
800150e: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
8001510: 2202 movs r2, #2
|
|
8001512: 4013 ands r3, r2
|
|
8001514: 60fb str r3, [r7, #12]
|
|
8001516: 68fb ldr r3, [r7, #12]
|
|
PA1 ------> TIM2_CH2
|
|
PB0 ------> TIM2_CH3
|
|
PB1 ------> TIM2_CH4
|
|
PA8 ------> TIM2_CH1
|
|
*/
|
|
GPIO_InitStruct.Pin = PWM_B_GAUCHE_Pin;
|
|
8001518: 193b adds r3, r7, r4
|
|
800151a: 2202 movs r2, #2
|
|
800151c: 601a str r2, [r3, #0]
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
800151e: 193b adds r3, r7, r4
|
|
8001520: 2202 movs r2, #2
|
|
8001522: 605a str r2, [r3, #4]
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
8001524: 193b adds r3, r7, r4
|
|
8001526: 2200 movs r2, #0
|
|
8001528: 609a str r2, [r3, #8]
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
800152a: 193b adds r3, r7, r4
|
|
800152c: 2200 movs r2, #0
|
|
800152e: 60da str r2, [r3, #12]
|
|
GPIO_InitStruct.Alternate = GPIO_AF2_TIM2;
|
|
8001530: 193b adds r3, r7, r4
|
|
8001532: 2202 movs r2, #2
|
|
8001534: 611a str r2, [r3, #16]
|
|
HAL_GPIO_Init(PWM_B_GAUCHE_GPIO_Port, &GPIO_InitStruct);
|
|
8001536: 193a adds r2, r7, r4
|
|
8001538: 23a0 movs r3, #160 ; 0xa0
|
|
800153a: 05db lsls r3, r3, #23
|
|
800153c: 0011 movs r1, r2
|
|
800153e: 0018 movs r0, r3
|
|
8001540: f000 fe70 bl 8002224 <HAL_GPIO_Init>
|
|
|
|
GPIO_InitStruct.Pin = PWM_A_DROIT_Pin|PWM_B_DROIT_Pin;
|
|
8001544: 193b adds r3, r7, r4
|
|
8001546: 2203 movs r2, #3
|
|
8001548: 601a str r2, [r3, #0]
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
800154a: 193b adds r3, r7, r4
|
|
800154c: 2202 movs r2, #2
|
|
800154e: 605a str r2, [r3, #4]
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
8001550: 193b adds r3, r7, r4
|
|
8001552: 2200 movs r2, #0
|
|
8001554: 609a str r2, [r3, #8]
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
8001556: 193b adds r3, r7, r4
|
|
8001558: 2200 movs r2, #0
|
|
800155a: 60da str r2, [r3, #12]
|
|
GPIO_InitStruct.Alternate = GPIO_AF5_TIM2;
|
|
800155c: 193b adds r3, r7, r4
|
|
800155e: 2205 movs r2, #5
|
|
8001560: 611a str r2, [r3, #16]
|
|
HAL_GPIO_Init(GPIOB, &GPIO_InitStruct);
|
|
8001562: 193b adds r3, r7, r4
|
|
8001564: 4a11 ldr r2, [pc, #68] ; (80015ac <HAL_TIM_MspPostInit+0xe8>)
|
|
8001566: 0019 movs r1, r3
|
|
8001568: 0010 movs r0, r2
|
|
800156a: f000 fe5b bl 8002224 <HAL_GPIO_Init>
|
|
|
|
GPIO_InitStruct.Pin = PWM_A_GAUCHE_Pin;
|
|
800156e: 0021 movs r1, r4
|
|
8001570: 187b adds r3, r7, r1
|
|
8001572: 2280 movs r2, #128 ; 0x80
|
|
8001574: 0052 lsls r2, r2, #1
|
|
8001576: 601a str r2, [r3, #0]
|
|
GPIO_InitStruct.Mode = GPIO_MODE_AF_PP;
|
|
8001578: 187b adds r3, r7, r1
|
|
800157a: 2202 movs r2, #2
|
|
800157c: 605a str r2, [r3, #4]
|
|
GPIO_InitStruct.Pull = GPIO_NOPULL;
|
|
800157e: 187b adds r3, r7, r1
|
|
8001580: 2200 movs r2, #0
|
|
8001582: 609a str r2, [r3, #8]
|
|
GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_LOW;
|
|
8001584: 187b adds r3, r7, r1
|
|
8001586: 2200 movs r2, #0
|
|
8001588: 60da str r2, [r3, #12]
|
|
GPIO_InitStruct.Alternate = GPIO_AF5_TIM2;
|
|
800158a: 187b adds r3, r7, r1
|
|
800158c: 2205 movs r2, #5
|
|
800158e: 611a str r2, [r3, #16]
|
|
HAL_GPIO_Init(PWM_A_GAUCHE_GPIO_Port, &GPIO_InitStruct);
|
|
8001590: 187a adds r2, r7, r1
|
|
8001592: 23a0 movs r3, #160 ; 0xa0
|
|
8001594: 05db lsls r3, r3, #23
|
|
8001596: 0011 movs r1, r2
|
|
8001598: 0018 movs r0, r3
|
|
800159a: f000 fe43 bl 8002224 <HAL_GPIO_Init>
|
|
/* USER CODE BEGIN TIM2_MspPostInit 1 */
|
|
|
|
/* USER CODE END TIM2_MspPostInit 1 */
|
|
}
|
|
|
|
}
|
|
800159e: 46c0 nop ; (mov r8, r8)
|
|
80015a0: 46bd mov sp, r7
|
|
80015a2: b00b add sp, #44 ; 0x2c
|
|
80015a4: bd90 pop {r4, r7, pc}
|
|
80015a6: 46c0 nop ; (mov r8, r8)
|
|
80015a8: 40021000 .word 0x40021000
|
|
80015ac: 50000400 .word 0x50000400
|
|
|
|
080015b0 <NMI_Handler>:
|
|
/******************************************************************************/
|
|
/**
|
|
* @brief This function handles Non maskable Interrupt.
|
|
*/
|
|
void NMI_Handler(void)
|
|
{
|
|
80015b0: b580 push {r7, lr}
|
|
80015b2: 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)
|
|
80015b4: e7fe b.n 80015b4 <NMI_Handler+0x4>
|
|
|
|
080015b6 <HardFault_Handler>:
|
|
|
|
/**
|
|
* @brief This function handles Hard fault interrupt.
|
|
*/
|
|
void HardFault_Handler(void)
|
|
{
|
|
80015b6: b580 push {r7, lr}
|
|
80015b8: af00 add r7, sp, #0
|
|
/* USER CODE BEGIN HardFault_IRQn 0 */
|
|
|
|
/* USER CODE END HardFault_IRQn 0 */
|
|
while (1)
|
|
80015ba: e7fe b.n 80015ba <HardFault_Handler+0x4>
|
|
|
|
080015bc <SysTick_Handler>:
|
|
|
|
/**
|
|
* @brief This function handles System tick timer.
|
|
*/
|
|
void SysTick_Handler(void)
|
|
{
|
|
80015bc: b580 push {r7, lr}
|
|
80015be: af00 add r7, sp, #0
|
|
/* USER CODE BEGIN SysTick_IRQn 0 */
|
|
|
|
/* USER CODE END SysTick_IRQn 0 */
|
|
HAL_IncTick();
|
|
80015c0: f000 f8d8 bl 8001774 <HAL_IncTick>
|
|
#if (INCLUDE_xTaskGetSchedulerState == 1 )
|
|
if (xTaskGetSchedulerState() != taskSCHEDULER_NOT_STARTED)
|
|
80015c4: f005 f930 bl 8006828 <xTaskGetSchedulerState>
|
|
80015c8: 0003 movs r3, r0
|
|
80015ca: 2b01 cmp r3, #1
|
|
80015cc: d001 beq.n 80015d2 <SysTick_Handler+0x16>
|
|
{
|
|
#endif /* INCLUDE_xTaskGetSchedulerState */
|
|
xPortSysTickHandler();
|
|
80015ce: f005 fe03 bl 80071d8 <xPortSysTickHandler>
|
|
}
|
|
#endif /* INCLUDE_xTaskGetSchedulerState */
|
|
/* USER CODE BEGIN SysTick_IRQn 1 */
|
|
|
|
/* USER CODE END SysTick_IRQn 1 */
|
|
}
|
|
80015d2: 46c0 nop ; (mov r8, r8)
|
|
80015d4: 46bd mov sp, r7
|
|
80015d6: bd80 pop {r7, pc}
|
|
|
|
080015d8 <EXTI2_3_IRQHandler>:
|
|
|
|
/**
|
|
* @brief This function handles EXTI line 2 and line 3 interrupts.
|
|
*/
|
|
void EXTI2_3_IRQHandler(void)
|
|
{
|
|
80015d8: b580 push {r7, lr}
|
|
80015da: af00 add r7, sp, #0
|
|
/* USER CODE BEGIN EXTI2_3_IRQn 0 */
|
|
|
|
/* USER CODE END EXTI2_3_IRQn 0 */
|
|
HAL_GPIO_EXTI_IRQHandler(GPIO_PIN_3);
|
|
80015dc: 2008 movs r0, #8
|
|
80015de: f000 ffad bl 800253c <HAL_GPIO_EXTI_IRQHandler>
|
|
/* USER CODE BEGIN EXTI2_3_IRQn 1 */
|
|
|
|
/* USER CODE END EXTI2_3_IRQn 1 */
|
|
}
|
|
80015e2: 46c0 nop ; (mov r8, r8)
|
|
80015e4: 46bd mov sp, r7
|
|
80015e6: bd80 pop {r7, pc}
|
|
|
|
080015e8 <DMA1_Channel2_3_IRQHandler>:
|
|
|
|
/**
|
|
* @brief This function handles DMA1 channel 2 and channel 3 interrupts.
|
|
*/
|
|
void DMA1_Channel2_3_IRQHandler(void)
|
|
{
|
|
80015e8: b580 push {r7, lr}
|
|
80015ea: af00 add r7, sp, #0
|
|
/* USER CODE BEGIN DMA1_Channel2_3_IRQn 0 */
|
|
|
|
/* USER CODE END DMA1_Channel2_3_IRQn 0 */
|
|
HAL_DMA_IRQHandler(&hdma_lpuart1_tx);
|
|
80015ec: 4b05 ldr r3, [pc, #20] ; (8001604 <DMA1_Channel2_3_IRQHandler+0x1c>)
|
|
80015ee: 0018 movs r0, r3
|
|
80015f0: f000 fd69 bl 80020c6 <HAL_DMA_IRQHandler>
|
|
HAL_DMA_IRQHandler(&hdma_lpuart1_rx);
|
|
80015f4: 4b04 ldr r3, [pc, #16] ; (8001608 <DMA1_Channel2_3_IRQHandler+0x20>)
|
|
80015f6: 0018 movs r0, r3
|
|
80015f8: f000 fd65 bl 80020c6 <HAL_DMA_IRQHandler>
|
|
/* USER CODE BEGIN DMA1_Channel2_3_IRQn 1 */
|
|
|
|
/* USER CODE END DMA1_Channel2_3_IRQn 1 */
|
|
}
|
|
80015fc: 46c0 nop ; (mov r8, r8)
|
|
80015fe: 46bd mov sp, r7
|
|
8001600: bd80 pop {r7, pc}
|
|
8001602: 46c0 nop ; (mov r8, r8)
|
|
8001604: 200017e8 .word 0x200017e8
|
|
8001608: 20001830 .word 0x20001830
|
|
|
|
0800160c <ADC1_IRQHandler>:
|
|
|
|
/**
|
|
* @brief This function handles ADC global interrupt.
|
|
*/
|
|
void ADC1_IRQHandler(void)
|
|
{
|
|
800160c: b580 push {r7, lr}
|
|
800160e: af00 add r7, sp, #0
|
|
/* USER CODE BEGIN ADC1_IRQn 0 */
|
|
|
|
/* USER CODE END ADC1_IRQn 0 */
|
|
HAL_ADC_IRQHandler(&hadc);
|
|
8001610: 4b03 ldr r3, [pc, #12] ; (8001620 <ADC1_IRQHandler+0x14>)
|
|
8001612: 0018 movs r0, r3
|
|
8001614: f000 fa3e bl 8001a94 <HAL_ADC_IRQHandler>
|
|
/* USER CODE BEGIN ADC1_IRQn 1 */
|
|
|
|
/* USER CODE END ADC1_IRQn 1 */
|
|
}
|
|
8001618: 46c0 nop ; (mov r8, r8)
|
|
800161a: 46bd mov sp, r7
|
|
800161c: bd80 pop {r7, pc}
|
|
800161e: 46c0 nop ; (mov r8, r8)
|
|
8001620: 200018b8 .word 0x200018b8
|
|
|
|
08001624 <LPUART1_IRQHandler>:
|
|
|
|
/**
|
|
* @brief This function handles LPUART1 global interrupt / LPUART1 wake-up interrupt through EXTI line 28.
|
|
*/
|
|
void LPUART1_IRQHandler(void)
|
|
{
|
|
8001624: b580 push {r7, lr}
|
|
8001626: af00 add r7, sp, #0
|
|
/* USER CODE BEGIN LPUART1_IRQn 0 */
|
|
|
|
/* USER CODE END LPUART1_IRQn 0 */
|
|
HAL_UART_IRQHandler(&hlpuart1);
|
|
8001628: 4b03 ldr r3, [pc, #12] ; (8001638 <LPUART1_IRQHandler+0x14>)
|
|
800162a: 0018 movs r0, r3
|
|
800162c: f002 fc4c bl 8003ec8 <HAL_UART_IRQHandler>
|
|
/* USER CODE BEGIN LPUART1_IRQn 1 */
|
|
|
|
/* USER CODE END LPUART1_IRQn 1 */
|
|
}
|
|
8001630: 46c0 nop ; (mov r8, r8)
|
|
8001632: 46bd mov sp, r7
|
|
8001634: bd80 pop {r7, pc}
|
|
8001636: 46c0 nop ; (mov r8, r8)
|
|
8001638: 20001734 .word 0x20001734
|
|
|
|
0800163c <SystemInit>:
|
|
* @brief Setup the microcontroller system.
|
|
* @param None
|
|
* @retval None
|
|
*/
|
|
void SystemInit (void)
|
|
{
|
|
800163c: b580 push {r7, lr}
|
|
800163e: af00 add r7, sp, #0
|
|
/* Configure the Vector Table location add offset address ------------------*/
|
|
#if defined (USER_VECT_TAB_ADDRESS)
|
|
SCB->VTOR = VECT_TAB_BASE_ADDRESS | VECT_TAB_OFFSET; /* Vector Table Relocation in Internal SRAM */
|
|
#endif /* USER_VECT_TAB_ADDRESS */
|
|
}
|
|
8001640: 46c0 nop ; (mov r8, r8)
|
|
8001642: 46bd mov sp, r7
|
|
8001644: bd80 pop {r7, pc}
|
|
...
|
|
|
|
08001648 <Reset_Handler>:
|
|
|
|
.section .text.Reset_Handler
|
|
.weak Reset_Handler
|
|
.type Reset_Handler, %function
|
|
Reset_Handler:
|
|
ldr r0, =_estack
|
|
8001648: 4813 ldr r0, [pc, #76] ; (8001698 <LoopForever+0x2>)
|
|
mov sp, r0 /* set stack pointer */
|
|
800164a: 4685 mov sp, r0
|
|
|
|
/*Check if boot space corresponds to system memory*/
|
|
|
|
LDR R0,=0x00000004
|
|
800164c: 4813 ldr r0, [pc, #76] ; (800169c <LoopForever+0x6>)
|
|
LDR R1, [R0]
|
|
800164e: 6801 ldr r1, [r0, #0]
|
|
LSRS R1, R1, #24
|
|
8001650: 0e09 lsrs r1, r1, #24
|
|
LDR R2,=0x1F
|
|
8001652: 4a13 ldr r2, [pc, #76] ; (80016a0 <LoopForever+0xa>)
|
|
CMP R1, R2
|
|
8001654: 4291 cmp r1, r2
|
|
BNE ApplicationStart
|
|
8001656: d105 bne.n 8001664 <ApplicationStart>
|
|
|
|
/*SYSCFG clock enable*/
|
|
LDR R0,=0x40021034
|
|
8001658: 4812 ldr r0, [pc, #72] ; (80016a4 <LoopForever+0xe>)
|
|
LDR R1,=0x00000001
|
|
800165a: 4913 ldr r1, [pc, #76] ; (80016a8 <LoopForever+0x12>)
|
|
STR R1, [R0]
|
|
800165c: 6001 str r1, [r0, #0]
|
|
|
|
/*Set CFGR1 register with flash memory remap at address 0*/
|
|
LDR R0,=0x40010000
|
|
800165e: 4813 ldr r0, [pc, #76] ; (80016ac <LoopForever+0x16>)
|
|
LDR R1,=0x00000000
|
|
8001660: 4913 ldr r1, [pc, #76] ; (80016b0 <LoopForever+0x1a>)
|
|
STR R1, [R0]
|
|
8001662: 6001 str r1, [r0, #0]
|
|
|
|
08001664 <ApplicationStart>:
|
|
|
|
ApplicationStart:
|
|
/* Copy the data segment initializers from flash to SRAM */
|
|
ldr r0, =_sdata
|
|
8001664: 4813 ldr r0, [pc, #76] ; (80016b4 <LoopForever+0x1e>)
|
|
ldr r1, =_edata
|
|
8001666: 4914 ldr r1, [pc, #80] ; (80016b8 <LoopForever+0x22>)
|
|
ldr r2, =_sidata
|
|
8001668: 4a14 ldr r2, [pc, #80] ; (80016bc <LoopForever+0x26>)
|
|
movs r3, #0
|
|
800166a: 2300 movs r3, #0
|
|
b LoopCopyDataInit
|
|
800166c: e002 b.n 8001674 <LoopCopyDataInit>
|
|
|
|
0800166e <CopyDataInit>:
|
|
|
|
CopyDataInit:
|
|
ldr r4, [r2, r3]
|
|
800166e: 58d4 ldr r4, [r2, r3]
|
|
str r4, [r0, r3]
|
|
8001670: 50c4 str r4, [r0, r3]
|
|
adds r3, r3, #4
|
|
8001672: 3304 adds r3, #4
|
|
|
|
08001674 <LoopCopyDataInit>:
|
|
|
|
LoopCopyDataInit:
|
|
adds r4, r0, r3
|
|
8001674: 18c4 adds r4, r0, r3
|
|
cmp r4, r1
|
|
8001676: 428c cmp r4, r1
|
|
bcc CopyDataInit
|
|
8001678: d3f9 bcc.n 800166e <CopyDataInit>
|
|
|
|
/* Zero fill the bss segment. */
|
|
ldr r2, =_sbss
|
|
800167a: 4a11 ldr r2, [pc, #68] ; (80016c0 <LoopForever+0x2a>)
|
|
ldr r4, =_ebss
|
|
800167c: 4c11 ldr r4, [pc, #68] ; (80016c4 <LoopForever+0x2e>)
|
|
movs r3, #0
|
|
800167e: 2300 movs r3, #0
|
|
b LoopFillZerobss
|
|
8001680: e001 b.n 8001686 <LoopFillZerobss>
|
|
|
|
08001682 <FillZerobss>:
|
|
|
|
FillZerobss:
|
|
str r3, [r2]
|
|
8001682: 6013 str r3, [r2, #0]
|
|
adds r2, r2, #4
|
|
8001684: 3204 adds r2, #4
|
|
|
|
08001686 <LoopFillZerobss>:
|
|
|
|
LoopFillZerobss:
|
|
cmp r2, r4
|
|
8001686: 42a2 cmp r2, r4
|
|
bcc FillZerobss
|
|
8001688: d3fb bcc.n 8001682 <FillZerobss>
|
|
|
|
/* Call the clock system intitialization function.*/
|
|
bl SystemInit
|
|
800168a: f7ff ffd7 bl 800163c <SystemInit>
|
|
/* Call static constructors */
|
|
bl __libc_init_array
|
|
800168e: f006 f869 bl 8007764 <__libc_init_array>
|
|
/* Call the application's entry point.*/
|
|
bl main
|
|
8001692: f7ff f98d bl 80009b0 <main>
|
|
|
|
08001696 <LoopForever>:
|
|
|
|
LoopForever:
|
|
b LoopForever
|
|
8001696: e7fe b.n 8001696 <LoopForever>
|
|
ldr r0, =_estack
|
|
8001698: 20002000 .word 0x20002000
|
|
LDR R0,=0x00000004
|
|
800169c: 00000004 .word 0x00000004
|
|
LDR R2,=0x1F
|
|
80016a0: 0000001f .word 0x0000001f
|
|
LDR R0,=0x40021034
|
|
80016a4: 40021034 .word 0x40021034
|
|
LDR R1,=0x00000001
|
|
80016a8: 00000001 .word 0x00000001
|
|
LDR R0,=0x40010000
|
|
80016ac: 40010000 .word 0x40010000
|
|
LDR R1,=0x00000000
|
|
80016b0: 00000000 .word 0x00000000
|
|
ldr r0, =_sdata
|
|
80016b4: 20000000 .word 0x20000000
|
|
ldr r1, =_edata
|
|
80016b8: 20000010 .word 0x20000010
|
|
ldr r2, =_sidata
|
|
80016bc: 08007928 .word 0x08007928
|
|
ldr r2, =_sbss
|
|
80016c0: 20000010 .word 0x20000010
|
|
ldr r4, =_ebss
|
|
80016c4: 200019ac .word 0x200019ac
|
|
|
|
080016c8 <DMA1_Channel1_IRQHandler>:
|
|
* @retval : None
|
|
*/
|
|
.section .text.Default_Handler,"ax",%progbits
|
|
Default_Handler:
|
|
Infinite_Loop:
|
|
b Infinite_Loop
|
|
80016c8: e7fe b.n 80016c8 <DMA1_Channel1_IRQHandler>
|
|
...
|
|
|
|
080016cc <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)
|
|
{
|
|
80016cc: b580 push {r7, lr}
|
|
80016ce: b082 sub sp, #8
|
|
80016d0: af00 add r7, sp, #0
|
|
HAL_StatusTypeDef status = HAL_OK;
|
|
80016d2: 1dfb adds r3, r7, #7
|
|
80016d4: 2200 movs r2, #0
|
|
80016d6: 701a strb r2, [r3, #0]
|
|
#if (BUFFER_CACHE_DISABLE != 0)
|
|
__HAL_FLASH_BUFFER_CACHE_DISABLE();
|
|
#endif /* BUFFER_CACHE_DISABLE */
|
|
|
|
#if (PREREAD_ENABLE != 0)
|
|
__HAL_FLASH_PREREAD_BUFFER_ENABLE();
|
|
80016d8: 4b0b ldr r3, [pc, #44] ; (8001708 <HAL_Init+0x3c>)
|
|
80016da: 681a ldr r2, [r3, #0]
|
|
80016dc: 4b0a ldr r3, [pc, #40] ; (8001708 <HAL_Init+0x3c>)
|
|
80016de: 2140 movs r1, #64 ; 0x40
|
|
80016e0: 430a orrs r2, r1
|
|
80016e2: 601a str r2, [r3, #0]
|
|
#if (PREFETCH_ENABLE != 0)
|
|
__HAL_FLASH_PREFETCH_BUFFER_ENABLE();
|
|
#endif /* PREFETCH_ENABLE */
|
|
|
|
/* Use SysTick as time base source and configure 1ms tick (default clock after Reset is MSI) */
|
|
if (HAL_InitTick(TICK_INT_PRIORITY) != HAL_OK)
|
|
80016e4: 2003 movs r0, #3
|
|
80016e6: f000 f811 bl 800170c <HAL_InitTick>
|
|
80016ea: 1e03 subs r3, r0, #0
|
|
80016ec: d003 beq.n 80016f6 <HAL_Init+0x2a>
|
|
{
|
|
status = HAL_ERROR;
|
|
80016ee: 1dfb adds r3, r7, #7
|
|
80016f0: 2201 movs r2, #1
|
|
80016f2: 701a strb r2, [r3, #0]
|
|
80016f4: e001 b.n 80016fa <HAL_Init+0x2e>
|
|
}
|
|
else
|
|
{
|
|
/* Init the low level hardware */
|
|
HAL_MspInit();
|
|
80016f6: f7ff fd1d bl 8001134 <HAL_MspInit>
|
|
}
|
|
|
|
/* Return function status */
|
|
return status;
|
|
80016fa: 1dfb adds r3, r7, #7
|
|
80016fc: 781b ldrb r3, [r3, #0]
|
|
}
|
|
80016fe: 0018 movs r0, r3
|
|
8001700: 46bd mov sp, r7
|
|
8001702: b002 add sp, #8
|
|
8001704: bd80 pop {r7, pc}
|
|
8001706: 46c0 nop ; (mov r8, r8)
|
|
8001708: 40022000 .word 0x40022000
|
|
|
|
0800170c <HAL_InitTick>:
|
|
* implementation in user file.
|
|
* @param TickPriority Tick interrupt priority.
|
|
* @retval HAL status
|
|
*/
|
|
__weak HAL_StatusTypeDef HAL_InitTick(uint32_t TickPriority)
|
|
{
|
|
800170c: b590 push {r4, r7, lr}
|
|
800170e: b083 sub sp, #12
|
|
8001710: af00 add r7, sp, #0
|
|
8001712: 6078 str r0, [r7, #4]
|
|
/* Configure the SysTick to have interrupt in 1ms time basis*/
|
|
if (HAL_SYSTICK_Config(SystemCoreClock / (1000U / uwTickFreq)) > 0U)
|
|
8001714: 4b14 ldr r3, [pc, #80] ; (8001768 <HAL_InitTick+0x5c>)
|
|
8001716: 681c ldr r4, [r3, #0]
|
|
8001718: 4b14 ldr r3, [pc, #80] ; (800176c <HAL_InitTick+0x60>)
|
|
800171a: 781b ldrb r3, [r3, #0]
|
|
800171c: 0019 movs r1, r3
|
|
800171e: 23fa movs r3, #250 ; 0xfa
|
|
8001720: 0098 lsls r0, r3, #2
|
|
8001722: f7fe fcf1 bl 8000108 <__udivsi3>
|
|
8001726: 0003 movs r3, r0
|
|
8001728: 0019 movs r1, r3
|
|
800172a: 0020 movs r0, r4
|
|
800172c: f7fe fcec bl 8000108 <__udivsi3>
|
|
8001730: 0003 movs r3, r0
|
|
8001732: 0018 movs r0, r3
|
|
8001734: f000 fbbb bl 8001eae <HAL_SYSTICK_Config>
|
|
8001738: 1e03 subs r3, r0, #0
|
|
800173a: d001 beq.n 8001740 <HAL_InitTick+0x34>
|
|
{
|
|
return HAL_ERROR;
|
|
800173c: 2301 movs r3, #1
|
|
800173e: e00f b.n 8001760 <HAL_InitTick+0x54>
|
|
}
|
|
|
|
/* Configure the SysTick IRQ priority */
|
|
if (TickPriority < (1UL << __NVIC_PRIO_BITS))
|
|
8001740: 687b ldr r3, [r7, #4]
|
|
8001742: 2b03 cmp r3, #3
|
|
8001744: d80b bhi.n 800175e <HAL_InitTick+0x52>
|
|
{
|
|
HAL_NVIC_SetPriority(SysTick_IRQn, TickPriority, 0U);
|
|
8001746: 6879 ldr r1, [r7, #4]
|
|
8001748: 2301 movs r3, #1
|
|
800174a: 425b negs r3, r3
|
|
800174c: 2200 movs r2, #0
|
|
800174e: 0018 movs r0, r3
|
|
8001750: f000 fb88 bl 8001e64 <HAL_NVIC_SetPriority>
|
|
uwTickPrio = TickPriority;
|
|
8001754: 4b06 ldr r3, [pc, #24] ; (8001770 <HAL_InitTick+0x64>)
|
|
8001756: 687a ldr r2, [r7, #4]
|
|
8001758: 601a str r2, [r3, #0]
|
|
{
|
|
return HAL_ERROR;
|
|
}
|
|
|
|
/* Return function status */
|
|
return HAL_OK;
|
|
800175a: 2300 movs r3, #0
|
|
800175c: e000 b.n 8001760 <HAL_InitTick+0x54>
|
|
return HAL_ERROR;
|
|
800175e: 2301 movs r3, #1
|
|
}
|
|
8001760: 0018 movs r0, r3
|
|
8001762: 46bd mov sp, r7
|
|
8001764: b003 add sp, #12
|
|
8001766: bd90 pop {r4, r7, pc}
|
|
8001768: 20000000 .word 0x20000000
|
|
800176c: 20000008 .word 0x20000008
|
|
8001770: 20000004 .word 0x20000004
|
|
|
|
08001774 <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)
|
|
{
|
|
8001774: b580 push {r7, lr}
|
|
8001776: af00 add r7, sp, #0
|
|
uwTick += uwTickFreq;
|
|
8001778: 4b05 ldr r3, [pc, #20] ; (8001790 <HAL_IncTick+0x1c>)
|
|
800177a: 781b ldrb r3, [r3, #0]
|
|
800177c: 001a movs r2, r3
|
|
800177e: 4b05 ldr r3, [pc, #20] ; (8001794 <HAL_IncTick+0x20>)
|
|
8001780: 681b ldr r3, [r3, #0]
|
|
8001782: 18d2 adds r2, r2, r3
|
|
8001784: 4b03 ldr r3, [pc, #12] ; (8001794 <HAL_IncTick+0x20>)
|
|
8001786: 601a str r2, [r3, #0]
|
|
}
|
|
8001788: 46c0 nop ; (mov r8, r8)
|
|
800178a: 46bd mov sp, r7
|
|
800178c: bd80 pop {r7, pc}
|
|
800178e: 46c0 nop ; (mov r8, r8)
|
|
8001790: 20000008 .word 0x20000008
|
|
8001794: 20001968 .word 0x20001968
|
|
|
|
08001798 <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)
|
|
{
|
|
8001798: b580 push {r7, lr}
|
|
800179a: af00 add r7, sp, #0
|
|
return uwTick;
|
|
800179c: 4b02 ldr r3, [pc, #8] ; (80017a8 <HAL_GetTick+0x10>)
|
|
800179e: 681b ldr r3, [r3, #0]
|
|
}
|
|
80017a0: 0018 movs r0, r3
|
|
80017a2: 46bd mov sp, r7
|
|
80017a4: bd80 pop {r7, pc}
|
|
80017a6: 46c0 nop ; (mov r8, r8)
|
|
80017a8: 20001968 .word 0x20001968
|
|
|
|
080017ac <HAL_ADC_Init>:
|
|
* function "HAL_ADCEx_EnableVREFINTTempSensor()" must be called similarilly.
|
|
* @param hadc ADC handle
|
|
* @retval HAL status
|
|
*/
|
|
HAL_StatusTypeDef HAL_ADC_Init(ADC_HandleTypeDef* hadc)
|
|
{
|
|
80017ac: b580 push {r7, lr}
|
|
80017ae: b082 sub sp, #8
|
|
80017b0: af00 add r7, sp, #0
|
|
80017b2: 6078 str r0, [r7, #4]
|
|
|
|
/* Check ADC handle */
|
|
if(hadc == NULL)
|
|
80017b4: 687b ldr r3, [r7, #4]
|
|
80017b6: 2b00 cmp r3, #0
|
|
80017b8: d101 bne.n 80017be <HAL_ADC_Init+0x12>
|
|
{
|
|
return HAL_ERROR;
|
|
80017ba: 2301 movs r3, #1
|
|
80017bc: e159 b.n 8001a72 <HAL_ADC_Init+0x2c6>
|
|
/* 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)
|
|
80017be: 687b ldr r3, [r7, #4]
|
|
80017c0: 6d5b ldr r3, [r3, #84] ; 0x54
|
|
80017c2: 2b00 cmp r3, #0
|
|
80017c4: d10a bne.n 80017dc <HAL_ADC_Init+0x30>
|
|
{
|
|
/* Initialize ADC error code */
|
|
ADC_CLEAR_ERRORCODE(hadc);
|
|
80017c6: 687b ldr r3, [r7, #4]
|
|
80017c8: 2200 movs r2, #0
|
|
80017ca: 659a str r2, [r3, #88] ; 0x58
|
|
|
|
/* Allocate lock resource and initialize it */
|
|
hadc->Lock = HAL_UNLOCKED;
|
|
80017cc: 687b ldr r3, [r7, #4]
|
|
80017ce: 2250 movs r2, #80 ; 0x50
|
|
80017d0: 2100 movs r1, #0
|
|
80017d2: 5499 strb r1, [r3, r2]
|
|
|
|
/* Init the low level hardware */
|
|
hadc->MspInitCallback(hadc);
|
|
#else
|
|
/* Init the low level hardware */
|
|
HAL_ADC_MspInit(hadc);
|
|
80017d4: 687b ldr r3, [r7, #4]
|
|
80017d6: 0018 movs r0, r3
|
|
80017d8: f7ff fcc8 bl 800116c <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_SET(hadc->State, HAL_ADC_STATE_ERROR_INTERNAL) ||
|
|
80017dc: 687b ldr r3, [r7, #4]
|
|
80017de: 6d5b ldr r3, [r3, #84] ; 0x54
|
|
80017e0: 2210 movs r2, #16
|
|
80017e2: 4013 ands r3, r2
|
|
80017e4: 2b10 cmp r3, #16
|
|
80017e6: d005 beq.n 80017f4 <HAL_ADC_Init+0x48>
|
|
(ADC_IS_CONVERSION_ONGOING_REGULAR(hadc) != RESET) )
|
|
80017e8: 687b ldr r3, [r7, #4]
|
|
80017ea: 681b ldr r3, [r3, #0]
|
|
80017ec: 689b ldr r3, [r3, #8]
|
|
80017ee: 2204 movs r2, #4
|
|
80017f0: 4013 ands r3, r2
|
|
if (HAL_IS_BIT_SET(hadc->State, HAL_ADC_STATE_ERROR_INTERNAL) ||
|
|
80017f2: d00b beq.n 800180c <HAL_ADC_Init+0x60>
|
|
{
|
|
/* Update ADC state machine to error */
|
|
SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_INTERNAL);
|
|
80017f4: 687b ldr r3, [r7, #4]
|
|
80017f6: 6d5b ldr r3, [r3, #84] ; 0x54
|
|
80017f8: 2210 movs r2, #16
|
|
80017fa: 431a orrs r2, r3
|
|
80017fc: 687b ldr r3, [r7, #4]
|
|
80017fe: 655a str r2, [r3, #84] ; 0x54
|
|
|
|
/* Process unlocked */
|
|
__HAL_UNLOCK(hadc);
|
|
8001800: 687b ldr r3, [r7, #4]
|
|
8001802: 2250 movs r2, #80 ; 0x50
|
|
8001804: 2100 movs r1, #0
|
|
8001806: 5499 strb r1, [r3, r2]
|
|
return HAL_ERROR;
|
|
8001808: 2301 movs r3, #1
|
|
800180a: e132 b.n 8001a72 <HAL_ADC_Init+0x2c6>
|
|
}
|
|
|
|
/* Set ADC state */
|
|
ADC_STATE_CLR_SET(hadc->State,
|
|
800180c: 687b ldr r3, [r7, #4]
|
|
800180e: 6d5b ldr r3, [r3, #84] ; 0x54
|
|
8001810: 4a9a ldr r2, [pc, #616] ; (8001a7c <HAL_ADC_Init+0x2d0>)
|
|
8001812: 4013 ands r3, r2
|
|
8001814: 2202 movs r2, #2
|
|
8001816: 431a orrs r2, r3
|
|
8001818: 687b ldr r3, [r7, #4]
|
|
800181a: 655a str r2, [r3, #84] ; 0x54
|
|
/* 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)
|
|
800181c: 687b ldr r3, [r7, #4]
|
|
800181e: 681b ldr r3, [r3, #0]
|
|
8001820: 689b ldr r3, [r3, #8]
|
|
8001822: 2203 movs r2, #3
|
|
8001824: 4013 ands r3, r2
|
|
8001826: 2b01 cmp r3, #1
|
|
8001828: d108 bne.n 800183c <HAL_ADC_Init+0x90>
|
|
800182a: 687b ldr r3, [r7, #4]
|
|
800182c: 681b ldr r3, [r3, #0]
|
|
800182e: 681b ldr r3, [r3, #0]
|
|
8001830: 2201 movs r2, #1
|
|
8001832: 4013 ands r3, r2
|
|
8001834: 2b01 cmp r3, #1
|
|
8001836: d101 bne.n 800183c <HAL_ADC_Init+0x90>
|
|
8001838: 2301 movs r3, #1
|
|
800183a: e000 b.n 800183e <HAL_ADC_Init+0x92>
|
|
800183c: 2300 movs r3, #0
|
|
800183e: 2b00 cmp r3, #0
|
|
8001840: d149 bne.n 80018d6 <HAL_ADC_Init+0x12a>
|
|
/* - internal measurement paths: Vbat, temperature sensor, Vref */
|
|
/* (set into HAL_ADC_ConfigChannel() ) */
|
|
|
|
/* Configuration of ADC clock: clock source PCLK or asynchronous with
|
|
selectable prescaler */
|
|
__HAL_ADC_CLOCK_PRESCALER(hadc);
|
|
8001842: 687b ldr r3, [r7, #4]
|
|
8001844: 685a ldr r2, [r3, #4]
|
|
8001846: 23c0 movs r3, #192 ; 0xc0
|
|
8001848: 061b lsls r3, r3, #24
|
|
800184a: 429a cmp r2, r3
|
|
800184c: d00b beq.n 8001866 <HAL_ADC_Init+0xba>
|
|
800184e: 687b ldr r3, [r7, #4]
|
|
8001850: 685a ldr r2, [r3, #4]
|
|
8001852: 2380 movs r3, #128 ; 0x80
|
|
8001854: 05db lsls r3, r3, #23
|
|
8001856: 429a cmp r2, r3
|
|
8001858: d005 beq.n 8001866 <HAL_ADC_Init+0xba>
|
|
800185a: 687b ldr r3, [r7, #4]
|
|
800185c: 685a ldr r2, [r3, #4]
|
|
800185e: 2380 movs r3, #128 ; 0x80
|
|
8001860: 061b lsls r3, r3, #24
|
|
8001862: 429a cmp r2, r3
|
|
8001864: d111 bne.n 800188a <HAL_ADC_Init+0xde>
|
|
8001866: 687b ldr r3, [r7, #4]
|
|
8001868: 681b ldr r3, [r3, #0]
|
|
800186a: 691a ldr r2, [r3, #16]
|
|
800186c: 687b ldr r3, [r7, #4]
|
|
800186e: 681b ldr r3, [r3, #0]
|
|
8001870: 0092 lsls r2, r2, #2
|
|
8001872: 0892 lsrs r2, r2, #2
|
|
8001874: 611a str r2, [r3, #16]
|
|
8001876: 687b ldr r3, [r7, #4]
|
|
8001878: 681b ldr r3, [r3, #0]
|
|
800187a: 6919 ldr r1, [r3, #16]
|
|
800187c: 687b ldr r3, [r7, #4]
|
|
800187e: 685a ldr r2, [r3, #4]
|
|
8001880: 687b ldr r3, [r7, #4]
|
|
8001882: 681b ldr r3, [r3, #0]
|
|
8001884: 430a orrs r2, r1
|
|
8001886: 611a str r2, [r3, #16]
|
|
8001888: e014 b.n 80018b4 <HAL_ADC_Init+0x108>
|
|
800188a: 687b ldr r3, [r7, #4]
|
|
800188c: 681b ldr r3, [r3, #0]
|
|
800188e: 691a ldr r2, [r3, #16]
|
|
8001890: 687b ldr r3, [r7, #4]
|
|
8001892: 681b ldr r3, [r3, #0]
|
|
8001894: 0092 lsls r2, r2, #2
|
|
8001896: 0892 lsrs r2, r2, #2
|
|
8001898: 611a str r2, [r3, #16]
|
|
800189a: 4b79 ldr r3, [pc, #484] ; (8001a80 <HAL_ADC_Init+0x2d4>)
|
|
800189c: 681a ldr r2, [r3, #0]
|
|
800189e: 4b78 ldr r3, [pc, #480] ; (8001a80 <HAL_ADC_Init+0x2d4>)
|
|
80018a0: 4978 ldr r1, [pc, #480] ; (8001a84 <HAL_ADC_Init+0x2d8>)
|
|
80018a2: 400a ands r2, r1
|
|
80018a4: 601a str r2, [r3, #0]
|
|
80018a6: 4b76 ldr r3, [pc, #472] ; (8001a80 <HAL_ADC_Init+0x2d4>)
|
|
80018a8: 6819 ldr r1, [r3, #0]
|
|
80018aa: 687b ldr r3, [r7, #4]
|
|
80018ac: 685a ldr r2, [r3, #4]
|
|
80018ae: 4b74 ldr r3, [pc, #464] ; (8001a80 <HAL_ADC_Init+0x2d4>)
|
|
80018b0: 430a orrs r2, r1
|
|
80018b2: 601a str r2, [r3, #0]
|
|
|
|
/* Configuration of ADC: */
|
|
/* - Resolution */
|
|
hadc->Instance->CFGR1 &= ~( ADC_CFGR1_RES);
|
|
80018b4: 687b ldr r3, [r7, #4]
|
|
80018b6: 681b ldr r3, [r3, #0]
|
|
80018b8: 68da ldr r2, [r3, #12]
|
|
80018ba: 687b ldr r3, [r7, #4]
|
|
80018bc: 681b ldr r3, [r3, #0]
|
|
80018be: 2118 movs r1, #24
|
|
80018c0: 438a bics r2, r1
|
|
80018c2: 60da str r2, [r3, #12]
|
|
hadc->Instance->CFGR1 |= hadc->Init.Resolution;
|
|
80018c4: 687b ldr r3, [r7, #4]
|
|
80018c6: 681b ldr r3, [r3, #0]
|
|
80018c8: 68d9 ldr r1, [r3, #12]
|
|
80018ca: 687b ldr r3, [r7, #4]
|
|
80018cc: 689a ldr r2, [r3, #8]
|
|
80018ce: 687b ldr r3, [r7, #4]
|
|
80018d0: 681b ldr r3, [r3, #0]
|
|
80018d2: 430a orrs r2, r1
|
|
80018d4: 60da str r2, [r3, #12]
|
|
}
|
|
|
|
/* Set the Low Frequency mode */
|
|
ADC->CCR &= (uint32_t)~ADC_CCR_LFMEN;
|
|
80018d6: 4b6a ldr r3, [pc, #424] ; (8001a80 <HAL_ADC_Init+0x2d4>)
|
|
80018d8: 681a ldr r2, [r3, #0]
|
|
80018da: 4b69 ldr r3, [pc, #420] ; (8001a80 <HAL_ADC_Init+0x2d4>)
|
|
80018dc: 496a ldr r1, [pc, #424] ; (8001a88 <HAL_ADC_Init+0x2dc>)
|
|
80018de: 400a ands r2, r1
|
|
80018e0: 601a str r2, [r3, #0]
|
|
ADC->CCR |=__HAL_ADC_CCR_LOWFREQUENCY(hadc->Init.LowPowerFrequencyMode);
|
|
80018e2: 4b67 ldr r3, [pc, #412] ; (8001a80 <HAL_ADC_Init+0x2d4>)
|
|
80018e4: 6819 ldr r1, [r3, #0]
|
|
80018e6: 687b ldr r3, [r7, #4]
|
|
80018e8: 6b5b ldr r3, [r3, #52] ; 0x34
|
|
80018ea: 065a lsls r2, r3, #25
|
|
80018ec: 4b64 ldr r3, [pc, #400] ; (8001a80 <HAL_ADC_Init+0x2d4>)
|
|
80018ee: 430a orrs r2, r1
|
|
80018f0: 601a str r2, [r3, #0]
|
|
|
|
/* Enable voltage regulator (if disabled at this step) */
|
|
if (HAL_IS_BIT_CLR(hadc->Instance->CR, ADC_CR_ADVREGEN))
|
|
80018f2: 687b ldr r3, [r7, #4]
|
|
80018f4: 681b ldr r3, [r3, #0]
|
|
80018f6: 689a ldr r2, [r3, #8]
|
|
80018f8: 2380 movs r3, #128 ; 0x80
|
|
80018fa: 055b lsls r3, r3, #21
|
|
80018fc: 4013 ands r3, r2
|
|
80018fe: d108 bne.n 8001912 <HAL_ADC_Init+0x166>
|
|
{
|
|
/* Set ADVREGEN bit */
|
|
hadc->Instance->CR |= ADC_CR_ADVREGEN;
|
|
8001900: 687b ldr r3, [r7, #4]
|
|
8001902: 681b ldr r3, [r3, #0]
|
|
8001904: 689a ldr r2, [r3, #8]
|
|
8001906: 687b ldr r3, [r7, #4]
|
|
8001908: 681b ldr r3, [r3, #0]
|
|
800190a: 2180 movs r1, #128 ; 0x80
|
|
800190c: 0549 lsls r1, r1, #21
|
|
800190e: 430a orrs r2, r1
|
|
8001910: 609a str r2, [r3, #8]
|
|
/* - Continuous conversion mode */
|
|
/* - DMA continuous request */
|
|
/* - Overrun */
|
|
/* - AutoDelay feature */
|
|
/* - Discontinuous mode */
|
|
hadc->Instance->CFGR1 &= ~(ADC_CFGR1_ALIGN |
|
|
8001912: 687b ldr r3, [r7, #4]
|
|
8001914: 681b ldr r3, [r3, #0]
|
|
8001916: 68da ldr r2, [r3, #12]
|
|
8001918: 687b ldr r3, [r7, #4]
|
|
800191a: 681b ldr r3, [r3, #0]
|
|
800191c: 495b ldr r1, [pc, #364] ; (8001a8c <HAL_ADC_Init+0x2e0>)
|
|
800191e: 400a ands r2, r1
|
|
8001920: 60da str r2, [r3, #12]
|
|
ADC_CFGR1_OVRMOD |
|
|
ADC_CFGR1_AUTDLY |
|
|
ADC_CFGR1_AUTOFF |
|
|
ADC_CFGR1_DISCEN );
|
|
|
|
hadc->Instance->CFGR1 |= (hadc->Init.DataAlign |
|
|
8001922: 687b ldr r3, [r7, #4]
|
|
8001924: 681b ldr r3, [r3, #0]
|
|
8001926: 68d9 ldr r1, [r3, #12]
|
|
8001928: 687b ldr r3, [r7, #4]
|
|
800192a: 68da ldr r2, [r3, #12]
|
|
ADC_SCANDIR(hadc->Init.ScanConvMode) |
|
|
800192c: 687b ldr r3, [r7, #4]
|
|
800192e: 691b ldr r3, [r3, #16]
|
|
8001930: 2b02 cmp r3, #2
|
|
8001932: d101 bne.n 8001938 <HAL_ADC_Init+0x18c>
|
|
8001934: 2304 movs r3, #4
|
|
8001936: e000 b.n 800193a <HAL_ADC_Init+0x18e>
|
|
8001938: 2300 movs r3, #0
|
|
hadc->Instance->CFGR1 |= (hadc->Init.DataAlign |
|
|
800193a: 431a orrs r2, r3
|
|
ADC_CONTINUOUS((uint32_t)hadc->Init.ContinuousConvMode) |
|
|
800193c: 687b ldr r3, [r7, #4]
|
|
800193e: 2020 movs r0, #32
|
|
8001940: 5c1b ldrb r3, [r3, r0]
|
|
8001942: 035b lsls r3, r3, #13
|
|
ADC_SCANDIR(hadc->Init.ScanConvMode) |
|
|
8001944: 431a orrs r2, r3
|
|
ADC_DMACONTREQ((uint32_t)hadc->Init.DMAContinuousRequests) |
|
|
8001946: 687b ldr r3, [r7, #4]
|
|
8001948: 202c movs r0, #44 ; 0x2c
|
|
800194a: 5c1b ldrb r3, [r3, r0]
|
|
800194c: 005b lsls r3, r3, #1
|
|
ADC_CONTINUOUS((uint32_t)hadc->Init.ContinuousConvMode) |
|
|
800194e: 431a orrs r2, r3
|
|
hadc->Init.Overrun |
|
|
8001950: 687b ldr r3, [r7, #4]
|
|
8001952: 6b1b ldr r3, [r3, #48] ; 0x30
|
|
ADC_DMACONTREQ((uint32_t)hadc->Init.DMAContinuousRequests) |
|
|
8001954: 431a orrs r2, r3
|
|
__HAL_ADC_CFGR1_AutoDelay(hadc->Init.LowPowerAutoWait) |
|
|
8001956: 687b ldr r3, [r7, #4]
|
|
8001958: 699b ldr r3, [r3, #24]
|
|
800195a: 039b lsls r3, r3, #14
|
|
hadc->Init.Overrun |
|
|
800195c: 431a orrs r2, r3
|
|
__HAL_ADC_CFGR1_AUTOFF(hadc->Init.LowPowerAutoPowerOff));
|
|
800195e: 687b ldr r3, [r7, #4]
|
|
8001960: 69db ldr r3, [r3, #28]
|
|
8001962: 03db lsls r3, r3, #15
|
|
__HAL_ADC_CFGR1_AutoDelay(hadc->Init.LowPowerAutoWait) |
|
|
8001964: 431a orrs r2, r3
|
|
hadc->Instance->CFGR1 |= (hadc->Init.DataAlign |
|
|
8001966: 687b ldr r3, [r7, #4]
|
|
8001968: 681b ldr r3, [r3, #0]
|
|
800196a: 430a orrs r2, r1
|
|
800196c: 60da str r2, [r3, #12]
|
|
/* 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)
|
|
800196e: 687b ldr r3, [r7, #4]
|
|
8001970: 6a5a ldr r2, [r3, #36] ; 0x24
|
|
8001972: 23c2 movs r3, #194 ; 0xc2
|
|
8001974: 33ff adds r3, #255 ; 0xff
|
|
8001976: 429a cmp r2, r3
|
|
8001978: d00b beq.n 8001992 <HAL_ADC_Init+0x1e6>
|
|
{
|
|
hadc->Instance->CFGR1 |= hadc->Init.ExternalTrigConv |
|
|
800197a: 687b ldr r3, [r7, #4]
|
|
800197c: 681b ldr r3, [r3, #0]
|
|
800197e: 68d9 ldr r1, [r3, #12]
|
|
8001980: 687b ldr r3, [r7, #4]
|
|
8001982: 6a5a ldr r2, [r3, #36] ; 0x24
|
|
hadc->Init.ExternalTrigConvEdge;
|
|
8001984: 687b ldr r3, [r7, #4]
|
|
8001986: 6a9b ldr r3, [r3, #40] ; 0x28
|
|
hadc->Instance->CFGR1 |= hadc->Init.ExternalTrigConv |
|
|
8001988: 431a orrs r2, r3
|
|
800198a: 687b ldr r3, [r7, #4]
|
|
800198c: 681b ldr r3, [r3, #0]
|
|
800198e: 430a orrs r2, r1
|
|
8001990: 60da str r2, [r3, #12]
|
|
}
|
|
|
|
/* Enable discontinuous mode only if continuous mode is disabled */
|
|
if (hadc->Init.DiscontinuousConvMode == ENABLE)
|
|
8001992: 687b ldr r3, [r7, #4]
|
|
8001994: 2221 movs r2, #33 ; 0x21
|
|
8001996: 5c9b ldrb r3, [r3, r2]
|
|
8001998: 2b01 cmp r3, #1
|
|
800199a: d11a bne.n 80019d2 <HAL_ADC_Init+0x226>
|
|
{
|
|
if (hadc->Init.ContinuousConvMode == DISABLE)
|
|
800199c: 687b ldr r3, [r7, #4]
|
|
800199e: 2220 movs r2, #32
|
|
80019a0: 5c9b ldrb r3, [r3, r2]
|
|
80019a2: 2b00 cmp r3, #0
|
|
80019a4: d109 bne.n 80019ba <HAL_ADC_Init+0x20e>
|
|
{
|
|
/* Enable the selected ADC group regular discontinuous mode */
|
|
hadc->Instance->CFGR1 |= (ADC_CFGR1_DISCEN);
|
|
80019a6: 687b ldr r3, [r7, #4]
|
|
80019a8: 681b ldr r3, [r3, #0]
|
|
80019aa: 68da ldr r2, [r3, #12]
|
|
80019ac: 687b ldr r3, [r7, #4]
|
|
80019ae: 681b ldr r3, [r3, #0]
|
|
80019b0: 2180 movs r1, #128 ; 0x80
|
|
80019b2: 0249 lsls r1, r1, #9
|
|
80019b4: 430a orrs r2, r1
|
|
80019b6: 60da str r2, [r3, #12]
|
|
80019b8: e00b b.n 80019d2 <HAL_ADC_Init+0x226>
|
|
/* 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);
|
|
80019ba: 687b ldr r3, [r7, #4]
|
|
80019bc: 6d5b ldr r3, [r3, #84] ; 0x54
|
|
80019be: 2220 movs r2, #32
|
|
80019c0: 431a orrs r2, r3
|
|
80019c2: 687b ldr r3, [r7, #4]
|
|
80019c4: 655a str r2, [r3, #84] ; 0x54
|
|
|
|
/* Set ADC error code to ADC peripheral internal error */
|
|
SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_INTERNAL);
|
|
80019c6: 687b ldr r3, [r7, #4]
|
|
80019c8: 6d9b ldr r3, [r3, #88] ; 0x58
|
|
80019ca: 2201 movs r2, #1
|
|
80019cc: 431a orrs r2, r3
|
|
80019ce: 687b ldr r3, [r7, #4]
|
|
80019d0: 659a str r2, [r3, #88] ; 0x58
|
|
}
|
|
}
|
|
|
|
if (hadc->Init.OversamplingMode == ENABLE)
|
|
80019d2: 687b ldr r3, [r7, #4]
|
|
80019d4: 6bdb ldr r3, [r3, #60] ; 0x3c
|
|
80019d6: 2b01 cmp r3, #1
|
|
80019d8: d11f bne.n 8001a1a <HAL_ADC_Init+0x26e>
|
|
/* Configuration of Oversampler: */
|
|
/* - Oversampling Ratio */
|
|
/* - Right bit shift */
|
|
/* - Triggered mode */
|
|
|
|
hadc->Instance->CFGR2 &= ~( ADC_CFGR2_OVSR |
|
|
80019da: 687b ldr r3, [r7, #4]
|
|
80019dc: 681b ldr r3, [r3, #0]
|
|
80019de: 691a ldr r2, [r3, #16]
|
|
80019e0: 687b ldr r3, [r7, #4]
|
|
80019e2: 681b ldr r3, [r3, #0]
|
|
80019e4: 492a ldr r1, [pc, #168] ; (8001a90 <HAL_ADC_Init+0x2e4>)
|
|
80019e6: 400a ands r2, r1
|
|
80019e8: 611a str r2, [r3, #16]
|
|
ADC_CFGR2_OVSS |
|
|
ADC_CFGR2_TOVS );
|
|
|
|
hadc->Instance->CFGR2 |= ( hadc->Init.Oversample.Ratio |
|
|
80019ea: 687b ldr r3, [r7, #4]
|
|
80019ec: 681b ldr r3, [r3, #0]
|
|
80019ee: 6919 ldr r1, [r3, #16]
|
|
80019f0: 687b ldr r3, [r7, #4]
|
|
80019f2: 6c1a ldr r2, [r3, #64] ; 0x40
|
|
hadc->Init.Oversample.RightBitShift |
|
|
80019f4: 687b ldr r3, [r7, #4]
|
|
80019f6: 6c5b ldr r3, [r3, #68] ; 0x44
|
|
hadc->Instance->CFGR2 |= ( hadc->Init.Oversample.Ratio |
|
|
80019f8: 431a orrs r2, r3
|
|
hadc->Init.Oversample.TriggeredMode );
|
|
80019fa: 687b ldr r3, [r7, #4]
|
|
80019fc: 6c9b ldr r3, [r3, #72] ; 0x48
|
|
hadc->Init.Oversample.RightBitShift |
|
|
80019fe: 431a orrs r2, r3
|
|
hadc->Instance->CFGR2 |= ( hadc->Init.Oversample.Ratio |
|
|
8001a00: 687b ldr r3, [r7, #4]
|
|
8001a02: 681b ldr r3, [r3, #0]
|
|
8001a04: 430a orrs r2, r1
|
|
8001a06: 611a str r2, [r3, #16]
|
|
|
|
/* Enable OverSampling mode */
|
|
hadc->Instance->CFGR2 |= ADC_CFGR2_OVSE;
|
|
8001a08: 687b ldr r3, [r7, #4]
|
|
8001a0a: 681b ldr r3, [r3, #0]
|
|
8001a0c: 691a ldr r2, [r3, #16]
|
|
8001a0e: 687b ldr r3, [r7, #4]
|
|
8001a10: 681b ldr r3, [r3, #0]
|
|
8001a12: 2101 movs r1, #1
|
|
8001a14: 430a orrs r2, r1
|
|
8001a16: 611a str r2, [r3, #16]
|
|
8001a18: e00e b.n 8001a38 <HAL_ADC_Init+0x28c>
|
|
}
|
|
else
|
|
{
|
|
if(HAL_IS_BIT_SET(hadc->Instance->CFGR2, ADC_CFGR2_OVSE))
|
|
8001a1a: 687b ldr r3, [r7, #4]
|
|
8001a1c: 681b ldr r3, [r3, #0]
|
|
8001a1e: 691b ldr r3, [r3, #16]
|
|
8001a20: 2201 movs r2, #1
|
|
8001a22: 4013 ands r3, r2
|
|
8001a24: 2b01 cmp r3, #1
|
|
8001a26: d107 bne.n 8001a38 <HAL_ADC_Init+0x28c>
|
|
{
|
|
/* Disable OverSampling mode if needed */
|
|
hadc->Instance->CFGR2 &= ~ADC_CFGR2_OVSE;
|
|
8001a28: 687b ldr r3, [r7, #4]
|
|
8001a2a: 681b ldr r3, [r3, #0]
|
|
8001a2c: 691a ldr r2, [r3, #16]
|
|
8001a2e: 687b ldr r3, [r7, #4]
|
|
8001a30: 681b ldr r3, [r3, #0]
|
|
8001a32: 2101 movs r1, #1
|
|
8001a34: 438a bics r2, r1
|
|
8001a36: 611a str r2, [r3, #16]
|
|
}
|
|
}
|
|
|
|
/* Clear the old sampling time */
|
|
hadc->Instance->SMPR &= (uint32_t)(~ADC_SMPR_SMPR);
|
|
8001a38: 687b ldr r3, [r7, #4]
|
|
8001a3a: 681b ldr r3, [r3, #0]
|
|
8001a3c: 695a ldr r2, [r3, #20]
|
|
8001a3e: 687b ldr r3, [r7, #4]
|
|
8001a40: 681b ldr r3, [r3, #0]
|
|
8001a42: 2107 movs r1, #7
|
|
8001a44: 438a bics r2, r1
|
|
8001a46: 615a str r2, [r3, #20]
|
|
|
|
/* Set the new sample time */
|
|
hadc->Instance->SMPR |= hadc->Init.SamplingTime;
|
|
8001a48: 687b ldr r3, [r7, #4]
|
|
8001a4a: 681b ldr r3, [r3, #0]
|
|
8001a4c: 6959 ldr r1, [r3, #20]
|
|
8001a4e: 687b ldr r3, [r7, #4]
|
|
8001a50: 6b9a ldr r2, [r3, #56] ; 0x38
|
|
8001a52: 687b ldr r3, [r7, #4]
|
|
8001a54: 681b ldr r3, [r3, #0]
|
|
8001a56: 430a orrs r2, r1
|
|
8001a58: 615a str r2, [r3, #20]
|
|
|
|
/* Clear ADC error code */
|
|
ADC_CLEAR_ERRORCODE(hadc);
|
|
8001a5a: 687b ldr r3, [r7, #4]
|
|
8001a5c: 2200 movs r2, #0
|
|
8001a5e: 659a str r2, [r3, #88] ; 0x58
|
|
|
|
/* Set the ADC state */
|
|
ADC_STATE_CLR_SET(hadc->State,
|
|
8001a60: 687b ldr r3, [r7, #4]
|
|
8001a62: 6d5b ldr r3, [r3, #84] ; 0x54
|
|
8001a64: 2203 movs r2, #3
|
|
8001a66: 4393 bics r3, r2
|
|
8001a68: 2201 movs r2, #1
|
|
8001a6a: 431a orrs r2, r3
|
|
8001a6c: 687b ldr r3, [r7, #4]
|
|
8001a6e: 655a str r2, [r3, #84] ; 0x54
|
|
HAL_ADC_STATE_BUSY_INTERNAL,
|
|
HAL_ADC_STATE_READY);
|
|
|
|
|
|
/* Return function status */
|
|
return HAL_OK;
|
|
8001a70: 2300 movs r3, #0
|
|
}
|
|
8001a72: 0018 movs r0, r3
|
|
8001a74: 46bd mov sp, r7
|
|
8001a76: b002 add sp, #8
|
|
8001a78: bd80 pop {r7, pc}
|
|
8001a7a: 46c0 nop ; (mov r8, r8)
|
|
8001a7c: fffffefd .word 0xfffffefd
|
|
8001a80: 40012708 .word 0x40012708
|
|
8001a84: ffc3ffff .word 0xffc3ffff
|
|
8001a88: fdffffff .word 0xfdffffff
|
|
8001a8c: fffe0219 .word 0xfffe0219
|
|
8001a90: fffffc03 .word 0xfffffc03
|
|
|
|
08001a94 <HAL_ADC_IRQHandler>:
|
|
* @brief Handle ADC interrupt request.
|
|
* @param hadc ADC handle
|
|
* @retval None
|
|
*/
|
|
void HAL_ADC_IRQHandler(ADC_HandleTypeDef* hadc)
|
|
{
|
|
8001a94: b580 push {r7, lr}
|
|
8001a96: b082 sub sp, #8
|
|
8001a98: af00 add r7, sp, #0
|
|
8001a9a: 6078 str r0, [r7, #4]
|
|
assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance));
|
|
assert_param(IS_FUNCTIONAL_STATE(hadc->Init.ContinuousConvMode));
|
|
assert_param(IS_ADC_EOC_SELECTION(hadc->Init.EOCSelection));
|
|
|
|
/* ========== Check End of Conversion flag for regular group ========== */
|
|
if( (__HAL_ADC_GET_FLAG(hadc, ADC_FLAG_EOC) && __HAL_ADC_GET_IT_SOURCE(hadc, ADC_IT_EOC)) ||
|
|
8001a9c: 687b ldr r3, [r7, #4]
|
|
8001a9e: 681b ldr r3, [r3, #0]
|
|
8001aa0: 681b ldr r3, [r3, #0]
|
|
8001aa2: 2204 movs r2, #4
|
|
8001aa4: 4013 ands r3, r2
|
|
8001aa6: 2b04 cmp r3, #4
|
|
8001aa8: d106 bne.n 8001ab8 <HAL_ADC_IRQHandler+0x24>
|
|
8001aaa: 687b ldr r3, [r7, #4]
|
|
8001aac: 681b ldr r3, [r3, #0]
|
|
8001aae: 685b ldr r3, [r3, #4]
|
|
8001ab0: 2204 movs r2, #4
|
|
8001ab2: 4013 ands r3, r2
|
|
8001ab4: 2b04 cmp r3, #4
|
|
8001ab6: d00d beq.n 8001ad4 <HAL_ADC_IRQHandler+0x40>
|
|
(__HAL_ADC_GET_FLAG(hadc, ADC_FLAG_EOS) && __HAL_ADC_GET_IT_SOURCE(hadc, ADC_IT_EOS)) )
|
|
8001ab8: 687b ldr r3, [r7, #4]
|
|
8001aba: 681b ldr r3, [r3, #0]
|
|
8001abc: 681b ldr r3, [r3, #0]
|
|
8001abe: 2208 movs r2, #8
|
|
8001ac0: 4013 ands r3, r2
|
|
if( (__HAL_ADC_GET_FLAG(hadc, ADC_FLAG_EOC) && __HAL_ADC_GET_IT_SOURCE(hadc, ADC_IT_EOC)) ||
|
|
8001ac2: 2b08 cmp r3, #8
|
|
8001ac4: d154 bne.n 8001b70 <HAL_ADC_IRQHandler+0xdc>
|
|
(__HAL_ADC_GET_FLAG(hadc, ADC_FLAG_EOS) && __HAL_ADC_GET_IT_SOURCE(hadc, ADC_IT_EOS)) )
|
|
8001ac6: 687b ldr r3, [r7, #4]
|
|
8001ac8: 681b ldr r3, [r3, #0]
|
|
8001aca: 685b ldr r3, [r3, #4]
|
|
8001acc: 2208 movs r2, #8
|
|
8001ace: 4013 ands r3, r2
|
|
8001ad0: 2b08 cmp r3, #8
|
|
8001ad2: d14d bne.n 8001b70 <HAL_ADC_IRQHandler+0xdc>
|
|
{
|
|
/* Update state machine on conversion status if not in error state */
|
|
if (HAL_IS_BIT_CLR(hadc->State, HAL_ADC_STATE_ERROR_INTERNAL))
|
|
8001ad4: 687b ldr r3, [r7, #4]
|
|
8001ad6: 6d5b ldr r3, [r3, #84] ; 0x54
|
|
8001ad8: 2210 movs r2, #16
|
|
8001ada: 4013 ands r3, r2
|
|
8001adc: d106 bne.n 8001aec <HAL_ADC_IRQHandler+0x58>
|
|
{
|
|
/* Set ADC state */
|
|
SET_BIT(hadc->State, HAL_ADC_STATE_REG_EOC);
|
|
8001ade: 687b ldr r3, [r7, #4]
|
|
8001ae0: 6d5b ldr r3, [r3, #84] ; 0x54
|
|
8001ae2: 2280 movs r2, #128 ; 0x80
|
|
8001ae4: 0092 lsls r2, r2, #2
|
|
8001ae6: 431a orrs r2, r3
|
|
8001ae8: 687b ldr r3, [r7, #4]
|
|
8001aea: 655a str r2, [r3, #84] ; 0x54
|
|
}
|
|
|
|
/* 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) &&
|
|
8001aec: 687b ldr r3, [r7, #4]
|
|
8001aee: 681b ldr r3, [r3, #0]
|
|
8001af0: 68da ldr r2, [r3, #12]
|
|
8001af2: 23c0 movs r3, #192 ; 0xc0
|
|
8001af4: 011b lsls r3, r3, #4
|
|
8001af6: 4013 ands r3, r2
|
|
8001af8: d12e bne.n 8001b58 <HAL_ADC_IRQHandler+0xc4>
|
|
(hadc->Init.ContinuousConvMode == DISABLE) )
|
|
8001afa: 687b ldr r3, [r7, #4]
|
|
8001afc: 2220 movs r2, #32
|
|
8001afe: 5c9b ldrb r3, [r3, r2]
|
|
if(ADC_IS_SOFTWARE_START_REGULAR(hadc) &&
|
|
8001b00: 2b00 cmp r3, #0
|
|
8001b02: d129 bne.n 8001b58 <HAL_ADC_IRQHandler+0xc4>
|
|
{
|
|
/* If End of Sequence is reached, disable interrupts */
|
|
if( __HAL_ADC_GET_FLAG(hadc, ADC_FLAG_EOS) )
|
|
8001b04: 687b ldr r3, [r7, #4]
|
|
8001b06: 681b ldr r3, [r3, #0]
|
|
8001b08: 681b ldr r3, [r3, #0]
|
|
8001b0a: 2208 movs r2, #8
|
|
8001b0c: 4013 ands r3, r2
|
|
8001b0e: 2b08 cmp r3, #8
|
|
8001b10: d122 bne.n 8001b58 <HAL_ADC_IRQHandler+0xc4>
|
|
{
|
|
/* 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)
|
|
8001b12: 687b ldr r3, [r7, #4]
|
|
8001b14: 681b ldr r3, [r3, #0]
|
|
8001b16: 689b ldr r3, [r3, #8]
|
|
8001b18: 2204 movs r2, #4
|
|
8001b1a: 4013 ands r3, r2
|
|
8001b1c: d110 bne.n 8001b40 <HAL_ADC_IRQHandler+0xac>
|
|
{
|
|
/* 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);
|
|
8001b1e: 687b ldr r3, [r7, #4]
|
|
8001b20: 681b ldr r3, [r3, #0]
|
|
8001b22: 685a ldr r2, [r3, #4]
|
|
8001b24: 687b ldr r3, [r7, #4]
|
|
8001b26: 681b ldr r3, [r3, #0]
|
|
8001b28: 210c movs r1, #12
|
|
8001b2a: 438a bics r2, r1
|
|
8001b2c: 605a str r2, [r3, #4]
|
|
|
|
/* Set ADC state */
|
|
ADC_STATE_CLR_SET(hadc->State,
|
|
8001b2e: 687b ldr r3, [r7, #4]
|
|
8001b30: 6d5b ldr r3, [r3, #84] ; 0x54
|
|
8001b32: 4a35 ldr r2, [pc, #212] ; (8001c08 <HAL_ADC_IRQHandler+0x174>)
|
|
8001b34: 4013 ands r3, r2
|
|
8001b36: 2201 movs r2, #1
|
|
8001b38: 431a orrs r2, r3
|
|
8001b3a: 687b ldr r3, [r7, #4]
|
|
8001b3c: 655a str r2, [r3, #84] ; 0x54
|
|
8001b3e: e00b b.n 8001b58 <HAL_ADC_IRQHandler+0xc4>
|
|
HAL_ADC_STATE_READY);
|
|
}
|
|
else
|
|
{
|
|
/* Change ADC state to error state */
|
|
SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_CONFIG);
|
|
8001b40: 687b ldr r3, [r7, #4]
|
|
8001b42: 6d5b ldr r3, [r3, #84] ; 0x54
|
|
8001b44: 2220 movs r2, #32
|
|
8001b46: 431a orrs r2, r3
|
|
8001b48: 687b ldr r3, [r7, #4]
|
|
8001b4a: 655a str r2, [r3, #84] ; 0x54
|
|
|
|
/* Set ADC error code to ADC peripheral internal error */
|
|
SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_INTERNAL);
|
|
8001b4c: 687b ldr r3, [r7, #4]
|
|
8001b4e: 6d9b ldr r3, [r3, #88] ; 0x58
|
|
8001b50: 2201 movs r2, #1
|
|
8001b52: 431a orrs r2, r3
|
|
8001b54: 687b ldr r3, [r7, #4]
|
|
8001b56: 659a str r2, [r3, #88] ; 0x58
|
|
/* from EOC or EOS, possibility to use: */
|
|
/* " if( __HAL_ADC_GET_FLAG(&hadc, ADC_FLAG_EOS)) " */
|
|
#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1)
|
|
hadc->ConvCpltCallback(hadc);
|
|
#else
|
|
HAL_ADC_ConvCpltCallback(hadc);
|
|
8001b58: 687b ldr r3, [r7, #4]
|
|
8001b5a: 0018 movs r0, r3
|
|
8001b5c: f000 f856 bl 8001c0c <HAL_ADC_ConvCpltCallback>
|
|
/* Note: Management of low power auto-wait enabled: flags must be cleared */
|
|
/* by user when fetching ADC conversion data. */
|
|
/* This case is managed in IRQ handler, but this low-power mode */
|
|
/* should not be used with programming model IT or DMA. */
|
|
/* Refer to comment of parameter "LowPowerAutoWait". */
|
|
if (hadc->Init.LowPowerAutoWait != ENABLE)
|
|
8001b60: 687b ldr r3, [r7, #4]
|
|
8001b62: 699b ldr r3, [r3, #24]
|
|
8001b64: 2b01 cmp r3, #1
|
|
8001b66: d003 beq.n 8001b70 <HAL_ADC_IRQHandler+0xdc>
|
|
{
|
|
__HAL_ADC_CLEAR_FLAG(hadc, (ADC_FLAG_EOC | ADC_FLAG_EOS));
|
|
8001b68: 687b ldr r3, [r7, #4]
|
|
8001b6a: 681b ldr r3, [r3, #0]
|
|
8001b6c: 220c movs r2, #12
|
|
8001b6e: 601a str r2, [r3, #0]
|
|
}
|
|
}
|
|
|
|
/* ========== Check analog watchdog 1 flag ========== */
|
|
if(__HAL_ADC_GET_FLAG(hadc, ADC_FLAG_AWD) && __HAL_ADC_GET_IT_SOURCE(hadc, ADC_IT_AWD))
|
|
8001b70: 687b ldr r3, [r7, #4]
|
|
8001b72: 681b ldr r3, [r3, #0]
|
|
8001b74: 681b ldr r3, [r3, #0]
|
|
8001b76: 2280 movs r2, #128 ; 0x80
|
|
8001b78: 4013 ands r3, r2
|
|
8001b7a: 2b80 cmp r3, #128 ; 0x80
|
|
8001b7c: d115 bne.n 8001baa <HAL_ADC_IRQHandler+0x116>
|
|
8001b7e: 687b ldr r3, [r7, #4]
|
|
8001b80: 681b ldr r3, [r3, #0]
|
|
8001b82: 685b ldr r3, [r3, #4]
|
|
8001b84: 2280 movs r2, #128 ; 0x80
|
|
8001b86: 4013 ands r3, r2
|
|
8001b88: 2b80 cmp r3, #128 ; 0x80
|
|
8001b8a: d10e bne.n 8001baa <HAL_ADC_IRQHandler+0x116>
|
|
{
|
|
/* Set ADC state */
|
|
SET_BIT(hadc->State, HAL_ADC_STATE_AWD1);
|
|
8001b8c: 687b ldr r3, [r7, #4]
|
|
8001b8e: 6d5b ldr r3, [r3, #84] ; 0x54
|
|
8001b90: 2280 movs r2, #128 ; 0x80
|
|
8001b92: 0252 lsls r2, r2, #9
|
|
8001b94: 431a orrs r2, r3
|
|
8001b96: 687b ldr r3, [r7, #4]
|
|
8001b98: 655a str r2, [r3, #84] ; 0x54
|
|
|
|
#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1)
|
|
hadc->LevelOutOfWindowCallback(hadc);
|
|
#else
|
|
HAL_ADC_LevelOutOfWindowCallback(hadc);
|
|
8001b9a: 687b ldr r3, [r7, #4]
|
|
8001b9c: 0018 movs r0, r3
|
|
8001b9e: f000 f83d bl 8001c1c <HAL_ADC_LevelOutOfWindowCallback>
|
|
#endif /* USE_HAL_ADC_REGISTER_CALLBACKS */
|
|
|
|
/* Clear ADC Analog watchdog flag */
|
|
__HAL_ADC_CLEAR_FLAG(hadc, ADC_FLAG_AWD);
|
|
8001ba2: 687b ldr r3, [r7, #4]
|
|
8001ba4: 681b ldr r3, [r3, #0]
|
|
8001ba6: 2280 movs r2, #128 ; 0x80
|
|
8001ba8: 601a str r2, [r3, #0]
|
|
|
|
}
|
|
|
|
|
|
/* ========== Check Overrun flag ========== */
|
|
if(__HAL_ADC_GET_FLAG(hadc, ADC_FLAG_OVR) && __HAL_ADC_GET_IT_SOURCE(hadc, ADC_IT_OVR))
|
|
8001baa: 687b ldr r3, [r7, #4]
|
|
8001bac: 681b ldr r3, [r3, #0]
|
|
8001bae: 681b ldr r3, [r3, #0]
|
|
8001bb0: 2210 movs r2, #16
|
|
8001bb2: 4013 ands r3, r2
|
|
8001bb4: 2b10 cmp r3, #16
|
|
8001bb6: d123 bne.n 8001c00 <HAL_ADC_IRQHandler+0x16c>
|
|
8001bb8: 687b ldr r3, [r7, #4]
|
|
8001bba: 681b ldr r3, [r3, #0]
|
|
8001bbc: 685b ldr r3, [r3, #4]
|
|
8001bbe: 2210 movs r2, #16
|
|
8001bc0: 4013 ands r3, r2
|
|
8001bc2: 2b10 cmp r3, #16
|
|
8001bc4: d11c bne.n 8001c00 <HAL_ADC_IRQHandler+0x16c>
|
|
/* overrun event is not considered as an error. */
|
|
/* (cf ref manual "Managing conversions without using the DMA and without */
|
|
/* overrun ") */
|
|
/* Exception for usage with DMA overrun event always considered as an */
|
|
/* error. */
|
|
if ((hadc->Init.Overrun == ADC_OVR_DATA_PRESERVED) ||
|
|
8001bc6: 687b ldr r3, [r7, #4]
|
|
8001bc8: 6b1b ldr r3, [r3, #48] ; 0x30
|
|
8001bca: 2b00 cmp r3, #0
|
|
8001bcc: d006 beq.n 8001bdc <HAL_ADC_IRQHandler+0x148>
|
|
HAL_IS_BIT_SET(hadc->Instance->CFGR1, ADC_CFGR1_DMAEN) )
|
|
8001bce: 687b ldr r3, [r7, #4]
|
|
8001bd0: 681b ldr r3, [r3, #0]
|
|
8001bd2: 68db ldr r3, [r3, #12]
|
|
8001bd4: 2201 movs r2, #1
|
|
8001bd6: 4013 ands r3, r2
|
|
if ((hadc->Init.Overrun == ADC_OVR_DATA_PRESERVED) ||
|
|
8001bd8: 2b01 cmp r3, #1
|
|
8001bda: d10d bne.n 8001bf8 <HAL_ADC_IRQHandler+0x164>
|
|
{
|
|
/* Set ADC error code to overrun */
|
|
SET_BIT(hadc->ErrorCode, HAL_ADC_ERROR_OVR);
|
|
8001bdc: 687b ldr r3, [r7, #4]
|
|
8001bde: 6d9b ldr r3, [r3, #88] ; 0x58
|
|
8001be0: 2202 movs r2, #2
|
|
8001be2: 431a orrs r2, r3
|
|
8001be4: 687b ldr r3, [r7, #4]
|
|
8001be6: 659a str r2, [r3, #88] ; 0x58
|
|
|
|
/* Clear ADC overrun flag */
|
|
__HAL_ADC_CLEAR_FLAG(hadc, ADC_FLAG_OVR);
|
|
8001be8: 687b ldr r3, [r7, #4]
|
|
8001bea: 681b ldr r3, [r3, #0]
|
|
8001bec: 2210 movs r2, #16
|
|
8001bee: 601a str r2, [r3, #0]
|
|
|
|
#if (USE_HAL_ADC_REGISTER_CALLBACKS == 1)
|
|
hadc->ErrorCallback(hadc);
|
|
#else
|
|
HAL_ADC_ErrorCallback(hadc);
|
|
8001bf0: 687b ldr r3, [r7, #4]
|
|
8001bf2: 0018 movs r0, r3
|
|
8001bf4: f000 f81a bl 8001c2c <HAL_ADC_ErrorCallback>
|
|
#endif /* USE_HAL_ADC_REGISTER_CALLBACKS */
|
|
}
|
|
|
|
/* Clear the Overrun flag */
|
|
__HAL_ADC_CLEAR_FLAG(hadc, ADC_FLAG_OVR);
|
|
8001bf8: 687b ldr r3, [r7, #4]
|
|
8001bfa: 681b ldr r3, [r3, #0]
|
|
8001bfc: 2210 movs r2, #16
|
|
8001bfe: 601a str r2, [r3, #0]
|
|
}
|
|
|
|
}
|
|
8001c00: 46c0 nop ; (mov r8, r8)
|
|
8001c02: 46bd mov sp, r7
|
|
8001c04: b002 add sp, #8
|
|
8001c06: bd80 pop {r7, pc}
|
|
8001c08: fffffefe .word 0xfffffefe
|
|
|
|
08001c0c <HAL_ADC_ConvCpltCallback>:
|
|
* @brief Conversion complete callback in non-blocking mode.
|
|
* @param hadc ADC handle
|
|
* @retval None
|
|
*/
|
|
__weak void HAL_ADC_ConvCpltCallback(ADC_HandleTypeDef* hadc)
|
|
{
|
|
8001c0c: b580 push {r7, lr}
|
|
8001c0e: b082 sub sp, #8
|
|
8001c10: af00 add r7, sp, #0
|
|
8001c12: 6078 str r0, [r7, #4]
|
|
UNUSED(hadc);
|
|
|
|
/* NOTE : This function should not be modified. When the callback is needed,
|
|
function HAL_ADC_ConvCpltCallback must be implemented in the user file.
|
|
*/
|
|
}
|
|
8001c14: 46c0 nop ; (mov r8, r8)
|
|
8001c16: 46bd mov sp, r7
|
|
8001c18: b002 add sp, #8
|
|
8001c1a: bd80 pop {r7, pc}
|
|
|
|
08001c1c <HAL_ADC_LevelOutOfWindowCallback>:
|
|
* @brief Analog watchdog 1 callback in non-blocking mode.
|
|
* @param hadc ADC handle
|
|
* @retval None
|
|
*/
|
|
__weak void HAL_ADC_LevelOutOfWindowCallback(ADC_HandleTypeDef* hadc)
|
|
{
|
|
8001c1c: b580 push {r7, lr}
|
|
8001c1e: b082 sub sp, #8
|
|
8001c20: af00 add r7, sp, #0
|
|
8001c22: 6078 str r0, [r7, #4]
|
|
UNUSED(hadc);
|
|
|
|
/* NOTE : This function should not be modified. When the callback is needed,
|
|
function HAL_ADC_LevelOutOfWindowCallback must be implemented in the user file.
|
|
*/
|
|
}
|
|
8001c24: 46c0 nop ; (mov r8, r8)
|
|
8001c26: 46bd mov sp, r7
|
|
8001c28: b002 add sp, #8
|
|
8001c2a: bd80 pop {r7, pc}
|
|
|
|
08001c2c <HAL_ADC_ErrorCallback>:
|
|
* (this function is also clearing overrun flag)
|
|
* @param hadc ADC handle
|
|
* @retval None
|
|
*/
|
|
__weak void HAL_ADC_ErrorCallback(ADC_HandleTypeDef *hadc)
|
|
{
|
|
8001c2c: b580 push {r7, lr}
|
|
8001c2e: b082 sub sp, #8
|
|
8001c30: af00 add r7, sp, #0
|
|
8001c32: 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.
|
|
*/
|
|
}
|
|
8001c34: 46c0 nop ; (mov r8, r8)
|
|
8001c36: 46bd mov sp, r7
|
|
8001c38: b002 add sp, #8
|
|
8001c3a: bd80 pop {r7, pc}
|
|
|
|
08001c3c <HAL_ADC_ConfigChannel>:
|
|
* @param hadc ADC handle
|
|
* @param sConfig Structure of ADC channel assigned to ADC group regular.
|
|
* @retval HAL status
|
|
*/
|
|
HAL_StatusTypeDef HAL_ADC_ConfigChannel(ADC_HandleTypeDef* hadc, ADC_ChannelConfTypeDef* sConfig)
|
|
{
|
|
8001c3c: b580 push {r7, lr}
|
|
8001c3e: b082 sub sp, #8
|
|
8001c40: af00 add r7, sp, #0
|
|
8001c42: 6078 str r0, [r7, #4]
|
|
8001c44: 6039 str r1, [r7, #0]
|
|
assert_param(IS_ADC_ALL_INSTANCE(hadc->Instance));
|
|
assert_param(IS_ADC_CHANNEL(sConfig->Channel));
|
|
assert_param(IS_ADC_RANK(sConfig->Rank));
|
|
|
|
/* Process locked */
|
|
__HAL_LOCK(hadc);
|
|
8001c46: 687b ldr r3, [r7, #4]
|
|
8001c48: 2250 movs r2, #80 ; 0x50
|
|
8001c4a: 5c9b ldrb r3, [r3, r2]
|
|
8001c4c: 2b01 cmp r3, #1
|
|
8001c4e: d101 bne.n 8001c54 <HAL_ADC_ConfigChannel+0x18>
|
|
8001c50: 2302 movs r3, #2
|
|
8001c52: e050 b.n 8001cf6 <HAL_ADC_ConfigChannel+0xba>
|
|
8001c54: 687b ldr r3, [r7, #4]
|
|
8001c56: 2250 movs r2, #80 ; 0x50
|
|
8001c58: 2101 movs r1, #1
|
|
8001c5a: 5499 strb r1, [r3, r2]
|
|
/* Parameters update conditioned to ADC state: */
|
|
/* Parameters that can be updated when ADC is disabled or enabled without */
|
|
/* conversion on going on regular group: */
|
|
/* - Channel number */
|
|
/* - Management of internal measurement channels: Vbat/VrefInt/TempSensor */
|
|
if (ADC_IS_CONVERSION_ONGOING_REGULAR(hadc) != RESET)
|
|
8001c5c: 687b ldr r3, [r7, #4]
|
|
8001c5e: 681b ldr r3, [r3, #0]
|
|
8001c60: 689b ldr r3, [r3, #8]
|
|
8001c62: 2204 movs r2, #4
|
|
8001c64: 4013 ands r3, r2
|
|
8001c66: d00b beq.n 8001c80 <HAL_ADC_ConfigChannel+0x44>
|
|
{
|
|
/* Update ADC state machine to error */
|
|
SET_BIT(hadc->State, HAL_ADC_STATE_ERROR_CONFIG);
|
|
8001c68: 687b ldr r3, [r7, #4]
|
|
8001c6a: 6d5b ldr r3, [r3, #84] ; 0x54
|
|
8001c6c: 2220 movs r2, #32
|
|
8001c6e: 431a orrs r2, r3
|
|
8001c70: 687b ldr r3, [r7, #4]
|
|
8001c72: 655a str r2, [r3, #84] ; 0x54
|
|
/* Process unlocked */
|
|
__HAL_UNLOCK(hadc);
|
|
8001c74: 687b ldr r3, [r7, #4]
|
|
8001c76: 2250 movs r2, #80 ; 0x50
|
|
8001c78: 2100 movs r1, #0
|
|
8001c7a: 5499 strb r1, [r3, r2]
|
|
return HAL_ERROR;
|
|
8001c7c: 2301 movs r3, #1
|
|
8001c7e: e03a b.n 8001cf6 <HAL_ADC_ConfigChannel+0xba>
|
|
}
|
|
|
|
if (sConfig->Rank != ADC_RANK_NONE)
|
|
8001c80: 683b ldr r3, [r7, #0]
|
|
8001c82: 685b ldr r3, [r3, #4]
|
|
8001c84: 4a1e ldr r2, [pc, #120] ; (8001d00 <HAL_ADC_ConfigChannel+0xc4>)
|
|
8001c86: 4293 cmp r3, r2
|
|
8001c88: d018 beq.n 8001cbc <HAL_ADC_ConfigChannel+0x80>
|
|
{
|
|
/* Enable selected channels */
|
|
hadc->Instance->CHSELR |= (uint32_t)(sConfig->Channel & ADC_CHANNEL_MASK);
|
|
8001c8a: 687b ldr r3, [r7, #4]
|
|
8001c8c: 681b ldr r3, [r3, #0]
|
|
8001c8e: 6a99 ldr r1, [r3, #40] ; 0x28
|
|
8001c90: 683b ldr r3, [r7, #0]
|
|
8001c92: 681b ldr r3, [r3, #0]
|
|
8001c94: 035b lsls r3, r3, #13
|
|
8001c96: 0b5a lsrs r2, r3, #13
|
|
8001c98: 687b ldr r3, [r7, #4]
|
|
8001c9a: 681b ldr r3, [r3, #0]
|
|
8001c9c: 430a orrs r2, r1
|
|
8001c9e: 629a str r2, [r3, #40] ; 0x28
|
|
ADC_DelayMicroSecond(ADC_TEMPSENSOR_DELAY_US);
|
|
}
|
|
#endif
|
|
|
|
/* If VRefInt channel is selected, then enable the internal buffers and path */
|
|
if (((sConfig->Channel & ADC_CHANNEL_MASK) & ADC_CHANNEL_VREFINT) == (ADC_CHANNEL_VREFINT & ADC_CHANNEL_MASK))
|
|
8001ca0: 683b ldr r3, [r7, #0]
|
|
8001ca2: 681a ldr r2, [r3, #0]
|
|
8001ca4: 2380 movs r3, #128 ; 0x80
|
|
8001ca6: 029b lsls r3, r3, #10
|
|
8001ca8: 4013 ands r3, r2
|
|
8001caa: d01f beq.n 8001cec <HAL_ADC_ConfigChannel+0xb0>
|
|
{
|
|
ADC->CCR |= ADC_CCR_VREFEN;
|
|
8001cac: 4b15 ldr r3, [pc, #84] ; (8001d04 <HAL_ADC_ConfigChannel+0xc8>)
|
|
8001cae: 681a ldr r2, [r3, #0]
|
|
8001cb0: 4b14 ldr r3, [pc, #80] ; (8001d04 <HAL_ADC_ConfigChannel+0xc8>)
|
|
8001cb2: 2180 movs r1, #128 ; 0x80
|
|
8001cb4: 03c9 lsls r1, r1, #15
|
|
8001cb6: 430a orrs r2, r1
|
|
8001cb8: 601a str r2, [r3, #0]
|
|
8001cba: e017 b.n 8001cec <HAL_ADC_ConfigChannel+0xb0>
|
|
}
|
|
else
|
|
{
|
|
/* Regular sequence configuration */
|
|
/* Reset the channel selection register from the selected channel */
|
|
hadc->Instance->CHSELR &= ~((uint32_t)(sConfig->Channel & ADC_CHANNEL_MASK));
|
|
8001cbc: 687b ldr r3, [r7, #4]
|
|
8001cbe: 681b ldr r3, [r3, #0]
|
|
8001cc0: 6a9a ldr r2, [r3, #40] ; 0x28
|
|
8001cc2: 683b ldr r3, [r7, #0]
|
|
8001cc4: 681b ldr r3, [r3, #0]
|
|
8001cc6: 035b lsls r3, r3, #13
|
|
8001cc8: 0b5b lsrs r3, r3, #13
|
|
8001cca: 43d9 mvns r1, r3
|
|
8001ccc: 687b ldr r3, [r7, #4]
|
|
8001cce: 681b ldr r3, [r3, #0]
|
|
8001cd0: 400a ands r2, r1
|
|
8001cd2: 629a str r2, [r3, #40] ; 0x28
|
|
ADC->CCR &= ~ADC_CCR_TSEN;
|
|
}
|
|
#endif
|
|
|
|
/* If VRefInt channel is selected, then enable the internal buffers and path */
|
|
if (((sConfig->Channel & ADC_CHANNEL_MASK) & ADC_CHANNEL_VREFINT) == (ADC_CHANNEL_VREFINT & ADC_CHANNEL_MASK))
|
|
8001cd4: 683b ldr r3, [r7, #0]
|
|
8001cd6: 681a ldr r2, [r3, #0]
|
|
8001cd8: 2380 movs r3, #128 ; 0x80
|
|
8001cda: 029b lsls r3, r3, #10
|
|
8001cdc: 4013 ands r3, r2
|
|
8001cde: d005 beq.n 8001cec <HAL_ADC_ConfigChannel+0xb0>
|
|
{
|
|
ADC->CCR &= ~ADC_CCR_VREFEN;
|
|
8001ce0: 4b08 ldr r3, [pc, #32] ; (8001d04 <HAL_ADC_ConfigChannel+0xc8>)
|
|
8001ce2: 681a ldr r2, [r3, #0]
|
|
8001ce4: 4b07 ldr r3, [pc, #28] ; (8001d04 <HAL_ADC_ConfigChannel+0xc8>)
|
|
8001ce6: 4908 ldr r1, [pc, #32] ; (8001d08 <HAL_ADC_ConfigChannel+0xcc>)
|
|
8001ce8: 400a ands r2, r1
|
|
8001cea: 601a str r2, [r3, #0]
|
|
}
|
|
#endif
|
|
}
|
|
|
|
/* Process unlocked */
|
|
__HAL_UNLOCK(hadc);
|
|
8001cec: 687b ldr r3, [r7, #4]
|
|
8001cee: 2250 movs r2, #80 ; 0x50
|
|
8001cf0: 2100 movs r1, #0
|
|
8001cf2: 5499 strb r1, [r3, r2]
|
|
|
|
/* Return function status */
|
|
return HAL_OK;
|
|
8001cf4: 2300 movs r3, #0
|
|
}
|
|
8001cf6: 0018 movs r0, r3
|
|
8001cf8: 46bd mov sp, r7
|
|
8001cfa: b002 add sp, #8
|
|
8001cfc: bd80 pop {r7, pc}
|
|
8001cfe: 46c0 nop ; (mov r8, r8)
|
|
8001d00: 00001001 .word 0x00001001
|
|
8001d04: 40012708 .word 0x40012708
|
|
8001d08: ffbfffff .word 0xffbfffff
|
|
|
|
08001d0c <__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)
|
|
{
|
|
8001d0c: b580 push {r7, lr}
|
|
8001d0e: b082 sub sp, #8
|
|
8001d10: af00 add r7, sp, #0
|
|
8001d12: 0002 movs r2, r0
|
|
8001d14: 1dfb adds r3, r7, #7
|
|
8001d16: 701a strb r2, [r3, #0]
|
|
if ((int32_t)(IRQn) >= 0)
|
|
8001d18: 1dfb adds r3, r7, #7
|
|
8001d1a: 781b ldrb r3, [r3, #0]
|
|
8001d1c: 2b7f cmp r3, #127 ; 0x7f
|
|
8001d1e: d809 bhi.n 8001d34 <__NVIC_EnableIRQ+0x28>
|
|
{
|
|
NVIC->ISER[0U] = (uint32_t)(1UL << (((uint32_t)IRQn) & 0x1FUL));
|
|
8001d20: 1dfb adds r3, r7, #7
|
|
8001d22: 781b ldrb r3, [r3, #0]
|
|
8001d24: 001a movs r2, r3
|
|
8001d26: 231f movs r3, #31
|
|
8001d28: 401a ands r2, r3
|
|
8001d2a: 4b04 ldr r3, [pc, #16] ; (8001d3c <__NVIC_EnableIRQ+0x30>)
|
|
8001d2c: 2101 movs r1, #1
|
|
8001d2e: 4091 lsls r1, r2
|
|
8001d30: 000a movs r2, r1
|
|
8001d32: 601a str r2, [r3, #0]
|
|
}
|
|
}
|
|
8001d34: 46c0 nop ; (mov r8, r8)
|
|
8001d36: 46bd mov sp, r7
|
|
8001d38: b002 add sp, #8
|
|
8001d3a: bd80 pop {r7, pc}
|
|
8001d3c: e000e100 .word 0xe000e100
|
|
|
|
08001d40 <__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)
|
|
{
|
|
8001d40: b590 push {r4, r7, lr}
|
|
8001d42: b083 sub sp, #12
|
|
8001d44: af00 add r7, sp, #0
|
|
8001d46: 0002 movs r2, r0
|
|
8001d48: 6039 str r1, [r7, #0]
|
|
8001d4a: 1dfb adds r3, r7, #7
|
|
8001d4c: 701a strb r2, [r3, #0]
|
|
if ((int32_t)(IRQn) >= 0)
|
|
8001d4e: 1dfb adds r3, r7, #7
|
|
8001d50: 781b ldrb r3, [r3, #0]
|
|
8001d52: 2b7f cmp r3, #127 ; 0x7f
|
|
8001d54: d828 bhi.n 8001da8 <__NVIC_SetPriority+0x68>
|
|
{
|
|
NVIC->IP[_IP_IDX(IRQn)] = ((uint32_t)(NVIC->IP[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) |
|
|
8001d56: 4a2f ldr r2, [pc, #188] ; (8001e14 <__NVIC_SetPriority+0xd4>)
|
|
8001d58: 1dfb adds r3, r7, #7
|
|
8001d5a: 781b ldrb r3, [r3, #0]
|
|
8001d5c: b25b sxtb r3, r3
|
|
8001d5e: 089b lsrs r3, r3, #2
|
|
8001d60: 33c0 adds r3, #192 ; 0xc0
|
|
8001d62: 009b lsls r3, r3, #2
|
|
8001d64: 589b ldr r3, [r3, r2]
|
|
8001d66: 1dfa adds r2, r7, #7
|
|
8001d68: 7812 ldrb r2, [r2, #0]
|
|
8001d6a: 0011 movs r1, r2
|
|
8001d6c: 2203 movs r2, #3
|
|
8001d6e: 400a ands r2, r1
|
|
8001d70: 00d2 lsls r2, r2, #3
|
|
8001d72: 21ff movs r1, #255 ; 0xff
|
|
8001d74: 4091 lsls r1, r2
|
|
8001d76: 000a movs r2, r1
|
|
8001d78: 43d2 mvns r2, r2
|
|
8001d7a: 401a ands r2, r3
|
|
8001d7c: 0011 movs r1, r2
|
|
(((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn)));
|
|
8001d7e: 683b ldr r3, [r7, #0]
|
|
8001d80: 019b lsls r3, r3, #6
|
|
8001d82: 22ff movs r2, #255 ; 0xff
|
|
8001d84: 401a ands r2, r3
|
|
8001d86: 1dfb adds r3, r7, #7
|
|
8001d88: 781b ldrb r3, [r3, #0]
|
|
8001d8a: 0018 movs r0, r3
|
|
8001d8c: 2303 movs r3, #3
|
|
8001d8e: 4003 ands r3, r0
|
|
8001d90: 00db lsls r3, r3, #3
|
|
8001d92: 409a lsls r2, r3
|
|
NVIC->IP[_IP_IDX(IRQn)] = ((uint32_t)(NVIC->IP[_IP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) |
|
|
8001d94: 481f ldr r0, [pc, #124] ; (8001e14 <__NVIC_SetPriority+0xd4>)
|
|
8001d96: 1dfb adds r3, r7, #7
|
|
8001d98: 781b ldrb r3, [r3, #0]
|
|
8001d9a: b25b sxtb r3, r3
|
|
8001d9c: 089b lsrs r3, r3, #2
|
|
8001d9e: 430a orrs r2, r1
|
|
8001da0: 33c0 adds r3, #192 ; 0xc0
|
|
8001da2: 009b lsls r3, r3, #2
|
|
8001da4: 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)));
|
|
}
|
|
}
|
|
8001da6: e031 b.n 8001e0c <__NVIC_SetPriority+0xcc>
|
|
SCB->SHP[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHP[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) |
|
|
8001da8: 4a1b ldr r2, [pc, #108] ; (8001e18 <__NVIC_SetPriority+0xd8>)
|
|
8001daa: 1dfb adds r3, r7, #7
|
|
8001dac: 781b ldrb r3, [r3, #0]
|
|
8001dae: 0019 movs r1, r3
|
|
8001db0: 230f movs r3, #15
|
|
8001db2: 400b ands r3, r1
|
|
8001db4: 3b08 subs r3, #8
|
|
8001db6: 089b lsrs r3, r3, #2
|
|
8001db8: 3306 adds r3, #6
|
|
8001dba: 009b lsls r3, r3, #2
|
|
8001dbc: 18d3 adds r3, r2, r3
|
|
8001dbe: 3304 adds r3, #4
|
|
8001dc0: 681b ldr r3, [r3, #0]
|
|
8001dc2: 1dfa adds r2, r7, #7
|
|
8001dc4: 7812 ldrb r2, [r2, #0]
|
|
8001dc6: 0011 movs r1, r2
|
|
8001dc8: 2203 movs r2, #3
|
|
8001dca: 400a ands r2, r1
|
|
8001dcc: 00d2 lsls r2, r2, #3
|
|
8001dce: 21ff movs r1, #255 ; 0xff
|
|
8001dd0: 4091 lsls r1, r2
|
|
8001dd2: 000a movs r2, r1
|
|
8001dd4: 43d2 mvns r2, r2
|
|
8001dd6: 401a ands r2, r3
|
|
8001dd8: 0011 movs r1, r2
|
|
(((priority << (8U - __NVIC_PRIO_BITS)) & (uint32_t)0xFFUL) << _BIT_SHIFT(IRQn)));
|
|
8001dda: 683b ldr r3, [r7, #0]
|
|
8001ddc: 019b lsls r3, r3, #6
|
|
8001dde: 22ff movs r2, #255 ; 0xff
|
|
8001de0: 401a ands r2, r3
|
|
8001de2: 1dfb adds r3, r7, #7
|
|
8001de4: 781b ldrb r3, [r3, #0]
|
|
8001de6: 0018 movs r0, r3
|
|
8001de8: 2303 movs r3, #3
|
|
8001dea: 4003 ands r3, r0
|
|
8001dec: 00db lsls r3, r3, #3
|
|
8001dee: 409a lsls r2, r3
|
|
SCB->SHP[_SHP_IDX(IRQn)] = ((uint32_t)(SCB->SHP[_SHP_IDX(IRQn)] & ~(0xFFUL << _BIT_SHIFT(IRQn))) |
|
|
8001df0: 4809 ldr r0, [pc, #36] ; (8001e18 <__NVIC_SetPriority+0xd8>)
|
|
8001df2: 1dfb adds r3, r7, #7
|
|
8001df4: 781b ldrb r3, [r3, #0]
|
|
8001df6: 001c movs r4, r3
|
|
8001df8: 230f movs r3, #15
|
|
8001dfa: 4023 ands r3, r4
|
|
8001dfc: 3b08 subs r3, #8
|
|
8001dfe: 089b lsrs r3, r3, #2
|
|
8001e00: 430a orrs r2, r1
|
|
8001e02: 3306 adds r3, #6
|
|
8001e04: 009b lsls r3, r3, #2
|
|
8001e06: 18c3 adds r3, r0, r3
|
|
8001e08: 3304 adds r3, #4
|
|
8001e0a: 601a str r2, [r3, #0]
|
|
}
|
|
8001e0c: 46c0 nop ; (mov r8, r8)
|
|
8001e0e: 46bd mov sp, r7
|
|
8001e10: b003 add sp, #12
|
|
8001e12: bd90 pop {r4, r7, pc}
|
|
8001e14: e000e100 .word 0xe000e100
|
|
8001e18: e000ed00 .word 0xe000ed00
|
|
|
|
08001e1c <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)
|
|
{
|
|
8001e1c: b580 push {r7, lr}
|
|
8001e1e: b082 sub sp, #8
|
|
8001e20: af00 add r7, sp, #0
|
|
8001e22: 6078 str r0, [r7, #4]
|
|
if ((ticks - 1UL) > SysTick_LOAD_RELOAD_Msk)
|
|
8001e24: 687b ldr r3, [r7, #4]
|
|
8001e26: 1e5a subs r2, r3, #1
|
|
8001e28: 2380 movs r3, #128 ; 0x80
|
|
8001e2a: 045b lsls r3, r3, #17
|
|
8001e2c: 429a cmp r2, r3
|
|
8001e2e: d301 bcc.n 8001e34 <SysTick_Config+0x18>
|
|
{
|
|
return (1UL); /* Reload value impossible */
|
|
8001e30: 2301 movs r3, #1
|
|
8001e32: e010 b.n 8001e56 <SysTick_Config+0x3a>
|
|
}
|
|
|
|
SysTick->LOAD = (uint32_t)(ticks - 1UL); /* set reload register */
|
|
8001e34: 4b0a ldr r3, [pc, #40] ; (8001e60 <SysTick_Config+0x44>)
|
|
8001e36: 687a ldr r2, [r7, #4]
|
|
8001e38: 3a01 subs r2, #1
|
|
8001e3a: 605a str r2, [r3, #4]
|
|
NVIC_SetPriority (SysTick_IRQn, (1UL << __NVIC_PRIO_BITS) - 1UL); /* set Priority for Systick Interrupt */
|
|
8001e3c: 2301 movs r3, #1
|
|
8001e3e: 425b negs r3, r3
|
|
8001e40: 2103 movs r1, #3
|
|
8001e42: 0018 movs r0, r3
|
|
8001e44: f7ff ff7c bl 8001d40 <__NVIC_SetPriority>
|
|
SysTick->VAL = 0UL; /* Load the SysTick Counter Value */
|
|
8001e48: 4b05 ldr r3, [pc, #20] ; (8001e60 <SysTick_Config+0x44>)
|
|
8001e4a: 2200 movs r2, #0
|
|
8001e4c: 609a str r2, [r3, #8]
|
|
SysTick->CTRL = SysTick_CTRL_CLKSOURCE_Msk |
|
|
8001e4e: 4b04 ldr r3, [pc, #16] ; (8001e60 <SysTick_Config+0x44>)
|
|
8001e50: 2207 movs r2, #7
|
|
8001e52: 601a str r2, [r3, #0]
|
|
SysTick_CTRL_TICKINT_Msk |
|
|
SysTick_CTRL_ENABLE_Msk; /* Enable SysTick IRQ and SysTick Timer */
|
|
return (0UL); /* Function successful */
|
|
8001e54: 2300 movs r3, #0
|
|
}
|
|
8001e56: 0018 movs r0, r3
|
|
8001e58: 46bd mov sp, r7
|
|
8001e5a: b002 add sp, #8
|
|
8001e5c: bd80 pop {r7, pc}
|
|
8001e5e: 46c0 nop ; (mov r8, r8)
|
|
8001e60: e000e010 .word 0xe000e010
|
|
|
|
08001e64 <HAL_NVIC_SetPriority>:
|
|
* with stm32l0xx 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)
|
|
{
|
|
8001e64: b580 push {r7, lr}
|
|
8001e66: b084 sub sp, #16
|
|
8001e68: af00 add r7, sp, #0
|
|
8001e6a: 60b9 str r1, [r7, #8]
|
|
8001e6c: 607a str r2, [r7, #4]
|
|
8001e6e: 210f movs r1, #15
|
|
8001e70: 187b adds r3, r7, r1
|
|
8001e72: 1c02 adds r2, r0, #0
|
|
8001e74: 701a strb r2, [r3, #0]
|
|
/* Check the parameters */
|
|
assert_param(IS_NVIC_PREEMPTION_PRIORITY(PreemptPriority));
|
|
NVIC_SetPriority(IRQn,PreemptPriority);
|
|
8001e76: 68ba ldr r2, [r7, #8]
|
|
8001e78: 187b adds r3, r7, r1
|
|
8001e7a: 781b ldrb r3, [r3, #0]
|
|
8001e7c: b25b sxtb r3, r3
|
|
8001e7e: 0011 movs r1, r2
|
|
8001e80: 0018 movs r0, r3
|
|
8001e82: f7ff ff5d bl 8001d40 <__NVIC_SetPriority>
|
|
}
|
|
8001e86: 46c0 nop ; (mov r8, r8)
|
|
8001e88: 46bd mov sp, r7
|
|
8001e8a: b004 add sp, #16
|
|
8001e8c: bd80 pop {r7, pc}
|
|
|
|
08001e8e <HAL_NVIC_EnableIRQ>:
|
|
* This parameter can be an enumerator of IRQn_Type enumeration
|
|
* (For the complete STM32 Devices IRQ Channels list, please refer to stm32l0xx.h file)
|
|
* @retval None
|
|
*/
|
|
void HAL_NVIC_EnableIRQ(IRQn_Type IRQn)
|
|
{
|
|
8001e8e: b580 push {r7, lr}
|
|
8001e90: b082 sub sp, #8
|
|
8001e92: af00 add r7, sp, #0
|
|
8001e94: 0002 movs r2, r0
|
|
8001e96: 1dfb adds r3, r7, #7
|
|
8001e98: 701a strb r2, [r3, #0]
|
|
/* Check the parameters */
|
|
assert_param(IS_NVIC_DEVICE_IRQ(IRQn));
|
|
|
|
/* Enable interrupt */
|
|
NVIC_EnableIRQ(IRQn);
|
|
8001e9a: 1dfb adds r3, r7, #7
|
|
8001e9c: 781b ldrb r3, [r3, #0]
|
|
8001e9e: b25b sxtb r3, r3
|
|
8001ea0: 0018 movs r0, r3
|
|
8001ea2: f7ff ff33 bl 8001d0c <__NVIC_EnableIRQ>
|
|
}
|
|
8001ea6: 46c0 nop ; (mov r8, r8)
|
|
8001ea8: 46bd mov sp, r7
|
|
8001eaa: b002 add sp, #8
|
|
8001eac: bd80 pop {r7, pc}
|
|
|
|
08001eae <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)
|
|
{
|
|
8001eae: b580 push {r7, lr}
|
|
8001eb0: b082 sub sp, #8
|
|
8001eb2: af00 add r7, sp, #0
|
|
8001eb4: 6078 str r0, [r7, #4]
|
|
return SysTick_Config(TicksNumb);
|
|
8001eb6: 687b ldr r3, [r7, #4]
|
|
8001eb8: 0018 movs r0, r3
|
|
8001eba: f7ff ffaf bl 8001e1c <SysTick_Config>
|
|
8001ebe: 0003 movs r3, r0
|
|
}
|
|
8001ec0: 0018 movs r0, r3
|
|
8001ec2: 46bd mov sp, r7
|
|
8001ec4: b002 add sp, #8
|
|
8001ec6: bd80 pop {r7, pc}
|
|
|
|
08001ec8 <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)
|
|
{
|
|
8001ec8: b580 push {r7, lr}
|
|
8001eca: b084 sub sp, #16
|
|
8001ecc: af00 add r7, sp, #0
|
|
8001ece: 6078 str r0, [r7, #4]
|
|
uint32_t tmp;
|
|
|
|
/* Check the DMA handle allocation */
|
|
if(hdma == NULL)
|
|
8001ed0: 687b ldr r3, [r7, #4]
|
|
8001ed2: 2b00 cmp r3, #0
|
|
8001ed4: d101 bne.n 8001eda <HAL_DMA_Init+0x12>
|
|
{
|
|
return HAL_ERROR;
|
|
8001ed6: 2301 movs r3, #1
|
|
8001ed8: e061 b.n 8001f9e <HAL_DMA_Init+0xd6>
|
|
assert_param(IS_DMA_MODE(hdma->Init.Mode));
|
|
assert_param(IS_DMA_PRIORITY(hdma->Init.Priority));
|
|
|
|
/* Compute the channel index */
|
|
/* Only one DMA: DMA1 */
|
|
hdma->ChannelIndex = (((uint32_t)hdma->Instance - (uint32_t)DMA1_Channel1) / ((uint32_t)DMA1_Channel2 - (uint32_t)DMA1_Channel1)) << 2;
|
|
8001eda: 687b ldr r3, [r7, #4]
|
|
8001edc: 681b ldr r3, [r3, #0]
|
|
8001ede: 4a32 ldr r2, [pc, #200] ; (8001fa8 <HAL_DMA_Init+0xe0>)
|
|
8001ee0: 4694 mov ip, r2
|
|
8001ee2: 4463 add r3, ip
|
|
8001ee4: 2114 movs r1, #20
|
|
8001ee6: 0018 movs r0, r3
|
|
8001ee8: f7fe f90e bl 8000108 <__udivsi3>
|
|
8001eec: 0003 movs r3, r0
|
|
8001eee: 009a lsls r2, r3, #2
|
|
8001ef0: 687b ldr r3, [r7, #4]
|
|
8001ef2: 645a str r2, [r3, #68] ; 0x44
|
|
hdma->DmaBaseAddress = DMA1;
|
|
8001ef4: 687b ldr r3, [r7, #4]
|
|
8001ef6: 4a2d ldr r2, [pc, #180] ; (8001fac <HAL_DMA_Init+0xe4>)
|
|
8001ef8: 641a str r2, [r3, #64] ; 0x40
|
|
|
|
/* Change DMA peripheral state */
|
|
hdma->State = HAL_DMA_STATE_BUSY;
|
|
8001efa: 687b ldr r3, [r7, #4]
|
|
8001efc: 2225 movs r2, #37 ; 0x25
|
|
8001efe: 2102 movs r1, #2
|
|
8001f00: 5499 strb r1, [r3, r2]
|
|
|
|
/* Get the CR register value */
|
|
tmp = hdma->Instance->CCR;
|
|
8001f02: 687b ldr r3, [r7, #4]
|
|
8001f04: 681b ldr r3, [r3, #0]
|
|
8001f06: 681b ldr r3, [r3, #0]
|
|
8001f08: 60fb str r3, [r7, #12]
|
|
|
|
/* Clear PL, MSIZE, PSIZE, MINC, PINC, CIRC, DIR and MEM2MEM bits */
|
|
tmp &= ((uint32_t)~(DMA_CCR_PL | DMA_CCR_MSIZE | DMA_CCR_PSIZE |
|
|
8001f0a: 68fb ldr r3, [r7, #12]
|
|
8001f0c: 4a28 ldr r2, [pc, #160] ; (8001fb0 <HAL_DMA_Init+0xe8>)
|
|
8001f0e: 4013 ands r3, r2
|
|
8001f10: 60fb str r3, [r7, #12]
|
|
DMA_CCR_MINC | DMA_CCR_PINC | DMA_CCR_CIRC |
|
|
DMA_CCR_DIR | DMA_CCR_MEM2MEM));
|
|
|
|
/* Prepare the DMA Channel configuration */
|
|
tmp |= hdma->Init.Direction |
|
|
8001f12: 687b ldr r3, [r7, #4]
|
|
8001f14: 689a ldr r2, [r3, #8]
|
|
hdma->Init.PeriphInc | hdma->Init.MemInc |
|
|
8001f16: 687b ldr r3, [r7, #4]
|
|
8001f18: 68db ldr r3, [r3, #12]
|
|
tmp |= hdma->Init.Direction |
|
|
8001f1a: 431a orrs r2, r3
|
|
hdma->Init.PeriphInc | hdma->Init.MemInc |
|
|
8001f1c: 687b ldr r3, [r7, #4]
|
|
8001f1e: 691b ldr r3, [r3, #16]
|
|
8001f20: 431a orrs r2, r3
|
|
hdma->Init.PeriphDataAlignment | hdma->Init.MemDataAlignment |
|
|
8001f22: 687b ldr r3, [r7, #4]
|
|
8001f24: 695b ldr r3, [r3, #20]
|
|
hdma->Init.PeriphInc | hdma->Init.MemInc |
|
|
8001f26: 431a orrs r2, r3
|
|
hdma->Init.PeriphDataAlignment | hdma->Init.MemDataAlignment |
|
|
8001f28: 687b ldr r3, [r7, #4]
|
|
8001f2a: 699b ldr r3, [r3, #24]
|
|
8001f2c: 431a orrs r2, r3
|
|
hdma->Init.Mode | hdma->Init.Priority;
|
|
8001f2e: 687b ldr r3, [r7, #4]
|
|
8001f30: 69db ldr r3, [r3, #28]
|
|
hdma->Init.PeriphDataAlignment | hdma->Init.MemDataAlignment |
|
|
8001f32: 431a orrs r2, r3
|
|
hdma->Init.Mode | hdma->Init.Priority;
|
|
8001f34: 687b ldr r3, [r7, #4]
|
|
8001f36: 6a1b ldr r3, [r3, #32]
|
|
8001f38: 4313 orrs r3, r2
|
|
tmp |= hdma->Init.Direction |
|
|
8001f3a: 68fa ldr r2, [r7, #12]
|
|
8001f3c: 4313 orrs r3, r2
|
|
8001f3e: 60fb str r3, [r7, #12]
|
|
|
|
/* Write to DMA Channel CR register */
|
|
hdma->Instance->CCR = tmp;
|
|
8001f40: 687b ldr r3, [r7, #4]
|
|
8001f42: 681b ldr r3, [r3, #0]
|
|
8001f44: 68fa ldr r2, [r7, #12]
|
|
8001f46: 601a str r2, [r3, #0]
|
|
|
|
/* Set request selection */
|
|
if(hdma->Init.Direction != DMA_MEMORY_TO_MEMORY)
|
|
8001f48: 687b ldr r3, [r7, #4]
|
|
8001f4a: 689a ldr r2, [r3, #8]
|
|
8001f4c: 2380 movs r3, #128 ; 0x80
|
|
8001f4e: 01db lsls r3, r3, #7
|
|
8001f50: 429a cmp r2, r3
|
|
8001f52: d018 beq.n 8001f86 <HAL_DMA_Init+0xbe>
|
|
{
|
|
/* Write to DMA channel selection register */
|
|
/* Reset request selection for DMA1 Channelx */
|
|
DMA1_CSELR->CSELR &= ~(DMA_CSELR_C1S << (hdma->ChannelIndex & 0x1cU));
|
|
8001f54: 4b17 ldr r3, [pc, #92] ; (8001fb4 <HAL_DMA_Init+0xec>)
|
|
8001f56: 681a ldr r2, [r3, #0]
|
|
8001f58: 687b ldr r3, [r7, #4]
|
|
8001f5a: 6c5b ldr r3, [r3, #68] ; 0x44
|
|
8001f5c: 211c movs r1, #28
|
|
8001f5e: 400b ands r3, r1
|
|
8001f60: 210f movs r1, #15
|
|
8001f62: 4099 lsls r1, r3
|
|
8001f64: 000b movs r3, r1
|
|
8001f66: 43d9 mvns r1, r3
|
|
8001f68: 4b12 ldr r3, [pc, #72] ; (8001fb4 <HAL_DMA_Init+0xec>)
|
|
8001f6a: 400a ands r2, r1
|
|
8001f6c: 601a str r2, [r3, #0]
|
|
|
|
/* Configure request selection for DMA1 Channelx */
|
|
DMA1_CSELR->CSELR |= (uint32_t) (hdma->Init.Request << (hdma->ChannelIndex & 0x1cU));
|
|
8001f6e: 4b11 ldr r3, [pc, #68] ; (8001fb4 <HAL_DMA_Init+0xec>)
|
|
8001f70: 6819 ldr r1, [r3, #0]
|
|
8001f72: 687b ldr r3, [r7, #4]
|
|
8001f74: 685a ldr r2, [r3, #4]
|
|
8001f76: 687b ldr r3, [r7, #4]
|
|
8001f78: 6c5b ldr r3, [r3, #68] ; 0x44
|
|
8001f7a: 201c movs r0, #28
|
|
8001f7c: 4003 ands r3, r0
|
|
8001f7e: 409a lsls r2, r3
|
|
8001f80: 4b0c ldr r3, [pc, #48] ; (8001fb4 <HAL_DMA_Init+0xec>)
|
|
8001f82: 430a orrs r2, r1
|
|
8001f84: 601a str r2, [r3, #0]
|
|
}
|
|
|
|
/* Initialise the error code */
|
|
hdma->ErrorCode = HAL_DMA_ERROR_NONE;
|
|
8001f86: 687b ldr r3, [r7, #4]
|
|
8001f88: 2200 movs r2, #0
|
|
8001f8a: 63da str r2, [r3, #60] ; 0x3c
|
|
|
|
/* Initialize the DMA state*/
|
|
hdma->State = HAL_DMA_STATE_READY;
|
|
8001f8c: 687b ldr r3, [r7, #4]
|
|
8001f8e: 2225 movs r2, #37 ; 0x25
|
|
8001f90: 2101 movs r1, #1
|
|
8001f92: 5499 strb r1, [r3, r2]
|
|
|
|
/* Allocate lock resource and initialize it */
|
|
hdma->Lock = HAL_UNLOCKED;
|
|
8001f94: 687b ldr r3, [r7, #4]
|
|
8001f96: 2224 movs r2, #36 ; 0x24
|
|
8001f98: 2100 movs r1, #0
|
|
8001f9a: 5499 strb r1, [r3, r2]
|
|
|
|
return HAL_OK;
|
|
8001f9c: 2300 movs r3, #0
|
|
}
|
|
8001f9e: 0018 movs r0, r3
|
|
8001fa0: 46bd mov sp, r7
|
|
8001fa2: b004 add sp, #16
|
|
8001fa4: bd80 pop {r7, pc}
|
|
8001fa6: 46c0 nop ; (mov r8, r8)
|
|
8001fa8: bffdfff8 .word 0xbffdfff8
|
|
8001fac: 40020000 .word 0x40020000
|
|
8001fb0: ffff800f .word 0xffff800f
|
|
8001fb4: 400200a8 .word 0x400200a8
|
|
|
|
08001fb8 <HAL_DMA_Abort>:
|
|
* @param hdma pointer to a DMA_HandleTypeDef structure that contains
|
|
* the configuration information for the specified DMA Channel.
|
|
* @retval HAL status
|
|
*/
|
|
HAL_StatusTypeDef HAL_DMA_Abort(DMA_HandleTypeDef *hdma)
|
|
{
|
|
8001fb8: b580 push {r7, lr}
|
|
8001fba: b084 sub sp, #16
|
|
8001fbc: af00 add r7, sp, #0
|
|
8001fbe: 6078 str r0, [r7, #4]
|
|
HAL_StatusTypeDef status = HAL_OK;
|
|
8001fc0: 230f movs r3, #15
|
|
8001fc2: 18fb adds r3, r7, r3
|
|
8001fc4: 2200 movs r2, #0
|
|
8001fc6: 701a strb r2, [r3, #0]
|
|
|
|
/* Check the DMA peripheral state */
|
|
if(hdma->State != HAL_DMA_STATE_BUSY)
|
|
8001fc8: 687b ldr r3, [r7, #4]
|
|
8001fca: 2225 movs r2, #37 ; 0x25
|
|
8001fcc: 5c9b ldrb r3, [r3, r2]
|
|
8001fce: b2db uxtb r3, r3
|
|
8001fd0: 2b02 cmp r3, #2
|
|
8001fd2: d008 beq.n 8001fe6 <HAL_DMA_Abort+0x2e>
|
|
{
|
|
hdma->ErrorCode = HAL_DMA_ERROR_NO_XFER;
|
|
8001fd4: 687b ldr r3, [r7, #4]
|
|
8001fd6: 2204 movs r2, #4
|
|
8001fd8: 63da str r2, [r3, #60] ; 0x3c
|
|
|
|
/* Process Unlocked */
|
|
__HAL_UNLOCK(hdma);
|
|
8001fda: 687b ldr r3, [r7, #4]
|
|
8001fdc: 2224 movs r2, #36 ; 0x24
|
|
8001fde: 2100 movs r1, #0
|
|
8001fe0: 5499 strb r1, [r3, r2]
|
|
|
|
return HAL_ERROR;
|
|
8001fe2: 2301 movs r3, #1
|
|
8001fe4: e024 b.n 8002030 <HAL_DMA_Abort+0x78>
|
|
}
|
|
else
|
|
{
|
|
/* Disable DMA IT */
|
|
__HAL_DMA_DISABLE_IT(hdma, (DMA_IT_TC | DMA_IT_HT | DMA_IT_TE));
|
|
8001fe6: 687b ldr r3, [r7, #4]
|
|
8001fe8: 681b ldr r3, [r3, #0]
|
|
8001fea: 681a ldr r2, [r3, #0]
|
|
8001fec: 687b ldr r3, [r7, #4]
|
|
8001fee: 681b ldr r3, [r3, #0]
|
|
8001ff0: 210e movs r1, #14
|
|
8001ff2: 438a bics r2, r1
|
|
8001ff4: 601a str r2, [r3, #0]
|
|
|
|
/* Disable the channel */
|
|
__HAL_DMA_DISABLE(hdma);
|
|
8001ff6: 687b ldr r3, [r7, #4]
|
|
8001ff8: 681b ldr r3, [r3, #0]
|
|
8001ffa: 681a ldr r2, [r3, #0]
|
|
8001ffc: 687b ldr r3, [r7, #4]
|
|
8001ffe: 681b ldr r3, [r3, #0]
|
|
8002000: 2101 movs r1, #1
|
|
8002002: 438a bics r2, r1
|
|
8002004: 601a str r2, [r3, #0]
|
|
|
|
/* Clear all flags */
|
|
hdma->DmaBaseAddress->IFCR = (DMA_ISR_GIF1 << (hdma->ChannelIndex & 0x1cU));
|
|
8002006: 687b ldr r3, [r7, #4]
|
|
8002008: 6c5b ldr r3, [r3, #68] ; 0x44
|
|
800200a: 221c movs r2, #28
|
|
800200c: 401a ands r2, r3
|
|
800200e: 687b ldr r3, [r7, #4]
|
|
8002010: 6c1b ldr r3, [r3, #64] ; 0x40
|
|
8002012: 2101 movs r1, #1
|
|
8002014: 4091 lsls r1, r2
|
|
8002016: 000a movs r2, r1
|
|
8002018: 605a str r2, [r3, #4]
|
|
|
|
/* Change the DMA state */
|
|
hdma->State = HAL_DMA_STATE_READY;
|
|
800201a: 687b ldr r3, [r7, #4]
|
|
800201c: 2225 movs r2, #37 ; 0x25
|
|
800201e: 2101 movs r1, #1
|
|
8002020: 5499 strb r1, [r3, r2]
|
|
|
|
/* Process Unlocked */
|
|
__HAL_UNLOCK(hdma);
|
|
8002022: 687b ldr r3, [r7, #4]
|
|
8002024: 2224 movs r2, #36 ; 0x24
|
|
8002026: 2100 movs r1, #0
|
|
8002028: 5499 strb r1, [r3, r2]
|
|
|
|
return status;
|
|
800202a: 230f movs r3, #15
|
|
800202c: 18fb adds r3, r7, r3
|
|
800202e: 781b ldrb r3, [r3, #0]
|
|
}
|
|
}
|
|
8002030: 0018 movs r0, r3
|
|
8002032: 46bd mov sp, r7
|
|
8002034: b004 add sp, #16
|
|
8002036: bd80 pop {r7, pc}
|
|
|
|
08002038 <HAL_DMA_Abort_IT>:
|
|
* @param hdma pointer to a DMA_HandleTypeDef structure that contains
|
|
* the configuration information for the specified DMA Channel.
|
|
* @retval HAL status
|
|
*/
|
|
HAL_StatusTypeDef HAL_DMA_Abort_IT(DMA_HandleTypeDef *hdma)
|
|
{
|
|
8002038: b580 push {r7, lr}
|
|
800203a: b084 sub sp, #16
|
|
800203c: af00 add r7, sp, #0
|
|
800203e: 6078 str r0, [r7, #4]
|
|
HAL_StatusTypeDef status = HAL_OK;
|
|
8002040: 210f movs r1, #15
|
|
8002042: 187b adds r3, r7, r1
|
|
8002044: 2200 movs r2, #0
|
|
8002046: 701a strb r2, [r3, #0]
|
|
|
|
if(HAL_DMA_STATE_BUSY != hdma->State)
|
|
8002048: 687b ldr r3, [r7, #4]
|
|
800204a: 2225 movs r2, #37 ; 0x25
|
|
800204c: 5c9b ldrb r3, [r3, r2]
|
|
800204e: b2db uxtb r3, r3
|
|
8002050: 2b02 cmp r3, #2
|
|
8002052: d006 beq.n 8002062 <HAL_DMA_Abort_IT+0x2a>
|
|
{
|
|
/* no transfer ongoing */
|
|
hdma->ErrorCode = HAL_DMA_ERROR_NO_XFER;
|
|
8002054: 687b ldr r3, [r7, #4]
|
|
8002056: 2204 movs r2, #4
|
|
8002058: 63da str r2, [r3, #60] ; 0x3c
|
|
|
|
status = HAL_ERROR;
|
|
800205a: 187b adds r3, r7, r1
|
|
800205c: 2201 movs r2, #1
|
|
800205e: 701a strb r2, [r3, #0]
|
|
8002060: e02a b.n 80020b8 <HAL_DMA_Abort_IT+0x80>
|
|
}
|
|
else
|
|
{
|
|
/* Disable DMA IT */
|
|
__HAL_DMA_DISABLE_IT(hdma, (DMA_IT_TC | DMA_IT_HT | DMA_IT_TE));
|
|
8002062: 687b ldr r3, [r7, #4]
|
|
8002064: 681b ldr r3, [r3, #0]
|
|
8002066: 681a ldr r2, [r3, #0]
|
|
8002068: 687b ldr r3, [r7, #4]
|
|
800206a: 681b ldr r3, [r3, #0]
|
|
800206c: 210e movs r1, #14
|
|
800206e: 438a bics r2, r1
|
|
8002070: 601a str r2, [r3, #0]
|
|
|
|
/* Disable the channel */
|
|
__HAL_DMA_DISABLE(hdma);
|
|
8002072: 687b ldr r3, [r7, #4]
|
|
8002074: 681b ldr r3, [r3, #0]
|
|
8002076: 681a ldr r2, [r3, #0]
|
|
8002078: 687b ldr r3, [r7, #4]
|
|
800207a: 681b ldr r3, [r3, #0]
|
|
800207c: 2101 movs r1, #1
|
|
800207e: 438a bics r2, r1
|
|
8002080: 601a str r2, [r3, #0]
|
|
|
|
/* Clear all flags */
|
|
hdma->DmaBaseAddress->IFCR = (DMA_ISR_GIF1 << (hdma->ChannelIndex & 0x1cU));
|
|
8002082: 687b ldr r3, [r7, #4]
|
|
8002084: 6c5b ldr r3, [r3, #68] ; 0x44
|
|
8002086: 221c movs r2, #28
|
|
8002088: 401a ands r2, r3
|
|
800208a: 687b ldr r3, [r7, #4]
|
|
800208c: 6c1b ldr r3, [r3, #64] ; 0x40
|
|
800208e: 2101 movs r1, #1
|
|
8002090: 4091 lsls r1, r2
|
|
8002092: 000a movs r2, r1
|
|
8002094: 605a str r2, [r3, #4]
|
|
|
|
/* Change the DMA state */
|
|
hdma->State = HAL_DMA_STATE_READY;
|
|
8002096: 687b ldr r3, [r7, #4]
|
|
8002098: 2225 movs r2, #37 ; 0x25
|
|
800209a: 2101 movs r1, #1
|
|
800209c: 5499 strb r1, [r3, r2]
|
|
|
|
/* Process Unlocked */
|
|
__HAL_UNLOCK(hdma);
|
|
800209e: 687b ldr r3, [r7, #4]
|
|
80020a0: 2224 movs r2, #36 ; 0x24
|
|
80020a2: 2100 movs r1, #0
|
|
80020a4: 5499 strb r1, [r3, r2]
|
|
|
|
/* Call User Abort callback */
|
|
if(hdma->XferAbortCallback != NULL)
|
|
80020a6: 687b ldr r3, [r7, #4]
|
|
80020a8: 6b9b ldr r3, [r3, #56] ; 0x38
|
|
80020aa: 2b00 cmp r3, #0
|
|
80020ac: d004 beq.n 80020b8 <HAL_DMA_Abort_IT+0x80>
|
|
{
|
|
hdma->XferAbortCallback(hdma);
|
|
80020ae: 687b ldr r3, [r7, #4]
|
|
80020b0: 6b9b ldr r3, [r3, #56] ; 0x38
|
|
80020b2: 687a ldr r2, [r7, #4]
|
|
80020b4: 0010 movs r0, r2
|
|
80020b6: 4798 blx r3
|
|
}
|
|
}
|
|
return status;
|
|
80020b8: 230f movs r3, #15
|
|
80020ba: 18fb adds r3, r7, r3
|
|
80020bc: 781b ldrb r3, [r3, #0]
|
|
}
|
|
80020be: 0018 movs r0, r3
|
|
80020c0: 46bd mov sp, r7
|
|
80020c2: b004 add sp, #16
|
|
80020c4: bd80 pop {r7, pc}
|
|
|
|
080020c6 <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)
|
|
{
|
|
80020c6: b580 push {r7, lr}
|
|
80020c8: b084 sub sp, #16
|
|
80020ca: af00 add r7, sp, #0
|
|
80020cc: 6078 str r0, [r7, #4]
|
|
uint32_t flag_it = hdma->DmaBaseAddress->ISR;
|
|
80020ce: 687b ldr r3, [r7, #4]
|
|
80020d0: 6c1b ldr r3, [r3, #64] ; 0x40
|
|
80020d2: 681b ldr r3, [r3, #0]
|
|
80020d4: 60fb str r3, [r7, #12]
|
|
uint32_t source_it = hdma->Instance->CCR;
|
|
80020d6: 687b ldr r3, [r7, #4]
|
|
80020d8: 681b ldr r3, [r3, #0]
|
|
80020da: 681b ldr r3, [r3, #0]
|
|
80020dc: 60bb str r3, [r7, #8]
|
|
|
|
/* Half Transfer Complete Interrupt management ******************************/
|
|
if ((0U != (flag_it & (DMA_FLAG_HT1 << (hdma->ChannelIndex & 0x1cU)))) && (0U != (source_it & DMA_IT_HT)))
|
|
80020de: 687b ldr r3, [r7, #4]
|
|
80020e0: 6c5b ldr r3, [r3, #68] ; 0x44
|
|
80020e2: 221c movs r2, #28
|
|
80020e4: 4013 ands r3, r2
|
|
80020e6: 2204 movs r2, #4
|
|
80020e8: 409a lsls r2, r3
|
|
80020ea: 0013 movs r3, r2
|
|
80020ec: 68fa ldr r2, [r7, #12]
|
|
80020ee: 4013 ands r3, r2
|
|
80020f0: d026 beq.n 8002140 <HAL_DMA_IRQHandler+0x7a>
|
|
80020f2: 68bb ldr r3, [r7, #8]
|
|
80020f4: 2204 movs r2, #4
|
|
80020f6: 4013 ands r3, r2
|
|
80020f8: d022 beq.n 8002140 <HAL_DMA_IRQHandler+0x7a>
|
|
{
|
|
/* Disable the half transfer interrupt if the DMA mode is not CIRCULAR */
|
|
if((hdma->Instance->CCR & DMA_CCR_CIRC) == 0U)
|
|
80020fa: 687b ldr r3, [r7, #4]
|
|
80020fc: 681b ldr r3, [r3, #0]
|
|
80020fe: 681b ldr r3, [r3, #0]
|
|
8002100: 2220 movs r2, #32
|
|
8002102: 4013 ands r3, r2
|
|
8002104: d107 bne.n 8002116 <HAL_DMA_IRQHandler+0x50>
|
|
{
|
|
/* Disable the half transfer interrupt */
|
|
__HAL_DMA_DISABLE_IT(hdma, DMA_IT_HT);
|
|
8002106: 687b ldr r3, [r7, #4]
|
|
8002108: 681b ldr r3, [r3, #0]
|
|
800210a: 681a ldr r2, [r3, #0]
|
|
800210c: 687b ldr r3, [r7, #4]
|
|
800210e: 681b ldr r3, [r3, #0]
|
|
8002110: 2104 movs r1, #4
|
|
8002112: 438a bics r2, r1
|
|
8002114: 601a str r2, [r3, #0]
|
|
}
|
|
/* Clear the half transfer complete flag */
|
|
hdma->DmaBaseAddress->IFCR = DMA_ISR_HTIF1 << (hdma->ChannelIndex & 0x1cU);
|
|
8002116: 687b ldr r3, [r7, #4]
|
|
8002118: 6c5b ldr r3, [r3, #68] ; 0x44
|
|
800211a: 221c movs r2, #28
|
|
800211c: 401a ands r2, r3
|
|
800211e: 687b ldr r3, [r7, #4]
|
|
8002120: 6c1b ldr r3, [r3, #64] ; 0x40
|
|
8002122: 2104 movs r1, #4
|
|
8002124: 4091 lsls r1, r2
|
|
8002126: 000a movs r2, r1
|
|
8002128: 605a str r2, [r3, #4]
|
|
|
|
/* DMA peripheral state is not updated in Half Transfer */
|
|
/* but in Transfer Complete case */
|
|
|
|
if(hdma->XferHalfCpltCallback != NULL)
|
|
800212a: 687b ldr r3, [r7, #4]
|
|
800212c: 6b1b ldr r3, [r3, #48] ; 0x30
|
|
800212e: 2b00 cmp r3, #0
|
|
8002130: d100 bne.n 8002134 <HAL_DMA_IRQHandler+0x6e>
|
|
8002132: e071 b.n 8002218 <HAL_DMA_IRQHandler+0x152>
|
|
{
|
|
/* Half transfer callback */
|
|
hdma->XferHalfCpltCallback(hdma);
|
|
8002134: 687b ldr r3, [r7, #4]
|
|
8002136: 6b1b ldr r3, [r3, #48] ; 0x30
|
|
8002138: 687a ldr r2, [r7, #4]
|
|
800213a: 0010 movs r0, r2
|
|
800213c: 4798 blx r3
|
|
if(hdma->XferHalfCpltCallback != NULL)
|
|
800213e: e06b b.n 8002218 <HAL_DMA_IRQHandler+0x152>
|
|
}
|
|
}
|
|
|
|
/* Transfer Complete Interrupt management ***********************************/
|
|
else if ((0U != (flag_it & (DMA_FLAG_TC1 << (hdma->ChannelIndex & 0x1cU)))) && (0U != (source_it & DMA_IT_TC)))
|
|
8002140: 687b ldr r3, [r7, #4]
|
|
8002142: 6c5b ldr r3, [r3, #68] ; 0x44
|
|
8002144: 221c movs r2, #28
|
|
8002146: 4013 ands r3, r2
|
|
8002148: 2202 movs r2, #2
|
|
800214a: 409a lsls r2, r3
|
|
800214c: 0013 movs r3, r2
|
|
800214e: 68fa ldr r2, [r7, #12]
|
|
8002150: 4013 ands r3, r2
|
|
8002152: d02d beq.n 80021b0 <HAL_DMA_IRQHandler+0xea>
|
|
8002154: 68bb ldr r3, [r7, #8]
|
|
8002156: 2202 movs r2, #2
|
|
8002158: 4013 ands r3, r2
|
|
800215a: d029 beq.n 80021b0 <HAL_DMA_IRQHandler+0xea>
|
|
{
|
|
if((hdma->Instance->CCR & DMA_CCR_CIRC) == 0U)
|
|
800215c: 687b ldr r3, [r7, #4]
|
|
800215e: 681b ldr r3, [r3, #0]
|
|
8002160: 681b ldr r3, [r3, #0]
|
|
8002162: 2220 movs r2, #32
|
|
8002164: 4013 ands r3, r2
|
|
8002166: d10b bne.n 8002180 <HAL_DMA_IRQHandler+0xba>
|
|
{
|
|
/* Disable the transfer complete and error interrupt */
|
|
__HAL_DMA_DISABLE_IT(hdma, DMA_IT_TE | DMA_IT_TC);
|
|
8002168: 687b ldr r3, [r7, #4]
|
|
800216a: 681b ldr r3, [r3, #0]
|
|
800216c: 681a ldr r2, [r3, #0]
|
|
800216e: 687b ldr r3, [r7, #4]
|
|
8002170: 681b ldr r3, [r3, #0]
|
|
8002172: 210a movs r1, #10
|
|
8002174: 438a bics r2, r1
|
|
8002176: 601a str r2, [r3, #0]
|
|
|
|
/* Change the DMA state */
|
|
hdma->State = HAL_DMA_STATE_READY;
|
|
8002178: 687b ldr r3, [r7, #4]
|
|
800217a: 2225 movs r2, #37 ; 0x25
|
|
800217c: 2101 movs r1, #1
|
|
800217e: 5499 strb r1, [r3, r2]
|
|
}
|
|
/* Clear the transfer complete flag */
|
|
hdma->DmaBaseAddress->IFCR = (DMA_ISR_TCIF1 << (hdma->ChannelIndex & 0x1cU));
|
|
8002180: 687b ldr r3, [r7, #4]
|
|
8002182: 6c5b ldr r3, [r3, #68] ; 0x44
|
|
8002184: 221c movs r2, #28
|
|
8002186: 401a ands r2, r3
|
|
8002188: 687b ldr r3, [r7, #4]
|
|
800218a: 6c1b ldr r3, [r3, #64] ; 0x40
|
|
800218c: 2102 movs r1, #2
|
|
800218e: 4091 lsls r1, r2
|
|
8002190: 000a movs r2, r1
|
|
8002192: 605a str r2, [r3, #4]
|
|
|
|
/* Process Unlocked */
|
|
__HAL_UNLOCK(hdma);
|
|
8002194: 687b ldr r3, [r7, #4]
|
|
8002196: 2224 movs r2, #36 ; 0x24
|
|
8002198: 2100 movs r1, #0
|
|
800219a: 5499 strb r1, [r3, r2]
|
|
|
|
if(hdma->XferCpltCallback != NULL)
|
|
800219c: 687b ldr r3, [r7, #4]
|
|
800219e: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
80021a0: 2b00 cmp r3, #0
|
|
80021a2: d039 beq.n 8002218 <HAL_DMA_IRQHandler+0x152>
|
|
{
|
|
/* Transfer complete callback */
|
|
hdma->XferCpltCallback(hdma);
|
|
80021a4: 687b ldr r3, [r7, #4]
|
|
80021a6: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
80021a8: 687a ldr r2, [r7, #4]
|
|
80021aa: 0010 movs r0, r2
|
|
80021ac: 4798 blx r3
|
|
if(hdma->XferCpltCallback != NULL)
|
|
80021ae: e033 b.n 8002218 <HAL_DMA_IRQHandler+0x152>
|
|
}
|
|
}
|
|
|
|
/* Transfer Error Interrupt management **************************************/
|
|
else if ((0U != (flag_it & (DMA_FLAG_TE1 << (hdma->ChannelIndex & 0x1cU)))) && (0U != (source_it & DMA_IT_TE)))
|
|
80021b0: 687b ldr r3, [r7, #4]
|
|
80021b2: 6c5b ldr r3, [r3, #68] ; 0x44
|
|
80021b4: 221c movs r2, #28
|
|
80021b6: 4013 ands r3, r2
|
|
80021b8: 2208 movs r2, #8
|
|
80021ba: 409a lsls r2, r3
|
|
80021bc: 0013 movs r3, r2
|
|
80021be: 68fa ldr r2, [r7, #12]
|
|
80021c0: 4013 ands r3, r2
|
|
80021c2: d02a beq.n 800221a <HAL_DMA_IRQHandler+0x154>
|
|
80021c4: 68bb ldr r3, [r7, #8]
|
|
80021c6: 2208 movs r2, #8
|
|
80021c8: 4013 ands r3, r2
|
|
80021ca: d026 beq.n 800221a <HAL_DMA_IRQHandler+0x154>
|
|
{
|
|
/* When a DMA transfer error occurs */
|
|
/* A hardware clear of its EN bits is performed */
|
|
/* Disable ALL DMA IT */
|
|
__HAL_DMA_DISABLE_IT(hdma, (DMA_IT_TC | DMA_IT_HT | DMA_IT_TE));
|
|
80021cc: 687b ldr r3, [r7, #4]
|
|
80021ce: 681b ldr r3, [r3, #0]
|
|
80021d0: 681a ldr r2, [r3, #0]
|
|
80021d2: 687b ldr r3, [r7, #4]
|
|
80021d4: 681b ldr r3, [r3, #0]
|
|
80021d6: 210e movs r1, #14
|
|
80021d8: 438a bics r2, r1
|
|
80021da: 601a str r2, [r3, #0]
|
|
|
|
/* Clear all flags */
|
|
hdma->DmaBaseAddress->IFCR = (DMA_ISR_GIF1 << (hdma->ChannelIndex & 0x1cU));
|
|
80021dc: 687b ldr r3, [r7, #4]
|
|
80021de: 6c5b ldr r3, [r3, #68] ; 0x44
|
|
80021e0: 221c movs r2, #28
|
|
80021e2: 401a ands r2, r3
|
|
80021e4: 687b ldr r3, [r7, #4]
|
|
80021e6: 6c1b ldr r3, [r3, #64] ; 0x40
|
|
80021e8: 2101 movs r1, #1
|
|
80021ea: 4091 lsls r1, r2
|
|
80021ec: 000a movs r2, r1
|
|
80021ee: 605a str r2, [r3, #4]
|
|
|
|
/* Update error code */
|
|
hdma->ErrorCode = HAL_DMA_ERROR_TE;
|
|
80021f0: 687b ldr r3, [r7, #4]
|
|
80021f2: 2201 movs r2, #1
|
|
80021f4: 63da str r2, [r3, #60] ; 0x3c
|
|
|
|
/* Change the DMA state */
|
|
hdma->State = HAL_DMA_STATE_READY;
|
|
80021f6: 687b ldr r3, [r7, #4]
|
|
80021f8: 2225 movs r2, #37 ; 0x25
|
|
80021fa: 2101 movs r1, #1
|
|
80021fc: 5499 strb r1, [r3, r2]
|
|
|
|
/* Process Unlocked */
|
|
__HAL_UNLOCK(hdma);
|
|
80021fe: 687b ldr r3, [r7, #4]
|
|
8002200: 2224 movs r2, #36 ; 0x24
|
|
8002202: 2100 movs r1, #0
|
|
8002204: 5499 strb r1, [r3, r2]
|
|
|
|
if (hdma->XferErrorCallback != NULL)
|
|
8002206: 687b ldr r3, [r7, #4]
|
|
8002208: 6b5b ldr r3, [r3, #52] ; 0x34
|
|
800220a: 2b00 cmp r3, #0
|
|
800220c: d005 beq.n 800221a <HAL_DMA_IRQHandler+0x154>
|
|
{
|
|
/* Transfer error callback */
|
|
hdma->XferErrorCallback(hdma);
|
|
800220e: 687b ldr r3, [r7, #4]
|
|
8002210: 6b5b ldr r3, [r3, #52] ; 0x34
|
|
8002212: 687a ldr r2, [r7, #4]
|
|
8002214: 0010 movs r0, r2
|
|
8002216: 4798 blx r3
|
|
}
|
|
else
|
|
{
|
|
/* Nothing To Do */
|
|
}
|
|
return;
|
|
8002218: 46c0 nop ; (mov r8, r8)
|
|
800221a: 46c0 nop ; (mov r8, r8)
|
|
}
|
|
800221c: 46bd mov sp, r7
|
|
800221e: b004 add sp, #16
|
|
8002220: bd80 pop {r7, pc}
|
|
...
|
|
|
|
08002224 <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)
|
|
{
|
|
8002224: b580 push {r7, lr}
|
|
8002226: b086 sub sp, #24
|
|
8002228: af00 add r7, sp, #0
|
|
800222a: 6078 str r0, [r7, #4]
|
|
800222c: 6039 str r1, [r7, #0]
|
|
uint32_t position = 0x00U;
|
|
800222e: 2300 movs r3, #0
|
|
8002230: 617b str r3, [r7, #20]
|
|
uint32_t iocurrent = 0x00U;
|
|
8002232: 2300 movs r3, #0
|
|
8002234: 60fb str r3, [r7, #12]
|
|
uint32_t temp = 0x00U;
|
|
8002236: 2300 movs r3, #0
|
|
8002238: 613b str r3, [r7, #16]
|
|
/* Check the parameters */
|
|
assert_param(IS_GPIO_MODE(GPIO_Init->Mode));
|
|
assert_param(IS_GPIO_PIN_AVAILABLE(GPIOx, (GPIO_Init->Pin)));
|
|
|
|
/* Configure the port pins */
|
|
while (((GPIO_Init->Pin) >> position) != 0)
|
|
800223a: e149 b.n 80024d0 <HAL_GPIO_Init+0x2ac>
|
|
{
|
|
/* Get the IO position */
|
|
iocurrent = (GPIO_Init->Pin) & (1U << position);
|
|
800223c: 683b ldr r3, [r7, #0]
|
|
800223e: 681b ldr r3, [r3, #0]
|
|
8002240: 2101 movs r1, #1
|
|
8002242: 697a ldr r2, [r7, #20]
|
|
8002244: 4091 lsls r1, r2
|
|
8002246: 000a movs r2, r1
|
|
8002248: 4013 ands r3, r2
|
|
800224a: 60fb str r3, [r7, #12]
|
|
|
|
if (iocurrent)
|
|
800224c: 68fb ldr r3, [r7, #12]
|
|
800224e: 2b00 cmp r3, #0
|
|
8002250: d100 bne.n 8002254 <HAL_GPIO_Init+0x30>
|
|
8002252: e13a b.n 80024ca <HAL_GPIO_Init+0x2a6>
|
|
{
|
|
/*--------------------- GPIO Mode Configuration ------------------------*/
|
|
/* In case of Output or Alternate function mode selection */
|
|
if (((GPIO_Init->Mode & GPIO_MODE) == MODE_OUTPUT) ||
|
|
8002254: 683b ldr r3, [r7, #0]
|
|
8002256: 685b ldr r3, [r3, #4]
|
|
8002258: 2203 movs r2, #3
|
|
800225a: 4013 ands r3, r2
|
|
800225c: 2b01 cmp r3, #1
|
|
800225e: d005 beq.n 800226c <HAL_GPIO_Init+0x48>
|
|
((GPIO_Init->Mode & GPIO_MODE) == MODE_AF))
|
|
8002260: 683b ldr r3, [r7, #0]
|
|
8002262: 685b ldr r3, [r3, #4]
|
|
8002264: 2203 movs r2, #3
|
|
8002266: 4013 ands r3, r2
|
|
if (((GPIO_Init->Mode & GPIO_MODE) == MODE_OUTPUT) ||
|
|
8002268: 2b02 cmp r3, #2
|
|
800226a: d130 bne.n 80022ce <HAL_GPIO_Init+0xaa>
|
|
{
|
|
/* Check the Speed parameter */
|
|
assert_param(IS_GPIO_SPEED(GPIO_Init->Speed));
|
|
/* Configure the IO Speed */
|
|
temp = GPIOx->OSPEEDR;
|
|
800226c: 687b ldr r3, [r7, #4]
|
|
800226e: 689b ldr r3, [r3, #8]
|
|
8002270: 613b str r3, [r7, #16]
|
|
temp &= ~(GPIO_OSPEEDER_OSPEED0 << (position * 2U));
|
|
8002272: 697b ldr r3, [r7, #20]
|
|
8002274: 005b lsls r3, r3, #1
|
|
8002276: 2203 movs r2, #3
|
|
8002278: 409a lsls r2, r3
|
|
800227a: 0013 movs r3, r2
|
|
800227c: 43da mvns r2, r3
|
|
800227e: 693b ldr r3, [r7, #16]
|
|
8002280: 4013 ands r3, r2
|
|
8002282: 613b str r3, [r7, #16]
|
|
temp |= (GPIO_Init->Speed << (position * 2U));
|
|
8002284: 683b ldr r3, [r7, #0]
|
|
8002286: 68da ldr r2, [r3, #12]
|
|
8002288: 697b ldr r3, [r7, #20]
|
|
800228a: 005b lsls r3, r3, #1
|
|
800228c: 409a lsls r2, r3
|
|
800228e: 0013 movs r3, r2
|
|
8002290: 693a ldr r2, [r7, #16]
|
|
8002292: 4313 orrs r3, r2
|
|
8002294: 613b str r3, [r7, #16]
|
|
GPIOx->OSPEEDR = temp;
|
|
8002296: 687b ldr r3, [r7, #4]
|
|
8002298: 693a ldr r2, [r7, #16]
|
|
800229a: 609a str r2, [r3, #8]
|
|
|
|
/* Configure the IO Output Type */
|
|
temp = GPIOx->OTYPER;
|
|
800229c: 687b ldr r3, [r7, #4]
|
|
800229e: 685b ldr r3, [r3, #4]
|
|
80022a0: 613b str r3, [r7, #16]
|
|
temp &= ~(GPIO_OTYPER_OT_0 << position) ;
|
|
80022a2: 2201 movs r2, #1
|
|
80022a4: 697b ldr r3, [r7, #20]
|
|
80022a6: 409a lsls r2, r3
|
|
80022a8: 0013 movs r3, r2
|
|
80022aa: 43da mvns r2, r3
|
|
80022ac: 693b ldr r3, [r7, #16]
|
|
80022ae: 4013 ands r3, r2
|
|
80022b0: 613b str r3, [r7, #16]
|
|
temp |= (((GPIO_Init->Mode & OUTPUT_TYPE) >> OUTPUT_TYPE_Pos) << position);
|
|
80022b2: 683b ldr r3, [r7, #0]
|
|
80022b4: 685b ldr r3, [r3, #4]
|
|
80022b6: 091b lsrs r3, r3, #4
|
|
80022b8: 2201 movs r2, #1
|
|
80022ba: 401a ands r2, r3
|
|
80022bc: 697b ldr r3, [r7, #20]
|
|
80022be: 409a lsls r2, r3
|
|
80022c0: 0013 movs r3, r2
|
|
80022c2: 693a ldr r2, [r7, #16]
|
|
80022c4: 4313 orrs r3, r2
|
|
80022c6: 613b str r3, [r7, #16]
|
|
GPIOx->OTYPER = temp;
|
|
80022c8: 687b ldr r3, [r7, #4]
|
|
80022ca: 693a ldr r2, [r7, #16]
|
|
80022cc: 605a str r2, [r3, #4]
|
|
}
|
|
|
|
if ((GPIO_Init->Mode & GPIO_MODE) != MODE_ANALOG)
|
|
80022ce: 683b ldr r3, [r7, #0]
|
|
80022d0: 685b ldr r3, [r3, #4]
|
|
80022d2: 2203 movs r2, #3
|
|
80022d4: 4013 ands r3, r2
|
|
80022d6: 2b03 cmp r3, #3
|
|
80022d8: d017 beq.n 800230a <HAL_GPIO_Init+0xe6>
|
|
{
|
|
/* 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;
|
|
80022da: 687b ldr r3, [r7, #4]
|
|
80022dc: 68db ldr r3, [r3, #12]
|
|
80022de: 613b str r3, [r7, #16]
|
|
temp &= ~(GPIO_PUPDR_PUPD0 << (position * 2U));
|
|
80022e0: 697b ldr r3, [r7, #20]
|
|
80022e2: 005b lsls r3, r3, #1
|
|
80022e4: 2203 movs r2, #3
|
|
80022e6: 409a lsls r2, r3
|
|
80022e8: 0013 movs r3, r2
|
|
80022ea: 43da mvns r2, r3
|
|
80022ec: 693b ldr r3, [r7, #16]
|
|
80022ee: 4013 ands r3, r2
|
|
80022f0: 613b str r3, [r7, #16]
|
|
temp |= ((GPIO_Init->Pull) << (position * 2U));
|
|
80022f2: 683b ldr r3, [r7, #0]
|
|
80022f4: 689a ldr r2, [r3, #8]
|
|
80022f6: 697b ldr r3, [r7, #20]
|
|
80022f8: 005b lsls r3, r3, #1
|
|
80022fa: 409a lsls r2, r3
|
|
80022fc: 0013 movs r3, r2
|
|
80022fe: 693a ldr r2, [r7, #16]
|
|
8002300: 4313 orrs r3, r2
|
|
8002302: 613b str r3, [r7, #16]
|
|
GPIOx->PUPDR = temp;
|
|
8002304: 687b ldr r3, [r7, #4]
|
|
8002306: 693a ldr r2, [r7, #16]
|
|
8002308: 60da str r2, [r3, #12]
|
|
}
|
|
|
|
/* In case of Alternate function mode selection */
|
|
if ((GPIO_Init->Mode & GPIO_MODE) == MODE_AF)
|
|
800230a: 683b ldr r3, [r7, #0]
|
|
800230c: 685b ldr r3, [r3, #4]
|
|
800230e: 2203 movs r2, #3
|
|
8002310: 4013 ands r3, r2
|
|
8002312: 2b02 cmp r3, #2
|
|
8002314: d123 bne.n 800235e <HAL_GPIO_Init+0x13a>
|
|
/* 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];
|
|
8002316: 697b ldr r3, [r7, #20]
|
|
8002318: 08da lsrs r2, r3, #3
|
|
800231a: 687b ldr r3, [r7, #4]
|
|
800231c: 3208 adds r2, #8
|
|
800231e: 0092 lsls r2, r2, #2
|
|
8002320: 58d3 ldr r3, [r2, r3]
|
|
8002322: 613b str r3, [r7, #16]
|
|
temp &= ~(0xFUL << ((uint32_t)(position & 0x07UL) * 4U));
|
|
8002324: 697b ldr r3, [r7, #20]
|
|
8002326: 2207 movs r2, #7
|
|
8002328: 4013 ands r3, r2
|
|
800232a: 009b lsls r3, r3, #2
|
|
800232c: 220f movs r2, #15
|
|
800232e: 409a lsls r2, r3
|
|
8002330: 0013 movs r3, r2
|
|
8002332: 43da mvns r2, r3
|
|
8002334: 693b ldr r3, [r7, #16]
|
|
8002336: 4013 ands r3, r2
|
|
8002338: 613b str r3, [r7, #16]
|
|
temp |= ((uint32_t)(GPIO_Init->Alternate) << (((uint32_t)position & (uint32_t)0x07U) * 4U));
|
|
800233a: 683b ldr r3, [r7, #0]
|
|
800233c: 691a ldr r2, [r3, #16]
|
|
800233e: 697b ldr r3, [r7, #20]
|
|
8002340: 2107 movs r1, #7
|
|
8002342: 400b ands r3, r1
|
|
8002344: 009b lsls r3, r3, #2
|
|
8002346: 409a lsls r2, r3
|
|
8002348: 0013 movs r3, r2
|
|
800234a: 693a ldr r2, [r7, #16]
|
|
800234c: 4313 orrs r3, r2
|
|
800234e: 613b str r3, [r7, #16]
|
|
GPIOx->AFR[position >> 3U] = temp;
|
|
8002350: 697b ldr r3, [r7, #20]
|
|
8002352: 08da lsrs r2, r3, #3
|
|
8002354: 687b ldr r3, [r7, #4]
|
|
8002356: 3208 adds r2, #8
|
|
8002358: 0092 lsls r2, r2, #2
|
|
800235a: 6939 ldr r1, [r7, #16]
|
|
800235c: 50d1 str r1, [r2, r3]
|
|
}
|
|
|
|
/* Configure IO Direction mode (Input, Output, Alternate or Analog) */
|
|
temp = GPIOx->MODER;
|
|
800235e: 687b ldr r3, [r7, #4]
|
|
8002360: 681b ldr r3, [r3, #0]
|
|
8002362: 613b str r3, [r7, #16]
|
|
temp &= ~(GPIO_MODER_MODE0 << (position * 2U));
|
|
8002364: 697b ldr r3, [r7, #20]
|
|
8002366: 005b lsls r3, r3, #1
|
|
8002368: 2203 movs r2, #3
|
|
800236a: 409a lsls r2, r3
|
|
800236c: 0013 movs r3, r2
|
|
800236e: 43da mvns r2, r3
|
|
8002370: 693b ldr r3, [r7, #16]
|
|
8002372: 4013 ands r3, r2
|
|
8002374: 613b str r3, [r7, #16]
|
|
temp |= ((GPIO_Init->Mode & GPIO_MODE) << (position * 2U));
|
|
8002376: 683b ldr r3, [r7, #0]
|
|
8002378: 685b ldr r3, [r3, #4]
|
|
800237a: 2203 movs r2, #3
|
|
800237c: 401a ands r2, r3
|
|
800237e: 697b ldr r3, [r7, #20]
|
|
8002380: 005b lsls r3, r3, #1
|
|
8002382: 409a lsls r2, r3
|
|
8002384: 0013 movs r3, r2
|
|
8002386: 693a ldr r2, [r7, #16]
|
|
8002388: 4313 orrs r3, r2
|
|
800238a: 613b str r3, [r7, #16]
|
|
GPIOx->MODER = temp;
|
|
800238c: 687b ldr r3, [r7, #4]
|
|
800238e: 693a ldr r2, [r7, #16]
|
|
8002390: 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)
|
|
8002392: 683b ldr r3, [r7, #0]
|
|
8002394: 685a ldr r2, [r3, #4]
|
|
8002396: 23c0 movs r3, #192 ; 0xc0
|
|
8002398: 029b lsls r3, r3, #10
|
|
800239a: 4013 ands r3, r2
|
|
800239c: d100 bne.n 80023a0 <HAL_GPIO_Init+0x17c>
|
|
800239e: e094 b.n 80024ca <HAL_GPIO_Init+0x2a6>
|
|
{
|
|
/* Enable SYSCFG Clock */
|
|
__HAL_RCC_SYSCFG_CLK_ENABLE();
|
|
80023a0: 4b51 ldr r3, [pc, #324] ; (80024e8 <HAL_GPIO_Init+0x2c4>)
|
|
80023a2: 6b5a ldr r2, [r3, #52] ; 0x34
|
|
80023a4: 4b50 ldr r3, [pc, #320] ; (80024e8 <HAL_GPIO_Init+0x2c4>)
|
|
80023a6: 2101 movs r1, #1
|
|
80023a8: 430a orrs r2, r1
|
|
80023aa: 635a str r2, [r3, #52] ; 0x34
|
|
|
|
temp = SYSCFG->EXTICR[position >> 2U];
|
|
80023ac: 4a4f ldr r2, [pc, #316] ; (80024ec <HAL_GPIO_Init+0x2c8>)
|
|
80023ae: 697b ldr r3, [r7, #20]
|
|
80023b0: 089b lsrs r3, r3, #2
|
|
80023b2: 3302 adds r3, #2
|
|
80023b4: 009b lsls r3, r3, #2
|
|
80023b6: 589b ldr r3, [r3, r2]
|
|
80023b8: 613b str r3, [r7, #16]
|
|
CLEAR_BIT(temp, (0x0FUL) << (4U * (position & 0x03U)));
|
|
80023ba: 697b ldr r3, [r7, #20]
|
|
80023bc: 2203 movs r2, #3
|
|
80023be: 4013 ands r3, r2
|
|
80023c0: 009b lsls r3, r3, #2
|
|
80023c2: 220f movs r2, #15
|
|
80023c4: 409a lsls r2, r3
|
|
80023c6: 0013 movs r3, r2
|
|
80023c8: 43da mvns r2, r3
|
|
80023ca: 693b ldr r3, [r7, #16]
|
|
80023cc: 4013 ands r3, r2
|
|
80023ce: 613b str r3, [r7, #16]
|
|
SET_BIT(temp, (GPIO_GET_INDEX(GPIOx)) << (4 * (position & 0x03U)));
|
|
80023d0: 687a ldr r2, [r7, #4]
|
|
80023d2: 23a0 movs r3, #160 ; 0xa0
|
|
80023d4: 05db lsls r3, r3, #23
|
|
80023d6: 429a cmp r2, r3
|
|
80023d8: d013 beq.n 8002402 <HAL_GPIO_Init+0x1de>
|
|
80023da: 687b ldr r3, [r7, #4]
|
|
80023dc: 4a44 ldr r2, [pc, #272] ; (80024f0 <HAL_GPIO_Init+0x2cc>)
|
|
80023de: 4293 cmp r3, r2
|
|
80023e0: d00d beq.n 80023fe <HAL_GPIO_Init+0x1da>
|
|
80023e2: 687b ldr r3, [r7, #4]
|
|
80023e4: 4a43 ldr r2, [pc, #268] ; (80024f4 <HAL_GPIO_Init+0x2d0>)
|
|
80023e6: 4293 cmp r3, r2
|
|
80023e8: d007 beq.n 80023fa <HAL_GPIO_Init+0x1d6>
|
|
80023ea: 687b ldr r3, [r7, #4]
|
|
80023ec: 4a42 ldr r2, [pc, #264] ; (80024f8 <HAL_GPIO_Init+0x2d4>)
|
|
80023ee: 4293 cmp r3, r2
|
|
80023f0: d101 bne.n 80023f6 <HAL_GPIO_Init+0x1d2>
|
|
80023f2: 2305 movs r3, #5
|
|
80023f4: e006 b.n 8002404 <HAL_GPIO_Init+0x1e0>
|
|
80023f6: 2306 movs r3, #6
|
|
80023f8: e004 b.n 8002404 <HAL_GPIO_Init+0x1e0>
|
|
80023fa: 2302 movs r3, #2
|
|
80023fc: e002 b.n 8002404 <HAL_GPIO_Init+0x1e0>
|
|
80023fe: 2301 movs r3, #1
|
|
8002400: e000 b.n 8002404 <HAL_GPIO_Init+0x1e0>
|
|
8002402: 2300 movs r3, #0
|
|
8002404: 697a ldr r2, [r7, #20]
|
|
8002406: 2103 movs r1, #3
|
|
8002408: 400a ands r2, r1
|
|
800240a: 0092 lsls r2, r2, #2
|
|
800240c: 4093 lsls r3, r2
|
|
800240e: 693a ldr r2, [r7, #16]
|
|
8002410: 4313 orrs r3, r2
|
|
8002412: 613b str r3, [r7, #16]
|
|
SYSCFG->EXTICR[position >> 2U] = temp;
|
|
8002414: 4935 ldr r1, [pc, #212] ; (80024ec <HAL_GPIO_Init+0x2c8>)
|
|
8002416: 697b ldr r3, [r7, #20]
|
|
8002418: 089b lsrs r3, r3, #2
|
|
800241a: 3302 adds r3, #2
|
|
800241c: 009b lsls r3, r3, #2
|
|
800241e: 693a ldr r2, [r7, #16]
|
|
8002420: 505a str r2, [r3, r1]
|
|
|
|
/* Clear EXTI line configuration */
|
|
temp = EXTI->IMR;
|
|
8002422: 4b36 ldr r3, [pc, #216] ; (80024fc <HAL_GPIO_Init+0x2d8>)
|
|
8002424: 681b ldr r3, [r3, #0]
|
|
8002426: 613b str r3, [r7, #16]
|
|
temp &= ~((uint32_t)iocurrent);
|
|
8002428: 68fb ldr r3, [r7, #12]
|
|
800242a: 43da mvns r2, r3
|
|
800242c: 693b ldr r3, [r7, #16]
|
|
800242e: 4013 ands r3, r2
|
|
8002430: 613b str r3, [r7, #16]
|
|
if ((GPIO_Init->Mode & EXTI_IT) != 0x00U)
|
|
8002432: 683b ldr r3, [r7, #0]
|
|
8002434: 685a ldr r2, [r3, #4]
|
|
8002436: 2380 movs r3, #128 ; 0x80
|
|
8002438: 025b lsls r3, r3, #9
|
|
800243a: 4013 ands r3, r2
|
|
800243c: d003 beq.n 8002446 <HAL_GPIO_Init+0x222>
|
|
{
|
|
temp |= iocurrent;
|
|
800243e: 693a ldr r2, [r7, #16]
|
|
8002440: 68fb ldr r3, [r7, #12]
|
|
8002442: 4313 orrs r3, r2
|
|
8002444: 613b str r3, [r7, #16]
|
|
}
|
|
EXTI->IMR = temp;
|
|
8002446: 4b2d ldr r3, [pc, #180] ; (80024fc <HAL_GPIO_Init+0x2d8>)
|
|
8002448: 693a ldr r2, [r7, #16]
|
|
800244a: 601a str r2, [r3, #0]
|
|
|
|
temp = EXTI->EMR;
|
|
800244c: 4b2b ldr r3, [pc, #172] ; (80024fc <HAL_GPIO_Init+0x2d8>)
|
|
800244e: 685b ldr r3, [r3, #4]
|
|
8002450: 613b str r3, [r7, #16]
|
|
temp &= ~((uint32_t)iocurrent);
|
|
8002452: 68fb ldr r3, [r7, #12]
|
|
8002454: 43da mvns r2, r3
|
|
8002456: 693b ldr r3, [r7, #16]
|
|
8002458: 4013 ands r3, r2
|
|
800245a: 613b str r3, [r7, #16]
|
|
if ((GPIO_Init->Mode & EXTI_EVT) != 0x00U)
|
|
800245c: 683b ldr r3, [r7, #0]
|
|
800245e: 685a ldr r2, [r3, #4]
|
|
8002460: 2380 movs r3, #128 ; 0x80
|
|
8002462: 029b lsls r3, r3, #10
|
|
8002464: 4013 ands r3, r2
|
|
8002466: d003 beq.n 8002470 <HAL_GPIO_Init+0x24c>
|
|
{
|
|
temp |= iocurrent;
|
|
8002468: 693a ldr r2, [r7, #16]
|
|
800246a: 68fb ldr r3, [r7, #12]
|
|
800246c: 4313 orrs r3, r2
|
|
800246e: 613b str r3, [r7, #16]
|
|
}
|
|
EXTI->EMR = temp;
|
|
8002470: 4b22 ldr r3, [pc, #136] ; (80024fc <HAL_GPIO_Init+0x2d8>)
|
|
8002472: 693a ldr r2, [r7, #16]
|
|
8002474: 605a str r2, [r3, #4]
|
|
|
|
/* Clear Rising Falling edge configuration */
|
|
temp = EXTI->RTSR;
|
|
8002476: 4b21 ldr r3, [pc, #132] ; (80024fc <HAL_GPIO_Init+0x2d8>)
|
|
8002478: 689b ldr r3, [r3, #8]
|
|
800247a: 613b str r3, [r7, #16]
|
|
temp &= ~((uint32_t)iocurrent);
|
|
800247c: 68fb ldr r3, [r7, #12]
|
|
800247e: 43da mvns r2, r3
|
|
8002480: 693b ldr r3, [r7, #16]
|
|
8002482: 4013 ands r3, r2
|
|
8002484: 613b str r3, [r7, #16]
|
|
if ((GPIO_Init->Mode & TRIGGER_RISING) != 0x00U)
|
|
8002486: 683b ldr r3, [r7, #0]
|
|
8002488: 685a ldr r2, [r3, #4]
|
|
800248a: 2380 movs r3, #128 ; 0x80
|
|
800248c: 035b lsls r3, r3, #13
|
|
800248e: 4013 ands r3, r2
|
|
8002490: d003 beq.n 800249a <HAL_GPIO_Init+0x276>
|
|
{
|
|
temp |= iocurrent;
|
|
8002492: 693a ldr r2, [r7, #16]
|
|
8002494: 68fb ldr r3, [r7, #12]
|
|
8002496: 4313 orrs r3, r2
|
|
8002498: 613b str r3, [r7, #16]
|
|
}
|
|
EXTI->RTSR = temp;
|
|
800249a: 4b18 ldr r3, [pc, #96] ; (80024fc <HAL_GPIO_Init+0x2d8>)
|
|
800249c: 693a ldr r2, [r7, #16]
|
|
800249e: 609a str r2, [r3, #8]
|
|
|
|
temp = EXTI->FTSR;
|
|
80024a0: 4b16 ldr r3, [pc, #88] ; (80024fc <HAL_GPIO_Init+0x2d8>)
|
|
80024a2: 68db ldr r3, [r3, #12]
|
|
80024a4: 613b str r3, [r7, #16]
|
|
temp &= ~((uint32_t)iocurrent);
|
|
80024a6: 68fb ldr r3, [r7, #12]
|
|
80024a8: 43da mvns r2, r3
|
|
80024aa: 693b ldr r3, [r7, #16]
|
|
80024ac: 4013 ands r3, r2
|
|
80024ae: 613b str r3, [r7, #16]
|
|
if ((GPIO_Init->Mode & TRIGGER_FALLING) != 0x00U)
|
|
80024b0: 683b ldr r3, [r7, #0]
|
|
80024b2: 685a ldr r2, [r3, #4]
|
|
80024b4: 2380 movs r3, #128 ; 0x80
|
|
80024b6: 039b lsls r3, r3, #14
|
|
80024b8: 4013 ands r3, r2
|
|
80024ba: d003 beq.n 80024c4 <HAL_GPIO_Init+0x2a0>
|
|
{
|
|
temp |= iocurrent;
|
|
80024bc: 693a ldr r2, [r7, #16]
|
|
80024be: 68fb ldr r3, [r7, #12]
|
|
80024c0: 4313 orrs r3, r2
|
|
80024c2: 613b str r3, [r7, #16]
|
|
}
|
|
EXTI->FTSR = temp;
|
|
80024c4: 4b0d ldr r3, [pc, #52] ; (80024fc <HAL_GPIO_Init+0x2d8>)
|
|
80024c6: 693a ldr r2, [r7, #16]
|
|
80024c8: 60da str r2, [r3, #12]
|
|
}
|
|
}
|
|
position++;
|
|
80024ca: 697b ldr r3, [r7, #20]
|
|
80024cc: 3301 adds r3, #1
|
|
80024ce: 617b str r3, [r7, #20]
|
|
while (((GPIO_Init->Pin) >> position) != 0)
|
|
80024d0: 683b ldr r3, [r7, #0]
|
|
80024d2: 681a ldr r2, [r3, #0]
|
|
80024d4: 697b ldr r3, [r7, #20]
|
|
80024d6: 40da lsrs r2, r3
|
|
80024d8: 1e13 subs r3, r2, #0
|
|
80024da: d000 beq.n 80024de <HAL_GPIO_Init+0x2ba>
|
|
80024dc: e6ae b.n 800223c <HAL_GPIO_Init+0x18>
|
|
}
|
|
}
|
|
80024de: 46c0 nop ; (mov r8, r8)
|
|
80024e0: 46c0 nop ; (mov r8, r8)
|
|
80024e2: 46bd mov sp, r7
|
|
80024e4: b006 add sp, #24
|
|
80024e6: bd80 pop {r7, pc}
|
|
80024e8: 40021000 .word 0x40021000
|
|
80024ec: 40010000 .word 0x40010000
|
|
80024f0: 50000400 .word 0x50000400
|
|
80024f4: 50000800 .word 0x50000800
|
|
80024f8: 50001c00 .word 0x50001c00
|
|
80024fc: 40010400 .word 0x40010400
|
|
|
|
08002500 <HAL_GPIO_WritePin>:
|
|
* GPIO_PIN_RESET: to clear the port pin
|
|
* GPIO_PIN_SET: to set the port pin
|
|
* @retval None
|
|
*/
|
|
void HAL_GPIO_WritePin(GPIO_TypeDef *GPIOx, uint16_t GPIO_Pin, GPIO_PinState PinState)
|
|
{
|
|
8002500: b580 push {r7, lr}
|
|
8002502: b082 sub sp, #8
|
|
8002504: af00 add r7, sp, #0
|
|
8002506: 6078 str r0, [r7, #4]
|
|
8002508: 0008 movs r0, r1
|
|
800250a: 0011 movs r1, r2
|
|
800250c: 1cbb adds r3, r7, #2
|
|
800250e: 1c02 adds r2, r0, #0
|
|
8002510: 801a strh r2, [r3, #0]
|
|
8002512: 1c7b adds r3, r7, #1
|
|
8002514: 1c0a adds r2, r1, #0
|
|
8002516: 701a strb r2, [r3, #0]
|
|
/* Check the parameters */
|
|
assert_param(IS_GPIO_PIN_AVAILABLE(GPIOx, GPIO_Pin));
|
|
assert_param(IS_GPIO_PIN_ACTION(PinState));
|
|
|
|
if (PinState != GPIO_PIN_RESET)
|
|
8002518: 1c7b adds r3, r7, #1
|
|
800251a: 781b ldrb r3, [r3, #0]
|
|
800251c: 2b00 cmp r3, #0
|
|
800251e: d004 beq.n 800252a <HAL_GPIO_WritePin+0x2a>
|
|
{
|
|
GPIOx->BSRR = GPIO_Pin;
|
|
8002520: 1cbb adds r3, r7, #2
|
|
8002522: 881a ldrh r2, [r3, #0]
|
|
8002524: 687b ldr r3, [r7, #4]
|
|
8002526: 619a str r2, [r3, #24]
|
|
}
|
|
else
|
|
{
|
|
GPIOx->BRR = GPIO_Pin ;
|
|
}
|
|
}
|
|
8002528: e003 b.n 8002532 <HAL_GPIO_WritePin+0x32>
|
|
GPIOx->BRR = GPIO_Pin ;
|
|
800252a: 1cbb adds r3, r7, #2
|
|
800252c: 881a ldrh r2, [r3, #0]
|
|
800252e: 687b ldr r3, [r7, #4]
|
|
8002530: 629a str r2, [r3, #40] ; 0x28
|
|
}
|
|
8002532: 46c0 nop ; (mov r8, r8)
|
|
8002534: 46bd mov sp, r7
|
|
8002536: b002 add sp, #8
|
|
8002538: bd80 pop {r7, pc}
|
|
...
|
|
|
|
0800253c <HAL_GPIO_EXTI_IRQHandler>:
|
|
* @brief This function handles EXTI interrupt request.
|
|
* @param GPIO_Pin Specifies the pins connected to the EXTI line.
|
|
* @retval None
|
|
*/
|
|
void HAL_GPIO_EXTI_IRQHandler(uint16_t GPIO_Pin)
|
|
{
|
|
800253c: b580 push {r7, lr}
|
|
800253e: b082 sub sp, #8
|
|
8002540: af00 add r7, sp, #0
|
|
8002542: 0002 movs r2, r0
|
|
8002544: 1dbb adds r3, r7, #6
|
|
8002546: 801a strh r2, [r3, #0]
|
|
/* EXTI line interrupt detected */
|
|
if (__HAL_GPIO_EXTI_GET_IT(GPIO_Pin) != RESET)
|
|
8002548: 4b09 ldr r3, [pc, #36] ; (8002570 <HAL_GPIO_EXTI_IRQHandler+0x34>)
|
|
800254a: 695b ldr r3, [r3, #20]
|
|
800254c: 1dba adds r2, r7, #6
|
|
800254e: 8812 ldrh r2, [r2, #0]
|
|
8002550: 4013 ands r3, r2
|
|
8002552: d008 beq.n 8002566 <HAL_GPIO_EXTI_IRQHandler+0x2a>
|
|
{
|
|
__HAL_GPIO_EXTI_CLEAR_IT(GPIO_Pin);
|
|
8002554: 4b06 ldr r3, [pc, #24] ; (8002570 <HAL_GPIO_EXTI_IRQHandler+0x34>)
|
|
8002556: 1dba adds r2, r7, #6
|
|
8002558: 8812 ldrh r2, [r2, #0]
|
|
800255a: 615a str r2, [r3, #20]
|
|
HAL_GPIO_EXTI_Callback(GPIO_Pin);
|
|
800255c: 1dbb adds r3, r7, #6
|
|
800255e: 881b ldrh r3, [r3, #0]
|
|
8002560: 0018 movs r0, r3
|
|
8002562: f000 f807 bl 8002574 <HAL_GPIO_EXTI_Callback>
|
|
}
|
|
}
|
|
8002566: 46c0 nop ; (mov r8, r8)
|
|
8002568: 46bd mov sp, r7
|
|
800256a: b002 add sp, #8
|
|
800256c: bd80 pop {r7, pc}
|
|
800256e: 46c0 nop ; (mov r8, r8)
|
|
8002570: 40010400 .word 0x40010400
|
|
|
|
08002574 <HAL_GPIO_EXTI_Callback>:
|
|
* @brief EXTI line detection callbacks.
|
|
* @param GPIO_Pin Specifies the pins connected to the EXTI line.
|
|
* @retval None
|
|
*/
|
|
__weak void HAL_GPIO_EXTI_Callback(uint16_t GPIO_Pin)
|
|
{
|
|
8002574: b580 push {r7, lr}
|
|
8002576: b082 sub sp, #8
|
|
8002578: af00 add r7, sp, #0
|
|
800257a: 0002 movs r2, r0
|
|
800257c: 1dbb adds r3, r7, #6
|
|
800257e: 801a strh r2, [r3, #0]
|
|
UNUSED(GPIO_Pin);
|
|
|
|
/* NOTE: This function Should not be modified, when the callback is needed,
|
|
the HAL_GPIO_EXTI_Callback could be implemented in the user file
|
|
*/
|
|
}
|
|
8002580: 46c0 nop ; (mov r8, r8)
|
|
8002582: 46bd mov sp, r7
|
|
8002584: b002 add sp, #8
|
|
8002586: bd80 pop {r7, pc}
|
|
|
|
08002588 <HAL_LPTIM_Init>:
|
|
* LPTIM_InitTypeDef and initialize the associated handle.
|
|
* @param hlptim LPTIM handle
|
|
* @retval HAL status
|
|
*/
|
|
HAL_StatusTypeDef HAL_LPTIM_Init(LPTIM_HandleTypeDef *hlptim)
|
|
{
|
|
8002588: b580 push {r7, lr}
|
|
800258a: b084 sub sp, #16
|
|
800258c: af00 add r7, sp, #0
|
|
800258e: 6078 str r0, [r7, #4]
|
|
uint32_t tmpcfgr;
|
|
|
|
/* Check the LPTIM handle allocation */
|
|
if (hlptim == NULL)
|
|
8002590: 687b ldr r3, [r7, #4]
|
|
8002592: 2b00 cmp r3, #0
|
|
8002594: d101 bne.n 800259a <HAL_LPTIM_Init+0x12>
|
|
{
|
|
return HAL_ERROR;
|
|
8002596: 2301 movs r3, #1
|
|
8002598: e078 b.n 800268c <HAL_LPTIM_Init+0x104>
|
|
}
|
|
assert_param(IS_LPTIM_OUTPUT_POLARITY(hlptim->Init.OutputPolarity));
|
|
assert_param(IS_LPTIM_UPDATE_MODE(hlptim->Init.UpdateMode));
|
|
assert_param(IS_LPTIM_COUNTER_SOURCE(hlptim->Init.CounterSource));
|
|
|
|
if (hlptim->State == HAL_LPTIM_STATE_RESET)
|
|
800259a: 687b ldr r3, [r7, #4]
|
|
800259c: 222e movs r2, #46 ; 0x2e
|
|
800259e: 5c9b ldrb r3, [r3, r2]
|
|
80025a0: b2db uxtb r3, r3
|
|
80025a2: 2b00 cmp r3, #0
|
|
80025a4: d107 bne.n 80025b6 <HAL_LPTIM_Init+0x2e>
|
|
{
|
|
/* Allocate lock resource and initialize it */
|
|
hlptim->Lock = HAL_UNLOCKED;
|
|
80025a6: 687b ldr r3, [r7, #4]
|
|
80025a8: 222d movs r2, #45 ; 0x2d
|
|
80025aa: 2100 movs r1, #0
|
|
80025ac: 5499 strb r1, [r3, r2]
|
|
|
|
/* Init the low level hardware : GPIO, CLOCK, NVIC */
|
|
hlptim->MspInitCallback(hlptim);
|
|
#else
|
|
/* Init the low level hardware : GPIO, CLOCK, NVIC */
|
|
HAL_LPTIM_MspInit(hlptim);
|
|
80025ae: 687b ldr r3, [r7, #4]
|
|
80025b0: 0018 movs r0, r3
|
|
80025b2: f7fe fe1f bl 80011f4 <HAL_LPTIM_MspInit>
|
|
#endif /* USE_HAL_LPTIM_REGISTER_CALLBACKS */
|
|
}
|
|
|
|
/* Change the LPTIM state */
|
|
hlptim->State = HAL_LPTIM_STATE_BUSY;
|
|
80025b6: 687b ldr r3, [r7, #4]
|
|
80025b8: 222e movs r2, #46 ; 0x2e
|
|
80025ba: 2102 movs r1, #2
|
|
80025bc: 5499 strb r1, [r3, r2]
|
|
|
|
/* Get the LPTIMx CFGR value */
|
|
tmpcfgr = hlptim->Instance->CFGR;
|
|
80025be: 687b ldr r3, [r7, #4]
|
|
80025c0: 681b ldr r3, [r3, #0]
|
|
80025c2: 68db ldr r3, [r3, #12]
|
|
80025c4: 60fb str r3, [r7, #12]
|
|
|
|
if ((hlptim->Init.Clock.Source == LPTIM_CLOCKSOURCE_ULPTIM)
|
|
80025c6: 687b ldr r3, [r7, #4]
|
|
80025c8: 685b ldr r3, [r3, #4]
|
|
80025ca: 2b01 cmp r3, #1
|
|
80025cc: d005 beq.n 80025da <HAL_LPTIM_Init+0x52>
|
|
|| (hlptim->Init.CounterSource == LPTIM_COUNTERSOURCE_EXTERNAL))
|
|
80025ce: 687b ldr r3, [r7, #4]
|
|
80025d0: 6a9a ldr r2, [r3, #40] ; 0x28
|
|
80025d2: 2380 movs r3, #128 ; 0x80
|
|
80025d4: 041b lsls r3, r3, #16
|
|
80025d6: 429a cmp r2, r3
|
|
80025d8: d103 bne.n 80025e2 <HAL_LPTIM_Init+0x5a>
|
|
{
|
|
tmpcfgr &= (uint32_t)(~(LPTIM_CFGR_CKPOL | LPTIM_CFGR_CKFLT));
|
|
80025da: 68fb ldr r3, [r7, #12]
|
|
80025dc: 221e movs r2, #30
|
|
80025de: 4393 bics r3, r2
|
|
80025e0: 60fb str r3, [r7, #12]
|
|
}
|
|
if (hlptim->Init.Trigger.Source != LPTIM_TRIGSOURCE_SOFTWARE)
|
|
80025e2: 687b ldr r3, [r7, #4]
|
|
80025e4: 695b ldr r3, [r3, #20]
|
|
80025e6: 4a2b ldr r2, [pc, #172] ; (8002694 <HAL_LPTIM_Init+0x10c>)
|
|
80025e8: 4293 cmp r3, r2
|
|
80025ea: d003 beq.n 80025f4 <HAL_LPTIM_Init+0x6c>
|
|
{
|
|
tmpcfgr &= (uint32_t)(~(LPTIM_CFGR_TRGFLT | LPTIM_CFGR_TRIGSEL));
|
|
80025ec: 68fb ldr r3, [r7, #12]
|
|
80025ee: 4a2a ldr r2, [pc, #168] ; (8002698 <HAL_LPTIM_Init+0x110>)
|
|
80025f0: 4013 ands r3, r2
|
|
80025f2: 60fb str r3, [r7, #12]
|
|
}
|
|
|
|
/* Clear CKSEL, PRESC, TRIGEN, TRGFLT, WAVPOL, PRELOAD & COUNTMODE bits */
|
|
tmpcfgr &= (uint32_t)(~(LPTIM_CFGR_CKSEL | LPTIM_CFGR_TRIGEN | LPTIM_CFGR_PRELOAD |
|
|
80025f4: 68fb ldr r3, [r7, #12]
|
|
80025f6: 4a29 ldr r2, [pc, #164] ; (800269c <HAL_LPTIM_Init+0x114>)
|
|
80025f8: 4013 ands r3, r2
|
|
80025fa: 60fb str r3, [r7, #12]
|
|
LPTIM_CFGR_WAVPOL | LPTIM_CFGR_PRESC | LPTIM_CFGR_COUNTMODE));
|
|
|
|
/* Set initialization parameters */
|
|
tmpcfgr |= (hlptim->Init.Clock.Source |
|
|
80025fc: 687b ldr r3, [r7, #4]
|
|
80025fe: 685a ldr r2, [r3, #4]
|
|
hlptim->Init.Clock.Prescaler |
|
|
8002600: 687b ldr r3, [r7, #4]
|
|
8002602: 689b ldr r3, [r3, #8]
|
|
tmpcfgr |= (hlptim->Init.Clock.Source |
|
|
8002604: 431a orrs r2, r3
|
|
hlptim->Init.OutputPolarity |
|
|
8002606: 687b ldr r3, [r7, #4]
|
|
8002608: 6a1b ldr r3, [r3, #32]
|
|
hlptim->Init.Clock.Prescaler |
|
|
800260a: 431a orrs r2, r3
|
|
hlptim->Init.UpdateMode |
|
|
800260c: 687b ldr r3, [r7, #4]
|
|
800260e: 6a5b ldr r3, [r3, #36] ; 0x24
|
|
hlptim->Init.OutputPolarity |
|
|
8002610: 431a orrs r2, r3
|
|
hlptim->Init.CounterSource);
|
|
8002612: 687b ldr r3, [r7, #4]
|
|
8002614: 6a9b ldr r3, [r3, #40] ; 0x28
|
|
hlptim->Init.UpdateMode |
|
|
8002616: 4313 orrs r3, r2
|
|
tmpcfgr |= (hlptim->Init.Clock.Source |
|
|
8002618: 68fa ldr r2, [r7, #12]
|
|
800261a: 4313 orrs r3, r2
|
|
800261c: 60fb str r3, [r7, #12]
|
|
|
|
/* Glitch filters for internal triggers and external inputs are configured
|
|
* only if an internal clock source is provided to the LPTIM
|
|
*/
|
|
if (hlptim->Init.Clock.Source == LPTIM_CLOCKSOURCE_APBCLOCK_LPOSC)
|
|
800261e: 687b ldr r3, [r7, #4]
|
|
8002620: 685b ldr r3, [r3, #4]
|
|
8002622: 2b00 cmp r3, #0
|
|
8002624: d107 bne.n 8002636 <HAL_LPTIM_Init+0xae>
|
|
{
|
|
tmpcfgr |= (hlptim->Init.Trigger.SampleTime |
|
|
8002626: 687b ldr r3, [r7, #4]
|
|
8002628: 69da ldr r2, [r3, #28]
|
|
hlptim->Init.UltraLowPowerClock.SampleTime);
|
|
800262a: 687b ldr r3, [r7, #4]
|
|
800262c: 691b ldr r3, [r3, #16]
|
|
tmpcfgr |= (hlptim->Init.Trigger.SampleTime |
|
|
800262e: 4313 orrs r3, r2
|
|
8002630: 68fa ldr r2, [r7, #12]
|
|
8002632: 4313 orrs r3, r2
|
|
8002634: 60fb str r3, [r7, #12]
|
|
}
|
|
|
|
/* Configure LPTIM external clock polarity and digital filter */
|
|
if ((hlptim->Init.Clock.Source == LPTIM_CLOCKSOURCE_ULPTIM)
|
|
8002636: 687b ldr r3, [r7, #4]
|
|
8002638: 685b ldr r3, [r3, #4]
|
|
800263a: 2b01 cmp r3, #1
|
|
800263c: d005 beq.n 800264a <HAL_LPTIM_Init+0xc2>
|
|
|| (hlptim->Init.CounterSource == LPTIM_COUNTERSOURCE_EXTERNAL))
|
|
800263e: 687b ldr r3, [r7, #4]
|
|
8002640: 6a9a ldr r2, [r3, #40] ; 0x28
|
|
8002642: 2380 movs r3, #128 ; 0x80
|
|
8002644: 041b lsls r3, r3, #16
|
|
8002646: 429a cmp r2, r3
|
|
8002648: d107 bne.n 800265a <HAL_LPTIM_Init+0xd2>
|
|
{
|
|
tmpcfgr |= (hlptim->Init.UltraLowPowerClock.Polarity |
|
|
800264a: 687b ldr r3, [r7, #4]
|
|
800264c: 68da ldr r2, [r3, #12]
|
|
hlptim->Init.UltraLowPowerClock.SampleTime);
|
|
800264e: 687b ldr r3, [r7, #4]
|
|
8002650: 691b ldr r3, [r3, #16]
|
|
tmpcfgr |= (hlptim->Init.UltraLowPowerClock.Polarity |
|
|
8002652: 4313 orrs r3, r2
|
|
8002654: 68fa ldr r2, [r7, #12]
|
|
8002656: 4313 orrs r3, r2
|
|
8002658: 60fb str r3, [r7, #12]
|
|
}
|
|
|
|
/* Configure LPTIM external trigger */
|
|
if (hlptim->Init.Trigger.Source != LPTIM_TRIGSOURCE_SOFTWARE)
|
|
800265a: 687b ldr r3, [r7, #4]
|
|
800265c: 695b ldr r3, [r3, #20]
|
|
800265e: 4a0d ldr r2, [pc, #52] ; (8002694 <HAL_LPTIM_Init+0x10c>)
|
|
8002660: 4293 cmp r3, r2
|
|
8002662: d00a beq.n 800267a <HAL_LPTIM_Init+0xf2>
|
|
{
|
|
/* Enable External trigger and set the trigger source */
|
|
tmpcfgr |= (hlptim->Init.Trigger.Source |
|
|
8002664: 687b ldr r3, [r7, #4]
|
|
8002666: 695a ldr r2, [r3, #20]
|
|
hlptim->Init.Trigger.ActiveEdge |
|
|
8002668: 687b ldr r3, [r7, #4]
|
|
800266a: 699b ldr r3, [r3, #24]
|
|
tmpcfgr |= (hlptim->Init.Trigger.Source |
|
|
800266c: 431a orrs r2, r3
|
|
hlptim->Init.Trigger.SampleTime);
|
|
800266e: 687b ldr r3, [r7, #4]
|
|
8002670: 69db ldr r3, [r3, #28]
|
|
hlptim->Init.Trigger.ActiveEdge |
|
|
8002672: 4313 orrs r3, r2
|
|
tmpcfgr |= (hlptim->Init.Trigger.Source |
|
|
8002674: 68fa ldr r2, [r7, #12]
|
|
8002676: 4313 orrs r3, r2
|
|
8002678: 60fb str r3, [r7, #12]
|
|
}
|
|
|
|
/* Write to LPTIMx CFGR */
|
|
hlptim->Instance->CFGR = tmpcfgr;
|
|
800267a: 687b ldr r3, [r7, #4]
|
|
800267c: 681b ldr r3, [r3, #0]
|
|
800267e: 68fa ldr r2, [r7, #12]
|
|
8002680: 60da str r2, [r3, #12]
|
|
|
|
/* Change the LPTIM state */
|
|
hlptim->State = HAL_LPTIM_STATE_READY;
|
|
8002682: 687b ldr r3, [r7, #4]
|
|
8002684: 222e movs r2, #46 ; 0x2e
|
|
8002686: 2101 movs r1, #1
|
|
8002688: 5499 strb r1, [r3, r2]
|
|
|
|
/* Return function status */
|
|
return HAL_OK;
|
|
800268a: 2300 movs r3, #0
|
|
}
|
|
800268c: 0018 movs r0, r3
|
|
800268e: 46bd mov sp, r7
|
|
8002690: b004 add sp, #16
|
|
8002692: bd80 pop {r7, pc}
|
|
8002694: 0000ffff .word 0x0000ffff
|
|
8002698: ffff1f3f .word 0xffff1f3f
|
|
800269c: ff19f1fe .word 0xff19f1fe
|
|
|
|
080026a0 <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)
|
|
{
|
|
80026a0: b5b0 push {r4, r5, r7, lr}
|
|
80026a2: b08a sub sp, #40 ; 0x28
|
|
80026a4: af00 add r7, sp, #0
|
|
80026a6: 6078 str r0, [r7, #4]
|
|
uint32_t hsi_state;
|
|
HAL_StatusTypeDef status;
|
|
uint32_t sysclk_source, pll_config;
|
|
|
|
/* Check Null pointer */
|
|
if(RCC_OscInitStruct == NULL)
|
|
80026a8: 687b ldr r3, [r7, #4]
|
|
80026aa: 2b00 cmp r3, #0
|
|
80026ac: d102 bne.n 80026b4 <HAL_RCC_OscConfig+0x14>
|
|
{
|
|
return HAL_ERROR;
|
|
80026ae: 2301 movs r3, #1
|
|
80026b0: f000 fb6c bl 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
}
|
|
|
|
/* Check the parameters */
|
|
assert_param(IS_RCC_OSCILLATORTYPE(RCC_OscInitStruct->OscillatorType));
|
|
|
|
sysclk_source = __HAL_RCC_GET_SYSCLK_SOURCE();
|
|
80026b4: 4bc8 ldr r3, [pc, #800] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
80026b6: 68db ldr r3, [r3, #12]
|
|
80026b8: 220c movs r2, #12
|
|
80026ba: 4013 ands r3, r2
|
|
80026bc: 61fb str r3, [r7, #28]
|
|
pll_config = __HAL_RCC_GET_PLL_OSCSOURCE();
|
|
80026be: 4bc6 ldr r3, [pc, #792] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
80026c0: 68da ldr r2, [r3, #12]
|
|
80026c2: 2380 movs r3, #128 ; 0x80
|
|
80026c4: 025b lsls r3, r3, #9
|
|
80026c6: 4013 ands r3, r2
|
|
80026c8: 61bb str r3, [r7, #24]
|
|
|
|
/*------------------------------- HSE Configuration ------------------------*/
|
|
if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_HSE) == RCC_OSCILLATORTYPE_HSE)
|
|
80026ca: 687b ldr r3, [r7, #4]
|
|
80026cc: 681b ldr r3, [r3, #0]
|
|
80026ce: 2201 movs r2, #1
|
|
80026d0: 4013 ands r3, r2
|
|
80026d2: d100 bne.n 80026d6 <HAL_RCC_OscConfig+0x36>
|
|
80026d4: e07d b.n 80027d2 <HAL_RCC_OscConfig+0x132>
|
|
{
|
|
/* Check the parameters */
|
|
assert_param(IS_RCC_HSE(RCC_OscInitStruct->HSEState));
|
|
|
|
/* When the HSE is used as system clock or clock source for PLL in these cases it is not allowed to be disabled */
|
|
if((sysclk_source == RCC_SYSCLKSOURCE_STATUS_HSE)
|
|
80026d6: 69fb ldr r3, [r7, #28]
|
|
80026d8: 2b08 cmp r3, #8
|
|
80026da: d007 beq.n 80026ec <HAL_RCC_OscConfig+0x4c>
|
|
|| ((sysclk_source == RCC_SYSCLKSOURCE_STATUS_PLLCLK) && (pll_config == RCC_PLLSOURCE_HSE)))
|
|
80026dc: 69fb ldr r3, [r7, #28]
|
|
80026de: 2b0c cmp r3, #12
|
|
80026e0: d112 bne.n 8002708 <HAL_RCC_OscConfig+0x68>
|
|
80026e2: 69ba ldr r2, [r7, #24]
|
|
80026e4: 2380 movs r3, #128 ; 0x80
|
|
80026e6: 025b lsls r3, r3, #9
|
|
80026e8: 429a cmp r2, r3
|
|
80026ea: d10d bne.n 8002708 <HAL_RCC_OscConfig+0x68>
|
|
{
|
|
if((__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) != 0U) && (RCC_OscInitStruct->HSEState == RCC_HSE_OFF))
|
|
80026ec: 4bba ldr r3, [pc, #744] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
80026ee: 681a ldr r2, [r3, #0]
|
|
80026f0: 2380 movs r3, #128 ; 0x80
|
|
80026f2: 029b lsls r3, r3, #10
|
|
80026f4: 4013 ands r3, r2
|
|
80026f6: d100 bne.n 80026fa <HAL_RCC_OscConfig+0x5a>
|
|
80026f8: e06a b.n 80027d0 <HAL_RCC_OscConfig+0x130>
|
|
80026fa: 687b ldr r3, [r7, #4]
|
|
80026fc: 685b ldr r3, [r3, #4]
|
|
80026fe: 2b00 cmp r3, #0
|
|
8002700: d166 bne.n 80027d0 <HAL_RCC_OscConfig+0x130>
|
|
{
|
|
return HAL_ERROR;
|
|
8002702: 2301 movs r3, #1
|
|
8002704: f000 fb42 bl 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* Set the new HSE configuration ---------------------------------------*/
|
|
__HAL_RCC_HSE_CONFIG(RCC_OscInitStruct->HSEState);
|
|
8002708: 687b ldr r3, [r7, #4]
|
|
800270a: 685a ldr r2, [r3, #4]
|
|
800270c: 2380 movs r3, #128 ; 0x80
|
|
800270e: 025b lsls r3, r3, #9
|
|
8002710: 429a cmp r2, r3
|
|
8002712: d107 bne.n 8002724 <HAL_RCC_OscConfig+0x84>
|
|
8002714: 4bb0 ldr r3, [pc, #704] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
8002716: 681a ldr r2, [r3, #0]
|
|
8002718: 4baf ldr r3, [pc, #700] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
800271a: 2180 movs r1, #128 ; 0x80
|
|
800271c: 0249 lsls r1, r1, #9
|
|
800271e: 430a orrs r2, r1
|
|
8002720: 601a str r2, [r3, #0]
|
|
8002722: e027 b.n 8002774 <HAL_RCC_OscConfig+0xd4>
|
|
8002724: 687b ldr r3, [r7, #4]
|
|
8002726: 685a ldr r2, [r3, #4]
|
|
8002728: 23a0 movs r3, #160 ; 0xa0
|
|
800272a: 02db lsls r3, r3, #11
|
|
800272c: 429a cmp r2, r3
|
|
800272e: d10e bne.n 800274e <HAL_RCC_OscConfig+0xae>
|
|
8002730: 4ba9 ldr r3, [pc, #676] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
8002732: 681a ldr r2, [r3, #0]
|
|
8002734: 4ba8 ldr r3, [pc, #672] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
8002736: 2180 movs r1, #128 ; 0x80
|
|
8002738: 02c9 lsls r1, r1, #11
|
|
800273a: 430a orrs r2, r1
|
|
800273c: 601a str r2, [r3, #0]
|
|
800273e: 4ba6 ldr r3, [pc, #664] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
8002740: 681a ldr r2, [r3, #0]
|
|
8002742: 4ba5 ldr r3, [pc, #660] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
8002744: 2180 movs r1, #128 ; 0x80
|
|
8002746: 0249 lsls r1, r1, #9
|
|
8002748: 430a orrs r2, r1
|
|
800274a: 601a str r2, [r3, #0]
|
|
800274c: e012 b.n 8002774 <HAL_RCC_OscConfig+0xd4>
|
|
800274e: 4ba2 ldr r3, [pc, #648] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
8002750: 681a ldr r2, [r3, #0]
|
|
8002752: 4ba1 ldr r3, [pc, #644] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
8002754: 49a1 ldr r1, [pc, #644] ; (80029dc <HAL_RCC_OscConfig+0x33c>)
|
|
8002756: 400a ands r2, r1
|
|
8002758: 601a str r2, [r3, #0]
|
|
800275a: 4b9f ldr r3, [pc, #636] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
800275c: 681a ldr r2, [r3, #0]
|
|
800275e: 2380 movs r3, #128 ; 0x80
|
|
8002760: 025b lsls r3, r3, #9
|
|
8002762: 4013 ands r3, r2
|
|
8002764: 60fb str r3, [r7, #12]
|
|
8002766: 68fb ldr r3, [r7, #12]
|
|
8002768: 4b9b ldr r3, [pc, #620] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
800276a: 681a ldr r2, [r3, #0]
|
|
800276c: 4b9a ldr r3, [pc, #616] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
800276e: 499c ldr r1, [pc, #624] ; (80029e0 <HAL_RCC_OscConfig+0x340>)
|
|
8002770: 400a ands r2, r1
|
|
8002772: 601a str r2, [r3, #0]
|
|
|
|
/* Check the HSE State */
|
|
if(RCC_OscInitStruct->HSEState != RCC_HSE_OFF)
|
|
8002774: 687b ldr r3, [r7, #4]
|
|
8002776: 685b ldr r3, [r3, #4]
|
|
8002778: 2b00 cmp r3, #0
|
|
800277a: d014 beq.n 80027a6 <HAL_RCC_OscConfig+0x106>
|
|
{
|
|
/* Get Start Tick */
|
|
tickstart = HAL_GetTick();
|
|
800277c: f7ff f80c bl 8001798 <HAL_GetTick>
|
|
8002780: 0003 movs r3, r0
|
|
8002782: 617b str r3, [r7, #20]
|
|
|
|
/* Wait till HSE is ready */
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) == 0U)
|
|
8002784: e008 b.n 8002798 <HAL_RCC_OscConfig+0xf8>
|
|
{
|
|
if((HAL_GetTick() - tickstart ) > HSE_TIMEOUT_VALUE)
|
|
8002786: f7ff f807 bl 8001798 <HAL_GetTick>
|
|
800278a: 0002 movs r2, r0
|
|
800278c: 697b ldr r3, [r7, #20]
|
|
800278e: 1ad3 subs r3, r2, r3
|
|
8002790: 2b64 cmp r3, #100 ; 0x64
|
|
8002792: d901 bls.n 8002798 <HAL_RCC_OscConfig+0xf8>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
8002794: 2303 movs r3, #3
|
|
8002796: e2f9 b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) == 0U)
|
|
8002798: 4b8f ldr r3, [pc, #572] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
800279a: 681a ldr r2, [r3, #0]
|
|
800279c: 2380 movs r3, #128 ; 0x80
|
|
800279e: 029b lsls r3, r3, #10
|
|
80027a0: 4013 ands r3, r2
|
|
80027a2: d0f0 beq.n 8002786 <HAL_RCC_OscConfig+0xe6>
|
|
80027a4: e015 b.n 80027d2 <HAL_RCC_OscConfig+0x132>
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* Get Start Tick */
|
|
tickstart = HAL_GetTick();
|
|
80027a6: f7fe fff7 bl 8001798 <HAL_GetTick>
|
|
80027aa: 0003 movs r3, r0
|
|
80027ac: 617b str r3, [r7, #20]
|
|
|
|
/* Wait till HSE is disabled */
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) != 0U)
|
|
80027ae: e008 b.n 80027c2 <HAL_RCC_OscConfig+0x122>
|
|
{
|
|
if((HAL_GetTick() - tickstart ) > HSE_TIMEOUT_VALUE)
|
|
80027b0: f7fe fff2 bl 8001798 <HAL_GetTick>
|
|
80027b4: 0002 movs r2, r0
|
|
80027b6: 697b ldr r3, [r7, #20]
|
|
80027b8: 1ad3 subs r3, r2, r3
|
|
80027ba: 2b64 cmp r3, #100 ; 0x64
|
|
80027bc: d901 bls.n 80027c2 <HAL_RCC_OscConfig+0x122>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
80027be: 2303 movs r3, #3
|
|
80027c0: e2e4 b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) != 0U)
|
|
80027c2: 4b85 ldr r3, [pc, #532] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
80027c4: 681a ldr r2, [r3, #0]
|
|
80027c6: 2380 movs r3, #128 ; 0x80
|
|
80027c8: 029b lsls r3, r3, #10
|
|
80027ca: 4013 ands r3, r2
|
|
80027cc: d1f0 bne.n 80027b0 <HAL_RCC_OscConfig+0x110>
|
|
80027ce: e000 b.n 80027d2 <HAL_RCC_OscConfig+0x132>
|
|
if((__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) != 0U) && (RCC_OscInitStruct->HSEState == RCC_HSE_OFF))
|
|
80027d0: 46c0 nop ; (mov r8, r8)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
/*----------------------------- HSI Configuration --------------------------*/
|
|
if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_HSI) == RCC_OSCILLATORTYPE_HSI)
|
|
80027d2: 687b ldr r3, [r7, #4]
|
|
80027d4: 681b ldr r3, [r3, #0]
|
|
80027d6: 2202 movs r2, #2
|
|
80027d8: 4013 ands r3, r2
|
|
80027da: d100 bne.n 80027de <HAL_RCC_OscConfig+0x13e>
|
|
80027dc: e099 b.n 8002912 <HAL_RCC_OscConfig+0x272>
|
|
{
|
|
/* Check the parameters */
|
|
assert_param(IS_RCC_HSI(RCC_OscInitStruct->HSIState));
|
|
assert_param(IS_RCC_CALIBRATION_VALUE(RCC_OscInitStruct->HSICalibrationValue));
|
|
|
|
hsi_state = RCC_OscInitStruct->HSIState;
|
|
80027de: 687b ldr r3, [r7, #4]
|
|
80027e0: 68db ldr r3, [r3, #12]
|
|
80027e2: 627b str r3, [r7, #36] ; 0x24
|
|
|
|
#if defined(RCC_CR_HSIOUTEN)
|
|
if((hsi_state & RCC_HSI_OUTEN) != 0U)
|
|
80027e4: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
80027e6: 2220 movs r2, #32
|
|
80027e8: 4013 ands r3, r2
|
|
80027ea: d009 beq.n 8002800 <HAL_RCC_OscConfig+0x160>
|
|
{
|
|
/* HSI Output enable for timer requested */
|
|
SET_BIT(RCC->CR, RCC_CR_HSIOUTEN);
|
|
80027ec: 4b7a ldr r3, [pc, #488] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
80027ee: 681a ldr r2, [r3, #0]
|
|
80027f0: 4b79 ldr r3, [pc, #484] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
80027f2: 2120 movs r1, #32
|
|
80027f4: 430a orrs r2, r1
|
|
80027f6: 601a str r2, [r3, #0]
|
|
|
|
hsi_state &= ~RCC_CR_HSIOUTEN;
|
|
80027f8: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
80027fa: 2220 movs r2, #32
|
|
80027fc: 4393 bics r3, r2
|
|
80027fe: 627b str r3, [r7, #36] ; 0x24
|
|
}
|
|
#endif
|
|
|
|
/* Check if HSI is used as system clock or as PLL source when PLL is selected as system clock */
|
|
if((sysclk_source == RCC_SYSCLKSOURCE_STATUS_HSI)
|
|
8002800: 69fb ldr r3, [r7, #28]
|
|
8002802: 2b04 cmp r3, #4
|
|
8002804: d005 beq.n 8002812 <HAL_RCC_OscConfig+0x172>
|
|
|| ((sysclk_source == RCC_SYSCLKSOURCE_STATUS_PLLCLK) && (pll_config == RCC_PLLSOURCE_HSI)))
|
|
8002806: 69fb ldr r3, [r7, #28]
|
|
8002808: 2b0c cmp r3, #12
|
|
800280a: d13e bne.n 800288a <HAL_RCC_OscConfig+0x1ea>
|
|
800280c: 69bb ldr r3, [r7, #24]
|
|
800280e: 2b00 cmp r3, #0
|
|
8002810: d13b bne.n 800288a <HAL_RCC_OscConfig+0x1ea>
|
|
{
|
|
/* When HSI is used as system clock it will not disabled */
|
|
if((__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) != 0U) && (hsi_state == RCC_HSI_OFF))
|
|
8002812: 4b71 ldr r3, [pc, #452] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
8002814: 681b ldr r3, [r3, #0]
|
|
8002816: 2204 movs r2, #4
|
|
8002818: 4013 ands r3, r2
|
|
800281a: d004 beq.n 8002826 <HAL_RCC_OscConfig+0x186>
|
|
800281c: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
800281e: 2b00 cmp r3, #0
|
|
8002820: d101 bne.n 8002826 <HAL_RCC_OscConfig+0x186>
|
|
{
|
|
return HAL_ERROR;
|
|
8002822: 2301 movs r3, #1
|
|
8002824: e2b2 b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
}
|
|
/* Otherwise, just the calibration and HSI or HSIdiv4 are allowed */
|
|
else
|
|
{
|
|
/* Adjusts the Internal High Speed oscillator (HSI) calibration value.*/
|
|
__HAL_RCC_HSI_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->HSICalibrationValue);
|
|
8002826: 4b6c ldr r3, [pc, #432] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
8002828: 685b ldr r3, [r3, #4]
|
|
800282a: 4a6e ldr r2, [pc, #440] ; (80029e4 <HAL_RCC_OscConfig+0x344>)
|
|
800282c: 4013 ands r3, r2
|
|
800282e: 0019 movs r1, r3
|
|
8002830: 687b ldr r3, [r7, #4]
|
|
8002832: 691b ldr r3, [r3, #16]
|
|
8002834: 021a lsls r2, r3, #8
|
|
8002836: 4b68 ldr r3, [pc, #416] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
8002838: 430a orrs r2, r1
|
|
800283a: 605a str r2, [r3, #4]
|
|
|
|
/* Enable the Internal High Speed oscillator (HSI or HSIdiv4) */
|
|
__HAL_RCC_HSI_CONFIG(hsi_state);
|
|
800283c: 4b66 ldr r3, [pc, #408] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
800283e: 681b ldr r3, [r3, #0]
|
|
8002840: 2209 movs r2, #9
|
|
8002842: 4393 bics r3, r2
|
|
8002844: 0019 movs r1, r3
|
|
8002846: 4b64 ldr r3, [pc, #400] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
8002848: 6a7a ldr r2, [r7, #36] ; 0x24
|
|
800284a: 430a orrs r2, r1
|
|
800284c: 601a str r2, [r3, #0]
|
|
}
|
|
|
|
/* Update the SystemCoreClock global variable */
|
|
SystemCoreClock = HAL_RCC_GetSysClockFreq() >> AHBPrescTable[(RCC->CFGR & RCC_CFGR_HPRE)>> RCC_CFGR_HPRE_Pos];
|
|
800284e: f000 fbeb bl 8003028 <HAL_RCC_GetSysClockFreq>
|
|
8002852: 0001 movs r1, r0
|
|
8002854: 4b60 ldr r3, [pc, #384] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
8002856: 68db ldr r3, [r3, #12]
|
|
8002858: 091b lsrs r3, r3, #4
|
|
800285a: 220f movs r2, #15
|
|
800285c: 4013 ands r3, r2
|
|
800285e: 4a62 ldr r2, [pc, #392] ; (80029e8 <HAL_RCC_OscConfig+0x348>)
|
|
8002860: 5cd3 ldrb r3, [r2, r3]
|
|
8002862: 000a movs r2, r1
|
|
8002864: 40da lsrs r2, r3
|
|
8002866: 4b61 ldr r3, [pc, #388] ; (80029ec <HAL_RCC_OscConfig+0x34c>)
|
|
8002868: 601a str r2, [r3, #0]
|
|
|
|
/* Configure the source of time base considering new system clocks settings*/
|
|
status = HAL_InitTick (uwTickPrio);
|
|
800286a: 4b61 ldr r3, [pc, #388] ; (80029f0 <HAL_RCC_OscConfig+0x350>)
|
|
800286c: 681b ldr r3, [r3, #0]
|
|
800286e: 2513 movs r5, #19
|
|
8002870: 197c adds r4, r7, r5
|
|
8002872: 0018 movs r0, r3
|
|
8002874: f7fe ff4a bl 800170c <HAL_InitTick>
|
|
8002878: 0003 movs r3, r0
|
|
800287a: 7023 strb r3, [r4, #0]
|
|
if(status != HAL_OK)
|
|
800287c: 197b adds r3, r7, r5
|
|
800287e: 781b ldrb r3, [r3, #0]
|
|
8002880: 2b00 cmp r3, #0
|
|
8002882: d046 beq.n 8002912 <HAL_RCC_OscConfig+0x272>
|
|
{
|
|
return status;
|
|
8002884: 197b adds r3, r7, r5
|
|
8002886: 781b ldrb r3, [r3, #0]
|
|
8002888: e280 b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* Check the HSI State */
|
|
if(hsi_state != RCC_HSI_OFF)
|
|
800288a: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
800288c: 2b00 cmp r3, #0
|
|
800288e: d027 beq.n 80028e0 <HAL_RCC_OscConfig+0x240>
|
|
{
|
|
/* Enable the Internal High Speed oscillator (HSI or HSIdiv4) */
|
|
__HAL_RCC_HSI_CONFIG(hsi_state);
|
|
8002890: 4b51 ldr r3, [pc, #324] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
8002892: 681b ldr r3, [r3, #0]
|
|
8002894: 2209 movs r2, #9
|
|
8002896: 4393 bics r3, r2
|
|
8002898: 0019 movs r1, r3
|
|
800289a: 4b4f ldr r3, [pc, #316] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
800289c: 6a7a ldr r2, [r7, #36] ; 0x24
|
|
800289e: 430a orrs r2, r1
|
|
80028a0: 601a str r2, [r3, #0]
|
|
|
|
/* Get Start Tick */
|
|
tickstart = HAL_GetTick();
|
|
80028a2: f7fe ff79 bl 8001798 <HAL_GetTick>
|
|
80028a6: 0003 movs r3, r0
|
|
80028a8: 617b str r3, [r7, #20]
|
|
|
|
/* Wait till HSI is ready */
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) == 0U)
|
|
80028aa: e008 b.n 80028be <HAL_RCC_OscConfig+0x21e>
|
|
{
|
|
if((HAL_GetTick() - tickstart ) > HSI_TIMEOUT_VALUE)
|
|
80028ac: f7fe ff74 bl 8001798 <HAL_GetTick>
|
|
80028b0: 0002 movs r2, r0
|
|
80028b2: 697b ldr r3, [r7, #20]
|
|
80028b4: 1ad3 subs r3, r2, r3
|
|
80028b6: 2b02 cmp r3, #2
|
|
80028b8: d901 bls.n 80028be <HAL_RCC_OscConfig+0x21e>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
80028ba: 2303 movs r3, #3
|
|
80028bc: e266 b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) == 0U)
|
|
80028be: 4b46 ldr r3, [pc, #280] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
80028c0: 681b ldr r3, [r3, #0]
|
|
80028c2: 2204 movs r2, #4
|
|
80028c4: 4013 ands r3, r2
|
|
80028c6: d0f1 beq.n 80028ac <HAL_RCC_OscConfig+0x20c>
|
|
}
|
|
}
|
|
|
|
/* Adjusts the Internal High Speed oscillator (HSI) calibration value.*/
|
|
__HAL_RCC_HSI_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->HSICalibrationValue);
|
|
80028c8: 4b43 ldr r3, [pc, #268] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
80028ca: 685b ldr r3, [r3, #4]
|
|
80028cc: 4a45 ldr r2, [pc, #276] ; (80029e4 <HAL_RCC_OscConfig+0x344>)
|
|
80028ce: 4013 ands r3, r2
|
|
80028d0: 0019 movs r1, r3
|
|
80028d2: 687b ldr r3, [r7, #4]
|
|
80028d4: 691b ldr r3, [r3, #16]
|
|
80028d6: 021a lsls r2, r3, #8
|
|
80028d8: 4b3f ldr r3, [pc, #252] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
80028da: 430a orrs r2, r1
|
|
80028dc: 605a str r2, [r3, #4]
|
|
80028de: e018 b.n 8002912 <HAL_RCC_OscConfig+0x272>
|
|
}
|
|
else
|
|
{
|
|
/* Disable the Internal High Speed oscillator (HSI). */
|
|
__HAL_RCC_HSI_DISABLE();
|
|
80028e0: 4b3d ldr r3, [pc, #244] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
80028e2: 681a ldr r2, [r3, #0]
|
|
80028e4: 4b3c ldr r3, [pc, #240] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
80028e6: 2101 movs r1, #1
|
|
80028e8: 438a bics r2, r1
|
|
80028ea: 601a str r2, [r3, #0]
|
|
|
|
/* Get Start Tick */
|
|
tickstart = HAL_GetTick();
|
|
80028ec: f7fe ff54 bl 8001798 <HAL_GetTick>
|
|
80028f0: 0003 movs r3, r0
|
|
80028f2: 617b str r3, [r7, #20]
|
|
|
|
/* Wait till HSI is disabled */
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) != 0U)
|
|
80028f4: e008 b.n 8002908 <HAL_RCC_OscConfig+0x268>
|
|
{
|
|
if((HAL_GetTick() - tickstart ) > HSI_TIMEOUT_VALUE)
|
|
80028f6: f7fe ff4f bl 8001798 <HAL_GetTick>
|
|
80028fa: 0002 movs r2, r0
|
|
80028fc: 697b ldr r3, [r7, #20]
|
|
80028fe: 1ad3 subs r3, r2, r3
|
|
8002900: 2b02 cmp r3, #2
|
|
8002902: d901 bls.n 8002908 <HAL_RCC_OscConfig+0x268>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
8002904: 2303 movs r3, #3
|
|
8002906: e241 b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) != 0U)
|
|
8002908: 4b33 ldr r3, [pc, #204] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
800290a: 681b ldr r3, [r3, #0]
|
|
800290c: 2204 movs r2, #4
|
|
800290e: 4013 ands r3, r2
|
|
8002910: d1f1 bne.n 80028f6 <HAL_RCC_OscConfig+0x256>
|
|
}
|
|
}
|
|
}
|
|
}
|
|
/*----------------------------- MSI Configuration --------------------------*/
|
|
if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_MSI) == RCC_OSCILLATORTYPE_MSI)
|
|
8002912: 687b ldr r3, [r7, #4]
|
|
8002914: 681b ldr r3, [r3, #0]
|
|
8002916: 2210 movs r2, #16
|
|
8002918: 4013 ands r3, r2
|
|
800291a: d100 bne.n 800291e <HAL_RCC_OscConfig+0x27e>
|
|
800291c: e0a1 b.n 8002a62 <HAL_RCC_OscConfig+0x3c2>
|
|
{
|
|
/* When the MSI is used as system clock it will not be disabled */
|
|
if(sysclk_source == RCC_CFGR_SWS_MSI)
|
|
800291e: 69fb ldr r3, [r7, #28]
|
|
8002920: 2b00 cmp r3, #0
|
|
8002922: d140 bne.n 80029a6 <HAL_RCC_OscConfig+0x306>
|
|
{
|
|
if((__HAL_RCC_GET_FLAG(RCC_FLAG_MSIRDY) != 0U) && (RCC_OscInitStruct->MSIState == RCC_MSI_OFF))
|
|
8002924: 4b2c ldr r3, [pc, #176] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
8002926: 681a ldr r2, [r3, #0]
|
|
8002928: 2380 movs r3, #128 ; 0x80
|
|
800292a: 009b lsls r3, r3, #2
|
|
800292c: 4013 ands r3, r2
|
|
800292e: d005 beq.n 800293c <HAL_RCC_OscConfig+0x29c>
|
|
8002930: 687b ldr r3, [r7, #4]
|
|
8002932: 699b ldr r3, [r3, #24]
|
|
8002934: 2b00 cmp r3, #0
|
|
8002936: d101 bne.n 800293c <HAL_RCC_OscConfig+0x29c>
|
|
{
|
|
return HAL_ERROR;
|
|
8002938: 2301 movs r3, #1
|
|
800293a: e227 b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
/* Check MSICalibrationValue and MSIClockRange input parameters */
|
|
assert_param(IS_RCC_MSICALIBRATION_VALUE(RCC_OscInitStruct->MSICalibrationValue));
|
|
assert_param(IS_RCC_MSI_CLOCK_RANGE(RCC_OscInitStruct->MSIClockRange));
|
|
|
|
/* Selects the Multiple Speed oscillator (MSI) clock range .*/
|
|
__HAL_RCC_MSI_RANGE_CONFIG(RCC_OscInitStruct->MSIClockRange);
|
|
800293c: 4b26 ldr r3, [pc, #152] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
800293e: 685b ldr r3, [r3, #4]
|
|
8002940: 4a2c ldr r2, [pc, #176] ; (80029f4 <HAL_RCC_OscConfig+0x354>)
|
|
8002942: 4013 ands r3, r2
|
|
8002944: 0019 movs r1, r3
|
|
8002946: 687b ldr r3, [r7, #4]
|
|
8002948: 6a1a ldr r2, [r3, #32]
|
|
800294a: 4b23 ldr r3, [pc, #140] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
800294c: 430a orrs r2, r1
|
|
800294e: 605a str r2, [r3, #4]
|
|
/* Adjusts the Multiple Speed oscillator (MSI) calibration value.*/
|
|
__HAL_RCC_MSI_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->MSICalibrationValue);
|
|
8002950: 4b21 ldr r3, [pc, #132] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
8002952: 685b ldr r3, [r3, #4]
|
|
8002954: 021b lsls r3, r3, #8
|
|
8002956: 0a19 lsrs r1, r3, #8
|
|
8002958: 687b ldr r3, [r7, #4]
|
|
800295a: 69db ldr r3, [r3, #28]
|
|
800295c: 061a lsls r2, r3, #24
|
|
800295e: 4b1e ldr r3, [pc, #120] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
8002960: 430a orrs r2, r1
|
|
8002962: 605a str r2, [r3, #4]
|
|
|
|
|
|
/* Update the SystemCoreClock global variable */
|
|
SystemCoreClock = (32768U * (1UL << ((RCC_OscInitStruct->MSIClockRange >> RCC_ICSCR_MSIRANGE_Pos) + 1U)))
|
|
8002964: 687b ldr r3, [r7, #4]
|
|
8002966: 6a1b ldr r3, [r3, #32]
|
|
8002968: 0b5b lsrs r3, r3, #13
|
|
800296a: 3301 adds r3, #1
|
|
800296c: 2280 movs r2, #128 ; 0x80
|
|
800296e: 0212 lsls r2, r2, #8
|
|
8002970: 409a lsls r2, r3
|
|
>> AHBPrescTable[((RCC->CFGR & RCC_CFGR_HPRE) >> RCC_CFGR_HPRE_Pos)];
|
|
8002972: 4b19 ldr r3, [pc, #100] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
8002974: 68db ldr r3, [r3, #12]
|
|
8002976: 091b lsrs r3, r3, #4
|
|
8002978: 210f movs r1, #15
|
|
800297a: 400b ands r3, r1
|
|
800297c: 491a ldr r1, [pc, #104] ; (80029e8 <HAL_RCC_OscConfig+0x348>)
|
|
800297e: 5ccb ldrb r3, [r1, r3]
|
|
8002980: 40da lsrs r2, r3
|
|
SystemCoreClock = (32768U * (1UL << ((RCC_OscInitStruct->MSIClockRange >> RCC_ICSCR_MSIRANGE_Pos) + 1U)))
|
|
8002982: 4b1a ldr r3, [pc, #104] ; (80029ec <HAL_RCC_OscConfig+0x34c>)
|
|
8002984: 601a str r2, [r3, #0]
|
|
|
|
/* Configure the source of time base considering new system clocks settings*/
|
|
status = HAL_InitTick (uwTickPrio);
|
|
8002986: 4b1a ldr r3, [pc, #104] ; (80029f0 <HAL_RCC_OscConfig+0x350>)
|
|
8002988: 681b ldr r3, [r3, #0]
|
|
800298a: 2513 movs r5, #19
|
|
800298c: 197c adds r4, r7, r5
|
|
800298e: 0018 movs r0, r3
|
|
8002990: f7fe febc bl 800170c <HAL_InitTick>
|
|
8002994: 0003 movs r3, r0
|
|
8002996: 7023 strb r3, [r4, #0]
|
|
if(status != HAL_OK)
|
|
8002998: 197b adds r3, r7, r5
|
|
800299a: 781b ldrb r3, [r3, #0]
|
|
800299c: 2b00 cmp r3, #0
|
|
800299e: d060 beq.n 8002a62 <HAL_RCC_OscConfig+0x3c2>
|
|
{
|
|
return status;
|
|
80029a0: 197b adds r3, r7, r5
|
|
80029a2: 781b ldrb r3, [r3, #0]
|
|
80029a4: e1f2 b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
{
|
|
/* Check MSI State */
|
|
assert_param(IS_RCC_MSI(RCC_OscInitStruct->MSIState));
|
|
|
|
/* Check the MSI State */
|
|
if(RCC_OscInitStruct->MSIState != RCC_MSI_OFF)
|
|
80029a6: 687b ldr r3, [r7, #4]
|
|
80029a8: 699b ldr r3, [r3, #24]
|
|
80029aa: 2b00 cmp r3, #0
|
|
80029ac: d03f beq.n 8002a2e <HAL_RCC_OscConfig+0x38e>
|
|
{
|
|
/* Enable the Multi Speed oscillator (MSI). */
|
|
__HAL_RCC_MSI_ENABLE();
|
|
80029ae: 4b0a ldr r3, [pc, #40] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
80029b0: 681a ldr r2, [r3, #0]
|
|
80029b2: 4b09 ldr r3, [pc, #36] ; (80029d8 <HAL_RCC_OscConfig+0x338>)
|
|
80029b4: 2180 movs r1, #128 ; 0x80
|
|
80029b6: 0049 lsls r1, r1, #1
|
|
80029b8: 430a orrs r2, r1
|
|
80029ba: 601a str r2, [r3, #0]
|
|
|
|
/* Get Start Tick */
|
|
tickstart = HAL_GetTick();
|
|
80029bc: f7fe feec bl 8001798 <HAL_GetTick>
|
|
80029c0: 0003 movs r3, r0
|
|
80029c2: 617b str r3, [r7, #20]
|
|
|
|
/* Wait till MSI is ready */
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_MSIRDY) == 0U)
|
|
80029c4: e018 b.n 80029f8 <HAL_RCC_OscConfig+0x358>
|
|
{
|
|
if((HAL_GetTick() - tickstart) > MSI_TIMEOUT_VALUE)
|
|
80029c6: f7fe fee7 bl 8001798 <HAL_GetTick>
|
|
80029ca: 0002 movs r2, r0
|
|
80029cc: 697b ldr r3, [r7, #20]
|
|
80029ce: 1ad3 subs r3, r2, r3
|
|
80029d0: 2b02 cmp r3, #2
|
|
80029d2: d911 bls.n 80029f8 <HAL_RCC_OscConfig+0x358>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
80029d4: 2303 movs r3, #3
|
|
80029d6: e1d9 b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
80029d8: 40021000 .word 0x40021000
|
|
80029dc: fffeffff .word 0xfffeffff
|
|
80029e0: fffbffff .word 0xfffbffff
|
|
80029e4: ffffe0ff .word 0xffffe0ff
|
|
80029e8: 08007884 .word 0x08007884
|
|
80029ec: 20000000 .word 0x20000000
|
|
80029f0: 20000004 .word 0x20000004
|
|
80029f4: ffff1fff .word 0xffff1fff
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_MSIRDY) == 0U)
|
|
80029f8: 4bc9 ldr r3, [pc, #804] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
80029fa: 681a ldr r2, [r3, #0]
|
|
80029fc: 2380 movs r3, #128 ; 0x80
|
|
80029fe: 009b lsls r3, r3, #2
|
|
8002a00: 4013 ands r3, r2
|
|
8002a02: d0e0 beq.n 80029c6 <HAL_RCC_OscConfig+0x326>
|
|
/* Check MSICalibrationValue and MSIClockRange input parameters */
|
|
assert_param(IS_RCC_MSICALIBRATION_VALUE(RCC_OscInitStruct->MSICalibrationValue));
|
|
assert_param(IS_RCC_MSI_CLOCK_RANGE(RCC_OscInitStruct->MSIClockRange));
|
|
|
|
/* Selects the Multiple Speed oscillator (MSI) clock range .*/
|
|
__HAL_RCC_MSI_RANGE_CONFIG(RCC_OscInitStruct->MSIClockRange);
|
|
8002a04: 4bc6 ldr r3, [pc, #792] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002a06: 685b ldr r3, [r3, #4]
|
|
8002a08: 4ac6 ldr r2, [pc, #792] ; (8002d24 <HAL_RCC_OscConfig+0x684>)
|
|
8002a0a: 4013 ands r3, r2
|
|
8002a0c: 0019 movs r1, r3
|
|
8002a0e: 687b ldr r3, [r7, #4]
|
|
8002a10: 6a1a ldr r2, [r3, #32]
|
|
8002a12: 4bc3 ldr r3, [pc, #780] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002a14: 430a orrs r2, r1
|
|
8002a16: 605a str r2, [r3, #4]
|
|
/* Adjusts the Multiple Speed oscillator (MSI) calibration value.*/
|
|
__HAL_RCC_MSI_CALIBRATIONVALUE_ADJUST(RCC_OscInitStruct->MSICalibrationValue);
|
|
8002a18: 4bc1 ldr r3, [pc, #772] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002a1a: 685b ldr r3, [r3, #4]
|
|
8002a1c: 021b lsls r3, r3, #8
|
|
8002a1e: 0a19 lsrs r1, r3, #8
|
|
8002a20: 687b ldr r3, [r7, #4]
|
|
8002a22: 69db ldr r3, [r3, #28]
|
|
8002a24: 061a lsls r2, r3, #24
|
|
8002a26: 4bbe ldr r3, [pc, #760] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002a28: 430a orrs r2, r1
|
|
8002a2a: 605a str r2, [r3, #4]
|
|
8002a2c: e019 b.n 8002a62 <HAL_RCC_OscConfig+0x3c2>
|
|
}
|
|
else
|
|
{
|
|
/* Disable the Multi Speed oscillator (MSI). */
|
|
__HAL_RCC_MSI_DISABLE();
|
|
8002a2e: 4bbc ldr r3, [pc, #752] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002a30: 681a ldr r2, [r3, #0]
|
|
8002a32: 4bbb ldr r3, [pc, #748] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002a34: 49bc ldr r1, [pc, #752] ; (8002d28 <HAL_RCC_OscConfig+0x688>)
|
|
8002a36: 400a ands r2, r1
|
|
8002a38: 601a str r2, [r3, #0]
|
|
|
|
/* Get Start Tick */
|
|
tickstart = HAL_GetTick();
|
|
8002a3a: f7fe fead bl 8001798 <HAL_GetTick>
|
|
8002a3e: 0003 movs r3, r0
|
|
8002a40: 617b str r3, [r7, #20]
|
|
|
|
/* Wait till MSI is ready */
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_MSIRDY) != 0U)
|
|
8002a42: e008 b.n 8002a56 <HAL_RCC_OscConfig+0x3b6>
|
|
{
|
|
if((HAL_GetTick() - tickstart) > MSI_TIMEOUT_VALUE)
|
|
8002a44: f7fe fea8 bl 8001798 <HAL_GetTick>
|
|
8002a48: 0002 movs r2, r0
|
|
8002a4a: 697b ldr r3, [r7, #20]
|
|
8002a4c: 1ad3 subs r3, r2, r3
|
|
8002a4e: 2b02 cmp r3, #2
|
|
8002a50: d901 bls.n 8002a56 <HAL_RCC_OscConfig+0x3b6>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
8002a52: 2303 movs r3, #3
|
|
8002a54: e19a b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_MSIRDY) != 0U)
|
|
8002a56: 4bb2 ldr r3, [pc, #712] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002a58: 681a ldr r2, [r3, #0]
|
|
8002a5a: 2380 movs r3, #128 ; 0x80
|
|
8002a5c: 009b lsls r3, r3, #2
|
|
8002a5e: 4013 ands r3, r2
|
|
8002a60: d1f0 bne.n 8002a44 <HAL_RCC_OscConfig+0x3a4>
|
|
}
|
|
}
|
|
}
|
|
}
|
|
/*------------------------------ LSI Configuration -------------------------*/
|
|
if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_LSI) == RCC_OSCILLATORTYPE_LSI)
|
|
8002a62: 687b ldr r3, [r7, #4]
|
|
8002a64: 681b ldr r3, [r3, #0]
|
|
8002a66: 2208 movs r2, #8
|
|
8002a68: 4013 ands r3, r2
|
|
8002a6a: d036 beq.n 8002ada <HAL_RCC_OscConfig+0x43a>
|
|
{
|
|
/* Check the parameters */
|
|
assert_param(IS_RCC_LSI(RCC_OscInitStruct->LSIState));
|
|
|
|
/* Check the LSI State */
|
|
if(RCC_OscInitStruct->LSIState != RCC_LSI_OFF)
|
|
8002a6c: 687b ldr r3, [r7, #4]
|
|
8002a6e: 695b ldr r3, [r3, #20]
|
|
8002a70: 2b00 cmp r3, #0
|
|
8002a72: d019 beq.n 8002aa8 <HAL_RCC_OscConfig+0x408>
|
|
{
|
|
/* Enable the Internal Low Speed oscillator (LSI). */
|
|
__HAL_RCC_LSI_ENABLE();
|
|
8002a74: 4baa ldr r3, [pc, #680] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002a76: 6d1a ldr r2, [r3, #80] ; 0x50
|
|
8002a78: 4ba9 ldr r3, [pc, #676] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002a7a: 2101 movs r1, #1
|
|
8002a7c: 430a orrs r2, r1
|
|
8002a7e: 651a str r2, [r3, #80] ; 0x50
|
|
|
|
/* Get Start Tick */
|
|
tickstart = HAL_GetTick();
|
|
8002a80: f7fe fe8a bl 8001798 <HAL_GetTick>
|
|
8002a84: 0003 movs r3, r0
|
|
8002a86: 617b str r3, [r7, #20]
|
|
|
|
/* Wait till LSI is ready */
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSIRDY) == 0U)
|
|
8002a88: e008 b.n 8002a9c <HAL_RCC_OscConfig+0x3fc>
|
|
{
|
|
if((HAL_GetTick() - tickstart ) > LSI_TIMEOUT_VALUE)
|
|
8002a8a: f7fe fe85 bl 8001798 <HAL_GetTick>
|
|
8002a8e: 0002 movs r2, r0
|
|
8002a90: 697b ldr r3, [r7, #20]
|
|
8002a92: 1ad3 subs r3, r2, r3
|
|
8002a94: 2b02 cmp r3, #2
|
|
8002a96: d901 bls.n 8002a9c <HAL_RCC_OscConfig+0x3fc>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
8002a98: 2303 movs r3, #3
|
|
8002a9a: e177 b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSIRDY) == 0U)
|
|
8002a9c: 4ba0 ldr r3, [pc, #640] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002a9e: 6d1b ldr r3, [r3, #80] ; 0x50
|
|
8002aa0: 2202 movs r2, #2
|
|
8002aa2: 4013 ands r3, r2
|
|
8002aa4: d0f1 beq.n 8002a8a <HAL_RCC_OscConfig+0x3ea>
|
|
8002aa6: e018 b.n 8002ada <HAL_RCC_OscConfig+0x43a>
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* Disable the Internal Low Speed oscillator (LSI). */
|
|
__HAL_RCC_LSI_DISABLE();
|
|
8002aa8: 4b9d ldr r3, [pc, #628] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002aaa: 6d1a ldr r2, [r3, #80] ; 0x50
|
|
8002aac: 4b9c ldr r3, [pc, #624] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002aae: 2101 movs r1, #1
|
|
8002ab0: 438a bics r2, r1
|
|
8002ab2: 651a str r2, [r3, #80] ; 0x50
|
|
|
|
/* Get Start Tick */
|
|
tickstart = HAL_GetTick();
|
|
8002ab4: f7fe fe70 bl 8001798 <HAL_GetTick>
|
|
8002ab8: 0003 movs r3, r0
|
|
8002aba: 617b str r3, [r7, #20]
|
|
|
|
/* Wait till LSI is disabled */
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSIRDY) != 0U)
|
|
8002abc: e008 b.n 8002ad0 <HAL_RCC_OscConfig+0x430>
|
|
{
|
|
if((HAL_GetTick() - tickstart ) > LSI_TIMEOUT_VALUE)
|
|
8002abe: f7fe fe6b bl 8001798 <HAL_GetTick>
|
|
8002ac2: 0002 movs r2, r0
|
|
8002ac4: 697b ldr r3, [r7, #20]
|
|
8002ac6: 1ad3 subs r3, r2, r3
|
|
8002ac8: 2b02 cmp r3, #2
|
|
8002aca: d901 bls.n 8002ad0 <HAL_RCC_OscConfig+0x430>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
8002acc: 2303 movs r3, #3
|
|
8002ace: e15d b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSIRDY) != 0U)
|
|
8002ad0: 4b93 ldr r3, [pc, #588] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002ad2: 6d1b ldr r3, [r3, #80] ; 0x50
|
|
8002ad4: 2202 movs r2, #2
|
|
8002ad6: 4013 ands r3, r2
|
|
8002ad8: d1f1 bne.n 8002abe <HAL_RCC_OscConfig+0x41e>
|
|
}
|
|
}
|
|
}
|
|
}
|
|
/*------------------------------ LSE Configuration -------------------------*/
|
|
if(((RCC_OscInitStruct->OscillatorType) & RCC_OSCILLATORTYPE_LSE) == RCC_OSCILLATORTYPE_LSE)
|
|
8002ada: 687b ldr r3, [r7, #4]
|
|
8002adc: 681b ldr r3, [r3, #0]
|
|
8002ade: 2204 movs r2, #4
|
|
8002ae0: 4013 ands r3, r2
|
|
8002ae2: d100 bne.n 8002ae6 <HAL_RCC_OscConfig+0x446>
|
|
8002ae4: e0ae b.n 8002c44 <HAL_RCC_OscConfig+0x5a4>
|
|
{
|
|
FlagStatus pwrclkchanged = RESET;
|
|
8002ae6: 2023 movs r0, #35 ; 0x23
|
|
8002ae8: 183b adds r3, r7, r0
|
|
8002aea: 2200 movs r2, #0
|
|
8002aec: 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())
|
|
8002aee: 4b8c ldr r3, [pc, #560] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002af0: 6b9a ldr r2, [r3, #56] ; 0x38
|
|
8002af2: 2380 movs r3, #128 ; 0x80
|
|
8002af4: 055b lsls r3, r3, #21
|
|
8002af6: 4013 ands r3, r2
|
|
8002af8: d109 bne.n 8002b0e <HAL_RCC_OscConfig+0x46e>
|
|
{
|
|
__HAL_RCC_PWR_CLK_ENABLE();
|
|
8002afa: 4b89 ldr r3, [pc, #548] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002afc: 6b9a ldr r2, [r3, #56] ; 0x38
|
|
8002afe: 4b88 ldr r3, [pc, #544] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002b00: 2180 movs r1, #128 ; 0x80
|
|
8002b02: 0549 lsls r1, r1, #21
|
|
8002b04: 430a orrs r2, r1
|
|
8002b06: 639a str r2, [r3, #56] ; 0x38
|
|
pwrclkchanged = SET;
|
|
8002b08: 183b adds r3, r7, r0
|
|
8002b0a: 2201 movs r2, #1
|
|
8002b0c: 701a strb r2, [r3, #0]
|
|
}
|
|
|
|
if(HAL_IS_BIT_CLR(PWR->CR, PWR_CR_DBP))
|
|
8002b0e: 4b87 ldr r3, [pc, #540] ; (8002d2c <HAL_RCC_OscConfig+0x68c>)
|
|
8002b10: 681a ldr r2, [r3, #0]
|
|
8002b12: 2380 movs r3, #128 ; 0x80
|
|
8002b14: 005b lsls r3, r3, #1
|
|
8002b16: 4013 ands r3, r2
|
|
8002b18: d11a bne.n 8002b50 <HAL_RCC_OscConfig+0x4b0>
|
|
{
|
|
/* Enable write access to Backup domain */
|
|
SET_BIT(PWR->CR, PWR_CR_DBP);
|
|
8002b1a: 4b84 ldr r3, [pc, #528] ; (8002d2c <HAL_RCC_OscConfig+0x68c>)
|
|
8002b1c: 681a ldr r2, [r3, #0]
|
|
8002b1e: 4b83 ldr r3, [pc, #524] ; (8002d2c <HAL_RCC_OscConfig+0x68c>)
|
|
8002b20: 2180 movs r1, #128 ; 0x80
|
|
8002b22: 0049 lsls r1, r1, #1
|
|
8002b24: 430a orrs r2, r1
|
|
8002b26: 601a str r2, [r3, #0]
|
|
|
|
/* Wait for Backup domain Write protection disable */
|
|
tickstart = HAL_GetTick();
|
|
8002b28: f7fe fe36 bl 8001798 <HAL_GetTick>
|
|
8002b2c: 0003 movs r3, r0
|
|
8002b2e: 617b str r3, [r7, #20]
|
|
|
|
while(HAL_IS_BIT_CLR(PWR->CR, PWR_CR_DBP))
|
|
8002b30: e008 b.n 8002b44 <HAL_RCC_OscConfig+0x4a4>
|
|
{
|
|
if((HAL_GetTick() - tickstart) > RCC_DBP_TIMEOUT_VALUE)
|
|
8002b32: f7fe fe31 bl 8001798 <HAL_GetTick>
|
|
8002b36: 0002 movs r2, r0
|
|
8002b38: 697b ldr r3, [r7, #20]
|
|
8002b3a: 1ad3 subs r3, r2, r3
|
|
8002b3c: 2b64 cmp r3, #100 ; 0x64
|
|
8002b3e: d901 bls.n 8002b44 <HAL_RCC_OscConfig+0x4a4>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
8002b40: 2303 movs r3, #3
|
|
8002b42: e123 b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
while(HAL_IS_BIT_CLR(PWR->CR, PWR_CR_DBP))
|
|
8002b44: 4b79 ldr r3, [pc, #484] ; (8002d2c <HAL_RCC_OscConfig+0x68c>)
|
|
8002b46: 681a ldr r2, [r3, #0]
|
|
8002b48: 2380 movs r3, #128 ; 0x80
|
|
8002b4a: 005b lsls r3, r3, #1
|
|
8002b4c: 4013 ands r3, r2
|
|
8002b4e: d0f0 beq.n 8002b32 <HAL_RCC_OscConfig+0x492>
|
|
}
|
|
}
|
|
}
|
|
|
|
/* Set the new LSE configuration -----------------------------------------*/
|
|
__HAL_RCC_LSE_CONFIG(RCC_OscInitStruct->LSEState);
|
|
8002b50: 687b ldr r3, [r7, #4]
|
|
8002b52: 689a ldr r2, [r3, #8]
|
|
8002b54: 2380 movs r3, #128 ; 0x80
|
|
8002b56: 005b lsls r3, r3, #1
|
|
8002b58: 429a cmp r2, r3
|
|
8002b5a: d107 bne.n 8002b6c <HAL_RCC_OscConfig+0x4cc>
|
|
8002b5c: 4b70 ldr r3, [pc, #448] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002b5e: 6d1a ldr r2, [r3, #80] ; 0x50
|
|
8002b60: 4b6f ldr r3, [pc, #444] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002b62: 2180 movs r1, #128 ; 0x80
|
|
8002b64: 0049 lsls r1, r1, #1
|
|
8002b66: 430a orrs r2, r1
|
|
8002b68: 651a str r2, [r3, #80] ; 0x50
|
|
8002b6a: e031 b.n 8002bd0 <HAL_RCC_OscConfig+0x530>
|
|
8002b6c: 687b ldr r3, [r7, #4]
|
|
8002b6e: 689b ldr r3, [r3, #8]
|
|
8002b70: 2b00 cmp r3, #0
|
|
8002b72: d10c bne.n 8002b8e <HAL_RCC_OscConfig+0x4ee>
|
|
8002b74: 4b6a ldr r3, [pc, #424] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002b76: 6d1a ldr r2, [r3, #80] ; 0x50
|
|
8002b78: 4b69 ldr r3, [pc, #420] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002b7a: 496b ldr r1, [pc, #428] ; (8002d28 <HAL_RCC_OscConfig+0x688>)
|
|
8002b7c: 400a ands r2, r1
|
|
8002b7e: 651a str r2, [r3, #80] ; 0x50
|
|
8002b80: 4b67 ldr r3, [pc, #412] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002b82: 6d1a ldr r2, [r3, #80] ; 0x50
|
|
8002b84: 4b66 ldr r3, [pc, #408] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002b86: 496a ldr r1, [pc, #424] ; (8002d30 <HAL_RCC_OscConfig+0x690>)
|
|
8002b88: 400a ands r2, r1
|
|
8002b8a: 651a str r2, [r3, #80] ; 0x50
|
|
8002b8c: e020 b.n 8002bd0 <HAL_RCC_OscConfig+0x530>
|
|
8002b8e: 687b ldr r3, [r7, #4]
|
|
8002b90: 689a ldr r2, [r3, #8]
|
|
8002b92: 23a0 movs r3, #160 ; 0xa0
|
|
8002b94: 00db lsls r3, r3, #3
|
|
8002b96: 429a cmp r2, r3
|
|
8002b98: d10e bne.n 8002bb8 <HAL_RCC_OscConfig+0x518>
|
|
8002b9a: 4b61 ldr r3, [pc, #388] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002b9c: 6d1a ldr r2, [r3, #80] ; 0x50
|
|
8002b9e: 4b60 ldr r3, [pc, #384] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002ba0: 2180 movs r1, #128 ; 0x80
|
|
8002ba2: 00c9 lsls r1, r1, #3
|
|
8002ba4: 430a orrs r2, r1
|
|
8002ba6: 651a str r2, [r3, #80] ; 0x50
|
|
8002ba8: 4b5d ldr r3, [pc, #372] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002baa: 6d1a ldr r2, [r3, #80] ; 0x50
|
|
8002bac: 4b5c ldr r3, [pc, #368] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002bae: 2180 movs r1, #128 ; 0x80
|
|
8002bb0: 0049 lsls r1, r1, #1
|
|
8002bb2: 430a orrs r2, r1
|
|
8002bb4: 651a str r2, [r3, #80] ; 0x50
|
|
8002bb6: e00b b.n 8002bd0 <HAL_RCC_OscConfig+0x530>
|
|
8002bb8: 4b59 ldr r3, [pc, #356] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002bba: 6d1a ldr r2, [r3, #80] ; 0x50
|
|
8002bbc: 4b58 ldr r3, [pc, #352] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002bbe: 495a ldr r1, [pc, #360] ; (8002d28 <HAL_RCC_OscConfig+0x688>)
|
|
8002bc0: 400a ands r2, r1
|
|
8002bc2: 651a str r2, [r3, #80] ; 0x50
|
|
8002bc4: 4b56 ldr r3, [pc, #344] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002bc6: 6d1a ldr r2, [r3, #80] ; 0x50
|
|
8002bc8: 4b55 ldr r3, [pc, #340] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002bca: 4959 ldr r1, [pc, #356] ; (8002d30 <HAL_RCC_OscConfig+0x690>)
|
|
8002bcc: 400a ands r2, r1
|
|
8002bce: 651a str r2, [r3, #80] ; 0x50
|
|
|
|
/* Check the LSE State */
|
|
if(RCC_OscInitStruct->LSEState != RCC_LSE_OFF)
|
|
8002bd0: 687b ldr r3, [r7, #4]
|
|
8002bd2: 689b ldr r3, [r3, #8]
|
|
8002bd4: 2b00 cmp r3, #0
|
|
8002bd6: d015 beq.n 8002c04 <HAL_RCC_OscConfig+0x564>
|
|
{
|
|
/* Get Start Tick */
|
|
tickstart = HAL_GetTick();
|
|
8002bd8: f7fe fdde bl 8001798 <HAL_GetTick>
|
|
8002bdc: 0003 movs r3, r0
|
|
8002bde: 617b str r3, [r7, #20]
|
|
|
|
/* Wait till LSE is ready */
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) == 0U)
|
|
8002be0: e009 b.n 8002bf6 <HAL_RCC_OscConfig+0x556>
|
|
{
|
|
if((HAL_GetTick() - tickstart ) > RCC_LSE_TIMEOUT_VALUE)
|
|
8002be2: f7fe fdd9 bl 8001798 <HAL_GetTick>
|
|
8002be6: 0002 movs r2, r0
|
|
8002be8: 697b ldr r3, [r7, #20]
|
|
8002bea: 1ad3 subs r3, r2, r3
|
|
8002bec: 4a51 ldr r2, [pc, #324] ; (8002d34 <HAL_RCC_OscConfig+0x694>)
|
|
8002bee: 4293 cmp r3, r2
|
|
8002bf0: d901 bls.n 8002bf6 <HAL_RCC_OscConfig+0x556>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
8002bf2: 2303 movs r3, #3
|
|
8002bf4: e0ca b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) == 0U)
|
|
8002bf6: 4b4a ldr r3, [pc, #296] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002bf8: 6d1a ldr r2, [r3, #80] ; 0x50
|
|
8002bfa: 2380 movs r3, #128 ; 0x80
|
|
8002bfc: 009b lsls r3, r3, #2
|
|
8002bfe: 4013 ands r3, r2
|
|
8002c00: d0ef beq.n 8002be2 <HAL_RCC_OscConfig+0x542>
|
|
8002c02: e014 b.n 8002c2e <HAL_RCC_OscConfig+0x58e>
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* Get Start Tick */
|
|
tickstart = HAL_GetTick();
|
|
8002c04: f7fe fdc8 bl 8001798 <HAL_GetTick>
|
|
8002c08: 0003 movs r3, r0
|
|
8002c0a: 617b str r3, [r7, #20]
|
|
|
|
/* Wait till LSE is disabled */
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) != 0U)
|
|
8002c0c: e009 b.n 8002c22 <HAL_RCC_OscConfig+0x582>
|
|
{
|
|
if((HAL_GetTick() - tickstart ) > RCC_LSE_TIMEOUT_VALUE)
|
|
8002c0e: f7fe fdc3 bl 8001798 <HAL_GetTick>
|
|
8002c12: 0002 movs r2, r0
|
|
8002c14: 697b ldr r3, [r7, #20]
|
|
8002c16: 1ad3 subs r3, r2, r3
|
|
8002c18: 4a46 ldr r2, [pc, #280] ; (8002d34 <HAL_RCC_OscConfig+0x694>)
|
|
8002c1a: 4293 cmp r3, r2
|
|
8002c1c: d901 bls.n 8002c22 <HAL_RCC_OscConfig+0x582>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
8002c1e: 2303 movs r3, #3
|
|
8002c20: e0b4 b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) != 0U)
|
|
8002c22: 4b3f ldr r3, [pc, #252] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002c24: 6d1a ldr r2, [r3, #80] ; 0x50
|
|
8002c26: 2380 movs r3, #128 ; 0x80
|
|
8002c28: 009b lsls r3, r3, #2
|
|
8002c2a: 4013 ands r3, r2
|
|
8002c2c: d1ef bne.n 8002c0e <HAL_RCC_OscConfig+0x56e>
|
|
}
|
|
}
|
|
}
|
|
|
|
/* Require to disable power clock if necessary */
|
|
if(pwrclkchanged == SET)
|
|
8002c2e: 2323 movs r3, #35 ; 0x23
|
|
8002c30: 18fb adds r3, r7, r3
|
|
8002c32: 781b ldrb r3, [r3, #0]
|
|
8002c34: 2b01 cmp r3, #1
|
|
8002c36: d105 bne.n 8002c44 <HAL_RCC_OscConfig+0x5a4>
|
|
{
|
|
__HAL_RCC_PWR_CLK_DISABLE();
|
|
8002c38: 4b39 ldr r3, [pc, #228] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002c3a: 6b9a ldr r2, [r3, #56] ; 0x38
|
|
8002c3c: 4b38 ldr r3, [pc, #224] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002c3e: 493e ldr r1, [pc, #248] ; (8002d38 <HAL_RCC_OscConfig+0x698>)
|
|
8002c40: 400a ands r2, r1
|
|
8002c42: 639a str r2, [r3, #56] ; 0x38
|
|
#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)
|
|
8002c44: 687b ldr r3, [r7, #4]
|
|
8002c46: 6a5b ldr r3, [r3, #36] ; 0x24
|
|
8002c48: 2b00 cmp r3, #0
|
|
8002c4a: d100 bne.n 8002c4e <HAL_RCC_OscConfig+0x5ae>
|
|
8002c4c: e09d b.n 8002d8a <HAL_RCC_OscConfig+0x6ea>
|
|
{
|
|
/* Check if the PLL is used as system clock or not */
|
|
if(sysclk_source != RCC_SYSCLKSOURCE_STATUS_PLLCLK)
|
|
8002c4e: 69fb ldr r3, [r7, #28]
|
|
8002c50: 2b0c cmp r3, #12
|
|
8002c52: d100 bne.n 8002c56 <HAL_RCC_OscConfig+0x5b6>
|
|
8002c54: e076 b.n 8002d44 <HAL_RCC_OscConfig+0x6a4>
|
|
{
|
|
if((RCC_OscInitStruct->PLL.PLLState) == RCC_PLL_ON)
|
|
8002c56: 687b ldr r3, [r7, #4]
|
|
8002c58: 6a5b ldr r3, [r3, #36] ; 0x24
|
|
8002c5a: 2b02 cmp r3, #2
|
|
8002c5c: d145 bne.n 8002cea <HAL_RCC_OscConfig+0x64a>
|
|
assert_param(IS_RCC_PLLSOURCE(RCC_OscInitStruct->PLL.PLLSource));
|
|
assert_param(IS_RCC_PLL_MUL(RCC_OscInitStruct->PLL.PLLMUL));
|
|
assert_param(IS_RCC_PLL_DIV(RCC_OscInitStruct->PLL.PLLDIV));
|
|
|
|
/* Disable the main PLL. */
|
|
__HAL_RCC_PLL_DISABLE();
|
|
8002c5e: 4b30 ldr r3, [pc, #192] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002c60: 681a ldr r2, [r3, #0]
|
|
8002c62: 4b2f ldr r3, [pc, #188] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002c64: 4935 ldr r1, [pc, #212] ; (8002d3c <HAL_RCC_OscConfig+0x69c>)
|
|
8002c66: 400a ands r2, r1
|
|
8002c68: 601a str r2, [r3, #0]
|
|
|
|
/* Get Start Tick */
|
|
tickstart = HAL_GetTick();
|
|
8002c6a: f7fe fd95 bl 8001798 <HAL_GetTick>
|
|
8002c6e: 0003 movs r3, r0
|
|
8002c70: 617b str r3, [r7, #20]
|
|
|
|
/* Wait till PLL is ready */
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) != 0U)
|
|
8002c72: e008 b.n 8002c86 <HAL_RCC_OscConfig+0x5e6>
|
|
{
|
|
if((HAL_GetTick() - tickstart ) > PLL_TIMEOUT_VALUE)
|
|
8002c74: f7fe fd90 bl 8001798 <HAL_GetTick>
|
|
8002c78: 0002 movs r2, r0
|
|
8002c7a: 697b ldr r3, [r7, #20]
|
|
8002c7c: 1ad3 subs r3, r2, r3
|
|
8002c7e: 2b02 cmp r3, #2
|
|
8002c80: d901 bls.n 8002c86 <HAL_RCC_OscConfig+0x5e6>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
8002c82: 2303 movs r3, #3
|
|
8002c84: e082 b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) != 0U)
|
|
8002c86: 4b26 ldr r3, [pc, #152] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002c88: 681a ldr r2, [r3, #0]
|
|
8002c8a: 2380 movs r3, #128 ; 0x80
|
|
8002c8c: 049b lsls r3, r3, #18
|
|
8002c8e: 4013 ands r3, r2
|
|
8002c90: d1f0 bne.n 8002c74 <HAL_RCC_OscConfig+0x5d4>
|
|
}
|
|
}
|
|
|
|
/* Configure the main PLL clock source, multiplication and division factors. */
|
|
__HAL_RCC_PLL_CONFIG(RCC_OscInitStruct->PLL.PLLSource,
|
|
8002c92: 4b23 ldr r3, [pc, #140] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002c94: 68db ldr r3, [r3, #12]
|
|
8002c96: 4a2a ldr r2, [pc, #168] ; (8002d40 <HAL_RCC_OscConfig+0x6a0>)
|
|
8002c98: 4013 ands r3, r2
|
|
8002c9a: 0019 movs r1, r3
|
|
8002c9c: 687b ldr r3, [r7, #4]
|
|
8002c9e: 6a9a ldr r2, [r3, #40] ; 0x28
|
|
8002ca0: 687b ldr r3, [r7, #4]
|
|
8002ca2: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
8002ca4: 431a orrs r2, r3
|
|
8002ca6: 687b ldr r3, [r7, #4]
|
|
8002ca8: 6b1b ldr r3, [r3, #48] ; 0x30
|
|
8002caa: 431a orrs r2, r3
|
|
8002cac: 4b1c ldr r3, [pc, #112] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002cae: 430a orrs r2, r1
|
|
8002cb0: 60da str r2, [r3, #12]
|
|
RCC_OscInitStruct->PLL.PLLMUL,
|
|
RCC_OscInitStruct->PLL.PLLDIV);
|
|
/* Enable the main PLL. */
|
|
__HAL_RCC_PLL_ENABLE();
|
|
8002cb2: 4b1b ldr r3, [pc, #108] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002cb4: 681a ldr r2, [r3, #0]
|
|
8002cb6: 4b1a ldr r3, [pc, #104] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002cb8: 2180 movs r1, #128 ; 0x80
|
|
8002cba: 0449 lsls r1, r1, #17
|
|
8002cbc: 430a orrs r2, r1
|
|
8002cbe: 601a str r2, [r3, #0]
|
|
|
|
/* Get Start Tick */
|
|
tickstart = HAL_GetTick();
|
|
8002cc0: f7fe fd6a bl 8001798 <HAL_GetTick>
|
|
8002cc4: 0003 movs r3, r0
|
|
8002cc6: 617b str r3, [r7, #20]
|
|
|
|
/* Wait till PLL is ready */
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) == 0U)
|
|
8002cc8: e008 b.n 8002cdc <HAL_RCC_OscConfig+0x63c>
|
|
{
|
|
if((HAL_GetTick() - tickstart ) > PLL_TIMEOUT_VALUE)
|
|
8002cca: f7fe fd65 bl 8001798 <HAL_GetTick>
|
|
8002cce: 0002 movs r2, r0
|
|
8002cd0: 697b ldr r3, [r7, #20]
|
|
8002cd2: 1ad3 subs r3, r2, r3
|
|
8002cd4: 2b02 cmp r3, #2
|
|
8002cd6: d901 bls.n 8002cdc <HAL_RCC_OscConfig+0x63c>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
8002cd8: 2303 movs r3, #3
|
|
8002cda: e057 b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) == 0U)
|
|
8002cdc: 4b10 ldr r3, [pc, #64] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002cde: 681a ldr r2, [r3, #0]
|
|
8002ce0: 2380 movs r3, #128 ; 0x80
|
|
8002ce2: 049b lsls r3, r3, #18
|
|
8002ce4: 4013 ands r3, r2
|
|
8002ce6: d0f0 beq.n 8002cca <HAL_RCC_OscConfig+0x62a>
|
|
8002ce8: e04f b.n 8002d8a <HAL_RCC_OscConfig+0x6ea>
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* Disable the main PLL. */
|
|
__HAL_RCC_PLL_DISABLE();
|
|
8002cea: 4b0d ldr r3, [pc, #52] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002cec: 681a ldr r2, [r3, #0]
|
|
8002cee: 4b0c ldr r3, [pc, #48] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002cf0: 4912 ldr r1, [pc, #72] ; (8002d3c <HAL_RCC_OscConfig+0x69c>)
|
|
8002cf2: 400a ands r2, r1
|
|
8002cf4: 601a str r2, [r3, #0]
|
|
|
|
/* Get Start Tick */
|
|
tickstart = HAL_GetTick();
|
|
8002cf6: f7fe fd4f bl 8001798 <HAL_GetTick>
|
|
8002cfa: 0003 movs r3, r0
|
|
8002cfc: 617b str r3, [r7, #20]
|
|
|
|
/* Wait till PLL is disabled */
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) != 0U)
|
|
8002cfe: e008 b.n 8002d12 <HAL_RCC_OscConfig+0x672>
|
|
{
|
|
if((HAL_GetTick() - tickstart ) > PLL_TIMEOUT_VALUE)
|
|
8002d00: f7fe fd4a bl 8001798 <HAL_GetTick>
|
|
8002d04: 0002 movs r2, r0
|
|
8002d06: 697b ldr r3, [r7, #20]
|
|
8002d08: 1ad3 subs r3, r2, r3
|
|
8002d0a: 2b02 cmp r3, #2
|
|
8002d0c: d901 bls.n 8002d12 <HAL_RCC_OscConfig+0x672>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
8002d0e: 2303 movs r3, #3
|
|
8002d10: e03c b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) != 0U)
|
|
8002d12: 4b03 ldr r3, [pc, #12] ; (8002d20 <HAL_RCC_OscConfig+0x680>)
|
|
8002d14: 681a ldr r2, [r3, #0]
|
|
8002d16: 2380 movs r3, #128 ; 0x80
|
|
8002d18: 049b lsls r3, r3, #18
|
|
8002d1a: 4013 ands r3, r2
|
|
8002d1c: d1f0 bne.n 8002d00 <HAL_RCC_OscConfig+0x660>
|
|
8002d1e: e034 b.n 8002d8a <HAL_RCC_OscConfig+0x6ea>
|
|
8002d20: 40021000 .word 0x40021000
|
|
8002d24: ffff1fff .word 0xffff1fff
|
|
8002d28: fffffeff .word 0xfffffeff
|
|
8002d2c: 40007000 .word 0x40007000
|
|
8002d30: fffffbff .word 0xfffffbff
|
|
8002d34: 00001388 .word 0x00001388
|
|
8002d38: efffffff .word 0xefffffff
|
|
8002d3c: feffffff .word 0xfeffffff
|
|
8002d40: ff02ffff .word 0xff02ffff
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* Check if there is a request to disable the PLL used as System clock source */
|
|
if((RCC_OscInitStruct->PLL.PLLState) == RCC_PLL_OFF)
|
|
8002d44: 687b ldr r3, [r7, #4]
|
|
8002d46: 6a5b ldr r3, [r3, #36] ; 0x24
|
|
8002d48: 2b01 cmp r3, #1
|
|
8002d4a: d101 bne.n 8002d50 <HAL_RCC_OscConfig+0x6b0>
|
|
{
|
|
return HAL_ERROR;
|
|
8002d4c: 2301 movs r3, #1
|
|
8002d4e: e01d b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
}
|
|
else
|
|
{
|
|
/* Do not return HAL_ERROR if request repeats the current configuration */
|
|
pll_config = RCC->CFGR;
|
|
8002d50: 4b10 ldr r3, [pc, #64] ; (8002d94 <HAL_RCC_OscConfig+0x6f4>)
|
|
8002d52: 68db ldr r3, [r3, #12]
|
|
8002d54: 61bb str r3, [r7, #24]
|
|
if((READ_BIT(pll_config, RCC_CFGR_PLLSRC) != RCC_OscInitStruct->PLL.PLLSource) ||
|
|
8002d56: 69ba ldr r2, [r7, #24]
|
|
8002d58: 2380 movs r3, #128 ; 0x80
|
|
8002d5a: 025b lsls r3, r3, #9
|
|
8002d5c: 401a ands r2, r3
|
|
8002d5e: 687b ldr r3, [r7, #4]
|
|
8002d60: 6a9b ldr r3, [r3, #40] ; 0x28
|
|
8002d62: 429a cmp r2, r3
|
|
8002d64: d10f bne.n 8002d86 <HAL_RCC_OscConfig+0x6e6>
|
|
(READ_BIT(pll_config, RCC_CFGR_PLLMUL) != RCC_OscInitStruct->PLL.PLLMUL) ||
|
|
8002d66: 69ba ldr r2, [r7, #24]
|
|
8002d68: 23f0 movs r3, #240 ; 0xf0
|
|
8002d6a: 039b lsls r3, r3, #14
|
|
8002d6c: 401a ands r2, r3
|
|
8002d6e: 687b ldr r3, [r7, #4]
|
|
8002d70: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
if((READ_BIT(pll_config, RCC_CFGR_PLLSRC) != RCC_OscInitStruct->PLL.PLLSource) ||
|
|
8002d72: 429a cmp r2, r3
|
|
8002d74: d107 bne.n 8002d86 <HAL_RCC_OscConfig+0x6e6>
|
|
(READ_BIT(pll_config, RCC_CFGR_PLLDIV) != RCC_OscInitStruct->PLL.PLLDIV))
|
|
8002d76: 69ba ldr r2, [r7, #24]
|
|
8002d78: 23c0 movs r3, #192 ; 0xc0
|
|
8002d7a: 041b lsls r3, r3, #16
|
|
8002d7c: 401a ands r2, r3
|
|
8002d7e: 687b ldr r3, [r7, #4]
|
|
8002d80: 6b1b ldr r3, [r3, #48] ; 0x30
|
|
(READ_BIT(pll_config, RCC_CFGR_PLLMUL) != RCC_OscInitStruct->PLL.PLLMUL) ||
|
|
8002d82: 429a cmp r2, r3
|
|
8002d84: d001 beq.n 8002d8a <HAL_RCC_OscConfig+0x6ea>
|
|
{
|
|
return HAL_ERROR;
|
|
8002d86: 2301 movs r3, #1
|
|
8002d88: e000 b.n 8002d8c <HAL_RCC_OscConfig+0x6ec>
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return HAL_OK;
|
|
8002d8a: 2300 movs r3, #0
|
|
}
|
|
8002d8c: 0018 movs r0, r3
|
|
8002d8e: 46bd mov sp, r7
|
|
8002d90: b00a add sp, #40 ; 0x28
|
|
8002d92: bdb0 pop {r4, r5, r7, pc}
|
|
8002d94: 40021000 .word 0x40021000
|
|
|
|
08002d98 <HAL_RCC_ClockConfig>:
|
|
* HPRE[3:0] bits to ensure that HCLK not exceed the maximum allowed frequency
|
|
* (for more details refer to section above "Initialization/de-initialization functions")
|
|
* @retval HAL status
|
|
*/
|
|
HAL_StatusTypeDef HAL_RCC_ClockConfig(RCC_ClkInitTypeDef *RCC_ClkInitStruct, uint32_t FLatency)
|
|
{
|
|
8002d98: b5b0 push {r4, r5, r7, lr}
|
|
8002d9a: b084 sub sp, #16
|
|
8002d9c: af00 add r7, sp, #0
|
|
8002d9e: 6078 str r0, [r7, #4]
|
|
8002da0: 6039 str r1, [r7, #0]
|
|
uint32_t tickstart;
|
|
HAL_StatusTypeDef status;
|
|
|
|
/* Check Null pointer */
|
|
if(RCC_ClkInitStruct == NULL)
|
|
8002da2: 687b ldr r3, [r7, #4]
|
|
8002da4: 2b00 cmp r3, #0
|
|
8002da6: d101 bne.n 8002dac <HAL_RCC_ClockConfig+0x14>
|
|
{
|
|
return HAL_ERROR;
|
|
8002da8: 2301 movs r3, #1
|
|
8002daa: e128 b.n 8002ffe <HAL_RCC_ClockConfig+0x266>
|
|
/* To correctly read data from FLASH memory, the number of wait states (LATENCY)
|
|
must be correctly programmed according to the frequency of the CPU clock
|
|
(HCLK) and the supply voltage of the device. */
|
|
|
|
/* Increasing the number of wait states because of higher CPU frequency */
|
|
if(FLatency > __HAL_FLASH_GET_LATENCY())
|
|
8002dac: 4b96 ldr r3, [pc, #600] ; (8003008 <HAL_RCC_ClockConfig+0x270>)
|
|
8002dae: 681b ldr r3, [r3, #0]
|
|
8002db0: 2201 movs r2, #1
|
|
8002db2: 4013 ands r3, r2
|
|
8002db4: 683a ldr r2, [r7, #0]
|
|
8002db6: 429a cmp r2, r3
|
|
8002db8: d91e bls.n 8002df8 <HAL_RCC_ClockConfig+0x60>
|
|
{
|
|
/* Program the new number of wait states to the LATENCY bits in the FLASH_ACR register */
|
|
__HAL_FLASH_SET_LATENCY(FLatency);
|
|
8002dba: 4b93 ldr r3, [pc, #588] ; (8003008 <HAL_RCC_ClockConfig+0x270>)
|
|
8002dbc: 681b ldr r3, [r3, #0]
|
|
8002dbe: 2201 movs r2, #1
|
|
8002dc0: 4393 bics r3, r2
|
|
8002dc2: 0019 movs r1, r3
|
|
8002dc4: 4b90 ldr r3, [pc, #576] ; (8003008 <HAL_RCC_ClockConfig+0x270>)
|
|
8002dc6: 683a ldr r2, [r7, #0]
|
|
8002dc8: 430a orrs r2, r1
|
|
8002dca: 601a str r2, [r3, #0]
|
|
|
|
/* Check that the new number of wait states is taken into account to access the Flash
|
|
memory by polling the FLASH_ACR register */
|
|
tickstart = HAL_GetTick();
|
|
8002dcc: f7fe fce4 bl 8001798 <HAL_GetTick>
|
|
8002dd0: 0003 movs r3, r0
|
|
8002dd2: 60fb str r3, [r7, #12]
|
|
|
|
while (__HAL_FLASH_GET_LATENCY() != FLatency)
|
|
8002dd4: e009 b.n 8002dea <HAL_RCC_ClockConfig+0x52>
|
|
{
|
|
if ((HAL_GetTick() - tickstart) > CLOCKSWITCH_TIMEOUT_VALUE)
|
|
8002dd6: f7fe fcdf bl 8001798 <HAL_GetTick>
|
|
8002dda: 0002 movs r2, r0
|
|
8002ddc: 68fb ldr r3, [r7, #12]
|
|
8002dde: 1ad3 subs r3, r2, r3
|
|
8002de0: 4a8a ldr r2, [pc, #552] ; (800300c <HAL_RCC_ClockConfig+0x274>)
|
|
8002de2: 4293 cmp r3, r2
|
|
8002de4: d901 bls.n 8002dea <HAL_RCC_ClockConfig+0x52>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
8002de6: 2303 movs r3, #3
|
|
8002de8: e109 b.n 8002ffe <HAL_RCC_ClockConfig+0x266>
|
|
while (__HAL_FLASH_GET_LATENCY() != FLatency)
|
|
8002dea: 4b87 ldr r3, [pc, #540] ; (8003008 <HAL_RCC_ClockConfig+0x270>)
|
|
8002dec: 681b ldr r3, [r3, #0]
|
|
8002dee: 2201 movs r2, #1
|
|
8002df0: 4013 ands r3, r2
|
|
8002df2: 683a ldr r2, [r7, #0]
|
|
8002df4: 429a cmp r2, r3
|
|
8002df6: d1ee bne.n 8002dd6 <HAL_RCC_ClockConfig+0x3e>
|
|
}
|
|
}
|
|
}
|
|
|
|
/*-------------------------- HCLK Configuration --------------------------*/
|
|
if(((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_HCLK) == RCC_CLOCKTYPE_HCLK)
|
|
8002df8: 687b ldr r3, [r7, #4]
|
|
8002dfa: 681b ldr r3, [r3, #0]
|
|
8002dfc: 2202 movs r2, #2
|
|
8002dfe: 4013 ands r3, r2
|
|
8002e00: d009 beq.n 8002e16 <HAL_RCC_ClockConfig+0x7e>
|
|
{
|
|
assert_param(IS_RCC_HCLK(RCC_ClkInitStruct->AHBCLKDivider));
|
|
MODIFY_REG(RCC->CFGR, RCC_CFGR_HPRE, RCC_ClkInitStruct->AHBCLKDivider);
|
|
8002e02: 4b83 ldr r3, [pc, #524] ; (8003010 <HAL_RCC_ClockConfig+0x278>)
|
|
8002e04: 68db ldr r3, [r3, #12]
|
|
8002e06: 22f0 movs r2, #240 ; 0xf0
|
|
8002e08: 4393 bics r3, r2
|
|
8002e0a: 0019 movs r1, r3
|
|
8002e0c: 687b ldr r3, [r7, #4]
|
|
8002e0e: 689a ldr r2, [r3, #8]
|
|
8002e10: 4b7f ldr r3, [pc, #508] ; (8003010 <HAL_RCC_ClockConfig+0x278>)
|
|
8002e12: 430a orrs r2, r1
|
|
8002e14: 60da str r2, [r3, #12]
|
|
}
|
|
|
|
/*------------------------- SYSCLK Configuration ---------------------------*/
|
|
if(((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_SYSCLK) == RCC_CLOCKTYPE_SYSCLK)
|
|
8002e16: 687b ldr r3, [r7, #4]
|
|
8002e18: 681b ldr r3, [r3, #0]
|
|
8002e1a: 2201 movs r2, #1
|
|
8002e1c: 4013 ands r3, r2
|
|
8002e1e: d100 bne.n 8002e22 <HAL_RCC_ClockConfig+0x8a>
|
|
8002e20: e089 b.n 8002f36 <HAL_RCC_ClockConfig+0x19e>
|
|
{
|
|
assert_param(IS_RCC_SYSCLKSOURCE(RCC_ClkInitStruct->SYSCLKSource));
|
|
|
|
/* HSE is selected as System Clock Source */
|
|
if(RCC_ClkInitStruct->SYSCLKSource == RCC_SYSCLKSOURCE_HSE)
|
|
8002e22: 687b ldr r3, [r7, #4]
|
|
8002e24: 685b ldr r3, [r3, #4]
|
|
8002e26: 2b02 cmp r3, #2
|
|
8002e28: d107 bne.n 8002e3a <HAL_RCC_ClockConfig+0xa2>
|
|
{
|
|
/* Check the HSE ready flag */
|
|
if(__HAL_RCC_GET_FLAG(RCC_FLAG_HSERDY) == 0U)
|
|
8002e2a: 4b79 ldr r3, [pc, #484] ; (8003010 <HAL_RCC_ClockConfig+0x278>)
|
|
8002e2c: 681a ldr r2, [r3, #0]
|
|
8002e2e: 2380 movs r3, #128 ; 0x80
|
|
8002e30: 029b lsls r3, r3, #10
|
|
8002e32: 4013 ands r3, r2
|
|
8002e34: d120 bne.n 8002e78 <HAL_RCC_ClockConfig+0xe0>
|
|
{
|
|
return HAL_ERROR;
|
|
8002e36: 2301 movs r3, #1
|
|
8002e38: e0e1 b.n 8002ffe <HAL_RCC_ClockConfig+0x266>
|
|
}
|
|
}
|
|
/* PLL is selected as System Clock Source */
|
|
else if(RCC_ClkInitStruct->SYSCLKSource == RCC_SYSCLKSOURCE_PLLCLK)
|
|
8002e3a: 687b ldr r3, [r7, #4]
|
|
8002e3c: 685b ldr r3, [r3, #4]
|
|
8002e3e: 2b03 cmp r3, #3
|
|
8002e40: d107 bne.n 8002e52 <HAL_RCC_ClockConfig+0xba>
|
|
{
|
|
/* Check the PLL ready flag */
|
|
if(__HAL_RCC_GET_FLAG(RCC_FLAG_PLLRDY) == 0U)
|
|
8002e42: 4b73 ldr r3, [pc, #460] ; (8003010 <HAL_RCC_ClockConfig+0x278>)
|
|
8002e44: 681a ldr r2, [r3, #0]
|
|
8002e46: 2380 movs r3, #128 ; 0x80
|
|
8002e48: 049b lsls r3, r3, #18
|
|
8002e4a: 4013 ands r3, r2
|
|
8002e4c: d114 bne.n 8002e78 <HAL_RCC_ClockConfig+0xe0>
|
|
{
|
|
return HAL_ERROR;
|
|
8002e4e: 2301 movs r3, #1
|
|
8002e50: e0d5 b.n 8002ffe <HAL_RCC_ClockConfig+0x266>
|
|
}
|
|
}
|
|
/* HSI is selected as System Clock Source */
|
|
else if(RCC_ClkInitStruct->SYSCLKSource == RCC_SYSCLKSOURCE_HSI)
|
|
8002e52: 687b ldr r3, [r7, #4]
|
|
8002e54: 685b ldr r3, [r3, #4]
|
|
8002e56: 2b01 cmp r3, #1
|
|
8002e58: d106 bne.n 8002e68 <HAL_RCC_ClockConfig+0xd0>
|
|
{
|
|
/* Check the HSI ready flag */
|
|
if(__HAL_RCC_GET_FLAG(RCC_FLAG_HSIRDY) == 0U)
|
|
8002e5a: 4b6d ldr r3, [pc, #436] ; (8003010 <HAL_RCC_ClockConfig+0x278>)
|
|
8002e5c: 681b ldr r3, [r3, #0]
|
|
8002e5e: 2204 movs r2, #4
|
|
8002e60: 4013 ands r3, r2
|
|
8002e62: d109 bne.n 8002e78 <HAL_RCC_ClockConfig+0xe0>
|
|
{
|
|
return HAL_ERROR;
|
|
8002e64: 2301 movs r3, #1
|
|
8002e66: e0ca b.n 8002ffe <HAL_RCC_ClockConfig+0x266>
|
|
}
|
|
/* MSI is selected as System Clock Source */
|
|
else
|
|
{
|
|
/* Check the MSI ready flag */
|
|
if(__HAL_RCC_GET_FLAG(RCC_FLAG_MSIRDY) == 0U)
|
|
8002e68: 4b69 ldr r3, [pc, #420] ; (8003010 <HAL_RCC_ClockConfig+0x278>)
|
|
8002e6a: 681a ldr r2, [r3, #0]
|
|
8002e6c: 2380 movs r3, #128 ; 0x80
|
|
8002e6e: 009b lsls r3, r3, #2
|
|
8002e70: 4013 ands r3, r2
|
|
8002e72: d101 bne.n 8002e78 <HAL_RCC_ClockConfig+0xe0>
|
|
{
|
|
return HAL_ERROR;
|
|
8002e74: 2301 movs r3, #1
|
|
8002e76: e0c2 b.n 8002ffe <HAL_RCC_ClockConfig+0x266>
|
|
}
|
|
}
|
|
__HAL_RCC_SYSCLK_CONFIG(RCC_ClkInitStruct->SYSCLKSource);
|
|
8002e78: 4b65 ldr r3, [pc, #404] ; (8003010 <HAL_RCC_ClockConfig+0x278>)
|
|
8002e7a: 68db ldr r3, [r3, #12]
|
|
8002e7c: 2203 movs r2, #3
|
|
8002e7e: 4393 bics r3, r2
|
|
8002e80: 0019 movs r1, r3
|
|
8002e82: 687b ldr r3, [r7, #4]
|
|
8002e84: 685a ldr r2, [r3, #4]
|
|
8002e86: 4b62 ldr r3, [pc, #392] ; (8003010 <HAL_RCC_ClockConfig+0x278>)
|
|
8002e88: 430a orrs r2, r1
|
|
8002e8a: 60da str r2, [r3, #12]
|
|
|
|
/* Get Start Tick */
|
|
tickstart = HAL_GetTick();
|
|
8002e8c: f7fe fc84 bl 8001798 <HAL_GetTick>
|
|
8002e90: 0003 movs r3, r0
|
|
8002e92: 60fb str r3, [r7, #12]
|
|
|
|
if(RCC_ClkInitStruct->SYSCLKSource == RCC_SYSCLKSOURCE_HSE)
|
|
8002e94: 687b ldr r3, [r7, #4]
|
|
8002e96: 685b ldr r3, [r3, #4]
|
|
8002e98: 2b02 cmp r3, #2
|
|
8002e9a: d111 bne.n 8002ec0 <HAL_RCC_ClockConfig+0x128>
|
|
{
|
|
while (__HAL_RCC_GET_SYSCLK_SOURCE() != RCC_SYSCLKSOURCE_STATUS_HSE)
|
|
8002e9c: e009 b.n 8002eb2 <HAL_RCC_ClockConfig+0x11a>
|
|
{
|
|
if((HAL_GetTick() - tickstart ) > CLOCKSWITCH_TIMEOUT_VALUE)
|
|
8002e9e: f7fe fc7b bl 8001798 <HAL_GetTick>
|
|
8002ea2: 0002 movs r2, r0
|
|
8002ea4: 68fb ldr r3, [r7, #12]
|
|
8002ea6: 1ad3 subs r3, r2, r3
|
|
8002ea8: 4a58 ldr r2, [pc, #352] ; (800300c <HAL_RCC_ClockConfig+0x274>)
|
|
8002eaa: 4293 cmp r3, r2
|
|
8002eac: d901 bls.n 8002eb2 <HAL_RCC_ClockConfig+0x11a>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
8002eae: 2303 movs r3, #3
|
|
8002eb0: e0a5 b.n 8002ffe <HAL_RCC_ClockConfig+0x266>
|
|
while (__HAL_RCC_GET_SYSCLK_SOURCE() != RCC_SYSCLKSOURCE_STATUS_HSE)
|
|
8002eb2: 4b57 ldr r3, [pc, #348] ; (8003010 <HAL_RCC_ClockConfig+0x278>)
|
|
8002eb4: 68db ldr r3, [r3, #12]
|
|
8002eb6: 220c movs r2, #12
|
|
8002eb8: 4013 ands r3, r2
|
|
8002eba: 2b08 cmp r3, #8
|
|
8002ebc: d1ef bne.n 8002e9e <HAL_RCC_ClockConfig+0x106>
|
|
8002ebe: e03a b.n 8002f36 <HAL_RCC_ClockConfig+0x19e>
|
|
}
|
|
}
|
|
}
|
|
else if(RCC_ClkInitStruct->SYSCLKSource == RCC_SYSCLKSOURCE_PLLCLK)
|
|
8002ec0: 687b ldr r3, [r7, #4]
|
|
8002ec2: 685b ldr r3, [r3, #4]
|
|
8002ec4: 2b03 cmp r3, #3
|
|
8002ec6: d111 bne.n 8002eec <HAL_RCC_ClockConfig+0x154>
|
|
{
|
|
while (__HAL_RCC_GET_SYSCLK_SOURCE() != RCC_SYSCLKSOURCE_STATUS_PLLCLK)
|
|
8002ec8: e009 b.n 8002ede <HAL_RCC_ClockConfig+0x146>
|
|
{
|
|
if((HAL_GetTick() - tickstart ) > CLOCKSWITCH_TIMEOUT_VALUE)
|
|
8002eca: f7fe fc65 bl 8001798 <HAL_GetTick>
|
|
8002ece: 0002 movs r2, r0
|
|
8002ed0: 68fb ldr r3, [r7, #12]
|
|
8002ed2: 1ad3 subs r3, r2, r3
|
|
8002ed4: 4a4d ldr r2, [pc, #308] ; (800300c <HAL_RCC_ClockConfig+0x274>)
|
|
8002ed6: 4293 cmp r3, r2
|
|
8002ed8: d901 bls.n 8002ede <HAL_RCC_ClockConfig+0x146>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
8002eda: 2303 movs r3, #3
|
|
8002edc: e08f b.n 8002ffe <HAL_RCC_ClockConfig+0x266>
|
|
while (__HAL_RCC_GET_SYSCLK_SOURCE() != RCC_SYSCLKSOURCE_STATUS_PLLCLK)
|
|
8002ede: 4b4c ldr r3, [pc, #304] ; (8003010 <HAL_RCC_ClockConfig+0x278>)
|
|
8002ee0: 68db ldr r3, [r3, #12]
|
|
8002ee2: 220c movs r2, #12
|
|
8002ee4: 4013 ands r3, r2
|
|
8002ee6: 2b0c cmp r3, #12
|
|
8002ee8: d1ef bne.n 8002eca <HAL_RCC_ClockConfig+0x132>
|
|
8002eea: e024 b.n 8002f36 <HAL_RCC_ClockConfig+0x19e>
|
|
}
|
|
}
|
|
}
|
|
else if(RCC_ClkInitStruct->SYSCLKSource == RCC_SYSCLKSOURCE_HSI)
|
|
8002eec: 687b ldr r3, [r7, #4]
|
|
8002eee: 685b ldr r3, [r3, #4]
|
|
8002ef0: 2b01 cmp r3, #1
|
|
8002ef2: d11b bne.n 8002f2c <HAL_RCC_ClockConfig+0x194>
|
|
{
|
|
while (__HAL_RCC_GET_SYSCLK_SOURCE() != RCC_SYSCLKSOURCE_STATUS_HSI)
|
|
8002ef4: e009 b.n 8002f0a <HAL_RCC_ClockConfig+0x172>
|
|
{
|
|
if((HAL_GetTick() - tickstart ) > CLOCKSWITCH_TIMEOUT_VALUE)
|
|
8002ef6: f7fe fc4f bl 8001798 <HAL_GetTick>
|
|
8002efa: 0002 movs r2, r0
|
|
8002efc: 68fb ldr r3, [r7, #12]
|
|
8002efe: 1ad3 subs r3, r2, r3
|
|
8002f00: 4a42 ldr r2, [pc, #264] ; (800300c <HAL_RCC_ClockConfig+0x274>)
|
|
8002f02: 4293 cmp r3, r2
|
|
8002f04: d901 bls.n 8002f0a <HAL_RCC_ClockConfig+0x172>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
8002f06: 2303 movs r3, #3
|
|
8002f08: e079 b.n 8002ffe <HAL_RCC_ClockConfig+0x266>
|
|
while (__HAL_RCC_GET_SYSCLK_SOURCE() != RCC_SYSCLKSOURCE_STATUS_HSI)
|
|
8002f0a: 4b41 ldr r3, [pc, #260] ; (8003010 <HAL_RCC_ClockConfig+0x278>)
|
|
8002f0c: 68db ldr r3, [r3, #12]
|
|
8002f0e: 220c movs r2, #12
|
|
8002f10: 4013 ands r3, r2
|
|
8002f12: 2b04 cmp r3, #4
|
|
8002f14: d1ef bne.n 8002ef6 <HAL_RCC_ClockConfig+0x15e>
|
|
8002f16: e00e b.n 8002f36 <HAL_RCC_ClockConfig+0x19e>
|
|
}
|
|
else
|
|
{
|
|
while(__HAL_RCC_GET_SYSCLK_SOURCE() != RCC_SYSCLKSOURCE_STATUS_MSI)
|
|
{
|
|
if((HAL_GetTick() - tickstart ) > CLOCKSWITCH_TIMEOUT_VALUE)
|
|
8002f18: f7fe fc3e bl 8001798 <HAL_GetTick>
|
|
8002f1c: 0002 movs r2, r0
|
|
8002f1e: 68fb ldr r3, [r7, #12]
|
|
8002f20: 1ad3 subs r3, r2, r3
|
|
8002f22: 4a3a ldr r2, [pc, #232] ; (800300c <HAL_RCC_ClockConfig+0x274>)
|
|
8002f24: 4293 cmp r3, r2
|
|
8002f26: d901 bls.n 8002f2c <HAL_RCC_ClockConfig+0x194>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
8002f28: 2303 movs r3, #3
|
|
8002f2a: e068 b.n 8002ffe <HAL_RCC_ClockConfig+0x266>
|
|
while(__HAL_RCC_GET_SYSCLK_SOURCE() != RCC_SYSCLKSOURCE_STATUS_MSI)
|
|
8002f2c: 4b38 ldr r3, [pc, #224] ; (8003010 <HAL_RCC_ClockConfig+0x278>)
|
|
8002f2e: 68db ldr r3, [r3, #12]
|
|
8002f30: 220c movs r2, #12
|
|
8002f32: 4013 ands r3, r2
|
|
8002f34: d1f0 bne.n 8002f18 <HAL_RCC_ClockConfig+0x180>
|
|
}
|
|
}
|
|
}
|
|
}
|
|
/* Decreasing the number of wait states because of lower CPU frequency */
|
|
if(FLatency < __HAL_FLASH_GET_LATENCY())
|
|
8002f36: 4b34 ldr r3, [pc, #208] ; (8003008 <HAL_RCC_ClockConfig+0x270>)
|
|
8002f38: 681b ldr r3, [r3, #0]
|
|
8002f3a: 2201 movs r2, #1
|
|
8002f3c: 4013 ands r3, r2
|
|
8002f3e: 683a ldr r2, [r7, #0]
|
|
8002f40: 429a cmp r2, r3
|
|
8002f42: d21e bcs.n 8002f82 <HAL_RCC_ClockConfig+0x1ea>
|
|
{
|
|
/* Program the new number of wait states to the LATENCY bits in the FLASH_ACR register */
|
|
__HAL_FLASH_SET_LATENCY(FLatency);
|
|
8002f44: 4b30 ldr r3, [pc, #192] ; (8003008 <HAL_RCC_ClockConfig+0x270>)
|
|
8002f46: 681b ldr r3, [r3, #0]
|
|
8002f48: 2201 movs r2, #1
|
|
8002f4a: 4393 bics r3, r2
|
|
8002f4c: 0019 movs r1, r3
|
|
8002f4e: 4b2e ldr r3, [pc, #184] ; (8003008 <HAL_RCC_ClockConfig+0x270>)
|
|
8002f50: 683a ldr r2, [r7, #0]
|
|
8002f52: 430a orrs r2, r1
|
|
8002f54: 601a str r2, [r3, #0]
|
|
|
|
/* Check that the new number of wait states is taken into account to access the Flash
|
|
memory by polling the FLASH_ACR register */
|
|
tickstart = HAL_GetTick();
|
|
8002f56: f7fe fc1f bl 8001798 <HAL_GetTick>
|
|
8002f5a: 0003 movs r3, r0
|
|
8002f5c: 60fb str r3, [r7, #12]
|
|
|
|
while (__HAL_FLASH_GET_LATENCY() != FLatency)
|
|
8002f5e: e009 b.n 8002f74 <HAL_RCC_ClockConfig+0x1dc>
|
|
{
|
|
if ((HAL_GetTick() - tickstart) > CLOCKSWITCH_TIMEOUT_VALUE)
|
|
8002f60: f7fe fc1a bl 8001798 <HAL_GetTick>
|
|
8002f64: 0002 movs r2, r0
|
|
8002f66: 68fb ldr r3, [r7, #12]
|
|
8002f68: 1ad3 subs r3, r2, r3
|
|
8002f6a: 4a28 ldr r2, [pc, #160] ; (800300c <HAL_RCC_ClockConfig+0x274>)
|
|
8002f6c: 4293 cmp r3, r2
|
|
8002f6e: d901 bls.n 8002f74 <HAL_RCC_ClockConfig+0x1dc>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
8002f70: 2303 movs r3, #3
|
|
8002f72: e044 b.n 8002ffe <HAL_RCC_ClockConfig+0x266>
|
|
while (__HAL_FLASH_GET_LATENCY() != FLatency)
|
|
8002f74: 4b24 ldr r3, [pc, #144] ; (8003008 <HAL_RCC_ClockConfig+0x270>)
|
|
8002f76: 681b ldr r3, [r3, #0]
|
|
8002f78: 2201 movs r2, #1
|
|
8002f7a: 4013 ands r3, r2
|
|
8002f7c: 683a ldr r2, [r7, #0]
|
|
8002f7e: 429a cmp r2, r3
|
|
8002f80: d1ee bne.n 8002f60 <HAL_RCC_ClockConfig+0x1c8>
|
|
}
|
|
}
|
|
}
|
|
|
|
/*-------------------------- PCLK1 Configuration ---------------------------*/
|
|
if(((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_PCLK1) == RCC_CLOCKTYPE_PCLK1)
|
|
8002f82: 687b ldr r3, [r7, #4]
|
|
8002f84: 681b ldr r3, [r3, #0]
|
|
8002f86: 2204 movs r2, #4
|
|
8002f88: 4013 ands r3, r2
|
|
8002f8a: d009 beq.n 8002fa0 <HAL_RCC_ClockConfig+0x208>
|
|
{
|
|
assert_param(IS_RCC_PCLK(RCC_ClkInitStruct->APB1CLKDivider));
|
|
MODIFY_REG(RCC->CFGR, RCC_CFGR_PPRE1, RCC_ClkInitStruct->APB1CLKDivider);
|
|
8002f8c: 4b20 ldr r3, [pc, #128] ; (8003010 <HAL_RCC_ClockConfig+0x278>)
|
|
8002f8e: 68db ldr r3, [r3, #12]
|
|
8002f90: 4a20 ldr r2, [pc, #128] ; (8003014 <HAL_RCC_ClockConfig+0x27c>)
|
|
8002f92: 4013 ands r3, r2
|
|
8002f94: 0019 movs r1, r3
|
|
8002f96: 687b ldr r3, [r7, #4]
|
|
8002f98: 68da ldr r2, [r3, #12]
|
|
8002f9a: 4b1d ldr r3, [pc, #116] ; (8003010 <HAL_RCC_ClockConfig+0x278>)
|
|
8002f9c: 430a orrs r2, r1
|
|
8002f9e: 60da str r2, [r3, #12]
|
|
}
|
|
|
|
/*-------------------------- PCLK2 Configuration ---------------------------*/
|
|
if(((RCC_ClkInitStruct->ClockType) & RCC_CLOCKTYPE_PCLK2) == RCC_CLOCKTYPE_PCLK2)
|
|
8002fa0: 687b ldr r3, [r7, #4]
|
|
8002fa2: 681b ldr r3, [r3, #0]
|
|
8002fa4: 2208 movs r2, #8
|
|
8002fa6: 4013 ands r3, r2
|
|
8002fa8: d00a beq.n 8002fc0 <HAL_RCC_ClockConfig+0x228>
|
|
{
|
|
assert_param(IS_RCC_PCLK(RCC_ClkInitStruct->APB2CLKDivider));
|
|
MODIFY_REG(RCC->CFGR, RCC_CFGR_PPRE2, ((RCC_ClkInitStruct->APB2CLKDivider) << 3));
|
|
8002faa: 4b19 ldr r3, [pc, #100] ; (8003010 <HAL_RCC_ClockConfig+0x278>)
|
|
8002fac: 68db ldr r3, [r3, #12]
|
|
8002fae: 4a1a ldr r2, [pc, #104] ; (8003018 <HAL_RCC_ClockConfig+0x280>)
|
|
8002fb0: 4013 ands r3, r2
|
|
8002fb2: 0019 movs r1, r3
|
|
8002fb4: 687b ldr r3, [r7, #4]
|
|
8002fb6: 691b ldr r3, [r3, #16]
|
|
8002fb8: 00da lsls r2, r3, #3
|
|
8002fba: 4b15 ldr r3, [pc, #84] ; (8003010 <HAL_RCC_ClockConfig+0x278>)
|
|
8002fbc: 430a orrs r2, r1
|
|
8002fbe: 60da str r2, [r3, #12]
|
|
}
|
|
|
|
/* Update the SystemCoreClock global variable */
|
|
SystemCoreClock = HAL_RCC_GetSysClockFreq() >> AHBPrescTable[(RCC->CFGR & RCC_CFGR_HPRE)>> RCC_CFGR_HPRE_Pos];
|
|
8002fc0: f000 f832 bl 8003028 <HAL_RCC_GetSysClockFreq>
|
|
8002fc4: 0001 movs r1, r0
|
|
8002fc6: 4b12 ldr r3, [pc, #72] ; (8003010 <HAL_RCC_ClockConfig+0x278>)
|
|
8002fc8: 68db ldr r3, [r3, #12]
|
|
8002fca: 091b lsrs r3, r3, #4
|
|
8002fcc: 220f movs r2, #15
|
|
8002fce: 4013 ands r3, r2
|
|
8002fd0: 4a12 ldr r2, [pc, #72] ; (800301c <HAL_RCC_ClockConfig+0x284>)
|
|
8002fd2: 5cd3 ldrb r3, [r2, r3]
|
|
8002fd4: 000a movs r2, r1
|
|
8002fd6: 40da lsrs r2, r3
|
|
8002fd8: 4b11 ldr r3, [pc, #68] ; (8003020 <HAL_RCC_ClockConfig+0x288>)
|
|
8002fda: 601a str r2, [r3, #0]
|
|
|
|
/* Configure the source of time base considering new system clocks settings*/
|
|
status = HAL_InitTick(uwTickPrio);
|
|
8002fdc: 4b11 ldr r3, [pc, #68] ; (8003024 <HAL_RCC_ClockConfig+0x28c>)
|
|
8002fde: 681b ldr r3, [r3, #0]
|
|
8002fe0: 250b movs r5, #11
|
|
8002fe2: 197c adds r4, r7, r5
|
|
8002fe4: 0018 movs r0, r3
|
|
8002fe6: f7fe fb91 bl 800170c <HAL_InitTick>
|
|
8002fea: 0003 movs r3, r0
|
|
8002fec: 7023 strb r3, [r4, #0]
|
|
if(status != HAL_OK)
|
|
8002fee: 197b adds r3, r7, r5
|
|
8002ff0: 781b ldrb r3, [r3, #0]
|
|
8002ff2: 2b00 cmp r3, #0
|
|
8002ff4: d002 beq.n 8002ffc <HAL_RCC_ClockConfig+0x264>
|
|
{
|
|
return status;
|
|
8002ff6: 197b adds r3, r7, r5
|
|
8002ff8: 781b ldrb r3, [r3, #0]
|
|
8002ffa: e000 b.n 8002ffe <HAL_RCC_ClockConfig+0x266>
|
|
}
|
|
|
|
return HAL_OK;
|
|
8002ffc: 2300 movs r3, #0
|
|
}
|
|
8002ffe: 0018 movs r0, r3
|
|
8003000: 46bd mov sp, r7
|
|
8003002: b004 add sp, #16
|
|
8003004: bdb0 pop {r4, r5, r7, pc}
|
|
8003006: 46c0 nop ; (mov r8, r8)
|
|
8003008: 40022000 .word 0x40022000
|
|
800300c: 00001388 .word 0x00001388
|
|
8003010: 40021000 .word 0x40021000
|
|
8003014: fffff8ff .word 0xfffff8ff
|
|
8003018: ffffc7ff .word 0xffffc7ff
|
|
800301c: 08007884 .word 0x08007884
|
|
8003020: 20000000 .word 0x20000000
|
|
8003024: 20000004 .word 0x20000004
|
|
|
|
08003028 <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)
|
|
{
|
|
8003028: b5b0 push {r4, r5, r7, lr}
|
|
800302a: b08e sub sp, #56 ; 0x38
|
|
800302c: af00 add r7, sp, #0
|
|
uint32_t tmpreg, pllm, plld, pllvco, msiclkrange; /* no init needed */
|
|
uint32_t sysclockfreq;
|
|
|
|
tmpreg = RCC->CFGR;
|
|
800302e: 4b4c ldr r3, [pc, #304] ; (8003160 <HAL_RCC_GetSysClockFreq+0x138>)
|
|
8003030: 68db ldr r3, [r3, #12]
|
|
8003032: 62fb str r3, [r7, #44] ; 0x2c
|
|
|
|
/* Get SYSCLK source -------------------------------------------------------*/
|
|
switch (tmpreg & RCC_CFGR_SWS)
|
|
8003034: 6afa ldr r2, [r7, #44] ; 0x2c
|
|
8003036: 230c movs r3, #12
|
|
8003038: 4013 ands r3, r2
|
|
800303a: 2b0c cmp r3, #12
|
|
800303c: d014 beq.n 8003068 <HAL_RCC_GetSysClockFreq+0x40>
|
|
800303e: d900 bls.n 8003042 <HAL_RCC_GetSysClockFreq+0x1a>
|
|
8003040: e07b b.n 800313a <HAL_RCC_GetSysClockFreq+0x112>
|
|
8003042: 2b04 cmp r3, #4
|
|
8003044: d002 beq.n 800304c <HAL_RCC_GetSysClockFreq+0x24>
|
|
8003046: 2b08 cmp r3, #8
|
|
8003048: d00b beq.n 8003062 <HAL_RCC_GetSysClockFreq+0x3a>
|
|
800304a: e076 b.n 800313a <HAL_RCC_GetSysClockFreq+0x112>
|
|
{
|
|
case RCC_SYSCLKSOURCE_STATUS_HSI: /* HSI used as system clock source */
|
|
{
|
|
if ((RCC->CR & RCC_CR_HSIDIVF) != 0U)
|
|
800304c: 4b44 ldr r3, [pc, #272] ; (8003160 <HAL_RCC_GetSysClockFreq+0x138>)
|
|
800304e: 681b ldr r3, [r3, #0]
|
|
8003050: 2210 movs r2, #16
|
|
8003052: 4013 ands r3, r2
|
|
8003054: d002 beq.n 800305c <HAL_RCC_GetSysClockFreq+0x34>
|
|
{
|
|
sysclockfreq = (HSI_VALUE >> 2);
|
|
8003056: 4b43 ldr r3, [pc, #268] ; (8003164 <HAL_RCC_GetSysClockFreq+0x13c>)
|
|
8003058: 633b str r3, [r7, #48] ; 0x30
|
|
}
|
|
else
|
|
{
|
|
sysclockfreq = HSI_VALUE;
|
|
}
|
|
break;
|
|
800305a: e07c b.n 8003156 <HAL_RCC_GetSysClockFreq+0x12e>
|
|
sysclockfreq = HSI_VALUE;
|
|
800305c: 4b42 ldr r3, [pc, #264] ; (8003168 <HAL_RCC_GetSysClockFreq+0x140>)
|
|
800305e: 633b str r3, [r7, #48] ; 0x30
|
|
break;
|
|
8003060: e079 b.n 8003156 <HAL_RCC_GetSysClockFreq+0x12e>
|
|
}
|
|
case RCC_SYSCLKSOURCE_STATUS_HSE: /* HSE used as system clock */
|
|
{
|
|
sysclockfreq = HSE_VALUE;
|
|
8003062: 4b42 ldr r3, [pc, #264] ; (800316c <HAL_RCC_GetSysClockFreq+0x144>)
|
|
8003064: 633b str r3, [r7, #48] ; 0x30
|
|
break;
|
|
8003066: e076 b.n 8003156 <HAL_RCC_GetSysClockFreq+0x12e>
|
|
}
|
|
case RCC_SYSCLKSOURCE_STATUS_PLLCLK: /* PLL used as system clock */
|
|
{
|
|
pllm = PLLMulTable[(uint32_t)(tmpreg & RCC_CFGR_PLLMUL) >> RCC_CFGR_PLLMUL_Pos];
|
|
8003068: 6afb ldr r3, [r7, #44] ; 0x2c
|
|
800306a: 0c9a lsrs r2, r3, #18
|
|
800306c: 230f movs r3, #15
|
|
800306e: 401a ands r2, r3
|
|
8003070: 4b3f ldr r3, [pc, #252] ; (8003170 <HAL_RCC_GetSysClockFreq+0x148>)
|
|
8003072: 5c9b ldrb r3, [r3, r2]
|
|
8003074: 62bb str r3, [r7, #40] ; 0x28
|
|
plld = ((uint32_t)(tmpreg & RCC_CFGR_PLLDIV) >> RCC_CFGR_PLLDIV_Pos) + 1U;
|
|
8003076: 6afb ldr r3, [r7, #44] ; 0x2c
|
|
8003078: 0d9a lsrs r2, r3, #22
|
|
800307a: 2303 movs r3, #3
|
|
800307c: 4013 ands r3, r2
|
|
800307e: 3301 adds r3, #1
|
|
8003080: 627b str r3, [r7, #36] ; 0x24
|
|
if (__HAL_RCC_GET_PLL_OSCSOURCE() != RCC_PLLSOURCE_HSI)
|
|
8003082: 4b37 ldr r3, [pc, #220] ; (8003160 <HAL_RCC_GetSysClockFreq+0x138>)
|
|
8003084: 68da ldr r2, [r3, #12]
|
|
8003086: 2380 movs r3, #128 ; 0x80
|
|
8003088: 025b lsls r3, r3, #9
|
|
800308a: 4013 ands r3, r2
|
|
800308c: d01a beq.n 80030c4 <HAL_RCC_GetSysClockFreq+0x9c>
|
|
{
|
|
/* HSE used as PLL clock source */
|
|
pllvco = (uint32_t)(((uint64_t)HSE_VALUE * (uint64_t)pllm) / (uint64_t)plld);
|
|
800308e: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8003090: 61bb str r3, [r7, #24]
|
|
8003092: 2300 movs r3, #0
|
|
8003094: 61fb str r3, [r7, #28]
|
|
8003096: 4a35 ldr r2, [pc, #212] ; (800316c <HAL_RCC_GetSysClockFreq+0x144>)
|
|
8003098: 2300 movs r3, #0
|
|
800309a: 69b8 ldr r0, [r7, #24]
|
|
800309c: 69f9 ldr r1, [r7, #28]
|
|
800309e: f7fd f8df bl 8000260 <__aeabi_lmul>
|
|
80030a2: 0002 movs r2, r0
|
|
80030a4: 000b movs r3, r1
|
|
80030a6: 0010 movs r0, r2
|
|
80030a8: 0019 movs r1, r3
|
|
80030aa: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
80030ac: 613b str r3, [r7, #16]
|
|
80030ae: 2300 movs r3, #0
|
|
80030b0: 617b str r3, [r7, #20]
|
|
80030b2: 693a ldr r2, [r7, #16]
|
|
80030b4: 697b ldr r3, [r7, #20]
|
|
80030b6: f7fd f8b3 bl 8000220 <__aeabi_uldivmod>
|
|
80030ba: 0002 movs r2, r0
|
|
80030bc: 000b movs r3, r1
|
|
80030be: 0013 movs r3, r2
|
|
80030c0: 637b str r3, [r7, #52] ; 0x34
|
|
80030c2: e037 b.n 8003134 <HAL_RCC_GetSysClockFreq+0x10c>
|
|
}
|
|
else
|
|
{
|
|
if ((RCC->CR & RCC_CR_HSIDIVF) != 0U)
|
|
80030c4: 4b26 ldr r3, [pc, #152] ; (8003160 <HAL_RCC_GetSysClockFreq+0x138>)
|
|
80030c6: 681b ldr r3, [r3, #0]
|
|
80030c8: 2210 movs r2, #16
|
|
80030ca: 4013 ands r3, r2
|
|
80030cc: d01a beq.n 8003104 <HAL_RCC_GetSysClockFreq+0xdc>
|
|
{
|
|
pllvco = (uint32_t)((((uint64_t)(HSI_VALUE >> 2)) * (uint64_t)pllm) / (uint64_t)plld);
|
|
80030ce: 6abb ldr r3, [r7, #40] ; 0x28
|
|
80030d0: 60bb str r3, [r7, #8]
|
|
80030d2: 2300 movs r3, #0
|
|
80030d4: 60fb str r3, [r7, #12]
|
|
80030d6: 4a23 ldr r2, [pc, #140] ; (8003164 <HAL_RCC_GetSysClockFreq+0x13c>)
|
|
80030d8: 2300 movs r3, #0
|
|
80030da: 68b8 ldr r0, [r7, #8]
|
|
80030dc: 68f9 ldr r1, [r7, #12]
|
|
80030de: f7fd f8bf bl 8000260 <__aeabi_lmul>
|
|
80030e2: 0002 movs r2, r0
|
|
80030e4: 000b movs r3, r1
|
|
80030e6: 0010 movs r0, r2
|
|
80030e8: 0019 movs r1, r3
|
|
80030ea: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
80030ec: 603b str r3, [r7, #0]
|
|
80030ee: 2300 movs r3, #0
|
|
80030f0: 607b str r3, [r7, #4]
|
|
80030f2: 683a ldr r2, [r7, #0]
|
|
80030f4: 687b ldr r3, [r7, #4]
|
|
80030f6: f7fd f893 bl 8000220 <__aeabi_uldivmod>
|
|
80030fa: 0002 movs r2, r0
|
|
80030fc: 000b movs r3, r1
|
|
80030fe: 0013 movs r3, r2
|
|
8003100: 637b str r3, [r7, #52] ; 0x34
|
|
8003102: e017 b.n 8003134 <HAL_RCC_GetSysClockFreq+0x10c>
|
|
}
|
|
else
|
|
{
|
|
pllvco = (uint32_t)(((uint64_t)HSI_VALUE * (uint64_t)pllm) / (uint64_t)plld);
|
|
8003104: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8003106: 0018 movs r0, r3
|
|
8003108: 2300 movs r3, #0
|
|
800310a: 0019 movs r1, r3
|
|
800310c: 4a16 ldr r2, [pc, #88] ; (8003168 <HAL_RCC_GetSysClockFreq+0x140>)
|
|
800310e: 2300 movs r3, #0
|
|
8003110: f7fd f8a6 bl 8000260 <__aeabi_lmul>
|
|
8003114: 0002 movs r2, r0
|
|
8003116: 000b movs r3, r1
|
|
8003118: 0010 movs r0, r2
|
|
800311a: 0019 movs r1, r3
|
|
800311c: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
800311e: 001c movs r4, r3
|
|
8003120: 2300 movs r3, #0
|
|
8003122: 001d movs r5, r3
|
|
8003124: 0022 movs r2, r4
|
|
8003126: 002b movs r3, r5
|
|
8003128: f7fd f87a bl 8000220 <__aeabi_uldivmod>
|
|
800312c: 0002 movs r2, r0
|
|
800312e: 000b movs r3, r1
|
|
8003130: 0013 movs r3, r2
|
|
8003132: 637b str r3, [r7, #52] ; 0x34
|
|
}
|
|
}
|
|
sysclockfreq = pllvco;
|
|
8003134: 6b7b ldr r3, [r7, #52] ; 0x34
|
|
8003136: 633b str r3, [r7, #48] ; 0x30
|
|
break;
|
|
8003138: e00d b.n 8003156 <HAL_RCC_GetSysClockFreq+0x12e>
|
|
}
|
|
case RCC_SYSCLKSOURCE_STATUS_MSI: /* MSI used as system clock source */
|
|
default: /* MSI used as system clock */
|
|
{
|
|
msiclkrange = (RCC->ICSCR & RCC_ICSCR_MSIRANGE ) >> RCC_ICSCR_MSIRANGE_Pos;
|
|
800313a: 4b09 ldr r3, [pc, #36] ; (8003160 <HAL_RCC_GetSysClockFreq+0x138>)
|
|
800313c: 685b ldr r3, [r3, #4]
|
|
800313e: 0b5b lsrs r3, r3, #13
|
|
8003140: 2207 movs r2, #7
|
|
8003142: 4013 ands r3, r2
|
|
8003144: 623b str r3, [r7, #32]
|
|
sysclockfreq = (32768U * (1UL << (msiclkrange + 1U)));
|
|
8003146: 6a3b ldr r3, [r7, #32]
|
|
8003148: 3301 adds r3, #1
|
|
800314a: 2280 movs r2, #128 ; 0x80
|
|
800314c: 0212 lsls r2, r2, #8
|
|
800314e: 409a lsls r2, r3
|
|
8003150: 0013 movs r3, r2
|
|
8003152: 633b str r3, [r7, #48] ; 0x30
|
|
break;
|
|
8003154: 46c0 nop ; (mov r8, r8)
|
|
}
|
|
}
|
|
return sysclockfreq;
|
|
8003156: 6b3b ldr r3, [r7, #48] ; 0x30
|
|
}
|
|
8003158: 0018 movs r0, r3
|
|
800315a: 46bd mov sp, r7
|
|
800315c: b00e add sp, #56 ; 0x38
|
|
800315e: bdb0 pop {r4, r5, r7, pc}
|
|
8003160: 40021000 .word 0x40021000
|
|
8003164: 003d0900 .word 0x003d0900
|
|
8003168: 00f42400 .word 0x00f42400
|
|
800316c: 007a1200 .word 0x007a1200
|
|
8003170: 0800789c .word 0x0800789c
|
|
|
|
08003174 <HAL_RCC_GetHCLKFreq>:
|
|
* @note The SystemCoreClock CMSIS variable is used to store System Clock Frequency
|
|
* and updated within this function
|
|
* @retval HCLK frequency
|
|
*/
|
|
uint32_t HAL_RCC_GetHCLKFreq(void)
|
|
{
|
|
8003174: b580 push {r7, lr}
|
|
8003176: af00 add r7, sp, #0
|
|
return SystemCoreClock;
|
|
8003178: 4b02 ldr r3, [pc, #8] ; (8003184 <HAL_RCC_GetHCLKFreq+0x10>)
|
|
800317a: 681b ldr r3, [r3, #0]
|
|
}
|
|
800317c: 0018 movs r0, r3
|
|
800317e: 46bd mov sp, r7
|
|
8003180: bd80 pop {r7, pc}
|
|
8003182: 46c0 nop ; (mov r8, r8)
|
|
8003184: 20000000 .word 0x20000000
|
|
|
|
08003188 <HAL_RCC_GetPCLK1Freq>:
|
|
* @note Each time PCLK1 changes, this function must be called to update the
|
|
* right PCLK1 value. Otherwise, any configuration based on this function will be incorrect.
|
|
* @retval PCLK1 frequency
|
|
*/
|
|
uint32_t HAL_RCC_GetPCLK1Freq(void)
|
|
{
|
|
8003188: b580 push {r7, lr}
|
|
800318a: af00 add r7, sp, #0
|
|
/* Get HCLK source and Compute PCLK1 frequency ---------------------------*/
|
|
return (HAL_RCC_GetHCLKFreq() >> APBPrescTable[(RCC->CFGR & RCC_CFGR_PPRE1) >> RCC_CFGR_PPRE1_Pos]);
|
|
800318c: f7ff fff2 bl 8003174 <HAL_RCC_GetHCLKFreq>
|
|
8003190: 0001 movs r1, r0
|
|
8003192: 4b06 ldr r3, [pc, #24] ; (80031ac <HAL_RCC_GetPCLK1Freq+0x24>)
|
|
8003194: 68db ldr r3, [r3, #12]
|
|
8003196: 0a1b lsrs r3, r3, #8
|
|
8003198: 2207 movs r2, #7
|
|
800319a: 4013 ands r3, r2
|
|
800319c: 4a04 ldr r2, [pc, #16] ; (80031b0 <HAL_RCC_GetPCLK1Freq+0x28>)
|
|
800319e: 5cd3 ldrb r3, [r2, r3]
|
|
80031a0: 40d9 lsrs r1, r3
|
|
80031a2: 000b movs r3, r1
|
|
}
|
|
80031a4: 0018 movs r0, r3
|
|
80031a6: 46bd mov sp, r7
|
|
80031a8: bd80 pop {r7, pc}
|
|
80031aa: 46c0 nop ; (mov r8, r8)
|
|
80031ac: 40021000 .word 0x40021000
|
|
80031b0: 08007894 .word 0x08007894
|
|
|
|
080031b4 <HAL_RCC_GetPCLK2Freq>:
|
|
* @note Each time PCLK2 changes, this function must be called to update the
|
|
* right PCLK2 value. Otherwise, any configuration based on this function will be incorrect.
|
|
* @retval PCLK2 frequency
|
|
*/
|
|
uint32_t HAL_RCC_GetPCLK2Freq(void)
|
|
{
|
|
80031b4: b580 push {r7, lr}
|
|
80031b6: af00 add r7, sp, #0
|
|
/* Get HCLK source and Compute PCLK2 frequency ---------------------------*/
|
|
return (HAL_RCC_GetHCLKFreq()>> APBPrescTable[(RCC->CFGR & RCC_CFGR_PPRE2) >> RCC_CFGR_PPRE2_Pos]);
|
|
80031b8: f7ff ffdc bl 8003174 <HAL_RCC_GetHCLKFreq>
|
|
80031bc: 0001 movs r1, r0
|
|
80031be: 4b06 ldr r3, [pc, #24] ; (80031d8 <HAL_RCC_GetPCLK2Freq+0x24>)
|
|
80031c0: 68db ldr r3, [r3, #12]
|
|
80031c2: 0adb lsrs r3, r3, #11
|
|
80031c4: 2207 movs r2, #7
|
|
80031c6: 4013 ands r3, r2
|
|
80031c8: 4a04 ldr r2, [pc, #16] ; (80031dc <HAL_RCC_GetPCLK2Freq+0x28>)
|
|
80031ca: 5cd3 ldrb r3, [r2, r3]
|
|
80031cc: 40d9 lsrs r1, r3
|
|
80031ce: 000b movs r3, r1
|
|
}
|
|
80031d0: 0018 movs r0, r3
|
|
80031d2: 46bd mov sp, r7
|
|
80031d4: bd80 pop {r7, pc}
|
|
80031d6: 46c0 nop ; (mov r8, r8)
|
|
80031d8: 40021000 .word 0x40021000
|
|
80031dc: 08007894 .word 0x08007894
|
|
|
|
080031e0 <HAL_RCCEx_PeriphCLKConfig>:
|
|
* @retval HAL status
|
|
* @note If HAL_ERROR returned, first switch-OFF HSE clock oscillator with @ref HAL_RCC_OscConfig()
|
|
* to possibly update HSE divider.
|
|
*/
|
|
HAL_StatusTypeDef HAL_RCCEx_PeriphCLKConfig(RCC_PeriphCLKInitTypeDef *PeriphClkInit)
|
|
{
|
|
80031e0: b580 push {r7, lr}
|
|
80031e2: b086 sub sp, #24
|
|
80031e4: af00 add r7, sp, #0
|
|
80031e6: 6078 str r0, [r7, #4]
|
|
uint32_t tickstart;
|
|
uint32_t temp_reg;
|
|
FlagStatus pwrclkchanged = RESET;
|
|
80031e8: 2017 movs r0, #23
|
|
80031ea: 183b adds r3, r7, r0
|
|
80031ec: 2200 movs r2, #0
|
|
80031ee: 701a strb r2, [r3, #0]
|
|
|
|
/* Check the parameters */
|
|
assert_param(IS_RCC_PERIPHCLOCK(PeriphClkInit->PeriphClockSelection));
|
|
|
|
/*------------------------------- RTC/LCD Configuration ------------------------*/
|
|
if ((((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_RTC) == RCC_PERIPHCLK_RTC)
|
|
80031f0: 687b ldr r3, [r7, #4]
|
|
80031f2: 681b ldr r3, [r3, #0]
|
|
80031f4: 2220 movs r2, #32
|
|
80031f6: 4013 ands r3, r2
|
|
80031f8: d100 bne.n 80031fc <HAL_RCCEx_PeriphCLKConfig+0x1c>
|
|
80031fa: e0c2 b.n 8003382 <HAL_RCCEx_PeriphCLKConfig+0x1a2>
|
|
#endif /* LCD */
|
|
|
|
/* 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())
|
|
80031fc: 4b81 ldr r3, [pc, #516] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
80031fe: 6b9a ldr r2, [r3, #56] ; 0x38
|
|
8003200: 2380 movs r3, #128 ; 0x80
|
|
8003202: 055b lsls r3, r3, #21
|
|
8003204: 4013 ands r3, r2
|
|
8003206: d109 bne.n 800321c <HAL_RCCEx_PeriphCLKConfig+0x3c>
|
|
{
|
|
__HAL_RCC_PWR_CLK_ENABLE();
|
|
8003208: 4b7e ldr r3, [pc, #504] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
800320a: 6b9a ldr r2, [r3, #56] ; 0x38
|
|
800320c: 4b7d ldr r3, [pc, #500] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
800320e: 2180 movs r1, #128 ; 0x80
|
|
8003210: 0549 lsls r1, r1, #21
|
|
8003212: 430a orrs r2, r1
|
|
8003214: 639a str r2, [r3, #56] ; 0x38
|
|
pwrclkchanged = SET;
|
|
8003216: 183b adds r3, r7, r0
|
|
8003218: 2201 movs r2, #1
|
|
800321a: 701a strb r2, [r3, #0]
|
|
}
|
|
|
|
if(HAL_IS_BIT_CLR(PWR->CR, PWR_CR_DBP))
|
|
800321c: 4b7a ldr r3, [pc, #488] ; (8003408 <HAL_RCCEx_PeriphCLKConfig+0x228>)
|
|
800321e: 681a ldr r2, [r3, #0]
|
|
8003220: 2380 movs r3, #128 ; 0x80
|
|
8003222: 005b lsls r3, r3, #1
|
|
8003224: 4013 ands r3, r2
|
|
8003226: d11a bne.n 800325e <HAL_RCCEx_PeriphCLKConfig+0x7e>
|
|
{
|
|
/* Enable write access to Backup domain */
|
|
SET_BIT(PWR->CR, PWR_CR_DBP);
|
|
8003228: 4b77 ldr r3, [pc, #476] ; (8003408 <HAL_RCCEx_PeriphCLKConfig+0x228>)
|
|
800322a: 681a ldr r2, [r3, #0]
|
|
800322c: 4b76 ldr r3, [pc, #472] ; (8003408 <HAL_RCCEx_PeriphCLKConfig+0x228>)
|
|
800322e: 2180 movs r1, #128 ; 0x80
|
|
8003230: 0049 lsls r1, r1, #1
|
|
8003232: 430a orrs r2, r1
|
|
8003234: 601a str r2, [r3, #0]
|
|
|
|
/* Wait for Backup domain Write protection disable */
|
|
tickstart = HAL_GetTick();
|
|
8003236: f7fe faaf bl 8001798 <HAL_GetTick>
|
|
800323a: 0003 movs r3, r0
|
|
800323c: 613b str r3, [r7, #16]
|
|
|
|
while(HAL_IS_BIT_CLR(PWR->CR, PWR_CR_DBP))
|
|
800323e: e008 b.n 8003252 <HAL_RCCEx_PeriphCLKConfig+0x72>
|
|
{
|
|
if((HAL_GetTick() - tickstart) > RCC_DBP_TIMEOUT_VALUE)
|
|
8003240: f7fe faaa bl 8001798 <HAL_GetTick>
|
|
8003244: 0002 movs r2, r0
|
|
8003246: 693b ldr r3, [r7, #16]
|
|
8003248: 1ad3 subs r3, r2, r3
|
|
800324a: 2b64 cmp r3, #100 ; 0x64
|
|
800324c: d901 bls.n 8003252 <HAL_RCCEx_PeriphCLKConfig+0x72>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
800324e: 2303 movs r3, #3
|
|
8003250: e0d4 b.n 80033fc <HAL_RCCEx_PeriphCLKConfig+0x21c>
|
|
while(HAL_IS_BIT_CLR(PWR->CR, PWR_CR_DBP))
|
|
8003252: 4b6d ldr r3, [pc, #436] ; (8003408 <HAL_RCCEx_PeriphCLKConfig+0x228>)
|
|
8003254: 681a ldr r2, [r3, #0]
|
|
8003256: 2380 movs r3, #128 ; 0x80
|
|
8003258: 005b lsls r3, r3, #1
|
|
800325a: 4013 ands r3, r2
|
|
800325c: d0f0 beq.n 8003240 <HAL_RCCEx_PeriphCLKConfig+0x60>
|
|
}
|
|
}
|
|
}
|
|
|
|
/* Check if user wants to change HSE RTC prescaler whereas HSE is enabled */
|
|
temp_reg = (RCC->CR & RCC_CR_RTCPRE);
|
|
800325e: 4b69 ldr r3, [pc, #420] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
8003260: 681a ldr r2, [r3, #0]
|
|
8003262: 23c0 movs r3, #192 ; 0xc0
|
|
8003264: 039b lsls r3, r3, #14
|
|
8003266: 4013 ands r3, r2
|
|
8003268: 60fb str r3, [r7, #12]
|
|
if ((temp_reg != (PeriphClkInit->RTCClockSelection & RCC_CR_RTCPRE))
|
|
800326a: 687b ldr r3, [r7, #4]
|
|
800326c: 685a ldr r2, [r3, #4]
|
|
800326e: 23c0 movs r3, #192 ; 0xc0
|
|
8003270: 039b lsls r3, r3, #14
|
|
8003272: 4013 ands r3, r2
|
|
8003274: 68fa ldr r2, [r7, #12]
|
|
8003276: 429a cmp r2, r3
|
|
8003278: d013 beq.n 80032a2 <HAL_RCCEx_PeriphCLKConfig+0xc2>
|
|
#if defined (LCD)
|
|
|| (temp_reg != (PeriphClkInit->LCDClockSelection & RCC_CR_RTCPRE))
|
|
#endif /* LCD */
|
|
)
|
|
{ /* Check HSE State */
|
|
if ((PeriphClkInit->RTCClockSelection & RCC_CSR_RTCSEL) == RCC_CSR_RTCSEL_HSE)
|
|
800327a: 687b ldr r3, [r7, #4]
|
|
800327c: 685a ldr r2, [r3, #4]
|
|
800327e: 23c0 movs r3, #192 ; 0xc0
|
|
8003280: 029b lsls r3, r3, #10
|
|
8003282: 401a ands r2, r3
|
|
8003284: 23c0 movs r3, #192 ; 0xc0
|
|
8003286: 029b lsls r3, r3, #10
|
|
8003288: 429a cmp r2, r3
|
|
800328a: d10a bne.n 80032a2 <HAL_RCCEx_PeriphCLKConfig+0xc2>
|
|
{
|
|
if (HAL_IS_BIT_SET(RCC->CR, RCC_CR_HSERDY))
|
|
800328c: 4b5d ldr r3, [pc, #372] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
800328e: 681a ldr r2, [r3, #0]
|
|
8003290: 2380 movs r3, #128 ; 0x80
|
|
8003292: 029b lsls r3, r3, #10
|
|
8003294: 401a ands r2, r3
|
|
8003296: 2380 movs r3, #128 ; 0x80
|
|
8003298: 029b lsls r3, r3, #10
|
|
800329a: 429a cmp r2, r3
|
|
800329c: d101 bne.n 80032a2 <HAL_RCCEx_PeriphCLKConfig+0xc2>
|
|
{
|
|
/* To update HSE divider, first switch-OFF HSE clock oscillator*/
|
|
return HAL_ERROR;
|
|
800329e: 2301 movs r3, #1
|
|
80032a0: e0ac b.n 80033fc <HAL_RCCEx_PeriphCLKConfig+0x21c>
|
|
}
|
|
}
|
|
}
|
|
|
|
/* Reset the Backup domain only if the RTC Clock source selection is modified from reset value */
|
|
temp_reg = (RCC->CSR & RCC_CSR_RTCSEL);
|
|
80032a2: 4b58 ldr r3, [pc, #352] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
80032a4: 6d1a ldr r2, [r3, #80] ; 0x50
|
|
80032a6: 23c0 movs r3, #192 ; 0xc0
|
|
80032a8: 029b lsls r3, r3, #10
|
|
80032aa: 4013 ands r3, r2
|
|
80032ac: 60fb str r3, [r7, #12]
|
|
|
|
if((temp_reg != 0x00000000U) && (((temp_reg != (PeriphClkInit->RTCClockSelection & RCC_CSR_RTCSEL)) \
|
|
80032ae: 68fb ldr r3, [r7, #12]
|
|
80032b0: 2b00 cmp r3, #0
|
|
80032b2: d03b beq.n 800332c <HAL_RCCEx_PeriphCLKConfig+0x14c>
|
|
80032b4: 687b ldr r3, [r7, #4]
|
|
80032b6: 685a ldr r2, [r3, #4]
|
|
80032b8: 23c0 movs r3, #192 ; 0xc0
|
|
80032ba: 029b lsls r3, r3, #10
|
|
80032bc: 4013 ands r3, r2
|
|
80032be: 68fa ldr r2, [r7, #12]
|
|
80032c0: 429a cmp r2, r3
|
|
80032c2: d033 beq.n 800332c <HAL_RCCEx_PeriphCLKConfig+0x14c>
|
|
&& (((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_RTC) == RCC_PERIPHCLK_RTC))
|
|
80032c4: 687b ldr r3, [r7, #4]
|
|
80032c6: 681b ldr r3, [r3, #0]
|
|
80032c8: 2220 movs r2, #32
|
|
80032ca: 4013 ands r3, r2
|
|
80032cc: d02e beq.n 800332c <HAL_RCCEx_PeriphCLKConfig+0x14c>
|
|
&& (((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_LCD) == RCC_PERIPHCLK_LCD))
|
|
#endif /* LCD */
|
|
))
|
|
{
|
|
/* Store the content of CSR register before the reset of Backup Domain */
|
|
temp_reg = (RCC->CSR & ~(RCC_CSR_RTCSEL));
|
|
80032ce: 4b4d ldr r3, [pc, #308] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
80032d0: 6d1b ldr r3, [r3, #80] ; 0x50
|
|
80032d2: 4a4e ldr r2, [pc, #312] ; (800340c <HAL_RCCEx_PeriphCLKConfig+0x22c>)
|
|
80032d4: 4013 ands r3, r2
|
|
80032d6: 60fb str r3, [r7, #12]
|
|
|
|
/* RTC Clock selection can be changed only if the Backup Domain is reset */
|
|
__HAL_RCC_BACKUPRESET_FORCE();
|
|
80032d8: 4b4a ldr r3, [pc, #296] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
80032da: 6d1a ldr r2, [r3, #80] ; 0x50
|
|
80032dc: 4b49 ldr r3, [pc, #292] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
80032de: 2180 movs r1, #128 ; 0x80
|
|
80032e0: 0309 lsls r1, r1, #12
|
|
80032e2: 430a orrs r2, r1
|
|
80032e4: 651a str r2, [r3, #80] ; 0x50
|
|
__HAL_RCC_BACKUPRESET_RELEASE();
|
|
80032e6: 4b47 ldr r3, [pc, #284] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
80032e8: 6d1a ldr r2, [r3, #80] ; 0x50
|
|
80032ea: 4b46 ldr r3, [pc, #280] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
80032ec: 4948 ldr r1, [pc, #288] ; (8003410 <HAL_RCCEx_PeriphCLKConfig+0x230>)
|
|
80032ee: 400a ands r2, r1
|
|
80032f0: 651a str r2, [r3, #80] ; 0x50
|
|
|
|
/* Restore the Content of CSR register */
|
|
RCC->CSR = temp_reg;
|
|
80032f2: 4b44 ldr r3, [pc, #272] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
80032f4: 68fa ldr r2, [r7, #12]
|
|
80032f6: 651a str r2, [r3, #80] ; 0x50
|
|
|
|
/* Wait for LSERDY if LSE was enabled */
|
|
if (HAL_IS_BIT_SET(temp_reg, RCC_CSR_LSEON))
|
|
80032f8: 68fa ldr r2, [r7, #12]
|
|
80032fa: 2380 movs r3, #128 ; 0x80
|
|
80032fc: 005b lsls r3, r3, #1
|
|
80032fe: 4013 ands r3, r2
|
|
8003300: d014 beq.n 800332c <HAL_RCCEx_PeriphCLKConfig+0x14c>
|
|
{
|
|
/* Get Start Tick */
|
|
tickstart = HAL_GetTick();
|
|
8003302: f7fe fa49 bl 8001798 <HAL_GetTick>
|
|
8003306: 0003 movs r3, r0
|
|
8003308: 613b str r3, [r7, #16]
|
|
|
|
/* Wait till LSE is ready */
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) == 0U)
|
|
800330a: e009 b.n 8003320 <HAL_RCCEx_PeriphCLKConfig+0x140>
|
|
{
|
|
if((HAL_GetTick() - tickstart ) > RCC_LSE_TIMEOUT_VALUE)
|
|
800330c: f7fe fa44 bl 8001798 <HAL_GetTick>
|
|
8003310: 0002 movs r2, r0
|
|
8003312: 693b ldr r3, [r7, #16]
|
|
8003314: 1ad3 subs r3, r2, r3
|
|
8003316: 4a3f ldr r2, [pc, #252] ; (8003414 <HAL_RCCEx_PeriphCLKConfig+0x234>)
|
|
8003318: 4293 cmp r3, r2
|
|
800331a: d901 bls.n 8003320 <HAL_RCCEx_PeriphCLKConfig+0x140>
|
|
{
|
|
return HAL_TIMEOUT;
|
|
800331c: 2303 movs r3, #3
|
|
800331e: e06d b.n 80033fc <HAL_RCCEx_PeriphCLKConfig+0x21c>
|
|
while(__HAL_RCC_GET_FLAG(RCC_FLAG_LSERDY) == 0U)
|
|
8003320: 4b38 ldr r3, [pc, #224] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
8003322: 6d1a ldr r2, [r3, #80] ; 0x50
|
|
8003324: 2380 movs r3, #128 ; 0x80
|
|
8003326: 009b lsls r3, r3, #2
|
|
8003328: 4013 ands r3, r2
|
|
800332a: d0ef beq.n 800330c <HAL_RCCEx_PeriphCLKConfig+0x12c>
|
|
}
|
|
}
|
|
}
|
|
}
|
|
__HAL_RCC_RTC_CONFIG(PeriphClkInit->RTCClockSelection);
|
|
800332c: 687b ldr r3, [r7, #4]
|
|
800332e: 685a ldr r2, [r3, #4]
|
|
8003330: 23c0 movs r3, #192 ; 0xc0
|
|
8003332: 029b lsls r3, r3, #10
|
|
8003334: 401a ands r2, r3
|
|
8003336: 23c0 movs r3, #192 ; 0xc0
|
|
8003338: 029b lsls r3, r3, #10
|
|
800333a: 429a cmp r2, r3
|
|
800333c: d10c bne.n 8003358 <HAL_RCCEx_PeriphCLKConfig+0x178>
|
|
800333e: 4b31 ldr r3, [pc, #196] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
8003340: 681b ldr r3, [r3, #0]
|
|
8003342: 4a35 ldr r2, [pc, #212] ; (8003418 <HAL_RCCEx_PeriphCLKConfig+0x238>)
|
|
8003344: 4013 ands r3, r2
|
|
8003346: 0019 movs r1, r3
|
|
8003348: 687b ldr r3, [r7, #4]
|
|
800334a: 685a ldr r2, [r3, #4]
|
|
800334c: 23c0 movs r3, #192 ; 0xc0
|
|
800334e: 039b lsls r3, r3, #14
|
|
8003350: 401a ands r2, r3
|
|
8003352: 4b2c ldr r3, [pc, #176] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
8003354: 430a orrs r2, r1
|
|
8003356: 601a str r2, [r3, #0]
|
|
8003358: 4b2a ldr r3, [pc, #168] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
800335a: 6d19 ldr r1, [r3, #80] ; 0x50
|
|
800335c: 687b ldr r3, [r7, #4]
|
|
800335e: 685a ldr r2, [r3, #4]
|
|
8003360: 23c0 movs r3, #192 ; 0xc0
|
|
8003362: 029b lsls r3, r3, #10
|
|
8003364: 401a ands r2, r3
|
|
8003366: 4b27 ldr r3, [pc, #156] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
8003368: 430a orrs r2, r1
|
|
800336a: 651a str r2, [r3, #80] ; 0x50
|
|
|
|
/* Require to disable power clock if necessary */
|
|
if(pwrclkchanged == SET)
|
|
800336c: 2317 movs r3, #23
|
|
800336e: 18fb adds r3, r7, r3
|
|
8003370: 781b ldrb r3, [r3, #0]
|
|
8003372: 2b01 cmp r3, #1
|
|
8003374: d105 bne.n 8003382 <HAL_RCCEx_PeriphCLKConfig+0x1a2>
|
|
{
|
|
__HAL_RCC_PWR_CLK_DISABLE();
|
|
8003376: 4b23 ldr r3, [pc, #140] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
8003378: 6b9a ldr r2, [r3, #56] ; 0x38
|
|
800337a: 4b22 ldr r3, [pc, #136] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
800337c: 4927 ldr r1, [pc, #156] ; (800341c <HAL_RCCEx_PeriphCLKConfig+0x23c>)
|
|
800337e: 400a ands r2, r1
|
|
8003380: 639a str r2, [r3, #56] ; 0x38
|
|
__HAL_RCC_USART1_CONFIG(PeriphClkInit->Usart1ClockSelection);
|
|
}
|
|
#endif /* RCC_CCIPR_USART1SEL */
|
|
|
|
/*----------------------------- USART2 Configuration --------------------------*/
|
|
if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_USART2) == RCC_PERIPHCLK_USART2)
|
|
8003382: 687b ldr r3, [r7, #4]
|
|
8003384: 681b ldr r3, [r3, #0]
|
|
8003386: 2202 movs r2, #2
|
|
8003388: 4013 ands r3, r2
|
|
800338a: d009 beq.n 80033a0 <HAL_RCCEx_PeriphCLKConfig+0x1c0>
|
|
{
|
|
/* Check the parameters */
|
|
assert_param(IS_RCC_USART2CLKSOURCE(PeriphClkInit->Usart2ClockSelection));
|
|
|
|
/* Configure the USART2 clock source */
|
|
__HAL_RCC_USART2_CONFIG(PeriphClkInit->Usart2ClockSelection);
|
|
800338c: 4b1d ldr r3, [pc, #116] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
800338e: 6cdb ldr r3, [r3, #76] ; 0x4c
|
|
8003390: 220c movs r2, #12
|
|
8003392: 4393 bics r3, r2
|
|
8003394: 0019 movs r1, r3
|
|
8003396: 687b ldr r3, [r7, #4]
|
|
8003398: 689a ldr r2, [r3, #8]
|
|
800339a: 4b1a ldr r3, [pc, #104] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
800339c: 430a orrs r2, r1
|
|
800339e: 64da str r2, [r3, #76] ; 0x4c
|
|
}
|
|
|
|
/*------------------------------ LPUART1 Configuration ------------------------*/
|
|
if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_LPUART1) == RCC_PERIPHCLK_LPUART1)
|
|
80033a0: 687b ldr r3, [r7, #4]
|
|
80033a2: 681b ldr r3, [r3, #0]
|
|
80033a4: 2204 movs r2, #4
|
|
80033a6: 4013 ands r3, r2
|
|
80033a8: d009 beq.n 80033be <HAL_RCCEx_PeriphCLKConfig+0x1de>
|
|
{
|
|
/* Check the parameters */
|
|
assert_param(IS_RCC_LPUART1CLKSOURCE(PeriphClkInit->Lpuart1ClockSelection));
|
|
|
|
/* Configure the LPUAR1 clock source */
|
|
__HAL_RCC_LPUART1_CONFIG(PeriphClkInit->Lpuart1ClockSelection);
|
|
80033aa: 4b16 ldr r3, [pc, #88] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
80033ac: 6cdb ldr r3, [r3, #76] ; 0x4c
|
|
80033ae: 4a1c ldr r2, [pc, #112] ; (8003420 <HAL_RCCEx_PeriphCLKConfig+0x240>)
|
|
80033b0: 4013 ands r3, r2
|
|
80033b2: 0019 movs r1, r3
|
|
80033b4: 687b ldr r3, [r7, #4]
|
|
80033b6: 68da ldr r2, [r3, #12]
|
|
80033b8: 4b12 ldr r3, [pc, #72] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
80033ba: 430a orrs r2, r1
|
|
80033bc: 64da str r2, [r3, #76] ; 0x4c
|
|
}
|
|
|
|
/*------------------------------ I2C1 Configuration ------------------------*/
|
|
if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_I2C1) == RCC_PERIPHCLK_I2C1)
|
|
80033be: 687b ldr r3, [r7, #4]
|
|
80033c0: 681b ldr r3, [r3, #0]
|
|
80033c2: 2208 movs r2, #8
|
|
80033c4: 4013 ands r3, r2
|
|
80033c6: d009 beq.n 80033dc <HAL_RCCEx_PeriphCLKConfig+0x1fc>
|
|
{
|
|
/* Check the parameters */
|
|
assert_param(IS_RCC_I2C1CLKSOURCE(PeriphClkInit->I2c1ClockSelection));
|
|
|
|
/* Configure the I2C1 clock source */
|
|
__HAL_RCC_I2C1_CONFIG(PeriphClkInit->I2c1ClockSelection);
|
|
80033c8: 4b0e ldr r3, [pc, #56] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
80033ca: 6cdb ldr r3, [r3, #76] ; 0x4c
|
|
80033cc: 4a15 ldr r2, [pc, #84] ; (8003424 <HAL_RCCEx_PeriphCLKConfig+0x244>)
|
|
80033ce: 4013 ands r3, r2
|
|
80033d0: 0019 movs r1, r3
|
|
80033d2: 687b ldr r3, [r7, #4]
|
|
80033d4: 691a ldr r2, [r3, #16]
|
|
80033d6: 4b0b ldr r3, [pc, #44] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
80033d8: 430a orrs r2, r1
|
|
80033da: 64da str r2, [r3, #76] ; 0x4c
|
|
__HAL_RCC_USB_CONFIG(PeriphClkInit->UsbClockSelection);
|
|
}
|
|
#endif /* USB */
|
|
|
|
/*---------------------------- LPTIM1 configuration ------------------------*/
|
|
if(((PeriphClkInit->PeriphClockSelection) & RCC_PERIPHCLK_LPTIM1) == (RCC_PERIPHCLK_LPTIM1))
|
|
80033dc: 687b ldr r3, [r7, #4]
|
|
80033de: 681b ldr r3, [r3, #0]
|
|
80033e0: 2280 movs r2, #128 ; 0x80
|
|
80033e2: 4013 ands r3, r2
|
|
80033e4: d009 beq.n 80033fa <HAL_RCCEx_PeriphCLKConfig+0x21a>
|
|
{
|
|
assert_param(IS_RCC_LPTIMCLK(PeriphClkInit->LptimClockSelection));
|
|
__HAL_RCC_LPTIM1_CONFIG(PeriphClkInit->LptimClockSelection);
|
|
80033e6: 4b07 ldr r3, [pc, #28] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
80033e8: 6cdb ldr r3, [r3, #76] ; 0x4c
|
|
80033ea: 4a0f ldr r2, [pc, #60] ; (8003428 <HAL_RCCEx_PeriphCLKConfig+0x248>)
|
|
80033ec: 4013 ands r3, r2
|
|
80033ee: 0019 movs r1, r3
|
|
80033f0: 687b ldr r3, [r7, #4]
|
|
80033f2: 695a ldr r2, [r3, #20]
|
|
80033f4: 4b03 ldr r3, [pc, #12] ; (8003404 <HAL_RCCEx_PeriphCLKConfig+0x224>)
|
|
80033f6: 430a orrs r2, r1
|
|
80033f8: 64da str r2, [r3, #76] ; 0x4c
|
|
}
|
|
|
|
return HAL_OK;
|
|
80033fa: 2300 movs r3, #0
|
|
}
|
|
80033fc: 0018 movs r0, r3
|
|
80033fe: 46bd mov sp, r7
|
|
8003400: b006 add sp, #24
|
|
8003402: bd80 pop {r7, pc}
|
|
8003404: 40021000 .word 0x40021000
|
|
8003408: 40007000 .word 0x40007000
|
|
800340c: fffcffff .word 0xfffcffff
|
|
8003410: fff7ffff .word 0xfff7ffff
|
|
8003414: 00001388 .word 0x00001388
|
|
8003418: ffcfffff .word 0xffcfffff
|
|
800341c: efffffff .word 0xefffffff
|
|
8003420: fffff3ff .word 0xfffff3ff
|
|
8003424: ffffcfff .word 0xffffcfff
|
|
8003428: fff3ffff .word 0xfff3ffff
|
|
|
|
0800342c <HAL_TIM_Base_Init>:
|
|
* Ex: call @ref HAL_TIM_Base_DeInit() before HAL_TIM_Base_Init()
|
|
* @param htim TIM Base handle
|
|
* @retval HAL status
|
|
*/
|
|
HAL_StatusTypeDef HAL_TIM_Base_Init(TIM_HandleTypeDef *htim)
|
|
{
|
|
800342c: b580 push {r7, lr}
|
|
800342e: b082 sub sp, #8
|
|
8003430: af00 add r7, sp, #0
|
|
8003432: 6078 str r0, [r7, #4]
|
|
/* Check the TIM handle allocation */
|
|
if (htim == NULL)
|
|
8003434: 687b ldr r3, [r7, #4]
|
|
8003436: 2b00 cmp r3, #0
|
|
8003438: d101 bne.n 800343e <HAL_TIM_Base_Init+0x12>
|
|
{
|
|
return HAL_ERROR;
|
|
800343a: 2301 movs r3, #1
|
|
800343c: e032 b.n 80034a4 <HAL_TIM_Base_Init+0x78>
|
|
assert_param(IS_TIM_CLOCKDIVISION_DIV(htim->Init.ClockDivision));
|
|
assert_param(IS_TIM_PERIOD(htim->Init.Period));
|
|
assert_param(IS_TIM_PRESCALER(htim->Init.Prescaler));
|
|
assert_param(IS_TIM_AUTORELOAD_PRELOAD(htim->Init.AutoReloadPreload));
|
|
|
|
if (htim->State == HAL_TIM_STATE_RESET)
|
|
800343e: 687b ldr r3, [r7, #4]
|
|
8003440: 2239 movs r2, #57 ; 0x39
|
|
8003442: 5c9b ldrb r3, [r3, r2]
|
|
8003444: b2db uxtb r3, r3
|
|
8003446: 2b00 cmp r3, #0
|
|
8003448: d107 bne.n 800345a <HAL_TIM_Base_Init+0x2e>
|
|
{
|
|
/* Allocate lock resource and initialize it */
|
|
htim->Lock = HAL_UNLOCKED;
|
|
800344a: 687b ldr r3, [r7, #4]
|
|
800344c: 2238 movs r2, #56 ; 0x38
|
|
800344e: 2100 movs r1, #0
|
|
8003450: 5499 strb r1, [r3, r2]
|
|
}
|
|
/* Init the low level hardware : GPIO, CLOCK, NVIC */
|
|
htim->Base_MspInitCallback(htim);
|
|
#else
|
|
/* Init the low level hardware : GPIO, CLOCK, NVIC */
|
|
HAL_TIM_Base_MspInit(htim);
|
|
8003452: 687b ldr r3, [r7, #4]
|
|
8003454: 0018 movs r0, r3
|
|
8003456: f7fd ffdd bl 8001414 <HAL_TIM_Base_MspInit>
|
|
#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */
|
|
}
|
|
|
|
/* Set the TIM state */
|
|
htim->State = HAL_TIM_STATE_BUSY;
|
|
800345a: 687b ldr r3, [r7, #4]
|
|
800345c: 2239 movs r2, #57 ; 0x39
|
|
800345e: 2102 movs r1, #2
|
|
8003460: 5499 strb r1, [r3, r2]
|
|
|
|
/* Set the Time Base configuration */
|
|
TIM_Base_SetConfig(htim->Instance, &htim->Init);
|
|
8003462: 687b ldr r3, [r7, #4]
|
|
8003464: 681a ldr r2, [r3, #0]
|
|
8003466: 687b ldr r3, [r7, #4]
|
|
8003468: 3304 adds r3, #4
|
|
800346a: 0019 movs r1, r3
|
|
800346c: 0010 movs r0, r2
|
|
800346e: f000 fa9f bl 80039b0 <TIM_Base_SetConfig>
|
|
|
|
/* Initialize the DMA burst operation state */
|
|
htim->DMABurstState = HAL_DMA_BURST_STATE_READY;
|
|
8003472: 687b ldr r3, [r7, #4]
|
|
8003474: 223e movs r2, #62 ; 0x3e
|
|
8003476: 2101 movs r1, #1
|
|
8003478: 5499 strb r1, [r3, r2]
|
|
|
|
/* Initialize the TIM channels state */
|
|
TIM_CHANNEL_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_READY);
|
|
800347a: 687b ldr r3, [r7, #4]
|
|
800347c: 223a movs r2, #58 ; 0x3a
|
|
800347e: 2101 movs r1, #1
|
|
8003480: 5499 strb r1, [r3, r2]
|
|
8003482: 687b ldr r3, [r7, #4]
|
|
8003484: 223b movs r2, #59 ; 0x3b
|
|
8003486: 2101 movs r1, #1
|
|
8003488: 5499 strb r1, [r3, r2]
|
|
800348a: 687b ldr r3, [r7, #4]
|
|
800348c: 223c movs r2, #60 ; 0x3c
|
|
800348e: 2101 movs r1, #1
|
|
8003490: 5499 strb r1, [r3, r2]
|
|
8003492: 687b ldr r3, [r7, #4]
|
|
8003494: 223d movs r2, #61 ; 0x3d
|
|
8003496: 2101 movs r1, #1
|
|
8003498: 5499 strb r1, [r3, r2]
|
|
|
|
/* Initialize the TIM state*/
|
|
htim->State = HAL_TIM_STATE_READY;
|
|
800349a: 687b ldr r3, [r7, #4]
|
|
800349c: 2239 movs r2, #57 ; 0x39
|
|
800349e: 2101 movs r1, #1
|
|
80034a0: 5499 strb r1, [r3, r2]
|
|
|
|
return HAL_OK;
|
|
80034a2: 2300 movs r3, #0
|
|
}
|
|
80034a4: 0018 movs r0, r3
|
|
80034a6: 46bd mov sp, r7
|
|
80034a8: b002 add sp, #8
|
|
80034aa: bd80 pop {r7, pc}
|
|
|
|
080034ac <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)
|
|
{
|
|
80034ac: b580 push {r7, lr}
|
|
80034ae: b082 sub sp, #8
|
|
80034b0: af00 add r7, sp, #0
|
|
80034b2: 6078 str r0, [r7, #4]
|
|
/* Check the TIM handle allocation */
|
|
if (htim == NULL)
|
|
80034b4: 687b ldr r3, [r7, #4]
|
|
80034b6: 2b00 cmp r3, #0
|
|
80034b8: d101 bne.n 80034be <HAL_TIM_PWM_Init+0x12>
|
|
{
|
|
return HAL_ERROR;
|
|
80034ba: 2301 movs r3, #1
|
|
80034bc: e032 b.n 8003524 <HAL_TIM_PWM_Init+0x78>
|
|
assert_param(IS_TIM_CLOCKDIVISION_DIV(htim->Init.ClockDivision));
|
|
assert_param(IS_TIM_PERIOD(htim->Init.Period));
|
|
assert_param(IS_TIM_PRESCALER(htim->Init.Prescaler));
|
|
assert_param(IS_TIM_AUTORELOAD_PRELOAD(htim->Init.AutoReloadPreload));
|
|
|
|
if (htim->State == HAL_TIM_STATE_RESET)
|
|
80034be: 687b ldr r3, [r7, #4]
|
|
80034c0: 2239 movs r2, #57 ; 0x39
|
|
80034c2: 5c9b ldrb r3, [r3, r2]
|
|
80034c4: b2db uxtb r3, r3
|
|
80034c6: 2b00 cmp r3, #0
|
|
80034c8: d107 bne.n 80034da <HAL_TIM_PWM_Init+0x2e>
|
|
{
|
|
/* Allocate lock resource and initialize it */
|
|
htim->Lock = HAL_UNLOCKED;
|
|
80034ca: 687b ldr r3, [r7, #4]
|
|
80034cc: 2238 movs r2, #56 ; 0x38
|
|
80034ce: 2100 movs r1, #0
|
|
80034d0: 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);
|
|
80034d2: 687b ldr r3, [r7, #4]
|
|
80034d4: 0018 movs r0, r3
|
|
80034d6: f000 f829 bl 800352c <HAL_TIM_PWM_MspInit>
|
|
#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */
|
|
}
|
|
|
|
/* Set the TIM state */
|
|
htim->State = HAL_TIM_STATE_BUSY;
|
|
80034da: 687b ldr r3, [r7, #4]
|
|
80034dc: 2239 movs r2, #57 ; 0x39
|
|
80034de: 2102 movs r1, #2
|
|
80034e0: 5499 strb r1, [r3, r2]
|
|
|
|
/* Init the base time for the PWM */
|
|
TIM_Base_SetConfig(htim->Instance, &htim->Init);
|
|
80034e2: 687b ldr r3, [r7, #4]
|
|
80034e4: 681a ldr r2, [r3, #0]
|
|
80034e6: 687b ldr r3, [r7, #4]
|
|
80034e8: 3304 adds r3, #4
|
|
80034ea: 0019 movs r1, r3
|
|
80034ec: 0010 movs r0, r2
|
|
80034ee: f000 fa5f bl 80039b0 <TIM_Base_SetConfig>
|
|
|
|
/* Initialize the DMA burst operation state */
|
|
htim->DMABurstState = HAL_DMA_BURST_STATE_READY;
|
|
80034f2: 687b ldr r3, [r7, #4]
|
|
80034f4: 223e movs r2, #62 ; 0x3e
|
|
80034f6: 2101 movs r1, #1
|
|
80034f8: 5499 strb r1, [r3, r2]
|
|
|
|
/* Initialize the TIM channels state */
|
|
TIM_CHANNEL_STATE_SET_ALL(htim, HAL_TIM_CHANNEL_STATE_READY);
|
|
80034fa: 687b ldr r3, [r7, #4]
|
|
80034fc: 223a movs r2, #58 ; 0x3a
|
|
80034fe: 2101 movs r1, #1
|
|
8003500: 5499 strb r1, [r3, r2]
|
|
8003502: 687b ldr r3, [r7, #4]
|
|
8003504: 223b movs r2, #59 ; 0x3b
|
|
8003506: 2101 movs r1, #1
|
|
8003508: 5499 strb r1, [r3, r2]
|
|
800350a: 687b ldr r3, [r7, #4]
|
|
800350c: 223c movs r2, #60 ; 0x3c
|
|
800350e: 2101 movs r1, #1
|
|
8003510: 5499 strb r1, [r3, r2]
|
|
8003512: 687b ldr r3, [r7, #4]
|
|
8003514: 223d movs r2, #61 ; 0x3d
|
|
8003516: 2101 movs r1, #1
|
|
8003518: 5499 strb r1, [r3, r2]
|
|
|
|
/* Initialize the TIM state*/
|
|
htim->State = HAL_TIM_STATE_READY;
|
|
800351a: 687b ldr r3, [r7, #4]
|
|
800351c: 2239 movs r2, #57 ; 0x39
|
|
800351e: 2101 movs r1, #1
|
|
8003520: 5499 strb r1, [r3, r2]
|
|
|
|
return HAL_OK;
|
|
8003522: 2300 movs r3, #0
|
|
}
|
|
8003524: 0018 movs r0, r3
|
|
8003526: 46bd mov sp, r7
|
|
8003528: b002 add sp, #8
|
|
800352a: bd80 pop {r7, pc}
|
|
|
|
0800352c <HAL_TIM_PWM_MspInit>:
|
|
* @brief Initializes the TIM PWM MSP.
|
|
* @param htim TIM PWM handle
|
|
* @retval None
|
|
*/
|
|
__weak void HAL_TIM_PWM_MspInit(TIM_HandleTypeDef *htim)
|
|
{
|
|
800352c: b580 push {r7, lr}
|
|
800352e: b082 sub sp, #8
|
|
8003530: af00 add r7, sp, #0
|
|
8003532: 6078 str r0, [r7, #4]
|
|
UNUSED(htim);
|
|
|
|
/* NOTE : This function should not be modified, when the callback is needed,
|
|
the HAL_TIM_PWM_MspInit could be implemented in the user file
|
|
*/
|
|
}
|
|
8003534: 46c0 nop ; (mov r8, r8)
|
|
8003536: 46bd mov sp, r7
|
|
8003538: b002 add sp, #8
|
|
800353a: bd80 pop {r7, pc}
|
|
|
|
0800353c <HAL_TIM_Encoder_Init>:
|
|
* @param htim TIM Encoder Interface handle
|
|
* @param sConfig TIM Encoder Interface configuration structure
|
|
* @retval HAL status
|
|
*/
|
|
HAL_StatusTypeDef HAL_TIM_Encoder_Init(TIM_HandleTypeDef *htim, TIM_Encoder_InitTypeDef *sConfig)
|
|
{
|
|
800353c: b580 push {r7, lr}
|
|
800353e: b086 sub sp, #24
|
|
8003540: af00 add r7, sp, #0
|
|
8003542: 6078 str r0, [r7, #4]
|
|
8003544: 6039 str r1, [r7, #0]
|
|
uint32_t tmpsmcr;
|
|
uint32_t tmpccmr1;
|
|
uint32_t tmpccer;
|
|
|
|
/* Check the TIM handle allocation */
|
|
if (htim == NULL)
|
|
8003546: 687b ldr r3, [r7, #4]
|
|
8003548: 2b00 cmp r3, #0
|
|
800354a: d101 bne.n 8003550 <HAL_TIM_Encoder_Init+0x14>
|
|
{
|
|
return HAL_ERROR;
|
|
800354c: 2301 movs r3, #1
|
|
800354e: e088 b.n 8003662 <HAL_TIM_Encoder_Init+0x126>
|
|
assert_param(IS_TIM_IC_FILTER(sConfig->IC1Filter));
|
|
assert_param(IS_TIM_IC_FILTER(sConfig->IC2Filter));
|
|
assert_param(IS_TIM_PERIOD(htim->Init.Period));
|
|
assert_param(IS_TIM_PRESCALER(htim->Init.Prescaler));
|
|
|
|
if (htim->State == HAL_TIM_STATE_RESET)
|
|
8003550: 687b ldr r3, [r7, #4]
|
|
8003552: 2239 movs r2, #57 ; 0x39
|
|
8003554: 5c9b ldrb r3, [r3, r2]
|
|
8003556: b2db uxtb r3, r3
|
|
8003558: 2b00 cmp r3, #0
|
|
800355a: d107 bne.n 800356c <HAL_TIM_Encoder_Init+0x30>
|
|
{
|
|
/* Allocate lock resource and initialize it */
|
|
htim->Lock = HAL_UNLOCKED;
|
|
800355c: 687b ldr r3, [r7, #4]
|
|
800355e: 2238 movs r2, #56 ; 0x38
|
|
8003560: 2100 movs r1, #0
|
|
8003562: 5499 strb r1, [r3, r2]
|
|
}
|
|
/* Init the low level hardware : GPIO, CLOCK, NVIC */
|
|
htim->Encoder_MspInitCallback(htim);
|
|
#else
|
|
/* Init the low level hardware : GPIO, CLOCK, NVIC and DMA */
|
|
HAL_TIM_Encoder_MspInit(htim);
|
|
8003564: 687b ldr r3, [r7, #4]
|
|
8003566: 0018 movs r0, r3
|
|
8003568: f7fd ff6a bl 8001440 <HAL_TIM_Encoder_MspInit>
|
|
#endif /* USE_HAL_TIM_REGISTER_CALLBACKS */
|
|
}
|
|
|
|
/* Set the TIM state */
|
|
htim->State = HAL_TIM_STATE_BUSY;
|
|
800356c: 687b ldr r3, [r7, #4]
|
|
800356e: 2239 movs r2, #57 ; 0x39
|
|
8003570: 2102 movs r1, #2
|
|
8003572: 5499 strb r1, [r3, r2]
|
|
|
|
/* Reset the SMS and ECE bits */
|
|
htim->Instance->SMCR &= ~(TIM_SMCR_SMS | TIM_SMCR_ECE);
|
|
8003574: 687b ldr r3, [r7, #4]
|
|
8003576: 681b ldr r3, [r3, #0]
|
|
8003578: 689a ldr r2, [r3, #8]
|
|
800357a: 687b ldr r3, [r7, #4]
|
|
800357c: 681b ldr r3, [r3, #0]
|
|
800357e: 493b ldr r1, [pc, #236] ; (800366c <HAL_TIM_Encoder_Init+0x130>)
|
|
8003580: 400a ands r2, r1
|
|
8003582: 609a str r2, [r3, #8]
|
|
|
|
/* Configure the Time base in the Encoder Mode */
|
|
TIM_Base_SetConfig(htim->Instance, &htim->Init);
|
|
8003584: 687b ldr r3, [r7, #4]
|
|
8003586: 681a ldr r2, [r3, #0]
|
|
8003588: 687b ldr r3, [r7, #4]
|
|
800358a: 3304 adds r3, #4
|
|
800358c: 0019 movs r1, r3
|
|
800358e: 0010 movs r0, r2
|
|
8003590: f000 fa0e bl 80039b0 <TIM_Base_SetConfig>
|
|
|
|
/* Get the TIMx SMCR register value */
|
|
tmpsmcr = htim->Instance->SMCR;
|
|
8003594: 687b ldr r3, [r7, #4]
|
|
8003596: 681b ldr r3, [r3, #0]
|
|
8003598: 689b ldr r3, [r3, #8]
|
|
800359a: 617b str r3, [r7, #20]
|
|
|
|
/* Get the TIMx CCMR1 register value */
|
|
tmpccmr1 = htim->Instance->CCMR1;
|
|
800359c: 687b ldr r3, [r7, #4]
|
|
800359e: 681b ldr r3, [r3, #0]
|
|
80035a0: 699b ldr r3, [r3, #24]
|
|
80035a2: 613b str r3, [r7, #16]
|
|
|
|
/* Get the TIMx CCER register value */
|
|
tmpccer = htim->Instance->CCER;
|
|
80035a4: 687b ldr r3, [r7, #4]
|
|
80035a6: 681b ldr r3, [r3, #0]
|
|
80035a8: 6a1b ldr r3, [r3, #32]
|
|
80035aa: 60fb str r3, [r7, #12]
|
|
|
|
/* Set the encoder Mode */
|
|
tmpsmcr |= sConfig->EncoderMode;
|
|
80035ac: 683b ldr r3, [r7, #0]
|
|
80035ae: 681b ldr r3, [r3, #0]
|
|
80035b0: 697a ldr r2, [r7, #20]
|
|
80035b2: 4313 orrs r3, r2
|
|
80035b4: 617b str r3, [r7, #20]
|
|
|
|
/* Select the Capture Compare 1 and the Capture Compare 2 as input */
|
|
tmpccmr1 &= ~(TIM_CCMR1_CC1S | TIM_CCMR1_CC2S);
|
|
80035b6: 693b ldr r3, [r7, #16]
|
|
80035b8: 4a2d ldr r2, [pc, #180] ; (8003670 <HAL_TIM_Encoder_Init+0x134>)
|
|
80035ba: 4013 ands r3, r2
|
|
80035bc: 613b str r3, [r7, #16]
|
|
tmpccmr1 |= (sConfig->IC1Selection | (sConfig->IC2Selection << 8U));
|
|
80035be: 683b ldr r3, [r7, #0]
|
|
80035c0: 689a ldr r2, [r3, #8]
|
|
80035c2: 683b ldr r3, [r7, #0]
|
|
80035c4: 699b ldr r3, [r3, #24]
|
|
80035c6: 021b lsls r3, r3, #8
|
|
80035c8: 4313 orrs r3, r2
|
|
80035ca: 693a ldr r2, [r7, #16]
|
|
80035cc: 4313 orrs r3, r2
|
|
80035ce: 613b str r3, [r7, #16]
|
|
|
|
/* Set the Capture Compare 1 and the Capture Compare 2 prescalers and filters */
|
|
tmpccmr1 &= ~(TIM_CCMR1_IC1PSC | TIM_CCMR1_IC2PSC);
|
|
80035d0: 693b ldr r3, [r7, #16]
|
|
80035d2: 4a28 ldr r2, [pc, #160] ; (8003674 <HAL_TIM_Encoder_Init+0x138>)
|
|
80035d4: 4013 ands r3, r2
|
|
80035d6: 613b str r3, [r7, #16]
|
|
tmpccmr1 &= ~(TIM_CCMR1_IC1F | TIM_CCMR1_IC2F);
|
|
80035d8: 693b ldr r3, [r7, #16]
|
|
80035da: 4a27 ldr r2, [pc, #156] ; (8003678 <HAL_TIM_Encoder_Init+0x13c>)
|
|
80035dc: 4013 ands r3, r2
|
|
80035de: 613b str r3, [r7, #16]
|
|
tmpccmr1 |= sConfig->IC1Prescaler | (sConfig->IC2Prescaler << 8U);
|
|
80035e0: 683b ldr r3, [r7, #0]
|
|
80035e2: 68da ldr r2, [r3, #12]
|
|
80035e4: 683b ldr r3, [r7, #0]
|
|
80035e6: 69db ldr r3, [r3, #28]
|
|
80035e8: 021b lsls r3, r3, #8
|
|
80035ea: 4313 orrs r3, r2
|
|
80035ec: 693a ldr r2, [r7, #16]
|
|
80035ee: 4313 orrs r3, r2
|
|
80035f0: 613b str r3, [r7, #16]
|
|
tmpccmr1 |= (sConfig->IC1Filter << 4U) | (sConfig->IC2Filter << 12U);
|
|
80035f2: 683b ldr r3, [r7, #0]
|
|
80035f4: 691b ldr r3, [r3, #16]
|
|
80035f6: 011a lsls r2, r3, #4
|
|
80035f8: 683b ldr r3, [r7, #0]
|
|
80035fa: 6a1b ldr r3, [r3, #32]
|
|
80035fc: 031b lsls r3, r3, #12
|
|
80035fe: 4313 orrs r3, r2
|
|
8003600: 693a ldr r2, [r7, #16]
|
|
8003602: 4313 orrs r3, r2
|
|
8003604: 613b str r3, [r7, #16]
|
|
|
|
/* Set the TI1 and the TI2 Polarities */
|
|
tmpccer &= ~(TIM_CCER_CC1P | TIM_CCER_CC2P);
|
|
8003606: 68fb ldr r3, [r7, #12]
|
|
8003608: 2222 movs r2, #34 ; 0x22
|
|
800360a: 4393 bics r3, r2
|
|
800360c: 60fb str r3, [r7, #12]
|
|
tmpccer &= ~(TIM_CCER_CC1NP | TIM_CCER_CC2NP);
|
|
800360e: 68fb ldr r3, [r7, #12]
|
|
8003610: 2288 movs r2, #136 ; 0x88
|
|
8003612: 4393 bics r3, r2
|
|
8003614: 60fb str r3, [r7, #12]
|
|
tmpccer |= sConfig->IC1Polarity | (sConfig->IC2Polarity << 4U);
|
|
8003616: 683b ldr r3, [r7, #0]
|
|
8003618: 685a ldr r2, [r3, #4]
|
|
800361a: 683b ldr r3, [r7, #0]
|
|
800361c: 695b ldr r3, [r3, #20]
|
|
800361e: 011b lsls r3, r3, #4
|
|
8003620: 4313 orrs r3, r2
|
|
8003622: 68fa ldr r2, [r7, #12]
|
|
8003624: 4313 orrs r3, r2
|
|
8003626: 60fb str r3, [r7, #12]
|
|
|
|
/* Write to TIMx SMCR */
|
|
htim->Instance->SMCR = tmpsmcr;
|
|
8003628: 687b ldr r3, [r7, #4]
|
|
800362a: 681b ldr r3, [r3, #0]
|
|
800362c: 697a ldr r2, [r7, #20]
|
|
800362e: 609a str r2, [r3, #8]
|
|
|
|
/* Write to TIMx CCMR1 */
|
|
htim->Instance->CCMR1 = tmpccmr1;
|
|
8003630: 687b ldr r3, [r7, #4]
|
|
8003632: 681b ldr r3, [r3, #0]
|
|
8003634: 693a ldr r2, [r7, #16]
|
|
8003636: 619a str r2, [r3, #24]
|
|
|
|
/* Write to TIMx CCER */
|
|
htim->Instance->CCER = tmpccer;
|
|
8003638: 687b ldr r3, [r7, #4]
|
|
800363a: 681b ldr r3, [r3, #0]
|
|
800363c: 68fa ldr r2, [r7, #12]
|
|
800363e: 621a str r2, [r3, #32]
|
|
|
|
/* Initialize the DMA burst operation state */
|
|
htim->DMABurstState = HAL_DMA_BURST_STATE_READY;
|
|
8003640: 687b ldr r3, [r7, #4]
|
|
8003642: 223e movs r2, #62 ; 0x3e
|
|
8003644: 2101 movs r1, #1
|
|
8003646: 5499 strb r1, [r3, r2]
|
|
|
|
/* Set the TIM channels state */
|
|
TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_1, HAL_TIM_CHANNEL_STATE_READY);
|
|
8003648: 687b ldr r3, [r7, #4]
|
|
800364a: 223a movs r2, #58 ; 0x3a
|
|
800364c: 2101 movs r1, #1
|
|
800364e: 5499 strb r1, [r3, r2]
|
|
TIM_CHANNEL_STATE_SET(htim, TIM_CHANNEL_2, HAL_TIM_CHANNEL_STATE_READY);
|
|
8003650: 687b ldr r3, [r7, #4]
|
|
8003652: 223b movs r2, #59 ; 0x3b
|
|
8003654: 2101 movs r1, #1
|
|
8003656: 5499 strb r1, [r3, r2]
|
|
|
|
/* Initialize the TIM state*/
|
|
htim->State = HAL_TIM_STATE_READY;
|
|
8003658: 687b ldr r3, [r7, #4]
|
|
800365a: 2239 movs r2, #57 ; 0x39
|
|
800365c: 2101 movs r1, #1
|
|
800365e: 5499 strb r1, [r3, r2]
|
|
|
|
return HAL_OK;
|
|
8003660: 2300 movs r3, #0
|
|
}
|
|
8003662: 0018 movs r0, r3
|
|
8003664: 46bd mov sp, r7
|
|
8003666: b006 add sp, #24
|
|
8003668: bd80 pop {r7, pc}
|
|
800366a: 46c0 nop ; (mov r8, r8)
|
|
800366c: ffffbff8 .word 0xffffbff8
|
|
8003670: fffffcfc .word 0xfffffcfc
|
|
8003674: fffff3f3 .word 0xfffff3f3
|
|
8003678: ffff0f0f .word 0xffff0f0f
|
|
|
|
0800367c <HAL_TIM_PWM_ConfigChannel>:
|
|
* @retval HAL status
|
|
*/
|
|
HAL_StatusTypeDef HAL_TIM_PWM_ConfigChannel(TIM_HandleTypeDef *htim,
|
|
TIM_OC_InitTypeDef *sConfig,
|
|
uint32_t Channel)
|
|
{
|
|
800367c: b580 push {r7, lr}
|
|
800367e: b086 sub sp, #24
|
|
8003680: af00 add r7, sp, #0
|
|
8003682: 60f8 str r0, [r7, #12]
|
|
8003684: 60b9 str r1, [r7, #8]
|
|
8003686: 607a str r2, [r7, #4]
|
|
HAL_StatusTypeDef status = HAL_OK;
|
|
8003688: 2317 movs r3, #23
|
|
800368a: 18fb adds r3, r7, r3
|
|
800368c: 2200 movs r2, #0
|
|
800368e: 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);
|
|
8003690: 68fb ldr r3, [r7, #12]
|
|
8003692: 2238 movs r2, #56 ; 0x38
|
|
8003694: 5c9b ldrb r3, [r3, r2]
|
|
8003696: 2b01 cmp r3, #1
|
|
8003698: d101 bne.n 800369e <HAL_TIM_PWM_ConfigChannel+0x22>
|
|
800369a: 2302 movs r3, #2
|
|
800369c: e0ad b.n 80037fa <HAL_TIM_PWM_ConfigChannel+0x17e>
|
|
800369e: 68fb ldr r3, [r7, #12]
|
|
80036a0: 2238 movs r2, #56 ; 0x38
|
|
80036a2: 2101 movs r1, #1
|
|
80036a4: 5499 strb r1, [r3, r2]
|
|
|
|
switch (Channel)
|
|
80036a6: 687b ldr r3, [r7, #4]
|
|
80036a8: 2b0c cmp r3, #12
|
|
80036aa: d100 bne.n 80036ae <HAL_TIM_PWM_ConfigChannel+0x32>
|
|
80036ac: e076 b.n 800379c <HAL_TIM_PWM_ConfigChannel+0x120>
|
|
80036ae: 687b ldr r3, [r7, #4]
|
|
80036b0: 2b0c cmp r3, #12
|
|
80036b2: d900 bls.n 80036b6 <HAL_TIM_PWM_ConfigChannel+0x3a>
|
|
80036b4: e095 b.n 80037e2 <HAL_TIM_PWM_ConfigChannel+0x166>
|
|
80036b6: 687b ldr r3, [r7, #4]
|
|
80036b8: 2b08 cmp r3, #8
|
|
80036ba: d04e beq.n 800375a <HAL_TIM_PWM_ConfigChannel+0xde>
|
|
80036bc: 687b ldr r3, [r7, #4]
|
|
80036be: 2b08 cmp r3, #8
|
|
80036c0: d900 bls.n 80036c4 <HAL_TIM_PWM_ConfigChannel+0x48>
|
|
80036c2: e08e b.n 80037e2 <HAL_TIM_PWM_ConfigChannel+0x166>
|
|
80036c4: 687b ldr r3, [r7, #4]
|
|
80036c6: 2b00 cmp r3, #0
|
|
80036c8: d003 beq.n 80036d2 <HAL_TIM_PWM_ConfigChannel+0x56>
|
|
80036ca: 687b ldr r3, [r7, #4]
|
|
80036cc: 2b04 cmp r3, #4
|
|
80036ce: d021 beq.n 8003714 <HAL_TIM_PWM_ConfigChannel+0x98>
|
|
80036d0: e087 b.n 80037e2 <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);
|
|
80036d2: 68fb ldr r3, [r7, #12]
|
|
80036d4: 681b ldr r3, [r3, #0]
|
|
80036d6: 68ba ldr r2, [r7, #8]
|
|
80036d8: 0011 movs r1, r2
|
|
80036da: 0018 movs r0, r3
|
|
80036dc: f000 f9b2 bl 8003a44 <TIM_OC1_SetConfig>
|
|
|
|
/* Set the Preload enable bit for channel1 */
|
|
htim->Instance->CCMR1 |= TIM_CCMR1_OC1PE;
|
|
80036e0: 68fb ldr r3, [r7, #12]
|
|
80036e2: 681b ldr r3, [r3, #0]
|
|
80036e4: 699a ldr r2, [r3, #24]
|
|
80036e6: 68fb ldr r3, [r7, #12]
|
|
80036e8: 681b ldr r3, [r3, #0]
|
|
80036ea: 2108 movs r1, #8
|
|
80036ec: 430a orrs r2, r1
|
|
80036ee: 619a str r2, [r3, #24]
|
|
|
|
/* Configure the Output Fast mode */
|
|
htim->Instance->CCMR1 &= ~TIM_CCMR1_OC1FE;
|
|
80036f0: 68fb ldr r3, [r7, #12]
|
|
80036f2: 681b ldr r3, [r3, #0]
|
|
80036f4: 699a ldr r2, [r3, #24]
|
|
80036f6: 68fb ldr r3, [r7, #12]
|
|
80036f8: 681b ldr r3, [r3, #0]
|
|
80036fa: 2104 movs r1, #4
|
|
80036fc: 438a bics r2, r1
|
|
80036fe: 619a str r2, [r3, #24]
|
|
htim->Instance->CCMR1 |= sConfig->OCFastMode;
|
|
8003700: 68fb ldr r3, [r7, #12]
|
|
8003702: 681b ldr r3, [r3, #0]
|
|
8003704: 6999 ldr r1, [r3, #24]
|
|
8003706: 68bb ldr r3, [r7, #8]
|
|
8003708: 68da ldr r2, [r3, #12]
|
|
800370a: 68fb ldr r3, [r7, #12]
|
|
800370c: 681b ldr r3, [r3, #0]
|
|
800370e: 430a orrs r2, r1
|
|
8003710: 619a str r2, [r3, #24]
|
|
break;
|
|
8003712: e06b b.n 80037ec <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);
|
|
8003714: 68fb ldr r3, [r7, #12]
|
|
8003716: 681b ldr r3, [r3, #0]
|
|
8003718: 68ba ldr r2, [r7, #8]
|
|
800371a: 0011 movs r1, r2
|
|
800371c: 0018 movs r0, r3
|
|
800371e: f000 f9cd bl 8003abc <TIM_OC2_SetConfig>
|
|
|
|
/* Set the Preload enable bit for channel2 */
|
|
htim->Instance->CCMR1 |= TIM_CCMR1_OC2PE;
|
|
8003722: 68fb ldr r3, [r7, #12]
|
|
8003724: 681b ldr r3, [r3, #0]
|
|
8003726: 699a ldr r2, [r3, #24]
|
|
8003728: 68fb ldr r3, [r7, #12]
|
|
800372a: 681b ldr r3, [r3, #0]
|
|
800372c: 2180 movs r1, #128 ; 0x80
|
|
800372e: 0109 lsls r1, r1, #4
|
|
8003730: 430a orrs r2, r1
|
|
8003732: 619a str r2, [r3, #24]
|
|
|
|
/* Configure the Output Fast mode */
|
|
htim->Instance->CCMR1 &= ~TIM_CCMR1_OC2FE;
|
|
8003734: 68fb ldr r3, [r7, #12]
|
|
8003736: 681b ldr r3, [r3, #0]
|
|
8003738: 699a ldr r2, [r3, #24]
|
|
800373a: 68fb ldr r3, [r7, #12]
|
|
800373c: 681b ldr r3, [r3, #0]
|
|
800373e: 4931 ldr r1, [pc, #196] ; (8003804 <HAL_TIM_PWM_ConfigChannel+0x188>)
|
|
8003740: 400a ands r2, r1
|
|
8003742: 619a str r2, [r3, #24]
|
|
htim->Instance->CCMR1 |= sConfig->OCFastMode << 8U;
|
|
8003744: 68fb ldr r3, [r7, #12]
|
|
8003746: 681b ldr r3, [r3, #0]
|
|
8003748: 6999 ldr r1, [r3, #24]
|
|
800374a: 68bb ldr r3, [r7, #8]
|
|
800374c: 68db ldr r3, [r3, #12]
|
|
800374e: 021a lsls r2, r3, #8
|
|
8003750: 68fb ldr r3, [r7, #12]
|
|
8003752: 681b ldr r3, [r3, #0]
|
|
8003754: 430a orrs r2, r1
|
|
8003756: 619a str r2, [r3, #24]
|
|
break;
|
|
8003758: e048 b.n 80037ec <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);
|
|
800375a: 68fb ldr r3, [r7, #12]
|
|
800375c: 681b ldr r3, [r3, #0]
|
|
800375e: 68ba ldr r2, [r7, #8]
|
|
8003760: 0011 movs r1, r2
|
|
8003762: 0018 movs r0, r3
|
|
8003764: f000 f9ec bl 8003b40 <TIM_OC3_SetConfig>
|
|
|
|
/* Set the Preload enable bit for channel3 */
|
|
htim->Instance->CCMR2 |= TIM_CCMR2_OC3PE;
|
|
8003768: 68fb ldr r3, [r7, #12]
|
|
800376a: 681b ldr r3, [r3, #0]
|
|
800376c: 69da ldr r2, [r3, #28]
|
|
800376e: 68fb ldr r3, [r7, #12]
|
|
8003770: 681b ldr r3, [r3, #0]
|
|
8003772: 2108 movs r1, #8
|
|
8003774: 430a orrs r2, r1
|
|
8003776: 61da str r2, [r3, #28]
|
|
|
|
/* Configure the Output Fast mode */
|
|
htim->Instance->CCMR2 &= ~TIM_CCMR2_OC3FE;
|
|
8003778: 68fb ldr r3, [r7, #12]
|
|
800377a: 681b ldr r3, [r3, #0]
|
|
800377c: 69da ldr r2, [r3, #28]
|
|
800377e: 68fb ldr r3, [r7, #12]
|
|
8003780: 681b ldr r3, [r3, #0]
|
|
8003782: 2104 movs r1, #4
|
|
8003784: 438a bics r2, r1
|
|
8003786: 61da str r2, [r3, #28]
|
|
htim->Instance->CCMR2 |= sConfig->OCFastMode;
|
|
8003788: 68fb ldr r3, [r7, #12]
|
|
800378a: 681b ldr r3, [r3, #0]
|
|
800378c: 69d9 ldr r1, [r3, #28]
|
|
800378e: 68bb ldr r3, [r7, #8]
|
|
8003790: 68da ldr r2, [r3, #12]
|
|
8003792: 68fb ldr r3, [r7, #12]
|
|
8003794: 681b ldr r3, [r3, #0]
|
|
8003796: 430a orrs r2, r1
|
|
8003798: 61da str r2, [r3, #28]
|
|
break;
|
|
800379a: e027 b.n 80037ec <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);
|
|
800379c: 68fb ldr r3, [r7, #12]
|
|
800379e: 681b ldr r3, [r3, #0]
|
|
80037a0: 68ba ldr r2, [r7, #8]
|
|
80037a2: 0011 movs r1, r2
|
|
80037a4: 0018 movs r0, r3
|
|
80037a6: f000 fa0b bl 8003bc0 <TIM_OC4_SetConfig>
|
|
|
|
/* Set the Preload enable bit for channel4 */
|
|
htim->Instance->CCMR2 |= TIM_CCMR2_OC4PE;
|
|
80037aa: 68fb ldr r3, [r7, #12]
|
|
80037ac: 681b ldr r3, [r3, #0]
|
|
80037ae: 69da ldr r2, [r3, #28]
|
|
80037b0: 68fb ldr r3, [r7, #12]
|
|
80037b2: 681b ldr r3, [r3, #0]
|
|
80037b4: 2180 movs r1, #128 ; 0x80
|
|
80037b6: 0109 lsls r1, r1, #4
|
|
80037b8: 430a orrs r2, r1
|
|
80037ba: 61da str r2, [r3, #28]
|
|
|
|
/* Configure the Output Fast mode */
|
|
htim->Instance->CCMR2 &= ~TIM_CCMR2_OC4FE;
|
|
80037bc: 68fb ldr r3, [r7, #12]
|
|
80037be: 681b ldr r3, [r3, #0]
|
|
80037c0: 69da ldr r2, [r3, #28]
|
|
80037c2: 68fb ldr r3, [r7, #12]
|
|
80037c4: 681b ldr r3, [r3, #0]
|
|
80037c6: 490f ldr r1, [pc, #60] ; (8003804 <HAL_TIM_PWM_ConfigChannel+0x188>)
|
|
80037c8: 400a ands r2, r1
|
|
80037ca: 61da str r2, [r3, #28]
|
|
htim->Instance->CCMR2 |= sConfig->OCFastMode << 8U;
|
|
80037cc: 68fb ldr r3, [r7, #12]
|
|
80037ce: 681b ldr r3, [r3, #0]
|
|
80037d0: 69d9 ldr r1, [r3, #28]
|
|
80037d2: 68bb ldr r3, [r7, #8]
|
|
80037d4: 68db ldr r3, [r3, #12]
|
|
80037d6: 021a lsls r2, r3, #8
|
|
80037d8: 68fb ldr r3, [r7, #12]
|
|
80037da: 681b ldr r3, [r3, #0]
|
|
80037dc: 430a orrs r2, r1
|
|
80037de: 61da str r2, [r3, #28]
|
|
break;
|
|
80037e0: e004 b.n 80037ec <HAL_TIM_PWM_ConfigChannel+0x170>
|
|
}
|
|
|
|
default:
|
|
status = HAL_ERROR;
|
|
80037e2: 2317 movs r3, #23
|
|
80037e4: 18fb adds r3, r7, r3
|
|
80037e6: 2201 movs r2, #1
|
|
80037e8: 701a strb r2, [r3, #0]
|
|
break;
|
|
80037ea: 46c0 nop ; (mov r8, r8)
|
|
}
|
|
|
|
__HAL_UNLOCK(htim);
|
|
80037ec: 68fb ldr r3, [r7, #12]
|
|
80037ee: 2238 movs r2, #56 ; 0x38
|
|
80037f0: 2100 movs r1, #0
|
|
80037f2: 5499 strb r1, [r3, r2]
|
|
|
|
return status;
|
|
80037f4: 2317 movs r3, #23
|
|
80037f6: 18fb adds r3, r7, r3
|
|
80037f8: 781b ldrb r3, [r3, #0]
|
|
}
|
|
80037fa: 0018 movs r0, r3
|
|
80037fc: 46bd mov sp, r7
|
|
80037fe: b006 add sp, #24
|
|
8003800: bd80 pop {r7, pc}
|
|
8003802: 46c0 nop ; (mov r8, r8)
|
|
8003804: fffffbff .word 0xfffffbff
|
|
|
|
08003808 <HAL_TIM_ConfigClockSource>:
|
|
* @param sClockSourceConfig pointer to a TIM_ClockConfigTypeDef structure that
|
|
* contains the clock source information for the TIM peripheral.
|
|
* @retval HAL status
|
|
*/
|
|
HAL_StatusTypeDef HAL_TIM_ConfigClockSource(TIM_HandleTypeDef *htim, TIM_ClockConfigTypeDef *sClockSourceConfig)
|
|
{
|
|
8003808: b580 push {r7, lr}
|
|
800380a: b084 sub sp, #16
|
|
800380c: af00 add r7, sp, #0
|
|
800380e: 6078 str r0, [r7, #4]
|
|
8003810: 6039 str r1, [r7, #0]
|
|
HAL_StatusTypeDef status = HAL_OK;
|
|
8003812: 230f movs r3, #15
|
|
8003814: 18fb adds r3, r7, r3
|
|
8003816: 2200 movs r2, #0
|
|
8003818: 701a strb r2, [r3, #0]
|
|
uint32_t tmpsmcr;
|
|
|
|
/* Process Locked */
|
|
__HAL_LOCK(htim);
|
|
800381a: 687b ldr r3, [r7, #4]
|
|
800381c: 2238 movs r2, #56 ; 0x38
|
|
800381e: 5c9b ldrb r3, [r3, r2]
|
|
8003820: 2b01 cmp r3, #1
|
|
8003822: d101 bne.n 8003828 <HAL_TIM_ConfigClockSource+0x20>
|
|
8003824: 2302 movs r3, #2
|
|
8003826: e0bc b.n 80039a2 <HAL_TIM_ConfigClockSource+0x19a>
|
|
8003828: 687b ldr r3, [r7, #4]
|
|
800382a: 2238 movs r2, #56 ; 0x38
|
|
800382c: 2101 movs r1, #1
|
|
800382e: 5499 strb r1, [r3, r2]
|
|
|
|
htim->State = HAL_TIM_STATE_BUSY;
|
|
8003830: 687b ldr r3, [r7, #4]
|
|
8003832: 2239 movs r2, #57 ; 0x39
|
|
8003834: 2102 movs r1, #2
|
|
8003836: 5499 strb r1, [r3, r2]
|
|
|
|
/* Check the parameters */
|
|
assert_param(IS_TIM_CLOCKSOURCE(sClockSourceConfig->ClockSource));
|
|
|
|
/* Reset the SMS, TS, ECE, ETPS and ETRF bits */
|
|
tmpsmcr = htim->Instance->SMCR;
|
|
8003838: 687b ldr r3, [r7, #4]
|
|
800383a: 681b ldr r3, [r3, #0]
|
|
800383c: 689b ldr r3, [r3, #8]
|
|
800383e: 60bb str r3, [r7, #8]
|
|
tmpsmcr &= ~(TIM_SMCR_SMS | TIM_SMCR_TS);
|
|
8003840: 68bb ldr r3, [r7, #8]
|
|
8003842: 2277 movs r2, #119 ; 0x77
|
|
8003844: 4393 bics r3, r2
|
|
8003846: 60bb str r3, [r7, #8]
|
|
tmpsmcr &= ~(TIM_SMCR_ETF | TIM_SMCR_ETPS | TIM_SMCR_ECE | TIM_SMCR_ETP);
|
|
8003848: 68bb ldr r3, [r7, #8]
|
|
800384a: 4a58 ldr r2, [pc, #352] ; (80039ac <HAL_TIM_ConfigClockSource+0x1a4>)
|
|
800384c: 4013 ands r3, r2
|
|
800384e: 60bb str r3, [r7, #8]
|
|
htim->Instance->SMCR = tmpsmcr;
|
|
8003850: 687b ldr r3, [r7, #4]
|
|
8003852: 681b ldr r3, [r3, #0]
|
|
8003854: 68ba ldr r2, [r7, #8]
|
|
8003856: 609a str r2, [r3, #8]
|
|
|
|
switch (sClockSourceConfig->ClockSource)
|
|
8003858: 683b ldr r3, [r7, #0]
|
|
800385a: 681b ldr r3, [r3, #0]
|
|
800385c: 2280 movs r2, #128 ; 0x80
|
|
800385e: 0192 lsls r2, r2, #6
|
|
8003860: 4293 cmp r3, r2
|
|
8003862: d040 beq.n 80038e6 <HAL_TIM_ConfigClockSource+0xde>
|
|
8003864: 2280 movs r2, #128 ; 0x80
|
|
8003866: 0192 lsls r2, r2, #6
|
|
8003868: 4293 cmp r3, r2
|
|
800386a: d900 bls.n 800386e <HAL_TIM_ConfigClockSource+0x66>
|
|
800386c: e088 b.n 8003980 <HAL_TIM_ConfigClockSource+0x178>
|
|
800386e: 2280 movs r2, #128 ; 0x80
|
|
8003870: 0152 lsls r2, r2, #5
|
|
8003872: 4293 cmp r3, r2
|
|
8003874: d100 bne.n 8003878 <HAL_TIM_ConfigClockSource+0x70>
|
|
8003876: e088 b.n 800398a <HAL_TIM_ConfigClockSource+0x182>
|
|
8003878: 2280 movs r2, #128 ; 0x80
|
|
800387a: 0152 lsls r2, r2, #5
|
|
800387c: 4293 cmp r3, r2
|
|
800387e: d900 bls.n 8003882 <HAL_TIM_ConfigClockSource+0x7a>
|
|
8003880: e07e b.n 8003980 <HAL_TIM_ConfigClockSource+0x178>
|
|
8003882: 2b70 cmp r3, #112 ; 0x70
|
|
8003884: d018 beq.n 80038b8 <HAL_TIM_ConfigClockSource+0xb0>
|
|
8003886: d900 bls.n 800388a <HAL_TIM_ConfigClockSource+0x82>
|
|
8003888: e07a b.n 8003980 <HAL_TIM_ConfigClockSource+0x178>
|
|
800388a: 2b60 cmp r3, #96 ; 0x60
|
|
800388c: d04f beq.n 800392e <HAL_TIM_ConfigClockSource+0x126>
|
|
800388e: d900 bls.n 8003892 <HAL_TIM_ConfigClockSource+0x8a>
|
|
8003890: e076 b.n 8003980 <HAL_TIM_ConfigClockSource+0x178>
|
|
8003892: 2b50 cmp r3, #80 ; 0x50
|
|
8003894: d03b beq.n 800390e <HAL_TIM_ConfigClockSource+0x106>
|
|
8003896: d900 bls.n 800389a <HAL_TIM_ConfigClockSource+0x92>
|
|
8003898: e072 b.n 8003980 <HAL_TIM_ConfigClockSource+0x178>
|
|
800389a: 2b40 cmp r3, #64 ; 0x40
|
|
800389c: d057 beq.n 800394e <HAL_TIM_ConfigClockSource+0x146>
|
|
800389e: d900 bls.n 80038a2 <HAL_TIM_ConfigClockSource+0x9a>
|
|
80038a0: e06e b.n 8003980 <HAL_TIM_ConfigClockSource+0x178>
|
|
80038a2: 2b30 cmp r3, #48 ; 0x30
|
|
80038a4: d063 beq.n 800396e <HAL_TIM_ConfigClockSource+0x166>
|
|
80038a6: d86b bhi.n 8003980 <HAL_TIM_ConfigClockSource+0x178>
|
|
80038a8: 2b20 cmp r3, #32
|
|
80038aa: d060 beq.n 800396e <HAL_TIM_ConfigClockSource+0x166>
|
|
80038ac: d868 bhi.n 8003980 <HAL_TIM_ConfigClockSource+0x178>
|
|
80038ae: 2b00 cmp r3, #0
|
|
80038b0: d05d beq.n 800396e <HAL_TIM_ConfigClockSource+0x166>
|
|
80038b2: 2b10 cmp r3, #16
|
|
80038b4: d05b beq.n 800396e <HAL_TIM_ConfigClockSource+0x166>
|
|
80038b6: e063 b.n 8003980 <HAL_TIM_ConfigClockSource+0x178>
|
|
assert_param(IS_TIM_CLOCKPRESCALER(sClockSourceConfig->ClockPrescaler));
|
|
assert_param(IS_TIM_CLOCKPOLARITY(sClockSourceConfig->ClockPolarity));
|
|
assert_param(IS_TIM_CLOCKFILTER(sClockSourceConfig->ClockFilter));
|
|
|
|
/* Configure the ETR Clock source */
|
|
TIM_ETR_SetConfig(htim->Instance,
|
|
80038b8: 687b ldr r3, [r7, #4]
|
|
80038ba: 6818 ldr r0, [r3, #0]
|
|
80038bc: 683b ldr r3, [r7, #0]
|
|
80038be: 6899 ldr r1, [r3, #8]
|
|
80038c0: 683b ldr r3, [r7, #0]
|
|
80038c2: 685a ldr r2, [r3, #4]
|
|
80038c4: 683b ldr r3, [r7, #0]
|
|
80038c6: 68db ldr r3, [r3, #12]
|
|
80038c8: f000 fa3a bl 8003d40 <TIM_ETR_SetConfig>
|
|
sClockSourceConfig->ClockPrescaler,
|
|
sClockSourceConfig->ClockPolarity,
|
|
sClockSourceConfig->ClockFilter);
|
|
|
|
/* Select the External clock mode1 and the ETRF trigger */
|
|
tmpsmcr = htim->Instance->SMCR;
|
|
80038cc: 687b ldr r3, [r7, #4]
|
|
80038ce: 681b ldr r3, [r3, #0]
|
|
80038d0: 689b ldr r3, [r3, #8]
|
|
80038d2: 60bb str r3, [r7, #8]
|
|
tmpsmcr |= (TIM_SLAVEMODE_EXTERNAL1 | TIM_CLOCKSOURCE_ETRMODE1);
|
|
80038d4: 68bb ldr r3, [r7, #8]
|
|
80038d6: 2277 movs r2, #119 ; 0x77
|
|
80038d8: 4313 orrs r3, r2
|
|
80038da: 60bb str r3, [r7, #8]
|
|
/* Write to TIMx SMCR */
|
|
htim->Instance->SMCR = tmpsmcr;
|
|
80038dc: 687b ldr r3, [r7, #4]
|
|
80038de: 681b ldr r3, [r3, #0]
|
|
80038e0: 68ba ldr r2, [r7, #8]
|
|
80038e2: 609a str r2, [r3, #8]
|
|
break;
|
|
80038e4: e052 b.n 800398c <HAL_TIM_ConfigClockSource+0x184>
|
|
assert_param(IS_TIM_CLOCKPRESCALER(sClockSourceConfig->ClockPrescaler));
|
|
assert_param(IS_TIM_CLOCKPOLARITY(sClockSourceConfig->ClockPolarity));
|
|
assert_param(IS_TIM_CLOCKFILTER(sClockSourceConfig->ClockFilter));
|
|
|
|
/* Configure the ETR Clock source */
|
|
TIM_ETR_SetConfig(htim->Instance,
|
|
80038e6: 687b ldr r3, [r7, #4]
|
|
80038e8: 6818 ldr r0, [r3, #0]
|
|
80038ea: 683b ldr r3, [r7, #0]
|
|
80038ec: 6899 ldr r1, [r3, #8]
|
|
80038ee: 683b ldr r3, [r7, #0]
|
|
80038f0: 685a ldr r2, [r3, #4]
|
|
80038f2: 683b ldr r3, [r7, #0]
|
|
80038f4: 68db ldr r3, [r3, #12]
|
|
80038f6: f000 fa23 bl 8003d40 <TIM_ETR_SetConfig>
|
|
sClockSourceConfig->ClockPrescaler,
|
|
sClockSourceConfig->ClockPolarity,
|
|
sClockSourceConfig->ClockFilter);
|
|
/* Enable the External clock mode2 */
|
|
htim->Instance->SMCR |= TIM_SMCR_ECE;
|
|
80038fa: 687b ldr r3, [r7, #4]
|
|
80038fc: 681b ldr r3, [r3, #0]
|
|
80038fe: 689a ldr r2, [r3, #8]
|
|
8003900: 687b ldr r3, [r7, #4]
|
|
8003902: 681b ldr r3, [r3, #0]
|
|
8003904: 2180 movs r1, #128 ; 0x80
|
|
8003906: 01c9 lsls r1, r1, #7
|
|
8003908: 430a orrs r2, r1
|
|
800390a: 609a str r2, [r3, #8]
|
|
break;
|
|
800390c: e03e b.n 800398c <HAL_TIM_ConfigClockSource+0x184>
|
|
|
|
/* Check TI1 input conditioning related parameters */
|
|
assert_param(IS_TIM_CLOCKPOLARITY(sClockSourceConfig->ClockPolarity));
|
|
assert_param(IS_TIM_CLOCKFILTER(sClockSourceConfig->ClockFilter));
|
|
|
|
TIM_TI1_ConfigInputStage(htim->Instance,
|
|
800390e: 687b ldr r3, [r7, #4]
|
|
8003910: 6818 ldr r0, [r3, #0]
|
|
8003912: 683b ldr r3, [r7, #0]
|
|
8003914: 6859 ldr r1, [r3, #4]
|
|
8003916: 683b ldr r3, [r7, #0]
|
|
8003918: 68db ldr r3, [r3, #12]
|
|
800391a: 001a movs r2, r3
|
|
800391c: f000 f996 bl 8003c4c <TIM_TI1_ConfigInputStage>
|
|
sClockSourceConfig->ClockPolarity,
|
|
sClockSourceConfig->ClockFilter);
|
|
TIM_ITRx_SetConfig(htim->Instance, TIM_CLOCKSOURCE_TI1);
|
|
8003920: 687b ldr r3, [r7, #4]
|
|
8003922: 681b ldr r3, [r3, #0]
|
|
8003924: 2150 movs r1, #80 ; 0x50
|
|
8003926: 0018 movs r0, r3
|
|
8003928: f000 f9f0 bl 8003d0c <TIM_ITRx_SetConfig>
|
|
break;
|
|
800392c: e02e b.n 800398c <HAL_TIM_ConfigClockSource+0x184>
|
|
|
|
/* Check TI2 input conditioning related parameters */
|
|
assert_param(IS_TIM_CLOCKPOLARITY(sClockSourceConfig->ClockPolarity));
|
|
assert_param(IS_TIM_CLOCKFILTER(sClockSourceConfig->ClockFilter));
|
|
|
|
TIM_TI2_ConfigInputStage(htim->Instance,
|
|
800392e: 687b ldr r3, [r7, #4]
|
|
8003930: 6818 ldr r0, [r3, #0]
|
|
8003932: 683b ldr r3, [r7, #0]
|
|
8003934: 6859 ldr r1, [r3, #4]
|
|
8003936: 683b ldr r3, [r7, #0]
|
|
8003938: 68db ldr r3, [r3, #12]
|
|
800393a: 001a movs r2, r3
|
|
800393c: f000 f9b4 bl 8003ca8 <TIM_TI2_ConfigInputStage>
|
|
sClockSourceConfig->ClockPolarity,
|
|
sClockSourceConfig->ClockFilter);
|
|
TIM_ITRx_SetConfig(htim->Instance, TIM_CLOCKSOURCE_TI2);
|
|
8003940: 687b ldr r3, [r7, #4]
|
|
8003942: 681b ldr r3, [r3, #0]
|
|
8003944: 2160 movs r1, #96 ; 0x60
|
|
8003946: 0018 movs r0, r3
|
|
8003948: f000 f9e0 bl 8003d0c <TIM_ITRx_SetConfig>
|
|
break;
|
|
800394c: e01e b.n 800398c <HAL_TIM_ConfigClockSource+0x184>
|
|
|
|
/* Check TI1 input conditioning related parameters */
|
|
assert_param(IS_TIM_CLOCKPOLARITY(sClockSourceConfig->ClockPolarity));
|
|
assert_param(IS_TIM_CLOCKFILTER(sClockSourceConfig->ClockFilter));
|
|
|
|
TIM_TI1_ConfigInputStage(htim->Instance,
|
|
800394e: 687b ldr r3, [r7, #4]
|
|
8003950: 6818 ldr r0, [r3, #0]
|
|
8003952: 683b ldr r3, [r7, #0]
|
|
8003954: 6859 ldr r1, [r3, #4]
|
|
8003956: 683b ldr r3, [r7, #0]
|
|
8003958: 68db ldr r3, [r3, #12]
|
|
800395a: 001a movs r2, r3
|
|
800395c: f000 f976 bl 8003c4c <TIM_TI1_ConfigInputStage>
|
|
sClockSourceConfig->ClockPolarity,
|
|
sClockSourceConfig->ClockFilter);
|
|
TIM_ITRx_SetConfig(htim->Instance, TIM_CLOCKSOURCE_TI1ED);
|
|
8003960: 687b ldr r3, [r7, #4]
|
|
8003962: 681b ldr r3, [r3, #0]
|
|
8003964: 2140 movs r1, #64 ; 0x40
|
|
8003966: 0018 movs r0, r3
|
|
8003968: f000 f9d0 bl 8003d0c <TIM_ITRx_SetConfig>
|
|
break;
|
|
800396c: e00e b.n 800398c <HAL_TIM_ConfigClockSource+0x184>
|
|
case TIM_CLOCKSOURCE_ITR3:
|
|
{
|
|
/* Check whether or not the timer instance supports internal trigger input */
|
|
assert_param(IS_TIM_CLOCKSOURCE_ITRX_INSTANCE(htim->Instance));
|
|
|
|
TIM_ITRx_SetConfig(htim->Instance, sClockSourceConfig->ClockSource);
|
|
800396e: 687b ldr r3, [r7, #4]
|
|
8003970: 681a ldr r2, [r3, #0]
|
|
8003972: 683b ldr r3, [r7, #0]
|
|
8003974: 681b ldr r3, [r3, #0]
|
|
8003976: 0019 movs r1, r3
|
|
8003978: 0010 movs r0, r2
|
|
800397a: f000 f9c7 bl 8003d0c <TIM_ITRx_SetConfig>
|
|
break;
|
|
800397e: e005 b.n 800398c <HAL_TIM_ConfigClockSource+0x184>
|
|
}
|
|
|
|
default:
|
|
status = HAL_ERROR;
|
|
8003980: 230f movs r3, #15
|
|
8003982: 18fb adds r3, r7, r3
|
|
8003984: 2201 movs r2, #1
|
|
8003986: 701a strb r2, [r3, #0]
|
|
break;
|
|
8003988: e000 b.n 800398c <HAL_TIM_ConfigClockSource+0x184>
|
|
break;
|
|
800398a: 46c0 nop ; (mov r8, r8)
|
|
}
|
|
htim->State = HAL_TIM_STATE_READY;
|
|
800398c: 687b ldr r3, [r7, #4]
|
|
800398e: 2239 movs r2, #57 ; 0x39
|
|
8003990: 2101 movs r1, #1
|
|
8003992: 5499 strb r1, [r3, r2]
|
|
|
|
__HAL_UNLOCK(htim);
|
|
8003994: 687b ldr r3, [r7, #4]
|
|
8003996: 2238 movs r2, #56 ; 0x38
|
|
8003998: 2100 movs r1, #0
|
|
800399a: 5499 strb r1, [r3, r2]
|
|
|
|
return status;
|
|
800399c: 230f movs r3, #15
|
|
800399e: 18fb adds r3, r7, r3
|
|
80039a0: 781b ldrb r3, [r3, #0]
|
|
}
|
|
80039a2: 0018 movs r0, r3
|
|
80039a4: 46bd mov sp, r7
|
|
80039a6: b004 add sp, #16
|
|
80039a8: bd80 pop {r7, pc}
|
|
80039aa: 46c0 nop ; (mov r8, r8)
|
|
80039ac: ffff00ff .word 0xffff00ff
|
|
|
|
080039b0 <TIM_Base_SetConfig>:
|
|
* @param TIMx TIM peripheral
|
|
* @param Structure TIM Base configuration structure
|
|
* @retval None
|
|
*/
|
|
static void TIM_Base_SetConfig(TIM_TypeDef *TIMx, TIM_Base_InitTypeDef *Structure)
|
|
{
|
|
80039b0: b580 push {r7, lr}
|
|
80039b2: b084 sub sp, #16
|
|
80039b4: af00 add r7, sp, #0
|
|
80039b6: 6078 str r0, [r7, #4]
|
|
80039b8: 6039 str r1, [r7, #0]
|
|
uint32_t tmpcr1;
|
|
tmpcr1 = TIMx->CR1;
|
|
80039ba: 687b ldr r3, [r7, #4]
|
|
80039bc: 681b ldr r3, [r3, #0]
|
|
80039be: 60fb str r3, [r7, #12]
|
|
|
|
/* Set TIM Time Base Unit parameters ---------------------------------------*/
|
|
if (IS_TIM_COUNTER_MODE_SELECT_INSTANCE(TIMx))
|
|
80039c0: 687a ldr r2, [r7, #4]
|
|
80039c2: 2380 movs r3, #128 ; 0x80
|
|
80039c4: 05db lsls r3, r3, #23
|
|
80039c6: 429a cmp r2, r3
|
|
80039c8: d003 beq.n 80039d2 <TIM_Base_SetConfig+0x22>
|
|
80039ca: 687b ldr r3, [r7, #4]
|
|
80039cc: 4a1b ldr r2, [pc, #108] ; (8003a3c <TIM_Base_SetConfig+0x8c>)
|
|
80039ce: 4293 cmp r3, r2
|
|
80039d0: d108 bne.n 80039e4 <TIM_Base_SetConfig+0x34>
|
|
{
|
|
/* Select the Counter Mode */
|
|
tmpcr1 &= ~(TIM_CR1_DIR | TIM_CR1_CMS);
|
|
80039d2: 68fb ldr r3, [r7, #12]
|
|
80039d4: 2270 movs r2, #112 ; 0x70
|
|
80039d6: 4393 bics r3, r2
|
|
80039d8: 60fb str r3, [r7, #12]
|
|
tmpcr1 |= Structure->CounterMode;
|
|
80039da: 683b ldr r3, [r7, #0]
|
|
80039dc: 685b ldr r3, [r3, #4]
|
|
80039de: 68fa ldr r2, [r7, #12]
|
|
80039e0: 4313 orrs r3, r2
|
|
80039e2: 60fb str r3, [r7, #12]
|
|
}
|
|
|
|
if (IS_TIM_CLOCK_DIVISION_INSTANCE(TIMx))
|
|
80039e4: 687a ldr r2, [r7, #4]
|
|
80039e6: 2380 movs r3, #128 ; 0x80
|
|
80039e8: 05db lsls r3, r3, #23
|
|
80039ea: 429a cmp r2, r3
|
|
80039ec: d003 beq.n 80039f6 <TIM_Base_SetConfig+0x46>
|
|
80039ee: 687b ldr r3, [r7, #4]
|
|
80039f0: 4a12 ldr r2, [pc, #72] ; (8003a3c <TIM_Base_SetConfig+0x8c>)
|
|
80039f2: 4293 cmp r3, r2
|
|
80039f4: d108 bne.n 8003a08 <TIM_Base_SetConfig+0x58>
|
|
{
|
|
/* Set the clock division */
|
|
tmpcr1 &= ~TIM_CR1_CKD;
|
|
80039f6: 68fb ldr r3, [r7, #12]
|
|
80039f8: 4a11 ldr r2, [pc, #68] ; (8003a40 <TIM_Base_SetConfig+0x90>)
|
|
80039fa: 4013 ands r3, r2
|
|
80039fc: 60fb str r3, [r7, #12]
|
|
tmpcr1 |= (uint32_t)Structure->ClockDivision;
|
|
80039fe: 683b ldr r3, [r7, #0]
|
|
8003a00: 68db ldr r3, [r3, #12]
|
|
8003a02: 68fa ldr r2, [r7, #12]
|
|
8003a04: 4313 orrs r3, r2
|
|
8003a06: 60fb str r3, [r7, #12]
|
|
}
|
|
|
|
/* Set the auto-reload preload */
|
|
MODIFY_REG(tmpcr1, TIM_CR1_ARPE, Structure->AutoReloadPreload);
|
|
8003a08: 68fb ldr r3, [r7, #12]
|
|
8003a0a: 2280 movs r2, #128 ; 0x80
|
|
8003a0c: 4393 bics r3, r2
|
|
8003a0e: 001a movs r2, r3
|
|
8003a10: 683b ldr r3, [r7, #0]
|
|
8003a12: 691b ldr r3, [r3, #16]
|
|
8003a14: 4313 orrs r3, r2
|
|
8003a16: 60fb str r3, [r7, #12]
|
|
|
|
TIMx->CR1 = tmpcr1;
|
|
8003a18: 687b ldr r3, [r7, #4]
|
|
8003a1a: 68fa ldr r2, [r7, #12]
|
|
8003a1c: 601a str r2, [r3, #0]
|
|
|
|
/* Set the Autoreload value */
|
|
TIMx->ARR = (uint32_t)Structure->Period ;
|
|
8003a1e: 683b ldr r3, [r7, #0]
|
|
8003a20: 689a ldr r2, [r3, #8]
|
|
8003a22: 687b ldr r3, [r7, #4]
|
|
8003a24: 62da str r2, [r3, #44] ; 0x2c
|
|
|
|
/* Set the Prescaler value */
|
|
TIMx->PSC = Structure->Prescaler;
|
|
8003a26: 683b ldr r3, [r7, #0]
|
|
8003a28: 681a ldr r2, [r3, #0]
|
|
8003a2a: 687b ldr r3, [r7, #4]
|
|
8003a2c: 629a str r2, [r3, #40] ; 0x28
|
|
|
|
/* Generate an update event to reload the Prescaler
|
|
and the repetition counter (only for advanced timer) value immediately */
|
|
TIMx->EGR = TIM_EGR_UG;
|
|
8003a2e: 687b ldr r3, [r7, #4]
|
|
8003a30: 2201 movs r2, #1
|
|
8003a32: 615a str r2, [r3, #20]
|
|
}
|
|
8003a34: 46c0 nop ; (mov r8, r8)
|
|
8003a36: 46bd mov sp, r7
|
|
8003a38: b004 add sp, #16
|
|
8003a3a: bd80 pop {r7, pc}
|
|
8003a3c: 40010800 .word 0x40010800
|
|
8003a40: fffffcff .word 0xfffffcff
|
|
|
|
08003a44 <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)
|
|
{
|
|
8003a44: b580 push {r7, lr}
|
|
8003a46: b086 sub sp, #24
|
|
8003a48: af00 add r7, sp, #0
|
|
8003a4a: 6078 str r0, [r7, #4]
|
|
8003a4c: 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;
|
|
8003a4e: 687b ldr r3, [r7, #4]
|
|
8003a50: 6a1b ldr r3, [r3, #32]
|
|
8003a52: 2201 movs r2, #1
|
|
8003a54: 4393 bics r3, r2
|
|
8003a56: 001a movs r2, r3
|
|
8003a58: 687b ldr r3, [r7, #4]
|
|
8003a5a: 621a str r2, [r3, #32]
|
|
|
|
/* Get the TIMx CCER register value */
|
|
tmpccer = TIMx->CCER;
|
|
8003a5c: 687b ldr r3, [r7, #4]
|
|
8003a5e: 6a1b ldr r3, [r3, #32]
|
|
8003a60: 617b str r3, [r7, #20]
|
|
/* Get the TIMx CR2 register value */
|
|
tmpcr2 = TIMx->CR2;
|
|
8003a62: 687b ldr r3, [r7, #4]
|
|
8003a64: 685b ldr r3, [r3, #4]
|
|
8003a66: 613b str r3, [r7, #16]
|
|
|
|
/* Get the TIMx CCMR1 register value */
|
|
tmpccmrx = TIMx->CCMR1;
|
|
8003a68: 687b ldr r3, [r7, #4]
|
|
8003a6a: 699b ldr r3, [r3, #24]
|
|
8003a6c: 60fb str r3, [r7, #12]
|
|
|
|
/* Reset the Output Compare Mode Bits */
|
|
tmpccmrx &= ~TIM_CCMR1_OC1M;
|
|
8003a6e: 68fb ldr r3, [r7, #12]
|
|
8003a70: 2270 movs r2, #112 ; 0x70
|
|
8003a72: 4393 bics r3, r2
|
|
8003a74: 60fb str r3, [r7, #12]
|
|
tmpccmrx &= ~TIM_CCMR1_CC1S;
|
|
8003a76: 68fb ldr r3, [r7, #12]
|
|
8003a78: 2203 movs r2, #3
|
|
8003a7a: 4393 bics r3, r2
|
|
8003a7c: 60fb str r3, [r7, #12]
|
|
/* Select the Output Compare Mode */
|
|
tmpccmrx |= OC_Config->OCMode;
|
|
8003a7e: 683b ldr r3, [r7, #0]
|
|
8003a80: 681b ldr r3, [r3, #0]
|
|
8003a82: 68fa ldr r2, [r7, #12]
|
|
8003a84: 4313 orrs r3, r2
|
|
8003a86: 60fb str r3, [r7, #12]
|
|
|
|
/* Reset the Output Polarity level */
|
|
tmpccer &= ~TIM_CCER_CC1P;
|
|
8003a88: 697b ldr r3, [r7, #20]
|
|
8003a8a: 2202 movs r2, #2
|
|
8003a8c: 4393 bics r3, r2
|
|
8003a8e: 617b str r3, [r7, #20]
|
|
/* Set the Output Compare Polarity */
|
|
tmpccer |= OC_Config->OCPolarity;
|
|
8003a90: 683b ldr r3, [r7, #0]
|
|
8003a92: 689b ldr r3, [r3, #8]
|
|
8003a94: 697a ldr r2, [r7, #20]
|
|
8003a96: 4313 orrs r3, r2
|
|
8003a98: 617b str r3, [r7, #20]
|
|
|
|
/* Write to TIMx CR2 */
|
|
TIMx->CR2 = tmpcr2;
|
|
8003a9a: 687b ldr r3, [r7, #4]
|
|
8003a9c: 693a ldr r2, [r7, #16]
|
|
8003a9e: 605a str r2, [r3, #4]
|
|
|
|
/* Write to TIMx CCMR1 */
|
|
TIMx->CCMR1 = tmpccmrx;
|
|
8003aa0: 687b ldr r3, [r7, #4]
|
|
8003aa2: 68fa ldr r2, [r7, #12]
|
|
8003aa4: 619a str r2, [r3, #24]
|
|
|
|
/* Set the Capture Compare Register value */
|
|
TIMx->CCR1 = OC_Config->Pulse;
|
|
8003aa6: 683b ldr r3, [r7, #0]
|
|
8003aa8: 685a ldr r2, [r3, #4]
|
|
8003aaa: 687b ldr r3, [r7, #4]
|
|
8003aac: 635a str r2, [r3, #52] ; 0x34
|
|
|
|
/* Write to TIMx CCER */
|
|
TIMx->CCER = tmpccer;
|
|
8003aae: 687b ldr r3, [r7, #4]
|
|
8003ab0: 697a ldr r2, [r7, #20]
|
|
8003ab2: 621a str r2, [r3, #32]
|
|
}
|
|
8003ab4: 46c0 nop ; (mov r8, r8)
|
|
8003ab6: 46bd mov sp, r7
|
|
8003ab8: b006 add sp, #24
|
|
8003aba: bd80 pop {r7, pc}
|
|
|
|
08003abc <TIM_OC2_SetConfig>:
|
|
* @param TIMx to select the TIM peripheral
|
|
* @param OC_Config The output configuration structure
|
|
* @retval None
|
|
*/
|
|
static void TIM_OC2_SetConfig(TIM_TypeDef *TIMx, TIM_OC_InitTypeDef *OC_Config)
|
|
{
|
|
8003abc: b580 push {r7, lr}
|
|
8003abe: b086 sub sp, #24
|
|
8003ac0: af00 add r7, sp, #0
|
|
8003ac2: 6078 str r0, [r7, #4]
|
|
8003ac4: 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;
|
|
8003ac6: 687b ldr r3, [r7, #4]
|
|
8003ac8: 6a1b ldr r3, [r3, #32]
|
|
8003aca: 2210 movs r2, #16
|
|
8003acc: 4393 bics r3, r2
|
|
8003ace: 001a movs r2, r3
|
|
8003ad0: 687b ldr r3, [r7, #4]
|
|
8003ad2: 621a str r2, [r3, #32]
|
|
|
|
/* Get the TIMx CCER register value */
|
|
tmpccer = TIMx->CCER;
|
|
8003ad4: 687b ldr r3, [r7, #4]
|
|
8003ad6: 6a1b ldr r3, [r3, #32]
|
|
8003ad8: 617b str r3, [r7, #20]
|
|
/* Get the TIMx CR2 register value */
|
|
tmpcr2 = TIMx->CR2;
|
|
8003ada: 687b ldr r3, [r7, #4]
|
|
8003adc: 685b ldr r3, [r3, #4]
|
|
8003ade: 613b str r3, [r7, #16]
|
|
|
|
/* Get the TIMx CCMR1 register value */
|
|
tmpccmrx = TIMx->CCMR1;
|
|
8003ae0: 687b ldr r3, [r7, #4]
|
|
8003ae2: 699b ldr r3, [r3, #24]
|
|
8003ae4: 60fb str r3, [r7, #12]
|
|
|
|
/* Reset the Output Compare mode and Capture/Compare selection Bits */
|
|
tmpccmrx &= ~TIM_CCMR1_OC2M;
|
|
8003ae6: 68fb ldr r3, [r7, #12]
|
|
8003ae8: 4a13 ldr r2, [pc, #76] ; (8003b38 <TIM_OC2_SetConfig+0x7c>)
|
|
8003aea: 4013 ands r3, r2
|
|
8003aec: 60fb str r3, [r7, #12]
|
|
tmpccmrx &= ~TIM_CCMR1_CC2S;
|
|
8003aee: 68fb ldr r3, [r7, #12]
|
|
8003af0: 4a12 ldr r2, [pc, #72] ; (8003b3c <TIM_OC2_SetConfig+0x80>)
|
|
8003af2: 4013 ands r3, r2
|
|
8003af4: 60fb str r3, [r7, #12]
|
|
|
|
/* Select the Output Compare Mode */
|
|
tmpccmrx |= (OC_Config->OCMode << 8U);
|
|
8003af6: 683b ldr r3, [r7, #0]
|
|
8003af8: 681b ldr r3, [r3, #0]
|
|
8003afa: 021b lsls r3, r3, #8
|
|
8003afc: 68fa ldr r2, [r7, #12]
|
|
8003afe: 4313 orrs r3, r2
|
|
8003b00: 60fb str r3, [r7, #12]
|
|
|
|
/* Reset the Output Polarity level */
|
|
tmpccer &= ~TIM_CCER_CC2P;
|
|
8003b02: 697b ldr r3, [r7, #20]
|
|
8003b04: 2220 movs r2, #32
|
|
8003b06: 4393 bics r3, r2
|
|
8003b08: 617b str r3, [r7, #20]
|
|
/* Set the Output Compare Polarity */
|
|
tmpccer |= (OC_Config->OCPolarity << 4U);
|
|
8003b0a: 683b ldr r3, [r7, #0]
|
|
8003b0c: 689b ldr r3, [r3, #8]
|
|
8003b0e: 011b lsls r3, r3, #4
|
|
8003b10: 697a ldr r2, [r7, #20]
|
|
8003b12: 4313 orrs r3, r2
|
|
8003b14: 617b str r3, [r7, #20]
|
|
|
|
/* Write to TIMx CR2 */
|
|
TIMx->CR2 = tmpcr2;
|
|
8003b16: 687b ldr r3, [r7, #4]
|
|
8003b18: 693a ldr r2, [r7, #16]
|
|
8003b1a: 605a str r2, [r3, #4]
|
|
|
|
/* Write to TIMx CCMR1 */
|
|
TIMx->CCMR1 = tmpccmrx;
|
|
8003b1c: 687b ldr r3, [r7, #4]
|
|
8003b1e: 68fa ldr r2, [r7, #12]
|
|
8003b20: 619a str r2, [r3, #24]
|
|
|
|
/* Set the Capture Compare Register value */
|
|
TIMx->CCR2 = OC_Config->Pulse;
|
|
8003b22: 683b ldr r3, [r7, #0]
|
|
8003b24: 685a ldr r2, [r3, #4]
|
|
8003b26: 687b ldr r3, [r7, #4]
|
|
8003b28: 639a str r2, [r3, #56] ; 0x38
|
|
|
|
/* Write to TIMx CCER */
|
|
TIMx->CCER = tmpccer;
|
|
8003b2a: 687b ldr r3, [r7, #4]
|
|
8003b2c: 697a ldr r2, [r7, #20]
|
|
8003b2e: 621a str r2, [r3, #32]
|
|
}
|
|
8003b30: 46c0 nop ; (mov r8, r8)
|
|
8003b32: 46bd mov sp, r7
|
|
8003b34: b006 add sp, #24
|
|
8003b36: bd80 pop {r7, pc}
|
|
8003b38: ffff8fff .word 0xffff8fff
|
|
8003b3c: fffffcff .word 0xfffffcff
|
|
|
|
08003b40 <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)
|
|
{
|
|
8003b40: b580 push {r7, lr}
|
|
8003b42: b086 sub sp, #24
|
|
8003b44: af00 add r7, sp, #0
|
|
8003b46: 6078 str r0, [r7, #4]
|
|
8003b48: 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;
|
|
8003b4a: 687b ldr r3, [r7, #4]
|
|
8003b4c: 6a1b ldr r3, [r3, #32]
|
|
8003b4e: 4a1a ldr r2, [pc, #104] ; (8003bb8 <TIM_OC3_SetConfig+0x78>)
|
|
8003b50: 401a ands r2, r3
|
|
8003b52: 687b ldr r3, [r7, #4]
|
|
8003b54: 621a str r2, [r3, #32]
|
|
|
|
/* Get the TIMx CCER register value */
|
|
tmpccer = TIMx->CCER;
|
|
8003b56: 687b ldr r3, [r7, #4]
|
|
8003b58: 6a1b ldr r3, [r3, #32]
|
|
8003b5a: 617b str r3, [r7, #20]
|
|
/* Get the TIMx CR2 register value */
|
|
tmpcr2 = TIMx->CR2;
|
|
8003b5c: 687b ldr r3, [r7, #4]
|
|
8003b5e: 685b ldr r3, [r3, #4]
|
|
8003b60: 613b str r3, [r7, #16]
|
|
|
|
/* Get the TIMx CCMR2 register value */
|
|
tmpccmrx = TIMx->CCMR2;
|
|
8003b62: 687b ldr r3, [r7, #4]
|
|
8003b64: 69db ldr r3, [r3, #28]
|
|
8003b66: 60fb str r3, [r7, #12]
|
|
|
|
/* Reset the Output Compare mode and Capture/Compare selection Bits */
|
|
tmpccmrx &= ~TIM_CCMR2_OC3M;
|
|
8003b68: 68fb ldr r3, [r7, #12]
|
|
8003b6a: 2270 movs r2, #112 ; 0x70
|
|
8003b6c: 4393 bics r3, r2
|
|
8003b6e: 60fb str r3, [r7, #12]
|
|
tmpccmrx &= ~TIM_CCMR2_CC3S;
|
|
8003b70: 68fb ldr r3, [r7, #12]
|
|
8003b72: 2203 movs r2, #3
|
|
8003b74: 4393 bics r3, r2
|
|
8003b76: 60fb str r3, [r7, #12]
|
|
/* Select the Output Compare Mode */
|
|
tmpccmrx |= OC_Config->OCMode;
|
|
8003b78: 683b ldr r3, [r7, #0]
|
|
8003b7a: 681b ldr r3, [r3, #0]
|
|
8003b7c: 68fa ldr r2, [r7, #12]
|
|
8003b7e: 4313 orrs r3, r2
|
|
8003b80: 60fb str r3, [r7, #12]
|
|
|
|
/* Reset the Output Polarity level */
|
|
tmpccer &= ~TIM_CCER_CC3P;
|
|
8003b82: 697b ldr r3, [r7, #20]
|
|
8003b84: 4a0d ldr r2, [pc, #52] ; (8003bbc <TIM_OC3_SetConfig+0x7c>)
|
|
8003b86: 4013 ands r3, r2
|
|
8003b88: 617b str r3, [r7, #20]
|
|
/* Set the Output Compare Polarity */
|
|
tmpccer |= (OC_Config->OCPolarity << 8U);
|
|
8003b8a: 683b ldr r3, [r7, #0]
|
|
8003b8c: 689b ldr r3, [r3, #8]
|
|
8003b8e: 021b lsls r3, r3, #8
|
|
8003b90: 697a ldr r2, [r7, #20]
|
|
8003b92: 4313 orrs r3, r2
|
|
8003b94: 617b str r3, [r7, #20]
|
|
|
|
/* Write to TIMx CR2 */
|
|
TIMx->CR2 = tmpcr2;
|
|
8003b96: 687b ldr r3, [r7, #4]
|
|
8003b98: 693a ldr r2, [r7, #16]
|
|
8003b9a: 605a str r2, [r3, #4]
|
|
|
|
/* Write to TIMx CCMR2 */
|
|
TIMx->CCMR2 = tmpccmrx;
|
|
8003b9c: 687b ldr r3, [r7, #4]
|
|
8003b9e: 68fa ldr r2, [r7, #12]
|
|
8003ba0: 61da str r2, [r3, #28]
|
|
|
|
/* Set the Capture Compare Register value */
|
|
TIMx->CCR3 = OC_Config->Pulse;
|
|
8003ba2: 683b ldr r3, [r7, #0]
|
|
8003ba4: 685a ldr r2, [r3, #4]
|
|
8003ba6: 687b ldr r3, [r7, #4]
|
|
8003ba8: 63da str r2, [r3, #60] ; 0x3c
|
|
|
|
/* Write to TIMx CCER */
|
|
TIMx->CCER = tmpccer;
|
|
8003baa: 687b ldr r3, [r7, #4]
|
|
8003bac: 697a ldr r2, [r7, #20]
|
|
8003bae: 621a str r2, [r3, #32]
|
|
}
|
|
8003bb0: 46c0 nop ; (mov r8, r8)
|
|
8003bb2: 46bd mov sp, r7
|
|
8003bb4: b006 add sp, #24
|
|
8003bb6: bd80 pop {r7, pc}
|
|
8003bb8: fffffeff .word 0xfffffeff
|
|
8003bbc: fffffdff .word 0xfffffdff
|
|
|
|
08003bc0 <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)
|
|
{
|
|
8003bc0: b580 push {r7, lr}
|
|
8003bc2: b086 sub sp, #24
|
|
8003bc4: af00 add r7, sp, #0
|
|
8003bc6: 6078 str r0, [r7, #4]
|
|
8003bc8: 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;
|
|
8003bca: 687b ldr r3, [r7, #4]
|
|
8003bcc: 6a1b ldr r3, [r3, #32]
|
|
8003bce: 4a1b ldr r2, [pc, #108] ; (8003c3c <TIM_OC4_SetConfig+0x7c>)
|
|
8003bd0: 401a ands r2, r3
|
|
8003bd2: 687b ldr r3, [r7, #4]
|
|
8003bd4: 621a str r2, [r3, #32]
|
|
|
|
/* Get the TIMx CCER register value */
|
|
tmpccer = TIMx->CCER;
|
|
8003bd6: 687b ldr r3, [r7, #4]
|
|
8003bd8: 6a1b ldr r3, [r3, #32]
|
|
8003bda: 617b str r3, [r7, #20]
|
|
/* Get the TIMx CR2 register value */
|
|
tmpcr2 = TIMx->CR2;
|
|
8003bdc: 687b ldr r3, [r7, #4]
|
|
8003bde: 685b ldr r3, [r3, #4]
|
|
8003be0: 613b str r3, [r7, #16]
|
|
|
|
/* Get the TIMx CCMR2 register value */
|
|
tmpccmrx = TIMx->CCMR2;
|
|
8003be2: 687b ldr r3, [r7, #4]
|
|
8003be4: 69db ldr r3, [r3, #28]
|
|
8003be6: 60fb str r3, [r7, #12]
|
|
|
|
/* Reset the Output Compare mode and Capture/Compare selection Bits */
|
|
tmpccmrx &= ~TIM_CCMR2_OC4M;
|
|
8003be8: 68fb ldr r3, [r7, #12]
|
|
8003bea: 4a15 ldr r2, [pc, #84] ; (8003c40 <TIM_OC4_SetConfig+0x80>)
|
|
8003bec: 4013 ands r3, r2
|
|
8003bee: 60fb str r3, [r7, #12]
|
|
tmpccmrx &= ~TIM_CCMR2_CC4S;
|
|
8003bf0: 68fb ldr r3, [r7, #12]
|
|
8003bf2: 4a14 ldr r2, [pc, #80] ; (8003c44 <TIM_OC4_SetConfig+0x84>)
|
|
8003bf4: 4013 ands r3, r2
|
|
8003bf6: 60fb str r3, [r7, #12]
|
|
|
|
/* Select the Output Compare Mode */
|
|
tmpccmrx |= (OC_Config->OCMode << 8U);
|
|
8003bf8: 683b ldr r3, [r7, #0]
|
|
8003bfa: 681b ldr r3, [r3, #0]
|
|
8003bfc: 021b lsls r3, r3, #8
|
|
8003bfe: 68fa ldr r2, [r7, #12]
|
|
8003c00: 4313 orrs r3, r2
|
|
8003c02: 60fb str r3, [r7, #12]
|
|
|
|
/* Reset the Output Polarity level */
|
|
tmpccer &= ~TIM_CCER_CC4P;
|
|
8003c04: 697b ldr r3, [r7, #20]
|
|
8003c06: 4a10 ldr r2, [pc, #64] ; (8003c48 <TIM_OC4_SetConfig+0x88>)
|
|
8003c08: 4013 ands r3, r2
|
|
8003c0a: 617b str r3, [r7, #20]
|
|
/* Set the Output Compare Polarity */
|
|
tmpccer |= (OC_Config->OCPolarity << 12U);
|
|
8003c0c: 683b ldr r3, [r7, #0]
|
|
8003c0e: 689b ldr r3, [r3, #8]
|
|
8003c10: 031b lsls r3, r3, #12
|
|
8003c12: 697a ldr r2, [r7, #20]
|
|
8003c14: 4313 orrs r3, r2
|
|
8003c16: 617b str r3, [r7, #20]
|
|
|
|
/* Write to TIMx CR2 */
|
|
TIMx->CR2 = tmpcr2;
|
|
8003c18: 687b ldr r3, [r7, #4]
|
|
8003c1a: 693a ldr r2, [r7, #16]
|
|
8003c1c: 605a str r2, [r3, #4]
|
|
|
|
/* Write to TIMx CCMR2 */
|
|
TIMx->CCMR2 = tmpccmrx;
|
|
8003c1e: 687b ldr r3, [r7, #4]
|
|
8003c20: 68fa ldr r2, [r7, #12]
|
|
8003c22: 61da str r2, [r3, #28]
|
|
|
|
/* Set the Capture Compare Register value */
|
|
TIMx->CCR4 = OC_Config->Pulse;
|
|
8003c24: 683b ldr r3, [r7, #0]
|
|
8003c26: 685a ldr r2, [r3, #4]
|
|
8003c28: 687b ldr r3, [r7, #4]
|
|
8003c2a: 641a str r2, [r3, #64] ; 0x40
|
|
|
|
/* Write to TIMx CCER */
|
|
TIMx->CCER = tmpccer;
|
|
8003c2c: 687b ldr r3, [r7, #4]
|
|
8003c2e: 697a ldr r2, [r7, #20]
|
|
8003c30: 621a str r2, [r3, #32]
|
|
}
|
|
8003c32: 46c0 nop ; (mov r8, r8)
|
|
8003c34: 46bd mov sp, r7
|
|
8003c36: b006 add sp, #24
|
|
8003c38: bd80 pop {r7, pc}
|
|
8003c3a: 46c0 nop ; (mov r8, r8)
|
|
8003c3c: ffffefff .word 0xffffefff
|
|
8003c40: ffff8fff .word 0xffff8fff
|
|
8003c44: fffffcff .word 0xfffffcff
|
|
8003c48: ffffdfff .word 0xffffdfff
|
|
|
|
08003c4c <TIM_TI1_ConfigInputStage>:
|
|
* @param TIM_ICFilter Specifies the Input Capture Filter.
|
|
* This parameter must be a value between 0x00 and 0x0F.
|
|
* @retval None
|
|
*/
|
|
static void TIM_TI1_ConfigInputStage(TIM_TypeDef *TIMx, uint32_t TIM_ICPolarity, uint32_t TIM_ICFilter)
|
|
{
|
|
8003c4c: b580 push {r7, lr}
|
|
8003c4e: b086 sub sp, #24
|
|
8003c50: af00 add r7, sp, #0
|
|
8003c52: 60f8 str r0, [r7, #12]
|
|
8003c54: 60b9 str r1, [r7, #8]
|
|
8003c56: 607a str r2, [r7, #4]
|
|
uint32_t tmpccmr1;
|
|
uint32_t tmpccer;
|
|
|
|
/* Disable the Channel 1: Reset the CC1E Bit */
|
|
tmpccer = TIMx->CCER;
|
|
8003c58: 68fb ldr r3, [r7, #12]
|
|
8003c5a: 6a1b ldr r3, [r3, #32]
|
|
8003c5c: 617b str r3, [r7, #20]
|
|
TIMx->CCER &= ~TIM_CCER_CC1E;
|
|
8003c5e: 68fb ldr r3, [r7, #12]
|
|
8003c60: 6a1b ldr r3, [r3, #32]
|
|
8003c62: 2201 movs r2, #1
|
|
8003c64: 4393 bics r3, r2
|
|
8003c66: 001a movs r2, r3
|
|
8003c68: 68fb ldr r3, [r7, #12]
|
|
8003c6a: 621a str r2, [r3, #32]
|
|
tmpccmr1 = TIMx->CCMR1;
|
|
8003c6c: 68fb ldr r3, [r7, #12]
|
|
8003c6e: 699b ldr r3, [r3, #24]
|
|
8003c70: 613b str r3, [r7, #16]
|
|
|
|
/* Set the filter */
|
|
tmpccmr1 &= ~TIM_CCMR1_IC1F;
|
|
8003c72: 693b ldr r3, [r7, #16]
|
|
8003c74: 22f0 movs r2, #240 ; 0xf0
|
|
8003c76: 4393 bics r3, r2
|
|
8003c78: 613b str r3, [r7, #16]
|
|
tmpccmr1 |= (TIM_ICFilter << 4U);
|
|
8003c7a: 687b ldr r3, [r7, #4]
|
|
8003c7c: 011b lsls r3, r3, #4
|
|
8003c7e: 693a ldr r2, [r7, #16]
|
|
8003c80: 4313 orrs r3, r2
|
|
8003c82: 613b str r3, [r7, #16]
|
|
|
|
/* Select the Polarity and set the CC1E Bit */
|
|
tmpccer &= ~(TIM_CCER_CC1P | TIM_CCER_CC1NP);
|
|
8003c84: 697b ldr r3, [r7, #20]
|
|
8003c86: 220a movs r2, #10
|
|
8003c88: 4393 bics r3, r2
|
|
8003c8a: 617b str r3, [r7, #20]
|
|
tmpccer |= TIM_ICPolarity;
|
|
8003c8c: 697a ldr r2, [r7, #20]
|
|
8003c8e: 68bb ldr r3, [r7, #8]
|
|
8003c90: 4313 orrs r3, r2
|
|
8003c92: 617b str r3, [r7, #20]
|
|
|
|
/* Write to TIMx CCMR1 and CCER registers */
|
|
TIMx->CCMR1 = tmpccmr1;
|
|
8003c94: 68fb ldr r3, [r7, #12]
|
|
8003c96: 693a ldr r2, [r7, #16]
|
|
8003c98: 619a str r2, [r3, #24]
|
|
TIMx->CCER = tmpccer;
|
|
8003c9a: 68fb ldr r3, [r7, #12]
|
|
8003c9c: 697a ldr r2, [r7, #20]
|
|
8003c9e: 621a str r2, [r3, #32]
|
|
}
|
|
8003ca0: 46c0 nop ; (mov r8, r8)
|
|
8003ca2: 46bd mov sp, r7
|
|
8003ca4: b006 add sp, #24
|
|
8003ca6: bd80 pop {r7, pc}
|
|
|
|
08003ca8 <TIM_TI2_ConfigInputStage>:
|
|
* @param TIM_ICFilter Specifies the Input Capture Filter.
|
|
* This parameter must be a value between 0x00 and 0x0F.
|
|
* @retval None
|
|
*/
|
|
static void TIM_TI2_ConfigInputStage(TIM_TypeDef *TIMx, uint32_t TIM_ICPolarity, uint32_t TIM_ICFilter)
|
|
{
|
|
8003ca8: b580 push {r7, lr}
|
|
8003caa: b086 sub sp, #24
|
|
8003cac: af00 add r7, sp, #0
|
|
8003cae: 60f8 str r0, [r7, #12]
|
|
8003cb0: 60b9 str r1, [r7, #8]
|
|
8003cb2: 607a str r2, [r7, #4]
|
|
uint32_t tmpccmr1;
|
|
uint32_t tmpccer;
|
|
|
|
/* Disable the Channel 2: Reset the CC2E Bit */
|
|
TIMx->CCER &= ~TIM_CCER_CC2E;
|
|
8003cb4: 68fb ldr r3, [r7, #12]
|
|
8003cb6: 6a1b ldr r3, [r3, #32]
|
|
8003cb8: 2210 movs r2, #16
|
|
8003cba: 4393 bics r3, r2
|
|
8003cbc: 001a movs r2, r3
|
|
8003cbe: 68fb ldr r3, [r7, #12]
|
|
8003cc0: 621a str r2, [r3, #32]
|
|
tmpccmr1 = TIMx->CCMR1;
|
|
8003cc2: 68fb ldr r3, [r7, #12]
|
|
8003cc4: 699b ldr r3, [r3, #24]
|
|
8003cc6: 617b str r3, [r7, #20]
|
|
tmpccer = TIMx->CCER;
|
|
8003cc8: 68fb ldr r3, [r7, #12]
|
|
8003cca: 6a1b ldr r3, [r3, #32]
|
|
8003ccc: 613b str r3, [r7, #16]
|
|
|
|
/* Set the filter */
|
|
tmpccmr1 &= ~TIM_CCMR1_IC2F;
|
|
8003cce: 697b ldr r3, [r7, #20]
|
|
8003cd0: 4a0d ldr r2, [pc, #52] ; (8003d08 <TIM_TI2_ConfigInputStage+0x60>)
|
|
8003cd2: 4013 ands r3, r2
|
|
8003cd4: 617b str r3, [r7, #20]
|
|
tmpccmr1 |= (TIM_ICFilter << 12U);
|
|
8003cd6: 687b ldr r3, [r7, #4]
|
|
8003cd8: 031b lsls r3, r3, #12
|
|
8003cda: 697a ldr r2, [r7, #20]
|
|
8003cdc: 4313 orrs r3, r2
|
|
8003cde: 617b str r3, [r7, #20]
|
|
|
|
/* Select the Polarity and set the CC2E Bit */
|
|
tmpccer &= ~(TIM_CCER_CC2P | TIM_CCER_CC2NP);
|
|
8003ce0: 693b ldr r3, [r7, #16]
|
|
8003ce2: 22a0 movs r2, #160 ; 0xa0
|
|
8003ce4: 4393 bics r3, r2
|
|
8003ce6: 613b str r3, [r7, #16]
|
|
tmpccer |= (TIM_ICPolarity << 4U);
|
|
8003ce8: 68bb ldr r3, [r7, #8]
|
|
8003cea: 011b lsls r3, r3, #4
|
|
8003cec: 693a ldr r2, [r7, #16]
|
|
8003cee: 4313 orrs r3, r2
|
|
8003cf0: 613b str r3, [r7, #16]
|
|
|
|
/* Write to TIMx CCMR1 and CCER registers */
|
|
TIMx->CCMR1 = tmpccmr1 ;
|
|
8003cf2: 68fb ldr r3, [r7, #12]
|
|
8003cf4: 697a ldr r2, [r7, #20]
|
|
8003cf6: 619a str r2, [r3, #24]
|
|
TIMx->CCER = tmpccer;
|
|
8003cf8: 68fb ldr r3, [r7, #12]
|
|
8003cfa: 693a ldr r2, [r7, #16]
|
|
8003cfc: 621a str r2, [r3, #32]
|
|
}
|
|
8003cfe: 46c0 nop ; (mov r8, r8)
|
|
8003d00: 46bd mov sp, r7
|
|
8003d02: b006 add sp, #24
|
|
8003d04: bd80 pop {r7, pc}
|
|
8003d06: 46c0 nop ; (mov r8, r8)
|
|
8003d08: ffff0fff .word 0xffff0fff
|
|
|
|
08003d0c <TIM_ITRx_SetConfig>:
|
|
* @arg TIM_TS_TI2FP2: Filtered Timer Input 2
|
|
* @arg TIM_TS_ETRF: External Trigger input
|
|
* @retval None
|
|
*/
|
|
static void TIM_ITRx_SetConfig(TIM_TypeDef *TIMx, uint32_t InputTriggerSource)
|
|
{
|
|
8003d0c: b580 push {r7, lr}
|
|
8003d0e: b084 sub sp, #16
|
|
8003d10: af00 add r7, sp, #0
|
|
8003d12: 6078 str r0, [r7, #4]
|
|
8003d14: 6039 str r1, [r7, #0]
|
|
uint32_t tmpsmcr;
|
|
|
|
/* Get the TIMx SMCR register value */
|
|
tmpsmcr = TIMx->SMCR;
|
|
8003d16: 687b ldr r3, [r7, #4]
|
|
8003d18: 689b ldr r3, [r3, #8]
|
|
8003d1a: 60fb str r3, [r7, #12]
|
|
/* Reset the TS Bits */
|
|
tmpsmcr &= ~TIM_SMCR_TS;
|
|
8003d1c: 68fb ldr r3, [r7, #12]
|
|
8003d1e: 2270 movs r2, #112 ; 0x70
|
|
8003d20: 4393 bics r3, r2
|
|
8003d22: 60fb str r3, [r7, #12]
|
|
/* Set the Input Trigger source and the slave mode*/
|
|
tmpsmcr |= (InputTriggerSource | TIM_SLAVEMODE_EXTERNAL1);
|
|
8003d24: 683a ldr r2, [r7, #0]
|
|
8003d26: 68fb ldr r3, [r7, #12]
|
|
8003d28: 4313 orrs r3, r2
|
|
8003d2a: 2207 movs r2, #7
|
|
8003d2c: 4313 orrs r3, r2
|
|
8003d2e: 60fb str r3, [r7, #12]
|
|
/* Write to TIMx SMCR */
|
|
TIMx->SMCR = tmpsmcr;
|
|
8003d30: 687b ldr r3, [r7, #4]
|
|
8003d32: 68fa ldr r2, [r7, #12]
|
|
8003d34: 609a str r2, [r3, #8]
|
|
}
|
|
8003d36: 46c0 nop ; (mov r8, r8)
|
|
8003d38: 46bd mov sp, r7
|
|
8003d3a: b004 add sp, #16
|
|
8003d3c: bd80 pop {r7, pc}
|
|
...
|
|
|
|
08003d40 <TIM_ETR_SetConfig>:
|
|
* This parameter must be a value between 0x00 and 0x0F
|
|
* @retval None
|
|
*/
|
|
static void TIM_ETR_SetConfig(TIM_TypeDef *TIMx, uint32_t TIM_ExtTRGPrescaler,
|
|
uint32_t TIM_ExtTRGPolarity, uint32_t ExtTRGFilter)
|
|
{
|
|
8003d40: b580 push {r7, lr}
|
|
8003d42: b086 sub sp, #24
|
|
8003d44: af00 add r7, sp, #0
|
|
8003d46: 60f8 str r0, [r7, #12]
|
|
8003d48: 60b9 str r1, [r7, #8]
|
|
8003d4a: 607a str r2, [r7, #4]
|
|
8003d4c: 603b str r3, [r7, #0]
|
|
uint32_t tmpsmcr;
|
|
|
|
tmpsmcr = TIMx->SMCR;
|
|
8003d4e: 68fb ldr r3, [r7, #12]
|
|
8003d50: 689b ldr r3, [r3, #8]
|
|
8003d52: 617b str r3, [r7, #20]
|
|
|
|
/* Reset the ETR Bits */
|
|
tmpsmcr &= ~(TIM_SMCR_ETF | TIM_SMCR_ETPS | TIM_SMCR_ECE | TIM_SMCR_ETP);
|
|
8003d54: 697b ldr r3, [r7, #20]
|
|
8003d56: 4a09 ldr r2, [pc, #36] ; (8003d7c <TIM_ETR_SetConfig+0x3c>)
|
|
8003d58: 4013 ands r3, r2
|
|
8003d5a: 617b str r3, [r7, #20]
|
|
|
|
/* Set the Prescaler, the Filter value and the Polarity */
|
|
tmpsmcr |= (uint32_t)(TIM_ExtTRGPrescaler | (TIM_ExtTRGPolarity | (ExtTRGFilter << 8U)));
|
|
8003d5c: 683b ldr r3, [r7, #0]
|
|
8003d5e: 021a lsls r2, r3, #8
|
|
8003d60: 687b ldr r3, [r7, #4]
|
|
8003d62: 431a orrs r2, r3
|
|
8003d64: 68bb ldr r3, [r7, #8]
|
|
8003d66: 4313 orrs r3, r2
|
|
8003d68: 697a ldr r2, [r7, #20]
|
|
8003d6a: 4313 orrs r3, r2
|
|
8003d6c: 617b str r3, [r7, #20]
|
|
|
|
/* Write to TIMx SMCR */
|
|
TIMx->SMCR = tmpsmcr;
|
|
8003d6e: 68fb ldr r3, [r7, #12]
|
|
8003d70: 697a ldr r2, [r7, #20]
|
|
8003d72: 609a str r2, [r3, #8]
|
|
}
|
|
8003d74: 46c0 nop ; (mov r8, r8)
|
|
8003d76: 46bd mov sp, r7
|
|
8003d78: b006 add sp, #24
|
|
8003d7a: bd80 pop {r7, pc}
|
|
8003d7c: ffff00ff .word 0xffff00ff
|
|
|
|
08003d80 <HAL_TIMEx_MasterConfigSynchronization>:
|
|
* mode.
|
|
* @retval HAL status
|
|
*/
|
|
HAL_StatusTypeDef HAL_TIMEx_MasterConfigSynchronization(TIM_HandleTypeDef *htim,
|
|
TIM_MasterConfigTypeDef *sMasterConfig)
|
|
{
|
|
8003d80: b580 push {r7, lr}
|
|
8003d82: b084 sub sp, #16
|
|
8003d84: af00 add r7, sp, #0
|
|
8003d86: 6078 str r0, [r7, #4]
|
|
8003d88: 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);
|
|
8003d8a: 687b ldr r3, [r7, #4]
|
|
8003d8c: 2238 movs r2, #56 ; 0x38
|
|
8003d8e: 5c9b ldrb r3, [r3, r2]
|
|
8003d90: 2b01 cmp r3, #1
|
|
8003d92: d101 bne.n 8003d98 <HAL_TIMEx_MasterConfigSynchronization+0x18>
|
|
8003d94: 2302 movs r3, #2
|
|
8003d96: e03d b.n 8003e14 <HAL_TIMEx_MasterConfigSynchronization+0x94>
|
|
8003d98: 687b ldr r3, [r7, #4]
|
|
8003d9a: 2238 movs r2, #56 ; 0x38
|
|
8003d9c: 2101 movs r1, #1
|
|
8003d9e: 5499 strb r1, [r3, r2]
|
|
|
|
/* Change the handler state */
|
|
htim->State = HAL_TIM_STATE_BUSY;
|
|
8003da0: 687b ldr r3, [r7, #4]
|
|
8003da2: 2239 movs r2, #57 ; 0x39
|
|
8003da4: 2102 movs r1, #2
|
|
8003da6: 5499 strb r1, [r3, r2]
|
|
|
|
/* Get the TIMx CR2 register value */
|
|
tmpcr2 = htim->Instance->CR2;
|
|
8003da8: 687b ldr r3, [r7, #4]
|
|
8003daa: 681b ldr r3, [r3, #0]
|
|
8003dac: 685b ldr r3, [r3, #4]
|
|
8003dae: 60fb str r3, [r7, #12]
|
|
|
|
/* Get the TIMx SMCR register value */
|
|
tmpsmcr = htim->Instance->SMCR;
|
|
8003db0: 687b ldr r3, [r7, #4]
|
|
8003db2: 681b ldr r3, [r3, #0]
|
|
8003db4: 689b ldr r3, [r3, #8]
|
|
8003db6: 60bb str r3, [r7, #8]
|
|
|
|
/* Reset the MMS Bits */
|
|
tmpcr2 &= ~TIM_CR2_MMS;
|
|
8003db8: 68fb ldr r3, [r7, #12]
|
|
8003dba: 2270 movs r2, #112 ; 0x70
|
|
8003dbc: 4393 bics r3, r2
|
|
8003dbe: 60fb str r3, [r7, #12]
|
|
/* Select the TRGO source */
|
|
tmpcr2 |= sMasterConfig->MasterOutputTrigger;
|
|
8003dc0: 683b ldr r3, [r7, #0]
|
|
8003dc2: 681b ldr r3, [r3, #0]
|
|
8003dc4: 68fa ldr r2, [r7, #12]
|
|
8003dc6: 4313 orrs r3, r2
|
|
8003dc8: 60fb str r3, [r7, #12]
|
|
|
|
/* Update TIMx CR2 */
|
|
htim->Instance->CR2 = tmpcr2;
|
|
8003dca: 687b ldr r3, [r7, #4]
|
|
8003dcc: 681b ldr r3, [r3, #0]
|
|
8003dce: 68fa ldr r2, [r7, #12]
|
|
8003dd0: 605a str r2, [r3, #4]
|
|
|
|
if (IS_TIM_SLAVE_INSTANCE(htim->Instance))
|
|
8003dd2: 687b ldr r3, [r7, #4]
|
|
8003dd4: 681a ldr r2, [r3, #0]
|
|
8003dd6: 2380 movs r3, #128 ; 0x80
|
|
8003dd8: 05db lsls r3, r3, #23
|
|
8003dda: 429a cmp r2, r3
|
|
8003ddc: d004 beq.n 8003de8 <HAL_TIMEx_MasterConfigSynchronization+0x68>
|
|
8003dde: 687b ldr r3, [r7, #4]
|
|
8003de0: 681b ldr r3, [r3, #0]
|
|
8003de2: 4a0e ldr r2, [pc, #56] ; (8003e1c <HAL_TIMEx_MasterConfigSynchronization+0x9c>)
|
|
8003de4: 4293 cmp r3, r2
|
|
8003de6: d10c bne.n 8003e02 <HAL_TIMEx_MasterConfigSynchronization+0x82>
|
|
{
|
|
/* Reset the MSM Bit */
|
|
tmpsmcr &= ~TIM_SMCR_MSM;
|
|
8003de8: 68bb ldr r3, [r7, #8]
|
|
8003dea: 2280 movs r2, #128 ; 0x80
|
|
8003dec: 4393 bics r3, r2
|
|
8003dee: 60bb str r3, [r7, #8]
|
|
/* Set master mode */
|
|
tmpsmcr |= sMasterConfig->MasterSlaveMode;
|
|
8003df0: 683b ldr r3, [r7, #0]
|
|
8003df2: 685b ldr r3, [r3, #4]
|
|
8003df4: 68ba ldr r2, [r7, #8]
|
|
8003df6: 4313 orrs r3, r2
|
|
8003df8: 60bb str r3, [r7, #8]
|
|
|
|
/* Update TIMx SMCR */
|
|
htim->Instance->SMCR = tmpsmcr;
|
|
8003dfa: 687b ldr r3, [r7, #4]
|
|
8003dfc: 681b ldr r3, [r3, #0]
|
|
8003dfe: 68ba ldr r2, [r7, #8]
|
|
8003e00: 609a str r2, [r3, #8]
|
|
}
|
|
|
|
/* Change the htim state */
|
|
htim->State = HAL_TIM_STATE_READY;
|
|
8003e02: 687b ldr r3, [r7, #4]
|
|
8003e04: 2239 movs r2, #57 ; 0x39
|
|
8003e06: 2101 movs r1, #1
|
|
8003e08: 5499 strb r1, [r3, r2]
|
|
|
|
__HAL_UNLOCK(htim);
|
|
8003e0a: 687b ldr r3, [r7, #4]
|
|
8003e0c: 2238 movs r2, #56 ; 0x38
|
|
8003e0e: 2100 movs r1, #0
|
|
8003e10: 5499 strb r1, [r3, r2]
|
|
|
|
return HAL_OK;
|
|
8003e12: 2300 movs r3, #0
|
|
}
|
|
8003e14: 0018 movs r0, r3
|
|
8003e16: 46bd mov sp, r7
|
|
8003e18: b004 add sp, #16
|
|
8003e1a: bd80 pop {r7, pc}
|
|
8003e1c: 40010800 .word 0x40010800
|
|
|
|
08003e20 <HAL_UART_Init>:
|
|
* parameters in the UART_InitTypeDef and initialize the associated handle.
|
|
* @param huart UART handle.
|
|
* @retval HAL status
|
|
*/
|
|
HAL_StatusTypeDef HAL_UART_Init(UART_HandleTypeDef *huart)
|
|
{
|
|
8003e20: b580 push {r7, lr}
|
|
8003e22: b082 sub sp, #8
|
|
8003e24: af00 add r7, sp, #0
|
|
8003e26: 6078 str r0, [r7, #4]
|
|
/* Check the UART handle allocation */
|
|
if (huart == NULL)
|
|
8003e28: 687b ldr r3, [r7, #4]
|
|
8003e2a: 2b00 cmp r3, #0
|
|
8003e2c: d101 bne.n 8003e32 <HAL_UART_Init+0x12>
|
|
{
|
|
return HAL_ERROR;
|
|
8003e2e: 2301 movs r3, #1
|
|
8003e30: e044 b.n 8003ebc <HAL_UART_Init+0x9c>
|
|
{
|
|
/* Check the parameters */
|
|
assert_param((IS_UART_INSTANCE(huart->Instance)) || (IS_LPUART_INSTANCE(huart->Instance)));
|
|
}
|
|
|
|
if (huart->gState == HAL_UART_STATE_RESET)
|
|
8003e32: 687b ldr r3, [r7, #4]
|
|
8003e34: 6f9b ldr r3, [r3, #120] ; 0x78
|
|
8003e36: 2b00 cmp r3, #0
|
|
8003e38: d107 bne.n 8003e4a <HAL_UART_Init+0x2a>
|
|
{
|
|
/* Allocate lock resource and initialize it */
|
|
huart->Lock = HAL_UNLOCKED;
|
|
8003e3a: 687b ldr r3, [r7, #4]
|
|
8003e3c: 2274 movs r2, #116 ; 0x74
|
|
8003e3e: 2100 movs r1, #0
|
|
8003e40: 5499 strb r1, [r3, r2]
|
|
|
|
/* Init the low level hardware */
|
|
huart->MspInitCallback(huart);
|
|
#else
|
|
/* Init the low level hardware : GPIO, CLOCK */
|
|
HAL_UART_MspInit(huart);
|
|
8003e42: 687b ldr r3, [r7, #4]
|
|
8003e44: 0018 movs r0, r3
|
|
8003e46: f7fd fa3b bl 80012c0 <HAL_UART_MspInit>
|
|
#endif /* (USE_HAL_UART_REGISTER_CALLBACKS) */
|
|
}
|
|
|
|
huart->gState = HAL_UART_STATE_BUSY;
|
|
8003e4a: 687b ldr r3, [r7, #4]
|
|
8003e4c: 2224 movs r2, #36 ; 0x24
|
|
8003e4e: 679a str r2, [r3, #120] ; 0x78
|
|
|
|
__HAL_UART_DISABLE(huart);
|
|
8003e50: 687b ldr r3, [r7, #4]
|
|
8003e52: 681b ldr r3, [r3, #0]
|
|
8003e54: 681a ldr r2, [r3, #0]
|
|
8003e56: 687b ldr r3, [r7, #4]
|
|
8003e58: 681b ldr r3, [r3, #0]
|
|
8003e5a: 2101 movs r1, #1
|
|
8003e5c: 438a bics r2, r1
|
|
8003e5e: 601a str r2, [r3, #0]
|
|
|
|
/* Set the UART Communication parameters */
|
|
if (UART_SetConfig(huart) == HAL_ERROR)
|
|
8003e60: 687b ldr r3, [r7, #4]
|
|
8003e62: 0018 movs r0, r3
|
|
8003e64: f000 fb26 bl 80044b4 <UART_SetConfig>
|
|
8003e68: 0003 movs r3, r0
|
|
8003e6a: 2b01 cmp r3, #1
|
|
8003e6c: d101 bne.n 8003e72 <HAL_UART_Init+0x52>
|
|
{
|
|
return HAL_ERROR;
|
|
8003e6e: 2301 movs r3, #1
|
|
8003e70: e024 b.n 8003ebc <HAL_UART_Init+0x9c>
|
|
}
|
|
|
|
if (huart->AdvancedInit.AdvFeatureInit != UART_ADVFEATURE_NO_INIT)
|
|
8003e72: 687b ldr r3, [r7, #4]
|
|
8003e74: 6a5b ldr r3, [r3, #36] ; 0x24
|
|
8003e76: 2b00 cmp r3, #0
|
|
8003e78: d003 beq.n 8003e82 <HAL_UART_Init+0x62>
|
|
{
|
|
UART_AdvFeatureConfig(huart);
|
|
8003e7a: 687b ldr r3, [r7, #4]
|
|
8003e7c: 0018 movs r0, r3
|
|
8003e7e: f000 fd7b bl 8004978 <UART_AdvFeatureConfig>
|
|
}
|
|
|
|
/* In asynchronous mode, the following bits must be kept cleared:
|
|
- LINEN and CLKEN bits in the USART_CR2 register,
|
|
- SCEN, HDSEL and IREN bits in the USART_CR3 register.*/
|
|
CLEAR_BIT(huart->Instance->CR2, (USART_CR2_LINEN | USART_CR2_CLKEN));
|
|
8003e82: 687b ldr r3, [r7, #4]
|
|
8003e84: 681b ldr r3, [r3, #0]
|
|
8003e86: 685a ldr r2, [r3, #4]
|
|
8003e88: 687b ldr r3, [r7, #4]
|
|
8003e8a: 681b ldr r3, [r3, #0]
|
|
8003e8c: 490d ldr r1, [pc, #52] ; (8003ec4 <HAL_UART_Init+0xa4>)
|
|
8003e8e: 400a ands r2, r1
|
|
8003e90: 605a str r2, [r3, #4]
|
|
CLEAR_BIT(huart->Instance->CR3, (USART_CR3_SCEN | USART_CR3_HDSEL | USART_CR3_IREN));
|
|
8003e92: 687b ldr r3, [r7, #4]
|
|
8003e94: 681b ldr r3, [r3, #0]
|
|
8003e96: 689a ldr r2, [r3, #8]
|
|
8003e98: 687b ldr r3, [r7, #4]
|
|
8003e9a: 681b ldr r3, [r3, #0]
|
|
8003e9c: 212a movs r1, #42 ; 0x2a
|
|
8003e9e: 438a bics r2, r1
|
|
8003ea0: 609a str r2, [r3, #8]
|
|
|
|
__HAL_UART_ENABLE(huart);
|
|
8003ea2: 687b ldr r3, [r7, #4]
|
|
8003ea4: 681b ldr r3, [r3, #0]
|
|
8003ea6: 681a ldr r2, [r3, #0]
|
|
8003ea8: 687b ldr r3, [r7, #4]
|
|
8003eaa: 681b ldr r3, [r3, #0]
|
|
8003eac: 2101 movs r1, #1
|
|
8003eae: 430a orrs r2, r1
|
|
8003eb0: 601a str r2, [r3, #0]
|
|
|
|
/* TEACK and/or REACK to check before moving huart->gState and huart->RxState to Ready */
|
|
return (UART_CheckIdleState(huart));
|
|
8003eb2: 687b ldr r3, [r7, #4]
|
|
8003eb4: 0018 movs r0, r3
|
|
8003eb6: f000 fe13 bl 8004ae0 <UART_CheckIdleState>
|
|
8003eba: 0003 movs r3, r0
|
|
}
|
|
8003ebc: 0018 movs r0, r3
|
|
8003ebe: 46bd mov sp, r7
|
|
8003ec0: b002 add sp, #8
|
|
8003ec2: bd80 pop {r7, pc}
|
|
8003ec4: ffffb7ff .word 0xffffb7ff
|
|
|
|
08003ec8 <HAL_UART_IRQHandler>:
|
|
* @brief Handle UART interrupt request.
|
|
* @param huart UART handle.
|
|
* @retval None
|
|
*/
|
|
void HAL_UART_IRQHandler(UART_HandleTypeDef *huart)
|
|
{
|
|
8003ec8: b590 push {r4, r7, lr}
|
|
8003eca: b0ab sub sp, #172 ; 0xac
|
|
8003ecc: af00 add r7, sp, #0
|
|
8003ece: 6078 str r0, [r7, #4]
|
|
uint32_t isrflags = READ_REG(huart->Instance->ISR);
|
|
8003ed0: 687b ldr r3, [r7, #4]
|
|
8003ed2: 681b ldr r3, [r3, #0]
|
|
8003ed4: 69db ldr r3, [r3, #28]
|
|
8003ed6: 22a4 movs r2, #164 ; 0xa4
|
|
8003ed8: 18b9 adds r1, r7, r2
|
|
8003eda: 600b str r3, [r1, #0]
|
|
uint32_t cr1its = READ_REG(huart->Instance->CR1);
|
|
8003edc: 687b ldr r3, [r7, #4]
|
|
8003ede: 681b ldr r3, [r3, #0]
|
|
8003ee0: 681b ldr r3, [r3, #0]
|
|
8003ee2: 20a0 movs r0, #160 ; 0xa0
|
|
8003ee4: 1839 adds r1, r7, r0
|
|
8003ee6: 600b str r3, [r1, #0]
|
|
uint32_t cr3its = READ_REG(huart->Instance->CR3);
|
|
8003ee8: 687b ldr r3, [r7, #4]
|
|
8003eea: 681b ldr r3, [r3, #0]
|
|
8003eec: 689b ldr r3, [r3, #8]
|
|
8003eee: 219c movs r1, #156 ; 0x9c
|
|
8003ef0: 1879 adds r1, r7, r1
|
|
8003ef2: 600b str r3, [r1, #0]
|
|
|
|
uint32_t errorflags;
|
|
uint32_t errorcode;
|
|
|
|
/* If no error occurs */
|
|
errorflags = (isrflags & (uint32_t)(USART_ISR_PE | USART_ISR_FE | USART_ISR_ORE | USART_ISR_NE | USART_ISR_RTOF));
|
|
8003ef4: 0011 movs r1, r2
|
|
8003ef6: 18bb adds r3, r7, r2
|
|
8003ef8: 681b ldr r3, [r3, #0]
|
|
8003efa: 4a99 ldr r2, [pc, #612] ; (8004160 <HAL_UART_IRQHandler+0x298>)
|
|
8003efc: 4013 ands r3, r2
|
|
8003efe: 2298 movs r2, #152 ; 0x98
|
|
8003f00: 18bc adds r4, r7, r2
|
|
8003f02: 6023 str r3, [r4, #0]
|
|
if (errorflags == 0U)
|
|
8003f04: 18bb adds r3, r7, r2
|
|
8003f06: 681b ldr r3, [r3, #0]
|
|
8003f08: 2b00 cmp r3, #0
|
|
8003f0a: d114 bne.n 8003f36 <HAL_UART_IRQHandler+0x6e>
|
|
{
|
|
/* UART in mode Receiver ---------------------------------------------------*/
|
|
if (((isrflags & USART_ISR_RXNE) != 0U)
|
|
8003f0c: 187b adds r3, r7, r1
|
|
8003f0e: 681b ldr r3, [r3, #0]
|
|
8003f10: 2220 movs r2, #32
|
|
8003f12: 4013 ands r3, r2
|
|
8003f14: d00f beq.n 8003f36 <HAL_UART_IRQHandler+0x6e>
|
|
&& ((cr1its & USART_CR1_RXNEIE) != 0U))
|
|
8003f16: 183b adds r3, r7, r0
|
|
8003f18: 681b ldr r3, [r3, #0]
|
|
8003f1a: 2220 movs r2, #32
|
|
8003f1c: 4013 ands r3, r2
|
|
8003f1e: d00a beq.n 8003f36 <HAL_UART_IRQHandler+0x6e>
|
|
{
|
|
if (huart->RxISR != NULL)
|
|
8003f20: 687b ldr r3, [r7, #4]
|
|
8003f22: 6e5b ldr r3, [r3, #100] ; 0x64
|
|
8003f24: 2b00 cmp r3, #0
|
|
8003f26: d100 bne.n 8003f2a <HAL_UART_IRQHandler+0x62>
|
|
8003f28: e298 b.n 800445c <HAL_UART_IRQHandler+0x594>
|
|
{
|
|
huart->RxISR(huart);
|
|
8003f2a: 687b ldr r3, [r7, #4]
|
|
8003f2c: 6e5b ldr r3, [r3, #100] ; 0x64
|
|
8003f2e: 687a ldr r2, [r7, #4]
|
|
8003f30: 0010 movs r0, r2
|
|
8003f32: 4798 blx r3
|
|
}
|
|
return;
|
|
8003f34: e292 b.n 800445c <HAL_UART_IRQHandler+0x594>
|
|
}
|
|
}
|
|
|
|
/* If some errors occur */
|
|
if ((errorflags != 0U)
|
|
8003f36: 2398 movs r3, #152 ; 0x98
|
|
8003f38: 18fb adds r3, r7, r3
|
|
8003f3a: 681b ldr r3, [r3, #0]
|
|
8003f3c: 2b00 cmp r3, #0
|
|
8003f3e: d100 bne.n 8003f42 <HAL_UART_IRQHandler+0x7a>
|
|
8003f40: e114 b.n 800416c <HAL_UART_IRQHandler+0x2a4>
|
|
&& (((cr3its & USART_CR3_EIE) != 0U)
|
|
8003f42: 239c movs r3, #156 ; 0x9c
|
|
8003f44: 18fb adds r3, r7, r3
|
|
8003f46: 681b ldr r3, [r3, #0]
|
|
8003f48: 2201 movs r2, #1
|
|
8003f4a: 4013 ands r3, r2
|
|
8003f4c: d106 bne.n 8003f5c <HAL_UART_IRQHandler+0x94>
|
|
|| ((cr1its & (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_RTOIE)) != 0U)))
|
|
8003f4e: 23a0 movs r3, #160 ; 0xa0
|
|
8003f50: 18fb adds r3, r7, r3
|
|
8003f52: 681b ldr r3, [r3, #0]
|
|
8003f54: 4a83 ldr r2, [pc, #524] ; (8004164 <HAL_UART_IRQHandler+0x29c>)
|
|
8003f56: 4013 ands r3, r2
|
|
8003f58: d100 bne.n 8003f5c <HAL_UART_IRQHandler+0x94>
|
|
8003f5a: e107 b.n 800416c <HAL_UART_IRQHandler+0x2a4>
|
|
{
|
|
/* UART parity error interrupt occurred -------------------------------------*/
|
|
if (((isrflags & USART_ISR_PE) != 0U) && ((cr1its & USART_CR1_PEIE) != 0U))
|
|
8003f5c: 23a4 movs r3, #164 ; 0xa4
|
|
8003f5e: 18fb adds r3, r7, r3
|
|
8003f60: 681b ldr r3, [r3, #0]
|
|
8003f62: 2201 movs r2, #1
|
|
8003f64: 4013 ands r3, r2
|
|
8003f66: d012 beq.n 8003f8e <HAL_UART_IRQHandler+0xc6>
|
|
8003f68: 23a0 movs r3, #160 ; 0xa0
|
|
8003f6a: 18fb adds r3, r7, r3
|
|
8003f6c: 681a ldr r2, [r3, #0]
|
|
8003f6e: 2380 movs r3, #128 ; 0x80
|
|
8003f70: 005b lsls r3, r3, #1
|
|
8003f72: 4013 ands r3, r2
|
|
8003f74: d00b beq.n 8003f8e <HAL_UART_IRQHandler+0xc6>
|
|
{
|
|
__HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_PEF);
|
|
8003f76: 687b ldr r3, [r7, #4]
|
|
8003f78: 681b ldr r3, [r3, #0]
|
|
8003f7a: 2201 movs r2, #1
|
|
8003f7c: 621a str r2, [r3, #32]
|
|
|
|
huart->ErrorCode |= HAL_UART_ERROR_PE;
|
|
8003f7e: 687b ldr r3, [r7, #4]
|
|
8003f80: 2280 movs r2, #128 ; 0x80
|
|
8003f82: 589b ldr r3, [r3, r2]
|
|
8003f84: 2201 movs r2, #1
|
|
8003f86: 431a orrs r2, r3
|
|
8003f88: 687b ldr r3, [r7, #4]
|
|
8003f8a: 2180 movs r1, #128 ; 0x80
|
|
8003f8c: 505a str r2, [r3, r1]
|
|
}
|
|
|
|
/* UART frame error interrupt occurred --------------------------------------*/
|
|
if (((isrflags & USART_ISR_FE) != 0U) && ((cr3its & USART_CR3_EIE) != 0U))
|
|
8003f8e: 23a4 movs r3, #164 ; 0xa4
|
|
8003f90: 18fb adds r3, r7, r3
|
|
8003f92: 681b ldr r3, [r3, #0]
|
|
8003f94: 2202 movs r2, #2
|
|
8003f96: 4013 ands r3, r2
|
|
8003f98: d011 beq.n 8003fbe <HAL_UART_IRQHandler+0xf6>
|
|
8003f9a: 239c movs r3, #156 ; 0x9c
|
|
8003f9c: 18fb adds r3, r7, r3
|
|
8003f9e: 681b ldr r3, [r3, #0]
|
|
8003fa0: 2201 movs r2, #1
|
|
8003fa2: 4013 ands r3, r2
|
|
8003fa4: d00b beq.n 8003fbe <HAL_UART_IRQHandler+0xf6>
|
|
{
|
|
__HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_FEF);
|
|
8003fa6: 687b ldr r3, [r7, #4]
|
|
8003fa8: 681b ldr r3, [r3, #0]
|
|
8003faa: 2202 movs r2, #2
|
|
8003fac: 621a str r2, [r3, #32]
|
|
|
|
huart->ErrorCode |= HAL_UART_ERROR_FE;
|
|
8003fae: 687b ldr r3, [r7, #4]
|
|
8003fb0: 2280 movs r2, #128 ; 0x80
|
|
8003fb2: 589b ldr r3, [r3, r2]
|
|
8003fb4: 2204 movs r2, #4
|
|
8003fb6: 431a orrs r2, r3
|
|
8003fb8: 687b ldr r3, [r7, #4]
|
|
8003fba: 2180 movs r1, #128 ; 0x80
|
|
8003fbc: 505a str r2, [r3, r1]
|
|
}
|
|
|
|
/* UART noise error interrupt occurred --------------------------------------*/
|
|
if (((isrflags & USART_ISR_NE) != 0U) && ((cr3its & USART_CR3_EIE) != 0U))
|
|
8003fbe: 23a4 movs r3, #164 ; 0xa4
|
|
8003fc0: 18fb adds r3, r7, r3
|
|
8003fc2: 681b ldr r3, [r3, #0]
|
|
8003fc4: 2204 movs r2, #4
|
|
8003fc6: 4013 ands r3, r2
|
|
8003fc8: d011 beq.n 8003fee <HAL_UART_IRQHandler+0x126>
|
|
8003fca: 239c movs r3, #156 ; 0x9c
|
|
8003fcc: 18fb adds r3, r7, r3
|
|
8003fce: 681b ldr r3, [r3, #0]
|
|
8003fd0: 2201 movs r2, #1
|
|
8003fd2: 4013 ands r3, r2
|
|
8003fd4: d00b beq.n 8003fee <HAL_UART_IRQHandler+0x126>
|
|
{
|
|
__HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_NEF);
|
|
8003fd6: 687b ldr r3, [r7, #4]
|
|
8003fd8: 681b ldr r3, [r3, #0]
|
|
8003fda: 2204 movs r2, #4
|
|
8003fdc: 621a str r2, [r3, #32]
|
|
|
|
huart->ErrorCode |= HAL_UART_ERROR_NE;
|
|
8003fde: 687b ldr r3, [r7, #4]
|
|
8003fe0: 2280 movs r2, #128 ; 0x80
|
|
8003fe2: 589b ldr r3, [r3, r2]
|
|
8003fe4: 2202 movs r2, #2
|
|
8003fe6: 431a orrs r2, r3
|
|
8003fe8: 687b ldr r3, [r7, #4]
|
|
8003fea: 2180 movs r1, #128 ; 0x80
|
|
8003fec: 505a str r2, [r3, r1]
|
|
}
|
|
|
|
/* UART Over-Run interrupt occurred -----------------------------------------*/
|
|
if (((isrflags & USART_ISR_ORE) != 0U)
|
|
8003fee: 23a4 movs r3, #164 ; 0xa4
|
|
8003ff0: 18fb adds r3, r7, r3
|
|
8003ff2: 681b ldr r3, [r3, #0]
|
|
8003ff4: 2208 movs r2, #8
|
|
8003ff6: 4013 ands r3, r2
|
|
8003ff8: d017 beq.n 800402a <HAL_UART_IRQHandler+0x162>
|
|
&& (((cr1its & USART_CR1_RXNEIE) != 0U) ||
|
|
8003ffa: 23a0 movs r3, #160 ; 0xa0
|
|
8003ffc: 18fb adds r3, r7, r3
|
|
8003ffe: 681b ldr r3, [r3, #0]
|
|
8004000: 2220 movs r2, #32
|
|
8004002: 4013 ands r3, r2
|
|
8004004: d105 bne.n 8004012 <HAL_UART_IRQHandler+0x14a>
|
|
((cr3its & USART_CR3_EIE) != 0U)))
|
|
8004006: 239c movs r3, #156 ; 0x9c
|
|
8004008: 18fb adds r3, r7, r3
|
|
800400a: 681b ldr r3, [r3, #0]
|
|
800400c: 2201 movs r2, #1
|
|
800400e: 4013 ands r3, r2
|
|
&& (((cr1its & USART_CR1_RXNEIE) != 0U) ||
|
|
8004010: d00b beq.n 800402a <HAL_UART_IRQHandler+0x162>
|
|
{
|
|
__HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_OREF);
|
|
8004012: 687b ldr r3, [r7, #4]
|
|
8004014: 681b ldr r3, [r3, #0]
|
|
8004016: 2208 movs r2, #8
|
|
8004018: 621a str r2, [r3, #32]
|
|
|
|
huart->ErrorCode |= HAL_UART_ERROR_ORE;
|
|
800401a: 687b ldr r3, [r7, #4]
|
|
800401c: 2280 movs r2, #128 ; 0x80
|
|
800401e: 589b ldr r3, [r3, r2]
|
|
8004020: 2208 movs r2, #8
|
|
8004022: 431a orrs r2, r3
|
|
8004024: 687b ldr r3, [r7, #4]
|
|
8004026: 2180 movs r1, #128 ; 0x80
|
|
8004028: 505a str r2, [r3, r1]
|
|
}
|
|
|
|
/* UART Receiver Timeout interrupt occurred ---------------------------------*/
|
|
if (((isrflags & USART_ISR_RTOF) != 0U) && ((cr1its & USART_CR1_RTOIE) != 0U))
|
|
800402a: 23a4 movs r3, #164 ; 0xa4
|
|
800402c: 18fb adds r3, r7, r3
|
|
800402e: 681a ldr r2, [r3, #0]
|
|
8004030: 2380 movs r3, #128 ; 0x80
|
|
8004032: 011b lsls r3, r3, #4
|
|
8004034: 4013 ands r3, r2
|
|
8004036: d013 beq.n 8004060 <HAL_UART_IRQHandler+0x198>
|
|
8004038: 23a0 movs r3, #160 ; 0xa0
|
|
800403a: 18fb adds r3, r7, r3
|
|
800403c: 681a ldr r2, [r3, #0]
|
|
800403e: 2380 movs r3, #128 ; 0x80
|
|
8004040: 04db lsls r3, r3, #19
|
|
8004042: 4013 ands r3, r2
|
|
8004044: d00c beq.n 8004060 <HAL_UART_IRQHandler+0x198>
|
|
{
|
|
__HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_RTOF);
|
|
8004046: 687b ldr r3, [r7, #4]
|
|
8004048: 681b ldr r3, [r3, #0]
|
|
800404a: 2280 movs r2, #128 ; 0x80
|
|
800404c: 0112 lsls r2, r2, #4
|
|
800404e: 621a str r2, [r3, #32]
|
|
|
|
huart->ErrorCode |= HAL_UART_ERROR_RTO;
|
|
8004050: 687b ldr r3, [r7, #4]
|
|
8004052: 2280 movs r2, #128 ; 0x80
|
|
8004054: 589b ldr r3, [r3, r2]
|
|
8004056: 2220 movs r2, #32
|
|
8004058: 431a orrs r2, r3
|
|
800405a: 687b ldr r3, [r7, #4]
|
|
800405c: 2180 movs r1, #128 ; 0x80
|
|
800405e: 505a str r2, [r3, r1]
|
|
}
|
|
|
|
/* Call UART Error Call back function if need be ----------------------------*/
|
|
if (huart->ErrorCode != HAL_UART_ERROR_NONE)
|
|
8004060: 687b ldr r3, [r7, #4]
|
|
8004062: 2280 movs r2, #128 ; 0x80
|
|
8004064: 589b ldr r3, [r3, r2]
|
|
8004066: 2b00 cmp r3, #0
|
|
8004068: d100 bne.n 800406c <HAL_UART_IRQHandler+0x1a4>
|
|
800406a: e1f9 b.n 8004460 <HAL_UART_IRQHandler+0x598>
|
|
{
|
|
/* UART in mode Receiver --------------------------------------------------*/
|
|
if (((isrflags & USART_ISR_RXNE) != 0U)
|
|
800406c: 23a4 movs r3, #164 ; 0xa4
|
|
800406e: 18fb adds r3, r7, r3
|
|
8004070: 681b ldr r3, [r3, #0]
|
|
8004072: 2220 movs r2, #32
|
|
8004074: 4013 ands r3, r2
|
|
8004076: d00e beq.n 8004096 <HAL_UART_IRQHandler+0x1ce>
|
|
&& ((cr1its & USART_CR1_RXNEIE) != 0U))
|
|
8004078: 23a0 movs r3, #160 ; 0xa0
|
|
800407a: 18fb adds r3, r7, r3
|
|
800407c: 681b ldr r3, [r3, #0]
|
|
800407e: 2220 movs r2, #32
|
|
8004080: 4013 ands r3, r2
|
|
8004082: d008 beq.n 8004096 <HAL_UART_IRQHandler+0x1ce>
|
|
{
|
|
if (huart->RxISR != NULL)
|
|
8004084: 687b ldr r3, [r7, #4]
|
|
8004086: 6e5b ldr r3, [r3, #100] ; 0x64
|
|
8004088: 2b00 cmp r3, #0
|
|
800408a: d004 beq.n 8004096 <HAL_UART_IRQHandler+0x1ce>
|
|
{
|
|
huart->RxISR(huart);
|
|
800408c: 687b ldr r3, [r7, #4]
|
|
800408e: 6e5b ldr r3, [r3, #100] ; 0x64
|
|
8004090: 687a ldr r2, [r7, #4]
|
|
8004092: 0010 movs r0, r2
|
|
8004094: 4798 blx r3
|
|
/* If Error is to be considered as blocking :
|
|
- Receiver Timeout error in Reception
|
|
- Overrun error in Reception
|
|
- any error occurs in DMA mode reception
|
|
*/
|
|
errorcode = huart->ErrorCode;
|
|
8004096: 687b ldr r3, [r7, #4]
|
|
8004098: 2280 movs r2, #128 ; 0x80
|
|
800409a: 589b ldr r3, [r3, r2]
|
|
800409c: 2194 movs r1, #148 ; 0x94
|
|
800409e: 187a adds r2, r7, r1
|
|
80040a0: 6013 str r3, [r2, #0]
|
|
if ((HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR)) ||
|
|
80040a2: 687b ldr r3, [r7, #4]
|
|
80040a4: 681b ldr r3, [r3, #0]
|
|
80040a6: 689b ldr r3, [r3, #8]
|
|
80040a8: 2240 movs r2, #64 ; 0x40
|
|
80040aa: 4013 ands r3, r2
|
|
80040ac: 2b40 cmp r3, #64 ; 0x40
|
|
80040ae: d004 beq.n 80040ba <HAL_UART_IRQHandler+0x1f2>
|
|
((errorcode & (HAL_UART_ERROR_RTO | HAL_UART_ERROR_ORE)) != 0U))
|
|
80040b0: 187b adds r3, r7, r1
|
|
80040b2: 681b ldr r3, [r3, #0]
|
|
80040b4: 2228 movs r2, #40 ; 0x28
|
|
80040b6: 4013 ands r3, r2
|
|
if ((HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR)) ||
|
|
80040b8: d047 beq.n 800414a <HAL_UART_IRQHandler+0x282>
|
|
{
|
|
/* Blocking error : transfer is aborted
|
|
Set the UART state ready to be able to start again the process,
|
|
Disable Rx Interrupts, and disable Rx DMA request, if ongoing */
|
|
UART_EndRxTransfer(huart);
|
|
80040ba: 687b ldr r3, [r7, #4]
|
|
80040bc: 0018 movs r0, r3
|
|
80040be: f000 fe1b bl 8004cf8 <UART_EndRxTransfer>
|
|
|
|
/* Disable the UART DMA Rx request if enabled */
|
|
if (HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR))
|
|
80040c2: 687b ldr r3, [r7, #4]
|
|
80040c4: 681b ldr r3, [r3, #0]
|
|
80040c6: 689b ldr r3, [r3, #8]
|
|
80040c8: 2240 movs r2, #64 ; 0x40
|
|
80040ca: 4013 ands r3, r2
|
|
80040cc: 2b40 cmp r3, #64 ; 0x40
|
|
80040ce: d137 bne.n 8004140 <HAL_UART_IRQHandler+0x278>
|
|
*/
|
|
__STATIC_FORCEINLINE uint32_t __get_PRIMASK(void)
|
|
{
|
|
uint32_t result;
|
|
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
80040d0: f3ef 8310 mrs r3, PRIMASK
|
|
80040d4: 663b str r3, [r7, #96] ; 0x60
|
|
return(result);
|
|
80040d6: 6e3b ldr r3, [r7, #96] ; 0x60
|
|
{
|
|
ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_DMAR);
|
|
80040d8: 2090 movs r0, #144 ; 0x90
|
|
80040da: 183a adds r2, r7, r0
|
|
80040dc: 6013 str r3, [r2, #0]
|
|
80040de: 2301 movs r3, #1
|
|
80040e0: 667b str r3, [r7, #100] ; 0x64
|
|
\details Assigns the given value to the Priority Mask Register.
|
|
\param [in] priMask Priority Mask
|
|
*/
|
|
__STATIC_FORCEINLINE void __set_PRIMASK(uint32_t priMask)
|
|
{
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
80040e2: 6e7b ldr r3, [r7, #100] ; 0x64
|
|
80040e4: f383 8810 msr PRIMASK, r3
|
|
}
|
|
80040e8: 46c0 nop ; (mov r8, r8)
|
|
80040ea: 687b ldr r3, [r7, #4]
|
|
80040ec: 681b ldr r3, [r3, #0]
|
|
80040ee: 689a ldr r2, [r3, #8]
|
|
80040f0: 687b ldr r3, [r7, #4]
|
|
80040f2: 681b ldr r3, [r3, #0]
|
|
80040f4: 2140 movs r1, #64 ; 0x40
|
|
80040f6: 438a bics r2, r1
|
|
80040f8: 609a str r2, [r3, #8]
|
|
80040fa: 183b adds r3, r7, r0
|
|
80040fc: 681b ldr r3, [r3, #0]
|
|
80040fe: 66bb str r3, [r7, #104] ; 0x68
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004100: 6ebb ldr r3, [r7, #104] ; 0x68
|
|
8004102: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004106: 46c0 nop ; (mov r8, r8)
|
|
|
|
/* Abort the UART DMA Rx channel */
|
|
if (huart->hdmarx != NULL)
|
|
8004108: 687b ldr r3, [r7, #4]
|
|
800410a: 6f1b ldr r3, [r3, #112] ; 0x70
|
|
800410c: 2b00 cmp r3, #0
|
|
800410e: d012 beq.n 8004136 <HAL_UART_IRQHandler+0x26e>
|
|
{
|
|
/* Set the UART DMA Abort callback :
|
|
will lead to call HAL_UART_ErrorCallback() at end of DMA abort procedure */
|
|
huart->hdmarx->XferAbortCallback = UART_DMAAbortOnError;
|
|
8004110: 687b ldr r3, [r7, #4]
|
|
8004112: 6f1b ldr r3, [r3, #112] ; 0x70
|
|
8004114: 4a14 ldr r2, [pc, #80] ; (8004168 <HAL_UART_IRQHandler+0x2a0>)
|
|
8004116: 639a str r2, [r3, #56] ; 0x38
|
|
|
|
/* Abort DMA RX */
|
|
if (HAL_DMA_Abort_IT(huart->hdmarx) != HAL_OK)
|
|
8004118: 687b ldr r3, [r7, #4]
|
|
800411a: 6f1b ldr r3, [r3, #112] ; 0x70
|
|
800411c: 0018 movs r0, r3
|
|
800411e: f7fd ff8b bl 8002038 <HAL_DMA_Abort_IT>
|
|
8004122: 1e03 subs r3, r0, #0
|
|
8004124: d01a beq.n 800415c <HAL_UART_IRQHandler+0x294>
|
|
{
|
|
/* Call Directly huart->hdmarx->XferAbortCallback function in case of error */
|
|
huart->hdmarx->XferAbortCallback(huart->hdmarx);
|
|
8004126: 687b ldr r3, [r7, #4]
|
|
8004128: 6f1b ldr r3, [r3, #112] ; 0x70
|
|
800412a: 6b9a ldr r2, [r3, #56] ; 0x38
|
|
800412c: 687b ldr r3, [r7, #4]
|
|
800412e: 6f1b ldr r3, [r3, #112] ; 0x70
|
|
8004130: 0018 movs r0, r3
|
|
8004132: 4790 blx r2
|
|
if (HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR))
|
|
8004134: e012 b.n 800415c <HAL_UART_IRQHandler+0x294>
|
|
#if (USE_HAL_UART_REGISTER_CALLBACKS == 1)
|
|
/*Call registered error callback*/
|
|
huart->ErrorCallback(huart);
|
|
#else
|
|
/*Call legacy weak error callback*/
|
|
HAL_UART_ErrorCallback(huart);
|
|
8004136: 687b ldr r3, [r7, #4]
|
|
8004138: 0018 movs r0, r3
|
|
800413a: f000 f9a7 bl 800448c <HAL_UART_ErrorCallback>
|
|
if (HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR))
|
|
800413e: e00d b.n 800415c <HAL_UART_IRQHandler+0x294>
|
|
#if (USE_HAL_UART_REGISTER_CALLBACKS == 1)
|
|
/*Call registered error callback*/
|
|
huart->ErrorCallback(huart);
|
|
#else
|
|
/*Call legacy weak error callback*/
|
|
HAL_UART_ErrorCallback(huart);
|
|
8004140: 687b ldr r3, [r7, #4]
|
|
8004142: 0018 movs r0, r3
|
|
8004144: f000 f9a2 bl 800448c <HAL_UART_ErrorCallback>
|
|
if (HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR))
|
|
8004148: e008 b.n 800415c <HAL_UART_IRQHandler+0x294>
|
|
#if (USE_HAL_UART_REGISTER_CALLBACKS == 1)
|
|
/*Call registered error callback*/
|
|
huart->ErrorCallback(huart);
|
|
#else
|
|
/*Call legacy weak error callback*/
|
|
HAL_UART_ErrorCallback(huart);
|
|
800414a: 687b ldr r3, [r7, #4]
|
|
800414c: 0018 movs r0, r3
|
|
800414e: f000 f99d bl 800448c <HAL_UART_ErrorCallback>
|
|
#endif /* USE_HAL_UART_REGISTER_CALLBACKS */
|
|
huart->ErrorCode = HAL_UART_ERROR_NONE;
|
|
8004152: 687b ldr r3, [r7, #4]
|
|
8004154: 2280 movs r2, #128 ; 0x80
|
|
8004156: 2100 movs r1, #0
|
|
8004158: 5099 str r1, [r3, r2]
|
|
}
|
|
}
|
|
return;
|
|
800415a: e181 b.n 8004460 <HAL_UART_IRQHandler+0x598>
|
|
if (HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR))
|
|
800415c: 46c0 nop ; (mov r8, r8)
|
|
return;
|
|
800415e: e17f b.n 8004460 <HAL_UART_IRQHandler+0x598>
|
|
8004160: 0000080f .word 0x0000080f
|
|
8004164: 04000120 .word 0x04000120
|
|
8004168: 08004dbd .word 0x08004dbd
|
|
|
|
} /* End if some error occurs */
|
|
|
|
/* Check current reception Mode :
|
|
If Reception till IDLE event has been selected : */
|
|
if ((huart->ReceptionType == HAL_UART_RECEPTION_TOIDLE)
|
|
800416c: 687b ldr r3, [r7, #4]
|
|
800416e: 6e1b ldr r3, [r3, #96] ; 0x60
|
|
8004170: 2b01 cmp r3, #1
|
|
8004172: d000 beq.n 8004176 <HAL_UART_IRQHandler+0x2ae>
|
|
8004174: e133 b.n 80043de <HAL_UART_IRQHandler+0x516>
|
|
&& ((isrflags & USART_ISR_IDLE) != 0U)
|
|
8004176: 23a4 movs r3, #164 ; 0xa4
|
|
8004178: 18fb adds r3, r7, r3
|
|
800417a: 681b ldr r3, [r3, #0]
|
|
800417c: 2210 movs r2, #16
|
|
800417e: 4013 ands r3, r2
|
|
8004180: d100 bne.n 8004184 <HAL_UART_IRQHandler+0x2bc>
|
|
8004182: e12c b.n 80043de <HAL_UART_IRQHandler+0x516>
|
|
&& ((cr1its & USART_ISR_IDLE) != 0U))
|
|
8004184: 23a0 movs r3, #160 ; 0xa0
|
|
8004186: 18fb adds r3, r7, r3
|
|
8004188: 681b ldr r3, [r3, #0]
|
|
800418a: 2210 movs r2, #16
|
|
800418c: 4013 ands r3, r2
|
|
800418e: d100 bne.n 8004192 <HAL_UART_IRQHandler+0x2ca>
|
|
8004190: e125 b.n 80043de <HAL_UART_IRQHandler+0x516>
|
|
{
|
|
__HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_IDLEF);
|
|
8004192: 687b ldr r3, [r7, #4]
|
|
8004194: 681b ldr r3, [r3, #0]
|
|
8004196: 2210 movs r2, #16
|
|
8004198: 621a str r2, [r3, #32]
|
|
|
|
/* Check if DMA mode is enabled in UART */
|
|
if (HAL_IS_BIT_SET(huart->Instance->CR3, USART_CR3_DMAR))
|
|
800419a: 687b ldr r3, [r7, #4]
|
|
800419c: 681b ldr r3, [r3, #0]
|
|
800419e: 689b ldr r3, [r3, #8]
|
|
80041a0: 2240 movs r2, #64 ; 0x40
|
|
80041a2: 4013 ands r3, r2
|
|
80041a4: 2b40 cmp r3, #64 ; 0x40
|
|
80041a6: d000 beq.n 80041aa <HAL_UART_IRQHandler+0x2e2>
|
|
80041a8: e09d b.n 80042e6 <HAL_UART_IRQHandler+0x41e>
|
|
{
|
|
/* DMA mode enabled */
|
|
/* Check received length : If all expected data are received, do nothing,
|
|
(DMA cplt callback will be called).
|
|
Otherwise, if at least one data has already been received, IDLE event is to be notified to user */
|
|
uint16_t nb_remaining_rx_data = (uint16_t) __HAL_DMA_GET_COUNTER(huart->hdmarx);
|
|
80041aa: 687b ldr r3, [r7, #4]
|
|
80041ac: 6f1b ldr r3, [r3, #112] ; 0x70
|
|
80041ae: 681b ldr r3, [r3, #0]
|
|
80041b0: 685a ldr r2, [r3, #4]
|
|
80041b2: 217e movs r1, #126 ; 0x7e
|
|
80041b4: 187b adds r3, r7, r1
|
|
80041b6: 801a strh r2, [r3, #0]
|
|
if ((nb_remaining_rx_data > 0U)
|
|
80041b8: 187b adds r3, r7, r1
|
|
80041ba: 881b ldrh r3, [r3, #0]
|
|
80041bc: 2b00 cmp r3, #0
|
|
80041be: d100 bne.n 80041c2 <HAL_UART_IRQHandler+0x2fa>
|
|
80041c0: e150 b.n 8004464 <HAL_UART_IRQHandler+0x59c>
|
|
&& (nb_remaining_rx_data < huart->RxXferSize))
|
|
80041c2: 687b ldr r3, [r7, #4]
|
|
80041c4: 2258 movs r2, #88 ; 0x58
|
|
80041c6: 5a9b ldrh r3, [r3, r2]
|
|
80041c8: 187a adds r2, r7, r1
|
|
80041ca: 8812 ldrh r2, [r2, #0]
|
|
80041cc: 429a cmp r2, r3
|
|
80041ce: d300 bcc.n 80041d2 <HAL_UART_IRQHandler+0x30a>
|
|
80041d0: e148 b.n 8004464 <HAL_UART_IRQHandler+0x59c>
|
|
{
|
|
/* Reception is not complete */
|
|
huart->RxXferCount = nb_remaining_rx_data;
|
|
80041d2: 687b ldr r3, [r7, #4]
|
|
80041d4: 187a adds r2, r7, r1
|
|
80041d6: 215a movs r1, #90 ; 0x5a
|
|
80041d8: 8812 ldrh r2, [r2, #0]
|
|
80041da: 525a strh r2, [r3, r1]
|
|
|
|
/* In Normal mode, end DMA xfer and HAL UART Rx process*/
|
|
if (HAL_IS_BIT_CLR(huart->hdmarx->Instance->CCR, DMA_CCR_CIRC))
|
|
80041dc: 687b ldr r3, [r7, #4]
|
|
80041de: 6f1b ldr r3, [r3, #112] ; 0x70
|
|
80041e0: 681b ldr r3, [r3, #0]
|
|
80041e2: 681b ldr r3, [r3, #0]
|
|
80041e4: 2220 movs r2, #32
|
|
80041e6: 4013 ands r3, r2
|
|
80041e8: d16e bne.n 80042c8 <HAL_UART_IRQHandler+0x400>
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
80041ea: f3ef 8310 mrs r3, PRIMASK
|
|
80041ee: 633b str r3, [r7, #48] ; 0x30
|
|
return(result);
|
|
80041f0: 6b3b ldr r3, [r7, #48] ; 0x30
|
|
{
|
|
/* Disable PE and ERR (Frame error, noise error, overrun error) interrupts */
|
|
ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_PEIE);
|
|
80041f2: 67bb str r3, [r7, #120] ; 0x78
|
|
80041f4: 2301 movs r3, #1
|
|
80041f6: 637b str r3, [r7, #52] ; 0x34
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
80041f8: 6b7b ldr r3, [r7, #52] ; 0x34
|
|
80041fa: f383 8810 msr PRIMASK, r3
|
|
}
|
|
80041fe: 46c0 nop ; (mov r8, r8)
|
|
8004200: 687b ldr r3, [r7, #4]
|
|
8004202: 681b ldr r3, [r3, #0]
|
|
8004204: 681a ldr r2, [r3, #0]
|
|
8004206: 687b ldr r3, [r7, #4]
|
|
8004208: 681b ldr r3, [r3, #0]
|
|
800420a: 499a ldr r1, [pc, #616] ; (8004474 <HAL_UART_IRQHandler+0x5ac>)
|
|
800420c: 400a ands r2, r1
|
|
800420e: 601a str r2, [r3, #0]
|
|
8004210: 6fbb ldr r3, [r7, #120] ; 0x78
|
|
8004212: 63bb str r3, [r7, #56] ; 0x38
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004214: 6bbb ldr r3, [r7, #56] ; 0x38
|
|
8004216: f383 8810 msr PRIMASK, r3
|
|
}
|
|
800421a: 46c0 nop ; (mov r8, r8)
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
800421c: f3ef 8310 mrs r3, PRIMASK
|
|
8004220: 63fb str r3, [r7, #60] ; 0x3c
|
|
return(result);
|
|
8004222: 6bfb ldr r3, [r7, #60] ; 0x3c
|
|
ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE);
|
|
8004224: 677b str r3, [r7, #116] ; 0x74
|
|
8004226: 2301 movs r3, #1
|
|
8004228: 643b str r3, [r7, #64] ; 0x40
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
800422a: 6c3b ldr r3, [r7, #64] ; 0x40
|
|
800422c: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004230: 46c0 nop ; (mov r8, r8)
|
|
8004232: 687b ldr r3, [r7, #4]
|
|
8004234: 681b ldr r3, [r3, #0]
|
|
8004236: 689a ldr r2, [r3, #8]
|
|
8004238: 687b ldr r3, [r7, #4]
|
|
800423a: 681b ldr r3, [r3, #0]
|
|
800423c: 2101 movs r1, #1
|
|
800423e: 438a bics r2, r1
|
|
8004240: 609a str r2, [r3, #8]
|
|
8004242: 6f7b ldr r3, [r7, #116] ; 0x74
|
|
8004244: 647b str r3, [r7, #68] ; 0x44
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004246: 6c7b ldr r3, [r7, #68] ; 0x44
|
|
8004248: f383 8810 msr PRIMASK, r3
|
|
}
|
|
800424c: 46c0 nop ; (mov r8, r8)
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
800424e: f3ef 8310 mrs r3, PRIMASK
|
|
8004252: 64bb str r3, [r7, #72] ; 0x48
|
|
return(result);
|
|
8004254: 6cbb ldr r3, [r7, #72] ; 0x48
|
|
|
|
/* Disable the DMA transfer for the receiver request by resetting the DMAR bit
|
|
in the UART CR3 register */
|
|
ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_DMAR);
|
|
8004256: 673b str r3, [r7, #112] ; 0x70
|
|
8004258: 2301 movs r3, #1
|
|
800425a: 64fb str r3, [r7, #76] ; 0x4c
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
800425c: 6cfb ldr r3, [r7, #76] ; 0x4c
|
|
800425e: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004262: 46c0 nop ; (mov r8, r8)
|
|
8004264: 687b ldr r3, [r7, #4]
|
|
8004266: 681b ldr r3, [r3, #0]
|
|
8004268: 689a ldr r2, [r3, #8]
|
|
800426a: 687b ldr r3, [r7, #4]
|
|
800426c: 681b ldr r3, [r3, #0]
|
|
800426e: 2140 movs r1, #64 ; 0x40
|
|
8004270: 438a bics r2, r1
|
|
8004272: 609a str r2, [r3, #8]
|
|
8004274: 6f3b ldr r3, [r7, #112] ; 0x70
|
|
8004276: 653b str r3, [r7, #80] ; 0x50
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004278: 6d3b ldr r3, [r7, #80] ; 0x50
|
|
800427a: f383 8810 msr PRIMASK, r3
|
|
}
|
|
800427e: 46c0 nop ; (mov r8, r8)
|
|
|
|
/* At end of Rx process, restore huart->RxState to Ready */
|
|
huart->RxState = HAL_UART_STATE_READY;
|
|
8004280: 687b ldr r3, [r7, #4]
|
|
8004282: 2220 movs r2, #32
|
|
8004284: 67da str r2, [r3, #124] ; 0x7c
|
|
huart->ReceptionType = HAL_UART_RECEPTION_STANDARD;
|
|
8004286: 687b ldr r3, [r7, #4]
|
|
8004288: 2200 movs r2, #0
|
|
800428a: 661a str r2, [r3, #96] ; 0x60
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
800428c: f3ef 8310 mrs r3, PRIMASK
|
|
8004290: 657b str r3, [r7, #84] ; 0x54
|
|
return(result);
|
|
8004292: 6d7b ldr r3, [r7, #84] ; 0x54
|
|
|
|
ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_IDLEIE);
|
|
8004294: 66fb str r3, [r7, #108] ; 0x6c
|
|
8004296: 2301 movs r3, #1
|
|
8004298: 65bb str r3, [r7, #88] ; 0x58
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
800429a: 6dbb ldr r3, [r7, #88] ; 0x58
|
|
800429c: f383 8810 msr PRIMASK, r3
|
|
}
|
|
80042a0: 46c0 nop ; (mov r8, r8)
|
|
80042a2: 687b ldr r3, [r7, #4]
|
|
80042a4: 681b ldr r3, [r3, #0]
|
|
80042a6: 681a ldr r2, [r3, #0]
|
|
80042a8: 687b ldr r3, [r7, #4]
|
|
80042aa: 681b ldr r3, [r3, #0]
|
|
80042ac: 2110 movs r1, #16
|
|
80042ae: 438a bics r2, r1
|
|
80042b0: 601a str r2, [r3, #0]
|
|
80042b2: 6efb ldr r3, [r7, #108] ; 0x6c
|
|
80042b4: 65fb str r3, [r7, #92] ; 0x5c
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
80042b6: 6dfb ldr r3, [r7, #92] ; 0x5c
|
|
80042b8: f383 8810 msr PRIMASK, r3
|
|
}
|
|
80042bc: 46c0 nop ; (mov r8, r8)
|
|
|
|
/* Last bytes received, so no need as the abort is immediate */
|
|
(void)HAL_DMA_Abort(huart->hdmarx);
|
|
80042be: 687b ldr r3, [r7, #4]
|
|
80042c0: 6f1b ldr r3, [r3, #112] ; 0x70
|
|
80042c2: 0018 movs r0, r3
|
|
80042c4: f7fd fe78 bl 8001fb8 <HAL_DMA_Abort>
|
|
#if (USE_HAL_UART_REGISTER_CALLBACKS == 1)
|
|
/*Call registered Rx Event callback*/
|
|
huart->RxEventCallback(huart, (huart->RxXferSize - huart->RxXferCount));
|
|
#else
|
|
/*Call legacy weak Rx Event callback*/
|
|
HAL_UARTEx_RxEventCallback(huart, (huart->RxXferSize - huart->RxXferCount));
|
|
80042c8: 687b ldr r3, [r7, #4]
|
|
80042ca: 2258 movs r2, #88 ; 0x58
|
|
80042cc: 5a9a ldrh r2, [r3, r2]
|
|
80042ce: 687b ldr r3, [r7, #4]
|
|
80042d0: 215a movs r1, #90 ; 0x5a
|
|
80042d2: 5a5b ldrh r3, [r3, r1]
|
|
80042d4: b29b uxth r3, r3
|
|
80042d6: 1ad3 subs r3, r2, r3
|
|
80042d8: b29a uxth r2, r3
|
|
80042da: 687b ldr r3, [r7, #4]
|
|
80042dc: 0011 movs r1, r2
|
|
80042de: 0018 movs r0, r3
|
|
80042e0: f000 f8dc bl 800449c <HAL_UARTEx_RxEventCallback>
|
|
#endif /* (USE_HAL_UART_REGISTER_CALLBACKS) */
|
|
}
|
|
return;
|
|
80042e4: e0be b.n 8004464 <HAL_UART_IRQHandler+0x59c>
|
|
else
|
|
{
|
|
/* DMA mode not enabled */
|
|
/* Check received length : If all expected data are received, do nothing.
|
|
Otherwise, if at least one data has already been received, IDLE event is to be notified to user */
|
|
uint16_t nb_rx_data = huart->RxXferSize - huart->RxXferCount;
|
|
80042e6: 687b ldr r3, [r7, #4]
|
|
80042e8: 2258 movs r2, #88 ; 0x58
|
|
80042ea: 5a99 ldrh r1, [r3, r2]
|
|
80042ec: 687b ldr r3, [r7, #4]
|
|
80042ee: 225a movs r2, #90 ; 0x5a
|
|
80042f0: 5a9b ldrh r3, [r3, r2]
|
|
80042f2: b29a uxth r2, r3
|
|
80042f4: 208e movs r0, #142 ; 0x8e
|
|
80042f6: 183b adds r3, r7, r0
|
|
80042f8: 1a8a subs r2, r1, r2
|
|
80042fa: 801a strh r2, [r3, #0]
|
|
if ((huart->RxXferCount > 0U)
|
|
80042fc: 687b ldr r3, [r7, #4]
|
|
80042fe: 225a movs r2, #90 ; 0x5a
|
|
8004300: 5a9b ldrh r3, [r3, r2]
|
|
8004302: b29b uxth r3, r3
|
|
8004304: 2b00 cmp r3, #0
|
|
8004306: d100 bne.n 800430a <HAL_UART_IRQHandler+0x442>
|
|
8004308: e0ae b.n 8004468 <HAL_UART_IRQHandler+0x5a0>
|
|
&& (nb_rx_data > 0U))
|
|
800430a: 183b adds r3, r7, r0
|
|
800430c: 881b ldrh r3, [r3, #0]
|
|
800430e: 2b00 cmp r3, #0
|
|
8004310: d100 bne.n 8004314 <HAL_UART_IRQHandler+0x44c>
|
|
8004312: e0a9 b.n 8004468 <HAL_UART_IRQHandler+0x5a0>
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
8004314: f3ef 8310 mrs r3, PRIMASK
|
|
8004318: 60fb str r3, [r7, #12]
|
|
return(result);
|
|
800431a: 68fb ldr r3, [r7, #12]
|
|
{
|
|
/* Disable the UART Parity Error Interrupt and RXNE interrupts */
|
|
ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE));
|
|
800431c: 2488 movs r4, #136 ; 0x88
|
|
800431e: 193a adds r2, r7, r4
|
|
8004320: 6013 str r3, [r2, #0]
|
|
8004322: 2301 movs r3, #1
|
|
8004324: 613b str r3, [r7, #16]
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004326: 693b ldr r3, [r7, #16]
|
|
8004328: f383 8810 msr PRIMASK, r3
|
|
}
|
|
800432c: 46c0 nop ; (mov r8, r8)
|
|
800432e: 687b ldr r3, [r7, #4]
|
|
8004330: 681b ldr r3, [r3, #0]
|
|
8004332: 681a ldr r2, [r3, #0]
|
|
8004334: 687b ldr r3, [r7, #4]
|
|
8004336: 681b ldr r3, [r3, #0]
|
|
8004338: 494f ldr r1, [pc, #316] ; (8004478 <HAL_UART_IRQHandler+0x5b0>)
|
|
800433a: 400a ands r2, r1
|
|
800433c: 601a str r2, [r3, #0]
|
|
800433e: 193b adds r3, r7, r4
|
|
8004340: 681b ldr r3, [r3, #0]
|
|
8004342: 617b str r3, [r7, #20]
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004344: 697b ldr r3, [r7, #20]
|
|
8004346: f383 8810 msr PRIMASK, r3
|
|
}
|
|
800434a: 46c0 nop ; (mov r8, r8)
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
800434c: f3ef 8310 mrs r3, PRIMASK
|
|
8004350: 61bb str r3, [r7, #24]
|
|
return(result);
|
|
8004352: 69bb ldr r3, [r7, #24]
|
|
|
|
/* Disable the UART Error Interrupt: (Frame error, noise error, overrun error) */
|
|
ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE);
|
|
8004354: 2484 movs r4, #132 ; 0x84
|
|
8004356: 193a adds r2, r7, r4
|
|
8004358: 6013 str r3, [r2, #0]
|
|
800435a: 2301 movs r3, #1
|
|
800435c: 61fb str r3, [r7, #28]
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
800435e: 69fb ldr r3, [r7, #28]
|
|
8004360: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004364: 46c0 nop ; (mov r8, r8)
|
|
8004366: 687b ldr r3, [r7, #4]
|
|
8004368: 681b ldr r3, [r3, #0]
|
|
800436a: 689a ldr r2, [r3, #8]
|
|
800436c: 687b ldr r3, [r7, #4]
|
|
800436e: 681b ldr r3, [r3, #0]
|
|
8004370: 2101 movs r1, #1
|
|
8004372: 438a bics r2, r1
|
|
8004374: 609a str r2, [r3, #8]
|
|
8004376: 193b adds r3, r7, r4
|
|
8004378: 681b ldr r3, [r3, #0]
|
|
800437a: 623b str r3, [r7, #32]
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
800437c: 6a3b ldr r3, [r7, #32]
|
|
800437e: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004382: 46c0 nop ; (mov r8, r8)
|
|
|
|
/* Rx process is completed, restore huart->RxState to Ready */
|
|
huart->RxState = HAL_UART_STATE_READY;
|
|
8004384: 687b ldr r3, [r7, #4]
|
|
8004386: 2220 movs r2, #32
|
|
8004388: 67da str r2, [r3, #124] ; 0x7c
|
|
huart->ReceptionType = HAL_UART_RECEPTION_STANDARD;
|
|
800438a: 687b ldr r3, [r7, #4]
|
|
800438c: 2200 movs r2, #0
|
|
800438e: 661a str r2, [r3, #96] ; 0x60
|
|
|
|
/* Clear RxISR function pointer */
|
|
huart->RxISR = NULL;
|
|
8004390: 687b ldr r3, [r7, #4]
|
|
8004392: 2200 movs r2, #0
|
|
8004394: 665a str r2, [r3, #100] ; 0x64
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
8004396: f3ef 8310 mrs r3, PRIMASK
|
|
800439a: 627b str r3, [r7, #36] ; 0x24
|
|
return(result);
|
|
800439c: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
|
|
ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_IDLEIE);
|
|
800439e: 2480 movs r4, #128 ; 0x80
|
|
80043a0: 193a adds r2, r7, r4
|
|
80043a2: 6013 str r3, [r2, #0]
|
|
80043a4: 2301 movs r3, #1
|
|
80043a6: 62bb str r3, [r7, #40] ; 0x28
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
80043a8: 6abb ldr r3, [r7, #40] ; 0x28
|
|
80043aa: f383 8810 msr PRIMASK, r3
|
|
}
|
|
80043ae: 46c0 nop ; (mov r8, r8)
|
|
80043b0: 687b ldr r3, [r7, #4]
|
|
80043b2: 681b ldr r3, [r3, #0]
|
|
80043b4: 681a ldr r2, [r3, #0]
|
|
80043b6: 687b ldr r3, [r7, #4]
|
|
80043b8: 681b ldr r3, [r3, #0]
|
|
80043ba: 2110 movs r1, #16
|
|
80043bc: 438a bics r2, r1
|
|
80043be: 601a str r2, [r3, #0]
|
|
80043c0: 193b adds r3, r7, r4
|
|
80043c2: 681b ldr r3, [r3, #0]
|
|
80043c4: 62fb str r3, [r7, #44] ; 0x2c
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
80043c6: 6afb ldr r3, [r7, #44] ; 0x2c
|
|
80043c8: f383 8810 msr PRIMASK, r3
|
|
}
|
|
80043cc: 46c0 nop ; (mov r8, r8)
|
|
#if (USE_HAL_UART_REGISTER_CALLBACKS == 1)
|
|
/*Call registered Rx complete callback*/
|
|
huart->RxEventCallback(huart, nb_rx_data);
|
|
#else
|
|
/*Call legacy weak Rx Event callback*/
|
|
HAL_UARTEx_RxEventCallback(huart, nb_rx_data);
|
|
80043ce: 183b adds r3, r7, r0
|
|
80043d0: 881a ldrh r2, [r3, #0]
|
|
80043d2: 687b ldr r3, [r7, #4]
|
|
80043d4: 0011 movs r1, r2
|
|
80043d6: 0018 movs r0, r3
|
|
80043d8: f000 f860 bl 800449c <HAL_UARTEx_RxEventCallback>
|
|
#endif /* (USE_HAL_UART_REGISTER_CALLBACKS) */
|
|
}
|
|
return;
|
|
80043dc: e044 b.n 8004468 <HAL_UART_IRQHandler+0x5a0>
|
|
}
|
|
}
|
|
|
|
/* UART wakeup from Stop mode interrupt occurred ---------------------------*/
|
|
if (((isrflags & USART_ISR_WUF) != 0U) && ((cr3its & USART_CR3_WUFIE) != 0U))
|
|
80043de: 23a4 movs r3, #164 ; 0xa4
|
|
80043e0: 18fb adds r3, r7, r3
|
|
80043e2: 681a ldr r2, [r3, #0]
|
|
80043e4: 2380 movs r3, #128 ; 0x80
|
|
80043e6: 035b lsls r3, r3, #13
|
|
80043e8: 4013 ands r3, r2
|
|
80043ea: d010 beq.n 800440e <HAL_UART_IRQHandler+0x546>
|
|
80043ec: 239c movs r3, #156 ; 0x9c
|
|
80043ee: 18fb adds r3, r7, r3
|
|
80043f0: 681a ldr r2, [r3, #0]
|
|
80043f2: 2380 movs r3, #128 ; 0x80
|
|
80043f4: 03db lsls r3, r3, #15
|
|
80043f6: 4013 ands r3, r2
|
|
80043f8: d009 beq.n 800440e <HAL_UART_IRQHandler+0x546>
|
|
{
|
|
__HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_WUF);
|
|
80043fa: 687b ldr r3, [r7, #4]
|
|
80043fc: 681b ldr r3, [r3, #0]
|
|
80043fe: 2280 movs r2, #128 ; 0x80
|
|
8004400: 0352 lsls r2, r2, #13
|
|
8004402: 621a str r2, [r3, #32]
|
|
#if (USE_HAL_UART_REGISTER_CALLBACKS == 1)
|
|
/* Call registered Wakeup Callback */
|
|
huart->WakeupCallback(huart);
|
|
#else
|
|
/* Call legacy weak Wakeup Callback */
|
|
HAL_UARTEx_WakeupCallback(huart);
|
|
8004404: 687b ldr r3, [r7, #4]
|
|
8004406: 0018 movs r0, r3
|
|
8004408: f000 fd1a bl 8004e40 <HAL_UARTEx_WakeupCallback>
|
|
#endif /* USE_HAL_UART_REGISTER_CALLBACKS */
|
|
return;
|
|
800440c: e02f b.n 800446e <HAL_UART_IRQHandler+0x5a6>
|
|
}
|
|
|
|
/* UART in mode Transmitter ------------------------------------------------*/
|
|
if (((isrflags & USART_ISR_TXE) != 0U)
|
|
800440e: 23a4 movs r3, #164 ; 0xa4
|
|
8004410: 18fb adds r3, r7, r3
|
|
8004412: 681b ldr r3, [r3, #0]
|
|
8004414: 2280 movs r2, #128 ; 0x80
|
|
8004416: 4013 ands r3, r2
|
|
8004418: d00f beq.n 800443a <HAL_UART_IRQHandler+0x572>
|
|
&& ((cr1its & USART_CR1_TXEIE) != 0U))
|
|
800441a: 23a0 movs r3, #160 ; 0xa0
|
|
800441c: 18fb adds r3, r7, r3
|
|
800441e: 681b ldr r3, [r3, #0]
|
|
8004420: 2280 movs r2, #128 ; 0x80
|
|
8004422: 4013 ands r3, r2
|
|
8004424: d009 beq.n 800443a <HAL_UART_IRQHandler+0x572>
|
|
{
|
|
if (huart->TxISR != NULL)
|
|
8004426: 687b ldr r3, [r7, #4]
|
|
8004428: 6e9b ldr r3, [r3, #104] ; 0x68
|
|
800442a: 2b00 cmp r3, #0
|
|
800442c: d01e beq.n 800446c <HAL_UART_IRQHandler+0x5a4>
|
|
{
|
|
huart->TxISR(huart);
|
|
800442e: 687b ldr r3, [r7, #4]
|
|
8004430: 6e9b ldr r3, [r3, #104] ; 0x68
|
|
8004432: 687a ldr r2, [r7, #4]
|
|
8004434: 0010 movs r0, r2
|
|
8004436: 4798 blx r3
|
|
}
|
|
return;
|
|
8004438: e018 b.n 800446c <HAL_UART_IRQHandler+0x5a4>
|
|
}
|
|
|
|
/* UART in mode Transmitter (transmission end) -----------------------------*/
|
|
if (((isrflags & USART_ISR_TC) != 0U) && ((cr1its & USART_CR1_TCIE) != 0U))
|
|
800443a: 23a4 movs r3, #164 ; 0xa4
|
|
800443c: 18fb adds r3, r7, r3
|
|
800443e: 681b ldr r3, [r3, #0]
|
|
8004440: 2240 movs r2, #64 ; 0x40
|
|
8004442: 4013 ands r3, r2
|
|
8004444: d013 beq.n 800446e <HAL_UART_IRQHandler+0x5a6>
|
|
8004446: 23a0 movs r3, #160 ; 0xa0
|
|
8004448: 18fb adds r3, r7, r3
|
|
800444a: 681b ldr r3, [r3, #0]
|
|
800444c: 2240 movs r2, #64 ; 0x40
|
|
800444e: 4013 ands r3, r2
|
|
8004450: d00d beq.n 800446e <HAL_UART_IRQHandler+0x5a6>
|
|
{
|
|
UART_EndTransmit_IT(huart);
|
|
8004452: 687b ldr r3, [r7, #4]
|
|
8004454: 0018 movs r0, r3
|
|
8004456: f000 fcc8 bl 8004dea <UART_EndTransmit_IT>
|
|
return;
|
|
800445a: e008 b.n 800446e <HAL_UART_IRQHandler+0x5a6>
|
|
return;
|
|
800445c: 46c0 nop ; (mov r8, r8)
|
|
800445e: e006 b.n 800446e <HAL_UART_IRQHandler+0x5a6>
|
|
return;
|
|
8004460: 46c0 nop ; (mov r8, r8)
|
|
8004462: e004 b.n 800446e <HAL_UART_IRQHandler+0x5a6>
|
|
return;
|
|
8004464: 46c0 nop ; (mov r8, r8)
|
|
8004466: e002 b.n 800446e <HAL_UART_IRQHandler+0x5a6>
|
|
return;
|
|
8004468: 46c0 nop ; (mov r8, r8)
|
|
800446a: e000 b.n 800446e <HAL_UART_IRQHandler+0x5a6>
|
|
return;
|
|
800446c: 46c0 nop ; (mov r8, r8)
|
|
}
|
|
|
|
}
|
|
800446e: 46bd mov sp, r7
|
|
8004470: b02b add sp, #172 ; 0xac
|
|
8004472: bd90 pop {r4, r7, pc}
|
|
8004474: fffffeff .word 0xfffffeff
|
|
8004478: fffffedf .word 0xfffffedf
|
|
|
|
0800447c <HAL_UART_TxCpltCallback>:
|
|
* @brief Tx Transfer completed callback.
|
|
* @param huart UART handle.
|
|
* @retval None
|
|
*/
|
|
__weak void HAL_UART_TxCpltCallback(UART_HandleTypeDef *huart)
|
|
{
|
|
800447c: b580 push {r7, lr}
|
|
800447e: b082 sub sp, #8
|
|
8004480: af00 add r7, sp, #0
|
|
8004482: 6078 str r0, [r7, #4]
|
|
UNUSED(huart);
|
|
|
|
/* NOTE : This function should not be modified, when the callback is needed,
|
|
the HAL_UART_TxCpltCallback can be implemented in the user file.
|
|
*/
|
|
}
|
|
8004484: 46c0 nop ; (mov r8, r8)
|
|
8004486: 46bd mov sp, r7
|
|
8004488: b002 add sp, #8
|
|
800448a: bd80 pop {r7, pc}
|
|
|
|
0800448c <HAL_UART_ErrorCallback>:
|
|
* @brief UART error callback.
|
|
* @param huart UART handle.
|
|
* @retval None
|
|
*/
|
|
__weak void HAL_UART_ErrorCallback(UART_HandleTypeDef *huart)
|
|
{
|
|
800448c: b580 push {r7, lr}
|
|
800448e: b082 sub sp, #8
|
|
8004490: af00 add r7, sp, #0
|
|
8004492: 6078 str r0, [r7, #4]
|
|
UNUSED(huart);
|
|
|
|
/* NOTE : This function should not be modified, when the callback is needed,
|
|
the HAL_UART_ErrorCallback can be implemented in the user file.
|
|
*/
|
|
}
|
|
8004494: 46c0 nop ; (mov r8, r8)
|
|
8004496: 46bd mov sp, r7
|
|
8004498: b002 add sp, #8
|
|
800449a: bd80 pop {r7, pc}
|
|
|
|
0800449c <HAL_UARTEx_RxEventCallback>:
|
|
* @param Size Number of data available in application reception buffer (indicates a position in
|
|
* reception buffer until which, data are available)
|
|
* @retval None
|
|
*/
|
|
__weak void HAL_UARTEx_RxEventCallback(UART_HandleTypeDef *huart, uint16_t Size)
|
|
{
|
|
800449c: b580 push {r7, lr}
|
|
800449e: b082 sub sp, #8
|
|
80044a0: af00 add r7, sp, #0
|
|
80044a2: 6078 str r0, [r7, #4]
|
|
80044a4: 000a movs r2, r1
|
|
80044a6: 1cbb adds r3, r7, #2
|
|
80044a8: 801a strh r2, [r3, #0]
|
|
UNUSED(Size);
|
|
|
|
/* NOTE : This function should not be modified, when the callback is needed,
|
|
the HAL_UARTEx_RxEventCallback can be implemented in the user file.
|
|
*/
|
|
}
|
|
80044aa: 46c0 nop ; (mov r8, r8)
|
|
80044ac: 46bd mov sp, r7
|
|
80044ae: b002 add sp, #8
|
|
80044b0: bd80 pop {r7, pc}
|
|
...
|
|
|
|
080044b4 <UART_SetConfig>:
|
|
* @brief Configure the UART peripheral.
|
|
* @param huart UART handle.
|
|
* @retval HAL status
|
|
*/
|
|
HAL_StatusTypeDef UART_SetConfig(UART_HandleTypeDef *huart)
|
|
{
|
|
80044b4: b5b0 push {r4, r5, r7, lr}
|
|
80044b6: b08e sub sp, #56 ; 0x38
|
|
80044b8: af00 add r7, sp, #0
|
|
80044ba: 61f8 str r0, [r7, #28]
|
|
uint32_t tmpreg;
|
|
uint16_t brrtemp;
|
|
UART_ClockSourceTypeDef clocksource;
|
|
uint32_t usartdiv;
|
|
HAL_StatusTypeDef ret = HAL_OK;
|
|
80044bc: 231a movs r3, #26
|
|
80044be: 2218 movs r2, #24
|
|
80044c0: 4694 mov ip, r2
|
|
80044c2: 44bc add ip, r7
|
|
80044c4: 4463 add r3, ip
|
|
80044c6: 2200 movs r2, #0
|
|
80044c8: 701a strb r2, [r3, #0]
|
|
* the UART Word Length, Parity, Mode and oversampling:
|
|
* set the M bits according to huart->Init.WordLength value
|
|
* set PCE and PS bits according to huart->Init.Parity value
|
|
* set TE and RE bits according to huart->Init.Mode value
|
|
* set OVER8 bit according to huart->Init.OverSampling value */
|
|
tmpreg = (uint32_t)huart->Init.WordLength | huart->Init.Parity | huart->Init.Mode | huart->Init.OverSampling ;
|
|
80044ca: 69fb ldr r3, [r7, #28]
|
|
80044cc: 689a ldr r2, [r3, #8]
|
|
80044ce: 69fb ldr r3, [r7, #28]
|
|
80044d0: 691b ldr r3, [r3, #16]
|
|
80044d2: 431a orrs r2, r3
|
|
80044d4: 69fb ldr r3, [r7, #28]
|
|
80044d6: 695b ldr r3, [r3, #20]
|
|
80044d8: 431a orrs r2, r3
|
|
80044da: 69fb ldr r3, [r7, #28]
|
|
80044dc: 69db ldr r3, [r3, #28]
|
|
80044de: 4313 orrs r3, r2
|
|
80044e0: 637b str r3, [r7, #52] ; 0x34
|
|
MODIFY_REG(huart->Instance->CR1, USART_CR1_FIELDS, tmpreg);
|
|
80044e2: 69fb ldr r3, [r7, #28]
|
|
80044e4: 681b ldr r3, [r3, #0]
|
|
80044e6: 681b ldr r3, [r3, #0]
|
|
80044e8: 4abc ldr r2, [pc, #752] ; (80047dc <UART_SetConfig+0x328>)
|
|
80044ea: 4013 ands r3, r2
|
|
80044ec: 0019 movs r1, r3
|
|
80044ee: 69fb ldr r3, [r7, #28]
|
|
80044f0: 681b ldr r3, [r3, #0]
|
|
80044f2: 6b7a ldr r2, [r7, #52] ; 0x34
|
|
80044f4: 430a orrs r2, r1
|
|
80044f6: 601a str r2, [r3, #0]
|
|
|
|
/*-------------------------- USART CR2 Configuration -----------------------*/
|
|
/* Configure the UART Stop Bits: Set STOP[13:12] bits according
|
|
* to huart->Init.StopBits value */
|
|
MODIFY_REG(huart->Instance->CR2, USART_CR2_STOP, huart->Init.StopBits);
|
|
80044f8: 69fb ldr r3, [r7, #28]
|
|
80044fa: 681b ldr r3, [r3, #0]
|
|
80044fc: 685b ldr r3, [r3, #4]
|
|
80044fe: 4ab8 ldr r2, [pc, #736] ; (80047e0 <UART_SetConfig+0x32c>)
|
|
8004500: 4013 ands r3, r2
|
|
8004502: 0019 movs r1, r3
|
|
8004504: 69fb ldr r3, [r7, #28]
|
|
8004506: 68da ldr r2, [r3, #12]
|
|
8004508: 69fb ldr r3, [r7, #28]
|
|
800450a: 681b ldr r3, [r3, #0]
|
|
800450c: 430a orrs r2, r1
|
|
800450e: 605a str r2, [r3, #4]
|
|
/* Configure
|
|
* - UART HardWare Flow Control: set CTSE and RTSE bits according
|
|
* to huart->Init.HwFlowCtl value
|
|
* - one-bit sampling method versus three samples' majority rule according
|
|
* to huart->Init.OneBitSampling (not applicable to LPUART) */
|
|
tmpreg = (uint32_t)huart->Init.HwFlowCtl;
|
|
8004510: 69fb ldr r3, [r7, #28]
|
|
8004512: 699b ldr r3, [r3, #24]
|
|
8004514: 637b str r3, [r7, #52] ; 0x34
|
|
|
|
if (!(UART_INSTANCE_LOWPOWER(huart)))
|
|
8004516: 69fb ldr r3, [r7, #28]
|
|
8004518: 681b ldr r3, [r3, #0]
|
|
800451a: 4ab2 ldr r2, [pc, #712] ; (80047e4 <UART_SetConfig+0x330>)
|
|
800451c: 4293 cmp r3, r2
|
|
800451e: d004 beq.n 800452a <UART_SetConfig+0x76>
|
|
{
|
|
tmpreg |= huart->Init.OneBitSampling;
|
|
8004520: 69fb ldr r3, [r7, #28]
|
|
8004522: 6a1b ldr r3, [r3, #32]
|
|
8004524: 6b7a ldr r2, [r7, #52] ; 0x34
|
|
8004526: 4313 orrs r3, r2
|
|
8004528: 637b str r3, [r7, #52] ; 0x34
|
|
}
|
|
MODIFY_REG(huart->Instance->CR3, USART_CR3_FIELDS, tmpreg);
|
|
800452a: 69fb ldr r3, [r7, #28]
|
|
800452c: 681b ldr r3, [r3, #0]
|
|
800452e: 689b ldr r3, [r3, #8]
|
|
8004530: 4aad ldr r2, [pc, #692] ; (80047e8 <UART_SetConfig+0x334>)
|
|
8004532: 4013 ands r3, r2
|
|
8004534: 0019 movs r1, r3
|
|
8004536: 69fb ldr r3, [r7, #28]
|
|
8004538: 681b ldr r3, [r3, #0]
|
|
800453a: 6b7a ldr r2, [r7, #52] ; 0x34
|
|
800453c: 430a orrs r2, r1
|
|
800453e: 609a str r2, [r3, #8]
|
|
|
|
|
|
/*-------------------------- USART BRR Configuration -----------------------*/
|
|
UART_GETCLOCKSOURCE(huart, clocksource);
|
|
8004540: 69fb ldr r3, [r7, #28]
|
|
8004542: 681b ldr r3, [r3, #0]
|
|
8004544: 4aa9 ldr r2, [pc, #676] ; (80047ec <UART_SetConfig+0x338>)
|
|
8004546: 4293 cmp r3, r2
|
|
8004548: d136 bne.n 80045b8 <UART_SetConfig+0x104>
|
|
800454a: 4ba9 ldr r3, [pc, #676] ; (80047f0 <UART_SetConfig+0x33c>)
|
|
800454c: 6cdb ldr r3, [r3, #76] ; 0x4c
|
|
800454e: 220c movs r2, #12
|
|
8004550: 4013 ands r3, r2
|
|
8004552: 2b0c cmp r3, #12
|
|
8004554: d020 beq.n 8004598 <UART_SetConfig+0xe4>
|
|
8004556: d827 bhi.n 80045a8 <UART_SetConfig+0xf4>
|
|
8004558: 2b08 cmp r3, #8
|
|
800455a: d00d beq.n 8004578 <UART_SetConfig+0xc4>
|
|
800455c: d824 bhi.n 80045a8 <UART_SetConfig+0xf4>
|
|
800455e: 2b00 cmp r3, #0
|
|
8004560: d002 beq.n 8004568 <UART_SetConfig+0xb4>
|
|
8004562: 2b04 cmp r3, #4
|
|
8004564: d010 beq.n 8004588 <UART_SetConfig+0xd4>
|
|
8004566: e01f b.n 80045a8 <UART_SetConfig+0xf4>
|
|
8004568: 231b movs r3, #27
|
|
800456a: 2218 movs r2, #24
|
|
800456c: 4694 mov ip, r2
|
|
800456e: 44bc add ip, r7
|
|
8004570: 4463 add r3, ip
|
|
8004572: 2200 movs r2, #0
|
|
8004574: 701a strb r2, [r3, #0]
|
|
8004576: e06f b.n 8004658 <UART_SetConfig+0x1a4>
|
|
8004578: 231b movs r3, #27
|
|
800457a: 2218 movs r2, #24
|
|
800457c: 4694 mov ip, r2
|
|
800457e: 44bc add ip, r7
|
|
8004580: 4463 add r3, ip
|
|
8004582: 2202 movs r2, #2
|
|
8004584: 701a strb r2, [r3, #0]
|
|
8004586: e067 b.n 8004658 <UART_SetConfig+0x1a4>
|
|
8004588: 231b movs r3, #27
|
|
800458a: 2218 movs r2, #24
|
|
800458c: 4694 mov ip, r2
|
|
800458e: 44bc add ip, r7
|
|
8004590: 4463 add r3, ip
|
|
8004592: 2204 movs r2, #4
|
|
8004594: 701a strb r2, [r3, #0]
|
|
8004596: e05f b.n 8004658 <UART_SetConfig+0x1a4>
|
|
8004598: 231b movs r3, #27
|
|
800459a: 2218 movs r2, #24
|
|
800459c: 4694 mov ip, r2
|
|
800459e: 44bc add ip, r7
|
|
80045a0: 4463 add r3, ip
|
|
80045a2: 2208 movs r2, #8
|
|
80045a4: 701a strb r2, [r3, #0]
|
|
80045a6: e057 b.n 8004658 <UART_SetConfig+0x1a4>
|
|
80045a8: 231b movs r3, #27
|
|
80045aa: 2218 movs r2, #24
|
|
80045ac: 4694 mov ip, r2
|
|
80045ae: 44bc add ip, r7
|
|
80045b0: 4463 add r3, ip
|
|
80045b2: 2210 movs r2, #16
|
|
80045b4: 701a strb r2, [r3, #0]
|
|
80045b6: e04f b.n 8004658 <UART_SetConfig+0x1a4>
|
|
80045b8: 69fb ldr r3, [r7, #28]
|
|
80045ba: 681b ldr r3, [r3, #0]
|
|
80045bc: 4a89 ldr r2, [pc, #548] ; (80047e4 <UART_SetConfig+0x330>)
|
|
80045be: 4293 cmp r3, r2
|
|
80045c0: d143 bne.n 800464a <UART_SetConfig+0x196>
|
|
80045c2: 4b8b ldr r3, [pc, #556] ; (80047f0 <UART_SetConfig+0x33c>)
|
|
80045c4: 6cda ldr r2, [r3, #76] ; 0x4c
|
|
80045c6: 23c0 movs r3, #192 ; 0xc0
|
|
80045c8: 011b lsls r3, r3, #4
|
|
80045ca: 4013 ands r3, r2
|
|
80045cc: 22c0 movs r2, #192 ; 0xc0
|
|
80045ce: 0112 lsls r2, r2, #4
|
|
80045d0: 4293 cmp r3, r2
|
|
80045d2: d02a beq.n 800462a <UART_SetConfig+0x176>
|
|
80045d4: 22c0 movs r2, #192 ; 0xc0
|
|
80045d6: 0112 lsls r2, r2, #4
|
|
80045d8: 4293 cmp r3, r2
|
|
80045da: d82e bhi.n 800463a <UART_SetConfig+0x186>
|
|
80045dc: 2280 movs r2, #128 ; 0x80
|
|
80045de: 0112 lsls r2, r2, #4
|
|
80045e0: 4293 cmp r3, r2
|
|
80045e2: d012 beq.n 800460a <UART_SetConfig+0x156>
|
|
80045e4: 2280 movs r2, #128 ; 0x80
|
|
80045e6: 0112 lsls r2, r2, #4
|
|
80045e8: 4293 cmp r3, r2
|
|
80045ea: d826 bhi.n 800463a <UART_SetConfig+0x186>
|
|
80045ec: 2b00 cmp r3, #0
|
|
80045ee: d004 beq.n 80045fa <UART_SetConfig+0x146>
|
|
80045f0: 2280 movs r2, #128 ; 0x80
|
|
80045f2: 00d2 lsls r2, r2, #3
|
|
80045f4: 4293 cmp r3, r2
|
|
80045f6: d010 beq.n 800461a <UART_SetConfig+0x166>
|
|
80045f8: e01f b.n 800463a <UART_SetConfig+0x186>
|
|
80045fa: 231b movs r3, #27
|
|
80045fc: 2218 movs r2, #24
|
|
80045fe: 4694 mov ip, r2
|
|
8004600: 44bc add ip, r7
|
|
8004602: 4463 add r3, ip
|
|
8004604: 2200 movs r2, #0
|
|
8004606: 701a strb r2, [r3, #0]
|
|
8004608: e026 b.n 8004658 <UART_SetConfig+0x1a4>
|
|
800460a: 231b movs r3, #27
|
|
800460c: 2218 movs r2, #24
|
|
800460e: 4694 mov ip, r2
|
|
8004610: 44bc add ip, r7
|
|
8004612: 4463 add r3, ip
|
|
8004614: 2202 movs r2, #2
|
|
8004616: 701a strb r2, [r3, #0]
|
|
8004618: e01e b.n 8004658 <UART_SetConfig+0x1a4>
|
|
800461a: 231b movs r3, #27
|
|
800461c: 2218 movs r2, #24
|
|
800461e: 4694 mov ip, r2
|
|
8004620: 44bc add ip, r7
|
|
8004622: 4463 add r3, ip
|
|
8004624: 2204 movs r2, #4
|
|
8004626: 701a strb r2, [r3, #0]
|
|
8004628: e016 b.n 8004658 <UART_SetConfig+0x1a4>
|
|
800462a: 231b movs r3, #27
|
|
800462c: 2218 movs r2, #24
|
|
800462e: 4694 mov ip, r2
|
|
8004630: 44bc add ip, r7
|
|
8004632: 4463 add r3, ip
|
|
8004634: 2208 movs r2, #8
|
|
8004636: 701a strb r2, [r3, #0]
|
|
8004638: e00e b.n 8004658 <UART_SetConfig+0x1a4>
|
|
800463a: 231b movs r3, #27
|
|
800463c: 2218 movs r2, #24
|
|
800463e: 4694 mov ip, r2
|
|
8004640: 44bc add ip, r7
|
|
8004642: 4463 add r3, ip
|
|
8004644: 2210 movs r2, #16
|
|
8004646: 701a strb r2, [r3, #0]
|
|
8004648: e006 b.n 8004658 <UART_SetConfig+0x1a4>
|
|
800464a: 231b movs r3, #27
|
|
800464c: 2218 movs r2, #24
|
|
800464e: 4694 mov ip, r2
|
|
8004650: 44bc add ip, r7
|
|
8004652: 4463 add r3, ip
|
|
8004654: 2210 movs r2, #16
|
|
8004656: 701a strb r2, [r3, #0]
|
|
|
|
/* Check LPUART instance */
|
|
if (UART_INSTANCE_LOWPOWER(huart))
|
|
8004658: 69fb ldr r3, [r7, #28]
|
|
800465a: 681b ldr r3, [r3, #0]
|
|
800465c: 4a61 ldr r2, [pc, #388] ; (80047e4 <UART_SetConfig+0x330>)
|
|
800465e: 4293 cmp r3, r2
|
|
8004660: d000 beq.n 8004664 <UART_SetConfig+0x1b0>
|
|
8004662: e088 b.n 8004776 <UART_SetConfig+0x2c2>
|
|
{
|
|
/* Retrieve frequency clock */
|
|
switch (clocksource)
|
|
8004664: 231b movs r3, #27
|
|
8004666: 2218 movs r2, #24
|
|
8004668: 4694 mov ip, r2
|
|
800466a: 44bc add ip, r7
|
|
800466c: 4463 add r3, ip
|
|
800466e: 781b ldrb r3, [r3, #0]
|
|
8004670: 2b08 cmp r3, #8
|
|
8004672: d01d beq.n 80046b0 <UART_SetConfig+0x1fc>
|
|
8004674: dc20 bgt.n 80046b8 <UART_SetConfig+0x204>
|
|
8004676: 2b04 cmp r3, #4
|
|
8004678: d015 beq.n 80046a6 <UART_SetConfig+0x1f2>
|
|
800467a: dc1d bgt.n 80046b8 <UART_SetConfig+0x204>
|
|
800467c: 2b00 cmp r3, #0
|
|
800467e: d002 beq.n 8004686 <UART_SetConfig+0x1d2>
|
|
8004680: 2b02 cmp r3, #2
|
|
8004682: d005 beq.n 8004690 <UART_SetConfig+0x1dc>
|
|
8004684: e018 b.n 80046b8 <UART_SetConfig+0x204>
|
|
{
|
|
case UART_CLOCKSOURCE_PCLK1:
|
|
pclk = HAL_RCC_GetPCLK1Freq();
|
|
8004686: f7fe fd7f bl 8003188 <HAL_RCC_GetPCLK1Freq>
|
|
800468a: 0003 movs r3, r0
|
|
800468c: 62fb str r3, [r7, #44] ; 0x2c
|
|
break;
|
|
800468e: e01d b.n 80046cc <UART_SetConfig+0x218>
|
|
case UART_CLOCKSOURCE_HSI:
|
|
if (__HAL_RCC_GET_FLAG(RCC_FLAG_HSIDIV) != 0U)
|
|
8004690: 4b57 ldr r3, [pc, #348] ; (80047f0 <UART_SetConfig+0x33c>)
|
|
8004692: 681b ldr r3, [r3, #0]
|
|
8004694: 2210 movs r2, #16
|
|
8004696: 4013 ands r3, r2
|
|
8004698: d002 beq.n 80046a0 <UART_SetConfig+0x1ec>
|
|
{
|
|
pclk = (uint32_t)(HSI_VALUE >> 2U);
|
|
800469a: 4b56 ldr r3, [pc, #344] ; (80047f4 <UART_SetConfig+0x340>)
|
|
800469c: 62fb str r3, [r7, #44] ; 0x2c
|
|
}
|
|
else
|
|
{
|
|
pclk = (uint32_t) HSI_VALUE;
|
|
}
|
|
break;
|
|
800469e: e015 b.n 80046cc <UART_SetConfig+0x218>
|
|
pclk = (uint32_t) HSI_VALUE;
|
|
80046a0: 4b55 ldr r3, [pc, #340] ; (80047f8 <UART_SetConfig+0x344>)
|
|
80046a2: 62fb str r3, [r7, #44] ; 0x2c
|
|
break;
|
|
80046a4: e012 b.n 80046cc <UART_SetConfig+0x218>
|
|
case UART_CLOCKSOURCE_SYSCLK:
|
|
pclk = HAL_RCC_GetSysClockFreq();
|
|
80046a6: f7fe fcbf bl 8003028 <HAL_RCC_GetSysClockFreq>
|
|
80046aa: 0003 movs r3, r0
|
|
80046ac: 62fb str r3, [r7, #44] ; 0x2c
|
|
break;
|
|
80046ae: e00d b.n 80046cc <UART_SetConfig+0x218>
|
|
case UART_CLOCKSOURCE_LSE:
|
|
pclk = (uint32_t) LSE_VALUE;
|
|
80046b0: 2380 movs r3, #128 ; 0x80
|
|
80046b2: 021b lsls r3, r3, #8
|
|
80046b4: 62fb str r3, [r7, #44] ; 0x2c
|
|
break;
|
|
80046b6: e009 b.n 80046cc <UART_SetConfig+0x218>
|
|
default:
|
|
pclk = 0U;
|
|
80046b8: 2300 movs r3, #0
|
|
80046ba: 62fb str r3, [r7, #44] ; 0x2c
|
|
ret = HAL_ERROR;
|
|
80046bc: 231a movs r3, #26
|
|
80046be: 2218 movs r2, #24
|
|
80046c0: 4694 mov ip, r2
|
|
80046c2: 44bc add ip, r7
|
|
80046c4: 4463 add r3, ip
|
|
80046c6: 2201 movs r2, #1
|
|
80046c8: 701a strb r2, [r3, #0]
|
|
break;
|
|
80046ca: 46c0 nop ; (mov r8, r8)
|
|
}
|
|
|
|
/* If proper clock source reported */
|
|
if (pclk != 0U)
|
|
80046cc: 6afb ldr r3, [r7, #44] ; 0x2c
|
|
80046ce: 2b00 cmp r3, #0
|
|
80046d0: d100 bne.n 80046d4 <UART_SetConfig+0x220>
|
|
80046d2: e139 b.n 8004948 <UART_SetConfig+0x494>
|
|
{
|
|
/* No Prescaler applicable */
|
|
/* Ensure that Frequency clock is in the range [3 * baudrate, 4096 * baudrate] */
|
|
if ((pclk < (3U * huart->Init.BaudRate)) ||
|
|
80046d4: 69fb ldr r3, [r7, #28]
|
|
80046d6: 685a ldr r2, [r3, #4]
|
|
80046d8: 0013 movs r3, r2
|
|
80046da: 005b lsls r3, r3, #1
|
|
80046dc: 189b adds r3, r3, r2
|
|
80046de: 6afa ldr r2, [r7, #44] ; 0x2c
|
|
80046e0: 429a cmp r2, r3
|
|
80046e2: d305 bcc.n 80046f0 <UART_SetConfig+0x23c>
|
|
(pclk > (4096U * huart->Init.BaudRate)))
|
|
80046e4: 69fb ldr r3, [r7, #28]
|
|
80046e6: 685b ldr r3, [r3, #4]
|
|
80046e8: 031b lsls r3, r3, #12
|
|
if ((pclk < (3U * huart->Init.BaudRate)) ||
|
|
80046ea: 6afa ldr r2, [r7, #44] ; 0x2c
|
|
80046ec: 429a cmp r2, r3
|
|
80046ee: d907 bls.n 8004700 <UART_SetConfig+0x24c>
|
|
{
|
|
ret = HAL_ERROR;
|
|
80046f0: 231a movs r3, #26
|
|
80046f2: 2218 movs r2, #24
|
|
80046f4: 4694 mov ip, r2
|
|
80046f6: 44bc add ip, r7
|
|
80046f8: 4463 add r3, ip
|
|
80046fa: 2201 movs r2, #1
|
|
80046fc: 701a strb r2, [r3, #0]
|
|
80046fe: e123 b.n 8004948 <UART_SetConfig+0x494>
|
|
}
|
|
else
|
|
{
|
|
usartdiv = (uint32_t)(UART_DIV_LPUART(pclk, huart->Init.BaudRate));
|
|
8004700: 6afb ldr r3, [r7, #44] ; 0x2c
|
|
8004702: 613b str r3, [r7, #16]
|
|
8004704: 2300 movs r3, #0
|
|
8004706: 617b str r3, [r7, #20]
|
|
8004708: 6939 ldr r1, [r7, #16]
|
|
800470a: 697a ldr r2, [r7, #20]
|
|
800470c: 000b movs r3, r1
|
|
800470e: 0e1b lsrs r3, r3, #24
|
|
8004710: 0010 movs r0, r2
|
|
8004712: 0205 lsls r5, r0, #8
|
|
8004714: 431d orrs r5, r3
|
|
8004716: 000b movs r3, r1
|
|
8004718: 021c lsls r4, r3, #8
|
|
800471a: 69fb ldr r3, [r7, #28]
|
|
800471c: 685b ldr r3, [r3, #4]
|
|
800471e: 085b lsrs r3, r3, #1
|
|
8004720: 60bb str r3, [r7, #8]
|
|
8004722: 2300 movs r3, #0
|
|
8004724: 60fb str r3, [r7, #12]
|
|
8004726: 68b8 ldr r0, [r7, #8]
|
|
8004728: 68f9 ldr r1, [r7, #12]
|
|
800472a: 1900 adds r0, r0, r4
|
|
800472c: 4169 adcs r1, r5
|
|
800472e: 69fb ldr r3, [r7, #28]
|
|
8004730: 685b ldr r3, [r3, #4]
|
|
8004732: 603b str r3, [r7, #0]
|
|
8004734: 2300 movs r3, #0
|
|
8004736: 607b str r3, [r7, #4]
|
|
8004738: 683a ldr r2, [r7, #0]
|
|
800473a: 687b ldr r3, [r7, #4]
|
|
800473c: f7fb fd70 bl 8000220 <__aeabi_uldivmod>
|
|
8004740: 0002 movs r2, r0
|
|
8004742: 000b movs r3, r1
|
|
8004744: 0013 movs r3, r2
|
|
8004746: 62bb str r3, [r7, #40] ; 0x28
|
|
if ((usartdiv >= LPUART_BRR_MIN) && (usartdiv <= LPUART_BRR_MAX))
|
|
8004748: 6aba ldr r2, [r7, #40] ; 0x28
|
|
800474a: 23c0 movs r3, #192 ; 0xc0
|
|
800474c: 009b lsls r3, r3, #2
|
|
800474e: 429a cmp r2, r3
|
|
8004750: d309 bcc.n 8004766 <UART_SetConfig+0x2b2>
|
|
8004752: 6aba ldr r2, [r7, #40] ; 0x28
|
|
8004754: 2380 movs r3, #128 ; 0x80
|
|
8004756: 035b lsls r3, r3, #13
|
|
8004758: 429a cmp r2, r3
|
|
800475a: d204 bcs.n 8004766 <UART_SetConfig+0x2b2>
|
|
{
|
|
huart->Instance->BRR = usartdiv;
|
|
800475c: 69fb ldr r3, [r7, #28]
|
|
800475e: 681b ldr r3, [r3, #0]
|
|
8004760: 6aba ldr r2, [r7, #40] ; 0x28
|
|
8004762: 60da str r2, [r3, #12]
|
|
8004764: e0f0 b.n 8004948 <UART_SetConfig+0x494>
|
|
}
|
|
else
|
|
{
|
|
ret = HAL_ERROR;
|
|
8004766: 231a movs r3, #26
|
|
8004768: 2218 movs r2, #24
|
|
800476a: 4694 mov ip, r2
|
|
800476c: 44bc add ip, r7
|
|
800476e: 4463 add r3, ip
|
|
8004770: 2201 movs r2, #1
|
|
8004772: 701a strb r2, [r3, #0]
|
|
8004774: e0e8 b.n 8004948 <UART_SetConfig+0x494>
|
|
}
|
|
} /* if ( (pclk < (3 * huart->Init.BaudRate) ) || (pclk > (4096 * huart->Init.BaudRate) )) */
|
|
} /* if (pclk != 0) */
|
|
}
|
|
/* Check UART Over Sampling to set Baud Rate Register */
|
|
else if (huart->Init.OverSampling == UART_OVERSAMPLING_8)
|
|
8004776: 69fb ldr r3, [r7, #28]
|
|
8004778: 69da ldr r2, [r3, #28]
|
|
800477a: 2380 movs r3, #128 ; 0x80
|
|
800477c: 021b lsls r3, r3, #8
|
|
800477e: 429a cmp r2, r3
|
|
8004780: d000 beq.n 8004784 <UART_SetConfig+0x2d0>
|
|
8004782: e087 b.n 8004894 <UART_SetConfig+0x3e0>
|
|
{
|
|
switch (clocksource)
|
|
8004784: 231b movs r3, #27
|
|
8004786: 2218 movs r2, #24
|
|
8004788: 4694 mov ip, r2
|
|
800478a: 44bc add ip, r7
|
|
800478c: 4463 add r3, ip
|
|
800478e: 781b ldrb r3, [r3, #0]
|
|
8004790: 2b08 cmp r3, #8
|
|
8004792: d835 bhi.n 8004800 <UART_SetConfig+0x34c>
|
|
8004794: 009a lsls r2, r3, #2
|
|
8004796: 4b19 ldr r3, [pc, #100] ; (80047fc <UART_SetConfig+0x348>)
|
|
8004798: 18d3 adds r3, r2, r3
|
|
800479a: 681b ldr r3, [r3, #0]
|
|
800479c: 469f mov pc, r3
|
|
{
|
|
case UART_CLOCKSOURCE_PCLK1:
|
|
pclk = HAL_RCC_GetPCLK1Freq();
|
|
800479e: f7fe fcf3 bl 8003188 <HAL_RCC_GetPCLK1Freq>
|
|
80047a2: 0003 movs r3, r0
|
|
80047a4: 62fb str r3, [r7, #44] ; 0x2c
|
|
break;
|
|
80047a6: e035 b.n 8004814 <UART_SetConfig+0x360>
|
|
case UART_CLOCKSOURCE_PCLK2:
|
|
pclk = HAL_RCC_GetPCLK2Freq();
|
|
80047a8: f7fe fd04 bl 80031b4 <HAL_RCC_GetPCLK2Freq>
|
|
80047ac: 0003 movs r3, r0
|
|
80047ae: 62fb str r3, [r7, #44] ; 0x2c
|
|
break;
|
|
80047b0: e030 b.n 8004814 <UART_SetConfig+0x360>
|
|
case UART_CLOCKSOURCE_HSI:
|
|
if (__HAL_RCC_GET_FLAG(RCC_FLAG_HSIDIV) != 0U)
|
|
80047b2: 4b0f ldr r3, [pc, #60] ; (80047f0 <UART_SetConfig+0x33c>)
|
|
80047b4: 681b ldr r3, [r3, #0]
|
|
80047b6: 2210 movs r2, #16
|
|
80047b8: 4013 ands r3, r2
|
|
80047ba: d002 beq.n 80047c2 <UART_SetConfig+0x30e>
|
|
{
|
|
pclk = (uint32_t)(HSI_VALUE >> 2U);
|
|
80047bc: 4b0d ldr r3, [pc, #52] ; (80047f4 <UART_SetConfig+0x340>)
|
|
80047be: 62fb str r3, [r7, #44] ; 0x2c
|
|
}
|
|
else
|
|
{
|
|
pclk = (uint32_t) HSI_VALUE;
|
|
}
|
|
break;
|
|
80047c0: e028 b.n 8004814 <UART_SetConfig+0x360>
|
|
pclk = (uint32_t) HSI_VALUE;
|
|
80047c2: 4b0d ldr r3, [pc, #52] ; (80047f8 <UART_SetConfig+0x344>)
|
|
80047c4: 62fb str r3, [r7, #44] ; 0x2c
|
|
break;
|
|
80047c6: e025 b.n 8004814 <UART_SetConfig+0x360>
|
|
case UART_CLOCKSOURCE_SYSCLK:
|
|
pclk = HAL_RCC_GetSysClockFreq();
|
|
80047c8: f7fe fc2e bl 8003028 <HAL_RCC_GetSysClockFreq>
|
|
80047cc: 0003 movs r3, r0
|
|
80047ce: 62fb str r3, [r7, #44] ; 0x2c
|
|
break;
|
|
80047d0: e020 b.n 8004814 <UART_SetConfig+0x360>
|
|
case UART_CLOCKSOURCE_LSE:
|
|
pclk = (uint32_t) LSE_VALUE;
|
|
80047d2: 2380 movs r3, #128 ; 0x80
|
|
80047d4: 021b lsls r3, r3, #8
|
|
80047d6: 62fb str r3, [r7, #44] ; 0x2c
|
|
break;
|
|
80047d8: e01c b.n 8004814 <UART_SetConfig+0x360>
|
|
80047da: 46c0 nop ; (mov r8, r8)
|
|
80047dc: efff69f3 .word 0xefff69f3
|
|
80047e0: ffffcfff .word 0xffffcfff
|
|
80047e4: 40004800 .word 0x40004800
|
|
80047e8: fffff4ff .word 0xfffff4ff
|
|
80047ec: 40004400 .word 0x40004400
|
|
80047f0: 40021000 .word 0x40021000
|
|
80047f4: 003d0900 .word 0x003d0900
|
|
80047f8: 00f42400 .word 0x00f42400
|
|
80047fc: 080078a8 .word 0x080078a8
|
|
default:
|
|
pclk = 0U;
|
|
8004800: 2300 movs r3, #0
|
|
8004802: 62fb str r3, [r7, #44] ; 0x2c
|
|
ret = HAL_ERROR;
|
|
8004804: 231a movs r3, #26
|
|
8004806: 2218 movs r2, #24
|
|
8004808: 4694 mov ip, r2
|
|
800480a: 44bc add ip, r7
|
|
800480c: 4463 add r3, ip
|
|
800480e: 2201 movs r2, #1
|
|
8004810: 701a strb r2, [r3, #0]
|
|
break;
|
|
8004812: 46c0 nop ; (mov r8, r8)
|
|
}
|
|
|
|
/* USARTDIV must be greater than or equal to 0d16 */
|
|
if (pclk != 0U)
|
|
8004814: 6afb ldr r3, [r7, #44] ; 0x2c
|
|
8004816: 2b00 cmp r3, #0
|
|
8004818: d100 bne.n 800481c <UART_SetConfig+0x368>
|
|
800481a: e095 b.n 8004948 <UART_SetConfig+0x494>
|
|
{
|
|
usartdiv = (uint16_t)(UART_DIV_SAMPLING8(pclk, huart->Init.BaudRate));
|
|
800481c: 6afb ldr r3, [r7, #44] ; 0x2c
|
|
800481e: 005a lsls r2, r3, #1
|
|
8004820: 69fb ldr r3, [r7, #28]
|
|
8004822: 685b ldr r3, [r3, #4]
|
|
8004824: 085b lsrs r3, r3, #1
|
|
8004826: 18d2 adds r2, r2, r3
|
|
8004828: 69fb ldr r3, [r7, #28]
|
|
800482a: 685b ldr r3, [r3, #4]
|
|
800482c: 0019 movs r1, r3
|
|
800482e: 0010 movs r0, r2
|
|
8004830: f7fb fc6a bl 8000108 <__udivsi3>
|
|
8004834: 0003 movs r3, r0
|
|
8004836: b29b uxth r3, r3
|
|
8004838: 62bb str r3, [r7, #40] ; 0x28
|
|
if ((usartdiv >= UART_BRR_MIN) && (usartdiv <= UART_BRR_MAX))
|
|
800483a: 6abb ldr r3, [r7, #40] ; 0x28
|
|
800483c: 2b0f cmp r3, #15
|
|
800483e: d921 bls.n 8004884 <UART_SetConfig+0x3d0>
|
|
8004840: 6aba ldr r2, [r7, #40] ; 0x28
|
|
8004842: 2380 movs r3, #128 ; 0x80
|
|
8004844: 025b lsls r3, r3, #9
|
|
8004846: 429a cmp r2, r3
|
|
8004848: d21c bcs.n 8004884 <UART_SetConfig+0x3d0>
|
|
{
|
|
brrtemp = (uint16_t)(usartdiv & 0xFFF0U);
|
|
800484a: 6abb ldr r3, [r7, #40] ; 0x28
|
|
800484c: b29a uxth r2, r3
|
|
800484e: 200e movs r0, #14
|
|
8004850: 2418 movs r4, #24
|
|
8004852: 193b adds r3, r7, r4
|
|
8004854: 181b adds r3, r3, r0
|
|
8004856: 210f movs r1, #15
|
|
8004858: 438a bics r2, r1
|
|
800485a: 801a strh r2, [r3, #0]
|
|
brrtemp |= (uint16_t)((usartdiv & (uint16_t)0x000FU) >> 1U);
|
|
800485c: 6abb ldr r3, [r7, #40] ; 0x28
|
|
800485e: 085b lsrs r3, r3, #1
|
|
8004860: b29b uxth r3, r3
|
|
8004862: 2207 movs r2, #7
|
|
8004864: 4013 ands r3, r2
|
|
8004866: b299 uxth r1, r3
|
|
8004868: 193b adds r3, r7, r4
|
|
800486a: 181b adds r3, r3, r0
|
|
800486c: 193a adds r2, r7, r4
|
|
800486e: 1812 adds r2, r2, r0
|
|
8004870: 8812 ldrh r2, [r2, #0]
|
|
8004872: 430a orrs r2, r1
|
|
8004874: 801a strh r2, [r3, #0]
|
|
huart->Instance->BRR = brrtemp;
|
|
8004876: 69fb ldr r3, [r7, #28]
|
|
8004878: 681b ldr r3, [r3, #0]
|
|
800487a: 193a adds r2, r7, r4
|
|
800487c: 1812 adds r2, r2, r0
|
|
800487e: 8812 ldrh r2, [r2, #0]
|
|
8004880: 60da str r2, [r3, #12]
|
|
8004882: e061 b.n 8004948 <UART_SetConfig+0x494>
|
|
}
|
|
else
|
|
{
|
|
ret = HAL_ERROR;
|
|
8004884: 231a movs r3, #26
|
|
8004886: 2218 movs r2, #24
|
|
8004888: 4694 mov ip, r2
|
|
800488a: 44bc add ip, r7
|
|
800488c: 4463 add r3, ip
|
|
800488e: 2201 movs r2, #1
|
|
8004890: 701a strb r2, [r3, #0]
|
|
8004892: e059 b.n 8004948 <UART_SetConfig+0x494>
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
switch (clocksource)
|
|
8004894: 231b movs r3, #27
|
|
8004896: 2218 movs r2, #24
|
|
8004898: 4694 mov ip, r2
|
|
800489a: 44bc add ip, r7
|
|
800489c: 4463 add r3, ip
|
|
800489e: 781b ldrb r3, [r3, #0]
|
|
80048a0: 2b08 cmp r3, #8
|
|
80048a2: d822 bhi.n 80048ea <UART_SetConfig+0x436>
|
|
80048a4: 009a lsls r2, r3, #2
|
|
80048a6: 4b30 ldr r3, [pc, #192] ; (8004968 <UART_SetConfig+0x4b4>)
|
|
80048a8: 18d3 adds r3, r2, r3
|
|
80048aa: 681b ldr r3, [r3, #0]
|
|
80048ac: 469f mov pc, r3
|
|
{
|
|
case UART_CLOCKSOURCE_PCLK1:
|
|
pclk = HAL_RCC_GetPCLK1Freq();
|
|
80048ae: f7fe fc6b bl 8003188 <HAL_RCC_GetPCLK1Freq>
|
|
80048b2: 0003 movs r3, r0
|
|
80048b4: 62fb str r3, [r7, #44] ; 0x2c
|
|
break;
|
|
80048b6: e022 b.n 80048fe <UART_SetConfig+0x44a>
|
|
case UART_CLOCKSOURCE_PCLK2:
|
|
pclk = HAL_RCC_GetPCLK2Freq();
|
|
80048b8: f7fe fc7c bl 80031b4 <HAL_RCC_GetPCLK2Freq>
|
|
80048bc: 0003 movs r3, r0
|
|
80048be: 62fb str r3, [r7, #44] ; 0x2c
|
|
break;
|
|
80048c0: e01d b.n 80048fe <UART_SetConfig+0x44a>
|
|
case UART_CLOCKSOURCE_HSI:
|
|
if (__HAL_RCC_GET_FLAG(RCC_FLAG_HSIDIV) != 0U)
|
|
80048c2: 4b2a ldr r3, [pc, #168] ; (800496c <UART_SetConfig+0x4b8>)
|
|
80048c4: 681b ldr r3, [r3, #0]
|
|
80048c6: 2210 movs r2, #16
|
|
80048c8: 4013 ands r3, r2
|
|
80048ca: d002 beq.n 80048d2 <UART_SetConfig+0x41e>
|
|
{
|
|
pclk = (uint32_t)(HSI_VALUE >> 2U);
|
|
80048cc: 4b28 ldr r3, [pc, #160] ; (8004970 <UART_SetConfig+0x4bc>)
|
|
80048ce: 62fb str r3, [r7, #44] ; 0x2c
|
|
}
|
|
else
|
|
{
|
|
pclk = (uint32_t) HSI_VALUE;
|
|
}
|
|
break;
|
|
80048d0: e015 b.n 80048fe <UART_SetConfig+0x44a>
|
|
pclk = (uint32_t) HSI_VALUE;
|
|
80048d2: 4b28 ldr r3, [pc, #160] ; (8004974 <UART_SetConfig+0x4c0>)
|
|
80048d4: 62fb str r3, [r7, #44] ; 0x2c
|
|
break;
|
|
80048d6: e012 b.n 80048fe <UART_SetConfig+0x44a>
|
|
case UART_CLOCKSOURCE_SYSCLK:
|
|
pclk = HAL_RCC_GetSysClockFreq();
|
|
80048d8: f7fe fba6 bl 8003028 <HAL_RCC_GetSysClockFreq>
|
|
80048dc: 0003 movs r3, r0
|
|
80048de: 62fb str r3, [r7, #44] ; 0x2c
|
|
break;
|
|
80048e0: e00d b.n 80048fe <UART_SetConfig+0x44a>
|
|
case UART_CLOCKSOURCE_LSE:
|
|
pclk = (uint32_t) LSE_VALUE;
|
|
80048e2: 2380 movs r3, #128 ; 0x80
|
|
80048e4: 021b lsls r3, r3, #8
|
|
80048e6: 62fb str r3, [r7, #44] ; 0x2c
|
|
break;
|
|
80048e8: e009 b.n 80048fe <UART_SetConfig+0x44a>
|
|
default:
|
|
pclk = 0U;
|
|
80048ea: 2300 movs r3, #0
|
|
80048ec: 62fb str r3, [r7, #44] ; 0x2c
|
|
ret = HAL_ERROR;
|
|
80048ee: 231a movs r3, #26
|
|
80048f0: 2218 movs r2, #24
|
|
80048f2: 4694 mov ip, r2
|
|
80048f4: 44bc add ip, r7
|
|
80048f6: 4463 add r3, ip
|
|
80048f8: 2201 movs r2, #1
|
|
80048fa: 701a strb r2, [r3, #0]
|
|
break;
|
|
80048fc: 46c0 nop ; (mov r8, r8)
|
|
}
|
|
|
|
if (pclk != 0U)
|
|
80048fe: 6afb ldr r3, [r7, #44] ; 0x2c
|
|
8004900: 2b00 cmp r3, #0
|
|
8004902: d021 beq.n 8004948 <UART_SetConfig+0x494>
|
|
{
|
|
/* USARTDIV must be greater than or equal to 0d16 */
|
|
usartdiv = (uint16_t)(UART_DIV_SAMPLING16(pclk, huart->Init.BaudRate));
|
|
8004904: 69fb ldr r3, [r7, #28]
|
|
8004906: 685b ldr r3, [r3, #4]
|
|
8004908: 085a lsrs r2, r3, #1
|
|
800490a: 6afb ldr r3, [r7, #44] ; 0x2c
|
|
800490c: 18d2 adds r2, r2, r3
|
|
800490e: 69fb ldr r3, [r7, #28]
|
|
8004910: 685b ldr r3, [r3, #4]
|
|
8004912: 0019 movs r1, r3
|
|
8004914: 0010 movs r0, r2
|
|
8004916: f7fb fbf7 bl 8000108 <__udivsi3>
|
|
800491a: 0003 movs r3, r0
|
|
800491c: b29b uxth r3, r3
|
|
800491e: 62bb str r3, [r7, #40] ; 0x28
|
|
if ((usartdiv >= UART_BRR_MIN) && (usartdiv <= UART_BRR_MAX))
|
|
8004920: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8004922: 2b0f cmp r3, #15
|
|
8004924: d909 bls.n 800493a <UART_SetConfig+0x486>
|
|
8004926: 6aba ldr r2, [r7, #40] ; 0x28
|
|
8004928: 2380 movs r3, #128 ; 0x80
|
|
800492a: 025b lsls r3, r3, #9
|
|
800492c: 429a cmp r2, r3
|
|
800492e: d204 bcs.n 800493a <UART_SetConfig+0x486>
|
|
{
|
|
huart->Instance->BRR = usartdiv;
|
|
8004930: 69fb ldr r3, [r7, #28]
|
|
8004932: 681b ldr r3, [r3, #0]
|
|
8004934: 6aba ldr r2, [r7, #40] ; 0x28
|
|
8004936: 60da str r2, [r3, #12]
|
|
8004938: e006 b.n 8004948 <UART_SetConfig+0x494>
|
|
}
|
|
else
|
|
{
|
|
ret = HAL_ERROR;
|
|
800493a: 231a movs r3, #26
|
|
800493c: 2218 movs r2, #24
|
|
800493e: 4694 mov ip, r2
|
|
8004940: 44bc add ip, r7
|
|
8004942: 4463 add r3, ip
|
|
8004944: 2201 movs r2, #1
|
|
8004946: 701a strb r2, [r3, #0]
|
|
}
|
|
}
|
|
|
|
|
|
/* Clear ISR function pointers */
|
|
huart->RxISR = NULL;
|
|
8004948: 69fb ldr r3, [r7, #28]
|
|
800494a: 2200 movs r2, #0
|
|
800494c: 665a str r2, [r3, #100] ; 0x64
|
|
huart->TxISR = NULL;
|
|
800494e: 69fb ldr r3, [r7, #28]
|
|
8004950: 2200 movs r2, #0
|
|
8004952: 669a str r2, [r3, #104] ; 0x68
|
|
|
|
return ret;
|
|
8004954: 231a movs r3, #26
|
|
8004956: 2218 movs r2, #24
|
|
8004958: 4694 mov ip, r2
|
|
800495a: 44bc add ip, r7
|
|
800495c: 4463 add r3, ip
|
|
800495e: 781b ldrb r3, [r3, #0]
|
|
}
|
|
8004960: 0018 movs r0, r3
|
|
8004962: 46bd mov sp, r7
|
|
8004964: b00e add sp, #56 ; 0x38
|
|
8004966: bdb0 pop {r4, r5, r7, pc}
|
|
8004968: 080078cc .word 0x080078cc
|
|
800496c: 40021000 .word 0x40021000
|
|
8004970: 003d0900 .word 0x003d0900
|
|
8004974: 00f42400 .word 0x00f42400
|
|
|
|
08004978 <UART_AdvFeatureConfig>:
|
|
* @brief Configure the UART peripheral advanced features.
|
|
* @param huart UART handle.
|
|
* @retval None
|
|
*/
|
|
void UART_AdvFeatureConfig(UART_HandleTypeDef *huart)
|
|
{
|
|
8004978: b580 push {r7, lr}
|
|
800497a: b082 sub sp, #8
|
|
800497c: af00 add r7, sp, #0
|
|
800497e: 6078 str r0, [r7, #4]
|
|
/* Check whether the set of advanced features to configure is properly set */
|
|
assert_param(IS_UART_ADVFEATURE_INIT(huart->AdvancedInit.AdvFeatureInit));
|
|
|
|
/* if required, configure TX pin active level inversion */
|
|
if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_TXINVERT_INIT))
|
|
8004980: 687b ldr r3, [r7, #4]
|
|
8004982: 6a5b ldr r3, [r3, #36] ; 0x24
|
|
8004984: 2201 movs r2, #1
|
|
8004986: 4013 ands r3, r2
|
|
8004988: d00b beq.n 80049a2 <UART_AdvFeatureConfig+0x2a>
|
|
{
|
|
assert_param(IS_UART_ADVFEATURE_TXINV(huart->AdvancedInit.TxPinLevelInvert));
|
|
MODIFY_REG(huart->Instance->CR2, USART_CR2_TXINV, huart->AdvancedInit.TxPinLevelInvert);
|
|
800498a: 687b ldr r3, [r7, #4]
|
|
800498c: 681b ldr r3, [r3, #0]
|
|
800498e: 685b ldr r3, [r3, #4]
|
|
8004990: 4a4a ldr r2, [pc, #296] ; (8004abc <UART_AdvFeatureConfig+0x144>)
|
|
8004992: 4013 ands r3, r2
|
|
8004994: 0019 movs r1, r3
|
|
8004996: 687b ldr r3, [r7, #4]
|
|
8004998: 6a9a ldr r2, [r3, #40] ; 0x28
|
|
800499a: 687b ldr r3, [r7, #4]
|
|
800499c: 681b ldr r3, [r3, #0]
|
|
800499e: 430a orrs r2, r1
|
|
80049a0: 605a str r2, [r3, #4]
|
|
}
|
|
|
|
/* if required, configure RX pin active level inversion */
|
|
if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_RXINVERT_INIT))
|
|
80049a2: 687b ldr r3, [r7, #4]
|
|
80049a4: 6a5b ldr r3, [r3, #36] ; 0x24
|
|
80049a6: 2202 movs r2, #2
|
|
80049a8: 4013 ands r3, r2
|
|
80049aa: d00b beq.n 80049c4 <UART_AdvFeatureConfig+0x4c>
|
|
{
|
|
assert_param(IS_UART_ADVFEATURE_RXINV(huart->AdvancedInit.RxPinLevelInvert));
|
|
MODIFY_REG(huart->Instance->CR2, USART_CR2_RXINV, huart->AdvancedInit.RxPinLevelInvert);
|
|
80049ac: 687b ldr r3, [r7, #4]
|
|
80049ae: 681b ldr r3, [r3, #0]
|
|
80049b0: 685b ldr r3, [r3, #4]
|
|
80049b2: 4a43 ldr r2, [pc, #268] ; (8004ac0 <UART_AdvFeatureConfig+0x148>)
|
|
80049b4: 4013 ands r3, r2
|
|
80049b6: 0019 movs r1, r3
|
|
80049b8: 687b ldr r3, [r7, #4]
|
|
80049ba: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
80049bc: 687b ldr r3, [r7, #4]
|
|
80049be: 681b ldr r3, [r3, #0]
|
|
80049c0: 430a orrs r2, r1
|
|
80049c2: 605a str r2, [r3, #4]
|
|
}
|
|
|
|
/* if required, configure data inversion */
|
|
if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_DATAINVERT_INIT))
|
|
80049c4: 687b ldr r3, [r7, #4]
|
|
80049c6: 6a5b ldr r3, [r3, #36] ; 0x24
|
|
80049c8: 2204 movs r2, #4
|
|
80049ca: 4013 ands r3, r2
|
|
80049cc: d00b beq.n 80049e6 <UART_AdvFeatureConfig+0x6e>
|
|
{
|
|
assert_param(IS_UART_ADVFEATURE_DATAINV(huart->AdvancedInit.DataInvert));
|
|
MODIFY_REG(huart->Instance->CR2, USART_CR2_DATAINV, huart->AdvancedInit.DataInvert);
|
|
80049ce: 687b ldr r3, [r7, #4]
|
|
80049d0: 681b ldr r3, [r3, #0]
|
|
80049d2: 685b ldr r3, [r3, #4]
|
|
80049d4: 4a3b ldr r2, [pc, #236] ; (8004ac4 <UART_AdvFeatureConfig+0x14c>)
|
|
80049d6: 4013 ands r3, r2
|
|
80049d8: 0019 movs r1, r3
|
|
80049da: 687b ldr r3, [r7, #4]
|
|
80049dc: 6b1a ldr r2, [r3, #48] ; 0x30
|
|
80049de: 687b ldr r3, [r7, #4]
|
|
80049e0: 681b ldr r3, [r3, #0]
|
|
80049e2: 430a orrs r2, r1
|
|
80049e4: 605a str r2, [r3, #4]
|
|
}
|
|
|
|
/* if required, configure RX/TX pins swap */
|
|
if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_SWAP_INIT))
|
|
80049e6: 687b ldr r3, [r7, #4]
|
|
80049e8: 6a5b ldr r3, [r3, #36] ; 0x24
|
|
80049ea: 2208 movs r2, #8
|
|
80049ec: 4013 ands r3, r2
|
|
80049ee: d00b beq.n 8004a08 <UART_AdvFeatureConfig+0x90>
|
|
{
|
|
assert_param(IS_UART_ADVFEATURE_SWAP(huart->AdvancedInit.Swap));
|
|
MODIFY_REG(huart->Instance->CR2, USART_CR2_SWAP, huart->AdvancedInit.Swap);
|
|
80049f0: 687b ldr r3, [r7, #4]
|
|
80049f2: 681b ldr r3, [r3, #0]
|
|
80049f4: 685b ldr r3, [r3, #4]
|
|
80049f6: 4a34 ldr r2, [pc, #208] ; (8004ac8 <UART_AdvFeatureConfig+0x150>)
|
|
80049f8: 4013 ands r3, r2
|
|
80049fa: 0019 movs r1, r3
|
|
80049fc: 687b ldr r3, [r7, #4]
|
|
80049fe: 6b5a ldr r2, [r3, #52] ; 0x34
|
|
8004a00: 687b ldr r3, [r7, #4]
|
|
8004a02: 681b ldr r3, [r3, #0]
|
|
8004a04: 430a orrs r2, r1
|
|
8004a06: 605a str r2, [r3, #4]
|
|
}
|
|
|
|
/* if required, configure RX overrun detection disabling */
|
|
if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_RXOVERRUNDISABLE_INIT))
|
|
8004a08: 687b ldr r3, [r7, #4]
|
|
8004a0a: 6a5b ldr r3, [r3, #36] ; 0x24
|
|
8004a0c: 2210 movs r2, #16
|
|
8004a0e: 4013 ands r3, r2
|
|
8004a10: d00b beq.n 8004a2a <UART_AdvFeatureConfig+0xb2>
|
|
{
|
|
assert_param(IS_UART_OVERRUN(huart->AdvancedInit.OverrunDisable));
|
|
MODIFY_REG(huart->Instance->CR3, USART_CR3_OVRDIS, huart->AdvancedInit.OverrunDisable);
|
|
8004a12: 687b ldr r3, [r7, #4]
|
|
8004a14: 681b ldr r3, [r3, #0]
|
|
8004a16: 689b ldr r3, [r3, #8]
|
|
8004a18: 4a2c ldr r2, [pc, #176] ; (8004acc <UART_AdvFeatureConfig+0x154>)
|
|
8004a1a: 4013 ands r3, r2
|
|
8004a1c: 0019 movs r1, r3
|
|
8004a1e: 687b ldr r3, [r7, #4]
|
|
8004a20: 6b9a ldr r2, [r3, #56] ; 0x38
|
|
8004a22: 687b ldr r3, [r7, #4]
|
|
8004a24: 681b ldr r3, [r3, #0]
|
|
8004a26: 430a orrs r2, r1
|
|
8004a28: 609a str r2, [r3, #8]
|
|
}
|
|
|
|
/* if required, configure DMA disabling on reception error */
|
|
if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_DMADISABLEONERROR_INIT))
|
|
8004a2a: 687b ldr r3, [r7, #4]
|
|
8004a2c: 6a5b ldr r3, [r3, #36] ; 0x24
|
|
8004a2e: 2220 movs r2, #32
|
|
8004a30: 4013 ands r3, r2
|
|
8004a32: d00b beq.n 8004a4c <UART_AdvFeatureConfig+0xd4>
|
|
{
|
|
assert_param(IS_UART_ADVFEATURE_DMAONRXERROR(huart->AdvancedInit.DMADisableonRxError));
|
|
MODIFY_REG(huart->Instance->CR3, USART_CR3_DDRE, huart->AdvancedInit.DMADisableonRxError);
|
|
8004a34: 687b ldr r3, [r7, #4]
|
|
8004a36: 681b ldr r3, [r3, #0]
|
|
8004a38: 689b ldr r3, [r3, #8]
|
|
8004a3a: 4a25 ldr r2, [pc, #148] ; (8004ad0 <UART_AdvFeatureConfig+0x158>)
|
|
8004a3c: 4013 ands r3, r2
|
|
8004a3e: 0019 movs r1, r3
|
|
8004a40: 687b ldr r3, [r7, #4]
|
|
8004a42: 6bda ldr r2, [r3, #60] ; 0x3c
|
|
8004a44: 687b ldr r3, [r7, #4]
|
|
8004a46: 681b ldr r3, [r3, #0]
|
|
8004a48: 430a orrs r2, r1
|
|
8004a4a: 609a str r2, [r3, #8]
|
|
}
|
|
|
|
/* if required, configure auto Baud rate detection scheme */
|
|
if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_AUTOBAUDRATE_INIT))
|
|
8004a4c: 687b ldr r3, [r7, #4]
|
|
8004a4e: 6a5b ldr r3, [r3, #36] ; 0x24
|
|
8004a50: 2240 movs r2, #64 ; 0x40
|
|
8004a52: 4013 ands r3, r2
|
|
8004a54: d01d beq.n 8004a92 <UART_AdvFeatureConfig+0x11a>
|
|
{
|
|
assert_param(IS_USART_AUTOBAUDRATE_DETECTION_INSTANCE(huart->Instance));
|
|
assert_param(IS_UART_ADVFEATURE_AUTOBAUDRATE(huart->AdvancedInit.AutoBaudRateEnable));
|
|
MODIFY_REG(huart->Instance->CR2, USART_CR2_ABREN, huart->AdvancedInit.AutoBaudRateEnable);
|
|
8004a56: 687b ldr r3, [r7, #4]
|
|
8004a58: 681b ldr r3, [r3, #0]
|
|
8004a5a: 685b ldr r3, [r3, #4]
|
|
8004a5c: 4a1d ldr r2, [pc, #116] ; (8004ad4 <UART_AdvFeatureConfig+0x15c>)
|
|
8004a5e: 4013 ands r3, r2
|
|
8004a60: 0019 movs r1, r3
|
|
8004a62: 687b ldr r3, [r7, #4]
|
|
8004a64: 6c1a ldr r2, [r3, #64] ; 0x40
|
|
8004a66: 687b ldr r3, [r7, #4]
|
|
8004a68: 681b ldr r3, [r3, #0]
|
|
8004a6a: 430a orrs r2, r1
|
|
8004a6c: 605a str r2, [r3, #4]
|
|
/* set auto Baudrate detection parameters if detection is enabled */
|
|
if (huart->AdvancedInit.AutoBaudRateEnable == UART_ADVFEATURE_AUTOBAUDRATE_ENABLE)
|
|
8004a6e: 687b ldr r3, [r7, #4]
|
|
8004a70: 6c1a ldr r2, [r3, #64] ; 0x40
|
|
8004a72: 2380 movs r3, #128 ; 0x80
|
|
8004a74: 035b lsls r3, r3, #13
|
|
8004a76: 429a cmp r2, r3
|
|
8004a78: d10b bne.n 8004a92 <UART_AdvFeatureConfig+0x11a>
|
|
{
|
|
assert_param(IS_UART_ADVFEATURE_AUTOBAUDRATEMODE(huart->AdvancedInit.AutoBaudRateMode));
|
|
MODIFY_REG(huart->Instance->CR2, USART_CR2_ABRMODE, huart->AdvancedInit.AutoBaudRateMode);
|
|
8004a7a: 687b ldr r3, [r7, #4]
|
|
8004a7c: 681b ldr r3, [r3, #0]
|
|
8004a7e: 685b ldr r3, [r3, #4]
|
|
8004a80: 4a15 ldr r2, [pc, #84] ; (8004ad8 <UART_AdvFeatureConfig+0x160>)
|
|
8004a82: 4013 ands r3, r2
|
|
8004a84: 0019 movs r1, r3
|
|
8004a86: 687b ldr r3, [r7, #4]
|
|
8004a88: 6c5a ldr r2, [r3, #68] ; 0x44
|
|
8004a8a: 687b ldr r3, [r7, #4]
|
|
8004a8c: 681b ldr r3, [r3, #0]
|
|
8004a8e: 430a orrs r2, r1
|
|
8004a90: 605a str r2, [r3, #4]
|
|
}
|
|
}
|
|
|
|
/* if required, configure MSB first on communication line */
|
|
if (HAL_IS_BIT_SET(huart->AdvancedInit.AdvFeatureInit, UART_ADVFEATURE_MSBFIRST_INIT))
|
|
8004a92: 687b ldr r3, [r7, #4]
|
|
8004a94: 6a5b ldr r3, [r3, #36] ; 0x24
|
|
8004a96: 2280 movs r2, #128 ; 0x80
|
|
8004a98: 4013 ands r3, r2
|
|
8004a9a: d00b beq.n 8004ab4 <UART_AdvFeatureConfig+0x13c>
|
|
{
|
|
assert_param(IS_UART_ADVFEATURE_MSBFIRST(huart->AdvancedInit.MSBFirst));
|
|
MODIFY_REG(huart->Instance->CR2, USART_CR2_MSBFIRST, huart->AdvancedInit.MSBFirst);
|
|
8004a9c: 687b ldr r3, [r7, #4]
|
|
8004a9e: 681b ldr r3, [r3, #0]
|
|
8004aa0: 685b ldr r3, [r3, #4]
|
|
8004aa2: 4a0e ldr r2, [pc, #56] ; (8004adc <UART_AdvFeatureConfig+0x164>)
|
|
8004aa4: 4013 ands r3, r2
|
|
8004aa6: 0019 movs r1, r3
|
|
8004aa8: 687b ldr r3, [r7, #4]
|
|
8004aaa: 6c9a ldr r2, [r3, #72] ; 0x48
|
|
8004aac: 687b ldr r3, [r7, #4]
|
|
8004aae: 681b ldr r3, [r3, #0]
|
|
8004ab0: 430a orrs r2, r1
|
|
8004ab2: 605a str r2, [r3, #4]
|
|
}
|
|
}
|
|
8004ab4: 46c0 nop ; (mov r8, r8)
|
|
8004ab6: 46bd mov sp, r7
|
|
8004ab8: b002 add sp, #8
|
|
8004aba: bd80 pop {r7, pc}
|
|
8004abc: fffdffff .word 0xfffdffff
|
|
8004ac0: fffeffff .word 0xfffeffff
|
|
8004ac4: fffbffff .word 0xfffbffff
|
|
8004ac8: ffff7fff .word 0xffff7fff
|
|
8004acc: ffffefff .word 0xffffefff
|
|
8004ad0: ffffdfff .word 0xffffdfff
|
|
8004ad4: ffefffff .word 0xffefffff
|
|
8004ad8: ff9fffff .word 0xff9fffff
|
|
8004adc: fff7ffff .word 0xfff7ffff
|
|
|
|
08004ae0 <UART_CheckIdleState>:
|
|
* @brief Check the UART Idle State.
|
|
* @param huart UART handle.
|
|
* @retval HAL status
|
|
*/
|
|
HAL_StatusTypeDef UART_CheckIdleState(UART_HandleTypeDef *huart)
|
|
{
|
|
8004ae0: b580 push {r7, lr}
|
|
8004ae2: b086 sub sp, #24
|
|
8004ae4: af02 add r7, sp, #8
|
|
8004ae6: 6078 str r0, [r7, #4]
|
|
uint32_t tickstart;
|
|
|
|
/* Initialize the UART ErrorCode */
|
|
huart->ErrorCode = HAL_UART_ERROR_NONE;
|
|
8004ae8: 687b ldr r3, [r7, #4]
|
|
8004aea: 2280 movs r2, #128 ; 0x80
|
|
8004aec: 2100 movs r1, #0
|
|
8004aee: 5099 str r1, [r3, r2]
|
|
|
|
/* Init tickstart for timeout management */
|
|
tickstart = HAL_GetTick();
|
|
8004af0: f7fc fe52 bl 8001798 <HAL_GetTick>
|
|
8004af4: 0003 movs r3, r0
|
|
8004af6: 60fb str r3, [r7, #12]
|
|
|
|
/* Check if the Transmitter is enabled */
|
|
if ((huart->Instance->CR1 & USART_CR1_TE) == USART_CR1_TE)
|
|
8004af8: 687b ldr r3, [r7, #4]
|
|
8004afa: 681b ldr r3, [r3, #0]
|
|
8004afc: 681b ldr r3, [r3, #0]
|
|
8004afe: 2208 movs r2, #8
|
|
8004b00: 4013 ands r3, r2
|
|
8004b02: 2b08 cmp r3, #8
|
|
8004b04: d10c bne.n 8004b20 <UART_CheckIdleState+0x40>
|
|
{
|
|
/* Wait until TEACK flag is set */
|
|
if (UART_WaitOnFlagUntilTimeout(huart, USART_ISR_TEACK, RESET, tickstart, HAL_UART_TIMEOUT_VALUE) != HAL_OK)
|
|
8004b06: 68fb ldr r3, [r7, #12]
|
|
8004b08: 2280 movs r2, #128 ; 0x80
|
|
8004b0a: 0391 lsls r1, r2, #14
|
|
8004b0c: 6878 ldr r0, [r7, #4]
|
|
8004b0e: 4a17 ldr r2, [pc, #92] ; (8004b6c <UART_CheckIdleState+0x8c>)
|
|
8004b10: 9200 str r2, [sp, #0]
|
|
8004b12: 2200 movs r2, #0
|
|
8004b14: f000 f82c bl 8004b70 <UART_WaitOnFlagUntilTimeout>
|
|
8004b18: 1e03 subs r3, r0, #0
|
|
8004b1a: d001 beq.n 8004b20 <UART_CheckIdleState+0x40>
|
|
{
|
|
/* Timeout occurred */
|
|
return HAL_TIMEOUT;
|
|
8004b1c: 2303 movs r3, #3
|
|
8004b1e: e021 b.n 8004b64 <UART_CheckIdleState+0x84>
|
|
}
|
|
}
|
|
|
|
/* Check if the Receiver is enabled */
|
|
if ((huart->Instance->CR1 & USART_CR1_RE) == USART_CR1_RE)
|
|
8004b20: 687b ldr r3, [r7, #4]
|
|
8004b22: 681b ldr r3, [r3, #0]
|
|
8004b24: 681b ldr r3, [r3, #0]
|
|
8004b26: 2204 movs r2, #4
|
|
8004b28: 4013 ands r3, r2
|
|
8004b2a: 2b04 cmp r3, #4
|
|
8004b2c: d10c bne.n 8004b48 <UART_CheckIdleState+0x68>
|
|
{
|
|
/* Wait until REACK flag is set */
|
|
if (UART_WaitOnFlagUntilTimeout(huart, USART_ISR_REACK, RESET, tickstart, HAL_UART_TIMEOUT_VALUE) != HAL_OK)
|
|
8004b2e: 68fb ldr r3, [r7, #12]
|
|
8004b30: 2280 movs r2, #128 ; 0x80
|
|
8004b32: 03d1 lsls r1, r2, #15
|
|
8004b34: 6878 ldr r0, [r7, #4]
|
|
8004b36: 4a0d ldr r2, [pc, #52] ; (8004b6c <UART_CheckIdleState+0x8c>)
|
|
8004b38: 9200 str r2, [sp, #0]
|
|
8004b3a: 2200 movs r2, #0
|
|
8004b3c: f000 f818 bl 8004b70 <UART_WaitOnFlagUntilTimeout>
|
|
8004b40: 1e03 subs r3, r0, #0
|
|
8004b42: d001 beq.n 8004b48 <UART_CheckIdleState+0x68>
|
|
{
|
|
/* Timeout occurred */
|
|
return HAL_TIMEOUT;
|
|
8004b44: 2303 movs r3, #3
|
|
8004b46: e00d b.n 8004b64 <UART_CheckIdleState+0x84>
|
|
}
|
|
}
|
|
|
|
/* Initialize the UART State */
|
|
huart->gState = HAL_UART_STATE_READY;
|
|
8004b48: 687b ldr r3, [r7, #4]
|
|
8004b4a: 2220 movs r2, #32
|
|
8004b4c: 679a str r2, [r3, #120] ; 0x78
|
|
huart->RxState = HAL_UART_STATE_READY;
|
|
8004b4e: 687b ldr r3, [r7, #4]
|
|
8004b50: 2220 movs r2, #32
|
|
8004b52: 67da str r2, [r3, #124] ; 0x7c
|
|
huart->ReceptionType = HAL_UART_RECEPTION_STANDARD;
|
|
8004b54: 687b ldr r3, [r7, #4]
|
|
8004b56: 2200 movs r2, #0
|
|
8004b58: 661a str r2, [r3, #96] ; 0x60
|
|
|
|
__HAL_UNLOCK(huart);
|
|
8004b5a: 687b ldr r3, [r7, #4]
|
|
8004b5c: 2274 movs r2, #116 ; 0x74
|
|
8004b5e: 2100 movs r1, #0
|
|
8004b60: 5499 strb r1, [r3, r2]
|
|
|
|
return HAL_OK;
|
|
8004b62: 2300 movs r3, #0
|
|
}
|
|
8004b64: 0018 movs r0, r3
|
|
8004b66: 46bd mov sp, r7
|
|
8004b68: b004 add sp, #16
|
|
8004b6a: bd80 pop {r7, pc}
|
|
8004b6c: 01ffffff .word 0x01ffffff
|
|
|
|
08004b70 <UART_WaitOnFlagUntilTimeout>:
|
|
* @param Timeout Timeout duration
|
|
* @retval HAL status
|
|
*/
|
|
HAL_StatusTypeDef UART_WaitOnFlagUntilTimeout(UART_HandleTypeDef *huart, uint32_t Flag, FlagStatus Status,
|
|
uint32_t Tickstart, uint32_t Timeout)
|
|
{
|
|
8004b70: b580 push {r7, lr}
|
|
8004b72: b094 sub sp, #80 ; 0x50
|
|
8004b74: af00 add r7, sp, #0
|
|
8004b76: 60f8 str r0, [r7, #12]
|
|
8004b78: 60b9 str r1, [r7, #8]
|
|
8004b7a: 603b str r3, [r7, #0]
|
|
8004b7c: 1dfb adds r3, r7, #7
|
|
8004b7e: 701a strb r2, [r3, #0]
|
|
/* Wait until flag is set */
|
|
while ((__HAL_UART_GET_FLAG(huart, Flag) ? SET : RESET) == Status)
|
|
8004b80: e0a3 b.n 8004cca <UART_WaitOnFlagUntilTimeout+0x15a>
|
|
{
|
|
/* Check for the Timeout */
|
|
if (Timeout != HAL_MAX_DELAY)
|
|
8004b82: 6dbb ldr r3, [r7, #88] ; 0x58
|
|
8004b84: 3301 adds r3, #1
|
|
8004b86: d100 bne.n 8004b8a <UART_WaitOnFlagUntilTimeout+0x1a>
|
|
8004b88: e09f b.n 8004cca <UART_WaitOnFlagUntilTimeout+0x15a>
|
|
{
|
|
if (((HAL_GetTick() - Tickstart) > Timeout) || (Timeout == 0U))
|
|
8004b8a: f7fc fe05 bl 8001798 <HAL_GetTick>
|
|
8004b8e: 0002 movs r2, r0
|
|
8004b90: 683b ldr r3, [r7, #0]
|
|
8004b92: 1ad3 subs r3, r2, r3
|
|
8004b94: 6dba ldr r2, [r7, #88] ; 0x58
|
|
8004b96: 429a cmp r2, r3
|
|
8004b98: d302 bcc.n 8004ba0 <UART_WaitOnFlagUntilTimeout+0x30>
|
|
8004b9a: 6dbb ldr r3, [r7, #88] ; 0x58
|
|
8004b9c: 2b00 cmp r3, #0
|
|
8004b9e: d13d bne.n 8004c1c <UART_WaitOnFlagUntilTimeout+0xac>
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
8004ba0: f3ef 8310 mrs r3, PRIMASK
|
|
8004ba4: 62bb str r3, [r7, #40] ; 0x28
|
|
return(result);
|
|
8004ba6: 6abb ldr r3, [r7, #40] ; 0x28
|
|
{
|
|
/* Disable TXE, RXNE, PE and ERR (Frame error, noise error, overrun error)
|
|
interrupts for the interrupt process */
|
|
ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE));
|
|
8004ba8: 647b str r3, [r7, #68] ; 0x44
|
|
8004baa: 2301 movs r3, #1
|
|
8004bac: 62fb str r3, [r7, #44] ; 0x2c
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004bae: 6afb ldr r3, [r7, #44] ; 0x2c
|
|
8004bb0: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004bb4: 46c0 nop ; (mov r8, r8)
|
|
8004bb6: 68fb ldr r3, [r7, #12]
|
|
8004bb8: 681b ldr r3, [r3, #0]
|
|
8004bba: 681a ldr r2, [r3, #0]
|
|
8004bbc: 68fb ldr r3, [r7, #12]
|
|
8004bbe: 681b ldr r3, [r3, #0]
|
|
8004bc0: 494c ldr r1, [pc, #304] ; (8004cf4 <UART_WaitOnFlagUntilTimeout+0x184>)
|
|
8004bc2: 400a ands r2, r1
|
|
8004bc4: 601a str r2, [r3, #0]
|
|
8004bc6: 6c7b ldr r3, [r7, #68] ; 0x44
|
|
8004bc8: 633b str r3, [r7, #48] ; 0x30
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004bca: 6b3b ldr r3, [r7, #48] ; 0x30
|
|
8004bcc: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004bd0: 46c0 nop ; (mov r8, r8)
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
8004bd2: f3ef 8310 mrs r3, PRIMASK
|
|
8004bd6: 637b str r3, [r7, #52] ; 0x34
|
|
return(result);
|
|
8004bd8: 6b7b ldr r3, [r7, #52] ; 0x34
|
|
ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE);
|
|
8004bda: 643b str r3, [r7, #64] ; 0x40
|
|
8004bdc: 2301 movs r3, #1
|
|
8004bde: 63bb str r3, [r7, #56] ; 0x38
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004be0: 6bbb ldr r3, [r7, #56] ; 0x38
|
|
8004be2: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004be6: 46c0 nop ; (mov r8, r8)
|
|
8004be8: 68fb ldr r3, [r7, #12]
|
|
8004bea: 681b ldr r3, [r3, #0]
|
|
8004bec: 689a ldr r2, [r3, #8]
|
|
8004bee: 68fb ldr r3, [r7, #12]
|
|
8004bf0: 681b ldr r3, [r3, #0]
|
|
8004bf2: 2101 movs r1, #1
|
|
8004bf4: 438a bics r2, r1
|
|
8004bf6: 609a str r2, [r3, #8]
|
|
8004bf8: 6c3b ldr r3, [r7, #64] ; 0x40
|
|
8004bfa: 63fb str r3, [r7, #60] ; 0x3c
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004bfc: 6bfb ldr r3, [r7, #60] ; 0x3c
|
|
8004bfe: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004c02: 46c0 nop ; (mov r8, r8)
|
|
|
|
huart->gState = HAL_UART_STATE_READY;
|
|
8004c04: 68fb ldr r3, [r7, #12]
|
|
8004c06: 2220 movs r2, #32
|
|
8004c08: 679a str r2, [r3, #120] ; 0x78
|
|
huart->RxState = HAL_UART_STATE_READY;
|
|
8004c0a: 68fb ldr r3, [r7, #12]
|
|
8004c0c: 2220 movs r2, #32
|
|
8004c0e: 67da str r2, [r3, #124] ; 0x7c
|
|
|
|
__HAL_UNLOCK(huart);
|
|
8004c10: 68fb ldr r3, [r7, #12]
|
|
8004c12: 2274 movs r2, #116 ; 0x74
|
|
8004c14: 2100 movs r1, #0
|
|
8004c16: 5499 strb r1, [r3, r2]
|
|
|
|
return HAL_TIMEOUT;
|
|
8004c18: 2303 movs r3, #3
|
|
8004c1a: e067 b.n 8004cec <UART_WaitOnFlagUntilTimeout+0x17c>
|
|
}
|
|
|
|
if (READ_BIT(huart->Instance->CR1, USART_CR1_RE) != 0U)
|
|
8004c1c: 68fb ldr r3, [r7, #12]
|
|
8004c1e: 681b ldr r3, [r3, #0]
|
|
8004c20: 681b ldr r3, [r3, #0]
|
|
8004c22: 2204 movs r2, #4
|
|
8004c24: 4013 ands r3, r2
|
|
8004c26: d050 beq.n 8004cca <UART_WaitOnFlagUntilTimeout+0x15a>
|
|
{
|
|
if (__HAL_UART_GET_FLAG(huart, UART_FLAG_RTOF) == SET)
|
|
8004c28: 68fb ldr r3, [r7, #12]
|
|
8004c2a: 681b ldr r3, [r3, #0]
|
|
8004c2c: 69da ldr r2, [r3, #28]
|
|
8004c2e: 2380 movs r3, #128 ; 0x80
|
|
8004c30: 011b lsls r3, r3, #4
|
|
8004c32: 401a ands r2, r3
|
|
8004c34: 2380 movs r3, #128 ; 0x80
|
|
8004c36: 011b lsls r3, r3, #4
|
|
8004c38: 429a cmp r2, r3
|
|
8004c3a: d146 bne.n 8004cca <UART_WaitOnFlagUntilTimeout+0x15a>
|
|
{
|
|
/* Clear Receiver Timeout flag*/
|
|
__HAL_UART_CLEAR_FLAG(huart, UART_CLEAR_RTOF);
|
|
8004c3c: 68fb ldr r3, [r7, #12]
|
|
8004c3e: 681b ldr r3, [r3, #0]
|
|
8004c40: 2280 movs r2, #128 ; 0x80
|
|
8004c42: 0112 lsls r2, r2, #4
|
|
8004c44: 621a str r2, [r3, #32]
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
8004c46: f3ef 8310 mrs r3, PRIMASK
|
|
8004c4a: 613b str r3, [r7, #16]
|
|
return(result);
|
|
8004c4c: 693b ldr r3, [r7, #16]
|
|
|
|
/* Disable TXE, RXNE, PE and ERR (Frame error, noise error, overrun error)
|
|
interrupts for the interrupt process */
|
|
ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE | USART_CR1_TXEIE));
|
|
8004c4e: 64fb str r3, [r7, #76] ; 0x4c
|
|
8004c50: 2301 movs r3, #1
|
|
8004c52: 617b str r3, [r7, #20]
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004c54: 697b ldr r3, [r7, #20]
|
|
8004c56: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004c5a: 46c0 nop ; (mov r8, r8)
|
|
8004c5c: 68fb ldr r3, [r7, #12]
|
|
8004c5e: 681b ldr r3, [r3, #0]
|
|
8004c60: 681a ldr r2, [r3, #0]
|
|
8004c62: 68fb ldr r3, [r7, #12]
|
|
8004c64: 681b ldr r3, [r3, #0]
|
|
8004c66: 4923 ldr r1, [pc, #140] ; (8004cf4 <UART_WaitOnFlagUntilTimeout+0x184>)
|
|
8004c68: 400a ands r2, r1
|
|
8004c6a: 601a str r2, [r3, #0]
|
|
8004c6c: 6cfb ldr r3, [r7, #76] ; 0x4c
|
|
8004c6e: 61bb str r3, [r7, #24]
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004c70: 69bb ldr r3, [r7, #24]
|
|
8004c72: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004c76: 46c0 nop ; (mov r8, r8)
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
8004c78: f3ef 8310 mrs r3, PRIMASK
|
|
8004c7c: 61fb str r3, [r7, #28]
|
|
return(result);
|
|
8004c7e: 69fb ldr r3, [r7, #28]
|
|
ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE);
|
|
8004c80: 64bb str r3, [r7, #72] ; 0x48
|
|
8004c82: 2301 movs r3, #1
|
|
8004c84: 623b str r3, [r7, #32]
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004c86: 6a3b ldr r3, [r7, #32]
|
|
8004c88: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004c8c: 46c0 nop ; (mov r8, r8)
|
|
8004c8e: 68fb ldr r3, [r7, #12]
|
|
8004c90: 681b ldr r3, [r3, #0]
|
|
8004c92: 689a ldr r2, [r3, #8]
|
|
8004c94: 68fb ldr r3, [r7, #12]
|
|
8004c96: 681b ldr r3, [r3, #0]
|
|
8004c98: 2101 movs r1, #1
|
|
8004c9a: 438a bics r2, r1
|
|
8004c9c: 609a str r2, [r3, #8]
|
|
8004c9e: 6cbb ldr r3, [r7, #72] ; 0x48
|
|
8004ca0: 627b str r3, [r7, #36] ; 0x24
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004ca2: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
8004ca4: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004ca8: 46c0 nop ; (mov r8, r8)
|
|
|
|
huart->gState = HAL_UART_STATE_READY;
|
|
8004caa: 68fb ldr r3, [r7, #12]
|
|
8004cac: 2220 movs r2, #32
|
|
8004cae: 679a str r2, [r3, #120] ; 0x78
|
|
huart->RxState = HAL_UART_STATE_READY;
|
|
8004cb0: 68fb ldr r3, [r7, #12]
|
|
8004cb2: 2220 movs r2, #32
|
|
8004cb4: 67da str r2, [r3, #124] ; 0x7c
|
|
huart->ErrorCode = HAL_UART_ERROR_RTO;
|
|
8004cb6: 68fb ldr r3, [r7, #12]
|
|
8004cb8: 2280 movs r2, #128 ; 0x80
|
|
8004cba: 2120 movs r1, #32
|
|
8004cbc: 5099 str r1, [r3, r2]
|
|
|
|
/* Process Unlocked */
|
|
__HAL_UNLOCK(huart);
|
|
8004cbe: 68fb ldr r3, [r7, #12]
|
|
8004cc0: 2274 movs r2, #116 ; 0x74
|
|
8004cc2: 2100 movs r1, #0
|
|
8004cc4: 5499 strb r1, [r3, r2]
|
|
|
|
return HAL_TIMEOUT;
|
|
8004cc6: 2303 movs r3, #3
|
|
8004cc8: e010 b.n 8004cec <UART_WaitOnFlagUntilTimeout+0x17c>
|
|
while ((__HAL_UART_GET_FLAG(huart, Flag) ? SET : RESET) == Status)
|
|
8004cca: 68fb ldr r3, [r7, #12]
|
|
8004ccc: 681b ldr r3, [r3, #0]
|
|
8004cce: 69db ldr r3, [r3, #28]
|
|
8004cd0: 68ba ldr r2, [r7, #8]
|
|
8004cd2: 4013 ands r3, r2
|
|
8004cd4: 68ba ldr r2, [r7, #8]
|
|
8004cd6: 1ad3 subs r3, r2, r3
|
|
8004cd8: 425a negs r2, r3
|
|
8004cda: 4153 adcs r3, r2
|
|
8004cdc: b2db uxtb r3, r3
|
|
8004cde: 001a movs r2, r3
|
|
8004ce0: 1dfb adds r3, r7, #7
|
|
8004ce2: 781b ldrb r3, [r3, #0]
|
|
8004ce4: 429a cmp r2, r3
|
|
8004ce6: d100 bne.n 8004cea <UART_WaitOnFlagUntilTimeout+0x17a>
|
|
8004ce8: e74b b.n 8004b82 <UART_WaitOnFlagUntilTimeout+0x12>
|
|
}
|
|
}
|
|
}
|
|
}
|
|
return HAL_OK;
|
|
8004cea: 2300 movs r3, #0
|
|
}
|
|
8004cec: 0018 movs r0, r3
|
|
8004cee: 46bd mov sp, r7
|
|
8004cf0: b014 add sp, #80 ; 0x50
|
|
8004cf2: bd80 pop {r7, pc}
|
|
8004cf4: fffffe5f .word 0xfffffe5f
|
|
|
|
08004cf8 <UART_EndRxTransfer>:
|
|
* @brief End ongoing Rx transfer on UART peripheral (following error detection or Reception completion).
|
|
* @param huart UART handle.
|
|
* @retval None
|
|
*/
|
|
static void UART_EndRxTransfer(UART_HandleTypeDef *huart)
|
|
{
|
|
8004cf8: b580 push {r7, lr}
|
|
8004cfa: b08e sub sp, #56 ; 0x38
|
|
8004cfc: af00 add r7, sp, #0
|
|
8004cfe: 6078 str r0, [r7, #4]
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
8004d00: f3ef 8310 mrs r3, PRIMASK
|
|
8004d04: 617b str r3, [r7, #20]
|
|
return(result);
|
|
8004d06: 697b ldr r3, [r7, #20]
|
|
/* Disable RXNE, PE and ERR (Frame error, noise error, overrun error) interrupts */
|
|
ATOMIC_CLEAR_BIT(huart->Instance->CR1, (USART_CR1_RXNEIE | USART_CR1_PEIE));
|
|
8004d08: 637b str r3, [r7, #52] ; 0x34
|
|
8004d0a: 2301 movs r3, #1
|
|
8004d0c: 61bb str r3, [r7, #24]
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004d0e: 69bb ldr r3, [r7, #24]
|
|
8004d10: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004d14: 46c0 nop ; (mov r8, r8)
|
|
8004d16: 687b ldr r3, [r7, #4]
|
|
8004d18: 681b ldr r3, [r3, #0]
|
|
8004d1a: 681a ldr r2, [r3, #0]
|
|
8004d1c: 687b ldr r3, [r7, #4]
|
|
8004d1e: 681b ldr r3, [r3, #0]
|
|
8004d20: 4925 ldr r1, [pc, #148] ; (8004db8 <UART_EndRxTransfer+0xc0>)
|
|
8004d22: 400a ands r2, r1
|
|
8004d24: 601a str r2, [r3, #0]
|
|
8004d26: 6b7b ldr r3, [r7, #52] ; 0x34
|
|
8004d28: 61fb str r3, [r7, #28]
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004d2a: 69fb ldr r3, [r7, #28]
|
|
8004d2c: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004d30: 46c0 nop ; (mov r8, r8)
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
8004d32: f3ef 8310 mrs r3, PRIMASK
|
|
8004d36: 623b str r3, [r7, #32]
|
|
return(result);
|
|
8004d38: 6a3b ldr r3, [r7, #32]
|
|
ATOMIC_CLEAR_BIT(huart->Instance->CR3, USART_CR3_EIE);
|
|
8004d3a: 633b str r3, [r7, #48] ; 0x30
|
|
8004d3c: 2301 movs r3, #1
|
|
8004d3e: 627b str r3, [r7, #36] ; 0x24
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004d40: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
8004d42: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004d46: 46c0 nop ; (mov r8, r8)
|
|
8004d48: 687b ldr r3, [r7, #4]
|
|
8004d4a: 681b ldr r3, [r3, #0]
|
|
8004d4c: 689a ldr r2, [r3, #8]
|
|
8004d4e: 687b ldr r3, [r7, #4]
|
|
8004d50: 681b ldr r3, [r3, #0]
|
|
8004d52: 2101 movs r1, #1
|
|
8004d54: 438a bics r2, r1
|
|
8004d56: 609a str r2, [r3, #8]
|
|
8004d58: 6b3b ldr r3, [r7, #48] ; 0x30
|
|
8004d5a: 62bb str r3, [r7, #40] ; 0x28
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004d5c: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8004d5e: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004d62: 46c0 nop ; (mov r8, r8)
|
|
|
|
/* In case of reception waiting for IDLE event, disable also the IDLE IE interrupt source */
|
|
if (huart->ReceptionType == HAL_UART_RECEPTION_TOIDLE)
|
|
8004d64: 687b ldr r3, [r7, #4]
|
|
8004d66: 6e1b ldr r3, [r3, #96] ; 0x60
|
|
8004d68: 2b01 cmp r3, #1
|
|
8004d6a: d118 bne.n 8004d9e <UART_EndRxTransfer+0xa6>
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
8004d6c: f3ef 8310 mrs r3, PRIMASK
|
|
8004d70: 60bb str r3, [r7, #8]
|
|
return(result);
|
|
8004d72: 68bb ldr r3, [r7, #8]
|
|
{
|
|
ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_IDLEIE);
|
|
8004d74: 62fb str r3, [r7, #44] ; 0x2c
|
|
8004d76: 2301 movs r3, #1
|
|
8004d78: 60fb str r3, [r7, #12]
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004d7a: 68fb ldr r3, [r7, #12]
|
|
8004d7c: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004d80: 46c0 nop ; (mov r8, r8)
|
|
8004d82: 687b ldr r3, [r7, #4]
|
|
8004d84: 681b ldr r3, [r3, #0]
|
|
8004d86: 681a ldr r2, [r3, #0]
|
|
8004d88: 687b ldr r3, [r7, #4]
|
|
8004d8a: 681b ldr r3, [r3, #0]
|
|
8004d8c: 2110 movs r1, #16
|
|
8004d8e: 438a bics r2, r1
|
|
8004d90: 601a str r2, [r3, #0]
|
|
8004d92: 6afb ldr r3, [r7, #44] ; 0x2c
|
|
8004d94: 613b str r3, [r7, #16]
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004d96: 693b ldr r3, [r7, #16]
|
|
8004d98: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004d9c: 46c0 nop ; (mov r8, r8)
|
|
}
|
|
|
|
/* At end of Rx process, restore huart->RxState to Ready */
|
|
huart->RxState = HAL_UART_STATE_READY;
|
|
8004d9e: 687b ldr r3, [r7, #4]
|
|
8004da0: 2220 movs r2, #32
|
|
8004da2: 67da str r2, [r3, #124] ; 0x7c
|
|
huart->ReceptionType = HAL_UART_RECEPTION_STANDARD;
|
|
8004da4: 687b ldr r3, [r7, #4]
|
|
8004da6: 2200 movs r2, #0
|
|
8004da8: 661a str r2, [r3, #96] ; 0x60
|
|
|
|
/* Reset RxIsr function pointer */
|
|
huart->RxISR = NULL;
|
|
8004daa: 687b ldr r3, [r7, #4]
|
|
8004dac: 2200 movs r2, #0
|
|
8004dae: 665a str r2, [r3, #100] ; 0x64
|
|
}
|
|
8004db0: 46c0 nop ; (mov r8, r8)
|
|
8004db2: 46bd mov sp, r7
|
|
8004db4: b00e add sp, #56 ; 0x38
|
|
8004db6: bd80 pop {r7, pc}
|
|
8004db8: fffffedf .word 0xfffffedf
|
|
|
|
08004dbc <UART_DMAAbortOnError>:
|
|
* (To be called at end of DMA Abort procedure following error occurrence).
|
|
* @param hdma DMA handle.
|
|
* @retval None
|
|
*/
|
|
static void UART_DMAAbortOnError(DMA_HandleTypeDef *hdma)
|
|
{
|
|
8004dbc: b580 push {r7, lr}
|
|
8004dbe: b084 sub sp, #16
|
|
8004dc0: af00 add r7, sp, #0
|
|
8004dc2: 6078 str r0, [r7, #4]
|
|
UART_HandleTypeDef *huart = (UART_HandleTypeDef *)(hdma->Parent);
|
|
8004dc4: 687b ldr r3, [r7, #4]
|
|
8004dc6: 6a9b ldr r3, [r3, #40] ; 0x28
|
|
8004dc8: 60fb str r3, [r7, #12]
|
|
huart->RxXferCount = 0U;
|
|
8004dca: 68fb ldr r3, [r7, #12]
|
|
8004dcc: 225a movs r2, #90 ; 0x5a
|
|
8004dce: 2100 movs r1, #0
|
|
8004dd0: 5299 strh r1, [r3, r2]
|
|
huart->TxXferCount = 0U;
|
|
8004dd2: 68fb ldr r3, [r7, #12]
|
|
8004dd4: 2252 movs r2, #82 ; 0x52
|
|
8004dd6: 2100 movs r1, #0
|
|
8004dd8: 5299 strh r1, [r3, r2]
|
|
#if (USE_HAL_UART_REGISTER_CALLBACKS == 1)
|
|
/*Call registered error callback*/
|
|
huart->ErrorCallback(huart);
|
|
#else
|
|
/*Call legacy weak error callback*/
|
|
HAL_UART_ErrorCallback(huart);
|
|
8004dda: 68fb ldr r3, [r7, #12]
|
|
8004ddc: 0018 movs r0, r3
|
|
8004dde: f7ff fb55 bl 800448c <HAL_UART_ErrorCallback>
|
|
#endif /* USE_HAL_UART_REGISTER_CALLBACKS */
|
|
}
|
|
8004de2: 46c0 nop ; (mov r8, r8)
|
|
8004de4: 46bd mov sp, r7
|
|
8004de6: b004 add sp, #16
|
|
8004de8: bd80 pop {r7, pc}
|
|
|
|
08004dea <UART_EndTransmit_IT>:
|
|
* @param huart pointer to a UART_HandleTypeDef structure that contains
|
|
* the configuration information for the specified UART module.
|
|
* @retval None
|
|
*/
|
|
static void UART_EndTransmit_IT(UART_HandleTypeDef *huart)
|
|
{
|
|
8004dea: b580 push {r7, lr}
|
|
8004dec: b086 sub sp, #24
|
|
8004dee: af00 add r7, sp, #0
|
|
8004df0: 6078 str r0, [r7, #4]
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
8004df2: f3ef 8310 mrs r3, PRIMASK
|
|
8004df6: 60bb str r3, [r7, #8]
|
|
return(result);
|
|
8004df8: 68bb ldr r3, [r7, #8]
|
|
/* Disable the UART Transmit Complete Interrupt */
|
|
ATOMIC_CLEAR_BIT(huart->Instance->CR1, USART_CR1_TCIE);
|
|
8004dfa: 617b str r3, [r7, #20]
|
|
8004dfc: 2301 movs r3, #1
|
|
8004dfe: 60fb str r3, [r7, #12]
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004e00: 68fb ldr r3, [r7, #12]
|
|
8004e02: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004e06: 46c0 nop ; (mov r8, r8)
|
|
8004e08: 687b ldr r3, [r7, #4]
|
|
8004e0a: 681b ldr r3, [r3, #0]
|
|
8004e0c: 681a ldr r2, [r3, #0]
|
|
8004e0e: 687b ldr r3, [r7, #4]
|
|
8004e10: 681b ldr r3, [r3, #0]
|
|
8004e12: 2140 movs r1, #64 ; 0x40
|
|
8004e14: 438a bics r2, r1
|
|
8004e16: 601a str r2, [r3, #0]
|
|
8004e18: 697b ldr r3, [r7, #20]
|
|
8004e1a: 613b str r3, [r7, #16]
|
|
__ASM volatile ("MSR primask, %0" : : "r" (priMask) : "memory");
|
|
8004e1c: 693b ldr r3, [r7, #16]
|
|
8004e1e: f383 8810 msr PRIMASK, r3
|
|
}
|
|
8004e22: 46c0 nop ; (mov r8, r8)
|
|
|
|
/* Tx process is ended, restore huart->gState to Ready */
|
|
huart->gState = HAL_UART_STATE_READY;
|
|
8004e24: 687b ldr r3, [r7, #4]
|
|
8004e26: 2220 movs r2, #32
|
|
8004e28: 679a str r2, [r3, #120] ; 0x78
|
|
|
|
/* Cleat TxISR function pointer */
|
|
huart->TxISR = NULL;
|
|
8004e2a: 687b ldr r3, [r7, #4]
|
|
8004e2c: 2200 movs r2, #0
|
|
8004e2e: 669a str r2, [r3, #104] ; 0x68
|
|
#if (USE_HAL_UART_REGISTER_CALLBACKS == 1)
|
|
/*Call registered Tx complete callback*/
|
|
huart->TxCpltCallback(huart);
|
|
#else
|
|
/*Call legacy weak Tx complete callback*/
|
|
HAL_UART_TxCpltCallback(huart);
|
|
8004e30: 687b ldr r3, [r7, #4]
|
|
8004e32: 0018 movs r0, r3
|
|
8004e34: f7ff fb22 bl 800447c <HAL_UART_TxCpltCallback>
|
|
#endif /* USE_HAL_UART_REGISTER_CALLBACKS */
|
|
}
|
|
8004e38: 46c0 nop ; (mov r8, r8)
|
|
8004e3a: 46bd mov sp, r7
|
|
8004e3c: b006 add sp, #24
|
|
8004e3e: bd80 pop {r7, pc}
|
|
|
|
08004e40 <HAL_UARTEx_WakeupCallback>:
|
|
* @brief UART wakeup from Stop mode callback.
|
|
* @param huart UART handle.
|
|
* @retval None
|
|
*/
|
|
__weak void HAL_UARTEx_WakeupCallback(UART_HandleTypeDef *huart)
|
|
{
|
|
8004e40: b580 push {r7, lr}
|
|
8004e42: b082 sub sp, #8
|
|
8004e44: af00 add r7, sp, #0
|
|
8004e46: 6078 str r0, [r7, #4]
|
|
UNUSED(huart);
|
|
|
|
/* NOTE : This function should not be modified, when the callback is needed,
|
|
the HAL_UARTEx_WakeupCallback can be implemented in the user file.
|
|
*/
|
|
}
|
|
8004e48: 46c0 nop ; (mov r8, r8)
|
|
8004e4a: 46bd mov sp, r7
|
|
8004e4c: b002 add sp, #8
|
|
8004e4e: bd80 pop {r7, pc}
|
|
|
|
08004e50 <SVC_Setup>:
|
|
#endif /* SysTick */
|
|
|
|
/*
|
|
Setup SVC to reset value.
|
|
*/
|
|
__STATIC_INLINE void SVC_Setup (void) {
|
|
8004e50: b580 push {r7, lr}
|
|
8004e52: af00 add r7, sp, #0
|
|
* The issue was logged under:https://github.com/ARM-software/CMSIS-FreeRTOS/issues/35
|
|
* until it is correctly fixed, the code below is commented
|
|
*/
|
|
/* NVIC_SetPriority (SVCall_IRQn, 0U); */
|
|
#endif
|
|
}
|
|
8004e54: 46c0 nop ; (mov r8, r8)
|
|
8004e56: 46bd mov sp, r7
|
|
8004e58: bd80 pop {r7, pc}
|
|
...
|
|
|
|
08004e5c <osKernelInitialize>:
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
osStatus_t osKernelInitialize (void) {
|
|
8004e5c: b580 push {r7, lr}
|
|
8004e5e: b084 sub sp, #16
|
|
8004e60: af00 add r7, sp, #0
|
|
__ASM volatile ("MRS %0, ipsr" : "=r" (result) );
|
|
8004e62: f3ef 8305 mrs r3, IPSR
|
|
8004e66: 60bb str r3, [r7, #8]
|
|
return(result);
|
|
8004e68: 68bb ldr r3, [r7, #8]
|
|
osStatus_t stat;
|
|
|
|
if (IS_IRQ()) {
|
|
8004e6a: 2b00 cmp r3, #0
|
|
8004e6c: d109 bne.n 8004e82 <osKernelInitialize+0x26>
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
8004e6e: f3ef 8310 mrs r3, PRIMASK
|
|
8004e72: 607b str r3, [r7, #4]
|
|
return(result);
|
|
8004e74: 687b ldr r3, [r7, #4]
|
|
8004e76: 2b00 cmp r3, #0
|
|
8004e78: d007 beq.n 8004e8a <osKernelInitialize+0x2e>
|
|
8004e7a: 4b0d ldr r3, [pc, #52] ; (8004eb0 <osKernelInitialize+0x54>)
|
|
8004e7c: 681b ldr r3, [r3, #0]
|
|
8004e7e: 2b02 cmp r3, #2
|
|
8004e80: d103 bne.n 8004e8a <osKernelInitialize+0x2e>
|
|
stat = osErrorISR;
|
|
8004e82: 2306 movs r3, #6
|
|
8004e84: 425b negs r3, r3
|
|
8004e86: 60fb str r3, [r7, #12]
|
|
8004e88: e00c b.n 8004ea4 <osKernelInitialize+0x48>
|
|
}
|
|
else {
|
|
if (KernelState == osKernelInactive) {
|
|
8004e8a: 4b09 ldr r3, [pc, #36] ; (8004eb0 <osKernelInitialize+0x54>)
|
|
8004e8c: 681b ldr r3, [r3, #0]
|
|
8004e8e: 2b00 cmp r3, #0
|
|
8004e90: d105 bne.n 8004e9e <osKernelInitialize+0x42>
|
|
#if defined(USE_FREERTOS_HEAP_5) && (HEAP_5_REGION_SETUP == 1)
|
|
vPortDefineHeapRegions (configHEAP_5_REGIONS);
|
|
#endif
|
|
KernelState = osKernelReady;
|
|
8004e92: 4b07 ldr r3, [pc, #28] ; (8004eb0 <osKernelInitialize+0x54>)
|
|
8004e94: 2201 movs r2, #1
|
|
8004e96: 601a str r2, [r3, #0]
|
|
stat = osOK;
|
|
8004e98: 2300 movs r3, #0
|
|
8004e9a: 60fb str r3, [r7, #12]
|
|
8004e9c: e002 b.n 8004ea4 <osKernelInitialize+0x48>
|
|
} else {
|
|
stat = osError;
|
|
8004e9e: 2301 movs r3, #1
|
|
8004ea0: 425b negs r3, r3
|
|
8004ea2: 60fb str r3, [r7, #12]
|
|
}
|
|
}
|
|
|
|
return (stat);
|
|
8004ea4: 68fb ldr r3, [r7, #12]
|
|
}
|
|
8004ea6: 0018 movs r0, r3
|
|
8004ea8: 46bd mov sp, r7
|
|
8004eaa: b004 add sp, #16
|
|
8004eac: bd80 pop {r7, pc}
|
|
8004eae: 46c0 nop ; (mov r8, r8)
|
|
8004eb0: 20000030 .word 0x20000030
|
|
|
|
08004eb4 <osKernelStart>:
|
|
}
|
|
|
|
return (state);
|
|
}
|
|
|
|
osStatus_t osKernelStart (void) {
|
|
8004eb4: b580 push {r7, lr}
|
|
8004eb6: b084 sub sp, #16
|
|
8004eb8: af00 add r7, sp, #0
|
|
__ASM volatile ("MRS %0, ipsr" : "=r" (result) );
|
|
8004eba: f3ef 8305 mrs r3, IPSR
|
|
8004ebe: 60bb str r3, [r7, #8]
|
|
return(result);
|
|
8004ec0: 68bb ldr r3, [r7, #8]
|
|
osStatus_t stat;
|
|
|
|
if (IS_IRQ()) {
|
|
8004ec2: 2b00 cmp r3, #0
|
|
8004ec4: d109 bne.n 8004eda <osKernelStart+0x26>
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
8004ec6: f3ef 8310 mrs r3, PRIMASK
|
|
8004eca: 607b str r3, [r7, #4]
|
|
return(result);
|
|
8004ecc: 687b ldr r3, [r7, #4]
|
|
8004ece: 2b00 cmp r3, #0
|
|
8004ed0: d007 beq.n 8004ee2 <osKernelStart+0x2e>
|
|
8004ed2: 4b0f ldr r3, [pc, #60] ; (8004f10 <osKernelStart+0x5c>)
|
|
8004ed4: 681b ldr r3, [r3, #0]
|
|
8004ed6: 2b02 cmp r3, #2
|
|
8004ed8: d103 bne.n 8004ee2 <osKernelStart+0x2e>
|
|
stat = osErrorISR;
|
|
8004eda: 2306 movs r3, #6
|
|
8004edc: 425b negs r3, r3
|
|
8004ede: 60fb str r3, [r7, #12]
|
|
8004ee0: e010 b.n 8004f04 <osKernelStart+0x50>
|
|
}
|
|
else {
|
|
if (KernelState == osKernelReady) {
|
|
8004ee2: 4b0b ldr r3, [pc, #44] ; (8004f10 <osKernelStart+0x5c>)
|
|
8004ee4: 681b ldr r3, [r3, #0]
|
|
8004ee6: 2b01 cmp r3, #1
|
|
8004ee8: d109 bne.n 8004efe <osKernelStart+0x4a>
|
|
/* Ensure SVC priority is at the reset value */
|
|
SVC_Setup();
|
|
8004eea: f7ff ffb1 bl 8004e50 <SVC_Setup>
|
|
/* Change state to enable IRQ masking check */
|
|
KernelState = osKernelRunning;
|
|
8004eee: 4b08 ldr r3, [pc, #32] ; (8004f10 <osKernelStart+0x5c>)
|
|
8004ef0: 2202 movs r2, #2
|
|
8004ef2: 601a str r2, [r3, #0]
|
|
/* Start the kernel scheduler */
|
|
vTaskStartScheduler();
|
|
8004ef4: f001 f80e bl 8005f14 <vTaskStartScheduler>
|
|
stat = osOK;
|
|
8004ef8: 2300 movs r3, #0
|
|
8004efa: 60fb str r3, [r7, #12]
|
|
8004efc: e002 b.n 8004f04 <osKernelStart+0x50>
|
|
} else {
|
|
stat = osError;
|
|
8004efe: 2301 movs r3, #1
|
|
8004f00: 425b negs r3, r3
|
|
8004f02: 60fb str r3, [r7, #12]
|
|
}
|
|
}
|
|
|
|
return (stat);
|
|
8004f04: 68fb ldr r3, [r7, #12]
|
|
}
|
|
8004f06: 0018 movs r0, r3
|
|
8004f08: 46bd mov sp, r7
|
|
8004f0a: b004 add sp, #16
|
|
8004f0c: bd80 pop {r7, pc}
|
|
8004f0e: 46c0 nop ; (mov r8, r8)
|
|
8004f10: 20000030 .word 0x20000030
|
|
|
|
08004f14 <osThreadNew>:
|
|
return (configCPU_CLOCK_HZ);
|
|
}
|
|
|
|
/*---------------------------------------------------------------------------*/
|
|
|
|
osThreadId_t osThreadNew (osThreadFunc_t func, void *argument, const osThreadAttr_t *attr) {
|
|
8004f14: b5b0 push {r4, r5, r7, lr}
|
|
8004f16: b090 sub sp, #64 ; 0x40
|
|
8004f18: af04 add r7, sp, #16
|
|
8004f1a: 60f8 str r0, [r7, #12]
|
|
8004f1c: 60b9 str r1, [r7, #8]
|
|
8004f1e: 607a str r2, [r7, #4]
|
|
uint32_t stack;
|
|
TaskHandle_t hTask;
|
|
UBaseType_t prio;
|
|
int32_t mem;
|
|
|
|
hTask = NULL;
|
|
8004f20: 2300 movs r3, #0
|
|
8004f22: 617b str r3, [r7, #20]
|
|
__ASM volatile ("MRS %0, ipsr" : "=r" (result) );
|
|
8004f24: f3ef 8305 mrs r3, IPSR
|
|
8004f28: 61fb str r3, [r7, #28]
|
|
return(result);
|
|
8004f2a: 69fb ldr r3, [r7, #28]
|
|
|
|
if (!IS_IRQ() && (func != NULL)) {
|
|
8004f2c: 2b00 cmp r3, #0
|
|
8004f2e: d000 beq.n 8004f32 <osThreadNew+0x1e>
|
|
8004f30: e08c b.n 800504c <osThreadNew+0x138>
|
|
__ASM volatile ("MRS %0, primask" : "=r" (result) :: "memory");
|
|
8004f32: f3ef 8310 mrs r3, PRIMASK
|
|
8004f36: 61bb str r3, [r7, #24]
|
|
return(result);
|
|
8004f38: 69bb ldr r3, [r7, #24]
|
|
8004f3a: 2b00 cmp r3, #0
|
|
8004f3c: d004 beq.n 8004f48 <osThreadNew+0x34>
|
|
8004f3e: 4b46 ldr r3, [pc, #280] ; (8005058 <osThreadNew+0x144>)
|
|
8004f40: 681b ldr r3, [r3, #0]
|
|
8004f42: 2b02 cmp r3, #2
|
|
8004f44: d100 bne.n 8004f48 <osThreadNew+0x34>
|
|
8004f46: e081 b.n 800504c <osThreadNew+0x138>
|
|
8004f48: 68fb ldr r3, [r7, #12]
|
|
8004f4a: 2b00 cmp r3, #0
|
|
8004f4c: d100 bne.n 8004f50 <osThreadNew+0x3c>
|
|
8004f4e: e07d b.n 800504c <osThreadNew+0x138>
|
|
stack = configMINIMAL_STACK_SIZE;
|
|
8004f50: 2380 movs r3, #128 ; 0x80
|
|
8004f52: 62bb str r3, [r7, #40] ; 0x28
|
|
prio = (UBaseType_t)osPriorityNormal;
|
|
8004f54: 2318 movs r3, #24
|
|
8004f56: 627b str r3, [r7, #36] ; 0x24
|
|
|
|
name = NULL;
|
|
8004f58: 2300 movs r3, #0
|
|
8004f5a: 62fb str r3, [r7, #44] ; 0x2c
|
|
mem = -1;
|
|
8004f5c: 2301 movs r3, #1
|
|
8004f5e: 425b negs r3, r3
|
|
8004f60: 623b str r3, [r7, #32]
|
|
|
|
if (attr != NULL) {
|
|
8004f62: 687b ldr r3, [r7, #4]
|
|
8004f64: 2b00 cmp r3, #0
|
|
8004f66: d044 beq.n 8004ff2 <osThreadNew+0xde>
|
|
if (attr->name != NULL) {
|
|
8004f68: 687b ldr r3, [r7, #4]
|
|
8004f6a: 681b ldr r3, [r3, #0]
|
|
8004f6c: 2b00 cmp r3, #0
|
|
8004f6e: d002 beq.n 8004f76 <osThreadNew+0x62>
|
|
name = attr->name;
|
|
8004f70: 687b ldr r3, [r7, #4]
|
|
8004f72: 681b ldr r3, [r3, #0]
|
|
8004f74: 62fb str r3, [r7, #44] ; 0x2c
|
|
}
|
|
if (attr->priority != osPriorityNone) {
|
|
8004f76: 687b ldr r3, [r7, #4]
|
|
8004f78: 699b ldr r3, [r3, #24]
|
|
8004f7a: 2b00 cmp r3, #0
|
|
8004f7c: d002 beq.n 8004f84 <osThreadNew+0x70>
|
|
prio = (UBaseType_t)attr->priority;
|
|
8004f7e: 687b ldr r3, [r7, #4]
|
|
8004f80: 699b ldr r3, [r3, #24]
|
|
8004f82: 627b str r3, [r7, #36] ; 0x24
|
|
}
|
|
|
|
if ((prio < osPriorityIdle) || (prio > osPriorityISR) || ((attr->attr_bits & osThreadJoinable) == osThreadJoinable)) {
|
|
8004f84: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
8004f86: 2b00 cmp r3, #0
|
|
8004f88: d007 beq.n 8004f9a <osThreadNew+0x86>
|
|
8004f8a: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
8004f8c: 2b38 cmp r3, #56 ; 0x38
|
|
8004f8e: d804 bhi.n 8004f9a <osThreadNew+0x86>
|
|
8004f90: 687b ldr r3, [r7, #4]
|
|
8004f92: 685b ldr r3, [r3, #4]
|
|
8004f94: 2201 movs r2, #1
|
|
8004f96: 4013 ands r3, r2
|
|
8004f98: d001 beq.n 8004f9e <osThreadNew+0x8a>
|
|
return (NULL);
|
|
8004f9a: 2300 movs r3, #0
|
|
8004f9c: e057 b.n 800504e <osThreadNew+0x13a>
|
|
}
|
|
|
|
if (attr->stack_size > 0U) {
|
|
8004f9e: 687b ldr r3, [r7, #4]
|
|
8004fa0: 695b ldr r3, [r3, #20]
|
|
8004fa2: 2b00 cmp r3, #0
|
|
8004fa4: d003 beq.n 8004fae <osThreadNew+0x9a>
|
|
/* In FreeRTOS stack is not in bytes, but in sizeof(StackType_t) which is 4 on ARM ports. */
|
|
/* Stack size should be therefore 4 byte aligned in order to avoid division caused side effects */
|
|
stack = attr->stack_size / sizeof(StackType_t);
|
|
8004fa6: 687b ldr r3, [r7, #4]
|
|
8004fa8: 695b ldr r3, [r3, #20]
|
|
8004faa: 089b lsrs r3, r3, #2
|
|
8004fac: 62bb str r3, [r7, #40] ; 0x28
|
|
}
|
|
|
|
if ((attr->cb_mem != NULL) && (attr->cb_size >= sizeof(StaticTask_t)) &&
|
|
8004fae: 687b ldr r3, [r7, #4]
|
|
8004fb0: 689b ldr r3, [r3, #8]
|
|
8004fb2: 2b00 cmp r3, #0
|
|
8004fb4: d00e beq.n 8004fd4 <osThreadNew+0xc0>
|
|
8004fb6: 687b ldr r3, [r7, #4]
|
|
8004fb8: 68db ldr r3, [r3, #12]
|
|
8004fba: 2b5b cmp r3, #91 ; 0x5b
|
|
8004fbc: d90a bls.n 8004fd4 <osThreadNew+0xc0>
|
|
(attr->stack_mem != NULL) && (attr->stack_size > 0U)) {
|
|
8004fbe: 687b ldr r3, [r7, #4]
|
|
8004fc0: 691b ldr r3, [r3, #16]
|
|
if ((attr->cb_mem != NULL) && (attr->cb_size >= sizeof(StaticTask_t)) &&
|
|
8004fc2: 2b00 cmp r3, #0
|
|
8004fc4: d006 beq.n 8004fd4 <osThreadNew+0xc0>
|
|
(attr->stack_mem != NULL) && (attr->stack_size > 0U)) {
|
|
8004fc6: 687b ldr r3, [r7, #4]
|
|
8004fc8: 695b ldr r3, [r3, #20]
|
|
8004fca: 2b00 cmp r3, #0
|
|
8004fcc: d002 beq.n 8004fd4 <osThreadNew+0xc0>
|
|
mem = 1;
|
|
8004fce: 2301 movs r3, #1
|
|
8004fd0: 623b str r3, [r7, #32]
|
|
8004fd2: e010 b.n 8004ff6 <osThreadNew+0xe2>
|
|
}
|
|
else {
|
|
if ((attr->cb_mem == NULL) && (attr->cb_size == 0U) && (attr->stack_mem == NULL)) {
|
|
8004fd4: 687b ldr r3, [r7, #4]
|
|
8004fd6: 689b ldr r3, [r3, #8]
|
|
8004fd8: 2b00 cmp r3, #0
|
|
8004fda: d10c bne.n 8004ff6 <osThreadNew+0xe2>
|
|
8004fdc: 687b ldr r3, [r7, #4]
|
|
8004fde: 68db ldr r3, [r3, #12]
|
|
8004fe0: 2b00 cmp r3, #0
|
|
8004fe2: d108 bne.n 8004ff6 <osThreadNew+0xe2>
|
|
8004fe4: 687b ldr r3, [r7, #4]
|
|
8004fe6: 691b ldr r3, [r3, #16]
|
|
8004fe8: 2b00 cmp r3, #0
|
|
8004fea: d104 bne.n 8004ff6 <osThreadNew+0xe2>
|
|
mem = 0;
|
|
8004fec: 2300 movs r3, #0
|
|
8004fee: 623b str r3, [r7, #32]
|
|
8004ff0: e001 b.n 8004ff6 <osThreadNew+0xe2>
|
|
}
|
|
}
|
|
}
|
|
else {
|
|
mem = 0;
|
|
8004ff2: 2300 movs r3, #0
|
|
8004ff4: 623b str r3, [r7, #32]
|
|
}
|
|
|
|
if (mem == 1) {
|
|
8004ff6: 6a3b ldr r3, [r7, #32]
|
|
8004ff8: 2b01 cmp r3, #1
|
|
8004ffa: d112 bne.n 8005022 <osThreadNew+0x10e>
|
|
hTask = xTaskCreateStatic ((TaskFunction_t)func, name, stack, argument, prio, (StackType_t *)attr->stack_mem,
|
|
8004ffc: 687b ldr r3, [r7, #4]
|
|
8004ffe: 691a ldr r2, [r3, #16]
|
|
(StaticTask_t *)attr->cb_mem);
|
|
8005000: 687b ldr r3, [r7, #4]
|
|
8005002: 689b ldr r3, [r3, #8]
|
|
hTask = xTaskCreateStatic ((TaskFunction_t)func, name, stack, argument, prio, (StackType_t *)attr->stack_mem,
|
|
8005004: 68bd ldr r5, [r7, #8]
|
|
8005006: 6abc ldr r4, [r7, #40] ; 0x28
|
|
8005008: 6af9 ldr r1, [r7, #44] ; 0x2c
|
|
800500a: 68f8 ldr r0, [r7, #12]
|
|
800500c: 9302 str r3, [sp, #8]
|
|
800500e: 9201 str r2, [sp, #4]
|
|
8005010: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
8005012: 9300 str r3, [sp, #0]
|
|
8005014: 002b movs r3, r5
|
|
8005016: 0022 movs r2, r4
|
|
8005018: f000 fd5b bl 8005ad2 <xTaskCreateStatic>
|
|
800501c: 0003 movs r3, r0
|
|
800501e: 617b str r3, [r7, #20]
|
|
8005020: e014 b.n 800504c <osThreadNew+0x138>
|
|
}
|
|
else {
|
|
if (mem == 0) {
|
|
8005022: 6a3b ldr r3, [r7, #32]
|
|
8005024: 2b00 cmp r3, #0
|
|
8005026: d111 bne.n 800504c <osThreadNew+0x138>
|
|
if (xTaskCreate ((TaskFunction_t)func, name, (uint16_t)stack, argument, prio, &hTask) != pdPASS) {
|
|
8005028: 6abb ldr r3, [r7, #40] ; 0x28
|
|
800502a: b29a uxth r2, r3
|
|
800502c: 68bc ldr r4, [r7, #8]
|
|
800502e: 6af9 ldr r1, [r7, #44] ; 0x2c
|
|
8005030: 68f8 ldr r0, [r7, #12]
|
|
8005032: 2314 movs r3, #20
|
|
8005034: 18fb adds r3, r7, r3
|
|
8005036: 9301 str r3, [sp, #4]
|
|
8005038: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
800503a: 9300 str r3, [sp, #0]
|
|
800503c: 0023 movs r3, r4
|
|
800503e: f000 fd8c bl 8005b5a <xTaskCreate>
|
|
8005042: 0003 movs r3, r0
|
|
8005044: 2b01 cmp r3, #1
|
|
8005046: d001 beq.n 800504c <osThreadNew+0x138>
|
|
hTask = NULL;
|
|
8005048: 2300 movs r3, #0
|
|
800504a: 617b str r3, [r7, #20]
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
return ((osThreadId_t)hTask);
|
|
800504c: 697b ldr r3, [r7, #20]
|
|
}
|
|
800504e: 0018 movs r0, r3
|
|
8005050: 46bd mov sp, r7
|
|
8005052: b00c add sp, #48 ; 0x30
|
|
8005054: bdb0 pop {r4, r5, r7, pc}
|
|
8005056: 46c0 nop ; (mov r8, r8)
|
|
8005058: 20000030 .word 0x20000030
|
|
|
|
0800505c <vApplicationGetIdleTaskMemory>:
|
|
|
|
/*
|
|
vApplicationGetIdleTaskMemory gets called when configSUPPORT_STATIC_ALLOCATION
|
|
equals to 1 and is required for static memory allocation support.
|
|
*/
|
|
void vApplicationGetIdleTaskMemory (StaticTask_t **ppxIdleTaskTCBBuffer, StackType_t **ppxIdleTaskStackBuffer, uint32_t *pulIdleTaskStackSize) {
|
|
800505c: b580 push {r7, lr}
|
|
800505e: b084 sub sp, #16
|
|
8005060: af00 add r7, sp, #0
|
|
8005062: 60f8 str r0, [r7, #12]
|
|
8005064: 60b9 str r1, [r7, #8]
|
|
8005066: 607a str r2, [r7, #4]
|
|
*ppxIdleTaskTCBBuffer = &Idle_TCB;
|
|
8005068: 68fb ldr r3, [r7, #12]
|
|
800506a: 4a06 ldr r2, [pc, #24] ; (8005084 <vApplicationGetIdleTaskMemory+0x28>)
|
|
800506c: 601a str r2, [r3, #0]
|
|
*ppxIdleTaskStackBuffer = &Idle_Stack[0];
|
|
800506e: 68bb ldr r3, [r7, #8]
|
|
8005070: 4a05 ldr r2, [pc, #20] ; (8005088 <vApplicationGetIdleTaskMemory+0x2c>)
|
|
8005072: 601a str r2, [r3, #0]
|
|
*pulIdleTaskStackSize = (uint32_t)configMINIMAL_STACK_SIZE;
|
|
8005074: 687b ldr r3, [r7, #4]
|
|
8005076: 2280 movs r2, #128 ; 0x80
|
|
8005078: 601a str r2, [r3, #0]
|
|
}
|
|
800507a: 46c0 nop ; (mov r8, r8)
|
|
800507c: 46bd mov sp, r7
|
|
800507e: b004 add sp, #16
|
|
8005080: bd80 pop {r7, pc}
|
|
8005082: 46c0 nop ; (mov r8, r8)
|
|
8005084: 20000034 .word 0x20000034
|
|
8005088: 20000090 .word 0x20000090
|
|
|
|
0800508c <vApplicationGetTimerTaskMemory>:
|
|
|
|
/*
|
|
vApplicationGetTimerTaskMemory gets called when configSUPPORT_STATIC_ALLOCATION
|
|
equals to 1 and is required for static memory allocation support.
|
|
*/
|
|
void vApplicationGetTimerTaskMemory (StaticTask_t **ppxTimerTaskTCBBuffer, StackType_t **ppxTimerTaskStackBuffer, uint32_t *pulTimerTaskStackSize) {
|
|
800508c: b580 push {r7, lr}
|
|
800508e: b084 sub sp, #16
|
|
8005090: af00 add r7, sp, #0
|
|
8005092: 60f8 str r0, [r7, #12]
|
|
8005094: 60b9 str r1, [r7, #8]
|
|
8005096: 607a str r2, [r7, #4]
|
|
*ppxTimerTaskTCBBuffer = &Timer_TCB;
|
|
8005098: 68fb ldr r3, [r7, #12]
|
|
800509a: 4a06 ldr r2, [pc, #24] ; (80050b4 <vApplicationGetTimerTaskMemory+0x28>)
|
|
800509c: 601a str r2, [r3, #0]
|
|
*ppxTimerTaskStackBuffer = &Timer_Stack[0];
|
|
800509e: 68bb ldr r3, [r7, #8]
|
|
80050a0: 4a05 ldr r2, [pc, #20] ; (80050b8 <vApplicationGetTimerTaskMemory+0x2c>)
|
|
80050a2: 601a str r2, [r3, #0]
|
|
*pulTimerTaskStackSize = (uint32_t)configTIMER_TASK_STACK_DEPTH;
|
|
80050a4: 687b ldr r3, [r7, #4]
|
|
80050a6: 2280 movs r2, #128 ; 0x80
|
|
80050a8: 0052 lsls r2, r2, #1
|
|
80050aa: 601a str r2, [r3, #0]
|
|
}
|
|
80050ac: 46c0 nop ; (mov r8, r8)
|
|
80050ae: 46bd mov sp, r7
|
|
80050b0: b004 add sp, #16
|
|
80050b2: bd80 pop {r7, pc}
|
|
80050b4: 20000290 .word 0x20000290
|
|
80050b8: 200002ec .word 0x200002ec
|
|
|
|
080050bc <vListInitialise>:
|
|
/*-----------------------------------------------------------
|
|
* PUBLIC LIST API documented in list.h
|
|
*----------------------------------------------------------*/
|
|
|
|
void vListInitialise( List_t * const pxList )
|
|
{
|
|
80050bc: b580 push {r7, lr}
|
|
80050be: b082 sub sp, #8
|
|
80050c0: af00 add r7, sp, #0
|
|
80050c2: 6078 str r0, [r7, #4]
|
|
/* The list structure contains a list item which is used to mark the
|
|
end of the list. To initialise the list the list end is inserted
|
|
as the only list entry. */
|
|
pxList->pxIndex = ( ListItem_t * ) &( pxList->xListEnd ); /*lint !e826 !e740 !e9087 The mini list structure is used as the list end to save RAM. This is checked and valid. */
|
|
80050c4: 687b ldr r3, [r7, #4]
|
|
80050c6: 3308 adds r3, #8
|
|
80050c8: 001a movs r2, r3
|
|
80050ca: 687b ldr r3, [r7, #4]
|
|
80050cc: 605a str r2, [r3, #4]
|
|
|
|
/* The list end value is the highest possible value in the list to
|
|
ensure it remains at the end of the list. */
|
|
pxList->xListEnd.xItemValue = portMAX_DELAY;
|
|
80050ce: 687b ldr r3, [r7, #4]
|
|
80050d0: 2201 movs r2, #1
|
|
80050d2: 4252 negs r2, r2
|
|
80050d4: 609a str r2, [r3, #8]
|
|
|
|
/* The list end next and previous pointers point to itself so we know
|
|
when the list is empty. */
|
|
pxList->xListEnd.pxNext = ( ListItem_t * ) &( pxList->xListEnd ); /*lint !e826 !e740 !e9087 The mini list structure is used as the list end to save RAM. This is checked and valid. */
|
|
80050d6: 687b ldr r3, [r7, #4]
|
|
80050d8: 3308 adds r3, #8
|
|
80050da: 001a movs r2, r3
|
|
80050dc: 687b ldr r3, [r7, #4]
|
|
80050de: 60da str r2, [r3, #12]
|
|
pxList->xListEnd.pxPrevious = ( ListItem_t * ) &( pxList->xListEnd );/*lint !e826 !e740 !e9087 The mini list structure is used as the list end to save RAM. This is checked and valid. */
|
|
80050e0: 687b ldr r3, [r7, #4]
|
|
80050e2: 3308 adds r3, #8
|
|
80050e4: 001a movs r2, r3
|
|
80050e6: 687b ldr r3, [r7, #4]
|
|
80050e8: 611a str r2, [r3, #16]
|
|
|
|
pxList->uxNumberOfItems = ( UBaseType_t ) 0U;
|
|
80050ea: 687b ldr r3, [r7, #4]
|
|
80050ec: 2200 movs r2, #0
|
|
80050ee: 601a str r2, [r3, #0]
|
|
|
|
/* Write known values into the list if
|
|
configUSE_LIST_DATA_INTEGRITY_CHECK_BYTES is set to 1. */
|
|
listSET_LIST_INTEGRITY_CHECK_1_VALUE( pxList );
|
|
listSET_LIST_INTEGRITY_CHECK_2_VALUE( pxList );
|
|
}
|
|
80050f0: 46c0 nop ; (mov r8, r8)
|
|
80050f2: 46bd mov sp, r7
|
|
80050f4: b002 add sp, #8
|
|
80050f6: bd80 pop {r7, pc}
|
|
|
|
080050f8 <vListInitialiseItem>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
void vListInitialiseItem( ListItem_t * const pxItem )
|
|
{
|
|
80050f8: b580 push {r7, lr}
|
|
80050fa: b082 sub sp, #8
|
|
80050fc: af00 add r7, sp, #0
|
|
80050fe: 6078 str r0, [r7, #4]
|
|
/* Make sure the list item is not recorded as being on a list. */
|
|
pxItem->pxContainer = NULL;
|
|
8005100: 687b ldr r3, [r7, #4]
|
|
8005102: 2200 movs r2, #0
|
|
8005104: 611a str r2, [r3, #16]
|
|
|
|
/* Write known values into the list item if
|
|
configUSE_LIST_DATA_INTEGRITY_CHECK_BYTES is set to 1. */
|
|
listSET_FIRST_LIST_ITEM_INTEGRITY_CHECK_VALUE( pxItem );
|
|
listSET_SECOND_LIST_ITEM_INTEGRITY_CHECK_VALUE( pxItem );
|
|
}
|
|
8005106: 46c0 nop ; (mov r8, r8)
|
|
8005108: 46bd mov sp, r7
|
|
800510a: b002 add sp, #8
|
|
800510c: bd80 pop {r7, pc}
|
|
|
|
0800510e <vListInsertEnd>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
void vListInsertEnd( List_t * const pxList, ListItem_t * const pxNewListItem )
|
|
{
|
|
800510e: b580 push {r7, lr}
|
|
8005110: b084 sub sp, #16
|
|
8005112: af00 add r7, sp, #0
|
|
8005114: 6078 str r0, [r7, #4]
|
|
8005116: 6039 str r1, [r7, #0]
|
|
ListItem_t * const pxIndex = pxList->pxIndex;
|
|
8005118: 687b ldr r3, [r7, #4]
|
|
800511a: 685b ldr r3, [r3, #4]
|
|
800511c: 60fb str r3, [r7, #12]
|
|
listTEST_LIST_ITEM_INTEGRITY( pxNewListItem );
|
|
|
|
/* Insert a new list item into pxList, but rather than sort the list,
|
|
makes the new list item the last item to be removed by a call to
|
|
listGET_OWNER_OF_NEXT_ENTRY(). */
|
|
pxNewListItem->pxNext = pxIndex;
|
|
800511e: 683b ldr r3, [r7, #0]
|
|
8005120: 68fa ldr r2, [r7, #12]
|
|
8005122: 605a str r2, [r3, #4]
|
|
pxNewListItem->pxPrevious = pxIndex->pxPrevious;
|
|
8005124: 68fb ldr r3, [r7, #12]
|
|
8005126: 689a ldr r2, [r3, #8]
|
|
8005128: 683b ldr r3, [r7, #0]
|
|
800512a: 609a str r2, [r3, #8]
|
|
|
|
/* Only used during decision coverage testing. */
|
|
mtCOVERAGE_TEST_DELAY();
|
|
|
|
pxIndex->pxPrevious->pxNext = pxNewListItem;
|
|
800512c: 68fb ldr r3, [r7, #12]
|
|
800512e: 689b ldr r3, [r3, #8]
|
|
8005130: 683a ldr r2, [r7, #0]
|
|
8005132: 605a str r2, [r3, #4]
|
|
pxIndex->pxPrevious = pxNewListItem;
|
|
8005134: 68fb ldr r3, [r7, #12]
|
|
8005136: 683a ldr r2, [r7, #0]
|
|
8005138: 609a str r2, [r3, #8]
|
|
|
|
/* Remember which list the item is in. */
|
|
pxNewListItem->pxContainer = pxList;
|
|
800513a: 683b ldr r3, [r7, #0]
|
|
800513c: 687a ldr r2, [r7, #4]
|
|
800513e: 611a str r2, [r3, #16]
|
|
|
|
( pxList->uxNumberOfItems )++;
|
|
8005140: 687b ldr r3, [r7, #4]
|
|
8005142: 681b ldr r3, [r3, #0]
|
|
8005144: 1c5a adds r2, r3, #1
|
|
8005146: 687b ldr r3, [r7, #4]
|
|
8005148: 601a str r2, [r3, #0]
|
|
}
|
|
800514a: 46c0 nop ; (mov r8, r8)
|
|
800514c: 46bd mov sp, r7
|
|
800514e: b004 add sp, #16
|
|
8005150: bd80 pop {r7, pc}
|
|
|
|
08005152 <vListInsert>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
void vListInsert( List_t * const pxList, ListItem_t * const pxNewListItem )
|
|
{
|
|
8005152: b580 push {r7, lr}
|
|
8005154: b084 sub sp, #16
|
|
8005156: af00 add r7, sp, #0
|
|
8005158: 6078 str r0, [r7, #4]
|
|
800515a: 6039 str r1, [r7, #0]
|
|
ListItem_t *pxIterator;
|
|
const TickType_t xValueOfInsertion = pxNewListItem->xItemValue;
|
|
800515c: 683b ldr r3, [r7, #0]
|
|
800515e: 681b ldr r3, [r3, #0]
|
|
8005160: 60bb str r3, [r7, #8]
|
|
new list item should be placed after it. This ensures that TCBs which are
|
|
stored in ready lists (all of which have the same xItemValue value) get a
|
|
share of the CPU. However, if the xItemValue is the same as the back marker
|
|
the iteration loop below will not end. Therefore the value is checked
|
|
first, and the algorithm slightly modified if necessary. */
|
|
if( xValueOfInsertion == portMAX_DELAY )
|
|
8005162: 68bb ldr r3, [r7, #8]
|
|
8005164: 3301 adds r3, #1
|
|
8005166: d103 bne.n 8005170 <vListInsert+0x1e>
|
|
{
|
|
pxIterator = pxList->xListEnd.pxPrevious;
|
|
8005168: 687b ldr r3, [r7, #4]
|
|
800516a: 691b ldr r3, [r3, #16]
|
|
800516c: 60fb str r3, [r7, #12]
|
|
800516e: e00c b.n 800518a <vListInsert+0x38>
|
|
4) Using a queue or semaphore before it has been initialised or
|
|
before the scheduler has been started (are interrupts firing
|
|
before vTaskStartScheduler() has been called?).
|
|
**********************************************************************/
|
|
|
|
for( pxIterator = ( ListItem_t * ) &( pxList->xListEnd ); pxIterator->pxNext->xItemValue <= xValueOfInsertion; pxIterator = pxIterator->pxNext ) /*lint !e826 !e740 !e9087 The mini list structure is used as the list end to save RAM. This is checked and valid. *//*lint !e440 The iterator moves to a different value, not xValueOfInsertion. */
|
|
8005170: 687b ldr r3, [r7, #4]
|
|
8005172: 3308 adds r3, #8
|
|
8005174: 60fb str r3, [r7, #12]
|
|
8005176: e002 b.n 800517e <vListInsert+0x2c>
|
|
8005178: 68fb ldr r3, [r7, #12]
|
|
800517a: 685b ldr r3, [r3, #4]
|
|
800517c: 60fb str r3, [r7, #12]
|
|
800517e: 68fb ldr r3, [r7, #12]
|
|
8005180: 685b ldr r3, [r3, #4]
|
|
8005182: 681b ldr r3, [r3, #0]
|
|
8005184: 68ba ldr r2, [r7, #8]
|
|
8005186: 429a cmp r2, r3
|
|
8005188: d2f6 bcs.n 8005178 <vListInsert+0x26>
|
|
/* There is nothing to do here, just iterating to the wanted
|
|
insertion position. */
|
|
}
|
|
}
|
|
|
|
pxNewListItem->pxNext = pxIterator->pxNext;
|
|
800518a: 68fb ldr r3, [r7, #12]
|
|
800518c: 685a ldr r2, [r3, #4]
|
|
800518e: 683b ldr r3, [r7, #0]
|
|
8005190: 605a str r2, [r3, #4]
|
|
pxNewListItem->pxNext->pxPrevious = pxNewListItem;
|
|
8005192: 683b ldr r3, [r7, #0]
|
|
8005194: 685b ldr r3, [r3, #4]
|
|
8005196: 683a ldr r2, [r7, #0]
|
|
8005198: 609a str r2, [r3, #8]
|
|
pxNewListItem->pxPrevious = pxIterator;
|
|
800519a: 683b ldr r3, [r7, #0]
|
|
800519c: 68fa ldr r2, [r7, #12]
|
|
800519e: 609a str r2, [r3, #8]
|
|
pxIterator->pxNext = pxNewListItem;
|
|
80051a0: 68fb ldr r3, [r7, #12]
|
|
80051a2: 683a ldr r2, [r7, #0]
|
|
80051a4: 605a str r2, [r3, #4]
|
|
|
|
/* Remember which list the item is in. This allows fast removal of the
|
|
item later. */
|
|
pxNewListItem->pxContainer = pxList;
|
|
80051a6: 683b ldr r3, [r7, #0]
|
|
80051a8: 687a ldr r2, [r7, #4]
|
|
80051aa: 611a str r2, [r3, #16]
|
|
|
|
( pxList->uxNumberOfItems )++;
|
|
80051ac: 687b ldr r3, [r7, #4]
|
|
80051ae: 681b ldr r3, [r3, #0]
|
|
80051b0: 1c5a adds r2, r3, #1
|
|
80051b2: 687b ldr r3, [r7, #4]
|
|
80051b4: 601a str r2, [r3, #0]
|
|
}
|
|
80051b6: 46c0 nop ; (mov r8, r8)
|
|
80051b8: 46bd mov sp, r7
|
|
80051ba: b004 add sp, #16
|
|
80051bc: bd80 pop {r7, pc}
|
|
|
|
080051be <uxListRemove>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
UBaseType_t uxListRemove( ListItem_t * const pxItemToRemove )
|
|
{
|
|
80051be: b580 push {r7, lr}
|
|
80051c0: b084 sub sp, #16
|
|
80051c2: af00 add r7, sp, #0
|
|
80051c4: 6078 str r0, [r7, #4]
|
|
/* The list item knows which list it is in. Obtain the list from the list
|
|
item. */
|
|
List_t * const pxList = pxItemToRemove->pxContainer;
|
|
80051c6: 687b ldr r3, [r7, #4]
|
|
80051c8: 691b ldr r3, [r3, #16]
|
|
80051ca: 60fb str r3, [r7, #12]
|
|
|
|
pxItemToRemove->pxNext->pxPrevious = pxItemToRemove->pxPrevious;
|
|
80051cc: 687b ldr r3, [r7, #4]
|
|
80051ce: 685b ldr r3, [r3, #4]
|
|
80051d0: 687a ldr r2, [r7, #4]
|
|
80051d2: 6892 ldr r2, [r2, #8]
|
|
80051d4: 609a str r2, [r3, #8]
|
|
pxItemToRemove->pxPrevious->pxNext = pxItemToRemove->pxNext;
|
|
80051d6: 687b ldr r3, [r7, #4]
|
|
80051d8: 689b ldr r3, [r3, #8]
|
|
80051da: 687a ldr r2, [r7, #4]
|
|
80051dc: 6852 ldr r2, [r2, #4]
|
|
80051de: 605a str r2, [r3, #4]
|
|
|
|
/* Only used during decision coverage testing. */
|
|
mtCOVERAGE_TEST_DELAY();
|
|
|
|
/* Make sure the index is left pointing to a valid item. */
|
|
if( pxList->pxIndex == pxItemToRemove )
|
|
80051e0: 68fb ldr r3, [r7, #12]
|
|
80051e2: 685b ldr r3, [r3, #4]
|
|
80051e4: 687a ldr r2, [r7, #4]
|
|
80051e6: 429a cmp r2, r3
|
|
80051e8: d103 bne.n 80051f2 <uxListRemove+0x34>
|
|
{
|
|
pxList->pxIndex = pxItemToRemove->pxPrevious;
|
|
80051ea: 687b ldr r3, [r7, #4]
|
|
80051ec: 689a ldr r2, [r3, #8]
|
|
80051ee: 68fb ldr r3, [r7, #12]
|
|
80051f0: 605a str r2, [r3, #4]
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
pxItemToRemove->pxContainer = NULL;
|
|
80051f2: 687b ldr r3, [r7, #4]
|
|
80051f4: 2200 movs r2, #0
|
|
80051f6: 611a str r2, [r3, #16]
|
|
( pxList->uxNumberOfItems )--;
|
|
80051f8: 68fb ldr r3, [r7, #12]
|
|
80051fa: 681b ldr r3, [r3, #0]
|
|
80051fc: 1e5a subs r2, r3, #1
|
|
80051fe: 68fb ldr r3, [r7, #12]
|
|
8005200: 601a str r2, [r3, #0]
|
|
|
|
return pxList->uxNumberOfItems;
|
|
8005202: 68fb ldr r3, [r7, #12]
|
|
8005204: 681b ldr r3, [r3, #0]
|
|
}
|
|
8005206: 0018 movs r0, r3
|
|
8005208: 46bd mov sp, r7
|
|
800520a: b004 add sp, #16
|
|
800520c: bd80 pop {r7, pc}
|
|
|
|
0800520e <xQueueGenericReset>:
|
|
} \
|
|
taskEXIT_CRITICAL()
|
|
/*-----------------------------------------------------------*/
|
|
|
|
BaseType_t xQueueGenericReset( QueueHandle_t xQueue, BaseType_t xNewQueue )
|
|
{
|
|
800520e: b580 push {r7, lr}
|
|
8005210: b084 sub sp, #16
|
|
8005212: af00 add r7, sp, #0
|
|
8005214: 6078 str r0, [r7, #4]
|
|
8005216: 6039 str r1, [r7, #0]
|
|
Queue_t * const pxQueue = xQueue;
|
|
8005218: 687b ldr r3, [r7, #4]
|
|
800521a: 60fb str r3, [r7, #12]
|
|
|
|
configASSERT( pxQueue );
|
|
800521c: 68fb ldr r3, [r7, #12]
|
|
800521e: 2b00 cmp r3, #0
|
|
8005220: d101 bne.n 8005226 <xQueueGenericReset+0x18>
|
|
8005222: b672 cpsid i
|
|
8005224: e7fe b.n 8005224 <xQueueGenericReset+0x16>
|
|
|
|
taskENTER_CRITICAL();
|
|
8005226: f001 ff7b bl 8007120 <vPortEnterCritical>
|
|
{
|
|
pxQueue->u.xQueue.pcTail = pxQueue->pcHead + ( pxQueue->uxLength * pxQueue->uxItemSize ); /*lint !e9016 Pointer arithmetic allowed on char types, especially when it assists conveying intent. */
|
|
800522a: 68fb ldr r3, [r7, #12]
|
|
800522c: 681a ldr r2, [r3, #0]
|
|
800522e: 68fb ldr r3, [r7, #12]
|
|
8005230: 6bd9 ldr r1, [r3, #60] ; 0x3c
|
|
8005232: 68fb ldr r3, [r7, #12]
|
|
8005234: 6c1b ldr r3, [r3, #64] ; 0x40
|
|
8005236: 434b muls r3, r1
|
|
8005238: 18d2 adds r2, r2, r3
|
|
800523a: 68fb ldr r3, [r7, #12]
|
|
800523c: 609a str r2, [r3, #8]
|
|
pxQueue->uxMessagesWaiting = ( UBaseType_t ) 0U;
|
|
800523e: 68fb ldr r3, [r7, #12]
|
|
8005240: 2200 movs r2, #0
|
|
8005242: 639a str r2, [r3, #56] ; 0x38
|
|
pxQueue->pcWriteTo = pxQueue->pcHead;
|
|
8005244: 68fb ldr r3, [r7, #12]
|
|
8005246: 681a ldr r2, [r3, #0]
|
|
8005248: 68fb ldr r3, [r7, #12]
|
|
800524a: 605a str r2, [r3, #4]
|
|
pxQueue->u.xQueue.pcReadFrom = pxQueue->pcHead + ( ( pxQueue->uxLength - 1U ) * pxQueue->uxItemSize ); /*lint !e9016 Pointer arithmetic allowed on char types, especially when it assists conveying intent. */
|
|
800524c: 68fb ldr r3, [r7, #12]
|
|
800524e: 681a ldr r2, [r3, #0]
|
|
8005250: 68fb ldr r3, [r7, #12]
|
|
8005252: 6bdb ldr r3, [r3, #60] ; 0x3c
|
|
8005254: 1e59 subs r1, r3, #1
|
|
8005256: 68fb ldr r3, [r7, #12]
|
|
8005258: 6c1b ldr r3, [r3, #64] ; 0x40
|
|
800525a: 434b muls r3, r1
|
|
800525c: 18d2 adds r2, r2, r3
|
|
800525e: 68fb ldr r3, [r7, #12]
|
|
8005260: 60da str r2, [r3, #12]
|
|
pxQueue->cRxLock = queueUNLOCKED;
|
|
8005262: 68fb ldr r3, [r7, #12]
|
|
8005264: 2244 movs r2, #68 ; 0x44
|
|
8005266: 21ff movs r1, #255 ; 0xff
|
|
8005268: 5499 strb r1, [r3, r2]
|
|
pxQueue->cTxLock = queueUNLOCKED;
|
|
800526a: 68fb ldr r3, [r7, #12]
|
|
800526c: 2245 movs r2, #69 ; 0x45
|
|
800526e: 21ff movs r1, #255 ; 0xff
|
|
8005270: 5499 strb r1, [r3, r2]
|
|
|
|
if( xNewQueue == pdFALSE )
|
|
8005272: 683b ldr r3, [r7, #0]
|
|
8005274: 2b00 cmp r3, #0
|
|
8005276: d10d bne.n 8005294 <xQueueGenericReset+0x86>
|
|
/* If there are tasks blocked waiting to read from the queue, then
|
|
the tasks will remain blocked as after this function exits the queue
|
|
will still be empty. If there are tasks blocked waiting to write to
|
|
the queue, then one should be unblocked as after this function exits
|
|
it will be possible to write to it. */
|
|
if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToSend ) ) == pdFALSE )
|
|
8005278: 68fb ldr r3, [r7, #12]
|
|
800527a: 691b ldr r3, [r3, #16]
|
|
800527c: 2b00 cmp r3, #0
|
|
800527e: d013 beq.n 80052a8 <xQueueGenericReset+0x9a>
|
|
{
|
|
if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToSend ) ) != pdFALSE )
|
|
8005280: 68fb ldr r3, [r7, #12]
|
|
8005282: 3310 adds r3, #16
|
|
8005284: 0018 movs r0, r3
|
|
8005286: f001 f8d7 bl 8006438 <xTaskRemoveFromEventList>
|
|
800528a: 1e03 subs r3, r0, #0
|
|
800528c: d00c beq.n 80052a8 <xQueueGenericReset+0x9a>
|
|
{
|
|
queueYIELD_IF_USING_PREEMPTION();
|
|
800528e: f001 ff37 bl 8007100 <vPortYield>
|
|
8005292: e009 b.n 80052a8 <xQueueGenericReset+0x9a>
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* Ensure the event queues start in the correct state. */
|
|
vListInitialise( &( pxQueue->xTasksWaitingToSend ) );
|
|
8005294: 68fb ldr r3, [r7, #12]
|
|
8005296: 3310 adds r3, #16
|
|
8005298: 0018 movs r0, r3
|
|
800529a: f7ff ff0f bl 80050bc <vListInitialise>
|
|
vListInitialise( &( pxQueue->xTasksWaitingToReceive ) );
|
|
800529e: 68fb ldr r3, [r7, #12]
|
|
80052a0: 3324 adds r3, #36 ; 0x24
|
|
80052a2: 0018 movs r0, r3
|
|
80052a4: f7ff ff0a bl 80050bc <vListInitialise>
|
|
}
|
|
}
|
|
taskEXIT_CRITICAL();
|
|
80052a8: f001 ff4c bl 8007144 <vPortExitCritical>
|
|
|
|
/* A value is returned for calling semantic consistency with previous
|
|
versions. */
|
|
return pdPASS;
|
|
80052ac: 2301 movs r3, #1
|
|
}
|
|
80052ae: 0018 movs r0, r3
|
|
80052b0: 46bd mov sp, r7
|
|
80052b2: b004 add sp, #16
|
|
80052b4: bd80 pop {r7, pc}
|
|
|
|
080052b6 <xQueueGenericCreateStatic>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
#if( configSUPPORT_STATIC_ALLOCATION == 1 )
|
|
|
|
QueueHandle_t xQueueGenericCreateStatic( const UBaseType_t uxQueueLength, const UBaseType_t uxItemSize, uint8_t *pucQueueStorage, StaticQueue_t *pxStaticQueue, const uint8_t ucQueueType )
|
|
{
|
|
80052b6: b590 push {r4, r7, lr}
|
|
80052b8: b089 sub sp, #36 ; 0x24
|
|
80052ba: af02 add r7, sp, #8
|
|
80052bc: 60f8 str r0, [r7, #12]
|
|
80052be: 60b9 str r1, [r7, #8]
|
|
80052c0: 607a str r2, [r7, #4]
|
|
80052c2: 603b str r3, [r7, #0]
|
|
Queue_t *pxNewQueue;
|
|
|
|
configASSERT( uxQueueLength > ( UBaseType_t ) 0 );
|
|
80052c4: 68fb ldr r3, [r7, #12]
|
|
80052c6: 2b00 cmp r3, #0
|
|
80052c8: d101 bne.n 80052ce <xQueueGenericCreateStatic+0x18>
|
|
80052ca: b672 cpsid i
|
|
80052cc: e7fe b.n 80052cc <xQueueGenericCreateStatic+0x16>
|
|
|
|
/* The StaticQueue_t structure and the queue storage area must be
|
|
supplied. */
|
|
configASSERT( pxStaticQueue != NULL );
|
|
80052ce: 683b ldr r3, [r7, #0]
|
|
80052d0: 2b00 cmp r3, #0
|
|
80052d2: d101 bne.n 80052d8 <xQueueGenericCreateStatic+0x22>
|
|
80052d4: b672 cpsid i
|
|
80052d6: e7fe b.n 80052d6 <xQueueGenericCreateStatic+0x20>
|
|
|
|
/* A queue storage area should be provided if the item size is not 0, and
|
|
should not be provided if the item size is 0. */
|
|
configASSERT( !( ( pucQueueStorage != NULL ) && ( uxItemSize == 0 ) ) );
|
|
80052d8: 687b ldr r3, [r7, #4]
|
|
80052da: 2b00 cmp r3, #0
|
|
80052dc: d002 beq.n 80052e4 <xQueueGenericCreateStatic+0x2e>
|
|
80052de: 68bb ldr r3, [r7, #8]
|
|
80052e0: 2b00 cmp r3, #0
|
|
80052e2: d001 beq.n 80052e8 <xQueueGenericCreateStatic+0x32>
|
|
80052e4: 2301 movs r3, #1
|
|
80052e6: e000 b.n 80052ea <xQueueGenericCreateStatic+0x34>
|
|
80052e8: 2300 movs r3, #0
|
|
80052ea: 2b00 cmp r3, #0
|
|
80052ec: d101 bne.n 80052f2 <xQueueGenericCreateStatic+0x3c>
|
|
80052ee: b672 cpsid i
|
|
80052f0: e7fe b.n 80052f0 <xQueueGenericCreateStatic+0x3a>
|
|
configASSERT( !( ( pucQueueStorage == NULL ) && ( uxItemSize != 0 ) ) );
|
|
80052f2: 687b ldr r3, [r7, #4]
|
|
80052f4: 2b00 cmp r3, #0
|
|
80052f6: d102 bne.n 80052fe <xQueueGenericCreateStatic+0x48>
|
|
80052f8: 68bb ldr r3, [r7, #8]
|
|
80052fa: 2b00 cmp r3, #0
|
|
80052fc: d101 bne.n 8005302 <xQueueGenericCreateStatic+0x4c>
|
|
80052fe: 2301 movs r3, #1
|
|
8005300: e000 b.n 8005304 <xQueueGenericCreateStatic+0x4e>
|
|
8005302: 2300 movs r3, #0
|
|
8005304: 2b00 cmp r3, #0
|
|
8005306: d101 bne.n 800530c <xQueueGenericCreateStatic+0x56>
|
|
8005308: b672 cpsid i
|
|
800530a: e7fe b.n 800530a <xQueueGenericCreateStatic+0x54>
|
|
#if( configASSERT_DEFINED == 1 )
|
|
{
|
|
/* Sanity check that the size of the structure used to declare a
|
|
variable of type StaticQueue_t or StaticSemaphore_t equals the size of
|
|
the real queue and semaphore structures. */
|
|
volatile size_t xSize = sizeof( StaticQueue_t );
|
|
800530c: 2350 movs r3, #80 ; 0x50
|
|
800530e: 613b str r3, [r7, #16]
|
|
configASSERT( xSize == sizeof( Queue_t ) );
|
|
8005310: 693b ldr r3, [r7, #16]
|
|
8005312: 2b50 cmp r3, #80 ; 0x50
|
|
8005314: d001 beq.n 800531a <xQueueGenericCreateStatic+0x64>
|
|
8005316: b672 cpsid i
|
|
8005318: e7fe b.n 8005318 <xQueueGenericCreateStatic+0x62>
|
|
( void ) xSize; /* Keeps lint quiet when configASSERT() is not defined. */
|
|
800531a: 693b ldr r3, [r7, #16]
|
|
#endif /* configASSERT_DEFINED */
|
|
|
|
/* The address of a statically allocated queue was passed in, use it.
|
|
The address of a statically allocated storage area was also passed in
|
|
but is already set. */
|
|
pxNewQueue = ( Queue_t * ) pxStaticQueue; /*lint !e740 !e9087 Unusual cast is ok as the structures are designed to have the same alignment, and the size is checked by an assert. */
|
|
800531c: 683b ldr r3, [r7, #0]
|
|
800531e: 617b str r3, [r7, #20]
|
|
|
|
if( pxNewQueue != NULL )
|
|
8005320: 697b ldr r3, [r7, #20]
|
|
8005322: 2b00 cmp r3, #0
|
|
8005324: d00e beq.n 8005344 <xQueueGenericCreateStatic+0x8e>
|
|
#if( configSUPPORT_DYNAMIC_ALLOCATION == 1 )
|
|
{
|
|
/* Queues can be allocated wither statically or dynamically, so
|
|
note this queue was allocated statically in case the queue is
|
|
later deleted. */
|
|
pxNewQueue->ucStaticallyAllocated = pdTRUE;
|
|
8005326: 697b ldr r3, [r7, #20]
|
|
8005328: 2246 movs r2, #70 ; 0x46
|
|
800532a: 2101 movs r1, #1
|
|
800532c: 5499 strb r1, [r3, r2]
|
|
}
|
|
#endif /* configSUPPORT_DYNAMIC_ALLOCATION */
|
|
|
|
prvInitialiseNewQueue( uxQueueLength, uxItemSize, pucQueueStorage, ucQueueType, pxNewQueue );
|
|
800532e: 2328 movs r3, #40 ; 0x28
|
|
8005330: 18fb adds r3, r7, r3
|
|
8005332: 781c ldrb r4, [r3, #0]
|
|
8005334: 687a ldr r2, [r7, #4]
|
|
8005336: 68b9 ldr r1, [r7, #8]
|
|
8005338: 68f8 ldr r0, [r7, #12]
|
|
800533a: 697b ldr r3, [r7, #20]
|
|
800533c: 9300 str r3, [sp, #0]
|
|
800533e: 0023 movs r3, r4
|
|
8005340: f000 f83d bl 80053be <prvInitialiseNewQueue>
|
|
{
|
|
traceQUEUE_CREATE_FAILED( ucQueueType );
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
return pxNewQueue;
|
|
8005344: 697b ldr r3, [r7, #20]
|
|
}
|
|
8005346: 0018 movs r0, r3
|
|
8005348: 46bd mov sp, r7
|
|
800534a: b007 add sp, #28
|
|
800534c: bd90 pop {r4, r7, pc}
|
|
|
|
0800534e <xQueueGenericCreate>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
#if( configSUPPORT_DYNAMIC_ALLOCATION == 1 )
|
|
|
|
QueueHandle_t xQueueGenericCreate( const UBaseType_t uxQueueLength, const UBaseType_t uxItemSize, const uint8_t ucQueueType )
|
|
{
|
|
800534e: b590 push {r4, r7, lr}
|
|
8005350: b08b sub sp, #44 ; 0x2c
|
|
8005352: af02 add r7, sp, #8
|
|
8005354: 60f8 str r0, [r7, #12]
|
|
8005356: 60b9 str r1, [r7, #8]
|
|
8005358: 1dfb adds r3, r7, #7
|
|
800535a: 701a strb r2, [r3, #0]
|
|
Queue_t *pxNewQueue;
|
|
size_t xQueueSizeInBytes;
|
|
uint8_t *pucQueueStorage;
|
|
|
|
configASSERT( uxQueueLength > ( UBaseType_t ) 0 );
|
|
800535c: 68fb ldr r3, [r7, #12]
|
|
800535e: 2b00 cmp r3, #0
|
|
8005360: d101 bne.n 8005366 <xQueueGenericCreate+0x18>
|
|
8005362: b672 cpsid i
|
|
8005364: e7fe b.n 8005364 <xQueueGenericCreate+0x16>
|
|
|
|
if( uxItemSize == ( UBaseType_t ) 0 )
|
|
8005366: 68bb ldr r3, [r7, #8]
|
|
8005368: 2b00 cmp r3, #0
|
|
800536a: d102 bne.n 8005372 <xQueueGenericCreate+0x24>
|
|
{
|
|
/* There is not going to be a queue storage area. */
|
|
xQueueSizeInBytes = ( size_t ) 0;
|
|
800536c: 2300 movs r3, #0
|
|
800536e: 61fb str r3, [r7, #28]
|
|
8005370: e003 b.n 800537a <xQueueGenericCreate+0x2c>
|
|
}
|
|
else
|
|
{
|
|
/* Allocate enough space to hold the maximum number of items that
|
|
can be in the queue at any time. */
|
|
xQueueSizeInBytes = ( size_t ) ( uxQueueLength * uxItemSize ); /*lint !e961 MISRA exception as the casts are only redundant for some ports. */
|
|
8005372: 68fb ldr r3, [r7, #12]
|
|
8005374: 68ba ldr r2, [r7, #8]
|
|
8005376: 4353 muls r3, r2
|
|
8005378: 61fb str r3, [r7, #28]
|
|
alignment requirements of the Queue_t structure - which in this case
|
|
is an int8_t *. Therefore, whenever the stack alignment requirements
|
|
are greater than or equal to the pointer to char requirements the cast
|
|
is safe. In other cases alignment requirements are not strict (one or
|
|
two bytes). */
|
|
pxNewQueue = ( Queue_t * ) pvPortMalloc( sizeof( Queue_t ) + xQueueSizeInBytes ); /*lint !e9087 !e9079 see comment above. */
|
|
800537a: 69fb ldr r3, [r7, #28]
|
|
800537c: 3350 adds r3, #80 ; 0x50
|
|
800537e: 0018 movs r0, r3
|
|
8005380: f002 f84a bl 8007418 <pvPortMalloc>
|
|
8005384: 0003 movs r3, r0
|
|
8005386: 61bb str r3, [r7, #24]
|
|
|
|
if( pxNewQueue != NULL )
|
|
8005388: 69bb ldr r3, [r7, #24]
|
|
800538a: 2b00 cmp r3, #0
|
|
800538c: d012 beq.n 80053b4 <xQueueGenericCreate+0x66>
|
|
{
|
|
/* Jump past the queue structure to find the location of the queue
|
|
storage area. */
|
|
pucQueueStorage = ( uint8_t * ) pxNewQueue;
|
|
800538e: 69bb ldr r3, [r7, #24]
|
|
8005390: 617b str r3, [r7, #20]
|
|
pucQueueStorage += sizeof( Queue_t ); /*lint !e9016 Pointer arithmetic allowed on char types, especially when it assists conveying intent. */
|
|
8005392: 697b ldr r3, [r7, #20]
|
|
8005394: 3350 adds r3, #80 ; 0x50
|
|
8005396: 617b str r3, [r7, #20]
|
|
#if( configSUPPORT_STATIC_ALLOCATION == 1 )
|
|
{
|
|
/* Queues can be created either statically or dynamically, so
|
|
note this task was created dynamically in case it is later
|
|
deleted. */
|
|
pxNewQueue->ucStaticallyAllocated = pdFALSE;
|
|
8005398: 69bb ldr r3, [r7, #24]
|
|
800539a: 2246 movs r2, #70 ; 0x46
|
|
800539c: 2100 movs r1, #0
|
|
800539e: 5499 strb r1, [r3, r2]
|
|
}
|
|
#endif /* configSUPPORT_STATIC_ALLOCATION */
|
|
|
|
prvInitialiseNewQueue( uxQueueLength, uxItemSize, pucQueueStorage, ucQueueType, pxNewQueue );
|
|
80053a0: 1dfb adds r3, r7, #7
|
|
80053a2: 781c ldrb r4, [r3, #0]
|
|
80053a4: 697a ldr r2, [r7, #20]
|
|
80053a6: 68b9 ldr r1, [r7, #8]
|
|
80053a8: 68f8 ldr r0, [r7, #12]
|
|
80053aa: 69bb ldr r3, [r7, #24]
|
|
80053ac: 9300 str r3, [sp, #0]
|
|
80053ae: 0023 movs r3, r4
|
|
80053b0: f000 f805 bl 80053be <prvInitialiseNewQueue>
|
|
{
|
|
traceQUEUE_CREATE_FAILED( ucQueueType );
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
return pxNewQueue;
|
|
80053b4: 69bb ldr r3, [r7, #24]
|
|
}
|
|
80053b6: 0018 movs r0, r3
|
|
80053b8: 46bd mov sp, r7
|
|
80053ba: b009 add sp, #36 ; 0x24
|
|
80053bc: bd90 pop {r4, r7, pc}
|
|
|
|
080053be <prvInitialiseNewQueue>:
|
|
|
|
#endif /* configSUPPORT_STATIC_ALLOCATION */
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static void prvInitialiseNewQueue( const UBaseType_t uxQueueLength, const UBaseType_t uxItemSize, uint8_t *pucQueueStorage, const uint8_t ucQueueType, Queue_t *pxNewQueue )
|
|
{
|
|
80053be: b580 push {r7, lr}
|
|
80053c0: b084 sub sp, #16
|
|
80053c2: af00 add r7, sp, #0
|
|
80053c4: 60f8 str r0, [r7, #12]
|
|
80053c6: 60b9 str r1, [r7, #8]
|
|
80053c8: 607a str r2, [r7, #4]
|
|
80053ca: 001a movs r2, r3
|
|
80053cc: 1cfb adds r3, r7, #3
|
|
80053ce: 701a strb r2, [r3, #0]
|
|
/* Remove compiler warnings about unused parameters should
|
|
configUSE_TRACE_FACILITY not be set to 1. */
|
|
( void ) ucQueueType;
|
|
|
|
if( uxItemSize == ( UBaseType_t ) 0 )
|
|
80053d0: 68bb ldr r3, [r7, #8]
|
|
80053d2: 2b00 cmp r3, #0
|
|
80053d4: d103 bne.n 80053de <prvInitialiseNewQueue+0x20>
|
|
{
|
|
/* No RAM was allocated for the queue storage area, but PC head cannot
|
|
be set to NULL because NULL is used as a key to say the queue is used as
|
|
a mutex. Therefore just set pcHead to point to the queue as a benign
|
|
value that is known to be within the memory map. */
|
|
pxNewQueue->pcHead = ( int8_t * ) pxNewQueue;
|
|
80053d6: 69bb ldr r3, [r7, #24]
|
|
80053d8: 69ba ldr r2, [r7, #24]
|
|
80053da: 601a str r2, [r3, #0]
|
|
80053dc: e002 b.n 80053e4 <prvInitialiseNewQueue+0x26>
|
|
}
|
|
else
|
|
{
|
|
/* Set the head to the start of the queue storage area. */
|
|
pxNewQueue->pcHead = ( int8_t * ) pucQueueStorage;
|
|
80053de: 69bb ldr r3, [r7, #24]
|
|
80053e0: 687a ldr r2, [r7, #4]
|
|
80053e2: 601a str r2, [r3, #0]
|
|
}
|
|
|
|
/* Initialise the queue members as described where the queue type is
|
|
defined. */
|
|
pxNewQueue->uxLength = uxQueueLength;
|
|
80053e4: 69bb ldr r3, [r7, #24]
|
|
80053e6: 68fa ldr r2, [r7, #12]
|
|
80053e8: 63da str r2, [r3, #60] ; 0x3c
|
|
pxNewQueue->uxItemSize = uxItemSize;
|
|
80053ea: 69bb ldr r3, [r7, #24]
|
|
80053ec: 68ba ldr r2, [r7, #8]
|
|
80053ee: 641a str r2, [r3, #64] ; 0x40
|
|
( void ) xQueueGenericReset( pxNewQueue, pdTRUE );
|
|
80053f0: 69bb ldr r3, [r7, #24]
|
|
80053f2: 2101 movs r1, #1
|
|
80053f4: 0018 movs r0, r3
|
|
80053f6: f7ff ff0a bl 800520e <xQueueGenericReset>
|
|
|
|
#if ( configUSE_TRACE_FACILITY == 1 )
|
|
{
|
|
pxNewQueue->ucQueueType = ucQueueType;
|
|
80053fa: 69bb ldr r3, [r7, #24]
|
|
80053fc: 1cfa adds r2, r7, #3
|
|
80053fe: 214c movs r1, #76 ; 0x4c
|
|
8005400: 7812 ldrb r2, [r2, #0]
|
|
8005402: 545a strb r2, [r3, r1]
|
|
pxNewQueue->pxQueueSetContainer = NULL;
|
|
}
|
|
#endif /* configUSE_QUEUE_SETS */
|
|
|
|
traceQUEUE_CREATE( pxNewQueue );
|
|
}
|
|
8005404: 46c0 nop ; (mov r8, r8)
|
|
8005406: 46bd mov sp, r7
|
|
8005408: b004 add sp, #16
|
|
800540a: bd80 pop {r7, pc}
|
|
|
|
0800540c <xQueueGenericSend>:
|
|
|
|
#endif /* ( ( configUSE_COUNTING_SEMAPHORES == 1 ) && ( configSUPPORT_DYNAMIC_ALLOCATION == 1 ) ) */
|
|
/*-----------------------------------------------------------*/
|
|
|
|
BaseType_t xQueueGenericSend( QueueHandle_t xQueue, const void * const pvItemToQueue, TickType_t xTicksToWait, const BaseType_t xCopyPosition )
|
|
{
|
|
800540c: b580 push {r7, lr}
|
|
800540e: b08a sub sp, #40 ; 0x28
|
|
8005410: af00 add r7, sp, #0
|
|
8005412: 60f8 str r0, [r7, #12]
|
|
8005414: 60b9 str r1, [r7, #8]
|
|
8005416: 607a str r2, [r7, #4]
|
|
8005418: 603b str r3, [r7, #0]
|
|
BaseType_t xEntryTimeSet = pdFALSE, xYieldRequired;
|
|
800541a: 2300 movs r3, #0
|
|
800541c: 627b str r3, [r7, #36] ; 0x24
|
|
TimeOut_t xTimeOut;
|
|
Queue_t * const pxQueue = xQueue;
|
|
800541e: 68fb ldr r3, [r7, #12]
|
|
8005420: 623b str r3, [r7, #32]
|
|
|
|
configASSERT( pxQueue );
|
|
8005422: 6a3b ldr r3, [r7, #32]
|
|
8005424: 2b00 cmp r3, #0
|
|
8005426: d101 bne.n 800542c <xQueueGenericSend+0x20>
|
|
8005428: b672 cpsid i
|
|
800542a: e7fe b.n 800542a <xQueueGenericSend+0x1e>
|
|
configASSERT( !( ( pvItemToQueue == NULL ) && ( pxQueue->uxItemSize != ( UBaseType_t ) 0U ) ) );
|
|
800542c: 68bb ldr r3, [r7, #8]
|
|
800542e: 2b00 cmp r3, #0
|
|
8005430: d103 bne.n 800543a <xQueueGenericSend+0x2e>
|
|
8005432: 6a3b ldr r3, [r7, #32]
|
|
8005434: 6c1b ldr r3, [r3, #64] ; 0x40
|
|
8005436: 2b00 cmp r3, #0
|
|
8005438: d101 bne.n 800543e <xQueueGenericSend+0x32>
|
|
800543a: 2301 movs r3, #1
|
|
800543c: e000 b.n 8005440 <xQueueGenericSend+0x34>
|
|
800543e: 2300 movs r3, #0
|
|
8005440: 2b00 cmp r3, #0
|
|
8005442: d101 bne.n 8005448 <xQueueGenericSend+0x3c>
|
|
8005444: b672 cpsid i
|
|
8005446: e7fe b.n 8005446 <xQueueGenericSend+0x3a>
|
|
configASSERT( !( ( xCopyPosition == queueOVERWRITE ) && ( pxQueue->uxLength != 1 ) ) );
|
|
8005448: 683b ldr r3, [r7, #0]
|
|
800544a: 2b02 cmp r3, #2
|
|
800544c: d103 bne.n 8005456 <xQueueGenericSend+0x4a>
|
|
800544e: 6a3b ldr r3, [r7, #32]
|
|
8005450: 6bdb ldr r3, [r3, #60] ; 0x3c
|
|
8005452: 2b01 cmp r3, #1
|
|
8005454: d101 bne.n 800545a <xQueueGenericSend+0x4e>
|
|
8005456: 2301 movs r3, #1
|
|
8005458: e000 b.n 800545c <xQueueGenericSend+0x50>
|
|
800545a: 2300 movs r3, #0
|
|
800545c: 2b00 cmp r3, #0
|
|
800545e: d101 bne.n 8005464 <xQueueGenericSend+0x58>
|
|
8005460: b672 cpsid i
|
|
8005462: e7fe b.n 8005462 <xQueueGenericSend+0x56>
|
|
#if ( ( INCLUDE_xTaskGetSchedulerState == 1 ) || ( configUSE_TIMERS == 1 ) )
|
|
{
|
|
configASSERT( !( ( xTaskGetSchedulerState() == taskSCHEDULER_SUSPENDED ) && ( xTicksToWait != 0 ) ) );
|
|
8005464: f001 f9e0 bl 8006828 <xTaskGetSchedulerState>
|
|
8005468: 1e03 subs r3, r0, #0
|
|
800546a: d102 bne.n 8005472 <xQueueGenericSend+0x66>
|
|
800546c: 687b ldr r3, [r7, #4]
|
|
800546e: 2b00 cmp r3, #0
|
|
8005470: d101 bne.n 8005476 <xQueueGenericSend+0x6a>
|
|
8005472: 2301 movs r3, #1
|
|
8005474: e000 b.n 8005478 <xQueueGenericSend+0x6c>
|
|
8005476: 2300 movs r3, #0
|
|
8005478: 2b00 cmp r3, #0
|
|
800547a: d101 bne.n 8005480 <xQueueGenericSend+0x74>
|
|
800547c: b672 cpsid i
|
|
800547e: e7fe b.n 800547e <xQueueGenericSend+0x72>
|
|
/*lint -save -e904 This function relaxes the coding standard somewhat to
|
|
allow return statements within the function itself. This is done in the
|
|
interest of execution time efficiency. */
|
|
for( ;; )
|
|
{
|
|
taskENTER_CRITICAL();
|
|
8005480: f001 fe4e bl 8007120 <vPortEnterCritical>
|
|
{
|
|
/* Is there room on the queue now? The running task must be the
|
|
highest priority task wanting to access the queue. If the head item
|
|
in the queue is to be overwritten then it does not matter if the
|
|
queue is full. */
|
|
if( ( pxQueue->uxMessagesWaiting < pxQueue->uxLength ) || ( xCopyPosition == queueOVERWRITE ) )
|
|
8005484: 6a3b ldr r3, [r7, #32]
|
|
8005486: 6b9a ldr r2, [r3, #56] ; 0x38
|
|
8005488: 6a3b ldr r3, [r7, #32]
|
|
800548a: 6bdb ldr r3, [r3, #60] ; 0x3c
|
|
800548c: 429a cmp r2, r3
|
|
800548e: d302 bcc.n 8005496 <xQueueGenericSend+0x8a>
|
|
8005490: 683b ldr r3, [r7, #0]
|
|
8005492: 2b02 cmp r3, #2
|
|
8005494: d11e bne.n 80054d4 <xQueueGenericSend+0xc8>
|
|
}
|
|
}
|
|
}
|
|
#else /* configUSE_QUEUE_SETS */
|
|
{
|
|
xYieldRequired = prvCopyDataToQueue( pxQueue, pvItemToQueue, xCopyPosition );
|
|
8005496: 683a ldr r2, [r7, #0]
|
|
8005498: 68b9 ldr r1, [r7, #8]
|
|
800549a: 6a3b ldr r3, [r7, #32]
|
|
800549c: 0018 movs r0, r3
|
|
800549e: f000 f99f bl 80057e0 <prvCopyDataToQueue>
|
|
80054a2: 0003 movs r3, r0
|
|
80054a4: 61fb str r3, [r7, #28]
|
|
|
|
/* If there was a task waiting for data to arrive on the
|
|
queue then unblock it now. */
|
|
if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToReceive ) ) == pdFALSE )
|
|
80054a6: 6a3b ldr r3, [r7, #32]
|
|
80054a8: 6a5b ldr r3, [r3, #36] ; 0x24
|
|
80054aa: 2b00 cmp r3, #0
|
|
80054ac: d009 beq.n 80054c2 <xQueueGenericSend+0xb6>
|
|
{
|
|
if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToReceive ) ) != pdFALSE )
|
|
80054ae: 6a3b ldr r3, [r7, #32]
|
|
80054b0: 3324 adds r3, #36 ; 0x24
|
|
80054b2: 0018 movs r0, r3
|
|
80054b4: f000 ffc0 bl 8006438 <xTaskRemoveFromEventList>
|
|
80054b8: 1e03 subs r3, r0, #0
|
|
80054ba: d007 beq.n 80054cc <xQueueGenericSend+0xc0>
|
|
{
|
|
/* The unblocked task has a priority higher than
|
|
our own so yield immediately. Yes it is ok to do
|
|
this from within the critical section - the kernel
|
|
takes care of that. */
|
|
queueYIELD_IF_USING_PREEMPTION();
|
|
80054bc: f001 fe20 bl 8007100 <vPortYield>
|
|
80054c0: e004 b.n 80054cc <xQueueGenericSend+0xc0>
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
else if( xYieldRequired != pdFALSE )
|
|
80054c2: 69fb ldr r3, [r7, #28]
|
|
80054c4: 2b00 cmp r3, #0
|
|
80054c6: d001 beq.n 80054cc <xQueueGenericSend+0xc0>
|
|
{
|
|
/* This path is a special case that will only get
|
|
executed if the task was holding multiple mutexes and
|
|
the mutexes were given back in an order that is
|
|
different to that in which they were taken. */
|
|
queueYIELD_IF_USING_PREEMPTION();
|
|
80054c8: f001 fe1a bl 8007100 <vPortYield>
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
#endif /* configUSE_QUEUE_SETS */
|
|
|
|
taskEXIT_CRITICAL();
|
|
80054cc: f001 fe3a bl 8007144 <vPortExitCritical>
|
|
return pdPASS;
|
|
80054d0: 2301 movs r3, #1
|
|
80054d2: e05b b.n 800558c <xQueueGenericSend+0x180>
|
|
}
|
|
else
|
|
{
|
|
if( xTicksToWait == ( TickType_t ) 0 )
|
|
80054d4: 687b ldr r3, [r7, #4]
|
|
80054d6: 2b00 cmp r3, #0
|
|
80054d8: d103 bne.n 80054e2 <xQueueGenericSend+0xd6>
|
|
{
|
|
/* The queue was full and no block time is specified (or
|
|
the block time has expired) so leave now. */
|
|
taskEXIT_CRITICAL();
|
|
80054da: f001 fe33 bl 8007144 <vPortExitCritical>
|
|
|
|
/* Return to the original privilege level before exiting
|
|
the function. */
|
|
traceQUEUE_SEND_FAILED( pxQueue );
|
|
return errQUEUE_FULL;
|
|
80054de: 2300 movs r3, #0
|
|
80054e0: e054 b.n 800558c <xQueueGenericSend+0x180>
|
|
}
|
|
else if( xEntryTimeSet == pdFALSE )
|
|
80054e2: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
80054e4: 2b00 cmp r3, #0
|
|
80054e6: d106 bne.n 80054f6 <xQueueGenericSend+0xea>
|
|
{
|
|
/* The queue was full and a block time was specified so
|
|
configure the timeout structure. */
|
|
vTaskInternalSetTimeOutState( &xTimeOut );
|
|
80054e8: 2314 movs r3, #20
|
|
80054ea: 18fb adds r3, r7, r3
|
|
80054ec: 0018 movs r0, r3
|
|
80054ee: f001 f801 bl 80064f4 <vTaskInternalSetTimeOutState>
|
|
xEntryTimeSet = pdTRUE;
|
|
80054f2: 2301 movs r3, #1
|
|
80054f4: 627b str r3, [r7, #36] ; 0x24
|
|
/* Entry time was already set. */
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
}
|
|
taskEXIT_CRITICAL();
|
|
80054f6: f001 fe25 bl 8007144 <vPortExitCritical>
|
|
|
|
/* Interrupts and other tasks can send to and receive from the queue
|
|
now the critical section has been exited. */
|
|
|
|
vTaskSuspendAll();
|
|
80054fa: f000 fd5f bl 8005fbc <vTaskSuspendAll>
|
|
prvLockQueue( pxQueue );
|
|
80054fe: f001 fe0f bl 8007120 <vPortEnterCritical>
|
|
8005502: 6a3b ldr r3, [r7, #32]
|
|
8005504: 2244 movs r2, #68 ; 0x44
|
|
8005506: 5c9b ldrb r3, [r3, r2]
|
|
8005508: b25b sxtb r3, r3
|
|
800550a: 3301 adds r3, #1
|
|
800550c: d103 bne.n 8005516 <xQueueGenericSend+0x10a>
|
|
800550e: 6a3b ldr r3, [r7, #32]
|
|
8005510: 2244 movs r2, #68 ; 0x44
|
|
8005512: 2100 movs r1, #0
|
|
8005514: 5499 strb r1, [r3, r2]
|
|
8005516: 6a3b ldr r3, [r7, #32]
|
|
8005518: 2245 movs r2, #69 ; 0x45
|
|
800551a: 5c9b ldrb r3, [r3, r2]
|
|
800551c: b25b sxtb r3, r3
|
|
800551e: 3301 adds r3, #1
|
|
8005520: d103 bne.n 800552a <xQueueGenericSend+0x11e>
|
|
8005522: 6a3b ldr r3, [r7, #32]
|
|
8005524: 2245 movs r2, #69 ; 0x45
|
|
8005526: 2100 movs r1, #0
|
|
8005528: 5499 strb r1, [r3, r2]
|
|
800552a: f001 fe0b bl 8007144 <vPortExitCritical>
|
|
|
|
/* Update the timeout state to see if it has expired yet. */
|
|
if( xTaskCheckForTimeOut( &xTimeOut, &xTicksToWait ) == pdFALSE )
|
|
800552e: 1d3a adds r2, r7, #4
|
|
8005530: 2314 movs r3, #20
|
|
8005532: 18fb adds r3, r7, r3
|
|
8005534: 0011 movs r1, r2
|
|
8005536: 0018 movs r0, r3
|
|
8005538: f000 fff0 bl 800651c <xTaskCheckForTimeOut>
|
|
800553c: 1e03 subs r3, r0, #0
|
|
800553e: d11e bne.n 800557e <xQueueGenericSend+0x172>
|
|
{
|
|
if( prvIsQueueFull( pxQueue ) != pdFALSE )
|
|
8005540: 6a3b ldr r3, [r7, #32]
|
|
8005542: 0018 movs r0, r3
|
|
8005544: f000 fa51 bl 80059ea <prvIsQueueFull>
|
|
8005548: 1e03 subs r3, r0, #0
|
|
800554a: d011 beq.n 8005570 <xQueueGenericSend+0x164>
|
|
{
|
|
traceBLOCKING_ON_QUEUE_SEND( pxQueue );
|
|
vTaskPlaceOnEventList( &( pxQueue->xTasksWaitingToSend ), xTicksToWait );
|
|
800554c: 6a3b ldr r3, [r7, #32]
|
|
800554e: 3310 adds r3, #16
|
|
8005550: 687a ldr r2, [r7, #4]
|
|
8005552: 0011 movs r1, r2
|
|
8005554: 0018 movs r0, r3
|
|
8005556: f000 ff2b bl 80063b0 <vTaskPlaceOnEventList>
|
|
/* Unlocking the queue means queue events can effect the
|
|
event list. It is possible that interrupts occurring now
|
|
remove this task from the event list again - but as the
|
|
scheduler is suspended the task will go onto the pending
|
|
ready last instead of the actual ready list. */
|
|
prvUnlockQueue( pxQueue );
|
|
800555a: 6a3b ldr r3, [r7, #32]
|
|
800555c: 0018 movs r0, r3
|
|
800555e: f000 f9d0 bl 8005902 <prvUnlockQueue>
|
|
/* Resuming the scheduler will move tasks from the pending
|
|
ready list into the ready list - so it is feasible that this
|
|
task is already in a ready list before it yields - in which
|
|
case the yield will not cause a context switch unless there
|
|
is also a higher priority task in the pending ready list. */
|
|
if( xTaskResumeAll() == pdFALSE )
|
|
8005562: f000 fd6d bl 8006040 <xTaskResumeAll>
|
|
8005566: 1e03 subs r3, r0, #0
|
|
8005568: d18a bne.n 8005480 <xQueueGenericSend+0x74>
|
|
{
|
|
portYIELD_WITHIN_API();
|
|
800556a: f001 fdc9 bl 8007100 <vPortYield>
|
|
800556e: e787 b.n 8005480 <xQueueGenericSend+0x74>
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* Try again. */
|
|
prvUnlockQueue( pxQueue );
|
|
8005570: 6a3b ldr r3, [r7, #32]
|
|
8005572: 0018 movs r0, r3
|
|
8005574: f000 f9c5 bl 8005902 <prvUnlockQueue>
|
|
( void ) xTaskResumeAll();
|
|
8005578: f000 fd62 bl 8006040 <xTaskResumeAll>
|
|
800557c: e780 b.n 8005480 <xQueueGenericSend+0x74>
|
|
}
|
|
}
|
|
else
|
|
{
|
|
/* The timeout has expired. */
|
|
prvUnlockQueue( pxQueue );
|
|
800557e: 6a3b ldr r3, [r7, #32]
|
|
8005580: 0018 movs r0, r3
|
|
8005582: f000 f9be bl 8005902 <prvUnlockQueue>
|
|
( void ) xTaskResumeAll();
|
|
8005586: f000 fd5b bl 8006040 <xTaskResumeAll>
|
|
|
|
traceQUEUE_SEND_FAILED( pxQueue );
|
|
return errQUEUE_FULL;
|
|
800558a: 2300 movs r3, #0
|
|
}
|
|
} /*lint -restore */
|
|
}
|
|
800558c: 0018 movs r0, r3
|
|
800558e: 46bd mov sp, r7
|
|
8005590: b00a add sp, #40 ; 0x28
|
|
8005592: bd80 pop {r7, pc}
|
|
|
|
08005594 <xQueueGenericSendFromISR>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
BaseType_t xQueueGenericSendFromISR( QueueHandle_t xQueue, const void * const pvItemToQueue, BaseType_t * const pxHigherPriorityTaskWoken, const BaseType_t xCopyPosition )
|
|
{
|
|
8005594: b590 push {r4, r7, lr}
|
|
8005596: b089 sub sp, #36 ; 0x24
|
|
8005598: af00 add r7, sp, #0
|
|
800559a: 60f8 str r0, [r7, #12]
|
|
800559c: 60b9 str r1, [r7, #8]
|
|
800559e: 607a str r2, [r7, #4]
|
|
80055a0: 603b str r3, [r7, #0]
|
|
BaseType_t xReturn;
|
|
UBaseType_t uxSavedInterruptStatus;
|
|
Queue_t * const pxQueue = xQueue;
|
|
80055a2: 68fb ldr r3, [r7, #12]
|
|
80055a4: 61bb str r3, [r7, #24]
|
|
|
|
configASSERT( pxQueue );
|
|
80055a6: 69bb ldr r3, [r7, #24]
|
|
80055a8: 2b00 cmp r3, #0
|
|
80055aa: d101 bne.n 80055b0 <xQueueGenericSendFromISR+0x1c>
|
|
80055ac: b672 cpsid i
|
|
80055ae: e7fe b.n 80055ae <xQueueGenericSendFromISR+0x1a>
|
|
configASSERT( !( ( pvItemToQueue == NULL ) && ( pxQueue->uxItemSize != ( UBaseType_t ) 0U ) ) );
|
|
80055b0: 68bb ldr r3, [r7, #8]
|
|
80055b2: 2b00 cmp r3, #0
|
|
80055b4: d103 bne.n 80055be <xQueueGenericSendFromISR+0x2a>
|
|
80055b6: 69bb ldr r3, [r7, #24]
|
|
80055b8: 6c1b ldr r3, [r3, #64] ; 0x40
|
|
80055ba: 2b00 cmp r3, #0
|
|
80055bc: d101 bne.n 80055c2 <xQueueGenericSendFromISR+0x2e>
|
|
80055be: 2301 movs r3, #1
|
|
80055c0: e000 b.n 80055c4 <xQueueGenericSendFromISR+0x30>
|
|
80055c2: 2300 movs r3, #0
|
|
80055c4: 2b00 cmp r3, #0
|
|
80055c6: d101 bne.n 80055cc <xQueueGenericSendFromISR+0x38>
|
|
80055c8: b672 cpsid i
|
|
80055ca: e7fe b.n 80055ca <xQueueGenericSendFromISR+0x36>
|
|
configASSERT( !( ( xCopyPosition == queueOVERWRITE ) && ( pxQueue->uxLength != 1 ) ) );
|
|
80055cc: 683b ldr r3, [r7, #0]
|
|
80055ce: 2b02 cmp r3, #2
|
|
80055d0: d103 bne.n 80055da <xQueueGenericSendFromISR+0x46>
|
|
80055d2: 69bb ldr r3, [r7, #24]
|
|
80055d4: 6bdb ldr r3, [r3, #60] ; 0x3c
|
|
80055d6: 2b01 cmp r3, #1
|
|
80055d8: d101 bne.n 80055de <xQueueGenericSendFromISR+0x4a>
|
|
80055da: 2301 movs r3, #1
|
|
80055dc: e000 b.n 80055e0 <xQueueGenericSendFromISR+0x4c>
|
|
80055de: 2300 movs r3, #0
|
|
80055e0: 2b00 cmp r3, #0
|
|
80055e2: d101 bne.n 80055e8 <xQueueGenericSendFromISR+0x54>
|
|
80055e4: b672 cpsid i
|
|
80055e6: e7fe b.n 80055e6 <xQueueGenericSendFromISR+0x52>
|
|
/* Similar to xQueueGenericSend, except without blocking if there is no room
|
|
in the queue. Also don't directly wake a task that was blocked on a queue
|
|
read, instead return a flag to say whether a context switch is required or
|
|
not (i.e. has a task with a higher priority than us been woken by this
|
|
post). */
|
|
uxSavedInterruptStatus = portSET_INTERRUPT_MASK_FROM_ISR();
|
|
80055e8: f001 fdc4 bl 8007174 <ulSetInterruptMaskFromISR>
|
|
80055ec: 0003 movs r3, r0
|
|
80055ee: 617b str r3, [r7, #20]
|
|
{
|
|
if( ( pxQueue->uxMessagesWaiting < pxQueue->uxLength ) || ( xCopyPosition == queueOVERWRITE ) )
|
|
80055f0: 69bb ldr r3, [r7, #24]
|
|
80055f2: 6b9a ldr r2, [r3, #56] ; 0x38
|
|
80055f4: 69bb ldr r3, [r7, #24]
|
|
80055f6: 6bdb ldr r3, [r3, #60] ; 0x3c
|
|
80055f8: 429a cmp r2, r3
|
|
80055fa: d302 bcc.n 8005602 <xQueueGenericSendFromISR+0x6e>
|
|
80055fc: 683b ldr r3, [r7, #0]
|
|
80055fe: 2b02 cmp r3, #2
|
|
8005600: d12e bne.n 8005660 <xQueueGenericSendFromISR+0xcc>
|
|
{
|
|
const int8_t cTxLock = pxQueue->cTxLock;
|
|
8005602: 2413 movs r4, #19
|
|
8005604: 193b adds r3, r7, r4
|
|
8005606: 69ba ldr r2, [r7, #24]
|
|
8005608: 2145 movs r1, #69 ; 0x45
|
|
800560a: 5c52 ldrb r2, [r2, r1]
|
|
800560c: 701a strb r2, [r3, #0]
|
|
/* Semaphores use xQueueGiveFromISR(), so pxQueue will not be a
|
|
semaphore or mutex. That means prvCopyDataToQueue() cannot result
|
|
in a task disinheriting a priority and prvCopyDataToQueue() can be
|
|
called here even though the disinherit function does not check if
|
|
the scheduler is suspended before accessing the ready lists. */
|
|
( void ) prvCopyDataToQueue( pxQueue, pvItemToQueue, xCopyPosition );
|
|
800560e: 683a ldr r2, [r7, #0]
|
|
8005610: 68b9 ldr r1, [r7, #8]
|
|
8005612: 69bb ldr r3, [r7, #24]
|
|
8005614: 0018 movs r0, r3
|
|
8005616: f000 f8e3 bl 80057e0 <prvCopyDataToQueue>
|
|
|
|
/* The event list is not altered if the queue is locked. This will
|
|
be done when the queue is unlocked later. */
|
|
if( cTxLock == queueUNLOCKED )
|
|
800561a: 193b adds r3, r7, r4
|
|
800561c: 781b ldrb r3, [r3, #0]
|
|
800561e: b25b sxtb r3, r3
|
|
8005620: 3301 adds r3, #1
|
|
8005622: d111 bne.n 8005648 <xQueueGenericSendFromISR+0xb4>
|
|
}
|
|
}
|
|
}
|
|
#else /* configUSE_QUEUE_SETS */
|
|
{
|
|
if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToReceive ) ) == pdFALSE )
|
|
8005624: 69bb ldr r3, [r7, #24]
|
|
8005626: 6a5b ldr r3, [r3, #36] ; 0x24
|
|
8005628: 2b00 cmp r3, #0
|
|
800562a: d016 beq.n 800565a <xQueueGenericSendFromISR+0xc6>
|
|
{
|
|
if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToReceive ) ) != pdFALSE )
|
|
800562c: 69bb ldr r3, [r7, #24]
|
|
800562e: 3324 adds r3, #36 ; 0x24
|
|
8005630: 0018 movs r0, r3
|
|
8005632: f000 ff01 bl 8006438 <xTaskRemoveFromEventList>
|
|
8005636: 1e03 subs r3, r0, #0
|
|
8005638: d00f beq.n 800565a <xQueueGenericSendFromISR+0xc6>
|
|
{
|
|
/* The task waiting has a higher priority so record that a
|
|
context switch is required. */
|
|
if( pxHigherPriorityTaskWoken != NULL )
|
|
800563a: 687b ldr r3, [r7, #4]
|
|
800563c: 2b00 cmp r3, #0
|
|
800563e: d00c beq.n 800565a <xQueueGenericSendFromISR+0xc6>
|
|
{
|
|
*pxHigherPriorityTaskWoken = pdTRUE;
|
|
8005640: 687b ldr r3, [r7, #4]
|
|
8005642: 2201 movs r2, #1
|
|
8005644: 601a str r2, [r3, #0]
|
|
8005646: e008 b.n 800565a <xQueueGenericSendFromISR+0xc6>
|
|
}
|
|
else
|
|
{
|
|
/* Increment the lock count so the task that unlocks the queue
|
|
knows that data was posted while it was locked. */
|
|
pxQueue->cTxLock = ( int8_t ) ( cTxLock + 1 );
|
|
8005648: 2313 movs r3, #19
|
|
800564a: 18fb adds r3, r7, r3
|
|
800564c: 781b ldrb r3, [r3, #0]
|
|
800564e: 3301 adds r3, #1
|
|
8005650: b2db uxtb r3, r3
|
|
8005652: b259 sxtb r1, r3
|
|
8005654: 69bb ldr r3, [r7, #24]
|
|
8005656: 2245 movs r2, #69 ; 0x45
|
|
8005658: 5499 strb r1, [r3, r2]
|
|
}
|
|
|
|
xReturn = pdPASS;
|
|
800565a: 2301 movs r3, #1
|
|
800565c: 61fb str r3, [r7, #28]
|
|
{
|
|
800565e: e001 b.n 8005664 <xQueueGenericSendFromISR+0xd0>
|
|
}
|
|
else
|
|
{
|
|
traceQUEUE_SEND_FROM_ISR_FAILED( pxQueue );
|
|
xReturn = errQUEUE_FULL;
|
|
8005660: 2300 movs r3, #0
|
|
8005662: 61fb str r3, [r7, #28]
|
|
}
|
|
}
|
|
portCLEAR_INTERRUPT_MASK_FROM_ISR( uxSavedInterruptStatus );
|
|
8005664: 697b ldr r3, [r7, #20]
|
|
8005666: 0018 movs r0, r3
|
|
8005668: f001 fd8a bl 8007180 <vClearInterruptMaskFromISR>
|
|
|
|
return xReturn;
|
|
800566c: 69fb ldr r3, [r7, #28]
|
|
}
|
|
800566e: 0018 movs r0, r3
|
|
8005670: 46bd mov sp, r7
|
|
8005672: b009 add sp, #36 ; 0x24
|
|
8005674: bd90 pop {r4, r7, pc}
|
|
|
|
08005676 <xQueueReceive>:
|
|
return xReturn;
|
|
}
|
|
/*-----------------------------------------------------------*/
|
|
|
|
BaseType_t xQueueReceive( QueueHandle_t xQueue, void * const pvBuffer, TickType_t xTicksToWait )
|
|
{
|
|
8005676: b580 push {r7, lr}
|
|
8005678: b08a sub sp, #40 ; 0x28
|
|
800567a: af00 add r7, sp, #0
|
|
800567c: 60f8 str r0, [r7, #12]
|
|
800567e: 60b9 str r1, [r7, #8]
|
|
8005680: 607a str r2, [r7, #4]
|
|
BaseType_t xEntryTimeSet = pdFALSE;
|
|
8005682: 2300 movs r3, #0
|
|
8005684: 627b str r3, [r7, #36] ; 0x24
|
|
TimeOut_t xTimeOut;
|
|
Queue_t * const pxQueue = xQueue;
|
|
8005686: 68fb ldr r3, [r7, #12]
|
|
8005688: 623b str r3, [r7, #32]
|
|
|
|
/* Check the pointer is not NULL. */
|
|
configASSERT( ( pxQueue ) );
|
|
800568a: 6a3b ldr r3, [r7, #32]
|
|
800568c: 2b00 cmp r3, #0
|
|
800568e: d101 bne.n 8005694 <xQueueReceive+0x1e>
|
|
8005690: b672 cpsid i
|
|
8005692: e7fe b.n 8005692 <xQueueReceive+0x1c>
|
|
|
|
/* The buffer into which data is received can only be NULL if the data size
|
|
is zero (so no data is copied into the buffer. */
|
|
configASSERT( !( ( ( pvBuffer ) == NULL ) && ( ( pxQueue )->uxItemSize != ( UBaseType_t ) 0U ) ) );
|
|
8005694: 68bb ldr r3, [r7, #8]
|
|
8005696: 2b00 cmp r3, #0
|
|
8005698: d103 bne.n 80056a2 <xQueueReceive+0x2c>
|
|
800569a: 6a3b ldr r3, [r7, #32]
|
|
800569c: 6c1b ldr r3, [r3, #64] ; 0x40
|
|
800569e: 2b00 cmp r3, #0
|
|
80056a0: d101 bne.n 80056a6 <xQueueReceive+0x30>
|
|
80056a2: 2301 movs r3, #1
|
|
80056a4: e000 b.n 80056a8 <xQueueReceive+0x32>
|
|
80056a6: 2300 movs r3, #0
|
|
80056a8: 2b00 cmp r3, #0
|
|
80056aa: d101 bne.n 80056b0 <xQueueReceive+0x3a>
|
|
80056ac: b672 cpsid i
|
|
80056ae: e7fe b.n 80056ae <xQueueReceive+0x38>
|
|
|
|
/* Cannot block if the scheduler is suspended. */
|
|
#if ( ( INCLUDE_xTaskGetSchedulerState == 1 ) || ( configUSE_TIMERS == 1 ) )
|
|
{
|
|
configASSERT( !( ( xTaskGetSchedulerState() == taskSCHEDULER_SUSPENDED ) && ( xTicksToWait != 0 ) ) );
|
|
80056b0: f001 f8ba bl 8006828 <xTaskGetSchedulerState>
|
|
80056b4: 1e03 subs r3, r0, #0
|
|
80056b6: d102 bne.n 80056be <xQueueReceive+0x48>
|
|
80056b8: 687b ldr r3, [r7, #4]
|
|
80056ba: 2b00 cmp r3, #0
|
|
80056bc: d101 bne.n 80056c2 <xQueueReceive+0x4c>
|
|
80056be: 2301 movs r3, #1
|
|
80056c0: e000 b.n 80056c4 <xQueueReceive+0x4e>
|
|
80056c2: 2300 movs r3, #0
|
|
80056c4: 2b00 cmp r3, #0
|
|
80056c6: d101 bne.n 80056cc <xQueueReceive+0x56>
|
|
80056c8: b672 cpsid i
|
|
80056ca: e7fe b.n 80056ca <xQueueReceive+0x54>
|
|
/*lint -save -e904 This function relaxes the coding standard somewhat to
|
|
allow return statements within the function itself. This is done in the
|
|
interest of execution time efficiency. */
|
|
for( ;; )
|
|
{
|
|
taskENTER_CRITICAL();
|
|
80056cc: f001 fd28 bl 8007120 <vPortEnterCritical>
|
|
{
|
|
const UBaseType_t uxMessagesWaiting = pxQueue->uxMessagesWaiting;
|
|
80056d0: 6a3b ldr r3, [r7, #32]
|
|
80056d2: 6b9b ldr r3, [r3, #56] ; 0x38
|
|
80056d4: 61fb str r3, [r7, #28]
|
|
|
|
/* Is there data in the queue now? To be running the calling task
|
|
must be the highest priority task wanting to access the queue. */
|
|
if( uxMessagesWaiting > ( UBaseType_t ) 0 )
|
|
80056d6: 69fb ldr r3, [r7, #28]
|
|
80056d8: 2b00 cmp r3, #0
|
|
80056da: d01a beq.n 8005712 <xQueueReceive+0x9c>
|
|
{
|
|
/* Data available, remove one item. */
|
|
prvCopyDataFromQueue( pxQueue, pvBuffer );
|
|
80056dc: 68ba ldr r2, [r7, #8]
|
|
80056de: 6a3b ldr r3, [r7, #32]
|
|
80056e0: 0011 movs r1, r2
|
|
80056e2: 0018 movs r0, r3
|
|
80056e4: f000 f8e7 bl 80058b6 <prvCopyDataFromQueue>
|
|
traceQUEUE_RECEIVE( pxQueue );
|
|
pxQueue->uxMessagesWaiting = uxMessagesWaiting - ( UBaseType_t ) 1;
|
|
80056e8: 69fb ldr r3, [r7, #28]
|
|
80056ea: 1e5a subs r2, r3, #1
|
|
80056ec: 6a3b ldr r3, [r7, #32]
|
|
80056ee: 639a str r2, [r3, #56] ; 0x38
|
|
|
|
/* There is now space in the queue, were any tasks waiting to
|
|
post to the queue? If so, unblock the highest priority waiting
|
|
task. */
|
|
if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToSend ) ) == pdFALSE )
|
|
80056f0: 6a3b ldr r3, [r7, #32]
|
|
80056f2: 691b ldr r3, [r3, #16]
|
|
80056f4: 2b00 cmp r3, #0
|
|
80056f6: d008 beq.n 800570a <xQueueReceive+0x94>
|
|
{
|
|
if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToSend ) ) != pdFALSE )
|
|
80056f8: 6a3b ldr r3, [r7, #32]
|
|
80056fa: 3310 adds r3, #16
|
|
80056fc: 0018 movs r0, r3
|
|
80056fe: f000 fe9b bl 8006438 <xTaskRemoveFromEventList>
|
|
8005702: 1e03 subs r3, r0, #0
|
|
8005704: d001 beq.n 800570a <xQueueReceive+0x94>
|
|
{
|
|
queueYIELD_IF_USING_PREEMPTION();
|
|
8005706: f001 fcfb bl 8007100 <vPortYield>
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
taskEXIT_CRITICAL();
|
|
800570a: f001 fd1b bl 8007144 <vPortExitCritical>
|
|
return pdPASS;
|
|
800570e: 2301 movs r3, #1
|
|
8005710: e062 b.n 80057d8 <xQueueReceive+0x162>
|
|
}
|
|
else
|
|
{
|
|
if( xTicksToWait == ( TickType_t ) 0 )
|
|
8005712: 687b ldr r3, [r7, #4]
|
|
8005714: 2b00 cmp r3, #0
|
|
8005716: d103 bne.n 8005720 <xQueueReceive+0xaa>
|
|
{
|
|
/* The queue was empty and no block time is specified (or
|
|
the block time has expired) so leave now. */
|
|
taskEXIT_CRITICAL();
|
|
8005718: f001 fd14 bl 8007144 <vPortExitCritical>
|
|
traceQUEUE_RECEIVE_FAILED( pxQueue );
|
|
return errQUEUE_EMPTY;
|
|
800571c: 2300 movs r3, #0
|
|
800571e: e05b b.n 80057d8 <xQueueReceive+0x162>
|
|
}
|
|
else if( xEntryTimeSet == pdFALSE )
|
|
8005720: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
8005722: 2b00 cmp r3, #0
|
|
8005724: d106 bne.n 8005734 <xQueueReceive+0xbe>
|
|
{
|
|
/* The queue was empty and a block time was specified so
|
|
configure the timeout structure. */
|
|
vTaskInternalSetTimeOutState( &xTimeOut );
|
|
8005726: 2314 movs r3, #20
|
|
8005728: 18fb adds r3, r7, r3
|
|
800572a: 0018 movs r0, r3
|
|
800572c: f000 fee2 bl 80064f4 <vTaskInternalSetTimeOutState>
|
|
xEntryTimeSet = pdTRUE;
|
|
8005730: 2301 movs r3, #1
|
|
8005732: 627b str r3, [r7, #36] ; 0x24
|
|
/* Entry time was already set. */
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
}
|
|
taskEXIT_CRITICAL();
|
|
8005734: f001 fd06 bl 8007144 <vPortExitCritical>
|
|
|
|
/* Interrupts and other tasks can send to and receive from the queue
|
|
now the critical section has been exited. */
|
|
|
|
vTaskSuspendAll();
|
|
8005738: f000 fc40 bl 8005fbc <vTaskSuspendAll>
|
|
prvLockQueue( pxQueue );
|
|
800573c: f001 fcf0 bl 8007120 <vPortEnterCritical>
|
|
8005740: 6a3b ldr r3, [r7, #32]
|
|
8005742: 2244 movs r2, #68 ; 0x44
|
|
8005744: 5c9b ldrb r3, [r3, r2]
|
|
8005746: b25b sxtb r3, r3
|
|
8005748: 3301 adds r3, #1
|
|
800574a: d103 bne.n 8005754 <xQueueReceive+0xde>
|
|
800574c: 6a3b ldr r3, [r7, #32]
|
|
800574e: 2244 movs r2, #68 ; 0x44
|
|
8005750: 2100 movs r1, #0
|
|
8005752: 5499 strb r1, [r3, r2]
|
|
8005754: 6a3b ldr r3, [r7, #32]
|
|
8005756: 2245 movs r2, #69 ; 0x45
|
|
8005758: 5c9b ldrb r3, [r3, r2]
|
|
800575a: b25b sxtb r3, r3
|
|
800575c: 3301 adds r3, #1
|
|
800575e: d103 bne.n 8005768 <xQueueReceive+0xf2>
|
|
8005760: 6a3b ldr r3, [r7, #32]
|
|
8005762: 2245 movs r2, #69 ; 0x45
|
|
8005764: 2100 movs r1, #0
|
|
8005766: 5499 strb r1, [r3, r2]
|
|
8005768: f001 fcec bl 8007144 <vPortExitCritical>
|
|
|
|
/* Update the timeout state to see if it has expired yet. */
|
|
if( xTaskCheckForTimeOut( &xTimeOut, &xTicksToWait ) == pdFALSE )
|
|
800576c: 1d3a adds r2, r7, #4
|
|
800576e: 2314 movs r3, #20
|
|
8005770: 18fb adds r3, r7, r3
|
|
8005772: 0011 movs r1, r2
|
|
8005774: 0018 movs r0, r3
|
|
8005776: f000 fed1 bl 800651c <xTaskCheckForTimeOut>
|
|
800577a: 1e03 subs r3, r0, #0
|
|
800577c: d11e bne.n 80057bc <xQueueReceive+0x146>
|
|
{
|
|
/* The timeout has not expired. If the queue is still empty place
|
|
the task on the list of tasks waiting to receive from the queue. */
|
|
if( prvIsQueueEmpty( pxQueue ) != pdFALSE )
|
|
800577e: 6a3b ldr r3, [r7, #32]
|
|
8005780: 0018 movs r0, r3
|
|
8005782: f000 f91c bl 80059be <prvIsQueueEmpty>
|
|
8005786: 1e03 subs r3, r0, #0
|
|
8005788: d011 beq.n 80057ae <xQueueReceive+0x138>
|
|
{
|
|
traceBLOCKING_ON_QUEUE_RECEIVE( pxQueue );
|
|
vTaskPlaceOnEventList( &( pxQueue->xTasksWaitingToReceive ), xTicksToWait );
|
|
800578a: 6a3b ldr r3, [r7, #32]
|
|
800578c: 3324 adds r3, #36 ; 0x24
|
|
800578e: 687a ldr r2, [r7, #4]
|
|
8005790: 0011 movs r1, r2
|
|
8005792: 0018 movs r0, r3
|
|
8005794: f000 fe0c bl 80063b0 <vTaskPlaceOnEventList>
|
|
prvUnlockQueue( pxQueue );
|
|
8005798: 6a3b ldr r3, [r7, #32]
|
|
800579a: 0018 movs r0, r3
|
|
800579c: f000 f8b1 bl 8005902 <prvUnlockQueue>
|
|
if( xTaskResumeAll() == pdFALSE )
|
|
80057a0: f000 fc4e bl 8006040 <xTaskResumeAll>
|
|
80057a4: 1e03 subs r3, r0, #0
|
|
80057a6: d191 bne.n 80056cc <xQueueReceive+0x56>
|
|
{
|
|
portYIELD_WITHIN_API();
|
|
80057a8: f001 fcaa bl 8007100 <vPortYield>
|
|
80057ac: e78e b.n 80056cc <xQueueReceive+0x56>
|
|
}
|
|
else
|
|
{
|
|
/* The queue contains data again. Loop back to try and read the
|
|
data. */
|
|
prvUnlockQueue( pxQueue );
|
|
80057ae: 6a3b ldr r3, [r7, #32]
|
|
80057b0: 0018 movs r0, r3
|
|
80057b2: f000 f8a6 bl 8005902 <prvUnlockQueue>
|
|
( void ) xTaskResumeAll();
|
|
80057b6: f000 fc43 bl 8006040 <xTaskResumeAll>
|
|
80057ba: e787 b.n 80056cc <xQueueReceive+0x56>
|
|
}
|
|
else
|
|
{
|
|
/* Timed out. If there is no data in the queue exit, otherwise loop
|
|
back and attempt to read the data. */
|
|
prvUnlockQueue( pxQueue );
|
|
80057bc: 6a3b ldr r3, [r7, #32]
|
|
80057be: 0018 movs r0, r3
|
|
80057c0: f000 f89f bl 8005902 <prvUnlockQueue>
|
|
( void ) xTaskResumeAll();
|
|
80057c4: f000 fc3c bl 8006040 <xTaskResumeAll>
|
|
|
|
if( prvIsQueueEmpty( pxQueue ) != pdFALSE )
|
|
80057c8: 6a3b ldr r3, [r7, #32]
|
|
80057ca: 0018 movs r0, r3
|
|
80057cc: f000 f8f7 bl 80059be <prvIsQueueEmpty>
|
|
80057d0: 1e03 subs r3, r0, #0
|
|
80057d2: d100 bne.n 80057d6 <xQueueReceive+0x160>
|
|
80057d4: e77a b.n 80056cc <xQueueReceive+0x56>
|
|
{
|
|
traceQUEUE_RECEIVE_FAILED( pxQueue );
|
|
return errQUEUE_EMPTY;
|
|
80057d6: 2300 movs r3, #0
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
} /*lint -restore */
|
|
}
|
|
80057d8: 0018 movs r0, r3
|
|
80057da: 46bd mov sp, r7
|
|
80057dc: b00a add sp, #40 ; 0x28
|
|
80057de: bd80 pop {r7, pc}
|
|
|
|
080057e0 <prvCopyDataToQueue>:
|
|
|
|
#endif /* configUSE_MUTEXES */
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static BaseType_t prvCopyDataToQueue( Queue_t * const pxQueue, const void *pvItemToQueue, const BaseType_t xPosition )
|
|
{
|
|
80057e0: b580 push {r7, lr}
|
|
80057e2: b086 sub sp, #24
|
|
80057e4: af00 add r7, sp, #0
|
|
80057e6: 60f8 str r0, [r7, #12]
|
|
80057e8: 60b9 str r1, [r7, #8]
|
|
80057ea: 607a str r2, [r7, #4]
|
|
BaseType_t xReturn = pdFALSE;
|
|
80057ec: 2300 movs r3, #0
|
|
80057ee: 617b str r3, [r7, #20]
|
|
UBaseType_t uxMessagesWaiting;
|
|
|
|
/* This function is called from a critical section. */
|
|
|
|
uxMessagesWaiting = pxQueue->uxMessagesWaiting;
|
|
80057f0: 68fb ldr r3, [r7, #12]
|
|
80057f2: 6b9b ldr r3, [r3, #56] ; 0x38
|
|
80057f4: 613b str r3, [r7, #16]
|
|
|
|
if( pxQueue->uxItemSize == ( UBaseType_t ) 0 )
|
|
80057f6: 68fb ldr r3, [r7, #12]
|
|
80057f8: 6c1b ldr r3, [r3, #64] ; 0x40
|
|
80057fa: 2b00 cmp r3, #0
|
|
80057fc: d10e bne.n 800581c <prvCopyDataToQueue+0x3c>
|
|
{
|
|
#if ( configUSE_MUTEXES == 1 )
|
|
{
|
|
if( pxQueue->uxQueueType == queueQUEUE_IS_MUTEX )
|
|
80057fe: 68fb ldr r3, [r7, #12]
|
|
8005800: 681b ldr r3, [r3, #0]
|
|
8005802: 2b00 cmp r3, #0
|
|
8005804: d14e bne.n 80058a4 <prvCopyDataToQueue+0xc4>
|
|
{
|
|
/* The mutex is no longer being held. */
|
|
xReturn = xTaskPriorityDisinherit( pxQueue->u.xSemaphore.xMutexHolder );
|
|
8005806: 68fb ldr r3, [r7, #12]
|
|
8005808: 689b ldr r3, [r3, #8]
|
|
800580a: 0018 movs r0, r3
|
|
800580c: f001 f828 bl 8006860 <xTaskPriorityDisinherit>
|
|
8005810: 0003 movs r3, r0
|
|
8005812: 617b str r3, [r7, #20]
|
|
pxQueue->u.xSemaphore.xMutexHolder = NULL;
|
|
8005814: 68fb ldr r3, [r7, #12]
|
|
8005816: 2200 movs r2, #0
|
|
8005818: 609a str r2, [r3, #8]
|
|
800581a: e043 b.n 80058a4 <prvCopyDataToQueue+0xc4>
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
#endif /* configUSE_MUTEXES */
|
|
}
|
|
else if( xPosition == queueSEND_TO_BACK )
|
|
800581c: 687b ldr r3, [r7, #4]
|
|
800581e: 2b00 cmp r3, #0
|
|
8005820: d119 bne.n 8005856 <prvCopyDataToQueue+0x76>
|
|
{
|
|
( void ) memcpy( ( void * ) pxQueue->pcWriteTo, pvItemToQueue, ( size_t ) pxQueue->uxItemSize ); /*lint !e961 !e418 !e9087 MISRA exception as the casts are only redundant for some ports, plus previous logic ensures a null pointer can only be passed to memcpy() if the copy size is 0. Cast to void required by function signature and safe as no alignment requirement and copy length specified in bytes. */
|
|
8005822: 68fb ldr r3, [r7, #12]
|
|
8005824: 6858 ldr r0, [r3, #4]
|
|
8005826: 68fb ldr r3, [r7, #12]
|
|
8005828: 6c1a ldr r2, [r3, #64] ; 0x40
|
|
800582a: 68bb ldr r3, [r7, #8]
|
|
800582c: 0019 movs r1, r3
|
|
800582e: f001 ffbd bl 80077ac <memcpy>
|
|
pxQueue->pcWriteTo += pxQueue->uxItemSize; /*lint !e9016 Pointer arithmetic on char types ok, especially in this use case where it is the clearest way of conveying intent. */
|
|
8005832: 68fb ldr r3, [r7, #12]
|
|
8005834: 685a ldr r2, [r3, #4]
|
|
8005836: 68fb ldr r3, [r7, #12]
|
|
8005838: 6c1b ldr r3, [r3, #64] ; 0x40
|
|
800583a: 18d2 adds r2, r2, r3
|
|
800583c: 68fb ldr r3, [r7, #12]
|
|
800583e: 605a str r2, [r3, #4]
|
|
if( pxQueue->pcWriteTo >= pxQueue->u.xQueue.pcTail ) /*lint !e946 MISRA exception justified as comparison of pointers is the cleanest solution. */
|
|
8005840: 68fb ldr r3, [r7, #12]
|
|
8005842: 685a ldr r2, [r3, #4]
|
|
8005844: 68fb ldr r3, [r7, #12]
|
|
8005846: 689b ldr r3, [r3, #8]
|
|
8005848: 429a cmp r2, r3
|
|
800584a: d32b bcc.n 80058a4 <prvCopyDataToQueue+0xc4>
|
|
{
|
|
pxQueue->pcWriteTo = pxQueue->pcHead;
|
|
800584c: 68fb ldr r3, [r7, #12]
|
|
800584e: 681a ldr r2, [r3, #0]
|
|
8005850: 68fb ldr r3, [r7, #12]
|
|
8005852: 605a str r2, [r3, #4]
|
|
8005854: e026 b.n 80058a4 <prvCopyDataToQueue+0xc4>
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
else
|
|
{
|
|
( void ) memcpy( ( void * ) pxQueue->u.xQueue.pcReadFrom, pvItemToQueue, ( size_t ) pxQueue->uxItemSize ); /*lint !e961 !e9087 !e418 MISRA exception as the casts are only redundant for some ports. Cast to void required by function signature and safe as no alignment requirement and copy length specified in bytes. Assert checks null pointer only used when length is 0. */
|
|
8005856: 68fb ldr r3, [r7, #12]
|
|
8005858: 68d8 ldr r0, [r3, #12]
|
|
800585a: 68fb ldr r3, [r7, #12]
|
|
800585c: 6c1a ldr r2, [r3, #64] ; 0x40
|
|
800585e: 68bb ldr r3, [r7, #8]
|
|
8005860: 0019 movs r1, r3
|
|
8005862: f001 ffa3 bl 80077ac <memcpy>
|
|
pxQueue->u.xQueue.pcReadFrom -= pxQueue->uxItemSize;
|
|
8005866: 68fb ldr r3, [r7, #12]
|
|
8005868: 68da ldr r2, [r3, #12]
|
|
800586a: 68fb ldr r3, [r7, #12]
|
|
800586c: 6c1b ldr r3, [r3, #64] ; 0x40
|
|
800586e: 425b negs r3, r3
|
|
8005870: 18d2 adds r2, r2, r3
|
|
8005872: 68fb ldr r3, [r7, #12]
|
|
8005874: 60da str r2, [r3, #12]
|
|
if( pxQueue->u.xQueue.pcReadFrom < pxQueue->pcHead ) /*lint !e946 MISRA exception justified as comparison of pointers is the cleanest solution. */
|
|
8005876: 68fb ldr r3, [r7, #12]
|
|
8005878: 68da ldr r2, [r3, #12]
|
|
800587a: 68fb ldr r3, [r7, #12]
|
|
800587c: 681b ldr r3, [r3, #0]
|
|
800587e: 429a cmp r2, r3
|
|
8005880: d207 bcs.n 8005892 <prvCopyDataToQueue+0xb2>
|
|
{
|
|
pxQueue->u.xQueue.pcReadFrom = ( pxQueue->u.xQueue.pcTail - pxQueue->uxItemSize );
|
|
8005882: 68fb ldr r3, [r7, #12]
|
|
8005884: 689a ldr r2, [r3, #8]
|
|
8005886: 68fb ldr r3, [r7, #12]
|
|
8005888: 6c1b ldr r3, [r3, #64] ; 0x40
|
|
800588a: 425b negs r3, r3
|
|
800588c: 18d2 adds r2, r2, r3
|
|
800588e: 68fb ldr r3, [r7, #12]
|
|
8005890: 60da str r2, [r3, #12]
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
if( xPosition == queueOVERWRITE )
|
|
8005892: 687b ldr r3, [r7, #4]
|
|
8005894: 2b02 cmp r3, #2
|
|
8005896: d105 bne.n 80058a4 <prvCopyDataToQueue+0xc4>
|
|
{
|
|
if( uxMessagesWaiting > ( UBaseType_t ) 0 )
|
|
8005898: 693b ldr r3, [r7, #16]
|
|
800589a: 2b00 cmp r3, #0
|
|
800589c: d002 beq.n 80058a4 <prvCopyDataToQueue+0xc4>
|
|
{
|
|
/* An item is not being added but overwritten, so subtract
|
|
one from the recorded number of items in the queue so when
|
|
one is added again below the number of recorded items remains
|
|
correct. */
|
|
--uxMessagesWaiting;
|
|
800589e: 693b ldr r3, [r7, #16]
|
|
80058a0: 3b01 subs r3, #1
|
|
80058a2: 613b str r3, [r7, #16]
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
|
|
pxQueue->uxMessagesWaiting = uxMessagesWaiting + ( UBaseType_t ) 1;
|
|
80058a4: 693b ldr r3, [r7, #16]
|
|
80058a6: 1c5a adds r2, r3, #1
|
|
80058a8: 68fb ldr r3, [r7, #12]
|
|
80058aa: 639a str r2, [r3, #56] ; 0x38
|
|
|
|
return xReturn;
|
|
80058ac: 697b ldr r3, [r7, #20]
|
|
}
|
|
80058ae: 0018 movs r0, r3
|
|
80058b0: 46bd mov sp, r7
|
|
80058b2: b006 add sp, #24
|
|
80058b4: bd80 pop {r7, pc}
|
|
|
|
080058b6 <prvCopyDataFromQueue>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static void prvCopyDataFromQueue( Queue_t * const pxQueue, void * const pvBuffer )
|
|
{
|
|
80058b6: b580 push {r7, lr}
|
|
80058b8: b082 sub sp, #8
|
|
80058ba: af00 add r7, sp, #0
|
|
80058bc: 6078 str r0, [r7, #4]
|
|
80058be: 6039 str r1, [r7, #0]
|
|
if( pxQueue->uxItemSize != ( UBaseType_t ) 0 )
|
|
80058c0: 687b ldr r3, [r7, #4]
|
|
80058c2: 6c1b ldr r3, [r3, #64] ; 0x40
|
|
80058c4: 2b00 cmp r3, #0
|
|
80058c6: d018 beq.n 80058fa <prvCopyDataFromQueue+0x44>
|
|
{
|
|
pxQueue->u.xQueue.pcReadFrom += pxQueue->uxItemSize; /*lint !e9016 Pointer arithmetic on char types ok, especially in this use case where it is the clearest way of conveying intent. */
|
|
80058c8: 687b ldr r3, [r7, #4]
|
|
80058ca: 68da ldr r2, [r3, #12]
|
|
80058cc: 687b ldr r3, [r7, #4]
|
|
80058ce: 6c1b ldr r3, [r3, #64] ; 0x40
|
|
80058d0: 18d2 adds r2, r2, r3
|
|
80058d2: 687b ldr r3, [r7, #4]
|
|
80058d4: 60da str r2, [r3, #12]
|
|
if( pxQueue->u.xQueue.pcReadFrom >= pxQueue->u.xQueue.pcTail ) /*lint !e946 MISRA exception justified as use of the relational operator is the cleanest solutions. */
|
|
80058d6: 687b ldr r3, [r7, #4]
|
|
80058d8: 68da ldr r2, [r3, #12]
|
|
80058da: 687b ldr r3, [r7, #4]
|
|
80058dc: 689b ldr r3, [r3, #8]
|
|
80058de: 429a cmp r2, r3
|
|
80058e0: d303 bcc.n 80058ea <prvCopyDataFromQueue+0x34>
|
|
{
|
|
pxQueue->u.xQueue.pcReadFrom = pxQueue->pcHead;
|
|
80058e2: 687b ldr r3, [r7, #4]
|
|
80058e4: 681a ldr r2, [r3, #0]
|
|
80058e6: 687b ldr r3, [r7, #4]
|
|
80058e8: 60da str r2, [r3, #12]
|
|
}
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
( void ) memcpy( ( void * ) pvBuffer, ( void * ) pxQueue->u.xQueue.pcReadFrom, ( size_t ) pxQueue->uxItemSize ); /*lint !e961 !e418 !e9087 MISRA exception as the casts are only redundant for some ports. Also previous logic ensures a null pointer can only be passed to memcpy() when the count is 0. Cast to void required by function signature and safe as no alignment requirement and copy length specified in bytes. */
|
|
80058ea: 687b ldr r3, [r7, #4]
|
|
80058ec: 68d9 ldr r1, [r3, #12]
|
|
80058ee: 687b ldr r3, [r7, #4]
|
|
80058f0: 6c1a ldr r2, [r3, #64] ; 0x40
|
|
80058f2: 683b ldr r3, [r7, #0]
|
|
80058f4: 0018 movs r0, r3
|
|
80058f6: f001 ff59 bl 80077ac <memcpy>
|
|
}
|
|
}
|
|
80058fa: 46c0 nop ; (mov r8, r8)
|
|
80058fc: 46bd mov sp, r7
|
|
80058fe: b002 add sp, #8
|
|
8005900: bd80 pop {r7, pc}
|
|
|
|
08005902 <prvUnlockQueue>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static void prvUnlockQueue( Queue_t * const pxQueue )
|
|
{
|
|
8005902: b580 push {r7, lr}
|
|
8005904: b084 sub sp, #16
|
|
8005906: af00 add r7, sp, #0
|
|
8005908: 6078 str r0, [r7, #4]
|
|
|
|
/* The lock counts contains the number of extra data items placed or
|
|
removed from the queue while the queue was locked. When a queue is
|
|
locked items can be added or removed, but the event lists cannot be
|
|
updated. */
|
|
taskENTER_CRITICAL();
|
|
800590a: f001 fc09 bl 8007120 <vPortEnterCritical>
|
|
{
|
|
int8_t cTxLock = pxQueue->cTxLock;
|
|
800590e: 230f movs r3, #15
|
|
8005910: 18fb adds r3, r7, r3
|
|
8005912: 687a ldr r2, [r7, #4]
|
|
8005914: 2145 movs r1, #69 ; 0x45
|
|
8005916: 5c52 ldrb r2, [r2, r1]
|
|
8005918: 701a strb r2, [r3, #0]
|
|
|
|
/* See if data was added to the queue while it was locked. */
|
|
while( cTxLock > queueLOCKED_UNMODIFIED )
|
|
800591a: e013 b.n 8005944 <prvUnlockQueue+0x42>
|
|
}
|
|
#else /* configUSE_QUEUE_SETS */
|
|
{
|
|
/* Tasks that are removed from the event list will get added to
|
|
the pending ready list as the scheduler is still suspended. */
|
|
if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToReceive ) ) == pdFALSE )
|
|
800591c: 687b ldr r3, [r7, #4]
|
|
800591e: 6a5b ldr r3, [r3, #36] ; 0x24
|
|
8005920: 2b00 cmp r3, #0
|
|
8005922: d016 beq.n 8005952 <prvUnlockQueue+0x50>
|
|
{
|
|
if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToReceive ) ) != pdFALSE )
|
|
8005924: 687b ldr r3, [r7, #4]
|
|
8005926: 3324 adds r3, #36 ; 0x24
|
|
8005928: 0018 movs r0, r3
|
|
800592a: f000 fd85 bl 8006438 <xTaskRemoveFromEventList>
|
|
800592e: 1e03 subs r3, r0, #0
|
|
8005930: d001 beq.n 8005936 <prvUnlockQueue+0x34>
|
|
{
|
|
/* The task waiting has a higher priority so record that
|
|
a context switch is required. */
|
|
vTaskMissedYield();
|
|
8005932: f000 fe53 bl 80065dc <vTaskMissedYield>
|
|
break;
|
|
}
|
|
}
|
|
#endif /* configUSE_QUEUE_SETS */
|
|
|
|
--cTxLock;
|
|
8005936: 210f movs r1, #15
|
|
8005938: 187b adds r3, r7, r1
|
|
800593a: 781b ldrb r3, [r3, #0]
|
|
800593c: 3b01 subs r3, #1
|
|
800593e: b2da uxtb r2, r3
|
|
8005940: 187b adds r3, r7, r1
|
|
8005942: 701a strb r2, [r3, #0]
|
|
while( cTxLock > queueLOCKED_UNMODIFIED )
|
|
8005944: 230f movs r3, #15
|
|
8005946: 18fb adds r3, r7, r3
|
|
8005948: 781b ldrb r3, [r3, #0]
|
|
800594a: b25b sxtb r3, r3
|
|
800594c: 2b00 cmp r3, #0
|
|
800594e: dce5 bgt.n 800591c <prvUnlockQueue+0x1a>
|
|
8005950: e000 b.n 8005954 <prvUnlockQueue+0x52>
|
|
break;
|
|
8005952: 46c0 nop ; (mov r8, r8)
|
|
}
|
|
|
|
pxQueue->cTxLock = queueUNLOCKED;
|
|
8005954: 687b ldr r3, [r7, #4]
|
|
8005956: 2245 movs r2, #69 ; 0x45
|
|
8005958: 21ff movs r1, #255 ; 0xff
|
|
800595a: 5499 strb r1, [r3, r2]
|
|
}
|
|
taskEXIT_CRITICAL();
|
|
800595c: f001 fbf2 bl 8007144 <vPortExitCritical>
|
|
|
|
/* Do the same for the Rx lock. */
|
|
taskENTER_CRITICAL();
|
|
8005960: f001 fbde bl 8007120 <vPortEnterCritical>
|
|
{
|
|
int8_t cRxLock = pxQueue->cRxLock;
|
|
8005964: 230e movs r3, #14
|
|
8005966: 18fb adds r3, r7, r3
|
|
8005968: 687a ldr r2, [r7, #4]
|
|
800596a: 2144 movs r1, #68 ; 0x44
|
|
800596c: 5c52 ldrb r2, [r2, r1]
|
|
800596e: 701a strb r2, [r3, #0]
|
|
|
|
while( cRxLock > queueLOCKED_UNMODIFIED )
|
|
8005970: e013 b.n 800599a <prvUnlockQueue+0x98>
|
|
{
|
|
if( listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToSend ) ) == pdFALSE )
|
|
8005972: 687b ldr r3, [r7, #4]
|
|
8005974: 691b ldr r3, [r3, #16]
|
|
8005976: 2b00 cmp r3, #0
|
|
8005978: d016 beq.n 80059a8 <prvUnlockQueue+0xa6>
|
|
{
|
|
if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToSend ) ) != pdFALSE )
|
|
800597a: 687b ldr r3, [r7, #4]
|
|
800597c: 3310 adds r3, #16
|
|
800597e: 0018 movs r0, r3
|
|
8005980: f000 fd5a bl 8006438 <xTaskRemoveFromEventList>
|
|
8005984: 1e03 subs r3, r0, #0
|
|
8005986: d001 beq.n 800598c <prvUnlockQueue+0x8a>
|
|
{
|
|
vTaskMissedYield();
|
|
8005988: f000 fe28 bl 80065dc <vTaskMissedYield>
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
--cRxLock;
|
|
800598c: 210e movs r1, #14
|
|
800598e: 187b adds r3, r7, r1
|
|
8005990: 781b ldrb r3, [r3, #0]
|
|
8005992: 3b01 subs r3, #1
|
|
8005994: b2da uxtb r2, r3
|
|
8005996: 187b adds r3, r7, r1
|
|
8005998: 701a strb r2, [r3, #0]
|
|
while( cRxLock > queueLOCKED_UNMODIFIED )
|
|
800599a: 230e movs r3, #14
|
|
800599c: 18fb adds r3, r7, r3
|
|
800599e: 781b ldrb r3, [r3, #0]
|
|
80059a0: b25b sxtb r3, r3
|
|
80059a2: 2b00 cmp r3, #0
|
|
80059a4: dce5 bgt.n 8005972 <prvUnlockQueue+0x70>
|
|
80059a6: e000 b.n 80059aa <prvUnlockQueue+0xa8>
|
|
}
|
|
else
|
|
{
|
|
break;
|
|
80059a8: 46c0 nop ; (mov r8, r8)
|
|
}
|
|
}
|
|
|
|
pxQueue->cRxLock = queueUNLOCKED;
|
|
80059aa: 687b ldr r3, [r7, #4]
|
|
80059ac: 2244 movs r2, #68 ; 0x44
|
|
80059ae: 21ff movs r1, #255 ; 0xff
|
|
80059b0: 5499 strb r1, [r3, r2]
|
|
}
|
|
taskEXIT_CRITICAL();
|
|
80059b2: f001 fbc7 bl 8007144 <vPortExitCritical>
|
|
}
|
|
80059b6: 46c0 nop ; (mov r8, r8)
|
|
80059b8: 46bd mov sp, r7
|
|
80059ba: b004 add sp, #16
|
|
80059bc: bd80 pop {r7, pc}
|
|
|
|
080059be <prvIsQueueEmpty>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static BaseType_t prvIsQueueEmpty( const Queue_t *pxQueue )
|
|
{
|
|
80059be: b580 push {r7, lr}
|
|
80059c0: b084 sub sp, #16
|
|
80059c2: af00 add r7, sp, #0
|
|
80059c4: 6078 str r0, [r7, #4]
|
|
BaseType_t xReturn;
|
|
|
|
taskENTER_CRITICAL();
|
|
80059c6: f001 fbab bl 8007120 <vPortEnterCritical>
|
|
{
|
|
if( pxQueue->uxMessagesWaiting == ( UBaseType_t ) 0 )
|
|
80059ca: 687b ldr r3, [r7, #4]
|
|
80059cc: 6b9b ldr r3, [r3, #56] ; 0x38
|
|
80059ce: 2b00 cmp r3, #0
|
|
80059d0: d102 bne.n 80059d8 <prvIsQueueEmpty+0x1a>
|
|
{
|
|
xReturn = pdTRUE;
|
|
80059d2: 2301 movs r3, #1
|
|
80059d4: 60fb str r3, [r7, #12]
|
|
80059d6: e001 b.n 80059dc <prvIsQueueEmpty+0x1e>
|
|
}
|
|
else
|
|
{
|
|
xReturn = pdFALSE;
|
|
80059d8: 2300 movs r3, #0
|
|
80059da: 60fb str r3, [r7, #12]
|
|
}
|
|
}
|
|
taskEXIT_CRITICAL();
|
|
80059dc: f001 fbb2 bl 8007144 <vPortExitCritical>
|
|
|
|
return xReturn;
|
|
80059e0: 68fb ldr r3, [r7, #12]
|
|
}
|
|
80059e2: 0018 movs r0, r3
|
|
80059e4: 46bd mov sp, r7
|
|
80059e6: b004 add sp, #16
|
|
80059e8: bd80 pop {r7, pc}
|
|
|
|
080059ea <prvIsQueueFull>:
|
|
return xReturn;
|
|
} /*lint !e818 xQueue could not be pointer to const because it is a typedef. */
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static BaseType_t prvIsQueueFull( const Queue_t *pxQueue )
|
|
{
|
|
80059ea: b580 push {r7, lr}
|
|
80059ec: b084 sub sp, #16
|
|
80059ee: af00 add r7, sp, #0
|
|
80059f0: 6078 str r0, [r7, #4]
|
|
BaseType_t xReturn;
|
|
|
|
taskENTER_CRITICAL();
|
|
80059f2: f001 fb95 bl 8007120 <vPortEnterCritical>
|
|
{
|
|
if( pxQueue->uxMessagesWaiting == pxQueue->uxLength )
|
|
80059f6: 687b ldr r3, [r7, #4]
|
|
80059f8: 6b9a ldr r2, [r3, #56] ; 0x38
|
|
80059fa: 687b ldr r3, [r7, #4]
|
|
80059fc: 6bdb ldr r3, [r3, #60] ; 0x3c
|
|
80059fe: 429a cmp r2, r3
|
|
8005a00: d102 bne.n 8005a08 <prvIsQueueFull+0x1e>
|
|
{
|
|
xReturn = pdTRUE;
|
|
8005a02: 2301 movs r3, #1
|
|
8005a04: 60fb str r3, [r7, #12]
|
|
8005a06: e001 b.n 8005a0c <prvIsQueueFull+0x22>
|
|
}
|
|
else
|
|
{
|
|
xReturn = pdFALSE;
|
|
8005a08: 2300 movs r3, #0
|
|
8005a0a: 60fb str r3, [r7, #12]
|
|
}
|
|
}
|
|
taskEXIT_CRITICAL();
|
|
8005a0c: f001 fb9a bl 8007144 <vPortExitCritical>
|
|
|
|
return xReturn;
|
|
8005a10: 68fb ldr r3, [r7, #12]
|
|
}
|
|
8005a12: 0018 movs r0, r3
|
|
8005a14: 46bd mov sp, r7
|
|
8005a16: b004 add sp, #16
|
|
8005a18: bd80 pop {r7, pc}
|
|
...
|
|
|
|
08005a1c <vQueueAddToRegistry>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
#if ( configQUEUE_REGISTRY_SIZE > 0 )
|
|
|
|
void vQueueAddToRegistry( QueueHandle_t xQueue, const char *pcQueueName ) /*lint !e971 Unqualified char types are allowed for strings and single characters only. */
|
|
{
|
|
8005a1c: b580 push {r7, lr}
|
|
8005a1e: b084 sub sp, #16
|
|
8005a20: af00 add r7, sp, #0
|
|
8005a22: 6078 str r0, [r7, #4]
|
|
8005a24: 6039 str r1, [r7, #0]
|
|
UBaseType_t ux;
|
|
|
|
/* See if there is an empty space in the registry. A NULL name denotes
|
|
a free slot. */
|
|
for( ux = ( UBaseType_t ) 0U; ux < ( UBaseType_t ) configQUEUE_REGISTRY_SIZE; ux++ )
|
|
8005a26: 2300 movs r3, #0
|
|
8005a28: 60fb str r3, [r7, #12]
|
|
8005a2a: e015 b.n 8005a58 <vQueueAddToRegistry+0x3c>
|
|
{
|
|
if( xQueueRegistry[ ux ].pcQueueName == NULL )
|
|
8005a2c: 4b0e ldr r3, [pc, #56] ; (8005a68 <vQueueAddToRegistry+0x4c>)
|
|
8005a2e: 68fa ldr r2, [r7, #12]
|
|
8005a30: 00d2 lsls r2, r2, #3
|
|
8005a32: 58d3 ldr r3, [r2, r3]
|
|
8005a34: 2b00 cmp r3, #0
|
|
8005a36: d10c bne.n 8005a52 <vQueueAddToRegistry+0x36>
|
|
{
|
|
/* Store the information on this queue. */
|
|
xQueueRegistry[ ux ].pcQueueName = pcQueueName;
|
|
8005a38: 4b0b ldr r3, [pc, #44] ; (8005a68 <vQueueAddToRegistry+0x4c>)
|
|
8005a3a: 68fa ldr r2, [r7, #12]
|
|
8005a3c: 00d2 lsls r2, r2, #3
|
|
8005a3e: 6839 ldr r1, [r7, #0]
|
|
8005a40: 50d1 str r1, [r2, r3]
|
|
xQueueRegistry[ ux ].xHandle = xQueue;
|
|
8005a42: 4a09 ldr r2, [pc, #36] ; (8005a68 <vQueueAddToRegistry+0x4c>)
|
|
8005a44: 68fb ldr r3, [r7, #12]
|
|
8005a46: 00db lsls r3, r3, #3
|
|
8005a48: 18d3 adds r3, r2, r3
|
|
8005a4a: 3304 adds r3, #4
|
|
8005a4c: 687a ldr r2, [r7, #4]
|
|
8005a4e: 601a str r2, [r3, #0]
|
|
|
|
traceQUEUE_REGISTRY_ADD( xQueue, pcQueueName );
|
|
break;
|
|
8005a50: e006 b.n 8005a60 <vQueueAddToRegistry+0x44>
|
|
for( ux = ( UBaseType_t ) 0U; ux < ( UBaseType_t ) configQUEUE_REGISTRY_SIZE; ux++ )
|
|
8005a52: 68fb ldr r3, [r7, #12]
|
|
8005a54: 3301 adds r3, #1
|
|
8005a56: 60fb str r3, [r7, #12]
|
|
8005a58: 68fb ldr r3, [r7, #12]
|
|
8005a5a: 2b07 cmp r3, #7
|
|
8005a5c: d9e6 bls.n 8005a2c <vQueueAddToRegistry+0x10>
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
}
|
|
8005a5e: 46c0 nop ; (mov r8, r8)
|
|
8005a60: 46c0 nop ; (mov r8, r8)
|
|
8005a62: 46bd mov sp, r7
|
|
8005a64: b004 add sp, #16
|
|
8005a66: bd80 pop {r7, pc}
|
|
8005a68: 2000196c .word 0x2000196c
|
|
|
|
08005a6c <vQueueWaitForMessageRestricted>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
#if ( configUSE_TIMERS == 1 )
|
|
|
|
void vQueueWaitForMessageRestricted( QueueHandle_t xQueue, TickType_t xTicksToWait, const BaseType_t xWaitIndefinitely )
|
|
{
|
|
8005a6c: b580 push {r7, lr}
|
|
8005a6e: b086 sub sp, #24
|
|
8005a70: af00 add r7, sp, #0
|
|
8005a72: 60f8 str r0, [r7, #12]
|
|
8005a74: 60b9 str r1, [r7, #8]
|
|
8005a76: 607a str r2, [r7, #4]
|
|
Queue_t * const pxQueue = xQueue;
|
|
8005a78: 68fb ldr r3, [r7, #12]
|
|
8005a7a: 617b str r3, [r7, #20]
|
|
will not actually cause the task to block, just place it on a blocked
|
|
list. It will not block until the scheduler is unlocked - at which
|
|
time a yield will be performed. If an item is added to the queue while
|
|
the queue is locked, and the calling task blocks on the queue, then the
|
|
calling task will be immediately unblocked when the queue is unlocked. */
|
|
prvLockQueue( pxQueue );
|
|
8005a7c: f001 fb50 bl 8007120 <vPortEnterCritical>
|
|
8005a80: 697b ldr r3, [r7, #20]
|
|
8005a82: 2244 movs r2, #68 ; 0x44
|
|
8005a84: 5c9b ldrb r3, [r3, r2]
|
|
8005a86: b25b sxtb r3, r3
|
|
8005a88: 3301 adds r3, #1
|
|
8005a8a: d103 bne.n 8005a94 <vQueueWaitForMessageRestricted+0x28>
|
|
8005a8c: 697b ldr r3, [r7, #20]
|
|
8005a8e: 2244 movs r2, #68 ; 0x44
|
|
8005a90: 2100 movs r1, #0
|
|
8005a92: 5499 strb r1, [r3, r2]
|
|
8005a94: 697b ldr r3, [r7, #20]
|
|
8005a96: 2245 movs r2, #69 ; 0x45
|
|
8005a98: 5c9b ldrb r3, [r3, r2]
|
|
8005a9a: b25b sxtb r3, r3
|
|
8005a9c: 3301 adds r3, #1
|
|
8005a9e: d103 bne.n 8005aa8 <vQueueWaitForMessageRestricted+0x3c>
|
|
8005aa0: 697b ldr r3, [r7, #20]
|
|
8005aa2: 2245 movs r2, #69 ; 0x45
|
|
8005aa4: 2100 movs r1, #0
|
|
8005aa6: 5499 strb r1, [r3, r2]
|
|
8005aa8: f001 fb4c bl 8007144 <vPortExitCritical>
|
|
if( pxQueue->uxMessagesWaiting == ( UBaseType_t ) 0U )
|
|
8005aac: 697b ldr r3, [r7, #20]
|
|
8005aae: 6b9b ldr r3, [r3, #56] ; 0x38
|
|
8005ab0: 2b00 cmp r3, #0
|
|
8005ab2: d106 bne.n 8005ac2 <vQueueWaitForMessageRestricted+0x56>
|
|
{
|
|
/* There is nothing in the queue, block for the specified period. */
|
|
vTaskPlaceOnEventListRestricted( &( pxQueue->xTasksWaitingToReceive ), xTicksToWait, xWaitIndefinitely );
|
|
8005ab4: 697b ldr r3, [r7, #20]
|
|
8005ab6: 3324 adds r3, #36 ; 0x24
|
|
8005ab8: 687a ldr r2, [r7, #4]
|
|
8005aba: 68b9 ldr r1, [r7, #8]
|
|
8005abc: 0018 movs r0, r3
|
|
8005abe: f000 fc95 bl 80063ec <vTaskPlaceOnEventListRestricted>
|
|
}
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
prvUnlockQueue( pxQueue );
|
|
8005ac2: 697b ldr r3, [r7, #20]
|
|
8005ac4: 0018 movs r0, r3
|
|
8005ac6: f7ff ff1c bl 8005902 <prvUnlockQueue>
|
|
}
|
|
8005aca: 46c0 nop ; (mov r8, r8)
|
|
8005acc: 46bd mov sp, r7
|
|
8005ace: b006 add sp, #24
|
|
8005ad0: bd80 pop {r7, pc}
|
|
|
|
08005ad2 <xTaskCreateStatic>:
|
|
const uint32_t ulStackDepth,
|
|
void * const pvParameters,
|
|
UBaseType_t uxPriority,
|
|
StackType_t * const puxStackBuffer,
|
|
StaticTask_t * const pxTaskBuffer )
|
|
{
|
|
8005ad2: b590 push {r4, r7, lr}
|
|
8005ad4: b08d sub sp, #52 ; 0x34
|
|
8005ad6: af04 add r7, sp, #16
|
|
8005ad8: 60f8 str r0, [r7, #12]
|
|
8005ada: 60b9 str r1, [r7, #8]
|
|
8005adc: 607a str r2, [r7, #4]
|
|
8005ade: 603b str r3, [r7, #0]
|
|
TCB_t *pxNewTCB;
|
|
TaskHandle_t xReturn;
|
|
|
|
configASSERT( puxStackBuffer != NULL );
|
|
8005ae0: 6b7b ldr r3, [r7, #52] ; 0x34
|
|
8005ae2: 2b00 cmp r3, #0
|
|
8005ae4: d101 bne.n 8005aea <xTaskCreateStatic+0x18>
|
|
8005ae6: b672 cpsid i
|
|
8005ae8: e7fe b.n 8005ae8 <xTaskCreateStatic+0x16>
|
|
configASSERT( pxTaskBuffer != NULL );
|
|
8005aea: 6bbb ldr r3, [r7, #56] ; 0x38
|
|
8005aec: 2b00 cmp r3, #0
|
|
8005aee: d101 bne.n 8005af4 <xTaskCreateStatic+0x22>
|
|
8005af0: b672 cpsid i
|
|
8005af2: e7fe b.n 8005af2 <xTaskCreateStatic+0x20>
|
|
#if( configASSERT_DEFINED == 1 )
|
|
{
|
|
/* Sanity check that the size of the structure used to declare a
|
|
variable of type StaticTask_t equals the size of the real task
|
|
structure. */
|
|
volatile size_t xSize = sizeof( StaticTask_t );
|
|
8005af4: 235c movs r3, #92 ; 0x5c
|
|
8005af6: 617b str r3, [r7, #20]
|
|
configASSERT( xSize == sizeof( TCB_t ) );
|
|
8005af8: 697b ldr r3, [r7, #20]
|
|
8005afa: 2b5c cmp r3, #92 ; 0x5c
|
|
8005afc: d001 beq.n 8005b02 <xTaskCreateStatic+0x30>
|
|
8005afe: b672 cpsid i
|
|
8005b00: e7fe b.n 8005b00 <xTaskCreateStatic+0x2e>
|
|
( void ) xSize; /* Prevent lint warning when configASSERT() is not used. */
|
|
8005b02: 697b ldr r3, [r7, #20]
|
|
}
|
|
#endif /* configASSERT_DEFINED */
|
|
|
|
|
|
if( ( pxTaskBuffer != NULL ) && ( puxStackBuffer != NULL ) )
|
|
8005b04: 6bbb ldr r3, [r7, #56] ; 0x38
|
|
8005b06: 2b00 cmp r3, #0
|
|
8005b08: d020 beq.n 8005b4c <xTaskCreateStatic+0x7a>
|
|
8005b0a: 6b7b ldr r3, [r7, #52] ; 0x34
|
|
8005b0c: 2b00 cmp r3, #0
|
|
8005b0e: d01d beq.n 8005b4c <xTaskCreateStatic+0x7a>
|
|
{
|
|
/* The memory used for the task's TCB and stack are passed into this
|
|
function - use them. */
|
|
pxNewTCB = ( TCB_t * ) pxTaskBuffer; /*lint !e740 !e9087 Unusual cast is ok as the structures are designed to have the same alignment, and the size is checked by an assert. */
|
|
8005b10: 6bbb ldr r3, [r7, #56] ; 0x38
|
|
8005b12: 61fb str r3, [r7, #28]
|
|
pxNewTCB->pxStack = ( StackType_t * ) puxStackBuffer;
|
|
8005b14: 69fb ldr r3, [r7, #28]
|
|
8005b16: 6b7a ldr r2, [r7, #52] ; 0x34
|
|
8005b18: 631a str r2, [r3, #48] ; 0x30
|
|
|
|
#if( tskSTATIC_AND_DYNAMIC_ALLOCATION_POSSIBLE != 0 ) /*lint !e731 !e9029 Macro has been consolidated for readability reasons. */
|
|
{
|
|
/* Tasks can be created statically or dynamically, so note this
|
|
task was created statically in case the task is later deleted. */
|
|
pxNewTCB->ucStaticallyAllocated = tskSTATICALLY_ALLOCATED_STACK_AND_TCB;
|
|
8005b1a: 69fb ldr r3, [r7, #28]
|
|
8005b1c: 2259 movs r2, #89 ; 0x59
|
|
8005b1e: 2102 movs r1, #2
|
|
8005b20: 5499 strb r1, [r3, r2]
|
|
}
|
|
#endif /* tskSTATIC_AND_DYNAMIC_ALLOCATION_POSSIBLE */
|
|
|
|
prvInitialiseNewTask( pxTaskCode, pcName, ulStackDepth, pvParameters, uxPriority, &xReturn, pxNewTCB, NULL );
|
|
8005b22: 683c ldr r4, [r7, #0]
|
|
8005b24: 687a ldr r2, [r7, #4]
|
|
8005b26: 68b9 ldr r1, [r7, #8]
|
|
8005b28: 68f8 ldr r0, [r7, #12]
|
|
8005b2a: 2300 movs r3, #0
|
|
8005b2c: 9303 str r3, [sp, #12]
|
|
8005b2e: 69fb ldr r3, [r7, #28]
|
|
8005b30: 9302 str r3, [sp, #8]
|
|
8005b32: 2318 movs r3, #24
|
|
8005b34: 18fb adds r3, r7, r3
|
|
8005b36: 9301 str r3, [sp, #4]
|
|
8005b38: 6b3b ldr r3, [r7, #48] ; 0x30
|
|
8005b3a: 9300 str r3, [sp, #0]
|
|
8005b3c: 0023 movs r3, r4
|
|
8005b3e: f000 f859 bl 8005bf4 <prvInitialiseNewTask>
|
|
prvAddNewTaskToReadyList( pxNewTCB );
|
|
8005b42: 69fb ldr r3, [r7, #28]
|
|
8005b44: 0018 movs r0, r3
|
|
8005b46: f000 f8e3 bl 8005d10 <prvAddNewTaskToReadyList>
|
|
8005b4a: e001 b.n 8005b50 <xTaskCreateStatic+0x7e>
|
|
}
|
|
else
|
|
{
|
|
xReturn = NULL;
|
|
8005b4c: 2300 movs r3, #0
|
|
8005b4e: 61bb str r3, [r7, #24]
|
|
}
|
|
|
|
return xReturn;
|
|
8005b50: 69bb ldr r3, [r7, #24]
|
|
}
|
|
8005b52: 0018 movs r0, r3
|
|
8005b54: 46bd mov sp, r7
|
|
8005b56: b009 add sp, #36 ; 0x24
|
|
8005b58: bd90 pop {r4, r7, pc}
|
|
|
|
08005b5a <xTaskCreate>:
|
|
const char * const pcName, /*lint !e971 Unqualified char types are allowed for strings and single characters only. */
|
|
const configSTACK_DEPTH_TYPE usStackDepth,
|
|
void * const pvParameters,
|
|
UBaseType_t uxPriority,
|
|
TaskHandle_t * const pxCreatedTask )
|
|
{
|
|
8005b5a: b590 push {r4, r7, lr}
|
|
8005b5c: b08d sub sp, #52 ; 0x34
|
|
8005b5e: af04 add r7, sp, #16
|
|
8005b60: 60f8 str r0, [r7, #12]
|
|
8005b62: 60b9 str r1, [r7, #8]
|
|
8005b64: 603b str r3, [r7, #0]
|
|
8005b66: 1dbb adds r3, r7, #6
|
|
8005b68: 801a strh r2, [r3, #0]
|
|
#else /* portSTACK_GROWTH */
|
|
{
|
|
StackType_t *pxStack;
|
|
|
|
/* Allocate space for the stack used by the task being created. */
|
|
pxStack = pvPortMalloc( ( ( ( size_t ) usStackDepth ) * sizeof( StackType_t ) ) ); /*lint !e9079 All values returned by pvPortMalloc() have at least the alignment required by the MCU's stack and this allocation is the stack. */
|
|
8005b6a: 1dbb adds r3, r7, #6
|
|
8005b6c: 881b ldrh r3, [r3, #0]
|
|
8005b6e: 009b lsls r3, r3, #2
|
|
8005b70: 0018 movs r0, r3
|
|
8005b72: f001 fc51 bl 8007418 <pvPortMalloc>
|
|
8005b76: 0003 movs r3, r0
|
|
8005b78: 617b str r3, [r7, #20]
|
|
|
|
if( pxStack != NULL )
|
|
8005b7a: 697b ldr r3, [r7, #20]
|
|
8005b7c: 2b00 cmp r3, #0
|
|
8005b7e: d010 beq.n 8005ba2 <xTaskCreate+0x48>
|
|
{
|
|
/* Allocate space for the TCB. */
|
|
pxNewTCB = ( TCB_t * ) pvPortMalloc( sizeof( TCB_t ) ); /*lint !e9087 !e9079 All values returned by pvPortMalloc() have at least the alignment required by the MCU's stack, and the first member of TCB_t is always a pointer to the task's stack. */
|
|
8005b80: 205c movs r0, #92 ; 0x5c
|
|
8005b82: f001 fc49 bl 8007418 <pvPortMalloc>
|
|
8005b86: 0003 movs r3, r0
|
|
8005b88: 61fb str r3, [r7, #28]
|
|
|
|
if( pxNewTCB != NULL )
|
|
8005b8a: 69fb ldr r3, [r7, #28]
|
|
8005b8c: 2b00 cmp r3, #0
|
|
8005b8e: d003 beq.n 8005b98 <xTaskCreate+0x3e>
|
|
{
|
|
/* Store the stack location in the TCB. */
|
|
pxNewTCB->pxStack = pxStack;
|
|
8005b90: 69fb ldr r3, [r7, #28]
|
|
8005b92: 697a ldr r2, [r7, #20]
|
|
8005b94: 631a str r2, [r3, #48] ; 0x30
|
|
8005b96: e006 b.n 8005ba6 <xTaskCreate+0x4c>
|
|
}
|
|
else
|
|
{
|
|
/* The stack cannot be used as the TCB was not created. Free
|
|
it again. */
|
|
vPortFree( pxStack );
|
|
8005b98: 697b ldr r3, [r7, #20]
|
|
8005b9a: 0018 movs r0, r3
|
|
8005b9c: f001 fce2 bl 8007564 <vPortFree>
|
|
8005ba0: e001 b.n 8005ba6 <xTaskCreate+0x4c>
|
|
}
|
|
}
|
|
else
|
|
{
|
|
pxNewTCB = NULL;
|
|
8005ba2: 2300 movs r3, #0
|
|
8005ba4: 61fb str r3, [r7, #28]
|
|
}
|
|
}
|
|
#endif /* portSTACK_GROWTH */
|
|
|
|
if( pxNewTCB != NULL )
|
|
8005ba6: 69fb ldr r3, [r7, #28]
|
|
8005ba8: 2b00 cmp r3, #0
|
|
8005baa: d01a beq.n 8005be2 <xTaskCreate+0x88>
|
|
{
|
|
#if( tskSTATIC_AND_DYNAMIC_ALLOCATION_POSSIBLE != 0 ) /*lint !e9029 !e731 Macro has been consolidated for readability reasons. */
|
|
{
|
|
/* Tasks can be created statically or dynamically, so note this
|
|
task was created dynamically in case it is later deleted. */
|
|
pxNewTCB->ucStaticallyAllocated = tskDYNAMICALLY_ALLOCATED_STACK_AND_TCB;
|
|
8005bac: 69fb ldr r3, [r7, #28]
|
|
8005bae: 2259 movs r2, #89 ; 0x59
|
|
8005bb0: 2100 movs r1, #0
|
|
8005bb2: 5499 strb r1, [r3, r2]
|
|
}
|
|
#endif /* tskSTATIC_AND_DYNAMIC_ALLOCATION_POSSIBLE */
|
|
|
|
prvInitialiseNewTask( pxTaskCode, pcName, ( uint32_t ) usStackDepth, pvParameters, uxPriority, pxCreatedTask, pxNewTCB, NULL );
|
|
8005bb4: 1dbb adds r3, r7, #6
|
|
8005bb6: 881a ldrh r2, [r3, #0]
|
|
8005bb8: 683c ldr r4, [r7, #0]
|
|
8005bba: 68b9 ldr r1, [r7, #8]
|
|
8005bbc: 68f8 ldr r0, [r7, #12]
|
|
8005bbe: 2300 movs r3, #0
|
|
8005bc0: 9303 str r3, [sp, #12]
|
|
8005bc2: 69fb ldr r3, [r7, #28]
|
|
8005bc4: 9302 str r3, [sp, #8]
|
|
8005bc6: 6b7b ldr r3, [r7, #52] ; 0x34
|
|
8005bc8: 9301 str r3, [sp, #4]
|
|
8005bca: 6b3b ldr r3, [r7, #48] ; 0x30
|
|
8005bcc: 9300 str r3, [sp, #0]
|
|
8005bce: 0023 movs r3, r4
|
|
8005bd0: f000 f810 bl 8005bf4 <prvInitialiseNewTask>
|
|
prvAddNewTaskToReadyList( pxNewTCB );
|
|
8005bd4: 69fb ldr r3, [r7, #28]
|
|
8005bd6: 0018 movs r0, r3
|
|
8005bd8: f000 f89a bl 8005d10 <prvAddNewTaskToReadyList>
|
|
xReturn = pdPASS;
|
|
8005bdc: 2301 movs r3, #1
|
|
8005bde: 61bb str r3, [r7, #24]
|
|
8005be0: e002 b.n 8005be8 <xTaskCreate+0x8e>
|
|
}
|
|
else
|
|
{
|
|
xReturn = errCOULD_NOT_ALLOCATE_REQUIRED_MEMORY;
|
|
8005be2: 2301 movs r3, #1
|
|
8005be4: 425b negs r3, r3
|
|
8005be6: 61bb str r3, [r7, #24]
|
|
}
|
|
|
|
return xReturn;
|
|
8005be8: 69bb ldr r3, [r7, #24]
|
|
}
|
|
8005bea: 0018 movs r0, r3
|
|
8005bec: 46bd mov sp, r7
|
|
8005bee: b009 add sp, #36 ; 0x24
|
|
8005bf0: bd90 pop {r4, r7, pc}
|
|
...
|
|
|
|
08005bf4 <prvInitialiseNewTask>:
|
|
void * const pvParameters,
|
|
UBaseType_t uxPriority,
|
|
TaskHandle_t * const pxCreatedTask,
|
|
TCB_t *pxNewTCB,
|
|
const MemoryRegion_t * const xRegions )
|
|
{
|
|
8005bf4: b580 push {r7, lr}
|
|
8005bf6: b086 sub sp, #24
|
|
8005bf8: af00 add r7, sp, #0
|
|
8005bfa: 60f8 str r0, [r7, #12]
|
|
8005bfc: 60b9 str r1, [r7, #8]
|
|
8005bfe: 607a str r2, [r7, #4]
|
|
8005c00: 603b str r3, [r7, #0]
|
|
|
|
/* Avoid dependency on memset() if it is not required. */
|
|
#if( tskSET_NEW_STACKS_TO_KNOWN_VALUE == 1 )
|
|
{
|
|
/* Fill the stack with a known value to assist debugging. */
|
|
( void ) memset( pxNewTCB->pxStack, ( int ) tskSTACK_FILL_BYTE, ( size_t ) ulStackDepth * sizeof( StackType_t ) );
|
|
8005c02: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8005c04: 6b18 ldr r0, [r3, #48] ; 0x30
|
|
8005c06: 687b ldr r3, [r7, #4]
|
|
8005c08: 009b lsls r3, r3, #2
|
|
8005c0a: 001a movs r2, r3
|
|
8005c0c: 21a5 movs r1, #165 ; 0xa5
|
|
8005c0e: f001 fdd6 bl 80077be <memset>
|
|
grows from high memory to low (as per the 80x86) or vice versa.
|
|
portSTACK_GROWTH is used to make the result positive or negative as required
|
|
by the port. */
|
|
#if( portSTACK_GROWTH < 0 )
|
|
{
|
|
pxTopOfStack = &( pxNewTCB->pxStack[ ulStackDepth - ( uint32_t ) 1 ] );
|
|
8005c12: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8005c14: 6b1a ldr r2, [r3, #48] ; 0x30
|
|
8005c16: 687b ldr r3, [r7, #4]
|
|
8005c18: 493c ldr r1, [pc, #240] ; (8005d0c <prvInitialiseNewTask+0x118>)
|
|
8005c1a: 468c mov ip, r1
|
|
8005c1c: 4463 add r3, ip
|
|
8005c1e: 009b lsls r3, r3, #2
|
|
8005c20: 18d3 adds r3, r2, r3
|
|
8005c22: 613b str r3, [r7, #16]
|
|
pxTopOfStack = ( StackType_t * ) ( ( ( portPOINTER_SIZE_TYPE ) pxTopOfStack ) & ( ~( ( portPOINTER_SIZE_TYPE ) portBYTE_ALIGNMENT_MASK ) ) ); /*lint !e923 !e9033 !e9078 MISRA exception. Avoiding casts between pointers and integers is not practical. Size differences accounted for using portPOINTER_SIZE_TYPE type. Checked by assert(). */
|
|
8005c24: 693b ldr r3, [r7, #16]
|
|
8005c26: 2207 movs r2, #7
|
|
8005c28: 4393 bics r3, r2
|
|
8005c2a: 613b str r3, [r7, #16]
|
|
|
|
/* Check the alignment of the calculated top of stack is correct. */
|
|
configASSERT( ( ( ( portPOINTER_SIZE_TYPE ) pxTopOfStack & ( portPOINTER_SIZE_TYPE ) portBYTE_ALIGNMENT_MASK ) == 0UL ) );
|
|
8005c2c: 693b ldr r3, [r7, #16]
|
|
8005c2e: 2207 movs r2, #7
|
|
8005c30: 4013 ands r3, r2
|
|
8005c32: d001 beq.n 8005c38 <prvInitialiseNewTask+0x44>
|
|
8005c34: b672 cpsid i
|
|
8005c36: e7fe b.n 8005c36 <prvInitialiseNewTask+0x42>
|
|
pxNewTCB->pxEndOfStack = pxNewTCB->pxStack + ( ulStackDepth - ( uint32_t ) 1 );
|
|
}
|
|
#endif /* portSTACK_GROWTH */
|
|
|
|
/* Store the task name in the TCB. */
|
|
if( pcName != NULL )
|
|
8005c38: 68bb ldr r3, [r7, #8]
|
|
8005c3a: 2b00 cmp r3, #0
|
|
8005c3c: d020 beq.n 8005c80 <prvInitialiseNewTask+0x8c>
|
|
{
|
|
for( x = ( UBaseType_t ) 0; x < ( UBaseType_t ) configMAX_TASK_NAME_LEN; x++ )
|
|
8005c3e: 2300 movs r3, #0
|
|
8005c40: 617b str r3, [r7, #20]
|
|
8005c42: e013 b.n 8005c6c <prvInitialiseNewTask+0x78>
|
|
{
|
|
pxNewTCB->pcTaskName[ x ] = pcName[ x ];
|
|
8005c44: 68ba ldr r2, [r7, #8]
|
|
8005c46: 697b ldr r3, [r7, #20]
|
|
8005c48: 18d3 adds r3, r2, r3
|
|
8005c4a: 7818 ldrb r0, [r3, #0]
|
|
8005c4c: 6aba ldr r2, [r7, #40] ; 0x28
|
|
8005c4e: 2134 movs r1, #52 ; 0x34
|
|
8005c50: 697b ldr r3, [r7, #20]
|
|
8005c52: 18d3 adds r3, r2, r3
|
|
8005c54: 185b adds r3, r3, r1
|
|
8005c56: 1c02 adds r2, r0, #0
|
|
8005c58: 701a strb r2, [r3, #0]
|
|
|
|
/* Don't copy all configMAX_TASK_NAME_LEN if the string is shorter than
|
|
configMAX_TASK_NAME_LEN characters just in case the memory after the
|
|
string is not accessible (extremely unlikely). */
|
|
if( pcName[ x ] == ( char ) 0x00 )
|
|
8005c5a: 68ba ldr r2, [r7, #8]
|
|
8005c5c: 697b ldr r3, [r7, #20]
|
|
8005c5e: 18d3 adds r3, r2, r3
|
|
8005c60: 781b ldrb r3, [r3, #0]
|
|
8005c62: 2b00 cmp r3, #0
|
|
8005c64: d006 beq.n 8005c74 <prvInitialiseNewTask+0x80>
|
|
for( x = ( UBaseType_t ) 0; x < ( UBaseType_t ) configMAX_TASK_NAME_LEN; x++ )
|
|
8005c66: 697b ldr r3, [r7, #20]
|
|
8005c68: 3301 adds r3, #1
|
|
8005c6a: 617b str r3, [r7, #20]
|
|
8005c6c: 697b ldr r3, [r7, #20]
|
|
8005c6e: 2b0f cmp r3, #15
|
|
8005c70: d9e8 bls.n 8005c44 <prvInitialiseNewTask+0x50>
|
|
8005c72: e000 b.n 8005c76 <prvInitialiseNewTask+0x82>
|
|
{
|
|
break;
|
|
8005c74: 46c0 nop ; (mov r8, r8)
|
|
}
|
|
}
|
|
|
|
/* Ensure the name string is terminated in the case that the string length
|
|
was greater or equal to configMAX_TASK_NAME_LEN. */
|
|
pxNewTCB->pcTaskName[ configMAX_TASK_NAME_LEN - 1 ] = '\0';
|
|
8005c76: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8005c78: 2243 movs r2, #67 ; 0x43
|
|
8005c7a: 2100 movs r1, #0
|
|
8005c7c: 5499 strb r1, [r3, r2]
|
|
8005c7e: e003 b.n 8005c88 <prvInitialiseNewTask+0x94>
|
|
}
|
|
else
|
|
{
|
|
/* The task has not been given a name, so just ensure there is a NULL
|
|
terminator when it is read out. */
|
|
pxNewTCB->pcTaskName[ 0 ] = 0x00;
|
|
8005c80: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8005c82: 2234 movs r2, #52 ; 0x34
|
|
8005c84: 2100 movs r1, #0
|
|
8005c86: 5499 strb r1, [r3, r2]
|
|
}
|
|
|
|
/* This is used as an array index so must ensure it's not too large. First
|
|
remove the privilege bit if one is present. */
|
|
if( uxPriority >= ( UBaseType_t ) configMAX_PRIORITIES )
|
|
8005c88: 6a3b ldr r3, [r7, #32]
|
|
8005c8a: 2b37 cmp r3, #55 ; 0x37
|
|
8005c8c: d901 bls.n 8005c92 <prvInitialiseNewTask+0x9e>
|
|
{
|
|
uxPriority = ( UBaseType_t ) configMAX_PRIORITIES - ( UBaseType_t ) 1U;
|
|
8005c8e: 2337 movs r3, #55 ; 0x37
|
|
8005c90: 623b str r3, [r7, #32]
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
pxNewTCB->uxPriority = uxPriority;
|
|
8005c92: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8005c94: 6a3a ldr r2, [r7, #32]
|
|
8005c96: 62da str r2, [r3, #44] ; 0x2c
|
|
#if ( configUSE_MUTEXES == 1 )
|
|
{
|
|
pxNewTCB->uxBasePriority = uxPriority;
|
|
8005c98: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8005c9a: 6a3a ldr r2, [r7, #32]
|
|
8005c9c: 64da str r2, [r3, #76] ; 0x4c
|
|
pxNewTCB->uxMutexesHeld = 0;
|
|
8005c9e: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8005ca0: 2200 movs r2, #0
|
|
8005ca2: 651a str r2, [r3, #80] ; 0x50
|
|
}
|
|
#endif /* configUSE_MUTEXES */
|
|
|
|
vListInitialiseItem( &( pxNewTCB->xStateListItem ) );
|
|
8005ca4: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8005ca6: 3304 adds r3, #4
|
|
8005ca8: 0018 movs r0, r3
|
|
8005caa: f7ff fa25 bl 80050f8 <vListInitialiseItem>
|
|
vListInitialiseItem( &( pxNewTCB->xEventListItem ) );
|
|
8005cae: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8005cb0: 3318 adds r3, #24
|
|
8005cb2: 0018 movs r0, r3
|
|
8005cb4: f7ff fa20 bl 80050f8 <vListInitialiseItem>
|
|
|
|
/* Set the pxNewTCB as a link back from the ListItem_t. This is so we can get
|
|
back to the containing TCB from a generic item in a list. */
|
|
listSET_LIST_ITEM_OWNER( &( pxNewTCB->xStateListItem ), pxNewTCB );
|
|
8005cb8: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8005cba: 6aba ldr r2, [r7, #40] ; 0x28
|
|
8005cbc: 611a str r2, [r3, #16]
|
|
|
|
/* Event lists are always in priority order. */
|
|
listSET_LIST_ITEM_VALUE( &( pxNewTCB->xEventListItem ), ( TickType_t ) configMAX_PRIORITIES - ( TickType_t ) uxPriority ); /*lint !e961 MISRA exception as the casts are only redundant for some ports. */
|
|
8005cbe: 6a3b ldr r3, [r7, #32]
|
|
8005cc0: 2238 movs r2, #56 ; 0x38
|
|
8005cc2: 1ad2 subs r2, r2, r3
|
|
8005cc4: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8005cc6: 619a str r2, [r3, #24]
|
|
listSET_LIST_ITEM_OWNER( &( pxNewTCB->xEventListItem ), pxNewTCB );
|
|
8005cc8: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8005cca: 6aba ldr r2, [r7, #40] ; 0x28
|
|
8005ccc: 625a str r2, [r3, #36] ; 0x24
|
|
}
|
|
#endif
|
|
|
|
#if ( configUSE_TASK_NOTIFICATIONS == 1 )
|
|
{
|
|
pxNewTCB->ulNotifiedValue = 0;
|
|
8005cce: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8005cd0: 2200 movs r2, #0
|
|
8005cd2: 655a str r2, [r3, #84] ; 0x54
|
|
pxNewTCB->ucNotifyState = taskNOT_WAITING_NOTIFICATION;
|
|
8005cd4: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8005cd6: 2258 movs r2, #88 ; 0x58
|
|
8005cd8: 2100 movs r1, #0
|
|
8005cda: 5499 strb r1, [r3, r2]
|
|
}
|
|
#endif
|
|
|
|
#if( INCLUDE_xTaskAbortDelay == 1 )
|
|
{
|
|
pxNewTCB->ucDelayAborted = pdFALSE;
|
|
8005cdc: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8005cde: 225a movs r2, #90 ; 0x5a
|
|
8005ce0: 2100 movs r1, #0
|
|
8005ce2: 5499 strb r1, [r3, r2]
|
|
}
|
|
#endif /* portSTACK_GROWTH */
|
|
}
|
|
#else /* portHAS_STACK_OVERFLOW_CHECKING */
|
|
{
|
|
pxNewTCB->pxTopOfStack = pxPortInitialiseStack( pxTopOfStack, pxTaskCode, pvParameters );
|
|
8005ce4: 683a ldr r2, [r7, #0]
|
|
8005ce6: 68f9 ldr r1, [r7, #12]
|
|
8005ce8: 693b ldr r3, [r7, #16]
|
|
8005cea: 0018 movs r0, r3
|
|
8005cec: f001 f980 bl 8006ff0 <pxPortInitialiseStack>
|
|
8005cf0: 0002 movs r2, r0
|
|
8005cf2: 6abb ldr r3, [r7, #40] ; 0x28
|
|
8005cf4: 601a str r2, [r3, #0]
|
|
}
|
|
#endif /* portHAS_STACK_OVERFLOW_CHECKING */
|
|
}
|
|
#endif /* portUSING_MPU_WRAPPERS */
|
|
|
|
if( pxCreatedTask != NULL )
|
|
8005cf6: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
8005cf8: 2b00 cmp r3, #0
|
|
8005cfa: d002 beq.n 8005d02 <prvInitialiseNewTask+0x10e>
|
|
{
|
|
/* Pass the handle out in an anonymous way. The handle can be used to
|
|
change the created task's priority, delete the created task, etc.*/
|
|
*pxCreatedTask = ( TaskHandle_t ) pxNewTCB;
|
|
8005cfc: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
8005cfe: 6aba ldr r2, [r7, #40] ; 0x28
|
|
8005d00: 601a str r2, [r3, #0]
|
|
}
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
8005d02: 46c0 nop ; (mov r8, r8)
|
|
8005d04: 46bd mov sp, r7
|
|
8005d06: b006 add sp, #24
|
|
8005d08: bd80 pop {r7, pc}
|
|
8005d0a: 46c0 nop ; (mov r8, r8)
|
|
8005d0c: 3fffffff .word 0x3fffffff
|
|
|
|
08005d10 <prvAddNewTaskToReadyList>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static void prvAddNewTaskToReadyList( TCB_t *pxNewTCB )
|
|
{
|
|
8005d10: b580 push {r7, lr}
|
|
8005d12: b082 sub sp, #8
|
|
8005d14: af00 add r7, sp, #0
|
|
8005d16: 6078 str r0, [r7, #4]
|
|
/* Ensure interrupts don't access the task lists while the lists are being
|
|
updated. */
|
|
taskENTER_CRITICAL();
|
|
8005d18: f001 fa02 bl 8007120 <vPortEnterCritical>
|
|
{
|
|
uxCurrentNumberOfTasks++;
|
|
8005d1c: 4b2a ldr r3, [pc, #168] ; (8005dc8 <prvAddNewTaskToReadyList+0xb8>)
|
|
8005d1e: 681b ldr r3, [r3, #0]
|
|
8005d20: 1c5a adds r2, r3, #1
|
|
8005d22: 4b29 ldr r3, [pc, #164] ; (8005dc8 <prvAddNewTaskToReadyList+0xb8>)
|
|
8005d24: 601a str r2, [r3, #0]
|
|
if( pxCurrentTCB == NULL )
|
|
8005d26: 4b29 ldr r3, [pc, #164] ; (8005dcc <prvAddNewTaskToReadyList+0xbc>)
|
|
8005d28: 681b ldr r3, [r3, #0]
|
|
8005d2a: 2b00 cmp r3, #0
|
|
8005d2c: d109 bne.n 8005d42 <prvAddNewTaskToReadyList+0x32>
|
|
{
|
|
/* There are no other tasks, or all the other tasks are in
|
|
the suspended state - make this the current task. */
|
|
pxCurrentTCB = pxNewTCB;
|
|
8005d2e: 4b27 ldr r3, [pc, #156] ; (8005dcc <prvAddNewTaskToReadyList+0xbc>)
|
|
8005d30: 687a ldr r2, [r7, #4]
|
|
8005d32: 601a str r2, [r3, #0]
|
|
|
|
if( uxCurrentNumberOfTasks == ( UBaseType_t ) 1 )
|
|
8005d34: 4b24 ldr r3, [pc, #144] ; (8005dc8 <prvAddNewTaskToReadyList+0xb8>)
|
|
8005d36: 681b ldr r3, [r3, #0]
|
|
8005d38: 2b01 cmp r3, #1
|
|
8005d3a: d110 bne.n 8005d5e <prvAddNewTaskToReadyList+0x4e>
|
|
{
|
|
/* This is the first task to be created so do the preliminary
|
|
initialisation required. We will not recover if this call
|
|
fails, but we will report the failure. */
|
|
prvInitialiseTaskLists();
|
|
8005d3c: f000 fcbc bl 80066b8 <prvInitialiseTaskLists>
|
|
8005d40: e00d b.n 8005d5e <prvAddNewTaskToReadyList+0x4e>
|
|
else
|
|
{
|
|
/* If the scheduler is not already running, make this task the
|
|
current task if it is the highest priority task to be created
|
|
so far. */
|
|
if( xSchedulerRunning == pdFALSE )
|
|
8005d42: 4b23 ldr r3, [pc, #140] ; (8005dd0 <prvAddNewTaskToReadyList+0xc0>)
|
|
8005d44: 681b ldr r3, [r3, #0]
|
|
8005d46: 2b00 cmp r3, #0
|
|
8005d48: d109 bne.n 8005d5e <prvAddNewTaskToReadyList+0x4e>
|
|
{
|
|
if( pxCurrentTCB->uxPriority <= pxNewTCB->uxPriority )
|
|
8005d4a: 4b20 ldr r3, [pc, #128] ; (8005dcc <prvAddNewTaskToReadyList+0xbc>)
|
|
8005d4c: 681b ldr r3, [r3, #0]
|
|
8005d4e: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8005d50: 687b ldr r3, [r7, #4]
|
|
8005d52: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
8005d54: 429a cmp r2, r3
|
|
8005d56: d802 bhi.n 8005d5e <prvAddNewTaskToReadyList+0x4e>
|
|
{
|
|
pxCurrentTCB = pxNewTCB;
|
|
8005d58: 4b1c ldr r3, [pc, #112] ; (8005dcc <prvAddNewTaskToReadyList+0xbc>)
|
|
8005d5a: 687a ldr r2, [r7, #4]
|
|
8005d5c: 601a str r2, [r3, #0]
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
|
|
uxTaskNumber++;
|
|
8005d5e: 4b1d ldr r3, [pc, #116] ; (8005dd4 <prvAddNewTaskToReadyList+0xc4>)
|
|
8005d60: 681b ldr r3, [r3, #0]
|
|
8005d62: 1c5a adds r2, r3, #1
|
|
8005d64: 4b1b ldr r3, [pc, #108] ; (8005dd4 <prvAddNewTaskToReadyList+0xc4>)
|
|
8005d66: 601a str r2, [r3, #0]
|
|
|
|
#if ( configUSE_TRACE_FACILITY == 1 )
|
|
{
|
|
/* Add a counter into the TCB for tracing only. */
|
|
pxNewTCB->uxTCBNumber = uxTaskNumber;
|
|
8005d68: 4b1a ldr r3, [pc, #104] ; (8005dd4 <prvAddNewTaskToReadyList+0xc4>)
|
|
8005d6a: 681a ldr r2, [r3, #0]
|
|
8005d6c: 687b ldr r3, [r7, #4]
|
|
8005d6e: 645a str r2, [r3, #68] ; 0x44
|
|
}
|
|
#endif /* configUSE_TRACE_FACILITY */
|
|
traceTASK_CREATE( pxNewTCB );
|
|
|
|
prvAddTaskToReadyList( pxNewTCB );
|
|
8005d70: 687b ldr r3, [r7, #4]
|
|
8005d72: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8005d74: 4b18 ldr r3, [pc, #96] ; (8005dd8 <prvAddNewTaskToReadyList+0xc8>)
|
|
8005d76: 681b ldr r3, [r3, #0]
|
|
8005d78: 429a cmp r2, r3
|
|
8005d7a: d903 bls.n 8005d84 <prvAddNewTaskToReadyList+0x74>
|
|
8005d7c: 687b ldr r3, [r7, #4]
|
|
8005d7e: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8005d80: 4b15 ldr r3, [pc, #84] ; (8005dd8 <prvAddNewTaskToReadyList+0xc8>)
|
|
8005d82: 601a str r2, [r3, #0]
|
|
8005d84: 687b ldr r3, [r7, #4]
|
|
8005d86: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8005d88: 0013 movs r3, r2
|
|
8005d8a: 009b lsls r3, r3, #2
|
|
8005d8c: 189b adds r3, r3, r2
|
|
8005d8e: 009b lsls r3, r3, #2
|
|
8005d90: 4a12 ldr r2, [pc, #72] ; (8005ddc <prvAddNewTaskToReadyList+0xcc>)
|
|
8005d92: 189a adds r2, r3, r2
|
|
8005d94: 687b ldr r3, [r7, #4]
|
|
8005d96: 3304 adds r3, #4
|
|
8005d98: 0019 movs r1, r3
|
|
8005d9a: 0010 movs r0, r2
|
|
8005d9c: f7ff f9b7 bl 800510e <vListInsertEnd>
|
|
|
|
portSETUP_TCB( pxNewTCB );
|
|
}
|
|
taskEXIT_CRITICAL();
|
|
8005da0: f001 f9d0 bl 8007144 <vPortExitCritical>
|
|
|
|
if( xSchedulerRunning != pdFALSE )
|
|
8005da4: 4b0a ldr r3, [pc, #40] ; (8005dd0 <prvAddNewTaskToReadyList+0xc0>)
|
|
8005da6: 681b ldr r3, [r3, #0]
|
|
8005da8: 2b00 cmp r3, #0
|
|
8005daa: d008 beq.n 8005dbe <prvAddNewTaskToReadyList+0xae>
|
|
{
|
|
/* If the created task is of a higher priority than the current task
|
|
then it should run now. */
|
|
if( pxCurrentTCB->uxPriority < pxNewTCB->uxPriority )
|
|
8005dac: 4b07 ldr r3, [pc, #28] ; (8005dcc <prvAddNewTaskToReadyList+0xbc>)
|
|
8005dae: 681b ldr r3, [r3, #0]
|
|
8005db0: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8005db2: 687b ldr r3, [r7, #4]
|
|
8005db4: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
8005db6: 429a cmp r2, r3
|
|
8005db8: d201 bcs.n 8005dbe <prvAddNewTaskToReadyList+0xae>
|
|
{
|
|
taskYIELD_IF_USING_PREEMPTION();
|
|
8005dba: f001 f9a1 bl 8007100 <vPortYield>
|
|
}
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
8005dbe: 46c0 nop ; (mov r8, r8)
|
|
8005dc0: 46bd mov sp, r7
|
|
8005dc2: b002 add sp, #8
|
|
8005dc4: bd80 pop {r7, pc}
|
|
8005dc6: 46c0 nop ; (mov r8, r8)
|
|
8005dc8: 20000bc0 .word 0x20000bc0
|
|
8005dcc: 200006ec .word 0x200006ec
|
|
8005dd0: 20000bcc .word 0x20000bcc
|
|
8005dd4: 20000bdc .word 0x20000bdc
|
|
8005dd8: 20000bc8 .word 0x20000bc8
|
|
8005ddc: 200006f0 .word 0x200006f0
|
|
|
|
08005de0 <vTaskDelay>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
#if ( INCLUDE_vTaskDelay == 1 )
|
|
|
|
void vTaskDelay( const TickType_t xTicksToDelay )
|
|
{
|
|
8005de0: b580 push {r7, lr}
|
|
8005de2: b084 sub sp, #16
|
|
8005de4: af00 add r7, sp, #0
|
|
8005de6: 6078 str r0, [r7, #4]
|
|
BaseType_t xAlreadyYielded = pdFALSE;
|
|
8005de8: 2300 movs r3, #0
|
|
8005dea: 60fb str r3, [r7, #12]
|
|
|
|
/* A delay time of zero just forces a reschedule. */
|
|
if( xTicksToDelay > ( TickType_t ) 0U )
|
|
8005dec: 687b ldr r3, [r7, #4]
|
|
8005dee: 2b00 cmp r3, #0
|
|
8005df0: d010 beq.n 8005e14 <vTaskDelay+0x34>
|
|
{
|
|
configASSERT( uxSchedulerSuspended == 0 );
|
|
8005df2: 4b0d ldr r3, [pc, #52] ; (8005e28 <vTaskDelay+0x48>)
|
|
8005df4: 681b ldr r3, [r3, #0]
|
|
8005df6: 2b00 cmp r3, #0
|
|
8005df8: d001 beq.n 8005dfe <vTaskDelay+0x1e>
|
|
8005dfa: b672 cpsid i
|
|
8005dfc: e7fe b.n 8005dfc <vTaskDelay+0x1c>
|
|
vTaskSuspendAll();
|
|
8005dfe: f000 f8dd bl 8005fbc <vTaskSuspendAll>
|
|
list or removed from the blocked list until the scheduler
|
|
is resumed.
|
|
|
|
This task cannot be in an event list as it is the currently
|
|
executing task. */
|
|
prvAddCurrentTaskToDelayedList( xTicksToDelay, pdFALSE );
|
|
8005e02: 687b ldr r3, [r7, #4]
|
|
8005e04: 2100 movs r1, #0
|
|
8005e06: 0018 movs r0, r3
|
|
8005e08: f000 fd86 bl 8006918 <prvAddCurrentTaskToDelayedList>
|
|
}
|
|
xAlreadyYielded = xTaskResumeAll();
|
|
8005e0c: f000 f918 bl 8006040 <xTaskResumeAll>
|
|
8005e10: 0003 movs r3, r0
|
|
8005e12: 60fb str r3, [r7, #12]
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
/* Force a reschedule if xTaskResumeAll has not already done so, we may
|
|
have put ourselves to sleep. */
|
|
if( xAlreadyYielded == pdFALSE )
|
|
8005e14: 68fb ldr r3, [r7, #12]
|
|
8005e16: 2b00 cmp r3, #0
|
|
8005e18: d101 bne.n 8005e1e <vTaskDelay+0x3e>
|
|
{
|
|
portYIELD_WITHIN_API();
|
|
8005e1a: f001 f971 bl 8007100 <vPortYield>
|
|
}
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
8005e1e: 46c0 nop ; (mov r8, r8)
|
|
8005e20: 46bd mov sp, r7
|
|
8005e22: b004 add sp, #16
|
|
8005e24: bd80 pop {r7, pc}
|
|
8005e26: 46c0 nop ; (mov r8, r8)
|
|
8005e28: 20000be8 .word 0x20000be8
|
|
|
|
08005e2c <prvTaskIsTaskSuspended>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
#if ( INCLUDE_vTaskSuspend == 1 )
|
|
|
|
static BaseType_t prvTaskIsTaskSuspended( const TaskHandle_t xTask )
|
|
{
|
|
8005e2c: b580 push {r7, lr}
|
|
8005e2e: b084 sub sp, #16
|
|
8005e30: af00 add r7, sp, #0
|
|
8005e32: 6078 str r0, [r7, #4]
|
|
BaseType_t xReturn = pdFALSE;
|
|
8005e34: 2300 movs r3, #0
|
|
8005e36: 60fb str r3, [r7, #12]
|
|
const TCB_t * const pxTCB = xTask;
|
|
8005e38: 687b ldr r3, [r7, #4]
|
|
8005e3a: 60bb str r3, [r7, #8]
|
|
|
|
/* Accesses xPendingReadyList so must be called from a critical
|
|
section. */
|
|
|
|
/* It does not make sense to check if the calling task is suspended. */
|
|
configASSERT( xTask );
|
|
8005e3c: 687b ldr r3, [r7, #4]
|
|
8005e3e: 2b00 cmp r3, #0
|
|
8005e40: d101 bne.n 8005e46 <prvTaskIsTaskSuspended+0x1a>
|
|
8005e42: b672 cpsid i
|
|
8005e44: e7fe b.n 8005e44 <prvTaskIsTaskSuspended+0x18>
|
|
|
|
/* Is the task being resumed actually in the suspended list? */
|
|
if( listIS_CONTAINED_WITHIN( &xSuspendedTaskList, &( pxTCB->xStateListItem ) ) != pdFALSE )
|
|
8005e46: 68bb ldr r3, [r7, #8]
|
|
8005e48: 695a ldr r2, [r3, #20]
|
|
8005e4a: 4b09 ldr r3, [pc, #36] ; (8005e70 <prvTaskIsTaskSuspended+0x44>)
|
|
8005e4c: 429a cmp r2, r3
|
|
8005e4e: d10a bne.n 8005e66 <prvTaskIsTaskSuspended+0x3a>
|
|
{
|
|
/* Has the task already been resumed from within an ISR? */
|
|
if( listIS_CONTAINED_WITHIN( &xPendingReadyList, &( pxTCB->xEventListItem ) ) == pdFALSE )
|
|
8005e50: 68bb ldr r3, [r7, #8]
|
|
8005e52: 6a9a ldr r2, [r3, #40] ; 0x28
|
|
8005e54: 4b07 ldr r3, [pc, #28] ; (8005e74 <prvTaskIsTaskSuspended+0x48>)
|
|
8005e56: 429a cmp r2, r3
|
|
8005e58: d005 beq.n 8005e66 <prvTaskIsTaskSuspended+0x3a>
|
|
{
|
|
/* Is it in the suspended list because it is in the Suspended
|
|
state, or because is is blocked with no timeout? */
|
|
if( listIS_CONTAINED_WITHIN( NULL, &( pxTCB->xEventListItem ) ) != pdFALSE ) /*lint !e961. The cast is only redundant when NULL is used. */
|
|
8005e5a: 68bb ldr r3, [r7, #8]
|
|
8005e5c: 6a9b ldr r3, [r3, #40] ; 0x28
|
|
8005e5e: 2b00 cmp r3, #0
|
|
8005e60: d101 bne.n 8005e66 <prvTaskIsTaskSuspended+0x3a>
|
|
{
|
|
xReturn = pdTRUE;
|
|
8005e62: 2301 movs r3, #1
|
|
8005e64: 60fb str r3, [r7, #12]
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
return xReturn;
|
|
8005e66: 68fb ldr r3, [r7, #12]
|
|
} /*lint !e818 xTask cannot be a pointer to const because it is a typedef. */
|
|
8005e68: 0018 movs r0, r3
|
|
8005e6a: 46bd mov sp, r7
|
|
8005e6c: b004 add sp, #16
|
|
8005e6e: bd80 pop {r7, pc}
|
|
8005e70: 20000bac .word 0x20000bac
|
|
8005e74: 20000b80 .word 0x20000b80
|
|
|
|
08005e78 <vTaskResume>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
#if ( INCLUDE_vTaskSuspend == 1 )
|
|
|
|
void vTaskResume( TaskHandle_t xTaskToResume )
|
|
{
|
|
8005e78: b580 push {r7, lr}
|
|
8005e7a: b084 sub sp, #16
|
|
8005e7c: af00 add r7, sp, #0
|
|
8005e7e: 6078 str r0, [r7, #4]
|
|
TCB_t * const pxTCB = xTaskToResume;
|
|
8005e80: 687b ldr r3, [r7, #4]
|
|
8005e82: 60fb str r3, [r7, #12]
|
|
|
|
/* It does not make sense to resume the calling task. */
|
|
configASSERT( xTaskToResume );
|
|
8005e84: 687b ldr r3, [r7, #4]
|
|
8005e86: 2b00 cmp r3, #0
|
|
8005e88: d101 bne.n 8005e8e <vTaskResume+0x16>
|
|
8005e8a: b672 cpsid i
|
|
8005e8c: e7fe b.n 8005e8c <vTaskResume+0x14>
|
|
|
|
/* The parameter cannot be NULL as it is impossible to resume the
|
|
currently executing task. */
|
|
if( ( pxTCB != pxCurrentTCB ) && ( pxTCB != NULL ) )
|
|
8005e8e: 4b1e ldr r3, [pc, #120] ; (8005f08 <vTaskResume+0x90>)
|
|
8005e90: 681b ldr r3, [r3, #0]
|
|
8005e92: 68fa ldr r2, [r7, #12]
|
|
8005e94: 429a cmp r2, r3
|
|
8005e96: d032 beq.n 8005efe <vTaskResume+0x86>
|
|
8005e98: 68fb ldr r3, [r7, #12]
|
|
8005e9a: 2b00 cmp r3, #0
|
|
8005e9c: d02f beq.n 8005efe <vTaskResume+0x86>
|
|
{
|
|
taskENTER_CRITICAL();
|
|
8005e9e: f001 f93f bl 8007120 <vPortEnterCritical>
|
|
{
|
|
if( prvTaskIsTaskSuspended( pxTCB ) != pdFALSE )
|
|
8005ea2: 68fb ldr r3, [r7, #12]
|
|
8005ea4: 0018 movs r0, r3
|
|
8005ea6: f7ff ffc1 bl 8005e2c <prvTaskIsTaskSuspended>
|
|
8005eaa: 1e03 subs r3, r0, #0
|
|
8005eac: d025 beq.n 8005efa <vTaskResume+0x82>
|
|
{
|
|
traceTASK_RESUME( pxTCB );
|
|
|
|
/* The ready list can be accessed even if the scheduler is
|
|
suspended because this is inside a critical section. */
|
|
( void ) uxListRemove( &( pxTCB->xStateListItem ) );
|
|
8005eae: 68fb ldr r3, [r7, #12]
|
|
8005eb0: 3304 adds r3, #4
|
|
8005eb2: 0018 movs r0, r3
|
|
8005eb4: f7ff f983 bl 80051be <uxListRemove>
|
|
prvAddTaskToReadyList( pxTCB );
|
|
8005eb8: 68fb ldr r3, [r7, #12]
|
|
8005eba: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8005ebc: 4b13 ldr r3, [pc, #76] ; (8005f0c <vTaskResume+0x94>)
|
|
8005ebe: 681b ldr r3, [r3, #0]
|
|
8005ec0: 429a cmp r2, r3
|
|
8005ec2: d903 bls.n 8005ecc <vTaskResume+0x54>
|
|
8005ec4: 68fb ldr r3, [r7, #12]
|
|
8005ec6: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8005ec8: 4b10 ldr r3, [pc, #64] ; (8005f0c <vTaskResume+0x94>)
|
|
8005eca: 601a str r2, [r3, #0]
|
|
8005ecc: 68fb ldr r3, [r7, #12]
|
|
8005ece: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8005ed0: 0013 movs r3, r2
|
|
8005ed2: 009b lsls r3, r3, #2
|
|
8005ed4: 189b adds r3, r3, r2
|
|
8005ed6: 009b lsls r3, r3, #2
|
|
8005ed8: 4a0d ldr r2, [pc, #52] ; (8005f10 <vTaskResume+0x98>)
|
|
8005eda: 189a adds r2, r3, r2
|
|
8005edc: 68fb ldr r3, [r7, #12]
|
|
8005ede: 3304 adds r3, #4
|
|
8005ee0: 0019 movs r1, r3
|
|
8005ee2: 0010 movs r0, r2
|
|
8005ee4: f7ff f913 bl 800510e <vListInsertEnd>
|
|
|
|
/* A higher priority task may have just been resumed. */
|
|
if( pxTCB->uxPriority >= pxCurrentTCB->uxPriority )
|
|
8005ee8: 68fb ldr r3, [r7, #12]
|
|
8005eea: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8005eec: 4b06 ldr r3, [pc, #24] ; (8005f08 <vTaskResume+0x90>)
|
|
8005eee: 681b ldr r3, [r3, #0]
|
|
8005ef0: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
8005ef2: 429a cmp r2, r3
|
|
8005ef4: d301 bcc.n 8005efa <vTaskResume+0x82>
|
|
{
|
|
/* This yield may not cause the task just resumed to run,
|
|
but will leave the lists in the correct state for the
|
|
next yield. */
|
|
taskYIELD_IF_USING_PREEMPTION();
|
|
8005ef6: f001 f903 bl 8007100 <vPortYield>
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
taskEXIT_CRITICAL();
|
|
8005efa: f001 f923 bl 8007144 <vPortExitCritical>
|
|
}
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
8005efe: 46c0 nop ; (mov r8, r8)
|
|
8005f00: 46bd mov sp, r7
|
|
8005f02: b004 add sp, #16
|
|
8005f04: bd80 pop {r7, pc}
|
|
8005f06: 46c0 nop ; (mov r8, r8)
|
|
8005f08: 200006ec .word 0x200006ec
|
|
8005f0c: 20000bc8 .word 0x20000bc8
|
|
8005f10: 200006f0 .word 0x200006f0
|
|
|
|
08005f14 <vTaskStartScheduler>:
|
|
|
|
#endif /* ( ( INCLUDE_xTaskResumeFromISR == 1 ) && ( INCLUDE_vTaskSuspend == 1 ) ) */
|
|
/*-----------------------------------------------------------*/
|
|
|
|
void vTaskStartScheduler( void )
|
|
{
|
|
8005f14: b590 push {r4, r7, lr}
|
|
8005f16: b089 sub sp, #36 ; 0x24
|
|
8005f18: af04 add r7, sp, #16
|
|
BaseType_t xReturn;
|
|
|
|
/* Add the idle task at the lowest priority. */
|
|
#if( configSUPPORT_STATIC_ALLOCATION == 1 )
|
|
{
|
|
StaticTask_t *pxIdleTaskTCBBuffer = NULL;
|
|
8005f1a: 2300 movs r3, #0
|
|
8005f1c: 60bb str r3, [r7, #8]
|
|
StackType_t *pxIdleTaskStackBuffer = NULL;
|
|
8005f1e: 2300 movs r3, #0
|
|
8005f20: 607b str r3, [r7, #4]
|
|
uint32_t ulIdleTaskStackSize;
|
|
|
|
/* The Idle task is created using user provided RAM - obtain the
|
|
address of the RAM then create the idle task. */
|
|
vApplicationGetIdleTaskMemory( &pxIdleTaskTCBBuffer, &pxIdleTaskStackBuffer, &ulIdleTaskStackSize );
|
|
8005f22: 003a movs r2, r7
|
|
8005f24: 1d39 adds r1, r7, #4
|
|
8005f26: 2308 movs r3, #8
|
|
8005f28: 18fb adds r3, r7, r3
|
|
8005f2a: 0018 movs r0, r3
|
|
8005f2c: f7ff f896 bl 800505c <vApplicationGetIdleTaskMemory>
|
|
xIdleTaskHandle = xTaskCreateStatic( prvIdleTask,
|
|
8005f30: 683c ldr r4, [r7, #0]
|
|
8005f32: 687b ldr r3, [r7, #4]
|
|
8005f34: 68ba ldr r2, [r7, #8]
|
|
8005f36: 491b ldr r1, [pc, #108] ; (8005fa4 <vTaskStartScheduler+0x90>)
|
|
8005f38: 481b ldr r0, [pc, #108] ; (8005fa8 <vTaskStartScheduler+0x94>)
|
|
8005f3a: 9202 str r2, [sp, #8]
|
|
8005f3c: 9301 str r3, [sp, #4]
|
|
8005f3e: 2300 movs r3, #0
|
|
8005f40: 9300 str r3, [sp, #0]
|
|
8005f42: 2300 movs r3, #0
|
|
8005f44: 0022 movs r2, r4
|
|
8005f46: f7ff fdc4 bl 8005ad2 <xTaskCreateStatic>
|
|
8005f4a: 0002 movs r2, r0
|
|
8005f4c: 4b17 ldr r3, [pc, #92] ; (8005fac <vTaskStartScheduler+0x98>)
|
|
8005f4e: 601a str r2, [r3, #0]
|
|
( void * ) NULL, /*lint !e961. The cast is not redundant for all compilers. */
|
|
portPRIVILEGE_BIT, /* In effect ( tskIDLE_PRIORITY | portPRIVILEGE_BIT ), but tskIDLE_PRIORITY is zero. */
|
|
pxIdleTaskStackBuffer,
|
|
pxIdleTaskTCBBuffer ); /*lint !e961 MISRA exception, justified as it is not a redundant explicit cast to all supported compilers. */
|
|
|
|
if( xIdleTaskHandle != NULL )
|
|
8005f50: 4b16 ldr r3, [pc, #88] ; (8005fac <vTaskStartScheduler+0x98>)
|
|
8005f52: 681b ldr r3, [r3, #0]
|
|
8005f54: 2b00 cmp r3, #0
|
|
8005f56: d002 beq.n 8005f5e <vTaskStartScheduler+0x4a>
|
|
{
|
|
xReturn = pdPASS;
|
|
8005f58: 2301 movs r3, #1
|
|
8005f5a: 60fb str r3, [r7, #12]
|
|
8005f5c: e001 b.n 8005f62 <vTaskStartScheduler+0x4e>
|
|
}
|
|
else
|
|
{
|
|
xReturn = pdFAIL;
|
|
8005f5e: 2300 movs r3, #0
|
|
8005f60: 60fb str r3, [r7, #12]
|
|
}
|
|
#endif /* configSUPPORT_STATIC_ALLOCATION */
|
|
|
|
#if ( configUSE_TIMERS == 1 )
|
|
{
|
|
if( xReturn == pdPASS )
|
|
8005f62: 68fb ldr r3, [r7, #12]
|
|
8005f64: 2b01 cmp r3, #1
|
|
8005f66: d103 bne.n 8005f70 <vTaskStartScheduler+0x5c>
|
|
{
|
|
xReturn = xTimerCreateTimerTask();
|
|
8005f68: f000 fd30 bl 80069cc <xTimerCreateTimerTask>
|
|
8005f6c: 0003 movs r3, r0
|
|
8005f6e: 60fb str r3, [r7, #12]
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
#endif /* configUSE_TIMERS */
|
|
|
|
if( xReturn == pdPASS )
|
|
8005f70: 68fb ldr r3, [r7, #12]
|
|
8005f72: 2b01 cmp r3, #1
|
|
8005f74: d10d bne.n 8005f92 <vTaskStartScheduler+0x7e>
|
|
/* Interrupts are turned off here, to ensure a tick does not occur
|
|
before or during the call to xPortStartScheduler(). The stacks of
|
|
the created tasks contain a status word with interrupts switched on
|
|
so interrupts will automatically get re-enabled when the first task
|
|
starts to run. */
|
|
portDISABLE_INTERRUPTS();
|
|
8005f76: b672 cpsid i
|
|
structure specific to the task that will run first. */
|
|
_impure_ptr = &( pxCurrentTCB->xNewLib_reent );
|
|
}
|
|
#endif /* configUSE_NEWLIB_REENTRANT */
|
|
|
|
xNextTaskUnblockTime = portMAX_DELAY;
|
|
8005f78: 4b0d ldr r3, [pc, #52] ; (8005fb0 <vTaskStartScheduler+0x9c>)
|
|
8005f7a: 2201 movs r2, #1
|
|
8005f7c: 4252 negs r2, r2
|
|
8005f7e: 601a str r2, [r3, #0]
|
|
xSchedulerRunning = pdTRUE;
|
|
8005f80: 4b0c ldr r3, [pc, #48] ; (8005fb4 <vTaskStartScheduler+0xa0>)
|
|
8005f82: 2201 movs r2, #1
|
|
8005f84: 601a str r2, [r3, #0]
|
|
xTickCount = ( TickType_t ) configINITIAL_TICK_COUNT;
|
|
8005f86: 4b0c ldr r3, [pc, #48] ; (8005fb8 <vTaskStartScheduler+0xa4>)
|
|
8005f88: 2200 movs r2, #0
|
|
8005f8a: 601a str r2, [r3, #0]
|
|
|
|
traceTASK_SWITCHED_IN();
|
|
|
|
/* Setting up the timer tick is hardware specific and thus in the
|
|
portable interface. */
|
|
if( xPortStartScheduler() != pdFALSE )
|
|
8005f8c: f001 f894 bl 80070b8 <xPortStartScheduler>
|
|
}
|
|
|
|
/* Prevent compiler warnings if INCLUDE_xTaskGetIdleTaskHandle is set to 0,
|
|
meaning xIdleTaskHandle is not used anywhere else. */
|
|
( void ) xIdleTaskHandle;
|
|
}
|
|
8005f90: e004 b.n 8005f9c <vTaskStartScheduler+0x88>
|
|
configASSERT( xReturn != errCOULD_NOT_ALLOCATE_REQUIRED_MEMORY );
|
|
8005f92: 68fb ldr r3, [r7, #12]
|
|
8005f94: 3301 adds r3, #1
|
|
8005f96: d101 bne.n 8005f9c <vTaskStartScheduler+0x88>
|
|
8005f98: b672 cpsid i
|
|
8005f9a: e7fe b.n 8005f9a <vTaskStartScheduler+0x86>
|
|
}
|
|
8005f9c: 46c0 nop ; (mov r8, r8)
|
|
8005f9e: 46bd mov sp, r7
|
|
8005fa0: b005 add sp, #20
|
|
8005fa2: bd90 pop {r4, r7, pc}
|
|
8005fa4: 08007804 .word 0x08007804
|
|
8005fa8: 080065f1 .word 0x080065f1
|
|
8005fac: 20000be4 .word 0x20000be4
|
|
8005fb0: 20000be0 .word 0x20000be0
|
|
8005fb4: 20000bcc .word 0x20000bcc
|
|
8005fb8: 20000bc4 .word 0x20000bc4
|
|
|
|
08005fbc <vTaskSuspendAll>:
|
|
vPortEndScheduler();
|
|
}
|
|
/*----------------------------------------------------------*/
|
|
|
|
void vTaskSuspendAll( void )
|
|
{
|
|
8005fbc: b580 push {r7, lr}
|
|
8005fbe: af00 add r7, sp, #0
|
|
/* A critical section is not required as the variable is of type
|
|
BaseType_t. Please read Richard Barry's reply in the following link to a
|
|
post in the FreeRTOS support forum before reporting this as a bug! -
|
|
http://goo.gl/wu4acr */
|
|
++uxSchedulerSuspended;
|
|
8005fc0: 4b03 ldr r3, [pc, #12] ; (8005fd0 <vTaskSuspendAll+0x14>)
|
|
8005fc2: 681b ldr r3, [r3, #0]
|
|
8005fc4: 1c5a adds r2, r3, #1
|
|
8005fc6: 4b02 ldr r3, [pc, #8] ; (8005fd0 <vTaskSuspendAll+0x14>)
|
|
8005fc8: 601a str r2, [r3, #0]
|
|
portMEMORY_BARRIER();
|
|
}
|
|
8005fca: 46c0 nop ; (mov r8, r8)
|
|
8005fcc: 46bd mov sp, r7
|
|
8005fce: bd80 pop {r7, pc}
|
|
8005fd0: 20000be8 .word 0x20000be8
|
|
|
|
08005fd4 <prvGetExpectedIdleTime>:
|
|
/*----------------------------------------------------------*/
|
|
|
|
#if ( configUSE_TICKLESS_IDLE != 0 )
|
|
|
|
static TickType_t prvGetExpectedIdleTime( void )
|
|
{
|
|
8005fd4: b580 push {r7, lr}
|
|
8005fd6: b082 sub sp, #8
|
|
8005fd8: af00 add r7, sp, #0
|
|
TickType_t xReturn;
|
|
UBaseType_t uxHigherPriorityReadyTasks = pdFALSE;
|
|
8005fda: 2300 movs r3, #0
|
|
8005fdc: 603b str r3, [r7, #0]
|
|
configUSE_PREEMPTION is 0, so there may be tasks above the idle priority
|
|
task that are in the Ready state, even though the idle task is
|
|
running. */
|
|
#if( configUSE_PORT_OPTIMISED_TASK_SELECTION == 0 )
|
|
{
|
|
if( uxTopReadyPriority > tskIDLE_PRIORITY )
|
|
8005fde: 4b13 ldr r3, [pc, #76] ; (800602c <prvGetExpectedIdleTime+0x58>)
|
|
8005fe0: 681b ldr r3, [r3, #0]
|
|
8005fe2: 2b00 cmp r3, #0
|
|
8005fe4: d001 beq.n 8005fea <prvGetExpectedIdleTime+0x16>
|
|
{
|
|
uxHigherPriorityReadyTasks = pdTRUE;
|
|
8005fe6: 2301 movs r3, #1
|
|
8005fe8: 603b str r3, [r7, #0]
|
|
uxHigherPriorityReadyTasks = pdTRUE;
|
|
}
|
|
}
|
|
#endif
|
|
|
|
if( pxCurrentTCB->uxPriority > tskIDLE_PRIORITY )
|
|
8005fea: 4b11 ldr r3, [pc, #68] ; (8006030 <prvGetExpectedIdleTime+0x5c>)
|
|
8005fec: 681b ldr r3, [r3, #0]
|
|
8005fee: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
8005ff0: 2b00 cmp r3, #0
|
|
8005ff2: d002 beq.n 8005ffa <prvGetExpectedIdleTime+0x26>
|
|
{
|
|
xReturn = 0;
|
|
8005ff4: 2300 movs r3, #0
|
|
8005ff6: 607b str r3, [r7, #4]
|
|
8005ff8: e012 b.n 8006020 <prvGetExpectedIdleTime+0x4c>
|
|
}
|
|
else if( listCURRENT_LIST_LENGTH( &( pxReadyTasksLists[ tskIDLE_PRIORITY ] ) ) > 1 )
|
|
8005ffa: 4b0e ldr r3, [pc, #56] ; (8006034 <prvGetExpectedIdleTime+0x60>)
|
|
8005ffc: 681b ldr r3, [r3, #0]
|
|
8005ffe: 2b01 cmp r3, #1
|
|
8006000: d902 bls.n 8006008 <prvGetExpectedIdleTime+0x34>
|
|
{
|
|
/* There are other idle priority tasks in the ready state. If
|
|
time slicing is used then the very next tick interrupt must be
|
|
processed. */
|
|
xReturn = 0;
|
|
8006002: 2300 movs r3, #0
|
|
8006004: 607b str r3, [r7, #4]
|
|
8006006: e00b b.n 8006020 <prvGetExpectedIdleTime+0x4c>
|
|
}
|
|
else if( uxHigherPriorityReadyTasks != pdFALSE )
|
|
8006008: 683b ldr r3, [r7, #0]
|
|
800600a: 2b00 cmp r3, #0
|
|
800600c: d002 beq.n 8006014 <prvGetExpectedIdleTime+0x40>
|
|
{
|
|
/* There are tasks in the Ready state that have a priority above the
|
|
idle priority. This path can only be reached if
|
|
configUSE_PREEMPTION is 0. */
|
|
xReturn = 0;
|
|
800600e: 2300 movs r3, #0
|
|
8006010: 607b str r3, [r7, #4]
|
|
8006012: e005 b.n 8006020 <prvGetExpectedIdleTime+0x4c>
|
|
}
|
|
else
|
|
{
|
|
xReturn = xNextTaskUnblockTime - xTickCount;
|
|
8006014: 4b08 ldr r3, [pc, #32] ; (8006038 <prvGetExpectedIdleTime+0x64>)
|
|
8006016: 681a ldr r2, [r3, #0]
|
|
8006018: 4b08 ldr r3, [pc, #32] ; (800603c <prvGetExpectedIdleTime+0x68>)
|
|
800601a: 681b ldr r3, [r3, #0]
|
|
800601c: 1ad3 subs r3, r2, r3
|
|
800601e: 607b str r3, [r7, #4]
|
|
}
|
|
|
|
return xReturn;
|
|
8006020: 687b ldr r3, [r7, #4]
|
|
}
|
|
8006022: 0018 movs r0, r3
|
|
8006024: 46bd mov sp, r7
|
|
8006026: b002 add sp, #8
|
|
8006028: bd80 pop {r7, pc}
|
|
800602a: 46c0 nop ; (mov r8, r8)
|
|
800602c: 20000bc8 .word 0x20000bc8
|
|
8006030: 200006ec .word 0x200006ec
|
|
8006034: 200006f0 .word 0x200006f0
|
|
8006038: 20000be0 .word 0x20000be0
|
|
800603c: 20000bc4 .word 0x20000bc4
|
|
|
|
08006040 <xTaskResumeAll>:
|
|
|
|
#endif /* configUSE_TICKLESS_IDLE */
|
|
/*----------------------------------------------------------*/
|
|
|
|
BaseType_t xTaskResumeAll( void )
|
|
{
|
|
8006040: b580 push {r7, lr}
|
|
8006042: b084 sub sp, #16
|
|
8006044: af00 add r7, sp, #0
|
|
TCB_t *pxTCB = NULL;
|
|
8006046: 2300 movs r3, #0
|
|
8006048: 60fb str r3, [r7, #12]
|
|
BaseType_t xAlreadyYielded = pdFALSE;
|
|
800604a: 2300 movs r3, #0
|
|
800604c: 60bb str r3, [r7, #8]
|
|
|
|
/* If uxSchedulerSuspended is zero then this function does not match a
|
|
previous call to vTaskSuspendAll(). */
|
|
configASSERT( uxSchedulerSuspended );
|
|
800604e: 4b3a ldr r3, [pc, #232] ; (8006138 <xTaskResumeAll+0xf8>)
|
|
8006050: 681b ldr r3, [r3, #0]
|
|
8006052: 2b00 cmp r3, #0
|
|
8006054: d101 bne.n 800605a <xTaskResumeAll+0x1a>
|
|
8006056: b672 cpsid i
|
|
8006058: e7fe b.n 8006058 <xTaskResumeAll+0x18>
|
|
/* It is possible that an ISR caused a task to be removed from an event
|
|
list while the scheduler was suspended. If this was the case then the
|
|
removed task will have been added to the xPendingReadyList. Once the
|
|
scheduler has been resumed it is safe to move all the pending ready
|
|
tasks from this list into their appropriate ready list. */
|
|
taskENTER_CRITICAL();
|
|
800605a: f001 f861 bl 8007120 <vPortEnterCritical>
|
|
{
|
|
--uxSchedulerSuspended;
|
|
800605e: 4b36 ldr r3, [pc, #216] ; (8006138 <xTaskResumeAll+0xf8>)
|
|
8006060: 681b ldr r3, [r3, #0]
|
|
8006062: 1e5a subs r2, r3, #1
|
|
8006064: 4b34 ldr r3, [pc, #208] ; (8006138 <xTaskResumeAll+0xf8>)
|
|
8006066: 601a str r2, [r3, #0]
|
|
|
|
if( uxSchedulerSuspended == ( UBaseType_t ) pdFALSE )
|
|
8006068: 4b33 ldr r3, [pc, #204] ; (8006138 <xTaskResumeAll+0xf8>)
|
|
800606a: 681b ldr r3, [r3, #0]
|
|
800606c: 2b00 cmp r3, #0
|
|
800606e: d15b bne.n 8006128 <xTaskResumeAll+0xe8>
|
|
{
|
|
if( uxCurrentNumberOfTasks > ( UBaseType_t ) 0U )
|
|
8006070: 4b32 ldr r3, [pc, #200] ; (800613c <xTaskResumeAll+0xfc>)
|
|
8006072: 681b ldr r3, [r3, #0]
|
|
8006074: 2b00 cmp r3, #0
|
|
8006076: d057 beq.n 8006128 <xTaskResumeAll+0xe8>
|
|
{
|
|
/* Move any readied tasks from the pending list into the
|
|
appropriate ready list. */
|
|
while( listLIST_IS_EMPTY( &xPendingReadyList ) == pdFALSE )
|
|
8006078: e02f b.n 80060da <xTaskResumeAll+0x9a>
|
|
{
|
|
pxTCB = listGET_OWNER_OF_HEAD_ENTRY( ( &xPendingReadyList ) ); /*lint !e9079 void * is used as this macro is used with timers and co-routines too. Alignment is known to be fine as the type of the pointer stored and retrieved is the same. */
|
|
800607a: 4b31 ldr r3, [pc, #196] ; (8006140 <xTaskResumeAll+0x100>)
|
|
800607c: 68db ldr r3, [r3, #12]
|
|
800607e: 68db ldr r3, [r3, #12]
|
|
8006080: 60fb str r3, [r7, #12]
|
|
( void ) uxListRemove( &( pxTCB->xEventListItem ) );
|
|
8006082: 68fb ldr r3, [r7, #12]
|
|
8006084: 3318 adds r3, #24
|
|
8006086: 0018 movs r0, r3
|
|
8006088: f7ff f899 bl 80051be <uxListRemove>
|
|
( void ) uxListRemove( &( pxTCB->xStateListItem ) );
|
|
800608c: 68fb ldr r3, [r7, #12]
|
|
800608e: 3304 adds r3, #4
|
|
8006090: 0018 movs r0, r3
|
|
8006092: f7ff f894 bl 80051be <uxListRemove>
|
|
prvAddTaskToReadyList( pxTCB );
|
|
8006096: 68fb ldr r3, [r7, #12]
|
|
8006098: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
800609a: 4b2a ldr r3, [pc, #168] ; (8006144 <xTaskResumeAll+0x104>)
|
|
800609c: 681b ldr r3, [r3, #0]
|
|
800609e: 429a cmp r2, r3
|
|
80060a0: d903 bls.n 80060aa <xTaskResumeAll+0x6a>
|
|
80060a2: 68fb ldr r3, [r7, #12]
|
|
80060a4: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
80060a6: 4b27 ldr r3, [pc, #156] ; (8006144 <xTaskResumeAll+0x104>)
|
|
80060a8: 601a str r2, [r3, #0]
|
|
80060aa: 68fb ldr r3, [r7, #12]
|
|
80060ac: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
80060ae: 0013 movs r3, r2
|
|
80060b0: 009b lsls r3, r3, #2
|
|
80060b2: 189b adds r3, r3, r2
|
|
80060b4: 009b lsls r3, r3, #2
|
|
80060b6: 4a24 ldr r2, [pc, #144] ; (8006148 <xTaskResumeAll+0x108>)
|
|
80060b8: 189a adds r2, r3, r2
|
|
80060ba: 68fb ldr r3, [r7, #12]
|
|
80060bc: 3304 adds r3, #4
|
|
80060be: 0019 movs r1, r3
|
|
80060c0: 0010 movs r0, r2
|
|
80060c2: f7ff f824 bl 800510e <vListInsertEnd>
|
|
|
|
/* If the moved task has a priority higher than the current
|
|
task then a yield must be performed. */
|
|
if( pxTCB->uxPriority >= pxCurrentTCB->uxPriority )
|
|
80060c6: 68fb ldr r3, [r7, #12]
|
|
80060c8: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
80060ca: 4b20 ldr r3, [pc, #128] ; (800614c <xTaskResumeAll+0x10c>)
|
|
80060cc: 681b ldr r3, [r3, #0]
|
|
80060ce: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
80060d0: 429a cmp r2, r3
|
|
80060d2: d302 bcc.n 80060da <xTaskResumeAll+0x9a>
|
|
{
|
|
xYieldPending = pdTRUE;
|
|
80060d4: 4b1e ldr r3, [pc, #120] ; (8006150 <xTaskResumeAll+0x110>)
|
|
80060d6: 2201 movs r2, #1
|
|
80060d8: 601a str r2, [r3, #0]
|
|
while( listLIST_IS_EMPTY( &xPendingReadyList ) == pdFALSE )
|
|
80060da: 4b19 ldr r3, [pc, #100] ; (8006140 <xTaskResumeAll+0x100>)
|
|
80060dc: 681b ldr r3, [r3, #0]
|
|
80060de: 2b00 cmp r3, #0
|
|
80060e0: d1cb bne.n 800607a <xTaskResumeAll+0x3a>
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
|
|
if( pxTCB != NULL )
|
|
80060e2: 68fb ldr r3, [r7, #12]
|
|
80060e4: 2b00 cmp r3, #0
|
|
80060e6: d001 beq.n 80060ec <xTaskResumeAll+0xac>
|
|
which may have prevented the next unblock time from being
|
|
re-calculated, in which case re-calculate it now. Mainly
|
|
important for low power tickless implementations, where
|
|
this can prevent an unnecessary exit from low power
|
|
state. */
|
|
prvResetNextTaskUnblockTime();
|
|
80060e8: f000 fb80 bl 80067ec <prvResetNextTaskUnblockTime>
|
|
/* If any ticks occurred while the scheduler was suspended then
|
|
they should be processed now. This ensures the tick count does
|
|
not slip, and that any delayed tasks are resumed at the correct
|
|
time. */
|
|
{
|
|
UBaseType_t uxPendedCounts = uxPendedTicks; /* Non-volatile copy. */
|
|
80060ec: 4b19 ldr r3, [pc, #100] ; (8006154 <xTaskResumeAll+0x114>)
|
|
80060ee: 681b ldr r3, [r3, #0]
|
|
80060f0: 607b str r3, [r7, #4]
|
|
|
|
if( uxPendedCounts > ( UBaseType_t ) 0U )
|
|
80060f2: 687b ldr r3, [r7, #4]
|
|
80060f4: 2b00 cmp r3, #0
|
|
80060f6: d00f beq.n 8006118 <xTaskResumeAll+0xd8>
|
|
{
|
|
do
|
|
{
|
|
if( xTaskIncrementTick() != pdFALSE )
|
|
80060f8: f000 f858 bl 80061ac <xTaskIncrementTick>
|
|
80060fc: 1e03 subs r3, r0, #0
|
|
80060fe: d002 beq.n 8006106 <xTaskResumeAll+0xc6>
|
|
{
|
|
xYieldPending = pdTRUE;
|
|
8006100: 4b13 ldr r3, [pc, #76] ; (8006150 <xTaskResumeAll+0x110>)
|
|
8006102: 2201 movs r2, #1
|
|
8006104: 601a str r2, [r3, #0]
|
|
}
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
--uxPendedCounts;
|
|
8006106: 687b ldr r3, [r7, #4]
|
|
8006108: 3b01 subs r3, #1
|
|
800610a: 607b str r3, [r7, #4]
|
|
} while( uxPendedCounts > ( UBaseType_t ) 0U );
|
|
800610c: 687b ldr r3, [r7, #4]
|
|
800610e: 2b00 cmp r3, #0
|
|
8006110: d1f2 bne.n 80060f8 <xTaskResumeAll+0xb8>
|
|
|
|
uxPendedTicks = 0;
|
|
8006112: 4b10 ldr r3, [pc, #64] ; (8006154 <xTaskResumeAll+0x114>)
|
|
8006114: 2200 movs r2, #0
|
|
8006116: 601a str r2, [r3, #0]
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
|
|
if( xYieldPending != pdFALSE )
|
|
8006118: 4b0d ldr r3, [pc, #52] ; (8006150 <xTaskResumeAll+0x110>)
|
|
800611a: 681b ldr r3, [r3, #0]
|
|
800611c: 2b00 cmp r3, #0
|
|
800611e: d003 beq.n 8006128 <xTaskResumeAll+0xe8>
|
|
{
|
|
#if( configUSE_PREEMPTION != 0 )
|
|
{
|
|
xAlreadyYielded = pdTRUE;
|
|
8006120: 2301 movs r3, #1
|
|
8006122: 60bb str r3, [r7, #8]
|
|
}
|
|
#endif
|
|
taskYIELD_IF_USING_PREEMPTION();
|
|
8006124: f000 ffec bl 8007100 <vPortYield>
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
taskEXIT_CRITICAL();
|
|
8006128: f001 f80c bl 8007144 <vPortExitCritical>
|
|
|
|
return xAlreadyYielded;
|
|
800612c: 68bb ldr r3, [r7, #8]
|
|
}
|
|
800612e: 0018 movs r0, r3
|
|
8006130: 46bd mov sp, r7
|
|
8006132: b004 add sp, #16
|
|
8006134: bd80 pop {r7, pc}
|
|
8006136: 46c0 nop ; (mov r8, r8)
|
|
8006138: 20000be8 .word 0x20000be8
|
|
800613c: 20000bc0 .word 0x20000bc0
|
|
8006140: 20000b80 .word 0x20000b80
|
|
8006144: 20000bc8 .word 0x20000bc8
|
|
8006148: 200006f0 .word 0x200006f0
|
|
800614c: 200006ec .word 0x200006ec
|
|
8006150: 20000bd4 .word 0x20000bd4
|
|
8006154: 20000bd0 .word 0x20000bd0
|
|
|
|
08006158 <xTaskGetTickCount>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
TickType_t xTaskGetTickCount( void )
|
|
{
|
|
8006158: b580 push {r7, lr}
|
|
800615a: b082 sub sp, #8
|
|
800615c: af00 add r7, sp, #0
|
|
TickType_t xTicks;
|
|
|
|
/* Critical section required if running on a 16 bit processor. */
|
|
portTICK_TYPE_ENTER_CRITICAL();
|
|
{
|
|
xTicks = xTickCount;
|
|
800615e: 4b04 ldr r3, [pc, #16] ; (8006170 <xTaskGetTickCount+0x18>)
|
|
8006160: 681b ldr r3, [r3, #0]
|
|
8006162: 607b str r3, [r7, #4]
|
|
}
|
|
portTICK_TYPE_EXIT_CRITICAL();
|
|
|
|
return xTicks;
|
|
8006164: 687b ldr r3, [r7, #4]
|
|
}
|
|
8006166: 0018 movs r0, r3
|
|
8006168: 46bd mov sp, r7
|
|
800616a: b002 add sp, #8
|
|
800616c: bd80 pop {r7, pc}
|
|
800616e: 46c0 nop ; (mov r8, r8)
|
|
8006170: 20000bc4 .word 0x20000bc4
|
|
|
|
08006174 <vTaskStepTick>:
|
|
implementations require configUSE_TICKLESS_IDLE to be set to a value other than
|
|
1. */
|
|
#if ( configUSE_TICKLESS_IDLE != 0 )
|
|
|
|
void vTaskStepTick( const TickType_t xTicksToJump )
|
|
{
|
|
8006174: b580 push {r7, lr}
|
|
8006176: b082 sub sp, #8
|
|
8006178: af00 add r7, sp, #0
|
|
800617a: 6078 str r0, [r7, #4]
|
|
/* Correct the tick count value after a period during which the tick
|
|
was suppressed. Note this does *not* call the tick hook function for
|
|
each stepped tick. */
|
|
configASSERT( ( xTickCount + xTicksToJump ) <= xNextTaskUnblockTime );
|
|
800617c: 4b09 ldr r3, [pc, #36] ; (80061a4 <vTaskStepTick+0x30>)
|
|
800617e: 681a ldr r2, [r3, #0]
|
|
8006180: 687b ldr r3, [r7, #4]
|
|
8006182: 18d2 adds r2, r2, r3
|
|
8006184: 4b08 ldr r3, [pc, #32] ; (80061a8 <vTaskStepTick+0x34>)
|
|
8006186: 681b ldr r3, [r3, #0]
|
|
8006188: 429a cmp r2, r3
|
|
800618a: d901 bls.n 8006190 <vTaskStepTick+0x1c>
|
|
800618c: b672 cpsid i
|
|
800618e: e7fe b.n 800618e <vTaskStepTick+0x1a>
|
|
xTickCount += xTicksToJump;
|
|
8006190: 4b04 ldr r3, [pc, #16] ; (80061a4 <vTaskStepTick+0x30>)
|
|
8006192: 681a ldr r2, [r3, #0]
|
|
8006194: 687b ldr r3, [r7, #4]
|
|
8006196: 18d2 adds r2, r2, r3
|
|
8006198: 4b02 ldr r3, [pc, #8] ; (80061a4 <vTaskStepTick+0x30>)
|
|
800619a: 601a str r2, [r3, #0]
|
|
traceINCREASE_TICK_COUNT( xTicksToJump );
|
|
}
|
|
800619c: 46c0 nop ; (mov r8, r8)
|
|
800619e: 46bd mov sp, r7
|
|
80061a0: b002 add sp, #8
|
|
80061a2: bd80 pop {r7, pc}
|
|
80061a4: 20000bc4 .word 0x20000bc4
|
|
80061a8: 20000be0 .word 0x20000be0
|
|
|
|
080061ac <xTaskIncrementTick>:
|
|
|
|
#endif /* INCLUDE_xTaskAbortDelay */
|
|
/*----------------------------------------------------------*/
|
|
|
|
BaseType_t xTaskIncrementTick( void )
|
|
{
|
|
80061ac: b580 push {r7, lr}
|
|
80061ae: b086 sub sp, #24
|
|
80061b0: af00 add r7, sp, #0
|
|
TCB_t * pxTCB;
|
|
TickType_t xItemValue;
|
|
BaseType_t xSwitchRequired = pdFALSE;
|
|
80061b2: 2300 movs r3, #0
|
|
80061b4: 617b str r3, [r7, #20]
|
|
|
|
/* Called by the portable layer each time a tick interrupt occurs.
|
|
Increments the tick then checks to see if the new tick value will cause any
|
|
tasks to be unblocked. */
|
|
traceTASK_INCREMENT_TICK( xTickCount );
|
|
if( uxSchedulerSuspended == ( UBaseType_t ) pdFALSE )
|
|
80061b6: 4b4a ldr r3, [pc, #296] ; (80062e0 <xTaskIncrementTick+0x134>)
|
|
80061b8: 681b ldr r3, [r3, #0]
|
|
80061ba: 2b00 cmp r3, #0
|
|
80061bc: d000 beq.n 80061c0 <xTaskIncrementTick+0x14>
|
|
80061be: e07e b.n 80062be <xTaskIncrementTick+0x112>
|
|
{
|
|
/* Minor optimisation. The tick count cannot change in this
|
|
block. */
|
|
const TickType_t xConstTickCount = xTickCount + ( TickType_t ) 1;
|
|
80061c0: 4b48 ldr r3, [pc, #288] ; (80062e4 <xTaskIncrementTick+0x138>)
|
|
80061c2: 681b ldr r3, [r3, #0]
|
|
80061c4: 3301 adds r3, #1
|
|
80061c6: 613b str r3, [r7, #16]
|
|
|
|
/* Increment the RTOS tick, switching the delayed and overflowed
|
|
delayed lists if it wraps to 0. */
|
|
xTickCount = xConstTickCount;
|
|
80061c8: 4b46 ldr r3, [pc, #280] ; (80062e4 <xTaskIncrementTick+0x138>)
|
|
80061ca: 693a ldr r2, [r7, #16]
|
|
80061cc: 601a str r2, [r3, #0]
|
|
|
|
if( xConstTickCount == ( TickType_t ) 0U ) /*lint !e774 'if' does not always evaluate to false as it is looking for an overflow. */
|
|
80061ce: 693b ldr r3, [r7, #16]
|
|
80061d0: 2b00 cmp r3, #0
|
|
80061d2: d117 bne.n 8006204 <xTaskIncrementTick+0x58>
|
|
{
|
|
taskSWITCH_DELAYED_LISTS();
|
|
80061d4: 4b44 ldr r3, [pc, #272] ; (80062e8 <xTaskIncrementTick+0x13c>)
|
|
80061d6: 681b ldr r3, [r3, #0]
|
|
80061d8: 681b ldr r3, [r3, #0]
|
|
80061da: 2b00 cmp r3, #0
|
|
80061dc: d001 beq.n 80061e2 <xTaskIncrementTick+0x36>
|
|
80061de: b672 cpsid i
|
|
80061e0: e7fe b.n 80061e0 <xTaskIncrementTick+0x34>
|
|
80061e2: 4b41 ldr r3, [pc, #260] ; (80062e8 <xTaskIncrementTick+0x13c>)
|
|
80061e4: 681b ldr r3, [r3, #0]
|
|
80061e6: 60fb str r3, [r7, #12]
|
|
80061e8: 4b40 ldr r3, [pc, #256] ; (80062ec <xTaskIncrementTick+0x140>)
|
|
80061ea: 681a ldr r2, [r3, #0]
|
|
80061ec: 4b3e ldr r3, [pc, #248] ; (80062e8 <xTaskIncrementTick+0x13c>)
|
|
80061ee: 601a str r2, [r3, #0]
|
|
80061f0: 4b3e ldr r3, [pc, #248] ; (80062ec <xTaskIncrementTick+0x140>)
|
|
80061f2: 68fa ldr r2, [r7, #12]
|
|
80061f4: 601a str r2, [r3, #0]
|
|
80061f6: 4b3e ldr r3, [pc, #248] ; (80062f0 <xTaskIncrementTick+0x144>)
|
|
80061f8: 681b ldr r3, [r3, #0]
|
|
80061fa: 1c5a adds r2, r3, #1
|
|
80061fc: 4b3c ldr r3, [pc, #240] ; (80062f0 <xTaskIncrementTick+0x144>)
|
|
80061fe: 601a str r2, [r3, #0]
|
|
8006200: f000 faf4 bl 80067ec <prvResetNextTaskUnblockTime>
|
|
|
|
/* See if this tick has made a timeout expire. Tasks are stored in
|
|
the queue in the order of their wake time - meaning once one task
|
|
has been found whose block time has not expired there is no need to
|
|
look any further down the list. */
|
|
if( xConstTickCount >= xNextTaskUnblockTime )
|
|
8006204: 4b3b ldr r3, [pc, #236] ; (80062f4 <xTaskIncrementTick+0x148>)
|
|
8006206: 681b ldr r3, [r3, #0]
|
|
8006208: 693a ldr r2, [r7, #16]
|
|
800620a: 429a cmp r2, r3
|
|
800620c: d349 bcc.n 80062a2 <xTaskIncrementTick+0xf6>
|
|
{
|
|
for( ;; )
|
|
{
|
|
if( listLIST_IS_EMPTY( pxDelayedTaskList ) != pdFALSE )
|
|
800620e: 4b36 ldr r3, [pc, #216] ; (80062e8 <xTaskIncrementTick+0x13c>)
|
|
8006210: 681b ldr r3, [r3, #0]
|
|
8006212: 681b ldr r3, [r3, #0]
|
|
8006214: 2b00 cmp r3, #0
|
|
8006216: d104 bne.n 8006222 <xTaskIncrementTick+0x76>
|
|
/* The delayed list is empty. Set xNextTaskUnblockTime
|
|
to the maximum possible value so it is extremely
|
|
unlikely that the
|
|
if( xTickCount >= xNextTaskUnblockTime ) test will pass
|
|
next time through. */
|
|
xNextTaskUnblockTime = portMAX_DELAY; /*lint !e961 MISRA exception as the casts are only redundant for some ports. */
|
|
8006218: 4b36 ldr r3, [pc, #216] ; (80062f4 <xTaskIncrementTick+0x148>)
|
|
800621a: 2201 movs r2, #1
|
|
800621c: 4252 negs r2, r2
|
|
800621e: 601a str r2, [r3, #0]
|
|
break;
|
|
8006220: e03f b.n 80062a2 <xTaskIncrementTick+0xf6>
|
|
{
|
|
/* The delayed list is not empty, get the value of the
|
|
item at the head of the delayed list. This is the time
|
|
at which the task at the head of the delayed list must
|
|
be removed from the Blocked state. */
|
|
pxTCB = listGET_OWNER_OF_HEAD_ENTRY( pxDelayedTaskList ); /*lint !e9079 void * is used as this macro is used with timers and co-routines too. Alignment is known to be fine as the type of the pointer stored and retrieved is the same. */
|
|
8006222: 4b31 ldr r3, [pc, #196] ; (80062e8 <xTaskIncrementTick+0x13c>)
|
|
8006224: 681b ldr r3, [r3, #0]
|
|
8006226: 68db ldr r3, [r3, #12]
|
|
8006228: 68db ldr r3, [r3, #12]
|
|
800622a: 60bb str r3, [r7, #8]
|
|
xItemValue = listGET_LIST_ITEM_VALUE( &( pxTCB->xStateListItem ) );
|
|
800622c: 68bb ldr r3, [r7, #8]
|
|
800622e: 685b ldr r3, [r3, #4]
|
|
8006230: 607b str r3, [r7, #4]
|
|
|
|
if( xConstTickCount < xItemValue )
|
|
8006232: 693a ldr r2, [r7, #16]
|
|
8006234: 687b ldr r3, [r7, #4]
|
|
8006236: 429a cmp r2, r3
|
|
8006238: d203 bcs.n 8006242 <xTaskIncrementTick+0x96>
|
|
/* It is not time to unblock this item yet, but the
|
|
item value is the time at which the task at the head
|
|
of the blocked list must be removed from the Blocked
|
|
state - so record the item value in
|
|
xNextTaskUnblockTime. */
|
|
xNextTaskUnblockTime = xItemValue;
|
|
800623a: 4b2e ldr r3, [pc, #184] ; (80062f4 <xTaskIncrementTick+0x148>)
|
|
800623c: 687a ldr r2, [r7, #4]
|
|
800623e: 601a str r2, [r3, #0]
|
|
break; /*lint !e9011 Code structure here is deedmed easier to understand with multiple breaks. */
|
|
8006240: e02f b.n 80062a2 <xTaskIncrementTick+0xf6>
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
/* It is time to remove the item from the Blocked state. */
|
|
( void ) uxListRemove( &( pxTCB->xStateListItem ) );
|
|
8006242: 68bb ldr r3, [r7, #8]
|
|
8006244: 3304 adds r3, #4
|
|
8006246: 0018 movs r0, r3
|
|
8006248: f7fe ffb9 bl 80051be <uxListRemove>
|
|
|
|
/* Is the task waiting on an event also? If so remove
|
|
it from the event list. */
|
|
if( listLIST_ITEM_CONTAINER( &( pxTCB->xEventListItem ) ) != NULL )
|
|
800624c: 68bb ldr r3, [r7, #8]
|
|
800624e: 6a9b ldr r3, [r3, #40] ; 0x28
|
|
8006250: 2b00 cmp r3, #0
|
|
8006252: d004 beq.n 800625e <xTaskIncrementTick+0xb2>
|
|
{
|
|
( void ) uxListRemove( &( pxTCB->xEventListItem ) );
|
|
8006254: 68bb ldr r3, [r7, #8]
|
|
8006256: 3318 adds r3, #24
|
|
8006258: 0018 movs r0, r3
|
|
800625a: f7fe ffb0 bl 80051be <uxListRemove>
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
/* Place the unblocked task into the appropriate ready
|
|
list. */
|
|
prvAddTaskToReadyList( pxTCB );
|
|
800625e: 68bb ldr r3, [r7, #8]
|
|
8006260: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8006262: 4b25 ldr r3, [pc, #148] ; (80062f8 <xTaskIncrementTick+0x14c>)
|
|
8006264: 681b ldr r3, [r3, #0]
|
|
8006266: 429a cmp r2, r3
|
|
8006268: d903 bls.n 8006272 <xTaskIncrementTick+0xc6>
|
|
800626a: 68bb ldr r3, [r7, #8]
|
|
800626c: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
800626e: 4b22 ldr r3, [pc, #136] ; (80062f8 <xTaskIncrementTick+0x14c>)
|
|
8006270: 601a str r2, [r3, #0]
|
|
8006272: 68bb ldr r3, [r7, #8]
|
|
8006274: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8006276: 0013 movs r3, r2
|
|
8006278: 009b lsls r3, r3, #2
|
|
800627a: 189b adds r3, r3, r2
|
|
800627c: 009b lsls r3, r3, #2
|
|
800627e: 4a1f ldr r2, [pc, #124] ; (80062fc <xTaskIncrementTick+0x150>)
|
|
8006280: 189a adds r2, r3, r2
|
|
8006282: 68bb ldr r3, [r7, #8]
|
|
8006284: 3304 adds r3, #4
|
|
8006286: 0019 movs r1, r3
|
|
8006288: 0010 movs r0, r2
|
|
800628a: f7fe ff40 bl 800510e <vListInsertEnd>
|
|
{
|
|
/* Preemption is on, but a context switch should
|
|
only be performed if the unblocked task has a
|
|
priority that is equal to or higher than the
|
|
currently executing task. */
|
|
if( pxTCB->uxPriority >= pxCurrentTCB->uxPriority )
|
|
800628e: 68bb ldr r3, [r7, #8]
|
|
8006290: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8006292: 4b1b ldr r3, [pc, #108] ; (8006300 <xTaskIncrementTick+0x154>)
|
|
8006294: 681b ldr r3, [r3, #0]
|
|
8006296: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
8006298: 429a cmp r2, r3
|
|
800629a: d3b8 bcc.n 800620e <xTaskIncrementTick+0x62>
|
|
{
|
|
xSwitchRequired = pdTRUE;
|
|
800629c: 2301 movs r3, #1
|
|
800629e: 617b str r3, [r7, #20]
|
|
if( listLIST_IS_EMPTY( pxDelayedTaskList ) != pdFALSE )
|
|
80062a0: e7b5 b.n 800620e <xTaskIncrementTick+0x62>
|
|
/* Tasks of equal priority to the currently running task will share
|
|
processing time (time slice) if preemption is on, and the application
|
|
writer has not explicitly turned time slicing off. */
|
|
#if ( ( configUSE_PREEMPTION == 1 ) && ( configUSE_TIME_SLICING == 1 ) )
|
|
{
|
|
if( listCURRENT_LIST_LENGTH( &( pxReadyTasksLists[ pxCurrentTCB->uxPriority ] ) ) > ( UBaseType_t ) 1 )
|
|
80062a2: 4b17 ldr r3, [pc, #92] ; (8006300 <xTaskIncrementTick+0x154>)
|
|
80062a4: 681b ldr r3, [r3, #0]
|
|
80062a6: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
80062a8: 4914 ldr r1, [pc, #80] ; (80062fc <xTaskIncrementTick+0x150>)
|
|
80062aa: 0013 movs r3, r2
|
|
80062ac: 009b lsls r3, r3, #2
|
|
80062ae: 189b adds r3, r3, r2
|
|
80062b0: 009b lsls r3, r3, #2
|
|
80062b2: 585b ldr r3, [r3, r1]
|
|
80062b4: 2b01 cmp r3, #1
|
|
80062b6: d907 bls.n 80062c8 <xTaskIncrementTick+0x11c>
|
|
{
|
|
xSwitchRequired = pdTRUE;
|
|
80062b8: 2301 movs r3, #1
|
|
80062ba: 617b str r3, [r7, #20]
|
|
80062bc: e004 b.n 80062c8 <xTaskIncrementTick+0x11c>
|
|
}
|
|
#endif /* configUSE_TICK_HOOK */
|
|
}
|
|
else
|
|
{
|
|
++uxPendedTicks;
|
|
80062be: 4b11 ldr r3, [pc, #68] ; (8006304 <xTaskIncrementTick+0x158>)
|
|
80062c0: 681b ldr r3, [r3, #0]
|
|
80062c2: 1c5a adds r2, r3, #1
|
|
80062c4: 4b0f ldr r3, [pc, #60] ; (8006304 <xTaskIncrementTick+0x158>)
|
|
80062c6: 601a str r2, [r3, #0]
|
|
#endif
|
|
}
|
|
|
|
#if ( configUSE_PREEMPTION == 1 )
|
|
{
|
|
if( xYieldPending != pdFALSE )
|
|
80062c8: 4b0f ldr r3, [pc, #60] ; (8006308 <xTaskIncrementTick+0x15c>)
|
|
80062ca: 681b ldr r3, [r3, #0]
|
|
80062cc: 2b00 cmp r3, #0
|
|
80062ce: d001 beq.n 80062d4 <xTaskIncrementTick+0x128>
|
|
{
|
|
xSwitchRequired = pdTRUE;
|
|
80062d0: 2301 movs r3, #1
|
|
80062d2: 617b str r3, [r7, #20]
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
#endif /* configUSE_PREEMPTION */
|
|
|
|
return xSwitchRequired;
|
|
80062d4: 697b ldr r3, [r7, #20]
|
|
}
|
|
80062d6: 0018 movs r0, r3
|
|
80062d8: 46bd mov sp, r7
|
|
80062da: b006 add sp, #24
|
|
80062dc: bd80 pop {r7, pc}
|
|
80062de: 46c0 nop ; (mov r8, r8)
|
|
80062e0: 20000be8 .word 0x20000be8
|
|
80062e4: 20000bc4 .word 0x20000bc4
|
|
80062e8: 20000b78 .word 0x20000b78
|
|
80062ec: 20000b7c .word 0x20000b7c
|
|
80062f0: 20000bd8 .word 0x20000bd8
|
|
80062f4: 20000be0 .word 0x20000be0
|
|
80062f8: 20000bc8 .word 0x20000bc8
|
|
80062fc: 200006f0 .word 0x200006f0
|
|
8006300: 200006ec .word 0x200006ec
|
|
8006304: 20000bd0 .word 0x20000bd0
|
|
8006308: 20000bd4 .word 0x20000bd4
|
|
|
|
0800630c <vTaskSwitchContext>:
|
|
|
|
#endif /* configUSE_APPLICATION_TASK_TAG */
|
|
/*-----------------------------------------------------------*/
|
|
|
|
void vTaskSwitchContext( void )
|
|
{
|
|
800630c: b580 push {r7, lr}
|
|
800630e: b082 sub sp, #8
|
|
8006310: af00 add r7, sp, #0
|
|
if( uxSchedulerSuspended != ( UBaseType_t ) pdFALSE )
|
|
8006312: 4b22 ldr r3, [pc, #136] ; (800639c <vTaskSwitchContext+0x90>)
|
|
8006314: 681b ldr r3, [r3, #0]
|
|
8006316: 2b00 cmp r3, #0
|
|
8006318: d003 beq.n 8006322 <vTaskSwitchContext+0x16>
|
|
{
|
|
/* The scheduler is currently suspended - do not allow a context
|
|
switch. */
|
|
xYieldPending = pdTRUE;
|
|
800631a: 4b21 ldr r3, [pc, #132] ; (80063a0 <vTaskSwitchContext+0x94>)
|
|
800631c: 2201 movs r2, #1
|
|
800631e: 601a str r2, [r3, #0]
|
|
structure specific to this task. */
|
|
_impure_ptr = &( pxCurrentTCB->xNewLib_reent );
|
|
}
|
|
#endif /* configUSE_NEWLIB_REENTRANT */
|
|
}
|
|
}
|
|
8006320: e037 b.n 8006392 <vTaskSwitchContext+0x86>
|
|
xYieldPending = pdFALSE;
|
|
8006322: 4b1f ldr r3, [pc, #124] ; (80063a0 <vTaskSwitchContext+0x94>)
|
|
8006324: 2200 movs r2, #0
|
|
8006326: 601a str r2, [r3, #0]
|
|
taskSELECT_HIGHEST_PRIORITY_TASK(); /*lint !e9079 void * is used as this macro is used with timers and co-routines too. Alignment is known to be fine as the type of the pointer stored and retrieved is the same. */
|
|
8006328: 4b1e ldr r3, [pc, #120] ; (80063a4 <vTaskSwitchContext+0x98>)
|
|
800632a: 681b ldr r3, [r3, #0]
|
|
800632c: 607b str r3, [r7, #4]
|
|
800632e: e007 b.n 8006340 <vTaskSwitchContext+0x34>
|
|
8006330: 687b ldr r3, [r7, #4]
|
|
8006332: 2b00 cmp r3, #0
|
|
8006334: d101 bne.n 800633a <vTaskSwitchContext+0x2e>
|
|
8006336: b672 cpsid i
|
|
8006338: e7fe b.n 8006338 <vTaskSwitchContext+0x2c>
|
|
800633a: 687b ldr r3, [r7, #4]
|
|
800633c: 3b01 subs r3, #1
|
|
800633e: 607b str r3, [r7, #4]
|
|
8006340: 4919 ldr r1, [pc, #100] ; (80063a8 <vTaskSwitchContext+0x9c>)
|
|
8006342: 687a ldr r2, [r7, #4]
|
|
8006344: 0013 movs r3, r2
|
|
8006346: 009b lsls r3, r3, #2
|
|
8006348: 189b adds r3, r3, r2
|
|
800634a: 009b lsls r3, r3, #2
|
|
800634c: 585b ldr r3, [r3, r1]
|
|
800634e: 2b00 cmp r3, #0
|
|
8006350: d0ee beq.n 8006330 <vTaskSwitchContext+0x24>
|
|
8006352: 687a ldr r2, [r7, #4]
|
|
8006354: 0013 movs r3, r2
|
|
8006356: 009b lsls r3, r3, #2
|
|
8006358: 189b adds r3, r3, r2
|
|
800635a: 009b lsls r3, r3, #2
|
|
800635c: 4a12 ldr r2, [pc, #72] ; (80063a8 <vTaskSwitchContext+0x9c>)
|
|
800635e: 189b adds r3, r3, r2
|
|
8006360: 603b str r3, [r7, #0]
|
|
8006362: 683b ldr r3, [r7, #0]
|
|
8006364: 685b ldr r3, [r3, #4]
|
|
8006366: 685a ldr r2, [r3, #4]
|
|
8006368: 683b ldr r3, [r7, #0]
|
|
800636a: 605a str r2, [r3, #4]
|
|
800636c: 683b ldr r3, [r7, #0]
|
|
800636e: 685a ldr r2, [r3, #4]
|
|
8006370: 683b ldr r3, [r7, #0]
|
|
8006372: 3308 adds r3, #8
|
|
8006374: 429a cmp r2, r3
|
|
8006376: d104 bne.n 8006382 <vTaskSwitchContext+0x76>
|
|
8006378: 683b ldr r3, [r7, #0]
|
|
800637a: 685b ldr r3, [r3, #4]
|
|
800637c: 685a ldr r2, [r3, #4]
|
|
800637e: 683b ldr r3, [r7, #0]
|
|
8006380: 605a str r2, [r3, #4]
|
|
8006382: 683b ldr r3, [r7, #0]
|
|
8006384: 685b ldr r3, [r3, #4]
|
|
8006386: 68da ldr r2, [r3, #12]
|
|
8006388: 4b08 ldr r3, [pc, #32] ; (80063ac <vTaskSwitchContext+0xa0>)
|
|
800638a: 601a str r2, [r3, #0]
|
|
800638c: 4b05 ldr r3, [pc, #20] ; (80063a4 <vTaskSwitchContext+0x98>)
|
|
800638e: 687a ldr r2, [r7, #4]
|
|
8006390: 601a str r2, [r3, #0]
|
|
}
|
|
8006392: 46c0 nop ; (mov r8, r8)
|
|
8006394: 46bd mov sp, r7
|
|
8006396: b002 add sp, #8
|
|
8006398: bd80 pop {r7, pc}
|
|
800639a: 46c0 nop ; (mov r8, r8)
|
|
800639c: 20000be8 .word 0x20000be8
|
|
80063a0: 20000bd4 .word 0x20000bd4
|
|
80063a4: 20000bc8 .word 0x20000bc8
|
|
80063a8: 200006f0 .word 0x200006f0
|
|
80063ac: 200006ec .word 0x200006ec
|
|
|
|
080063b0 <vTaskPlaceOnEventList>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
void vTaskPlaceOnEventList( List_t * const pxEventList, const TickType_t xTicksToWait )
|
|
{
|
|
80063b0: b580 push {r7, lr}
|
|
80063b2: b082 sub sp, #8
|
|
80063b4: af00 add r7, sp, #0
|
|
80063b6: 6078 str r0, [r7, #4]
|
|
80063b8: 6039 str r1, [r7, #0]
|
|
configASSERT( pxEventList );
|
|
80063ba: 687b ldr r3, [r7, #4]
|
|
80063bc: 2b00 cmp r3, #0
|
|
80063be: d101 bne.n 80063c4 <vTaskPlaceOnEventList+0x14>
|
|
80063c0: b672 cpsid i
|
|
80063c2: e7fe b.n 80063c2 <vTaskPlaceOnEventList+0x12>
|
|
|
|
/* Place the event list item of the TCB in the appropriate event list.
|
|
This is placed in the list in priority order so the highest priority task
|
|
is the first to be woken by the event. The queue that contains the event
|
|
list is locked, preventing simultaneous access from interrupts. */
|
|
vListInsert( pxEventList, &( pxCurrentTCB->xEventListItem ) );
|
|
80063c4: 4b08 ldr r3, [pc, #32] ; (80063e8 <vTaskPlaceOnEventList+0x38>)
|
|
80063c6: 681b ldr r3, [r3, #0]
|
|
80063c8: 3318 adds r3, #24
|
|
80063ca: 001a movs r2, r3
|
|
80063cc: 687b ldr r3, [r7, #4]
|
|
80063ce: 0011 movs r1, r2
|
|
80063d0: 0018 movs r0, r3
|
|
80063d2: f7fe febe bl 8005152 <vListInsert>
|
|
|
|
prvAddCurrentTaskToDelayedList( xTicksToWait, pdTRUE );
|
|
80063d6: 683b ldr r3, [r7, #0]
|
|
80063d8: 2101 movs r1, #1
|
|
80063da: 0018 movs r0, r3
|
|
80063dc: f000 fa9c bl 8006918 <prvAddCurrentTaskToDelayedList>
|
|
}
|
|
80063e0: 46c0 nop ; (mov r8, r8)
|
|
80063e2: 46bd mov sp, r7
|
|
80063e4: b002 add sp, #8
|
|
80063e6: bd80 pop {r7, pc}
|
|
80063e8: 200006ec .word 0x200006ec
|
|
|
|
080063ec <vTaskPlaceOnEventListRestricted>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
#if( configUSE_TIMERS == 1 )
|
|
|
|
void vTaskPlaceOnEventListRestricted( List_t * const pxEventList, TickType_t xTicksToWait, const BaseType_t xWaitIndefinitely )
|
|
{
|
|
80063ec: b580 push {r7, lr}
|
|
80063ee: b084 sub sp, #16
|
|
80063f0: af00 add r7, sp, #0
|
|
80063f2: 60f8 str r0, [r7, #12]
|
|
80063f4: 60b9 str r1, [r7, #8]
|
|
80063f6: 607a str r2, [r7, #4]
|
|
configASSERT( pxEventList );
|
|
80063f8: 68fb ldr r3, [r7, #12]
|
|
80063fa: 2b00 cmp r3, #0
|
|
80063fc: d101 bne.n 8006402 <vTaskPlaceOnEventListRestricted+0x16>
|
|
80063fe: b672 cpsid i
|
|
8006400: e7fe b.n 8006400 <vTaskPlaceOnEventListRestricted+0x14>
|
|
|
|
/* Place the event list item of the TCB in the appropriate event list.
|
|
In this case it is assume that this is the only task that is going to
|
|
be waiting on this event list, so the faster vListInsertEnd() function
|
|
can be used in place of vListInsert. */
|
|
vListInsertEnd( pxEventList, &( pxCurrentTCB->xEventListItem ) );
|
|
8006402: 4b0c ldr r3, [pc, #48] ; (8006434 <vTaskPlaceOnEventListRestricted+0x48>)
|
|
8006404: 681b ldr r3, [r3, #0]
|
|
8006406: 3318 adds r3, #24
|
|
8006408: 001a movs r2, r3
|
|
800640a: 68fb ldr r3, [r7, #12]
|
|
800640c: 0011 movs r1, r2
|
|
800640e: 0018 movs r0, r3
|
|
8006410: f7fe fe7d bl 800510e <vListInsertEnd>
|
|
|
|
/* If the task should block indefinitely then set the block time to a
|
|
value that will be recognised as an indefinite delay inside the
|
|
prvAddCurrentTaskToDelayedList() function. */
|
|
if( xWaitIndefinitely != pdFALSE )
|
|
8006414: 687b ldr r3, [r7, #4]
|
|
8006416: 2b00 cmp r3, #0
|
|
8006418: d002 beq.n 8006420 <vTaskPlaceOnEventListRestricted+0x34>
|
|
{
|
|
xTicksToWait = portMAX_DELAY;
|
|
800641a: 2301 movs r3, #1
|
|
800641c: 425b negs r3, r3
|
|
800641e: 60bb str r3, [r7, #8]
|
|
}
|
|
|
|
traceTASK_DELAY_UNTIL( ( xTickCount + xTicksToWait ) );
|
|
prvAddCurrentTaskToDelayedList( xTicksToWait, xWaitIndefinitely );
|
|
8006420: 687a ldr r2, [r7, #4]
|
|
8006422: 68bb ldr r3, [r7, #8]
|
|
8006424: 0011 movs r1, r2
|
|
8006426: 0018 movs r0, r3
|
|
8006428: f000 fa76 bl 8006918 <prvAddCurrentTaskToDelayedList>
|
|
}
|
|
800642c: 46c0 nop ; (mov r8, r8)
|
|
800642e: 46bd mov sp, r7
|
|
8006430: b004 add sp, #16
|
|
8006432: bd80 pop {r7, pc}
|
|
8006434: 200006ec .word 0x200006ec
|
|
|
|
08006438 <xTaskRemoveFromEventList>:
|
|
|
|
#endif /* configUSE_TIMERS */
|
|
/*-----------------------------------------------------------*/
|
|
|
|
BaseType_t xTaskRemoveFromEventList( const List_t * const pxEventList )
|
|
{
|
|
8006438: b580 push {r7, lr}
|
|
800643a: b084 sub sp, #16
|
|
800643c: af00 add r7, sp, #0
|
|
800643e: 6078 str r0, [r7, #4]
|
|
get called - the lock count on the queue will get modified instead. This
|
|
means exclusive access to the event list is guaranteed here.
|
|
|
|
This function assumes that a check has already been made to ensure that
|
|
pxEventList is not empty. */
|
|
pxUnblockedTCB = listGET_OWNER_OF_HEAD_ENTRY( pxEventList ); /*lint !e9079 void * is used as this macro is used with timers and co-routines too. Alignment is known to be fine as the type of the pointer stored and retrieved is the same. */
|
|
8006440: 687b ldr r3, [r7, #4]
|
|
8006442: 68db ldr r3, [r3, #12]
|
|
8006444: 68db ldr r3, [r3, #12]
|
|
8006446: 60bb str r3, [r7, #8]
|
|
configASSERT( pxUnblockedTCB );
|
|
8006448: 68bb ldr r3, [r7, #8]
|
|
800644a: 2b00 cmp r3, #0
|
|
800644c: d101 bne.n 8006452 <xTaskRemoveFromEventList+0x1a>
|
|
800644e: b672 cpsid i
|
|
8006450: e7fe b.n 8006450 <xTaskRemoveFromEventList+0x18>
|
|
( void ) uxListRemove( &( pxUnblockedTCB->xEventListItem ) );
|
|
8006452: 68bb ldr r3, [r7, #8]
|
|
8006454: 3318 adds r3, #24
|
|
8006456: 0018 movs r0, r3
|
|
8006458: f7fe feb1 bl 80051be <uxListRemove>
|
|
|
|
if( uxSchedulerSuspended == ( UBaseType_t ) pdFALSE )
|
|
800645c: 4b1f ldr r3, [pc, #124] ; (80064dc <xTaskRemoveFromEventList+0xa4>)
|
|
800645e: 681b ldr r3, [r3, #0]
|
|
8006460: 2b00 cmp r3, #0
|
|
8006462: d11f bne.n 80064a4 <xTaskRemoveFromEventList+0x6c>
|
|
{
|
|
( void ) uxListRemove( &( pxUnblockedTCB->xStateListItem ) );
|
|
8006464: 68bb ldr r3, [r7, #8]
|
|
8006466: 3304 adds r3, #4
|
|
8006468: 0018 movs r0, r3
|
|
800646a: f7fe fea8 bl 80051be <uxListRemove>
|
|
prvAddTaskToReadyList( pxUnblockedTCB );
|
|
800646e: 68bb ldr r3, [r7, #8]
|
|
8006470: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8006472: 4b1b ldr r3, [pc, #108] ; (80064e0 <xTaskRemoveFromEventList+0xa8>)
|
|
8006474: 681b ldr r3, [r3, #0]
|
|
8006476: 429a cmp r2, r3
|
|
8006478: d903 bls.n 8006482 <xTaskRemoveFromEventList+0x4a>
|
|
800647a: 68bb ldr r3, [r7, #8]
|
|
800647c: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
800647e: 4b18 ldr r3, [pc, #96] ; (80064e0 <xTaskRemoveFromEventList+0xa8>)
|
|
8006480: 601a str r2, [r3, #0]
|
|
8006482: 68bb ldr r3, [r7, #8]
|
|
8006484: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
8006486: 0013 movs r3, r2
|
|
8006488: 009b lsls r3, r3, #2
|
|
800648a: 189b adds r3, r3, r2
|
|
800648c: 009b lsls r3, r3, #2
|
|
800648e: 4a15 ldr r2, [pc, #84] ; (80064e4 <xTaskRemoveFromEventList+0xac>)
|
|
8006490: 189a adds r2, r3, r2
|
|
8006492: 68bb ldr r3, [r7, #8]
|
|
8006494: 3304 adds r3, #4
|
|
8006496: 0019 movs r1, r3
|
|
8006498: 0010 movs r0, r2
|
|
800649a: f7fe fe38 bl 800510e <vListInsertEnd>
|
|
normally left unchanged, because it is automatically reset to a new
|
|
value when the tick count equals xNextTaskUnblockTime. However if
|
|
tickless idling is used it might be more important to enter sleep mode
|
|
at the earliest possible time - so reset xNextTaskUnblockTime here to
|
|
ensure it is updated at the earliest possible time. */
|
|
prvResetNextTaskUnblockTime();
|
|
800649e: f000 f9a5 bl 80067ec <prvResetNextTaskUnblockTime>
|
|
80064a2: e007 b.n 80064b4 <xTaskRemoveFromEventList+0x7c>
|
|
}
|
|
else
|
|
{
|
|
/* The delayed and ready lists cannot be accessed, so hold this task
|
|
pending until the scheduler is resumed. */
|
|
vListInsertEnd( &( xPendingReadyList ), &( pxUnblockedTCB->xEventListItem ) );
|
|
80064a4: 68bb ldr r3, [r7, #8]
|
|
80064a6: 3318 adds r3, #24
|
|
80064a8: 001a movs r2, r3
|
|
80064aa: 4b0f ldr r3, [pc, #60] ; (80064e8 <xTaskRemoveFromEventList+0xb0>)
|
|
80064ac: 0011 movs r1, r2
|
|
80064ae: 0018 movs r0, r3
|
|
80064b0: f7fe fe2d bl 800510e <vListInsertEnd>
|
|
}
|
|
|
|
if( pxUnblockedTCB->uxPriority > pxCurrentTCB->uxPriority )
|
|
80064b4: 68bb ldr r3, [r7, #8]
|
|
80064b6: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
80064b8: 4b0c ldr r3, [pc, #48] ; (80064ec <xTaskRemoveFromEventList+0xb4>)
|
|
80064ba: 681b ldr r3, [r3, #0]
|
|
80064bc: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
80064be: 429a cmp r2, r3
|
|
80064c0: d905 bls.n 80064ce <xTaskRemoveFromEventList+0x96>
|
|
{
|
|
/* Return true if the task removed from the event list has a higher
|
|
priority than the calling task. This allows the calling task to know if
|
|
it should force a context switch now. */
|
|
xReturn = pdTRUE;
|
|
80064c2: 2301 movs r3, #1
|
|
80064c4: 60fb str r3, [r7, #12]
|
|
|
|
/* Mark that a yield is pending in case the user is not using the
|
|
"xHigherPriorityTaskWoken" parameter to an ISR safe FreeRTOS function. */
|
|
xYieldPending = pdTRUE;
|
|
80064c6: 4b0a ldr r3, [pc, #40] ; (80064f0 <xTaskRemoveFromEventList+0xb8>)
|
|
80064c8: 2201 movs r2, #1
|
|
80064ca: 601a str r2, [r3, #0]
|
|
80064cc: e001 b.n 80064d2 <xTaskRemoveFromEventList+0x9a>
|
|
}
|
|
else
|
|
{
|
|
xReturn = pdFALSE;
|
|
80064ce: 2300 movs r3, #0
|
|
80064d0: 60fb str r3, [r7, #12]
|
|
}
|
|
|
|
return xReturn;
|
|
80064d2: 68fb ldr r3, [r7, #12]
|
|
}
|
|
80064d4: 0018 movs r0, r3
|
|
80064d6: 46bd mov sp, r7
|
|
80064d8: b004 add sp, #16
|
|
80064da: bd80 pop {r7, pc}
|
|
80064dc: 20000be8 .word 0x20000be8
|
|
80064e0: 20000bc8 .word 0x20000bc8
|
|
80064e4: 200006f0 .word 0x200006f0
|
|
80064e8: 20000b80 .word 0x20000b80
|
|
80064ec: 200006ec .word 0x200006ec
|
|
80064f0: 20000bd4 .word 0x20000bd4
|
|
|
|
080064f4 <vTaskInternalSetTimeOutState>:
|
|
taskEXIT_CRITICAL();
|
|
}
|
|
/*-----------------------------------------------------------*/
|
|
|
|
void vTaskInternalSetTimeOutState( TimeOut_t * const pxTimeOut )
|
|
{
|
|
80064f4: b580 push {r7, lr}
|
|
80064f6: b082 sub sp, #8
|
|
80064f8: af00 add r7, sp, #0
|
|
80064fa: 6078 str r0, [r7, #4]
|
|
/* For internal use only as it does not use a critical section. */
|
|
pxTimeOut->xOverflowCount = xNumOfOverflows;
|
|
80064fc: 4b05 ldr r3, [pc, #20] ; (8006514 <vTaskInternalSetTimeOutState+0x20>)
|
|
80064fe: 681a ldr r2, [r3, #0]
|
|
8006500: 687b ldr r3, [r7, #4]
|
|
8006502: 601a str r2, [r3, #0]
|
|
pxTimeOut->xTimeOnEntering = xTickCount;
|
|
8006504: 4b04 ldr r3, [pc, #16] ; (8006518 <vTaskInternalSetTimeOutState+0x24>)
|
|
8006506: 681a ldr r2, [r3, #0]
|
|
8006508: 687b ldr r3, [r7, #4]
|
|
800650a: 605a str r2, [r3, #4]
|
|
}
|
|
800650c: 46c0 nop ; (mov r8, r8)
|
|
800650e: 46bd mov sp, r7
|
|
8006510: b002 add sp, #8
|
|
8006512: bd80 pop {r7, pc}
|
|
8006514: 20000bd8 .word 0x20000bd8
|
|
8006518: 20000bc4 .word 0x20000bc4
|
|
|
|
0800651c <xTaskCheckForTimeOut>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
BaseType_t xTaskCheckForTimeOut( TimeOut_t * const pxTimeOut, TickType_t * const pxTicksToWait )
|
|
{
|
|
800651c: b580 push {r7, lr}
|
|
800651e: b086 sub sp, #24
|
|
8006520: af00 add r7, sp, #0
|
|
8006522: 6078 str r0, [r7, #4]
|
|
8006524: 6039 str r1, [r7, #0]
|
|
BaseType_t xReturn;
|
|
|
|
configASSERT( pxTimeOut );
|
|
8006526: 687b ldr r3, [r7, #4]
|
|
8006528: 2b00 cmp r3, #0
|
|
800652a: d101 bne.n 8006530 <xTaskCheckForTimeOut+0x14>
|
|
800652c: b672 cpsid i
|
|
800652e: e7fe b.n 800652e <xTaskCheckForTimeOut+0x12>
|
|
configASSERT( pxTicksToWait );
|
|
8006530: 683b ldr r3, [r7, #0]
|
|
8006532: 2b00 cmp r3, #0
|
|
8006534: d101 bne.n 800653a <xTaskCheckForTimeOut+0x1e>
|
|
8006536: b672 cpsid i
|
|
8006538: e7fe b.n 8006538 <xTaskCheckForTimeOut+0x1c>
|
|
|
|
taskENTER_CRITICAL();
|
|
800653a: f000 fdf1 bl 8007120 <vPortEnterCritical>
|
|
{
|
|
/* Minor optimisation. The tick count cannot change in this block. */
|
|
const TickType_t xConstTickCount = xTickCount;
|
|
800653e: 4b24 ldr r3, [pc, #144] ; (80065d0 <xTaskCheckForTimeOut+0xb4>)
|
|
8006540: 681b ldr r3, [r3, #0]
|
|
8006542: 613b str r3, [r7, #16]
|
|
const TickType_t xElapsedTime = xConstTickCount - pxTimeOut->xTimeOnEntering;
|
|
8006544: 687b ldr r3, [r7, #4]
|
|
8006546: 685b ldr r3, [r3, #4]
|
|
8006548: 693a ldr r2, [r7, #16]
|
|
800654a: 1ad3 subs r3, r2, r3
|
|
800654c: 60fb str r3, [r7, #12]
|
|
|
|
#if( INCLUDE_xTaskAbortDelay == 1 )
|
|
if( pxCurrentTCB->ucDelayAborted != ( uint8_t ) pdFALSE )
|
|
800654e: 4b21 ldr r3, [pc, #132] ; (80065d4 <xTaskCheckForTimeOut+0xb8>)
|
|
8006550: 681b ldr r3, [r3, #0]
|
|
8006552: 225a movs r2, #90 ; 0x5a
|
|
8006554: 5c9b ldrb r3, [r3, r2]
|
|
8006556: 2b00 cmp r3, #0
|
|
8006558: d007 beq.n 800656a <xTaskCheckForTimeOut+0x4e>
|
|
{
|
|
/* The delay was aborted, which is not the same as a time out,
|
|
but has the same result. */
|
|
pxCurrentTCB->ucDelayAborted = pdFALSE;
|
|
800655a: 4b1e ldr r3, [pc, #120] ; (80065d4 <xTaskCheckForTimeOut+0xb8>)
|
|
800655c: 681b ldr r3, [r3, #0]
|
|
800655e: 225a movs r2, #90 ; 0x5a
|
|
8006560: 2100 movs r1, #0
|
|
8006562: 5499 strb r1, [r3, r2]
|
|
xReturn = pdTRUE;
|
|
8006564: 2301 movs r3, #1
|
|
8006566: 617b str r3, [r7, #20]
|
|
8006568: e02b b.n 80065c2 <xTaskCheckForTimeOut+0xa6>
|
|
}
|
|
else
|
|
#endif
|
|
|
|
#if ( INCLUDE_vTaskSuspend == 1 )
|
|
if( *pxTicksToWait == portMAX_DELAY )
|
|
800656a: 683b ldr r3, [r7, #0]
|
|
800656c: 681b ldr r3, [r3, #0]
|
|
800656e: 3301 adds r3, #1
|
|
8006570: d102 bne.n 8006578 <xTaskCheckForTimeOut+0x5c>
|
|
{
|
|
/* If INCLUDE_vTaskSuspend is set to 1 and the block time
|
|
specified is the maximum block time then the task should block
|
|
indefinitely, and therefore never time out. */
|
|
xReturn = pdFALSE;
|
|
8006572: 2300 movs r3, #0
|
|
8006574: 617b str r3, [r7, #20]
|
|
8006576: e024 b.n 80065c2 <xTaskCheckForTimeOut+0xa6>
|
|
}
|
|
else
|
|
#endif
|
|
|
|
if( ( xNumOfOverflows != pxTimeOut->xOverflowCount ) && ( xConstTickCount >= pxTimeOut->xTimeOnEntering ) ) /*lint !e525 Indentation preferred as is to make code within pre-processor directives clearer. */
|
|
8006578: 687b ldr r3, [r7, #4]
|
|
800657a: 681a ldr r2, [r3, #0]
|
|
800657c: 4b16 ldr r3, [pc, #88] ; (80065d8 <xTaskCheckForTimeOut+0xbc>)
|
|
800657e: 681b ldr r3, [r3, #0]
|
|
8006580: 429a cmp r2, r3
|
|
8006582: d007 beq.n 8006594 <xTaskCheckForTimeOut+0x78>
|
|
8006584: 687b ldr r3, [r7, #4]
|
|
8006586: 685b ldr r3, [r3, #4]
|
|
8006588: 693a ldr r2, [r7, #16]
|
|
800658a: 429a cmp r2, r3
|
|
800658c: d302 bcc.n 8006594 <xTaskCheckForTimeOut+0x78>
|
|
/* The tick count is greater than the time at which
|
|
vTaskSetTimeout() was called, but has also overflowed since
|
|
vTaskSetTimeOut() was called. It must have wrapped all the way
|
|
around and gone past again. This passed since vTaskSetTimeout()
|
|
was called. */
|
|
xReturn = pdTRUE;
|
|
800658e: 2301 movs r3, #1
|
|
8006590: 617b str r3, [r7, #20]
|
|
8006592: e016 b.n 80065c2 <xTaskCheckForTimeOut+0xa6>
|
|
}
|
|
else if( xElapsedTime < *pxTicksToWait ) /*lint !e961 Explicit casting is only redundant with some compilers, whereas others require it to prevent integer conversion errors. */
|
|
8006594: 683b ldr r3, [r7, #0]
|
|
8006596: 681b ldr r3, [r3, #0]
|
|
8006598: 68fa ldr r2, [r7, #12]
|
|
800659a: 429a cmp r2, r3
|
|
800659c: d20c bcs.n 80065b8 <xTaskCheckForTimeOut+0x9c>
|
|
{
|
|
/* Not a genuine timeout. Adjust parameters for time remaining. */
|
|
*pxTicksToWait -= xElapsedTime;
|
|
800659e: 683b ldr r3, [r7, #0]
|
|
80065a0: 681a ldr r2, [r3, #0]
|
|
80065a2: 68fb ldr r3, [r7, #12]
|
|
80065a4: 1ad2 subs r2, r2, r3
|
|
80065a6: 683b ldr r3, [r7, #0]
|
|
80065a8: 601a str r2, [r3, #0]
|
|
vTaskInternalSetTimeOutState( pxTimeOut );
|
|
80065aa: 687b ldr r3, [r7, #4]
|
|
80065ac: 0018 movs r0, r3
|
|
80065ae: f7ff ffa1 bl 80064f4 <vTaskInternalSetTimeOutState>
|
|
xReturn = pdFALSE;
|
|
80065b2: 2300 movs r3, #0
|
|
80065b4: 617b str r3, [r7, #20]
|
|
80065b6: e004 b.n 80065c2 <xTaskCheckForTimeOut+0xa6>
|
|
}
|
|
else
|
|
{
|
|
*pxTicksToWait = 0;
|
|
80065b8: 683b ldr r3, [r7, #0]
|
|
80065ba: 2200 movs r2, #0
|
|
80065bc: 601a str r2, [r3, #0]
|
|
xReturn = pdTRUE;
|
|
80065be: 2301 movs r3, #1
|
|
80065c0: 617b str r3, [r7, #20]
|
|
}
|
|
}
|
|
taskEXIT_CRITICAL();
|
|
80065c2: f000 fdbf bl 8007144 <vPortExitCritical>
|
|
|
|
return xReturn;
|
|
80065c6: 697b ldr r3, [r7, #20]
|
|
}
|
|
80065c8: 0018 movs r0, r3
|
|
80065ca: 46bd mov sp, r7
|
|
80065cc: b006 add sp, #24
|
|
80065ce: bd80 pop {r7, pc}
|
|
80065d0: 20000bc4 .word 0x20000bc4
|
|
80065d4: 200006ec .word 0x200006ec
|
|
80065d8: 20000bd8 .word 0x20000bd8
|
|
|
|
080065dc <vTaskMissedYield>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
void vTaskMissedYield( void )
|
|
{
|
|
80065dc: b580 push {r7, lr}
|
|
80065de: af00 add r7, sp, #0
|
|
xYieldPending = pdTRUE;
|
|
80065e0: 4b02 ldr r3, [pc, #8] ; (80065ec <vTaskMissedYield+0x10>)
|
|
80065e2: 2201 movs r2, #1
|
|
80065e4: 601a str r2, [r3, #0]
|
|
}
|
|
80065e6: 46c0 nop ; (mov r8, r8)
|
|
80065e8: 46bd mov sp, r7
|
|
80065ea: bd80 pop {r7, pc}
|
|
80065ec: 20000bd4 .word 0x20000bd4
|
|
|
|
080065f0 <prvIdleTask>:
|
|
*
|
|
* void prvIdleTask( void *pvParameters );
|
|
*
|
|
*/
|
|
static portTASK_FUNCTION( prvIdleTask, pvParameters )
|
|
{
|
|
80065f0: b580 push {r7, lr}
|
|
80065f2: b084 sub sp, #16
|
|
80065f4: af00 add r7, sp, #0
|
|
80065f6: 6078 str r0, [r7, #4]
|
|
|
|
for( ;; )
|
|
{
|
|
/* See if any tasks have deleted themselves - if so then the idle task
|
|
is responsible for freeing the deleted task's TCB and stack. */
|
|
prvCheckTasksWaitingTermination();
|
|
80065f8: f000 f8a2 bl 8006740 <prvCheckTasksWaitingTermination>
|
|
|
|
A critical region is not required here as we are just reading from
|
|
the list, and an occasional incorrect value will not matter. If
|
|
the ready list at the idle priority contains more than one task
|
|
then a task other than the idle task is ready to execute. */
|
|
if( listCURRENT_LIST_LENGTH( &( pxReadyTasksLists[ tskIDLE_PRIORITY ] ) ) > ( UBaseType_t ) 1 )
|
|
80065fc: 4b12 ldr r3, [pc, #72] ; (8006648 <prvIdleTask+0x58>)
|
|
80065fe: 681b ldr r3, [r3, #0]
|
|
8006600: 2b01 cmp r3, #1
|
|
8006602: d901 bls.n 8006608 <prvIdleTask+0x18>
|
|
{
|
|
taskYIELD();
|
|
8006604: f000 fd7c bl 8007100 <vPortYield>
|
|
/* It is not desirable to suspend then resume the scheduler on
|
|
each iteration of the idle task. Therefore, a preliminary
|
|
test of the expected idle time is performed without the
|
|
scheduler suspended. The result here is not necessarily
|
|
valid. */
|
|
xExpectedIdleTime = prvGetExpectedIdleTime();
|
|
8006608: f7ff fce4 bl 8005fd4 <prvGetExpectedIdleTime>
|
|
800660c: 0003 movs r3, r0
|
|
800660e: 60fb str r3, [r7, #12]
|
|
|
|
if( xExpectedIdleTime >= configEXPECTED_IDLE_TIME_BEFORE_SLEEP )
|
|
8006610: 68fb ldr r3, [r7, #12]
|
|
8006612: 2b01 cmp r3, #1
|
|
8006614: d9f0 bls.n 80065f8 <prvIdleTask+0x8>
|
|
{
|
|
vTaskSuspendAll();
|
|
8006616: f7ff fcd1 bl 8005fbc <vTaskSuspendAll>
|
|
{
|
|
/* Now the scheduler is suspended, the expected idle
|
|
time can be sampled again, and this time its value can
|
|
be used. */
|
|
configASSERT( xNextTaskUnblockTime >= xTickCount );
|
|
800661a: 4b0c ldr r3, [pc, #48] ; (800664c <prvIdleTask+0x5c>)
|
|
800661c: 681a ldr r2, [r3, #0]
|
|
800661e: 4b0c ldr r3, [pc, #48] ; (8006650 <prvIdleTask+0x60>)
|
|
8006620: 681b ldr r3, [r3, #0]
|
|
8006622: 429a cmp r2, r3
|
|
8006624: d201 bcs.n 800662a <prvIdleTask+0x3a>
|
|
8006626: b672 cpsid i
|
|
8006628: e7fe b.n 8006628 <prvIdleTask+0x38>
|
|
xExpectedIdleTime = prvGetExpectedIdleTime();
|
|
800662a: f7ff fcd3 bl 8005fd4 <prvGetExpectedIdleTime>
|
|
800662e: 0003 movs r3, r0
|
|
8006630: 60fb str r3, [r7, #12]
|
|
/* Define the following macro to set xExpectedIdleTime to 0
|
|
if the application does not want
|
|
portSUPPRESS_TICKS_AND_SLEEP() to be called. */
|
|
configPRE_SUPPRESS_TICKS_AND_SLEEP_PROCESSING( xExpectedIdleTime );
|
|
|
|
if( xExpectedIdleTime >= configEXPECTED_IDLE_TIME_BEFORE_SLEEP )
|
|
8006632: 68fb ldr r3, [r7, #12]
|
|
8006634: 2b01 cmp r3, #1
|
|
8006636: d903 bls.n 8006640 <prvIdleTask+0x50>
|
|
{
|
|
traceLOW_POWER_IDLE_BEGIN();
|
|
portSUPPRESS_TICKS_AND_SLEEP( xExpectedIdleTime );
|
|
8006638: 68fb ldr r3, [r7, #12]
|
|
800663a: 0018 movs r0, r3
|
|
800663c: f000 fde6 bl 800720c <vPortSuppressTicksAndSleep>
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
( void ) xTaskResumeAll();
|
|
8006640: f7ff fcfe bl 8006040 <xTaskResumeAll>
|
|
prvCheckTasksWaitingTermination();
|
|
8006644: e7d8 b.n 80065f8 <prvIdleTask+0x8>
|
|
8006646: 46c0 nop ; (mov r8, r8)
|
|
8006648: 200006f0 .word 0x200006f0
|
|
800664c: 20000be0 .word 0x20000be0
|
|
8006650: 20000bc4 .word 0x20000bc4
|
|
|
|
08006654 <eTaskConfirmSleepModeStatus>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
#if( configUSE_TICKLESS_IDLE != 0 )
|
|
|
|
eSleepModeStatus eTaskConfirmSleepModeStatus( void )
|
|
{
|
|
8006654: b580 push {r7, lr}
|
|
8006656: b082 sub sp, #8
|
|
8006658: af00 add r7, sp, #0
|
|
/* The idle task exists in addition to the application tasks. */
|
|
const UBaseType_t uxNonApplicationTasks = 1;
|
|
800665a: 2301 movs r3, #1
|
|
800665c: 603b str r3, [r7, #0]
|
|
eSleepModeStatus eReturn = eStandardSleep;
|
|
800665e: 1dfb adds r3, r7, #7
|
|
8006660: 2201 movs r2, #1
|
|
8006662: 701a strb r2, [r3, #0]
|
|
|
|
if( listCURRENT_LIST_LENGTH( &xPendingReadyList ) != 0 )
|
|
8006664: 4b10 ldr r3, [pc, #64] ; (80066a8 <eTaskConfirmSleepModeStatus+0x54>)
|
|
8006666: 681b ldr r3, [r3, #0]
|
|
8006668: 2b00 cmp r3, #0
|
|
800666a: d003 beq.n 8006674 <eTaskConfirmSleepModeStatus+0x20>
|
|
{
|
|
/* A task was made ready while the scheduler was suspended. */
|
|
eReturn = eAbortSleep;
|
|
800666c: 1dfb adds r3, r7, #7
|
|
800666e: 2200 movs r2, #0
|
|
8006670: 701a strb r2, [r3, #0]
|
|
8006672: e012 b.n 800669a <eTaskConfirmSleepModeStatus+0x46>
|
|
}
|
|
else if( xYieldPending != pdFALSE )
|
|
8006674: 4b0d ldr r3, [pc, #52] ; (80066ac <eTaskConfirmSleepModeStatus+0x58>)
|
|
8006676: 681b ldr r3, [r3, #0]
|
|
8006678: 2b00 cmp r3, #0
|
|
800667a: d003 beq.n 8006684 <eTaskConfirmSleepModeStatus+0x30>
|
|
{
|
|
/* A yield was pended while the scheduler was suspended. */
|
|
eReturn = eAbortSleep;
|
|
800667c: 1dfb adds r3, r7, #7
|
|
800667e: 2200 movs r2, #0
|
|
8006680: 701a strb r2, [r3, #0]
|
|
8006682: e00a b.n 800669a <eTaskConfirmSleepModeStatus+0x46>
|
|
{
|
|
/* If all the tasks are in the suspended list (which might mean they
|
|
have an infinite block time rather than actually being suspended)
|
|
then it is safe to turn all clocks off and just wait for external
|
|
interrupts. */
|
|
if( listCURRENT_LIST_LENGTH( &xSuspendedTaskList ) == ( uxCurrentNumberOfTasks - uxNonApplicationTasks ) )
|
|
8006684: 4b0a ldr r3, [pc, #40] ; (80066b0 <eTaskConfirmSleepModeStatus+0x5c>)
|
|
8006686: 681a ldr r2, [r3, #0]
|
|
8006688: 4b0a ldr r3, [pc, #40] ; (80066b4 <eTaskConfirmSleepModeStatus+0x60>)
|
|
800668a: 6819 ldr r1, [r3, #0]
|
|
800668c: 683b ldr r3, [r7, #0]
|
|
800668e: 1acb subs r3, r1, r3
|
|
8006690: 429a cmp r2, r3
|
|
8006692: d102 bne.n 800669a <eTaskConfirmSleepModeStatus+0x46>
|
|
{
|
|
eReturn = eNoTasksWaitingTimeout;
|
|
8006694: 1dfb adds r3, r7, #7
|
|
8006696: 2202 movs r2, #2
|
|
8006698: 701a strb r2, [r3, #0]
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
|
|
return eReturn;
|
|
800669a: 1dfb adds r3, r7, #7
|
|
800669c: 781b ldrb r3, [r3, #0]
|
|
}
|
|
800669e: 0018 movs r0, r3
|
|
80066a0: 46bd mov sp, r7
|
|
80066a2: b002 add sp, #8
|
|
80066a4: bd80 pop {r7, pc}
|
|
80066a6: 46c0 nop ; (mov r8, r8)
|
|
80066a8: 20000b80 .word 0x20000b80
|
|
80066ac: 20000bd4 .word 0x20000bd4
|
|
80066b0: 20000bac .word 0x20000bac
|
|
80066b4: 20000bc0 .word 0x20000bc0
|
|
|
|
080066b8 <prvInitialiseTaskLists>:
|
|
|
|
#endif /* portUSING_MPU_WRAPPERS */
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static void prvInitialiseTaskLists( void )
|
|
{
|
|
80066b8: b580 push {r7, lr}
|
|
80066ba: b082 sub sp, #8
|
|
80066bc: af00 add r7, sp, #0
|
|
UBaseType_t uxPriority;
|
|
|
|
for( uxPriority = ( UBaseType_t ) 0U; uxPriority < ( UBaseType_t ) configMAX_PRIORITIES; uxPriority++ )
|
|
80066be: 2300 movs r3, #0
|
|
80066c0: 607b str r3, [r7, #4]
|
|
80066c2: e00c b.n 80066de <prvInitialiseTaskLists+0x26>
|
|
{
|
|
vListInitialise( &( pxReadyTasksLists[ uxPriority ] ) );
|
|
80066c4: 687a ldr r2, [r7, #4]
|
|
80066c6: 0013 movs r3, r2
|
|
80066c8: 009b lsls r3, r3, #2
|
|
80066ca: 189b adds r3, r3, r2
|
|
80066cc: 009b lsls r3, r3, #2
|
|
80066ce: 4a14 ldr r2, [pc, #80] ; (8006720 <prvInitialiseTaskLists+0x68>)
|
|
80066d0: 189b adds r3, r3, r2
|
|
80066d2: 0018 movs r0, r3
|
|
80066d4: f7fe fcf2 bl 80050bc <vListInitialise>
|
|
for( uxPriority = ( UBaseType_t ) 0U; uxPriority < ( UBaseType_t ) configMAX_PRIORITIES; uxPriority++ )
|
|
80066d8: 687b ldr r3, [r7, #4]
|
|
80066da: 3301 adds r3, #1
|
|
80066dc: 607b str r3, [r7, #4]
|
|
80066de: 687b ldr r3, [r7, #4]
|
|
80066e0: 2b37 cmp r3, #55 ; 0x37
|
|
80066e2: d9ef bls.n 80066c4 <prvInitialiseTaskLists+0xc>
|
|
}
|
|
|
|
vListInitialise( &xDelayedTaskList1 );
|
|
80066e4: 4b0f ldr r3, [pc, #60] ; (8006724 <prvInitialiseTaskLists+0x6c>)
|
|
80066e6: 0018 movs r0, r3
|
|
80066e8: f7fe fce8 bl 80050bc <vListInitialise>
|
|
vListInitialise( &xDelayedTaskList2 );
|
|
80066ec: 4b0e ldr r3, [pc, #56] ; (8006728 <prvInitialiseTaskLists+0x70>)
|
|
80066ee: 0018 movs r0, r3
|
|
80066f0: f7fe fce4 bl 80050bc <vListInitialise>
|
|
vListInitialise( &xPendingReadyList );
|
|
80066f4: 4b0d ldr r3, [pc, #52] ; (800672c <prvInitialiseTaskLists+0x74>)
|
|
80066f6: 0018 movs r0, r3
|
|
80066f8: f7fe fce0 bl 80050bc <vListInitialise>
|
|
|
|
#if ( INCLUDE_vTaskDelete == 1 )
|
|
{
|
|
vListInitialise( &xTasksWaitingTermination );
|
|
80066fc: 4b0c ldr r3, [pc, #48] ; (8006730 <prvInitialiseTaskLists+0x78>)
|
|
80066fe: 0018 movs r0, r3
|
|
8006700: f7fe fcdc bl 80050bc <vListInitialise>
|
|
}
|
|
#endif /* INCLUDE_vTaskDelete */
|
|
|
|
#if ( INCLUDE_vTaskSuspend == 1 )
|
|
{
|
|
vListInitialise( &xSuspendedTaskList );
|
|
8006704: 4b0b ldr r3, [pc, #44] ; (8006734 <prvInitialiseTaskLists+0x7c>)
|
|
8006706: 0018 movs r0, r3
|
|
8006708: f7fe fcd8 bl 80050bc <vListInitialise>
|
|
}
|
|
#endif /* INCLUDE_vTaskSuspend */
|
|
|
|
/* Start with pxDelayedTaskList using list1 and the pxOverflowDelayedTaskList
|
|
using list2. */
|
|
pxDelayedTaskList = &xDelayedTaskList1;
|
|
800670c: 4b0a ldr r3, [pc, #40] ; (8006738 <prvInitialiseTaskLists+0x80>)
|
|
800670e: 4a05 ldr r2, [pc, #20] ; (8006724 <prvInitialiseTaskLists+0x6c>)
|
|
8006710: 601a str r2, [r3, #0]
|
|
pxOverflowDelayedTaskList = &xDelayedTaskList2;
|
|
8006712: 4b0a ldr r3, [pc, #40] ; (800673c <prvInitialiseTaskLists+0x84>)
|
|
8006714: 4a04 ldr r2, [pc, #16] ; (8006728 <prvInitialiseTaskLists+0x70>)
|
|
8006716: 601a str r2, [r3, #0]
|
|
}
|
|
8006718: 46c0 nop ; (mov r8, r8)
|
|
800671a: 46bd mov sp, r7
|
|
800671c: b002 add sp, #8
|
|
800671e: bd80 pop {r7, pc}
|
|
8006720: 200006f0 .word 0x200006f0
|
|
8006724: 20000b50 .word 0x20000b50
|
|
8006728: 20000b64 .word 0x20000b64
|
|
800672c: 20000b80 .word 0x20000b80
|
|
8006730: 20000b94 .word 0x20000b94
|
|
8006734: 20000bac .word 0x20000bac
|
|
8006738: 20000b78 .word 0x20000b78
|
|
800673c: 20000b7c .word 0x20000b7c
|
|
|
|
08006740 <prvCheckTasksWaitingTermination>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static void prvCheckTasksWaitingTermination( void )
|
|
{
|
|
8006740: b580 push {r7, lr}
|
|
8006742: b082 sub sp, #8
|
|
8006744: af00 add r7, sp, #0
|
|
{
|
|
TCB_t *pxTCB;
|
|
|
|
/* uxDeletedTasksWaitingCleanUp is used to prevent taskENTER_CRITICAL()
|
|
being called too often in the idle task. */
|
|
while( uxDeletedTasksWaitingCleanUp > ( UBaseType_t ) 0U )
|
|
8006746: e01a b.n 800677e <prvCheckTasksWaitingTermination+0x3e>
|
|
{
|
|
taskENTER_CRITICAL();
|
|
8006748: f000 fcea bl 8007120 <vPortEnterCritical>
|
|
{
|
|
pxTCB = listGET_OWNER_OF_HEAD_ENTRY( ( &xTasksWaitingTermination ) ); /*lint !e9079 void * is used as this macro is used with timers and co-routines too. Alignment is known to be fine as the type of the pointer stored and retrieved is the same. */
|
|
800674c: 4b10 ldr r3, [pc, #64] ; (8006790 <prvCheckTasksWaitingTermination+0x50>)
|
|
800674e: 68db ldr r3, [r3, #12]
|
|
8006750: 68db ldr r3, [r3, #12]
|
|
8006752: 607b str r3, [r7, #4]
|
|
( void ) uxListRemove( &( pxTCB->xStateListItem ) );
|
|
8006754: 687b ldr r3, [r7, #4]
|
|
8006756: 3304 adds r3, #4
|
|
8006758: 0018 movs r0, r3
|
|
800675a: f7fe fd30 bl 80051be <uxListRemove>
|
|
--uxCurrentNumberOfTasks;
|
|
800675e: 4b0d ldr r3, [pc, #52] ; (8006794 <prvCheckTasksWaitingTermination+0x54>)
|
|
8006760: 681b ldr r3, [r3, #0]
|
|
8006762: 1e5a subs r2, r3, #1
|
|
8006764: 4b0b ldr r3, [pc, #44] ; (8006794 <prvCheckTasksWaitingTermination+0x54>)
|
|
8006766: 601a str r2, [r3, #0]
|
|
--uxDeletedTasksWaitingCleanUp;
|
|
8006768: 4b0b ldr r3, [pc, #44] ; (8006798 <prvCheckTasksWaitingTermination+0x58>)
|
|
800676a: 681b ldr r3, [r3, #0]
|
|
800676c: 1e5a subs r2, r3, #1
|
|
800676e: 4b0a ldr r3, [pc, #40] ; (8006798 <prvCheckTasksWaitingTermination+0x58>)
|
|
8006770: 601a str r2, [r3, #0]
|
|
}
|
|
taskEXIT_CRITICAL();
|
|
8006772: f000 fce7 bl 8007144 <vPortExitCritical>
|
|
|
|
prvDeleteTCB( pxTCB );
|
|
8006776: 687b ldr r3, [r7, #4]
|
|
8006778: 0018 movs r0, r3
|
|
800677a: f000 f80f bl 800679c <prvDeleteTCB>
|
|
while( uxDeletedTasksWaitingCleanUp > ( UBaseType_t ) 0U )
|
|
800677e: 4b06 ldr r3, [pc, #24] ; (8006798 <prvCheckTasksWaitingTermination+0x58>)
|
|
8006780: 681b ldr r3, [r3, #0]
|
|
8006782: 2b00 cmp r3, #0
|
|
8006784: d1e0 bne.n 8006748 <prvCheckTasksWaitingTermination+0x8>
|
|
}
|
|
}
|
|
#endif /* INCLUDE_vTaskDelete */
|
|
}
|
|
8006786: 46c0 nop ; (mov r8, r8)
|
|
8006788: 46c0 nop ; (mov r8, r8)
|
|
800678a: 46bd mov sp, r7
|
|
800678c: b002 add sp, #8
|
|
800678e: bd80 pop {r7, pc}
|
|
8006790: 20000b94 .word 0x20000b94
|
|
8006794: 20000bc0 .word 0x20000bc0
|
|
8006798: 20000ba8 .word 0x20000ba8
|
|
|
|
0800679c <prvDeleteTCB>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
#if ( INCLUDE_vTaskDelete == 1 )
|
|
|
|
static void prvDeleteTCB( TCB_t *pxTCB )
|
|
{
|
|
800679c: b580 push {r7, lr}
|
|
800679e: b082 sub sp, #8
|
|
80067a0: af00 add r7, sp, #0
|
|
80067a2: 6078 str r0, [r7, #4]
|
|
#elif( tskSTATIC_AND_DYNAMIC_ALLOCATION_POSSIBLE != 0 ) /*lint !e731 !e9029 Macro has been consolidated for readability reasons. */
|
|
{
|
|
/* The task could have been allocated statically or dynamically, so
|
|
check what was statically allocated before trying to free the
|
|
memory. */
|
|
if( pxTCB->ucStaticallyAllocated == tskDYNAMICALLY_ALLOCATED_STACK_AND_TCB )
|
|
80067a4: 687b ldr r3, [r7, #4]
|
|
80067a6: 2259 movs r2, #89 ; 0x59
|
|
80067a8: 5c9b ldrb r3, [r3, r2]
|
|
80067aa: 2b00 cmp r3, #0
|
|
80067ac: d109 bne.n 80067c2 <prvDeleteTCB+0x26>
|
|
{
|
|
/* Both the stack and TCB were allocated dynamically, so both
|
|
must be freed. */
|
|
vPortFree( pxTCB->pxStack );
|
|
80067ae: 687b ldr r3, [r7, #4]
|
|
80067b0: 6b1b ldr r3, [r3, #48] ; 0x30
|
|
80067b2: 0018 movs r0, r3
|
|
80067b4: f000 fed6 bl 8007564 <vPortFree>
|
|
vPortFree( pxTCB );
|
|
80067b8: 687b ldr r3, [r7, #4]
|
|
80067ba: 0018 movs r0, r3
|
|
80067bc: f000 fed2 bl 8007564 <vPortFree>
|
|
configASSERT( pxTCB->ucStaticallyAllocated == tskSTATICALLY_ALLOCATED_STACK_AND_TCB );
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
#endif /* configSUPPORT_DYNAMIC_ALLOCATION */
|
|
}
|
|
80067c0: e010 b.n 80067e4 <prvDeleteTCB+0x48>
|
|
else if( pxTCB->ucStaticallyAllocated == tskSTATICALLY_ALLOCATED_STACK_ONLY )
|
|
80067c2: 687b ldr r3, [r7, #4]
|
|
80067c4: 2259 movs r2, #89 ; 0x59
|
|
80067c6: 5c9b ldrb r3, [r3, r2]
|
|
80067c8: 2b01 cmp r3, #1
|
|
80067ca: d104 bne.n 80067d6 <prvDeleteTCB+0x3a>
|
|
vPortFree( pxTCB );
|
|
80067cc: 687b ldr r3, [r7, #4]
|
|
80067ce: 0018 movs r0, r3
|
|
80067d0: f000 fec8 bl 8007564 <vPortFree>
|
|
}
|
|
80067d4: e006 b.n 80067e4 <prvDeleteTCB+0x48>
|
|
configASSERT( pxTCB->ucStaticallyAllocated == tskSTATICALLY_ALLOCATED_STACK_AND_TCB );
|
|
80067d6: 687b ldr r3, [r7, #4]
|
|
80067d8: 2259 movs r2, #89 ; 0x59
|
|
80067da: 5c9b ldrb r3, [r3, r2]
|
|
80067dc: 2b02 cmp r3, #2
|
|
80067de: d001 beq.n 80067e4 <prvDeleteTCB+0x48>
|
|
80067e0: b672 cpsid i
|
|
80067e2: e7fe b.n 80067e2 <prvDeleteTCB+0x46>
|
|
}
|
|
80067e4: 46c0 nop ; (mov r8, r8)
|
|
80067e6: 46bd mov sp, r7
|
|
80067e8: b002 add sp, #8
|
|
80067ea: bd80 pop {r7, pc}
|
|
|
|
080067ec <prvResetNextTaskUnblockTime>:
|
|
|
|
#endif /* INCLUDE_vTaskDelete */
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static void prvResetNextTaskUnblockTime( void )
|
|
{
|
|
80067ec: b580 push {r7, lr}
|
|
80067ee: b082 sub sp, #8
|
|
80067f0: af00 add r7, sp, #0
|
|
TCB_t *pxTCB;
|
|
|
|
if( listLIST_IS_EMPTY( pxDelayedTaskList ) != pdFALSE )
|
|
80067f2: 4b0b ldr r3, [pc, #44] ; (8006820 <prvResetNextTaskUnblockTime+0x34>)
|
|
80067f4: 681b ldr r3, [r3, #0]
|
|
80067f6: 681b ldr r3, [r3, #0]
|
|
80067f8: 2b00 cmp r3, #0
|
|
80067fa: d104 bne.n 8006806 <prvResetNextTaskUnblockTime+0x1a>
|
|
{
|
|
/* The new current delayed list is empty. Set xNextTaskUnblockTime to
|
|
the maximum possible value so it is extremely unlikely that the
|
|
if( xTickCount >= xNextTaskUnblockTime ) test will pass until
|
|
there is an item in the delayed list. */
|
|
xNextTaskUnblockTime = portMAX_DELAY;
|
|
80067fc: 4b09 ldr r3, [pc, #36] ; (8006824 <prvResetNextTaskUnblockTime+0x38>)
|
|
80067fe: 2201 movs r2, #1
|
|
8006800: 4252 negs r2, r2
|
|
8006802: 601a str r2, [r3, #0]
|
|
which the task at the head of the delayed list should be removed
|
|
from the Blocked state. */
|
|
( pxTCB ) = listGET_OWNER_OF_HEAD_ENTRY( pxDelayedTaskList ); /*lint !e9079 void * is used as this macro is used with timers and co-routines too. Alignment is known to be fine as the type of the pointer stored and retrieved is the same. */
|
|
xNextTaskUnblockTime = listGET_LIST_ITEM_VALUE( &( ( pxTCB )->xStateListItem ) );
|
|
}
|
|
}
|
|
8006804: e008 b.n 8006818 <prvResetNextTaskUnblockTime+0x2c>
|
|
( pxTCB ) = listGET_OWNER_OF_HEAD_ENTRY( pxDelayedTaskList ); /*lint !e9079 void * is used as this macro is used with timers and co-routines too. Alignment is known to be fine as the type of the pointer stored and retrieved is the same. */
|
|
8006806: 4b06 ldr r3, [pc, #24] ; (8006820 <prvResetNextTaskUnblockTime+0x34>)
|
|
8006808: 681b ldr r3, [r3, #0]
|
|
800680a: 68db ldr r3, [r3, #12]
|
|
800680c: 68db ldr r3, [r3, #12]
|
|
800680e: 607b str r3, [r7, #4]
|
|
xNextTaskUnblockTime = listGET_LIST_ITEM_VALUE( &( ( pxTCB )->xStateListItem ) );
|
|
8006810: 687b ldr r3, [r7, #4]
|
|
8006812: 685a ldr r2, [r3, #4]
|
|
8006814: 4b03 ldr r3, [pc, #12] ; (8006824 <prvResetNextTaskUnblockTime+0x38>)
|
|
8006816: 601a str r2, [r3, #0]
|
|
}
|
|
8006818: 46c0 nop ; (mov r8, r8)
|
|
800681a: 46bd mov sp, r7
|
|
800681c: b002 add sp, #8
|
|
800681e: bd80 pop {r7, pc}
|
|
8006820: 20000b78 .word 0x20000b78
|
|
8006824: 20000be0 .word 0x20000be0
|
|
|
|
08006828 <xTaskGetSchedulerState>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
#if ( ( INCLUDE_xTaskGetSchedulerState == 1 ) || ( configUSE_TIMERS == 1 ) )
|
|
|
|
BaseType_t xTaskGetSchedulerState( void )
|
|
{
|
|
8006828: b580 push {r7, lr}
|
|
800682a: b082 sub sp, #8
|
|
800682c: af00 add r7, sp, #0
|
|
BaseType_t xReturn;
|
|
|
|
if( xSchedulerRunning == pdFALSE )
|
|
800682e: 4b0a ldr r3, [pc, #40] ; (8006858 <xTaskGetSchedulerState+0x30>)
|
|
8006830: 681b ldr r3, [r3, #0]
|
|
8006832: 2b00 cmp r3, #0
|
|
8006834: d102 bne.n 800683c <xTaskGetSchedulerState+0x14>
|
|
{
|
|
xReturn = taskSCHEDULER_NOT_STARTED;
|
|
8006836: 2301 movs r3, #1
|
|
8006838: 607b str r3, [r7, #4]
|
|
800683a: e008 b.n 800684e <xTaskGetSchedulerState+0x26>
|
|
}
|
|
else
|
|
{
|
|
if( uxSchedulerSuspended == ( UBaseType_t ) pdFALSE )
|
|
800683c: 4b07 ldr r3, [pc, #28] ; (800685c <xTaskGetSchedulerState+0x34>)
|
|
800683e: 681b ldr r3, [r3, #0]
|
|
8006840: 2b00 cmp r3, #0
|
|
8006842: d102 bne.n 800684a <xTaskGetSchedulerState+0x22>
|
|
{
|
|
xReturn = taskSCHEDULER_RUNNING;
|
|
8006844: 2302 movs r3, #2
|
|
8006846: 607b str r3, [r7, #4]
|
|
8006848: e001 b.n 800684e <xTaskGetSchedulerState+0x26>
|
|
}
|
|
else
|
|
{
|
|
xReturn = taskSCHEDULER_SUSPENDED;
|
|
800684a: 2300 movs r3, #0
|
|
800684c: 607b str r3, [r7, #4]
|
|
}
|
|
}
|
|
|
|
return xReturn;
|
|
800684e: 687b ldr r3, [r7, #4]
|
|
}
|
|
8006850: 0018 movs r0, r3
|
|
8006852: 46bd mov sp, r7
|
|
8006854: b002 add sp, #8
|
|
8006856: bd80 pop {r7, pc}
|
|
8006858: 20000bcc .word 0x20000bcc
|
|
800685c: 20000be8 .word 0x20000be8
|
|
|
|
08006860 <xTaskPriorityDisinherit>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
#if ( configUSE_MUTEXES == 1 )
|
|
|
|
BaseType_t xTaskPriorityDisinherit( TaskHandle_t const pxMutexHolder )
|
|
{
|
|
8006860: b580 push {r7, lr}
|
|
8006862: b084 sub sp, #16
|
|
8006864: af00 add r7, sp, #0
|
|
8006866: 6078 str r0, [r7, #4]
|
|
TCB_t * const pxTCB = pxMutexHolder;
|
|
8006868: 687b ldr r3, [r7, #4]
|
|
800686a: 60bb str r3, [r7, #8]
|
|
BaseType_t xReturn = pdFALSE;
|
|
800686c: 2300 movs r3, #0
|
|
800686e: 60fb str r3, [r7, #12]
|
|
|
|
if( pxMutexHolder != NULL )
|
|
8006870: 687b ldr r3, [r7, #4]
|
|
8006872: 2b00 cmp r3, #0
|
|
8006874: d044 beq.n 8006900 <xTaskPriorityDisinherit+0xa0>
|
|
{
|
|
/* A task can only have an inherited priority if it holds the mutex.
|
|
If the mutex is held by a task then it cannot be given from an
|
|
interrupt, and if a mutex is given by the holding task then it must
|
|
be the running state task. */
|
|
configASSERT( pxTCB == pxCurrentTCB );
|
|
8006876: 4b25 ldr r3, [pc, #148] ; (800690c <xTaskPriorityDisinherit+0xac>)
|
|
8006878: 681b ldr r3, [r3, #0]
|
|
800687a: 68ba ldr r2, [r7, #8]
|
|
800687c: 429a cmp r2, r3
|
|
800687e: d001 beq.n 8006884 <xTaskPriorityDisinherit+0x24>
|
|
8006880: b672 cpsid i
|
|
8006882: e7fe b.n 8006882 <xTaskPriorityDisinherit+0x22>
|
|
configASSERT( pxTCB->uxMutexesHeld );
|
|
8006884: 68bb ldr r3, [r7, #8]
|
|
8006886: 6d1b ldr r3, [r3, #80] ; 0x50
|
|
8006888: 2b00 cmp r3, #0
|
|
800688a: d101 bne.n 8006890 <xTaskPriorityDisinherit+0x30>
|
|
800688c: b672 cpsid i
|
|
800688e: e7fe b.n 800688e <xTaskPriorityDisinherit+0x2e>
|
|
( pxTCB->uxMutexesHeld )--;
|
|
8006890: 68bb ldr r3, [r7, #8]
|
|
8006892: 6d1b ldr r3, [r3, #80] ; 0x50
|
|
8006894: 1e5a subs r2, r3, #1
|
|
8006896: 68bb ldr r3, [r7, #8]
|
|
8006898: 651a str r2, [r3, #80] ; 0x50
|
|
|
|
/* Has the holder of the mutex inherited the priority of another
|
|
task? */
|
|
if( pxTCB->uxPriority != pxTCB->uxBasePriority )
|
|
800689a: 68bb ldr r3, [r7, #8]
|
|
800689c: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
800689e: 68bb ldr r3, [r7, #8]
|
|
80068a0: 6cdb ldr r3, [r3, #76] ; 0x4c
|
|
80068a2: 429a cmp r2, r3
|
|
80068a4: d02c beq.n 8006900 <xTaskPriorityDisinherit+0xa0>
|
|
{
|
|
/* Only disinherit if no other mutexes are held. */
|
|
if( pxTCB->uxMutexesHeld == ( UBaseType_t ) 0 )
|
|
80068a6: 68bb ldr r3, [r7, #8]
|
|
80068a8: 6d1b ldr r3, [r3, #80] ; 0x50
|
|
80068aa: 2b00 cmp r3, #0
|
|
80068ac: d128 bne.n 8006900 <xTaskPriorityDisinherit+0xa0>
|
|
/* A task can only have an inherited priority if it holds
|
|
the mutex. If the mutex is held by a task then it cannot be
|
|
given from an interrupt, and if a mutex is given by the
|
|
holding task then it must be the running state task. Remove
|
|
the holding task from the ready list. */
|
|
if( uxListRemove( &( pxTCB->xStateListItem ) ) == ( UBaseType_t ) 0 )
|
|
80068ae: 68bb ldr r3, [r7, #8]
|
|
80068b0: 3304 adds r3, #4
|
|
80068b2: 0018 movs r0, r3
|
|
80068b4: f7fe fc83 bl 80051be <uxListRemove>
|
|
}
|
|
|
|
/* Disinherit the priority before adding the task into the
|
|
new ready list. */
|
|
traceTASK_PRIORITY_DISINHERIT( pxTCB, pxTCB->uxBasePriority );
|
|
pxTCB->uxPriority = pxTCB->uxBasePriority;
|
|
80068b8: 68bb ldr r3, [r7, #8]
|
|
80068ba: 6cda ldr r2, [r3, #76] ; 0x4c
|
|
80068bc: 68bb ldr r3, [r7, #8]
|
|
80068be: 62da str r2, [r3, #44] ; 0x2c
|
|
|
|
/* Reset the event list item value. It cannot be in use for
|
|
any other purpose if this task is running, and it must be
|
|
running to give back the mutex. */
|
|
listSET_LIST_ITEM_VALUE( &( pxTCB->xEventListItem ), ( TickType_t ) configMAX_PRIORITIES - ( TickType_t ) pxTCB->uxPriority ); /*lint !e961 MISRA exception as the casts are only redundant for some ports. */
|
|
80068c0: 68bb ldr r3, [r7, #8]
|
|
80068c2: 6adb ldr r3, [r3, #44] ; 0x2c
|
|
80068c4: 2238 movs r2, #56 ; 0x38
|
|
80068c6: 1ad2 subs r2, r2, r3
|
|
80068c8: 68bb ldr r3, [r7, #8]
|
|
80068ca: 619a str r2, [r3, #24]
|
|
prvAddTaskToReadyList( pxTCB );
|
|
80068cc: 68bb ldr r3, [r7, #8]
|
|
80068ce: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
80068d0: 4b0f ldr r3, [pc, #60] ; (8006910 <xTaskPriorityDisinherit+0xb0>)
|
|
80068d2: 681b ldr r3, [r3, #0]
|
|
80068d4: 429a cmp r2, r3
|
|
80068d6: d903 bls.n 80068e0 <xTaskPriorityDisinherit+0x80>
|
|
80068d8: 68bb ldr r3, [r7, #8]
|
|
80068da: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
80068dc: 4b0c ldr r3, [pc, #48] ; (8006910 <xTaskPriorityDisinherit+0xb0>)
|
|
80068de: 601a str r2, [r3, #0]
|
|
80068e0: 68bb ldr r3, [r7, #8]
|
|
80068e2: 6ada ldr r2, [r3, #44] ; 0x2c
|
|
80068e4: 0013 movs r3, r2
|
|
80068e6: 009b lsls r3, r3, #2
|
|
80068e8: 189b adds r3, r3, r2
|
|
80068ea: 009b lsls r3, r3, #2
|
|
80068ec: 4a09 ldr r2, [pc, #36] ; (8006914 <xTaskPriorityDisinherit+0xb4>)
|
|
80068ee: 189a adds r2, r3, r2
|
|
80068f0: 68bb ldr r3, [r7, #8]
|
|
80068f2: 3304 adds r3, #4
|
|
80068f4: 0019 movs r1, r3
|
|
80068f6: 0010 movs r0, r2
|
|
80068f8: f7fe fc09 bl 800510e <vListInsertEnd>
|
|
in an order different to that in which they were taken.
|
|
If a context switch did not occur when the first mutex was
|
|
returned, even if a task was waiting on it, then a context
|
|
switch should occur when the last mutex is returned whether
|
|
a task is waiting on it or not. */
|
|
xReturn = pdTRUE;
|
|
80068fc: 2301 movs r3, #1
|
|
80068fe: 60fb str r3, [r7, #12]
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
return xReturn;
|
|
8006900: 68fb ldr r3, [r7, #12]
|
|
}
|
|
8006902: 0018 movs r0, r3
|
|
8006904: 46bd mov sp, r7
|
|
8006906: b004 add sp, #16
|
|
8006908: bd80 pop {r7, pc}
|
|
800690a: 46c0 nop ; (mov r8, r8)
|
|
800690c: 200006ec .word 0x200006ec
|
|
8006910: 20000bc8 .word 0x20000bc8
|
|
8006914: 200006f0 .word 0x200006f0
|
|
|
|
08006918 <prvAddCurrentTaskToDelayedList>:
|
|
}
|
|
#endif
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static void prvAddCurrentTaskToDelayedList( TickType_t xTicksToWait, const BaseType_t xCanBlockIndefinitely )
|
|
{
|
|
8006918: b580 push {r7, lr}
|
|
800691a: b084 sub sp, #16
|
|
800691c: af00 add r7, sp, #0
|
|
800691e: 6078 str r0, [r7, #4]
|
|
8006920: 6039 str r1, [r7, #0]
|
|
TickType_t xTimeToWake;
|
|
const TickType_t xConstTickCount = xTickCount;
|
|
8006922: 4b24 ldr r3, [pc, #144] ; (80069b4 <prvAddCurrentTaskToDelayedList+0x9c>)
|
|
8006924: 681b ldr r3, [r3, #0]
|
|
8006926: 60fb str r3, [r7, #12]
|
|
#if( INCLUDE_xTaskAbortDelay == 1 )
|
|
{
|
|
/* About to enter a delayed list, so ensure the ucDelayAborted flag is
|
|
reset to pdFALSE so it can be detected as having been set to pdTRUE
|
|
when the task leaves the Blocked state. */
|
|
pxCurrentTCB->ucDelayAborted = pdFALSE;
|
|
8006928: 4b23 ldr r3, [pc, #140] ; (80069b8 <prvAddCurrentTaskToDelayedList+0xa0>)
|
|
800692a: 681b ldr r3, [r3, #0]
|
|
800692c: 225a movs r2, #90 ; 0x5a
|
|
800692e: 2100 movs r1, #0
|
|
8006930: 5499 strb r1, [r3, r2]
|
|
}
|
|
#endif
|
|
|
|
/* Remove the task from the ready list before adding it to the blocked list
|
|
as the same list item is used for both lists. */
|
|
if( uxListRemove( &( pxCurrentTCB->xStateListItem ) ) == ( UBaseType_t ) 0 )
|
|
8006932: 4b21 ldr r3, [pc, #132] ; (80069b8 <prvAddCurrentTaskToDelayedList+0xa0>)
|
|
8006934: 681b ldr r3, [r3, #0]
|
|
8006936: 3304 adds r3, #4
|
|
8006938: 0018 movs r0, r3
|
|
800693a: f7fe fc40 bl 80051be <uxListRemove>
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
#if ( INCLUDE_vTaskSuspend == 1 )
|
|
{
|
|
if( ( xTicksToWait == portMAX_DELAY ) && ( xCanBlockIndefinitely != pdFALSE ) )
|
|
800693e: 687b ldr r3, [r7, #4]
|
|
8006940: 3301 adds r3, #1
|
|
8006942: d10b bne.n 800695c <prvAddCurrentTaskToDelayedList+0x44>
|
|
8006944: 683b ldr r3, [r7, #0]
|
|
8006946: 2b00 cmp r3, #0
|
|
8006948: d008 beq.n 800695c <prvAddCurrentTaskToDelayedList+0x44>
|
|
{
|
|
/* Add the task to the suspended task list instead of a delayed task
|
|
list to ensure it is not woken by a timing event. It will block
|
|
indefinitely. */
|
|
vListInsertEnd( &xSuspendedTaskList, &( pxCurrentTCB->xStateListItem ) );
|
|
800694a: 4b1b ldr r3, [pc, #108] ; (80069b8 <prvAddCurrentTaskToDelayedList+0xa0>)
|
|
800694c: 681b ldr r3, [r3, #0]
|
|
800694e: 1d1a adds r2, r3, #4
|
|
8006950: 4b1a ldr r3, [pc, #104] ; (80069bc <prvAddCurrentTaskToDelayedList+0xa4>)
|
|
8006952: 0011 movs r1, r2
|
|
8006954: 0018 movs r0, r3
|
|
8006956: f7fe fbda bl 800510e <vListInsertEnd>
|
|
|
|
/* Avoid compiler warning when INCLUDE_vTaskSuspend is not 1. */
|
|
( void ) xCanBlockIndefinitely;
|
|
}
|
|
#endif /* INCLUDE_vTaskSuspend */
|
|
}
|
|
800695a: e026 b.n 80069aa <prvAddCurrentTaskToDelayedList+0x92>
|
|
xTimeToWake = xConstTickCount + xTicksToWait;
|
|
800695c: 68fa ldr r2, [r7, #12]
|
|
800695e: 687b ldr r3, [r7, #4]
|
|
8006960: 18d3 adds r3, r2, r3
|
|
8006962: 60bb str r3, [r7, #8]
|
|
listSET_LIST_ITEM_VALUE( &( pxCurrentTCB->xStateListItem ), xTimeToWake );
|
|
8006964: 4b14 ldr r3, [pc, #80] ; (80069b8 <prvAddCurrentTaskToDelayedList+0xa0>)
|
|
8006966: 681b ldr r3, [r3, #0]
|
|
8006968: 68ba ldr r2, [r7, #8]
|
|
800696a: 605a str r2, [r3, #4]
|
|
if( xTimeToWake < xConstTickCount )
|
|
800696c: 68ba ldr r2, [r7, #8]
|
|
800696e: 68fb ldr r3, [r7, #12]
|
|
8006970: 429a cmp r2, r3
|
|
8006972: d209 bcs.n 8006988 <prvAddCurrentTaskToDelayedList+0x70>
|
|
vListInsert( pxOverflowDelayedTaskList, &( pxCurrentTCB->xStateListItem ) );
|
|
8006974: 4b12 ldr r3, [pc, #72] ; (80069c0 <prvAddCurrentTaskToDelayedList+0xa8>)
|
|
8006976: 681a ldr r2, [r3, #0]
|
|
8006978: 4b0f ldr r3, [pc, #60] ; (80069b8 <prvAddCurrentTaskToDelayedList+0xa0>)
|
|
800697a: 681b ldr r3, [r3, #0]
|
|
800697c: 3304 adds r3, #4
|
|
800697e: 0019 movs r1, r3
|
|
8006980: 0010 movs r0, r2
|
|
8006982: f7fe fbe6 bl 8005152 <vListInsert>
|
|
}
|
|
8006986: e010 b.n 80069aa <prvAddCurrentTaskToDelayedList+0x92>
|
|
vListInsert( pxDelayedTaskList, &( pxCurrentTCB->xStateListItem ) );
|
|
8006988: 4b0e ldr r3, [pc, #56] ; (80069c4 <prvAddCurrentTaskToDelayedList+0xac>)
|
|
800698a: 681a ldr r2, [r3, #0]
|
|
800698c: 4b0a ldr r3, [pc, #40] ; (80069b8 <prvAddCurrentTaskToDelayedList+0xa0>)
|
|
800698e: 681b ldr r3, [r3, #0]
|
|
8006990: 3304 adds r3, #4
|
|
8006992: 0019 movs r1, r3
|
|
8006994: 0010 movs r0, r2
|
|
8006996: f7fe fbdc bl 8005152 <vListInsert>
|
|
if( xTimeToWake < xNextTaskUnblockTime )
|
|
800699a: 4b0b ldr r3, [pc, #44] ; (80069c8 <prvAddCurrentTaskToDelayedList+0xb0>)
|
|
800699c: 681b ldr r3, [r3, #0]
|
|
800699e: 68ba ldr r2, [r7, #8]
|
|
80069a0: 429a cmp r2, r3
|
|
80069a2: d202 bcs.n 80069aa <prvAddCurrentTaskToDelayedList+0x92>
|
|
xNextTaskUnblockTime = xTimeToWake;
|
|
80069a4: 4b08 ldr r3, [pc, #32] ; (80069c8 <prvAddCurrentTaskToDelayedList+0xb0>)
|
|
80069a6: 68ba ldr r2, [r7, #8]
|
|
80069a8: 601a str r2, [r3, #0]
|
|
}
|
|
80069aa: 46c0 nop ; (mov r8, r8)
|
|
80069ac: 46bd mov sp, r7
|
|
80069ae: b004 add sp, #16
|
|
80069b0: bd80 pop {r7, pc}
|
|
80069b2: 46c0 nop ; (mov r8, r8)
|
|
80069b4: 20000bc4 .word 0x20000bc4
|
|
80069b8: 200006ec .word 0x200006ec
|
|
80069bc: 20000bac .word 0x20000bac
|
|
80069c0: 20000b7c .word 0x20000b7c
|
|
80069c4: 20000b78 .word 0x20000b78
|
|
80069c8: 20000be0 .word 0x20000be0
|
|
|
|
080069cc <xTimerCreateTimerTask>:
|
|
TimerCallbackFunction_t pxCallbackFunction,
|
|
Timer_t *pxNewTimer ) PRIVILEGED_FUNCTION;
|
|
/*-----------------------------------------------------------*/
|
|
|
|
BaseType_t xTimerCreateTimerTask( void )
|
|
{
|
|
80069cc: b590 push {r4, r7, lr}
|
|
80069ce: b089 sub sp, #36 ; 0x24
|
|
80069d0: af04 add r7, sp, #16
|
|
BaseType_t xReturn = pdFAIL;
|
|
80069d2: 2300 movs r3, #0
|
|
80069d4: 60fb str r3, [r7, #12]
|
|
|
|
/* This function is called when the scheduler is started if
|
|
configUSE_TIMERS is set to 1. Check that the infrastructure used by the
|
|
timer service task has been created/initialised. If timers have already
|
|
been created then the initialisation will already have been performed. */
|
|
prvCheckForValidListAndQueue();
|
|
80069d6: f000 fac9 bl 8006f6c <prvCheckForValidListAndQueue>
|
|
|
|
if( xTimerQueue != NULL )
|
|
80069da: 4b17 ldr r3, [pc, #92] ; (8006a38 <xTimerCreateTimerTask+0x6c>)
|
|
80069dc: 681b ldr r3, [r3, #0]
|
|
80069de: 2b00 cmp r3, #0
|
|
80069e0: d020 beq.n 8006a24 <xTimerCreateTimerTask+0x58>
|
|
{
|
|
#if( configSUPPORT_STATIC_ALLOCATION == 1 )
|
|
{
|
|
StaticTask_t *pxTimerTaskTCBBuffer = NULL;
|
|
80069e2: 2300 movs r3, #0
|
|
80069e4: 60bb str r3, [r7, #8]
|
|
StackType_t *pxTimerTaskStackBuffer = NULL;
|
|
80069e6: 2300 movs r3, #0
|
|
80069e8: 607b str r3, [r7, #4]
|
|
uint32_t ulTimerTaskStackSize;
|
|
|
|
vApplicationGetTimerTaskMemory( &pxTimerTaskTCBBuffer, &pxTimerTaskStackBuffer, &ulTimerTaskStackSize );
|
|
80069ea: 003a movs r2, r7
|
|
80069ec: 1d39 adds r1, r7, #4
|
|
80069ee: 2308 movs r3, #8
|
|
80069f0: 18fb adds r3, r7, r3
|
|
80069f2: 0018 movs r0, r3
|
|
80069f4: f7fe fb4a bl 800508c <vApplicationGetTimerTaskMemory>
|
|
xTimerTaskHandle = xTaskCreateStatic( prvTimerTask,
|
|
80069f8: 683c ldr r4, [r7, #0]
|
|
80069fa: 687b ldr r3, [r7, #4]
|
|
80069fc: 68ba ldr r2, [r7, #8]
|
|
80069fe: 490f ldr r1, [pc, #60] ; (8006a3c <xTimerCreateTimerTask+0x70>)
|
|
8006a00: 480f ldr r0, [pc, #60] ; (8006a40 <xTimerCreateTimerTask+0x74>)
|
|
8006a02: 9202 str r2, [sp, #8]
|
|
8006a04: 9301 str r3, [sp, #4]
|
|
8006a06: 2302 movs r3, #2
|
|
8006a08: 9300 str r3, [sp, #0]
|
|
8006a0a: 2300 movs r3, #0
|
|
8006a0c: 0022 movs r2, r4
|
|
8006a0e: f7ff f860 bl 8005ad2 <xTaskCreateStatic>
|
|
8006a12: 0002 movs r2, r0
|
|
8006a14: 4b0b ldr r3, [pc, #44] ; (8006a44 <xTimerCreateTimerTask+0x78>)
|
|
8006a16: 601a str r2, [r3, #0]
|
|
NULL,
|
|
( ( UBaseType_t ) configTIMER_TASK_PRIORITY ) | portPRIVILEGE_BIT,
|
|
pxTimerTaskStackBuffer,
|
|
pxTimerTaskTCBBuffer );
|
|
|
|
if( xTimerTaskHandle != NULL )
|
|
8006a18: 4b0a ldr r3, [pc, #40] ; (8006a44 <xTimerCreateTimerTask+0x78>)
|
|
8006a1a: 681b ldr r3, [r3, #0]
|
|
8006a1c: 2b00 cmp r3, #0
|
|
8006a1e: d001 beq.n 8006a24 <xTimerCreateTimerTask+0x58>
|
|
{
|
|
xReturn = pdPASS;
|
|
8006a20: 2301 movs r3, #1
|
|
8006a22: 60fb str r3, [r7, #12]
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
configASSERT( xReturn );
|
|
8006a24: 68fb ldr r3, [r7, #12]
|
|
8006a26: 2b00 cmp r3, #0
|
|
8006a28: d101 bne.n 8006a2e <xTimerCreateTimerTask+0x62>
|
|
8006a2a: b672 cpsid i
|
|
8006a2c: e7fe b.n 8006a2c <xTimerCreateTimerTask+0x60>
|
|
return xReturn;
|
|
8006a2e: 68fb ldr r3, [r7, #12]
|
|
}
|
|
8006a30: 0018 movs r0, r3
|
|
8006a32: 46bd mov sp, r7
|
|
8006a34: b005 add sp, #20
|
|
8006a36: bd90 pop {r4, r7, pc}
|
|
8006a38: 20000c1c .word 0x20000c1c
|
|
8006a3c: 0800780c .word 0x0800780c
|
|
8006a40: 08006b65 .word 0x08006b65
|
|
8006a44: 20000c20 .word 0x20000c20
|
|
|
|
08006a48 <xTimerGenericCommand>:
|
|
}
|
|
}
|
|
/*-----------------------------------------------------------*/
|
|
|
|
BaseType_t xTimerGenericCommand( TimerHandle_t xTimer, const BaseType_t xCommandID, const TickType_t xOptionalValue, BaseType_t * const pxHigherPriorityTaskWoken, const TickType_t xTicksToWait )
|
|
{
|
|
8006a48: b590 push {r4, r7, lr}
|
|
8006a4a: b08b sub sp, #44 ; 0x2c
|
|
8006a4c: af00 add r7, sp, #0
|
|
8006a4e: 60f8 str r0, [r7, #12]
|
|
8006a50: 60b9 str r1, [r7, #8]
|
|
8006a52: 607a str r2, [r7, #4]
|
|
8006a54: 603b str r3, [r7, #0]
|
|
BaseType_t xReturn = pdFAIL;
|
|
8006a56: 2300 movs r3, #0
|
|
8006a58: 627b str r3, [r7, #36] ; 0x24
|
|
DaemonTaskMessage_t xMessage;
|
|
|
|
configASSERT( xTimer );
|
|
8006a5a: 68fb ldr r3, [r7, #12]
|
|
8006a5c: 2b00 cmp r3, #0
|
|
8006a5e: d101 bne.n 8006a64 <xTimerGenericCommand+0x1c>
|
|
8006a60: b672 cpsid i
|
|
8006a62: e7fe b.n 8006a62 <xTimerGenericCommand+0x1a>
|
|
|
|
/* Send a message to the timer service task to perform a particular action
|
|
on a particular timer definition. */
|
|
if( xTimerQueue != NULL )
|
|
8006a64: 4b1c ldr r3, [pc, #112] ; (8006ad8 <xTimerGenericCommand+0x90>)
|
|
8006a66: 681b ldr r3, [r3, #0]
|
|
8006a68: 2b00 cmp r3, #0
|
|
8006a6a: d030 beq.n 8006ace <xTimerGenericCommand+0x86>
|
|
{
|
|
/* Send a command to the timer service task to start the xTimer timer. */
|
|
xMessage.xMessageID = xCommandID;
|
|
8006a6c: 2414 movs r4, #20
|
|
8006a6e: 193b adds r3, r7, r4
|
|
8006a70: 68ba ldr r2, [r7, #8]
|
|
8006a72: 601a str r2, [r3, #0]
|
|
xMessage.u.xTimerParameters.xMessageValue = xOptionalValue;
|
|
8006a74: 193b adds r3, r7, r4
|
|
8006a76: 687a ldr r2, [r7, #4]
|
|
8006a78: 605a str r2, [r3, #4]
|
|
xMessage.u.xTimerParameters.pxTimer = xTimer;
|
|
8006a7a: 193b adds r3, r7, r4
|
|
8006a7c: 68fa ldr r2, [r7, #12]
|
|
8006a7e: 609a str r2, [r3, #8]
|
|
|
|
if( xCommandID < tmrFIRST_FROM_ISR_COMMAND )
|
|
8006a80: 68bb ldr r3, [r7, #8]
|
|
8006a82: 2b05 cmp r3, #5
|
|
8006a84: dc19 bgt.n 8006aba <xTimerGenericCommand+0x72>
|
|
{
|
|
if( xTaskGetSchedulerState() == taskSCHEDULER_RUNNING )
|
|
8006a86: f7ff fecf bl 8006828 <xTaskGetSchedulerState>
|
|
8006a8a: 0003 movs r3, r0
|
|
8006a8c: 2b02 cmp r3, #2
|
|
8006a8e: d109 bne.n 8006aa4 <xTimerGenericCommand+0x5c>
|
|
{
|
|
xReturn = xQueueSendToBack( xTimerQueue, &xMessage, xTicksToWait );
|
|
8006a90: 4b11 ldr r3, [pc, #68] ; (8006ad8 <xTimerGenericCommand+0x90>)
|
|
8006a92: 6818 ldr r0, [r3, #0]
|
|
8006a94: 6bba ldr r2, [r7, #56] ; 0x38
|
|
8006a96: 1939 adds r1, r7, r4
|
|
8006a98: 2300 movs r3, #0
|
|
8006a9a: f7fe fcb7 bl 800540c <xQueueGenericSend>
|
|
8006a9e: 0003 movs r3, r0
|
|
8006aa0: 627b str r3, [r7, #36] ; 0x24
|
|
8006aa2: e014 b.n 8006ace <xTimerGenericCommand+0x86>
|
|
}
|
|
else
|
|
{
|
|
xReturn = xQueueSendToBack( xTimerQueue, &xMessage, tmrNO_DELAY );
|
|
8006aa4: 4b0c ldr r3, [pc, #48] ; (8006ad8 <xTimerGenericCommand+0x90>)
|
|
8006aa6: 6818 ldr r0, [r3, #0]
|
|
8006aa8: 2314 movs r3, #20
|
|
8006aaa: 18f9 adds r1, r7, r3
|
|
8006aac: 2300 movs r3, #0
|
|
8006aae: 2200 movs r2, #0
|
|
8006ab0: f7fe fcac bl 800540c <xQueueGenericSend>
|
|
8006ab4: 0003 movs r3, r0
|
|
8006ab6: 627b str r3, [r7, #36] ; 0x24
|
|
8006ab8: e009 b.n 8006ace <xTimerGenericCommand+0x86>
|
|
}
|
|
}
|
|
else
|
|
{
|
|
xReturn = xQueueSendToBackFromISR( xTimerQueue, &xMessage, pxHigherPriorityTaskWoken );
|
|
8006aba: 4b07 ldr r3, [pc, #28] ; (8006ad8 <xTimerGenericCommand+0x90>)
|
|
8006abc: 6818 ldr r0, [r3, #0]
|
|
8006abe: 683a ldr r2, [r7, #0]
|
|
8006ac0: 2314 movs r3, #20
|
|
8006ac2: 18f9 adds r1, r7, r3
|
|
8006ac4: 2300 movs r3, #0
|
|
8006ac6: f7fe fd65 bl 8005594 <xQueueGenericSendFromISR>
|
|
8006aca: 0003 movs r3, r0
|
|
8006acc: 627b str r3, [r7, #36] ; 0x24
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
return xReturn;
|
|
8006ace: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
}
|
|
8006ad0: 0018 movs r0, r3
|
|
8006ad2: 46bd mov sp, r7
|
|
8006ad4: b00b add sp, #44 ; 0x2c
|
|
8006ad6: bd90 pop {r4, r7, pc}
|
|
8006ad8: 20000c1c .word 0x20000c1c
|
|
|
|
08006adc <prvProcessExpiredTimer>:
|
|
return pxTimer->pcTimerName;
|
|
}
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static void prvProcessExpiredTimer( const TickType_t xNextExpireTime, const TickType_t xTimeNow )
|
|
{
|
|
8006adc: b580 push {r7, lr}
|
|
8006ade: b086 sub sp, #24
|
|
8006ae0: af02 add r7, sp, #8
|
|
8006ae2: 6078 str r0, [r7, #4]
|
|
8006ae4: 6039 str r1, [r7, #0]
|
|
BaseType_t xResult;
|
|
Timer_t * const pxTimer = ( Timer_t * ) listGET_OWNER_OF_HEAD_ENTRY( pxCurrentTimerList ); /*lint !e9087 !e9079 void * is used as this macro is used with tasks and co-routines too. Alignment is known to be fine as the type of the pointer stored and retrieved is the same. */
|
|
8006ae6: 4b1e ldr r3, [pc, #120] ; (8006b60 <prvProcessExpiredTimer+0x84>)
|
|
8006ae8: 681b ldr r3, [r3, #0]
|
|
8006aea: 68db ldr r3, [r3, #12]
|
|
8006aec: 68db ldr r3, [r3, #12]
|
|
8006aee: 60fb str r3, [r7, #12]
|
|
|
|
/* Remove the timer from the list of active timers. A check has already
|
|
been performed to ensure the list is not empty. */
|
|
( void ) uxListRemove( &( pxTimer->xTimerListItem ) );
|
|
8006af0: 68fb ldr r3, [r7, #12]
|
|
8006af2: 3304 adds r3, #4
|
|
8006af4: 0018 movs r0, r3
|
|
8006af6: f7fe fb62 bl 80051be <uxListRemove>
|
|
traceTIMER_EXPIRED( pxTimer );
|
|
|
|
/* If the timer is an auto reload timer then calculate the next
|
|
expiry time and re-insert the timer in the list of active timers. */
|
|
if( ( pxTimer->ucStatus & tmrSTATUS_IS_AUTORELOAD ) != 0 )
|
|
8006afa: 68fb ldr r3, [r7, #12]
|
|
8006afc: 2228 movs r2, #40 ; 0x28
|
|
8006afe: 5c9b ldrb r3, [r3, r2]
|
|
8006b00: 001a movs r2, r3
|
|
8006b02: 2304 movs r3, #4
|
|
8006b04: 4013 ands r3, r2
|
|
8006b06: d019 beq.n 8006b3c <prvProcessExpiredTimer+0x60>
|
|
{
|
|
/* The timer is inserted into a list using a time relative to anything
|
|
other than the current time. It will therefore be inserted into the
|
|
correct list relative to the time this task thinks it is now. */
|
|
if( prvInsertTimerInActiveList( pxTimer, ( xNextExpireTime + pxTimer->xTimerPeriodInTicks ), xTimeNow, xNextExpireTime ) != pdFALSE )
|
|
8006b08: 68fb ldr r3, [r7, #12]
|
|
8006b0a: 699a ldr r2, [r3, #24]
|
|
8006b0c: 687b ldr r3, [r7, #4]
|
|
8006b0e: 18d1 adds r1, r2, r3
|
|
8006b10: 687b ldr r3, [r7, #4]
|
|
8006b12: 683a ldr r2, [r7, #0]
|
|
8006b14: 68f8 ldr r0, [r7, #12]
|
|
8006b16: f000 f8c3 bl 8006ca0 <prvInsertTimerInActiveList>
|
|
8006b1a: 1e03 subs r3, r0, #0
|
|
8006b1c: d017 beq.n 8006b4e <prvProcessExpiredTimer+0x72>
|
|
{
|
|
/* The timer expired before it was added to the active timer
|
|
list. Reload it now. */
|
|
xResult = xTimerGenericCommand( pxTimer, tmrCOMMAND_START_DONT_TRACE, xNextExpireTime, NULL, tmrNO_DELAY );
|
|
8006b1e: 687a ldr r2, [r7, #4]
|
|
8006b20: 68f8 ldr r0, [r7, #12]
|
|
8006b22: 2300 movs r3, #0
|
|
8006b24: 9300 str r3, [sp, #0]
|
|
8006b26: 2300 movs r3, #0
|
|
8006b28: 2100 movs r1, #0
|
|
8006b2a: f7ff ff8d bl 8006a48 <xTimerGenericCommand>
|
|
8006b2e: 0003 movs r3, r0
|
|
8006b30: 60bb str r3, [r7, #8]
|
|
configASSERT( xResult );
|
|
8006b32: 68bb ldr r3, [r7, #8]
|
|
8006b34: 2b00 cmp r3, #0
|
|
8006b36: d10a bne.n 8006b4e <prvProcessExpiredTimer+0x72>
|
|
8006b38: b672 cpsid i
|
|
8006b3a: e7fe b.n 8006b3a <prvProcessExpiredTimer+0x5e>
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
else
|
|
{
|
|
pxTimer->ucStatus &= ~tmrSTATUS_IS_ACTIVE;
|
|
8006b3c: 68fb ldr r3, [r7, #12]
|
|
8006b3e: 2228 movs r2, #40 ; 0x28
|
|
8006b40: 5c9b ldrb r3, [r3, r2]
|
|
8006b42: 2201 movs r2, #1
|
|
8006b44: 4393 bics r3, r2
|
|
8006b46: b2d9 uxtb r1, r3
|
|
8006b48: 68fb ldr r3, [r7, #12]
|
|
8006b4a: 2228 movs r2, #40 ; 0x28
|
|
8006b4c: 5499 strb r1, [r3, r2]
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
/* Call the timer callback. */
|
|
pxTimer->pxCallbackFunction( ( TimerHandle_t ) pxTimer );
|
|
8006b4e: 68fb ldr r3, [r7, #12]
|
|
8006b50: 6a1b ldr r3, [r3, #32]
|
|
8006b52: 68fa ldr r2, [r7, #12]
|
|
8006b54: 0010 movs r0, r2
|
|
8006b56: 4798 blx r3
|
|
}
|
|
8006b58: 46c0 nop ; (mov r8, r8)
|
|
8006b5a: 46bd mov sp, r7
|
|
8006b5c: b004 add sp, #16
|
|
8006b5e: bd80 pop {r7, pc}
|
|
8006b60: 20000c14 .word 0x20000c14
|
|
|
|
08006b64 <prvTimerTask>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static portTASK_FUNCTION( prvTimerTask, pvParameters )
|
|
{
|
|
8006b64: b580 push {r7, lr}
|
|
8006b66: b084 sub sp, #16
|
|
8006b68: af00 add r7, sp, #0
|
|
8006b6a: 6078 str r0, [r7, #4]
|
|
|
|
for( ;; )
|
|
{
|
|
/* Query the timers list to see if it contains any timers, and if so,
|
|
obtain the time at which the next timer will expire. */
|
|
xNextExpireTime = prvGetNextExpireTime( &xListWasEmpty );
|
|
8006b6c: 2308 movs r3, #8
|
|
8006b6e: 18fb adds r3, r7, r3
|
|
8006b70: 0018 movs r0, r3
|
|
8006b72: f000 f853 bl 8006c1c <prvGetNextExpireTime>
|
|
8006b76: 0003 movs r3, r0
|
|
8006b78: 60fb str r3, [r7, #12]
|
|
|
|
/* If a timer has expired, process it. Otherwise, block this task
|
|
until either a timer does expire, or a command is received. */
|
|
prvProcessTimerOrBlockTask( xNextExpireTime, xListWasEmpty );
|
|
8006b7a: 68ba ldr r2, [r7, #8]
|
|
8006b7c: 68fb ldr r3, [r7, #12]
|
|
8006b7e: 0011 movs r1, r2
|
|
8006b80: 0018 movs r0, r3
|
|
8006b82: f000 f803 bl 8006b8c <prvProcessTimerOrBlockTask>
|
|
|
|
/* Empty the command queue. */
|
|
prvProcessReceivedCommands();
|
|
8006b86: f000 f8cd bl 8006d24 <prvProcessReceivedCommands>
|
|
xNextExpireTime = prvGetNextExpireTime( &xListWasEmpty );
|
|
8006b8a: e7ef b.n 8006b6c <prvTimerTask+0x8>
|
|
|
|
08006b8c <prvProcessTimerOrBlockTask>:
|
|
}
|
|
}
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static void prvProcessTimerOrBlockTask( const TickType_t xNextExpireTime, BaseType_t xListWasEmpty )
|
|
{
|
|
8006b8c: b580 push {r7, lr}
|
|
8006b8e: b084 sub sp, #16
|
|
8006b90: af00 add r7, sp, #0
|
|
8006b92: 6078 str r0, [r7, #4]
|
|
8006b94: 6039 str r1, [r7, #0]
|
|
TickType_t xTimeNow;
|
|
BaseType_t xTimerListsWereSwitched;
|
|
|
|
vTaskSuspendAll();
|
|
8006b96: f7ff fa11 bl 8005fbc <vTaskSuspendAll>
|
|
/* Obtain the time now to make an assessment as to whether the timer
|
|
has expired or not. If obtaining the time causes the lists to switch
|
|
then don't process this timer as any timers that remained in the list
|
|
when the lists were switched will have been processed within the
|
|
prvSampleTimeNow() function. */
|
|
xTimeNow = prvSampleTimeNow( &xTimerListsWereSwitched );
|
|
8006b9a: 2308 movs r3, #8
|
|
8006b9c: 18fb adds r3, r7, r3
|
|
8006b9e: 0018 movs r0, r3
|
|
8006ba0: f000 f85e bl 8006c60 <prvSampleTimeNow>
|
|
8006ba4: 0003 movs r3, r0
|
|
8006ba6: 60fb str r3, [r7, #12]
|
|
if( xTimerListsWereSwitched == pdFALSE )
|
|
8006ba8: 68bb ldr r3, [r7, #8]
|
|
8006baa: 2b00 cmp r3, #0
|
|
8006bac: d12b bne.n 8006c06 <prvProcessTimerOrBlockTask+0x7a>
|
|
{
|
|
/* The tick count has not overflowed, has the timer expired? */
|
|
if( ( xListWasEmpty == pdFALSE ) && ( xNextExpireTime <= xTimeNow ) )
|
|
8006bae: 683b ldr r3, [r7, #0]
|
|
8006bb0: 2b00 cmp r3, #0
|
|
8006bb2: d10c bne.n 8006bce <prvProcessTimerOrBlockTask+0x42>
|
|
8006bb4: 687a ldr r2, [r7, #4]
|
|
8006bb6: 68fb ldr r3, [r7, #12]
|
|
8006bb8: 429a cmp r2, r3
|
|
8006bba: d808 bhi.n 8006bce <prvProcessTimerOrBlockTask+0x42>
|
|
{
|
|
( void ) xTaskResumeAll();
|
|
8006bbc: f7ff fa40 bl 8006040 <xTaskResumeAll>
|
|
prvProcessExpiredTimer( xNextExpireTime, xTimeNow );
|
|
8006bc0: 68fa ldr r2, [r7, #12]
|
|
8006bc2: 687b ldr r3, [r7, #4]
|
|
8006bc4: 0011 movs r1, r2
|
|
8006bc6: 0018 movs r0, r3
|
|
8006bc8: f7ff ff88 bl 8006adc <prvProcessExpiredTimer>
|
|
else
|
|
{
|
|
( void ) xTaskResumeAll();
|
|
}
|
|
}
|
|
}
|
|
8006bcc: e01d b.n 8006c0a <prvProcessTimerOrBlockTask+0x7e>
|
|
if( xListWasEmpty != pdFALSE )
|
|
8006bce: 683b ldr r3, [r7, #0]
|
|
8006bd0: 2b00 cmp r3, #0
|
|
8006bd2: d008 beq.n 8006be6 <prvProcessTimerOrBlockTask+0x5a>
|
|
xListWasEmpty = listLIST_IS_EMPTY( pxOverflowTimerList );
|
|
8006bd4: 4b0f ldr r3, [pc, #60] ; (8006c14 <prvProcessTimerOrBlockTask+0x88>)
|
|
8006bd6: 681b ldr r3, [r3, #0]
|
|
8006bd8: 681b ldr r3, [r3, #0]
|
|
8006bda: 2b00 cmp r3, #0
|
|
8006bdc: d101 bne.n 8006be2 <prvProcessTimerOrBlockTask+0x56>
|
|
8006bde: 2301 movs r3, #1
|
|
8006be0: e000 b.n 8006be4 <prvProcessTimerOrBlockTask+0x58>
|
|
8006be2: 2300 movs r3, #0
|
|
8006be4: 603b str r3, [r7, #0]
|
|
vQueueWaitForMessageRestricted( xTimerQueue, ( xNextExpireTime - xTimeNow ), xListWasEmpty );
|
|
8006be6: 4b0c ldr r3, [pc, #48] ; (8006c18 <prvProcessTimerOrBlockTask+0x8c>)
|
|
8006be8: 6818 ldr r0, [r3, #0]
|
|
8006bea: 687a ldr r2, [r7, #4]
|
|
8006bec: 68fb ldr r3, [r7, #12]
|
|
8006bee: 1ad3 subs r3, r2, r3
|
|
8006bf0: 683a ldr r2, [r7, #0]
|
|
8006bf2: 0019 movs r1, r3
|
|
8006bf4: f7fe ff3a bl 8005a6c <vQueueWaitForMessageRestricted>
|
|
if( xTaskResumeAll() == pdFALSE )
|
|
8006bf8: f7ff fa22 bl 8006040 <xTaskResumeAll>
|
|
8006bfc: 1e03 subs r3, r0, #0
|
|
8006bfe: d104 bne.n 8006c0a <prvProcessTimerOrBlockTask+0x7e>
|
|
portYIELD_WITHIN_API();
|
|
8006c00: f000 fa7e bl 8007100 <vPortYield>
|
|
}
|
|
8006c04: e001 b.n 8006c0a <prvProcessTimerOrBlockTask+0x7e>
|
|
( void ) xTaskResumeAll();
|
|
8006c06: f7ff fa1b bl 8006040 <xTaskResumeAll>
|
|
}
|
|
8006c0a: 46c0 nop ; (mov r8, r8)
|
|
8006c0c: 46bd mov sp, r7
|
|
8006c0e: b004 add sp, #16
|
|
8006c10: bd80 pop {r7, pc}
|
|
8006c12: 46c0 nop ; (mov r8, r8)
|
|
8006c14: 20000c18 .word 0x20000c18
|
|
8006c18: 20000c1c .word 0x20000c1c
|
|
|
|
08006c1c <prvGetNextExpireTime>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static TickType_t prvGetNextExpireTime( BaseType_t * const pxListWasEmpty )
|
|
{
|
|
8006c1c: b580 push {r7, lr}
|
|
8006c1e: b084 sub sp, #16
|
|
8006c20: af00 add r7, sp, #0
|
|
8006c22: 6078 str r0, [r7, #4]
|
|
the timer with the nearest expiry time will expire. If there are no
|
|
active timers then just set the next expire time to 0. That will cause
|
|
this task to unblock when the tick count overflows, at which point the
|
|
timer lists will be switched and the next expiry time can be
|
|
re-assessed. */
|
|
*pxListWasEmpty = listLIST_IS_EMPTY( pxCurrentTimerList );
|
|
8006c24: 4b0d ldr r3, [pc, #52] ; (8006c5c <prvGetNextExpireTime+0x40>)
|
|
8006c26: 681b ldr r3, [r3, #0]
|
|
8006c28: 681b ldr r3, [r3, #0]
|
|
8006c2a: 2b00 cmp r3, #0
|
|
8006c2c: d101 bne.n 8006c32 <prvGetNextExpireTime+0x16>
|
|
8006c2e: 2201 movs r2, #1
|
|
8006c30: e000 b.n 8006c34 <prvGetNextExpireTime+0x18>
|
|
8006c32: 2200 movs r2, #0
|
|
8006c34: 687b ldr r3, [r7, #4]
|
|
8006c36: 601a str r2, [r3, #0]
|
|
if( *pxListWasEmpty == pdFALSE )
|
|
8006c38: 687b ldr r3, [r7, #4]
|
|
8006c3a: 681b ldr r3, [r3, #0]
|
|
8006c3c: 2b00 cmp r3, #0
|
|
8006c3e: d105 bne.n 8006c4c <prvGetNextExpireTime+0x30>
|
|
{
|
|
xNextExpireTime = listGET_ITEM_VALUE_OF_HEAD_ENTRY( pxCurrentTimerList );
|
|
8006c40: 4b06 ldr r3, [pc, #24] ; (8006c5c <prvGetNextExpireTime+0x40>)
|
|
8006c42: 681b ldr r3, [r3, #0]
|
|
8006c44: 68db ldr r3, [r3, #12]
|
|
8006c46: 681b ldr r3, [r3, #0]
|
|
8006c48: 60fb str r3, [r7, #12]
|
|
8006c4a: e001 b.n 8006c50 <prvGetNextExpireTime+0x34>
|
|
}
|
|
else
|
|
{
|
|
/* Ensure the task unblocks when the tick count rolls over. */
|
|
xNextExpireTime = ( TickType_t ) 0U;
|
|
8006c4c: 2300 movs r3, #0
|
|
8006c4e: 60fb str r3, [r7, #12]
|
|
}
|
|
|
|
return xNextExpireTime;
|
|
8006c50: 68fb ldr r3, [r7, #12]
|
|
}
|
|
8006c52: 0018 movs r0, r3
|
|
8006c54: 46bd mov sp, r7
|
|
8006c56: b004 add sp, #16
|
|
8006c58: bd80 pop {r7, pc}
|
|
8006c5a: 46c0 nop ; (mov r8, r8)
|
|
8006c5c: 20000c14 .word 0x20000c14
|
|
|
|
08006c60 <prvSampleTimeNow>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static TickType_t prvSampleTimeNow( BaseType_t * const pxTimerListsWereSwitched )
|
|
{
|
|
8006c60: b580 push {r7, lr}
|
|
8006c62: b084 sub sp, #16
|
|
8006c64: af00 add r7, sp, #0
|
|
8006c66: 6078 str r0, [r7, #4]
|
|
TickType_t xTimeNow;
|
|
PRIVILEGED_DATA static TickType_t xLastTime = ( TickType_t ) 0U; /*lint !e956 Variable is only accessible to one task. */
|
|
|
|
xTimeNow = xTaskGetTickCount();
|
|
8006c68: f7ff fa76 bl 8006158 <xTaskGetTickCount>
|
|
8006c6c: 0003 movs r3, r0
|
|
8006c6e: 60fb str r3, [r7, #12]
|
|
|
|
if( xTimeNow < xLastTime )
|
|
8006c70: 4b0a ldr r3, [pc, #40] ; (8006c9c <prvSampleTimeNow+0x3c>)
|
|
8006c72: 681b ldr r3, [r3, #0]
|
|
8006c74: 68fa ldr r2, [r7, #12]
|
|
8006c76: 429a cmp r2, r3
|
|
8006c78: d205 bcs.n 8006c86 <prvSampleTimeNow+0x26>
|
|
{
|
|
prvSwitchTimerLists();
|
|
8006c7a: f000 f919 bl 8006eb0 <prvSwitchTimerLists>
|
|
*pxTimerListsWereSwitched = pdTRUE;
|
|
8006c7e: 687b ldr r3, [r7, #4]
|
|
8006c80: 2201 movs r2, #1
|
|
8006c82: 601a str r2, [r3, #0]
|
|
8006c84: e002 b.n 8006c8c <prvSampleTimeNow+0x2c>
|
|
}
|
|
else
|
|
{
|
|
*pxTimerListsWereSwitched = pdFALSE;
|
|
8006c86: 687b ldr r3, [r7, #4]
|
|
8006c88: 2200 movs r2, #0
|
|
8006c8a: 601a str r2, [r3, #0]
|
|
}
|
|
|
|
xLastTime = xTimeNow;
|
|
8006c8c: 4b03 ldr r3, [pc, #12] ; (8006c9c <prvSampleTimeNow+0x3c>)
|
|
8006c8e: 68fa ldr r2, [r7, #12]
|
|
8006c90: 601a str r2, [r3, #0]
|
|
|
|
return xTimeNow;
|
|
8006c92: 68fb ldr r3, [r7, #12]
|
|
}
|
|
8006c94: 0018 movs r0, r3
|
|
8006c96: 46bd mov sp, r7
|
|
8006c98: b004 add sp, #16
|
|
8006c9a: bd80 pop {r7, pc}
|
|
8006c9c: 20000c24 .word 0x20000c24
|
|
|
|
08006ca0 <prvInsertTimerInActiveList>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static BaseType_t prvInsertTimerInActiveList( Timer_t * const pxTimer, const TickType_t xNextExpiryTime, const TickType_t xTimeNow, const TickType_t xCommandTime )
|
|
{
|
|
8006ca0: b580 push {r7, lr}
|
|
8006ca2: b086 sub sp, #24
|
|
8006ca4: af00 add r7, sp, #0
|
|
8006ca6: 60f8 str r0, [r7, #12]
|
|
8006ca8: 60b9 str r1, [r7, #8]
|
|
8006caa: 607a str r2, [r7, #4]
|
|
8006cac: 603b str r3, [r7, #0]
|
|
BaseType_t xProcessTimerNow = pdFALSE;
|
|
8006cae: 2300 movs r3, #0
|
|
8006cb0: 617b str r3, [r7, #20]
|
|
|
|
listSET_LIST_ITEM_VALUE( &( pxTimer->xTimerListItem ), xNextExpiryTime );
|
|
8006cb2: 68fb ldr r3, [r7, #12]
|
|
8006cb4: 68ba ldr r2, [r7, #8]
|
|
8006cb6: 605a str r2, [r3, #4]
|
|
listSET_LIST_ITEM_OWNER( &( pxTimer->xTimerListItem ), pxTimer );
|
|
8006cb8: 68fb ldr r3, [r7, #12]
|
|
8006cba: 68fa ldr r2, [r7, #12]
|
|
8006cbc: 611a str r2, [r3, #16]
|
|
|
|
if( xNextExpiryTime <= xTimeNow )
|
|
8006cbe: 68ba ldr r2, [r7, #8]
|
|
8006cc0: 687b ldr r3, [r7, #4]
|
|
8006cc2: 429a cmp r2, r3
|
|
8006cc4: d812 bhi.n 8006cec <prvInsertTimerInActiveList+0x4c>
|
|
{
|
|
/* Has the expiry time elapsed between the command to start/reset a
|
|
timer was issued, and the time the command was processed? */
|
|
if( ( ( TickType_t ) ( xTimeNow - xCommandTime ) ) >= pxTimer->xTimerPeriodInTicks ) /*lint !e961 MISRA exception as the casts are only redundant for some ports. */
|
|
8006cc6: 687a ldr r2, [r7, #4]
|
|
8006cc8: 683b ldr r3, [r7, #0]
|
|
8006cca: 1ad2 subs r2, r2, r3
|
|
8006ccc: 68fb ldr r3, [r7, #12]
|
|
8006cce: 699b ldr r3, [r3, #24]
|
|
8006cd0: 429a cmp r2, r3
|
|
8006cd2: d302 bcc.n 8006cda <prvInsertTimerInActiveList+0x3a>
|
|
{
|
|
/* The time between a command being issued and the command being
|
|
processed actually exceeds the timers period. */
|
|
xProcessTimerNow = pdTRUE;
|
|
8006cd4: 2301 movs r3, #1
|
|
8006cd6: 617b str r3, [r7, #20]
|
|
8006cd8: e01b b.n 8006d12 <prvInsertTimerInActiveList+0x72>
|
|
}
|
|
else
|
|
{
|
|
vListInsert( pxOverflowTimerList, &( pxTimer->xTimerListItem ) );
|
|
8006cda: 4b10 ldr r3, [pc, #64] ; (8006d1c <prvInsertTimerInActiveList+0x7c>)
|
|
8006cdc: 681a ldr r2, [r3, #0]
|
|
8006cde: 68fb ldr r3, [r7, #12]
|
|
8006ce0: 3304 adds r3, #4
|
|
8006ce2: 0019 movs r1, r3
|
|
8006ce4: 0010 movs r0, r2
|
|
8006ce6: f7fe fa34 bl 8005152 <vListInsert>
|
|
8006cea: e012 b.n 8006d12 <prvInsertTimerInActiveList+0x72>
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if( ( xTimeNow < xCommandTime ) && ( xNextExpiryTime >= xCommandTime ) )
|
|
8006cec: 687a ldr r2, [r7, #4]
|
|
8006cee: 683b ldr r3, [r7, #0]
|
|
8006cf0: 429a cmp r2, r3
|
|
8006cf2: d206 bcs.n 8006d02 <prvInsertTimerInActiveList+0x62>
|
|
8006cf4: 68ba ldr r2, [r7, #8]
|
|
8006cf6: 683b ldr r3, [r7, #0]
|
|
8006cf8: 429a cmp r2, r3
|
|
8006cfa: d302 bcc.n 8006d02 <prvInsertTimerInActiveList+0x62>
|
|
{
|
|
/* If, since the command was issued, the tick count has overflowed
|
|
but the expiry time has not, then the timer must have already passed
|
|
its expiry time and should be processed immediately. */
|
|
xProcessTimerNow = pdTRUE;
|
|
8006cfc: 2301 movs r3, #1
|
|
8006cfe: 617b str r3, [r7, #20]
|
|
8006d00: e007 b.n 8006d12 <prvInsertTimerInActiveList+0x72>
|
|
}
|
|
else
|
|
{
|
|
vListInsert( pxCurrentTimerList, &( pxTimer->xTimerListItem ) );
|
|
8006d02: 4b07 ldr r3, [pc, #28] ; (8006d20 <prvInsertTimerInActiveList+0x80>)
|
|
8006d04: 681a ldr r2, [r3, #0]
|
|
8006d06: 68fb ldr r3, [r7, #12]
|
|
8006d08: 3304 adds r3, #4
|
|
8006d0a: 0019 movs r1, r3
|
|
8006d0c: 0010 movs r0, r2
|
|
8006d0e: f7fe fa20 bl 8005152 <vListInsert>
|
|
}
|
|
}
|
|
|
|
return xProcessTimerNow;
|
|
8006d12: 697b ldr r3, [r7, #20]
|
|
}
|
|
8006d14: 0018 movs r0, r3
|
|
8006d16: 46bd mov sp, r7
|
|
8006d18: b006 add sp, #24
|
|
8006d1a: bd80 pop {r7, pc}
|
|
8006d1c: 20000c18 .word 0x20000c18
|
|
8006d20: 20000c14 .word 0x20000c14
|
|
|
|
08006d24 <prvProcessReceivedCommands>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static void prvProcessReceivedCommands( void )
|
|
{
|
|
8006d24: b590 push {r4, r7, lr}
|
|
8006d26: b08d sub sp, #52 ; 0x34
|
|
8006d28: af02 add r7, sp, #8
|
|
DaemonTaskMessage_t xMessage;
|
|
Timer_t *pxTimer;
|
|
BaseType_t xTimerListsWereSwitched, xResult;
|
|
TickType_t xTimeNow;
|
|
|
|
while( xQueueReceive( xTimerQueue, &xMessage, tmrNO_DELAY ) != pdFAIL ) /*lint !e603 xMessage does not have to be initialised as it is passed out, not in, and it is not used unless xQueueReceive() returns pdTRUE. */
|
|
8006d2a: e0ac b.n 8006e86 <prvProcessReceivedCommands+0x162>
|
|
{
|
|
#if ( INCLUDE_xTimerPendFunctionCall == 1 )
|
|
{
|
|
/* Negative commands are pended function calls rather than timer
|
|
commands. */
|
|
if( xMessage.xMessageID < ( BaseType_t ) 0 )
|
|
8006d2c: 2208 movs r2, #8
|
|
8006d2e: 18bb adds r3, r7, r2
|
|
8006d30: 681b ldr r3, [r3, #0]
|
|
8006d32: 2b00 cmp r3, #0
|
|
8006d34: da0f bge.n 8006d56 <prvProcessReceivedCommands+0x32>
|
|
{
|
|
const CallbackParameters_t * const pxCallback = &( xMessage.u.xCallbackParameters );
|
|
8006d36: 18bb adds r3, r7, r2
|
|
8006d38: 3304 adds r3, #4
|
|
8006d3a: 627b str r3, [r7, #36] ; 0x24
|
|
|
|
/* The timer uses the xCallbackParameters member to request a
|
|
callback be executed. Check the callback is not NULL. */
|
|
configASSERT( pxCallback );
|
|
8006d3c: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
8006d3e: 2b00 cmp r3, #0
|
|
8006d40: d101 bne.n 8006d46 <prvProcessReceivedCommands+0x22>
|
|
8006d42: b672 cpsid i
|
|
8006d44: e7fe b.n 8006d44 <prvProcessReceivedCommands+0x20>
|
|
|
|
/* Call the function. */
|
|
pxCallback->pxCallbackFunction( pxCallback->pvParameter1, pxCallback->ulParameter2 );
|
|
8006d46: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
8006d48: 681a ldr r2, [r3, #0]
|
|
8006d4a: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
8006d4c: 6858 ldr r0, [r3, #4]
|
|
8006d4e: 6a7b ldr r3, [r7, #36] ; 0x24
|
|
8006d50: 689b ldr r3, [r3, #8]
|
|
8006d52: 0019 movs r1, r3
|
|
8006d54: 4790 blx r2
|
|
}
|
|
#endif /* INCLUDE_xTimerPendFunctionCall */
|
|
|
|
/* Commands that are positive are timer commands rather than pended
|
|
function calls. */
|
|
if( xMessage.xMessageID >= ( BaseType_t ) 0 )
|
|
8006d56: 2208 movs r2, #8
|
|
8006d58: 18bb adds r3, r7, r2
|
|
8006d5a: 681b ldr r3, [r3, #0]
|
|
8006d5c: 2b00 cmp r3, #0
|
|
8006d5e: da00 bge.n 8006d62 <prvProcessReceivedCommands+0x3e>
|
|
8006d60: e090 b.n 8006e84 <prvProcessReceivedCommands+0x160>
|
|
{
|
|
/* The messages uses the xTimerParameters member to work on a
|
|
software timer. */
|
|
pxTimer = xMessage.u.xTimerParameters.pxTimer;
|
|
8006d62: 18bb adds r3, r7, r2
|
|
8006d64: 689b ldr r3, [r3, #8]
|
|
8006d66: 623b str r3, [r7, #32]
|
|
|
|
if( listIS_CONTAINED_WITHIN( NULL, &( pxTimer->xTimerListItem ) ) == pdFALSE ) /*lint !e961. The cast is only redundant when NULL is passed into the macro. */
|
|
8006d68: 6a3b ldr r3, [r7, #32]
|
|
8006d6a: 695b ldr r3, [r3, #20]
|
|
8006d6c: 2b00 cmp r3, #0
|
|
8006d6e: d004 beq.n 8006d7a <prvProcessReceivedCommands+0x56>
|
|
{
|
|
/* The timer is in a list, remove it. */
|
|
( void ) uxListRemove( &( pxTimer->xTimerListItem ) );
|
|
8006d70: 6a3b ldr r3, [r7, #32]
|
|
8006d72: 3304 adds r3, #4
|
|
8006d74: 0018 movs r0, r3
|
|
8006d76: f7fe fa22 bl 80051be <uxListRemove>
|
|
it must be present in the function call. prvSampleTimeNow() must be
|
|
called after the message is received from xTimerQueue so there is no
|
|
possibility of a higher priority task adding a message to the message
|
|
queue with a time that is ahead of the timer daemon task (because it
|
|
pre-empted the timer daemon task after the xTimeNow value was set). */
|
|
xTimeNow = prvSampleTimeNow( &xTimerListsWereSwitched );
|
|
8006d7a: 1d3b adds r3, r7, #4
|
|
8006d7c: 0018 movs r0, r3
|
|
8006d7e: f7ff ff6f bl 8006c60 <prvSampleTimeNow>
|
|
8006d82: 0003 movs r3, r0
|
|
8006d84: 61fb str r3, [r7, #28]
|
|
|
|
switch( xMessage.xMessageID )
|
|
8006d86: 2308 movs r3, #8
|
|
8006d88: 18fb adds r3, r7, r3
|
|
8006d8a: 681b ldr r3, [r3, #0]
|
|
8006d8c: 2b09 cmp r3, #9
|
|
8006d8e: d900 bls.n 8006d92 <prvProcessReceivedCommands+0x6e>
|
|
8006d90: e079 b.n 8006e86 <prvProcessReceivedCommands+0x162>
|
|
8006d92: 009a lsls r2, r3, #2
|
|
8006d94: 4b44 ldr r3, [pc, #272] ; (8006ea8 <prvProcessReceivedCommands+0x184>)
|
|
8006d96: 18d3 adds r3, r2, r3
|
|
8006d98: 681b ldr r3, [r3, #0]
|
|
8006d9a: 469f mov pc, r3
|
|
case tmrCOMMAND_START_FROM_ISR :
|
|
case tmrCOMMAND_RESET :
|
|
case tmrCOMMAND_RESET_FROM_ISR :
|
|
case tmrCOMMAND_START_DONT_TRACE :
|
|
/* Start or restart a timer. */
|
|
pxTimer->ucStatus |= tmrSTATUS_IS_ACTIVE;
|
|
8006d9c: 6a3b ldr r3, [r7, #32]
|
|
8006d9e: 2228 movs r2, #40 ; 0x28
|
|
8006da0: 5c9b ldrb r3, [r3, r2]
|
|
8006da2: 2201 movs r2, #1
|
|
8006da4: 4313 orrs r3, r2
|
|
8006da6: b2d9 uxtb r1, r3
|
|
8006da8: 6a3b ldr r3, [r7, #32]
|
|
8006daa: 2228 movs r2, #40 ; 0x28
|
|
8006dac: 5499 strb r1, [r3, r2]
|
|
if( prvInsertTimerInActiveList( pxTimer, xMessage.u.xTimerParameters.xMessageValue + pxTimer->xTimerPeriodInTicks, xTimeNow, xMessage.u.xTimerParameters.xMessageValue ) != pdFALSE )
|
|
8006dae: 2408 movs r4, #8
|
|
8006db0: 193b adds r3, r7, r4
|
|
8006db2: 685a ldr r2, [r3, #4]
|
|
8006db4: 6a3b ldr r3, [r7, #32]
|
|
8006db6: 699b ldr r3, [r3, #24]
|
|
8006db8: 18d1 adds r1, r2, r3
|
|
8006dba: 193b adds r3, r7, r4
|
|
8006dbc: 685b ldr r3, [r3, #4]
|
|
8006dbe: 69fa ldr r2, [r7, #28]
|
|
8006dc0: 6a38 ldr r0, [r7, #32]
|
|
8006dc2: f7ff ff6d bl 8006ca0 <prvInsertTimerInActiveList>
|
|
8006dc6: 1e03 subs r3, r0, #0
|
|
8006dc8: d05d beq.n 8006e86 <prvProcessReceivedCommands+0x162>
|
|
{
|
|
/* The timer expired before it was added to the active
|
|
timer list. Process it now. */
|
|
pxTimer->pxCallbackFunction( ( TimerHandle_t ) pxTimer );
|
|
8006dca: 6a3b ldr r3, [r7, #32]
|
|
8006dcc: 6a1b ldr r3, [r3, #32]
|
|
8006dce: 6a3a ldr r2, [r7, #32]
|
|
8006dd0: 0010 movs r0, r2
|
|
8006dd2: 4798 blx r3
|
|
traceTIMER_EXPIRED( pxTimer );
|
|
|
|
if( ( pxTimer->ucStatus & tmrSTATUS_IS_AUTORELOAD ) != 0 )
|
|
8006dd4: 6a3b ldr r3, [r7, #32]
|
|
8006dd6: 2228 movs r2, #40 ; 0x28
|
|
8006dd8: 5c9b ldrb r3, [r3, r2]
|
|
8006dda: 001a movs r2, r3
|
|
8006ddc: 2304 movs r3, #4
|
|
8006dde: 4013 ands r3, r2
|
|
8006de0: d051 beq.n 8006e86 <prvProcessReceivedCommands+0x162>
|
|
{
|
|
xResult = xTimerGenericCommand( pxTimer, tmrCOMMAND_START_DONT_TRACE, xMessage.u.xTimerParameters.xMessageValue + pxTimer->xTimerPeriodInTicks, NULL, tmrNO_DELAY );
|
|
8006de2: 193b adds r3, r7, r4
|
|
8006de4: 685a ldr r2, [r3, #4]
|
|
8006de6: 6a3b ldr r3, [r7, #32]
|
|
8006de8: 699b ldr r3, [r3, #24]
|
|
8006dea: 18d2 adds r2, r2, r3
|
|
8006dec: 6a38 ldr r0, [r7, #32]
|
|
8006dee: 2300 movs r3, #0
|
|
8006df0: 9300 str r3, [sp, #0]
|
|
8006df2: 2300 movs r3, #0
|
|
8006df4: 2100 movs r1, #0
|
|
8006df6: f7ff fe27 bl 8006a48 <xTimerGenericCommand>
|
|
8006dfa: 0003 movs r3, r0
|
|
8006dfc: 61bb str r3, [r7, #24]
|
|
configASSERT( xResult );
|
|
8006dfe: 69bb ldr r3, [r7, #24]
|
|
8006e00: 2b00 cmp r3, #0
|
|
8006e02: d140 bne.n 8006e86 <prvProcessReceivedCommands+0x162>
|
|
8006e04: b672 cpsid i
|
|
8006e06: e7fe b.n 8006e06 <prvProcessReceivedCommands+0xe2>
|
|
break;
|
|
|
|
case tmrCOMMAND_STOP :
|
|
case tmrCOMMAND_STOP_FROM_ISR :
|
|
/* The timer has already been removed from the active list. */
|
|
pxTimer->ucStatus &= ~tmrSTATUS_IS_ACTIVE;
|
|
8006e08: 6a3b ldr r3, [r7, #32]
|
|
8006e0a: 2228 movs r2, #40 ; 0x28
|
|
8006e0c: 5c9b ldrb r3, [r3, r2]
|
|
8006e0e: 2201 movs r2, #1
|
|
8006e10: 4393 bics r3, r2
|
|
8006e12: b2d9 uxtb r1, r3
|
|
8006e14: 6a3b ldr r3, [r7, #32]
|
|
8006e16: 2228 movs r2, #40 ; 0x28
|
|
8006e18: 5499 strb r1, [r3, r2]
|
|
break;
|
|
8006e1a: e034 b.n 8006e86 <prvProcessReceivedCommands+0x162>
|
|
|
|
case tmrCOMMAND_CHANGE_PERIOD :
|
|
case tmrCOMMAND_CHANGE_PERIOD_FROM_ISR :
|
|
pxTimer->ucStatus |= tmrSTATUS_IS_ACTIVE;
|
|
8006e1c: 6a3b ldr r3, [r7, #32]
|
|
8006e1e: 2228 movs r2, #40 ; 0x28
|
|
8006e20: 5c9b ldrb r3, [r3, r2]
|
|
8006e22: 2201 movs r2, #1
|
|
8006e24: 4313 orrs r3, r2
|
|
8006e26: b2d9 uxtb r1, r3
|
|
8006e28: 6a3b ldr r3, [r7, #32]
|
|
8006e2a: 2228 movs r2, #40 ; 0x28
|
|
8006e2c: 5499 strb r1, [r3, r2]
|
|
pxTimer->xTimerPeriodInTicks = xMessage.u.xTimerParameters.xMessageValue;
|
|
8006e2e: 2308 movs r3, #8
|
|
8006e30: 18fb adds r3, r7, r3
|
|
8006e32: 685a ldr r2, [r3, #4]
|
|
8006e34: 6a3b ldr r3, [r7, #32]
|
|
8006e36: 619a str r2, [r3, #24]
|
|
configASSERT( ( pxTimer->xTimerPeriodInTicks > 0 ) );
|
|
8006e38: 6a3b ldr r3, [r7, #32]
|
|
8006e3a: 699b ldr r3, [r3, #24]
|
|
8006e3c: 2b00 cmp r3, #0
|
|
8006e3e: d101 bne.n 8006e44 <prvProcessReceivedCommands+0x120>
|
|
8006e40: b672 cpsid i
|
|
8006e42: e7fe b.n 8006e42 <prvProcessReceivedCommands+0x11e>
|
|
be longer or shorter than the old one. The command time is
|
|
therefore set to the current time, and as the period cannot
|
|
be zero the next expiry time can only be in the future,
|
|
meaning (unlike for the xTimerStart() case above) there is
|
|
no fail case that needs to be handled here. */
|
|
( void ) prvInsertTimerInActiveList( pxTimer, ( xTimeNow + pxTimer->xTimerPeriodInTicks ), xTimeNow, xTimeNow );
|
|
8006e44: 6a3b ldr r3, [r7, #32]
|
|
8006e46: 699a ldr r2, [r3, #24]
|
|
8006e48: 69fb ldr r3, [r7, #28]
|
|
8006e4a: 18d1 adds r1, r2, r3
|
|
8006e4c: 69fb ldr r3, [r7, #28]
|
|
8006e4e: 69fa ldr r2, [r7, #28]
|
|
8006e50: 6a38 ldr r0, [r7, #32]
|
|
8006e52: f7ff ff25 bl 8006ca0 <prvInsertTimerInActiveList>
|
|
break;
|
|
8006e56: e016 b.n 8006e86 <prvProcessReceivedCommands+0x162>
|
|
#if ( configSUPPORT_DYNAMIC_ALLOCATION == 1 )
|
|
{
|
|
/* The timer has already been removed from the active list,
|
|
just free up the memory if the memory was dynamically
|
|
allocated. */
|
|
if( ( pxTimer->ucStatus & tmrSTATUS_IS_STATICALLY_ALLOCATED ) == ( uint8_t ) 0 )
|
|
8006e58: 6a3b ldr r3, [r7, #32]
|
|
8006e5a: 2228 movs r2, #40 ; 0x28
|
|
8006e5c: 5c9b ldrb r3, [r3, r2]
|
|
8006e5e: 001a movs r2, r3
|
|
8006e60: 2302 movs r3, #2
|
|
8006e62: 4013 ands r3, r2
|
|
8006e64: d104 bne.n 8006e70 <prvProcessReceivedCommands+0x14c>
|
|
{
|
|
vPortFree( pxTimer );
|
|
8006e66: 6a3b ldr r3, [r7, #32]
|
|
8006e68: 0018 movs r0, r3
|
|
8006e6a: f000 fb7b bl 8007564 <vPortFree>
|
|
8006e6e: e00a b.n 8006e86 <prvProcessReceivedCommands+0x162>
|
|
}
|
|
else
|
|
{
|
|
pxTimer->ucStatus &= ~tmrSTATUS_IS_ACTIVE;
|
|
8006e70: 6a3b ldr r3, [r7, #32]
|
|
8006e72: 2228 movs r2, #40 ; 0x28
|
|
8006e74: 5c9b ldrb r3, [r3, r2]
|
|
8006e76: 2201 movs r2, #1
|
|
8006e78: 4393 bics r3, r2
|
|
8006e7a: b2d9 uxtb r1, r3
|
|
8006e7c: 6a3b ldr r3, [r7, #32]
|
|
8006e7e: 2228 movs r2, #40 ; 0x28
|
|
8006e80: 5499 strb r1, [r3, r2]
|
|
no need to free the memory - just mark the timer as
|
|
"not active". */
|
|
pxTimer->ucStatus &= ~tmrSTATUS_IS_ACTIVE;
|
|
}
|
|
#endif /* configSUPPORT_DYNAMIC_ALLOCATION */
|
|
break;
|
|
8006e82: e000 b.n 8006e86 <prvProcessReceivedCommands+0x162>
|
|
|
|
default :
|
|
/* Don't expect to get here. */
|
|
break;
|
|
}
|
|
}
|
|
8006e84: 46c0 nop ; (mov r8, r8)
|
|
while( xQueueReceive( xTimerQueue, &xMessage, tmrNO_DELAY ) != pdFAIL ) /*lint !e603 xMessage does not have to be initialised as it is passed out, not in, and it is not used unless xQueueReceive() returns pdTRUE. */
|
|
8006e86: 4b09 ldr r3, [pc, #36] ; (8006eac <prvProcessReceivedCommands+0x188>)
|
|
8006e88: 681b ldr r3, [r3, #0]
|
|
8006e8a: 2208 movs r2, #8
|
|
8006e8c: 18b9 adds r1, r7, r2
|
|
8006e8e: 2200 movs r2, #0
|
|
8006e90: 0018 movs r0, r3
|
|
8006e92: f7fe fbf0 bl 8005676 <xQueueReceive>
|
|
8006e96: 1e03 subs r3, r0, #0
|
|
8006e98: d000 beq.n 8006e9c <prvProcessReceivedCommands+0x178>
|
|
8006e9a: e747 b.n 8006d2c <prvProcessReceivedCommands+0x8>
|
|
}
|
|
}
|
|
8006e9c: 46c0 nop ; (mov r8, r8)
|
|
8006e9e: 46c0 nop ; (mov r8, r8)
|
|
8006ea0: 46bd mov sp, r7
|
|
8006ea2: b00b add sp, #44 ; 0x2c
|
|
8006ea4: bd90 pop {r4, r7, pc}
|
|
8006ea6: 46c0 nop ; (mov r8, r8)
|
|
8006ea8: 080078f0 .word 0x080078f0
|
|
8006eac: 20000c1c .word 0x20000c1c
|
|
|
|
08006eb0 <prvSwitchTimerLists>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static void prvSwitchTimerLists( void )
|
|
{
|
|
8006eb0: b580 push {r7, lr}
|
|
8006eb2: b088 sub sp, #32
|
|
8006eb4: af02 add r7, sp, #8
|
|
|
|
/* The tick count has overflowed. The timer lists must be switched.
|
|
If there are any timers still referenced from the current timer list
|
|
then they must have expired and should be processed before the lists
|
|
are switched. */
|
|
while( listLIST_IS_EMPTY( pxCurrentTimerList ) == pdFALSE )
|
|
8006eb6: e041 b.n 8006f3c <prvSwitchTimerLists+0x8c>
|
|
{
|
|
xNextExpireTime = listGET_ITEM_VALUE_OF_HEAD_ENTRY( pxCurrentTimerList );
|
|
8006eb8: 4b2a ldr r3, [pc, #168] ; (8006f64 <prvSwitchTimerLists+0xb4>)
|
|
8006eba: 681b ldr r3, [r3, #0]
|
|
8006ebc: 68db ldr r3, [r3, #12]
|
|
8006ebe: 681b ldr r3, [r3, #0]
|
|
8006ec0: 613b str r3, [r7, #16]
|
|
|
|
/* Remove the timer from the list. */
|
|
pxTimer = ( Timer_t * ) listGET_OWNER_OF_HEAD_ENTRY( pxCurrentTimerList ); /*lint !e9087 !e9079 void * is used as this macro is used with tasks and co-routines too. Alignment is known to be fine as the type of the pointer stored and retrieved is the same. */
|
|
8006ec2: 4b28 ldr r3, [pc, #160] ; (8006f64 <prvSwitchTimerLists+0xb4>)
|
|
8006ec4: 681b ldr r3, [r3, #0]
|
|
8006ec6: 68db ldr r3, [r3, #12]
|
|
8006ec8: 68db ldr r3, [r3, #12]
|
|
8006eca: 60fb str r3, [r7, #12]
|
|
( void ) uxListRemove( &( pxTimer->xTimerListItem ) );
|
|
8006ecc: 68fb ldr r3, [r7, #12]
|
|
8006ece: 3304 adds r3, #4
|
|
8006ed0: 0018 movs r0, r3
|
|
8006ed2: f7fe f974 bl 80051be <uxListRemove>
|
|
traceTIMER_EXPIRED( pxTimer );
|
|
|
|
/* Execute its callback, then send a command to restart the timer if
|
|
it is an auto-reload timer. It cannot be restarted here as the lists
|
|
have not yet been switched. */
|
|
pxTimer->pxCallbackFunction( ( TimerHandle_t ) pxTimer );
|
|
8006ed6: 68fb ldr r3, [r7, #12]
|
|
8006ed8: 6a1b ldr r3, [r3, #32]
|
|
8006eda: 68fa ldr r2, [r7, #12]
|
|
8006edc: 0010 movs r0, r2
|
|
8006ede: 4798 blx r3
|
|
|
|
if( ( pxTimer->ucStatus & tmrSTATUS_IS_AUTORELOAD ) != 0 )
|
|
8006ee0: 68fb ldr r3, [r7, #12]
|
|
8006ee2: 2228 movs r2, #40 ; 0x28
|
|
8006ee4: 5c9b ldrb r3, [r3, r2]
|
|
8006ee6: 001a movs r2, r3
|
|
8006ee8: 2304 movs r3, #4
|
|
8006eea: 4013 ands r3, r2
|
|
8006eec: d026 beq.n 8006f3c <prvSwitchTimerLists+0x8c>
|
|
the timer going into the same timer list then it has already expired
|
|
and the timer should be re-inserted into the current list so it is
|
|
processed again within this loop. Otherwise a command should be sent
|
|
to restart the timer to ensure it is only inserted into a list after
|
|
the lists have been swapped. */
|
|
xReloadTime = ( xNextExpireTime + pxTimer->xTimerPeriodInTicks );
|
|
8006eee: 68fb ldr r3, [r7, #12]
|
|
8006ef0: 699b ldr r3, [r3, #24]
|
|
8006ef2: 693a ldr r2, [r7, #16]
|
|
8006ef4: 18d3 adds r3, r2, r3
|
|
8006ef6: 60bb str r3, [r7, #8]
|
|
if( xReloadTime > xNextExpireTime )
|
|
8006ef8: 68ba ldr r2, [r7, #8]
|
|
8006efa: 693b ldr r3, [r7, #16]
|
|
8006efc: 429a cmp r2, r3
|
|
8006efe: d90e bls.n 8006f1e <prvSwitchTimerLists+0x6e>
|
|
{
|
|
listSET_LIST_ITEM_VALUE( &( pxTimer->xTimerListItem ), xReloadTime );
|
|
8006f00: 68fb ldr r3, [r7, #12]
|
|
8006f02: 68ba ldr r2, [r7, #8]
|
|
8006f04: 605a str r2, [r3, #4]
|
|
listSET_LIST_ITEM_OWNER( &( pxTimer->xTimerListItem ), pxTimer );
|
|
8006f06: 68fb ldr r3, [r7, #12]
|
|
8006f08: 68fa ldr r2, [r7, #12]
|
|
8006f0a: 611a str r2, [r3, #16]
|
|
vListInsert( pxCurrentTimerList, &( pxTimer->xTimerListItem ) );
|
|
8006f0c: 4b15 ldr r3, [pc, #84] ; (8006f64 <prvSwitchTimerLists+0xb4>)
|
|
8006f0e: 681a ldr r2, [r3, #0]
|
|
8006f10: 68fb ldr r3, [r7, #12]
|
|
8006f12: 3304 adds r3, #4
|
|
8006f14: 0019 movs r1, r3
|
|
8006f16: 0010 movs r0, r2
|
|
8006f18: f7fe f91b bl 8005152 <vListInsert>
|
|
8006f1c: e00e b.n 8006f3c <prvSwitchTimerLists+0x8c>
|
|
}
|
|
else
|
|
{
|
|
xResult = xTimerGenericCommand( pxTimer, tmrCOMMAND_START_DONT_TRACE, xNextExpireTime, NULL, tmrNO_DELAY );
|
|
8006f1e: 693a ldr r2, [r7, #16]
|
|
8006f20: 68f8 ldr r0, [r7, #12]
|
|
8006f22: 2300 movs r3, #0
|
|
8006f24: 9300 str r3, [sp, #0]
|
|
8006f26: 2300 movs r3, #0
|
|
8006f28: 2100 movs r1, #0
|
|
8006f2a: f7ff fd8d bl 8006a48 <xTimerGenericCommand>
|
|
8006f2e: 0003 movs r3, r0
|
|
8006f30: 607b str r3, [r7, #4]
|
|
configASSERT( xResult );
|
|
8006f32: 687b ldr r3, [r7, #4]
|
|
8006f34: 2b00 cmp r3, #0
|
|
8006f36: d101 bne.n 8006f3c <prvSwitchTimerLists+0x8c>
|
|
8006f38: b672 cpsid i
|
|
8006f3a: e7fe b.n 8006f3a <prvSwitchTimerLists+0x8a>
|
|
while( listLIST_IS_EMPTY( pxCurrentTimerList ) == pdFALSE )
|
|
8006f3c: 4b09 ldr r3, [pc, #36] ; (8006f64 <prvSwitchTimerLists+0xb4>)
|
|
8006f3e: 681b ldr r3, [r3, #0]
|
|
8006f40: 681b ldr r3, [r3, #0]
|
|
8006f42: 2b00 cmp r3, #0
|
|
8006f44: d1b8 bne.n 8006eb8 <prvSwitchTimerLists+0x8>
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
|
|
pxTemp = pxCurrentTimerList;
|
|
8006f46: 4b07 ldr r3, [pc, #28] ; (8006f64 <prvSwitchTimerLists+0xb4>)
|
|
8006f48: 681b ldr r3, [r3, #0]
|
|
8006f4a: 617b str r3, [r7, #20]
|
|
pxCurrentTimerList = pxOverflowTimerList;
|
|
8006f4c: 4b06 ldr r3, [pc, #24] ; (8006f68 <prvSwitchTimerLists+0xb8>)
|
|
8006f4e: 681a ldr r2, [r3, #0]
|
|
8006f50: 4b04 ldr r3, [pc, #16] ; (8006f64 <prvSwitchTimerLists+0xb4>)
|
|
8006f52: 601a str r2, [r3, #0]
|
|
pxOverflowTimerList = pxTemp;
|
|
8006f54: 4b04 ldr r3, [pc, #16] ; (8006f68 <prvSwitchTimerLists+0xb8>)
|
|
8006f56: 697a ldr r2, [r7, #20]
|
|
8006f58: 601a str r2, [r3, #0]
|
|
}
|
|
8006f5a: 46c0 nop ; (mov r8, r8)
|
|
8006f5c: 46bd mov sp, r7
|
|
8006f5e: b006 add sp, #24
|
|
8006f60: bd80 pop {r7, pc}
|
|
8006f62: 46c0 nop ; (mov r8, r8)
|
|
8006f64: 20000c14 .word 0x20000c14
|
|
8006f68: 20000c18 .word 0x20000c18
|
|
|
|
08006f6c <prvCheckForValidListAndQueue>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static void prvCheckForValidListAndQueue( void )
|
|
{
|
|
8006f6c: b580 push {r7, lr}
|
|
8006f6e: b082 sub sp, #8
|
|
8006f70: af02 add r7, sp, #8
|
|
/* Check that the list from which active timers are referenced, and the
|
|
queue used to communicate with the timer service, have been
|
|
initialised. */
|
|
taskENTER_CRITICAL();
|
|
8006f72: f000 f8d5 bl 8007120 <vPortEnterCritical>
|
|
{
|
|
if( xTimerQueue == NULL )
|
|
8006f76: 4b16 ldr r3, [pc, #88] ; (8006fd0 <prvCheckForValidListAndQueue+0x64>)
|
|
8006f78: 681b ldr r3, [r3, #0]
|
|
8006f7a: 2b00 cmp r3, #0
|
|
8006f7c: d123 bne.n 8006fc6 <prvCheckForValidListAndQueue+0x5a>
|
|
{
|
|
vListInitialise( &xActiveTimerList1 );
|
|
8006f7e: 4b15 ldr r3, [pc, #84] ; (8006fd4 <prvCheckForValidListAndQueue+0x68>)
|
|
8006f80: 0018 movs r0, r3
|
|
8006f82: f7fe f89b bl 80050bc <vListInitialise>
|
|
vListInitialise( &xActiveTimerList2 );
|
|
8006f86: 4b14 ldr r3, [pc, #80] ; (8006fd8 <prvCheckForValidListAndQueue+0x6c>)
|
|
8006f88: 0018 movs r0, r3
|
|
8006f8a: f7fe f897 bl 80050bc <vListInitialise>
|
|
pxCurrentTimerList = &xActiveTimerList1;
|
|
8006f8e: 4b13 ldr r3, [pc, #76] ; (8006fdc <prvCheckForValidListAndQueue+0x70>)
|
|
8006f90: 4a10 ldr r2, [pc, #64] ; (8006fd4 <prvCheckForValidListAndQueue+0x68>)
|
|
8006f92: 601a str r2, [r3, #0]
|
|
pxOverflowTimerList = &xActiveTimerList2;
|
|
8006f94: 4b12 ldr r3, [pc, #72] ; (8006fe0 <prvCheckForValidListAndQueue+0x74>)
|
|
8006f96: 4a10 ldr r2, [pc, #64] ; (8006fd8 <prvCheckForValidListAndQueue+0x6c>)
|
|
8006f98: 601a str r2, [r3, #0]
|
|
/* The timer queue is allocated statically in case
|
|
configSUPPORT_DYNAMIC_ALLOCATION is 0. */
|
|
static StaticQueue_t xStaticTimerQueue; /*lint !e956 Ok to declare in this manner to prevent additional conditional compilation guards in other locations. */
|
|
static uint8_t ucStaticTimerQueueStorage[ ( size_t ) configTIMER_QUEUE_LENGTH * sizeof( DaemonTaskMessage_t ) ]; /*lint !e956 Ok to declare in this manner to prevent additional conditional compilation guards in other locations. */
|
|
|
|
xTimerQueue = xQueueCreateStatic( ( UBaseType_t ) configTIMER_QUEUE_LENGTH, ( UBaseType_t ) sizeof( DaemonTaskMessage_t ), &( ucStaticTimerQueueStorage[ 0 ] ), &xStaticTimerQueue );
|
|
8006f9a: 4b12 ldr r3, [pc, #72] ; (8006fe4 <prvCheckForValidListAndQueue+0x78>)
|
|
8006f9c: 4a12 ldr r2, [pc, #72] ; (8006fe8 <prvCheckForValidListAndQueue+0x7c>)
|
|
8006f9e: 2100 movs r1, #0
|
|
8006fa0: 9100 str r1, [sp, #0]
|
|
8006fa2: 2110 movs r1, #16
|
|
8006fa4: 200a movs r0, #10
|
|
8006fa6: f7fe f986 bl 80052b6 <xQueueGenericCreateStatic>
|
|
8006faa: 0002 movs r2, r0
|
|
8006fac: 4b08 ldr r3, [pc, #32] ; (8006fd0 <prvCheckForValidListAndQueue+0x64>)
|
|
8006fae: 601a str r2, [r3, #0]
|
|
}
|
|
#endif
|
|
|
|
#if ( configQUEUE_REGISTRY_SIZE > 0 )
|
|
{
|
|
if( xTimerQueue != NULL )
|
|
8006fb0: 4b07 ldr r3, [pc, #28] ; (8006fd0 <prvCheckForValidListAndQueue+0x64>)
|
|
8006fb2: 681b ldr r3, [r3, #0]
|
|
8006fb4: 2b00 cmp r3, #0
|
|
8006fb6: d006 beq.n 8006fc6 <prvCheckForValidListAndQueue+0x5a>
|
|
{
|
|
vQueueAddToRegistry( xTimerQueue, "TmrQ" );
|
|
8006fb8: 4b05 ldr r3, [pc, #20] ; (8006fd0 <prvCheckForValidListAndQueue+0x64>)
|
|
8006fba: 681b ldr r3, [r3, #0]
|
|
8006fbc: 4a0b ldr r2, [pc, #44] ; (8006fec <prvCheckForValidListAndQueue+0x80>)
|
|
8006fbe: 0011 movs r1, r2
|
|
8006fc0: 0018 movs r0, r3
|
|
8006fc2: f7fe fd2b bl 8005a1c <vQueueAddToRegistry>
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
taskEXIT_CRITICAL();
|
|
8006fc6: f000 f8bd bl 8007144 <vPortExitCritical>
|
|
}
|
|
8006fca: 46c0 nop ; (mov r8, r8)
|
|
8006fcc: 46bd mov sp, r7
|
|
8006fce: bd80 pop {r7, pc}
|
|
8006fd0: 20000c1c .word 0x20000c1c
|
|
8006fd4: 20000bec .word 0x20000bec
|
|
8006fd8: 20000c00 .word 0x20000c00
|
|
8006fdc: 20000c14 .word 0x20000c14
|
|
8006fe0: 20000c18 .word 0x20000c18
|
|
8006fe4: 20000cc8 .word 0x20000cc8
|
|
8006fe8: 20000c28 .word 0x20000c28
|
|
8006fec: 08007814 .word 0x08007814
|
|
|
|
08006ff0 <pxPortInitialiseStack>:
|
|
|
|
/*
|
|
* See header file for description.
|
|
*/
|
|
StackType_t *pxPortInitialiseStack( StackType_t *pxTopOfStack, TaskFunction_t pxCode, void *pvParameters )
|
|
{
|
|
8006ff0: b580 push {r7, lr}
|
|
8006ff2: b084 sub sp, #16
|
|
8006ff4: af00 add r7, sp, #0
|
|
8006ff6: 60f8 str r0, [r7, #12]
|
|
8006ff8: 60b9 str r1, [r7, #8]
|
|
8006ffa: 607a str r2, [r7, #4]
|
|
/* Simulate the stack frame as it would be created by a context switch
|
|
interrupt. */
|
|
pxTopOfStack--; /* Offset added to account for the way the MCU uses the stack on entry/exit of interrupts. */
|
|
8006ffc: 68fb ldr r3, [r7, #12]
|
|
8006ffe: 3b04 subs r3, #4
|
|
8007000: 60fb str r3, [r7, #12]
|
|
*pxTopOfStack = portINITIAL_XPSR; /* xPSR */
|
|
8007002: 68fb ldr r3, [r7, #12]
|
|
8007004: 2280 movs r2, #128 ; 0x80
|
|
8007006: 0452 lsls r2, r2, #17
|
|
8007008: 601a str r2, [r3, #0]
|
|
pxTopOfStack--;
|
|
800700a: 68fb ldr r3, [r7, #12]
|
|
800700c: 3b04 subs r3, #4
|
|
800700e: 60fb str r3, [r7, #12]
|
|
*pxTopOfStack = ( StackType_t ) pxCode; /* PC */
|
|
8007010: 68ba ldr r2, [r7, #8]
|
|
8007012: 68fb ldr r3, [r7, #12]
|
|
8007014: 601a str r2, [r3, #0]
|
|
pxTopOfStack--;
|
|
8007016: 68fb ldr r3, [r7, #12]
|
|
8007018: 3b04 subs r3, #4
|
|
800701a: 60fb str r3, [r7, #12]
|
|
*pxTopOfStack = ( StackType_t ) portTASK_RETURN_ADDRESS; /* LR */
|
|
800701c: 4a08 ldr r2, [pc, #32] ; (8007040 <pxPortInitialiseStack+0x50>)
|
|
800701e: 68fb ldr r3, [r7, #12]
|
|
8007020: 601a str r2, [r3, #0]
|
|
pxTopOfStack -= 5; /* R12, R3, R2 and R1. */
|
|
8007022: 68fb ldr r3, [r7, #12]
|
|
8007024: 3b14 subs r3, #20
|
|
8007026: 60fb str r3, [r7, #12]
|
|
*pxTopOfStack = ( StackType_t ) pvParameters; /* R0 */
|
|
8007028: 687a ldr r2, [r7, #4]
|
|
800702a: 68fb ldr r3, [r7, #12]
|
|
800702c: 601a str r2, [r3, #0]
|
|
pxTopOfStack -= 8; /* R11..R4. */
|
|
800702e: 68fb ldr r3, [r7, #12]
|
|
8007030: 3b20 subs r3, #32
|
|
8007032: 60fb str r3, [r7, #12]
|
|
|
|
return pxTopOfStack;
|
|
8007034: 68fb ldr r3, [r7, #12]
|
|
}
|
|
8007036: 0018 movs r0, r3
|
|
8007038: 46bd mov sp, r7
|
|
800703a: b004 add sp, #16
|
|
800703c: bd80 pop {r7, pc}
|
|
800703e: 46c0 nop ; (mov r8, r8)
|
|
8007040: 08007045 .word 0x08007045
|
|
|
|
08007044 <prvTaskExitError>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static void prvTaskExitError( void )
|
|
{
|
|
8007044: b580 push {r7, lr}
|
|
8007046: b082 sub sp, #8
|
|
8007048: af00 add r7, sp, #0
|
|
volatile uint32_t ulDummy = 0UL;
|
|
800704a: 2300 movs r3, #0
|
|
800704c: 607b str r3, [r7, #4]
|
|
its caller as there is nothing to return to. If a task wants to exit it
|
|
should instead call vTaskDelete( NULL ).
|
|
|
|
Artificially force an assert() to be triggered if configASSERT() is
|
|
defined, then stop here so application writers can catch the error. */
|
|
configASSERT( uxCriticalNesting == ~0UL );
|
|
800704e: 4b08 ldr r3, [pc, #32] ; (8007070 <prvTaskExitError+0x2c>)
|
|
8007050: 681b ldr r3, [r3, #0]
|
|
8007052: 3301 adds r3, #1
|
|
8007054: d001 beq.n 800705a <prvTaskExitError+0x16>
|
|
8007056: b672 cpsid i
|
|
8007058: e7fe b.n 8007058 <prvTaskExitError+0x14>
|
|
portDISABLE_INTERRUPTS();
|
|
800705a: b672 cpsid i
|
|
while( ulDummy == 0 )
|
|
800705c: 46c0 nop ; (mov r8, r8)
|
|
800705e: 687b ldr r3, [r7, #4]
|
|
8007060: 2b00 cmp r3, #0
|
|
8007062: d0fc beq.n 800705e <prvTaskExitError+0x1a>
|
|
about code appearing after this function is called - making ulDummy
|
|
volatile makes the compiler think the function could return and
|
|
therefore not output an 'unreachable code' warning for code that appears
|
|
after it. */
|
|
}
|
|
}
|
|
8007064: 46c0 nop ; (mov r8, r8)
|
|
8007066: 46c0 nop ; (mov r8, r8)
|
|
8007068: 46bd mov sp, r7
|
|
800706a: b002 add sp, #8
|
|
800706c: bd80 pop {r7, pc}
|
|
800706e: 46c0 nop ; (mov r8, r8)
|
|
8007070: 2000000c .word 0x2000000c
|
|
|
|
08007074 <SVC_Handler>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
void vPortSVCHandler( void )
|
|
{
|
|
8007074: b580 push {r7, lr}
|
|
8007076: af00 add r7, sp, #0
|
|
/* This function is no longer used, but retained for backward
|
|
compatibility. */
|
|
}
|
|
8007078: 46c0 nop ; (mov r8, r8)
|
|
800707a: 46bd mov sp, r7
|
|
800707c: bd80 pop {r7, pc}
|
|
...
|
|
|
|
08007080 <vPortStartFirstTask>:
|
|
void vPortStartFirstTask( void )
|
|
{
|
|
/* The MSP stack is not reset as, unlike on M3/4 parts, there is no vector
|
|
table offset register that can be used to locate the initial stack value.
|
|
Not all M0 parts have the application vector table at address 0. */
|
|
__asm volatile(
|
|
8007080: 4a0b ldr r2, [pc, #44] ; (80070b0 <pxCurrentTCBConst2>)
|
|
8007082: 6813 ldr r3, [r2, #0]
|
|
8007084: 6818 ldr r0, [r3, #0]
|
|
8007086: 3020 adds r0, #32
|
|
8007088: f380 8809 msr PSP, r0
|
|
800708c: 2002 movs r0, #2
|
|
800708e: f380 8814 msr CONTROL, r0
|
|
8007092: f3bf 8f6f isb sy
|
|
8007096: bc3f pop {r0, r1, r2, r3, r4, r5}
|
|
8007098: 46ae mov lr, r5
|
|
800709a: bc08 pop {r3}
|
|
800709c: bc04 pop {r2}
|
|
800709e: b662 cpsie i
|
|
80070a0: 4718 bx r3
|
|
80070a2: 46c0 nop ; (mov r8, r8)
|
|
80070a4: 46c0 nop ; (mov r8, r8)
|
|
80070a6: 46c0 nop ; (mov r8, r8)
|
|
80070a8: 46c0 nop ; (mov r8, r8)
|
|
80070aa: 46c0 nop ; (mov r8, r8)
|
|
80070ac: 46c0 nop ; (mov r8, r8)
|
|
80070ae: 46c0 nop ; (mov r8, r8)
|
|
|
|
080070b0 <pxCurrentTCBConst2>:
|
|
80070b0: 200006ec .word 0x200006ec
|
|
" bx r3 \n" /* Finally, jump to the user defined task code. */
|
|
" \n"
|
|
" .align 4 \n"
|
|
"pxCurrentTCBConst2: .word pxCurrentTCB "
|
|
);
|
|
}
|
|
80070b4: 46c0 nop ; (mov r8, r8)
|
|
80070b6: 46c0 nop ; (mov r8, r8)
|
|
|
|
080070b8 <xPortStartScheduler>:
|
|
|
|
/*
|
|
* See header file for description.
|
|
*/
|
|
BaseType_t xPortStartScheduler( void )
|
|
{
|
|
80070b8: b580 push {r7, lr}
|
|
80070ba: af00 add r7, sp, #0
|
|
/* Make PendSV, CallSV and SysTick the same priority as the kernel. */
|
|
*(portNVIC_SYSPRI2) |= portNVIC_PENDSV_PRI;
|
|
80070bc: 4b0e ldr r3, [pc, #56] ; (80070f8 <xPortStartScheduler+0x40>)
|
|
80070be: 681a ldr r2, [r3, #0]
|
|
80070c0: 4b0d ldr r3, [pc, #52] ; (80070f8 <xPortStartScheduler+0x40>)
|
|
80070c2: 21ff movs r1, #255 ; 0xff
|
|
80070c4: 0409 lsls r1, r1, #16
|
|
80070c6: 430a orrs r2, r1
|
|
80070c8: 601a str r2, [r3, #0]
|
|
*(portNVIC_SYSPRI2) |= portNVIC_SYSTICK_PRI;
|
|
80070ca: 4b0b ldr r3, [pc, #44] ; (80070f8 <xPortStartScheduler+0x40>)
|
|
80070cc: 681a ldr r2, [r3, #0]
|
|
80070ce: 4b0a ldr r3, [pc, #40] ; (80070f8 <xPortStartScheduler+0x40>)
|
|
80070d0: 21ff movs r1, #255 ; 0xff
|
|
80070d2: 0609 lsls r1, r1, #24
|
|
80070d4: 430a orrs r2, r1
|
|
80070d6: 601a str r2, [r3, #0]
|
|
|
|
/* Start the timer that generates the tick ISR. Interrupts are disabled
|
|
here already. */
|
|
prvSetupTimerInterrupt();
|
|
80070d8: f000 f95e bl 8007398 <prvSetupTimerInterrupt>
|
|
|
|
/* Initialise the critical nesting count ready for the first task. */
|
|
uxCriticalNesting = 0;
|
|
80070dc: 4b07 ldr r3, [pc, #28] ; (80070fc <xPortStartScheduler+0x44>)
|
|
80070de: 2200 movs r2, #0
|
|
80070e0: 601a str r2, [r3, #0]
|
|
|
|
/* Start the first task. */
|
|
vPortStartFirstTask();
|
|
80070e2: f7ff ffcd bl 8007080 <vPortStartFirstTask>
|
|
exit error function to prevent compiler warnings about a static function
|
|
not being called in the case that the application writer overrides this
|
|
functionality by defining configTASK_RETURN_ADDRESS. Call
|
|
vTaskSwitchContext() so link time optimisation does not remove the
|
|
symbol. */
|
|
vTaskSwitchContext();
|
|
80070e6: f7ff f911 bl 800630c <vTaskSwitchContext>
|
|
prvTaskExitError();
|
|
80070ea: f7ff ffab bl 8007044 <prvTaskExitError>
|
|
|
|
/* Should not get here! */
|
|
return 0;
|
|
80070ee: 2300 movs r3, #0
|
|
}
|
|
80070f0: 0018 movs r0, r3
|
|
80070f2: 46bd mov sp, r7
|
|
80070f4: bd80 pop {r7, pc}
|
|
80070f6: 46c0 nop ; (mov r8, r8)
|
|
80070f8: e000ed20 .word 0xe000ed20
|
|
80070fc: 2000000c .word 0x2000000c
|
|
|
|
08007100 <vPortYield>:
|
|
configASSERT( uxCriticalNesting == 1000UL );
|
|
}
|
|
/*-----------------------------------------------------------*/
|
|
|
|
void vPortYield( void )
|
|
{
|
|
8007100: b580 push {r7, lr}
|
|
8007102: af00 add r7, sp, #0
|
|
/* Set a PendSV to request a context switch. */
|
|
*( portNVIC_INT_CTRL ) = portNVIC_PENDSVSET;
|
|
8007104: 4b05 ldr r3, [pc, #20] ; (800711c <vPortYield+0x1c>)
|
|
8007106: 2280 movs r2, #128 ; 0x80
|
|
8007108: 0552 lsls r2, r2, #21
|
|
800710a: 601a str r2, [r3, #0]
|
|
|
|
/* Barriers are normally not required but do ensure the code is completely
|
|
within the specified behaviour for the architecture. */
|
|
__asm volatile( "dsb" ::: "memory" );
|
|
800710c: f3bf 8f4f dsb sy
|
|
__asm volatile( "isb" );
|
|
8007110: f3bf 8f6f isb sy
|
|
}
|
|
8007114: 46c0 nop ; (mov r8, r8)
|
|
8007116: 46bd mov sp, r7
|
|
8007118: bd80 pop {r7, pc}
|
|
800711a: 46c0 nop ; (mov r8, r8)
|
|
800711c: e000ed04 .word 0xe000ed04
|
|
|
|
08007120 <vPortEnterCritical>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
void vPortEnterCritical( void )
|
|
{
|
|
8007120: b580 push {r7, lr}
|
|
8007122: af00 add r7, sp, #0
|
|
portDISABLE_INTERRUPTS();
|
|
8007124: b672 cpsid i
|
|
uxCriticalNesting++;
|
|
8007126: 4b06 ldr r3, [pc, #24] ; (8007140 <vPortEnterCritical+0x20>)
|
|
8007128: 681b ldr r3, [r3, #0]
|
|
800712a: 1c5a adds r2, r3, #1
|
|
800712c: 4b04 ldr r3, [pc, #16] ; (8007140 <vPortEnterCritical+0x20>)
|
|
800712e: 601a str r2, [r3, #0]
|
|
__asm volatile( "dsb" ::: "memory" );
|
|
8007130: f3bf 8f4f dsb sy
|
|
__asm volatile( "isb" );
|
|
8007134: f3bf 8f6f isb sy
|
|
}
|
|
8007138: 46c0 nop ; (mov r8, r8)
|
|
800713a: 46bd mov sp, r7
|
|
800713c: bd80 pop {r7, pc}
|
|
800713e: 46c0 nop ; (mov r8, r8)
|
|
8007140: 2000000c .word 0x2000000c
|
|
|
|
08007144 <vPortExitCritical>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
void vPortExitCritical( void )
|
|
{
|
|
8007144: b580 push {r7, lr}
|
|
8007146: af00 add r7, sp, #0
|
|
configASSERT( uxCriticalNesting );
|
|
8007148: 4b09 ldr r3, [pc, #36] ; (8007170 <vPortExitCritical+0x2c>)
|
|
800714a: 681b ldr r3, [r3, #0]
|
|
800714c: 2b00 cmp r3, #0
|
|
800714e: d101 bne.n 8007154 <vPortExitCritical+0x10>
|
|
8007150: b672 cpsid i
|
|
8007152: e7fe b.n 8007152 <vPortExitCritical+0xe>
|
|
uxCriticalNesting--;
|
|
8007154: 4b06 ldr r3, [pc, #24] ; (8007170 <vPortExitCritical+0x2c>)
|
|
8007156: 681b ldr r3, [r3, #0]
|
|
8007158: 1e5a subs r2, r3, #1
|
|
800715a: 4b05 ldr r3, [pc, #20] ; (8007170 <vPortExitCritical+0x2c>)
|
|
800715c: 601a str r2, [r3, #0]
|
|
if( uxCriticalNesting == 0 )
|
|
800715e: 4b04 ldr r3, [pc, #16] ; (8007170 <vPortExitCritical+0x2c>)
|
|
8007160: 681b ldr r3, [r3, #0]
|
|
8007162: 2b00 cmp r3, #0
|
|
8007164: d100 bne.n 8007168 <vPortExitCritical+0x24>
|
|
{
|
|
portENABLE_INTERRUPTS();
|
|
8007166: b662 cpsie i
|
|
}
|
|
}
|
|
8007168: 46c0 nop ; (mov r8, r8)
|
|
800716a: 46bd mov sp, r7
|
|
800716c: bd80 pop {r7, pc}
|
|
800716e: 46c0 nop ; (mov r8, r8)
|
|
8007170: 2000000c .word 0x2000000c
|
|
|
|
08007174 <ulSetInterruptMaskFromISR>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
uint32_t ulSetInterruptMaskFromISR( void )
|
|
{
|
|
__asm volatile(
|
|
8007174: f3ef 8010 mrs r0, PRIMASK
|
|
8007178: b672 cpsid i
|
|
800717a: 4770 bx lr
|
|
/* To avoid compiler warnings. The return statement will nevere be reached,
|
|
but some compilers warn if it is not included, while others won't compile if
|
|
it is. */
|
|
return 0;
|
|
#endif
|
|
}
|
|
800717c: 46c0 nop ; (mov r8, r8)
|
|
800717e: 0018 movs r0, r3
|
|
|
|
08007180 <vClearInterruptMaskFromISR>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
void vClearInterruptMaskFromISR( __attribute__( ( unused ) ) uint32_t ulMask )
|
|
{
|
|
__asm volatile(
|
|
8007180: f380 8810 msr PRIMASK, r0
|
|
8007184: 4770 bx lr
|
|
/* Just to avoid compiler warning. ulMask is used from the asm code but
|
|
the compiler can't see that. Some compilers generate warnings without the
|
|
following line, while others generate warnings if the line is included. */
|
|
( void ) ulMask;
|
|
#endif
|
|
}
|
|
8007186: 46c0 nop ; (mov r8, r8)
|
|
...
|
|
|
|
08007190 <PendSV_Handler>:
|
|
|
|
void xPortPendSVHandler( void )
|
|
{
|
|
/* This is a naked function. */
|
|
|
|
__asm volatile
|
|
8007190: f3ef 8009 mrs r0, PSP
|
|
8007194: 4b0e ldr r3, [pc, #56] ; (80071d0 <pxCurrentTCBConst>)
|
|
8007196: 681a ldr r2, [r3, #0]
|
|
8007198: 3820 subs r0, #32
|
|
800719a: 6010 str r0, [r2, #0]
|
|
800719c: c0f0 stmia r0!, {r4, r5, r6, r7}
|
|
800719e: 4644 mov r4, r8
|
|
80071a0: 464d mov r5, r9
|
|
80071a2: 4656 mov r6, sl
|
|
80071a4: 465f mov r7, fp
|
|
80071a6: c0f0 stmia r0!, {r4, r5, r6, r7}
|
|
80071a8: b508 push {r3, lr}
|
|
80071aa: b672 cpsid i
|
|
80071ac: f7ff f8ae bl 800630c <vTaskSwitchContext>
|
|
80071b0: b662 cpsie i
|
|
80071b2: bc0c pop {r2, r3}
|
|
80071b4: 6811 ldr r1, [r2, #0]
|
|
80071b6: 6808 ldr r0, [r1, #0]
|
|
80071b8: 3010 adds r0, #16
|
|
80071ba: c8f0 ldmia r0!, {r4, r5, r6, r7}
|
|
80071bc: 46a0 mov r8, r4
|
|
80071be: 46a9 mov r9, r5
|
|
80071c0: 46b2 mov sl, r6
|
|
80071c2: 46bb mov fp, r7
|
|
80071c4: f380 8809 msr PSP, r0
|
|
80071c8: 3820 subs r0, #32
|
|
80071ca: c8f0 ldmia r0!, {r4, r5, r6, r7}
|
|
80071cc: 4718 bx r3
|
|
80071ce: 46c0 nop ; (mov r8, r8)
|
|
|
|
080071d0 <pxCurrentTCBConst>:
|
|
80071d0: 200006ec .word 0x200006ec
|
|
" bx r3 \n"
|
|
" \n"
|
|
" .align 4 \n"
|
|
"pxCurrentTCBConst: .word pxCurrentTCB "
|
|
);
|
|
}
|
|
80071d4: 46c0 nop ; (mov r8, r8)
|
|
80071d6: 46c0 nop ; (mov r8, r8)
|
|
|
|
080071d8 <xPortSysTickHandler>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
void xPortSysTickHandler( void )
|
|
{
|
|
80071d8: b580 push {r7, lr}
|
|
80071da: b082 sub sp, #8
|
|
80071dc: af00 add r7, sp, #0
|
|
uint32_t ulPreviousMask;
|
|
|
|
ulPreviousMask = portSET_INTERRUPT_MASK_FROM_ISR();
|
|
80071de: f7ff ffc9 bl 8007174 <ulSetInterruptMaskFromISR>
|
|
80071e2: 0003 movs r3, r0
|
|
80071e4: 607b str r3, [r7, #4]
|
|
{
|
|
/* Increment the RTOS tick. */
|
|
if( xTaskIncrementTick() != pdFALSE )
|
|
80071e6: f7fe ffe1 bl 80061ac <xTaskIncrementTick>
|
|
80071ea: 1e03 subs r3, r0, #0
|
|
80071ec: d003 beq.n 80071f6 <xPortSysTickHandler+0x1e>
|
|
{
|
|
/* Pend a context switch. */
|
|
*(portNVIC_INT_CTRL) = portNVIC_PENDSVSET;
|
|
80071ee: 4b06 ldr r3, [pc, #24] ; (8007208 <xPortSysTickHandler+0x30>)
|
|
80071f0: 2280 movs r2, #128 ; 0x80
|
|
80071f2: 0552 lsls r2, r2, #21
|
|
80071f4: 601a str r2, [r3, #0]
|
|
}
|
|
}
|
|
portCLEAR_INTERRUPT_MASK_FROM_ISR( ulPreviousMask );
|
|
80071f6: 687b ldr r3, [r7, #4]
|
|
80071f8: 0018 movs r0, r3
|
|
80071fa: f7ff ffc1 bl 8007180 <vClearInterruptMaskFromISR>
|
|
}
|
|
80071fe: 46c0 nop ; (mov r8, r8)
|
|
8007200: 46bd mov sp, r7
|
|
8007202: b002 add sp, #8
|
|
8007204: bd80 pop {r7, pc}
|
|
8007206: 46c0 nop ; (mov r8, r8)
|
|
8007208: e000ed04 .word 0xe000ed04
|
|
|
|
0800720c <vPortSuppressTicksAndSleep>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
#if configUSE_TICKLESS_IDLE == 1
|
|
|
|
__attribute__((weak)) void vPortSuppressTicksAndSleep( TickType_t xExpectedIdleTime )
|
|
{
|
|
800720c: b580 push {r7, lr}
|
|
800720e: b088 sub sp, #32
|
|
8007210: af00 add r7, sp, #0
|
|
8007212: 6078 str r0, [r7, #4]
|
|
uint32_t ulReloadValue, ulCompleteTickPeriods, ulCompletedSysTickDecrements, ulSysTickCTRL;
|
|
TickType_t xModifiableIdleTime;
|
|
|
|
/* Make sure the SysTick reload value does not overflow the counter. */
|
|
if( xExpectedIdleTime > xMaximumPossibleSuppressedTicks )
|
|
8007214: 687a ldr r2, [r7, #4]
|
|
8007216: 4b5a ldr r3, [pc, #360] ; (8007380 <vPortSuppressTicksAndSleep+0x174>)
|
|
8007218: 681b ldr r3, [r3, #0]
|
|
800721a: 429a cmp r2, r3
|
|
800721c: d902 bls.n 8007224 <vPortSuppressTicksAndSleep+0x18>
|
|
{
|
|
xExpectedIdleTime = xMaximumPossibleSuppressedTicks;
|
|
800721e: 4b58 ldr r3, [pc, #352] ; (8007380 <vPortSuppressTicksAndSleep+0x174>)
|
|
8007220: 681b ldr r3, [r3, #0]
|
|
8007222: 607b str r3, [r7, #4]
|
|
|
|
/* Stop the SysTick momentarily. The time the SysTick is stopped for
|
|
is accounted for as best it can be, but using the tickless mode will
|
|
inevitably result in some tiny drift of the time maintained by the
|
|
kernel with respect to calendar time. */
|
|
portNVIC_SYSTICK_CTRL &= ~portNVIC_SYSTICK_ENABLE;
|
|
8007224: 4b57 ldr r3, [pc, #348] ; (8007384 <vPortSuppressTicksAndSleep+0x178>)
|
|
8007226: 681a ldr r2, [r3, #0]
|
|
8007228: 4b56 ldr r3, [pc, #344] ; (8007384 <vPortSuppressTicksAndSleep+0x178>)
|
|
800722a: 2101 movs r1, #1
|
|
800722c: 438a bics r2, r1
|
|
800722e: 601a str r2, [r3, #0]
|
|
|
|
/* Calculate the reload value required to wait xExpectedIdleTime
|
|
tick periods. -1 is used because this code will execute part way
|
|
through one of the tick periods. */
|
|
ulReloadValue = portNVIC_SYSTICK_CURRENT_VALUE + ( ulTimerCountsForOneTick * ( xExpectedIdleTime - 1UL ) );
|
|
8007230: 4b55 ldr r3, [pc, #340] ; (8007388 <vPortSuppressTicksAndSleep+0x17c>)
|
|
8007232: 681a ldr r2, [r3, #0]
|
|
8007234: 687b ldr r3, [r7, #4]
|
|
8007236: 1e59 subs r1, r3, #1
|
|
8007238: 4b54 ldr r3, [pc, #336] ; (800738c <vPortSuppressTicksAndSleep+0x180>)
|
|
800723a: 681b ldr r3, [r3, #0]
|
|
800723c: 434b muls r3, r1
|
|
800723e: 18d3 adds r3, r2, r3
|
|
8007240: 61fb str r3, [r7, #28]
|
|
if( ulReloadValue > ulStoppedTimerCompensation )
|
|
8007242: 4b53 ldr r3, [pc, #332] ; (8007390 <vPortSuppressTicksAndSleep+0x184>)
|
|
8007244: 681b ldr r3, [r3, #0]
|
|
8007246: 69fa ldr r2, [r7, #28]
|
|
8007248: 429a cmp r2, r3
|
|
800724a: d904 bls.n 8007256 <vPortSuppressTicksAndSleep+0x4a>
|
|
{
|
|
ulReloadValue -= ulStoppedTimerCompensation;
|
|
800724c: 4b50 ldr r3, [pc, #320] ; (8007390 <vPortSuppressTicksAndSleep+0x184>)
|
|
800724e: 681b ldr r3, [r3, #0]
|
|
8007250: 69fa ldr r2, [r7, #28]
|
|
8007252: 1ad3 subs r3, r2, r3
|
|
8007254: 61fb str r3, [r7, #28]
|
|
}
|
|
|
|
/* Enter a critical section but don't use the taskENTER_CRITICAL()
|
|
method as that will mask interrupts that should exit sleep mode. */
|
|
__asm volatile( "cpsid i" );
|
|
8007256: b672 cpsid i
|
|
|
|
/* If a context switch is pending or a task is waiting for the scheduler
|
|
to be unsuspended then abandon the low power entry. */
|
|
if( eTaskConfirmSleepModeStatus() == eAbortSleep )
|
|
8007258: f7ff f9fc bl 8006654 <eTaskConfirmSleepModeStatus>
|
|
800725c: 1e03 subs r3, r0, #0
|
|
800725e: d110 bne.n 8007282 <vPortSuppressTicksAndSleep+0x76>
|
|
{
|
|
/* Restart from whatever is left in the count register to complete
|
|
this tick period. */
|
|
portNVIC_SYSTICK_LOAD = portNVIC_SYSTICK_CURRENT_VALUE;
|
|
8007260: 4a49 ldr r2, [pc, #292] ; (8007388 <vPortSuppressTicksAndSleep+0x17c>)
|
|
8007262: 4b4c ldr r3, [pc, #304] ; (8007394 <vPortSuppressTicksAndSleep+0x188>)
|
|
8007264: 6812 ldr r2, [r2, #0]
|
|
8007266: 601a str r2, [r3, #0]
|
|
|
|
/* Restart SysTick. */
|
|
portNVIC_SYSTICK_CTRL |= portNVIC_SYSTICK_ENABLE;
|
|
8007268: 4b46 ldr r3, [pc, #280] ; (8007384 <vPortSuppressTicksAndSleep+0x178>)
|
|
800726a: 681a ldr r2, [r3, #0]
|
|
800726c: 4b45 ldr r3, [pc, #276] ; (8007384 <vPortSuppressTicksAndSleep+0x178>)
|
|
800726e: 2101 movs r1, #1
|
|
8007270: 430a orrs r2, r1
|
|
8007272: 601a str r2, [r3, #0]
|
|
|
|
/* Reset the reload register to the value required for normal tick
|
|
periods. */
|
|
portNVIC_SYSTICK_LOAD = ulTimerCountsForOneTick - 1UL;
|
|
8007274: 4b45 ldr r3, [pc, #276] ; (800738c <vPortSuppressTicksAndSleep+0x180>)
|
|
8007276: 681a ldr r2, [r3, #0]
|
|
8007278: 4b46 ldr r3, [pc, #280] ; (8007394 <vPortSuppressTicksAndSleep+0x188>)
|
|
800727a: 3a01 subs r2, #1
|
|
800727c: 601a str r2, [r3, #0]
|
|
|
|
/* Re-enable interrupts - see comments above the cpsid instruction()
|
|
above. */
|
|
__asm volatile( "cpsie i" );
|
|
800727e: b662 cpsie i
|
|
vTaskStepTick( ulCompleteTickPeriods );
|
|
portNVIC_SYSTICK_LOAD = ulTimerCountsForOneTick - 1UL;
|
|
}
|
|
portEXIT_CRITICAL();
|
|
}
|
|
}
|
|
8007280: e07a b.n 8007378 <vPortSuppressTicksAndSleep+0x16c>
|
|
portNVIC_SYSTICK_LOAD = ulReloadValue;
|
|
8007282: 4b44 ldr r3, [pc, #272] ; (8007394 <vPortSuppressTicksAndSleep+0x188>)
|
|
8007284: 69fa ldr r2, [r7, #28]
|
|
8007286: 601a str r2, [r3, #0]
|
|
portNVIC_SYSTICK_CURRENT_VALUE = 0UL;
|
|
8007288: 4b3f ldr r3, [pc, #252] ; (8007388 <vPortSuppressTicksAndSleep+0x17c>)
|
|
800728a: 2200 movs r2, #0
|
|
800728c: 601a str r2, [r3, #0]
|
|
portNVIC_SYSTICK_CTRL |= portNVIC_SYSTICK_ENABLE;
|
|
800728e: 4b3d ldr r3, [pc, #244] ; (8007384 <vPortSuppressTicksAndSleep+0x178>)
|
|
8007290: 681a ldr r2, [r3, #0]
|
|
8007292: 4b3c ldr r3, [pc, #240] ; (8007384 <vPortSuppressTicksAndSleep+0x178>)
|
|
8007294: 2101 movs r1, #1
|
|
8007296: 430a orrs r2, r1
|
|
8007298: 601a str r2, [r3, #0]
|
|
xModifiableIdleTime = xExpectedIdleTime;
|
|
800729a: 687b ldr r3, [r7, #4]
|
|
800729c: 60bb str r3, [r7, #8]
|
|
configPRE_SLEEP_PROCESSING( &xModifiableIdleTime );
|
|
800729e: 2308 movs r3, #8
|
|
80072a0: 18fb adds r3, r7, r3
|
|
80072a2: 0018 movs r0, r3
|
|
80072a4: f7f9 f8fa bl 800049c <PreSleepProcessing>
|
|
if( xModifiableIdleTime > 0 )
|
|
80072a8: 68bb ldr r3, [r7, #8]
|
|
80072aa: 2b00 cmp r3, #0
|
|
80072ac: d004 beq.n 80072b8 <vPortSuppressTicksAndSleep+0xac>
|
|
__asm volatile( "dsb" );
|
|
80072ae: f3bf 8f4f dsb sy
|
|
__asm volatile( "wfi" );
|
|
80072b2: bf30 wfi
|
|
__asm volatile( "isb" );
|
|
80072b4: f3bf 8f6f isb sy
|
|
configPOST_SLEEP_PROCESSING( &xExpectedIdleTime );
|
|
80072b8: 1d3b adds r3, r7, #4
|
|
80072ba: 0018 movs r0, r3
|
|
80072bc: f7f9 f8f6 bl 80004ac <PostSleepProcessing>
|
|
ulSysTickCTRL = portNVIC_SYSTICK_CTRL;
|
|
80072c0: 4b30 ldr r3, [pc, #192] ; (8007384 <vPortSuppressTicksAndSleep+0x178>)
|
|
80072c2: 681b ldr r3, [r3, #0]
|
|
80072c4: 613b str r3, [r7, #16]
|
|
portNVIC_SYSTICK_CTRL = ( ulSysTickCTRL & ~portNVIC_SYSTICK_ENABLE );
|
|
80072c6: 4b2f ldr r3, [pc, #188] ; (8007384 <vPortSuppressTicksAndSleep+0x178>)
|
|
80072c8: 693a ldr r2, [r7, #16]
|
|
80072ca: 2101 movs r1, #1
|
|
80072cc: 438a bics r2, r1
|
|
80072ce: 601a str r2, [r3, #0]
|
|
__asm volatile( "cpsie i" );
|
|
80072d0: b662 cpsie i
|
|
if( ( ulSysTickCTRL & portNVIC_SYSTICK_COUNT_FLAG ) != 0 )
|
|
80072d2: 693a ldr r2, [r7, #16]
|
|
80072d4: 2380 movs r3, #128 ; 0x80
|
|
80072d6: 025b lsls r3, r3, #9
|
|
80072d8: 4013 ands r3, r2
|
|
80072da: d01d beq.n 8007318 <vPortSuppressTicksAndSleep+0x10c>
|
|
ulCalculatedLoadValue = ( ulTimerCountsForOneTick - 1UL ) - ( ulReloadValue - portNVIC_SYSTICK_CURRENT_VALUE );
|
|
80072dc: 4b2b ldr r3, [pc, #172] ; (800738c <vPortSuppressTicksAndSleep+0x180>)
|
|
80072de: 681a ldr r2, [r3, #0]
|
|
80072e0: 4b29 ldr r3, [pc, #164] ; (8007388 <vPortSuppressTicksAndSleep+0x17c>)
|
|
80072e2: 6819 ldr r1, [r3, #0]
|
|
80072e4: 69fb ldr r3, [r7, #28]
|
|
80072e6: 1acb subs r3, r1, r3
|
|
80072e8: 18d3 adds r3, r2, r3
|
|
80072ea: 3b01 subs r3, #1
|
|
80072ec: 617b str r3, [r7, #20]
|
|
if( ( ulCalculatedLoadValue < ulStoppedTimerCompensation ) || ( ulCalculatedLoadValue > ulTimerCountsForOneTick ) )
|
|
80072ee: 4b28 ldr r3, [pc, #160] ; (8007390 <vPortSuppressTicksAndSleep+0x184>)
|
|
80072f0: 681b ldr r3, [r3, #0]
|
|
80072f2: 697a ldr r2, [r7, #20]
|
|
80072f4: 429a cmp r2, r3
|
|
80072f6: d304 bcc.n 8007302 <vPortSuppressTicksAndSleep+0xf6>
|
|
80072f8: 4b24 ldr r3, [pc, #144] ; (800738c <vPortSuppressTicksAndSleep+0x180>)
|
|
80072fa: 681b ldr r3, [r3, #0]
|
|
80072fc: 697a ldr r2, [r7, #20]
|
|
80072fe: 429a cmp r2, r3
|
|
8007300: d903 bls.n 800730a <vPortSuppressTicksAndSleep+0xfe>
|
|
ulCalculatedLoadValue = ( ulTimerCountsForOneTick - 1UL );
|
|
8007302: 4b22 ldr r3, [pc, #136] ; (800738c <vPortSuppressTicksAndSleep+0x180>)
|
|
8007304: 681b ldr r3, [r3, #0]
|
|
8007306: 3b01 subs r3, #1
|
|
8007308: 617b str r3, [r7, #20]
|
|
portNVIC_SYSTICK_LOAD = ulCalculatedLoadValue;
|
|
800730a: 4b22 ldr r3, [pc, #136] ; (8007394 <vPortSuppressTicksAndSleep+0x188>)
|
|
800730c: 697a ldr r2, [r7, #20]
|
|
800730e: 601a str r2, [r3, #0]
|
|
ulCompleteTickPeriods = xExpectedIdleTime - 1UL;
|
|
8007310: 687b ldr r3, [r7, #4]
|
|
8007312: 3b01 subs r3, #1
|
|
8007314: 61bb str r3, [r7, #24]
|
|
8007316: e019 b.n 800734c <vPortSuppressTicksAndSleep+0x140>
|
|
ulCompletedSysTickDecrements = ( xExpectedIdleTime * ulTimerCountsForOneTick ) - portNVIC_SYSTICK_CURRENT_VALUE;
|
|
8007318: 687a ldr r2, [r7, #4]
|
|
800731a: 4b1c ldr r3, [pc, #112] ; (800738c <vPortSuppressTicksAndSleep+0x180>)
|
|
800731c: 681b ldr r3, [r3, #0]
|
|
800731e: 435a muls r2, r3
|
|
8007320: 4b19 ldr r3, [pc, #100] ; (8007388 <vPortSuppressTicksAndSleep+0x17c>)
|
|
8007322: 681b ldr r3, [r3, #0]
|
|
8007324: 1ad3 subs r3, r2, r3
|
|
8007326: 60fb str r3, [r7, #12]
|
|
ulCompleteTickPeriods = ulCompletedSysTickDecrements / ulTimerCountsForOneTick;
|
|
8007328: 4b18 ldr r3, [pc, #96] ; (800738c <vPortSuppressTicksAndSleep+0x180>)
|
|
800732a: 681b ldr r3, [r3, #0]
|
|
800732c: 0019 movs r1, r3
|
|
800732e: 68f8 ldr r0, [r7, #12]
|
|
8007330: f7f8 feea bl 8000108 <__udivsi3>
|
|
8007334: 0003 movs r3, r0
|
|
8007336: 61bb str r3, [r7, #24]
|
|
portNVIC_SYSTICK_LOAD = ( ( ulCompleteTickPeriods + 1 ) * ulTimerCountsForOneTick ) - ulCompletedSysTickDecrements;
|
|
8007338: 69bb ldr r3, [r7, #24]
|
|
800733a: 1c5a adds r2, r3, #1
|
|
800733c: 4b13 ldr r3, [pc, #76] ; (800738c <vPortSuppressTicksAndSleep+0x180>)
|
|
800733e: 681b ldr r3, [r3, #0]
|
|
8007340: 4353 muls r3, r2
|
|
8007342: 0019 movs r1, r3
|
|
8007344: 4b13 ldr r3, [pc, #76] ; (8007394 <vPortSuppressTicksAndSleep+0x188>)
|
|
8007346: 68fa ldr r2, [r7, #12]
|
|
8007348: 1a8a subs r2, r1, r2
|
|
800734a: 601a str r2, [r3, #0]
|
|
portNVIC_SYSTICK_CURRENT_VALUE = 0UL;
|
|
800734c: 4b0e ldr r3, [pc, #56] ; (8007388 <vPortSuppressTicksAndSleep+0x17c>)
|
|
800734e: 2200 movs r2, #0
|
|
8007350: 601a str r2, [r3, #0]
|
|
portENTER_CRITICAL();
|
|
8007352: f7ff fee5 bl 8007120 <vPortEnterCritical>
|
|
portNVIC_SYSTICK_CTRL |= portNVIC_SYSTICK_ENABLE;
|
|
8007356: 4b0b ldr r3, [pc, #44] ; (8007384 <vPortSuppressTicksAndSleep+0x178>)
|
|
8007358: 681a ldr r2, [r3, #0]
|
|
800735a: 4b0a ldr r3, [pc, #40] ; (8007384 <vPortSuppressTicksAndSleep+0x178>)
|
|
800735c: 2101 movs r1, #1
|
|
800735e: 430a orrs r2, r1
|
|
8007360: 601a str r2, [r3, #0]
|
|
vTaskStepTick( ulCompleteTickPeriods );
|
|
8007362: 69bb ldr r3, [r7, #24]
|
|
8007364: 0018 movs r0, r3
|
|
8007366: f7fe ff05 bl 8006174 <vTaskStepTick>
|
|
portNVIC_SYSTICK_LOAD = ulTimerCountsForOneTick - 1UL;
|
|
800736a: 4b08 ldr r3, [pc, #32] ; (800738c <vPortSuppressTicksAndSleep+0x180>)
|
|
800736c: 681a ldr r2, [r3, #0]
|
|
800736e: 4b09 ldr r3, [pc, #36] ; (8007394 <vPortSuppressTicksAndSleep+0x188>)
|
|
8007370: 3a01 subs r2, #1
|
|
8007372: 601a str r2, [r3, #0]
|
|
portEXIT_CRITICAL();
|
|
8007374: f7ff fee6 bl 8007144 <vPortExitCritical>
|
|
}
|
|
8007378: 46c0 nop ; (mov r8, r8)
|
|
800737a: 46bd mov sp, r7
|
|
800737c: b008 add sp, #32
|
|
800737e: bd80 pop {r7, pc}
|
|
8007380: 20000d1c .word 0x20000d1c
|
|
8007384: e000e010 .word 0xe000e010
|
|
8007388: e000e018 .word 0xe000e018
|
|
800738c: 20000d18 .word 0x20000d18
|
|
8007390: 20000d20 .word 0x20000d20
|
|
8007394: e000e014 .word 0xe000e014
|
|
|
|
08007398 <prvSetupTimerInterrupt>:
|
|
/*
|
|
* Setup the systick timer to generate the tick interrupts at the required
|
|
* frequency.
|
|
*/
|
|
void prvSetupTimerInterrupt( void )
|
|
{
|
|
8007398: b580 push {r7, lr}
|
|
800739a: af00 add r7, sp, #0
|
|
/* Calculate the constants required to configure the tick interrupt. */
|
|
#if configUSE_TICKLESS_IDLE == 1
|
|
{
|
|
ulTimerCountsForOneTick = ( configSYSTICK_CLOCK_HZ / configTICK_RATE_HZ );
|
|
800739c: 4b16 ldr r3, [pc, #88] ; (80073f8 <prvSetupTimerInterrupt+0x60>)
|
|
800739e: 681b ldr r3, [r3, #0]
|
|
80073a0: 2164 movs r1, #100 ; 0x64
|
|
80073a2: 0018 movs r0, r3
|
|
80073a4: f7f8 feb0 bl 8000108 <__udivsi3>
|
|
80073a8: 0003 movs r3, r0
|
|
80073aa: 001a movs r2, r3
|
|
80073ac: 4b13 ldr r3, [pc, #76] ; (80073fc <prvSetupTimerInterrupt+0x64>)
|
|
80073ae: 601a str r2, [r3, #0]
|
|
xMaximumPossibleSuppressedTicks = portMAX_24_BIT_NUMBER / ulTimerCountsForOneTick;
|
|
80073b0: 4b12 ldr r3, [pc, #72] ; (80073fc <prvSetupTimerInterrupt+0x64>)
|
|
80073b2: 681b ldr r3, [r3, #0]
|
|
80073b4: 0019 movs r1, r3
|
|
80073b6: 4812 ldr r0, [pc, #72] ; (8007400 <prvSetupTimerInterrupt+0x68>)
|
|
80073b8: f7f8 fea6 bl 8000108 <__udivsi3>
|
|
80073bc: 0003 movs r3, r0
|
|
80073be: 001a movs r2, r3
|
|
80073c0: 4b10 ldr r3, [pc, #64] ; (8007404 <prvSetupTimerInterrupt+0x6c>)
|
|
80073c2: 601a str r2, [r3, #0]
|
|
ulStoppedTimerCompensation = portMISSED_COUNTS_FACTOR / ( configCPU_CLOCK_HZ / configSYSTICK_CLOCK_HZ );
|
|
80073c4: 4b10 ldr r3, [pc, #64] ; (8007408 <prvSetupTimerInterrupt+0x70>)
|
|
80073c6: 222d movs r2, #45 ; 0x2d
|
|
80073c8: 601a str r2, [r3, #0]
|
|
}
|
|
#endif /* configUSE_TICKLESS_IDLE */
|
|
|
|
/* Stop and reset the SysTick. */
|
|
portNVIC_SYSTICK_CTRL = 0UL;
|
|
80073ca: 4b10 ldr r3, [pc, #64] ; (800740c <prvSetupTimerInterrupt+0x74>)
|
|
80073cc: 2200 movs r2, #0
|
|
80073ce: 601a str r2, [r3, #0]
|
|
portNVIC_SYSTICK_CURRENT_VALUE = 0UL;
|
|
80073d0: 4b0f ldr r3, [pc, #60] ; (8007410 <prvSetupTimerInterrupt+0x78>)
|
|
80073d2: 2200 movs r2, #0
|
|
80073d4: 601a str r2, [r3, #0]
|
|
|
|
/* Configure SysTick to interrupt at the requested rate. */
|
|
portNVIC_SYSTICK_LOAD = ( configCPU_CLOCK_HZ / configTICK_RATE_HZ ) - 1UL;
|
|
80073d6: 4b08 ldr r3, [pc, #32] ; (80073f8 <prvSetupTimerInterrupt+0x60>)
|
|
80073d8: 681b ldr r3, [r3, #0]
|
|
80073da: 2164 movs r1, #100 ; 0x64
|
|
80073dc: 0018 movs r0, r3
|
|
80073de: f7f8 fe93 bl 8000108 <__udivsi3>
|
|
80073e2: 0003 movs r3, r0
|
|
80073e4: 001a movs r2, r3
|
|
80073e6: 4b0b ldr r3, [pc, #44] ; (8007414 <prvSetupTimerInterrupt+0x7c>)
|
|
80073e8: 3a01 subs r2, #1
|
|
80073ea: 601a str r2, [r3, #0]
|
|
portNVIC_SYSTICK_CTRL = portNVIC_SYSTICK_CLK | portNVIC_SYSTICK_INT | portNVIC_SYSTICK_ENABLE;
|
|
80073ec: 4b07 ldr r3, [pc, #28] ; (800740c <prvSetupTimerInterrupt+0x74>)
|
|
80073ee: 2207 movs r2, #7
|
|
80073f0: 601a str r2, [r3, #0]
|
|
}
|
|
80073f2: 46c0 nop ; (mov r8, r8)
|
|
80073f4: 46bd mov sp, r7
|
|
80073f6: bd80 pop {r7, pc}
|
|
80073f8: 20000000 .word 0x20000000
|
|
80073fc: 20000d18 .word 0x20000d18
|
|
8007400: 00ffffff .word 0x00ffffff
|
|
8007404: 20000d1c .word 0x20000d1c
|
|
8007408: 20000d20 .word 0x20000d20
|
|
800740c: e000e010 .word 0xe000e010
|
|
8007410: e000e018 .word 0xe000e018
|
|
8007414: e000e014 .word 0xe000e014
|
|
|
|
08007418 <pvPortMalloc>:
|
|
static size_t xBlockAllocatedBit = 0;
|
|
|
|
/*-----------------------------------------------------------*/
|
|
|
|
void *pvPortMalloc( size_t xWantedSize )
|
|
{
|
|
8007418: b580 push {r7, lr}
|
|
800741a: b086 sub sp, #24
|
|
800741c: af00 add r7, sp, #0
|
|
800741e: 6078 str r0, [r7, #4]
|
|
BlockLink_t *pxBlock, *pxPreviousBlock, *pxNewBlockLink;
|
|
void *pvReturn = NULL;
|
|
8007420: 2300 movs r3, #0
|
|
8007422: 60fb str r3, [r7, #12]
|
|
|
|
vTaskSuspendAll();
|
|
8007424: f7fe fdca bl 8005fbc <vTaskSuspendAll>
|
|
{
|
|
/* If this is the first call to malloc then the heap will require
|
|
initialisation to setup the list of free blocks. */
|
|
if( pxEnd == NULL )
|
|
8007428: 4b49 ldr r3, [pc, #292] ; (8007550 <pvPortMalloc+0x138>)
|
|
800742a: 681b ldr r3, [r3, #0]
|
|
800742c: 2b00 cmp r3, #0
|
|
800742e: d101 bne.n 8007434 <pvPortMalloc+0x1c>
|
|
{
|
|
prvHeapInit();
|
|
8007430: f000 f8e0 bl 80075f4 <prvHeapInit>
|
|
|
|
/* Check the requested block size is not so large that the top bit is
|
|
set. The top bit of the block size member of the BlockLink_t structure
|
|
is used to determine who owns the block - the application or the
|
|
kernel, so it must be free. */
|
|
if( ( xWantedSize & xBlockAllocatedBit ) == 0 )
|
|
8007434: 4b47 ldr r3, [pc, #284] ; (8007554 <pvPortMalloc+0x13c>)
|
|
8007436: 681b ldr r3, [r3, #0]
|
|
8007438: 687a ldr r2, [r7, #4]
|
|
800743a: 4013 ands r3, r2
|
|
800743c: d000 beq.n 8007440 <pvPortMalloc+0x28>
|
|
800743e: e079 b.n 8007534 <pvPortMalloc+0x11c>
|
|
{
|
|
/* The wanted size is increased so it can contain a BlockLink_t
|
|
structure in addition to the requested amount of bytes. */
|
|
if( xWantedSize > 0 )
|
|
8007440: 687b ldr r3, [r7, #4]
|
|
8007442: 2b00 cmp r3, #0
|
|
8007444: d012 beq.n 800746c <pvPortMalloc+0x54>
|
|
{
|
|
xWantedSize += xHeapStructSize;
|
|
8007446: 2208 movs r2, #8
|
|
8007448: 687b ldr r3, [r7, #4]
|
|
800744a: 189b adds r3, r3, r2
|
|
800744c: 607b str r3, [r7, #4]
|
|
|
|
/* Ensure that blocks are always aligned to the required number
|
|
of bytes. */
|
|
if( ( xWantedSize & portBYTE_ALIGNMENT_MASK ) != 0x00 )
|
|
800744e: 687b ldr r3, [r7, #4]
|
|
8007450: 2207 movs r2, #7
|
|
8007452: 4013 ands r3, r2
|
|
8007454: d00a beq.n 800746c <pvPortMalloc+0x54>
|
|
{
|
|
/* Byte alignment required. */
|
|
xWantedSize += ( portBYTE_ALIGNMENT - ( xWantedSize & portBYTE_ALIGNMENT_MASK ) );
|
|
8007456: 687b ldr r3, [r7, #4]
|
|
8007458: 2207 movs r2, #7
|
|
800745a: 4393 bics r3, r2
|
|
800745c: 3308 adds r3, #8
|
|
800745e: 607b str r3, [r7, #4]
|
|
configASSERT( ( xWantedSize & portBYTE_ALIGNMENT_MASK ) == 0 );
|
|
8007460: 687b ldr r3, [r7, #4]
|
|
8007462: 2207 movs r2, #7
|
|
8007464: 4013 ands r3, r2
|
|
8007466: d001 beq.n 800746c <pvPortMalloc+0x54>
|
|
8007468: b672 cpsid i
|
|
800746a: e7fe b.n 800746a <pvPortMalloc+0x52>
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
if( ( xWantedSize > 0 ) && ( xWantedSize <= xFreeBytesRemaining ) )
|
|
800746c: 687b ldr r3, [r7, #4]
|
|
800746e: 2b00 cmp r3, #0
|
|
8007470: d060 beq.n 8007534 <pvPortMalloc+0x11c>
|
|
8007472: 4b39 ldr r3, [pc, #228] ; (8007558 <pvPortMalloc+0x140>)
|
|
8007474: 681b ldr r3, [r3, #0]
|
|
8007476: 687a ldr r2, [r7, #4]
|
|
8007478: 429a cmp r2, r3
|
|
800747a: d85b bhi.n 8007534 <pvPortMalloc+0x11c>
|
|
{
|
|
/* Traverse the list from the start (lowest address) block until
|
|
one of adequate size is found. */
|
|
pxPreviousBlock = &xStart;
|
|
800747c: 4b37 ldr r3, [pc, #220] ; (800755c <pvPortMalloc+0x144>)
|
|
800747e: 613b str r3, [r7, #16]
|
|
pxBlock = xStart.pxNextFreeBlock;
|
|
8007480: 4b36 ldr r3, [pc, #216] ; (800755c <pvPortMalloc+0x144>)
|
|
8007482: 681b ldr r3, [r3, #0]
|
|
8007484: 617b str r3, [r7, #20]
|
|
while( ( pxBlock->xBlockSize < xWantedSize ) && ( pxBlock->pxNextFreeBlock != NULL ) )
|
|
8007486: e004 b.n 8007492 <pvPortMalloc+0x7a>
|
|
{
|
|
pxPreviousBlock = pxBlock;
|
|
8007488: 697b ldr r3, [r7, #20]
|
|
800748a: 613b str r3, [r7, #16]
|
|
pxBlock = pxBlock->pxNextFreeBlock;
|
|
800748c: 697b ldr r3, [r7, #20]
|
|
800748e: 681b ldr r3, [r3, #0]
|
|
8007490: 617b str r3, [r7, #20]
|
|
while( ( pxBlock->xBlockSize < xWantedSize ) && ( pxBlock->pxNextFreeBlock != NULL ) )
|
|
8007492: 697b ldr r3, [r7, #20]
|
|
8007494: 685b ldr r3, [r3, #4]
|
|
8007496: 687a ldr r2, [r7, #4]
|
|
8007498: 429a cmp r2, r3
|
|
800749a: d903 bls.n 80074a4 <pvPortMalloc+0x8c>
|
|
800749c: 697b ldr r3, [r7, #20]
|
|
800749e: 681b ldr r3, [r3, #0]
|
|
80074a0: 2b00 cmp r3, #0
|
|
80074a2: d1f1 bne.n 8007488 <pvPortMalloc+0x70>
|
|
}
|
|
|
|
/* If the end marker was reached then a block of adequate size
|
|
was not found. */
|
|
if( pxBlock != pxEnd )
|
|
80074a4: 4b2a ldr r3, [pc, #168] ; (8007550 <pvPortMalloc+0x138>)
|
|
80074a6: 681b ldr r3, [r3, #0]
|
|
80074a8: 697a ldr r2, [r7, #20]
|
|
80074aa: 429a cmp r2, r3
|
|
80074ac: d042 beq.n 8007534 <pvPortMalloc+0x11c>
|
|
{
|
|
/* Return the memory space pointed to - jumping over the
|
|
BlockLink_t structure at its start. */
|
|
pvReturn = ( void * ) ( ( ( uint8_t * ) pxPreviousBlock->pxNextFreeBlock ) + xHeapStructSize );
|
|
80074ae: 693b ldr r3, [r7, #16]
|
|
80074b0: 681b ldr r3, [r3, #0]
|
|
80074b2: 2208 movs r2, #8
|
|
80074b4: 189b adds r3, r3, r2
|
|
80074b6: 60fb str r3, [r7, #12]
|
|
|
|
/* This block is being returned for use so must be taken out
|
|
of the list of free blocks. */
|
|
pxPreviousBlock->pxNextFreeBlock = pxBlock->pxNextFreeBlock;
|
|
80074b8: 697b ldr r3, [r7, #20]
|
|
80074ba: 681a ldr r2, [r3, #0]
|
|
80074bc: 693b ldr r3, [r7, #16]
|
|
80074be: 601a str r2, [r3, #0]
|
|
|
|
/* If the block is larger than required it can be split into
|
|
two. */
|
|
if( ( pxBlock->xBlockSize - xWantedSize ) > heapMINIMUM_BLOCK_SIZE )
|
|
80074c0: 697b ldr r3, [r7, #20]
|
|
80074c2: 685a ldr r2, [r3, #4]
|
|
80074c4: 687b ldr r3, [r7, #4]
|
|
80074c6: 1ad2 subs r2, r2, r3
|
|
80074c8: 2308 movs r3, #8
|
|
80074ca: 005b lsls r3, r3, #1
|
|
80074cc: 429a cmp r2, r3
|
|
80074ce: d916 bls.n 80074fe <pvPortMalloc+0xe6>
|
|
{
|
|
/* This block is to be split into two. Create a new
|
|
block following the number of bytes requested. The void
|
|
cast is used to prevent byte alignment warnings from the
|
|
compiler. */
|
|
pxNewBlockLink = ( void * ) ( ( ( uint8_t * ) pxBlock ) + xWantedSize );
|
|
80074d0: 697a ldr r2, [r7, #20]
|
|
80074d2: 687b ldr r3, [r7, #4]
|
|
80074d4: 18d3 adds r3, r2, r3
|
|
80074d6: 60bb str r3, [r7, #8]
|
|
configASSERT( ( ( ( size_t ) pxNewBlockLink ) & portBYTE_ALIGNMENT_MASK ) == 0 );
|
|
80074d8: 68bb ldr r3, [r7, #8]
|
|
80074da: 2207 movs r2, #7
|
|
80074dc: 4013 ands r3, r2
|
|
80074de: d001 beq.n 80074e4 <pvPortMalloc+0xcc>
|
|
80074e0: b672 cpsid i
|
|
80074e2: e7fe b.n 80074e2 <pvPortMalloc+0xca>
|
|
|
|
/* Calculate the sizes of two blocks split from the
|
|
single block. */
|
|
pxNewBlockLink->xBlockSize = pxBlock->xBlockSize - xWantedSize;
|
|
80074e4: 697b ldr r3, [r7, #20]
|
|
80074e6: 685a ldr r2, [r3, #4]
|
|
80074e8: 687b ldr r3, [r7, #4]
|
|
80074ea: 1ad2 subs r2, r2, r3
|
|
80074ec: 68bb ldr r3, [r7, #8]
|
|
80074ee: 605a str r2, [r3, #4]
|
|
pxBlock->xBlockSize = xWantedSize;
|
|
80074f0: 697b ldr r3, [r7, #20]
|
|
80074f2: 687a ldr r2, [r7, #4]
|
|
80074f4: 605a str r2, [r3, #4]
|
|
|
|
/* Insert the new block into the list of free blocks. */
|
|
prvInsertBlockIntoFreeList( pxNewBlockLink );
|
|
80074f6: 68bb ldr r3, [r7, #8]
|
|
80074f8: 0018 movs r0, r3
|
|
80074fa: f000 f8db bl 80076b4 <prvInsertBlockIntoFreeList>
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
xFreeBytesRemaining -= pxBlock->xBlockSize;
|
|
80074fe: 4b16 ldr r3, [pc, #88] ; (8007558 <pvPortMalloc+0x140>)
|
|
8007500: 681a ldr r2, [r3, #0]
|
|
8007502: 697b ldr r3, [r7, #20]
|
|
8007504: 685b ldr r3, [r3, #4]
|
|
8007506: 1ad2 subs r2, r2, r3
|
|
8007508: 4b13 ldr r3, [pc, #76] ; (8007558 <pvPortMalloc+0x140>)
|
|
800750a: 601a str r2, [r3, #0]
|
|
|
|
if( xFreeBytesRemaining < xMinimumEverFreeBytesRemaining )
|
|
800750c: 4b12 ldr r3, [pc, #72] ; (8007558 <pvPortMalloc+0x140>)
|
|
800750e: 681a ldr r2, [r3, #0]
|
|
8007510: 4b13 ldr r3, [pc, #76] ; (8007560 <pvPortMalloc+0x148>)
|
|
8007512: 681b ldr r3, [r3, #0]
|
|
8007514: 429a cmp r2, r3
|
|
8007516: d203 bcs.n 8007520 <pvPortMalloc+0x108>
|
|
{
|
|
xMinimumEverFreeBytesRemaining = xFreeBytesRemaining;
|
|
8007518: 4b0f ldr r3, [pc, #60] ; (8007558 <pvPortMalloc+0x140>)
|
|
800751a: 681a ldr r2, [r3, #0]
|
|
800751c: 4b10 ldr r3, [pc, #64] ; (8007560 <pvPortMalloc+0x148>)
|
|
800751e: 601a str r2, [r3, #0]
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
/* The block is being returned - it is allocated and owned
|
|
by the application and has no "next" block. */
|
|
pxBlock->xBlockSize |= xBlockAllocatedBit;
|
|
8007520: 697b ldr r3, [r7, #20]
|
|
8007522: 685a ldr r2, [r3, #4]
|
|
8007524: 4b0b ldr r3, [pc, #44] ; (8007554 <pvPortMalloc+0x13c>)
|
|
8007526: 681b ldr r3, [r3, #0]
|
|
8007528: 431a orrs r2, r3
|
|
800752a: 697b ldr r3, [r7, #20]
|
|
800752c: 605a str r2, [r3, #4]
|
|
pxBlock->pxNextFreeBlock = NULL;
|
|
800752e: 697b ldr r3, [r7, #20]
|
|
8007530: 2200 movs r2, #0
|
|
8007532: 601a str r2, [r3, #0]
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
traceMALLOC( pvReturn, xWantedSize );
|
|
}
|
|
( void ) xTaskResumeAll();
|
|
8007534: f7fe fd84 bl 8006040 <xTaskResumeAll>
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
#endif
|
|
|
|
configASSERT( ( ( ( size_t ) pvReturn ) & ( size_t ) portBYTE_ALIGNMENT_MASK ) == 0 );
|
|
8007538: 68fb ldr r3, [r7, #12]
|
|
800753a: 2207 movs r2, #7
|
|
800753c: 4013 ands r3, r2
|
|
800753e: d001 beq.n 8007544 <pvPortMalloc+0x12c>
|
|
8007540: b672 cpsid i
|
|
8007542: e7fe b.n 8007542 <pvPortMalloc+0x12a>
|
|
return pvReturn;
|
|
8007544: 68fb ldr r3, [r7, #12]
|
|
}
|
|
8007546: 0018 movs r0, r3
|
|
8007548: 46bd mov sp, r7
|
|
800754a: b006 add sp, #24
|
|
800754c: bd80 pop {r7, pc}
|
|
800754e: 46c0 nop ; (mov r8, r8)
|
|
8007550: 2000152c .word 0x2000152c
|
|
8007554: 20001538 .word 0x20001538
|
|
8007558: 20001530 .word 0x20001530
|
|
800755c: 20001524 .word 0x20001524
|
|
8007560: 20001534 .word 0x20001534
|
|
|
|
08007564 <vPortFree>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
void vPortFree( void *pv )
|
|
{
|
|
8007564: b580 push {r7, lr}
|
|
8007566: b084 sub sp, #16
|
|
8007568: af00 add r7, sp, #0
|
|
800756a: 6078 str r0, [r7, #4]
|
|
uint8_t *puc = ( uint8_t * ) pv;
|
|
800756c: 687b ldr r3, [r7, #4]
|
|
800756e: 60fb str r3, [r7, #12]
|
|
BlockLink_t *pxLink;
|
|
|
|
if( pv != NULL )
|
|
8007570: 687b ldr r3, [r7, #4]
|
|
8007572: 2b00 cmp r3, #0
|
|
8007574: d035 beq.n 80075e2 <vPortFree+0x7e>
|
|
{
|
|
/* The memory being freed will have an BlockLink_t structure immediately
|
|
before it. */
|
|
puc -= xHeapStructSize;
|
|
8007576: 2308 movs r3, #8
|
|
8007578: 425b negs r3, r3
|
|
800757a: 68fa ldr r2, [r7, #12]
|
|
800757c: 18d3 adds r3, r2, r3
|
|
800757e: 60fb str r3, [r7, #12]
|
|
|
|
/* This casting is to keep the compiler from issuing warnings. */
|
|
pxLink = ( void * ) puc;
|
|
8007580: 68fb ldr r3, [r7, #12]
|
|
8007582: 60bb str r3, [r7, #8]
|
|
|
|
/* Check the block is actually allocated. */
|
|
configASSERT( ( pxLink->xBlockSize & xBlockAllocatedBit ) != 0 );
|
|
8007584: 68bb ldr r3, [r7, #8]
|
|
8007586: 685a ldr r2, [r3, #4]
|
|
8007588: 4b18 ldr r3, [pc, #96] ; (80075ec <vPortFree+0x88>)
|
|
800758a: 681b ldr r3, [r3, #0]
|
|
800758c: 4013 ands r3, r2
|
|
800758e: d101 bne.n 8007594 <vPortFree+0x30>
|
|
8007590: b672 cpsid i
|
|
8007592: e7fe b.n 8007592 <vPortFree+0x2e>
|
|
configASSERT( pxLink->pxNextFreeBlock == NULL );
|
|
8007594: 68bb ldr r3, [r7, #8]
|
|
8007596: 681b ldr r3, [r3, #0]
|
|
8007598: 2b00 cmp r3, #0
|
|
800759a: d001 beq.n 80075a0 <vPortFree+0x3c>
|
|
800759c: b672 cpsid i
|
|
800759e: e7fe b.n 800759e <vPortFree+0x3a>
|
|
|
|
if( ( pxLink->xBlockSize & xBlockAllocatedBit ) != 0 )
|
|
80075a0: 68bb ldr r3, [r7, #8]
|
|
80075a2: 685a ldr r2, [r3, #4]
|
|
80075a4: 4b11 ldr r3, [pc, #68] ; (80075ec <vPortFree+0x88>)
|
|
80075a6: 681b ldr r3, [r3, #0]
|
|
80075a8: 4013 ands r3, r2
|
|
80075aa: d01a beq.n 80075e2 <vPortFree+0x7e>
|
|
{
|
|
if( pxLink->pxNextFreeBlock == NULL )
|
|
80075ac: 68bb ldr r3, [r7, #8]
|
|
80075ae: 681b ldr r3, [r3, #0]
|
|
80075b0: 2b00 cmp r3, #0
|
|
80075b2: d116 bne.n 80075e2 <vPortFree+0x7e>
|
|
{
|
|
/* The block is being returned to the heap - it is no longer
|
|
allocated. */
|
|
pxLink->xBlockSize &= ~xBlockAllocatedBit;
|
|
80075b4: 68bb ldr r3, [r7, #8]
|
|
80075b6: 685a ldr r2, [r3, #4]
|
|
80075b8: 4b0c ldr r3, [pc, #48] ; (80075ec <vPortFree+0x88>)
|
|
80075ba: 681b ldr r3, [r3, #0]
|
|
80075bc: 43db mvns r3, r3
|
|
80075be: 401a ands r2, r3
|
|
80075c0: 68bb ldr r3, [r7, #8]
|
|
80075c2: 605a str r2, [r3, #4]
|
|
|
|
vTaskSuspendAll();
|
|
80075c4: f7fe fcfa bl 8005fbc <vTaskSuspendAll>
|
|
{
|
|
/* Add this block to the list of free blocks. */
|
|
xFreeBytesRemaining += pxLink->xBlockSize;
|
|
80075c8: 68bb ldr r3, [r7, #8]
|
|
80075ca: 685a ldr r2, [r3, #4]
|
|
80075cc: 4b08 ldr r3, [pc, #32] ; (80075f0 <vPortFree+0x8c>)
|
|
80075ce: 681b ldr r3, [r3, #0]
|
|
80075d0: 18d2 adds r2, r2, r3
|
|
80075d2: 4b07 ldr r3, [pc, #28] ; (80075f0 <vPortFree+0x8c>)
|
|
80075d4: 601a str r2, [r3, #0]
|
|
traceFREE( pv, pxLink->xBlockSize );
|
|
prvInsertBlockIntoFreeList( ( ( BlockLink_t * ) pxLink ) );
|
|
80075d6: 68bb ldr r3, [r7, #8]
|
|
80075d8: 0018 movs r0, r3
|
|
80075da: f000 f86b bl 80076b4 <prvInsertBlockIntoFreeList>
|
|
}
|
|
( void ) xTaskResumeAll();
|
|
80075de: f7fe fd2f bl 8006040 <xTaskResumeAll>
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
}
|
|
80075e2: 46c0 nop ; (mov r8, r8)
|
|
80075e4: 46bd mov sp, r7
|
|
80075e6: b004 add sp, #16
|
|
80075e8: bd80 pop {r7, pc}
|
|
80075ea: 46c0 nop ; (mov r8, r8)
|
|
80075ec: 20001538 .word 0x20001538
|
|
80075f0: 20001530 .word 0x20001530
|
|
|
|
080075f4 <prvHeapInit>:
|
|
/* This just exists to keep the linker quiet. */
|
|
}
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static void prvHeapInit( void )
|
|
{
|
|
80075f4: b580 push {r7, lr}
|
|
80075f6: b084 sub sp, #16
|
|
80075f8: af00 add r7, sp, #0
|
|
BlockLink_t *pxFirstFreeBlock;
|
|
uint8_t *pucAlignedHeap;
|
|
size_t uxAddress;
|
|
size_t xTotalHeapSize = configTOTAL_HEAP_SIZE;
|
|
80075fa: 2380 movs r3, #128 ; 0x80
|
|
80075fc: 011b lsls r3, r3, #4
|
|
80075fe: 60bb str r3, [r7, #8]
|
|
|
|
/* Ensure the heap starts on a correctly aligned boundary. */
|
|
uxAddress = ( size_t ) ucHeap;
|
|
8007600: 4b26 ldr r3, [pc, #152] ; (800769c <prvHeapInit+0xa8>)
|
|
8007602: 60fb str r3, [r7, #12]
|
|
|
|
if( ( uxAddress & portBYTE_ALIGNMENT_MASK ) != 0 )
|
|
8007604: 68fb ldr r3, [r7, #12]
|
|
8007606: 2207 movs r2, #7
|
|
8007608: 4013 ands r3, r2
|
|
800760a: d00c beq.n 8007626 <prvHeapInit+0x32>
|
|
{
|
|
uxAddress += ( portBYTE_ALIGNMENT - 1 );
|
|
800760c: 68fb ldr r3, [r7, #12]
|
|
800760e: 3307 adds r3, #7
|
|
8007610: 60fb str r3, [r7, #12]
|
|
uxAddress &= ~( ( size_t ) portBYTE_ALIGNMENT_MASK );
|
|
8007612: 68fb ldr r3, [r7, #12]
|
|
8007614: 2207 movs r2, #7
|
|
8007616: 4393 bics r3, r2
|
|
8007618: 60fb str r3, [r7, #12]
|
|
xTotalHeapSize -= uxAddress - ( size_t ) ucHeap;
|
|
800761a: 68ba ldr r2, [r7, #8]
|
|
800761c: 68fb ldr r3, [r7, #12]
|
|
800761e: 1ad2 subs r2, r2, r3
|
|
8007620: 4b1e ldr r3, [pc, #120] ; (800769c <prvHeapInit+0xa8>)
|
|
8007622: 18d3 adds r3, r2, r3
|
|
8007624: 60bb str r3, [r7, #8]
|
|
}
|
|
|
|
pucAlignedHeap = ( uint8_t * ) uxAddress;
|
|
8007626: 68fb ldr r3, [r7, #12]
|
|
8007628: 607b str r3, [r7, #4]
|
|
|
|
/* xStart is used to hold a pointer to the first item in the list of free
|
|
blocks. The void cast is used to prevent compiler warnings. */
|
|
xStart.pxNextFreeBlock = ( void * ) pucAlignedHeap;
|
|
800762a: 4b1d ldr r3, [pc, #116] ; (80076a0 <prvHeapInit+0xac>)
|
|
800762c: 687a ldr r2, [r7, #4]
|
|
800762e: 601a str r2, [r3, #0]
|
|
xStart.xBlockSize = ( size_t ) 0;
|
|
8007630: 4b1b ldr r3, [pc, #108] ; (80076a0 <prvHeapInit+0xac>)
|
|
8007632: 2200 movs r2, #0
|
|
8007634: 605a str r2, [r3, #4]
|
|
|
|
/* pxEnd is used to mark the end of the list of free blocks and is inserted
|
|
at the end of the heap space. */
|
|
uxAddress = ( ( size_t ) pucAlignedHeap ) + xTotalHeapSize;
|
|
8007636: 687b ldr r3, [r7, #4]
|
|
8007638: 68ba ldr r2, [r7, #8]
|
|
800763a: 18d3 adds r3, r2, r3
|
|
800763c: 60fb str r3, [r7, #12]
|
|
uxAddress -= xHeapStructSize;
|
|
800763e: 2208 movs r2, #8
|
|
8007640: 68fb ldr r3, [r7, #12]
|
|
8007642: 1a9b subs r3, r3, r2
|
|
8007644: 60fb str r3, [r7, #12]
|
|
uxAddress &= ~( ( size_t ) portBYTE_ALIGNMENT_MASK );
|
|
8007646: 68fb ldr r3, [r7, #12]
|
|
8007648: 2207 movs r2, #7
|
|
800764a: 4393 bics r3, r2
|
|
800764c: 60fb str r3, [r7, #12]
|
|
pxEnd = ( void * ) uxAddress;
|
|
800764e: 68fa ldr r2, [r7, #12]
|
|
8007650: 4b14 ldr r3, [pc, #80] ; (80076a4 <prvHeapInit+0xb0>)
|
|
8007652: 601a str r2, [r3, #0]
|
|
pxEnd->xBlockSize = 0;
|
|
8007654: 4b13 ldr r3, [pc, #76] ; (80076a4 <prvHeapInit+0xb0>)
|
|
8007656: 681b ldr r3, [r3, #0]
|
|
8007658: 2200 movs r2, #0
|
|
800765a: 605a str r2, [r3, #4]
|
|
pxEnd->pxNextFreeBlock = NULL;
|
|
800765c: 4b11 ldr r3, [pc, #68] ; (80076a4 <prvHeapInit+0xb0>)
|
|
800765e: 681b ldr r3, [r3, #0]
|
|
8007660: 2200 movs r2, #0
|
|
8007662: 601a str r2, [r3, #0]
|
|
|
|
/* To start with there is a single free block that is sized to take up the
|
|
entire heap space, minus the space taken by pxEnd. */
|
|
pxFirstFreeBlock = ( void * ) pucAlignedHeap;
|
|
8007664: 687b ldr r3, [r7, #4]
|
|
8007666: 603b str r3, [r7, #0]
|
|
pxFirstFreeBlock->xBlockSize = uxAddress - ( size_t ) pxFirstFreeBlock;
|
|
8007668: 683b ldr r3, [r7, #0]
|
|
800766a: 68fa ldr r2, [r7, #12]
|
|
800766c: 1ad2 subs r2, r2, r3
|
|
800766e: 683b ldr r3, [r7, #0]
|
|
8007670: 605a str r2, [r3, #4]
|
|
pxFirstFreeBlock->pxNextFreeBlock = pxEnd;
|
|
8007672: 4b0c ldr r3, [pc, #48] ; (80076a4 <prvHeapInit+0xb0>)
|
|
8007674: 681a ldr r2, [r3, #0]
|
|
8007676: 683b ldr r3, [r7, #0]
|
|
8007678: 601a str r2, [r3, #0]
|
|
|
|
/* Only one block exists - and it covers the entire usable heap space. */
|
|
xMinimumEverFreeBytesRemaining = pxFirstFreeBlock->xBlockSize;
|
|
800767a: 683b ldr r3, [r7, #0]
|
|
800767c: 685a ldr r2, [r3, #4]
|
|
800767e: 4b0a ldr r3, [pc, #40] ; (80076a8 <prvHeapInit+0xb4>)
|
|
8007680: 601a str r2, [r3, #0]
|
|
xFreeBytesRemaining = pxFirstFreeBlock->xBlockSize;
|
|
8007682: 683b ldr r3, [r7, #0]
|
|
8007684: 685a ldr r2, [r3, #4]
|
|
8007686: 4b09 ldr r3, [pc, #36] ; (80076ac <prvHeapInit+0xb8>)
|
|
8007688: 601a str r2, [r3, #0]
|
|
|
|
/* Work out the position of the top bit in a size_t variable. */
|
|
xBlockAllocatedBit = ( ( size_t ) 1 ) << ( ( sizeof( size_t ) * heapBITS_PER_BYTE ) - 1 );
|
|
800768a: 4b09 ldr r3, [pc, #36] ; (80076b0 <prvHeapInit+0xbc>)
|
|
800768c: 2280 movs r2, #128 ; 0x80
|
|
800768e: 0612 lsls r2, r2, #24
|
|
8007690: 601a str r2, [r3, #0]
|
|
}
|
|
8007692: 46c0 nop ; (mov r8, r8)
|
|
8007694: 46bd mov sp, r7
|
|
8007696: b004 add sp, #16
|
|
8007698: bd80 pop {r7, pc}
|
|
800769a: 46c0 nop ; (mov r8, r8)
|
|
800769c: 20000d24 .word 0x20000d24
|
|
80076a0: 20001524 .word 0x20001524
|
|
80076a4: 2000152c .word 0x2000152c
|
|
80076a8: 20001534 .word 0x20001534
|
|
80076ac: 20001530 .word 0x20001530
|
|
80076b0: 20001538 .word 0x20001538
|
|
|
|
080076b4 <prvInsertBlockIntoFreeList>:
|
|
/*-----------------------------------------------------------*/
|
|
|
|
static void prvInsertBlockIntoFreeList( BlockLink_t *pxBlockToInsert )
|
|
{
|
|
80076b4: b580 push {r7, lr}
|
|
80076b6: b084 sub sp, #16
|
|
80076b8: af00 add r7, sp, #0
|
|
80076ba: 6078 str r0, [r7, #4]
|
|
BlockLink_t *pxIterator;
|
|
uint8_t *puc;
|
|
|
|
/* Iterate through the list until a block is found that has a higher address
|
|
than the block being inserted. */
|
|
for( pxIterator = &xStart; pxIterator->pxNextFreeBlock < pxBlockToInsert; pxIterator = pxIterator->pxNextFreeBlock )
|
|
80076bc: 4b27 ldr r3, [pc, #156] ; (800775c <prvInsertBlockIntoFreeList+0xa8>)
|
|
80076be: 60fb str r3, [r7, #12]
|
|
80076c0: e002 b.n 80076c8 <prvInsertBlockIntoFreeList+0x14>
|
|
80076c2: 68fb ldr r3, [r7, #12]
|
|
80076c4: 681b ldr r3, [r3, #0]
|
|
80076c6: 60fb str r3, [r7, #12]
|
|
80076c8: 68fb ldr r3, [r7, #12]
|
|
80076ca: 681b ldr r3, [r3, #0]
|
|
80076cc: 687a ldr r2, [r7, #4]
|
|
80076ce: 429a cmp r2, r3
|
|
80076d0: d8f7 bhi.n 80076c2 <prvInsertBlockIntoFreeList+0xe>
|
|
/* Nothing to do here, just iterate to the right position. */
|
|
}
|
|
|
|
/* Do the block being inserted, and the block it is being inserted after
|
|
make a contiguous block of memory? */
|
|
puc = ( uint8_t * ) pxIterator;
|
|
80076d2: 68fb ldr r3, [r7, #12]
|
|
80076d4: 60bb str r3, [r7, #8]
|
|
if( ( puc + pxIterator->xBlockSize ) == ( uint8_t * ) pxBlockToInsert )
|
|
80076d6: 68fb ldr r3, [r7, #12]
|
|
80076d8: 685b ldr r3, [r3, #4]
|
|
80076da: 68ba ldr r2, [r7, #8]
|
|
80076dc: 18d3 adds r3, r2, r3
|
|
80076de: 687a ldr r2, [r7, #4]
|
|
80076e0: 429a cmp r2, r3
|
|
80076e2: d108 bne.n 80076f6 <prvInsertBlockIntoFreeList+0x42>
|
|
{
|
|
pxIterator->xBlockSize += pxBlockToInsert->xBlockSize;
|
|
80076e4: 68fb ldr r3, [r7, #12]
|
|
80076e6: 685a ldr r2, [r3, #4]
|
|
80076e8: 687b ldr r3, [r7, #4]
|
|
80076ea: 685b ldr r3, [r3, #4]
|
|
80076ec: 18d2 adds r2, r2, r3
|
|
80076ee: 68fb ldr r3, [r7, #12]
|
|
80076f0: 605a str r2, [r3, #4]
|
|
pxBlockToInsert = pxIterator;
|
|
80076f2: 68fb ldr r3, [r7, #12]
|
|
80076f4: 607b str r3, [r7, #4]
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
|
|
/* Do the block being inserted, and the block it is being inserted before
|
|
make a contiguous block of memory? */
|
|
puc = ( uint8_t * ) pxBlockToInsert;
|
|
80076f6: 687b ldr r3, [r7, #4]
|
|
80076f8: 60bb str r3, [r7, #8]
|
|
if( ( puc + pxBlockToInsert->xBlockSize ) == ( uint8_t * ) pxIterator->pxNextFreeBlock )
|
|
80076fa: 687b ldr r3, [r7, #4]
|
|
80076fc: 685b ldr r3, [r3, #4]
|
|
80076fe: 68ba ldr r2, [r7, #8]
|
|
8007700: 18d2 adds r2, r2, r3
|
|
8007702: 68fb ldr r3, [r7, #12]
|
|
8007704: 681b ldr r3, [r3, #0]
|
|
8007706: 429a cmp r2, r3
|
|
8007708: d118 bne.n 800773c <prvInsertBlockIntoFreeList+0x88>
|
|
{
|
|
if( pxIterator->pxNextFreeBlock != pxEnd )
|
|
800770a: 68fb ldr r3, [r7, #12]
|
|
800770c: 681a ldr r2, [r3, #0]
|
|
800770e: 4b14 ldr r3, [pc, #80] ; (8007760 <prvInsertBlockIntoFreeList+0xac>)
|
|
8007710: 681b ldr r3, [r3, #0]
|
|
8007712: 429a cmp r2, r3
|
|
8007714: d00d beq.n 8007732 <prvInsertBlockIntoFreeList+0x7e>
|
|
{
|
|
/* Form one big block from the two blocks. */
|
|
pxBlockToInsert->xBlockSize += pxIterator->pxNextFreeBlock->xBlockSize;
|
|
8007716: 687b ldr r3, [r7, #4]
|
|
8007718: 685a ldr r2, [r3, #4]
|
|
800771a: 68fb ldr r3, [r7, #12]
|
|
800771c: 681b ldr r3, [r3, #0]
|
|
800771e: 685b ldr r3, [r3, #4]
|
|
8007720: 18d2 adds r2, r2, r3
|
|
8007722: 687b ldr r3, [r7, #4]
|
|
8007724: 605a str r2, [r3, #4]
|
|
pxBlockToInsert->pxNextFreeBlock = pxIterator->pxNextFreeBlock->pxNextFreeBlock;
|
|
8007726: 68fb ldr r3, [r7, #12]
|
|
8007728: 681b ldr r3, [r3, #0]
|
|
800772a: 681a ldr r2, [r3, #0]
|
|
800772c: 687b ldr r3, [r7, #4]
|
|
800772e: 601a str r2, [r3, #0]
|
|
8007730: e008 b.n 8007744 <prvInsertBlockIntoFreeList+0x90>
|
|
}
|
|
else
|
|
{
|
|
pxBlockToInsert->pxNextFreeBlock = pxEnd;
|
|
8007732: 4b0b ldr r3, [pc, #44] ; (8007760 <prvInsertBlockIntoFreeList+0xac>)
|
|
8007734: 681a ldr r2, [r3, #0]
|
|
8007736: 687b ldr r3, [r7, #4]
|
|
8007738: 601a str r2, [r3, #0]
|
|
800773a: e003 b.n 8007744 <prvInsertBlockIntoFreeList+0x90>
|
|
}
|
|
}
|
|
else
|
|
{
|
|
pxBlockToInsert->pxNextFreeBlock = pxIterator->pxNextFreeBlock;
|
|
800773c: 68fb ldr r3, [r7, #12]
|
|
800773e: 681a ldr r2, [r3, #0]
|
|
8007740: 687b ldr r3, [r7, #4]
|
|
8007742: 601a str r2, [r3, #0]
|
|
|
|
/* If the block being inserted plugged a gab, so was merged with the block
|
|
before and the block after, then it's pxNextFreeBlock pointer will have
|
|
already been set, and should not be set here as that would make it point
|
|
to itself. */
|
|
if( pxIterator != pxBlockToInsert )
|
|
8007744: 68fa ldr r2, [r7, #12]
|
|
8007746: 687b ldr r3, [r7, #4]
|
|
8007748: 429a cmp r2, r3
|
|
800774a: d002 beq.n 8007752 <prvInsertBlockIntoFreeList+0x9e>
|
|
{
|
|
pxIterator->pxNextFreeBlock = pxBlockToInsert;
|
|
800774c: 68fb ldr r3, [r7, #12]
|
|
800774e: 687a ldr r2, [r7, #4]
|
|
8007750: 601a str r2, [r3, #0]
|
|
}
|
|
else
|
|
{
|
|
mtCOVERAGE_TEST_MARKER();
|
|
}
|
|
}
|
|
8007752: 46c0 nop ; (mov r8, r8)
|
|
8007754: 46bd mov sp, r7
|
|
8007756: b004 add sp, #16
|
|
8007758: bd80 pop {r7, pc}
|
|
800775a: 46c0 nop ; (mov r8, r8)
|
|
800775c: 20001524 .word 0x20001524
|
|
8007760: 2000152c .word 0x2000152c
|
|
|
|
08007764 <__libc_init_array>:
|
|
8007764: b570 push {r4, r5, r6, lr}
|
|
8007766: 2600 movs r6, #0
|
|
8007768: 4d0c ldr r5, [pc, #48] ; (800779c <__libc_init_array+0x38>)
|
|
800776a: 4c0d ldr r4, [pc, #52] ; (80077a0 <__libc_init_array+0x3c>)
|
|
800776c: 1b64 subs r4, r4, r5
|
|
800776e: 10a4 asrs r4, r4, #2
|
|
8007770: 42a6 cmp r6, r4
|
|
8007772: d109 bne.n 8007788 <__libc_init_array+0x24>
|
|
8007774: 2600 movs r6, #0
|
|
8007776: f000 f82b bl 80077d0 <_init>
|
|
800777a: 4d0a ldr r5, [pc, #40] ; (80077a4 <__libc_init_array+0x40>)
|
|
800777c: 4c0a ldr r4, [pc, #40] ; (80077a8 <__libc_init_array+0x44>)
|
|
800777e: 1b64 subs r4, r4, r5
|
|
8007780: 10a4 asrs r4, r4, #2
|
|
8007782: 42a6 cmp r6, r4
|
|
8007784: d105 bne.n 8007792 <__libc_init_array+0x2e>
|
|
8007786: bd70 pop {r4, r5, r6, pc}
|
|
8007788: 00b3 lsls r3, r6, #2
|
|
800778a: 58eb ldr r3, [r5, r3]
|
|
800778c: 4798 blx r3
|
|
800778e: 3601 adds r6, #1
|
|
8007790: e7ee b.n 8007770 <__libc_init_array+0xc>
|
|
8007792: 00b3 lsls r3, r6, #2
|
|
8007794: 58eb ldr r3, [r5, r3]
|
|
8007796: 4798 blx r3
|
|
8007798: 3601 adds r6, #1
|
|
800779a: e7f2 b.n 8007782 <__libc_init_array+0x1e>
|
|
800779c: 08007920 .word 0x08007920
|
|
80077a0: 08007920 .word 0x08007920
|
|
80077a4: 08007920 .word 0x08007920
|
|
80077a8: 08007924 .word 0x08007924
|
|
|
|
080077ac <memcpy>:
|
|
80077ac: 2300 movs r3, #0
|
|
80077ae: b510 push {r4, lr}
|
|
80077b0: 429a cmp r2, r3
|
|
80077b2: d100 bne.n 80077b6 <memcpy+0xa>
|
|
80077b4: bd10 pop {r4, pc}
|
|
80077b6: 5ccc ldrb r4, [r1, r3]
|
|
80077b8: 54c4 strb r4, [r0, r3]
|
|
80077ba: 3301 adds r3, #1
|
|
80077bc: e7f8 b.n 80077b0 <memcpy+0x4>
|
|
|
|
080077be <memset>:
|
|
80077be: 0003 movs r3, r0
|
|
80077c0: 1882 adds r2, r0, r2
|
|
80077c2: 4293 cmp r3, r2
|
|
80077c4: d100 bne.n 80077c8 <memset+0xa>
|
|
80077c6: 4770 bx lr
|
|
80077c8: 7019 strb r1, [r3, #0]
|
|
80077ca: 3301 adds r3, #1
|
|
80077cc: e7f9 b.n 80077c2 <memset+0x4>
|
|
...
|
|
|
|
080077d0 <_init>:
|
|
80077d0: b5f8 push {r3, r4, r5, r6, r7, lr}
|
|
80077d2: 46c0 nop ; (mov r8, r8)
|
|
80077d4: bcf8 pop {r3, r4, r5, r6, r7}
|
|
80077d6: bc08 pop {r3}
|
|
80077d8: 469e mov lr, r3
|
|
80077da: 4770 bx lr
|
|
|
|
080077dc <_fini>:
|
|
80077dc: b5f8 push {r3, r4, r5, r6, r7, lr}
|
|
80077de: 46c0 nop ; (mov r8, r8)
|
|
80077e0: bcf8 pop {r3, r4, r5, r6, r7}
|
|
80077e2: bc08 pop {r3}
|
|
80077e4: 469e mov lr, r3
|
|
80077e6: 4770 bx lr
|