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 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 306C7C36010 for ; Tue, 1 Apr 2025 22:38:21 +0000 (UTC) Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id E5DD910E679; Tue, 1 Apr 2025 22:38:20 +0000 (UTC) Authentication-Results: gabe.freedesktop.org; dkim=pass (1024-bit key; unprotected) header.d=redhat.com header.i=@redhat.com header.b="N8gvtqE1"; dkim-atps=neutral Received: from us-smtp-delivery-124.mimecast.com (us-smtp-delivery-124.mimecast.com [170.10.133.124]) by gabe.freedesktop.org (Postfix) with ESMTPS id 81D9B10E679 for ; Tue, 1 Apr 2025 22:38:19 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1743547098; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=C5PJKLi2OplBGTGIMXpZ53IzIo/Tz04cZeR9oJzwXFw=; b=N8gvtqE1wMEPnueJ2vCyssvec/AA6vqRKz/t4GI5Xbdd5tWRJX/DG/sh01mOYL84YttIZJ zMezMg8HD+NQAv6HBARk/ImiNsEy35rUYjBph65uqfL/waJPGGVsaME9++TIh8+O8B4gbO ecmg7Kc8nvbzqsBbOqtVYCFwBtlzCMY= Received: from mail-wm1-f69.google.com (mail-wm1-f69.google.com [209.85.128.69]) by relay.mimecast.com with ESMTP with STARTTLS (version=TLSv1.3, cipher=TLS_AES_256_GCM_SHA384) id us-mta-492-G_v2WhwsN2WsrFdNnyxZTg-1; Tue, 01 Apr 2025 18:38:17 -0400 X-MC-Unique: G_v2WhwsN2WsrFdNnyxZTg-1 X-Mimecast-MFC-AGG-ID: G_v2WhwsN2WsrFdNnyxZTg_1743547096 Received: by mail-wm1-f69.google.com with SMTP id 5b1f17b1804b1-43cf3168b87so33909055e9.2 for ; Tue, 01 Apr 2025 15:38:17 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1743547096; x=1744151896; h=content-transfer-encoding:in-reply-to:from:content-language :references:cc:to:subject:user-agent:mime-version:date:message-id :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=C5PJKLi2OplBGTGIMXpZ53IzIo/Tz04cZeR9oJzwXFw=; b=NgiPclRYBxgrEHOqTR4pTPdexeG0P+Pjt3dP7cK+Lj9/3ttv/ruboOo+gnWvjqTvbS 8pLFXXuBYON723/xDHXNcUCbVqt+pAzrqmJmxmKDyIVKHApmyMmmL1kCvtL6Fpt+LPAU e+TzPZljmGPQFG5H1uLnW+FPNxb8XJ+eY2r+Wu88LkYMtq/7VJna49XyRdSKmbo8SeKu m6uO4HF+ux3l8xQ4qkAty5Bb0ULYKU0COeinXIL3sVIdA8JW/pBC6vgUO+CBt2esiiMG OYIE3wOWXFEpnRrvVJ2eRts43skZklCc9/emVTCfulVF9Qs5LvCRP1J0K1yp8i+Z3h02 8Tug== X-Forwarded-Encrypted: i=1; AJvYcCXHiNQmp1VSjdsnADHBaoNQOI72qDCCkSQvevTt60N1NQopWOrOTWvM4eP2VYGMj/H2QdrOm5Y9Pg==@lists.freedesktop.org X-Gm-Message-State: AOJu0YxdGL5hT5DYDZ8ZOFpEePsas4pJXU+LW2J5al5bvB9bCThlXm31 eRPFI1+6rLkeOK4HR7JKWp7b/yhd2z8XlW+N5q7hHh3AZLZeRup6VLfadmkqfq4nTCrL/ftrkS9 opUhUFnpd6sqZ5CywEOMmcnF2Hfx+L7Kb3Tt3OouNPmZXOf9K2fv/z7pQKAuEinSh X-Gm-Gg: ASbGncs/9NHbkGI+fGRN5tZ9jRWUpTyKx80EPE/kvoYDdm1ZBq5SFgGatA/iCNMvI16 yUKXIG5OAQxxs+aXx3S1nYSKYs9iDlu7YCy+6C+wpYWDCltai+vnKKAECM1UEI/YuZ3FOuvuYbK yg4NRDkGKfWtABcgV9tUWaXHoW1B6WQEQhbPPkz1S6tA/cddNVHjVn/rBi2JL4jsFZjQIrtnkwX 2AKosSPB8zQ1ktTKzamqobQK0C08/lnFgbtSoxgudxi/wJ7TQVWsHPt5+fkeGBMFtAji+kId0kB 3vYko0baE38OePVUqjtuZRfi7cavKLJ4fR1QJhLdCtxh8o1fhE4ZzPA= X-Received: by 2002:a05:600c:4e52:b0:43b:ca39:6c75 with SMTP id 5b1f17b1804b1-43ead8c33d6mr29300795e9.16.1743547096025; Tue, 01 Apr 2025 15:38:16 -0700 (PDT) X-Google-Smtp-Source: AGHT+IF+A9B3Z3i0+ExREjsKk6CLKNAI1PotfynRKX0NjYjl47QvaVyla0up+c3eNFCiXusT9Z7c5g== X-Received: by 2002:a05:600c:4e52:b0:43b:ca39:6c75 with SMTP id 5b1f17b1804b1-43ead8c33d6mr29300575e9.16.1743547095592; Tue, 01 Apr 2025 15:38:15 -0700 (PDT) Received: from ?IPV6:2a01:e0a:c:37e0:ced3:55bd:f454:e722? ([2a01:e0a:c:37e0:ced3:55bd:f454:e722]) by smtp.gmail.com with ESMTPSA id ffacd0b85a97d-39c0b7a4294sm14934785f8f.89.2025.04.01.15.38.14 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Tue, 01 Apr 2025 15:38:14 -0700 (PDT) Message-ID: <4256338c-e547-4ec5-a72e-262d58f2a818@redhat.com> Date: Wed, 2 Apr 2025 00:38:13 +0200 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v6 4/8] drm/i915/gem: Add i915_gem_object_panic_map() To: =?UTF-8?B?VmlsbGUgU3lyasOkbMOk?= Cc: Jani Nikula , Rodrigo Vivi , Joonas Lahtinen , Tvrtko Ursulin , David Airlie , Simona Vetter , intel-gfx@lists.freedesktop.org, intel-xe@lists.freedesktop.org, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org References: <20250401125818.333033-1-jfalempe@redhat.com> <20250401125818.333033-5-jfalempe@redhat.com> From: Jocelyn Falempe In-Reply-To: X-Mimecast-Spam-Score: 0 X-Mimecast-MFC-PROC-ID: -wCwse_RpcYRDHV9JkqAZMHthZZCO3mvsn9X1WTfnng_1743547096 X-Mimecast-Originator: redhat.com Content-Language: en-US, fr Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 8bit X-BeenThere: intel-xe@lists.freedesktop.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Intel Xe graphics driver List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: intel-xe-bounces@lists.freedesktop.org Sender: "Intel-xe" On 01/04/2025 19:57, Ville Syrjälä wrote: > On Tue, Apr 01, 2025 at 08:47:50PM +0300, Ville Syrjälä wrote: >> On Tue, Apr 01, 2025 at 02:51:10PM +0200, Jocelyn Falempe wrote: >>> Prepare the work for drm_panic support. This is used to map the >>> current framebuffer, so the CPU can overwrite it with the panic >>> message. >>> >>> Signed-off-by: Jocelyn Falempe >>> --- >>> >>> v5: >>> * Use iosys_map for intel_bo_panic_map(). >>> >>> drivers/gpu/drm/i915/display/intel_bo.c | 5 ++++ >>> drivers/gpu/drm/i915/display/intel_bo.h | 1 + >>> drivers/gpu/drm/i915/gem/i915_gem_object.h | 2 ++ >>> drivers/gpu/drm/i915/gem/i915_gem_pages.c | 29 ++++++++++++++++++++++ >>> drivers/gpu/drm/xe/display/intel_bo.c | 10 ++++++++ >>> 5 files changed, 47 insertions(+) >>> >>> diff --git a/drivers/gpu/drm/i915/display/intel_bo.c b/drivers/gpu/drm/i915/display/intel_bo.c >>> index fbd16d7b58d9..ac904e9ec7d5 100644 >>> --- a/drivers/gpu/drm/i915/display/intel_bo.c >>> +++ b/drivers/gpu/drm/i915/display/intel_bo.c >>> @@ -57,3 +57,8 @@ void intel_bo_describe(struct seq_file *m, struct drm_gem_object *obj) >>> { >>> i915_debugfs_describe_obj(m, to_intel_bo(obj)); >>> } >>> + >>> +void intel_bo_panic_map(struct drm_gem_object *obj, struct iosys_map *map) >>> +{ >>> + i915_gem_object_panic_map(to_intel_bo(obj), map); >>> +} >>> diff --git a/drivers/gpu/drm/i915/display/intel_bo.h b/drivers/gpu/drm/i915/display/intel_bo.h >>> index ea7a2253aaa5..5b6c63d99786 100644 >>> --- a/drivers/gpu/drm/i915/display/intel_bo.h >>> +++ b/drivers/gpu/drm/i915/display/intel_bo.h >>> @@ -23,5 +23,6 @@ struct intel_frontbuffer *intel_bo_set_frontbuffer(struct drm_gem_object *obj, >>> struct intel_frontbuffer *front); >>> >>> void intel_bo_describe(struct seq_file *m, struct drm_gem_object *obj); >>> +void intel_bo_panic_map(struct drm_gem_object *obj, struct iosys_map *map); >>> >>> #endif /* __INTEL_BO__ */ >>> diff --git a/drivers/gpu/drm/i915/gem/i915_gem_object.h b/drivers/gpu/drm/i915/gem/i915_gem_object.h >>> index a5f34542135c..b16092707ea5 100644 >>> --- a/drivers/gpu/drm/i915/gem/i915_gem_object.h >>> +++ b/drivers/gpu/drm/i915/gem/i915_gem_object.h >>> @@ -692,6 +692,8 @@ i915_gem_object_unpin_pages(struct drm_i915_gem_object *obj) >>> int __i915_gem_object_put_pages(struct drm_i915_gem_object *obj); >>> int i915_gem_object_truncate(struct drm_i915_gem_object *obj); >>> >>> +void i915_gem_object_panic_map(struct drm_i915_gem_object *obj, struct iosys_map *map); >>> + >>> /** >>> * i915_gem_object_pin_map - return a contiguous mapping of the entire object >>> * @obj: the object to map into kernel address space >>> diff --git a/drivers/gpu/drm/i915/gem/i915_gem_pages.c b/drivers/gpu/drm/i915/gem/i915_gem_pages.c >>> index 8780aa243105..718bea6474d7 100644 >>> --- a/drivers/gpu/drm/i915/gem/i915_gem_pages.c >>> +++ b/drivers/gpu/drm/i915/gem/i915_gem_pages.c >>> @@ -355,6 +355,35 @@ static void *i915_gem_object_map_pfn(struct drm_i915_gem_object *obj, >>> return vaddr ?: ERR_PTR(-ENOMEM); >>> } >>> >>> +/* Map the current framebuffer for CPU access. Called from panic handler, so no >>> + * need to pin or cleanup. >>> + */ >>> +void i915_gem_object_panic_map(struct drm_i915_gem_object *obj, struct iosys_map *map) >>> +{ >>> + enum i915_map_type has_type; >>> + void *ptr; >>> + >>> + ptr = page_unpack_bits(obj->mm.mapping, &has_type); >>> + >>> + >>> + if (!ptr) { >>> + if (i915_gem_object_has_struct_page(obj)) >>> + ptr = i915_gem_object_map_page(obj, I915_MAP_WB); >>> + else >>> + ptr = i915_gem_object_map_pfn(obj, I915_MAP_WB); >> >> WB mapping would require clflushing to make it to the display. >> Is that being done somewhere? > > This also seems to have a bunch of race conditions: > - what happens if the oops happens before the pages have > even been swapped in? > - what happens if the oops happens before we've committed > the fb to the hardware? > The panic handler tries to take the panic_lock from the device->mode_config, which should ensure we're not in the middle of a page swap. https://elixir.bootlin.com/linux/v6.14-rc6/source/include/drm/drm_panic.h#L70 https://elixir.bootlin.com/linux/v6.14-rc6/source/include/drm/drm_mode_config.h#L500 If the lock is already taken when the panic handler run, it will skip this device, and won't draw the panic screen on it. Best regards, -- Jocelyn >> >>> + >>> + if (IS_ERR(ptr)) >>> + return; >> >> What happens when the mapping fails? >> >>> + >>> + obj->mm.mapping = page_pack_bits(ptr, I915_MAP_WB); >>> + } >>> + >>> + if (i915_gem_object_has_iomem(obj)) >>> + iosys_map_set_vaddr_iomem(map, (void __iomem *) ptr); >>> + else >>> + iosys_map_set_vaddr(map, ptr); >>> +} >>> + >>> /* get, pin, and map the pages of the object into kernel space */ >>> void *i915_gem_object_pin_map(struct drm_i915_gem_object *obj, >>> enum i915_map_type type) >>> diff --git a/drivers/gpu/drm/xe/display/intel_bo.c b/drivers/gpu/drm/xe/display/intel_bo.c >>> index 27437c22bd70..c68166a64336 100644 >>> --- a/drivers/gpu/drm/xe/display/intel_bo.c >>> +++ b/drivers/gpu/drm/xe/display/intel_bo.c >>> @@ -59,3 +59,13 @@ void intel_bo_describe(struct seq_file *m, struct drm_gem_object *obj) >>> { >>> /* FIXME */ >>> } >>> + >>> +void intel_bo_panic_map(struct drm_gem_object *obj, struct iosys_map *map) >>> +{ >>> + struct xe_bo *bo = gem_to_xe_bo(obj); >>> + int ret; >>> + >>> + ret = ttm_bo_vmap(&bo->ttm, map); >>> + if (ret) >>> + iosys_map_clear(map); >>> +} >>> -- >>> 2.49.0 >> >> -- >> Ville Syrjälä >> Intel >