==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板；<br>0x81表示第一块STM32板，0x82表示第二块STM32电路板，0x83表示第二块STM32电路板，一个字节||0x01表示第一块CPU板，0x02表示第二块CPU板，0x03表示第三块CPU板；<br>0x81表示第一块STM32板，0x82表示第二块STM32电路板，0x83表示第二块STM32电路板；<br>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程序进行处理:

<code>
convert image_in.png -ordered-dither o8x8,32,64,32 image_out.png
</code>