Skip to content
New issue

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

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

Already on GitHub? # to your account

Library changes pin mode of A0 to INPUT #479

Open
per1234 opened this issue Jun 7, 2024 · 0 comments · May be fixed by #481
Open

Library changes pin mode of A0 to INPUT #479

per1234 opened this issue Jun 7, 2024 · 0 comments · May be fixed by #481
Labels
type: imperfection Perceived defect in any part of project

Comments

@per1234
Copy link
Contributor

per1234 commented Jun 7, 2024

Describe the problem

Under the following conditions, the library uses an analog read of pin A0 to seed the pseudorandom number generator:

  • Board does not has a built-in ECCx08 crypto chip
  • Board does not have a hardware random number generator

randomSeed(analogRead(0));

This analog read puts the pin into INPUT mode.

In addition to use as a ADC, analog pins may be used as digital output pins by setting the pin mode to OUTPUT.

🐛 If the user is using pin A0 as an output, the library will break their sketch by changing the pin mode.

To reproduce

  1. Add the following code to the setup function of an ArduinoIoTCloud sketch that calls ArduinoCloud.getInternalTime() or ArduinoCloud.update():
    pinMode(A0, OUTPUT);
  2. Add the following code to the loop function of the sketch:
    static unsigned long blinkTimestamp;
    static byte pinState;
    if (millis() - blinkTimestamp >= 1000) {
      blinkTimestamp = millis();
      if (pinState == LOW) {
        pinState = HIGH;
      } else {
        pinState = LOW;
      }
      digitalWrite(A0, pinState);
    }
  3. Upload the sketch to one of the following boards (tested with UNO R4 WiFi):
    • MKR WiFi 1010
    • NANO 33 IoT
    • Nicla Vision
    • Portenta C33
    • UNO R4 WiFi
  4. Monitor the state of pin A0 with an LED or meter.

🐛 The pin state stops toggling.

Expected behavior

Library does not interfere with user's ability to use pin A0 as an output.

- OR -

Library's impact on pin A0 is clearly documented.

Library version

d4ae0a3

Additional context

Originally reported at https://forum.arduino.cc/t/a0-pin-behavior-uno-r4-wifi/1238998

Related

Workaround

Add the following code to the loop function of your sketch:

  static bool pinModeRestored = false;  // Track state to avoid unnecessary calls to the fairly slow ArduinoCloud.connected()
  if (!pinModeRestored && ArduinoCloud.connected()) {
    pinMode(ledPin, OUTPUT);
    pinModeRestored = true;
  }
@per1234 per1234 added the type: imperfection Perceived defect in any part of project label Jun 7, 2024
# for free to join this conversation on GitHub. Already have an account? # to comment
Labels
type: imperfection Perceived defect in any part of project
Projects
None yet
Development

Successfully merging a pull request may close this issue.

1 participant