Skip to content

Commit

Permalink
Add EC Virgo (qmk#23173)
Browse files Browse the repository at this point in the history
Co-authored-by: jack <0x6a73@protonmail.com>
  • Loading branch information
2 people authored and aaruff committed May 22, 2024
1 parent 98d9997 commit 6ca474a
Show file tree
Hide file tree
Showing 40 changed files with 421 additions and 94 deletions.
5 changes: 0 additions & 5 deletions keyboards/cipulot/ec_23u/config.h
Original file line number Diff line number Diff line change
Expand Up @@ -62,8 +62,3 @@

#define EECONFIG_KB_DATA_SIZE 57

/* 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
6 changes: 6 additions & 0 deletions keyboards/cipulot/ec_23u/info.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,12 @@
"build": {
"lto": true
},
"qmk": {
"locking": {
"enabled": true,
"resync": true
}
},
"diode_direction": "COL2ROW",
"features": {
"bootmagic": false,
Expand Down
3 changes: 2 additions & 1 deletion keyboards/cipulot/ec_23u/rules.mk
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
CUSTOM_MATRIX = lite
ANALOG_DRIVER_REQUIRED = yes
SRC += keyboards/cipulot/common/matrix.c keyboards/cipulot/common/ec_board.c keyboards/cipulot/common/ec_switch_matrix.c
VPATH += keyboards/cipulot/common
SRC += matrix.c ec_board.c ec_switch_matrix.c
OPT = 2
6 changes: 0 additions & 6 deletions keyboards/cipulot/ec_60/config.h
Original file line number Diff line number Diff line change
Expand Up @@ -64,9 +64,3 @@
// #define DEBUG_MATRIX_SCAN_RATE

#define EECONFIG_KB_DATA_SIZE 159

/* 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
6 changes: 6 additions & 0 deletions keyboards/cipulot/ec_60/info.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,12 @@
"build": {
"lto": true
},
"qmk": {
"locking": {
"enabled": true,
"resync": true
}
},
"diode_direction": "COL2ROW",
"features": {
"bootmagic": false,
Expand Down
3 changes: 2 additions & 1 deletion keyboards/cipulot/ec_60/rules.mk
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
CUSTOM_MATRIX = lite
ANALOG_DRIVER_REQUIRED = yes
SRC += keyboards/cipulot/common/matrix.c keyboards/cipulot/common/ec_board.c keyboards/cipulot/common/ec_switch_matrix.c
VPATH += keyboards/cipulot/common
SRC += matrix.c ec_board.c ec_switch_matrix.c
OPT = 3
6 changes: 0 additions & 6 deletions keyboards/cipulot/ec_alveus/1_0_0/config.h
Original file line number Diff line number Diff line change
Expand Up @@ -63,9 +63,3 @@
// #define DEBUG_MATRIX_SCAN_RATE

#define EECONFIG_KB_DATA_SIZE 169

/* 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
6 changes: 6 additions & 0 deletions keyboards/cipulot/ec_alveus/1_0_0/info.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,12 @@
"build": {
"lto": true
},
"qmk": {
"locking": {
"enabled": true,
"resync": true
}
},
"diode_direction": "COL2ROW",
"features": {
"bootmagic": false,
Expand Down
3 changes: 2 additions & 1 deletion keyboards/cipulot/ec_alveus/1_0_0/rules.mk
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
CUSTOM_MATRIX = lite
ANALOG_DRIVER_REQUIRED = yes
SRC += keyboards/cipulot/common/matrix.c keyboards/cipulot/common/ec_board.c keyboards/cipulot/common/ec_switch_matrix.c
VPATH += keyboards/cipulot/common
SRC += matrix.c ec_board.c ec_switch_matrix.c
OPT = 3
6 changes: 0 additions & 6 deletions keyboards/cipulot/ec_alveus/1_2_0/config.h
Original file line number Diff line number Diff line change
Expand Up @@ -63,9 +63,3 @@
// #define DEBUG_MATRIX_SCAN_RATE

#define EECONFIG_KB_DATA_SIZE 169

/* 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
6 changes: 6 additions & 0 deletions keyboards/cipulot/ec_alveus/1_2_0/info.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,12 @@
"build": {
"lto": true
},
"qmk": {
"locking": {
"enabled": true,
"resync": true
}
},
"diode_direction": "COL2ROW",
"features": {
"bootmagic": false,
Expand Down
3 changes: 2 additions & 1 deletion keyboards/cipulot/ec_alveus/1_2_0/rules.mk
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
CUSTOM_MATRIX = lite
ANALOG_DRIVER_REQUIRED = yes
SRC += keyboards/cipulot/common/matrix.c keyboards/cipulot/common/ec_board.c keyboards/cipulot/common/ec_switch_matrix.c
VPATH += keyboards/cipulot/common
SRC += matrix.c ec_board.c ec_switch_matrix.c
OPT = 3
5 changes: 0 additions & 5 deletions keyboards/cipulot/ec_pro2/config.h
Original file line number Diff line number Diff line change
Expand Up @@ -65,8 +65,3 @@

#define EECONFIG_KB_DATA_SIZE 159

/* 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
6 changes: 6 additions & 0 deletions keyboards/cipulot/ec_pro2/info.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,12 @@
"build": {
"lto": true
},
"qmk": {
"locking": {
"enabled": true,
"resync": true
}
},
"diode_direction": "COL2ROW",
"features": {
"bootmagic": false,
Expand Down
3 changes: 2 additions & 1 deletion keyboards/cipulot/ec_pro2/rules.mk
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
CUSTOM_MATRIX = lite
ANALOG_DRIVER_REQUIRED = yes
SRC += keyboards/cipulot/common/matrix.c keyboards/cipulot/common/ec_board.c keyboards/cipulot/common/ec_switch_matrix.c
VPATH += keyboards/cipulot/common
SRC += matrix.c ec_board.c ec_switch_matrix.c
OPT = 2
6 changes: 0 additions & 6 deletions keyboards/cipulot/ec_prox/ansi_iso/config.h
Original file line number Diff line number Diff line change
Expand Up @@ -64,9 +64,3 @@
// #define DEBUG_MATRIX_SCAN_RATE

#define EECONFIG_KB_DATA_SIZE 159

/* 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
6 changes: 6 additions & 0 deletions keyboards/cipulot/ec_prox/ansi_iso/info.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,12 @@
"build": {
"lto": true
},
"qmk": {
"locking": {
"enabled": true,
"resync": true
}
},
"diode_direction": "COL2ROW",
"features": {
"bootmagic": false,
Expand Down
3 changes: 2 additions & 1 deletion keyboards/cipulot/ec_prox/ansi_iso/rules.mk
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
CUSTOM_MATRIX = lite
ANALOG_DRIVER_REQUIRED = yes
SRC += keyboards/cipulot/common/matrix.c keyboards/cipulot/common/ec_board.c keyboards/cipulot/common/ec_switch_matrix.c
VPATH += keyboards/cipulot/common
SRC += matrix.c ec_board.c ec_switch_matrix.c
OPT = 2
6 changes: 0 additions & 6 deletions keyboards/cipulot/ec_prox/jis/config.h
Original file line number Diff line number Diff line change
Expand Up @@ -64,9 +64,3 @@
// #define DEBUG_MATRIX_SCAN_RATE

#define EECONFIG_KB_DATA_SIZE 149

/* 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
6 changes: 6 additions & 0 deletions keyboards/cipulot/ec_prox/jis/info.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,12 @@
"build": {
"lto": true
},
"qmk": {
"locking": {
"enabled": true,
"resync": true
}
},
"diode_direction": "COL2ROW",
"features": {
"bootmagic": false,
Expand Down
3 changes: 2 additions & 1 deletion keyboards/cipulot/ec_prox/jis/rules.mk
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
CUSTOM_MATRIX = lite
ANALOG_DRIVER_REQUIRED = yes
SRC += keyboards/cipulot/common/matrix.c keyboards/cipulot/common/ec_board.c keyboards/cipulot/common/ec_switch_matrix.c
VPATH += keyboards/cipulot/common
SRC += matrix.c ec_board.c ec_switch_matrix.c
OPT = 2
6 changes: 0 additions & 6 deletions keyboards/cipulot/ec_theca/config.h
Original file line number Diff line number Diff line change
Expand Up @@ -63,9 +63,3 @@
// #define DEBUG_MATRIX_SCAN_RATE
#define DYNAMIC_KEYMAP_LAYER_COUNT 3
#define EECONFIG_KB_DATA_SIZE 201

/* 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
10 changes: 6 additions & 4 deletions keyboards/cipulot/ec_theca/info.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,12 @@
"build": {
"lto": true
},
"qmk": {
"locking": {
"enabled": true,
"resync": true
}
},
"diode_direction": "COL2ROW",
"features": {
"bootmagic": false,
Expand All @@ -27,10 +33,6 @@
"LAYOUT_all": "LAYOUT_tkl_ansi",
"LAYOUT_tkl_ansi_tsangan_wkl": "LAYOUT_tkl_ansi_wkl"
},
"community_layouts": [
"tkl_ansi",
"tkl_ansi_tsangan"
],
"layouts": {
"LAYOUT_tkl_ansi": {
"layout": [
Expand Down
3 changes: 2 additions & 1 deletion keyboards/cipulot/ec_theca/rules.mk
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
CUSTOM_MATRIX = lite
ANALOG_DRIVER_REQUIRED = yes
SRC += keyboards/cipulot/common/matrix.c keyboards/cipulot/common/ec_board.c keyboards/cipulot/common/ec_switch_matrix.c
VPATH += keyboards/cipulot/common
SRC += matrix.c ec_board.c ec_switch_matrix.c
OPT = 3
66 changes: 66 additions & 0 deletions keyboards/cipulot/ec_virgo/config.h
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
/* 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 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/

#pragma once

#define MATRIX_ROWS 6
#define MATRIX_COLS 18

#define MATRIX_ROW_PINS \
{ B6, B7, B5, B4, B3, A15 }

#define AMUX_COUNT 2
#define AMUX_MAX_COLS_COUNT 16

#define AMUX_EN_PINS \
{ A9, A8 }

#define AMUX_SEL_PINS \
{ B12, B13, B15, B14 }

#define AMUX_COL_CHANNELS_SIZES \
{ 7, 11 }

#define AMUX_0_COL_CHANNELS \
{ 2, 1, 0, 3, 5, 4, 7 }

#define AMUX_1_COL_CHANNELS \
{ 2, 1, 0, 15, 14, 13, 12, 8, 11, 10, 9 }

#define AMUX_COL_CHANNELS AMUX_0_COL_CHANNELS, AMUX_1_COL_CHANNELS

#define DISCHARGE_PIN A4
#define ANALOG_PORT A3

#define DEFAULT_ACTUATION_MODE 0
#define DEFAULT_MODE_0_ACTUATION_LEVEL 550
#define DEFAULT_MODE_0_RELEASE_LEVEL 500
#define DEFAULT_MODE_1_INITIAL_DEADZONE_OFFSET DEFAULT_MODE_0_ACTUATION_LEVEL
#define DEFAULT_MODE_1_ACTUATION_OFFSET 70
#define DEFAULT_MODE_1_RELEASE_OFFSET 70
#define DEFAULT_EXTREMUM 1023
#define EXPECTED_NOISE_FLOOR 0
#define NOISE_FLOOR_THRESHOLD 50
#define BOTTOMING_CALIBRATION_THRESHOLD 50
#define DEFAULT_NOISE_FLOOR_SAMPLING_COUNT 30
#define DEFAULT_BOTTOMING_READING 1023
#define DEFAULT_CALIBRATION_STARTER true

#define DISCHARGE_TIME 10

// #define DEBUG_MATRIX_SCAN_RATE

#define EECONFIG_KB_DATA_SIZE 225
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
/* Copyright 2022 Cipulot
/* 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
Expand All @@ -16,7 +16,6 @@

#pragma once

/* 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 HAL_USE_ADC TRUE

#include_next <halconf.h>
Loading

0 comments on commit 6ca474a

Please sign in to comment.