blob: 8bf30822f6a1669d4b580a675f012ec19a42d770 [file] [log] [blame]
AppaRao Pulic532f552019-07-05 15:23:50 +05301/*
2// Copyright (c) 2019 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#pragma once
17
18#include <string>
19
20namespace intel
21{
22namespace pfr
23{
24
25enum class ImageType
26{
Vikram Bodireddy3c6c8c32019-12-05 11:06:15 +053027 cpldActive,
28 cpldRecovery,
AppaRao Pulic532f552019-07-05 15:23:50 +053029 biosActive,
30 biosRecovery,
31 bmcActive,
32 bmcRecovery
33};
34
AppaRao Puli88aa33b2019-07-18 23:49:55 +053035enum class ActionType
36{
37 recoveryCount,
38 recoveryReason,
39 panicCount,
40 panicReason,
41 majorError,
42 minorError
43};
44
AppaRao Pulidbe184d2019-10-09 18:04:22 +053045std::string toHexString(const uint8_t val);
AppaRao Puli4b639a22019-10-01 18:12:59 +053046std::string getFirmwareVersion(const ImageType &imgType);
AppaRao Pulic532f552019-07-05 15:23:50 +053047int getProvisioningStatus(bool &ufmLocked, bool &ufmProvisioned);
AppaRao Pulidbe184d2019-10-09 18:04:22 +053048int readCpldReg(const ActionType &action, uint8_t &value);
AppaRao Puli46cead92019-07-22 16:50:09 +053049int setBMCBootCheckpoint(const uint8_t checkPoint);
AppaRao Pulic532f552019-07-05 15:23:50 +053050
51} // namespace pfr
52} // namespace intel