blob: 704d590511d51fc4a0129c5edf27956fb1d5e0e3 [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 Puli67d184c2020-05-29 00:48:33 +053046std::string getFirmwareVersion(const ImageType& imgType);
47int getProvisioningStatus(bool& ufmLocked, bool& ufmProvisioned);
48int 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