|
@@ -0,0 +1,51 @@
|
|
|
+/*
|
|
|
+ * Copyright (C) 2012 Sascha Hauer, Pengutronix <s.hauer@pengutronix.de>
|
|
|
+ *
|
|
|
+ * This program is free software; you can redistribute it and/or modify
|
|
|
+ * it under the terms of the GNU General Public License version 2 as
|
|
|
+ * published by the Free Software Foundation.
|
|
|
+ *
|
|
|
+ */
|
|
|
+#include <linux/mm.h>
|
|
|
+#include <linux/delay.h>
|
|
|
+#include <linux/clk.h>
|
|
|
+#include <linux/io.h>
|
|
|
+#include <linux/clkdev.h>
|
|
|
+#include <linux/of.h>
|
|
|
+#include <linux/err.h>
|
|
|
+
|
|
|
+#include "crmregs-imx3.h"
|
|
|
+#include "clk.h"
|
|
|
+#include "common.h"
|
|
|
+#include "hardware.h"
|
|
|
+
|
|
|
+struct arm_ahb_div {
|
|
|
+ unsigned char arm, ahb, sel;
|
|
|
+};
|
|
|
+
|
|
|
+static struct arm_ahb_div clk_consumer[] = {
|
|
|
+ { .arm = 1, .ahb = 4, .sel = 0},
|
|
|
+ { .arm = 1, .ahb = 3, .sel = 1},
|
|
|
+ { .arm = 2, .ahb = 2, .sel = 0},
|
|
|
+ { .arm = 0, .ahb = 0, .sel = 0},
|
|
|
+ { .arm = 0, .ahb = 0, .sel = 0},
|
|
|
+ { .arm = 0, .ahb = 0, .sel = 0},
|
|
|
+ { .arm = 4, .ahb = 1, .sel = 0},
|
|
|
+ { .arm = 1, .ahb = 5, .sel = 0},
|
|
|
+ { .arm = 1, .ahb = 8, .sel = 0},
|
|
|
+ { .arm = 1, .ahb = 6, .sel = 1},
|
|
|
+ { .arm = 2, .ahb = 4, .sel = 0},
|
|
|
+ { .arm = 0, .ahb = 0, .sel = 0},
|
|
|
+ { .arm = 0, .ahb = 0, .sel = 0},
|
|
|
+ { .arm = 0, .ahb = 0, .sel = 0},
|
|
|
+ { .arm = 4, .ahb = 2, .sel = 0},
|
|
|
+ { .arm = 0, .ahb = 0, .sel = 0},
|
|
|
+};
|
|
|
+
|
|
|
+static char hsp_div_532[] = { 4, 8, 3, 0 };
|
|
|
+static char hsp_div_400[] = { 3, 6, 3, 0 };
|
|
|
+
|
|
|
+static const char *std_sel[] = {"ppll", "arm"};
|
|
|
+static const char *ipg_per_sel[] = {"ahb_per_div", "arm_per_div"};
|
|
|
+
|
|
|
+enum mx35_clks {
|