Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp585608pxb; Wed, 27 Jan 2021 15:55:08 -0800 (PST) X-Google-Smtp-Source: ABdhPJw41ARWjtwDDRmAUJ59qtPTr+x6mTTvkx9Dd/uqwoj3Wgwq1ELJH6d1eFjKoi3QwGT3/I84 X-Received: by 2002:a17:906:44a:: with SMTP id e10mr8360987eja.265.1611791708508; Wed, 27 Jan 2021 15:55:08 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1611791708; cv=none; d=google.com; s=arc-20160816; b=vo+PMIBBWtEe5GXE8l6NB4gi1FA/AkotRblI5NybIn65ZNje6eMMbzros5wTfbiynw 4fY2oHL8JdOfM0zmmiWZeJwISc04a63kSRU1H4pKY6fCv+oV14nY+TF5dgGq0UFE7Sia z5BkSqtvTw00vIFl/z6LXuu4wTZz9MKhVR63u8r4wM8Eeq103gFr64KHsN5JXpryPHDa zDKixvr78+w8lpJ4KN6FaKVJVkwewbtWL4qGA3gQ203jE474RLk7TLQIIRqx4xTwKkge G09kOvt2A/m/MYO+SR5dzO9AIkiRyHEpdE92W+WvaEJt5owP444+QwwhWtSfLg4eXLAM Q4sA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=lwuc+jSkD82sotlNHJidx8xja/Bw1JYQcR061EVrMxA=; b=r/Mynj+Q6LT/bsiNfDdP1bJ+e9raY/gksV5u2cdhPsslv5vpVAVKSsCEN7ATzAGEnR SL7HHLddjVJ/VBn/tkxG6MhDcAylQ/OXWh68y3SB7Me6in94MeEAxFw/s5tsNri9R2bQ IgW+y/ivZnrD6aJ3M+ugNGWR4vO7UVxYfs2I9+ED5z+EqwA2Ap/I2ZMfOMicJ2dICHSp P2uML/TLCj8+zHluhBnVtubYoXBIdSf9p9iaC9FfihSTC9LExCNbf2wgsMI68lfrNZUB yRU/mD6fDoh2uYNytRDnjz0yUhus7NCk/rhhTcTcituGxTy56pl1bf79RJlK1uSf7DDp vEcQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@suse.com header.s=susede1 header.b=VqvtxSgm; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=suse.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y5si1867554eds.374.2021.01.27.15.54.44; Wed, 27 Jan 2021 15:55:08 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@suse.com header.s=susede1 header.b=VqvtxSgm; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=suse.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236673AbhA0L6a (ORCPT + 99 others); Wed, 27 Jan 2021 06:58:30 -0500 Received: from mx2.suse.de ([195.135.220.15]:34026 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236685AbhA0L4A (ORCPT ); Wed, 27 Jan 2021 06:56:00 -0500 X-Virus-Scanned: by amavisd-new at test-mx.suse.de DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.com; s=susede1; t=1611748514; h=from:from:reply-to:date:date:message-id:message-id:to:to:cc:cc: mime-version:mime-version:content-type:content-type: in-reply-to:in-reply-to:references:references; bh=lwuc+jSkD82sotlNHJidx8xja/Bw1JYQcR061EVrMxA=; b=VqvtxSgmJ5cfSryecsAWZnhhs5uilRcndo5u4Gvp2ENukoxoKJsr+mTPjc4n9b02HE5zd2 tNiYkZOsfUa2IE/eO+Ngsze83nqq8S0L9O25uNbLapCDnMcbQVY3lblEQhhKn8OhgSez7d hI+RKBYuVTq7jTQ+3zuaVTVbMniYl0A= Received: from relay2.suse.de (unknown [195.135.221.27]) by mx2.suse.de (Postfix) with ESMTP id 6B807AD2B; Wed, 27 Jan 2021 11:55:14 +0000 (UTC) Date: Wed, 27 Jan 2021 12:55:13 +0100 From: Petr Mladek To: Jessica Yu Cc: Christoph Hellwig , Frederic Barrat , Andrew Donnellan , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Daniel Vetter , Josh Poimboeuf , Jiri Kosina , Miroslav Benes , Joe Lawrence , Masahiro Yamada , Michal Marek , linux-kernel@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, dri-devel@lists.freedesktop.org, live-patching@vger.kernel.org, linux-kbuild@vger.kernel.org Subject: Re: [PATCH 04/13] livepatch: move klp_find_object_module to module.c Message-ID: References: <20210121074959.313333-1-hch@lst.de> <20210121074959.313333-5-hch@lst.de> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue 2021-01-26 15:25:16, Jessica Yu wrote: > +++ Christoph Hellwig [21/01/21 08:49 +0100]: > > To uncouple the livepatch code from module loader internals move a > > slightly refactored version of klp_find_object_module to module.c > > This allows to mark find_module static and removes one of the last > > users of module_mutex outside of module.c. > > > > Signed-off-by: Christoph Hellwig > > --- > > include/linux/module.h | 3 +-- > > kernel/livepatch/core.c | 39 +++++++++++++-------------------------- > > kernel/module.c | 17 ++++++++++++++++- > > 3 files changed, 30 insertions(+), 29 deletions(-) > > > > diff --git a/include/linux/module.h b/include/linux/module.h > > index b4654f8a408134..8588482bde4116 100644 > > --- a/include/linux/module.h > > +++ b/include/linux/module.h > > @@ -586,8 +586,7 @@ static inline bool within_module(unsigned long addr, const struct module *mod) > > return within_module_init(addr, mod) || within_module_core(addr, mod); > > } > > > > -/* Search for module by name: must hold module_mutex. */ > > -struct module *find_module(const char *name); > > +struct module *find_klp_module(const char *name); > > > > /* Check if a module is loaded. */ > > bool module_loaded(const char *name); > > diff --git a/kernel/livepatch/core.c b/kernel/livepatch/core.c > > index a7f625dc24add3..878759baadd81c 100644 > > --- a/kernel/livepatch/core.c > > +++ b/kernel/livepatch/core.c > > @@ -49,30 +49,6 @@ static bool klp_is_module(struct klp_object *obj) > > return obj->name; > > } > > > > -/* sets obj->mod if object is not vmlinux and module is found */ > > -static void klp_find_object_module(struct klp_object *obj) > > -{ > > - struct module *mod; > > - > > - mutex_lock(&module_mutex); > > - /* > > - * We do not want to block removal of patched modules and therefore > > - * we do not take a reference here. The patches are removed by > > - * klp_module_going() instead. > > - */ > > - mod = find_module(obj->name); > > - /* > > - * Do not mess work of klp_module_coming() and klp_module_going(). > > - * Note that the patch might still be needed before klp_module_going() > > - * is called. Module functions can be called even in the GOING state > > - * until mod->exit() finishes. This is especially important for > > - * patches that modify semantic of the functions. > > - */ > > - if (mod && mod->klp_alive) > > - obj->mod = mod; > > - mutex_unlock(&module_mutex); > > -} > > Hmm, I am not a huge fan of moving more livepatch code into module.c, I > wonder if we can keep them separate. > > Why not have module_is_loaded() kill two birds with one stone? That > is, just have it return a module pointer to signify that the module is > loaded, NULL if not. Then we don't need an extra find_klp_module() > function just to call find_module() and return a pointer, as > module_is_loaded() can just do that for us. > > As for the mod->klp_alive check, I believe this function > (klp_find_object_module()) is called with klp_mutex held, and > mod->klp_alive is only modified under klp_mutex. Also, if klp_alive is > true, the module is at least COMING and cannot be GOING until it > acquires the klp_mutex again in klp_module_going(). So does that hunk > really need to be under module_mutex? It has been a long time since > I've looked at livepatch code so it would be great if someone could > double check. We need to make sure that the module is not freed before we manipulate mod->klp_alive. One solution would be to take the reference and block it during this operation. Alternatively it might be to rely on RCU. It seems that the struct is protected by RCU because of kallsyms. But I am not sure if it is safe in all module states. But it should be. We find the module via the same list like kallsyms. Best Regards, Petr