搜索
bottom↓
回复: 20

请教:I2C上拉电阻影响静电测试结果

[复制链接]

出0入0汤圆

发表于 2022-5-17 13:58:43 | 显示全部楼层 |阅读模式


最近一款产品在做静电测试,6000V空气放电。
出现了一个诡异的事情难以解释,
上图中的I2C传感器插上去,打静电会导致单片机跑飞。
传感器拔掉就没事,这个可以解释,毕竟传感器插上去相当于天线了。

另一个我不理解的现象是,把传感器插上去,把R142,R143两个上拉电阻换成10K的也可以大大改善测试结果。
2K的时候打10次就会死,换成10K的要打40次左右才会死。
希望有懂的大佬不吝赐教。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

阿莫论坛20周年了!感谢大家的支持与爱护!!

月入3000的是反美的。收入3万是亲美的。收入30万是移民美国的。收入300万是取得绿卡后回国,教唆那些3000来反美的!

出50入4汤圆

发表于 2022-5-17 14:25:35 | 显示全部楼层
2K 再并个 100pF 电容试试

出0入0汤圆

发表于 2022-5-17 16:41:36 | 显示全部楼层
跑飞也要看是软件还是硬件引起的。如果是静电引起IIC总线错误导致软件跑飞,可以增强软件的容错性,或者增加滤波电路。如果是高压进入MCU,则要加防静电电路。

出0入8汤圆

发表于 2022-5-17 16:48:00 来自手机 | 显示全部楼层
iic总线端口加esd试试

出0入0汤圆

发表于 2022-5-17 16:55:49 | 显示全部楼层
总线那里串100欧电阻,像上面兄弟说的输入并个100PF试试

出0入0汤圆

 楼主| 发表于 2022-5-17 18:04:30 | 显示全部楼层
zhuyi25762 发表于 2022-5-17 14:25
2K 再并个 100pF 电容试试
(引用自2楼)

哥,能不能说下原理是什么,这么做是基于什么样的考虑。
板子现在已经通过测试不用修改了。我就是想不通为啥会有这个现象。

出0入0汤圆

 楼主| 发表于 2022-5-17 18:06:15 | 显示全部楼层
vuo50z 发表于 2022-5-17 16:41
跑飞也要看是软件还是硬件引起的。如果是静电引起IIC总线错误导致软件跑飞,可以增强软件的容错性,或者增 ...
(引用自3楼)

pic的单片机,用的硬件IIC,IIC总线错误会导致单片机跑飞么?软件的容错性大概有什么样的手段?望指教。

出0入0汤圆

 楼主| 发表于 2022-5-17 18:07:28 | 显示全部楼层
sfes 发表于 2022-5-17 16:48
iic总线端口加esd试试
(引用自4楼)

我现在在上海被封着,我同事在昆山测试的,开始我就跟他说串联20-100欧电阻,加5V ESD,他没干。
换上拉电阻解决了,现在我就是想不通这个原理。

出0入0汤圆

 楼主| 发表于 2022-5-17 18:07:45 | 显示全部楼层
lsfsxfljj 发表于 2022-5-17 16:55
总线那里串100欧电阻,像上面兄弟说的输入并个100PF试试
(引用自5楼)

我现在在上海被封着,我同事在昆山测试的,开始我就跟他说串联20-100欧电阻,加5V ESD,他没干。
换上拉电阻解决了,现在我就是想不通这个原理。

出0入14汤圆

发表于 2022-5-17 18:13:18 | 显示全部楼层
krguang 发表于 2022-5-17 18:07
我现在在上海被封着,我同事在昆山测试的,开始我就跟他说串联20-100欧电阻,加5V ESD,他没干。
换上拉 ...
(引用自8楼)

首先你的了解打静电的原理,然后去看看电磁场与电磁波这本书,顺便学学电子元器件的知识及原理,应该你就理解的八九不离十了

出130入20汤圆

发表于 2022-5-17 21:48:14 | 显示全部楼层
外接端口,要加上ESD器件

出50入0汤圆

