On Wed, Sep 13, 2017 at 07:38:14AM +0000, xiaoggchen(陈小光) wrote:
> v2:
> Change based on Joe's suggestion that revert back to ".*.o" and add a new
> "*/.lib_exports.o" pattern.
> 
> v1:
> When there are ".." in source object path then current kpatch-gcc can not
> handle it correctly:
> kpatch-gcc use the following logic to check the objects who got recompiled
> and would write the changed objects to "chagned_objs". But if the path of the
> input obj is something like"arch/x86/kvm/../../../virt/kvm/.tmp_kvm_main.o"
> then the following logic can not handle it properly, the kvm_main.o will fall
> into the "*.*.o" branch.
> And kpatch-build will end up with "ERROR: no changed objects found.
> Check /root/.kpatch/build.log for more details."
> 
> kpatch/kpatch-build/kpatch-gcc:
>  ......
>  case "$obj" in
>                                 *.mod.o|\
>                                 *built-in.o|\
>                                 vmlinux.o|\
>                                 .tmp_kallsyms1.o|\
>                                 .tmp_kallsyms2.o|\
>                                 init/version.o|\
>                                 arch/x86/boot/version.o|\
>                                 arch/x86/boot/compressed/eboot.o|\
>                                 arch/x86/boot/header.o|\
>                                 arch/x86/boot/compressed/efi_stub_64.o|\
>                                 arch/x86/boot/compressed/piggy.o|\
>                                 kernel/system_certificates.o|\
>                                 arch/x86/vdso/*|\
>                                 arch/x86/entry/vdso/*|\
>                                 drivers/firmware/efi/libstub/*|\
>                                 arch/powerpc/kernel/prom_init.o|\
>                                 *.*.o)
>                                         break
>                                         ;;
>                                 *.o)
>                                         mkdir -p 
> "$KPATCH_GCC_TEMPDIR/orig/$(dirname $obj)"
>                                         [[ -e $obj ]] && cp -f "$obj" 
> "$KPATCH_GCC_TEMPDIR/orig/$obj"
>                                         echo "$obj" >> 
> "$KPATCH_GCC_TEMPDIR/changed_objs"
>                                         break
>                                         ;;
>                                 *)
>                                         break
>                                         ;;
>                         esac
>  ......
> 
> Cc: Joe Lawrence <[email protected]>
> Signed-off-by: chen xiaoguang <[email protected]>
> ---
>  kpatch-build/kpatch-gcc | 3 ++-
>  1 file changed, 2 insertions(+), 1 deletion(-)
> 
> diff --git a/kpatch-build/kpatch-gcc b/kpatch-build/kpatch-gcc
> index e91f4b2..35f479f 100755
> --- a/kpatch-build/kpatch-gcc
> +++ b/kpatch-build/kpatch-gcc
> @@ -38,7 +38,8 @@ if [[ "$TOOLCHAINCMD" = "gcc" ]] ; then
>                                 arch/x86/entry/vdso/*|\
>                                 drivers/firmware/efi/libstub/*|\
>                                 arch/powerpc/kernel/prom_init.o|\
> -                               *.*.o)
> +                               .*.o|\
> +                               */.lib_exports.o)
>                                         break
>                                         ;;
>                                 *.o)
> --
> 1.8.3.1

Thanks for the updated patch.  The patch seems to be malformed, so I
wasn't able to apply it.  Sending patches over email can be tricky; it
might help if you send the patch as an attachment.  Or it might be
easier to open a pull request on github.  Thanks!

-- 
Josh

_______________________________________________
kpatch mailing list
[email protected]
https://www.redhat.com/mailman/listinfo/kpatch

Reply via email to