From patchwork Sat Oct 20 13:38:21 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Paul Walmsley X-Patchwork-Id: 987196 Return-Path: X-Original-To: incoming-dt@patchwork.ozlabs.org Delivered-To: patchwork-incoming-dt@bilbo.ozlabs.org Authentication-Results: ozlabs.org; spf=none (mailfrom) smtp.mailfrom=vger.kernel.org (client-ip=209.132.180.67; helo=vger.kernel.org; envelope-from=devicetree-owner@vger.kernel.org; receiver=) Authentication-Results: ozlabs.org; dmarc=none (p=none dis=none) header.from=sifive.com Authentication-Results: ozlabs.org; dkim=pass (2048-bit key; unprotected) header.d=sifive.com header.i=@sifive.com header.b="ggF7jUHb"; dkim-atps=neutral Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by ozlabs.org (Postfix) with ESMTP id 42ckQ90dcvz9sCm for ; Sun, 21 Oct 2018 00:38:41 +1100 (AEDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727404AbeJTVtJ (ORCPT ); Sat, 20 Oct 2018 17:49:09 -0400 Received: from mail-wr1-f68.google.com ([209.85.221.68]:46194 "EHLO mail-wr1-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727341AbeJTVtJ (ORCPT ); Sat, 20 Oct 2018 17:49:09 -0400 Received: by mail-wr1-f68.google.com with SMTP id i4-v6so1457688wrr.13 for ; Sat, 20 Oct 2018 06:38:38 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=sifive.com; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=RK1db71p1doYFuCGfEE1NLdP4LEETqtV01w8eRQfie0=; b=ggF7jUHbQPMBuzgjjE1ZSJ9H0neYUI42BFHKGWNXK7GgHTtct8R+T39RVP0cx41h3M L360cSFJLESd44XCP+s89e523uYEmm77QVO8RhAis+eMLTT11YlI3CBmLBkJyyWhOyl9 jwF6OzRb9puvAQfqBA3ji19Pb5jBj5kmQs5urLofh92esCujfvmu9tlgbhZmP+DDVyxw 2sB34Jx8KzJz5KsS9V7py3MmgFZMgCHcvyyPbLNfm8RGL2qqUgWXQOWDjqMByVmidS0K QcBx3k2OICAk3BGTb9Oh7woQxI7Hj5jya4WBxdlCK+fFkZt16DC24RfXHONj+KHg21N7 i6nw== 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=RK1db71p1doYFuCGfEE1NLdP4LEETqtV01w8eRQfie0=; b=OVKFuynJ9HsUyxzMW74MnGwLMPqinPyabO7yaIR7rfx9/t83POkOji+Hhr0bADqeoK CV9A8SDcl6d4MSUEJ61C0gz1aKf0wyKGvhcfzHtu/gTOcP/Op1YKlYGutK1txor9xOMr XCIvCoNBmpuQdG6chOF+C0oj0rJrxI8c/TMgkJpqwITw7oImjBa24FATTJMJmR7OTEYb QpUogrNmlqRfcb1kdyJkAuPjJS5Bi4K6XjoxGGKdp28Yli4Ol4FhK5e01GhqEG7QBv6F 6w66uy4GZ5AtYSljfdlb9mI1G7ZyCQSjzZvzEnWpZEmW3WFQYXgbUE2CXHtF9PeEQXIT DUjA== X-Gm-Message-State: AGRZ1gJR0mr+lu7E73+QThH0yc0i0KuNtDEPHBVoCu/dTSCioayC1pna wop4T0Ips8OclITPv4iqM0+S6Q== X-Google-Smtp-Source: AJdET5fai4n4Ip1a0hHB33795iEBz3hBXBP3ecQ6x/4i9IveVrF6RZUuoWlbXtxm2O0tkc3e8pKlyw== X-Received: by 2002:adf:dd8d:: with SMTP id x13-v6mr8459254wrl.237.1540042717701; Sat, 20 Oct 2018 06:38:37 -0700 (PDT) Received: from viisi.sifive.com ([37.152.39.96]) by smtp.gmail.com with ESMTPSA id f1-v6sm5227207wme.23.2018.10.20.06.38.36 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Sat, 20 Oct 2018 06:38:36 -0700 (PDT) From: Paul Walmsley To: linux-clk@vger.kernel.org, devicetree@vger.kernel.org Cc: Paul Walmsley , Michael Turquette , Stephen Boyd , Albert Ou , "Wesley W . Terpstra" , Palmer Dabbelt , Megan Wachs , Rob Herring , Mark Rutland , linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH 0/3] clk: add driver for the SiFive FU540 PRCI and PLLs it controls Date: Sat, 20 Oct 2018 06:38:21 -0700 Message-Id: <20181020133823.27103-1-paul.walmsley@sifive.com> X-Mailer: git-send-email 2.19.1 MIME-Version: 1.0 Sender: devicetree-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org Add a driver for the SiFive FU540 PRCI IP block, which handles clock and some device reset control for the SiFive FU540 chip. Also add a driver- independent library for the Analog Bits Wide-Range PLL (WRPLL), used by the PRCI driver to monitor and control the WRPLL instances on the FU540 chip. It's been a long time since I've worked on Linux clock code, so Mike & Stephen, I'd appreciate a close look at the PRCI driver to make sure what it's doing makes sense. Boot-tested on a SiFive HiFive Unleashed board. COREPLL rate changes and notification were also tested on the same board. This patch series is also available at: https://github.com/sifive/riscv-linux/tree/dev/paulw/prci-v4.19-rc7 Paul Walmsley (3): clk: analogbits: add Wide-Range PLL library dt-bindings: clk: add documentation for the SiFive PRCI driver clk: sifive: add a driver for the SiFive FU540 PRCI IP block .../bindings/clock/sifive/fu540-prci.txt | 40 ++ MAINTAINERS | 6 + drivers/clk/Kconfig | 2 + drivers/clk/Makefile | 2 + drivers/clk/analogbits/Kconfig | 3 + drivers/clk/analogbits/Makefile | 2 + drivers/clk/analogbits/wrpll-cln28hpc.c | 387 +++++++++++ drivers/clk/sifive/Kconfig | 18 + drivers/clk/sifive/Makefile | 1 + drivers/clk/sifive/fu540-prci.c | 634 ++++++++++++++++++ include/linux/clk/analogbits-wrpll-cln28hpc.h | 99 +++ include/linux/clk/sifive-fu540-prci.h | 27 + 12 files changed, 1221 insertions(+) create mode 100644 Documentation/devicetree/bindings/clock/sifive/fu540-prci.txt create mode 100644 drivers/clk/analogbits/Kconfig create mode 100644 drivers/clk/analogbits/Makefile create mode 100644 drivers/clk/analogbits/wrpll-cln28hpc.c create mode 100644 drivers/clk/sifive/Kconfig create mode 100644 drivers/clk/sifive/Makefile create mode 100644 drivers/clk/sifive/fu540-prci.c create mode 100644 include/linux/clk/analogbits-wrpll-cln28hpc.h create mode 100644 include/linux/clk/sifive-fu540-prci.h Cc: Michael Turquette Cc: Stephen Boyd Cc: Albert Ou Cc: Wesley W. Terpstra Cc: Palmer Dabbelt Cc: Megan Wachs Cc: Rob Herring Cc: Mark Rutland Cc: devicetree@vger.kernel.org Cc: linux-riscv@lists.infradead.org Cc: linux-kernel@vger.kernel.org Cc: linux-clk@vger.kernel.org