From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-4.1 required=3.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,INCLUDES_PATCH,MAILING_LIST_MULTI,SPF_HELO_NONE, SPF_PASS autolearn=no autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 0D6EAC00523 for ; Mon, 6 Jan 2020 03:09:08 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id C27A1217F4 for ; Mon, 6 Jan 2020 03:09:07 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1578280147; bh=vxNW2GyhdGoGRiMtNDnrgoP06OCkjtgTm1EGwq+PnAg=; h=In-Reply-To:References:Cc:To:Subject:From:Date:List-ID:From; b=iqdymlnxELbm/OmN40TUhTjXac2UtL6lrzKxcTpL+e6lbcHoifjF5WYiuDg8VDxMy WIUfjt68CvQJualRlp1R+ZIiph8uEP/3b097/uyvaWP6ge4X/p3HqehWBPyqx5LPBz GDY1UNv1YEiNVsdkT1QosDmwRjVrHyu2qYTJBtCY= Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727334AbgAFDJH (ORCPT ); Sun, 5 Jan 2020 22:09:07 -0500 Received: from mail.kernel.org ([198.145.29.99]:33344 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727307AbgAFDJH (ORCPT ); Sun, 5 Jan 2020 22:09:07 -0500 Received: from kernel.org (unknown [104.132.0.74]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 8643221582; Mon, 6 Jan 2020 03:09:05 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1578280145; bh=vxNW2GyhdGoGRiMtNDnrgoP06OCkjtgTm1EGwq+PnAg=; h=In-Reply-To:References:Cc:To:Subject:From:Date:From; b=dS7d1yUleZjq1UFYvj0xQTgJV2/bxxSAHOKWKxc+tpZYzZvWxPSMQ/pqqE/VJy6LL VOhb+ayiihHrhvbTa/rfVVdk9x4E4FL9F7gQANJ1hKVtgUCYro5gWVxBY8/Dmrp40n 8FEP3QhRMLZ981sJy4Cde6/Fp1U4nP3qVvCKA+ak= Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable In-Reply-To: <20191229202907.335931-1-alexandre.belloni@bootlin.com> References: <20191229202907.335931-1-alexandre.belloni@bootlin.com> Cc: Nicolas Ferre , Michael Turquette , linux-clk@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Alexandre Belloni To: Alexandre Belloni Subject: Re: [PATCH] clk: at91: add sama5d3 pmc driver From: Stephen Boyd User-Agent: alot/0.8.1 Date: Sun, 05 Jan 2020 19:09:04 -0800 Message-Id: <20200106030905.8643221582@mail.kernel.org> Sender: linux-clk-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-clk@vger.kernel.org Quoting Alexandre Belloni (2019-12-29 12:29:07) > diff --git a/drivers/clk/at91/sama5d3.c b/drivers/clk/at91/sama5d3.c > new file mode 100644 > index 000000000000..0b73c174ab56 > --- /dev/null > +++ b/drivers/clk/at91/sama5d3.c > @@ -0,0 +1,236 @@ > +// SPDX-License-Identifier: GPL-2.0 > +#include > +#include > +#include > + > +#include > + > +#include "pmc.h" > + > +static const struct clk_master_characteristics mck_characteristics =3D { > + .output =3D { .min =3D 0, .max =3D 166000000 }, > + .divisors =3D { 1, 2, 4, 3 }, > +}; > + > +static u8 plla_out[] =3D { 0 }; > + > +static u16 plla_icpll[] =3D { 0 }; > + > +static const struct clk_range plla_outputs[] =3D { > + { .min =3D 400000000, .max =3D 1000000000 }, > +}; > + > +static const struct clk_pll_characteristics plla_characteristics =3D { > + .input =3D { .min =3D 8000000, .max =3D 50000000 }, > + .num_output =3D ARRAY_SIZE(plla_outputs), > + .output =3D plla_outputs, > + .icpll =3D plla_icpll, > + .out =3D plla_out, > +}; > + > +static const struct clk_pcr_layout sama5d3_pcr_layout =3D { > + .offset =3D 0x10c, > + .cmd =3D BIT(12), > + .pid_mask =3D GENMASK(6, 0), > + .div_mask =3D GENMASK(17, 16), > +}; > + > +static const struct { > + char *n; > + char *p; > + u8 id; > +} sama5d3_systemck[] =3D { > + { .n =3D "ddrck", .p =3D "masterck", .id =3D 2 }, > + { .n =3D "lcdck", .p =3D "masterck", .id =3D 3 }, > + { .n =3D "smdck", .p =3D "smdclk", .id =3D 4 }, > + { .n =3D "uhpck", .p =3D "usbck", .id =3D 6 }, > + { .n =3D "udpck", .p =3D "usbck", .id =3D 7 }, > + { .n =3D "pck0", .p =3D "prog0", .id =3D 8 }, > + { .n =3D "pck1", .p =3D "prog1", .id =3D 9 }, > + { .n =3D "pck2", .p =3D "prog2", .id =3D 10 }, > +}; > + > +static const struct { > + char *n; > + u8 id; > + struct clk_range r; > +} sama5d3_periphck[] =3D { If it can't be a platform device can this be __initconst? > + { .n =3D "dbgu_clk", .id =3D 2, }, > + { .n =3D "hsmc_clk", .id =3D 5, }, > + { .n =3D "pioA_clk", .id =3D 6, }, > + { .n =3D "pioB_clk", .id =3D 7, }, > + { .n =3D "pioC_clk", .id =3D 8, }, > + { .n =3D "pioD_clk", .id =3D 9, }, > + { .n =3D "pioE_clk", .id =3D 10, }, > + { .n =3D "usart0_clk", .id =3D 12, .r =3D { .min =3D 0, .max =3D = 66000000 }, }, > + { .n =3D "usart1_clk", .id =3D 13, .r =3D { .min =3D 0, .max =3D = 66000000 }, }, > + { .n =3D "usart2_clk", .id =3D 14, .r =3D { .min =3D 0, .max =3D = 66000000 }, }, > + { .n =3D "usart3_clk", .id =3D 15, .r =3D { .min =3D 0, .max =3D = 66000000 }, }, > + { .n =3D "uart0_clk", .id =3D 16, .r =3D { .min =3D 0, .max =3D 6= 6000000 }, }, > + { .n =3D "uart1_clk", .id =3D 17, .r =3D { .min =3D 0, .max =3D 6= 6000000 }, }, > + { .n =3D "twi0_clk", .id =3D 18, .r =3D { .min =3D 0, .max =3D 16= 625000 }, }, > + { .n =3D "twi1_clk", .id =3D 19, .r =3D { .min =3D 0, .max =3D 16= 625000 }, }, > + { .n =3D "twi2_clk", .id =3D 20, .r =3D { .min =3D 0, .max =3D 16= 625000 }, }, > + { .n =3D "mci0_clk", .id =3D 21, }, > + { .n =3D "mci1_clk", .id =3D 22, }, > + { .n =3D "mci2_clk", .id =3D 23, }, > + { .n =3D "spi0_clk", .id =3D 24, .r =3D { .min =3D 0, .max =3D 13= 3000000 }, }, > + { .n =3D "spi1_clk", .id =3D 25, .r =3D { .min =3D 0, .max =3D 13= 3000000 }, }, > + { .n =3D "tcb0_clk", .id =3D 26, .r =3D { .min =3D 0, .max =3D 13= 3000000 }, }, > + { .n =3D "tcb1_clk", .id =3D 27, }, > + { .n =3D "pwm_clk", .id =3D 28, }, > + { .n =3D "adc_clk", .id =3D 29, .r =3D { .min =3D 0, .max =3D 660= 00000 }, }, > + { .n =3D "dma0_clk", .id =3D 30, }, > + { .n =3D "dma1_clk", .id =3D 31, }, > + { .n =3D "uhphs_clk", .id =3D 32, }, > + { .n =3D "udphs_clk", .id =3D 33, }, > + { .n =3D "macb0_clk", .id =3D 34, }, > + { .n =3D "macb1_clk", .id =3D 35, }, > + { .n =3D "lcdc_clk", .id =3D 36, }, > + { .n =3D "isi_clk", .id =3D 37, }, > + { .n =3D "ssc0_clk", .id =3D 38, .r =3D { .min =3D 0, .max =3D 66= 000000 }, }, > + { .n =3D "ssc1_clk", .id =3D 39, .r =3D { .min =3D 0, .max =3D 66= 000000 }, }, > + { .n =3D "can0_clk", .id =3D 40, .r =3D { .min =3D 0, .max =3D 66= 000000 }, }, > + { .n =3D "can1_clk", .id =3D 41, .r =3D { .min =3D 0, .max =3D 66= 000000 }, }, > + { .n =3D "sha_clk", .id =3D 42, }, > + { .n =3D "aes_clk", .id =3D 43, }, > + { .n =3D "tdes_clk", .id =3D 44, }, > + { .n =3D "trng_clk", .id =3D 45, }, > + { .n =3D "fuse_clk", .id =3D 48, }, > + { .n =3D "mpddr_clk", .id =3D 49, }, > +}; > + > +static void __init sama5d3_pmc_setup(struct device_node *np) > +{ > + const char *slck_name, *mainxtal_name; > + struct pmc_data *sama5d3_pmc; > + const char *parent_names[5]; > + struct regmap *regmap; > + struct clk_hw *hw; > + int i; > + bool bypass; > + > + i =3D of_property_match_string(np, "clock-names", "slow_clk"); > + if (i < 0) > + return; > + > + slck_name =3D of_clk_get_parent_name(np, i); > + > + i =3D of_property_match_string(np, "clock-names", "main_xtal"); > + if (i < 0) > + return; > + mainxtal_name =3D of_clk_get_parent_name(np, i); > + > + regmap =3D syscon_node_to_regmap(np); > + if (IS_ERR(regmap)) > + return; > + > + sama5d3_pmc =3D pmc_data_allocate(PMC_MAIN + 1, > + nck(sama5d3_systemck), > + nck(sama5d3_periphck), 0); > + if (!sama5d3_pmc) > + return; > + > + hw =3D at91_clk_register_main_rc_osc(regmap, "main_rc_osc", 12000= 000, > + 50000000); > + if (IS_ERR(hw)) > + goto err_free; > + > + bypass =3D of_property_read_bool(np, "atmel,osc-bypass"); > + > + hw =3D at91_clk_register_main_osc(regmap, "main_osc", mainxtal_na= me, > + bypass); > + if (IS_ERR(hw)) > + goto err_free; > + > + parent_names[0] =3D "main_rc_osc"; > + parent_names[1] =3D "main_osc"; > + hw =3D at91_clk_register_sam9x5_main(regmap, "mainck", parent_nam= es, 2); > + if (IS_ERR(hw)) > + goto err_free; > + > + hw =3D at91_clk_register_pll(regmap, "pllack", "mainck", 0, > + &sama5d3_pll_layout, &plla_characteris= tics); > + if (IS_ERR(hw)) > + goto err_free; > + > + hw =3D at91_clk_register_plldiv(regmap, "plladivck", "pllack"); > + if (IS_ERR(hw)) > + goto err_free; > + > + hw =3D at91_clk_register_utmi(regmap, NULL, "utmick", "mainck"); > + if (IS_ERR(hw)) > + goto err_free; > + > + sama5d3_pmc->chws[PMC_UTMI] =3D hw; > + > + parent_names[0] =3D slck_name; > + parent_names[1] =3D "mainck"; > + parent_names[2] =3D "plladivck"; > + parent_names[3] =3D "utmick"; > + hw =3D at91_clk_register_master(regmap, "masterck", 4, parent_nam= es, > + &at91sam9x5_master_layout, > + &mck_characteristics); > + if (IS_ERR(hw)) > + goto err_free; > + > + sama5d3_pmc->chws[PMC_MCK] =3D hw; > + > + parent_names[0] =3D "plladivck"; > + parent_names[1] =3D "utmick"; > + hw =3D at91sam9x5_clk_register_usb(regmap, "usbck", parent_names,= 2); > + if (IS_ERR(hw)) > + goto err_free; > + > + hw =3D at91sam9x5_clk_register_smd(regmap, "smdclk", parent_names= , 2); > + if (IS_ERR(hw)) > + goto err_free; > + > + parent_names[0] =3D slck_name; > + parent_names[1] =3D "mainck"; > + parent_names[2] =3D "plladivck"; > + parent_names[3] =3D "utmick"; > + parent_names[4] =3D "masterck"; > + for (i =3D 0; i < 3; i++) { > + char name[6]; > + > + snprintf(name, sizeof(name), "prog%d", i); > + > + hw =3D at91_clk_register_programmable(regmap, name, > + parent_names, 5, i, > + &at91sam9x5_programma= ble_layout); > + if (IS_ERR(hw)) > + goto err_free; > + } > + > + for (i =3D 0; i < ARRAY_SIZE(sama5d3_systemck); i++) { > + hw =3D at91_clk_register_system(regmap, sama5d3_systemck[= i].n, > + sama5d3_systemck[i].p, > + sama5d3_systemck[i].id); > + if (IS_ERR(hw)) > + goto err_free; > + > + sama5d3_pmc->shws[sama5d3_systemck[i].id] =3D hw; > + } > + > + for (i =3D 0; i < ARRAY_SIZE(sama5d3_periphck); i++) { > + hw =3D at91_clk_register_sam9x5_peripheral(regmap, &pmc_p= cr_lock, > + &sama5d3_pcr_lay= out, > + sama5d3_periphck= [i].n, > + "masterck", > + sama5d3_periphck= [i].id, > + &sama5d3_periphc= k[i].r); > + if (IS_ERR(hw)) > + goto err_free; > + > + sama5d3_pmc->phws[sama5d3_periphck[i].id] =3D hw; > + } > + > + of_clk_add_hw_provider(np, of_clk_hw_pmc_get, sama5d3_pmc); > + > + return; > + > +err_free: > + pmc_data_free(sama5d3_pmc); > +} > +CLK_OF_DECLARE_DRIVER(sama5d3_pmc, "atmel,sama5d3-pmc", sama5d3_pmc_setu= p); Any reason this can't be a platform driver? From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-4.0 required=3.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,INCLUDES_PATCH,MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS autolearn=no autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 8B976C33C99 for ; Mon, 6 Jan 2020 03:09:09 +0000 (UTC) Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 5B8AC21734 for ; Mon, 6 Jan 2020 03:09:09 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=lists.infradead.org header.i=@lists.infradead.org header.b="HmlkAEYo"; dkim=fail reason="signature verification failed" (1024-bit key) header.d=kernel.org header.i=@kernel.org header.b="dS7d1yUl" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 5B8AC21734 Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=kernel.org Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-arm-kernel-bounces+infradead-linux-arm-kernel=archiver.kernel.org@lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20170209; h=Sender: Content-Transfer-Encoding:Content-Type:Cc:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:Message-Id:Date:From:Subject:To: References:In-Reply-To:MIME-Version:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=EUcgm51w03pCJlRAxvVTzHZJOqNKxGfYgSrwzW/ubP8=; b=HmlkAEYo7j3khj deTuPySPXxShab2pHYIg2oRjE0HvphhW9pS67p2gFUvcg9TyRZT16fOGLr2pwV5c6M2d6RILUV7+c 4n11sfsGT37LcP6HmwnO4eU+lRs/NfpXfhklcUiw7Ky2D+nFT2dPTAzgTMkR1HCiRJqLLJMcZtYyA SCwvk9NOA6V1PfU2yazNar8tW7YmQyHm4g4YXVP9PvfnjV9PVp7Sqwb45deInD1OtkkeAdNlkHa/6 85SmdiTTMpI1tKsdGPa0IkCrwIkL5XjpNc7ColrPPoisjwbQtyYNu6IDoZavanQ21hx43LtPi1Lim IBdbPwyE0xdKw7cgrFig==; Received: from localhost ([127.0.0.1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.92.3 #3 (Red Hat Linux)) id 1ioIlQ-00089l-Rj; Mon, 06 Jan 2020 03:09:08 +0000 Received: from mail.kernel.org ([198.145.29.99]) by bombadil.infradead.org with esmtps (Exim 4.92.3 #3 (Red Hat Linux)) id 1ioIlN-00089K-Vy for linux-arm-kernel@lists.infradead.org; Mon, 06 Jan 2020 03:09:07 +0000 Received: from kernel.org (unknown [104.132.0.74]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 8643221582; Mon, 6 Jan 2020 03:09:05 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1578280145; bh=vxNW2GyhdGoGRiMtNDnrgoP06OCkjtgTm1EGwq+PnAg=; h=In-Reply-To:References:Cc:To:Subject:From:Date:From; b=dS7d1yUleZjq1UFYvj0xQTgJV2/bxxSAHOKWKxc+tpZYzZvWxPSMQ/pqqE/VJy6LL VOhb+ayiihHrhvbTa/rfVVdk9x4E4FL9F7gQANJ1hKVtgUCYro5gWVxBY8/Dmrp40n 8FEP3QhRMLZ981sJy4Cde6/Fp1U4nP3qVvCKA+ak= MIME-Version: 1.0 In-Reply-To: <20191229202907.335931-1-alexandre.belloni@bootlin.com> References: <20191229202907.335931-1-alexandre.belloni@bootlin.com> To: Alexandre Belloni Subject: Re: [PATCH] clk: at91: add sama5d3 pmc driver From: Stephen Boyd User-Agent: alot/0.8.1 Date: Sun, 05 Jan 2020 19:09:04 -0800 Message-Id: <20200106030905.8643221582@mail.kernel.org> X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20200105_190906_072174_55C6F83A X-CRM114-Status: GOOD ( 11.58 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: Alexandre Belloni , Michael Turquette , linux-kernel@vger.kernel.org, linux-clk@vger.kernel.org, linux-arm-kernel@lists.infradead.org Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+infradead-linux-arm-kernel=archiver.kernel.org@lists.infradead.org Quoting Alexandre Belloni (2019-12-29 12:29:07) > diff --git a/drivers/clk/at91/sama5d3.c b/drivers/clk/at91/sama5d3.c > new file mode 100644 > index 000000000000..0b73c174ab56 > --- /dev/null > +++ b/drivers/clk/at91/sama5d3.c > @@ -0,0 +1,236 @@ > +// SPDX-License-Identifier: GPL-2.0 > +#include > +#include > +#include > + > +#include > + > +#include "pmc.h" > + > +static const struct clk_master_characteristics mck_characteristics = { > + .output = { .min = 0, .max = 166000000 }, > + .divisors = { 1, 2, 4, 3 }, > +}; > + > +static u8 plla_out[] = { 0 }; > + > +static u16 plla_icpll[] = { 0 }; > + > +static const struct clk_range plla_outputs[] = { > + { .min = 400000000, .max = 1000000000 }, > +}; > + > +static const struct clk_pll_characteristics plla_characteristics = { > + .input = { .min = 8000000, .max = 50000000 }, > + .num_output = ARRAY_SIZE(plla_outputs), > + .output = plla_outputs, > + .icpll = plla_icpll, > + .out = plla_out, > +}; > + > +static const struct clk_pcr_layout sama5d3_pcr_layout = { > + .offset = 0x10c, > + .cmd = BIT(12), > + .pid_mask = GENMASK(6, 0), > + .div_mask = GENMASK(17, 16), > +}; > + > +static const struct { > + char *n; > + char *p; > + u8 id; > +} sama5d3_systemck[] = { > + { .n = "ddrck", .p = "masterck", .id = 2 }, > + { .n = "lcdck", .p = "masterck", .id = 3 }, > + { .n = "smdck", .p = "smdclk", .id = 4 }, > + { .n = "uhpck", .p = "usbck", .id = 6 }, > + { .n = "udpck", .p = "usbck", .id = 7 }, > + { .n = "pck0", .p = "prog0", .id = 8 }, > + { .n = "pck1", .p = "prog1", .id = 9 }, > + { .n = "pck2", .p = "prog2", .id = 10 }, > +}; > + > +static const struct { > + char *n; > + u8 id; > + struct clk_range r; > +} sama5d3_periphck[] = { If it can't be a platform device can this be __initconst? > + { .n = "dbgu_clk", .id = 2, }, > + { .n = "hsmc_clk", .id = 5, }, > + { .n = "pioA_clk", .id = 6, }, > + { .n = "pioB_clk", .id = 7, }, > + { .n = "pioC_clk", .id = 8, }, > + { .n = "pioD_clk", .id = 9, }, > + { .n = "pioE_clk", .id = 10, }, > + { .n = "usart0_clk", .id = 12, .r = { .min = 0, .max = 66000000 }, }, > + { .n = "usart1_clk", .id = 13, .r = { .min = 0, .max = 66000000 }, }, > + { .n = "usart2_clk", .id = 14, .r = { .min = 0, .max = 66000000 }, }, > + { .n = "usart3_clk", .id = 15, .r = { .min = 0, .max = 66000000 }, }, > + { .n = "uart0_clk", .id = 16, .r = { .min = 0, .max = 66000000 }, }, > + { .n = "uart1_clk", .id = 17, .r = { .min = 0, .max = 66000000 }, }, > + { .n = "twi0_clk", .id = 18, .r = { .min = 0, .max = 16625000 }, }, > + { .n = "twi1_clk", .id = 19, .r = { .min = 0, .max = 16625000 }, }, > + { .n = "twi2_clk", .id = 20, .r = { .min = 0, .max = 16625000 }, }, > + { .n = "mci0_clk", .id = 21, }, > + { .n = "mci1_clk", .id = 22, }, > + { .n = "mci2_clk", .id = 23, }, > + { .n = "spi0_clk", .id = 24, .r = { .min = 0, .max = 133000000 }, }, > + { .n = "spi1_clk", .id = 25, .r = { .min = 0, .max = 133000000 }, }, > + { .n = "tcb0_clk", .id = 26, .r = { .min = 0, .max = 133000000 }, }, > + { .n = "tcb1_clk", .id = 27, }, > + { .n = "pwm_clk", .id = 28, }, > + { .n = "adc_clk", .id = 29, .r = { .min = 0, .max = 66000000 }, }, > + { .n = "dma0_clk", .id = 30, }, > + { .n = "dma1_clk", .id = 31, }, > + { .n = "uhphs_clk", .id = 32, }, > + { .n = "udphs_clk", .id = 33, }, > + { .n = "macb0_clk", .id = 34, }, > + { .n = "macb1_clk", .id = 35, }, > + { .n = "lcdc_clk", .id = 36, }, > + { .n = "isi_clk", .id = 37, }, > + { .n = "ssc0_clk", .id = 38, .r = { .min = 0, .max = 66000000 }, }, > + { .n = "ssc1_clk", .id = 39, .r = { .min = 0, .max = 66000000 }, }, > + { .n = "can0_clk", .id = 40, .r = { .min = 0, .max = 66000000 }, }, > + { .n = "can1_clk", .id = 41, .r = { .min = 0, .max = 66000000 }, }, > + { .n = "sha_clk", .id = 42, }, > + { .n = "aes_clk", .id = 43, }, > + { .n = "tdes_clk", .id = 44, }, > + { .n = "trng_clk", .id = 45, }, > + { .n = "fuse_clk", .id = 48, }, > + { .n = "mpddr_clk", .id = 49, }, > +}; > + > +static void __init sama5d3_pmc_setup(struct device_node *np) > +{ > + const char *slck_name, *mainxtal_name; > + struct pmc_data *sama5d3_pmc; > + const char *parent_names[5]; > + struct regmap *regmap; > + struct clk_hw *hw; > + int i; > + bool bypass; > + > + i = of_property_match_string(np, "clock-names", "slow_clk"); > + if (i < 0) > + return; > + > + slck_name = of_clk_get_parent_name(np, i); > + > + i = of_property_match_string(np, "clock-names", "main_xtal"); > + if (i < 0) > + return; > + mainxtal_name = of_clk_get_parent_name(np, i); > + > + regmap = syscon_node_to_regmap(np); > + if (IS_ERR(regmap)) > + return; > + > + sama5d3_pmc = pmc_data_allocate(PMC_MAIN + 1, > + nck(sama5d3_systemck), > + nck(sama5d3_periphck), 0); > + if (!sama5d3_pmc) > + return; > + > + hw = at91_clk_register_main_rc_osc(regmap, "main_rc_osc", 12000000, > + 50000000); > + if (IS_ERR(hw)) > + goto err_free; > + > + bypass = of_property_read_bool(np, "atmel,osc-bypass"); > + > + hw = at91_clk_register_main_osc(regmap, "main_osc", mainxtal_name, > + bypass); > + if (IS_ERR(hw)) > + goto err_free; > + > + parent_names[0] = "main_rc_osc"; > + parent_names[1] = "main_osc"; > + hw = at91_clk_register_sam9x5_main(regmap, "mainck", parent_names, 2); > + if (IS_ERR(hw)) > + goto err_free; > + > + hw = at91_clk_register_pll(regmap, "pllack", "mainck", 0, > + &sama5d3_pll_layout, &plla_characteristics); > + if (IS_ERR(hw)) > + goto err_free; > + > + hw = at91_clk_register_plldiv(regmap, "plladivck", "pllack"); > + if (IS_ERR(hw)) > + goto err_free; > + > + hw = at91_clk_register_utmi(regmap, NULL, "utmick", "mainck"); > + if (IS_ERR(hw)) > + goto err_free; > + > + sama5d3_pmc->chws[PMC_UTMI] = hw; > + > + parent_names[0] = slck_name; > + parent_names[1] = "mainck"; > + parent_names[2] = "plladivck"; > + parent_names[3] = "utmick"; > + hw = at91_clk_register_master(regmap, "masterck", 4, parent_names, > + &at91sam9x5_master_layout, > + &mck_characteristics); > + if (IS_ERR(hw)) > + goto err_free; > + > + sama5d3_pmc->chws[PMC_MCK] = hw; > + > + parent_names[0] = "plladivck"; > + parent_names[1] = "utmick"; > + hw = at91sam9x5_clk_register_usb(regmap, "usbck", parent_names, 2); > + if (IS_ERR(hw)) > + goto err_free; > + > + hw = at91sam9x5_clk_register_smd(regmap, "smdclk", parent_names, 2); > + if (IS_ERR(hw)) > + goto err_free; > + > + parent_names[0] = slck_name; > + parent_names[1] = "mainck"; > + parent_names[2] = "plladivck"; > + parent_names[3] = "utmick"; > + parent_names[4] = "masterck"; > + for (i = 0; i < 3; i++) { > + char name[6]; > + > + snprintf(name, sizeof(name), "prog%d", i); > + > + hw = at91_clk_register_programmable(regmap, name, > + parent_names, 5, i, > + &at91sam9x5_programmable_layout); > + if (IS_ERR(hw)) > + goto err_free; > + } > + > + for (i = 0; i < ARRAY_SIZE(sama5d3_systemck); i++) { > + hw = at91_clk_register_system(regmap, sama5d3_systemck[i].n, > + sama5d3_systemck[i].p, > + sama5d3_systemck[i].id); > + if (IS_ERR(hw)) > + goto err_free; > + > + sama5d3_pmc->shws[sama5d3_systemck[i].id] = hw; > + } > + > + for (i = 0; i < ARRAY_SIZE(sama5d3_periphck); i++) { > + hw = at91_clk_register_sam9x5_peripheral(regmap, &pmc_pcr_lock, > + &sama5d3_pcr_layout, > + sama5d3_periphck[i].n, > + "masterck", > + sama5d3_periphck[i].id, > + &sama5d3_periphck[i].r); > + if (IS_ERR(hw)) > + goto err_free; > + > + sama5d3_pmc->phws[sama5d3_periphck[i].id] = hw; > + } > + > + of_clk_add_hw_provider(np, of_clk_hw_pmc_get, sama5d3_pmc); > + > + return; > + > +err_free: > + pmc_data_free(sama5d3_pmc); > +} > +CLK_OF_DECLARE_DRIVER(sama5d3_pmc, "atmel,sama5d3-pmc", sama5d3_pmc_setup); Any reason this can't be a platform driver? _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel