On Mon, Mar 21, 2016 at 03:18:32PM -0400, Jessica Yu wrote: > +++ Miroslav Benes [21/03/16 14:55 +0100]: > >On Wed, 16 Mar 2016, Jessica Yu wrote: > > > >[...] > > > >>+struct klp_buf { > >>+ char symname[KSYM_SYMBOL_LEN]; > > > >I think it is better to make this KSYM_NAME_LEN. KSYM_SYMBOL_LEN looks > >like something different and KSYM_NAME_LEN is 128 which you reference > >below. > > > > Ack, I did mean to use KSYM_NAME_LEN, thanks. > > >>+ char objname[MODULE_NAME_LEN]; > >>+}; > > > >[...] > > > >>+static int klp_resolve_symbols(Elf_Shdr *relasec, struct module *pmod) > >>+{ > >>+ int i, cnt, vmlinux, ret; > >>+ struct klp_buf bufs = {0}; > >>+ Elf_Rela *relas; > >>+ Elf_Sym *sym; > >>+ char *symname; > >>+ unsigned long sympos; > >>+ > >>+ relas = (Elf_Rela *) relasec->sh_addr; > >>+ /* For each rela in this klp relocation section */ > >>+ for (i = 0; i < relasec->sh_size / sizeof(Elf_Rela); i++) { > >>+ sym = pmod->core_kallsyms.symtab + ELF_R_SYM(relas[i].r_info); > >>+ if (sym->st_shndx != SHN_LIVEPATCH) > >>+ return -EINVAL; > >>+ > >>+ klp_clear_buf(&bufs); > >>+ > >>+ /* Format: .klp.sym.objname.symbol_name,sympos */ > >>+ symname = pmod->core_kallsyms.strtab + sym->st_name; > >>+ cnt = sscanf(symname, ".klp.sym.%64[^.].%128[^,],%lu", > >>+ bufs.objname, bufs.symname, &sympos); > > > >It would be really nice to change actual values for their macro > >definitions, but this would be a mess which is not worth it. Anyway > >shouldn't those width modifiers be %63 and %127 to make a room for \0? > > > > Yes, this is a concern and I'm not sure what the best way to fix it > is. If both MODULE_NAME_LEN and KSYM_NAME_LEN were straight up > constants, then I think Josh's stringify approach would have worked > perfectly. However since MODULE_NAME_LEN translates to an expression > (64 - sizeof(unsigned long)), which the preprocessor cannot evaluate, > we will need another approach. Building the format strings at run time > might be messier than we'd like. Alternatively we could just go the > simple route and simply be a bit more aggressive on the upper bound > for the format width; though the size of long varies on different > architectures, afaik the max size it could ever be on any arch is 8 > bytes, so perhaps 64 - 8 = 56 (then - 1 to make room for \0) might be > an appropriate field width. This would deserve a comment as well. I think something like that would be good, along with: BUILD_BUG_ON(MODULE_NAME_LEN < 56); and a comment explaining why. -- Josh -- To unsubscribe from this list: send the line "unsubscribe live-patching" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html