aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLaxman Dewangan <ldewangan@nvidia.com>2016-02-24 04:14:07 -0500
committerLinus Walleij <linus.walleij@linaro.org>2016-04-20 18:03:32 -0400
commite46e3ef3d7472f8bdf8f26801847f375300a666b (patch)
tree52b698811e5786bb291c80927a1f36bed891a225
parentf1daa8a1a96812372f3afda90c6dc29d62f7f9b3 (diff)
pinctrl: tegra-xusb: Use devm_pinctrl_register() for pinctrl registration
Use devm_pinctrl_register() for pin control registration and clean the error path. Signed-off-by: Laxman Dewangan <ldewangan@nvidia.com> Cc: Stephen Warren <swarren@wwwdotorg.org> Cc: Thierry Reding <thierry.reding@gmail.com> Cc: Alexandre Courbot <gnurou@gmail.com> Cc: Jon Hunter <jonathanh@nvidia.com> Acked-by: Stephen Warren <swarren@nvidia.com> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
-rw-r--r--drivers/pinctrl/tegra/pinctrl-tegra-xusb.c13
1 files changed, 5 insertions, 8 deletions
diff --git a/drivers/pinctrl/tegra/pinctrl-tegra-xusb.c b/drivers/pinctrl/tegra/pinctrl-tegra-xusb.c
index e58b5f344b34..5ce174ad4fb3 100644
--- a/drivers/pinctrl/tegra/pinctrl-tegra-xusb.c
+++ b/drivers/pinctrl/tegra/pinctrl-tegra-xusb.c
@@ -914,7 +914,8 @@ static int tegra_xusb_padctl_probe(struct platform_device *pdev)
914 padctl->desc.confops = &tegra_xusb_padctl_pinconf_ops; 914 padctl->desc.confops = &tegra_xusb_padctl_pinconf_ops;
915 padctl->desc.owner = THIS_MODULE; 915 padctl->desc.owner = THIS_MODULE;
916 916
917 padctl->pinctrl = pinctrl_register(&padctl->desc, &pdev->dev, padctl); 917 padctl->pinctrl = devm_pinctrl_register(&pdev->dev, &padctl->desc,
918 padctl);
918 if (IS_ERR(padctl->pinctrl)) { 919 if (IS_ERR(padctl->pinctrl)) {
919 dev_err(&pdev->dev, "failed to register pincontrol\n"); 920 dev_err(&pdev->dev, "failed to register pincontrol\n");
920 err = PTR_ERR(padctl->pinctrl); 921 err = PTR_ERR(padctl->pinctrl);
@@ -924,7 +925,7 @@ static int tegra_xusb_padctl_probe(struct platform_device *pdev)
924 phy = devm_phy_create(&pdev->dev, NULL, &pcie_phy_ops); 925 phy = devm_phy_create(&pdev->dev, NULL, &pcie_phy_ops);
925 if (IS_ERR(phy)) { 926 if (IS_ERR(phy)) {
926 err = PTR_ERR(phy); 927 err = PTR_ERR(phy);
927 goto unregister; 928 goto reset;
928 } 929 }
929 930
930 padctl->phys[TEGRA_XUSB_PADCTL_PCIE] = phy; 931 padctl->phys[TEGRA_XUSB_PADCTL_PCIE] = phy;
@@ -933,7 +934,7 @@ static int tegra_xusb_padctl_probe(struct platform_device *pdev)
933 phy = devm_phy_create(&pdev->dev, NULL, &sata_phy_ops); 934 phy = devm_phy_create(&pdev->dev, NULL, &sata_phy_ops);
934 if (IS_ERR(phy)) { 935 if (IS_ERR(phy)) {
935 err = PTR_ERR(phy); 936 err = PTR_ERR(phy);
936 goto unregister; 937 goto reset;
937 } 938 }
938 939
939 padctl->phys[TEGRA_XUSB_PADCTL_SATA] = phy; 940 padctl->phys[TEGRA_XUSB_PADCTL_SATA] = phy;
@@ -944,13 +945,11 @@ static int tegra_xusb_padctl_probe(struct platform_device *pdev)
944 if (IS_ERR(padctl->provider)) { 945 if (IS_ERR(padctl->provider)) {
945 err = PTR_ERR(padctl->provider); 946 err = PTR_ERR(padctl->provider);
946 dev_err(&pdev->dev, "failed to register PHYs: %d\n", err); 947 dev_err(&pdev->dev, "failed to register PHYs: %d\n", err);
947 goto unregister; 948 goto reset;
948 } 949 }
949 950
950 return 0; 951 return 0;
951 952
952unregister:
953 pinctrl_unregister(padctl->pinctrl);
954reset: 953reset:
955 reset_control_assert(padctl->rst); 954 reset_control_assert(padctl->rst);
956 return err; 955 return err;
@@ -961,8 +960,6 @@ static int tegra_xusb_padctl_remove(struct platform_device *pdev)
961 struct tegra_xusb_padctl *padctl = platform_get_drvdata(pdev); 960 struct tegra_xusb_padctl *padctl = platform_get_drvdata(pdev);
962 int err; 961 int err;
963 962
964 pinctrl_unregister(padctl->pinctrl);
965
966 err = reset_control_assert(padctl->rst); 963 err = reset_control_assert(padctl->rst);
967 if (err < 0) 964 if (err < 0)
968 dev_err(&pdev->dev, "failed to assert reset: %d\n", err); 965 dev_err(&pdev->dev, "failed to assert reset: %d\n", err);