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

Subversion Repositories riscv_vhdl

[/] [riscv_vhdl/] [trunk/] [debugger/] [src/] [socsim_plugin/] [gpio.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      GPIO functional model.
6
 */
7
 
8
#include "api_core.h"
9
#include "gpio.h"
10
#include "coreservices/isignallistener.h"
11
 
12
namespace debugger {
13
 
14
GPIO::GPIO(const char *name)  : IService(name) {
15
    registerInterface(static_cast<IMemoryOperation *>(this));
16
    registerInterface(static_cast<ISignal *>(this));
17
    registerAttribute("BaseAddress", &baseAddress_);
18
    registerAttribute("Length", &length_);
19
    registerAttribute("DIP", &dip_);
20
 
21
    baseAddress_.make_uint64(0);
22
    length_.make_uint64(0);
23
    dip_.make_uint64(0);
24
 
25
    listOfListerners_.make_list(0);
26
 
27
    memset(&regs_, 0, sizeof(regs_));
28
}
29
 
30
GPIO::~GPIO() {
31
}
32
 
33
void GPIO::postinitService() {
34
    regs_.dip = static_cast<uint32_t>(dip_.to_uint64());
35
}
36
 
37
void GPIO::b_transport(Axi4TransactionType *trans) {
38
    uint64_t mask = (length_.to_uint64() - 1);
39
    uint64_t off = ((trans->addr - getBaseAddress()) & mask) / 4;
40
    uint32_t *mem_ = reinterpret_cast<uint32_t *>(&regs_);
41
    trans->response = MemResp_Valid;
42
    if (trans->action == MemAction_Write) {
43
        for (uint64_t i = 0; i < trans->xsize/4; i++) {
44
            if (trans->wstrb & (0xf << 4*i)) {
45
                mem_[off + i] = trans->wpayload.b32[i];
46
            }
47
 
48
            if (off + i == (reinterpret_cast<uint64_t>(&regs_.led)
49
                          - reinterpret_cast<uint64_t>(&regs_))) {
50
                ISignalListener *ilistener;
51
                for (unsigned n = 0; n < listOfListerners_.size(); n++) {
52
                    ilistener = static_cast<ISignalListener *>(
53
                                    listOfListerners_[n].to_iface());
54
                    ilistener->updateSignal(0, 8, regs_.led & 0xFF);
55
                }
56
            }
57
        }
58
    } else {
59
        for (uint64_t i = 0; i < trans->xsize/4; i++) {
60
            trans->rpayload.b32[i] = mem_[i + off];
61
        }
62
    }
63
}
64
 
65
void GPIO::setLevel(int start, int width, uint64_t value) {
66
    uint64_t t = value >> start;
67
    uint64_t msk = (1LL << width) - 1;
68
    uint64_t prev = dip_.to_uint64() & ~(msk << start);
69
    t &= msk;
70
    dip_.make_uint64(prev | (t << start));
71
    RISCV_info("set level pins[%d:%d] <= %" RV_PRI64 "x", start - 1, width, t);
72
}
73
 
74
void GPIO::registerSignalListener(IFace *listener) {
75
    AttributeType t(listener);
76
    listOfListerners_.add_to_list(&t);
77
}
78
 
79
void GPIO::unregisterSignalListener(IFace *listener) {
80
}
81
 
82
}  // namespace debugger

powered by: WebSVN 2.1.0

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