diff options
author | Shakeeb <shakeebbk@in.ibm.com> | 2016-09-01 06:24:44 -0500 |
---|---|---|
committer | AMIT J. TENDOLKAR <amit.tendolkar@in.ibm.com> | 2016-09-01 07:48:28 -0400 |
commit | 5e83bcb5cf9d400739cfb2beaab1a3173e8cafb2 (patch) | |
tree | b3d6cd12b5eb0c92404ae5ac0352bb360b38fa95 /import/hwpf | |
parent | 1008ef70a71fcfdec398ff30923d5025991c85f4 (diff) | |
download | talos-sbe-5e83bcb5cf9d400739cfb2beaab1a3173e8cafb2.tar.gz talos-sbe-5e83bcb5cf9d400739cfb2beaab1a3173e8cafb2.zip |
SBE move import`
Change-Id: I726951318cdb19fd445af2f7910e0d6872eff18c
Reviewed-on: http://ralgit01.raleigh.ibm.com/gerrit1/29086
Tested-by: Jenkins Server <pfd-jenkins+hostboot@us.ibm.com>
Reviewed-by: Sachin Gupta <sgupta2m@in.ibm.com>
Reviewed-by: AMIT J. TENDOLKAR <amit.tendolkar@in.ibm.com>
Diffstat (limited to 'import/hwpf')
37 files changed, 0 insertions, 9472 deletions
diff --git a/import/hwpf/fapi2/include/buffer.H b/import/hwpf/fapi2/include/buffer.H deleted file mode 100644 index 7661a9cd..00000000 --- a/import/hwpf/fapi2/include/buffer.H +++ /dev/null @@ -1,781 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/buffer.H $ */ -/* */ -/* OpenPOWER sbe 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 buffer.H - * @brief definitions for fapi2 variable integral buffers - */ - -#ifndef __FAPI2_INTEGRAL_BUFFER__ -#define __FAPI2_INTEGRAL_BUFFER__ - -#include <buffer_parameters.H> -#include <buffer_traits.H> -#include <plat_trace.H> -#include <return_code_defs.H> - -namespace fapi2 -{ -/// @brief Class representing a FAPI buffer<T> -/// @tparam T, the integral type of the buffer (uint16_t, uint64_t, etc.) -template <typename T, typename TT = bufferTraits<T> > -class buffer -{ - public: - /// Shortcut typedef to get to our traits class - typedef typename TT::bits_type bits_type; - - /// - /// @brief Integral buffer assignment constructor - /// @param[in] i_value initial value of the buffer - /// Meaningless for variable types and thus protected. - /// - inline buffer(T i_value = 0): - iv_data(i_value) - { - } - - ~buffer(void) = default; - -#if !defined(DOXYGEN) && defined(FAPI2_DEBUG) - /// @brief Print the contents of the buffer to stdout - inline void print(void) const - { - TT::print(iv_data); - } -#endif - - /// - /// @brief Get the contents of the buffer - /// @return The contents of the buffer - /// - inline operator T() const - { - return iv_data; - } - - /// - /// @brief Get the contents of the buffer - /// @return The contents of the buffer - /// - inline operator T& () - { - return iv_data; - } - - /// - /// @brief Get the contents of the buffer - /// @return The contents of the buffer - /// - inline T& operator()(void) - { - return iv_data; - } - - /// - /// @brief Get the contents of the buffer - /// @return Reference to the contents of the buffer - /// - inline const T& operator()(void) const - { - return iv_data; - } - - /// @name Buffer Manipulation Functions - ///@{ - - /// - /// @brief Set an OT of data in buffer - /// @param[in] i_value sizeof(OT) bits of data - /// @param[in] i_offset Start OT (start word, for example) in buffer - /// - defaults to 0 (will by default write the left most element) - /// @return FAPI2_RC_SUCCESS on success, FAPI2_RC_OVERFLOW otherwise - /// @note This is is only available for integral types. To set a - /// variable_buffer into a variable_buffer, use insert() - /// - template< typename OT> - inline fapi2::ReturnCodes set(OT i_value, const bits_type i_offset = 0) - { - // Compile time check to make sure OT is integral - static_assert( std::is_integral<OT>::value, - "Input must be an integral type" ); - - const uint32_t length = TT:: template size<OT>(iv_data); - static const bits_type bits_in_value = parameterTraits<OT>::bit_length(); - const bits_type bit_length = TT::bit_length(iv_data); - - if (i_offset + bits_in_value > bit_length) - { - return FAPI2_RC_OVERFLOW; - } - - // Create mask if part of this byte is not in the valid part of the buffer, - // Shift it left by the amount of unused bits, - // Clear the unused bits - if (((i_offset + 1) == length) && (bit_length % bits_in_value)) - { - i_value &= parameterTraits<OT>::mask() << ((bits_in_value * length) - - bit_length); - } - - parameterTraits<OT>::template write_element<typename TT::unit_type> - (TT::get_address(iv_data), i_value, i_offset); - return FAPI2_RC_SUCCESS; - } - - /// @name Bit/Word Manipulation Functions - ///@{ - - /// - /// @brief Return the length of the buffer in bits - /// @return Length in bits - /// - inline constexpr uint32_t getBitLength(void) const - { - return TT::bit_length(iv_data); - } - - /// - /// @brief Return the length of the buffer in OT units - /// @return Length in OT units rounded up - /// @tparam OT the type to get the length of. For example, if one - /// wanted the length in double words, OT would be uint64_t - /// (getLength<uint64_t>().) Similarly, to get the length in words, - /// getLength<uin32_t>(). - /// - template< typename OT > - inline constexpr uint32_t getLength(void) const - { - return TT::template size<OT>(iv_data); - } - - /// - /// @brief Templated setBit for integral types - /// @tparam B the bit number to set. - /// @tparam C the count of bits to set, defaults to 1 - /// @return buffer& Useful for method chaining - /// @note 0 is left-most - /// @note Example: fapi2::buffer<uint64_t>().setBit<3>(); - /// - template< bits_type B, bits_type C = 1 > - inline buffer & setBit(void) - { - static_assert((B >= 0) && - ((B + C - 1) < TT::bits_per_unit()), "failed range check"); - - // This would be a candidate for a fast_mask (see variable_buffer) but - // we'd need tables for all the integral types which maybe we need to - // do ... - iv_data |= (T(~0) >> (TT::bits_per_unit() - C)) << (TT::bits_per_unit() - B - - C); - return *this; - } - - /// - /// @brief Set a bit in the buffer - /// @param[in] i_bit the bit number to set. - /// @param[in] i_count the count of bits to set, defaults to 1 - /// @note 0 is left-most - /// @return FAPI2_RC_SUCCESS if OK - /// - inline fapi2::ReturnCodes setBit(const bits_type& i_bit, - const bits_type& i_count = 1) - { - if ((i_count + i_bit - 1) >= TT::bits_per_unit()) - { - return FAPI2_RC_INVALID_PARAMETER; - } - - iv_data |= (T(~0) >> (TT::bits_per_unit() - i_count)) << - (TT::bits_per_unit() - i_bit - i_count); - - return FAPI2_RC_SUCCESS; - } - - /// - /// @brief Clear a bit in buffer - /// @tparam B Bit in buffer to clear. - /// @tparam C the count of bits to clear, defaults to 1 - /// @return buffer& Useful for method chaining - /// @note Asserting that all the parameters are known at - /// compile time so this can be templated only. If that is not - /// the case we can add a function parameter version. - /// - template< bits_type B, bits_type C = 1> - inline buffer & clearBit(void) - { - static_assert((B >= 0) && - ((B + C - 1) < TT::bits_per_unit()), "failed range check"); - - iv_data &= buffer<T>().setBit<B, C>().invert(); - return *this; - } - - /// - /// @brief Clear a bit in the buffer - /// @param[in] i_bit the bit number to clear. - /// @param[in] i_count the count of bits to clear, defaults to 1 - /// @note 0 is left-most - /// @return FAPI2_RC_SUCCESS if OK - /// - inline fapi2::ReturnCodes clearBit(const bits_type& i_bit, - const bits_type& i_count = 1) - { - if ((i_count + i_bit - 1) >= TT::bits_per_unit()) - { - return FAPI2_RC_INVALID_PARAMETER; - } - - fapi2::buffer<T> l_scratch; - - if (l_scratch.setBit(i_bit, i_count) != FAPI2_RC_SUCCESS) - { - return FAPI2_RC_INVALID_PARAMETER; - } - - iv_data &= l_scratch.invert(); - - return FAPI2_RC_SUCCESS; - } - - /// - /// @brief Write a bit in buffer to a given value - /// @tparam B Bit in buffer to write - /// @tparam C the count of bits to write, defaults to 1 - /// @return buffer& Useful for method chaining - /// @note Asserting that all the parameters are known at - /// compile time so this can be templated only. If that is not - /// the case we can add a function parameter version. - /// - template< bits_type B, bits_type C = 1 > - inline buffer & writeBit(const bool i_value) - { - static_assert((B >= 0) && - ((B + C - 1) < TT::bits_per_unit()), "failed range check"); - - (i_value == 0) ? clearBit<B, C>() : setBit<B, C>(); - return *this; - } - - - /// - /// @brief Invert bit - /// @tparam B Bit in buffer to invert. - /// @tparam C the count of bits to flip, defaults to 1 - /// @return buffer& Useful for method chaining - /// @note Asserting that all the parameters are known at - /// compile time so this can be templated only. If that is not - /// the case we can add a function parameter version. - /// - template< bits_type B, bits_type C = 1 > - inline buffer & flipBit(void) - { - static_assert((B >= 0) && - ((B + C - 1) < TT::bits_per_unit()), "failed range check"); - - iv_data ^= buffer<T>().setBit<B, C>(); - return *this; - } - - /// - /// @brief Get the value of a bit in the buffer - /// @tparam B Bit in buffer to get. - /// @tparam C the count of bits to get, defaults to 1 - /// @return true if *any* bit is on, false if *every* bit is off - /// @note 0 is left-most - /// - template< bits_type B, bits_type C = 1> - inline bool getBit(void) const - { - return buffer<T>().setBit<B, C>() & iv_data; - } - - /// - /// @brief Get the value of a bit in the buffer - /// @param[in] i_bit the bit number to set. - /// @param[in] i_count the count of bits to set, defaults to 1 - /// @return true if *any* bit is on, false if *every* bit is off - /// @note 0 is left-most - /// - inline bool getBit(const bits_type& i_bit, - const bits_type& i_count = 1) - { - buffer<T> l_temp; - l_temp.setBit(i_bit, i_count); - return l_temp & iv_data; - } - - /// - /// @brief Set and entire buffer to X's - /// @tparam X {0,1} depending if you want to clear (0) - /// or fill (1) a buffer - /// @return buffer_base&, Useful for method chaining - /// - template< uint8_t X > - inline buffer& flush(void) - { - static_assert( (X == 1) || (X == 0), "bad argument to flush" ); - (0 == X) ? TT::clear(iv_data) : TT::set(iv_data); - return *this; - } - - /// - /// @brief Invert entire buffer - /// @return buffer_base&, Useful for method chaining - /// - inline buffer& invert(void) - { - TT::invert(iv_data); - return *this; - } - - /// - /// @brief Bit reverse entire buffer - /// @return buffer_base&, Useful for method chaining - /// - inline buffer& reverse(void) - { - TT::reverse(iv_data); - return *this; - } - - - ///@} - - /// @name Buffer Manipulation Functions - ///@{ - - /// - /// @brief Get a pointer to the buffer bits - /// @return Pointer to the buffer itself - /// - inline T* pointer(void) - { - return &iv_data; - } - - // Note: Many (all?) of these are not needed and the compiler complains - // as the cast to T yields a better operator. There are here mainly for - // documenation purposes. - - /// - /// @brief operator>>() - /// -#ifdef DOXYGEN - inline buffer<T>& operator>>(bits_type i_shiftnum); -#endif - - /// - /// @brief operator<<() - /// -#ifdef DOXYGEN - inline buffer<T>& operator<<(bits_type i_shiftnum); -#endif - - /// - /// @brief operator+() - /// -#ifdef DOXYGEN - inline buffer<T>& operator+(const T& rhs); -#endif - - /// - /// @brief operator+=() - /// -#ifdef DOXYGEN - inline buffer<T>& operator+=(const T& rhs); -#endif - - /// - /// @brief operator|=() - /// -#ifdef DOXYGEN - inline buffer<T>& operator|=(const T& rhs); -#endif - - /// - /// @brief operator&=() - /// -#ifdef DOXYGEN - inline buffer<T>& operator&=(const T& rhs); -#endif - - /// - /// @brief operator|() - /// -#ifdef DOXYGEN - inline buffer<T>& operator|(const T& rhs); -#endif - - /// - /// @brief operator&() - /// -#ifdef DOXYGEN - inline buffer<T>& operator&(const T& rhs); -#endif - - /// - /// @brief operator^=() - /// -#ifdef DOXYGEN - inline buffer<T>& operator^=(const T& rhs); -#endif - - /// - /// @brief operator~() - /// -#ifdef DOXYGEN - inline buffer<T>& operator~(const T& rhs) const; -#endif - - /// - /// @brief operator==() - /// -#ifdef DOXYGEN - inline bool operator==(const T& rhs) const; -#endif - - /// - /// @brief operator!=() - /// -#ifdef DOXYGEN - inline bool operator!=(const T& rhs) const; -#endif - - /// - /// @brief Copy part of a OT into the DataBuffer - /// @tparam TS Start bit to insert into (target start) - /// @tparam L Length of bits to insert - /// @tparam SS Start bit in source - defaults to bit 0 - /// @tparam OT the type of the incoming (origin) data - /// @param[in] i_datain OT value to copy into DataBuffer - /// - data is taken left aligned - /// @return buffer& Useful for method chaining - /// - template<bits_type TS, bits_type L, bits_type SS = 0, typename OT> - inline buffer & insert(const OT i_datain) - { - const bits_type target_length = parameterTraits<T>::bit_length(); - const bits_type source_length = parameterTraits<OT>::bit_length(); - - // Error if input data don't make sense - static_assert((TS + L) <= target_length, - "insert(): (Target Start + Len) is out of bounds"); - static_assert((SS + L) <= source_length, - "insert(): (Source Start + Len) is out of bounds"); - static_assert(TS < target_length, - "insert(): Target Start is out of bounds"); - static_assert(SS < source_length, - "insert(): Source Start is out of bounds"); - - // Normalize the input to 2 64 bit integers and adjust the starts accordingly - uint64_t source = static_cast<uint64_t>(i_datain); - const uint64_t target = static_cast<uint64_t>(iv_data); - - const bits_type source_start = parameterTraits<uint64_t>::bit_length() - - (source_length - SS); - const bits_type target_start = parameterTraits<uint64_t>::bit_length() - - (target_length - TS); - - // Get mask value for Target buffer - // Note: Need "& 0ULL" because bit shift left for Target buffer doesn't roll off - uint64_t mask = ((~0ULL << (parameterTraits<uint64_t>::bit_length() - L)) & ~0ULL) - >> target_start; - - // Align the source to the target. Make things signed so we know which way to shift. - int32_t shift = source_start - target_start; - - if (shift > 0) - { - source <<= shift; - } - else - { - shift = target_start - source_start; - source >>= shift; - } - - iv_data = ((target & ~mask) | (source & mask)); - return *this; - } - - /// - /// @brief Copy part of a OT into the DataBuffer - /// @tparam OT the type of the incoming (origin) data - /// @param[in] i_datain OT value to copy into DataBuffer - /// - data is taken left aligned - /// @param[in] i_targetStart bit to insert into (target start) - /// @param[in] i_len Length of bits to insert - /// @param[in] i_sourceStart Start bit in source - defaults to bit 0 - - /// @return FAPI2_RC_SUCCESS if successful - /// - template<typename OT> - fapi2::ReturnCodes insert(const OT i_datain, const bits_type i_targetStart, - const bits_type i_len, const bits_type i_sourceStart = 0) - { - const bits_type target_length = parameterTraits<T>::bit_length(); - const bits_type source_length = parameterTraits<OT>::bit_length(); - - // Error if input data don't make sense - if ((i_targetStart + i_len) > target_length) - { - FAPI_ERR("insert(): (Target Start + Len) is out of bounds"); - return FAPI2_RC_INVALID_PARAMETER; - } - - if ((i_sourceStart + i_len) > source_length) - { - FAPI_ERR("insert(): (Source Start + Len) is out of bounds"); - return FAPI2_RC_INVALID_PARAMETER; - } - - if (i_targetStart >= target_length) - { - FAPI_ERR("insert(): Target Start is out of bounds"); - return FAPI2_RC_INVALID_PARAMETER; - } - - if (i_sourceStart >= source_length) - { - FAPI_ERR("insert(): Source Start is out of bounds"); - return FAPI2_RC_INVALID_PARAMETER; - } - - // Normalize the input to 2 64 bit integers and adjust the starts accordingly - uint64_t source = static_cast<uint64_t>(i_datain); - const uint64_t target = static_cast<uint64_t>(iv_data); - - const bits_type source_start = parameterTraits<uint64_t>::bit_length() - - (source_length - i_sourceStart); - const bits_type target_start = parameterTraits<uint64_t>::bit_length() - - (target_length - i_targetStart); - - // Get mask value for Target buffer - // Note: Need "& 0ULL" because bit shift left for Target buffer doesn't roll off - uint64_t mask = ((~0ULL << (parameterTraits<uint64_t>::bit_length() - i_len)) & - ~0ULL) >> target_start; - - // Align the source to the target. Make things signed so we know which way to shift. - int32_t shift = source_start - target_start; - - if (shift > 0) - { - source <<= shift; - } - else - { - shift = target_start - source_start; - source >>= shift; - } - - iv_data = ((target & ~mask) | (source & mask)); - return FAPI2_RC_SUCCESS; - } - - /// - /// @brief Copy in a right aligned value - /// @tparam SB Start bit to insert into - /// @tparam L Length of bits to insert - /// @tparam OT the type of the incoming (origin) data - /// @param[in] i_datain OT value to copy into DataBuffer - /// - data is taken right aligned - /// @return buffer& Useful for method chaining - /// @note Data is assumed to be aligned on the word boundary of L - /// - template<bits_type TS, bits_type L, typename OT> - inline buffer& insertFromRight(const OT i_datain) - { - // Error if input data don't make sense - static_assert(L <= parameterTraits<OT>::bit_length(), - "insertFromRight(): Len > input buffer"); - static_assert(TS < parameterTraits<T>::bit_length(), - "insertFromRight(): Target Start is out of bounds"); - static_assert((TS + L) <= parameterTraits<T>::bit_length(), - "InsertFromRight(): (Target Start + Len) is out of bounds"); - - this->insert < TS, L, parameterTraits<OT>::bit_length() - L > (i_datain); - return *this; - } - - /// - /// @brief Copy in a right aligned value - /// @tparam OT the type of the incoming (origin) data - /// @param[in] i_datain OT value to copy into DataBuffer - /// - data is taken right aligned - /// @param[in] i_targetStart Start bit to insert into - /// @param[in] i_len Length of bits to insert - /// @return FAPi2_RC_SUCCESS if no error - /// @note Data is assumed to be aligned on the word boundary of L - /// - template<typename OT> - fapi2::ReturnCodes insertFromRight(const OT i_datain, - const bits_type i_targetStart, - const bits_type i_len) - { - // Error if input data don't make sense - if ((i_targetStart + i_len) > parameterTraits<T>::bit_length()) - { - FAPI_ERR("insertFromRight(): (Target Start + Len) is out of bounds"); - return FAPI2_RC_INVALID_PARAMETER; - } - - if (i_targetStart >= parameterTraits<T>::bit_length()) - { - FAPI_ERR("insertFromRight(): Target Start is out of bounds"); - return FAPI2_RC_INVALID_PARAMETER; - } - - if (i_len > parameterTraits<OT>::bit_length()) - { - FAPI_ERR("insertFromRight(): Len > input buffer"); - return FAPI2_RC_INVALID_PARAMETER; - } - - return this->insert(i_datain, i_targetStart, i_len, - parameterTraits<OT>::bit_length() - i_len); - } - - /// - /// @brief Copy data from this buffer into an OT - /// @tparam SS Start bit in source - /// @tparam L Length of bits to insert - /// @tparam TS Start bit to insert into (target start) - /// @tparam OT the type of the outgoing (target) - /// @param[out] o_out OT to copy into - data is placed left aligned - /// @return const buffer& Useful for method chaining - /// - template<bits_type SS, bits_type L, bits_type TS = 0, typename OT> - inline const buffer & extract(OT& o_out) const - { - // Extraction is just an insert into o_out - - buffer<OT> out(o_out); - out.insert<TS, L, SS>(iv_data); - o_out = out; - return *this; - } - - /// - /// @brief Copy data from this buffer into an OT - /// @tparam SS Start bit in source - /// @tparam L Length of bits to insert - /// @tparam TS Start bit to insert into (target start) - /// @tparam OT the type of the outgoing (target) - /// @param[out] o_out OT to copy into - data is placed left aligned - /// @return buffer& Useful for method chaining - /// - template<bits_type SS, bits_type L, bits_type TS = 0, typename OT> - inline buffer & extract(OT& o_out) - { - // Extraction is just an insert into o_out - - buffer<OT> out(o_out); - out.insert<TS, L, SS>(iv_data); - o_out = out; - return *this; - } - - /// - /// @brief Copy data from this buffer into an OT - /// @tparam OT the type of the outgoing (target) - /// @param[out] o_out OT to copy into - data is placed left aligned - /// @param[in] i_sourceStart Start bit in source - /// @param[in] i_len Length of bits to extract - /// @param[in] i_targetStart Start bit to insert into (target start) - /// @return FAPI2_RC_SUCCESS if ok - /// - template<typename OT> - fapi2::ReturnCodes extract(OT& o_out, const bits_type i_sourceStart, - const bits_type i_len, const bits_type i_targetStart = 0) const - { - // Extraction is just an insert into o_out - - buffer<OT> out(o_out); - - if (out.insert(iv_data, i_targetStart, i_len, - i_sourceStart) != FAPI2_RC_SUCCESS) - { - return FAPI2_RC_INVALID_PARAMETER; - } - - o_out = out; - return FAPI2_RC_SUCCESS; - } - - /// - /// @brief Copy data from this buffer into an OT and right justify - /// @tparam SS Start bit to insert into (source start) - /// @tparam L Length of bits to extract - /// @tparam OT the type of the outgoing (target) - /// @param[out] o_out OT to copy into - data is placed right aligned - /// @return const buffer& Useful for method chaining - /// - template<bits_type SS, bits_type L, typename OT> - inline const buffer& extractToRight(OT& o_out) const - { - extract < SS, L, parameterTraits<OT>::bit_length() - L > (o_out); - return *this; - } - - /// - /// @brief Copy data from this buffer into an OT and right justify - /// @tparam SS Start bit to insert into (source start) - /// @tparam L Length of bits to extract - /// @tparam OT the type of the outgoing (target) - /// @param[out] o_out OT to copy into - data is placed right aligned - /// @return buffer& Useful for method chaining - /// - template<bits_type SS, bits_type L, typename OT> - inline buffer& extractToRight(OT& o_out) - { - extract < SS, L, parameterTraits<OT>::bit_length() - L > (o_out); - return *this; - } - - /// - /// @brief Copy data from this buffer into an OT and right justify - /// @tparam OT the type of the outgoing (target) - /// @param[out] o_out OT to copy into - data is placed right aligned - /// @param[in] i_sourceStart Start bit to insert into (source start) - /// @param[in] i_len Length of bits to insert - /// @return FAPI2_RC_SUCCESS if ok - /// - template<typename OT> - fapi2::ReturnCodes extractToRight(OT& o_out, const bits_type i_sourceStart, - const bits_type i_len) const - { - return extract(o_out, i_sourceStart, i_len, - parameterTraits<OT>::bit_length() - i_len); - } - - ///@} - - private: - /// The contents of the buffer - T iv_data; -}; -} - -#endif diff --git a/import/hwpf/fapi2/include/buffer_parameters.H b/import/hwpf/fapi2/include/buffer_parameters.H deleted file mode 100644 index aea03c66..00000000 --- a/import/hwpf/fapi2/include/buffer_parameters.H +++ /dev/null @@ -1,76 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/buffer_parameters.H $ */ -/* */ -/* OpenPOWER sbe 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 buffer_parameters.H - * @brief definitions for fapi2 buffer parameter types - */ - -#ifndef __FAPI2_BUFFER_PARAM__ -#define __FAPI2_BUFFER_PARAM__ - -#include <stdint.h> - -namespace fapi2 -{ -/// @cond -/// @brief Traits of buffer parameters - things passed in -/// @tparam T is the type of i_value (typically an integral type) -template<typename T> -class parameterTraits -{ - public: - // Why constexpr functions? Enums are hard to do math on, and - // static const doesn't work without -O1 (or greater.) That might - // be a bug in g++ but this works just the same. - constexpr static T mask(void) - { - return T(~0); - } - - constexpr static uint32_t byte_length(void) - { - return sizeof(T); - } - - constexpr static uint32_t bit_length(void) - { - return sizeof(T) * 8; - } - - template<typename U> - inline static void write_element(void* i_data, T i_value, uint32_t i_offset) - { -#if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__ - T* ptr = (T*)i_data + (i_offset ^ ((sizeof(U) / sizeof(T)) - 1)); -#else - T* ptr = (T*)i_data + i_offset; -#endif - *ptr = i_value; - } -}; -/// @endcond -} - -#endif diff --git a/import/hwpf/fapi2/include/buffer_traits.H b/import/hwpf/fapi2/include/buffer_traits.H deleted file mode 100644 index b14df7ea..00000000 --- a/import/hwpf/fapi2/include/buffer_traits.H +++ /dev/null @@ -1,275 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/buffer_traits.H $ */ -/* */ -/* OpenPOWER sbe 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 buffer_traits.H - * @brief trait definitions for fapi2 buffer base class - */ - -#ifndef __FAPI2_BUFFER_TRAITS__ -#define __FAPI2_BUFFER_TRAITS__ - -#include <stdint.h> -#include <vector> -#include <algorithm> -#include <buffer_parameters.H> - -#ifdef FAPI2_DEBUG - #include <iostream> -#endif - -#include <iterator> - -namespace fapi2 -{ -/// @cond -/// Types representing a container of bits. Used to create -/// variable_buffer. container_unit must remain 32-bits -/// for now - there will be a lot of code to change if it -/// changes. There are assertions helping to enforce this -/// in places in the code. -typedef uint32_t container_unit; -typedef std::vector<container_unit> bits_container; - -/// @brief Traits of buffers -// In general, we try to give buffers traits reflecting integral types. If -// this fails, the compiler will let someone know. -/// -/// @tparam T is the type of iv_data (std::vector, etc) -/// @tparam B is the type of the bit-specifier, typically uint32_t -template<typename T, typename B = uint32_t> -class bufferTraits -{ - public: - -#if !defined(DOXYGEN) && defined(FAPI2_DEBUG) - /// - /// @brief Print a container of bits - /// @param[in] i_data the container of bits - /// - static inline void print(const T& i_data) - { - // convert to uint64_t to prevent uint8_t from being - // printed as a char. - std::cout << "\tdata is " - << std::hex - << static_cast<uint64_t>(i_data) - << std::dec << std::endl; - } -#endif - - /// - /// @brief Return the size of the buffer in E units - /// @tparam E, the element size. - /// @param[in] i_buffer the buffer which to size - /// @return The size of the buffer in E's rounded up - /// - template<typename E> - constexpr static B size(const T& i_buffer) - { - return (bit_length(i_buffer) + - (parameterTraits<E>::bit_length() - 1)) / - parameterTraits<E>::bit_length(); - } - - /// - /// @brief Return the size of the buffer itself - /// @param[in] i_buffer the buffer which to size - /// @return The size of the buffer in bits (not units) - /// - constexpr static B bit_length(const T&) - { - return sizeof(T) * 8; - } - - /// - /// @brief Clear the buffer - /// @param[in,out] io_buffer the buffer which to clear - /// - static inline void clear(T& io_buffer) - { - io_buffer = static_cast<T>(0); - } - - /// - /// @brief Set the buffer - /// @param[in,out] io_buffer the buffer which to set - /// - static inline void set(T& io_buffer) - { - io_buffer = static_cast<T>(~0); - } - - /// - /// @brief Invert the buffer - /// @param[in,out] io_buffer the buffer which to invert - /// - static inline void invert(T& io_buffer) - { - io_buffer = ~io_buffer; - } - - /// - /// @brief Reverse the buffer - /// @param[in,out] io_buffer the buffer which to reverse - // - // @note from - // http://stackoverflow.com/questions/746171/best-algorithm-for-bit-reversal-from-msb-lsb-to-lsb-msb-in-c - /// - static inline void reverse( T& io_buffer) - { - T l_result = io_buffer; - size_t l_s = sizeof(T) * 8 - 1; - - for( io_buffer >>= 1; io_buffer; io_buffer >>= 1) - { - l_result <<= 1; - l_result |= io_buffer & 1; - l_s--; - } - - l_result <<= l_s; - - io_buffer = l_result; - } - /// - /// @brief Get the address of the buffer as an array - /// @param[in] i_buffer the buffer which to invert - /// @return The address of the first element of the buffer - /// - static inline void* get_address(T& i_buffer) - { - return (void*)&i_buffer; - } - - typedef B bits_type; - typedef T unit_type; - constexpr static uint32_t bits_per_unit(void) - { - return sizeof(unit_type) * 8; - } -}; - -// -// -/// @brief Traits for buffers which are a container of bits -// -// -template<> -class bufferTraits<bits_container, uint32_t> -{ - public: -#if !defined(DOXYGEN) && defined(FAPI2_DEBUG) - /// - /// @brief Print a container of bits - /// @param[in] i_data the container of bits - /// - static inline void print(const bits_container& i_data) - { - std::cout << "\tdata is " << std::hex; - std::copy(i_data.begin(), i_data.end(), - std::ostream_iterator<container_unit>(std::cout, " ")); - std::cout << std::dec << std::endl; - } -#endif - - /// - /// @brief Return the size of the buffer in E units - /// @tparam E, the element size. - /// @param[in] i_buffer the buffer which to size - /// @return The size of the buffer in E's rounded up - /// - template<typename E> - constexpr static uint32_t size(const bits_container& i_buffer) - { - return (bit_length(i_buffer) + - (parameterTraits<E>::bit_length() - 1)) / - parameterTraits<E>::bit_length(); - } - - /// - /// @brief Return the size of the buffer itself - /// @param[in] i_buffer the buffer which to size - /// @return The size of the buffer in bits (not units) - /// - static inline uint32_t bit_length(const bits_container& i_buffer) - { - return i_buffer.size() * sizeof(container_unit) * 8; - } - - /// - /// @brief Clear the buffer - /// @param[in,out] io_buffer the buffer which to clear - /// - static inline void clear(bits_container& io_buffer) - { - io_buffer.assign(io_buffer.size(), 0); - } - - /// - /// @brief Set the buffer - /// @param[in,out] io_buffer the buffer which to set - /// - static inline void set(bits_container& io_buffer) - { - io_buffer.assign(io_buffer.size(), ~0); - } - - /// - /// @brief Invert the buffer - /// @param[in,out] io_buffer the buffer which to invert - /// - static inline void invert(bits_container& io_buffer) - { - std::transform(io_buffer.begin(), io_buffer.end(), - io_buffer.begin(), - [](container_unit u) - { - return ~u; - }); - } - - /// - /// @brief Get the address of the buffer as an array - /// @param[in] i_buffer the buffer which to invert - /// @return The address of the first element of the buffer - /// - static inline void* get_address(bits_container& i_buffer) - { - return (void*) & (i_buffer[0]); - } - - typedef uint32_t bits_type; - typedef container_unit unit_type; - constexpr static uint32_t bits_per_unit(void) - { - return sizeof(unit_type) * 8; - } -}; -/// @endcond -} - - - -#endif diff --git a/import/hwpf/fapi2/include/error_info.H b/import/hwpf/fapi2/include/error_info.H deleted file mode 100644 index 9f0e0419..00000000 --- a/import/hwpf/fapi2/include/error_info.H +++ /dev/null @@ -1,686 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/error_info.H $ */ -/* */ -/* OpenPOWER sbe 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 error_info.H -/// @brief Defines the Error Information structures and classes -/// - -#ifndef FAPI2_ERRORINFO_H_ -#define FAPI2_ERRORINFO_H_ - -#include <stdint.h> -#include <memory> -#include <vector> -#include <target.H> -#include <error_info_defs.H> - -namespace fapi2 -{ - -#if defined(MINIMUM_FFDC) && !defined(FAPI2_NO_FFDC) -// convert generic type to uint64_t -template<typename T> -inline uint64_t convertType( T& i_value ) -{ - // for simplicity sake, all FFDC chunks from the SBE - // are going to be sent as a uint64_t - return static_cast<uint64_t>(i_value); -}; - -// convert platform target handle to a uint64_t -template<fapi2::TargetType T> -inline uint64_t convertType( const fapi2::Target<T>& i_value) -{ - // send the target type and instance as ffdc they will be used - // to instantiate a target before logging the ffdc data - return static_cast<uint64_t>((static_cast<uint64_t>( - (i_value.get().getFapiTargetType())) << 32) | - i_value.get().getTargetInstance()); -}; -#endif - -#if !defined(FAPI2_NO_FFDC) && !defined(MINIMUM_FFDC) -// forward fapi2::Assert() -extern void Assert(bool); - -/// -/// @class ErrorInfoFfdc -/// -/// This class contains a copy of some FFDC data -/// -class ErrorInfoFfdc -{ - public: - /// - /// @brief Constructor - /// - /// @param[in] i_ffdcId FFDC Identifier (used to decode FFDC) - /// @param[in] i_pFfdc Pointer to the FFDC to copy - /// @param[in] i_size Size of the FFDC to copy - /// - ErrorInfoFfdc(const uint32_t i_ffdcId, - const void* i_pFfdc, - const uint32_t i_size); - - /// - /// @brief Get a pointer to the FfdcData - /// - /// @param[out] o_size Reference to uint32_t that is filled in with - /// the FFDC size - /// - /// @return void *. Pointer to the FFDC - /// - inline const void* getData(uint32_t& o_size) const - { - o_size = iv_size; - return iv_pFfdc.get(); - } - - /// - /// @brief Get a pointer to the FfdcData - /// @return void *. Pointer to the FFDC - /// - inline void* getData(void) const - { - return iv_pFfdc.get(); - } - - /// - /// @brief Get the FFDC Identifier - /// - /// @return uint32_t The FFDC Identifier - /// - inline uint32_t getFfdcId(void) - { - return iv_ffdcId; - } - -#ifdef FAPI_CUSTOM_MALLOC - /// - /// @brief Overload new operator to use platform-specific allocator - /// - /// @param[in] i_sz Size of memory to allocate in bytes - /// - /// @return Pointer to allocated memory - /// - static void* operator new(size_t i_sz); - - /// - /// @brief Overload delete operator to use platform-specific deallocator - /// - /// @param[in] i_ptr Pointer to memory previously allocated with new - /// - static void operator delete(void* i_ptr); -#endif - - private: - - // FFDC Identifier - uint32_t iv_ffdcId; - - // Pointer to the FFDC - std::shared_ptr<uint8_t> iv_pFfdc; - - // Size of the FFDC - uint32_t iv_size; - - // Disabled - ErrorInfoFfdc(const ErrorInfoFfdc&) = delete; - ErrorInfoFfdc& operator=(const ErrorInfoFfdc&) = delete; -}; - -/// -/// @struct ErrorInfoHwCallout -/// -/// This struct contains hardware to callout -/// -struct ErrorInfoHwCallout -{ - /// - /// @brief Constructor. - /// - /// @param[in] i_hw Hardware to callout - /// @param[in] i_calloutPriority Priority of callout - /// @param[in] i_refTarget Reference to reference target - /// - ErrorInfoHwCallout( - const HwCallouts::HwCallout i_hw, - const CalloutPriorities::CalloutPriority i_calloutPriority, - const Target<TARGET_TYPE_ALL>& i_refTarget); - -#ifdef FAPI_CUSTOM_MALLOC - /// - /// @brief Overload new operator to use platform-specific allocator - /// - /// @param[in] i_sz Size of memory to allocate in bytes - /// - /// @return Pointer to allocated memory - /// - static void* operator new(size_t i_sz); - - /// - /// @brief Overload delete operator to use platform-specific deallocator - /// - /// @param[in] i_ptr Pointer to memory previously allocated with new - /// - static void operator delete(void* i_ptr); -#endif - - // The hw to callout - HwCallouts::HwCallout iv_hw; - - // The callout priority - CalloutPriorities::CalloutPriority iv_calloutPriority; - - // The reference target (needed for some HW callouts to identify what to - // callout). The target handle is NULL if there is no reference target. - Target<TARGET_TYPE_ALL> iv_refTarget; -}; - -/// -/// @struct ErrorInfoProcedureCallout -/// -/// This struct contains a procedure to callout -/// -struct ErrorInfoProcedureCallout -{ - /// - /// @brief Constructor. - /// - /// @param[in] i_procedure Procedure to callout - /// @param[in] i_calloutPriority Priority of callout - /// - ErrorInfoProcedureCallout( - const ProcedureCallouts::ProcedureCallout i_procedure, - const CalloutPriorities::CalloutPriority i_calloutPriority); - -#ifdef FAPI_CUSTOM_MALLOC - /// - /// @brief Overload new operator to use platform-specific allocator - /// - /// @param[in] i_sz Size of memory to allocate in bytes - /// - /// @return Pointer to allocated memory - /// - static void* operator new(size_t i_sz); - - /// - /// @brief Overload delete operator to use platform-specific deallocator - /// - /// @param[in] i_ptr Pointer to memory previously allocated with new - /// - static void operator delete(void* i_ptr); -#endif - - // The procedure to callout - ProcedureCallouts::ProcedureCallout iv_procedure; - - // The callout priority - CalloutPriorities::CalloutPriority iv_calloutPriority; -}; - -/// -/// @struct ErrorInfoBusCallout -/// -/// This struct contains a bus to callout -/// -struct ErrorInfoBusCallout -{ - /// - /// @brief Constructor. - /// - /// @param[in] i_target1 Reference to target on one end of the bus - /// @param[in] i_target2 Reference to target on other end of the bus - /// @param[in] i_calloutPriority Priority of callout - /// - ErrorInfoBusCallout( - const Target<TARGET_TYPE_ALL>& i_target1, - const Target<TARGET_TYPE_ALL>& i_target2, - const CalloutPriorities::CalloutPriority i_calloutPriority); - -#ifdef FAPI_CUSTOM_MALLOC - /// - /// @brief Overload new operator to use platform-specific allocator - /// - /// @param[in] i_sz Size of memory to allocate in bytes - /// - /// @return Pointer to allocated memory - /// - static void* operator new(size_t i_sz); - - /// - /// @brief Overload delete operator to use platform-specific deallocator - /// - /// @param[in] i_ptr Pointer to memory previously allocated with new - /// - static void operator delete(void* i_ptr); -#endif - - // The targets on each end of the bus to callout - Target<TARGET_TYPE_ALL> iv_target1; - Target<TARGET_TYPE_ALL> iv_target2; - - // The callout priority - CalloutPriorities::CalloutPriority iv_calloutPriority; -}; - -/// -/// @struct ErrorInfoCDG -/// -/// This struct contains a target to callout/deconfigure/GARD -/// -struct ErrorInfoCDG -{ - /// - /// @brief Constructor. - /// - /// @param[in] i_target Reference to the target to c/d/g - /// @param[in] i_callout True if Target should be called out - /// @param[in] i_deconfigure True if Target should be deconfigured - /// @param[in] i_gard True if Target should be GARDed - /// @param[in] i_priority The priority of any callout - /// - ErrorInfoCDG(const Target<TARGET_TYPE_ALL>& i_target, - const bool i_callout, - const bool i_deconfigure, - const bool i_gard, - const CalloutPriorities::CalloutPriority i_priority); - -#ifdef FAPI_CUSTOM_MALLOC - /// - /// @brief Overload new operator to use platform-specific allocator - /// - /// @param[in] i_sz Size of memory to allocate in bytes - /// - /// @return Pointer to allocated memory - /// - static void* operator new(size_t i_sz); - - /// - /// @brief Overload delete operator to use platform-specific deallocator - /// - /// @param[in] i_ptr Pointer to memory previously allocated with new - /// - static void operator delete(void* i_ptr); -#endif - - // The target to callout/deconfigure/GARD - Target<TARGET_TYPE_ALL> iv_target; - - // Callout Information - bool iv_callout; - CalloutPriorities::CalloutPriority iv_calloutPriority; - - // Deconfigure Information - bool iv_deconfigure; - - // GARD Information - bool iv_gard; -}; - -/// -/// @struct ErrorInfoChildrenCDG -/// -/// This struct contains children targets to callout/deconfigure/GARD -/// -/// Children by containment can be CDG (chiplets belonging to a parent chip) -/// e.g. -/// - PROC_CHIP -> EX_CHIPLET -/// - MEMBUF_CHIP -> MBA_CHIPLET -/// Children by affinity can be CDG. -/// Any from PROC_CHIP->MCS_CHIPLET->MEMBUF_CHIP->MBA_CHIPLET->DIMM e.g. -/// - PROC_CHIP->MEMBUF_CHIP -/// - MEMBUF_CHIP->DIMM -/// - MBA_CHIPLET->DIMM -/// Port and Number criteria can be applied to the child target as -/// detailed in the constructor -/// -struct ErrorInfoChildrenCDG -{ - /// - /// @brief Constructor. - /// - /// @param[in] i_parentChip Reference to the parent target - /// @param[in] i_childType Child target type to c/d/g - /// @param[in] i_callout True if Target should be called out - /// @param[in] i_deconfigure True if Target should be deconfigured - /// @param[in] i_gard True if Target should be GARDed - /// @param[in] i_priority The priority of any callout - /// @param[in] i_childPort Child Port - /// For DIMM children, the MBA port number - /// @param[in] i_childNum Child Number - /// For DIMM children, the dimm socket number - /// For Chip children, the chip position - /// For Chiplet children, the chiplet unit pos - /// - ErrorInfoChildrenCDG(const Target<TARGET_TYPE_ALL>& i_parentChip, - const TargetType i_childType, - const bool i_callout, - const bool i_deconfigure, - const bool i_gard, - const CalloutPriorities::CalloutPriority i_priority, - const uint8_t i_childPort, const uint8_t i_childNum); - -#ifdef FAPI_CUSTOM_MALLOC - /// - /// @brief Overload new operator to use platform-specific allocator - /// - /// @param[in] i_sz Size of memory to allocate in bytes - /// - /// @return Pointer to allocated memory - /// - static void* operator new(size_t i_sz); - - /// - /// @brief Overload delete operator to use platform-specific deallocator - /// - /// @param[in] i_ptr Pointer to memory previously allocated with new - /// - static void operator delete(void* i_ptr); -#endif - - // The parent chip - Target<TARGET_TYPE_ALL> iv_parent; - - // The child target types to c/d/g - TargetType iv_childType; - - // Callout Information - bool iv_callout; - CalloutPriorities::CalloutPriority iv_calloutPriority; - - // Deconfigure Information - bool iv_deconfigure; - - // GARD Information - bool iv_gard; - - // Child Port - static const uint8_t ALL_CHILD_PORTS = 0xff; - uint8_t iv_childPort; - - // Child Number - static const uint8_t ALL_CHILD_NUMBERS = 0xff; - uint8_t iv_childNumber; -}; - -/// -/// @struct ErrorInfoCollectTrace -/// -/// This struct contains trace ID to add to the error log -/// -struct ErrorInfoCollectTrace -{ - /// - /// @brief Constructor. - /// - /// @param[in] i_traceId - /// - ErrorInfoCollectTrace(CollectTraces::CollectTrace i_traceId); - - -#ifdef FAPI_CUSTOM_MALLOC - /// - /// @brief Overload new operator to use platform-specific allocator - /// - /// @param[in] i_sz Size of memory to allocate in bytes - /// - /// @return Pointer to allocated memory - /// - static void* operator new(size_t i_sz); - - /// - /// @brief Overload delete operator to use platform-specific deallocator - /// - /// @param[in] i_ptr Pointer to memory previously allocated with new - /// - static void operator delete(void* i_ptr); -#endif - - // trace - CollectTraces::CollectTrace iv_eiTraceId; -}; - -/// -/// @struct ErrorInfo -/// -/// This struct defines the error information associated with a fapi2::ffdc -/// Users are allowed to access the data directly -/// -struct ErrorInfo -{ - -#ifdef FAPI_CUSTOM_MALLOC - /// - /// @brief Overload new operator to use platform-specific allocator - /// - /// @param[in] i_sz Size of memory to allocate in bytes - /// - /// @return Pointer to allocated memory - /// - static void* operator new(size_t i_sz); - - /// - /// @brief Overload delete operator to use platform-specific deallocator - /// - /// @param[in] i_ptr Pointer to memory previously allocated with new - /// - static void operator delete(void* i_ptr); -#endif - - // Vector of FFDC Data - std::vector<std::shared_ptr<ErrorInfoFfdc> > iv_ffdcs; - - // Vector of Hardware to callout - std::vector<std::shared_ptr<ErrorInfoHwCallout> > iv_hwCallouts; - - // Vector of procedures to callout - std::vector<std::shared_ptr<ErrorInfoProcedureCallout> > - iv_procedureCallouts; - - // Vector of buses to callout - std::vector<std::shared_ptr<ErrorInfoBusCallout> > iv_busCallouts; - - // Vector of targets to callout/deconfigure/GARD - std::vector<std::shared_ptr<ErrorInfoCDG> > iv_CDGs; - - // Vector of children targets to callout/deconfigure/GARD - std::vector<std::shared_ptr<ErrorInfoChildrenCDG> > iv_childrenCDGs; - - // Vector of traces to collect - std::vector<std::shared_ptr<ErrorInfoCollectTrace> > iv_traces; -}; -/// -/// @brief Structure representing a single ErrorInfo entry. -/// -/// An array of these is passed to the addErrorInfo function when a HWP -/// generates an error by calling the FAPI_SET_HWP_ERROR macro -// Why aren't these inherited classes? Saves on allocation overhead. -// We create an array of ErrorInfoEntries as automatics when we start -// FFDC collection. If we did this as inherited classes it would either -// be allocating and deallocating or we'd need to allocate an array of -// the largest and map each struct in to it. That's messy to do without -// unions (that's what they're for) so we do it like this. The inherited -// model would result in a jump table anyway, so we're basically doing -// all of that by hand to avoid the mess. -// -struct ErrorInfoEntryFfdc -{ - uint8_t iv_ffdcObjIndex; - uint16_t iv_ffdcSize; - uint32_t iv_ffdcId; - void addErrorInfo(std::shared_ptr<ErrorInfo> i_info, - const void* const* i_object) const; -}; - -/// -/// @brief Structure representing a hardware callout -/// -struct ErrorInfoEntryHwCallout -{ - uint8_t iv_hw; - uint8_t iv_calloutPriority; - uint8_t iv_refObjIndex; - void addErrorInfo(std::shared_ptr<ErrorInfo> i_info, - const void* const* i_object) const; -}; - -/// -/// @brief Structure representing a procedure callout -/// -struct ErrorInfoEntryProcCallout -{ - uint8_t iv_procedure; - uint8_t iv_calloutPriority; - void addErrorInfo(std::shared_ptr<ErrorInfo> i_info, - const void* const* i_object) const; - - ErrorInfoEntryProcCallout(uint8_t i_procedure, uint8_t i_calloutPriority): - iv_procedure(i_procedure), - iv_calloutPriority(i_calloutPriority) - {} - - ErrorInfoEntryProcCallout(void) = default; -}; - -/// -/// @brief Structure representing a bus callout -/// -struct ErrorInfoEntryBusCallout -{ - uint8_t iv_endpoint1ObjIndex; - uint8_t iv_endpoint2ObjIndex; - uint8_t iv_calloutPriority; - void addErrorInfo(std::shared_ptr<ErrorInfo> i_info, - const void* const* i_object) const; -}; - -/// -/// @brief Structure representing a target callout -/// -struct ErrorInfoEntryTargetCDG -{ - uint8_t iv_targetObjIndex; - uint8_t iv_callout; - uint8_t iv_deconfigure; - uint8_t iv_gard; - uint8_t iv_calloutPriority; - void addErrorInfo(std::shared_ptr<ErrorInfo> i_info, - const void* const* i_object) const; -}; - -/// -/// @brief Structure representing a child callout -/// -struct ErrorInfoEntryChildrenCDG -{ - uint8_t iv_parentObjIndex; - uint8_t iv_callout; - uint8_t iv_deconfigure; - uint32_t iv_childType; - uint8_t iv_childPort; - uint8_t iv_childNumber; - uint8_t iv_gard; - uint8_t iv_calloutPriority; - void addErrorInfo(std::shared_ptr<ErrorInfo> i_info, - const void* const* i_object) const; -}; - -/// -/// @brief Structure representing collected trace information -/// -struct ErrorInfoEntryCollectTrace -{ - uint32_t iv_eieTraceId; - void addErrorInfo(std::shared_ptr<ErrorInfo> i_info, - const void* const* i_object) const; -}; - -/// -/// @brief Union of all the error info types -/// -struct ErrorInfoEntry -{ - uint8_t iv_type; // Value from ErrorInfoType - union - { - ErrorInfoEntryFfdc ffdc; - ErrorInfoEntryHwCallout hw_callout; - ErrorInfoEntryProcCallout proc_callout; - ErrorInfoEntryBusCallout bus_callout; - ErrorInfoEntryTargetCDG target_cdg; - ErrorInfoEntryChildrenCDG children_cdg; - ErrorInfoEntryCollectTrace collect_trace; - }; - - /// - /// @brief Add error information to the FFDC object - /// @param[in] i_info a shared pointer to the error info - /// @param[in] i_object the list of ffdc objects being collected - /// - void addErrorInfo(std::shared_ptr<ErrorInfo> i_info, - const void* const* i_object) const - { - // "unhandled error info type"); - fapi2::Assert(iv_type < EI_LAST_TYPE); - - switch(iv_type) - { - case EI_TYPE_FFDC: - ffdc.addErrorInfo(i_info, i_object); - break; - - case EI_TYPE_HW_CALLOUT: - hw_callout.addErrorInfo(i_info, i_object); - break; - - case EI_TYPE_PROCEDURE_CALLOUT: - proc_callout.addErrorInfo(i_info, i_object); - break; - - case EI_TYPE_BUS_CALLOUT: - bus_callout.addErrorInfo(i_info, i_object); - break; - - case EI_TYPE_CDG: - target_cdg.addErrorInfo(i_info, i_object); - break; - - case EI_TYPE_CHILDREN_CDG: - children_cdg.addErrorInfo(i_info, i_object); - break; - - case EI_TYPE_COLLECT_TRACE: - collect_trace.addErrorInfo(i_info, i_object); - break; - }; - - return; - } -}; -#endif // !defined(FAPI2_NO_FFDC) && !defined(MINIMUM_FFDC) -} -#endif // FAPI2_ERRORINFO_H_ diff --git a/import/hwpf/fapi2/include/error_info_defs.H b/import/hwpf/fapi2/include/error_info_defs.H deleted file mode 100644 index c67e4061..00000000 --- a/import/hwpf/fapi2/include/error_info_defs.H +++ /dev/null @@ -1,344 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/error_info_defs.H $ */ -/* */ -/* OpenPOWER sbe 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 error_info_defs.H -/// @brief Defines to support the Error Information class -/// - -#ifndef FAPI2_ERRORINFO_DEFS_H_ -#define FAPI2_ERRORINFO_DEFS_H_ - -#include <stdint.h> -#include <target.H> - -#if !defined(MINIMUM_FFDC) && !defined(FAPI2_NO_FFDC) - #include <variable_buffer.H> - #include <utility> -#endif -namespace fapi2 -{ - -// $TEMP - funciton temp function to pass compiling -template<TargetType T> -Target<T>* getTarget(TargetType type, uint8_t instance) -{ - static_cast<void>(type); - static_cast<void>(instance); - return new Target<T>(0); -} - -/// -/// @brief Type to hold the ffdc data to be sent to hostboot -/// -/// Note: Typical data sent seems to be register/addresss info -/// rather than use extra space converting stuff just -/// send a uint64 always -/// -struct sbeFfdc_t -{ - uint32_t size; - uint64_t data; -}; - -// 10 entries limits the size of SbeFfdcData_t to 128 bytes -enum -{ - MAX_SBE_FFDC_ENTRIES = 10 -}; - -// Data type for SBE ffdc buffer sent through fifo -typedef struct -{ - uint32_t fapiRc; // Return code from failure - uint32_t ffdcLength; // length of Fapi FFDC data (in bytes) - struct sbeFfdc_t ffdcData[MAX_SBE_FFDC_ENTRIES]; // fapi FFDC data -} SbeFfdcData_t; // 128 bytes - -/// -/// @brief Type to hold the ffdc element in the ffdc class -/// Needed so that the size can be squirled away before the -/// macro is called. -/// -struct ffdc_struct -{ - const void* ptr; - int16_t size; -}; - - -class ffdc_t -{ - public: - ffdc_t(void) - {} - - void operator=(const ffdc_t& i ) - { - iv_value.ptr = i.ptr(); - iv_value.size = i.size(); - } - - operator const void* () const - { - return iv_value.ptr; - } - operator uint8_t() const - { - return *(reinterpret_cast<const uint8_t*>(iv_value.ptr)); - } - - int16_t size(void) const - { - return iv_value.size; - } - int16_t& size(void) - { - return iv_value.size; - } - - const void* ptr(void) const - { - return iv_value.ptr; - } - const void*& ptr(void) - { - return iv_value.ptr; - } - - private: - struct ffdc_struct iv_value; -}; - -/// -/// @brief Enumeration of ErrorInfo FFDC sizes that are used to indicate a -/// special type that cannot simply be memcopied -enum ErrorInfoFfdcSize -{ - EI_FFDC_SIZE_BUF = 0xffff, // fapi2::buffer<T> - EI_FFDC_SIZE_TARGET = 0xfffe, // fapi2::Target - EI_FFDC_SIZE_VBUF = 0xfffd, // fapi2::variable_buffer - EI_FFDC_MAX_SIZE = 0x1000, // Limit regular FFDC capture to 4kb -}; - -/// -/// @brief Enumeration of error log severity. -/// -enum errlSeverity_t -{ - FAPI2_ERRL_SEV_UNDEFINED = 0x00, /// Used internally by ffdc mechanism - FAPI2_ERRL_SEV_RECOVERED = 0x10, /// Not seen by customer - FAPI2_ERRL_SEV_PREDICTIVE = 0x20, /// Error recovered but customer will see - FAPI2_ERRL_SEV_UNRECOVERABLE = 0x40 /// Unrecoverable, general -}; - -/// -/// @brief Enumeration of ErrorInfo types -/// -enum ErrorInfoType -{ - EI_TYPE_FFDC = 0, - EI_TYPE_HW_CALLOUT = 1, - EI_TYPE_PROCEDURE_CALLOUT = 2, - EI_TYPE_BUS_CALLOUT = 3, - EI_TYPE_CDG = 4, // Target Callout/Deconfig/GARD - EI_TYPE_CHILDREN_CDG = 5, // Children Callout/Deconfig/GARD - EI_TYPE_COLLECT_TRACE = 6, - EI_LAST_TYPE = EI_TYPE_COLLECT_TRACE + 1, -}; - -#ifndef MINIMUM_FFDC -/// -/// @enum HwCallout -/// -/// This enumeration defines the possible Hardware Callouts that are not -/// represented by fapi2::Targets -/// -/// Note that platform code may depend on the enum values starting at 0 and -/// incrementing in order to efficiently convert to a platform callout value -/// so do not reorder without consulting all platforms -/// -namespace HwCallouts -{ -enum HwCallout -{ - // Where indicated, a HW Callout in FAPI Error XML must include a - // reference target that is used to identify the HW. e.g. for - // TOD_CLOCK, the proc chip that the clock is attached to must be - // specified - TOD_CLOCK = 0, // Include proc-chip ref (or child chiplet) - MEM_REF_CLOCK = 1, // Include membuf-chip ref (or child chiplet) - PROC_REF_CLOCK = 2, // Include proc-chip ref (or child chiplet) - PCI_REF_CLOCK = 3, // Include proc-chip ref (or child chiplet) - FLASH_CONTROLLER_PART = 4, - PNOR_PART = 5, - SBE_SEEPROM_PART = 6, - VPD_PART = 7, - LPC_SLAVE_PART = 8, - GPIO_EXPANDER_PART = 9, - SPIVID_SLAVE_PART = 10, -}; -} - -/// -/// @enum ProcedureCallout -/// -/// This enumeration defines the possible Procedure Callouts -/// These instruct the customer/customer-engineer what to do -/// -/// Note that platform code may depend on the enum values starting at 0 and -/// incrementing in order to efficiently convert to a platform callout value -/// so do not reorder without consulting all platforms -/// -namespace ProcedureCallouts -{ -enum ProcedureCallout -{ - CODE = 0, // Code problem - LVL_SUPPORT = 1, // Call next level of support - MEMORY_PLUGGING_ERROR = 2, // DIMM Plugging error - BUS_CALLOUT = 3, // Bus Called Out -}; -} - -/// -/// @enum CalloutPriority -/// -/// This enumeration defines the possible Procedure and Target callout priorities -/// -/// Note that platform code may depend on the enum values starting at 0 and -/// incrementing in order to efficiently convert to a platform priority value -/// so do not reorder without consulting all platforms -/// -namespace CalloutPriorities -{ -enum CalloutPriority -{ - LOW = 0, - MEDIUM = 1, - HIGH = 2, -}; -} - -/// -/// @enum CollectTrace -/// -/// This enumeration defines the possible firmware traces to collect -/// -namespace CollectTraces -{ -const uint32_t TRACE_SIZE = 256; // limit collected trace size -enum CollectTrace -{ - FSI = 1, - SCOM = 2, - SCAN = 3, - MBOX = 4, -}; -} -#endif - -// NOTE - this assumes no buffer_t or variable_buffers are passed -// data is converted to a uint64_t when placed into the sbe ffdc -// buffer -inline fapi2::ffdc_t getFfdcData( sbeFfdc_t& i_sbeFfdc ) -{ - fapi2::ffdc_t temp; - - // passed in size is a uint32_t but, needs to be uint16_t - temp.size() = static_cast<uint16_t>(i_sbeFfdc.size); - - if(temp.size() == EI_FFDC_SIZE_TARGET) - { - uint64_t targetData = i_sbeFfdc.data; - fapi2::TargetType type = static_cast<fapi2::TargetType>(targetData >> 32); - uint8_t instance = static_cast<uint8_t>(targetData & 0xFFFFFFFF); - // call hostboot to get the fapi2 target reference - temp.ptr() = static_cast<void*>(getTarget<TARGET_TYPE_ALL>(type, instance)); - } - else - { - // adjust the pointer based on the data size. - temp.ptr() = static_cast<void*>(reinterpret_cast<uint8_t*>(&i_sbeFfdc.data) + - (sizeof(uint64_t) - i_sbeFfdc.size)); - } - - return temp; -} -/// -/// @brief Get FFDC Size -/// -/// This is called by the FAPI_SET_HWP_ERROR macro to find out the size of -/// FFDC data. If the data is of a special type that is handled differently -/// than types that are simply memcopied then it is handled by a template -/// specialization. -/// If this function template is instantiated with a pointer, the compile -/// will fail. -/// -/// @return uint16_t. Size of the FFDC data -/// -template<typename T> -inline uint16_t getErrorInfoFfdcSize(const T&) -{ - static_assert(sizeof(T) <= EI_FFDC_MAX_SIZE, - "FFDC too large to capture"); - return sizeof(T); -} -#if !defined(MINIMUM_FFDC) && !defined(FAPI2_NO_FFDC) -/// -/// @brief Compile error if caller tries to get the FFDC size of a pointer -/// -template<typename T> -inline uint16_t getErrorInfoFfdcSize(const T*) -{ - static_assert(std::is_pointer<T>::value, - "pointer passed to getErrorInfoFfdcSize"); - return 0; -} -#endif -/// -/// @brief Get FFDC Size specialization for fapi2::Target -/// -template<fapi2::TargetType T, typename V> -inline uint16_t getErrorInfoFfdcSize(const fapi2::Target<T, V>&) -{ - return EI_FFDC_SIZE_TARGET; -} - -#if !defined(MINIMUM_FFDC) && !defined(FAPI2_NO_FFDC) -/// -/// @brief Get FFDC Size specialization for variable buffers -/// -template<> -inline uint16_t getErrorInfoFfdcSize(const fapi2::variable_buffer& i_thing) -{ - // Limit a variable buffer to 4kb bytes, and we can memcpy the storage. - return std::min(static_cast<uint32_t>(EI_FFDC_MAX_SIZE), - i_thing.getLength<uint8_t>()); -} -#endif -}; - -#endif // FAPI2_ERRORINFO_DEFS_H_ diff --git a/import/hwpf/fapi2/include/error_scope.H b/import/hwpf/fapi2/include/error_scope.H deleted file mode 100644 index 1a00386c..00000000 --- a/import/hwpf/fapi2/include/error_scope.H +++ /dev/null @@ -1,37 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/error_scope.H $ */ -/* */ -/* OpenPOWER sbe 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 error_scope.H - * @brief platform specializations which create a scope for automatic error handling - */ - -#ifndef __FAPI2_ERROR_SCOPE__ -#define __FAPI2_ERROR_SCOPE__ - -#include <plat_error_scope.H> -#include <fapi2_error_scope.H> - - -#endif diff --git a/import/hwpf/fapi2/include/fapi2.H b/import/hwpf/fapi2/include/fapi2.H deleted file mode 100644 index 9965e8e5..00000000 --- a/import/hwpf/fapi2/include/fapi2.H +++ /dev/null @@ -1,55 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/fapi2.H $ */ -/* */ -/* OpenPOWER sbe 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 fapi2.H -/// @brief top level header for fapi2 -/// - -#ifndef __FAPI2_TOP_LEVEL__ -#define __FAPI2_TOP_LEVEL__ - -#include <target.H> -#include <return_code.H> -#include <buffer.H> -#include <hw_access.H> -#include <utils.H> -#include <plat_trace.H> - -// In turn includes the needed generated headers (hwp_ffd_classes, etc.) -#include <error_scope.H> -#include <set_sbe_error.H> // Generated file - -#include <fapi2_hwp_executor.H> -#include <fapi2_attribute_service.H> -#include <fapi2_chip_ec_feature.H> - -#include <mvpd_access.H> - -// Block of headers not currently in fapi2 -#ifdef FAPI2_MISSING_HEADERS - #include <mbvpdAccess.H> -#endif - -#endif // __FAPI2_TOP_LEVEL__ diff --git a/import/hwpf/fapi2/include/fapi2_attribute_service.H b/import/hwpf/fapi2/include/fapi2_attribute_service.H deleted file mode 100644 index 78655961..00000000 --- a/import/hwpf/fapi2/include/fapi2_attribute_service.H +++ /dev/null @@ -1,148 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/fapi2_attribute_service.H $ */ -/* */ -/* OpenPOWER sbe 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 fapi2_attribute_service.H -/// -/// @brief Defines the FAPI_ATTR_GET and FAPI_ATTR_SET macros that a user -/// calls to get/set attributes and a check function that the macros use to -/// verify correct usage -/// - -#ifndef FAPI2ATTRIBUTESERVICE_H_ -#define FAPI2ATTRIBUTESERVICE_H_ -#include <stdint.h> -#include <attribute_ids.H> -#include <return_code.H> -#include <target.H> -#include <target_types.H> -#include <plat_attribute_service.H> - -/// @brief Macros called by user to get/set attributes for FAPI2 targets -/// -/// Code must have a reference to a FAPI2 Target and an attribute ID (from -/// XML file): -/// fapi2::ReturnCode l_rc; -/// fapi2::Target<target type>& l_target = ????; -/// Ex: Target<TARGET_TYPE_PROC_CHIP>& l_target = ????; -/// -/// To get a copy of an integer attribute and set the attribute -/// uint64_t l_val = 0; -/// l_rc = FAPI_ATTR_GET(<ID>, l_target, l_val); -/// l_rc = FAPI_ATTR_SET(<ID>, l_target, l_val); -/// -/// To get a copy of an integer array attribute and set the attribute -/// uint32_t l_pVal[4] = {0}; -/// l_rc = FAPI_ATTR_GET(<ID>, l_target, l_pVal); -/// l_rc = FAPI_ATTR_SET(<ID>, l_target, l_pVal); -/// -/// A priveleged attribute is one that a HWP should not generally access, -/// examples include ATTR_NAME and ATTR_EC, where usage can lead to a non -/// data-driven design. A privileged attribute can be accessed with -/// FAPI_ATTR_GET_PRIVILEGED and FAPI_ATTR_SET_PRIVILEGED -/// -/// The non-PRIVILEGED macros first call a template function (compiler will -/// optimize out) that will cause a compile failure if the attribute is -/// privileged, they then call a PRIVILEGED macro to get/set the attribute -/// -/// The PRIVILEGED macros call a template function (compiler will optimize out) -/// that will cause a compile failure if the ID is not valid or VAL is not the -/// correct type. -// - -#define FAPI_ATTR_GET(ID, TARGET, VAL) \ - (fapi2::failIfPrivileged<ID##_Privileged>(), \ - fapi2::Target<ID##_TargetType>(TARGET), \ - fapi2::checkIdType<ID##_Type>(ID, VAL), \ - ID##_GETMACRO(ID, TARGET, VAL)) - -#define FAPI_ATTR_SET(ID, TARGET, VAL) \ - (fapi2::failIfPrivileged<ID##_Privileged>(), \ - fapi2::Target<ID##_TargetType>(TARGET), \ - fapi2::checkIdType<ID##_Type>(ID, VAL), \ - ID##_SETMACRO(ID, TARGET, VAL)) - -#define FAPI_ATTR_GET_PRIVILEGED(ID, TARGET, VAL) \ - (fapi2::checkIdType<ID##_Type>(ID, VAL), \ - ID##_GETMACRO(ID, TARGET, VAL)) - -#define FAPI_ATTR_SET_PRIVILEGED(ID, TARGET, VAL) \ - (fapi2::checkIdType<ID##_Type>(ID, VAL), \ - ID##_SETMACRO(ID, TARGET, VAL)) - -namespace fapi2 -{ - -/// -/// @brief Get raw access to a FAPI2 Attribute. This is used to dump FAPI2 -/// Attrs -/// -/// This function gets a copy of an attribute. In the case of an array attribute, -/// The value in the specified index is retrieved. This should be used by the -/// InitFile HWP only, that HWP processes a binary InitFile and therefore needs -/// to read a variable ID of a variable data type. Standard HWPs should use the -/// FAPI2_ATTR_GET macro which automatically checks the type for correct usage. -/// -/// If there are ever attributes with more than 4 dimensions then this function -/// will need to be updated. -/// -/// @tparam K template parameter, passed in target. -/// @param[in] i_id AttributeID -/// @param[in] i_target Reference to fapi2::Target (can be NULL for system) -/// @param[out] o_val Reference to uint64_t where attribute value is set -/// @param[in] i_arrayIndex1 If array attribute then index1 -/// @param[in] i_arrayIndex2 If at least 2D array attribute then index2 -/// @param[in] i_arrayIndex3 If at least 3D array attribute then index3 -/// @param[in] i_arrayIndex4 If at least 4D array attribute then index4 -/// -/// @return ReturnCode. Zero if success -/// -ReturnCode rawAccessAttr(const AttributeId i_id, - const Target<TARGET_TYPE_ALL>& i_target, - uint8_t* o_val); - -/** - * @brief Check the ID and TYPE - * - * This is called by FAPI code to check at compile time that a FAPI attribute - * access is using the correct data type and a valid AttributeId - */ -template<typename T> inline void checkIdType(AttributeId, T&) {} - -/** - * @brief Fail if attribute privileged - * - * This is called by FAPI code to check at compile time that a standard FAPI - * attribute access (FAPI_ATTR_GET) is not accessing a privileged attribute - */ -class ErrorAccessingPrivilegedAttribute; -template<const bool PRIVILEGED> void failIfPrivileged() -{ - ErrorAccessingPrivilegedAttribute(); -} -template <> inline void failIfPrivileged<false>() {} - -} - -#endif // FAPI2ATTRIBUTESERVICE_H_ diff --git a/import/hwpf/fapi2/include/fapi2_error_scope.H b/import/hwpf/fapi2/include/fapi2_error_scope.H deleted file mode 100644 index 8a4833ac..00000000 --- a/import/hwpf/fapi2/include/fapi2_error_scope.H +++ /dev/null @@ -1,89 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/fapi2_error_scope.H $ */ -/* */ -/* OpenPOWER sbe 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 fapi2_error_scope.H - * @brief common definitions which create a scope for automatic error handling - */ - -#ifndef __FAPI2_COMMON_ERROR_SCOPE__ -#define __FAPI2_COMMON_ERROR_SCOPE__ - -#include <stdint.h> -#include <plat_error_scope.H> -#include <hwp_ffdc_classes.H> - -/// @cond -#define FAPI_VA_NARGS_IMPL(_1, _2, _3, _4, _5, N, ...) N -#define FAPI_VA_NARGS(...) FAPI_VA_NARGS_IMPL(__VA_ARGS__, 5, 4, 3, 2, 1) - -#define FAPI_TRY_IMPL2(count, ...) FAPI_TRY ## count (__VA_ARGS__) -#define FAPI_TRY_IMPL(count, ...) FAPI_TRY_IMPL2(count, __VA_ARGS__) - -#define FAPI_TRY_NO_TRACE( __operation__ ) PLAT_FAPI_TRY_NO_TRACE( __operation__ ) -#define FAPI_TRY_TRACE( __operation__, ... ) PLAT_FAPI_TRY_TRACE( __operation__, __VA_ARGS__ ) - -#define FAPI_TRY1 FAPI_TRY_NO_TRACE -#define FAPI_TRY2 FAPI_TRY_TRACE -#define FAPI_TRY3 FAPI_TRY_TRACE -#define FAPI_TRY4 FAPI_TRY_TRACE -#define FAPI_TRY5 FAPI_TRY_TRACE -/// @endcond - -/// -/// @brief Wrapper to check an operation for an error state -/// and jump to the label clean_up if there is an error. -/// @param[in] \__operation__ an operation which returns a fapi::ReturnCode -/// @param[in] ... vararg format/agruments for trace output (optional) -/// @note This implementation does not support PIB error masks or -/// FSP operational states. -/// -#ifdef DOXYGEN - #define FAPI_TRY(__operation__, ...) FAPI_TRY_IMPL -#else - #define FAPI_TRY(...) FAPI_TRY_IMPL(FAPI_VA_NARGS(__VA_ARGS__), __VA_ARGS__) -#endif - -/// -/// @brief Assert a conditional is true. -/// If it is not, the FFDC gathering function is called and the -/// trace is output as a FAPI error trace. -/// @param[in] \__conditional__ the condition to assert -/// @param[in] \__ffdc__ the FFDC gathering function -/// @param[in] ... varargs, as input to FAPI_ERR -/// -#define FAPI_ASSERT( __conditional__, __ffdc__, ... ) \ - PLAT_FAPI_ASSERT( __conditional__, __ffdc__, __VA_ARGS__ ) - -/// -/// @brief Create an eror log, commit it, but do not exit the hwp because of -/// the error condition. -/// @param[in] \__conditional__ the condition to assert -/// @param[in] \__ffdc__ the FFDC gathering function -/// @param[in] ... varargs, as input to FAPI_ERR -/// -#define FAPI_ASSERT_NOEXIT( __conditional__, __ffdc__, ... ) \ - PLAT_FAPI_ASSERT_NOEXIT( __conditional__, __ffdc__, __VA_ARGS__ ) - -#endif diff --git a/import/hwpf/fapi2/include/fapi2_hw_access.H b/import/hwpf/fapi2/include/fapi2_hw_access.H deleted file mode 100644 index 8dc871bb..00000000 --- a/import/hwpf/fapi2/include/fapi2_hw_access.H +++ /dev/null @@ -1,428 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/fapi2_hw_access.H $ */ -/* */ -/* OpenPOWER sbe 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 fapi2_hw_access.H -/// @brief Common file that defines the hardware access functions that -/// platform code must implement. -/// - -#ifndef _FAPI2_COMMON_HWACCESS_H_ -#define _FAPI2_COMMON_HWACCESS_H_ - -#ifdef FAPI_SUPPORT_SPY_AS_ENUM - #include <spy_ids.H> - typedef uint64_t spyId_t; -#endif - -#include <stdint.h> -#include <buffer.H> - -// variable_buffer isn't supported on PPE -#ifndef __PPE__ - #include <variable_buffer.H> -#endif - -#include <return_code.H> -#include <target.H> -#include <hw_access_def.H> -#include <plat_hw_access.H> -#include <p9_ringId.H> - -namespace fapi2 -{ -//-------------------------------------------------------------------------- -// PIB Error Functions -//-------------------------------------------------------------------------- - -/// @brief Sets the PIB error mask - platform dependant -/// @param[in] i_mask The new error mask -inline void setPIBErrorMask(uint8_t i_mask); - -/// @brief Gets the PIB error mask - platform dependant -/// @return uint8_t The current PIB error mask -inline uint8_t getPIBErrorMask(void); - -//-------------------------------------------------------------------------- -// Operational Mode Error Functions -//-------------------------------------------------------------------------- - -/// @brief Sets the operational mode -/// @param[in] i_mode The new mode -inline void setOpMode(const OpModes i_mode); - -/// @brief Gets the operational mode -/// @return the operational mode -inline OpModes getOpMode(void); - -//-------------------------------------------------------------------------- -// HW Communication Functions -//-------------------------------------------------------------------------- - -/// @brief Reads a SCOM register from a chip. -/// @tparam K template parameter, passed in target. -/// @param[in] i_target HW target to operate on. -/// @param[in] i_address SCOM register address to read from. -/// @param[out] o_data Buffer that holds data read from HW target. -/// @return fapi2::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -template< TargetType K, typename V > -inline ReturnCode getScom(const Target<K, V>& i_target, const uint64_t i_address, - buffer<uint64_t>& o_data); - -/// @brief Writes a SCOM register on a chip. -/// @tparam K template parameter, passed in target. -/// @param[in] i_target HW target to operate on. -/// @param[in] i_address SCOM register address to write to. -/// @param[in] i_data Buffer that holds data to write into address. -/// @return fapi2::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -template< TargetType K, typename V > -inline ReturnCode putScom(const Target<K, V>& i_target, const uint64_t i_address, - const buffer<uint64_t> i_data); - -/// @brief Writes a SCOM register under mask on a chip -/// @tparam K template parameter, passed in target. -/// @param[in] i_target HW target to operate on. -/// @param[in] i_address SCOM register address to write to. -/// @param[in] i_data Buffer that holds data to write into address. -/// @param[in] i_mask Buffer that holds the mask value. -/// @return fapi2::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -template< TargetType K, typename V > -inline ReturnCode putScomUnderMask(const Target<K, V>& i_target, - const uint64_t i_address, - const buffer<uint64_t> i_data, - const buffer<uint64_t> i_mask); - -/// @brief Reads a CFAM register from a chip. -/// CFAM register is 32-bit wide. -/// @tparam K template parameter, passed in target. -/// @param[in] i_target HW target to operate on. -/// @param[in] i_address CFAM register address to read from. -/// @param[out] o_data Buffer that holds data read from HW target. -/// @return fapi2::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -template< TargetType K, typename V > -inline ReturnCode getCfamRegister(const Target<K, V>& i_target, - const uint32_t i_address, - buffer<uint32_t>& o_data); - -/// @brief Writes a CFAM register on a chip. -/// CFAM register is 32-bit wide. -/// @tparam K template parameter, passed in target. -/// @param[in] i_target HW target to operate on. -/// @param[in] i_address CFAM register address to write to. -/// @param[in] i_data Buffer that holds data to write into address. -/// @return fapi2::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -template< TargetType K, typename V > -inline ReturnCode putCfamRegister(const Target<K, V>& i_target, - const uint32_t i_address, - const buffer<uint32_t> i_data); - -/// @brief Read-modify-write a CFAM register on a chip. -/// CFAM register is 32-bit wide. -/// @tparam K template parameter, passed in target. -/// @param[in] i_target HW target to operate on. -/// @param[in] i_address CFAM register address to modify. -/// @param[in] i_data Buffer that holds data to be modified. -/// @param[in] i_modifyMode The modify mode (or/and/xor). -/// @return fapi2::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -template< TargetType K, typename V > -inline ReturnCode modifyCfamRegister(const Target<K, V>& i_target, - const uint32_t i_address, - const buffer<uint32_t> i_data, - const ChipOpModifyMode i_modifyMode); - -/// @brief Writes a ring to a chip. -/// @tparam K template parameter, passed in target. -/// @param[in] i_target Target to operate on. -/// @param[in] i_ringID Ring ID that will identify the Ring in the image. -/// @param[in] i_ringMode Ring operation mode. -/// @return fapi2::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -template< TargetType K, typename V > -ReturnCode putRing(const Target<K, V>& i_target, - const RingID i_ringID, - const RingMode i_ringMode = RING_MODE_HEADER_CHECK); - -// variable_buffer isn't supported on PPE -#ifndef __PPE__ -/// @brief Reads a ring from a chip. -/// @tparam K template parameter, passed in target. -/// @param[in] i_target Target to operate on. -/// @param[in] i_address Ring address to read from. -/// @param[out] o_data Buffer that holds data read from HW target. -/// @param[in] i_ringMode Ring operation mode. -/// @return fapi2::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -template< TargetType K, typename V > -inline ReturnCode getRing(const Target<K, V>& i_target, - const scanRingId_t i_address, - variable_buffer& o_data, - const RingMode i_ringMode = 0); - -/// @brief Read-modify-write a ring on a chip. -/// @tparam K template parameter, passed in target. -/// @param[in] i_target Target to operate on. -/// @param[in] i_address Ring address to modify. -/// @param[in] i_data Buffer that contains RS4 compressed ring data -/// to be modified. -/// @param[in] i_modifyMode The modify mode (or/and/xor) -/// @param[in] i_ringMode Ring operation mode. -/// @return fapi2::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -template< TargetType K, typename V > -inline ReturnCode modifyRing(const Target<K, V>& i_target, - const scanRingId_t i_address, - const variable_buffer& i_data, - const ChipOpModifyMode i_modifyMode, - const RingMode i_ringMode = 0); -#endif - -// -------------------------------------------------------------------------- -// NOTE: -// Implement platform Spy access functions if platform supports them. -// -------------------------------------------------------------------------- - -// variable_buffer isn't supported on PPE -#ifndef __PPE__ -/// @brief Reads a spy from a chip. -/// @tparam K template parameter, passed in target. -/// @param[in] TARGET Target to operate on. -/// @param[in] ID Id of the spy whose data to be read. -/// @param[out] DATA Buffer that holds data read from HW target. -/// @return fapi2::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -/// -/// @note: The string version is only supported for cronus. -/// -/// The fapi design to support both FSP and cronus use of get and -/// put spy functions is dependant on the SPY names being expanded -/// to resemble a valid C identifier. This design places some -/// restrictions on the SPY names which can be used. -/// -/// 1. if the spy name contains a # procedure writers should replace -/// it with an __P__ for example - -/// -/// ABUS.RX0.RXPACKS#0.RXPACK.RD.LC.LC.ACT_DIS -/// becomes -/// ABUS.RX0.RXPACKS__P__0.RXPACK.RD.LC.LC.ACT_DIS -/// -/// 2. if the spy name has a number following a "." it must have an -/// underscore prepended to the number. -/// -/// EH.TPCHIP.2KX100_ARY_CLK_EDGES_DLY -/// becomes -/// EH.TPCHIP._2KX100_ARY_CLK_EDGES_DLY -/// -/// Example SPY name: -/// The hardware procedure should call the function like: -/// -/// ABUS.RX0.RXPACKS#0.RXPACK.RD.LC.LC.ACT_DIS -/// -/// fapi2::ReturnCode rc = fapiGetSpy( targ, -/// ABUS.RX0.RXPACKS__P__0.RXPACK.RD.LC.LC.ACT_DIS, data ); -/// -/// @note The ID is not in quotes the fapi code will handle adding -/// the quotes for the cronus environment -#if defined(FAPI_SUPPORT_SPY_AS_ENUM) || defined(DOXYGEN) - -#define FAPI_GET_SPY(TARGET, ID, DATA) fapi2::getSpy(TARGET, FAPI_SPY_NAMES::ID.value, DATA) - -template< TargetType K, typename V > -inline ReturnCode getSpy(const Target<K, V>& i_target, - const spyId_t i_spyId, - variable_buffer& o_data); - -template< TargetType K > -inline ReturnCode getSpy(const Target<K>& i_target, - const spyId_t i_spyId, - variable_buffer& o_data, - const RingMode i_ringMode); -#endif - -#if defined(FAPI_SUPPORT_SPY_AS_STRING) || defined(DOXYGEN) - -#define FAPI_GET_SPY(TARGET, ID, DATA) fapi2::getSpy(TARGET, #ID, DATA) - -template< TargetType K, typename V > -inline ReturnCode getSpy(const Target<K, V>& i_target, - const char* const i_spyId, - variable_buffer& o_data); - -template< TargetType K > -inline ReturnCode getSpy(const Target<K>& i_target, - const char* const i_spyId, - variable_buffer& o_data, - const RingMode i_ringMode); -#endif - -/// @brief Writes a spy on a chip. -/// @tparam K template parameter, passed in target. -/// @param[in] TARGET Target to operate on. -/// @param[in] ID Id of the spy to write data to. -/// @param[out] DATA Buffer that holds data to write into spy. -/// @return fapi2::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -/// -/// @note: The string version is only supported for cronus. -/// -/// The fapi design to support both FSP and cronus use of get and -/// put spy functions is dependent on the SPY names being expanded -/// to resemble a valid C identifier. This design places some -/// restrictions on the SPY names which can be used. -/// -/// 1. if the spy name contains a # procedure writers should replace -/// is with an __P__ for example - -/// -/// ABUS.RX0.RXPACKS#0.RXPACK.RD.LC.LC.ACT_DIS -/// becomes -/// ABUS.RX0.RXPACKS__P__0.RXPACK.RD.LC.LC.ACT_DIS -/// -/// 2. if the spy name has a number following a "." it must have an -/// underscore prepended to the number. -/// -/// EH.TPCHIP.2KX100_ARY_CLK_EDGES_DLY -/// becomes -/// EH.TPCHIP._2KX100_ARY_CLK_EDGES_DLY -/// -/// Example SPY name: -/// The hardware procedure should call the function like: -/// -/// ABUS.RX0.RXPACKS#0.RXPACK.RD.LC.LC.ACT_DIS -/// -/// fapi2::ReturnCode rc = fapiPutSpy( targ, -/// ABUS.RX0.RXPACKS__P__0.RXPACK.RD.LC.LC.ACT_DIS, data ); -/// -/// @note The ID is not in quotes the fapi code will handle adding -/// the quotes for the cronus environment -/// -#if defined(FAPI_SUPPORT_SPY_AS_ENUM) || defined(DOXYGEN) - -#define FAPI_PUT_SPY(TARGET, ID, DATA) fapi2::putSpy(TARGET, FAPI_SPY_NAMES::ID.value, DATA) - -template< TargetType K, typename V > -inline ReturnCode putSpy(const Target<K, V>& i_target, - const spyId_t i_spyId, - const variable_buffer& i_data); -#endif - -#if defined(FAPI_SUPPORT_SPY_AS_STRING) || defined(DOXYGEN) - -#define FAPI_PUT_SPY(TARGET, ID, DATA) fapi2::putSpy(TARGET, #ID, DATA) - -template< TargetType K, typename V > -inline ReturnCode putSpy(const Target<K, V>& i_target, - const char* const i_spyId, - const variable_buffer& i_data); - -template< TargetType K, typename V > -inline ReturnCode putSpy(const Target<K, V>& i_target, - const char* const i_spyId, - const char* i_enum); -#endif - -/// @brief Writes spy data into a buffer holding ring data image -/// This API is used by L2/L3 repair to put column repair data -/// into a ring buffer image. -/// @tparam K template parameter, passed in target. -/// @param[in] TARGET Target to operate on. -/// @param[in] ID Id of the spy. -/// @param[in] DATA1 Buffer that holds spy data to write into ring -/// image. -/// @param[out] DATA2 Buffer that holds updated ring image. -/// @return fapi2::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -/// -/// @note: The string version is only supported for cronus. -/// -/// The fapi design to support both FSP and cronus use of get and -/// put spy functions is dependent on the SPY names being expanded -/// to resemble a valid C identifier. This design places some -/// restrictions on the SPY names which can be used. -/// -/// See fapiPutSpy for details on spy id specifics. -/// -#if defined(FAPI_SUPPORT_SPY_AS_ENUM) || defined(DOXYGEN) - -#define FAPI_PUT_SPY_IMAGE(TARGET, ID, DATA1, DATA2) \ - fapi2::putSpyImage(TARGET, FAPI_SPY_NAMES::ID.value, \ - DATA1, DATA2) - -template< TargetType K, typename V > -inline ReturnCode putSpyImage(const Target<K, V>& i_target, - const spyId_t i_spyId, - const variable_buffer& i_data, - variable_buffer& o_imageData); -#endif - -#if defined(FAPI_SUPPORT_SPY_AS_STRING) || defined(DOXYGEN) - -#define FAPI_PUT_SPY_IMAGE(TARGET, ID, DATA1, DATA2) \ - fapi2::putSpyImage(TARGET, #ID, DATA1,DATA2) - -template< TargetType K, typename V > -inline ReturnCode putSpyImage(const Target<K, V>& i_target, - const char* const i_spyId, - const variable_buffer& i_data, - variable_buffer& o_imageData); -#endif - -/// @brief Reads spy data from a ring image buffer -/// @param[in] TARGET Target to operate on -/// @param[in] ID The spy's id -/// @param[out] DATA1 Buffer that holds data read from ring image. -/// @param[in] DATA2 Buffer that holds ring image to read data -/// from. -/// @return fapi2::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -/// -/// @note: The string version is only supported for cronus. -/// -/// The fapi design to support both FSP and cronus use of get and -/// put spy functions is dependent on the SPY names being expanded -/// to resemble a valid C identifier. This design places some -/// restrictions on the SPY names which can be used. -/// -/// See fapiPutSpy for details on spy id specifics. -/// -#if defined(FAPI_SUPPORT_SPY_AS_ENUM) || defined(DOXYGEN) - -#define FAPI_GET_SPY_IMAGE(TARGET, ID, DATA1, DATA2) \ - fapi2:getSpyImage(TARGET, FAPI_SPY_NAMES::ID.value, \ - DATA1, DATA2) - -template< TargetType K, typename V > -inline ReturnCode getSpyImage(const Target<K, V>& i_target, - const spyId_t i_spyId, - variable_buffer& o_data, - const variable_buffer& i_imageData); -#endif - -#if defined(FAPI_SUPPORT_SPY_AS_STRING) || defined(DOXYGEN) - -#define FAPI_GET_SPY_IMAGE(TARGET, ID, DATA1, DATA2) \ - fapi2::getSpyImage(TARGET, #ID, DATA1,DATA2) - -template< TargetType K, typename V > -inline ReturnCode getSpyImage(const Target<K, V>& i_target, - const char* const i_spyId, - variable_buffer& o_data, - const variable_buffer& i_imageData); -#endif - -#endif // PPE -}; - -#endif // _FAPI2_HWACCESS_H_ diff --git a/import/hwpf/fapi2/include/fapi2_hwp_executor.H b/import/hwpf/fapi2/include/fapi2_hwp_executor.H deleted file mode 100644 index 78a18fba..00000000 --- a/import/hwpf/fapi2/include/fapi2_hwp_executor.H +++ /dev/null @@ -1,48 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/fapi2_hwp_executor.H $ */ -/* */ -/* OpenPOWER sbe 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 fapi2_hwp_executor.H -/// -/// @brief Defines the FAPI2 HWP Executor Macro. -/// -/// The FAPI2 HWP Executor macro is called when a PLAT invoker function or a HWP -/// wants to execute a HWP. -/// - -#ifndef FAPI2HWPEXECUTOR_H_ -#define FAPI2HWPEXECUTOR_H_ - -#include <hwp_executor.H> - -/** - * @brief HWP Executor macro - * - * This macro calls a PLAT macro which will do any platform specific work to - * execute the HWP (e.g. dlopening a shared library) - */ -#define FAPI_EXEC_HWP(RC, FUNC, _args_...) \ - FAPI_PLAT_EXEC_HWP(RC, FUNC, ##_args_) - -#endif // FAPI2HWPEXECUTOR_H_ diff --git a/import/hwpf/fapi2/include/fapi2_multicast.H b/import/hwpf/fapi2/include/fapi2_multicast.H deleted file mode 100644 index c83be5bc..00000000 --- a/import/hwpf/fapi2/include/fapi2_multicast.H +++ /dev/null @@ -1,171 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/fapi2_multicast.H $ */ -/* */ -/* OpenPOWER sbe Project */ -/* */ -/* Contributors Listed Below - COPYRIGHT 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 fapi2_multicast.H -/// @brief Common definitions for fapi2 multicast target value wrapper class -/// - -#ifndef __FAPI2_COMMON_MULTICAST__ -#define __FAPI2_COMMON_MULTICAST__ - -#include <target.H> -#include <fapi2_multicast_defs.H> - -namespace fapi2 -{ - -/// -/// @brief Class representing a FAPI2 Multicast target value wrapper -/// @tparam M the type of multicast operation -/// @tparam G the type of multicast group -/// @tparam V the type of the target's Value this class is wrapping -/// @remark This wrapper class defines how a handle will behave by -/// type and group if internal to the handle mulitcast operation -/// is enabled. If the handle used is not multicast enabled most -/// function of this class will be ignored. -/// -template<MulticastType M, MulticastGroup G, typename V = plat_target_handle_t > -class Multicast -{ - public: - /// - /// @brief Delagate default constructor to constructor - /// that takes in a value as a param - /// - Multicast() : Multicast(V()) {} - - /// - /// @brief Create a Multicast value with a target value - /// @param[in] Value the value (i.e., specific element this - /// target represents, or pointer) - /// @note Platforms can will update the handle value with - /// information on the multicast type and group - /// - Multicast(const V& value) : iv_handle(value) - { - updateHandle<M, G>(iv_handle); - } - - /// - /// @brief Create a Multicast value from another Multicast value - /// @param[in] other the value - /// @note Platforms can will update the handle value with - /// information on the multicast type and group - /// - template<MulticastType O, MulticastGroup N> - Multicast(const Multicast<O, N> other) : - iv_handle(static_cast<V>(other)) - { - updateHandle<M, G>(iv_handle); - } - - /// - /// @brief Get the handle as a V - /// @return V The Multicast wrapper's internal handle, or value - /// - inline operator V() const - { - return iv_handle; - } - - /// - /// @brief Get the handle as a V - /// @return V The Multicast wrapper's internal handle, or value - /// - inline V& operator()() const - { - return iv_handle; - } - - /// - /// @brief Has the handle been enabled for multicast operation - /// @return Return true if multicast, false otherwise - /// - inline bool isMulticast() const; - - private: - /// - /// @brief update the handle with group and type given - /// @tparam O the type of multicast operation - /// @tparam N the type of multicast group - /// @param[in] Value the value/handle - /// - template<MulticastType O, MulticastGroup N> - inline void updateHandle(V& value); - - V iv_handle; -}; - -// multicast from unicast -template<MulticastType M, MulticastGroup G, TargetType K, typename V> -inline Target<K, Multicast<M, G, V>> make_multicast(const Target<K, V>& t) -{ - return Target<K, Multicast<M, G, V>>(t.get()); -} - -// multicast from multicast -- changing type -template<MulticastType M, MulticastType N, MulticastGroup G, TargetType K, typename V> -inline Target<K, Multicast<M, G, V>> make_multicast(const Target<K, Multicast<N, G, V>>& t) -{ - return Target<K, Multicast<M, G, V>>(t.get()); -} - -// multicast from multicast -- changing type and group -template<MulticastType M, MulticastGroup O, MulticastType N, MulticastGroup G, TargetType K, typename V> -inline Target<K, Multicast<M, O, V>> make_multicast(const Target<K, Multicast<N, G, V>>& t) -{ - return Target<K, Multicast<M, O, V>>(t.get()); -} - -// unicast from multicast -template<MulticastType M, MulticastGroup G, TargetType K, typename V> -inline Target<K, V> make_unicast(const Target<K, Multicast<M, G, V>>& t) -{ - return Target<K, V>(t.get()); -} - -// test if a multicast target -template<MulticastType M, MulticastGroup G, TargetType K, typename V> -inline bool is_multicast(const Target<K, Multicast<M, G, V>>& t) -{ - const Multicast<M, G, V>& l_mref = t; - return l_mref.isMulticast(); -} - -// return false if testing a non-multicast target -template<TargetType K, typename V> -inline bool is_multicast(const Target<K, V>& t) -{ - return false; -} - -template<MulticastType M1, MulticastType M2> -constexpr bool is_same() -{ - return (M1 == M2); -} -} - -#endif diff --git a/import/hwpf/fapi2/include/fapi2_multicast_defs.H b/import/hwpf/fapi2/include/fapi2_multicast_defs.H deleted file mode 100644 index 6199b4e0..00000000 --- a/import/hwpf/fapi2/include/fapi2_multicast_defs.H +++ /dev/null @@ -1,42 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/fapi2_multicast_defs.H $ */ -/* */ -/* OpenPOWER sbe Project */ -/* */ -/* Contributors Listed Below - COPYRIGHT 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 */ -#ifndef __FAPI2_COMMON_MULTICAST_DEFS__ -#define __FAPI2_COMMON_MULTICAST_DEFS__ - -namespace fapi2 -{ -enum MulticastType -{ - MULTICAST_WRITE, - MULTICAST_READAND, - MULTICAST_READOR, - MULTICAST_READBITX, - MULTICAST_READCOMPARE, -}; - -typedef uint32_t MulticastGroup; -} - -#endif diff --git a/import/hwpf/fapi2/include/fapi2_target.H b/import/hwpf/fapi2/include/fapi2_target.H deleted file mode 100644 index b41eb477..00000000 --- a/import/hwpf/fapi2/include/fapi2_target.H +++ /dev/null @@ -1,549 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/fapi2_target.H $ */ -/* */ -/* OpenPOWER sbe 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 fapi2_target.H -/// @brief Common definitions for fapi2 targets -/// - -#ifndef __FAPI2_COMMON_TARGET__ -#define __FAPI2_COMMON_TARGET__ - -#include <stdint.h> -#include <stdlib.h> -#include <vector> -#include <target_types.H> -#include <target_states.H> -#include <plat_target.H> -#include <return_code_defs.H> - -namespace fapi2 -{ - -/// -/// @brief Class representing a FAPI2 Target -/// @tparam K the type (Kind) of target -/// @tparam V the type of the target's Value -/// @remark TargetLite targets are uint64_t, Targets -/// are uintptr_t (void*). -/// -/// Assuming there are representations of a processor, -/// a membuf and a system here are some examples: -/// @code -/// #define PROCESSOR_CHIP_A 0xFFFF0000 -/// #define MEMBUF_CHIP_B 0x0000FFFF -/// #define SYSTEM_C 0x0000AAAA -/// @endcode -/// -/// * To define a target: -/// @code -/// fapi2::Target<fapi2::TARGET_TYPE_PROC_CHIP> A(PROCESSOR_CHIP_A); -/// fapi2::Target<fapi2::TARGET_TYPE_SYSTEM> C(SYSTEM_C); -/// fapi2::Target<fapi2::TARGET_TYPE_MEMBUF_CHIP> B(MEMBUF_CHIP_B); -/// @endcode -/// -/// * Functions which take composite target types -/// @code -/// void takesProcOrMembuf( -/// const fapi2::Target<fapi2::TARGET_TYPE_PROC_CHIP | -/// fapi2::TARGET_TYPE_MEMBUF_CHIP>& V ); -/// -/// void takesAny(const fapi2::Target<fapi2::TARGET_TYPE_ALL>& V ); -/// -/// @endcode -/// -/// * Traversing the target "tree" -/// @code -/// fapi2::Target<fapi2::TARGET_TYPE_PROC_CHIP> A(PROCESSOR_CHIP_A); -/// -/// // Get A's parent -/// A.getParent<fapi2::TARGET_TYPE_SYSTEM>(); -/// -/// // Get the 0x53'd core -/// fapi2::getTarget<fapi2::TARGET_TYPE_CORE>(0x53); -/// -/// // Get all *my* present/functional children which are cores -/// A.getChildren<fapi2::TARGET_TYPE_CORE>(); -/// -/// // Get all of the the cores relative to my base target -/// fapi2::getChildren<fapi2::TARGET_TYPE_CORE>(); -/// @endcode -/// -/// * Invalid casts -/// @code -/// // Can't cast to a specialized target -/// fapi2::Target<fapi2::TARGET_TYPE_NONE> D(MEMBUF_CHIP_B); -/// takesProcOrMembuf( D ); -/// -/// // Not one of the shared types -/// fapi2::Target<fapi2::TARGET_TYPE_ABUS_ENDPOINT> E; -/// takesProcOrMembuf( E ); -/// @endcode -template<TargetType K, typename V = plat_target_handle_t> -class Target -{ - public: - - /// - /// @brief Delagate default constructor to constructor - /// that takes in a value as a param - /// - Target(): Target(V()) - {}; - - /// - /// @brief Create a Target, with a value - /// @param[in] Value the value (i.e., specific element this - /// target represents, or pointer) - /// @note Platforms can mangle the value and K to get a - /// single uint64_t in value which represents all the information - /// they might need. value( K | V ), for example - /// - Target(const V& Value): - iv_handle(Value) - {}; - - - /// - /// @brief Assignment Operator. - /// @param[in] i_right Reference to Target to assign from. - /// @return Reference to 'this' Target - /// - Target& operator=(const Target& i_right); - - /// - /// @brief Equality Comparison Operator - /// @param[in] i_right Reference to Target to compare. - /// @return bool. True if equal. - /// @note Platforms need to define this so that the physical - /// targets are determined to be equivilent rather than just the handles - /// - bool operator==(const Target& i_right) const; - - /// - /// @brief Inquality Comparison Operator - /// @param[in] i_right Reference to Target to compare. - /// @return bool. True if not equal. - /// @note Platforms need to define this so that the physical - /// targets are determined to be equivilent rather than just the handles - /// - bool operator!=(const Target& i_right) const; - - /// - /// @brief Less Than Comparison Operator - /// @param[in] i_right Reference to Target to compare. - /// @return bool. True if less than i_right. - /// @note Platforms need to define this so that the physical - /// targets are determined to be less than rather than just the handles - /// - bool operator<(const Target& i_right) const; - - /// - /// @brief Get the handle. - /// @return V The target's handle, or value - /// - V get(void) const - { - return iv_handle; - } - - /// - /// @brief Get the handle as a V - /// @return V The target's handle, or value - /// - inline operator V() const - { - return iv_handle; - } - - /// - /// @brief Get a target's value - /// @return V The target's handle, or value - /// - inline V& operator()(void) - { - return iv_handle; - } - - /// - /// @brief Get the target type - /// @return The type of target represented by this target - /// - inline TargetType getType(void) const - { - return iv_type; - } - - /// - /// @brief Get this target's immediate parent - /// @tparam T The type of the parent - /// @return Target<T> a target representing the parent - /// - template< TargetType T > - inline Target<T, V> getParent(void) const; - - /// - /// @brief Is this target a chip? - /// @return Return true if this target is a chip, false otherwise - /// - inline constexpr bool isChip(void) const - { - return (isChip(K)); - } - - /// - /// @brief Static function check if a Target type value is that of - /// a chip. It will return false for compound types that - /// include non-chip Target type bits - /// - /// @param[in] i_type The value of the Target type. - /// @return Return true if this type is of a chip, false otherwise - /// - static inline bool isChip(const TargetType i_type) - { - bool l_retVal = false; - - // Target type must have only chip type bits set - if ( ((i_type & TARGET_TYPE_CHIPS) != 0) && - ((i_type & ~TARGET_TYPE_CHIPS) == 0) ) - { - l_retVal = true; - } - - return l_retVal; - } - - /// - /// @brief Is this target a chiplet? - /// @return Return true if this target is a chiplet, false otherwise - /// - inline constexpr bool isChiplet(void) const - { - return (isChiplet(K)); - } - - /// - /// @brief Static function check if a Target type value is that of - /// a chiplet. It will return false for compound types that - /// include non-chiplet Target type bits - /// - /// @param[in] i_type The value of the Target type. - /// @return Return true if this type is of a chiplet, false otherwise - /// - static inline bool isChiplet(const TargetType i_type) - { - bool l_retVal = false; - - // Target type must have only chiplet type bits set - if ( ((i_type & TARGET_TYPE_CHIPLETS) != 0) && - ((i_type & ~TARGET_TYPE_CHIPLETS) == 0) ) - { - l_retVal = true; - } - - return l_retVal; - } - - /// - /// @brief Get this target's children - /// @tparam T The type of the parent - /// @param[in] i_state The desired TargetState of the children - /// @return std::vector<Target<T,V>> a vector of present/functional - /// children - /// @warning The children of EX's (cores) are expected to be returned - /// in order. That is, core 0 is std::vector[0]. - /// - template< TargetType T> - inline std::vector<Target<T, V> > - getChildren(const TargetState i_state = TARGET_STATE_FUNCTIONAL) const; - - /// - /// @brief Get this target's children, filtered - /// @tparam T The type of the parent - /// @param[in] i_filter The desired chiplet filter - /// @param[in] i_state The desired TargetState of the children - /// @return std::vector<Target<T,V>> a vector of present/functional - /// children - /// - template< TargetType T> - inline std::vector<Target<T, V> > - getChildren(const TargetFilter i_filter, - const TargetState i_state = TARGET_STATE_FUNCTIONAL) const; - - /// - /// @brief Get the target at the other end of a bus - /// @tparam T The type of the target on the other end - /// @param[out] o_target A target representing the thing on the other end - /// @param[in] i_state The desired TargetState of the other end - /// @return FAPI2_RC_SUCCESS if OK, platforms will return a non-success - /// ReturnCode in the event of failure - /// @note o_target is only valid if return is FAPI2_RC_SUCCESS - /// - - template<TargetType T> - inline fapi2::ReturnCodes - getOtherEnd(Target<T, V>& o_target, const TargetState i_state = TARGET_STATE_FUNCTIONAL) const; - - /// - /// @brief Is the target functional? - /// @return true if target is functional, false if non-functional - /// - - inline bool - isFunctional(void) const; - - /// - /// @brief Returns the chiplet number associated with the Target - /// @return The chiplet number for the Target. 0 is returned if the - /// Target does not have a chiplet number (for ex, the PROC_CHIP Target) - /// @note For logical targets such as the EX, the chiplet number of - /// their immediate parent chiplet is returned - /// - inline uint8_t - getChipletNumber(void) const; - - /// - /// @brief Copy from a Target<O> to a Target<K> - /// @tparam O the target type of the other - /// - template<TargetType O, typename VO> - inline Target( const Target<O, VO>& Other ): - Target<K, V>(Other.get()) - { - // In case of recursion depth failure, use -ftemplate-depth= - static_assert( (K & O) != 0, - "unable to cast Target, no shared types"); - - static_assert( bitCount<K>::count >= bitCount<O>::count, - "unable to cast to specialized Target"); - } - - private: - // Don't use enums here as it makes it hard to assign - // in the platform target cast constructor. - static const TargetType iv_type = K; - V iv_handle; - -}; - -// EX threads map to CORE threads: -// t0 / t2 / t4 / t6 fused = t0 / t1 / t2 / t3 normal (c0) -// t1 / t3 / t5 / t7 fused = t0 / t1 / t2 / t3 normal (c1) -// So when splitting the EX, we need to map from EX threads -// to CORE threads. - -/// -/// @brief Given a normal core thread id, translate this to -/// a fused core thread id. (normal to fused) -/// @param[in] i_ordinal the ordinal number of the normal core this thread belongs to -/// @param[in] i_thread_id a normal core thread id - 0, ..., 3 -/// @return the fused core thread id -/// -inline uint8_t thread_id_n2f(const uint8_t i_ordinal, const uint8_t i_thread_id) -{ - return (i_thread_id << 1) | i_ordinal; -} - -/// -/// @brief Given a fused core thread id, translate this to -/// a normal core thread id. (fused to normal) -/// @param[in] i_thread_id a fused core thread id - 0, ..., 7 -/// @return the normal core thread id -/// -inline uint8_t thread_id_f2n(const uint8_t i_thread_id) -{ - return i_thread_id >> 1; -} - -/// -/// @brief Given a normal core thread id, translate this to a -/// normal core bitset. -/// @param[in] i_thread_id a normal core thread id - 0, ..., 3 -/// @return the normal core bitset -/// @note to got from a fused core id to a normal core bitset, -/// translate from a fused core thread id first. -/// -inline uint8_t thread_id2bitset(const uint8_t i_thread_id) -{ - // 0xff means "set all bits" - static const uint8_t all_threads = 0xff; - static const uint8_t all_normal_threads_bitset = 0x0f; - - if (i_thread_id == all_threads) - { - return all_normal_threads_bitset; - } - - // A thread_id is really just bit index. - return (1 << (4 - i_thread_id - 1)); -} - -/// -/// @brief Given a bitset of normal core thread ids, translate this to -/// a bit mask of fused core thread id. (normal to fused) -/// @param[in] i_ordinal the ordinal number of the normal core this thread belongs to -/// @param[in] i_threads a normal core thread bitset - b0000, ..., b1111 -/// @return the corresponding fused core bitset -/// -inline uint8_t thread_bitset_n2f(const uint8_t i_ordinal, const uint8_t i_threads) -{ - // Since we only have 4 bits I think this is better than a shift-type solution - // for interleaving bits - static uint8_t core_map[] = - { - 0b00000000, // b0000 - 0b00000010, // b0001 - 0b00001000, // b0010 - 0b00001010, // b0011 - 0b00100000, // b0100 - 0b00100010, // b0101 - 0b00101000, // b0110 - 0b00101010, // b0111 - 0b10000000, // b1000 - 0b10000010, // b1001 - 0b10001000, // b1010 - 0b10001010, // b1011 - 0b10100000, // b1100 - 0b10100010, // b1101 - 0b10101000, // b1110 - 0b10101010, // b1111 - }; - - return core_map[i_threads] >> i_ordinal; -} - -/// -/// @brief Given a fused core thread bitset, translate this to -/// a normal core thread bitset. (fused to normal) -/// @param[in] i_ordinal the ordinal number of the normal core this thread belongs to -/// @param[in] i_threads a fused core thread bitset - b00000000, ..., b11111111 -/// @return the corresponding normal core bitset -/// -inline uint8_t thread_bitset_f2n(const uint8_t i_ordinal, const uint8_t i_threads) -{ - uint8_t normal_set = 0; - - // core 0 is the left-most bit in the pair - uint8_t pair_mask = (i_ordinal == 0) ? 0x2 : 0x1; - - // For each bit which can be set in the normal core bit_set ... - for( auto i = 0; i <= 3; ++i ) - { - // ... grab the two fused bits which represent it ... - // ... and mask off the bit in the pair which represents this normal core ... - // (the << 1 shifts the masks over as we walk the pairs of bits) - uint8_t bits = (((3 << (i << 1)) & i_threads) & (pair_mask << (i << 1))); - - // ... if either bit is set, set the corresponding bit in - // the normal core bitset. - normal_set |= (bits != 0) << i; - } - - return normal_set; -} - -/// -/// @brief Return the string interpretation of this target -/// @tparam T The type of the target -/// @param[in] i_target Target<T,V> -/// @param[in] i_buffer buffer to write in to -/// @param[in] i_bsize size of the buffer -/// @return void -/// @post The contents of the buffer is replaced with the string -/// representation of the target -/// -template< TargetType T, typename V > -inline void toString(const Target<T, V>& i_target, char* i_buffer, size_t i_bsize); - -/// -/// @brief Return the string interpretation of this target -/// @tparam T The type of the target -/// @tparam B The type of the buffer -/// @param[in] i_target A pointer to the Target<T,V> -/// @param[in] i_buffer buffer to write in to -/// @param[in] i_bsize size of the buffer -/// @return void -/// @post The contents of the buffer is replaced with the string -/// representation of the target -/// -template< TargetType T, typename V > -inline void toString(const Target<T, V>* i_target, char* i_buffer, size_t i_bsize); - -/// -/// @brief Get an enumerated target of a specific type -/// @tparam T The type of the target -/// @param[in] Ordinal representing the ordinal number of -/// the desired target -/// @return Target<T> the target requested -/// -template<TargetType T, typename V = plat_target_handle_t> -inline Target<T, V> getTarget(uint64_t Ordinal); - -// Why has the been removed? For starters, the API name -// is probably wrong as it's already been confused with -// Target::getChildren(). And if I'm going to change it -// I really want to see if we need it. I'm still not -// clear on whether we're alloing this traversal or not. -#if 0 -/// -/// @brief Get the base target's children -/// @tparam T The type of the target -/// @return std::vector<Target<T,V>> a vector of present/functional -/// children -/// -template<TargetType T, typename V> -inline std::vector<Target<T, V>> getChildren() -{ - // For testing - return {Target<T, V>(), Target<T, V>()}; -} -#endif - -/// -/// @brief Return the string interpretation of this target -/// @tparam T The type of the target -/// @tparam B The type of the buffer -/// @param[in] i_target Target<T,V> -/// @param[in] i_buffer buffer -/// @return void -/// @post The contents of the buffer is replaced with the string -/// representation of the target -/// -template<TargetType T, typename V, typename B> -inline void toString(const Target<T, V>& i_target, B& i_buffer); - -/// -/// @brief Check if the target is of a type, or in a type subset. -/// @tparam K the TargetType to check -/// @tparam T TargetType or TargetType composite to check against -/// @return True, iff K is a proper T -/// -template< TargetType K, TargetType T > -inline constexpr bool is_same(void) -{ - return (K & T) != 0; -} -} - -#endif diff --git a/import/hwpf/fapi2/include/fapi2_vpd_access.H b/import/hwpf/fapi2/include/fapi2_vpd_access.H deleted file mode 100644 index d5b946b0..00000000 --- a/import/hwpf/fapi2/include/fapi2_vpd_access.H +++ /dev/null @@ -1,96 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/fapi2_vpd_access.H $ */ -/* */ -/* OpenPOWER sbe Project */ -/* */ -/* Contributors Listed Below - COPYRIGHT 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 fapi2_vpd_access.H -/// @brief Common file that defines the vpd access functions that -/// platform code must implement. -/// -// - -#ifndef _FAPI2_VPDACCESS_H_ -#define _FAPI2_VPDACCESS_H_ - -#include <return_code.H> -#include <target_types.H> -#include <vpd_access_defs.H> -#include <plat_vpd_access.H> - -namespace fapi2 -{ - -/// constants for VPD Info -constexpr uint64_t VPD_INFO_INVALID = 0xffffffffffffffff; - -/// @brief Specialized class representing required VPDInfo to be used -/// in collecting VPD for the MCS target type. -/// @tparam T fapi2::TARGET_TYPE_MCS -template<> -class VPDInfo<TARGET_TYPE_MCS> -{ - public: - // @brief VPDInfo constructor - VPDInfo( const fapi2::MemVpdData& i_vpd_type) - : iv_vpd_type(i_vpd_type), - iv_size(VPD_INFO_INVALID), - iv_freq_mhz(VPD_INFO_INVALID), - iv_rank_count_dimm_0(VPD_INFO_INVALID), - iv_rank_count_dimm_1(VPD_INFO_INVALID) - {}; - // type of vpd field to return - fapi2::MemVpdData_t iv_vpd_type; - - // size of the vpd data - size_t iv_size; - uint64_t iv_freq_mhz; - uint64_t iv_rank_count_dimm_0; - uint64_t iv_rank_count_dimm_1; - -}; - - -/// @brief Return a blob of memory VPD data associated with the input target -/// @param[in] i_target a valid fapi2 target -/// @param[in] io_vpd_info fapi2::VPDInfo class that specifies which piece of data to return -/// @param[out] o_blob the blob of raw data from the vpd -/// @return FAPI2_RC_SUCCESS if there's no problem -/// @note passing nullptr for o_blob will return the size of the keyword -/// -/// Example: -/// fapi2::VPDInfo<fapi2::TARGET_TYPE_MCS> vpdInfo(MR_keyword); -/// vpdInfo.iv_freq = 2667; -/// -/// uint8_t * blob = NULL; -/// -/// FAPI_TRY(getVPD( mcs, vpdInfo, blob )); -/// blob = static_cast<uint8_t *>(malloc(vpdInfo.iv_size)); -/// FAPI_TRY(getVPD( mcs, vpdInfo, blob )); -/// blob now contains the VPD data for the MCS. -/// -template<TargetType T, typename V> -ReturnCode getVPD(const Target<T, V>& i_target, - VPDInfo<T>& io_vpd_info, - uint8_t* o_blob); - -}; -#endif diff --git a/import/hwpf/fapi2/include/ffdc.H b/import/hwpf/fapi2/include/ffdc.H deleted file mode 100644 index 82483d54..00000000 --- a/import/hwpf/fapi2/include/ffdc.H +++ /dev/null @@ -1,238 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/ffdc.H $ */ -/* */ -/* OpenPOWER sbe 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 ffdc.H - * @brief Defines the FirstFailureData class - */ - -#ifndef FAPI2_FFDC_H_ -#define FAPI2_FFDC_H_ - -#include <memory> -#include <hwp_return_codes.H> -#include <return_code_defs.H> -#include <plat_trace.H> -#include <error_info.H> -#include <target.H> - -using fapi2::TARGET_TYPE_ALL; - -namespace fapi2 -{ -/// -/// @brief Check the type of a variable -/// -/// This function can be called to check that a variable type is as expected -/// @note This mechanism will allow for cast ctor's which other static type -/// checking might not. -/// -template<typename T> -inline -void checkType(const T&) {} - -class ReturnCode; - -/// -/// @class FirstFailureData -/// -/// This class provides storage and methods for creating and manipulating -/// FFDC. -/// It is not needed on all platforms - platforms which need this class have -/// specified this by forcing their fapi2::ReturnCode to be a subclass of -/// this class. -/// -template< class R = fapi2::ReturnCode > -class FirstFailureData -{ - public: - - /// - /// @brief Default constructor. - /// @note We don't create our error info by default. It will be created - /// when its needed in the setHwpError() method. Note that dereferencing - /// the error info without first calling setHwpError() will create a - // problem. - /// - FirstFailureData(void): - iv_info( nullptr ), iv_platDataPtr(nullptr) - {} - - /// - /// @brief Copy Constructor - /// - /// @param[in] i_right Reference to FirstFailureData to copy - /// @note Generates default copy constructor - no deep pointer - /// copies necessary. - /// - FirstFailureData(const FirstFailureData& i_right) = default; - - /// - /// @brief Destructor - /// - ~FirstFailureData(void) = default; - - /// - /// @brief Assignment Operator. - /// - /// @param[in] i_right Reference to FirstFailureData to assign from. - /// @return Reference to 'this' FirstFailureData - /// - FirstFailureData& operator=(const FirstFailureData& i_right) = default; - - /// - /// @brief Sets a HWP error. Sets the rcValue to the supplied value (from - /// the HwpFirstFailureData enumeration) and deletes any - /// associated data. - /// - /// HWP code must call the FAPI_SET_HWP_ERROR macro rather than this - /// function - /// directly to generate an error so that any error information is - /// automatically added to the FirstFailureData - /// - /// @param[in] i_rcValue Error value to set - /// - inline void _setHwpError(const fapi2::HwpReturnCode i_rcValue) - { - FAPI_ERR("_setHwpError: Creating HWP error 0x%x", i_rcValue); - static_cast<R*>(this)->operator=(i_rcValue); - - // Forget about any associated data (this is a new error) - iv_info.reset( new ErrorInfo()); - - } - - /// - /// @return void *. Pointer to error info data. If NULL then no data - /// - void* getData(void) const; - - /// - /// @brief Get a pointer to any error info and release ownership from - /// FirstFailureData. The caller is responsible for deletion. - /// - /// This is called by PLAT. The expected use-case is to retrieve a - /// platform error log. - /// - /// @return void*. Pointer to any Error data. If NULL then no data - /// - inline void* releaseData(void) - { - void* l_pData = iv_info; - iv_info = NULL; - return l_pData; - } - - /// - /// @brief Add ErrorInfo - /// - /// This is called by the FAPI_SET_HWP_ERROR and macro to add ErrorInfo - /// to the FirstFailureData when a HWP generates an error. The function - /// is designed to add all the ErrorInfo at once rather than the - /// FAPI_SET_HWP_ERROR macro making multiple function calls to add each - /// piece of ErrorInfo individually in order to minimize code size - /// - /// @param[in] i_pObjects Pointer to array of const pointers to const - /// objects that are referred to by ErrorInfoEntry objects - /// @param[in] i_pEntries Pointer to array of ErrorInfoEntry objects - /// defining the ErrorInfo that needs to be added - /// @param[in] i_count Number of ErrorInfoEntry entries - /// - void addErrorInfo(const void* const* i_pObjects, - const ErrorInfoEntry* i_pEntries, - const uint8_t i_count); - - - /// - /// @brief Add ErrorInfo - /// - /// This is called by the collectFfdc and collectRegFfdc functions - /// following the call to actually collect the ffdc data, the ffdc - /// collection functions return a vector of shared pointers to the - /// ErrorInfoFfdc objects - /// - /// @param[in] i_errorInfo - vector of shared pointers to - /// errorInfoFfdc objects - /// - inline void addErrorInfo(std::vector<std::shared_ptr<ErrorInfoFfdc>>& i_errorInfo) - { - for( auto p : i_errorInfo ) - { - iv_info->iv_ffdcs.push_back(p); - } - }; - - /// - /// @brief Get a pointer to any ErrorInfo - /// - /// This is called by PLAT to find information about an error - /// - /// @return ErrorInfo *. Pointer to any ErrorInfo. If NULL then no info - /// - inline const fapi2::ErrorInfo* getErrorInfo(void) const - { - return iv_info.get(); - } - - /// - /// @brief Forgets about any associated data (PlatData and ErrorInfo) - /// - /// If this is the only FirstFailureData pointing to the data then the - /// data is deleted - /// - inline void forgetData(void) - { - iv_info = nullptr; - } - - /// - /// @brief Returns the platform data pointer value to the caller. - /// - inline void* getPlatDataPtr() - { - return iv_platDataPtr; - }; - - /// - /// @brief Sets objects platform data pointer to the passed in value. - /// - /// - inline void setPlatDataPtr( void* i_ptr ) - { - static_cast<R*>(this)->operator=(FAPI2_RC_PLAT_ERR_SEE_DATA); - iv_platDataPtr = i_ptr; - }; - - - protected: - // Pointer to the error info - std::shared_ptr<ErrorInfo> iv_info; - - private: - // free format data, to be used by the platform - void* iv_platDataPtr; -}; - -} -#endif // FAPI2_FFDC_H_ diff --git a/import/hwpf/fapi2/include/hw_access_def.H b/import/hwpf/fapi2/include/hw_access_def.H deleted file mode 100644 index 9d67961c..00000000 --- a/import/hwpf/fapi2/include/hw_access_def.H +++ /dev/null @@ -1,83 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/hw_access_def.H $ */ -/* */ -/* OpenPOWER sbe 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 hw_access_def.H -/// @brief Hardware access definitions -/// - -#ifndef FAPI2_HWACCESSDEF_H_ -#define FAPI2_HWACCESSDEF_H_ - -#include <stdint.h> - -/// @cond -typedef uint64_t spyId_t; -typedef uint64_t scanRingId_t; -/// @endcond - -namespace fapi2 -{ -/// -/// @enum fapi2::ChipOpModifyMode -/// @brief Enumeration of modify modes used in HW access modify operations -/// -enum ChipOpModifyMode -{ - CHIP_OP_MODIFY_MODE_OR = 1, ///< Modify or mode - CHIP_OP_MODIFY_MODE_AND = 2, ///< Modify and mode - CHIP_OP_MODIFY_MODE_XOR = 3, ///< Modify xor mode -}; - -/// -/// @enum fapi2::RingMode -/// @brief Enumeration of Ring access operation modes -/// This is a bitmap to allow the user to specify multiple modes. -/// -enum RingMode -{ - RING_MODE_HEADER_CHECK = 0x00000000, ///< Check header - RING_MODE_SET_PULSE_NO_OPCG_COND = 0x00000001, ///< Set pulse with - /// no OPCG conditioning - RING_MODE_NO_HEADER_CHECK = 0x00000002, ///< Don't check header - RING_MODE_SET_PULSE_NSL = 0x00000004, ///< Set pulse with NSL - /// pulse - RING_MODE_SET_PULSE_SL = 0x00000008, ///< Set pulse with SL - /// pulse - RING_MODE_SET_PULSE_ALL = 0x00000010, ///< Set pulse with pulse - /// to all hold types -}; - -/// @enum OpModes operational Mode Error Functions -enum OpModes -{ - // These are bit-masks in case they need to be or'd together - NORMAL = 0x00, - IGNORE_HW_ERROR = 0x01, - DO_NOT_DO_WAKEUP = 0x02, -}; - -} - -#endif diff --git a/import/hwpf/fapi2/include/mvpd_access.H b/import/hwpf/fapi2/include/mvpd_access.H deleted file mode 100644 index 532b32ee..00000000 --- a/import/hwpf/fapi2/include/mvpd_access.H +++ /dev/null @@ -1,87 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/mvpd_access.H $ */ -/* */ -/* OpenPOWER sbe 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 mvpd_access.H -/// -/// @brief Defines the Module VPD functions that platform must implement -/// - -#ifndef _FAPI2_MVPDACCESS_H_ -#define _FAPI2_MVPDACCESS_H_ - -#include <stdint.h> -#include <return_code.H> -#include <target.H> -#include <mvpd_access_defs.H> - -namespace fapi2 -{ -/// -/// @brief Get Module VPD field. -/// -/// A Module VPD field is specified using a record and keyword enumerator -/// -/// Suggested way to call this routine is to call it once with a NULL buffer -/// pointer to to retrieve the size of the record, then allocate the proper -/// size of the buffer and call again. -/// -/// @param[in] i_record Record enumerator -/// @param[in] i_keyword Keyword enumerator -/// @param[in] i_target Reference to processor chip target for the record -/// @param[in] i_pBuffer Pointer to buffer where record will be stored. If -/// NULL then the size of record will be stored in -/// io_fieldSize -/// @param[in,out] io_fieldSize Size of i_pBuffer in bytes -/// -/// @return fapi2::ReturnCode. FAPI_RC_SUCCESS, or failure value. -/// -ReturnCode getMvpdField(const MvpdRecord i_record, - const MvpdKeyword i_keyword, - const Target<TARGET_TYPE_PROC_CHIP>& i_target, - uint8_t* const i_pBuffer, - uint32_t& io_fieldSize); - -/// -/// @brief Set Module VPD field. -/// -/// A Module VPD field is specified using a record and keyword enumerator -/// -/// @param[in] i_record Record enumerator -/// @param[in] i_keyword Keyword enumerator -/// @param[in] i_target Reference to processor chip target for the record -/// @param[in] i_pBuffer Pointer to buffer where data to set is stored -/// @param[in] i_fieldSize Size of i_pBuffer in bytes -/// -/// @return fapi2::ReturnCode. FAPI_RC_SUCCESS, or failure value. -/// -ReturnCode setMvpdField(const MvpdRecord i_record, - const MvpdKeyword i_keyword, - const Target<TARGET_TYPE_PROC_CHIP>& i_target, - const uint8_t* const i_pBuffer, - const uint32_t i_fieldSize); -} - -#endif diff --git a/import/hwpf/fapi2/include/mvpd_access_defs.H b/import/hwpf/fapi2/include/mvpd_access_defs.H deleted file mode 100644 index a1a4aaff..00000000 --- a/import/hwpf/fapi2/include/mvpd_access_defs.H +++ /dev/null @@ -1,121 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/mvpd_access_defs.H $ */ -/* */ -/* OpenPOWER sbe 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 mvpd_access_defs.H -/// -/// @brief Defines the Module VPD Records and Keywords -/// - -#ifndef _FAPI2_MVPDACCESS_DEFS_H_ -#define _FAPI2_MVPDACCESS_DEFS_H_ - -namespace fapi2 -{ -enum MvpdRecord -{ - MVPD_RECORD_CRP0 = 0x00, - MVPD_RECORD_CP00 = 0x01, - MVPD_RECORD_VINI = 0x02, - MVPD_RECORD_LRP0 = 0x03, - MVPD_RECORD_LRP1 = 0x04, - MVPD_RECORD_LRP2 = 0x05, - MVPD_RECORD_LRP3 = 0x06, - MVPD_RECORD_LRP4 = 0x07, - MVPD_RECORD_LRP5 = 0x08, - MVPD_RECORD_LRP6 = 0x09, - MVPD_RECORD_LRP7 = 0x0a, - MVPD_RECORD_LRP8 = 0x0b, - MVPD_RECORD_LRP9 = 0x0c, - MVPD_RECORD_LRPA = 0x0d, - MVPD_RECORD_LRPB = 0x0e, - MVPD_RECORD_LRPC = 0x0f, - MVPD_RECORD_LRPD = 0x10, - MVPD_RECORD_LRPE = 0x11, - MVPD_RECORD_LWP0 = 0x12, - MVPD_RECORD_LWP1 = 0x13, - MVPD_RECORD_LWP2 = 0x14, - MVPD_RECORD_LWP3 = 0x15, - MVPD_RECORD_LWP4 = 0x16, - MVPD_RECORD_LWP5 = 0x17, - MVPD_RECORD_LWP6 = 0x18, - MVPD_RECORD_LWP7 = 0x19, - MVPD_RECORD_LWP8 = 0x1a, - MVPD_RECORD_LWP9 = 0x1b, - MVPD_RECORD_LWPA = 0x1c, - MVPD_RECORD_LWPB = 0x1d, - MVPD_RECORD_LWPC = 0x1e, - MVPD_RECORD_LWPD = 0x1f, - MVPD_RECORD_LWPE = 0x20, - MVPD_RECORD_VWML = 0x21, - MVPD_RECORD_MER0 = 0x22, - MVPD_RECORD_LAST, //useful for testcases - MVPD_RECORD_FIRST = MVPD_RECORD_CRP0, //useful for testcases -}; - -enum MvpdKeyword -{ - MVPD_KEYWORD_VD = 0x00, - MVPD_KEYWORD_ED = 0x01, - MVPD_KEYWORD_TE = 0x02, - MVPD_KEYWORD_DD = 0x03, - MVPD_KEYWORD_PDP = 0x04, - MVPD_KEYWORD_ST = 0x05, - MVPD_KEYWORD_DN = 0x06, - MVPD_KEYWORD_PG = 0x07, - MVPD_KEYWORD_PK = 0x08, - MVPD_KEYWORD_PDR = 0x09, - MVPD_KEYWORD_PDV = 0x0a, - MVPD_KEYWORD_PDH = 0x0b, - MVPD_KEYWORD_SB = 0x0c, - MVPD_KEYWORD_DR = 0x0d, - MVPD_KEYWORD_VZ = 0x0e, - MVPD_KEYWORD_CC = 0x0f, - MVPD_KEYWORD_CE = 0x10, - MVPD_KEYWORD_FN = 0x11, - MVPD_KEYWORD_PN = 0x12, - MVPD_KEYWORD_SN = 0x13, - MVPD_KEYWORD_PR = 0x14, - MVPD_KEYWORD_HE = 0x15, - MVPD_KEYWORD_CT = 0x16, - MVPD_KEYWORD_HW = 0x17, - MVPD_KEYWORD_PDM = 0x18, - MVPD_KEYWORD_IN = 0x19, - MVPD_KEYWORD_PD2 = 0x1a, - MVPD_KEYWORD_PD3 = 0x1b, - MVPD_KEYWORD_OC = 0x1c, - MVPD_KEYWORD_FO = 0x1d, - MVPD_KEYWORD_PDI = 0x1e, - MVPD_KEYWORD_PDG = 0x1f, - MVPD_KEYWORD_MK = 0x20, - MVPD_KEYWORD_PB = 0x21, - MVPD_KEYWORD_CH = 0x22, - MVPD_KEYWORD_IQ = 0x23, - MVPD_KEYWORD_LAST, //useful for testcases - MVPD_KEYWORD_FIRST = MVPD_KEYWORD_VD, //useful for testcases -}; -} - -#endif diff --git a/import/hwpf/fapi2/include/plat/hw_access.H b/import/hwpf/fapi2/include/plat/hw_access.H deleted file mode 100644 index fbe8ae6e..00000000 --- a/import/hwpf/fapi2/include/plat/hw_access.H +++ /dev/null @@ -1,560 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/plat/hw_access.H $ */ -/* */ -/* OpenPOWER sbe 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 hw_access.H -/// -/// @brief Hardware access functions that needs to be specialized for -/// platform implementation. -/// - -#ifndef _FAPI2_HWACCESS_H_ -#define _FAPI2_HWACCESS_H_ - -// variable_buffer isn't supported on PPE -#ifndef __PPE__ - #include <variable_buffer.H> -#endif - -#include <plat_hw_access.H> -#include <fapi2_hw_access.H> - -namespace fapi2 -{ -//-------------------------------------------------------------------------- -// PIB Error Functions -//-------------------------------------------------------------------------- - -/// @brief Sets the PIB error mask - platform dependant -/// @param[in] i_mask The new error mask -// note: this can be moved to a C file if desired -inline void setPIBErrorMask(uint8_t i_mask) -{ - // Keeps the compiler from complaining about the unused i_mask - static_cast<void>(i_mask); - - return; -} - -/// @brief Gets the PIB error mask - platform dependant -/// @return uint8_t The current PIB error mask -// note: this can be moved to a C file if desired -inline uint8_t getPIBErrorMask(void) -{ - return 0; -} - -//-------------------------------------------------------------------------- -// Operational Mode Error Functions -//-------------------------------------------------------------------------- - -/// @brief Sets the operational mode -/// @param[in] i_mode The new mode -// note: this can be moved to a C file if desired -inline void setOpMode(const OpModes i_mode) -{ - // Keeps the compiler from complaining about the unused i_mode - static_cast<void>(i_mode); - - // No-op for now. Should set thread-local operational mode - return; -} - -/// @brief Gets the operational mode -/// @return the operational mode -// note: this can be moved to a C file if desired -inline OpModes getOpMode(void) -{ - // No-op for now. Should read thread-local operational mode - return NORMAL; -} - -//------------------------------------------------------------------------------ -// HW Communication Functions to be implemented at the platform layer. -//------------------------------------------------------------------------------ - -/// -/// @brief Platform-level implementation of getScom() -/// @tparam K template parameter, passed in target. -/// @param[in] i_target HW target to operate on. -/// @param[in] i_address SCOM register address to read from. -/// @param[out] o_data Buffer that holds data read from HW target. -/// @return fapi::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -/// -template< TargetType K, typename V > -inline ReturnCode getScom(const Target<K, V>& i_target, - const uint64_t i_address, - buffer<uint64_t>& o_data) -{ - o_data = 0x0000FEEDFACE0000; - std::cout << std::hex << " getScom " - << "target: {" << i_target.getType() << "," - << uint64_t(i_target) << "}; " - << "address: " << i_address << "; " - << "output data: " << uint64_t(o_data) - << std::dec << std::endl; - - return FAPI2_RC_SUCCESS; -} - -/// @brief Platform-level implementation of putScom() -/// @tparam K template parameter, passed in target. -/// @param[in] i_target HW target to operate on. -/// @param[in] i_address SCOM register address to write to. -/// @param[in] i_data Buffer that holds data to write into address. -/// @return fapi::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -template< TargetType K, typename V > -inline ReturnCode putScom(const Target<K, V>& i_target, - const uint64_t i_address, - const buffer<uint64_t> i_data) -{ - std::cout << std::hex << " putScom " - << "target: {" << i_target.getType() << "," - << uint64_t(i_target) << "}; " - << "address: " << i_address << "; " - << "input data: " << uint64_t(i_data) - << std::dec << std::endl; - return FAPI2_RC_SUCCESS; -} - -/// @brief Platform-level implementation of putScomUnderMask() -/// @tparam K template parameter, passed in target. -/// @param[in] i_target HW target to operate on. -/// @param[in] i_address SCOM register address to write to. -/// @param[in] i_data Buffer that holds data to write into address. -/// @param[in] i_mask Buffer that holds the mask value. -/// @return fapi::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -template< TargetType K, typename V > -inline ReturnCode putScomUnderMask(const Target<K, V>& i_target, - const uint64_t i_address, - const buffer<uint64_t> i_data, - const buffer<uint64_t> i_mask) -{ - std::cout << std::hex << " putScomUnderMask " - << "target: {" << i_target.getType() << "," - << uint64_t(i_target) << "}; " - << "address: " << i_address << "; " - << "input data: " << uint64_t(i_data) << "; " - << "input mask: " << uint64_t(i_mask) - << std::dec << std::endl; - return FAPI2_RC_SUCCESS; -} - -/// -/// @brief Platform-level implementation called by getCfamRegister() -/// Hardware procedures writers will not call this function. -/// @tparam K template parameter, passed in target. -/// @param[in] i_target HW target to operate on. -/// @param[in] i_address CFAM address to read from. -/// @param[out] o_data 32-bit buffer that holds data read from HW target. -/// @return fapi::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -/// -template< TargetType K, typename V > -inline ReturnCode getCfamRegister(const Target<K, V>& i_target, - const uint32_t i_address, - buffer<uint32_t>& o_data) -{ - o_data = 0xFEED0CFA; - std::cout << std::hex << " getCfamRegister " - << "target: {" << i_target.getType() << "," - << uint64_t(i_target) << "}; " - << "address: " << i_address << "; " - << "output data: " << uint32_t(o_data) - << std::dec << std::endl; - return FAPI2_RC_SUCCESS; -} - -/// -/// @brief Platform-level implementation of putCfamRegister() -/// Hardware procedures writers will not call this function. -/// @tparam K template parameter, passed in target. -/// @param[in] i_target HW target to operate on. -/// @param[in] i_address CFAM address to write to. -/// @param[out] i_data 32-bit buffer that holds data to write into address. -/// @return fapi::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -/// -template< TargetType K, typename V > -inline ReturnCode putCfamRegister(const Target<K, V>& i_target, - const uint32_t i_address, - const buffer<uint32_t> i_data) -{ - std::cout << std::hex << " putCfamRegister " - << "target: {" << i_target.getType() << "," - << uint64_t(i_target) << "}; " - << "address: " << i_address << "; " - << "input data: " << uint32_t(i_data) - << std::dec << std::endl; - return FAPI2_RC_SUCCESS; -} - - -/// -/// @brief Platform-level implementation of modifyCfamRegister() -/// Hardware procedures writers will not call this function. -/// @tparam K template parameter, passed in target. -/// @param[in] i_target HW target to operate on. -/// @param[in] i_address CFAM register address to modify. -/// @param[out] i_data 32-bit buffer that holds data to modify. -/// @param[in] i_modifyMode The modify mode (or/and/xor). -/// @return fapi::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -/// -template< TargetType K, typename V > -inline ReturnCode modifyCfamRegister(const Target<K, V>& i_target, - const uint32_t i_address, - const buffer<uint32_t> i_data, - const fapi2::ChipOpModifyMode i_modifyMode) -{ - std::cout << std::hex << " modifyCfamRegister " - << "target: {" << i_target.getType() << "," - << uint64_t(i_target) << "}; " - << "address: " << i_address << "; " - << "input modifying data: " << uint32_t(i_data) << "; " - << "input ChipOpModifyMode: " << i_modifyMode - << std::dec << std::endl; - return FAPI2_RC_SUCCESS; -} - -/// @brief Platform-level implementation of putRing() -/// Hardware procedures writers will not call this function. -/// @tparam K template parameter, passed in target. -/// @param[in] i_target Target to operate on. -/// @param[in] i_ringID Ring ID that will identify the Ring in the image. -/// @param[in] i_ringMode Ring operation mode. -/// @return fapi::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -template< TargetType K, typename V > -ReturnCode putRing(const Target<K, V>& i_target, - const RingID i_ringID, - const RingMode i_ringMode) -{ - std::cout << std::hex << " putRing " - << "target: {" << i_target.getType() << "," - << uint64_t(i_target) << "}; " - << "Ring ID: " << i_ringID << "; " - << "ring mode: " << i_ringMode - << std::endl; - - return FAPI2_RC_SUCCESS; -} - -// variable_buffer isn't supported on PPE -#ifndef __PPE__ -/// -/// @brief Platform-level implementation of getRing() -/// Hardware procedures writers will not call this function. -/// @tparam K template parameter, passed in target. -/// @param[in] i_target HW target to operate on. -/// @param[in] i_address Ring address to read from. -/// @param[out] o_data Buffer that holds ring data read from HW target. -/// @param[in] i_ringMode Ring operation mode. -/// @return fapi::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -/// -template< TargetType K, typename V > -inline ReturnCode getRing(const Target<K, V>& i_target, - const scanRingId_t i_address, - variable_buffer& o_data, - const RingMode i_ringMode) -{ - o_data.setBit(0); - o_data.setBit(3); - std::cout << std::hex << " getRing " - << "target: {" << i_target.getType() << "," - << uint64_t(i_target) << "}; " - << "ring address: " << i_address << "; " - << "ring mode: " << i_ringMode << "; " - << "first element of output data: " << o_data()[0] - << std::endl; - - return FAPI2_RC_SUCCESS; -} - -/// @brief Platform-level implementation of modifyRing() -/// @tparam K template parameter, passed in target. -/// @param[in] i_target Target to operate on. -/// @param[in] i_address Ring address to modify. -/// @param[in] i_data Buffer that contains RS4 compressed ring data -/// to be modified. -/// @param[in] i_modifyMode The modify mode (or/and/xor) -/// @param[in] i_ringMode Ring operation mode. -/// @return fapi::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -template< TargetType K, typename V > -inline ReturnCode modifyRing(const Target<K, V>& i_target, - const scanRingId_t i_address, - const variable_buffer& i_data, - const ChipOpModifyMode i_modifyMode, - const RingMode i_ringMode) -{ - std::cout << std::hex << " modifyRing " - << "target: {" << i_target.getType() << "," - << uint64_t(i_target) << "}; " - << "address: " << i_address << "; " - << "input ChipOpModifyMode: " << i_modifyMode << "; " - << "ring mode: " << i_ringMode << "; " - << "first element of the input data: " << i_data()[0] - << std::endl; - - return FAPI2_RC_SUCCESS; -} -#endif - -// -------------------------------------------------------------------------- -// NOTE: -// Implement platform Spy access functions if platform supports them. -// -------------------------------------------------------------------------- - -// variable_buffer isn't supported on PPE -#ifndef __PPE__ -/// @brief Reads a spy from a chip. -/// @tparam K template parameter, passed in target. -/// @param[in] i_target Target to operate on. -/// @param[in] i_spyId Id of the spy whose data to be read. -/// @param[out] o_data Buffer that holds data read from HW target. -/// @return fapi2::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -/// -/// @note: The string version is only supported for cronus. -/// -/// The fapi design to support both FSP and cronus use of get and -/// put spy functions is dependant on the SPY names being expanded -/// to resemble a valid C identifier. This design places some -/// restrictions on the SPY names which can be used. -/// -/// 1. if the spy name contains a # procedure writers should replace -/// it with an __P__ for example - -/// -/// ABUS.RX0.RXPACKS#0.RXPACK.RD.LC.LC.ACT_DIS -/// becomes -/// ABUS.RX0.RXPACKS__P__0.RXPACK.RD.LC.LC.ACT_DIS -/// -/// 2. if the spy name has a number following a "." it must have an -/// underscore prepended to the number. -/// -/// EH.TPCHIP.2KX100_ARY_CLK_EDGES_DLY -/// becomes -/// EH.TPCHIP._2KX100_ARY_CLK_EDGES_DLY -/// -/// Example SPY name: -/// The hardware procedure should call the function like: -/// -/// ABUS.RX0.RXPACKS#0.RXPACK.RD.LC.LC.ACT_DIS -/// -/// fapi2::ReturnCode rc = fapiGetSpy( targ, -/// ABUS.RX0.RXPACKS__P__0.RXPACK.RD.LC.LC.ACT_DIS, data ); -/// -/// @note The ID is not in quotes the fapi code will handle adding -/// the quotes for the cronus environment -/// -#ifdef FAPI_SUPPORT_SPY_AS_ENUM -template< TargetType K, typename V > -inline ReturnCode getSpy(const Target<K, V>& i_target, - const spyId_t i_spyId, - variable_buffer& o_data) -{ - static_assert(K == 0, "implement getSpy (enum)"); - return ~FAPI2_RC_SUCCESS; -} - -template< TargetType K > -inline ReturnCode getSpy(const Target<K>& i_target, - const spyId_t i_spyId, - variable_buffer& o_data, - const RingMode i_ringMode) -{ - static_assert(K == 0, "implement getSpy (enum)"); - return ~FAPI2_RC_SUCCESS; -} -#endif -#ifdef FAPI_SUPPORT_SPY_AS_STRING -template< TargetType K, typename V > -inline ReturnCode getSpy(const Target<K, V>& i_target, - const char* const i_spyId, - variable_buffer& o_data) -{ - static_assert(K == 0, "implement getSpy (string)"); - return ~FAPI2_RC_SUCCESS; -} - -template< TargetType K > -inline ReturnCode getSpy(const Target<K>& i_target, - const char* const i_spyId, - variable_buffer& o_data, - const RingMode i_ringMode) -{ - static_assert(K == 0, "implement getSpy (string)"); - return ~FAPI2_RC_SUCCESS; -} -#endif -/// @brief Writes a spy on a chip. -/// @tparam K template parameter, passed in target. -/// @param[in] i_target Target to operate on. -/// @param[in] i_spyId Id of the spy to write data to. -/// @param[out] i_data Buffer that holds data to write into spy. -/// @return fapi2::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -/// -/// @note: The string version is only supported for cronus. -/// -/// The fapi design to support both FSP and cronus use of get and -/// put spy functions is dependent on the SPY names being expanded -/// to resemble a valid C identifier. This design places some -/// restrictions on the SPY names which can be used. -/// -/// 1. if the spy name contains a # procedure writers should replace -/// is with an __P__ for example - -/// -/// ABUS.RX0.RXPACKS#0.RXPACK.RD.LC.LC.ACT_DIS -/// becomes -/// ABUS.RX0.RXPACKS__P__0.RXPACK.RD.LC.LC.ACT_DIS -/// -/// 2. if the spy name has a number following a "." it must have an -/// underscore prepended to the number. -/// -/// EH.TPCHIP.2KX100_ARY_CLK_EDGES_DLY -/// becomes -/// EH.TPCHIP._2KX100_ARY_CLK_EDGES_DLY -/// -/// Example SPY name: -/// The hardware procedure should call the function like: -/// -/// ABUS.RX0.RXPACKS#0.RXPACK.RD.LC.LC.ACT_DIS -/// -/// fapi2::ReturnCode rc = fapiPutSpy( targ, -/// ABUS.RX0.RXPACKS__P__0.RXPACK.RD.LC.LC.ACT_DIS, data ); -/// -/// @note The ID is not in quotes the fapi code will handle adding -/// the quotes for the cronus environment -/// -#ifdef FAPI_SUPPORT_SPY_AS_ENUM -template< TargetType K, typename V > -inline ReturnCode putSpy(const Target<K, V>& i_target, - const spyId_t i_spyId, - const variable_buffer& i_data) -{ - static_assert(K == 0, "implement putSpy (enum)"); - return ~FAPI2_RC_SUCCESS; -} -#endif -#ifdef FAPI_SUPPORT_SPY_AS_STRING -template< TargetType K, typename V > -inline ReturnCode putSpy(const Target<K, V>& i_target, - const char* const i_spyId, - const variable_buffer& i_data) -{ - static_assert(K == 0, "implement putSpy (string)"); - return ~FAPI2_RC_SUCCESS; -} - -template< TargetType K, typename V > -inline ReturnCode putSpy(const Target<K, V>& i_target, - const char* const i_spyId, - const char* i_enum) -{ - static_assert(K == 0, "implement putSpy (string)"); - return ~FAPI2_RC_SUCCESS; -} -#endif -/// @brief Writes spy data into a buffer holding ring data image -/// This API is used by L2/L3 repair to put column repair data -/// into a ring buffer image. -/// @tparam K template parameter, passed in target. -/// @param[in] i_target Target to operate on. -/// @param[in] i_spyId Id of the spy. -/// @param[in] i_data Buffer that holds spy data to write into ring -/// image. -/// @param[out] o_imageData Buffer that holds updated ring image. -/// @return fapi2::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -/// -/// @note: The string version is only supported for cronus. -/// -/// The fapi design to support both FSP and cronus use of get and -/// put spy functions is dependent on the SPY names being expanded -/// to resemble a valid C identifier. This design places some -/// restrictions on the SPY names which can be used. -/// -/// See fapiPutSpy for details on spy id specifics. -/// -#ifdef FAPI_SUPPORT_SPY_AS_ENUM -template< TargetType K, typename V > -inline ReturnCode putSpyImage(const Target<K, V>& i_target, - const spyId_t i_spyId, - const variable_buffer& i_data, - variable_buffer& o_imageData) -{ - static_assert(K == 0, "implement putSpyImage (enum)"); - return ~FAPI2_RC_SUCCESS; -} -#endif -#ifdef FAPI_SUPPORT_SPY_AS_STRING -template< TargetType K, typename V > -inline ReturnCode putSpyImage(const Target<K, V>& i_target, - const char* const i_spyId, - const variable_buffer& i_data, - variable_buffer& o_imageData) -{ - static_assert(K == 0, "implement putSpyImage (string)"); - return ~FAPI2_RC_SUCCESS; -} -#endif -/// @brief Reads spy data from a ring image buffer -/// @param[in] i_target Target to operate on -/// @param[in] i_spyId The spy's id -/// @param[out] o_data Buffer that holds data read from ring image. -/// @param[in] i_imageData Buffer that holds ring image to read data -/// from. -/// @return fapi2::ReturnCode. FAPI2_RC_SUCCESS if success, else error code. -/// -/// @note: The string version is only supported for cronus. -/// -/// The fapi design to support both FSP and cronus use of get and -/// put spy functions is dependent on the SPY names being expanded -/// to resemble a valid C identifier. This design places some -/// restrictions on the SPY names which can be used. -/// -/// See fapiPutSpy for details on spy id specifics. -/// -#ifdef FAPI_SUPPORT_SPY_AS_ENUM -template< TargetType K, typename V > -inline ReturnCode getSpyImage(const Target<K, V>& i_target, - const spyId_t i_spyId, - variable_buffer& o_data, - const variable_buffer& i_imageData) -{ - static_assert(K == 0, "implement getSpyImage (enum)"); - return ~FAPI2_RC_SUCCESS; -} -#endif -#ifdef FAPI_SUPPORT_SPY_AS_STRING -template< TargetType K, typename V > -inline ReturnCode getSpyImage(const Target<K, V>& i_target, - const char* const i_spyId, - variable_buffer& o_data, - const variable_buffer& i_imageData) -{ - static_assert(K == 0, "implement getSpyImage (string)"); - return ~FAPI2_RC_SUCCESS; -} -#endif - -#endif // PPE - -}; - -#endif // _FAPI2_HWACCESS_H_ diff --git a/import/hwpf/fapi2/include/plat/plat_error_scope.H b/import/hwpf/fapi2/include/plat/plat_error_scope.H deleted file mode 100644 index 4b198a10..00000000 --- a/import/hwpf/fapi2/include/plat/plat_error_scope.H +++ /dev/null @@ -1,89 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/plat/plat_error_scope.H $ */ -/* */ -/* OpenPOWER sbe 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 plat_error_scope.H - * @brief platform definitions which create a scope for automatic error handling - */ - -#ifndef __FAPI2_PLAT_ERROR_SCOPE__ -#define __FAPI2_PLAT_ERROR_SCOPE__ - -/// @cond -#define PLAT_FAPI_TRY_NO_TRACE( __operation__ ) \ - if ((fapi2::current_err = (__operation__)) != fapi2::FAPI2_RC_SUCCESS) \ - { \ - goto fapi_try_exit; \ - } - -#define PLAT_FAPI_TRY_TRACE( __operation__, ... ) \ - if ((fapi2::current_err = (__operation__)) != fapi2::FAPI2_RC_SUCCESS) \ - { \ - FAPI_ERR(__VA_ARGS__); \ - goto fapi_try_exit; \ - } - -/// -/// @brief Assert a conditional is true. -/// If it is not, the FFDC gathering function is called and the -/// trace is output as a FAPI error trace. -/// @param[in] __conditional__ the condition to assert -/// @param[in] __ffdc__ the FFDC gathering function -/// @param[in] ... varargs, as input to FAPI_ERR -/// -#define PLAT_FAPI_ASSERT( __conditional__, __ffdc__, ... ) \ - if (! (__conditional__)) \ - { \ - (__ffdc__).execute(); \ - FAPI_ERR(__VA_ARGS__); \ - goto fapi_try_exit; \ - } - -/// -/// @brief Create an error log based on __conditional__, -/// the FFDC gathering function is called and the -/// trace is output as a FAPI error trace. An error log -/// is created and returned to the caller via the platform -/// log pointer of the fapi2::current_err return code object -/// The caller is responsible for handling the error object. -/// -/// @param[in] __conditional__ the condition to assert -/// @param[in] __ffdc__ the FFDC gathering function -/// @param[in] ... varargs, as input to FAPI_ERR -/// -/// @note: Plat error, if supported, is stored in RC object. Failing -/// the __conditional__ test does not cause a branch to fapi_try_exit -/// -/// -#define PLAT_FAPI_ASSERT_NOEXIT( __conditional__, __ffdc__, ... ) \ - if (! (__conditional__)) \ - { \ - __ffdc__.execute( \ - fapi2::FAPI2_ERRL_SEV_UNDEFINED, true); \ - FAPI_ERR(__VA_ARGS__); \ - } -/// @endcond - - -#endif diff --git a/import/hwpf/fapi2/include/plat/plat_hw_access.H b/import/hwpf/fapi2/include/plat/plat_hw_access.H deleted file mode 100644 index 10f162b4..00000000 --- a/import/hwpf/fapi2/include/plat/plat_hw_access.H +++ /dev/null @@ -1,39 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/plat/plat_hw_access.H $ */ -/* */ -/* OpenPOWER sbe 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 plat_hw_access.H -/// -/// @brief Platform hardware-access definitions -/// - -#ifndef _FAPI2_PLAT_HWACCESS_H_ -#define _FAPI2_PLAT_HWACCESS_H_ - -namespace fapi2 -{ - -} - -#endif // _FAPI2_PLAT_HWACCESS_H_ diff --git a/import/hwpf/fapi2/include/plat/plat_target.H b/import/hwpf/fapi2/include/plat/plat_target.H deleted file mode 100644 index 4712cda5..00000000 --- a/import/hwpf/fapi2/include/plat/plat_target.H +++ /dev/null @@ -1,45 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/plat/plat_target.H $ */ -/* */ -/* OpenPOWER sbe 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 plat_target.H - * @brief platform definitions for fapi2 targets - */ - -#ifndef __FAPI2_PLAT_TARGET__ -#define __FAPI2_PLAT_TARGET__ - -#include <stdint.h> - -// -// Define what a platform handle looks like. For Hostboot, -// for example, this might be a void*. For the SBE, this -// will be a uint64_t ... -// -namespace fapi2 -{ -typedef uint64_t plat_target_handle_t; -} - -#endif diff --git a/import/hwpf/fapi2/include/plat/plat_trace.H b/import/hwpf/fapi2/include/plat/plat_trace.H deleted file mode 100644 index fbd3aef6..00000000 --- a/import/hwpf/fapi2/include/plat/plat_trace.H +++ /dev/null @@ -1,73 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/plat/plat_trace.H $ */ -/* */ -/* OpenPOWER sbe 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 plat_trace.H - * @brief Defines the FAPI2 trace macros. - * - * Note that platform code must provide the implementation. - * - * FAPI has provided a default implementation. Platform code must - * provide an alternate implementation if needed. - */ - -#ifndef FAPI2_PLATTRACE_H_ -#define FAPI2_PLATTRACE_H_ - -#include <stdio.h> -#include <stdint.h> - -// Why not a #define, why is this in the fapi2 namespace? -// To prevent problems with Cronus and the fapi1 definitions. -namespace fapi2 -{ -static const uint32_t MAX_ECMD_STRING_LEN = 64; -}; - -// Information traces (go into fast trace buffer that can wrap often) -#define FAPI_TRACE(_id_, _fmt_, _args_...) \ - printf("%s: %s:%d ", _id_, __func__, __LINE__); \ - printf(_fmt_, ##_args_); \ - printf("\n") - -#define FAPI_INF(_fmt_, _args_...) FAPI_TRACE("inf", _fmt_, ##_args_) - -// Important traces (go into slow trace buffer that should not wrap often) -#define FAPI_IMP(_fmt_, _args_...) FAPI_TRACE("imp", _fmt_, ##_args_) - -// Error traces (go into slow trace buffer that should not wrap often) -#define FAPI_ERR(_fmt_, _args_...) FAPI_TRACE("err", _fmt_, ##_args_) - -// Debug traces (go into fast trace buffer that can wrap often) -#define FAPI_DBG(_fmt_, _args_...) FAPI_TRACE("dbg", _fmt_, ##_args_) - -// Scan traces -#define FAPI_SCAN(_fmt_, _args_...) FAPI_TRACE("scan", _fmt_, ##_args_) - -#define FAPI_MFG(_fmt_, _args_...) FAPI_TRACE("mfg", _fmt_, ##_args_) - -#define FAPI_LAB(__fmt_, _args_...) \ - printf(_fmt_, ##_args_); \ - printf("\n") -#endif // FAPI2_PLATTRACE_H_ diff --git a/import/hwpf/fapi2/include/plat/plat_vpd_access.H b/import/hwpf/fapi2/include/plat/plat_vpd_access.H deleted file mode 100644 index 5ca078a8..00000000 --- a/import/hwpf/fapi2/include/plat/plat_vpd_access.H +++ /dev/null @@ -1,64 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/plat/plat_vpd_access.H $ */ -/* */ -/* OpenPOWER sbe Project */ -/* */ -/* Contributors Listed Below - COPYRIGHT 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 plat_vpd_access.H -/// -/// @brief Platform vpd-access definitions -/// - -#ifndef _FAPI2_PLAT_VPDACCESS_H_ -#define _FAPI2_PLAT_VPDACCESS_H_ - -#include <fapi2_vpd_access.H> - -namespace fapi2 -{ -// -- platform specific getVPD implementation goes here -- - -// platform specific for MCS target -- test code only -inline fapi2::ReturnCode platGetVPD(const fapi2::Target<fapi2::TARGET_TYPE_MCS>& i_target, - VPDInfo<fapi2::TARGET_TYPE_MCS>& io_vpd_info, - uint8_t* o_blob) -{ - fapi2::ReturnCode l_rc = fapi2::FAPI2_RC_SUCCESS; - - if( o_blob == nullptr ) - { - io_vpd_info.iv_size = 2048; - } - else - { - o_blob[0] = 111; - - io_vpd_info.iv_freq_mhz = 10000; - io_vpd_info.iv_rank_count_dimm_0 = 1; - io_vpd_info.iv_rank_count_dimm_1 = 8; - - } - - return l_rc; -} - -}; -#endif // _FAPI2_PLAT_VPDACCESS_H_ diff --git a/import/hwpf/fapi2/include/plat/target.H b/import/hwpf/fapi2/include/plat/target.H deleted file mode 100644 index 842d9d1f..00000000 --- a/import/hwpf/fapi2/include/plat/target.H +++ /dev/null @@ -1,242 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/plat/target.H $ */ -/* */ -/* OpenPOWER sbe 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 target.H - * @brief platform specializations for fapi2 targets - */ - -#ifndef __FAPI2_TARGET__ -#define __FAPI2_TARGET__ - -#include <plat_target.H> -#include <fapi2_target.H> -#include <multicast.H> -#include <stdio.h> - -namespace fapi2 -{ - -/// -/// @brief Assignment Operator. -/// @param[in] i_right Reference to Target to assign from. -/// @return Reference to 'this' Target -/// -template<TargetType K, typename V> -Target<K, V>& Target<K, V>::operator=(const Target& i_right) -{ - iv_handle = i_right.iv_handle; - return *this; -} - -/// -/// @brief Equality Comparison Operator -/// @param[in] i_right Reference to Target to compare. -/// @return bool. True if equal. -/// @note Platforms need to define this so that the physical -/// targets are determined to be equivilent rather than just the handles -/// -template<TargetType K, typename V> -bool Target<K, V>::operator==(const Target& i_right) const -{ - return i_right.iv_handle == iv_handle; -} - -/// -/// @brief Inquality Comparison Operator -/// @param[in] i_right Reference to Target to compare. -/// @return bool. True if not equal. -/// @note Platforms need to define this so that the physical -/// targets are determined to be equivilent rather than just the handles -/// -template<TargetType K, typename V> -bool Target<K, V>::operator!=(const Target& i_right) const -{ - return i_right.iv_handle != iv_handle; -} - -/// -/// @brief Less Than Comparison Operator -/// @param[in] i_right Reference to Target to compare. -/// @return bool. True if less than i_right. -/// @note Platforms need to define this so that the physical -/// targets are determined to be less than rather than just the handles -/// -template<TargetType K, typename V> -bool Target<K, V>::operator<(const Target& i_right) const -{ - return i_right.iv_handle < iv_handle; -} - -/// -/// @brief Get this target's immediate parent -/// @tparam T The type of the parent -/// @return Target<T> a target representing the parent -/// -template<TargetType K, typename V> -template<TargetType T> -inline Target<T, V> Target<K, V>::getParent(void) const -{ - // For testing - return Target<T, V>(iv_handle); -} - -/// -/// @brief Get this target's children -/// @tparam T The type of the parent -/// @param[in] i_state The desired TargetState of the children -/// @return std::vector<Target<T> > a vector of present/functional -/// children -/// @warning The children of EX's (cores) are expected to be returned -/// in order. That is, core 0 is std::vector[0]. -/// -template<TargetType K, typename V> -template< TargetType T> -inline std::vector<Target<T, V> > -Target<K, V>::getChildren(const TargetState i_state) const -{ - // To keep the compiler quiet about unused variables - static_cast<void>(i_state); - // For testing - return {Target<T, V>(), Target<T, V>()}; -} -// Specialization of getChildren, filtered for pervasive targets. -template<> -template<> -inline std::vector<Target<TARGET_TYPE_PERV> > -Target<TARGET_TYPE_PERV>::getChildren(const TargetFilter i_filter, - const TargetState i_state ) const -{ - // To keep the compiler quiet about unused variables - static_cast<void>(i_state); - static_cast<void>(i_filter); - - // For testing - return {Target<TARGET_TYPE_PERV>(i_filter), Target<TARGET_TYPE_PERV>(i_filter)}; -} - -/// -/// @brief Get the target at the other end of a bus -/// @tparam T The type of the target on the other end -/// @param[out] o_target A target representing the thing on the other end -/// @param[in] i_state The desired TargetState of the other end -/// @return FAPI2_RC_SUCCESS if OK, platforms will return a non-success -/// ReturnCode in the event of failure -/// @note o_target is only valid if return is FAPI2_RC_SUCCESS -/// - -template<TargetType K, typename V> -template<TargetType T> -inline fapi2::ReturnCodes -Target<K, V>::getOtherEnd(Target<T, V>& o_target, - const TargetState i_state) const -{ - // To keep the compiler quiet about unused variables - static_cast<void>(i_state); - - o_target = Target<T, V>(); - - return FAPI2_RC_SUCCESS; -} - -/// -/// @brief Is the target functional? -/// @return true if target is functional, false if non-functional -/// - -template<TargetType K, typename V> -inline bool -Target<K, V>::isFunctional(void) const -{ - // Platform check if target is good - // Could check ATTR_FUNCTIONAL or ATTR_PG_* - return true; -} - -/// -/// @brief Returns the chiplet number associated with the Target -/// @return The chiplet number for the Target. 0 is returned if the -/// Target does not have a chiplet number (for ex, the PROC_CHIP Target) -/// @note For logical targets such as the EX, the chiplet number of -/// their immediate parent chiplet is returned -/// -template<TargetType K, typename V> -inline uint8_t -Target<K, V>::getChipletNumber(void) const -{ - // Platform can return the chiplet number stored in it's Target handle - return 0; -} - -/// -/// @brief Return the string interpretation of this target -/// @tparam T The type of the target -/// @param[in] i_target Target<T> -/// @param[in] i_buffer buffer to write in to -/// @param[in] i_bsize size of the buffer -/// @return void -/// @post The contents of the buffer is replaced with the string -/// representation of the target -/// -template< TargetType T, typename V > -inline void toString(const Target<T, V>& i_target, - char* i_buffer, size_t i_bsize) -{ - snprintf(i_buffer, i_bsize, "Target 0x%lx/0x%x", i_target.get(), T); -} - -/// -/// @brief Return the string interpretation of this target -/// @tparam T The type of the target -/// @tparam B The type of the buffer -/// @param[in] i_target A pointer to the Target<T> -/// @param[in] i_buffer buffer to write in to -/// @param[in] i_bsize size of the buffer -/// @return void -/// @post The contents of the buffer is replaced with the string -/// representation of the target -/// -template< TargetType T, typename V > -inline void toString(const Target<T, V>* i_target, - char* i_buffer, size_t i_bsize) -{ - snprintf(i_buffer, i_bsize, "Target 0x%lx/0x%x", i_target->get(), T); -} - -/// -/// @brief Get an enumerated target of a specific type -/// @tparam T The type of the target -/// @param[in] Ordinal representing the ordinal number of -/// the desired target -/// @return Target<T> the target requested -/// -template<TargetType T, typename V> -inline Target<T, V> getTarget(uint64_t Ordinal) -{ - // For testing - return Target<T, V>(Ordinal); -} -} - -#endif diff --git a/import/hwpf/fapi2/include/plat/vpd_access.H b/import/hwpf/fapi2/include/plat/vpd_access.H deleted file mode 100644 index 554a3469..00000000 --- a/import/hwpf/fapi2/include/plat/vpd_access.H +++ /dev/null @@ -1,52 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/plat/vpd_access.H $ */ -/* */ -/* OpenPOWER sbe Project */ -/* */ -/* Contributors Listed Below - COPYRIGHT 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 vpd_access.H -/// -/// @brief VPD access functions that needs to be specialized for -/// platform implementation. -/// - -#ifndef __VPDACCESS_H_ -#define __VPDACCESS_H_ - -#include <target.H> -#include <return_code.H> -#include <plat_vpd_access.H> -#include <fapi2_vpd_access.H> -namespace fapi2 -{ -// -- platform specializations for getVPD go here -- - -// specialization for MCS target -template<> fapi2::ReturnCode getVPD(const fapi2::Target<fapi2::TARGET_TYPE_MCS>& i_target, - VPDInfo<fapi2::TARGET_TYPE_MCS>& io_vpd_info, - uint8_t* o_blob) -{ - return platGetVPD( i_target, io_vpd_info, o_blob ); -} - -}; - -#endif // _FAPI2_VPDACCESS_H_ diff --git a/import/hwpf/fapi2/include/return_code.H b/import/hwpf/fapi2/include/return_code.H deleted file mode 100644 index f5569dc2..00000000 --- a/import/hwpf/fapi2/include/return_code.H +++ /dev/null @@ -1,187 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/return_code.H $ */ -/* */ -/* OpenPOWER sbe 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 <stdint.h> - -#ifndef FAPI2_NO_FFDC - #include <ffdc.H> -#endif - -namespace fapi2 -{ -/// -/// @brief Class representing a FAPI2 ReturnCode -/// -// Remove the inheritance relationship with FirstFailureData if -// the platform doesn't support FFDC. -#ifdef FAPI2_NO_FFDC -class ReturnCode -#else -class ReturnCode : public FirstFailureData<ReturnCode> -#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<uint32_t>(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 diff --git a/import/hwpf/fapi2/include/return_code_defs.H b/import/hwpf/fapi2/include/return_code_defs.H deleted file mode 100644 index c7c95f09..00000000 --- a/import/hwpf/fapi2/include/return_code_defs.H +++ /dev/null @@ -1,121 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/return_code_defs.H $ */ -/* */ -/* OpenPOWER sbe 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_DEFS_ -#define __FAPI2_RETURN_CODE_DEFS_ - -#include <stdint.h> - -/// -/// @brief Set HWP Error macro -/// -/// This macro should be used by a HWP to create an error. The ReturnCode's -/// internal return code is set and any error information in the Error XML file -/// is added to the ReturnCode -/// -#define FAPI_SET_HWP_ERROR(RC, ERROR) \ - RC._setHwpError(fapi2::ERROR); \ - ERROR##_CALL_FUNCS_TO_COLLECT_FFDC(RC); \ - ERROR##_CALL_FUNCS_TO_COLLECT_REG_FFDC(RC); \ - ERROR##_ADD_ERROR_INFO(RC) - -/// -/// @brief Add info to HWP Error macro -/// -/// This macro should be used by an FFDC HWP to add error information from an -/// Error XML file to an existing error. -/// -#define FAPI_ADD_INFO_TO_HWP_ERROR(RC, ERROR) \ - ERROR##_CALL_FUNCS_TO_COLLECT_FFDC(RC); \ - ERROR##_CALL_FUNCS_TO_COLLECT_REG_FFDC(RC); \ - ERROR##_ADD_ERROR_INFO(RC) - -namespace fapi2 -{ -/// -/// @brief Enumeration of return codes -/// -enum ReturnCodes : uint32_t -{ - ///< Success - FAPI2_RC_SUCCESS = 0, - - // Flag bits indicating which code generated the error. - FAPI2_RC_FAPI2_MASK = 0x04000000, ///< FAPI2 mask - FAPI2_RC_PLAT_MASK = 0x02000000, ///< Platform mask - FAPI2_RC_HWP_MASK = 0x00000000, ///< HWP mask - - // - // FAPI generated return codes - // - - FAPI2_RC_INVALID_ATTR_GET = FAPI2_RC_FAPI2_MASK | 0x01, - ///< Initfile requested an attribute with an invalid attribute ID - - FAPI2_RC_INVALID_CHIP_EC_FEATURE_GET = FAPI2_RC_FAPI2_MASK | 0x02, - ///< HWP requested a chip EC feature with an invalid attribute ID - - FAPI2_RC_INVALID_PARAMETER = FAPI2_RC_FAPI2_MASK | 0x04, - ///< Invalid parameters to a FAPI2 function - - FAPI2_RC_OVERFLOW = FAPI2_RC_FAPI2_MASK | 0x05, - ///< Overflow condition, typically a buffer operation - - FAPI2_RC_FALSE = FAPI2_RC_FAPI2_MASK | 0x06, - ///< The logical opposite of SUCCESS. Needed where procedures want - ///< a multi-bool type of operation (e.g., true, false, scom error) - - // - // PLAT generated return codes. Additional details may be contained in - // ReturnCode platData (this can only be looked at by PLAT code) - // - - FAPI2_RC_PLAT_ERR_SEE_DATA = FAPI2_RC_PLAT_MASK | 0x01, - ///< Generic platform error - - FAPI2_RC_PLAT_ERR_ADU_LOCKED = FAPI2_RC_PLAT_MASK | 0x02, - ///< Operation to AlterDisplay unit failed because it is locked - - FAPI2_RC_PLAT_NOT_SUPPORTED_AT_RUNTIME = FAPI2_RC_PLAT_MASK | 0x03, - ///< Operation not supported by HB runtime - - FAPI2_RC_PLAT_ERR_RING_HEADER_CHECK = FAPI2_RC_PLAT_MASK | 0x04, - //Operation on putring fail because of header data mismatch - // - FAPI2_RC_PLAT_RING_DECODE_LENGTH_EXCEEDED = FAPI2_RC_PLAT_MASK | 0x05, - //Operation on putring fail because of decode length greater than actual - //ring length. - - FAPI2_RC_PLAT_RING_ID_NOT_FOUND_IN_RS4_IMAGE = FAPI2_RC_PLAT_MASK | 0x06, - //Operation on putring fail because of ringId not found in RS4 image -}; - -} - -#endif diff --git a/import/hwpf/fapi2/include/target_states.H b/import/hwpf/fapi2/include/target_states.H deleted file mode 100644 index be29cb28..00000000 --- a/import/hwpf/fapi2/include/target_states.H +++ /dev/null @@ -1,45 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/target_states.H $ */ -/* */ -/* OpenPOWER sbe 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 target_states.H - * @brief common state for fapi2 targets - */ - -#ifndef __FAPI2_TARGET_STATES__ -#define __FAPI2_TARGET_STATES__ - -namespace fapi2 -{ -/// -/// @brief Enumeration of target state values (bitmask values) -/// -enum TargetState -{ - TARGET_STATE_PRESENT = 0x00000001, - TARGET_STATE_FUNCTIONAL = 0x00000002, -}; -} - -#endif diff --git a/import/hwpf/fapi2/include/target_types.H b/import/hwpf/fapi2/include/target_types.H deleted file mode 100644 index 3e852a1e..00000000 --- a/import/hwpf/fapi2/include/target_types.H +++ /dev/null @@ -1,277 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/target_types.H $ */ -/* */ -/* OpenPOWER sbe 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 target_types.H - * @brief definitions for fapi2 target types - */ - -#ifndef __FAPI2_TARGET_TYPES__ -#define __FAPI2_TARGET_TYPES__ -#include <stdint.h> - -// File that plat uses to assign values to TargetFilter enum -#include <plat_target_filter.H> - - -/// FAPI namespace -namespace fapi2 -{ -/// -/// @enum fapi::TargetType -/// @brief Types, kinds, of targets -/// @note TYPE_NONE is used to represent empty/NULL targets in lists -/// or tables. TYPE_ALL is used to pass targets to methods which -/// can act generally on any type of target -/// - -/// Target Kind -enum TargetType -{ - TARGET_TYPE_NONE = 0x00000000, ///< No type - TARGET_TYPE_SYSTEM = 0x00000001, ///< System type - TARGET_TYPE_DIMM = 0x00000002, ///< DIMM type - TARGET_TYPE_PROC_CHIP = 0x00000004, ///< Processor type - TARGET_TYPE_MEMBUF_CHIP = 0x00000008, ///< Membuf type - TARGET_TYPE_EX = 0x00000010, ///< EX - 2x Core, L2, L3 - can be deconfigured - TARGET_TYPE_MBA = 0x00000020, ///< MBA type - TARGET_TYPE_MCS = 0x00000040, ///< MCS type - TARGET_TYPE_XBUS = 0x00000080, ///< XBUS type - TARGET_TYPE_ABUS = 0x00000100, ///< ABUS type - TARGET_TYPE_L4 = 0x00000200, ///< L4 type - TARGET_TYPE_CORE = 0x00000400, ///< Core - 4x threads(?) - can be deconfigured - TARGET_TYPE_EQ = 0x00000800, ///< EQ - 4x core, 2x L2, 2x L3 - can be deconfigured - TARGET_TYPE_MCA = 0x00001000, ///< MCA type - TARGET_TYPE_MCBIST = 0x00002000, ///< MCBIST type - TARGET_TYPE_MI = 0x00004000, ///< MI Memory Interface (Cumulus) - TARGET_TYPE_CAPP = 0x00008000, ///< CAPP target - TARGET_TYPE_DMI = 0x00010000, ///< DMI type - TARGET_TYPE_OBUS = 0x00020000, ///< OBUS type - TARGET_TYPE_NV = 0x00040000, ///< NV bus type - TARGET_TYPE_SBE = 0x00080000, ///< SBE type - TARGET_TYPE_PPE = 0x00100000, ///< PPE type - TARGET_TYPE_PERV = 0x00200000, ///< Pervasive type - TARGET_TYPE_PEC = 0x00400000, ///< PEC type - TARGET_TYPE_PHB = 0x00800000, ///< PHB type - - TARGET_TYPE_ALL = 0xFFFFFFFF, ///< Any/All types - - // Compound target types - TARGET_TYPE_CHIPS = TARGET_TYPE_PROC_CHIP | - TARGET_TYPE_MEMBUF_CHIP, - - TARGET_TYPE_CHIPLETS = TARGET_TYPE_EX | - TARGET_TYPE_MBA | - TARGET_TYPE_MCS | - TARGET_TYPE_XBUS | - TARGET_TYPE_ABUS | - TARGET_TYPE_L4 | - TARGET_TYPE_CORE | - TARGET_TYPE_EQ | - TARGET_TYPE_MCA | - TARGET_TYPE_MCBIST | - TARGET_TYPE_MI | - TARGET_TYPE_DMI | - TARGET_TYPE_OBUS | - TARGET_TYPE_NV | - TARGET_TYPE_SBE | - TARGET_TYPE_PPE | - TARGET_TYPE_PERV | - TARGET_TYPE_PEC | - TARGET_TYPE_PHB, - - // Mappings to target types found in the error xml files - TARGET_TYPE_EX_CHIPLET = TARGET_TYPE_EX, - TARGET_TYPE_MBA_CHIPLET = TARGET_TYPE_MBA, - TARGET_TYPE_MCS_CHIPLET = TARGET_TYPE_MCS, - TARGET_TYPE_XBUS_ENDPOINT = TARGET_TYPE_XBUS, - TARGET_TYPE_ABUS_ENDPOINT = TARGET_TYPE_ABUS, -}; - -/// -/// @brief Enumeration of chiplet filters -/// @note plat_target_filter.H assigns enum value using PlatTargetFilter namespace -/// - -enum TargetFilter : uint64_t -{ - TARGET_FILTER_NONE = 0x0000000000000000, - TARGET_FILTER_TP = PlatTargetFilter::PLAT_TARGET_FILTER_TP, // Pervasive 1 - TARGET_FILTER_NEST_NORTH = PlatTargetFilter::PLAT_TARGET_FILTER_NEST_NORTH, // Pervasive 2 - TARGET_FILTER_NEST_EAST = PlatTargetFilter::PLAT_TARGET_FILTER_NEST_EAST, // Pervasive 3 - TARGET_FILTER_NEST_SOUTH = PlatTargetFilter::PLAT_TARGET_FILTER_NEST_SOUTH, // Pervasive 4 - TARGET_FILTER_NEST_WEST = PlatTargetFilter::PLAT_TARGET_FILTER_NEST_WEST, // Pervasive 5 - TARGET_FILTER_XBUS = PlatTargetFilter::PLAT_TARGET_FILTER_XBUS, // Pervasive 6 - TARGET_FILTER_MC_WEST = PlatTargetFilter::PLAT_TARGET_FILTER_MC_WEST, // Pervasive 7 - TARGET_FILTER_MC_EAST = PlatTargetFilter::PLAT_TARGET_FILTER_MC_EAST, // Pervasive 8 - TARGET_FILTER_OBUS0 = PlatTargetFilter::PLAT_TARGET_FILTER_OBUS0, // Pervasive 9 - TARGET_FILTER_OBUS1 = PlatTargetFilter::PLAT_TARGET_FILTER_OBUS1, // Pervasive 10 - TARGET_FILTER_OBUS2 = PlatTargetFilter::PLAT_TARGET_FILTER_OBUS2, // Pervasive 11 - TARGET_FILTER_OBUS3 = PlatTargetFilter::PLAT_TARGET_FILTER_OBUS3, // Pervasive 12 - TARGET_FILTER_PCI0 = PlatTargetFilter::PLAT_TARGET_FILTER_PCI0, // Pervasive 13 - TARGET_FILTER_PCI1 = PlatTargetFilter::PLAT_TARGET_FILTER_PCI1, // Pervasive 14 - TARGET_FILTER_PCI2 = PlatTargetFilter::PLAT_TARGET_FILTER_PCI2, // Pervasive 15 - TARGET_FILTER_CACHE0 = PlatTargetFilter::PLAT_TARGET_FILTER_CACHE0, // Pervasive 16 - TARGET_FILTER_CACHE1 = PlatTargetFilter::PLAT_TARGET_FILTER_CACHE1, // Pervasive 17 - TARGET_FILTER_CACHE2 = PlatTargetFilter::PLAT_TARGET_FILTER_CACHE2, // Pervasive 18 - TARGET_FILTER_CACHE3 = PlatTargetFilter::PLAT_TARGET_FILTER_CACHE3, // Pervasive 19 - TARGET_FILTER_CACHE4 = PlatTargetFilter::PLAT_TARGET_FILTER_CACHE4, // Pervasive 20 - TARGET_FILTER_CACHE5 = PlatTargetFilter::PLAT_TARGET_FILTER_CACHE5, // Pervasive 21 - TARGET_FILTER_CORE0 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE0, // Pervasive 32 - TARGET_FILTER_CORE1 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE1, // Pervasive 33 - TARGET_FILTER_CORE2 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE2, // Pervasive 34 - TARGET_FILTER_CORE3 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE3, // Pervasive 35 - TARGET_FILTER_CORE4 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE4, // Pervasive 36 - TARGET_FILTER_CORE5 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE5, // Pervasive 37 - TARGET_FILTER_CORE6 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE6, // Pervasive 38 - TARGET_FILTER_CORE7 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE7, // Pervasive 39 - TARGET_FILTER_CORE8 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE8, // Pervasive 20 - TARGET_FILTER_CORE9 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE9, // Pervasive 41 - TARGET_FILTER_CORE10 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE10, // Pervasive 42 - TARGET_FILTER_CORE11 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE11, // Pervasive 43 - TARGET_FILTER_CORE12 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE12, // Pervasive 44 - TARGET_FILTER_CORE13 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE13, // Pervasive 45 - TARGET_FILTER_CORE14 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE14, // Pervasive 46 - TARGET_FILTER_CORE15 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE15, // Pervasive 47 - TARGET_FILTER_CORE16 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE16, // Pervasive 48 - TARGET_FILTER_CORE17 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE17, // Pervasive 49 - TARGET_FILTER_CORE18 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE18, // Pervasive 50 - TARGET_FILTER_CORE19 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE19, // Pervasive 51 - TARGET_FILTER_CORE20 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE20, // Pervasive 52 - TARGET_FILTER_CORE21 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE21, // Pervasive 53 - TARGET_FILTER_CORE22 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE22, // Pervasive 54 - TARGET_FILTER_CORE23 = PlatTargetFilter::PLAT_TARGET_FILTER_CORE23, // Pervasive 55 - - // Composite filters follow - - // Pervasive 32-55 (all cores) - TARGET_FILTER_ALL_CORES = (TARGET_FILTER_CORE0 | - TARGET_FILTER_CORE1 | TARGET_FILTER_CORE2 | - TARGET_FILTER_CORE3 | TARGET_FILTER_CORE4 | - TARGET_FILTER_CORE5 | TARGET_FILTER_CORE6 | - TARGET_FILTER_CORE7 | TARGET_FILTER_CORE8 | - TARGET_FILTER_CORE9 | TARGET_FILTER_CORE10 | - TARGET_FILTER_CORE11 | TARGET_FILTER_CORE12 | - TARGET_FILTER_CORE13 | TARGET_FILTER_CORE14 | - TARGET_FILTER_CORE15 | TARGET_FILTER_CORE16 | - TARGET_FILTER_CORE17 | TARGET_FILTER_CORE18 | - TARGET_FILTER_CORE19 | TARGET_FILTER_CORE20 | - TARGET_FILTER_CORE21 | TARGET_FILTER_CORE22 | - TARGET_FILTER_CORE23), - - // Pervasive 16-21 (all caches) - TARGET_FILTER_ALL_CACHES = (TARGET_FILTER_CACHE0 | - TARGET_FILTER_CACHE1 | TARGET_FILTER_CACHE2 | - TARGET_FILTER_CACHE3 | TARGET_FILTER_CACHE4 | - TARGET_FILTER_CACHE5), - - // Pervasive 2-5 (eg N0-N3) < req'd - TARGET_FILTER_ALL_NEST = (TARGET_FILTER_NEST_NORTH | - TARGET_FILTER_NEST_SOUTH | TARGET_FILTER_NEST_EAST | - TARGET_FILTER_NEST_WEST), - - // Pervasive 2-4 (eg N0-N2) < req'd - TARGET_FILTER_NEST_SLAVES = - (TARGET_FILTER_NEST_NORTH | TARGET_FILTER_NEST_SOUTH | - TARGET_FILTER_NEST_EAST), - - // Pervasive 5 (eg N32) < req'd - TARGET_FILTER_NEST_MASTER = TARGET_FILTER_NEST_WEST, - - // Pervasive 7-8 (eg MC0-MC1) - TARGET_FILTER_ALL_MC = - (TARGET_FILTER_MC_WEST | TARGET_FILTER_MC_EAST), - - // Pervasive 9-12 (OB0-OB3) - TARGET_FILTER_ALL_OBUS = - (TARGET_FILTER_OBUS0 | TARGET_FILTER_OBUS1 | TARGET_FILTER_OBUS2 | - TARGET_FILTER_OBUS3), - - // Pervasive 13-15 (PCI0-PCI2) - TARGET_FILTER_ALL_PCI = - (TARGET_FILTER_PCI0 | TARGET_FILTER_PCI1 | TARGET_FILTER_PCI2), - - // Sync mode filter = All NEST + All MCS - TARGET_FILTER_SYNC_MODE_NEST = - (TARGET_FILTER_ALL_NEST | TARGET_FILTER_ALL_MC), - - // All IO Targets except NEST - TARGET_FILTER_ALL_IO_EXCEPT_NEST = - (TARGET_FILTER_XBUS | TARGET_FILTER_ALL_PCI | TARGET_FILTER_ALL_OBUS), - - // All sync mode IO except NEST - TARGET_FILTER_SYNC_MODE_ALL_IO_EXCEPT_NEST = - (TARGET_FILTER_ALL_MC | TARGET_FILTER_XBUS | TARGET_FILTER_ALL_PCI | - TARGET_FILTER_ALL_OBUS), - - // All sync mode NEST slaves - TARGET_FILTER_SYNC_MODE_NEST_SLAVES = - (TARGET_FILTER_ALL_MC | TARGET_FILTER_NEST_SLAVES), - - // All sync mode IO - TARGET_FILTER_SYNC_MODE_ALL_IO = - (TARGET_FILTER_ALL_MC | TARGET_FILTER_ALL_NEST | - TARGET_FILTER_ALL_OBUS | TARGET_FILTER_ALL_PCI | - TARGET_FILTER_XBUS), - - // All IO - TARGET_FILTER_ALL_IO = (TARGET_FILTER_ALL_NEST | - TARGET_FILTER_ALL_OBUS | TARGET_FILTER_ALL_PCI | - TARGET_FILTER_XBUS), - - // All sync mode except TP - TARGET_FILTER_SYNC_MODE_ALL_EXCEPT_TP = - (TARGET_FILTER_ALL_MC | TARGET_FILTER_ALL_NEST | - TARGET_FILTER_ALL_OBUS | TARGET_FILTER_ALL_PCI | - TARGET_FILTER_XBUS | TARGET_FILTER_ALL_CORES | - TARGET_FILTER_ALL_CACHES), -}; - - -/// @cond -constexpr TargetType operator|(TargetType x, TargetType y) -{ - return static_cast<TargetType>(static_cast<int>(x) | - static_cast<int>(y)); -} - -template<uint64_t V> -class bitCount -{ - public: - // Don't use enums, too hard to compare - static const uint8_t count = bitCount < (V >> 1) >::count + (V & 1); -}; - -template<> -class bitCount<0> -{ - public: - static const uint8_t count = 0; -}; -/// @endcond - -} - -#endif diff --git a/import/hwpf/fapi2/include/utils.H b/import/hwpf/fapi2/include/utils.H deleted file mode 100644 index e4f5fa09..00000000 --- a/import/hwpf/fapi2/include/utils.H +++ /dev/null @@ -1,171 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/utils.H $ */ -/* */ -/* OpenPOWER sbe 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 utils.H - * @brief Defines common fapi2 utilities - */ - -#ifndef FAPI2_UTILS_H_ -#define FAPI2_UTILS_H_ - -#include <stdint.h> -#include <return_code.H> -#include <target_types.H> -#include <plat_utils.H> - - -namespace fapi2 -{ - -/// -/// @brief Enable/Disable special wakeup on processor chip core(s) -/// -/// Special Wakeup Enable must be done when a HWP is doing an operation that -/// requires core(s) to be awake (e.g. modifying the Hcode image). For -/// each Special Wakeup Enable call, there must be a subsequent Special Wakeup -/// Disable call. -/// -/// This does not apply to SCOM operations, platforms must handle Special Wakeup -/// for SCOM operations internally. -/// -/// If Special Wakeup is enabled, a core will not go to sleep (if already -/// sleeping, it is woken up). If Special Wakeup is disabled, if there are no -/// other active Enables, the core is allowed to sleep. -/// -/// @note Implemented by platform code calling the cpu special wakeup HWP. -/// This is a FAPI2 function because each platform may do different things -/// Hostboot: Does nothing (cores cannot sleep while Hostboot running) -/// FSP: Uses an algorithm to decide when to disable special wakeup -/// Cronus: Does Special Wakeup enable/disable as requested -/// -/// @param[in] i_target -/// TARGET_TYPE_PROC_CHIP: Enables/Disables Special Wakeup on all -/// cores (EX,EQ chiplets) of the specified chip target. -/// TARGET_TYPE_CORE: Enables/Disables Special Wakeup on the -/// specified core target (EX,EQ chiplets) -/// TARGET_TYPE_EX: Enables/Disables Special Wakeup on the -/// specified EX target. -/// TARGET_TYPE_EQ: Enables/Disables Special Wakeup on the -/// specified EQ target. -/// -/// @param[in] i_enable true = enable. false = disable. -/// -/// @return ReturnCode. FAPI2_RC_SUCCESS on success, else platform specified error. -/// -/// -template<TargetType T, typename V> -inline ReturnCode specialWakeup(const Target<T, V>& i_target, - const bool i_enable) -{ - // enforce the allowed target types - static_assert( ((T == fapi2::TARGET_TYPE_PROC_CHIP) || - (T == fapi2::TARGET_TYPE_CORE) || - (T == fapi2::TARGET_TYPE_EX) || - (T == fapi2::TARGET_TYPE_EQ)), - "Invalid target type for this function"); - - ReturnCode l_rc = platSpecialWakeup( i_target, i_enable ); - - return l_rc; -} - -/// -/// @brief Log an error. -/// -/// @param[in,out] io_rc Reference to ReturnCode (Any references to data and error -/// target are removed and rc value is set to success after -/// function ends.) -/// @param[in] i_sev Fapi error log severity defaulted to unrecoverable -/// @param[in] i_unitTestError - flag to log error which does not cause a unit -/// test to fail. -/// -/// @note This function is called from the ffdc collection classes and no longer -/// needs to be called directly. -/// @note Implemented by platform code -/// -void logError( - fapi2::ReturnCode& io_rc, - fapi2::errlSeverity_t i_sev = fapi2::FAPI2_ERRL_SEV_UNRECOVERABLE, - bool i_unitTestError = false ); - -/// -/// @brief Create a platform error log -/// -/// This function will create a platform error log from the passed in -/// return code value and will populate the iv_platDataPtr of the return code -/// with a pointer to the newly created log. -/// -/// @param[in,out] io_rc - Reference to ReturnCode -/// -/// @param[in] i_sev Fapi error log severity defaulted to unrecoverable -// -// -/// @note Implemented by platform code -/// -void createPlatLog( - fapi2::ReturnCode& io_rc, - fapi2::errlSeverity_t i_sev = fapi2::FAPI2_ERRL_SEV_UNRECOVERABLE -); - -/// -/// @brief Delay this thread. Hostboot will use the nanoseconds parameter -/// and make a syscall to nanosleep. While in the syscall, the hostboot -/// kernel will continue to consume CPU cycles as it looks for a runnable -/// task. When the delay time expires, the task becomes runnable and will soon -/// return from the syscall. Callers of delay() in the hostboot environment -/// will likely have to know the mHz clock speed they are running on and -/// compute a non-zero value for i_nanoSeconds. -/// -/// On the FSP, it was sometimes acceptable to just provide zero for the -/// sleep delay time, causing the task to yield its time slice. By the -/// time the calling task could run again, it was pretty certain enough -/// host cycles had past. This is probably not acceptable in -/// the hostboot environment. Callers should calculate and provide a -/// sleep value in nanoseconds relative to host clock speed. -/// -/// On FSP when VBU is the target, then the i_simCycles parameter will be -/// used instead. The FSP needs to use the simdispatcher client/server -/// API and issue a command to the awan to advance the simulation the -/// specified number of cycles. -/// -/// @param[in] i_nanoSeconds nanoseconds to sleep -/// @param[in] i_simCycles count of Awan cycles to advance -/// @param[in] i_fixed Determination, for DFT, if this time is -/// fixed or not. Defaults to non-fixed -/// -/// @return ReturnCode. Zero on success, else platform specified error. -/// -ReturnCode delay(uint64_t i_nanoSeconds, uint64_t i_simCycles, - bool i_fixed = false); - -/// -/// @brief Assert a condition, and halt -/// -/// @param[in] i_expression a boolean representing the assertion -/// -void Assert(bool i_expression); -}; - -#endif // FAPI2_UTILS_H_ diff --git a/import/hwpf/fapi2/include/variable_buffer.H b/import/hwpf/fapi2/include/variable_buffer.H deleted file mode 100644 index e32c69e7..00000000 --- a/import/hwpf/fapi2/include/variable_buffer.H +++ /dev/null @@ -1,1291 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/variable_buffer.H $ */ -/* */ -/* OpenPOWER sbe 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 variable_buffer.H - * @brief definitions for fapi2 variable length buffers - */ - -#ifndef __FAPI2_VARIABLE_BUFFER__ -#define __FAPI2_VARIABLE_BUFFER__ - -#include <buffer_parameters.H> -#include <buffer_traits.H> -#include <return_code_defs.H> -#include <plat_trace.H> - -namespace fapi2 -{ - -// forward fapi2::Assert() -extern void Assert(bool); - - -/// @brief Get a 32 bit mask quickly -// This is one of the main reasons we static_assert in the ctor's -// to ensure the unit_type is 32 bits. -inline uint32_t fast_mask32(int32_t i_pos, int32_t i_len) -{ - // generates an arbitrary 32-bit mask using two operations, not too shabby - - static const uint32_t l_mask32[] = - { - 0x00000000, - 0x80000000, 0xC0000000, 0xE0000000, 0xF0000000, - 0xF8000000, 0xFC000000, 0xFE000000, 0xFF000000, - 0xFF800000, 0xFFC00000, 0xFFE00000, 0xFFF00000, - 0xFFF80000, 0xFFFC0000, 0xFFFE0000, 0xFFFF0000, - 0xFFFF8000, 0xFFFFC000, 0xFFFFE000, 0xFFFFF000, - 0xFFFFF800, 0xFFFFFC00, 0xFFFFFE00, 0xFFFFFF00, - 0xFFFFFF80, 0xFFFFFFC0, 0xFFFFFFE0, 0xFFFFFFF0, - 0xFFFFFFF8, 0xFFFFFFFC, 0xFFFFFFFE, 0xFFFFFFFF, - }; - return l_mask32[i_len] >> i_pos; -} - -// -// General set a series of bits in the buffer. -// - -/// -/// @cond -/// @brief Internal bit inserting method. -/// @tparam unit_type The type of a unit of the arrays -/// @tparam bits_type The type of the bit counting values -/// @param[in] i_source The incoming data -/// @param[in] i_source_length The length in bits of the incoming data -/// @param[in] i_target The outgoing data -/// @param[in] i_target_length The length in bits of the outgoing data -/// @param[in] i_source_start_bit The starting bit location in the -/// incoming data -/// @param[in] i_target_start_bit The starting bit position in this -/// @param[in] i_length The length, in bits, the user wants copied. -/// -template<typename unit_type, typename bits_type, typename output_type> -inline fapi2::ReturnCodes _insert(const unit_type* i_source, - bits_type i_source_length, - output_type* i_target, - bits_type i_target_length, - bits_type i_source_start_bit, - bits_type i_target_start_bit, - bits_type i_length) -{ - const bits_type bits_per_input_unit = parameterTraits<unit_type>::bit_length(); - const bits_type bits_per_output_unit = parameterTraits<output_type>::bit_length(); - - // targetStart is defaulted to the sizeof(target) - (sizeof(source) - i_source_start_bit) - // which makes this act like insert from right - if (i_target_start_bit == static_cast<bits_type>(~0)) - { - i_target_start_bit = (i_target_length - (i_source_length - i_source_start_bit)); - } - - // len defaults to (sizeof(OT) * 8) - i_source_start_bit - if (i_length == static_cast<bits_type>(~0)) - { - i_length = i_source_length - i_source_start_bit; - } - - // Check for overflow - if ((i_length + i_target_start_bit > i_target_length) || - (i_length + i_source_start_bit > i_source_length)) - { - return fapi2::FAPI2_RC_OVERFLOW; - } - - do - { - const bits_type src_idx = i_source_start_bit / bits_per_input_unit; - const bits_type trg_idx = i_target_start_bit / bits_per_output_unit; - - // "slop" = unaligned bits - const bits_type src_slop = i_source_start_bit % bits_per_input_unit; - const bits_type trg_slop = i_target_start_bit % bits_per_output_unit; - - // "cnt" = largest number of bits to be moved each pass - bits_type cnt = std::min(i_length, bits_per_input_unit); - cnt = std::min(cnt, bits_per_input_unit - src_slop); - cnt = std::min(cnt, bits_per_output_unit - trg_slop); - - // generate the source mask only once - bits_type mask = fast_mask32(src_slop, cnt); - - // read the source bits only once - bits_type src_bits = i_source[src_idx] & mask; - - // "shift" = amount of shifting needed for target alignment - int32_t shift = trg_slop - src_slop; - - if (shift < 0) - { - src_bits <<= -shift; - mask <<= -shift; - } - else - { - src_bits >>= shift; - mask >>= shift; - } - - // clear source '0' bits in the target - i_target[trg_idx] &= ~mask; - - // set source '1' bits in the target - i_target[trg_idx] |= src_bits; - - i_source_start_bit += cnt; - i_target_start_bit += cnt; - - i_length -= cnt; - - } - while (0 < i_length); - - return fapi2::FAPI2_RC_SUCCESS; -} -/// @endcond - -/// @brief Class representing a FAPI variable_buffer. -/// @remark Variable buffers are buffers which can be variable in length -/// (and "odd sized.") These best represent the FAPI 1.X ecmdDataBuffer, -/// however they are implemented using the same template techniques -/// as the new fapi::buffer. -/// @note Variable buffers are not (presently) declared as std::bitset -/// as bitsets' size is fixed at runtime. It is not clear if this is -/// acceptable for variable_buffers at this time. -/// @note Variable buffers are implemented as a std::vector of uint32_t -/// as this keeps simple compatibility with ecmdDataBuffers. Cronus (at -// least) needs to interwork the two. -class variable_buffer -{ - - public: - - /// Shortcut typedef to get to our traits class - typedef typename bufferTraits<bits_container>::bits_type bits_type; - /// Shortcut typedef to get to our traits class - typedef typename bufferTraits<bits_container>::unit_type unit_type; - - /// - /// @brief Variable buffer constructor - /// @param[in] i_value number of *bits* (sizeof(uint_type) * 8) - /// needed. - inline variable_buffer(bits_type i_value = 0): - iv_data(_vector_size(i_value)), - iv_perceived_bit_length(i_value) - { - static_assert(std::is_same<unit_type, uint32_t>::value, - "code currently needs unit_type to be a unit32_t"); - } -#ifndef NO_INITIALIZER_LIST - /// - /// @brief Variable buffer list constructor - /// @param[in] i_value an initializer list to initialize the container. - /// @warning Input data is assumed to be right-aligned and must be 32 bits - /// - inline variable_buffer(const std::initializer_list<unit_type>& i_value): - iv_data(i_value), - iv_perceived_bit_length(i_value.size() * sizeof(unit_type) * 8) - { - static_assert(std::is_same<unit_type, uint32_t>::value, - "code currently needs unit_type to be a unit32_t"); - } -#endif - /// - /// @brief Variable buffer copy constructor - /// @param[in] i_buffer the buffer to copy from - /// - inline variable_buffer(const variable_buffer& i_buffer) - { - iv_perceived_bit_length = i_buffer.iv_perceived_bit_length; - iv_data = i_buffer.iv_data; - } - - /// - /// @brief Variable buffer move constructor - /// @param[in] i_buffer the buffer to move - /// - inline variable_buffer(variable_buffer&& i_buffer) - { - iv_perceived_bit_length = i_buffer.iv_perceived_bit_length; - i_buffer.iv_perceived_bit_length = 0; - iv_data = std::move(i_buffer.iv_data); - } - - /// - /// @brief Variable buffer array constructor - /// @param[in] i_value a uint32_t array to initialize the container. - /// @param[in] i_length the length of the array in 32-bit words - /// @param[in] i_bit_length the length of the resulting buffer in bits. - /// @warning This assumes the underlying container of a variable_buffer - /// is a uint32_t - which it is. - /// @note To use this constructor given an ecmdDataBuffer, you would - /// ecmd.memCopyOut( buffer, ... ); - /// variable_buffer( buffer, ecmd.getCapacity(), ecmd.getBitLength()); - /// - inline variable_buffer(const uint32_t* i_value, const uint32_t i_length, - const uint32_t i_bit_length): - iv_perceived_bit_length(i_bit_length) - { - static_assert(std::is_same<unit_type, uint32_t>::value, - "code currently needs unit_type to be a unit32_t"); - - // Copy the array in to our vector. - iv_data.insert(iv_data.end(), i_value, &i_value[i_length]); - } - - -#if !defined(DOXYGEN) && defined(FAPI2_DEBUG) - /// @brief Print the contents of the buffer to stdout - inline void print(void) const - { - bufferTraits<bits_container>::print(iv_data); - } -#endif - - /// - /// @brief Get the contents of the buffer - /// @return The contents of the buffer - /// - inline operator bits_container() const - { - return iv_data; - } - - /// - /// @brief Get the contents of the buffer - /// @return The contents of the buffer - /// - inline operator bits_container& () - { - return iv_data; - } - - /// - /// @brief Get the contents of the buffer - /// @return The contents of the buffer - /// - inline bits_container& operator()(void) - { - return iv_data; - } - - /// - /// @brief Get the contents of the buffer - /// @return Reference to the contents of the buffer - /// - inline const bits_container& operator()(void) const - { - return iv_data; - } - - /// @name Buffer Manipulation Functions - ///@{ - - /// - /// @brief Set an OT of data in buffer. - /// - /// It is possible to write the incomplete last OT of a buffer that's not - /// an integer multiple of OT's size in bits; in that case, the value will - /// be treated left aligned and truncated. - /// - /// @param[in] i_value sizeof(OT) bits of data - /// @param[in] i_offset Start OT (start word, for example) in buffer - /// - defaults to 0 (will by default write the left most element) - /// @return FAPI2_RC_SUCCESS on success, FAPI2_RC_OVERFLOW otherwise - /// - template< typename OT> - inline fapi2::ReturnCodes set(OT i_value, const bits_type i_offset = 0) - { - // Compile time check to make sure OT is integral - static_assert( std::is_integral<OT>::value, - "Input must be an integral type" ); - - const bits_type bits_in_value = parameterTraits<OT>::bit_length(); - const bits_type bit_offset = i_offset * bits_in_value; - - if (bit_offset >= iv_perceived_bit_length) - { - return FAPI2_RC_OVERFLOW; - } - - const bits_type available_space = iv_perceived_bit_length - bit_offset; - - return insert<OT>( i_value, (i_offset * bits_in_value), std::min(available_space, bits_in_value), 0); - - } - - /// - /// @brief Get an OT of data from buffer - /// - /// It is possible to read the incomplete last OT of a buffer that's not - /// an integer multiple of OT's size in bits; in that case, the return - /// value will contain the remaining bits left-aligned. - /// - /// @tparam OT the type of the data to get - /// @param[in] i_offset Start OT (start word, for example) in buffer - /// - defaults to 0 (will by default read the left most element) - /// @return OT - /// @note uint8_t b = get<uint8_t>(N) <- gets the N'th left byte from the buffer - /// - template< typename OT> - inline OT get(const bits_type i_offset = 0) const; - - /// @name Bit/Word Manipulation Functions - ///@{ - - /// - /// @brief Return the length of the buffer in bits - /// @return Length in bits - /// - inline uint32_t getBitLength(void) const - { - return iv_perceived_bit_length; - } - - /// - /// @brief Return the length of the buffer in OT units - /// @return Length in OT units rounded up - /// @tparam OT the type to get the length of. For example, if one - /// wanted the length in double words, OT would be uint64_t - /// (getLength<uint64_t>().) Similarly, to get the length in words, - /// getLength<uin32_t>(). - /// - template< typename OT > - inline uint32_t getLength(void) const - { - static const uint32_t bits_in_ot = sizeof(OT) * 8; - return (getBitLength() + (bits_in_ot - 1)) / bits_in_ot; - } - - /// - /// @brief Set a bit in buffer - /// @tparam SB Start bit in buffer to clear. - /// @tparam L Number of consecutive bits from start bit to - /// clear - /// @return FAPI2_RC_SUCCESS on success - inline fapi2::ReturnCodes setBit( const bits_type SB, bits_type L = 1) - { - - ReturnCodes rc; - // make sure we stay within our container - fapi2::Assert((L > 0) && ((SB + L) <= this->iv_perceived_bit_length) ); - - uint32_t mask = 0; - - // last bit to check - bits_type EB = SB + L - 1; - - // index where first bit to check is located - bits_type start_index = SB / bits_per_unit; - - // index where last bit is located - bits_type end_index = EB / bits_per_unit; - - if( start_index == end_index ) - { - // normalize our SB to be within a unit - bits_type TempSB = SB - (start_index * bits_per_unit); - - // grab a mask from SB for L number of bits. - mask = fast_mask32(TempSB, L); - - iv_data[start_index] |= mask; - - rc = FAPI2_RC_SUCCESS; - - } - else - { - // the bits span more than one internal unit, need to break - // it up to process it. - - // make TempSB point to the start of the next unit, adjust the - // length and go again, process the bits in the previous index - // when we get back. - bits_type TempSB = (start_index + 1) * bits_per_unit; - bits_type TempL = EB - TempSB + 1; - - rc = this->setBit( TempSB, TempL ); - - if(rc == FAPI2_RC_SUCCESS) - { - // now check the bits in the previous index up to the next index. - // normalize our SB to be within a unit - TempSB = SB - (start_index * bits_per_unit); - - // get a mask for the new SB location to the end of this unit. - mask = fast_mask32(TempSB, L - TempL); - - // merge theses bits with the others. - iv_data[start_index] |= mask; - } - - } - - return rc; - } - - /// - /// @brief Clear a bit in buffer - /// @tparam SB Start bit in buffer to clear. - /// @tparam L Number of consecutive bits from start bit to - /// clear - /// @return FAPI2_RC_SUCCESS on success - /// @note Asserting that all the parameters are known at - /// compile time so this can be templated only. If that is not - /// the case we can add a function parameter version. - /// - inline fapi2::ReturnCodes clearBit(bits_type SB, bits_type L = 1) - { - ReturnCodes rc = invert().setBit(SB, L); - - invert(); - - return rc; - } - - /// - /// @brief invert a bit or range of bits in a buffer - /// @tparam SB Start bit in buffer to invert. - /// @tparam L Number of consecutive bits from start bit to - /// invert, defaults to 1 - /// @return FAPI2_RC_SUCCESS on success - /// - inline fapi2::ReturnCodes flipBit( bits_type SB, bits_type L = 1) - { - ReturnCodes rc; - - // make sure we are within our container - if((SB + L) <= this->iv_perceived_bit_length) - { - // loop for L bits flipping as you go - for( bits_type i = 0; i < L; i++) - { - bits_type bit = SB + i; - - if(this->isBitSet(bit)) - { - rc = this->clearBit(bit); - } - else - { - rc = this->setBit(bit); - } - } - } - else - { - rc = FAPI2_RC_OVERFLOW; - } - - return rc; - } - - /// - /// @brief Get the value of a bit in the buffer - /// @tparam B Bit in buffer to get. - /// @return true/1 if bit is on, false/0 if bit is off - /// @note Asserting that all the parameters are known at - /// compile time so this can be templated only. If that is not - /// the case we can add a function parameter version. - /// - template< bits_type B > - inline bool getBit(void) const - { - const bits_type index = B / bits_per_unit; - const unit_type mask = unit_type(1) << - ((bits_per_unit - 1) - (B - (index * bits_per_unit))); - return iv_data[index] & mask; - } - - /// - /// @brief Test if multiple bits are set - /// @param SB Start bit in buffer to test. - /// @param L Number of consecutive bits from start bit to - /// test, defaults to 1 - /// @return true if all bits in range are set - false if any - /// bit is clear - /// @note Example: fapi2::buffer<uint64_t>().isBitSet(4,3); - inline bool isBitSet( bits_type SB, bits_type L = 1 ) const - { - // make sure we stay within our container - fapi2::Assert( ((L > 0) && ((SB + L) <= this->iv_perceived_bit_length)) ); - - bool is_set = false; - uint32_t mask = 0; - - // last bit to check - bits_type EB = SB + L - 1; - - // index where first bit to check is located - bits_type start_index = SB / bits_per_unit; - - // index where last bit is located - bits_type end_index = EB / bits_per_unit; - - if( start_index == end_index ) - { - // normalize our SB to be within a unit - bits_type TempSB = SB - (start_index * bits_per_unit); - - // grab a mask from SB for L number of bits. - mask = fast_mask32(TempSB, L); - - is_set = - (( iv_data[start_index] & mask) == mask ) ? true : false; - - } - else - { - // the bits span more than one internal unit, need to break - // it up to process it. - - // make TempSB point to the start of the next unit, adjust the - // length and go again, process the bits in the previous index - // when we get back. - bits_type TempSB = (start_index + 1) * bits_per_unit; - bits_type TempL = EB - TempSB + 1; - - is_set = this->isBitSet( TempSB, TempL ); - - // now check the bits in the previous index up to the next index. - // normalize our SB to be within a unit - TempSB = SB - (start_index * bits_per_unit); - - // get a mask for the new SB location to the end of this unit. - mask = fast_mask32(TempSB, L - TempL); - - // test these bits against the others.. - is_set &= - (( iv_data[start_index] & mask) == mask ) ? true : false; - - } - - return is_set; - } - - /// - /// @brief Test if multiple bits are clear - /// @param SB Start bit in buffer to test. - /// @param L Number of consecutive bits from start bit to - /// test, defaults to 1 - /// @return true if bit is clear - false if bit is set - /// - inline bool isBitClear( bits_type SB, bits_type L = 1 ) const - { - variable_buffer l_buf = *this; - - return l_buf.invert().isBitSet(SB, L); - } - - /// - /// @brief Count number of bits set in a range - /// @tparam SB Start bit in buffer to test. - /// @tparam L Number of consecutive bits from start bit to - /// test, defaults to 1 - /// - inline bits_type getNumBitsSet(bits_type SB, bits_type L = 1) const - { - bits_type number_of_bits_set = 0; - - for(bits_type i = 0; i < L; i++) - { - if( this->isBitSet(SB + i) ) - { - number_of_bits_set++; - } - } - - return number_of_bits_set; - } - - /// - /// @brief Set and entire buffer to X's - /// @tparam X {0,1} depending if you want to clear (0) - /// or fill (1) a buffer - /// @return variable_buffer&, Useful for method chaining - /// - template< uint8_t X > - inline variable_buffer& flush(void) - { - static_assert( (X == 1) || (X == 0), "bad argument to flush" ); - (0 == X) ? bufferTraits<bits_container>::clear(iv_data) : bufferTraits<bits_container>::set(iv_data); - return *this; - } - - /// - /// @brief Invert entire buffer - /// @return variable_buffer&, Useful for method chaining - /// - inline variable_buffer& invert(void) - { - bufferTraits<bits_container>::invert(iv_data); - return *this; - } - - ///@} - - /// @name Buffer Manipulation Functions - ///@{ - - /// - /// @brief Shift a buffer left a defined number of bits, from a start bit - /// @param[in] i_shiftNum number of bits to shift - /// @param[in] i_offset offset from 0 to start shift, defaults to ~0 (see operator<<()) - /// @note an offset of ~(0) implies "end of the buffer" - /// @warning there is no shiftLeftandResize - resizing the buffer is left to - /// the caller to alight the operations with integral buffers. - /// @return FAPI2_RC_SUCCESS on success - /// - inline ReturnCodes shiftLeft(bits_type i_shiftNum, bits_type i_offset = ~0); - - /// - /// @brief Shift a buffer right a defined number of bits, from a start bit - /// @param[in] i_shiftNum number of bits to shift - /// @param[in] i_offset offset from 0 to start shift, defaults to 0 (see operator>>()) - /// @warning there is no shiftRightandResize - resizing the buffer is left to - /// the caller to alight the operations with integral buffers. - /// @return FAPI2_RC_SUCCESS on success - /// - inline ReturnCodes shiftRight(bits_type i_shiftNum, bits_type i_offset = 0); - - /// - /// @brief move operator=() - /// @note To use: new_buffer = std::move(old_buffer). old_buffer will be - /// destroyed and no copy will be made (moved) - /// - inline variable_buffer& operator=(variable_buffer&& other) - { - iv_perceived_bit_length = other.iv_perceived_bit_length; - other.iv_perceived_bit_length = 0; - iv_data = std::move(other.iv_data); - return *this; - } - - /// - /// @brief operator=() - /// - inline variable_buffer& operator=(const variable_buffer& other) - { - iv_perceived_bit_length = other.iv_perceived_bit_length; - iv_data = other.iv_data; - return *this; - } - - /// - /// @brief operator>>() - /// - inline variable_buffer& operator>>(bits_type i_shiftnum) - { - // This is just a right shift from the begining of the buffer - // Why void? Well, there's no place to return the return - // code and in reality the only problem which can arise - // is the offset is out of bounds. But since we're hard-wiring it - // to 0, it can't be out of bounds. So there's no real problem - // which can arise here. - static_cast<void>(shiftRight(i_shiftnum)); - return *this; - } - - /// - /// @brief operator<<() - /// - inline variable_buffer& operator<<(bits_type i_shiftnum) - { - // This is just a left shift from the end of the buffer - // Why void? Well, there's no place to return the return - // code and in reality the only problem which can arise - // is the offset is out of bounds. But since we're hard-wiring it - // to 0, it can't be out of bounds. So there's no real problem - // which can arise here. - static_cast<void>(shiftLeft(i_shiftnum)); - return *this; - } - - - /// - /// @brief operator+() - /// @param[in] rhs A variable_buffer to append to this - /// - inline variable_buffer& operator+(const variable_buffer& rhs) - { - iv_perceived_bit_length += rhs.iv_perceived_bit_length; - iv_data.insert(iv_data.end(), rhs.iv_data.begin(), rhs.iv_data.end()); - return *this; - } - - /// - /// @brief operator+() - /// @param[in] rhs A number of bits to add to this buffer - /// - inline variable_buffer& operator+(const bits_type& rhs) - { - if (rhs != 0) - { - iv_perceived_bit_length += rhs; - iv_data.resize(_vector_size(iv_perceived_bit_length)); - } - - return *this; - } - - /// - /// @brief resize() - /// @param[in] rhs Desired resulting size of the buffer, in bits - /// - inline variable_buffer& resize(const bits_type& rhs) - { - return operator+(rhs - iv_perceived_bit_length); - } - - /// - /// @brief operator+=() - /// -#ifdef DOXYGEN - inline variable_buffer<T>& operator+=(const T& rhs); -#endif - - /// - /// @brief operator|=() - /// -#ifdef DOXYGEN - inline variable_buffer<T>& operator|=(const T& rhs); -#endif - - /// - /// @brief operator&=() - /// -#ifdef DOXYGEN - inline variable_buffer<T>& operator&=(const T& rhs); -#endif - - /// - /// @brief operator|() - /// -#ifdef DOXYGEN - inline variable_buffer<T>& operator|(const T& rhs); -#endif - - /// - /// @brief operator&() - /// -#ifdef DOXYGEN - inline variable_buffer<T>& operator&(const T& rhs); -#endif - - /// - /// @brief operator^=() - /// -#ifdef DOXYGEN - inline variable_buffer<T>& operator^=(const T& rhs); -#endif - - /// - /// @brief Get a pointer to the buffer bits - /// @return Pointer to the buffer itself - /// - inline unit_type* pointer(void) - { - return &(iv_data[0]); - } - - /// - /// @brief operator!=() - /// - inline bool operator!=(const variable_buffer& rhs) const - { - return ! operator==(rhs); - } - - /// - /// @brief operator==() - /// @return true if and only if lhs == rhs - /// - inline bool operator==(const variable_buffer& rhs) const - { - if (&iv_data == &rhs.iv_data) - { - return true; - } - - return (iv_data == rhs.iv_data) && - (iv_perceived_bit_length == rhs.iv_perceived_bit_length); - } - - /// - /// @brief Copy part of an element into the DataBuffer - /// @param[in] i_data OT value to copy into DataBuffer - /// @param[in] i_targetStart The position in this where the copy starts - /// @param[in] i_len How many bits to copy - /// @param[in] i_sourceStart The start positon in i_data, defaults to 0 - /// @return FAPI2_RC_SUCCESS on success, FAPI2_RC_OVERFLOW otherwise - /// - template<typename OT> - inline fapi2::ReturnCodes insert(const OT& i_data, - bits_type i_targetStart = 0, - bits_type i_len = ~0, - bits_type i_sourceStart = 0) - { - // Compile time check to make sure OT is integral - static_assert( std::is_integral<OT>::value, - "Input must be an integral type" ); - - // _insert likes 32-bit sources. So lets make our source 32 bits. - uint32_t l_source = static_cast<uint32_t>(i_data); - bits_type l_sourceStart = i_sourceStart + - parameterTraits<uint32_t>::bit_length() - - parameterTraits<OT>::bit_length(); - - return _insert(&l_source, parameterTraits<uint32_t>::bit_length(), - &(iv_data[0]), getBitLength(), - l_sourceStart, i_targetStart, i_len); - } - - /// - /// @brief Copy in a right aligned (decimal) element - /// @param[in] i_data the incoming data - /// - data is taken right aligned - /// @param[in] i_targetStart The starting bit position in this - /// - Defaults to 0 - /// @param[in] i_len The length, in bits, the user wants copied. - /// - Defaults to all of the bits in the source which fit - /// @return FAPI2_RC_SUCCESS on success, FAPI2_RC_OVERFLOW otherwise - /// - template<typename OT> - inline fapi2::ReturnCodes insertFromRight(const OT& i_data, - bits_type i_targetStart = 0, - bits_type i_len = ~0) - { - return _insertFromRight(i_data, parameterTraits<OT>::bit_length(), - i_targetStart, i_len); - } - - /// - /// @brief Copy data from this buffer into an OT - /// @tparam OT the type of the outgoing data - /// @param[out] o_out OT to copy into - data is placed left aligned - /// @param[in] i_start Start bit to copy from - defaults to 0 - /// @param[in] i_len Length of bits to copy - defaults to filling o_out - /// @return FAPI2_RC_SUCCESS on success - /// @warning fapi2::extract() does not extend the argument buffer. The caller - /// should adjust the size proir to calling extract() (resize()). This is to - /// keep the semantics the same with integral buffers, which can't be resized. - /// - // Generic extract. Extract is an insert with the arguments reversed. - template< typename OT > - inline fapi2::ReturnCodes extract(OT& o_out, - bits_type i_start = 0, - bits_type i_len = ~0) const - { - // If they didn't pass an i_len, assume they want all the data - // which will fit. - if (i_len == static_cast<bits_type>(~0)) - { - i_len = std::min(getBitLength(), - parameterTraits<OT>::bit_length()); - } - - if (i_len > getBitLength()) - { - return FAPI2_RC_INVALID_PARAMETER; - } - - // _insert likes 32-bit targets. So lets make our target 32 bits. - uint32_t l_data = static_cast<uint32_t>(o_out); - - ReturnCodes rc; - - if ((rc = _insert((container_unit*)&iv_data[0], getBitLength(), - &l_data, - parameterTraits<uint32_t>::bit_length(), - i_start, 0U, i_len)) != FAPI2_RC_SUCCESS) - { - return rc; - } - - // Shift back to the original bit width. - o_out = l_data >> (parameterTraits<uint32_t>::bit_length() - - parameterTraits<OT>::bit_length()); - return FAPI2_RC_SUCCESS; - } - - /// - /// @brief Copy data from this buffer into an OT and right justify - /// @tparam OT the type of the outgoing data - /// @param[out] o_out OT to copy into - data is placed right aligned - /// @param[in] i_start Start bit to copy from - defaults to 0 - /// @param[in] i_len Length of bits to copy - defaults to filling o_out - /// @return FAPI2_RC_SUCCESS on success - /// - // Extract is an insert with the arguments reversed. - template< typename OT > - inline fapi2::ReturnCodes extractToRight(OT& o_out, - bits_type i_start = 0, - bits_type i_len = ~0) const - { - // If thy didn't pass an i_len, assume they want all the data - // which will fit. - if ((i_len == static_cast<bits_type>(~0)) || - (i_len > parameterTraits<OT>::bit_length())) - { - i_len = std::min(getBitLength(), - parameterTraits<OT>::bit_length()); - } - - // _insert likes 32-bit targets. So lets make our target 32 bits. - uint32_t l_data = static_cast<uint32_t>(o_out); - - ReturnCodes rc; - - if ((rc = _insert( - reinterpret_cast<const container_unit*>(&iv_data[0]), - getBitLength(), - &l_data, - parameterTraits<uint32_t>::bit_length(), - i_start, - parameterTraits<uint32_t>::bit_length() - - i_len, i_len)) != FAPI2_RC_SUCCESS) - { - return rc; - } - - o_out = l_data; - return FAPI2_RC_SUCCESS; - } - - ///@} - - private: - // Just shorthand ... - static const bits_type bits_per_unit = bufferTraits<bits_container>::bits_per_unit(); - - ///@cond - /// - /// @brief Return the size of the internal vector given a desired bit size - /// @param[in] The size in bits - /// @return The size in units. - /// - inline bits_type _vector_size(const bits_type& bits_size) - { - // If we fit in one unit, we allocate one unit. - if (bits_size < parameterTraits<unit_type>::bit_length()) - { - return 1; - } - - // Otherwise, the number of units is calculates - add one if - // we cross the unit boundary. - else - { - bits_type my_size = bits_type(bits_size / 8 / sizeof(unit_type)); - my_size += (bits_size % parameterTraits<unit_type>::bit_length() == 0) ? 0 : 1; - return my_size; - } - } - ///@endcond - - /// The contents of the buffer - bits_container iv_data; - - // The number of bits the user asked for. The actual size of the - // container might be larger. - bits_type iv_perceived_bit_length; - - /// - /// @brief Internal insertFromRight - /// @param[in] i_data, the incoming data - /// @param[in] i_data_length The length in bits of the incoming data - /// @param[in] i_target_start_bit The starting bit position in this - /// @param[in] i_length The length, in bits, the user wants copied. - /// - template<typename OT> - inline fapi2::ReturnCodes _insertFromRight(const OT& i_data, - bits_type i_data_length, - bits_type i_targetStart, - bits_type i_len) - { - // If they didn't pass in a length, assume they want all the i_data - // which will fit. - if( i_len == static_cast<bits_type>(~0) ) - { - // The longest the length can be is the length of the data - // This is the miniumum of the length of the data or the - // number of available bits - i_len = std::min(i_data_length, getBitLength() - i_targetStart); - } - - // Source start is the length, counted from the right - return insert(i_data, i_targetStart, i_len, i_data_length - i_len); - } - -}; - -// If the source is 64-bits, treat that as 2x32 -template<> -inline fapi2::ReturnCodes variable_buffer::insert(const uint64_t& i_source, - bits_type i_targetStart, - bits_type i_len, - bits_type i_sourceStart) -{ - // _insert wants 32 bit chunks, so lets turn our uint64_t into a - // uint32_t array (of 64 bits in length). Looks like a 64 bit - // variable_buffer. - uint32_t l_source[2] = - { - static_cast<uint32_t>((i_source & 0xFFFFFFFF00000000) >> 32), - static_cast<uint32_t>((i_source & 0x00000000FFFFFFFF)) - }; - - return _insert(l_source, parameterTraits<uint64_t>::bit_length(), - &(iv_data[0]), getBitLength(), - i_sourceStart, i_targetStart, i_len); -} - -// Insert another variable_buffer -template<> -inline fapi2::ReturnCodes variable_buffer::insert( - const variable_buffer& i_data, - bits_type i_targetStart, - bits_type i_len, - bits_type i_sourceStart) -{ - return _insert(reinterpret_cast<const unit_type*>(&(i_data()[0])), - i_data.getBitLength(), - &(iv_data[0]), getBitLength(), - i_sourceStart, i_targetStart, i_len); -} - -// variable_buffer insert from right -template<> -inline fapi2::ReturnCodes variable_buffer::insertFromRight( - const variable_buffer& i_data, - bits_type i_targetStart, - bits_type i_len) -{ - const bits_type bit_length_of_source = i_data.getBitLength(); - return _insertFromRight(i_data, bit_length_of_source, - i_targetStart, i_len); -} - -template<> -inline fapi2::ReturnCodes variable_buffer::extract( - uint64_t& i_data, - bits_type i_start, - bits_type i_len) const -{ - // If thy didn't pass an i_len, assume they want all the data - // which will fit. - if ((i_len == static_cast<bits_type>(~0)) || - (i_len > parameterTraits<uint64_t>::bit_length())) - { - i_len = std::min(getBitLength(), - parameterTraits<uint64_t>::bit_length()); - } - - // _insert wants 32 bit chunks, so lets turn our uint64_t into a - // uint32_t array (of 64 bits in length). Looks like a 64 bit - // variable_buffer. - uint32_t l_data[2] = - { - static_cast<uint32_t>((i_data & 0xFFFFFFFF00000000) >> 32), - static_cast<uint32_t>((i_data & 0x00000000FFFFFFFF)) - }; - - ReturnCodes rc; - - if ((rc = _insert((container_unit*)&iv_data[0], getBitLength(), - l_data, parameterTraits<uint64_t>::bit_length(), - i_start, 0U, i_len)) != FAPI2_RC_SUCCESS) - { - return rc; - } - - i_data = static_cast<uint64_t>(l_data[0]) << 32; - i_data |= l_data[1]; - - return FAPI2_RC_SUCCESS; -} - -// Extract in to another variable_bufer -template<> -inline fapi2::ReturnCodes variable_buffer::extract( - variable_buffer& i_data, - bits_type i_start, - bits_type i_len) const -{ - // If thy didn't pass an i_len, assume they want all the data - // which will fit. - if (i_len == static_cast<bits_type>(~0)) - { - i_len = i_data.getBitLength(); - } - - return _insert(reinterpret_cast<const container_unit*>( - &iv_data[0]), - getBitLength(), - &(i_data()[0]), i_data.getBitLength(), - i_start, 0U, i_len); -} - -template<> -inline fapi2::ReturnCodes variable_buffer::extractToRight( - uint64_t& i_data, - bits_type i_start, - bits_type i_len) const -{ - // If thy didn't pass an i_len, assume they want all the data - // which will fit. - if ((i_len == static_cast<bits_type>(~0)) || - (i_len > parameterTraits<uint64_t>::bit_length())) - { - i_len = std::min(getBitLength(), - parameterTraits<uint64_t>::bit_length()); - } - - // _insert wants 32 bit chunks, so lets turn our uint64_t into a - // uint32_t array (of 64 bits in length). - uint32_t l_data[2] = - { - static_cast<uint32_t>((i_data & 0xFFFFFFFF00000000) >> 32), - static_cast<uint32_t>((i_data & 0x00000000FFFFFFFF)) - }; - - ReturnCodes rc; - - if ((rc = _insert( - reinterpret_cast<const container_unit*>(&iv_data[0]), - getBitLength(), - l_data, parameterTraits<uint64_t>::bit_length(), - i_start, - parameterTraits<uint64_t>::bit_length() - i_len, i_len)) - != FAPI2_RC_SUCCESS) - { - return rc; - } - - i_data = static_cast<uint64_t>(l_data[0]) << 32; - i_data |= l_data[1]; - - return FAPI2_RC_SUCCESS; -} - -inline fapi2::ReturnCodes variable_buffer::shiftLeft( - bits_type i_shiftNum, - bits_type i_offset) -{ - if (i_offset == 0) - { - return FAPI2_RC_SUCCESS; - } - - if (i_offset == static_cast<bits_type>(~0)) - { - i_offset = getBitLength(); - } - - else if (i_offset > getBitLength()) - { - return FAPI2_RC_INVALID_PARAMETER; - } - - /* To shift the data, extact the piece being shifted and then re-insert it at the new location */ - variable_buffer shiftData(i_offset); - ReturnCodes rc; - - // Get the hunk of data - if ((rc = extract(shiftData, 0, i_offset)) != FAPI2_RC_SUCCESS) - { - return rc; - } - - // Clear the hole that was opened - if ((rc = clearBit((i_offset - i_shiftNum), i_shiftNum)) != FAPI2_RC_SUCCESS) - { - return rc; - } - - // Stick the data back in - rc = insert(shiftData, 0, (shiftData.getBitLength() - i_shiftNum), i_shiftNum); - - return rc; -} - -inline fapi2::ReturnCodes variable_buffer::shiftRight( - bits_type i_shiftNum, - bits_type i_offset) -{ - if (i_offset == getBitLength()) - { - return FAPI2_RC_SUCCESS; - } - - if (i_offset > getBitLength()) - { - return FAPI2_RC_INVALID_PARAMETER; - } - - /* To shift the data, extact the piece being shifted and then re-insert it at the new location */ - variable_buffer shiftData(getBitLength() - i_offset); - ReturnCodes rc; - - // Get the hunk of data - if ((rc = extract(shiftData, i_offset, getBitLength() - i_offset)) != FAPI2_RC_SUCCESS) - { - return rc; - } - - // Clear the hole that was opened - if ((rc = clearBit(i_offset, i_shiftNum)) != FAPI2_RC_SUCCESS) - { - return rc; - } - - // Stick the data back in - rc = insert(shiftData, (i_offset + i_shiftNum), (shiftData.getBitLength() - i_shiftNum)); - - return rc; -} - -template< typename OT> -inline OT variable_buffer::get(const bits_type i_offset) const -{ - const bits_type bits_in_value = parameterTraits<OT>::bit_length(); - const bits_type bit_offset = i_offset * bits_in_value; - - if (bit_offset >= iv_perceived_bit_length) - { - FAPI_ERR("Overrun in variable_buffer::get<OT>() - bits_in_value=%d bit_offset=%d iv_perceived_bit_length=%d", - bits_in_value, bit_offset, iv_perceived_bit_length); - fapi2::Assert(false); - } - - // Get is just an extract. - OT l_tmp = OT(0); - const bits_type available_space = iv_perceived_bit_length - bit_offset; - extract(l_tmp, bit_offset, std::min(available_space, bits_in_value)); - return l_tmp; -} -} -#endif diff --git a/import/hwpf/fapi2/include/variable_buffer_utils.H b/import/hwpf/fapi2/include/variable_buffer_utils.H deleted file mode 100644 index b1ae4664..00000000 --- a/import/hwpf/fapi2/include/variable_buffer_utils.H +++ /dev/null @@ -1,149 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/variable_buffer_utils.H $ */ -/* */ -/* OpenPOWER sbe 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 */ - -#ifndef __FAPI2_VARIABLE_BUFFER_UTILS__ -#define __FAPI2_VARIABLE_BUFFER_UTILS__ - -#include <inttypes.h> - -#include <ecmdDataBufferBase.H> -#include <ecmdUtils.H> - -#include <variable_buffer.H> -#include <return_code_defs.H> -#include <plat_trace.H> - -namespace fapi2 -{ -/** @name Variable buffer utility functions for platforms that support eCMD **/ -//@{ - -/** - * @brief Copies contents of fapi2::variable_buffer to a ecmdDataBufferBase - * @param[in] i_src fapi::variable_buffer to copy from - * @param[out] o_dest ecmdDataBufferBase to copy to - * @return uint32_t return code zero if success - */ -inline uint32_t bufferCopy(ecmdDataBufferBase& o_dest, const fapi2::variable_buffer& i_src) -{ - uint32_t rc = 0; - uint32_t l_ecmdRc = 0; - uint32_t l_bitLength = i_src.getBitLength(); - const uint32_t l_bitsPerWord = sizeof(uint32_t) * 8; - uint32_t l_wordLength = l_bitLength / l_bitsPerWord; - uint32_t l_currentWord = 0; - uint32_t l_extractData = 0; - fapi2::ReturnCodes l_copy_rc = fapi2::FAPI2_RC_SUCCESS; - - l_ecmdRc = o_dest.setBitLength(l_bitLength); - - if (l_ecmdRc) - { - FAPI_ERR("Error calling o_dest.setBitLength(%d) rc = 0x%08X\n", - l_bitLength, l_ecmdRc); - rc = l_ecmdRc; - } - - while ((l_currentWord < l_wordLength) && (rc == 0)) - { - l_copy_rc = i_src.extract(l_extractData, l_currentWord * l_bitsPerWord, l_bitsPerWord); - - if (l_copy_rc != fapi2::FAPI2_RC_SUCCESS) - { - FAPI_ERR("Error calling i_src.extract(l_extractData, %d, %d) rc = 0x" UINT64_HEX16_FORMAT "\n", - l_currentWord * l_bitsPerWord, l_bitsPerWord, static_cast<uint64_t>(l_copy_rc)); - rc = static_cast<uint64_t>(l_copy_rc); - break; - } - - l_ecmdRc = o_dest.insert(l_extractData, l_currentWord * l_bitsPerWord, l_bitsPerWord, 0); - - if (l_ecmdRc) - { - FAPI_ERR("Error calling o_dest.insert(%08X, %d, %d, 0) rc = 0x%08X\n", - l_extractData, l_currentWord * l_bitsPerWord, l_bitsPerWord, l_ecmdRc); - rc = l_ecmdRc; - break; - } - - l_currentWord++; - } - - if ((l_bitLength > (l_wordLength * l_bitsPerWord)) && (rc == 0)) - { - uint32_t l_bitsRemaining = l_bitLength - (l_wordLength * l_bitsPerWord); - l_copy_rc = i_src.extract(l_extractData, l_wordLength * l_bitsPerWord, l_bitsRemaining); - - if (l_copy_rc != fapi2::FAPI2_RC_SUCCESS) - { - FAPI_ERR("error calling i_src.extract(l_extractData, %d, %d) rc = 0x" UINT64_HEX16_FORMAT "\n", - l_wordLength * l_bitsPerWord, l_bitsRemaining, static_cast<uint64_t>(l_copy_rc)); - rc = static_cast<uint64_t>(l_copy_rc); - } - else - { - l_ecmdRc = o_dest.insert(l_extractData, l_wordLength * l_bitsPerWord, l_bitsRemaining, 0); - - if (l_ecmdRc) - { - FAPI_ERR("Error calling o_dest.insert(%08X, %d, %d, 0) rc = 0x%08X\n", - l_extractData, l_wordLength * l_bitsPerWord, l_bitsRemaining, l_ecmdRc); - rc = l_ecmdRc; - } - } - } - - return rc; -} - -/** - * @brief Copies contents of ecmdDataBufferBase to a fapi2::variable_buffer - * @param[in] i_src ecmdDataBufferBase to copy from - * @param[out] o_dest fapi::variable_buffer to copy to - * @return uint32_t return code zero if success - */ -inline uint32_t bufferCopy(fapi2::variable_buffer& o_dest, ecmdDataBufferBase& i_src) -{ - uint32_t rc = 0; - uint32_t* l_data = ecmdDataBufferBaseImplementationHelper::getDataPtr(&i_src); - - if (l_data != NULL) - { - o_dest = fapi2::variable_buffer(l_data, i_src.getCapacity(), i_src.getBitLength()); - } - else - { - FAPI_ERR("Error getting data pointer to ecmdDataBufferBase\n"); - rc = 1; - } - - return rc; -} - -//@} - -} // namespace fapi2 - -#endif /* __FAPI2_VARIABLE_BUFFER_UTILS__ */ diff --git a/import/hwpf/fapi2/include/vpd_access_defs.H b/import/hwpf/fapi2/include/vpd_access_defs.H deleted file mode 100644 index 57d51e13..00000000 --- a/import/hwpf/fapi2/include/vpd_access_defs.H +++ /dev/null @@ -1,58 +0,0 @@ -/* IBM_PROLOG_BEGIN_TAG */ -/* This is an automatically generated prolog. */ -/* */ -/* $Source: import/hwpf/fapi2/include/vpd_access_defs.H $ */ -/* */ -/* OpenPOWER sbe Project */ -/* */ -/* Contributors Listed Below - COPYRIGHT 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 vpd_access_defs.H -/// -/// @brief VPD access definitions -/// - -#ifndef __VPDACCESSDEFS_H_ -#define __VPDACCESSDEFS_H_ - -#include <stdint.h> - -namespace fapi2 -{ - -// @brief VPD accesss enums -enum MemVpdData -{ - MR, //! Memory phase rotator - MT, //! Memory Termination - MP, //! Memory Power related info -}; - -typedef MemVpdData MemVpdData_t; - -/// @brief Class representing required VPDInfo to be used in vpd collection. -/// @tparam T, the type of target this class is used with. -/// -/// NOTE: to be defined by implementor -// -template<fapi2::TargetType T> -class VPDInfo; - -} -#endif diff --git a/import/hwpf/fapi2/tools/parseErrorInfo.pl b/import/hwpf/fapi2/tools/parseErrorInfo.pl deleted file mode 100755 index 8a431d1b..00000000 --- a/import/hwpf/fapi2/tools/parseErrorInfo.pl +++ /dev/null @@ -1,1596 +0,0 @@ -#!/usr/bin/perl -# IBM_PROLOG_BEGIN_TAG -# This is an automatically generated prolog. -# -# $Source: import/hwpf/fapi2/tools/parseErrorInfo.pl $ -# -# OpenPOWER sbe 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 parseErrorInfo.pl -# @brief This perl script will parse HWP Error XML files and generate required -# FAPI code to create and error log and add FFDC to the error. -# -# *HWP HWP Owner: N/A -# *HWP FW Owner: Thi Tran <thi@us.ibm.com> -# *HWP Team: N/A -# *HWP Level: 1 -# *HWP Consumed by: HB -# -# Usage: -# parseErrorInfo.pl <output dir> <filename1> <filename2> ... - -use strict; - -#------------------------------------------------------------------------------ -# Set PREFERRED_PARSER to XML::Parser. Otherwise it uses XML::SAX which contains -# bugs that result in XML parse errors that can be fixed by adjusting white- -# space (i.e. parse errors that do not make sense). -#------------------------------------------------------------------------------ -$XML::Simple::PREFERRED_PARSER = 'XML::Parser'; - -#------------------------------------------------------------------------------ -# Specify perl modules to use -#------------------------------------------------------------------------------ -use Digest::MD5 qw(md5_hex); -use XML::Simple; -my $xml = new XML::Simple (KeyAttr=>[]); - -# Uncomment to enable debug output -use Data::Dumper; -use Getopt::Long; - - -my @eiObjects = (); -my $target_ffdc_type = "fapi2::Target<T>"; -my $buffer_ffdc_type = "fapi2::buffer"; -my $variable_buffer_ffdc_type = "fapi2::variable_buffer"; -my $ffdc_type = "fapi2::ffdc_t"; -my $mcast_type = "fapi2::mcast_t"; - -# We want to keep the signatures for the ffdc gathering hwp so that -# we can create members of the proper types for the ffdc classes. -my %signatures = ("proc_extract_pore_halt_ffdc" => ["por_base_state", - "por_halt_type_t", - "por_ffdc_offset_t"], - "proc_example" => ["uint32_t","uint8_t"], - "proc_extract_pore_base_ffdc" => ["por_base_state", "por_sbe_base_state"], - "proc_tp_collect_dbg_data" => [$target_ffdc_type], - "p9_collect_some_ffdc" => ["uint32_t","uint8_t"], - ); - -# There are some names used in the XML files which exist in either -# c++ keywords (case, for example) or macros (DOMAIN). The one's which -# cause problems and need to be changed are here. -# -# DOMAIN is defined to 1 in math.h -my %mangle_names = ("DOMAIN" => "FAPI2_DOMAIN"); - -# A list of deprecated elements. These will report messages to the -# user, and not define anything. They have not been found to be used, -# but that doesn't mean they're not ... -my %deprecated = ("RC_PROCPM_PMCINIT_TIMEOUT" => "CHIP_IN_ERROR is defined as a callout procedure"); - -#------------------------------------------------------------------------------ -# Print Command Line Help -#------------------------------------------------------------------------------ -my $arg_empty_ffdc = undef; -my $arg_local_ffdc = undef; -my $arg_output_dir = undef; -my $arg_use_variable_buffers = undef; - -# Get the options from the command line - the rest of @ARGV will -# be filenames -GetOptions("empty-ffdc-classes" => \$arg_empty_ffdc, - "local-ffdc" => \$arg_local_ffdc, - "output-dir=s" => \$arg_output_dir, - "use-variable-buffers" => \$arg_use_variable_buffers); - -my $numArgs = $#ARGV + 1; -if (($numArgs < 1) || ($arg_output_dir eq undef)) -{ - print ("Usage: parseErrorInfo.pl [--empty-ffdc-classes] [--use-variable-buffers] --output-dir=<output dir> <filename1> <filename2> ...\n"); - print (" This perl script will parse HWP Error XML files and creates\n"); - print (" the following files:\n"); - print (" - hwp_return_codes.H. HwpReturnCode enumeration (HWP generated errors)\n"); - print (" - hwp_error_info.H. Error information (used by FAPI_SET_HWP_ERROR\n"); - print (" when a HWP generates an error)\n"); - print (" - collect_reg_ffdc_regs.H. File containing registers used by collectRegFfdc() \n"); - print (" - set_sbe_error.H. Macro to create an SBE error\n"); - print (" The --empty-ffdc-classes option is for platforms which don't collect ffdc.\n"); - exit(1); -} - -#------------------------------------------------------------------------------ -# Hashes containing error names/enum-values -#------------------------------------------------------------------------------ -my %errNameToValueHash; -my %errValuePresentHash; - -#------------------------------------------------------------------------------ -# Hashes containing ffdc names/enum-values -#------------------------------------------------------------------------------ -my %ffdcNameToValueHash = (); -my %ffdcValuePresentHash = (); - -#------------------------------------------------------------------------------ -# Subroutine that checks if an entry exists in an array. If it doesn't exist -# then it is added. The index of the entry within the array is returned -#------------------------------------------------------------------------------ -sub addEntryToArray -{ - my ($arrayref, $entry ) = @_; - - my $match = 0; - my $index = 0; - - foreach my $element (@$arrayref) - { - if ($element eq $entry) - { - $match = 1; - last; - } - else - { - $index++; - } - } - - if (!($match)) - { - push(@$arrayref, $entry); - } - - return $index; -} - -#------------------------------------------------------------------------------ -# Subroutine that figures out an error enum value from an error name and stores -# it in global hashes -#------------------------------------------------------------------------------ -sub setErrorEnumValue -{ - my $name = $_[0]; - - #-------------------------------------------------------------------------- - # Check that the error name is not a duplicate - #-------------------------------------------------------------------------- - if (exists($errNameToValueHash{$name})) - { - # Two different errors with the same name! - print ("fapiParseErrorInfo.pl ERROR. Duplicate error name ", $name, "\n"); - exit(1); - } - - #-------------------------------------------------------------------------- - # Figure out the error enum-value. This is a hash value generated from - # the error name. A hash is used for Cronus so that if a HWP is not - # recompiled against a new eCMD/Cronus version where the errors have - # changed then there will not be a mismatch in error values. - # This is a 24bit hash value because FAPI has a requirement that the - # top byte of the 32 bit error value be zero to store flags indicating - # the creator of the error - #-------------------------------------------------------------------------- - my $errHash128Bit = md5_hex($name); - my $errHash24Bit = substr($errHash128Bit, 0, 6); - - #-------------------------------------------------------------------------- - # Check that the error enum-value is not a duplicate - #-------------------------------------------------------------------------- - if (exists($errValuePresentHash{$errHash24Bit})) - { - # Two different errors generate the same hash-value! - print ("fapiParseAttributeInfo.pl ERROR. Duplicate error hash value\n"); - exit(1); - } - - #-------------------------------------------------------------------------- - # Update the hashes with the error name and ID - #-------------------------------------------------------------------------- - $errValuePresentHash{$errHash24Bit} = 1; - $errNameToValueHash{$name} = $errHash24Bit; -} - -#------------------------------------------------------------------------------ -# Subroutine that figures out an FFDC ID value from an FFDC name and stores it -# in global hashes for use when creating the enumeration of FFDC IDs -#------------------------------------------------------------------------------ -sub setFfdcIdValue -{ - my $name = $_[0]; - - #-------------------------------------------------------------------------- - # Check that the FFDC name is not a duplicate - #-------------------------------------------------------------------------- - if (exists($ffdcNameToValueHash{$name})) - { - # Two different FFDCs with the same name! - print ("fapiParseErrorInfo.pl ERROR. Duplicate FFDC name ", $name, "\n"); - exit(1); - } - - #-------------------------------------------------------------------------- - # Figure out the FFDC enum-value. This is a hash value generated from - # the FFDC name. - #-------------------------------------------------------------------------- - my $ffdcHash128Bit = md5_hex($name); - my $ffdcHash32Bit = substr($ffdcHash128Bit, 0, 8); - - #-------------------------------------------------------------------------- - # Check that the error enum-value is not a duplicate - #-------------------------------------------------------------------------- - if (exists($ffdcValuePresentHash{$ffdcHash32Bit})) - { - # Two different FFDCs generate the same hash-value! - print ("fapiParseAttributeInfo.pl ERROR. Duplicate FFDC hash value\n"); - exit(1); - } - - #-------------------------------------------------------------------------- - # Update the hashes with the error name and ID - #-------------------------------------------------------------------------- - $ffdcValuePresentHash{$ffdcHash32Bit} = 1; - $ffdcNameToValueHash{$name} = $ffdcHash32Bit; -} - -#------------------------------------------------------------------------------ -# Subroutine to create ffdc methods -#------------------------------------------------------------------------------ -sub addFfdcMethod -{ - my $methods = shift; - my $ffdc_uc = shift; - my $class_name = shift; - my $type = shift; - my $objectNumber = shift; - - # Remove the leading *_ - $class_name = (split (/_/, $class_name, 2))[1]; - - # If we didn't get a type passed in, this element will get an ffdc_t pair. - $type = $ffdc_type if ($type eq undef); - - # Mangle the uppercase name if needed - $ffdc_uc = $mangle_names{$ffdc_uc} if ($mangle_names{$ffdc_uc} ne undef); - - my $key = $ffdc_uc.$type; - my $key_target = $ffdc_uc.$target_ffdc_type; - my $key_ffdc = $ffdc_uc.$ffdc_type; - - # Check to see if this element already has been recorded with this - # type or a target type. Note the effect we're shooting for here is - # to define the member if it's not been defined before *or* it's - # changing from an ffdc_t to a target due to other information in the xml - return if ($methods->{$key}{type} eq $type); - return if ($methods->{$key_target}{type} eq $target_ffdc_type); - - # Just leave if this is a variable_buffer as we're not supporting that. - return if (($type eq $variable_buffer_ffdc_type) && ($arg_use_variable_buffers eq undef)); - - # Set the proper type, and clear out any previous members/methods if - # we're going from an ffdc_t to a target. - $methods->{$key}{type} = $type; - delete $methods->{$key_ffdc} if ($type eq $target_ffdc_type); - - - my $method = ""; - my $method_body = ""; - - # If we're generating empty classes, not using an argument name will avoid the unused parameter warnings - my $param = ($arg_empty_ffdc eq undef) ? "i_value" : ""; - - if ($type eq $ffdc_type) - { - $method = "\ttemplate< typename T >\n"; - $method .= "\tinline $class_name& set_$ffdc_uc(const T& $param)\n"; - - if($arg_local_ffdc eq undef) - { - $method_body = " {$ffdc_uc.ptr() = &i_value; $ffdc_uc.size() ="; - $method_body .= " fapi2::getErrorInfoFfdcSize(i_value); return *this;}\n\n"; - $methods->{$key}{member} = "$ffdc_type $ffdc_uc;"; - $methods->{$objectNumber}{localvar} = "$ffdc_type $ffdc_uc = getFfdcData(FFDC_BUFFER[$objectNumber]);"; - $methods->{$objectNumber}{assignment_string} = "l_obj.$ffdc_uc = $ffdc_uc;"; - } - else - { - # need to use the objectNumber here so when we decode the info at the hwsv/hb side we have a reference, - # they will be copied into/out of the sbe buffer in the correct order - $method_body .= "\t{\n\t\tfapi2::g_FfdcData.ffdcData[$objectNumber].data= convertType(i_value);\n"; - $method_body .= "\t\tfapi2::g_FfdcData.ffdcData[$objectNumber].size ="; - $method_body .=" fapi2::getErrorInfoFfdcSize(i_value);\n"; - $method_body .= "\t\tfapi2::g_FfdcData.ffdcLength += sizeof(sbeFfdc_t);\n"; - $method_body .= "\t\treturn *this;\n\t};\n\n"; - } - - } - elsif ($type eq $buffer_ffdc_type) - { - # Two methods - one for integral buffers and one for variable_buffers - $method = "\n template< typename T >\n"; - $method .= " inline $class_name& set_$ffdc_uc(const fapi2::buffer<T>& $param)\n"; - $method_body = " {$ffdc_uc.ptr() = &i_value(); $ffdc_uc.size() = i_value.template getLength<uint8_t>(); return *this;}\n\n"; - $methods->{$key}{member} = "$ffdc_type $ffdc_uc;"; - $methods->{$objectNumber}{localvar} = "$buffer_ffdc_type $ffdc_uc = getFfdcData(FFDC_BUFFER[$objectNumber]);"; - $methods->{$objectNumber}{assignment_string} = "l_obj.$ffdc_uc = $ffdc_uc;"; - } - - elsif ($type eq $variable_buffer_ffdc_type) - { - $method = "\n inline $class_name& set_$ffdc_uc(const fapi2::variable_buffer& $param)\n"; - $method_body = " {$ffdc_uc.ptr() = &$param(); $ffdc_uc.size() = $param.template getLength<uint8_t>(); return *this;}\n\n"; - - # No need to add the member here, it was added with fapi2::buffer. And we can't have variable - # buffer support with out integral buffer support (can we?) - } - - elsif ($type eq $target_ffdc_type) - { - $method = "\n template< TargetType T >\n"; - $method .= " inline $class_name& set_$ffdc_uc(const $type& $param)\n"; - $method_body .= " {$ffdc_uc.ptr() = &$param; $ffdc_uc.size() = fapi2::getErrorInfoFfdcSize($param); " . - " return *this;}\n\n"; - - $methods->{$key}{member} = "$ffdc_type $ffdc_uc;"; - $methods->{$objectNumber}{localvar} = "$ffdc_type $ffdc_uc = getFfdcData(FFDC_BUFFER[$objectNumber]);"; - $methods->{$objectNumber}{assignment_string} = "l_obj.$ffdc_uc=$ffdc_uc"; - } - - else - { - $method .= "\tinline $class_name& set_$ffdc_uc($type $param)\n"; - - if($arg_local_ffdc eq undef) - { - $method_body = " { $ffdc_uc = i_value; "; - $method_body .= " return *this;}\n\n"; - $methods->{$key}{member} = "$type $ffdc_uc;"; - $methods->{$objectNumber}{localvar} = "$type $ffdc_uc = getFfdcData(FFDC_BUFFER[$objectNumber]);"; - $methods->{$objectNumber}{assignment_string} = "l_obj.$ffdc_uc = $ffdc_uc;"; - } - else - { - # need to use the objectNumber here so when we decode the info at the hwsv/hb side we have a point of - # reference and they will be copied into/out of the sbe buffer in the correct order - $method_body .= "\t{\n\t\tfapi2::g_FfdcData.ffdcData[$objectNumber].data= convertType(i_value);\n"; - $method_body .= "\t\tfapi2::g_FfdcData.ffdcData[$objectNumber].size ="; - $method_body .=" fapi2::getErrorInfoFfdcSize(i_value);\n"; - $method_body .= "\t\tfapi2::g_FfdcData.ffdcLength += sizeof(sbeFfdc_t);\n"; - $method_body .= "\t\treturn *this;\n\t};\n\n"; - } - } - - $method .= ($arg_empty_ffdc eq undef) ? $method_body : " {return *this;}\n\n"; - $methods->{$key}{method} = $method; -} - -#------------------------------------------------------------------------------ -# Open output files for writing -#------------------------------------------------------------------------------ -my $rcFile = $arg_output_dir; -$rcFile .= "/"; -$rcFile .= "hwp_return_codes.H"; -open(RCFILE, ">", $rcFile); - -my $eiFile = $arg_output_dir; -$eiFile .= "/"; -$eiFile .= "hwp_error_info.H"; -open(EIFILE, ">", $eiFile); - -my $ecFile = $arg_output_dir; -$ecFile .= "/"; -$ecFile .= "hwp_ffdc_classes.H"; -open(ECFILE, ">", $ecFile); - -my $crFile = $arg_output_dir; -$crFile .= "/"; -$crFile .= "collect_reg_ffdc_regs.C"; -open(CRFILE, ">", $crFile); - -my $sbFile = $arg_output_dir; -$sbFile .= "/"; -$sbFile .= "set_sbe_error.H"; -open(SBFILE, ">", $sbFile); - -#------------------------------------------------------------------------------ -# Print start of file information to hwp_error_info.H -#------------------------------------------------------------------------------ -print EIFILE "// hwp_error_info.H\n"; -print EIFILE "// This file is generated by the perl script parseErrorInfo.pl\n\n"; -print EIFILE "#ifndef FAPI2_HWPERRORINFO_H_\n"; -print EIFILE "#define FAPI2_HWPERRORINFO_H_\n\n"; -print EIFILE "#include <target.H>\n"; -print EIFILE "#include <plat_trace.H>\n"; -print EIFILE "#include <hwp_return_codes.H>\n"; -print EIFILE "#include <hwp_executor.H>\n"; -print EIFILE "#include <set_sbe_error.H>\n"; - -print EIFILE "/**\n"; -print EIFILE " * \@brief Error Information macros and HwpFfdcId enumeration\n"; -print EIFILE " *\/\n"; -#------------------------------------------------------------------------------ -# Print start of file information to hwp_ffdc_classes.H -#------------------------------------------------------------------------------ -print ECFILE "// hwp_ffdc_classes.H\n"; -print ECFILE "// This file is generated by the perl script parseErrorInfo.pl\n\n"; -print ECFILE "#ifndef FAPI2_HWP_FFDC_CLASSES_H_\n"; -print ECFILE "#define FAPI2_HWP_FFDC_CLASSES_H_\n\n"; -print ECFILE "#include <return_code.H>\n"; -print ECFILE "#include <fapi2_hwp_executor.H>\n"; -print ECFILE "#include <error_info.H>\n"; -print ECFILE "#include <buffer.H>\n"; -print ECFILE "#include <variable_buffer.H>\n" if ($arg_use_variable_buffers ne undef); -print ECFILE "#include <hwp_error_info.H>\n"; -print ECFILE "#if !defined(FAPI2_NO_FFDC) && !defined(MINIMUM_FFDC)\n"; -print ECFILE "#include <ffdc_includes.H>\n"; -print ECFILE "#include <collect_reg_ffdc.H>\n"; -print ECFILE "#endif\n"; -print ECFILE "/**\n"; -print ECFILE " * \@brief FFDC gathering classes\n"; -print ECFILE " *\/\n"; -print ECFILE "namespace fapi2\n{\n"; -if($arg_local_ffdc) -{ - print ECFILE "extern SbeFfdcData_t g_FfdcData; \n"; -} -#------------------------------------------------------------------------------ -# Print start of file information to collect_reg_ffdc_regs.C -#------------------------------------------------------------------------------ -print CRFILE "// collect_reg_ffdc_regs.C\n"; -print CRFILE "// This file is generated by the perl script parseErrorInfo.pl\n\n"; -print CRFILE "#include <stdint.h>\n"; -print CRFILE "#include <vector>\n"; -print CRFILE "#include <plat_trace.H>\n"; -print CRFILE "#include <hwp_error_info.H>\n"; -print CRFILE "#include <p9_mc_scom_addresses.H>\n"; -print CRFILE "#include <p9_misc_scom_addresses.H>\n"; -print CRFILE "#include <p9_obus_scom_addresses.H>\n"; -print CRFILE "#include <p9_perv_scom_addresses.H>\n"; -print CRFILE "#include <p9_quad_scom_addresses.H>\n"; -print CRFILE "#include <p9_xbus_scom_addresses.H>\n"; -print CRFILE "namespace fapi2\n"; -print CRFILE "{\n"; -print CRFILE "void getAddressData(const fapi2::HwpFfdcId i_ffdcId,\n"; -print CRFILE " std::vector<uint64_t>& o_scomAddresses ,\n"; -print CRFILE " std::vector<uint32_t>& o_cfamAddresses ,\n"; -print CRFILE " uint32_t & o_ffdcSize )\n"; -print CRFILE "{\n"; -print CRFILE " FAPI_INF(\"getAddresses. FFDC ID: 0x%x\", i_ffdcId);\n"; -print CRFILE " o_ffdcSize = 0;\n\n"; -print CRFILE " switch (i_ffdcId)\n"; -print CRFILE " {\n"; -#------------------------------------------------------------------------------ -# Print start of file information to setSbeError.H -#------------------------------------------------------------------------------ -print SBFILE "// setSbeError.H\n"; -print SBFILE "// This file is generated by the perl script parseErrorInfo.pl\n\n"; -print SBFILE "// When SBE code creates an error, it produces an error value\n"; -print SBFILE "// that matches a value in the HwpReturnCode enum in\n"; -print SBFILE "// fapiHwpReturnCodes.H. The SBE uses the __ASSEMBLER__\n"; -print SBFILE "// primitives in hwpReturnCodes.H to do this. The function\n"; -print SBFILE "// that extracts the error value from the SBE needs to call\n"; -print SBFILE "// FAPI_SET_HWP_ERROR to create the error and get all the\n"; -print SBFILE "// actions in the error XML file performed, but that macro can\n"; -print SBFILE "// only be called with the enumerator, not the value. This\n"; -print SBFILE "// FAPI_SET_SBE_ERROR macro can be called instead, it calls\n"; -print SBFILE "// FAPI_SET_HWP_ERROR with the correct error enumerator.\n"; -print SBFILE "// Errors containing <sbeError/> in their XML are supported\n"; -print SBFILE "// in this macro.\n\n"; -print SBFILE "// Note that it is expected that this macro will be called\n"; -print SBFILE "// in one place (the function that extracts the error from\n"; -print SBFILE "// the SBE), if this changes and it is called in multiple\n"; -print SBFILE "// places then the macro could be turned into a function to\n"; -print SBFILE "// avoid the code size increase of expanding the macro in\n"; -print SBFILE "// multiple places. The function approach is slightly more\n"; -print SBFILE "// complicated, there is an extra C file and the function\n"; -print SBFILE "// must take a parameter for the generic chip ID in the error\n"; -print SBFILE "// XML.\n\n"; -print SBFILE "#ifndef FAPI2_SETSBEERROR_H_\n"; -print SBFILE "#define FAPI2_SETSBEERROR_H_\n\n"; -print SBFILE "#define FAPI_SET_SBE_ERROR(RC,ERRVAL,FFDC_BUFFER)\\\n"; -print SBFILE "{\\\n"; -print SBFILE "switch (ERRVAL)\\\n"; -print SBFILE "{\\\n"; - - -#------------------------------------------------------------------------------ -# For each XML file -#------------------------------------------------------------------------------ -foreach my $argnum (0 .. $#ARGV) -{ - my $infile = $ARGV[$argnum]; - my $count = 0; - - #-------------------------------------------------------------------------- - # Read XML file. The ForceArray option ensures that there is an array of - # elements even if there is only one element - #-------------------------------------------------------------------------- - my $errors = $xml->XMLin($infile, ForceArray => - ['hwpError', 'collectFfdc', 'ffdc','mcastId', 'callout', 'deconfigure', 'gard', - 'registerFfdc', 'collectRegisterFfdc', 'cfamRegister', 'scomRegister', - 'id','collectTrace', 'buffer']); - - # Uncomment to get debug output of all errors -# print "\nFile: ", $infile, "\n", Dumper($errors), "\n"; - - #-------------------------------------------------------------------------- - # For each Error - #-------------------------------------------------------------------------- - foreach my $err (@{$errors->{hwpError}}) - { - my $objectStr = undef; - # Hash of methods for the ffdc-gathering class - my %methods; - - # Array of EI Objects - @eiObjects = (); - - #---------------------------------------------------------------------- - # Check that expected fields are present - #---------------------------------------------------------------------- - if (! exists $err->{rc}) - { - print ("parseErrorInfo.pl ERROR. rc missing\n"); - exit(1); - } - - if (! exists $err->{description}) - { - print ("parseErrorInfo.pl ERROR in $err->{rc}. description missing\n"); - exit(1); - } - - #---------------------------------------------------------------------- - # Check that this rc hasn't been deprecated - #---------------------------------------------------------------------- - if ($deprecated{$err->{rc}} ne undef) - { - print "WARNING: $err->{rc} has been deprecated because $deprecated{$err->{rc}}\n"; - next; - } - - #---------------------------------------------------------------------- - # Set the error enum value in a global hash - #--------------------------------------------------------------------- - setErrorEnumValue($err->{rc}); - - - #---------------------------------------------------------------------- - # Print the CALL_FUNCS_TO_COLLECT_FFDC macro to hwp_error_info.H - #---------------------------------------------------------------------- - print EIFILE "#define $err->{rc}_CALL_FUNCS_TO_COLLECT_FFDC(RC)"; - - my $collectFfdcStr = undef; - $count = 0; - foreach my $collectFfdc (@{$err->{collectFfdc}}) - { - if ($count == 0) - { - #this rc wont be used, except to indicate the FFDC collection failed - $collectFfdcStr = "\tfapi2::ReturnCode l_rc; \\\n"; - # each collect ffdc function needs to populate this so we can add it to i_rc; - $collectFfdcStr .= "\tstd::vector<std::shared_ptr<ErrorInfoFfdc>>ffdc; \\\n"; - } - $count++; - - # collectFfdc is a string we're going to stuff into FAPI_EXEC_HWP - # but we need to create the arguments in the ffdc class. The first - # element in the collectFfdc string is the function to call. - my @elements = split /,/, $collectFfdc; - my @signature = @{$signatures{@elements[0]}}; - - # build up the function call here - @elements[0] =~ s/^\s+|\s+$//g; - $collectFfdc = "@elements[0]" .",ffdc"; - for (my $i = 1; $i <= $#elements; $i++) - { - $collectFfdc .= ","; - - # the parameters will be in the l_objects, unused, but need to be - # counted for the SBE implementation - my $parameter = "static_cast<void*>(&"."@elements[$i])"; - - # Add the parameter to the object list if it doesn't already exist - # - my $objNum = addEntryToArray(\@eiObjects, $parameter); - - # add a set method for each parameter too.. - @elements[$i] =~ s/^\s+|\s+$//g; - addFfdcMethod(\%methods, @elements[$i], $err->{rc}, @signature[$i-1],$objNum); - - $collectFfdc .= "@elements[$i]" - - } - - $collectFfdcStr .= "\tFAPI_EXEC_HWP(l_rc, $collectFfdc); \\\n"; - - print EIFILE "\\\n{ \\\n$collectFfdcStr"; - print EIFILE "\tRC.addErrorInfo(ffdc); \\\n}"; - } #end collectFfdc tag - - print EIFILE "\n"; - - #---------------------------------------------------------------------- - # Print the CALL_FUNCS_TO_COLLECT_REG_FFDC macro to hwp_error_info.H - #---------------------------------------------------------------------- - print EIFILE "#define $err->{rc}_CALL_FUNCS_TO_COLLECT_REG_FFDC(RC)"; - - my $crffdcStr = undef; - - my $crffdcCount =0; - - if($arg_local_ffdc eq undef) - { - foreach my $collectRegisterFfdc (@{$err->{collectRegisterFfdc}}) - { - #------------------------------------------------------------------ - # Check that expected fields are present - #------------------------------------------------------------------ - if (! exists $collectRegisterFfdc->{id}[0]) - { - print ("parseErrorInfo.pl ERROR in $err->{rc}. id(s) missing from collectRegisterFfdc $infile\n"); - exit(1); - } - - - foreach my $id (@{$collectRegisterFfdc->{id}}) - { - - if( $crffdcCount eq 0 ) - { - print EIFILE " \\\n{ \\\n"; - $crffdcStr = "\tstd::vector<std::shared_ptr<ErrorInfoFfdc>> ffdc; \\\n"; - } - else - { - $crffdcStr = ""; - } - - $crffdcCount++; - #--------------------------------------------------------------------------------- - # Check FFDC register collection type: target, child, or based on present children - #--------------------------------------------------------------------------------- - if (exists $collectRegisterFfdc->{target}) - { - if(!(exists $collectRegisterFfdc->{targetType} )) - { - print ("parseErrorInfo.pl ERROR: target type missing from $collectRegisterFfdc->{target} in file $infile\n"); - exit(1); - } - $crffdcStr .= "\tfapi2::collectRegFfdc<$collectRegisterFfdc->{targetType}>($collectRegisterFfdc->{target},"; - $crffdcStr .= "fapi2::$id,ffdc); \\\n"; - - addFfdcMethod(\%methods, $collectRegisterFfdc->{target}, - $err->{rc}, $target_ffdc_type); - } - elsif (exists $collectRegisterFfdc->{childTargets}) - { - if(!(exists $collectRegisterFfdc->{childTargets}{parent} )) - { - print ("parseErrorInfo.pl ERROR: parent missing from $collectRegisterFfdc->{id} in $infile\n"); - exit(1); - } - - if(!(exists $collectRegisterFfdc->{childTargets}{parentType} )) - { - print ("parseErrorInfo.pl ERROR: parent type missing from $collectRegisterFfdc->{id} in $infile\n"); - exit(1); - } - - $crffdcStr .= "\tfapi2::collectRegFfdc<fapi2::$collectRegisterFfdc->{childTargets}->{childType},"; - $crffdcStr .= "$collectRegisterFfdc->{childTargets}->{parentType}>"; - $crffdcStr .= "($collectRegisterFfdc->{childTargets}->{parent}, "; - $crffdcStr .= "fapi2::TARGET_STATE_FUNCTIONAL,fapi2::$id, ffdc); \\\n"; - - addFfdcMethod(\%methods, $collectRegisterFfdc->{childTargets}->{parent}, - $err->{rc}, $target_ffdc_type); - } - elsif (exists $collectRegisterFfdc->{basedOnPresentChildren}) - { - if ( exists $collectRegisterFfdc->{basedOnPresentChildren}->{target}) - { - if (! exists $collectRegisterFfdc->{basedOnPresentChildren}->{childType}) - { - die ("parseErrorInfo.pl ERROR: childType missing from collectRegisterFfdc $infile\n"); - exit(1); - } - if(!(exists $collectRegisterFfdc->{basedOnPresentChildren}{targetType} )) - { - print ("parseErrorInfo.pl ERROR: type missing from "); - print ("$collectRegisterFfdc->{basedOnPresentChildren}{parent} in file $infile\n"); - exit(1); - } - - if (! exists $collectRegisterFfdc->{basedOnPresentChildren}->{childPosOffsetMultiplier}) - { - print ("parseErrorInfo.pl ERROR: childPosOffsetMultiplier missing from collectRegisterFfdc $infile\n"); - exit(1); - } - $crffdcStr .= "\tfapi2::collectRegFfdc<fapi2::$collectRegisterFfdc->{basedOnPresentChildren}->{childType},"; - $crffdcStr .= "$collectRegisterFfdc->{basedOnPresentChildren}->{targetType}>"; - $crffdcStr .= "($collectRegisterFfdc->{basedOnPresentChildren}->{target},"; - $crffdcStr .= "fapi2::TARGET_STATE_PRESENT,"; - $crffdcStr .= "fapi2::$id, ffdc,"; - $crffdcStr .= "$collectRegisterFfdc->{basedOnPresentChildren}->{childPosOffsetMultiplier});\\\n"; - $crffdcCount++; - - addFfdcMethod(\%methods, $collectRegisterFfdc->{basedOnPresentChildren}->{target}, - $err->{rc}, $target_ffdc_type); - } - else - { - print ("parseErrorInfo.pl ERROR: Invalid collectRegisterFfdc configuration in $infile\n"); - exit(1); - - } - } - else - { - print ("parseErrorInfo.pl ERROR: Invalid collectRegisterFfdc configuration in $infile\n"); - exit(1); - } - - #print the collectRegFfdc string to the info file - print EIFILE "$crffdcStr"; - - } #end foreach register id - - } # end foreach collectRegisterFfdc - - if($crffdcCount > 0) - { - print EIFILE "\tRC.addErrorInfo(ffdc); \\\n}\n"; - } - - } - print EIFILE "\n"; - - #---------------------------------------------------------------------- - # Print the ADD_ERROR_INFO macro to hwp_error_info.H - #---------------------------------------------------------------------- - print EIFILE "#define $err->{rc}_ADD_ERROR_INFO(RC)"; - - my $eiEntryStr = undef; - my $eiObjectMap = undef; #object names to buffer address mapping - my $eiObjectStr = "\tconst void * l_objects[] = {"; - my $executeStr = undef; - my $eiEntryCount = 0; - my %cdgTargetHash; # Records the callout/deconfigure/gards for Targets - my %cdgChildHash; # Records the callout/deconfigure/gards for Children - - # collect firmware trace - foreach my $collectTrace (@{$err->{collectTrace}}) - { - # Add an EI entry to eiEntryStr - $eiEntryStr .= "\tl_entries[$eiEntryCount].iv_type = fapi2::EI_TYPE_COLLECT_TRACE; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].collect_trace.iv_eieTraceId = fapi2::CollectTraces::$collectTrace; \\\n"; - $eiEntryCount++; - } #end foreach $collectTrace - - # Local FFDC - foreach my $ffdc (@{$err->{ffdc}}) - { - - # Set the FFDC ID value in a global hash. The name is <rc>_<ffdc> - my $ffdcName = $err->{rc} . "_"; - $ffdcName = $ffdcName . $ffdc; - setFfdcIdValue($ffdcName); - - # Add the FFDC data to the EI Object array if it doesn't already exist - my $objNum = addEntryToArray(\@eiObjects, $ffdc); - - # Add a method to the ffdc-gathering class - addFfdcMethod(\%methods, $ffdc, $err->{rc},$ffdc_type,$objNum); - - $ffdc = $mangle_names{$ffdc} if ($mangle_names{$ffdc} ne undef); - - # Add an EI entry to eiEntryStr - $eiEntryStr .= "\tl_entries[$eiEntryCount].iv_type = fapi2::EI_TYPE_FFDC; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].ffdc.iv_ffdcObjIndex = $objNum; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].ffdc.iv_ffdcId = fapi2::$ffdcName; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].ffdc.iv_ffdcSize = $ffdc.size(); \\\n"; - $eiEntryCount++; - } #end foreach $ffdc - - # Multicast ID - foreach my $mcast (@{$err->{mcastId}}) - { - # Set the FFDC ID value in a global hash. The name is <rc>_<ffdc> - my $ffdcName = $err->{rc} . "_"; - $ffdcName = $ffdcName . $mcast; - setFfdcIdValue($ffdcName); - - # Add the FFDC data to the EI Object array if it doesn't already exist - my $objNum = addEntryToArray(\@eiObjects, $mcast); - - # Add a method to the ffdc-gathering class - addFfdcMethod(\%methods, $mcast, $err->{rc},$mcast_type,$objNum); - - $mcast = $mangle_names{$mcast} if ($mangle_names{$mcast} ne undef); - - # Add an EI entry to eiEntryStr - $eiEntryStr .= "\tl_entries[$eiEntryCount].iv_type = fapi2::EI_TYPE_FFDC; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].ffdc.iv_ffdcObjIndex = $objNum; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].ffdc.iv_ffdcId = fapi2::$ffdcName; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].ffdc.iv_ffdcSize = 4; \\\n"; - $eiEntryCount++; - } #foreach mcastId - - if($arg_local_ffdc eq undef) - { - # Buffers, looks a lot like local ffdc - foreach my $buffer (@{$err->{buffer}}) - { - # Set the FFDC ID value in a global hash. The name is <rc>_<ffdc> - my $bufferName = $err->{rc} . "_"; - $bufferName = $bufferName . $buffer; - setFfdcIdValue($bufferName); - - # Add the FFDC data to the EI Object array if it doesn't already exist - my $objNum = addEntryToArray(\@eiObjects, $buffer); - - # Add a method to the ffdc-gathering class - one for each buffer type - addFfdcMethod(\%methods, $buffer, $err->{rc}, $buffer_ffdc_type); - addFfdcMethod(\%methods, $buffer, $err->{rc}, $variable_buffer_ffdc_type); - - # Add an EI entry to eiEntryStr - $eiEntryStr .= "\tl_entries[$eiEntryCount].iv_type = fapi2::EI_TYPE_FFDC; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].ffdc.iv_ffdcObjIndex = $objNum; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].ffdc.iv_ffdcId = fapi2::$bufferName; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].ffdc.iv_ffdcSize = fapi2::getErrorInfoFfdcSize($buffer); \\\n"; - $eiEntryCount++; - } #foreach $buffer - - # Procedure/Target/Bus/Child callouts - foreach my $callout (@{$err->{callout}}) - { - if (! exists $callout->{priority}) - { - print ("parseErrorInfo.pl ERROR in $err->{rc}. Callout priority missing\n"); - exit(1); - } - - my $elementsFound = 0; - if (exists $callout->{hw}) - { - # HW Callout - if (! exists $callout->{hw}->{hwid}) - { - print ("parseErrorInfo.pl ERROR in $err->{rc}. HW Callout hwid missing\n"); - exit(1); - } - - # Check that those HW callouts that need reference targets have them - if (($callout->{hw}->{hwid} eq "TOD_CLOCK") || - ($callout->{hw}->{hwid} eq "MEM_REF_CLOCK") || - ($callout->{hw}->{hwid} eq "PROC_REF_CLOCK") || - ($callout->{hw}->{hwid} eq "PCI_REF_CLOCK")) - { - if (! exists $callout->{hw}->{refTarget}) - { - print ("parseErrorInfo.pl ERROR in $err->{rc}. Callout missing refTarget\n"); - exit(1); - } - } - - # Add an EI entry to eiEntryStr - $eiEntryStr .= "\tl_entries[$eiEntryCount].iv_type = fapi2::EI_TYPE_HW_CALLOUT; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].hw_callout.iv_hw = fapi2::HwCallouts::$callout->{hw}->{hwid}; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].hw_callout.iv_calloutPriority = fapi2::CalloutPriorities::$callout->{priority}; \\\n"; - if (exists $callout->{hw}->{refTarget}) - { - # Add the Targets to the objectlist if they don't already exist - my $objNum = addEntryToArray(\@eiObjects, $callout->{hw}->{refTarget}); - $eiEntryStr .= "\tl_entries[$eiEntryCount].hw_callout.iv_refObjIndex = $objNum; \\\n"; - - # Add a method to the ffdc-gathering class - addFfdcMethod(\%methods, $callout->{hw}->{refTarget}, $err->{rc}); - } - else - { - $eiEntryStr .= "\tl_entries[$eiEntryCount].hw_callout.iv_refObjIndex = 0xff; \\\n"; - } - $eiEntryCount++; - $elementsFound++; - } - if (exists $callout->{procedure}) - { - # Procedure Callout - # Add an EI entry to eiEntryStr - $eiEntryStr .= "\tl_entries[$eiEntryCount].iv_type = fapi2::EI_TYPE_PROCEDURE_CALLOUT; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].proc_callout.iv_procedure = fapi2::ProcedureCallouts::$callout->{procedure}; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].proc_callout.iv_calloutPriority = fapi2::CalloutPriorities::$callout->{priority}; \\\n"; - $eiEntryCount++; - $elementsFound++; - } - if (exists $callout->{bus}) - { - # A Bus Callout consists of two targets separated by - # commas/spaces - my @targets = split(/\s*,\s*|\s+/, $callout->{bus}); - - if (scalar @targets != 2) - { - print ("parseErrorInfo.pl ERROR in $err->{rc}. did not find two targets in bus callout\n"); - exit(1); - } - - # Add the Targets to the objectlist if they don't already exist - my $objNum1 = addEntryToArray(\@eiObjects, $targets[0]); - - my $objNum2 = addEntryToArray(\@eiObjects, $targets[1]); - - # Add a method to the ffdc-gathering class - addFfdcMethod(\%methods, $targets[0], $err->{rc}, $target_ffdc_type); - addFfdcMethod(\%methods, $targets[1], $err->{rc}, $target_ffdc_type); - - # Add an EI entry to eiEntryStr - $eiEntryStr .= "\tl_entries[$eiEntryCount].iv_type = fapi2::EI_TYPE_BUS_CALLOUT; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].bus_callout.iv_endpoint1ObjIndex = $objNum1; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].bus_callout.iv_endpoint2ObjIndex = $objNum2; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].bus_callout.iv_calloutPriority = fapi2::CalloutPriorities::$callout->{priority}; \\\n"; - $eiEntryCount++; - $elementsFound++; - } - if (exists $callout->{target}) - { - # Add the Target to cdgTargetHash to be processed with any - # deconfigure and GARD requests - $cdgTargetHash{$callout->{target}}{callout} = 1; - $cdgTargetHash{$callout->{target}}{priority} = - $callout->{priority}; - - $elementsFound++; - } - if (exists $callout->{childTargets}) - { - # Check that the parent and childType subelements exist - if (! exists $callout->{childTargets}->{parent}) - { - print ("parseErrorInfo.pl ERROR in $err->{rc}. Child Callout parent missing\n"); - exit(1); - } - - if (! exists $callout->{childTargets}->{childType}) - { - print ("parseErrorInfo.pl ERROR in $err->{rc}. Child Callout childType missing\n"); - exit(1); - } - - # Add the child info to cdgChildHash to be processed with - # any deconfigure and GARD requests - my $parent = $callout->{childTargets}->{parent}; - my $childType = $callout->{childTargets}->{childType}; - $cdgChildHash{$parent}{$childType}{callout} = 1; - $cdgChildHash{$parent}{$childType}{priority} = - $callout->{priority}; - - $elementsFound++; - - if (exists $callout->{childTargets}->{childPort}) - { - my $childPort = $callout->{childTargets}->{childPort}; - - $cdgChildHash{$parent}{$childType}{childPort} = $childPort; - } - - if (exists $callout->{childTargets}->{childNumber}) - { - my $childNum = $callout->{childTargets}->{childNumber}; - $cdgChildHash{$parent}{$childType}{childNumber} = $childNum; - } - - } - if ($elementsFound == 0) - { - print ("parseErrorInfo.pl ERROR in $err->{rc}. Callout incomplete\n"); - exit(1); - } - elsif ($elementsFound > 1) - { - print ("parseErrorInfo.pl ERROR in $err->{rc}. Callout has multiple elements\n"); - exit(1); - } - } # callout - - # Target/Child deconfigures - foreach my $deconfigure (@{$err->{deconfigure}}) - { - my $elementsFound = 0; - if (exists $deconfigure->{target}) - { - # Add the Target to cdgTargetHash to be processed with any - # callout and GARD requests - $cdgTargetHash{$deconfigure->{target}}{deconf} = 1; - $elementsFound++; - } - if (exists $deconfigure->{childTargets}) - { - # Check that the parent and childType subelements exist - if (! exists $deconfigure->{childTargets}->{parent}) - { - print ("parseErrorInfo.pl ERROR in $err->{rc}. Child Deconfigure parent missing\n"); - exit(1); - } - if (! exists $deconfigure->{childTargets}->{childType}) - { - print ("parseErrorInfo.pl ERROR in $err->{rc}. Child Deconfigure childType missing\n"); - exit(1); - } - - # Add the child info to cdgChildHash to be processed with - # any callout and GARD requests - my $parent = $deconfigure->{childTargets}->{parent}; - my $childType = $deconfigure->{childTargets}->{childType}; - $cdgChildHash{$parent}{$childType}{deconf} = 1; - - $elementsFound++; - - if ( exists $deconfigure->{childTargets}->{childPort}) - { - my $childPort = $deconfigure->{childTargets}->{childPort}; - - $cdgChildHash{$parent}{$childType}{childPort} = $childPort; - } - - if ( exists $deconfigure->{childTargets}->{childNumber}) - { - my $childNum = $deconfigure->{childTargets}->{childNumber}; - $cdgChildHash{$parent}{$childType}{childNumber} = $childNum; - - } - } - if ($elementsFound == 0) - { - print ("parseErrorInfo.pl ERROR in $err->{rc}. Deconfigure incomplete\n"); - exit(1); - } - elsif ($elementsFound > 1) - { - print ("parseErrorInfo.pl ERROR in $err->{rc}. Deconfigure has multiple elements\n"); - exit(1); - } - } # deconfigure - - # Target/Child Gards - foreach my $gard (@{$err->{gard}}) - { - my $elementsFound = 0; - if (exists $gard->{target}) - { - # Add the Target to cdgTargetHash to be processed with any - # callout and deconfigure requests - $cdgTargetHash{$gard->{target}}{gard} = 1; - $elementsFound++; - } - if (exists $gard->{childTargets}) - { - # Check that the parent and childType subelements exist - if (! exists $gard->{childTargets}->{parent}) - { - print ("parseErrorInfo.pl ERROR in $err->{rc}. Child GARD parent missing\n"); - exit(1); - } - if (! exists $gard->{childTargets}->{childType}) - { - print ("parseErrorInfo.pl ERROR in $err->{rc}. Child GARD childType missing\n"); - exit(1); - } - - # Add the child info to cdgChildHash to be processed with - # any callout and deconfigure requests - my $parent = $gard->{childTargets}->{parent}; - my $childType = $gard->{childTargets}->{childType}; - $cdgChildHash{$parent}{$childType}{gard} = 1; - - $elementsFound++; - - if ( exists $gard->{childTargets}->{childPort}) - { - my $childPort = $gard->{childTargets}->{childPort}; - - $cdgChildHash{$parent}{$childType}{childPort} = $childPort; - - } - - if ( exists $gard->{childTargets}->{childNumber}) - { - my $childNum = $gard->{childTargets}->{childNumber}; - $cdgChildHash{$parent}{$childType}{childNumber} = $childNum; - } - } - if ($elementsFound == 0) - { - print ("parseErrorInfo.pl ERROR in $err->{rc}. GARD incomplete\n"); - exit(1); - } - elsif ($elementsFound > 1) - { - print ("parseErrorInfo.pl ERROR in $err->{rc}. GARD has multiple elements\n"); - exit(1); - } - } # gard - - # Process the callout, deconfigures and GARDs for each Target - foreach my $cdg (keys %cdgTargetHash) - { - my $callout = 0; - my $priority = 'LOW'; - my $deconf = 0; - my $gard = 0; - - if (exists $cdgTargetHash{$cdg}->{callout}) - { - $callout = 1; - } - if (exists $cdgTargetHash{$cdg}->{priority}) - { - $priority = $cdgTargetHash{$cdg}->{priority}; - } - if (exists $cdgTargetHash{$cdg}->{deconf}) - { - $deconf = 1; - } - if (exists $cdgTargetHash{$cdg}->{gard}) - { - $gard = 1; - } - - # Add the Target to the objectlist if it doesn't already exist - my $objNum = addEntryToArray(\@eiObjects, $cdg); - - # Add a method to the ffdc-gathering class - addFfdcMethod(\%methods, $cdg, $err->{rc}, $target_ffdc_type); - - # Add an EI entry to eiEntryStr - $eiEntryStr .= "\tl_entries[$eiEntryCount].iv_type = fapi2::EI_TYPE_CDG; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].target_cdg.iv_targetObjIndex = $objNum; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].target_cdg.iv_callout = $callout; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].target_cdg.iv_deconfigure = $deconf; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].target_cdg.iv_gard = $gard; \\\n"; - $eiEntryStr .= "\tl_entries[$eiEntryCount].target_cdg.iv_calloutPriority = fapi2::CalloutPriorities::$priority; \\\n"; - $eiEntryCount++; - } - - # Process the callout, deconfigures and GARDs for Child Targets - foreach my $parent (keys %cdgChildHash) - { - foreach my $childType (keys %{$cdgChildHash{$parent}}) - { - my $callout = 0; - my $priority = 'LOW'; - my $deconf = 0; - my $gard = 0; - my $childPort = 0xFF; - my $childNumber = 0xFF; - - if (exists $cdgChildHash{$parent}{$childType}->{callout}) - { - $callout = 1; - } - if (exists $cdgChildHash{$parent}->{$childType}->{priority}) - { - $priority = - $cdgChildHash{$parent}->{$childType}->{priority}; - } - if (exists $cdgChildHash{$parent}->{$childType}->{deconf}) - { - $deconf = 1; - } - if (exists $cdgChildHash{$parent}->{$childType}->{childPort}) - { - $childPort = - $cdgChildHash{$parent}->{$childType}->{childPort} ; - addFfdcMethod(\%methods, $childPort, $err->{rc}); - } - if (exists $cdgChildHash{$parent}->{$childType}->{childNumber}) - { - $childNumber = - $cdgChildHash{$parent}->{$childType}->{childNumber} ; - addFfdcMethod(\%methods, $childNumber, $err->{rc}); - } - if (exists $cdgChildHash{$parent}->{$childType}->{gard}) - { - $gard = 1; - } - - - # Add the Target to the objectlist if it doesn't already exist - my $objNum = addEntryToArray(\@eiObjects, $parent); - addFfdcMethod(\%methods, $parent, $err->{rc}, $target_ffdc_type); - - # Add an EI entry to eiEntryStr - $eiEntryStr .= - "\tl_entries[$eiEntryCount].iv_type = fapi2::EI_TYPE_CHILDREN_CDG; \\\n"; - $eiEntryStr .= - "\tl_entries[$eiEntryCount].children_cdg.iv_parentObjIndex = $objNum; \\\n"; - $eiEntryStr .= - "\tl_entries[$eiEntryCount].children_cdg.iv_callout = $callout; \\\n"; - $eiEntryStr .= - "\tl_entries[$eiEntryCount].children_cdg.iv_deconfigure = $deconf; \\\n"; - $eiEntryStr .= - "\tl_entries[$eiEntryCount].children_cdg.iv_childType = fapi2::$childType; \\\n"; - $eiEntryStr .= - "\tl_entries[$eiEntryCount].children_cdg.iv_childPort = $childPort; \\\n"; - $eiEntryStr .= - "\tl_entries[$eiEntryCount].children_cdg.iv_childNumber = $childNumber; \\\n"; - $eiEntryStr .= - "\tl_entries[$eiEntryCount].children_cdg.iv_gard = $gard; \\\n"; - $eiEntryStr .= - "\tl_entries[$eiEntryCount].children_cdg.iv_calloutPriority = fapi2::CalloutPriorities::$priority; \\\n"; - $eiEntryCount++; - } - } - } - # Add all objects to $eiObjectStr - my $objCount = 0; - - # add ordinary types to eiObjectStr here - - foreach my $eiObject (@eiObjects) - { - if ($objCount > 0) - { - $eiObjectStr .= ", "; - } - - if ($mangle_names{$eiObject} eq undef) - { - $eiObjectStr .= "$eiObject"; - - if ((exists $err->{sbeError}) ) - { - if((exists $methods{$objCount}{object})) - { - $objectStr .= "\t\t$methods{$objCount}{object} \\\n"; - - } - - if((exists $methods{$objCount}{localvar})) - { - $objectStr .= "\t\t$methods{$objCount}{localvar} \\\n"; - $objectStr .= "\t\t$methods{$objCount}{assignment_string} \\\n"; - } - } - } - else - { - $eiObjectStr .= $mangle_names{$eiObject}; - } - - $objCount++; - } - - - $eiObjectStr .= "};"; - - - # Print info to file - if ($eiEntryCount > 0) - { - print EIFILE " \\\n{ \\\n $eiObjectStr \\\n"; - print EIFILE "\tfapi2::ErrorInfoEntry l_entries[$eiEntryCount]; \\\n"; - print EIFILE "$eiEntryStr"; - print EIFILE "\tRC.addErrorInfo(l_objects, l_entries, $eiEntryCount); \\\n}"; - } - - print EIFILE "\n"; - - #---------------------------------------------------------------------- - # Print the return code class to hwp_error_info.H - #---------------------------------------------------------------------- - # Remove the repeated whitespace and newlines other characters from the description - $err->{description} =~ s/^\s+|\s+$|"//g; - $err->{description} =~ tr{\n}{ }; - $err->{description} =~ s/\h+/ /g; - - #---------------------------------------------------------------------- - # Print the return code class to hwp_error_info.H - #---------------------------------------------------------------------- - my $class_name = $err->{rc}; - # Remove everything upto and including the first _. This makes the ffdc class - # names different from the error code value enum names. - $class_name = (split (/_/, $class_name, 2))[1]; - - # Class declaration - print ECFILE "\nclass $class_name\n{\n public:\n"; - - # Constructor. This traces the description. If this is too much, we can - # remove it. - if ($arg_empty_ffdc eq undef) - { - if($arg_local_ffdc eq undef) - { - print ECFILE " $class_name(fapi2::errlSeverity_t i_sev = fapi2::FAPI2_ERRL_SEV_UNRECOVERABLE, fapi2::ReturnCode& i_rc = fapi2::current_err):\n"; - print ECFILE " iv_rc(i_rc),\n"; - print ECFILE " iv_sev(i_sev)\n"; - print ECFILE " { FAPI_ERR(\"$err->{description}\"); }\n\n"; - } - else - { - print ECFILE " $class_name()\n"; - print ECFILE " {\n\t\tfapi2::current_err = RC_$class_name;\n\t\tFAPI_ERR(\"$err->{description}\");\n"; - print ECFILE " \tfapi2::g_FfdcData.fapiRc = RC_$class_name;\n\t}\n\n"; - } - } - else - { - # Void expression keeps the compiler from complaining about the unused arguments. - # We want to set the i_rc to the RC if we're empty. This otherwise gets done in _setHwpError() - print ECFILE " $class_name(fapi2::errlSeverity_t i_sev = fapi2::FAPI2_ERRL_SEV_UNRECOVERABLE, fapi2::ReturnCode& i_rc = fapi2::current_err)\n"; - print ECFILE " {\n"; - print ECFILE " static_cast<void>(i_sev);\n"; - print ECFILE " i_rc = $err->{rc};\n"; - print ECFILE " }\n\n"; - } - - my $method_count = 0; - # Methods - foreach my $key (keys %methods) - { - print ECFILE $methods{$key}{method}; - $method_count++; - } - if($arg_local_ffdc eq undef) - { - # add a method to adjust the severity if desired - print ECFILE "\tinline void setSev(const fapi2::errlSeverity_t i_sev)\n"; - if ($arg_empty_ffdc eq undef) - { - print ECFILE "\t\t\t{ iv_sev = i_sev;};\n\n"; - } - else - { - print ECFILE "\t\t\t{ static_cast<void>(i_sev);};\n\n"; - } - - # add a method to read the severity if desired - print ECFILE "\tinline fapi2::errlSeverity_t getSev() const\n"; - if ($arg_empty_ffdc eq undef) - { - print ECFILE "\t\t\t{ return iv_sev; };\n\n"; - } - else - { - print ECFILE "\t\t\t{ return fapi2::FAPI2_ERRL_SEV_UNDEFINED; };\n\n"; - } - - } - - if( $arg_local_ffdc eq undef ) - { - - - - # Stick the execute method at the end of the other methods. We allow - # passing in of the severity so that macros which call execute() can over-ride - # the default severity. - print ECFILE "\tvoid execute(fapi2::errlSeverity_t " . - "i_sev = fapi2::FAPI2_ERRL_SEV_UNDEFINED," . - "bool commit = false )\n"; - if ($arg_empty_ffdc eq undef ) - { - print ECFILE "\t\t{\n"; - print ECFILE "\t\t\tFAPI_SET_HWP_ERROR(iv_rc,$err->{rc});\n\n"; - print ECFILE "\t\t\tif( commit )\n"; - print ECFILE "\t\t\t{\n"; - print ECFILE "\t\t\t\tfapi2::logError(iv_rc, " . - "(i_sev == fapi2::FAPI2_ERRL_SEV_UNDEFINED)" . - " ? iv_sev : i_sev);\n"; - print ECFILE "\t\t\t}\n"; - print ECFILE "\t\t}\n"; - - } - else - { - print ECFILE " {\n"; - print ECFILE " static_cast<void>(i_sev);\n"; - print ECFILE " static_cast<void>(commit);\n"; - print ECFILE " }\n\n"; - } - - # Instance variables - if ($arg_empty_ffdc eq undef) - { - print ECFILE "\tpublic:\n"; - foreach my $key (keys %methods) - { - if( !($methods{$key}{member} eq undef) ) - { - print ECFILE "\t\t$methods{$key}{member}\n"; - } - - } - - print ECFILE "\t\tfapi2::ReturnCode& iv_rc;\n"; - print ECFILE "\t\tfapi2::errlSeverity_t iv_sev;\n"; - } - - } - else - { - print ECFILE " void execute()\n"; - print ECFILE " {\n"; - print ECFILE "$executeStr\n"; - print ECFILE " }\n"; - } - - print ECFILE "};\n\n"; - - #---------------------------------------------------------------------- - # If this is an SBE error, add it to set_sbe_error.H - #---------------------------------------------------------------------- - if (exists $err->{sbeError}) - { - print SBFILE "\tcase fapi2::$err->{rc}: \\\n"; - print SBFILE "\t{\\\n\t\t$class_name l_obj("; - print SBFILE "fapi2::FAPI2_ERRL_SEV_UNRECOVERABLE,RC);\\\n"; - - if(!($objectStr eq undef )) - { - print SBFILE "$objectStr"; - } - print SBFILE "\t\tl_obj.execute(); \\\n"; - print SBFILE "\t\tbreak; \\\n\t} \\\n"; - } - - } #for each hwpError tag - # - #-------------------------------------------------------------------------- - # For each registerFfdc. - #-------------------------------------------------------------------------- - foreach my $registerFfdc (@{$errors->{registerFfdc}}) - { - #---------------------------------------------------------------------- - # Check that expected fields are present - #---------------------------------------------------------------------- - if (! exists $registerFfdc->{id}[0]) - { - print ("parseErrorInfo.pl ERROR. id missing from registerFfdc\n"); - exit(1); - } - - if (scalar @{$registerFfdc->{id}} > 1) - { - print ("parseErrorInfo.pl ERROR. multiple ids in registerFfdc\n"); - exit(1); - } - - #---------------------------------------------------------------------- - # Set the FFDC ID value in a global hash - #---------------------------------------------------------------------- - setFfdcIdValue($registerFfdc->{id}[0]); - - #---------------------------------------------------------------------- - # Generate code to capture the registers in collect_reg_ffdc_regs.C - #---------------------------------------------------------------------- - print CRFILE " case $registerFfdc->{id}[0]:\n"; - - # Look for CFAM Register addresses - foreach my $cfamRegister (@{$registerFfdc->{cfamRegister}}) - { - print CRFILE " o_cfamAddresses.push_back($cfamRegister);\n"; - } - - # Look for SCOM Register addresses - foreach my $scomRegister (@{$registerFfdc->{scomRegister}}) - { - print CRFILE " o_scomAddresses.push_back($scomRegister);\n"; - } - - print CRFILE " break;\n"; - } - - -} - -#------------------------------------------------------------------------------ -# Print end of file information to collect_reg_ffdc_regs.C -#------------------------------------------------------------------------------ -print CRFILE " default:\n"; -print CRFILE " FAPI_ERR(\"collect_reg_ffdc_regs.C: Invalid FFDC ID 0x%x\", "; -print CRFILE "i_ffdcId);\n"; -print CRFILE " return;\n"; -print CRFILE " }\n"; -print CRFILE "o_ffdcSize = o_scomAddresses.size() * sizeof(uint64_t);\n"; -print CRFILE "o_ffdcSize += o_cfamAddresses.size() * sizeof(uint32_t);\n"; -print CRFILE "}\n"; -print CRFILE "} // end namespace\n\n"; - -#------------------------------------------------------------------------------ -# Print the fapiHwpReturnCodes.H file -#------------------------------------------------------------------------------ -print RCFILE "// fapiHwpReturnCodes.H\n"; -print RCFILE "// This file is generated by perl script parseErrorInfo.pl\n\n"; -print RCFILE "#ifndef FAPI2_HWPRETURNCODES_H_\n"; -print RCFILE "#define FAPI2_HWPRETURNCODES_H_\n\n"; -print RCFILE "#ifndef __ASSEMBLER__\n"; -print RCFILE "namespace fapi2\n"; -print RCFILE "{\n\n"; -print RCFILE "/**\n"; -print RCFILE " * \@brief Enumeration of HWP return codes\n"; -print RCFILE " *\/\n"; -print RCFILE "enum HwpReturnCode\n"; -print RCFILE "{\n"; -foreach my $key (keys %errNameToValueHash) -{ - print RCFILE " $key = 0x$errNameToValueHash{$key},\n"; -} -print RCFILE "};\n\n"; -print RCFILE "}\n\n"; -print RCFILE "#else\n"; -foreach my $key (keys %errNameToValueHash) -{ - print RCFILE " .set $key, 0x$errNameToValueHash{$key}\n"; -} -print RCFILE "#endif\n"; -print RCFILE "#endif\n"; - -#------------------------------------------------------------------------------ -# Print the HwpFfdcId enumeration to hwp_error_info.H -#------------------------------------------------------------------------------ -print EIFILE "namespace fapi2\n"; -print EIFILE "{\n\n"; -if($arg_local_ffdc) -{ - print EIFILE " extern SbeFfdcData_t g_FfdcData;\n"; -} -print EIFILE "/**\n"; -print EIFILE " * \@brief Enumeration of FFDC identifiers\n"; -print EIFILE " *\/\n"; -print EIFILE "enum HwpFfdcId\n"; -print EIFILE "{\n"; -foreach my $key (keys %ffdcNameToValueHash) -{ - print EIFILE " $key = 0x$ffdcNameToValueHash{$key},\n"; -} -print EIFILE "};\n\n"; -print EIFILE "}\n\n"; - -#------------------------------------------------------------------------------ -# Print end of file information to hwp_error_info.H -#------------------------------------------------------------------------------ -print EIFILE "\n\n#endif\n"; - -#------------------------------------------------------------------------------ -# Print end of file information to hwp_ffdc_classes.H -#------------------------------------------------------------------------------ -print ECFILE "\n};\n"; # close the namespace -print ECFILE "\n\n#endif\n"; - -#------------------------------------------------------------------------------ -# Print end of file information to set_sbe_error.H -#------------------------------------------------------------------------------ -print SBFILE " default:\\\n"; -#print SBFILE " FAPI_SET_HWP_ERROR(RC, RC_SBE_UNKNOWN_ERROR,0);\\\n"; -print SBFILE " break;\\\n"; -print SBFILE "}\\\n"; -print SBFILE "}\n\n"; -print SBFILE "#endif\n"; - -#------------------------------------------------------------------------------ -# Close output files -#------------------------------------------------------------------------------ -close(RCFILE); -close(EIFILE); -close(ECFILE); -close(CRFILE); -close(SBFILE); diff --git a/import/hwpf/fapi2/xml/attribute_info/chip_attributes.xml b/import/hwpf/fapi2/xml/attribute_info/chip_attributes.xml deleted file mode 100644 index 116c209a..00000000 --- a/import/hwpf/fapi2/xml/attribute_info/chip_attributes.xml +++ /dev/null @@ -1,59 +0,0 @@ -<!-- IBM_PROLOG_BEGIN_TAG --> -<!-- This is an automatically generated prolog. --> -<!-- --> -<!-- $Source: import/hwpf/fapi2/xml/attribute_info/chip_attributes.xml $ --> -<!-- --> -<!-- OpenPOWER sbe 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 --> -<attributes> - <!-- ******************************************************************************** --> - <attribute> - <id>ATTR_NAME</id> - <targetType>TARGET_TYPE_PROC_CHIP, TARGET_TYPE_MEMBUF_CHIP</targetType> - <description> - Product name of a chip target. - Provided by the MRW. - </description> - <valueType>uint8</valueType> - <enum> - NONE = 0x0, - CENTAUR = 0x3, - NIMBUS = 0x5, - CUMULUS = 0x6 - </enum> - <platInit/> - <privileged/> - </attribute> - <!-- ********************************************************************* --> - <attribute> - <id>ATTR_EC</id> - <targetType>TARGET_TYPE_PROC_CHIP, TARGET_TYPE_MEMBUF_CHIP</targetType> - <description> - EC level of a chip target. - Read from the chip by the platform - </description> - <valueType>uint8</valueType> - <platInit/> - <!-- To make HWPs data driven, this is a privileged attribute that cannot - be accessed by normal HWPs. --> - <privileged/> - </attribute> - <!-- ********************************************************************* --> -</attributes> |