Received: by 2002:a25:f815:0:0:0:0:0 with SMTP id u21csp409133ybd; Tue, 25 Jun 2019 23:58:07 -0700 (PDT) X-Google-Smtp-Source: APXvYqwLlgojyuwXRbmJ+JO2aNdaoheopyISBsyy7dS2VRS5uvDJs85o8jyPTx5Jgra42Pvm2MU4 X-Received: by 2002:a63:735d:: with SMTP id d29mr1414440pgn.276.1561532287756; Tue, 25 Jun 2019 23:58:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1561532287; cv=none; d=google.com; s=arc-20160816; b=HmfSGbknAmY1FdAepHAtc2MBIvPGih/2oPr750aXXrmI6PkeVAb2PyAIqYHTa2dOtB 3Y0EvuV6ARtAy17Ayvc56grywjBdI2K7Yczne3cDNwaVbus5SK8yTyVv1AYWnnExlLQs tz4t/Tru3tC+cHEnJxUe4RVDddab/iFhmYj3BfL8tLBY7dmYh+TMTpMUjwBAUsTl0Z1b iX1Fcx2Qqr8YP/EFExkA9VYRFRH/pLLxUuC84/8mOP3x9plH+UpZRJNqh3Kha1w6Of33 xRfbq+LUxbEE6USm0ZzjhlCY9WCKqcN7wqZLoOLy643uLL8nR9LEDmIVfgqxEEp/cShQ 9SOg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=WeA0hOLnxFUTDB0XNkwCjMzn2lRUDxi3McnEWi3lBGs=; b=zjGlqeNJ9Qx2toG+E/aBBI3bvdeebW2yZ44Cl91wQZJo/ib2u4hQJIO6LwOXLahipK CoxcKXcuqsrukVKPCJ1SHhwmKIEl3NOCZGbWhAJoRzcnnMUYzfV4h8wCU2Mw6hA5QI2M BrvUaSjVwmW2HThA3iBv93j3f74V2TkA4VHpgyrov4v/I0sGM368uX3/mhawH5fuKfuD dPrCB43TtNPv2ja4GW6RVBPyQWjOd6NfG+s7d6ms34p2+kT+mRVYOCa3PbBswKYwu/+h 0a9CNBiUEECYWPo4LZaVhFhmZN4ZcsDBLoc+M9e8or9agCN1lS5JIWzP2M2v1vRoOx+g WcYQ== ARC-Authentication-Results: i=1; mx.google.com; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 138si16568151pfy.77.2019.06.25.23.57.51; Tue, 25 Jun 2019 23:58:07 -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; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726833AbfFZGz6 (ORCPT + 99 others); Wed, 26 Jun 2019 02:55:58 -0400 Received: from mx1.redhat.com ([209.132.183.28]:52760 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726468AbfFZGz6 (ORCPT ); Wed, 26 Jun 2019 02:55:58 -0400 Received: from smtp.corp.redhat.com (int-mx03.intmail.prod.int.phx2.redhat.com [10.5.11.13]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id ACABF307D861; Wed, 26 Jun 2019 06:55:57 +0000 (UTC) Received: from sirius.home.kraxel.org (ovpn-116-96.ams2.redhat.com [10.36.116.96]) by smtp.corp.redhat.com (Postfix) with ESMTP id A7900608C1; Wed, 26 Jun 2019 06:55:52 +0000 (UTC) Received: by sirius.home.kraxel.org (Postfix, from userid 1000) id C27E016E1A; Wed, 26 Jun 2019 08:55:51 +0200 (CEST) From: Gerd Hoffmann To: dri-devel@lists.freedesktop.org Cc: tzimmermann@suse.de, Gerd Hoffmann , David Airlie , Daniel Vetter , virtualization@lists.linux-foundation.org (open list:DRM DRIVER FOR BOCHS VIRTUAL GPU), linux-kernel@vger.kernel.org (open list) Subject: [PATCH 2/2] drm/bochs: fix framebuffer setup. Date: Wed, 26 Jun 2019 08:55:51 +0200 Message-Id: <20190626065551.12956-3-kraxel@redhat.com> In-Reply-To: <20190626065551.12956-1-kraxel@redhat.com> References: <20190626065551.12956-1-kraxel@redhat.com> X-Scanned-By: MIMEDefang 2.79 on 10.5.11.13 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.5.110.48]); Wed, 26 Jun 2019 06:55:57 +0000 (UTC) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org If bo->width doesn't match fb->width the driver fails to configure the display correctly, resulting in a scrambled display. Fix it. Signed-off-by: Gerd Hoffmann --- drivers/gpu/drm/bochs/bochs.h | 2 +- drivers/gpu/drm/bochs/bochs_hw.c | 13 +++++++++---- drivers/gpu/drm/bochs/bochs_kms.c | 1 + 3 files changed, 11 insertions(+), 5 deletions(-) diff --git a/drivers/gpu/drm/bochs/bochs.h b/drivers/gpu/drm/bochs/bochs.h index cc35d492142c..78c0283496cc 100644 --- a/drivers/gpu/drm/bochs/bochs.h +++ b/drivers/gpu/drm/bochs/bochs.h @@ -86,7 +86,7 @@ void bochs_hw_setmode(struct bochs_device *bochs, void bochs_hw_setformat(struct bochs_device *bochs, const struct drm_format_info *format); void bochs_hw_setbase(struct bochs_device *bochs, - int x, int y, u64 addr); + int x, int y, int fbwidth, u64 addr); int bochs_hw_load_edid(struct bochs_device *bochs); /* bochs_mm.c */ diff --git a/drivers/gpu/drm/bochs/bochs_hw.c b/drivers/gpu/drm/bochs/bochs_hw.c index 791ab2f79947..141aa02962d3 100644 --- a/drivers/gpu/drm/bochs/bochs_hw.c +++ b/drivers/gpu/drm/bochs/bochs_hw.c @@ -255,16 +255,21 @@ void bochs_hw_setformat(struct bochs_device *bochs, } void bochs_hw_setbase(struct bochs_device *bochs, - int x, int y, u64 addr) + int x, int y, int fbwidth, u64 addr) { - unsigned long offset = (unsigned long)addr + + unsigned long offset; + unsigned int vx, vy; + + bochs->stride = fbwidth * (bochs->bpp / 8); + offset = (unsigned long)addr + y * bochs->stride + x * (bochs->bpp / 8); - int vy = offset / bochs->stride; - int vx = (offset % bochs->stride) * 8 / bochs->bpp; + vy = offset / bochs->stride; + vx = (offset % bochs->stride) * 8 / bochs->bpp; DRM_DEBUG_DRIVER("x %d, y %d, addr %llx -> offset %lx, vx %d, vy %d\n", x, y, addr, offset, vx, vy); + bochs_dispi_write(bochs, VBE_DISPI_INDEX_VIRT_WIDTH, fbwidth); bochs_dispi_write(bochs, VBE_DISPI_INDEX_X_OFFSET, vx); bochs_dispi_write(bochs, VBE_DISPI_INDEX_Y_OFFSET, vy); } diff --git a/drivers/gpu/drm/bochs/bochs_kms.c b/drivers/gpu/drm/bochs/bochs_kms.c index 5904eddc83a5..1f6aa11a1dc9 100644 --- a/drivers/gpu/drm/bochs/bochs_kms.c +++ b/drivers/gpu/drm/bochs/bochs_kms.c @@ -36,6 +36,7 @@ static void bochs_plane_update(struct bochs_device *bochs, bochs_hw_setbase(bochs, state->crtc_x, state->crtc_y, + gbo->width, gbo->bo.offset); bochs_hw_setformat(bochs, state->fb->format); } -- 2.18.1