summaryrefslogtreecommitdiffstats
path: root/keyboards/crkbd/rev1/legacy/split_scomm.h
diff options
context:
space:
mode:
authorDrashna Jaelre <drashna@live.com>2020-09-17 00:41:55 -0700
committerGitHub <noreply@github.com>2020-09-17 00:41:55 -0700
commitf37a134f712891db64b1391a250b0d752206f520 (patch)
tree5067c94b61510d1e1f8db5cabad41d48147724e1 /keyboards/crkbd/rev1/legacy/split_scomm.h
parentf650b03fb77530eb6aa7eab541f6a28c98e0ced6 (diff)
[Keyboard] Convert Corne Keyboard to Split Common (#6001)
* [Keyboard] Convert Corne Keyboard to Split Common * Add VIA Support * Makes sure that ol(e)d and new OLED implementation can't coexist * Add licensing header to files * Add changes based on feedback from foostan * Fixes
Diffstat (limited to 'keyboards/crkbd/rev1/legacy/split_scomm.h')
-rw-r--r--keyboards/crkbd/rev1/legacy/split_scomm.h42
1 files changed, 42 insertions, 0 deletions
diff --git a/keyboards/crkbd/rev1/legacy/split_scomm.h b/keyboards/crkbd/rev1/legacy/split_scomm.h
new file mode 100644
index 0000000000..47f0ca1b9d
--- /dev/null
+++ b/keyboards/crkbd/rev1/legacy/split_scomm.h
@@ -0,0 +1,42 @@
+/*
+Copyright 2019 @foostan
+Copyright 2020 Drashna Jaelre <@drashna>
+
+This program is free software: you can redistribute it and/or modify
+it under the terms of the GNU General Public License as published by
+the Free Software Foundation, either version 2 of the License, or
+(at your option) any later version.
+
+This program is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+GNU General Public License for more details.
+
+You should have received a copy of the GNU General Public License
+along with this program. If not, see <http://www.gnu.org/licenses/>.
+*/
+
+#ifndef SPLIT_COMM_H
+#define SPLIT_COMM_H
+
+#ifndef SERIAL_USE_MULTI_TRANSACTION
+/* --- USE Simple API (OLD API, compatible with let's split serial.c) --- */
+#include "serial.h"
+
+#else
+/* --- USE flexible API (using multi-type transaction function) --- */
+// Buffers for master - slave communication
+#define SERIAL_SLAVE_BUFFER_LENGTH MATRIX_ROWS/2
+#define SERIAL_MASTER_BUFFER_LENGTH MATRIX_ROWS/2
+
+extern volatile uint8_t serial_slave_buffer[SERIAL_SLAVE_BUFFER_LENGTH];
+extern volatile uint8_t serial_master_buffer[SERIAL_MASTER_BUFFER_LENGTH];
+extern uint8_t slave_buffer_change_count;
+
+void serial_master_init(void);
+void serial_slave_init(void);
+int serial_update_buffers(int master_changed);
+
+#endif
+
+#endif /* SPLIT_COMM_H */