RTEMS 7.0-rc1
Loading...
Searching...
No Matches
am335x.h
1/* SPDX-License-Identifier: BSD-2-Clause */
2
3/*
4 * Copyright (c) 2012 Claas Ziemke. All rights reserved.
5 *
6 * Claas Ziemke
7 * Kernerstrasse 11
8 * 70182 Stuttgart
9 * Germany
10 * <claas.ziemke@gmx.net>
11 *
12 * Redistribution and use in source and binary forms, with or without
13 * modification, are permitted provided that the following conditions
14 * are met:
15 * 1. Redistributions of source code must retain the above copyright
16 * notice, this list of conditions and the following disclaimer.
17 * 2. Redistributions in binary form must reproduce the above copyright
18 * notice, this list of conditions and the following disclaimer in the
19 * documentation and/or other materials provided with the distribution.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
22 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
25 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
26 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
27 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
28 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
29 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
31 * POSSIBILITY OF SUCH DAMAGE.
32 */
33
34#if !defined(_AM335X_H_)
35#define _AM335X_H_
36
37#define AM335X_MASK(Shift, Width) (((1 << (Width)) - 1) << (Shift))
38
39
40/* Interrupt controller memory map */
41#define OMAP3_DM37XX_INTR_BASE 0x48200000 /* INTCPS physical address */
42
43/* Interrupt controller memory map */
44#define OMAP3_AM335X_INTR_BASE 0x48200000 /* INTCPS physical address */
45
46#define AM335X_INT_EMUINT 0
47 /* Emulation interrupt (EMUICINTR) */
48#define AM335X_INT_COMMTX 1
49 /* CortexA8 COMMTX */
50#define AM335X_INT_COMMRX 2
51 /* CortexA8 COMMRX */
52#define AM335X_INT_BENCH 3
53 /* CortexA8 NPMUIRQ */
54#define AM335X_INT_ELM_IRQ 4
55 /* Sinterrupt (Error location process completion) */
56#define AM335X_INT_NMI 7
57 /* nmi_int */
58#define AM335X_INT_L3DEBUG 9
59 /* l3_FlagMux_top_FlagOut1 */
60#define AM335X_INT_L3APPINT 10
61 /* l3_FlagMux_top_FlagOut0 */
62#define AM335X_INT_PRCMINT 11
63 /* irq_mpu */
64#define AM335X_INT_EDMACOMPINT 12
65 /* tpcc_int_pend_po0 */
66#define AM335X_INT_EDMAMPERR 13
67 /* tpcc_mpint_pend_po */
68#define AM335X_INT_EDMAERRINT 14
69 /* tpcc_errint_pend_po */
70#define AM335X_INT_ADC_TSC_GENINT 16
71 /* gen_intr_pend */
72#define AM335X_INT_USBSSINT 17
73 /* usbss_intr_pend */
74#define AM335X_INT_USB0 18
75 /* usb0_intr_pend */
76#define AM335X_INT_USB1 19
77 /* usb1_intr_pend */
78#define AM335X_INT_PRUSS1_EVTOUT0 20
79 /* pr1_host_intr0_intr_pend */
80#define AM335X_INT_PRUSS1_EVTOUT1 21
81 /* pr1_host_intr1_intr_pend */
82#define AM335X_INT_PRUSS1_EVTOUT2 22
83 /* pr1_host_intr2_intr_pend */
84#define AM335X_INT_PRUSS1_EVTOUT3 23
85 /* pr1_host_intr3_intr_pend */
86#define AM335X_INT_PRUSS1_EVTOUT4 24
87 /* pr1_host_intr4_intr_pend */
88#define AM335X_INT_PRUSS1_EVTOUT5 25
89 /* pr1_host_intr5_intr_pend */
90#define AM335X_INT_PRUSS1_EVTOUT6 26
91 /* pr1_host_intr6_intr_pend */
92#define AM335X_INT_PRUSS1_EVTOUT7 27
93 /* pr1_host_intr7_intr_pend */
94#define AM335X_INT_MMCSD1INT 28
95 /* MMCSD1 SINTERRUPTN */
96#define AM335X_INT_MMCSD2INT 29
97 /* MMCSD2 SINTERRUPT */
98#define AM335X_INT_I2C2INT 30
99 /* I2C2 POINTRPEND */
100#define AM335X_INT_eCAP0INT 31
101 /* ecap_intr_intr_pend */
102#define AM335X_INT_GPIOINT2A 32
103 /* GPIO 2 POINTRPEND1 */
104#define AM335X_INT_GPIOINT2B 33
105 /* GPIO 2 POINTRPEND2 */
106#define AM335X_INT_USBWAKEUP 34
107 /* USBSS slv0p_Swakeup */
108#define AM335X_INT_LCDCINT 36
109 /* LCDC lcd_irq */
110#define AM335X_INT_GFXINT 37
111 /* SGX530 THALIAIRQ */
112#define AM335X_INT_ePWM2INT 39
113 /* (PWM Subsystem) epwm_intr_intr_pend */
114#define AM335X_INT_3PGSWRXTHR0 40
115 /* (Ethernet) c0_rx_thresh_pend (RX_THRESH_PULSE) */
116#define AM335X_INT_3PGSWRXINT0 41
117 /* CPSW (Ethernet) c0_rx_pend */
118#define AM335X_INT_3PGSWTXINT0 42
119 /* CPSW (Ethernet) c0_tx_pend */
120#define AM335X_INT_3PGSWMISC0 43
121 /* CPSW (Ethernet) c0_misc_pend */
122#define AM335X_INT_UART3INT 44
123 /* UART3 niq */
124#define AM335X_INT_UART4INT 45
125 /* UART4 niq */
126#define AM335X_INT_UART5INT 46
127 /* UART5 niq */
128#define AM335X_INT_eCAP1INT 47
129 /* (PWM Subsystem) ecap_intr_intr_pend */
130#define AM335X_INT_DCAN0_INT0 52
131 /* DCAN0 dcan_intr0_intr_pend */
132#define AM335X_INT_DCAN0_INT1 53
133 /* DCAN0 dcan_intr1_intr_pend */
134#define AM335X_INT_DCAN0_PARITY 54
135 /* DCAN0 dcan_uerr_intr_pend */
136#define AM335X_INT_DCAN1_INT0 55
137 /* DCAN1 dcan_intr0_intr_pend */
138#define AM335X_INT_DCAN1_INT1 56
139 /* DCAN1 dcan_intr1_intr_pend */
140#define AM335X_INT_DCAN1_PARITY 57
141 /* DCAN1 dcan_uerr_intr_pend */
142#define AM335X_INT_ePWM0_TZINT 58
143 /* eHRPWM0 TZ interrupt (PWM epwm_tz_intr_pend Subsystem) */
144#define AM335X_INT_ePWM1_TZINT 59
145 /* eHRPWM1 TZ interrupt (PWM epwm_tz_intr_pend Subsystem) */
146#define AM335X_INT_ePWM2_TZINT 60
147 /* eHRPWM2 TZ interrupt (PWM epwm_tz_intr_pend Subsystem) */
148#define AM335X_INT_eCAP2INT 61
149 /* eCAP2 (PWM Subsystem) ecap_intr_intr_pend */
150#define AM335X_INT_GPIOINT3A 62
151 /* GPIO 3 POINTRPEND1 */
152#define AM335X_INT_GPIOINT3B 63
153 /* GPIO 3 POINTRPEND2 */
154#define AM335X_INT_MMCSD0INT 64
155 /* MMCSD0 SINTERRUPTN */
156#define AM335X_INT_SPI0INT 65
157 /* McSPI0 SINTERRUPTN */
158#define AM335X_INT_TINT0 66
159 /* Timer0 POINTR_PEND */
160#define AM335X_INT_TINT1_1MS 67
161 /* DMTIMER_1ms POINTR_PEND */
162#define AM335X_INT_TINT2 68
163 /* DMTIMER2 POINTR_PEND */
164#define AM335X_INT_TINT3 69
165 /* DMTIMER3 POINTR_PEND */
166#define AM335X_INT_I2C0INT 70
167 /* I2C0 POINTRPEND */
168#define AM335X_INT_I2C1INT 71
169 /* I2C1 POINTRPEND */
170#define AM335X_INT_UART0INT 72
171 /* UART0 niq */
172#define AM335X_INT_UART1INT 73
173 /* UART1 niq */
174#define AM335X_INT_UART2INT 74
175 /* UART2 niq */
176#define AM335X_INT_RTCINT 75
177 /* RTC timer_intr_pend */
178#define AM335X_INT_RTCALARMINT 76
179 /* RTC alarm_intr_pend */
180#define AM335X_INT_MBINT0 77
181 /* Mailbox0 (mail_u0_irq) initiator_sinterrupt_q_n */
182#define AM335X_INT_M3_TXEV 78
183 /* Wake M3 Subsystem TXEV */
184#define AM335X_INT_eQEP0INT 79
185 /* eQEP0 (PWM Subsystem) eqep_intr_intr_pend */
186#define AM335X_INT_MCATXINT0 80
187 /* McASP0 mcasp_x_intr_pend */
188#define AM335X_INT_MCARXINT0 81
189 /* McASP0 mcasp_r_intr_pend */
190#define AM335X_INT_MCATXINT1 82
191 /* McASP1 mcasp_x_intr_pend */
192#define AM335X_INT_MCARXINT1 83
193 /* McASP1 mcasp_r_intr_pend */
194#define AM335X_INT_ePWM0INT 86
195 /* (PWM Subsystem) epwm_intr_intr_pend */
196#define AM335X_INT_ePWM1INT 87
197 /* (PWM Subsystem) epwm_intr_intr_pend */
198#define AM335X_INT_eQEP1INT 88
199 /* (PWM Subsystem) eqep_intr_intr_pend */
200#define AM335X_INT_eQEP2INT 89
201 /* (PWM Subsystem) eqep_intr_intr_pend */
202#define AM335X_INT_DMA_INTR_PIN2 90
203 /* External DMA/Interrupt Pin2 */
204#define AM335X_INT_WDT1INT 91
205 /* (Public Watchdog) WDTIMER1 PO_INT_PEND */
206#define AM335X_INT_TINT4 92
207 /* DMTIMER4 POINTR_PEN */
208#define AM335X_INT_TINT5 93
209 /* DMTIMER5 POINTR_PEN */
210#define AM335X_INT_TINT6 94
211 /* DMTIMER6 POINTR_PEND */
212#define AM335X_INT_TINT7 95
213 /* DMTIMER7 POINTR_PEND */
214#define AM335X_INT_GPIOINT0A 96
215 /* GPIO 0 POINTRPEND1 */
216#define AM335X_INT_GPIOINT0B 97
217 /* GPIO 0 POINTRPEND2 */
218#define AM335X_INT_GPIOINT1A 98
219 /* GPIO 1 POINTRPEND1 */
220#define AM335X_INT_GPIOINT1B 99
221 /* GPIO 1 POINTRPEND2 */
222#define AM335X_INT_GPMCINT 100
223 /* GPMC gpmc_sinterrupt */
224#define AM335X_INT_DDRERR0 101
225 /* EMIF sys_err_intr_pend */
226#define AM335X_INT_TCERRINT0 112
227 /* TPTC0 tptc_erint_pend_po */
228#define AM335X_INT_TCERRINT1 113
229 /* TPTC1 tptc_erint_pend_po */
230#define AM335X_INT_TCERRINT2 114
231 /* TPTC2 tptc_erint_pend_po */
232#define AM335X_INT_ADC_TSC_PENINT 115
233 /* ADC_TSC pen_intr_pend */
234#define AM335X_INT_SMRFLX_Sabertooth 120
235 /* Smart Reflex 0 intrpen */
236#define AM335X_INT_SMRFLX_Core 121
237 /* Smart Reflex 1 intrpend */
238#define AM335X_INT_DMA_INTR_PIN0 123
239 /* pi_x_dma_event_intr0 (xdma_event_intr0) */
240#define AM335X_INT_DMA_INTR_PIN1 124
241 /* pi_x_dma_event_intr1 (xdma_event_intr1) */
242#define AM335X_INT_SPI1INT 125
243 /* McSPI1 SINTERRUPTN */
244
245#define OMAP3_AM335X_NR_IRQ_VECTORS 125
246
247#define AM335X_DMTIMER0_BASE 0x44E05000
248 /* DMTimer0 Registers */
249#define AM335X_DMTIMER1_1MS_BASE 0x44E31000
250 /* DMTimer1 1ms Registers (Accurate 1ms timer) */
251#define AM335X_DMTIMER2_BASE 0x48040000
252 /* DMTimer2 Registers */
253#define AM335X_DMTIMER3_BASE 0x48042000
254 /* DMTimer3 Registers */
255#define AM335X_DMTIMER4_BASE 0x48044000
256 /* DMTimer4 Registers */
257#define AM335X_DMTIMER5_BASE 0x48046000
258 /* DMTimer5 Registers */
259#define AM335X_DMTIMER6_BASE 0x48048000
260 /* DMTimer6 Registers */
261#define AM335X_DMTIMER7_BASE 0x4804A000
262 /* DMTimer7 Registers */
263
264/* General-purpose timer registers
265 AM335x non 1MS timers have different offsets */
266#define AM335X_TIMER_TIDR 0x000
267 /* IP revision code */
268#define AM335X_TIMER_TIOCP_CFG 0x010
269 /* Controls params for GP timer L4 interface */
270#define AM335X_TIMER_IRQSTATUS_RAW 0x024
271 /* Timer IRQSTATUS Raw Register */
272#define AM335X_TIMER_IRQSTATUS 0x028
273 /* Timer IRQSTATUS Register */
274#define AM335X_TIMER_IRQENABLE_SET 0x02C
275 /* Timer IRQENABLE Set Register */
276#define AM335X_TIMER_IRQENABLE_CLR 0x030
277 /* Timer IRQENABLE Clear Register */
278#define AM335X_TIMER_IRQWAKEEN 0x034
279 /* Timer IRQ Wakeup Enable Register */
280#define AM335X_TIMER_TCLR 0x038
281 /* Controls optional features */
282#define AM335X_TIMER_TCRR 0x03C
283 /* Internal counter value */
284#define AM335X_TIMER_TLDR 0x040
285 /* Timer load value */
286#define AM335X_TIMER_TTGR 0x044
287 /* Triggers counter reload */
288#define AM335X_TIMER_TWPS 0x048
289 /* Indicates if Write-Posted pending */
290#define AM335X_TIMER_TMAR 0x04C
291 /* Value to be compared with counter */
292#define AM335X_TIMER_TCAR1 0x050
293 /* First captured value of counter register */
294#define AM335X_TIMER_TSICR 0x054
295 /* Control posted mode and functional SW reset */
296#define AM335X_TIMER_TCAR2 0x058
297 /* Second captured value of counter register */
298#define AM335X_WDT_BASE 0x44E35000
299 /* Watchdog timer */
300#define AM335X_WDT_WWPS 0x34
301 /* Command posted status */
302#define AM335X_WDT_WSPR 0x48
303 /* Activate/deactivate sequence */
304
305/* RTC registers */
306#define AM335X_RTC_BASE 0x44E3E000
307#define AM335X_RTC_SECS 0x0
308#define AM335X_RTC_MINS 0x4
309#define AM335X_RTC_HOURS 0x8
310#define AM335X_RTC_DAYS 0xc
311#define AM335X_RTC_MONTHS 0x10
312#define AM335X_RTC_YEARS 0x14
313#define AM335X_RTC_WEEKS 0x18
314#define AM335X_RTC_CTRL_REG 0x40
315#define AM335X_RTC_STATUS_REG 0x44
316#define AM335X_RTC_REV_REG 0x74
317#define AM335X_RTC_SYSCONFIG 0x78
318#define AM335X_RTC_KICK0 0x6c
319#define AM335X_RTC_KICK1 0x70
320#define AM335X_RTC_OSC_CLOCK 0x54
321
322#define AM335X_RTC_KICK0_KEY 0x83E70B13
323#define AM335X_RTC_KICK1_KEY 0x95A4F1E0
324
325/* GPIO memory-mapped registers */
326
327#define AM335X_GPIO0_BASE 0x44E07000
328 /* GPIO Bank 0 base Register */
329#define AM335X_GPIO1_BASE 0x4804C000
330 /* GPIO Bank 1 base Register */
331#define AM335X_GPIO2_BASE 0x481AC000
332 /* GPIO Bank 2 base Register */
333#define AM335X_GPIO3_BASE 0x481AE000
334 /* GPIO Bank 3 base Register */
335
336#define AM335X_GPIO_REVISION 0x00
337#define AM335X_GPIO_SYSCONFIG 0x10
338#define AM335X_GPIO_EOI 0x20
339#define AM335X_GPIO_IRQSTATUS_RAW_0 0x24
340#define AM335X_GPIO_IRQSTATUS_RAW_1 0x28
341#define AM335X_GPIO_IRQSTATUS_0 0x2C
342#define AM335X_GPIO_IRQSTATUS_1 0x30
343#define AM335X_GPIO_IRQSTATUS_SET_0 0x34
344#define AM335X_GPIO_IRQSTATUS_SET_1 0x38
345#define AM335X_GPIO_IRQSTATUS_CLR_0 0x3C
346#define AM335X_GPIO_IRQSTATUS_CLR_1 0x40
347#define AM335X_GPIO_IRQWAKEN_0 0x44
348#define AM335X_GPIO_IRQWAKEN_1 0x48
349#define AM335X_GPIO_SYSSTATUS 0x114
350#define AM335X_GPIO_CTRL 0x130
351#define AM335X_GPIO_OE 0x134
352#define AM335X_GPIO_DATAIN 0x138
353#define AM335X_GPIO_DATAOUT 0x13C
354#define AM335X_GPIO_LEVELDETECT0 0x140
355#define AM335X_GPIO_LEVELDETECT1 0x144
356#define AM335X_GPIO_RISINGDETECT 0x148
357#define AM335X_GPIO_FALLINGDETECT 0x14C
358#define AM335X_GPIO_DEBOUNCENABLE 0x150
359#define AM335X_GPIO_DEBOUNCINGTIME 0x154
360#define AM335X_GPIO_CLEARDATAOUT 0x190
361#define AM335X_GPIO_SETDATAOUT 0x194
362
363/* AM335X Pad Configuration Register Base */
364#define AM335X_PADCONF_BASE 0x44E10000
365
366/* Memory mapped register offset for Control Module */
367#define AM335X_CONF_GPMC_AD0 0x800
368#define AM335X_CONF_GPMC_AD1 0x804
369#define AM335X_CONF_GPMC_AD2 0x808
370#define AM335X_CONF_GPMC_AD3 0x80C
371#define AM335X_CONF_GPMC_AD4 0x810
372#define AM335X_CONF_GPMC_AD5 0x814
373#define AM335X_CONF_GPMC_AD6 0x818
374#define AM335X_CONF_GPMC_AD7 0x81C
375#define AM335X_CONF_GPMC_AD8 0x820
376#define AM335X_CONF_GPMC_AD9 0x824
377#define AM335X_CONF_GPMC_AD10 0x828
378#define AM335X_CONF_GPMC_AD11 0x82C
379#define AM335X_CONF_GPMC_AD12 0x830
380#define AM335X_CONF_GPMC_AD13 0x834
381#define AM335X_CONF_GPMC_AD14 0x838
382#define AM335X_CONF_GPMC_AD15 0x83C
383#define AM335X_CONF_GPMC_A0 0x840
384#define AM335X_CONF_GPMC_A1 0x844
385#define AM335X_CONF_GPMC_A2 0x848
386#define AM335X_CONF_GPMC_A3 0x84C
387#define AM335X_CONF_GPMC_A4 0x850
388#define AM335X_CONF_GPMC_A5 0x854
389#define AM335X_CONF_GPMC_A6 0x858
390#define AM335X_CONF_GPMC_A7 0x85C
391#define AM335X_CONF_GPMC_A8 0x860
392#define AM335X_CONF_GPMC_A9 0x864
393#define AM335X_CONF_GPMC_A10 0x868
394#define AM335X_CONF_GPMC_A11 0x86C
395#define AM335X_CONF_GPMC_WAIT0 0x870
396#define AM335X_CONF_GPMC_WPN 0x874
397#define AM335X_CONF_GPMC_BEN1 0x878
398#define AM335X_CONF_GPMC_CSN0 0x87C
399#define AM335X_CONF_GPMC_CSN1 0x880
400#define AM335X_CONF_GPMC_CSN2 0x884
401#define AM335X_CONF_GPMC_CSN3 0x888
402#define AM335X_CONF_GPMC_CLK 0x88C
403#define AM335X_CONF_GPMC_ADVN_ALE 0x890
404#define AM335X_CONF_GPMC_OEN_REN 0x894
405#define AM335X_CONF_GPMC_WEN 0x898
406#define AM335X_CONF_GPMC_BEN0_CLE 0x89C
407#define AM335X_CONF_LCD_DATA0 0x8A0
408#define AM335X_CONF_LCD_DATA1 0x8A4
409#define AM335X_CONF_LCD_DATA2 0x8A8
410#define AM335X_CONF_LCD_DATA3 0x8AC
411#define AM335X_CONF_LCD_DATA4 0x8B0
412#define AM335X_CONF_LCD_DATA5 0x8B4
413#define AM335X_CONF_LCD_DATA6 0x8B8
414#define AM335X_CONF_LCD_DATA7 0x8BC
415#define AM335X_CONF_LCD_DATA8 0x8C0
416#define AM335X_CONF_LCD_DATA9 0x8C4
417#define AM335X_CONF_LCD_DATA10 0x8C8
418#define AM335X_CONF_LCD_DATA11 0x8CC
419#define AM335X_CONF_LCD_DATA12 0x8D0
420#define AM335X_CONF_LCD_DATA13 0x8D4
421#define AM335X_CONF_LCD_DATA14 0x8D8
422#define AM335X_CONF_LCD_DATA15 0x8DC
423#define AM335X_CONF_LCD_VSYNC 0x8E0
424#define AM335X_CONF_LCD_HSYNC 0x8E4
425#define AM335X_CONF_LCD_PCLK 0x8E8
426#define AM335X_CONF_LCD_AC_BIAS_EN 0x8EC
427#define AM335X_CONF_MMC0_DAT3 0x8F0
428#define AM335X_CONF_MMC0_DAT2 0x8F4
429#define AM335X_CONF_MMC0_DAT1 0x8F8
430#define AM335X_CONF_MMC0_DAT0 0x8FC
431#define AM335X_CONF_MMC0_CLK 0x900
432#define AM335X_CONF_MMC0_CMD 0x904
433#define AM335X_CONF_MII1_COL 0x908
434#define AM335X_CONF_MII1_CRS 0x90C
435#define AM335X_CONF_MII1_RX_ER 0x910
436#define AM335X_CONF_MII1_TX_EN 0x914
437#define AM335X_CONF_MII1_RX_DV 0x918
438#define AM335X_CONF_MII1_TXD3 0x91C
439#define AM335X_CONF_MII1_TXD2 0x920
440#define AM335X_CONF_MII1_TXD1 0x924
441#define AM335X_CONF_MII1_TXD0 0x928
442#define AM335X_CONF_MII1_TX_CLK 0x92C
443#define AM335X_CONF_MII1_RX_CLK 0x930
444#define AM335X_CONF_MII1_RXD3 0x934
445#define AM335X_CONF_MII1_RXD2 0x938
446#define AM335X_CONF_MII1_RXD1 0x93C
447#define AM335X_CONF_MII1_RXD0 0x940
448#define AM335X_CONF_RMII1_REF_CLK 0x944
449#define AM335X_CONF_MDIO 0x948
450#define AM335X_CONF_MDC 0x94C
451#define AM335X_CONF_SPI0_SCLK 0x950
452#define AM335X_CONF_SPI0_D0 0x954
453#define AM335X_CONF_SPI0_D1 0x958
454#define AM335X_CONF_SPI0_CS0 0x95C
455#define AM335X_CONF_SPI0_CS1 0x960
456#define AM335X_CONF_ECAP0_IN_PWM0_OUT 0x964
457#define AM335X_CONF_UART0_CTSN 0x968
458#define AM335X_CONF_UART0_RTSN 0x96C
459#define AM335X_CONF_UART0_RXD 0x970
460#define AM335X_CONF_UART0_TXD 0x974
461#define AM335X_CONF_UART1_CTSN 0x978
462#define AM335X_CONF_UART1_RTSN 0x97C
463#define AM335X_CONF_UART1_RXD 0x980
464#define AM335X_CONF_UART1_TXD 0x984
465#define AM335X_CONF_I2C0_SDA 0x988
466#define AM335X_CONF_I2C0_SCL 0x98C
467#define AM335X_CONF_MCASP0_ACLKX 0x990
468#define AM335X_CONF_MCASP0_FSX 0x994
469#define AM335X_CONF_MCASP0_AXR0 0x998
470#define AM335X_CONF_MCASP0_AHCLKR 0x99C
471#define AM335X_CONF_MCASP0_ACLKR 0x9A0
472#define AM335X_CONF_MCASP0_FSR 0x9A4
473#define AM335X_CONF_MCASP0_AXR1 0x9A8
474#define AM335X_CONF_MCASP0_AHCLKX 0x9AC
475#define AM335X_CONF_XDMA_EVENT_INTR0 0x9B0
476#define AM335X_CONF_XDMA_EVENT_INTR1 0x9B4
477#define AM335X_CONF_WARMRSTN 0x9B8
478#define AM335X_CONF_NNMI 0x9C0
479#define AM335X_CONF_TMS 0x9D0
480#define AM335X_CONF_TDI 0x9D4
481#define AM335X_CONF_TDO 0x9D8
482#define AM335X_CONF_TCK 0x9DC
483#define AM335X_CONF_TRSTN 0x9E0
484#define AM335X_CONF_EMU0 0x9E4
485#define AM335X_CONF_EMU1 0x9E8
486#define AM335X_CONF_RTC_PWRONRSTN 0x9F8
487#define AM335X_CONF_PMIC_POWER_EN 0x9FC
488#define AM335X_CONF_EXT_WAKEUP 0xA00
489#define AM335X_CONF_RTC_KALDO_ENN 0xA04
490#define AM335X_CONF_USB0_DRVVBUS 0xA1C
491#define AM335X_CONF_USB1_DRVVBUS 0xA34
492
493/* Registers for PWM Subsystem */
494#define AM335X_PWMSS_CTRL (0x664)
495#define AM335X_CM_PER_EPWMSS0_CLKCTRL (0xD4)
496#define AM335X_CM_PER_EPWMSS1_CLKCTRL (0xCC)
497#define AM335X_CM_PER_EPWMSS2_CLKCTRL (0xD8)
498#define AM335X_CONTROL_MODULE (0x44e10000)
499#define AM335X_CM_PER_ADDR (0x44e00000)
500#define AM335X_PWMSS_CLKSTATUS (0xC)
501#define AM335X_PWMSS0_MMAP_ADDR 0x48300000
502#define AM335X_PWMSS1_MMAP_ADDR 0x48302000
503#define AM335X_PWMSS2_MMAP_ADDR 0x48304000
504#define AM335X_PWMSS_MMAP_LEN 0x1000
505#define AM335X_PWMSS_IDVER 0x0
506#define AM335X_PWMSS_SYSCONFIG 0x4
507#define AM335X_PWMSS_CLKCONFIG 0x8
508#define AM335X_PWMSS_CLK_EN_ACK 0x100
509#define AM335X_EPWM_TBCTL 0x0
510#define AM335X_EPWM_TBSTS 0x2
511#define AM335X_EPWM_TBPHSHR 0x4
512#define AM335X_EPWM_TBPHS 0x6
513#define AM335X_EPWM_TBCNT 0x8
514#define AM335X_EPWM_TBPRD 0xA
515#define AM335X_EPWM_CMPCTL 0xE
516#define AM335X_EPWM_CMPAHR 0x10
517#define AM335X_EPWM_CMPA 0x12
518#define AM335X_EPWM_CMPB 0x14
519#define AM335X_EPWM_AQCTLA 0x16
520#define AM335X_EPWM_AQCTLB 0x18
521#define AM335X_EPWM_AQSFRC 0x1A
522#define AM335X_EPWM_AQCSFRC 0x1C
523#define AM335X_EPWM_DBCTL 0x1E
524#define AM335X_EPWM_DBRED 0x20
525#define AM335X_EPWM_DBFED 0x22
526#define AM335X_TBCTL_CTRMODE_UP 0x0
527#define AM335X_TBCTL_CTRMODE_DOWN 0x1
528#define AM335X_TBCTL_CTRMODE_UPDOWN 0x2
529#define AM335X_TBCTL_CTRMODE_FREEZE 0x3
530#define AM335X_EPWM_AQCTLA_ZRO_XALOW (0x0001u)
531#define AM335X_EPWM_AQCTLA_ZRO_XAHIGH (0x0002u)
532#define AM335X_EPWM_AQCTLA_CAU_EPWMXATOGGLE (0x0003u)
533#define AM335X_EPWM_AQCTLA_CAU_SHIFT (0x0004u)
534#define AM335X_EPWM_AQCTLA_ZRO_XBLOW (0x0001u)
535#define AM335X_EPWM_AQCTLB_ZRO_XBHIGH (0x0002u)
536#define AM335X_EPWM_AQCTLB_CBU_EPWMXBTOGGLE (0x0003u)
537#define AM335X_EPWM_AQCTLB_CBU_SHIFT (0x0008u)
538#define AM335X_EPWM_TBCTL_CTRMODE_STOPFREEZE (0x0003u)
539#define AM335X_PWMSS_CTRL_PWMSS0_TBCLKEN (0x00000001u)
540#define AM335X_PWMSS_CTRL_PWMSS1_TBCLKEN (0x00000002u)
541#define AM335X_PWMSS_CTRL_PWMSS2_TBCLKEN (0x00000004u)
542#define AM335X_CM_PER_EPWMSS0_CLKCTRL_MODULEMODE_ENABLE (0x2u)
543#define AM335X_CM_PER_EPWMSS1_CLKCTRL_MODULEMODE_ENABLE (0x2u)
544#define AM335X_CM_PER_EPWMSS2_CLKCTRL_MODULEMODE_ENABLE (0x2u)
545#define AM335X_TBCTL_CLKDIV_MASK (3 << 10)
546#define AM335X_TBCTL_HSPCLKDIV_MASK (3 << 7)
547#define AM335X_EPWM_TBCTL_CLKDIV (0x1C00u)
548#define AM335X_EPWM_TBCTL_CLKDIV_SHIFT (0x000Au)
549#define AM335X_EPWM_TBCTL_HSPCLKDIV (0x0380u)
550#define AM335X_EPWM_TBCTL_HSPCLKDIV_SHIFT (0x0007u)
551#define AM335X_EPWM_TBCTL_PRDLD (0x0008u)
552#define AM335X_EPWM_PRD_LOAD_SHADOW_MASK AM335X_EPWM_TBCTL_PRDLD
553#define AM335X_EPWM_SHADOW_WRITE_ENABLE 0x0
554#define AM335X_EPWM_SHADOW_WRITE_DISABLE 0x1
555#define AM335X_EPWM_TBCTL_PRDLD_SHIFT (0x0003u)
556#define AM335X_EPWM_TBCTL_CTRMODE (0x0003u)
557#define AM335X_EPWM_COUNTER_MODE_MASK AM335X_EPWM_TBCTL_CTRMODE
558#define AM335X_TBCTL_FREERUN (2 << 14)
559#define AM335X_TBCTL_CTRMODE_SHIFT (0x0000u)
560#define AM335X_EPWM_COUNT_UP (AM335X_TBCTL_CTRMODE_UP << \
561 AM335X_TBCTL_CTRMODE_SHIFT)
562
563#define AM335X_EPWM_REGS (0x00000200)
564#define AM335X_EPWM_0_REGS (AM335X_PWMSS0_MMAP_ADDR + AM335X_EPWM_REGS)
565#define AM335X_EPWM_1_REGS (AM335X_PWMSS1_MMAP_ADDR + AM335X_EPWM_REGS)
566#define AM335X_EPWM_2_REGS (AM335X_PWMSS2_MMAP_ADDR + AM335X_EPWM_REGS)
567
568#define AM335X_CM_PER_EPWMSS0_CLKCTRL_MODULEMODE (0x00000003u)
569#define AM335X_CM_PER_EPWMSS0_CLKCTRL_IDLEST_FUNC (0x0u)
570#define AM335X_CM_PER_EPWMSS0_CLKCTRL_IDLEST_SHIFT (0x00000010u)
571#define AM335X_CM_PER_EPWMSS0_CLKCTRL_IDLEST (0x00030000u)
572
573#define AM335X_CM_PER_EPWMSS1_CLKCTRL_MODULEMODE (0x00000003u)
574#define AM335X_CM_PER_EPWMSS1_CLKCTRL_IDLEST (0x00030000u)
575#define AM335X_CM_PER_EPWMSS1_CLKCTRL_IDLEST_FUNC (0x0u)
576#define AM335X_CM_PER_EPWMSS1_CLKCTRL_IDLEST_SHIFT (0x00000010u)
577
578#define AM335X_CM_PER_EPWMSS2_CLKCTRL_MODULEMODE (0x00000003u)
579#define AM335X_CM_PER_EPWMSS2_CLKCTRL_IDLEST_FUNC (0x0u)
580#define AM335X_CM_PER_EPWMSS2_CLKCTRL_IDLEST_SHIFT (0x00000010u)
581#define AM335X_CM_PER_EPWMSS2_CLKCTRL_IDLEST (0x00030000u)
582
583
584
585/* I2C registers */
586#define AM335X_I2C0_BASE 0x44e0b000
587 /* I2C0 base address */
588#define AM335X_I2C1_BASE 0x4802a000
589 /* I2C1 base address */
590#define AM335X_I2C2_BASE 0x4819c000
591 /* I2C2 base address */
592#define AM335X_I2C_REVNB_LO 0x00
593 /* Module Revision Register (low bytes) */
594#define AM335X_I2C_REVNB_HI 0x04
595 /* Module Revision Register (high bytes) */
596#define AM335X_I2C_SYSC 0x10
597 /* System Configuration Register */
598#define AM335X_I2C_IRQSTATUS_RAW 0x24
599 /* I2C Status Raw Register */
600#define AM335X_I2C_IRQSTATUS 0x28
601 /* I2C Status Register */
602#define AM335X_I2C_IRQENABLE_SET 0x2c
603 /* I2C Interrupt Enable Set Register */
604#define AM335X_I2C_IRQENABLE_CLR 0x30
605 /* I2C Interrupt Enable Clear Register */
606#define AM335X_I2C_WE 0x34
607 /* I2C Wakeup Enable Register */
608#define AM335X_I2C_DMARXENABLE_SET 0x38
609 /* Receive DMA Enable Set Register */
610#define AM335X_I2C_DMATXENABLE_SET 0x3c
611 /* Transmit DMA Enable Set Register */
612#define AM335X_I2C_DMARXENABLE_CLR 0x40
613 /* Receive DMA Enable Clear Register */
614#define AM335X_I2C_DMATXENABLE_CLR 0x44
615 /* Transmit DMA Enable Clear Register */
616#define AM335X_I2C_DMARXWAKE_EN 0x48
617 /* Receive DMA Wakeup Register */
618#define AM335X_I2C_DMATXWAKE_EN 0x4c
619 /* Transmit DMA Wakeup Register */
620#define AM335X_I2C_SYSS 0x90
621 /* System Status Register */
622#define AM335X_I2C_BUF 0x94
623 /* Buffer Configuration Register */
624#define AM335X_I2C_CNT 0x98
625 /* Data Counter Register */
626#define AM335X_I2C_DATA 0x9c
627 /* Data Access Register */
628#define AM335X_I2C_CON 0xa4
629 /* I2C Configuration Register */
630#define AM335X_I2C_OA 0xa8
631 /* I2C Own Address Register */
632#define AM335X_I2C_SA 0xac
633 /* I2C Slave Address Register */
634#define AM335X_I2C_PSC 0xb0
635 /* I2C Clock Prescaler Register */
636#define AM335X_I2C_SCLL 0xb4
637 /* I2C SCL Low Time Register */
638#define AM335X_I2C_SCLH 0xb8
639 /* I2C SCL High Time Register */
640#define AM335X_I2C_SYSTEST 0xbc
641 /* System Test Register */
642#define AM335X_I2C_BUFSTAT 0xc0
643 /* I2C Buffer Status Register */
644#define AM335X_I2C_OA1 0xc4
645 /* I2C Own Address 1 Register */
646#define AM335X_I2C_OA2 0xc8
647 /* I2C Own Address 2 Register */
648#define AM335X_I2C_OA3 0xcc
649 /* I2C Own Address 3 Register */
650#define AM335X_I2C_ACTOA 0xd0
651 /* Active Own Address Register */
652#define AM335X_I2C_SBLOCK 0xd4
653 /* I2C Clock Blocking Enable Register */
654
655#define AM335X_CM_PER_L4LS_CLKSTCTRL (0x0)
656#define AM335X_CM_PER_L4LS_CLKSTCTRL_CLKTRCTRL_SW_WKUP (0x2u)
657#define AM335X_CM_PER_L4LS_CLKSTCTRL_CLKTRCTRL (0x00000003u)
658#define AM335X_CM_PER_L4LS_CLKCTRL (0x60)
659#define AM335X_CM_PER_L4LS_CLKCTRL_MODULEMODE_ENABLE (0x2u)
660#define AM335X_CM_PER_L4LS_CLKCTRL_MODULEMODE (0x00000003u)
661#define AM335X_CM_PER_I2C1_CLKCTRL (0x48)
662#define AM335X_CM_PER_I2C1_CLKCTRL_MODULEMODE_ENABLE (0x2u)
663#define AM335X_CM_PER_I2C1_CLKCTRL_MODULEMODE (0x00000003u)
664#define AM335X_CM_PER_I2C2_CLKCTRL (0x44)
665#define AM335X_CM_PER_I2C2_CLKCTRL_MODULEMODE_ENABLE (0x2u)
666#define AM335X_CM_PER_I2C2_CLKCTRL_MODULEMODE (0x00000003u)
667#define AM335X_CM_PER_L4LS_CLKSTCTRL_CLKACTIVITY_L4LS_GCLK (0x00000100u)
668#define AM335X_CM_PER_L4LS_CLKSTCTRL_CLKACTIVITY_I2C_FCLK (0x01000000u)
669#define AM335X_CM_PER_I2C1_CLKCTRL_MODULEMODE (0x00000003u)
670#define AM335X_CM_PER_SPI0_CLKCTRL (0x4c)
671#define AM335X_CM_PER_SPI0_CLKCTRL_MODULEMODE_ENABLE (0x2u)
672#define AM335X_CM_PER_SPI0_CLKCTRL_MODULEMODE (0x00000003u)
673#define AM335X_I2C_CON_XSA (0x00000100u)
674#define AM335X_I2C_CFG_10BIT_SLAVE_ADDR AM335X_I2C_CON_XSA
675#define AM335X_I2C_CON_XSA_SHIFT (0x00000008u)
676#define AM335X_I2C_CFG_7BIT_SLAVE_ADDR (0 << AM335X_I2C_CON_XSA_SHIFT)
677#define AM335X_I2C_CON_I2C_EN (0x00008000u)
678#define AM335X_I2C_CON_TRX (0x00000200u)
679#define AM335X_I2C_CON_MST (0x00000400u)
680#define AM335X_I2C_CON_STB (0x00000800u)
681#define AM335X_I2C_SYSC_AUTOIDLE (0x00000001u)
682#define AM335X_I2C_SYSC_SRST (0x00000002u)
683#define AM335X_I2C_SYSC_ENAWAKEUP (0x00000004u)
684#define AM335X_I2C_SYSS_RDONE (0x00000001u)
685
686/*I2C0 module clock registers*/
687#define AM335X_CM_WKUP_CONTROL_CLKCTRL (0x4)
688#define AM335X_CM_WKUP_CLKSTCTRL (0x0)
689#define AM335X_CM_WKUP_I2C0_CLKCTRL (0xb8)
690#define AM335X_CM_WKUP_I2C0_CLKCTRL_MODULEMODE_ENABLE (0x2u)
691#define AM335X_CM_WKUP_I2C0_CLKCTRL_MODULEMODE (0x00000003u)
692#define AM335X_CM_WKUP_CONTROL_CLKCTRL_IDLEST_FUNC (0x0u)
693#define AM335X_CM_WKUP_CONTROL_CLKCTRL_IDLEST_SHIFT (0x00000010u)
694#define AM335X_CM_WKUP_CONTROL_CLKCTRL_IDLEST (0x00030000u)
695#define AM335X_CM_WKUP_CLKSTCTRL_CLKACTIVITY_I2C0_GFCLK (0x00000800u)
696#define AM335X_CM_WKUP_I2C0_CLKCTRL_IDLEST_FUNC (0x0u)
697#define AM335X_CM_WKUP_I2C0_CLKCTRL_IDLEST_SHIFT (0x00000010u)
698#define AM335X_CM_WKUP_I2C0_CLKCTRL_IDLEST (0x00030000u)
699#define AM335X_SOC_CM_WKUP_REGS (AM335X_CM_PER_ADDR + 0x400)
700
701/* SPI0 module clock registers */
702#define AM335X_CM_PER_CONTROL_CLKCTRL_IDLEST_FUNC (0x0u)
703#define AM335X_CM_PER_CONTROL_CLKCTRL_IDLEST_SHIFT (0x00000010u)
704#define AM335X_CM_PER_CONTROL_CLKCTRL_IDLEST (0x00030000u)
705
706
707#define AM335X_I2C_BUF_TXTRSH_SHIFT (0)
708#define AM335X_I2C_BUF_TXTRSH_MASK (0x0000003Fu)
709#define AM335X_I2C_BUF_TXTRSH(X) (((X) << AM335X_I2C_BUF_TXTRSH_SHIFT) \
710 & AM335X_I2C_BUF_TXTRSH_MASK)
711#define AM335X_I2C_BUF_TXFIFO_CLR (0x00000040u)
712#define AM335X_I2C_BUF_RXTRSH_SHIFT (8)
713#define AM335X_I2C_BUF_RXTRSH_MASK (0x00003F00u)
714#define AM335X_I2C_BUF_RXTRSH(X) (((X) << AM335X_I2C_BUF_RXTRSH_SHIFT) \
715 & AM335X_I2C_BUF_RXTRSH_MASK)
716#define AM335X_I2C_BUF_RXFIFO_CLR (0x00004000u)
717
718/* I2C status Register */
719#define AM335X_I2C_IRQSTATUS_AL (1 << 0)
720#define AM335X_I2C_IRQSTATUS_NACK (1 << 1)
721#define AM335X_I2C_IRQSTATUS_ARDY (1 << 2)
722#define AM335X_I2C_IRQSTATUS_RRDY (1 << 3)
723#define AM335X_I2C_IRQSTATUS_XRDY (1 << 4)
724#define AM335X_I2C_IRQSTATUS_GC (1 << 5)
725#define AM335X_I2C_IRQSTATUS_STC (1 << 6)
726#define AM335X_I2C_IRQSTATUS_AERR (1 << 7)
727#define AM335X_I2C_IRQSTATUS_BF (1 << 8)
728#define AM335X_I2C_IRQSTATUS_AAS (1 << 9)
729#define AM335X_I2C_IRQSTATUS_XUDF (1 << 10)
730#define AM335X_I2C_IRQSTATUS_ROVR (1 << 11)
731#define AM335X_I2C_IRQSTATUS_BB (1 << 12)
732#define AM335X_I2C_IRQSTATUS_RDR (1 << 13)
733#define AM335X_I2C_IRQSTATUS_XDR (1 << 14)
734
735#define AM335X_I2C_INT_RECV_READY AM335X_I2C_IRQSTATUS_RRDY
736#define AM335X_I2C_CON_STOP (0x00000002u)
737#define AM335X_I2C_CON_START (0x00000001u)
738#define AM335X_I2C_CFG_MST_RX AM335X_I2C_CON_MST
739#define AM335X_I2C_CFG_MST_TX (AM335X_I2C_CON_TRX | AM335X_I2C_CON_MST)
740#define AM335X_CM_PER_OCPWP_L3_CLKSTCTRL_CLKACTIVITY_OCPWP_L4_GCLK (0x00000020u)
741#define AM335X_I2C_INT_STOP_CONDITION AM335X_I2C_IRQSTATUS_BF
742
743
744/* SPI registers */
745#define AM335X_SPI0_BASE 0x48030000
746 /* SPI0 base address */
747#define AM335X_SPI1_BASE 0x481A0000
748 /* SPI1 base address */
749
750#define AM335X_SPI_REVISION 0x000
751#define AM335X_SPI_SYSCONFIG 0x110
752#define AM335X_SPI_SYSSTATUS 0x114
753#define AM335X_SPI_IRQSTATUS 0x118
754#define AM335X_SPI_IRQENABLE 0x11c
755#define AM335X_SPI_WAKEUPENABLE 0x120
756#define AM335X_SPI_SYST 0x124
757#define AM335X_SPI_MODULCTRL 0x128
758#define AM335X_SPI_CH0CONF 0x12c
759#define AM335X_SPI_CH0STAT 0x130
760#define AM335X_SPI_CH0CTRL 0x134
761#define AM335X_SPI_TX0 0x138
762#define AM335X_SPI_RX0 0x13C
763#define AM335X_SPI_XFERLEVEL 0x17c
764
765/* SPI sysconfig Register */
766#define AM335X_SPI_SYSCONFIG_SOFTRESET (1 << 1)
767
768/* SPI sysstatus Register */
769#define AM335X_SPI_SYSSTATUS_RESETDONE (1 << 0)
770
771/* SPI interrupt status Register */
772#define AM335X_SPI_IRQSTATUS_TX0_EMPTY (1 << 0)
773#define AM335X_SPI_IRQSTATUS_RX0_FULL (1 << 2)
774
775/* SPI interrupt enable Register */
776#define AM335X_SPI_IRQENABLE_TX0_EMPTY (1 << 0)
777#define AM335X_SPI_IRQENABLE_RX0_FULL (1 << 2)
778
779/* SPI system Register */
780#define AM335X_SPI_SYST_SPIEN_0 (1 << 0)
781#define AM335X_SPI_SYST_SPIDAT_0 (1 << 4)
782#define AM335X_SPI_SYST_SPIDAT_1 (1 << 5)
783#define AM335X_SPI_SYST_SPIDATDIR0 (1 << 8)
784#define AM335X_SPI_SYST_SPIDATDIR1 (1 << 9)
785#define AM335X_SPI_SYST_SSB (1 << 11)
786
787/* SPI modulctrl Register */
788#define AM335X_SPI_MODULCTRL_SINGLE (1 << 0)
789#define AM335X_SPI_MODULCTRL_PIN34 (1 << 1)
790#define AM335X_SPI_MODULCTRL_MS (1 << 2)
791
792/* SPI Channel 0 Configuration Register */
793#define AM335X_SPI_CH0CONF_PHA (1 << 0)
794#define AM335X_SPI_CH0CONF_POL (1 << 1)
795#define AM335X_SPI_CH0CONF_CLKD_SHIFT 2
796#define AM335X_SPI_CH0CONF_CLKD_WIDTH 4
797#define AM335X_SPI_CH0CONF_CLKD_MASK AM335X_MASK(AM335X_SPI_CH0CONF_CLKD_SHIFT, AM335X_SPI_CH0CONF_CLKD_WIDTH)
798#define AM335X_SPI_CH0CONF_CLKD(X) (((X) << AM335X_SPI_CH0CONF_CLKD_SHIFT) & AM335X_SPI_CH0CONF_CLKD_MASK)
799#define AM335X_SPI_CH0CONF_EPOL (1 << 6)
800#define AM335X_SPI_CH0CONF_WL_SHIFT 7
801#define AM335X_SPI_CH0CONF_WL_WIDTH 5
802#define AM335X_SPI_CH0CONF_WL_MASK AM335X_MASK(AM335X_SPI_CH0CONF_WL_SHIFT, AM335X_SPI_CH0CONF_WL_WIDTH)
803#define AM335X_SPI_CH0CONF_WL(X) (((X) << AM335X_SPI_CH0CONF_WL_SHIFT) & AM335X_SPI_CH0CONF_WL_MASK)
804#define AM335X_SPI_CH0CONF_TRM_SHIFT 12
805#define AM335X_SPI_CH0CONF_TRM_WIDTH 2
806#define AM335X_SPI_CH0CONF_TRM_MASK AM335X_MASK(AM335X_SPI_CH0CONF_TRM_SHIFT, AM335X_SPI_CH0CONF_TRM_WIDTH)
807#define AM335X_SPI_CH0CONF_TRM(X) (((X) << AM335X_SPI_CH0CONF_TRM_SHIFT) & AM335X_SPI_CH0CONF_TRM_MASK)
808#define AM335X_SPI_CH0CONF_DPE0 (1 << 16)
809#define AM335X_SPI_CH0CONF_DPE1 (1 << 17)
810#define AM335X_SPI_CH0CONF_IS (1 << 18)
811#define AM335X_SPI_CH0CONF_FORCE (1 << 20)
812#define AM335X_SPI_CH0CONF_SBPOL (1 << 27)
813#define AM335X_SPI_CH0CONF_FFEW (1 << 27)
814#define AM335X_SPI_CH0CONF_FFER (1 << 28)
815
816/* SPI Channel 0 Status Register */
817#define AM335X_SPI_CH0STAT_RXS (1 << 0)
818#define AM335X_SPI_CH0STAT_TXS (1 << 1)
819
820/* SPI Channel 0 Control Register */
821#define AM335X_SPI_CH0CTRL_EN (1 << 0)
822
823#endif