发表于 2022-5-17 22:21:02 来自手机 | 显示全部楼层
上拉电阻2k太小了,10k,4.7k都可以,但10k是比较合适的。用2k试想你把io拉低时,一根io将vcc 的电流增加1.65ma,这些电流都会灌到io口。你程序跑飞很可能是原本vcc电压就被被拉低及端口电流过大,存在一个不稳定的状态。打测试只是引起跑飞的一根导火索。

出0入0汤圆

 楼主| 发表于 2022-5-17 23:02:47 | 显示全部楼层
god-father 发表于 2022-5-17 22:21
上拉电阻2k太小了,10k,4.7k都可以,但10k是比较合适的。用2k试想你把io拉低时,一根io将vcc 的电流增加1. ...
(引用自12楼)

谢谢解释,感觉很有道理

出20入128汤圆

发表于 2022-5-18 06:56:11 来自手机 | 显示全部楼层
krguang 发表于 2022-5-17 23:02
谢谢解释,感觉很有道理
(引用自13楼)

但是10k好像速度上不去吧?最近看的一个国外参考设计,上拉1.8K@3.3V

出0入91汤圆

发表于 2022-5-18 08:41:28 | 显示全部楼层
单片机复位口  的RST 并的电容再加大点,上拉电阻减小点
一般这样后 可以硬抗

出0入0汤圆

 楼主| 发表于 2022-5-18 09:30:47 | 显示全部楼层
ackyee 发表于 2022-5-18 08:41
单片机复位口  的RST 并的电容再加大点,上拉电阻减小点
一般这样后 可以硬抗 ...
(引用自15楼)

单片机没复位,是卡住了。开了看门狗才会复位。

出50入0汤圆

发表于 2022-5-18 10:31:28 | 显示全部楼层
krguang 发表于 2022-5-18 09:30
单片机没复位,是卡住了。开了看门狗才会复位。
(引用自16楼)


检查下是不是你的VCC电流供应不足

出0入0汤圆

 楼主| 发表于 2022-5-18 23:04:29 | 显示全部楼层
god-father 发表于 2022-5-18 10:31
检查下是不是你的VCC电流供应不足
(引用自17楼)

好的谢谢,我重点看看

出10入10汤圆

发表于 2022-5-19 07:56:38 | 显示全部楼层
有可能是静电造成总线数据错误,单片机在死等,卡住了。应该有通讯错误超时退出机制,退出后再次发起通讯。

出0入0汤圆

 楼主| 发表于 2022-5-19 10:16:46 | 显示全部楼层
szxszx 发表于 2022-5-19 07:56
有可能是静电造成总线数据错误,单片机在死等,卡住了。应该有通讯错误超时退出机制,退出后再次发起通讯。 ...
(引用自19楼)

谢谢回答,用的是硬件I2C,没地方控制超时退出。
读取传感器过程是这样的:
  1.         i2c_start(I2C1);
  2.         i2c_write(I2C1, SIARGO_SLAVE_ADDRESS_WRITE);

  3.         i2c_write(I2C1, SIARGO_READ_FLOW_CMD);

  4.         i2c_start(I2C1);
  5.         i2c_write(I2C1, SIARGO_SLAVE_ADDRESS_READ);

  6.         Data[0] = i2c_read(I2C1,1);
  7.         Data[1] = i2c_read(I2C1,1);
  8.         Data[2] = i2c_read(I2C1,1);
  9.         Data[3] = i2c_read(I2C1,0);  
  10.         i2c_stop(I2C1);
复制代码


这些读写函数都在单片机的头文件里。

出50入0汤圆

发表于 2022-5-19 11:16:18 | 显示全部楼层
szxszx 发表于 2022-5-19 07:56
有可能是静电造成总线数据错误,单片机在死等,卡住了。应该有通讯错误超时退出机制,退出后再次发起通讯。 ...
(引用自19楼)

I2C协议读数据的时候错误应该不会有等待的。除非是自己程序对错误数据处理的问题。
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-4-27 03:16

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表