RE: [PATCH 3/3] ptp_qoriq: convert to use module parameters for initialization
From: "Y.b. Lu" <yangbo.lu@nxp.com>
Date: 2018-08-01 04:36:49
Also in:
linux-arm-kernel, linuxppc-dev, lkml, netdev
Hi Richard,
-----Original Message----- From: Richard Cochran [mailto:richardcochran@gmail.com] Sent: Monday, July 30, 2018 10:31 PM To: Y.b. Lu <yangbo.lu@nxp.com> Cc: netdev@vger.kernel.org; Madalin-cristian Bucur [off-list ref]; Rob Herring [off-list ref]; Shawn Guo [off-list ref]; David S . Miller [off-list ref]; devicetree@vger.kernel.org; linuxppc-dev@lists.ozlabs.org; linux-arm-kernel@lists.infradead.org; linux-kernel@vger.kernel.org Subject: Re: [PATCH 3/3] ptp_qoriq: convert to use module parameters for initialization On Mon, Jul 30, 2018 at 06:01:54PM +0800, Yangbo Lu wrote:quoted
The ptp_qoriq driver initialized the 1588 timer with the configurations provided by the properties of device tree node. For example, fsl,tclk-period = <5>; fsl,tmr-prsc = <2>; fsl,tmr-add = <0xaaaaaaab>; fsl,tmr-fiper1 = <999999995>; fsl,tmr-fiper2 = <99990>; fsl,max-adj = <499999999>; These things actually were runtime configurations which were not proper to be put into dts.That is debatable. While I agree that the dts isn't ideal for these, still it is the lesser of two or more evils.
[Y.b. Lu] Ok. You're right indeed :)
quoted
This patch is to convert to use module parameters for 1588 timer initialization, and to support initial register values calculation.It is hard for me to understand how using module parameters improves the situation.
[Y.b. Lu] Actually I'm not sure whether module_param will be accepted to replace dts. I thought the most possibility would be rejection before sending them out. Just want suggestion and confirmation whether there is better idea than dts from your comments. Since we should keep the dts, I will drop the module_param. Could I add a function to calculate a set of default register values to initialize ptp timer when dts method failed to get required properties in driver? I think this will be useful. The ptp timer on new platforms (you may see two dts patches in this patchset. Many platforms will be affected.) will work without these dts properties. If user want specific setting, they can set dts properties.
quoted
If the parameters are not provided, the driver will calculate register values with a set of default parameters. With this patch, those dts properties are no longer needed for new platform to support 1588 timer, and many QorIQ DPAA platforms (some P series and T series platforms of PowerPC, and some LS series platforms of ARM64) could use this driver for their fman ptp timer with default module parameters. However, this patch didn't remove the dts method. Because there were still many old platforms using the dts method. We need to clean up their dts files, verify module parameters on them, and convert them to the new method gradually in case of breaking any function.In addition, like it or not, because the dts is an ABI, you must continue support of the dts values as a legacy option.
[Y.b. Lu] I get your point now. The dts should be kept :)
Thanks, Richard