#include <linux/of_platform.h>
 #include <linux/slab.h>
 
+#include <linux/clk.h>
 #include <linux/io.h>
 #include <linux/fsl_devices.h>
 #include <linux/i2c.h>
 #ifdef CONFIG_PM_SLEEP
        u8 fdr, dfsrr;
 #endif
+       struct clk *clk_per;
 };
 
 struct mpc_i2c_divider {
        int result = 0;
        int plen;
        struct resource res;
+       struct clk *clk;
+       int err;
 
        match = of_match_device(mpc_i2c_of_match, &op->dev);
        if (!match)
                }
        }
 
+       /*
+        * enable clock for the I2C peripheral (non fatal),
+        * keep a reference upon successful allocation
+        */
+       clk = devm_clk_get(&op->dev, NULL);
+       if (!IS_ERR(clk)) {
+               err = clk_prepare_enable(clk);
+               if (err) {
+                       dev_err(&op->dev, "failed to enable clock\n");
+                       goto fail_request;
+               } else {
+                       i2c->clk_per = clk;
+               }
+       }
+
        if (of_get_property(op->dev.of_node, "fsl,preserve-clocking", NULL)) {
                clock = MPC_I2C_CLOCK_PRESERVE;
        } else {
        return result;
 
  fail_add:
+       if (i2c->clk_per)
+               clk_disable_unprepare(i2c->clk_per);
        free_irq(i2c->irq, i2c);
  fail_request:
        irq_dispose_mapping(i2c->irq);
 
        i2c_del_adapter(&i2c->adap);
 
+       if (i2c->clk_per)
+               clk_disable_unprepare(i2c->clk_per);
+
        if (i2c->irq)
                free_irq(i2c->irq, i2c);