-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgraph.cc
96 lines (83 loc) · 1.72 KB
/
graph.cc
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
/*******************************************************************************
*
* Copyright (c) 2022 Ruslan Dashkin
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor,
* Boston, MA 02110-1301, USA.
*
******************************************************************************/
#include "graph.h"
namespace fpga {
/*
Port class
*/
port::port(){
c = NULL;
visited = 0;
disable = 0;
dir = 0;
bi = 0;
drive_type = 0;
delay = 0;
forced = 0;
extra_owner = 0;
extra_dir = 0;
owner = 0;
primary = 0;
wire = 0;
e = NULL;
u.p.n = NULL;
}
port::~port(){}
void port::setExtraOwner(inst_node *in)
{
extra_owner = 1;
e = in;
}
void port::setExtraDir(int i)
{
extra_dir = i;
}
void port::setOwner(node *n)
{
owner = 0;
u.p.n = n;
}
void port::setOwner(inst_node *in)
{
owner = 1;
u.i.in = in;
}
void port::setOwner(gate *g)
{
owner = 2;
u.g.g = g;
}
/*
Instance node class
*/
inst_node::inst_node()
{
proc = NULL;
n = NULL;
par = NULL;
inst_name = NULL;
array = NULL;
visited = 0;
extra_inst = 0;
next = NULL;
}
inst_node::~inst_node(){}
}