Received: by 2002:a25:ab43:0:0:0:0:0 with SMTP id u61csp4472980ybi; Tue, 11 Jun 2019 07:14:05 -0700 (PDT) X-Google-Smtp-Source: APXvYqzPSLwBOlvLSGPOhU/M8M6e4eCypqb+5ybwxEEquw0G9rUWnwfIDkn7FYQSWhE5CpKWKqh8 X-Received: by 2002:a17:902:aa0a:: with SMTP id be10mr74266058plb.293.1560262445155; Tue, 11 Jun 2019 07:14:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1560262445; cv=none; d=google.com; s=arc-20160816; b=cQ9YDv812a1rp+/4XAJEY6BGiGy0rUN3nzlpj6RDq9rAx7Y00w/gXPqnXI9qYuzrU7 5du6zeWUBG8lfIQmwrsLJCJ+UyOZ6LdjrMrIt/1RMHpddkA04a0KKk31VWcm1fHfcwxW lr7uSua07fjrvDIn31cd5syiowmeWutli3lAPeJmwm6MNJDxksTN2bOOmKG2VAsMahyv fefGb6+gdbCvOA0Yl0+C56tv6bk97iUXsYEFfmdgE9mY3yM3MUdC8SjjO5KI4TsFCKz2 ovYWz8X4YQrf//kqBfBhhY38/zLjZ/5qsfy36KYrfAtJb1j2GnPRGzWIgaujXllXW192 dmFQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=3W15ekCH1B2VP6VfjpN019tRdYhBGtOcUejLsRlFiFU=; b=cCNkJJiJoyu4zv6lZp6gbsrdlRrhALUzvxicBzK69UPlPIi5FpI814wbdyMy2goBf3 ED9Yc9rkw5TeF0VlWT23lQe0Zzpfdth2FL1WmYbh59Tf1768YS0oZ7AeVtO2/8GTw1ty Je5IwHpacbMGjA1HBBdmGOMoMBUdz7CaF10NRApz+5dhinXnmbINxAZ8e3z+V3xUy+/k 3sWdcyRDEAKDSBBKYnh/qFkr9CQlpWyAk4q8Zsh+E9CdP6Gvt6U2W+TYe0B1IbQ49khw oUSyl061yZKqDUk2QVsXbL6jFIzlvmyFmOVjW/0agS1Eei7F4tq8E8B7IeLt2LmtL028 d9YA== 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 o20si2418178pjp.48.2019.06.11.07.13.48; Tue, 11 Jun 2019 07:14:05 -0700 (PDT) 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 S2389798AbfFKON1 (ORCPT + 99 others); Tue, 11 Jun 2019 10:13:27 -0400 Received: from mx2.suse.de ([195.135.220.15]:44164 "EHLO mx1.suse.de" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S2387447AbfFKON1 (ORCPT ); Tue, 11 Jun 2019 10:13:27 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.220.254]) by mx1.suse.de (Postfix) with ESMTP id C3F52AF1F; Tue, 11 Jun 2019 14:13:25 +0000 (UTC) From: Miroslav Benes To: jpoimboe@redhat.com, jikos@kernel.org, pmladek@suse.com Cc: joe.lawrence@redhat.com, kamalesh@linux.vnet.ibm.com, live-patching@vger.kernel.org, linux-kernel@vger.kernel.org, Miroslav Benes Subject: [PATCH v4 2/3] Revert "livepatch: Remove reliable stacktrace check in klp_try_switch_task()" Date: Tue, 11 Jun 2019 16:13:19 +0200 Message-Id: <20190611141320.25359-3-mbenes@suse.cz> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190611141320.25359-1-mbenes@suse.cz> References: <20190611141320.25359-1-mbenes@suse.cz> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This reverts commit 1d98a69e5cef3aeb68bcefab0e67e342d6bb4dad. Commit 31adf2308f33 ("livepatch: Convert error about unsupported reliable stacktrace into a warning") weakened the enforcement for architectures to have reliable stack traces support. The system only warns now about it. It only makes sense to reintroduce the compile time checking in klp_try_switch_task() again and bail out early. Signed-off-by: Miroslav Benes --- kernel/livepatch/transition.c | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/kernel/livepatch/transition.c b/kernel/livepatch/transition.c index 8e8c79d4b204..7e7ef04689d1 100644 --- a/kernel/livepatch/transition.c +++ b/kernel/livepatch/transition.c @@ -293,6 +293,13 @@ static bool klp_try_switch_task(struct task_struct *task) if (task->patch_state == klp_target_state) return true; + /* + * For arches which don't have reliable stack traces, we have to rely + * on other methods (e.g., switching tasks at kernel exit). + */ + if (!klp_have_reliable_stack()) + return false; + /* * Now try to check the stack for any to-be-patched or to-be-unpatched * functions. If all goes well, switch the task to the target patch -- 2.21.0