b1fbfaaacc
Although `keychron/c2_pro/ansi/rgb` and `keychron/c2_pro/ansi/white` use the same custom matrix code, the matrix layouts are slightly different; in particular, only the `keychron/c2_pro/ansi/white` board actually uses column 19. However, the handling of column 19 in the custom matrix code was broken, therefore that column did not work. Looks like the custom matrix code assumes that `SHIFT_COL_END` refers to the last column connected to the shift register, and not to the column past that; so the value of `SHIFT_COL_END` needs to be changed from 19 to 18 (columns 11...18 are connected to the shift register, and column 19 is connected to the C14 pin). Also the code which was determining `SIZE_T` and `UNSELECT_ALL_COL` had an off-by-one bug when counting the required number of bits (again due to the confusion on the `SHIFT_COL_END` meaning); this had been fixed too (the actual behavior of that part of the code did not change, because both the old and the new version select the 8 bit variant).
45 lines
1.4 KiB
C
45 lines
1.4 KiB
C
/* Copyright 2023 @ Keychron(https://www.keychron.com)
|
|
*
|
|
* This program is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation, either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
/* DIP switch */
|
|
#define DIP_SWITCH_MATRIX_GRID { { 5, 4 } }
|
|
|
|
/* Disable DIP switch in matrix data */
|
|
#define MATRIX_MASKED
|
|
|
|
/* EEPROM Driver Configuration */
|
|
#define WEAR_LEVELING_LOGICAL_SIZE 2048
|
|
#define WEAR_LEVELING_BACKING_SIZE (WEAR_LEVELING_LOGICAL_SIZE * 2)
|
|
|
|
/* Increase I2C speed to 1000 KHz */
|
|
#define I2C1_TIMINGR_PRESC 0U
|
|
#define I2C1_TIMINGR_SCLDEL 3U
|
|
#define I2C1_TIMINGR_SDADEL 0U
|
|
#define I2C1_TIMINGR_SCLH 15U
|
|
#define I2C1_TIMINGR_SCLL 51U
|
|
|
|
/* Old default behavior of mod-taps */
|
|
#define HOLD_ON_OTHER_KEY_PRESS
|
|
|
|
/* HC595 used pins definiton */
|
|
#define HC595_STCP A0
|
|
#define HC595_SHCP A1
|
|
#define HC595_DS C15
|
|
#define SHIFT_COL_START 11
|
|
#define SHIFT_COL_END 18
|