spi.h 수정 후 insmod 사용 시 "disagrees about version of symbol"
안녕하세요.
RPi 4B 에서 SPI device driver 를 테스트하고있는데요,
.dts 파일에 설정한 DT 변수값이 spi_device 까지 잘 전달되는지 보려고 아래와 같이 /include/linux/spi.h 의 spi_device 에 테스트용 변수를 하나 추가했습니다.
테스트를 위해 /drivers/spi/spi.c 에도 debug_sheld 에 접근하는 코드를 넣었구요.
***********************************************
struct spi_device {
struct device dev;
struct spi_controller *controller;
struct spi_controller *master;
u32 max_speed_hz;
u32 debug_sheld; /* 테스트용 변수 */
...
}
***********************************************
이후 kernel 을 compile 한 후 spidev.ko 모듈을 올리면 아래와 같은 메세지가 나오면서 모듈이 올라가지 않네요
($ sudo make -j4 zImage modules dtbs).
***********************************************
pi@raspberrypi:~/git_repository/Kernel/linux-5.4.59/drivers/spi $ sudo insmod spidev.ko
insmod: ERROR: could not insert module spidev.ko: Invalid parameters
***********************************************
dmesg 를 확인하니 아래와 같이 나오고요
***********************************************
[ 81.717199] spidev: disagrees about version of symbol spi_sync
[ 81.717211] spidev: Unknown symbol spi_sync (err -22)
[ 81.717248] spidev: disagrees about version of symbol spi_setup
[ 81.717257] spidev: Unknown symbol spi_setup (err -22)
[ 81.717278] spidev: disagrees about version of symbol __spi_register_driver
[ 81.717287] spidev: Unknown symbol __spi_register_driver (err -22)
[ 81.717311] spidev: disagrees about version of symbol spi_slave_abort
[ 81.717320] spidev: Unknown symbol spi_slave_abort (err -22)
[ 310.352225] spidev: disagrees about version of symbol spi_sync
[ 310.352237] spidev: Unknown symbol spi_sync (err -22)
[ 310.352274] spidev: disagrees about version of symbol spi_setup
[ 310.352283] spidev: Unknown symbol spi_setup (err -22)
[ 310.352305] spidev: disagrees about version of symbol __spi_register_driver
[ 310.352314] spidev: Unknown symbol __spi_register_driver (err -22)
[ 310.352338] spidev: disagrees about version of symbol spi_slave_abort
[ 310.352347] spidev: Unknown symbol spi_slave_abort (err -22)
[ 649.449228] spidev: disagrees about version of symbol spi_sync
[ 649.449244] spidev: Unknown symbol spi_sync (err -22)
[ 649.449291] spidev: disagrees about version of symbol spi_setup
[ 649.449303] spidev: Unknown symbol spi_setup (err -22)
[ 649.449332] spidev: disagrees about version of symbol __spi_register_driver
[ 649.449343] spidev: Unknown symbol __spi_register_driver (err -22)
[ 649.449375] spidev: disagrees about version of symbol spi_slave_abort
[ 649.449386] spidev: Unknown symbol spi_slave_abort (err -22)
***********************************************
여기서 spi_device 에 추가했던 내용을 되돌리고,
대신 spi.h 파일안에 한번 struct spi_sheld_debug 와 같은 구조체를 추가로 정의해봤을 때는 문제가 없었습니다.
즉, spi.h 파일내용이 달라진 자체만으로 발생하는 것은 아니고 무언가.. 기존에 있던 spi_device 가 바뀌면서 발생한 문제 같네요.
웹검색을 해보니 모듈버전 관련된 사항 같은데..
혹시 도움 주실분 계실까요?
감사합니다.
댓글 달기