From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932944AbcFPArq (ORCPT ); Wed, 15 Jun 2016 20:47:46 -0400 Received: from smtp.codeaurora.org ([198.145.29.96]:47434 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753209AbcFPArn (ORCPT ); Wed, 15 Jun 2016 20:47:43 -0400 Date: Wed, 15 Jun 2016 17:47:41 -0700 From: Stephen Boyd To: Ricardo Ribalda Delgado Cc: Michael Turquette , s.hauer@pengutronix.de, jeremy.kerr@canonical.com, linux-clk@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 2/3] clk: fixed-factor: Convert into a module platform driver Message-ID: <20160616004741.GR28218@codeaurora.org> References: <1465381201-11537-1-git-send-email-ricardo.ribalda@gmail.com> <1465381201-11537-3-git-send-email-ricardo.ribalda@gmail.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1465381201-11537-3-git-send-email-ricardo.ribalda@gmail.com> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 06/08, Ricardo Ribalda Delgado wrote: > if (of_property_read_u32(node, "clock-mult", &mult)) { > pr_err("%s Fixed factor clock <%s> must have a clock-mult property\n", > __func__, node->name); > - return; > + return ERR_PTR(-EIO); > } > > of_property_read_string(node, "clock-output-names", &clk_name); > @@ -171,8 +172,67 @@ void __init of_fixed_factor_clk_setup(struct device_node *node) > mult, div); > if (!IS_ERR(clk)) > of_clk_add_provider(node, of_clk_src_simple_get, clk); What if this fails now? > + > + return clk; > +} > + [..] > + > +static const struct of_device_id of_fixed_factor_clk_ids[] = { > + { > + .compatible = "fixed-factor-clock", > + }, > + { }, > +}; Nitpick: Do it this way: static const struct of_device_id of_fixed_factor_clk_ids[] = { { .compatible = "fixed-factor-clock" }, { } }; > +MODULE_DEVICE_TABLE(of, of_fixed_factor_clk_ids); > + > +static struct platform_driver of_fixed_factor_clk_driver = { > + .driver = { > + .name = "of_fixed_factor_clk", > + .of_match_table = of_fixed_factor_clk_ids, > + }, > + .probe = of_fixed_factor_clk_probe, > + .remove = of_fixed_factor_clk_remove, > +}; > + > +module_platform_driver(of_fixed_factor_clk_driver); > + This should be builtin_platform_driver() because these are obj-y right now. -- Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, a Linux Foundation Collaborative Project