勤工儉學(xué)
deep throat
級(jí)別: 論壇先鋒
精華主題: 0
發(fā)帖數(shù)量: 188 個(gè)
工控威望: 1567 點(diǎn)
下載積分: 5955 分
在線時(shí)間: 120(小時(shí))
注冊時(shí)間: 2016-03-10
最后登錄: 2024-09-27
查看勤工儉學(xué)的 主題 / 回貼
樓主  發(fā)表于: 2020-03-22 12:25
rs2指令,通道2,參數(shù)設(shè)置如下圖。


plc與電腦通信,數(shù)據(jù)發(fā)送正常,接收也正常。
但是如果電腦沒有發(fā)送數(shù)據(jù)的話,plc通信超時(shí)標(biāo)志位不會(huì)接通。哪怕是一頓午飯的時(shí)間,依然沒有通信超時(shí)。
中午飯后發(fā)現(xiàn)沒有通信超時(shí),我嘗試從電腦發(fā)送一段數(shù)據(jù)給plc,plc接收了,完成一次發(fā)送接收。
我查看手冊,手冊里部分內(nèi)容如下。
“當(dāng)接收數(shù)據(jù)中途中斷時(shí),從這一刻開始,如果經(jīng)過了超時(shí)時(shí)間設(shè)定中的時(shí)間,卻依然沒有收到下一個(gè)數(shù)據(jù),則通信超時(shí)判定標(biāo)志位置ON!
是不是數(shù)據(jù)發(fā)送結(jié)束后,并沒有進(jìn)入”數(shù)據(jù)接收“的狀態(tài),要有數(shù)據(jù)或著其他什么東西來觸發(fā)接收。
所以沒有搞明白為什么通信超時(shí)不起作用。
先謝謝各位大神了。
勤工儉學(xué)
deep throat
級(jí)別: 論壇先鋒
精華主題: 0
發(fā)帖數(shù)量: 188 個(gè)
工控威望: 1567 點(diǎn)
下載積分: 5955 分
在線時(shí)間: 120(小時(shí))
注冊時(shí)間: 2016-03-10
最后登錄: 2024-09-27
查看勤工儉學(xué)的 主題 / 回貼
1樓  發(fā)表于: 2020-03-23 09:42
引用
引用第1樓ntbigcg于2020-03-23 07:44發(fā)表的  :
這個(gè)有點(diǎn)復(fù)雜了,1、你PLC里用的是什么方式發(fā)送數(shù)據(jù)的,用RS?如果用了,就會(huì)一直在發(fā)送接收,除非指令不發(fā)送接收。你如果加了超時(shí)判定標(biāo)志斷開了發(fā)送接收,那你得有程序來恢復(fù)發(fā)送接收。2、如果你沒用RS,而是用上位機(jī),那上位機(jī)程序里判斷超時(shí)設(shè)置后有沒有用恢復(fù)通訊功能?還有要檢查上位機(jī)的每次發(fā)送接收之間有沒有加延時(shí)防止通訊來不及反應(yīng)導(dǎo)致的通訊錯(cuò)誤,通訊錯(cuò)誤就會(huì)發(fā)生超時(shí)。
從問題來看,你是用了RS的,你用RS發(fā)送的時(shí)候與上位機(jī)怎樣協(xié)商的,是不是需要上位機(jī)回發(fā)數(shù)據(jù),如果有回發(fā),你PLC里有沒有等回發(fā)結(jié)束再給上位機(jī)發(fā)送,如果沒有加這個(gè)判斷,很容易發(fā)生錯(cuò)誤的,一發(fā)生錯(cuò)誤通訊就死掉了。

