Received: by 2002:a25:23cc:0:0:0:0:0 with SMTP id j195csp237239ybj; Mon, 4 May 2020 20:15:40 -0700 (PDT) X-Google-Smtp-Source: APiQypLBTQl0f7HjeO0l6tGAG6FheuFEQRpWLlNoKaOH7Mwio5jc58QPT9YpQmGmifhE0sx/9Mo+ X-Received: by 2002:aa7:cd01:: with SMTP id b1mr875004edw.163.1588648539874; Mon, 04 May 2020 20:15:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588648539; cv=none; d=google.com; s=arc-20160816; b=sQY9j13FlKAj+cLTchHiHPA4mWUUZ5IaLSNGoXwbozqy9+tXmbWnnkOw/8S/dtXmFR uUlNjULGAegdnMnvuUO0AThIXMeJRV+/ITp7Tl3CM5uLP5LcBZxCin48wPEbmkoM/8q1 Y5ulgMRmK0hmZpiYqVQOubnMoZt79b37Oiqd34Td8ZAMz6dsxSUl9rs8A4D1aq4u2WQL eZVyVy9o3gRC37/2IfYzY6rNlYrcQ+R/v3HItf4uIHvVawIWh0/iD04vqRG8dsjuPncA tz3qmJzuCje1qTVmxHdkQ6Fu5QQrI8pnM9t8g/Tsl1WKW38UJ7Gq8kVjM/Rp1/0Lef0/ nLag== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=GYizcWQEdFFMME7plWgxGUqZtB5T/alBirdJJTamDl0=; b=ZDF9VoY9fxICMgJT3mpnMzun49dWyH1ta8fJxR0VkjESQNA/qkC3ibpeNmCUCH5TT4 gjxDFiGLnXchwfOMOn0I3Jq4iv04EOmfMSOJIlWoEaQFbKlZ10yqE7T2ruQgqUk0h+Ck TKdRmjVC0YKLXSJJTMpq2vqk/IKzHcMKL7uHuhOvRvr9r/YovIFL4Zhv+JTkYx7R750K jI3g13uluiDm5rRaj+3wzMi4fKjD0+5qBfgMhlaSsOSdb93ZWgJNpkMR60wFFlgqXv1t bw9YluPWa2Prv5dOAJf5Y/txuGz172ARWUnMcgSsy8EMM6h34pqpBATXAU0Y+gUuu25c K7bQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=Opgztqxb; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id t30si483002edt.410.2020.05.04.20.15.16; Mon, 04 May 2020 20:15:39 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=Opgztqxb; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727932AbgEEDNr (ORCPT + 99 others); Mon, 4 May 2020 23:13:47 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:58580 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-FAIL-OK-FAIL) by vger.kernel.org with ESMTP id S1727820AbgEEDNq (ORCPT ); Mon, 4 May 2020 23:13:46 -0400 Received: from mail-pg1-x541.google.com (mail-pg1-x541.google.com [IPv6:2607:f8b0:4864:20::541]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A76F0C061A10 for ; Mon, 4 May 2020 20:13:46 -0700 (PDT) Received: by mail-pg1-x541.google.com with SMTP id o18so393951pgg.8 for ; Mon, 04 May 2020 20:13:46 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=GYizcWQEdFFMME7plWgxGUqZtB5T/alBirdJJTamDl0=; b=OpgztqxbjjIWT0S0o1w7IFpGpHzmzY39WXydiZMi6ldwkil3Y4q4qejU5vjDm3/nUe fEbipUBhO56RPrSNWfIWQCFHFBpbKJLw1sKyAEBOzfq4LHO5St/jUkn5GRAaJv8IaDNi edyX5q2ArkjAFFHnUrW3ROVTOSpJ39tUMixto= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=GYizcWQEdFFMME7plWgxGUqZtB5T/alBirdJJTamDl0=; b=pOrUX5U8akDnouPumKUJNrnshikUOkm4aeObvxgAFbe6ekr9ByEpXvbbcwmJ+266If WTtW25/YJUKTPTQktpRLTfEBlqZ0+zPsb12iXO91ACXlk7I/a865IFmG7b6agjrPb679 C2xN8cVdMqA1dCcB81lK7qMzXyHQYlSHv102zLg5lI2CAGWfV3GsVhwhTCJLkSgM4xnK Im0BfytH5heaRn5wNT4+BcVSWW1iQuzul/MRzkqq2Dy2Zbf8DTPSFBPNve7iFCV27Edb f9zwmxo3rtaed/OnLlpj1mQbWuBUeS+YWThM5NfDmy8F7a1NtD8tN8pjditncsWGJpql 82Ew== X-Gm-Message-State: AGi0PuZqC2UFVDqoh8KSrqpcqeW0YOASXbqsz0Agcc3uSpk8pS+ALbsc uOXuRnyJx/eLQ+XpJTad8NvzQoTmZ4g= X-Received: by 2002:a62:e803:: with SMTP id c3mr1104548pfi.228.1588648425913; Mon, 04 May 2020 20:13:45 -0700 (PDT) Received: from localhost ([2401:fa00:9:14:1105:3e8a:838d:e326]) by smtp.gmail.com with ESMTPSA id a12sm398974pgv.14.2020.05.04.20.13.38 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 04 May 2020 20:13:45 -0700 (PDT) From: Evan Benn To: LKML Cc: jwerner@chromium.org, xingyu.chen@amlogic.com, Evan Benn , Anson Huang , Bjorn Andersson , Catalin Marinas , "David S. Miller" , Geert Uytterhoeven , Greg Kroah-Hartman , Guenter Roeck , Leonard Crestez , Li Yang , Marcin Juszkiewicz , Matthias Brugger , Mauro Carvalho Chehab , Olof Johansson , Rob Herring , Rob Herring , Shawn Guo , Will Deacon , Wim Van Sebroeck , devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, linux-watchdog@vger.kernel.org Subject: [PATCH v6 0/2] Add a watchdog driver that uses ARM Secure Monitor Calls. Date: Tue, 5 May 2020 13:13:29 +1000 Message-Id: <20200505031331.122781-1-evanbenn@chromium.org> X-Mailer: git-send-email 2.26.2.526.g744177e7f7-goog MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This is currently supported in firmware deployed on oak, hana and elm mt8173 chromebook devices. The kernel driver is written to be a generic SMC watchdog driver. Arm Trusted Firmware upstreaming review: https://review.trustedfirmware.org/c/TF-A/trusted-firmware-a/+/3405 Patch to add oak, hana, elm device tree: https://lore.kernel.org/linux-arm-kernel/20200110073730.213789-1-hsinyi@chromium.org/ I would like to add the device tree support after the above patch is accepted. Changes in v6: - Don't use dt default - Use default arm,smc-id value if non provided by dt Changes in v5: - Change compatible to arm,smc-wdt - Make timeleft return 0 on error - Use type punning on smc_func_id to save an alloc - Change compatible to arm,smc-wdt Changes in v4: - Add arm,smc-id property - Get smc-id from of property - Return a1 instead of a0 in timeleft Changes in v3: - Change name back to arm - Add optional get_timeleft op - change name to arm_smc_wdt Changes in v2: - Change name arm > mt8173 - use watchdog_stop_on_reboot - use watchdog_stop_on_unregister - use devm_watchdog_register_device - remove smcwd_shutdown, smcwd_remove - change error codes Evan Benn (1): dt-bindings: watchdog: Add ARM smc wdt for mt8173 watchdog Julius Werner (1): watchdog: Add new arm_smc_wdt watchdog driver .../bindings/watchdog/arm-smc-wdt.yaml | 37 ++++ MAINTAINERS | 7 + arch/arm64/configs/defconfig | 1 + drivers/watchdog/Kconfig | 13 ++ drivers/watchdog/Makefile | 1 + drivers/watchdog/arm_smc_wdt.c | 188 ++++++++++++++++++ 6 files changed, 247 insertions(+) create mode 100644 Documentation/devicetree/bindings/watchdog/arm-smc-wdt.yaml create mode 100644 drivers/watchdog/arm_smc_wdt.c -- 2.26.2.526.g744177e7f7-goog