aboutsummaryrefslogtreecommitdiffstats
path: root/keyboards/kmac/kmac.c
diff options
context:
space:
mode:
authorMathias Andersson <wraul@dbox.se>2019-06-26 09:32:03 +0200
committerDrashna Jaelre <drashna@live.com>2019-06-26 00:32:03 -0700
commit3483c51f62640c83d35a0b4c4636a5939f2c3898 (patch)
treebf4d0a94104a5e883c7b0f9d9b53aad982627a0c /keyboards/kmac/kmac.c
parent8fd3f42281885346f93fff2f122569c002071c67 (diff)
downloadfirmware-3483c51f62640c83d35a0b4c4636a5939f2c3898.tar.gz
firmware-3483c51f62640c83d35a0b4c4636a5939f2c3898.tar.bz2
firmware-3483c51f62640c83d35a0b4c4636a5939f2c3898.zip
[Keyboard] Modernize KMAC (#6131)
* [Keyboard] Modernize the KMAC implementation This brings the matrix implementation more in line with the current default matrix code. It also simplifies the implementation quite a bit. * [Keyboard] Add layout support to KMAC
Diffstat (limited to 'keyboards/kmac/kmac.c')
-rw-r--r--keyboards/kmac/kmac.c100
1 files changed, 50 insertions, 50 deletions
diff --git a/keyboards/kmac/kmac.c b/keyboards/kmac/kmac.c
index 6b54294b4..dcbbc2f17 100644
--- a/keyboards/kmac/kmac.c
+++ b/keyboards/kmac/kmac.c
@@ -1,4 +1,4 @@
-/* Copyright 2017 Mathias Andersson <wraul@dbox.se>
+/* Copyright 2017-2019 Mathias Andersson <wraul@dbox.se>
*
* 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
@@ -15,61 +15,68 @@
*/
#include "kmac.h"
+#define CAPS_PIN B0
+#define SCROLL_PIN E6
+#define F_ROW_MASK 0b01
+#define WASD_MASK 0b10
+
+// Optional override functions below.
+// You can leave any or all of these undefined.
+// These are only required if you want to perform custom actions.
+
void matrix_init_kb(void) {
// put your keyboard start-up code here
// runs once when the firmware starts up
- led_init_ports();
+ setPinOutput(CAPS_PIN);
+ setPinOutput(SCROLL_PIN);
+
matrix_init_user();
}
+/*
+
void matrix_scan_kb(void) {
- // put your looping keyboard code here
- // runs every cycle (a lot)
+ // put your looping keyboard code here
+ // runs every cycle (a lot)
- matrix_scan_user();
+ 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
+ // put your per-action keyboard code here
+ // runs for every action, just before processing by the firmware
- return process_record_user(keycode, record);
+ return process_record_user(keycode, record);
}
-void led_init_ports(void) {
- DDRB |= (1<<0); // OUT
- DDRE |= (1<<6); // OUT
-}
+*/
/* LED pin configuration
* Scroll Lock: Low PE6
* Caps Lock: Low PB0
*/
void led_set_kb(uint8_t usb_led) {
- if (usb_led & (1<<USB_LED_CAPS_LOCK))
- {
- PORTB &= ~(1<<0); // LO
- }
- else
- {
- PORTB |= (1<<0); // HI
+ if (IS_LED_ON(usb_led, USB_LED_CAPS_LOCK)) {
+ writePinLow(CAPS_PIN);
+ } else {
+ writePinHigh(CAPS_PIN);
}
- if (usb_led & (1<<USB_LED_SCROLL_LOCK))
- {
- PORTE &= ~(1<<6); // LO
- }
- else
- {
- PORTE |= (1<<6); // HI
+ if (IS_LED_ON(usb_led, USB_LED_SCROLL_LOCK)) {
+ writePinLow(SCROLL_PIN);
+ } else {
+ writePinHigh(SCROLL_PIN);
}
led_set_user(usb_led);
}
void backlight_init_ports(void) {
- DDRB |= (1<<1) | (1<<2) | (1<<3) | (1<<4); // OUT
- DDRD |= (1<<7); // OUT
+ setPinOutput(B1);
+ setPinOutput(B2);
+ setPinOutput(B3);
+ setPinOutput(B4);
+ setPinOutput(D7);
}
/* Backlight pin configuration
@@ -79,31 +86,24 @@ void backlight_init_ports(void) {
* S: Low PB3
* D: Low PD7
*/
-void backlight_set(uint8_t level)
-{
+void backlight_set(uint8_t level) {
// F-row
- if(level & (1<<0))
- {
- PORTB |= (1<<1); // HI
- }
- else
- {
- PORTB &= ~(1<<1); // LO
+ if (level & F_ROW_MASK) {
+ writePinHigh(B1);
+ } else {
+ writePinLow(B1);
}
// WASD
- if(level & (1<<1))
- {
- PORTB &= ~(1<<4); // LO
- PORTB &= ~(1<<2); // LO
- PORTB &= ~(1<<3); // LO
- PORTD &= ~(1<<7); // LO
- }
- else
- {
- PORTB |= (1<<4); // HI
- PORTB |= (1<<2); // HI
- PORTB |= (1<<3); // HI
- PORTD |= (1<<7); // HI
+ if (level & WASD_MASK) {
+ writePinLow(B2);
+ writePinLow(B3);
+ writePinLow(B4);
+ writePinLow(D7);
+ } else {
+ writePinHigh(B2);
+ writePinHigh(B3);
+ writePinHigh(B4);
+ writePinHigh(D7);
}
}