Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp3912899imm; Mon, 8 Oct 2018 11:34:58 -0700 (PDT) X-Google-Smtp-Source: ACcGV61/X/I22jrUx14zLGTjSkTnNWIrAPOXUIVP2iawfXnvspio70bT1u12jI63A5eoYlEZ/+Ls X-Received: by 2002:a17:902:3fe4:: with SMTP id a91-v6mr25011434pld.187.1539023698701; Mon, 08 Oct 2018 11:34:58 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539023698; cv=none; d=google.com; s=arc-20160816; b=savDQnPwjFQFjpsUdaHZRX5pmINrgWl4Ftg1dqzWGEv1wkoV0stHblQyjoALnakUlz wc7qmkcRMsJFTiqQD7jtNwO0RJ8W0icIZxVXgXFqTQBz36QF+Yxb4tYA6bjb/c9n/pGG aLbnXM3pzoYVByXPs092N1uUpZ5u/GOGQxoYakEWkT/M1p9H5ghdSkCiPo+A4zM2mSWt eFlTDDsogkTgapO2OQI2DoiL6palJbP1o50TcKoDXBMg6rGTmMyl6kBUVfTY7ciliTI6 Wxh16cvdFZdD4w9wPEqT1YcOUSzwU5S9n02lZBsnLkYgj8SIRCWCLaxyEBj9PDWnUwai MdNg== 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=cbnL2nVvomwstP7EmTBTuyW7ReRJsZIjc6u8o1e72Ms=; b=roTAG7c1aNaSHVUYi3ChNEcZ+68RHfE87V6BWaMdquxMhKzq2+1YBb7vaZbPRpRX3R 7anIxH/EvAP67CKNJDgvP6rlxjhEhimCiqioRxuxATNE4aNHoOL48la7ro58F1LwI9h8 f/WSbAkvsI5+WbEJDlQnP+D3VbR1e2XcK28xsKYRcj4OJTQwTfAjHMZPP0sb6lFqdN/P zY8wP2sNy44i0DvXXJ5AYtxA0eCn86Kj+tgxkwMSTJYvXoHyup9KEkRJER3H5lQU0S6Y 0JNULJ3ENjB99T65Ay0JmpRS9L0//JvL4YZwoafwZphe5bxHbrXyY5tN6tLe1f3nXjzd xYoA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=NS3VsK9r; 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 x17-v6si17605138pgl.414.2018.10.08.11.34.44; Mon, 08 Oct 2018 11:34:58 -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=NS3VsK9r; 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 S1727584AbeJIBrI (ORCPT + 99 others); Mon, 8 Oct 2018 21:47:08 -0400 Received: from mail.kernel.org ([198.145.29.99]:57860 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726596AbeJIBrH (ORCPT ); Mon, 8 Oct 2018 21:47:07 -0400 Received: from localhost (ip-213-127-77-176.ip.prioritytelecom.net [213.127.77.176]) (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 ADF492087D; Mon, 8 Oct 2018 18:34:04 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1539023645; bh=FYoXdL8EFkUC84FkgYYcVYCmV1jIriOddOSDVJ2rwrs=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=NS3VsK9rQqxKuftCygmMYq3SnUsdf5fNqQDXoWSRDDLu9Ca37X3U0toMMakq9CQkR Bf+pZ03rLdwfG/kS+lRT5WIHAhSpll2g41V6WEhBftxX08DFuLQjstFgroIMkXL7js i4AMm5+c3l5G6GqZqdkbEjaELcOzCXJmH97uCT6c= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Ethan Tuttle , Gregory CLEMENT , Sasha Levin Subject: [PATCH 4.4 035/113] ARM: mvebu: declare asm symbols as character arrays in pmsu.c Date: Mon, 8 Oct 2018 20:30:36 +0200 Message-Id: <20181008175532.546277612@linuxfoundation.org> X-Mailer: git-send-email 2.19.0 In-Reply-To: <20181008175530.864641368@linuxfoundation.org> References: <20181008175530.864641368@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review 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.4-stable review patch. If anyone has any objections, please let me know. ------------------ From: Ethan Tuttle [ Upstream commit d0d378ff451a66e486488eec842e507d28145813 ] With CONFIG_FORTIFY_SOURCE, memcpy uses the declared size of operands to detect buffer overflows. If src or dest is declared as a char, attempts to copy more than byte will result in a fortify_panic(). Address this problem in mvebu_setup_boot_addr_wa() by declaring mvebu_boot_wa_start and mvebu_boot_wa_end as character arrays. Also remove a couple addressof operators to avoid "arithmetic on pointer to an incomplete type" compiler error. See commit 54a7d50b9205 ("x86: mark kprobe templates as character arrays, not single characters") for a similar fix. Fixes "detected buffer overflow in memcpy" error during init on some mvebu systems (armada-370-xp, armada-375): (fortify_panic) from (mvebu_setup_boot_addr_wa+0xb0/0xb4) (mvebu_setup_boot_addr_wa) from (mvebu_v7_cpu_pm_init+0x154/0x204) (mvebu_v7_cpu_pm_init) from (do_one_initcall+0x7c/0x1a8) (do_one_initcall) from (kernel_init_freeable+0x1bc/0x254) (kernel_init_freeable) from (kernel_init+0x8/0x114) (kernel_init) from (ret_from_fork+0x14/0x2c) Signed-off-by: Ethan Tuttle Tested-by: Ethan Tuttle Signed-off-by: Gregory CLEMENT Signed-off-by: Sasha Levin Signed-off-by: Greg Kroah-Hartman --- arch/arm/mach-mvebu/pmsu.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) --- a/arch/arm/mach-mvebu/pmsu.c +++ b/arch/arm/mach-mvebu/pmsu.c @@ -117,8 +117,8 @@ void mvebu_pmsu_set_cpu_boot_addr(int hw PMSU_BOOT_ADDR_REDIRECT_OFFSET(hw_cpu)); } -extern unsigned char mvebu_boot_wa_start; -extern unsigned char mvebu_boot_wa_end; +extern unsigned char mvebu_boot_wa_start[]; +extern unsigned char mvebu_boot_wa_end[]; /* * This function sets up the boot address workaround needed for SMP @@ -131,7 +131,7 @@ int mvebu_setup_boot_addr_wa(unsigned in phys_addr_t resume_addr_reg) { void __iomem *sram_virt_base; - u32 code_len = &mvebu_boot_wa_end - &mvebu_boot_wa_start; + u32 code_len = mvebu_boot_wa_end - mvebu_boot_wa_start; mvebu_mbus_del_window(BOOTROM_BASE, BOOTROM_SIZE); mvebu_mbus_add_window_by_id(crypto_eng_target, crypto_eng_attribute,