ARM: PNX4008: get i2c clock rate from clk API
authorRussell King <rmk+kernel@arm.linux.org.uk>
Fri, 20 Nov 2009 12:46:07 +0000 (12:46 +0000)
committerRussell King <rmk+kernel@arm.linux.org.uk>
Fri, 12 Feb 2010 17:32:39 +0000 (17:32 +0000)
Acked-by: Vitaly Wool <vitalywool@gmail.com>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
arch/arm/mach-pnx4008/clock.c
arch/arm/mach-pnx4008/i2c.c
drivers/i2c/busses/i2c-pnx.c
include/linux/i2c-pnx.h

index 692625cd20010aa6cf3f8230fc7d88ac274d6c9f..9d1975fa4d9f2c2e71e3782c7716bd66c5c67dff 100644 (file)
@@ -638,9 +638,10 @@ static struct clk flash_ck = {
 static struct clk i2c0_ck = {
        .name = "i2c0_ck",
        .parent = &per_ck,
-       .flags = NEEDS_INITIALIZATION,
+       .flags = NEEDS_INITIALIZATION | FIXED_RATE,
        .enable_shift = 0,
        .enable_reg = I2CCLKCTRL_REG,
+       .rate = 13000000,
        .enable = clk_reg_enable,
        .disable = clk_reg_disable,
 };
@@ -648,9 +649,10 @@ static struct clk i2c0_ck = {
 static struct clk i2c1_ck = {
        .name = "i2c1_ck",
        .parent = &per_ck,
-       .flags = NEEDS_INITIALIZATION,
+       .flags = NEEDS_INITIALIZATION | FIXED_RATE,
        .enable_shift = 1,
        .enable_reg = I2CCLKCTRL_REG,
+       .rate = 13000000,
        .enable = clk_reg_enable,
        .disable = clk_reg_disable,
 };
@@ -658,9 +660,10 @@ static struct clk i2c1_ck = {
 static struct clk i2c2_ck = {
        .name = "i2c2_ck",
        .parent = &per_ck,
-       .flags = NEEDS_INITIALIZATION,
+       .flags = NEEDS_INITIALIZATION | FIXED_RATE,
        .enable_shift = 2,
        .enable_reg = USB_OTG_CLKCTRL_REG,
+       .rate = 13000000,
        .enable = clk_reg_enable,
        .disable = clk_reg_disable,
 };
index 14b4906bec2f23ccf2e70497f93af7755ee634da..23ec335a4bc074f13cd63ec00a0b2aba09fd92d0 100644 (file)
 #include <mach/irqs.h>
 #include <mach/i2c.h>
 
-static u32 calculate_input_freq(struct platform_device *pdev)
-{
-       return HCLK_MHZ;
-}
-
-
 static struct i2c_pnx_algo_data pnx_algo_data0 = {
        .base = PNX4008_I2C1_BASE,
        .irq = I2C_1_INT,
@@ -54,17 +48,14 @@ static struct i2c_adapter pnx_adapter2 = {
 };
 
 static struct i2c_pnx_data i2c0_data = {
-       .calculate_input_freq = calculate_input_freq,
        .adapter = &pnx_adapter0,
 };
 
 static struct i2c_pnx_data i2c1_data = {
-       .calculate_input_freq = calculate_input_freq,
        .adapter = &pnx_adapter1,
 };
 
 static struct i2c_pnx_data i2c2_data = {
-       .calculate_input_freq = calculate_input_freq,
        .adapter = &pnx_adapter2,
 };
 
index 29f91774c4dff3ac299d2849b839a38d10cec880..bfcd079e885cb91755444a4e4bd35e2b67094690 100644 (file)
@@ -31,7 +31,6 @@
 #define I2C_PNX_TIMEOUT                10 /* msec */
 #define I2C_PNX_SPEED_KHZ      100
 #define I2C_PNX_REGION_SIZE    0x100
-#define PNX_DEFAULT_FREQ       13 /* MHz */
 
 static inline int wait_timeout(long timeout, struct i2c_pnx_algo_data *data)
 {
@@ -578,7 +577,7 @@ static int __devinit i2c_pnx_probe(struct platform_device *pdev)
        unsigned long tmp;
        int ret = 0;
        struct i2c_pnx_algo_data *alg_data;
-       int freq_mhz;
+       unsigned long freq;
        struct i2c_pnx_data *i2c_pnx = pdev->dev.platform_data;
 
        if (!i2c_pnx || !i2c_pnx->adapter) {
@@ -599,14 +598,6 @@ static int __devinit i2c_pnx_probe(struct platform_device *pdev)
                goto out_drvdata;
        }
 
-       if (i2c_pnx->calculate_input_freq)
-               freq_mhz = i2c_pnx->calculate_input_freq(pdev);
-       else {
-               freq_mhz = PNX_DEFAULT_FREQ;
-               dev_info(&pdev->dev, "Setting bus frequency to default value: "
-                      "%d MHz\n", freq_mhz);
-       }
-
        init_timer(&alg_data->mif.timer);
        alg_data->mif.timer.function = i2c_pnx_timeout;
        alg_data->mif.timer.data = (unsigned long)i2c_pnx->adapter;
@@ -632,6 +623,8 @@ static int __devinit i2c_pnx_probe(struct platform_device *pdev)
        if (ret)
                goto out_unmap;
 
+       freq = clk_get_rate(alg_data->clk);
+
        /*
         * Clock Divisor High This value is the number of system clocks
         * the serial clock (SCL) will be high.
@@ -643,7 +636,7 @@ static int __devinit i2c_pnx_probe(struct platform_device *pdev)
         * the deglitching filter length.
         */
 
-       tmp = ((freq_mhz * 1000) / I2C_PNX_SPEED_KHZ) / 2 - 2;
+       tmp = ((freq / 1000) / I2C_PNX_SPEED_KHZ) / 2 - 2;
        iowrite32(tmp, I2C_REG_CKH(alg_data));
        iowrite32(tmp, I2C_REG_CKL(alg_data));
 
index 688e29262a43d7f11f957f84a32c7f059a7539f1..9035711cb3b1868a676f0b782b9826b4ab9e7f91 100644 (file)
@@ -34,7 +34,6 @@ struct i2c_pnx_algo_data {
 };
 
 struct i2c_pnx_data {
-       u32 (*calculate_input_freq) (struct platform_device *pdev);
        struct i2c_adapter *adapter;
 };