|  | @@ -392,3 +392,83 @@ static struct clk clk_tin[] = {
 | 
											
												
													
														|  |  		.ops	= &clk_tin_ops,
 |  |  		.ops	= &clk_tin_ops,
 | 
											
												
													
														|  |  	},
 |  |  	},
 | 
											
												
													
														|  |  	[3]	= {
 |  |  	[3]	= {
 | 
											
												
													
														|  | 
 |  | +		.name	= "pwm-tin",
 | 
											
												
													
														|  | 
 |  | +		.devname	= "s3c24xx-pwm.3",
 | 
											
												
													
														|  | 
 |  | +		.id	= 3,
 | 
											
												
													
														|  | 
 |  | +		.ops	= &clk_tin_ops,
 | 
											
												
													
														|  | 
 |  | +	},
 | 
											
												
													
														|  | 
 |  | +	[4]	= {
 | 
											
												
													
														|  | 
 |  | +		.name	= "pwm-tin",
 | 
											
												
													
														|  | 
 |  | +		.devname	= "s3c24xx-pwm.4",
 | 
											
												
													
														|  | 
 |  | +		.id	= 4,
 | 
											
												
													
														|  | 
 |  | +		.ops	= &clk_tin_ops,
 | 
											
												
													
														|  | 
 |  | +	},
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +static __init int clk_pwm_tin_register(struct clk *pwm)
 | 
											
												
													
														|  | 
 |  | +{
 | 
											
												
													
														|  | 
 |  | +	unsigned long tcfg1 = __raw_readl(S3C2410_TCFG1);
 | 
											
												
													
														|  | 
 |  | +	unsigned int id = pwm->id;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	struct clk *parent;
 | 
											
												
													
														|  | 
 |  | +	int ret;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	ret = s3c24xx_register_clock(pwm);
 | 
											
												
													
														|  | 
 |  | +	if (ret < 0)
 | 
											
												
													
														|  | 
 |  | +		return ret;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	tcfg1 >>= S3C2410_TCFG1_SHIFT(id);
 | 
											
												
													
														|  | 
 |  | +	tcfg1 &= S3C2410_TCFG1_MUX_MASK;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	if (pwm_cfg_src_is_tclk(tcfg1))
 | 
											
												
													
														|  | 
 |  | +		parent = s3c24xx_pwmclk_tclk(id);
 | 
											
												
													
														|  | 
 |  | +	else
 | 
											
												
													
														|  | 
 |  | +		parent = s3c24xx_pwmclk_tdiv(id);
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	return clk_set_parent(pwm, parent);
 | 
											
												
													
														|  | 
 |  | +}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +/**
 | 
											
												
													
														|  | 
 |  | + * s3c_pwmclk_init() - initialise pwm clocks
 | 
											
												
													
														|  | 
 |  | + *
 | 
											
												
													
														|  | 
 |  | + * Initialise and register the clocks which provide the inputs for the
 | 
											
												
													
														|  | 
 |  | + * pwm timer blocks.
 | 
											
												
													
														|  | 
 |  | + *
 | 
											
												
													
														|  | 
 |  | + * Note, this call is required by the time core, so must be called after
 | 
											
												
													
														|  | 
 |  | + * the base clocks are added and before any of the initcalls are run.
 | 
											
												
													
														|  | 
 |  | + */
 | 
											
												
													
														|  | 
 |  | +__init void s3c_pwmclk_init(void)
 | 
											
												
													
														|  | 
 |  | +{
 | 
											
												
													
														|  | 
 |  | +	struct clk *clk_timers;
 | 
											
												
													
														|  | 
 |  | +	unsigned int clk;
 | 
											
												
													
														|  | 
 |  | +	int ret;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	clk_timers = clk_get(NULL, "timers");
 | 
											
												
													
														|  | 
 |  | +	if (IS_ERR(clk_timers)) {
 | 
											
												
													
														|  | 
 |  | +		printk(KERN_ERR "%s: no parent clock\n", __func__);
 | 
											
												
													
														|  | 
 |  | +		return;
 | 
											
												
													
														|  | 
 |  | +	}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	for (clk = 0; clk < ARRAY_SIZE(clk_timer_scaler); clk++)
 | 
											
												
													
														|  | 
 |  | +		clk_timer_scaler[clk].parent = clk_timers;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	s3c_register_clocks(clk_timer_scaler, ARRAY_SIZE(clk_timer_scaler));
 | 
											
												
													
														|  | 
 |  | +	s3c_register_clocks(clk_timer_tclk, ARRAY_SIZE(clk_timer_tclk));
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	for (clk = 0; clk < ARRAY_SIZE(clk_timer_tdiv); clk++) {
 | 
											
												
													
														|  | 
 |  | +		ret = clk_pwm_tdiv_register(clk);
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +		if (ret < 0) {
 | 
											
												
													
														|  | 
 |  | +			printk(KERN_ERR "error adding pwm%d tdiv clock\n", clk);
 | 
											
												
													
														|  | 
 |  | +			return;
 | 
											
												
													
														|  | 
 |  | +		}
 | 
											
												
													
														|  | 
 |  | +	}
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +	for (clk = 0; clk < ARRAY_SIZE(clk_tin); clk++) {
 | 
											
												
													
														|  | 
 |  | +		ret = clk_pwm_tin_register(&clk_tin[clk]);
 | 
											
												
													
														|  | 
 |  | +		if (ret < 0) {
 | 
											
												
													
														|  | 
 |  | +			printk(KERN_ERR "error adding pwm%d tin clock\n", clk);
 | 
											
												
													
														|  | 
 |  | +			return;
 | 
											
												
													
														|  | 
 |  | +		}
 | 
											
												
													
														|  | 
 |  | +	}
 | 
											
												
													
														|  | 
 |  | +}
 |