Received: by 2002:ac0:a5a6:0:0:0:0:0 with SMTP id m35-v6csp2491272imm; Mon, 24 Sep 2018 05:24:01 -0700 (PDT) X-Google-Smtp-Source: ACcGV61A4lREsam2dy4QQR6uQXWBwPwYIbG/pED/OuH9/uMW2d/pwlp4GsP716Mx4JPJbiFEYrIr X-Received: by 2002:a63:2bc9:: with SMTP id r192-v6mr9404161pgr.386.1537791841364; Mon, 24 Sep 2018 05:24:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1537791841; cv=none; d=google.com; s=arc-20160816; b=v+vZEKJT/kElN/hfoGyv8m3DuLnYPiBv2CbsnenT4M18qh3OGfwsemzMwb5ZIBEQOe kH99VN5CK9FwtRpcOC7aH8zPo7YrP9Pz4/bV6iBL9JMxTfoIfhiroCzaZwG+ddbTXIAA 8c5NpkKge1Sep/CItZvKDI+CM6RbM2axUyFM0FdfmdMI6RdzkKctvd85OKxhUu2l9r5k 3xTH3XW1IpY+1TIh2+J9KV6EoZRySRUGTD9L6XP+PDaPgOUa8Fh5b2WnodcSvYuaHr0j C2X2stMXgAUOn3rkjEIGQwftNLVhmukS+kWDwRbo0YmzwAseWGKkX5rmQiIIp6v+CM7d pcmg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from; bh=tnhPScJBZyyropRfJEh9LDEogLknq6n1TTE5+/A0kH8=; b=fh6soCie2RKpztYb1N+jhYKaywG0PFXijSrCeNF3mlQ9v/EDCPplAsjgGsgU3MOp+X ealgt3sTw7M5j+mcdtVjjV/Ws/+SImmdhwEhBaVjzwmw02B/nDFRB3KfBROLc4CiqIed 0tNUvzv4092WNzGZVaYMETl4cZY2bY6D5d396WOUCVh4JVc4oh0uDSH4k+uslZUIht+o VUjWVnZZZMGvJChzK94FMW9p/fNJ56dT0pdpsLQIA3AsZur/lnHvU51wmrjVVWxlx55j 3Oj7Gy09PhQIFy1NnR7auz1PqdgAsnmGqlQ0PNQZFisTmLkchkb6vH6o9ogwPZO8AEAl s5Ug== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x22-v6si34313314pfh.84.2018.09.24.05.23.45; Mon, 24 Sep 2018 05:24:01 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732339AbeIXSXR (ORCPT + 99 others); Mon, 24 Sep 2018 14:23:17 -0400 Received: from mail.linuxfoundation.org ([140.211.169.12]:56272 "EHLO mail.linuxfoundation.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732318AbeIXSXQ (ORCPT ); Mon, 24 Sep 2018 14:23:16 -0400 Received: from localhost (ip-213-127-77-73.ip.prioritytelecom.net [213.127.77.73]) by mail.linuxfoundation.org (Postfix) with ESMTPSA id 97D62108A; Mon, 24 Sep 2018 12:21:23 +0000 (UTC) From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, "H. Nikolaus Schaller" , Christ van Willegen , Haojian Zhuang , Jacopo Mondi , Paul Cercueil , Sean Wang , Tony Lindgren , Andy Shevchenko , Linus Walleij , Sasha Levin Subject: [PATCH 4.14 120/173] pinctrl: pinmux: Return selector to the pinctrl driver Date: Mon, 24 Sep 2018 13:52:34 +0200 Message-Id: <20180924113124.799928646@linuxfoundation.org> X-Mailer: git-send-email 2.19.0 In-Reply-To: <20180924113114.334025954@linuxfoundation.org> References: <20180924113114.334025954@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.14-stable review patch. If anyone has any objections, please let me know. ------------------ From: Tony Lindgren [ Upstream commit f913cfce4ee49a3382a9ff95696f49a46e56e974 ] We must return the selector from pinmux_generic_add_function() so pin controller device drivers can remove the right group if needed for deferred probe for example. And we now must make sure that a proper name is passed so we can use it to check if the entry already exists. Note that fixes are also needed for the pin controller drivers to use the selector value. Fixes: a76edc89b100 ("pinctrl: core: Add generic pinctrl functions for managing groups") Reported-by: H. Nikolaus Schaller Cc: Christ van Willegen Cc: Haojian Zhuang Cc: Jacopo Mondi Cc: Paul Cercueil Cc: Sean Wang Signed-off-by: Tony Lindgren Tested-By: H. Nikolaus Schaller Reviewed-by: Andy Shevchenko Signed-off-by: Linus Walleij Signed-off-by: Sasha Levin Signed-off-by: Greg Kroah-Hartman --- drivers/pinctrl/pinmux.c | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) --- a/drivers/pinctrl/pinmux.c +++ b/drivers/pinctrl/pinmux.c @@ -308,7 +308,6 @@ static int pinmux_func_name_to_selector( selector++; } - dev_err(pctldev->dev, "function '%s' not supported\n", function); return -EINVAL; } @@ -777,6 +776,16 @@ int pinmux_generic_add_function(struct p void *data) { struct function_desc *function; + int selector; + + if (!name) + return -EINVAL; + + selector = pinmux_func_name_to_selector(pctldev, name); + if (selector >= 0) + return selector; + + selector = pctldev->num_functions; function = devm_kzalloc(pctldev->dev, sizeof(*function), GFP_KERNEL); if (!function) @@ -787,12 +796,11 @@ int pinmux_generic_add_function(struct p function->num_group_names = num_groups; function->data = data; - radix_tree_insert(&pctldev->pin_function_tree, pctldev->num_functions, - function); + radix_tree_insert(&pctldev->pin_function_tree, selector, function); pctldev->num_functions++; - return 0; + return selector; } EXPORT_SYMBOL_GPL(pinmux_generic_add_function);