GNU Linux-libre 4.14.303-gnu1
[releases.git] / arch / mn10300 / unit-asb2364 / include / unit / fpga-regs.h
1 /* SPDX-License-Identifier: GPL-2.0 */
2 /* ASB2364 FPGA registers
3  */
4
5 #ifndef _ASM_UNIT_FPGA_REGS_H
6 #define _ASM_UNIT_FPGA_REGS_H
7
8 #include <asm/cpu-regs.h>
9
10 #ifdef __KERNEL__
11
12 #define ASB2364_FPGA_REG_RESET_LAN      __SYSREG(0xa9001300, u16)
13 #define ASB2364_FPGA_REG_RESET_UART     __SYSREG(0xa9001304, u16)
14 #define ASB2364_FPGA_REG_RESET_I2C      __SYSREG(0xa9001308, u16)
15 #define ASB2364_FPGA_REG_RESET_USB      __SYSREG(0xa900130c, u16)
16 #define ASB2364_FPGA_REG_RESET_AV       __SYSREG(0xa9001310, u16)
17
18 #define ASB2364_FPGA_REG_IRQ(X)         __SYSREG(0xa9001510+((X)*4), u16)
19 #define ASB2364_FPGA_REG_IRQ_LAN        ASB2364_FPGA_REG_IRQ(0)
20 #define ASB2364_FPGA_REG_IRQ_UART       ASB2364_FPGA_REG_IRQ(1)
21 #define ASB2364_FPGA_REG_IRQ_I2C        ASB2364_FPGA_REG_IRQ(2)
22 #define ASB2364_FPGA_REG_IRQ_USB        ASB2364_FPGA_REG_IRQ(3)
23 #define ASB2364_FPGA_REG_IRQ_FPGA       ASB2364_FPGA_REG_IRQ(5)
24
25 #define ASB2364_FPGA_REG_MASK(X)        __SYSREG(0xa9001590+((X)*4), u16)
26 #define ASB2364_FPGA_REG_MASK_LAN       ASB2364_FPGA_REG_MASK(0)
27 #define ASB2364_FPGA_REG_MASK_UART      ASB2364_FPGA_REG_MASK(1)
28 #define ASB2364_FPGA_REG_MASK_I2C       ASB2364_FPGA_REG_MASK(2)
29 #define ASB2364_FPGA_REG_MASK_USB       ASB2364_FPGA_REG_MASK(3)
30 #define ASB2364_FPGA_REG_MASK_FPGA      ASB2364_FPGA_REG_MASK(5)
31
32 #define ASB2364_FPGA_REG_CPLD5_SET1     __SYSREG(0xa9002500, u16)
33 #define ASB2364_FPGA_REG_CPLD5_SET2     __SYSREG(0xa9002504, u16)
34 #define ASB2364_FPGA_REG_CPLD6_SET1     __SYSREG(0xa9002600, u16)
35 #define ASB2364_FPGA_REG_CPLD6_SET2     __SYSREG(0xa9002604, u16)
36 #define ASB2364_FPGA_REG_CPLD7_SET1     __SYSREG(0xa9002700, u16)
37 #define ASB2364_FPGA_REG_CPLD7_SET2     __SYSREG(0xa9002704, u16)
38 #define ASB2364_FPGA_REG_CPLD8_SET1     __SYSREG(0xa9002800, u16)
39 #define ASB2364_FPGA_REG_CPLD8_SET2     __SYSREG(0xa9002804, u16)
40 #define ASB2364_FPGA_REG_CPLD9_SET1     __SYSREG(0xa9002900, u16)
41 #define ASB2364_FPGA_REG_CPLD9_SET2     __SYSREG(0xa9002904, u16)
42 #define ASB2364_FPGA_REG_CPLD10_SET1    __SYSREG(0xa9002a00, u16)
43 #define ASB2364_FPGA_REG_CPLD10_SET2    __SYSREG(0xa9002a04, u16)
44
45 #define SyncExBus()                                     \
46         do {                                            \
47                 unsigned short w;                       \
48                 w = *(volatile short *)0xa9000000;      \
49         } while (0)
50
51 #endif /* __KERNEL__ */
52
53 #endif /* _ASM_UNIT_FPGA_REGS_H */