|  | @@ -1627,3 +1627,96 @@ static struct omap_hwmod_irq_info omap44xx_i2c4_irqs[] = {
 | 
											
												
													
														|  |  	{ .irq = -1 }
 |  |  	{ .irq = -1 }
 | 
											
												
													
														|  |  };
 |  |  };
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +static struct omap_hwmod_dma_info omap44xx_i2c4_sdma_reqs[] = {
 | 
											
												
													
														|  | 
 |  | +	{ .name = "tx", .dma_req = 123 + OMAP44XX_DMA_REQ_START },
 | 
											
												
													
														|  | 
 |  | +	{ .name = "rx", .dma_req = 124 + OMAP44XX_DMA_REQ_START },
 | 
											
												
													
														|  | 
 |  | +	{ .dma_req = -1 }
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +static struct omap_hwmod omap44xx_i2c4_hwmod = {
 | 
											
												
													
														|  | 
 |  | +	.name		= "i2c4",
 | 
											
												
													
														|  | 
 |  | +	.class		= &omap44xx_i2c_hwmod_class,
 | 
											
												
													
														|  | 
 |  | +	.clkdm_name	= "l4_per_clkdm",
 | 
											
												
													
														|  | 
 |  | +	.flags		= HWMOD_16BIT_REG | HWMOD_SET_DEFAULT_CLOCKACT,
 | 
											
												
													
														|  | 
 |  | +	.mpu_irqs	= omap44xx_i2c4_irqs,
 | 
											
												
													
														|  | 
 |  | +	.sdma_reqs	= omap44xx_i2c4_sdma_reqs,
 | 
											
												
													
														|  | 
 |  | +	.main_clk	= "i2c4_fck",
 | 
											
												
													
														|  | 
 |  | +	.prcm = {
 | 
											
												
													
														|  | 
 |  | +		.omap4 = {
 | 
											
												
													
														|  | 
 |  | +			.clkctrl_offs = OMAP4_CM_L4PER_I2C4_CLKCTRL_OFFSET,
 | 
											
												
													
														|  | 
 |  | +			.context_offs = OMAP4_RM_L4PER_I2C4_CONTEXT_OFFSET,
 | 
											
												
													
														|  | 
 |  | +			.modulemode   = MODULEMODE_SWCTRL,
 | 
											
												
													
														|  | 
 |  | +		},
 | 
											
												
													
														|  | 
 |  | +	},
 | 
											
												
													
														|  | 
 |  | +	.dev_attr	= &i2c_dev_attr,
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +/*
 | 
											
												
													
														|  | 
 |  | + * 'ipu' class
 | 
											
												
													
														|  | 
 |  | + * imaging processor unit
 | 
											
												
													
														|  | 
 |  | + */
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +static struct omap_hwmod_class omap44xx_ipu_hwmod_class = {
 | 
											
												
													
														|  | 
 |  | +	.name	= "ipu",
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +/* ipu */
 | 
											
												
													
														|  | 
 |  | +static struct omap_hwmod_irq_info omap44xx_ipu_irqs[] = {
 | 
											
												
													
														|  | 
 |  | +	{ .irq = 100 + OMAP44XX_IRQ_GIC_START },
 | 
											
												
													
														|  | 
 |  | +	{ .irq = -1 }
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +static struct omap_hwmod_rst_info omap44xx_ipu_resets[] = {
 | 
											
												
													
														|  | 
 |  | +	{ .name = "cpu0", .rst_shift = 0 },
 | 
											
												
													
														|  | 
 |  | +	{ .name = "cpu1", .rst_shift = 1 },
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +static struct omap_hwmod omap44xx_ipu_hwmod = {
 | 
											
												
													
														|  | 
 |  | +	.name		= "ipu",
 | 
											
												
													
														|  | 
 |  | +	.class		= &omap44xx_ipu_hwmod_class,
 | 
											
												
													
														|  | 
 |  | +	.clkdm_name	= "ducati_clkdm",
 | 
											
												
													
														|  | 
 |  | +	.mpu_irqs	= omap44xx_ipu_irqs,
 | 
											
												
													
														|  | 
 |  | +	.rst_lines	= omap44xx_ipu_resets,
 | 
											
												
													
														|  | 
 |  | +	.rst_lines_cnt	= ARRAY_SIZE(omap44xx_ipu_resets),
 | 
											
												
													
														|  | 
 |  | +	.main_clk	= "ducati_clk_mux_ck",
 | 
											
												
													
														|  | 
 |  | +	.prcm = {
 | 
											
												
													
														|  | 
 |  | +		.omap4 = {
 | 
											
												
													
														|  | 
 |  | +			.clkctrl_offs = OMAP4_CM_DUCATI_DUCATI_CLKCTRL_OFFSET,
 | 
											
												
													
														|  | 
 |  | +			.rstctrl_offs = OMAP4_RM_DUCATI_RSTCTRL_OFFSET,
 | 
											
												
													
														|  | 
 |  | +			.context_offs = OMAP4_RM_DUCATI_DUCATI_CONTEXT_OFFSET,
 | 
											
												
													
														|  | 
 |  | +			.modulemode   = MODULEMODE_HWCTRL,
 | 
											
												
													
														|  | 
 |  | +		},
 | 
											
												
													
														|  | 
 |  | +	},
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +/*
 | 
											
												
													
														|  | 
 |  | + * 'iss' class
 | 
											
												
													
														|  | 
 |  | + * external images sensor pixel data processor
 | 
											
												
													
														|  | 
 |  | + */
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +static struct omap_hwmod_class_sysconfig omap44xx_iss_sysc = {
 | 
											
												
													
														|  | 
 |  | +	.rev_offs	= 0x0000,
 | 
											
												
													
														|  | 
 |  | +	.sysc_offs	= 0x0010,
 | 
											
												
													
														|  | 
 |  | +	/*
 | 
											
												
													
														|  | 
 |  | +	 * ISS needs 100 OCP clk cycles delay after a softreset before
 | 
											
												
													
														|  | 
 |  | +	 * accessing sysconfig again.
 | 
											
												
													
														|  | 
 |  | +	 * The lowest frequency at the moment for L3 bus is 100 MHz, so
 | 
											
												
													
														|  | 
 |  | +	 * 1usec delay is needed. Add an x2 margin to be safe (2 usecs).
 | 
											
												
													
														|  | 
 |  | +	 *
 | 
											
												
													
														|  | 
 |  | +	 * TODO: Indicate errata when available.
 | 
											
												
													
														|  | 
 |  | +	 */
 | 
											
												
													
														|  | 
 |  | +	.srst_udelay	= 2,
 | 
											
												
													
														|  | 
 |  | +	.sysc_flags	= (SYSC_HAS_MIDLEMODE | SYSC_HAS_RESET_STATUS |
 | 
											
												
													
														|  | 
 |  | +			   SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET),
 | 
											
												
													
														|  | 
 |  | +	.idlemodes	= (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
 | 
											
												
													
														|  | 
 |  | +			   SIDLE_SMART_WKUP | MSTANDBY_FORCE | MSTANDBY_NO |
 | 
											
												
													
														|  | 
 |  | +			   MSTANDBY_SMART | MSTANDBY_SMART_WKUP),
 | 
											
												
													
														|  | 
 |  | +	.sysc_fields	= &omap_hwmod_sysc_type2,
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +static struct omap_hwmod_class omap44xx_iss_hwmod_class = {
 | 
											
												
													
														|  | 
 |  | +	.name	= "iss",
 | 
											
												
													
														|  | 
 |  | +	.sysc	= &omap44xx_iss_sysc,
 | 
											
												
													
														|  | 
 |  | +};
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +/* iss */
 |