我想阅读华为E3531的RSSI。所以我发现一些文档显示了使用AT命令获取这些信息的简单方法。问题是我甚至无法连接到我的华为E3531。我的意思是,它作为一个调制解调器工作得很好。我有很好的联系。但是当我在开发中寻找设备时,我发现2个设备(“sdb”和“sgm”)似乎是2个光盘,但与串口无关。
所以我尝试了一些我找到的东西: - 我插上华为后,发现Idvendor和Idproduct做了一个lsusb。 - 他们做了一个sudo modprobe usbserial vendor = 0X“Idvendor”product = 0X“Idproduct” - 当我做dmesg时,我可以读到:
[ 1038.498282] usbcore: registered new interface driver usbserial
[ 1038.498299] usbcore: registered new interface driver usbserial_generic
[ 1038.498312] usbserial: USB Serial support registered for generic
通常我应该有:
usb 1-1: generic converter now attached to ttyUSB0
我想我必须说从Mac上看到sdb和sgm是不可能的,所以我是从我的Ubuntu那里做的。如果我启用我的wifi,调制解调器无法连接(所以我没有看到sdb和sgm)
如果有人需要,这是dmesg的第一部分:
[ 742.756888] usb 3-1: USB disconnect, device number 6
[ 743.123706] usb 3-1: new high-speed USB device number 7 using xhci_hcd
[ 743.252854] usb 3-1: New USB device found, idVendor=12d1, idProduct=14dc
[ 743.252861] usb 3-1: New USB device strings: Mfr=1, Product=2, SerialNumber=0
[ 743.252865] usb 3-1: Product: HUAWEI Mobile
[ 743.252868] usb 3-1: Manufacturer: HUAWEI
[ 743.482312] cdc_ether 3-1:1.0 usb0: register 'cdc_ether' at usb-0000:00:14.0-1, CDC Ethernet Device, 9a:c2:9b:ee:4c:d9
[ 743.482859] usb-storage 3-1:1.2: USB Mass Storage device detected
[ 743.483249] scsi11 : usb-storage 3-1:1.2
[ 743.520839] audit: type=1400 audit(1427889713.269:79): apparmor="DENIED" operation="file_inherit" profile="/usr/lib/NetworkManager/nm-dhcp-client.action" pid=3414 comm="nm-dhcp-client." lport=29180 family="inet" sock_type="dgram" protocol=17
[ 743.520857] audit: type=1400 audit(1427889713.269:80): apparmor="DENIED" operation="file_inherit" profile="/usr/lib/NetworkManager/nm-dhcp-client.action" pid=3414 comm="nm-dhcp-client." lport=47709 family="inet6" sock_type="dgram" protocol=17
[ 744.481267] scsi 11:0:0:0: Direct-Access HUAWEI TF CARD Storage 2.31 PQ: 0 ANSI: 2
[ 744.481722] sd 11:0:0:0: Attached scsi generic sg2 type 0
[ 744.482933] sd 11:0:0:0: [sdb] Attached SCSI removable disk
[ 753.752310] audit: type=1400 audit(1427889723.496:81): apparmor="DENIED" operation="file_inherit" profile="/usr/lib/NetworkManager/nm-dhcp-client.action" pid=3423 comm="nm-dhcp-client." lport=29180 family="inet" sock_type="dgram" protocol=17
[ 753.752328] audit: type=1400 audit(1427889723.496:82): apparmor="DENIED" operation="file_inherit" profile="/usr/lib/NetworkManager/nm-dhcp-client.action" pid=3423 comm="nm-dhcp-client." lport=47709 family="inet6" sock_type="dgram" protocol=17
[ 1038.498282] usbcore: registered new interface driver usbserial
[ 1038.498299] usbcore: registered new interface driver usbserial_generic
[ 1038.498312] usbserial: USB Serial support registered for generic
再次感谢你,如果你能给我一个小小的想法,我会接受它! 很快见到你
编辑9/04/2015 所以我发现了一些东西做一个lsusb你会看到你的设备:
总线003设备020:ID 12d1:1f01华为技术有限公司
1f01是Idproduct,但它可以在某个时候改变,因为调制解调器自己进入不同的模式。如果是1F01,请执行:
sudo usb_modeswitch -v 12d1 -p 1F01 -M '55534243123456780000000000000011062000000100000000000000000000'
这会强制您的设备更改模式。现在你的设备将有一个Idproduct等于1001.做一个lsusb看到它:
总线003设备023:ID 12d1:1001华为技术有限公司 E169 / E620 / E800 HSDPA调制解调器
你有4个新的usb开发:USB0,USB1,USB2和USB3。 现在我将尝试使用minicom发送AT命令。
答案 0 :(得分:5)
所以基本上,我的问题是我看不到我的调制解调器是一个序列。我解释了如何做到这一点,你必须用这个命令强制你的调制解调器:
sudo usb_modeswitch -v 12d1 -p 1F01 -M ' 55534243123456780000000000000011062000000100000000000000000000'
然后我尝试了Minicom,这非常好,你只需要使用正确的参数如波特率和端口连接好。所以寻找并做一些测试。要查看您在minicom中编写的内容,只需启用本地回显(ctrl + a然后选择z)。 所以你可以发送你想要的所有信息。
但我想将它集成到python脚本中,所以这是我的代码:
def terminalComAndRead(a,b) :
found = False
proc = subprocess.Popen([a], stdout=subprocess.PIPE, shell=True)#send the command
(out, err) = proc.communicate()
string=str(out)
#print(string)
foundstring=string.find(b, 0, len(string))#look for the string b in the serial answer of my device
if foundstring != -1 :
found= True #send back true if it found it
return found
def send(data,ser):
try:
ser.write(data)#write the command my serail port
except Exception as e:
print "Couldn't send data to serial port: %s" % str(e)
else:
try:
sleep(1)
data = ser.read(1)#read the serial
except Exception as e:
print "Couldn't read data from serial port: %s" % str(e)
else:
if data: # If data = None, timeout occurr
n = ser.inWaiting()
if n > 0: data += ser.read(n)
return data
def searchModem():
foundmob= False
foundusb= False
sudoPassword='Figaro5558_'#my sudo password
command="usb_modeswitch -v 12d1 -p 1f01 -M '55534243123456780000000000000011062000000100000000000000000000'" # the command that for ce the modem to be on serial mode
while foundusb!= True : # this allows me to look for the modem as an usb and then force it
foundmob=terminalComAndRead("lsusb",'12d1:1f01')#doing a ls usb and then looking for the id of my device
changemob=terminalComAndRead("lsusb",'12d1:1001')#this is the id of my device when it is already in serial mode
if foundmob == True :
sleep(1)
os.system('echo %s|sudo -S %s' % (sudoPassword, command))# this is the line who execute the command on sudo
foundusb=terminalComAndRead("ls /dev/ttyUSB*",'ttyUSB1')
if changemob == True :
foundusb=terminalComAndRead("ls /dev/ttyUSB*",'ttyUSB1')
if foundusb == True :
print('Modem ready for connection')
ttyusb0=terminalComAndRead('dmesg | tail -50','now attached to ttyUSB0') #look int he dmesg if there is my new usb port
if ttyusb0 == True :
usbPort='/dev/ttyUSB0'#give the path
return usbPort
ser = serial.Serial(usbPort, 9600, bytesize=8, parity='N', stopbits=1, timeout=1, rtscts=False, dsrdtr=False) #connect to your serial
cmd="AT^HCSQ?\r\n"#the AT command
msg=str(send(cmd,ser))#use the send function to send the AT command
print(msg)
所以这对我有用,我希望它会对你有所帮助! 干杯