Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp638644img; Fri, 22 Mar 2019 05:41:10 -0700 (PDT) X-Google-Smtp-Source: APXvYqxiFMPrOCuM+HlX8E6H5pHSQUwcud5AGc5CoR/ERHenJDNrIvr2cNHhBjdRIgZQouMtMOq8 X-Received: by 2002:a63:1960:: with SMTP id 32mr8683161pgz.171.1553258470738; Fri, 22 Mar 2019 05:41:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1553258470; cv=none; d=google.com; s=arc-20160816; b=Qz8yn4UiIJU8eEBtVYyowk2rrixOu5sJu1uRZ6vu9QSeXtxB5Znhnwb/8ZcHMlgdvv NYPQBeMYu47gPZIsXZLd2cO3RiHM6zO8DzAjBL8FoetjBXXdnuyJdf0tvtoZQHChIbPn m++3ipdFLIswitM0AtiqpxvTBONxYylhxU2O2J1jKyjGp80EAYGnTCtPZlTXbDBUiBhm 3Ls6TZ+f4GZsu0FA7tb/pE2dUWIygCC8/KJd7xI677h9dvsV2+jIqlM928uMa2STUV4K 8vwqYMukmWqCOep8NzZKKbB8D76MI3/K25P2+Hs0XbdjABclDhQvPEod1x15HFCDNOmK L9Mw== 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=7NzkRx3YwvYh7MyzkQaomhPSvbvEipBN1Wm7sx2qf8I=; b=ApIWTvJQJ/pfuzg3oX6JyFkqt9E/AbvZM1+WrHbXCZaZDhhHm/yiPOHwaU3i/n0Ok2 0x6N8PSqYYu8trILFkH73HLmWbOFxLmDTr7oF0sK/vRSyrIKM/9uCwmwY1PAQVFmndgE xsNb89ybMyKk7LKVHxM95IoEsGVlpnAT/lI0bRQBcm6c7EZsFFv/OIPjKzM6XFbBZUP5 uYNr/BI8XxzQWGrpgcUgn0JnzAeEbvY8MMdtZw4I4QUdfYON847BG3b2X6t79R9OpiES ojLRU++14fPh8M5c+q23swVNCMul4xitLUeIYm4aTwAFZlwg6VuBSLBXnL6Hz6mD8NUa 35eA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=O4Nl+wmJ; 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 d195si6885395pga.309.2019.03.22.05.40.53; Fri, 22 Mar 2019 05:41:10 -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=O4Nl+wmJ; 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 S2388947AbfCVMIg (ORCPT + 99 others); Fri, 22 Mar 2019 08:08:36 -0400 Received: from mail.kernel.org ([198.145.29.99]:46930 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388269AbfCVMId (ORCPT ); Fri, 22 Mar 2019 08:08:33 -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 5A9CD2082C; Fri, 22 Mar 2019 12:08:31 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1553256511; bh=1htCl6tD3KSwtXjsV0pIkzTDPx2MxGeGSbjIXuH375w=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=O4Nl+wmJuuthYuwhH7YZRvZwayViKEfIsqNmi2a/yqd72D7G8silnN9Vv2bwEn26X ZlcWIH3GdnPMkSSRxBRZO7tec65jMEDBzY0iaQgK/9Aph1wUofJaNmcRZP9YupV0Vt HZufO2ODbIruJwDXNzhvQ9gdEhvycTVTc49MnkJs= 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 4.19 233/280] arm64: debug: Ensure debug handlers check triggering exception level Date: Fri, 22 Mar 2019 12:16:26 +0100 Message-Id: <20190322111337.674610361@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190322111306.356185024@linuxfoundation.org> References: <20190322111306.356185024@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 4.19-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; }