304 lines
7.9 KiB
Bash
Executable File
304 lines
7.9 KiB
Bash
Executable File
#!/bin/sh
|
|
# Copyright (C) 2023 Siriling <siriling@qq.com>
|
|
|
|
#脚本目录
|
|
SCRIPT_DIR="/usr/share/modem"
|
|
|
|
#查询信息强度
|
|
All_CSQ()
|
|
{
|
|
debug "All_CSQ"
|
|
#信号
|
|
OX=$( sh modem_at.sh $at_port "AT+CSQ" |grep "+CSQ:")
|
|
OX=$(echo $OX | tr 'a-z' 'A-Z')
|
|
CSQ=$(echo "$OX" | grep -o "+CSQ: [0-9]\{1,2\}" | grep -o "[0-9]\{1,2\}")
|
|
if [ $CSQ = "99" ]; then
|
|
CSQ=""
|
|
fi
|
|
if [ -n "$CSQ" ]; then
|
|
CSQ_PER=$(($CSQ * 100/31))"%"
|
|
CSQ_RSSI=$((2 * CSQ - 113))" dBm"
|
|
else
|
|
CSQ="-"
|
|
CSQ_PER="-"
|
|
CSQ_RSSI="-"
|
|
fi
|
|
}
|
|
|
|
# SIMCOM获取基站信息
|
|
SIMCOM_Cellinfo()
|
|
{
|
|
#baseinfo.gcom
|
|
OX=$( sh modem_at.sh 2 "ATI")
|
|
OX=$( sh modem_at.sh 2 "AT+CGEQNEG=1")
|
|
|
|
#cellinfo0.gcom
|
|
OX1=$( sh modem_at.sh 2 "AT+COPS=3,0;+COPS?")
|
|
OX2=$( sh modem_at.sh 2 "AT+COPS=3,2;+COPS?")
|
|
OX=$OX1" "$OX2
|
|
|
|
#cellinfo.gcom
|
|
OY1=$( sh modem_at.sh 2 "AT+CREG=2;+CREG?;+CREG=0")
|
|
OY2=$( sh modem_at.sh 2 "AT+CEREG=2;+CEREG?;+CEREG=0")
|
|
OY3=$( sh modem_at.sh 2 "AT+C5GREG=2;+C5GREG?;+C5GREG=0")
|
|
OY=$OY1" "$OY2" "$OY3
|
|
|
|
|
|
OXx=$OX
|
|
OX=$(echo $OX | tr 'a-z' 'A-Z')
|
|
OY=$(echo $OY | tr 'a-z' 'A-Z')
|
|
OX=$OX" "$OY
|
|
|
|
#debug "$OX"
|
|
#debug "$OY"
|
|
|
|
COPS="-"
|
|
COPS_MCC="-"
|
|
COPS_MNC="-"
|
|
COPSX=$(echo $OXx | grep -o "+COPS: [01],0,.\+," | cut -d, -f3 | grep -o "[^\"]\+")
|
|
|
|
if [ "x$COPSX" != "x" ]; then
|
|
COPS=$COPSX
|
|
fi
|
|
|
|
COPSX=$(echo $OX | grep -o "+COPS: [01],2,.\+," | cut -d, -f3 | grep -o "[^\"]\+")
|
|
|
|
if [ "x$COPSX" != "x" ]; then
|
|
COPS_MCC=${COPSX:0:3}
|
|
COPS_MNC=${COPSX:3:3}
|
|
if [ "$COPS" = "-" ]; then
|
|
COPS=$(awk -F[\;] '/'$COPS'/ {print $2}' $ROOTER/signal/mccmnc.data)
|
|
[ "x$COPS" = "x" ] && COPS="-"
|
|
fi
|
|
fi
|
|
|
|
if [ "$COPS" = "-" ]; then
|
|
COPS=$(echo "$O" | awk -F[\"] '/^\+COPS: 0,0/ {print $2}')
|
|
if [ "x$COPS" = "x" ]; then
|
|
COPS="-"
|
|
COPS_MCC="-"
|
|
COPS_MNC="-"
|
|
fi
|
|
fi
|
|
COPS_MNC=" "$COPS_MNC
|
|
|
|
OX=$(echo "${OX//[ \"]/}")
|
|
CID=""
|
|
CID5=""
|
|
RAT=""
|
|
REGV=$(echo "$OX" | grep -o "+C5GREG:2,[0-9],[A-F0-9]\{2,6\},[A-F0-9]\{5,10\},[0-9]\{1,2\}")
|
|
if [ -n "$REGV" ]; then
|
|
LAC5=$(echo "$REGV" | cut -d, -f3)
|
|
LAC5=$LAC5" ($(printf "%d" 0x$LAC5))"
|
|
CID5=$(echo "$REGV" | cut -d, -f4)
|
|
CID5L=$(printf "%010X" 0x$CID5)
|
|
RNC5=${CID5L:1:6}
|
|
RNC5=$RNC5" ($(printf "%d" 0x$RNC5))"
|
|
CID5=${CID5L:7:3}
|
|
CID5="Short $(printf "%X" 0x$CID5) ($(printf "%d" 0x$CID5)), Long $(printf "%X" 0x$CID5L) ($(printf "%d" 0x$CID5L))"
|
|
RAT=$(echo "$REGV" | cut -d, -f5)
|
|
fi
|
|
REGV=$(echo "$OX" | grep -o "+CEREG:2,[0-9],[A-F0-9]\{2,4\},[A-F0-9]\{5,8\}")
|
|
REGFMT="3GPP"
|
|
if [ -z "$REGV" ]; then
|
|
REGV=$(echo "$OX" | grep -o "+CEREG:2,[0-9],[A-F0-9]\{2,4\},[A-F0-9]\{1,3\},[A-F0-9]\{5,8\}")
|
|
REGFMT="SW"
|
|
fi
|
|
if [ -n "$REGV" ]; then
|
|
LAC=$(echo "$REGV" | cut -d, -f3)
|
|
LAC=$(printf "%04X" 0x$LAC)" ($(printf "%d" 0x$LAC))"
|
|
if [ $REGFMT = "3GPP" ]; then
|
|
CID=$(echo "$REGV" | cut -d, -f4)
|
|
else
|
|
CID=$(echo "$REGV" | cut -d, -f5)
|
|
fi
|
|
CIDL=$(printf "%08X" 0x$CID)
|
|
RNC=${CIDL:1:5}
|
|
RNC=$RNC" ($(printf "%d" 0x$RNC))"
|
|
CID=${CIDL:6:2}
|
|
CID="Short $(printf "%X" 0x$CID) ($(printf "%d" 0x$CID)), Long $(printf "%X" 0x$CIDL) ($(printf "%d" 0x$CIDL))"
|
|
|
|
else
|
|
REGV=$(echo "$OX" | grep -o "+CREG:2,[0-9],[A-F0-9]\{2,4\},[A-F0-9]\{2,8\}")
|
|
if [ -n "$REGV" ]; then
|
|
LAC=$(echo "$REGV" | cut -d, -f3)
|
|
CID=$(echo "$REGV" | cut -d, -f4)
|
|
if [ ${#CID} -gt 4 ]; then
|
|
LAC=$(printf "%04X" 0x$LAC)" ($(printf "%d" 0x$LAC))"
|
|
CIDL=$(printf "%08X" 0x$CID)
|
|
RNC=${CIDL:1:3}
|
|
CID=${CIDL:4:4}
|
|
CID="Short $(printf "%X" 0x$CID) ($(printf "%d" 0x$CID)), Long $(printf "%X" 0x$CIDL) ($(printf "%d" 0x$CIDL))"
|
|
else
|
|
LAC=""
|
|
fi
|
|
else
|
|
LAC=""
|
|
fi
|
|
fi
|
|
REGSTAT=$(echo "$REGV" | cut -d, -f2)
|
|
if [ "$REGSTAT" == "5" -a "$COPS" != "-" ]; then
|
|
COPS_MNC=$COPS_MNC" (Roaming)"
|
|
fi
|
|
if [ -n "$CID" -a -n "$CID5" ] && [ "$RAT" == "13" -o "$RAT" == "10" ]; then
|
|
LAC="4G $LAC, 5G $LAC5"
|
|
CID="4G $CID<br />5G $CID5"
|
|
RNC="4G $RNC, 5G $RNC5"
|
|
elif [ -n "$CID5" ]; then
|
|
LAC=$LAC5
|
|
CID=$CID5
|
|
RNC=$RNC5
|
|
fi
|
|
if [ -z "$LAC" ]; then
|
|
LAC="-"
|
|
CID="-"
|
|
RNC="-"
|
|
fi
|
|
}
|
|
SIMCOM_SIMINFO()
|
|
{
|
|
debug "Quectel_SIMINFO"
|
|
# 获取IMEI
|
|
IMEI=$( sh modem_at.sh $at_port "AT+CGSN" | sed -n '2p' )
|
|
# 获取IMSI
|
|
IMSI=$( sh modem_at.sh $at_port "AT+CIMI" | sed -n '2p' )
|
|
# 获取ICCID
|
|
ICCID=$( sh modem_at.sh $at_port "AT+ICCID" | grep -o "+ICCID:[ ]*[-0-9]\+" | grep -o "[-0-9]\{1,4\}" )
|
|
# 获取电话号码
|
|
phone=$( sh modem_at.sh $at_port "AT+CNUM" | grep "+CNUM:" )
|
|
}
|
|
#simcom查找基站AT
|
|
get_simcom_data()
|
|
{
|
|
debug "get simcom data"
|
|
#设置AT串口
|
|
at_port=$1
|
|
|
|
All_CSQ
|
|
SIMCOM_SIMINFO
|
|
SIMCOM_Cellinfo
|
|
|
|
#温度
|
|
OX=$( sh modem_at.sh $at_port "AT+CPMUTEMP")
|
|
TEMP=$(echo "$OX" | grep -o "+CPMUTEMP:[ ]*[-0-9]\+" | grep -o "[-0-9]\{1,4\}")
|
|
if [ -n "$TEMP" ]; then
|
|
TEMP=$(echo $TEMP)$(printf "\xc2\xb0")"C"
|
|
fi
|
|
|
|
|
|
#基站信息
|
|
OX=$( sh modem_at.sh $at_port "AT+CPSI?")
|
|
rec=$(echo "$OX" | grep "+CPSI:")
|
|
w=$(echo $rec |grep "NO SERVICE"| wc -l)
|
|
if [ $w -ge 1 ];then
|
|
debug "NO SERVICE"
|
|
return
|
|
fi
|
|
w=$(echo $rec |grep "NR5G_"| wc -l)
|
|
if [ $w -ge 1 ];then
|
|
|
|
w=$(echo $rec |grep "32768"| wc -l)
|
|
if [ $w -ge 1 ];then
|
|
debug "-32768"
|
|
return
|
|
fi
|
|
|
|
debug "$rec"
|
|
rec1=${rec##*+CPSI:}
|
|
#echo "$rec1"
|
|
MODE="${rec1%%,*}" # MODE="NR5G"
|
|
rect1=${rec1#*,}
|
|
rect1s="${rect1%%,*}" #Online
|
|
rect2=${rect1#*,}
|
|
rect2s="${rect2%%,*}" #460-11
|
|
rect3=${rect2#*,}
|
|
rect3s="${rect3%%,*}" #0xCFA102
|
|
rect4=${rect3#*,}
|
|
rect4s="${rect4%%,*}" #55744245764
|
|
rect5=${rect4#*,}
|
|
rect5s="${rect5%%,*}" #196
|
|
rect6=${rect5#*,}
|
|
rect6s="${rect6%%,*}" #NR5G_BAND78
|
|
rect7=${rect6#*,}
|
|
rect7s="${rect7%%,*}" #627264
|
|
rect8=${rect7#*,}
|
|
rect8s="${rect8%%,*}" #-940
|
|
rect9=${rect8#*,}
|
|
rect9s="${rect9%%,*}" #-110
|
|
# "${rec1##*,}" #最后一位
|
|
rect10=${rect9#*,}
|
|
rect10s="${rect10%%,*}" #最后一位
|
|
PCI=$rect5s
|
|
LBAND="n"$(echo $rect6s | cut -d, -f0 | grep -o "BAND[0-9]\{1,3\}" | grep -o "[0-9]\+")
|
|
CHANNEL=$rect7s
|
|
RSCP=$(($(echo $rect8s | cut -d, -f0) / 10))
|
|
ECIO=$(($(echo $rect9s | cut -d, -f0) / 10))
|
|
if [ "$CSQ_PER" = "-" ]; then
|
|
CSQ_PER=$((100 - (($RSCP + 31) * 100/-125)))"%"
|
|
fi
|
|
SINR=$(($(echo $rect10s | cut -d, -f0) / 10))" dB"
|
|
fi
|
|
w=$(echo $rec |grep "LTE"|grep "EUTRAN"| wc -l)
|
|
if [ $w -ge 1 ];then
|
|
rec1=${rec#*EUTRAN-}
|
|
lte_band=${rec1%%,*} #EUTRAN-BAND
|
|
rec1=${rec1#*,}
|
|
rec1=${rec1#*,}
|
|
rec1=${rec1#*,}
|
|
rec1=${rec1#*,}
|
|
#rec1=${rec1#*,}
|
|
rec1=${rec1#*,}
|
|
lte_rssi=${rec1%%,*} #LTE_RSSI
|
|
lte_rssi=`expr $lte_rssi / 10` #LTE_RSSI
|
|
debug "LTE_BAND=$lte_band LTE_RSSI=$lte_rssi"
|
|
if [ $rssi == 0 ];then
|
|
rssi=$lte_rssi
|
|
fi
|
|
fi
|
|
w=$(echo $rec |grep "WCDMA"| wc -l)
|
|
if [ $w -ge 1 ];then
|
|
w=$(echo $rec |grep "UNKNOWN"|wc -l)
|
|
if [ $w -ge 1 ];then
|
|
debug "UNKNOWN BAND"
|
|
return
|
|
fi
|
|
fi
|
|
|
|
#CNMP
|
|
OX=$( sh modem_at.sh $at_port "AT+CNMP?")
|
|
CNMP=$(echo "$OX" | grep -o "+CNMP:[ ]*[0-9]\{1,3\}" | grep -o "[0-9]\{1,3\}")
|
|
if [ -n "$CNMP" ]; then
|
|
case $CNMP in
|
|
"2"|"55" )
|
|
NETMODE="1" ;;
|
|
"13" )
|
|
NETMODE="3" ;;
|
|
"14" )
|
|
NETMODE="5" ;;
|
|
"38" )
|
|
NETMODE="7" ;;
|
|
"71" )
|
|
NETMODE="9" ;;
|
|
"109" )
|
|
NETMODE="8" ;;
|
|
* )
|
|
NETMODE="0" ;;
|
|
esac
|
|
fi
|
|
|
|
# CMGRMI 信息
|
|
OX=$( sh modem_at.sh $at_port "AT+CMGRMI=4")
|
|
CAINFO=$(echo "$OX" | grep -o "$REGXz" | tr ' ' ':')
|
|
if [ -n "$CAINFO" ]; then
|
|
for CASV in $(echo "$CAINFO"); do
|
|
LBAND=$LBAND"<br />B"$(echo "$CASV" | cut -d, -f4)
|
|
BW=$(echo "$CASV" | cut -d, -f5)
|
|
decode_bw
|
|
LBAND=$LBAND" (CA, Bandwidth $BW MHz)"
|
|
CHANNEL="$CHANNEL, "$(echo "$CASV" | cut -d, -f2)
|
|
PCI="$PCI, "$(echo "$CASV" | cut -d, -f7)
|
|
done
|
|
fi
|
|
|
|
}
|