Loading...
1/* SPDX-License-Identifier: GPL-2.0 */
2#ifndef BCM63XX_IOREMAP_H_
3#define BCM63XX_IOREMAP_H_
4
5#include <bcm63xx_cpu.h>
6
7static inline int is_bcm63xx_internal_registers(phys_addr_t offset)
8{
9 switch (bcm63xx_get_cpu_id()) {
10 case BCM3368_CPU_ID:
11 if (offset >= 0xfff80000)
12 return 1;
13 break;
14 case BCM6338_CPU_ID:
15 case BCM6345_CPU_ID:
16 case BCM6348_CPU_ID:
17 case BCM6358_CPU_ID:
18 if (offset >= 0xfff00000)
19 return 1;
20 break;
21 case BCM6328_CPU_ID:
22 case BCM6362_CPU_ID:
23 case BCM6368_CPU_ID:
24 if (offset >= 0xb0000000 && offset < 0xb1000000)
25 return 1;
26 break;
27 }
28 return 0;
29}
30
31static inline void __iomem *plat_ioremap(phys_addr_t offset, unsigned long size,
32 unsigned long flags)
33{
34 if (is_bcm63xx_internal_registers(offset))
35 return (void __iomem *)offset;
36 return NULL;
37}
38
39static inline int plat_iounmap(const volatile void __iomem *addr)
40{
41 return is_bcm63xx_internal_registers((unsigned long)addr);
42}
43
44#endif /* BCM63XX_IOREMAP_H_ */
1/* SPDX-License-Identifier: GPL-2.0 */
2#ifndef BCM63XX_IOREMAP_H_
3#define BCM63XX_IOREMAP_H_
4
5#include <bcm63xx_cpu.h>
6
7static inline phys_addr_t fixup_bigphys_addr(phys_addr_t phys_addr, phys_addr_t size)
8{
9 return phys_addr;
10}
11
12static inline int is_bcm63xx_internal_registers(phys_addr_t offset)
13{
14 switch (bcm63xx_get_cpu_id()) {
15 case BCM3368_CPU_ID:
16 if (offset >= 0xfff80000)
17 return 1;
18 break;
19 case BCM6338_CPU_ID:
20 case BCM6345_CPU_ID:
21 case BCM6348_CPU_ID:
22 case BCM6358_CPU_ID:
23 if (offset >= 0xfff00000)
24 return 1;
25 break;
26 case BCM6328_CPU_ID:
27 case BCM6362_CPU_ID:
28 case BCM6368_CPU_ID:
29 if (offset >= 0xb0000000 && offset < 0xb1000000)
30 return 1;
31 break;
32 }
33 return 0;
34}
35
36static inline void __iomem *plat_ioremap(phys_addr_t offset, unsigned long size,
37 unsigned long flags)
38{
39 if (is_bcm63xx_internal_registers(offset))
40 return (void __iomem *)offset;
41 return NULL;
42}
43
44static inline int plat_iounmap(const volatile void __iomem *addr)
45{
46 return is_bcm63xx_internal_registers((unsigned long)addr);
47}
48
49#endif /* BCM63XX_IOREMAP_H_ */