Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp352775pxj; Tue, 18 May 2021 05:02:39 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwqsTFSlPmCPvhOwXa+bAmmx1L9XcTsWiArkDcjepWBPFRqkPjbI52nPocOm44phNL/2TR7 X-Received: by 2002:a17:906:3da9:: with SMTP id y9mr5670922ejh.303.1621339359042; Tue, 18 May 2021 05:02:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1621339359; cv=none; d=google.com; s=arc-20160816; b=VGACyiiOsxzXj5O9zkOw0SUeIpBA/6ihjIcNwQNu2yjPc68xmBq8gthze1rNAS958G jOEvy+jOX6keFd2tC1SjLtwjm70EQH902C7qI7aslj3plQsJl3YAv1IqvqJSv/IYXGbF AHXMup3+4hHzCmA2dHT2a/Ch86ArODhF5CeP4nAiRvI3E6sYYPl/+F73J5NjwAvCw/W1 uhw4gjQiWQ8IG70msxbQk4NlI+A4s1w2LQUkc3mstkkW9GeE2ryGiJQW4zvNC87JEwOM cmC9sya66DQOns6cqevfUrXTOOB3h7OpYuiFBhmju8mIWom1Fje9p56eGUIufEk2NU0F ifQQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=JTv572Smi1BW9TbWEzeylVC4AHxDOSojtyqDgmSjIUs=; b=jDtt+5GSVgKAF713Sh69X97jXcBf6pkhKHcFnTU+jXX/w1yfrN2OfGeKCIL8/Wp6Jn r2NxA2Cvp93Fz7tYk5O/y/dKzLb1/z5d87oSAt1d2RVkqq/DwodFTTlg3HCH5vYJmPV1 zFjTXJeVZTmCa0/9eV21ECsrBnIdvQW8Yocmlt8FJGG5rRsMY8eHN8FjU/RLbfDISugU EMv/4NYeULkANEx7OhS91Ke3G7SsbVlWQ8NFpGCpILy3T2IyibQOQosiVypLn2YBNBWr /ANi4fIfYP+2CVAOO92CiWLR/VRwM8ZPEYQur68crYiG16+EhaKoTaYFNmxYr/rVO3dO TGQw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=rvB+71F3; 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=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id f11si16910665edc.302.2021.05.18.05.01.56; Tue, 18 May 2021 05:02:39 -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=@linuxfoundation.org header.s=korg header.b=rvB+71F3; 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=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S243540AbhEQP0R (ORCPT + 99 others); Mon, 17 May 2021 11:26:17 -0400 Received: from mail.kernel.org ([198.145.29.99]:36846 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S242762AbhEQPMP (ORCPT ); Mon, 17 May 2021 11:12:15 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 3A19061C49; Mon, 17 May 2021 14:31:19 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1621261879; bh=6Vp80qS7+caMCitputbWgWF2Ko1xwPcVy27HN7NfAAU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=rvB+71F3wQMpFUGIRmmTI56EZMkxcMDW3Tj8AXs5bh01Hj6BEBXk+X/lKd1XUmD7K 5h5AKHb9jQZtWsWzPis3eaUgEkQ7mPT+e420+ivYI/IutQJo19N7orDDl5P2b8uwWK T3oB8AduSn0chCFpAvkdYwxEEeSw7CoFu/dUZ9Nc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Chris Wilson , =?UTF-8?q?Ville=20Syrj=C3=A4l=C3=A4?= , Jani Nikula Subject: [PATCH 5.4 104/141] drm/i915: Avoid div-by-zero on gen2 Date: Mon, 17 May 2021 16:02:36 +0200 Message-Id: <20210517140246.279576967@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210517140242.729269392@linuxfoundation.org> References: <20210517140242.729269392@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Ville Syrjälä commit 4819d16d91145966ce03818a95169df1fd56b299 upstream. Gen2 tiles are 2KiB in size so i915_gem_object_get_tile_row_size() can in fact return <4KiB, which leads to div-by-zero here. Avoid that. Not sure i915_gem_object_get_tile_row_size() is entirely sane anyway since it doesn't account for the different tile layouts on i8xx/i915... I'm not able to hit this before commit 6846895fde05 ("drm/i915: Replace PIN_NONFAULT with calls to PIN_NOEVICT") and it looks like I also need to run recent version of Mesa. With those in place xonotic trips on this quite easily on my 85x. Cc: stable@vger.kernel.org Reviewed-by: Chris Wilson Signed-off-by: Ville Syrjälä Link: https://patchwork.freedesktop.org/patch/msgid/20210421153401.13847-2-ville.syrjala@linux.intel.com (cherry picked from commit ed52c62d386f764194e0184fdb905d5f24194cae) Signed-off-by: Jani Nikula Signed-off-by: Greg Kroah-Hartman --- drivers/gpu/drm/i915/gem/i915_gem_mman.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) --- a/drivers/gpu/drm/i915/gem/i915_gem_mman.c +++ b/drivers/gpu/drm/i915/gem/i915_gem_mman.c @@ -181,7 +181,7 @@ compute_partial_view(const struct drm_i9 struct i915_ggtt_view view; if (i915_gem_object_is_tiled(obj)) - chunk = roundup(chunk, tile_row_pages(obj)); + chunk = roundup(chunk, tile_row_pages(obj) ?: 1); view.type = I915_GGTT_VIEW_PARTIAL; view.partial.offset = rounddown(page_offset, chunk);