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

After Wire.requestFrom() there is no need for a timeout and no endTransmission. #10

Open
Koepel opened this issue Oct 8, 2016 · 1 comment

Comments

@Koepel
Copy link

Koepel commented Oct 8, 2016

In the functions readAccReg() and readMagReg(), there is a Wire.endTransmission() after the Wire.requestFrom(). That should not be there. The Wire.endTransmission() is only used when writing data.
It is not a big problem, but the Wire.endTransmission() will sent the sensor address to the I2C bus and the sensor will aknowledge. It does no harm, but it is unnecessary.

In the functions readAcc() and readMag(), there is a timeout after Wire.requestFrom(). That timeout is not needed. The Wire.requestFrom() waits until the I2C transmission has completely finished. After that, the received data is in a buffer in the Wire library. The Wire.available() shows how many bytes there are in that buffer.
The timeout is not needed, but in case there was a I2C bus error, it does detect that not all bytes are received and it does return with an error.

The return value of Wire.requestFrom() or the Wire.available() could be be used once to check if the correct number of bytes was received or if a bus error did occur.

@Koepel
Copy link
Author

Koepel commented Mar 29, 2018

I just noticed this pull-request: #2
A while-loop to wait for something after a Wire.requestFrom() is wrong and that was replaced with nonsense code with millis() and a timeout.
Explanation: Common-mistakes#1

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

No branches or pull requests

1 participant