[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [PATCH v2 2/2] livepatch: refuse to resolve symbols that belong to init sections
On 22.04.2024 13:34, Roger Pau Monné wrote: > On Mon, Apr 22, 2024 at 12:57:55PM +0200, Jan Beulich wrote: >> On 22.04.2024 12:49, Roger Pau Monné wrote: >>> On Mon, Apr 22, 2024 at 10:25:40AM +0200, Jan Beulich wrote: >>>> On 22.04.2024 09:54, Roger Pau Monné wrote: >>>>> On Fri, Apr 19, 2024 at 04:34:41PM +0200, Jan Beulich wrote: >>>>>> On 19.04.2024 12:50, Roger Pau Monné wrote: >>>>>>> On Fri, Apr 19, 2024 at 12:15:19PM +0200, Jan Beulich wrote: >>>>>>>> On 19.04.2024 12:02, Roger Pau Monne wrote: >>>>>>>>> Livepatch payloads containing symbols that belong to init sections >>>>>>>>> can only >>>>>>>>> lead to page faults later on, as by the time the livepatch is loaded >>>>>>>>> init >>>>>>>>> sections have already been freed. >>>>>>>>> >>>>>>>>> Refuse to resolve such symbols and return an error instead. >>>>>>>>> >>>>>>>>> Note such resolutions are only relevant for symbols that point to >>>>>>>>> undefined >>>>>>>>> sections (SHN_UNDEF), as that implies the symbol is not in the >>>>>>>>> current payload >>>>>>>>> and hence must either be a Xen or a different livepatch payload >>>>>>>>> symbol. >>>>>>>>> >>>>>>>>> Do not allow to resolve symbols that point to __init_begin, as that >>>>>>>>> address is >>>>>>>>> also unmapped. On the other hand, __init_end is not unmapped, and >>>>>>>>> hence allow >>>>>>>>> resolutions against it. >>>>>>>>> >>>>>>>>> Signed-off-by: Roger Pau Monné <roger.pau@xxxxxxxxxx> >>>>>>>>> --- >>>>>>>>> Changes since v1: >>>>>>>>> - Fix off-by-one in range checking. >>>>>>>> >>>>>>>> Which means you addressed Andrew's comment while at the same time >>>>>>>> extending >>>>>>>> the scope of ... >>>>>>>> >>>>>>>>> @@ -310,6 +311,21 @@ int livepatch_elf_resolve_symbols(struct >>>>>>>>> livepatch_elf *elf) >>>>>>>>> break; >>>>>>>>> } >>>>>>>>> } >>>>>>>>> + >>>>>>>>> + /* >>>>>>>>> + * Ensure not an init symbol. Only applicable to Xen >>>>>>>>> symbols, as >>>>>>>>> + * livepatch payloads don't have init sections or >>>>>>>>> equivalent. >>>>>>>>> + */ >>>>>>>>> + else if ( st_value >= (uintptr_t)&__init_begin && >>>>>>>>> + st_value < (uintptr_t)&__init_end ) >>>>>>>>> + { >>>>>>>>> + printk(XENLOG_ERR LIVEPATCH >>>>>>>>> + "%s: symbol %s is in init section, not >>>>>>>>> resolving\n", >>>>>>>>> + elf->name, elf->sym[i].name); >>>>>>>> >>>>>>>> ... what I raised concern about (and I had not seen any verbal reply >>>>>>>> to that, >>>>>>>> I don't think). >>>>>>> >>>>>>> I've extended the commit message to explicitly mention the handling of >>>>>>> bounds for __init_{begin,end} checks. Let me know if you are not fine >>>>>>> with it (or maybe you expected something else?). >>>>>> >>>>>> Well, you mention the two symbols you care about, but you don't mention >>>>>> at all that these two may alias other symbols which might be legal to >>>>>> reference from a livepatch. >>>>> >>>>> I'm having a hard time understanding why a livepatch would want to >>>>> reference those, or any symbol in the .init sections for that matter. >>>>> __init_{begin,end} are exclusively used to unmap the init region after >>>>> boot. What's the point in livepatch referencing data that's no >>>>> longer there? The only application I would think of is to calculate >>>>> some kind of offsets, but that would better be done using other >>>>> symbols instead. >>>>> >>>>> Please bear with me, it would be easier for me to understand if you >>>>> could provide a concrete example. >>>> >>>> The issue is that you do comparison by address, not by name. Let's assume >>>> that .rodata ends exactly where .init.* starts. Then &__init_begin == >>>> &_erodata == &__2M_rodata_end. Access to the latter two symbols wants to >>>> be permitted; only __init_begin and whatever ends up being the very first >>>> symbol in .init.* ought to not be referenced. >>> >>> Hm, I guess I could add comparison by name additionally, but it looks >>> fragile to me. >> >> It looks fragile, yes. Thing is that you're trying to deal with this when >> crucial information was lost already. Or wait - isn't the section number >> still available in ->st_shndx? > > But that's the section number of the to be resolved symbol? In the > livepatch payload it would for example appear as: > > 0000000000000000 F *UND* 0000000000000000 .hidden > setup_boot_APIC_clock > > With undefined section. > > It's possible I'm not following, is there a way to get the section > number of the current Xen symbols, and then correlate it with the > .init section? Hmm, yes, looks like I was forgetting that livepatch resolves symbols using kallsyms data, not Xen's ELF symbol table. Jan
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |