blob: fb53520339f8a69b60b4379049d8676bc110b498 [file] [log] [blame]
Patrick Benavoli68a91282011-08-31 11:23:23 +02001/* <auto_header>
2 * <FILENAME>
3 *
4 * INTEL CONFIDENTIAL
5 * Copyright © 2011 Intel
6 * Corporation All Rights Reserved.
7 *
8 * The source code contained or described herein and all documents related to
9 * the source code ("Material") are owned by Intel Corporation or its suppliers
10 * or licensors. Title to the Material remains with Intel Corporation or its
11 * suppliers and licensors. The Material contains trade secrets and proprietary
12 * and confidential information of Intel or its suppliers and licensors. The
13 * Material is protected by worldwide copyright and trade secret laws and
14 * treaty provisions. No part of the Material may be used, copied, reproduced,
15 * modified, published, uploaded, posted, transmitted, distributed, or
16 * disclosed in any way without Intel’s prior express written permission.
17 *
18 * No license under any patent, copyright, trade secret or other intellectual
19 * property right is granted to or conferred upon you by disclosure or delivery
20 * of the Materials, either expressly, by implication, inducement, estoppel or
21 * otherwise. Any license under such intellectual property rights must be
22 * express and approved by Intel in writing.
23 *
24 * AUTHOR: Patrick Benavoli (patrickx.benavoli@intel.com)
25 * CREATED: 2011-06-01
26 * UPDATED: 2011-07-27
27 *
28 *
29 * </auto_header>
30 */
31#include "SubsystemObject.h"
32#include "InstanceConfigurableElement.h"
33#include "ParameterBlackboard.h"
34#include <assert.h>
35
36CSubsystemObject::CSubsystemObject(CInstanceConfigurableElement* pInstanceConfigurableElement)
37 : _pInstanceConfigurableElement(pInstanceConfigurableElement), _uiDataSize(pInstanceConfigurableElement->getFootPrint()), _pvSynchronizedLocation(NULL)
38{
39 // Syncer
40 _pInstanceConfigurableElement->setSyncer(this);
41}
42
43CSubsystemObject::~CSubsystemObject()
44{
45 _pInstanceConfigurableElement->unsetSyncer();
46}
47
48// Synchronized location
49void CSubsystemObject::setSynchronizedLocation(void* pvSynchronizedLocation)
50{
51 _pvSynchronizedLocation = pvSynchronizedLocation;
52}
53
54// Size
55uint32_t CSubsystemObject::getSize() const
56{
57 return _uiDataSize;
58}
59
60// Synchronization
61bool CSubsystemObject::sync(CParameterBlackboard& parameterBlackboard, bool bBack, string& strError)
62{
63 assert(_pvSynchronizedLocation);
64
65#ifdef SIMULATION
66 return true;
67#endif
68
69 // Synchronize to/from HW
70 if (bBack) {
71
72 // Read from HW
73 if (!receiveFromHW()) {
74
75 strError = "Unable to back synchronize configurable element " + _pInstanceConfigurableElement->getPath();
76
77 return false;
78 }
79
80 // Write parameter block data
81 parameterBlackboard.rawWrite(_pvSynchronizedLocation, _uiDataSize, _pInstanceConfigurableElement->getOffset());
82
83 } else {
84
85 // Read parameter block data
86 parameterBlackboard.rawRead(_pvSynchronizedLocation, _uiDataSize, _pInstanceConfigurableElement->getOffset());
87
88 // Send to HW
89 if (!sendToHW()) {
90
91 strError = "Unable to synchronize configurable element " + _pInstanceConfigurableElement->getPath();
92
93 return false;
94 }
95 }
96 return true;
97}