mirror of
https://github.com/hyperion-project/hyperion.ng.git
synced 2023-10-10 13:36:59 +02:00
e9936e131b
* Allow build, if no grabbers are enabled * Align available functions to right Qt version * Update to next development version * Align available functions to right Qt version * fix workflows (apt/nightly) * Disable QNetworkConfigurationManager deprecation warnings * Initial go on Smart Pointers * Add Deallocation * Correct QT_WARNING_DISABLE_DEPRECATED (available since 5.9) * Cluster Build Variables * Hyperion Light * Address build warnings * Hyperion Light - UI * Update Protobuf to latest master * Removed compiler warnings * Added restart ability to systray * Correct Protobuf * Ignore 'no-return' warning on protobuf build * hyperion-remote: Fix auto discovery of hyperion server * Fix Qt version override * Update changelog * Remove Grabber Components, if no Grabber exists * Standalone Grabber - Fix fps default * Remote Control - Have Source Selction accrosswhole screen * Enable Blackborder detection only, if relevant input sources available * Enable Blackborder detection only, if relevant input sources available * Remote UI - rearrange containers * Checkout * Fix compilation on windows * Re-added qmdnsengine template cmake * chrono added for linux * Removed existing AVAHI/Bonjour, allow to enable/disable mDNS * hyperiond macos typo fix * Fix macOS Bundle build * Fix macOS bundle info details * Correct CMake files * Removed existing AVAHI/Bonjour (2) * Share hyperion's services via mDNS * Add mDNS Browser and mDNS for LED-Devices * Support mDNS discovery for standalone grabbers * Remove ZLib Dependency & Cleanup * mDNS - hanle 2.local2 an ".local." domains equally * Hue - Link discovery to bridge class, workaround port 443 for mDNS discovery * Fix save button state when switching between devices * Removed sessions (of other hyperions) * mDNS Publisher - Simplify service naming * mDNS refactoring & Forwarder discovery * mDNS Updates to use device service name * Consistency of standalone grabbers with mDNS Service Registry * Merge branch 'hyperion-project:master' into mDNS * Start JSON and WebServers only after Instance 0 is available * Remove bespoke qDebug Output again * MDNS updates and refactor Forwarder * Minor updates * Upgrade to CMake 3.1 * typo * macOS fix * Correct merge * - Remove dynamic linker flag from standalone dispmanX Grabber - Added ability to use system qmdns libs * Cec handler library will load at runtime * typo fix * protobuf changes * mDNS changes for Windows/macOS * test window build qmdnsengine * absolute path to protobuf cmake dir * Rework Hue Wizard supporting mDNS * LED-Devices - Retry support + Refactoring (excl. Hue) * LED-Devices - Refactoring/Retry support Hue + additional alignments * Address LGTM findings * Fix CI-Build, revert test changes * Build Windows in Release mode to avoid python problem * Correct that WebServerObject is available earlier * Ensure that instance name in logs for one instance are presented * Update content LEDs * Rework mDNS Address lookup * Fix LED UI * Fix for non mDNS Services (ignore default port) * Disbale device when now input is available * Revert back some updates, ensure last color is updated when switched on * Handle reopening case and changed IP, port for API-calls * Add UPD-DDP Device * WLED support for DDP * Fix printout * LEDDevice - Allow more retries, udapte defaults * LED-Net Devices - Select Custom device, if configured Co-authored-by: Paulchen Panther <16664240+Paulchen-Panther@users.noreply.github.com> Co-authored-by: Paulchen Panther <Paulchen-Panter@protonmail.com>
101 lines
2.6 KiB
C++
101 lines
2.6 KiB
C++
#include "LedDeviceTpm2net.h"
|
|
#include <utils/NetUtils.h>
|
|
|
|
// Constants
|
|
namespace {
|
|
|
|
const char CONFIG_HOST[] = "host";
|
|
const char CONFIG_PORT[] = "port";
|
|
const ushort TPM2_DEFAULT_PORT = 65506;
|
|
}
|
|
|
|
LedDeviceTpm2net::LedDeviceTpm2net(const QJsonObject &deviceConfig)
|
|
: ProviderUdp(deviceConfig)
|
|
, _tpm2_buffer(nullptr)
|
|
{
|
|
}
|
|
|
|
LedDeviceTpm2net::~LedDeviceTpm2net()
|
|
{
|
|
free (_tpm2_buffer);
|
|
}
|
|
|
|
LedDevice* LedDeviceTpm2net::construct(const QJsonObject &deviceConfig)
|
|
{
|
|
return new LedDeviceTpm2net(deviceConfig);
|
|
}
|
|
|
|
bool LedDeviceTpm2net::init(const QJsonObject &deviceConfig)
|
|
{
|
|
bool isInitOK {false};
|
|
|
|
// Initialise sub-class
|
|
if ( ProviderUdp::init(deviceConfig) )
|
|
{
|
|
_hostName = _devConfig[ CONFIG_HOST ].toString();
|
|
_port = deviceConfig[CONFIG_PORT].toInt(TPM2_DEFAULT_PORT);
|
|
|
|
_tpm2_max = deviceConfig["max-packet"].toInt(170);
|
|
_tpm2ByteCount = 3 * _ledCount;
|
|
_tpm2TotalPackets = (_tpm2ByteCount / _tpm2_max) + ((_tpm2ByteCount % _tpm2_max) != 0);
|
|
|
|
_tpm2_buffer = (uint8_t*) malloc(_tpm2_max+7);
|
|
|
|
isInitOK = true;
|
|
}
|
|
return isInitOK;
|
|
}
|
|
|
|
int LedDeviceTpm2net::open()
|
|
{
|
|
int retval = -1;
|
|
_isDeviceReady = false;
|
|
|
|
if (NetUtils::resolveHostToAddress(_log, _hostName, _address))
|
|
{
|
|
if (ProviderUdp::open() == 0)
|
|
{
|
|
// Everything is OK, device is ready
|
|
_isDeviceReady = true;
|
|
retval = 0;
|
|
}
|
|
}
|
|
return retval;
|
|
}
|
|
|
|
int LedDeviceTpm2net::write(const std::vector<ColorRgb> &ledValues)
|
|
{
|
|
int retVal = 0;
|
|
|
|
int _thisPacketBytes = 0;
|
|
_tpm2ThisPacket = 1;
|
|
|
|
const uint8_t * rawdata = reinterpret_cast<const uint8_t *>(ledValues.data());
|
|
|
|
for (int rawIdx = 0; rawIdx < _tpm2ByteCount; rawIdx++)
|
|
{
|
|
if (rawIdx % _tpm2_max == 0) // start of new packet
|
|
{
|
|
_thisPacketBytes = (_tpm2ByteCount - rawIdx < _tpm2_max) ? _tpm2ByteCount % _tpm2_max : _tpm2_max;
|
|
// is this the last packet? ? ^^ last packet : ^^ earlier packets
|
|
|
|
_tpm2_buffer[0] = 0x9c; // Packet start byte
|
|
_tpm2_buffer[1] = 0xda; // Packet type Data frame
|
|
_tpm2_buffer[2] = (_thisPacketBytes >> 8) & 0xff; // Frame size high
|
|
_tpm2_buffer[3] = _thisPacketBytes & 0xff; // Frame size low
|
|
_tpm2_buffer[4] = _tpm2ThisPacket++; // Packet Number
|
|
_tpm2_buffer[5] = _tpm2TotalPackets; // Number of packets
|
|
}
|
|
|
|
_tpm2_buffer [6 + rawIdx%_tpm2_max] = rawdata[rawIdx];
|
|
|
|
// is this the last byte of last packet || last byte of other packets
|
|
if ( (rawIdx == _tpm2ByteCount-1) || (rawIdx %_tpm2_max == _tpm2_max-1) )
|
|
{
|
|
_tpm2_buffer [6 + rawIdx%_tpm2_max +1] = 0x36; // Packet end byte
|
|
retVal &= writeBytes(_thisPacketBytes+7, _tpm2_buffer);
|
|
}
|
|
}
|
|
return retVal;
|
|
}
|