문서 편집 권한이 없습니다. 다음 이유를 확인해주세요: 요청한 명령은 다음 권한을 가진 사용자에게 제한됩니다: 사용자. 문서의 원본을 보거나 복사할 수 있습니다. [[분류: 디버깅]] == WARNING: bad unlock balance detected! == '''WARNING: bad unlock balance detected!'''는 Linux 커널에서 락(lock)을 사용하는 과정에서 락의 상태 관리가 올바르게 이루어지지 않았음을 나타내는 경고이다. 이는 코드의 특정 경로에서 락을 걸고 해제하는 균형(balance)이 맞지 않을 때 발생한다. === 발생 상황 === 이 경고는 다음과 같은 상황에서 발생할 수 있다: ==== 1. 락 해제 없이 코드 종료 ==== 락을 걸었지만, 코드 경로에서 락을 해제하지 않은 경우 발생한다. <syntaxhighlight lang=c> spin_lock(&my_lock); if (error_condition) { return -1; // 락을 풀지 않고 리턴 } spin_unlock(&my_lock); </syntaxhighlight> ==== 2. 중복된 락 해제 ==== 이미 해제된 락을 다시 해제하려 할 때 발생한다. <syntaxhighlight lang=c> spin_lock(&my_lock); spin_unlock(&my_lock); spin_unlock(&my_lock); // 두 번째 해제가 문제 발생 </syntaxhighlight> ==== 3. 락을 걸지 않은 상태에서 해제 시도 ==== 락을 얻지 않은 상태에서 해제를 시도할 때 발생한다. <syntaxhighlight lang=c> spin_unlock(&my_lock); // 락을 건 적이 없는데 해제 시도 </syntaxhighlight> ==== 4. 다른 컨텍스트에서 잘못된 락 관리 ==== 인터럽트 컨텍스트에서 락을 해제하거나, 재귀적으로 락을 사용하는 경우에 문제가 발생할 수 있다. 락을 얻거나 해제하는 동안 컨텍스트가 변경되었을 때 발생한다. 예를 들어, IRQ를 비활성화하는 락(`spin_lock_irqsave`)을 얻었지만, 일반 락 해제를 시도한 경우이다. <syntaxhighlight lang=c> unsigned long flags; spin_lock_irqsave(&my_lock, flags); spin_unlock(&my_lock); // 잘못된 해제 </syntaxhighlight> === 디버깅 방법 === 이 경고를 디버깅하려면 다음 단계를 수행한다: ==== 1. 경고 로그 확인 ==== 커널 로그(`dmesg` 또는 `/var/log/kern.log`)를 분석하여 문제가 발생한 락 이름, 코드 위치, 호출 스택(trace)을 확인한다. ==== 2. 락 상태 점검 ==== 커널 락 디버깅 옵션(`CONFIG_DEBUG_SPINLOCK`, `CONFIG_DEBUG_MUTEXES`)을 활성화하여 락 사용 문제를 확인한다. ==== 3. 락의 균형 유지 확인 ==== 모든 경로에서 락 획득과 해제가 올바르게 이루어지는지 코드 흐름을 점검한다. ==== 4. 컨텍스트 일치 여부 확인 ==== 락이 올바른 컨텍스트에서 관리되고 있는지 확인한다. 인터럽트 컨텍스트에서의 락 사용 규칙을 준수한다. === 요약 === '''WARNING: bad unlock balance detected!'''는 커널 락 관리의 균형이 맞지 않을 때 발생하는 경고이다. 이는 잠재적인 데드락이나 리소스 관리 문제로 이어질 수 있으므로, 로그와 코드를 분석하여 락 사용 방식을 올바르게 수정해야 한다. Bad unlock balance 문서로 돌아갑니다.