2022-12-12 21:10:32 +01:00
|
|
|
/* Copyright 2022 @ 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
|
|
|
|
|
|
|
|
/* key matrix size */
|
|
|
|
#define MATRIX_ROWS 6
|
|
|
|
#define MATRIX_COLS 16
|
|
|
|
|
|
|
|
/* key matrix pins */
|
|
|
|
#define MATRIX_ROW_PINS \
|
|
|
|
{ B5, B4, B3, A15, A14, A13 }
|
|
|
|
#define MATRIX_COL_PINS \
|
|
|
|
{ C14, C15, A0, A1, A2, A3, A4, A5, NO_PIN, NO_PIN, NO_PIN, NO_PIN, NO_PIN, NO_PIN, NO_PIN, NO_PIN }
|
|
|
|
|
|
|
|
/* COL2ROW or ROW2COL */
|
|
|
|
#define DIODE_DIRECTION ROW2COL
|
|
|
|
|
|
|
|
/* RGB Matrix Driver Configuration */
|
2023-10-21 13:41:59 +02:00
|
|
|
#define SNLED27351_I2C_ADDRESS_1 SNLED27351_I2C_ADDRESS_VDDIO
|
|
|
|
#define SNLED27351_I2C_ADDRESS_2 SNLED27351_I2C_ADDRESS_GND
|
2022-12-12 21:10:32 +01:00
|
|
|
|
|
|
|
/* 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
|
|
|
|
|
2023-11-20 16:48:23 +01:00
|
|
|
#define SNLED27351_PHASE_CHANNEL SNLED27351_SCAN_PHASE_9_CHANNEL
|
2023-10-04 11:10:05 +02:00
|
|
|
#define SNLED27351_CURRENT_TUNE \
|
2022-12-12 21:10:32 +01:00
|
|
|
{ 0x98, 0x98, 0x4A, 0x98, 0x98, 0x4A, 0x98, 0x98, 0x4A, 0x98, 0x98, 0x4A }
|
|
|
|
|
|
|
|
/* EEPROM Driver Configuration */
|
|
|
|
#define WEAR_LEVELING_LOGICAL_SIZE 2048
|
|
|
|
#define WEAR_LEVELING_BACKING_SIZE (WEAR_LEVELING_LOGICAL_SIZE * 2)
|