OpenCores
URL https://opencores.org/ocsvn/an-fpga-implementation-of-low-latency-noc-based-mpsoc/an-fpga-implementation-of-low-latency-noc-based-mpsoc/trunk

Subversion Repositories an-fpga-implementation-of-low-latency-noc-based-mpsoc

[/] [an-fpga-implementation-of-low-latency-noc-based-mpsoc/] [trunk/] [mpsoc/] [perl_gui/] [lib/] [perl/] [intfc_gen.pm] - Blame information for rev 16

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 16 alirezamon
#!/usr/bin/perl -w -I ..
2
###############################################################################
3
#
4
# File:         interface.pm
5
# 
6
#
7
###############################################################################
8
use warnings;
9
use strict;
10
 
11
 
12
 
13
package intfc_gen;
14
 
15
sub interface_generator {
16
                my $class = "intfc_gen";
17
                my $self;
18
                $self->{file_name}=();
19
                $self->{modules}={};
20
                $self->{module_name}=();
21
                $self->{type}=();
22
                $self->{name}=();
23
                bless($self,$class);
24
                return $self;
25
}
26
 
27
sub intfc_set_interface_file {
28
        my ($self,$file)= @_;
29
        if (defined $file){
30
                #print "file name has been changed to $file\n";
31
                $self->{file_name}=$file;
32
                #delete old data
33
                if(exists ($self->{modules})) {delete $self->{modules}; } ;
34
                if(exists ($self->{module_name})) {delete $self->{module_name}; } ;
35
                if(exists ($self->{ports})){ delete $self->{ports}};
36
 
37
 
38
 
39
                }
40
}
41
 
42
sub intfc_get_interface_file {
43
        my ($self)=@_;
44
        my $file;
45
        if (exists ($self->{file_name})){
46
                $file=$self->{file_name};
47
        }
48
        return $file;
49
}
50
 
51
sub intfc_add_module_list{
52
                my ($self,@list)=@_;
53
                $self->{modules}={};
54
                foreach my $p(@list) {
55
                        $self->{modules}{$p}={};
56
 
57
                }
58
 
59
}
60
 
61
 
62
sub intfc_get_module_list{
63
                my ($self)=@_;
64
                my @modules;
65
                if(exists($self->{modules})){
66
                        @modules=keys %{$self->{modules}};
67
                }
68
                return @modules;
69
}
70
 
71
sub intfc_set_module_name{
72
        my ($self,$module)= @_;
73
        $self->{module_name}=$module;
74
        if(exists ($self->{ports})){ delete $self->{ports}};
75
}
76
 
77
sub intfc_remove_ports{
78
        my $self=shift;
79
        if(exists ($self->{ports})){ delete $self->{ports}};
80
}
81
 
82
 
83
 
84
sub intfc_get_module_name {
85
        my ($self)=@_;
86
        my $module;
87
        if (exists ($self->{module_name})){
88
                $module=$self->{module_name};
89
        }
90
        return $module;
91
}
92
 
93
 
94
sub intfc_add_port{
95
        my ($self,$port_id,$type,$range,$name,$connect_type,$connect_range,$connect_name,$outport_type)=@_;
96
        $self->{ports}{$port_id}{name}=$name;
97
        $self->{ports}{$port_id}{range}=$range;
98
        $self->{ports}{$port_id}{type}=$type;
99
        $self->{ports}{$port_id}{connect_name}=$connect_name;
100
        $self->{ports}{$port_id}{connect_range}=$connect_range;
101
        $self->{ports}{$port_id}{connect_type}=$connect_type;
102
        $self->{ports}{$port_id}{outport_type}=$outport_type;
103
}
104
 
105
sub intfc_get_ports{
106
        my ($self,$types_ref,$ranges_ref,$names_ref,$connect_types_ref,$connect_ranges_ref,$connect_name_ref,$outport_type_ref)=@_;
107
        if(exists ($self->{ports})){
108
                foreach my $id (sort keys %{$self->{ports}}){
109
                                $types_ref->{$id}=$self->{ports}{$id}{type};
110
                                $ranges_ref->{$id}=$self->{ports}{$id}{range};
111
                                $names_ref->{$id}=$self->{ports}{$id}{name};
112
                                $connect_types_ref->{$id}=$self->{ports}{$id}{connect_type};
113
                                $connect_ranges_ref->{$id}=$self->{ports}{$id}{connect_range};
114
                                $connect_name_ref->{$id}=$self->{ports}{$id}{connect_name};
115
                                $outport_type_ref->{$id}=$self->{ports}{$id}{outport_type};
116
                }
117
        }
118
}
119
 
120
sub intfc_ckeck_ports_available{
121
        my ($self)=@_;
122
        my $result;
123
        if(exists ($self->{ports})){$result=1;}
124
        return $result;
125
 
126
}
127
 
128
sub intfc_remove_port{
129
                my ($self,$port_id)=@_;
130
                if(exists ($self->{ports}{$port_id})){
131
                        delete $self->{ports}{$port_id};
132
                }
133
}
134
 
135
 
136
sub intfc_get_ports_type{
137
        my ($self)=@_;
138
        my %ports_type;
139
        if(exists ($self->{ports})){
140
                foreach my $p (sort keys %{$self->{ports}}){
141
                        $ports_type{$p}= $self->{ports}{$p}{type};
142
 
143
                }
144
        }
145
        return %ports_type;
146
}
147
 
148
 
149
 
150
sub intfc_set_interface_name{
151
        my ($self,$name)=@_;
152
        $self->{name}=$name;
153
}
154
 
155
sub intfc_get_interface_name {
156
        my ($self)=@_;
157
        my $name;
158
        if(exists ($self->{name})){
159
                $name=$self->{name};
160
        }
161
        return $name;
162
}
163
 
164
 
165
 
166
 
167
sub intfc_set_interface_type {
168
        my ($self,$intfc_type)=@_;
169
        $self->{type}=$intfc_type;
170
}
171
 
172
 
173
sub intfc_get_interface_type {
174
        my ($self)=@_;
175
        my $type;
176
        if(exists ($self->{type})){
177
                $type=$self->{type};
178
        }
179
        return $type;
180
}
181
 
182
 
183
sub intfc_set_connection_num {
184
        my ($self,$connection_num)=@_;
185
        $self->{connection_num}=$connection_num;
186
}
187
 
188
 
189
sub intfc_get_connection_num {
190
        my ($self)=@_;
191
        my $connection_num;
192
        if(exists ($self->{connection_num})){
193
                $connection_num=$self->{connection_num};
194
        }
195
        return $connection_num;
196
}
197
 
198
 
199
sub intfc_set_category{
200
        my ($self,$category)=@_;
201
        $self->{category}=$category;
202
}
203
 
204
 
205
sub intfc_get_category{
206
        my ($self)=@_;
207
        my $category;
208
        if(exists ($self->{category})){
209
                $category=$self->{category};
210
        }
211
        return $category;
212
}
213
 
214
sub intfc_set_description{
215
        my  ($self,$description)=@_;
216
        $self->{description}=$description;
217
}
218
 
219
 
220
 
221
sub intfc_get_description{
222
my ($self)=@_;
223
        my $des;
224
        if(exists ($self->{description})){
225
                $des=$self->{description};
226
        }
227
        return $des;
228
}
229
 
230
 
231
 
232
1

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.