00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019 #ifndef TORC_PHYSICAL_MODULETRANSFORMER_HPP
00020 #define TORC_PHYSICAL_MODULETRANSFORMER_HPP
00021
00022 #include "torc/Architecture.hpp"
00023 #include "torc/physical/Factory.hpp"
00024 #include <boost/lexical_cast.hpp>
00025
00026 using namespace std;
00027 using namespace torc::architecture;
00028 using namespace torc::architecture::xilinx;
00029
00030 namespace torc {
00031 namespace physical {
00032
00033
00034 class ModuleTransformer {
00035
00036 protected:
00037
00038
00039 typedef Design::InstanceSharedPtrConstIterator InstanceSharedPtrConstIterator;
00040
00041 typedef Design::NetSharedPtrIterator NetSharedPtrIterator;
00042
00043 typedef Design::ModuleSharedPtrIterator ModuleSharedPtrIterator;
00044
00045 typedef Design::InstanceSharedPtrIterator InstanceSharedPtrIterator;
00046
00047 typedef Module::PortSharedPtrConstIterator PortSharedPtrConstIterator;
00048
00049 typedef Net::InstancePinSharedPtrIterator InstancePinSharedPtrIterator;
00050
00051 typedef Net::InstancePinSharedPtrConstIterator InstancePinSharedPtrConstIterator;
00052
00053 typedef Net::PipConstIterator PipConstIterator;
00054
00055
00056 DesignSharedPtr mDesignPtr;
00057
00058 static const string sHierarchySeparator;
00059
00060 static const string sPortIndexSeparator;
00061
00062 static const boost::regex sValidPinNameCharactersRegEx;
00063
00064 static const boost::regex sInvalidPinNameFirstCharactersRegEx;
00065
00066
00067
00068 enum ENetConnectivity {
00069 eNetConnectivityNotConnected = 0, eNetConnectivityInternal, eNetConnectivityExternal
00070 };
00071
00072 public:
00073
00074
00075
00076 ModuleTransformer(DesignSharedPtr& inDesignPtr) : mDesignPtr(inDesignPtr) {}
00077
00078
00079
00080
00081
00082
00083
00084
00085
00086
00087
00088
00089
00090
00091
00092
00093
00094
00095
00096
00097
00098
00099
00100
00101
00102
00103
00104
00105
00106
00107
00108
00109
00110
00111
00112
00113
00114
00115
00116
00117
00118
00119
00120
00121
00122
00123
00124
00125
00126
00127
00128
00129
00130
00131
00132
00133
00134
00135
00136
00137
00138
00139
00140
00141
00142
00143
00144
00145
00146
00147 bool modularize(const InstanceSharedPtrVector& inInstances,
00148 const string& inModuleDefinitionName, const string& inModuleInstanceName,
00149 bool inKeepPlacement = false, bool inKeepRouting = false) {
00150
00151
00152 InstanceSharedPtrConstIterator inInstanceSharedPtrConstIter = inInstances.begin();
00153
00154 InstanceSharedPtrConstIterator inInstanceSharedPtrConstEnd = inInstances.end();
00155
00156
00157 if(inInstanceSharedPtrConstIter == inInstanceSharedPtrConstEnd) {
00158
00159
00160 std::clog << "WARNING: There were no instances specified to be modularized. "
00161 << std::endl;
00162
00163
00164 return false;
00165
00166 }
00167
00168
00169 InstanceSharedPtr moduleReferenceInst = *inInstanceSharedPtrConstIter;
00170
00171 ModuleSharedPtr moduleDefinition = Factory::newModulePtr(inModuleDefinitionName,
00172 moduleReferenceInst->getName());
00173
00174 InstanceSharedPtr moduleInst = Factory::newInstancePtr(inModuleInstanceName,
00175 inModuleDefinitionName, moduleReferenceInst->getTile(),
00176 moduleReferenceInst->getSite());
00177
00178
00179 if(!inKeepPlacement) moduleInst->unplace();
00180
00181
00182
00183 while(inInstanceSharedPtrConstIter != inInstanceSharedPtrConstEnd) {
00184
00185
00186 InstanceSharedPtr instPtr = *inInstanceSharedPtrConstIter;
00187
00188
00189 InstanceSharedPtrConstIterator instPtrIter
00190 = mDesignPtr->findInstance(instPtr->getName());
00191
00192
00193 if(instPtrIter == mDesignPtr->instancesEnd()) {
00194
00195
00196 std::clog << "WARNING: Instance " << instPtr->getName()
00197 << "was not found in design " << mDesignPtr->getName() << std::endl;
00198
00199 return false;
00200
00201 }
00202
00203
00204 InstanceSharedPtr designInstPtr = *instPtrIter;
00205
00206
00207 if(!inKeepPlacement) designInstPtr->unplace();
00208
00209
00210 moduleDefinition->addInstance(designInstPtr);
00211
00212 mDesignPtr->removeInstance(designInstPtr);
00213
00214
00215 inInstanceSharedPtrConstIter++;
00216
00217 }
00218
00219
00220
00221
00222 NetSharedPtrIterator designNetsIter = mDesignPtr->netsBegin();
00223
00224 NetSharedPtrIterator designNetsEnd = mDesignPtr->netsEnd();
00225
00226 InstanceSharedPtrConstIterator modHostedInstPtrConstBegin
00227 = moduleDefinition->instancesBegin();
00228
00229 InstanceSharedPtrConstIterator modHostedInstPtrConstEnd
00230 = moduleDefinition->instancesEnd();
00231
00232 InstancePinSharedPtrVector modInstSourcePinPtrVector;
00233
00234 InstancePinSharedPtrVector modInstSinkPinPtrVector;
00235
00236
00237 while(designNetsIter != designNetsEnd) {
00238
00239
00240 NetSharedPtr designNetPtr = *designNetsIter;
00241
00242 ENetConnectivity eNet = getNetConnectivity(modHostedInstPtrConstBegin,
00243 modHostedInstPtrConstEnd, designNetPtr);
00244
00245
00246 if(eNet == eNetConnectivityInternal) {
00247
00248
00249 if(!inKeepRouting) designNetPtr->unroute();
00250
00251
00252 moduleDefinition->addNet(designNetPtr);
00253
00254 mDesignPtr->removeNet(designNetPtr);
00255
00256 designNetsEnd = mDesignPtr->netsEnd();
00257
00258 } else {
00259
00260
00261 if(eNet == eNetConnectivityNotConnected) {
00262
00263
00264 designNetsIter++;
00265 continue;
00266
00267 }
00268
00269
00270
00271 if(!inKeepRouting) designNetPtr->unroute();
00272
00273
00274 InstancePinSharedPtrIterator designNetSourcesIter
00275 = designNetPtr->sourcesBegin();
00276
00277 InstancePinSharedPtrIterator designNetSourcesEnd = designNetPtr->sourcesEnd();
00278
00279 u_int32_t portIndex = 0;
00280
00281
00282 while(designNetSourcesIter != designNetSourcesEnd) {
00283
00284
00285 InstancePinSharedPtr instPinPtr = *designNetSourcesIter;
00286
00287 InstanceSharedPtr pinInstPtr = instPinPtr->getInstancePtr().lock();
00288
00289
00290 if((std::find(modHostedInstPtrConstBegin, modHostedInstPtrConstEnd,
00291 pinInstPtr)) != modHostedInstPtrConstEnd) {
00292
00293
00294 string portName = sanitizePinName(designNetPtr->getName())
00295 + sPortIndexSeparator
00296 + boost::lexical_cast<std::string>(portIndex++);
00297
00298 PortSharedPtr portPtr = Factory::newPortPtr(portName, *(std::find(
00299 modHostedInstPtrConstBegin, modHostedInstPtrConstEnd,
00300 pinInstPtr)), instPinPtr->getPinName());
00301
00302 moduleDefinition->addPort(portPtr);
00303
00304 modInstSourcePinPtrVector.push_back(
00305 Factory::newInstancePinPtr(moduleInst, portName));
00306
00307 designNetPtr->removeSource(instPinPtr);
00308
00309 designNetSourcesEnd = designNetPtr->sourcesEnd();
00310
00311 } else {
00312
00313
00314 designNetSourcesIter++;
00315
00316 }
00317 }
00318
00319
00320 InstancePinSharedPtrIterator modInstSourcesIter =
00321 modInstSourcePinPtrVector.begin();
00322
00323 InstancePinSharedPtrIterator modInstSourcesEnd =
00324 modInstSourcePinPtrVector.end();
00325
00326
00327 while(modInstSourcesIter != modInstSourcesEnd) {
00328
00329
00330 designNetPtr->addSource(*modInstSourcesIter);
00331
00332 modInstSourcesIter++;
00333
00334 }
00335
00336
00337 modInstSourcePinPtrVector.clear();
00338
00339 InstancePinSharedPtrIterator designNetSinksIter = designNetPtr->sinksBegin();
00340
00341 InstancePinSharedPtrIterator designNetSinksEnd = designNetPtr->sinksEnd();
00342
00343
00344 while(designNetSinksIter != designNetSinksEnd) {
00345
00346
00347 InstancePinSharedPtr instPinPtr = *designNetSinksIter;
00348
00349 InstanceSharedPtr pinInstPtr = instPinPtr->getInstancePtr().lock();
00350
00351
00352 if((std::find(modHostedInstPtrConstBegin, modHostedInstPtrConstEnd,
00353 pinInstPtr)) != modHostedInstPtrConstEnd) {
00354
00355
00356 string portName = sanitizePinName(designNetPtr->getName())
00357 + sPortIndexSeparator + boost::lexical_cast<std::string>(
00358 portIndex++);
00359
00360 PortSharedPtr portPtr = Factory::newPortPtr(portName, *(std::find(
00361 modHostedInstPtrConstBegin, modHostedInstPtrConstEnd,
00362 pinInstPtr)), instPinPtr->getPinName());
00363
00364 moduleDefinition->addPort(portPtr);
00365
00366 modInstSinkPinPtrVector.push_back(Factory::newInstancePinPtr(
00367 moduleInst, portName));
00368
00369 designNetPtr->removeSink(instPinPtr);
00370
00371 designNetSinksEnd = designNetPtr->sinksEnd();
00372
00373 } else {
00374
00375
00376 designNetSinksIter++;
00377
00378 }
00379 }
00380
00381
00382 InstancePinSharedPtrIterator modInstSinksIter =
00383 modInstSinkPinPtrVector.begin();
00384
00385 InstancePinSharedPtrIterator modInstSinksEnd =
00386 modInstSinkPinPtrVector.end();
00387
00388
00389 while(modInstSinksIter != modInstSinksEnd) {
00390
00391
00392 designNetPtr->addSink(*modInstSinksIter);
00393
00394 modInstSinksIter++;
00395
00396 }
00397
00398
00399 modInstSinkPinPtrVector.clear();
00400
00401
00402 designNetsIter++;
00403
00404 }
00405 }
00406
00407
00408
00409 mDesignPtr->addModule(moduleDefinition);
00410
00411 mDesignPtr->addInstance(moduleInst);
00412
00413
00414 return true;
00415 }
00416
00417
00418
00419
00420
00421
00422
00423
00424
00425
00426
00427
00428
00429
00430
00431
00432
00433
00434
00435
00436
00437
00438
00439
00440
00441
00442
00443
00444
00445
00446
00447
00448
00449
00450
00451
00452
00453
00454
00455
00456
00457
00458
00459
00460
00461
00462
00463
00464
00465
00466
00467
00468
00469
00470
00471
00472
00473
00474
00475
00476
00477
00478
00479
00480
00481 bool flatten(const string& inModuleInstanceName, bool inKeepPlacement = false,
00482 bool inKeepRouting = false) {
00483
00484
00485 InstancePinSharedPtrVector flattenedModuleSourcePinPtrVector;
00486
00487 InstancePinSharedPtrVector flattenedModuleSinkPinPtrVector;
00488
00489 InstanceSharedPtrConstIterator designModInstPtrConstIter
00490 = mDesignPtr->findInstance(inModuleInstanceName);
00491
00492
00493 if(designModInstPtrConstIter == mDesignPtr->instancesEnd()) {
00494
00495
00496 std::clog << "WARNING: Module instance of name " << inModuleInstanceName
00497 << " was not found in design " << mDesignPtr->getName() << "." << std::endl;
00498
00499
00500 return false;
00501
00502 }
00503
00504
00505 InstanceSharedPtr instPtr = *designModInstPtrConstIter;
00506
00507 ModuleSharedPtrIterator designModPtrConstIter
00508 = mDesignPtr->findModule(instPtr->getType());
00509
00510
00511 if(designModPtrConstIter == mDesignPtr->modulesEnd()) {
00512
00513
00514 std::clog << "WARNING: Module of name " << instPtr->getType()
00515 << " was not found in design " << mDesignPtr->getName() << "." << std::endl;
00516
00517
00518 return false;
00519
00520 }
00521
00522
00523 ModuleSharedPtr module = *designModPtrConstIter;
00524
00525
00526
00527
00528 InstanceSharedPtrIterator moduleAnchorInstIterator
00529 = module->findInstance(module->getAnchor());
00530 InstanceSharedPtr moduleAnchorInst = *moduleAnchorInstIterator;
00531
00532
00533 InstanceSharedPtrIterator moduleInstancesIter = module->instancesBegin();
00534
00535 InstanceSharedPtrIterator moduleInstancesEnd = module->instancesEnd();
00536
00537
00538 while(moduleInstancesIter != moduleInstancesEnd) {
00539
00540
00541 InstanceSharedPtr modInstPtr = *moduleInstancesIter;
00542
00543 InstanceSharedPtr modInstPtrClone = cloneInstance(modInstPtr,
00544 inModuleInstanceName + sHierarchySeparator + modInstPtr->getName());
00545
00546 modInstPtrClone->setInstanceReferencePtr(Factory::newInstanceReferencePtr(
00547 inModuleInstanceName, module, modInstPtr));
00548
00549
00550 if(!inKeepPlacement) modInstPtrClone->unplace();
00551
00552
00553 mDesignPtr->addInstance(modInstPtrClone);
00554
00555
00556 moduleInstancesIter++;
00557
00558 }
00559
00560
00561
00562
00563 NetSharedPtrIterator moduleNetsIter = module->netsBegin();
00564
00565 NetSharedPtrIterator moduleNetsEnd = module->netsEnd();
00566
00567
00568 while(moduleNetsIter != moduleNetsEnd) {
00569
00570
00571 NetSharedPtr moduleNetPtr = *moduleNetsIter;
00572
00573 NetSharedPtr moduleNetPtrClone = cloneNet(moduleNetPtr, inModuleInstanceName
00574 + sHierarchySeparator + moduleNetPtr->getName(), inModuleInstanceName);
00575
00576
00577 if(!inKeepRouting) moduleNetPtrClone->unroute();
00578
00579
00580 mDesignPtr->addNet(moduleNetPtrClone);
00581
00582 moduleNetsIter++;
00583
00584 }
00585
00586
00587
00588 NetSharedPtrIterator designNetsIter = mDesignPtr->netsBegin();
00589
00590 NetSharedPtrIterator designNetsEnd = mDesignPtr->netsEnd();
00591
00592
00593 while(designNetsIter != designNetsEnd) {
00594
00595
00596 NetSharedPtr designNetPtr = *designNetsIter;
00597
00598
00599 InstancePinSharedPtrIterator designNetSourcesIter = designNetPtr->sourcesBegin();
00600
00601 InstancePinSharedPtrIterator designNetSourcesEnd = designNetPtr->sourcesEnd();
00602
00603
00604 while(designNetSourcesIter != designNetSourcesEnd) {
00605
00606
00607 InstancePinSharedPtr instPinPtr = *designNetSourcesIter;
00608
00609 InstanceSharedPtr pinInstPtr = instPinPtr->getInstancePtr().lock();
00610
00611
00612 if(pinInstPtr == instPtr) {
00613
00614
00615 if(!inKeepRouting) designNetPtr->unroute();
00616
00617
00618 PortSharedPtrConstIterator modulePortConstIter
00619 = module->findPort(instPinPtr->getPinName());
00620
00621
00622 if(modulePortConstIter != module->portsEnd()) {
00623
00624
00625 PortSharedPtr modPortPtr = *modulePortConstIter;
00626
00627 InstanceSharedPtr portInstPtr = modPortPtr->getInstancePtr().lock();
00628
00629 InstanceSharedPtrIterator pinInstPtrCloneItr
00630 = mDesignPtr->findInstance(inModuleInstanceName
00631 + sHierarchySeparator + portInstPtr->getName());
00632
00633 flattenedModuleSourcePinPtrVector.push_back(
00634 Factory::newInstancePinPtr(*pinInstPtrCloneItr,
00635 modPortPtr->getPinName()));
00636
00637 designNetPtr->removeSource(instPinPtr);
00638
00639 designNetSourcesEnd = designNetPtr->sourcesEnd();
00640
00641 }
00642
00643 } else {
00644
00645
00646 designNetSourcesIter++;
00647
00648 }
00649 }
00650
00651
00652 InstancePinSharedPtrIterator flattenedModuleSourcesIter
00653 = flattenedModuleSourcePinPtrVector.begin();
00654
00655 InstancePinSharedPtrIterator flattenedModuleSourcesEnd
00656 = flattenedModuleSourcePinPtrVector.end();
00657
00658
00659 while(flattenedModuleSourcesIter != flattenedModuleSourcesEnd) {
00660
00661
00662 designNetPtr->addSource(*flattenedModuleSourcesIter);
00663
00664 flattenedModuleSourcesIter++;
00665 }
00666
00667
00668 flattenedModuleSourcePinPtrVector.clear();
00669
00670 InstancePinSharedPtrIterator designNetSinksIter = designNetPtr->sinksBegin();
00671
00672 InstancePinSharedPtrIterator designNetSinksEnd = designNetPtr->sinksEnd();
00673
00674
00675 while(designNetSinksIter != designNetSinksEnd) {
00676
00677
00678 InstancePinSharedPtr instPinPtr = *designNetSinksIter;
00679
00680 InstanceSharedPtr pinInstPtr = instPinPtr->getInstancePtr().lock();
00681
00682
00683 if(pinInstPtr == instPtr) {
00684
00685
00686 if(!inKeepRouting) designNetPtr->unroute();
00687
00688
00689 PortSharedPtrConstIterator modulePortConstIter
00690 = module->findPort(instPinPtr->getPinName());
00691
00692
00693 if(modulePortConstIter != module->portsEnd()) {
00694
00695
00696 PortSharedPtr modPortPtr = *modulePortConstIter;
00697
00698 InstanceSharedPtr portInstPtr = modPortPtr->getInstancePtr().lock();
00699
00700 InstanceSharedPtrIterator pinInstPtrCloneItr
00701 = mDesignPtr->findInstance(inModuleInstanceName
00702 + sHierarchySeparator + portInstPtr->getName());
00703
00704 flattenedModuleSinkPinPtrVector.push_back(
00705 Factory::newInstancePinPtr(*pinInstPtrCloneItr,
00706 modPortPtr->getPinName()));
00707
00708 designNetPtr->removeSink(instPinPtr);
00709
00710 designNetSinksEnd = designNetPtr->sinksEnd();
00711 }
00712
00713 } else {
00714
00715
00716 designNetSinksIter++;
00717
00718 }
00719 }
00720
00721
00722 InstancePinSharedPtrIterator flattenedModuleSinksBegin
00723 = flattenedModuleSinkPinPtrVector.begin();
00724
00725 InstancePinSharedPtrIterator flattenedModuleSinksEnd
00726 = flattenedModuleSinkPinPtrVector.end();
00727
00728
00729 while(flattenedModuleSinksBegin != flattenedModuleSinksEnd) {
00730
00731
00732 designNetPtr->addSink(*flattenedModuleSinksBegin);
00733
00734 flattenedModuleSinksBegin++;
00735
00736 }
00737
00738
00739 flattenedModuleSinkPinPtrVector.clear();
00740
00741
00742 designNetsIter++;
00743
00744 }
00745
00746
00747
00748 mDesignPtr->removeInstance(instPtr);
00749
00750
00751 return true;
00752 }
00753
00754 private:
00755
00756
00757
00758
00759
00760 ENetConnectivity getNetConnectivity(
00761 InstanceSharedPtrConstIterator inInstanceSharedPtrConstBegin,
00762 InstanceSharedPtrConstIterator inInstanceSharedPtrConstEnd, NetSharedPtr inNetPtr) {
00763
00764
00765 ENetConnectivity netConnectivity = eNetConnectivityNotConnected;
00766
00767 bool isNetConnectedToModule = false;
00768
00769 bool isNetInterToModule = false;
00770
00771 InstancePinSharedPtrIterator sourcesBegin = inNetPtr->sourcesBegin();
00772
00773 InstancePinSharedPtrIterator sourcesEnd = inNetPtr->sourcesEnd();
00774
00775
00776 while(sourcesBegin != sourcesEnd) {
00777
00778
00779 InstancePinSharedPtr instPinPtr = *sourcesBegin;
00780
00781 InstanceSharedPtr pinInst = instPinPtr->getInstancePtr().lock();
00782
00783
00784 if((std::find(inInstanceSharedPtrConstBegin, inInstanceSharedPtrConstEnd, pinInst))
00785 != inInstanceSharedPtrConstEnd) {
00786
00787
00788 isNetConnectedToModule = true;
00789
00790 } else {
00791
00792
00793 isNetInterToModule = true;
00794
00795 }
00796
00797
00798 sourcesBegin++;
00799 }
00800
00801
00802 InstancePinSharedPtrIterator sinksBegin = inNetPtr->sinksBegin();
00803
00804 InstancePinSharedPtrIterator sinksEnd = inNetPtr->sinksEnd();
00805
00806
00807 while(sinksBegin != sinksEnd) {
00808
00809
00810 InstancePinSharedPtr instPinPtr = *sinksBegin;
00811
00812 InstanceSharedPtr pinInst = instPinPtr->getInstancePtr().lock();
00813
00814 if((std::find(inInstanceSharedPtrConstBegin, inInstanceSharedPtrConstEnd, pinInst))
00815 != inInstanceSharedPtrConstEnd) {
00816
00817 isNetConnectedToModule = true;
00818 } else {
00819
00820 isNetInterToModule = true;
00821 }
00822
00823 sinksBegin++;
00824 }
00825
00826 if(isNetConnectedToModule) {
00827 if(isNetInterToModule) {
00828 netConnectivity = eNetConnectivityExternal;
00829 } else {
00830 netConnectivity = eNetConnectivityInternal;
00831 }
00832 }
00833
00834
00835 return netConnectivity;
00836 }
00837
00838
00839
00840 string sanitizePinName(string inPinName) {
00841
00842
00843 string sanitizedPinName;
00844
00845
00846 for(u_int32_t i = 0; i < inPinName.length(); i++) {
00847
00848
00849 if(boost::regex_match(inPinName.substr(i, 1), sValidPinNameCharactersRegEx)) {
00850 sanitizedPinName += inPinName.substr(i, 1);
00851 }
00852 }
00853
00854
00855 while(sanitizedPinName.size() > 0 && boost::regex_match(sanitizedPinName.substr(0, 1),
00856 sInvalidPinNameFirstCharactersRegEx)) {
00857
00858
00859 sanitizedPinName = sanitizedPinName.substr(1, sanitizedPinName.size() - 1);
00860
00861 }
00862
00863
00864 return sanitizedPinName;
00865 }
00866
00867
00868
00869
00870
00871
00872 InstanceSharedPtr cloneInstance(InstanceSharedPtr inIntancePtr,
00873 const string& inCloneInstanceName) {
00874
00875
00876 InstanceSharedPtr inInstanceClonePtr = Factory::newInstancePtr(inCloneInstanceName,
00877 inIntancePtr->getType(), inIntancePtr->getTile(), inIntancePtr->getSite(),
00878 inIntancePtr->getBonding());
00879
00880
00881
00882 ConfigMap::const_iterator instanceConfigBegin = inIntancePtr->configBegin();
00883
00884 ConfigMap::const_iterator instanceConfigEnd = inIntancePtr->configEnd();
00885
00886 ConfigMap configMap;
00887
00888
00889 while(instanceConfigBegin != instanceConfigEnd) {
00890
00891
00892 const string setting = instanceConfigBegin->first;
00893
00894 const Config config = instanceConfigBegin->second;
00895
00896 configMap.setConfig(setting, config);
00897
00898 instanceConfigBegin++;
00899
00900 }
00901
00902
00903 inInstanceClonePtr->addConfigs(configMap);
00904
00905
00906
00907 return inInstanceClonePtr;
00908 }
00909
00910
00911
00912
00913
00914
00915
00916 NetSharedPtr cloneNet(NetSharedPtr inNetPtr, const string& inNetCloneName,
00917 const string& inModuleInstanceName) {
00918
00919
00920 NetSharedPtr inNetClonePtr = Factory::newNetPtr(inNetCloneName, inNetPtr->getNetType());
00921
00922
00923
00924 ConfigMap::const_iterator netConfigBegin = inNetPtr->configBegin();
00925
00926 ConfigMap::const_iterator netConfigEnd = inNetPtr->configEnd();
00927
00928 ConfigMap configMap;
00929
00930
00931 while(netConfigBegin != netConfigEnd) {
00932
00933
00934 const string setting = netConfigBegin->first;
00935
00936 const Config config = netConfigBegin->second;
00937
00938 configMap.setConfig(setting, config);
00939
00940 netConfigBegin++;
00941
00942 }
00943
00944
00945 inNetClonePtr->addConfigs(configMap);
00946
00947
00948
00949
00950 InstancePinSharedPtrConstIterator inNetSourcesBegin = inNetPtr->sourcesBegin();
00951
00952 InstancePinSharedPtrConstIterator inNetSourcesEnd = inNetPtr->sourcesEnd();
00953
00954
00955 while(inNetSourcesBegin != inNetSourcesEnd) {
00956
00957
00958 InstancePinSharedPtr instPinPtr = *inNetSourcesBegin;
00959
00960 InstanceSharedPtr pinInstPtr = instPinPtr->getInstancePtr().lock();
00961
00962 InstanceSharedPtrIterator pinInstPtrCloneItr = mDesignPtr->findInstance(
00963 inModuleInstanceName + sHierarchySeparator + pinInstPtr->getName());
00964
00965 InstancePinSharedPtr instPinPtrClone
00966 = Factory::newInstancePinPtr(*pinInstPtrCloneItr, instPinPtr->getPinName());
00967
00968 inNetClonePtr->addSource(instPinPtrClone);
00969
00970 inNetSourcesBegin++;
00971
00972 }
00973
00974
00975
00976
00977 InstancePinSharedPtrConstIterator inNetSinksBegin = inNetPtr->sinksBegin();
00978
00979 InstancePinSharedPtrConstIterator inNetSinksEnd = inNetPtr->sinksEnd();
00980
00981
00982 while(inNetSinksBegin != inNetSinksEnd) {
00983
00984
00985 InstancePinSharedPtr instPinPtr = *inNetSinksBegin;
00986
00987 InstanceSharedPtr pinInstPtr = instPinPtr->getInstancePtr().lock();
00988
00989 InstanceSharedPtrIterator pinInstPtrCloneItr = mDesignPtr->findInstance(
00990 inModuleInstanceName + sHierarchySeparator + pinInstPtr->getName());
00991
00992 InstancePinSharedPtr instPinPtrClone
00993 = Factory::newInstancePinPtr(*pinInstPtrCloneItr, instPinPtr->getPinName());
00994
00995 inNetClonePtr->addSink(instPinPtrClone);
00996
00997 inNetSinksBegin++;
00998
00999 }
01000
01001
01002
01003
01004 PipConstIterator inNetPipsBegin = inNetPtr->pipsBegin();
01005
01006 PipConstIterator inNetPipsEnd = inNetPtr->pipsEnd();
01007
01008
01009 while(inNetPipsBegin != inNetPipsEnd) {
01010
01011
01012 Pip pipPtr = *inNetPipsBegin;
01013
01014
01015 Pip pipClone = Factory::newPip(pipPtr.getTileName(), pipPtr.getSourceWireName(),
01016 pipPtr.getSinkWireName(), pipPtr.getDirection());
01017
01018 inNetClonePtr->addPip(pipClone);
01019
01020 inNetPipsBegin++;
01021
01022 }
01023
01024
01025
01026 return inNetClonePtr;
01027 }
01028 };
01029
01030 }
01031 }
01032
01033 #endif // TORC_PHYSICAL_MODULETRANSFORMER_HPP