OpenCores
URL https://opencores.org/ocsvn/riscv_vhdl/riscv_vhdl/trunk

Subversion Repositories riscv_vhdl

[/] [riscv_vhdl/] [trunk/] [debugger/] [src/] [libdbg64g/] [services/] [exec/] [cmd/] [cmd_reg.cpp] - Blame information for rev 2

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 2 sergeykhbr
/**
2
 * @file
3
 * @copyright  Copyright 2016 GNSS Sensor Ltd. All right reserved.
4
 * @author     Sergey Khabarov - sergeykhbr@gmail.com
5
 * @brief      Read/write register value.
6
 */
7
 
8
#include "cmd_reg.h"
9
 
10
namespace debugger {
11
 
12
CmdReg::CmdReg(ITap *tap, ISocInfo *info)
13
    : ICommand ("reg", tap, info) {
14
 
15
    briefDescr_.make_string("Read/write register value");
16
    detailedDescr_.make_string(
17
        "Description:\n"
18
        "    Read or modify the specific CPU's register.\n"
19
        "Usage:\n"
20
        "    reg name\n"
21
        "    reg name wrvalue\n"
22
        "Example:\n"
23
        "    reg\n"
24
        "    reg pc\n"
25
        "    reg sp 0x10007fc0\n");
26
}
27
 
28
bool CmdReg::isValid(AttributeType *args) {
29
    if ((*args)[0u].is_equal(cmdName_.to_string())
30
     && (args->size() == 2 || args->size() == 3)) {
31
        return CMD_VALID;
32
    }
33
    return CMD_INVALID;
34
}
35
 
36
void CmdReg::exec(AttributeType *args, AttributeType *res) {
37
    if (!isValid(args)) {
38
        generateError(res, "Wrong argument list");
39
        return;
40
    }
41
    res->make_nil();
42
 
43
    uint64_t val;
44
    const char *reg_name = (*args)[1].to_string();
45
    uint64_t addr = info_->reg2addr(reg_name);
46
    if (addr == REG_ADDR_ERROR) {
47
        char tstr[128];
48
        RISCV_sprintf(tstr, sizeof(tstr), "%s not found", reg_name);
49
        generateError(res, tstr);
50
        return;
51
    }
52
 
53
    if (args->size() == 2) {
54
        int err = tap_->read(addr, 8, reinterpret_cast<uint8_t *>(&val));
55
        if (err == TAP_ERROR) {
56
            return;
57
        }
58
        res->make_uint64(val);
59
    } else {
60
        val = (*args)[2].to_uint64();
61
        tap_->write(addr, 8, reinterpret_cast<uint8_t *>(&val));
62
    }
63
}
64
 
65
}  // namespace debugger

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.