91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Linux環(huán)境下段錯誤的產(chǎn)生原因及調(diào)試方法小結(jié)

Linux閱碼場 ? 來源:Linuxer ? 2020-04-30 15:23 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

最近在Linux環(huán)境下做C語言項目,由于是在一個原有項目基礎(chǔ)之上進行二次開發(fā),而且項目工程龐大復(fù)雜,出現(xiàn)了不少問題,其中遇到最多、花費時間最長的問題就是著名的“段錯誤”(Segmentation Fault)。借此機會系統(tǒng)學(xué)習(xí)了一下,這里對Linux環(huán)境下的段錯誤做個小結(jié),方便以后同類問題的排查與解決。

1. 段錯誤是什么

一句話來說,段錯誤是指訪問的內(nèi)存超出了系統(tǒng)給這個程序所設(shè)定的內(nèi)存空間,例如訪問了不存在的內(nèi)存地址、訪問了系統(tǒng)保護的內(nèi)存地址、訪問了只讀的內(nèi)存地址等等情況。這里貼一個對于“段錯誤”的準確定義(參考Answers.com):

A segmentation fault (often shortened to segfault) is a particular error condition that can occur during the operation of computer software. In short, a segmentation fault occurs when a program attempts to access a memory location that it is not allowed to access, or attempts to access a memory location in a way that is not allowed (e.g., attempts to write to a read-only location, or to overwrite part of the operating system). Systems based on processors like the Motorola 68000 tend to refer to these events as Address or Bus errors. Segmentation is one approach to memory management and protection in the operating system. It has been superseded by paging for most purposes, but much of the terminology of segmentation is still used, "segmentation fault" being an example. Some operating systems still have segmentation at some logical level although paging is used as the main memory management policy. On Unix-like operating systems, a process that accesses invalid memory receives the SIGSEGV signal. On Microsoft Windows, a process that accesses invalid memory receives the STATUS_ACCESS_VIOLATION exception.

2. 段錯誤產(chǎn)生的原因

2.1 訪問不存在的內(nèi)存地址

#include#includevoid main(){int *ptr = NULL; *ptr = 0;}

2.2 訪問系統(tǒng)保護的內(nèi)存地址

#include#includevoid main(){int *ptr = (int *)0; *ptr = 100;}

2.3 訪問只讀的內(nèi)存地址

#include#include#includevoid main(){char *ptr = "test"; strcpy(ptr, "TEST");}

2.4 棧溢出

#include#includevoid main(){ main();}

等等其他原因。

3. 段錯誤信息的獲取

程序發(fā)生段錯誤時,提示信息很少,下面有幾種查看段錯誤的發(fā)生信息的途徑。

3.1 dmesg

dmesg可以在應(yīng)用程序crash掉時,顯示內(nèi)核中保存的相關(guān)信息。如下所示,通過dmesg命令可以查看發(fā)生段錯誤的程序名稱、引起段錯誤發(fā)生的內(nèi)存地址、指令指針地址、堆棧指針地址、錯誤代碼、錯誤原因等。以程序2.3為例:

panfeng@ubuntu:~/segfault$ dmesg[ 2329.479037] segfault3[2700]: segfault at 80484e0 ip 00d2906a sp bfbbec3c error 7 in libc-2.10.1.so[cb4000+13e000]

3.2 -g

使用gcc編譯程序的源碼時,加上-g參數(shù),這樣可以使得生成的二進制文件中加入可以用于gdb調(diào)試的有用信息。以程序2.3為例:

panfeng@ubuntu:~/segfault$ gcc -g -o segfault3 segfault3.c

3.3 nm

使用nm命令列出二進制文件中的符號表,包括符號地址、符號類型、符號名等,這樣可以幫助定位在哪里發(fā)生了段錯誤。以程序2.3為例:

