Tom Rini | 10e4779 | 2018-05-06 17:58:06 -0400 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0+ */ |
Rick Chen | 76c0a24 | 2017-12-26 13:55:51 +0800 | [diff] [blame] | 2 | /* |
| 3 | * (C) Copyright 2002 |
| 4 | * Wolfgang Denk, DENX Software Engineering, wd@denx.de. |
| 5 | * |
| 6 | * Copyright (c) 2017 Microsemi Corporation. |
| 7 | * Padmarao Begari, Microsemi Corporation <padmarao.begari@microsemi.com> |
Rick Chen | 76c0a24 | 2017-12-26 13:55:51 +0800 | [diff] [blame] | 8 | */ |
| 9 | |
| 10 | #ifndef __ASM_GBL_DATA_H |
| 11 | #define __ASM_GBL_DATA_H |
| 12 | |
Lukas Auer | 83d573d | 2019-03-17 19:28:32 +0100 | [diff] [blame] | 13 | #include <asm/smp.h> |
Sean Anderson | 5aa0074 | 2020-06-24 06:41:16 -0400 | [diff] [blame] | 14 | #include <asm/u-boot.h> |
| 15 | #include <compiler.h> |
Lukas Auer | 83d573d | 2019-03-17 19:28:32 +0100 | [diff] [blame] | 16 | |
Rick Chen | 76c0a24 | 2017-12-26 13:55:51 +0800 | [diff] [blame] | 17 | /* Architecture-specific global data */ |
| 18 | struct arch_global_data { |
Bin Meng | 89681a7 | 2018-12-12 06:12:45 -0800 | [diff] [blame] | 19 | long boot_hart; /* boot hart id */ |
Atish Patra | 111b804 | 2020-04-21 11:15:01 -0700 | [diff] [blame] | 20 | phys_addr_t firmware_fdt_addr; |
Bin Meng | 614b1d8 | 2021-05-11 20:04:12 +0800 | [diff] [blame] | 21 | #if CONFIG_IS_ENABLED(SIFIVE_CLINT) |
Bin Meng | b6ee5e1 | 2018-12-12 06:12:30 -0800 | [diff] [blame] | 22 | void __iomem *clint; /* clint base address */ |
| 23 | #endif |
Yu Chien Peter Lin | 739cd6f | 2022-10-25 23:03:50 +0800 | [diff] [blame] | 24 | #ifdef CONFIG_ANDES_PLICSW |
| 25 | void __iomem *plicsw; /* plic base address */ |
Rick Chen | 6df4ed0 | 2019-04-02 15:56:39 +0800 | [diff] [blame] | 26 | #endif |
Bin Meng | b161f90 | 2020-04-16 08:09:30 -0700 | [diff] [blame] | 27 | #if CONFIG_IS_ENABLED(SMP) |
Lukas Auer | 83d573d | 2019-03-17 19:28:32 +0100 | [diff] [blame] | 28 | struct ipi_data ipi[CONFIG_NR_CPUS]; |
| 29 | #endif |
Nikita Shubin | 7e5e029 | 2022-09-02 11:47:39 +0300 | [diff] [blame] | 30 | #if !CONFIG_IS_ENABLED(XIP) |
Rick Chen | 9c4d5c1 | 2022-09-21 14:34:54 +0800 | [diff] [blame] | 31 | #ifdef CONFIG_AVAILABLE_HARTS |
Lukas Auer | 83d573d | 2019-03-17 19:28:32 +0100 | [diff] [blame] | 32 | ulong available_harts; |
Rick Chen | e5e6c36 | 2019-04-30 13:49:33 +0800 | [diff] [blame] | 33 | #endif |
Rick Chen | 9c4d5c1 | 2022-09-21 14:34:54 +0800 | [diff] [blame] | 34 | #endif |
Rick Chen | 76c0a24 | 2017-12-26 13:55:51 +0800 | [diff] [blame] | 35 | }; |
| 36 | |
| 37 | #include <asm-generic/global_data.h> |
| 38 | |
Rick Chen | b34b4b9 | 2018-02-12 11:10:04 +0800 | [diff] [blame] | 39 | #define DECLARE_GLOBAL_DATA_PTR register gd_t *gd asm ("gp") |
Rick Chen | 76c0a24 | 2017-12-26 13:55:51 +0800 | [diff] [blame] | 40 | |
Heinrich Schuchardt | 6e7eb46 | 2020-09-10 07:47:39 +0200 | [diff] [blame] | 41 | static inline void set_gd(volatile gd_t *gd_ptr) |
| 42 | { |
| 43 | #ifdef CONFIG_64BIT |
| 44 | asm volatile("ld gp, %0\n" : : "m"(gd_ptr)); |
| 45 | #else |
| 46 | asm volatile("lw gp, %0\n" : : "m"(gd_ptr)); |
| 47 | #endif |
| 48 | } |
| 49 | |
Rick Chen | 76c0a24 | 2017-12-26 13:55:51 +0800 | [diff] [blame] | 50 | #endif /* __ASM_GBL_DATA_H */ |