[PATCH] sbi: fwft: clear the config lock when warm boot
Xiang W
wxjstz at 126.com
Thu Nov 21 20:06:03 PST 2024
在 2024-11-21四的 21:24 -0600,Samuel Holland写道:
> Hi Xiang,
>
> On 2024-11-21 8:45 PM, Xiang W wrote:
> > 在 2024-11-15五的 15:33 +0800,Nick Hu写道:
> > > The hotplug cpu should clear the fwft config's SBI_FWFT_SET_FLAG_LOCK
> > > in the warm boot flow otherwise the cpu can't set the menvcfg.sse by
> > > SBI_EXT_FWFT_SET sbi call and cause the illegal instruction when
> > > accessing the CSR_SSP in kernel.
> > >
> > > Signed-off-by: Nick Hu <nick.hu at sifive.com>
> >
> > In sbi_fwft_init, the memory for fwft_hart_state is allocated by
> > sbi_zalloc, which ensures that flags is 0. So no additional code
> > is needed to clear the SBI_FWFT_SET_FLAG_LOCK bit.
>
> That allocation only occurs the first time a hart is started. After a
> sbi_hsm_hart_stop() and sbi_hsm_hart_start(), the FWFT features will be reset to
> their default values per the SBI spec, and the flags need to be reset as well.
>
Yes, you are right, I ignored the situation you mentioned.
Regards,
Xiang W
> Regards,
> Samuel
>
> > > ---
> > > lib/sbi/sbi_fwft.c | 15 +++++++++++++++
> > > 1 file changed, 15 insertions(+)
> > >
> > > diff --git a/lib/sbi/sbi_fwft.c b/lib/sbi/sbi_fwft.c
> > > index 9cf14c16..0cb165b4 100644
> > > --- a/lib/sbi/sbi_fwft.c
> > > +++ b/lib/sbi/sbi_fwft.c
> > > @@ -311,6 +311,18 @@ static int fwft_get_feature(enum sbi_fwft_feature_t feature,
> > > return SBI_SUCCESS;
> > > }
> > >
> > > +static void fwft_clear_config_lock(enum sbi_fwft_feature_t feature)
> > > +{
> > > + int ret;
> > > + struct fwft_config *conf;
> > > +
> > > + ret = fwft_get_feature(feature, &conf);
> > > + if (ret)
> > > + return;
> > > +
> > > + conf->flags &= ~SBI_FWFT_SET_FLAG_LOCK;
> > > +}
> > > +
> > > int sbi_fwft_set(enum sbi_fwft_feature_t feature, unsigned long value,
> > > unsigned long flags)
> > > {
> > > @@ -414,5 +426,8 @@ int sbi_fwft_init(struct sbi_scratch *scratch, bool cold_boot)
> > > fwft_set_hart_state_ptr(scratch, fhs);
> > > }
> > >
> > > + for (i = 0; i < array_size(features); i++)
> > > + fwft_clear_config_lock(features[i].id);
> > > +
> > > return 0;
> > > }
> > > --
> > > 2.34.1
> > >
> > >
> >
> >
>
>
More information about the opensbi
mailing list