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 X-Spam-Level: X-Spam-Status: No, score=-3.8 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI, SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED autolearn=no autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 1098DC4363A for ; Tue, 20 Oct 2020 17:02:27 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id 547032222D for ; Tue, 20 Oct 2020 17:02:26 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=ffwll.ch header.i=@ffwll.ch header.b="lgMz8sdc" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2395107AbgJTRCZ (ORCPT ); Tue, 20 Oct 2020 13:02:25 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35818 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2395101AbgJTRCZ (ORCPT ); Tue, 20 Oct 2020 13:02:25 -0400 Received: from mail-oi1-x241.google.com (mail-oi1-x241.google.com [IPv6:2607:f8b0:4864:20::241]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 6392EC0613CE for ; Tue, 20 Oct 2020 10:02:25 -0700 (PDT) Received: by mail-oi1-x241.google.com with SMTP id h10so2869431oie.5 for ; Tue, 20 Oct 2020 10:02:25 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ffwll.ch; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=P4+C5p+llcwaESK7UDZfwOBx7DxHfZ9HboztqP1iS4g=; b=lgMz8sdcu9sQoMGgIE+liuBWO+twfZy/QEazS/rCG3M8l/5Z7Pnh2eZLUsEcAjg7pi /d1J5pYJhBXFThen+TqXCn/G7XFPZX6BohXhBND20NAeI2UfM68dJ73J8+AmkV2P+hTN T5amaeHDUhBP1IY8syyaozxGAz7c22VGCvZaU= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=P4+C5p+llcwaESK7UDZfwOBx7DxHfZ9HboztqP1iS4g=; b=JiJzLX2WY75DvXn1CLf+EbEJk4+DCWsiPun3TSYX8Q/AazH24tbrTeRie3P/M/NRUA pbTaQzJTfXioPzxUIdy0SguwiCH2Fr8yWKUomagPJd6+C5HgV7YB8xNNdJGkqTpfsexc 2fAcAaGwmVTGQgzmb7ZvTbRfy2xaZujZP8jRb8b82ly7gtxijt6qEbVmtEwYiQAcGioN Qc++M3U7N/dh1l/CKri1faMnN8NRl9e6ZpqF+VG8a5XLpBlh1bY11t61xr4fn9LEXkch K3AKtFj6XqCHrawqFU4kWlw30hTq2GskvuHigS87gjwGd8uFlCKvjK7GOyXKcHECizr9 3QLQ== X-Gm-Message-State: AOAM530x5z8QOs+iDoZ47O0GnWZU5JGJsqeRrxyV/FNXuNkAP358le02 QqviymrvClke0WXtDty4nRvU7zf+Chu7RMIxSpE0ng== X-Google-Smtp-Source: ABdhPJziCirkuLc2wSExzSHGfg7J7PUVMZw/wNFmMnlb/m4Wq1PqAKS7o974V3wCQ/yVgCKVfDf1DWuPJoMBwnDl9Po= X-Received: by 2002:aca:cc01:: with SMTP id c1mr2523946oig.128.1603213344582; Tue, 20 Oct 2020 10:02:24 -0700 (PDT) MIME-Version: 1.0 References: <20201019211101.143327-1-robdclark@gmail.com> <20201020082404.GJ401619@phenom.ffwll.local> In-Reply-To: From: Daniel Vetter Date: Tue, 20 Oct 2020 19:02:13 +0200 Message-ID: Subject: Re: [PATCH 0/3] drm/msm: kthread_worker conversion To: Rob Clark Cc: dri-devel , Akhil P Oommen , Tanmay Shah , Bjorn Andersson , AngeloGioacchino Del Regno , Sam Ravnborg , Emil Velikov , Rob Clark , Jonathan Marek , Qinglang Miao , Roy Spliet , Wambui Karuga , linux-arm-msm , Sharat Masetty , Kalyan Thota , Rajendra Nayak , "Gustavo A. R. Silva" , open list , tongtiangen , Thomas Zimmermann , Drew Davenport , "open list:DRM DRIVER FOR MSM ADRENO GPU" Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-arm-msm@vger.kernel.org On Tue, Oct 20, 2020 at 5:08 PM Rob Clark wrote: > > On Tue, Oct 20, 2020 at 7:29 AM Daniel Vetter wrote: > > > > On Tue, Oct 20, 2020 at 4:01 PM Rob Clark wrote: > > > > > > On Tue, Oct 20, 2020 at 1:24 AM Daniel Vetter wrote: > > > > > > > > On Mon, Oct 19, 2020 at 02:10:50PM -0700, Rob Clark wrote: > > > > > From: Rob Clark > > > > > > > > > > In particular, converting the async atomic commit (for cursor updates, > > > > > etc) to SCHED_FIFO kthread_worker helps with some cases where we > > > > > wouldn't manage to flush the updates within the 1ms-before-vblank > > > > > deadline resulting in fps drops when there is cursor movement. > > > > > > > > > > Rob Clark (3): > > > > > drm/msm/gpu: Convert retire/recover work to kthread_worker > > > > > drm/msm/kms: Update msm_kms_init/destroy > > > > > drm/msm/atomic: Convert to per-CRTC kthread_work > > > > > > > > So i915 has it's own commit worker already for $reasons, but I don't think > > > > that's a good path to go down with more drivers. And the problem seems > > > > entirely generic in nature ... > > > > > > I'm not *entirely* sure what your point is here? This is just > > > migrating away from a shared ordered wq to per-crtc kthread so that we > > > don't miss vblank deadlines for silly reasons (and then stall on the > > > next frame's pageflip because we are still waiting for the cursor > > > update to latch). Kind of like vblank-work but scheduled prior to, > > > rather than after, vblank. > > > > > > And you're right that the problem is partially generic.. hw that (a) > > > doesn't have true async (cursor and/or otherwise) updates, and (b) has > > > various flush bits that latch register updates on vblank, is not that > > > uncommon. But the current atomic helper API would have to be a bit > > > redesigned to look more like the interface between msm_atomic and the > > > display backend. That is a fair bit of churn for re-using a small bit > > > of code. > > > > I was making some assumptions about what you're doing, and I was > > wrong. So I went and tried to understand what's actually going on > > here. > > > > I'm trying to understand what exactly you've added with that async msm > > support 2d99ced787e3d. I think this breaks the state structure update > > model, you can't access any ->state pointers from the commit functions > > after you've called drm_atomic_helper_commit_hw_done, or you might > > have a use after free. And that seems to be happening from this commit > > work thing you added to your existing commit work that the atomic > > helpers provide already. > > > > The various commit functions seem to grab various state objects by > > just chasing pointers from the objects (instead of the > > drm_atomic_state stuff), so this all feels like it's yolo > > free-wheeling. > > > > You also seem to be using the async_commit stuff from the atomic > > helpers (which is actually synchronous (i.e. blocking) from the pov of > > how the code runs, but seems to be for mdp5 only and not others. Also > > your can_do_async still checks for legacy_cursor_update (maybe a > > leftover, or needed on !mdp5 platforms) and ->async_update. > > > > I'm thoroughly confused how this all works. > > The legacy_cursor_update is really the thing that motivated the async > commit support in the first place. Sadly we still have userspace that > expects to be able to use legacy cursor API, and that it will be > nonblocking (and not cause fps drop). (I'm not a fan of the legacy > cursor UAPI.. don't hate the player..) Yeah this is why we have these atomic_async_check/commit functions, and msm is even using them for mdp5. Not hating the player here at all. > The premise is to do everything in terms of crtc_mask, although yeah, > it looks like there are a few points that need to look at things like > crtc->state->active. The only point in msm-atomic itself that does > this is vblank_get/put(), possibly we can fix drm_vblank instead and > drop that workaround (see 43906812eaab06423f56af5cca9a9fcdbb4ac454) > > The rest of the async part is really just supposed to be writing the > appropriate flush reg(s) and waiting until flush completes, although > dpu's excess layering makes this harder than it needs to be. > > In practice, the kms->wait_flush() at the top of > msm_atomic_commit_tail() will block until a pending async commit > completes (this is where we hit the fps drop if we miss vblank > deadline), so I don't *think* you can trigger a use-after-free. But > the dpu code could be better cleaned up to have less obj->state > dereference in the kms->flush_commit(crtc_mask)/etc path. Hm this is more or less what the atomic_async_commit/check stuff was meant to help facilitate too, and now msm is using that for mdp5, but not for other pieces. That seems very confusing. Also I'm not sure how this works if you still end up flushing anyway, since then you'd be back to doing everything in-order. Or will an normal atomic flip push all the cursor updates to the next frame (in which case you really should be able to do this all with async helpers we have instead of hand-rolling a bunch of it in strange places). You probably still need the worker to push out the update at the right time, and I'm not sure what some good locking for that is. At least I'm not really seeing how you sync that worker against a racing update for the next cursor move. -Daniel > BR, > -R > > > I do agree though that you probably want this to be a real time fifo > > kthread worker, like for the vblank worker. Except now that I looked, > > I'm not sure it's actually working intended and correct. > > -Daniel > > > > > BR, > > > -R > > > > > > > -Daniel > > > > > > > > > > > > > > drivers/gpu/drm/msm/adreno/a5xx_gpu.c | 3 +-- > > > > > drivers/gpu/drm/msm/adreno/a5xx_preempt.c | 6 ++--- > > > > > drivers/gpu/drm/msm/adreno/a6xx_gmu.c | 4 +-- > > > > > drivers/gpu/drm/msm/adreno/a6xx_gpu.c | 4 +-- > > > > > drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c | 8 +++++- > > > > > drivers/gpu/drm/msm/disp/mdp4/mdp4_kms.c | 8 +++++- > > > > > drivers/gpu/drm/msm/disp/mdp5/mdp5_kms.c | 11 ++++++--- > > > > > drivers/gpu/drm/msm/disp/mdp_kms.h | 9 +++++-- > > > > > drivers/gpu/drm/msm/msm_atomic.c | 25 +++++++++++++++---- > > > > > drivers/gpu/drm/msm/msm_drv.h | 3 ++- > > > > > drivers/gpu/drm/msm/msm_gpu.c | 30 +++++++++++++++-------- > > > > > drivers/gpu/drm/msm/msm_gpu.h | 13 +++++++--- > > > > > drivers/gpu/drm/msm/msm_kms.h | 23 ++++++++++++++--- > > > > > 13 files changed, 104 insertions(+), 43 deletions(-) > > > > > > > > > > -- > > > > > 2.26.2 > > > > > > > > > > _______________________________________________ > > > > > dri-devel mailing list > > > > > dri-devel@lists.freedesktop.org > > > > > https://lists.freedesktop.org/mailman/listinfo/dri-devel > > > > > > > > -- > > > > Daniel Vetter > > > > Software Engineer, Intel Corporation > > > > http://blog.ffwll.ch > > > _______________________________________________ > > > dri-devel mailing list > > > dri-devel@lists.freedesktop.org > > > https://lists.freedesktop.org/mailman/listinfo/dri-devel > > > > > > > > -- > > Daniel Vetter > > Software Engineer, Intel Corporation > > http://blog.ffwll.ch -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch 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 X-Spam-Level: X-Spam-Status: No, score=-3.5 required=3.0 tests=BAYES_00,DKIM_INVALID, DKIM_SIGNED,HEADER_FROM_DIFFERENT_DOMAINS,MAILING_LIST_MULTI,SPF_HELO_NONE, SPF_PASS,URIBL_BLOCKED autolearn=no autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id E631DC41604 for ; Tue, 20 Oct 2020 17:02:28 +0000 (UTC) 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 mail.kernel.org (Postfix) with ESMTPS id 6D4BD2177B for ; Tue, 20 Oct 2020 17:02:28 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=fail reason="signature verification failed" (1024-bit key) header.d=ffwll.ch header.i=@ffwll.ch header.b="lgMz8sdc" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 6D4BD2177B Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=ffwll.ch Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=dri-devel-bounces@lists.freedesktop.org Received: from gabe.freedesktop.org (localhost [127.0.0.1]) by gabe.freedesktop.org (Postfix) with ESMTP id D8B936ED16; Tue, 20 Oct 2020 17:02:26 +0000 (UTC) Received: from mail-oi1-x241.google.com (mail-oi1-x241.google.com [IPv6:2607:f8b0:4864:20::241]) by gabe.freedesktop.org (Postfix) with ESMTPS id 73AC56ED11 for ; Tue, 20 Oct 2020 17:02:25 +0000 (UTC) Received: by mail-oi1-x241.google.com with SMTP id u127so2868264oib.6 for ; Tue, 20 Oct 2020 10:02:25 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ffwll.ch; s=google; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=P4+C5p+llcwaESK7UDZfwOBx7DxHfZ9HboztqP1iS4g=; b=lgMz8sdcu9sQoMGgIE+liuBWO+twfZy/QEazS/rCG3M8l/5Z7Pnh2eZLUsEcAjg7pi /d1J5pYJhBXFThen+TqXCn/G7XFPZX6BohXhBND20NAeI2UfM68dJ73J8+AmkV2P+hTN T5amaeHDUhBP1IY8syyaozxGAz7c22VGCvZaU= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=P4+C5p+llcwaESK7UDZfwOBx7DxHfZ9HboztqP1iS4g=; b=HmYN0wwZ+sF3N6eaFp2paI0ZP7P/1NI6N/egG01WIjkDkoEh8Uw57EVpc2Ylz8k+L/ nx3HfFMQsCz+8nkZcXAVpOl2OagkAzc8ZAmAEOrmGswx15KgQudxSH5nhO7rqQ6Z9Roi o2jJ3KTW3S6X3/JR/TWInuGqhZbD7qDBF/j0inLaSbm6qXEwOySaGcKRCHfBieMRqGu/ YQKdsIpPiGI/DqMLwRsQ1iXp06L7/bp2QakR9doW7tQjVwSsWHpjRjH3e83VTJq+n5RO xHF28UdKwAyIVIwycnZX5kDSDypVK1BLsU+nO5E/Mu87CGI7nNUSoIgYl9tTNCFhnQ3x TJKA== X-Gm-Message-State: AOAM5335rFVCxIo5w7AGHH0PB8HGm9eZ6hS1KB4PWukmd6eYQ42WZwPQ qnsyN5BLOu3mXyxnOa7WCywS0IED++5oB53koiPaeQ== X-Google-Smtp-Source: ABdhPJziCirkuLc2wSExzSHGfg7J7PUVMZw/wNFmMnlb/m4Wq1PqAKS7o974V3wCQ/yVgCKVfDf1DWuPJoMBwnDl9Po= X-Received: by 2002:aca:cc01:: with SMTP id c1mr2523946oig.128.1603213344582; Tue, 20 Oct 2020 10:02:24 -0700 (PDT) MIME-Version: 1.0 References: <20201019211101.143327-1-robdclark@gmail.com> <20201020082404.GJ401619@phenom.ffwll.local> In-Reply-To: From: Daniel Vetter Date: Tue, 20 Oct 2020 19:02:13 +0200 Message-ID: Subject: Re: [PATCH 0/3] drm/msm: kthread_worker conversion To: Rob Clark 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: , Cc: Akhil P Oommen , Tanmay Shah , Bjorn Andersson , AngeloGioacchino Del Regno , Sam Ravnborg , Emil Velikov , Rob Clark , Jonathan Marek , Qinglang Miao , Roy Spliet , Wambui Karuga , linux-arm-msm , Sharat Masetty , dri-devel , Kalyan Thota , Rajendra Nayak , "Gustavo A. R. Silva" , open list , tongtiangen , Thomas Zimmermann , Drew Davenport , "open list:DRM DRIVER FOR MSM ADRENO GPU" Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" On Tue, Oct 20, 2020 at 5:08 PM Rob Clark wrote: > > On Tue, Oct 20, 2020 at 7:29 AM Daniel Vetter wrote: > > > > On Tue, Oct 20, 2020 at 4:01 PM Rob Clark wrote: > > > > > > On Tue, Oct 20, 2020 at 1:24 AM Daniel Vetter wrote: > > > > > > > > On Mon, Oct 19, 2020 at 02:10:50PM -0700, Rob Clark wrote: > > > > > From: Rob Clark > > > > > > > > > > In particular, converting the async atomic commit (for cursor updates, > > > > > etc) to SCHED_FIFO kthread_worker helps with some cases where we > > > > > wouldn't manage to flush the updates within the 1ms-before-vblank > > > > > deadline resulting in fps drops when there is cursor movement. > > > > > > > > > > Rob Clark (3): > > > > > drm/msm/gpu: Convert retire/recover work to kthread_worker > > > > > drm/msm/kms: Update msm_kms_init/destroy > > > > > drm/msm/atomic: Convert to per-CRTC kthread_work > > > > > > > > So i915 has it's own commit worker already for $reasons, but I don't think > > > > that's a good path to go down with more drivers. And the problem seems > > > > entirely generic in nature ... > > > > > > I'm not *entirely* sure what your point is here? This is just > > > migrating away from a shared ordered wq to per-crtc kthread so that we > > > don't miss vblank deadlines for silly reasons (and then stall on the > > > next frame's pageflip because we are still waiting for the cursor > > > update to latch). Kind of like vblank-work but scheduled prior to, > > > rather than after, vblank. > > > > > > And you're right that the problem is partially generic.. hw that (a) > > > doesn't have true async (cursor and/or otherwise) updates, and (b) has > > > various flush bits that latch register updates on vblank, is not that > > > uncommon. But the current atomic helper API would have to be a bit > > > redesigned to look more like the interface between msm_atomic and the > > > display backend. That is a fair bit of churn for re-using a small bit > > > of code. > > > > I was making some assumptions about what you're doing, and I was > > wrong. So I went and tried to understand what's actually going on > > here. > > > > I'm trying to understand what exactly you've added with that async msm > > support 2d99ced787e3d. I think this breaks the state structure update > > model, you can't access any ->state pointers from the commit functions > > after you've called drm_atomic_helper_commit_hw_done, or you might > > have a use after free. And that seems to be happening from this commit > > work thing you added to your existing commit work that the atomic > > helpers provide already. > > > > The various commit functions seem to grab various state objects by > > just chasing pointers from the objects (instead of the > > drm_atomic_state stuff), so this all feels like it's yolo > > free-wheeling. > > > > You also seem to be using the async_commit stuff from the atomic > > helpers (which is actually synchronous (i.e. blocking) from the pov of > > how the code runs, but seems to be for mdp5 only and not others. Also > > your can_do_async still checks for legacy_cursor_update (maybe a > > leftover, or needed on !mdp5 platforms) and ->async_update. > > > > I'm thoroughly confused how this all works. > > The legacy_cursor_update is really the thing that motivated the async > commit support in the first place. Sadly we still have userspace that > expects to be able to use legacy cursor API, and that it will be > nonblocking (and not cause fps drop). (I'm not a fan of the legacy > cursor UAPI.. don't hate the player..) Yeah this is why we have these atomic_async_check/commit functions, and msm is even using them for mdp5. Not hating the player here at all. > The premise is to do everything in terms of crtc_mask, although yeah, > it looks like there are a few points that need to look at things like > crtc->state->active. The only point in msm-atomic itself that does > this is vblank_get/put(), possibly we can fix drm_vblank instead and > drop that workaround (see 43906812eaab06423f56af5cca9a9fcdbb4ac454) > > The rest of the async part is really just supposed to be writing the > appropriate flush reg(s) and waiting until flush completes, although > dpu's excess layering makes this harder than it needs to be. > > In practice, the kms->wait_flush() at the top of > msm_atomic_commit_tail() will block until a pending async commit > completes (this is where we hit the fps drop if we miss vblank > deadline), so I don't *think* you can trigger a use-after-free. But > the dpu code could be better cleaned up to have less obj->state > dereference in the kms->flush_commit(crtc_mask)/etc path. Hm this is more or less what the atomic_async_commit/check stuff was meant to help facilitate too, and now msm is using that for mdp5, but not for other pieces. That seems very confusing. Also I'm not sure how this works if you still end up flushing anyway, since then you'd be back to doing everything in-order. Or will an normal atomic flip push all the cursor updates to the next frame (in which case you really should be able to do this all with async helpers we have instead of hand-rolling a bunch of it in strange places). You probably still need the worker to push out the update at the right time, and I'm not sure what some good locking for that is. At least I'm not really seeing how you sync that worker against a racing update for the next cursor move. -Daniel > BR, > -R > > > I do agree though that you probably want this to be a real time fifo > > kthread worker, like for the vblank worker. Except now that I looked, > > I'm not sure it's actually working intended and correct. > > -Daniel > > > > > BR, > > > -R > > > > > > > -Daniel > > > > > > > > > > > > > > drivers/gpu/drm/msm/adreno/a5xx_gpu.c | 3 +-- > > > > > drivers/gpu/drm/msm/adreno/a5xx_preempt.c | 6 ++--- > > > > > drivers/gpu/drm/msm/adreno/a6xx_gmu.c | 4 +-- > > > > > drivers/gpu/drm/msm/adreno/a6xx_gpu.c | 4 +-- > > > > > drivers/gpu/drm/msm/disp/dpu1/dpu_kms.c | 8 +++++- > > > > > drivers/gpu/drm/msm/disp/mdp4/mdp4_kms.c | 8 +++++- > > > > > drivers/gpu/drm/msm/disp/mdp5/mdp5_kms.c | 11 ++++++--- > > > > > drivers/gpu/drm/msm/disp/mdp_kms.h | 9 +++++-- > > > > > drivers/gpu/drm/msm/msm_atomic.c | 25 +++++++++++++++---- > > > > > drivers/gpu/drm/msm/msm_drv.h | 3 ++- > > > > > drivers/gpu/drm/msm/msm_gpu.c | 30 +++++++++++++++-------- > > > > > drivers/gpu/drm/msm/msm_gpu.h | 13 +++++++--- > > > > > drivers/gpu/drm/msm/msm_kms.h | 23 ++++++++++++++--- > > > > > 13 files changed, 104 insertions(+), 43 deletions(-) > > > > > > > > > > -- > > > > > 2.26.2 > > > > > > > > > > _______________________________________________ > > > > > dri-devel mailing list > > > > > dri-devel@lists.freedesktop.org > > > > > https://lists.freedesktop.org/mailman/listinfo/dri-devel > > > > > > > > -- > > > > Daniel Vetter > > > > Software Engineer, Intel Corporation > > > > http://blog.ffwll.ch > > > _______________________________________________ > > > dri-devel mailing list > > > dri-devel@lists.freedesktop.org > > > https://lists.freedesktop.org/mailman/listinfo/dri-devel > > > > > > > > -- > > Daniel Vetter > > Software Engineer, Intel Corporation > > http://blog.ffwll.ch -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch _______________________________________________ dri-devel mailing list dri-devel@lists.freedesktop.org https://lists.freedesktop.org/mailman/listinfo/dri-devel