gem5
v20.1.0.0
systemc
ext
channel
sc_fifo_in_if.hh
Go to the documentation of this file.
1
/*
2
* Copyright 2018 Google, Inc.
3
*
4
* Redistribution and use in source and binary forms, with or without
5
* modification, are permitted provided that the following conditions are
6
* met: redistributions of source code must retain the above copyright
7
* notice, this list of conditions and the following disclaimer;
8
* redistributions in binary form must reproduce the above copyright
9
* notice, this list of conditions and the following disclaimer in the
10
* documentation and/or other materials provided with the distribution;
11
* neither the name of the copyright holders nor the names of its
12
* contributors may be used to endorse or promote products derived from
13
* this software without specific prior written permission.
14
*
15
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
18
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
19
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
20
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
21
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
25
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26
*/
27
28
#ifndef __SYSTEMC_EXT_CHANNEL_SC_FIFO_IN_IF_HH__
29
#define __SYSTEMC_EXT_CHANNEL_SC_FIFO_IN_IF_HH__
30
31
#include "../core/sc_interface.hh"
32
33
namespace
sc_core
34
{
35
36
class
sc_event;
37
38
template
<
class
T>
39
class
sc_fifo_nonblocking_in_if
:
virtual
public
sc_interface
40
{
41
public
:
42
virtual
bool
nb_read
(T &) = 0;
43
virtual
const
sc_event
&
data_written_event
()
const
= 0;
44
};
45
46
template
<
class
T>
47
class
sc_fifo_blocking_in_if
:
virtual
public
sc_interface
48
{
49
public
:
50
virtual
void
read
(T &) = 0;
51
virtual
T
read
() = 0;
52
};
53
54
template
<
class
T>
55
class
sc_fifo_in_if
:
public
sc_fifo_nonblocking_in_if
<T>,
56
public
sc_fifo_blocking_in_if
<T>
57
{
58
public
:
59
virtual
int
num_available
()
const
= 0;
60
61
protected
:
62
sc_fifo_in_if
() :
sc_interface
() {}
63
64
private
:
65
// Disabled
66
sc_fifo_in_if
(
const
sc_fifo_in_if<T>
&);
67
sc_fifo_in_if<T>
&
operator =
(
const
sc_fifo_in_if<T>
&) {
return
*
this
; }
68
};
69
70
}
// namespace sc_core
71
72
#endif //__SYSTEMC_EXT_CHANNEL_SC_FIFO_IN_IF_HH__
sc_core::sc_fifo_in_if::operator=
sc_fifo_in_if< T > & operator=(const sc_fifo_in_if< T > &)
Definition:
sc_fifo_in_if.hh:67
sc_core
Definition:
messages.cc:31
sc_core::sc_interface
Definition:
sc_interface.hh:37
sc_core::sc_event
Definition:
sc_event.hh:169
sc_core::sc_fifo_blocking_in_if::read
virtual T read()=0
sc_core::sc_fifo_in_if::num_available
virtual int num_available() const =0
sc_core::sc_fifo_in_if
Definition:
sc_fifo_in_if.hh:55
sc_core::sc_fifo_blocking_in_if
Definition:
sc_fifo_in_if.hh:47
sc_core::sc_fifo_nonblocking_in_if::nb_read
virtual bool nb_read(T &)=0
sc_core::sc_fifo_nonblocking_in_if::data_written_event
virtual const sc_event & data_written_event() const =0
sc_core::sc_fifo_nonblocking_in_if
Definition:
sc_fifo_in_if.hh:39
sc_core::sc_fifo_in_if::sc_fifo_in_if
sc_fifo_in_if()
Definition:
sc_fifo_in_if.hh:62
Generated on Wed Sep 30 2020 14:02:15 for gem5 by
doxygen
1.8.17