board_pins: Use an explicit parameter to specify mcu name(s)

Add an 'mcu' option to the board_pins config and use that to specify
the name of the mcu to apply the aliases to.  Support applying the
aliases to multiple mcus.

Add support for any number of options starting with an "aliases_"
prefix.

Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
Kevin O'Connor 2020-11-20 11:36:36 -05:00
parent 37b475815e
commit bdd938b578
4 changed files with 43 additions and 25 deletions

View File

@ -124,7 +124,8 @@ aliases:
SERVO_0=P9_14, SERVO_1=P9_16, SERVO_0=P9_14, SERVO_1=P9_16,
[board_pins host] [board_pins host]
aliases: mcu: host
aliases_foo:
# Host aliases for Linux MCU # Host aliases for Linux MCU
HOST_X2_STOP=gpio30, HOST_Y2_STOP=gpio113, HOST_Z2_STOP=gpio4 HOST_X2_STOP=gpio30, HOST_Y2_STOP=gpio113, HOST_Z2_STOP=gpio4
# Thermistors # Thermistors

View File

@ -6,6 +6,12 @@ All dates in this document are approximate.
# Changes # Changes
20201120: The `[board_pins]` config section now specifies the mcu name
in an explicit `mcu:` parameter. If using board_pins for a secondary
mcu, then the config must be updated to specify that name. See the
[config reference](Config_Reference.md#[board_pins]) for further
details.
20201112: The time reported by `print_stats.print_duration` has 20201112: The time reported by `print_stats.print_duration` has
changed. The duration prior to the first detected extrusion is changed. The duration prior to the first detected extrusion is
now excluded. now excluded.

View File

@ -1396,19 +1396,23 @@ software dependencies must be installed; refer to
## [board_pins] ## [board_pins]
Board pin aliases. One may define aliases for the pins on a Board pin aliases (one may define any number of sections with a
micro-controller. (If a micro-controller name is omitted in the "board_pins" prefix). Use this to define aliases for the pins on a
board_pins config section name then it defaults to "mcu".) micro-controller.
``` ```
[board_pins mcu] [board_pins my_aliases]
mcu: mcu
# A comma separated list of micro-controllers that may use the
# aliases. The default is to apply the aliases to the main "mcu".
aliases: aliases:
aliases_<name>:
# A comma separated list of "name=value" aliases to create for the # A comma separated list of "name=value" aliases to create for the
# given micro-controller. For example, "EXP1_1=PE6" would create an # given micro-controller. For example, "EXP1_1=PE6" would create an
# "EXP1_1" alias for the "PE6" pin. However, if "value" is enclosed # "EXP1_1" alias for the "PE6" pin. However, if "value" is enclosed
# in "<>" then "name" is created as a reserved pin (for example, # in "<>" then "name" is created as a reserved pin (for example,
# "EXP1_9=<GND>" would reserve "EXP1_9"). This parameter must be # "EXP1_9=<GND>" would reserve "EXP1_9"). Any number of options
# provided. # starting with "aliases_" may be specified.
``` ```
## [include] ## [include]

View File

@ -1,29 +1,36 @@
# Support for custom board pin aliases # Support for custom board pin aliases
# #
# Copyright (C) 2019 Kevin O'Connor <kevin@koconnor.net> # Copyright (C) 2019-2020 Kevin O'Connor <kevin@koconnor.net>
# #
# This file may be distributed under the terms of the GNU GPLv3 license. # This file may be distributed under the terms of the GNU GPLv3 license.
class PrinterBoardAliases: class PrinterBoardAliases:
def __init__(self, config, chip_name): def __init__(self, config):
ppins = config.get_printer().lookup_object('pins') ppins = config.get_printer().lookup_object('pins')
pin_resolver = ppins.get_pin_resolver(chip_name) mcu_names = [n.strip() for n in config.get('mcu', 'mcu').split(',')]
aliases = config.get("aliases").strip() pin_resolvers = [ppins.get_pin_resolver(n) for n in mcu_names]
if aliases.endswith(','): options = ["aliases"] + config.get_prefix_options("aliases_")
aliases = aliases[:-1] for opt in options:
parts = [a.split('=', 1) for a in aliases.split(',')] aliases = config.get(opt, "").strip()
for pair in parts: if not aliases:
if len(pair) != 2: continue
raise ppins.error("Unable to parse aliases in %s" if aliases.endswith(','):
% (config.get_name(),)) aliases = aliases[:-1]
name, value = [s.strip() for s in pair] parts = [a.split('=', 1) for a in aliases.split(',')]
if value.startswith('<') and value.endswith('>'): for pair in parts:
pin_resolver.reserve_pin(name, value) if len(pair) != 2:
else: raise ppins.error("Unable to parse aliases in %s"
pin_resolver.alias_pin(name, value) % (config.get_name(),))
name, value = [s.strip() for s in pair]
if value.startswith('<') and value.endswith('>'):
for pin_resolver in pin_resolvers:
pin_resolver.reserve_pin(name, value)
else:
for pin_resolver in pin_resolvers:
pin_resolver.alias_pin(name, value)
def load_config(config): def load_config(config):
return PrinterBoardAliases(config, "mcu") return PrinterBoardAliases(config)
def load_config_prefix(config): def load_config_prefix(config):
return PrinterBoardAliases(config, config.get_name().split()[1]) return PrinterBoardAliases(config)