正文
1.C语言中,一个函数只能有一个返回值,若需要通过函数对函数外多个变量进行修改时,就要引入输入量为指针。如,带进位的加法运算,输入量为被加数与加数,返回值为是否进位。输入量为数值时,只能向函数输入值,不能被函数赋予值。若输入量为指针,则可以对输入量进行赋值,这就是指针的好处。
2.在用MSP430FR6972单片机时,发现烧写程序不成功。烧录软件提示MCU有问题。我就换了个好的单片机,发现还是无法烧写。然后问同事,同事建议我用万用表量量,看看下载口用到的各个引脚和单片机的引脚是否连接。在量的过程中发现,VCC和GND引脚短路,查看MCU焊接正常,无短路,便怀疑MCU旁路电容短路造成。通过排除法,找到短路的旁路电容,去掉该电容后烧写正常。
3.3.6v供电的电路板,被软件拿过去,上8v的电直接坏掉了。有了上次电容短路的经验,我这次一上来就先用万用表量下VCC和GND是否短路,发现VCC和GND没有短路,便顺手量了下VBAT和GND,结果发现VBAT和GND短路。然后就翻开原理图,查用到VBAT的地方,发现NB模组控电电源电路中,VBAT串mose管再串静电释放二级管电路中(NBVCC从mose和静电释放二极管连接处流出),mose管源极和漏极导通了,再量发现静电释放二极管导通了。把mose管和静电释放二极管去掉后,再量VBAT和GND发现不再短路。接上电源后,发现液晶屏不工作,量单片机的VCC和GND电压3.6v正常,于是推测单片机烧掉了,更换单片机。然后再上电,发现液晶可以显示,但是切屏过程中显示会乱码。检测液晶屏幕引脚焊接正常,然后用电洛铁把单片机和电路板的连接引脚再依次焊接一遍,上电后发现切屏正常。将mose管和静电释放二极管更换后,上电监控模组,入网正常。
4.使用外部IIC读写EEPROM时,最后加上写入再读出来,看看写入值是否正确的判断机制,避免其他中断打断写EEPROM的过程。
5.针对BC95和BC35NB模组,AT指令中,AT+NBAND?\r\n获取的是Band搜网顺序,而不是当前Band,真正的当前连接成功的Band要根据AT+NUESTATS\r\n,回复的指令中,找到CURRENT BAND:**,后面Band才是当前的Band。要把这个Band存储下了,下次尝试连接时,先尝试这个Band。
6.像BC25这些全网通的模组,为了实现像手机一样一插卡就可以自动识别运营商的功能,可以通过读取IMSI卡号的前几位来区分运营商。46011是电信卡,46006是联调卡,46004是移动卡。入网时,要先获取IMSI卡号,再跟据识别到的运营商去切换Band搜网顺序,在执行其他入网流程。识别运营商的流程不必每次入网都执行,只是每次上电入网时执行一次即可。
7.在设置Band搜网顺序时,要先设置AT+CFUN=0切换为飞行模式再设置Band。下发Band搜网顺序时,不要下发太多,最好能用到哪个下发哪个。比如电信发送AT+NBADN=5\r\n即可,联通发送AT+NBAND=3,8\r\n或者AT+NBAND=8,3\r\n,不要把AT+NBAND=5,8,3,20\r\n都下发。因为在搜网时,模组每搜到一个PLMN时,都会把所有设置过得Band都尝试一遍,这样的话,设置的Band越多,则搜网时间越长。
8.在做NB模组通讯时,会遇到NB模组应答字节数太长的问题。比如AT+NCONFIG?\r\n指令,应答的字节数超过了1K。比如MCU判断收到中间的某个有效字节时,就认为该指令应答成功。此时,若要直接去下发下一条指令,则有可能出现模组收不到MCU发来的指令,因为模组还有其他的字节没有往外发送完,模组是半双工的,这就会造成MCU发来的指令丢失。比较好的方法是通过延时足够长的时间,等待模组把其他的指令发送完,MCU再继续下发其他的指令。当然,也可以通过判断模组应答指令的最后一个字节去决定是否本条指令回复完毕,但这样的缺点时,要求MCU开辟的缓存足够的大,这就可能造成一定的资源浪费。
9.APN国内不需设置,按照0默认即可。但是国外的APN需要设置,这个在做出口设备时要注意。
10.CCID卡号国内是20位,而国外是19位,在做程序时,要兼容国外的19位卡号,当发现是19位卡号时,要将最后一位补成0,凑成20位,这样便于开号的存储和读取。
11.联通不同区域的****可能会出现PLMN不同的问题,故联通NB设计时,要加入PLMN可设置功能。默认的卡内PLMN是46001,在做程序时,可以设计为当PLMN为空值时,不对卡中PLMN进行设置。此时卡内的PLMN还是原来的46001,用AT+CGATT=1开始进行启动入网。当需要设置成新的PLMN(如46006)时,要通过AT+COPS=1,2+PLMN进行启动入。注意在查询是否入网成功时,无论是否设置过PLMN都要用AT+CGATT?来查询。
12.在做电信AEP平台时,要加入更新声明周期的指令,兼容电信AEP平台,这点和OC平台不一样。
13.NB入网搜网时间方面,电信只有一个频段,搜网等待时间为2分钟即可。联通有B3\B8两个频段,在搜网时等待时间要加长至5分钟。
14.NB联网成功后,不要立马发送数据指令,此时设备可能还没有在IOT平台上注册成功,直接发数据指令会出现ER513,要用AT+NMSTATUS?查询是否注册成功,等待注册成功后再发送数据。循环使用AT+NMSTATUS?查询的等待时间为30s。
15.在使用外部EEPROM时,不要用单片机IO直接给EEPROM的VCC通过电源,由于单片机IO驱动能力不足,可能出现EEPROM工作不稳定的情况。
16.输入检测类IO,在使用时打开内部上下拉,在不进行检测时,要关闭上下拉,这样可以降低整体功耗。
17.在串口通讯试,使用了9600的波特率,进行通讯,并且每发送完一个字节要延时2ms,这样是为了提高串口通讯成功率,将字节与字节间稳定的隔开,不会影响波特率,因为有起始位和结束位,从起始位开始,按照波特率进行字节的存取。从结束位开始,停止存取数据。
18.#pragma location用于定义绝对地址的单个全局或静态变量或数据对象。变量或数据对象必须声明为__no_init或const。这对于必须位于固定地址的个体数据对象非常有用,例如变量、带有外部或内部接口的数据对象或增加的硬件表项。
#pragma location=0xfa00
const char a=1;
表示把a存到0xfa00。
19.在每次下载STC程序时,要先选择对内部IRC晶振频率,保证内部IRC晶振和程序中主晶振保持一致。否则,程序会异常运行。
20.C语言中,全局变量不赋初值,会被初始化为0。局部变量不赋初值,会被初始化随机数。
21.CRC16校验时,若低字节在前,判断CRC是否正确有两种方法,一是将数据域进行CRC16计算,让结果与传输帧中的CRC16进行判断看是否一致;另一种是将数据域和传输帧中的CRC16一起做CRC16校验,若得到的校验值为0,则说明传输的CRC16和实际接收到的数据帧计算后得到的一致。但是注意,第二种方法要求校验值是低字节在前。
22.在现场测试信号时,一般需要注意到以下几个变量:
地点,便于后期分析测试位置;信噪比SINR,覆盖等级,灵敏度RSRP,小区PCI,频点EHRFN,ID。若在一同一个地方,收到不同的PCI,而且频点EHRFN一样,这就需要考虑同频干扰对传输的影响了。
23.在做红外收发串口时,要记得发送中断中要把串口接收中断关下,因为红外接收管和发送管离得太近,要是不关串口接收中断,则会受到发送的数据。
24.*p++:等同于:*p; p += 1;【注意】是运算后p再加1,而不是p所指向的变量*p再加1。