aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTim Newsome <tim@sifive.com>2022-05-04 10:25:37 -0700
committerTim Newsome <tim@sifive.com>2022-05-04 10:44:09 -0700
commite191bccc730389c9bca661077dbc7121828cf946 (patch)
treea40356dc79d52e4347c8d4fee4cf691371eb49bb
parentb6dddfacc05ea981aabcf76ed155f68b677950a1 (diff)
downloadriscv-openocd-e191bccc730389c9bca661077dbc7121828cf946.zip
riscv-openocd-e191bccc730389c9bca661077dbc7121828cf946.tar.gz
riscv-openocd-e191bccc730389c9bca661077dbc7121828cf946.tar.bz2
Change set_haltgroup() to more general set_group()
Change-Id: Ib91a252ac63604e54b756f70c549ccd47241fd10 Signed-off-by: Tim Newsome <tim@sifive.com>
-rw-r--r--src/target/riscv/riscv-013.c13
1 files changed, 9 insertions, 4 deletions
diff --git a/src/target/riscv/riscv-013.c b/src/target/riscv/riscv-013.c
index 63b40c6..e179e82 100644
--- a/src/target/riscv/riscv-013.c
+++ b/src/target/riscv/riscv-013.c
@@ -1503,15 +1503,20 @@ static void deinit_target(struct target *target)
info->version_specific = NULL;
}
-static int set_haltgroup(struct target *target, bool *supported)
+typedef enum {
+ HALTGROUP,
+ RESUMEGROUP
+} grouptype_t;
+static int set_group(struct target *target, bool *supported, unsigned group, grouptype_t grouptype)
{
- uint32_t write = set_field(DM_DMCS2_HGWRITE, DM_DMCS2_GROUP, target->smp);
+ uint32_t write = set_field(DM_DMCS2_HGWRITE, DM_DMCS2_GROUP, group);
+ write = set_field(write, DM_DMCS2_GROUPTYPE, 1);
if (dmi_write(target, DM_DMCS2, write) != ERROR_OK)
return ERROR_FAIL;
uint32_t read;
if (dmi_read(target, &read, DM_DMCS2) != ERROR_OK)
return ERROR_FAIL;
- *supported = get_field(read, DM_DMCS2_GROUP) == (unsigned)target->smp;
+ *supported = get_field(read, DM_DMCS2_GROUP) == group;
return ERROR_OK;
}
@@ -1754,7 +1759,7 @@ static int examine(struct target *target)
if (target->smp) {
bool haltgroup_supported;
- if (set_haltgroup(target, &haltgroup_supported) != ERROR_OK)
+ if (set_group(target, &haltgroup_supported, target->smp, HALTGROUP) != ERROR_OK)
return ERROR_FAIL;
if (haltgroup_supported)
LOG_INFO("Core %d made part of halt group %d.", target->coreid,