00001
00002
00003
00004
00005
00006
00007
00008 #include "otsdaq-core/ConfigurationDataFormats/RegisterBase.h"
00009 #include "otsdaq-core/ConfigurationDataFormats/RegisterConfigurationInfoReader.h"
00010 #include "otsdaq-core/ConfigurationDataFormats/RegisterSequencerInfoReader.h"
00011
00012 #include <algorithm>
00013
00014 using namespace ots;
00015
00016 RegisterBase::RegisterBase(std::string configurationName, std::string componentType) :
00017 ConfigurationBase(configurationName)
00018 ,componentTypeName_ (componentType)
00019 {
00020
00021 RegisterConfigurationInfoReader configurationInfoReader;
00022 configurationInfoReader.read(this);
00023
00024 RegisterSequencerInfoReader sequencerInfoReader;
00025 sequencerInfoReader.read(this);
00026
00027 init();
00028 }
00029
00030 RegisterBase::~RegisterBase() {
00031
00032 }
00033
00034 void RegisterBase::init(void)
00035 {
00036 theComponentList_.clear();
00037
00038
00039 for(auto it : *mockupRegisterView_.getRegistersSequencerInfoPointer())
00040 {
00041
00042
00043 theComponentList_.insert(std::make_pair(it.getComponentName(), Component(it.getComponentName())));
00044
00045 auto regs = theComponentList_.find(it.getComponentName())->second.getRegistersPointer();
00046 std::find_if(regs->begin(), regs->end(),[it](auto r){return r.getName() == it.getRegisterName();})->setState(it.getState(), it.getValueSequencePair());
00047
00048 }
00049
00050 for(auto aComponent : theComponentList_) {
00051
00052 for(auto registerFromConfiguration : *aComponent.second.getRegistersPointer())
00053 {
00054
00055 for(auto aRegister : *mockupRegisterView_.getRegistersInfoPointer())
00056 {
00057
00058 if(aRegister.getRegisterName() == registerFromConfiguration.getName()
00059
00060 ){
00061 registerFromConfiguration.fillRegisterInfo(aRegister.getBaseAddress(), aRegister.getSize(), aRegister.getAccess());
00062 }
00063 }
00064 }
00065 }
00066
00067
00068 for(auto aComponent : theComponentList_) {
00069 aComponent.second.printInfo();
00070 }
00071
00072
00073
00074
00075
00076
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 const RegisterView& RegisterBase::getRegisterView() const
00125 {
00126 return *activeRegisterView_;
00127 }
00128
00129
00130 RegisterView* RegisterBase::getRegisterViewPointer()
00131 {
00132 return activeRegisterView_;
00133 }
00134
00135
00136 RegisterView* RegisterBase::getMockupRegisterViewPointer()
00137 {
00138 return &mockupRegisterView_;
00139 }
00140
00141 std::string RegisterBase::getTypeName()
00142 {
00143 return componentTypeName_;
00144 }