From patchwork Fri May 22 00:43:07 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Alex Nemirovsky X-Patchwork-Id: 1295784 X-Patchwork-Delegate: trini@ti.com Return-Path: X-Original-To: incoming@patchwork.ozlabs.org Delivered-To: patchwork-incoming@bilbo.ozlabs.org Authentication-Results: ozlabs.org; spf=pass (sender SPF authorized) smtp.mailfrom=lists.denx.de (client-ip=2a01:238:438b:c500:173d:9f52:ddab:ee01; helo=phobos.denx.de; envelope-from=u-boot-bounces@lists.denx.de; receiver=) Authentication-Results: ozlabs.org; dmarc=none (p=none dis=none) header.from=cortina-access.com Authentication-Results: ozlabs.org; dkim=pass (1024-bit key; unprotected) header.d=CortinaAccess.onmicrosoft.com header.i=@CortinaAccess.onmicrosoft.com header.a=rsa-sha256 header.s=selector2-CortinaAccess-onmicrosoft-com header.b=lj3mIQj1; dkim-atps=neutral Received: from phobos.denx.de (phobos.denx.de [IPv6:2a01:238:438b:c500:173d:9f52:ddab:ee01]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits)) (No client certificate requested) by ozlabs.org (Postfix) with ESMTPS id 49SnmM0Y31z9sSc for ; Fri, 22 May 2020 10:43:47 +1000 (AEST) Received: from h2850616.stratoserver.net (localhost [IPv6:::1]) by phobos.denx.de (Postfix) with ESMTP id E964A81868; Fri, 22 May 2020 02:43:32 +0200 (CEST) Authentication-Results: phobos.denx.de; dmarc=none (p=none dis=none) header.from=cortina-access.com Authentication-Results: phobos.denx.de; spf=pass smtp.mailfrom=u-boot-bounces@lists.denx.de Authentication-Results: phobos.denx.de; dkim=pass (1024-bit key; unprotected) header.d=CortinaAccess.onmicrosoft.com header.i=@CortinaAccess.onmicrosoft.com header.b="lj3mIQj1"; dkim-atps=neutral Received: by phobos.denx.de (Postfix, from userid 109) id 8514C8176A; Fri, 22 May 2020 02:43:28 +0200 (CEST) X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on phobos.denx.de X-Spam-Level: X-Spam-Status: No, score=-0.9 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,FORGED_SPF_HELO,MSGID_FROM_MTA_HEADER,SPF_HELO_PASS, URIBL_BLOCKED autolearn=no autolearn_force=no version=3.4.2 Received: from APC01-PU1-obe.outbound.protection.outlook.com (mail-pu1apc01on061a.outbound.protection.outlook.com [IPv6:2a01:111:f400:febe::61a]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by phobos.denx.de (Postfix) with ESMTPS id D902681589 for ; Fri, 22 May 2020 02:43:22 +0200 (CEST) Authentication-Results: phobos.denx.de; dmarc=none (p=none dis=none) header.from=cortina-access.com Authentication-Results: phobos.denx.de; spf=pass smtp.mailfrom=Alex.Nemirovsky@cortina-access.com ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=RuZEJRM4h+Xj62clnrpjw+/kAzD/a4evfGlxtArTkbrMjZ5M5kAx9pietrkRfbS1PTZJrv/7Ersg1xfYz45Ehbl2NtaKpbKSEQulUj9IbBedUjcTMseBjbcAu3neebIYzvgm9H08fg9NSN0ncdDodMo5ts4NlE8MormFDJLTRTNOqUQs8QUV1TVIl+AEJdLuJhbPEAqOf2f3ONkSrtPYVY5H5z959k+reRN7oXGaO0S4mHUDBKefuwwz6NcfJKpLBQ4HwEWyig3WAU/56EmPYbnBPUJwrot8gdtEnCqurYoI3xPqlEL1W3DgE1XJ5fXCVGnlxVM6aBGgxvn+4WZJgg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=J+Hz7w06YCOFTYhyW4jRbvFJJZxn+MV8va4dLSxW3XY=; b=Ng7lSawm+sKdMo9yA2hR8DLL+5X3nKjdIIOL3xXHd1Q73gw0pZuG1E4bf897kx9EatA6gSBR5DLApZe1tZ8H3z3/wDfxvqKkQQrQpVJoMoQENXZczU9K61kUj8Lv+cs3P1UNaHq4ntsU8+OBKGiQiJNB5T6zlLMcIybh4p4+fuX/RXovkRmrurWVeT1OKtprvcmzu2o20ELX1iWFQLYUpWm0oqgNMRp0Uf369kbLLixtALO1//2JRiNp8rM7ZdXk4iwVY8hV5iN6MrBr502uNbc/9KYlvymrZA/h2/YKyg9qqrfpUGEsrDNnoL5ce5kUdwtSlIU9mfEOdd55UlpNXQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=cortina-access.com; dmarc=pass action=none header.from=cortina-access.com; dkim=pass header.d=cortina-access.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=CortinaAccess.onmicrosoft.com; s=selector2-CortinaAccess-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=J+Hz7w06YCOFTYhyW4jRbvFJJZxn+MV8va4dLSxW3XY=; b=lj3mIQj1vnv9YsmNIyowucm8xD9EJUpa3ceeBwHWOEcX5zS7srXQqDHUiI8EbhkxwJJGUXZSf/6tE3XeD4OQyTTlrL/AoYinWHXjNoIb+2dWD23jJCH32vA4o7aihSvWvvfs43Hi2x4dyP1U+oIxl2i48ELReHiTG8+OHeOVpSk= Authentication-Results: lists.denx.de; dkim=none (message not signed) header.d=none;lists.denx.de; dmarc=none action=none header.from=cortina-access.com; Received: from PU1PR01MB1964.apcprd01.prod.exchangelabs.com (2603:1096:803:1e::16) by PU1PR01MB1899.apcprd01.prod.exchangelabs.com (2603:1096:803:1c::11) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3021.23; Fri, 22 May 2020 00:43:18 +0000 Received: from PU1PR01MB1964.apcprd01.prod.exchangelabs.com ([fe80::3182:d1e7:f400:7c1d]) by PU1PR01MB1964.apcprd01.prod.exchangelabs.com ([fe80::3182:d1e7:f400:7c1d%3]) with mapi id 15.20.3021.020; Fri, 22 May 2020 00:43:18 +0000 From: Alex Nemirovsky To: u-boot@lists.denx.de Cc: Jway Lin , Alex Nemirovsky , Simon Glass Subject: [PATCH v8 1/2] led: led_cortina: Add CAxxx LED support Date: Thu, 21 May 2020 17:43:07 -0700 Message-Id: <1590108188-8115-1-git-send-email-alex.nemirovsky@cortina-access.com> X-Mailer: git-send-email 2.7.4 X-ClientProxiedBy: MWHPR1701CA0019.namprd17.prod.outlook.com (2603:10b6:301:14::29) To PU1PR01MB1964.apcprd01.prod.exchangelabs.com (2603:1096:803:1e::16) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from smok.hrh.localdomain (70.58.207.205) by MWHPR1701CA0019.namprd17.prod.outlook.com (2603:10b6:301:14::29) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256) id 15.20.3021.23 via Frontend Transport; Fri, 22 May 2020 00:43:17 +0000 X-Mailer: git-send-email 2.7.4 X-Originating-IP: [70.58.207.205] X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 4f532cca-be95-445e-5f41-08d7fde91ea8 X-MS-TrafficTypeDiagnostic: PU1PR01MB1899: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-LD-Processed: 0694623c-6669-497c-89c3-3a32a9934313,ExtAddr X-MS-Oob-TLC-OOBClassifiers: OLM:123; X-Forefront-PRVS: 04111BAC64 X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: wIJTkqxjjgsly7LE7SMQBLhujyW0Ez881vFpTFdotVsk1cmO7ZqEC4m8dD26Sw1LDc+a2ncm/cB3JfgNoOWu20DVGkfLk4Yx4K+ozEfACew69cDXoJY9GY1tNw8kpTYUUDw2Ea55gLhm/a4wLoH1VVQeGQ5OYZXdgCKh65JLfm67e1pRN5mwQGfVcccFpTGOkIYGE7MH/QROu/aTT6VGJZvprIa8pak21wbLSHCCwecD/yj4DvA1CoEIRvKYbGIvQcQtrAgv0VikaG0aUsRxerovkp25OgItYeIVDjgtFWqmCx4dEF03GwdhlukdON/pD/c+50maszbLYsOO0JU++VcsyD4P8AyOkiq6xQpO74rTQgliIvABNst32vTZLdejOsRs2Jua4wSy2SbidFajKA== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:PU1PR01MB1964.apcprd01.prod.exchangelabs.com; PTR:; CAT:NONE; SFTY:; SFS:(396003)(39850400004)(136003)(376002)(366004)(346002)(44832011)(66476007)(8676002)(186003)(956004)(26005)(6512007)(508600001)(2616005)(66946007)(52116002)(30864003)(6666004)(83080400001)(16526019)(66556008)(6916009)(6486002)(4326008)(36756003)(5660300002)(2906002)(54906003)(966005)(8936002)(6506007)(86362001)(316002); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData: VjFlGZMQrUya0Vm93kPpJlZAasqxNWyv93Z53/6leIEArnjk2oKNo8l60O2z1xpqpfJpet7utvV5J+8vO8uDlIT/vRrRSvl2wVtkvnzgEpG2zwgENED+90b0UlkAWluTB3kFUecv/5YRJMDwA8bMgJsRvFl3vexQVIvWLb/U4PjMsmUlKsxYUf0e6/Cx2Px94Jx4zCA6AD/qfXiFqZW8+y0AF3vBMu7QdIfK+d4CrkU2P8C8zhDqa+14Bvc+yHvuY1x1MjtnXTlQ7zkK8B/g0OR3+svAWvqRz3y6h8+r62Rmx1OC6F0ejCrmT4cM5Fg4W8vmawksTUcH06wVrwuFqgi01OF53zhKdLe0d5DYbhw2EM97lOHmhB4mhknnz30b1B2Vakzo2Y08u474zdZGI6wGvNHE9p6rpThEd9H1/LOUkib6nXvu2Gz5Y5r3J5t79T+N1L+olmUaly6ls0pPZ2uTW6zbfsH6dg90Iw9JHz4= X-OriginatorOrg: CORTINA-ACCESS.COM X-MS-Exchange-CrossTenant-Network-Message-Id: 4f532cca-be95-445e-5f41-08d7fde91ea8 X-MS-Exchange-CrossTenant-OriginalArrivalTime: 22 May 2020 00:43:18.4989 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 0694623c-6669-497c-89c3-3a32a9934313 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: OyaDw8pXYsDkDW36S6m+jyed3M3Hy/9fnLR9REszoSKuAt/Zs6K2E1hG4N0XHod0bCoGX1fyi6KHLaAgl/7zKaeNbw5STNugFwJRif62MZY9Imem2vjQOPnMVqkTOEF/ X-MS-Exchange-Transport-CrossTenantHeadersStamped: PU1PR01MB1899 X-BeenThere: u-boot@lists.denx.de X-Mailman-Version: 2.1.30rc1 Precedence: list List-Id: U-Boot discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: u-boot-bounces@lists.denx.de Sender: "U-Boot" X-Virus-Scanned: clamav-milter 0.102.2 at phobos.denx.de X-Virus-Status: Clean From: Jway Lin Add Cortina Access LED controller support for CAxxxx SOCs Signed-off-by: Jway Lin Signed-off-by: Alex Nemirovsky CC: Simon Glass Reviewed-by: Simon Glass --- Changes in v8: - No code change - Split out individual driver from Cortina Package 2 patch series to help streamline acceptence into master Changes in v7: - rename OFFSET to SHIFT from macros - add additinal struct comments - Reading the DT should really happen in the ofdata_to_platdata method Changes in v4: - remove unused macros - remove cortina prefix from macros - remove use BSS variable - further cleanup to meet code style guidelines - add additinal struct comments - rename DT blink rate symbol MAINTAINERS | 8 +- drivers/led/Kconfig | 8 ++ drivers/led/Makefile | 1 + drivers/led/led_cortina.c | 305 ++++++++++++++++++++++++++++++++++++++++++++++ 4 files changed, 321 insertions(+), 1 deletion(-) create mode 100644 drivers/led/led_cortina.c diff --git a/MAINTAINERS b/MAINTAINERS index 8add9d4..7a624bd 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -181,6 +181,9 @@ F: drivers/gpio/cortina_gpio.c F: drivers/watchdog/cortina_wdt.c F: drivers/serial/serial_cortina.c F: drivers/mmc/ca_dw_mmc.c +F: drivers/i2c/i2c-cortina.c +F: drivers/i2c/i2c-cortina.h +F: drivers/led/led_cortina.c ARM/CZ.NIC TURRIS MOX SUPPORT M: Marek Behun @@ -732,6 +735,9 @@ F: drivers/gpio/cortina_gpio.c F: drivers/watchdog/cortina_wdt.c F: drivers/serial/serial_cortina.c F: drivers/mmc/ca_dw_mmc.c +F: drivers/i2c/i2c-cortina.c +F: drivers/i2c/i2c-cortina.h +F: drivers/led/led_cortina.c MIPS MSCC M: Gregory CLEMENT @@ -824,7 +830,7 @@ S: Maintained F: arch/powerpc/ POWERPC MPC8XX -M: Christophe Leroy +M: Christophe Leroy S: Maintained T: git https://gitlab.denx.de/u-boot/custodians/u-boot-mpc8xx.git F: arch/powerpc/cpu/mpc8xx/ diff --git a/drivers/led/Kconfig b/drivers/led/Kconfig index 6675934..cc87fbf 100644 --- a/drivers/led/Kconfig +++ b/drivers/led/Kconfig @@ -35,6 +35,14 @@ config LED_BCM6858 This option enables support for LEDs connected to the BCM6858 HW has blinking capabilities and up to 32 LEDs can be controlled. +config LED_CORTINA + bool "LED Support for Cortina Access CAxxxx SoCs" + depends on LED && (CORTINA_PLATFORM) + help + This option enables support for LEDs connected to the Cortina + Access CAxxxx SOCs. + + config LED_BLINK bool "Support LED blinking" depends on LED diff --git a/drivers/led/Makefile b/drivers/led/Makefile index 3654dd3..8e3ae7f 100644 --- a/drivers/led/Makefile +++ b/drivers/led/Makefile @@ -8,3 +8,4 @@ obj-$(CONFIG_LED_BCM6328) += led_bcm6328.o obj-$(CONFIG_LED_BCM6358) += led_bcm6358.o obj-$(CONFIG_LED_BCM6858) += led_bcm6858.o obj-$(CONFIG_$(SPL_)LED_GPIO) += led_gpio.o +obj-$(CONFIG_LED_CORTINA) += led_cortina.o diff --git a/drivers/led/led_cortina.c b/drivers/led/led_cortina.c new file mode 100644 index 0000000..a6d9159 --- /dev/null +++ b/drivers/led/led_cortina.c @@ -0,0 +1,305 @@ +// SPDX-License-Identifier: GPL-2.0+ + +/* + * Copyright (C) 2020 Cortina-Access + * Author: Jway Lin + * + */ + +#include +#include +#include +#include +#include +#include + +#define LED_MAX_HW_BLINK 127 +#define LED_MAX_COUNT 16 + +/* LED_CONTROL fields */ +#define LED_BLINK_RATE1_SHIFT 0 +#define LED_BLINK_RATE1_MASK 0xff +#define LED_BLINK_RATE2_SHIFT 8 +#define LED_BLINK_RATE2_MASK 0xff +#define LED_CLK_TEST BIT(16) +#define LED_CLK_POLARITY BIT(17) +#define LED_CLK_TEST_MODE BIT(16) +#define LED_CLK_TEST_RX_TEST BIT(30) +#define LED_CLK_TEST_TX_TEST BIT(31) + +/* LED_CONFIG fields */ +#define LED_EVENT_ON_SHIFT 0 +#define LED_EVENT_ON_MASK 0x7 +#define LED_EVENT_BLINK_SHIFT 3 +#define LED_EVENT_BLINK_MASK 0x7 +#define LED_EVENT_OFF_SHIFT 6 +#define LED_EVENT_OFF_MASK 0x7 +#define LED_OFF_ON_SHIFT 9 +#define LED_OFF_ON_MASK 0x3 +#define LED_PORT_SHIFT 11 +#define LED_PORT_MASK 0x7 +#define LED_OFF_VAL BIT(14) +#define LED_SW_EVENT BIT(15) +#define LED_BLINK_SEL BIT(16) + +/* LED_CONFIG structures */ +struct cortina_led_cfg { + void __iomem *regs; + u32 pin; /* LED pin nubmer */ + bool active_low; /*Active-High or Active-Low*/ + u32 off_event; /* set led off event (RX,TX,SW)*/ + u32 blink_event; /* set led blink event (RX,TX,SW)*/ + u32 on_event; /* set led on event (RX,TX,SW)*/ + u32 port; /* corresponding ethernet port */ + int blink_sel; /* select blink-rate1 or blink-rate2 */ +}; + +/* LED_control structures */ +struct cortina_led_platdata { + void __iomem *ctrl_regs; + u16 rate1; /* blink rate setting 0 */ + u16 rate2; /* blink rate setting 1 */ +}; + +enum ca_led_state_t { + CA_EVENT_MODE = 0, + CA_LED_ON = 1, + CA_LED_OFF, +}; + +static void cortina_led_write(void __iomem *reg, unsigned long data) +{ + writel(data, reg); +} + +static unsigned long cortina_led_read(void __iomem *reg) +{ + return readl(reg); +} + +static enum led_state_t cortina_led_get_state(struct udevice *dev) +{ + struct cortina_led_cfg *priv = dev_get_priv(dev); + enum led_state_t state = LEDST_OFF; + u32 val; + + val = readl(priv->regs); + + if (val & LED_SW_EVENT) + state = LEDST_ON; + + return state; +} + +static int cortina_led_set_state(struct udevice *dev, enum led_state_t state) +{ + u32 val; + struct cortina_led_cfg *priv = dev_get_priv(dev); + + val = readl(priv->regs); + val &= ~(LED_OFF_ON_MASK << LED_OFF_ON_SHIFT); + + switch (state) { + case LEDST_OFF: + val &= ~LED_SW_EVENT; + val |= CA_LED_OFF << LED_OFF_ON_SHIFT; + cortina_led_write(priv->regs, val); + break; + case LEDST_ON: + val |= LED_SW_EVENT; + val |= CA_LED_ON << LED_OFF_ON_SHIFT; + cortina_led_write(priv->regs, val); + break; + case LEDST_TOGGLE: + if (cortina_led_get_state(dev) == LEDST_OFF) + return cortina_led_set_state(dev, LEDST_ON); + else + return cortina_led_set_state(dev, LEDST_OFF); + break; +#ifdef CONFIG_LED_BLINK + case LEDST_BLINK: + val &= ~LED_SW_EVENT; + val |= CA_LED_OFF << LED_OFF_ON_SHIFT; + val |= LED_EVENT_BLINK_MASK << LED_EVENT_BLINK_SHIFT; + cortina_led_write(priv->regs, val); + break; +#endif + + default: + return -EINVAL; + } + + return 0; +} + +static const struct led_ops cortina_led_ops = { + .get_state = cortina_led_get_state, + .set_state = cortina_led_set_state, +}; + +static int ca_led_ofdata_to_platdata(struct udevice *dev) +{ + struct led_uc_plat *uc_plat = dev_get_uclass_platdata(dev); + + /* Top-level LED node */ + if (!uc_plat->label) { + struct cortina_led_platdata *plt = dev_get_platdata(dev); + + plt->rate1 = + dev_read_u32_default(dev, "Cortina,blink-rate1", 256); + plt->rate2 = + dev_read_u32_default(dev, "Cortina,blink-rate2", 512); + plt->ctrl_regs = dev_remap_addr(dev); + } else { + struct cortina_led_cfg *priv = dev_get_priv(dev); + + priv->regs = dev_remap_addr(dev_get_parent(dev)); + priv->pin = dev_read_u32_default(dev, "pin", LED_MAX_COUNT); + priv->blink_sel = dev_read_u32_default(dev, "blink-sel", 0); + priv->off_event = dev_read_u32_default(dev, "off-event", 0); + priv->blink_event = dev_read_u32_default(dev, "blink-event", 0); + priv->on_event = dev_read_u32_default(dev, "on-event", 0); + priv->port = dev_read_u32_default(dev, "port", 0); + + if (dev_read_bool(dev, "active-low")) + priv->active_low = true; + else + priv->active_low = false; + } + + return 0; +} + +static int cortina_led_probe(struct udevice *dev) +{ + struct led_uc_plat *uc_plat = dev_get_uclass_platdata(dev); + + /* Top-level LED node */ + if (!uc_plat->label) { + struct cortina_led_platdata *platdata = dev_get_platdata(dev); + u32 reg_value, val; + u16 rate1, rate2; + + if (!platdata->ctrl_regs) + return -EINVAL; + + reg_value = 0; + reg_value |= LED_CLK_POLARITY; + + rate1 = platdata->rate1; + rate2 = platdata->rate2; + + val = rate1 / 16 - 1; + rate1 = val > LED_MAX_HW_BLINK ? + LED_MAX_HW_BLINK : val; + reg_value |= (rate1 & LED_BLINK_RATE1_MASK) << + LED_BLINK_RATE1_SHIFT; + + val = rate2 / 16 - 1; + rate2 = val > LED_MAX_HW_BLINK ? + LED_MAX_HW_BLINK : val; + reg_value |= (rate2 & LED_BLINK_RATE2_MASK) << + LED_BLINK_RATE2_SHIFT; + + cortina_led_write(platdata->ctrl_regs, reg_value); + + } else { + struct cortina_led_cfg *priv = dev_get_priv(dev); + void __iomem *regs; + u32 val, port, off_event, blink_event, on_event; + + regs = priv->regs; + if (!regs) + return -EINVAL; + + if (priv->pin >= LED_MAX_COUNT) + return -EINVAL; + + priv->regs = regs + 4 + priv->pin * 4; + + val = cortina_led_read(priv->regs); + + if (priv->active_low) + val |= LED_OFF_VAL; + else + val &= ~LED_OFF_VAL; + + if (priv->blink_sel == 0) + val &= ~LED_BLINK_SEL; + else if (priv->blink_sel == 1) + val |= LED_BLINK_SEL; + + off_event = priv->off_event; + val &= ~(LED_EVENT_OFF_MASK << LED_EVENT_OFF_SHIFT); + if (off_event != 0) + val |= BIT(off_event) << LED_EVENT_OFF_SHIFT; + + blink_event = priv->blink_event; + val &= ~(LED_EVENT_BLINK_MASK << LED_EVENT_BLINK_SHIFT); + if (blink_event != 0) + val |= BIT(blink_event) << LED_EVENT_BLINK_SHIFT; + + on_event = priv->on_event; + val &= ~(LED_EVENT_ON_MASK << LED_EVENT_ON_SHIFT); + if (on_event != 0) + val |= BIT(on_event) << LED_EVENT_ON_SHIFT; + + port = priv->port; + val &= ~(LED_PORT_MASK << LED_PORT_SHIFT); + val |= port << LED_PORT_SHIFT; + + /* force off */ + val &= ~(LED_OFF_ON_MASK << LED_OFF_ON_SHIFT); + val |= CA_LED_OFF << LED_OFF_ON_SHIFT; + + cortina_led_write(priv->regs, val); + } + + return 0; +} + +static int cortina_led_bind(struct udevice *parent) +{ + ofnode node; + + dev_for_each_subnode(node, parent) { + struct led_uc_plat *uc_plat; + struct udevice *dev; + const char *label; + int ret; + + label = ofnode_read_string(node, "label"); + if (!label) { + debug("%s: node %s has no label\n", __func__, + ofnode_get_name(node)); + return -EINVAL; + } + + ret = device_bind_driver_to_node(parent, "ca-leds", + ofnode_get_name(node), + node, &dev); + if (ret) + return ret; + uc_plat = dev_get_uclass_platdata(dev); + uc_plat->label = label; + } + + return 0; +} + +static const struct udevice_id ca_led_ids[] = { + { .compatible = "cortina,ca-leds" }, + { /* sentinel */ } +}; + +U_BOOT_DRIVER(cortina_led) = { + .name = "ca-leds", + .id = UCLASS_LED, + .of_match = ca_led_ids, + .ofdata_to_platdata = ca_led_ofdata_to_platdata, + .bind = cortina_led_bind, + .probe = cortina_led_probe, + .platdata_auto_alloc_size = sizeof(struct cortina_led_platdata), + .priv_auto_alloc_size = sizeof(struct cortina_led_cfg), + .ops = &cortina_led_ops, +}; From patchwork Fri May 22 00:43:08 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Alex Nemirovsky X-Patchwork-Id: 1295783 X-Patchwork-Delegate: trini@ti.com Return-Path: X-Original-To: incoming@patchwork.ozlabs.org Delivered-To: patchwork-incoming@bilbo.ozlabs.org Authentication-Results: ozlabs.org; spf=pass (sender SPF authorized) smtp.mailfrom=lists.denx.de (client-ip=85.214.62.61; helo=phobos.denx.de; envelope-from=u-boot-bounces@lists.denx.de; receiver=) Authentication-Results: ozlabs.org; dmarc=none (p=none dis=none) header.from=cortina-access.com Authentication-Results: ozlabs.org; dkim=pass (1024-bit key; unprotected) header.d=CortinaAccess.onmicrosoft.com header.i=@CortinaAccess.onmicrosoft.com header.a=rsa-sha256 header.s=selector2-CortinaAccess-onmicrosoft-com header.b=aul/PUn/; dkim-atps=neutral Received: from phobos.denx.de (phobos.denx.de [85.214.62.61]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits)) (No client certificate requested) by ozlabs.org (Postfix) with ESMTPS id 49Snm94Zqfz9sSc for ; Fri, 22 May 2020 10:43:37 +1000 (AEST) Received: from h2850616.stratoserver.net (localhost [IPv6:::1]) by phobos.denx.de (Postfix) with ESMTP id 92CDA81748; Fri, 22 May 2020 02:43:30 +0200 (CEST) Authentication-Results: phobos.denx.de; dmarc=none (p=none dis=none) header.from=cortina-access.com Authentication-Results: phobos.denx.de; spf=pass smtp.mailfrom=u-boot-bounces@lists.denx.de Authentication-Results: phobos.denx.de; dkim=pass (1024-bit key; unprotected) header.d=CortinaAccess.onmicrosoft.com header.i=@CortinaAccess.onmicrosoft.com header.b="aul/PUn/"; dkim-atps=neutral Received: by phobos.denx.de (Postfix, from userid 109) id 9F3DD8179A; Fri, 22 May 2020 02:43:27 +0200 (CEST) X-Spam-Checker-Version: SpamAssassin 3.4.2 (2018-09-13) on phobos.denx.de X-Spam-Level: X-Spam-Status: No, score=-0.9 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,FORGED_SPF_HELO,MSGID_FROM_MTA_HEADER,SPF_HELO_PASS, URIBL_BLOCKED autolearn=no autolearn_force=no version=3.4.2 Received: from APC01-PU1-obe.outbound.protection.outlook.com (mail-pu1apc01on061a.outbound.protection.outlook.com [IPv6:2a01:111:f400:febe::61a]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by phobos.denx.de (Postfix) with ESMTPS id E7D0B81748 for ; Fri, 22 May 2020 02:43:23 +0200 (CEST) Authentication-Results: phobos.denx.de; dmarc=none (p=none dis=none) header.from=cortina-access.com Authentication-Results: phobos.denx.de; spf=pass smtp.mailfrom=Alex.Nemirovsky@cortina-access.com ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=G7R0k1CtBL8+cTm3dkvz2OypcuAPDpWG8X/9WpJeZ6Li+amy792SwRi9hra0mhtdEbDMgQvlB+tfBkHBEDG314+fOIvILV65Qll6RRbCaJZOHa0/MEX4/bxqwbOaM9Dws0XkEQiUZofq3biWrNZUd9O99TAJbVjdqVADua3xVDrlZfQgEiXuDN6rXu33W1pRmi9H3oYTgB7gDYQJsbRUldHFPJ8e6qWwejBZ7eFBj1f6lTgELkmUz0hNNAUjjEpT6xTE/NXsZKVRgPEZy015uF/0T2rEAdCfALN1Dd1xb/MfzUJx/Gf41JGLdI8Jm6L213EXtf9SE3EA/2chyvVM9Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=sCcweD7zudWk4g8UNEhq+bS0domzF0mxkealaOAZP9E=; b=g/Ah6GImgsDynZBHVL/n6pmWa6aLwDj1eK8L0xQ507LDJy6eVACb4DhRZcKZKpIgLJe8THMQI3/APMwvi3sUJs1huUGy3JxLjkjGJGwpYG5VANa4x0hzo2Ygtzl8R1YoLCJEE/HBL1KsIiDmyV7eKRoQeoe2BtELgnXNvsPu90w6mYAD2ILNUvzN8U0+SfIhdH+pvk+Y4db1IMlvPXVk+BTS6r8BPHPhjA8T9ykoUigpo92tSMUJrFsNKLAR78KtHb+ZrKtd2M5lqOIrRWggVvyrF46WP/2SvZIkGGKFbEtICNSMCKa0GNPWRxO2PFsjKzr3ZvgIIjJhfFtby/N+qA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=cortina-access.com; dmarc=pass action=none header.from=cortina-access.com; dkim=pass header.d=cortina-access.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=CortinaAccess.onmicrosoft.com; s=selector2-CortinaAccess-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=sCcweD7zudWk4g8UNEhq+bS0domzF0mxkealaOAZP9E=; b=aul/PUn/OawrZrU6QiAiJftAGGJME9rZEUrIuMOXVYJsiAtbz0aiRCrKB1fajHwNrzjPM4scwucaFuAV+jlrCXVLtMaYREDmTunPtaEOoY0amWDjXUIbPKylcbyDglV9QOrWWo0HGKgojLTvjdlXfX9IyiMCvnumpJgX6L8ASM8= Authentication-Results: lists.denx.de; dkim=none (message not signed) header.d=none;lists.denx.de; dmarc=none action=none header.from=cortina-access.com; Received: from PU1PR01MB1964.apcprd01.prod.exchangelabs.com (2603:1096:803:1e::16) by PU1PR01MB1899.apcprd01.prod.exchangelabs.com (2603:1096:803:1c::11) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.3021.23; Fri, 22 May 2020 00:43:21 +0000 Received: from PU1PR01MB1964.apcprd01.prod.exchangelabs.com ([fe80::3182:d1e7:f400:7c1d]) by PU1PR01MB1964.apcprd01.prod.exchangelabs.com ([fe80::3182:d1e7:f400:7c1d%3]) with mapi id 15.20.3021.020; Fri, 22 May 2020 00:43:21 +0000 From: Alex Nemirovsky To: u-boot@lists.denx.de Cc: Jway Lin , Alex Nemirovsky , Simon Glass Subject: [PATCH v8 2/2] board: presidio: add LED support Date: Thu, 21 May 2020 17:43:08 -0700 Message-Id: <1590108188-8115-2-git-send-email-alex.nemirovsky@cortina-access.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1590108188-8115-1-git-send-email-alex.nemirovsky@cortina-access.com> References: <1590108188-8115-1-git-send-email-alex.nemirovsky@cortina-access.com> X-ClientProxiedBy: MWHPR1701CA0019.namprd17.prod.outlook.com (2603:10b6:301:14::29) To PU1PR01MB1964.apcprd01.prod.exchangelabs.com (2603:1096:803:1e::16) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 Received: from smok.hrh.localdomain (70.58.207.205) by MWHPR1701CA0019.namprd17.prod.outlook.com (2603:10b6:301:14::29) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256) id 15.20.3021.23 via Frontend Transport; Fri, 22 May 2020 00:43:18 +0000 X-Mailer: git-send-email 2.7.4 X-Originating-IP: [70.58.207.205] X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 3f05052a-9514-4cc5-97c0-08d7fde9200e X-MS-TrafficTypeDiagnostic: PU1PR01MB1899: X-MS-Exchange-Transport-Forked: True X-Microsoft-Antispam-PRVS: X-LD-Processed: 0694623c-6669-497c-89c3-3a32a9934313,ExtAddr X-MS-Oob-TLC-OOBClassifiers: OLM:1284; X-Forefront-PRVS: 04111BAC64 X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: AsLhs0xOOiOmgPjkHDg5uqQRDZYdhBFLIGsNWpuDnTjN3seLZHOlgo6zw47seK7mlk9EE5nBeMTpAyhvadN+J/xP0C39rQS629buG8GSTAahMeOjQYCZCuHKJ84i+Bpvi5QtoA+BNRujVzGlTyRK3bDajRMoQa8R+aqdGjACLM5cnhKJYYamVbcYyzHoKjBEdd3N0YRsA8ZvKwyGQzhs4QKrae4ZircHumHZ9nKs6ji70rhnQwoBSz6jToxiowPtRvsgcvm1y69SklxkEAdtAuHrq5PjDrr0rZxWz3jMeisd2NVwQ1jYt0tmgxUT/DUxiICnJGKxN9gAW8uW9MgFoQ== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:PU1PR01MB1964.apcprd01.prod.exchangelabs.com; PTR:; CAT:NONE; SFTY:; SFS:(396003)(39850400004)(136003)(376002)(366004)(346002)(44832011)(66476007)(8676002)(186003)(956004)(26005)(6512007)(508600001)(2616005)(66946007)(52116002)(6666004)(16526019)(66556008)(6916009)(6486002)(4326008)(36756003)(5660300002)(2906002)(54906003)(8936002)(6506007)(86362001)(316002); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData: fmfmUHhPwiheQUZG8bySlC9FhnF+KFHTNlOSX5xWoLScBNV4B71OXb70OHVTZUmU25xLU8RTvSz4hJHl17rz+gVnmHMZXQ5qz0GCgHxp4JjWowNaFi4DMpunn1lxdxxnBcRa3tx/67X1aCF8W0kEyuPBsdc3xzzTK15Yoeaq9ivEHP3uk99dIA2sPsouIphN/gyzKG2sNRK9rKLV50Oke99QF+s3UwUmQg67/6AB3WKTZ93c1K1mrJMY/326fuYqid2xY53kIeTNboBhf+eWLAH0L6Hr4MSaAvyLolXMT7m0w47laLU9SOYdbv/0FRmy3y8CIqvUbOApwTHM0T9bs8BDPpjH7yqNmY7pgIsx1s4qa9TrR/w24bcRpxp+GSMYn91Wg1r6W3J8ju0XzqtHin7znyXAAY/2PmbnxJTg2gAlFBp5K8sVkAI5p87JN3PylpgbDe8MCl8r7fqsKA+mxDg3cqErPotsodAxN5sgkqQ= X-OriginatorOrg: CORTINA-ACCESS.COM X-MS-Exchange-CrossTenant-Network-Message-Id: 3f05052a-9514-4cc5-97c0-08d7fde9200e X-MS-Exchange-CrossTenant-OriginalArrivalTime: 22 May 2020 00:43:20.9175 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 0694623c-6669-497c-89c3-3a32a9934313 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: GvxFU4yyElEVS7P1Tk8GZRXjzUQKmUJB6rsVt/WLhSawXxdai36xU8sqUWwAR8a1l0avlghxr6+yxyp2qtKjgTOPs1jZtkl4tXfRTGmUlLXD5dM333QjZoygb7wzCz+4 X-MS-Exchange-Transport-CrossTenantHeadersStamped: PU1PR01MB1899 X-BeenThere: u-boot@lists.denx.de X-Mailman-Version: 2.1.30rc1 Precedence: list List-Id: U-Boot discussion List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: u-boot-bounces@lists.denx.de Sender: "U-Boot" X-Virus-Scanned: clamav-milter 0.102.2 at phobos.denx.de X-Virus-Status: Clean From: Jway Lin Add LED support for Cortina Access Presidio Engineering Board Signed-off-by: Jway Lin Signed-off-by: Alex Nemirovsky Reviewed-by: Simon Glass CC: Simon Glass --- Changes in v8: None Changes in v7: None Changes in v4: - rename DT blink rate symbol arch/arm/dts/ca-presidio-engboard.dts | 31 +++++++++++++++++++++++++++++++ 1 file changed, 31 insertions(+) diff --git a/arch/arm/dts/ca-presidio-engboard.dts b/arch/arm/dts/ca-presidio-engboard.dts index c03dacc..2075539 100644 --- a/arch/arm/dts/ca-presidio-engboard.dts +++ b/arch/arm/dts/ca-presidio-engboard.dts @@ -66,4 +66,35 @@ spi-max-frequency = <108000000>; }; }; + + leds: led-controller@f43200f0 { + compatible = "cortina,ca-leds"; + reg = <0x0 0xf43200f0 0x40>; + + cortina,blink-rate1 = <256>; + cortina,blink-rate2 = <512>; + + led@0 { + pin = <0>; + active-low; + blink-sel =<0>; + port = <0>; + off-event = <0>; + label = "led0"; + }; + + led@1 { + pin = <1>; + active-low; + blink-sel =<1>; + label = "led1"; + }; + + led@2 { + pin = <2>; + active-low; + label = "led2"; + }; + + }; };