panfeng@ubuntu:~/segfault$ nm segfault308049f20 d _DYNAMIC08049ff4 d _GLOBAL_OFFSET_TABLE_080484dc R _IO_stdin_used w _Jv_RegisterClasses08049f10 d __CTOR_END__08049f0c d __CTOR_LIST__08049f18 D __DTOR_END__08049f14 d __DTOR_LIST__080484ec r __FRAME_END__08049f1c d __JCR_END__08049f1c d __JCR_LIST__0804a014 A __bss_start0804a00c D __data_start08048490 t __do_global_ctors_aux08048360 t __do_global_dtors_aux0804a010 D __dso_handle w __gmon_start__0804848a T __i686.get_pc_thunk.bx08049f0c d __init_array_end08049f0c d __init_array_start08048420 T __libc_csu_fini08048430 T __libc_csu_init U __libc_start_main@@GLIBC_2.00804a014 A _edata0804a01c A _end080484bc T _fini080484d8 R _fp_hw080482bc T _init08048330 T _start0804a014 b completed.69900804a00c W data_start0804a018 b dtor_idx.6992080483c0 t frame_dummy080483e4 T main U memcpy@@GLIBC_2.0

3.4 ldd

使用ldd命令查看二進制程序的共享鏈接庫依賴,包括庫的名稱、起始地址,這樣可以確定段錯誤到底是發(fā)生在了自己的程序中還是依賴的共享庫中。以程序2.3為例:

panfeng@ubuntu:~/segfault$ ldd ./segfault3 linux-gate.so.1 => (0x00e08000) libc.so.6 => /lib/tls/i686/cmov/libc.so.6 (0x00675000) /lib/ld-linux.so.2 (0x00482000)

4. 段錯誤的調(diào)試方法

4.1 使用printf輸出信息

這個是看似最簡單但往往很多情況下十分有效的調(diào)試方式,也許可以說是程序員用的最多的調(diào)試方式。簡單來說,就是在程序的重要代碼附近加上像printf這類輸出信息,這樣可以跟蹤并打印出段錯誤在代碼中可能出現(xiàn)的位置。

為了方便使用這種方法,可以使用條件編譯指令#ifdef DEBUG和#endif把printf函數(shù)包起來。這樣在程序編譯時,如果加上-DDEBUG參數(shù)就能查看調(diào)試信息;否則不加該參數(shù)就不會顯示調(diào)試信息。

4.2 使用gcc和gdb

4.2.1 調(diào)試步驟

1、為了能夠使用gdb調(diào)試程序,在編譯階段加上-g參數(shù),以程序2.3為例:

panfeng@ubuntu:~/segfault$ gcc -g -o segfault3 segfault3.c

2、使用gdb命令調(diào)試程序:

panfeng@ubuntu:~/segfault$ gdb ./segfault3GNU gdb (GDB) 7.0-ubuntuCopyright (C) 2009 Free Software Foundation, Inc.License GPLv3+: GNU GPL version 3 or later This is free software: you are free to change and redistribute it.There is NO WARRANTY, to the extent permitted by law. Type "show copying"and "show warranty" for details.This GDB was configured as "i486-linux-gnu".For bug reporting instructions, please see:...Reading symbols from /home/panfeng/segfault/segfault3...done.(gdb)

3、進入gdb后,運行程序:

(gdb) runStarting program: /home/panfeng/segfault/segfault3 Program received signal SIGSEGV, Segmentation fault.0x001a306a in memcpy () from /lib/tls/i686/cmov/libc.so.6(gdb)

從輸出看出,程序2.3收到SIGSEGV信號,觸發(fā)段錯誤,并提示地址0x001a306a、調(diào)用memcpy報的錯,位于/lib/tls/i686/cmov/libc.so.6庫中。

4、完成調(diào)試后,輸入quit命令退出gdb:

(gdb) quitA debugging session is active. Inferior 1 [process 3207] will be killed. Quit anyway? (y or n) y

4.2.2 適用場景

1、僅當能確定程序一定會發(fā)生段錯誤的情況下使用。

2、當程序的源碼可以獲得的情況下,使用-g參數(shù)編譯程序。

3、一般用于測試階段,生產(chǎn)環(huán)境下gdb會有副作用:使程序運行減慢,運行不夠穩(wěn)定,等等。

4、即使在測試階段,如果程序過于復(fù)雜,gdb也不能處理。

4.3 使用core文件和gdb

在4.2節(jié)中提到段錯誤會觸發(fā)SIGSEGV信號,通過man 7 signal,可以看到SIGSEGV默認的handler會打印段錯誤出錯信息,并產(chǎn)生core文件,由此我們可以借助于程序異常退出時生成的core文件中的調(diào)試信息,使用gdb工具來調(diào)試程序中的段錯誤。

4.3.1 調(diào)試步驟

