Add support for RADPluto over USB
parent
a465d5d6c6
commit
56d191b438
|
|
@ -38,6 +38,10 @@ static std::vector<DeviceType> supportedDevices = {
|
||||||
RADGalaxy::DEVICE_TYPE,
|
RADGalaxy::DEVICE_TYPE,
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef __RADPLUTOUSB_H_
|
||||||
|
RADPlutoUSB::DEVICE_TYPE,
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef __RADSTAR2ETH_H_
|
#ifdef __RADSTAR2ETH_H_
|
||||||
RADStar2ETH::DEVICE_TYPE,
|
RADStar2ETH::DEVICE_TYPE,
|
||||||
#endif
|
#endif
|
||||||
|
|
@ -112,6 +116,10 @@ std::vector<std::shared_ptr<Device>> DeviceFinder::FindAll() {
|
||||||
findResults.push_back(RADGalaxy::Find());
|
findResults.push_back(RADGalaxy::Find());
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#ifdef __RADPLUTOUSB_H_
|
||||||
|
findResults.push_back(RADPlutoUSB::Find());
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef __RADSTAR2ETH_H_
|
#ifdef __RADSTAR2ETH_H_
|
||||||
findResults.push_back(RADStar2ETH::Find());
|
findResults.push_back(RADStar2ETH::Find());
|
||||||
#endif
|
#endif
|
||||||
|
|
|
||||||
|
|
@ -13,39 +13,8 @@ class RADPluto : public Device {
|
||||||
public:
|
public:
|
||||||
// Serial numbers start with PL
|
// Serial numbers start with PL
|
||||||
static constexpr DeviceType::Enum DEVICE_TYPE = DeviceType::RADPluto;
|
static constexpr DeviceType::Enum DEVICE_TYPE = DeviceType::RADPluto;
|
||||||
static constexpr const uint16_t PRODUCT_ID = 0xffff; // Not yet set
|
static constexpr const uint16_t PRODUCT_ID = 0x1104;
|
||||||
static constexpr const char* SERIAL_START = "PL";
|
static constexpr const char* SERIAL_START = "PL";
|
||||||
static std::vector<std::shared_ptr<Device>> Find() {
|
|
||||||
std::vector<std::shared_ptr<Device>> found;
|
|
||||||
|
|
||||||
for(auto& foundDev : PCAP::FindAll()) {
|
|
||||||
auto fakedev = std::shared_ptr<RADPluto>(new RADPluto({}));
|
|
||||||
for(auto& payload : foundDev.discoveryPackets)
|
|
||||||
fakedev->com->packetizer->input(payload);
|
|
||||||
for(auto& packet : fakedev->com->packetizer->output()) {
|
|
||||||
std::shared_ptr<Message> msg;
|
|
||||||
if(!fakedev->com->decoder->decode(msg, packet))
|
|
||||||
continue; // We failed to decode this packet
|
|
||||||
|
|
||||||
if(!msg || msg->network.getNetID() != Network::NetID::Main51)
|
|
||||||
continue; // Not a message we care about
|
|
||||||
auto sn = std::dynamic_pointer_cast<SerialNumberMessage>(msg);
|
|
||||||
if(!sn)
|
|
||||||
continue; // Not a serial number message
|
|
||||||
|
|
||||||
if(sn->deviceSerial.length() < 2)
|
|
||||||
continue;
|
|
||||||
if(sn->deviceSerial.substr(0, 2) != SERIAL_START)
|
|
||||||
continue; // Not a RADPluto
|
|
||||||
|
|
||||||
foundDev.device.serial[sn->deviceSerial.copy(foundDev.device.serial, sizeof(foundDev.device.serial))] = '\0';
|
|
||||||
found.emplace_back(new RADPluto(foundDev.device));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return found;
|
|
||||||
}
|
|
||||||
|
|
||||||
static const std::vector<Network>& GetSupportedNetworks() {
|
static const std::vector<Network>& GetSupportedNetworks() {
|
||||||
static std::vector<Network> supportedNetworks = {
|
static std::vector<Network> supportedNetworks = {
|
||||||
|
|
@ -65,28 +34,16 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
RADPluto(neodevice_t neodevice) : Device(neodevice) {
|
RADPluto(neodevice_t neodevice) : Device(neodevice) {
|
||||||
initialize<PCAP>();
|
|
||||||
getWritableNeoDevice().type = DEVICE_TYPE;
|
getWritableNeoDevice().type = DEVICE_TYPE;
|
||||||
productId = PRODUCT_ID;
|
productId = PRODUCT_ID;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void setupPacketizer(Packetizer& packetizer) override {
|
|
||||||
Device::setupPacketizer(packetizer);
|
|
||||||
packetizer.disableChecksum = true;
|
|
||||||
packetizer.align16bit = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void setupEncoder(Encoder& encoder) override {
|
virtual void setupEncoder(Encoder& encoder) override {
|
||||||
Device::setupEncoder(encoder);
|
Device::setupEncoder(encoder);
|
||||||
encoder.supportCANFD = true;
|
encoder.supportCANFD = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual void setupDecoder(Decoder& decoder) override {
|
|
||||||
Device::setupDecoder(decoder);
|
|
||||||
decoder.timestampMultiplier = 10; // Timestamps are in 10ns increments instead of the usual 25ns
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void setupSupportedRXNetworks(std::vector<Network>& rxNetworks) override {
|
virtual void setupSupportedRXNetworks(std::vector<Network>& rxNetworks) override {
|
||||||
for(auto& netid : GetSupportedNetworks())
|
for(auto& netid : GetSupportedNetworks())
|
||||||
rxNetworks.emplace_back(netid);
|
rxNetworks.emplace_back(netid);
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,29 @@
|
||||||
|
#ifndef __RADPLUTOUSB_H_
|
||||||
|
#define __RADPLUTOUSB_H_
|
||||||
|
|
||||||
|
#include "icsneo/device/radpluto/radpluto.h"
|
||||||
|
#include "icsneo/platform/stm32.h"
|
||||||
|
|
||||||
|
namespace icsneo {
|
||||||
|
|
||||||
|
class RADPlutoUSB : public RADPluto {
|
||||||
|
public:
|
||||||
|
// Serial numbers start with RP
|
||||||
|
static std::vector<std::shared_ptr<Device>> Find() {
|
||||||
|
std::vector<std::shared_ptr<Device>> found;
|
||||||
|
|
||||||
|
for(auto neodevice : STM32::FindByProduct(PRODUCT_ID))
|
||||||
|
found.emplace_back(new RADPlutoUSB(neodevice));
|
||||||
|
|
||||||
|
return found;
|
||||||
|
}
|
||||||
|
|
||||||
|
private:
|
||||||
|
RADPlutoUSB(neodevice_t neodevice) : RADPluto(neodevice) {
|
||||||
|
initialize<STM32>();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
@ -9,7 +9,7 @@
|
||||||
#include "icsneo/device/plasion/neoviion.h"
|
#include "icsneo/device/plasion/neoviion.h"
|
||||||
#include "icsneo/device/plasion/neoviplasma.h"
|
#include "icsneo/device/plasion/neoviplasma.h"
|
||||||
//#include "icsneo/device/radgalaxy/radgalaxy.h"
|
//#include "icsneo/device/radgalaxy/radgalaxy.h"
|
||||||
#include "icsneo/device/radpluto/radpluto.h"
|
#include "icsneo/device/radpluto/radplutousb.h"
|
||||||
//#include "icsneo/device/radstar2/radstar2eth.h"
|
//#include "icsneo/device/radstar2/radstar2eth.h"
|
||||||
#include "icsneo/device/radstar2/radstar2usb.h"
|
#include "icsneo/device/radstar2/radstar2usb.h"
|
||||||
#include "icsneo/device/radsupermoon/radsupermoon.h"
|
#include "icsneo/device/radsupermoon/radsupermoon.h"
|
||||||
|
|
|
||||||
|
|
@ -9,7 +9,7 @@
|
||||||
#include "icsneo/device/plasion/neoviion.h"
|
#include "icsneo/device/plasion/neoviion.h"
|
||||||
#include "icsneo/device/plasion/neoviplasma.h"
|
#include "icsneo/device/plasion/neoviplasma.h"
|
||||||
#include "icsneo/device/radgalaxy/radgalaxy.h"
|
#include "icsneo/device/radgalaxy/radgalaxy.h"
|
||||||
#include "icsneo/device/radgalaxy/radpluto.h"
|
#include "icsneo/device/radpluto/radplutousb.h"
|
||||||
#include "icsneo/device/radstar2/radstar2eth.h"
|
#include "icsneo/device/radstar2/radstar2eth.h"
|
||||||
#include "icsneo/device/radstar2/radstar2usb.h"
|
#include "icsneo/device/radstar2/radstar2usb.h"
|
||||||
#include "icsneo/device/radsupermoon/radsupermoon.h"
|
#include "icsneo/device/radsupermoon/radsupermoon.h"
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue