Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp622912img; Fri, 22 Mar 2019 05:21:35 -0700 (PDT) X-Google-Smtp-Source: APXvYqxJg+yGe578PsKWbXZwXj+sijaioo+gkN3Dq3FyzUZlB1tQp7nKkU9WbX8jnXvs4WBMm8uj X-Received: by 2002:a63:5458:: with SMTP id e24mr5028554pgm.132.1553257295007; Fri, 22 Mar 2019 05:21:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553257295; cv=none; d=google.com; s=arc-20160816; b=KqLTItEfwjBL0Lh1Jmpdu48E6XUsrhTYFFGZ0B+zoHzqZwlL/7C3n56CJ2Dsb1TLgF 6T7I9q/z+Nj91H/hKHn1My8KKYwnvkSgI3scP1kcO4b2b3wlJvWju7TlfJButLWFvbIj AP7qVXQzkZNoub2c2e4X1wVUyx+kK5aNU803ApwAPPPYyRK78lgE49jvq2I1eD7dorw4 bx/qoCsRX7pyRm06nwi4lqJ28Ne+32rkPYbHIo7McGaOCP4kfh8Y2FRlIwVc4W2ME98D fuBcqKWRJh0GlIWiSUB1XyFhl4cp3gnPxd48KCnMStbNjH54ac3Io8IKz3qewJyEpZ1H PCng== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=aRJkJQUNRXwKvh/TxWXvAjV6SBkdTbBtXuXMVljIJQA=; b=YEr5/LXVb8jcl+KLEni1fJhq+WkzzFFk1kIndVOd2fGy6qevyce2H2d4dAPSbVVrH1 aYIzWpHiuJ4sXEZcYozr0IaDUQLuv4mT6MNZnJdUGMlSGt34ywXqT6rdTtwtOMwepZwK dsqXs6A6CPlCpMgKTerR6uqAmqbq17Dl+F7Ll5uRNPL9ncRSvZqzbDChVdnk9nRIJiG6 0cH5S6YTxKF1OcCDmMX4eWm/803JXkTPEF2m67YR/NwWdD1L+YF0AOcIUzYTDL3d7Ai0 11KDb0PTOGsIxLhNN05PQx6fWs+yeMIX4kbMtfy7qSqymo83n36OrHwpYw2I+ivFWURz lvIg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=bkTLGMnt; 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 b13si5185621pgl.331.2019.03.22.05.21.19; Fri, 22 Mar 2019 05:21:34 -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; dkim=pass header.i=@kernel.org header.s=default header.b=bkTLGMnt; 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 S2390761AbfCVMUq (ORCPT + 99 others); Fri, 22 Mar 2019 08:20:46 -0400 Received: from mail.kernel.org ([198.145.29.99]:59648 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2390357AbfCVMUk (ORCPT ); Fri, 22 Mar 2019 08:20:40 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id D7C9721900; Fri, 22 Mar 2019 12:20:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1553257239; bh=aAX9lWY15Bj/CWUbhU40+2+I7Ln3B3FE/jNNNWr+9sc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=bkTLGMntzTuqzM/KFWBhwDX8kHYAO06o8TP1weifntbIOmCmFpV93CYasIVOnzxNG kxt3aECF+njo4195zZhM5QQY/c78+TBajOo0QFmaVUUv3cY/VRWzLpU/eXoA25y+Nj xwpJGlnj+X1eQYX7qqbFIyXImw/bpB1B+nmNuU+g= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Mark Rutland , Will Deacon , Catalin Marinas Subject: [PATCH 5.0 173/238] arm64: debug: Ensure debug handlers check triggering exception level Date: Fri, 22 Mar 2019 12:16:32 +0100 Message-Id: <20190322111308.489770309@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190322111258.383569278@linuxfoundation.org> References: <20190322111258.383569278@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 5.0-stable review patch. If anyone has any objections, please let me know. ------------------ From: Will Deacon commit 6bd288569b50bc89fa5513031086746968f585cb upstream. Debug exception handlers may be called for exceptions generated both by user and kernel code. In many cases, this is checked explicitly, but in other cases things either happen to work by happy accident or they go slightly wrong. For example, executing 'brk #4' from userspace will enter the kprobes code and be ignored, but the instruction will be retried forever in userspace instead of delivering a SIGTRAP. Fix this issue in the most stable-friendly fashion by simply adding explicit checks of the triggering exception level to all of our debug exception handlers. Cc: Reviewed-by: Mark Rutland Signed-off-by: Will Deacon Signed-off-by: Catalin Marinas Signed-off-by: Greg Kroah-Hartman --- arch/arm64/kernel/kgdb.c | 14 ++++++++++---- arch/arm64/kernel/probes/kprobes.c | 6 ++++++ 2 files changed, 16 insertions(+), 4 deletions(-) --- a/arch/arm64/kernel/kgdb.c +++ b/arch/arm64/kernel/kgdb.c @@ -244,27 +244,33 @@ int kgdb_arch_handle_exception(int excep static int kgdb_brk_fn(struct pt_regs *regs, unsigned int esr) { + if (user_mode(regs)) + return DBG_HOOK_ERROR; + kgdb_handle_exception(1, SIGTRAP, 0, regs); - return 0; + return DBG_HOOK_HANDLED; } NOKPROBE_SYMBOL(kgdb_brk_fn) static int kgdb_compiled_brk_fn(struct pt_regs *regs, unsigned int esr) { + if (user_mode(regs)) + return DBG_HOOK_ERROR; + compiled_break = 1; kgdb_handle_exception(1, SIGTRAP, 0, regs); - return 0; + return DBG_HOOK_HANDLED; } NOKPROBE_SYMBOL(kgdb_compiled_brk_fn); static int kgdb_step_brk_fn(struct pt_regs *regs, unsigned int esr) { - if (!kgdb_single_step) + if (user_mode(regs) || !kgdb_single_step) return DBG_HOOK_ERROR; kgdb_handle_exception(1, SIGTRAP, 0, regs); - return 0; + return DBG_HOOK_HANDLED; } NOKPROBE_SYMBOL(kgdb_step_brk_fn); --- a/arch/arm64/kernel/probes/kprobes.c +++ b/arch/arm64/kernel/probes/kprobes.c @@ -450,6 +450,9 @@ kprobe_single_step_handler(struct pt_reg struct kprobe_ctlblk *kcb = get_kprobe_ctlblk(); int retval; + if (user_mode(regs)) + return DBG_HOOK_ERROR; + /* return error if this is not our step */ retval = kprobe_ss_hit(kcb, instruction_pointer(regs)); @@ -466,6 +469,9 @@ kprobe_single_step_handler(struct pt_reg int __kprobes kprobe_breakpoint_handler(struct pt_regs *regs, unsigned int esr) { + if (user_mode(regs)) + return DBG_HOOK_ERROR; + kprobe_handler(regs); return DBG_HOOK_HANDLED; }