본문 바로가기

Core BSP 분석/리눅스 커널 핵심 분석

(90)
kernel panic - HARDLOCKUP [ 240.64624 01-01 00:04:04.840 CPU1] healthd: battery l=94 v=4 t=25.0 h=2 st=2 chg=u [ 253.70946 01-01 00:04:17.900 CPU1] lkdtm: Performing direct entry HARDLOCKUP [ 258.84042 01-01 00:04:23.040 CPU0] BUG: CPU 0 waiting for CSD lock held by CPU 1 [ 258.84053 01-01 00:04:23.040 CPU0] CPU: 0 PID: 143 Comm: kworker/0:3 Tainted: G W 3.10.20-x86_64_moor-dirty #4 [ 258.84065 01-01 00:04:23.040 CPU0] W..
와치독 리셋 - atd daemon 와치독 리셋이 발생하는 디바이스에서 아래와 같은 툼스톤, 즉 유언이 확인되었다. backtrace: #00 pc 000221c8 /system/lib/libc.so (tgkill+12) #01 pc 000131c9 /system/lib/libc.so (pthread_kill+48) #02 pc 000133dd /system/lib/libc.so (raise+10) #03 pc 00012113 /system/lib/libc.so #04 pc 00021a7c /system/lib/libc.so (abort+4) #05 pc 00012bf9 /system/lib/libc.so #06 pc 00012c0f /system/lib/libc.so #07 pc 00023af7 /system/lib/libc.so (__..
커널 패닉 이슈: tty_wakeup() 08/18/2014 커널이 아래와 같은 유서를 남기고 돌아가셨다. tty_wakeup()에서 돌아가셨고, 암은 슈퍼바이저 모드상태였다. [71653.259161 08-15 11:27:39.779] android_work: did not send uevent (0 0 (null)) [71653.290526 08-15 11:27:39.811] android_work: sent uevent USB_STATE=CONNECTED [71653.292844 08-15 11:27:39.813] android_work: sent uevent USB_STATE=DISCONNECTED [71653.365187 08-15 11:27:39.885] android_usb gadget: high speed config #1: android [7165..
MMU - 페이지 테이블 덤프 섹션 엔트리 페이지 테이블은 아래와 같다. _______________________logical|_physical_____________________|sec|_d_|_size____|_permissions____________________|_glb|_shr|_pageflags_(remapped)___________|_tablewalk C:03A0:DFBFF000--DFBFFFFF| A:9FBFF000--9FBFFFFF| ns| 00| 00100000| P:readwrite U:noaccess exec | yes| yes| strongly ordered | A6F9C000[0DFB]=9FB1140E C:03A0:DFC00000--DFC00FFF| A:9FC00000--9FC00FFF| ns| 00| ..
Crash 명령어 스택 심볼 보기 아래와 같이 커널 패닉 로그가 나왔을 때, [ 35.106647 01-05 13:30:50.343] [] (ext4_free_inode+0x288/0x574) from [] (ext4_evict_inode+0x2f0/0x4c0) [ 35.117770 01-05 13:30:50.354] [] (ext4_evict_inode+0x2f0/0x4c0) from [] (evict+0x9c/0x184) [ 34.943888 01-05 13:30:50.180] Process system_server (pid: 928, stack limit = 0xe0e9e2f0) [ 34.952098 01-05 13:30:50.188] Stack: (0xe0e9fe38 to 0xe0ea0000) .... [ 35.127937 01-..
MMU 페이지 테이블 확인 우선 페이지 테이블은 아래와 같다. |_tablewalk | A6F9C000[0C06]=8061140E | A6F9C000[0C06]=8061140E | A6F9C000[0C06]=8061140E | A6F9C000[0C06]=8061140E 0x8061140E 이놈을 이진수로 바꾸면 10000000011000010001010000001110이다. 끝자리가 10이구만. 섹션 엔트리이므로 가상 주소는 1메가 단위라는 것을 알 수 있다. 앞에 12비트만 남기고 나머지를 0으로 비트 클리어를 하면, 10000000011000010001010000001110 11111111111100000000000000000000 10000000010000000000000000000000 (결과값) 0x80100000 0x8..
MMU - 메모리 설정 이번에는 페이지 테이블 비트 값으로 메모리 상태를 점검해보자. | A6F9C000[0D3F]=93F1140E 헥사값이 E로 끝나니 10으로 이진수가 끝남을 알 수 있다. 물론 섹션 엔트리겠지. 0x93F1140E를 이진수로 바꾸면 아래와 같다. 자릿수) 10987654321098765432109876543210 LSB 10010011111100010001010000001110 LSB AP[11:10]이 01이네. 아래 테이블에서 첫번째에 해당하는 내용임을 알 수 있다. AP[1:0] 권한 User 01 | Read/Write No access 10 | Read/Write Read only 11 | Read Write Read/Write 아래 페이지 테이블을 한번 보자. A6F9C000[058E]=A6E9..
커널패닉 - ext4 파일 시스템 커널 패닉 한번 분석 좀 해보자. 패닉 로그는 아래와 같다. 오라 ext4 파일 시스템에서 커널님이 돌아가셨구나. 돌아가실 때 프로세스 이름은 system_server이며 대략, ext4 파일 시스템에서 아이노드를 free하다가 죽었다는 것을 알 수 있다. [ 34.187856 01-05 13:30:49.424] Unable to handle kernel NULL pointer dereference at virtual address 00000000 [ 34.197812 01-05 13:30:49.434] pgd = e6f9c000 [ 34.202275 01-05 13:30:49.438] [00000000] *pgd=00000000 [ 34.207610 01-05 13:30:49.444] Internal ..