Run if you want it
300x250

Linux System/Linux Kernel 7

Kernel Panic Calltrace 분석

Kernel Panic이 발생한 경우 하기와 같이 Calltrace log를 출력하기 때문에 해당 정보를 기반으로 디버깅 하는 방법 정리 example) xen porting 과정 중 kernel 부팅 시 발생한 error [ 0.500423] Internal error: synchronous external abort: 96000010 [#1] PREEMPT SMP [ 0.501475] Modules linked in: [ 0.502306] CPU: 1 PID: 1 Comm: swapper/0 Not tainted 4.20.11 #6 [ 0.503174] Hardware name: linux,dummy-virt (DT) [ 0.507173] pstate: 40000005 (nZcv daif -PAN -..

[Kernel] Timer

jiffies 커널에서 시간은 타이머 인터럽트를 통해 관리되는데, 타이머 인터럽트는 1초당 n번 발생하는 빈도가 HZ로 정의되어 있음. 이 HZ값은 아키텍처마다 다르게 정의되어 있다. 만약 100HZ라고 하면 1초당 100번의 타이머 인터럽트가 발생함 해당 커널 시스템의 HZ 값은 .config에 CONFIG_HZ로 정의되어 있다. 커널에는 시스템이 시작한 후, 해당 타이머 인터럽트 발생횟수를 저장하는 jiffies라고하는 전역변수가 정의되어 있는데 extern unsigned long volatile __cacheline_aligned_in_smp __jiffy_arch_data jiffies; 만약 HZ가 100인 시스템에서 시스템이 시작된 뒤 1초 후 jiffies는 값은 100이다. 해당 jiff..

runtime에 target board kernel의 config 확인

커널을 빌드하는 host 환경이 아닌 실행중인 target board에서 해당 kernel image에 적용된 config를 확인할 수 있는 방법 /proc 디렉토리 아래 config.gz로 해당 커널 image의 config가 압축되어 config.gz파일로 존재 이를 압축 해제하게 되면 해당 image의 kernel config를 확인할 수 있음 하기 명령은 압축해제한 config를 running.config에 저장 cat /proc/config.gz | gunzip > /tmp/running.config 압축 해제한 config 확인 vi /tmp/running.config # # Automatically generated file; DO NOT EDIT. # Linux/arm64 4.14.202 ..

User Space와 Kernel Space

User Space와 Kernel Space 응용 프로그램은 유저 영역에서, 커널 모듈은 커널 영역에서 실행 됨. 이와 같이 메모리 영역을 나눔으로서 응용 프로그램이 OS가 load되어 있는 커널 영역에 침범하여 시스템에 critical한 에러 등을 발생시키는 일을 방지. 커널 영역에 접근하기 위해서는 커널 모드(or 관리자 모드)로 전환되어야 함 System Call(시스템 콜) 위와 같은 이유로 인해 응용 프로그램에서 H/W나 커널의 리소스에 접근하여 사용할 수 있도록 System Call 방식을 이용 응용프로그램이 직접 커널의 기능을 호출할 수 없으므로 커널은 유저공간에 추상화된 인터페이스인 System Call을 제공하며 이를 통해 유저 영역에서 커널 기능을 호출. 시스템 콜이 호출 되면 유저 모..

Device Driver - Atomic

Atomic 연산 Atomic 연산이란 연산 수행 중 다른 thread로 context 전환이 되지 않는 연산을 의미하며 task의 context switching이 일어나거나 interrupt routine에서 해당 메모리에 대해 동시 처리되지 않도록 보장하는 연산을 일컫는다. 성능이 굉장히 중요한 부분에 있어서 Lock을 사용하기에는 성능 저하가 우려되는 경우 사용 Function Description ATOMIC_INIT(int i) At declaration, initialize an atomic_t to i int atomic_read(atomic_t *v) Atomically read the integer value of v void atomic_set(atomic_t *v, int i) At..

Kernel Build

Kernel Configuration Kernel Config 커널을 빌드하기 전에 각 시스템에 맞게 설정을 해주어야 하는데 "CONFIG_"라는 prefix로 시작되는 설정 옵션을 조정함으로서 가능하다. 예를 들어 FrameBuffer에 대한 feature를 활성화해주기 위해서는 CONFIG_FB를 enable 시키면 된다. 이 설정 옵션은 두 가지 형태의 값을 갖는데 Boolean과 Tri-state의 형태로 값을 갖는다. Boolean 타입의 경우 커널 빌드 시 해당 feature를 활성화할 것인지(yes), 비활성화(no)할 것인지를 설정하게 되고, Tri-State의 경우 Boolean 타입에서 module이라는 값이 추가된 타입인데 module로 설정하여 빌드 시, 해당 feature 모듈을 ..

Kernel Source Tree

커널 소스 트리 커널 소스 트리는 아래와 같이 여러 개의 디렉토리로 구성되어 있음 Directory Description Directory Desciption arch 아키텍쳐 종속코드 mm 메모리 관리 하위시스템과 VM crypto 암호와 API net 네트워크 drivers 디바이스 드라이버 scripts 커널 빌드시 사용되는 스크립트 fs VFS와 그밖의 fs security 보안 모듈 include 커널파일 헤더들 sound 사운드 하위시스템 init 커널부트와 초기화관련 usr 초기 UserSpace 코드(initramfs) ipc 프로세스 간 통신코드 kernel 스케쥴러 등 핵심 하위시스템 lib 유틸리티 루틴

728x90