2019-05-27 02:55:01 -04:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2016-09-19 00:38:54 -04:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2012-2016 Zhang, Keguang <keguang.zhang@gmail.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/clk-provider.h>
|
|
|
|
#include <linux/slab.h>
|
|
|
|
|
2018-11-30 15:59:38 -05:00
|
|
|
#include "clk.h"
|
|
|
|
|
2016-09-19 00:38:54 -04:00
|
|
|
struct clk_hw *__init clk_hw_register_pll(struct device *dev,
|
|
|
|
const char *name,
|
|
|
|
const char *parent_name,
|
|
|
|
const struct clk_ops *ops,
|
|
|
|
unsigned long flags)
|
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
struct clk_hw *hw;
|
|
|
|
struct clk_init_data init;
|
|
|
|
|
|
|
|
/* allocate the divider */
|
|
|
|
hw = kzalloc(sizeof(*hw), GFP_KERNEL);
|
|
|
|
if (!hw)
|
|
|
|
return ERR_PTR(-ENOMEM);
|
|
|
|
|
|
|
|
init.name = name;
|
|
|
|
init.ops = ops;
|
2018-11-30 15:59:38 -05:00
|
|
|
init.flags = flags;
|
|
|
|
init.parent_names = parent_name ? &parent_name : NULL;
|
|
|
|
init.num_parents = parent_name ? 1 : 0;
|
2016-09-19 00:38:54 -04:00
|
|
|
hw->init = &init;
|
|
|
|
|
|
|
|
/* register the clock */
|
|
|
|
ret = clk_hw_register(dev, hw);
|
|
|
|
if (ret) {
|
|
|
|
kfree(hw);
|
|
|
|
hw = ERR_PTR(ret);
|
|
|
|
}
|
|
|
|
|
|
|
|
return hw;
|
|
|
|
}
|