1 /* 2 * omap_hwmod_common_data.h - OMAP hwmod common macros and declarations 3 * 4 * Copyright (C) 2010-2011 Nokia Corporation 5 * Copyright (C) 2010-2012 Texas Instruments, Inc. 6 * Paul Walmsley 7 * Benoît Cousson 8 * 9 * This program is free software; you can redistribute it and/or modify 10 * it under the terms of the GNU General Public License version 2 as 11 * published by the Free Software Foundation. 12 */ 13 #ifndef __ARCH_ARM_MACH_OMAP2_OMAP_HWMOD_COMMON_DATA_H 14 #define __ARCH_ARM_MACH_OMAP2_OMAP_HWMOD_COMMON_DATA_H 15 16 #include "omap_hwmod.h" 17 18 #include "common.h" 19 #include "display.h" 20 21 /* Common address space across OMAP2xxx/3xxx */ 22 extern struct omap_hwmod_addr_space omap2_dma_system_addrs[]; 23 24 /* Common IP block data across OMAP2xxx */ 25 extern struct omap_gpio_dev_attr omap2xxx_gpio_dev_attr; 26 extern struct omap_hwmod omap2xxx_l3_main_hwmod; 27 extern struct omap_hwmod omap2xxx_l4_core_hwmod; 28 extern struct omap_hwmod omap2xxx_l4_wkup_hwmod; 29 extern struct omap_hwmod omap2xxx_mpu_hwmod; 30 extern struct omap_hwmod omap2xxx_iva_hwmod; 31 extern struct omap_hwmod omap2xxx_timer1_hwmod; 32 extern struct omap_hwmod omap2xxx_timer2_hwmod; 33 extern struct omap_hwmod omap2xxx_timer3_hwmod; 34 extern struct omap_hwmod omap2xxx_timer4_hwmod; 35 extern struct omap_hwmod omap2xxx_timer5_hwmod; 36 extern struct omap_hwmod omap2xxx_timer6_hwmod; 37 extern struct omap_hwmod omap2xxx_timer7_hwmod; 38 extern struct omap_hwmod omap2xxx_timer8_hwmod; 39 extern struct omap_hwmod omap2xxx_timer9_hwmod; 40 extern struct omap_hwmod omap2xxx_timer10_hwmod; 41 extern struct omap_hwmod omap2xxx_timer11_hwmod; 42 extern struct omap_hwmod omap2xxx_timer12_hwmod; 43 extern struct omap_hwmod omap2xxx_wd_timer2_hwmod; 44 extern struct omap_hwmod omap2xxx_uart1_hwmod; 45 extern struct omap_hwmod omap2xxx_uart2_hwmod; 46 extern struct omap_hwmod omap2xxx_uart3_hwmod; 47 extern struct omap_hwmod omap2xxx_dss_core_hwmod; 48 extern struct omap_hwmod omap2xxx_dss_dispc_hwmod; 49 extern struct omap_hwmod omap2xxx_dss_rfbi_hwmod; 50 extern struct omap_hwmod omap2xxx_dss_venc_hwmod; 51 extern struct omap_hwmod omap2xxx_gpio1_hwmod; 52 extern struct omap_hwmod omap2xxx_gpio2_hwmod; 53 extern struct omap_hwmod omap2xxx_gpio3_hwmod; 54 extern struct omap_hwmod omap2xxx_gpio4_hwmod; 55 extern struct omap_hwmod omap2xxx_mcspi1_hwmod; 56 extern struct omap_hwmod omap2xxx_mcspi2_hwmod; 57 extern struct omap_hwmod omap2xxx_counter_32k_hwmod; 58 extern struct omap_hwmod omap2xxx_gpmc_hwmod; 59 extern struct omap_hwmod omap2xxx_rng_hwmod; 60 extern struct omap_hwmod omap2xxx_sham_hwmod; 61 extern struct omap_hwmod omap2xxx_aes_hwmod; 62 63 /* Common interface data across OMAP2xxx */ 64 extern struct omap_hwmod_ocp_if omap2xxx_l3_main__l4_core; 65 extern struct omap_hwmod_ocp_if omap2xxx_mpu__l3_main; 66 extern struct omap_hwmod_ocp_if omap2xxx_dss__l3; 67 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__l4_wkup; 68 extern struct omap_hwmod_ocp_if omap2_l4_core__uart1; 69 extern struct omap_hwmod_ocp_if omap2_l4_core__uart2; 70 extern struct omap_hwmod_ocp_if omap2_l4_core__uart3; 71 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__mcspi1; 72 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__mcspi2; 73 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__timer2; 74 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__timer3; 75 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__timer4; 76 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__timer5; 77 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__timer6; 78 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__timer7; 79 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__timer8; 80 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__timer9; 81 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__timer10; 82 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__timer11; 83 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__timer12; 84 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__dss; 85 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__dss_dispc; 86 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__dss_rfbi; 87 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__dss_venc; 88 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__rng; 89 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__sham; 90 extern struct omap_hwmod_ocp_if omap2xxx_l4_core__aes; 91 92 /* Common IP block data */ 93 extern struct omap_hwmod_dma_info omap2_uart1_sdma_reqs[]; 94 extern struct omap_hwmod_dma_info omap2_uart2_sdma_reqs[]; 95 extern struct omap_hwmod_dma_info omap2_uart3_sdma_reqs[]; 96 extern struct omap_hwmod_dma_info omap2_i2c1_sdma_reqs[]; 97 extern struct omap_hwmod_dma_info omap2_i2c2_sdma_reqs[]; 98 extern struct omap_hwmod_dma_info omap2_mcspi1_sdma_reqs[]; 99 extern struct omap_hwmod_dma_info omap2_mcspi2_sdma_reqs[]; 100 extern struct omap_hwmod_dma_info omap2_mcbsp1_sdma_reqs[]; 101 extern struct omap_hwmod_dma_info omap2_mcbsp2_sdma_reqs[]; 102 103 /* Common IP block data on OMAP2430/OMAP3 */ 104 extern struct omap_hwmod_dma_info omap2_mcbsp3_sdma_reqs[]; 105 106 /* Common IP block data across OMAP2/3 */ 107 extern struct omap_hwmod_irq_info omap2_timer1_mpu_irqs[]; 108 extern struct omap_hwmod_irq_info omap2_timer2_mpu_irqs[]; 109 extern struct omap_hwmod_irq_info omap2_timer3_mpu_irqs[]; 110 extern struct omap_hwmod_irq_info omap2_timer4_mpu_irqs[]; 111 extern struct omap_hwmod_irq_info omap2_timer5_mpu_irqs[]; 112 extern struct omap_hwmod_irq_info omap2_timer6_mpu_irqs[]; 113 extern struct omap_hwmod_irq_info omap2_timer7_mpu_irqs[]; 114 extern struct omap_hwmod_irq_info omap2_timer8_mpu_irqs[]; 115 extern struct omap_hwmod_irq_info omap2_timer9_mpu_irqs[]; 116 extern struct omap_hwmod_irq_info omap2_timer10_mpu_irqs[]; 117 extern struct omap_hwmod_irq_info omap2_timer11_mpu_irqs[]; 118 extern struct omap_hwmod_irq_info omap2_uart1_mpu_irqs[]; 119 extern struct omap_hwmod_irq_info omap2_uart2_mpu_irqs[]; 120 extern struct omap_hwmod_irq_info omap2_uart3_mpu_irqs[]; 121 extern struct omap_hwmod_irq_info omap2_dispc_irqs[]; 122 extern struct omap_hwmod_irq_info omap2_i2c1_mpu_irqs[]; 123 extern struct omap_hwmod_irq_info omap2_i2c2_mpu_irqs[]; 124 extern struct omap_hwmod_irq_info omap2_dma_system_irqs[]; 125 extern struct omap_hwmod_irq_info omap2_mcspi1_mpu_irqs[]; 126 extern struct omap_hwmod_irq_info omap2_mcspi2_mpu_irqs[]; 127 extern struct omap_hwmod_addr_space omap2xxx_timer12_addrs[]; 128 extern struct omap_hwmod_irq_info omap2_hdq1w_mpu_irqs[]; 129 130 /* OMAP hwmod classes - forward declarations */ 131 extern struct omap_hwmod_class l3_hwmod_class; 132 extern struct omap_hwmod_class l4_hwmod_class; 133 extern struct omap_hwmod_class mpu_hwmod_class; 134 extern struct omap_hwmod_class iva_hwmod_class; 135 extern struct omap_hwmod_class omap2_uart_class; 136 extern struct omap_hwmod_class omap2_dss_hwmod_class; 137 extern struct omap_hwmod_class omap2_dispc_hwmod_class; 138 extern struct omap_hwmod_class omap2_rfbi_hwmod_class; 139 extern struct omap_hwmod_class omap2_venc_hwmod_class; 140 extern struct omap_hwmod_class_sysconfig omap2_hdq1w_sysc; 141 extern struct omap_hwmod_class omap2_hdq1w_class; 142 143 extern struct omap_hwmod_class omap2xxx_timer_hwmod_class; 144 extern struct omap_hwmod_class omap2xxx_wd_timer_hwmod_class; 145 extern struct omap_hwmod_class omap2xxx_gpio_hwmod_class; 146 extern struct omap_hwmod_class omap2xxx_dma_hwmod_class; 147 extern struct omap_hwmod_class omap2xxx_mailbox_hwmod_class; 148 extern struct omap_hwmod_class omap2xxx_mcspi_class; 149 150 extern struct omap_dss_dispc_dev_attr omap2_3_dss_dispc_dev_attr; 151 152 #endif 153