Skip to content

Commit 1c15dd6

Browse files
target/loongarch/gdbstub: Add vector registers support
GDB already support LoongArch vector extension[1], QEMU gdb adds LoongArch vector registers support, so that users can use 'info all-registers' to get all vector registers values. [1]: https://sourceware.org/git/?p=binutils-gdb.git;a=commitdiff;h=1e9569f383a3d5a88ee07d0c2401bd95613c222e Signed-off-by: Song Gao <[email protected]> Reviewed-by: Philippe Mathieu-Daudé <[email protected]> Reviewd-by: Bibo Mao <[email protected]> Message-Id: <[email protected]>
1 parent 23fa749 commit 1c15dd6

File tree

5 files changed

+192
-4
lines changed

5 files changed

+192
-4
lines changed
Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,4 +1,4 @@
11
# Default configuration for loongarch64-linux-user
22
TARGET_ARCH=loongarch64
33
TARGET_BASE_ARCH=loongarch
4-
TARGET_XML_FILES=gdb-xml/loongarch-base64.xml gdb-xml/loongarch-fpu.xml
4+
TARGET_XML_FILES=gdb-xml/loongarch-base64.xml gdb-xml/loongarch-fpu.xml gdb-xml/loongarch-lsx.xml gdb-xml/loongarch-lasx.xml

configs/targets/loongarch64-softmmu.mak

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,6 @@ TARGET_ARCH=loongarch64
22
TARGET_BASE_ARCH=loongarch
33
TARGET_KVM_HAVE_GUEST_DEBUG=y
44
TARGET_SUPPORTS_MTTCG=y
5-
TARGET_XML_FILES= gdb-xml/loongarch-base32.xml gdb-xml/loongarch-base64.xml gdb-xml/loongarch-fpu.xml
5+
TARGET_XML_FILES= gdb-xml/loongarch-base32.xml gdb-xml/loongarch-base64.xml gdb-xml/loongarch-fpu.xml gdb-xml/loongarch-lsx.xml gdb-xml/loongarch-lasx.xml
66
# all boards require libfdt
77
TARGET_NEED_FDT=y

gdb-xml/loongarch-lasx.xml

Lines changed: 60 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,60 @@
1+
<?xml version="1.0"?>
2+
<!-- Copyright (C) 2022-2024 Free Software Foundation, Inc.
3+
4+
Copying and distribution of this file, with or without modification,
5+
are permitted in any medium without royalty provided the copyright
6+
notice and this notice are preserved. -->
7+
8+
<!DOCTYPE feature SYSTEM "gdb-target.dtd">
9+
<feature name="org.gnu.gdb.loongarch.lasx">
10+
<vector id="v8f32" type="ieee_single" count="8"/>
11+
<vector id="v4f64" type="ieee_double" count="4"/>
12+
<vector id="v32i8" type="int8" count="32"/>
13+
<vector id="v16i16" type="int16" count="16"/>
14+
<vector id="v8i32" type="int32" count="8"/>
15+
<vector id="v4i64" type="int64" count="4"/>
16+
<vector id="v2ui128" type="uint128" count="2"/>
17+
18+
<union id="lasxv">
19+
<field name="v8_float" type="v8f32"/>
20+
<field name="v4_double" type="v4f64"/>
21+
<field name="v32_int8" type="v32i8"/>
22+
<field name="v16_int16" type="v16i16"/>
23+
<field name="v8_int32" type="v8i32"/>
24+
<field name="v4_int64" type="v4i64"/>
25+
<field name="v2_uint128" type="v2ui128"/>
26+
</union>
27+
28+
<reg name="xr0" bitsize="256" type="lasxv" group="lasx"/>
29+
<reg name="xr1" bitsize="256" type="lasxv" group="lasx"/>
30+
<reg name="xr2" bitsize="256" type="lasxv" group="lasx"/>
31+
<reg name="xr3" bitsize="256" type="lasxv" group="lasx"/>
32+
<reg name="xr4" bitsize="256" type="lasxv" group="lasx"/>
33+
<reg name="xr5" bitsize="256" type="lasxv" group="lasx"/>
34+
<reg name="xr6" bitsize="256" type="lasxv" group="lasx"/>
35+
<reg name="xr7" bitsize="256" type="lasxv" group="lasx"/>
36+
<reg name="xr8" bitsize="256" type="lasxv" group="lasx"/>
37+
<reg name="xr9" bitsize="256" type="lasxv" group="lasx"/>
38+
<reg name="xr10" bitsize="256" type="lasxv" group="lasx"/>
39+
<reg name="xr11" bitsize="256" type="lasxv" group="lasx"/>
40+
<reg name="xr12" bitsize="256" type="lasxv" group="lasx"/>
41+
<reg name="xr13" bitsize="256" type="lasxv" group="lasx"/>
42+
<reg name="xr14" bitsize="256" type="lasxv" group="lasx"/>
43+
<reg name="xr15" bitsize="256" type="lasxv" group="lasx"/>
44+
<reg name="xr16" bitsize="256" type="lasxv" group="lasx"/>
45+
<reg name="xr17" bitsize="256" type="lasxv" group="lasx"/>
46+
<reg name="xr18" bitsize="256" type="lasxv" group="lasx"/>
47+
<reg name="xr19" bitsize="256" type="lasxv" group="lasx"/>
48+
<reg name="xr20" bitsize="256" type="lasxv" group="lasx"/>
49+
<reg name="xr21" bitsize="256" type="lasxv" group="lasx"/>
50+
<reg name="xr22" bitsize="256" type="lasxv" group="lasx"/>
51+
<reg name="xr23" bitsize="256" type="lasxv" group="lasx"/>
52+
<reg name="xr24" bitsize="256" type="lasxv" group="lasx"/>
53+
<reg name="xr25" bitsize="256" type="lasxv" group="lasx"/>
54+
<reg name="xr26" bitsize="256" type="lasxv" group="lasx"/>
55+
<reg name="xr27" bitsize="256" type="lasxv" group="lasx"/>
56+
<reg name="xr28" bitsize="256" type="lasxv" group="lasx"/>
57+
<reg name="xr29" bitsize="256" type="lasxv" group="lasx"/>
58+
<reg name="xr30" bitsize="256" type="lasxv" group="lasx"/>
59+
<reg name="xr31" bitsize="256" type="lasxv" group="lasx"/>
60+
</feature>

