config.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. /*
  2. Copyright 2012 Jun Wako <wakojun@gmail.com>
  3. Copyright 2015 Jack Humbert
  4. This program is free software: you can redistribute it and/or modify
  5. it under the terms of the GNU General Public License as published by
  6. the Free Software Foundation, either version 2 of the License, or
  7. (at your option) any later version.
  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. You should have received a copy of the GNU General Public License
  13. along with this program. If not, see <http://www.gnu.org/licenses/>.
  14. */
  15. #ifndef PICO_CONFIG_H
  16. #define PICO_CONFIG_H
  17. /* USB Device descriptor parameter */
  18. #define VENDOR_ID 0xFEED
  19. #define PRODUCT_ID 0x3060
  20. #define DEVICE_VER 0x0002
  21. #define MANUFACTURER Yushakobo
  22. #define PRODUCT HelixPico
  23. #define DESCRIPTION A split keyboard for the cheap makers
  24. #define TAPPING_FORCE_HOLD
  25. #define TAPPING_TERM 100
  26. /* Use I2C or Serial */
  27. #define USE_I2C
  28. #define USE_SERIAL
  29. //#define USE_MATRIX_I2C
  30. /* Select hand configuration */
  31. #define MASTER_LEFT
  32. // #define MASTER_RIGHT
  33. // #define EE_HANDS
  34. // Helix keyboard OLED support
  35. // see ./rules.mk: OLED_ENABLE=yes or no
  36. #ifdef OLED_ENABLE
  37. #define SSD1306OLED
  38. #endif
  39. /* key matrix size */
  40. // Rows are doubled-up
  41. #define MATRIX_ROWS 8
  42. #define MATRIX_ROW_PINS { D4, C6, D7, E6 }
  43. // wiring of each half
  44. #define MATRIX_COLS 7
  45. #define MATRIX_COL_PINS { F4, F5, F6, F7, B1, B3, B2 }
  46. // #define MATRIX_COL_PINS { B2, B3, B1, F7, F6, F5, F4 } //uncomment this line and comment line above if you need to reverse left-to-right key order
  47. /* define if matrix has ghost */
  48. //#define MATRIX_HAS_GHOST
  49. /* number of backlight levels */
  50. // #define BACKLIGHT_LEVELS 3
  51. /* Set 0 if debouncing isn't needed */
  52. #define DEBOUNCING_DELAY 5
  53. /* Mechanical locking support. Use KC_LCAP, KC_LNUM or KC_LSCR instead in keymap */
  54. //#define LOCKING_SUPPORT_ENABLE
  55. /* Locking resynchronize hack */
  56. //#define LOCKING_RESYNC_ENABLE
  57. /* Audio */
  58. #ifdef AUDIO_ENABLE
  59. #define B5_AUDIO
  60. #endif
  61. /* ws2812 RGB LED */
  62. #define RGB_DI_PIN D3
  63. //#define RGBLED_NUM 12 // Number of LEDs. see ./keymaps/default/config.h
  64. // Helix keyboard RGB LED support
  65. //#define RGBLIGHT_ANIMATIONS : see ./rules.mk: LED_ANIMATIONS = yes or no
  66. // see ./rules.mk: LED_BACK_ENABLE or LED_UNDERGLOW_ENABLE set yes
  67. #ifdef RGBLED_BACK
  68. #define RGBLED_NUM 25
  69. #else
  70. #define RGBLED_NUM 6
  71. #endif
  72. #ifndef IOS_DEVICE_ENABLE
  73. #if RGBLED_NUM <= 6
  74. #define RGBLIGHT_LIMIT_VAL 255
  75. #else
  76. #define RGBLIGHT_LIMIT_VAL 130
  77. #endif
  78. #define RGBLIGHT_VAL_STEP 17
  79. #else
  80. #if RGBLED_NUM <= 6
  81. #define RGBLIGHT_LIMIT_VAL 90
  82. #else
  83. #define RGBLIGHT_LIMIT_VAL 45
  84. #endif
  85. #define RGBLIGHT_VAL_STEP 4
  86. #endif
  87. #define RGBLIGHT_HUE_STEP 10
  88. #define RGBLIGHT_SAT_STEP 17
  89. #if defined(RGBLIGHT_ENABLE) && !defined(IOS_DEVICE_ENABLE)
  90. // USB_MAX_POWER_CONSUMPTION value for Helix keyboard
  91. // 120 RGBoff, OLEDoff
  92. // 120 OLED
  93. // 330 RGB 6
  94. // 300 RGB 32
  95. // 310 OLED & RGB 32
  96. #define USB_MAX_POWER_CONSUMPTION 400
  97. #else
  98. // fix iPhone and iPad power adapter issue
  99. // iOS device need lessthan 100
  100. #define USB_MAX_POWER_CONSUMPTION 100
  101. #endif
  102. /*
  103. * Feature disable options
  104. * These options are also useful to firmware size reduction.
  105. */
  106. /* disable debug print */
  107. // #define NO_DEBUG
  108. /* disable print */
  109. // #define NO_PRINT
  110. /* disable action features */
  111. //#define NO_ACTION_LAYER
  112. //#define NO_ACTION_TAPPING
  113. //#define NO_ACTION_ONESHOT
  114. //#define NO_ACTION_MACRO
  115. //#define NO_ACTION_FUNCTION
  116. #endif