Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751012AbdFSQ4k (ORCPT ); Mon, 19 Jun 2017 12:56:40 -0400 Received: from mx2.suse.de ([195.135.220.15]:56373 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1750863AbdFSQ4j (ORCPT ); Mon, 19 Jun 2017 12:56:39 -0400 Date: Mon, 19 Jun 2017 18:56:37 +0200 (CEST) From: Miroslav Benes To: Josh Poimboeuf cc: Petr Mladek , Joe Lawrence , live-patching@vger.kernel.org, linux-kernel@vger.kernel.org, Jessica Yu , Jiri Kosina Subject: Re: [PATCH 3/3] livepatch: add shadow variable sample program In-Reply-To: <20170615134927.n53bn3ckizi6anhi@treble> Message-ID: References: <1496341526-19061-1-git-send-email-joe.lawrence@redhat.com> <1496341526-19061-4-git-send-email-joe.lawrence@redhat.com> <20170614142102.GA2583@pathway.suse.cz> <20170614145756.gom3zf6uv7ua423h@treble> <20170615105943.GE15013@pathway.suse.cz> <20170615134927.n53bn3ckizi6anhi@treble> User-Agent: Alpine 2.20 (LSU 67 2015-01-07) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1460 Lines: 30 > > > I often wonder whether it's really a good idea to even allow the > > > unloading of patch modules at all. It adds complexity to the livepatch > > > code. Is it worth it? I don't have an answer but I'd be interested in > > > other people's opinion. > > > > I could imagine a situation when a livepatch causes, for example, > > performance, problems on a server because of the redirection > > to the new code. Then it might be handy to disable the patch > > and ftrace handlers completely. > > Fair enough, though it sounds theoretical. It would be good to know > we're supporting actual real world use cases. We distribute cumulative "replace_all" patches at SUSE. replace_all means that all previous patches are reverted in the process of application. All livepatch modules with zero refcount are removed. This keeps a number of loaded modules low and system's state well defined, which is always a good thing, because a customer might run into problems and we'd have to debug it. It is true that it is a limitation too. Especially for state changes and data structure modifications. Sometimes it is easy to patch a system, but impossible to unpatch it. Because we don't have a consistency on a state level, only on a task/process level. But I perceive this also as an advantage. I have to always know what a livepatch does exactly and I discovered couple of problems just because I had to think about unloading of modules. Miroslav