insmod에서 에러 납니다.
글쓴이: kimtakeun / 작성시간: 일, 2006/03/19 - 3:05오전
안녕하세요?
모듈 컴파일을 하는데 문제가 생겨 질문 드립니다.
다음과 같은 코드를 모듈 컴파일을 하는데, 컴파일 까지는 잘 됩니다. 그런데 insmod 를 하면 insmod: error inserting 'hello.ko': -1 Invalid module format 과 같은 에러가 뜹니다. /var/log/message 에 보면 Mar 19 02:55:27 tesla kernel: hello: disagrees about version of symbol struct_module 과 같은 메세지가 뜨구요.
저 에러로 검색을 해보니 커널 버젼과 소스 버젼이 틀려서 그렇다고 하던데, 둘 다 2.6.10 커널로 맞춰서 컴파일 했는데도 안되네요. CONFIG_MODULEVERSIONS 인가 no로 설정해주면 된다고 해서 해봤는데도 안되구요. (우분투 5.04 - kernel 2.6.10 사용하고 있습니다.)
답변 부탁드립니다 :)
- hello.c
#include <linux/module.h> #include <linux/kernel.h> int init_module(void) { printk(KERN_INFO "Hello World 1.\n"); return 0; } void cleanup_module(void) { printk(KERN_INFO "Goodbye 1.\n"); }
- build.sh
make -C /usr/src/kernel-source-2.6.10 SUBDIRS=$PWD modules
- makefile
obj-m := hello.o
clean:
rm -rf *.o *.ko *.mod.c
Forums:
아마도 커널 모듈에
아마도 커널 모듈에 정의되어 있어야 하는 몇개의 변수들이 정의되지 않아서 그런 것 같습니다. 2.6용 커널 모듈 만드는 방법에 관한 글을 찾아보시고 그런 값들을 정의해 주세요.
------------------
한 걸음 더 가까이
첨부하신 소스는 커널 2.4.x 의 소스같은데요
suki1978 style, free style
2.4.x대의 소스같습니다.
2.4.x 용 모듈 소스는 init_module, cleanup_module처럼 함수명이 정해져 있습니다.
하지만 2.6.x대의 모듈 소스는 init_module, cleanup_module에 해당하는 함수의 이름은 원하는데로 정하데, 매크로 함수를 이용해서 등록해주는 차이가 있을것입니다.
열정은 남자의 미래다! - suki1978 style, free style
댓글 달기