mirror of
https://github.com/qmk/qmk_firmware.git
synced 2024-11-22 11:29:26 +00:00
325 lines
13 KiB
Python
325 lines
13 KiB
Python
"""Information that should be available to the python library.
|
|
"""
|
|
from os import environ
|
|
from datetime import date
|
|
from pathlib import Path
|
|
|
|
from qmk.userspace import detect_qmk_userspace
|
|
|
|
# The root of the qmk_firmware tree.
|
|
QMK_FIRMWARE = Path.cwd()
|
|
|
|
# The detected userspace tree
|
|
QMK_USERSPACE = detect_qmk_userspace()
|
|
|
|
# Whether or not we have a separate userspace directory
|
|
HAS_QMK_USERSPACE = True if QMK_USERSPACE is not None else False
|
|
|
|
# Upstream repo url
|
|
QMK_FIRMWARE_UPSTREAM = 'qmk/qmk_firmware'
|
|
|
|
# This is the number of directories under `qmk_firmware/keyboards` that will be traversed. This is currently a limitation of our make system.
|
|
MAX_KEYBOARD_SUBFOLDERS = 5
|
|
|
|
# Supported processor types
|
|
CHIBIOS_PROCESSORS = 'cortex-m0', 'cortex-m0plus', 'cortex-m3', 'cortex-m4', 'MKL26Z64', 'MK20DX128', 'MK20DX256', 'MK64FX512', 'MK66FX1M0', 'RP2040', 'STM32F042', 'STM32F072', 'STM32F103', 'STM32F303', 'STM32F401', 'STM32F405', 'STM32F407', 'STM32F411', 'STM32F446', 'STM32G431', 'STM32G474', 'STM32H723', 'STM32H733', 'STM32L412', 'STM32L422', 'STM32L432', 'STM32L433', 'STM32L442', 'STM32L443', 'GD32VF103', 'WB32F3G71', 'WB32FQ95'
|
|
LUFA_PROCESSORS = 'at90usb162', 'atmega16u2', 'atmega32u2', 'atmega16u4', 'atmega32u4', 'at90usb646', 'at90usb647', 'at90usb1286', 'at90usb1287', None
|
|
VUSB_PROCESSORS = 'atmega32a', 'atmega328p', 'atmega328', 'attiny85'
|
|
|
|
# Bootloaders of the supported processors
|
|
MCU2BOOTLOADER = {
|
|
"RP2040": "rp2040",
|
|
"MKL26Z64": "halfkay",
|
|
"MK20DX128": "halfkay",
|
|
"MK20DX256": "halfkay",
|
|
"MK66FX1M0": "halfkay",
|
|
"STM32F042": "stm32-dfu",
|
|
"STM32F072": "stm32-dfu",
|
|
"STM32F103": "stm32duino",
|
|
"STM32F303": "stm32-dfu",
|
|
"STM32F401": "stm32-dfu",
|
|
"STM32F405": "stm32-dfu",
|
|
"STM32F407": "stm32-dfu",
|
|
"STM32F411": "stm32-dfu",
|
|
"STM32F446": "stm32-dfu",
|
|
"STM32G431": "stm32-dfu",
|
|
"STM32G474": "stm32-dfu",
|
|
"STM32H723": "stm32-dfu",
|
|
"STM32H733": "stm32-dfu",
|
|
"STM32L412": "stm32-dfu",
|
|
"STM32L422": "stm32-dfu",
|
|
"STM32L432": "stm32-dfu",
|
|
"STM32L433": "stm32-dfu",
|
|
"STM32L442": "stm32-dfu",
|
|
"STM32L443": "stm32-dfu",
|
|
"GD32VF103": "gd32v-dfu",
|
|
"WB32F3G71": "wb32-dfu",
|
|
"WB32FQ95": "wb32-dfu",
|
|
"atmega16u2": "atmel-dfu",
|
|
"atmega32u2": "atmel-dfu",
|
|
"atmega16u4": "atmel-dfu",
|
|
"atmega32u4": "atmel-dfu",
|
|
"at90usb162": "atmel-dfu",
|
|
"at90usb646": "atmel-dfu",
|
|
"at90usb647": "atmel-dfu",
|
|
"at90usb1286": "atmel-dfu",
|
|
"at90usb1287": "atmel-dfu",
|
|
"atmega32a": "bootloadhid",
|
|
"atmega328p": "usbasploader",
|
|
"atmega328": "usbasploader",
|
|
}
|
|
|
|
# Map of legacy keycodes that can be automatically updated
|
|
LEGACY_KEYCODES = { # Comment here is to force multiline formatting
|
|
'RESET': 'QK_BOOT'
|
|
}
|
|
|
|
# Map VID:PID values to bootloaders
|
|
BOOTLOADER_VIDS_PIDS = {
|
|
'atmel-dfu': {
|
|
("03eb", "2fef"), # ATmega16U2
|
|
("03eb", "2ff0"), # ATmega32U2
|
|
("03eb", "2ff3"), # ATmega16U4
|
|
("03eb", "2ff4"), # ATmega32U4
|
|
("03eb", "2ff9"), # AT90USB64
|
|
("03eb", "2ffa"), # AT90USB162
|
|
("03eb", "2ffb") # AT90USB128
|
|
},
|
|
'kiibohd': {("1c11", "b007")},
|
|
'stm32-dfu': {
|
|
("1eaf", "0003"), # STM32duino
|
|
("0483", "df11") # STM32 DFU
|
|
},
|
|
'apm32-dfu': {("314b", "0106")},
|
|
'gd32v-dfu': {("28e9", "0189")},
|
|
'wb32-dfu': {("342d", "dfa0")},
|
|
'bootloadhid': {("16c0", "05df")},
|
|
'usbasploader': {("16c0", "05dc")},
|
|
'usbtinyisp': {("1782", "0c9f")},
|
|
'md-boot': {("03eb", "6124")},
|
|
'caterina': {
|
|
# pid.codes shared PID
|
|
("1209", "2302"), # Keyboardio Atreus 2 Bootloader
|
|
# Spark Fun Electronics
|
|
("1b4f", "9203"), # Pro Micro 3V3/8MHz
|
|
("1b4f", "9205"), # Pro Micro 5V/16MHz
|
|
("1b4f", "9207"), # LilyPad 3V3/8MHz (and some Pro Micro clones)
|
|
# Pololu Electronics
|
|
("1ffb", "0101"), # A-Star 32U4
|
|
# Arduino SA
|
|
("2341", "0036"), # Leonardo
|
|
("2341", "0037"), # Micro
|
|
# Adafruit Industries LLC
|
|
("239a", "000c"), # Feather 32U4
|
|
("239a", "000d"), # ItsyBitsy 32U4 3V3/8MHz
|
|
("239a", "000e"), # ItsyBitsy 32U4 5V/16MHz
|
|
# dog hunter AG
|
|
("2a03", "0036"), # Leonardo
|
|
("2a03", "0037") # Micro
|
|
},
|
|
'hid-bootloader': {
|
|
("03eb", "2067"), # QMK HID
|
|
("16c0", "0478") # PJRC halfkay
|
|
}
|
|
}
|
|
|
|
# Common format strings
|
|
DATE_FORMAT = '%Y-%m-%d'
|
|
DATETIME_FORMAT = '%Y-%m-%d %H:%M:%S %Z'
|
|
TIME_FORMAT = '%H:%M:%S'
|
|
|
|
# Used when generating matrix locations
|
|
COL_LETTERS = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijilmnopqrstuvwxyz'
|
|
ROW_LETTERS = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnop'
|
|
|
|
# Constants that should match their counterparts in make
|
|
BUILD_DIR = environ.get('BUILD_DIR', '.build')
|
|
INTERMEDIATE_OUTPUT_PREFIX = f'{BUILD_DIR}/obj_'
|
|
|
|
# Headers for generated files
|
|
GPL2_HEADER_C_LIKE = f'''\
|
|
// Copyright {date.today().year} QMK
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
'''
|
|
|
|
GPL2_HEADER_SH_LIKE = f'''\
|
|
# Copyright {date.today().year} QMK
|
|
# SPDX-License-Identifier: GPL-2.0-or-later
|
|
'''
|
|
|
|
GENERATED_HEADER_C_LIKE = '''\
|
|
/*******************************************************************************
|
|
88888888888 888 d8b .d888 d8b 888 d8b
|
|
888 888 Y8P d88P" Y8P 888 Y8P
|
|
888 888 888 888
|
|
888 88888b. 888 .d8888b 888888 888 888 .d88b. 888 .d8888b
|
|
888 888 "88b 888 88K 888 888 888 d8P Y8b 888 88K
|
|
888 888 888 888 "Y8888b. 888 888 888 88888888 888 "Y8888b.
|
|
888 888 888 888 X88 888 888 888 Y8b. 888 X88
|
|
888 888 888 888 88888P' 888 888 888 "Y8888 888 88888P'
|
|
888 888
|
|
888 888
|
|
888 888
|
|
.d88b. .d88b. 88888b. .d88b. 888d888 8888b. 888888 .d88b. .d88888
|
|
d88P"88b d8P Y8b 888 "88b d8P Y8b 888P" "88b 888 d8P Y8b d88" 888
|
|
888 888 88888888 888 888 88888888 888 .d888888 888 88888888 888 888
|
|
Y88b 888 Y8b. 888 888 Y8b. 888 888 888 Y88b. Y8b. Y88b 888
|
|
"Y88888 "Y8888 888 888 "Y8888 888 "Y888888 "Y888 "Y8888 "Y88888
|
|
888
|
|
Y8b d88P
|
|
"Y88P"
|
|
*******************************************************************************/
|
|
'''
|
|
|
|
GENERATED_HEADER_SH_LIKE = '''\
|
|
################################################################################
|
|
#
|
|
# 88888888888 888 d8b .d888 d8b 888 d8b
|
|
# 888 888 Y8P d88P" Y8P 888 Y8P
|
|
# 888 888 888 888
|
|
# 888 88888b. 888 .d8888b 888888 888 888 .d88b. 888 .d8888b
|
|
# 888 888 "88b 888 88K 888 888 888 d8P Y8b 888 88K
|
|
# 888 888 888 888 "Y8888b. 888 888 888 88888888 888 "Y8888b.
|
|
# 888 888 888 888 X88 888 888 888 Y8b. 888 X88
|
|
# 888 888 888 888 88888P' 888 888 888 "Y8888 888 88888P'
|
|
#
|
|
# 888 888
|
|
# 888 888
|
|
# 888 888
|
|
# .d88b. .d88b. 88888b. .d88b. 888d888 8888b. 888888 .d88b. .d88888
|
|
# d88P"88b d8P Y8b 888 "88b d8P Y8b 888P" "88b 888 d8P Y8b d88" 888
|
|
# 888 888 88888888 888 888 88888888 888 .d888888 888 88888888 888 888
|
|
# Y88b 888 Y8b. 888 888 Y8b. 888 888 888 Y88b. Y8b. Y88b 888
|
|
# "Y88888 "Y8888 888 888 "Y8888 888 "Y888888 "Y888 "Y8888 "Y88888
|
|
# 888
|
|
# Y8b d88P
|
|
# "Y88P"
|
|
#
|
|
################################################################################
|
|
'''
|
|
|
|
LICENSE_TEXTS = [
|
|
(
|
|
'GPL-2.0-or-later', [
|
|
"""\
|
|
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 the Free Software Foundation; either version 2
|
|
of the License, or (at your option) any later version.
|
|
""", """\
|
|
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 the Free Software Foundation; either version 2
|
|
of the License, or any later version.
|
|
"""
|
|
]
|
|
),
|
|
('GPL-2.0-only', ["""\
|
|
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 the Free Software Foundation; version 2.
|
|
"""]),
|
|
(
|
|
'GPL-3.0-or-later', [
|
|
"""\
|
|
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 the Free Software Foundation, either version 3 of
|
|
the License, or (at your option) any later version.
|
|
""", """\
|
|
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 the Free Software Foundation, either version 3 of
|
|
the License, or any later version.
|
|
"""
|
|
]
|
|
),
|
|
('GPL-3.0-only', ["""\
|
|
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 the Free Software Foundation, version 3.
|
|
"""]),
|
|
(
|
|
'LGPL-2.1-or-later', [
|
|
"""\
|
|
This program is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public License
|
|
as published by the Free Software Foundation; either version 2.1
|
|
of the License, or (at your option) any later version.
|
|
""", """\
|
|
This program is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public License
|
|
as published by the Free Software Foundation; either version 2.1
|
|
of the License, or any later version.
|
|
""", """\
|
|
This library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public License
|
|
as published by the Free Software Foundation; either version 2.1
|
|
of the License, or (at your option) any later version.
|
|
""", """\
|
|
This library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public License
|
|
as published by the Free Software Foundation; either version 2.1
|
|
of the License, or any later version.
|
|
"""
|
|
]
|
|
),
|
|
(
|
|
'LGPL-2.1-only', [
|
|
"""\
|
|
This program is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public License as
|
|
published by the Free Software Foundation; version 2.1.
|
|
""", """\
|
|
This library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public License as
|
|
published by the Free Software Foundation; version 2.1.
|
|
"""
|
|
]
|
|
),
|
|
(
|
|
'LGPL-3.0-or-later', [
|
|
"""\
|
|
This program is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public License
|
|
as published by the Free Software Foundation; either version 3
|
|
of the License, or (at your option) any later version.
|
|
""", """\
|
|
This program is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public License
|
|
as published by the Free Software Foundation; either version 3
|
|
of the License, or any later version.
|
|
""", """\
|
|
This library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public License
|
|
as published by the Free Software Foundation; either version 3
|
|
of the License, or (at your option) any later version.
|
|
""", """\
|
|
This library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public License
|
|
as published by the Free Software Foundation; either version 3
|
|
of the License, or any later version.
|
|
"""
|
|
]
|
|
),
|
|
(
|
|
'LGPL-3.0-only', [
|
|
"""\
|
|
This program is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public License as
|
|
published by the Free Software Foundation; version 3.
|
|
""", """\
|
|
This library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public License as
|
|
published by the Free Software Foundation; version 3.
|
|
"""
|
|
]
|
|
),
|
|
('Apache-2.0', ["""\
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
"""]),
|
|
]
|
|
|
|
JOYSTICK_AXES = ['x', 'y', 'z', 'rx', 'ry', 'rz']
|