Yocto开发笔记之《驱动调试-华为3G模块》(QQ交流群:519230208)
QQ群:519230208,为避免广告骚扰,申请时请注明 “开发者” 字样
========================================================
参考:
http://blog.csdn.net/yel617/article/details/5602934
http://wenku.baidu.com/link?url=v96wCcrz8oYObkMTiPa55OyWxg35MhHF4L7voiDhKhtNPCB3uJhvNshz9UVUgpo4BTWmJE_4AhcAoW5oVOmtxr_NHYxb8ev0VKCpGwCSq1m
http://blog.csdn.net/suntao222/article/details/8930744
http://wandering.blog.51cto.com/467932/354562
http://blog.chinaunix.net/uid-9525959-id-3998519.html
一 上网模块需要内核编译配置 《Guide to Kernel Driver Integration ......》
修改源文件,修改内核配置项等,详细参考3G模块手册。
二 交叉编译一些工具(参考 《Yocto Project Application Developer's Guide》):
将以下内容添加到根目录的Makefile文件中:
CC=arm-poky-linux-gnueabi-gcc -m32 -march=i586 --sysroot=/opt/poky/1.8/sysroots/x86_64-pokysdk-linux
LD=arm-poky-linux-gnueabi-ld --sysroot=/opt/poky/1.8/sysroots/x86_64-pokysdk-linux
CFLAGS=-O2 -pipe -g -feliminate-unused-debug-types
CXXFLAGS=-O2 -pipe -g -feliminate-unused-debug-types change to : CC=arm-poky-linux-gnueabi-gcc --sysroot=/home/summer/test-yocto/qemuarm
LD=arm-poky-linux-gnueabi-ld --sysroot=/home/summer/test-yocto/qemuarm
CFLAGS=-O2 -pipe -g -feliminate-unused-debug-types
CXXFLAGS=-O2 -pipe -g -feliminate-unused-debug-types # ./configure # make
PPP
. 下载代码:https://ppp.samba.org/
. 编译代码: http://blog.csdn.net/lanyou1900/article/details/40185259
. 编译成功后将编译生成的chat,pppd,pppdump等命令拷贝到板子文件系统的/usr/sbin目录下边去
USB(我的环境里以下功能都包含了,以下仅用来参考)
libusb-1.0. (用于编译usb-modeswitch-2.0.)
http://sourceforge.net/projects/libusb/postdownload?source=dlp usb-modeswitch-2.0. (用于切换网卡的模式)
http://www.draisberghof.de/usb_modeswitch/#download usb-modeswitch-data- (用于切换时指定切换的型号)
http://www.draisberghof.de/usb_modeswitch/#download
三 编写拨号脚本
在板子文件系统/etc/ppp/peers目录下边创建三个文件如下:
1. wcdma
debug
nodetach
/dev/ttyUSB0 usepeerdns
noauth
noipdefault
novj
novjccomp
noccp
defaultroute
ipcp-accept-local
ipcp-accept-remote
connect '/usr/sbin/chat -s -v -f /etc/ppp/peers/chat-wcdma-connect'
2. chat-wcdma-connect
TIMEOUT
ABORT 'NO CARRIER'
ABORT 'ERROR'
ABORT 'NODIALTONE'
ABORT 'BUSY'
ABORT 'NO ANSWER'
'' \rAT
OK \rATZ
OK \rAT+CGDCONT=,"IP","3GNET",,,
OK-AT-OK ATDT*#
CONNECT \d\c
3. chat-wcdma-disconnect
ABORT"ERROR"
ABORT "NODIALTONE"
SAY"\nSending break to the modem\n"
'' "\K"
''"+++ATH"
SAY"\nGoodbay\n"
四 添加DNS信息
# vi /etc/resolv.conf // 加入以下内容, 如果已经存在,替换成以下内容
nameserver 202.99.160.68
nameserver 202.99.166.4 或者,替换成
nameserver 1.2.4.8
nameserver 210.2.4.8 // TOBEDO : 重启开发板,dns信息被冲掉
五 检测ppp0网络是否能够使用
# Ping –I ppp0 www.baidu.com // 能够ping通就表示3G卡移植驱动成功
出现错误,域名不能ping通,ip可以
root@imx6ulevk:~# ping www.baidu.com
ping: bad address 'www.baidu.com'
六 测试模块状态
# lsusb // 查看usb连接状态
Bus Device : ID 12d1:1c25 Huawei Technologies Co., Ltd.
Bus Device : ID 1d6b: Linux Foundation 2.0 root hub # netstat -nr
# dmesg cdc_ether -:2.0 eth2: register 'cdc_ether' at usb-ci_hdrc.-, CDC Ethernet Device, :1e::1f::
usbcore: registered new interface driver option
usbcore: registered new interface driver cdc_ether
usbserial: USB Serial support registered for GSM modem (-port)
option -:2.2: GSM modem (-port) converter detected
usb -: GSM modem (-port) converter now attached to ttyUSB0
option -:2.3: GSM modem (-port) converter detected
usb -: GSM modem (-port) converter now attached to ttyUSB1
option -:2.4: GSM modem (-port) converter detected
usb -: GSM modem (-port) converter now attached to ttyUSB2
usb -: USB disconnect, device number
cdc_ether -:2.0 eth2: unregister 'cdc_ether' usb-ci_hdrc.-, CDC Ethernet Device
option1 ttyUSB0: GSM modem (-port) converter now disconnected from ttyUSB0
option -:2.2: device disconnected
option1 ttyUSB1: GSM modem (-port) converter now disconnected from ttyUSB1
option -:2.3: device disconnected
option1 ttyUSB2: GSM modem (-port) converter now disconnected from ttyUSB2
option -:2.4: device disconnected
usb -: new full-speed USB device number using ci_hdrc
usb -: new high-speed USB device number using ci_hdrc
cdc_ether -:2.0 eth2: register 'cdc_ether' at usb-ci_hdrc.-, CDC Ethernet Device, :1e::1f::
option -:2.2: GSM modem (-port) converter detected
usb -: GSM modem (-port) converter now attached to ttyUSB0
option -:2.3: GSM modem (-port) converter detected
usb -: GSM modem (-port) converter now attached to ttyUSB1
option -:2.4: GSM modem (-port) converter detected
usb -: GSM modem (-port) converter now attached to ttyUSB2
# dmesg | grep -in ppp // 查看ppp连接状态
#cat /dev/ttyUSB0 &
# echo AT+CGMI > /dev/ttyUSB0 // 查询厂商相关信息
# echo AT+CSQ > /dev/ttyUSB0 // 查询信号,顺带还可以让你知道SIM卡相关的是否正常
# #netstat -nal // 查看网络连接状态
# ifconfig -a
Attention:
USB线的选择直接影响到能否正常识别模块
附录:
一 插上USB 3G模块显示的log
root@imx6ulevk:/mnt# usb -: new high-speed USB device number using ci_hdrc
usb -: new high-speed USB device number using ci_hdrc
cdc_ether -:2.0 eth2: register 'cdc_ether' at usb-ci_hdrc.-, CDC Ethernet Device, :1e::1f::
usbcore: registered new interface driver option
usbserial: USB Serial support registered for GSM modem (-port)
option -:2.2: GSM modem (-port) converter detected
usb -: GSM modem (-port) converter now attached to ttyUSB0
option -:2.3: GSM modem (-port) converter detected
usb -: GSM modem (-port) converter now attached to ttyUSB1
option -:2.4: GSM modem (-port) converter detected
usb -: GSM modem (-port) converter now attached to ttyUSB2
二 lsusb显示的log
root@imx6ulevk:/mnt# lsusb
Bus Device : ID 12d1:1c25 Huawei Technologies Co., Ltd.
Bus Device : ID 1d6b: Linux Foundation 2.0 root hub
三 ls /dev/ppp显示的log
root@imx6ulevk:/mnt# ls /dev/ppp
/dev/pp
四 手动拨号的错误log
root@imx6ulevk:~# timeout set to seconds
abort on (NO CARRIER)
abort on (ERROR)
abort on (NODIALTONE)
abort on (BUSY)
abort on (NO ANSWER)
send (^MAT^M)
expect (OK)
^M
OK
-- got it send (^MATZ^M)
expect (OK)
^M
^M
OK
-- got it send (^MAT+CGDCONT=,"IP","3GNET",,,^M)
expect (OK)
^M
^MAT+CGDCONT=,"IP","3GNET",,,^M^M
OK
-- got it send (ATDT*#^M)
expect (CONNECT)
^M
ATDT*#^M^M
CONNECT
-- got it send (\d)
Script /usr/sbin/chat -s -v -f /etc/ppp/peers/chat-wcdma-connect finished (pid ), status = 0x0
Serial connection established.
Couldn't set tty to PPP discipline: Invalid argument
expect (ABORT"ERROR")
^C
看起来像拨号成功的log
root@imx6ulevk:~# pppd call wcdma &
[]
root@imx6ulevk:~# timeout set to seconds
abort on (NO CARRIER)
abort on (ERROR)
abort on (NODIALTONE)
abort on (BUSY)
abort on (NO ANSWER)
send (^MAT^M)
expect (OK)
^MAT^M^M
OK
-- got it send (^MATZ^M)
expect (OK)
^M
^MATZ^M^M
OK
-- got it send (^MAT+CGDCONT=,"IP","3GNET",,,^M)
expect (OK)
^M
^MAT+CGDCONT=,"IP","3GNET",,,^M^M
OK
-- got it send (ATDT*#^M)
expect (CONNECT)
^M
ATDT*#^M^M
CONNECT
-- got it send (\d)
Script /usr/sbin/chat -s -v -f /etc/ppp/peers/chat-wcdma-connect finished (pid ), status = 0x0
Serial connection established.
using channel
Using interface ppp0
Connect: ppp0 <--> /dev/ttyUSB0
sent [LCP ConfReq id=0x1 <asyncmap 0x0> <magic 0x38c54823> <pcomp> <accomp>]
rcvd [LCP ConfReq id=0x1 <accomp> <pcomp> <asyncmap 0x0> <mru > <magic 0x545> <auth chap MD5>]
No auth is possible
sent [LCP ConfRej id=0x1 <auth chap MD5>]
rcvd [LCP ConfAck id=0x1 <asyncmap 0x0> <magic 0x38c54823> <pcomp> <accomp>]
rcvd [LCP ConfReq id=0x2 <accomp> <pcomp> <asyncmap 0x0> <mru > <magic 0x545>]
sent [LCP ConfAck id=0x2 <accomp> <pcomp> <asyncmap 0x0> <mru > <magic 0x545>]
sent [IPCP ConfReq id=0x1 <addr 0.0.0.0> <ms-dns1 0.0.0.0> <ms-dns2 0.0.0.0>]
rcvd [IPCP ConfReq id=0x1]
sent [IPCP ConfNak id=0x1 <addr 0.0.0.0>]
rcvd [IPCP ConfNak id=0x1 <ms-dns1 0.0.0.0> <ms-dns2 0.0.0.0>]
sent [IPCP ConfReq id=0x2 <addr 0.0.0.0> <ms-dns1 0.0.0.0> <ms-dns2 0.0.0.0>]
rcvd [IPCP ConfReq id=0x2]
sent [IPCP ConfAck id=0x2]
rcvd [IPCP ConfNak id=0x2 <addr 10.74.89.144> <ms-dns1 120.80.80.80> <ms-dns2 221.5.88.88>]
sent [IPCP ConfReq id=0x3 <addr 10.74.89.144> <ms-dns1 120.80.80.80> <ms-dns2 221.5.88.88>]
rcvd [IPCP ConfAck id=0x3 <addr 10.74.89.144> <ms-dns1 120.80.80.80> <ms-dns2 221.5.88.88>]
Could not determine remote IP address: defaulting to 10.64.64.64
local IP address 10.74.89.144
remote IP address 10.64.64.64
primary DNS address 120.80.80.80
secondary DNS address 221.5.88.88
ifconfig -a
ppp0 Link encap:Point-to-Point Protocol
inet addr:10.74.89.144 P-t-P:10.64.64.64 Mask:255.255.255.255
UP POINTOPOINT RUNNING NOARP MULTICAST MTU: Metric:
RX packets: errors: dropped: overruns: frame:
TX packets: errors: dropped: overruns: carrier:
collisions: txqueuelen:
RX bytes: (68.0 B) TX bytes: (80.0 B)
netstat -nr
root@imx6ulevk:~# netstat -nr
Kernel IP routing table
Destination Gateway Genmask Flags MSS Window irtt Iface
0.0.0.0 0.0.0.0 0.0.0.0 U ppp0
10.64.64.64 0.0.0.0 255.255.255.255 UH ppp0
error
root@imx6ulevk:~# ping -I ppp0 www.baidu.com
ping: bad address 'www.baidu.com'
success
root@imx6ulevk:~# ping 202.108.23.237
PING 202.108.23.237 (202.108.23.237): data bytes
bytes from 202.108.23.237: seq= ttl= time=1515.208 ms
bytes from 202.108.23.237: seq= ttl= time=75.742 ms
Yocto开发笔记之《驱动调试-华为3G模块》(QQ交流群:519230208)的更多相关文章
- 运维开发笔记整理-URL配置
运维开发笔记整理-URL配置 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.URL路由 对于高质量的Web应用来说,使用简洁,优雅的URL的路由是一个非常值得重视的细节.Dja ...
- Yocto开发笔记之《快速入门,环境搭建 & 编译》(QQ交流群:519230208)
开了一个交流群,欢迎爱好者和开发者一起交流,转载请注明出处. QQ群:,为避免广告骚扰,申请时请注明 “开发者” 字样 ======================================== ...
- Yocto开发笔记之《根文件系统裁剪》(QQ交流群:519230208)
开了一个交流群,欢迎爱好者和开发者一起交流,转载请注明出处. QQ群:519230208,为避免广告骚扰,申请时请注明 “开发者” 字样 =============================== ...
- Yocto开发笔记之《嵌入式linux libcurl编程》(QQ交流群:519230208)
开了一个交流群,欢迎爱好者和开发者一起交流,转载请注明出处. QQ群:519230208,为避免广告骚扰,申请时请注明 “开发者” 字样 =============================== ...
- Yocto开发笔记之《Makefile编写》(QQ交流群:519230208)
开了一个交流群,欢迎爱好者和开发者一起交流,转载请注明出处. QQ群:519230208,为避免广告骚扰,申请时请注明 “开发者” 字样 =============================== ...
- Yocto开发笔记之《驱动调试-GPS数据采集》(QQ交流群:519230208)
开了一个交流群,欢迎爱好者和开发者一起交流,转载请注明出处. QQ群:519230208,为避免广告骚扰,申请时请注明 “开发者” 字样 =============================== ...
- Yocto开发笔记之《Tip-bitbake常用命令》(QQ交流群:519230208)
开了一个交流群,欢迎爱好者和开发者一起交流,转载请注明出处. QQ群:519230208,为避免广告骚扰,申请时请注明 “开发者” 字样 =============================== ...
- [Openwrt 项目开发笔记]:MySQL配置(六)
[Openwrt项目开发笔记]系列文章传送门:http://www.cnblogs.com/double-win/p/3888399.html 正文: 在本人的项目中,运行在路由器上的服务器采用Ngi ...
- 《linux就该这么学》课堂笔记12 网卡配置、防火墙配置
1.网卡配置(四种方法,选其一即可,配置后须重启网络服务使其生效) 1)修改配置文件./etc/sysconfig/network-scripts/ifcfg-网卡名称 2)nmtui [RHEL7] ...
- Yocto开发笔记之《网卡配置》(QQ交流群:519230208)
QQ群:519230208,为避免广告骚扰,申请时请注明 “开发者” 字样 ============================================== # ifconfig -a # ...
随机推荐
- json数据转换失败json_last_error int(4)
最近在程序中使用json_decode($data,true);转换失败, 并且使用 json_last_error();方法返回最后一次转换的错误,json_last_error();返回int(4 ...
- Graphql介绍(Introduction to GraphQL)
Introduction to GraphQL GraphQL介绍 Learn about GraphQL, how it works, and how to use it in this seri ...
- The superclass javax.servlet.http.HttpServlet was not found on the Java Build Path。
项目上右键-->Build Path-->Configuration Build Path -->Add Library -->Server Runtime 选择tomcat
- 写启动界面Splash的正确姿势,解决启动白屏(转)
原文链接:http://www.jianshu.com/p/cd6ef8d3d74d 从我学习写第一个android项目以来,我都是这样写着启动界面: 在里面做一些事,比如:第一次启动时拷贝数据. 然 ...
- Android判断当前系统时间是否在指定时间的范围内(免消息打扰)
/** * 判断当前系统时间是否在指定时间的范围内 * * @param beginHour * 开始小时,例如22 * @param beginMin * 开始小时的分钟数,例如30 * @para ...
- .Net Core 1.0.0正式版安装及示例教程
使用VS Code 从零开始开发调试.NET Core 1.0 RTM. .NET Core 是一个开源的.跨平台的 .NET 实现. VS Code 全称是 Visual Studio Code,V ...
- 平行四边形面积 light 1305
double 不一定是与x y轴平平行 所以要正弦定理和余弦定理 似乎一定要printf输出 错了好几次 #include<iostream> #include<math.h> ...
- Html+js 控制input输入框提示
<input type="text" class="fl plsearch_txt" id="key" value="请输入 ...
- hashMap的输出是和加入元素的顺序一样的吗?
hashMap是无序的,同时也不是先进先出的.
- 【C++实现python字符串函数库】二:字符串匹配函数startswith与endswith
[C++实现python字符串函数库]字符串匹配函数startswith与endswith 这两个函数用于匹配字符串的开头或末尾,判断是否包含另一个字符串,它们返回bool值.startswith() ...