diff options
author | Stephen Warren <swarren@nvidia.com> | 2014-03-06 13:06:31 -0700 |
---|---|---|
committer | Stephen Warren <swarren@nvidia.com> | 2014-04-22 16:18:35 -0600 |
commit | 2577ab08c5a84229580c83a0cd00a03328eba89b (patch) | |
tree | ad04beb34ad4e3f65564316b6a9d8ac585298095 /board-to-kernel-dt.py | |
parent | 16495973b3f18b575ed20773c788be642ffceb63 (diff) | |
download | tegra-pinmux-scripts-2577ab08c5a84229580c83a0cd00a03328eba89b.tar.gz |
Initial set of scripts
A set of scripts to generate Linux kernel and U-Boot pinmux drivers and
board pinmux configuration tables. Also included are scripts to convert
existing Linux kernel pinmux drivers and NV-internal spreadsheets to the
internal data representation.
SoC configuration files are included for Tegra30, Tegra114, and Tegra124.
Board configuration files are included for Jetson TK1 and Venice2.
configs/tegra30.soc
configs/tegra114.soc
configs/tegra124.soc
SoC pin definitions
configs/jetson-tk1.board
configs/venice2.board
Board configurations
soc-to-kernel-pinctrl-driver.py
soc-to-uboot-driver.py
Generate Linux kernel and U-Boot pinmux drivers
board-to-kernel-dt.py
board-to-uboot.py
Generate board configuration tables for the Linux kernel (DT) and
U-Boot.
kernel-pinctrl-driver-to-soc.py
Convert an existing Linux kernel pinmux driver to the internal
representation of an SoC used by this project.
csv-to-board-tegra124-xlsx.py
Convert an NV-internal board configuration spreadsheet to the
internal representation of a board configuration used by this
project.
tegra_pmx_board_parser.py
tegra_pmx_parser_utils.py
tegra_pmx_soc_parser.py
tegra_pmx_utils.py
Internal Python modules used to parse the internal data
representations, and various other utilities.
Signed-off-by: Stephen Warren <swarren@nvidia.com>
Diffstat (limited to 'board-to-kernel-dt.py')
-rwxr-xr-x | board-to-kernel-dt.py | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/board-to-kernel-dt.py b/board-to-kernel-dt.py new file mode 100755 index 0000000..966fee2 --- /dev/null +++ b/board-to-kernel-dt.py @@ -0,0 +1,65 @@ +#!/usr/bin/python3 + +# Copyright (c) 2014, NVIDIA CORPORATION. All rights reserved. +# +# Permission is hereby granted, free of charge, to any person obtaining a +# copy of this software and associated documentation files (the "Software"), +# to deal in the Software without restriction, including without limitation +# the rights to use, copy, modify, merge, publish, distribute, sublicense, +# and/or sell copies of the Software, and to permit persons to whom the +# Software is furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in +# all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL +# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER +# DEALINGS IN THE SOFTWARE. + +import argparse +import os.path +import tegra_pmx_board_parser +from tegra_pmx_utils import * + +dbg = False + +parser = argparse.ArgumentParser(description='Create a kernel device tree ' + + 'pinmux fragment from a board config file') +parser.add_argument('--debug', action='store_true', help='Turn on debugging prints') +parser.add_argument('board', help='Board to process') +args = parser.parse_args() +if args.debug: + dbg = True +if dbg: print(args) + +board = tegra_pmx_board_parser.load_board(args.board) + +def mapper_pull(val): + return 'TEGRA_PIN_PULL_' + val.upper() + +def mapper_bool(val): + return 'TEGRA_PIN_' + {False: 'DISABLE', True: 'ENABLE'}[val] + +print(' state_default: pinmux {') + +for pincfg in board.pincfgs_by_num(): + print(' ' + pincfg.fullname + ' {') + print(' nvidia,pins = "' + pincfg.fullname + '";') + if pincfg.mux: + print(' nvidia,function = "' + pincfg.mux + '";') + print(' nvidia,pull = <' + mapper_pull(pincfg.pull) + '>;') + print(' nvidia,tristate = <' + mapper_bool(pincfg.tri) + '>;') + print(' nvidia,enable-input = <' + mapper_bool(pincfg.e_inp) + '>;') + if pincfg.gpio_pin.od: + print(' nvidia,open-drain = <' + mapper_bool(pincfg.od) + '>;') + if pincfg.gpio_pin.rcv_sel: + print(' nvidia,rcv-sel = <' + mapper_bool(pincfg.rcv_sel) + '>;') + print(' };') + +# FIXME: Handle drive groups + +print(' };') |