Received: by 2002:ad5:4acb:0:0:0:0:0 with SMTP id n11csp412826imw; Thu, 14 Jul 2022 03:58:42 -0700 (PDT) X-Google-Smtp-Source: AGRyM1s7WEUAx7MZslfbWGnDuxBz0YoWMtt+ta0Twl3a0QZErOkLdDquRzJwgvlHktwfBViI9/B5 X-Received: by 2002:a17:907:2808:b0:72b:50cd:2c8a with SMTP id eb8-20020a170907280800b0072b50cd2c8amr7923017ejc.246.1657796321980; Thu, 14 Jul 2022 03:58:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1657796321; cv=none; d=google.com; s=arc-20160816; b=U8eFPUfZ9QN3SyXqamJ0VnKU2Ulv/a+6KTa0U9QE3vllYRqHD7u8x87SXAZmfzbdqu JYGZAowNkQrukkZCYoiBDiq4xxFALKWkFwk6nhVBloB0IAsKsMsSNr1uucTgX8LPnzb2 faIRSKAyEx49CEbRWxR8jVJn8rM5NelNqVJftfFzTEPHEARG0KW9th9cNatIoEcp6Fh9 Ehm5bfAYRPchBvhygMXtatop158fstrVWpu4P8kMJLuWXkStUt0dv6RN31lX8tmT7OE8 tWp6h8RvRLC0WAxT3rNnaigsk/mJpilgHBvr+NOI0Y9KYAmu0t+xVVzdkfCU2oFe3uOi NB3w== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=laS+z20t8W+gu6qSBY5WxZVfLb3N5kS2iCZpDzyZ0fM=; b=vLyNKV4SsBTTt0XU3aehYhC+GXbozdJEQ6WVfTF2jQg1Gljifjq2/2X+HX+tQhIA45 m2t1F5LXUjpR4qo92U4DrQEIyGjXTBrgbvnEXtjimxIawn6orzo/qImyMkExuzMo9SC8 yGLoUuFkcslyevW59g1AaevZ82Ovjty/HmdgB1+wbnsrTEXf2gx+Fank2ZIvvM4I539F Eqq2nZhM9FIF//PeQDQ0d8cwu6FfuB70p5PIIyRVP6D4TtInK3KCZ4GYU8Ou/p6d71+o 4coHlY+870E2tEXwFvfyDsy071d6IwT8kwpgyXAeQ7oULIGfhR3xq7vwbPNu8zK+v2zQ ayyg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id ga4-20020a1709070c0400b00726ab8af824si1749503ejc.788.2022.07.14.03.58.17; Thu, 14 Jul 2022 03:58:41 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231549AbiGNKUN (ORCPT + 99 others); Thu, 14 Jul 2022 06:20:13 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59404 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232009AbiGNKUK (ORCPT ); Thu, 14 Jul 2022 06:20:10 -0400 Received: from xavier.telenet-ops.be (xavier.telenet-ops.be [IPv6:2a02:1800:120:4::f00:14]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 1BE0922298 for ; Thu, 14 Jul 2022 03:20:07 -0700 (PDT) Received: from ramsan.of.borg ([84.195.186.194]) by xavier.telenet-ops.be with bizsmtp id uyL32700G4C55Sk01yL3Cw; Thu, 14 Jul 2022 12:20:05 +0200 Received: from rox.of.borg ([192.168.97.57]) by ramsan.of.borg with esmtps (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.93) (envelope-from ) id 1oBvwx-003The-0z; Thu, 14 Jul 2022 12:20:03 +0200 Received: from geert by rox.of.borg with local (Exim 4.93) (envelope-from ) id 1oBulZ-00Bf27-Ik; Thu, 14 Jul 2022 11:04:13 +0200 From: Geert Uytterhoeven To: Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Daniel Vetter , Hans de Goede Cc: dri-devel@lists.freedesktop.org, linux-fbdev@vger.kernel.org, linux-m68k@vger.kernel.org, linux-kernel@vger.kernel.org, Geert Uytterhoeven Subject: [PATCH v2 4/5] drm/modes: Add support for driver-specific named modes Date: Thu, 14 Jul 2022 11:04:09 +0200 Message-Id: <528b126b3d932bff055ff085e598b91e2e690a4e.1657788997.git.geert@linux-m68k.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-2.6 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_LOW, SPF_HELO_NONE,SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=ham 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 The mode parsing code recognizes named modes only if they are explicitly listed in the internal whitelist, which is currently limited to "NTSC" and "PAL". Provide a mechanism for drivers to override this list to support custom mode names. Ideally, this list should just come from the driver's actual list of modes, but connector->probed_modes is not yet populated at the time of parsing. Signed-off-by: Geert Uytterhoeven Reviewed-by: Hans de Goede --- v2: - Add Reviewed-by. --- drivers/gpu/drm/drm_modes.c | 15 +++++++++++---- include/drm/drm_connector.h | 10 ++++++++++ 2 files changed, 21 insertions(+), 4 deletions(-) diff --git a/drivers/gpu/drm/drm_modes.c b/drivers/gpu/drm/drm_modes.c index 0cbf0467f263b30a..bfc3a08614522689 100644 --- a/drivers/gpu/drm/drm_modes.c +++ b/drivers/gpu/drm/drm_modes.c @@ -1748,24 +1748,30 @@ static int drm_mode_parse_cmdline_options(const char *str, static const char * const drm_named_modes_whitelist[] = { "NTSC", "PAL", + NULL }; static int drm_mode_parse_cmdline_named_mode(const char *name, unsigned int length, bool refresh, + const struct drm_connector *connector, struct drm_cmdline_mode *mode) { + const char * const *named_modes_whitelist; unsigned int i; int ret; - for (i = 0; i < ARRAY_SIZE(drm_named_modes_whitelist); i++) { - ret = str_has_prefix(name, drm_named_modes_whitelist[i]); + named_modes_whitelist = connector->named_modes_whitelist ? : + drm_named_modes_whitelist; + + for (i = 0; named_modes_whitelist[i]; i++) { + ret = str_has_prefix(name, named_modes_whitelist[i]); if (ret != length) continue; if (refresh) return -EINVAL; /* named + refresh is invalid */ - strcpy(mode->name, drm_named_modes_whitelist[i]); + strcpy(mode->name, named_modes_whitelist[i]); mode->specified = true; return 0; } @@ -1849,7 +1855,8 @@ bool drm_mode_parse_command_line_for_connector(const char *mode_option, /* First check for a named mode */ if (mode_end) { ret = drm_mode_parse_cmdline_named_mode(name, mode_end, - refresh_ptr, mode); + refresh_ptr, connector, + mode); if (ret) return false; } diff --git a/include/drm/drm_connector.h b/include/drm/drm_connector.h index 3ac4bf87f2571c4c..6361f8a596c01107 100644 --- a/include/drm/drm_connector.h +++ b/include/drm/drm_connector.h @@ -1659,6 +1659,16 @@ struct drm_connector { /** @hdr_sink_metadata: HDR Metadata Information read from sink */ struct hdr_sink_metadata hdr_sink_metadata; + + /** + * @named_modes_whitelist: + * + * Optional NULL-terminated array of names to be considered valid mode + * names. This lets the command line option parser distinguish between + * mode names and freestanding extras and/or options. + * If not set, a set of defaults will be used. + */ + const char * const *named_modes_whitelist; }; #define obj_to_connector(x) container_of(x, struct drm_connector, base) -- 2.25.1