aboutsummaryrefslogtreecommitdiff
path: root/lib/sbi/sbi_ecall_sse.c
blob: a28a033e2e09d1061578eb6db4cd56ffeac6c01b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
#include <sbi/sbi_error.h>
#include <sbi/sbi_ecall.h>
#include <sbi/sbi_trap.h>
#include <sbi/sbi_sse.h>

static int sbi_ecall_sse_handler(unsigned long extid, unsigned long funcid,
				  struct sbi_trap_regs *regs,
				  struct sbi_ecall_return *out)
{
	int ret;

	switch (funcid) {
	case SBI_EXT_SSE_READ_ATTR:
		ret = sbi_sse_read_attrs(regs->a0, regs->a1, regs->a2,
					 regs->a3, regs->a4);
		break;
	case SBI_EXT_SSE_WRITE_ATTR:
		ret = sbi_sse_write_attrs(regs->a0, regs->a1, regs->a2,
					 regs->a3, regs->a4);
		break;
	case SBI_EXT_SSE_REGISTER:
		ret = sbi_sse_register(regs->a0, regs->a1, regs->a2);
		break;
	case SBI_EXT_SSE_UNREGISTER:
		ret = sbi_sse_unregister(regs->a0);
		break;
	case SBI_EXT_SSE_ENABLE:
		ret = sbi_sse_enable(regs->a0);
		break;
	case SBI_EXT_SSE_DISABLE:
		ret = sbi_sse_disable(regs->a0);
		break;
	case SBI_EXT_SSE_COMPLETE:
		ret = sbi_sse_complete(regs, out);
		break;
	case SBI_EXT_SSE_INJECT:
		ret = sbi_sse_inject_from_ecall(regs->a0, regs->a1, out);
		break;
	default:
		ret = SBI_ENOTSUPP;
	}
	return ret;
}

struct sbi_ecall_extension ecall_sse;

static int sbi_ecall_sse_register_extensions(void)
{
	return sbi_ecall_register_extension(&ecall_sse);
}

struct sbi_ecall_extension ecall_sse = {
	.extid_start		= SBI_EXT_SSE,
	.extid_end		= SBI_EXT_SSE,
	.register_extensions	= sbi_ecall_sse_register_extensions,
	.handle			= sbi_ecall_sse_handler,
};