chibios_config.h 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. /* Copyright 2019
  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. */
  16. #pragma once
  17. #ifndef USB_VBUS_PIN
  18. # define SPLIT_USB_DETECT // Force this on when dedicated pin is not used
  19. #endif
  20. // STM32 compatibility
  21. #if defined(MCU_STM32)
  22. # define CPU_CLOCK STM32_SYSCLK
  23. # if defined(STM32F1XX)
  24. # define USE_GPIOV1
  25. # define PAL_MODE_ALTERNATE_OPENDRAIN PAL_MODE_STM32_ALTERNATE_OPENDRAIN
  26. # define PAL_MODE_ALTERNATE_PUSHPULL PAL_MODE_STM32_ALTERNATE_PUSHPULL
  27. # else
  28. # define PAL_OUTPUT_TYPE_OPENDRAIN PAL_STM32_OTYPE_OPENDRAIN
  29. # define PAL_OUTPUT_TYPE_PUSHPULL PAL_STM32_OTYPE_PUSHPULL
  30. # define PAL_OUTPUT_SPEED_HIGHEST PAL_STM32_OSPEED_HIGHEST
  31. # define PAL_PUPDR_FLOATING PAL_STM32_PUPDR_FLOATING
  32. # endif
  33. # if defined(STM32F1XX) || defined(STM32F2XX) || defined(STM32F4XX) || defined(STM32L1XX)
  34. # define USE_I2CV1
  35. # endif
  36. #endif
  37. // GD32 compatibility
  38. #if defined(MCU_GD32V)
  39. # define CPU_CLOCK GD32_SYSCLK
  40. # if defined(GD32VF103)
  41. # define USE_GPIOV1
  42. # define USE_I2CV1
  43. # define PAL_MODE_ALTERNATE_OPENDRAIN PAL_MODE_GD32_ALTERNATE_OPENDRAIN
  44. # define PAL_MODE_ALTERNATE_PUSHPULL PAL_MODE_GD32_ALTERNATE_PUSHPULL
  45. # endif
  46. #endif
  47. // WB32 compatibility
  48. #if defined(MCU_WB32)
  49. # define CPU_CLOCK WB32_MAINCLK
  50. # if defined(WB32F3G71xx)
  51. # define PAL_OUTPUT_TYPE_OPENDRAIN PAL_WB32_OTYPE_OPENDRAIN
  52. # define PAL_OUTPUT_TYPE_PUSHPULL PAL_WB32_OTYPE_PUSHPULL
  53. # define PAL_OUTPUT_SPEED_HIGHEST PAL_WB32_OSPEED_HIGH
  54. # define PAL_PUPDR_FLOATING PAL_WB32_PUPDR_FLOATING
  55. # endif
  56. #endif
  57. #if defined(GD32VF103)
  58. /* This chip has the same API as STM32F103, but uses different names for literally the same thing.
  59. * As of 4.7.2021 QMK is tailored to use STM32 defines/names, for compatibility sake
  60. * we just redefine the GD32 names. */
  61. # include "gd32v_compatibility.h"
  62. #endif
  63. // teensy compatibility
  64. #if defined(MCU_KINETIS)
  65. # define CPU_CLOCK KINETIS_SYSCLK_FREQUENCY
  66. # if defined(K20x) || defined(KL2x)
  67. # define USE_I2CV1
  68. # define USE_I2CV1_CONTRIB // for some reason a bunch of ChibiOS-Contrib boards only have clock_speed
  69. # define USE_GPIOV1
  70. # endif
  71. #endif
  72. #if defined(HT32)
  73. # define CPU_CLOCK HT32_CK_SYS_FREQUENCY
  74. # define PAL_MODE_ALTERNATE PAL_HT32_MODE_AF
  75. # define PAL_OUTPUT_TYPE_OPENDRAIN (PAL_HT32_MODE_OD | PAL_HT32_MODE_DIR)
  76. # define PAL_OUTPUT_TYPE_PUSHPULL PAL_HT32_MODE_DIR
  77. # define PAL_OUTPUT_SPEED_HIGHEST 0
  78. #endif