Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Wait for correct response id #77

Open
wants to merge 2 commits into
base: master
Choose a base branch
from
Open

Conversation

decadenza
Copy link

Due to noise/interference on the serial line (separate problem), I was having errors like:

error="modbus: response slave id '69' does not match request '1'"
error="modbus: response slave id '48' does not match request '1'"

And so on.

My system has only one slave with id 1.
I came across this issue on a different repository.
image

As I understand it, Modbus protocol specifies that master should manage the "unexpected slave" and wait for the correct one for the specified timeout setting.

Checking the code I realised that the client was not waiting for the correct timeout before throwing the error.

With this simple change my error rate has reduced, and when it happens the correct "timeout" error is given.

@decadenza
Copy link
Author

Added error value err = fmt.Errorf("modbus: response timeout")

Copy link
Contributor

@frzifus frzifus left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does it make sense to limit the amount of retries and to introduce a break between the retries?

@decadenza
Copy link
Author

@frzifus Yes, that is what I was doing as a sub-optimal measure. But I think it would be preferable to actually follow the specifications. The problem arises when the traffic is high. Any thoughts?

@hnicolaysen
Copy link
Contributor

Hi @decadenza!

Please excuse the late reply here, I hope you're still around!
First of all, thank you for your contribution!

I really like your suggestion here, but I have a question left:
The automaton above shows a retry for the response reception. In your requested change, you also propose to re-send the request if the first response was not matching. Is this intended?

@decadenza
Copy link
Author

Hi.
The re-send is intentional, but only until maxTime, calculated from the tcpTimeout parameter.

As an alternative, the user has to fire a re-attempt, but it looks more logical to use the timeout parameter that is already part of the library. What do you think?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants