2018-12-11 21:54:06 +08:00
|
|
|
/*
|
2019-01-24 14:11:10 +08:00
|
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
|
|
*
|
|
|
|
* Copyright (c) 2019 Western Digital Corporation or its affiliates.
|
2018-12-11 21:54:06 +08:00
|
|
|
*
|
|
|
|
* Authors:
|
|
|
|
* Anup Patel <anup.patel@wdc.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __SBI_SCRATCH_H__
|
|
|
|
#define __SBI_SCRATCH_H__
|
|
|
|
|
|
|
|
#include <sbi/riscv_asm.h>
|
2018-12-31 13:49:20 +08:00
|
|
|
|
2019-04-11 08:41:46 +08:00
|
|
|
/* clang-format off */
|
|
|
|
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Offset of fw_start member in sbi_scratch */
|
2019-01-02 17:21:30 +08:00
|
|
|
#define SBI_SCRATCH_FW_START_OFFSET (0 * __SIZEOF_POINTER__)
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Offset of fw_size member in sbi_scratch */
|
2019-01-02 17:21:30 +08:00
|
|
|
#define SBI_SCRATCH_FW_SIZE_OFFSET (1 * __SIZEOF_POINTER__)
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Offset of next_arg1 member in sbi_scratch */
|
2019-01-02 17:21:30 +08:00
|
|
|
#define SBI_SCRATCH_NEXT_ARG1_OFFSET (2 * __SIZEOF_POINTER__)
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Offset of next_addr member in sbi_scratch */
|
2019-01-02 17:21:30 +08:00
|
|
|
#define SBI_SCRATCH_NEXT_ADDR_OFFSET (3 * __SIZEOF_POINTER__)
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Offset of next_mode member in sbi_scratch */
|
2019-01-02 17:21:30 +08:00
|
|
|
#define SBI_SCRATCH_NEXT_MODE_OFFSET (4 * __SIZEOF_POINTER__)
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Offset of warmboot_addr member in sbi_scratch */
|
2019-01-02 17:21:30 +08:00
|
|
|
#define SBI_SCRATCH_WARMBOOT_ADDR_OFFSET (5 * __SIZEOF_POINTER__)
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Offset of platform_addr member in sbi_scratch */
|
2019-01-02 17:21:30 +08:00
|
|
|
#define SBI_SCRATCH_PLATFORM_ADDR_OFFSET (6 * __SIZEOF_POINTER__)
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Offset of hartid_to_scratch member in sbi_scratch */
|
2019-01-02 17:21:30 +08:00
|
|
|
#define SBI_SCRATCH_HARTID_TO_SCRATCH_OFFSET (7 * __SIZEOF_POINTER__)
|
2019-02-19 20:41:22 +08:00
|
|
|
/** Offset of tmp0 member in sbi_scratch */
|
2019-03-09 03:22:22 +08:00
|
|
|
#define SBI_SCRATCH_TMP0_OFFSET (8 * __SIZEOF_POINTER__)
|
2019-03-27 22:57:20 +08:00
|
|
|
/** Offset of options member in sbi_scratch */
|
|
|
|
#define SBI_SCRATCH_OPTIONS_OFFSET (9 * __SIZEOF_POINTER__)
|
2019-03-09 03:22:22 +08:00
|
|
|
|
|
|
|
/** sbi_ipi_data is located behind sbi_scratch. This struct is not packed. */
|
|
|
|
/** Offset of ipi_type in sbi_ipi_data */
|
|
|
|
#define SBI_IPI_DATA_IPI_TYPE_OFFSET (15 * __SIZEOF_POINTER__)
|
|
|
|
|
2019-04-02 08:07:54 +08:00
|
|
|
#define SBI_SCRATCH_TLB_QUEUE_HEAD_OFFSET (16 * __SIZEOF_POINTER__)
|
|
|
|
#define SBI_SCRATCH_TLB_QUEUE_MEM_OFFSET (SBI_SCRATCH_TLB_QUEUE_HEAD_OFFSET + SBI_TLB_INFO_SIZE)
|
|
|
|
|
2019-03-09 03:22:22 +08:00
|
|
|
/** Maximum size of sbi_scratch and sbi_ipi_data */
|
2019-04-02 08:05:53 +08:00
|
|
|
#define SBI_SCRATCH_SIZE (64 * __SIZEOF_POINTER__)
|
2018-12-31 13:49:20 +08:00
|
|
|
|
2019-04-11 08:41:46 +08:00
|
|
|
/* clang-format on */
|
|
|
|
|
2018-12-31 13:49:20 +08:00
|
|
|
#ifndef __ASSEMBLY__
|
|
|
|
|
2018-12-11 21:54:06 +08:00
|
|
|
#include <sbi/sbi_types.h>
|
2019-03-10 04:57:20 +08:00
|
|
|
#include <sbi/sbi_ipi.h>
|
2019-03-09 03:22:22 +08:00
|
|
|
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Representation of per-HART scratch space */
|
2018-12-11 21:54:06 +08:00
|
|
|
struct sbi_scratch {
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Start (or base) address of firmware linked to OpenSBI library */
|
2018-12-11 21:54:06 +08:00
|
|
|
unsigned long fw_start;
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Size (in bytes) of firmware linked to OpenSBI library */
|
2018-12-11 21:54:06 +08:00
|
|
|
unsigned long fw_size;
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Arg1 (or 'a1' register) of next booting stage for this HART */
|
2018-12-11 21:54:06 +08:00
|
|
|
unsigned long next_arg1;
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Address of next booting stage for this HART */
|
2018-12-11 21:54:06 +08:00
|
|
|
unsigned long next_addr;
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Priviledge mode of next booting stage for this HART */
|
2018-12-11 21:54:06 +08:00
|
|
|
unsigned long next_mode;
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Warm boot entry point address for this HART */
|
2018-12-11 21:54:06 +08:00
|
|
|
unsigned long warmboot_addr;
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Address of sbi_platform */
|
2018-12-11 21:54:06 +08:00
|
|
|
unsigned long platform_addr;
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Address of HART ID to sbi_scratch conversion function */
|
2018-12-11 21:54:06 +08:00
|
|
|
unsigned long hartid_to_scratch;
|
2019-02-19 20:41:22 +08:00
|
|
|
/** Temporary storage */
|
|
|
|
unsigned long tmp0;
|
2019-03-27 22:57:20 +08:00
|
|
|
/** Options for OpenSBI library */
|
|
|
|
unsigned long options;
|
2019-01-14 17:30:15 +08:00
|
|
|
} __packed;
|
2018-12-11 21:54:06 +08:00
|
|
|
|
2019-03-27 22:58:49 +08:00
|
|
|
/** Possible options for OpenSBI library */
|
|
|
|
enum sbi_scratch_options {
|
|
|
|
/** Disable prints during boot */
|
|
|
|
SBI_SCRATCH_NO_BOOT_PRINTS = (1 << 0),
|
|
|
|
};
|
|
|
|
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Get pointer to sbi_scratch for current HART */
|
2018-12-11 21:54:06 +08:00
|
|
|
#define sbi_scratch_thishart_ptr() \
|
2019-02-13 10:32:06 +08:00
|
|
|
((struct sbi_scratch *)csr_read(CSR_MSCRATCH))
|
2018-12-11 21:54:06 +08:00
|
|
|
|
2019-01-14 16:30:32 +08:00
|
|
|
/** Get Arg1 of next booting stage for current HART */
|
2018-12-11 21:54:06 +08:00
|
|
|
#define sbi_scratch_thishart_arg1_ptr() \
|
|
|
|
((void *)(sbi_scratch_thishart_ptr()->next_arg1))
|
|
|
|
|
2019-03-09 03:22:22 +08:00
|
|
|
/** Get pointer to sbi_ipi_data from sbi_scratch */
|
|
|
|
#define sbi_ipi_data_ptr(scratch) \
|
|
|
|
((struct sbi_ipi_data *)(void*)scratch + SBI_IPI_DATA_IPI_TYPE_OFFSET)
|
|
|
|
|
2019-04-02 08:07:54 +08:00
|
|
|
/** Get pointer to tlb flush info fifo header from sbi_scratch */
|
|
|
|
#define sbi_tlb_fifo_head_ptr(scratch) \
|
|
|
|
((struct sbi_fifo *)(void*)scratch + SBI_SCRATCH_TLB_QUEUE_HEAD_OFFSET)
|
|
|
|
|
|
|
|
/** Get pointer to tlb flush info fifo queue address from sbi_scratch */
|
|
|
|
#define sbi_tlb_fifo_mem_ptr(scratch) \
|
|
|
|
(void *)((void*)scratch + SBI_SCRATCH_TLB_QUEUE_MEM_OFFSET)
|
2019-03-10 04:57:20 +08:00
|
|
|
|
2018-12-11 21:54:06 +08:00
|
|
|
#endif
|
2018-12-31 13:49:20 +08:00
|
|
|
|
|
|
|
#endif
|