From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from lists.gnu.org (lists.gnu.org [209.51.188.17]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 1370DCF64B0 for ; Thu, 20 Nov 2025 04:10:08 +0000 (UTC) Received: from localhost ([::1] helo=lists1p.gnu.org) by lists.gnu.org with esmtp (Exim 4.90_1) (envelope-from ) id 1vLvxx-00015e-Se; Wed, 19 Nov 2025 23:08:18 -0500 Received: from eggs.gnu.org ([2001:470:142:3::10]) by lists.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1vLvxs-00014k-5T for qemu-devel@nongnu.org; Wed, 19 Nov 2025 23:08:13 -0500 Received: from sender3-pp-f112.zoho.com ([136.143.184.112]) by eggs.gnu.org with esmtps (TLS1.2:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.90_1) (envelope-from ) id 1vLvxl-0000YM-TK for qemu-devel@nongnu.org; Wed, 19 Nov 2025 23:08:11 -0500 ARC-Seal: i=1; a=rsa-sha256; t=1763611665; cv=none; d=zohomail.com; s=zohoarc; b=XFUDYUS80+L2GKnHrBZ+hwokOzgob74ww3D9rJyfHAtCaJ01CBtLC8loJfIZzfsXDrStIx9O8fui0XparVg0rDlyT86TvwVYc/BWpEyqrkKe6l80LiQs2FEu3lUfCX3/MoegKUCKSEPwvXDnC1s/uVyuKmlHt/YIIJrK6vB1bFI= ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=zohomail.com; s=zohoarc; t=1763611665; h=Content-Transfer-Encoding:Cc:Cc:Date:Date:From:From:MIME-Version:Message-ID:Subject:Subject:To:To:Message-Id:Reply-To; bh=Wk+wP/5u7U28DKn1JNryhSMQxwmW9YIvjXBakJRrpV8=; b=bAW3IWI8rgQugejiQsufwTprT9+F/5SxcVA619cPp826VOBFP+Ms4zGUrBCySVY4vFa2Jk5gBMeuCVytMDTAgD0GDufPpPDWMZQ0W5R5mPJG/iL9yQMawXl5L1BRX8c2j0dkiIL7WNwidEFyQ6xhEnoSEcbGyhzUBv6I4F0TMuM= ARC-Authentication-Results: i=1; mx.zohomail.com; dkim=pass header.i=collabora.com; spf=pass smtp.mailfrom=dmitry.osipenko@collabora.com; dmarc=pass header.from= DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; t=1763611665; s=zohomail; d=collabora.com; i=dmitry.osipenko@collabora.com; h=From:From:To:To:Cc:Cc:Subject:Subject:Date:Date:Message-ID:MIME-Version:Content-Transfer-Encoding:Message-Id:Reply-To; bh=Wk+wP/5u7U28DKn1JNryhSMQxwmW9YIvjXBakJRrpV8=; b=WaRRu+3FoYZOaVGzXoOgc52+5EfoDExXkBJxDJkfR9saTJ0SJTYcyGUOAwtULNE8 BzRoeT9ZJVWQsskwTkWkFR5Y+sFLMSdHOs8z99SfM6hX/H6DdI0zI2dWuOFS9wn2+py 97mo5psVePcgAASwqPgy2Z9tcVfMJRjBSQL7FX8I= Received: by mx.zohomail.com with SMTPS id 1763611662570600.6813283416309; Wed, 19 Nov 2025 20:07:42 -0800 (PST) From: Dmitry Osipenko To: Akihiko Odaki , Huang Rui , =?UTF-8?q?Marc-Andr=C3=A9=20Lureau?= , =?UTF-8?q?Philippe=20Mathieu-Daud=C3=A9?= , Gerd Hoffmann , =?UTF-8?q?Alex=20Benn=C3=A9e?= , Pierre-Eric Pelloux-Prayer , "Michael S . Tsirkin" , Paolo Bonzini , Yiwei Zhang , Sergio Lopez Pascual Cc: Gert Wollny , qemu-devel@nongnu.org, Gurchetan Singh , Alyssa Ross , =?UTF-8?q?Roger=20Pau=20Monn=C3=A9?= , Alex Deucher , Stefano Stabellini , =?UTF-8?q?Christian=20K=C3=B6nig?= , Xenia Ragiadakou , Honglei Huang , Julia Zhang , Chen Jiqian , Rob Clark , Robert Beckett Subject: [RFC PATCH v3 0/7] Support mapping virtio-gpu virgl hostmem blobs using MAP_FIXED API Date: Thu, 20 Nov 2025 07:06:25 +0300 Message-ID: <20251120040632.4036204-1-dmitry.osipenko@collabora.com> X-Mailer: git-send-email 2.51.1 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-ZohoMailClient: External Received-SPF: pass client-ip=136.143.184.112; envelope-from=dmitry.osipenko@collabora.com; helo=sender3-pp-f112.zoho.com X-Spam_score_int: -20 X-Spam_score: -2.1 X-Spam_bar: -- X-Spam_report: (-2.1 / 5.0 requ) BAYES_00=-1.9, DKIM_SIGNED=0.1, DKIM_VALID=-0.1, DKIM_VALID_AU=-0.1, DKIM_VALID_EF=-0.1, RCVD_IN_MSPIKE_H4=0.001, RCVD_IN_MSPIKE_WL=0.001, RCVD_IN_VALIDITY_CERTIFIED_BLOCKED=0.001, RCVD_IN_VALIDITY_RPBL_BLOCKED=0.001, SPF_HELO_NONE=0.001, SPF_PASS=-0.001 autolearn=ham autolearn_force=no X-Spam_action: no action X-BeenThere: qemu-devel@nongnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: qemu-devel-bounces+qemu-devel=archiver.kernel.org@nongnu.org Sender: qemu-devel-bounces+qemu-devel=archiver.kernel.org@nongnu.org Virglrender got a new unstable API that allows mapping host blobs at a given memory address using MAP_FIXED mmap flag [1]. Usage of this new API brings major performance and stability improvement for venus and drm native contexts, see commit message of the RFC patch for details. Sending early to collect review feeback and have patch prepared by the time new version of libvirglrenderer will be released with the stabilized API. [1] https://gitlab.freedesktop.org/virgl/virglrenderer/-/merge_requests/1374 Based-on: 20251116125641.2255794-1-dmitry.osipenko@collabora.com Changelog: v3: - Addressed v2 review comments from Akihiko Odaki. - Droped check for CONFIG_WIN32. My current understanding that MAP_FIXED is supported by Cygwin. - Added new patches resetting virgl resources, validating hostmem offset and improving error-handlings. - Added r-b from Akihiko Odaki to the frist patch and t-b from Yiwei Zhang to the map_fixed patch. v2: - Addressed v1 review comments from Akihiko Odaki - Added patch that removes unnecessary memory_region_set_enabled(), suggested by Akihiko Odaki Dmitry Osipenko (7): virtio-gpu: Remove superfluous memory_region_set_enabled() virtio-gpu: Validate hostmem mapping offset virtio-gpu: Make virtio_gpu_virgl_unmap_resource_blob() return -1 on error virtio-gpu: Blame host for virgl blob resource unmapping error virtio-gpu: Destroy virgl resources on virtio-gpu reset virtio-gpu: Make virtio_gpu_virgl_init() return -1 on error virtio-gpu: Support mapping hostmem blobs with map_fixed hw/display/virtio-gpu-gl.c | 51 ++++++++++- hw/display/virtio-gpu-virgl.c | 159 ++++++++++++++++++++++++++------- include/hw/virtio/virtio-gpu.h | 8 +- 3 files changed, 183 insertions(+), 35 deletions(-) -- 2.51.1