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:
parent
37b475815e
commit
bdd938b578
|
@ -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
|
||||||
|
|
|
@ -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.
|
||||||
|
|
|
@ -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]
|
||||||
|
|
|
@ -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)
|
||||||
|
|
Loading…
Reference in New Issue