This repository has been archived by the owner on Jul 23, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 11
/
cMultiWireBuilder.cpp
62 lines (53 loc) · 1.92 KB
/
cMultiWireBuilder.cpp
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
/******************************************************************************
Copyright 2012 Victor Yurkovsky
This file is part of FPGAsm
FPGAsm 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 3 of the License, or
(at your option) any later version.
FPGAsm 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 FPGAsm. If not, see <http://www.gnu.org/licenses/>.
******************************************************************************/
#include "global.h"
#include "cMultiWireBuilder.h"
#define CLASS cMultiWireBuilder
CLASS::CLASS(){
max = CMULTIWIRE_CAP_INIT; //initial limit, in wireends.
buf = (sWireEnd*)malloc(max*sizeof(sWireEnd));
index=0;
}
CLASS::~CLASS(){
//we never free the buffer - it is used by consumers.
}
void CLASS::add(int inst,int port,int busid){
//is there room
if(index>=max) {
// reallocate, double size
//fprintf(stderr,"cMultiWireBuilder: reallocating from %d to %d\n",max,max*2);
max = max*2;
buf = (sWireEnd*)realloc(buf,max*sizeof(sWireEnd));
}
buf[index].inst=inst;
buf[index].pindex=port;
buf[index].busid=busid;
index++;
//fprintf(stderr,"cMultiWireBuilder: added %d %d %d, total %d\n",inst,port,busid,index);
}
void CLASS::stop(){
add(INST_STOP, 0, 0);
}
void CLASS::end(){
add(INST_END, 0, 0);
}
cMultiWire* CLASS::solidify(){
end();
buf = (sWireEnd*)realloc(buf,index*sizeof(sWireEnd));
//fprintf(stderr,"cMultiWireBuilder: final size %d units\n",index);
cMultiWire* ret = new cMultiWire(*this);
buf=0; //this way it will not be free'd
return ret;
}