From 4f9415445f6d33466223f9f3ef6621986068f1be Mon Sep 17 00:00:00 2001 From: Rodrigo Garcia Date: Tue, 13 Jun 2023 10:01:22 -0300 Subject: [PATCH] Adds missing pinMode (#8312) * Adds missing pinMode The example code lacks a pinMode() to initialize the GPIO 0 (button). In Arduino Core 3.0.0, it prints an error message when trying to read a not initialized GPIO. * Update KeyboardLogout.ino Adds to keep code standard * Update KeyboardReprogram.ino Adds to keep code standard --- libraries/USB/examples/CompositeDevice/CompositeDevice.ino | 2 ++ .../USB/examples/Keyboard/KeyboardLogout/KeyboardLogout.ino | 6 ++++-- .../Keyboard/KeyboardReprogram/KeyboardReprogram.ino | 6 ++++-- 3 files changed, 10 insertions(+), 4 deletions(-) diff --git a/libraries/USB/examples/CompositeDevice/CompositeDevice.ino b/libraries/USB/examples/CompositeDevice/CompositeDevice.ino index 587720ab85e..0ad87b520ba 100644 --- a/libraries/USB/examples/CompositeDevice/CompositeDevice.ino +++ b/libraries/USB/examples/CompositeDevice/CompositeDevice.ino @@ -166,6 +166,8 @@ void setup() { HWSerial.begin(115200); HWSerial.setDebugOutput(true); + pinMode(buttonPin, INPUT_PULLUP); + USB.onEvent(usbEventCallback); USBSerial.onEvent(usbEventCallback); MSC_Update.onEvent(usbEventCallback); diff --git a/libraries/USB/examples/Keyboard/KeyboardLogout/KeyboardLogout.ino b/libraries/USB/examples/Keyboard/KeyboardLogout/KeyboardLogout.ino index b4b21180031..cb502cc39e0 100644 --- a/libraries/USB/examples/Keyboard/KeyboardLogout/KeyboardLogout.ino +++ b/libraries/USB/examples/Keyboard/KeyboardLogout/KeyboardLogout.ino @@ -41,16 +41,18 @@ USBHIDKeyboard Keyboard; // change this to match your platform: int platform = OSX; +const int buttonPin = 0; // input pin for pushbutton + void setup() { // make pin 0 an input and turn on the pull-up resistor so it goes high unless // connected to ground: - pinMode(0, INPUT_PULLUP); + pinMode(buttonPin, INPUT_PULLUP); Keyboard.begin(); USB.begin(); } void loop() { - while (digitalRead(0) == HIGH) { + while (digitalRead(buttonPin) == HIGH) { // do nothing until pin 2 goes low delay(500); } diff --git a/libraries/USB/examples/Keyboard/KeyboardReprogram/KeyboardReprogram.ino b/libraries/USB/examples/Keyboard/KeyboardReprogram/KeyboardReprogram.ino index e1a28add531..ad1af41f6b0 100644 --- a/libraries/USB/examples/Keyboard/KeyboardReprogram/KeyboardReprogram.ino +++ b/libraries/USB/examples/Keyboard/KeyboardReprogram/KeyboardReprogram.ino @@ -34,6 +34,8 @@ void loop(){} #include "USBHIDKeyboard.h" USBHIDKeyboard Keyboard; +const int buttonPin = 0; // input pin for pushbutton + // use this option for OSX. // Comment it out if using Windows or Linux: char ctrlKey = KEY_LEFT_GUI; @@ -45,14 +47,14 @@ char ctrlKey = KEY_LEFT_GUI; void setup() { // make pin 0 an input and turn on the pull-up resistor so it goes high unless // connected to ground: - pinMode(0, INPUT_PULLUP); + pinMode(buttonPin, INPUT_PULLUP); // initialize control over the keyboard: Keyboard.begin(); USB.begin(); } void loop() { - while (digitalRead(0) == HIGH) { + while (digitalRead(buttonPin) == HIGH) { // do nothing until pin 0 goes low delay(500); }