From patchwork Fri Mar 21 11:16:54 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Jocelyn Falempe X-Patchwork-Id: 14025288 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 gabe.freedesktop.org (gabe.freedesktop.org [131.252.210.177]) (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 840C7C36000 for ; Fri, 21 Mar 2025 11:25:13 +0000 (UTC) Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id E437110E7A4; Fri, 21 Mar 2025 11:25:12 +0000 (UTC) Authentication-Results: gabe.freedesktop.org; dkim=pass (1024-bit key; unprotected) header.d=redhat.com header.i=@redhat.com header.b="H8JWH0xj"; dkim-atps=neutral Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.129.124]) by gabe.freedesktop.org (Postfix) with ESMTPS id E90E410E7A4 for ; Fri, 21 Mar 2025 11:25:07 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1742556307; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version: content-transfer-encoding:content-transfer-encoding; bh=Q/45+X0nz6DYq9cPSKysVGVnJ9IivWVYXHf1OYLZvh4=; b=H8JWH0xjDET9Xsl6UC9EnBQ+6+S5AhlZbse0wZNT1HrR3Bm4Bk+oFYhpwgvWVJmHWQ+Ur0 DNU8QeCRFjT3gA7gUAtGI2HbXixmut805unRR4JGbO6QmcTYK9xmz00c+PdgAQLXQihpgO 0yPCZq/y2axK/t43NB9JXNbXU4FBT/k= Received: from mx-prod-mc-02.mail-002.prod.us-west-2.aws.redhat.com (ec2-54-186-198-63.us-west-2.compute.amazonaws.com [54.186.198.63]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-139-H-lpW1u0OrOjg9GoXfw0Sg-1; Fri, 21 Mar 2025 07:25:03 -0400 X-MC-Unique: H-lpW1u0OrOjg9GoXfw0Sg-1 X-Mimecast-MFC-AGG-ID: H-lpW1u0OrOjg9GoXfw0Sg_1742556301 Received: from mx-prod-int-08.mail-002.prod.us-west-2.aws.redhat.com (mx-prod-int-08.mail-002.prod.us-west-2.aws.redhat.com [10.30.177.111]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (2048 bits) server-digest SHA256) (No client certificate requested) by mx-prod-mc-02.mail-002.prod.us-west-2.aws.redhat.com (Postfix) with ESMTPS id EC655196B36E; Fri, 21 Mar 2025 11:25:00 +0000 (UTC) Received: from hydra.redhat.com (unknown [10.44.34.21]) by mx-prod-int-08.mail-002.prod.us-west-2.aws.redhat.com (Postfix) with ESMTP id 2DD171800268; Fri, 21 Mar 2025 11:24:54 +0000 (UTC) From: Jocelyn Falempe To: Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Simona Vetter , Ryosuke Yasuoka , Javier Martinez Canillas , Wei Yang , Andrew Morton , David Hildenbrand , John Ogness , Thomas Gleixner , linux-mm@kvack.org, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org Cc: Jocelyn Falempe Subject: [PATCH v2 0/2] drm/panic: Add support to scanout buffer as array of pages Date: Fri, 21 Mar 2025 12:16:54 +0100 Message-ID: <20250321112436.1739876-1-jfalempe@redhat.com> MIME-Version: 1.0 X-Scanned-By: MIMEDefang 3.4.1 on 10.30.177.111 X-BeenThere: dri-devel@lists.freedesktop.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Direct Rendering Infrastructure - Development List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" Some drivers like virtio-gpu, don't map the scanout buffer in the kernel. Calling vmap() in a panic handler is not safe, and writing an atomic_vmap() API is more complex than expected [1]. So instead, pass the array of pages of the scanout buffer to the panic handler, and map only one page at a time to draw the pixels. This is obviously slow, but acceptable for a panic handler. As kmap_local_page() is not safe to call from a panic handler, introduce a kmap_local_page_try_from_panic() that will avoid unsafe operations. [1] https://lore.kernel.org/dri-devel/20250305152555.318159-1-ryasuoka@redhat.com/ v2: * Add kmap_local_page_try_from_panic() Simona Vetter * Correctly handle the case if kmap_local_page_try_from_panic() returns NULL * Check that the current page is not NULL before trying to map it. * Add a comment in struct drm_scanout_buffer, that the array of pages shouldn't be allocated in the get_scanout_buffer() callback. Jocelyn Falempe (2): mm/kmap: Add kmap_local_page_try_from_panic() drm/panic: Add support to scanout buffer as array of pages drivers/gpu/drm/drm_panic.c | 142 +++++++++++++++++++++++++++++-- include/drm/drm_panic.h | 12 ++- include/linux/highmem-internal.h | 12 +++ 3 files changed, 159 insertions(+), 7 deletions(-) base-commit: f24d1d4a7a425e67551ca8d86a89df7102766ac9