|
@@ -0,0 +1,111 @@
|
|
|
|
+/*
|
|
|
|
+ * linux/arch/arm/mach-omap2/devices.c
|
|
|
|
+ *
|
|
|
|
+ * OMAP2 platform device setup/initialization
|
|
|
|
+ *
|
|
|
|
+ * This program is free software; you can redistribute it and/or modify
|
|
|
|
+ * it under the terms of the GNU General Public License as published by
|
|
|
|
+ * the Free Software Foundation; either version 2 of the License, or
|
|
|
|
+ * (at your option) any later version.
|
|
|
|
+ */
|
|
|
|
+#include <linux/gpio.h>
|
|
|
|
+#include <linux/kernel.h>
|
|
|
|
+#include <linux/init.h>
|
|
|
|
+#include <linux/platform_device.h>
|
|
|
|
+#include <linux/io.h>
|
|
|
|
+#include <linux/clk.h>
|
|
|
|
+#include <linux/err.h>
|
|
|
|
+#include <linux/slab.h>
|
|
|
|
+#include <linux/of.h>
|
|
|
|
+#include <linux/pinctrl/machine.h>
|
|
|
|
+#include <linux/platform_data/omap4-keypad.h>
|
|
|
|
+#include <linux/platform_data/omap_ocp2scp.h>
|
|
|
|
+
|
|
|
|
+#include <asm/mach-types.h>
|
|
|
|
+#include <asm/mach/map.h>
|
|
|
|
+
|
|
|
|
+#include <linux/omap-dma.h>
|
|
|
|
+
|
|
|
|
+#include "iomap.h"
|
|
|
|
+#include "omap_hwmod.h"
|
|
|
|
+#include "omap_device.h"
|
|
|
|
+#include "omap4-keypad.h"
|
|
|
|
+
|
|
|
|
+#include "soc.h"
|
|
|
|
+#include "common.h"
|
|
|
|
+#include "mux.h"
|
|
|
|
+#include "control.h"
|
|
|
|
+#include "devices.h"
|
|
|
|
+#include "dma.h"
|
|
|
|
+
|
|
|
|
+#define L3_MODULES_MAX_LEN 12
|
|
|
|
+#define L3_MODULES 3
|
|
|
|
+
|
|
|
|
+static int __init omap3_l3_init(void)
|
|
|
|
+{
|
|
|
|
+ struct omap_hwmod *oh;
|
|
|
|
+ struct platform_device *pdev;
|
|
|
|
+ char oh_name[L3_MODULES_MAX_LEN];
|
|
|
|
+
|
|
|
|
+ /*
|
|
|
|
+ * To avoid code running on other OMAPs in
|
|
|
|
+ * multi-omap builds
|
|
|
|
+ */
|
|
|
|
+ if (!(cpu_is_omap34xx()))
|
|
|
|
+ return -ENODEV;
|
|
|
|
+
|
|
|
|
+ snprintf(oh_name, L3_MODULES_MAX_LEN, "l3_main");
|
|
|
|
+
|
|
|
|
+ oh = omap_hwmod_lookup(oh_name);
|
|
|
|
+
|
|
|
|
+ if (!oh)
|
|
|
|
+ pr_err("could not look up %s\n", oh_name);
|
|
|
|
+
|
|
|
|
+ pdev = omap_device_build("omap_l3_smx", 0, oh, NULL, 0,
|
|
|
|
+ NULL, 0, 0);
|
|
|
|
+
|
|
|
|
+ WARN(IS_ERR(pdev), "could not build omap_device for %s\n", oh_name);
|
|
|
|
+
|
|
|
|
+ return IS_ERR(pdev) ? PTR_ERR(pdev) : 0;
|
|
|
|
+}
|
|
|
|
+postcore_initcall(omap3_l3_init);
|
|
|
|
+
|
|
|
|
+static int __init omap4_l3_init(void)
|
|
|
|
+{
|
|
|
|
+ int i;
|
|
|
|
+ struct omap_hwmod *oh[3];
|
|
|
|
+ struct platform_device *pdev;
|
|
|
|
+ char oh_name[L3_MODULES_MAX_LEN];
|
|
|
|
+
|
|
|
|
+ /* If dtb is there, the devices will be created dynamically */
|
|
|
|
+ if (of_have_populated_dt())
|
|
|
|
+ return -ENODEV;
|
|
|
|
+
|
|
|
|
+ /*
|
|
|
|
+ * To avoid code running on other OMAPs in
|
|
|
|
+ * multi-omap builds
|
|
|
|
+ */
|
|
|
|
+ if (!cpu_is_omap44xx() && !soc_is_omap54xx())
|
|
|
|
+ return -ENODEV;
|
|
|
|
+
|
|
|
|
+ for (i = 0; i < L3_MODULES; i++) {
|
|
|
|
+ snprintf(oh_name, L3_MODULES_MAX_LEN, "l3_main_%d", i+1);
|
|
|
|
+
|
|
|
|
+ oh[i] = omap_hwmod_lookup(oh_name);
|
|
|
|
+ if (!(oh[i]))
|
|
|
|
+ pr_err("could not look up %s\n", oh_name);
|
|
|
|
+ }
|
|
|
|
+
|
|
|
|
+ pdev = omap_device_build_ss("omap_l3_noc", 0, oh, 3, NULL,
|
|
|
|
+ 0, NULL, 0, 0);
|
|
|
|
+
|
|
|
|
+ WARN(IS_ERR(pdev), "could not build omap_device for %s\n", oh_name);
|
|
|
|
+
|
|
|
|
+ return IS_ERR(pdev) ? PTR_ERR(pdev) : 0;
|
|
|
|
+}
|
|
|
|
+postcore_initcall(omap4_l3_init);
|
|
|
|
+
|
|
|
|
+#if defined(CONFIG_VIDEO_OMAP2) || defined(CONFIG_VIDEO_OMAP2_MODULE)
|
|
|
|
+
|
|
|
|
+static struct resource omap2cam_resources[] = {
|
|
|
|
+ {
|