한국어
Embedded
 

printk()

makersweb 2014.02.27 12:29 조회 수 : 5637

 

printf()와 유사하지만 커널의 메시지를 출력하고 관리할 수 있는 특성이 있다.

  • 메시지 기록 관리를 위한 로그 레벨의 지정
  • 원형 큐 구조의 관리
  • 출력 디바이스의 다중 지정
  • 콘솔에서 확인하거나 dmesg명령을 이용해서 로그 파일을 확인

로그 레벨 지정

로그 레벨은 printk()함수에 전달되는 문자열의 선두 문자에 "<1>"과 같이 숫자로 등급을 표현한다. linux/kernel.h 에 정의된 선언문을 이용하는 것이 바람직하다.

상수 선언문

의미

#define KERN_EMERG

<0>시스템이 동작하지 않는다.

#define KERN_ALERT

<1>항상 출력된다.

#define KERN_CRIT

<2>치명적인 정보

#define KERN_ERR

<3>오류 정보

#define KERN_WARNING

<4>경고 정보

#define KERN_NOTICE

<5>정상적인 정보

#define KERN_INFO

<6>시스템 정보

#define KERN_DEBUG

<7>디버깅 정보

 

레벨에 대한 표시를 하지 않으면 KERN_WARNING과 같은 레벨이다. 다음의 처리 결과는 모두 같다.

printk(KERN_WARNING"system okn");

printk("<4>""system okn");

printk("<4> system okn");

printk("system okn");

 

원형 큐 구조 관리

커널 메시지는 커널 내부에 있는 원형 큐 형식의 로그 버퍼에 저장된다.

이 로그 버퍼의 크기는 CONFIG_LOG_BUF_SHIFT 값으로 지정된다. 

 (정의된 헤더 include/config/log/buf/shift.h)

로그 버퍼는 일반적으로 콘솔에 출력된다.

 

커널 메시지 관리 데몬

klogd : 커널에서 발생하는 메시지를 기록하고 관리한다.

syslogd : 커널에서 발생하는 메시지와 응용 프로그램에서 요청한 시스템 정보를 기록하고 관리한다.

 

printk()사용 시 주의점

printk()를 과도하게 사용하지 않는다. -> 실행시간이 길다.

개행 문자가 있어야 출력을 시작한다. -> 'n' 을 포함 하도록 한다.