summaryrefslogtreecommitdiff
path: root/utils/regtools/qeditor/backend.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'utils/regtools/qeditor/backend.cpp')
-rw-r--r--utils/regtools/qeditor/backend.cpp60
1 files changed, 38 insertions, 22 deletions
diff --git a/utils/regtools/qeditor/backend.cpp b/utils/regtools/qeditor/backend.cpp
index e47df8e3a4..c2db1f2a3e 100644
--- a/utils/regtools/qeditor/backend.cpp
+++ b/utils/regtools/qeditor/backend.cpp
@@ -107,23 +107,14 @@ IoBackend *Backend::CreateHWStubIoBackend(HWStubDevice *dev)
107#endif 107#endif
108 108
109/** 109/**
110 * FileIoBackend 110 * RamIoBackend
111 */ 111 */
112 112RamIoBackend::RamIoBackend(const QString& soc_name)
113FileIoBackend::FileIoBackend(const QString& filename, const QString& soc_name)
114{ 113{
115 m_filename = filename;
116 m_soc = soc_name; 114 m_soc = soc_name;
117 m_valid = false;
118 Reload();
119} 115}
120 116
121QString FileIoBackend::GetSocName() 117bool RamIoBackend::ReadRegister(const QString& name, soc_word_t& value)
122{
123 return m_soc;
124}
125
126bool FileIoBackend::ReadRegister(const QString& name, soc_word_t& value)
127{ 118{
128 if(m_map.find(name) == m_map.end()) 119 if(m_map.find(name) == m_map.end())
129 return false; 120 return false;
@@ -131,13 +122,45 @@ bool FileIoBackend::ReadRegister(const QString& name, soc_word_t& value)
131 return true; 122 return true;
132} 123}
133 124
125void RamIoBackend::DeleteAll()
126{
127 m_map.clear();
128}
129
130bool RamIoBackend::WriteRegister(const QString& name, soc_word_t value, WriteMode mode)
131{
132 switch(mode)
133 {
134 case Write: m_map[name] = value; return true;
135 case Set: m_map[name] |= value; return true;
136 case Clear: m_map[name] &= ~value; return true;
137 case Toggle: m_map[name] ^= value; return true;
138 default: return false;
139 }
140}
141
142
143
144/**
145 * FileIoBackend
146 */
147
148FileIoBackend::FileIoBackend(const QString& filename, const QString& soc_name)
149 :RamIoBackend(soc_name)
150{
151 m_filename = filename;
152 m_valid = false;
153 Reload();
154}
155
156
134bool FileIoBackend::Reload() 157bool FileIoBackend::Reload()
135{ 158{
136 m_valid = false; 159 m_valid = false;
137 QFile file(m_filename); 160 QFile file(m_filename);
138 if(!file.open(QIODevice::ReadOnly | QIODevice::Text)) 161 if(!file.open(QIODevice::ReadOnly | QIODevice::Text))
139 return false; 162 return false;
140 m_map.clear(); 163 DeleteAll();
141 164
142 QTextStream in(&file); 165 QTextStream in(&file);
143 while(!in.atEnd()) 166 while(!in.atEnd())
@@ -152,7 +175,7 @@ bool FileIoBackend::Reload()
152 if(key == "HW") 175 if(key == "HW")
153 m_soc = line.mid(idx + 1).trimmed(); 176 m_soc = line.mid(idx + 1).trimmed();
154 else if(ok) 177 else if(ok)
155 m_map[key] = val; 178 RamIoBackend::WriteRegister(key, val, Write);
156 } 179 }
157 180
158 m_readonly = !QFileInfo(file).isWritable(); 181 m_readonly = !QFileInfo(file).isWritable();
@@ -164,14 +187,7 @@ bool FileIoBackend::Reload()
164bool FileIoBackend::WriteRegister(const QString& name, soc_word_t value, WriteMode mode) 187bool FileIoBackend::WriteRegister(const QString& name, soc_word_t value, WriteMode mode)
165{ 188{
166 m_dirty = true; 189 m_dirty = true;
167 switch(mode) 190 return RamIoBackend::WriteRegister(name, value, mode);
168 {
169 case Write: m_map[name] = value; return true;
170 case Set: m_map[name] |= value; return true;
171 case Clear: m_map[name] &= ~value; return true;
172 case Toggle: m_map[name] ^= value; return true;
173 default: return false;
174 }
175} 191}
176 192
177bool FileIoBackend::Commit() 193bool FileIoBackend::Commit()