Re: [PATCH] scripts/mksysmap: Ignore prefixed KCFI symbols

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Sat, Jun 24, 2023 at 5:45 AM Sami Tolvanen <samitolvanen@xxxxxxxxxx> wrote:
>
> Hi Pierre-Clément,
>
> On Fri, Jun 23, 2023 at 7:08 AM Pierre-Clément Tosi <ptosi@xxxxxxxxxx> wrote:
> >
> > The (relatively) new KCFI feature in LLVM/Clang encodes type information
> > for C functions by generating symbols named __kcfi_typeid_<fname>, which
> > can then be referenced from assembly. However, some custom build rules
> > (e.g. EFI, nVHE, or early PIE on arm64) use objcopy to add a prefix to
> > all the symbols in their object files, making mksysmap's ignore filter
> > miss those KCFI symbols.
> >
> > Therefore, explicitly list those twice-prefixed KCFI symbols as ignored.
> >
> > Alternatively, this could also be achieved in a less verbose way by
> > ignoring any symbol containing the string "__kcfi_typeid_". However,
> > listing the combined prefixes explicitly saves us from running the small
> > risk of ignoring symbols that should be kept.
> >
> > Signed-off-by: Pierre-Clément Tosi <ptosi@xxxxxxxxxx>
> > ---
> >  scripts/mksysmap | 3 +++
> >  1 file changed, 3 insertions(+)
> >
> > diff --git a/scripts/mksysmap b/scripts/mksysmap
> > index 26f39772f7a5..17cf4292e26b 100755
> > --- a/scripts/mksysmap
> > +++ b/scripts/mksysmap
> > @@ -61,7 +61,10 @@ ${NM} -n ${1} | sed >${2} -e "
> >  / __microLA25Thunk_/d
> >
> >  # CFI type identifiers
> > +/ __efistub___kcfi_typeid_/d
>
> Does the existing __efistub_/d rule not catch this?


Agree with Sami.

This line looks redundant to me.




>
> >  / __kcfi_typeid_/d
> > +/ __kvm_nvhe___kcfi_typeid_/d
> > +/ __pi___kcfi_typeid_/d
>
> Either way, otherwise this looks reasonable to me. Thanks for the patch!
>
> Reviewed-by: Sami Tolvanen <samitolvanen@xxxxxxxxxx>
>
> Sami



-- 
Best Regards
Masahiro Yamada




[Index of Archives]     [Linux&nblp;USB Development]     [Linux Media]     [Video for Linux]     [Linux Audio Users]     [Yosemite Secrets]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux