|  | // Module Description ************************************************** | 
|  | // | 
|  | // Description: This module provides the implementation for the PRD Scan | 
|  | //              Comm Register Chip class. | 
|  | // | 
|  | // End Module Description ********************************************** | 
|  |  | 
|  | //---------------------------------------------------------------------- | 
|  | //  Includes | 
|  | //---------------------------------------------------------------------- | 
|  |  | 
|  | #include <hei_includes.hpp> | 
|  | #include <hei_user_interface.hpp> | 
|  | #include <register/hei_hardware_register.hpp> | 
|  | #include <util/hei_bit_string.hpp> | 
|  |  | 
|  | #if 0 | 
|  | #include <iipchip.h> | 
|  | #include <prdfMain.H> | 
|  | #include <prdfRasServices.H> | 
|  | #include <prdfRegisterCache.H> | 
|  | #include <prdfPlatServices.H> | 
|  | #include <prdfExtensibleChip.H> | 
|  |  | 
|  | //---------------------------------------------------------------------- | 
|  | //  User Types | 
|  | //---------------------------------------------------------------------- | 
|  |  | 
|  | //---------------------------------------------------------------------- | 
|  | //  Constants | 
|  | //---------------------------------------------------------------------- | 
|  |  | 
|  | //---------------------------------------------------------------------- | 
|  | //  Macros | 
|  | //---------------------------------------------------------------------- | 
|  |  | 
|  | //---------------------------------------------------------------------- | 
|  | //  Internal Function Prototypes | 
|  | //---------------------------------------------------------------------- | 
|  |  | 
|  | //---------------------------------------------------------------------- | 
|  | //  Global Variables | 
|  | //---------------------------------------------------------------------- | 
|  |  | 
|  | //--------------------------------------------------------------------- | 
|  | // Member Function Specifications | 
|  | //--------------------------------------------------------------------- | 
|  |  | 
|  | // -------------------------------------------------------------------- | 
|  | #endif | 
|  |  | 
|  | namespace libhei | 
|  | { | 
|  |  | 
|  | #if 0 | 
|  | // --------------------------------------------------------------------- | 
|  |  | 
|  | void HardwareRegister::SetBitString( const BitString *bs ) | 
|  | { | 
|  | BitString & l_string  = AccessBitString(); | 
|  | l_string.setString(*bs); | 
|  | } | 
|  |  | 
|  |  | 
|  | //------------------------------------------------------------------------------ | 
|  |  | 
|  | const BitString * HardwareRegister::GetBitString(ATTENTION_TYPE i_type) const | 
|  | { | 
|  | // Calling Read() will ensure that an entry exists in the cache and the | 
|  | // entry has at been synched with hardware at least once. Note that we | 
|  | // cannot read hardware for write-only registers. In this case, an entry | 
|  | // will be created in the cache, if it does not exist, when readCache() is | 
|  | // called below. | 
|  | if ( ( ACCESS_NONE != iv_operationType ) && | 
|  | ( ACCESS_WO != iv_operationType ) ) | 
|  | { | 
|  | Read(); | 
|  | } | 
|  | return &(readCache()); | 
|  | } | 
|  |  | 
|  | //------------------------------------------------------------------------------ | 
|  |  | 
|  | BitString & HardwareRegister::AccessBitString() | 
|  | { | 
|  | // Calling Read() will ensure that an entry exists in the cache and the | 
|  | // entry has at been synched with hardware at least once. Note that we | 
|  | // cannot read hardware for write-only registers. In this case, an entry | 
|  | // will be created in the cache, if it does not exist, when readCache() is | 
|  | // called below. | 
|  | if ( ( ACCESS_NONE != iv_operationType ) && | 
|  | ( ACCESS_WO != iv_operationType ) ) | 
|  | { | 
|  | Read(); | 
|  | } | 
|  |  | 
|  | return readCache(); | 
|  | } | 
|  | #endif | 
|  |  | 
|  | //------------------------------------------------------------------------------ | 
|  |  | 
|  | ReturnCode HardwareRegister::read( bool i_force ) const | 
|  | { | 
|  | ReturnCode rc; | 
|  |  | 
|  | #if 0 | 
|  | // Read from hardware only if the read is forced or the entry for this | 
|  | // instance does not exist in the cache. | 
|  | if ( i_force || !queryCache() ) | 
|  | { | 
|  | // This register must be readable. | 
|  | HEI_ASSERT( ( ACCESS_NONE != iv_operationType ) && | 
|  | ( ACCESS_WO   != iv_operationType ) ); | 
|  |  | 
|  | // Get the buffer from the register cache. | 
|  | BitString & bs = readCache(); | 
|  |  | 
|  | // Get the byte size of the buffer. | 
|  | size_t sz_buffer = BitString::getMinBytes( bs.getBitLen() ); | 
|  |  | 
|  | // Read this register from hardware. | 
|  | rc = registerRead( getAccessorChip().getChip(), bs.getBufAddr(), | 
|  | sz_buffer, getRegisterType(), getAddress() ); | 
|  | if ( RC_SUCCESS != rc ) | 
|  | { | 
|  | // The read failed and we can't trust what was put in the register | 
|  | // cache. So remove this instance's entry from the cache. | 
|  | flushCache( getAccessorChip() ); | 
|  | } | 
|  | else | 
|  | { | 
|  | // Sanity check. The returned size of the data written to the buffer | 
|  | // should match the register size. | 
|  | HEI_ASSERT( getSize() == sz_buffer ); | 
|  | } | 
|  | } | 
|  | #endif | 
|  |  | 
|  | return rc; | 
|  | } | 
|  |  | 
|  | //------------------------------------------------------------------------------ | 
|  |  | 
|  | #ifndef __HEI_READ_ONLY | 
|  |  | 
|  | ReturnCode HardwareRegister::write() const | 
|  | { | 
|  | ReturnCode rc; | 
|  |  | 
|  | #if 0 | 
|  | // This register must be writable. | 
|  | HEI_ASSERT( ( ACCESS_NONE != iv_operationType ) && | 
|  | ( ACCESS_RO   != iv_operationType ) ); | 
|  |  | 
|  | // An entry for this register must exist in the cache. | 
|  | HEI_ASSERT( queryCache() ); | 
|  |  | 
|  | // Get the buffer from the register cache. | 
|  | BitString & bs = readCache(); | 
|  |  | 
|  | // Get the byte size of the buffer. | 
|  | size_t sz_buffer = BitString::getMinBytes( bs.getBitLen() ); | 
|  |  | 
|  | // Write to this register to hardware. | 
|  | rc = registerWrite( getAccessorChip().getChip(), bs.getBufAddr(), | 
|  | sz_buffer, getRegisterType(), getAddress() ); | 
|  |  | 
|  | if ( RC_SUCCESS == rc ) | 
|  | { | 
|  | // Sanity check. The returned size of the data written to the buffer | 
|  | // should match the register size. | 
|  | HEI_ASSERT( getSize() == sz_buffer ); | 
|  | } | 
|  | #endif | 
|  |  | 
|  | return rc; | 
|  | } | 
|  |  | 
|  | #endif // __HEI_READ_ONLY | 
|  |  | 
|  | #if 0 | 
|  | //------------------------------------------------------------------------------ | 
|  |  | 
|  | bool HardwareRegister::queryCache() const | 
|  | { | 
|  | RegDataCache & cache = RegDataCache::getCachedRegisters(); | 
|  | BitString * bs = cache.queryCache( getAccessorChip(), this ); | 
|  | return ( nullptr != bs ); | 
|  | } | 
|  |  | 
|  | //------------------------------------------------------------------------------ | 
|  |  | 
|  | BitString & HardwareRegister::readCache() const | 
|  | { | 
|  | RegDataCache & cache = RegDataCache::getCachedRegisters(); | 
|  | return cache.read( getAccessorChip(), this ); | 
|  | } | 
|  |  | 
|  | //------------------------------------------------------------------------------ | 
|  |  | 
|  | void HardwareRegister::flushCache( ExtensibleChip *i_pChip ) const | 
|  | { | 
|  | RegDataCache & regDump = RegDataCache::getCachedRegisters(); | 
|  | if( nullptr == i_pChip ) | 
|  | { | 
|  | regDump.flush(); | 
|  | } | 
|  | else | 
|  | { | 
|  | regDump.flush( i_pChip ,this ); | 
|  | } | 
|  | } | 
|  |  | 
|  | //----------------------------------------------------------------------------- | 
|  |  | 
|  | bool HardwareRegister::operator == ( const HardwareRegister & i_rightRegister ) const | 
|  | { | 
|  | if( iv_scomAddress == i_rightRegister.GetAddress() ) | 
|  | { | 
|  | return ( iv_chipType == i_rightRegister.getChipType() ); | 
|  | } | 
|  | else | 
|  | { | 
|  | return false ; | 
|  | } | 
|  |  | 
|  | } | 
|  |  | 
|  | //----------------------------------------------------------------------------- | 
|  | bool HardwareRegister::operator < ( const HardwareRegister & i_rightRegister  ) const | 
|  | { | 
|  | if( iv_scomAddress == i_rightRegister.GetAddress() ) | 
|  | { | 
|  | return ( iv_chipType < i_rightRegister.getChipType() ); | 
|  | } | 
|  | else | 
|  | { | 
|  | return( iv_scomAddress  < i_rightRegister.GetAddress() ); | 
|  | } | 
|  |  | 
|  |  | 
|  | } | 
|  | //----------------------------------------------------------------------------- | 
|  | bool HardwareRegister::operator >= ( const HardwareRegister & i_rightRegister  ) const | 
|  | { | 
|  | return !( *this < i_rightRegister ); | 
|  | } | 
|  | #endif | 
|  |  | 
|  | //------------------------------------------------------------------------------ | 
|  |  | 
|  | HardwareRegister::Accessor * HardwareRegister::cv_accessor = nullptr; | 
|  |  | 
|  | //------------------------------------------------------------------------------ | 
|  |  | 
|  | } // end namespace libhei | 
|  |  |