加载rt3070sta.ko出现insmod: can't insert 'rt3070sta.ko': invalid module format问题
来源:互联网 发布:两个域名指向一个主机 编辑:程序博客网 时间:2024/04/29 07:48
rt3070sta: unknown relocation: 40
insmod: can't insert 'rt3070sta.ko': invalid module format
我使用的是linux2.6.28-10版本的内核
编译器是 arm-none-linux-gnueabi-gcc-4.3.3
无论怎么改都是这样的问题,开始以为是内核配置不对,但是启动后会出现
usb 1-1: New USB device found, idVendor=148f, idProduct=3070
usb 1-1: New USB device strings: Mfr=1, Product=2, SerialNumber=3
usb 1-1: Product: 802.11 n WLAN
usb 1-1: Manufacturer: Ralink
usb 1-1: SerialNumber: 1.0
已经认出USB设备了,为什么就是不行呢,后来又改了几个版本的root文件系统,还是不行
最后在网上查到一个帖子,如下
由于EABI-4.3.3的编译器比2.6.25.8的新,再编译连接程序时两者的有些参数不兼容,所以使用3.4.5的编译器编译2.6.25.8的内核和wifi驱动时不会有任何问题;而EABI-4.3.3的编译器编译2.6.25.8的wifi驱动时(主要是mac80211)要调用到include/asm-arm/elf.h文件中的参数,而2.6.25.8的内核中没有EABI要调用的参数。所以会出现“unknown relocation: 40”这个错误。
解决办法:
1、修改include/asm-arm/elf.h的32行,添加#define R_ARM_V4BX
2、修改arch/arm/kernel/module.c文件在134行添加
case R_ARM_V4BX:
难怪呢,按指示修改elf.h,这个文件在2.6.28的内核里面是arch/arm/include/asm下的elf.h
添加#define R_ARM_V4BX
在arch/arm/kernel/module.c文件在134行添加
case R_ARM_V4BX:
再编译加载,大功告成,这个问题折腾了我好几天
[root@smsf /root]# insmod rt3070sta.ko
rtusb init rt2870 --->
=== pAd = c48ff000, size = 508632 ===
<-- RTMPAllocTxRxRingMemory, Status=0
<-- RTMPAllocAdapterBlock, Status=0
usbcore: registered new interface driver rt2870
[root@smsf /root]# ifconfig -a
eth0 Link encap:Ethernet HWaddr 10:12:34:56:78:18
inet addr:192.168.8.3 Bcast:192.168.8.255 Mask:255.255.255.0
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:39 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:4538 (4.4 KiB) TX bytes:0 (0.0 B)
Interrupt:16 Base address:0xc300
lo Link encap:Local Loopback
inet addr:127.0.0.1 Mask:255.0.0.0
UP LOOPBACK RUNNING MTU:16436 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:0
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
ra0 Link encap:Ethernet HWaddr 00:00:00:00:00:00
BROADCAST MULTICAST MTU:1500 Metric:1
RX packets:0 errors:0 dropped:0 overruns:0 frame:0
TX packets:0 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:0 (0.0 B) TX bytes:0 (0.0 B)
[root@smsf /root]# iwconfig
-/bin/sh: iwconfig: not found
[root@smsf /root]# ifconfig ra0 192.168.8.25
(Efuse for 3062/3562/3572) Size=0x2d [2d0-2fc]
RTMP_TimerListAdd: add timer obj c49468c8!
RTMP_TimerListAdd: add timer obj c49468f4!
RTMP_TimerListAdd: add timer obj c4946920!
RTMP_TimerListAdd: add timer obj c494689c!
RTMP_TimerListAdd: add timer obj c4946818!
RTMP_TimerListAdd: add timer obj c4946844!
RTMP_TimerListAdd: add timer obj c491145c!
RTMP_TimerListAdd: add timer obj c4900c70!
RTMP_TimerListAdd: add timer obj c4900ca4!
RTMP_TimerListAdd: add timer obj c49114f4!
RTMP_TimerListAdd: add timer obj c4911404!
RTMP_TimerListAdd: add timer obj c49114c4!
-->RTUSBVenderReset
<--RTUSBVenderReset
Key1Str is Invalid key length(0) or Type(0)
Key2Str is Invalid key length(0) or Type(0)
Key3Str is Invalid key length(0) or Type(0)
Key4Str is Invalid key length(0) or Type(0)
1. Phy Mode = 5
2. Phy Mode = 5
NVM is Efuse and its size =2d[2d0-2fc]
phy mode> Error! The chip does not support 5G band 5!
RTMPSetPhyMode: channel is out of range, use first channel=1
(Efuse for 3062/3562/3572) Size=0x2d [2d0-2fc]
3. Phy Mode = 9
AntCfgInit: primary/secondary ant 0/1
MCS Set = ff 00 00 00 01
<==== rt28xx_init, Status=0
0x1300 = 00064300
- 加载rt3070sta.ko出现insmod: can't insert 'rt3070sta.ko': invalid module format问题
- insmod: can't insert 'led.ko': invalid module format
- 驱动模块加载错误:insmod: can't insert 'xx.ko': invalid module format
- insmod: can't insert 'led.ko': invalid module format详细解释
- 安装Dahdi模块出现insmod: can't insert 'dahdi.ko': unknown symbol in module or invalid parameter
- insmod: cannot insert '18b20.ko': invalid module format
- insmod: can't insert 'hci_uart.ko': invalid parameter
- insmod: can't insert 'xxx.ko': Success
- 往开发板写led驱动时出现错误:insmod: can't insert 's3c_led.ko': unknown symbol in module or invalid parameter
- insmod: ERROR: could not insert module module.ko: Invalid parameters
- 解决insmod: error inserting 'helloworld.ko': -1 Invalid module format
- 解决insmod: error inserting 'helloworld.ko': -1 Invalid module format
- insmod: error inserting 'hello.ko': -1 Invalid module format
- insmod: error inserting 'hello.ko': -1 Invalid module format
- 解决insmod: error inserting 'helloworld.ko': -1 Invalid module format
- 解决insmod: error inserting 'hello.ko': -1 Invalid module format
- insmod: error inserting 'simp-blkdev.ko': -1 Invalid module format
- insmod: error inserting 'hello.ko': -1 Invalid module format
- DEVICE_ATTR的使用
- vim 编辑 运行 shell 文件
- 反射实现JDBC封装
- 格雷戈里T.豪根的《有效的工作分解结构》免费阅读
- Android实战技巧:多线程AsyncTask(版本不同,有点差异)
- 加载rt3070sta.ko出现insmod: can't insert 'rt3070sta.ko': invalid module format问题
- POJ 1815 Friendship 最小割
- Android中OnkeyDown事件和OnBackPressed方法区别、兼容、使用
- Nginx学习(12)—核心结构(1)
- 学习计划
- 深入理解全局编录服务器GC
- redis 备份
- 存储过程
- CentOS 6下安装nodejs 0.9.0