|
@@ -523,3 +523,194 @@ static struct omap_hwmod omap44xx_debugss_hwmod = {
|
|
},
|
|
},
|
|
},
|
|
},
|
|
};
|
|
};
|
|
|
|
+
|
|
|
|
+/*
|
|
|
|
+ * 'dma' class
|
|
|
|
+ * dma controller for data exchange between memory to memory (i.e. internal or
|
|
|
|
+ * external memory) and gp peripherals to memory or memory to gp peripherals
|
|
|
|
+ */
|
|
|
|
+
|
|
|
|
+static struct omap_hwmod_class_sysconfig omap44xx_dma_sysc = {
|
|
|
|
+ .rev_offs = 0x0000,
|
|
|
|
+ .sysc_offs = 0x002c,
|
|
|
|
+ .syss_offs = 0x0028,
|
|
|
|
+ .sysc_flags = (SYSC_HAS_AUTOIDLE | SYSC_HAS_CLOCKACTIVITY |
|
|
|
|
+ SYSC_HAS_EMUFREE | SYSC_HAS_MIDLEMODE |
|
|
|
|
+ SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET |
|
|
|
|
+ SYSS_HAS_RESET_STATUS),
|
|
|
|
+ .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
|
|
|
|
+ MSTANDBY_FORCE | MSTANDBY_NO | MSTANDBY_SMART),
|
|
|
|
+ .sysc_fields = &omap_hwmod_sysc_type1,
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+static struct omap_hwmod_class omap44xx_dma_hwmod_class = {
|
|
|
|
+ .name = "dma",
|
|
|
|
+ .sysc = &omap44xx_dma_sysc,
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+/* dma dev_attr */
|
|
|
|
+static struct omap_dma_dev_attr dma_dev_attr = {
|
|
|
|
+ .dev_caps = RESERVE_CHANNEL | DMA_LINKED_LCH | GLOBAL_PRIORITY |
|
|
|
|
+ IS_CSSA_32 | IS_CDSA_32 | IS_RW_PRIORITY,
|
|
|
|
+ .lch_count = 32,
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+/* dma_system */
|
|
|
|
+static struct omap_hwmod_irq_info omap44xx_dma_system_irqs[] = {
|
|
|
|
+ { .name = "0", .irq = 12 + OMAP44XX_IRQ_GIC_START },
|
|
|
|
+ { .name = "1", .irq = 13 + OMAP44XX_IRQ_GIC_START },
|
|
|
|
+ { .name = "2", .irq = 14 + OMAP44XX_IRQ_GIC_START },
|
|
|
|
+ { .name = "3", .irq = 15 + OMAP44XX_IRQ_GIC_START },
|
|
|
|
+ { .irq = -1 }
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+static struct omap_hwmod omap44xx_dma_system_hwmod = {
|
|
|
|
+ .name = "dma_system",
|
|
|
|
+ .class = &omap44xx_dma_hwmod_class,
|
|
|
|
+ .clkdm_name = "l3_dma_clkdm",
|
|
|
|
+ .mpu_irqs = omap44xx_dma_system_irqs,
|
|
|
|
+ .main_clk = "l3_div_ck",
|
|
|
|
+ .prcm = {
|
|
|
|
+ .omap4 = {
|
|
|
|
+ .clkctrl_offs = OMAP4_CM_SDMA_SDMA_CLKCTRL_OFFSET,
|
|
|
|
+ .context_offs = OMAP4_RM_SDMA_SDMA_CONTEXT_OFFSET,
|
|
|
|
+ },
|
|
|
|
+ },
|
|
|
|
+ .dev_attr = &dma_dev_attr,
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+/*
|
|
|
|
+ * 'dmic' class
|
|
|
|
+ * digital microphone controller
|
|
|
|
+ */
|
|
|
|
+
|
|
|
|
+static struct omap_hwmod_class_sysconfig omap44xx_dmic_sysc = {
|
|
|
|
+ .rev_offs = 0x0000,
|
|
|
|
+ .sysc_offs = 0x0010,
|
|
|
|
+ .sysc_flags = (SYSC_HAS_EMUFREE | SYSC_HAS_RESET_STATUS |
|
|
|
|
+ SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET),
|
|
|
|
+ .idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
|
|
|
|
+ SIDLE_SMART_WKUP),
|
|
|
|
+ .sysc_fields = &omap_hwmod_sysc_type2,
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+static struct omap_hwmod_class omap44xx_dmic_hwmod_class = {
|
|
|
|
+ .name = "dmic",
|
|
|
|
+ .sysc = &omap44xx_dmic_sysc,
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+/* dmic */
|
|
|
|
+static struct omap_hwmod_irq_info omap44xx_dmic_irqs[] = {
|
|
|
|
+ { .irq = 114 + OMAP44XX_IRQ_GIC_START },
|
|
|
|
+ { .irq = -1 }
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+static struct omap_hwmod_dma_info omap44xx_dmic_sdma_reqs[] = {
|
|
|
|
+ { .dma_req = 66 + OMAP44XX_DMA_REQ_START },
|
|
|
|
+ { .dma_req = -1 }
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+static struct omap_hwmod omap44xx_dmic_hwmod = {
|
|
|
|
+ .name = "dmic",
|
|
|
|
+ .class = &omap44xx_dmic_hwmod_class,
|
|
|
|
+ .clkdm_name = "abe_clkdm",
|
|
|
|
+ .mpu_irqs = omap44xx_dmic_irqs,
|
|
|
|
+ .sdma_reqs = omap44xx_dmic_sdma_reqs,
|
|
|
|
+ .main_clk = "dmic_fck",
|
|
|
|
+ .prcm = {
|
|
|
|
+ .omap4 = {
|
|
|
|
+ .clkctrl_offs = OMAP4_CM1_ABE_DMIC_CLKCTRL_OFFSET,
|
|
|
|
+ .context_offs = OMAP4_RM_ABE_DMIC_CONTEXT_OFFSET,
|
|
|
|
+ .modulemode = MODULEMODE_SWCTRL,
|
|
|
|
+ },
|
|
|
|
+ },
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+/*
|
|
|
|
+ * 'dsp' class
|
|
|
|
+ * dsp sub-system
|
|
|
|
+ */
|
|
|
|
+
|
|
|
|
+static struct omap_hwmod_class omap44xx_dsp_hwmod_class = {
|
|
|
|
+ .name = "dsp",
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+/* dsp */
|
|
|
|
+static struct omap_hwmod_irq_info omap44xx_dsp_irqs[] = {
|
|
|
|
+ { .irq = 28 + OMAP44XX_IRQ_GIC_START },
|
|
|
|
+ { .irq = -1 }
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+static struct omap_hwmod_rst_info omap44xx_dsp_resets[] = {
|
|
|
|
+ { .name = "dsp", .rst_shift = 0 },
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+static struct omap_hwmod omap44xx_dsp_hwmod = {
|
|
|
|
+ .name = "dsp",
|
|
|
|
+ .class = &omap44xx_dsp_hwmod_class,
|
|
|
|
+ .clkdm_name = "tesla_clkdm",
|
|
|
|
+ .mpu_irqs = omap44xx_dsp_irqs,
|
|
|
|
+ .rst_lines = omap44xx_dsp_resets,
|
|
|
|
+ .rst_lines_cnt = ARRAY_SIZE(omap44xx_dsp_resets),
|
|
|
|
+ .main_clk = "dpll_iva_m4x2_ck",
|
|
|
|
+ .prcm = {
|
|
|
|
+ .omap4 = {
|
|
|
|
+ .clkctrl_offs = OMAP4_CM_TESLA_TESLA_CLKCTRL_OFFSET,
|
|
|
|
+ .rstctrl_offs = OMAP4_RM_TESLA_RSTCTRL_OFFSET,
|
|
|
|
+ .context_offs = OMAP4_RM_TESLA_TESLA_CONTEXT_OFFSET,
|
|
|
|
+ .modulemode = MODULEMODE_HWCTRL,
|
|
|
|
+ },
|
|
|
|
+ },
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+/*
|
|
|
|
+ * 'dss' class
|
|
|
|
+ * display sub-system
|
|
|
|
+ */
|
|
|
|
+
|
|
|
|
+static struct omap_hwmod_class_sysconfig omap44xx_dss_sysc = {
|
|
|
|
+ .rev_offs = 0x0000,
|
|
|
|
+ .syss_offs = 0x0014,
|
|
|
|
+ .sysc_flags = SYSS_HAS_RESET_STATUS,
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+static struct omap_hwmod_class omap44xx_dss_hwmod_class = {
|
|
|
|
+ .name = "dss",
|
|
|
|
+ .sysc = &omap44xx_dss_sysc,
|
|
|
|
+ .reset = omap_dss_reset,
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+/* dss */
|
|
|
|
+static struct omap_hwmod_opt_clk dss_opt_clks[] = {
|
|
|
|
+ { .role = "sys_clk", .clk = "dss_sys_clk" },
|
|
|
|
+ { .role = "tv_clk", .clk = "dss_tv_clk" },
|
|
|
|
+ { .role = "hdmi_clk", .clk = "dss_48mhz_clk" },
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+static struct omap_hwmod omap44xx_dss_hwmod = {
|
|
|
|
+ .name = "dss_core",
|
|
|
|
+ .flags = HWMOD_CONTROL_OPT_CLKS_IN_RESET,
|
|
|
|
+ .class = &omap44xx_dss_hwmod_class,
|
|
|
|
+ .clkdm_name = "l3_dss_clkdm",
|
|
|
|
+ .main_clk = "dss_dss_clk",
|
|
|
|
+ .prcm = {
|
|
|
|
+ .omap4 = {
|
|
|
|
+ .clkctrl_offs = OMAP4_CM_DSS_DSS_CLKCTRL_OFFSET,
|
|
|
|
+ .context_offs = OMAP4_RM_DSS_DSS_CONTEXT_OFFSET,
|
|
|
|
+ },
|
|
|
|
+ },
|
|
|
|
+ .opt_clks = dss_opt_clks,
|
|
|
|
+ .opt_clks_cnt = ARRAY_SIZE(dss_opt_clks),
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
+/*
|
|
|
|
+ * 'dispc' class
|
|
|
|
+ * display controller
|
|
|
|
+ */
|
|
|
|
+
|
|
|
|
+static struct omap_hwmod_class_sysconfig omap44xx_dispc_sysc = {
|
|
|
|
+ .rev_offs = 0x0000,
|
|
|
|
+ .sysc_offs = 0x0010,
|
|
|
|
+ .syss_offs = 0x0014,
|
|
|
|
+ .sysc_flags = (SYSC_HAS_AUTOIDLE | SYSC_HAS_CLOCKACTIVITY |
|
|
|
|
+ SYSC_HAS_ENAWAKEUP | SYSC_HAS_MIDLEMODE |
|