此次的短信AT指令和信令从以下几个方面介绍:
一 . 短信AT指令的格式
二 . 短信AT指令的使用(超级终端)
三 . 短信AT指令在log中的查看
四 . 短信modem相关信令
五 . 超级终端的使用(hyper_terminal)
六 . 其他短信AT指令
七 . CMC ERROR 错误码
短信的编码方式有两种:text模式,pdu模式。因此短信的AT指令执行格式也有两种,分别对应text模式和pdu模式。
1 . Text模式
纯文本模式,支持不同的字符集,从技术上说也可用于发送中文短消息,但国内手机基本上不支持,主要用于欧美地区。
2 . Pdu模式
这个是手机默认的编码方式,可以使用任何字符集,其包括三种编码方式:7bit编码,8bit编码,UCS2编码。
7bit编码:ASCⅡ码就是7bit编码。
8bit编码:ASCⅡ字符可以使用7位二进制表示,但是由于计算机的基本处理单位是字节(1byte=8bit),所以一般在高位补0,用一个字节表示一个ASCⅡ字符。这就是8bit编码。
UCS2编码:处理Unicode字符,使用2个字节来表示一个字符,可以表示世界上所有的字符。发送中文就是使用此编码方式。
1 . 查看目前的短信编码模式
AT+CMGF?
2 . 切换编码模式
AT+CMGF=0//PDU
AT+CMGF=1//TEXT
3 . 当模式为text时,发送格式如下
AT+CMGS=”18579853304”
dddddd…. (此处为发送内容)
0X1A (此处表示内容结尾,必须)
结果:
+CMGS: 211
OK
4 . 当模式为pdu时,发送格式如下
AT+CMGS=19, “0001000b818125514688f4000006c8329bfd0601” 或者
AT+CMGS=20, “0001000b818175893503f4000008d3ba3a1d76ebcb”
19和20为:pdu约定固定长度15+发送的报文的长度(16进制数)
00 服务号码信息长度为0
01 没有多余信息的发送,即不包括服务号码信息
00 消息基准值(TP-MR) 0
0b 发送号码的信息长度
81 国际号码格式即”+”
8125514688f4 目的号码,即18521564884(算法:末尾加f后奇偶位调换)
00 协议标识是普通GSM 类型,点到点方式
00 编码方式,08–USC2,00–7-bit
00 有效期
06 信息长度
c8329bfd0601 信息内容/Hello
1 . 正常发送短信
RILJ : [4194]> SEND_SMS [SUB0] //从RIL.java中发出SEND_SMS消息
AT : AT send on RIL_CMD_READER_3, tid:548282602560
AT : AT>AT+CMGS=19,"0001000b818175893503f4000006c8329bfd0e03"
AT : AT< +CMGS: 218 //modem返回的结果,返回CMGS说明发送成功
AT : response received on RIL_CMD_READER_3, tid:548282602560
RILJ : [4194]< SEND_SMS { mMessageRef = 218, mErrorCode = 0, mAckPdu = null} [SUB0] //AT向RIL.java报告发送情况
2 . 发送短信失败
RILJ : [4838]> SEND_SMS [SUB0]
AT : AT send on RIL_CMD_READER_3, tid:548305933376
AT : AT>AT+CMGS=20,"0001000b818175893503f4000008d3ba3a1d76ebcb"
AT : AT< ERROR
以上例子失败原因:
设置编码为Text模式,但是手机默认的编码为pdu模式,以上AT+CMGS命令执行时参数为pdu码。因此报AT< ERROR。
以上例子不具有代表性,实际上,发送短信失败,最终AT的返回结果为:
AT< +CMS ERROR: 111。
111代表的意思为:Protocol error, unspecified
每个错误码对应响应的失败原因,CMS ERROR的错误码见文档最后。
3 . 正常接收短信
AT : AT< +CMT: ,25
AT : SMS Urc Received!
AT : AT< 0891683110501905F0040BA18175893503F400006101809103242306F732681C7603
AT : RIL_URC_READER:line1:+CMT:,25,line2:0891683110501905F0040BA18175893503F400006101809103242306F732681C7603
RILJ : [UNSL]< UNSOL_RESPONSE_NEW_SMS [SUB0] //向RIL.java上报新消息
RILJ : [4223]> SMS_ACKNOWLEDGE true 0 [SUB0] //RIL.java确认新消息已收到
AT : AT send on RIL_CMD_READER_2, tid:548283642944
AT : AT> AT+CNMA=1, 2, "0000" //AT向服务器反馈消息已收到
AT : AT< OK //基站服务器响应ok
AT : response received on RIL_CMD_READER_2, tid:548283642944
RILJ : [4223]< SMS_ACKNOWLEDGE [SUB0] //AT向RIL.java响应ok
4 . 接收短信失败
AT : AT< +EIMSCMT: ,22
AT : SMS Urc Received!
AT : AT< 0891683109520000F0000A11620010861400006190032180958004D4F29C0E
AT : RIL_URC_READER: line1:+EIMSCMT: ,22,line2:0891683109520000F0000A11620010861400006190032180958004D4F29C0E
RILJ : [UNSL]< UNSOL_RESPONSE_NEW_SMS [SUB0]SmsMessage: SMS PDU parsing failed:
.......
RILJ : [3892]> SMS_ACKNOWLEDGE false 255 [SUB0] //RIL.java确认新消息已收到,但是新消息存在问题,返回255错误码
AT : AT send on RIL_CMD_READER_2, tid:547637703744
AT : AT> AT+EIMSCNMA=2, 3, "00FF00" //AT向服务器反馈消息已收到
AT : AT< OK
AT : response received on RIL_CMD_READER_2, tid:547637703744
RILJ : [3892]< SMS_ACKNOWLEDGE [SUB0]
以上例子:
客户使用一台样机向另一台样机发送短信,发送方发送短信成功,但是接收方接收不到短信。
从以上log可以看出,RIL.java在对pdu码解析的过程中发生了错误,但是实际上AT已经收到了新短信,因此也需要向服务器反馈结果,AT的整个流程是没有问题的。因为pdu解析出错,新短信自然不能保存并显示,我们看到的现象就是接收不到新短信。
解析pdu出错的详细信息如下:
SmsMessage: java.lang.RuntimeException: Invalid TOA - high bit must be set. toa = 17 (at offset 11)
SmsMessage: at com.android.internal.telephony.gsm.SmsMessage$PduParser.getAddress(SmsMessage.java:609)
SmsMessage: at com.android.internal.telephony.gsm.SmsMessage.parseSmsDeliver(SmsMessage.java:1041)
SmsMessage: at com.android.internal.telephony.gsm.SmsMessage.parsePdu(SmsMessage.java:968)
SmsMessage: at com.android.internal.telephony.gsm.SmsMessage.newFromCMT(SmsMessage.java:163)
SmsMessage: at android.telephony.SmsMessage.newFromCMT(SmsMessage.java:257)
SmsMessage: at com.android.internal.telephony.RIL.processUnsolicited(RIL.java:3832)
SmsMessage: at com.android.internal.telephony.RIL.processResponse(RIL.java:2930)
SmsMessage: at com.android.internal.telephony.RIL.-wrap6(RIL.java)
SmsMessage: at com.android.internal.telephony.RIL$RILReceiver.run(RIL.java:848)
SmsMessage: at java.lang.Thread.run(Thread.java:818)
从RuntimeException信息中看到, code 会做SMS OA address type 的检查。log 中 的号码为0A116200108614 ,address type 栏位是0x11,但spec要求 最高bit是1,因此抛出了异常。
解决办法:一是我们去掉SMS OA address type的检查,但是会存在不确定性,二是看看运营商在发送短信时检查下OA address type的最高一个bit 是否为1。
在GSM中,SMS在协议上分为三层(RP/CP/TP),每层传输使用的protocol不一样,RP和CP分别代表在SM-RL与CM-sublayer上的数据,定义在TS 24.011。RP是处于CP的上层,因此发送SMS数据时RP数据单元要在CM-sublayer层上打包为CP数据单元,接收的CP则要在SM-RL解包为RP。详细的SMS分层参考3GPP TS24.011第2.1节。
发送短信:
(UE –> NW) CP-DATA[包含SMS的文本内容;包含RP-DATA]
(UE <– NW) CP-ACK [简单响应收到上一个CP-DATA;不包含RP]
(UE <– NW) CP-DATA[如果短信有什么异常或网络拒绝等异常cause会携带在里面;包含RP-ACK或者是RP-ERROR,响应上面的RP-DATA]
(UE –> NW) CP-ACK [简单响应NW收到了上一个CP-DATA;不包含RP]
接收短信:
(UE <– NW) CP-DATA[包含SMS的文本内容;包含RP-DATA]
(UE –> NW) CP-ACK [简单响应收到上一个CP-DATA;不包含RP]
(UE –> NW) CP-DATA[如果短信有什么异常或手机拒绝等异常cause会携带在里面;包含RP-ACK或者是RP-ERROR,响应上面的RP-DATA]
(UE <– NW) CP-ACK [简单响应手机收到上一个CP-DATA;不包含RP]
ERROR cause是携带在第三个流程中,具体的cause可以查TS 24.011附件 Annex E
1.安装超级终端。
2.获取串口(COM1,2,3,4)。
由于手机在Normal Mode下,PC需要通过Kernel VCOM Port向手机发送AT Command;而手机默认在Normal Mode下并没有打开Kernel VCOM Port。此时需要通过向手机发送ADB Command去让手机枚举Kernel VCOM Port。
对于ICS及以上版本,手机枚举Kernel VCOM的命令为:在adb shell下,输入setprop persist.sys.usb.config mass_storage,adb,acm
对于MT6572 GB3版本,手机枚举Kernel VCOM的命令为:在adb shell下,输入echo 1 > /sys/class/usb_composite/acm/enable
3.测试
AT 确认串口正常
ok
1.AT+CPMS
命令解释:选择短信存储载体
1.1 设置短信存储载体
命令格式:AT+CPMS=[,][,]
命令返回:+CPMS:,,,,, OK/ERROR
测试结果:
1.2 显示当前短信存储载体设置
命令格式:AT+CPMS?
命令返回:+CPMS:,,,,,,,, OK/ERROR
测试结果:
1.3 显示本命令支持的参数
命令格式:AT+CPMS=?
命令返回:+CPMS: (list of supporteds),(list of supporteds),(list of supporteds) OK/ERROR
测试结果:
命令内容:AT+CPMS=?
命令返回:+CPMS: (“ME”,”SM”),(“ME”,”SM”),(“ME”,”SM”) OK
2.AT+CMGF
命令解释:设置短信格式
2.1 设置短信格式
命令格式:AT+CMGF=//0:PDU格式 1:文本格式
命令返回:OK/ERROR
2.2 显示本命令支持的参数
命令格式:AT+CMGF=?
命令返回:OK/ERROR
2.3 显示当前短信格式
命令格式:AT+CMGF?
命令返回:OK/ERROR
测试结果:
3.AT+CMGS
命令解释:发送短信
命令格式:AT+CMGS=[,]
Text is entered
Error Description
CMS ERROR: 1 Unassigned number
CMS ERROR: 8 Operator determined barring
CMS ERROR: 10 Call bared
CMS ERROR: 21 Short message transfer rejected
CMS ERROR: 27 Destination out of service
CMS ERROR: 28 Unindentified subscriber
CMS ERROR: 29 Facility rejected
CMS ERROR: 30 Unknown subscriber
CMS ERROR: 38 Network out of order
CMS ERROR: 41 Temporary failure
CMS ERROR: 42 Congestion
CMS ERROR: 47 Recources unavailable
CMS ERROR: 50 Requested facility not subscribed
CMS ERROR: 69 Requested facility not implemented
CMS ERROR: 81 Invalid short message transfer reference value
CMS ERROR: 95 Invalid message unspecified
CMS ERROR: 96 Invalid mandatory information
CMS ERROR: 97 Message type non existent or not implemented
CMS ERROR: 98 Message not compatible with short message protocol
CMS ERROR: 99 Information element non-existent or not implemente
CMS ERROR: 111 Protocol error, unspecified
CMS ERROR: 127 Internetworking , unspecified
CMS ERROR: 128 Telematic internetworking not supported
CMS ERROR: 129 Short message type 0 not supported
CMS ERROR: 130 Cannot replace short message
CMS ERROR: 143 Unspecified TP-PID error
CMS ERROR: 144 Data code scheme not supported
CMS ERROR: 145 Message class not supported
CMS ERROR: 159 Unspecified TP-DCS error
CMS ERROR: 160 Command cannot be actioned
CMS ERROR: 161 Command unsupported
CMS ERROR: 175 Unspecified TP-Command error
CMS ERROR: 176 TPDU not supported
CMS ERROR: 192 SC busy
CMS ERROR: 193 No SC subscription
CMS ERROR: 194 SC System failure
CMS ERROR: 195 Invalid SME address
CMS ERROR: 196 Destination SME barred
CMS ERROR: 197 SM Rejected-Duplicate SM
CMS ERROR: 198 TP-VPF not supported
CMS ERROR: 199 TP-VP not supported
CMS ERROR: 208 D0 SIM SMS Storage full
CMS ERROR: 209 No SMS Storage capability in SIM
CMS ERROR: 210 Error in MS
CMS ERROR: 211 Memory capacity exceeded
CMS ERROR: 212 Sim application toolkit busy
CMS ERROR: 213 SIM data download error
CMS ERROR: 255 Unspecified error cause
CMS ERROR: 300 ME Failure
CMS ERROR: 301 SMS service of ME reserved
CMS ERROR: 302 Operation not allowed
CMS ERROR: 303 Operation not supported
CMS ERROR: 304 Invalid PDU mode parameter
CMS ERROR: 305 Invalid Text mode parameter
CMS ERROR: 310 SIM not inserted
CMS ERROR: 311 SIM PIN required
CMS ERROR: 312 PH-SIM PIN required
CMS ERROR: 313 SIM failure
CMS ERROR: 314 SIM busy
CMS ERROR: 315 SIM wrong
CMS ERROR: 316 SIM PUK required
CMS ERROR: 317 SIM PIN2 required
CMS ERROR: 318 SIM PUK2 required
CMS ERROR: 320 Memory failure
CMS ERROR: 321 Invalid memory index
CMS ERROR: 322 Memory full
CMS ERROR: 330 SMSC address unknown
CMS ERROR: 331 No network service
CMS ERROR: 332 Network timeout
CMS ERROR: 340 No +CNMA expected
CMS ERROR: 500 Unknown error
CMS ERROR: 512 User abort
CMS ERROR: 513 Unable to store
CMS ERROR: 514 Invalid Status
CMS ERROR: 515 Device busy or Invalid Character in string
CMS ERROR: 516 Invalid length
CMS ERROR: 517 Invalid character in PDU
CMS ERROR: 518 Invalid parameter
CMS ERROR: 519 Invalid length or character
CMS ERROR: 520 Invalid character in text
CMS ERROR: 521 Timer expired
CMS ERROR: 522 Operation temporary not allowed
CMS ERROR: 532 SIM not ready
CMS ERROR: 534 Cell Broadcast error unknown
CMS ERROR: 535 Protocol stack busy
CMS ERROR: 538 Invalid parameter
参考:http://blog.sina.com.cn/s/blog_4c8b0d600100dlt7.html
http://www.cppblog.com/zhangyq/archive/2009/07/04/89245.html