struct device *dev)
{
u32 data = 0;
+ int ret;
+ /* enable spu bus bridge clock */
+ ret = clk_enable(fsi->master->clk_spu);
+ if (ret)
+ return ret;
/* clock setting */
if (fsi_is_clk_master(fsi))
fsi_fifo_init(fsi, io, dev);
/* start master clock */
- if (fsi_is_clk_master(fsi))
- return fsi_clk_enable(dev, fsi);
+ if (fsi_is_clk_master(fsi)) {
+ ret = fsi_clk_enable(dev, fsi);
+ if (ret) {
+ clk_disable(fsi->master->clk_spu);
+ return ret;
+ }
+ }
return 0;
}
static int fsi_hw_shutdown(struct fsi_priv *fsi,
struct device *dev)
{
+ int ret;
/* stop master clock */
- if (fsi_is_clk_master(fsi))
- return fsi_clk_disable(dev, fsi);
+ if (fsi_is_clk_master(fsi)) {
+ ret = fsi_clk_disable(dev, fsi);
+ if (ret)
+ return ret;
+ }
+ /* stop spu bus bridge clock */
+ clk_disable(fsi->master->clk_spu);
return 0;
}