Received: by 10.223.176.5 with SMTP id f5csp498834wra; Tue, 6 Feb 2018 02:36:08 -0800 (PST) X-Google-Smtp-Source: AH8x227xbgASbVeZgX4XjUVmta3kiewRa9IQEFMBpBCSfTEL1E2/8gpLDgtlOio2Qvf75+ENnmEp X-Received: by 10.98.9.67 with SMTP id e64mr1948572pfd.230.1517913368649; Tue, 06 Feb 2018 02:36:08 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1517913368; cv=none; d=google.com; s=arc-20160816; b=xdfi3n7nonmRPi28mm7hNMbSw40L5HgWbI3GqMNbCZbdNc1dsNB/wMCbOQ8qU4Qk+7 GeoKuvUfwAiHZiB0GkyNiR7R7Hg5D2YNzSGBfL+Z/5u33JwVyi7W0A/aeQ25Rjzs83SJ jG54wehnPLipWgdli9jGQlY+u/GGA1a+1+CKMLMs3X/MHoYs2vMjP1fLcu9BxE70NETs 6ApiFTvul3U+pj1lNPoIHqbv/xj4C2ZRtAyqY0kfse5p8oMRIm9SR0TgEQyiXYU+3Mrt jtvOkmmNsYTHRrZbqK3jfsgG67mHTUlI7f8ZMTdJcfopPO7tegFPI8sIwajieL9Npmgz 81QQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=aIC75K84K/48xDvcwgHGPcZUK9QiNQegWZI4u/abkWU=; b=Vj6fSviXKIlrwXlPg0W1d1p0hICZAUkeW6pA7fNfx4As0WuTRGSXJ6Ormh4Y9FNjGX uXHzyvzrM2I3akROQA72XR8ujpYllNIzSHrx/MucLBvw3nIld4PwfGgyXkT6CTo24d7A buWtYbLNpE+kJvQDRxDTDUVE3D8xr2XkRmA+CHWXG5UMJSiOc03j67iWBebZK5kCf5gA 1tc1xTLfwAzsCGkkz3FddvEj2KTTf3l/ZkGNtRZ5ZI+2iBaDaI6Lo8u7fnv3F2ysX4gK 2BIIyRNs5EgTkXlrQuP65rkaR9NVQfJJ1BW1dZF/sBB3PIjoMaeDX3IJhrodoar9eEMu BxiA== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id c20si8444880pfk.415.2018.02.06.02.35.54; Tue, 06 Feb 2018 02:36:08 -0800 (PST) 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752847AbeBFKfI (ORCPT + 99 others); Tue, 6 Feb 2018 05:35:08 -0500 Received: from mx2.suse.de ([195.135.220.15]:59956 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752795AbeBFKes (ORCPT ); Tue, 6 Feb 2018 05:34:48 -0500 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (charybdis-ext.suse.de [195.135.220.254]) by mx2.suse.de (Postfix) with ESMTP id 85198AE3A; Tue, 6 Feb 2018 10:34:46 +0000 (UTC) From: Petr Mladek To: Jiri Kosina , Josh Poimboeuf , Miroslav Benes Cc: Jason Baron , Joe Lawrence , Jessica Yu , Evgenii Shatokhin , live-patching@vger.kernel.org, linux-kernel@vger.kernel.org, Petr Mladek Subject: [PATCH v7 2/7] livepatch: Free only structures with initialized kobject Date: Tue, 6 Feb 2018 11:34:19 +0100 Message-Id: <20180206103424.10829-3-pmladek@suse.com> X-Mailer: git-send-email 2.13.6 In-Reply-To: <20180206103424.10829-1-pmladek@suse.com> References: <20180206103424.10829-1-pmladek@suse.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org We are going to add a feature called atomic replace. It will allow to create a patch that would replace all already registered patches. For this, we will need to dynamically create funcs and objects for functions that are not longer patched. We will want to reuse the existing init() and free() functions. Up to now, the free() functions checked a limit and were called only for structures with initialized kobject. But we will want to call them also for structures that were allocated but where the kobject was not initialized yet. This patch removes the limit. It calls klp_free*() functions for all structures. But only the ones with initialized kobject are freed. The handling of un-initialized structures will be added later with the support for dynamic structures. This patch does not change the existing behavior. Signed-off-by: Petr Mladek Cc: Josh Poimboeuf Cc: Jessica Yu Cc: Jiri Kosina Cc: Miroslav Benes Cc: Jason Baron --- kernel/livepatch/core.c | 42 ++++++++++++++++++++---------------------- 1 file changed, 20 insertions(+), 22 deletions(-) diff --git a/kernel/livepatch/core.c b/kernel/livepatch/core.c index 1d525f4a270a..ef7c3b5f561b 100644 --- a/kernel/livepatch/core.c +++ b/kernel/livepatch/core.c @@ -654,16 +654,17 @@ static struct kobj_type klp_ktype_func = { }; /* - * Free all functions' kobjects in the array up to some limit. When limit is - * NULL, all kobjects are freed. + * Free all funcs that have the kobject initialized. Otherwise, + * nothing is needed. */ -static void klp_free_funcs_limited(struct klp_object *obj, - struct klp_func *limit) +static void klp_free_funcs(struct klp_object *obj) { struct klp_func *func; - for (func = obj->funcs; func->old_name && func != limit; func++) - kobject_put(&func->kobj); + klp_for_each_func(obj, func) { + if (func->kobj.state_initialized) + kobject_put(&func->kobj); + } } /* Clean up when a patched object is unloaded */ @@ -678,23 +679,25 @@ static void klp_free_object_loaded(struct klp_object *obj) } /* - * Free all objects' kobjects in the array up to some limit. When limit is - * NULL, all kobjects are freed. + * Free all funcs and objects that have the kobject initialized. + * Otherwise, nothing is needed. */ -static void klp_free_objects_limited(struct klp_patch *patch, - struct klp_object *limit) +static void klp_free_objects(struct klp_patch *patch) { struct klp_object *obj; - for (obj = patch->objs; obj->funcs && obj != limit; obj++) { - klp_free_funcs_limited(obj, NULL); - kobject_put(&obj->kobj); + klp_for_each_object(patch, obj) { + klp_free_funcs(obj); + + if (obj->kobj.state_initialized) + kobject_put(&obj->kobj); } } static void klp_free_patch(struct klp_patch *patch) { - klp_free_objects_limited(patch, NULL); + klp_free_objects(patch); + if (!list_empty(&patch->list)) list_del(&patch->list); } @@ -791,21 +794,16 @@ static int klp_init_object(struct klp_patch *patch, struct klp_object *obj) klp_for_each_func(obj, func) { ret = klp_init_func(obj, func); if (ret) - goto free; + return ret; } if (klp_is_object_loaded(obj)) { ret = klp_init_object_loaded(patch, obj); if (ret) - goto free; + return ret; } return 0; - -free: - klp_free_funcs_limited(obj, func); - kobject_put(&obj->kobj); - return ret; } static int klp_init_patch(struct klp_patch *patch) @@ -842,7 +840,7 @@ static int klp_init_patch(struct klp_patch *patch) return 0; free: - klp_free_objects_limited(patch, obj); + klp_free_objects(patch); mutex_unlock(&klp_mutex); -- 2.13.6