X-Git-Url: https://git.ayoreis.com/Adafruit_Blinka-hackapet.git/blobdiff_plain/70b2c4be7ea920982168bb03fc55aa5b0563639c..a9c7f80c891445ac21fbc814fb64a2630ebc3dcd:/src/adafruit_blinka/microcontroller/amlogic/meson_g12_common/pin.py diff --git a/src/adafruit_blinka/microcontroller/amlogic/meson_g12_common/pin.py b/src/adafruit_blinka/microcontroller/amlogic/meson_g12_common/pin.py index d920b1f..fc4e588 100644 --- a/src/adafruit_blinka/microcontroller/amlogic/meson_g12_common/pin.py +++ b/src/adafruit_blinka/microcontroller/amlogic/meson_g12_common/pin.py @@ -1,4 +1,5 @@ # SPDX-FileCopyrightText: 2021 Melissa LeBlanc-Williams for Adafruit Industries +# SPDX-FileCopyrightText: 2023 Steve Jeong for Hardkernel # # SPDX-License-Identifier: MIT """ @@ -11,24 +12,45 @@ Linux kernel 5.4.y (mainline) linux/arch/arm64/boot/dts/amlogic/meson-g12-common.dtsi """ -import re -import gpiod +from adafruit_blinka.agnostic import detector +from adafruit_blinka.microcontroller.alias import get_dts_alias from adafruit_blinka.microcontroller.generic_linux.libgpiod_pin import Pin -chip0 = gpiod.Chip("0") -chip1 = gpiod.Chip("1") +try: + import gpiod +except ImportError: + raise ImportError( + "libgpiod Python bindings not found, please install and try again!" + ) from ImportError -if chip0.num_lines() < 20: +if hasattr(gpiod, "Chip"): + chip0 = gpiod.Chip("0") + chip1 = gpiod.Chip("1") +else: + chip0 = gpiod.chip("0") + chip1 = gpiod.chip("1") + +if callable(chip0.num_lines): + chip0lines = chip0.num_lines() +else: + chip0lines = chip0.num_lines + +if callable(chip1.num_lines): + chip1lines = chip1.num_lines() +else: + chip1lines = chip1.num_lines + +if chip0lines < 20: aobus = 0 periphs = 1 - periphs_offset = chip1.num_lines() - 85 + periphs_offset = chip1lines - 85 else: aobus = 1 periphs = 0 - periphs_offset = chip0.num_lines() - 85 + periphs_offset = chip0lines - 85 -chip0.close() -chip1.close() +del chip0 +del chip1 GPIOAO_0 = GPIO496 = Pin((aobus, 0)) GPIOAO_1 = GPIO497 = Pin((aobus, 1)) @@ -100,43 +122,42 @@ SPI0_MISO = GPIOX_9 SPI0_MOSI = GPIOX_8 SPI0_CS0 = GPIOX_10 -# ordered as spiId, sckId, mosiId, misoId -spiPorts = ((0, SPI0_SCLK, SPI0_MOSI, SPI0_MISO),) - UART1_TX = GPIOX_12 UART1_RX = GPIOX_13 -# ordered as uartId, txId, rxId -uartPorts = ((1, UART1_TX, UART1_RX),) - - -def get_dts_alias(device: str) -> str: - """Get the Device Tree Alias""" - uevent_path = "/sys/bus/platform/devices/" + device + "/uevent" - with open(uevent_path, "r", encoding="utf-8") as fd: - pattern = r"^OF_ALIAS_0=(.*)$" - uevent = fd.read().split("\n") - for line in uevent: - match = re.search(pattern, line) - if match: - return match.group(1).upper() - - return None - - # ordered as i2cId, sclId, sdaId i2cPorts = [] -alias = get_dts_alias("ffd1d000.i2c") -if alias is not None: - globals()[alias + "_SCL"] = GPIOX_18 - globals()[alias + "_SDA"] = GPIOX_17 - i2cPorts.append((int(alias[3]), GPIOX_18, GPIOX_17)) +# ordered as spiId, sckId, mosiId, misoId +spiPorts = ((0, SPI0_SCLK, SPI0_MOSI, SPI0_MISO),) -alias = get_dts_alias("ffd1c000.i2c") -if alias is not None: - globals()[alias + "_SCL"] = GPIOA_15 - globals()[alias + "_SDA"] = GPIOA_14 - i2cPorts.append((int(alias[3]), GPIOA_15, GPIOA_14)) +# ordered as uartId, txId, rxId +uartPorts = [ + (1, UART1_TX, UART1_RX), +] + +board = detector.board.id +if board in ("ODROID_C4", "ODROID_N2"): + alias = get_dts_alias("ffd1d000.i2c") + if alias is not None: + globals()[alias + "_SCL"] = GPIOX_18 + globals()[alias + "_SDA"] = GPIOX_17 + i2cPorts.append((int(alias[-1]), GPIOX_18, GPIOX_17)) + alias = get_dts_alias("ffd1c000.i2c") + if alias is not None: + globals()[alias + "_SCL"] = GPIOA_15 + globals()[alias + "_SDA"] = GPIOA_14 + i2cPorts.append((int(alias[-1]), GPIOA_15, GPIOA_14)) + alias = get_dts_alias("fdd24000.serial") + if alias is not None: + globals()[alias + "_TX"] = GPIOX_12 + globals()[alias + "_RX"] = GPIOX_13 + uartPorts.append((int(alias[-1]), GPIOX_12, GPIOX_13)) + alias = get_dts_alias("fdd23000.serial") + if alias is not None: + globals()[alias + "_TX"] = GPIOX_6 + globals()[alias + "_RX"] = GPIOX_7 + uartPorts.append((int(alias[-1]), GPIOX_6, GPIOX_7)) i2cPorts = tuple(i2cPorts) +uartPorts = tuple(uartPorts)