Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753240AbbKJOH0 (ORCPT ); Tue, 10 Nov 2015 09:07:26 -0500 Received: from mx1.redhat.com ([209.132.183.28]:55264 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752441AbbKJOHZ (ORCPT ); Tue, 10 Nov 2015 09:07:25 -0500 Date: Tue, 10 Nov 2015 08:07:21 -0600 From: Josh Poimboeuf To: Zhou Chengming Cc: sjenning@redhat.com, jkosina@suse.cz, vojtech@suse.cz, live-patching@vger.kernel.org, linux-kernel@vger.kernel.org, guohanjun@huawei.com, huawei.libin@huawei.com, xiexiuqi@huawei.com, cbay@alwaysdata.com Subject: Re: [PATCH v2] livepatch: x86: bugfix about kASLR Message-ID: <20151110140721.GC3163@treble.redhat.com> References: <1446791100-41585-1-git-send-email-zhouchengming1@huawei.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <1446791100-41585-1-git-send-email-zhouchengming1@huawei.com> User-Agent: Mutt/1.5.23.1-rc1 (2014-03-12) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1735 Lines: 48 On Fri, Nov 06, 2015 at 02:25:00PM +0800, Zhou Chengming wrote: > When enable KASLR, livepatch will adjust old_addr of changed > function accordingly. So do the same thing for reloc. > > [PATCH v1] https://lkml.org/lkml/2015/11/4/91 > > Reported-by: Cyril B. > Signed-off-by: Zhou Chengming > --- > kernel/livepatch/core.c | 6 ++++++ > 1 files changed, 6 insertions(+), 0 deletions(-) > > diff --git a/kernel/livepatch/core.c b/kernel/livepatch/core.c > index 6e53441..db545cb 100644 > --- a/kernel/livepatch/core.c > +++ b/kernel/livepatch/core.c > @@ -294,6 +294,12 @@ static int klp_write_object_relocations(struct module *pmod, > > for (reloc = obj->relocs; reloc->name; reloc++) { > if (!klp_is_module(obj)) { > + > +#if defined(CONFIG_RANDOMIZE_BASE) > + /* If KASLR has been enabled, adjust old value accordingly */ > + if (kaslr_enabled()) > + reloc->val += kaslr_offset(); > +#endif > ret = klp_verify_vmlinux_symbol(reloc->name, > reloc->val); > if (ret) Zhou, thanks a lot for this fix. Generally I think this patch is fine. However, Chris J Arges is working on another patch[*] which may get rid of reloc->val as an input and make this patch obsolete. So, assuming Chris's patch eventually gets accepted, I don't see a need for this one unless anybody wants it as a bug fix for 4.4. [*] https://lkml.kernel.org/r/1447085770-11729-1-git-send-email-chris.j.arges@canonical.com -- Josh -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/