gdb-xml/loongarch-lsx.xml

Lines changed: 59 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,59 @@
1+
<?xml version="1.0"?>
2+
<!-- Copyright (C) 2022-2024 Free Software Foundation, Inc.
3+
4+
Copying and distribution of this file, with or without modification,
5+
are permitted in any medium without royalty provided the copyright
6+
notice and this notice are preserved. -->
7+
8+
<!DOCTYPE feature SYSTEM "gdb-target.dtd">
9+
<feature name="org.gnu.gdb.loongarch.lsx">
10+
<vector id="v4f32" type="ieee_single" count="4"/>
11+
<vector id="v2f64" type="ieee_double" count="2"/>
12+
<vector id="v16i8" type="int8" count="16"/>
13+
<vector id="v8i16" type="int16" count="8"/>
14+
<vector id="v4i32" type="int32" count="4"/>
15+
<vector id="v2i64" type="int64" count="2"/>
16+
17+
<union id="lsxv">
18+
<field name="v4_float" type="v4f32"/>
19+
<field name="v2_double" type="v2f64"/>
20+
<field name="v16_int8" type="v16i8"/>
21+
<field name="v8_int16" type="v8i16"/>
22+
<field name="v4_int32" type="v4i32"/>
23+
<field name="v2_int64" type="v2i64"/>
24+
<field name="uint128" type="uint128"/>
25+
</union>
26+
27+
<reg name="vr0" bitsize="128" type="lsxv" group="lsx"/>
28+
<reg name="vr1" bitsize="128" type="lsxv" group="lsx"/>
29+
<reg name="vr2" bitsize="128" type="lsxv" group="lsx"/>
30+
<reg name="vr3" bitsize="128" type="lsxv" group="lsx"/>
31+
<reg name="vr4" bitsize="128" type="lsxv" group="lsx"/>
32+
<reg name="vr5" bitsize="128" type="lsxv" group="lsx"/>
33+
<reg name="vr6" bitsize="128" type="lsxv" group="lsx"/>
34+
<reg name="vr7" bitsize="128" type="lsxv" group="lsx"/>
35+
<reg name="vr8" bitsize="128" type="lsxv" group="lsx"/>
36+
<reg name="vr9" bitsize="128" type="lsxv" group="lsx"/>
37+
<reg name="vr10" bitsize="128" type="lsxv" group="lsx"/>
38+
<reg name="vr11" bitsize="128" type="lsxv" group="lsx"/>
39+
<reg name="vr12" bitsize="128" type="lsxv" group="lsx"/>
40+
<reg name="vr13" bitsize="128" type="lsxv" group="lsx"/>
41+
<reg name="vr14" bitsize="128" type="lsxv" group="lsx"/>
42+
<reg name="vr15" bitsize="128" type="lsxv" group="lsx"/>
43+
<reg name="vr16" bitsize="128" type="lsxv" group="lsx"/>
44+
<reg name="vr17" bitsize="128" type="lsxv" group="lsx"/>
45+
<reg name="vr18" bitsize="128" type="lsxv" group="lsx"/>
46+
<reg name="vr19" bitsize="128" type="lsxv" group="lsx"/>
47+
<reg name="vr20" bitsize="128" type="lsxv" group="lsx"/>
48+
<reg name="vr21" bitsize="128" type="lsxv" group="lsx"/>
49+
<reg name="vr22" bitsize="128" type="lsxv" group="lsx"/>
50+
<reg name="vr23" bitsize="128" type="lsxv" group="lsx"/>
51+
<reg name="vr26" bitsize="128" type="lsxv" group="lsx"/>
52+
<reg name="vr25" bitsize="128" type="lsxv" group="lsx"/>
53+
<reg name="vr26" bitsize="128" type="lsxv" group="lsx"/>
54+
<reg name="vr27" bitsize="128" type="lsxv" group="lsx"/>
55+
<reg name="vr28" bitsize="128" type="lsxv" group="lsx"/>
56+
<reg name="vr29" bitsize="128" type="lsxv" group="lsx"/>
57+
<reg name="vr30" bitsize="128" type="lsxv" group="lsx"/>
58+
<reg name="vr31" bitsize="128" type="lsxv" group="lsx"/>
59+
</feature>

