Received: by 2002:a5d:9c59:0:0:0:0:0 with SMTP id 25csp134723iof; Sun, 5 Jun 2022 23:24:07 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwzQxH02LwjMyWUGMpWn2MdgujAI5aNGCPtp/wm3ouH04c8GeFEKfgRsrRXyAkyx2NG/PMp X-Received: by 2002:a63:6b82:0:b0:3fd:1865:a783 with SMTP id g124-20020a636b82000000b003fd1865a783mr14408442pgc.500.1654496647367; Sun, 05 Jun 2022 23:24:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1654496647; cv=none; d=google.com; s=arc-20160816; b=LIM2XoWHjyVN+zHVzGbkmmeeVaj2QcXU/snRxw4cPjmsqY5TlfMM2nxRP8pyp8gOg8 3KIuHf21ZD4zvyDNdFmU0CG/OOz1D9ME8CvnQzK+d5ZhrAu9R/zHTvAANtygh9BOLSi5 KS3kOztibx4RO/xx5fGaVukFVoHiqTZI9vNqpP3IK6QhkLx1nyc/K/rINjFf4rzoKWBj pxkXM1yC74P4Op8JicGFItNXP6VYct+hq+kRalZdLagyYtE8QFlM8L4w42mbYh4s4v8h N329y4VStL87frC/W2Hj8nrYeWFze7tp/sV7/kGqS3DWdd/7Ia47z030ZhNDH/MX9aVT YtuA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=V48jIpUPpkwi/mXw0vV1qlo/0R+nh6UqO3bUzG0QHns=; b=w7DVae0VkuV9ITfs7EvzNHb9bP7pguVygiVBYcDb/URsUlo9PgwNQiU572nAUyHKV9 a0P4IEwNJaVGpktmFdfuGILsEYDHRy+8tpvyvvTPga9dfMpX8YD1dgz8g7sedDY0w23I XW4eH/6Dwk1zsSPlUpTKVwDWNBRSIqLJRtsLuXJ3DAXSyR1fKC0UAyLcGDWMaFUhzDmX udzPI1BM9Wph8DCixMCcJonkpIe4icN1+tlbiSTh/mQKgksttibmhmIlPGf+/RwLf62S qmvYaIl/x1D++8ni2e64A7cMGhozpxYQ9DEl6Sj5VIvBompCiPKX4FOPE1yVX3OT1hc2 LAEw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=nqQSjOva; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [2620:137:e000::1:18]) by mx.google.com with ESMTPS id mh17-20020a17090b4ad100b001e839b85f69si10522343pjb.47.2022.06.05.23.24.07 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 05 Jun 2022 23:24:07 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) client-ip=2620:137:e000::1:18; Authentication-Results: mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=nqQSjOva; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id D735D12DBCB; Sun, 5 Jun 2022 22:06:41 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229494AbiFFFGT (ORCPT + 99 others); Mon, 6 Jun 2022 01:06:19 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51886 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229453AbiFFFGR (ORCPT ); Mon, 6 Jun 2022 01:06:17 -0400 Received: from mail-pl1-x62d.google.com (mail-pl1-x62d.google.com [IPv6:2607:f8b0:4864:20::62d]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id E19214926F for ; Sun, 5 Jun 2022 21:47:27 -0700 (PDT) Received: by mail-pl1-x62d.google.com with SMTP id w3so11202948plp.13 for ; Sun, 05 Jun 2022 21:47:27 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=V48jIpUPpkwi/mXw0vV1qlo/0R+nh6UqO3bUzG0QHns=; b=nqQSjOvanX+8t+tfNQWjxQaFfRS/+GiSKg6PgDaC+vs0EtY834wW/8lUSx+MIh6+66 QxSZBzAa72S8ewu9/W+7na7Kc7k0dqpizfCf/j+3vNxRtbDBwkBlrf52exTYP/uHo+77 Ssb8uKKBEcUSKuPtsbTbCH81UkVrmiSnDCncw= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id:mime-version :content-transfer-encoding; bh=V48jIpUPpkwi/mXw0vV1qlo/0R+nh6UqO3bUzG0QHns=; b=osgjjDtzqwm1m+uzs2/hUujR1OMwwU+HO+ZwJZiFvMx758GdXCqEGypJlUpZTiVyNB pjVGKBek32adTjHS+FnPfnHCaEeLhD4+c347djIlGBMS8hYbBdgY31IGCnPpnfWjL83K tT220NK7c+4vYwXUv4Ynt2Bf0iezIeAelpV1h9aZ8wVqVFomkEL5K0kBquXXglufCfqE AeOd2TP66AY0dtsqiv0AQSnR7DsSiiS75tJm+c1ku60JyAs/mAG92yayP3oXk0HjgZ1x 0Madfq9bN7AHclKq+n51R51J17JpLZuFvh8XpSHLNgzt+Z+Eo0CQEP03x8Vp5TpwmV1c DSgw== X-Gm-Message-State: AOAM533EDsl+mNLISjTLBRRShqP+g77WeYJA14fhZNiD+94BYmbTfKLx A3nHmbwxeGA5rwf5IwDbU+JYlg== X-Received: by 2002:a17:90a:c002:b0:1d9:250a:73c8 with SMTP id p2-20020a17090ac00200b001d9250a73c8mr24459800pjt.133.1654490847065; Sun, 05 Jun 2022 21:47:27 -0700 (PDT) Received: from hsinyi-z840.tpe.corp.google.com ([2401:fa00:1:10:ced3:b110:401b:b32c]) by smtp.gmail.com with ESMTPSA id t190-20020a6381c7000000b003db7de758besm9718609pgd.5.2022.06.05.21.47.23 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Sun, 05 Jun 2022 21:47:26 -0700 (PDT) From: Hsin-Yi Wang To: Chun-Kuang Hu Cc: Hans de Goede , Thierry Reding , Sam Ravnborg , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , Philipp Zabel , David Airlie , Daniel Vetter , Matthias Brugger , dri-devel@lists.freedesktop.org, linux-mediatek@lists.infradead.org, Rob Clark , Stephen Boyd , Douglas Anderson , Rob Herring , linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH v3 0/8] Add a panel API to return panel orientation Date: Mon, 6 Jun 2022 12:47:12 +0800 Message-Id: <20220606044720.945964-1-hsinyi@chromium.org> X-Mailer: git-send-email 2.36.1.255.ge46751e96f-goog MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-3.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Panels usually call drm_connector_set_panel_orientation(), which is later than drm/kms driver calling drm_dev_register(). This leads to a WARN()[1]. The orientation property is known earlier. For example, some panels parse the property through device tree during probe. The series add a panel API drm_panel_get_orientation() for drm/kms drivers. The drivers can use the API to get panel's orientation, so they can call drm_connector_set_panel_orientation() before drm_dev_register(). Panel needs to implement .get_orientation callback to return the property. [1] https://patchwork.kernel.org/project/linux-mediatek/patch/20220530081910.3947168-2-hsinyi@chromium.org/ Hsin-Yi Wang (8): drm/panel: Add an API drm_panel_get_orientation() to return panel orientation drm/panel: boe-tv101wum-nl6: Implement .get_orientation callback drm/panel: panel-edp: Implement .get_orientation callback drm/panel: lvds: Implement .get_orientation callback drm/panel: panel-simple: Implement .get_orientation callback drm/panel: ili9881c: Implement .get_orientation callback drm/panel: elida-kd35t133: Implement .get_orientation callback drm/mediatek: Config orientation property if panel provides it drivers/gpu/drm/drm_panel.c | 8 ++++++++ drivers/gpu/drm/mediatek/mtk_dsi.c | 10 ++++++++++ drivers/gpu/drm/panel/panel-boe-tv101wum-nl6.c | 14 ++++++++++++++ drivers/gpu/drm/panel/panel-edp.c | 15 ++++++++++++++- drivers/gpu/drm/panel/panel-elida-kd35t133.c | 14 ++++++++++++++ drivers/gpu/drm/panel/panel-ilitek-ili9881c.c | 14 ++++++++++++++ drivers/gpu/drm/panel/panel-lvds.c | 14 ++++++++++++++ drivers/gpu/drm/panel/panel-simple.c | 16 +++++++++++++++- include/drm/drm_panel.h | 10 ++++++++++ 9 files changed, 113 insertions(+), 2 deletions(-) -- 2.36.1.255.ge46751e96f-goog