Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp1751327ybl; Sat, 11 Jan 2020 02:05:37 -0800 (PST) X-Google-Smtp-Source: APXvYqy+rBcXFboco6iXyfzM/FNsW12XLvi9y5XvAqzPhQU3aQ2dpb1zFl9YH+bMhga3gYA/uvlQ X-Received: by 2002:a05:6830:18fa:: with SMTP id d26mr1378831otf.305.1578737136961; Sat, 11 Jan 2020 02:05:36 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1578737136; cv=none; d=google.com; s=arc-20160816; b=pGMtwVucRrfBmiyYLZvZgcXsv5rS5d5GoQQM7jVMDDp9uqIb9HBwvfHhnUTUfdIWiv nwCzw4mh7ah9nlmvadsFpXZXqLy9V3MZ3pKLMkawxuKLoewNm7WncUxsiX94Z9f70H7X v0hsPYyiImDu7qBNfqq+IsIUrdAVwYXkrylM7120WxhayHgCtoHULLPN+r8NbWxu/nNb GO6fa7AD4AvtCDfVXw5ib+nqN3GJBrICtCs0oNXbqUATxRVKm9jOs1dSLrRvr00qJHhe g53ZKyeE65GeD7yIUwIYU8piaYjQc2iigWTxhGIdU8zT5ip4Rp25TWNmVLbf8oRmA9+v ybEg== 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=gND8Awh3IDIITsydVk8RETTAeamv9JcuCvWCRfLCZ7U=; b=Y8dz4ObhHt8LUUKJXxXS07FQr+O+OQ4z4LlwBCzBFy4AUao/5ZXT5Kk6MZE48WXFvk reEvW/8BqZLmPD2ch8e40SKffpa8a6uhI8g05xSoizGtpH5bMBNGY0J5xrvp34bZjrdh tcMDAiBmBz0GP2ixaZL/qpG+E23xWsFpzJVX3bFIo4M1WkMKj0zBCaFo/wU1P5cwOVJg e5U5mpS8Z+3gv1srjfkrS/AI80E2kD19Rkq1PCbw9mQW3fbknxZJflVOu588kGxU0ZZQ uG2USweaY+t6vp23CPT4anNn85R+bXOUjpM2x+YIvpxKT+0Ver5oOFtf+0Nm7a0+RjnX HXWA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=bNo43ZaR; 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 h18si3548399otj.114.2020.01.11.02.05.25; Sat, 11 Jan 2020 02:05:36 -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; dkim=pass header.i=@kernel.org header.s=default header.b=bNo43ZaR; 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 S1729529AbgAKKEd (ORCPT + 99 others); Sat, 11 Jan 2020 05:04:33 -0500 Received: from mail.kernel.org ([198.145.29.99]:36874 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728986AbgAKKEb (ORCPT ); Sat, 11 Jan 2020 05:04:31 -0500 Received: from localhost (unknown [62.119.166.9]) (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 057242082E; Sat, 11 Jan 2020 10:04:28 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1578737070; bh=TL7wiWT41V2lDfq0DQGYxm5qEkBIpbBGApRyJOlvkjY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=bNo43ZaRfWkdW5dztlkZWQQayP0n4t1AiaXwCFroeblwhGR4Q0Sne5lTwu+BSOeSE COZY9mvw3/Ftklh4ssGowt+JbnKk3x8yOxrpOuFQEiaql87DgFSxD34zzii8Wpq3rR 4Cnge7pcVTc+3j/jXf0je5/MjkfLxX4NoVQ1ABK8= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Daniel Axtens , Michael Ellerman , Sasha Levin Subject: [PATCH 4.9 46/91] powerpc/pseries/hvconsole: Fix stack overread via udbg Date: Sat, 11 Jan 2020 10:49:39 +0100 Message-Id: <20200111094902.539942964@linuxfoundation.org> X-Mailer: git-send-email 2.24.1 In-Reply-To: <20200111094844.748507863@linuxfoundation.org> References: <20200111094844.748507863@linuxfoundation.org> User-Agent: quilt/0.66 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 From: Daniel Axtens [ Upstream commit 934bda59f286d0221f1a3ebab7f5156a996cc37d ] While developing KASAN for 64-bit book3s, I hit the following stack over-read. It occurs because the hypercall to put characters onto the terminal takes 2 longs (128 bits/16 bytes) of characters at a time, and so hvc_put_chars() would unconditionally copy 16 bytes from the argument buffer, regardless of supplied length. However, udbg_hvc_putc() can call hvc_put_chars() with a single-byte buffer, leading to the error. ================================================================== BUG: KASAN: stack-out-of-bounds in hvc_put_chars+0xdc/0x110 Read of size 8 at addr c0000000023e7a90 by task swapper/0 CPU: 0 PID: 0 Comm: swapper Not tainted 5.2.0-rc2-next-20190528-02824-g048a6ab4835b #113 Call Trace: dump_stack+0x104/0x154 (unreliable) print_address_description+0xa0/0x30c __kasan_report+0x20c/0x224 kasan_report+0x18/0x30 __asan_report_load8_noabort+0x24/0x40 hvc_put_chars+0xdc/0x110 hvterm_raw_put_chars+0x9c/0x110 udbg_hvc_putc+0x154/0x200 udbg_write+0xf0/0x240 console_unlock+0x868/0xd30 register_console+0x970/0xe90 register_early_udbg_console+0xf8/0x114 setup_arch+0x108/0x790 start_kernel+0x104/0x784 start_here_common+0x1c/0x534 Memory state around the buggy address: c0000000023e7980: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 c0000000023e7a00: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 f1 f1 >c0000000023e7a80: f1 f1 01 f2 f2 f2 00 00 00 00 00 00 00 00 00 00 ^ c0000000023e7b00: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 c0000000023e7b80: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ================================================================== Document that a 16-byte buffer is requred, and provide it in udbg. Signed-off-by: Daniel Axtens Signed-off-by: Michael Ellerman Signed-off-by: Sasha Levin --- arch/powerpc/platforms/pseries/hvconsole.c | 2 +- drivers/tty/hvc/hvc_vio.c | 16 +++++++++++++++- 2 files changed, 16 insertions(+), 2 deletions(-) diff --git a/arch/powerpc/platforms/pseries/hvconsole.c b/arch/powerpc/platforms/pseries/hvconsole.c index 74da18de853a..73ec15cd2708 100644 --- a/arch/powerpc/platforms/pseries/hvconsole.c +++ b/arch/powerpc/platforms/pseries/hvconsole.c @@ -62,7 +62,7 @@ EXPORT_SYMBOL(hvc_get_chars); * @vtermno: The vtermno or unit_address of the adapter from which the data * originated. * @buf: The character buffer that contains the character data to send to - * firmware. + * firmware. Must be at least 16 bytes, even if count is less than 16. * @count: Send this number of characters. */ int hvc_put_chars(uint32_t vtermno, const char *buf, int count) diff --git a/drivers/tty/hvc/hvc_vio.c b/drivers/tty/hvc/hvc_vio.c index b05dc5086627..8bab8b00d47d 100644 --- a/drivers/tty/hvc/hvc_vio.c +++ b/drivers/tty/hvc/hvc_vio.c @@ -120,6 +120,14 @@ static int hvterm_raw_get_chars(uint32_t vtermno, char *buf, int count) return got; } +/** + * hvterm_raw_put_chars: send characters to firmware for given vterm adapter + * @vtermno: The virtual terminal number. + * @buf: The characters to send. Because of the underlying hypercall in + * hvc_put_chars(), this buffer must be at least 16 bytes long, even if + * you are sending fewer chars. + * @count: number of chars to send. + */ static int hvterm_raw_put_chars(uint32_t vtermno, const char *buf, int count) { struct hvterm_priv *pv = hvterm_privs[vtermno]; @@ -232,6 +240,7 @@ static const struct hv_ops hvterm_hvsi_ops = { static void udbg_hvc_putc(char c) { int count = -1; + unsigned char bounce_buffer[16]; if (!hvterm_privs[0]) return; @@ -242,7 +251,12 @@ static void udbg_hvc_putc(char c) do { switch(hvterm_privs[0]->proto) { case HV_PROTOCOL_RAW: - count = hvterm_raw_put_chars(0, &c, 1); + /* + * hvterm_raw_put_chars requires at least a 16-byte + * buffer, so go via the bounce buffer + */ + bounce_buffer[0] = c; + count = hvterm_raw_put_chars(0, bounce_buffer, 1); break; case HV_PROTOCOL_HVSI: count = hvterm_hvsi_put_chars(0, &c, 1); -- 2.20.1