forked from stsquad/risu
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathrisu_loongarch64.c
More file actions
50 lines (43 loc) · 1.3 KB
/
risu_loongarch64.c
File metadata and controls
50 lines (43 loc) · 1.3 KB
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
/******************************************************************************
* Copyright (c) 2022 Loongson Technology Corporation Limited
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* based on Peter Maydell's risu_arm.c
*****************************************************************************/
#include <asm/types.h>
#include <signal.h>
#include <asm/ucontext.h>
#include "risu.h"
void advance_pc(void *vuc)
{
struct ucontext *uc = vuc;
uc->uc_mcontext.sc_pc += 4;
}
void set_ucontext_paramreg(void *vuc, uint64_t value)
{
struct ucontext *uc = vuc;
uc->uc_mcontext.sc_regs[4] = value;
}
uint64_t get_reginfo_paramreg(struct reginfo *ri)
{
return ri->regs[4];
}
RisuOp get_risuop(struct reginfo *ri)
{
/* Return the risuop we have been asked to do
* (or OP_SIGILL if this was a SIGILL for a non-risuop insn)
*/
uint32_t insn = ri->faulting_insn;
uint32_t op = insn & 0xf;
uint32_t key = insn & ~0xf;
uint32_t risukey = 0x000001f0;
return (key != risukey) ? OP_SIGILL : op;
}
uintptr_t get_pc(struct reginfo *ri)
{
return ri->pc;
}