[PATCH v2 4/4] riscv: dts: starfive: don't use a default configuration

Heinrich Schuchardt heinrich.schuchardt at canonical.com
Mon Feb 10 14:26:46 CET 2025


On 10.02.25 14:08, Simon Glass wrote:
> Hi Heinrich,
> 
> On Mon, 10 Feb 2025 at 04:18, Heinrich Schuchardt
> <heinrich.schuchardt at canonical.com> wrote:
>>
>> Booting JH7110 systems with a VisionFive 2 device-tree used to kind of
>> work without causing harm to the hardware. But there is no guarantee
>> that this will hold true in future. So we should not rely on it.
>>
>> Before the current patch series booting failed on unsupported boards due
>> to the lack of a device-tree in the binman generated default configuration
>> when reaching main U-Boot.
>>
>> By setting the default configuration to non-matching value booting will
>> now fail on unsupported boards already in SPL. This allows SPL to
>> continue with the next boot source for a possible recovery.
>>
>> Signed-off-by: Heinrich Schuchardt <heinrich.schuchardt at canonical.com>
>> ---
>> v2:
>>          new patch
>> ---
>>   arch/riscv/dts/starfive-visionfive2-binman.dtsi | 13 +++++++++++++
>>   1 file changed, 13 insertions(+)
>>
>> diff --git a/arch/riscv/dts/starfive-visionfive2-binman.dtsi b/arch/riscv/dts/starfive-visionfive2-binman.dtsi
>> index 05787bdb92d..dd0faca6824 100644
>> --- a/arch/riscv/dts/starfive-visionfive2-binman.dtsi
>> +++ b/arch/riscv/dts/starfive-visionfive2-binman.dtsi
>> @@ -13,6 +13,19 @@
>>   };
>>
>>   &binman {
>> +       itb {
>> +               fit {
>> +                       configurations {
>> +                               /*
>> +                                * Do not boot if there is no matching
>> +                                * configuration. We can't remove the default
>> +                                * here. So use a non-matching value.
>> +                                */
>> +                               default = "none";
> 
> The 'default' is optional [1] but the spec is silent on what happens
> when the default is missing. What do you think it should do? Perhaps
> we should add a property to define the behaviour?

If there is no match and default does not exist, we should not boot.

In our current code we don't boot if default points to a non-existing 
config. But having inconsistent FIT images might not be the best idea.

Maybe it would be better to use

#ifndef CONFIG_MULTI_DTB_FIT
	default = "conf-1";
#endif

in arch/riscv/dts/binman.dtsi to avoid having an invalid default value?

Best regards

Heinrich

> 
>> +                       };
>> +               };
>> +       };
>> +
>>          spl-img {
>>                  filename = "spl/u-boot-spl.bin.normal.out";
>>
>> --
>> 2.47.1
>>
> 
> Regards,
> SImon
> 
> [1] https://fitspec.osfw.foundation/#id4



More information about the U-Boot mailing list