mirror of
https://github.com/riscv-software-src/opensbi.git
synced 2025-08-24 15:31:22 +01:00

This patch updates copyright header in all files as follows: 1. Makes "SPDX-License-Identifier: BSD-2-Clause" as first line 2. Change copyright year to 2019 for Western Digital Signed-off-by: Anup Patel <anup.patel@wdc.com>
49 lines
1.4 KiB
C
49 lines
1.4 KiB
C
/*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*
|
|
* Copyright (c) 2019 Western Digital Corporation or its affiliates.
|
|
*
|
|
* Authors:
|
|
* Anup Patel <anup.patel@wdc.com>
|
|
*/
|
|
|
|
#ifndef __SBI_ECALL_INTERFACE_H__
|
|
#define __SBI_ECALL_INTERFACE_H__
|
|
|
|
#define SBI_ECALL_SET_TIMER 0
|
|
#define SBI_ECALL_CONSOLE_PUTCHAR 1
|
|
#define SBI_ECALL_CONSOLE_GETCHAR 2
|
|
#define SBI_ECALL_CLEAR_IPI 3
|
|
#define SBI_ECALL_SEND_IPI 4
|
|
#define SBI_ECALL_REMOTE_FENCE_I 5
|
|
#define SBI_ECALL_REMOTE_SFENCE_VMA 6
|
|
#define SBI_ECALL_REMOTE_SFENCE_VMA_ASID 7
|
|
#define SBI_ECALL_SHUTDOWN 8
|
|
|
|
#define SBI_ECALL(__num, __a0, __a1, __a2) ({ \
|
|
register unsigned long a0 asm ("a0") = (unsigned long)(__a0); \
|
|
register unsigned long a1 asm ("a1") = (unsigned long)(__a1); \
|
|
register unsigned long a2 asm ("a2") = (unsigned long)(__a2); \
|
|
register unsigned long a7 asm ("a7") = (unsigned long)(__num); \
|
|
asm volatile ("ecall" \
|
|
: "+r" (a0) \
|
|
: "r" (a1), "r" (a2), "r" (a7) \
|
|
: "memory"); \
|
|
a0; \
|
|
})
|
|
|
|
#define SBI_ECALL_0(__num) SBI_ECALL(__num, 0, 0, 0)
|
|
#define SBI_ECALL_1(__num, __a0) SBI_ECALL(__num, __a0, 0, 0)
|
|
#define SBI_ECALL_2(__num, __a0, __a1) SBI_ECALL(__num, __a0, __a1, 0)
|
|
|
|
#define sbi_ecall_console_putc(c) \
|
|
SBI_ECALL_1(SBI_ECALL_CONSOLE_PUTCHAR, (c));
|
|
|
|
static inline void sbi_ecall_console_puts(const char *str)
|
|
{
|
|
while (str && *str)
|
|
sbi_ecall_console_putc(*str++);
|
|
}
|
|
|
|
#endif
|