-
Notifications
You must be signed in to change notification settings - Fork 196
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
wifinina: connect improvements #561
Conversation
Reopening since #537 will not merge until TinyGo 0.29 |
…vice reset Signed-off-by: deadprogram <[email protected]>
…ctions Signed-off-by: deadprogram <[email protected]>
…r boards like the Arduino MKR 1010 Signed-off-by: deadprogram <[email protected]>
ae3a69a
to
1a618b6
Compare
Rebased against |
// should be High or Low (the default). Set this to true | ||
// before calling Configure() for boards such as the Arduino MKR 1010, | ||
// where the reset signal needs to go high instead of low. | ||
ResetIsHigh bool |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This does look to me as a hack/workaround.
Shall we not have RESET_HIGH
and RESET_LOW
pins then instead?
Alternatively RESET_HIGH
and RESET
for backwards compatibility.
Then users can choose which pin to assign and which leave as "nopin".
And logic in Configure()
then decides which pin to use (can panic / error when both defined or none)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Another alternative: control behaviour of RESET
pin with a build tag.
Arduino MKR 1010
target could have, say, wifinina_reset_high
build tag. Next, wifinina driver has an extra file with this tag here that sets an internal flag for such behaviour.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Both sound more complicated somehow.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Second alternative is more complicated to implement perhaps, but easier and transparent to use.
To me it feels the reset pin behaviour is board/hardware specific and weird to have to think about it in the application code.
The first approach, I like it less myself, just brainstormed how can we do it differently.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We have drivers that have different behaviour for different build tags already, see https://github.com/tinygo-org/drivers/tree/release/ws2812
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, but they do more than just swap high/low for a specific pin. Adding a build tag for that seems like overkill, IMO.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The change I made seemed to me like the "simplest thing that could possibly work" to address the swap of setting high/low. Adding more code/logic just seemed like a lot extra for that.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
To me it feels the reset pin behaviour is board/hardware specific and weird to have to think about it in the application code.
It is a single line you need to add if you are using one of only a couple of specific boards. Hence why I tried to make the least intrusive change possible.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
After discussions in slack and in the light of the big upcoming refactoring in this package (netdev), it is no point to dwell on minor API changes now.
[seal of approval]
Merging to keep the progress/bug fixes moving along. Thanks everyone! |
This PR adds a few improvements for connecting the WiFiNINA.
It corrects the timing used for the RESET pins when calling
Configure()
to match other libraries.It also adds a new
ResetIsHigh
property to allow changing the behavior of the RESET pin for boards like the Arduino MKR 1010, which correct #386Lastly, it makes some changes to the various examples to make a few retry attempts when connecting to the WiFi access point, which appears to solve most of the issues when connecting especially right after flashing.
Note that this PR depends on #560 which needs to be merged first, and then this PR rebased.