lmk->dev = &spi->dev;
 
-       lmk->oscin = devm_clk_get(lmk->dev, "oscin");
+       lmk->oscin = devm_clk_get_enabled(lmk->dev, "oscin");
        if (IS_ERR(lmk->oscin)) {
                dev_err(lmk->dev, "failed to get oscin clock\n");
                return PTR_ERR(lmk->oscin);
        }
 
-       ret = clk_prepare_enable(lmk->oscin);
-       if (ret)
-               return ret;
-
        lmk->reset_gpio = devm_gpiod_get_optional(&spi->dev, "reset",
                                                  GPIOD_OUT_LOW);
 
                                 sizeof(struct lmk_dclk), GFP_KERNEL);
        if (!lmk->dclk) {
                ret = -ENOMEM;
-               goto err_disable_oscin;
+               return ret;
        }
 
        lmk->clkout = devm_kcalloc(lmk->dev, info->num_channels,
                                   sizeof(*lmk->clkout), GFP_KERNEL);
        if (!lmk->clkout) {
                ret = -ENOMEM;
-               goto err_disable_oscin;
+               return ret;
        }
 
        lmk->clk_data = devm_kzalloc(lmk->dev, struct_size(lmk->clk_data, hws,
                                     GFP_KERNEL);
        if (!lmk->clk_data) {
                ret = -ENOMEM;
-               goto err_disable_oscin;
+               return ret;
        }
 
        device_property_read_u32(lmk->dev, "ti,vco-hz", &lmk->vco_rate);
                        dev_err(lmk->dev, "missing reg property in child: %s\n",
                                child->full_name);
                        of_node_put(child);
-                       goto err_disable_oscin;
+                       return ret;
                }
 
                of_property_read_u32(child, "ti,clkout-fmt",
 
                        __func__, PTR_ERR(lmk->regmap));
                ret = PTR_ERR(lmk->regmap);
-               goto err_disable_oscin;
+               return ret;
        }
 
        regmap_write(lmk->regmap, LMK04832_REG_RST3W, LMK04832_BIT_RESET);
                                         &rdbk_pin);
                ret = lmk04832_set_spi_rdbk(lmk, rdbk_pin);
                if (ret)
-                       goto err_disable_oscin;
+                       return ret;
        }
 
        regmap_bulk_read(lmk->regmap, LMK04832_REG_ID_PROD_MSB, &tmp, 3);
                dev_err(lmk->dev, "unsupported device type: pid 0x%04x, maskrev 0x%02x\n",
                        tmp[0] << 8 | tmp[1], tmp[2]);
                ret = -EINVAL;
-               goto err_disable_oscin;
+               return ret;
        }
 
        ret = lmk04832_register_vco(lmk);
        if (ret) {
                dev_err(lmk->dev, "failed to init device clock path\n");
-               goto err_disable_oscin;
+               return ret;
        }
 
        if (lmk->vco_rate) {
                ret = clk_set_rate(lmk->vco.clk, lmk->vco_rate);
                if (ret) {
                        dev_err(lmk->dev, "failed to set VCO rate\n");
-                       goto err_disable_oscin;
+                       return ret;
                }
        }
 
        ret = lmk04832_register_sclk(lmk);
        if (ret) {
                dev_err(lmk->dev, "failed to init SYNC/SYSREF clock path\n");
-               goto err_disable_oscin;
+               return ret;
        }
 
        for (i = 0; i < info->num_channels; i++) {
                ret = lmk04832_register_clkout(lmk, i);
                if (ret) {
                        dev_err(lmk->dev, "failed to register clk %d\n", i);
-                       goto err_disable_oscin;
+                       return ret;
                }
        }
 
                                          lmk->clk_data);
        if (ret) {
                dev_err(lmk->dev, "failed to add provider (%d)\n", ret);
-               goto err_disable_oscin;
+               return ret;
        }
 
        spi_set_drvdata(spi, lmk);
 
        return 0;
-
-err_disable_oscin:
-       clk_disable_unprepare(lmk->oscin);
-
-       return ret;
-}
-
-static void lmk04832_remove(struct spi_device *spi)
-{
-       struct lmk04832 *lmk = spi_get_drvdata(spi);
-
-       clk_disable_unprepare(lmk->oscin);
 }
 
 static const struct spi_device_id lmk04832_id[] = {
                .of_match_table = lmk04832_of_id,
        },
        .probe          = lmk04832_probe,
-       .remove         = lmk04832_remove,
        .id_table       = lmk04832_id,
 };
 module_spi_driver(lmk04832_driver);