/*
*
*
* INTEL CONFIDENTIAL
* Copyright © 2011 Intel
* Corporation All Rights Reserved.
*
* The source code contained or described herein and all documents related to
* the source code ("Material") are owned by Intel Corporation or its suppliers
* or licensors. Title to the Material remains with Intel Corporation or its
* suppliers and licensors. The Material contains trade secrets and proprietary
* and confidential information of Intel or its suppliers and licensors. The
* Material is protected by worldwide copyright and trade secret laws and
* treaty provisions. No part of the Material may be used, copied, reproduced,
* modified, published, uploaded, posted, transmitted, distributed, or
* disclosed in any way without Intel’s prior express written permission.
*
* No license under any patent, copyright, trade secret or other intellectual
* property right is granted to or conferred upon you by disclosure or delivery
* of the Materials, either expressly, by implication, inducement, estoppel or
* otherwise. Any license under such intellectual property rights must be
* express and approved by Intel in writing.
*
* AUTHOR: Patrick Benavoli (patrickx.benavoli@intel.com)
* CREATED: 2011-06-01
* UPDATED: 2011-07-27
*
*
*
*/
#include "Parameter.h"
#include "ParameterType.h"
#include "ParameterAccessContext.h"
#include "ConfigurationAccessContext.h"
#include "ParameterBlackboard.h"
#define base CInstanceConfigurableElement
CParameter::CParameter(const string& strName, const CTypeElement* pTypeElement) : base(strName, pTypeElement)
{
}
CParameter::~CParameter()
{
}
CInstanceConfigurableElement::Type CParameter::getType() const
{
return EParameter;
}
// XML configuration settings parsing/composing
bool CParameter::serializeXmlSettings(CXmlElement& xmlConfigurationSettingsElementContent, CConfigurationAccessContext& configurationAccessContext) const
{
// Check for value space
handleValueSpaceAttribute(xmlConfigurationSettingsElementContent, configurationAccessContext);
// Handle access
if (!configurationAccessContext.serializeOut()) {
// Write to blackboard
if (!doSetValue(xmlConfigurationSettingsElementContent.getTextContent(), getOffset() - configurationAccessContext.getBaseOffset(), configurationAccessContext)) {
// Append parameter path to error
configurationAccessContext.appendToError(" " + getPath());
return false;
}
} else {
// Get string value
string strValue;
doGetValue(strValue, getOffset() - configurationAccessContext.getBaseOffset(), configurationAccessContext);
// Populate value into xml text node
xmlConfigurationSettingsElementContent.setTextContent(strValue);
}
// Done
return true;
}
// Value space handling for configuration import
void CParameter::handleValueSpaceAttribute(CXmlElement& xmlConfigurableElementSettingsElement, CConfigurationAccessContext& configurationAccessContext) const
{
// Delegate to type
static_cast(getTypeElement())->handleValueSpaceAttribute(xmlConfigurableElementSettingsElement, configurationAccessContext);
}
uint32_t CParameter::getFootPrint() const
{
return getSize();
}
uint32_t CParameter::getSize() const
{
return static_cast(getTypeElement())->getSize();
}
// Dump
void CParameter::logValue(string& strValue, CErrorContext& errorContext) const
{
CParameterAccessContext& parameterContext = static_cast(errorContext);
// Dump value
doGetValue(strValue, getOffset(), parameterContext);
// Prepend unit if any
prependUnit(strValue);
}
// Used for simulation only
void CParameter::setDefaultValues(CParameterAccessContext& parameterAccessContext) const
{
// Get default value from type
uint32_t uiDefaultValue = static_cast(getTypeElement())->getDefaultValue();
// Write blackboard
CParameterBlackboard* pBlackboard = parameterAccessContext.getParameterBlackboard();
// Beware this code works on little endian architectures only!
pBlackboard->write(&uiDefaultValue, getSize(), getOffset(), parameterAccessContext.isBigEndianSubsystem());
}
// Unit
void CParameter::prependUnit(string& strValue) const
{
string strUnit = static_cast(getTypeElement())->getUnit();
if (!strUnit.empty()) {
strValue = "(" + strUnit + ") " + strValue;
}
}
// Parameter Access
bool CParameter::setValue(CPathNavigator& pathNavigator, const string& strValue, CErrorContext& errorContext) const
{
// Check path validity
if (!checkPathExhausted(pathNavigator, errorContext)) {
return false;
}
// Parameter context
CParameterAccessContext& parameterContext = static_cast(errorContext);
// Set Value
if (!doSetValue(strValue, getOffset(), parameterContext)) {
// Append parameter path to error
parameterContext.appendToError(" " + getPath());
return false;
}
// Synchronize
if (parameterContext.getAutoSync() && !sync(parameterContext)) {
// Append parameter path to error
parameterContext.appendToError(" " + getPath());
return false;
}
return true;
}
bool CParameter::getValue(CPathNavigator& pathNavigator, string& strValue, CErrorContext& errorContext) const
{
// Check path validity
if (!checkPathExhausted(pathNavigator, errorContext)) {
return false;
}
// Parameter context
CParameterAccessContext& parameterContext = static_cast(errorContext);
// Get Value
doGetValue(strValue, getOffset(), parameterContext);
return true;
}
bool CParameter::doSetValue(const string& strValue, uint32_t uiOffset, CParameterAccessContext& parameterAccessContext) const
{
uint32_t uiData;
if (!static_cast(getTypeElement())->asInteger(strValue, uiData, parameterAccessContext)) {
return false;
}
// Write blackboard
CParameterBlackboard* pBlackboard = parameterAccessContext.getParameterBlackboard();
// Beware this code works on little endian architectures only!
pBlackboard->write(&uiData, getSize(), uiOffset, parameterAccessContext.isBigEndianSubsystem());
return true;
}
void CParameter::doGetValue(string& strValue, uint32_t uiOffset, CParameterAccessContext& parameterAccessContext) const
{
uint32_t uiData = 0;
// Read blackboard
CParameterBlackboard* pBlackboard = parameterAccessContext.getParameterBlackboard();
// Beware this code works on little endian architectures only!
pBlackboard->read(&uiData, getSize(), uiOffset, parameterAccessContext.isBigEndianSubsystem());
static_cast(getTypeElement())->asString(uiData, strValue, parameterAccessContext);
}