LINUX

포스트: 477|조회수: 0|TERM
Items

Posts

477 posts

GOTY 단평

1월 Milkmaid of the Milky Way PC, Mac, iOS 05-Jan Hopiko PC, Mac, Linux 06-Jan Ladykiller in a Bind PC, Mac, Linux 09-Jan Hatsune Miku: Project DIVA Future Tone PS4 10-Jan Criminal Girls: Invite Only PC 11-Jan Pit People (Early Access) Xbox One, PC 13-Jan Rise & Shine Xbox One, PC 13-Jan Atelier Shallie Plus: Alchemists of the Dusk Sea PSVita 17-Jan Fate/Extella: The Umbral Star PS4, PS

spin_lock() vs spin_lock_irq() vs spin_lock_irqsave() - 분석

Guillermo Austin Kim|2017년 12월 26일

자 그 동안 궁금해왔던 아래 API들의 차이점에 대해서 알아보는 시간을 갖도록 하겠습니다.spin_lock(), spin_lock_irq(), spin_lock_irqsave() 리눅스 커널 책에서 마르고 닳도록 설명을 많이 하고 있는데요. 직접 소스를 열어서 분석하는게 가장 좋은 리눅스 커널을 마스터하는 길인 것 같아요. 소스 코드가 오픈되어 있잖아요. 1> spin_lock()아래 순서로 실제 구현부는 __raw_spin_lock() 함수 라는 걸 알 수 있어요. spin_lock -> raw_spin_lock -> __raw_spin_lockstatic inline void spin_lock(spinlock_t *lock){ raw_spin_lock(&lock->rlo

ARM64(Aarch64) - 함수 호출시 Stack Push(스택 푸쉬) 규약

Guillermo Austin Kim|2017년 12월 25일

아래와 같은 콜 스택에서 유저 공간에서 돌던 레지스터 Stack Push와 Exception 발생 시 Stack Push에 대해서 살펴봤어요. 이제는 평상시 함수 호출 시 어떻게 Stack Push를 하는 지 점검하려고 해요. 자 계속 그 동안 다뤄왔던 아래 "rild"란 프로세스의 콜스택에서 msm_ipc_router_sendmsg()-> msm_ipc_router_send_to() 으로 함수가 호출된 후 스택 푸쉬가 어떻게 수행되는 지 점검해볼께요.-000|do_mem_abort()-001|el1_da(asm) -->|exception-002|ch_pop_remote_rx_intent()-003|glink_tx_common()-004|glink_txv()-005|ipc_router_glink

Runqueue(런큐) Timestamp(실행 시간) 확인

Guillermo Austin Kim|2017년 12월 24일

보통 커널 크래시나 와치독 리셋으로 시스템이 다운된 경우 세밀하게 디버깅해야 할 때가 있어요.그런데 가끔 각 프로세스가 마지막에 어떤 순서로 실행이 됐는지 확인하고 싶을 경우가 가끔 있거든요.이 순서가 가끔 정말 중요한 순간이 가끔 있어요. 아래는 런큐에서 돌고 있는 프로세스 목록이거든요. 그럼 각각 프로세스가 어떤 순서로 실행이 되었는지 알 수 있을까요?crash64> runq -m CPU 0: [0 07:36:22.901] PID: 585 TASK: ffffffc071eb8b80 COMMAND: "android.hardwar" CPU 1: [0 07:36:22.901] PID: 726 TASK: ffffffc0f6e3f300 COMMAND: "DispSync" CPU 2: [0