-
-
Notifications
You must be signed in to change notification settings - Fork 40k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Durgod keyboard refactor in preparation for adding additional durgod keyboards #11978
Conversation
I was able to build and flash the via keymap on my K320 ISO. Works like a charm with all 4 layers. I'm glad you know your way around memory much better than I do. Feel free to reach out if you need to test stuff on the K320 ISO hardware. |
Thank you @mcoirault, glad to hear the via keymap still works! Could you test that the new @AlCutter, @nomis, @mcoirault Regarding the |
@dkjer Regarding |
This is using |
Thanks @nomis ; PR updated.
Thanks for checking @mcoirault . @AlCutter I have removed the |
6104f01
to
762a6ab
Compare
Sorry about that, GitHub decided to delete the |
I think According to layouts/default/tkl_iso/default_tkl_iso/keymap.c it should be in row 4, not row 3. |
I'll be eagerly-awaiting this PR to get merged before I post the Durgod Taurus K310 non-backlit stuff currently located at https://github.com/tylert/qmk_firmware/tree/durgod_k310. Having just spent nearly two whole days tracing both a K320 ANSI keyboard and a K310 ANSI keyboard side-by-side, I'm reasonably confident we could combine the non-backlit K310 and the non-backlit K320 work into a single "keyboard". I'm going to try out a K310 firmware on a K320 board when I get a chance. Anybody with a K310 ISO keyboard willing to test a load for me? |
@nomis I'm not sure which |
@tylert I was just thinking the same thing, after seeing your changes. We could rename this keyboard I think having a separate |
The key spans two physical rows. It can only be in one row in the #define but it's currently in the wrong one. |
The ANSI Durgod keyboards I've looked at so far (two K310 boards and four K320 boards) all have holes for both the ANSI and ISO variants so I'm pretty sure they'd both use the same PCB. The 2 alternate holes for Enter on the PCB are electrically-connected on both switch pins meaning you could insert a switch at either the ANSI location or the ISO one. Regardless, the switch must sit at position Seems like @mcoirault also has an ISO keyboard so perhaps they would be willing to test again with the latest HEAD of this branch. I'm going to check some other examples of ISO Enter keys in the other keyboards to confirm though for the physical layouts. I suspect all the |
I am not debating the physical position of the key or where it is in in the matrix. For the I've made a PR to fix this: dkjer#2 |
The k310 is full size so they're not the same keyboard. You're making an assumption that there will never be a k300, k330, k340, etc. with different behaviour. Yes there may be ways to share files between the two keyboards but they are not a "k3x0" model. |
Any chance of backlight support for the k320? The regular version of the board has solder points for LEDs, so I've always assumed that it used the same PCB as the corona variant, just with different firmware. It'd be great to have those enabled at some point |
I think the stock firmware is actually the same on the backlight version because the key presses for increasing/decreasing the brightness work because it flashes all the status LEDs when you reach the minimum/maximum. There's an unpopulated "U3" chip header on my board along with some capacitors and resistors that might be required for the backlight? |
Ah, you might be right. It's right underneath that thin plastic card in most teardown pics that I could find so I didn't notice it |
I was thinking at the time that the unpopulated U3 chip might be a serial EEPROM or some additional flash. The traces are connected to a few of the B3-B7 or C0-C3 pins. Unfortunately, I didn't write down which pins these were as this wasn't a priority for me on the weekend. I might be convinced to open up one of my K320s again if folks want help confirming how similar the non-backlit K320 is to a backlit K320 by having me trace any additional data pins on the STM32F070 that aren't used for the key matrix or LEDs. Edit: I only have non-backlit boards at the moment. In case it helps others, all the pins that I did trace on the K310/K320 non-backlit boards I captured in a "ditaa" diagram at https://github.com/tylert/tylert.github.io/blob/master/source/hardware_stuff/schematic_durgod_k3x0_keyboard.txt (use "ditaa -r foo.txt -o foo.png" to turn it into a bitmap). The pin numbers are listed in the document at https://www.st.com/resource/en/datasheet/stm32f070c6.pdf (page 24, the LQFP64 package). Technically, the After this PR gets merged, I'm going to put my https://github.com/tylert/qmk_firmware/tree/durgod_k310 PR up which should have all the recommended changes made by @nomis for ISO support (Canada is stuck with ANSI boards). I've only done the bare essential keymaps "default" and "via" initially just to keep my first PR smaller... and my only K310 "customer" says she doesn't care about all those fancy-schmancy programmable features... yet :) |
@dkjer is there a reason why DEBOUNCE is set to 7ms? The default (and most other keyboards) have this set to 5. I've changed it to 0 and haven't noticed any problems yet, but that might not work for everyone. I've also set |
@nomis No particular reason it was set to 7ms DEBOUNCE as far as I know; that was the setting used in the original PR to add K320 support. I would be ok with defaulting that back to 5. Perhaps we should have an e-mail or discord discussion for non-PR related questions? As far as I can tell, this PR is ready to be merged, and the questions posed here are more about future incoming changes, or general tweaks to configuration. |
…keyboards * Moving Durgod board configuration into a common location * Reformatting layout macro whitespace * Moving TGUI key functionality to the keyboard level * Replacing default keymap.c with keymap.json * Changing default and default_toggle_mac_windows keymaps to LAYOUT_all * Increasing EEPROM size to support more VIA layers * Fixing media keys; KC_MRWD/KC_MFFD => KC_MPRV/KC_NXT
Rebased after pulling develop branch |
…keyboards (qmk#11978) * Durgod keyboard refactor in preparation for adding additional durgod keyboards * Moving Durgod board configuration into a common location * Reformatting layout macro whitespace * Moving TGUI key functionality to the keyboard level * Replacing default keymap.c with keymap.json * Changing default and default_toggle_mac_windows keymaps to LAYOUT_all * Increasing EEPROM size to support more VIA layers * Fixing media keys; KC_MRWD/KC_MFFD => KC_MPRV/KC_NXT * Move ISO Enter key to the correct row in Durgod K320 * Minor whitespace and readme cleanup for K320 * Changing durgod/k320 debounce back to default * Simplifying DURGOD_STM32_F070's chconf.h Co-authored-by: Simon Arlott <sa.me.uk> Co-authored-by: Tyler Tidman <[email protected]>
commit 6028a1f8cbe5922f7a9be4bb9ed8513c9312595f Author: Pete Sevander <[email protected]> Date: Fri Apr 2 15:49:55 2021 +0300 Fix sneaky infinite loop with `combo_disable()` No need to call `dump_key_buffer` when disabling combos because the buffer is either being dumped if a combo-key was pressed, or the buffer is empty if a non-combo-key is pressed. commit 4d9e53d1da81b2c610bed44f592e5ac268ef6400 Author: Pete Sevander <[email protected]> Date: Tue Mar 30 10:02:38 2021 +0300 Update docs/feature_combo.md Co-authored-by: precondition <[email protected]> commit 78a7f7089b177c3a722859d37ab6f2cc61222514 Author: Pete Sevander <[email protected]> Date: Tue Mar 30 08:43:37 2021 +0300 Change "the" combo action example to "email" example. commit 107e5432c04b25c68207f5e3d3294042bc86dff1 Author: Pete Sevander <[email protected]> Date: Mon Mar 29 21:27:17 2021 +0300 Update docs/feature_combo.md Co-authored-by: precondition <[email protected]> commit 95e48d61d7fc95ce77514625d992abdd067c656c Author: Pete Sevander <[email protected]> Date: Mon Mar 29 21:26:38 2021 +0300 Update docs/feature_combo.md Co-authored-by: precondition <[email protected]> commit 027e68d9fcb11148966eefe7682753a25424962a Author: Pete Sevander <[email protected]> Date: Mon Mar 29 21:23:04 2021 +0300 Update docs/feature_combo.md Co-authored-by: precondition <[email protected]> commit f3e149b61ae4aa2603c29d8973555b9c1e736109 Author: Pete Sevander <[email protected]> Date: Mon Mar 29 21:22:35 2021 +0300 Update docs/feature_combo.md Co-authored-by: precondition <[email protected]> commit 2342b98a73cd869c6039fb07d903c3891cec8268 Author: Pete Sevander <[email protected]> Date: Mon Mar 29 21:21:55 2021 +0300 Update docs/feature_combo.md Co-authored-by: precondition <[email protected]> commit d7447c7cebd20afd51787c3c98aeacb7f3fddd42 Author: Pete Sevander <[email protected]> Date: Sun Mar 28 23:17:05 2021 +0300 Add more examples and clarify things with dict management system. - Simple examples now has a combo that has modifiers included. - The slightly more advanced examples now are actually more advanced instead of just `tap_code16(<modded-keycode>)`. - Added a note that `COMBO_ACTION`s are not needed anymore as you can just use custom keycodes. - Added a note that the `g/keymap_combo.h` macros use the `process_combo_event` function and that it is not usable in one's keymap afterwards. commit 471ec9e96a88c8988939d28f1f3d69c7439ed609 Author: Pete Sevander <[email protected]> Date: Fri Mar 26 08:35:51 2021 +0200 Add `EXTRA_SHORT_COMBOS` option. Stuff combo's `disabled` and `active` flags into `state`. Possibly can save some space. commit 5ec2a51b36422617b2694be143d570626de41171 Author: Pete Sevander <[email protected]> Date: Thu Feb 11 11:57:27 2021 +0200 Update quantum/process_keycode/process_combo.c Co-authored-by: precondition <[email protected]> commit 9afd8d0e1466e3e62c48af759d8280cbb67518af Author: Pete Sevander <[email protected]> Date: Sat Feb 6 14:20:11 2021 +0200 Update docs/feature_combo.md Co-authored-by: precondition <[email protected]> commit 98791c48e05e356d8ed72bb935448aaa154eee00 Author: Pete Sevander <[email protected]> Date: Fri Feb 5 15:38:22 2021 +0200 Docs for `COMBO_ONLY_FROM_LAYER` commit feec1a83e008da5ac164b306587377acc4212395 Author: Pete Sevander <[email protected]> Date: Wed Feb 3 08:55:39 2021 +0200 Fix not passing a pointer when NO_ACTION_TAPPING is defined. commit 946866e58519c4dc0b4b89a13121ed272542eda2 Author: Pete Sevander <[email protected]> Date: Mon Feb 1 09:35:40 2021 +0200 Fix `process_combo_key_release` not called correctly with tap-only combos commit 40728c2e359e23577d8fa897ad45d1a3f61c68ff Author: Pete Sevander <[email protected]> Date: Mon Jan 25 13:12:08 2021 +0200 Remove the size flags from combo_t struct boolean members. This in the end actually saves space as the members are accessed so many times. The amount of operations needed to access the bits uses more memory than setting the size saves. commit 81a6bee0874e7e7fee9f071e02173083c3ea641d Author: Pete Sevander <[email protected]> Date: Sat Mar 28 21:13:12 2020 +0200 Combo processing improvements. Now it is possible to use ModTap and LayerTap keys as part of combos. Overlapping combos also don't trigger all the combos, just exactly the one that you press. New settings: - COMBO_MUST_HOLD_MODS - COMBO_MOD_TERM - COMBO_TERM_PER_COMBO - COMBO_MUST_HOLD_PER_COMBO - COMBO_STRICT_TIMER - COMBO_NO_TIMER commit 49ff80c4cb8f0d47bf92a15bbf174d3af38631a4 Author: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Date: Thu Mar 25 23:44:37 2021 +1100 Format code according to conventions (qmk#12381) Co-authored-by: QMK Bot <[email protected]> commit 45ea394a85023965d9875dbd1d02126b94bcc9b8 Author: Oleg Senchenko <[email protected]> Date: Thu Mar 25 15:42:25 2021 +0300 Fix connection issue in split keyboards when slave and OLED display are connected via I2C, fix qmk#9335 (qmk#11487) * In split keyboards fix connection issue when slave and OLED are connected via I2C. Fix qmk#9335 * Revert "In split keyboards fix connection issue when slave and OLED are connected via I2C. Fix qmk#9335" This reverts commit 3ee639e. * In split keyboards fix connection issue when slave and OLED are connected via I2C. Fix qmk#9335 * Update drivers/oled/oled_driver.c Co-authored-by: Drashna Jaelre <[email protected]> Co-authored-by: osenchenko <[email protected]> Co-authored-by: Drashna Jaelre <[email protected]> commit 7b283b6daa0db1e2494de45b0f12ae249c9df417 Author: Liyang HU <[email protected]> Date: Thu Mar 25 12:38:54 2021 +0000 keyboards/xd60/readme.md: link to schematic on EasyEDA (qmk#12018) commit d7725360987a05478aecc005b14552ecccaaf518 Author: XScorpion2 <[email protected]> Date: Thu Mar 25 06:33:18 2021 -0500 Adding keyboard level weak function for slave matrix scan (qmk#12317) commit deac178a077b528a9b4f41301fbb587f417c23df Author: Ryan <[email protected]> Date: Wed Mar 24 13:09:56 2021 +1100 LED Matrix: Fix up eeconfig code (qmk#12327) commit 7ec6d6d7bcaece0a8a3f032e24dca12f3e380da0 Author: Donald Kjer <[email protected]> Date: Sat Mar 20 17:11:22 2021 -0700 Durgod keyboard refactor in preparation for adding additional durgod keyboards (qmk#11978) * Durgod keyboard refactor in preparation for adding additional durgod keyboards * Moving Durgod board configuration into a common location * Reformatting layout macro whitespace * Moving TGUI key functionality to the keyboard level * Replacing default keymap.c with keymap.json * Changing default and default_toggle_mac_windows keymaps to LAYOUT_all * Increasing EEPROM size to support more VIA layers * Fixing media keys; KC_MRWD/KC_MFFD => KC_MPRV/KC_NXT * Move ISO Enter key to the correct row in Durgod K320 * Minor whitespace and readme cleanup for K320 * Changing durgod/k320 debounce back to default * Simplifying DURGOD_STM32_F070's chconf.h Co-authored-by: Simon Arlott <sa.me.uk> Co-authored-by: Tyler Tidman <[email protected]> commit c00d367f61026f6cf0ac9d726b4324436fa9973c Author: Ryan <[email protected]> Date: Sat Mar 20 14:52:33 2021 +1100 LED Matrix: Additional common_features.mk tweaks (qmk#12187) commit 16731c708e06f038c02f4f2205156938906c8c6f Author: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Date: Fri Mar 19 16:24:36 2021 +0000 Format code according to conventions (qmk#12292) Co-authored-by: QMK Bot <[email protected]> commit 208d7a6308bb10b7a18a0df4bf490402cd815e0f Author: Xelus22 <[email protected]> Date: Fri Mar 19 08:29:18 2021 +0000 ARM WS2812 SPI config (baudrate and circular buffer) (qmk#12216) * initial commit * include circular buffer command * add endif * circular buffer mode * remove untrue comment * revamp and add documentation * do not allow WS2812_SPI_SYNC & CIRCULAR_BUFFER commit 9075ff3219004ee650fa29d9b7a1d25481501c25 Author: Zach White <[email protected]> Date: Thu Mar 18 16:10:40 2021 -0700 Consistently use bin/qmk when that script is called (qmk#12286) * Pass QMK_BIN down to build_keyboard.mk * choose the correct qmk script commit aa90487a64a786cf6a47f853e77044edb6df926f Author: XScorpion2 <[email protected]> Date: Wed Mar 17 01:56:39 2021 -0500 [Keyboard] Split RGB Matrix Zygomorph support (qmk#11083) commit 1aa634007703948d424d7fcac33e334f1b4cf99e Author: Michael Stapelberg <[email protected]> Date: Tue Mar 16 20:45:21 2021 +0100 core: add support for MK66F18 (Teensy 3.6) micro controller (qmk#12258) This is in preparation for qmk#10171 commit 579b203ca71e5a5ad1ada7fed384fad94f9ca9db Author: Ryan <[email protected]> Date: Sat Mar 13 11:38:26 2021 +1100 LED Matrix: Clean up includes (qmk#12197) commit 24612f76ed751128ef1f5dc79a267a05b55c953b Author: Joel Challis <[email protected]> Date: Wed Mar 10 22:47:36 2021 +0000 Move gpio wait logic to wait.h (qmk#12067) commit 1019cc8bcfab05e49c6bd341e8fa7eb30d0376c7 Author: Ryan <[email protected]> Date: Thu Mar 11 05:21:28 2021 +1100 Remove `FUNC()` (qmk#12161) commit daa9bb7c45694e8c7a4f78d6093a73530a977b9b Author: Ryan <[email protected]> Date: Mon Mar 8 16:55:00 2021 +1100 LED Matrix: decouple from Backlight (qmk#12054) commit 0ba4d2a4c4f834cb8a51d9ec6e0fae2ecd8b1e82 Author: Zach White <[email protected]> Date: Sun Mar 7 19:10:03 2021 -0800 Begin the process of deprecating bin/qmk in favor of the global cli (qmk#12109) * Begin the process of deprecating bin/qmk in favor of the global cli * Correctly set the qmk bin commit e53d95a9421a5bfbb891b3a78244a8425184265a Author: Zach White <[email protected]> Date: Sun Mar 7 12:01:13 2021 -0800 trivial change to trigger api update commit be65191b4ecbde6d42437c7fe44bf409193bb857 Author: Drashna Jaelre <[email protected]> Date: Fri Mar 5 16:26:57 2021 -0800 Set default OLED Update Interval for Split Keyboards (qmk#12107) Because the matrix scanning is slower for splits, in general, the frequent updating of the OLEDs can slow down the matrix scanning. To help prevent that, set the update interval for the OLEDs to not update as frequently. commit 6c93b26b6a2b7ac5bc69743e4f65b42e00af2c6b Author: Drashna Jaelre <[email protected]> Date: Wed Mar 3 10:38:21 2021 -0800 [Keyboard] Enable RGB Matrix for Corne (qmk#12091) commit f58948330bab4c86f60d51055b7bc1ec27b430d2 Author: Sergey Vlasov <[email protected]> Date: Wed Mar 3 07:26:06 2021 +0300 Add support for complementary outputs to the WS2812 PWM driver (qmk#11988) commit a5befa39421b3c496d1589972de684ad7cb3c7ca Author: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Date: Wed Mar 3 07:54:11 2021 +1100 Format code according to conventions (qmk#12088) Co-authored-by: QMK Bot <[email protected]> commit b0a5c2f8660ee4e9e6df5e56e19077ea7552ab8e Author: XScorpion2 <[email protected]> Date: Tue Mar 2 14:32:15 2021 -0600 Split RGB Matrix (qmk#11055) * Split RGB Matrix * Suspend State sync for rgb matrix commit 62cd0f95540c2015025bd1a0e77fc2dd5ff02f1c Author: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Date: Mon Mar 1 18:08:18 2021 +0000 Format code according to conventions (qmk#12076) Co-authored-by: QMK Bot <[email protected]> commit e6cfb826df3dd6af3f90966d9a6ab9044feb9d22 Author: Drashna Jaelre <[email protected]> Date: Mon Mar 1 08:57:02 2021 -0800 Add ability to toggle One Shot functionality (qmk#4198) Co-authored-by: Nick Brassel <[email protected]> Co-authored-by: Ryan <[email protected]> commit 66b272e879cb8b8f43fa2c86ac2fe3ba7f5dcd91 Author: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Date: Sun Feb 28 15:53:54 2021 +0000 Format code according to conventions (qmk#12056) Co-authored-by: QMK Bot <[email protected]> commit f62a92d9d6fbc91e919b4ecc0941757851495235 Author: Joel Challis <[email protected]> Date: Sun Feb 28 15:52:58 2021 +0000 Refactor of USB code within split_common (qmk#11890) * Initial refactor of usb code within split_common * Add headers * Correct disable condition * Format * Align func name commit 988e1d20b93a5a728df4683a82a90c0073edf28f Author: Joel Challis <[email protected]> Date: Sun Feb 28 15:52:43 2021 +0000 ARM - Refactor SLEEP_LED to support more platforms (qmk#8403) * Initial refactor of ARM SLEEP_LED to enable more platforms * fix build issues * Disable SLEEP_LED for boards with no caps lock code * Enable GPT14 for boards with caps lock code and SLEEP_LED enabled * Enable GPT for boards with caps lock code and SLEEP_LED enabled commit 17c6a3896fb7db66bee21444a5f73553a5dc2f9f Author: Joel Challis <[email protected]> Date: Sun Feb 28 15:50:15 2021 +0000 Overhaul bootmagic logic to have single entrypoint (qmk#8532) * Relocate bootmagic logic to have single entrypoint * Align init of layer state commit 8fc5dcf094e12b24379dd2e152804aedeaa2a14c Author: James Young <[email protected]> Date: Sat Feb 27 12:54:23 2021 -0800 Branch point for 2021 May 29 Breaking Change
…keyboards (qmk#11978) * Durgod keyboard refactor in preparation for adding additional durgod keyboards * Moving Durgod board configuration into a common location * Reformatting layout macro whitespace * Moving TGUI key functionality to the keyboard level * Replacing default keymap.c with keymap.json * Changing default and default_toggle_mac_windows keymaps to LAYOUT_all * Increasing EEPROM size to support more VIA layers * Fixing media keys; KC_MRWD/KC_MFFD => KC_MPRV/KC_NXT * Move ISO Enter key to the correct row in Durgod K320 * Minor whitespace and readme cleanup for K320 * Changing durgod/k320 debounce back to default * Simplifying DURGOD_STM32_F070's chconf.h Co-authored-by: Simon Arlott <sa.me.uk> Co-authored-by: Tyler Tidman <[email protected]>
…keyboards (qmk#11978) * Durgod keyboard refactor in preparation for adding additional durgod keyboards * Moving Durgod board configuration into a common location * Reformatting layout macro whitespace * Moving TGUI key functionality to the keyboard level * Replacing default keymap.c with keymap.json * Changing default and default_toggle_mac_windows keymaps to LAYOUT_all * Increasing EEPROM size to support more VIA layers * Fixing media keys; KC_MRWD/KC_MFFD => KC_MPRV/KC_NXT * Move ISO Enter key to the correct row in Durgod K320 * Minor whitespace and readme cleanup for K320 * Changing durgod/k320 debounce back to default * Simplifying DURGOD_STM32_F070's chconf.h Co-authored-by: Simon Arlott <sa.me.uk> Co-authored-by: Tyler Tidman <[email protected]>
…keyboards (qmk#11978) * Durgod keyboard refactor in preparation for adding additional durgod keyboards * Moving Durgod board configuration into a common location * Reformatting layout macro whitespace * Moving TGUI key functionality to the keyboard level * Replacing default keymap.c with keymap.json * Changing default and default_toggle_mac_windows keymaps to LAYOUT_all * Increasing EEPROM size to support more VIA layers * Fixing media keys; KC_MRWD/KC_MFFD => KC_MPRV/KC_NXT * Move ISO Enter key to the correct row in Durgod K320 * Minor whitespace and readme cleanup for K320 * Changing durgod/k320 debounce back to default * Simplifying DURGOD_STM32_F070's chconf.h Co-authored-by: Simon Arlott <sa.me.uk> Co-authored-by: Tyler Tidman <[email protected]>
In preparation for adding additional Durgod keyboards, performing some clean up:
Description
Types of Changes
Issues Fixed or Closed by This PR
Checklist