From 185cc83580a61e38decb8448176400c930dc8ad4 Mon Sep 17 00:00:00 2001
From: Cipulot <40441626+Cipulot@users.noreply.github.com>
Date: Sat, 6 May 2023 18:30:42 +0200
Subject: [PATCH 1/2] Alveus init
---
keyboards/cipulot/alveus/alveus.c | 148 +++++++
keyboards/cipulot/alveus/alveus.h | 37 ++
keyboards/cipulot/alveus/config.h | 48 +++
keyboards/cipulot/alveus/ec_switch_matrix.c | 192 +++++++++
keyboards/cipulot/alveus/ec_switch_matrix.h | 42 ++
keyboards/cipulot/alveus/halconf.h | 21 +
keyboards/cipulot/alveus/info.json | 379 ++++++++++++++++++
.../cipulot/alveus/keymaps/default/keymap.c | 49 +++
.../cipulot/alveus/keymaps/via/alveus.json | 240 +++++++++++
keyboards/cipulot/alveus/keymaps/via/keymap.c | 49 +++
keyboards/cipulot/alveus/keymaps/via/rules.mk | 1 +
keyboards/cipulot/alveus/matrix.c | 67 ++++
keyboards/cipulot/alveus/mcuconf.h | 22 +
keyboards/cipulot/alveus/readme.md | 21 +
keyboards/cipulot/alveus/rules.mk | 25 ++
15 files changed, 1341 insertions(+)
create mode 100644 keyboards/cipulot/alveus/alveus.c
create mode 100644 keyboards/cipulot/alveus/alveus.h
create mode 100644 keyboards/cipulot/alveus/config.h
create mode 100644 keyboards/cipulot/alveus/ec_switch_matrix.c
create mode 100644 keyboards/cipulot/alveus/ec_switch_matrix.h
create mode 100644 keyboards/cipulot/alveus/halconf.h
create mode 100644 keyboards/cipulot/alveus/info.json
create mode 100644 keyboards/cipulot/alveus/keymaps/default/keymap.c
create mode 100644 keyboards/cipulot/alveus/keymaps/via/alveus.json
create mode 100644 keyboards/cipulot/alveus/keymaps/via/keymap.c
create mode 100644 keyboards/cipulot/alveus/keymaps/via/rules.mk
create mode 100644 keyboards/cipulot/alveus/matrix.c
create mode 100644 keyboards/cipulot/alveus/mcuconf.h
create mode 100644 keyboards/cipulot/alveus/readme.md
create mode 100644 keyboards/cipulot/alveus/rules.mk
diff --git a/keyboards/cipulot/alveus/alveus.c b/keyboards/cipulot/alveus/alveus.c
new file mode 100644
index 000000000000..24b6a46ca293
--- /dev/null
+++ b/keyboards/cipulot/alveus/alveus.c
@@ -0,0 +1,148 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#include "alveus.h"
+#include "ec_switch_matrix.h"
+#include "eeprom.h"
+#include "eeconfig.h"
+
+_Static_assert(sizeof(apc_config) == EECONFIG_KB_DATA_SIZE, "Mismatch in keyboard EECONFIG stored data");
+
+void keyboard_post_init_kb(void) {
+ eeconfig_read_kb_datablock(&apc);
+ for (uint8_t row = 0; row < MATRIX_ROWS; row++) {
+ for (uint8_t col = 0; col < MATRIX_COLS; col++) {
+ ecsm_config.low_threshold_matrix[row][col] = apc.apc_actuation_level * 4;
+ ecsm_config.high_threshold_matrix[row][col] = apc.apc_deactuation_level * 4;
+ }
+ }
+ ecsm_update(&ecsm_config);
+}
+
+void eeconfig_init_kb(void) {
+ // Default values
+ apc.apc_enabled = false;
+ apc.apc_actuation_level = 175;
+ apc.apc_deactuation_level = 162;
+ // Write default value to EEPROM now
+ eeconfig_update_kb_datablock(&apc);
+}
+
+enum via_apc { id_apc_enable = 1, id_actuation_threshold = 2, id_deactuation_threshold = 3 };
+
+void apc_config_set_value(uint8_t *data) {
+ // data = [ value_id, value_data ]
+ uint8_t *value_id = &(data[0]);
+ uint8_t *value_data = &(data[1]);
+
+ switch (*value_id) {
+ case id_apc_enable: {
+ apc.apc_enabled = value_data[0];
+ if (apc.apc_enabled) {
+ printf(" <------------------- APC ENABLED -------------------> \n");
+ } else {
+ printf(" <------------------- APC DISABLED -------------------> \n");
+ for (uint8_t row = 0; row < MATRIX_ROWS; row++) {
+ for (uint8_t col = 0; col < MATRIX_COLS; col++) {
+ ecsm_config.low_threshold_matrix[row][col] = apc.apc_actuation_level * 4;
+ ecsm_config.high_threshold_matrix[row][col] = apc.apc_deactuation_level * 4;
+ }
+ }
+ ecsm_update(&ecsm_config);
+ }
+ break;
+ }
+ case id_actuation_threshold: {
+ apc.apc_actuation_level = value_data[0];
+ for (uint8_t row = 0; row < MATRIX_ROWS; row++) {
+ for (uint8_t col = 0; col < MATRIX_COLS; col++) {
+ ecsm_config.low_threshold_matrix[row][col] = apc.apc_actuation_level * 4;
+ }
+ }
+ ecsm_update(&ecsm_config);
+ uprintf("APC ACTUATION LEVEL: %4d\n", apc.apc_actuation_level * 4);
+ break;
+ }
+ case id_deactuation_threshold: {
+ apc.apc_deactuation_level = value_data[0];
+ for (uint8_t row = 0; row < MATRIX_ROWS; row++) {
+ for (uint8_t col = 0; col < MATRIX_COLS; col++) {
+ ecsm_config.high_threshold_matrix[row][col] = apc.apc_deactuation_level * 4;
+ }
+ }
+ ecsm_update(&ecsm_config);
+ uprintf("APC DEACTUATION LEVEL: %4d\n", apc.apc_deactuation_level * 4);
+ break;
+ }
+ }
+}
+
+void apc_config_get_value(uint8_t *data) {
+ // data = [ value_id, value_data ]
+ uint8_t *value_id = &(data[0]);
+ uint8_t *value_data = &(data[1]);
+
+ switch (*value_id) {
+ case id_apc_enable: {
+ value_data[0] = apc.apc_enabled;
+ break;
+ }
+ case id_actuation_threshold: {
+ value_data[0] = apc.apc_actuation_level;
+ break;
+ }
+ case id_deactuation_threshold: {
+ value_data[0] = apc.apc_deactuation_level;
+ break;
+ }
+ }
+}
+
+void apc_config_save(void) {
+ eeconfig_update_kb_datablock(&apc);
+}
+
+void via_custom_value_command_kb(uint8_t *data, uint8_t length) {
+ // data = [ command_id, channel_id, value_id, value_data ]
+ uint8_t *command_id = &(data[0]);
+ uint8_t *channel_id = &(data[1]);
+ uint8_t *value_id_and_data = &(data[2]);
+
+ if (*channel_id == id_custom_channel) {
+ switch (*command_id) {
+ case id_custom_set_value: {
+ apc_config_set_value(value_id_and_data);
+ break;
+ }
+ case id_custom_get_value: {
+ apc_config_get_value(value_id_and_data);
+ break;
+ }
+ case id_custom_save: {
+ apc_config_save();
+ break;
+ }
+ default: {
+ // Unhandled message.
+ *command_id = id_unhandled;
+ break;
+ }
+ }
+ return;
+ }
+
+ *command_id = id_unhandled;
+}
diff --git a/keyboards/cipulot/alveus/alveus.h b/keyboards/cipulot/alveus/alveus.h
new file mode 100644
index 000000000000..c8d83c05bbfd
--- /dev/null
+++ b/keyboards/cipulot/alveus/alveus.h
@@ -0,0 +1,37 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#pragma once
+
+#include "quantum.h"
+
+#define ___ KC_NO
+
+// clang-format off
+#define LAYOUT( \
+ k00, k01, k02, k03, k04, k05, k06, k07, k08, k09, k0A, k0B, k0C, k0D, k0E, k0F, k1F, \
+ k10, k11, k12, k13, k14, k15, k16, k17, k18, k19, k1A, k1B, k1C, k1D, k1E, k2E, k2F, \
+ k20, k21, k22, k23, k24, k25, k26, k27, k28, k29, k2A, k2B, k2D, \
+ k30, k31, k32, k33, k34, k35, k36, k37, k38, k39, k3A, k3D, k3E, \
+ k40, k41, k42, k45, k5B, k5C, k5D, k5E, k5F, k3F \
+) { \
+ { k00, k01, k02, k03, k04, k05, k06, k07, k08, k09, k0A, k0B, k0C, k0D, k0E, k0F }, \
+ { k10, k11, k12, k13, k14, k15, k16, k17, k18, k19, k1A, k1B, k1C, k1D, k1E, k1F }, \
+ { k20, k21, k22, k23, k24, k25, k26, k27, k28, k29, k2A, k2B, ___, k2D, k2E, k2F }, \
+ { k30, k31, k32, k33, k34, k35, k36, k37, k38, k39, k3A, ___, ___, k3D, k3E, k3F }, \
+ { k40, k41, k42, ___, ___, k45, ___, ___, ___, ___, ___, k5B, k5C, k5D, k5E, k5F } \
+}
+// clang-format on
diff --git a/keyboards/cipulot/alveus/config.h b/keyboards/cipulot/alveus/config.h
new file mode 100644
index 000000000000..25672ae46db1
--- /dev/null
+++ b/keyboards/cipulot/alveus/config.h
@@ -0,0 +1,48 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#pragma once
+
+#include "config_common.h"
+
+/* key matrix size */
+#define MATRIX_ROWS 5
+#define MATRIX_COLS 16
+
+/* Custom matrix pins and port select array */
+#define MATRIX_ROW_PINS \
+ { A14, B3, A15, B5, B4 }
+#define MATRIX_COL_CHANNELS \
+ { 3, 0, 1, 2, 6, 5, 7, 4 }
+#define MUX_SEL_PINS \
+ { B7, B8, B9 }
+
+/* Hardware peripherals pins */
+#define APLEX_EN_PIN_0 C13
+#define APLEX_EN_PIN_1 C14
+#define DISCHARGE_PIN B1
+#define ANALOG_PORT A3
+
+/* COL2ROW, ROW2COL */
+#define DIODE_DIRECTION COL2ROW
+
+/* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */
+#define LOCKING_SUPPORT_ENABLE
+
+/* Locking resynchronize hack */
+#define LOCKING_RESYNC_ENABLE
+
+#define EECONFIG_KB_DATA_SIZE 3
diff --git a/keyboards/cipulot/alveus/ec_switch_matrix.c b/keyboards/cipulot/alveus/ec_switch_matrix.c
new file mode 100644
index 000000000000..9a3f89b2c25b
--- /dev/null
+++ b/keyboards/cipulot/alveus/ec_switch_matrix.c
@@ -0,0 +1,192 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#include "ec_switch_matrix.h"
+
+#include "quantum.h"
+#include "analog.h"
+#include "atomic_util.h"
+#include "print.h"
+
+#define WAIT_DISCHARGE()
+#define WAIT_CHARGE()
+
+/* Pin and port array */
+const uint32_t row_pins[] = MATRIX_ROW_PINS;
+const uint8_t col_channels[] = MATRIX_COL_CHANNELS;
+const uint32_t mux_sel_pins[] = MUX_SEL_PINS;
+
+static ecsm_config_t config;
+static uint16_t ecsm_sw_value[MATRIX_ROWS][MATRIX_COLS];
+
+static adc_mux adcMux;
+
+static inline void discharge_capacitor(void) {
+ writePinLow(DISCHARGE_PIN);
+}
+static inline void charge_capacitor(uint8_t row) {
+ writePinHigh(DISCHARGE_PIN);
+ writePinHigh(row_pins[row]);
+}
+
+static inline void clear_all_row_pins(void) {
+ for (int row = 0; row < MATRIX_ROWS; row++) {
+ writePinLow(row_pins[row]);
+ }
+}
+
+static inline void init_mux_sel(void) {
+ for (int idx = 0; idx < 3; idx++) {
+ setPinOutput(mux_sel_pins[idx]);
+ }
+}
+
+static inline void select_mux(uint8_t col) {
+ uint8_t ch = col_channels[col];
+ writePin(mux_sel_pins[0], ch & 1);
+ writePin(mux_sel_pins[1], ch & 2);
+ writePin(mux_sel_pins[2], ch & 4);
+}
+
+static inline void init_row(void) {
+ for (int idx = 0; idx < MATRIX_ROWS; idx++) {
+ setPinOutput(row_pins[idx]);
+ writePinLow(row_pins[idx]);
+ }
+}
+
+/* Initialize the peripherals pins */
+int ecsm_init(ecsm_config_t const* const ecsm_config) {
+ // Save config
+ config = *ecsm_config;
+
+ palSetLineMode(ANALOG_PORT, PAL_MODE_INPUT_ANALOG);
+ adcMux = pinToMux(ANALOG_PORT);
+
+ // Initialize discharge pin as discharge mode
+ writePinLow(DISCHARGE_PIN);
+ setPinOutputOpenDrain(DISCHARGE_PIN);
+
+ // Initialize drive lines
+ init_row();
+
+ // Initialize multiplexer select pin
+ init_mux_sel();
+
+ // Enable AMUX
+ setPinOutput(APLEX_EN_PIN_0);
+ writePinLow(APLEX_EN_PIN_0);
+ setPinOutput(APLEX_EN_PIN_1);
+ writePinLow(APLEX_EN_PIN_1);
+
+ return 0;
+}
+
+int ecsm_update(ecsm_config_t const* const ecsm_config) {
+ // Save config
+ config = *ecsm_config;
+ return 0;
+}
+
+// Read the capacitive sensor value
+static uint16_t ecsm_readkey_raw(uint8_t channel, uint8_t row, uint8_t col) {
+ uint16_t sw_value = 0;
+
+ // Select the multiplexer
+ if (channel == 0) {
+ writePinHigh(APLEX_EN_PIN_0);
+ select_mux(col);
+ writePinLow(APLEX_EN_PIN_0);
+ } else {
+ writePinHigh(APLEX_EN_PIN_1);
+ select_mux(col);
+ writePinLow(APLEX_EN_PIN_1);
+ }
+
+ // Set strobe pins to low state
+ writePinLow(row_pins[row]);
+
+ ATOMIC_BLOCK_FORCEON {
+ // Set the row pin to high state and have capacitor charge
+ charge_capacitor(row);
+
+ WAIT_CHARGE();
+ sw_value = adc_read(adcMux);
+ }
+
+ // Discharge peak hold capacitor
+ discharge_capacitor();
+ WAIT_DISCHARGE();
+
+ return sw_value;
+}
+
+// Update press/release state of key at (row, col)
+static bool ecsm_update_key(matrix_row_t* current_row, uint8_t row, uint8_t col, uint16_t sw_value) {
+ bool current_state = (*current_row >> col) & 1;
+
+ // press to release
+ if (current_state && sw_value < config.low_threshold_matrix[row][col]) {
+ *current_row &= ~(1 << col);
+ return true;
+ }
+
+ // release to press
+ if ((!current_state) && sw_value > config.high_threshold_matrix[row][col]) {
+ *current_row |= (1 << col);
+ return true;
+ }
+
+ return false;
+}
+
+// Scan key values and update matrix state
+bool ecsm_matrix_scan(matrix_row_t current_matrix[]) {
+ bool updated = false;
+
+ // Disable AMUX of channel 1
+ writePinHigh(APLEX_EN_PIN_1);
+ for (int col = 0; col < sizeof(col_channels); col++) {
+ for (int row = 0; row < MATRIX_ROWS; row++) {
+ ecsm_sw_value[row][col] = ecsm_readkey_raw(0, row, col);
+ updated |= ecsm_update_key(¤t_matrix[row], row, col, ecsm_sw_value[row][col]);
+ }
+ }
+
+ // Disable AMUX of channel 1
+ writePinHigh(APLEX_EN_PIN_0);
+ for (int col = 0; col < sizeof(col_channels); col++) {
+ for (int row = 0; row < MATRIX_ROWS; row++) {
+ ecsm_sw_value[row][col + 8] = ecsm_readkey_raw(1, row, col);
+ updated |= ecsm_update_key(¤t_matrix[row], row, col + 8, ecsm_sw_value[row][col + 8]);
+ }
+ }
+ return updated;
+}
+
+// Debug print key values
+void ecsm_print_matrix(void) {
+ for (int row = 0; row < MATRIX_ROWS; row++) {
+ for (int col = 0; col < MATRIX_COLS; col++) {
+ uprintf("%4d", ecsm_sw_value[row][col]);
+ if (col < MATRIX_COLS - 1) {
+ print(",");
+ }
+ }
+ print("\n");
+ }
+ print("\n");
+}
diff --git a/keyboards/cipulot/alveus/ec_switch_matrix.h b/keyboards/cipulot/alveus/ec_switch_matrix.h
new file mode 100644
index 000000000000..95846224ba6f
--- /dev/null
+++ b/keyboards/cipulot/alveus/ec_switch_matrix.h
@@ -0,0 +1,42 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#pragma once
+
+#include
+#include
+
+#include "matrix.h"
+
+typedef struct {
+ uint16_t low_threshold_matrix[MATRIX_ROWS][MATRIX_COLS]; // threshold for key release
+ uint16_t high_threshold_matrix[MATRIX_ROWS][MATRIX_COLS]; // threshold for key press
+} ecsm_config_t;
+
+ecsm_config_t ecsm_config;
+
+int ecsm_init(ecsm_config_t const* const ecsm_config);
+int ecsm_update(ecsm_config_t const* const ecsm_config);
+bool ecsm_matrix_scan(matrix_row_t current_matrix[]);
+void ecsm_print_matrix(void);
+
+typedef struct _apc_config_t {
+ bool apc_enabled;
+ uint8_t apc_actuation_level;
+ uint8_t apc_deactuation_level;
+} apc_config;
+
+apc_config apc;
diff --git a/keyboards/cipulot/alveus/halconf.h b/keyboards/cipulot/alveus/halconf.h
new file mode 100644
index 000000000000..5b71acecbbc8
--- /dev/null
+++ b/keyboards/cipulot/alveus/halconf.h
@@ -0,0 +1,21 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#pragma once
+
+#define HAL_USE_ADC TRUE
+
+#include_next
diff --git a/keyboards/cipulot/alveus/info.json b/keyboards/cipulot/alveus/info.json
new file mode 100644
index 000000000000..f799a44de628
--- /dev/null
+++ b/keyboards/cipulot/alveus/info.json
@@ -0,0 +1,379 @@
+{
+ "keyboard_name": "Alveus",
+ "manufacturer": "Cipulot",
+ "url": "",
+ "maintainer": "Cipulot",
+ "usb": {
+ "vid": "0x6369",
+ "pid": "0x6B90",
+ "device_version": "0.0.1"
+ },
+ "layouts": {
+ "LAYOUT": {
+ "layout": [
+ {
+ "label": "0,0",
+ "x": 0,
+ "y": 0
+ },
+ {
+ "label": "0,1",
+ "x": 1,
+ "y": 0
+ },
+ {
+ "label": "0,2",
+ "x": 2,
+ "y": 0
+ },
+ {
+ "label": "0,3",
+ "x": 3,
+ "y": 0
+ },
+ {
+ "label": "0,4",
+ "x": 4,
+ "y": 0
+ },
+ {
+ "label": "0,5",
+ "x": 5,
+ "y": 0
+ },
+ {
+ "label": "0,6",
+ "x": 6,
+ "y": 0
+ },
+ {
+ "label": "0,7",
+ "x": 7,
+ "y": 0
+ },
+ {
+ "label": "0,8",
+ "x": 8,
+ "y": 0
+ },
+ {
+ "label": "0,9",
+ "x": 9,
+ "y": 0
+ },
+ {
+ "label": "0,10",
+ "x": 10,
+ "y": 0
+ },
+ {
+ "label": "0,11",
+ "x": 11,
+ "y": 0
+ },
+ {
+ "label": "0,12",
+ "x": 12,
+ "y": 0
+ },
+ {
+ "label": "0,13",
+ "x": 13,
+ "y": 0,
+ "w": 2
+ },
+ {
+ "label": "0,14",
+ "x": 15.25,
+ "y": 0
+ },
+ {
+ "label": "0,15",
+ "x": 16.25,
+ "y": 0
+ },
+ {
+ "label": "1,15",
+ "x": 17.25,
+ "y": 0
+ },
+ {
+ "label": "1,0",
+ "x": 0,
+ "y": 1,
+ "w": 1.5
+ },
+ {
+ "label": "1,1",
+ "x": 1.5,
+ "y": 1
+ },
+ {
+ "label": "1,2",
+ "x": 2.5,
+ "y": 1
+ },
+ {
+ "label": "1,3",
+ "x": 3.5,
+ "y": 1
+ },
+ {
+ "label": "1,4",
+ "x": 4.5,
+ "y": 1
+ },
+ {
+ "label": "1,5",
+ "x": 5.5,
+ "y": 1
+ },
+ {
+ "label": "1,6",
+ "x": 6.5,
+ "y": 1
+ },
+ {
+ "label": "1,7",
+ "x": 7.5,
+ "y": 1
+ },
+ {
+ "label": "1,8",
+ "x": 8.5,
+ "y": 1
+ },
+ {
+ "label": "1,9",
+ "x": 9.5,
+ "y": 1
+ },
+ {
+ "label": "1,10",
+ "x": 10.5,
+ "y": 1
+ },
+ {
+ "label": "1,11",
+ "x": 11.5,
+ "y": 1
+ },
+ {
+ "label": "1,12",
+ "x": 12.5,
+ "y": 1
+ },
+ {
+ "label": "1,13",
+ "x": 13.5,
+ "y": 1,
+ "w": 1.5
+ },
+ {
+ "label": "1,14",
+ "x": 15.25,
+ "y": 1
+ },
+ {
+ "label": "2,14",
+ "x": 16.25,
+ "y": 1
+ },
+ {
+ "label": "2,15",
+ "x": 17.25,
+ "y": 1
+ },
+ {
+ "label": "2,0",
+ "x": 0,
+ "y": 2,
+ "w": 1.75
+ },
+ {
+ "label": "2,1",
+ "x": 1.75,
+ "y": 2
+ },
+ {
+ "label": "2,2",
+ "x": 2.75,
+ "y": 2
+ },
+ {
+ "label": "2,3",
+ "x": 3.75,
+ "y": 2
+ },
+ {
+ "label": "2,4",
+ "x": 4.75,
+ "y": 2
+ },
+ {
+ "label": "2,5",
+ "x": 5.75,
+ "y": 2
+ },
+ {
+ "label": "2,6",
+ "x": 6.75,
+ "y": 2
+ },
+ {
+ "label": "2,7",
+ "x": 7.75,
+ "y": 2
+ },
+ {
+ "label": "2,8",
+ "x": 8.75,
+ "y": 2
+ },
+ {
+ "label": "2,9",
+ "x": 9.75,
+ "y": 2
+ },
+ {
+ "label": "2,10",
+ "x": 10.75,
+ "y": 2
+ },
+ {
+ "label": "2,11",
+ "x": 11.75,
+ "y": 2
+ },
+ {
+ "label": "2,13",
+ "x": 12.75,
+ "y": 2,
+ "w": 2.25
+ },
+ {
+ "label": "3,0",
+ "x": 0,
+ "y": 3,
+ "w": 2.25
+ },
+ {
+ "label": "3,1",
+ "x": 2.25,
+ "y": 3
+ },
+ {
+ "label": "3,2",
+ "x": 3.25,
+ "y": 3
+ },
+ {
+ "label": "3,3",
+ "x": 4.25,
+ "y": 3
+ },
+ {
+ "label": "3,4",
+ "x": 5.25,
+ "y": 3
+ },
+ {
+ "label": "3,5",
+ "x": 6.25,
+ "y": 3
+ },
+ {
+ "label": "3,6",
+ "x": 7.25,
+ "y": 3
+ },
+ {
+ "label": "3,7",
+ "x": 8.25,
+ "y": 3
+ },
+ {
+ "label": "3,8",
+ "x": 9.25,
+ "y": 3
+ },
+ {
+ "label": "3,9",
+ "x": 10.25,
+ "y": 3
+ },
+ {
+ "label": "3,10",
+ "x": 11.25,
+ "y": 3
+ },
+ {
+ "label": "3,13",
+ "x": 12.25,
+ "y": 3,
+ "w": 2.75
+ },
+ {
+ "label": "3,14",
+ "x": 16.25,
+ "y": 3
+ },
+ {
+ "label": "4,0",
+ "x": 0,
+ "y": 4,
+ "w": 1.5
+ },
+ {
+ "label": "4,1",
+ "x": 1.5,
+ "y": 4
+ },
+ {
+ "label": "4,2",
+ "x": 2.5,
+ "y": 4,
+ "w": 1.5
+ },
+ {
+ "label": "4,5",
+ "x": 4,
+ "y": 4,
+ "w": 7
+ },
+ {
+ "label": "4,11",
+ "x": 11,
+ "y": 4,
+ "w": 1.5
+ },
+ {
+ "label": "4,12",
+ "x": 12.5,
+ "y": 4
+ },
+ {
+ "label": "4,13",
+ "x": 13.5,
+ "y": 4,
+ "w": 1.5
+ },
+ {
+ "label": "4,14",
+ "x": 15.25,
+ "y": 4
+ },
+ {
+ "label": "4,15",
+ "x": 16.25,
+ "y": 4
+ },
+ {
+ "label": "3,15",
+ "x": 17.25,
+ "y": 4
+ }
+ ]
+ }
+ }
+}
diff --git a/keyboards/cipulot/alveus/keymaps/default/keymap.c b/keyboards/cipulot/alveus/keymaps/default/keymap.c
new file mode 100644
index 000000000000..3373c417fb12
--- /dev/null
+++ b/keyboards/cipulot/alveus/keymaps/default/keymap.c
@@ -0,0 +1,49 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#include QMK_KEYBOARD_H
+
+const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
+ // clang-format off
+ [0] = LAYOUT(
+ KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, KC_INS, KC_HOME, KC_PGUP,
+ KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_DEL, KC_END, KC_PGDN,
+ KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENTER,
+ KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, KC_UP,
+ KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, MO(1), KC_RGUI, KC_RCTL, KC_LEFT, KC_DOWN, KC_RIGHT),
+
+ [1] = LAYOUT(
+ KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, _______, _______, _______, KC_VOLU,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_VOLD,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______),
+
+ [2] = LAYOUT(
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______),
+
+ [3] = LAYOUT(
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______)
+ // clang-format on
+};
diff --git a/keyboards/cipulot/alveus/keymaps/via/alveus.json b/keyboards/cipulot/alveus/keymaps/via/alveus.json
new file mode 100644
index 000000000000..96f4151be652
--- /dev/null
+++ b/keyboards/cipulot/alveus/keymaps/via/alveus.json
@@ -0,0 +1,240 @@
+{
+ "name": "Alveus",
+ "vendorId": "0x6369",
+ "productId": "0x6B90",
+ "menus": [
+ {
+ "label": "EC Tools",
+ "content": [
+ {
+ "label": "Whole",
+ "content":[
+ {
+ "label": "Enable APC",
+ "type": "toggle",
+ "content": ["id_apc_enable", 0, 1]
+ },
+ {
+ "showIf": "{id_apc_enable} == 1",
+ "label": "Actuation Level",
+ "type": "range",
+ "options": [0, 255],
+ "content": ["id_actuation_threshold", 0, 2]
+ },
+ {
+ "showIf": "{id_apc_enable} == 1",
+ "label": "Deactuation Level",
+ "type": "range",
+ "options": [0, 255],
+ "content": ["id_deactuation_threshold", 0, 3]
+ }
+ ]
+ }
+ ]
+ }
+ ],
+ "matrix": {
+ "rows": 5,
+ "cols": 16
+ },
+ "layouts": {
+ "labels": [
+ [
+ "Bottom row",
+ "WKL",
+ "WK"
+ ]
+ ],
+ "keymap": [
+ [
+ {
+ "c": "#777777"
+ },
+ "0,0",
+ {
+ "c": "#cccccc"
+ },
+ "0,1",
+ "0,2",
+ "0,3",
+ "0,4",
+ "0,5",
+ "0,6",
+ "0,7",
+ "0,8",
+ "0,9",
+ "0,10",
+ "0,11",
+ "0,12",
+ {
+ "c": "#aaaaaa",
+ "w": 2
+ },
+ "0,13",
+ {
+ "x": 0.25,
+ "c": "#cccccc"
+ },
+ "0,14",
+ "0,15",
+ "1,15"
+ ],
+ [
+ {
+ "c": "#aaaaaa",
+ "w": 1.5
+ },
+ "1,0",
+ {
+ "c": "#cccccc"
+ },
+ "1,1",
+ "1,2",
+ "1,3",
+ "1,4",
+ "1,5",
+ "1,6",
+ "1,7",
+ "1,8",
+ "1,9",
+ "1,10",
+ "1,11",
+ "1,12",
+ {
+ "w": 1.5
+ },
+ "1,13",
+ {
+ "x": 0.25
+ },
+ "1,14",
+ "2,14",
+ "2,15"
+ ],
+ [
+ {
+ "c": "#aaaaaa",
+ "w": 1.75
+ },
+ "2,0",
+ {
+ "c": "#cccccc"
+ },
+ "2,1",
+ "2,2",
+ "2,3",
+ "2,4",
+ "2,5",
+ "2,6",
+ "2,7",
+ "2,8",
+ "2,9",
+ "2,10",
+ "2,11",
+ {
+ "c": "#777777",
+ "w": 2.25
+ },
+ "2,13"
+ ],
+ [
+ {
+ "c": "#aaaaaa",
+ "w": 2.25
+ },
+ "3,0",
+ {
+ "c": "#cccccc"
+ },
+ "3,1",
+ "3,2",
+ "3,3",
+ "3,4",
+ "3,5",
+ "3,6",
+ "3,7",
+ "3,8",
+ "3,9",
+ "3,10",
+ {
+ "c": "#aaaaaa",
+ "w": 2.75
+ },
+ "3,13",
+ {
+ "x": 1.25,
+ "c": "#cccccc"
+ },
+ "3,14"
+ ],
+ [
+ {
+ "c": "#aaaaaa",
+ "w": 1.5
+ },
+ "4,0\n\n\n0,0",
+ {
+ "d": true
+ },
+ "\n\n\n0,0",
+ {
+ "w": 1.5
+ },
+ "4,2\n\n\n0,0",
+ {
+ "c": "#cccccc",
+ "w": 7
+ },
+ "4,5\n\n\n0,0",
+ {
+ "c": "#aaaaaa",
+ "w": 1.5
+ },
+ "4,11\n\n\n0,0",
+ {
+ "d": true
+ },
+ "\n\n\n0,0",
+ {
+ "w": 1.5
+ },
+ "4,13\n\n\n0,0",
+ {
+ "x": 0.25,
+ "c": "#cccccc"
+ },
+ "4,14",
+ "4,15",
+ "3,15"
+ ],
+ [
+ {
+ "y": 0.25,
+ "c": "#aaaaaa",
+ "w": 1.5
+ },
+ "4,0\n\n\n0,1",
+ "4,1\n\n\n0,1",
+ {
+ "w": 1.5
+ },
+ "4,2\n\n\n0,1",
+ {
+ "c": "#cccccc",
+ "w": 7
+ },
+ "4,5\n\n\n0,1",
+ {
+ "c": "#aaaaaa",
+ "w": 1.5
+ },
+ "4,11\n\n\n0,1",
+ "4,12\n\n\n0,1",
+ {
+ "w": 1.5
+ },
+ "4,13\n\n\n0,1"
+ ]
+ ]
+ }
+}
diff --git a/keyboards/cipulot/alveus/keymaps/via/keymap.c b/keyboards/cipulot/alveus/keymaps/via/keymap.c
new file mode 100644
index 000000000000..3373c417fb12
--- /dev/null
+++ b/keyboards/cipulot/alveus/keymaps/via/keymap.c
@@ -0,0 +1,49 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#include QMK_KEYBOARD_H
+
+const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
+ // clang-format off
+ [0] = LAYOUT(
+ KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, KC_INS, KC_HOME, KC_PGUP,
+ KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_DEL, KC_END, KC_PGDN,
+ KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENTER,
+ KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, KC_UP,
+ KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, MO(1), KC_RGUI, KC_RCTL, KC_LEFT, KC_DOWN, KC_RIGHT),
+
+ [1] = LAYOUT(
+ KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, _______, _______, _______, KC_VOLU,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_VOLD,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______),
+
+ [2] = LAYOUT(
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______),
+
+ [3] = LAYOUT(
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______)
+ // clang-format on
+};
diff --git a/keyboards/cipulot/alveus/keymaps/via/rules.mk b/keyboards/cipulot/alveus/keymaps/via/rules.mk
new file mode 100644
index 000000000000..1e5b99807cb7
--- /dev/null
+++ b/keyboards/cipulot/alveus/keymaps/via/rules.mk
@@ -0,0 +1 @@
+VIA_ENABLE = yes
diff --git a/keyboards/cipulot/alveus/matrix.c b/keyboards/cipulot/alveus/matrix.c
new file mode 100644
index 000000000000..7fea2614f925
--- /dev/null
+++ b/keyboards/cipulot/alveus/matrix.c
@@ -0,0 +1,67 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#include "ec_switch_matrix.h"
+#include "matrix.h"
+#include "debug.h"
+
+/* matrix state(1:on, 0:off) */
+extern matrix_row_t raw_matrix[MATRIX_ROWS]; // raw values
+extern matrix_row_t matrix[MATRIX_ROWS]; // debounced values
+
+// clang-format off
+const uint16_t low_threshold[MATRIX_ROWS][MATRIX_COLS] = {
+ { 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700 }, \
+ { 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700 }, \
+ { 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700 }, \
+ { 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700 }, \
+ { 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700 } \
+};
+const uint16_t high_threshold[MATRIX_ROWS][MATRIX_COLS] = {
+ { 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650 }, \
+ { 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650 }, \
+ { 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650 }, \
+ { 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650 }, \
+ { 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650 } \
+};
+// clang-format on
+
+void matrix_init_custom(void) {
+ ecsm_config_t ecsm_config;
+
+ for (uint8_t row = 0; row < MATRIX_ROWS; row++) {
+ for (uint8_t col = 0; col < MATRIX_COLS; col++) {
+ ecsm_config.low_threshold_matrix[row][col] = 700;
+ ecsm_config.high_threshold_matrix[row][col] = 650;
+ }
+ }
+
+ ecsm_init(&ecsm_config);
+}
+
+bool matrix_scan_custom(matrix_row_t current_matrix[]) {
+ bool updated = ecsm_matrix_scan(current_matrix);
+
+// RAW matrix values on console
+#ifdef CONSOLE_ENABLE
+ static int cnt = 0;
+ if (cnt++ == 1000) {
+ cnt = 0;
+ ecsm_print_matrix();
+ }
+#endif
+ return updated;
+}
diff --git a/keyboards/cipulot/alveus/mcuconf.h b/keyboards/cipulot/alveus/mcuconf.h
new file mode 100644
index 000000000000..1bef7dfabcbd
--- /dev/null
+++ b/keyboards/cipulot/alveus/mcuconf.h
@@ -0,0 +1,22 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#pragma once
+
+#include_next "mcuconf.h"
+
+#undef STM32_ADC_USE_ADC1
+#define STM32_ADC_USE_ADC1 TRUE
diff --git a/keyboards/cipulot/alveus/readme.md b/keyboards/cipulot/alveus/readme.md
new file mode 100644
index 000000000000..36fd1f3a13b4
--- /dev/null
+++ b/keyboards/cipulot/alveus/readme.md
@@ -0,0 +1,21 @@
+# Alveus
+
+EC FRL TKL keyboard.
+
+* Keyboard Maintainer: [cipulot](https://github.com/cipulot)
+* Hardware Supported: Alveus
+* Hardware Availability: TBD
+
+Make example for this keyboard (after setting up your build environment):
+
+ make cipulot/alveus:default
+ make cipulot/alveus:via
+ make cipulot/alveus:vial
+
+Flashing example for this keyboard:
+
+ make cipulot/alveus:default:flash
+ make cipulot/alveus:via:flash
+ make cipulot/alveus:vial:flash
+
+See the [build environment setup](https://docs.qmk.fm/#/getting_started_build_tools) and the [make instructions](https://docs.qmk.fm/#/getting_started_make_guide) for more information. Brand new to QMK? Start with our [Complete Newbs Guide](https://docs.qmk.fm/#/newbs).
diff --git a/keyboards/cipulot/alveus/rules.mk b/keyboards/cipulot/alveus/rules.mk
new file mode 100644
index 000000000000..1a62de2b4e12
--- /dev/null
+++ b/keyboards/cipulot/alveus/rules.mk
@@ -0,0 +1,25 @@
+# MCU name
+MCU = STM32F401
+
+BOARD = GENERIC_STM32_F401XC
+
+# Bootloader selection
+BOOTLOADER = stm32-dfu
+
+KEYBOARD_SHARED_EP = yes
+
+CUSTOM_MATRIX = lite
+SRC += analog.c matrix.c ec_switch_matrix.c
+
+# Build Options
+# change yes to no to disable
+#
+BOOTMAGIC_ENABLE = yes # Enable Bootmagic Lite
+MOUSEKEY_ENABLE = yes # Mouse keys
+EXTRAKEY_ENABLE = yes # Audio control and System control
+CONSOLE_ENABLE = yes # Console for debug
+COMMAND_ENABLE = no # Commands for debug and configuration
+NKRO_ENABLE = yes # Enable N-Key Rollover
+BACKLIGHT_ENABLE = no # Enable keyboard backlight functionality
+RGBLIGHT_ENABLE = no # Enable keyboard RGB underglow
+AUDIO_ENABLE = no # Audio output
From 947c8256e4221563481e48086040723863fd10e7 Mon Sep 17 00:00:00 2001
From: Cipulot <40441626+Cipulot@users.noreply.github.com>
Date: Wed, 10 May 2023 16:49:27 +0200
Subject: [PATCH 2/2] Alveus versions update
---
keyboards/cipulot/alveus/alveus.c | 148 -------
keyboards/cipulot/alveus/alveus.h | 37 --
keyboards/cipulot/alveus/info.json | 379 ------------------
.../cipulot/alveus/keymaps/via/alveus.json | 240 -----------
keyboards/cipulot/alveus/keymaps/via/rules.mk | 1 -
keyboards/cipulot/alveus/matrix.c | 67 ----
keyboards/cipulot/alveus/readme.md | 21 -
keyboards/cipulot/alveus/rules.mk | 25 --
.../{alveus => ec_alveus/1_0_0}/config.h | 11 +-
.../1_0_0}/ec_switch_matrix.c | 41 +-
.../1_0_0}/ec_switch_matrix.h | 22 +-
.../{alveus => ec_alveus/1_0_0}/halconf.h | 0
keyboards/cipulot/ec_alveus/1_0_0/info.json | 181 +++++++++
.../1_0_0}/keymaps/default/keymap.c | 36 +-
.../ec_alveus/1_0_0/keymaps/via/config.h | 20 +
.../ec_alveus/1_0_0/keymaps/via/keymap.c | 49 +++
.../ec_alveus/1_0_0/keymaps/via/rules.mk | 3 +
.../ec_alveus/1_0_0/keymaps/via/via_apc.c | 156 +++++++
keyboards/cipulot/ec_alveus/1_0_0/matrix.c | 44 ++
.../{alveus => ec_alveus/1_0_0}/mcuconf.h | 2 +-
keyboards/cipulot/ec_alveus/1_0_0/readme.md | 27 ++
keyboards/cipulot/ec_alveus/1_0_0/rules.mk | 3 +
keyboards/cipulot/ec_alveus/1_2_0/config.h | 45 +++
.../ec_alveus/1_2_0/ec_switch_matrix.c | 183 +++++++++
.../ec_alveus/1_2_0/ec_switch_matrix.h | 36 ++
keyboards/cipulot/ec_alveus/1_2_0/halconf.h | 21 +
keyboards/cipulot/ec_alveus/1_2_0/info.json | 255 ++++++++++++
.../1_2_0/keymaps/default}/keymap.c | 36 +-
.../keymap.c | 49 +++
.../ec_alveus/1_2_0/keymaps/via/config.h | 20 +
.../ec_alveus/1_2_0/keymaps/via/keymap.c | 49 +++
.../ec_alveus/1_2_0/keymaps/via/rules.mk | 3 +
.../ec_alveus/1_2_0/keymaps/via/via_apc.c | 156 +++++++
keyboards/cipulot/ec_alveus/1_2_0/matrix.c | 44 ++
keyboards/cipulot/ec_alveus/1_2_0/mcuconf.h | 22 +
keyboards/cipulot/ec_alveus/1_2_0/readme.md | 27 ++
keyboards/cipulot/ec_alveus/1_2_0/rules.mk | 3 +
37 files changed, 1461 insertions(+), 1001 deletions(-)
delete mode 100644 keyboards/cipulot/alveus/alveus.c
delete mode 100644 keyboards/cipulot/alveus/alveus.h
delete mode 100644 keyboards/cipulot/alveus/info.json
delete mode 100644 keyboards/cipulot/alveus/keymaps/via/alveus.json
delete mode 100644 keyboards/cipulot/alveus/keymaps/via/rules.mk
delete mode 100644 keyboards/cipulot/alveus/matrix.c
delete mode 100644 keyboards/cipulot/alveus/readme.md
delete mode 100644 keyboards/cipulot/alveus/rules.mk
rename keyboards/cipulot/{alveus => ec_alveus/1_0_0}/config.h (90%)
rename keyboards/cipulot/{alveus => ec_alveus/1_0_0}/ec_switch_matrix.c (85%)
rename keyboards/cipulot/{alveus => ec_alveus/1_0_0}/ec_switch_matrix.h (60%)
rename keyboards/cipulot/{alveus => ec_alveus/1_0_0}/halconf.h (100%)
create mode 100644 keyboards/cipulot/ec_alveus/1_0_0/info.json
rename keyboards/cipulot/{alveus => ec_alveus/1_0_0}/keymaps/default/keymap.c (68%)
create mode 100644 keyboards/cipulot/ec_alveus/1_0_0/keymaps/via/config.h
create mode 100644 keyboards/cipulot/ec_alveus/1_0_0/keymaps/via/keymap.c
create mode 100644 keyboards/cipulot/ec_alveus/1_0_0/keymaps/via/rules.mk
create mode 100644 keyboards/cipulot/ec_alveus/1_0_0/keymaps/via/via_apc.c
create mode 100644 keyboards/cipulot/ec_alveus/1_0_0/matrix.c
rename keyboards/cipulot/{alveus => ec_alveus/1_0_0}/mcuconf.h (96%)
create mode 100644 keyboards/cipulot/ec_alveus/1_0_0/readme.md
create mode 100644 keyboards/cipulot/ec_alveus/1_0_0/rules.mk
create mode 100644 keyboards/cipulot/ec_alveus/1_2_0/config.h
create mode 100644 keyboards/cipulot/ec_alveus/1_2_0/ec_switch_matrix.c
create mode 100644 keyboards/cipulot/ec_alveus/1_2_0/ec_switch_matrix.h
create mode 100644 keyboards/cipulot/ec_alveus/1_2_0/halconf.h
create mode 100644 keyboards/cipulot/ec_alveus/1_2_0/info.json
rename keyboards/cipulot/{alveus/keymaps/via => ec_alveus/1_2_0/keymaps/default}/keymap.c (68%)
create mode 100644 keyboards/cipulot/ec_alveus/1_2_0/keymaps/tkl_nofrow_ansi_tsangan_wkl_split_bs/keymap.c
create mode 100644 keyboards/cipulot/ec_alveus/1_2_0/keymaps/via/config.h
create mode 100644 keyboards/cipulot/ec_alveus/1_2_0/keymaps/via/keymap.c
create mode 100644 keyboards/cipulot/ec_alveus/1_2_0/keymaps/via/rules.mk
create mode 100644 keyboards/cipulot/ec_alveus/1_2_0/keymaps/via/via_apc.c
create mode 100644 keyboards/cipulot/ec_alveus/1_2_0/matrix.c
create mode 100644 keyboards/cipulot/ec_alveus/1_2_0/mcuconf.h
create mode 100644 keyboards/cipulot/ec_alveus/1_2_0/readme.md
create mode 100644 keyboards/cipulot/ec_alveus/1_2_0/rules.mk
diff --git a/keyboards/cipulot/alveus/alveus.c b/keyboards/cipulot/alveus/alveus.c
deleted file mode 100644
index 24b6a46ca293..000000000000
--- a/keyboards/cipulot/alveus/alveus.c
+++ /dev/null
@@ -1,148 +0,0 @@
-/* Copyright 2023 Cipulot
- *
- * 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 .
- */
-
-#include "alveus.h"
-#include "ec_switch_matrix.h"
-#include "eeprom.h"
-#include "eeconfig.h"
-
-_Static_assert(sizeof(apc_config) == EECONFIG_KB_DATA_SIZE, "Mismatch in keyboard EECONFIG stored data");
-
-void keyboard_post_init_kb(void) {
- eeconfig_read_kb_datablock(&apc);
- for (uint8_t row = 0; row < MATRIX_ROWS; row++) {
- for (uint8_t col = 0; col < MATRIX_COLS; col++) {
- ecsm_config.low_threshold_matrix[row][col] = apc.apc_actuation_level * 4;
- ecsm_config.high_threshold_matrix[row][col] = apc.apc_deactuation_level * 4;
- }
- }
- ecsm_update(&ecsm_config);
-}
-
-void eeconfig_init_kb(void) {
- // Default values
- apc.apc_enabled = false;
- apc.apc_actuation_level = 175;
- apc.apc_deactuation_level = 162;
- // Write default value to EEPROM now
- eeconfig_update_kb_datablock(&apc);
-}
-
-enum via_apc { id_apc_enable = 1, id_actuation_threshold = 2, id_deactuation_threshold = 3 };
-
-void apc_config_set_value(uint8_t *data) {
- // data = [ value_id, value_data ]
- uint8_t *value_id = &(data[0]);
- uint8_t *value_data = &(data[1]);
-
- switch (*value_id) {
- case id_apc_enable: {
- apc.apc_enabled = value_data[0];
- if (apc.apc_enabled) {
- printf(" <------------------- APC ENABLED -------------------> \n");
- } else {
- printf(" <------------------- APC DISABLED -------------------> \n");
- for (uint8_t row = 0; row < MATRIX_ROWS; row++) {
- for (uint8_t col = 0; col < MATRIX_COLS; col++) {
- ecsm_config.low_threshold_matrix[row][col] = apc.apc_actuation_level * 4;
- ecsm_config.high_threshold_matrix[row][col] = apc.apc_deactuation_level * 4;
- }
- }
- ecsm_update(&ecsm_config);
- }
- break;
- }
- case id_actuation_threshold: {
- apc.apc_actuation_level = value_data[0];
- for (uint8_t row = 0; row < MATRIX_ROWS; row++) {
- for (uint8_t col = 0; col < MATRIX_COLS; col++) {
- ecsm_config.low_threshold_matrix[row][col] = apc.apc_actuation_level * 4;
- }
- }
- ecsm_update(&ecsm_config);
- uprintf("APC ACTUATION LEVEL: %4d\n", apc.apc_actuation_level * 4);
- break;
- }
- case id_deactuation_threshold: {
- apc.apc_deactuation_level = value_data[0];
- for (uint8_t row = 0; row < MATRIX_ROWS; row++) {
- for (uint8_t col = 0; col < MATRIX_COLS; col++) {
- ecsm_config.high_threshold_matrix[row][col] = apc.apc_deactuation_level * 4;
- }
- }
- ecsm_update(&ecsm_config);
- uprintf("APC DEACTUATION LEVEL: %4d\n", apc.apc_deactuation_level * 4);
- break;
- }
- }
-}
-
-void apc_config_get_value(uint8_t *data) {
- // data = [ value_id, value_data ]
- uint8_t *value_id = &(data[0]);
- uint8_t *value_data = &(data[1]);
-
- switch (*value_id) {
- case id_apc_enable: {
- value_data[0] = apc.apc_enabled;
- break;
- }
- case id_actuation_threshold: {
- value_data[0] = apc.apc_actuation_level;
- break;
- }
- case id_deactuation_threshold: {
- value_data[0] = apc.apc_deactuation_level;
- break;
- }
- }
-}
-
-void apc_config_save(void) {
- eeconfig_update_kb_datablock(&apc);
-}
-
-void via_custom_value_command_kb(uint8_t *data, uint8_t length) {
- // data = [ command_id, channel_id, value_id, value_data ]
- uint8_t *command_id = &(data[0]);
- uint8_t *channel_id = &(data[1]);
- uint8_t *value_id_and_data = &(data[2]);
-
- if (*channel_id == id_custom_channel) {
- switch (*command_id) {
- case id_custom_set_value: {
- apc_config_set_value(value_id_and_data);
- break;
- }
- case id_custom_get_value: {
- apc_config_get_value(value_id_and_data);
- break;
- }
- case id_custom_save: {
- apc_config_save();
- break;
- }
- default: {
- // Unhandled message.
- *command_id = id_unhandled;
- break;
- }
- }
- return;
- }
-
- *command_id = id_unhandled;
-}
diff --git a/keyboards/cipulot/alveus/alveus.h b/keyboards/cipulot/alveus/alveus.h
deleted file mode 100644
index c8d83c05bbfd..000000000000
--- a/keyboards/cipulot/alveus/alveus.h
+++ /dev/null
@@ -1,37 +0,0 @@
-/* Copyright 2023 Cipulot
- *
- * 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 .
- */
-
-#pragma once
-
-#include "quantum.h"
-
-#define ___ KC_NO
-
-// clang-format off
-#define LAYOUT( \
- k00, k01, k02, k03, k04, k05, k06, k07, k08, k09, k0A, k0B, k0C, k0D, k0E, k0F, k1F, \
- k10, k11, k12, k13, k14, k15, k16, k17, k18, k19, k1A, k1B, k1C, k1D, k1E, k2E, k2F, \
- k20, k21, k22, k23, k24, k25, k26, k27, k28, k29, k2A, k2B, k2D, \
- k30, k31, k32, k33, k34, k35, k36, k37, k38, k39, k3A, k3D, k3E, \
- k40, k41, k42, k45, k5B, k5C, k5D, k5E, k5F, k3F \
-) { \
- { k00, k01, k02, k03, k04, k05, k06, k07, k08, k09, k0A, k0B, k0C, k0D, k0E, k0F }, \
- { k10, k11, k12, k13, k14, k15, k16, k17, k18, k19, k1A, k1B, k1C, k1D, k1E, k1F }, \
- { k20, k21, k22, k23, k24, k25, k26, k27, k28, k29, k2A, k2B, ___, k2D, k2E, k2F }, \
- { k30, k31, k32, k33, k34, k35, k36, k37, k38, k39, k3A, ___, ___, k3D, k3E, k3F }, \
- { k40, k41, k42, ___, ___, k45, ___, ___, ___, ___, ___, k5B, k5C, k5D, k5E, k5F } \
-}
-// clang-format on
diff --git a/keyboards/cipulot/alveus/info.json b/keyboards/cipulot/alveus/info.json
deleted file mode 100644
index f799a44de628..000000000000
--- a/keyboards/cipulot/alveus/info.json
+++ /dev/null
@@ -1,379 +0,0 @@
-{
- "keyboard_name": "Alveus",
- "manufacturer": "Cipulot",
- "url": "",
- "maintainer": "Cipulot",
- "usb": {
- "vid": "0x6369",
- "pid": "0x6B90",
- "device_version": "0.0.1"
- },
- "layouts": {
- "LAYOUT": {
- "layout": [
- {
- "label": "0,0",
- "x": 0,
- "y": 0
- },
- {
- "label": "0,1",
- "x": 1,
- "y": 0
- },
- {
- "label": "0,2",
- "x": 2,
- "y": 0
- },
- {
- "label": "0,3",
- "x": 3,
- "y": 0
- },
- {
- "label": "0,4",
- "x": 4,
- "y": 0
- },
- {
- "label": "0,5",
- "x": 5,
- "y": 0
- },
- {
- "label": "0,6",
- "x": 6,
- "y": 0
- },
- {
- "label": "0,7",
- "x": 7,
- "y": 0
- },
- {
- "label": "0,8",
- "x": 8,
- "y": 0
- },
- {
- "label": "0,9",
- "x": 9,
- "y": 0
- },
- {
- "label": "0,10",
- "x": 10,
- "y": 0
- },
- {
- "label": "0,11",
- "x": 11,
- "y": 0
- },
- {
- "label": "0,12",
- "x": 12,
- "y": 0
- },
- {
- "label": "0,13",
- "x": 13,
- "y": 0,
- "w": 2
- },
- {
- "label": "0,14",
- "x": 15.25,
- "y": 0
- },
- {
- "label": "0,15",
- "x": 16.25,
- "y": 0
- },
- {
- "label": "1,15",
- "x": 17.25,
- "y": 0
- },
- {
- "label": "1,0",
- "x": 0,
- "y": 1,
- "w": 1.5
- },
- {
- "label": "1,1",
- "x": 1.5,
- "y": 1
- },
- {
- "label": "1,2",
- "x": 2.5,
- "y": 1
- },
- {
- "label": "1,3",
- "x": 3.5,
- "y": 1
- },
- {
- "label": "1,4",
- "x": 4.5,
- "y": 1
- },
- {
- "label": "1,5",
- "x": 5.5,
- "y": 1
- },
- {
- "label": "1,6",
- "x": 6.5,
- "y": 1
- },
- {
- "label": "1,7",
- "x": 7.5,
- "y": 1
- },
- {
- "label": "1,8",
- "x": 8.5,
- "y": 1
- },
- {
- "label": "1,9",
- "x": 9.5,
- "y": 1
- },
- {
- "label": "1,10",
- "x": 10.5,
- "y": 1
- },
- {
- "label": "1,11",
- "x": 11.5,
- "y": 1
- },
- {
- "label": "1,12",
- "x": 12.5,
- "y": 1
- },
- {
- "label": "1,13",
- "x": 13.5,
- "y": 1,
- "w": 1.5
- },
- {
- "label": "1,14",
- "x": 15.25,
- "y": 1
- },
- {
- "label": "2,14",
- "x": 16.25,
- "y": 1
- },
- {
- "label": "2,15",
- "x": 17.25,
- "y": 1
- },
- {
- "label": "2,0",
- "x": 0,
- "y": 2,
- "w": 1.75
- },
- {
- "label": "2,1",
- "x": 1.75,
- "y": 2
- },
- {
- "label": "2,2",
- "x": 2.75,
- "y": 2
- },
- {
- "label": "2,3",
- "x": 3.75,
- "y": 2
- },
- {
- "label": "2,4",
- "x": 4.75,
- "y": 2
- },
- {
- "label": "2,5",
- "x": 5.75,
- "y": 2
- },
- {
- "label": "2,6",
- "x": 6.75,
- "y": 2
- },
- {
- "label": "2,7",
- "x": 7.75,
- "y": 2
- },
- {
- "label": "2,8",
- "x": 8.75,
- "y": 2
- },
- {
- "label": "2,9",
- "x": 9.75,
- "y": 2
- },
- {
- "label": "2,10",
- "x": 10.75,
- "y": 2
- },
- {
- "label": "2,11",
- "x": 11.75,
- "y": 2
- },
- {
- "label": "2,13",
- "x": 12.75,
- "y": 2,
- "w": 2.25
- },
- {
- "label": "3,0",
- "x": 0,
- "y": 3,
- "w": 2.25
- },
- {
- "label": "3,1",
- "x": 2.25,
- "y": 3
- },
- {
- "label": "3,2",
- "x": 3.25,
- "y": 3
- },
- {
- "label": "3,3",
- "x": 4.25,
- "y": 3
- },
- {
- "label": "3,4",
- "x": 5.25,
- "y": 3
- },
- {
- "label": "3,5",
- "x": 6.25,
- "y": 3
- },
- {
- "label": "3,6",
- "x": 7.25,
- "y": 3
- },
- {
- "label": "3,7",
- "x": 8.25,
- "y": 3
- },
- {
- "label": "3,8",
- "x": 9.25,
- "y": 3
- },
- {
- "label": "3,9",
- "x": 10.25,
- "y": 3
- },
- {
- "label": "3,10",
- "x": 11.25,
- "y": 3
- },
- {
- "label": "3,13",
- "x": 12.25,
- "y": 3,
- "w": 2.75
- },
- {
- "label": "3,14",
- "x": 16.25,
- "y": 3
- },
- {
- "label": "4,0",
- "x": 0,
- "y": 4,
- "w": 1.5
- },
- {
- "label": "4,1",
- "x": 1.5,
- "y": 4
- },
- {
- "label": "4,2",
- "x": 2.5,
- "y": 4,
- "w": 1.5
- },
- {
- "label": "4,5",
- "x": 4,
- "y": 4,
- "w": 7
- },
- {
- "label": "4,11",
- "x": 11,
- "y": 4,
- "w": 1.5
- },
- {
- "label": "4,12",
- "x": 12.5,
- "y": 4
- },
- {
- "label": "4,13",
- "x": 13.5,
- "y": 4,
- "w": 1.5
- },
- {
- "label": "4,14",
- "x": 15.25,
- "y": 4
- },
- {
- "label": "4,15",
- "x": 16.25,
- "y": 4
- },
- {
- "label": "3,15",
- "x": 17.25,
- "y": 4
- }
- ]
- }
- }
-}
diff --git a/keyboards/cipulot/alveus/keymaps/via/alveus.json b/keyboards/cipulot/alveus/keymaps/via/alveus.json
deleted file mode 100644
index 96f4151be652..000000000000
--- a/keyboards/cipulot/alveus/keymaps/via/alveus.json
+++ /dev/null
@@ -1,240 +0,0 @@
-{
- "name": "Alveus",
- "vendorId": "0x6369",
- "productId": "0x6B90",
- "menus": [
- {
- "label": "EC Tools",
- "content": [
- {
- "label": "Whole",
- "content":[
- {
- "label": "Enable APC",
- "type": "toggle",
- "content": ["id_apc_enable", 0, 1]
- },
- {
- "showIf": "{id_apc_enable} == 1",
- "label": "Actuation Level",
- "type": "range",
- "options": [0, 255],
- "content": ["id_actuation_threshold", 0, 2]
- },
- {
- "showIf": "{id_apc_enable} == 1",
- "label": "Deactuation Level",
- "type": "range",
- "options": [0, 255],
- "content": ["id_deactuation_threshold", 0, 3]
- }
- ]
- }
- ]
- }
- ],
- "matrix": {
- "rows": 5,
- "cols": 16
- },
- "layouts": {
- "labels": [
- [
- "Bottom row",
- "WKL",
- "WK"
- ]
- ],
- "keymap": [
- [
- {
- "c": "#777777"
- },
- "0,0",
- {
- "c": "#cccccc"
- },
- "0,1",
- "0,2",
- "0,3",
- "0,4",
- "0,5",
- "0,6",
- "0,7",
- "0,8",
- "0,9",
- "0,10",
- "0,11",
- "0,12",
- {
- "c": "#aaaaaa",
- "w": 2
- },
- "0,13",
- {
- "x": 0.25,
- "c": "#cccccc"
- },
- "0,14",
- "0,15",
- "1,15"
- ],
- [
- {
- "c": "#aaaaaa",
- "w": 1.5
- },
- "1,0",
- {
- "c": "#cccccc"
- },
- "1,1",
- "1,2",
- "1,3",
- "1,4",
- "1,5",
- "1,6",
- "1,7",
- "1,8",
- "1,9",
- "1,10",
- "1,11",
- "1,12",
- {
- "w": 1.5
- },
- "1,13",
- {
- "x": 0.25
- },
- "1,14",
- "2,14",
- "2,15"
- ],
- [
- {
- "c": "#aaaaaa",
- "w": 1.75
- },
- "2,0",
- {
- "c": "#cccccc"
- },
- "2,1",
- "2,2",
- "2,3",
- "2,4",
- "2,5",
- "2,6",
- "2,7",
- "2,8",
- "2,9",
- "2,10",
- "2,11",
- {
- "c": "#777777",
- "w": 2.25
- },
- "2,13"
- ],
- [
- {
- "c": "#aaaaaa",
- "w": 2.25
- },
- "3,0",
- {
- "c": "#cccccc"
- },
- "3,1",
- "3,2",
- "3,3",
- "3,4",
- "3,5",
- "3,6",
- "3,7",
- "3,8",
- "3,9",
- "3,10",
- {
- "c": "#aaaaaa",
- "w": 2.75
- },
- "3,13",
- {
- "x": 1.25,
- "c": "#cccccc"
- },
- "3,14"
- ],
- [
- {
- "c": "#aaaaaa",
- "w": 1.5
- },
- "4,0\n\n\n0,0",
- {
- "d": true
- },
- "\n\n\n0,0",
- {
- "w": 1.5
- },
- "4,2\n\n\n0,0",
- {
- "c": "#cccccc",
- "w": 7
- },
- "4,5\n\n\n0,0",
- {
- "c": "#aaaaaa",
- "w": 1.5
- },
- "4,11\n\n\n0,0",
- {
- "d": true
- },
- "\n\n\n0,0",
- {
- "w": 1.5
- },
- "4,13\n\n\n0,0",
- {
- "x": 0.25,
- "c": "#cccccc"
- },
- "4,14",
- "4,15",
- "3,15"
- ],
- [
- {
- "y": 0.25,
- "c": "#aaaaaa",
- "w": 1.5
- },
- "4,0\n\n\n0,1",
- "4,1\n\n\n0,1",
- {
- "w": 1.5
- },
- "4,2\n\n\n0,1",
- {
- "c": "#cccccc",
- "w": 7
- },
- "4,5\n\n\n0,1",
- {
- "c": "#aaaaaa",
- "w": 1.5
- },
- "4,11\n\n\n0,1",
- "4,12\n\n\n0,1",
- {
- "w": 1.5
- },
- "4,13\n\n\n0,1"
- ]
- ]
- }
-}
diff --git a/keyboards/cipulot/alveus/keymaps/via/rules.mk b/keyboards/cipulot/alveus/keymaps/via/rules.mk
deleted file mode 100644
index 1e5b99807cb7..000000000000
--- a/keyboards/cipulot/alveus/keymaps/via/rules.mk
+++ /dev/null
@@ -1 +0,0 @@
-VIA_ENABLE = yes
diff --git a/keyboards/cipulot/alveus/matrix.c b/keyboards/cipulot/alveus/matrix.c
deleted file mode 100644
index 7fea2614f925..000000000000
--- a/keyboards/cipulot/alveus/matrix.c
+++ /dev/null
@@ -1,67 +0,0 @@
-/* Copyright 2023 Cipulot
- *
- * 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 .
- */
-
-#include "ec_switch_matrix.h"
-#include "matrix.h"
-#include "debug.h"
-
-/* matrix state(1:on, 0:off) */
-extern matrix_row_t raw_matrix[MATRIX_ROWS]; // raw values
-extern matrix_row_t matrix[MATRIX_ROWS]; // debounced values
-
-// clang-format off
-const uint16_t low_threshold[MATRIX_ROWS][MATRIX_COLS] = {
- { 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700 }, \
- { 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700 }, \
- { 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700 }, \
- { 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700 }, \
- { 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700, 700 } \
-};
-const uint16_t high_threshold[MATRIX_ROWS][MATRIX_COLS] = {
- { 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650 }, \
- { 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650 }, \
- { 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650 }, \
- { 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650 }, \
- { 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650, 650 } \
-};
-// clang-format on
-
-void matrix_init_custom(void) {
- ecsm_config_t ecsm_config;
-
- for (uint8_t row = 0; row < MATRIX_ROWS; row++) {
- for (uint8_t col = 0; col < MATRIX_COLS; col++) {
- ecsm_config.low_threshold_matrix[row][col] = 700;
- ecsm_config.high_threshold_matrix[row][col] = 650;
- }
- }
-
- ecsm_init(&ecsm_config);
-}
-
-bool matrix_scan_custom(matrix_row_t current_matrix[]) {
- bool updated = ecsm_matrix_scan(current_matrix);
-
-// RAW matrix values on console
-#ifdef CONSOLE_ENABLE
- static int cnt = 0;
- if (cnt++ == 1000) {
- cnt = 0;
- ecsm_print_matrix();
- }
-#endif
- return updated;
-}
diff --git a/keyboards/cipulot/alveus/readme.md b/keyboards/cipulot/alveus/readme.md
deleted file mode 100644
index 36fd1f3a13b4..000000000000
--- a/keyboards/cipulot/alveus/readme.md
+++ /dev/null
@@ -1,21 +0,0 @@
-# Alveus
-
-EC FRL TKL keyboard.
-
-* Keyboard Maintainer: [cipulot](https://github.com/cipulot)
-* Hardware Supported: Alveus
-* Hardware Availability: TBD
-
-Make example for this keyboard (after setting up your build environment):
-
- make cipulot/alveus:default
- make cipulot/alveus:via
- make cipulot/alveus:vial
-
-Flashing example for this keyboard:
-
- make cipulot/alveus:default:flash
- make cipulot/alveus:via:flash
- make cipulot/alveus:vial:flash
-
-See the [build environment setup](https://docs.qmk.fm/#/getting_started_build_tools) and the [make instructions](https://docs.qmk.fm/#/getting_started_make_guide) for more information. Brand new to QMK? Start with our [Complete Newbs Guide](https://docs.qmk.fm/#/newbs).
diff --git a/keyboards/cipulot/alveus/rules.mk b/keyboards/cipulot/alveus/rules.mk
deleted file mode 100644
index 1a62de2b4e12..000000000000
--- a/keyboards/cipulot/alveus/rules.mk
+++ /dev/null
@@ -1,25 +0,0 @@
-# MCU name
-MCU = STM32F401
-
-BOARD = GENERIC_STM32_F401XC
-
-# Bootloader selection
-BOOTLOADER = stm32-dfu
-
-KEYBOARD_SHARED_EP = yes
-
-CUSTOM_MATRIX = lite
-SRC += analog.c matrix.c ec_switch_matrix.c
-
-# Build Options
-# change yes to no to disable
-#
-BOOTMAGIC_ENABLE = yes # Enable Bootmagic Lite
-MOUSEKEY_ENABLE = yes # Mouse keys
-EXTRAKEY_ENABLE = yes # Audio control and System control
-CONSOLE_ENABLE = yes # Console for debug
-COMMAND_ENABLE = no # Commands for debug and configuration
-NKRO_ENABLE = yes # Enable N-Key Rollover
-BACKLIGHT_ENABLE = no # Enable keyboard backlight functionality
-RGBLIGHT_ENABLE = no # Enable keyboard RGB underglow
-AUDIO_ENABLE = no # Audio output
diff --git a/keyboards/cipulot/alveus/config.h b/keyboards/cipulot/ec_alveus/1_0_0/config.h
similarity index 90%
rename from keyboards/cipulot/alveus/config.h
rename to keyboards/cipulot/ec_alveus/1_0_0/config.h
index 25672ae46db1..1947c308026d 100644
--- a/keyboards/cipulot/alveus/config.h
+++ b/keyboards/cipulot/ec_alveus/1_0_0/config.h
@@ -16,9 +16,6 @@
#pragma once
-#include "config_common.h"
-
-/* key matrix size */
#define MATRIX_ROWS 5
#define MATRIX_COLS 16
@@ -36,13 +33,13 @@
#define DISCHARGE_PIN B1
#define ANALOG_PORT A3
-/* COL2ROW, ROW2COL */
-#define DIODE_DIRECTION COL2ROW
-
/* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */
#define LOCKING_SUPPORT_ENABLE
/* Locking resynchronize hack */
#define LOCKING_RESYNC_ENABLE
-#define EECONFIG_KB_DATA_SIZE 3
+#define DEFAULT_ACTUATION_LEVEL 550
+#define DEFAULT_RELEASE_LEVEL 500
+
+#define DISCHARGE_TIME 10
diff --git a/keyboards/cipulot/alveus/ec_switch_matrix.c b/keyboards/cipulot/ec_alveus/1_0_0/ec_switch_matrix.c
similarity index 85%
rename from keyboards/cipulot/alveus/ec_switch_matrix.c
rename to keyboards/cipulot/ec_alveus/1_0_0/ec_switch_matrix.c
index 9a3f89b2c25b..783c00457c78 100644
--- a/keyboards/cipulot/alveus/ec_switch_matrix.c
+++ b/keyboards/cipulot/ec_alveus/1_0_0/ec_switch_matrix.c
@@ -15,14 +15,10 @@
*/
#include "ec_switch_matrix.h"
-
-#include "quantum.h"
#include "analog.h"
#include "atomic_util.h"
#include "print.h"
-
-#define WAIT_DISCHARGE()
-#define WAIT_CHARGE()
+#include "wait.h"
/* Pin and port array */
const uint32_t row_pins[] = MATRIX_ROW_PINS;
@@ -42,12 +38,6 @@ static inline void charge_capacitor(uint8_t row) {
writePinHigh(row_pins[row]);
}
-static inline void clear_all_row_pins(void) {
- for (int row = 0; row < MATRIX_ROWS; row++) {
- writePinLow(row_pins[row]);
- }
-}
-
static inline void init_mux_sel(void) {
for (int idx = 0; idx < 3; idx++) {
setPinOutput(mux_sel_pins[idx]);
@@ -70,12 +60,15 @@ static inline void init_row(void) {
/* Initialize the peripherals pins */
int ecsm_init(ecsm_config_t const* const ecsm_config) {
- // Save config
+ // Initialize config
config = *ecsm_config;
palSetLineMode(ANALOG_PORT, PAL_MODE_INPUT_ANALOG);
adcMux = pinToMux(ANALOG_PORT);
+ // Dummy call to make sure that adcStart() has been called in the appropriate state
+ adc_read(adcMux);
+
// Initialize discharge pin as discharge mode
writePinLow(DISCHARGE_PIN);
setPinOutputOpenDrain(DISCHARGE_PIN);
@@ -102,7 +95,7 @@ int ecsm_update(ecsm_config_t const* const ecsm_config) {
}
// Read the capacitive sensor value
-static uint16_t ecsm_readkey_raw(uint8_t channel, uint8_t row, uint8_t col) {
+uint16_t ecsm_readkey_raw(uint8_t channel, uint8_t row, uint8_t col) {
uint16_t sw_value = 0;
// Select the multiplexer
@@ -118,34 +111,32 @@ static uint16_t ecsm_readkey_raw(uint8_t channel, uint8_t row, uint8_t col) {
// Set strobe pins to low state
writePinLow(row_pins[row]);
-
ATOMIC_BLOCK_FORCEON {
// Set the row pin to high state and have capacitor charge
charge_capacitor(row);
-
- WAIT_CHARGE();
+ // Read the ADC value
sw_value = adc_read(adcMux);
}
-
// Discharge peak hold capacitor
discharge_capacitor();
- WAIT_DISCHARGE();
+ // Waiting for the ghost capacitor to discharge fully
+ wait_us(DISCHARGE_TIME);
return sw_value;
}
-// Update press/release state of key at (row, col)
-static bool ecsm_update_key(matrix_row_t* current_row, uint8_t row, uint8_t col, uint16_t sw_value) {
+// Update press/release state of key
+bool ecsm_update_key(matrix_row_t* current_row, uint8_t row, uint8_t col, uint16_t sw_value) {
bool current_state = (*current_row >> col) & 1;
- // press to release
- if (current_state && sw_value < config.low_threshold_matrix[row][col]) {
+ // Press to release
+ if (current_state && sw_value < config.ecsm_actuation_threshold) {
*current_row &= ~(1 << col);
return true;
}
- // release to press
- if ((!current_state) && sw_value > config.high_threshold_matrix[row][col]) {
+ // Release to press
+ if ((!current_state) && sw_value > config.ecsm_release_threshold) {
*current_row |= (1 << col);
return true;
}
@@ -182,7 +173,7 @@ void ecsm_print_matrix(void) {
for (int row = 0; row < MATRIX_ROWS; row++) {
for (int col = 0; col < MATRIX_COLS; col++) {
uprintf("%4d", ecsm_sw_value[row][col]);
- if (col < MATRIX_COLS - 1) {
+ if (col < (MATRIX_COLS - 1)) {
print(",");
}
}
diff --git a/keyboards/cipulot/alveus/ec_switch_matrix.h b/keyboards/cipulot/ec_alveus/1_0_0/ec_switch_matrix.h
similarity index 60%
rename from keyboards/cipulot/alveus/ec_switch_matrix.h
rename to keyboards/cipulot/ec_alveus/1_0_0/ec_switch_matrix.h
index 95846224ba6f..9dcb216caa3f 100644
--- a/keyboards/cipulot/alveus/ec_switch_matrix.h
+++ b/keyboards/cipulot/ec_alveus/1_0_0/ec_switch_matrix.h
@@ -22,21 +22,15 @@
#include "matrix.h"
typedef struct {
- uint16_t low_threshold_matrix[MATRIX_ROWS][MATRIX_COLS]; // threshold for key release
- uint16_t high_threshold_matrix[MATRIX_ROWS][MATRIX_COLS]; // threshold for key press
+ uint16_t ecsm_actuation_threshold; // threshold for key release
+ uint16_t ecsm_release_threshold; // threshold for key press
} ecsm_config_t;
ecsm_config_t ecsm_config;
-int ecsm_init(ecsm_config_t const* const ecsm_config);
-int ecsm_update(ecsm_config_t const* const ecsm_config);
-bool ecsm_matrix_scan(matrix_row_t current_matrix[]);
-void ecsm_print_matrix(void);
-
-typedef struct _apc_config_t {
- bool apc_enabled;
- uint8_t apc_actuation_level;
- uint8_t apc_deactuation_level;
-} apc_config;
-
-apc_config apc;
+int ecsm_init(ecsm_config_t const* const ecsm_config);
+int ecsm_update(ecsm_config_t const* const ecsm_config);
+bool ecsm_matrix_scan(matrix_row_t current_matrix[]);
+uint16_t ecsm_readkey_raw(uint8_t channel, uint8_t row, uint8_t col);
+bool ecsm_update_key(matrix_row_t* current_row, uint8_t row, uint8_t col, uint16_t sw_value);
+void ecsm_print_matrix(void);
diff --git a/keyboards/cipulot/alveus/halconf.h b/keyboards/cipulot/ec_alveus/1_0_0/halconf.h
similarity index 100%
rename from keyboards/cipulot/alveus/halconf.h
rename to keyboards/cipulot/ec_alveus/1_0_0/halconf.h
diff --git a/keyboards/cipulot/ec_alveus/1_0_0/info.json b/keyboards/cipulot/ec_alveus/1_0_0/info.json
new file mode 100644
index 000000000000..3e1954608917
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_0_0/info.json
@@ -0,0 +1,181 @@
+{
+ "manufacturer": "Cipulot",
+ "keyboard_name": "EC Alveus 1.0.0",
+ "maintainer": "Cipulot",
+ "bootloader": "stm32-dfu",
+ "build": {
+ "lto": true
+ },
+ "diode_direction": "COL2ROW",
+ "features": {
+ "audio": false,
+ "backlight": false,
+ "bootmagic": true,
+ "command": false,
+ "console": true,
+ "extrakey": true,
+ "mousekey": true,
+ "nkro": true,
+ "rgblight": false
+ },
+ "mouse_key": {
+ "enabled": true
+ },
+ "processor": "STM32F401",
+ "usb": {
+ "device_version": "1.0.0",
+ "pid": "0x6BA4",
+ "shared_endpoint": {
+ "keyboard": true
+ },
+ "vid": "0x6369"
+ },
+ "layouts": {
+ "LAYOUT_all": {
+ "layout": [
+ { "label": "0,0", "matrix": [0, 0], "x": 0, "y": 0 },
+ { "label": "0,1", "matrix": [0, 1], "x": 1, "y": 0 },
+ { "label": "0,2", "matrix": [0, 2], "x": 2, "y": 0 },
+ { "label": "0,3", "matrix": [0, 3], "x": 3, "y": 0 },
+ { "label": "0,4", "matrix": [0, 4], "x": 4, "y": 0 },
+ { "label": "0,5", "matrix": [0, 5], "x": 5, "y": 0 },
+ { "label": "0,6", "matrix": [0, 6], "x": 6, "y": 0 },
+ { "label": "0,7", "matrix": [0, 7], "x": 7, "y": 0 },
+ { "label": "0,8", "matrix": [0, 8], "x": 8, "y": 0 },
+ { "label": "0,9", "matrix": [0, 9], "x": 9, "y": 0 },
+ { "label": "0,10", "matrix": [0, 10], "x": 10, "y": 0 },
+ { "label": "0,11", "matrix": [0, 11], "x": 11, "y": 0 },
+ { "label": "0,12", "matrix": [0, 12], "x": 12, "y": 0 },
+ { "label": "0,13", "matrix": [0, 13], "w": 2, "x": 13, "y": 0 },
+ { "label": "0,14", "matrix": [0, 14], "x": 15.25, "y": 0 },
+ { "label": "0,15", "matrix": [0, 15], "x": 16.25, "y": 0 },
+ { "label": "1,15", "matrix": [1, 15], "x": 17.25, "y": 0 },
+ { "label": "1,0", "matrix": [1, 0], "w": 1.5, "x": 0, "y": 1 },
+ { "label": "1,1", "matrix": [1, 1], "x": 1.5, "y": 1 },
+ { "label": "1,2", "matrix": [1, 2], "x": 2.5, "y": 1 },
+ { "label": "1,3", "matrix": [1, 3], "x": 3.5, "y": 1 },
+ { "label": "1,4", "matrix": [1, 4], "x": 4.5, "y": 1 },
+ { "label": "1,5", "matrix": [1, 5], "x": 5.5, "y": 1 },
+ { "label": "1,6", "matrix": [1, 6], "x": 6.5, "y": 1 },
+ { "label": "1,7", "matrix": [1, 7], "x": 7.5, "y": 1 },
+ { "label": "1,8", "matrix": [1, 8], "x": 8.5, "y": 1 },
+ { "label": "1,9", "matrix": [1, 9], "x": 9.5, "y": 1 },
+ { "label": "1,10", "matrix": [1, 10], "x": 10.5, "y": 1 },
+ { "label": "1,11", "matrix": [1, 11], "x": 11.5, "y": 1 },
+ { "label": "1,12", "matrix": [1, 12], "x": 12.5, "y": 1 },
+ { "label": "1,13", "matrix": [1, 13], "w": 1.5, "x": 13.5, "y": 1 },
+ { "label": "1,14", "matrix": [1, 14], "x": 15.25, "y": 1 },
+ { "label": "2,14", "matrix": [2, 14], "x": 16.25, "y": 1 },
+ { "label": "2,15", "matrix": [2, 15], "x": 17.25, "y": 1 },
+ { "label": "2,0", "matrix": [2, 0], "w": 1.75, "x": 0, "y": 2 },
+ { "label": "2,1", "matrix": [2, 1], "x": 1.75, "y": 2 },
+ { "label": "2,2", "matrix": [2, 2], "x": 2.75, "y": 2 },
+ { "label": "2,3", "matrix": [2, 3], "x": 3.75, "y": 2 },
+ { "label": "2,4", "matrix": [2, 4], "x": 4.75, "y": 2 },
+ { "label": "2,5", "matrix": [2, 5], "x": 5.75, "y": 2 },
+ { "label": "2,6", "matrix": [2, 6], "x": 6.75, "y": 2 },
+ { "label": "2,7", "matrix": [2, 7], "x": 7.75, "y": 2 },
+ { "label": "2,8", "matrix": [2, 8], "x": 8.75, "y": 2 },
+ { "label": "2,9", "matrix": [2, 9], "x": 9.75, "y": 2 },
+ { "label": "2,10", "matrix": [2, 10], "x": 10.75, "y": 2 },
+ { "label": "2,11", "matrix": [2, 11], "x": 11.75, "y": 2 },
+ { "label": "2,13", "matrix": [2, 13], "w": 2.25, "x": 12.75, "y": 2 },
+ { "label": "3,0", "matrix": [3, 0], "w": 2.25, "x": 0, "y": 3 },
+ { "label": "3,1", "matrix": [3, 1], "x": 2.25, "y": 3 },
+ { "label": "3,2", "matrix": [3, 2], "x": 3.25, "y": 3 },
+ { "label": "3,3", "matrix": [3, 3], "x": 4.25, "y": 3 },
+ { "label": "3,4", "matrix": [3, 4], "x": 5.25, "y": 3 },
+ { "label": "3,5", "matrix": [3, 5], "x": 6.25, "y": 3 },
+ { "label": "3,6", "matrix": [3, 6], "x": 7.25, "y": 3 },
+ { "label": "3,7", "matrix": [3, 7], "x": 8.25, "y": 3 },
+ { "label": "3,8", "matrix": [3, 8], "x": 9.25, "y": 3 },
+ { "label": "3,9", "matrix": [3, 9], "x": 10.25, "y": 3 },
+ { "label": "3,10", "matrix": [3, 10], "x": 11.25, "y": 3 },
+ { "label": "3,13", "matrix": [3, 13], "w": 2.75, "x": 12.25, "y": 3 },
+ { "label": "3,14", "matrix": [3, 14], "x": 16.25, "y": 3 },
+ { "label": "4,0", "matrix": [4, 0], "w": 1.5, "x": 0, "y": 4 },
+ { "label": "4,1", "matrix": [4, 1], "x": 1.5, "y": 4 },
+ { "label": "4,2", "matrix": [4, 2], "w": 1.5, "x": 2.5, "y": 4 },
+ { "label": "4,5", "matrix": [4, 5], "w": 7, "x": 4, "y": 4 },
+ { "label": "4,11", "matrix": [4, 11], "w": 1.5, "x": 11, "y": 4 },
+ { "label": "4,12", "matrix": [4, 12], "x": 12.5, "y": 4 },
+ { "label": "4,13", "matrix": [4, 13], "w": 1.5, "x": 13.5, "y": 4 },
+ { "label": "4,14", "matrix": [4, 14], "x": 15.25, "y": 4 },
+ { "label": "4,15", "matrix": [4, 15], "x": 16.25, "y": 4 },
+ { "label": "3,15", "matrix": [3, 15], "x": 17.25, "y": 4 }
+ ]
+ },
+ "LAYOUT_tkl_nofrow_ansi_tsangan_wkl": {
+ "layout": [
+ { "label": "0,0", "matrix": [0, 0], "x": 0, "y": 0 },
+ { "label": "0,1", "matrix": [0, 1], "x": 1, "y": 0 },
+ { "label": "0,2", "matrix": [0, 2], "x": 2, "y": 0 },
+ { "label": "0,3", "matrix": [0, 3], "x": 3, "y": 0 },
+ { "label": "0,4", "matrix": [0, 4], "x": 4, "y": 0 },
+ { "label": "0,5", "matrix": [0, 5], "x": 5, "y": 0 },
+ { "label": "0,6", "matrix": [0, 6], "x": 6, "y": 0 },
+ { "label": "0,7", "matrix": [0, 7], "x": 7, "y": 0 },
+ { "label": "0,8", "matrix": [0, 8], "x": 8, "y": 0 },
+ { "label": "0,9", "matrix": [0, 9], "x": 9, "y": 0 },
+ { "label": "0,10", "matrix": [0, 10], "x": 10, "y": 0 },
+ { "label": "0,11", "matrix": [0, 11], "x": 11, "y": 0 },
+ { "label": "0,12", "matrix": [0, 12], "x": 12, "y": 0 },
+ { "label": "0,13", "matrix": [0, 13], "w": 2, "x": 13, "y": 0 },
+ { "label": "0,14", "matrix": [0, 14], "x": 15.25, "y": 0 },
+ { "label": "0,15", "matrix": [0, 15], "x": 16.25, "y": 0 },
+ { "label": "1,15", "matrix": [1, 15], "x": 17.25, "y": 0 },
+ { "label": "1,0", "matrix": [1, 0], "w": 1.5, "x": 0, "y": 1 },
+ { "label": "1,1", "matrix": [1, 1], "x": 1.5, "y": 1 },
+ { "label": "1,2", "matrix": [1, 2], "x": 2.5, "y": 1 },
+ { "label": "1,3", "matrix": [1, 3], "x": 3.5, "y": 1 },
+ { "label": "1,4", "matrix": [1, 4], "x": 4.5, "y": 1 },
+ { "label": "1,5", "matrix": [1, 5], "x": 5.5, "y": 1 },
+ { "label": "1,6", "matrix": [1, 6], "x": 6.5, "y": 1 },
+ { "label": "1,7", "matrix": [1, 7], "x": 7.5, "y": 1 },
+ { "label": "1,8", "matrix": [1, 8], "x": 8.5, "y": 1 },
+ { "label": "1,9", "matrix": [1, 9], "x": 9.5, "y": 1 },
+ { "label": "1,10", "matrix": [1, 10], "x": 10.5, "y": 1 },
+ { "label": "1,11", "matrix": [1, 11], "x": 11.5, "y": 1 },
+ { "label": "1,12", "matrix": [1, 12], "x": 12.5, "y": 1 },
+ { "label": "1,13", "matrix": [1, 13], "w": 1.5, "x": 13.5, "y": 1 },
+ { "label": "1,14", "matrix": [1, 14], "x": 15.25, "y": 1 },
+ { "label": "2,14", "matrix": [2, 14], "x": 16.25, "y": 1 },
+ { "label": "2,15", "matrix": [2, 15], "x": 17.25, "y": 1 },
+ { "label": "2,0", "matrix": [2, 0], "w": 1.75, "x": 0, "y": 2 },
+ { "label": "2,1", "matrix": [2, 1], "x": 1.75, "y": 2 },
+ { "label": "2,2", "matrix": [2, 2], "x": 2.75, "y": 2 },
+ { "label": "2,3", "matrix": [2, 3], "x": 3.75, "y": 2 },
+ { "label": "2,4", "matrix": [2, 4], "x": 4.75, "y": 2 },
+ { "label": "2,5", "matrix": [2, 5], "x": 5.75, "y": 2 },
+ { "label": "2,6", "matrix": [2, 6], "x": 6.75, "y": 2 },
+ { "label": "2,7", "matrix": [2, 7], "x": 7.75, "y": 2 },
+ { "label": "2,8", "matrix": [2, 8], "x": 8.75, "y": 2 },
+ { "label": "2,9", "matrix": [2, 9], "x": 9.75, "y": 2 },
+ { "label": "2,10", "matrix": [2, 10], "x": 10.75, "y": 2 },
+ { "label": "2,11", "matrix": [2, 11], "x": 11.75, "y": 2 },
+ { "label": "2,13", "matrix": [2, 13], "w": 2.25, "x": 12.75, "y": 2 },
+ { "label": "3,0", "matrix": [3, 0], "w": 2.25, "x": 0, "y": 3 },
+ { "label": "3,1", "matrix": [3, 1], "x": 2.25, "y": 3 },
+ { "label": "3,2", "matrix": [3, 2], "x": 3.25, "y": 3 },
+ { "label": "3,3", "matrix": [3, 3], "x": 4.25, "y": 3 },
+ { "label": "3,4", "matrix": [3, 4], "x": 5.25, "y": 3 },
+ { "label": "3,5", "matrix": [3, 5], "x": 6.25, "y": 3 },
+ { "label": "3,6", "matrix": [3, 6], "x": 7.25, "y": 3 },
+ { "label": "3,7", "matrix": [3, 7], "x": 8.25, "y": 3 },
+ { "label": "3,8", "matrix": [3, 8], "x": 9.25, "y": 3 },
+ { "label": "3,9", "matrix": [3, 9], "x": 10.25, "y": 3 },
+ { "label": "3,10", "matrix": [3, 10], "x": 11.25, "y": 3 },
+ { "label": "3,13", "matrix": [3, 13], "w": 2.75, "x": 12.25, "y": 3 },
+ { "label": "3,14", "matrix": [3, 14], "x": 16.25, "y": 3 },
+ { "label": "4,0", "matrix": [4, 0], "w": 1.5, "x": 0, "y": 4 },
+ { "label": "4,2", "matrix": [4, 2], "w": 1.5, "x": 2.5, "y": 4 },
+ { "label": "4,5", "matrix": [4, 5], "w": 7, "x": 4, "y": 4 },
+ { "label": "4,11", "matrix": [4, 11], "w": 1.5, "x": 11, "y": 4 },
+ { "label": "4,13", "matrix": [4, 13], "w": 1.5, "x": 13.5, "y": 4 },
+ { "label": "4,14", "matrix": [4, 14], "x": 15.25, "y": 4 },
+ { "label": "4,15", "matrix": [4, 15], "x": 16.25, "y": 4 },
+ { "label": "3,15", "matrix": [3, 15], "x": 17.25, "y": 4 }
+ ]
+ }
+ }
+}
diff --git a/keyboards/cipulot/alveus/keymaps/default/keymap.c b/keyboards/cipulot/ec_alveus/1_0_0/keymaps/default/keymap.c
similarity index 68%
rename from keyboards/cipulot/alveus/keymaps/default/keymap.c
rename to keyboards/cipulot/ec_alveus/1_0_0/keymaps/default/keymap.c
index 3373c417fb12..d111c6a6853f 100644
--- a/keyboards/cipulot/alveus/keymaps/default/keymap.c
+++ b/keyboards/cipulot/ec_alveus/1_0_0/keymaps/default/keymap.c
@@ -18,32 +18,32 @@
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
// clang-format off
- [0] = LAYOUT(
+ [0] = LAYOUT_tkl_nofrow_ansi_tsangan_wkl(
KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, KC_INS, KC_HOME, KC_PGUP,
KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_DEL, KC_END, KC_PGDN,
KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENTER,
- KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, KC_UP,
- KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, MO(1), KC_RGUI, KC_RCTL, KC_LEFT, KC_DOWN, KC_RIGHT),
+ KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, KC_UP,
+ KC_LCTL, KC_LALT, KC_SPC, MO(1), KC_RCTL, KC_LEFT, KC_DOWN, KC_RIGHT),
- [1] = LAYOUT(
- KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, _______, _______, _______, KC_VOLU,
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_VOLD,
+ [1] = LAYOUT_tkl_nofrow_ansi_tsangan_wkl(
+ KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______),
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______),
- [2] = LAYOUT(
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ [2] = LAYOUT_tkl_nofrow_ansi_tsangan_wkl(
+ QK_BOOT, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______),
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______),
- [3] = LAYOUT(
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ [3] = LAYOUT_tkl_nofrow_ansi_tsangan_wkl(
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______)
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______)
// clang-format on
};
diff --git a/keyboards/cipulot/ec_alveus/1_0_0/keymaps/via/config.h b/keyboards/cipulot/ec_alveus/1_0_0/keymaps/via/config.h
new file mode 100644
index 000000000000..ebf954d07aca
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_0_0/keymaps/via/config.h
@@ -0,0 +1,20 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#pragma once
+
+// This is the size of the EEPROM for the custom VIA-specific data
+#define EECONFIG_USER_DATA_SIZE 4
diff --git a/keyboards/cipulot/ec_alveus/1_0_0/keymaps/via/keymap.c b/keyboards/cipulot/ec_alveus/1_0_0/keymaps/via/keymap.c
new file mode 100644
index 000000000000..5fc6c4d94e08
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_0_0/keymaps/via/keymap.c
@@ -0,0 +1,49 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#include QMK_KEYBOARD_H
+
+const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
+ // clang-format off
+ [0] = LAYOUT_all(
+ KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, KC_INS, KC_HOME, KC_PGUP,
+ KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_DEL, KC_END, KC_PGDN,
+ KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENTER,
+ KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, KC_UP,
+ KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, MO(1), KC_RGUI, KC_RCTL, KC_LEFT, KC_DOWN, KC_RIGHT),
+
+ [1] = LAYOUT_all(
+ KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______),
+
+ [2] = LAYOUT_all(
+ QK_BOOT, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______),
+
+ [3] = LAYOUT_all(
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______)
+ // clang-format on
+};
diff --git a/keyboards/cipulot/ec_alveus/1_0_0/keymaps/via/rules.mk b/keyboards/cipulot/ec_alveus/1_0_0/keymaps/via/rules.mk
new file mode 100644
index 000000000000..520b11f20312
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_0_0/keymaps/via/rules.mk
@@ -0,0 +1,3 @@
+VIA_ENABLE = yes
+
+SRC += via_apc.c
diff --git a/keyboards/cipulot/ec_alveus/1_0_0/keymaps/via/via_apc.c b/keyboards/cipulot/ec_alveus/1_0_0/keymaps/via/via_apc.c
new file mode 100644
index 000000000000..5ea77af44c8b
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_0_0/keymaps/via/via_apc.c
@@ -0,0 +1,156 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#include "ec_switch_matrix.h"
+#include "action.h"
+#include "via.h"
+
+void apc_init_thresholds(void);
+void apc_set_threshold(bool is_for_actuation);
+
+// Declaring an _apc_config_t struct that will store our data
+typedef struct _apc_config_t {
+ uint16_t actuation_threshold;
+ uint16_t release_threshold;
+} apc_config;
+
+// Check if the size of the reserved persistent memory is the same as the size of struct apc_config
+_Static_assert(sizeof(apc_config) == EECONFIG_USER_DATA_SIZE, "Mismatch in keyboard EECONFIG stored data");
+
+// Declaring a new variable apc of type apc_config
+apc_config apc;
+
+// Declaring enums for VIA config menu
+enum via_apc_enums {
+ // clang-format off
+ id_apc_actuation_threshold = 1,
+ id_apc_release_threshold = 2
+ // clang-format on
+};
+
+// Initializing persistent memory configuration: default values are declared and stored in PMEM
+void eeconfig_init_user(void) {
+ // Default values
+ apc.actuation_threshold = DEFAULT_ACTUATION_LEVEL;
+ apc.release_threshold = DEFAULT_RELEASE_LEVEL;
+ // Write default value to EEPROM now
+ eeconfig_update_user_datablock(&apc);
+}
+
+// On Keyboard startup
+void keyboard_post_init_user(void) {
+ // Read custom menu variables from memory
+ eeconfig_read_user_datablock(&apc);
+ apc_init_thresholds();
+}
+
+// Handle the data received by the keyboard from the VIA menus
+void apc_config_set_value(uint8_t *data) {
+ // data = [ value_id, value_data ]
+ uint8_t *value_id = &(data[0]);
+ uint8_t *value_data = &(data[1]);
+
+ switch (*value_id) {
+ case id_apc_actuation_threshold: {
+ apc.actuation_threshold = value_data[1] | (value_data[0] << 8);
+ apc_set_threshold(true);
+ break;
+ }
+ case id_apc_release_threshold: {
+ apc.release_threshold = value_data[1] | (value_data[0] << 8);
+ apc_set_threshold(false);
+ break;
+ }
+ }
+}
+
+// Handle the data sent by the keyboard to the VIA menus
+void apc_config_get_value(uint8_t *data) {
+ // data = [ value_id, value_data ]
+ uint8_t *value_id = &(data[0]);
+ uint8_t *value_data = &(data[1]);
+
+ switch (*value_id) {
+ case id_apc_actuation_threshold: {
+ value_data[0] = apc.actuation_threshold >> 8;
+ value_data[1] = apc.actuation_threshold & 0xFF;
+ break;
+ }
+ case id_apc_release_threshold: {
+ value_data[0] = apc.release_threshold >> 8;
+ value_data[1] = apc.release_threshold & 0xFF;
+ break;
+ }
+ }
+}
+
+// Save the data to persistent memory after changes are made
+void apc_config_save(void) {
+ eeconfig_update_user_datablock(&apc);
+}
+
+void via_custom_value_command_kb(uint8_t *data, uint8_t length) {
+ // data = [ command_id, channel_id, value_id, value_data ]
+ uint8_t *command_id = &(data[0]);
+ uint8_t *channel_id = &(data[1]);
+ uint8_t *value_id_and_data = &(data[2]);
+
+ if (*channel_id == id_custom_channel) {
+ switch (*command_id) {
+ case id_custom_set_value: {
+ apc_config_set_value(value_id_and_data);
+ break;
+ }
+ case id_custom_get_value: {
+ apc_config_get_value(value_id_and_data);
+ break;
+ }
+ case id_custom_save: {
+ apc_config_save();
+ break;
+ }
+ default: {
+ // Unhandled message.
+ *command_id = id_unhandled;
+ break;
+ }
+ }
+ return;
+ }
+
+ *command_id = id_unhandled;
+}
+
+// Initialize the thresholds
+void apc_init_thresholds(void) {
+ ecsm_config.ecsm_actuation_threshold = apc.actuation_threshold;
+ ecsm_config.ecsm_release_threshold = apc.release_threshold;
+
+ // Update the ecsm_config
+ ecsm_update(&ecsm_config);
+}
+
+// Set the thresholds
+void apc_set_threshold(bool is_for_actuation) {
+ if (is_for_actuation) {
+ ecsm_config.ecsm_actuation_threshold = apc.actuation_threshold;
+
+ } else {
+ ecsm_config.ecsm_release_threshold = apc.release_threshold;
+ }
+ // Update the ecsm_config
+ ecsm_update(&ecsm_config);
+}
diff --git a/keyboards/cipulot/ec_alveus/1_0_0/matrix.c b/keyboards/cipulot/ec_alveus/1_0_0/matrix.c
new file mode 100644
index 000000000000..1850acf26414
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_0_0/matrix.c
@@ -0,0 +1,44 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#include "ec_switch_matrix.h"
+#include "matrix.h"
+
+/* matrix state(1:on, 0:off) */
+extern matrix_row_t raw_matrix[MATRIX_ROWS]; // raw values
+extern matrix_row_t matrix[MATRIX_ROWS]; // debounced values
+
+void matrix_init_custom(void) {
+ // Default values, overwritten by VIA if enabled later
+ ecsm_config.ecsm_actuation_threshold = DEFAULT_ACTUATION_LEVEL;
+ ecsm_config.ecsm_release_threshold = DEFAULT_RELEASE_LEVEL;
+
+ ecsm_init(&ecsm_config);
+}
+
+bool matrix_scan_custom(matrix_row_t current_matrix[]) {
+ bool updated = ecsm_matrix_scan(current_matrix);
+
+// RAW matrix values on console
+#ifdef CONSOLE_ENABLE
+ static int cnt = 0;
+ if (cnt++ == 350) {
+ cnt = 0;
+ ecsm_print_matrix();
+ }
+#endif
+ return updated;
+}
diff --git a/keyboards/cipulot/alveus/mcuconf.h b/keyboards/cipulot/ec_alveus/1_0_0/mcuconf.h
similarity index 96%
rename from keyboards/cipulot/alveus/mcuconf.h
rename to keyboards/cipulot/ec_alveus/1_0_0/mcuconf.h
index 1bef7dfabcbd..d91f576bd48b 100644
--- a/keyboards/cipulot/alveus/mcuconf.h
+++ b/keyboards/cipulot/ec_alveus/1_0_0/mcuconf.h
@@ -16,7 +16,7 @@
#pragma once
-#include_next "mcuconf.h"
+#include_next
#undef STM32_ADC_USE_ADC1
#define STM32_ADC_USE_ADC1 TRUE
diff --git a/keyboards/cipulot/ec_alveus/1_0_0/readme.md b/keyboards/cipulot/ec_alveus/1_0_0/readme.md
new file mode 100644
index 000000000000..01e82a88055d
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_0_0/readme.md
@@ -0,0 +1,27 @@
+# EC Alveus
+
+![EC Alveus](https://i.imgur.com/J31LzzOh.jpg)
+
+EC FRL TKL keyboard.
+
+* Keyboard Maintainer: [cipulot](https://github.com/cipulot)
+* Hardware Supported: EC Alveus 1.0.0
+* Hardware Availability: Raffle Sale from [Densus](https://www.instagram.com/densusdesign/)
+
+Make example for this keyboard (after setting up your build environment):
+
+ make cipulot/ec_alveus/1_0_0:default
+
+Flashing example for this keyboard:
+
+ make cipulot/ec_alveus/1_0_0:default:flash
+
+See the [build environment setup](https://docs.qmk.fm/#/getting_started_build_tools) and the [make instructions](https://docs.qmk.fm/#/getting_started_make_guide) for more information. Brand new to QMK? Start with our [Complete Newbs Guide](https://docs.qmk.fm/#/newbs).
+
+## Bootloader
+
+Enter the bootloader in 3 ways:
+
+* **Bootmagic reset**: Hold down the key at (0,0) in the matrix (usually the top left key or Escape) and plug in the keyboard
+* **Physical reset**: Long short the exposed pads on the top of the PCB
+* **Keycode in layout**: Press the key mapped to `QK_BOOT` if it is available
diff --git a/keyboards/cipulot/ec_alveus/1_0_0/rules.mk b/keyboards/cipulot/ec_alveus/1_0_0/rules.mk
new file mode 100644
index 000000000000..b8929fa590d7
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_0_0/rules.mk
@@ -0,0 +1,3 @@
+CUSTOM_MATRIX = lite
+QUANTUM_LIB_SRC += analog.c
+SRC += matrix.c ec_switch_matrix.c
diff --git a/keyboards/cipulot/ec_alveus/1_2_0/config.h b/keyboards/cipulot/ec_alveus/1_2_0/config.h
new file mode 100644
index 000000000000..1947c308026d
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_2_0/config.h
@@ -0,0 +1,45 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#pragma once
+
+#define MATRIX_ROWS 5
+#define MATRIX_COLS 16
+
+/* Custom matrix pins and port select array */
+#define MATRIX_ROW_PINS \
+ { A14, B3, A15, B5, B4 }
+#define MATRIX_COL_CHANNELS \
+ { 3, 0, 1, 2, 6, 5, 7, 4 }
+#define MUX_SEL_PINS \
+ { B7, B8, B9 }
+
+/* Hardware peripherals pins */
+#define APLEX_EN_PIN_0 C13
+#define APLEX_EN_PIN_1 C14
+#define DISCHARGE_PIN B1
+#define ANALOG_PORT A3
+
+/* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */
+#define LOCKING_SUPPORT_ENABLE
+
+/* Locking resynchronize hack */
+#define LOCKING_RESYNC_ENABLE
+
+#define DEFAULT_ACTUATION_LEVEL 550
+#define DEFAULT_RELEASE_LEVEL 500
+
+#define DISCHARGE_TIME 10
diff --git a/keyboards/cipulot/ec_alveus/1_2_0/ec_switch_matrix.c b/keyboards/cipulot/ec_alveus/1_2_0/ec_switch_matrix.c
new file mode 100644
index 000000000000..783c00457c78
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_2_0/ec_switch_matrix.c
@@ -0,0 +1,183 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#include "ec_switch_matrix.h"
+#include "analog.h"
+#include "atomic_util.h"
+#include "print.h"
+#include "wait.h"
+
+/* Pin and port array */
+const uint32_t row_pins[] = MATRIX_ROW_PINS;
+const uint8_t col_channels[] = MATRIX_COL_CHANNELS;
+const uint32_t mux_sel_pins[] = MUX_SEL_PINS;
+
+static ecsm_config_t config;
+static uint16_t ecsm_sw_value[MATRIX_ROWS][MATRIX_COLS];
+
+static adc_mux adcMux;
+
+static inline void discharge_capacitor(void) {
+ writePinLow(DISCHARGE_PIN);
+}
+static inline void charge_capacitor(uint8_t row) {
+ writePinHigh(DISCHARGE_PIN);
+ writePinHigh(row_pins[row]);
+}
+
+static inline void init_mux_sel(void) {
+ for (int idx = 0; idx < 3; idx++) {
+ setPinOutput(mux_sel_pins[idx]);
+ }
+}
+
+static inline void select_mux(uint8_t col) {
+ uint8_t ch = col_channels[col];
+ writePin(mux_sel_pins[0], ch & 1);
+ writePin(mux_sel_pins[1], ch & 2);
+ writePin(mux_sel_pins[2], ch & 4);
+}
+
+static inline void init_row(void) {
+ for (int idx = 0; idx < MATRIX_ROWS; idx++) {
+ setPinOutput(row_pins[idx]);
+ writePinLow(row_pins[idx]);
+ }
+}
+
+/* Initialize the peripherals pins */
+int ecsm_init(ecsm_config_t const* const ecsm_config) {
+ // Initialize config
+ config = *ecsm_config;
+
+ palSetLineMode(ANALOG_PORT, PAL_MODE_INPUT_ANALOG);
+ adcMux = pinToMux(ANALOG_PORT);
+
+ // Dummy call to make sure that adcStart() has been called in the appropriate state
+ adc_read(adcMux);
+
+ // Initialize discharge pin as discharge mode
+ writePinLow(DISCHARGE_PIN);
+ setPinOutputOpenDrain(DISCHARGE_PIN);
+
+ // Initialize drive lines
+ init_row();
+
+ // Initialize multiplexer select pin
+ init_mux_sel();
+
+ // Enable AMUX
+ setPinOutput(APLEX_EN_PIN_0);
+ writePinLow(APLEX_EN_PIN_0);
+ setPinOutput(APLEX_EN_PIN_1);
+ writePinLow(APLEX_EN_PIN_1);
+
+ return 0;
+}
+
+int ecsm_update(ecsm_config_t const* const ecsm_config) {
+ // Save config
+ config = *ecsm_config;
+ return 0;
+}
+
+// Read the capacitive sensor value
+uint16_t ecsm_readkey_raw(uint8_t channel, uint8_t row, uint8_t col) {
+ uint16_t sw_value = 0;
+
+ // Select the multiplexer
+ if (channel == 0) {
+ writePinHigh(APLEX_EN_PIN_0);
+ select_mux(col);
+ writePinLow(APLEX_EN_PIN_0);
+ } else {
+ writePinHigh(APLEX_EN_PIN_1);
+ select_mux(col);
+ writePinLow(APLEX_EN_PIN_1);
+ }
+
+ // Set strobe pins to low state
+ writePinLow(row_pins[row]);
+ ATOMIC_BLOCK_FORCEON {
+ // Set the row pin to high state and have capacitor charge
+ charge_capacitor(row);
+ // Read the ADC value
+ sw_value = adc_read(adcMux);
+ }
+ // Discharge peak hold capacitor
+ discharge_capacitor();
+ // Waiting for the ghost capacitor to discharge fully
+ wait_us(DISCHARGE_TIME);
+
+ return sw_value;
+}
+
+// Update press/release state of key
+bool ecsm_update_key(matrix_row_t* current_row, uint8_t row, uint8_t col, uint16_t sw_value) {
+ bool current_state = (*current_row >> col) & 1;
+
+ // Press to release
+ if (current_state && sw_value < config.ecsm_actuation_threshold) {
+ *current_row &= ~(1 << col);
+ return true;
+ }
+
+ // Release to press
+ if ((!current_state) && sw_value > config.ecsm_release_threshold) {
+ *current_row |= (1 << col);
+ return true;
+ }
+
+ return false;
+}
+
+// Scan key values and update matrix state
+bool ecsm_matrix_scan(matrix_row_t current_matrix[]) {
+ bool updated = false;
+
+ // Disable AMUX of channel 1
+ writePinHigh(APLEX_EN_PIN_1);
+ for (int col = 0; col < sizeof(col_channels); col++) {
+ for (int row = 0; row < MATRIX_ROWS; row++) {
+ ecsm_sw_value[row][col] = ecsm_readkey_raw(0, row, col);
+ updated |= ecsm_update_key(¤t_matrix[row], row, col, ecsm_sw_value[row][col]);
+ }
+ }
+
+ // Disable AMUX of channel 1
+ writePinHigh(APLEX_EN_PIN_0);
+ for (int col = 0; col < sizeof(col_channels); col++) {
+ for (int row = 0; row < MATRIX_ROWS; row++) {
+ ecsm_sw_value[row][col + 8] = ecsm_readkey_raw(1, row, col);
+ updated |= ecsm_update_key(¤t_matrix[row], row, col + 8, ecsm_sw_value[row][col + 8]);
+ }
+ }
+ return updated;
+}
+
+// Debug print key values
+void ecsm_print_matrix(void) {
+ for (int row = 0; row < MATRIX_ROWS; row++) {
+ for (int col = 0; col < MATRIX_COLS; col++) {
+ uprintf("%4d", ecsm_sw_value[row][col]);
+ if (col < (MATRIX_COLS - 1)) {
+ print(",");
+ }
+ }
+ print("\n");
+ }
+ print("\n");
+}
diff --git a/keyboards/cipulot/ec_alveus/1_2_0/ec_switch_matrix.h b/keyboards/cipulot/ec_alveus/1_2_0/ec_switch_matrix.h
new file mode 100644
index 000000000000..9dcb216caa3f
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_2_0/ec_switch_matrix.h
@@ -0,0 +1,36 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#pragma once
+
+#include
+#include
+
+#include "matrix.h"
+
+typedef struct {
+ uint16_t ecsm_actuation_threshold; // threshold for key release
+ uint16_t ecsm_release_threshold; // threshold for key press
+} ecsm_config_t;
+
+ecsm_config_t ecsm_config;
+
+int ecsm_init(ecsm_config_t const* const ecsm_config);
+int ecsm_update(ecsm_config_t const* const ecsm_config);
+bool ecsm_matrix_scan(matrix_row_t current_matrix[]);
+uint16_t ecsm_readkey_raw(uint8_t channel, uint8_t row, uint8_t col);
+bool ecsm_update_key(matrix_row_t* current_row, uint8_t row, uint8_t col, uint16_t sw_value);
+void ecsm_print_matrix(void);
diff --git a/keyboards/cipulot/ec_alveus/1_2_0/halconf.h b/keyboards/cipulot/ec_alveus/1_2_0/halconf.h
new file mode 100644
index 000000000000..5b71acecbbc8
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_2_0/halconf.h
@@ -0,0 +1,21 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#pragma once
+
+#define HAL_USE_ADC TRUE
+
+#include_next
diff --git a/keyboards/cipulot/ec_alveus/1_2_0/info.json b/keyboards/cipulot/ec_alveus/1_2_0/info.json
new file mode 100644
index 000000000000..65af74e99bad
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_2_0/info.json
@@ -0,0 +1,255 @@
+{
+ "manufacturer": "Cipulot",
+ "keyboard_name": "EC Alveus 1.2.0",
+ "maintainer": "Cipulot",
+ "bootloader": "stm32-dfu",
+ "build": {
+ "lto": true
+ },
+ "diode_direction": "COL2ROW",
+ "features": {
+ "audio": false,
+ "backlight": false,
+ "bootmagic": true,
+ "command": false,
+ "console": true,
+ "extrakey": true,
+ "mousekey": true,
+ "nkro": true,
+ "rgblight": false
+ },
+ "mouse_key": {
+ "enabled": true
+ },
+ "processor": "STM32F401",
+ "usb": {
+ "device_version": "1.2.0",
+ "pid": "0x6B90",
+ "shared_endpoint": {
+ "keyboard": true
+ },
+ "vid": "0x6369"
+ },
+ "layouts": {
+ "LAYOUT_all": {
+ "layout": [
+ { "label": "0,0", "matrix": [0, 0], "x": 0, "y": 0 },
+ { "label": "0,1", "matrix": [0, 1], "x": 1, "y": 0 },
+ { "label": "0,2", "matrix": [0, 2], "x": 2, "y": 0 },
+ { "label": "0,3", "matrix": [0, 3], "x": 3, "y": 0 },
+ { "label": "0,4", "matrix": [0, 4], "x": 4, "y": 0 },
+ { "label": "0,5", "matrix": [0, 5], "x": 5, "y": 0 },
+ { "label": "0,6", "matrix": [0, 6], "x": 6, "y": 0 },
+ { "label": "0,7", "matrix": [0, 7], "x": 7, "y": 0 },
+ { "label": "0,8", "matrix": [0, 8], "x": 8, "y": 0 },
+ { "label": "0,9", "matrix": [0, 9], "x": 9, "y": 0 },
+ { "label": "0,10", "matrix": [0, 10], "x": 10, "y": 0 },
+ { "label": "0,11", "matrix": [0, 11], "x": 11, "y": 0 },
+ { "label": "0,12", "matrix": [0, 12], "x": 12, "y": 0 },
+ { "label": "0,13", "matrix": [0, 13], "x": 13, "y": 0 },
+ { "label": "1,13", "matrix": [1, 13], "x": 14, "y": 0 },
+ { "label": "0,14", "matrix": [0, 14], "x": 15.25, "y": 0 },
+ { "label": "0,15", "matrix": [0, 15], "x": 16.25, "y": 0 },
+ { "label": "1,15", "matrix": [1, 15], "x": 17.25, "y": 0 },
+ { "label": "1,0", "matrix": [1, 0], "w": 1.5, "x": 0, "y": 1 },
+ { "label": "1,1", "matrix": [1, 1], "x": 1.5, "y": 1 },
+ { "label": "1,2", "matrix": [1, 2], "x": 2.5, "y": 1 },
+ { "label": "1,3", "matrix": [1, 3], "x": 3.5, "y": 1 },
+ { "label": "1,4", "matrix": [1, 4], "x": 4.5, "y": 1 },
+ { "label": "1,5", "matrix": [1, 5], "x": 5.5, "y": 1 },
+ { "label": "1,6", "matrix": [1, 6], "x": 6.5, "y": 1 },
+ { "label": "1,7", "matrix": [1, 7], "x": 7.5, "y": 1 },
+ { "label": "1,8", "matrix": [1, 8], "x": 8.5, "y": 1 },
+ { "label": "1,9", "matrix": [1, 9], "x": 9.5, "y": 1 },
+ { "label": "1,10", "matrix": [1, 10], "x": 10.5, "y": 1 },
+ { "label": "1,11", "matrix": [1, 11], "x": 11.5, "y": 1 },
+ { "label": "1,12", "matrix": [1, 12], "x": 12.5, "y": 1 },
+ { "label": "2,13", "matrix": [2, 13], "w": 1.5, "x": 13.5, "y": 1 },
+ { "label": "1,14", "matrix": [1, 14], "x": 15.25, "y": 1 },
+ { "label": "2,14", "matrix": [2, 14], "x": 16.25, "y": 1 },
+ { "label": "2,15", "matrix": [2, 15], "x": 17.25, "y": 1 },
+ { "label": "2,0", "matrix": [2, 0], "w": 1.75, "x": 0, "y": 2 },
+ { "label": "2,1", "matrix": [2, 1], "x": 1.75, "y": 2 },
+ { "label": "2,2", "matrix": [2, 2], "x": 2.75, "y": 2 },
+ { "label": "2,3", "matrix": [2, 3], "x": 3.75, "y": 2 },
+ { "label": "2,4", "matrix": [2, 4], "x": 4.75, "y": 2 },
+ { "label": "2,5", "matrix": [2, 5], "x": 5.75, "y": 2 },
+ { "label": "2,6", "matrix": [2, 6], "x": 6.75, "y": 2 },
+ { "label": "2,7", "matrix": [2, 7], "x": 7.75, "y": 2 },
+ { "label": "2,8", "matrix": [2, 8], "x": 8.75, "y": 2 },
+ { "label": "2,9", "matrix": [2, 9], "x": 9.75, "y": 2 },
+ { "label": "2,10", "matrix": [2, 10], "x": 10.75, "y": 2 },
+ { "label": "2,11", "matrix": [2, 11], "x": 11.75, "y": 2 },
+ { "label": "2,12", "matrix": [2, 12], "w": 2.25, "x": 12.75, "y": 2 },
+ { "label": "3,0", "matrix": [3, 0], "w": 2.25, "x": 0, "y": 3 },
+ { "label": "3,1", "matrix": [3, 1], "x": 2.25, "y": 3 },
+ { "label": "3,2", "matrix": [3, 2], "x": 3.25, "y": 3 },
+ { "label": "3,3", "matrix": [3, 3], "x": 4.25, "y": 3 },
+ { "label": "3,4", "matrix": [3, 4], "x": 5.25, "y": 3 },
+ { "label": "3,5", "matrix": [3, 5], "x": 6.25, "y": 3 },
+ { "label": "3,6", "matrix": [3, 6], "x": 7.25, "y": 3 },
+ { "label": "3,7", "matrix": [3, 7], "x": 8.25, "y": 3 },
+ { "label": "3,8", "matrix": [3, 8], "x": 9.25, "y": 3 },
+ { "label": "3,9", "matrix": [3, 9], "x": 10.25, "y": 3 },
+ { "label": "3,10", "matrix": [3, 10], "x": 11.25, "y": 3 },
+ { "label": "3,13", "matrix": [3, 13], "w": 2.75, "x": 12.25, "y": 3 },
+ { "label": "3,14", "matrix": [3, 14], "x": 16.25, "y": 3 },
+ { "label": "4,0", "matrix": [4, 0], "w": 1.5, "x": 0, "y": 4 },
+ { "label": "4,1", "matrix": [4, 1], "x": 1.5, "y": 4 },
+ { "label": "4,2", "matrix": [4, 2], "w": 1.5, "x": 2.5, "y": 4 },
+ { "label": "4,5", "matrix": [4, 5], "w": 7, "x": 4, "y": 4 },
+ { "label": "4,11", "matrix": [4, 11], "w": 1.5, "x": 11, "y": 4 },
+ { "label": "4,12", "matrix": [4, 12], "x": 12.5, "y": 4 },
+ { "label": "4,13", "matrix": [4, 13], "w": 1.5, "x": 13.5, "y": 4 },
+ { "label": "4,14", "matrix": [4, 14], "x": 15.25, "y": 4 },
+ { "label": "4,15", "matrix": [4, 15], "x": 16.25, "y": 4 },
+ { "label": "3,15", "matrix": [3, 15], "x": 17.25, "y": 4 }
+ ]
+ },
+ "LAYOUT_tkl_nofrow_ansi_tsangan_wkl": {
+ "layout": [
+ { "label": "0,0", "matrix": [0, 0], "x": 0, "y": 0 },
+ { "label": "0,1", "matrix": [0, 1], "x": 1, "y": 0 },
+ { "label": "0,2", "matrix": [0, 2], "x": 2, "y": 0 },
+ { "label": "0,3", "matrix": [0, 3], "x": 3, "y": 0 },
+ { "label": "0,4", "matrix": [0, 4], "x": 4, "y": 0 },
+ { "label": "0,5", "matrix": [0, 5], "x": 5, "y": 0 },
+ { "label": "0,6", "matrix": [0, 6], "x": 6, "y": 0 },
+ { "label": "0,7", "matrix": [0, 7], "x": 7, "y": 0 },
+ { "label": "0,8", "matrix": [0, 8], "x": 8, "y": 0 },
+ { "label": "0,9", "matrix": [0, 9], "x": 9, "y": 0 },
+ { "label": "0,10", "matrix": [0, 10], "x": 10, "y": 0 },
+ { "label": "0,11", "matrix": [0, 11], "x": 11, "y": 0 },
+ { "label": "0,12", "matrix": [0, 12], "x": 12, "y": 0 },
+ { "label": "1,13", "matrix": [1, 13], "w": 2, "x": 13, "y": 0 },
+ { "label": "0,14", "matrix": [0, 14], "x": 15.25, "y": 0 },
+ { "label": "0,15", "matrix": [0, 15], "x": 16.25, "y": 0 },
+ { "label": "1,15", "matrix": [1, 15], "x": 17.25, "y": 0 },
+ { "label": "1,0", "matrix": [1, 0], "w": 1.5, "x": 0, "y": 1 },
+ { "label": "1,1", "matrix": [1, 1], "x": 1.5, "y": 1 },
+ { "label": "1,2", "matrix": [1, 2], "x": 2.5, "y": 1 },
+ { "label": "1,3", "matrix": [1, 3], "x": 3.5, "y": 1 },
+ { "label": "1,4", "matrix": [1, 4], "x": 4.5, "y": 1 },
+ { "label": "1,5", "matrix": [1, 5], "x": 5.5, "y": 1 },
+ { "label": "1,6", "matrix": [1, 6], "x": 6.5, "y": 1 },
+ { "label": "1,7", "matrix": [1, 7], "x": 7.5, "y": 1 },
+ { "label": "1,8", "matrix": [1, 8], "x": 8.5, "y": 1 },
+ { "label": "1,9", "matrix": [1, 9], "x": 9.5, "y": 1 },
+ { "label": "1,10", "matrix": [1, 10], "x": 10.5, "y": 1 },
+ { "label": "1,11", "matrix": [1, 11], "x": 11.5, "y": 1 },
+ { "label": "1,12", "matrix": [1, 12], "x": 12.5, "y": 1 },
+ { "label": "2,13", "matrix": [2, 13], "w": 1.5, "x": 13.5, "y": 1 },
+ { "label": "1,14", "matrix": [1, 14], "x": 15.25, "y": 1 },
+ { "label": "2,14", "matrix": [2, 14], "x": 16.25, "y": 1 },
+ { "label": "2,15", "matrix": [2, 15], "x": 17.25, "y": 1 },
+ { "label": "2,0", "matrix": [2, 0], "w": 1.75, "x": 0, "y": 2 },
+ { "label": "2,1", "matrix": [2, 1], "x": 1.75, "y": 2 },
+ { "label": "2,2", "matrix": [2, 2], "x": 2.75, "y": 2 },
+ { "label": "2,3", "matrix": [2, 3], "x": 3.75, "y": 2 },
+ { "label": "2,4", "matrix": [2, 4], "x": 4.75, "y": 2 },
+ { "label": "2,5", "matrix": [2, 5], "x": 5.75, "y": 2 },
+ { "label": "2,6", "matrix": [2, 6], "x": 6.75, "y": 2 },
+ { "label": "2,7", "matrix": [2, 7], "x": 7.75, "y": 2 },
+ { "label": "2,8", "matrix": [2, 8], "x": 8.75, "y": 2 },
+ { "label": "2,9", "matrix": [2, 9], "x": 9.75, "y": 2 },
+ { "label": "2,10", "matrix": [2, 10], "x": 10.75, "y": 2 },
+ { "label": "2,11", "matrix": [2, 11], "x": 11.75, "y": 2 },
+ { "label": "2,12", "matrix": [2, 12], "w": 2.25, "x": 12.75, "y": 2 },
+ { "label": "3,0", "matrix": [3, 0], "w": 2.25, "x": 0, "y": 3 },
+ { "label": "3,1", "matrix": [3, 1], "x": 2.25, "y": 3 },
+ { "label": "3,2", "matrix": [3, 2], "x": 3.25, "y": 3 },
+ { "label": "3,3", "matrix": [3, 3], "x": 4.25, "y": 3 },
+ { "label": "3,4", "matrix": [3, 4], "x": 5.25, "y": 3 },
+ { "label": "3,5", "matrix": [3, 5], "x": 6.25, "y": 3 },
+ { "label": "3,6", "matrix": [3, 6], "x": 7.25, "y": 3 },
+ { "label": "3,7", "matrix": [3, 7], "x": 8.25, "y": 3 },
+ { "label": "3,8", "matrix": [3, 8], "x": 9.25, "y": 3 },
+ { "label": "3,9", "matrix": [3, 9], "x": 10.25, "y": 3 },
+ { "label": "3,10", "matrix": [3, 10], "x": 11.25, "y": 3 },
+ { "label": "3,13", "matrix": [3, 13], "w": 2.75, "x": 12.25, "y": 3 },
+ { "label": "3,14", "matrix": [3, 14], "x": 16.25, "y": 3 },
+ { "label": "4,0", "matrix": [4, 0], "w": 1.5, "x": 0, "y": 4 },
+ { "label": "4,2", "matrix": [4, 2], "w": 1.5, "x": 2.5, "y": 4 },
+ { "label": "4,5", "matrix": [4, 5], "w": 7, "x": 4, "y": 4 },
+ { "label": "4,11", "matrix": [4, 11], "w": 1.5, "x": 11, "y": 4 },
+ { "label": "4,13", "matrix": [4, 13], "w": 1.5, "x": 13.5, "y": 4 },
+ { "label": "4,14", "matrix": [4, 14], "x": 15.25, "y": 4 },
+ { "label": "4,15", "matrix": [4, 15], "x": 16.25, "y": 4 },
+ { "label": "3,15", "matrix": [3, 15], "x": 17.25, "y": 4 }
+ ]
+ },
+ "LAYOUT_tkl_nofrow_ansi_tsangan_wkl_split_bs": {
+ "layout": [
+ { "label": "0,0", "matrix": [0, 0], "x": 0, "y": 0 },
+ { "label": "0,1", "matrix": [0, 1], "x": 1, "y": 0 },
+ { "label": "0,2", "matrix": [0, 2], "x": 2, "y": 0 },
+ { "label": "0,3", "matrix": [0, 3], "x": 3, "y": 0 },
+ { "label": "0,4", "matrix": [0, 4], "x": 4, "y": 0 },
+ { "label": "0,5", "matrix": [0, 5], "x": 5, "y": 0 },
+ { "label": "0,6", "matrix": [0, 6], "x": 6, "y": 0 },
+ { "label": "0,7", "matrix": [0, 7], "x": 7, "y": 0 },
+ { "label": "0,8", "matrix": [0, 8], "x": 8, "y": 0 },
+ { "label": "0,9", "matrix": [0, 9], "x": 9, "y": 0 },
+ { "label": "0,10", "matrix": [0, 10], "x": 10, "y": 0 },
+ { "label": "0,11", "matrix": [0, 11], "x": 11, "y": 0 },
+ { "label": "0,12", "matrix": [0, 12], "x": 12, "y": 0 },
+ { "label": "0,13", "matrix": [0, 13], "x": 13, "y": 0 },
+ { "label": "1,13", "matrix": [1, 13], "x": 14, "y": 0 },
+ { "label": "0,14", "matrix": [0, 14], "x": 15.25, "y": 0 },
+ { "label": "0,15", "matrix": [0, 15], "x": 16.25, "y": 0 },
+ { "label": "1,15", "matrix": [1, 15], "x": 17.25, "y": 0 },
+ { "label": "1,0", "matrix": [1, 0], "w": 1.5, "x": 0, "y": 1 },
+ { "label": "1,1", "matrix": [1, 1], "x": 1.5, "y": 1 },
+ { "label": "1,2", "matrix": [1, 2], "x": 2.5, "y": 1 },
+ { "label": "1,3", "matrix": [1, 3], "x": 3.5, "y": 1 },
+ { "label": "1,4", "matrix": [1, 4], "x": 4.5, "y": 1 },
+ { "label": "1,5", "matrix": [1, 5], "x": 5.5, "y": 1 },
+ { "label": "1,6", "matrix": [1, 6], "x": 6.5, "y": 1 },
+ { "label": "1,7", "matrix": [1, 7], "x": 7.5, "y": 1 },
+ { "label": "1,8", "matrix": [1, 8], "x": 8.5, "y": 1 },
+ { "label": "1,9", "matrix": [1, 9], "x": 9.5, "y": 1 },
+ { "label": "1,10", "matrix": [1, 10], "x": 10.5, "y": 1 },
+ { "label": "1,11", "matrix": [1, 11], "x": 11.5, "y": 1 },
+ { "label": "1,12", "matrix": [1, 12], "x": 12.5, "y": 1 },
+ { "label": "2,13", "matrix": [2, 13], "w": 1.5, "x": 13.5, "y": 1 },
+ { "label": "1,14", "matrix": [1, 14], "x": 15.25, "y": 1 },
+ { "label": "2,14", "matrix": [2, 14], "x": 16.25, "y": 1 },
+ { "label": "2,15", "matrix": [2, 15], "x": 17.25, "y": 1 },
+ { "label": "2,0", "matrix": [2, 0], "w": 1.75, "x": 0, "y": 2 },
+ { "label": "2,1", "matrix": [2, 1], "x": 1.75, "y": 2 },
+ { "label": "2,2", "matrix": [2, 2], "x": 2.75, "y": 2 },
+ { "label": "2,3", "matrix": [2, 3], "x": 3.75, "y": 2 },
+ { "label": "2,4", "matrix": [2, 4], "x": 4.75, "y": 2 },
+ { "label": "2,5", "matrix": [2, 5], "x": 5.75, "y": 2 },
+ { "label": "2,6", "matrix": [2, 6], "x": 6.75, "y": 2 },
+ { "label": "2,7", "matrix": [2, 7], "x": 7.75, "y": 2 },
+ { "label": "2,8", "matrix": [2, 8], "x": 8.75, "y": 2 },
+ { "label": "2,9", "matrix": [2, 9], "x": 9.75, "y": 2 },
+ { "label": "2,10", "matrix": [2, 10], "x": 10.75, "y": 2 },
+ { "label": "2,11", "matrix": [2, 11], "x": 11.75, "y": 2 },
+ { "label": "2,12", "matrix": [2, 12], "w": 2.25, "x": 12.75, "y": 2 },
+ { "label": "3,0", "matrix": [3, 0], "w": 2.25, "x": 0, "y": 3 },
+ { "label": "3,1", "matrix": [3, 1], "x": 2.25, "y": 3 },
+ { "label": "3,2", "matrix": [3, 2], "x": 3.25, "y": 3 },
+ { "label": "3,3", "matrix": [3, 3], "x": 4.25, "y": 3 },
+ { "label": "3,4", "matrix": [3, 4], "x": 5.25, "y": 3 },
+ { "label": "3,5", "matrix": [3, 5], "x": 6.25, "y": 3 },
+ { "label": "3,6", "matrix": [3, 6], "x": 7.25, "y": 3 },
+ { "label": "3,7", "matrix": [3, 7], "x": 8.25, "y": 3 },
+ { "label": "3,8", "matrix": [3, 8], "x": 9.25, "y": 3 },
+ { "label": "3,9", "matrix": [3, 9], "x": 10.25, "y": 3 },
+ { "label": "3,10", "matrix": [3, 10], "x": 11.25, "y": 3 },
+ { "label": "3,13", "matrix": [3, 13], "w": 2.75, "x": 12.25, "y": 3 },
+ { "label": "3,14", "matrix": [3, 14], "x": 16.25, "y": 3 },
+ { "label": "4,0", "matrix": [4, 0], "w": 1.5, "x": 0, "y": 4 },
+ { "label": "4,2", "matrix": [4, 2], "w": 1.5, "x": 2.5, "y": 4 },
+ { "label": "4,5", "matrix": [4, 5], "w": 7, "x": 4, "y": 4 },
+ { "label": "4,11", "matrix": [4, 11], "w": 1.5, "x": 11, "y": 4 },
+ { "label": "4,13", "matrix": [4, 13], "w": 1.5, "x": 13.5, "y": 4 },
+ { "label": "4,14", "matrix": [4, 14], "x": 15.25, "y": 4 },
+ { "label": "4,15", "matrix": [4, 15], "x": 16.25, "y": 4 },
+ { "label": "3,15", "matrix": [3, 15], "x": 17.25, "y": 4 }
+ ]
+ }
+ }
+}
diff --git a/keyboards/cipulot/alveus/keymaps/via/keymap.c b/keyboards/cipulot/ec_alveus/1_2_0/keymaps/default/keymap.c
similarity index 68%
rename from keyboards/cipulot/alveus/keymaps/via/keymap.c
rename to keyboards/cipulot/ec_alveus/1_2_0/keymaps/default/keymap.c
index 3373c417fb12..d111c6a6853f 100644
--- a/keyboards/cipulot/alveus/keymaps/via/keymap.c
+++ b/keyboards/cipulot/ec_alveus/1_2_0/keymaps/default/keymap.c
@@ -18,32 +18,32 @@
const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
// clang-format off
- [0] = LAYOUT(
+ [0] = LAYOUT_tkl_nofrow_ansi_tsangan_wkl(
KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, KC_INS, KC_HOME, KC_PGUP,
KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_DEL, KC_END, KC_PGDN,
KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENTER,
- KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, KC_UP,
- KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, MO(1), KC_RGUI, KC_RCTL, KC_LEFT, KC_DOWN, KC_RIGHT),
+ KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, KC_UP,
+ KC_LCTL, KC_LALT, KC_SPC, MO(1), KC_RCTL, KC_LEFT, KC_DOWN, KC_RIGHT),
- [1] = LAYOUT(
- KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, _______, _______, _______, KC_VOLU,
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, KC_VOLD,
+ [1] = LAYOUT_tkl_nofrow_ansi_tsangan_wkl(
+ KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______),
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______),
- [2] = LAYOUT(
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ [2] = LAYOUT_tkl_nofrow_ansi_tsangan_wkl(
+ QK_BOOT, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______),
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______),
- [3] = LAYOUT(
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ [3] = LAYOUT_tkl_nofrow_ansi_tsangan_wkl(
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
_______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
- _______, _______, _______, _______, _______, _______, _______, _______, _______, _______)
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______)
// clang-format on
};
diff --git a/keyboards/cipulot/ec_alveus/1_2_0/keymaps/tkl_nofrow_ansi_tsangan_wkl_split_bs/keymap.c b/keyboards/cipulot/ec_alveus/1_2_0/keymaps/tkl_nofrow_ansi_tsangan_wkl_split_bs/keymap.c
new file mode 100644
index 000000000000..4552cd64575a
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_2_0/keymaps/tkl_nofrow_ansi_tsangan_wkl_split_bs/keymap.c
@@ -0,0 +1,49 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#include QMK_KEYBOARD_H
+
+const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
+ // clang-format off
+ [0] = LAYOUT_tkl_nofrow_ansi_tsangan_wkl_split_bs(
+ KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, KC_BSPC, KC_INS, KC_HOME, KC_PGUP,
+ KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_DEL, KC_END, KC_PGDN,
+ KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENTER,
+ KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, KC_UP,
+ KC_LCTL, KC_LALT, KC_SPC, MO(1), KC_RCTL, KC_LEFT, KC_DOWN, KC_RIGHT),
+
+ [1] = LAYOUT_tkl_nofrow_ansi_tsangan_wkl_split_bs(
+ KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______),
+
+ [2] = LAYOUT_tkl_nofrow_ansi_tsangan_wkl_split_bs(
+ QK_BOOT, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______),
+
+ [3] = LAYOUT_tkl_nofrow_ansi_tsangan_wkl_split_bs(
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______)
+ // clang-format on
+};
diff --git a/keyboards/cipulot/ec_alveus/1_2_0/keymaps/via/config.h b/keyboards/cipulot/ec_alveus/1_2_0/keymaps/via/config.h
new file mode 100644
index 000000000000..ebf954d07aca
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_2_0/keymaps/via/config.h
@@ -0,0 +1,20 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#pragma once
+
+// This is the size of the EEPROM for the custom VIA-specific data
+#define EECONFIG_USER_DATA_SIZE 4
diff --git a/keyboards/cipulot/ec_alveus/1_2_0/keymaps/via/keymap.c b/keyboards/cipulot/ec_alveus/1_2_0/keymaps/via/keymap.c
new file mode 100644
index 000000000000..54a8f3b4f00b
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_2_0/keymaps/via/keymap.c
@@ -0,0 +1,49 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#include QMK_KEYBOARD_H
+
+const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
+ // clang-format off
+ [0] = LAYOUT_all(
+ KC_ESC, KC_1, KC_2, KC_3, KC_4, KC_5, KC_6, KC_7, KC_8, KC_9, KC_0, KC_MINS, KC_EQL, KC_BSPC, KC_BSPC, KC_INS, KC_HOME, KC_PGUP,
+ KC_TAB, KC_Q, KC_W, KC_E, KC_R, KC_T, KC_Y, KC_U, KC_I, KC_O, KC_P, KC_LBRC, KC_RBRC, KC_BSLS, KC_DEL, KC_END, KC_PGDN,
+ KC_CAPS, KC_A, KC_S, KC_D, KC_F, KC_G, KC_H, KC_J, KC_K, KC_L, KC_SCLN, KC_QUOT, KC_ENTER,
+ KC_LSFT, KC_Z, KC_X, KC_C, KC_V, KC_B, KC_N, KC_M, KC_COMM, KC_DOT, KC_SLSH, KC_RSFT, KC_UP,
+ KC_LCTL, KC_LGUI, KC_LALT, KC_SPC, MO(1), KC_RGUI, KC_RCTL, KC_LEFT, KC_DOWN, KC_RIGHT),
+
+ [1] = LAYOUT_all(
+ KC_GRV, KC_F1, KC_F2, KC_F3, KC_F4, KC_F5, KC_F6, KC_F7, KC_F8, KC_F9, KC_F10, KC_F11, KC_F12, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______),
+
+ [2] = LAYOUT_all(
+ QK_BOOT, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______),
+
+ [3] = LAYOUT_all(
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______, _______,
+ _______, _______, _______, _______, _______, _______, _______, _______, _______, _______)
+ // clang-format on
+};
diff --git a/keyboards/cipulot/ec_alveus/1_2_0/keymaps/via/rules.mk b/keyboards/cipulot/ec_alveus/1_2_0/keymaps/via/rules.mk
new file mode 100644
index 000000000000..520b11f20312
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_2_0/keymaps/via/rules.mk
@@ -0,0 +1,3 @@
+VIA_ENABLE = yes
+
+SRC += via_apc.c
diff --git a/keyboards/cipulot/ec_alveus/1_2_0/keymaps/via/via_apc.c b/keyboards/cipulot/ec_alveus/1_2_0/keymaps/via/via_apc.c
new file mode 100644
index 000000000000..5ea77af44c8b
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_2_0/keymaps/via/via_apc.c
@@ -0,0 +1,156 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#include "ec_switch_matrix.h"
+#include "action.h"
+#include "via.h"
+
+void apc_init_thresholds(void);
+void apc_set_threshold(bool is_for_actuation);
+
+// Declaring an _apc_config_t struct that will store our data
+typedef struct _apc_config_t {
+ uint16_t actuation_threshold;
+ uint16_t release_threshold;
+} apc_config;
+
+// Check if the size of the reserved persistent memory is the same as the size of struct apc_config
+_Static_assert(sizeof(apc_config) == EECONFIG_USER_DATA_SIZE, "Mismatch in keyboard EECONFIG stored data");
+
+// Declaring a new variable apc of type apc_config
+apc_config apc;
+
+// Declaring enums for VIA config menu
+enum via_apc_enums {
+ // clang-format off
+ id_apc_actuation_threshold = 1,
+ id_apc_release_threshold = 2
+ // clang-format on
+};
+
+// Initializing persistent memory configuration: default values are declared and stored in PMEM
+void eeconfig_init_user(void) {
+ // Default values
+ apc.actuation_threshold = DEFAULT_ACTUATION_LEVEL;
+ apc.release_threshold = DEFAULT_RELEASE_LEVEL;
+ // Write default value to EEPROM now
+ eeconfig_update_user_datablock(&apc);
+}
+
+// On Keyboard startup
+void keyboard_post_init_user(void) {
+ // Read custom menu variables from memory
+ eeconfig_read_user_datablock(&apc);
+ apc_init_thresholds();
+}
+
+// Handle the data received by the keyboard from the VIA menus
+void apc_config_set_value(uint8_t *data) {
+ // data = [ value_id, value_data ]
+ uint8_t *value_id = &(data[0]);
+ uint8_t *value_data = &(data[1]);
+
+ switch (*value_id) {
+ case id_apc_actuation_threshold: {
+ apc.actuation_threshold = value_data[1] | (value_data[0] << 8);
+ apc_set_threshold(true);
+ break;
+ }
+ case id_apc_release_threshold: {
+ apc.release_threshold = value_data[1] | (value_data[0] << 8);
+ apc_set_threshold(false);
+ break;
+ }
+ }
+}
+
+// Handle the data sent by the keyboard to the VIA menus
+void apc_config_get_value(uint8_t *data) {
+ // data = [ value_id, value_data ]
+ uint8_t *value_id = &(data[0]);
+ uint8_t *value_data = &(data[1]);
+
+ switch (*value_id) {
+ case id_apc_actuation_threshold: {
+ value_data[0] = apc.actuation_threshold >> 8;
+ value_data[1] = apc.actuation_threshold & 0xFF;
+ break;
+ }
+ case id_apc_release_threshold: {
+ value_data[0] = apc.release_threshold >> 8;
+ value_data[1] = apc.release_threshold & 0xFF;
+ break;
+ }
+ }
+}
+
+// Save the data to persistent memory after changes are made
+void apc_config_save(void) {
+ eeconfig_update_user_datablock(&apc);
+}
+
+void via_custom_value_command_kb(uint8_t *data, uint8_t length) {
+ // data = [ command_id, channel_id, value_id, value_data ]
+ uint8_t *command_id = &(data[0]);
+ uint8_t *channel_id = &(data[1]);
+ uint8_t *value_id_and_data = &(data[2]);
+
+ if (*channel_id == id_custom_channel) {
+ switch (*command_id) {
+ case id_custom_set_value: {
+ apc_config_set_value(value_id_and_data);
+ break;
+ }
+ case id_custom_get_value: {
+ apc_config_get_value(value_id_and_data);
+ break;
+ }
+ case id_custom_save: {
+ apc_config_save();
+ break;
+ }
+ default: {
+ // Unhandled message.
+ *command_id = id_unhandled;
+ break;
+ }
+ }
+ return;
+ }
+
+ *command_id = id_unhandled;
+}
+
+// Initialize the thresholds
+void apc_init_thresholds(void) {
+ ecsm_config.ecsm_actuation_threshold = apc.actuation_threshold;
+ ecsm_config.ecsm_release_threshold = apc.release_threshold;
+
+ // Update the ecsm_config
+ ecsm_update(&ecsm_config);
+}
+
+// Set the thresholds
+void apc_set_threshold(bool is_for_actuation) {
+ if (is_for_actuation) {
+ ecsm_config.ecsm_actuation_threshold = apc.actuation_threshold;
+
+ } else {
+ ecsm_config.ecsm_release_threshold = apc.release_threshold;
+ }
+ // Update the ecsm_config
+ ecsm_update(&ecsm_config);
+}
diff --git a/keyboards/cipulot/ec_alveus/1_2_0/matrix.c b/keyboards/cipulot/ec_alveus/1_2_0/matrix.c
new file mode 100644
index 000000000000..1850acf26414
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_2_0/matrix.c
@@ -0,0 +1,44 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#include "ec_switch_matrix.h"
+#include "matrix.h"
+
+/* matrix state(1:on, 0:off) */
+extern matrix_row_t raw_matrix[MATRIX_ROWS]; // raw values
+extern matrix_row_t matrix[MATRIX_ROWS]; // debounced values
+
+void matrix_init_custom(void) {
+ // Default values, overwritten by VIA if enabled later
+ ecsm_config.ecsm_actuation_threshold = DEFAULT_ACTUATION_LEVEL;
+ ecsm_config.ecsm_release_threshold = DEFAULT_RELEASE_LEVEL;
+
+ ecsm_init(&ecsm_config);
+}
+
+bool matrix_scan_custom(matrix_row_t current_matrix[]) {
+ bool updated = ecsm_matrix_scan(current_matrix);
+
+// RAW matrix values on console
+#ifdef CONSOLE_ENABLE
+ static int cnt = 0;
+ if (cnt++ == 350) {
+ cnt = 0;
+ ecsm_print_matrix();
+ }
+#endif
+ return updated;
+}
diff --git a/keyboards/cipulot/ec_alveus/1_2_0/mcuconf.h b/keyboards/cipulot/ec_alveus/1_2_0/mcuconf.h
new file mode 100644
index 000000000000..d91f576bd48b
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_2_0/mcuconf.h
@@ -0,0 +1,22 @@
+/* Copyright 2023 Cipulot
+ *
+ * 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 .
+ */
+
+#pragma once
+
+#include_next
+
+#undef STM32_ADC_USE_ADC1
+#define STM32_ADC_USE_ADC1 TRUE
diff --git a/keyboards/cipulot/ec_alveus/1_2_0/readme.md b/keyboards/cipulot/ec_alveus/1_2_0/readme.md
new file mode 100644
index 000000000000..e4c3ef86c3f4
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_2_0/readme.md
@@ -0,0 +1,27 @@
+# EC Alveus
+
+![EC Alveus](https://i.imgur.com/J31LzzOh.jpg)
+
+EC FRL TKL keyboard.
+
+* Keyboard Maintainer: [cipulot](https://github.com/cipulot)
+* Hardware Supported: EC Alveus 1.2.0
+* Hardware Availability: Raffle Sale from [Densus](https://www.instagram.com/densusdesign/)
+
+Make example for this keyboard (after setting up your build environment):
+
+ make cipulot/ec_alveus/1_2_0:default
+
+Flashing example for this keyboard:
+
+ make cipulot/ec_alveus/1_2_0:default:flash
+
+See the [build environment setup](https://docs.qmk.fm/#/getting_started_build_tools) and the [make instructions](https://docs.qmk.fm/#/getting_started_make_guide) for more information. Brand new to QMK? Start with our [Complete Newbs Guide](https://docs.qmk.fm/#/newbs).
+
+## Bootloader
+
+Enter the bootloader in 3 ways:
+
+* **Bootmagic reset**: Hold down the key at (0,0) in the matrix (usually the top left key or Escape) and plug in the keyboard
+* **Physical reset**: Long short the exposed pads on the top of the PCB
+* **Keycode in layout**: Press the key mapped to `QK_BOOT` if it is available
diff --git a/keyboards/cipulot/ec_alveus/1_2_0/rules.mk b/keyboards/cipulot/ec_alveus/1_2_0/rules.mk
new file mode 100644
index 000000000000..b8929fa590d7
--- /dev/null
+++ b/keyboards/cipulot/ec_alveus/1_2_0/rules.mk
@@ -0,0 +1,3 @@
+CUSTOM_MATRIX = lite
+QUANTUM_LIB_SRC += analog.c
+SRC += matrix.c ec_switch_matrix.c