summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authortomaszduda23 <[email protected]>2022-07-15 16:22:26 +0900
committerGitHub <[email protected]>2022-07-15 10:22:26 +0300
commit48f479286170f3cf79304d9b89dd166dec5af834 (patch)
treec99ed8dee91921c6e39127a6af2dfafb5416849d
parent4b87851119ea8b1529ac9d29a563c6823220bf46 (diff)
commented kvmd/kvmd#80 (#102)
Co-authored-by: Maxim Devaev <[email protected]>
-rw-r--r--hid/patch.py1
-rw-r--r--hid/patches/arduino-no-main.patch35
-rw-r--r--hid/src/main.cpp61
3 files changed, 51 insertions, 46 deletions
diff --git a/hid/patch.py b/hid/patch.py
index 9c253295..0d080b49 100644
--- a/hid/patch.py
+++ b/hid/patch.py
@@ -28,6 +28,7 @@ def _patch(path: str, patch_path: str) -> None:
assert exists(path)
flag_path: str = join(path, f".{basename(patch_path)}.done")
if not exists(flag_path):
+ # TODO check for failure
env.Execute(f"patch -p1 -d {path} < {patch_path}")
env.Execute(lambda *_, **__: open(flag_path, "w").close())
diff --git a/hid/patches/arduino-no-main.patch b/hid/patches/arduino-no-main.patch
index 7dc1f81c..ab10c9a8 100644
--- a/hid/patches/arduino-no-main.patch
+++ b/hid/patches/arduino-no-main.patch
@@ -1,17 +1,24 @@
-diff -u -r a/cores/arduino/main.cpp b/cores/arduino/main.cpp
---- a/cores/arduino/main.cpp 2019-05-16 15:52:01.000000000 +0300
-+++ b/cores/arduino/main.cpp 2020-11-17 18:56:01.243474508 +0300
-@@ -30,6 +30,7 @@
- void setupUSB() __attribute__((weak));
- void setupUSB() { }
+diff --git a/cores/arduino/main.cpp b/cores/arduino/main.cpp
+index 434cd40..7aba76f 100644
+--- a/cores/arduino/main.cpp
++++ b/cores/arduino/main.cpp
+@@ -36,15 +36,15 @@ int main(void)
-+/*
- int main(void)
- {
- init();
-@@ -49,4 +50,5 @@
+ initVariant();
+
+-#if defined(USBCON)
+- USBDevice.attach();
+-#endif
++// #if defined(USBCON)
++// USBDevice.attach();
++// #endif
+
+ setup();
+
+ for (;;) {
+ loop();
+- if (serialEventRun) serialEventRun();
++ // if (serialEventRun) serialEventRun();
+ }
return 0;
- }
-+*/
-
diff --git a/hid/src/main.cpp b/hid/src/main.cpp
index d02ca55c..c568d6c2 100644
--- a/hid/src/main.cpp
+++ b/hid/src/main.cpp
@@ -303,9 +303,7 @@ static void _sendResponse(uint8_t code) {
# endif
}
-int main() {
- init(); // Embedded
- initVariant(); // Arduino
+void setup() {
_initOutputs();
# ifdef AUM
@@ -314,41 +312,40 @@ int main() {
# ifdef CMD_SERIAL
CMD_SERIAL.begin(CMD_SERIAL_SPEED);
- unsigned long last = micros();
- uint8_t buffer[8];
- uint8_t index = 0;
# elif defined(CMD_SPI)
spiBegin();
# endif
+}
- while (true) {
-# ifdef AUM
- aumProxyUsbVbus();
-# endif
+void loop() {
+# ifdef AUM
+ aumProxyUsbVbus();
+# endif
- _kbd->periodic();
-
-# ifdef CMD_SERIAL
- if (CMD_SERIAL.available() > 0) {
- buffer[index] = (uint8_t)CMD_SERIAL.read();
- if (index == 7) {
- _sendResponse(_handleRequest(buffer));
- index = 0;
- } else /*if (buffer[0] == PROTO::MAGIC)*/ { // FIXME: See kvmd/kvmd#80
- last = micros();
- ++index;
- }
- } else if (index > 0) {
- if (is_micros_timed_out(last, CMD_SERIAL_TIMEOUT)) {
- _sendResponse(PROTO::RESP::TIMEOUT_ERROR);
- index = 0;
- }
+ _kbd->periodic();
+
+# ifdef CMD_SERIAL
+ static unsigned long last = micros();
+ static uint8_t buffer[8];
+ static uint8_t index = 0;
+ if (CMD_SERIAL.available() > 0) {
+ buffer[index] = (uint8_t)CMD_SERIAL.read();
+ if (index == 7) {
+ _sendResponse(_handleRequest(buffer));
+ index = 0;
+ } else /*if (buffer[0] == PROTO::MAGIC)*/ { // FIXME: See kvmd/kvmd#80
+ last = micros();
+ ++index;
}
-# elif defined(CMD_SPI)
- if (spiReady()) {
- _sendResponse(_handleRequest(spiGet()));
+ } else if (index > 0) {
+ if (is_micros_timed_out(last, CMD_SERIAL_TIMEOUT)) {
+ _sendResponse(PROTO::RESP::TIMEOUT_ERROR);
+ index = 0;
}
-# endif
}
- return 0;
+# elif defined(CMD_SPI)
+ if (spiReady()) {
+ _sendResponse(_handleRequest(spiGet()));
+ }
+# endif
}