1、在一些Linux版本下,默認是不產(chǎn)生core文件的,首先可以查看一下系統(tǒng)core文件的大小限制:

panfeng@ubuntu:~/segfault$ ulimit -c0

2、可以看到默認設(shè)置情況下,本機Linux環(huán)境下發(fā)生段錯誤時不會自動生成core文件,下面設(shè)置下core文件的大小限制(單位為KB):

panfeng@ubuntu:~/segfault$ ulimit -c 1024panfeng@ubuntu:~/segfault$ ulimit -c1024

3、運行程序2.3,發(fā)生段錯誤生成core文件:

panfeng@ubuntu:~/segfault$ ./segfault3段錯誤 (core dumped)

4、加載core文件,使用gdb工具進行調(diào)試:

panfeng@ubuntu:~/segfault$ gdb ./segfault3 ./coreGNU gdb (GDB) 7.0-ubuntuCopyright (C) 2009 Free Software Foundation, Inc.License GPLv3+: GNU GPL version 3 or later This is free software: you are free to change and redistribute it.There is NO WARRANTY, to the extent permitted by law. Type "show copying"and "show warranty" for details.This GDB was configured as "i486-linux-gnu".For bug reporting instructions, please see:...Reading symbols from /home/panfeng/segfault/segfault3...done. warning: Can't read pathname for load map: 輸入/輸出錯誤.Reading symbols from /lib/tls/i686/cmov/libc.so.6...(no debugging symbols found)...done.Loaded symbols for /lib/tls/i686/cmov/libc.so.6Reading symbols from /lib/ld-linux.so.2...(no debugging symbols found)...done.Loaded symbols for /lib/ld-linux.so.2Core was generated by `./segfault3'.Program terminated with signal 11, Segmentation fault.#0 0x0018506a in memcpy () from /lib/tls/i686/cmov/libc.6

從輸出看出,同4.2.1中一樣的段錯誤信息。

5、完成調(diào)試后,輸入quit命令退出gdb:

(gdb) quit

4.3.2 適用場景

1、適合于在實際生成環(huán)境下調(diào)試程序的段錯誤(即在不用重新發(fā)生段錯誤的情況下重現(xiàn)段錯誤)。

2、當程序很復(fù)雜,core文件相當大時,該方法不可用。

4.4 使用objdump

4.4.1 調(diào)試步驟

1、使用dmesg命令,找到最近發(fā)生的段錯誤輸出信息:

panfeng@ubuntu:~/segfault$ dmesg... ...[17257.502808] segfault3[3320]: segfault at 80484e0 ip 0018506a sp bfc1cd6c error 7 in libc-2.10.1.so[110000+13e000]

其中,對我們接下來的調(diào)試過程有用的是發(fā)生段錯誤的地址:80484e0和指令指針地址:0018506a。

2、使用objdump生成二進制的相關(guān)信息,重定向到文件中:

panfeng@ubuntu:~/segfault$ objdump -d ./segfault3 > segfault3Dump

其中,生成的segfault3Dump文件中包含了二進制文件的segfault3的匯編代碼。

3、在segfault3Dump文件中查找發(fā)生段錯誤的地址:

panfeng@ubuntu:~/segfault$ grep -n -A 10 -B 10 "80484e0" ./segfault3Dump121- 80483df: ff d0 call *%eax122- 80483e1: c9 leave123- 80483e2: c3 ret124- 80483e3: 90 nop125-126-080483e4

:127- 80483e4: 55 push %ebp128- 80483e5: 89 e5 mov %esp,%ebp129- 80483e7: 83 e4 f0 and $0xfffffff0,%esp130- 80483ea: 83 ec 20 sub $0x20,%esp131: 80483ed: c7 44 24 1c e0 84 04 movl $0x80484e0,0x1c(%esp)132- 80483f4: 08133- 80483f5: b8 e5 84 04 08 mov $0x80484e5,%eax134- 80483fa: c7 44 24 08 05 00 00 movl $0x5,0x8(%esp)135- 8048401: 00136- 8048402: 89 44 24 04 mov %eax,0x4(%esp)137- 8048406: 8b 44 24 1c mov 0x1c(%esp),%eax138- 804840a: 89 04 24 mov %eax,(%esp)139- 804840d: e8 0a ff ff ff call 804831c 140- 8048412: c9 leave141- 8048413: c3 ret

