在root的Xperia Z android设备上发送AT命令

时间:2013-10-01 16:37:36

标签: android adb at-command ussd

我有一个扎根的xperia Z手机。 我想发送USSD命令并找到答案。

我的第一个想法是通过adb shell界面通过良好的界面发送AT命令。

我列出了所有接口:

/dev/tty             /dev/tty        5       0   system:/dev/tty
/dev/console         /dev/console    5       1   system:console
/dev/ptmx            /dev/ptmx       5       2   system
/dev/vc/0            /dev/vc/0       4       0   system:vtmaster
rfcomm               /dev/rfcomm   216 0-255     serial
usbserial            /dev/ttyUSB   188 0-253     serial
msm_serial_hsl       /dev/ttyHSL   244 0-3       serial
msm_serial_hs        /dev/ttyHS    245 0-255     serial
pty_slave            /dev/pts      136 0-1048575 pty:slave
pty_master           /dev/ptm      128 0-1048575 pty:master
smd_tty_driver       /dev/smd      251 0-36      serial
unknown              /dev/tty        4 1-63      console

我无法找到好的界面。 我试过这个命令集:

root@android:/tmp/tst # tail -f /dev/ttyHSL1 &
root@android:/tmp/tst # echo -e "AT\r" > /dev/ttyHSL1

但我没有回答。

知道如何找到好的端口吗?

EDIT1: 根据Alex P。

的要求
root@android:/ # getprop | grep -i ril
[gsm.version.ril-impl]: [Qualcomm RIL 1.0]
[init.svc.ril-daemon]: [running]
[init.svc.ril-qmi]: [stopped]
[persist.rild.nitz_long_ons_0]: []
[persist.rild.nitz_long_ons_1]: []
[persist.rild.nitz_long_ons_2]: []
[persist.rild.nitz_long_ons_3]: []
[persist.rild.nitz_plmn]: []
[persist.rild.nitz_short_ons_0]: []
[persist.rild.nitz_short_ons_1]: []
[persist.rild.nitz_short_ons_2]: []
[persist.rild.nitz_short_ons_3]: []
[persist.ro.ril.sms_sync_sending]: [1]
[ril.cat.first.start]: [false]
[ril.ecclist]: [911,112]
[ril.icctype]: [2]
[ril.subscription.types]: [NV,RUIM]
[rild.libargs]: [-d /dev/smd0]
[rild.libpath]: [/system/lib/libril-qc-qmi-1.so]
[ro.ril.svdo]: [false]
[ro.ril.svlte1x]: [false]
[ro.ril.transmitpower]: [true]


goot@android:/ # grep -i ril /init*rc /init*sh
/init.qcom.rc:    onrestart /system/bin/log -t RIL-ATFWD -p w "ATFWD daemon restarted"
/init.qcom.rc:service ril-daemon1 /system/bin/rild -c 1
/init.qcom.rc:    socket rild1 stream 660 root radio
/init.qcom.rc:    socket rild-debug1 stream 660 radio system
/init.rc:service ril-daemon /system/bin/rild
/init.rc:    socket rild stream 660 root radio
/init.rc:    socket rild-debug stream 660 radio system
/init.target.rc:service ril-qmi /system/bin/sh /init.qcom.ril.sh
/init.qcom.class_main.sh:# start ril-daemon only for targets on which radio is present
/init.qcom.class_main.sh:multirild=`getprop ro.multi.rild`
/init.qcom.class_main.sh:    setprop ro.radio.noril yes
/init.qcom.class_main.sh:    stop ril-daemon
/init.qcom.class_main.sh:          setprop ro.multi.rild true
/init.qcom.class_main.sh:          stop ril-daemon
/init.qcom.class_main.sh:          start ril-daemon
/init.qcom.class_main.sh:          start ril-daemon1
/init.qcom.class_main.sh:    case "$multirild" in
/init.qcom.class_main.sh:             start ril-daemon1
/init.qcom.ril.sh:# start two rild when dsds property enabled
/init.qcom.ril.sh:    setprop ro.multi.rild true
/init.qcom.ril.sh:    stop ril-daemon
/init.qcom.ril.sh:    start ril-daemon
/init.qcom.ril.sh:    start ril-daemon1