先謝謝你的回帖~
用的是rs2指令和電腦進(jìn)行通信的,F(xiàn)在是plc送出數(shù)據(jù)后,等電腦回發(fā)數(shù)據(jù),這樣完成一次簡單的通信。昨天發(fā)現(xiàn)電腦沒有回發(fā)數(shù)據(jù),plc這邊就一直等待電腦回發(fā),沒有通信超時(shí)。我想是不是某個(gè)參數(shù)沒有設(shè)置好,造成通信超時(shí)沒有起作用。
勤工儉學(xué)
deep throat
級(jí)別: 論壇先鋒
精華主題: 0
發(fā)帖數(shù)量: 188 個(gè)
工控威望: 1567 點(diǎn)
下載積分: 5955 分
在線時(shí)間: 120(小時(shí))
注冊時(shí)間: 2016-03-10
最后登錄: 2024-09-27
查看勤工儉學(xué)的 主題 / 回貼
2樓  發(fā)表于: 2020-03-23 15:00
引用
引用第3樓無良!于2020-03-23 12:11發(fā)表的  :
沒用過三菱。。。
PLC發(fā)出數(shù)據(jù)而沒有接受數(shù)據(jù),我認(rèn)為有兩種情況
1.你發(fā)送的格式,類似報(bào)文那樣,校驗(yàn)之類的對(duì)不對(duì)?
2.PLC發(fā)給上位機(jī),上位機(jī)有沒有收到數(shù)據(jù)會(huì)自動(dòng)返回?cái)?shù)據(jù)給下位機(jī),還是說要手動(dòng)用上位機(jī)給下位機(jī)發(fā)送一串?dāng)?shù)據(jù),這樣才能形成一個(gè)發(fā)送與接受的過程

謝謝啦~
報(bào)文格式以及校驗(yàn)是沒有問題的。現(xiàn)在主要是plc這邊的通信超時(shí)功能不起作用。標(biāo)志位m8429沒有動(dòng)作。
勤工儉學(xué)
deep throat
級(jí)別: 論壇先鋒
精華主題: 0
發(fā)帖數(shù)量: 188 個(gè)
工控威望: 1567 點(diǎn)
下載積分: 5955 分
在線時(shí)間: 120(小時(shí))
注冊時(shí)間: 2016-03-10
最后登錄: 2024-09-27
查看勤工儉學(xué)的 主題 / 回貼
3樓  發(fā)表于: 2020-03-30 18:35
引用
引用第5樓無良!!于2020-03-24 21:34發(fā)表的  :
這個(gè)通訊超時(shí)功能,是不是用在只發(fā)不收時(shí)的情況?
你完成一次通訊,說明沒有錯(cuò)誤

是的,只用在只發(fā)不收的情況。我是在無意中發(fā)現(xiàn)這個(gè)情況。
勤工儉學(xué)
deep throat
級(jí)別: 論壇先鋒
精華主題: 0
發(fā)帖數(shù)量: 188 個(gè)
工控威望: 1567 點(diǎn)
下載積分: 5955 分
在線時(shí)間: 120(小時(shí))
注冊時(shí)間: 2016-03-10
最后登錄: 2024-09-27
查看勤工儉學(xué)的 主題 / 回貼
4樓  發(fā)表于: 2020-03-30 18:42
我仔細(xì)看了手冊,在rs2指令發(fā)送數(shù)據(jù)后,不會(huì)馬上進(jìn)入數(shù)據(jù)接收狀態(tài)。
手冊里有一段話,如下。
執(zhí)行了RS2指令后, 變?yōu)榈却邮諣顟B(tài)。 從連接的設(shè)備接收數(shù)據(jù), 當(dāng)接收數(shù)據(jù)結(jié)束時(shí), 接收結(jié)束標(biāo)志位置ON。
在等待接收狀態(tài)下接收到數(shù)據(jù)后, 數(shù)據(jù)的接收就開始了。
數(shù)據(jù)接收開始后, 以中斷方式保存接收數(shù)據(jù), 而與運(yùn)算周期無關(guān)。
但是, 當(dāng)在通信格式中指定了報(bào)頭時(shí), 連續(xù)接收到報(bào)頭中設(shè)定的代碼時(shí), 接收才開始。 除報(bào)頭以外的接收數(shù)據(jù)被保存。
這段話說明有在數(shù)據(jù)接收之前有一個(gè)狀態(tài),是等待接收狀態(tài)。這個(gè)等待狀態(tài)需要接收到數(shù)據(jù)后才會(huì)切換到接收中的狀態(tài)。所以在等待接收狀態(tài)中是不會(huì)產(chǎn)生通信超時(shí)的。通信超時(shí)產(chǎn)生于數(shù)據(jù)接收的過程中。
不知道我的理解對(duì)不對(duì)。