/* IBM_PROLOG_BEGIN_TAG */ /* This is an automatically generated prolog. */ /* */ /* $Source: src/import/hwpf/fapi2/include/return_code.H $ */ /* */ /* OpenPOWER HostBoot Project */ /* */ /* Contributors Listed Below - COPYRIGHT 2015,2016 */ /* [+] International Business Machines Corp. */ /* */ /* */ /* Licensed under the Apache License, Version 2.0 (the "License"); */ /* you may not use this file except in compliance with the License. */ /* You may obtain a copy of the License at */ /* */ /* http://www.apache.org/licenses/LICENSE-2.0 */ /* */ /* Unless required by applicable law or agreed to in writing, software */ /* distributed under the License is distributed on an "AS IS" BASIS, */ /* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or */ /* implied. See the License for the specific language governing */ /* permissions and limitations under the License. */ /* */ /* IBM_PROLOG_END_TAG */ /** * @file return_code.H * @brief definitions for fapi2 return codes */ #ifndef __FAPI2_RETURN_CODE__ #define __FAPI2_RETURN_CODE__ #include #include #ifndef FAPI2_NO_FFDC #include #endif namespace fapi2 { /// /// @brief Class representing a FAPI2 ReturnCode /// // Remove the inheritance relationship with FirstFailureData if // the platform doesn't support FFDC. #if defined (FAPI2_NO_FFDC) || defined (MINIMUM_FFDC) class ReturnCode #else class ReturnCode : public FirstFailureData #endif { public: /// /// @brief Constructor. /// @param[in] i_rc the rc to set /// ReturnCode(const uint32_t i_rc = FAPI2_RC_SUCCESS): iv_rc(i_rc) {}; /// /// @brief integral type conversion function. Returns the error code /// @return The error code /// inline operator uint32_t() const { return iv_rc; } /// /// @brief integral type conversion function. Returns the error code /// @return The error code /// inline operator uint64_t() const { return iv_rc; } /// /// @brief Returns true iff iv_rc != SUCCESS /// @return true or false /// inline operator bool() const { return iv_rc != FAPI2_RC_SUCCESS; } /// /// @brief Assignement operator /// #ifdef DOXYGEN inline ReturnCode& operator=(const uint32_t& rhs); inline ReturnCode& operator=(const ReturnCodes& rhs); #endif inline bool operator==(const uint32_t& rhs) const { return rhs == iv_rc; } inline bool operator==(const ReturnCodes& rhs) const { return rhs == iv_rc; } inline bool operator!=(const uint32_t& rhs) const { return rhs != iv_rc; } inline bool operator!=(const ReturnCodes& rhs) const { return rhs != iv_rc; } /// /// @brief Enumeration of return code creators /// enum returnCodeCreator { CREATOR_FAPI = 1, CREATOR_PLAT = 2, CREATOR_HWP = 3, }; /// /// @brief Gets the creator of the return code /// @return ReturnCodeCreator /// inline returnCodeCreator getCreator(void) const { returnCodeCreator l_creator = CREATOR_HWP; if (iv_rc & FAPI2_RC_FAPI2_MASK) { l_creator = CREATOR_FAPI; } else if (iv_rc & FAPI2_RC_PLAT_MASK) { l_creator = CREATOR_PLAT; } return l_creator; } /// /// @brief explicit check for RC value /// @return true if this instance has a matching RC /// inline bool isRC(const ReturnCodes i_rc) const { return static_cast(i_rc) == iv_rc; } /// /// @brief explicit check for RC value /// @return true if this instance has a matching RC /// inline bool isRC(const uint32_t i_rc) const { return i_rc == iv_rc; } private: uint32_t iv_rc; }; /// This implementation assumes no exception handling and leverages thread-local /// storage. For platforms without thread support, a global variable will /// suffice for the error state. extern thread_local uint64_t pib_error_mask; /// the pib mask extern thread_local uint64_t operational_state; /// the operational mode #ifndef PLAT_NO_THREAD_LOCAL_STORAGE extern thread_local ReturnCode current_err; /// the current error state #else extern ReturnCode current_err; #endif } #endif