root@android:/ # busybox netstat -lpnx | grep -i ril
unix  2      [ ACC ]     STREAM     LISTENING       7312 277/rild            /dev/socket/rild-debug
unix  2      [ ACC ]     STREAM     LISTENING       7314 277/rild            /dev/socket/rild

EDIT2:

在我看到/ dev / smd0时,我列出了所有smd界面:

root@android:/ # ls -l /dev/smd*
ls -l /dev/smd*
crw------- root     root     251,   1 2013-10-01 21:53 smd1
crw------- root     root     251,  11 1970-05-31 18:07 smd11
crw-rw---- bluetooth bluetooth 251,   2 1970-05-31 18:07 smd2
crw------- root     root     251,  21 1970-05-31 18:07 smd21
crw------- root     root     250,   8 1970-05-31 18:07 smd22
crw------- root     root     251,  27 1970-05-31 18:07 smd27
crw-rw---- bluetooth bluetooth 251,   3 2013-10-01 17:45 smd3
crw------- root     root     251,  36 1970-05-31 18:07 smd36
crw-rw---- system   system   251,   4 1970-05-31 18:07 smd4
crw------- root     root     251,   5 1970-05-31 18:07 smd5
crw------- root     root     251,   6 1970-05-31 18:07 smd6
crw-rw---- bluetooth bluetooth 251,   7 1970-05-31 18:07 smd7
crw-r----- radio    radio    250,  22 1970-05-31 18:07 smd_cxm_qmi
crw------- root     root     250,  23 1970-05-31 18:07 smd_pkt_loopback
crw------- root     root     250,  21 1970-05-31 18:07 smd_sns_adsp
crw------- root     root     250,  18 1970-05-31 18:07 smd_sns_dsps
crw------- root     root     250,   9 1970-05-31 18:07 smdcnt_rev0
crw------- root     root     250,  10 1970-05-31 18:07 smdcnt_rev1
crw------- root     root     250,  11 1970-05-31 18:07 smdcnt_rev2
crw------- root     root     250,  12 1970-05-31 18:07 smdcnt_rev3
crw------- root     root     250,  13 1970-05-31 18:07 smdcnt_rev4
crw------- root     root     250,  14 1970-05-31 18:07 smdcnt_rev5
crw------- root     root     250,  15 1970-05-31 18:07 smdcnt_rev6
crw------- root     root     250,  16 1970-05-31 18:07 smdcnt_rev7
crw------- root     root     250,  17 1970-05-31 18:07 smdcnt_rev8
crw-r----- radio    radio    250,   0 1970-05-31 18:07 smdcntl0
crw-r----- radio    radio    250,   1 1970-05-31 18:07 smdcntl1
crw-r----- radio    radio    250,   2 1970-05-31 18:07 smdcntl2
crw-r----- radio    radio    250,   3 1970-05-31 18:07 smdcntl3
crw-r----- radio    radio    250,   4 1970-05-31 18:07 smdcntl4
crw-r----- radio    radio    250,   5 1970-05-31 18:07 smdcntl5
crw-r----- radio    radio    250,   6 1970-05-31 18:07 smdcntl6
crw-r----- radio    radio    250,   7 1970-05-31 18:07 smdcntl7
crw------- root     root     250,  20 1970-05-31 18:07 smdcntl8

我没有安装/ dev / smd0接口

EDIT3:

我尝试了套接字解决方案:

new-host:platform-tools julio$ ./adb forward tcp:8080 localfilesystem:/dev/socket/rild-debug
* daemon not running. starting it now on port 5037 *
* daemon started successfully *
new-host:platform-tools julio$ 



>>> MaSocket = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
>>> MaSocket.connect(('127.0.0.1',8080))
>>> MaSocket.send('AT\r\n')
4
>>> print MaSocket.recv(1)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
socket.error: [Errno 54] Connection reset by peer
>>> print MaSocket.recv(1)

>>> 

2 个答案:

答案 0 :(得分:2)

我有同样的问题: 您可以使用/dev/smd7/dev/sdm8/dev/smd11
EX:

echo "AT\r" | busybox microcom -t 500 /dev/smd11

答案 1 :(得分:1)

最好的机会是使用/dev/socket/rild-debug unix socket。它可能需要设备端的一些本机或Java代码。或者,您可以设置adb forward tcp:XXXX localfilesystem:/dev/socket/rild-debug并从PC端访问它。