module프로그래밍 에러 그 두번째..^^
글쓴이: 익명 사용자 / 작성시간: 월, 2002/08/12 - 10:53오후
저번에 올렸던 모듈프로그램 에러는
gcc를 업그래이드 하면서 대충 잡힌것 같습니다
컴파일까지는 아무이상없이 됩니다..
그런데 또 이런 커널버젼에러(?)가 뜨는군요...
커널을 새로 컴파일 해야 할까요?
####################
hello_module.o kernel-module version mismatch
hello_module.o was compiled for kernel version 2.4.13-1hl
while this kernel is version 2.4.18.
###################
Forums:
Re: module프로그래밍 에러 그 두번째..^^
커널 모듈에서 컴파일 시에 사용한 커널 소스 버전과 현재 사용하는 커
널 버전이 틀리기 때문에 발생하는 에러입니다. 모듈 컴파일시에 사용한
버전은 2.4.13 인데 지금 깔려 있는 커널은 2.4.18 이군요. 이걸 일치시
켜줘야 합니다. 그냥 커널 모듈을 컴파일 할 때, 2.4.18 소스를 쓰시면
될듯 하네요.
그럼 고운 하루되세요.
Re^2: module프로그래밍 에러 그 두번째..^^
답변 고맙습니다..^^
그런데 모듈을 어떻게 컴파일하죠?
혹시 linux소스에서
----------------
make modules
make modules_install
-------------------
이라고 하는거면 방금 해봤습니다
원래는 커널 2.4.18이였는데 이번에 새로 컴파일 할겸해서리
2.4.19로 업그래이드 했거든요
그래도 에러가 비슷하게 뜹니다
-------------------------
hello_module.o kernel-module version mismatch
hello_module.o was compiled for kernel version 2.4.13-1hl
while this kernel is version 2.4.19.
-----------------------------
그런데 질문이 하나 더 늘었군요
boot밑에 보면 링크가 여러가지가 있습니다
-------------------
System.map -> System.map-2.4.19
kernel.h -> kernel.h-2.4.13
module-info -> module-info-2.4.13-1hl
vmlinuz -> vmlinuz-2.4.13-1hl
-------------------
이렇게 4개가 있는데요 이것을 어떻게 건들여야 할지..^^;
헤헤~ 모두 즐거운 하루 되시구요
Re^3: module프로그래밍 에러 그 두번째..^^
좋은 사이트를 가르켜 드리겠습니다. ^^
http//linuxkernel.net 에 보면
flyduck 님께서 쓰신 MODULE 프로그래밍에 관한 글이 있습니다.
이 사이트를 살펴보시면 지금 궁금하신건 모두 해결할 수 있으실듯
보이네요.
그리고 모듈 컴파일의 경우 단순히 새로 짠 모듈을 추가하기 위해서는
그렇게 module_install 대신에 단순히 gcc 로 모듈의 컴파일이
가능합니다. 그리고 insmod 로 그 모듈을 추가하시면 됩니다.
(컴파일시 옵션이 생각이 안나네요. 그 사이트에 가보시면 다 있답니다.)
그럼 고운 하루되시길...
원하던 답을 찾았습니다..^^*
전에 module이 컴파일이 안되는 에러는 잡았습니다
제가 사용하는 한컴에서 원래 gcc-2.96이 조금 불안정 하다고 해서 바꾼것이
2.95.4였는데요...
그것이 문제였나봅니다
gcc-3.01로 바꾼뒤로는 별 에러없이 컴파일이 되었습니다
하지만 모듈을 올릴려고 modprobe를 하면
##########################
hello_module.o kernel-module version mismatch
hello_module.o was compiled for kernel version 2.4.13-1hl
while this kernel is version 2.4.18.
###########################
이란 커널 버젼 에러가 뜨는 바람에 또 한참을 고민했습니다
kldp사이트에서 정보를 얻어서
www.linuxkernel.net 라는 사이트에 갔더니
이것을 해결할수 있을만한 정보가 있었습니다
----------------------------------
리눅스 커널의 헤더 파일은 /usr/include 밑에 linux와 asm이라는 디렉토리에
있는데 보통 이 파일이
/usr/src/linux/include/linux, /usr/src/linux/include/asm을 링크를 걸어놓은
상테인데 RED HAT 7.1 에서는 --;; 디렉토리로 되어 있더군요...혹시나 해서..
이 디렉토리를 위에 제가 컴파일한 디렉토리로 심볼링 링크를 걸어주니 ...
제대로 module load가 되네요...
--linuxkernel사이트에서 발최--
-----------------------------------
저도 비슷한 에러가 뜨기에 링크를 바꿔줬더니
에러가 사라졌습니다
대신 컴파일 할때
#################
gcc -Wall -D__KERNEL__ -DMODULE -D_LINUX -O2 -c hello_module.c
hello_module.c In function `init_module'
hello_module.c16 warning implicit declaration of function
`printk_Rsmp_1b7d4074'
##################
이란 알수없는 에러가 뜨는군요..
그리고 insmod실행시
##################
Warning loading hello_module.o will taint the kernel no license
###################
란 경고가 하나 뜹니다...
되는건 확실하지만 무언가 찜찜해서..^^;;
싸이트 갈켜주신 좋은님에게 감사감사~..^^
댓글 달기