// UNCLASSIFIED /*------------------------------------------------------------------------- RAYTHEON PROPRIETARY: THIS DOCUMENT CONTAINS DATA OR INFORMATION PROPRIETARY TO RAYTHEON COMPANY AND IS RESTRICTED TO USE ONLY BY PERSONS AUTHORIZED BY RAYTHEON COMPANY IN WRITING TO USE IT. DISCLOSURE TO UNAUTHORIZED PERSONS WOULD LIKELY CAUSE SUBSTANTIAL COMPETITIVE HARM TO RAYTHEON COMPANY'S BUSINESS POSITION. NEITHER SAID DOCUMENT NOR ITS CONTENTS SHALL BE FURNISHED OR DISCLOSED TO OR COPIED OR USED BY PERSONS OUTSIDE RAYTHEON COMPANY WITHOUT THE EXPRESS WRITTEN APPROVAL OF RAYTHEON COMPANY. THIS PROPRIETARY NOTICE IS NOT APPLICABLE IF DELIVERED TO THE U.S. GOVERNMENT. UNPUBLISHED WORK - COPYRIGHT RAYTHEON COMPANY. -------------------------------------------------------------------------*/ using NLog; using Raytheon.Common; using System; using System.Collections.Generic; using System.Threading; namespace Raytheon.Instruments { /// /// A simulated fpga /// public class CommFpgaSim : IFpgaComm { #region PrivateClassMembers private Dictionary _registers; private static object _syncObj = new Object(); private SelfTestResult _selfTestResult; private State _state; private string _name; /// /// NLog logger /// private readonly ILogger _logger; /// /// Raytheon configuration /// private readonly IConfigurationManager _configurationManager; private readonly IConfiguration _configuration; #endregion #region PrivateFunctions /// /// The finalizer. /// ~CommFpgaSim() { Dispose(false); } /// /// /// /// protected virtual void Dispose(bool disposing) { try { if (disposing) { } } catch (Exception) { try { //ErrorLogger.Instance().Write(err.Message + "\r\n" + err.StackTrace); } catch (Exception) { //Do not rethrow. Exception from error logger that has already been garbage collected } } } #endregion #region PublicFuctions /// /// CommFpgaSim factory constructor /// /// /// public CommFpgaSim(string deviceName, IConfigurationManager configurationManager, ILogger logger) { Name = deviceName; _logger = logger; _configurationManager = configurationManager; _configuration = _configurationManager.GetConfiguration(Name); _selfTestResult = SelfTestResult.Unknown; _state = State.Uninitialized; _registers = null; } /// /// /// /// public CommFpgaSim(string name) { _name = name; _logger = LogManager.GetCurrentClassLogger(); _selfTestResult = SelfTestResult.Unknown; _state = State.Uninitialized; _registers = null; } /// /// /// /// public bool ClearErrors() { return false; } /// /// /// public string DetailedStatus { get { return "This is a FPGA Sim called " + _name; } } /// /// /// public bool DisplayEnabled { get { return false; } set { throw new NotImplementedException(); } } /// /// /// public void Dispose() { lock (_syncObj) { try { Dispose(true); GC.SuppressFinalize(this); } catch (Exception) { try { //ErrorLogger.Instance().Write(err.Message + "\r\n" + err.StackTrace); } catch (Exception) { //Do not rethrow. Exception from error logger that has already been garbage collected } } } } /// /// /// public bool FrontPanelEnabled { get { return false; } set { throw new NotImplementedException(); } } /// /// /// public InstrumentMetadata Info { get { throw new NotImplementedException(); } } /// /// /// public void Initialize() { throw new NotImplementedException(); } /// /// /// /// public void Initialize(string fpga) { lock (_syncObj) { if (_state == State.Uninitialized) { _state = State.Ready; _registers = new Dictionary(); } else { throw new Exception("expected the state to be Uninitialized, state was: " + _state.ToString() + " on card " + _name); } } } /// /// /// public string Name { get { return _name; } set { _name = value; } } /// /// /// /// public SelfTestResult PerformSelfTest() { _selfTestResult = SelfTestResult.Unknown; return _selfTestResult; } /// /// /// /// /// /// public uint Read(string fpgaName, uint address) { lock (_syncObj) { Thread.Sleep(50); if (_registers.ContainsKey(address) == true) { return _registers[address]; } else { return 0xffffffff; } } } /// /// /// /// /// /// /// /// public void ReadBlock(string fpgaName, uint address, uint numberOfWordsToRead, bool shallWeIncrementAddress, ref uint[] dataRead) { lock (_syncObj) { Thread.Sleep(50); for (int i = 0; i < numberOfWordsToRead; i++) { dataRead[i] = Read(fpgaName, address); if (shallWeIncrementAddress == true) { address += 4; } } } } /// /// /// public void Reset() { Shutdown(); Initialize(); } /// /// /// public SelfTestResult SelfTestResult { get { return _selfTestResult; } } /// /// /// public State Status { get { return _state; } } /// /// /// public void Shutdown() { _state = State.Uninitialized; } /// /// /// /// /// /// public void Write(string fpgaName, uint address, uint value) { lock (_syncObj) { Thread.Sleep(50); _registers[address] = value; } } /// /// /// /// /// /// /// /// public void WriteBlock(string fpgaName, uint address, uint numberOfWordsToWrite, uint[] data, bool shallWeIncrementAddress) { lock (_syncObj) { Thread.Sleep(50); for (int i = 0; i < numberOfWordsToWrite; i++) { uint dataItem = data[i]; Write(fpgaName, address, dataItem); if (shallWeIncrementAddress == true) { address += 4; } } } } /// /// Loads firmware /// /// public void LoadFirmware(string fpgaName) { Initialize(fpgaName); } #endregion } }