/* XMRig * Copyright (c) 2018-2021 SChernykh * Copyright (c) 2016-2021 XMRig , * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #include "hw/msr/MsrItem.h" #include "3rdparty/rapidjson/document.h" #include xmrig::MsrItem::MsrItem(const rapidjson::Value &value) { if (!value.IsString()) { return; } auto kv = String(value.GetString()).split(':'); if (kv.size() < 2) { return; } m_reg = strtoul(kv[0], nullptr, 0); m_value = strtoull(kv[1], nullptr, 0); m_mask = (kv.size() > 2) ? strtoull(kv[2], nullptr, 0) : kNoMask; } rapidjson::Value xmrig::MsrItem::toJSON(rapidjson::Document &doc) const { return toString().toJSON(doc); } xmrig::String xmrig::MsrItem::toString() const { constexpr size_t size = 48; auto buf = new char[size](); if (m_mask != kNoMask) { snprintf(buf, size, "0x%" PRIx32 ":0x%" PRIx64 ":0x%" PRIx64, m_reg, m_value, m_mask); } else { snprintf(buf, size, "0x%" PRIx32 ":0x%" PRIx64, m_reg, m_value); } return buf; }