



'embeded > Cortex-M7 STM' 카테고리의 다른 글
| stm32cubeide gdb external flash (0) | 2021.07.02 |
|---|---|
| TouchGFX on STM32F746G-DISCO (4) | 2021.07.02 |
| st-link stm32 option bytes (0) | 2021.07.02 |
| cortex-M7 우와.. -_- (0) | 2021.07.02 |
| new 장난감! STM32F746G-DISCO (0) | 2021.07.02 |




| stm32cubeide gdb external flash (0) | 2021.07.02 |
|---|---|
| TouchGFX on STM32F746G-DISCO (4) | 2021.07.02 |
| st-link stm32 option bytes (0) | 2021.07.02 |
| cortex-M7 우와.. -_- (0) | 2021.07.02 |
| new 장난감! STM32F746G-DISCO (0) | 2021.07.02 |
AVR의 fuse bit 같은 녀석
| Level 0: no read protection Level 1: read protection enabled Level 2: debug/chip read protection disabled |
[링크 : https://www.st.com/resource/en/reference_manual/DM00031020-.pdf]
| stm32 wdg 최대 설정시간 (0) | 2021.08.09 |
|---|---|
| stm32 RST pull-up reset fail (0) | 2021.08.02 |
| stm32 uart echo (0) | 2021.02.04 |
| STM32CubeIDE / HAL register callbacks (0) | 2021.02.03 |
| STM32CubeIDE 주의사항(?) (0) | 2021.02.02 |
DMIPS 값이 아주 넘사벽이네.. ㄷㄷ
L1 캐시의 유무도 클꺼고..
| Characteristics Performance Efficiency: 5.01 CoreMark/MHz* and 2.14/3.23 DMIPS/MHz** |
[링크 : https://developer.arm.com/ip-products/processors/cortex-m/cortex-m7]
[링크 : https://yomi-tory.tistory.com/entry/그것을-알아보자-ARM-Cortex-M7]
| Characteristics Performance Efficiency: 3.42 CoreMark/MHz* and without FPU: 1.25 /1.52 /1.91 DMIPS/MHz**, with FPU: 1.27 /1.55 /1.95 DMIPS/MHz** |
[링크 : https://developer.arm.com/ip-products/processors/cortex-m/cortex-m4]
[링크 : https://yomi-tory.tistory.com/entry/그것을-알아보자-ARM-Cortex-M4]
| stm32cubeide gdb external flash (0) | 2021.07.02 |
|---|---|
| TouchGFX on STM32F746G-DISCO (4) | 2021.07.02 |
| st-link stm32 option bytes (0) | 2021.07.02 |
| st-link util external module? (0) | 2021.07.02 |
| new 장난감! STM32F746G-DISCO (0) | 2021.07.02 |
와.. cortex-m7 이라는건 첨 들어보네
| STM32F746NGH6 in TFBGA216 package ARM®32-bit Cortex®-M7 + FPU + Chrom-ART Accelerator 216 MHz max CPU frequency VDD from 1.7 V to 3.6 V 1024 KB Flash 320 KB SRAM GPIOs (168) with external interrupt capability 12-bit ADCs with 24 channels (3) 12-bit DAC channels (2) USART/UART (8) I2C (4) SPI (6) Advanced-control Timer (2) Low-power Timer (1) General Purpose Timers (12) Watchdog Timers (2) CAN 2.0B active (2) SAI (2) USB 2.0 OTG HS USB 2.0 OTG FS Ethernet SDMMC Camera interface Random Generator (TRNG for HW entropy) LCD-TFT |
[링크 : https://os.mbed.com/platforms/ST-Discovery-F746NG/]
[링크 : https://www.st.com/en/evaluation-tools/32f746gdiscovery.html]
[링크 : https://blog.naver.com/chandong83/220783693412] 2016년 글이니 나온지 꽤 된 녀석이구나..
| stm32cubeide gdb external flash (0) | 2021.07.02 |
|---|---|
| TouchGFX on STM32F746G-DISCO (4) | 2021.07.02 |
| st-link stm32 option bytes (0) | 2021.07.02 |
| st-link util external module? (0) | 2021.07.02 |
| cortex-M7 우와.. -_- (0) | 2021.07.02 |
GND에 빨간선이 연결되어있고
스위치의 반대편은 GPIO로 연결되어 있는데
GPIO에 pull up이 있어서 인지 스위치를 누르면 ground로 인식이 된다.
(아래 코드에서 4번째 라인 not을 지웠다가 파일 바꾼다고 dog 고생을...)
while True:
# Check each pin
for key_pin in key_pin_array:
if not key_pin.value: # Is it grounded?
i = key_pin_array.index(key_pin)
print("Pin #{} is grounded.".format(i))
# Turn on the red LED
led.value = True
while not key_pin.value:
pass # Wait for it to be ungrounded!
# "Type" the Keycode or string
key = keys_pressed[i] # Get the corresponding Keycode or string
if isinstance(key, str): # If it's a string...
keyboard_layout.write(key) # ...Print the string
else: # If it's not a string...
keyboard.press(control_key, key) # "Press"...
keyboard.release_all() # ..."Release"!
# Turn off the red LED
led.value = False
time.sleep(0.01)
아무튼.. 원래 의도는 3V 전원에서 330옴 통해서 전류 제한해서 gpio로 3.3V가 들어가게 하는거였는데
멀 잘못했네.. 멀티메터로는 정상적으로 3.3V 나오던데 ㅠㅠ

[링크 : https://circuitpython.readthedocs.io/projects/hid/en/latest/api.html]
+

| rpi pico pwm channel (0) | 2021.08.02 |
|---|---|
| rpi pico c (0) | 2021.07.07 |
| rpi pico, circuitpython, USB HID (0) | 2021.06.28 |
| rpi pico pinout (0) | 2021.06.28 |
| rpi pico USB OTG를 이용한 오실로스코프 (0) | 2021.06.27 |
아부지 카메라 니콘 p900s 배터리랑 충전기 4달라! 외치셔서 대리 지름
아니.. 링크까지 찾을줄 아시면 이제 구매만 누르면 되는데!!!!!!!!

| 블루투스 사운드 바 LP-S09 분해 (0) | 2021.07.20 |
|---|---|
| 당근 무료나눔 받아옴 (2) | 2021.07.20 |
| 지를까 말까 고민 중 (0) | 2021.06.07 |
| 월 초 = 지름 (2) | 2021.06.01 |
| 월 말 (2) | 2021.05.31 |
아따 빡세다 -_-
컴파일 하는데 libz.so.1이 없다고 하는데
아마도.. 64bit ubuntu라 32bit 용 libz가 없다고 배쨰는 듯
| /home/minimonk/work/tools/arm-bcm2708/gcc-linaro-arm-linux-gnueabihf-raspbian/bin/../libexec/gcc/arm-linux-gnueabihf/4.8.3/cc1plus: error while loading shared libraries: libz.so.1: cannot open shared object file: No such file or directory $sudo apt-get install lib32z1 |
[링크 : https://damedame.tistory.com/entry/libzso1-파일을-찾을수-없을때]
std::is_trivially_copyable은 c++11 표준이라 gcc 5.x 이상부터 지원하기 때문이라고
| In file included from /home/minimonk/work/tensorflow/tensorflow/lite/tools/make/downloads/ruy/ruy/frontend.h:30:0, from /home/minimonk/work/tensorflow/tensorflow/lite/tools/make/downloads/ruy/ruy/ruy.h:23, from ./tensorflow/lite/kernels/cpu_backend_gemm_ruy.h:21, from ./tensorflow/lite/kernels/cpu_backend_gemm.h:25, from ./tensorflow/lite/kernels/internal/optimized/optimized_ops.h:45, from tensorflow/lite/kernels/audio_spectrogram.cc:24: /home/minimonk/work/tensorflow/tensorflow/lite/tools/make/downloads/ruy/ruy/create_trmul_params.h: In function ‘void ruy::detail::FinalizeMulParams(const ruy::MulParams<AccumScalar, DstScalar>&, ruy::ChannelDimension, ruy::Ctx*, ruy::TrMulParams*)’: /home/minimonk/work/tensorflow/tensorflow/lite/tools/make/downloads/ruy/ruy/create_trmul_params.h:388:17: error: ‘is_trivially_copyable’ is not a member of ‘std’ static_assert(std::is_trivially_copyable<MulParamsType>::value, ""); ^ /home/minimonk/work/tensorflow/tensorflow/lite/tools/make/downloads/ruy/ruy/create_trmul_params.h:388:57: error: expected primary-expression before ‘>’ token static_assert(std::is_trivially_copyable<MulParamsType>::value, ""); ^ /home/minimonk/work/tensorflow/tensorflow/lite/tools/make/downloads/ruy/ruy/create_trmul_params.h:388:58: error: ‘::value’ has not been declared static_assert(std::is_trivially_copyable<MulParamsType>::value, ""); ^ |
[링크 : https://stackoverflow.com/questions/25123458/is-trivially-copyable-is-not-a-member-of-std]
예라이... -_-
| $ arm-linux-gnueabihf-g++ --version arm-linux-gnueabihf-g++ (crosstool-NG linaro-1.13.1-4.8-2014.01 - Linaro GCC 2013.11) 4.8.3 20140106 (prerelease) Copyright (C) 2013 Free Software Foundation, Inc. This is free software; see the source for copying conditions. There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
| $ sudo apt-get install gcc-arm-linux-gnueabihf g++-arm-linux-gnueabihf |
| tflite gpu openCL support build fail (0) | 2021.08.31 |
|---|---|
| tf lite cmake (0) | 2021.08.27 |
| tensorflow lite on rpi4 64bit (0) | 2021.06.30 |
| tensorflow delegate (0) | 2021.06.30 |
| tflite typed_tensor(), tensor() (0) | 2021.06.25 |
| 5.7.2 Advanced SIMD Mnemonics Although derived from the AArch32 Advanced SIMD syntax, a number of changes have been made to harmonise with the AArch64 core integer and floating point instruction set syntax, and to unify AArch32’s divergent “architectural” and “programmers’” notations: • The ‘V’ mnemonic prefix has been removed, and S/U/F/P added to indicate signed/unsigned/floatingpoint/polynomial data type. The mnemonic always indicates the data type(s) of the operation. • The vector organisation (element size and number of lanes) is described by the register qualifiers and never by a mnemonic qualifier. See the description of the vector register syntax in §4.4.2 above. • The ‘P’ prefix for “pairwise” operations becomes a suffix. • A ‘V’ suffix has been added for the new reduction (across-all-lanes) operations • A ‘2’ suffix has been added for the new widening/narrowing “second part” instructions, described below. • Vector compares now use the integer condition code names to indicate whether an integer comparison is signed or unsigned (e.g. CMLT, CMLO, CMGE, CMHI, etc) • Some mnemonics have been renamed where the removal of the V prefix caused clash with the core instruction set mnemonics. ADD Vd.<T>, Vn.<T>, Vm.<T> Integer add (vector). Where <T> is 8B, 16B, 4H, 8H, 2S, 4S or 2D |
| $ gcc neon.c -fopt-info-vec -O3 neon.c:10:9: note: loop vectorized |
vadd 이런게 안보이네?
| $ objdump -d a.out a.out: file format elf64-littleaarch64 Disassembly of section .init: 00000000000005d0 <_init>: 5d0: a9bf7bfd stp x29, x30, [sp, #-16]! 5d4: 910003fd mov x29, sp 5d8: 94000043 bl 6e4 <call_weak_fn> 5dc: a8c17bfd ldp x29, x30, [sp], #16 5e0: d65f03c0 ret Disassembly of section .plt: 00000000000005f0 <.plt>: 5f0: a9bf7bf0 stp x16, x30, [sp, #-16]! 5f4: 90000090 adrp x16, 10000 <__FRAME_END__+0xf680> 5f8: f947fe11 ldr x17, [x16, #4088] 5fc: 913fe210 add x16, x16, #0xff8 600: d61f0220 br x17 604: d503201f nop 608: d503201f nop 60c: d503201f nop 0000000000000610 <__cxa_finalize@plt>: 610: b0000090 adrp x16, 11000 <__cxa_finalize@GLIBC_2.17> 614: f9400211 ldr x17, [x16] 618: 91000210 add x16, x16, #0x0 61c: d61f0220 br x17 0000000000000620 <__libc_start_main@plt>: 620: b0000090 adrp x16, 11000 <__cxa_finalize@GLIBC_2.17> 624: f9400611 ldr x17, [x16, #8] 628: 91002210 add x16, x16, #0x8 62c: d61f0220 br x17 0000000000000630 <__gmon_start__@plt>: 630: b0000090 adrp x16, 11000 <__cxa_finalize@GLIBC_2.17> 634: f9400a11 ldr x17, [x16, #16] 638: 91004210 add x16, x16, #0x10 63c: d61f0220 br x17 0000000000000640 <abort@plt>: 640: b0000090 adrp x16, 11000 <__cxa_finalize@GLIBC_2.17> 644: f9400e11 ldr x17, [x16, #24] 648: 91006210 add x16, x16, #0x18 64c: d61f0220 br x17 0000000000000650 <printf@plt>: 650: b0000090 adrp x16, 11000 <__cxa_finalize@GLIBC_2.17> 654: f9401211 ldr x17, [x16, #32] 658: 91008210 add x16, x16, #0x20 65c: d61f0220 br x17 Disassembly of section .text: 0000000000000660 <main>: 660: d13003ff sub sp, sp, #0xc00 664: 912003e0 add x0, sp, #0x800 668: 911003e2 add x2, sp, #0x400 66c: 910003e1 mov x1, sp 670: 913003e3 add x3, sp, #0xc00 674: d503201f nop 678: 3cc10401 ldr q1, [x0], #16 67c: 3cc10440 ldr q0, [x2], #16 680: eb03001f cmp x0, x3 684: 4ea18400 add v0.4s, v0.4s, v1.4s 688: 3c810420 str q0, [x1], #16 68c: 54ffff61 b.ne 678 <main+0x18> // b.any 690: b94003e1 ldr w1, [sp] 694: 90000000 adrp x0, 0 <_init-0x5d0> 698: b94403e2 ldr w2, [sp, #1024] 69c: 91214000 add x0, x0, #0x850 6a0: b94803e3 ldr w3, [sp, #2048] 6a4: 913003ff add sp, sp, #0xc00 6a8: 17ffffea b 650 <printf@plt> 00000000000006ac <_start>: 6ac: d280001d mov x29, #0x0 // #0 6b0: d280001e mov x30, #0x0 // #0 6b4: aa0003e5 mov x5, x0 6b8: f94003e1 ldr x1, [sp] 6bc: 910023e2 add x2, sp, #0x8 6c0: 910003e6 mov x6, sp 6c4: 90000080 adrp x0, 10000 <__FRAME_END__+0xf680> 6c8: f947ec00 ldr x0, [x0, #4056] 6cc: 90000083 adrp x3, 10000 <__FRAME_END__+0xf680> 6d0: f947e863 ldr x3, [x3, #4048] 6d4: 90000084 adrp x4, 10000 <__FRAME_END__+0xf680> 6d8: f947d884 ldr x4, [x4, #4016] 6dc: 97ffffd1 bl 620 <__libc_start_main@plt> 6e0: 97ffffd8 bl 640 <abort@plt> 00000000000006e4 <call_weak_fn>: 6e4: 90000080 adrp x0, 10000 <__FRAME_END__+0xf680> 6e8: f947e400 ldr x0, [x0, #4040] 6ec: b4000040 cbz x0, 6f4 <call_weak_fn+0x10> 6f0: 17ffffd0 b 630 <__gmon_start__@plt> 6f4: d65f03c0 ret 00000000000006f8 <deregister_tm_clones>: 6f8: b0000080 adrp x0, 11000 <__cxa_finalize@GLIBC_2.17> 6fc: 9100e000 add x0, x0, #0x38 700: b0000081 adrp x1, 11000 <__cxa_finalize@GLIBC_2.17> 704: 9100e021 add x1, x1, #0x38 708: eb00003f cmp x1, x0 70c: 540000a0 b.eq 720 <deregister_tm_clones+0x28> // b.none 710: 90000081 adrp x1, 10000 <__FRAME_END__+0xf680> 714: f947dc21 ldr x1, [x1, #4024] 718: b4000041 cbz x1, 720 <deregister_tm_clones+0x28> 71c: d61f0020 br x1 720: d65f03c0 ret 724: d503201f nop 0000000000000728 <register_tm_clones>: 728: b0000080 adrp x0, 11000 <__cxa_finalize@GLIBC_2.17> 72c: 9100e000 add x0, x0, #0x38 730: b0000081 adrp x1, 11000 <__cxa_finalize@GLIBC_2.17> 734: 9100e021 add x1, x1, #0x38 738: cb000021 sub x1, x1, x0 73c: 9343fc21 asr x1, x1, #3 740: 8b41fc21 add x1, x1, x1, lsr #63 744: 9341fc21 asr x1, x1, #1 748: b40000a1 cbz x1, 75c <register_tm_clones+0x34> 74c: 90000082 adrp x2, 10000 <__FRAME_END__+0xf680> 750: f947f042 ldr x2, [x2, #4064] 754: b4000042 cbz x2, 75c <register_tm_clones+0x34> 758: d61f0040 br x2 75c: d65f03c0 ret 0000000000000760 <__do_global_dtors_aux>: 760: a9be7bfd stp x29, x30, [sp, #-32]! 764: 910003fd mov x29, sp 768: f9000bf3 str x19, [sp, #16] 76c: b0000093 adrp x19, 11000 <__cxa_finalize@GLIBC_2.17> 770: 3940e260 ldrb w0, [x19, #56] 774: 35000140 cbnz w0, 79c <__do_global_dtors_aux+0x3c> 778: 90000080 adrp x0, 10000 <__FRAME_END__+0xf680> 77c: f947e000 ldr x0, [x0, #4032] 780: b4000080 cbz x0, 790 <__do_global_dtors_aux+0x30> 784: b0000080 adrp x0, 11000 <__cxa_finalize@GLIBC_2.17> 788: f9401800 ldr x0, [x0, #48] 78c: 97ffffa1 bl 610 <__cxa_finalize@plt> 790: 97ffffda bl 6f8 <deregister_tm_clones> 794: 52800020 mov w0, #0x1 // #1 798: 3900e260 strb w0, [x19, #56] 79c: f9400bf3 ldr x19, [sp, #16] 7a0: a8c27bfd ldp x29, x30, [sp], #32 7a4: d65f03c0 ret 00000000000007a8 <frame_dummy>: 7a8: 17ffffe0 b 728 <register_tm_clones> 7ac: d503201f nop 00000000000007b0 <__libc_csu_init>: 7b0: a9bc7bfd stp x29, x30, [sp, #-64]! 7b4: 910003fd mov x29, sp 7b8: a90153f3 stp x19, x20, [sp, #16] 7bc: 90000094 adrp x20, 10000 <__FRAME_END__+0xf680> 7c0: 91370294 add x20, x20, #0xdc0 7c4: a9025bf5 stp x21, x22, [sp, #32] 7c8: 90000095 adrp x21, 10000 <__FRAME_END__+0xf680> 7cc: 9136e2b5 add x21, x21, #0xdb8 7d0: cb150294 sub x20, x20, x21 7d4: 2a0003f6 mov w22, w0 7d8: a90363f7 stp x23, x24, [sp, #48] 7dc: aa0103f7 mov x23, x1 7e0: aa0203f8 mov x24, x2 7e4: 9343fe94 asr x20, x20, #3 7e8: 97ffff7a bl 5d0 <_init> 7ec: b4000174 cbz x20, 818 <__libc_csu_init+0x68> 7f0: d2800013 mov x19, #0x0 // #0 7f4: d503201f nop 7f8: f8737aa3 ldr x3, [x21, x19, lsl #3] 7fc: aa1803e2 mov x2, x24 800: 91000673 add x19, x19, #0x1 804: aa1703e1 mov x1, x23 808: 2a1603e0 mov w0, w22 80c: d63f0060 blr x3 810: eb13029f cmp x20, x19 814: 54ffff21 b.ne 7f8 <__libc_csu_init+0x48> // b.any 818: a94153f3 ldp x19, x20, [sp, #16] 81c: a9425bf5 ldp x21, x22, [sp, #32] 820: a94363f7 ldp x23, x24, [sp, #48] 824: a8c47bfd ldp x29, x30, [sp], #64 828: d65f03c0 ret 82c: d503201f nop 0000000000000830 <__libc_csu_fini>: 830: d65f03c0 ret Disassembly of section .fini: 0000000000000834 <_fini>: 834: a9bf7bfd stp x29, x30, [sp, #-16]! 838: 910003fd mov x29, sp 83c: a8c17bfd ldp x29, x30, [sp], #16 840: d65f03c0 ret |
| 조향장치 완성 (0) | 2021.07.24 |
|---|---|
| rpi 2b pxe (0) | 2021.07.12 |
| rpi 4b 32bit vs 64bit? (0) | 2021.06.30 |
| rpi 4 32bit / 64bit cpuinfo (0) | 2021.06.30 |
| AArch64 linux cpu features (0) | 2021.06.30 |
라고 적기에는 좀 애매한데
아무튼 NEON 가속을 통해 동일한 프로그램을 돌리는데
32bit 에서는 초당 7.5 프레임
64bit 에서는 초당 11 프레임까지 연산이 가능해지는게 신기해서 찾아보는 중
다른분에게 여쭤보니
메모리 대역폭이 늘어나거나 neon bit width 영향이 아닐까 라고 말씀하셔서 찾아보는데
보기에는 어짜피 float 변수라 single precision으로 차이가 없고
int 형이 연산에 시간을 많이 빼앗길 부분이라 up to 16x8bit operations per instruction 이라
속도에 영향을 주는건 그럼.. 전송 대역폭 혹은 메모리 복사에 다른 속도 차이 정도 이려나?

| rpi 2b pxe (0) | 2021.07.12 |
|---|---|
| aarch, armv8 asimd build (neon) (0) | 2021.06.30 |
| rpi 4 32bit / 64bit cpuinfo (0) | 2021.06.30 |
| AArch64 linux cpu features (0) | 2021.06.30 |
| citcuitpyrhon joystick (0) | 2021.06.28 |
build_rpi_lib.sh를 통해 빌드 하려는데 에러 뿜뿜 -_-
그래서 makefile을 고쳐야 하나 멘붕이 와서 다시 찾아 보는데
| /bin/bash: arm-linux-gnueabihf-g++: command not found |
| ./tensorflow/lite/tools/make/build_aarch64_lib.sh |
[링크 : https://www.tensorflow.org/lite/guide/build_arm64?hl=ko]
| tf lite cmake (0) | 2021.08.27 |
|---|---|
| tensorflow cross compile (0) | 2021.07.01 |
| tensorflow delegate (0) | 2021.06.30 |
| tflite typed_tensor(), tensor() (0) | 2021.06.25 |
| tflite yolov4 (0) | 2021.06.14 |