blob: 27a7264a1f4a01b33617b398347aa51b7c723999 [file] [log] [blame]
Zhikui Ren18a5ab92020-09-01 21:35:20 -07001/*
2// Copyright (c) 2020 intel Corporation
3//
4// Licensed under the Apache License, Version 2.0 (the "License");
5// you may not use this file except in compliance with the License.
6// You may obtain a copy of the License at
7//
8// http://www.apache.org/licenses/LICENSE-2.0
9//
10// Unless required by applicable law or agreed to in writing, software
11// distributed under the License is distributed on an "AS IS" BASIS,
12// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13// See the License for the specific language governing permissions and
14// limitations under the License.
15*/
16
17#pragma once
18
19#include <sdbusplus/asio/object_server.hpp>
20#include <xyz/openbmc_project/Inventory/Decorator/Asset/server.hpp>
21
22namespace phosphor
23{
24namespace cpu_info
25{
26static constexpr char const* cpuInfoObject = "xyz.openbmc_project.CPUInfo";
27static constexpr char const* cpuInfoPath = "/xyz/openbmc_project/CPUInfo";
28static constexpr char const* cpuInfoInterface = "xyz.openbmc_project.CPUInfo";
Jonathan Doman94c94bf2020-10-05 23:25:45 -070029static constexpr const char* cpuPath =
30 "/xyz/openbmc_project/inventory/system/chassis/motherboard/cpu";
Zhikui Ren18a5ab92020-09-01 21:35:20 -070031
Zhikui Ren6d3ad582020-09-11 21:25:59 -070032static constexpr const int configCheckInterval = 10;
33static constexpr const int peciCheckInterval = 60;
Zhikui Ren18a5ab92020-09-01 21:35:20 -070034
35/** \ todo add cpu interface to CPUInfo and consolidate with smbios service
36 * using processor =
37 sdbusplus::xyz::openbmc_project::Inventory::Item::server::Cpu;
38*/
Zhikui Ren18a5ab92020-09-01 21:35:20 -070039
Zhikui Ren6d3ad582020-09-11 21:25:59 -070040// This will be expanded to CPUInfo object_server in a future patch
41struct CPUInfo
Zhikui Ren18a5ab92020-09-01 21:35:20 -070042{
Zhikui Ren6d3ad582020-09-11 21:25:59 -070043 CPUInfo(const size_t cpuId, const uint8_t peciAddress,
44 const uint8_t i2cBusNum, const uint8_t i2cSlaveAddress) :
45 id(cpuId),
46 peciAddr(peciAddress), i2cBus(i2cBusNum), i2cDevice(i2cSlaveAddress)
Zhikui Ren18a5ab92020-09-01 21:35:20 -070047 {}
48
Zhikui Ren6d3ad582020-09-11 21:25:59 -070049 uint8_t id;
50 uint8_t peciAddr;
51 uint8_t i2cBus;
52 uint8_t i2cDevice;
Zhikui Ren18a5ab92020-09-01 21:35:20 -070053};
54
55} // namespace cpu_info
56} // namespace phosphor