forked from RaftLib/RaftLib
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathport.hpp
165 lines (145 loc) · 5.08 KB
/
port.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
/**
* port.hpp -
* @author: Jonathan Beard
* @version: Thu Aug 28 09:55:47 2014
*
* Copyright 2014 Jonathan Beard
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at:
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef _PORT_HPP_
#define _PORT_HPP_ 1
#include <map>
#include <string>
#include <utility>
#include <typeinfo>
#include <typeindex>
#include "graphtools.hpp"
#include "ringbuffertypes.hpp"
#include "fifo.hpp"
#include "port_info.hpp"
#include "ringbuffer.tcc"
#include "port_info_types.hpp"
class Kernel;
class Port
{
public:
Port( Kernel *k );
/**
* ~Port - destructor, deletes the FIFO that was given
* when the object was initalized.
*/
virtual ~Port();
/**
* addPort - adds and initializes a port for the name
* given. Function returns true if added, false if not.
* Main reason for returning false would be that the
* port already exists.
* @param port_name - const std::string
* @return bool
*/
template < class T >
bool addPort( const std::string port_name )
{
/**
* we'll have to make a port info object first and pass it by copy
* to the portmap. Perhaps re-work later with pointers, but for
* right now this will work and it doesn't necessarily have to
* be performant since its only executed once.
*/
PortInfo pi( typeid( T ) );
pi.my_kernel = kernel;
pi.my_name = port_name;
(this)->initializeConstMap<T>( pi );
const auto ret_val( portmap.insert( std::make_pair( port_name,
pi ) ) );
return( ret_val.second );
}
/**
* getPortType - input the port name, and get the hash
* for the type of the port. This function is useful
* for checking the streaming graph to make sure all the
* ports that are "dynamically" created do in fact have
* compatible types.
* @param port_name - const std::string
* @return const type_index&
* @throws PortNotFoundException
*/
const std::type_index& getPortType( const std::string port_name );
/**
* operator[] - input the port name and get a port
* if it exists.
*/
FIFO& operator[]( const std::string port_name );
/**
* hasPorts - returns true if any ports exists, false
* otherwise.
* @return bool
*/
bool hasPorts();
protected:
/**
* initializeConstMap - hack to get around the inability to otherwise
* initialize a template function where later we don't have the
* template parameter. NOTE: this is a biggy, if we have more
* FIFO types in the future (i.e., sub-classes of FIFO) then we
* must create an entry here otherwise bad things will happen.
* @param pi - PortInfo&
*/
template < class T > void initializeConstMap( PortInfo &pi )
{
pi.const_map.insert(
std::make_pair( Type::Heap , new instr_map_t() ) );
pi.const_map[ Type::Heap ]->insert(
std::make_pair( false /** no instrumentation **/,
RingBuffer< T, Type::Heap, false >::make_new_fifo ) );
pi.const_map[ Type::Heap ]->insert(
std::make_pair( true /** yes instrumentation **/,
RingBuffer< T, Type::Heap, false >::make_new_fifo ) );
pi.const_map.insert( std::make_pair( Type::SharedMemory, new instr_map_t() ) );
pi.const_map[ Type::SharedMemory ]->insert(
std::make_pair( false /** no instrumentation **/,
RingBuffer< T, Type::SharedMemory >::make_new_fifo ) );
/** no instrumentation version defined yet **/
return;
}
/**
* getPortInfo - returns the PortInfo struct for a kernel if we
* expect it to have a single port. If there's more than one port
* this function throws an exception.
* @return std::pair< std::string, PortInfo& >
*/
PortInfo& getPortInfo();
/**
* getPortInfoFor - gets port information for the param port
* throws an exception if the port doesn't exist.
* @param port_name - const std::string
* @return PortInfo&
*/
PortInfo& getPortInfoFor( const std::string port_name );
/**
* portmap - data structure that maps the ports by name
* to the info data structures that actually contain them
*/
std::map< std::string, PortInfo > portmap;
/**
* parent kernel that owns this port
*/
Kernel *kernel;
/** we need some friends **/
friend class Map;
friend void GraphTools::BFS( std::set< Kernel* > &source_kernels,
edge_func fun,
bool connection_error );
};
#endif /* END _PORT_HPP_ */