Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp925346img; Fri, 22 Mar 2019 11:32:18 -0700 (PDT) X-Google-Smtp-Source: APXvYqyUchdJEY1YYYfD1zWgmKgDrF5ACGKXW6JF82C0SxS/fJU1aS1/cwCbvZphiyjiuWkKA9aQ X-Received: by 2002:a63:195e:: with SMTP id 30mr6698034pgz.312.1553279538785; Fri, 22 Mar 2019 11:32:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553279538; cv=none; d=google.com; s=arc-20160816; b=entKAIerxeZAMJ0VzZpyjatLnJ8Ti4+M4TcfD1JySXJrjvKwtBw59naYn0tR9jyaSL ybQRupnsNx+RWmCH9sOhJM8XbfPiiiDX1LWbvR9wP6DOR0G2HSDCbEgR9lQwxghhIkYb Q9/SoIz4N1EZyrdEYmEEbYM1BAyVG/IDknczKJ3j/8o7/lF+ee024WZ6MbYaGuZZP3mX whPD5tzfc86LiQnDbTMrngNCNKZXIZ7OSryCBJIeOVbr1cTZInItW0Y5RV9t7NbTL+xT aoUuBU9KnQgbTNMN8lUc6htN/Z7HTy45ZFxPXPZdXa2T39huDlj+8NkDpvZnKzfU3e9e o0Hw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=7uET6IRlhQ7pKGqwPLRxCoUL/eQ8Hy0eLLM4jvlCpi4=; b=nn4+msgS5DJTYsjbUUfFp6kgzhv/YTFen3T7GONcS/fusi7deGQuQ6PuNeqcy359j3 F7gwUyZzkza0CMkL7//+taLwc4rzFK9PQxFvOP/wykxJ/OO9ogRrTVCydUzXuVQ2ySe6 blWN2sUUN6zWhq3q98uPUNrdjT6fzjn7ayK4XTHRR9dwrlk0auB9QldLdgjtR8sheFQF NUO/o/xkwpzttPzqtsKcBItFk1iKlxFvyKFylOHRpd6C+ZllvjH0/hQh4FtFkl51JrhO FhJDzfNeyKUGUKABJ6fIbY3U6Bk8aXPbgIBYBV7b0mqVyKl1IX93HID0W0/KtL9NuyMS FkNw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h66si7452383pgc.537.2019.03.22.11.32.00; Fri, 22 Mar 2019 11:32:18 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728660AbfCVS3e (ORCPT + 99 others); Fri, 22 Mar 2019 14:29:34 -0400 Received: from mx1.redhat.com ([209.132.183.28]:48322 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727050AbfCVS3e (ORCPT ); Fri, 22 Mar 2019 14:29:34 -0400 Received: from smtp.corp.redhat.com (int-mx05.intmail.prod.int.phx2.redhat.com [10.5.11.15]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 79D2D89C37; Fri, 22 Mar 2019 18:29:32 +0000 (UTC) Received: from [10.18.17.208] (dhcp-17-208.bos.redhat.com [10.18.17.208]) by smtp.corp.redhat.com (Postfix) with ESMTPS id A4DE15D70A; Fri, 22 Mar 2019 18:29:30 +0000 (UTC) Subject: Re: [PATCH v2 5/8] modpost: Integrate klp-convert To: Joao Moreira Cc: live-patching@vger.kernel.org, mbenes@suse.cz, pmladek@suse.cz, jikos@suse.cz, nstange@suse.de, jpoimboe@redhat.com, khlebnikov@yandex-team.ru, jeyu@kernel.org, matz@suse.de, linux-kernel@vger.kernel.org, yamada.masahiro@socionext.com, linux-kbuild@vger.kernel.org, michal.lkml@markovi.net, live-patching-owner@vger.kernel.org References: <20190301141313.15057-1-jmoreira@suse.de> <20190301141313.15057-6-jmoreira@suse.de> <20190322145404.GA31248@redhat.com> <48deaa61c7bd81e40df445ba80825ad7@suse.de> From: Joe Lawrence Message-ID: <548c547a-d56c-40e9-6747-016c9eba7bf4@redhat.com> Date: Fri, 22 Mar 2019 14:29:29 -0400 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.5.1 MIME-Version: 1.0 In-Reply-To: <48deaa61c7bd81e40df445ba80825ad7@suse.de> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit X-Scanned-By: MIMEDefang 2.79 on 10.5.11.15 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.27]); Fri, 22 Mar 2019 18:29:33 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 3/22/19 12:37 PM, Joao Moreira wrote: > On 2019-03-22 11:54, Joe Lawrence wrote: >> On Fri, Mar 01, 2019 at 11:13:10AM -0300, Joao Moreira wrote: >>> From: Josh Poimboeuf >>> >>> Create cmd_klp_convert and hook it into scripts/Makefile.modpost. >>> cmd_klp_convert invokes klp-convert with the right arguments for the >>> conversion of unresolved symbols inside a livepatch. >>> >>> [khlebnikov: >>> * save cmd_ld_ko_o into .module.cmd, if_changed_rule doesn't do that >>> * fix bashisms for debian where /bin/sh is a symlink to /bin/dash >>> * rename rule_link_module to rule_ld_ko_o, otherwise arg-check inside >>> if_changed_rule compares cmd_link_module and cmd_ld_ko_o >>> * check modinfo -F livepatch only if CONFIG_LIVEPATCH is true >>> ] >>> >>> [mbenes: >>> * remove modinfo call. LIVEPATCH_ in Makefiled >>> ] >>> >>> [jmoreira: >>> * split up: move the .livepatch file-based scheme for identifying >>> livepatches to a previous patch, as it was required for correctly >>> building Symbols.list there. >>> ] >>> >>> Signed-off-by: Josh Poimboeuf >>> Signed-off-by: Konstantin Khlebnikov >>> Signed-off-by: Miroslav Benes >>> Signed-off-by: Joao Moreira >>> --- >>> scripts/Kbuild.include | 4 +++- >>> scripts/Makefile.modpost | 16 +++++++++++++++- >>> scripts/mod/modpost.c | 6 +++++- >>> scripts/mod/modpost.h | 1 + >>> 4 files changed, 24 insertions(+), 3 deletions(-) >>> >>> >>> [ ... snip ... ] >>> >>> diff --git a/scripts/Makefile.modpost b/scripts/Makefile.modpost >>> index 7d4af0d0accb..da779a185218 100644 >>> --- a/scripts/Makefile.modpost >>> +++ b/scripts/Makefile.modpost >>> @@ -125,8 +125,22 @@ quiet_cmd_ld_ko_o = LD [M] $@ >>> -o $@ $(filter-out FORCE,$^) ; >>> \ >>> $(if $(ARCH_POSTLINK), $(MAKE) -f $(ARCH_POSTLINK) $@, true) >>> >>> +SLIST = $(objtree)/Symbols.list >>> +KLP_CONVERT = scripts/livepatch/klp-convert >>> +quiet_cmd_klp_convert = KLP $@ >>> + cmd_klp_convert = mv $@ $(@:.ko=.klp.o); \ >>> + $(KLP_CONVERT) $(SLIST) $(@:.ko=.klp.o) $@ >>> + >>> +define rule_ld_ko_o >>> + $(call cmd,ld_ko_o) $(cmd_ld_ko_o) ; \ >> ^ >> Should there be a ';' semicolon here (and maybe a line-break) between >> $(call cmd,ld_ko_o) and $(cmd_ld_ko_o)? >> >> I didn't see this in my x86_64 VM, but on a ppc64le box, I kept getting >> really strange build errors that I traced to this line. Without a >> semicolon, the build was trying to run a make command with a linker >> command smashed onto the end of it: >> >> make -f ./arch/powerpc/Makefile.postlink crypto/xts.ko ld -r -EL -m >> elf64lppc -T ./scripts/module-common.lds -T >> ./arch/powerpc/kernel/module.lds --save-restore-funcs --build-id -o >> crypto/xts.ko crypto/xts.o crypto/xts.mod.o >> >> >> Now, klp-convert looks like will need some ppc64le work as well, as >> it's >> confused about .TOC. symbols: >> >> CC samples/livepatch/livepatch-annotated-sample.mod.o >> CC samples/livepatch/livepatch-callbacks-busymod.mod.o >> CC samples/livepatch/livepatch-callbacks-demo.mod.o >> CC samples/livepatch/livepatch-callbacks-mod.mod.o >> CC samples/livepatch/livepatch-sample.mod.o >> CC samples/livepatch/livepatch-shadow-fix1.mod.o >> CC samples/livepatch/livepatch-shadow-fix2.mod.o >> CC samples/livepatch/livepatch-shadow-mod.mod.o >> LD [M] samples/livepatch/livepatch-annotated-sample.ko >> LD [M] samples/livepatch/livepatch-callbacks-demo.ko >> KLP samples/livepatch/livepatch-annotated-sample.ko >> LD [M] samples/livepatch/livepatch-callbacks-mod.ko >> KLP samples/livepatch/livepatch-callbacks-demo.ko >> LD [M] samples/livepatch/livepatch-sample.ko >> LD [M] samples/livepatch/livepatch-shadow-fix1.ko >> klp-convert: Define KLP_SYMPOS for the symbol: .TOC. >> Valid KLP_SYMPOS for symbol .TOC.: >> >> [ ... snip listing of all .TOC's across the kernel ... ] >> >> but we can save that for another day. >> > > Hi Joe, first of all, thank you for you in-depth review. I did not have > the time to go through everything yet, and I'll reply properly to the > other comments soon. Yet, I would like to add a quick note here, since > you are testing ppc64le. ppc64le is exactly one of the things I have > been dealing with in the last two days, specifically the .TOC. symbols > (there is also another bug related to converting relocations of symbols > with index 0, but this one is architecture agnostic). > > If you would like to take a look, the fix is in the latest commit here: > - https://github.com/SUSE/klp-convert/tree/fixppc64le > > I would be very glad if you have any comment or input on that, and I > guess that if the fix is that simple, I can manage to squash it into v3. Hi João, I added https://github.com/SUSE/klp-convert/commit/69b89ef5c366 on top of my https://github.com/joe-lawrence/linux/tree/klp-convert-v2-rebase-review branch with positive results: (No build klp-convert build complaints) % uname -r Linux ibm-p9z-21-lp26.mpc.lab.eng.bos.redhat.com 5.1.0-rc1+ #6 SMP Thu Mar 21 11:40:24 EDT 2019 ppc64le ppc64le ppc64le GNU/Linux % insmod samples/livepatch/livepatch-annotated-sample.ko % grep -o 'livepatch.*' /proc/cmdline livepatch=1 % ./tools/testing/selftests/livepatch/test-livepatch.sh TEST: basic function patching ... ok TEST: multiple livepatches ... ok TEST: atomic replace livepatch ... ok TEST: klp-convert symbols ... ok There may be more ppc64le specifics lurking, but if we could get samples and self-tests working, I think we'd be in good shape for v3. -- Joe