forked from Minki/linux
13662dc5b1
This patch adds a custom DSS reset function used on OMAPs from OMAP2 forward. The function doesn't actually do a reset, it only waits for the reset to complete. The reason for this is that on OMAP4 there is no possibility to do a SW reset, and on OMAP2/3 doing a SW reset for dss_core resets all the other DSS modules also, thus breaking the HWMOD model where every DSS module is handled independently. This fixes the problem with DSS reset on OMAP4, caused by the fact that because there's no SW reset for dss_core on OMAP4, the HWMOD framework doesn't try to reset dss_core and thus the DSS clocks were never enabled at the same time. This causes causes the HWMOD reset to fail for dss_dispc and dss_rfbi. The common reset function will also allow us to fix another problem in the future: before doing a reset we need to disable DSS outputs, which are in some cases enabled by the bootloader, as otherwise DSS HW seems to get more or less stuck, requiring a power reset to recover. Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com> [paul@pwsan.com: modified to build arch/arm/mach-omap2/display.o unconditionally to avoid an error when !CONFIG_OMAP2_DSS] Signed-off-by: Paul Walmsley <paul@pwsan.com>
326 lines
7.4 KiB
C
326 lines
7.4 KiB
C
/*
|
|
* omap_hwmod_2xxx_3xxx_ipblock_data.c - common IP block data for OMAP2/3
|
|
*
|
|
* Copyright (C) 2011 Nokia Corporation
|
|
* Paul Walmsley
|
|
*
|
|
* 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 <plat/omap_hwmod.h>
|
|
#include <plat/serial.h>
|
|
#include <plat/dma.h>
|
|
#include <plat/common.h>
|
|
|
|
#include <mach/irqs.h>
|
|
|
|
#include "omap_hwmod_common_data.h"
|
|
|
|
/* UART */
|
|
|
|
static struct omap_hwmod_class_sysconfig omap2_uart_sysc = {
|
|
.rev_offs = 0x50,
|
|
.sysc_offs = 0x54,
|
|
.syss_offs = 0x58,
|
|
.sysc_flags = (SYSC_HAS_SIDLEMODE |
|
|
SYSC_HAS_ENAWAKEUP | SYSC_HAS_SOFTRESET |
|
|
SYSC_HAS_AUTOIDLE | SYSS_HAS_RESET_STATUS),
|
|
.idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART),
|
|
.sysc_fields = &omap_hwmod_sysc_type1,
|
|
};
|
|
|
|
struct omap_hwmod_class omap2_uart_class = {
|
|
.name = "uart",
|
|
.sysc = &omap2_uart_sysc,
|
|
};
|
|
|
|
/*
|
|
* 'dss' class
|
|
* display sub-system
|
|
*/
|
|
|
|
static struct omap_hwmod_class_sysconfig omap2_dss_sysc = {
|
|
.rev_offs = 0x0000,
|
|
.sysc_offs = 0x0010,
|
|
.syss_offs = 0x0014,
|
|
.sysc_flags = (SYSC_HAS_SOFTRESET | SYSC_HAS_AUTOIDLE |
|
|
SYSS_HAS_RESET_STATUS),
|
|
.sysc_fields = &omap_hwmod_sysc_type1,
|
|
};
|
|
|
|
struct omap_hwmod_class omap2_dss_hwmod_class = {
|
|
.name = "dss",
|
|
.sysc = &omap2_dss_sysc,
|
|
.reset = omap_dss_reset,
|
|
};
|
|
|
|
/*
|
|
* 'dispc' class
|
|
* display controller
|
|
*/
|
|
|
|
static struct omap_hwmod_class_sysconfig omap2_dispc_sysc = {
|
|
.rev_offs = 0x0000,
|
|
.sysc_offs = 0x0010,
|
|
.syss_offs = 0x0014,
|
|
.sysc_flags = (SYSC_HAS_SIDLEMODE | SYSC_HAS_MIDLEMODE |
|
|
SYSC_HAS_SOFTRESET | SYSC_HAS_AUTOIDLE),
|
|
.idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART |
|
|
MSTANDBY_FORCE | MSTANDBY_NO | MSTANDBY_SMART),
|
|
.sysc_fields = &omap_hwmod_sysc_type1,
|
|
};
|
|
|
|
struct omap_hwmod_class omap2_dispc_hwmod_class = {
|
|
.name = "dispc",
|
|
.sysc = &omap2_dispc_sysc,
|
|
};
|
|
|
|
/*
|
|
* 'rfbi' class
|
|
* remote frame buffer interface
|
|
*/
|
|
|
|
static struct omap_hwmod_class_sysconfig omap2_rfbi_sysc = {
|
|
.rev_offs = 0x0000,
|
|
.sysc_offs = 0x0010,
|
|
.syss_offs = 0x0014,
|
|
.sysc_flags = (SYSC_HAS_SIDLEMODE | SYSC_HAS_SOFTRESET |
|
|
SYSC_HAS_AUTOIDLE),
|
|
.idlemodes = (SIDLE_FORCE | SIDLE_NO | SIDLE_SMART),
|
|
.sysc_fields = &omap_hwmod_sysc_type1,
|
|
};
|
|
|
|
struct omap_hwmod_class omap2_rfbi_hwmod_class = {
|
|
.name = "rfbi",
|
|
.sysc = &omap2_rfbi_sysc,
|
|
};
|
|
|
|
/*
|
|
* 'venc' class
|
|
* video encoder
|
|
*/
|
|
|
|
struct omap_hwmod_class omap2_venc_hwmod_class = {
|
|
.name = "venc",
|
|
};
|
|
|
|
|
|
/* Common DMA request line data */
|
|
struct omap_hwmod_dma_info omap2_uart1_sdma_reqs[] = {
|
|
{ .name = "rx", .dma_req = OMAP24XX_DMA_UART1_RX, },
|
|
{ .name = "tx", .dma_req = OMAP24XX_DMA_UART1_TX, },
|
|
{ .dma_req = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_dma_info omap2_uart2_sdma_reqs[] = {
|
|
{ .name = "rx", .dma_req = OMAP24XX_DMA_UART2_RX, },
|
|
{ .name = "tx", .dma_req = OMAP24XX_DMA_UART2_TX, },
|
|
{ .dma_req = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_dma_info omap2_uart3_sdma_reqs[] = {
|
|
{ .name = "rx", .dma_req = OMAP24XX_DMA_UART3_RX, },
|
|
{ .name = "tx", .dma_req = OMAP24XX_DMA_UART3_TX, },
|
|
{ .dma_req = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_dma_info omap2_i2c1_sdma_reqs[] = {
|
|
{ .name = "tx", .dma_req = OMAP24XX_DMA_I2C1_TX },
|
|
{ .name = "rx", .dma_req = OMAP24XX_DMA_I2C1_RX },
|
|
{ .dma_req = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_dma_info omap2_i2c2_sdma_reqs[] = {
|
|
{ .name = "tx", .dma_req = OMAP24XX_DMA_I2C2_TX },
|
|
{ .name = "rx", .dma_req = OMAP24XX_DMA_I2C2_RX },
|
|
{ .dma_req = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_dma_info omap2_mcspi1_sdma_reqs[] = {
|
|
{ .name = "tx0", .dma_req = 35 }, /* DMA_SPI1_TX0 */
|
|
{ .name = "rx0", .dma_req = 36 }, /* DMA_SPI1_RX0 */
|
|
{ .name = "tx1", .dma_req = 37 }, /* DMA_SPI1_TX1 */
|
|
{ .name = "rx1", .dma_req = 38 }, /* DMA_SPI1_RX1 */
|
|
{ .name = "tx2", .dma_req = 39 }, /* DMA_SPI1_TX2 */
|
|
{ .name = "rx2", .dma_req = 40 }, /* DMA_SPI1_RX2 */
|
|
{ .name = "tx3", .dma_req = 41 }, /* DMA_SPI1_TX3 */
|
|
{ .name = "rx3", .dma_req = 42 }, /* DMA_SPI1_RX3 */
|
|
{ .dma_req = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_dma_info omap2_mcspi2_sdma_reqs[] = {
|
|
{ .name = "tx0", .dma_req = 43 }, /* DMA_SPI2_TX0 */
|
|
{ .name = "rx0", .dma_req = 44 }, /* DMA_SPI2_RX0 */
|
|
{ .name = "tx1", .dma_req = 45 }, /* DMA_SPI2_TX1 */
|
|
{ .name = "rx1", .dma_req = 46 }, /* DMA_SPI2_RX1 */
|
|
{ .dma_req = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_dma_info omap2_mcbsp1_sdma_reqs[] = {
|
|
{ .name = "rx", .dma_req = 32 },
|
|
{ .name = "tx", .dma_req = 31 },
|
|
{ .dma_req = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_dma_info omap2_mcbsp2_sdma_reqs[] = {
|
|
{ .name = "rx", .dma_req = 34 },
|
|
{ .name = "tx", .dma_req = 33 },
|
|
{ .dma_req = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_dma_info omap2_mcbsp3_sdma_reqs[] = {
|
|
{ .name = "rx", .dma_req = 18 },
|
|
{ .name = "tx", .dma_req = 17 },
|
|
{ .dma_req = -1 }
|
|
};
|
|
|
|
/* Other IP block data */
|
|
|
|
|
|
/*
|
|
* omap_hwmod class data
|
|
*/
|
|
|
|
struct omap_hwmod_class l3_hwmod_class = {
|
|
.name = "l3"
|
|
};
|
|
|
|
struct omap_hwmod_class l4_hwmod_class = {
|
|
.name = "l4"
|
|
};
|
|
|
|
struct omap_hwmod_class mpu_hwmod_class = {
|
|
.name = "mpu"
|
|
};
|
|
|
|
struct omap_hwmod_class iva_hwmod_class = {
|
|
.name = "iva"
|
|
};
|
|
|
|
/* Common MPU IRQ line data */
|
|
|
|
struct omap_hwmod_irq_info omap2_timer1_mpu_irqs[] = {
|
|
{ .irq = 37, },
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_timer2_mpu_irqs[] = {
|
|
{ .irq = 38, },
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_timer3_mpu_irqs[] = {
|
|
{ .irq = 39, },
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_timer4_mpu_irqs[] = {
|
|
{ .irq = 40, },
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_timer5_mpu_irqs[] = {
|
|
{ .irq = 41, },
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_timer6_mpu_irqs[] = {
|
|
{ .irq = 42, },
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_timer7_mpu_irqs[] = {
|
|
{ .irq = 43, },
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_timer8_mpu_irqs[] = {
|
|
{ .irq = 44, },
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_timer9_mpu_irqs[] = {
|
|
{ .irq = 45, },
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_timer10_mpu_irqs[] = {
|
|
{ .irq = 46, },
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_timer11_mpu_irqs[] = {
|
|
{ .irq = 47, },
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_uart1_mpu_irqs[] = {
|
|
{ .irq = INT_24XX_UART1_IRQ, },
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_uart2_mpu_irqs[] = {
|
|
{ .irq = INT_24XX_UART2_IRQ, },
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_uart3_mpu_irqs[] = {
|
|
{ .irq = INT_24XX_UART3_IRQ, },
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_dispc_irqs[] = {
|
|
{ .irq = 25 },
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_i2c1_mpu_irqs[] = {
|
|
{ .irq = INT_24XX_I2C1_IRQ, },
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_i2c2_mpu_irqs[] = {
|
|
{ .irq = INT_24XX_I2C2_IRQ, },
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_gpio1_irqs[] = {
|
|
{ .irq = 29 }, /* INT_24XX_GPIO_BANK1 */
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_gpio2_irqs[] = {
|
|
{ .irq = 30 }, /* INT_24XX_GPIO_BANK2 */
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_gpio3_irqs[] = {
|
|
{ .irq = 31 }, /* INT_24XX_GPIO_BANK3 */
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_gpio4_irqs[] = {
|
|
{ .irq = 32 }, /* INT_24XX_GPIO_BANK4 */
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_dma_system_irqs[] = {
|
|
{ .name = "0", .irq = 12 }, /* INT_24XX_SDMA_IRQ0 */
|
|
{ .name = "1", .irq = 13 }, /* INT_24XX_SDMA_IRQ1 */
|
|
{ .name = "2", .irq = 14 }, /* INT_24XX_SDMA_IRQ2 */
|
|
{ .name = "3", .irq = 15 }, /* INT_24XX_SDMA_IRQ3 */
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_mcspi1_mpu_irqs[] = {
|
|
{ .irq = 65 },
|
|
{ .irq = -1 }
|
|
};
|
|
|
|
struct omap_hwmod_irq_info omap2_mcspi2_mpu_irqs[] = {
|
|
{ .irq = 66 },
|
|
{ .irq = -1 }
|
|
};
|
|
|