From patchwork Mon Feb 1 13:38:24 2021 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Xuezhi Zhang X-Patchwork-Id: 12059065 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=-15.7 required=3.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,FREEMAIL_FORGED_FROMDOMAIN,FREEMAIL_FROM, HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_CR_TRAILER,INCLUDES_PATCH, MAILING_LIST_MULTI,SPF_HELO_NONE,SPF_PASS,URIBL_BLOCKED,USER_AGENT_GIT autolearn=unavailable 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 F1D7AC433DB for ; Mon, 1 Feb 2021 13:39:20 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id A0EFB64E7A for ; Mon, 1 Feb 2021 13:39:20 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231405AbhBANjE (ORCPT ); Mon, 1 Feb 2021 08:39:04 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46034 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229707AbhBANjC (ORCPT ); Mon, 1 Feb 2021 08:39:02 -0500 Received: from mail-pg1-x531.google.com (mail-pg1-x531.google.com [IPv6:2607:f8b0:4864:20::531]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id BDC9BC061573; Mon, 1 Feb 2021 05:38:20 -0800 (PST) Received: by mail-pg1-x531.google.com with SMTP id o16so12097973pgg.5; Mon, 01 Feb 2021 05:38:20 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id; bh=7Caf+TB7h06nb0xxu/+sgOXyFULnYGYCV3FXEmFfuj0=; b=HnJZZN66mPlNbBSAdES3ijMvErvph2BvCvS/hx6+qoXWGuh2iYq9FY0h7ET9B3EhQY Fh3kK+qIVAF6WlCVVAj/K26djrrq8irbt5Q/c26ZNc6wqPGAk1YecW97F0tP7602ox2P ITC6IJfE6d9qw/FvuB6a/l2wgtzUZ5nnwCWhCxK+MuGQ481xH6/mi/172gtL9L/gIvaY QD0pmjB87eUeOKgxQdA2+1/TG4LBc377OhIfwQtbg10mkFLndBtQ7T4MzHPylaF2kZ+o phphNUb7mopfNTi08AuwWztiTEQBfsKEHJ1hdc3WCjPQYCe4eGVB/Om+dY3cc9auB1rz pO5A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=7Caf+TB7h06nb0xxu/+sgOXyFULnYGYCV3FXEmFfuj0=; b=C4dcXXGfI0H5Bz0i1Fcm7RqiBUYbOeJEj2NODH675b+lbp/6HFUArY2xxBFXzdVC3O txqoK2UU8DvFXMOacni173nGwml8yfUuQc4yGqKmrVs3BkTxdFicv5fAgPOZ6OYI8KBU ziQJ4ns+W2Q4L4Jfl8wWG+hP6m1UAtfSuq7yRJ7m4rS0bzQALgvMfmOH8ETcBz2Pv7ar tIotB7FZ6aL3N1LVV71ZjsGsNOwjG0z+kXoC/08XpIqpP/CtXRQkQkDM6z+s9eDjMMBP pbpanUj8g8phpPC/cCcMlSmJK7Vl3RTVUEd11J4qPCE3Phu01QbZLkidQY0nteix1Jp9 Bfxg== X-Gm-Message-State: AOAM531WaaJ3QX7P7B+llaOHozOHYASs+cXTpbvcHeqroobYMAE8fSm+ HJ8nqAPfjgdQUPAkYPAKpJQ= X-Google-Smtp-Source: ABdhPJwUgQ7Es/Fic0jA/FSGL4cg/vEKJivgdQ/LGulL6iqxcF4SmqtgM7X+Buc+5Cg5X9pR4g3ZKg== X-Received: by 2002:a63:5221:: with SMTP id g33mr16966842pgb.202.1612186700238; Mon, 01 Feb 2021 05:38:20 -0800 (PST) Received: from bf-rmsz-10.ccdomain.com ([103.220.76.197]) by smtp.gmail.com with ESMTPSA id bj18sm15670597pjb.40.2021.02.01.05.38.17 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Mon, 01 Feb 2021 05:38:19 -0800 (PST) From: Carlis To: gregkh@linuxfoundation.org Cc: colin.king@canonical.com, oliver.graute@kococonnector.com, zhangxuezhi1@yulong.com, mh12gx2825@gmail.com, sbrivio@redhat.com, dri-devel@lists.freedesktop.org, linux-fbdev@vger.kernel.org, devel@driverdev.osuosl.org, linux-kernel@vger.kernel.org Subject: [PATCH v13] staging: fbtft: add tearing signal detect Date: Mon, 1 Feb 2021 21:38:24 +0800 Message-Id: <1612186704-161451-1-git-send-email-zhangxuezhi3@gmail.com> X-Mailer: git-send-email 1.9.1 Precedence: bulk List-ID: X-Mailing-List: linux-fbdev@vger.kernel.org From: Carlis For st7789v IC, when we need continuous full screen refresh, it is best to wait for the tearing effect line signal to arrive to avoid screen tearing. Signed-off-by: Carlis --- v13: change TE completion to par data struct member and add a new function to deal te gpio request, move wait logic to fbtft_write_vmem16_bus8. v12: change dev_err to dev_err_probe and add space in comments start, and delete te_mutex, change te wait logic. v11: remove devm_gpio_put and change a dev_err to dev_info. v10: additional notes. v9: change pr_* to dev_*. v8: delete a log line. v7: return error value when request fail. v6: add te gpio request fail deal logic. v5: fix log print. v4: modify some code style and change te irq set function name. v3: modify author and signed-off-by name. v2: add release te gpio after irq request fail. --- drivers/staging/fbtft/fb_st7789v.c | 112 +++++++++++++++++++++++++++++++++++++ drivers/staging/fbtft/fbtft.h | 5 ++ 2 files changed, 117 insertions(+) diff --git a/drivers/staging/fbtft/fb_st7789v.c b/drivers/staging/fbtft/fb_st7789v.c index 3a280cc..7b41bad 100644 --- a/drivers/staging/fbtft/fb_st7789v.c +++ b/drivers/staging/fbtft/fb_st7789v.c @@ -7,9 +7,13 @@ #include #include +#include #include #include +#include +#include #include + #include