GNU Linux-libre 4.14.332-gnu1
[releases.git] / arch / arm / mach-omap2 / omap_hwmod_common_data.h
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