#ifndef __RADMOONDUO_H_ #define __RADMOONDUO_H_ #ifdef __cplusplus #include "icsneo/device/device.h" #include "icsneo/device/devicetype.h" #include "icsneo/device/tree/radmoonduo/radmoonduosettings.h" namespace icsneo { class RADMoonDuo : public Device { public: // Serial numbers start with MD // USB PID is 1106, standard driver is CDCACM ICSNEO_FINDABLE_DEVICE(RADMoonDuo, DeviceType::RADMoonDuo, "MD"); static const std::vector& GetSupportedNetworks() { // If Converter1 Target is set to USB/CM, AE_02 will be exposed to the PC static std::vector supportedNetworks = { Network::NetID::AE_02 }; return supportedNetworks; } bool getEthPhyRegControlSupported() const override { return true; } ProductID getProductID() const override { return ProductID::RADMoonDuo; } protected: RADMoonDuo(neodevice_t neodevice, const driver_factory_t& makeDriver) : Device(neodevice) { initialize(makeDriver); } virtual void setupEncoder(Encoder& encoder) override { Device::setupEncoder(encoder); encoder.supportEthPhy = 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); } bool requiresVehiclePower() const override { return false; } std::optional getCoreminiStartAddressFlash() const override { return 512*2048; } std::optional getCoreminiStartAddressSD() const override { return 0; } bool supportsEraseMemory() const override { return true; } }; } #endif // __cplusplus #endif