==AM3352、STM32通讯协议== *通讯数据简单说明:在开机后,AM3352在无动作操作情况时,每30秒发送心跳包到STM32,证明AM3352正常待机状态,STM32无需应答; *在工作状态下,每1秒STM32将采集到的AD数据等数据发送给AM3352,AM3352无需应答; *在工作状态下,AM3352发送控制命令数据到STM32,STM32需要有应答,未收到应答需要重新发送; ====物理层协议==== *通过串口通讯,9600波特率,校验位无,数据位8位,停止位1位 =====帧格式表===== {| class="wikitable sortable" |- ! 起始位 !! 数据位 !! 校验位置 !! 结束位置 |- |0xA5,一个字节长度||见数据位表,变长||数据位异或校验,一个字节长度||0x5A,一个字节长度 |} =====数据位表===== {| class="wikitable sortable" |- ! 数据来源地址 !! 目的地址 !! 数据长度 !! 数据命令以及数据内容 |- |0x01表示第一块CPU板,0x02表示第二块CPU板,0x03表示第三块CPU板;
0x81表示第一块STM32板,0x82表示第二块STM32电路板,0x83表示第二块STM32电路板,一个字节||0x01表示第一块CPU板,0x02表示第二块CPU板,0x03表示第三块CPU板;
0x81表示第一块STM32板,0x82表示第二块STM32电路板,0x83表示第二块STM32电路板;
0x80表示目的地址是广播给所有的CPU电路板,0xfe表示目的地址是所有的STM32电路板,0xff表示广播给系统中所有设备,其他地址备用,一个字节长度||数据命令以及数据内容部分数据长度,两个字节,高位在前||见数据命令以及数据内容表,'''是否需要回复'''是数据内容最后一个字节,变长 |} =====数据命令以及数据内容表===== {| class="wikitable sortable" |- ! 命令序号 !! 命令内容 !! 是否需要回复!! 备注 |- |1,STM32主动上传状态(12寸没有这个命令,7寸、5寸、4.3寸有这个命令)||见'''STM32上传状态表'''||0表示无需返回,1表示需要返回|| |- |2,335X应答STM32主动上传状态||数据正常应答0x00,错误应答0x01,一个字节长度||0表示无需返回|| |- |3,STM32主动上传软件版本||例如,"HM70.A8.01",10个字节长度||0表示无需返回,1表示需要返回|| |- |4,335X应答STM32主动上传软件版本||数据正常应答0x00,错误应答0x01,一个字节长度||0表示无需返回|| |- |5,STM32主动上传硬件版本||例如,"HMHD70.A8",9个字节长度||0表示无需返回,1表示需要返回|| |- |6,335X应答STM32主动上传硬件版本||数据正常应答0x00,错误应答0x01,一个字节长度||0表示无需返回|| |- |7,335X主动发送控制命令给STM32||见'''335X控制命令表'''||0表示无需返回,1表示需要返回|| |- |8,STM32应答335X主动发送控制命令||数据正常应答0x00,错误应答0x01,一个字节长度||0表示无需返回|| |- |9,335X读取STM32硬件版本号||无||0表示无需返回,1表示需要返回|| |- |10,STM32回复硬件版本号||例如,"HMHD70.A8",9个字节长度||0表示无需返回|| |- |11,335X读取STM32软件版本号||无||0表示无需返回,1表示需要返回|| |- |12,STM32回复软件版本号||例如,"HM70.A8.01",10个字节长度||0表示无需返回|| |- |13,335X提出升级STM32代码('''新增加实现''')||无||0表示无需返回,1表示需要返回|| |- |14,STM32回复335X提出升级STM32代码||数据正常应答0x00(STM32进入升级状态),错误应答0x01,一个字节长度||0表示无需返回|| |- |15,335X发送强行结束升级命令('''新增加实现''')||无 ||0表示无需返回,1表示需要返回|| |- |16,STM32应答|| 数据正常应答0x00,错误应答0x01,一个字节长度||0表示无需返回|| |- |17,335X发送代码数据长度给STM32('''新增加实现''')||4个字节长度,高位在前,低位在后||0表示无需返回,1表示需要返回|| |- |18,STM32应答335X发送代码数据长度给STM32||数据正常应答0x00,错误应答0x01,一个字节长度||0表示无需返回|| |- |19,335X发送代码数据给STM32('''新增加实现''')||见'''335X发送代码数据给STM32数据内容表'''||0表示无需返回,1表示需要返回|| |- |20,STM32应答335X发送代码数据给STM32||'''STM32应答335X发送代码数据给STM32表'''||0表示无需返回|| |- |21,335X发送数据升级完毕('''新增加实现''')||无||0表示无需返回,1表示需要返回|| |- |22,STM32应答335X发送数据升级完毕||数据正常应答0x00,错误应答0x01,一个字节长度||0表示无需返回||335X收 STM32升级完毕 应答OK后,置GPIO1_18 为高电平(不置高电平,在STM32升级过程中,335X会掉电) |- |23,STM32主动上报升级完成命令||升级是否成功标志,1个字节(0,STM32升级成功,1,STM32升级未成功),当前软件版本号(例如,"HM70.A8.01",10个字节长度)||1表示无需返回|| |- |24,335X应答升级||无||0表示无需返回||335X收 STM32升级完毕 应答OK后,置GPIO1_18 为低电平(不置低电平,在STM32不能关掉335X 的电。GPIO1_18 只是在335X发送STM32 升级数据完成到STM32升级成功这段时间内高电平,其他时间均低电平) |- |25,STM32上传按键事件||0,按键按下,1,按键释放||0表示无需返回,1表示需要返回|| |- |26,335X应答STM32上传按键事件||数据正常应答0x00,错误应答0x01,一个字节长度||0表示无需返回|| |- |27,335X设置关机J25延时时间|| 延时时间,单位10秒(默认时长10分钟,此数据STM32不保存,SS5X关机前,需要设置此时间)||0表示无需返回,1表示需要返回|| |- |28,STM32应答||数据正常应答0x00,错误应答0x01,一个字节长度||0表示无需返回|| |- |29,335X发生扫码成功|| ||0表示无需返回,1表示需要返回|| |- |30,STM32应答||数据正常应答0x00,错误应答0x01,一个字节长度||0表示无需返回|| |} =====STM32上传状态表(7寸)===== {| class="wikitable sortable" |- ! 状态数据!! 说明 |- |0x70,一个字节||表示7寸平板电脑 |- |0xXX 0xXX 2个字节||A路PT100电阻ADC值(正常使用路)(低位在前)。STM32 PA0。R = 660 /v - 202.25;v = (3.3 * Adc)/4096;Adc 值为STM32上传ADC值,通过ADC值计算v值,在通过v值计算v1值,再计算R值。对过R值对照PT100阻值表查询温度值 |- |0xXX 0xXX 2个字节||水箱水位计温度ADC值(低位在前),STM32 PA1 |- |0xXX 0xXX 2个字节||氢气检测传感器ADC值(低位在前),STM32 PA2.'''GPIO3_15 需要低电平氢气检查ADC值有效,GPIO3_15状态下 ADC值无意义''' |- |0xXX 0xXX 2个字节||雾化器温度传感器ADC值(低位在前),STM32 PA3 |- |0xXX 0xXX 2个字节||风扇马达电磁阀电流抽样(低位在前),STM32 PA4 |- |0xXX 0xXX 2个字节||'''感应式雾化器水位计温度传感器ADC值,低位在前,J10第5PIN,STM32 PC5''' |- |0xXX 1个字节|| 备用 |- |0xXX 0xXX2个字节|| 表示散热器PWM调速风扇1转速,低位在前,高位在后,板子J41; |- |0xXX 1个字节|| 备用 |- |0xXX 0xXX2个字节|| 表示散热器PWM调速风扇2转速,低位在前,高位在后,板子J42; |- |0xXX 1个字节|| 感应式雾化器水位计接口。0000 00XXB,最低位水位低GPIO状态,第二位水位高GPIO状态('''水位计潓美生产,状态表示由潓美定义''')),J10接口 |- |0xXX 1个字节|| 湿化杯电容式水位计状态。0000 XXXXB,最低为表示低水位GPIO状态,第二位表示中水位GPIO状态,第三位表示高水位GPIO状态,第4位表示超高水位GPIO状态。('''水位计潓美生产,状态表示由潓美定义'''),J49 |- |0xXX 1个字节|| 注水口盖GPIO状态。0表示低电平,1表示高电平,其他无效。状态惠美定义。J47 |- |0xXX 1个字节|| 氢水杯水位状态。0000 00XXB,最低为表示氢水杯水位高状态,第二位表示氢水杯水位低状态。 |- |0xXX 1个字节|| '''氢气浓度周期小于等于410时,此值无效。氢气浓度周期大于等于410时,表示氢气浓度GPIO状态,0表示低电平,1表示高电平。(J15连接器 1PIN脚状态)''' |- |0xXX 2个字节|| 氢气浓度周期,单位ms,低位在前 |- |0xXX 1个字节|| 备用 |- |0xXX 1个字节|| 备用 |- |0xXX 1个字节|| 备用 |- |0xXX 1个字节|| 备用 |- |0xXX 1个字节|| '''新增,,0表示非220V上电开机,1表示220V上电开机 ''' |- |0xXX 1个字节|| 按键GPIO状态上报,GPIO状态为0时,上报0xA0;GPIO状态为1时,上报状态为0xA1;GPIO状态为没有采集到有效数据时,上报状态为0xA2; |} =====335X控制命令表===== {| class="wikitable sortable" |- ! 控制命令 !! 说明 |- |0xXX 一个字节|| 主机开启关闭标识 0x00 表示335X主机正常工作,0x01表示335X 主机将关闭。STM32收到关闭命令后1S关闭CH2电源,2S后关闭335X电源 |- |0xXX 一个字节|| 散热器PWM调速风扇1控制PWM,0 到 100,对应PWM 的0% 到 100%。'''GPIO0_12控制风扇打开关闭,低电平风扇打开''' |- |0xXX 一个字节|| 散热器PWM调速风扇2控制PWM,0 到 100,对应PWM 的0% 到 100%。'''GPIO0_7控制风扇打开关闭,低电平风扇打开''' |- |0xXX 一个字节|| 雾化量控制,0 到 100.'''潓美有两种雾化器,一种雾化器,0时雾化量最大,一种雾化器0时雾化量最小''' |- |0xXX 一个字节|| 电磁阀3(J25)控制标识 0x00 标识关闭电磁阀3,0x01打开电磁阀3 |- |0xXX 一个字节|| LED效果灯控制 0x01或0x00.0时STM32控制LED灯GPIO为低电平,1时STM32控制LED灯GPIO为高电平。'''LED板子为潓美设计,高电平LED灯亮''' |- |0xXX 一个字节|| 2,锁住清水杯,PC0 10ms方波;1,释放清水杯,PC0 20ms方波,其他数据,无10ms,20ms方波 |- |0xXX 一个字节|| 2,氢气浓度超标,50ms方波,1,氢气浓度未超标,60ms方波,其他,氢气浓度不超标,无50ms,60ms方波。 |- |0xXX 一个字节|| 备用 |- |0xXX 一个字节|| 备用 |- |0xXX 一个字节|| 备用 |- |0xXX 一个字节|| 备用 |- |0xXX 一个字节|| 备用 |- |0xXX 一个字节|| 备用 |- |0xXX 一个字节|| 备用 |- |0xXX 一个字节|| 0xA1,关闭看门狗;0xA2,打开看门狗。(12分钟没有收到控制命令,重启335X功能) |} =====335X发送代码数据给STM32数据内容表===== {| class="wikitable sortable" |- ! 代码包序号 !! 代码数据 !! 校验 |- |0x0001,两个字节,高位在前,表示第一包数据,依次递增||代码数据,256个字节,不够256字节补充0xff||代码数据位(256个字节)CRC16校验,两个字节长度,高位在前,低位在后 |} =====STM32应答335X发送代码数据给STM32表===== {| class="wikitable sortable" |- ! 代码包序号 !! 应答码 |- |0x0001,两个字节,高位在前,表示第一包数据,依次递增||0x00表示数据正常,0x01表示错误 |} ==上位机和测试底板STM32通讯协议== *在工作状态下,每1秒STM32将采集到的数据发送给上位机,上位机无需应答; *数据传输格式采用大端模式; ====物理层协议==== *通过串口通讯,9600波特率,校验位无,数据位8位,停止位1位 =====帧格式表===== {| class="wikitable sortable" |- ! 起始位 !! 数据位 !! 校验位置 !! 结束位置 |- |0xA5,一个字节长度||见数据位表,变长||数据位异或校验,一个字节长度||0x5A,一个字节长度 |} =====数据位表===== {| class="wikitable sortable" |- ! 数据来源地址 !! 目的地址 !! 数据长度 !! 数据命令以及数据内容 |- |0xa0表示上位机,0xb0表示惠美7寸A8版本平板,0xb1表示惠美7寸A8版本测试底板,如测试底板发送给上位机则来源地址为0xb1,目的地址为0xa0||0xa0表示上位机,0xb0表示惠美7寸A8版本平板,0xb1表示惠美7寸A8版本测试底板,其他地址备用,一个字节长度||数据命令以及数据内容部分数据长度,两个字节,高位在前||见数据命令以及数据内容表,变长 |} {| class="wikitable sortable" |- ! 命令序号 !! 命令内容 !! 是否需要回复!! 备注 |- |101,生产测试指令, 上位机->测试底板STM32||见'''生产测试数据命令以及数据内容表'''||0表示无需返回,1表示需要返回|| |- |102,生产测试指令应答||数据正常应答0x00,错误应答0x01,一个字节长度||0表示无需返回|| |- |103,测试版主动上报测试版状态||见'''生产测试数据命令以及数据内容表'''||0表示无需返回,1表示需要返回|| |} =====生产测试数据命令以及数据内容表===== {| class="wikitable sortable" |- ! 标示编号 !! 命令字节 !! 测试项数量!! 测试项!!保留字!!测试项附加数据段长度!!数据段 |- |2个字节,上位机发送,STM32响应和主动上传数据时都需原样复制此编号||1个字节,详见'''命令字列表'''||1个字节||1个字节,详见'''测试项列表'''||1个字节||1个字节||可变长,测试项如只是响应,则0标示OK,1标示执行Fail |} =====生产测试命令字列表===== {| class="wikitable sortable" |- ! 命令字列表!! 说明 |- |1||设置指令, 上位机->生产测试底板STM32 |- |2||设置指令响应, 生产测试底板STM32->上位机 |- |3||表示测试底板STM32主动上传数据 |} =====生产测试项列表===== {| class="wikitable sortable" |- ! 测试项列表 !! 说明 |- |0x50|| 设置HIGH状态,全部输出口设置,状态参见设置矩阵 |- |0x51|| 设置LOW状态,全部输出口设置,状态参见设置矩阵 |} =====STM32上报接口PIN脚定义===== {| class="wikitable sortable" |- ! 接口PIN脚定义 !! 说明 J01_01_NC=1, J01_02_TXD, J01_03_RXD, J01_04_GND, J02_01_SPK_P, J02_02_SPK_N, J08_01_24VP, J08_02_24VN, J09_01_POW_P_GPIO1_16_OUT, J09_02_POW_N, J09_03_CONT_PA5_DAC_OUT, J09_04_NC, J09_05_TMP_PA3_ADC_IN, J09_06_TMP_POW_P_3V3, J10_01_POW_3V3, J10_02_LEVEL_H_PC11_IN, J10_03_LEVEL_L_PB2_IN, J10_04_GND, J10_05_TMP_PC5_ADC_IN, J10_06_TMP_POW_P_3V3_PB11, J13_01_24VP_GPIO1_24_OUT, J13_02_24VN, J15_01_PC1, J15_02_NC, J15_03_PC0_OUT, J15_04_NC, J15_05_POW_5V, J15_06_NC, J15_07_GND, J15_08_GPIO1_23_IN, J15_09_GND, J15_10_NC, J15_11_LEVEL_H_PC12_IN, J15_12_LEVEL_L_PB9_IN, J16_01_24VP_GPIO1_25_OUT, J16_02_24VN, J17_01_24VP_GPIO1_26_OUT, J17_02_24VN, J19_01_24VP_GPIO3_18_OUT, J19_02_24VN, J20_01_USB_VBUS, J20_02_DM, J20_03_DP, J20_04_GND, J21_01_GND, J21_02_GND, J21_03_5V, J21_04_5V, J21_05_GND, J21_06_GPIO1_19_OUT, J21_07_GPIO1_20_OUT, J21_08_PB1_OUT, J21_09_NC, J21_10_NC, J21_11_NC, J21_12_NC, J21_13_GPIO2_1_IN, J21_14_NC, J21_15_NC, J21_16_NC, J21_17_SCL, J21_18_SDA, J25_01_24VP_PC10_OUT, J25_02_24VN, J26_01_MP, PA0_ADC_IN, J26_02_MM, J26_03_FEEDBACK, J34_01_GND, J34_02_NC, J34_03_AIN_PA2_ADC_IN, J34_04_POW_5V, J41_01_FAN_N, J41_02_24VP_GPIO0_20_OUT, J41_03_FAN_FEEDBACK_PB10_PWM_IN, J41_04_FAN_CONT_PA8_PWM_OUT, J42_01_FAN_N, J42_02_24VP_GPIO0_7_OUT, J42_03_FAN_FEEDBACK_PC9_PWM_IN, J42_04_FAN_CONT_PC8_PWM_OUT, J45_01_LEVEL_H_GPIO1_21_IN, J45_02_GND, J45_03_LEVEL_L_GPIO1_22_IN, J45_04_GND, J45_05_TMP_PA1_ADC_IN, J45_06_POW_3V3, J46_01_POW_3V3, J46_02_PA6_IN, J46_03_SIGNAL, J46_04_GND, J47_01_POW_5V, J47_02_IO_PC4_IN, J47_03_GND, J49_01_POW_5V, J49_02_LEVEL_SH_PC2_IN, J49_03_LEVEL_H_PC3_IN, J49_04_LEVEL_M_PC6_IN, J49_05_LEVEL_L_PC7_IN, J49_06_GND, UNKOWN, |} =======CRC校验算法======= '''#'''define CRC1(crc,byte) (((crc) >> 8 ) ^ tabel[((crc) ^ (unsigned int) (byte)) & 0XFF]) CPU_INT16U const tabel[256]={ 0X0000, 0XC0C1, 0XC181, 0X0140, 0XC301, 0X03C0, 0X0280, 0XC241, 0XC601, 0X06C0, 0X0780, 0XC741, 0X0500, 0XC5C1, 0XC481, 0X0440, 0XCC01, 0X0CC0, 0X0D80, 0XCD41, 0X0F00, 0XCFC1, 0XCE81, 0X0E40, 0X0A00, 0XCAC1, 0XCB81, 0X0B40, 0XC901, 0X09C0, 0X0880, 0XC841, 0XD801, 0X18C0, 0X1980, 0XD941, 0X1B00, 0XDBC1, 0XDA81, 0X1A40, 0X1E00, 0XDEC1, 0XDF81, 0X1F40, 0XDD01, 0X1DC0, 0X1C80, 0XDC41, 0X1400, 0XD4C1, 0XD581, 0X1540, 0XD701, 0X17C0, 0X1680, 0XD641, 0XD201, 0X12C0, 0X1380, 0XD341, 0X1100, 0XD1C1, 0XD081, 0X1040, 0XF001, 0X30C0, 0X3180, 0XF141, 0X3300, 0XF3C1, 0XF281, 0X3240, 0X3600, 0XF6C1, 0XF781, 0X3740, 0XF501, 0X35C0, 0X3480, 0XF441, 0X3C00, 0XFCC1, 0XFD81, 0X3D40, 0XFF01, 0X3FC0, 0X3E80, 0XFE41, 0XFA01, 0X3AC0, 0X3B80, 0XFB41, 0X3900, 0XF9C1, 0XF881, 0X3840, 0X2800, 0XE8C1, 0XE981, 0X2940, 0XEB01, 0X2BC0, 0X2A80, 0XEA41, 0XEE01, 0X2EC0, 0X2F80, 0XEF41, 0X2D00, 0XEDC1, 0XEC81, 0X2C40, 0XE401, 0X24C0, 0X2580, 0XE541, 0X2700, 0XE7C1, 0XE681, 0X2640, 0X2200, 0XE2C1, 0XE381, 0X2340, 0XE101, 0X21C0, 0X2080, 0XE041, 0XA001, 0X60C0, 0X6180, 0XA141, 0X6300, 0XA3C1, 0XA281, 0X6240, 0X6600, 0XA6C1, 0XA781, 0X6740, 0XA501, 0X65C0, 0X6480, 0XA441, 0X6C00, 0XACC1, 0XAD81, 0X6D40, 0XAF01, 0X6FC0, 0X6E80, 0XAE41, 0XAA01, 0X6AC0, 0X6B80, 0XAB41, 0X6900, 0XA9C1, 0XA881, 0X6840, 0X7800, 0XB8C1, 0XB981, 0X7940, 0XBB01, 0X7BC0, 0X7A80, 0XBA41, 0XBE01, 0X7EC0, 0X7F80, 0XBF41, 0X7D00, 0XBDC1, 0XBC81, 0X7C40, 0XB401, 0X74C0, 0X7580, 0XB541, 0X7700, 0XB7C1, 0XB681, 0X7640, 0X7200, 0XB2C1, 0XB381, 0X7340, 0XB101, 0X71C0, 0X7080, 0XB041, 0X5000, 0X90C1, 0X9181, 0X5140, 0X9301, 0X53C0, 0X5280, 0X9241, 0X9601, 0X56C0, 0X5780, 0X9741, 0X5500, 0X95C1, 0X9481, 0X5440, 0X9C01, 0X5CC0, 0X5D80, 0X9D41, 0X5F00, 0X9FC1, 0X9E81, 0X5E40, 0X5A00, 0X9AC1, 0X9B81, 0X5B40, 0X9901, 0X59C0, 0X5880, 0X9841, 0X8801, 0X48C0, 0X4980, 0X8941, 0X4B00, 0X8BC1, 0X8A81, 0X4A40, 0X4E00, 0X8EC1, 0X8F81, 0X4F40, 0X8D01, 0X4DC0, 0X4C80, 0X8C41, 0X4400, 0X84C1, 0X8581, 0X4540, 0X8701, 0X47C0, 0X4680, 0X8641, 0X8201, 0X42C0, 0X4380, 0X8341, 0X4100, 0X81C1, 0X8081, 0X4040 }; static CPU_INT16U CalcCRC(CPU_INT08S *data, CPU_INT32S size) { CPU_INT32S i; CPU_INT16U crc = 0; for (i = 0; i < size; i++) { crc = CRC1(crc, data[i]); } return crc; } ==潓美7寸平板电脑A8版本主要问题点== ===花屏问题=== =====问题描述===== 1. 开机后或者运行一段时间后屏幕出现竖状条纹,无法正常显示,如下图: [[file:crash.png]] =====原因排查===== 1.发现U7(MP1530DM-LF-Z)输入电压有抖动,最低会下降到3.1V左右,波形如下: [[file:raw.png]] =====改善措施===== 1.输入端电容加大,C221 从22pF改到10uF,改善后波形如下: [[file:modified.png]] ===I2C问题=== =====问题描述===== 1. I2C在400KHz频率下波形和频率失真严重,概率性和台达电源通信失败,造成电源设置异常,整机现象为无法产气(GPIO52已经拉高,程序进入产气模式,但是实际台达电源没有输出,无法产气),不良波形如下: [[file:I2C_400K_DeltaPower.png]] =====原因排查===== 1.怀疑台达电源端容性负载较大或者软件有限制,平板端I2C 400K频率下的波形如下(不接台达电源,连接测试治具): [[file:I2C_400K_Nor.png]] =====改善措施===== 1.更新内核,把I2C频率降到100KHz,改善后波形如下: [[file:I2C_100K_DeltaPower.png]] ===WIFI连接问题=== =====问题描述===== 1. 经常性发生无法连接WIFI的情况 =====原因排查===== 1.连接不上的情况下发现wpa调用命令出错: 正确指令:wpa_supplicant -iwlan0 -Dwext -C/var/run/wpa_supplicant -c/var/lib/wifi.conf 出错指令:/wpa_supplicant -iwlan0 -Dwext -C/var/run/wpa_supplicant 缺少最后的wifi.conf调用 =====改善措施===== 1.程序启动时加判断wpa_suppllicant是否正确启动,如果没有则重启该进程 ===16位色问题=== AM335x平台没有内置RGB888转RGB565色抖动的功能,需要对所有应用程序用到的图像进行预处理,可以用ImageMagick程序进行处理: convert image_in.png -ordered-dither o8x8,32,64,32 image_out.png