clk: samsung: Revert "clk: samsung: exynos-clkout: Use of_device_get_match_data()"
of_device_get_match_data() function should not be used on the device other than the one matched to the given driver, because it always returns the match_data of the matched driver. In case of exynos-clkout driver, the code matched the OF IDs on the PARENT device, so replacing it with of_device_get_match_data() broke the driver. This reverts commit777aaf3d1d
. Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com> Fixes:777aaf3d1d
("clk: samsung: exynos-clkout: Use of_device_get_match_data()") Reviewed-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org> Link: https://lore.kernel.org/r/20221108213718.32076-1-m.szyprowski@samsung.com Signed-off-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
This commit is contained in:
parent
4854e8b083
commit
2bc5febd05
1 changed files with 4 additions and 2 deletions
|
@ -81,17 +81,19 @@ MODULE_DEVICE_TABLE(of, exynos_clkout_ids);
|
||||||
static int exynos_clkout_match_parent_dev(struct device *dev, u32 *mux_mask)
|
static int exynos_clkout_match_parent_dev(struct device *dev, u32 *mux_mask)
|
||||||
{
|
{
|
||||||
const struct exynos_clkout_variant *variant;
|
const struct exynos_clkout_variant *variant;
|
||||||
|
const struct of_device_id *match;
|
||||||
|
|
||||||
if (!dev->parent) {
|
if (!dev->parent) {
|
||||||
dev_err(dev, "not instantiated from MFD\n");
|
dev_err(dev, "not instantiated from MFD\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
variant = of_device_get_match_data(dev->parent);
|
match = of_match_device(exynos_clkout_ids, dev->parent);
|
||||||
if (!variant) {
|
if (!match) {
|
||||||
dev_err(dev, "cannot match parent device\n");
|
dev_err(dev, "cannot match parent device\n");
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
|
variant = match->data;
|
||||||
|
|
||||||
*mux_mask = variant->mux_mask;
|
*mux_mask = variant->mux_mask;
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue