Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp2025995ybt; Mon, 15 Jun 2020 16:14:52 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyQkXrrP3n7m65+eWHcqqGRus+mUSDwLgCKUxlqQBMreQyncRCPvotZnsFS5IlV6+bf+ohd X-Received: by 2002:a17:906:bcfc:: with SMTP id op28mr124515ejb.237.1592262892162; Mon, 15 Jun 2020 16:14:52 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592262892; cv=none; d=google.com; s=arc-20160816; b=cf4iY0JM6FB+Z/poMuH87qSxfZjGu45iic8JKWeIL9spTO7BU+xUlQsNE8jcAH5IPw NeekmHqFXRlg6GH5n2g22KQB2WKOdTgCDvaIqRWiWqUlIZo3drCov9WcGgm6cy52nmAE uptYsr5j2xFyei7YcAqt/XIY44TgqIoxLHfgOJWzvpkFiPHwiF1WXRuOOZgeQ0wYQxMi ARTYUObqz+Rf8gU4VXWuMvWDXKH5HnXm5Ci71/mLEurl1HlXQM8VdlwQQO4eTIDY3DrV cyZUUU/OsQthlSfg0nzaiZ9rZqTRwGuxdWQGTAjFdkdzM82kCxDfb4p1TZ9aDqRbnUEC jd8A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:content-disposition :mime-version:message-id:subject:cc:to:from:date:dkim-signature; bh=jAA2OW63oxBAkM063UFzT257y7rS03LtxYSxKthsN4c=; b=ezIt+t05x6BcUxjGfOMXuInhM0QTfcs+VR0wxdooapVFA+2wk1g7RuzK6jeLTLVTVg l6zBPDscJWPxuNpPpjH3lReFt+Sd4ApQkMDknhvI/74Bu0CzoVYezSEPC/7lTgYQ3w1j MoNCCA577nMczaEk/Y2+433NWm2G1wNSofIQv7xHp01kgj6VZ1iL7y+/87mI+McPR9Ry Y9ES3bpLSYrrlG1q++1lQR7crifxPOvD+RLms/oZJWumikKnkDJgi/Josc8nHcc5OkGN uOLPsRnClKhZ6FXD9Yvk+MK7Q1NVqBowBI3jNz5vz3OhBqa+sgk3R4xlV8k/tjwDaY2j tlqA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=CEs4aLG5; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id lj6si9715054ejb.108.2020.06.15.16.14.29; Mon, 15 Jun 2020 16:14:52 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=CEs4aLG5; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726718AbgFOXKY (ORCPT + 99 others); Mon, 15 Jun 2020 19:10:24 -0400 Received: from mail.kernel.org ([198.145.29.99]:38550 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725960AbgFOXKX (ORCPT ); Mon, 15 Jun 2020 19:10:23 -0400 Received: from embeddedor (unknown [189.207.59.248]) (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 D51EC2068E; Mon, 15 Jun 2020 23:10:22 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1592262623; bh=7RV+LZohdXGjxU20nhjS42pqNFlJCzFWcJTRRTFiDDc=; h=Date:From:To:Cc:Subject:From; b=CEs4aLG5bPIwZbrsvC2dSFTmKvPInHk5eson9VqbhFdXVH0XydZjGHGGolJ1XST+g mlNkDLx5IU3HQg59/H7h47facnlBhyRq+gX3NcxcZ6UcYuXoBExfajLH22hE+PRHfu BpG1T8V0uj1NWRhG3TsLNA7PQU73D1kX15FUM8YM= Date: Mon, 15 Jun 2020 18:15:42 -0500 From: "Gustavo A. R. Silva" To: Bartlomiej Zolnierkiewicz Cc: dri-devel@lists.freedesktop.org, linux-fbdev@vger.kernel.org, linux-kernel@vger.kernel.org, "Gustavo A. R. Silva" Subject: [PATCH][next] fbcon: Use array3_size() helper in scr_memcpyw() Message-ID: <20200615231542.GA20470@embeddedor> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline User-Agent: Mutt/1.9.4 (2018-02-28) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Use array3_size() helper instead of the open-coded version in scr_memcpyw() and scr_memsetw(). These sorts of multiplication factors need to be wrapped in array3_size(). This issue was found with the help of Coccinelle and, audited and fixed manually. Addresses-KSPP-ID: https://github.com/KSPP/linux/issues/83 Signed-off-by: Gustavo A. R. Silva --- drivers/video/fbdev/core/fbcon.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/drivers/video/fbdev/core/fbcon.c b/drivers/video/fbdev/core/fbcon.c index 9d28a8e3328f..6af2734f2a7b 100644 --- a/drivers/video/fbdev/core/fbcon.c +++ b/drivers/video/fbdev/core/fbcon.c @@ -639,7 +639,7 @@ static void fbcon_prepare_logo(struct vc_data *vc, struct fb_info *info, GFP_KERNEL); if (save) { int i = cols < new_cols ? cols : new_cols; - scr_memsetw(save, erase, logo_lines * new_cols * 2); + scr_memsetw(save, erase, array3_size(logo_lines, new_cols, 2)); r = q - step; for (cnt = 0; cnt < logo_lines; cnt++, r += i) scr_memcpyw(save + cnt * new_cols, r, 2 * i); @@ -676,7 +676,7 @@ static void fbcon_prepare_logo(struct vc_data *vc, struct fb_info *info, q = (unsigned short *) (vc->vc_origin + vc->vc_size_row * rows); - scr_memcpyw(q, save, logo_lines * new_cols * 2); + scr_memcpyw(q, save, array3_size(logo_lines, new_cols, 2)); vc->vc_y += logo_lines; vc->vc_pos += logo_lines * vc->vc_size_row; kfree(save); -- 2.27.0