리눅스 커널 질문.. 도와주세요
1. 리눅스 커널에서
cat /proc/kallsyms
를 통해서 심볼테이블을 확인해보면
c0851000 B swapper_pg_dir
이런식으로 심볼이 정의되있는걸 볼수있는데요
커널모듈 소스코드상에서
unsigned int* p = swapper_pg_dir;
이런 코드로 주소를 가져오려고하면
undefined symbol 이라고 에러가 나네요;
kallsyms 에서 확인이 가능한데 왜 사용을 못하는걸까요?
2. 커널페이지테이블의 시작주소가(swapper_pg_dir) 라고 해서
일단 가상주소가 심볼테이블에 있으니, 그곳을 따라가서 메모리 덤프를 떳습니다.
그러니까 페이지 디렉토리의 내용이 나오는것 같았습니다.
하지만 페이지 디렉토리에 있는 내용은
20비트의 페이지 테이블의 PFN(page frame number) 과, 12비트의 dirty 등 각종 비트들이었습니다.
그런데 이 20비트의 PFN 을 가지고 해당 페이지테이블에 대한 덤프도
떠보고싶은데, 어떻게해야 가능할까요??
물리적 frame number 를 가지고, 프로그램 소스코드상에서 접근할 방법이 없는데...?
커널 디바이스드라이버 관련 책이나 글들을 보면
vir_to_phy 뭐 이런 함수들을 소개하지만 이건 0xc0000000 ~ high_mem 까지의
linear mapping 영역에 대해서 단순한 +- 계산만 해주는 매크로라서
페이지테이블을 참조하는거랑 상관이 없는것 같더군요
페이지 테이블을 따라가서 최종적인 물리메모리 주소를 알아내고싶습니다.
도와주세요~!!
3.0 이후로는 잘 모릅니다만 2.6에서는
3.0 이후로는 잘 모릅니다만
2.6에서는 0xc0000000 이후 영역으로 선형적으로 매핑된다고 알고있습니다.
즉 물리메모리 0x1234번지는 선형주소로 0xc0001234 이라고 알고있습니다.
이걸 vir_to_phy등의 매크로함수로 제공해주는 것이지요.
따라서 페이지 번호를 알면 페이지크기*페이지번호로 + 0xc0000000 으로 선형주소를 알수있지않을까요?
그리고 커널에서 사용하는 모든 전역 변수를 모듈에서 참조할 수 있는게 아닌걸로 압니다.
커널에서 선언한 변수중에 모듈에서도 쓸 수 있도록 선언하는 매크로가 있는걸로 기억이 납니다.
그 매크로로 선언된 변수만이 드라이버에서도 접근할 수 있는 것이지요.
페이지테이블 주소같은걸 모듈에서 접근할 수 있다면 문제가 생길것 같습니다.
대신 커널 소스에서 원하시는 변수를 해당 매크로로 선언하도록 수정하면 될것 같습니다.
잠깐 v2.6에서 printk 소스를
잠깐 v2.6에서 printk 소스를 봤는데
EXPORT_SYMBOL라는 매크로가 특정 섹션에 심볼들을 모아서 저장하고
다른 모듈이 참조할 수 있도록해주는것 같습니다.
댓글 달기