~ruther/qmk_firmware

41482e02a6ac06bd9d0fa31c42d372c9d73c5d2b — Joel Challis 6 years ago 547fbe7
[Keyboard] Align xd84 and xd96 with moon (#6465)

* Refactor xd84 to use LINK_TIME_OPTIMIZATION_ENABLE

* Refactor xd96 to use LINK_TIME_OPTIMIZATION_ENABLE

* Align xd84 and xd96 with moon

* Update keyboards/xd96/rules.mk

Co-Authored-By: Drashna Jaelre <drashna@live.com>

* Update keyboards/xd84/rules.mk

Co-Authored-By: Drashna Jaelre <drashna@live.com>
M keyboards/xd84/config.h => keyboards/xd84/config.h +0 -4
@@ 237,7 237,3 @@
/* Bootmagic Lite key configuration */
// #define BOOTMAGIC_LITE_ROW 0
// #define BOOTMAGIC_LITE_COLUMN 0

// LTO options
#define NO_ACTION_MACRO
#define NO_ACTION_FUNCTION

M keyboards/xd84/custom_matrix_helper.c => keyboards/xd84/custom_matrix_helper.c +15 -0
@@ 1,3 1,18 @@
/* Copyright 2019
 *
 * 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/>.
 */
#include <stdint.h>
#include <stdbool.h>
#include "wait.h"

M keyboards/xd84/matrix.c => keyboards/xd84/matrix.c +1 -1
@@ 65,7 65,7 @@ static bool read_cols_on_row(matrix_row_t current_matrix[], uint8_t current_row)
  // Clear data in matrix row
  current_matrix[current_row] = 0;

  // Select row and wait for row selecton to stabilize
  // Select row and wait for row selection to stabilize
  select_row(current_row);
  wait_us(30);


M keyboards/xd84/pca9555.c => keyboards/xd84/pca9555.c +25 -10
@@ 1,9 1,24 @@
/* Copyright 2019
 *
 * 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/>.
 */
#include "i2c_master.h"
#include "pca9555.h"

#include "debug.h"

#define SLAVE_TO_ADDR(n)   (n<<1)
#define SLAVE_TO_ADDR(n) (n << 1)
#define TIMEOUT 100

enum {


@@ 14,7 29,7 @@ enum {
  CMD_INVERSION_0,
  CMD_INVERSION_1,
  CMD_CONFIG_0,
  CMD_CONFIG_1
  CMD_CONFIG_1,
};

void pca9555_init(uint8_t slave_addr) {


@@ 22,17 37,17 @@ void pca9555_init(uint8_t slave_addr) {
  if (!s_init) {
    i2c_init();

    s_init=1;
    s_init = 1;
  }

  // TODO: could check device connected
  //i2c_start(SLAVE_TO_ADDR(slave) | I2C_WRITE);
  //i2c_stop();
  // i2c_start(SLAVE_TO_ADDR(slave) | I2C_WRITE);
  // i2c_stop();
}

void pca9555_set_config(uint8_t slave_addr, uint8_t port, uint8_t conf) {
  uint8_t addr = SLAVE_TO_ADDR(slave_addr);
  uint8_t cmd = port ? CMD_OUTPUT_1 : CMD_OUTPUT_0;
  uint8_t cmd  = port ? CMD_CONFIG_1 : CMD_CONFIG_0;

  i2c_status_t ret = i2c_writeReg(addr, cmd, &conf, sizeof(conf), TIMEOUT);
  if (ret != I2C_STATUS_SUCCESS) {


@@ 42,7 57,7 @@ void pca9555_set_config(uint8_t slave_addr, uint8_t port, uint8_t conf) {

void pca9555_set_output(uint8_t slave_addr, uint8_t port, uint8_t conf) {
  uint8_t addr = SLAVE_TO_ADDR(slave_addr);
  uint8_t cmd = port ? CMD_CONFIG_1 : CMD_CONFIG_0;
  uint8_t cmd  = port ? CMD_OUTPUT_1 : CMD_OUTPUT_0;

  i2c_status_t ret = i2c_writeReg(addr, cmd, &conf, sizeof(conf), TIMEOUT);
  if (ret != I2C_STATUS_SUCCESS) {


@@ 52,10 67,10 @@ void pca9555_set_output(uint8_t slave_addr, uint8_t port, uint8_t conf) {

uint8_t pca9555_readPins(uint8_t slave_addr, uint8_t port) {
  uint8_t addr = SLAVE_TO_ADDR(slave_addr);
  uint8_t cmd = port ? CMD_INPUT_1 : CMD_INPUT_0;
  uint8_t cmd  = port ? CMD_INPUT_1 : CMD_INPUT_0;

  uint8_t data = 0;
  i2c_status_t ret = i2c_readReg(addr, cmd, &data, sizeof(data), TIMEOUT);
  uint8_t      data = 0;
  i2c_status_t ret  = i2c_readReg(addr, cmd, &data, sizeof(data), TIMEOUT);
  if (ret != I2C_STATUS_SUCCESS) {
    print("pca9555_readPins::FAILED\n");
  }

M keyboards/xd84/pca9555.h => keyboards/xd84/pca9555.h +11 -11
@@ 18,15 18,15 @@
/*
            PCA9555
         ,----------.
   SDA --| SDA  P00 |-- P1
   SCL --| SCL  P01 |-- P2
   INT --| INT  P02 |-- P3
         |      P03 |-- P4
   A0  --| A0   P04 |-- P5
   A1  --| A1   P05 |-- P6
   A2  --| A2   P06 |-- P7
         |      P07 |-- P8
         |          |      
   SDA --| SDA  P00 |-- P00
   SCL --| SCL  P01 |-- P01
   INT --| INT  P02 |-- P02
         |      P03 |-- P03
   A0  --| A0   P04 |-- P04
   A1  --| A1   P05 |-- P05
   A2  --| A2   P06 |-- P06
         |      P07 |-- P07
         |          |
         |      P10 |-- P10
         |      P11 |-- P11
         |      P12 |-- P12


@@ 35,7 35,7 @@
         |      P15 |-- P15
         |      P16 |-- P16
         |      P17 |-- P17
         `----------'      
         `----------'
*/

#define PCA9555_PORT0 0


@@ 52,4 52,4 @@ void pca9555_set_config(uint8_t slave_addr, uint8_t port, uint8_t conf);

void pca9555_set_output(uint8_t slave_addr, uint8_t port, uint8_t conf);

uint8_t pca9555_readPins(uint8_t slave_addr, uint8_t port);
\ No newline at end of file
uint8_t pca9555_readPins(uint8_t slave_addr, uint8_t port);

M keyboards/xd84/readme.md => keyboards/xd84/readme.md +1 -1
@@ 2,7 2,7 @@

![XD84](https://cdn.shopify.com/s/files/1/2711/4238/products/HTB17eeJSXXXXXbIXFXXq6xXFXXXp_1024x1024.jpg?v=1515505994)

Compact With 84 Keys & RGB LED Underglow
Keyboard with 84 Keys & RGB LED Underglow
- Designed by Xiudi
- Up to 87 keys
  - iso and ansi support

M keyboards/xd84/rules.mk => keyboards/xd84/rules.mk +4 -4
@@ 78,11 78,11 @@ BLUETOOTH_ENABLE = no       # Enable Bluetooth with the Adafruit EZ-Key HID
AUDIO_ENABLE = no           # Audio output on port C6
FAUXCLICKY_ENABLE = no      # Use buzzer to emulate clicky switches
HD44780_ENABLE = no 		# Enable support for HD44780 based LCDs (+400)
LINK_TIME_OPTIMIZATION_ENABLE = yes

# custom matrix setup
CUSTOM_MATRIX = yes
SRC = i2c_master.c custom_matrix_helper.c pca9555.c matrix.c
SRC += custom_matrix_helper.c pca9555.c matrix.c
QUANTUM_LIB_SRC += i2c_master.c

EXTRAFLAGS += -flto

LAYOUTS = 75_ansi 75_iso
\ No newline at end of file
LAYOUTS = 75_ansi 75_iso

M keyboards/xd96/config.h => keyboards/xd96/config.h +0 -4
@@ 238,7 238,3 @@
/* Bootmagic Lite key configuration */
// #define BOOTMAGIC_LITE_ROW 0
// #define BOOTMAGIC_LITE_COLUMN 0

// LTO options
#define NO_ACTION_MACRO
#define NO_ACTION_FUNCTION

M keyboards/xd96/matrix.c => keyboards/xd96/matrix.c +1 -1
@@ 67,7 67,7 @@ static bool read_cols_on_row(matrix_row_t current_matrix[], uint8_t current_row)
  // Clear data in matrix row
  current_matrix[current_row] = 0;

  // Select row and wait for row selecton to stabilize
  // Select row and wait for row selection to stabilize
  select_row(current_row);
  wait_us(30);


M keyboards/xd96/pca9555.c => keyboards/xd96/pca9555.c +10 -10
@@ 18,7 18,7 @@

#include "debug.h"

#define SLAVE_TO_ADDR(n)   (n<<1)
#define SLAVE_TO_ADDR(n) (n << 1)
#define TIMEOUT 100

enum {


@@ 29,7 29,7 @@ enum {
  CMD_INVERSION_0,
  CMD_INVERSION_1,
  CMD_CONFIG_0,
  CMD_CONFIG_1
  CMD_CONFIG_1,
};

void pca9555_init(uint8_t slave_addr) {


@@ 37,17 37,17 @@ void pca9555_init(uint8_t slave_addr) {
  if (!s_init) {
    i2c_init();

    s_init=1;
    s_init = 1;
  }

  // TODO: could check device connected
  //i2c_start(SLAVE_TO_ADDR(slave) | I2C_WRITE);
  //i2c_stop();
  // i2c_start(SLAVE_TO_ADDR(slave) | I2C_WRITE);
  // i2c_stop();
}

void pca9555_set_config(uint8_t slave_addr, uint8_t port, uint8_t conf) {
  uint8_t addr = SLAVE_TO_ADDR(slave_addr);
  uint8_t cmd = port ? CMD_OUTPUT_1 : CMD_OUTPUT_0;
  uint8_t cmd  = port ? CMD_CONFIG_1 : CMD_CONFIG_0;

  i2c_status_t ret = i2c_writeReg(addr, cmd, &conf, sizeof(conf), TIMEOUT);
  if (ret != I2C_STATUS_SUCCESS) {


@@ 57,7 57,7 @@ void pca9555_set_config(uint8_t slave_addr, uint8_t port, uint8_t conf) {

void pca9555_set_output(uint8_t slave_addr, uint8_t port, uint8_t conf) {
  uint8_t addr = SLAVE_TO_ADDR(slave_addr);
  uint8_t cmd = port ? CMD_CONFIG_1 : CMD_CONFIG_0;
  uint8_t cmd  = port ? CMD_OUTPUT_1 : CMD_OUTPUT_0;

  i2c_status_t ret = i2c_writeReg(addr, cmd, &conf, sizeof(conf), TIMEOUT);
  if (ret != I2C_STATUS_SUCCESS) {


@@ 67,10 67,10 @@ void pca9555_set_output(uint8_t slave_addr, uint8_t port, uint8_t conf) {

uint8_t pca9555_readPins(uint8_t slave_addr, uint8_t port) {
  uint8_t addr = SLAVE_TO_ADDR(slave_addr);
  uint8_t cmd = port ? CMD_INPUT_1 : CMD_INPUT_0;
  uint8_t cmd  = port ? CMD_INPUT_1 : CMD_INPUT_0;

  uint8_t data = 0;
  i2c_status_t ret = i2c_readReg(addr, cmd, &data, sizeof(data), TIMEOUT);
  uint8_t      data = 0;
  i2c_status_t ret  = i2c_readReg(addr, cmd, &data, sizeof(data), TIMEOUT);
  if (ret != I2C_STATUS_SUCCESS) {
    print("pca9555_readPins::FAILED\n");
  }

M keyboards/xd96/pca9555.h => keyboards/xd96/pca9555.h +11 -11
@@ 18,15 18,15 @@
/*
            PCA9555
         ,----------.
   SDA --| SDA  P00 |-- P1
   SCL --| SCL  P01 |-- P2
   INT --| INT  P02 |-- P3
         |      P03 |-- P4
   A0  --| A0   P04 |-- P5
   A1  --| A1   P05 |-- P6
   A2  --| A2   P06 |-- P7
         |      P07 |-- P8
         |          |      
   SDA --| SDA  P00 |-- P00
   SCL --| SCL  P01 |-- P01
   INT --| INT  P02 |-- P02
         |      P03 |-- P03
   A0  --| A0   P04 |-- P04
   A1  --| A1   P05 |-- P05
   A2  --| A2   P06 |-- P06
         |      P07 |-- P07
         |          |
         |      P10 |-- P10
         |      P11 |-- P11
         |      P12 |-- P12


@@ 35,7 35,7 @@
         |      P15 |-- P15
         |      P16 |-- P16
         |      P17 |-- P17
         `----------'      
         `----------'
*/

#define PCA9555_PORT0 0


@@ 52,4 52,4 @@ void pca9555_set_config(uint8_t slave_addr, uint8_t port, uint8_t conf);

void pca9555_set_output(uint8_t slave_addr, uint8_t port, uint8_t conf);

uint8_t pca9555_readPins(uint8_t slave_addr, uint8_t port);
\ No newline at end of file
uint8_t pca9555_readPins(uint8_t slave_addr, uint8_t port);

M keyboards/xd96/readme.md => keyboards/xd96/readme.md +1 -1
@@ 2,7 2,7 @@

![XD96](https://cdn.shopify.com/s/files/1/2711/4238/products/xd96_pcb_1024x1024.jpg?v=1515425370)

Compact With 96 Keys & RGB LED Underglow
Keyboard with 96 Keys & RGB LED Underglow
- Designed by Xiudi
- ISO and ANSI support
- Uses Kimera core

M keyboards/xd96/rules.mk => keyboards/xd96/rules.mk +3 -3
@@ 78,9 78,9 @@ BLUETOOTH_ENABLE = no       # Enable Bluetooth with the Adafruit EZ-Key HID
AUDIO_ENABLE = no           # Audio output on port C6
FAUXCLICKY_ENABLE = no      # Use buzzer to emulate clicky switches
HD44780_ENABLE = no 		# Enable support for HD44780 based LCDs (+400)
LINK_TIME_OPTIMIZATION_ENABLE = yes

# custom matrix setup
CUSTOM_MATRIX = yes
SRC = i2c_master.c custom_matrix_helper.c pca9555.c matrix.c

EXTRAFLAGS += -flto
SRC += custom_matrix_helper.c pca9555.c matrix.c
QUANTUM_LIB_SRC += i2c_master.c