gem5
v21.2.1.1
systemc
ext
channel
sc_fifo_out_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_OUT_IF_HH__
29
#define __SYSTEMC_EXT_CHANNEL_SC_FIFO_OUT_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_out_if
:
virtual
public
sc_interface
40
{
41
public
:
42
virtual
bool
nb_write
(
const
T &) = 0;
43
virtual
const
sc_event
&
data_read_event
()
const
= 0;
44
};
45
46
template
<
class
T>
47
class
sc_fifo_blocking_out_if
:
virtual
public
sc_interface
48
{
49
public
:
50
virtual
void
write
(
const
T &) = 0;
51
};
52
53
template
<
class
T>
54
class
sc_fifo_out_if
:
public
sc_fifo_nonblocking_out_if
<T>,
55
public
sc_fifo_blocking_out_if
<T>
56
{
57
public
:
58
virtual
int
num_free
()
const
= 0;
59
60
protected
:
61
sc_fifo_out_if
() :
sc_interface
(),
sc_fifo_nonblocking_out_if
<T>(),
62
sc_fifo_blocking_out_if
<T>()
63
{}
64
65
private
:
66
sc_fifo_out_if
(
const
sc_fifo_out_if<T>
&) :
sc_interface
(),
67
sc_fifo_nonblocking_out_if
<T>(),
sc_fifo_blocking_out_if
<T>()
68
{}
69
sc_fifo_out_if<T>
&
operator =
(
const
sc_fifo_out_if<T>
&) {
return
*
this
; }
70
};
71
72
}
// namespace sc_core
73
74
#endif //__SYSTEMC_EXT_CHANNEL_SC_FIFO_OUT_IF_HH__
sc_core::sc_fifo_nonblocking_out_if
Definition:
sc_fifo_out_if.hh:39
sc_core
Definition:
messages.cc:31
sc_core::sc_fifo_out_if
Definition:
sc_fifo_out_if.hh:54
sc_core::sc_fifo_out_if::num_free
virtual int num_free() const =0
sc_core::sc_interface
Definition:
sc_interface.hh:37
sc_core::sc_fifo_blocking_out_if
Definition:
sc_fifo_out_if.hh:47
sc_core::sc_event
Definition:
sc_event.hh:169
sc_core::sc_fifo_out_if::sc_fifo_out_if
sc_fifo_out_if()
Definition:
sc_fifo_out_if.hh:61
sc_core::sc_fifo_nonblocking_out_if::nb_write
virtual bool nb_write(const T &)=0
sc_core::sc_fifo_out_if::operator=
sc_fifo_out_if< T > & operator=(const sc_fifo_out_if< T > &)
Definition:
sc_fifo_out_if.hh:69
sc_core::sc_fifo_nonblocking_out_if::data_read_event
virtual const sc_event & data_read_event() const =0
sc_core::sc_fifo_out_if::sc_fifo_out_if
sc_fifo_out_if(const sc_fifo_out_if< T > &)
Definition:
sc_fifo_out_if.hh:66
sc_core::sc_fifo_blocking_out_if::write
virtual void write(const T &)=0
Generated on Wed May 4 2022 12:14:04 for gem5 by
doxygen
1.8.17