通過對以上匯編代碼分析,得知段錯誤發(fā)生main函數(shù),對應(yīng)的匯編指令是movl $0x80484e0,0x1c(%esp),接下來打開程序的源碼,找到匯編指令對應(yīng)的源碼,也就定位到段錯誤了。

4.4.2 適用場景

1、不需要-g參數(shù)編譯,不需要借助于core文件,但需要有一定的匯編語言基礎(chǔ)。

2、如果使用了gcc編譯優(yōu)化參數(shù)(-O1,-O2,-O3)的話,生成的匯編指令將會被優(yōu)化,使得調(diào)試過程有些難度。

4.5 使用catchsegv

catchsegv命令專門用來撲獲段錯誤,它通過動態(tài)加載器(ld-linux.so)的預(yù)加載機制(PRELOAD)把一個事先寫好的庫(/lib/libSegFault.so)加載上,用于捕捉斷錯誤的出錯信息。

panfeng@ubuntu:~/segfault$ catchsegv ./segfault3Segmentation fault (core dumped)*** Segmentation faultRegister dump: EAX: 00000000 EBX: 00fb3ff4 ECX: 00000002 EDX: 00000000 ESI: 080484e5 EDI: 080484e0 EBP: bfb7ad38 ESP: bfb7ad0c EIP: 00ee806a EFLAGS: 00010203 CS: 0073 DS: 007b ES: 007b FS: 0000 GS: 0033 SS: 007b Trap: 0000000e Error: 00000007 OldMask: 00000000 ESP/signal: bfb7ad0c CR2: 080484e0 Backtrace:/lib/libSegFault.so[0x3b606f]??:0(??)[0xc76400]/lib/tls/i686/cmov/libc.so.6(__libc_start_main+0xe6)[0xe89b56]/build/buildd/eglibc-2.10.1/csu/../sysdeps/i386/elf/start.S:122(_start)[0x8048351] Memory map: 00258000-00273000 r-xp 00000000 08:01 157 /lib/ld-2.10.1.so00273000-00274000 r--p 0001a000 08:01 157 /lib/ld-2.10.1.so00274000-00275000 rw-p 0001b000 08:01 157 /lib/ld-2.10.1.so003b4000-003b7000 r-xp 00000000 08:01 13105 /lib/libSegFault.so003b7000-003b8000 r--p 00002000 08:01 13105 /lib/libSegFault.so003b8000-003b9000 rw-p 00003000 08:01 13105 /lib/libSegFault.so00c76000-00c77000 r-xp 00000000 00:00 0 [vdso]00e0d000-00e29000 r-xp 00000000 08:01 4817 /lib/libgcc_s.so.100e29000-00e2a000 r--p 0001b000 08:01 4817 /lib/libgcc_s.so.100e2a000-00e2b000 rw-p 0001c000 08:01 4817 /lib/libgcc_s.so.100e73000-00fb1000 r-xp 00000000 08:01 1800 /lib/tls/i686/cmov/libc-2.10.1.so00fb1000-00fb2000 ---p 0013e000 08:01 1800 /lib/tls/i686/cmov/libc-2.10.1.so00fb2000-00fb4000 r--p 0013e000 08:01 1800 /lib/tls/i686/cmov/libc-2.10.1.so00fb4000-00fb5000 rw-p 00140000 08:01 1800 /lib/tls/i686/cmov/libc-2.10.1.so00fb5000-00fb8000 rw-p 00000000 00:00 008048000-08049000 r-xp 00000000 08:01 303895 /home/panfeng/segfault/segfault308049000-0804a000 r--p 00000000 08:01 303895 /home/panfeng/segfault/segfault30804a000-0804b000 rw-p 00001000 08:01 303895 /home/panfeng/segfault/segfault309432000-09457000 rw-p 00000000 00:00 0 [heap]b78cf000-b78d1000 rw-p 00000000 00:00 0b78df000-b78e1000 rw-p 00000000 00:00 0bfb67000-bfb7c000 rw-p 00000000 00:00 0 [stack]

5. 一些注意事項

1、出現(xiàn)段錯誤時,首先應(yīng)該想到段錯誤的定義,從它出發(fā)考慮引發(fā)錯誤的原因。

2、在使用指針時,定義了指針后記得初始化指針,在使用的時候記得判斷是否為NULL。