target/loongarch/gdbstub.c

Lines changed: 71 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -116,8 +116,77 @@ static int loongarch_gdb_set_fpu(CPUState *cs, uint8_t *mem_buf, int n)
116116
return length;
117117
}
118118

119+
#define VREG_NUM 32
120+
#define REG64_LEN 64
121+
122+
static int loongarch_gdb_get_vec(CPUState *cs, GByteArray *mem_buf, int n, int vl)
123+
{
124+
LoongArchCPU *cpu = LOONGARCH_CPU(cs);
125+
CPULoongArchState *env = &cpu->env;
126+
int i, length = 0;
127+
128+
if (0 <= n && n < VREG_NUM) {
129+
for (i = 0; i < vl / REG64_LEN; i++) {
130+
length += gdb_get_reg64(mem_buf, env->fpr[n].vreg.D(i));
131+
}
132+
}
133+
134+
return length;
135+
}
136+
137+
static int loongarch_gdb_set_vec(CPUState *cs, uint8_t *mem_buf, int n, int vl)
138+
{
139+
LoongArchCPU *cpu = LOONGARCH_CPU(cs);
140+
CPULoongArchState *env = &cpu->env;
141+
int i, length = 0;
142+
143+
if (0 <= n && n < VREG_NUM) {
144+
for (i = 0; i < vl / REG64_LEN; i++) {
145+
env->fpr[n].vreg.D(i) = ldq_le_p(mem_buf + 8 * i);
146+
length += 8;
147+
}
148+
}
149+
150+
return length;
151+
}
152+
153+
static int loongarch_gdb_get_lsx(CPUState *cs, GByteArray *mem_buf, int n)
154+
{
155+
return loongarch_gdb_get_vec(cs, mem_buf, n, LSX_LEN);
156+
}
157+
158+
static int loongarch_gdb_set_lsx(CPUState *cs, uint8_t *mem_buf, int n)
159+
{
160+
return loongarch_gdb_set_vec(cs, mem_buf, n, LSX_LEN);
161+
}
162+
163+
static int loongarch_gdb_get_lasx(CPUState *cs, GByteArray *mem_buf, int n)
164+
{
165+
return loongarch_gdb_get_vec(cs, mem_buf, n, LASX_LEN);
166+
}
167+
168+
static int loongarch_gdb_set_lasx(CPUState *cs, uint8_t *mem_buf, int n)
169+
{
170+
return loongarch_gdb_set_vec(cs, mem_buf, n, LASX_LEN);
171+
}
172+
119173
void loongarch_cpu_register_gdb_regs_for_features(CPUState *cs)
120174
{
121-
gdb_register_coprocessor(cs, loongarch_gdb_get_fpu, loongarch_gdb_set_fpu,
122-
gdb_find_static_feature("loongarch-fpu.xml"), 0);
175+
LoongArchCPU *cpu = LOONGARCH_CPU(cs);
176+
CPULoongArchState *env = &cpu->env;
177+
178+
if (FIELD_EX32(env->cpucfg[2], CPUCFG2, FP)) {
179+
gdb_register_coprocessor(cs, loongarch_gdb_get_fpu, loongarch_gdb_set_fpu,
180+
gdb_find_static_feature("loongarch-fpu.xml"), 0);
181+
}
182+
183+
if (FIELD_EX32(env->cpucfg[2], CPUCFG2, LSX)) {
184+
gdb_register_coprocessor(cs, loongarch_gdb_get_lsx, loongarch_gdb_set_lsx,
185+
gdb_find_static_feature("loongarch-lsx.xml"), 0);
186+
}
187+
188+
if (FIELD_EX32(env->cpucfg[2], CPUCFG2, LASX)) {
189+
gdb_register_coprocessor(cs, loongarch_gdb_get_lasx, loongarch_gdb_set_lasx,
190+
gdb_find_static_feature("loongarch-lasx.xml"), 0);
191+
}
123192
}

0 commit comments

Comments
 (0)