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

Subversion Repositories riscv_vhdl

[/] [riscv_vhdl/] [trunk/] [debugger/] [src/] [socsim_plugin/] [gpio.h] - 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
#ifndef __DEBUGGER_SOCSIM_PLUGIN_GPIO_H__
9
#define __DEBUGGER_SOCSIM_PLUGIN_GPIO_H__
10
 
11
#include "iclass.h"
12
#include "iservice.h"
13
#include "coreservices/imemop.h"
14
#include "coreservices/isignal.h"
15
 
16
namespace debugger {
17
 
18
class GPIO : public IService,
19
             public IMemoryOperation,
20
             public ISignal {
21
public:
22
    GPIO(const char *name);
23
    ~GPIO();
24
 
25
    /** IService interface */
26
    virtual void postinitService();
27
 
28
    /** IMemoryOperation */
29
    virtual void b_transport(Axi4TransactionType *trans);
30
 
31
    virtual uint64_t getBaseAddress() {
32
        return baseAddress_.to_uint64();
33
    }
34
    virtual uint64_t getLength() {
35
        return length_.to_uint64();
36
    }
37
 
38
    /** ISignal interface */
39
    virtual void setLevel(int start, int width, uint64_t value);
40
    virtual void registerSignalListener(IFace *listener);
41
    virtual void unregisterSignalListener(IFace *listener);
42
 
43
 
44
private:
45
    AttributeType baseAddress_;
46
    AttributeType length_;
47
    AttributeType dip_;
48
    AttributeType listOfListerners_;
49
 
50
    struct gpio_map {
51
        volatile uint32_t led;
52
        volatile uint32_t dip;
53
        volatile uint32_t reg2;
54
        volatile uint32_t reg3;
55
        volatile uint32_t led_period;
56
        volatile uint32_t reg5;
57
        volatile uint32_t reg6;
58
    } regs_;
59
};
60
 
61
DECLARE_CLASS(GPIO)
62
 
63
}  // namespace debugger
64
 
65
#endif  // __DEBUGGER_SOCSIM_PLUGIN_GPIO_H__

powered by: WebSVN 2.1.0

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