[U-Boot] [PATCH 01/50] dm: clk: Add support for decoding clocks from the device tree
Simon Glass
sjg at chromium.org
Tue Jan 19 03:53:03 CET 2016
Hi Masahiro,
On 18 January 2016 at 19:01, Masahiro Yamada
<yamada.masahiro at socionext.com> wrote:
> Hi Simon,
>
>
> 2016-01-15 22:21 GMT+09:00 Simon Glass <sjg at chromium.org>:
>> Hi Masahiro,
>>
>> On 14 January 2016 at 03:11, Masahiro Yamada
>> <yamada.masahiro at socionext.com> wrote:
>>> Hi Simon,
>>>
>>>
>>>
>>>> @@ -12,6 +12,8 @@
>>>> #include <dm/lists.h>
>>>> #include <dm/root.h>
>>>>
>>>> +DECLARE_GLOBAL_DATA_PTR;
>>>> +
>>>> ulong clk_get_rate(struct udevice *dev)
>>>> {
>>>> struct clk_ops *ops = clk_get_ops(dev);
>>>> @@ -62,6 +64,32 @@ int clk_get_id(struct udevice *dev, int args_count, uint32_t *args)
>>>> return ops->get_id(dev, args_count, args);
>>>> }
>>>>
>>>> +int clk_get_by_index(struct udevice *dev, int index, struct udevice **clk_devp,
>>>> + int *periphp)
>>>
>>>
>>> This function causes NULL pointer access
>>> if called with clk_devp == NULL.
>>
>> Yes, don't do that. Do you think the function comment is unclear?
>
>
> This would not be a problem in this case,
> but I thought NULL-pointer checking is a boilterplate
> when we return a pointer filled into a function argument.
>
>
>
>>>
>>>
>>> You can decrease the number of arguments
>>> if this function returns periph ID.
>>
>> Right, but how to handle 0?
>
>
>>= 0 means peripheral ID.
>
> < 0 means error code.
>
>
>>>
>>>
>>>> +{
>>>> + struct fdtdec_phandle_args args;
>>>> + int ret;
>>>> +
>>>> + ret = fdtdec_parse_phandle_with_args(gd->fdt_blob, dev->of_offset,
>>>> + "clocks", "#clock-cells", 0, index,
>>>> + &args);
>>>> + if (ret) {
>>>> + debug("%s: fdtdec_parse_phandle_with_args failed: err=%d\n",
>>>> + __func__, ret);
>>>> + return ret;
>>>> + }
>>>> +
>>>> + ret = uclass_get_device_by_of_offset(UCLASS_CLK, args.node, clk_devp);
>>>> + if (ret) {
>>>> + debug("%s: uclass_get_device_by_of_offset failed: err=%d\n",
>>>> + __func__, ret);
>>>> + return ret;
>>>> + }
>>>> + *periphp = args.args_count > 0 ? args.args[0] : -1;
>>>
>>>
>>> Do you want to let this function fail against #clock-cells == 0?
>>
>> At present it doesn't. That's why I didn't have it return the
>> peripheral ID. What could we return to signify that the function
>> succeeded but there was no peripheral ID?
>
>
> I think any clock provider should have at least one ID.
>
> If "clock-cells == 0", this clock has ID 0.
>
> Please correct me if I am misunderstanding.
That sounds fine to me. I've sent an update to that one patch.
Regards,
Simon
More information about the U-Boot
mailing list