| /* |
| // Copyright (c) 2018 Intel Corporation |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| */ |
| |
| #include "cpu.hpp" |
| |
| #include <bitset> |
| #include <map> |
| |
| namespace phosphor |
| { |
| namespace smbios |
| { |
| |
| void Cpu::socket(const uint8_t positionNum, const uint8_t structLen, |
| uint8_t* dataIn) |
| { |
| std::string result = positionToString(positionNum, structLen, dataIn); |
| |
| processor::socket(result); |
| } |
| |
| void Cpu::family(const uint8_t value) |
| { |
| std::map<uint8_t, const char*>::const_iterator it = familyTable.find(value); |
| if (it == familyTable.end()) |
| { |
| processor::family("Unknown Processor Family"); |
| } |
| else |
| { |
| processor::family(it->second); |
| } |
| } |
| |
| void Cpu::manufacturer(const uint8_t positionNum, const uint8_t structLen, |
| uint8_t* dataIn) |
| { |
| std::string result = positionToString(positionNum, structLen, dataIn); |
| |
| asset::manufacturer(result); |
| } |
| |
| void Cpu::version(const uint8_t positionNum, const uint8_t structLen, |
| uint8_t* dataIn) |
| { |
| std::string result; |
| |
| result = positionToString(positionNum, structLen, dataIn); |
| |
| rev::version(result); |
| } |
| |
| void Cpu::characteristics(uint16_t value) |
| { |
| std::vector<processor::Capability> result; |
| std::optional<processor::Capability> cap; |
| |
| std::bitset<16> charBits = value; |
| for (uint8_t index = 0; index < charBits.size(); index++) |
| { |
| if (charBits.test(index)) |
| { |
| if (cap = characteristicsTable[index]) |
| { |
| result.emplace_back(*cap); |
| } |
| } |
| } |
| |
| processor::characteristics(result); |
| } |
| |
| static constexpr uint8_t maxOldVersionCount = 0xff; |
| void Cpu::infoUpdate(void) |
| { |
| uint8_t* dataIn = storage; |
| |
| dataIn = getSMBIOSTypePtr(dataIn, processorsType); |
| if (dataIn == nullptr) |
| { |
| return; |
| } |
| |
| for (uint8_t index = 0; index < cpuNum; index++) |
| { |
| dataIn = smbiosNextPtr(dataIn); |
| if (dataIn == nullptr) |
| { |
| return; |
| } |
| dataIn = getSMBIOSTypePtr(dataIn, processorsType); |
| if (dataIn == nullptr) |
| { |
| return; |
| } |
| } |
| |
| auto cpuInfo = reinterpret_cast<struct ProcessorInfo*>(dataIn); |
| |
| socket(cpuInfo->socketDesignation, cpuInfo->length, |
| dataIn); // offset 4h |
| // this class is for type CPU //offset 5h |
| family(cpuInfo->family); // offset 6h |
| manufacturer(cpuInfo->manufacturer, cpuInfo->length, |
| dataIn); // offset 7h |
| id(cpuInfo->id); // offset 8h |
| version(cpuInfo->version, cpuInfo->length, dataIn); // offset 10h |
| maxSpeedInMhz(cpuInfo->maxSpeed); // offset 14h |
| if (cpuInfo->coreCount < maxOldVersionCount) // offset 23h or 2Ah |
| { |
| coreCount(cpuInfo->coreCount); |
| } |
| else |
| { |
| coreCount(cpuInfo->coreCount2); |
| } |
| |
| if (cpuInfo->threadCount < maxOldVersionCount) // offset 25h or 2Eh) |
| { |
| threadCount(cpuInfo->threadCount); |
| } |
| else |
| { |
| threadCount(cpuInfo->threadCount2); |
| } |
| |
| characteristics(cpuInfo->characteristics); // offset 26h |
| } |
| |
| } // namespace smbios |
| } // namespace phosphor |