#ifndef __NEOVIFIRE2_H_ #define __NEOVIFIRE2_H_ #ifdef __cplusplus #include "icsneo/device/device.h" #include "icsneo/device/devicetype.h" #include "icsneo/device/tree/neovifire2/neovifire2settings.h" #include "icsneo/disk/neomemorydiskdriver.h" namespace icsneo { class NeoVIFIRE2 : public Device { public: // Serial numbers start with CY // USB PID is 0x1000, standard driver is DXX // Ethernet MAC allocation is 0x04, standard driver is Raw ICSNEO_FINDABLE_DEVICE(NeoVIFIRE2, DeviceType::FIRE2, "CY"); enum class SKU { Standard, AP1200A, // Keysight Branding }; static const std::vector& GetSupportedNetworks() { static std::vector supportedNetworks = { Network::NetID::DWCAN_01, Network::NetID::DWCAN_08, Network::NetID::DWCAN_02, Network::NetID::DWCAN_03, Network::NetID::DWCAN_04, Network::NetID::DWCAN_05, Network::NetID::DWCAN_06, Network::NetID::DWCAN_07, Network::NetID::LSFTCAN_01, Network::NetID::LSFTCAN_02, Network::NetID::SWCAN_01, Network::NetID::SWCAN_02, Network::NetID::ETHERNET_01, Network::NetID::LIN_01, Network::NetID::LIN_02, Network::NetID::LIN_03, Network::NetID::LIN_04, Network::NetID::ISO9141_01, Network::NetID::ISO9141_02, Network::NetID::ISO9141_03, Network::NetID::ISO9141_04 }; return supportedNetworks; } SKU getSKU() const { switch(getSerial().back()) { case 'A': return SKU::AP1200A; default: return SKU::Standard; } } std::string getProductName() const override { switch(getSKU()) { case SKU::Standard: break; case SKU::AP1200A: return "Keysight AP1200A"; } return Device::getProductName(); } size_t getEthernetActivationLineCount() const override { return 1; } size_t getUSBHostPowerCount() const override { return 1; } bool getBackupPowerSupported() const override { return true; } std::vector getMiscIO() const override { return { {5, true, true, false}, {6, true, true, false} }; } std::vector getEMiscIO() const override { return { {1, true, true, true}, {2, true, true, true} }; } ProductID getProductID() const override { return ProductID::neoVIFIRE2; } const std::vector& getChipInfo() const override { static std::vector chips = { {ChipID::neoVIFIRE2_MCHIP, true, "MCHIP", "fire2_mchip_ief", 0, FirmwareType::IEF}, {ChipID::neoVIFIRE2_ZYNQ, true, "ZCHIP", "fire2_zchip_ief", 1, FirmwareType::IEF}, {ChipID::neoVIFIRE2_Core, true, "Core", "fire2_core", 2, FirmwareType::IEF}, }; return chips; } BootloaderPipeline getBootloader() override { return BootloaderPipeline() .add() .add(ChipID::neoVIFIRE2_MCHIP, BootloaderCommunication::RED) .add(ChipID::neoVIFIRE2_ZYNQ, BootloaderCommunication::RED, false, true) .add(ChipID::neoVIFIRE2_Core, BootloaderCommunication::REDCore, false, false) .add(); } protected: NeoVIFIRE2(neodevice_t neodevice, const driver_factory_t& makeDriver) : Device(neodevice) { initialize(makeDriver); } void setupSettings(IDeviceSettings& ssettings) override { if(com->driver->isEthernet()) { // TODO Check firmware version, old firmwares will reset Ethernet settings on settings send ssettings.readonly = true; } } bool currentDriverSupportsDFU() const override { return !com->driver->isEthernet(); } void setupPacketizer(Packetizer& packetizer) override { Device::setupPacketizer(packetizer); packetizer.align16bit = !com->driver->isEthernet(); } virtual void setupEncoder(Encoder& encoder) override { Device::setupEncoder(encoder); encoder.supportCANFD = true; } void setupSupportedRXNetworks(std::vector& rxNetworks) override { for(auto& netid : GetSupportedNetworks()) rxNetworks.emplace_back(netid); } // The supported TX networks are the same as the supported RX networks for this device void setupSupportedTXNetworks(std::vector& txNetworks) override { setupSupportedRXNetworks(txNetworks); } void handleDeviceStatus(const std::shared_ptr& message) override { if(message->data.size() < sizeof(neovifire2_status_t)) return; std::lock_guard lk(ioMutex); const neovifire2_status_t* status = reinterpret_cast(message->data.data()); backupPowerEnabled = status->backupPowerEnabled; backupPowerGood = status->backupPowerGood; ethActivationStatus = status->ethernetActivationLineEnabled; usbHostPowerStatus = status->usbHostPowerEnabled; } std::optional getCoreminiStartAddressFlash() const override { return 4608 * 512; } std::optional getCoreminiStartAddressSD() const override { return 0; } bool supportsEraseMemory() const override { return true; } size_t getDiskCount() const override { return 1; } }; } #endif // __cplusplus #endif