디바이스 드라이버 예제 실행중에...printk 문제점..
글쓴이: gnoygnas / 작성시간: 화, 2005/03/29 - 1:29오후
아주 기초적인 질문이 될 수 있지만 이쪽 분야는 생소하기에 부딪히는 일이 많네요..
아래는 커널 2.6에서 실행한 내용입니다..(얼핏 듯기로 2.4버전대하고 모듈 프로그래밍하는 방식이 틀리다고 하는데, 어떤 점에서 다른지 궁금합니다.)
1 #define MODULE 2 #include <linux/module.h> 3 #include <linux/init.h> 4 #include <linux/kernel.h> 5 6 int moduleInit(void) 7 { 8 printk("<1>Hello, world\n"); 9 return 0; 10 } 11 12 void moduleCleanup(void) 13 { 14 printk("<1>Goodbye\n"); 15 } 16 17 module_init(moduleInit); 18 module_exit(moduleCleanup);
[root@venus embedded]# gcc -c hello.cc hello.cc: In function `int moduleInit()': hello.cc:8: error: `printk' undeclared (first use this function) hello.cc:8: error: (Each undeclared identifier is reported only once for each function it appears in.) hello.cc: In function `void moduleCleanup()': hello.cc:14: error: `printk' undeclared (first use this function) [root@venus embedded]#
분명히 <linux/kernel.h>를 포함해 주었는데 printk가 선언이 안되었다고 나오네요...뭐가 잘못되었는지...
해결책 부탁드립니다...^^
Forums:
확장자를 c 로 고쳐보세요..
확장자가 cc 니까 gcc 가 C++ 파일로 가정하고 처리하는 과정에서
함수 이름을 인식하지 못하는 것으로 보입니다.
파일의 확장자를 cc 가 아니라 c 로 고쳐서 해보시기 바랍니다.
그리고 2.6 에서 모듈 프로그래밍을 하려면
Makefile 파일을 작성하시는 것이 좋습니다.
자세한 내용은 flyduck 님의 글을 검색해 보세요.. ^^
-D__KERNEL__ 을 컴파일 옵션에 넣어야 합니다.그리고 커
-D__KERNEL__ 을 컴파일 옵션에 넣어야 합니다.
그리고 커널 2.6에서는 커널 모듈에 여러가지 정보(컴파일러 버젼, 커널의 중요 설정 등등)이 포함되기 때문에 단순히 .o파일로 만들어서는 모듈이 로딩되지 않습니다.
http://pain.mizi.com/wikix/index.php?display=MyDocKernel26DeviceDriver#wikiXheading_27 에 있는대로 Makefile을 만들고 실행하여야 올바른 커널 모듈이 만들어집니다.
----
데스크탑 프로그래머를 꿈꾸는 임베디드 삽질러
답변 감사합니다..해결 했네요...
위에 답변 주신 덕분에 잘 해결했습니다...^^
일반 프로그래밍하고는 약간 틀려서 애먹네요...
아무쪼록 감사합니다..
아래는 이래 저래 참조해서 만든 Makefile인데, 혹시 저 같은 분들이 있을까 첨부합니다..
One must, In fact, Love your pursuit
My home is below...Well, just go own your gait!
댓글 달기