3、在使用數(shù)組時,注意數(shù)組是否被初始化,數(shù)組下標是否越界,數(shù)組元素是否存在等。

4、在訪問變量時,注意變量所占地址空間是否已經(jīng)被程序釋放掉。

5、在處理變量時,注意變量的格式控制是否合理等。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 二進制
    +關(guān)注

    關(guān)注

    2

    文章

    809

    瀏覽量

    43045
  • Linux
    +關(guān)注

    關(guān)注

    88

    文章

    11763

    瀏覽量

    219091
  • 內(nèi)存
    +關(guān)注

    關(guān)注

    9

    文章

    3211

    瀏覽量

    76383

原文標題:Linux環(huán)境下段錯誤的產(chǎn)生原因及調(diào)試方法小結(jié)

文章出處:【微信號:LinuxDev,微信公眾號:Linux閱碼場】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    使用 J-LINK 調(diào)試時發(fā)生錯誤,是什么原因導(dǎo)致的?如何解決?

    使用J-Link調(diào)試時發(fā)生錯誤,如圖所示。我應(yīng)該如何解決這個錯誤?
    發(fā)表于 02-26 10:08

    色差是什么?它產(chǎn)生原因是什么?

    色像差(簡稱色差)。色差產(chǎn)生原因色差產(chǎn)生的根本原因就是由于光的色散效應(yīng)。白光是由不同波長的可見光組成的,例如紅色的光波長為620-750納米,藍色的波長為450
    的頭像 發(fā)表于 01-27 17:19 ?730次閱讀
    色差是什么?它<b class='flag-5'>產(chǎn)生</b>的<b class='flag-5'>原因</b>是什么?

    linux-arm開發(fā)環(huán)境的簡單配置

    linux-arm開發(fā)環(huán)境簡單配置 關(guān)于linux-arm開發(fā)環(huán)境簡單配置是ARM學(xué)習(xí)的第一步,很多初學(xué)者會在這問題上糾結(jié)很久都不能配置好開發(fā)環(huán)境
    發(fā)表于 01-13 07:56

    DR1平臺Linux應(yīng)用開發(fā)指南:含GDB調(diào)試、Python及MQTT實戰(zhàn)

    本文為創(chuàng)龍科技DR1 系列評估板 Linux 應(yīng)用開發(fā)手冊,系統(tǒng)講解開發(fā)環(huán)境搭建、GDB 調(diào)試、多類型應(yīng)用案例及 MQTT 通信實現(xiàn)。核心內(nèi)容包括 LinuxSDK 與工具鏈配置、GDB 遠程
    的頭像 發(fā)表于 01-05 16:48 ?4580次閱讀
    DR1平臺<b class='flag-5'>Linux</b>應(yīng)用開發(fā)指南:含GDB<b class='flag-5'>調(diào)試</b>、Python及MQTT實戰(zhàn)

    Linux內(nèi)核日志玩明白了嗎?printk調(diào)試神器全解析

    前言:做Linux驅(qū)動開發(fā)或內(nèi)核調(diào)試的朋友,一定對printk不陌生,但你真的會用它嗎?為什么同樣是調(diào)試RK3588內(nèi)核,別人能精準捕捉關(guān)鍵錯誤,你卻被海量日志淹沒?今天就帶大家吃透p
    的頭像 發(fā)表于 12-19 08:32 ?872次閱讀
    <b class='flag-5'>Linux</b>內(nèi)核日志玩明白了嗎?printk<b class='flag-5'>調(diào)試</b>神器全解析

    單片機系統(tǒng)硬件的調(diào)試方法

    單片機的系統(tǒng)硬件調(diào)試,通常有靜態(tài)調(diào)試和動態(tài)調(diào)試兩種不同,前者是通過目測、萬能表測試、加電檢查、聯(lián)機檢查的方法,在加電于樣機之前.對樣機的型號規(guī)格,以及安裝要求等進行核對,同時檢查 電源
    發(fā)表于 12-03 06:10

    e203仿真報Syntax error: \"&amp;\"unexpected錯誤原因

    剛開始接觸學(xué)習(xí)e203,仿真的第一步就遇上問題。按照手冊在linux環(huán)境下跑仿真遇到如圖錯誤: 有人說是e203版本問題,遂下載了更早的版本: https://github.com
    發(fā)表于 11-05 13:39

    在Windows和Linux環(huán)境下分別使用Olimex和蜂鳥調(diào)試器下載程序

    本隊伍編號CICC3042,本篇文章介紹在Windows和Linux環(huán)境下分別使用Olimex和蜂鳥調(diào)試器下載程序,和上一篇Hbirdv2的移植配合使用。 使用過第一版蜂鳥的同學(xué)們可能按照書中
    發(fā)表于 10-31 08:26

    國產(chǎn)!全志T113-i 雙核Cortex-A7@1.2GHz 工業(yè)開發(fā)板—GDB程序調(diào)試方法說明

    前 ?言 本指導(dǎo)文檔適用開發(fā)環(huán)境: ? Windows開發(fā)環(huán)境:Windows 7 64bit、Windows 10 64bit 虛擬機:VMware15.5.5 Linux開發(fā)環(huán)境
    的頭像 發(fā)表于 08-05 15:33 ?568次閱讀
    國產(chǎn)!全志T113-i 雙核Cortex-A7@1.2GHz 工業(yè)開發(fā)板—GDB程序<b class='flag-5'>調(diào)試</b><b class='flag-5'>方法</b>說明

    Linux系統(tǒng)環(huán)境監(jiān)測終極指南

    Linux系統(tǒng)環(huán)境主要監(jiān)測CPU、內(nèi)存、磁盤I/O和網(wǎng)絡(luò)流量。
    的頭像 發(fā)表于 06-25 14:41 ?825次閱讀
    <b class='flag-5'>Linux</b>系統(tǒng)<b class='flag-5'>環(huán)境</b>監(jiān)測終極指南

    激光焊錫中虛焊產(chǎn)生原因和解決方法

    激光焊錫是發(fā)展的非常成熟的一種焊接技術(shù),但是在一些參數(shù)控制不好的情況下,依然會產(chǎn)生一些焊接問題,比如說虛焊的問題。松盛光電來給大家介紹一下激光錫焊中虛焊問題產(chǎn)生原因及其解決方案。
    的頭像 發(fā)表于 06-25 09:41 ?1655次閱讀

    硬件調(diào)試:JLink 驅(qū)動配置與調(diào)試技巧

    摘要: 本文深入探討了 JLink 調(diào)試器在嵌入式系統(tǒng)硬件調(diào)試中的應(yīng)用,詳細闡述了 JLink 驅(qū)動配置的方法以及硬件調(diào)試技巧。本文以國科安芯的AS32系列MCU芯片為例,通過分析 J
    的頭像 發(fā)表于 06-12 23:20 ?1673次閱讀
    硬件<b class='flag-5'>調(diào)試</b>:JLink 驅(qū)動配置與<b class='flag-5'>調(diào)試</b>技巧

    遠程日志errDump調(diào)試功能實戰(zhàn)教程:案例驅(qū)動的故障排查!

    及Air8101開發(fā)板實操驗證。 ? 一、errDump功能介紹 1.1 errDump有什么用? errDump是LuatOS系統(tǒng)中的錯誤日志上報模塊,主要用于遠程調(diào)試與故障診斷。 其原理是將模塊運行過程中產(chǎn)生
    的頭像 發(fā)表于 06-09 16:51 ?746次閱讀
    遠程日志errDump<b class='flag-5'>調(diào)試</b>功能實戰(zhàn)教程:案例驅(qū)動的故障排查!

    晶圓表面清洗靜電力產(chǎn)生原因

    晶圓表面清洗過程中產(chǎn)生靜電力的原因主要與材料特性、工藝環(huán)境和設(shè)備操作等因素相關(guān),以下是系統(tǒng)性分析: 1. 靜電力產(chǎn)生的核心機制 摩擦起電(Triboelectric Effect) 接
    的頭像 發(fā)表于 05-28 13:38 ?993次閱讀

    UVC FX3 I2C通信錯誤\"CY_U3P_ERROR_LOST_ARBITRATION\"的原因?

    我試圖在 FX3 板和我的定制板之間建立 I2C 通信,但在 CyU3PI2cReceiveBytes 函數(shù)中遇到錯誤 55\"CY_U3P_ERROR_LOST_ARBITRATION\" 。 請說明出現(xiàn)此錯誤原因以及
    發(fā)表于 05-21 06:17