You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

226 lines
6.3 KiB

Backlighting for JJ40 and underglow initialisation code (#2260) * Cleanup Mechmini keymap. Once the custom RGB function is defined, there is no need to manually handle RGB code. * Change default to KEYMAP_MIT, not KEYMAP_OFFSET * Add custom RGB code for JJ40 * Reset Mechmini advertised power draw to 500. Will have to test actual maximum power draw later. * RGB working on JJ40. * Fix: saturation increase/decrease flipped * Add new directory for my custom keymap with RGB keycodes * Swap LAlt and LGUI * Update JJ40 max power draw with measured value * Update: fun40 rules.mk to enable underglow; earlier failed Travis CI * Fix: init RGB LEDs on boot. Also added HHKB-like keymap for XD60. * Super rudimentary backlight test, init RGB LEDs on boot * Backlighting works - stays on for now * Toggling working * Now can override backlight.c functions. Problem was functions in backlight.c weren't called before due to a lack of matrix_scan_quantum() in matrix.c * Timers not working * Delete global.h * Cleanup * Compiles * Good sign: LEDs stop working again * Handle timer1 overflow * Progress: fix: forgot to init * Backlighting fully working now except breathing. * Revert keymap to original keycodes * Update XD60 keymap README * Update JJ40 keymap with backlight toggles * Breathing working just fine. * Update references * Add backlight_set() call * Cleanup code to disable backlight * Fix: does not compile * Fix: missing call to rgblight_task. * Testing with BACKLIGHT_BREATHING * Cleanup * Cleanup comments * More commenting cleanup. * Do not enable BACKLIGHT_BREATHING by default
6 years ago
Lets split eh (#3120) * Line ending stuff again * Added Let's Split Eh? Files and updated #USE_IC2 checks to also include th EH revision (can only be used in I2C) * Added personal keymap, updated some of the EH files * Created new keyboard file for testing "lets_split_eh" will merge into lets_split once fully functional * Added split code from lets_split, removed pro micro imports and LED code THIS IS WORKING CODE, WITHOUT RGB AND BACKLIGHT * Took back original Lets Slit files for the lets_split keyboard, working in the lets_split_eh folder for now * Updated eh.c * More rework of the I2C code, added global flags for split boards. * Introduced RGB over I2C, having weird edge case issues at the moment though * Fixed weird I2C edgecase with RGB, although still would like to track down route cause.. * Changed RGB keycodes (static ones) to activate on key-up instead of key-down to elimate weird ghosting issue over I2C * Lots of changes, mainly externalized the Split keyboard code and added logic for only including when needed. - Added makefile option "SPLIT_KEYBOARD" that when = yes will include the split keyboard files and custom matrix - Split keyboard files placed into quantum/split_common/ - Added define option for config files "SPLIT_HAND_PIN" FOr using high/low pin to determine handedness, low = right hand, high = left hand - Cleaned up split logic for RGB and Backlight so it is only exectuted / included when needed * Updated documentation for the new makefile options and #defines specific to split keyboards * Added a bit more info to docs, so people aren't confused * Modifed Let's Split to use externalized code, also added left and right hand eeprom files to the split_common folder * Removed some debugging from eh.c * Small changes to keyboard configs. Also added a default keymap (just a copy of my that_canadian keymap). * Added a README file to the Let's Split Eh? * Changed it so RGB static updates are done on key-up ONLY for split boards rather than all boards. Also fixed leftover un-used variable in rgblight.c * Updated default keymap and my keymap for Let's Split Eh? Updated the comments so it reflects RGB control, and removed audio functions. * Fixed lets_split_eh not having a default version * Removed "eh" references from lets_split folder for now * Took lets_split folder from master to fix travis build errors, weird my local was overriding. * Changed LAYOUT_ortho_4x12_kc -> LAYOUT_kc_ortho_4x12 to match bakingpy and others * Removed rules.mk from my lets_split keymap, not needed * Updated the config_options doc to better explain the usage of "#define SPLIT_HAND_PIN"
5 years ago
  1. # Copyright 2017 Fred Sundvik
  2. #
  3. # This program is free software: you can redistribute it and/or modify
  4. # it under the terms of the GNU General Public License as published by
  5. # the Free Software Foundation, either version 2 of the License, or
  6. # (at your option) any later version.
  7. #
  8. # This program is distributed in the hope that it will be useful,
  9. # but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. # GNU General Public License for more details.
  12. #
  13. # You should have received a copy of the GNU General Public License
  14. # along with this program. If not, see <http://www.gnu.org/licenses/>.
  15. SERIAL_DIR := $(QUANTUM_DIR)/serial_link
  16. SERIAL_PATH := $(QUANTUM_PATH)/serial_link
  17. SERIAL_SRC := $(wildcard $(SERIAL_PATH)/protocol/*.c)
  18. SERIAL_SRC += $(wildcard $(SERIAL_PATH)/system/*.c)
  19. SERIAL_DEFS += -DSERIAL_LINK_ENABLE
  20. COMMON_VPATH += $(SERIAL_PATH)
  21. ifeq ($(strip $(API_SYSEX_ENABLE)), yes)
  22. OPT_DEFS += -DAPI_SYSEX_ENABLE
  23. SRC += $(QUANTUM_DIR)/api/api_sysex.c
  24. OPT_DEFS += -DAPI_ENABLE
  25. SRC += $(QUANTUM_DIR)/api.c
  26. MIDI_ENABLE=yes
  27. endif
  28. MUSIC_ENABLE := 0
  29. ifeq ($(strip $(AUDIO_ENABLE)), yes)
  30. OPT_DEFS += -DAUDIO_ENABLE
  31. MUSIC_ENABLE := 1
  32. SRC += $(QUANTUM_DIR)/process_keycode/process_audio.c
  33. SRC += $(QUANTUM_DIR)/process_keycode/process_clicky.c
  34. ifeq ($(PLATFORM),AVR)
  35. SRC += $(QUANTUM_DIR)/audio/audio.c
  36. else
  37. SRC += $(QUANTUM_DIR)/audio/audio_arm.c
  38. endif
  39. SRC += $(QUANTUM_DIR)/audio/voices.c
  40. SRC += $(QUANTUM_DIR)/audio/luts.c
  41. endif
  42. ifeq ($(strip $(MIDI_ENABLE)), yes)
  43. OPT_DEFS += -DMIDI_ENABLE
  44. MUSIC_ENABLE := 1
  45. SRC += $(QUANTUM_DIR)/process_keycode/process_midi.c
  46. endif
  47. ifeq ($(MUSIC_ENABLE), 1)
  48. SRC += $(QUANTUM_DIR)/process_keycode/process_music.c
  49. endif
  50. ifeq ($(strip $(COMBO_ENABLE)), yes)
  51. OPT_DEFS += -DCOMBO_ENABLE
  52. SRC += $(QUANTUM_DIR)/process_keycode/process_combo.c
  53. endif
  54. ifeq ($(strip $(STENO_ENABLE)), yes)
  55. OPT_DEFS += -DSTENO_ENABLE
  56. VIRTSER_ENABLE := yes
  57. SRC += $(QUANTUM_DIR)/process_keycode/process_steno.c
  58. endif
  59. ifeq ($(strip $(VIRTSER_ENABLE)), yes)
  60. OPT_DEFS += -DVIRTSER_ENABLE
  61. endif
  62. ifeq ($(strip $(FAUXCLICKY_ENABLE)), yes)
  63. OPT_DEFS += -DFAUXCLICKY_ENABLE
  64. SRC += $(QUANTUM_DIR)/fauxclicky.c
  65. endif
  66. ifeq ($(strip $(POINTING_DEVICE_ENABLE)), yes)
  67. OPT_DEFS += -DPOINTING_DEVICE_ENABLE
  68. OPT_DEFS += -DMOUSE_ENABLE
  69. SRC += $(QUANTUM_DIR)/pointing_device.c
  70. endif
  71. ifeq ($(strip $(UCIS_ENABLE)), yes)
  72. OPT_DEFS += -DUCIS_ENABLE
  73. UNICODE_COMMON = yes
  74. SRC += $(QUANTUM_DIR)/process_keycode/process_ucis.c
  75. endif
  76. ifeq ($(strip $(UNICODEMAP_ENABLE)), yes)
  77. OPT_DEFS += -DUNICODEMAP_ENABLE
  78. UNICODE_COMMON = yes
  79. SRC += $(QUANTUM_DIR)/process_keycode/process_unicodemap.c
  80. endif
  81. ifeq ($(strip $(UNICODE_ENABLE)), yes)
  82. OPT_DEFS += -DUNICODE_ENABLE
  83. UNICODE_COMMON = yes
  84. SRC += $(QUANTUM_DIR)/process_keycode/process_unicode.c
  85. endif
  86. ifeq ($(strip $(UNICODE_COMMON)), yes)
  87. SRC += $(QUANTUM_DIR)/process_keycode/process_unicode_common.c
  88. endif
  89. ifeq ($(strip $(RGBLIGHT_ENABLE)), yes)
  90. OPT_DEFS += -DRGBLIGHT_ENABLE
  91. SRC += $(QUANTUM_DIR)/rgblight.c
  92. CIE1931_CURVE = yes
  93. LED_BREATHING_TABLE = yes
  94. ifeq ($(strip $(RGBLIGHT_CUSTOM_DRIVER)), yes)
  95. OPT_DEFS += -DRGBLIGHT_CUSTOM_DRIVER
  96. else
  97. SRC += ws2812.c
  98. endif
  99. endif
  100. ifeq ($(strip $(RGB_MATRIX_ENABLE)), yes)
  101. OPT_DEFS += -DRGB_MATRIX_ENABLE
  102. SRC += is31fl3731.c
  103. SRC += i2c_master.c
  104. SRC += $(QUANTUM_DIR)/color.c
  105. SRC += $(QUANTUM_DIR)/rgb_matrix.c
  106. CIE1931_CURVE = yes
  107. endif
  108. ifeq ($(strip $(TAP_DANCE_ENABLE)), yes)
  109. OPT_DEFS += -DTAP_DANCE_ENABLE
  110. SRC += $(QUANTUM_DIR)/process_keycode/process_tap_dance.c
  111. endif
  112. ifeq ($(strip $(KEY_LOCK_ENABLE)), yes)
  113. OPT_DEFS += -DKEY_LOCK_ENABLE
  114. SRC += $(QUANTUM_DIR)/process_keycode/process_key_lock.c
  115. endif
  116. ifeq ($(strip $(PRINTING_ENABLE)), yes)
  117. OPT_DEFS += -DPRINTING_ENABLE
  118. SRC += $(QUANTUM_DIR)/process_keycode/process_printer.c
  119. SRC += $(TMK_DIR)/protocol/serial_uart.c
  120. endif
  121. ifeq ($(strip $(AUTO_SHIFT_ENABLE)), yes)
  122. OPT_DEFS += -DAUTO_SHIFT_ENABLE
  123. SRC += $(QUANTUM_DIR)/process_keycode/process_auto_shift.c
  124. ifeq ($(strip $(AUTO_SHIFT_MODIFIERS)), yes)
  125. OPT_DEFS += -DAUTO_SHIFT_MODIFIERS
  126. endif
  127. endif
  128. ifeq ($(strip $(SERIAL_LINK_ENABLE)), yes)
  129. SRC += $(patsubst $(QUANTUM_PATH)/%,%,$(SERIAL_SRC))
  130. OPT_DEFS += $(SERIAL_DEFS)
  131. VAPTH += $(SERIAL_PATH)
  132. endif
  133. ifneq ($(strip $(VARIABLE_TRACE)),)
  134. SRC += $(QUANTUM_DIR)/variable_trace.c
  135. OPT_DEFS += -DNUM_TRACED_VARIABLES=$(strip $(VARIABLE_TRACE))
  136. ifneq ($(strip $(MAX_VARIABLE_TRACE_SIZE)),)
  137. OPT_DEFS += -DMAX_VARIABLE_TRACE_SIZE=$(strip $(MAX_VARIABLE_TRACE_SIZE))
  138. endif
  139. endif
  140. ifeq ($(strip $(LCD_ENABLE)), yes)
  141. CIE1931_CURVE = yes
  142. endif
  143. ifeq ($(strip $(BACKLIGHT_ENABLE)), yes)
  144. ifeq ($(strip $(VISUALIZER_ENABLE)), yes)
  145. CIE1931_CURVE = yes
  146. endif
  147. ifeq ($(strip $(BACKLIGHT_CUSTOM_DRIVER)), yes)
  148. OPT_DEFS += -DBACKLIGHT_CUSTOM_DRIVER
  149. endif
  150. endif
  151. ifeq ($(strip $(CIE1931_CURVE)), yes)
  152. OPT_DEFS += -DUSE_CIE1931_CURVE
  153. LED_TABLES = yes
  154. endif
  155. ifeq ($(strip $(LED_BREATHING_TABLE)), yes)
  156. OPT_DEFS += -DUSE_LED_BREATHING_TABLE
  157. LED_TABLES = yes
  158. endif
  159. ifeq ($(strip $(LED_TABLES)), yes)
  160. SRC += $(QUANTUM_DIR)/led_tables.c
  161. endif
  162. ifeq ($(strip $(TERMINAL_ENABLE)), yes)
  163. SRC += $(QUANTUM_DIR)/process_keycode/process_terminal.c
  164. OPT_DEFS += -DTERMINAL_ENABLE
  165. endif
  166. ifeq ($(strip $(USB_HID_ENABLE)), yes)
  167. include $(TMK_DIR)/protocol/usb_hid.mk
  168. endif
  169. ifeq ($(strip $(HD44780_ENABLE)), yes)
  170. SRC += drivers/avr/hd44780.c
  171. OPT_DEFS += -DHD44780_ENABLE
  172. endif
  173. QUANTUM_SRC:= \
  174. $(QUANTUM_DIR)/quantum.c \
  175. $(QUANTUM_DIR)/keymap_common.c \
  176. $(QUANTUM_DIR)/keycode_config.c \
  177. $(QUANTUM_DIR)/process_keycode/process_leader.c
  178. ifndef CUSTOM_MATRIX
  179. ifeq ($(strip $(SPLIT_KEYBOARD)), yes)
  180. QUANTUM_SRC += $(QUANTUM_DIR)/split_common/matrix.c
  181. else
  182. QUANTUM_SRC += $(QUANTUM_DIR)/matrix.c
  183. endif
  184. endif
  185. ifeq ($(strip $(SPLIT_KEYBOARD)), yes)
  186. OPT_DEFS += -DSPLIT_KEYBOARD
  187. QUANTUM_SRC += $(QUANTUM_DIR)/split_common/split_flags.c \
  188. $(QUANTUM_DIR)/split_common/split_util.c \
  189. $(QUANTUM_DIR)/split_common/i2c.c \
  190. $(QUANTUM_DIR)/split_common/serial.c
  191. endif