Skip to content

Commit

Permalink
Refactor to use led config - Part 4 (qmk#10967)
Browse files Browse the repository at this point in the history
* Refactor to use led config

* Refactor to use led_update_kb
  • Loading branch information
zvecr authored Nov 21, 2020
1 parent 2322262 commit 95fd2ce
Show file tree
Hide file tree
Showing 15 changed files with 36 additions and 230 deletions.
10 changes: 0 additions & 10 deletions keyboards/clueboard/17/17.c
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,6 @@

int pwm_level;

void matrix_init_kb(void) {
// put your keyboard start-up code here
// runs once when the firmware starts up
matrix_init_user();
};

void led_set_kb(uint8_t usb_led) {
print("led_set\n");
}

void backlight_init_ports(void) {
// Set C7 to output
DDRC |= (1<<7);
Expand Down
41 changes: 0 additions & 41 deletions keyboards/clueboard/2x1800/2018/2018.c
Original file line number Diff line number Diff line change
Expand Up @@ -14,44 +14,3 @@
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "2018.h"

void matrix_init_kb(void) {
// Set our LED pins as output
DDRB |= (1<<4); // Numlock
DDRB |= (1<<5); // Capslock
DDRB |= (1<<6); // Scroll Lock

// Run the keymap level init
matrix_init_user();
}

void matrix_scan_kb(void) {
matrix_scan_user();
}

bool process_record_kb(uint16_t keycode, keyrecord_t *record) {
return process_record_user(keycode, record);
}

void led_set_kb(uint8_t usb_led) {
// Toggle numlock as needed
if (usb_led & (1<<USB_LED_NUM_LOCK)) {
PORTB |= (1<<4);
} else {
PORTB &= ~(1<<4);
}

// Toggle capslock as needed
if (usb_led & (1<<USB_LED_CAPS_LOCK)) {
PORTB |= (1<<5);
} else {
PORTB &= ~(1<<5);
}

// Toggle scrolllock as needed
if (usb_led & (1<<USB_LED_SCROLL_LOCK)) {
PORTB |= (1<<6);
} else {
PORTB &= ~(1<<6);
}
}
4 changes: 4 additions & 0 deletions keyboards/clueboard/2x1800/2018/config.h
Original file line number Diff line number Diff line change
Expand Up @@ -60,6 +60,10 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
#define C4_AUDIO
#define AUDIO_CLICKY

#define LED_NUM_LOCK_PIN B4
#define LED_CAPS_LOCK_PIN B5
#define LED_SCROLL_LOCK_PIN B6

/* number of backlight levels */
// #define BACKLIGHT_PIN B7
// #define BACKLIGHT_BREATHING
Expand Down
4 changes: 3 additions & 1 deletion keyboards/clueboard/60/config.h
Original file line number Diff line number Diff line change
Expand Up @@ -121,6 +121,8 @@
/* override number of MIDI tone keycodes (each octave adds 12 keycodes and allocates 12 bytes) */
//#define MIDI_TONE_KEYCODE_OCTAVES 1

/* Backlight configuration
#define LED_CAPS_LOCK_PIN B7

/* Backlight configuration
*/
#define BACKLIGHT_LEVELS 1
12 changes: 0 additions & 12 deletions keyboards/clueboard/60/led.c
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,6 @@
*/

#include "hal.h"
#include "led.h"
#include "printf.h"

#ifdef BACKLIGHT_ENABLE
Expand All @@ -40,14 +39,3 @@ void backlight_set(uint8_t level) {
}
}
#endif

void led_set_kb(uint8_t usb_led) {
printf("led_set_kb(%d)\n", usb_led);
if (usb_led & (1<<USB_LED_CAPS_LOCK)) {
// Turn capslock on
palSetPad(GPIOB, 7);
} else {
// Turn capslock off
palClearPad(GPIOB, 7);
}
}
2 changes: 2 additions & 0 deletions keyboards/clueboard/66/rev1/config.h
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,8 @@
//#define NO_ACTION_MACRO
//#define NO_ACTION_FUNCTION

#define LED_CAPS_LOCK_PIN F0

/* Underlight configuration
*/
#define RGB_DI_PIN B2
Expand Down
16 changes: 0 additions & 16 deletions keyboards/clueboard/66/rev1/rev1.c
Original file line number Diff line number Diff line change
@@ -1,17 +1 @@
#include "rev1.h"

void led_init_ports() {
// * Set our LED pins as output
DDRF |= (1<<0);
}

void led_set_kb(uint8_t usb_led) {
DDRF |= (1<<0);
if (usb_led & (1<<USB_LED_CAPS_LOCK)) {
// Turn capslock on
PORTF |= (1<<0);
} else {
// Turn capslock off
PORTF &= ~(1<<0);
}
}
4 changes: 3 additions & 1 deletion keyboards/clueboard/66/rev2/config.h
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,9 @@
//#define NO_ACTION_MACRO
//#define NO_ACTION_FUNCTION

/* Backlight configuration
#define LED_CAPS_LOCK_PIN B4

/* Backlight configuration
*/
#define BACKLIGHT_LEVELS 1

Expand Down
30 changes: 0 additions & 30 deletions keyboards/clueboard/66/rev2/rev2.c
Original file line number Diff line number Diff line change
@@ -1,20 +1,6 @@
#include "rev2.h"
#include <avr/io.h>
#include "backlight.h"
#include "print.h"

void matrix_init_kb(void) {
// put your keyboard start-up code here
// runs once when the firmware starts up
matrix_init_user();
led_init_ports();
}


void matrix_scan_kb(void) {
matrix_scan_user();
}

void backlight_init_ports(void) {
print("init_backlight_pin()\n");
// Set our LED pins as output
Expand All @@ -41,19 +27,3 @@ void backlight_set(uint8_t level) {
PORTD &= ~(1<<4); // Arrows
}
}

void led_init_ports() {
// * Set our LED pins as output
DDRB |= (1<<4);
}

void led_set_kb(uint8_t usb_led) {
DDRB |= (1<<4);
if (usb_led & (1<<USB_LED_CAPS_LOCK)) {
// Turn capslock on
PORTB |= (1<<4);
} else {
// Turn capslock off
PORTB &= ~(1<<4);
}
}
4 changes: 3 additions & 1 deletion keyboards/clueboard/66/rev3/config.h
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,9 @@
//#define NO_ACTION_MACRO
//#define NO_ACTION_FUNCTION

/* Backlight configuration
#define LED_CAPS_LOCK_PIN B4

/* Backlight configuration
*/
#define BACKLIGHT_LEVELS 1

Expand Down
30 changes: 0 additions & 30 deletions keyboards/clueboard/66/rev3/rev3.c
Original file line number Diff line number Diff line change
@@ -1,20 +1,6 @@
#include "rev3.h"
#include <avr/io.h>
#include "backlight.h"
#include "print.h"

void matrix_init_kb(void) {
// put your keyboard start-up code here
// runs once when the firmware starts up
matrix_init_user();
led_init_ports();
}


void matrix_scan_kb(void) {
matrix_scan_user();
}

void backlight_init_ports(void) {
print("init_backlight_pin()\n");
// Set our LED pins as output
Expand All @@ -41,19 +27,3 @@ void backlight_set(uint8_t level) {
PORTD &= ~(1<<4); // Arrows
}
}

void led_init_ports() {
// * Set our LED pins as output
DDRB |= (1<<4);
}

void led_set_kb(uint8_t usb_led) {
DDRB |= (1<<4);
if (usb_led & (1<<USB_LED_CAPS_LOCK)) {
// Turn capslock on
PORTB |= (1<<4);
} else {
// Turn capslock off
PORTB &= ~(1<<4);
}
}
49 changes: 18 additions & 31 deletions keyboards/clueboard/66/rev4/rev4.c
Original file line number Diff line number Diff line change
@@ -1,43 +1,30 @@
#include "rev4.h"
//#include "backlight.h"

void matrix_init_kb(void) {
// put your keyboard start-up code here
// runs once when the firmware starts up
matrix_init_user();
led_init_ports();

matrix_init_user();
}

void led_init_ports() {
// Set our LED pins as output
palSetPadMode(GPIOB, 13, PAL_MODE_OUTPUT_PUSHPULL); // LED1
palClearPad(GPIOB, 13);
palSetPadMode(GPIOB, 14, PAL_MODE_OUTPUT_PUSHPULL); // LED2
palClearPad(GPIOB, 14);
palSetPadMode(GPIOA, 8, PAL_MODE_OUTPUT_PUSHPULL); // LED3
palClearPad(GPIOA, 8);
palSetPadMode(GPIOA, 0, PAL_MODE_OUTPUT_PUSHPULL); // Capslock LED
palClearPad(GPIOA, 0);
setPinOutput(B13); // LED1
writePinLow(B13);
setPinOutput(B14); // LED2
writePinLow(B14);
setPinOutput(A8); // LED3
writePinLow(A8);
setPinOutput(A0); // Capslock LED
writePinLow(A0);
}

void led_set_kb(uint8_t usb_led) {
if (usb_led & (1<<USB_LED_NUM_LOCK)) {
palSetPad(GPIOB, 13); // LED1
} else {
palClearPad(GPIOB, 13); // LED1
}

if (usb_led & (1<<USB_LED_CAPS_LOCK)) {
palSetPad(GPIOA, 0); // Capslock LED
palSetPad(GPIOB, 14); // LED2
} else {
palClearPad(GPIOA, 0); // Capslock LED
palClearPad(GPIOB, 14); // LED2
}

if (usb_led & (1<<USB_LED_SCROLL_LOCK)) {
palSetPad(GPIOA, 8); // LED3
} else {
palClearPad(GPIOA, 8); // LED3
bool led_update_kb(led_t led_state) {
bool res = led_update_user(led_state);
if(res) {
writePin(B13, led_state.num_lock);
writePin(A0, led_state.caps_lock);
writePin(B14, led_state.caps_lock);
writePin(A8, led_state.scroll_lock);
}
return res;
}
2 changes: 2 additions & 0 deletions keyboards/clueboard/66_hotswap/prototype/config.h
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,8 @@
*/
#define NO_ACTION_TAPPING

#define LED_CAPS_LOCK_PIN B4

/* Backlight configuration
*/
#define BACKLIGHT_LEVELS 1
Expand Down
30 changes: 0 additions & 30 deletions keyboards/clueboard/66_hotswap/prototype/prototype.c
Original file line number Diff line number Diff line change
@@ -1,20 +1,6 @@
#include "prototype.h"
#include <avr/io.h>
#include "backlight.h"
#include "print.h"

void matrix_init_kb(void) {
// put your keyboard start-up code here
// runs once when the firmware starts up
matrix_init_user();
led_init_ports();
}


void matrix_scan_kb(void) {
matrix_scan_user();
}

void backlight_init_ports(void) {
print("init_backlight_pin()\n");
// Set our LED pins as output
Expand All @@ -41,19 +27,3 @@ void backlight_set(uint8_t level) {
PORTD &= ~(1<<1); // Arrows
}
}

void led_init_ports() {
// * Set our LED pins as output
DDRB |= (1<<4);
}

void led_set_kb(uint8_t usb_led) {
DDRB |= (1<<4);
if (usb_led & (1<<USB_LED_CAPS_LOCK)) {
// Turn capslock on
PORTB |= (1<<4);
} else {
// Turn capslock off
PORTB &= ~(1<<4);
}
}
28 changes: 1 addition & 27 deletions keyboards/clueboard/card/card.c
Original file line number Diff line number Diff line change
@@ -1,35 +1,9 @@
#include "card.h"

#define BL_RED OCR1B
#define BL_GREEN OCR1A
#define BL_BLUE OCR1C

void matrix_init_kb(void) {
// put your keyboard start-up code here
// runs once when the firmware starts up

matrix_init_user();
}

void matrix_scan_kb(void) {
// put your looping keyboard code here
// runs every cycle (a lot)

matrix_scan_user();
}

bool process_record_kb(uint16_t keycode, keyrecord_t *record) {
// put your per-action keyboard code here
// runs for every action, just before processing by the firmware

return process_record_user(keycode, record);
}

void led_set_kb(uint8_t usb_led) {
// put your keyboard LED indicator (ex: Caps Lock LED) toggling code here

led_set_user(usb_led);
}

void backlight_init_ports(void)
{
// Set B5, B6, and B7 as output
Expand Down

0 comments on commit 95fd2ce

Please sign in to comment.