Ignoring AVR8 registers that are not in the data address space

This commit is contained in:
Nav
2021-08-30 22:31:44 +01:00
parent 9d9f429fba
commit df1f3958c0
3 changed files with 11 additions and 1 deletions

View File

@@ -66,7 +66,7 @@ TargetDescriptionFile::TargetDescriptionFile(
matchingDescriptionFiles.begin(),
matchingDescriptionFiles.end(),
std::back_inserter(targetNames),
[](const QJsonValue& descriptionFile) {
[] (const QJsonValue& descriptionFile) {
return QString("\"" + descriptionFile.toObject().find("targetName")->toString().toLower() + "\"");
}
);
@@ -473,6 +473,11 @@ void TargetDescriptionFile::loadTargetRegisterDescriptors() {
auto& peripheralRegisterGroups = this->peripheralRegisterGroupsMappedByModuleRegisterGroupName
.at(registerGroupName);
for (const auto& peripheralRegisterGroup : peripheralRegisterGroups) {
if (peripheralRegisterGroup.addressSpaceId.value_or("") != "data") {
// Currently, we only deal with registers in the data address space.
continue;
}
for (const auto& [moduleRegisterName, moduleRegister] : registerGroup.registersMappedByName) {
if (moduleRegister.size < 1) {
continue;