Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2812454imu; Mon, 17 Dec 2018 08:12:50 -0800 (PST) X-Google-Smtp-Source: AFSGD/X5uB56xHVPndzjYTybLtVnQKll17t9GtxQAWNHVJepRTKqaaSbsKpMJ1oCMe600z2Bn0Gn X-Received: by 2002:a17:902:1127:: with SMTP id d36mr12769968pla.299.1545063170518; Mon, 17 Dec 2018 08:12:50 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1545063170; cv=none; d=google.com; s=arc-20160816; b=KvXUE9r4d/7MdNC2v8F/l6XLwGl5TbzXbLHktIEZNyYX//f8RkTHVCKjqogiVBNnYC riLjlx6njfGn2NLY/GQV+SpChOC+Kx5V5ew24kO/aW6axOscO7q+g1KGojYOvEF/H+tX zufresHahzX/68R+nj/xPvRMMr0n5QKj/hl1/nSgpji+Dm2OsqMKO3bZYY6rwu5MgagC rlH0ERyd51O070KfOCh1QiDclgpmkROkrSIMMtbMFCWsT+SZXNlxRM/JWmDpspWzvKVv vszo8qKS9F+obpCPJoWDqmceFlBCmxdCyOXouAxNpnelq/XS0XsfhfKywK0UwTd5dM05 2grA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=WGqOss16gbbyiNqBsbAkAGTvqKml8ASLI6m2ToPaFq8=; b=Jw97vSZaet/8qFMmHlP+0fkISLOOP3+hS0Qt1HMYPJDr8WiOx0ITn8fewXYeYwHjGA QtesZ0DpEh0M/oL132hm8bfRAPNysdN9JX4onh6EbWaDMpZT+ua54OCQs1KKj8Cn48t5 8WV8fAf0JzSK/mxNFpdEg0iI75ROGwTt5uu0NbytkiqIRifos6orDjEvIRw8UXHGet8c SFHHDiryCqK8Kat2xpq6QpfKD9+Ij5kc2wg1PVHU4xrU3svpZ3suCB8alb0HdkqFIoh/ vpQFs07jq47ATmqxcJ2JjJJijSSXQrwEkPF2zs7klFGN9ftad289x/v8c0DenJDa+CN9 ArOg== 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 f9si10700594pgc.85.2018.12.17.08.12.35; Mon, 17 Dec 2018 08:12:50 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388255AbeLQQLR (ORCPT + 99 others); Mon, 17 Dec 2018 11:11:17 -0500 Received: from mx1.redhat.com ([209.132.183.28]:36206 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727814AbeLQQLK (ORCPT ); Mon, 17 Dec 2018 11:11:10 -0500 Received: from smtp.corp.redhat.com (int-mx01.intmail.prod.int.phx2.redhat.com [10.5.11.11]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 1919BC0495BF; Mon, 17 Dec 2018 16:11:10 +0000 (UTC) Received: from treble (ovpn-120-179.rdu2.redhat.com [10.10.120.179]) by smtp.corp.redhat.com (Postfix) with ESMTPS id 2E9496012B; Mon, 17 Dec 2018 16:11:06 +0000 (UTC) Date: Mon, 17 Dec 2018 10:11:04 -0600 From: Josh Poimboeuf To: Petr Mladek Cc: Jiri Kosina , Miroslav Benes , Jason Baron , Joe Lawrence , Evgenii Shatokhin , live-patching@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v14 08/11] livepatch: Remove Nop structures when unused Message-ID: <20181217161104.bc4jkklw35svcaqy@treble> References: <20181129094431.7801-1-pmladek@suse.com> <20181129094431.7801-9-pmladek@suse.com> <20181213230045.2xgi2pyewkjbou22@treble> <20181217155453.nr34ooxmriik2cln@pathway.suse.cz> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20181217155453.nr34ooxmriik2cln@pathway.suse.cz> User-Agent: NeoMutt/20180716 X-Scanned-By: MIMEDefang 2.79 on 10.5.11.11 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.31]); Mon, 17 Dec 2018 16:11:10 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, Dec 17, 2018 at 04:54:53PM +0100, Petr Mladek wrote: > On Thu 2018-12-13 17:00:45, Josh Poimboeuf wrote: > > On Thu, Nov 29, 2018 at 10:44:28AM +0100, Petr Mladek wrote: > > > +static void __klp_free_funcs(struct klp_object *obj, bool free_all) > > > { > > > - struct klp_func *func; > > > + struct klp_func *func, *tmp_func; > > > + > > > + klp_for_each_func_safe(obj, func, tmp_func) { > > > + if (!free_all && !func->nop) > > > + continue; > > > > I suspect that changing 'free_all" to 'nops_only' (and inverting the > > condition) would make the code more readable. > > > > And a similar suggestion for __klp_free_objects(). > > I am not super happy with the negative check as well. The problem is > that in __klp_free_objects() it would look like: > > if (nops_only && !obj->dynamic) > continue; > > By other words, "free_all" works better with both "nops" and "dynamic". > > That said, I do not mind about it. Tell me what you prefer and I'll > change it. The problem I had with 'free_all' was that it's vague: For a reader of the code, freeing all would be the expected case, so it's not necessarily clear what *not* freeing all would mean. Using 'nops_only' makes the meaning of !all explicit. Even for the __klp_free_objects() case, I think it's an improvement, though you could maybe call it 'dynamic_only' or 'dyn_only' instead (any of those options would be fine with me). -- Josh