/* XMRig * Copyright (c) 2017-2019 XMR-Stak , * 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 . */ #ifndef XMRIG_BASICCPUINFO_H #define XMRIG_BASICCPUINFO_H #include "backend/cpu/interfaces/ICpuInfo.h" #include namespace xmrig { class BasicCpuInfo : public ICpuInfo { public: BasicCpuInfo(); protected: const char *backend() const override; CpuThreads threads(const Algorithm &algorithm, uint32_t limit) const override; rapidjson::Value toJSON(rapidjson::Document &doc) const override; inline Arch arch() const override { return m_arch; } inline Assembly::Id assembly() const override { return m_assembly; } inline bool has(Flag flag) const override { return m_flags.test(flag); } inline bool hasAES() const override { return has(FLAG_AES); } inline bool hasVAES() const override { return has(FLAG_VAES); } inline bool hasAVX() const override { return has(FLAG_AVX); } inline bool hasAVX2() const override { return has(FLAG_AVX2); } inline bool hasBMI2() const override { return has(FLAG_BMI2); } inline bool hasCatL3() const override { return has(FLAG_CAT_L3); } inline bool hasOneGbPages() const override { return has(FLAG_PDPE1GB); } inline bool hasXOP() const override { return has(FLAG_XOP); } inline bool isVM() const override { return has(FLAG_VM); } inline bool jccErratum() const override { return m_jccErratum; } inline const char *brand() const override { return m_brand; } inline const std::vector &units() const override { return m_units; } inline MsrMod msrMod() const override { return m_msrMod; } inline size_t cores() const override { return 0; } inline size_t L2() const override { return 0; } inline size_t L3() const override { return 0; } inline size_t nodes() const override { return 0; } inline size_t packages() const override { return 1; } inline size_t threads() const override { return m_threads; } inline Vendor vendor() const override { return m_vendor; } inline uint32_t model() const override { # ifndef XMRIG_ARM return m_model; # else return 0; # endif } protected: Arch m_arch = ARCH_UNKNOWN; bool m_jccErratum = false; char m_brand[64 + 6]{}; size_t m_threads; std::vector m_units; Vendor m_vendor = VENDOR_UNKNOWN; private: # ifndef XMRIG_ARM uint32_t m_procInfo = 0; uint32_t m_family = 0; uint32_t m_model = 0; uint32_t m_stepping = 0; # endif Assembly m_assembly = Assembly::NONE; MsrMod m_msrMod = MSR_MOD_NONE; std::bitset m_flags; }; } /* namespace xmrig */ #endif /* XMRIG_BASICCPUINFO_H */